new_frontend partial def fact : Nat → Nat | 0 => 1 | (n+1) => (n+1)*fact n #eval fact 10 #eval fact 100 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! _