resource ResSlo = open Prelude in { -- AR March 2020 -- sources: -- Wiki = https://en.wikipedia.org/wiki/Czech_declension, https://en.wikipedia.org/wiki/Czech_conjugation -- CEG = J. Naughton, Czech: an Essential Grammar, Routledge 2005. -- parameters param Number = Sg | Pl ; Animacy = Anim | Inanim ; Gender = Masc Animacy | Fem | Neutr ; Case = Nom | Gen | Dat | Acc | Loc | Ins ; -- traditional order Person = P1 | P2 | P3 ; Agr = Ag Gender Number Person ; CTense = CTPres | CTPast ; ----- TODO complete the tense system to match Czech verb morphology -- phonology oper hardConsonant : pattern Str = #("d"|"t"|"g"|"h"|"k"|"n"|"r") ; softConsonant : pattern Str = #("ť"|"ď"|"j"|"ň"|"š"|"c"|"č"|"ž"|"ľ"|"ĺ"|"ŕ"|"dz") ; neutralConsonant : pattern Str = #("b"|"f"|"l"|"m"|"p"|"s"|"v") ; consonant : pattern Str = #( "d" | "t" | "g" | "h" | "k" | "n" | "r" | "ť" | "ď" | "j" | "ň" | "š" | "c" | "č" | "ž" | "b" | "f" | "l" | "m" | "p" | "s" | "v" | "ľ" | "ĺ" | "ŕ" | "dz" ) ; dropFleetingE : Str -> Str = \s -> case s of { x + "e" + c@("k"|"c"|"n") => x + c ; x + "e" + "ň" => x + "n" ; _ => s } ; shortenVowel : Str -> Str = \s -> case s of { x + "á" + y => x + "a" + y ; x + "é" + y => x + "e" + y ; x + "í" + y => x + "i" + y ; x + "ý" + y => x + "y" + y ; x + "ó" + y => x + "o" + y ; x + "ú" + y => x + "u" + y ; x + "ů" + y => x + "o" + y ; _ => s } ; addI : Str -> Str = \s -> case s of { klu + "k" => klu + "ci" ; vra + "h" => vra + "zi" ; ce + "ch" => ce + "ši" ; dokto + "r" => dokto + "ři" ; pan => pan + "i" } ; addAdjI : Str -> Str = \s -> case s of { angli + "ck" => angli + "čtí" ; ce + "sk" => ce + "ští" ; _ => init (addI s) + "í" } ; -- 3.4.10, in particular when also final 'a' is dropped addE : Str -> Str = \s -> case s of { re + "k" => re + "ce" ; pra + ("g"|"h") => pra + "ze" ; stre + "ch" => stre + "še" ; sest + "r" => sest + "ře" ; pan => pan + "ě" } ; addEch : Str -> Str = \s -> case s of { klu + "k" => klu + "cich" ; vra + ("h"|"g") => vra + "zich" ; ce + "ch" => ce + "šich" ; pan => pan + "ech" } ; shortFemPlGen : Str -> Str = \s -> case s of { ul + "ice" => ul + "ic" ; koleg + "yně" => koleg + "yň" ; ruz + "e" => ruz + "í" ; _ => Predef.error ("shortFemPlGen does not apply to" ++ s) } ; --------------- -- Nouns --------------- -- https://en.wikipedia.org/wiki/Slovak_declension -- http://www.angelfire.com/sk3/quality/Slovak_declension.html -- novel idea (for RGL): lexical items stored as records rather than tables -- advantages: -- - easier to make exceptions to paradigms (by ** {}) -- - easier to keep the number of forms minimal -- - easier to see what is happening than with lots of anonymous arguments to mkN, mkA, mkV -- so this is the lincat of N NounForms : Type = {snom,sgen,sdat,sacc,sloc,sins, pnom,pgen,pdat,pacc,ploc,pins : Str ; g : Gender} ; -- But traditional tables make agreement easier to handle in syntax -- so this is the lincat of CN Noun : Type = {s : Number => Case => Str ; g : Gender} ; -- this is used in UseN nounFormsNoun : NounForms -> Noun = \forms -> { s = table { Sg => table { Nom => forms.snom ; Gen => forms.sgen ; Dat => forms.sdat ; Acc => forms.sacc ; Loc => forms.sloc ; Ins => forms.sins } ; Pl => table { Nom => forms.pnom ; Gen => forms.pgen ; Dat => forms.pdat ; Acc => forms.pacc ; Loc => forms.ploc ; Ins => forms.pins } } ; g = forms.g } ; -- terminology of CEG DeclensionType : Type = Str -> NounForms ; declensionNounForms : (snom,pgen : Str) -> Gender -> NounForms = \snom,pgen,g -> case of { => hrdinaN snom ; => ponyN snom ; ---- => hrdinaN snom ; => strojN snom ; => dubN snom ; => dubN snom ; => zenaN snom ; => zenaN snom ; => ulicaN snom ; => ulicaN snom ; => kostN snom pgen ; => dlanN snom pgen ; => mestoN snom ; => vysvedcenieN snom ; => srdceN snom ; => dievceniecN snom ; => dievcaN snom ; _ => Predef.error ("cannot infer declension type for" ++ snom ++ pgen) } ** {pgen = pgen ; g = g} ; -- the "smartest" one-argument mkN guessNounForms : Str -> NounForms = \snom -> case snom of { _ + ("i"|"y"|"e") => ponyN snom ; _ + #softConsonant => strojN snom ; _ + #hardConsonant => dubN snom ; _ + #neutralConsonant => dubN snom ; _ + #hardConsonant + "a" => zenaN snom ; _ + #neutralConsonant + "a" => zenaN snom ; _ + #softConsonant + "a" => ulicaN snom ; _ + ("ia"|"ya") => ulicaN snom ; _ + "o" => mestoN snom ; _ + "ie" => vysvedcenieN snom ; _ + "e" => srdceN snom ; _ + "ä" => dievcaN snom ; _ => Predef.error ("cannot guess declension type for" ++ snom) } ; -- the traditional declensions, in both CEG and Wiki -- they are also exported in ParadigmsSlo with names chlapN etc chlapN : DeclensionType = \chlap -> { snom = chlap ; sgen,sacc = chlap + "a" ; sdat,sloc = chlap + "ovi" ; sins = chlap + "om" ; pnom = chlap + "i" ; pgen,pacc = chlap + "ov" ; pdat = chlap + "om" ; ploc = chlap + "och" ; pins = chlap + "mi" ; g = Masc Anim } ; hrdinaN : DeclensionType = \hrdina -> let hrdin = init hrdina in { snom = hrdina ; sgen,sacc = hrdin + "u" ; sdat,sloc = hrdin + "ovi" ; sins = hrdin + "om" ; pnom = hrdin + "ovia" ; pgen,pacc = hrdin + "ov" ; pdat = hrdin + "om" ; ploc = hrdin + "och" ; pins = hrdin + "ami" ; g = Masc Anim } ; dubN : DeclensionType = \dub -> { snom = dub ; sgen = dub + "a" ; sdat = dub + "u" ; sacc = dub + "" ; sloc = dub + "e" ; sins = dub + "om" ; pnom = dub + "y" ; pgen = dub + "ov" ; pdat = dub + "om" ; pacc = dub + "y" ; ploc = dub + "och" ; pins = dub + "mi" ; g = Masc Inanim } ; strojN : DeclensionType = \stroj -> { snom = stroj ; sgen = stroj + "a" ; sdat = stroj + "u" ; sacc = stroj + "" ; sloc = stroj + "i" ; sins = stroj + "om" ; pnom = stroj + "e" ; pgen = stroj + "ov" ; pdat = stroj + "om" ; pacc = stroj + "e" ; ploc = stroj + "och" ; pins = stroj + "mi" ; g = Masc Inanim } ; -- "fifth type" ponyN : DeclensionType = \pony -> { snom = pony ; sgen = pony + "ho" ; sdat = pony + "mu" ; sacc = pony + "ho" ; sloc = pony + "m" ; sins = pony + "m" ; pnom = pony + "ovia" ; pgen = pony + "ov" ; pdat = pony + "om" ; pacc = pony + "ov" ; ploc = pony + "och" ; pins = pony + "mi" ; g = Masc Anim } ; zenaN : DeclensionType = \zena -> let zen = init zena ; zien : Str = case zen of { z + "e" + c@? => z + "ie" + c ; _ => zen ---- TODO: many more rules } in { snom = zena ; sgen = zen + "y" ; sdat = zen + "e" ; sacc = zen + "u" ; sloc = zen + "e" ; sins = zen + "ou" ; pnom = zen + "y" ; pgen = zien ; pdat = zen + "ám" ; pacc = zen + "y" ; ploc = zen + "ách" ; pins = zen + "ami" ; g = Fem } ; ulicaN : DeclensionType = \ulica -> let ulic = init ulica ; ulíc : Str = case ulic of { ul + "i" + c@? => ul + "í" + c ; _ => ulic } in { snom = ulica ; sgen = ulic + "e" ; sdat = ulic + "i" ; sacc = ulic + "u" ; sloc = ulic + "i" ; sins = ulic + "ou" ; pnom = ulic + "e" ; pgen = ulíc ; pdat = ulic + "iam" ; pacc = ulic + "e" ; ploc = ulic + "iach" ; pins = ulic + "ami" ; g = Fem } ; dlanN : Str -> DeclensionType = \dlanj,dlani -> let dlan : Str = init dlani in { snom = dlanj ; sgen = dlan + "e" ; sdat = dlan + "i" ; sacc = dlanj ; sloc = dlan + "i" ; sins = dlanj + "ou" ; pnom = dlan + "e" ; pgen = dlani ; pdat = dlan + "iam" ; pacc = dlan + "e" ; ploc = dlan + "iach" ; pins = dlanj + "ami" ; g = Fem } ; kostN : Str -> DeclensionType = \kost',kosti -> let kost = init kosti in { snom = kost' ; sgen = kost + "i" ; sdat = kost + "i" ; sacc = kost' ; sloc = kost + "i" ; sins = kost' + "ou" ; pnom = kost + "i" ; pgen = kosti ; pdat = kost + "iam" ; pacc = kost + "i" ; ploc = kost + "iach" ; pins = kost' + "ami" ; g = Fem } ; mestoN : DeclensionType = \mesto -> let mest = init mesto ; miest : Str = case mest of { m + "e" + c@(? | (? + ?)) => m + "ie" + c ; _ => mest ---- TODO: many more rules } in { snom = mesto ; sgen = mest + "a" ; sdat = mest + "u" ; sacc = mesto ; sloc = mest + "e" ; sins = mest + "om" ; pnom = mest + "á" ; pgen = miest ; pdat = mest + "ám" ; pacc = mest + "á" ; ploc = mest + "ách" ; pins = mest + "ami" ; g = Neutr } ; srdceN : DeclensionType = \srdce -> let srdc = init srdce in { snom = srdce ; sgen = srdc + "a" ; sdat = srdc + "u" ; sacc = srdce ; sloc = srdc + "i" ; sins = srdc + "om" ; pnom = srdc + "ia" ; pgen = srdc ; ---- TODO sŕdc pdat = srdc + "iam" ; pacc = srdc + "ia" ; ploc = srdc + "iach" ; pins = srdc + "ami" ; g = Neutr } ; vysvedcenieN : DeclensionType = \vysvedcenie -> let vysvedceni = init vysvedcenie ; vysvedcen = init vysvedceni in { snom = vysvedcenie ; sgen = vysvedceni + "a" ; sdat = vysvedceni + "u" ; sacc = vysvedcenie ; sloc = vysvedcen + "í" ; sins = vysvedcen + "ím" ; pnom = vysvedceni + "a" ; pgen = vysvedcen + "í" ; pdat = vysvedceni + "am" ; pacc = vysvedceni + "a" ; ploc = vysvedceni + "ach" ; pins = vysvedceni + "ami" ; g = Neutr } ; dievcaN : DeclensionType = \dievca -> let dievc = init dievca in { snom = dievca ; sgen = dievca + "ťa" ; sdat = dievca + "ťu" ; sacc = dievca ; sloc = dievca + "ti" ; sins = dievca + "ťom" ; pnom = dievca + "tá" ; pgen = dievc + "iat" ; pdat = dievca + "tám" ; pacc = dievca + "tá" ; ploc = dievca + "tách" ; pins = dievca + "tami" ; g = Neutr } ; -- with variant plural forms of the previous dievceniecN : DeclensionType = \dievca -> let dievc = init dievca in dievcaN dievca ** { pnom = dievc + "ence" ; pgen = dievc + "eniec" ; pdat = dievc + "encom" ; pacc = dievc + "ence" ; ploc = dievc + "encoch" ; pins = dievc + "encami" ; } ; --------------------------- -- Adjectives -- to be used for AP: 56 forms for each degree Adjective : Type = {s : Gender => Number => Case => Str} ; -- to be used for A, in three degrees: 15 forms in each ---- TODO other degrees than positive AdjForms : Type = { msnom, fsnom, nsnom : Str ; msgen, fsgen : Str ; -- nsgen = msgen, pacc = fsgen msdat, fsdat : Str ; -- nsdat = msdat fsacc : Str ; -- amsacc = msgen, imsacc = msnom, nsacc = nsnom msloc : Str ; -- fsloc = fsdat, nsloc = msloc msins, fsins : Str ; -- nsins = msins, pdat = msins mpnom,fpnom : Str ; -- impnom = fpnom, npnom = fsnom pgen : Str ; -- ploc = pgen pins : Str ; } ; -- used in PositA but will also work in Compar and Superl by calling their record fields adjFormsAdjective : AdjForms -> Adjective = \afs -> { s = \\g,n,c => case of { | => afs.msnom ; | => afs.fsnom ; => afs.nsnom ; | => afs.msgen ; | => afs.fsgen ; => afs.msdat ; => afs.fsdat ; => afs.fsacc ; => afs.msloc ; | => afs.msins ; => afs.fsins ; => afs.mpnom ; => afs.fpnom ; => afs.pgen ; => afs.pins } } ; -- hard declension mladyAdjForms : Str -> AdjForms = \mlady -> let mlad = init mlady in { msnom = mlad + "ý" ; fsnom = mlad + "á" ; nsnom,fsgen,fsdat,fpnom = mlad + "é" ; msgen = mlad + "ého" ; msdat = mlad + "ému" ; fsacc,fsins = mlad + "ou" ; msloc = mlad + "ém" ; msins,pdat = mlad + "ým" ; mpnom = addAdjI mlad ; pgen = mlad + "ých" ; pins = mlad + "ými" ; } ; -- soft declension jarniAdjForms : Str -> AdjForms = \jarni -> { msnom,fsnom,nsnom, fsgen,fsdat,fsacc,fsins, mpnom,fpnom = jarni ; msgen = jarni + "ho" ; msdat = jarni + "mu" ; msloc,msins = jarni + "m" ; pgen = jarni + "ch" ; pins = jarni + "mi" ; } ; -- masculine possession: the same endings as in feminine otcuvAdjForms : Str -> AdjForms = \otcuv -> let otcov = Predef.tk 2 otcuv + "ov" in matcinAdjForms otcov ** {msnom = otcuv} ; -- feminine possession matcinAdjForms : Str -> AdjForms = \matcin -> { msnom = matcin ; fsnom,msgen = matcin + "a" ; nsnom = matcin + "o" ; fsgen,fpnom = matcin + "y" ; msdat,fsacc = matcin + "u" ; fsdat,msloc = matcin + "ě" ; msins = matcin + "ým" ; fsins = matcin + "ou" ; mpnom = matcin + "i" ; pgen = matcin + "ých" ; pins = matcin + "ými" ; } ; --------------------- -- Verbs VerbForms : Type = { ---- TODO more forms to add inf, pressg1, pressg2, pressg3, prespl1, prespl2, prespl3, pastpartsg, pastpartpl, ---- passpart, negpressg3 : Str -- matters only for copula } ; ComplementCase : Type = {s : Str ; c : Case ; hasPrep : Bool} ; verbAgr : VerbForms -> Agr -> Bool -> Str ---- TODO tenses = \vf,a,b -> case a of { Ag _ Sg P1 => vf.pressg1 ; Ag _ Sg P2 => vf.pressg2 ; Ag _ Sg P3 => case b of { True => vf.pressg3 ; False => vf.negpressg3 -- matters only for copula } ; Ag _ Pl P1 => vf.prespl1 ; Ag _ Pl P2 => vf.prespl2 ; Ag _ Pl P3 => vf.prespl3 } ; copulaVerbForms : VerbForms = { inf = "být" ; pressg1 = "jsem" ; pressg2 = "jsi" ; pressg3 = "je" ; prespl1 = "jsme" ; prespl2 = "jste" ; prespl3 = "jsou" ; pastpartsg = "byl" ; pastpartpl = "byli" ; negpressg3 = "ní" ; -- ne is added to this } ; haveVerbForms : VerbForms = { inf = "mít" ; pressg1 = "mám" ; pressg2 = "máš" ; pressg3, negpressg3 = "má" ; prespl1 = "máme" ; prespl2 = "máte" ; prespl3 = "mají" ; pastpartsg = "měl" ; pastpartpl = "měli" ; } ; -- just an example of a traditional paradigm ---- TODO other traditional paradigms iii_kupovatVerbForms : Str -> VerbForms = \kupovat -> let kupo = Predef.tk 3 kupovat ; kupu = Predef.tk 1 kupo + "u" in { inf = kupovat ; pressg1 = kupu + "ji" ; --- kupuju pressg2 = kupu + "ješ" ; pressg3, negpressg3 = kupu + "je" ; prespl1 = kupu + "jeme" ; prespl2 = kupu + "jete" ; prespl3 = kupu + "jí" ; --- kupujou pastpartsg = kupo + "val" ; pastpartpl = kupo + "vali" ; } ; --------------------------- -- Pronouns PronForms : Type = { nom, cnom, -- cnom is the pro-drop subject gen, cgen,pgen, -- bare, clitic, prepositional acc, cacc,pacc, dat, cdat,pdat, loc, ins,pins : Str ; a : Agr } ; ---- TODO: possessives personalPron : Agr -> PronForms = \a -> {a = a ; cnom = []} ** case a of { Ag _ Sg P1 => { nom = "já" ; gen,acc,pgen,pacc = "mne" ; cgen,cacc = "mě" ; dat,pdat,loc = "mně" ; cdat = "mi" ; ins,pins = "mnou" } ; Ag _ Sg P2 => { nom = "ty" ; gen,acc,pgen,pacc = "tebe" ; cgen,cacc = "tě" ; dat,pdat,loc = "tobě" ; cdat = "ti" ; ins,pins = "tebou" } ; Ag (Masc _) Sg P3 => { nom = "on" ; gen,acc = "jeho" ; cgen,cacc = "ho" ; pgen,pacc = "něho" ; dat = "jemu" ; cdat = "mu" ; pdat = "němu" ; loc = "něm" ; ins = "jím" ; pins = "ním" ; } ; Ag Fem Sg P3 => { nom = "ona" ; gen = "její" ; dat,acc,cgen,cacc,cdat,ins = "ji" ; pgen,pdat,pacc,loc,pins = "ní" ; } ; Ag Neutr Sg P3 => { nom = "ono" ; gen = "jeho" ; cgen,cacc = "ho" ; pgen = "něho" ; dat = "jemu" ; acc = "je" ; pacc = "ně" ; cdat = "mu" ; pdat = "němu" ; loc = "něm" ; ins = "jím" ; pins = "ním" ; } ; Ag _ Pl P1 => { nom = "my" ; gen,acc, cgen,cacc, pgen,pacc, loc = "nás" ; dat,cdat,pdat = "nám" ; ins,pins = "námi" ; } ; Ag _ Pl P2 => { nom = "vy" ; gen,acc, cgen,cacc, pgen,pacc, loc = "vás" ; dat,cdat,pdat = "vám" ; ins,pins = "vámi" ; } ; Ag g Pl P3 => { nom = case g of { Masc _ => "oni" ; Fem => "ony" ; Neutr => "ona" } ; gen,cgen = "jich" ; pgen = "nich" ; dat,cdat = "jim" ; pdat = "nim" ; acc,cacc = "je" ; pacc = "ně" ; loc = "nich" ; ins = "jimi" ; pins = "nimi" ; } } ; -------------------------------- -- demonstrative pronouns, used for Quant and Det oper DemPronForms : Type = { msnom, fsnom, nsnom, msgen, fsgen, msdat, -- fsdat = fsgen unlike AdjForms fsacc, msloc, msins, fsins, mpnom, fpnom, -- mpacc = fpacc = fpnom pgen, pdat, -- NOT msins like AdjForms pins : Str } ; demPronFormsAdjective : DemPronForms -> Str -> Adjective = \dem,s -> let demAdj = dem ** {fsdat = dem.fsgen} ; adjAdj = adjFormsAdjective demAdj in { s = \\g,n,c => case of { <_,Pl,Dat> => dem.pdat ; => dem.fpnom ; _ => adjAdj.s ! g ! n ! c } + s } ; Determiner : Type = { s : Gender => Case => Str ; size : NumSize } ; mkDemPronForms : Str -> DemPronForms = \t -> { msnom = t + "en" ; fsnom = t + "a" ; nsnom = t + "o" ; msgen = t + "oho" ; fsgen = t + "é" ; msdat = t + "omu" ; fsacc = t + "u" ; msloc = t + "om" ; msins = t + "ím" ; fsins = t + "ou" ; mpnom = t + "i" ; fpnom = t + "y" ; pgen = t + "ěch" ; pdat = t + "ěm" ; pins = t + "ěmi" ; } ; invarDemPronForms : Str -> DemPronForms = \s -> { msnom, fsnom, nsnom, msgen, fsgen, msdat, fsacc, msloc, msins, fsins, mpnom, fpnom, pgen, pdat, pins = s ; } ; -- interrogatives kdoForms : Case => Str = table { Nom => "kdo" ; Gen | Acc => "koho" ; Dat => "komu" ; Loc => "kom" ; Ins => "kým" } ; coForms : Case => Str = table { Nom|Acc => "co" ; Gen => "čeho" ; Dat => "čemu" ; Loc => "čem" ; Ins => "čím" } ; -- Numerals -- singular forms of demonstratives NumeralForms : Type = { msnom, fsnom, nsnom, msgen, fsgen, msdat, fsacc, msloc, msins, fsins : Str } ; numeralFormsDeterminer : NumeralForms -> NumSize -> Determiner = \nume,size -> let dem = nume ** {mpnom, fpnom, pgen, pdat, pins = nume.msnom} ; --- plural forms not used demAdj = dem ** {fsdat = dem.fsgen} ; adjAdj = adjFormsAdjective demAdj in { s = \\g,c => adjAdj.s ! g ! Sg ! c ; size = size } ; -- example: number 1 oneNumeral : Determiner = numeralFormsDeterminer ((mkDemPronForms "jedn") ** {msnom = "jeden"}) Num1 ; -- numbers 2,3,4 ---- to check if everything comes out right with the determiner type twoNumeral : Determiner = let forms = { msnom = "dva" ; fsnom, nsnom, fsacc = "dvě" ; msgen, fsgen, msloc = "dvou" ; msdat, msins, fsins = "dvěma" } in numeralFormsDeterminer forms Num2_4 ; threeNumeral : Determiner = let forms = { msnom, fsnom, nsnom, fsacc, msgen, fsgen = "tři" ; msdat = "třem" ; msloc = "třech" ; msins,fsins = "třemi" ; } in numeralFormsDeterminer forms Num2_4 ; fourNumeral : Determiner = let forms = { msnom, fsnom, nsnom, fsacc = "čtyři" ; msgen, fsgen = "čtyř" ; msdat = "čtyřem" ; msloc = "čtyřech" ; msins,fsins = "čtyřmi" ; } in numeralFormsDeterminer forms Num2_4 ; -- for the numbers 5 upwards regNumeral : Str -> Str -> Determiner = \pet,peti -> let forms = { msnom,fsnom,nsnom = pet ; msgen, fsgen, msdat, fsacc, msloc, msins, fsins = peti } in numeralFormsDeterminer forms Num5 ; invarDeterminer : Str -> NumSize -> Determiner = \sto,size -> regNumeral sto sto ; invarNumeral : Str -> Determiner = \s -> invarDeterminer s Num5 ; -------------------------------- -- combining nouns with numerals param NumSize = Num1 | Num2_4 | Num5 ; -- CEG 6.1 oper numSizeForm : (Number => Case => Str) -> NumSize -> Case -> Str = \cns,n,c -> case n of { Num1 => cns ! Sg ! c ; Num2_4 => cns ! Pl ! c ; Num5 => case c of { Nom | Acc => cns ! Pl ! Gen ; _ => cns ! Pl ! c } } ; numSizeAgr : Gender -> NumSize -> Person -> Agr = \g,ns,p -> case ns of { Num5 => Ag Neutr Sg p ; -- essential grammar 6.1.4 Num2_4 => Ag g Pl p ; Num1 => Ag g Sg p } ; numSizeNumber : NumSize -> Number = \ns -> case ns of { Num1 => Sg ; _ => Pl ---- TO CHECK } ; }