mirror of
https://github.com/GrammaticalFramework/gf-core.git
synced 2026-04-23 03:32:51 -06:00
some fixes in QuerySwe; a first version of QueryFre
This commit is contained in:
@@ -2,7 +2,7 @@ interface LexQuery = open Syntax in {
|
|||||||
|
|
||||||
oper
|
oper
|
||||||
located_A : A ;
|
located_A : A ;
|
||||||
give_V3 : V3 ;
|
giveMe : NP -> VP ;
|
||||||
know_V2 : V2 ;
|
know_V2 : V2 ;
|
||||||
|
|
||||||
-- structural words
|
-- structural words
|
||||||
|
|||||||
@@ -4,7 +4,7 @@ instance LexQueryEng of LexQuery =
|
|||||||
oper
|
oper
|
||||||
located_A : A = mkA "located" | mkA "situated" ;
|
located_A : A = mkA "located" | mkA "situated" ;
|
||||||
|
|
||||||
give_V3 : V3 = mkV3 give_V ;
|
giveMe : NP -> VP = \np -> mkVP (mkV3 give_V) (mkNP i_Pron) np ;
|
||||||
know_V2 = mkV2 know_V ;
|
know_V2 = mkV2 know_V ;
|
||||||
|
|
||||||
-- structural words
|
-- structural words
|
||||||
|
|||||||
32
examples/query/LexQueryFre.gf
Normal file
32
examples/query/LexQueryFre.gf
Normal file
@@ -0,0 +1,32 @@
|
|||||||
|
instance LexQueryFre of LexQuery =
|
||||||
|
open SyntaxFre, (M = MakeStructuralFre), ParadigmsFre, ExtraFre, IrregFre in {
|
||||||
|
|
||||||
|
oper
|
||||||
|
located_A : A = mkA "situé" ;
|
||||||
|
|
||||||
|
giveMe = \np -> mkVP (mkV2 (mkV "montrer")) np ; ---
|
||||||
|
know_V2 = connaître_V2 ;
|
||||||
|
|
||||||
|
-- structural words
|
||||||
|
about_Prep : Prep = mkPrep "sur" ;
|
||||||
|
all_NP : NP = mkNP (mkPN "tout") ; ---
|
||||||
|
also_AdV : AdV = mkAdV "aussi" ;
|
||||||
|
also_AdA : AdA = mkAdA "aussi" ;
|
||||||
|
as_Prep : Prep = mkPrep "pour" ; --- only used for "vad har X för Y"
|
||||||
|
at_Prep : Prep = mkPrep "chez" ; --- | mkPrep "hos" | mkPrep "vid" ;
|
||||||
|
that_RP = which_RP ;
|
||||||
|
|
||||||
|
participlePropCN : Prop -> CN -> CN = variants {} ;
|
||||||
|
|
||||||
|
vpAP _ = mkAP (mkA "nonexistant") ; --- not used, see LexQuery.participlePropCN
|
||||||
|
|
||||||
|
called_A : A = mkA "appelé" ;
|
||||||
|
|
||||||
|
information_N : N = mkN "information" feminine ;
|
||||||
|
other_A : A = prefixA (mkA "autre") ;
|
||||||
|
otherwise_AdV : AdV = mkAdV "autrement" ;
|
||||||
|
otherwise_AdA : AdA = mkAdA "autrement" ;
|
||||||
|
what_IQuant : IQuant = which_IQuant ;
|
||||||
|
|
||||||
|
|
||||||
|
}
|
||||||
@@ -4,7 +4,7 @@ instance LexQuerySwe of LexQuery =
|
|||||||
oper
|
oper
|
||||||
located_A : A = compoundA (mkA "belägen" "beläget" "belägna" [] []) ;
|
located_A : A = compoundA (mkA "belägen" "beläget" "belägna" [] []) ;
|
||||||
|
|
||||||
give_V3 : V3 = mkV3 giva_V ;
|
giveMe : NP -> VP = \np -> mkVP (mkV3 giva_V) (mkNP i_Pron) np ;
|
||||||
know_V2 = mkV2 veta_V ;
|
know_V2 = mkV2 veta_V ;
|
||||||
|
|
||||||
-- structural words
|
-- structural words
|
||||||
@@ -12,7 +12,7 @@ oper
|
|||||||
all_NP : NP = mkNP (mkPN "allt") ; ---
|
all_NP : NP = mkNP (mkPN "allt") ; ---
|
||||||
also_AdV : AdV = mkAdV "också" ;
|
also_AdV : AdV = mkAdV "också" ;
|
||||||
also_AdA : AdA = mkAdA "även" ;
|
also_AdA : AdA = mkAdA "även" ;
|
||||||
as_Prep : Prep = mkPrep "som" ;
|
as_Prep : Prep = mkPrep "för" ; --- only used for "vad har X för Y"
|
||||||
at_Prep : Prep = mkPrep "på" ; --- | mkPrep "hos" | mkPrep "vid" ;
|
at_Prep : Prep = mkPrep "på" ; --- | mkPrep "hos" | mkPrep "vid" ;
|
||||||
that_RP = which_RP ;
|
that_RP = which_RP ;
|
||||||
|
|
||||||
|
|||||||
131
examples/query/QueryFre.gf
Normal file
131
examples/query/QueryFre.gf
Normal file
@@ -0,0 +1,131 @@
|
|||||||
|
--# -path=.:present
|
||||||
|
|
||||||
|
concrete QueryFre of Query = QueryI - [namePrep, propCalled, SFun] with
|
||||||
|
(Syntax = SyntaxFre),
|
||||||
|
(Lang = LangFre),
|
||||||
|
(LexQuery = LexQueryFre) **
|
||||||
|
open
|
||||||
|
LexQueryFre,
|
||||||
|
ParadigmsFre,
|
||||||
|
IrregFre,
|
||||||
|
SyntaxFre,
|
||||||
|
ExtraFre,
|
||||||
|
(L = LangFre),
|
||||||
|
(M = MakeStructuralFre),
|
||||||
|
Prelude
|
||||||
|
in {
|
||||||
|
|
||||||
|
-- deviations from functor
|
||||||
|
oper
|
||||||
|
-- prep not "av"
|
||||||
|
namePrep = on_Prep ;
|
||||||
|
-- verb "heta"
|
||||||
|
propCalled : NP -> Prop = \i ->
|
||||||
|
propVP (mkVP (mkAdV "aussi") (mkVP (mkV2 (reflV (mkV "appeler")) for_Prep) i)) ;
|
||||||
|
|
||||||
|
lin
|
||||||
|
SFun s r = mkNP (mkNP the_Quant plNum r.cn) (mkAdv r.prep s) ;
|
||||||
|
|
||||||
|
|
||||||
|
-- lexicon
|
||||||
|
|
||||||
|
lin
|
||||||
|
Located = relAP (mkAP located_A) in_Prep ;
|
||||||
|
|
||||||
|
In = relVP useCopula in_Prep ;
|
||||||
|
|
||||||
|
Employed =
|
||||||
|
relAP (mkAP (mkA "employé")) by8agent_Prep
|
||||||
|
| relAP (mkAP (mkA "payé")) by8agent_Prep
|
||||||
|
| relAP (mkAP (mkA "actif")) at_Prep
|
||||||
|
| relAP (mkAP (mkA "professionnellement aktif")) at_Prep
|
||||||
|
| relVP (mkVP (mkV "travailler")) at_Prep
|
||||||
|
;
|
||||||
|
|
||||||
|
HaveTitle =
|
||||||
|
relAP (mkAP (mkA "employé")) som_Prep
|
||||||
|
| relVP useCopula noPrep
|
||||||
|
| relVP (mkVP (mkV "travailler")) som_Prep
|
||||||
|
| relVP (mkVP have_V2 (mkNP the_Det (mkCN (mkN2 (mkN "titre" masculine) noPrep))))
|
||||||
|
possess_Prep
|
||||||
|
;
|
||||||
|
|
||||||
|
EmployedAt s =
|
||||||
|
relAP (mkAP (mkA2 (mkA "employé") at_Prep) s) som_Prep
|
||||||
|
| relAP (mkAP (mkA2 (mkA "employé") by8agent_Prep) s) som_Prep
|
||||||
|
| relVP (mkVP (mkV2 (mkV "travailler") at_Prep) s) som_Prep
|
||||||
|
;
|
||||||
|
|
||||||
|
HaveTitleAt t =
|
||||||
|
relAP (mkAP (mkA2 (mkA "employé") som_Prep) (mkNP t)) at_Prep
|
||||||
|
| relAP (mkAP (mkA2 (mkA "employé") som_Prep) (mkNP t)) by8agent_Prep
|
||||||
|
| relVP (mkVP (mkNP a_Det t)) at_Prep
|
||||||
|
| relVP (mkVP (mkV2 (mkV "travailler") som_Prep) (mkNP t)) at_Prep
|
||||||
|
| relVP (mkVP have_V2 (mkNP the_Det (mkCN (mkN2 (mkN "titre") noPrep)
|
||||||
|
(mkNP t)))) at_Prep
|
||||||
|
;
|
||||||
|
|
||||||
|
Named n = propAP (mkAP (mkA2 called_A (mkPrep [])) n) ;
|
||||||
|
Start n = propVP (mkVP (mkV2 (mkV "commencer") with_Prep) n) ;
|
||||||
|
|
||||||
|
Organization = mkCN (mkN "organisation" feminine) ;
|
||||||
|
Company = mkCN (mkN "entreprise") ;
|
||||||
|
Place = mkCN (mkN "lieu") | mkCN (mkN "endroit") ;
|
||||||
|
Person =
|
||||||
|
mkCN (mkN "personne")
|
||||||
|
| mkCN (mkN "personne" "gens" feminine) ;
|
||||||
|
|
||||||
|
Location = mkFunctionP (mkN "localité") possess_Prep ;
|
||||||
|
Region = mkFunctionP (mkN "région" feminine) possess_Prep ;
|
||||||
|
Subregion = mkFunctionP (mkN "sous-région" feminine) possess_Prep ;
|
||||||
|
FName = mkFunctionP (mkN "nom") possess_Prep ;
|
||||||
|
FNickname = mkFunctionP (mkN "surnom") possess_Prep ;
|
||||||
|
FJobTitle =
|
||||||
|
mkFunctionP (mkN "titre" masculine) possess_Prep
|
||||||
|
| mkFunctionP (mkN "position" feminine) possess_Prep ;
|
||||||
|
|
||||||
|
SJobTitle t = mkNP a_Det t ;
|
||||||
|
|
||||||
|
oper
|
||||||
|
mkCountry : Str -> Str -> {np : NP ; a : A} =
|
||||||
|
\n,a -> {np = mkNP (mkPN n) ; a = mkA a} ;
|
||||||
|
|
||||||
|
mkName : Str -> NP =
|
||||||
|
\s -> mkNP (mkPN s) ;
|
||||||
|
mkFunction : Str -> Fun =
|
||||||
|
\s -> {cn = mkCN (mkN s) ; prep = possess_Prep} ;
|
||||||
|
mkFunctionP : N -> Prep -> Fun =
|
||||||
|
\n,p -> {cn = mkCN n ; prep = p} ;
|
||||||
|
|
||||||
|
som_Prep = mkPrep "comme" ;
|
||||||
|
|
||||||
|
noPrep = mkPrep [] ;
|
||||||
|
|
||||||
|
useCopula = mkVP être_V ;
|
||||||
|
|
||||||
|
lin
|
||||||
|
-- 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" ;
|
||||||
|
|
||||||
|
}
|
||||||
@@ -34,7 +34,7 @@ lin
|
|||||||
---- | mkNP (GenNP s) sgNum Lang.name_N
|
---- | mkNP (GenNP s) sgNum Lang.name_N
|
||||||
---- | mkNP (GenNP s) plNum Lang.name_N ;
|
---- | mkNP (GenNP s) plNum Lang.name_N ;
|
||||||
in
|
in
|
||||||
mkUtt (mkImp (mkVP LexQuery.give_V3 ss (mkNP i_Pron)))
|
mkUtt (mkImp (giveMe ss))
|
||||||
| mkUtt (mkQS (mkQCl (Lang.CompIP whatSg_IP) ss))
|
| mkUtt (mkQS (mkQCl (Lang.CompIP whatSg_IP) ss))
|
||||||
| mkUtt (mkQS (mkQCl (Lang.CompIP (Lang.IdetIP (mkIDet which_IQuant))) ss))
|
| mkUtt (mkQS (mkQCl (Lang.CompIP (Lang.IdetIP (mkIDet which_IQuant))) ss))
|
||||||
| mkUtt ss ;
|
| mkUtt ss ;
|
||||||
@@ -47,11 +47,10 @@ lin
|
|||||||
|
|
||||||
QFun r s =
|
QFun r s =
|
||||||
mkUtt
|
mkUtt
|
||||||
(mkImp (mkVP LexQuery.give_V3
|
(mkImp (giveMe (mkNP and_Conj s (detSet s r.cn))))
|
||||||
(mkNP and_Conj s (detSet s r.cn)) (mkNP i_Pron)))
|
|
||||||
| mkUtt (mkQS (mkQCl (mkIP what_IQuant plNum r.cn) s have_V2))
|
| mkUtt (mkQS (mkQCl (mkIP what_IQuant plNum r.cn) s have_V2))
|
||||||
| mkUtt (mkQS (mkQCl whatSg_IP
|
| mkUtt (mkQS (mkQCl whatSg_IP
|
||||||
(mkClSlash (mkClSlash s have_V2) (mkAdv as_Prep (mkNP aPl_Det r.cn))))) ;
|
(mkClSlash (mkClSlash s have_V2) (mkAdv LexQuery.as_Prep (mkNP aPl_Det r.cn))))) ;
|
||||||
|
|
||||||
QFunPair s f =
|
QFunPair s f =
|
||||||
let
|
let
|
||||||
@@ -60,7 +59,7 @@ lin
|
|||||||
ss : NP = mkNP and_Conj ss0 (mkNP (mkQuant they_Pron) plNum f.cn)
|
ss : NP = mkNP and_Conj ss0 (mkNP (mkQuant they_Pron) plNum f.cn)
|
||||||
| mkNP ss0 (mkAdv with_Prep (mkNP (mkQuant they_Pron) plNum f.cn))
|
| mkNP ss0 (mkAdv with_Prep (mkNP (mkQuant they_Pron) plNum f.cn))
|
||||||
in
|
in
|
||||||
mkUtt (mkImp (mkVP LexQuery.give_V3 ss (mkNP i_Pron)))
|
mkUtt (mkImp (giveMe ss))
|
||||||
| mkUtt (mkQS (mkQCl (Lang.CompIP whatPl_IP) ss))
|
| mkUtt (mkQS (mkQCl (Lang.CompIP whatPl_IP) ss))
|
||||||
| mkUtt (mkQS (mkQCl (Lang.CompIP (Lang.IdetIP (mkIDet which_IQuant))) ss))
|
| mkUtt (mkQS (mkQCl (Lang.CompIP (Lang.IdetIP (mkIDet which_IQuant))) ss))
|
||||||
| mkUtt ss ;
|
| mkUtt ss ;
|
||||||
@@ -69,7 +68,7 @@ lin
|
|||||||
let
|
let
|
||||||
info : NP = mkNP (all_NP | (mkNP information_N)) (mkAdv about_Prep s) ;
|
info : NP = mkNP (all_NP | (mkNP information_N)) (mkAdv about_Prep s) ;
|
||||||
in
|
in
|
||||||
mkUtt (mkImp (mkVP LexQuery.give_V3 info (mkNP i_Pron)))
|
mkUtt (mkImp (giveMe info))
|
||||||
| mkUtt (mkQCl whatSg_IP
|
| mkUtt (mkQCl whatSg_IP
|
||||||
(mkClSlash (mkClSlash (mkNP youSg_Pron) know_V2) (mkAdv about_Prep s)))
|
(mkClSlash (mkClSlash (mkNP youSg_Pron) know_V2) (mkAdv about_Prep s)))
|
||||||
| mkUtt info ;
|
| mkUtt info ;
|
||||||
|
|||||||
@@ -44,27 +44,27 @@ lin
|
|||||||
;
|
;
|
||||||
|
|
||||||
HaveTitle =
|
HaveTitle =
|
||||||
relAP (mkAP (mkA "anställd" "anställt")) as_Prep
|
relAP (mkAP (mkA "anställd" "anställt")) som_Prep
|
||||||
| relVP UseCopula noPrep
|
| relVP UseCopula noPrep
|
||||||
| relVP (mkVP (mkV "arbeta")) as_Prep
|
| relVP (mkVP (mkV "arbeta")) som_Prep
|
||||||
| relVP (mkVP (mkV "jobba")) as_Prep
|
| relVP (mkVP (mkV "jobba")) som_Prep
|
||||||
| relVP (mkVP have_V2 (mkNP the_Det (mkCN (mkN2 (mkN "titel" "titlar") noPrep))))
|
| relVP (mkVP have_V2 (mkNP the_Det (mkCN (mkN2 (mkN "titel" "titlar") noPrep))))
|
||||||
possess_Prep
|
possess_Prep
|
||||||
;
|
;
|
||||||
|
|
||||||
EmployedAt s =
|
EmployedAt s =
|
||||||
relAP (mkAP (mkA2 (mkA "anställd" "anställt") at_Prep) s) as_Prep
|
relAP (mkAP (mkA2 (mkA "anställd" "anställt") at_Prep) s) som_Prep
|
||||||
| relAP (mkAP (mkA2 (mkA "anställd" "anställt") by8agent_Prep) s) as_Prep
|
| relAP (mkAP (mkA2 (mkA "anställd" "anställt") by8agent_Prep) s) som_Prep
|
||||||
| relVP (mkVP (mkV2 (mkV "arbeta") at_Prep) s) as_Prep
|
| relVP (mkVP (mkV2 (mkV "arbeta") at_Prep) s) som_Prep
|
||||||
| relVP (mkVP (mkV2 (mkV "jobba") at_Prep) s) as_Prep
|
| relVP (mkVP (mkV2 (mkV "jobba") at_Prep) s) som_Prep
|
||||||
;
|
;
|
||||||
|
|
||||||
HaveTitleAt t =
|
HaveTitleAt t =
|
||||||
relAP (mkAP (mkA2 (mkA "anställd" "anställt") as_Prep) (mkNP t)) at_Prep
|
relAP (mkAP (mkA2 (mkA "anställd" "anställt") som_Prep) (mkNP t)) at_Prep
|
||||||
| relAP (mkAP (mkA2 (mkA "anställd" "anställt") as_Prep) (mkNP t)) by8agent_Prep
|
| relAP (mkAP (mkA2 (mkA "anställd" "anställt") som_Prep) (mkNP t)) by8agent_Prep
|
||||||
| relVP (mkVP (mkNP a_Det t)) at_Prep
|
| relVP (mkVP (mkNP a_Det t)) at_Prep
|
||||||
| relVP (mkVP (mkV2 (mkV "arbeta") as_Prep) (mkNP t)) at_Prep
|
| relVP (mkVP (mkV2 (mkV "arbeta") som_Prep) (mkNP t)) at_Prep
|
||||||
| relVP (mkVP (mkV2 (mkV "jobba") as_Prep) (mkNP t)) at_Prep
|
| relVP (mkVP (mkV2 (mkV "jobba") som_Prep) (mkNP t)) at_Prep
|
||||||
| relVP (mkVP have_V2 (mkNP the_Det (mkCN (mkN2 (mkN "titel" "titlar") noPrep)
|
| relVP (mkVP have_V2 (mkNP the_Det (mkCN (mkN2 (mkN "titel" "titlar") noPrep)
|
||||||
(mkNP t)))) at_Prep
|
(mkNP t)))) at_Prep
|
||||||
;
|
;
|
||||||
@@ -101,6 +101,7 @@ oper
|
|||||||
mkFunctionP : N -> Prep -> Fun =
|
mkFunctionP : N -> Prep -> Fun =
|
||||||
\n,p -> {cn = mkCN n ; prep = p} ;
|
\n,p -> {cn = mkCN n ; prep = p} ;
|
||||||
|
|
||||||
|
som_Prep = mkPrep "som" ;
|
||||||
|
|
||||||
lin
|
lin
|
||||||
-- JobTitles
|
-- JobTitles
|
||||||
|
|||||||
Reference in New Issue
Block a user