23af5ab217
Signed-off-by: Leonardo de Moura <leonardo@microsoft.com>
19 lines
No EOL
454 B
Text
19 lines
No EOL
454 B
Text
import logic num
|
|
using eq_proofs
|
|
|
|
inductive nat : Type :=
|
|
| zero : nat
|
|
| succ : nat → nat
|
|
|
|
definition add (x y : nat) : nat := nat_rec x (λn r, succ r) y
|
|
infixl `+`:65 := add
|
|
definition mul (n m : nat) := nat_rec zero (fun m x, x + n) m
|
|
infixl `*`:75 := mul
|
|
|
|
axiom mul_zero_right (n : nat) : n * zero = zero
|
|
|
|
variable P : nat → Prop
|
|
|
|
print "==========================="
|
|
theorem tst (n : nat) (H : P (n * zero)) : P zero
|
|
:= subst (mul_zero_right _) H |