hindi-resource-grammar

This commit is contained in:
virk.shafqat
2012-02-23 13:36:50 +00:00
parent f1d2852c4d
commit 9aede98c7f
52 changed files with 2166 additions and 1991 deletions

View File

@@ -1,2 +1,2 @@
concrete AdjectiveHin of Adjective = CatHin ** AdjectiveHindustani with concrete AdjectiveHin of Adjective = CatHin ** AdjectiveHindustani with
(ResHindustani = ResHin) ; (ResHindustani = ResHin);

View File

@@ -1,2 +1,2 @@
concrete AdverbHin of Adverb = CatHin ** AdverbHindustani with concrete AdverbHin of Adverb = CatHin ** AdverbHindustani with
(ResHindustani = ResHin) ; (ResHindustani = ResHin);

View File

@@ -1,6 +1,6 @@
--# -path=.:../abstract:../common:../prelude:../hindustani --# -path=.:../abstract:../common:../prelude:../hindustani
concrete AllHin of AllHinAbs = concrete AllHin of AllHinAbs =
LangHin, LangHin
ExtraHin -- ExtraHin
** {} ; ** {} ;

View File

@@ -1,4 +1,4 @@
abstract AllHinAbs = abstract AllHinAbs =
Lang, Lang
ExtraHinAbs -- ExtraHinAbs
** {} ; ** {} ;

View File

@@ -1,2 +1,3 @@
concrete CatHin of Cat = CommonX - [Adv,AdN] ** CatHindustani with concrete CatHin of Cat = CommonX - [Adv,AdN,SC] ** CatHindustani with
(ResHindustani = ResHin) ; (ResHindustani = ResHin);

View File

@@ -1,4 +1,6 @@
instance DiffHin of DiffHindustani = open CommonHindustani, Prelude in { instance DiffHin of DiffHindustani = open CommonHindustani, ResHindustani,Prelude in {
--instance DiffHin of DiffHindustani = CommonHindustani ** open Prelude in {
flags coding = utf8;
oper oper
Clause : Type = {s : VPHTense => Polarity => Order => Str} ; Clause : Type = {s : VPHTense => Polarity => Order => Str} ;
mkClause : NP -> VPH -> Clause = \np,vp -> { mkClause : NP -> VPH -> Clause = \np,vp -> {
@@ -31,9 +33,9 @@ Clause : Type = {s : VPHTense => Polarity => Order => Str} ;
VPPerfFut => {fin = [] ; inf = Prelude.glue ((vp.s ! VPTense VPPerf agr).inf ++ hw p n) (copula CFuture n p g) } ; VPPerfFut => {fin = [] ; inf = Prelude.glue ((vp.s ! VPTense VPPerf agr).inf ++ hw p n) (copula CFuture n p g) } ;
VPPerfPresCont => {fin = copula CPresent n p g ; inf = (vp.s ! VPTense VPPres agr).inf ++ raha g n } ; VPPerfPresCont => {fin = copula CPresent n p g ; inf = (vp.s ! VPTense VPPres agr).inf ++ raha g n } ;
VPPerfPastCont => {fin = copula CPast n p g ; inf = (vp.s ! VPTense VPPres agr).inf ++ raha g n } ; VPPerfPastCont => {fin = copula CPast n p g ; inf = (vp.s ! VPTense VPPres agr).inf ++ raha g n } ;
VPPerfFutCont => {fin = [] ; inf = Prelude.glue ((vp.s ! VPTense VPPres agr).inf ++ raha g n ++ hw p n) (copula CFuture n p g )} ; VPPerfFutCont => {fin = [] ; inf = Prelude.glue ((vp.s ! VPTense VPPres agr).inf ++ raha g n ++ hw p n) (copula CFuture n p g) } ;
VPSubj => case vp.prog of { True => {fin = (vp.s ! VPTense VPFutr agr).inf ++ hw p n ; inf = "Xयद" } ; VPSubj => case vp.prog of { True => {fin = (vp.s ! VPTense VPFutr agr).inf ++ hw p n ; inf = "शायद" } ;
_ => {fin = (vp.s ! VPTense VPFutr agr).inf ; inf = "Xयद" } } _ => {fin = (vp.s ! VPTense VPFutr agr).inf ; inf = "शायद" } }
}; };
@@ -41,7 +43,7 @@ Clause : Type = {s : VPHTense => Polarity => Order => Str} ;
quest = quest =
case ord of case ord of
{ ODir => []; { ODir => [];
OQuest => "कय" }; OQuest => "कय" };
na = na =
case b of case b of
{ Pos => []; { Pos => [];
@@ -49,7 +51,7 @@ Clause : Type = {s : VPHTense => Polarity => Order => Str} ;
nahim = nahim =
case b of case b of
{ Pos => []; { Pos => [];
Neg => "नहं" }; Neg => "नहं" };
in in
case vt of { case vt of {
VPSubj => quest ++ np.s ! subj ++ vp.obj.s ++ vp.ad ++ vp.comp ! np.a ++ na ++ vps.inf ++ vps.fin ++ vp.embComp ; VPSubj => quest ++ np.s ! subj ++ vp.obj.s ++ vp.ad ++ vp.comp ! np.a ++ na ++ vps.inf ++ vps.fin ++ vp.embComp ;
@@ -76,15 +78,15 @@ Clause : Type = {s : VPHTense => Polarity => Order => Str} ;
VPPerfFut => {fin = [] ; inf = Prelude.glue ((vp.s ! VPStem).inf ++ cka g n ++ hw p n) (copula CFuture n p g) } ; VPPerfFut => {fin = [] ; inf = Prelude.glue ((vp.s ! VPStem).inf ++ cka g n ++ hw p n) (copula CFuture n p g) } ;
VPPerfPresCont => {fin = copula CPresent n p g ; inf = (vp.s ! VPStem).inf ++ raha g n } ; VPPerfPresCont => {fin = copula CPresent n p g ; inf = (vp.s ! VPStem).inf ++ raha g n } ;
VPPerfPastCont => {fin = copula CPast n p g ; inf = (vp.s ! VPStem).inf ++ raha g n } ; VPPerfPastCont => {fin = copula CPast n p g ; inf = (vp.s ! VPStem).inf ++ raha g n } ;
VPPerfFutCont => {fin = [] ; inf = Prelude.glue ((vp.s ! VPStem).inf ++ raha g n ++ hw p n) (copula CFuture n p g ) } ; VPPerfFutCont => {fin = [] ; inf = Prelude.glue ((vp.s ! VPStem).inf ++ raha g n ++ hw p n) (copula CFuture n p g) } ;
VPSubj => {fin = insertSubj p (vp.s ! VPStem).inf ; inf = "xयद" } VPSubj => {fin = insertSubj p (vp.s ! VPStem).inf ; inf = "शायद" }
}; };
quest = quest =
case ord of case ord of
{ ODir => []; { ODir => [];
OQuest => "कय" }; OQuest => "कय" };
na = na =
case b of case b of
{ Pos => []; { Pos => [];
@@ -92,42 +94,159 @@ Clause : Type = {s : VPHTense => Polarity => Order => Str} ;
nahim = nahim =
case b of case b of
{ Pos => []; { Pos => [];
Neg => "नहं" }; Neg => "नहं" };
in in
case t of { case t of {
VPSubj => quest ++ subj ++ vp.obj.s ++ vp.ad ++ vp.comp ! agr ++ na ++ vps.inf ++ vps.fin ++ vp.embComp; VPSubj => quest ++ subj ++ vp.obj.s ++ vp.ad ++ vp.comp ! agr ++ na ++ vps.inf ++ vps.fin ++ vp.embComp;
_ => quest ++ subj ++ vp.obj.s ++ vp.ad ++ vp.comp ! agr ++ nahim ++ vps.inf ++ vps.fin ++ vp.embComp}; _ => quest ++ subj ++ vp.obj.s ++ vp.ad ++ vp.comp ! agr ++ nahim ++ vps.inf ++ vps.fin ++ vp.embComp};
} ; } ;
{- Verb : Type = {s : VerbForm => Str} ;
predV v = {
s = \\vh =>
case vh of {
VPTense VPPres (Ag g n p) => {fin = copula CPresent n p g ; inf = v.s ! VF Imperf p n g } ;
VPTense VPPast (Ag g n p) => {fin = [] ; inf =v.s ! VF Perf p n g} ;
VPTense VPFutr (Ag g n p) => {fin = [] ; inf = Prelude.glue (v.s ! VF Subj p n g) (copula CFuture n p g)} ;
VPTense VPPerf (Ag g n p) => { fin = [] ; inf = v.s ! Root ++ cka g n } ;
VPStem => {fin = [] ; inf = v.s ! Root};
_ => {fin = [] ; inf = v.s ! Root}
};
obj = {s = [] ; a = defaultAgr} ;
subj = VIntrans ;
inf = v.s ! Inf;
ad = [];
embComp = [];
prog = False ;
comp = \\_ => []
} ;
-}
np2pronCase ppf npc a = case npc of { np2pronCase ppf npc a = case npc of {
NPC c => ppf ! c; NPC c => ppf ! c;
NPObj => ppf ! Obl ; NPObj => ppf ! Obl ;
NPErg =>case (fromAgr a).p of { NPErg =>case (fromAgr a).p of {
(Pers3_Near|Pers3_Distant) => Prelude.glue (ppf ! Obl) "न" ; -- in hindi in case of pronouns nE is tagged to pron rather than a separate word (Pers3_Near|Pers3_Distant) => Prelude.glue (ppf ! Obl) "न" ; -- in hindi in case of pronouns nE is tagged to pron rather than a separate word
_ => Prelude.glue (ppf ! Dir) "न" _ => Prelude.glue (ppf ! Dir) "न"
} }
} ; } ;
conjThat = "कि" ;
insertSubj : UPerson -> Str -> Str = \p,s ->
case p of { Pers1 => s ++ "वाँ" ; _ => Prelude.glue s "ए"}; -- check with prasad for vn~
agr = "a-गर" ;
awr = "और" ;
ky = "की" ;
jn = "जिन" ;
js = "जिस" ;
jw = "जो" ;
kw = "को" ;
mt = "मत" ;
nE = "ने" ;
nh = "न" ;
sE = "से" ;
waN = "वाँ" ; -- check with prasad
hE = "हे" ;
comma = "," ;
indfArt = "एक" ; -- check with prasad
kwd = "ख़ुद" ; -- check with prasad
oper
copula : CTense -> Number -> UPerson -> Gender -> Str = \t,n,p,g ->
case <t,n,p,g> of {
<CPresent,Sg,Pers1,_ > => "हूँ" ;
<CPresent,Sg,Pers2_Casual,_ > => "है" ;
<CPresent,Sg,Pers2_Familiar,_ > => "हो" ;
<CPresent,Sg,Pers2_Respect,_ > => "हैं" ;
<CPresent,Sg,Pers3_Near,_ > => "है" ;
<CPresent,Sg,Pers3_Distant,_ > => "है" ;
<CPresent,Pl,Pers1,_ > => "हैँ" ;
<CPresent,Pl,Pers2_Casual,_ > => "हौ" ;
<CPresent,Pl,Pers2_Familiar,_ > => "हौ" ;
<CPresent,Pl,Pers2_Respect,_ > => "हैं" ;
<CPresent,Pl,Pers3_Near,_ > => "हैं" ;
<CPresent,Pl,Pers3_Distant,_ > => "हैं" ;
<CPast,Sg,Pers1,Masc > => "था" ;
<CPast,Sg,Pers1,Fem > => "थी" ;
<CPast,Sg,Pers2_Casual,Masc > => "था" ;
<CPast,Sg,Pers2_Casual,Fem > => "थी" ;
<CPast,Sg,Pers2_Familiar,Masc > => "था" ;
<CPast,Sg,Pers2_Familiar,Fem > => "थी" ;
<CPast,Sg,Pers2_Respect,Masc > => "थे" ;
<CPast,Sg,Pers2_Respect,Fem > => "थीं" ;
<CPast,Sg,Pers3_Near,Masc > => "था" ;
<CPast,Sg,Pers3_Near,Fem > => "थी" ;
<CPast,Sg,Pers3_Distant,Masc > => "था" ;
<CPast,Sg,Pers3_Distant,Fem > => "थी" ;
<CPast,Pl,Pers1,Masc > => "थे" ;
<CPast,Pl,Pers1,Fem > => "थीं" ;
<CPast,Pl,Pers2_Casual,Masc > => "थे" ;
<CPast,Pl,Pers2_Casual,Fem > => "थीं" ;
<CPast,Pl,Pers2_Familiar,Masc > => "थे" ;
<CPast,Pl,Pers2_Familiar,Fem > => "थीं" ;
<CPast,Pl,Pers2_Respect,Masc > => "थे" ;
<CPast,Pl,Pers2_Respect,Fem > => "थीं" ;
<CPast,Pl,Pers3_Near,Masc > => "थे" ;
<CPast,Pl,Pers3_Near,Fem > => "थीं" ;
<CPast,Pl,Pers3_Distant,Masc > => "थे" ;
<CPast,Pl,Pers3_Distant,Fem > => "थीं" ;
<CFuture,Sg,Pers1,Masc > => "गा" ;
<CFuture,Sg,Pers1,Fem > => "गी" ;
<CFuture,Sg,Pers2_Casual,Masc > => "गा" ;
<CFuture,Sg,Pers2_Casual,Fem > => "गी" ;
<CFuture,Sg,Pers2_Familiar,Masc > => "गे" ;
<CFuture,Sg,Pers2_Familiar,Fem > => "गी" ;
<CFuture,Sg,Pers2_Respect,Masc > => "गे" ;
<CFuture,Sg,Pers2_Respect,Fem > => "गी" ;
<CFuture,Sg,Pers3_Near,Masc > => "गा" ;
<CFuture,Sg,Pers3_Near,Fem > => "गी" ;
<CFuture,Sg,Pers3_Distant,Masc > => "गा" ;
<CFuture,Sg,Pers3_Distant,Fem > => "गी" ;
<CFuture,Pl,Pers1,Masc > => "गे" ;
<CFuture,Pl,Pers1,Fem > => "गी" ;
<CFuture,Pl,Pers2_Casual,Masc > => "गे" ;
<CFuture,Pl,Pers2_Casual,Fem > => "गी" ;
<CFuture,Pl,Pers2_Familiar,Masc > => "गे" ;
<CFuture,Pl,Pers2_Familiar,Fem > => "गी" ;
<CFuture,Pl,Pers2_Respect,Masc > => "गे" ;
<CFuture,Pl,Pers2_Respect,Fem > => "गी" ;
<CFuture,Pl,Pers3_Near,Masc > => "गे" ;
<CFuture,Pl,Pers3_Near,Fem > => "गी" ;
<CFuture,Pl,Pers3_Distant,Masc > => "गे" ;
<CFuture,Pl,Pers3_Distant,Fem > => "गी"
} ;
raha : Gender -> Number -> Str = \g,n ->
(regAdjective "रहा").s ! n ! g ! Dir ! Posit ;
cka : Gender -> Number -> Str = \g,n ->
(regAdjective "चुका").s ! n ! g ! Dir ! Posit ;
hw : UPerson -> Number -> Str = \pp,n ->
case <pp,n> of {
<Pers1,_> => "हूँ";
<_,Pl> => "होँ";
<_,_> => "हो"
};
hwa : Agr -> Str = \agr ->
let n = (fromAgr agr).n;
p = (fromAgr agr).p;
g = (fromAgr agr).g;
in
case <n,g> of {
<Sg,Masc> => "हुआ";
<Sg,Fem> => "हुई";
<Pl,Masc> => "हुए" ;
<Pl,Fem> => "हुई"
};
-----------------------------------------------
-- Hindustani Adjectives
-----------------------------------------------
regAdjective : Str -> Adjective;
regAdjective x = case x of {
acch + ("ा"|"न") => mkAdjective x ("बहुत" ++ x) ("सब से" ++ x) (acch + "े") ("बहुत" ++ acch + "े") ("सब से" ++ acch + "E") (acch + "े") ("बहुत" ++ acch + "े") ("सब से" ++ acch + "े")
(acch + "ी") ("बहुत" ++ acch + "ी") ("सब से" ++ acch + "ी") (acch + "ी") ("बहुत" ++ acch + "ी") ("सब से" ++ acch + "ी") (acch + "ी") ("बहुत" ++ acch + "ी") ("सब से" ++ acch + "ी")
(acch +"े") ("बहुत" ++ acch + "े") ("सब से" ++ acch + "े") (acch + "े") ("बहुत" ++ acch + "े") ("सब से" ++ acch + "े") (acch + "े") ("बहुत" ++ acch + "े") ("सब से" ++ acch + "े")
(acch + "ी") ("बहुत" ++ acch + "ी") ("सब से" ++ acch + "ी") (acch + "ी") ("बहुत" ++ acch + "ी") ("सब से" ++ acch + "ी") (acch + "ी") ("बहुत" ++ acch + "ी") ("सब से" ++ acch + "ी");
_ => mkAdjective x ("बहुत" ++ x) ("सब से" ++ x) x ("बहुत" ++ x) ("सब से" ++ x) x ("बहुत" ++ x) ("सब से" ++ x)
x ("बहुत" ++ x) ("सब से" ++ x) x ("बहुत" ++ x) ("सब से" ++ x) x ("बहुत" ++ x) ("सब से" ++ x)
x ("बहुत" ++ x) ("सब से" ++ x) x ("बहुत" ++ x) ("सब से" ++ x) x ("बहुत" ++ x) ("सब से" ++ x)
x ("बहुत" ++ x) ("सब से" ++ x) x ("बहुत" ++ x) ("सब से" ++ x) x ("बहुत" ++ x) ("सब से" ++ x)
};
IrregAdjective : Str -> Adjective;
IrregAdjective x = mkAdjective x ("बहुत" ++ x) ("सब से" ++ x) x ("बहुत" ++ x) ("सब से" ++ x) x ("बहुत" ++ x) ("सब से" ++ x)
x ("बहुत" ++ x) ("सब से" ++ x) x ("बहुत" ++ x) ("सब से" ++ x) x ("बहुत" ++ x) ("सब से" ++ x)
x ("बहुत" ++ x) ("सब से" ++ x) x ("बहुत" ++ x) ("सब से" ++ x) x ("बहुत" ++ x) ("सब से" ++ x)
x ("बहुत" ++ x) ("सब से" ++ x) x ("बहुत" ++ x) ("सब से" ++ x) x ("बहुत" ++ x) ("सब से" ++ x) ;
} }

View File

@@ -1,4 +1,4 @@
--# -path=.:../abstract:../common:../prelude:c:/gf_unicoded/hindustani --# -path=.:../abstract:../common:../prelude:
concrete GrammarHin of Grammar = concrete GrammarHin of Grammar =
NounHin, NounHin,
@@ -11,9 +11,9 @@
RelativeHin, RelativeHin,
ConjunctionHin, ConjunctionHin,
PhraseHin, PhraseHin,
TextX - [Adv,AdN], TextX - [Adv,AdN,SC],
StructuralHin, StructuralHin,
TenseX - [Adv,AdN], TenseX - [Adv,AdN,SC],
IdiomHin IdiomHin
** { ** {

View File

@@ -5,21 +5,21 @@ concrete IdiomHin of Idiom = CatHin ** open Prelude,Predef, ResHin,ParamX,Common
lin lin
ImpersCl vp = mkSClause " " (agrP3 Masc Sg) vp ; ImpersCl vp = mkSClause " " (agrP3 Masc Sg) vp ;
GenericCl vp = mkSClause "कwय" (agrP3 Masc Sg) vp ; GenericCl vp = mkSClause "कोई" (agrP3 Masc Sg) vp ;
CleftNP np rs = CleftNP np rs =
let cl = mkSClause (np.s ! NPC rs.c) (np.a) (predAux auxBe); let cl = mkSClause (np.s ! NPC rs.c) (np.a) (predAux auxBe);
in in
{s = \\t,p,o => cl.s ! t ! p ! o ++ rs.s ! np.a }; {s = \\t,p,o => cl.s ! t ! p ! o ++ rs.s ! np.a };
-- CleftAdv ad ss = { s = \\t,b,o => ad.s ! Masc ++ ss.s}; CleftAdv ad ss = { s = \\t,b,o => ad.s ! Masc ++ ss.s};
-- ExistNP np = ExistNP np =
-- mkSClause "wहं" (agrP3 (fromAgr np.a).g (fromAgr np.a).n) mkSClause "वहाँ" (agrP3 (fromAgr np.a).g (fromAgr np.a).n)
-- (insertObj (\\_ => np.s ! NPC Obl) (predAux auxBe)) ; (insertObj (\\_ => np.s ! NPC Dir) (predAux auxBe)) ;
ExistIP ip = ExistIP ip =
let cl = mkSClause ("wहं" ++ ip.s ! Dir) (agrP3 ip.g ip.n) (predAux auxBe); let cl = mkSClause ("वहाँ" ++ ip.s ! Dir) (agrP3 ip.g ip.n) (predAux auxBe);
in { in {
s = \\t,p,qf => case qf of { s = \\t,p,qf => case qf of {
QDir => cl.s ! t ! p ! ODir; QDir => cl.s ! t ! p ! ODir;
@@ -31,8 +31,9 @@ concrete IdiomHin of Idiom = CatHin ** open Prelude,Predef, ResHin,ParamX,Common
ProgrVP vp = (predProg vp) ; ProgrVP vp = (predProg vp) ;
ImpPl1 vp = {s = "ाw" ++ infVP True vp (agrP1 Masc Pl)} ; -- ImpPl1 vp = {s = "आओ" ++ infVP True vp (agrP1 Masc Pl)} ;
ImpP3 np vp = {s = np.s!NPC Dir ++ "कw" ++ (vp.s ! VPImp ).inf ++ "दw"}; ImpPl1 vp = {s = "आओ" ++ vp.obj.s ++ (vp.s ! VPTense VPFutr (agrP1 Masc Pl)).inf ++ vp.comp ! (agrP1 Masc Pl)} ;
ImpP3 np vp = {s = np.s!NPC Dir ++ "को" ++ (vp.s ! VPImp ).inf ++ "दो"};
} }

View File

@@ -8,362 +8,366 @@ concrete LexiconHin of Lexicon = CatHin **
optimize=values ; optimize=values ;
coding = utf8; coding = utf8;
lin lin
airplane_N = mkN "जHज" ; airplane_N = mkCmpdNoun "हवाई" (mkN "जहाज़") ;
-- answer_V2S = mkV2 (compoundV "जwब" (mkV "दयन")) ; answer_V2S = mkV2 (compoundV "जवाब" (mkV "देना")) ;
-- apartment_N = mkN "कमर" ; apartment_N = mkN "कमर" ;
apple_N = mkN "सब" ; apple_N = mkN "सब" ;
-- art_N = mkN "fन" ; -- art_N = mkN "" ;
ask_V2Q = mkV2 (mkV "पwचHन") ; ask_V2Q = mkV2 (mkV "पूछना") ;
-- baby_N = mkN "बचH" ; baby_N = mkN "बच्छा" ;
bad_A = mkA "ब" ; bad_A = mkA "बुरा" ;
bank_N = mkN "बयनक" ; bank_N = mkN "बैंक" ;
beautiful_A = mkA "सनदर" ; beautiful_A = mkA "ख़ूबसूरत" ;
become_VA = mkV "बनन"; become_VA = mkV "बनन";
beer_N = mkN "बेेर" ; beer_N = mkN "बियर" ;
-- beg_V2V = mkV2V (compoundV "लतज" (mkV "करन")) "स" "कह" False; beg_V2V = mkV2V (compoundV "भीख" (mkV "मांगना")) "स" "कह" False;
big_A = mkA "ब" ; big_A = mkA "बड़ा" ;
-- bike_N = mkN "सयचल" feminine ; bike_N = mkN "सायकल" feminine ;
-- bird_N = mkN "परनदह" ; bird_N = mkN "चिड़िया" ;
black_A = mkA "क" ; black_A = mkA "काला" ;
blue_A = mkA "नयल" ; blue_A = mkA "नीला" ;
boat_N = mkN "नw" ; boat_N = mkN "नाव" ;
book_N = mkN "कब" feminine ; book_N = mkN "किताब" feminine ;
-- boot_N = mkN "जwत" ; boot_N = mkN "जूता" ;
boss_N = mkN "मक" ; boss_N = mkN "मालिक" ;
boy_N = mkN "लृक" ; boy_N = mkN "लड़का" ;
bread_N = mkN "रwतय" ; bread_N = mkN "रोटी" ;
break_V2 = mkV2 (mkV "तwृन") ; break_V2 = mkV2 (mkV "तोड़ना") ;
broad_A = mkA "चwृ" ; broad_A = mkA "चौड़ा" ;
brother_N2 = mkN2 (mkN "बHय") (mkPrep "क" "क") "क" ; --not correct brother_N2 = mkN2 (mkN "भाई") (mkPrep "क" "क") "क" ; --not correct
brown_A = mkA "बHwर" ; brown_A = mkA "भूरा" ;
-- butter_N = mkN "मकh-न" ; butter_N = mkN "मक्खन" ;
buy_V2 = mkV2 (mkV "खरयदन"); buy_V2 = mkV2 (mkV "ख़रीदन") "को"; -- add ko: here for es ko khredna, but this will create sentences like kitab ko kharedna
camera_N = mkN "कमरH" ; camera_N = mkN "कमर" ;
cap_N = mkN "तwपय" ; cap_N = mkN "टोपी" ;
car_N = mkN "कर" ; car_N = mkN "कर" ;
-- carpet_N = mkN "तपy^य" ; carpet_N = mkN "क़ालीन" ;
cat_N = mkN "बलय" feminine; cat_N = mkN "बिलली" feminine;
-- ceiling_N = mkN "चh-त" feminine ; ceiling_N = mkN "त" feminine ;
chair_N = mkN "करसय" ; chair_N = mkN "कुर्सी" ;
-- cheese_N = mkN "पनर" feminine ; cheese_N = mkN "पनर" feminine ;
child_N = mkN "बचH" ; child_N = mkN "बच्छा" ;
church_N = mkN "गरज" ; church_N = mkN "गिरिजा" ;
city_N = mkN "XHर" ; city_N = mkN "शहर" ;
clean_A = mkA "सf" ; clean_A = mkA "साफ़" ;
clever_A = mkA "चतर" ; clever_A = mkA "चालाक" ;
close_V2 = mkV2 (compoundV "बनद" do_V2); close_V2 = mkV2 (compoundV "बनद" do_V2);
coat_N = mkN "कwथ" ; coat_N = mkN "कोट" ;
cold_A = mkA "सरद" ; cold_A = mkA "सरद" ;
come_V = mkV "ा" ; come_V = mkV "आना" ;
computer_N = mkN "कपयwथर" ; computer_N = mkN "कपयूटर" ;
country_N = mkN "दयX" ; country_N = mkN "देश" ;
-- cousin_N = mkCmpdNoun "चच" (mkN "ज़द") ; -- a compund noun made of two nouns cousin_N = mkCmpdNoun "चच" (mkN "ज़द") ; -- a compund noun made of two nouns
cow_N = mkN "ग" feminine ; cow_N = mkN "गाय" feminine ;
die_V = mkV "मरन" ; die_V = mkV "मरन" ;
dirty_A = mkA "गनद" ; dirty_A = mkA "गंदा" ;
-- distance_N3 = mkN3 (mkN "fशलह") (mkPrep "क") "क" "स" ; distance_N3 = mkN3 (mkN "फ़ासला") (mkPrep "का" "की") "क" "स" ;
doctor_N = mkN "दकतर" ; doctor_N = mkN "डाकटर" ;
dog_N = mkN "क" ; dog_N = mkN "कुतता" ;
door_N = mkN "दरwज़" ; door_N = mkN "दरवाज़ा" ;
drink_V2 = mkV2 (mkV "पयन"); drink_V2 = mkV2 (mkV "पीना");
easy_A2V = mkA "ान" "" ; -- chek for A or a easy_A2V = mkA "आसान" "" ; -- chek for A or a
eat_V2 = mkV2 (mkV "कHन") "" ; eat_V2 = mkV2 (mkV "खाना") "" ;
empty_A = mkA "खलय" ; empty_A = mkA "ख़ाली" ;
enemy_N = mkN "दXमन" ; enemy_N = mkN "दुश्मन" ;
factory_N = mkN "करखन" ; factory_N = mkN "कारख़ाना" ;
-- father_N2 = mkN2 (mkN "पत" irregular) (mkPrep "क") "क" ; father_N2 = mkN2 (mkN "बाप") (mkPrep "क" "की") "क" ;
fear_VS = mkV "दृन"; fear_N = mkN "डर";
find_V2 = mkV2 (mkV "दHwनद") ; fear_VS = mkV "डरना";
fish_N = mkN "मचHलय" ; find_V2 = mkV2 (mkV "पाना") ;
floor_N = mkN "fरX" ; fish_N = mkN "मछली" ;
forget_V2 = mkV2 (mkV "बHwलन") ; floor_N = mkN "फ़रश" ;
-- fridge_N = mkN "fरयग" ; forget_V2 = mkV2 (mkV "भूलना") ;
friend_N = mkN "दwसत" masculine ; fridge_N = mkN "फ़रिज" ;
fruit_N = mkN "पHल" ; friend_N = mkN "दोस्त" masculine ;
-- fun_AV = mkAV (regA "fुन") ; fruit_N = mkN "फल" ;
garden_N = mkN "बघ" ; -- chek for G -- fun_AV = mkAV (regA "फ़ुन") ;
girl_N = mkN "लृकय" ; garden_N = mkN "बाग़" ; -- chek for g.
glove_N = mkN "दसतन" ; girl_N = mkN "लड़की" ;
gold_N = mkN "सwन" ; glove_N = mkN "दसताना" ;
good_A = mkA "चH" ; gold_N = mkN "सोना" ;
go_V = mkV "जन" ; good_A = mkA "अच्छा" ;
green_A = mkA "Hर" ; go_V = mkV "जाना" ;
-- harbour_N = mkCmpdNoun "बनदर" (mkN "गह") ; green_A = mkA "हरा" ;
hate_V2 = mkV2 (compoundV "नfरत" do_V2) ; harbour_N = mkCmpdNoun "बंदर" (mkN "गाह") ;
hat_N = mkN "थwपय" ; hate_N = mkN "नफ़रत" ;
-- have_V2 = dirV2 (mk5V "हवे" "हस" "हद" "हद" "हविनग") ; hate_V2 = mkV2 (compoundV "नफ़रत" do_V2) ;
hear_V2 = mkV2 (mkV "सनन") ; hat_N = mkN "टोपी" ;
-- hill_N = mkN "पहृय" ; -- have_V2 = dirV2 (mk5V "हवe" "हस" "हद" "हद" "हविनग") ;
-- hope_VS = (compoundV "मयद" do_V2); hear_V2 = mkV2 (mkV "सुनना") ;
horse_N = mkN "गHwृ" ; hill_N = mkN "पहाड़" ;
hope_N = mkN "उममीद" ;
hope_VS = (compoundV "उममीद" do_V2);
horse_N = mkN "घोड़ा" ;
hot_A = mkA "गरम" ; hot_A = mkA "गरम" ;
house_N = mkN "गHर" ; house_N = mkN "र" ;
important_A = mkA "ज़रwरय" ; -- check about z important_A = mkA "ज़रूरी" ; -- check about z
-- industry_N = mkN "शनेत" feminine ; industry_N = mkN "सनत" feminine ;
iron_N = mkN "लwH" ; iron_N = mkN "लोहा" ;
king_N = mkN "र" ; king_N = mkN "राजा" ;
know_V2 = mkV2 (mkV "जनन") ; know_V2 = mkV2 (mkV "जनन") ;
know_VS = mkV "जनन"; know_VS = mkV "जनन";
-- lake_N = mkN "जh-यल" feminine ; lake_N = mkN "झील" feminine ;
lamp_N = mkN "दय" ; lamp_N = mkN "चिराग" ;
learn_V2 = mkV2 (mkV "सयकHन") ; learn_V2 = mkV2 (mkV "सीखना") ;
-- leather_N = mkN "चम" ; leather_N = mkN "चमड़ा" ;
leave_V2 = mkV2 (mkV "चलन") ; leave_V2 = mkV2 (mkV "चलन") ;
like_V2 = mkV2 (compoundV "पसद" do_V2); like_V2 = mkV2 (compoundV "पसद" do_V2);
listen_V2 = mkV2 (mkV "सनन") ; listen_V2 = mkV2 (mkV "सनन") ;
live_V = mkV "रहन" ; ---- touch live_V = mkV "रहन" ; ---- touch
long_A = mkA "लमब" ; long_A = mkA "लंबा" ;
lose_V2 = mkV2 (compoundV "कHw" do_V2) ; lose_V2 = mkV2 (compoundV "खो" do_V2) ;
love_N = mkN "परयम" ; love_N = mkN "प्यार" ;
love_V2 = mkV2 (compoundV "पर" do_V2) "कw"; love_V2 = mkV2 (compoundV "प्यार" do_V2) "क";
man_N = mkN "दम" ; man_N = mkN "दम" masculine;
-- married_A2 = mkA "Xदय " "स" ; married_A2 = mkIrregA "शादी शुदा" "स" ;
meat_N = mkN "मस" ; marriage = mkN "शादी " ;
milk_N = mkN "दwदH" ; meat_N = mkN "मांस" ;
moon_N = mkN "चनद" ; milk_N = mkN "दूध" ;
mother_N2 = mkN2 (mkN "मत" feminine) (mkPrep "कय" "कय") "कै"; -- not covered need to be discussed moon_N = mkN "चांद" ;
-- mountain_N = mkN "पहृय" ; mother_N = mkN "माँ" feminine; -- not covered need to be discussed
music_N = mkN "सनगयत" ; mountain_N = mkN "पहाड़" ;
-- narrow_A = mkA "बरयक" ; music_N = mkN "संगीत" ;
new_A = mkA "नय" ; narrow_A = mkA "तंग" ;
newspaper_N = mkN "खबर" ; new_A = mkA "नया" ;
oil_N = mkN "तयल" ; newspaper_N = mkN "अख़बार" ;
old_A = mkA "बwृH" ; oil_N = mkN "तेल" ;
open_V2 = mkV2 (mkV "कHwलन") ; old_A = mkA "बूढ़ा" ;
-- paint_V2A = mkV2 (compoundV "रनग" do_V2) ; open_V2 = mkV2 (mkV "खोलना") ;
paper_N = mkN "कघज़" ; paint_V2A = mkV2 (compoundV "रंग" do_V2) ;
paris_PN = mkPN "पयरस" ; paper_N = mkN "काग़ज़" ;
peace_N = mkN "मन" ; paris_PN = mkPN "पैरिस" ;
pen_N = mkN "qलम" ; peace_N = mkN "अमन" ;
-- planet_N = mkN "सयरह" ; pen_N = mkN "क़लम" ;
-- plastic_N = mkN "पलसथक" ; planet_N = mkN "सितारा" ;
play_V2 = mkV2 (mkV "कHयलन") ; plastic_N = mkN "पलासटिक" ;
-- policeman_N = mkCmpdNoun "पwलयस" (mkN "wल") ; play_V2 = mkV2 (mkV "खेलना") ;
-- priest_N = (mkN "पयघमबर") ; policeman_N = mkCmpdNoun "पुलिस" (mkN "wाला") ;
-- probable_AS = mkAS (regA "परॉबबले") ; priest_N = mkN "पुजारी" ;
-- queen_N = mkN "Xहज़दय" ; -- probable_AS = mkAS (regA "परoबबलe") ;
-- radio_N = mkN "रयधयw" ; queen_N = mkN "रानी" ;
rain_V0 = compoundV "बरX" (mkV "Hwन" ) ; radio_N = mkN "रेडिो" ;
read_V2 = mkV2 (mkV "पृHन"); rain_N = mkN "बारिश" ;
red_A = mkA "लल" ; rain_V0 = compoundV "बारिश" (mkV "होना" ) ;
religion_N = mkN "दHरम" ; read_V2 = mkV2 (mkV "पढ़ना");
-- restaurant_N = mkN "हwथल" ; red_A = mkA "लाल" ;
river_N = mkN "दरय" masculine ; religion_N = mkN "मज़हब" ;
rock_N = mkN "चथन" ; restaurant_N = mkN "रेसटोरांट" ;
roof_N = mkN "चh-त" masculine ; -- river_N = mkN "दरिया" masculine ;
-- rubber_N = mkN "रबृ" ; rock_N = mkN "चटटान" ;
run_V = mkV "दwृन" ; roof_N = mkN "छत" masculine ;
say_VS = mkV "कHन" ; rubber_N = mkN "रबर" ;
school_N = mkN "मकतब" ; run_V = mkV "दौड़ना" ;
-- science_N = mkN "सनस" ; -- vgyan say_VS = mkV "कहना" ;
sea_N = mkN "समनदर" ; school_N = mkN "सकूल" ;
-- seek_V2 = mkV2 (compoundV "तलX" do_V2) ; science_N = mkN "सािनस" ; -- vgyan
see_V2 = mkV2 (mkV "दयकHन") ; sea_N = mkN "समंदर" ;
sell_V3 = mkV3 (mkV "बयचन") "कw" ""; seek_V2 = mkV2 (compoundV "तलाश" do_V2) ;
send_V3 = mkV3 (mkV "बHयजन") "कw" ""; see_V2 = mkV2 (mkV "देखना") ;
sheep_N = mkN "बHयृ" feminine ; sell_V3 = mkV3 (mkV "बेचना") "को" "";
ship_N = mkN "जHज़" ; send_V3 = mkV3 (mkV "भेजना") "को" "";
shirt_N = mkN "करत" feminine; sheep_N = mkN "भीड़" feminine ;
shoe_N = mkN "जwत" ; ship_N = mkN "जहाज़" ;
shop_N = mkN "दwकन" feminine ; shirt_N = mkN "कुर्ता" feminine;
short_A = mkA "चHwथ" ; shoe_N = mkN "जूता" ;
silver_N = mkN "चनदय" ; shop_N = mkN "दूकान" feminine ;
sister_N = mkN "बHन" feminine ; short_A = mkA "छोटा" ;
sleep_V = mkV "सwन" ; silver_N = mkN "चांदी" ;
small_A = mkA "चHwथ" ; sister_N = mkN "बहन" feminine ;
snake_N = mkN "सनप" ; sleep_V = mkV "सोना" ;
-- sock_N = mkN "जरब" feminine ; small_A = mkA "छोटा" ;
speak_V2 = mkV2 (mkV "बwलन") ; snake_N = mkN "सांप" ;
star_N = mkN "तर" ; sock_N = mkN "जुरराब" feminine ;
-- steel_N = mkN "सतयल" ; -- something like ispat speak_V2 = mkV2 (mkV "बोलना") ;
stone_N = mkN "पतHर" ; star_N = mkN "तारा" ;
-- stove_N = mkN "चwलह" ; steel_N = mkN "इसपात" ; -- something like ispat
-- student_N = mkCmpdNoun "t-लब" (mkN "ेलम") ; -- something vidrati stone_N = mkN "पत्थर" ;
stupid_A = mkA "बैwqwf" ; stove_N = mkN "चूल्हा" ;
-- sun_N = mkN "सwरज" ; -- swrya -- student_N = mkCmpdNoun "t-लब" (mkN "eलम") ; -- something vidrati
switch8off_V2 = mkV2 (compoundV "बनद" do_V2) ; stupid_A = mkA "बेवक़ूफ़" ;
switch8on_V2 = mkV2 (mkV "चलन") ; sun_N = mkN "सूरज" ; -- swrya
table_N = mkN "मयज़" feminine ; switch8off_V2 = mkV2 (compoundV "बंद" do_V2) ;
talk_V3 = mkV3 (mkV "बwलन") "सै" "कै बरै में"; switch8on_V2 = mkV2 (mkV "चलाना") ;
-- teacher_N = mkN "िसतद" ; -- adyapak table_N = mkN "मेज़" feminine ;
teach_V2 = mkV2 (mkV "पृHन") ; talk_V3 = mkV3 (mkV "बोलना") "से" "के बारे मे";
television_N = mkN "तयwय" ; teacher_N = mkN "उस्ताद" ; -- adyapak
thick_A = mkA "मwथ" ; teach_V2 = mkV2 (mkV "सिखाना") ;
thin_A = mkA "पतल" ; television_N = mkN "टीवी" ;
train_N = mkN "रयल गृय" ; thick_A = mkA "मोटा" ;
travel_V = (compoundV "सfर" do_V2) ; thin_A = mkA "पतला" ;
-- tree_N = mkN "पयृ" masculine ; train_N = mkN "रेल गाड़ी" ;
-- ---- trousers_N = mkN "तरॉुसेरस" ; travel_V = (compoundV "सफ़र" do_V2) ;
ugly_A = mkA "बदसwरत" ; -- tree_N = mkN "पेड़" masculine ;
understand_V2 = mkV2 (mkV "समजHन") ; trousers_N = mkN "पतलून" ;
-- university_N = mkN "यwनयwरसथय" ; ugly_A = mkA "बदसूरत" ;
village_N = mkN "गwं" ; -- check for n or N understand_V2 = mkV2 (mkV "समझना") ;
-- wait_V2 = mkV2 (compoundV "नतz-र" do_V2) "क" ; -- something prtkXa university_N = mkN "यूनिवरसिटी" ;
walk_V = mkV "चलन" ; village_N = mkN "गाँव" ; -- check for n or N
-- warm_A = mkA "गरम" ; something gngna wait_V2 = mkV2 (compoundV "इंतज़ार" do_V2) "का" ; -- something prtkXa
-- war_N = mkN "जनग" ; walk_V = mkV "चलना" ;
watch_V2 = mkV2 (mkV "दयकHन") ; warm_A = mkA "गरम" ; something gngna
-- water_N = mkN "पनय" masculine ; -- not covered masculine ending with y war_N = mkN "लड़ाई" ;
white_A = mkA "सfयद" ; watch_V2 = mkV2 (mkV "देखना") ;
window_N = mkN "रwXनदन" ; water_N = mkN "पानी" masculine ; -- not covered masculine ending with y
-- wine_N = mkN "Xरब" feminine ; white_A = mkA "सफ़ेद" ;
win_V2 = mkV2 (mkV "जयतन") ; window_N = mkN "खिड़की" ;
woman_N = mkN "ेwरत" feminine ; wine_N = mkN "शराब" feminine ;
-- wonder_VQ = compoundV "Hेरन" (mkV "हwन") ; win_V2 = mkV2 (mkV "जीतना") ;
wood_N = mkN "लकृय" ; woman_N = mkN "औरत" feminine ;
write_V2 = mkV2 (mkV "लकh-न") ; wonder_VQ = compoundV "हैरान" (mkV "होना") ;
yellow_A = mkA "पयल" ; wood_N = mkN "लकड़ी" ;
young_A = mkA "जwन" ; write_V2 = mkV2 (mkV "लिखना") ;
do_V2 = mkV2 (mkV "करन") ; yellow_A = mkA "पीला" ;
-- now_Adv = mkAdv "ब" ; young_A = mkA "जवान" ;
-- already_Adv = mkAdv "पहलै हय" ; do_V2 = mkV2 (mkV "करना") ;
song_N = mkN "गयत" ; now_Adv = mkAdv "अब" ;
add_V3 = mkV3 (compoundV "जमे" do_V2) "" "" ; already_Adv = mkAdv "पहले ही" ;
-- number_N = mkN "हनदसह" ; song_N = mkN "गीत" ;
-- put_V2 = mkV2 (mkV "धलन") ; add_V3 = mkV3 (mkV "जोड़ना") "को" "मीं"; -- confirm
stop_V = mkV "रकन" ; number_N = mkN "हनदसह" ;
-- jump_V = compoundV "चHलनग" (mkV "लगन") feminine ; put_V2 = mkV2 (mkV "डालना") ;
stop_V = mkV "रुकना" ;
jump_V = compoundV "छलांग" (mkV "लगाना") ;
-- left_Ord = {s = "बयं" ; n = singular}; left_Ord = {s = "बायाँ" ; n = singular};
-- right_Ord = {s= "दयं" ; n = singular}; right_Ord = {s= "दायाँ" ; n = singular};
-- far_Adv = mkAdv "दwर" ; far_Adv = mkAdv "दर" ;
correct_A = mkA "सयH" ; correct_A = mkA "सहीह" ;
dry_A = mkA "सwकH" ; dry_A = mkA "सूखा" ;
-- dull_A = mkA "नलिक" ; dull_A = mkA "नलिक" ;
-- full_A = mkA "मकमल" ; full_A = mkA "भरा" ;
heavy_A = mkA "बHरय" ; heavy_A = mkA "भारी" ;
near_A = mkA "पस" ; near_A = mkA "पस" ;
-- rotten_A = mkA "खरब" ; rotten_A = mkA "सड़ा" ;
round_A = mkA "गwल" ; round_A = mkA "गल" ;
sharp_A = mkA "तज़" ; sharp_A = mkA "तज़" ;
smooth_A = mkA "चकन" ; smooth_A = mkA "चिकन" ;
straight_A = mkA "सयदH" ; straight_A = mkA "सीधा" ;
wet_A = mkA "गयल" ; ---- wet_A = mkA "गीला" ; ----
wide_A = mkA "चwृ" ; wide_A = mkA "चौड़ा" ;
animal_N = mkN "जनwर" ; animal_N = mkN "जानवर" ;
ashes_N = mkN "रकh-" feminine; -- FIXME: plural only? ashes_N = mkN "राख" feminine; -- FIXME: plural only?
-- back_N = mkN "qमर" feminine ; back_N = mkN "पीठ" feminine ;
-- bark_N = mkN "बरक" ; -- bark_N = mkN "बरक" ;
-- belly_N = mkN "दh-नय" ; -- belly_N = mkN "दh-नय" ;
-- blood_N = mkN "खwन" ; blood_N = mkN "ख़ून" ;
bone_N = mkN "Hधय" feminine ; bone_N = mkN "हडडी" feminine ;
-- breast_N = mkN "चh-तय" ; --stan breast_N = mkN "छाती" ; --stan
cloud_N = mkN "बदल" ; cloud_N = mkN "बदल" ;
day_N = mkN "दन" ; day_N = mkN "दिन" ;
dust_N = mkN "दHwल" ; dust_N = mkN "धूल" ;
ear_N = mkN "कन" ; ear_N = mkN "कन" ;
-- earth_N = mkN "ज़मन" feminine ; earth_N = mkN "ज़मन" feminine ;
egg_N = mkN "नधH" ; egg_N = mkN "अंडा" ;
eye_N = mkN "ानकH" feminine ; eye_N = mkN "आंख" feminine ;
fat_N = mkN "मwत" ; fat_N = mkN "मोटा" ;
feather_N = mkN "पनकH" ; feather_N = mkN "पंख" ;
-- fingernail_N = mkN "नन" ; fingernail_N = mkN "नाखून" ;
fire_N = mkN "ग" feminine ; fire_N = mkN "ग" feminine ;
flower_N = mkN "पHwल" ; flower_N = mkN "फूल" ;
fog_N = mkN "दHनद" feminine ; fog_N = mkN "धुंध" feminine ;
foot_N = mkN "पwं" ; -- not properly covered need to be discussed foot_N = mkN "पांव" ; -- not properly covered need to be discussed
forest_N = mkN "जगल" ; forest_N = mkN "जगल" ;
grass_N = mkN "गHस" feminine ; grass_N = mkN "घास" feminine ;
-- guts_N = mkN "गुत" ; -- FIXME: no singular -- guts_N = mkN "गुत" ; -- FIXME: no singular
hair_N = mkN "बल" ; hair_N = mkN "बल" ;
hand_N = mkN "HतH" ; hand_N = mkN "हाथ" ;
head_N = mkN "सर" ; head_N = mkN "सिर" ;
heart_N = mkN "दल" ; heart_N = mkN "दिल" ;
-- horn_N = mkN "गh-नतय" ; horn_N = mkN "सींग" ;
husband_N = mkN "पत" ; husband_N = mkN "पति" ;
ice_N = mkN "बरf" feminine ; ice_N = mkN "बर्फ़" feminine ;
knee_N = mkN "गHतनH" ; knee_N = mkN "घुटना" ;
leaf_N = mkN "पतH" ; leaf_N = mkN "पतता" ;
leg_N = mkN "तनग" feminine ; leg_N = mkN "टांग" feminine ;
liver_N = mkN "कलयजH" ; liver_N = mkN "कलेजा" ;
-- louse_N = mkN "" ; -- jwN louse_N = mkN "जू" ;
mouth_N = mkN "मनH" ; mouth_N = mkN "मुह" ;
name_N = mkN "नम" ; name_N = mkN "नम" ;
neck_N = mkN "गरदन" feminine ; neck_N = mkN "गरदन" feminine ;
night_N = mkN "रत" feminine ; night_N = mkN "रत" feminine ;
nose_N = mkN "नक" ; nose_N = mkN "नक" ;
-- person_N = mkN "Xखश" ; -- person_N = mkN "XKष" ;
rain_N = mkN "बरX" feminine ; road_N = mkN "सड़क" ;
road_N = mkN "सृक" ; root_N = mkN "जड़" feminine ;
root_N = mkN "गृ" feminine ; rope_N = mkN "रससी" ;
rope_N = mkN "रसय" ;
salt_N = mkN "नमक" feminine ; salt_N = mkN "नमक" feminine ;
sand_N = mkN "रत" feminine ; sand_N = mkN "रत" feminine ;
seed_N = mkN "बज" ; seed_N = mkN "बज" ;
-- skin_N = mkN "जलद" feminine ; -- crm skin_N = mkN "जलद" feminine ; -- crm
sky_N = mkN "मबर" ; sky_N = mkN "आसमान" ;
smoke_N = mkN "दHwं"; -- singular masc nouns ending with aN,wN yet to be implemented smoke_N = mkN "धुाँ"; -- singular masc nouns ending with aN,wN yet to be implemented
snow_N = mkN "बरf" feminine ; snow_N = mkN "बर्फ़" feminine ;
stick_N = mkN "सॉथय" ; stick_N = mkN "लकड़ी" ;
tail_N = mkN "दम" ; tail_N = mkN "दम" ;
-- tongue_N = mkN "ज़बन" feminine ; tongue_N = mkN "ज़बन" feminine ;
-- tooth_N = mkN "दत" masculine; tooth_N = mkN "दांत" masculine;
wife_N = mkN "पतनय" ; wife_N = mkN "बीवी" ;
wind_N = mkN "Hw" ; wind_N = mkN "हवा" ;
-- wing_N = mkN "पर" ; -- wing_N = mkN "पर" ;
worm_N = mkN "कयृ" ; worm_N = mkN "कीड़" ;
year_N = mkN "सल" ; year_N = mkN "सल" ;
-- blow_V = mkV "चलन" ; -- blow_V = mkV "चलन" ;
breathe_V = compoundV "सस" (mkV "लयन" ) ; breathe_V = compoundV "साँस" (mkV "लेना" ) ;
burn_V = mkV "जल" ; burn_V = mkV "जलाना" ;
dig_V = mkV "कHwदन" ; dig_V = mkV "खोदन" ;
fall_V = mkV "गरन" ; fall_V = mkV "गिरन" ;
-- float_V = mkV "तरन" ; float_V = mkV "तरन" ;
flow_V = mkV "चलन" ; flow_V = mkV "बहना" ;
fly_V = mkV "ृन" ; fly_V = mkV "ुड़ना" ;
-- freeze_V = mkV "जमन"; -- freeze_V = mkV "जमन";
give_V3 = mkV3 (mkV "दयन") "कw" ""; give_V3 = mkV3 (mkV "देना") "क" "";
laugh_V = mkV "हसन" ; laugh_V = mkV "हसन" ;
-- lie_N = mkN "जh-wत" masculine ; lie_N = mkN "झूट" masculine ;
lie_V = compoundV "जHwत" (mkV "बwलन" ); lie_V = compoundV "झूट" (mkV "बलन" );
play_V = mkV "कHयलन" ; play_V = mkV "खेलन" ;
sew_V = mkV "सयन" ; sew_V = mkV "सीना" ;
sing_V = mkV "ग" ; sing_V = mkV "गाना" ;
sit_V = mkV "बयथHन" ; sit_V = mkV "बैठना" ;
smell_V = mkV "सwनगन" ; smell_V = mkV "सूंगन" ;
spit_V = mkV "तHwकन" ; spit_V = mkV "थूकन" ;
stand_V = compoundV "कHृै" (mkV "हwन" ); -- a type of compound verb made of two verbs i.e 'kHRa' also inflects, rather than a string and verb should be fixed stand_V = compoundV "खड़ा" (mkV "होना" ); -- a type of compound verb made of two verbs i.e 'kHRa' also inflects, rather than a string and verb should be fixed
-- swell_V = mkV "सwजh-न" ; swell_V = mkV "सूजना" ;
swim_V = mkV "तरन" ; swim_V = mkV "तरन" ;
think_V = mkV "सwचन" ; think_V = mkV "सचन" ;
turn_V = mkV "मृन"; turn_V = mkV "मुड़ना";
-- vomit_V = compoundV "लय" (mkV "करन") feminine ; -- vomit_V = compoundV "लय" (mkV "करन") feminine ;
bite_V2 = mkV2 (mkV "कतन") ; bite_V2 = mkV2 (mkV "काटना") ;
count_V2 = mkV2 (mkV "गनन") ; count_V2 = mkV2 (mkV "गिनन") ;
cut_V2 = mkV2 (mkV "कतन") ; cut_V2 = mkV2 (mkV "काटना") ;
fear_V2 = mkV2 (mkV "रन") ; fear_V2 = mkV2 (mkV "रन") ;
fight_V2 = mkV2 (mkV "लृन") ; fight_V2 = mkV2 (mkV "लड़ना") ;
-- hit_V2 = mkV2 (compoundV "तh-wकर" (mkV "मरन" )); -- hit_V2 = mkV2 (compoundV "तh-wकर" (mkV "मरन" ));
hold_V2 = mkV2 (mkV "पकृन") ; hold_V2 = mkV2 (mkV "पकड़ना") ;
-- hunt_V2 = mkV2 (compoundV "Xकर" do_V2); -- hunt_V2 = mkV2 (compoundV "Xकर" do_V2);
kill_V2 = mkV2 (compoundV "मर" (mkV "लन" )) ; kill_V2 = mkV2 (compoundV "मर" (mkV "डालन" )) ;
pull_V2 = mkV2 (mkV "कHनचन"); pull_V2 = mkV2 (mkV "खींचन");
-- push_V2 = mkV2 (mkV "दh-कयलन") "कw" ; push_V2 = mkV2 (mkV "धकेलन") "क" ;
-- rub_V2 = mkV2 (mkV "रगृन") ; rub_V2 = mkV2 (mkV "रगड़ना") ;
-- scratch_V2 = mkV2 (mkV "कh-रचन") "कw" ; scratch_V2 = mkV2 (mkV "खरोंचन") "क" ;
-- split_V2 = mkV2 (mkV "बनत") "कw" ; -- split_V2 = mkV2 (mkV "बनत") "कo::" ;
-- squeeze_V2 = dirV2 (regV "सqुेेज़े") ; -- squeeze_V2 = dirV2 (regV "सक़ुeeज़e") ;
-- stab_V2 = dirV2 (regDuplV "सतब") ; -- stab_V2 = dirV2 (regDuplV "सतब") ;
-- suck_V2 = mkV2 (mkV "चwसन") ; suck_V2 = mkV2 (mkV "चसन") ;
throw_V2 = mkV2 (mkV "पHयनकन") ; throw_V2 = mkV2 (mkV "फेंकन") ;
tie_V2 = mkV2 (mkV "बनदHन") ; tie_V2 = mkV2 (mkV "बांधना") ;
wash_V2 = mkV2 (mkV "दHwन") ; wash_V2 = mkV2 (mkV "धोना") ;
wipe_V2 = mkV2 (compoundV "शf" (mkV "करन" )); -- wash_V2 = mkV2 (mkV "पोंछना") ;
---- other_A = regA "तहर" ; ---- other_A = regA "oतहeर" ;
-- grammar_N = mkN "गरदन" ; -- grammar_N = mkN "गरदन" ;
-- language_N = mkN "ज़बन" feminine ; -- language_N = mkN "ज़बन" feminine ;
-- rule_N = mkN "wल" ; -- rule_N = mkN "अषwल" ;
---- added 4/6/2007 ---- added 4/6/2007
john_PN = mkPN "जन" ; john_PN = mkPN "जन" ;
-- question_N = mkN "सwल" ; question_N = mkN "सवाल" ;
-- ready_A = regA "रेदय" ; ready_A = mkA "तैयार" ;
-- reason_N = mkN "wजह" feminine ; reason_N = mkN "जह" feminine ;
-- today_Adv = mkAdv "ज" ; today_Adv = mkAdv "ज" ;
-- uncertain_A = mkA ["यर यqयनय"] ; -- uncertain_A = mkA ["यर ययनय"] ;
} }

View File

@@ -36,29 +36,31 @@ oper
regNoun : Str -> Noun ; regNoun : Str -> Noun ;
regNoun s = case s of { regNoun s = case s of {
_ + "य" => mkN05 (s); _ + "य" => mkN05 (s);
_ + (""|"े"|"ह") => mkN01 (s); _ + ("") => mkN01 (s);
_ + "" => mkN03 (s); _ + "" => mkN03 (s);
_ + (""|"wं") => mkN04 (s); _ + ("ाँ"|"") => mkN04 (s);
_ + "ाँव" => mkN12 s;
_ + "w^" => mkN12 (s); _ + "w^" => mkN12 (s);
_ => regNoun2 (s) _ => regNoun2 (s)
}; };
regNoun2 : Str -> Noun; regNoun2 : Str -> Noun;
regNoun2 s = let c = if_then_else Bool (eq (last s) "" ) True (if_then_else Bool (eq (last s) "ह") True (if_then_else Bool (eq (last s) "") True False)) regNoun2 s = let c = if_then_else Bool (eq (last s) "" ) True (if_then_else Bool (eq (last s) "ह") True (if_then_else Bool (eq (last s) "e") True False))
in case c of { in case c of {
False => mkN02 (s); False => mkN02 (s);
True => mkN01 (s) True => mkN01 (s)
}; };
reggNoun : Str -> Gender -> Noun ; reggNoun : Str -> Gender -> Noun ;
reggNoun s g = let c = if_then_else Bool (eq (last s) "" ) True (if_then_else Bool (eq (dp 2 s) "") True (if_then_else Bool (eq (dp 2 s) "w") True False)) reggNoun s g = let c = if_then_else Bool (eq (last s) "" ) True (if_then_else Bool (eq (dp 2 s) "") True (if_then_else Bool (eq (dp 2 s) "w") True False))
in case <s,g,c> of { in case <s,g,c> of {
<_ + "त",Fem,_> => mkN10 (s); <_ + "त",Fem,_> => mkN10 (s);
<_ + "त",Masc,_> => mkN02 (s); <_ + "त",Masc,_> => mkN02 (s);
<_ + "w",Masc,_> => mkN11 (s); <_ + "",Masc,_> => mkN11 (s);
<_ + "w",Fem,_> => mkN07 (s); <_ + "w",Fem,_> => mkN07 (s);
<_ + "य",Fem,_> => mkN05 (s); <_ + "य",Fem,_> => mkN05 (s);
<_ + "य",Masc,_> => mkN02 (s); <_ + "य",Masc,_> => mkN02 (s);
<_ + "ी",Masc,_> => mkN13 (s);
<_,Fem,False> => mkN08 (s); <_,Fem,False> => mkN08 (s);
<_,Fem,_> => mkN09 (s) <_,Fem,_> => mkN09 (s)
@@ -69,15 +71,15 @@ oper
mkN01 : Str -> Noun ; mkN01 : Str -> Noun ;
mkN01 lRka = let end = last (lRka) ; mkN01 lRka = let end = last (lRka) ;
lRk = if_then_else Str (eq end "") lRka (tk 1 lRka) lRk = if_then_else Str (eq end "e") lRka (tk 1 lRka)
in mkNoun (lRka) (lRk+"") (lRk+"") in mkNoun (lRka) (lRk+"") (lRk+"")
(lRk+"") (lRk+"wं") (lRk+"w") (lRk+"") (lRk+"ोँ") (lRk+"")
Masc ; Masc ;
-- masculine nouns does not end with a, h, e, an -- masculine nouns does not end with a, h, e, an
mkN02 : Str -> Noun ; mkN02 : Str -> Noun ;
mkN02 mrd = let mrdwN = mrd+"wं" ; mkN02 mrd = let mrdwN = mrd+"ोँ" ;
mrdw = tk 1 mrdwN mrdw = tk 1 mrdwN
in mkNoun mrd mrd mrd in mkNoun mrd mrd mrd
mrd mrdwN mrdw mrd mrdwN mrdw
@@ -86,24 +88,32 @@ oper
-- feminine Nouns end with y -- feminine Nouns end with y
mkN03 : Str -> Noun ; mkN03 : Str -> Noun ;
mkN03 krsy = let krsyaN = krsy+"" ; mkN03 krsy = let krsyaN = krsy+"" ;
krsywN = krsy+"wं" ; krsywN = krsy+"योँ" ;
krsyw = tk 1 krsywN krsyw = tk 1 krsywN
in mkNoun krsy krsy krsy in mkNoun krsy krsy krsy
krsyaN krsywN krsyw krsyaN krsywN krsyw
Fem ; Fem ;
-- masculine nouns ending at i: e.g Admi:
mkN13 : Str -> Noun ;
mkN13 krsy = let
krsywN = krsy+"योँ" ;
krsyw = tk 1 krsywN
in mkNoun krsy krsy krsy
krsy krsywN krsyw
Masc ;
-- feminine nouns end with a, aN, wN -- feminine nouns end with a, aN, wN
mkN04 : Str -> Noun ; mkN04 : Str -> Noun ;
mkN04 n = case last n of { mkN04 n = case last n of {
"" => let bla = n "" => mkNoun n n n
in mkNoun bla bla bla (n+"ाेँ") (n+"ाोँ") (n+"ाो")
(bla+"y^यं") (bla+"w^ं") (bla+"w^")
Fem ; Fem ;
_ => let maN = n ; -- ends with aN and wN _ => let maN = n ; -- ends with aN and wN
ma = tk 1 maN ma = tk 1 maN
in mkNoun maN maN maN in mkNoun maN maN maN
(ma+"y^यं") (ma+"w^ं") (ma+"w^ं") (maN+"ाँेँ") (maN+"ाँोँ") (maN+"ाँो")
Fem Fem
}; };
@@ -112,14 +122,14 @@ oper
mkN05 : Str -> Noun ; mkN05 : Str -> Noun ;
mkN05 gRya = let gRy = (tk 1 gRya) mkN05 gRya = let gRy = (tk 1 gRya)
in mkNoun gRya gRya gRya in mkNoun gRya gRya gRya
(gRya+"") (gRy+"wं") (gRy+"w") (gRya+"") (gRy+"ोँ") (gRy+"")
Fem ; Fem ;
-- feminine nouns end with w -- feminine nouns end with w
mkN07 : Str -> Noun ; mkN07 : Str -> Noun ;
mkN07 khshbw = mkNoun khshbw khshbw khshbw mkN07 khshbw = mkNoun khshbw khshbw khshbw
(khshbw + "y^यं") (khshbw + "w^ं") (khshbw + "w^") (khshbw + "ेँ") (khshbw + "ोँ") (khshbw + "")
Fem ; Fem ;
-- Loan arabic feminine nouns end with t -- Loan arabic feminine nouns end with t
@@ -127,7 +137,7 @@ oper
mkN10 : Str -> Noun ; mkN10 : Str -> Noun ;
mkN10 ndamt = mkNoun ndamt ndamt ndamt mkN10 ndamt = mkNoun ndamt ndamt ndamt
(ndamt+"ं") (ndamt+"wं") (ndamt+"w") (ndamt+"ं") (ndamt+"w:ं") (ndamt+"")
Fem ; Fem ;
-- Worst case function -- Worst case function
mkN : (_,_,_,_,_,_ : Str) -> Gender -> Noun ; mkN : (_,_,_,_,_,_ : Str) -> Gender -> Noun ;
@@ -136,28 +146,28 @@ oper
mkN06 : Str -> Noun ; mkN06 : Str -> Noun ;
mkN06 rya = mkNoun rya rya rya mkN06 rya = mkNoun rya rya rya
(rya+"y^य") (rya+"w^") rya (rya+"y^य") (rya+"w^") rya
Fem ; Fem ;
-- feminine nouns that do not end with a, N, w, wN -- feminine nouns that do not end with a, N, w, wN
mkN08 : Str -> Noun ; mkN08 : Str -> Noun ;
mkN08 ktab = mkNoun ktab ktab ktab mkN08 ktab = mkNoun ktab ktab ktab
(ktab+"यं") (ktab+"wं") (ktab+"w") (ktab+"ेँ") (ktab+"ोँ") (ktab+"")
Fem ; Fem ;
-- Loan arabic feminine nouns -- Loan arabic feminine nouns
mkN09 : Str -> Noun ; mkN09 : Str -> Noun ;
mkN09 ahsan = mkNoun ahsan ahsan ahsan mkN09 ahsan = mkNoun ahsan ahsan ahsan
(ahsan+"त") (ahsan+"त") (ahsan+"w") (ahsan+"त") (ahsan+"त") (ahsan+"")
Fem ; Fem ;
-- (variants{ahsan+"त";ahsan+"w"}) -- (variants{ahsan+"त";ahsan+"w"})
-- Loan persian maculine nouns end with w -- Loan persian maculine nouns end with w
mkN11 : Str -> Noun ; mkN11 : Str -> Noun ;
mkN11 alw = mkNoun alw alw alw mkN11 alw = mkNoun alw alw alw
alw (alw+"w^ं") (alw+"w^") alw (alw+"ोँ") (alw+"")
Masc ; Masc ;
@@ -167,17 +177,19 @@ oper
mkN12 bhao = mkNoun (bhao) (bhao) (bhao) mkN12 bhao = mkNoun (bhao) (bhao) (bhao)
(bhao) (bhao) (bhao) (bhao) (bhao) (bhao)
Masc ; Masc ;
----2 Determiners ----2 Determiners
IDeterminer = {s:Gender => Str ; n : Number}; IDeterminer = {s:Gender => Case => Str ; n : Number};
makeDet : Str -> Str -> Str -> Str -> Number -> Determiner = \s1,s2,s3,s4,n -> { makeDet : Str -> Str -> Str -> Str -> Number -> Determiner = \s1,s2,s3,s4,n -> {
s = table { s = table {
Sg => table { Sg => table {
Masc => s1 ; Masc => table {_ => s1} ;
Fem => s2 Fem => table {_ => s2}
} ; } ;
Pl => table { Pl => table {
Masc => s3 ; Masc => table { _ => s3} ;
Fem => s4 Fem => table {_ => s4}
} }
} ; } ;
@@ -186,8 +198,8 @@ oper
makeIDet : Str -> Str -> Number -> IDeterminer = \s1,s2,n -> { makeIDet : Str -> Str -> Number -> IDeterminer = \s1,s2,n -> {
s = table { s = table {
Masc => s1; Masc => table {_ =>s1};
Fem => s2 Fem => table {_ =>s2}
}; };
n = n n = n
}; };
@@ -290,8 +302,8 @@ oper
}; };
makePersPron : PersPron; makePersPron : PersPron;
makePersPron = mkPersPron "m(a)य" "m(o)j'|ह" "" "t(o)w " "t(o)j|ह" "t(o)w " "t(o)म" "t(o)म" "t(o)म" "प" "प" "प" "y(i)ह" "a(i)स" "" "w(o)ह" "a(o)स" "" makePersPron = mkPersPron "m(a)य" "m(o)j'|ह" "" "t(o)w " "t(o)j|ह" "t(o)w " "t(o)म" "t(o)म" "t(o)म" "प" "प" "प" "y(i)ह" "a(i)स" "" "w(o)ह" "a(o)स" ""
"h(a)म" "h(a)म" "" "t(o)म" "t(o)म" "t(o)म" "t(o)म" "t(o)म" "t(o)म" "प" "प" "प" "y(i)ह" "a(i)न" "" "w(o)ह" "a(o)न" "" ; "h(a)म" "h(a)म" "" "t(o)म" "t(o)म" "t(o)म" "t(o)म" "t(o)म" "t(o)म" "प" "प" "प" "y(i)ह" "a(i)न" "" "w(o)ह" "a(o)न" "" ;
mkPron : (x1,x2,x3:Str) -> {s:Case => Str} = mkPron : (x1,x2,x3:Str) -> {s:Case => Str} =
\y1,y2,y3 -> { s = \y1,y2,y3 -> { s =
@@ -317,13 +329,14 @@ oper
}; };
----2 Adjectives ----2 Adjectives
-- defined in ResUrd
makeIrregA : Str -> Adjective = \str -> {s = \\_,_,_,_ => str} ;
----3 Verbs ----3 Verbs
CommonVF = {s : VTense => UPerson => Number => Gender => Str} ; CommonVF = {s : VTense => UPerson => Number => Gender => Str} ;
mkVerb : (x1: Str) -> Verb = \inf -> mkVerb : (x1: Str) -> Verb = \inf ->
let root = (tk 2 inf); inf_obl = ((tk 1 inf) + ""); inf_fem = ((tk 1 inf) + "य") let root = (tk 2 inf); inf_obl = ((tk 1 inf) + ""); inf_fem = ((tk 2 inf) + "य")
in { s = table { in { s = table {
VF tense person number gender => (mkCmnVF root tense person number gender).s ; VF tense person number gender => (mkCmnVF root tense person number gender).s ;
@@ -343,38 +356,43 @@ oper
mkCmnVF : Str -> VTense -> UPerson -> Number -> Gender -> {s:Str} = mkCmnVF : Str -> VTense -> UPerson -> Number -> Gender -> {s:Str} =
\root,t,p,n,g -> \root,t,p,n,g ->
{s = {s =
let form1 = case (last root) of { let form1 = case (last root) of
""|"ा"|"w" => root + "w^ं" ; {
_ => root + "wं" "ा"|"ो"|"ी" => root + "ऊँ";
}; "े" => (tk 1 root)+ "ूँ";
form2 = case (last root) of { _ => root + "ूँ"
""|"ा"|"w" => root + "y^ं" ;
_ => root + "यं"
}; };
form2 = case (last root) of
{
"ा"|"ो" => root + "एँ";
"ी" => root + "येँ";
"े" => (tk 1 root)+ "ेँ";
_ => root + "ेँ"
}
in in
case <t,p,n,g> of { case <t,p,n,g> of {
<Subj,Pers1,Sg,_> => form1 ; <Subj,Pers1,Sg,_> => form1 ;
<Subj,Pers1,Pl,_> => form2 ; <Subj,Pers1,Pl,_> => form2 ;
<Subj,_,_,_> => (mkImpert root p n g).s ; <Subj,_,_,_> => (mkImpert root p n g).s ;
<Perf,_,_,_> => case root of { <Perf,_,_,_> => case root of {
"हw" => (mkPastInd root p n g).s ; "ह" => (mkPastInd root p n g).s ;
"ज" => (mkPastInd "गय" p n g).s ; "ज" => (mkPastInd "गय" p n g).s ;
"कर" => (mkPastInd "क" p n g).s ; "कर" => (mkPastInd "किय" p n g).s ;
"द" => (mkPastInd "द" p n g).s ; -- "दE" => (mkPastInd "द" p n g).s ;
"ल" => (mkPastInd "ल" p n g).s ; -- "लE" => (mkPastInd "ल" p n g).s ;
_ => (mkPastInd root p n g).s }; _ => (mkPastInd root p n g).s };
<Imperf,Pers2_Familiar,Sg,Masc> => root + "त"; <Imperf,Pers2_Familiar,Sg,Masc> => root + "त";
<Imperf,Pers2_Familiar,Sg,Fem> => root + "त"; --variants{root+"तय" ; root+"तय"}; <Imperf,Pers2_Familiar,Sg,Fem> => root + "त"; --variants{root+"तय" ; root+"तय"};
<Imperf,Pers2_Familiar,Pl,Masc> => root + "त"; <Imperf,Pers2_Familiar,Pl,Masc> => root + "त";
<Imperf,Pers2_Familiar,Pl,Fem> => root+"तयं"; <Imperf,Pers2_Familiar,Pl,Fem> => root+"त";
<Imperf,Pers2_Respect,Sg,Masc> => root + "त"; <Imperf,Pers2_Respect,Sg,Masc> => root + "त";
<Imperf,Pers2_Respect,Sg,Fem> => root + "त"; --variants{root+"तय" ; root+"तय"}; <Imperf,Pers2_Respect,Sg,Fem> => root + "त"; --variants{root+"तय" ; root+"तय"};
<Imperf,Pers2_Respect,Pl,Masc> => root + "त"; <Imperf,Pers2_Respect,Pl,Masc> => root + "त";
<Imperf,Pers2_Respect,Pl,Fem> => root+"तयं"; <Imperf,Pers2_Respect,Pl,Fem> => root+"त";
<Imperf,_,Sg,Masc> => root+"त"; <Imperf,_,Sg,Masc> => root+"त";
<Imperf,_,Sg,Fem> => root+"त"; <Imperf,_,Sg,Fem> => root+"त";
<Imperf,_,Pl,Masc> => root+"ते"; <Imperf,_,Pl,Masc> => root+"ते";
<Imperf,_,Pl,Fem> => root+"तयं" <Imperf,_,Pl,Fem> => root+"त"
} }
} ; } ;
@@ -382,20 +400,27 @@ oper
mkPastInd : Str -> UPerson -> Number -> Gender -> {s:Str} = \root,p,n,g -> mkPastInd : Str -> UPerson -> Number -> Gender -> {s:Str} = \root,p,n,g ->
{s = let roo = root ; {s = let roo = root ;
a = case (last root) of { a = case (last root) of {
""|"ा"|"w"|"" => "य" ; "ा"|""|"" => "य" ;
_ => "" "े" => (tk 1 roo) + "िया" ;
_ => "ा"
} ; } ;
y = case (last root) of { y = case (last root) of {
""|"ा"|"w" => "y^य" ; "ा"|"" => "य" ;
_ => "" "ी" => "" ;
"े" => (tk 1 roo) + "ी" ;
"िय" => (tk 2 roo) + "ी" ;
_ => "ी"
} ; } ;
e = case (last root) of { e = case (last root) of {
""|""|"w"|"क" => "y^ै" ; ""|""|""|"क" => "ये" ;
_ => "ै" "े" => (tk 1 roo) + "ी" ;
_ => "े"
} ; } ;
yN = case (last root) of { yN = case (last root) of {
""|""|"w" => "y^यं" ; ""|""|"" => "यीँ" ;
_ => "यं" "िय" => (tk 2 roo) + "ी" ;
"े" => (tk 1 roo) + "ीँ" ;
_ => "यँ"
} ; } ;
in in
@@ -430,20 +455,19 @@ oper
mkImpert : Str -> UPerson -> Number -> Gender -> {s:Str} = \root,p,n,g -> mkImpert : Str -> UPerson -> Number -> Gender -> {s:Str} = \root,p,n,g ->
{s = let roo = root ; {s = let roo = root ;
w = case (last root) of { w = case (last root) of {
""|"ा"|"w" => "w^" ; "" => "" ;
_ => "w" "ो" => "ओ" ;
_ => "ो"
} ; } ;
yN = case (last root) of { yN = case (last root) of {
""|"ा"|"w" => "y^यं" ; "ा"|"" => "एँ" ;
_ => "यं" _ => "एँ"
} ;
yE = case (last root) of {
""|"ा"|"w" => "y^यै" ;
_ => "यै"
} ; } ;
e = case (last root) of { e = case (last root) of {
""|"ा"|"w" => "y^ै" ; "ा"|"" => "" ;
_ => "" "े" => "" ;
"ी" => "ये" ;
_ => "ए"
} in } in
case <p,n,g> of { case <p,n,g> of {
<Pers1,_,_> => ""; --nonExist ; <Pers1,_,_> => ""; --nonExist ;

View File

@@ -1,2 +1,2 @@
concrete NounHin of Noun = CatHin ** NounHindustani with concrete NounHin of Noun = CatHin ** NounHindustani with
(ResHindustani = ResHin) ; (ResHindustani = ResHin);

View File

@@ -1,10 +1,10 @@
concrete NumeralHin of Numeral = CatHin ** open ResHin,Prelude,ParamX in { -- By Harald Hammarstr
-- By Harald Hammarström -- Modification for Urdu Shafqat Virk
-- Modification for Hinu Shafqat Virk
flags coding=utf8 ;
--- still old Devanagari coding
concrete NumeralHin of Numeral = CatHin ** open ResHin,CommonHindustani,ParamX, Prelude in {
flags coding=utf8 ;
param DForm = unit | ten ; param DForm = unit | ten ;
param DSize = sg | r2 | r3 | r4 | r5 | r6 | r7 | r8 | r9 ; param DSize = sg | r2 | r3 | r4 | r5 | r6 | r7 | r8 | r9 ;
param Size = singl | less100 | more100 ; param Size = singl | less100 | more100 ;
@@ -22,20 +22,10 @@ lincat Sub1000000 = { s : Str ; n : Number } ;
lin num x0 = lin num x0 =
{s = table { {s = table {
NCard => x0.s ; NCard => x0.s ;
NOrd => x0.s ++ "واں" -- need to use mkOrd which will make irregular ordinals but it gives path error NOrd => Prelude.glue x0.s "वाँ" -- need to use mkOrd x0.s but it gives linking error
}; };
n = x0.n n = x0.n
} ; } ;
oper mkOrd : Str -> Str =
\s -> case s of {
"عك" => "پہلا";
"دo" => "دوسرا";
"تi:ن" => "تعسرا";
"چa:ر" => "چوتh-ا";
("چحاہ"|"چحا"|"چحاi") => "چh-ٹا";
_ => s ++ "واں"
};
-- {s = \\_ => x0.s ; n = x0.n} ;
oper mkNum : Str -> Str -> DSize -> LinDigit = oper mkNum : Str -> Str -> DSize -> LinDigit =
@@ -43,47 +33,47 @@ oper mkNum : Str -> Str -> DSize -> LinDigit =
{s = table {unit => do ; ten => bis } ; {s = table {unit => do ; ten => bis } ;
size = sz ; n = Pl} ; size = sz ; n = Pl} ;
lin n2 = mkNum "دو" "بیس" r2 ; lin n2 = mkNum "दो" "बीस" r2 ;
lin n3 = mkNum "تین" "تیس" r3 ; lin n3 = mkNum "तीन" "तीस" r3 ;
lin n4 = mkNum "چار" "چالیس" r4 ; lin n4 = mkNum "चार" "चालीस" r4 ;
lin n5 = mkNum "پانچ" "پچاس" r5 ; lin n5 = mkNum "पांच" "पचास" r5 ;
lin n6 = mkNum "چh-" "ساتh-" r6 ; lin n6 = mkNum "छे" "साटh'" r6 ;
lin n7 = mkNum "سات" "ستر" r7; lin n7 = mkNum "सात" "सततर" r7;
lin n8 = mkNum "آتh-" "اسی" r8; lin n8 = mkNum "आठ" "अससी" r8;
lin n9 = mkNum "نو" "نوے" r9 ; lin n9 = mkNum "नौ" "नववे" r9 ;
oper mkR : Str -> Str -> Str -> Str -> Str -> Str -> Str -> Str -> Str -> DSize => Str = \a1 -> \a2 -> \a3 -> \a4 -> \a5 -> \a6 -> \a7 -> \a8 -> \a9 -> table { oper mkR : Str -> Str -> Str -> Str -> Str -> Str -> Str -> Str -> Str -> DSize => Str = \a1 -> \a2 -> \a3 -> \a4 -> \a5 -> \a6 -> \a7 -> \a8 -> \a9 -> table {
sg => a1 + "اہ" ; sg => a1 + "" ;
r2 => a2 + "i:س" ; r2 => a2 + "" ;
r3 => a3 + "تi:س" ; r3 => a3 + "तीस" ;
r4 => a4 + "a:لi:س" ; r4 => a4 + "ालीस" ;
r5 => a5 + "ان" ; r5 => a5 + "" ;
r6 => a6 + "ساٹح" ; r6 => a6 + "सठ" ;
r7 => a7 + "ہاتتار" ; r7 => a7 + "ततर" ;
r8 => a8 + "a:سi:" ; r8 => a8 + "ासी" ;
r9 => a9 + "a:نا" r9 => a9 + "ानwवे"
} ; } ;
oper rows : DSize => DSize => Str = table { oper rows : DSize => DSize => Str = table {
sg => mkR "گیارہ" "iكك" "iكات" "عكت" "iكیاو" "" "iك" "iكی" "iكی" ; sg => mkR "गयार" "इककी" "इकत" "इकत" "इकयाव" "इक" "इकह" "इकय" "इकय" ;
r2 => mkR "بارہ" "بای" "بات" "بای" "باو" "با" "با" "بای" "ب" ; r2 => mkR "बार" "बाई" "बत" "बैत" "बाव" "बा" "बह" "बय" "" ;
r3 => mkR "تیر" "تی" "تین" "تنت" "ترپ" "تری" "ت" "تر" "تر" ; r3 => mkR "तेर" "तेई" "तैं" "तैंत" "तिरप" "तिर" "तिह" "तिर" "तिर" ;
r4 => mkR "چود" "چوب" "چون" "چوا" "چوو" "چون" "چوہ" "چور" "چور" ; r4 => mkR "चौद" "चौबी" "चौं" "चौव" "चww" "चौँ" "चौह" "चw+र" "चौर" ;
r5 => mkR "پند" "پچی" "پین" "پنتا" "پچپ" "پین" "پہ" "پچ" "پچ" ; r5 => mkR "पंदर" "पचची" "पैं" "पैंत" "पचप" "पैँ" "पिछ" "पच" "पिच" ;
r6 => mkR "سول" "چh-ب" "چh-ت" "چh-ی" "چh-پ" "چh-یا" "چh-" "چh-ی" "چh-ی" ; r6 => mkR "सोल" "चa'बबी" "छात" "छिय" "छपप" "छिया" "चिह" "छिय" "छिय" ;
r7 => mkR "ستر" "ستا" "سین" "سنت" "ستاو" "ستا" "سر" "ست" "ستا" ; r7 => mkR "सतर" "सतताई" "सैं" "सैंत" "सताव" "सढ़" "सतह" "सत" "सत" ;
r8 => mkR "اتh-ار" "اتh-ای" "اڑ" "اڑت" "اتh-او" "اڑ" "اتh-" "اتh-" "اتh-" ; r8 => mkR "अठार" "टh'ाई" "अढ़" "अढ़त" "अठाव" "अढ़" "अटह" "अठ" "अठ" ;
r9 => table {sg => "انیس" ; r2 => "انتیس" ; r3 => "انتالیس" ; r9 => table {sg => "उननीस" ; r2 => "उनततीस" ; r3 => "उंतालीस" ;
r4 => "انچاس" ; r5 => "انستh-" ; r6 => "انہتر" ; r4 => "उंचास" ; r5 => "उनसठ" ; r6 => "उनहततर" ;
r7 => "اناسی" ; r7 => "उनससी" ;
r8 => "انانوے" ; r9 => "ننانوے" } r8 => "उनननवे" ; r9 => "निन्यानवे" }
} ; } ;
oper ss : Str -> {s : Str} = \s -> {s = s} ; oper ss : Str -> {s : Str} = \s -> {s = s} ;
lin pot01 = {s = table {unit => "ایك" ; _ => "دuممی" } ; size = sg ; n = Sg} ; lin pot01 = {s = table {unit => "एक" ; _ => "दमी" } ; size = sg ; n = Sg} ;
lin pot0 d = d ; lin pot0 d = d ;
lin pot110 = {s = "داس" ; size = less100 ; n = Pl} ; lin pot110 = {s = "दस" ; size = less100 ; n = Pl} ;
lin pot111 = {s = rows ! sg ! sg ; size = less100 ; n = Pl} ; lin pot111 = {s = rows ! sg ! sg ; size = less100 ; n = Pl} ;
lin pot1to19 d = {s = rows ! d.size ! sg ; size = less100 ; n = d.n} ; lin pot1to19 d = {s = rows ! d.size ! sg ; size = less100 ; n = d.n} ;
lin pot0as1 n = {s = n.s ! unit ; size = table {sg => singl ; _ => less100} ! n.size ; n = n.n } ; lin pot0as1 n = {s = n.s ! unit ; size = table {sg => singl ; _ => less100} ! n.size ; n = n.n } ;
@@ -91,37 +81,37 @@ lin pot0as1 n = {s = n.s ! unit ; size = table {sg => singl ; _ => less100} ! n.
lin pot1 d = {s = d.s ! ten ; size = less100 ; n = d.n} ; lin pot1 d = {s = d.s ! ten ; size = less100 ; n = d.n} ;
lin pot1plus d e = {s = rows ! e.size ! d.size ; size = less100 ; n = d.n} ; lin pot1plus d e = {s = rows ! e.size ! d.size ; size = less100 ; n = d.n} ;
lin pot1as2 n = {s = n.s ; s2 = "دuممی" ; size = n.size ; n = n.n} ; lin pot1as2 n = {s = n.s ; s2 = "दमी" ; size = n.size ; n = n.n} ;
lin pot2 d = {s = (mksau (d.s ! unit) d.size) ; lin pot2 d = {s = (mksau (d.s ! unit) d.size) ;
s2 = d.s ! unit ++ "لاكh-" ; size = more100 ; n = d.n} ; s2 = d.s ! unit ++ "लाख" ; size = more100 ; n = d.n} ;
lin pot2plus d e = lin pot2plus d e =
{s = (mksau (d.s ! unit) d.size) ++ e.s ; {s = (mksau (d.s ! unit) d.size) ++ e.s ;
s2 = (d.s ! unit) ++ "لاكh-" ++ (mkhazar e.s e.size) ; s2 = (d.s ! unit) ++ "लाख" ++ (mkhazar e.s e.size) ;
size = more100 ; n = d.n} ; size = more100 ; n = d.n} ;
lin pot2as3 n = {s = n.s ; n = n.n} ; lin pot2as3 n = {s = n.s ; n = n.n} ;
lin pot3 n = {s = table { singl => ekhazar ; lin pot3 n = {s = table { singl => ekhazar ;
less100 => n.s ++ "ہزار" ; less100 => n.s ++ "हज़ार" ;
more100 => n.s2 } ! n.size ; n = n.n} ; more100 => n.s2 } ! n.size ; n = n.n} ;
lin pot3plus n m = lin pot3plus n m =
{s = table {singl => ekhazar ; {s = table {singl => ekhazar ;
less100 => n.s ++ "ہزار" ; less100 => n.s ++ "हज़ार" ;
more100 => n.s2 } ! n.size ++ m.s ; n = n.n} ; more100 => n.s2 } ! n.size ++ m.s ; n = n.n} ;
lin D_0 = { s = "0" ; n = Sg}; lin D_0 = { s = "" ; n = Sg};
lin D_1 = { s = "1" ; n = Sg}; lin D_1 = { s = "" ; n = Sg};
lin D_2 = { s = "2" ; n = Pl}; lin D_2 = { s = "" ; n = Pl};
lin D_3 = { s = "3" ; n = Pl}; lin D_3 = { s = "" ; n = Pl};
lin D_4 = { s = "4" ; n = Pl}; lin D_4 = { s = "" ; n = Pl};
lin D_5 = { s = "5" ; n = Pl}; lin D_5 = { s = "" ; n = Pl};
lin D_6 = { s = "6" ; n = Pl}; lin D_6 = { s = "" ; n = Pl};
lin D_7 = { s = "7" ; n = Pl}; lin D_7 = { s = "" ; n = Pl};
lin D_8 = { s = "8" ; n = Pl}; lin D_8 = { s = "" ; n = Pl};
lin D_9 = { s = "9" ; n = Pl}; lin D_9 = { s = "" ; n = Pl};
lin IDig d = { s = \\_ => d.s ; n = d.n} ; lin IDig d = { s = \\_ => d.s ; n = d.n} ;
lin IIDig d dg = { s = \\df => Prelude.glue (dg.s ! df) d.s ; n = Pl }; lin IIDig d dg = { s = \\df => Prelude.glue (dg.s ! df) d.s ; n = Pl };
oper ekhazar : Str = variants {"ہزار" ; "ایك" ++ "ہزار"} ; oper ekhazar : Str = variants {"हज़ार" ; "एक" ++ "हज़ार"} ;
oper mkhazar : Str -> Size -> Str = \s -> \sz -> table {singl => ekhazar ; _ => s ++ "ہزار"} ! sz ; oper mkhazar : Str -> Size -> Str = \s -> \sz -> table {singl => ekhazar ; _ => s ++ "हज़ार"} ! sz ;
oper mksau : Str -> DSize -> Str = \s -> \sz -> table {sg => "سو" ; _ => s ++ "سو"} ! sz ; oper mksau : Str -> DSize -> Str = \s -> \sz -> table {sg => "एक" ++ "सौ" ; _ => s ++ "सौ"} ! sz ;
} }

View File

@@ -47,7 +47,16 @@ oper
-- Proper names -- Proper names
mkPN : Str -> PN = \s -> let n = regNoun s in {s = n.s ! Sg ; g = n.g ; lock_PN = <>} ; mkPN : Str -> PN = \s -> let n = regNoun s in {s = n.s ! Sg ; g = n.g ; lock_PN = <>} ;
personalPN : Str -> Str -> Str -> Str -> Number -> Gender -> UPerson -> Pron = \s1,s2,s3,sp,nn,g,p -> let n = mkPron s1 s2 s3 in {s = n.s ; a = toAgr nn p g ; ps = sp ; lock_Pron = <>}; personalPN : Str -> Str -> Str -> Str -> Str -> Str -> Str -> Number -> Gender -> UPerson -> Pron =
\s1,s2,s3,smp,sfp,pmp,pfp,nn,g,p -> let n = mkPron s1 s2 s3 in
{s = n.s ;
a = toAgr nn p g ;
ps = \\n,g => case <n,g> of {
<Sg,Masc> =>smp ;
<Sg,Fem> => sfp ;
<Pl,Masc> => pmp ;
<Pl,Fem> => pfp } ; lock_Pron = <>};
demoPN : Str -> Str -> Str -> Quant = \s1,s2,s3 -> let n = makeDemonPronForm s1 s2 s3 in {s = n.s ; a = defaultAgr ; lock_Quant = <>}; demoPN : Str -> Str -> Str -> Quant = \s1,s2,s3 -> let n = makeDemonPronForm s1 s2 s3 in {s = n.s ; a = defaultAgr ; lock_Quant = <>};
mkDet : Str -> Str -> Str -> Str -> Number -> Det = \s1,s2,s3,s4,nb -> let dt = makeDet s1 s2 s3 s4 nb in {s = dt.s ; n = nb ; lock_Det = <>}; mkDet : Str -> Str -> Str -> Str -> Number -> Det = \s1,s2,s3,s4,nb -> let dt = makeDet s1 s2 s3 s4 nb in {s = dt.s ; n = nb ; lock_Det = <>};
mkIP : (x1,x2,x3:Str) -> Number -> Gender -> IP = \s1,s2,s3,n,g -> let p = mkIntPronForm s1 s2 s3 in { s = p.s ; n = n ; g = g ; lock_IP = <>}; mkIP : (x1,x2,x3:Str) -> Number -> Gender -> IP = \s1,s2,s3,n,g -> let p = mkIntPronForm s1 s2 s3 in { s = p.s ; n = n ; g = g ; lock_IP = <>};
@@ -63,6 +72,8 @@ oper
= \a,c -> let n = regAdjective a in {s = n.s; c2 = c} ** {lock_A2 = <>} ; = \a,c -> let n = regAdjective a in {s = n.s; c2 = c} ** {lock_A2 = <>} ;
} ; } ;
mkIrregA : Str -> Str -> A2 = \str,c -> makeIrregA str ** {c2 = c ; lock_A2 = <>} ;
--2 Verbs --2 Verbs
mkV : Str -> V mkV : Str -> V
@@ -99,6 +110,22 @@ oper
--3 Determiners and quantifiers --3 Determiners and quantifiers
mkIQuant : (s1,_,_,_,_,_,_,_,_,_,_,s12:Str) -> IQuant =
\smd,smo,smv,sfd,sfo,sfv,pmd,pmo,pmv,pfd,pfo,pfv ->
{s = \\n,g,c => case <n,g,c> of {
<Sg,Masc,Dir> =>smd ;
<Sg,Masc,Obl> =>smo;
<Sg,Masc,Voc> =>smv ;
<Sg,Fem,Dir> =>sfd ;
<Sg,Fem,Obl> =>sfo;
<Sg,Fem,Voc> =>sfv ;
<Pl,Masc,Dir> =>pmd ;
<Pl,Masc,Obl> =>pmo;
<Pl,Masc,Voc> =>pmv ;
<Pl,Fem,Dir> =>pfd ;
<Pl,Fem,Obl> =>pfo;
<Pl,Fem,Voc> =>pfv} ;
lock_IQuant = <>};
-- mkQuant : overload { -- mkQuant : overload {
mkQuant : Pron -> Quant ; mkQuant : Pron -> Quant ;
-- mkQuant : (no_sg, no_pl, none_sg, non_pl : Str) -> Quant ; -- mkQuant : (no_sg, no_pl, none_sg, non_pl : Str) -> Quant ;

View File

@@ -1,2 +1,2 @@
concrete RelativeHin of Relative = CatHin ** RelativeHindustani with concrete RelativeHin of Relative = CatHin ** RelativeHindustani with
(ResHindustani = ResHin) ; (ResHindustani = ResHin);

View File

@@ -1,2 +1,2 @@
instance ResHin of ResHindustani = DiffHin ** open CommonHindustani, Prelude, Predef in { instance ResHin of ResHindustani = DiffHin ** open CommonHindustani,StringsHin, Prelude, Predef in {
} ; } ;

View File

@@ -1,2 +1,2 @@
concrete SentenceHin of Sentence = CatHin ** SentenceHindustani with concrete SentenceHin of Sentence = CatHin ** SentenceHindustani with
(ResHindustani = ResHin) ; (ResHindustani = ResHin);

View File

@@ -5,125 +5,126 @@ concrete StructuralHin of Structural = CatHin **
coding = utf8; coding = utf8;
lin lin
above_Prep = mkPrep "wपर" "wपर" ; above_Prep = mkPrep ["के ऊपर"] ["के ऊपर"] ;
after_Prep = mkPrep ["कद"] ["कद"] ; after_Prep = mkPrep ["कद"] ["कद"] ;
all_Predet = ss "तमम" ; all_Predet = ss "तमम" ;
almost_AdA, almost_AdN = mkAdN "तqरयब" ; almost_AdA, almost_AdN = mkAdN "तक़रीबन" ;
although_Subj = ss "गरचh-" ; although_Subj = ss "गरचि" ;
always_AdV = ss "हमयXह" ; always_AdV = ss "हमेशा" ;
and_Conj = sd2 [] "wर" ** {n = Pl} ; and_Conj = sd2 [] "र" ** {n = Pl} ;
because_Subj = ss "कयwनकh-" ; because_Subj = ss "क्योँकि" ;
before_Prep = mkPrep "पहलै" "पहलै" ; before_Prep = mkPrep ["से पहले"] ["से पहले"] ;
behind_Prep = mkPrep "पयचh-ै" "पयचh-ै" ; behind_Prep = mkPrep ["के पीछे"] ["के पीछे"] ;
between_Prep = mkPrep "दरमयं" "दरमयं" ; between_Prep = mkPrep ["के दरमियान"] ["के दरमियान"] ;
both7and_DConj = sd2 "दwनwं" "wर" ** {n = Pl} ; both7and_DConj = sd2 "दोनों" "र" ** {n = Pl} ;
but_PConj = ss "लयकन" ; but_PConj = ss "लेकिन" ;
by8agent_Prep = mkPrep "" "" ; by8agent_Prep = mkPrep "" "" ;
by8means_Prep = mkPrep "" "" ; by8means_Prep = mkPrep "" "" ;
-- can8know_VV,can_VV = mkV "सकन" ** { isAux = True} ; can8know_VV,can_VV = mkV "सकन" ** { isAux = True} ;
during_Prep = mkPrep ["क दरमयं"] ["क दरमयं"] ; during_Prep = mkPrep ["क दरमियान"] ["क दरमियान"] ;
either7or_DConj = sd2 "कwय यक" "य" ** {n = Sg} ; either7or_DConj = sd2 "कोई एक" "य" ** {n = Sg} ;
everybody_NP = MassNP (UseN (ParadigmsHin.mkN "हर कwय" "हर कwय" "हर कwय" "हर कwय" "हर कwय" "हर कwय" Masc )); -- not a good way coz need to include NounHin everybody_NP = MassNP (UseN (ParadigmsHin.mkN "हर कोई" "हर कोई" "हर कोई" "हर कोई" "हर कोई" "हर कोई" Masc ));
-- every_Det = mkDet "हर" Sg; every_Det = mkDet "हर" "हर" "हर" "हर" Sg;
everything_NP = MassNP (UseN (ParadigmsHin.mkN "हर चज़" "हर चज़" "हर चयज़w" "सब चयज़यं" "सब चयज़wं" "सब चयज़w" Masc )); everything_NP = MassNP (UseN (ParadigmsHin.mkN "हर चज़" "हर चज़" "हर चीज़ोँ" "सब चीज़ेँ" "सब चीज़ोँ" "सब चीज़ोँ" Masc ));
everywhere_Adv = mkAdv "हर जगह" ; everywhere_Adv = mkAdv "हर जगह" ;
-- few_Det = mkDet "चद" Pl ; few_Det = mkDet "चंद" "चंद" "चंद" "चंद" Pl ;
first_Ord = {s = "पेहल" ; n = Sg} ; --DEPRECATED first_Ord = {s = "" ; n = Sg} ; --De:PRe:CATe:D
for_Prep = mkPrep "कयलयै" "कयलयै" ; for_Prep = mkPrep ["के लिये"] ["के लिये"] ;
from_Prep = mkPrep "स" "स" ; from_Prep = mkPrep "स" "स" ;
he_Pron = personalPN "wह" "स" "" "स क" Sg Masc Pers3_Distant ; he_Pron = personalPN "ह" "स" "" "स क" "उस की" "उस के" "उस की" Sg Masc Pers3_Distant ;
here_Adv = mkAdv "यह" ; here_Adv = mkAdv "यहाँ" ;
here7to_Adv = mkAdv "यह पर" ; here7to_Adv = mkAdv ["यहाँ पर"] ;
here7from_Adv = mkAdv "यहं सै" ; here7from_Adv = mkAdv ["यहाँ से"] ;
how_IAdv = ss "कयसै" ; how_IAdv = ss "कैसे" ;
how8many_IDet = makeIDet "कतन" "कतन" Pl ; how8many_IDet = makeIDet "कितन" "कितन" Pl ;
if_Subj = ss "गर" ; how8much_IAdv = ss "कितना" ;
in8front_Prep = mkPrep ["कै समनै"] ["कै समनै"] ; if_Subj = ss "अगर" ;
i_Pron = personalPN "मयं" "मजh-" "" "मयर" Sg Masc Pers1; in8front_Prep = mkPrep ["के सामने"] ["के सामने"] ;
i_Pron = personalPN "मैं" "मुझ" "" "मेरा" "मेरी" "मेरे" "मेरी" Sg Masc Pers1;
in_Prep = mkPrep "में" "में" ; in_Prep = mkPrep "में" "में" ;
it_Pron = personalPN "यह" "यह" "यह" "स क" Sg Masc Pers3_Near; it_Pron = personalPN "यह" "इस" "यह" "इस का" "स की" "उस के" "उस की" Sg Masc Pers3_Near;
less_CAdv = {s = "कम" ; p = ""} ; less_CAdv = {s = "कम" ; p = ""} ;
-- many_Det = mkDet "बहत ज़यदह" Pl ; many_Det = mkDet "बहुत" "बहुत" "बहुत" "बहुत" Pl ;
more_CAdv = {s = "ज़यदh-" ; p = "" } ; more_CAdv = {s = "ज़्यादा" ; p = "से" } ;
most_Predet = ss "ज़यदह तर" ; most_Predet = ss "सब से ज़्यादा" ;
--much_Det = mkDet "बहत" Pl ; much_Det = mkDet "बहत" "बहुत" "बहुत" "बहुत" Sg ;
-- must_VV = { -- must_VV = {
-- s = table { -- s = table {
-- VVF VInf => ["हव"] ; -- VVF VInf => ["हवeo"] ;
-- VVF VPres => "मुसत" ; -- VVF VPres => "मुसत" ;
-- VVF VPPart => ["हद त"] ; -- VVF VPPart => ["हद तo"] ;
-- VVF VPresPart => ["हविनग त"] ; -- VVF VPresPart => ["हविनग तo"] ;
-- VVF VPast => ["हद त"] ; --# notpresent -- VVF VPast => ["हद तo"] ; --# notpresent
-- VVPastNeg => ["हदn'त त"] ; --# notpresent -- VVPastNeg => ["हदn'त तo"] ; --# notpresent
-- VVPresNeg => "मुसतn'त" -- VVPresNeg => "मुसतn'त"
-- } ; -- } ;
-- isAux = True -- isAux = True
-- } ; -- } ;
-----b no_Phr = ss "न" ; no_Utt = ss "नहीं" ;
no_Utt = ss "नहयं" ;
on_Prep = mkPrep "पर" "पर" ; on_Prep = mkPrep "पर" "पर" ;
-- one_Quant = demoPN "यक" "यक" "यक" ; -- DEPRECATED -- one_Quant = demoPN "" ; -- De:PRe:CATe:D
only_Predet = ss "सरf" ; only_Predet = ss "सिर्फ़" ;
or_Conj = sd2 [] "य" ** {n = Sg} ; or_Conj = sd2 [] "य" ** {n = Sg} ;
otherwise_PConj = ss "य पh-र" ; otherwise_PConj = ss "नहीं तो" ;
part_Prep = mkPrep "" "" ; part_Prep = mkPrep "" "" ;
please_Voc = ss "महरबनि" ; -- please_Voc = ss "" ;
possess_Prep = mkPrep "क" "क" ; possess_Prep = mkPrep "क" "क" ;
quite_Adv = ss "कहमॉसह" ; quite_Adv = ss "काफ़ी" ;
she_Pron = personalPN "wह" "स" "wह" "स क" Sg Fem Pers3_Distant ; she_Pron = personalPN "ह" "स" "उस" "उस का" "उस की" "स क" "उस की" Sg Fem Pers3_Distant ; -- chek with prasad about 'Us'
so_AdA = ss "सॉ" ; so_AdA = ss "तो" ;
somebody_NP = MassNP (UseN (ParadigmsHin.mkN "कwय" "कwय" "कwय" "कwय" "कwय" "कwय" Masc )); somebody_NP = MassNP (UseN (ParadigmsHin.mkN "कोई" "कोई" "कोई" "कोई" "कोई" "कोई" Masc ));
--someSg_Det = mkDet "कचh-" Sg ; someSg_Det = mkDet "कुछ" "कुछ" "कुछ" "कुछ" Sg ;
--somePl_Det = mkDet "कचh-" Pl ; somePl_Det = mkDet "कुछ" "कुछ" "कुछ" "कुछ" Pl ;
something_NP = MassNP (UseN (ParadigmsHin.mkN "कwयज़" "कwयज़" "कwयज़" "कh- चयज़यं" "कh- चयज़wं" "कh- चयज़w" Masc )); something_NP = MassNP (UseN (ParadigmsHin.mkN ["कोईज़"] ["कोईज़"] ["कोईज़"] ["कोई चीज़"] ["कोई चीज़"] ["कोई चीज़"] Masc ));
somewhere_Adv = mkAdv "कहिन पर" ; somewhere_Adv = mkAdv ["कहीं"] ;
that_Quant = demoPN "wह" "स" "न" ; that_Quant = demoPN "ह" "स" "न" ;
that_Subj = ss "क"; that_Subj = ss "कि";
there_Adv = mkAdv "wहं" ; there_Adv = mkAdv "वहाँ" ;
there7to_Adv = mkAdv "wहं पर" ; there7to_Adv = mkAdv ["वहाँ पर"] ;
there7from_Adv = mkAdv ["wहं"] ; there7from_Adv = mkAdv ["वहाँ"] ;
therefore_PConj = ss "स लयै" ; therefore_PConj = ss "स लिये" ;
they_Pron = personalPN "wह" "wह" "wह" "न क" Pl Masc Pers3_Distant ; ---- they_Pron = personalPN "ह" "ह" "ह" "न का" "उन की" "उन के" "उन की" Pl Masc Pers3_Distant ; ----
this_Quant = demoPN "यह" "स" "न"; this_Quant = demoPN "यह" "स" "न";
through_Prep = mkPrep ["मं स"] ["मं स"] ; through_Prep = mkPrep ["मं स"] ["मं स"] ;
too_AdA = ss "बहत" ; too_AdA = ss "बहत" ;
to_Prep = mkPrep "कw" "कw" ; to_Prep = mkPrep "क" "क" ; -- ** {lock_Prep = <>};
under_Prep = mkPrep "नयचै" "नयचै" ; under_Prep = mkPrep ["के नीचे"] ["के नीचे"] ; -- ** {lock_Prep = <>};
very_AdA = ss "बहत" ; very_AdA = ss "बहत" ;
-- want_VV = mkV "चहन" ** { isAux = False} ; want_VV = mkV "चहन" ** { isAux = False} ;
we_Pron = personalPN "हम" "हम" "हम" "हम" Pl Masc Pers1 ; we_Pron = personalPN "हम" "हम" "हम" "हमारा" "हमारी" "हमारे" "हमारी" Pl Masc Pers1 ;
whatSg_IP = mkIP "क" "किस" "किस" Sg Masc ; whatSg_IP = mkIP "क्या" "क्या" "क्या" Sg Masc ; -- confirm
whatPl_IP = mkIP "क" "किन" "किन" Pl Masc ; whatPl_IP = mkIP "क्या" "क्या" "क्या" Pl Masc ;
when_IAdv = ss "कब" ; when_IAdv = ss "कब" ;
when_Subj = ss "कब" ; when_Subj = ss "कब" ;
where_IAdv = ss "कह" ; where_IAdv = ss "कहाँ" ;
which_IQuant = {s = \\_ => "कwन सय"} ; which_IQuant = mkIQuant ["कौन सा"] ["कौन से"] "" ["कौन सी"] ["कन सी"] ""
-- whichPl_IDet = makeDet "कwन स" "कwन सय" "कwन सै" "कwन सय" ; ["कन से"] ["कन से"] "" ["कौन सी"] ["कन सी"] "" ; -- need to put right forms Prasad
-- whichSg_IDet = makeDet "कwन स" "कwन सय" "कwन सै" "कwन सय" ; -- whichPl_IDet = makeDet "" ;
whoSg_IP = mkIP "कwन" "किस" "किस" Sg Masc ; -- whichSg_IDet = makeDet "";
whoPl_IP = mkIP "कwन" "क" "कनहwं" Pl Masc ; whoSg_IP = mkIP "कन" "किस" "किस" Sg Masc ;
why_IAdv = ss "कयwं" ; whoPl_IP = mkIP "कौन" "किन" "किनहों" Pl Masc ;
without_Prep = mkPrep ["कै बघयर"] ["कै बघयर"] ; why_IAdv = ss "क्यों" ;
with_Prep = mkPrep ["कै सतh-"] ["कै सतh-"] ; -- without_Prep = mkPrep ;
-- yes_Phr = ss "हं" ; with_Prep = mkPrep ["के साथ"] ["के साथ"] ;
yes_Utt = ss "हं" ; -- yes_Phr = ss "???" ;
youSg_Pron = personalPN "तम" "तम" "तम" "तमh-र" Sg Masc Pers2_Casual ; yes_Utt = ss "हाँ" ;
youPl_Pron = personalPN "तम" "तम" "तम" "तमh-र" Pl Masc Pers2_Casual ; youSg_Pron = personalPN "तू" "तुम" "तम" "तुमहारा" "तुमहारी" "तुमहारे" "तुमहारी" Sg Masc Pers2_Casual ;
youPol_Pron = personalPN "ाप" "ाफ" "ाफ" "ाप क" Sg Masc Pers2_Respect ; youPl_Pron = personalPN "तुम" "तुम" "तुम" "तुमहारा" "तुमहारी" "तुमहारे" "तुमहारी" Pl Masc Pers2_Casual ;
no_Quant = demoPN " कwय नहयं" "कwय नहयं" "कwय नहयं" ; youPol_Pron = personalPN "आप" "आप" "आप" "आप का" "आप की" "आप के" "आप की" Sg Masc Pers2_Respect ;
not_Predet = {s="नहं"} ; -- no_Quant = demoPN "कोई नहं" ;
if_then_Conj = sd2 "गर" "तw" ** {n = Sg} ; not_Predet = {s="नहीं"} ;
at_least_AdN = mkAdN ["कम ज़ कम"] ; -- if_then_Conj = sd2 "गर तो" ** {n = Sg} ;
at_most_AdN = mkAdN ["ज़यदह सै ज़यदह"]; at_least_AdN = mkAdN ["कम से कम"] ;
nothing_NP = MassNP (UseN (ParadigmsHin.mkN "कwय चयज़ नहयं" "कwय चयज़ नहयं" "कwय चयज़ नहयं" "कwय चयज़ नहयं" "कwय चयज़ नहयं" "कwय चयज़ नहयं" Masc )); at_most_AdN = mkAdN ["ज़्यादा से ज़्यादा"];
except_Prep = mkPrep "सwै" "सwै" ; -- nothing_NP = MassNP (UseN (ParadigmsHin.mkN "कुछ नहीं" Masc ));
nobody_NP = MassNP (UseN (ParadigmsHin.mkN "कwय नहयं" "कwय नहयं" "कwय नहयं" "कwय नहयं" "कwय नहयं" "कwय नहयं" Masc )); except_Prep = mkPrep "के सिवाय" "के सिवाय";
-- nobody_NP = MassNP (UseN (ParadigmsHin.mkN "कोई नहीं" Masc ));
as_CAdv = {s = "तन" ; p = "जतन"} ; as_CAdv = {s = "ितन" ; p = "जितन"} ;
have_V2 = mkV2 (mkV "रकh-न") "" ; -- have_V2 = mkV2 "";
language_title_Utt = ss "रदw" ; language_title_Utt = ss "हिन्दी" ;
} }

View File

@@ -2,3 +2,4 @@
concrete SymbolHin of Symbol = CatHin ** SymbolHindustani with concrete SymbolHin of Symbol = CatHin ** SymbolHindustani with
(ResHindustani = ResHin) ; (ResHindustani = ResHin) ;

View File

@@ -1,2 +1,3 @@
concrete VerbHin of Verb = CatHin ** VerbHindustani with concrete VerbHin of Verb = CatHin ** VerbHindustani with
(ResHindustani = ResHin) ; (ResHindustani = ResHin);

View File

@@ -1,4 +1,6 @@
instance DiffHin of DiffHindustani = open CommonHindustani, Prelude in { instance DiffHin of DiffHindustani = open CommonHindustani, ResHindustani,Prelude in {
--instance DiffHin of DiffHindustani = CommonHindustani ** open Prelude in {
flags coding = utf8;
oper oper
Clause : Type = {s : VPHTense => Polarity => Order => Str} ; Clause : Type = {s : VPHTense => Polarity => Order => Str} ;
mkClause : NP -> VPH -> Clause = \np,vp -> { mkClause : NP -> VPH -> Clause = \np,vp -> {
@@ -31,9 +33,9 @@ Clause : Type = {s : VPHTense => Polarity => Order => Str} ;
VPPerfFut => {fin = [] ; inf = Prelude.glue ((vp.s ! VPTense VPPerf agr).inf ++ hw p n) (copula CFuture n p g) } ; VPPerfFut => {fin = [] ; inf = Prelude.glue ((vp.s ! VPTense VPPerf agr).inf ++ hw p n) (copula CFuture n p g) } ;
VPPerfPresCont => {fin = copula CPresent n p g ; inf = (vp.s ! VPTense VPPres agr).inf ++ raha g n } ; VPPerfPresCont => {fin = copula CPresent n p g ; inf = (vp.s ! VPTense VPPres agr).inf ++ raha g n } ;
VPPerfPastCont => {fin = copula CPast n p g ; inf = (vp.s ! VPTense VPPres agr).inf ++ raha g n } ; VPPerfPastCont => {fin = copula CPast n p g ; inf = (vp.s ! VPTense VPPres agr).inf ++ raha g n } ;
VPPerfFutCont => {fin = [] ; inf = Prelude.glue ((vp.s ! VPTense VPPres agr).inf ++ raha g n ++ hw p n) (copula CFuture n p g )} ; VPPerfFutCont => {fin = [] ; inf = Prelude.glue ((vp.s ! VPTense VPPres agr).inf ++ raha g n ++ hw p n) (copula CFuture n p g) } ;
VPSubj => case vp.prog of { True => {fin = (vp.s ! VPTense VPFutr agr).inf ++ hw p n ; inf = "Xayd" } ; VPSubj => case vp.prog of { True => {fin = (vp.s ! VPTense VPFutr agr).inf ++ hw p n ; inf = "s*a:yd" } ;
_ => {fin = (vp.s ! VPTense VPFutr agr).inf ; inf = "Xayd" } } _ => {fin = (vp.s ! VPTense VPFutr agr).inf ; inf = "s*a:yd" } }
}; };
@@ -41,7 +43,7 @@ Clause : Type = {s : VPHTense => Polarity => Order => Str} ;
quest = quest =
case ord of case ord of
{ ODir => []; { ODir => [];
OQuest => "kya" }; OQuest => "kya:" };
na = na =
case b of case b of
{ Pos => []; { Pos => [];
@@ -49,7 +51,7 @@ Clause : Type = {s : VPHTense => Polarity => Order => Str} ;
nahim = nahim =
case b of case b of
{ Pos => []; { Pos => [];
Neg => "nhyN" }; Neg => "nahi:m." };
in in
case vt of { case vt of {
VPSubj => quest ++ np.s ! subj ++ vp.obj.s ++ vp.ad ++ vp.comp ! np.a ++ na ++ vps.inf ++ vps.fin ++ vp.embComp ; VPSubj => quest ++ np.s ! subj ++ vp.obj.s ++ vp.ad ++ vp.comp ! np.a ++ na ++ vps.inf ++ vps.fin ++ vp.embComp ;
@@ -76,15 +78,15 @@ Clause : Type = {s : VPHTense => Polarity => Order => Str} ;
VPPerfFut => {fin = [] ; inf = Prelude.glue ((vp.s ! VPStem).inf ++ cka g n ++ hw p n) (copula CFuture n p g) } ; VPPerfFut => {fin = [] ; inf = Prelude.glue ((vp.s ! VPStem).inf ++ cka g n ++ hw p n) (copula CFuture n p g) } ;
VPPerfPresCont => {fin = copula CPresent n p g ; inf = (vp.s ! VPStem).inf ++ raha g n } ; VPPerfPresCont => {fin = copula CPresent n p g ; inf = (vp.s ! VPStem).inf ++ raha g n } ;
VPPerfPastCont => {fin = copula CPast n p g ; inf = (vp.s ! VPStem).inf ++ raha g n } ; VPPerfPastCont => {fin = copula CPast n p g ; inf = (vp.s ! VPStem).inf ++ raha g n } ;
VPPerfFutCont => {fin = [] ; inf = Prelude.glue ((vp.s ! VPStem).inf ++ raha g n ++ hw p n) (copula CFuture n p g ) } ; VPPerfFutCont => {fin = [] ; inf = Prelude.glue ((vp.s ! VPStem).inf ++ raha g n ++ hw p n) (copula CFuture n p g) } ;
VPSubj => {fin = insertSubj p (vp.s ! VPStem).inf ; inf = "xayd" } VPSubj => {fin = insertSubj p (vp.s ! VPStem).inf ; inf = "s*a:yd" }
}; };
quest = quest =
case ord of case ord of
{ ODir => []; { ODir => [];
OQuest => "kya" }; OQuest => "kya:" };
na = na =
case b of case b of
{ Pos => []; { Pos => [];
@@ -92,42 +94,159 @@ Clause : Type = {s : VPHTense => Polarity => Order => Str} ;
nahim = nahim =
case b of case b of
{ Pos => []; { Pos => [];
Neg => "nhyN" }; Neg => "nahi:m." };
in in
case t of { case t of {
VPSubj => quest ++ subj ++ vp.obj.s ++ vp.ad ++ vp.comp ! agr ++ na ++ vps.inf ++ vps.fin ++ vp.embComp; VPSubj => quest ++ subj ++ vp.obj.s ++ vp.ad ++ vp.comp ! agr ++ na ++ vps.inf ++ vps.fin ++ vp.embComp;
_ => quest ++ subj ++ vp.obj.s ++ vp.ad ++ vp.comp ! agr ++ nahim ++ vps.inf ++ vps.fin ++ vp.embComp}; _ => quest ++ subj ++ vp.obj.s ++ vp.ad ++ vp.comp ! agr ++ nahim ++ vps.inf ++ vps.fin ++ vp.embComp};
} ; } ;
{- Verb : Type = {s : VerbForm => Str} ;
predV v = {
s = \\vh =>
case vh of {
VPTense VPPres (Ag g n p) => {fin = copula CPresent n p g ; inf = v.s ! VF Imperf p n g } ;
VPTense VPPast (Ag g n p) => {fin = [] ; inf =v.s ! VF Perf p n g} ;
VPTense VPFutr (Ag g n p) => {fin = [] ; inf = Prelude.glue (v.s ! VF Subj p n g) (copula CFuture n p g)} ;
VPTense VPPerf (Ag g n p) => { fin = [] ; inf = v.s ! Root ++ cka g n } ;
VPStem => {fin = [] ; inf = v.s ! Root};
_ => {fin = [] ; inf = v.s ! Root}
};
obj = {s = [] ; a = defaultAgr} ;
subj = VIntrans ;
inf = v.s ! Inf;
ad = [];
embComp = [];
prog = False ;
comp = \\_ => []
} ;
-}
np2pronCase ppf npc a = case npc of { np2pronCase ppf npc a = case npc of {
NPC c => ppf ! c; NPC c => ppf ! c;
NPObj => ppf ! Obl ; NPObj => ppf ! Obl ;
NPErg =>case (fromAgr a).p of { NPErg =>case (fromAgr a).p of {
(Pers3_Near|Pers3_Distant) => Prelude.glue (ppf ! Obl) "nE" ; -- in hindi in case of pronouns nE is tagged to pron rather than a separate word (Pers3_Near|Pers3_Distant) => Prelude.glue (ppf ! Obl) "ne:" ; -- in hindi in case of pronouns nE is tagged to pron rather than a separate word
_ => Prelude.glue (ppf ! Dir) "nE" _ => Prelude.glue (ppf ! Dir) "ne:"
} }
} ; } ;
conjThat = "ki" ;
insertSubj : UPerson -> Str -> Str = \p,s ->
case p of { Pers1 => s ++ "va:n~" ; _ => Prelude.glue s "E:"}; -- check with prasad for vn~
agr = "a-gar" ;
awr = "O+r" ;
ky = "ki:" ;
jn = "jin" ;
js = "jis" ;
jw = "jo:" ;
kw = "ko:" ;
mt = "mat" ;
nE = "ne:" ;
nh = "na" ;
sE = "se:" ;
waN = "va:n~" ; -- check with prasad
hE = "he:" ;
comma = "," ;
indfArt = "E:k" ; -- check with prasad
kwd = "xud" ; -- check with prasad
oper
copula : CTense -> Number -> UPerson -> Gender -> Str = \t,n,p,g ->
case <t,n,p,g> of {
<CPresent,Sg,Pers1,_ > => "hu:n~" ;
<CPresent,Sg,Pers2_Casual,_ > => "he+" ;
<CPresent,Sg,Pers2_Familiar,_ > => "ho:" ;
<CPresent,Sg,Pers2_Respect,_ > => "he+m." ;
<CPresent,Sg,Pers3_Near,_ > => "he+" ;
<CPresent,Sg,Pers3_Distant,_ > => "he+" ;
<CPresent,Pl,Pers1,_ > => "he+n~" ;
<CPresent,Pl,Pers2_Casual,_ > => "ho+" ;
<CPresent,Pl,Pers2_Familiar,_ > => "ho+" ;
<CPresent,Pl,Pers2_Respect,_ > => "he+m." ;
<CPresent,Pl,Pers3_Near,_ > => "he+m." ;
<CPresent,Pl,Pers3_Distant,_ > => "he+m." ;
<CPast,Sg,Pers1,Masc > => "t'a:" ;
<CPast,Sg,Pers1,Fem > => "t'i:" ;
<CPast,Sg,Pers2_Casual,Masc > => "t'a:" ;
<CPast,Sg,Pers2_Casual,Fem > => "t'i:" ;
<CPast,Sg,Pers2_Familiar,Masc > => "t'a:" ;
<CPast,Sg,Pers2_Familiar,Fem > => "t'i:" ;
<CPast,Sg,Pers2_Respect,Masc > => "t'e:" ;
<CPast,Sg,Pers2_Respect,Fem > => "t'i:m." ;
<CPast,Sg,Pers3_Near,Masc > => "t'a:" ;
<CPast,Sg,Pers3_Near,Fem > => "t'i:" ;
<CPast,Sg,Pers3_Distant,Masc > => "t'a:" ;
<CPast,Sg,Pers3_Distant,Fem > => "t'i:" ;
<CPast,Pl,Pers1,Masc > => "t'e:" ;
<CPast,Pl,Pers1,Fem > => "t'i:m." ;
<CPast,Pl,Pers2_Casual,Masc > => "t'e:" ;
<CPast,Pl,Pers2_Casual,Fem > => "t'i:m." ;
<CPast,Pl,Pers2_Familiar,Masc > => "t'e:" ;
<CPast,Pl,Pers2_Familiar,Fem > => "t'i:m." ;
<CPast,Pl,Pers2_Respect,Masc > => "t'e:" ;
<CPast,Pl,Pers2_Respect,Fem > => "t'i:m." ;
<CPast,Pl,Pers3_Near,Masc > => "t'e:" ;
<CPast,Pl,Pers3_Near,Fem > => "t'i:m." ;
<CPast,Pl,Pers3_Distant,Masc > => "t'e:" ;
<CPast,Pl,Pers3_Distant,Fem > => "t'i:m." ;
<CFuture,Sg,Pers1,Masc > => "ga:" ;
<CFuture,Sg,Pers1,Fem > => "gi:" ;
<CFuture,Sg,Pers2_Casual,Masc > => "ga:" ;
<CFuture,Sg,Pers2_Casual,Fem > => "gi:" ;
<CFuture,Sg,Pers2_Familiar,Masc > => "ge:" ;
<CFuture,Sg,Pers2_Familiar,Fem > => "gi:" ;
<CFuture,Sg,Pers2_Respect,Masc > => "ge:" ;
<CFuture,Sg,Pers2_Respect,Fem > => "gi:" ;
<CFuture,Sg,Pers3_Near,Masc > => "ga:" ;
<CFuture,Sg,Pers3_Near,Fem > => "gi:" ;
<CFuture,Sg,Pers3_Distant,Masc > => "ga:" ;
<CFuture,Sg,Pers3_Distant,Fem > => "gi:" ;
<CFuture,Pl,Pers1,Masc > => "ge:" ;
<CFuture,Pl,Pers1,Fem > => "gi:" ;
<CFuture,Pl,Pers2_Casual,Masc > => "ge:" ;
<CFuture,Pl,Pers2_Casual,Fem > => "gi:" ;
<CFuture,Pl,Pers2_Familiar,Masc > => "ge:" ;
<CFuture,Pl,Pers2_Familiar,Fem > => "gi:" ;
<CFuture,Pl,Pers2_Respect,Masc > => "ge:" ;
<CFuture,Pl,Pers2_Respect,Fem > => "gi:" ;
<CFuture,Pl,Pers3_Near,Masc > => "ge:" ;
<CFuture,Pl,Pers3_Near,Fem > => "gi:" ;
<CFuture,Pl,Pers3_Distant,Masc > => "ge:" ;
<CFuture,Pl,Pers3_Distant,Fem > => "gi:"
} ;
raha : Gender -> Number -> Str = \g,n ->
(regAdjective "raha:").s ! n ! g ! Dir ! Posit ;
cka : Gender -> Number -> Str = \g,n ->
(regAdjective "cuka:").s ! n ! g ! Dir ! Posit ;
hw : UPerson -> Number -> Str = \pp,n ->
case <pp,n> of {
<Pers1,_> => "hu:n~";
<_,Pl> => "ho:n~";
<_,_> => "ho:"
};
hwa : Agr -> Str = \agr ->
let n = (fromAgr agr).n;
p = (fromAgr agr).p;
g = (fromAgr agr).g;
in
case <n,g> of {
<Sg,Masc> => "huA:";
<Sg,Fem> => "huI:";
<Pl,Masc> => "huE:" ;
<Pl,Fem> => "huI:"
};
-----------------------------------------------
-- Hindustani Adjectives
-----------------------------------------------
regAdjective : Str -> Adjective;
regAdjective x = case x of {
acch + ("a:"|"an") => mkAdjective x ("bahut" ++ x) ("sab se:" ++ x) (acch + "e:") ("bahut" ++ acch + "e:") ("sab se:" ++ acch + "E") (acch + "e:") ("bahut" ++ acch + "e:") ("sab se:" ++ acch + "e:")
(acch + "i:") ("bahut" ++ acch + "i:") ("sab se:" ++ acch + "i:") (acch + "i:") ("bahut" ++ acch + "i:") ("sab se:" ++ acch + "i:") (acch + "i:") ("bahut" ++ acch + "i:") ("sab se:" ++ acch + "i:")
(acch +"e:") ("bahut" ++ acch + "e:") ("sab se:" ++ acch + "e:") (acch + "e:") ("bahut" ++ acch + "e:") ("sab se:" ++ acch + "e:") (acch + "e:") ("bahut" ++ acch + "e:") ("sab se:" ++ acch + "e:")
(acch + "i:") ("bahut" ++ acch + "i:") ("sab se:" ++ acch + "i:") (acch + "i:") ("bahut" ++ acch + "i:") ("sab se:" ++ acch + "i:") (acch + "i:") ("bahut" ++ acch + "i:") ("sab se:" ++ acch + "i:");
_ => mkAdjective x ("bahut" ++ x) ("sab se:" ++ x) x ("bahut" ++ x) ("sab se:" ++ x) x ("bahut" ++ x) ("sab se:" ++ x)
x ("bahut" ++ x) ("sab se:" ++ x) x ("bahut" ++ x) ("sab se:" ++ x) x ("bahut" ++ x) ("sab se:" ++ x)
x ("bahut" ++ x) ("sab se:" ++ x) x ("bahut" ++ x) ("sab se:" ++ x) x ("bahut" ++ x) ("sab se:" ++ x)
x ("bahut" ++ x) ("sab se:" ++ x) x ("bahut" ++ x) ("sab se:" ++ x) x ("bahut" ++ x) ("sab se:" ++ x)
};
IrregAdjective : Str -> Adjective;
IrregAdjective x = mkAdjective x ("bahut" ++ x) ("sab se:" ++ x) x ("bahut" ++ x) ("sab se:" ++ x) x ("bahut" ++ x) ("sab se:" ++ x)
x ("bahut" ++ x) ("sab se:" ++ x) x ("bahut" ++ x) ("sab se:" ++ x) x ("bahut" ++ x) ("sab se:" ++ x)
x ("bahut" ++ x) ("sab se:" ++ x) x ("bahut" ++ x) ("sab se:" ++ x) x ("bahut" ++ x) ("sab se:" ++ x)
x ("bahut" ++ x) ("sab se:" ++ x) x ("bahut" ++ x) ("sab se:" ++ x) x ("bahut" ++ x) ("sab se:" ++ x) ;
} }

View File

@@ -1,8 +1,9 @@
--# -path=.:../abstract:../common:../prelude:/Users/virk/gf_1/lib/src/hindustani --# -path=.:../abstract:../common:../prelude:/Users/virk/gf_1/lib/src/hindustani
concrete ExtraHin of ExtraHinAbs = CatHin ** concrete ExtraHin of ExtraHinAbs = CatHin **
open ResHin, Coordination, Prelude, MorphoHin, ParadigmsHin in { open ResHin, Coordination, Prelude, MorphoHin, ParadigmsHin in {
flags coding = utf8;
lin lin
-- GenNP np = {s = \\_,_,_ => np.s ! NPC Obl ++ "ka" ; a = np.a} ; -- GenNP np = {s = \\_,_,_ => np.s ! NPC Obl ++ "ka" ; a = np.a} ;
-- each_Det = mkDet "hr kwy" "hr kwy" "hr kwy" "hr kwy" Sg ; -- each_Det = mkDet "hr kwy" "hr kwy" "hr kwy" "hr kwy" Sg ;

View File

@@ -5,21 +5,21 @@ concrete IdiomHin of Idiom = CatHin ** open Prelude,Predef, ResHin,ParamX,Common
lin lin
ImpersCl vp = mkSClause " " (agrP3 Masc Sg) vp ; ImpersCl vp = mkSClause " " (agrP3 Masc Sg) vp ;
GenericCl vp = mkSClause "kwy" (agrP3 Masc Sg) vp ; GenericCl vp = mkSClause "ko:I:" (agrP3 Masc Sg) vp ;
CleftNP np rs = CleftNP np rs =
let cl = mkSClause (np.s ! NPC rs.c) (np.a) (predAux auxBe); let cl = mkSClause (np.s ! NPC rs.c) (np.a) (predAux auxBe);
in in
{s = \\t,p,o => cl.s ! t ! p ! o ++ rs.s ! np.a }; {s = \\t,p,o => cl.s ! t ! p ! o ++ rs.s ! np.a };
-- CleftAdv ad ss = { s = \\t,b,o => ad.s ! Masc ++ ss.s}; CleftAdv ad ss = { s = \\t,b,o => ad.s ! Masc ++ ss.s};
-- ExistNP np = ExistNP np =
-- mkSClause "whaN" (agrP3 (fromAgr np.a).g (fromAgr np.a).n) mkSClause "vaha:n~" (agrP3 (fromAgr np.a).g (fromAgr np.a).n)
-- (insertObj (\\_ => np.s ! NPC Obl) (predAux auxBe)) ; (insertObj (\\_ => np.s ! NPC Dir) (predAux auxBe)) ;
ExistIP ip = ExistIP ip =
let cl = mkSClause ("whaN" ++ ip.s ! Dir) (agrP3 ip.g ip.n) (predAux auxBe); let cl = mkSClause ("vaha:n~" ++ ip.s ! Dir) (agrP3 ip.g ip.n) (predAux auxBe);
in { in {
s = \\t,p,qf => case qf of { s = \\t,p,qf => case qf of {
QDir => cl.s ! t ! p ! ODir; QDir => cl.s ! t ! p ! ODir;
@@ -31,8 +31,9 @@ concrete IdiomHin of Idiom = CatHin ** open Prelude,Predef, ResHin,ParamX,Common
ProgrVP vp = (predProg vp) ; ProgrVP vp = (predProg vp) ;
ImpPl1 vp = {s = "Aw" ++ infVP True vp (agrP1 Masc Pl)} ; -- ImpPl1 vp = {s = "A:O:" ++ infVP True vp (agrP1 Masc Pl)} ;
ImpP3 np vp = {s = np.s!NPC Dir ++ "kw" ++ (vp.s ! VPImp ).inf ++ "dw"}; ImpPl1 vp = {s = "A:O:" ++ vp.obj.s ++ (vp.s ! VPTense VPFutr (agrP1 Masc Pl)).inf ++ vp.comp ! (agrP1 Masc Pl)} ;
ImpP3 np vp = {s = np.s!NPC Dir ++ "ko:" ++ (vp.s ! VPImp ).inf ++ "do:"};
} }

View File

@@ -8,362 +8,366 @@ concrete LexiconHin of Lexicon = CatHin **
optimize=values ; optimize=values ;
coding = utf8; coding = utf8;
lin lin
airplane_N = mkN "jHaj" ; airplane_N = mkCmpdNoun "hava:I:" (mkN "jaha:z") ;
-- answer_V2S = mkV2 (compoundV "jwab" (mkV "dyna")) ; answer_V2S = mkV2 (compoundV "java:b" (mkV "de:na:")) ;
-- apartment_N = mkN "kmrh" ; apartment_N = mkN "kamra:" ;
apple_N = mkN "syb" ; apple_N = mkN "se:b" ;
-- art_N = mkN "fn" ; -- art_N = mkN "" ;
ask_V2Q = mkV2 (mkV "pwcHna") ; ask_V2Q = mkV2 (mkV "pu:c'ana:") ;
-- baby_N = mkN "bcH" ; baby_N = mkN "bacX,c'a:" ;
bad_A = mkA "bra" ; bad_A = mkA "bura:" ;
bank_N = mkN "bynk" ; bank_N = mkN "be+m.k" ;
beautiful_A = mkA "sndr" ; beautiful_A = mkA "xu:bsu:rat" ;
become_VA = mkV "bnna"; become_VA = mkV "banana:";
beer_N = mkN "beer" ; beer_N = mkN "biyar" ;
-- beg_V2V = mkV2V (compoundV "altja" (mkV "krna")) "sE" "kh" False; beg_V2V = mkV2V (compoundV "b'i:k'" (mkV "ma:m.gna:")) "se:" "kh" False;
big_A = mkA "bRa" ; big_A = mkA "baRa:" ;
-- bike_N = mkN "saycl" feminine ; bike_N = mkN "sa:ykal" feminine ;
-- bird_N = mkN "prndh" ; bird_N = mkN "ciRiya:" ;
black_A = mkA "kala" ; black_A = mkA "ka:la:" ;
blue_A = mkA "nyla" ; blue_A = mkA "ni:la:" ;
boat_N = mkN "naw" ; boat_N = mkN "na:v" ;
book_N = mkN "ktab" feminine ; book_N = mkN "kita:b" feminine ;
-- boot_N = mkN "jwta" ; boot_N = mkN "ju:ta:" ;
boss_N = mkN "malk" ; boss_N = mkN "ma:lik" ;
boy_N = mkN "lRka" ; boy_N = mkN "laRka:" ;
bread_N = mkN "rwty" ; bread_N = mkN "ro:Ti:" ;
break_V2 = mkV2 (mkV "twRna") ; break_V2 = mkV2 (mkV "to:Rna:") ;
broad_A = mkA "cwRa" ; broad_A = mkA "co+Ra:" ;
brother_N2 = mkN2 (mkN "bHay") (mkPrep "ka" "ka") "kE" ; --not correct brother_N2 = mkN2 (mkN "b'a:I:") (mkPrep "ka" "ki:") "ke:" ; --not correct
brown_A = mkA "bHwra" ; brown_A = mkA "b'u:ra:" ;
-- butter_N = mkN "mkh-n" ; butter_N = mkN "makX,k'an" ;
buy_V2 = mkV2 (mkV "Krydna"); buy_V2 = mkV2 (mkV "xari:dna:") "ko:"; -- add ko: here for es ko khredna, but this will create sentences like kitab ko kharedna
camera_N = mkN "kymrH" ; camera_N = mkN "ke+mara:" ;
cap_N = mkN "twpy" ; cap_N = mkN "To:pi:" ;
car_N = mkN "kar" ; car_N = mkN "ka:r" ;
-- carpet_N = mkN "tpay^y" ; carpet_N = mkN "qa:li:n" ;
cat_N = mkN "bly" feminine; cat_N = mkN "billi:" feminine;
-- ceiling_N = mkN "ch-t" feminine ; ceiling_N = mkN "c'at" feminine ;
chair_N = mkN "krsy" ; chair_N = mkN "kurX,si:" ;
-- cheese_N = mkN "pnyr" feminine ; cheese_N = mkN "pani:r" feminine ;
child_N = mkN "bcH" ; child_N = mkN "bacX,c'a:" ;
church_N = mkN "grja" ; church_N = mkN "girija:" ;
city_N = mkN "XHr" ; city_N = mkN "s*ahar" ;
clean_A = mkA "saf" ; clean_A = mkA "sa:f" ;
clever_A = mkA "catr" ; clever_A = mkA "ca:la:k" ;
close_V2 = mkV2 (compoundV "bnd" do_V2); close_V2 = mkV2 (compoundV "band" do_V2);
coat_N = mkN "kwT" ; coat_N = mkN "ko:T" ;
cold_A = mkA "srd" ; cold_A = mkA "sard" ;
come_V = mkV "Ana" ; come_V = mkV "A:na:" ;
computer_N = mkN "kmpywTr" ; computer_N = mkN "kam.pyu:Tar" ;
country_N = mkN "dyX" ; country_N = mkN "de:s*" ;
-- cousin_N = mkCmpdNoun "cca" (mkN "zad") ; -- a compund noun made of two nouns cousin_N = mkCmpdNoun "cca" (mkN "zad") ; -- a compund noun made of two nouns
cow_N = mkN "gaE" feminine ; cow_N = mkN "ga:y" feminine ;
die_V = mkV "mrna" ; die_V = mkV "marna:" ;
dirty_A = mkA "gnda" ; dirty_A = mkA "gam.da:" ;
-- distance_N3 = mkN3 (mkN "faSlh") (mkPrep "ka") "kE" "sE" ; distance_N3 = mkN3 (mkN "fa:sla:") (mkPrep "ka:" "ki:") "ke:" "se:" ;
doctor_N = mkN "daktr" ; doctor_N = mkN "Da:kTar" ;
dog_N = mkN "kta" ; dog_N = mkN "kutta:" ;
door_N = mkN "drwza" ; door_N = mkN "darva:za:" ;
drink_V2 = mkV2 (mkV "pyna"); drink_V2 = mkV2 (mkV "pi:na:");
easy_A2V = mkA "Asan" "" ; -- chek for A or a easy_A2V = mkA "A:sa:n" "" ; -- chek for A or a
eat_V2 = mkV2 (mkV "kHana") "" ; eat_V2 = mkV2 (mkV "k'a:na:") "" ;
empty_A = mkA "Kaly" ; empty_A = mkA "xa:li:" ;
enemy_N = mkN "dXmn" ; enemy_N = mkN "dus*X,man" ;
factory_N = mkN "karKana" ; factory_N = mkN "ka:rxa:na:" ;
-- father_N2 = mkN2 (mkN "pta" irregular) (mkPrep "ka") "kE" ; father_N2 = mkN2 (mkN "ba:p") (mkPrep "ka" "ki:") "ke:" ;
fear_VS = mkV "dRna"; fear_N = mkN "Dar";
find_V2 = mkV2 (mkV "dHwnda") ; fear_VS = mkV "Darna:";
fish_N = mkN "mcHly" ; find_V2 = mkV2 (mkV "pa:na:") ;
floor_N = mkN "frX" ; fish_N = mkN "mac'li:" ;
forget_V2 = mkV2 (mkV "bHwlna") ; floor_N = mkN "fars*" ;
-- fridge_N = mkN "fryg" ; forget_V2 = mkV2 (mkV "b'u:lna:") ;
friend_N = mkN "dwst" masculine ; fridge_N = mkN "frij" ;
fruit_N = mkN "pHl" ; friend_N = mkN "do:sX,t" masculine ;
fruit_N = mkN "p'al" ;
-- fun_AV = mkAV (regA "fun") ; -- fun_AV = mkAV (regA "fun") ;
garden_N = mkN "baG" ; -- chek for G garden_N = mkN "ba:g." ; -- chek for g.
girl_N = mkN "lRky" ; girl_N = mkN "laRki:" ;
glove_N = mkN "dstana" ; glove_N = mkN "dasta:na:" ;
gold_N = mkN "swna" ; gold_N = mkN "so:na:" ;
good_A = mkA "acHa" ; good_A = mkA "AcX,c'a:" ;
go_V = mkV "jana" ; go_V = mkV "ja:na:" ;
green_A = mkA "Hra" ; green_A = mkA "hara:" ;
-- harbour_N = mkCmpdNoun "bndr" (mkN "gah") ; harbour_N = mkCmpdNoun "bam.dar" (mkN "ga:h") ;
hate_V2 = mkV2 (compoundV "nfrt" do_V2) ; hate_N = mkN "nafrat" ;
hat_N = mkN "Twpy" ; hate_V2 = mkV2 (compoundV "nafrat" do_V2) ;
hat_N = mkN "To:pi:" ;
-- have_V2 = dirV2 (mk5V "have" "has" "had" "had" "having") ; -- have_V2 = dirV2 (mk5V "have" "has" "had" "had" "having") ;
hear_V2 = mkV2 (mkV "snna") ; hear_V2 = mkV2 (mkV "sunna:") ;
-- hill_N = mkN "phaRy" ; hill_N = mkN "paha:R" ;
-- hope_VS = (compoundV "amyd" do_V2); hope_N = mkN "Ummi:d" ;
horse_N = mkN "gHwRa" ; hope_VS = (compoundV "Ummi:d" do_V2);
hot_A = mkA "grm" ; horse_N = mkN "g'o:Ra:" ;
house_N = mkN "gHr" ; hot_A = mkA "garm" ;
important_A = mkA "zrwry" ; -- check about z house_N = mkN "g'ar" ;
-- industry_N = mkN "Snet" feminine ; important_A = mkA "zaru:ri:" ; -- check about z
iron_N = mkN "lwHa" ; industry_N = mkN "sant" feminine ;
king_N = mkN "raja" ; iron_N = mkN "lo:ha:" ;
know_V2 = mkV2 (mkV "janna") ; king_N = mkN "ra:ja:" ;
know_VS = mkV "janna"; know_V2 = mkV2 (mkV "ja:nna:") ;
-- lake_N = mkN "jh-yl" feminine ; know_VS = mkV "ja:nna:";
lamp_N = mkN "dya" ; lake_N = mkN "j'i:l" feminine ;
learn_V2 = mkV2 (mkV "sykHna") ; lamp_N = mkN "cira:g" ;
-- leather_N = mkN "cmRa" ; learn_V2 = mkV2 (mkV "si:k'na:") ;
leave_V2 = mkV2 (mkV "clna") ; leather_N = mkN "camRa:" ;
like_V2 = mkV2 (compoundV "psnd" do_V2); leave_V2 = mkV2 (mkV "calna:") ;
listen_V2 = mkV2 (mkV "snna") ; like_V2 = mkV2 (compoundV "pasam.d" do_V2);
live_V = mkV "rhna" ; ---- touch listen_V2 = mkV2 (mkV "sunna:") ;
long_A = mkA "lmba" ; live_V = mkV "rahna:" ; ---- touch
lose_V2 = mkV2 (compoundV "kHw" do_V2) ; long_A = mkA "lam.ba:" ;
love_N = mkN "prym" ; lose_V2 = mkV2 (compoundV "k'o:" do_V2) ;
love_V2 = mkV2 (compoundV "pyar" do_V2) "kw"; love_N = mkN "pX,ya:r" ;
man_N = mkN "Admy" ; love_V2 = mkV2 (compoundV "pX,ya:r" do_V2) "ko:";
-- married_A2 = mkA "Xady " "sE" ; man_N = mkN "A:dmi:" masculine;
meat_N = mkN "mas" ; married_A2 = mkIrregA "s*a:di: s*uda:" "se:" ;
milk_N = mkN "dwdH" ; marriage = mkN "s*a:di: " ;
moon_N = mkN "cand" ; meat_N = mkN "ma:m.s" ;
mother_N2 = mkN2 (mkN "mata" feminine) (mkPrep "ky" "ky") "kE"; -- not covered need to be discussed milk_N = mkN "du:d'" ;
-- mountain_N = mkN "phaRy" ; moon_N = mkN "ca:m.d" ;
music_N = mkN "sngyt" ; mother_N = mkN "ma:n~" feminine; -- not covered need to be discussed
-- narrow_A = mkA "baryk" ; mountain_N = mkN "paha:R" ;
new_A = mkA "nya" ; music_N = mkN "sam.gi:t" ;
newspaper_N = mkN "aKbar" ; narrow_A = mkA "tam.g" ;
oil_N = mkN "tyl" ; new_A = mkA "naya:" ;
old_A = mkA "bwRHa" ; newspaper_N = mkN "Axba:r" ;
open_V2 = mkV2 (mkV "kHwlna") ; oil_N = mkN "te:l" ;
-- paint_V2A = mkV2 (compoundV "rng" do_V2) ; old_A = mkA "bu:R'a:" ;
paper_N = mkN "kaGz" ; open_V2 = mkV2 (mkV "k'o:lna:") ;
paris_PN = mkPN "pyrs" ; paint_V2A = mkV2 (compoundV "ram.g" do_V2) ;
peace_N = mkN "amn" ; paper_N = mkN "ka:g.az" ;
pen_N = mkN "qlm" ; paris_PN = mkPN "pe+ris" ;
-- planet_N = mkN "syarh" ; peace_N = mkN "Aman" ;
-- plastic_N = mkN "plasTk" ; pen_N = mkN "qalam" ;
play_V2 = mkV2 (mkV "kHylna") ; planet_N = mkN "sita:ra:" ;
-- policeman_N = mkCmpdNoun "pwlys" (mkN "wala") ; plastic_N = mkN "pla:sTik" ;
-- priest_N = (mkN "pyGmbr") ; play_V2 = mkV2 (mkV "k'e:lna:") ;
policeman_N = mkCmpdNoun "pulis" (mkN "wa:la:") ;
priest_N = mkN "puja:ri:" ;
-- probable_AS = mkAS (regA "probable") ; -- probable_AS = mkAS (regA "probable") ;
-- queen_N = mkN "Xhzady" ; queen_N = mkN "ra:ni:" ;
-- radio_N = mkN "ryDyw" ; radio_N = mkN "re:Dio:" ;
rain_V0 = compoundV "barX" (mkV "Hwna" ) ; rain_N = mkN "ba:ris*" ;
read_V2 = mkV2 (mkV "pRHna"); rain_V0 = compoundV "ba:ris*" (mkV "ho:na:" ) ;
red_A = mkA "lal" ; read_V2 = mkV2 (mkV "paR'na:");
religion_N = mkN "dHrm" ; red_A = mkA "la:l" ;
-- restaurant_N = mkN "hwTl" ; religion_N = mkN "mazhab" ;
river_N = mkN "drya" masculine ; restaurant_N = mkN "re:sTo:ra:m.T" ;
rock_N = mkN "cTan" ; -- river_N = mkN "dariya:" masculine ;
roof_N = mkN "ch-t" masculine ; rock_N = mkN "caTTa:n" ;
-- rubber_N = mkN "rbR" ; roof_N = mkN "c'at" masculine ;
run_V = mkV "dwRna" ; rubber_N = mkN "rabar" ;
say_VS = mkV "kHna" ; run_V = mkV "do+Rna:" ;
school_N = mkN "mktb" ; say_VS = mkV "kahna:" ;
-- science_N = mkN "sans" ; -- vgyan school_N = mkN "sku:l" ;
sea_N = mkN "smndr" ; science_N = mkN "sa:ians" ; -- vgyan
-- seek_V2 = mkV2 (compoundV "tlaX" do_V2) ; sea_N = mkN "samam.dar" ;
see_V2 = mkV2 (mkV "dykHna") ; seek_V2 = mkV2 (compoundV "tala:s*" do_V2) ;
sell_V3 = mkV3 (mkV "bycna") "kw" ""; see_V2 = mkV2 (mkV "de:k'na:") ;
send_V3 = mkV3 (mkV "bHyjna") "kw" ""; sell_V3 = mkV3 (mkV "be:cna:") "ko:" "";
sheep_N = mkN "bHyR" feminine ; send_V3 = mkV3 (mkV "b'e:jna:") "ko:" "";
ship_N = mkN "jHaz" ; sheep_N = mkN "b'i:R" feminine ;
shirt_N = mkN "krta" feminine; ship_N = mkN "jaha:z" ;
shoe_N = mkN "jwta" ; shirt_N = mkN "kurX,ta:" feminine;
shop_N = mkN "dwkan" feminine ; shoe_N = mkN "ju:ta:" ;
short_A = mkA "cHwTa" ; shop_N = mkN "du:ka:n" feminine ;
silver_N = mkN "candy" ; short_A = mkA "c'o:Ta:" ;
sister_N = mkN "bHn" feminine ; silver_N = mkN "ca:m.di:" ;
sleep_V = mkV "swna" ; sister_N = mkN "bahan" feminine ;
small_A = mkA "cHwTa" ; sleep_V = mkV "so:na:" ;
snake_N = mkN "sanp" ; small_A = mkA "c'o:Ta:" ;
-- sock_N = mkN "jrab" feminine ; snake_N = mkN "sa:m.p" ;
speak_V2 = mkV2 (mkV "bwlna") ; sock_N = mkN "jurra:b" feminine ;
star_N = mkN "tara" ; speak_V2 = mkV2 (mkV "bo:lna:") ;
-- steel_N = mkN "styl" ; -- something like ispat star_N = mkN "ta:ra:" ;
stone_N = mkN "ptHr" ; steel_N = mkN "Ispa:t" ; -- something like ispat
-- stove_N = mkN "cwlha" ; stone_N = mkN "patX,t'ar" ;
stove_N = mkN "cu:lX,ha:" ;
-- student_N = mkCmpdNoun "t-alb" (mkN "elm") ; -- something vidrati -- student_N = mkCmpdNoun "t-alb" (mkN "elm") ; -- something vidrati
stupid_A = mkA "bEwqwf" ; stupid_A = mkA "be:vaqu:f" ;
-- sun_N = mkN "swrj" ; -- swrya sun_N = mkN "su:raj" ; -- swrya
switch8off_V2 = mkV2 (compoundV "bnd" do_V2) ; switch8off_V2 = mkV2 (compoundV "bam.d" do_V2) ;
switch8on_V2 = mkV2 (mkV "clana") ; switch8on_V2 = mkV2 (mkV "cala:na:") ;
table_N = mkN "myz" feminine ; table_N = mkN "me:z" feminine ;
talk_V3 = mkV3 (mkV "bwlna") "sE" "kE barE meN"; talk_V3 = mkV3 (mkV "bo:lna:") "se:" "ke: ba:re: me:";
-- teacher_N = mkN "istad" ; -- adyapak teacher_N = mkN "UsX,ta:d" ; -- adyapak
teach_V2 = mkV2 (mkV "pRHna") ; teach_V2 = mkV2 (mkV "sik'a:na:") ;
television_N = mkN "tywy" ; television_N = mkN "Ti:vi:" ;
thick_A = mkA "mwTa" ; thick_A = mkA "mo:Ta:" ;
thin_A = mkA "ptla" ; thin_A = mkA "patla:" ;
train_N = mkN "ryl gaRy" ; train_N = mkN "re:l ga:Ri:" ;
travel_V = (compoundV "sfr" do_V2) ; travel_V = (compoundV "safar" do_V2) ;
-- tree_N = mkN "pyR" masculine ; -- tree_N = mkN "pe:R" masculine ;
-- ---- trousers_N = mkN "trousers" ; trousers_N = mkN "patlu:n" ;
ugly_A = mkA "bdswrt" ; ugly_A = mkA "badsu:rat" ;
understand_V2 = mkV2 (mkV "smjHna") ; understand_V2 = mkV2 (mkV "samaj'na:") ;
-- university_N = mkN "ywnywrsTy" ; university_N = mkN "yu:nivarsiTi:" ;
village_N = mkN "gawN" ; -- check for n or N village_N = mkN "ga:n~v" ; -- check for n or N
-- wait_V2 = mkV2 (compoundV "antz-ar" do_V2) "ka" ; -- something prtkXa wait_V2 = mkV2 (compoundV "Im.taza:r" do_V2) "ka:" ; -- something prtkXa
walk_V = mkV "clna" ; walk_V = mkV "calna:" ;
-- warm_A = mkA "grm" ; something gngna warm_A = mkA "garm" ; something gngna
-- war_N = mkN "jng" ; war_N = mkN "laRa:I:" ;
watch_V2 = mkV2 (mkV "dykHna") ; watch_V2 = mkV2 (mkV "de:k'na:") ;
-- water_N = mkN "pany" masculine ; -- not covered masculine ending with y water_N = mkN "pa:ni:" masculine ; -- not covered masculine ending with y
white_A = mkA "sfyd" ; white_A = mkA "safe:d" ;
window_N = mkN "rwXndan" ; window_N = mkN "k'iRki:" ;
-- wine_N = mkN "Xrab" feminine ; wine_N = mkN "s*ara:b" feminine ;
win_V2 = mkV2 (mkV "jytna") ; win_V2 = mkV2 (mkV "ji:tna:") ;
woman_N = mkN "ewrt" feminine ; woman_N = mkN "O+rat" feminine ;
-- wonder_VQ = compoundV "Heran" (mkV "hwna") ; wonder_VQ = compoundV "he+ra:n" (mkV "ho:na:") ;
wood_N = mkN "lkRy" ; wood_N = mkN "lakRi:" ;
write_V2 = mkV2 (mkV "lkh-na") ; write_V2 = mkV2 (mkV "lik'na:") ;
yellow_A = mkA "pyla" ; yellow_A = mkA "pi:la:" ;
young_A = mkA "jwan" ; young_A = mkA "java:n" ;
do_V2 = mkV2 (mkV "krna") ; do_V2 = mkV2 (mkV "karna:") ;
-- now_Adv = mkAdv "ab" ; now_Adv = mkAdv "Ab" ;
-- already_Adv = mkAdv "phlE hy" ; already_Adv = mkAdv "pahle: hi:" ;
song_N = mkN "gyt" ; song_N = mkN "gi:t" ;
add_V3 = mkV3 (compoundV "jme" do_V2) "" "" ; add_V3 = mkV3 (mkV "jo:Rana:") "ko:" "mi:m."; -- confirm
-- number_N = mkN "hndsh" ; number_N = mkN "hndsh" ;
-- put_V2 = mkV2 (mkV "Dalna") ; put_V2 = mkV2 (mkV "Da:lna:") ;
stop_V = mkV "rkna" ; stop_V = mkV "rukna:" ;
-- jump_V = compoundV "cHlang" (mkV "lgana") feminine ; jump_V = compoundV "c'ala:m.g" (mkV "laga:na:") ;
-- left_Ord = {s = "bayaN" ; n = singular}; left_Ord = {s = "ba:ya:n~" ; n = singular};
-- right_Ord = {s= "dayaN" ; n = singular}; right_Ord = {s= "da:ya:n~" ; n = singular};
-- far_Adv = mkAdv "dwr" ; far_Adv = mkAdv "du:r" ;
correct_A = mkA "syH" ; correct_A = mkA "sahi:h" ;
dry_A = mkA "swkHa" ; dry_A = mkA "su:k'a:" ;
-- dull_A = mkA "nalik" ; dull_A = mkA "nalik" ;
-- full_A = mkA "mkml" ; full_A = mkA "b'ara:" ;
heavy_A = mkA "bHary" ; heavy_A = mkA "b'a:ri:" ;
near_A = mkA "pas" ; near_A = mkA "pa:s" ;
-- rotten_A = mkA "Krab" ; rotten_A = mkA "saRa:" ;
round_A = mkA "gwl" ; round_A = mkA "go:l" ;
sharp_A = mkA "tyz" ; sharp_A = mkA "te:z" ;
smooth_A = mkA "ckna" ; smooth_A = mkA "cikna:" ;
straight_A = mkA "sydHa" ; straight_A = mkA "si:d'a:" ;
wet_A = mkA "gyla" ; ---- wet_A = mkA "gi:la:" ; ----
wide_A = mkA "cwRa" ; wide_A = mkA "co+Ra:" ;
animal_N = mkN "janwr" ; animal_N = mkN "ja:nvar" ;
ashes_N = mkN "rakh-" feminine; -- FIXME: plural only? ashes_N = mkN "ra:k'" feminine; -- FIXME: plural only?
-- back_N = mkN "qmr" feminine ; back_N = mkN "pi:T'" feminine ;
-- bark_N = mkN "bark" ; -- bark_N = mkN "bark" ;
-- belly_N = mkN "dh-ny" ; -- belly_N = mkN "dh-ny" ;
-- blood_N = mkN "Kwn" ; blood_N = mkN "xu:n" ;
bone_N = mkN "HDy" feminine ; bone_N = mkN "haDDi:" feminine ;
-- breast_N = mkN "ch-aty" ; --stan breast_N = mkN "c'a:ti:" ; --stan
cloud_N = mkN "badl" ; cloud_N = mkN "ba:dal" ;
day_N = mkN "dn" ; day_N = mkN "din" ;
dust_N = mkN "dHwl" ; dust_N = mkN "d'u:l" ;
ear_N = mkN "kan" ; ear_N = mkN "ka:n" ;
-- earth_N = mkN "zmyn" feminine ; earth_N = mkN "zami:n" feminine ;
egg_N = mkN "anDH" ; egg_N = mkN "Am.Da:" ;
eye_N = mkN "AnkH" feminine ; eye_N = mkN "A:m.k'" feminine ;
fat_N = mkN "mwta" ; fat_N = mkN "mo:Ta:" ;
feather_N = mkN "pnkH" ; feather_N = mkN "pam.k'" ;
-- fingernail_N = mkN "naKn" ; fingernail_N = mkN "na:k'u:n" ;
fire_N = mkN "Ag" feminine ; fire_N = mkN "A:g" feminine ;
flower_N = mkN "pHwl" ; flower_N = mkN "p'u:l" ;
fog_N = mkN "dHnd" feminine ; fog_N = mkN "d'um.d'" feminine ;
foot_N = mkN "pawN" ; -- not properly covered need to be discussed foot_N = mkN "pa:m.v" ; -- not properly covered need to be discussed
forest_N = mkN "jngl" ; forest_N = mkN "jam.gal" ;
grass_N = mkN "gHs" feminine ; grass_N = mkN "g'a:s" feminine ;
-- guts_N = mkN "gut" ; -- FIXME: no singular -- guts_N = mkN "gut" ; -- FIXME: no singular
hair_N = mkN "bal" ; hair_N = mkN "ba:l" ;
hand_N = mkN "HatH" ; hand_N = mkN "ha:t'" ;
head_N = mkN "sr" ; head_N = mkN "sir" ;
heart_N = mkN "dl" ; heart_N = mkN "dil" ;
-- horn_N = mkN "gh-nty" ; horn_N = mkN "si:m.g" ;
husband_N = mkN "pty" ; husband_N = mkN "pati" ;
ice_N = mkN "brf" feminine ; ice_N = mkN "barX,f" feminine ;
knee_N = mkN "gHtnH" ; knee_N = mkN "g'uTna:" ;
leaf_N = mkN "ptH" ; leaf_N = mkN "patta:" ;
leg_N = mkN "tang" feminine ; leg_N = mkN "Ta:m.g" feminine ;
liver_N = mkN "klyjH" ; liver_N = mkN "kale:ja:" ;
-- louse_N = mkN "" ; -- jwN louse_N = mkN "ju:" ;
mouth_N = mkN "mnH" ; mouth_N = mkN "muh" ;
name_N = mkN "nam" ; name_N = mkN "na:m" ;
neck_N = mkN "grdn" feminine ; neck_N = mkN "garX,dan" feminine ;
night_N = mkN "rat" feminine ; night_N = mkN "ra:t" feminine ;
nose_N = mkN "nak" ; nose_N = mkN "na:k" ;
-- person_N = mkN "XKS" ; -- person_N = mkN "XKS" ;
rain_N = mkN "barX" feminine ; road_N = mkN "saRak" ;
road_N = mkN "sRk" ; root_N = mkN "jaR" feminine ;
root_N = mkN "gR" feminine ; rope_N = mkN "rassi:" ;
rope_N = mkN "rsy" ; salt_N = mkN "namak" feminine ;
salt_N = mkN "nmk" feminine ; sand_N = mkN "re:t" feminine ;
sand_N = mkN "ryt" feminine ; seed_N = mkN "bi:j" ;
seed_N = mkN "byj" ; skin_N = mkN "jld" feminine ; -- crm
-- skin_N = mkN "jld" feminine ; -- crm sky_N = mkN "A:sma:n" ;
sky_N = mkN "ambr" ; smoke_N = mkN "d'ua:n~"; -- singular masc nouns ending with aN,wN yet to be implemented
smoke_N = mkN "dHwaN"; -- singular masc nouns ending with aN,wN yet to be implemented snow_N = mkN "barX,f" feminine ;
snow_N = mkN "brf" feminine ; stick_N = mkN "lakRi:" ;
stick_N = mkN "soTy" ; tail_N = mkN "dum" ;
tail_N = mkN "dm" ; tongue_N = mkN "zaba:n" feminine ;
-- tongue_N = mkN "zban" feminine ; tooth_N = mkN "da:m.t" masculine;
-- tooth_N = mkN "dant" masculine; wife_N = mkN "bi:vi:" ;
wife_N = mkN "ptny" ; wind_N = mkN "hava:" ;
wind_N = mkN "Hwa" ;
-- wing_N = mkN "pr" ; -- wing_N = mkN "pr" ;
worm_N = mkN "kyRa" ; worm_N = mkN "ki:Ra" ;
year_N = mkN "sal" ; year_N = mkN "sa:l" ;
-- blow_V = mkV "clna" ; -- blow_V = mkV "clna" ;
breathe_V = compoundV "sans" (mkV "lyna" ) ; breathe_V = compoundV "sa:n~s" (mkV "le:na:" ) ;
burn_V = mkV "jlana" ; burn_V = mkV "jala:na:" ;
dig_V = mkV "kHwdna" ; dig_V = mkV "k'o:dna:" ;
fall_V = mkV "grna" ; fall_V = mkV "girna:" ;
-- float_V = mkV "tyrna" ; float_V = mkV "te+rna:" ;
flow_V = mkV "clna" ; flow_V = mkV "bahna:" ;
fly_V = mkV "aRna" ; fly_V = mkV "uRna:" ;
-- freeze_V = mkV "jmna"; -- freeze_V = mkV "jmna";
give_V3 = mkV3 (mkV "dyna") "kw" ""; give_V3 = mkV3 (mkV "de:na:") "ko:" "";
laugh_V = mkV "hnsna" ; laugh_V = mkV "ham.sna:" ;
-- lie_N = mkN "jh-wt" masculine ; lie_N = mkN "j'u:T" masculine ;
lie_V = compoundV "jHwt" (mkV "bwlna" ); lie_V = compoundV "j'u:T" (mkV "bo:lna:" );
play_V = mkV "kHylna" ; play_V = mkV "k'e:lna:" ;
sew_V = mkV "syna" ; sew_V = mkV "si:na:" ;
sing_V = mkV "gana" ; sing_V = mkV "ga:na:" ;
sit_V = mkV "byTHna" ; sit_V = mkV "be+T'na:" ;
smell_V = mkV "swngna" ; smell_V = mkV "su:m.gna:" ;
spit_V = mkV "tHwkna" ; spit_V = mkV "t'u:kna:" ;
stand_V = compoundV "kHRE" (mkV "hwna" ); -- a type of compound verb made of two verbs i.e 'kHRa' also inflects, rather than a string and verb should be fixed stand_V = compoundV "k'aRa:" (mkV "ho:na:" ); -- a type of compound verb made of two verbs i.e 'kHRa' also inflects, rather than a string and verb should be fixed
-- swell_V = mkV "swjh-na" ; swell_V = mkV "su:jna:" ;
swim_V = mkV "tyrna" ; swim_V = mkV "te+rna:" ;
think_V = mkV "swcna" ; think_V = mkV "so:cna:" ;
turn_V = mkV "mRna"; turn_V = mkV "muRna:";
-- vomit_V = compoundV "alty" (mkV "krna") feminine ; -- vomit_V = compoundV "Aly" (mkV "krna") feminine ;
bite_V2 = mkV2 (mkV "katna") ; bite_V2 = mkV2 (mkV "ka:Tana:") ;
count_V2 = mkV2 (mkV "gnna") ; count_V2 = mkV2 (mkV "ginna:") ;
cut_V2 = mkV2 (mkV "katna") ; cut_V2 = mkV2 (mkV "ka:Tna:") ;
fear_V2 = mkV2 (mkV "Drna") ; fear_V2 = mkV2 (mkV "Darna:") ;
fight_V2 = mkV2 (mkV "lRna") ; fight_V2 = mkV2 (mkV "laRna:") ;
-- hit_V2 = mkV2 (compoundV "th-wkr" (mkV "marna" )); -- hit_V2 = mkV2 (compoundV "th-wkr" (mkV "marna" ));
hold_V2 = mkV2 (mkV "pkRna") ; hold_V2 = mkV2 (mkV "pakaRna:") ;
-- hunt_V2 = mkV2 (compoundV "Xkar" do_V2); -- hunt_V2 = mkV2 (compoundV "Xkar" do_V2);
kill_V2 = mkV2 (compoundV "mar" (mkV "Dalna" )) ; kill_V2 = mkV2 (compoundV "ma:r" (mkV "Da:lna:" )) ;
pull_V2 = mkV2 (mkV "kHncna"); pull_V2 = mkV2 (mkV "k'i:m.cna:");
-- push_V2 = mkV2 (mkV "dh-kylna") "kw" ; push_V2 = mkV2 (mkV "d'ake:lna:") "ko:" ;
-- rub_V2 = mkV2 (mkV "rgRna") ; rub_V2 = mkV2 (mkV "ragaRna:") ;
-- scratch_V2 = mkV2 (mkV "kh-rcna") "kw" ; scratch_V2 = mkV2 (mkV "k'aro:m.cna:") "ko:" ;
-- split_V2 = mkV2 (mkV "banta") "kw" ; -- split_V2 = mkV2 (mkV "banta") "ko::" ;
-- squeeze_V2 = dirV2 (regV "squeeze") ; -- squeeze_V2 = dirV2 (regV "squeeze") ;
-- stab_V2 = dirV2 (regDuplV "stab") ; -- stab_V2 = dirV2 (regDuplV "stab") ;
-- suck_V2 = mkV2 (mkV "cwsna") ; suck_V2 = mkV2 (mkV "cu:sna:") ;
throw_V2 = mkV2 (mkV "pHynkna") ; throw_V2 = mkV2 (mkV "p'e:m.kna:") ;
tie_V2 = mkV2 (mkV "bandHna") ; tie_V2 = mkV2 (mkV "ba:m.d'na:") ;
wash_V2 = mkV2 (mkV "dHwna") ; wash_V2 = mkV2 (mkV "d'o:na:") ;
wipe_V2 = mkV2 (compoundV "Saf" (mkV "krna" )); -- wash_V2 = mkV2 (mkV "po:m.c'ana:") ;
---- other_A = regA "other" ; ---- other_A = regA "other" ;
-- grammar_N = mkN "grdan" ; -- grammar_N = mkN "grdan" ;
-- language_N = mkN "zban" feminine ; -- language_N = mkN "zban" feminine ;
-- rule_N = mkN "aSwl" ; -- rule_N = mkN "ASwl" ;
---- added 4/6/2007 ---- added 4/6/2007
john_PN = mkPN "jon" ; john_PN = mkPN "ja:n" ;
-- question_N = mkN "swal" ; question_N = mkN "sava:l" ;
-- ready_A = regA "ready" ; ready_A = mkA "te+ya:r" ;
-- reason_N = mkN "wjh" feminine ; reason_N = mkN "vajah" feminine ;
-- today_Adv = mkAdv "Aj" ; today_Adv = mkAdv "A:j" ;
-- uncertain_A = mkA ["Gyr yqyny"] ; -- uncertain_A = mkA ["g.yr yqyny"] ;
} }

View File

@@ -36,10 +36,11 @@ oper
regNoun : Str -> Noun ; regNoun : Str -> Noun ;
regNoun s = case s of { regNoun s = case s of {
_ + "ya" => mkN05 (s); _ + "ya:" => mkN05 (s);
_ + ("a"|"e"|"h") => mkN01 (s); _ + ("a:") => mkN01 (s);
_ + "y" => mkN03 (s); _ + "i:" => mkN03 (s);
_ + ("aN"|"wN") => mkN04 (s); _ + ("a:n~"|"a:") => mkN04 (s);
_ + "a:n~v" => mkN12 s;
_ + "w^" => mkN12 (s); _ + "w^" => mkN12 (s);
_ => regNoun2 (s) _ => regNoun2 (s)
}; };
@@ -55,10 +56,11 @@ oper
in case <s,g,c> of { in case <s,g,c> of {
<_ + "t",Fem,_> => mkN10 (s); <_ + "t",Fem,_> => mkN10 (s);
<_ + "t",Masc,_> => mkN02 (s); <_ + "t",Masc,_> => mkN02 (s);
<_ + "w",Masc,_> => mkN11 (s); <_ + "u:",Masc,_> => mkN11 (s);
<_ + "w",Fem,_> => mkN07 (s); <_ + "w",Fem,_> => mkN07 (s);
<_ + "ya",Fem,_> => mkN05 (s); <_ + "ya",Fem,_> => mkN05 (s);
<_ + "ya",Masc,_> => mkN02 (s); <_ + "ya",Masc,_> => mkN02 (s);
<_ + "i:",Masc,_> => mkN13 (s);
<_,Fem,False> => mkN08 (s); <_,Fem,False> => mkN08 (s);
<_,Fem,_> => mkN09 (s) <_,Fem,_> => mkN09 (s)
@@ -70,14 +72,14 @@ oper
mkN01 : Str -> Noun ; mkN01 : Str -> Noun ;
mkN01 lRka = let end = last (lRka) ; mkN01 lRka = let end = last (lRka) ;
lRk = if_then_else Str (eq end "e") lRka (tk 1 lRka) lRk = if_then_else Str (eq end "e") lRka (tk 1 lRka)
in mkNoun (lRka) (lRk+"E") (lRk+"E") in mkNoun (lRka) (lRk+"e:") (lRk+"e:")
(lRk+"E") (lRk+"wN") (lRk+"w") (lRk+"e:") (lRk+"o:n~") (lRk+"o:")
Masc ; Masc ;
-- masculine nouns does not end with a, h, e, an -- masculine nouns does not end with a, h, e, an
mkN02 : Str -> Noun ; mkN02 : Str -> Noun ;
mkN02 mrd = let mrdwN = mrd+"wN" ; mkN02 mrd = let mrdwN = mrd+"o:n~" ;
mrdw = tk 1 mrdwN mrdw = tk 1 mrdwN
in mkNoun mrd mrd mrd in mkNoun mrd mrd mrd
mrd mrdwN mrdw mrd mrdwN mrdw
@@ -86,24 +88,32 @@ oper
-- feminine Nouns end with y -- feminine Nouns end with y
mkN03 : Str -> Noun ; mkN03 : Str -> Noun ;
mkN03 krsy = let krsyaN = krsy+"aN" ; mkN03 krsy = let krsyaN = krsy+"an~" ;
krsywN = krsy+"wN" ; krsywN = krsy+"yo:n~" ;
krsyw = tk 1 krsywN krsyw = tk 1 krsywN
in mkNoun krsy krsy krsy in mkNoun krsy krsy krsy
krsyaN krsywN krsyw krsyaN krsywN krsyw
Fem ; Fem ;
-- masculine nouns ending at i: e.g Admi:
mkN13 : Str -> Noun ;
mkN13 krsy = let
krsywN = krsy+"yo:n~" ;
krsyw = tk 1 krsywN
in mkNoun krsy krsy krsy
krsy krsywN krsyw
Masc ;
-- feminine nouns end with a, aN, wN -- feminine nouns end with a, aN, wN
mkN04 : Str -> Noun ; mkN04 : Str -> Noun ;
mkN04 n = case last n of { mkN04 n = case last n of {
"a" => let bla = n "a:" => mkNoun n n n
in mkNoun bla bla bla (n+"a:e:n~") (n+"a:o:n~") (n+"a:o:")
(bla+"y^yN") (bla+"w^N") (bla+"w^")
Fem ; Fem ;
_ => let maN = n ; -- ends with aN and wN _ => let maN = n ; -- ends with aN and wN
ma = tk 1 maN ma = tk 1 maN
in mkNoun maN maN maN in mkNoun maN maN maN
(ma+"y^yN") (ma+"w^N") (ma+"w^N") (maN+"a:n~e:n~") (maN+"a:n~o:n~") (maN+"a:n~o:")
Fem Fem
}; };
@@ -112,14 +122,14 @@ oper
mkN05 : Str -> Noun ; mkN05 : Str -> Noun ;
mkN05 gRya = let gRy = (tk 1 gRya) mkN05 gRya = let gRy = (tk 1 gRya)
in mkNoun gRya gRya gRya in mkNoun gRya gRya gRya
(gRya+"N") (gRy+"wN") (gRy+"w") (gRya+"n~") (gRy+"o:n~") (gRy+"o:")
Fem ; Fem ;
-- feminine nouns end with w -- feminine nouns end with w
mkN07 : Str -> Noun ; mkN07 : Str -> Noun ;
mkN07 khshbw = mkNoun khshbw khshbw khshbw mkN07 khshbw = mkNoun khshbw khshbw khshbw
(khshbw + "y^yN") (khshbw + "w^N") (khshbw + "w^") (khshbw + "e:n~") (khshbw + "o:n~") (khshbw + "o:")
Fem ; Fem ;
-- Loan arabic feminine nouns end with t -- Loan arabic feminine nouns end with t
@@ -127,7 +137,7 @@ oper
mkN10 : Str -> Noun ; mkN10 : Str -> Noun ;
mkN10 ndamt = mkNoun ndamt ndamt ndamt mkN10 ndamt = mkNoun ndamt ndamt ndamt
(ndamt+"yN") (ndamt+"wN") (ndamt+"w") (ndamt+"e:m.") (ndamt+"w:m.") (ndamt+"o:")
Fem ; Fem ;
-- Worst case function -- Worst case function
mkN : (_,_,_,_,_,_ : Str) -> Gender -> Noun ; mkN : (_,_,_,_,_,_ : Str) -> Gender -> Noun ;
@@ -143,21 +153,21 @@ oper
mkN08 : Str -> Noun ; mkN08 : Str -> Noun ;
mkN08 ktab = mkNoun ktab ktab ktab mkN08 ktab = mkNoun ktab ktab ktab
(ktab+"yN") (ktab+"wN") (ktab+"w") (ktab+"e:n~") (ktab+"o:n~") (ktab+"o:")
Fem ; Fem ;
-- Loan arabic feminine nouns -- Loan arabic feminine nouns
mkN09 : Str -> Noun ; mkN09 : Str -> Noun ;
mkN09 ahsan = mkNoun ahsan ahsan ahsan mkN09 ahsan = mkNoun ahsan ahsan ahsan
(ahsan+"at") (ahsan+"at") (ahsan+"w") (ahsan+"a:t") (ahsan+"a:t") (ahsan+"o:")
Fem ; Fem ;
-- (variants{ahsan+"at";ahsan+"wN"}) -- (variants{ahsan+"at";ahsan+"wN"})
-- Loan persian maculine nouns end with w -- Loan persian maculine nouns end with w
mkN11 : Str -> Noun ; mkN11 : Str -> Noun ;
mkN11 alw = mkNoun alw alw alw mkN11 alw = mkNoun alw alw alw
alw (alw+"w^N") (alw+"w^") alw (alw+"o:n~") (alw+"o:")
Masc ; Masc ;
@@ -167,17 +177,19 @@ oper
mkN12 bhao = mkNoun (bhao) (bhao) (bhao) mkN12 bhao = mkNoun (bhao) (bhao) (bhao)
(bhao) (bhao) (bhao) (bhao) (bhao) (bhao)
Masc ; Masc ;
----2 Determiners ----2 Determiners
IDeterminer = {s:Gender => Str ; n : Number}; IDeterminer = {s:Gender => Case => Str ; n : Number};
makeDet : Str -> Str -> Str -> Str -> Number -> Determiner = \s1,s2,s3,s4,n -> { makeDet : Str -> Str -> Str -> Str -> Number -> Determiner = \s1,s2,s3,s4,n -> {
s = table { s = table {
Sg => table { Sg => table {
Masc => s1 ; Masc => table {_ => s1} ;
Fem => s2 Fem => table {_ => s2}
} ; } ;
Pl => table { Pl => table {
Masc => s3 ; Masc => table { _ => s3} ;
Fem => s4 Fem => table {_ => s4}
} }
} ; } ;
@@ -186,8 +198,8 @@ oper
makeIDet : Str -> Str -> Number -> IDeterminer = \s1,s2,n -> { makeIDet : Str -> Str -> Number -> IDeterminer = \s1,s2,n -> {
s = table { s = table {
Masc => s1; Masc => table {_ =>s1};
Fem => s2 Fem => table {_ =>s2}
}; };
n = n n = n
}; };
@@ -317,13 +329,14 @@ oper
}; };
----2 Adjectives ----2 Adjectives
-- defined in ResUrd
makeIrregA : Str -> Adjective = \str -> {s = \\_,_,_,_ => str} ;
----3 Verbs ----3 Verbs
CommonVF = {s : VTense => UPerson => Number => Gender => Str} ; CommonVF = {s : VTense => UPerson => Number => Gender => Str} ;
mkVerb : (x1: Str) -> Verb = \inf -> mkVerb : (x1: Str) -> Verb = \inf ->
let root = (tk 2 inf); inf_obl = ((tk 1 inf) + "E"); inf_fem = ((tk 1 inf) + "y") let root = (tk 2 inf); inf_obl = ((tk 1 inf) + "e:"); inf_fem = ((tk 2 inf) + "yi:")
in { s = table { in { s = table {
VF tense person number gender => (mkCmnVF root tense person number gender).s ; VF tense person number gender => (mkCmnVF root tense person number gender).s ;
@@ -343,38 +356,43 @@ oper
mkCmnVF : Str -> VTense -> UPerson -> Number -> Gender -> {s:Str} = mkCmnVF : Str -> VTense -> UPerson -> Number -> Gender -> {s:Str} =
\root,t,p,n,g -> \root,t,p,n,g ->
{s = {s =
let form1 = case (last root) of { let form1 = case (last root) of
"a"|"A"|"w" => root + "w^N" ; {
_ => root + "wN" "a:"|"o:"|"i:" => root + "U:n~";
}; "e:" => (tk 1 root)+ "u:n~";
form2 = case (last root) of { _ => root + "u:n~"
"a"|"A"|"w" => root + "y^N" ;
_ => root + "yN"
}; };
form2 = case (last root) of
{
"a:"|"o:" => root + "E:n~";
"i:" => root + "ye:n~";
"e:" => (tk 1 root)+ "e:n~";
_ => root + "e:n~"
}
in in
case <t,p,n,g> of { case <t,p,n,g> of {
<Subj,Pers1,Sg,_> => form1 ; <Subj,Pers1,Sg,_> => form1 ;
<Subj,Pers1,Pl,_> => form2 ; <Subj,Pers1,Pl,_> => form2 ;
<Subj,_,_,_> => (mkImpert root p n g).s ; <Subj,_,_,_> => (mkImpert root p n g).s ;
<Perf,_,_,_> => case root of { <Perf,_,_,_> => case root of {
"hw" => (mkPastInd root p n g).s ; "ho:" => (mkPastInd root p n g).s ;
"ja" => (mkPastInd "gy" p n g).s ; "ja:" => (mkPastInd "gay" p n g).s ;
"kr" => (mkPastInd "k" p n g).s ; "kr" => (mkPastInd "kiy" p n g).s ;
"dE" => (mkPastInd "d" p n g).s ; -- "dE" => (mkPastInd "d" p n g).s ;
"lE" => (mkPastInd "l" p n g).s ; -- "lE" => (mkPastInd "l" p n g).s ;
_ => (mkPastInd root p n g).s }; _ => (mkPastInd root p n g).s };
<Imperf,Pers2_Familiar,Sg,Masc> => root + "tE"; <Imperf,Pers2_Familiar,Sg,Masc> => root + "te:";
<Imperf,Pers2_Familiar,Sg,Fem> => root + "ty"; --variants{root+"ty" ; root+"tyN"}; <Imperf,Pers2_Familiar,Sg,Fem> => root + "ti:"; --variants{root+"ty" ; root+"tyN"};
<Imperf,Pers2_Familiar,Pl,Masc> => root + "tE"; <Imperf,Pers2_Familiar,Pl,Masc> => root + "te:";
<Imperf,Pers2_Familiar,Pl,Fem> => root+"tyN"; <Imperf,Pers2_Familiar,Pl,Fem> => root+"ti:";
<Imperf,Pers2_Respect,Sg,Masc> => root + "tE"; <Imperf,Pers2_Respect,Sg,Masc> => root + "te:";
<Imperf,Pers2_Respect,Sg,Fem> => root + "ty"; --variants{root+"ty" ; root+"tyN"}; <Imperf,Pers2_Respect,Sg,Fem> => root + "ti:"; --variants{root+"ty" ; root+"tyN"};
<Imperf,Pers2_Respect,Pl,Masc> => root + "tE"; <Imperf,Pers2_Respect,Pl,Masc> => root + "te:";
<Imperf,Pers2_Respect,Pl,Fem> => root+"tyN"; <Imperf,Pers2_Respect,Pl,Fem> => root+"ti:";
<Imperf,_,Sg,Masc> => root+"ta"; <Imperf,_,Sg,Masc> => root+"ta:";
<Imperf,_,Sg,Fem> => root+"ty"; <Imperf,_,Sg,Fem> => root+"ti:";
<Imperf,_,Pl,Masc> => root+"te"; <Imperf,_,Pl,Masc> => root+"te:";
<Imperf,_,Pl,Fem> => root+"tyN" <Imperf,_,Pl,Fem> => root+"ti:"
} }
} ; } ;
@@ -382,20 +400,27 @@ oper
mkPastInd : Str -> UPerson -> Number -> Gender -> {s:Str} = \root,p,n,g -> mkPastInd : Str -> UPerson -> Number -> Gender -> {s:Str} = \root,p,n,g ->
{s = let roo = root ; {s = let roo = root ;
a = case (last root) of { a = case (last root) of {
"a"|"A"|"w"|"k" => "ya" ; "a:"|"o:"|"i:" => "ya:" ;
_ => "a" "e:" => (tk 1 roo) + "iya:" ;
_ => "a:"
} ; } ;
y = case (last root) of { y = case (last root) of {
"a"|"A"|"w" => "y^y" ; "a:"|"o:" => "yi:" ;
_ => "y" "i:" => "" ;
"e:" => (tk 1 roo) + "i:" ;
"iy" => (tk 2 roo) + "i:" ;
_ => "i:"
} ; } ;
e = case (last root) of { e = case (last root) of {
"a"|"A"|"w"|"k" => "y^E" ; "a:"|"o:"|"i:"|"k" => "ye:" ;
_ => "E" "e:" => (tk 1 roo) + "i:" ;
_ => "e:"
} ; } ;
yN = case (last root) of { yN = case (last root) of {
"a"|"A"|"w" => "y^yN" ; "a:"|"o:"|"i:" => "yi:n~" ;
_ => "yN" "iy" => (tk 2 roo) + "i:" ;
"e:" => (tk 1 roo) + "i:n~" ;
_ => "yn~"
} ; } ;
in in
@@ -430,20 +455,19 @@ oper
mkImpert : Str -> UPerson -> Number -> Gender -> {s:Str} = \root,p,n,g -> mkImpert : Str -> UPerson -> Number -> Gender -> {s:Str} = \root,p,n,g ->
{s = let roo = root ; {s = let roo = root ;
w = case (last root) of { w = case (last root) of {
"a"|"A"|"w" => "w^" ; "a:" => "O:" ;
_ => "w" "o:" => "O:" ;
_ => "o:"
} ; } ;
yN = case (last root) of { yN = case (last root) of {
"a"|"A"|"w" => "y^yN" ; "a:"|"o:" => "E:n~" ;
_ => "yN" _ => "E:n~"
} ;
yE = case (last root) of {
"a"|"A"|"w" => "y^yE" ;
_ => "yE"
} ; } ;
e = case (last root) of { e = case (last root) of {
"a"|"A"|"w" => "y^E" ; "a:"|"o:" => "E:" ;
_ => "E" "e:" => "" ;
"i:" => "ye:" ;
_ => "E:"
} in } in
case <p,n,g> of { case <p,n,g> of {
<Pers1,_,_> => ""; --nonExist ; <Pers1,_,_> => ""; --nonExist ;

View File

@@ -5,48 +5,49 @@ concrete StructuralHin of Structural = CatHin **
coding = utf8; coding = utf8;
lin lin
above_Prep = mkPrep "awpr" "awpr" ; above_Prep = mkPrep ["ke: U:par"] ["ke: U:par"] ;
after_Prep = mkPrep ["kE bed"] ["kE bed"] ; after_Prep = mkPrep ["ke: ba:d"] ["ke: ba:d"] ;
all_Predet = ss "tmam" ; all_Predet = ss "tama:m" ;
almost_AdA, almost_AdN = mkAdN "tqryba" ; almost_AdA, almost_AdN = mkAdN "taqari:ban" ;
although_Subj = ss "agrch-" ; although_Subj = ss "Agarci" ;
always_AdV = ss "hmyXh" ; always_AdV = ss "hame:s*a:" ;
and_Conj = sd2 [] "awr" ** {n = Pl} ; and_Conj = sd2 [] "O+r" ** {n = Pl} ;
because_Subj = ss "kywnkh-" ; because_Subj = ss "kX,yo:n~ki" ;
before_Prep = mkPrep "phlE" "phlE" ; before_Prep = mkPrep ["se: pahale:"] ["se: pahale:"] ;
behind_Prep = mkPrep "pych-E" "pych-E" ; behind_Prep = mkPrep ["ke: pi:c'e:"] ["ke: pi:c'e:"] ;
between_Prep = mkPrep "drmyaN" "drmyaN" ; between_Prep = mkPrep ["ke: darmiya:n"] ["ke: darmiya:n"] ;
both7and_DConj = sd2 "dwnwN" "awr" ** {n = Pl} ; both7and_DConj = sd2 "do:no:m." "O+r" ** {n = Pl} ;
but_PConj = ss "lykn" ; but_PConj = ss "le:kin" ;
by8agent_Prep = mkPrep "" "" ; by8agent_Prep = mkPrep "" "" ;
by8means_Prep = mkPrep "" "" ; by8means_Prep = mkPrep "" "" ;
-- can8know_VV,can_VV = mkV "skna" ** { isAux = True} ; can8know_VV,can_VV = mkV "sakana:" ** { isAux = True} ;
during_Prep = mkPrep ["kE drmyaN"] ["kE drmyaN"] ; during_Prep = mkPrep ["ke: darmiya:n"] ["ke: darmiya:n"] ;
either7or_DConj = sd2 "kwy ayk" "ya" ** {n = Sg} ; either7or_DConj = sd2 "ko:I: E:k" "ya:" ** {n = Sg} ;
everybody_NP = MassNP (UseN (ParadigmsHin.mkN "hr kwy" "hr kwy" "hr kwy" "hr kwy" "hr kwy" "hr kwy" Masc )); -- not a good way coz need to include NounHin everybody_NP = MassNP (UseN (ParadigmsHin.mkN "har ko:I:" "har ko:I:" "har ko:I:" "har ko:I:" "har ko:I:" "har ko:I:" Masc ));
-- every_Det = mkDet "hr" Sg; every_Det = mkDet "har" "har" "har" "har" Sg;
everything_NP = MassNP (UseN (ParadigmsHin.mkN "hr cyz" "hr cyz" "hr cyzw" "sb cyzyN" "sb cyzwN" "sb cyzw" Masc )); everything_NP = MassNP (UseN (ParadigmsHin.mkN "har ci:z" "har ci:z" "har ci:zo:n~" "sab ci:ze:n~" "sab ci:zo:n~" "sab ci:zo:n~" Masc ));
everywhere_Adv = mkAdv "hr jgh" ; everywhere_Adv = mkAdv "har jagah" ;
-- few_Det = mkDet "cnd" Pl ; few_Det = mkDet "cam.d" "cam.d" "cam.d" "cam.d" Pl ;
first_Ord = {s = "pehla" ; n = Sg} ; --DEPRECATED first_Ord = {s = "" ; n = Sg} ; --De:PRe:CATe:D
for_Prep = mkPrep "kylyE" "kylyE" ; for_Prep = mkPrep ["ke: liye:"] ["ke: liye:"] ;
from_Prep = mkPrep "sE" "sE" ; from_Prep = mkPrep "se:" "se:" ;
he_Pron = personalPN "wh" "as" "" "as ka" Sg Masc Pers3_Distant ; he_Pron = personalPN "vah" "Us" "" "Us ka:" "Us ki:" "Us ke:" "Us ki:" Sg Masc Pers3_Distant ;
here_Adv = mkAdv "yhaN" ; here_Adv = mkAdv "yaha:n~" ;
here7to_Adv = mkAdv "yhaN pr" ; here7to_Adv = mkAdv ["yaha:n~ par"] ;
here7from_Adv = mkAdv "yhaN sE" ; here7from_Adv = mkAdv ["yaha:n~ se:"] ;
how_IAdv = ss "kysE" ; how_IAdv = ss "ke+se:" ;
how8many_IDet = makeIDet "ktnE" "ktny" Pl ; how8many_IDet = makeIDet "kitane:" "kitani:" Pl ;
if_Subj = ss "agr" ; how8much_IAdv = ss "kitana:" ;
in8front_Prep = mkPrep ["kE samnE"] ["kE samnE"] ; if_Subj = ss "Agar" ;
i_Pron = personalPN "myN" "mjh-" "" "myra" Sg Masc Pers1; in8front_Prep = mkPrep ["ke: sa:mane:"] ["ke: sa:mane:"] ;
in_Prep = mkPrep "meN" "meN" ; i_Pron = personalPN "me+m." "muj'" "" "me:ra:" "me:ri:" "me:re:" "me:ri:" Sg Masc Pers1;
it_Pron = personalPN "yh" "yh" "yh" "as ka" Sg Masc Pers3_Near; in_Prep = mkPrep "me:m." "me:m." ;
less_CAdv = {s = "km" ; p = ""} ; it_Pron = personalPN "yah" "Is" "yah" "Is ka:" "Is ki:" "Us ke:" "Us ki:" Sg Masc Pers3_Near;
-- many_Det = mkDet "bht zyadh" Pl ; less_CAdv = {s = "kam" ; p = ""} ;
more_CAdv = {s = "zyadh-" ; p = "" } ; many_Det = mkDet "bahut" "bahut" "bahut" "bahut" Pl ;
most_Predet = ss "zyadh tr" ; more_CAdv = {s = "zX,ya:da:" ; p = "se:" } ;
--much_Det = mkDet "bht" Pl ; most_Predet = ss "sab se: zX,ya:da:" ;
much_Det = mkDet "bahut" "bahut" "bahut" "bahut" Sg ;
-- must_VV = { -- must_VV = {
-- s = table { -- s = table {
-- VVF VInf => ["have to"] ; -- VVF VInf => ["have to"] ;
@@ -59,71 +60,71 @@ concrete StructuralHin of Structural = CatHin **
-- } ; -- } ;
-- isAux = True -- isAux = True
-- } ; -- } ;
-----b no_Phr = ss "no" ; no_Utt = ss "nahi:m." ;
no_Utt = ss "nhyN" ; on_Prep = mkPrep "par" "par" ;
on_Prep = mkPrep "pr" "pr" ; -- one_Quant = demoPN "" ; -- De:PRe:CATe:D
-- one_Quant = demoPN "ayk" "ayk" "ayk" ; -- DEPRECATED only_Predet = ss "sirX,f" ;
only_Predet = ss "srf" ; or_Conj = sd2 [] "ya:" ** {n = Sg} ;
or_Conj = sd2 [] "ya" ** {n = Sg} ; otherwise_PConj = ss "nahi:m. to:" ;
otherwise_PConj = ss "ya ph-r" ;
part_Prep = mkPrep "" "" ; part_Prep = mkPrep "" "" ;
please_Voc = ss "mhrbani" ; -- please_Voc = ss "" ;
possess_Prep = mkPrep "ka" "ky" ; possess_Prep = mkPrep "ka:" "ki:" ;
quite_Adv = ss "khamosh" ; quite_Adv = ss "ka:fi:" ;
she_Pron = personalPN "wh" "as" "wh" "as ky" Sg Fem Pers3_Distant ; she_Pron = personalPN "vah" "Us" "Us" "Us ka:" "Us ki:" "Us ke:" "Us ki:" Sg Fem Pers3_Distant ; -- chek with prasad about 'Us'
so_AdA = ss "so" ; so_AdA = ss "to:" ;
somebody_NP = MassNP (UseN (ParadigmsHin.mkN "kwy" "kwy" "kwy" "kwy" "kwy" "kwy" Masc )); somebody_NP = MassNP (UseN (ParadigmsHin.mkN "ko:I:" "ko:I:" "ko:I:" "ko:I:" "ko:I:" "ko:I:" Masc ));
--someSg_Det = mkDet "kch-" Sg ; someSg_Det = mkDet "kuc'" "kuc'" "kuc'" "kuc'" Sg ;
--somePl_Det = mkDet "kch-" Pl ; somePl_Det = mkDet "kuc'" "kuc'" "kuc'" "kuc'" Pl ;
something_NP = MassNP (UseN (ParadigmsHin.mkN "kwy cyz" "kwy cyz" "kwy cyz" "kh- cyzyN" "kh- cyzwN" "kh- cyzw" Masc )); something_NP = MassNP (UseN (ParadigmsHin.mkN ["ko:I: ci:z"] ["ko:I: ci:z"] ["ko:I: ci:z"] ["ko:I: ci:z"] ["ko:I: ci:z"] ["ko:I: ci:z"] Masc ));
somewhere_Adv = mkAdv "khin pr" ; somewhere_Adv = mkAdv ["kahi:m."] ;
that_Quant = demoPN "wh" "as" "an" ; that_Quant = demoPN "vah" "Us" "Un" ;
that_Subj = ss "kh"; that_Subj = ss "ki";
there_Adv = mkAdv "whaN" ; there_Adv = mkAdv "vaha:n~" ;
there7to_Adv = mkAdv "whaN pr" ; there7to_Adv = mkAdv ["vaha:n~ par"] ;
there7from_Adv = mkAdv ["whaN sE"] ; there7from_Adv = mkAdv ["vaha:n~ se:"] ;
therefore_PConj = ss "as lyE" ; therefore_PConj = ss "Is liye:" ;
they_Pron = personalPN "wh" "wh" "wh" "an ka" Pl Masc Pers3_Distant ; ---- they_Pron = personalPN "vah" "vah" "vah" "Un ka:" "Un ki:" "Un ke:" "Un ki:" Pl Masc Pers3_Distant ; ----
this_Quant = demoPN "yh" "as" "an"; this_Quant = demoPN "yah" "Is" "In";
through_Prep = mkPrep ["myN sE"] ["myN sE"] ; through_Prep = mkPrep ["me:m. se:"] ["me:m. se:"] ;
too_AdA = ss "bht" ; too_AdA = ss "bahut" ;
to_Prep = mkPrep "kw" "kw" ; to_Prep = mkPrep "ko:" "ko:" ; -- ** {lock_Prep = <>};
under_Prep = mkPrep "nycE" "nycE" ; under_Prep = mkPrep ["ke: ni:ce:"] ["ke: ni:ce:"] ; -- ** {lock_Prep = <>};
very_AdA = ss "bht" ; very_AdA = ss "bahut" ;
-- want_VV = mkV "cahna" ** { isAux = False} ; want_VV = mkV "ca:hna:" ** { isAux = False} ;
we_Pron = personalPN "hm" "hm" "hm" "hmara" Pl Masc Pers1 ; we_Pron = personalPN "ham" "ham" "ham" "hama:ra:" "hama:ri:" "hama:re:" "hama:ri:" Pl Masc Pers1 ;
whatSg_IP = mkIP "kya" "kis" "kis" Sg Masc ; whatSg_IP = mkIP "kX,ya:" "kX,ya:" "kX,ya:" Sg Masc ; -- confirm
whatPl_IP = mkIP "kya" "kin" "kin" Pl Masc ; whatPl_IP = mkIP "kX,ya:" "kX,ya:" "kX,ya:" Pl Masc ;
when_IAdv = ss "kb" ; when_IAdv = ss "kab" ;
when_Subj = ss "kb" ; when_Subj = ss "kab" ;
where_IAdv = ss "khaN" ; where_IAdv = ss "kaha:n~" ;
which_IQuant = {s = \\_ => "kwn sy"} ; which_IQuant = mkIQuant ["ko+n sa:"] ["ko+n se:"] "" ["ko+n si:"] ["ko+n si:"] ""
-- whichPl_IDet = makeDet "kwn sa" "kwn sy" "kwn sE" "kwn sy" ; ["ko+n se:"] ["ko+n se:"] "" ["ko+n si:"] ["ko+n si:"] "" ; -- need to put right forms Prasad
-- whichSg_IDet = makeDet "kwn sa" "kwn sy" "kwn sE" "kwn sy" ; -- whichPl_IDet = makeDet "" ;
whoSg_IP = mkIP "kwn" "kis" "kis" Sg Masc ; -- whichSg_IDet = makeDet "";
whoPl_IP = mkIP "kwn" "kn" "knhwN" Pl Masc ; whoSg_IP = mkIP "ko+n" "kis" "kis" Sg Masc ;
why_IAdv = ss "kywN" ; whoPl_IP = mkIP "ko+n" "kin" "kinho:m." Pl Masc ;
without_Prep = mkPrep ["kE bGyr"] ["kE bGyr"] ; why_IAdv = ss "kX,yo:m." ;
with_Prep = mkPrep ["kE sath-"] ["kE sath-"] ; -- without_Prep = mkPrep ;
-- yes_Phr = ss "haN" ; with_Prep = mkPrep ["ke: sa:t'"] ["ke: sa:t'"] ;
yes_Utt = ss "haN" ; -- yes_Phr = ss "???" ;
youSg_Pron = personalPN "tm" "tm" "tm" "tmh-ara" Sg Masc Pers2_Casual ; yes_Utt = ss "ha:n~" ;
youPl_Pron = personalPN "tm" "tm" "tm" "tmh-ara" Pl Masc Pers2_Casual ; youSg_Pron = personalPN "tu:" "tum" "tum" "tumha:ra:" "tumha:ri:" "tumha:re:" "tumha:ri:" Sg Masc Pers2_Casual ;
youPol_Pron = personalPN "Ap" "AP" "AP" "Ap ka" Sg Masc Pers2_Respect ; youPl_Pron = personalPN "tum" "tum" "tum" "tumha:ra:" "tumha:ri:" "tumha:re:" "tumha:ri:" Pl Masc Pers2_Casual ;
no_Quant = demoPN " kwy nhyN" "kwy nhyN" "kwy nhyN" ; youPol_Pron = personalPN "A:p" "A:p" "A:p" "A:p ka:" "A:p ki:" "A:p ke:" "A:p ki:" Sg Masc Pers2_Respect ;
not_Predet = {s="nhyN"} ; -- no_Quant = demoPN "ko:I: nahi:m." ;
if_then_Conj = sd2 "agr" "tw" ** {n = Sg} ; not_Predet = {s="nahi:m."} ;
at_least_AdN = mkAdN ["km az km"] ; -- if_then_Conj = sd2 "agar to:" ** {n = Sg} ;
at_most_AdN = mkAdN ["zyadh sE zyadh"]; at_least_AdN = mkAdN ["kam se: kam"] ;
nothing_NP = MassNP (UseN (ParadigmsHin.mkN "kwy cyz nhyN" "kwy cyz nhyN" "kwy cyz nhyN" "kwy cyz nhyN" "kwy cyz nhyN" "kwy cyz nhyN" Masc )); at_most_AdN = mkAdN ["zX,ya:da: se: zX,ya:da:"];
except_Prep = mkPrep "swaE" "swaE" ; -- nothing_NP = MassNP (UseN (ParadigmsHin.mkN "kuc' nahi:m." Masc ));
nobody_NP = MassNP (UseN (ParadigmsHin.mkN "kwy nhyN" "kwy nhyN" "kwy nhyN" "kwy nhyN" "kwy nhyN" "kwy nhyN" Masc )); except_Prep = mkPrep "ke: siva:y" "ke: siva:y";
-- nobody_NP = MassNP (UseN (ParadigmsHin.mkN "ko:I: nahi:m." Masc ));
as_CAdv = {s = "etna" ; p = "jtna"} ; as_CAdv = {s = "itna:" ; p = "jitna:"} ;
have_V2 = mkV2 (mkV "rakh-na") "" ; -- have_V2 = mkV2 "";
language_title_Utt = ss "ardw" ; language_title_Utt = ss "hinX,di:" ;
} }

View File

@@ -8,4 +8,6 @@ rf -file=src/IdiomHin.gf | ps -env=quotes -to_devanagari | wf -file=IdiomHin.gf
rf -file=src/LexiconHin.gf | ps -env=quotes -to_devanagari | wf -file=LexiconHin.gf rf -file=src/LexiconHin.gf | ps -env=quotes -to_devanagari | wf -file=LexiconHin.gf
rf -file=src/MorphoHin.gf | ps -env=quotes -to_devanagari | wf -file=MorphoHin.gf rf -file=src/MorphoHin.gf | ps -env=quotes -to_devanagari | wf -file=MorphoHin.gf
rf -file=src/StructuralHin.gf | ps -env=quotes -to_devanagari | wf -file=StructuralHin.gf rf -file=src/StructuralHin.gf | ps -env=quotes -to_devanagari | wf -file=StructuralHin.gf
rf -file=src/StringsHin.gf | ps -env=quotes -to_devanagari | wf -file=StringsHin.gf
rf -file=src/NumeralHin.gf | ps -env=quotes -to_devanagari | wf -file=NumeralHin.gf

View File

@@ -1,4 +1,4 @@
incomplete concrete AdjectiveHindustani of Adjective = CatHindustani ** open CommonHindustani,ResHindustani, StringsHindustani, Prelude in { incomplete concrete AdjectiveHindustani of Adjective = CatHindustani ** open CommonHindustani,ResHindustani, Prelude in {
lin lin
@@ -20,7 +20,9 @@ incomplete concrete AdjectiveHindustani of Adjective = CatHindustani ** open Com
} ; } ;
SentAP ap sc = { SentAP ap sc = {
s = \\n,g,c,d => ap.s ! n ! g ! c ! d ++ sc.s ; s = \\n,g,c,d => case sc.fromVP of {
True => sc.s ++ kw ++ ap.s ! n ! g ! c ! d ;
False => ap.s ! n ! g ! c ! d ++ sc.s } ;
} ; } ;
AdAP ada ap = { AdAP ada ap = {

View File

@@ -1,4 +1,4 @@
incomplete concrete AdverbHindustani of Adverb = CatHindustani ** open CommonHindustani, ResHindustani, StringsHindustani, Prelude in { incomplete concrete AdverbHindustani of Adverb = CatHindustani ** open CommonHindustani, ResHindustani, Prelude in {
lin lin
PositAdvAdj a = {s = \\g => a.s ! Sg ! g ! Obl ! Posit} ; PositAdvAdj a = {s = \\g => a.s ! Sg ! g ! Obl ! Posit} ;

View File

@@ -1,6 +1,6 @@
--concrete CatUrd of Cat = CommonX - [Adv,AdN] ** open ResUrd, Prelude in { --concrete CatUrd of Cat = CommonX - [Adv,AdN] ** open ResUrd, Prelude in {
incomplete concrete CatHindustani of Cat = incomplete concrete CatHindustani of Cat =
CommonX - [Adv,AdN]** open ResHindustani, Prelude, CommonHindustani, (R = ParamX) in { CommonX - [Adv,AdN,SC]** open ResHindustani, Prelude, CommonHindustani, (R = ParamX) in {
flags optimize=all_subs ; flags optimize=all_subs ;
@@ -11,6 +11,7 @@ incomplete concrete CatHindustani of Cat =
QS = {s : QForm => Str} ; QS = {s : QForm => Str} ;
RS = {s : Agr => Str ; c : Case} ; -- c for it clefts RS = {s : Agr => Str ; c : Case} ; -- c for it clefts
SSlash = {s : Str ; c2 : ResHindustani.Compl} ; SSlash = {s : Str ; c2 : ResHindustani.Compl} ;
SC = {s : Str ; fromVP : Bool} ;
---- Sentence ---- Sentence

View File

@@ -4,8 +4,8 @@
-- --
-- This module contains operations that are needed to make the -- This module contains operations that are needed to make the
-- resource syntax work. -- resource syntax work.
resource CommonHindustani = ParamX ** open Prelude,Predef in { resource CommonHindustani = ParamX ** open Prelude, Predef in {
--interface CommonHindustani = ParamX ** open Prelude,Predef,StringsHindustani1 in {
flags coding = utf8 ; flags coding = utf8 ;
oper oper
@@ -73,103 +73,6 @@ resource CommonHindustani = ParamX ** open Prelude,Predef in {
oper oper
copula : CTense -> Number -> UPerson -> Gender -> Str = \t,n,p,g ->
case <t,n,p,g> of {
<CPresent,Sg,Pers1,_ > => "hwN" ;
<CPresent,Sg,Pers2_Casual,_ > => "hE" ;
<CPresent,Sg,Pers2_Familiar,_ > => "hw" ;
<CPresent,Sg,Pers2_Respect,_ > => "hyN" ;
<CPresent,Sg,Pers3_Near,_ > => "hE" ;
<CPresent,Sg,Pers3_Distant,_ > => "hE" ;
<CPresent,Pl,Pers1,_ > => "hyN" ;
<CPresent,Pl,Pers2_Casual,_ > => "hw" ;
<CPresent,Pl,Pers2_Familiar,_ > => "hw" ;
<CPresent,Pl,Pers2_Respect,_ > => "hyN" ;
<CPresent,Pl,Pers3_Near,_ > => "hyN" ;
<CPresent,Pl,Pers3_Distant,_ > => "hyN" ;
<CPast,Sg,Pers1,Masc > => "th'a" ;
<CPast,Sg,Pers1,Fem > => "th'y" ;
<CPast,Sg,Pers2_Casual,Masc > => "th'a" ;
<CPast,Sg,Pers2_Casual,Fem > => "th'y" ;
<CPast,Sg,Pers2_Familiar,Masc > => "th-a" ;
<CPast,Sg,Pers2_Familiar,Fem > => "th'y" ;
<CPast,Sg,Pers2_Respect,Masc > => "th'E" ;
<CPast,Sg,Pers2_Respect,Fem > => "th'yN" ;
<CPast,Sg,Pers3_Near,Masc > => "th-a" ;
<CPast,Sg,Pers3_Near,Fem > => "th'y" ;
<CPast,Sg,Pers3_Distant,Masc > => "th-a" ;
<CPast,Sg,Pers3_Distant,Fem > => "th'y" ;
<CPast,Pl,Pers1,Masc > => "th'E" ;
<CPast,Pl,Pers1,Fem > => "th'yN" ;
<CPast,Pl,Pers2_Casual,Masc > => "th'E" ;
<CPast,Pl,Pers2_Casual,Fem > => "th'yN" ;
<CPast,Pl,Pers2_Familiar,Masc > => "th'E" ;
<CPast,Pl,Pers2_Familiar,Fem > => "th'yN" ;
<CPast,Pl,Pers2_Respect,Masc > => "th'E" ;
<CPast,Pl,Pers2_Respect,Fem > => "th'yN" ;
<CPast,Pl,Pers3_Near,Masc > => "th'E" ;
<CPast,Pl,Pers3_Near,Fem > => "th'yN" ;
<CPast,Pl,Pers3_Distant,Masc > => "th'E" ;
<CPast,Pl,Pers3_Distant,Fem > => "th'yN" ;
<CFuture,Sg,Pers1,Masc > => "ga" ;
<CFuture,Sg,Pers1,Fem > => "gy" ;
<CFuture,Sg,Pers2_Casual,Masc > => "ga" ;
<CFuture,Sg,Pers2_Casual,Fem > => "gy" ;
<CFuture,Sg,Pers2_Familiar,Masc > => "gE" ;
<CFuture,Sg,Pers2_Familiar,Fem > => "gy" ;
<CFuture,Sg,Pers2_Respect,Masc > => "gE" ;
<CFuture,Sg,Pers2_Respect,Fem > => "gy" ;
<CFuture,Sg,Pers3_Near,Masc > => "ga" ;
<CFuture,Sg,Pers3_Near,Fem > => "gy" ;
<CFuture,Sg,Pers3_Distant,Masc > => "ga" ;
<CFuture,Sg,Pers3_Distant,Fem > => "gy" ;
<CFuture,Pl,Pers1,Masc > => "gE" ;
<CFuture,Pl,Pers1,Fem > => "gy" ;
<CFuture,Pl,Pers2_Casual,Masc > => "gE" ;
<CFuture,Pl,Pers2_Casual,Fem > => "gy" ;
<CFuture,Pl,Pers2_Familiar,Masc > => "gE" ;
<CFuture,Pl,Pers2_Familiar,Fem > => "gy" ;
<CFuture,Pl,Pers2_Respect,Masc > => "gE" ;
<CFuture,Pl,Pers2_Respect,Fem > => "gy" ;
<CFuture,Pl,Pers3_Near,Masc > => "gE" ;
<CFuture,Pl,Pers3_Near,Fem > => "gE" ;
<CFuture,Pl,Pers3_Distant,Masc > => "gE" ;
<CFuture,Pl,Pers3_Distant,Fem > => "gy"
} ;
raha : Gender -> Number -> Str = \g,n ->
(regAdjective "rha").s ! n ! g ! Dir ! Posit ;
cka : Gender -> Number -> Str = \g,n ->
(regAdjective "cka").s ! n ! g ! Dir ! Posit ;
hw : UPerson -> Number -> Str = \pp,n ->
case <pp,n> of {
<Pers1,_> => "hwN";
<_,Pl> => "hwN";
<_,_> => "hw"
};
-----------------------------------------------
-- Hindustani Adjectives
-----------------------------------------------
Adjective = { s: Number => Gender => Case => Degree => Str };
regAdjective : Str -> Adjective;
regAdjective x = case x of {
acch + ("a"|"aN") => mkAdjective x ("bht" ++ x) ("sb sE" ++ x) (acch + "E") ("bht" ++ acch + "E") ("sb sE" ++ acch + "E") (acch + "E") ("bht" ++ acch + "E") ("sb sE" ++ acch + "E")
(acch + "y") ("bht" ++ acch + "y") ("sb sE" ++ acch + "y") (acch + "y") ("bht" ++ acch + "y") ("sb sE" ++ acch + "y") (acch + "y") ("bht" ++ acch + "y") ("sb sE" ++ acch + "y")
(acch +"E") ("bht" ++ acch + "E") ("sb sE" ++ acch + "E") (acch + "E") ("bht" ++ acch + "E") ("sb sE" ++ acch + "E") (acch + "E") ("bht" ++ acch + "E") ("sb sE" ++ acch + "E")
(acch + "y") ("bht" ++ acch + "y") ("sb sE" ++ acch + "y") (acch + "y") ("bht" ++ acch + "y") ("sb sE" ++ acch + "y") (acch + "y") ("bht" ++ acch + "y") ("sb sE" ++ acch + "y");
_ => mkAdjective x ("bht" ++ x) ("sb sE" ++ x) x ("bht" ++ x) ("sb sE" ++ x) x ("bht" ++ x) ("sb sE" ++ x)
x ("bht" ++ x) ("sb sE" ++ x) x ("bht" ++ x) ("sb sE" ++ x) x ("bht" ++ x) ("sb sE" ++ x)
x ("bht" ++ x) ("sb sE" ++ x) x ("bht" ++ x) ("sb sE" ++ x) x ("bht" ++ x) ("sb sE" ++ x)
x ("bht" ++ x) ("sb sE" ++ x) x ("bht" ++ x) ("sb sE" ++ x) x ("bht" ++ x) ("sb sE" ++ x)
};
mkAdjective : (x1,x2,x3,x4,x5,x6,x7,x8,x9,x10,x11,x12,x13,x14,x15,x16,x17,x18,x19,x20,x21,x22,x23,x24,x25,x26,x27,x28,x29,x30,x31,x32,x33,x34,x35,x36:Str) -> Adjective = mkAdjective : (x1,x2,x3,x4,x5,x6,x7,x8,x9,x10,x11,x12,x13,x14,x15,x16,x17,x18,x19,x20,x21,x22,x23,x24,x25,x26,x27,x28,x29,x30,x31,x32,x33,x34,x35,x36:Str) -> Adjective =
\y1,y2,y3,y4,y5,y6,y7,y8,y9,y10,y11,y12,y13,y14,y15,y16,y17,y18,y19,y20,y21,y22,y23,y24,y25,y26,y27,y28,y29,y30,y31,y32,y33,y34,y35,y36 -> { \y1,y2,y3,y4,y5,y6,y7,y8,y9,y10,y11,y12,y13,y14,y15,y16,y17,y18,y19,y20,y21,y22,y23,y24,y25,y26,y27,y28,y29,y30,y31,y32,y33,y34,y35,y36 -> {
@@ -249,34 +152,10 @@ resource CommonHindustani = ParamX ** open Prelude,Predef in {
} }
}; };
compoundAdj : Str -> Str -> Adjective = \s1,s2 -> mkCompoundAdj (regAdjective s1) (regAdjective s2) ; Adjective = { s: Number => Gender => Case => Degree => Str };
mkCompoundAdj : Adjective -> Adjective -> Adjective ;
mkCompoundAdj adj1 adj2 = {s = \\n,g,c,d => adj1.s ! n ! g ! c ! d ++ adj2.s ! n ! g ! c ! d} ;
Verb : Type = {s : VerbForm => Str} ; Verb : Type = {s : VerbForm => Str} ;
predV : Verb -> VPH ;
predV v = {
s = \\vh =>
case vh of {
VPTense VPPres (Ag g n p) => {fin = copula CPresent n p g ; inf = v.s ! VF Imperf p n g } ;
VPTense VPPast (Ag g n p) => {fin = [] ; inf =v.s ! VF Perf p n g} ;
VPTense VPFutr (Ag g n p) => {fin = copula CFuture n p g ; inf = v.s ! VF Subj p n g } ;
VPTense VPPerf (Ag g n p) => { fin = [] ; inf = v.s ! Root ++ cka g n } ;
VPStem => {fin = [] ; inf = v.s ! Root};
VPInf => {fin = v.s ! Inf_Obl ; inf = v.s ! Root}; -- for V2V like sonE ky altja krna , check if it is being used anywhere else
VPImp => {fin = v.s ! VF Subj Pers3_Near Pl Masc ; inf = v.s ! Root};
_ => {fin = [] ; inf = v.s ! Root}
};
obj = {s = [] ; a = defaultAgr} ;
subj = VIntrans ;
inf = v.s ! Inf;
ad = [];
embComp = [];
prog = False ;
comp = \\_ => []
} ;
defaultAgr : Agr = agrP3 Masc Sg ; defaultAgr : Agr = agrP3 Masc Sg ;
agrP3 : Gender -> Number -> Agr = \g,n -> Ag g n Pers3_Distant ; agrP3 : Gender -> Number -> Agr = \g,n -> Ag g n Pers3_Distant ;
toAgr : Number -> UPerson -> Gender -> Agr = \n,p,g -> toAgr : Number -> UPerson -> Gender -> Agr = \n,p,g ->
@@ -300,8 +179,9 @@ resource CommonHindustani = ParamX ** open Prelude,Predef in {
giveGender : Agr -> Gender =\a -> case a of { giveGender : Agr -> Gender =\a -> case a of {
Ag g _ _ => g Ag g _ _ => g
}; };
insertSubj : UPerson -> Str -> Str = \p,s ->
case p of { Pers1 => s ++ "wN" ; _ => s ++ "E"}; -- insertSubj : UPerson -> Str -> Str = \p,s ->
-- case p of { Pers1 => s ++ "wN" ; _ => s ++ "E"};
mkOrd : Str -> Str = mkOrd : Str -> Str =
\s -> case s of { \s -> case s of {
@@ -312,5 +192,6 @@ resource CommonHindustani = ParamX ** open Prelude,Predef in {
"ch'" => "ch'Ta"; "ch'" => "ch'Ta";
_ => s ++ "waN" _ => s ++ "waN"
}; };
} }

View File

@@ -1,8 +1,35 @@
interface DiffHindustani = open CommonHindustani, Prelude in { interface DiffHindustani = open Prelude in {
oper oper
mkClause : NP -> VPH -> Clause ; mkClause : NP -> VPH -> Clause ;
mkSClause : Str -> Agr -> VPH -> Clause ; mkSClause : Str -> Agr -> VPH -> Clause ;
np2pronCase : (Case => Str) -> NPCase -> Agr -> Str ; np2pronCase : (Case => Str) -> NPCase -> Agr -> Str ;
conjThat : Str ; -- = "kh" ;
insertSubj : UPerson -> Str -> Str ;
kwd : Str ;
ky : Str ;
agr : Str ;
awr : Str ;
jn : Str ;
js : Str ;
jw : Str ;
kw : Str ;
mt : Str ;
nE : Str ;
nh : Str ;
sE : Str ;
waN : Str ;
comma : Str ;
indfArt : Str ;
nE : Str ;
hE : Str ;
copula : CTense -> Number -> UPerson -> Gender -> Str ;
raha : Gender -> Number -> Str ;
cka : Gender -> Number -> Str ;
hw : UPerson -> Number -> Str ;
hwa : Agr -> Str ;
regAdjective : Str -> Adjective ;
} }

View File

@@ -1,6 +1,6 @@
--concrete NounUrd of Noun = CatUrd ** open ResUrd, Prelude in { --concrete NounUrd of Noun = CatUrd ** open ResUrd, Prelude in {
incomplete concrete NounHindustani of Noun = incomplete concrete NounHindustani of Noun =
CatHindustani ** open CommonHindustani, ResHindustani, StringsHindustani, Prelude in { CatHindustani ** open CommonHindustani, ResHindustani, Prelude in {
flags optimize=all_subs ; flags optimize=all_subs ;
@@ -19,7 +19,7 @@ incomplete concrete NounHindustani of Noun =
} ; } ;
PPartNP np v2 = { PPartNP np v2 = {
s = \\c => v2.s ! VF Perf (fromAgr np.a).p (fromAgr np.a).n (fromAgr np.a).g ++ np.s ! c ; s = \\c => v2.s ! VF Perf (fromAgr np.a).p (fromAgr np.a).n (fromAgr np.a).g ++ hwa np.a ++ np.s ! c ;
a = np.a a = np.a
} ; } ;
@@ -133,7 +133,11 @@ incomplete concrete NounHindustani of Noun =
-- AdvCN cn ad = {s = \\n,c => cn.s ! n ! c ++ ad.s ; g = cn.g} ; -- changed during WebAlt adver comes before noun like phaRy pr gh-r (house on the hill) -- AdvCN cn ad = {s = \\n,c => cn.s ! n ! c ++ ad.s ; g = cn.g} ; -- changed during WebAlt adver comes before noun like phaRy pr gh-r (house on the hill)
AdvCN cn ad = {s = \\n,c => ad.s ! cn.g ++ cn.s ! n ! c ; g = cn.g} ; AdvCN cn ad = {s = \\n,c => ad.s ! cn.g ++ cn.s ! n ! c ; g = cn.g} ;
SentCN cn sc = {s = \\n,c => cn.s ! n ! c ++ sc.s ; g = cn.g} ; SentCN cn sc = {s = \\n,c => case sc.fromVP of {
True => sc.s ++ ky ++ cn.s ! n ! c ;
False => cn.s ! n ! c ++ sc.s } ;
g = cn.g ;
} ;
ApposCN cn np = {s = \\n,c => cn.s ! n ! Dir ++ np.s ! NPC c ; g = cn.g} ; ApposCN cn np = {s = \\n,c => cn.s ! n ! Dir ++ np.s ! NPC c ; g = cn.g} ;

View File

@@ -1,6 +1,6 @@
--concrete QuestionUrd of Question = CatUrd ** open ResUrd, StringsHindustani, Prelude in { --concrete QuestionUrd of Question = CatUrd ** open ResUrd, StringsHindustani, Prelude in {
incomplete concrete QuestionHindustani of Question = incomplete concrete QuestionHindustani of Question =
CatHindustani ** open CommonHindustani, ResHindustani, StringsHindustani, Prelude in { CatHindustani ** open CommonHindustani, ResHindustani, Prelude in {
flags optimize=all_subs ; flags optimize=all_subs ;
coding = utf8; coding = utf8;
@@ -24,8 +24,11 @@ incomplete concrete QuestionHindustani of Question =
} }
}; };
QuestSlash ip slash = QuestSlash ip slash =
let ip1 = ip.s ! Dir; let
ip2 = ip.s ! Obl ++ nE -- ip1 = ip.s ! Dir;
-- ip2 = ip.s ! Obl ++ nE
ip1 = ip.s ! Obl ++ kw;
ip2 = ip.s ! Obl ++ kw
in { in {
s = \\t,p,o => case t of { s = \\t,p,o => case t of {
VPImpPast => ip2 ++ slash.s ! t ! p ! ODir; VPImpPast => ip2 ++ slash.s ! t ! p ! ODir;

View File

@@ -1,6 +1,6 @@
--concrete RelativeUrd of Relative = CatUrd ** open ResUrd, StringsHindustani in { --concrete RelativeUrd of Relative = CatUrd ** open ResUrd, StringsHindustani in {
incomplete concrete RelativeHindustani of Relative = incomplete concrete RelativeHindustani of Relative =
CatHindustani ** open CommonHindustani, ResHindustani, StringsHindustani, Prelude in { CatHindustani ** open CommonHindustani, ResHindustani, Prelude in {
flags optimize=all_subs ; flags optimize=all_subs ;
coding = utf8; coding = utf8;
@@ -11,7 +11,7 @@ incomplete concrete RelativeHindustani of Relative =
s = \\t,p,o,agr => case <t,giveNumber agr> of { s = \\t,p,o,agr => case <t,giveNumber agr> of {
<VPImpPast,Sg> => js ++ cl.s ! t ! p ! o ; <VPImpPast,Sg> => js ++ cl.s ! t ! p ! o ;
<VPImpPast,Pl> => jn ++ cl.s ! t ! p ! o ; <VPImpPast,Pl> => jn ++ cl.s ! t ! p ! o ;
<_,_> => "jw" ++ cl.s ! t ! p ! o <_,_> => jw ++ cl.s ! t ! p ! o
}; };
c = Dir c = Dir
} ; } ;

View File

@@ -50,7 +50,7 @@ param
eq : Str -> Str -> Bool = \s1,s2-> (pbool2bool (eqStr s1 s2)) ; eq : Str -> Str -> Bool = \s1,s2-> (pbool2bool (eqStr s1 s2)) ;
RefPron : Str; RefPron : Str;
RefPron = "Kwd"; RefPron = kwd ;
---------------------------------------------------------- ----------------------------------------------------------
-- Grammar part -- Grammar part
@@ -60,47 +60,23 @@ param
toNP : ( Case => Str) -> NPCase -> Str = \pn, npc -> case npc of { toNP : ( Case => Str) -> NPCase -> Str = \pn, npc -> case npc of {
NPC c => pn ! c ; NPC c => pn ! c ;
NPObj => pn ! Dir ; NPObj => pn ! Dir ;
NPErg => pn ! Obl ++ "nE" NPErg => pn ! Obl ++ nE
} ; } ;
detcn2NP : (Determiner) -> Noun -> NPCase -> Number -> Str = \dt,cn,npc,nn -> case npc of { detcn2NP : (Determiner) -> Noun -> NPCase -> Number -> Str = \dt,cn,npc,nn -> case npc of {
-- NPC c => dt.s ! Sg ! Masc ++ cn.s ! nn ! c ; --changed while phrasebook e.g tyry beti where gender of determiner 'tyry' should be dependent on gender of common noum e.g 'beti' -- NPC c => dt.s ! Sg ! Masc ++ cn.s ! nn ! c ; --changed while phrasebook e.g tyry beti where gender of determiner 'tyry' should be dependent on gender of common noum e.g 'beti'
NPC c => dt.s ! nn ! cn.g ! c ++ cn.s ! nn ! c ; NPC c => dt.s ! nn ! cn.g ! c ++ cn.s ! nn ! c ;
NPObj => dt.s ! nn ! cn.g ! Obl ++ cn.s ! nn ! Dir ; NPObj => dt.s ! nn ! cn.g ! Obl ++ cn.s ! nn ! Dir ;
NPErg => dt.s ! nn ! cn.g ! Obl ++ cn.s ! nn ! Obl ++ "nE" NPErg => dt.s ! nn ! cn.g ! Obl ++ cn.s ! nn ! Obl ++ nE
} ; } ;
det2NP : (Determiner) -> NPCase -> Str = \dt,npc -> case npc of { det2NP : (Determiner) -> NPCase -> Str = \dt,npc -> case npc of {
NPC c => dt.s ! Sg ! Masc ! c ; NPC c => dt.s ! Sg ! Masc ! c ;
NPObj => dt.s ! Sg ! Masc ! Dir ; NPObj => dt.s ! Sg ! Masc ! Dir ;
NPErg => dt.s ! Sg ! Masc ! Obl ++ "nE" NPErg => dt.s ! Sg ! Masc ! Obl ++ nE
} ; } ;
------------------------------------------ ------------------------------------------
-- Agreement transformations -- Agreement transformations
----------------------------------------- -----------------------------------------
{- toAgr : Number -> UPerson -> Gender -> Agr = \n,p,g ->
Ag g n p;
fromAgr : Agr -> {n : Number ; p : UPerson ; g : Gender} = \a -> case a of {
Ag g n p => {n = n ; p = p ; g = g}
} ;
conjAgr : Agr -> Agr -> Agr = \a0,b0 ->
let a = fromAgr a0 ; b = fromAgr b0
in
toAgr
(conjNumber a.n b.n)
b.p a.g;
giveNumber : Agr -> Number =\a -> case a of {
Ag _ n _ => n
};
giveGender : Agr -> Gender =\a -> case a of {
Ag g _ _ => g
};
-}
-- defaultAgr : Agr = agrP3 Masc Sg ;
-- agrP3 : Gender -> Number -> Agr = \g,n -> Ag g n Pers3_Distant ;
personalAgr : Agr = agrP1 Masc Sg ; personalAgr : Agr = agrP1 Masc Sg ;
agrP1 : Gender -> Number -> Agr = \g,n -> Ag g n Pers1 ; agrP1 : Gender -> Number -> Agr = \g,n -> Ag g n Pers1 ;
@@ -121,6 +97,7 @@ param
objVType : VType -> NPCase = \vt -> case vt of { objVType : VType -> NPCase = \vt -> case vt of {
VTrans => NPObj ; VTrans => NPObj ;
VTransPost => NPC Dir ;
_ => NPC Obl _ => NPC Obl
} ; } ;
@@ -131,13 +108,27 @@ param
predVc : (Verb ** {c2,c1 : Str}) -> VPHSlash = \verb -> predVc : (Verb ** {c2,c1 : Str}) -> VPHSlash = \verb ->
predV verb ** {c2 = {s = verb.c1 ; c = VTrans} } ; predV verb ** {c2 = {s = verb.c1 ; c = VTrans} } ;
{- predV : Verb -> VPH ;
------------------------- predV v = {
-- added for cauitives s = \\vh =>
predVcc : (Verb **{c2:Compl}) -> VPHSlash = \verb -> case vh of {
predV verb ** {c2 = {s = "" ; c = VTrans} } ; VPTense VPPres (Ag g n p) => {fin = copula CPresent n p g ; inf = v.s ! VF Imperf p n g } ;
------------------------ VPTense VPPast (Ag g n p) => {fin = [] ; inf =v.s ! VF Perf p n g} ;
-} VPTense VPFutr (Ag g n p) => {fin = copula CFuture n p g ; inf = v.s ! VF Subj p n g } ;
VPTense VPPerf (Ag g n p) => { fin = [] ; inf = v.s ! Root ++ cka g n } ;
VPStem => {fin = [] ; inf = v.s ! Root};
VPInf => {fin = v.s ! Inf_Obl ; inf = v.s ! Root}; -- for V2V like sonE ky altja krna , check if it is being used anywhere else
VPImp => {fin = v.s ! VF Subj Pers3_Near Pl Masc ; inf = v.s ! Root};
_ => {fin = [] ; inf = v.s ! Root}
};
obj = {s = [] ; a = defaultAgr} ;
subj = VIntrans ;
inf = v.s ! Inf;
ad = [];
embComp = [];
prog = False ;
comp = \\_ => []
} ;
predAux : Aux -> VPH = \verb -> { predAux : Aux -> VPH = \verb -> {
s = \\vh => s = \\vh =>
let let
@@ -191,107 +182,6 @@ param
comp = verb.comp comp = verb.comp
} ; } ;
{- Clause : Type = {s : VPHTense => Polarity => Order => Str} ;
mkClause : NP -> VPH -> Clause = \np,vp -> {
s = \\vt,b,ord =>
let
subjagr : NPCase * Agr = case vt of {
VPImpPast => case vp.subj of {
VTrans => <NPErg, vp.obj.a> ;
VTransPost => <NPErg, defaultAgr> ;
_ => <NPC Dir, np.a>
} ;
_ => <NPC Dir, np.a>
} ;
subj = subjagr.p1 ;
agr = subjagr.p2 ;
n = (fromAgr agr).n;
p = (fromAgr agr).p;
g = (fromAgr agr).g;
vps = case vt of {
VPGenPres => vp.s ! VPTense VPPres agr ;
VPImpPast => vp.s ! VPTense VPPast agr ;
VPFut => case vp.prog of { True => {fin = (vp.s ! VPTense VPFutr agr).fin ; inf = (vp.s ! VPTense VPFutr agr).inf ++ hw p n} ;
_ => vp.s ! VPTense VPFutr agr } ;
VPContPres => {fin = copula CPresent n p g ; inf = (vp.s ! VPStem).inf ++ raha g n } ;
VPContPast => {fin = copula CPast n p g ; inf = (vp.s ! VPStem).inf ++ raha g n } ;
VPContFut => {fin = copula CFuture n p g ; inf = (vp.s ! VPStem).inf ++ raha g n ++ hw p n} ;
VPPerfPres => {fin = copula CPresent n p g ; inf = (vp.s ! VPTense VPPerf agr).inf } ;
VPPerfPast => {fin = copula CPast n p g ; inf = (vp.s ! VPTense VPPerf agr).inf } ;
VPPerfFut => {fin = copula CFuture n p g ; inf = (vp.s ! VPTense VPPerf agr).inf ++ hw p n } ;
VPPerfPresCont => {fin = copula CPresent n p g ; inf = (vp.s ! VPTense VPPres agr).inf ++ raha g n } ;
VPPerfPastCont => {fin = copula CPast n p g ; inf = (vp.s ! VPTense VPPres agr).inf ++ raha g n } ;
VPPerfFutCont => {fin = copula CFuture n p g ; inf = (vp.s ! VPTense VPPres agr).inf ++ raha g n ++ hw p n } ;
VPSubj => case vp.prog of { True => {fin = (vp.s ! VPTense VPFutr agr).inf ++ hw p n ; inf = "Xayd" } ;
_ => {fin = (vp.s ! VPTense VPFutr agr).inf ; inf = "Xayd" } }
};
quest =
case ord of
{ ODir => [];
OQuest => "kya" };
na =
case b of
{ Pos => [];
Neg => "na" };
nahim =
case b of
{ Pos => [];
Neg => "nhyN" };
in
case vt of {
VPSubj => quest ++ np.s ! subj ++ vp.obj.s ++ vp.ad ++ vp.comp ! np.a ++ na ++ vps.inf ++ vps.fin ++ vp.embComp ;
_ => quest ++ np.s ! subj ++ vp.obj.s ++ vp.ad ++ vp.comp ! np.a ++ nahim ++ vps.inf ++ vps.fin ++ vp.embComp};
} ;
mkSClause : Str -> Agr -> VPH -> Clause =
\subj,agr,vp -> {
s = \\t,b,ord =>
let
n = (fromAgr agr).n;
p = (fromAgr agr).p;
g = (fromAgr agr).g;
vps = case t of {
VPGenPres => vp.s ! VPTense VPPres agr ;
VPImpPast => vp.s ! VPTense VPPast agr ;
VPFut => vp.s ! VPTense VPFutr agr ;
VPContPres => {fin = copula CPresent n p g ; inf = (vp.s ! VPStem).inf ++ raha g n } ;
VPContPast => {fin = copula CPast n p g ; inf = (vp.s ! VPStem).inf ++ raha g n } ;
VPContFut => {fin = copula CFuture n p g ; inf = (vp.s ! VPStem).inf ++ raha g n ++ hw p n } ;
VPPerfPres => {fin = copula CPresent n p g ; inf = (vp.s ! VPStem).inf ++ cka g n } ;
VPPerfPast => {fin = copula CPast n p g ; inf = (vp.s ! VPStem).inf ++ cka g n } ;
VPPerfFut => {fin = copula CFuture n p g ; inf = (vp.s ! VPStem).inf ++ cka g n ++ hw p n } ;
VPPerfPresCont => {fin = copula CPresent n p g ; inf = (vp.s ! VPStem).inf ++ raha g n } ;
VPPerfPastCont => {fin = copula CPast n p g ; inf = (vp.s ! VPStem).inf ++ raha g n } ;
VPPerfFutCont => {fin = copula CFuture n p g ; inf = (vp.s ! VPStem).inf ++ raha g n ++ hw p n } ;
VPSubj => {fin = insertSubj p (vp.s ! VPStem).inf ; inf = "Xayd" }
};
quest =
case ord of
{ ODir => [];
OQuest => "kya" };
na =
case b of
{ Pos => [];
Neg => "na" };
nahim =
case b of
{ Pos => [];
Neg => "nhyN" };
in
case t of {
VPSubj => quest ++ subj ++ vp.obj.s ++ vp.ad ++ vp.comp ! agr ++ na ++ vps.inf ++ vps.fin ++ vp.embComp;
_ => quest ++ subj ++ vp.obj.s ++ vp.ad ++ vp.comp ! agr ++ nahim ++ vps.inf ++ vps.fin ++ vp.embComp};
} ;
-}
-- insertSubj : UPerson -> Str -> Str = \p,s ->
-- case p of { Pers1 => s ++ "wN" ; _ => s ++ "E"};
insertObj : (Agr => Str) -> VPH -> VPH = \obj1,vp -> { insertObj : (Agr => Str) -> VPH -> VPH = \obj1,vp -> {
s = vp.s ; s = vp.s ;
@@ -332,13 +222,12 @@ param
insertObj2 obj vp ** {c2 = vp.c2} ; insertObj2 obj vp ** {c2 = vp.c2} ;
infVP : Bool -> VPH -> Agr -> Str = \isAux,vp,a -> infVP : Bool -> VPH -> Agr -> Str = \isAux,vp,a ->
vp.obj.s ++ vp.inf ++ vp.comp ! a ; vp.obj.s ++ vp.comp ! a ++ vp.inf ;
-- infVV : Bool -> VPH -> Str = \isAux,vp ->
-- case isAux of {False => vp.obj.s ++ vp.inf ; True => vp.obj.s ++ (vp.s ! VPImp).fin };
infVV : Bool -> VPH -> Str = \isAux,vp -> infVV : Bool -> VPH -> Str = \isAux,vp ->
case isAux of {False => vp.obj.s ++ (vp.comp ! (toAgr Sg Pers1 Masc)) ++ vp.inf ; True => vp.obj.s ++ (vp.comp ! (toAgr Sg Pers1 Masc)) ++ (vp.s ! VPImp).fin } ; case isAux of {False => vp.obj.s ++ (vp.comp ! (toAgr Sg Pers1 Masc)) ++ vp.inf ; True => (vp.s ! VPImp).inf ++ vp.obj.s ++ (vp.comp ! (toAgr Sg Pers1 Masc)) } ;
infV2V : Bool -> VPH -> Str = \isAux,vp -> infV2V : Bool -> VPH -> Str = \isAux,vp ->
case isAux of {False => vp.obj.s ++ (vp.comp ! (toAgr Sg Pers1 Masc)) ++ (vp.s ! VPInf).fin ++ "ky" ; True => vp.obj.s ++ (vp.comp ! (toAgr Sg Pers1 Masc)) ++ (vp.s ! VPImp).fin ++ "ky"}; case isAux of {False => vp.obj.s ++ (vp.comp ! (toAgr Sg Pers1 Masc)) ++ (vp.s ! VPInf).fin ++ ky ; True => vp.obj.s ++ (vp.comp ! (toAgr Sg Pers1 Masc)) ++ (vp.s ! VPImp).fin ++ ky};
insertObject : NP -> VPHSlash -> VPH = \np,vps -> { insertObject : NP -> VPHSlash -> VPH = \np,vps -> {
@@ -374,7 +263,7 @@ param
comp = vp.comp comp = vp.comp
} ; } ;
conjThat : Str = "kh" ; -- conjThat : Str = "kh" ;
insertEmbCompl : VPH -> Str -> VPH = \vp,emb -> { insertEmbCompl : VPH -> Str -> VPH = \vp,emb -> {
s = vp.s ; s = vp.s ;
@@ -397,5 +286,10 @@ param
comp = vp.comp comp = vp.comp
} ; } ;
compoundAdj : Str -> Str -> Adjective = \s1,s2 -> mkCompoundAdj (regAdjective s1) (regAdjective s2) ;
mkCompoundAdj : Adjective -> Adjective -> Adjective ;
mkCompoundAdj adj1 adj2 = {s = \\n,g,c,d => adj1.s ! n ! g ! c ! d ++ adj2.s ! n ! g ! c ! d} ;
} }

View File

@@ -1,6 +1,6 @@
--concrete SentenceUrd of Sentence = CatUrd ** open Prelude, StringsHindustani, ResUrd in { --concrete SentenceUrd of Sentence = CatUrd ** open Prelude, StringsHindustani, ResUrd in {
incomplete concrete SentenceHindustani of Sentence = incomplete concrete SentenceHindustani of Sentence =
CatHindustani ** open CommonHindustani, ResHindustani, Prelude, StringsHindustani in { CatHindustani ** open CommonHindustani, ResHindustani, Prelude in {
flags optimize=all_subs ; flags optimize=all_subs ;
coding = utf8; coding = utf8;
@@ -40,9 +40,10 @@ incomplete concrete SentenceHindustani of Sentence =
(insertObj2 (conjThat ++ slash.s) (predV vs)) ** (insertObj2 (conjThat ++ slash.s) (predV vs)) **
{c2 = slash.c2} ; {c2 = slash.c2} ;
EmbedS s = {s = conjThat ++ s.s} ; EmbedS s = {s = conjThat ++ s.s ; fromVP = False} ;
EmbedQS qs = {s = qs.s ! QIndir} ; EmbedQS qs = {s = conjThat ++ qs.s ! QIndir ; fromVP = False} ;
EmbedVP vp = {s = infVP False vp defaultAgr} ; --- agr -- EmbedVP vp = {s = infVP False vp defaultAgr ; fromVP = True} ; --- agr
EmbedVP vp = {s = (vp.s ! VPInf).fin ; fromVP = True} ;
UseCl temp p cl = UseCl temp p cl =
{ s = case <temp.t,temp.a> of { { s = case <temp.t,temp.a> of {
@@ -98,7 +99,6 @@ incomplete concrete SentenceHindustani of Sentence =
} ; } ;
AdvS a s = {s = a.s ! Masc ++ s.s} ; AdvS a s = {s = a.s ! Masc ++ s.s} ;
ExtAdvS a s = {s = a.s ! Masc ++ "," ++ s.s} ;
RelS s r = {s = s.s ++ r.s ! agrP3 Masc Sg} ; RelS s r = {s = s.s ++ r.s ! agrP3 Masc Sg} ;
SSubjS s sj s = { s = s.s ++ sj.s ++ s.s}; SSubjS s sj s = { s = s.s ++ sj.s ++ s.s};

View File

@@ -10,7 +10,7 @@ oper
jw = "jw" ; jw = "jw" ;
kw = "kw" ; kw = "kw" ;
mt = "mt" ; mt = "mt" ;
nE = "nE" ; -- nE = "nE" ;
nh = "nh" ; nh = "nh" ;
sE = "sE" ; sE = "sE" ;
waN = "waN" ; waN = "waN" ;

View File

@@ -2,7 +2,7 @@
--concrete SymbolUrd of Symbol = CatUrd ** open Prelude, ResUrd, StringsHindustani in { --concrete SymbolUrd of Symbol = CatUrd ** open Prelude, ResUrd, StringsHindustani in {
incomplete concrete SymbolHindustani of Symbol = incomplete concrete SymbolHindustani of Symbol =
CatHindustani ** open Prelude, ResHindustani, StringsHindustani, CommonHindustani in { CatHindustani ** open Prelude, ResHindustani, CommonHindustani in {
lin lin
-- SymbPN i = {s = \\_ => i.s ; g = Masc} ; -- SymbPN i = {s = \\_ => i.s ; g = Masc} ;

View File

@@ -1,5 +1,5 @@
--concrete VerbUrd of Verb = CatUrd ** open ResUrd in { --concrete VerbUrd of Verb = CatUrd ** open ResUrd in {
incomplete concrete VerbHindustani of Verb = CatHindustani ** open CommonHindustani, ResHindustani, StringsHindustani in { incomplete concrete VerbHindustani of Verb = CatHindustani ** open CommonHindustani, ResHindustani in {
flags optimize=all_subs ; flags optimize=all_subs ;
@@ -7,17 +7,17 @@ incomplete concrete VerbHindustani of Verb = CatHindustani ** open CommonHindust
UseV v = predV v ; UseV v = predV v ;
SlashV2a v = predV v ** {c2 = {s = v.c2.s ; c = VTrans}} ; SlashV2a v = predV v ** {c2 = {s = v.c2.s ; c = VTrans}} ;
Slash2V3 v np = Slash2V3 v np =
insertObjc (\\_ => np.s ! NPObj ++ v.c3 ) (predV v ** {c2 = {s = v.c2 ; c = VTrans}}) ; insertObjc (\\_ => np.s ! NPC Dir ++ v.c3 ) (predV v ** {c2 = {s = v.c2 ; c = VTransPost}}) ; -- changed form NPObj
Slash3V3 v np = Slash3V3 v np =
insertObjc (\\_ => np.s ! NPC Obl ++ v.c2) (predV v ** {c2 = {s = v.c3 ; c = VTrans}}) ; insertObjc (\\_ => np.s ! NPC Obl ++ v.c2) (predV v ** {c2 = {s = v.c3 ; c = VTransPost}}) ;
ComplVV v vp = insertTrans (insertVV (infVV v.isAux vp) (predV v) vp.embComp ) VTransPost; ComplVV v vp = insertTrans (insertVV (infVV v.isAux vp) (predV v) vp.embComp ) VTrans; -- changed from VTransPost
ComplVS v s = insertTrans (insertObj2 (conjThat ++ s.s) (predV v)) VTransPost ; ComplVS v s = insertTrans (insertObj2 (conjThat ++ s.s) (predV v)) VTrans ; -- changed from VTransPost
ComplVQ v q = insertObj2 (conjThat ++ q.s ! QIndir) (predV v) ; ComplVQ v q = insertObj2 (conjThat ++ q.s ! QIndir) (predV v) ;
ComplVA v ap = insertObj (\\a => ap.s ! giveNumber a ! giveGender a ! Dir ! Posit) (predV v) ; ComplVA v ap = insertObj (\\a => ap.s ! giveNumber a ! giveGender a ! Dir ! Posit) (predV v) ;
SlashV2V v vp = insertVV (infV2V v.isAux vp) (predV v) vp.embComp **{c2 = {s = sE ; c = VTransPost}} ; SlashV2V v vp = insertVV (infV2V v.isAux vp) (predV v) vp.embComp **{c2 = {s = sE ; c = VTrans}} ; -- changed from VTransPost
SlashV2S v s = insertObjc2 (conjThat ++ s.s) (predV v ** {c2 = {s = kw ; c = VTransPost}}) ; SlashV2S v s = insertObjc2 (conjThat ++ s.s) (predV v ** {c2 = {s = kw ; c = VTrans}}) ; -- changed from VTransPost
SlashV2Q v q = insertObjc2 (conjThat ++ q.s ! QIndir) (predV v ** {c2 = {s = sE ; c = VTransPost}}) ; SlashV2Q v q = insertObjc2 (conjThat ++ q.s ! QIndir) (predV v ** {c2 = {s = sE ; c = VTrans}}) ; -- changed from VTransPost
SlashV2A v ap = insertObjc (\\a => ap.s ! giveNumber a ! giveGender a ! Dir ! Posit) (predV v ** {c2 = {s = kw ; c = VTransPost}}) ; ---- SlashV2A v ap = insertObjc (\\a => ap.s ! giveNumber a ! giveGender a ! Dir ! Posit) (predV v ** {c2 = {s = kw ; c = VTrans}}) ; ----
ComplSlash vp np = insertObject np vp ; ComplSlash vp np = insertObject np vp ;
SlashVV vv vp = SlashVV vv vp =
insertEmbCompl (insertObj (\\a => infVP vv.isAux vp a) (predV vv)) vp.embComp ** insertEmbCompl (insertObj (\\a => infVP vv.isAux vp a) (predV vv)) vp.embComp **

View File

@@ -1,2 +1,2 @@
concrete CatUrd of Cat = CommonX - [Adv,AdN] ** CatHindustani with concrete CatUrd of Cat = CommonX - [Adv,AdN,SC] ** CatHindustani with
(ResHindustani = ResUrd) ; (ResHindustani = ResUrd) ;

View File

@@ -4,8 +4,8 @@
-- --
-- This module contains operations that are needed to make the -- This module contains operations that are needed to make the
-- resource syntax work. -- resource syntax work.
resource CommonHindustani = ParamX ** open Prelude,Predef in { resource CommonHindustani = ParamX ** open Prelude, Predef in {
--interface CommonHindustani = ParamX ** open Prelude,Predef,StringsHindustani1 in {
flags coding = utf8 ; flags coding = utf8 ;
oper oper
@@ -73,103 +73,6 @@ resource CommonHindustani = ParamX ** open Prelude,Predef in {
oper oper
copula : CTense -> Number -> UPerson -> Gender -> Str = \t,n,p,g ->
case <t,n,p,g> of {
<CPresent,Sg,Pers1,_ > => "ہوں" ;
<CPresent,Sg,Pers2_Casual,_ > => "ہے" ;
<CPresent,Sg,Pers2_Familiar,_ > => "ہو" ;
<CPresent,Sg,Pers2_Respect,_ > => "ہیں" ;
<CPresent,Sg,Pers3_Near,_ > => "ہے" ;
<CPresent,Sg,Pers3_Distant,_ > => "ہے" ;
<CPresent,Pl,Pers1,_ > => "ہیں" ;
<CPresent,Pl,Pers2_Casual,_ > => "ہو" ;
<CPresent,Pl,Pers2_Familiar,_ > => "ہو" ;
<CPresent,Pl,Pers2_Respect,_ > => "ہیں" ;
<CPresent,Pl,Pers3_Near,_ > => "ہیں" ;
<CPresent,Pl,Pers3_Distant,_ > => "ہیں" ;
<CPast,Sg,Pers1,Masc > => "تھا" ;
<CPast,Sg,Pers1,Fem > => "تھی" ;
<CPast,Sg,Pers2_Casual,Masc > => "تھا" ;
<CPast,Sg,Pers2_Casual,Fem > => "تھی" ;
<CPast,Sg,Pers2_Familiar,Masc > => "تh-ا" ;
<CPast,Sg,Pers2_Familiar,Fem > => "تھی" ;
<CPast,Sg,Pers2_Respect,Masc > => "تھے" ;
<CPast,Sg,Pers2_Respect,Fem > => "تھیں" ;
<CPast,Sg,Pers3_Near,Masc > => "تh-ا" ;
<CPast,Sg,Pers3_Near,Fem > => "تھی" ;
<CPast,Sg,Pers3_Distant,Masc > => "تh-ا" ;
<CPast,Sg,Pers3_Distant,Fem > => "تھی" ;
<CPast,Pl,Pers1,Masc > => "تھے" ;
<CPast,Pl,Pers1,Fem > => "تھیں" ;
<CPast,Pl,Pers2_Casual,Masc > => "تھے" ;
<CPast,Pl,Pers2_Casual,Fem > => "تھیں" ;
<CPast,Pl,Pers2_Familiar,Masc > => "تھے" ;
<CPast,Pl,Pers2_Familiar,Fem > => "تھیں" ;
<CPast,Pl,Pers2_Respect,Masc > => "تھے" ;
<CPast,Pl,Pers2_Respect,Fem > => "تھیں" ;
<CPast,Pl,Pers3_Near,Masc > => "تھے" ;
<CPast,Pl,Pers3_Near,Fem > => "تھیں" ;
<CPast,Pl,Pers3_Distant,Masc > => "تھے" ;
<CPast,Pl,Pers3_Distant,Fem > => "تھیں" ;
<CFuture,Sg,Pers1,Masc > => "گا" ;
<CFuture,Sg,Pers1,Fem > => "گی" ;
<CFuture,Sg,Pers2_Casual,Masc > => "گا" ;
<CFuture,Sg,Pers2_Casual,Fem > => "گی" ;
<CFuture,Sg,Pers2_Familiar,Masc > => "گے" ;
<CFuture,Sg,Pers2_Familiar,Fem > => "گی" ;
<CFuture,Sg,Pers2_Respect,Masc > => "گے" ;
<CFuture,Sg,Pers2_Respect,Fem > => "گی" ;
<CFuture,Sg,Pers3_Near,Masc > => "گا" ;
<CFuture,Sg,Pers3_Near,Fem > => "گی" ;
<CFuture,Sg,Pers3_Distant,Masc > => "گا" ;
<CFuture,Sg,Pers3_Distant,Fem > => "گی" ;
<CFuture,Pl,Pers1,Masc > => "گے" ;
<CFuture,Pl,Pers1,Fem > => "گی" ;
<CFuture,Pl,Pers2_Casual,Masc > => "گے" ;
<CFuture,Pl,Pers2_Casual,Fem > => "گی" ;
<CFuture,Pl,Pers2_Familiar,Masc > => "گے" ;
<CFuture,Pl,Pers2_Familiar,Fem > => "گی" ;
<CFuture,Pl,Pers2_Respect,Masc > => "گے" ;
<CFuture,Pl,Pers2_Respect,Fem > => "گی" ;
<CFuture,Pl,Pers3_Near,Masc > => "گے" ;
<CFuture,Pl,Pers3_Near,Fem > => "گے" ;
<CFuture,Pl,Pers3_Distant,Masc > => "گے" ;
<CFuture,Pl,Pers3_Distant,Fem > => "گی"
} ;
raha : Gender -> Number -> Str = \g,n ->
(regAdjective "رہا").s ! n ! g ! Dir ! Posit ;
cka : Gender -> Number -> Str = \g,n ->
(regAdjective "چكا").s ! n ! g ! Dir ! Posit ;
hw : UPerson -> Number -> Str = \pp,n ->
case <pp,n> of {
<Pers1,_> => "ہوں";
<_,Pl> => "ہوں";
<_,_> => "ہو"
};
-----------------------------------------------
-- Hindustani Adjectives
-----------------------------------------------
Adjective = { s: Number => Gender => Case => Degree => Str };
regAdjective : Str -> Adjective;
regAdjective x = case x of {
acch + ("ا"|"اں") => mkAdjective x ("بہت" ++ x) ("سب سے" ++ x) (acch + "ے") ("بہت" ++ acch + "ے") ("سب سے" ++ acch + "ے") (acch + "ے") ("بہت" ++ acch + "ے") ("سب سے" ++ acch + "ے")
(acch + "ی") ("بہت" ++ acch + "ی") ("سب سے" ++ acch + "ی") (acch + "ی") ("بہت" ++ acch + "ی") ("سب سے" ++ acch + "ی") (acch + "ی") ("بہت" ++ acch + "ی") ("سب سے" ++ acch + "ی")
(acch +"ے") ("بہت" ++ acch + "ے") ("سب سے" ++ acch + "ے") (acch + "ے") ("بہت" ++ acch + "ے") ("سب سے" ++ acch + "ے") (acch + "ے") ("بہت" ++ acch + "ے") ("سب سے" ++ acch + "ے")
(acch + "ی") ("بہت" ++ acch + "ی") ("سب سے" ++ acch + "ی") (acch + "ی") ("بہت" ++ acch + "ی") ("سب سے" ++ acch + "ی") (acch + "ی") ("بہت" ++ acch + "ی") ("سب سے" ++ acch + "ی");
_ => mkAdjective x ("بہت" ++ x) ("سب سے" ++ x) x ("بہت" ++ x) ("سب سے" ++ x) x ("بہت" ++ x) ("سب سے" ++ x)
x ("بہت" ++ x) ("سب سے" ++ x) x ("بہت" ++ x) ("سب سے" ++ x) x ("بہت" ++ x) ("سب سے" ++ x)
x ("بہت" ++ x) ("سب سے" ++ x) x ("بہت" ++ x) ("سب سے" ++ x) x ("بہت" ++ x) ("سب سے" ++ x)
x ("بہت" ++ x) ("سب سے" ++ x) x ("بہت" ++ x) ("سب سے" ++ x) x ("بہت" ++ x) ("سب سے" ++ x)
};
mkAdjective : (x1,x2,x3,x4,x5,x6,x7,x8,x9,x10,x11,x12,x13,x14,x15,x16,x17,x18,x19,x20,x21,x22,x23,x24,x25,x26,x27,x28,x29,x30,x31,x32,x33,x34,x35,x36:Str) -> Adjective = mkAdjective : (x1,x2,x3,x4,x5,x6,x7,x8,x9,x10,x11,x12,x13,x14,x15,x16,x17,x18,x19,x20,x21,x22,x23,x24,x25,x26,x27,x28,x29,x30,x31,x32,x33,x34,x35,x36:Str) -> Adjective =
\y1,y2,y3,y4,y5,y6,y7,y8,y9,y10,y11,y12,y13,y14,y15,y16,y17,y18,y19,y20,y21,y22,y23,y24,y25,y26,y27,y28,y29,y30,y31,y32,y33,y34,y35,y36 -> { \y1,y2,y3,y4,y5,y6,y7,y8,y9,y10,y11,y12,y13,y14,y15,y16,y17,y18,y19,y20,y21,y22,y23,y24,y25,y26,y27,y28,y29,y30,y31,y32,y33,y34,y35,y36 -> {
@@ -249,34 +152,10 @@ resource CommonHindustani = ParamX ** open Prelude,Predef in {
} }
}; };
compoundAdj : Str -> Str -> Adjective = \s1,s2 -> mkCompoundAdj (regAdjective s1) (regAdjective s2) ; Adjective = { s: Number => Gender => Case => Degree => Str };
mkCompoundAdj : Adjective -> Adjective -> Adjective ;
mkCompoundAdj adj1 adj2 = {s = \\n,g,c,d => adj1.s ! n ! g ! c ! d ++ adj2.s ! n ! g ! c ! d} ;
Verb : Type = {s : VerbForm => Str} ; Verb : Type = {s : VerbForm => Str} ;
predV : Verb -> VPH ;
predV v = {
s = \\vh =>
case vh of {
VPTense VPPres (Ag g n p) => {fin = copula CPresent n p g ; inf = v.s ! VF Imperf p n g } ;
VPTense VPPast (Ag g n p) => {fin = [] ; inf =v.s ! VF Perf p n g} ;
VPTense VPFutr (Ag g n p) => {fin = copula CFuture n p g ; inf = v.s ! VF Subj p n g } ;
VPTense VPPerf (Ag g n p) => { fin = [] ; inf = v.s ! Root ++ cka g n } ;
VPStem => {fin = [] ; inf = v.s ! Root};
VPInf => {fin = v.s ! Inf_Obl ; inf = v.s ! Root}; -- for V2V like sonE ky altja krna , check if it is being used anywhere else
VPImp => {fin = v.s ! VF Subj Pers3_Near Pl Masc ; inf = v.s ! Root};
_ => {fin = [] ; inf = v.s ! Root}
};
obj = {s = [] ; a = defaultAgr} ;
subj = VIntrans ;
inf = v.s ! Inf;
ad = [];
embComp = [];
prog = False ;
comp = \\_ => []
} ;
defaultAgr : Agr = agrP3 Masc Sg ; defaultAgr : Agr = agrP3 Masc Sg ;
agrP3 : Gender -> Number -> Agr = \g,n -> Ag g n Pers3_Distant ; agrP3 : Gender -> Number -> Agr = \g,n -> Ag g n Pers3_Distant ;
toAgr : Number -> UPerson -> Gender -> Agr = \n,p,g -> toAgr : Number -> UPerson -> Gender -> Agr = \n,p,g ->
@@ -300,8 +179,9 @@ resource CommonHindustani = ParamX ** open Prelude,Predef in {
giveGender : Agr -> Gender =\a -> case a of { giveGender : Agr -> Gender =\a -> case a of {
Ag g _ _ => g Ag g _ _ => g
}; };
insertSubj : UPerson -> Str -> Str = \p,s ->
case p of { Pers1 => s ++ "وں" ; _ => s ++ "ے"}; -- insertSubj : UPerson -> Str -> Str = \p,s ->
-- case p of { Pers1 => s ++ "وں" ; _ => s ++ "ے"};
mkOrd : Str -> Str = mkOrd : Str -> Str =
\s -> case s of { \s -> case s of {
@@ -312,5 +192,6 @@ resource CommonHindustani = ParamX ** open Prelude,Predef in {
"چھ" => "چھٹا"; "چھ" => "چھٹا";
_ => s ++ "واں" _ => s ++ "واں"
}; };
} }

View File

@@ -112,4 +112,137 @@ Clause : Type = {s : VPHTense => Polarity => Order => Str} ;
_ => ppf ! Dir ++ "نے" _ => ppf ! Dir ++ "نے"
} }
} ; } ;
conjThat = "كہ" ;
insertSubj : UPerson -> Str -> Str = \p,s ->
case p of { Pers1 => s ++ "واں" ; _ => s ++ "ے"}; -- check with prasad for vn~
agr = "اگر" ;
awr = "اور" ;
ky = "كی" ;
jn = "جن" ;
js = "جس" ;
jw = "جو" ;
kw = "كو" ;
mt = "مت" ;
nE = "نے" ;
nh = "نا" ;
sE = "سے" ;
waN = "واں" ;
hE = "ہے" ;
comma = "," ;
indfArt = "اك" ;
kwd = "خود" ;
copula : CTense -> Number -> UPerson -> Gender -> Str = \t,n,p,g ->
case <t,n,p,g> of {
<CPresent,Sg,Pers1,_ > => "ہوں" ;
<CPresent,Sg,Pers2_Casual,_ > => "ہے";
<CPresent,Sg,Pers2_Familiar,_ > => "ہو" ;
<CPresent,Sg,Pers2_Respect,_ > => "ہیں" ;
<CPresent,Sg,Pers3_Near,_ > => "ہے" ;
<CPresent,Sg,Pers3_Distant,_ > => "ہے" ;
<CPresent,Pl,Pers1,_ > => "ہیں" ;
<CPresent,Pl,Pers2_Casual,_ > => "ہو" ;
<CPresent,Pl,Pers2_Familiar,_ > => "ہو" ;
<CPresent,Pl,Pers2_Respect,_ > => "ہیں" ;
<CPresent,Pl,Pers3_Near,_ > => "ہیں" ;
<CPresent,Pl,Pers3_Distant,_ > => "ہیں" ;
<CPast,Sg,Pers1,Masc > => "تھا" ;
<CPast,Sg,Pers1,Fem > => "تھی" ;
<CPast,Sg,Pers2_Casual,Masc > => "تھا" ;
<CPast,Sg,Pers2_Casual,Fem > => "تھی" ;
<CPast,Sg,Pers2_Familiar,Masc > => "تh-ا" ;
<CPast,Sg,Pers2_Familiar,Fem > => "تھی" ;
<CPast,Sg,Pers2_Respect,Masc > => "تھے" ;
<CPast,Sg,Pers2_Respect,Fem > => "تھیں" ;
<CPast,Sg,Pers3_Near,Masc > => "تh-ا" ;
<CPast,Sg,Pers3_Near,Fem > => "تھی" ;
<CPast,Sg,Pers3_Distant,Masc > => "تh-ا" ;
<CPast,Sg,Pers3_Distant,Fem > => "تھی" ;
<CPast,Pl,Pers1,Masc > => "تھے" ;
<CPast,Pl,Pers1,Fem > => "تھیں" ;
<CPast,Pl,Pers2_Casual,Masc > => "تھے" ;
<CPast,Pl,Pers2_Casual,Fem > => "تھیں" ;
<CPast,Pl,Pers2_Familiar,Masc > => "تھے" ;
<CPast,Pl,Pers2_Familiar,Fem > => "تھیں" ;
<CPast,Pl,Pers2_Respect,Masc > => "تھے" ;
<CPast,Pl,Pers2_Respect,Fem > => "تھیں" ;
<CPast,Pl,Pers3_Near,Masc > => "تھے" ;
<CPast,Pl,Pers3_Near,Fem > => "تھیں" ;
<CPast,Pl,Pers3_Distant,Masc > => "تھے" ;
<CPast,Pl,Pers3_Distant,Fem > => "تھیں" ;
<CFuture,Sg,Pers1,Masc > => "گا" ;
<CFuture,Sg,Pers1,Fem > => "گی" ;
<CFuture,Sg,Pers2_Casual,Masc > => "گا" ;
<CFuture,Sg,Pers2_Casual,Fem > => "گی" ;
<CFuture,Sg,Pers2_Familiar,Masc > => "گے" ;
<CFuture,Sg,Pers2_Familiar,Fem > => "گی" ;
<CFuture,Sg,Pers2_Respect,Masc > => "گے" ;
<CFuture,Sg,Pers2_Respect,Fem > => "گی" ;
<CFuture,Sg,Pers3_Near,Masc > => "گا" ;
<CFuture,Sg,Pers3_Near,Fem > => "گی" ;
<CFuture,Sg,Pers3_Distant,Masc > => "گا" ;
<CFuture,Sg,Pers3_Distant,Fem > => "گی" ;
<CFuture,Pl,Pers1,Masc > => "گے" ;
<CFuture,Pl,Pers1,Fem > => "گی" ;
<CFuture,Pl,Pers2_Casual,Masc > => "گے" ;
<CFuture,Pl,Pers2_Casual,Fem > => "گی" ;
<CFuture,Pl,Pers2_Familiar,Masc > => "گے" ;
<CFuture,Pl,Pers2_Familiar,Fem > => "گی" ;
<CFuture,Pl,Pers2_Respect,Masc > => "گے" ;
<CFuture,Pl,Pers2_Respect,Fem > => "گی" ;
<CFuture,Pl,Pers3_Near,Masc > => "گے" ;
<CFuture,Pl,Pers3_Near,Fem > => "گے" ;
<CFuture,Pl,Pers3_Distant,Masc > => "گے" ;
<CFuture,Pl,Pers3_Distant,Fem > => "گی"
} ;
raha : Gender -> Number -> Str = \g,n ->
(regAdjective "رہا").s ! n ! g ! Dir ! Posit ;
cka : Gender -> Number -> Str = \g,n ->
(regAdjective "چكا").s ! n ! g ! Dir ! Posit ;
hw : UPerson -> Number -> Str = \pp,n ->
case <pp,n> of {
<Pers1,_> => "ہوں";
<_,Pl> => "ہوں";
<_,_> => "ہو"
};
hwa : Agr -> Str = \agr ->
let n = (fromAgr agr).n;
p = (fromAgr agr).p;
g = (fromAgr agr).g;
in
case <n,g> of {
<Sg,Masc> => "ہوا";
<Sg,Fem> => "ہوی";
<Pl,Masc> => "ہوے" ;
<Pl,Fem> => "ہوی"
};
-----------------------------------------------
-- Hindustani Adjectives
-----------------------------------------------
Adjective = { s: Number => Gender => Case => Degree => Str };
regAdjective : Str -> Adjective;
regAdjective x = case x of {
acch + ("ا"|"اں") => mkAdjective x ("بہت" ++ x) ("سب سے" ++ x) (acch + "ے") ("بہت" ++ acch + "ے") ("سب سے" ++ acch + "ے") (acch + "ے") ("بہت" ++ acch + "ے") ("سب سے" ++ acch + "ے")
(acch + "ی") ("بہت" ++ acch + "ی") ("سب سے" ++ acch + "ی") (acch + "ی") ("بہت" ++ acch + "ی") ("سب سے" ++ acch + "ی") (acch + "ی") ("بہت" ++ acch + "ی") ("سب سے" ++ acch + "ی")
(acch +"ے") ("بہت" ++ acch + "ے") ("سب سے" ++ acch + "ے") (acch + "ے") ("بہت" ++ acch + "ے") ("سب سے" ++ acch + "ے") (acch + "ے") ("بہت" ++ acch + "ے") ("سب سے" ++ acch + "ے")
(acch + "ی") ("بہت" ++ acch + "ی") ("سب سے" ++ acch + "ی") (acch + "ی") ("بہت" ++ acch + "ی") ("سب سے" ++ acch + "ی") (acch + "ی") ("بہت" ++ acch + "ی") ("سب سے" ++ acch + "ی");
_ => mkAdjective x ("بہت" ++ x) ("سب سے" ++ x) x ("بہت" ++ x) ("سب سے" ++ x) x ("بہت" ++ x) ("سب سے" ++ x)
x ("بہت" ++ x) ("سب سے" ++ x) x ("بہت" ++ x) ("سب سے" ++ x) x ("بہت" ++ x) ("سب سے" ++ x)
x ("بہت" ++ x) ("سب سے" ++ x) x ("بہت" ++ x) ("سب سے" ++ x) x ("بہت" ++ x) ("سب سے" ++ x)
x ("بہت" ++ x) ("سب سے" ++ x) x ("بہت" ++ x) ("سب سے" ++ x) x ("بہت" ++ x) ("سب سے" ++ x)
};
} }

View File

@@ -11,10 +11,10 @@
RelativeUrd, RelativeUrd,
ConjunctionUrd, ConjunctionUrd,
PhraseUrd, PhraseUrd,
TextUrd - [Adv,AdN], TextUrd - [Adv,AdN,SC],
-- TextX - [Adv,AdN], -- TextX - [Adv,AdN],
StructuralUrd, StructuralUrd,
TenseX - [Adv,AdN], TenseX - [Adv,AdN,SC],
IdiomUrd IdiomUrd
** { ** {

View File

@@ -119,7 +119,7 @@ concrete LexiconUrd of Lexicon = CatUrd **
love_N = mkN "محبت" ; love_N = mkN "محبت" ;
love_V2 = mkV2 (compoundV "پیار" do_V2) "كو"; love_V2 = mkV2 (compoundV "پیار" do_V2) "كو";
man_N = mkN "آدمی" "آدمی" "آدمی" "آدمی" "آدمیوں" "آدمیو" masculine ; man_N = mkN "آدمی" "آدمی" "آدمی" "آدمی" "آدمیوں" "آدمیو" masculine ;
married_A2 = mkA "[شادی كرنa]" "سے" ; married_A2 = mkA "شادی شدہ" "سے" ;
meat_N = mkN "گوشت" ; meat_N = mkN "گوشت" ;
milk_N = mkN "دودھ" ; milk_N = mkN "دودھ" ;
moon_N = mkN "چاند" ; moon_N = mkN "چاند" ;
@@ -162,7 +162,7 @@ concrete LexiconUrd of Lexicon = CatUrd **
seek_V2 = mkV2 (compoundV "تلاش" do_V2) ; seek_V2 = mkV2 (compoundV "تلاش" do_V2) ;
see_V2 = mkV2 (mkV "دیكھنا") ; see_V2 = mkV2 (mkV "دیكھنا") ;
sell_V3 = mkV3 (mkV "بیچنا") "كو" ""; sell_V3 = mkV3 (mkV "بیچنا") "كو" "";
send_V3 = mkV3 (mkV "بھیجنا") "كو" "كو"; send_V3 = mkV3 (mkV "بھیجنا") "كو" "";
sheep_N = mkN "بھیڑ" feminine ; sheep_N = mkN "بھیڑ" feminine ;
ship_N = mkN "جہاز" ; ship_N = mkN "جہاز" ;
shirt_N = mkN "قمیص" feminine; shirt_N = mkN "قمیص" feminine;
@@ -352,7 +352,7 @@ concrete LexiconUrd of Lexicon = CatUrd **
wash_V2 = mkV2 (mkV "دھونا") ; wash_V2 = mkV2 (mkV "دھونا") ;
wipe_V2 = mkV2 (compoundV "صاف" (mkV "كرنا" )); wipe_V2 = mkV2 (compoundV "صاف" (mkV "كرنا" ));
---- other_A = regA "?تہعر" ; ---- other_A = regA "؟تہعر" ;
grammar_N = mkN "گردان" ; grammar_N = mkN "گردان" ;
language_N = mkN "زبان" feminine ; language_N = mkN "زبان" feminine ;
@@ -361,7 +361,7 @@ concrete LexiconUrd of Lexicon = CatUrd **
---- added 4/6/2007 ---- added 4/6/2007
john_PN = mkPN "جان" ; john_PN = mkPN "جان" ;
question_N = mkN "سوال" ; question_N = mkN "سوال" ;
-- ready_A = regA "رعادی" ; ready_A = mkA "تیار" ;
reason_N = mkN "وجہ" feminine ; reason_N = mkN "وجہ" feminine ;
today_Adv = mkAdv "آج" ; today_Adv = mkAdv "آج" ;
uncertain_A = mkA ["غیریقینی"] ; uncertain_A = mkA ["غیریقینی"] ;

View File

@@ -50,7 +50,7 @@ param
eq : Str -> Str -> Bool = \s1,s2-> (pbool2bool (eqStr s1 s2)) ; eq : Str -> Str -> Bool = \s1,s2-> (pbool2bool (eqStr s1 s2)) ;
RefPron : Str; RefPron : Str;
RefPron = "خود"; RefPron = kwd ;
---------------------------------------------------------- ----------------------------------------------------------
-- Grammar part -- Grammar part
@@ -60,47 +60,23 @@ param
toNP : ( Case => Str) -> NPCase -> Str = \pn, npc -> case npc of { toNP : ( Case => Str) -> NPCase -> Str = \pn, npc -> case npc of {
NPC c => pn ! c ; NPC c => pn ! c ;
NPObj => pn ! Dir ; NPObj => pn ! Dir ;
NPErg => pn ! Obl ++ "نے" NPErg => pn ! Obl ++ nE
} ; } ;
detcn2NP : (Determiner) -> Noun -> NPCase -> Number -> Str = \dt,cn,npc,nn -> case npc of { detcn2NP : (Determiner) -> Noun -> NPCase -> Number -> Str = \dt,cn,npc,nn -> case npc of {
-- NPC c => dt.s ! Sg ! Masc ++ cn.s ! nn ! c ; --changed while phrasebook e.g tyry beti where gender of determiner 'tyry' should be dependent on gender of common noum e.g 'beti' -- NPC c => dt.s ! Sg ! Masc ++ cn.s ! nn ! c ; --changed while phrasebook e.g tyry beti where gender of determiner 'tyry' should be dependent on gender of common noum e.g 'beti'
NPC c => dt.s ! nn ! cn.g ! c ++ cn.s ! nn ! c ; NPC c => dt.s ! nn ! cn.g ! c ++ cn.s ! nn ! c ;
NPObj => dt.s ! nn ! cn.g ! Obl ++ cn.s ! nn ! Dir ; NPObj => dt.s ! nn ! cn.g ! Obl ++ cn.s ! nn ! Dir ;
NPErg => dt.s ! nn ! cn.g ! Obl ++ cn.s ! nn ! Obl ++ "نے" NPErg => dt.s ! nn ! cn.g ! Obl ++ cn.s ! nn ! Obl ++ nE
} ; } ;
det2NP : (Determiner) -> NPCase -> Str = \dt,npc -> case npc of { det2NP : (Determiner) -> NPCase -> Str = \dt,npc -> case npc of {
NPC c => dt.s ! Sg ! Masc ! c ; NPC c => dt.s ! Sg ! Masc ! c ;
NPObj => dt.s ! Sg ! Masc ! Dir ; NPObj => dt.s ! Sg ! Masc ! Dir ;
NPErg => dt.s ! Sg ! Masc ! Obl ++ "نے" NPErg => dt.s ! Sg ! Masc ! Obl ++ nE
} ; } ;
------------------------------------------ ------------------------------------------
-- Agreement transformations -- Agreement transformations
----------------------------------------- -----------------------------------------
{- toAgr : Number -> UPerson -> Gender -> Agr = \n,p,g ->
Ag g n p;
fromAgr : Agr -> {n : Number ; p : UPerson ; g : Gender} = \a -> case a of {
Ag g n p => {n = n ; p = p ; g = g}
} ;
conjAgr : Agr -> Agr -> Agr = \a0,b0 ->
let a = fromAgr a0 ; b = fromAgr b0
in
toAgr
(conjNumber a.n b.n)
b.p a.g;
giveNumber : Agr -> Number =\a -> case a of {
Ag _ n _ => n
};
giveGender : Agr -> Gender =\a -> case a of {
Ag g _ _ => g
};
-}
-- defaultAgr : Agr = agrP3 Masc Sg ;
-- agrP3 : Gender -> Number -> Agr = \g,n -> Ag g n Pers3_Distant ;
personalAgr : Agr = agrP1 Masc Sg ; personalAgr : Agr = agrP1 Masc Sg ;
agrP1 : Gender -> Number -> Agr = \g,n -> Ag g n Pers1 ; agrP1 : Gender -> Number -> Agr = \g,n -> Ag g n Pers1 ;
@@ -121,6 +97,7 @@ param
objVType : VType -> NPCase = \vt -> case vt of { objVType : VType -> NPCase = \vt -> case vt of {
VTrans => NPObj ; VTrans => NPObj ;
VTransPost => NPC Dir ;
_ => NPC Obl _ => NPC Obl
} ; } ;
@@ -131,13 +108,27 @@ param
predVc : (Verb ** {c2,c1 : Str}) -> VPHSlash = \verb -> predVc : (Verb ** {c2,c1 : Str}) -> VPHSlash = \verb ->
predV verb ** {c2 = {s = verb.c1 ; c = VTrans} } ; predV verb ** {c2 = {s = verb.c1 ; c = VTrans} } ;
{- predV : Verb -> VPH ;
------------------------- predV v = {
-- added for cauitives s = \\vh =>
predVcc : (Verb **{c2:Compl}) -> VPHSlash = \verb -> case vh of {
predV verb ** {c2 = {s = "" ; c = VTrans} } ; VPTense VPPres (Ag g n p) => {fin = copula CPresent n p g ; inf = v.s ! VF Imperf p n g } ;
------------------------ VPTense VPPast (Ag g n p) => {fin = [] ; inf =v.s ! VF Perf p n g} ;
-} VPTense VPFutr (Ag g n p) => {fin = copula CFuture n p g ; inf = v.s ! VF Subj p n g } ;
VPTense VPPerf (Ag g n p) => { fin = [] ; inf = v.s ! Root ++ cka g n } ;
VPStem => {fin = [] ; inf = v.s ! Root};
VPInf => {fin = v.s ! Inf_Obl ; inf = v.s ! Root}; -- for V2V like sonE ky altja krna , check if it is being used anywhere else
VPImp => {fin = v.s ! VF Subj Pers3_Near Pl Masc ; inf = v.s ! Root};
_ => {fin = [] ; inf = v.s ! Root}
};
obj = {s = [] ; a = defaultAgr} ;
subj = VIntrans ;
inf = v.s ! Inf;
ad = [];
embComp = [];
prog = False ;
comp = \\_ => []
} ;
predAux : Aux -> VPH = \verb -> { predAux : Aux -> VPH = \verb -> {
s = \\vh => s = \\vh =>
let let
@@ -191,107 +182,6 @@ param
comp = verb.comp comp = verb.comp
} ; } ;
{- Clause : Type = {s : VPHTense => Polarity => Order => Str} ;
mkClause : NP -> VPH -> Clause = \np,vp -> {
s = \\vt,b,ord =>
let
subjagr : NPCase * Agr = case vt of {
VPImpPast => case vp.subj of {
VTrans => <NPErg, vp.obj.a> ;
VTransPost => <NPErg, defaultAgr> ;
_ => <NPC Dir, np.a>
} ;
_ => <NPC Dir, np.a>
} ;
subj = subjagr.p1 ;
agr = subjagr.p2 ;
n = (fromAgr agr).n;
p = (fromAgr agr).p;
g = (fromAgr agr).g;
vps = case vt of {
VPGenPres => vp.s ! VPTense VPPres agr ;
VPImpPast => vp.s ! VPTense VPPast agr ;
VPFut => case vp.prog of { True => {fin = (vp.s ! VPTense VPFutr agr).fin ; inf = (vp.s ! VPTense VPFutr agr).inf ++ hw p n} ;
_ => vp.s ! VPTense VPFutr agr } ;
VPContPres => {fin = copula CPresent n p g ; inf = (vp.s ! VPStem).inf ++ raha g n } ;
VPContPast => {fin = copula CPast n p g ; inf = (vp.s ! VPStem).inf ++ raha g n } ;
VPContFut => {fin = copula CFuture n p g ; inf = (vp.s ! VPStem).inf ++ raha g n ++ hw p n} ;
VPPerfPres => {fin = copula CPresent n p g ; inf = (vp.s ! VPTense VPPerf agr).inf } ;
VPPerfPast => {fin = copula CPast n p g ; inf = (vp.s ! VPTense VPPerf agr).inf } ;
VPPerfFut => {fin = copula CFuture n p g ; inf = (vp.s ! VPTense VPPerf agr).inf ++ hw p n } ;
VPPerfPresCont => {fin = copula CPresent n p g ; inf = (vp.s ! VPTense VPPres agr).inf ++ raha g n } ;
VPPerfPastCont => {fin = copula CPast n p g ; inf = (vp.s ! VPTense VPPres agr).inf ++ raha g n } ;
VPPerfFutCont => {fin = copula CFuture n p g ; inf = (vp.s ! VPTense VPPres agr).inf ++ raha g n ++ hw p n } ;
VPSubj => case vp.prog of { True => {fin = (vp.s ! VPTense VPFutr agr).inf ++ hw p n ; inf = "شاید" } ;
_ => {fin = (vp.s ! VPTense VPFutr agr).inf ; inf = "شاید" } }
};
quest =
case ord of
{ ODir => [];
OQuest => "كیا" };
na =
case b of
{ Pos => [];
Neg => "نا" };
nahim =
case b of
{ Pos => [];
Neg => "نہیں" };
in
case vt of {
VPSubj => quest ++ np.s ! subj ++ vp.obj.s ++ vp.ad ++ vp.comp ! np.a ++ na ++ vps.inf ++ vps.fin ++ vp.embComp ;
_ => quest ++ np.s ! subj ++ vp.obj.s ++ vp.ad ++ vp.comp ! np.a ++ nahim ++ vps.inf ++ vps.fin ++ vp.embComp};
} ;
mkSClause : Str -> Agr -> VPH -> Clause =
\subj,agr,vp -> {
s = \\t,b,ord =>
let
n = (fromAgr agr).n;
p = (fromAgr agr).p;
g = (fromAgr agr).g;
vps = case t of {
VPGenPres => vp.s ! VPTense VPPres agr ;
VPImpPast => vp.s ! VPTense VPPast agr ;
VPFut => vp.s ! VPTense VPFutr agr ;
VPContPres => {fin = copula CPresent n p g ; inf = (vp.s ! VPStem).inf ++ raha g n } ;
VPContPast => {fin = copula CPast n p g ; inf = (vp.s ! VPStem).inf ++ raha g n } ;
VPContFut => {fin = copula CFuture n p g ; inf = (vp.s ! VPStem).inf ++ raha g n ++ hw p n } ;
VPPerfPres => {fin = copula CPresent n p g ; inf = (vp.s ! VPStem).inf ++ cka g n } ;
VPPerfPast => {fin = copula CPast n p g ; inf = (vp.s ! VPStem).inf ++ cka g n } ;
VPPerfFut => {fin = copula CFuture n p g ; inf = (vp.s ! VPStem).inf ++ cka g n ++ hw p n } ;
VPPerfPresCont => {fin = copula CPresent n p g ; inf = (vp.s ! VPStem).inf ++ raha g n } ;
VPPerfPastCont => {fin = copula CPast n p g ; inf = (vp.s ! VPStem).inf ++ raha g n } ;
VPPerfFutCont => {fin = copula CFuture n p g ; inf = (vp.s ! VPStem).inf ++ raha g n ++ hw p n } ;
VPSubj => {fin = insertSubj p (vp.s ! VPStem).inf ; inf = "شاید" }
};
quest =
case ord of
{ ODir => [];
OQuest => "كیا" };
na =
case b of
{ Pos => [];
Neg => "نا" };
nahim =
case b of
{ Pos => [];
Neg => "نہیں" };
in
case t of {
VPSubj => quest ++ subj ++ vp.obj.s ++ vp.ad ++ vp.comp ! agr ++ na ++ vps.inf ++ vps.fin ++ vp.embComp;
_ => quest ++ subj ++ vp.obj.s ++ vp.ad ++ vp.comp ! agr ++ nahim ++ vps.inf ++ vps.fin ++ vp.embComp};
} ;
-}
-- insertSubj : UPerson -> Str -> Str = \p,s ->
-- case p of { Pers1 => s ++ "وں" ; _ => s ++ "ے"};
insertObj : (Agr => Str) -> VPH -> VPH = \obj1,vp -> { insertObj : (Agr => Str) -> VPH -> VPH = \obj1,vp -> {
s = vp.s ; s = vp.s ;
@@ -332,13 +222,12 @@ param
insertObj2 obj vp ** {c2 = vp.c2} ; insertObj2 obj vp ** {c2 = vp.c2} ;
infVP : Bool -> VPH -> Agr -> Str = \isAux,vp,a -> infVP : Bool -> VPH -> Agr -> Str = \isAux,vp,a ->
vp.obj.s ++ vp.inf ++ vp.comp ! a ; vp.obj.s ++ vp.comp ! a ++ vp.inf ;
-- infVV : Bool -> VPH -> Str = \isAux,vp ->
-- case isAux of {False => vp.obj.s ++ vp.inf ; True => vp.obj.s ++ (vp.s ! VPImp).fin };
infVV : Bool -> VPH -> Str = \isAux,vp -> infVV : Bool -> VPH -> Str = \isAux,vp ->
case isAux of {False => vp.obj.s ++ (vp.comp ! (toAgr Sg Pers1 Masc)) ++ vp.inf ; True => vp.obj.s ++ (vp.comp ! (toAgr Sg Pers1 Masc)) ++ (vp.s ! VPImp).fin } ; case isAux of {False => vp.obj.s ++ (vp.comp ! (toAgr Sg Pers1 Masc)) ++ vp.inf ; True => (vp.s ! VPImp).inf ++ vp.obj.s ++ (vp.comp ! (toAgr Sg Pers1 Masc)) } ;
infV2V : Bool -> VPH -> Str = \isAux,vp -> infV2V : Bool -> VPH -> Str = \isAux,vp ->
case isAux of {False => vp.obj.s ++ (vp.comp ! (toAgr Sg Pers1 Masc)) ++ (vp.s ! VPInf).fin ++ "كی" ; True => vp.obj.s ++ (vp.comp ! (toAgr Sg Pers1 Masc)) ++ (vp.s ! VPImp).fin ++ "كی"}; case isAux of {False => vp.obj.s ++ (vp.comp ! (toAgr Sg Pers1 Masc)) ++ (vp.s ! VPInf).fin ++ ky ; True => vp.obj.s ++ (vp.comp ! (toAgr Sg Pers1 Masc)) ++ (vp.s ! VPImp).fin ++ ky};
insertObject : NP -> VPHSlash -> VPH = \np,vps -> { insertObject : NP -> VPHSlash -> VPH = \np,vps -> {
@@ -374,7 +263,7 @@ param
comp = vp.comp comp = vp.comp
} ; } ;
conjThat : Str = "كہ" ; -- conjThat : Str = "كہ" ;
insertEmbCompl : VPH -> Str -> VPH = \vp,emb -> { insertEmbCompl : VPH -> Str -> VPH = \vp,emb -> {
s = vp.s ; s = vp.s ;
@@ -397,5 +286,10 @@ param
comp = vp.comp comp = vp.comp
} ; } ;
compoundAdj : Str -> Str -> Adjective = \s1,s2 -> mkCompoundAdj (regAdjective s1) (regAdjective s2) ;
mkCompoundAdj : Adjective -> Adjective -> Adjective ;
mkCompoundAdj adj1 adj2 = {s = \\n,g,c,d => adj1.s ! n ! g ! c ! d ++ adj2.s ! n ! g ! c ! d} ;
} }

View File

@@ -10,7 +10,7 @@ oper
jw = "جو" ; jw = "جو" ;
kw = "كو" ; kw = "كو" ;
mt = "مت" ; mt = "مت" ;
nE = "نے" ; -- nE = "نے" ;
nh = "نہ" ; nh = "نہ" ;
sE = "سے" ; sE = "سے" ;
waN = "واں" ; waN = "واں" ;

View File

@@ -5,7 +5,7 @@ concrete StructuralUrd of Structural = CatUrd **
coding = utf8; coding = utf8;
lin lin
above_Prep = mkPrep "اوپر" "اوپر" ; above_Prep = mkPrep ["كے اوپر"] ["كے اوپر"] ;
after_Prep = mkPrep ["كے بعد"] ["كے بعد"] ; after_Prep = mkPrep ["كے بعد"] ["كے بعد"] ;
all_Predet = ss "تمام" ; all_Predet = ss "تمام" ;
almost_AdA, almost_AdN = mkAdN "تقریبا" ; almost_AdA, almost_AdN = mkAdN "تقریبا" ;
@@ -13,8 +13,8 @@ concrete StructuralUrd of Structural = CatUrd **
always_AdV = ss "ہمیشہ" ; always_AdV = ss "ہمیشہ" ;
and_Conj = sd2 [] "اور" ** {n = Pl} ; and_Conj = sd2 [] "اور" ** {n = Pl} ;
because_Subj = ss "كیونكہ" ; because_Subj = ss "كیونكہ" ;
before_Prep = mkPrep "پہلے" "پہلے" ; before_Prep = mkPrep ["سے پہلے"] ["سے پہلے"] ;
behind_Prep = mkPrep "پیچھے" "پیچھے" ; behind_Prep = mkPrep ["كے پیچھے"] ["كے پیچھے"] ;
between_Prep = mkPrep "درمیاں" "درمیاں" ; between_Prep = mkPrep "درمیاں" "درمیاں" ;
both7and_DConj = sd2 "دونوں" "اور" ** {n = Pl} ; both7and_DConj = sd2 "دونوں" "اور" ** {n = Pl} ;
but_PConj = ss "لیكن" ; but_PConj = ss "لیكن" ;

View File

@@ -1,6 +1,6 @@
concrete TextUrd of Text = CommonX - [Temp,TTAnt,Tense,TPres,TPast,TFut,TCond] ** { concrete TextUrd of Text = CommonX - [Temp,TTAnt,Tense,TPres,TPast,TFut,TCond] ** {
-- This works for the special punctuation marks of Urdu but still browser does not display them well so left balnk. -- This works for the special punctuation marks of Urdu.
lin lin
TEmpty = {s = []} ; TEmpty = {s = []} ;

View File

@@ -112,4 +112,137 @@ Clause : Type = {s : VPHTense => Polarity => Order => Str} ;
_ => ppf ! Dir ++ "nE" _ => ppf ! Dir ++ "nE"
} }
} ; } ;
conjThat = "kh" ;
insertSubj : UPerson -> Str -> Str = \p,s ->
case p of { Pers1 => s ++ "waN" ; _ => s ++ "E"}; -- check with prasad for vn~
agr = "agr" ;
awr = "awr" ;
ky = "ky" ;
jn = "jn" ;
js = "js" ;
jw = "jw" ;
kw = "kw" ;
mt = "mt" ;
nE = "nE" ;
nh = "na" ;
sE = "sE" ;
waN = "waN" ;
hE = "hE" ;
comma = "," ;
indfArt = "ak" ;
kwd = "Kwd" ;
copula : CTense -> Number -> UPerson -> Gender -> Str = \t,n,p,g ->
case <t,n,p,g> of {
<CPresent,Sg,Pers1,_ > => "hwN" ;
<CPresent,Sg,Pers2_Casual,_ > => "hE";
<CPresent,Sg,Pers2_Familiar,_ > => "hw" ;
<CPresent,Sg,Pers2_Respect,_ > => "hyN" ;
<CPresent,Sg,Pers3_Near,_ > => "hE" ;
<CPresent,Sg,Pers3_Distant,_ > => "hE" ;
<CPresent,Pl,Pers1,_ > => "hyN" ;
<CPresent,Pl,Pers2_Casual,_ > => "hw" ;
<CPresent,Pl,Pers2_Familiar,_ > => "hw" ;
<CPresent,Pl,Pers2_Respect,_ > => "hyN" ;
<CPresent,Pl,Pers3_Near,_ > => "hyN" ;
<CPresent,Pl,Pers3_Distant,_ > => "hyN" ;
<CPast,Sg,Pers1,Masc > => "th'a" ;
<CPast,Sg,Pers1,Fem > => "th'y" ;
<CPast,Sg,Pers2_Casual,Masc > => "th'a" ;
<CPast,Sg,Pers2_Casual,Fem > => "th'y" ;
<CPast,Sg,Pers2_Familiar,Masc > => "th-a" ;
<CPast,Sg,Pers2_Familiar,Fem > => "th'y" ;
<CPast,Sg,Pers2_Respect,Masc > => "th'E" ;
<CPast,Sg,Pers2_Respect,Fem > => "th'yN" ;
<CPast,Sg,Pers3_Near,Masc > => "th-a" ;
<CPast,Sg,Pers3_Near,Fem > => "th'y" ;
<CPast,Sg,Pers3_Distant,Masc > => "th-a" ;
<CPast,Sg,Pers3_Distant,Fem > => "th'y" ;
<CPast,Pl,Pers1,Masc > => "th'E" ;
<CPast,Pl,Pers1,Fem > => "th'yN" ;
<CPast,Pl,Pers2_Casual,Masc > => "th'E" ;
<CPast,Pl,Pers2_Casual,Fem > => "th'yN" ;
<CPast,Pl,Pers2_Familiar,Masc > => "th'E" ;
<CPast,Pl,Pers2_Familiar,Fem > => "th'yN" ;
<CPast,Pl,Pers2_Respect,Masc > => "th'E" ;
<CPast,Pl,Pers2_Respect,Fem > => "th'yN" ;
<CPast,Pl,Pers3_Near,Masc > => "th'E" ;
<CPast,Pl,Pers3_Near,Fem > => "th'yN" ;
<CPast,Pl,Pers3_Distant,Masc > => "th'E" ;
<CPast,Pl,Pers3_Distant,Fem > => "th'yN" ;
<CFuture,Sg,Pers1,Masc > => "ga" ;
<CFuture,Sg,Pers1,Fem > => "gy" ;
<CFuture,Sg,Pers2_Casual,Masc > => "ga" ;
<CFuture,Sg,Pers2_Casual,Fem > => "gy" ;
<CFuture,Sg,Pers2_Familiar,Masc > => "gE" ;
<CFuture,Sg,Pers2_Familiar,Fem > => "gy" ;
<CFuture,Sg,Pers2_Respect,Masc > => "gE" ;
<CFuture,Sg,Pers2_Respect,Fem > => "gy" ;
<CFuture,Sg,Pers3_Near,Masc > => "ga" ;
<CFuture,Sg,Pers3_Near,Fem > => "gy" ;
<CFuture,Sg,Pers3_Distant,Masc > => "ga" ;
<CFuture,Sg,Pers3_Distant,Fem > => "gy" ;
<CFuture,Pl,Pers1,Masc > => "gE" ;
<CFuture,Pl,Pers1,Fem > => "gy" ;
<CFuture,Pl,Pers2_Casual,Masc > => "gE" ;
<CFuture,Pl,Pers2_Casual,Fem > => "gy" ;
<CFuture,Pl,Pers2_Familiar,Masc > => "gE" ;
<CFuture,Pl,Pers2_Familiar,Fem > => "gy" ;
<CFuture,Pl,Pers2_Respect,Masc > => "gE" ;
<CFuture,Pl,Pers2_Respect,Fem > => "gy" ;
<CFuture,Pl,Pers3_Near,Masc > => "gE" ;
<CFuture,Pl,Pers3_Near,Fem > => "gE" ;
<CFuture,Pl,Pers3_Distant,Masc > => "gE" ;
<CFuture,Pl,Pers3_Distant,Fem > => "gy"
} ;
raha : Gender -> Number -> Str = \g,n ->
(regAdjective "rha").s ! n ! g ! Dir ! Posit ;
cka : Gender -> Number -> Str = \g,n ->
(regAdjective "cka").s ! n ! g ! Dir ! Posit ;
hw : UPerson -> Number -> Str = \pp,n ->
case <pp,n> of {
<Pers1,_> => "hwN";
<_,Pl> => "hwN";
<_,_> => "hw"
};
hwa : Agr -> Str = \agr ->
let n = (fromAgr agr).n;
p = (fromAgr agr).p;
g = (fromAgr agr).g;
in
case <n,g> of {
<Sg,Masc> => "hwa";
<Sg,Fem> => "hwy";
<Pl,Masc> => "hwE" ;
<Pl,Fem> => "hwy"
};
-----------------------------------------------
-- Hindustani Adjectives
-----------------------------------------------
Adjective = { s: Number => Gender => Case => Degree => Str };
regAdjective : Str -> Adjective;
regAdjective x = case x of {
acch + ("a"|"aN") => mkAdjective x ("bht" ++ x) ("sb sE" ++ x) (acch + "E") ("bht" ++ acch + "E") ("sb sE" ++ acch + "E") (acch + "E") ("bht" ++ acch + "E") ("sb sE" ++ acch + "E")
(acch + "y") ("bht" ++ acch + "y") ("sb sE" ++ acch + "y") (acch + "y") ("bht" ++ acch + "y") ("sb sE" ++ acch + "y") (acch + "y") ("bht" ++ acch + "y") ("sb sE" ++ acch + "y")
(acch +"E") ("bht" ++ acch + "E") ("sb sE" ++ acch + "E") (acch + "E") ("bht" ++ acch + "E") ("sb sE" ++ acch + "E") (acch + "E") ("bht" ++ acch + "E") ("sb sE" ++ acch + "E")
(acch + "y") ("bht" ++ acch + "y") ("sb sE" ++ acch + "y") (acch + "y") ("bht" ++ acch + "y") ("sb sE" ++ acch + "y") (acch + "y") ("bht" ++ acch + "y") ("sb sE" ++ acch + "y");
_ => mkAdjective x ("bht" ++ x) ("sb sE" ++ x) x ("bht" ++ x) ("sb sE" ++ x) x ("bht" ++ x) ("sb sE" ++ x)
x ("bht" ++ x) ("sb sE" ++ x) x ("bht" ++ x) ("sb sE" ++ x) x ("bht" ++ x) ("sb sE" ++ x)
x ("bht" ++ x) ("sb sE" ++ x) x ("bht" ++ x) ("sb sE" ++ x) x ("bht" ++ x) ("sb sE" ++ x)
x ("bht" ++ x) ("sb sE" ++ x) x ("bht" ++ x) ("sb sE" ++ x) x ("bht" ++ x) ("sb sE" ++ x)
};
} }

View File

@@ -119,7 +119,7 @@ concrete LexiconUrd of Lexicon = CatUrd **
love_N = mkN "mHbt" ; love_N = mkN "mHbt" ;
love_V2 = mkV2 (compoundV "pyar" do_V2) "kw"; love_V2 = mkV2 (compoundV "pyar" do_V2) "kw";
man_N = mkN "Admy" "Admy" "Admy" "Admy" "AdmywN" "Admyw" masculine ; man_N = mkN "Admy" "Admy" "Admy" "Admy" "AdmywN" "Admyw" masculine ;
married_A2 = mkA "[Xady krna]" "sE" ; married_A2 = mkA "Xady Xdh" "sE" ;
meat_N = mkN "gwXt" ; meat_N = mkN "gwXt" ;
milk_N = mkN "dwdh'" ; milk_N = mkN "dwdh'" ;
moon_N = mkN "cand" ; moon_N = mkN "cand" ;
@@ -162,7 +162,7 @@ concrete LexiconUrd of Lexicon = CatUrd **
seek_V2 = mkV2 (compoundV "tlaX" do_V2) ; seek_V2 = mkV2 (compoundV "tlaX" do_V2) ;
see_V2 = mkV2 (mkV "dykh'na") ; see_V2 = mkV2 (mkV "dykh'na") ;
sell_V3 = mkV3 (mkV "bycna") "kw" ""; sell_V3 = mkV3 (mkV "bycna") "kw" "";
send_V3 = mkV3 (mkV "bh'yjna") "kw" "kw"; send_V3 = mkV3 (mkV "bh'yjna") "kw" "";
sheep_N = mkN "bh'yR" feminine ; sheep_N = mkN "bh'yR" feminine ;
ship_N = mkN "jhaz" ; ship_N = mkN "jhaz" ;
shirt_N = mkN "qmyS" feminine; shirt_N = mkN "qmyS" feminine;
@@ -361,7 +361,7 @@ concrete LexiconUrd of Lexicon = CatUrd **
---- added 4/6/2007 ---- added 4/6/2007
john_PN = mkPN "jan" ; john_PN = mkPN "jan" ;
question_N = mkN "swal" ; question_N = mkN "swal" ;
-- ready_A = regA "ready" ; ready_A = mkA "tyar" ;
reason_N = mkN "wjh" feminine ; reason_N = mkN "wjh" feminine ;
today_Adv = mkAdv "Aj" ; today_Adv = mkAdv "Aj" ;
uncertain_A = mkA ["Gyryqyny"] ; uncertain_A = mkA ["Gyryqyny"] ;

View File

@@ -5,7 +5,7 @@ concrete StructuralUrd of Structural = CatUrd **
coding = utf8; coding = utf8;
lin lin
above_Prep = mkPrep "awpr" "awpr" ; above_Prep = mkPrep ["kE awpr"] ["kE awpr"] ;
after_Prep = mkPrep ["kE bed"] ["kE bed"] ; after_Prep = mkPrep ["kE bed"] ["kE bed"] ;
all_Predet = ss "tmam" ; all_Predet = ss "tmam" ;
almost_AdA, almost_AdN = mkAdN "tqryba" ; almost_AdA, almost_AdN = mkAdN "tqryba" ;
@@ -13,8 +13,8 @@ concrete StructuralUrd of Structural = CatUrd **
always_AdV = ss "hmyXh" ; always_AdV = ss "hmyXh" ;
and_Conj = sd2 [] "awr" ** {n = Pl} ; and_Conj = sd2 [] "awr" ** {n = Pl} ;
because_Subj = ss "kywnkh" ; because_Subj = ss "kywnkh" ;
before_Prep = mkPrep "phlE" "phlE" ; before_Prep = mkPrep ["sE phlE"] ["sE phlE"] ;
behind_Prep = mkPrep "pych'E" "pych'E" ; behind_Prep = mkPrep ["kE pych'E"] ["kE pych'E"] ;
between_Prep = mkPrep "drmyaN" "drmyaN" ; between_Prep = mkPrep "drmyaN" "drmyaN" ;
both7and_DConj = sd2 "dwnwN" "awr" ** {n = Pl} ; both7and_DConj = sd2 "dwnwN" "awr" ** {n = Pl} ;
but_PConj = ss "lykn" ; but_PConj = ss "lykn" ;
@@ -72,7 +72,7 @@ concrete StructuralUrd of Structural = CatUrd **
possess_Prep = mkPrep "ka" "ky" ; possess_Prep = mkPrep "ka" "ky" ;
quite_Adv = ss "KamwX" ; quite_Adv = ss "KamwX" ;
she_Pron = personalPN "wh" "as" "wh" ["as ky"] ["as ky"] ["as kE"] ["as ky"] Sg Fem Pers3_Distant ; she_Pron = personalPN "wh" "as" "wh" ["as ky"] ["as ky"] ["as kE"] ["as ky"] Sg Fem Pers3_Distant ;
so_AdA = ss "[as lyE]" ; so_AdA = ss "as lyE" ;
somebody_NP = MassNP (UseN (ParadigmsUrd.mkN "kwy" "kwy" "kwy" "kwy" "kwy" "kwy" Masc )); somebody_NP = MassNP (UseN (ParadigmsUrd.mkN "kwy" "kwy" "kwy" "kwy" "kwy" "kwy" Masc ));
someSg_Det = mkDet "kch'" "kch'" "kch'" "kch'" Sg ; someSg_Det = mkDet "kch'" "kch'" "kch'" "kch'" Sg ;
somePl_Det = mkDet "kch'" "kch'" "kch'" "kch'" Pl ; somePl_Det = mkDet "kch'" "kch'" "kch'" "kch'" Pl ;
@@ -89,7 +89,7 @@ concrete StructuralUrd of Structural = CatUrd **
through_Prep = mkPrep ["myN sE"] ["myN sE"] ; through_Prep = mkPrep ["myN sE"] ["myN sE"] ;
too_AdA = ss "bht" ; too_AdA = ss "bht" ;
to_Prep = mkPrep "kw" "kw" ; -- ** {lock_Prep = <>}; to_Prep = mkPrep "kw" "kw" ; -- ** {lock_Prep = <>};
under_Prep = mkPrep "nycE" "nycE" ; -- ** {lock_Prep = <>}; under_Prep = mkPrep "kE nycE" "kE nycE" ; -- ** {lock_Prep = <>};
very_AdA = ss "bht" ; very_AdA = ss "bht" ;
want_VV = mkV "cahna" ** { isAux = False} ; want_VV = mkV "cahna" ** { isAux = False} ;
we_Pron = personalPN "hm" "hm" "hm" "hmara" "hmary" "hmarE" "hmary" Pl Masc Pers1 ; we_Pron = personalPN "hm" "hm" "hm" "hmara" "hmary" "hmarE" "hmary" Pl Masc Pers1 ;
@@ -118,7 +118,7 @@ concrete StructuralUrd of Structural = CatUrd **
at_least_AdN = mkAdN ["km az km"] ; at_least_AdN = mkAdN ["km az km"] ;
at_most_AdN = mkAdN ["zyadh sE zyadh"]; at_most_AdN = mkAdN ["zyadh sE zyadh"];
nothing_NP = MassNP (UseN (ParadigmsUrd.mkN "kwy cyz nhyN" "kwy cyz nhyN" "kwy cyz nhyN" "kwy cyz nhyN" "kwy cyz nhyN" "kwy cyz nhyN" Masc )); nothing_NP = MassNP (UseN (ParadigmsUrd.mkN "kwy cyz nhyN" "kwy cyz nhyN" "kwy cyz nhyN" "kwy cyz nhyN" "kwy cyz nhyN" "kwy cyz nhyN" Masc ));
except_Prep = mkPrep "swaE" "swaE" ; except_Prep = mkPrep "kE swaE" "kE swaE" ;
nobody_NP = MassNP (UseN (ParadigmsUrd.mkN "kwy nhyN" "kwy nhyN" "kwy nhyN" "kwy nhyN" "kwy nhyN" "kwy nhyN" Masc )); nobody_NP = MassNP (UseN (ParadigmsUrd.mkN "kwy nhyN" "kwy nhyN" "kwy nhyN" "kwy nhyN" "kwy nhyN" "kwy nhyN" Masc ));
as_CAdv = {s = "atna" ; p = "jtna"} ; as_CAdv = {s = "atna" ; p = "jtna"} ;

View File

@@ -123,15 +123,16 @@ transDevanagari :: Transliteration
transDevanagari = transDevanagari =
(mkTransliteration "Devanagari" (mkTransliteration "Devanagari"
allTransUrduHindi allCodes){invisible_chars = ["a"]} where allTransUrduHindi allCodes){invisible_chars = ["a"]} where
allCodes = [0x0900 .. 0x095f] allCodes = [0x0900 .. 0x095f] ++ [0x0966 .. 0x096f]
allTransUrduHindi = words $ allTransUrduHindi = words $
"- M N - - a- A- i- I- u- U- R- - - - e- " ++ "- n~ m. h. - A A: I I: U U: r.- l.- - - E: " ++
"E- - - o- O- k K g G N: c C j J n: t. " ++ "E+ - - O: O+ k k' g g' n- c c' j j' n* T " ++
"T. d. D. n. t T d D n - p P b B m y " ++ "T' D D' N t t' d d' n - p p' b b' m y " ++
"r - l - - v S s. s h - - r: - A i " ++ "r - l L - v s* S s h - - X~ - a: i " ++
"I u U R - - - e E o O - - - - - " ++ "i: u u: r. l. - - e: e+ - - o: o+ X, - - " ++
"- - - - - - - - - - - z r. - - - " "- - - - - - - - q x g. z R R' f - " ++
"N0 N1 N2 N3 N4 N5 N6 N7 N8 N9 "
transUrdu :: Transliteration transUrdu :: Transliteration
@@ -150,7 +151,7 @@ transUrdu =
transSindhi :: Transliteration transSindhi :: Transliteration
transSindhi = transSindhi =
(mkTransliteration "Sindhi" allTrans allCodes) where (mkTransliteration "Sindhi" allTrans allCodes) where
allCodes = [0x0626 .. 0x062f] ++ [0x0630 .. 0x063a] ++ [0x0641 .. 0x0648] ++ allCodes = [0x062e] ++ [0x0627 .. 0x062f] ++ [0x0630 .. 0x063a] ++ [0x0641 .. 0x0648] ++
[0x067a,0x067b,0x067d,0x067e,0x067f] ++ [0x0680 .. 0x068f] ++ [0x067a,0x067b,0x067d,0x067e,0x067f] ++ [0x0680 .. 0x068f] ++
[0x0699,0x0918,0x06a6,0x061d,0x06a9,0x06af,0x06b3,0x06bb,0x06be,0x06f6,0x06cc,0x06b1, 0x06aa, 0x06fd, 0x06fe] ++ [0x0699,0x0918,0x06a6,0x061d,0x06a9,0x06af,0x06b3,0x06bb,0x06be,0x06f6,0x06cc,0x06b1, 0x06aa, 0x06fd, 0x06fe] ++
[0x06f0 .. 0x06f9] ++ [0x061f,0x06D4] [0x06f0 .. 0x06f9] ++ [0x061f,0x06D4]