2015-02-01 19:36:06 -08:00
|
|
|
open nat
|
|
|
|
|
2015-03-13 14:47:21 -07:00
|
|
|
definition foo1 : nat → nat
|
|
|
|
| foo1 (0 + x) := x
|
2015-02-01 19:36:06 -08:00
|
|
|
|
2015-03-13 14:47:21 -07:00
|
|
|
definition foo2 : nat → nat → nat
|
|
|
|
| foo2 0 _ := 0
|
|
|
|
| foo2 x ⌞y⌟ := x
|
2015-02-01 19:36:06 -08:00
|
|
|
|
2015-03-13 14:47:21 -07:00
|
|
|
definition foo3 : nat → nat → nat
|
|
|
|
| foo3 0 _ := 0
|
|
|
|
| foo3 ⌞x⌟ x := x
|
2015-02-01 19:36:06 -08:00
|
|
|
|
|
|
|
inductive tree (A : Type) :=
|
2015-02-25 17:00:10 -08:00
|
|
|
| node : tree_list A → tree A
|
|
|
|
| leaf : A → tree A
|
2015-02-01 19:36:06 -08:00
|
|
|
with tree_list :=
|
2015-02-25 17:00:10 -08:00
|
|
|
| nil {} : tree_list A
|
|
|
|
| cons : tree A → tree_list A → tree_list A
|
2015-02-01 19:36:06 -08:00
|
|
|
|
|
|
|
definition is_leaf {A : Type} : tree A → bool
|
2015-02-25 16:20:44 -08:00
|
|
|
with is_leaf_aux : tree_list A → bool
|
|
|
|
| is_leaf (tree.node _) := bool.ff
|
|
|
|
| is_leaf (tree.leaf _) := bool.tt
|
|
|
|
| is_leaf_aux tree_list.nil := bool.ff
|
|
|
|
| is_leaf_aux (tree_list.cons _ _) := bool.ff
|
2015-02-01 19:36:06 -08:00
|
|
|
|
2015-02-25 16:20:44 -08:00
|
|
|
definition foo : nat → nat
|
|
|
|
| foo 0 := 0
|
|
|
|
| foo (x+1) := let y := x + 2 in y * y
|
2015-02-01 19:36:06 -08:00
|
|
|
|
|
|
|
example : foo 5 = 36 := rfl
|
|
|
|
|
2015-02-25 16:20:44 -08:00
|
|
|
definition boo : nat → nat
|
|
|
|
| boo (x + 1) := boo (x + 2)
|
|
|
|
| boo 0 := 0
|