concrete NumeralChi of Numeral = CatChi [Numeral,Digits] ** open ResChi, Prelude in { flags coding = utf8 ; param Qform = bai | bai0 | shiwan | shiwan0 ; param Bform = shi | shi0 | wan | wan0 ; param Zero = zero | nozero ; oper ling : Zero * Zero => Str = table { => "零" ; => "零" ; => []} ; oper Wan : Zero => Str = table {zero => "万" ; nozero => []} ; oper mkD : Str -> Str -> Str = \x,_ -> word x ; -- hiding the "formal" version lincat Digit = {s,p : Str} ; -- s/p: without/with classifier (er/liang) lincat Sub10 = {s,p,t : Str} ; -- t: with "shi wan" lincat Sub100 = {end0,beg0 : Zero ; s,p : Bform => Str} ; -- end0: ends with zeros, e.g. 20 ; beg0: begins with zeros, e.g. 02 lincat Sub1000 = {end0,beg0 : Zero ; s,p : Qform => Str} ; -- end0: ends with zeros, e.g. 210 ; beg0: begins with zeros, e.g. 021 lincat Sub1000000 = {s,p : Str} ; lin num x0 = x0 ; -- 一二三四五六七八九十一百千 -- lin n2 = {s = mkD "二" "贰" ; p = "两"} ; lin n3 = {s,p = mkD "三" "叁"} ; lin n4 = {s,p = mkD "四" "肆"} ; lin n5 = {s,p = mkD "五" "伍"} ; lin n6 = {s,p = mkD "六" "陆"} ; lin n7 = {s,p = mkD "七" "柒"} ; lin n8 = {s,p = mkD "八" "捌"} ; lin n9 = {s,p = mkD "九" "玖"} ; lin pot01 = {s,p = mkD "一" "壹" ; t = []} ; -- t used in "(*yi) shi wan" lin pot0 d = {s,t = d.s ; p = d.p} ; lin pot110 = {beg0 = nozero ; end0 = zero ; s,p = table { shi => mkD "十" "拾" ; shi0 => mkD "一十" "壹拾" ; wan => mkD "一万" "壹万" ; wan0 => mkD "一万" "壹万" }} ; lin pot111 = {beg0 = nozero ; end0 = nozero ; s,p = table { shi => mkD "十一" "拾壹" ; shi0 => mkD "一十一" "壹拾壹" ; wan => mkD "一万一千" "壹万壹千" ; -- 11.16 by chenpeng wan => mkD "十一万" "拾壹万" ; wan0 => mkD "一万一千" "壹万壹千" }} ; -- 11.16 by chenpeng wan0 => mkD "十一万" "拾壹万"}} ; lin pot1to19 d = {beg0 = nozero ; end0 = nozero ; s,p = table { shi => mkD "十" "壹拾" ++ d.s ; shi0 => mkD "一十" "壹拾" ++ d.s ; wan => mkD "一万" "壹万" ++ d.s ++ mkD "千" "仟" ; wan0 => mkD "一万" "壹万" ++ d.s ++ mkD "千" "仟" }} ; lin pot0as1 n = {beg0 = zero ; end0 = nozero ; s = table { shi => n.s ; shi0 => n.s ; wan => n.p ++ mkD "千" "仟" ; wan0 => n.p ++ mkD "千" "仟" } ; p = table { shi => n.p ; shi0 => n.s ; wan => n.p ++ mkD "千" "仟" ; wan0 => n.p ++ mkD "千" "仟" } } ; lin pot1 d = {beg0 = nozero ; end0 = zero ; -- inh = nozero ; s,p = table { shi => d.s ++ mkD "十" "拾" ; shi0 => d.s ++ mkD "十" "拾" ; wan0 => (d.p | d.s) ++ "万" ; wan => (d.p | d.s) ++ "万" }} ; lin pot1plus d e = {beg0 = nozero ; end0 = nozero ; -- inh = nozero ; s,p = table { shi => d.s ++ mkD "十" "拾" ++ e.s ; shi0 => d.s ++ mkD "十" "拾" ++ e.s ; wan => (d.p | d.s) ++ "万" ++ e.s ++ mkD "千" "仟" ; wan0 => (d.p | d.s) ++ "万" ++ e.s ++ mkD "千" "仟" }} ; lin pot1as2 n = {beg0 = zero ; end0 = n.end0 ; -- inh = zero ; s = table { bai => n.s ! shi ; bai0 => n.s ! shi0 ; shiwan => n.s ! wan ; shiwan0 => n.s ! wan0 } ; p = table { bai => n.p ! shi ; bai0 => n.s ! shi0 ; shiwan => n.s ! wan ; shiwan0 => n.s ! wan0 }} ; lin pot2 d = {beg0 = nozero ; end0 = zero ; -- inh = zero ; s,p = table { bai => (d.p | d.s) ++ mkD "百" "佰" ; bai0 => (d.p | d.s) ++ mkD "百" "佰" ; shiwan0 => d.t ++ mkD "十万" "拾万" ; shiwan => d.t ++ mkD "十万" "拾万" }} ; lin pot2plus d e = {beg0 = nozero ; end0 = e.end0 ; -- inh = nozero ; s,p = table { bai => (d.p | d.s) ++ mkD "百" "佰" ++ (ling ! ) ++ e.s ! shi0 ; --why omit "百"? i add it /chenpeng bai0 => (d.p | d.s) ++ mkD "百" "佰" ++ (ling ! ) ++ e.s ! shi0 ; --why omit "百"? i add it /chenpeng shiwan => d.t ++ mkD "十" "拾" ++ (Wan ! (e.end0)) ++ e.s ! wan ; --why omit "十"? i add it /chenpeng shiwan0 => d.t ++ mkD "十" "拾" ++ (Wan ! (e.end0)) ++ e.s ! wan0 }} ;--why omit "十"? i add it /chenpeng lin pot2as3 n = {s = n.s ! bai ; p = n.p ! bai} ; lin pot3 n = {s,p = n.s ! shiwan} ; lin pot3plus n m = {s,p = (n.s ! shiwan0) ++ (ling ! ) ++ m.s ! bai0} ; -- numerals as sequences of digits lincat Dig = SS ; lin IDig d = d ; IIDig d i = ss (d.s ++ i.s) ; D_0 = ss "0" ; D_1 = ss "1" ; D_2 = ss "2" ; D_3 = ss "3" ; D_4 = ss "4" ; D_5 = ss "5" ; D_6 = ss "6" ; D_7 = ss "7" ; D_8 = ss "8" ; D_9 = ss "9" ; }