diff options
| author | ramona.enache <ramona.enache@chalmers.se> | 2012-06-21 14:21:18 +0000 |
|---|---|---|
| committer | ramona.enache <ramona.enache@chalmers.se> | 2012-06-21 14:21:18 +0000 |
| commit | ffa1e7731d3ef7a3892366f72b708e934eb840d5 (patch) | |
| tree | 75d4d514e2891f5417edd35fa20db545a84de4a2 /examples/query/small/patentsQuery/LexQueryPatsFre.gf | |
| parent | 6e2c7623fd1cfc9b48fa98759583e7d0d3374d59 (diff) | |
added French grammar for patent queries
Diffstat (limited to 'examples/query/small/patentsQuery/LexQueryPatsFre.gf')
| -rw-r--r-- | examples/query/small/patentsQuery/LexQueryPatsFre.gf | 159 |
1 files changed, 159 insertions, 0 deletions
diff --git a/examples/query/small/patentsQuery/LexQueryPatsFre.gf b/examples/query/small/patentsQuery/LexQueryPatsFre.gf new file mode 100644 index 000000000..7577e1d66 --- /dev/null +++ b/examples/query/small/patentsQuery/LexQueryPatsFre.gf @@ -0,0 +1,159 @@ +instance LexQueryPatsFre of LexQueryPats = open + SyntaxFre, + ParadigmsFre, + ExtraFre, + IrregFre, + DiffFre, + StructuralFre, + (CR=CommonRomance), + ParamX, + QueryFre, + Prelude + in +{ + +oper +-------------------------------------------------------------- +-- structural words and extra grammar constructs + + about_Prep : Prep = mkPreposition ["à propos de"] ; + + all_NP : NP = mkNP (mkPN "tout") ; + + vpAP : VP -> AP = variants {} ; + + what_IQuant : IQuant = which_IQuant ; + + massInfoSg : CN -> NP = \cn -> + let g = cn.g ; + n = Sg + in lin NP { + s = \\c => {comp,ton = cn.s ! n ; c1,c2 = []} ; + a = CR.agrP3 g n ; + hasClit = False ; + isPol = False + } ; + + massInfoPl : CN -> NP = \cn -> SyntaxFre.mkNP aPl_Det cn ; + + PatsAdvVPSlash : VPSlash -> Adv -> VPSlash = \vp, adv -> lin VPSlash + { + s = vp.s ; + agr = vp.agr ; + clit1 = vp.clit1 ; + clit2 = vp.clit2 ; + clit3 = vp.clit3 ; + neg = vp.neg ; + comp = \\a => vp.comp ! a ++ adv.s ; + ext = vp.ext ; + c2 = vp.c2 ; + } ; + + selectIP : NP -> IP = \np -> case np.a.n of + {Sg => whatSg_IP ; + _ => whatPl_IP + }; + + +-------------------------------------------------------------- +-- kinds + + patent_number_CN : Kind = + let pn : CN = mkCN (mkCN (mkN "numéro")) (SyntaxFre.mkAdv possess_Prep (mkNP (mkN "brevet"))) + in lin Kind pn ; + + claim_N : Kind = lin Kind (mkCN (mkN "revendication")) ; + + +-------------------------------------------------------------- +-- activities + + expire_V : Adv -> Activity = \pdate -> + lin Activity (mkVP (mkVP (mkV "expire")) pdate) ; + + simp_expire_V : Activity = + lin Activity (mkVP (regV "expirer")) ; + + apply_V : NP -> Activity = \pat -> lin Activity ( mkVP (mkVP (regV "appliquer")) (SyntaxFre.mkAdv for_Prep pat)) ; + + compound_CN : Activity = let vp : VP = mkVP (mkCN (mkN "composé")) + in lin Activity vp ; + + use_V2 : Set -> Activity = \s -> lin Activity (mkVP (passiveVP (dirV2 (regV "utiliser"))) (SyntaxFre.mkAdv in_Prep s)); + + approve_V2 : Adv -> Activity = \pdate -> lin Activity (mkVP (passiveVP (dirV2 (regV "approuver"))) pdate) ; + + mention_V2 : NP -> Activity = \drug -> + lin Activity ( mkVP (mkVPSlash (dirV2 (regV "mentionner"))) drug) ; + + contain_V2 : NP -> Activity = \chem -> + lin Activity (mkVP (mkVPSlash IrregFre.contenir_V2) chem) ; + + +-------------------------------------------------------------- +-- properties + + approve_prop_V2 : Adv -> Property = \pdate -> lin Property (vpAP (mkVP (passiveVP (dirV2 (regV "approuver"))) pdate)) ; + + use_prop_V2 : Set -> Property = \s -> lin Property (vpAP (mkVP (passiveVP (dirV2 (regV "utiliser"))) (SyntaxFre.mkAdv in_Prep s))) ; + + + +-------------------------------------------------------------- +-- relations + + active_ingredient_CN : Relation = makeRelation (mkCN (mkA "actif") (mkN "ingrédient")) ; + + dosage_form_CN : Relation = makeRelation (mkCN (mkA "posologique") (mkN "forme")) ; + + route_of_administration_CN : Relation = makeRelation (mkCN (mkCN (mkN "voie")) (SyntaxFre.mkAdv possess_Prep (mkNP (mkN "administration")))) ; + + patent_number_Rel : Relation = makeRelation (mkCN (mkCN (mkN "numéro")) (SyntaxFre.mkAdv possess_Prep (mkNP (mkN "brevet")))) ; + + patent_N : Relation = lin Relation {cn = mkCN (mkN "brevet") ; prep = for_Prep } ; + + patent_with_N : Relation = lin Relation {cn = mkCN (mkN "brevet"); prep = with_Prep} ; + + expiration_date_CN : Relation = makeRelation (mkCN (mkCN (mkN "date")) (SyntaxFre.mkAdv possess_Prep (mkNP (mkN "expiration")))) ; + + use_code_CN : Relation = makeRelation (mkCN (mkCN (mkN "code")) (SyntaxFre.mkAdv possess_Prep (mkNP (mkN "utilisation")))) ; + + application_number_CN : Relation = makeRelation (mkCN (mkCN (mkN "numéro")) (SyntaxFre.mkAdv possess_Prep (mkNP (mkN "demande")))) ; + + + application_number_no_CN : Relation = lin Relation {cn = (mkCN (mkCN (mkN "numéro")) (SyntaxFre.mkAdv possess_Prep (mkNP (mkN "demande")))); prep = mkPrep ""} ; + + applicant_CN : Relation = lin Relation { cn = mkCN (mkN "demandeur") ; prep = for_Prep } ; + + + applicant_no_CN : Relation = lin Relation {cn = mkCN (mkN "demandeur"); prep = mkPrep ""} ; + + approval_date_CN : Relation = makeRelation (mkCN (mkCN (mkN "date")) (SyntaxFre.mkAdv possess_Prep (mkNP (mkN "approbation")))) ; + + + chemical_composition_CN : Relation = makeRelation (mkCN (mkA "chemique") (mkN "composition")) ; + + chemical_substance_CN : Relation = lin Relation {cn = (mkCN (mkA "chimique") (mkN "substance")) ; prep = from_Prep | part_Prep } ; + + drug_N : Relation = lin Relation {cn = mkCN (mkN "médicament") ; prep = with_Prep} ; + + use_N : Relation = makeRelation (mkCN (mkN "utilisation")) ; + + method_N : Relation = makeRelation (mkCN (mkN "méthode")) ; + + drug_with_usage_form_CN : Relation = lin Relation {cn = mkCN (mkN "médicament") ; prep = mkPrep "" } ; + + drug_preparation_CN : Relation = lin Relation {cn = mkCN (mkN "préparation") ; prep = for_Prep} ; + + strength_N : Relation = makeRelation (mkCN (mkN "dosage")) ; + + name_N : Relation = makeRelation (mkCN (mkN "nom")) ; + + usage_form_CN = makeRelation ( mkCN (mkCN (mkN "formulaire")) (SyntaxFre.mkAdv possess_Prep (mkNP (mkN "utilisation")))) ; + +---------------------------------------------------------------------------- +oper makeRelation : CN -> Relation = + \s -> lin Relation {cn = s ; prep = possess_Prep} ; + + +} |
