mirror of
https://github.com/GrammaticalFramework/gf-core.git
synced 2026-04-22 11:19:32 -06:00
451 lines
19 KiB
Plaintext
451 lines
19 KiB
Plaintext
--# -path=.:..:../../abstract:../../common:../../english:../kotus
|
|
--# -coding=latin1
|
|
|
|
resource WNKotus = open Kotus, MorphoFin, ParadigmsFin, CatFin, StemFin, Prelude in {
|
|
|
|
-- interpretations of paradigms in KOTUS word list, used in DictFin built with the Finnish Wordnet
|
|
|
|
oper vowelHarmony = vowHarmony ;
|
|
|
|
oper
|
|
|
|
-- lexicon constructors
|
|
|
|
separateN : Str -> N -> N = \s,n -> mkN (s + "_") n ;
|
|
|
|
compoundN : Str -> NForms -> N = \s,nf -> lin N (mkStrN s (nforms2snoun nf)) ;
|
|
|
|
compoundA : Str -> NForms -> N = \s,nf -> lin N (mkStrN s (nforms2snoun nf)) ;
|
|
|
|
compoundAdv = overload {
|
|
compoundAdv : Str -> NForms -> Adv = \s,nf -> mkAdv (s + nf ! 0) ;
|
|
compoundAdv : Str -> Str -> Adv = \s,t -> mkAdv (s + t) ;
|
|
} ;
|
|
|
|
compoundV : Str -> VForms -> V = \s,vf -> mkV (lin VK {s = <table {f => s + vf ! f} : VForms>}) ;
|
|
|
|
mkWN = overload {
|
|
mkWN : (_ : Str) -> N = \s -> mkN s ;
|
|
mkWN : (_,_ : Str) -> N = \s,t -> separateN s (mkN t);
|
|
mkWN : (_ : NForms) -> N = \nf -> lin N (nforms2snoun nf) ;
|
|
mkWN : NForms -> Str -> N = \s,t -> separateN t (lin N (nforms2snoun s)) ;
|
|
mkWN : NForms -> Str -> Str -> N = \s,t,u -> separateN (t ++ u) (lin N (nforms2snoun s)) ;
|
|
mkWN : (_ : N) -> N = \n -> n ;
|
|
mkWN : N -> Str -> N = \n,s -> separateN s n ; --- emansipaation kannattaja
|
|
mkWN : N -> (_,_ : Str) -> N = \n,s,t -> separateN (s ++ t) n ; --- silmäluomien synnynnäinen puuttuminen
|
|
} ;
|
|
|
|
mkWA = overload {
|
|
mkWA : (_ : Str) -> A = \s -> mkA s ;
|
|
mkWA : (_,_ : Str) -> A = \s,t -> mkA (separateN s (mkN t));
|
|
mkWA : (_ : NForms) -> A = \nf -> mkA (lin N (nforms2snoun nf)) ;
|
|
mkWN : NForms -> Str -> A = \s,t -> mkA (separateN t (lin N (nforms2snoun s))) ;
|
|
mkWA : (_ : N) -> A = \n -> mkA n ;
|
|
mkWA : N -> Str -> A = \n,s -> mkA (separateN s n) ; --- emansipaation kannattaja
|
|
mkWA : N -> (_,_ : Str) -> A = \n,s,t -> mkA (separateN (s ++ t) n) ; --- silmäluomien synnynnäinen puuttuminen
|
|
} ;
|
|
|
|
mkWAdv = overload {
|
|
mkWAdv : (_ : Str) -> Adv = \s -> mkAdv s ;
|
|
mkWAdv : (_ : Adv) -> Adv = \a -> a ;
|
|
mkWAdv : NForms -> Adv = \nf -> mkAdv (nf ! 0) ;
|
|
mkWAdv : Adv -> Str -> Adv = \a,s -> mkAdv (s ++ a.s) ;
|
|
mkWAdv : (_,_ : Str) -> Adv = \s,p -> mkAdv (s ++ p) ;
|
|
mkWAdv : (_,_,_ : Str) -> Adv = \s,p,q -> mkAdv (s ++ p ++ q) ;
|
|
} ;
|
|
|
|
mkWV = overload {
|
|
mkWV : (_ : Str) -> V = \s -> mkV s ;
|
|
mkWV : (_ : VForms) -> V = \vf -> mkV (lin VK {s = vf}) ;
|
|
mkWV : (_ : V) -> V = \v -> v ;
|
|
mkWV : VForms -> Str -> V = \vf,s -> mkV (mkV (lin VK {s = vf})) s ;
|
|
} ;
|
|
|
|
mkWV2 = overload {
|
|
mkWV2 : (_ : Str) -> V2 = \s -> mkV2 s ;
|
|
mkWV2 : (_ : VForms) -> V2 = \vf -> mkV2 (lin VK {s = vf}) ;
|
|
mkWV2 : (_ : VForms) -> ParadigmsFin.Case -> V2 = \vf,c -> mkV2 (mkV (lin VK {s = vf})) c ;
|
|
mkWV2 : (_ : V) -> V2 = \v -> mkV2 v ;
|
|
mkWV2 : (_ : V) -> ParadigmsFin.Case -> V2 = \v,c -> mkV2 v c ;
|
|
mkWV2 : (_ : V) -> Str -> V2 = \v,s -> mkV2 (mkV v s) ;
|
|
mkWV2 : VForms -> Str -> V2 = \vf,s -> mkV2 (mkV (mkV (lin VK {s = vf})) s) ;
|
|
} ;
|
|
|
|
mkWV3 = overload {
|
|
mkWV3 : (_ : Str) -> V3 = \s -> dirdirV3 (mkV s) ;
|
|
mkWV3 : (_ : VForms) -> V3 = \vf -> dirdirV3 (mkV (lin VK {s = vf})) ;
|
|
mkWV3 : (_ : V) -> V3 = \v -> dirdirV3 v ;
|
|
mkWV3 : VForms -> Str -> V3 = \vf,s -> dirdirV3 (mkV (mkV (lin VK {s = vf})) s) ;
|
|
} ;
|
|
|
|
|
|
mkWVV = overload {
|
|
mkWVV : (_ : Str) -> VV = \s -> mkVV (mkV s) ;
|
|
mkWVV : (_ : VForms) -> VV = \vf -> mkVV (mkV (lin VK {s = vf})) ;
|
|
mkWVV : (_ : VForms) -> InfForm -> VV = \vf,i -> mkVV (mkV (lin VK {s = vf})) i ;
|
|
mkWVV : (_ : V) -> VV = \v -> mkVV v ;
|
|
mkWVV : VForms -> Str -> VV = \vf,s -> mkVV (mkV (mkV (lin VK {s = vf})) s) ;
|
|
} ;
|
|
|
|
mkWVS = overload {
|
|
mkWVS : (_ : Str) -> VS = \s -> mkVS (mkV s) ;
|
|
mkWVS : (_ : VForms) -> VS = \vf -> mkVS (mkV (lin VK {s = vf})) ;
|
|
mkWVS : (_ : V) -> VS = \v -> mkVS v ;
|
|
mkWVS : VForms -> Str -> VS = \vf,s -> mkVS (mkV (mkV (lin VK {s = vf})) s) ;
|
|
} ;
|
|
|
|
mkWVQ = overload {
|
|
mkWVQ : (_ : Str) -> VQ = \s -> mkVQ (mkV s) ;
|
|
mkWVQ : (_ : VForms) -> VQ = \vf -> mkVQ (mkV (lin VK {s = vf})) ;
|
|
mkWVQ : (_ : V) -> VQ = \v -> mkVQ v ;
|
|
mkWVQ : VForms -> Str -> VQ = \vf,s -> mkVQ (mkV (mkV (lin VK {s = vf})) s) ;
|
|
} ;
|
|
|
|
mkWV2V = overload {
|
|
mkWV2V : (_ : Str) -> V2V = \s -> mkV2Vbare (mkV s) ;
|
|
mkWV2V : (_ : VForms) -> V2V = \vf -> mkV2Vbare (mkV (lin VK {s = vf})) ;
|
|
mkWV2V : (_ : V) -> V2V = \v -> mkV2Vbare v ;
|
|
mkWV2V : VForms -> Str -> V2V = \vf,s -> mkV2Vbare (mkV (mkV (lin VK {s = vf})) s) ;
|
|
} ;
|
|
|
|
mkWVA = overload {
|
|
mkWVA : (_ : Str) -> VA = \s -> mkVAbare (mkV s) ;
|
|
mkWVA : (_ : VForms) -> VA = \vf -> mkVAbare (mkV (lin VK {s = vf})) ;
|
|
mkWVA : (_ : V) -> VA = \v -> mkVAbare v ;
|
|
mkWVA : VForms -> Str -> VA = \vf,s -> mkVAbare (mkV (mkV (lin VK {s = vf})) s) ;
|
|
} ;
|
|
|
|
mkWV2A = overload {
|
|
mkWV2A : (_ : Str) -> V2A = \s -> mkV2Abare (mkV s) ;
|
|
mkWV2A : (_ : VForms) -> V2A = \vf -> mkV2Abare (mkV (lin VK {s = vf})) ;
|
|
mkWV2A : (_ : V) -> V2A = \v -> mkV2Abare v ;
|
|
mkWV2A : VForms -> Str -> V2A = \vf,s -> mkV2Abare (mkV (mkV (lin VK {s = vf})) s) ;
|
|
} ;
|
|
|
|
mkWV2Q = overload {
|
|
mkWV2Q : (_ : Str) -> V2Q = \s -> mkV2Qbare (mkV s) ;
|
|
mkWV2Q : (_ : VForms) -> V2Q = \vf -> mkV2Qbare (mkV (lin VK {s = vf})) ;
|
|
mkWV2Q : (_ : V) -> V2Q = \v -> mkV2Qbare v ;
|
|
mkWV2Q : VForms -> Str -> V2Q = \vf,s -> mkV2Qbare (mkV (mkV (lin VK {s = vf})) s) ;
|
|
} ;
|
|
|
|
mkWV2S = overload {
|
|
mkWV2S : (_ : Str) -> V2S = \s -> mkV2Sbare (mkV s) ;
|
|
mkWV2S : (_ : VForms) -> V2S = \vf -> mkV2Sbare (mkV (lin VK {s = vf})) ;
|
|
mkWV2S : (_ : V) -> V2S = \v -> mkV2Sbare v ;
|
|
mkWV2S : VForms -> Str -> V2S = \vf,s -> mkV2Sbare (mkV (mkV (lin VK {s = vf})) s) ;
|
|
} ;
|
|
|
|
mkWAdV : Str -> AdV = \s -> lin AdV (ss s) ;
|
|
mkWAdA : Str -> AdA = \s -> lin AdA (ss s) ;
|
|
mkWAdN : Str -> AdN = \s -> lin AdN (ss s) ;
|
|
|
|
-- kotus paradigms
|
|
|
|
k1 : Str -> NForms -- 1780 öljy
|
|
= \s -> dUkko s (s + "n") ;
|
|
k1A : Str -> NForms -- 166 yökkö
|
|
= \s -> dUkko s (weakGrade s + "n") ;
|
|
k2 : Str -> NForms -- 1189 ääntely
|
|
= \s -> dSilakka s (s + "n") (s + "j" + getHarmony (last s)) ;
|
|
k3 : Str -> NForms -- 481 ääntiö
|
|
= \s -> dSilakka s (s + "n") (s + "it" + vowelHarmony s) ;
|
|
k4A : Str -> NForms -- 273 äpärikkö
|
|
= \s -> let ws = weakGrade s in
|
|
dSilakka s (ws + "n") (ws + "it" + getHarmony (last s)) ;
|
|
k5 : Str -> NForms -- 3212 öljymaali
|
|
= \s -> case last s of {
|
|
"i" => dPaatti s (s + "n") ;
|
|
_ => dUnix s
|
|
} ;
|
|
k5A : Str -> NForms -- 1959 öylätti
|
|
= \s -> dPaatti s (weakGrade s + "n") ;
|
|
k6 : Str -> NForms -- 1231 öykkäri
|
|
= \s -> dTohtori s ;
|
|
k7 : Str -> NForms -- 81 vuoksi
|
|
= \s -> dArpi s (init s + "en") ;
|
|
k7A : Str -> NForms -- 70 väki
|
|
= \s -> dArpi s (init (weakGrade s) + "en") ;
|
|
k8 : Str -> NForms -- 99 à la carte
|
|
= \s -> dNukke s (s + "n") ;
|
|
k8A : Str -> NForms -- 5 vinaigrette
|
|
= \s -> dNukke s (weakGrade s + "n") ;
|
|
k9 : Str -> NForms -- 696 ääriraja
|
|
= \s -> let a = last s in dSilakka s
|
|
(s + "n")
|
|
(init s + case a of {"a" => "o" ; _ => "ö"} + "j" + a) ;
|
|
k9A : Str -> NForms -- 1040 ääniraita
|
|
= \s -> let a = last s in dSilakka s
|
|
(weakGrade s + "n")
|
|
(init s + case a of {"a" => "o" ; _ => "ö"} + "j" + a) ;
|
|
k10 : Str -> NForms -- 2119 äänittäjä
|
|
= \s -> dSilakka s (s + "n") (init s + "i" + vowelHarmony (last s)) ;
|
|
k10A : Str -> NForms -- 284 änkkä
|
|
= \s -> dSilakka s (weakGrade s + "n") (init s + "i" + vowelHarmony (last s)) ;
|
|
k11 : Str -> NForms -- 46 ödeema
|
|
= \s -> dSilakka s (weakGrade s + "n") (init s + "i" + vowelHarmony (last s)) ;
|
|
k12 : Str -> NForms -- 1125 örinä
|
|
= \s -> let a = vowelHarmony (last s) in
|
|
dSilakka s (s + "n")
|
|
(init s + case a of {"a" => "o" ; _ => "ö"} + "it" + a) ;
|
|
k13 : Str -> NForms -- 157 virtaska
|
|
= \s -> let a = vowelHarmony (last s) in
|
|
dSilakka s (s + "n")
|
|
(init s + case a of {"a" => "o" ; _ => "ö"} + "j" + a) ;
|
|
k14A : Str -> NForms -- 244 ötökkä
|
|
= \s -> let a = vowelHarmony (last s) ; ws = weakGrade s in
|
|
dSilakka s (ws + "n")
|
|
(init ws + case a of {"a" => "o" ; _ => "ö"} + "it" + a) ;
|
|
k15 : Str -> NForms -- 170 äreä
|
|
= dKorkea ;
|
|
k16 : Str -> NForms -- 2 kumpikin --?
|
|
= \s -> let kumpi = Predef.take 5 s ; kin = Predef.drop 5 s in
|
|
\\i => (dSuurempi kumpi ! i + kin) ;
|
|
k16A : Str -> NForms -- 20 ylempi
|
|
= dSuurempi ;
|
|
k17 : Str -> NForms -- 38 virkkuu
|
|
= dPaluu ;
|
|
k18 : Str -> NForms -- voi, tee, sää
|
|
= dPuu ;
|
|
k19 : Str -> NForms -- 6 yö
|
|
= dSuo ;
|
|
k20 : Str -> NForms -- 46 voodoo
|
|
= dPaluu ;
|
|
k21 : Str -> NForms -- 22 tax-free --? rosé
|
|
= dPuu ;
|
|
k22 : Str -> NForms -- 13 tournedos
|
|
= \s -> nForms10
|
|
s (s + "'n") (s + "'ta") (s + "'na") (s + "'hon")
|
|
(s + "'iden") (s + "'ita") (s + "'ina") (s + "'issa") (s + "'ihin") ;
|
|
k23 : Str -> NForms -- 9 vuohi
|
|
= \s -> dArpi s (init s + "en") ;
|
|
k24 : Str -> NForms -- 20 uni
|
|
= \s -> dArpi s (init s + "en") ;
|
|
k25 : Str -> NForms -- 9 tuomi
|
|
= \s -> dArpi s (init s + "en") ;
|
|
k26 : Str -> NForms -- 113 ääri
|
|
= \s -> dArpi s (init s + "en") ;
|
|
k27 : Str -> NForms -- 23 vuosi
|
|
= \s -> dArpi s (Predef.tk 2 s + "den") ;
|
|
k28 : Str -> NForms -- 13 virsi
|
|
= \s -> dArpi s (Predef.tk 2 s + "ren") ;
|
|
k28A : Str -> NForms -- 1 jälsi
|
|
= \s -> dArpi s (Predef.tk 2 s + "len") ;
|
|
k29 : Str -> NForms -- 1 lapsi
|
|
= \s -> let lapsi = dArpi s (init s + "en") in
|
|
table {2 => Predef.tk 3 s + "ta" ; i => lapsi ! i} ;
|
|
k30 : Str -> NForms -- 2 veitsi
|
|
= \s -> let lapsi = dArpi s (init s + "en") in
|
|
table {2 => Predef.tk 3 s + "stä" ; i => lapsi ! i} ;
|
|
k31 : Str -> NForms -- 3 yksi
|
|
= \s -> let
|
|
y = Predef.tk 3 s ;
|
|
a = vowelHarmony y
|
|
in nForms10
|
|
s (y + "hden") (y + "ht" + a) (y + "hten" + a) (y + "hteen")
|
|
(s + "en") (s + a) (s + "n" + a) (s + "ss" + a) (s + "in") ;
|
|
k32 : Str -> NForms -- 20 uumen
|
|
= \s -> dPiennar s (s + "en") ;
|
|
k32A : Str -> NForms -- 54 ystävätär
|
|
= \s -> dPiennar s (strongGrade (init s) + last s + "en") ;
|
|
k33 : Str -> NForms -- 168 väistin
|
|
= \s -> dLiitin s (init s + "men") ;
|
|
k33A : Str -> NForms -- 181 yllytin
|
|
= \s -> dLiitin s (strongGrade (init s) + "men") ;
|
|
k34 : Str -> NForms -- 1 alaston
|
|
= \s -> let alastom = init s in
|
|
nForms10
|
|
s (alastom + "an") (s + "ta") (alastom + "ana") (alastom + "aan")
|
|
(alastom + "ien") (alastom + "ia") (alastom + "ina") (alastom + "issa")
|
|
(alastom + "iin") ;
|
|
k34A : Str -> NForms -- 569 ääretön
|
|
= dOnneton ;
|
|
k35A : Str -> NForms -- 1 lämmin
|
|
= \s -> let lämpim = strongGrade (init s) + "m" in
|
|
nForms10
|
|
s (lämpim + "än") (s + "tä") (lämpim + "änä") (lämpim + "ään")
|
|
(lämpim + "ien") (lämpim + "iä") (lämpim + "inä") (lämpim + "issä")
|
|
(lämpim + "iin") ;
|
|
k36 : Str -> NForms -- 11 ylin
|
|
= dSuurin ;
|
|
k37 : Str -> NForms -- 1 vasen
|
|
= \s -> let vasem = init s + "m" in
|
|
nForms10
|
|
s (vasem + "man") (s + "ta") (vasem + "pana") (vasem + "paan")
|
|
(vasem + "pien") (vasem + "pia") (vasem + "pina") (vasem + "missa")
|
|
(vasem + "piin") ;
|
|
k38 : Str -> NForms -- 4195 öykkärimäinen
|
|
= dNainen ;
|
|
k39 : Str -> NForms -- 2730 örähdys
|
|
= dJalas ;
|
|
k40 : Str -> NForms -- 2482 öykkärimäisyys
|
|
= dLujuus ;
|
|
k41 : Str -> NForms -- 127 äyräs
|
|
= \s -> let is = init s in dRae s (is + last is + "n") ;
|
|
k41A : Str -> NForms -- 401 öljykangas
|
|
= \s -> let is = init s in dRae s (strongGrade is + last is + "n") ;
|
|
k42 : Str -> NForms -- 1 mies
|
|
= \s -> let mieh = init s + "h" in
|
|
nForms10
|
|
s (mieh + "en") (s + "tä") (mieh + "enä") (mieh + "een")
|
|
(s + "ten") (mieh + "iä") (mieh + "inä") (mieh + "issä")
|
|
(mieh + "iin") ;
|
|
k43 : Str -> NForms -- 11 tiehyt
|
|
= \s -> dRae s (init s + "en") ;
|
|
k43A : Str -> NForms -- 1 immyt
|
|
= \s -> dRae s (strongGrade (init s) + "en") ;
|
|
k44 : Str -> NForms -- 1 kevät
|
|
= \s -> let kevä = init s in
|
|
nForms10
|
|
s (kevä + "än") (s + "tä") (kevä + "änä") (kevä + "äseen")
|
|
(s + "iden") (kevä + "itä") (kevä + "inä") (kevä + "issä")
|
|
(kevä + "isiin") ;
|
|
k45 : Str -> NForms -- 23 yhdes
|
|
= \s -> let yhde = init s ; a = vowelHarmony s in
|
|
nForms10
|
|
s (yhde + "nnen") (yhde + "tt" + a) (yhde + "nten" + a) (yhde + "nteen")
|
|
(yhde + "nsien") (yhde + "nsi" + a) (yhde + "nsin" + a) (yhde + "nsiss" + a)
|
|
(yhde + "nsiin") ;
|
|
k46 : Str -> NForms -- 1 tuhat
|
|
= \s -> let tuha = init s ; a = vowelHarmony s in
|
|
nForms10
|
|
s (tuha + "nnen") (tuha + "tt" + a) (tuha + "nten" + a) (tuha + "nteen")
|
|
(tuha + "nsien") (tuha + "nsi" + a) (tuha + "nsin" + a) (tuha + "nsiss" + a)
|
|
(tuha + "nsiin") ;
|
|
k47 : Str -> NForms -- 46 ylirasittunut
|
|
= dOttanut ;
|
|
k48 : Str -> NForms -- 346 äpäre
|
|
= \s -> dRae s (s + last s + "n") ;
|
|
k48A : Str -> NForms -- 481 äänne
|
|
= \s -> dRae s (strongGrade s + "en") ;
|
|
k49 : Str -> NForms -- 31 vempele
|
|
= \s -> case last s of {
|
|
"e" => dRae s (s + "en") ;
|
|
_ => dPiennar s (s + "en")
|
|
} ;
|
|
k49A : Str -> NForms -- 11 vemmel
|
|
= \s -> dPiennar s (strongGrade (init s) + "len") ;
|
|
|
|
k52 : Str -> VForms -- 667 ärjyä
|
|
= \s -> cHukkua s (init s + "n") ;
|
|
k52A : Str -> VForms -- 1568 öljyyntyä
|
|
= \s -> cHukkua s (weakGrade (init s) + "n") ;
|
|
k53 : Str -> VForms -- 605 äänestää
|
|
= \s -> let ott = Predef.tk 2 s in
|
|
cOttaa s (init s + "n") (ott + "in") (ott + "i") ;
|
|
k53A : Str -> VForms -- 2121 örähtää
|
|
= \s -> let ota = weakGrade (init s) in
|
|
cOttaa s (ota + "n") (init ota + "in") (Predef.tk 2 s + "i") ;
|
|
k54 : Str -> VForms -- 2 pieksää
|
|
= \s -> let ott = Predef.tk 2 s in
|
|
cOttaa s (init s + "n") (ott + "in") (ott + "i") ;
|
|
k54A : Str -> VForms -- 316 ääntää
|
|
= \s -> let ota = weakGrade (init s) ; o = Predef.tk 2 ota in
|
|
cOttaa s (ota + "n") (o + "sin") (o + "si") ;
|
|
k55A : Str -> VForms -- 7 yltää
|
|
= c54A ; --? diff: variation ylti/ylsi
|
|
k56 : Str -> VForms -- 22 valaa
|
|
= \s -> let val = Predef.tk 2 s in
|
|
cOttaa s (init s + "n") (val + "oin") (val + "oi") ; -- never ö
|
|
k56A : Str -> VForms -- 28 virkkaa
|
|
= \s -> let ota = weakGrade (init s) ; ot = init ota in
|
|
cOttaa s (ota + "n") (ot + "oin") (ot + "oi") ;
|
|
k57A : Str -> VForms -- 3 saartaa
|
|
= c56A ; --? diff: saartoi/saarsi
|
|
k58 : Str -> VForms -- 13 suitsea
|
|
= \s -> cHukkua s (init s + "n") ;
|
|
k58A : Str -> VForms -- 19 tunkea
|
|
= \s -> cHukkua s (weakGrade (init s) + "n") ;
|
|
k59A : Str -> VForms -- 1 tuntea
|
|
= \s -> let tunte = init s ; tunne = weakGrade tunte ; tuns = Predef.tk 2 tunte + "s" in
|
|
vForms12 s (tunne + "n") (tunte + "e") (tunte + "vat") (tunte + "kaa") (tunne + "taan")
|
|
(tuns + "in") (tuns + "i") (init tunte + "isi") (tunte + "nut") (tunne + "ttu")
|
|
(tunte + "nee") ; -- just one verb
|
|
k60A : Str -> VForms -- 1 lähteä
|
|
= c58A ; --? diff lähti/läksi, just one verb
|
|
k61 : Str -> VForms -- 249 äyskiä
|
|
= \s -> cHukkua s (init s + "n") ;
|
|
k61A : Str -> VForms -- 153 vääntelehtiä
|
|
= \s -> cHukkua s (weakGrade (init s) + "n") ;
|
|
k62 : Str -> VForms -- 684 öykkäröidä
|
|
= \s -> cJuoda s ;
|
|
k63 : Str -> VForms -- 3 saada
|
|
= c62 ;
|
|
k64 : Str -> VForms -- 8 viedä
|
|
= c62 ;
|
|
k65 : Str -> VForms -- 1 käydä
|
|
= \s -> let kay = Predef.tk 2 s ; kavi = init kay + "vi" in
|
|
vForms12 s (kay + "n") kay (kay + "vät") (kay + "kää") (kay + "dään")
|
|
(kavi + "n") kavi (kavi + "si") (kay + "nyt") (kay + "tty")
|
|
(kay + "nee") ; -- just one verb
|
|
k66 : Str -> VForms -- 268 öristä
|
|
= \s -> cKuunnella s (Predef.tk 2 s + "in") ;
|
|
k66A : Str -> VForms -- 3 vavista
|
|
= \s -> cKuunnella s (strongGrade (Predef.tk 3 s) + "sin") ;
|
|
k67 : Str -> VForms -- 704 ällistellä
|
|
= \s -> cKuunnella s (Predef.tk 2 s + "in") ;
|
|
k67A : Str -> VForms -- 634 äännellä
|
|
= \s -> cKuunnella s (strongGrade (Predef.tk 3 s) + "lin") ;
|
|
k68 : Str -> VForms -- 49 viheriöidä
|
|
= c62 ; -- diff viheriöin/viheriöitsen
|
|
k69 : Str -> VForms -- 48 villitä
|
|
= \s -> cHarkita s ;
|
|
k70 : Str -> VForms -- 3 syöstä
|
|
= \s -> cJuosta s (Predef.tk 3 s + "ksen") ;
|
|
k71 : Str -> VForms -- 2 tehdä
|
|
= \s -> let te = Predef.tk 3 s in
|
|
vForms12 s (te + "en") (te + "kee") (te + "kevät") (te + "hkää") (te + "hdään")
|
|
(te + "en") (te + "ki") (te + "kisi") (te + "hnyt") (te + "hty")
|
|
(te + "hnee") ; -- just two verbs: nähdä, tehdä
|
|
k72 : Str -> VForms -- 93 yletä
|
|
= \s -> cValjeta s (Predef.tk 2 s + "ni") ;
|
|
k72A : Str -> VForms -- 52 yhdetä
|
|
= \s -> cValjeta s (strongGrade (Predef.tk 2 s) + "ni") ;
|
|
k73 : Str -> VForms -- 600 äkseerata
|
|
= \s -> cPudota s (Predef.tk 2 s + "si") ;
|
|
k73A : Str -> VForms -- 313 änkätä
|
|
= \s -> cPudota s (strongGrade (Predef.tk 2 s) + "si") ;
|
|
k74 : Str -> VForms -- 99 öljytä
|
|
= \s -> cPudota s (Predef.tk 2 s + "si") ;
|
|
k74A : Str -> VForms -- 72 ängetä
|
|
= \s -> cPudota s (strongGrade (Predef.tk 2 s) + "si") ;
|
|
k75 : Str -> VForms -- 39 viritä
|
|
= \s -> cPudota s (Predef.tk 2 s + "si") ;
|
|
k75A : Str -> VForms -- 9 siitä
|
|
= \s -> cPudota s (strongGrade (Predef.tk 2 s) + "si") ;
|
|
k76A : Str -> VForms -- 2 tietää
|
|
= \s -> let tieta = init s ; tieda = weakGrade tieta ; ties = Predef.tk 2 tieta + "s" in
|
|
cOttaa s (tieda + "n") (ties + "in") (ties + "i") ; -- only tietaa, taitaa
|
|
-- defective verbs
|
|
k77 : Str -> VForms -- 3 vipajaa
|
|
= c56A ; ----
|
|
k78 : Str -> VForms -- 31 ähkää
|
|
= c56A ; ----
|
|
k78A : Str -> VForms -- 1 tuikkaa
|
|
= c56A ; ----
|
|
k99 : Str -> Str -- 5453 öykkärimäisesti
|
|
= \s -> s ;
|
|
|
|
k101 : Str -> Str -- pronouns etc
|
|
= c99 ; -- dummy
|
|
|
|
-- compound nouns, latter part inflected
|
|
kcompoundNK : Str -> NForms -> NForms = \x,y ->
|
|
\\v => x + y ! v ;
|
|
|
|
--- this is a lot slower
|
|
kccompoundNK : (Str -> NForms) -> Str -> Str -> NForms = \d,x,y ->
|
|
let ys = d y in \\v => x + ys ! v ;
|
|
|
|
---- remnants of erroneous annotations
|
|
|
|
k50 : Str -> N ---- Forms -- 520 vääräsääri
|
|
= \s -> mkN s ;
|
|
k51 : Str -> N ---- Forms -- 62 vierasmies
|
|
= \s -> mkN s ;
|
|
kH1 : Str -> N ---- Forms -- remnant of homonym information
|
|
= \s -> mkN s ;
|
|
|
|
}
|
|
|