lean4-htt/tests/lean/run/simp3.lean
2021-02-16 11:53:49 -08:00

18 lines
627 B
Text

constant f (x : Nat) : Nat
@[simp] axiom fEq (x : Nat) : f x = x
theorem ex1 (x : Nat) : f (f x, x).fst = x := by simp
theorem ex2 (x : Nat) : f ((fun a => f (f a)) x) = x := by simp
constant g (x : Nat) : Nat
@[simp] axiom gEq (x : Nat) : g x = match x with | 0 => 1 | x+1 => 2
@[simp] theorem add1 (x : Nat) : x + 1 = x.succ := rfl
theorem ex3 (x : Nat) : g (x + 1) = 2 := by simp
theorem ex4 (x : Nat) : (fun x => x + 1) = (fun x => x.succ) := by simp
@[simp] theorem comm (x y : Nat) : x + y = y + x := Nat.add_comm ..
theorem ex5 (x y : Nat) : (fun x y : Nat => x + 0 + y) = (fun x y : Nat => y + x + 0) := by simp