summaryrefslogtreecommitdiff
path: root/examples/phrasebook/Implementation.html
diff options
context:
space:
mode:
authoraarne <aarne@chalmers.se>2010-05-03 09:46:56 +0000
committeraarne <aarne@chalmers.se>2010-05-03 09:46:56 +0000
commitc7653c25ab0c68822f19997123d83ee99b1a341f (patch)
tree7f837b885176513dfadf6926d6377d30c20d0df4 /examples/phrasebook/Implementation.html
parent9326db54e41f5dbe5d9624e7ab841c2207648f49 (diff)
updates in phrasebook doc and in resource status doc
Diffstat (limited to 'examples/phrasebook/Implementation.html')
-rw-r--r--examples/phrasebook/Implementation.html117
1 files changed, 105 insertions, 12 deletions
diff --git a/examples/phrasebook/Implementation.html b/examples/phrasebook/Implementation.html
index 7c737f99c..e6227956c 100644
--- a/examples/phrasebook/Implementation.html
+++ b/examples/phrasebook/Implementation.html
@@ -41,6 +41,9 @@ gfdoc - a rudimentary GF document generator.
Date = Adv ;
Name = NP ;
Number = Card ;
+ ByTransport = Adv ;
+ Transport = {name : CN ; by : Adv} ;
+ Superlative = Det ;
lin
PSentence s = mkText s | lin Text (mkUtt s) ; -- optional '.'
PQuestion s = mkText s | lin Text (mkUtt s) ; -- optional '?'
@@ -57,6 +60,8 @@ gfdoc - a rudimentary GF document generator.
PCountry x = mkPhrase (mkUtt x) ;
PCitizenship x = mkPhrase (mkUtt (mkAP x)) ;
PDay d = mkPhrase (mkUtt d.name) ;
+ PTransport t = mkPhrase (mkUtt t.name) ;
+ PByTransport t = mkPhrase (mkUtt t) ;
PYes = mkPhrase yes_Utt ;
PNo = mkPhrase no_Utt ;
@@ -91,12 +96,9 @@ gfdoc - a rudimentary GF document generator.
Very property = mkAP very_AdA (mkAP property) ;
Too property = mkAP too_AdA (mkAP property) ;
PropQuality property = mkAP property ;
- ThePlace kind =
- let name : NP = mkNP the_Quant kind.name in {
- name = name ;
- at = mkAdv kind.at name ;
- to = mkAdv kind.to name
- } ;
+
+ ThePlace kind = placeNP the_Det kind ;
+ APlace kind = placeNP a_Det kind ;
IMale, IFemale = mkPerson i_Pron ;
YouFamMale, YouFamFemale = mkPerson youSg_Pron ;
@@ -120,8 +122,10 @@ gfdoc - a rudimentary GF document generator.
NNumeral n = mkCard &lt;lin Numeral n : Numeral> ;
AHave p kind = mkCl p.name have_V2 (mkNP kind) ;
+ AHaveCurr p curr = mkCl p.name have_V2 (mkNP aPl_Det curr) ;
ACitizen p n = mkCl p.name n ;
ABePlace p place = mkCl p.name place.at ;
+ ByTransp t = t.by ;
oper
</pre>
@@ -161,6 +165,13 @@ These are used in Words for each language.
to = t
} ;
+ placeNP : Det -> CNPlace -> NPPlace = \det,kind ->
+ let name : NP = mkNP det kind.name in {
+ name = name ;
+ at = mkAdv kind.at name ;
+ to = mkAdv kind.to name
+ } ;
+
NPPerson : Type = {name : NP ; isPron : Bool ; poss : Quant} ;
relativePerson : GNumber -> CN -> (Num -> NP -> CN -> NP) -> NPPerson -> NPPerson =
@@ -242,20 +253,33 @@ also the directional preposition varies, but in English we use <tt>to</tt>, as
defined by <tt>mkPlace</tt>.
<pre>
Airport = mkPlace "airport" "at" ;
+ AmusementPark = mkCompoundPlace "amusement" "park" "at" ;
+ Bank = mkPlace "bank" "at" ;
Bar = mkPlace "bar" "in" ;
- Church = mkPlace "church" "in" ;
+ Cafeteria = mkPlace "canteen" "in" ;
+ Center = mkPlace "center" "in" ;
Cinema = mkPlace "cinema" "at" ;
+ Church = mkPlace "church" "in" ;
+ Disco = mkPlace "disco" "at" ;
Hospital = mkPlace "hospital" "in" ;
Hotel = mkPlace "hotel" "in" ;
- Museum = mkPlace "museum" "in" ;
+ Museum = mkPlace "museum" "at" ;
Park = mkPlace "park" "in" ;
+ Parking = mkCompoundPlace "car" "park" "in" ;
+ Pharmacy = mkPlace "pharmacy" "at" ;
+ PostOffice = mkCompoundPlace "post" "office" "at" ;
+ Pub = mkPlace "pub" "at" ;
Restaurant = mkPlace "restaurant" "in" ;
School = mkPlace "school" "at" ;
- Shop = mkPlace "shop" "in" ;
+ Shop = mkPlace "shop" "at" ;
Station = mkPlace "station" "at" ;
+ Supermarket = mkPlace "supermarket" "at" ;
Theatre = mkPlace "theatre" "at" ;
Toilet = mkPlace "toilet" "in" ;
University = mkPlace "university" "at" ;
+ Zoo = mkPlace "zoo" "at" ;
+
+ CitRestaurant cit = mkCNPlace (mkCN cit (mkN "restaurant")) in_Prep to_Prep ;
</pre>
Currencies; <tt>crown</tt> is ambiguous between Danish and Swedish crowns.
@@ -264,25 +288,54 @@ Currencies; <tt>crown</tt> is ambiguous between Danish and Swedish crowns.
Dollar = mkCN (mkN "dollar") ;
Euro = mkCN (mkN "euro" "euros") ; -- to prevent euroes
Lei = mkCN (mkN "leu" "lei") ;
+ Leva = mkCN (mkN "lev") ;
+ NorwegianCrown = mkCN (mkA "Norwegian") (mkN "crown") | mkCN (mkN "crown") ;
+ Pound = mkCN (mkN "pound") ;
+ Rouble = mkCN (mkN "rouble") ;
SwedishCrown = mkCN (mkA "Swedish") (mkN "crown") | mkCN (mkN "crown") ;
+ Zloty = mkCN (mkN "zloty" "zloty") ;
</pre>
Nationalities
<pre>
Belgian = mkA "Belgian" ;
Belgium = mkNP (mkPN "Belgium") ;
+ Bulgarian = mkNat "Bulgarian" "Bulgaria" ;
+ Catalan = mkNPNationality (mkNP (mkPN "Catalan")) (mkNP (mkPN "Catalonia")) (mkA "Catalonian") ;
+ Danish = mkNat "Danish" "Denmark" ;
+ Dutch = mkNPNationality (mkNP (mkPN "Dutch")) (mkNP the_Quant (mkN "Netherlands")) (mkA "Dutch") ;
English = mkNat "English" "England" ;
Finnish = mkNat "Finnish" "Finland" ;
Flemish = mkNP (mkPN "Flemish") ;
French = mkNat "French" "France" ;
+ German = mkNat "German" "Germany" ;
Italian = mkNat "Italian" "Italy" ;
+ Norwegian = mkNat "Norwegian" "Norway" ;
+ Polish = mkNat "Polish" "Poland" ;
Romanian = mkNat "Romanian" "Romania" ;
+ Russian = mkNat "Russian" "Russia" ;
+ Spanish = mkNat "Spanish" "Spain" ;
Swedish = mkNat "Swedish" "Sweden" ;
</pre>
+Means of transportation
+<pre>
+ Bike = mkTransport L.bike_N ;
+ Bus = mkTransport (mkN "bus") ;
+ Car = mkTransport L.car_N ;
+ Ferry = mkTransport (mkN "ferry") ;
+ Plane = mkTransport L.airplane_N ;
+ Subway = mkTransport (mkN "subway") ;
+ Taxi = mkTransport (mkN "taxi") ;
+ Train = mkTransport (mkN "train") ;
+ Tram = mkTransport (mkN "tram") ;
+
+ ByFoot = P.mkAdv "by foot" ;
+</pre>
+
Actions: the predication patterns are very often language-dependent.
<pre>
- AHasAge p num = mkCl p.name (mkNP num L.year_N) ;
+ AHasAge p num = mkCl p.name (mkNP (mkDet num)) ;
AHasChildren p num = mkCl p.name have_V2 (mkNP num L.child_N) ;
AHasRoom p num = mkCl p.name have_V2
(mkNP (mkNP a_Det (mkN "room")) (SyntaxEng.mkAdv for_Prep (mkNP num (mkN "person")))) ;
@@ -324,8 +377,9 @@ miscellaneous
Building phrases from strings is complicated: the solution is to use
mkText : Text -> Text -> Text ;
<pre>
- PSeeYou d = mkText (lin Text (ss ("see you"))) (mkPhrase (mkUtt d)) ;
- PSeeYouPlace p d =
+ PSeeYouDate d = mkText (lin Text (ss ("see you"))) (mkPhrase (mkUtt d)) ;
+ PSeeYouPlace p = mkText (lin Text (ss ("see you"))) (mkPhrase (mkUtt p.at)) ;
+ PSeeYouPlaceDate p d =
mkText (lin Text (ss ("see you")))
(mkText (mkPhrase (mkUtt p.at)) (mkPhrase (mkUtt d))) ;
</pre>
@@ -354,6 +408,33 @@ week days
Tomorrow = P.mkAdv "tomorrow" ;
</pre>
+modifiers of places
+<pre>
+ TheBest = mkSuperl L.good_A ;
+ TheClosest = mkSuperl L.near_A ;
+ TheCheapest = mkSuperl (mkA "cheap") ;
+ TheMostExpensive = mkSuperl (mkA "expensive") ;
+ TheMostPopular = mkSuperl (mkA "popular") ;
+ TheWorst = mkSuperl L.bad_A ;
+
+ SuperlPlace sup p = placeNP sup p ;
+</pre>
+
+transports
+<pre>
+ HowFar place = mkQS (mkQCl far_IAdv place.name) ;
+ HowFarFrom x y = mkQS (mkQCl far_IAdv (mkNP y.name (SyntaxEng.mkAdv from_Prep x.name))) ;
+ HowFarFromBy x y t =
+ mkQS (mkQCl far_IAdv (mkNP (mkNP y.name (SyntaxEng.mkAdv from_Prep x.name)) t)) ;
+ HowFarBy y t = mkQS (mkQCl far_IAdv (mkNP y.name t)) ;
+
+ WhichTranspPlace trans place =
+ mkQS (mkQCl (mkIP which_IDet trans.name) (mkVP (mkVP L.go_V) place.to)) ;
+
+ IsTranspPlace trans place =
+ mkQS (mkQCl (mkCl (mkCN trans.name place.to))) ;
+</pre>
+
auxiliaries
<pre>
oper
@@ -366,6 +447,9 @@ auxiliaries
mkNPDay day (SyntaxEng.mkAdv on_Prep day)
(SyntaxEng.mkAdv on_Prep (mkNP a_Quant plNum (mkCN (mkN d)))) ;
+ mkCompoundPlace : Str -> Str -> Str -> {name : CN ; at : Prep ; to : Prep} = \comp, p, i ->
+ mkCNPlace (mkCN (P.mkN comp (mkN p))) (P.mkPrep i) to_Prep ;
+
mkPlace : Str -> Str -> {name : CN ; at : Prep ; to : Prep} = \p,i ->
mkCNPlace (mkCN (mkN p)) (P.mkPrep i) to_Prep ;
@@ -377,6 +461,15 @@ auxiliaries
nameOf : NPPerson -> NP = \p -> (xOf sing (mkN "name") p).name ;
+ mkTransport : N -> {name : CN ; by : Adv} = \n -> {
+ name = mkCN n ;
+ by = SyntaxEng.mkAdv by8means_Prep (mkNP n)
+ } ;
+
+ mkSuperl : A -> Det = \a -> SyntaxEng.mkDet the_Art (SyntaxEng.mkOrd a) ;
+
+ far_IAdv = ExtraEng.IAdvAdv (ss "far") ;
+
}
</pre>