summaryrefslogtreecommitdiff
path: root/examples/query/QueryEng.gf
diff options
context:
space:
mode:
authoraarne <aarne@chalmers.se>2010-06-19 10:29:06 +0000
committeraarne <aarne@chalmers.se>2010-06-19 10:29:06 +0000
commita0f2ff0772a112b323c95f6b236e3cd3d349e579 (patch)
treec65aa36c9bd0a7f5dbd82d78c7375706da3b34b3 /examples/query/QueryEng.gf
parent0493f640d3fd649468f128407894dbbc9bddc767 (diff)
query language extended and generalized
Diffstat (limited to 'examples/query/QueryEng.gf')
-rw-r--r--examples/query/QueryEng.gf133
1 files changed, 103 insertions, 30 deletions
diff --git a/examples/query/QueryEng.gf b/examples/query/QueryEng.gf
index 2ffb28d6f..8f0756e77 100644
--- a/examples/query/QueryEng.gf
+++ b/examples/query/QueryEng.gf
@@ -6,30 +6,32 @@ concrete QueryEng of Query = open
SyntaxEng,
ExtraEng,
(L = LangEng),
+ (M = MakeStructuralEng),
Prelude
in {
lincat
Move = Utt ; ---- Text ;
Query = Utt ;
- Answer = Utt ;
+ Answer = Cl ; -- Utt ;
Set = NP ;
Relation = {cn : CN ; prep : Prep} ;
Kind = CN ;
- Property = AP ; ---- {vp : VP ; typ : PropTyp} ;
+ Property = {ap : AP ; vp : VP} ;
Individual = NP ;
- Activity = VP ;
Name = NP ;
[Individual] = [NP] ;
lin
MQuery q = q ; ---- mkText (mkPhr q) questMarkPunct ;
- MAnswer a = a ; ---- mkText (mkPhr a) fullStopPunct ;
+ MAnswer a = mkUtt a ; ---- mkText (mkPhr a) fullStopPunct ;
QSet s =
let
ss : NP = s
+ | mkNP (mkNP theSg_Det L.name_N) (mkAdv possess_Prep s)
| mkNP (mkNP thePl_Det L.name_N) (mkAdv possess_Prep s)
+ | mkNP (GenNP s) sgNum L.name_N
| mkNP (GenNP s) plNum L.name_N ;
in
mkUtt (mkImp (mkVP give_V3 ss (mkNP i_Pron)))
@@ -37,24 +39,43 @@ lin
| mkUtt (mkQS (mkQCl (L.CompIP (L.IdetIP (mkIDet which_IQuant))) ss))
| mkUtt ss ;
- QWhere s = mkUtt (mkQS (mkQCl where_IAdv s)) ;
+ QWhat k p =
+ mkUtt (mkQS (mkQCl (mkIP (what_IQuant | which_IQuant) (sgNum | plNum) k) p.vp)) ;
+ QWho p = mkUtt (mkQS (mkQCl whoSg_IP p.vp)) ;
+
+ QWhere s =
+ mkUtt (mkQS (mkQCl where_IAdv s))
+ | mkUtt (mkQS (mkQCl where_IAdv (mkCl s (mkA "located" | mkA "situated")))) ;
+ QRel r s =
+ mkUtt
+ (mkImp (mkVP give_V3 (mkNP and_Conj s (mkNP (mkQuant they_Pron) plNum r.cn)) (mkNP i_Pron)))
+ | mkUtt (mkQS (mkQCl (mkIP what_IQuant plNum r.cn) s have_V2))
+ | mkUtt (mkQS (mkQCl whatSg_IP
+ (mkClSlash (mkClSlash s have_V2) (mkAdv as_Prep (mkNP aPl_Det r.cn))))) ;
QInfo s =
let
info : NP = mkNP (all_NP | (mkNP information_N)) (mkAdv about_Prep s) ;
in
mkUtt (mkImp (mkVP give_V3 info (mkNP i_Pron)))
+ | mkUtt (mkQCl whatSg_IP
+ (mkClSlash (mkClSlash (mkNP youSg_Pron) (mkV2 know_V)) (mkAdv about_Prep s)))
| mkUtt info ;
- QCalled i = mkUtt (mkQS (mkQCl how_IAdv (mkCl i (mkVP also_AdV (mkVP called_A))))) ;
+ QCalled i = mkUtt (mkQS (mkQCl how_IAdv (mkCl i
+ (mkVP (also_AdV | otherwise_AdV) (mkVP called_A))))) ;
- AKind s k = mkUtt (mkCl s (mkNP aPl_Det k)) ; ---- a, fun of s
- AProp s p = mkUtt (mkCl s p) ;
- AAct s p = mkUtt (mkCl s p) ;
+ QWhether a = mkUtt (mkQS a) ;
+
+ AKind s k = (mkCl s (L.UseComp (L.CompCN k))) ;
+ AInd s i = (mkCl s i) ;
+ AName s n = (mkCl n (mkNP the_Det (mkCN L.name_N (mkAdv possess_Prep s)))) ;
+ AProp s p = (mkCl s p.vp) ;
SAll k = mkNP all_Predet (mkNP aPl_Det k) | mkNP thePl_Det k ;
- SRel s r = mkNP (GenNP s) plNum r.cn ;
+ SRel s r = mkNP (GenNP s) plNum r.cn | mkNP (GenNP s) sgNum r.cn ;
SOne k = mkNP n1_Numeral k ;
SIndef k = mkNP a_Det k ;
+ SDef k = mkNP the_Det k ;
SPlural k = mkNP aPl_Det k ;
SOther k = mkNP aPl_Det (mkCN other_A k) ;
SInd i = i ;
@@ -63,23 +84,24 @@ lin
KRelSet r s =
mkCN r.cn (mkAdv r.prep s) ;
----- KRelsSet r q s =
----- mkCN r.cn (mkAdv r.prep s) ;
+ KRelsSet r q s =
+ mkCN (ConjCN and_Conj (BaseCN r.cn q.cn)) (mkAdv r.prep s) ;
KRelKind k r s =
mkCN k (mkRS (mkRCl that_RP (mkVP (mkNP aPl_Det (mkCN r.cn (mkAdv r.prep s)))))) ;
KRelPair k r = mkCN k (mkAdv with_Prep (mkNP (mkQuant they_Pron) plNum r.cn)) ;
KProp p k =
- mkCN p k
- | mkCN k (mkRS (mkRCl that_RP (mkVP p))) ;
- KAct p k =
- mkCN k (mkRS (mkRCl that_RP p)) ;
+ mkCN p.ap k
+ | mkCN k (mkRS (mkRCl that_RP p.vp)) ;
KRel r = r.cn ;
IName n = n ;
- ACalled is = mkVP also_AdV (mkVP (mkAP (mkA2 called_A []) (mkNP or_Conj is))) ;
+ PCalled i = propCalled i ;
+ PCalleds is = propCalled (mkNP or_Conj is) ;
+
+ PIs i = propVP (mkVP i) ;
BaseIndividual = mkListNP ;
ConsIndividual = mkListNP ;
@@ -88,13 +110,17 @@ oper
-- structural words
about_Prep = mkPrep "about" ;
all_NP = mkNP (mkPN "all") ; ---
- also_AdV = mkAdV "also" | mkAdV "otherwise" ;
+ also_AdV = mkAdV "also" ;
+ also_AdA = mkAdA "also" ;
as_Prep = mkPrep "as" ;
at_Prep = mkPrep "at" ;
called_A = mkA "called" | mkA "named" ;
give_V3 = mkV3 give_V ;
information_N = mkN "information" ;
other_A = mkA "other" ;
+ otherwise_AdV = mkAdV "otherwise" ;
+ otherwise_AdA = mkAdA "otherwise" ;
+ what_IQuant = M.mkIQuant "what" "what" ;
-- lexical constructors
mkName : Str -> NP =
@@ -102,6 +128,20 @@ oper
mkRelation : Str -> {cn : CN ; prep : Prep} =
\s -> {cn = mkCN (mkN s) ; prep = possess_Prep} ;
+ propAP : AP -> {ap : AP ; vp : VP} = \ap -> {
+ ap = ap ;
+ vp = mkVP ap
+ } ;
+
+ propVP : VP -> {ap : AP ; vp : VP} = \vp -> {
+ ap = PartVP vp ;
+ vp = vp
+ } ;
+
+ propCalled : NP -> {ap : AP ; vp : VP} = \i ->
+ propAP (mkAP (also_AdA | otherwise_AdA) (mkAP (mkA2 called_A []) i)) ;
+
+
-- lexicon
lincat
@@ -109,26 +149,52 @@ lincat
JobTitle = CN ;
lin
NCountry c = c.np ;
- PCountry c = mkAP c.a ;
+ PCountry c = propAP (mkAP c.a) ;
- Located i =
+ Located i = propAP (
mkAP (mkA2 (mkA "located") in_Prep) i
- | mkAP (mkA2 (mkA "situated") in_Prep) i ;
+ | mkAP (mkA2 (mkA "situated") in_Prep) i
+ ) ;
+
+ In i = propVP (mkVP (mkAdv in_Prep i)) ;
- Employed i =
+ Employed i = propAP (
mkAP (mkA2 (mkA "employed") by8agent_Prep) i
| mkAP (mkA2 (mkA "paid") by8agent_Prep) i
| mkAP (mkA2 (mkA "active") at_Prep) i
- | mkAP (mkA2 (mkA "professionally active") at_Prep) i ;
-
- Work i =
+ | mkAP (mkA2 (mkA "professionally active") at_Prep) i
+ )
+ |
+ propVP (
mkVP (mkV2 (mkV "work") at_Prep) i
- | mkVP (mkV2 (mkV "collaborate") in_Prep) i ;
-
- HaveTitle t i =
- mkVP (mkVP (mkAP (mkA2 (mkA "employed") as_Prep) (mkNP t))) (mkAdv at_Prep i)
+ | mkVP (mkV2 (mkV "collaborate") in_Prep) i
+ ) ;
+
+ HaveTitle t =
+ propAP (
+ mkAP (mkA2 (mkA "employed") as_Prep) (mkNP t)
+ )
+ |
+ propVP (
+ mkVP (mkNP a_Det t)
+ | mkVP (mkV2 (mkV "work") as_Prep) (mkNP t)
+-- | mkVP have_V2 (mkNP the_Det (mkCN (mkN2 (mkN "title")) (mkNP t)))
+ ) ;
+
+ HaveTitleAt t i =
+ propAP (
+ mkAP (mkA2 (mkA "employed") as_Prep) (mkNP (mkNP t) (mkAdv at_Prep i))
+ )
+ |
+ propVP (
+ mkVP (mkVP (mkNP a_Det t)) (mkAdv at_Prep i)
| mkVP (mkVP (mkV2 (mkV "work") as_Prep) (mkNP t)) (mkAdv at_Prep i)
- | mkVP (mkVP have_V2 (mkNP the_Det (mkCN (mkN2 (mkN "title")) (mkNP t)))) (mkAdv at_Prep i) ;
+-- | mkVP (mkVP have_V2 (mkNP the_Det (mkCN (mkN2 (mkN "title")) (mkNP t))))
+-- (mkAdv at_Prep i)
+ ) ;
+
+ Named n = propAP (mkAP (mkA2 (mkA "named") []) n) ;
+ Start n = propVP (mkVP (mkV2 "start" with_Prep) n) ;
Organization = mkCN (mkN "organization") ;
Place = mkCN (mkN "place") ;
@@ -141,6 +207,9 @@ lin
Subregion = mkRelation "subregion" | mkRelation "sub-region" ;
RName = mkRelation "name" ;
RNickname = mkRelation "nickname" ;
+ RJobTitle = mkRelation "job title" | mkRelation "job" | mkRelation "position" |
+ mkRelation "appointment" | mkRelation "job position" | mkRelation "mandate" |
+ mkRelation "title" ;
USA = mkCountry "USA" "American" ;
Bulgaria = mkCountry "Bulgaria" "Bulgarian" ;
@@ -148,6 +217,7 @@ lin
OblastSofiya = mkName "Oblast Sofiya" ;
CEO = mkCN (mkN "CEO") ;
+ ChiefInformationOfficer = mkCN (mkN "Chief Information Officer") ;
Microsoft = mkName "Microsoft" ;
Google = mkName "Google" ;
@@ -157,6 +227,9 @@ lin
EricSchmidt = mkName "Eric Schmidt" ;
MarissaMayer = mkName "Marissa Mayer" ;
UdiManber = mkName "Udi Manber" ;
+ CarlGustavJung = mkName "Carl Gustav Jung" ;
+ Jung = mkName "Jung" ;
+ BenFried = mkName "Ben Fried" ;
oper
mkCountry : Str -> Str -> {np : NP ; a : A} =