open nat

inductive tree (A : Type) :=
leaf : A → tree A,
node : tree A → tree A → tree A

check tree.node

definition size {A : Type} (t : tree A) :=
tree.rec (λ a, 1) (λ t₁ t₂ n₁ n₂, n₁ + n₂) t

check size

eval size (tree.node (tree.node (tree.leaf 0) (tree.leaf 1))
                (tree.leaf 0))