lean4-htt/tests/lean/run/reduce1.lean
Leonardo de Moura 736925bbce feat: allow decide! and nativeDecide! take _ as an argument
We use the expected type in this case.
2020-03-18 16:00:06 -07:00

42 lines
1.4 KiB
Text

def fact : Nat → Nat
| 0 => 1
| (n+1) => (n+1)*fact n
#eval fact 10
#eval fact 100
new_frontend
theorem tst1 : fact 10 = 3628800 :=
nativeRefl! (fact 10)
theorem tst2 : fact 100 = 93326215443944152681699238856266700490715968264381621468592963895217599993229915608941463976156518286253697920827223758251185210916864000000000000000000000000 :=
nativeRefl! (fact 100)
theorem tst3 : decide (10000000000000000 < 200000000000000000000) = true :=
nativeRefl! (decide (10000000000000000 < 200000000000000000000))
theorem tst4 : 10000000000000000 < 200000000000000000000 :=
ofDecideEqTrue (nativeRefl! (decide (10000000000000000 < 200000000000000000000)))
theorem tst5 : 10000000000000000 < 200000000000000000000 :=
nativeDecide! (10000000000000000 < 200000000000000000000)
theorem tst6 : 10000000000000000 < 200000000000000000000 :=
let h₁ := nativeDecide! (10000000000000000 < 10000000000000010);
let h₂ := nativeDecide! (10000000000000010 < 200000000000000000000);
Nat.ltTrans h₁ h₂
theorem tst7 : 10000000000000000 < 200000000000000000000 :=
decide! (10000000000000000 < 200000000000000000000)
theorem tst8 : 10000000000000000 < 200000000000000000000 :=
let h₁ := decide! (10000000000000000 < 10000000000000010);
let h₂ := decide! (10000000000000010 < 200000000000000000000);
Nat.ltTrans h₁ h₂
theorem tst9 : 10000000000000000 < 200000000000000000000 :=
decide! _
theorem tst10 : 10000000000000000 < 200000000000000000000 :=
nativeDecide! _