From d09777a9aaeb580d8e793ad5e572296eb4c351d9 Mon Sep 17 00:00:00 2001 From: aarne Date: Thu, 29 Jan 2004 12:57:32 +0000 Subject: New order among numerals. --- examples/numerals/welsh.gf | 71 ++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 71 insertions(+) create mode 100644 examples/numerals/welsh.gf (limited to 'examples/numerals/welsh.gf') diff --git a/examples/numerals/welsh.gf b/examples/numerals/welsh.gf new file mode 100644 index 000000000..54a2ca640 --- /dev/null +++ b/examples/numerals/welsh.gf @@ -0,0 +1,71 @@ +include numerals.Abs.gf ; + +-- The neo-base-10 system dauddeg, trideg, pedwardeg, pumdeg/hanner cant, chwedeg, saithdeg, wythdeg, nawdeg is +-- implemented as the second variant as it should be + +oper LinDigit = {s : DForm => Str ; even20 : Even20 ; size : Size} ; +oper LinSub100 = {s : Str ; size : Size} ; + +oper mk20Ten : Str -> Str -> Str -> Str -> Size -> LinDigit = + \tri -> \trideg -> \fiche -> \triarddeg -> \sz -> + { s = table {unit => tri ; twenty => fiche ; teen => triarddeg ; ten => trideg} ; even20 = odd ; size = sz} ; + +oper mkEven20 : Str -> Str -> Str -> Str -> Size -> LinDigit = + \tri -> \trideg -> \fiche -> \triarddeg -> \sz -> + { s = table {unit => tri ; twenty => fiche ; teen => triarddeg ; ten => trideg} ; even20 = even ; size = sz} ; + +param Even20 = odd | even ; +param DForm = unit | ten | twenty | teen ; +param Size = sg | mutation | am | pl | five | overten; + +lincat Numeral = {s : Str} ; +lincat Digit = LinDigit ; +lincat Sub10 = LinDigit ; +lincat Sub100 = LinSub100 ; +lincat Sub1000 = LinSub100 ; +lincat Sub1000000 = {s : Str} ; +lin num x0 = + {s = x0.s} ; +lin n2 = mkEven20 "dau" "dauddeg" "hugain" "deuddeg" mutation ; +lin n3 = mk20Ten "tri" "trideg" "hugain" ("tri" ++ "ar" ++ "deg") am ; +lin n4 = mkEven20 "pedwar" "pedwardeg" "deugain" ("pedwar" ++ "ar" ++ "ddeg") pl ; +lin n5 = mk20Ten ("pum" + p) "pumdeg" "deugain" "pymtheg" five ; +lin n6 = mkEven20 ("chwe" + ch) "chwedeg" "trigain" ("un" ++ "ar" ++ "bymtheg") am ; +lin n7 = mk20Ten "saith" "saithdeg" "trigain" ("dau" ++ "ar" ++ "bymtheg") pl ; +lin n8 = mkEven20 "wyth" "wythdeg" ("pedwar" ++ "ugain") "deunaw" pl ; +lin n9 = mk20Ten "naw" "nawdeg" ("pedwar" ++ "ugain") ("pedwar" ++ "ar" ++ "bymtheg") pl ; +oper AR : Str = pre {"ar" ; "a" / strs {"d"} } ; +oper AG : Str = pre {"a" ; "ag" / strs {"a" ; "u" ; "i" ; "e" ; "o" ; "w"} } ; -- before vowel +oper ng : Str = pre {"g" ; "ng" / strs {"m"} } ; +oper t : Str = pre {[] ; "t" / strs {[]}} ; +oper ch : Str = pre {[] ; "ch" / strs{[]}} ; +oper p : Str = pre {[] ; "p" / strs{[]}} ; + +oper mkR : Str -> LinSub100 = \s1 -> {s = s1 ; size = overten } ; +oper mkR2 : Str -> Size -> LinSub100 = \s1 -> \sz -> {s = s1 ; size = table {mutation => mutation ; am => am ; _ => overten} ! sz } ; + +lin pot01 = + {s = table {unit => "un" ; _ => "dummy"} ; even20 = odd ; size = sg}; +lin pot0 d = d ; +lin pot110 = {s = "de" + ng ; size = pl} ; +lin pot111 = mkR (variants {"un" ++ "ar" ++ "ddeg" ; "undeg" ++ "un"}) ; +lin pot1to19 d = mkR (variants {d.s ! teen ; "undeg" ++ d.s ! unit}) ; +lin pot0as1 n = {s = n.s ! unit ; size = n.size} ; +lin pot1 d = table {mutation => mkR (variants {"ugain" ; "dauddeg" }) ; + five => mkR (variants {"hanner" ++ "cant" ; "deg" ++ "a" + "deugain" ; "pumdeg"}) ; + _ => mkR (variants { table {even => d.s ! twenty ; odd => "deg" ++ AR ++ d.s ! twenty} ! d.even20 ; d.s ! ten}) } ! d.size ; +lin pot1plus d e = mkR2 (variants { table {even => e.s ! unit ++ AR ++ d.s ! twenty ; odd => e.s ! teen ++ AR ++ d.s ! twenty} ! d.even20 ; d.s ! ten}) e.size ; -- hugain +lin pot1as2 n = n ; +lin pot2 d = mkR ((CANT (d.s ! unit)) ! d.size) ; +lin pot2plus d e = mkR2 (((CANT (d.s ! unit)) ! d.size) ++ (maybeAG ! e.size) ++ e.s) e.size; +lin pot2as3 n = + {s = n.s } ; +lin pot3 n = + {s = (MIL n.s) ! n.size } ; +lin pot3plus n m = + {s = (MIL n.s) ! n.size ++ m.s } ; + +oper maybeAG : Size => Str = (table {overten => [] ; _ => AG} ); +oper CANT : Str -> Size => Str = \s1 -> table {sg => "can" + t ; mutation => s1 ++ "gan" + t; am => s1 ++ "chan" + t ; _ => s1 ++ "can" + t} ; +oper MIL : Str -> Size => Str = \s1 -> table {sg => "mil" ; mutation => s1 ++ "fil" ; _ => s1 ++ "mil" } ; + -- cgit v1.2.3