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}
|