summaryrefslogtreecommitdiff
path: root/program/exp.prim
blob: 8af7c3f1df14115e9fcf89fd7a38cf77c6e5ed31 (plain)
1
2
3
let add (x : Nat) (y : Nat) : Nat = foldcase x by {Z u => y; S k => suc k} in
let mul (x : Nat) (y : Nat) : Nat = foldcase x by {Z u => 0; S k => add y k} in
\x, y => foldcase y by {Z u => 1; S k => mul x k}