27 lines
729 B
Text
27 lines
729 B
Text
def minFacAux (n : Nat) : Nat → Nat
|
||
| k =>
|
||
if h : n < k * k then n
|
||
else
|
||
if h' : k ∣ n then k
|
||
else
|
||
have : k ≤ n := by have := Nat.le_mul_self k; omega
|
||
minFacAux n (k + 2)
|
||
termination_by k => n + 2 - k
|
||
|
||
def Nat.minFac (n : Nat) : Nat :=
|
||
if 2 ∣ n then 2 else minFacAux n 3
|
||
|
||
def Nat.log (b n : Nat) : Nat :=
|
||
if b ≤ 1 then 0 else (go b n).2 where
|
||
go : Nat → Nat → Nat × Nat
|
||
| _, 0 => (n, 0)
|
||
| b, fuel + 1 =>
|
||
if n < b then
|
||
(n, 0)
|
||
else
|
||
let (q, e) := go (b * b) fuel
|
||
if q < b then (q, 2 * e) else (q / b, 2 * e + 1)
|
||
|
||
theorem test : ¬∃ k, k ≤ Nat.log 2 15 ∧ 0 < k ∧ 15 = Nat.minFac 15 ^ k := by
|
||
apply of_decide_eq_true
|
||
conv => lhs; cbv
|