summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authoraarne <aarne@chalmers.se>2011-03-13 19:49:41 +0000
committeraarne <aarne@chalmers.se>2011-03-13 19:49:41 +0000
commitb9ebd48a2c70cf1dd62b84dbdab3e4048593ddd3 (patch)
tree2dcc0e91855878fc16486447f15189fe2628afb0
parent7361ddea45727e80a79ba42af34e45f9641fc993 (diff)
smaller query grammars for MOLTO KRI
-rw-r--r--examples/query/small/Query.gf111
-rw-r--r--examples/query/small/QueryEng.gf179
-rw-r--r--examples/query/small/QueryFin.gf172
-rw-r--r--examples/query/small/QuerySwe.gf185
4 files changed, 647 insertions, 0 deletions
diff --git a/examples/query/small/Query.gf b/examples/query/small/Query.gf
new file mode 100644
index 000000000..532dc6a8e
--- /dev/null
+++ b/examples/query/small/Query.gf
@@ -0,0 +1,111 @@
+abstract Query = {
+
+flags
+ startcat = Move ;
+
+-- general query language, which can be specialized with any lexicon
+
+cat
+ Move ; -- top-level utterance, e.g. "give me all Bulgarian persons that work at Google"
+ Query ;
+ Answer ;
+ Set ; -- the set requested, e.g. "all persons"
+ Relation ; -- something of something, e.g. "subregion of Bulgaria"
+ Kind ; -- type of things, e.g. "person"
+ Property ; -- property of things, e.g. "employed at Google"
+ Individual ; -- one entity, e.g. "Google"
+ Activity ; -- action property, e.g. "work at Google"
+ Name ; -- person, company... e.g. "Eric Schmidt"
+ Loc ;
+ Org ;
+ Pers ;
+ [Individual] {2} ; -- list of entities, e.g. "Larry Page, Sergey Brin"
+
+fun
+ MQuery : Query -> Move ;
+ MAnswer : Answer -> Move ;
+
+ QSet : Set -> Query ; -- (give me | what are | which are | ) (S | the names of S | S's names)
+ QWhere : Set -> Query ; -- where are S
+ QInfo : Set -> Query ; -- (give me | ) (information about | all about) S
+ QCalled : Individual -> Query ; -- how is X (also | otherwise) (called | named | known) ;
+
+ AKind : Set -> Kind -> Answer ; -- S is a K
+ AProp : Set -> Property -> Answer ; -- S is P
+ AAct : Set -> Activity -> Answer ; -- S As
+
+ SAll : Kind -> Set ; -- all Ks | the Ks
+ SOne : Kind -> Set ; -- one K
+ SIndef : Kind -> Set ; -- a K
+ SPlural : Kind -> Set ; -- Ks
+ SOther : Kind -> Set ; -- other Ks
+ SInd : Individual -> Set ; -- X
+ SInds : [Individual] -> Set ; -- X and Y
+
+ KRelSet : Relation -> Set -> Kind ; -- R of S | S's R
+ KRelsSet : Relation -> Relation -> Set -> Kind ; -- R and Q of S
+ KRelKind : Kind -> Relation -> Set -> Kind ; -- K that is R of S
+ KRelPair : Kind -> Relation -> Kind ; -- S's with their R's
+ KProp : Property -> Kind -> Kind ; -- P K | K that is P
+ KAct : Activity -> Kind -> Kind ; -- K that Ps
+ KRel : Relation -> Kind ; -- R ---??
+
+ IName : Name -> Individual ;
+
+ NLoc : Loc -> Name ;
+ NOrg : Org -> Name ;
+ NPers : Pers -> Name ;
+
+ ACalled : [Individual] -> Activity ;
+
+
+-- the test lexicon
+
+cat
+ Country ;
+ JobTitle ;
+fun
+ NCountry : Country -> Name ;
+ PCountry : Country -> Property ;
+
+ Located : Loc -> Property ;
+ Employed : Org -> Property ;
+
+ Work : Org -> Activity ;
+ HaveTitle : JobTitle -> Org -> Activity ;
+
+ Organization : Kind ;
+ Place : Kind ;
+ Person : Kind ;
+
+ Location : Relation ;
+ Region : Relation ;
+ Subregion : Relation ;
+
+ RName : Relation ;
+ RNickname : Relation ;
+
+-- JobTitles
+ JobTitle1 : JobTitle ;
+ JobTitle2 : JobTitle ;
+ JobTitle3 : JobTitle ;
+ JobTitle4 : JobTitle ;
+
+-- Locations
+ Location1 : Loc ;
+ Location2 : Loc ;
+ Location3 : Loc ;
+ Location4 : Loc ;
+
+-- Organizations
+ Organization1 : Org ;
+ Organization2 : Org ;
+ Organization3 : Org ;
+ Organization4 : Org ;
+
+-- Persons
+ Person1 : Pers ;
+ Person2 : Pers ;
+ Person3 : Pers ;
+ Person4 : Pers ;
+}
diff --git a/examples/query/small/QueryEng.gf b/examples/query/small/QueryEng.gf
new file mode 100644
index 000000000..bce50ffce
--- /dev/null
+++ b/examples/query/small/QueryEng.gf
@@ -0,0 +1,179 @@
+--# -path=.:alltenses
+
+concrete QueryEng of Query = open
+ ParadigmsEng,
+ IrregEng,
+ SyntaxEng,
+ ExtraEng,
+ (L = LangEng),
+ Prelude
+in {
+
+lincat
+ Move = Utt ; ---- Text ;
+ Query = Utt ;
+ Answer = Utt ;
+ Set = NP ;
+ Relation = {cn : CN ; prep : Prep} ;
+ Kind = CN ;
+ Property = AP ; ---- {vp : VP ; typ : PropTyp} ;
+ Individual = NP ;
+ Activity = VP ;
+ Name = NP ;
+ Loc = NP ;
+ Org = NP ;
+ Pers = NP ;
+ [Individual] = [NP] ;
+
+lin
+ MQuery q = q ; ---- mkText (mkPhr q) questMarkPunct ;
+ MAnswer a = a ; ---- mkText (mkPhr a) fullStopPunct ;
+
+ QSet s =
+ let
+ ss : NP = s
+ | mkNP (mkNP thePl_Det L.name_N) (mkAdv possess_Prep s)
+ ---- s's names
+ in
+ mkUtt (mkImp (mkVP give_V3 (mkNP i_Pron) ss))
+ | mkUtt (mkQS (mkQCl (L.CompIP whatSg_IP) ss))
+ | mkUtt (mkQS (mkQCl (L.CompIP (L.IdetIP (mkIDet which_IQuant))) ss))
+ | mkUtt ss ;
+
+ QWhere s = mkUtt (mkQS (mkQCl where_IAdv s)) ;
+ QInfo s =
+ let
+ info : NP = mkNP (all_NP | (mkNP information_N)) (mkAdv about_Prep s) ;
+ in
+ mkUtt (mkImp (mkVP give_V3 (mkNP i_Pron) info))
+ | mkUtt info ;
+
+ QCalled i = mkUtt (mkQS (mkQCl how_IAdv (mkCl i (mkVP also_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) ;
+
+ SAll k = mkNP all_Predet (mkNP aPl_Det k) | mkNP thePl_Det k ;
+ SOne k = mkNP n1_Numeral k ;
+ SIndef k = mkNP a_Det k ;
+ SPlural k = mkNP aPl_Det k ;
+ SOther k = mkNP aPl_Det (mkCN other_A k) ;
+ SInd i = i ;
+ SInds is = mkNP and_Conj is ;
+
+ KRelSet r s =
+ mkCN r.cn (mkAdv r.prep s) ;
+ ---- | S's R
+
+---- KRelsSet r q s =
+---- mkCN r.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)) ;
+ KRel r = r.cn ;
+
+ IName n = n ;
+ NLoc n = n ;
+ NOrg n = n ;
+ NPers n = n;
+
+ ACalled is = mkVP also_AdV (mkVP (mkAP (mkA2 called_A []) (mkNP or_Conj is))) ;
+
+ BaseIndividual = mkListNP ;
+ ConsIndividual = mkListNP ;
+
+oper
+-- structural words
+ about_Prep = mkPrep "about" ;
+ all_NP = mkNP (mkPN "all") ; ---
+ also_AdV = mkAdV "also" | mkAdV "otherwise" ;
+ 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" ;
+
+-- lexical constructors
+ mkName : Str -> NP =
+ \s -> mkNP (mkPN s) ;
+ mkRelation : Str -> {cn : CN ; prep : Prep} =
+ \s -> {cn = mkCN (mkN s) ; prep = possess_Prep} ;
+
+-- lexicon
+
+lincat
+ Country = {np : NP ; a : A} ;
+ JobTitle = CN ;
+lin
+ NCountry c = c.np ;
+ PCountry c = mkAP c.a ;
+
+ Located i =
+ mkAP (mkA2 (mkA "located") in_Prep) i
+ | mkAP (mkA2 (mkA "situated") in_Prep) i ;
+
+ Employed i =
+ 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 =
+ 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 (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) ;
+
+ Organization = mkCN (mkN "organization") ;
+ Place = mkCN (mkN "place") ;
+ Person =
+ mkCN (mkN "person" "people")
+ | mkCN (mkN "person") ;
+
+ Location = mkRelation "location" ;
+ Region = mkRelation "region" ;
+ Subregion = mkRelation "subregion" ;
+ RName = mkRelation "name" ;
+ RNickname = mkRelation "nickname" ;
+
+-- JobTitles
+ JobTitle1 = mkCN (mkN "'JobTitle1") ;
+ JobTitle2 = mkCN (mkN "'JobTitle2") ;
+ JobTitle3 = mkCN (mkN "'JobTitle3") ;
+ JobTitle4 = mkCN (mkN "'JobTitle4") ;
+
+-- Locations
+ Location1 = mkName "'Location1" ;
+ Location2 = mkName "'Location2" ;
+ Location3 = mkName "'Location3" ;
+ Location4 = mkName "'Location4" ;
+
+-- Organizations
+ Organization1 = mkName "'Organization1" ;
+ Organization2 = mkName "'Organization2" ;
+ Organization3 = mkName "'Organization3" ;
+ Organization4 = mkName "'Organization4" ;
+
+-- Persons
+ Person1 = mkName "'Person1" ;
+ Person2 = mkName "'Person2" ;
+ Person3 = mkName "'Person3" ;
+ Person4 = mkName "'Person4" ;
+
+oper
+ mkCountry : Str -> Str -> {np : NP ; a : A} =
+ \n,a -> {np = mkNP (mkPN n) ; a = mkA a} ;
+
+}
diff --git a/examples/query/small/QueryFin.gf b/examples/query/small/QueryFin.gf
new file mode 100644
index 000000000..8d8b6c426
--- /dev/null
+++ b/examples/query/small/QueryFin.gf
@@ -0,0 +1,172 @@
+--# -path=.:alltenses
+
+concrete QueryFin of Query = open
+ ParadigmsFin,
+ SyntaxFin,
+ ExtraFin,
+ (L = LangFin),
+ Prelude
+in {
+
+lincat
+ Move = Utt ; ---- Text ;
+ Query = Utt ;
+ Answer = Utt ;
+ Set = NP ;
+ Relation = {cn : CN ; prep : Prep} ;
+ Kind = CN ;
+ Property = AP ; ---- {vp : VP ; typ : PropTyp} ;
+ Individual = NP ;
+ Activity = VP ;
+ Name = NP ;
+ Loc = NP ;
+ Org = NP ;
+ Pers = NP ;
+ [Individual] = [NP] ;
+
+lin
+ MQuery q = q ; ---- mkText (mkPhr q) questMarkPunct ;
+ MAnswer a = a ; ---- mkText (mkPhr a) fullStopPunct ;
+
+ QSet s =
+ let
+ ss : NP = s
+ | mkNP (mkNP thePl_Det L.name_N) (mkAdv possess_Prep s)
+ ---- s's names
+ in
+ mkUtt (mkImp (mkVP give_V3 (mkNP i_Pron) ss))
+ | mkUtt (mkQS (mkQCl (L.CompIP whatSg_IP) ss))
+ | mkUtt (mkQS (mkQCl (L.CompIP (L.IdetIP (mkIDet which_IQuant))) ss))
+ | mkUtt ss ;
+
+ QWhere s = mkUtt (mkQS (mkQCl where_IAdv s)) ;
+ QInfo s =
+ let
+ info : NP = mkNP (all_NP | (mkNP information_N)) (mkAdv about_Prep s) ;
+ in
+ mkUtt (mkImp (mkVP give_V3 (mkNP i_Pron) info))
+ | mkUtt info ;
+
+ QCalled i = mkUtt (mkQS (mkQCl how_IAdv (mkCl i (mkVP also_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) ;
+
+ SAll k = mkNP all_Predet (mkNP aPl_Det k) | mkNP thePl_Det k ;
+ SOne k = mkNP n1_Numeral k ;
+ SIndef k = mkNP a_Det k ;
+ SPlural k = mkNP aPl_Det k ;
+ SOther k = mkNP aPl_Det (mkCN other_A k) ;
+ SInd i = i ;
+ SInds is = mkNP and_Conj is ;
+
+ KRelSet r s =
+ mkCN r.cn (mkAdv r.prep s) ;
+ ---- | S's R
+
+---- KRelsSet r q s =
+---- mkCN r.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)) ;
+ KRel r = r.cn ;
+
+ IName n = n ;
+ NLoc n = n ;
+ NOrg n = n ;
+ NPers n = n;
+
+ ACalled is = mkVP also_AdV (mkVP (mkAP (mkA2 called_A (casePrep translative)) (mkNP or_Conj is))) ;
+
+ BaseIndividual = mkListNP ;
+ ConsIndividual = mkListNP ;
+
+oper
+-- structural words
+ about_Prep = casePrep elative ;
+ all_NP = mkNP (mkPN (mkN "kaikki" "kaiken")) ; ---
+ also_AdV = ss "myös" ;
+ as_Prep = casePrep essive ;
+ at_Prep = casePrep adessive ;
+ called_A = mkA "kutsuttu" ;
+ give_V3 = mkV3 (mkV "antaa") (casePrep allative) (casePrep nominative) ;
+ information_N = mkN "tieto" ;
+ other_A = mkA "muu" ;
+ that_RP = which_RP ;
+
+-- lexical constructors
+ mkName : Str -> NP =
+ \s -> mkNP (mkPN s) ;
+ mkRelation : Str -> {cn : CN ; prep : Prep} =
+ \s -> {cn = mkCN (mkN s) ; prep = possess_Prep} ;
+
+-- lexicon
+
+lincat
+ Country = {np : NP ; a : A} ;
+ JobTitle = CN ;
+lin
+ NCountry c = c.np ;
+ PCountry c = mkAP c.a ;
+
+ Located i =
+ mkAP (mkA2 (mkA "sijaitseva") in_Prep) i ;
+
+ Employed i = mkAP (mkA2 (mkA "töissä") at_Prep) i ;
+
+ Work i =
+ mkVP (mkV2 (mkV "työskennellä") at_Prep) i ;
+
+ HaveTitle t i =
+ mkVP (mkVP (mkNP 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) ;
+
+ Organization = mkCN (mkN "organisaatio" "organisaatioita") ;
+ Place = mkCN (mkN "paikka") ;
+ Person =
+ mkCN (mkN "henkilö" "henkilöitä") ;
+
+ Location = mkRelation "sijainti" ;
+ Region = mkRelation "alue" ;
+ Subregion = mkRelation "alue" ;
+ RName = mkRelation "nimi" ;
+ RNickname = mkRelation "lempinimi" ;
+
+-- JobTitles
+ JobTitle1 = mkCN (mkN "'JobTitle1") ;
+ JobTitle2 = mkCN (mkN "'JobTitle2") ;
+ JobTitle3 = mkCN (mkN "'JobTitle3") ;
+ JobTitle4 = mkCN (mkN "'JobTitle4") ;
+
+-- Locations
+ Location1 = mkName "'Location1" ;
+ Location2 = mkName "'Location2" ;
+ Location3 = mkName "'Location3" ;
+ Location4 = mkName "'Location4" ;
+
+-- Organizations
+ Organization1 = mkName "'Organization1" ;
+ Organization2 = mkName "'Organization2" ;
+ Organization3 = mkName "'Organization3" ;
+ Organization4 = mkName "'Organization4" ;
+
+-- Persons
+ Person1 = mkName "'Person1" ;
+ Person2 = mkName "'Person2" ;
+ Person3 = mkName "'Person3" ;
+ Person4 = mkName "'Person4" ;
+
+oper
+ mkCountry : Str -> Str -> {np : NP ; a : A} =
+ \n,a -> {np = mkNP (mkPN n) ; a = mkA a} ;
+
+}
diff --git a/examples/query/small/QuerySwe.gf b/examples/query/small/QuerySwe.gf
new file mode 100644
index 000000000..17f89352c
--- /dev/null
+++ b/examples/query/small/QuerySwe.gf
@@ -0,0 +1,185 @@
+--# -path=.:alltenses
+
+concrete QuerySwe of Query = open
+ ParadigmsSwe,
+ IrregSwe,
+ SyntaxSwe,
+ ExtraSwe,
+ (M = MakeStructuralSwe),
+ (L = LangSwe),
+ Prelude
+in {
+
+flags coding = utf8 ;
+
+lincat
+ Move = Utt ; ---- Text ;
+ Query = Utt ;
+ Answer = Utt ;
+ Set = NP ;
+ Relation = {cn : CN ; prep : Prep} ;
+ Kind = CN ;
+ Property = AP ; ---- {vp : VP ; typ : PropTyp} ;
+ Individual = NP ;
+ Activity = VP ;
+ Name = NP ;
+ Loc = NP ;
+ Org = NP ;
+ Pers = NP ;
+ [Individual] = [NP] ;
+
+lin
+ MQuery q = q ; ---- mkText (mkPhr q) questMarkPunct ;
+ MAnswer a = a ; ---- mkText (mkPhr a) fullStopPunct ;
+
+ QSet s =
+ let
+ ss : NP = s
+ | mkNP (mkNP thePl_Det L.name_N) (mkAdv on_Prep s)
+ ---- s's names
+ in
+ mkUtt (mkImp (mkVP give_V3 (mkNP i_Pron) ss))
+ | mkUtt (mkQS (mkQCl (L.CompIP whatSg_IP) ss))
+ | mkUtt (mkQS (mkQCl (L.CompIP (L.IdetIP (mkIDet which_IQuant))) ss))
+ | mkUtt ss ;
+
+ QWhere s = mkUtt (mkQS (mkQCl where_IAdv s)) ;
+ QInfo s =
+ let
+ info : NP = mkNP (all_NP | (mkNP information_N)) (mkAdv about_Prep s) ;
+ in
+ mkUtt (mkImp (mkVP give_V3 (mkNP i_Pron) info))
+ | mkUtt info ;
+
+ QCalled i = mkUtt (mkQS (mkQCl how_IAdv (mkCl i (mkVP also_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) ;
+
+ SAll k = mkNP all_Predet (mkNP aPl_Det k) | mkNP thePl_Det k ;
+ SOne k = mkNP n1_Numeral k ;
+ SIndef k = mkNP a_Det k ;
+ SPlural k = mkNP aPl_Det k ;
+ SOther k = mkNP aPl_Det (mkCN other_A k) ;
+ SInd i = i ;
+ SInds is = mkNP and_Conj is ;
+
+ KRelSet r s =
+ mkCN r.cn (mkAdv r.prep s) ;
+ ---- | S's R
+
+---- KRelsSet r q s =
+---- mkCN r.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 (sina 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)) ;
+ KRel r = r.cn ;
+
+ IName n = n ;
+ NLoc n = n ;
+ NOrg n = n ;
+ NPers n = n;
+
+ ACalled is = mkVP also_AdV (mkVP (mkAP (mkA2 called_A for_Prep) (mkNP or_Conj is))) ;
+
+ BaseIndividual = mkListNP ;
+ ConsIndividual = mkListNP ;
+
+oper
+-- structural words
+ about_Prep = mkPrep "om" ;
+ all_NP = mkNP (mkPN "allt" neutrum) ; ---
+ also_AdV = mkAdV "också" | mkAdV "annars" ;
+ as_Prep = mkPrep "som" ;
+ at_Prep = mkPrep "på" ;
+ called_A = mkA "kallad" "kallat" "kallade" ;
+ give_V3 = mkV3 giva_V ;
+ information_N = mkN "information" "informationer" ;
+ other_A = compoundA (mkA "annan" "annat" "andra" "andra" "andra") ;
+ that_RP = which_RP ;
+
+ sina : CN -> NP = \cn -> mkNP (M.mkPredet "sin" "sitt" "sina") (mkNP a_Quant plNum cn) ; ---- should be in ExtraSwe
+
+-- lexical constructors
+ mkName : Str -> NP =
+ \s -> mkNP (mkPN s) ;
+ mkRelation : N -> Prep -> {cn : CN ; prep : Prep} =
+ \s,p -> {cn = mkCN s ; prep = p} ;
+
+-- lexicon
+
+lincat
+ Country = {np : NP ; a : A} ;
+ JobTitle = CN ;
+lin
+ NCountry c = c.np ;
+ PCountry c = mkAP c.a ;
+
+ Located i =
+ mkAP (mkA2 (mkA "belägen" "beläget") in_Prep) i ;
+-- | mkAP (mkA2 (mkA "situated") in_Prep) i ;
+
+ Employed i =
+ mkAP (mkA2 (mkA "anställd") by8agent_Prep) i
+-- | mkAP (mkA2 (mkA "paid") by8agent_Prep) i
+-- | mkAP (mkA2 (mkA "aktiv") at_Prep) i
+ | mkAP (mkA2 (mkA "professionellt aktiv") at_Prep) i ;
+
+ Work i =
+ mkVP (mkV2 (mkV "jobba") at_Prep) i
+ | mkVP (mkV2 (mkV "arbeta") in_Prep) i ;
+
+ HaveTitle t i =
+ mkVP (mkVP (mkAP (mkA2 (mkA "anställd") as_Prep) (mkNP t))) (mkAdv at_Prep i)
+ | mkVP (mkVP (mkV2 (mkV "jobba") as_Prep) (mkNP t)) (mkAdv at_Prep i) ;
+-- | mkVP (mkVP have_V2 (mkNP the_Det (mkCN (mkN2 (mkN "titel" "titlar") po) (mkNP t)))) (mkAdv at_Prep i) ;
+
+ Organization = mkCN (mkN "organisation" "organisationer") ;
+ Place = mkCN (mkN "plats" "platser") ;
+ Person =
+ mkCN (mkN "person" "personer") ;
+-- | mkCN (mkN "person" "folk") ;
+
+ Location = mkRelation (mkN "läge" "lägen") possess_Prep ;
+ Region = mkRelation (mkN "region" "regioner") in_Prep ;
+ Subregion = mkRelation (mkN "delregion" "delregioner") in_Prep ;
+ RName = mkRelation (mkN "namn" "namn") on_Prep ;
+ RNickname = mkRelation (mkN "tilläggsnamn" "tilläggsnamn") on_Prep ;
+
+-- JobTitles
+ JobTitle1 = mkCN (mkN "'JobTitle1") ;
+ JobTitle2 = mkCN (mkN "'JobTitle2") ;
+ JobTitle3 = mkCN (mkN "'JobTitle3") ;
+ JobTitle4 = mkCN (mkN "'JobTitle4") ;
+
+-- Locations
+ Location1 = mkName "'Location1" ;
+ Location2 = mkName "'Location2" ;
+ Location3 = mkName "'Location3" ;
+ Location4 = mkName "'Location4" ;
+
+-- Organizations
+ Organization1 = mkName "'Organization1" ;
+ Organization2 = mkName "'Organization2" ;
+ Organization3 = mkName "'Organization3" ;
+ Organization4 = mkName "'Organization4" ;
+
+-- Persons
+ Person1 = mkName "'Person1" ;
+ Person2 = mkName "'Person2" ;
+ Person3 = mkName "'Person3" ;
+ Person4 = mkName "'Person4" ;
+
+oper
+ mkCountry : Str -> Str -> {np : NP ; a : A} =
+ \n,a -> {np = mkNP (mkPN n neutrum) ; a = mkA a} ;
+
+}