diff options
| author | ramona.enache <ramona.enache@chalmers.se> | 2012-06-21 11:17:34 +0000 |
|---|---|---|
| committer | ramona.enache <ramona.enache@chalmers.se> | 2012-06-21 11:17:34 +0000 |
| commit | 5a8c8de789908bc1a7e4e5b3c647386e028c0972 (patch) | |
| tree | a88480cc1b992e9629c74cfab948bd573e6193cc /examples/query/small/patentsQuery/LexQueryPatsEng.gf | |
| parent | 7af649f2784056f26fec3908f644057bd9a870be (diff) | |
added patents queries in new_patentsQuery
Diffstat (limited to 'examples/query/small/patentsQuery/LexQueryPatsEng.gf')
| -rw-r--r-- | examples/query/small/patentsQuery/LexQueryPatsEng.gf | 136 |
1 files changed, 136 insertions, 0 deletions
diff --git a/examples/query/small/patentsQuery/LexQueryPatsEng.gf b/examples/query/small/patentsQuery/LexQueryPatsEng.gf new file mode 100644 index 000000000..09206388e --- /dev/null +++ b/examples/query/small/patentsQuery/LexQueryPatsEng.gf @@ -0,0 +1,136 @@ +instance LexQueryPatsEng of LexQueryPats = open + SyntaxEng, + (M=MakeStructuralEng), + ParadigmsEng, + ExtraEng, + IrregEng, + LangEng, + ResEng, + QueryEng + in +{ + +oper +-------------------------------------------------------------- +-- structural words and extra grammar constructs + + about_Prep : Prep = mkPrep "about" ; + + all_NP : NP = SyntaxEng.mkNP (mkPN "all") ; + + vpAP : VP -> AP = PartVP ; + + what_IQuant : IQuant = M.mkIQuant "what" "what" ; + + massInfoSg : CN -> NP = \cn -> SyntaxEng.mkNP cn ; + + massInfoPl : CN -> NP = \cn -> SyntaxEng.mkNP aPl_Det cn ; + + PatsAdvVPSlash : VPSlash -> Adv -> VPSlash = LangEng.AdvVPSlash ; + + selectIP : NP -> IP = \np -> case np.a of + {AgP3Sg _ => whatSg_IP ; + _ => whatPl_IP + }; + + +-------------------------------------------------------------- +-- kinds + + patent_number_CN : Kind = lin Kind (mkCN (mkN "patent" (mkN "number"))) ; + + claim_N : Kind = lin Kind (mkCN (mkN "claim")) ; + + +-------------------------------------------------------------- +-- activities + + expire_V : Adv -> Activity = \pdate -> + lin Activity (mkVP (mkVP (mkV "expire")) pdate) ; + + simp_expire_V : Activity = + lin Activity (mkVP (mkV "expire")) ; + + apply_V : NP -> Activity = \pat -> lin Activity ( mkVP (mkVP (mkV "apply" "applies" "applied" "applied" "applying")) (SyntaxEng.mkAdv for_Prep pat)) ; + + compound_CN : Activity = let vp : VP = mkVP (mkCN (mkN "compound")) + in lin Activity vp ; + + use_V2 : Set -> Activity = \s -> lin Activity (mkVP (passiveVP (mkV2 (mkV "use" "uses" "used" "used" "using"))) (SyntaxEng.mkAdv in_Prep s)); + + approve_V2 : Adv -> Activity = \pdate -> lin Activity (mkVP (passiveVP (mkV2 (mkV "approve" "approves" "approved" "approved" "approving"))) pdate) ; + + mention_V2 : NP -> Activity = \drug -> + lin Activity ( mkVP (mkVPSlash (mkV2 (mkV "mention" "mentions" "mentioned" "mentioned" "mentioning"))) drug) ; + + contain_V2 : NP -> Activity = \chem -> + lin Activity (mkVP (mkVPSlash (mkV2 (mkV "contain" "contains" "contained" "contained" "containing"))) chem) ; + + +-------------------------------------------------------------- +-- properties + + approve_prop_V2 : Adv -> Property = \pdate -> lin Property (vpAP (mkVP (passiveVP (mkV2 (mkV "approve" "approves" "approved" "approved" "approving"))) pdate)) ; + + use_prop_V2 : Set -> Property = \s -> lin Property (vpAP (mkVP (passiveVP (mkV2 (mkV "use" "uses" "used" "used" "using"))) (SyntaxEng.mkAdv in_Prep s))) ; + + + +-------------------------------------------------------------- +-- relations + + active_ingredient_CN : Relation = makeRelation (mkCN (mkA "active") (mkN "ingredient")) ; + + dosage_form_CN : Relation = makeRelation (mkCN (mkN "dosage" (mkN "form"))) ; + + route_of_administration_CN : Relation = makeRelation (mkCN (mkN "route") (SyntaxEng.mkAdv (mkPrep "of") (SyntaxEng.mkNP (mkN "administration")))) ; + + patent_number_Rel : Relation = makeRelation (mkCN (mkN "patent" (mkN "number"))) ; + + patent_N : Relation = lin Relation {cn = mkCN (mkN "patent") ; prep = for_Prep } ; + + patent_with_N : Relation = lin Relation {cn = mkCN (mkN "patent"); prep = with_Prep} ; + + expiration_date_CN : Relation = makeRelation (mkCN (mkN "expiration" (mkN "date"))) ; + + use_code_CN : Relation = makeRelation (SyntaxEng.mkCN (mkN "use" (mkN "code"))) ; + + application_number_CN : Relation = makeRelation ((mkCN (mkN "application" (mkN "number"))) | (mkCN (mkN ["patent application"] (mkN "number")))) ; + + + application_number_no_CN : Relation = lin Relation {cn = ((mkCN (mkN "application" (mkN "number"))) | (mkCN (mkN ["patent application"] (mkN "number")))); prep = noPrep} ; + + applicant_CN : Relation = lin Relation { cn = mkCN (mkN "applicant") ; prep = for_Prep } ; + + + applicant_no_CN : Relation = lin Relation {cn = mkCN (mkN "applicant"); prep = noPrep} ; + + approval_date_CN : Relation = makeRelation (mkCN (mkN "approval" (mkN "date"))) ; + + + chemical_composition_CN : Relation = makeRelation (mkCN (mkA "chemical") (mkN "composition")) ; + + chemical_substance_CN : Relation = lin Relation {cn = (mkCN (mkA "chemical") (mkN "substance")) ; prep = from_Prep | part_Prep } ; + + drug_N : Relation = lin Relation {cn = mkCN (mkN "drug") ; prep = with_Prep} ; + + use_N : Relation = makeRelation (mkCN (mkN "use")) ; + + method_N : Relation = makeRelation (mkCN (mkN "method")) ; + + drug_with_usage_form_CN : Relation = lin Relation {cn = mkCN (mkN "drug") ; prep = noPrep } ; + + drug_preparation_CN : Relation = lin Relation {cn = mkCN (mkN "drug" (mkN "preparation")) ; prep = for_Prep} ; + + strength_N : Relation = makeRelation (mkCN (mkN "strength")) ; + + name_N : Relation = makeRelation (mkCN (mkN "name")) ; + + usage_form_CN = makeRelation (mkCN (mkN "usage" (mkN "form"))) ; + +---------------------------------------------------------------------------- +oper makeRelation : CN -> Relation = + \s -> lin Relation {cn = s ; prep = possess_Prep} ; + + +}
\ No newline at end of file |
