MPE Home Metamath Proof Explorer < Previous   Next >
Nearby theorems
Mirrors  >  Home  >  MPE Home  >  Th. List  >  faclbnd Structured version   Visualization version   GIF version

Theorem faclbnd 14247
Description: A lower bound for the factorial function. (Contributed by NM, 17-Dec-2005.)
Assertion
Ref Expression
faclbnd ((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) → (𝑀↑(𝑁 + 1)) ≤ ((𝑀𝑀) · (!‘𝑁)))

Proof of Theorem faclbnd
Dummy variables 𝑗 𝑘 are mutually distinct and distinct from all other variables.
StepHypRef Expression
1 elnn0 12471 . 2 (𝑀 ∈ ℕ0 ↔ (𝑀 ∈ ℕ ∨ 𝑀 = 0))
2 oveq1 7413 . . . . . . . 8 (𝑗 = 0 → (𝑗 + 1) = (0 + 1))
32oveq2d 7422 . . . . . . 7 (𝑗 = 0 → (𝑀↑(𝑗 + 1)) = (𝑀↑(0 + 1)))
4 fveq2 6889 . . . . . . . 8 (𝑗 = 0 → (!‘𝑗) = (!‘0))
54oveq2d 7422 . . . . . . 7 (𝑗 = 0 → ((𝑀𝑀) · (!‘𝑗)) = ((𝑀𝑀) · (!‘0)))
63, 5breq12d 5161 . . . . . 6 (𝑗 = 0 → ((𝑀↑(𝑗 + 1)) ≤ ((𝑀𝑀) · (!‘𝑗)) ↔ (𝑀↑(0 + 1)) ≤ ((𝑀𝑀) · (!‘0))))
76imbi2d 341 . . . . 5 (𝑗 = 0 → ((𝑀 ∈ ℕ → (𝑀↑(𝑗 + 1)) ≤ ((𝑀𝑀) · (!‘𝑗))) ↔ (𝑀 ∈ ℕ → (𝑀↑(0 + 1)) ≤ ((𝑀𝑀) · (!‘0)))))
8 oveq1 7413 . . . . . . . 8 (𝑗 = 𝑘 → (𝑗 + 1) = (𝑘 + 1))
98oveq2d 7422 . . . . . . 7 (𝑗 = 𝑘 → (𝑀↑(𝑗 + 1)) = (𝑀↑(𝑘 + 1)))
10 fveq2 6889 . . . . . . . 8 (𝑗 = 𝑘 → (!‘𝑗) = (!‘𝑘))
1110oveq2d 7422 . . . . . . 7 (𝑗 = 𝑘 → ((𝑀𝑀) · (!‘𝑗)) = ((𝑀𝑀) · (!‘𝑘)))
129, 11breq12d 5161 . . . . . 6 (𝑗 = 𝑘 → ((𝑀↑(𝑗 + 1)) ≤ ((𝑀𝑀) · (!‘𝑗)) ↔ (𝑀↑(𝑘 + 1)) ≤ ((𝑀𝑀) · (!‘𝑘))))
1312imbi2d 341 . . . . 5 (𝑗 = 𝑘 → ((𝑀 ∈ ℕ → (𝑀↑(𝑗 + 1)) ≤ ((𝑀𝑀) · (!‘𝑗))) ↔ (𝑀 ∈ ℕ → (𝑀↑(𝑘 + 1)) ≤ ((𝑀𝑀) · (!‘𝑘)))))
14 oveq1 7413 . . . . . . . 8 (𝑗 = (𝑘 + 1) → (𝑗 + 1) = ((𝑘 + 1) + 1))
1514oveq2d 7422 . . . . . . 7 (𝑗 = (𝑘 + 1) → (𝑀↑(𝑗 + 1)) = (𝑀↑((𝑘 + 1) + 1)))
16 fveq2 6889 . . . . . . . 8 (𝑗 = (𝑘 + 1) → (!‘𝑗) = (!‘(𝑘 + 1)))
1716oveq2d 7422 . . . . . . 7 (𝑗 = (𝑘 + 1) → ((𝑀𝑀) · (!‘𝑗)) = ((𝑀𝑀) · (!‘(𝑘 + 1))))
1815, 17breq12d 5161 . . . . . 6 (𝑗 = (𝑘 + 1) → ((𝑀↑(𝑗 + 1)) ≤ ((𝑀𝑀) · (!‘𝑗)) ↔ (𝑀↑((𝑘 + 1) + 1)) ≤ ((𝑀𝑀) · (!‘(𝑘 + 1)))))
1918imbi2d 341 . . . . 5 (𝑗 = (𝑘 + 1) → ((𝑀 ∈ ℕ → (𝑀↑(𝑗 + 1)) ≤ ((𝑀𝑀) · (!‘𝑗))) ↔ (𝑀 ∈ ℕ → (𝑀↑((𝑘 + 1) + 1)) ≤ ((𝑀𝑀) · (!‘(𝑘 + 1))))))
20 oveq1 7413 . . . . . . . 8 (𝑗 = 𝑁 → (𝑗 + 1) = (𝑁 + 1))
2120oveq2d 7422 . . . . . . 7 (𝑗 = 𝑁 → (𝑀↑(𝑗 + 1)) = (𝑀↑(𝑁 + 1)))
22 fveq2 6889 . . . . . . . 8 (𝑗 = 𝑁 → (!‘𝑗) = (!‘𝑁))
2322oveq2d 7422 . . . . . . 7 (𝑗 = 𝑁 → ((𝑀𝑀) · (!‘𝑗)) = ((𝑀𝑀) · (!‘𝑁)))
2421, 23breq12d 5161 . . . . . 6 (𝑗 = 𝑁 → ((𝑀↑(𝑗 + 1)) ≤ ((𝑀𝑀) · (!‘𝑗)) ↔ (𝑀↑(𝑁 + 1)) ≤ ((𝑀𝑀) · (!‘𝑁))))
2524imbi2d 341 . . . . 5 (𝑗 = 𝑁 → ((𝑀 ∈ ℕ → (𝑀↑(𝑗 + 1)) ≤ ((𝑀𝑀) · (!‘𝑗))) ↔ (𝑀 ∈ ℕ → (𝑀↑(𝑁 + 1)) ≤ ((𝑀𝑀) · (!‘𝑁)))))
26 nnre 12216 . . . . . . 7 (𝑀 ∈ ℕ → 𝑀 ∈ ℝ)
27 nnge1 12237 . . . . . . 7 (𝑀 ∈ ℕ → 1 ≤ 𝑀)
28 elnnuz 12863 . . . . . . . 8 (𝑀 ∈ ℕ ↔ 𝑀 ∈ (ℤ‘1))
2928biimpi 215 . . . . . . 7 (𝑀 ∈ ℕ → 𝑀 ∈ (ℤ‘1))
3026, 27, 29leexp2ad 14214 . . . . . 6 (𝑀 ∈ ℕ → (𝑀↑1) ≤ (𝑀𝑀))
31 0p1e1 12331 . . . . . . . 8 (0 + 1) = 1
3231oveq2i 7417 . . . . . . 7 (𝑀↑(0 + 1)) = (𝑀↑1)
3332a1i 11 . . . . . 6 (𝑀 ∈ ℕ → (𝑀↑(0 + 1)) = (𝑀↑1))
34 fac0 14233 . . . . . . . 8 (!‘0) = 1
3534oveq2i 7417 . . . . . . 7 ((𝑀𝑀) · (!‘0)) = ((𝑀𝑀) · 1)
36 nnnn0 12476 . . . . . . . . . 10 (𝑀 ∈ ℕ → 𝑀 ∈ ℕ0)
3726, 36reexpcld 14125 . . . . . . . . 9 (𝑀 ∈ ℕ → (𝑀𝑀) ∈ ℝ)
3837recnd 11239 . . . . . . . 8 (𝑀 ∈ ℕ → (𝑀𝑀) ∈ ℂ)
3938mulridd 11228 . . . . . . 7 (𝑀 ∈ ℕ → ((𝑀𝑀) · 1) = (𝑀𝑀))
4035, 39eqtrid 2785 . . . . . 6 (𝑀 ∈ ℕ → ((𝑀𝑀) · (!‘0)) = (𝑀𝑀))
4130, 33, 403brtr4d 5180 . . . . 5 (𝑀 ∈ ℕ → (𝑀↑(0 + 1)) ≤ ((𝑀𝑀) · (!‘0)))
4226ad3antrrr 729 . . . . . . . . . . . . . 14 ((((𝑀 ∈ ℕ ∧ 𝑘 ∈ ℕ0) ∧ (𝑀↑(𝑘 + 1)) ≤ ((𝑀𝑀) · (!‘𝑘))) ∧ ((𝑀 ∈ ℕ ∧ 𝑘 ∈ ℕ0) ∧ 𝑀 ≤ (𝑘 + 1))) → 𝑀 ∈ ℝ)
43 simpllr 775 . . . . . . . . . . . . . . 15 ((((𝑀 ∈ ℕ ∧ 𝑘 ∈ ℕ0) ∧ (𝑀↑(𝑘 + 1)) ≤ ((𝑀𝑀) · (!‘𝑘))) ∧ ((𝑀 ∈ ℕ ∧ 𝑘 ∈ ℕ0) ∧ 𝑀 ≤ (𝑘 + 1))) → 𝑘 ∈ ℕ0)
44 peano2nn0 12509 . . . . . . . . . . . . . . 15 (𝑘 ∈ ℕ0 → (𝑘 + 1) ∈ ℕ0)
4543, 44syl 17 . . . . . . . . . . . . . 14 ((((𝑀 ∈ ℕ ∧ 𝑘 ∈ ℕ0) ∧ (𝑀↑(𝑘 + 1)) ≤ ((𝑀𝑀) · (!‘𝑘))) ∧ ((𝑀 ∈ ℕ ∧ 𝑘 ∈ ℕ0) ∧ 𝑀 ≤ (𝑘 + 1))) → (𝑘 + 1) ∈ ℕ0)
4642, 45reexpcld 14125 . . . . . . . . . . . . 13 ((((𝑀 ∈ ℕ ∧ 𝑘 ∈ ℕ0) ∧ (𝑀↑(𝑘 + 1)) ≤ ((𝑀𝑀) · (!‘𝑘))) ∧ ((𝑀 ∈ ℕ ∧ 𝑘 ∈ ℕ0) ∧ 𝑀 ≤ (𝑘 + 1))) → (𝑀↑(𝑘 + 1)) ∈ ℝ)
4736ad3antrrr 729 . . . . . . . . . . . . . . 15 ((((𝑀 ∈ ℕ ∧ 𝑘 ∈ ℕ0) ∧ (𝑀↑(𝑘 + 1)) ≤ ((𝑀𝑀) · (!‘𝑘))) ∧ ((𝑀 ∈ ℕ ∧ 𝑘 ∈ ℕ0) ∧ 𝑀 ≤ (𝑘 + 1))) → 𝑀 ∈ ℕ0)
4842, 47reexpcld 14125 . . . . . . . . . . . . . 14 ((((𝑀 ∈ ℕ ∧ 𝑘 ∈ ℕ0) ∧ (𝑀↑(𝑘 + 1)) ≤ ((𝑀𝑀) · (!‘𝑘))) ∧ ((𝑀 ∈ ℕ ∧ 𝑘 ∈ ℕ0) ∧ 𝑀 ≤ (𝑘 + 1))) → (𝑀𝑀) ∈ ℝ)
4943faccld 14241 . . . . . . . . . . . . . . 15 ((((𝑀 ∈ ℕ ∧ 𝑘 ∈ ℕ0) ∧ (𝑀↑(𝑘 + 1)) ≤ ((𝑀𝑀) · (!‘𝑘))) ∧ ((𝑀 ∈ ℕ ∧ 𝑘 ∈ ℕ0) ∧ 𝑀 ≤ (𝑘 + 1))) → (!‘𝑘) ∈ ℕ)
5049nnred 12224 . . . . . . . . . . . . . 14 ((((𝑀 ∈ ℕ ∧ 𝑘 ∈ ℕ0) ∧ (𝑀↑(𝑘 + 1)) ≤ ((𝑀𝑀) · (!‘𝑘))) ∧ ((𝑀 ∈ ℕ ∧ 𝑘 ∈ ℕ0) ∧ 𝑀 ≤ (𝑘 + 1))) → (!‘𝑘) ∈ ℝ)
5148, 50remulcld 11241 . . . . . . . . . . . . 13 ((((𝑀 ∈ ℕ ∧ 𝑘 ∈ ℕ0) ∧ (𝑀↑(𝑘 + 1)) ≤ ((𝑀𝑀) · (!‘𝑘))) ∧ ((𝑀 ∈ ℕ ∧ 𝑘 ∈ ℕ0) ∧ 𝑀 ≤ (𝑘 + 1))) → ((𝑀𝑀) · (!‘𝑘)) ∈ ℝ)
52 nn0re 12478 . . . . . . . . . . . . . 14 (𝑘 ∈ ℕ0𝑘 ∈ ℝ)
53 peano2re 11384 . . . . . . . . . . . . . 14 (𝑘 ∈ ℝ → (𝑘 + 1) ∈ ℝ)
5443, 52, 533syl 18 . . . . . . . . . . . . 13 ((((𝑀 ∈ ℕ ∧ 𝑘 ∈ ℕ0) ∧ (𝑀↑(𝑘 + 1)) ≤ ((𝑀𝑀) · (!‘𝑘))) ∧ ((𝑀 ∈ ℕ ∧ 𝑘 ∈ ℕ0) ∧ 𝑀 ≤ (𝑘 + 1))) → (𝑘 + 1) ∈ ℝ)
55 nngt0 12240 . . . . . . . . . . . . . . . 16 (𝑀 ∈ ℕ → 0 < 𝑀)
5655ad3antrrr 729 . . . . . . . . . . . . . . 15 ((((𝑀 ∈ ℕ ∧ 𝑘 ∈ ℕ0) ∧ (𝑀↑(𝑘 + 1)) ≤ ((𝑀𝑀) · (!‘𝑘))) ∧ ((𝑀 ∈ ℕ ∧ 𝑘 ∈ ℕ0) ∧ 𝑀 ≤ (𝑘 + 1))) → 0 < 𝑀)
57 0re 11213 . . . . . . . . . . . . . . . 16 0 ∈ ℝ
58 ltle 11299 . . . . . . . . . . . . . . . 16 ((0 ∈ ℝ ∧ 𝑀 ∈ ℝ) → (0 < 𝑀 → 0 ≤ 𝑀))
5957, 58mpan 689 . . . . . . . . . . . . . . 15 (𝑀 ∈ ℝ → (0 < 𝑀 → 0 ≤ 𝑀))
6042, 56, 59sylc 65 . . . . . . . . . . . . . 14 ((((𝑀 ∈ ℕ ∧ 𝑘 ∈ ℕ0) ∧ (𝑀↑(𝑘 + 1)) ≤ ((𝑀𝑀) · (!‘𝑘))) ∧ ((𝑀 ∈ ℕ ∧ 𝑘 ∈ ℕ0) ∧ 𝑀 ≤ (𝑘 + 1))) → 0 ≤ 𝑀)
6142, 45, 60expge0d 14126 . . . . . . . . . . . . 13 ((((𝑀 ∈ ℕ ∧ 𝑘 ∈ ℕ0) ∧ (𝑀↑(𝑘 + 1)) ≤ ((𝑀𝑀) · (!‘𝑘))) ∧ ((𝑀 ∈ ℕ ∧ 𝑘 ∈ ℕ0) ∧ 𝑀 ≤ (𝑘 + 1))) → 0 ≤ (𝑀↑(𝑘 + 1)))
62 simplr 768 . . . . . . . . . . . . 13 ((((𝑀 ∈ ℕ ∧ 𝑘 ∈ ℕ0) ∧ (𝑀↑(𝑘 + 1)) ≤ ((𝑀𝑀) · (!‘𝑘))) ∧ ((𝑀 ∈ ℕ ∧ 𝑘 ∈ ℕ0) ∧ 𝑀 ≤ (𝑘 + 1))) → (𝑀↑(𝑘 + 1)) ≤ ((𝑀𝑀) · (!‘𝑘)))
63 simprr 772 . . . . . . . . . . . . 13 ((((𝑀 ∈ ℕ ∧ 𝑘 ∈ ℕ0) ∧ (𝑀↑(𝑘 + 1)) ≤ ((𝑀𝑀) · (!‘𝑘))) ∧ ((𝑀 ∈ ℕ ∧ 𝑘 ∈ ℕ0) ∧ 𝑀 ≤ (𝑘 + 1))) → 𝑀 ≤ (𝑘 + 1))
6446, 51, 42, 54, 61, 60, 62, 63lemul12ad 12153 . . . . . . . . . . . 12 ((((𝑀 ∈ ℕ ∧ 𝑘 ∈ ℕ0) ∧ (𝑀↑(𝑘 + 1)) ≤ ((𝑀𝑀) · (!‘𝑘))) ∧ ((𝑀 ∈ ℕ ∧ 𝑘 ∈ ℕ0) ∧ 𝑀 ≤ (𝑘 + 1))) → ((𝑀↑(𝑘 + 1)) · 𝑀) ≤ (((𝑀𝑀) · (!‘𝑘)) · (𝑘 + 1)))
6564anandis 677 . . . . . . . . . . 11 (((𝑀 ∈ ℕ ∧ 𝑘 ∈ ℕ0) ∧ ((𝑀↑(𝑘 + 1)) ≤ ((𝑀𝑀) · (!‘𝑘)) ∧ 𝑀 ≤ (𝑘 + 1))) → ((𝑀↑(𝑘 + 1)) · 𝑀) ≤ (((𝑀𝑀) · (!‘𝑘)) · (𝑘 + 1)))
66 nncn 12217 . . . . . . . . . . . . 13 (𝑀 ∈ ℕ → 𝑀 ∈ ℂ)
67 expp1 14031 . . . . . . . . . . . . 13 ((𝑀 ∈ ℂ ∧ (𝑘 + 1) ∈ ℕ0) → (𝑀↑((𝑘 + 1) + 1)) = ((𝑀↑(𝑘 + 1)) · 𝑀))
6866, 44, 67syl2an 597 . . . . . . . . . . . 12 ((𝑀 ∈ ℕ ∧ 𝑘 ∈ ℕ0) → (𝑀↑((𝑘 + 1) + 1)) = ((𝑀↑(𝑘 + 1)) · 𝑀))
6968adantr 482 . . . . . . . . . . 11 (((𝑀 ∈ ℕ ∧ 𝑘 ∈ ℕ0) ∧ ((𝑀↑(𝑘 + 1)) ≤ ((𝑀𝑀) · (!‘𝑘)) ∧ 𝑀 ≤ (𝑘 + 1))) → (𝑀↑((𝑘 + 1) + 1)) = ((𝑀↑(𝑘 + 1)) · 𝑀))
70 facp1 14235 . . . . . . . . . . . . . . 15 (𝑘 ∈ ℕ0 → (!‘(𝑘 + 1)) = ((!‘𝑘) · (𝑘 + 1)))
7170adantl 483 . . . . . . . . . . . . . 14 ((𝑀 ∈ ℕ ∧ 𝑘 ∈ ℕ0) → (!‘(𝑘 + 1)) = ((!‘𝑘) · (𝑘 + 1)))
7271oveq2d 7422 . . . . . . . . . . . . 13 ((𝑀 ∈ ℕ ∧ 𝑘 ∈ ℕ0) → ((𝑀𝑀) · (!‘(𝑘 + 1))) = ((𝑀𝑀) · ((!‘𝑘) · (𝑘 + 1))))
7338adantr 482 . . . . . . . . . . . . . 14 ((𝑀 ∈ ℕ ∧ 𝑘 ∈ ℕ0) → (𝑀𝑀) ∈ ℂ)
74 faccl 14240 . . . . . . . . . . . . . . . 16 (𝑘 ∈ ℕ0 → (!‘𝑘) ∈ ℕ)
7574nncnd 12225 . . . . . . . . . . . . . . 15 (𝑘 ∈ ℕ0 → (!‘𝑘) ∈ ℂ)
7675adantl 483 . . . . . . . . . . . . . 14 ((𝑀 ∈ ℕ ∧ 𝑘 ∈ ℕ0) → (!‘𝑘) ∈ ℂ)
77 nn0cn 12479 . . . . . . . . . . . . . . . 16 (𝑘 ∈ ℕ0𝑘 ∈ ℂ)
78 peano2cn 11383 . . . . . . . . . . . . . . . 16 (𝑘 ∈ ℂ → (𝑘 + 1) ∈ ℂ)
7977, 78syl 17 . . . . . . . . . . . . . . 15 (𝑘 ∈ ℕ0 → (𝑘 + 1) ∈ ℂ)
8079adantl 483 . . . . . . . . . . . . . 14 ((𝑀 ∈ ℕ ∧ 𝑘 ∈ ℕ0) → (𝑘 + 1) ∈ ℂ)
8173, 76, 80mulassd 11234 . . . . . . . . . . . . 13 ((𝑀 ∈ ℕ ∧ 𝑘 ∈ ℕ0) → (((𝑀𝑀) · (!‘𝑘)) · (𝑘 + 1)) = ((𝑀𝑀) · ((!‘𝑘) · (𝑘 + 1))))
8272, 81eqtr4d 2776 . . . . . . . . . . . 12 ((𝑀 ∈ ℕ ∧ 𝑘 ∈ ℕ0) → ((𝑀𝑀) · (!‘(𝑘 + 1))) = (((𝑀𝑀) · (!‘𝑘)) · (𝑘 + 1)))
8382adantr 482 . . . . . . . . . . 11 (((𝑀 ∈ ℕ ∧ 𝑘 ∈ ℕ0) ∧ ((𝑀↑(𝑘 + 1)) ≤ ((𝑀𝑀) · (!‘𝑘)) ∧ 𝑀 ≤ (𝑘 + 1))) → ((𝑀𝑀) · (!‘(𝑘 + 1))) = (((𝑀𝑀) · (!‘𝑘)) · (𝑘 + 1)))
8465, 69, 833brtr4d 5180 . . . . . . . . . 10 (((𝑀 ∈ ℕ ∧ 𝑘 ∈ ℕ0) ∧ ((𝑀↑(𝑘 + 1)) ≤ ((𝑀𝑀) · (!‘𝑘)) ∧ 𝑀 ≤ (𝑘 + 1))) → (𝑀↑((𝑘 + 1) + 1)) ≤ ((𝑀𝑀) · (!‘(𝑘 + 1))))
8584exp32 422 . . . . . . . . 9 ((𝑀 ∈ ℕ ∧ 𝑘 ∈ ℕ0) → ((𝑀↑(𝑘 + 1)) ≤ ((𝑀𝑀) · (!‘𝑘)) → (𝑀 ≤ (𝑘 + 1) → (𝑀↑((𝑘 + 1) + 1)) ≤ ((𝑀𝑀) · (!‘(𝑘 + 1))))))
8685com23 86 . . . . . . . 8 ((𝑀 ∈ ℕ ∧ 𝑘 ∈ ℕ0) → (𝑀 ≤ (𝑘 + 1) → ((𝑀↑(𝑘 + 1)) ≤ ((𝑀𝑀) · (!‘𝑘)) → (𝑀↑((𝑘 + 1) + 1)) ≤ ((𝑀𝑀) · (!‘(𝑘 + 1))))))
87 nn0ltp1le 12617 . . . . . . . . . . 11 (((𝑘 + 1) ∈ ℕ0𝑀 ∈ ℕ0) → ((𝑘 + 1) < 𝑀 ↔ ((𝑘 + 1) + 1) ≤ 𝑀))
8844, 36, 87syl2anr 598 . . . . . . . . . 10 ((𝑀 ∈ ℕ ∧ 𝑘 ∈ ℕ0) → ((𝑘 + 1) < 𝑀 ↔ ((𝑘 + 1) + 1) ≤ 𝑀))
89 peano2nn0 12509 . . . . . . . . . . . . . . 15 ((𝑘 + 1) ∈ ℕ0 → ((𝑘 + 1) + 1) ∈ ℕ0)
9044, 89syl 17 . . . . . . . . . . . . . 14 (𝑘 ∈ ℕ0 → ((𝑘 + 1) + 1) ∈ ℕ0)
91 reexpcl 14041 . . . . . . . . . . . . . 14 ((𝑀 ∈ ℝ ∧ ((𝑘 + 1) + 1) ∈ ℕ0) → (𝑀↑((𝑘 + 1) + 1)) ∈ ℝ)
9226, 90, 91syl2an 597 . . . . . . . . . . . . 13 ((𝑀 ∈ ℕ ∧ 𝑘 ∈ ℕ0) → (𝑀↑((𝑘 + 1) + 1)) ∈ ℝ)
9392adantr 482 . . . . . . . . . . . 12 (((𝑀 ∈ ℕ ∧ 𝑘 ∈ ℕ0) ∧ ((𝑘 + 1) + 1) ≤ 𝑀) → (𝑀↑((𝑘 + 1) + 1)) ∈ ℝ)
9437ad2antrr 725 . . . . . . . . . . . 12 (((𝑀 ∈ ℕ ∧ 𝑘 ∈ ℕ0) ∧ ((𝑘 + 1) + 1) ≤ 𝑀) → (𝑀𝑀) ∈ ℝ)
9544faccld 14241 . . . . . . . . . . . . . . 15 (𝑘 ∈ ℕ0 → (!‘(𝑘 + 1)) ∈ ℕ)
9695nnred 12224 . . . . . . . . . . . . . 14 (𝑘 ∈ ℕ0 → (!‘(𝑘 + 1)) ∈ ℝ)
97 remulcl 11192 . . . . . . . . . . . . . 14 (((𝑀𝑀) ∈ ℝ ∧ (!‘(𝑘 + 1)) ∈ ℝ) → ((𝑀𝑀) · (!‘(𝑘 + 1))) ∈ ℝ)
9837, 96, 97syl2an 597 . . . . . . . . . . . . 13 ((𝑀 ∈ ℕ ∧ 𝑘 ∈ ℕ0) → ((𝑀𝑀) · (!‘(𝑘 + 1))) ∈ ℝ)
9998adantr 482 . . . . . . . . . . . 12 (((𝑀 ∈ ℕ ∧ 𝑘 ∈ ℕ0) ∧ ((𝑘 + 1) + 1) ≤ 𝑀) → ((𝑀𝑀) · (!‘(𝑘 + 1))) ∈ ℝ)
10026ad2antrr 725 . . . . . . . . . . . . 13 (((𝑀 ∈ ℕ ∧ 𝑘 ∈ ℕ0) ∧ ((𝑘 + 1) + 1) ≤ 𝑀) → 𝑀 ∈ ℝ)
10127ad2antrr 725 . . . . . . . . . . . . 13 (((𝑀 ∈ ℕ ∧ 𝑘 ∈ ℕ0) ∧ ((𝑘 + 1) + 1) ≤ 𝑀) → 1 ≤ 𝑀)
102 simpr 486 . . . . . . . . . . . . . 14 (((𝑀 ∈ ℕ ∧ 𝑘 ∈ ℕ0) ∧ ((𝑘 + 1) + 1) ≤ 𝑀) → ((𝑘 + 1) + 1) ≤ 𝑀)
10390ad2antlr 726 . . . . . . . . . . . . . . . 16 (((𝑀 ∈ ℕ ∧ 𝑘 ∈ ℕ0) ∧ ((𝑘 + 1) + 1) ≤ 𝑀) → ((𝑘 + 1) + 1) ∈ ℕ0)
104103nn0zd 12581 . . . . . . . . . . . . . . 15 (((𝑀 ∈ ℕ ∧ 𝑘 ∈ ℕ0) ∧ ((𝑘 + 1) + 1) ≤ 𝑀) → ((𝑘 + 1) + 1) ∈ ℤ)
105 nnz 12576 . . . . . . . . . . . . . . . 16 (𝑀 ∈ ℕ → 𝑀 ∈ ℤ)
106105ad2antrr 725 . . . . . . . . . . . . . . 15 (((𝑀 ∈ ℕ ∧ 𝑘 ∈ ℕ0) ∧ ((𝑘 + 1) + 1) ≤ 𝑀) → 𝑀 ∈ ℤ)
107 eluz 12833 . . . . . . . . . . . . . . 15 ((((𝑘 + 1) + 1) ∈ ℤ ∧ 𝑀 ∈ ℤ) → (𝑀 ∈ (ℤ‘((𝑘 + 1) + 1)) ↔ ((𝑘 + 1) + 1) ≤ 𝑀))
108104, 106, 107syl2anc 585 . . . . . . . . . . . . . 14 (((𝑀 ∈ ℕ ∧ 𝑘 ∈ ℕ0) ∧ ((𝑘 + 1) + 1) ≤ 𝑀) → (𝑀 ∈ (ℤ‘((𝑘 + 1) + 1)) ↔ ((𝑘 + 1) + 1) ≤ 𝑀))
109102, 108mpbird 257 . . . . . . . . . . . . 13 (((𝑀 ∈ ℕ ∧ 𝑘 ∈ ℕ0) ∧ ((𝑘 + 1) + 1) ≤ 𝑀) → 𝑀 ∈ (ℤ‘((𝑘 + 1) + 1)))
110100, 101, 109leexp2ad 14214 . . . . . . . . . . . 12 (((𝑀 ∈ ℕ ∧ 𝑘 ∈ ℕ0) ∧ ((𝑘 + 1) + 1) ≤ 𝑀) → (𝑀↑((𝑘 + 1) + 1)) ≤ (𝑀𝑀))
11137, 96anim12i 614 . . . . . . . . . . . . . 14 ((𝑀 ∈ ℕ ∧ 𝑘 ∈ ℕ0) → ((𝑀𝑀) ∈ ℝ ∧ (!‘(𝑘 + 1)) ∈ ℝ))
112 nn0re 12478 . . . . . . . . . . . . . . . . 17 (𝑀 ∈ ℕ0𝑀 ∈ ℝ)
113 id 22 . . . . . . . . . . . . . . . . 17 (𝑀 ∈ ℕ0𝑀 ∈ ℕ0)
114 nn0ge0 12494 . . . . . . . . . . . . . . . . 17 (𝑀 ∈ ℕ0 → 0 ≤ 𝑀)
115112, 113, 114expge0d 14126 . . . . . . . . . . . . . . . 16 (𝑀 ∈ ℕ0 → 0 ≤ (𝑀𝑀))
11636, 115syl 17 . . . . . . . . . . . . . . 15 (𝑀 ∈ ℕ → 0 ≤ (𝑀𝑀))
11795nnge1d 12257 . . . . . . . . . . . . . . 15 (𝑘 ∈ ℕ0 → 1 ≤ (!‘(𝑘 + 1)))
118116, 117anim12i 614 . . . . . . . . . . . . . 14 ((𝑀 ∈ ℕ ∧ 𝑘 ∈ ℕ0) → (0 ≤ (𝑀𝑀) ∧ 1 ≤ (!‘(𝑘 + 1))))
119 lemulge11 12073 . . . . . . . . . . . . . 14 ((((𝑀𝑀) ∈ ℝ ∧ (!‘(𝑘 + 1)) ∈ ℝ) ∧ (0 ≤ (𝑀𝑀) ∧ 1 ≤ (!‘(𝑘 + 1)))) → (𝑀𝑀) ≤ ((𝑀𝑀) · (!‘(𝑘 + 1))))
120111, 118, 119syl2anc 585 . . . . . . . . . . . . 13 ((𝑀 ∈ ℕ ∧ 𝑘 ∈ ℕ0) → (𝑀𝑀) ≤ ((𝑀𝑀) · (!‘(𝑘 + 1))))
121120adantr 482 . . . . . . . . . . . 12 (((𝑀 ∈ ℕ ∧ 𝑘 ∈ ℕ0) ∧ ((𝑘 + 1) + 1) ≤ 𝑀) → (𝑀𝑀) ≤ ((𝑀𝑀) · (!‘(𝑘 + 1))))
12293, 94, 99, 110, 121letrd 11368 . . . . . . . . . . 11 (((𝑀 ∈ ℕ ∧ 𝑘 ∈ ℕ0) ∧ ((𝑘 + 1) + 1) ≤ 𝑀) → (𝑀↑((𝑘 + 1) + 1)) ≤ ((𝑀𝑀) · (!‘(𝑘 + 1))))
123122ex 414 . . . . . . . . . 10 ((𝑀 ∈ ℕ ∧ 𝑘 ∈ ℕ0) → (((𝑘 + 1) + 1) ≤ 𝑀 → (𝑀↑((𝑘 + 1) + 1)) ≤ ((𝑀𝑀) · (!‘(𝑘 + 1)))))
12488, 123sylbid 239 . . . . . . . . 9 ((𝑀 ∈ ℕ ∧ 𝑘 ∈ ℕ0) → ((𝑘 + 1) < 𝑀 → (𝑀↑((𝑘 + 1) + 1)) ≤ ((𝑀𝑀) · (!‘(𝑘 + 1)))))
125124a1dd 50 . . . . . . . 8 ((𝑀 ∈ ℕ ∧ 𝑘 ∈ ℕ0) → ((𝑘 + 1) < 𝑀 → ((𝑀↑(𝑘 + 1)) ≤ ((𝑀𝑀) · (!‘𝑘)) → (𝑀↑((𝑘 + 1) + 1)) ≤ ((𝑀𝑀) · (!‘(𝑘 + 1))))))
12652, 53syl 17 . . . . . . . . 9 (𝑘 ∈ ℕ0 → (𝑘 + 1) ∈ ℝ)
127 lelttric 11318 . . . . . . . . 9 ((𝑀 ∈ ℝ ∧ (𝑘 + 1) ∈ ℝ) → (𝑀 ≤ (𝑘 + 1) ∨ (𝑘 + 1) < 𝑀))
12826, 126, 127syl2an 597 . . . . . . . 8 ((𝑀 ∈ ℕ ∧ 𝑘 ∈ ℕ0) → (𝑀 ≤ (𝑘 + 1) ∨ (𝑘 + 1) < 𝑀))
12986, 125, 128mpjaod 859 . . . . . . 7 ((𝑀 ∈ ℕ ∧ 𝑘 ∈ ℕ0) → ((𝑀↑(𝑘 + 1)) ≤ ((𝑀𝑀) · (!‘𝑘)) → (𝑀↑((𝑘 + 1) + 1)) ≤ ((𝑀𝑀) · (!‘(𝑘 + 1)))))
130129expcom 415 . . . . . 6 (𝑘 ∈ ℕ0 → (𝑀 ∈ ℕ → ((𝑀↑(𝑘 + 1)) ≤ ((𝑀𝑀) · (!‘𝑘)) → (𝑀↑((𝑘 + 1) + 1)) ≤ ((𝑀𝑀) · (!‘(𝑘 + 1))))))
131130a2d 29 . . . . 5 (𝑘 ∈ ℕ0 → ((𝑀 ∈ ℕ → (𝑀↑(𝑘 + 1)) ≤ ((𝑀𝑀) · (!‘𝑘))) → (𝑀 ∈ ℕ → (𝑀↑((𝑘 + 1) + 1)) ≤ ((𝑀𝑀) · (!‘(𝑘 + 1))))))
1327, 13, 19, 25, 41, 131nn0ind 12654 . . . 4 (𝑁 ∈ ℕ0 → (𝑀 ∈ ℕ → (𝑀↑(𝑁 + 1)) ≤ ((𝑀𝑀) · (!‘𝑁))))
133132impcom 409 . . 3 ((𝑀 ∈ ℕ ∧ 𝑁 ∈ ℕ0) → (𝑀↑(𝑁 + 1)) ≤ ((𝑀𝑀) · (!‘𝑁)))
134 faccl 14240 . . . . . . . 8 (𝑁 ∈ ℕ0 → (!‘𝑁) ∈ ℕ)
135134nnnn0d 12529 . . . . . . 7 (𝑁 ∈ ℕ0 → (!‘𝑁) ∈ ℕ0)
136135nn0ge0d 12532 . . . . . 6 (𝑁 ∈ ℕ0 → 0 ≤ (!‘𝑁))
137 nn0p1nn 12508 . . . . . . 7 (𝑁 ∈ ℕ0 → (𝑁 + 1) ∈ ℕ)
1381370expd 14101 . . . . . 6 (𝑁 ∈ ℕ0 → (0↑(𝑁 + 1)) = 0)
139 0exp0e1 14029 . . . . . . . 8 (0↑0) = 1
140139oveq1i 7416 . . . . . . 7 ((0↑0) · (!‘𝑁)) = (1 · (!‘𝑁))
141134nncnd 12225 . . . . . . . 8 (𝑁 ∈ ℕ0 → (!‘𝑁) ∈ ℂ)
142141mullidd 11229 . . . . . . 7 (𝑁 ∈ ℕ0 → (1 · (!‘𝑁)) = (!‘𝑁))
143140, 142eqtrid 2785 . . . . . 6 (𝑁 ∈ ℕ0 → ((0↑0) · (!‘𝑁)) = (!‘𝑁))
144136, 138, 1433brtr4d 5180 . . . . 5 (𝑁 ∈ ℕ0 → (0↑(𝑁 + 1)) ≤ ((0↑0) · (!‘𝑁)))
145 oveq1 7413 . . . . . 6 (𝑀 = 0 → (𝑀↑(𝑁 + 1)) = (0↑(𝑁 + 1)))
146 oveq12 7415 . . . . . . . 8 ((𝑀 = 0 ∧ 𝑀 = 0) → (𝑀𝑀) = (0↑0))
147146anidms 568 . . . . . . 7 (𝑀 = 0 → (𝑀𝑀) = (0↑0))
148147oveq1d 7421 . . . . . 6 (𝑀 = 0 → ((𝑀𝑀) · (!‘𝑁)) = ((0↑0) · (!‘𝑁)))
149145, 148breq12d 5161 . . . . 5 (𝑀 = 0 → ((𝑀↑(𝑁 + 1)) ≤ ((𝑀𝑀) · (!‘𝑁)) ↔ (0↑(𝑁 + 1)) ≤ ((0↑0) · (!‘𝑁))))
150144, 149imbitrrid 245 . . . 4 (𝑀 = 0 → (𝑁 ∈ ℕ0 → (𝑀↑(𝑁 + 1)) ≤ ((𝑀𝑀) · (!‘𝑁))))
151150imp 408 . . 3 ((𝑀 = 0 ∧ 𝑁 ∈ ℕ0) → (𝑀↑(𝑁 + 1)) ≤ ((𝑀𝑀) · (!‘𝑁)))
152133, 151jaoian 956 . 2 (((𝑀 ∈ ℕ ∨ 𝑀 = 0) ∧ 𝑁 ∈ ℕ0) → (𝑀↑(𝑁 + 1)) ≤ ((𝑀𝑀) · (!‘𝑁)))
1531, 152sylanb 582 1 ((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) → (𝑀↑(𝑁 + 1)) ≤ ((𝑀𝑀) · (!‘𝑁)))
Colors of variables: wff setvar class
Syntax hints:  wi 4  wb 205  wa 397  wo 846   = wceq 1542  wcel 2107   class class class wbr 5148  cfv 6541  (class class class)co 7406  cc 11105  cr 11106  0cc0 11107  1c1 11108   + caddc 11110   · cmul 11112   < clt 11245  cle 11246  cn 12209  0cn0 12469  cz 12555  cuz 12819  cexp 14024  !cfa 14230
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-3 8  ax-gen 1798  ax-4 1812  ax-5 1914  ax-6 1972  ax-7 2012  ax-8 2109  ax-9 2117  ax-10 2138  ax-11 2155  ax-12 2172  ax-ext 2704  ax-sep 5299  ax-nul 5306  ax-pow 5363  ax-pr 5427  ax-un 7722  ax-cnex 11163  ax-resscn 11164  ax-1cn 11165  ax-icn 11166  ax-addcl 11167  ax-addrcl 11168  ax-mulcl 11169  ax-mulrcl 11170  ax-mulcom 11171  ax-addass 11172  ax-mulass 11173  ax-distr 11174  ax-i2m1 11175  ax-1ne0 11176  ax-1rid 11177  ax-rnegex 11178  ax-rrecex 11179  ax-cnre 11180  ax-pre-lttri 11181  ax-pre-lttrn 11182  ax-pre-ltadd 11183  ax-pre-mulgt0 11184
This theorem depends on definitions:  df-bi 206  df-an 398  df-or 847  df-3or 1089  df-3an 1090  df-tru 1545  df-fal 1555  df-ex 1783  df-nf 1787  df-sb 2069  df-mo 2535  df-eu 2564  df-clab 2711  df-cleq 2725  df-clel 2811  df-nfc 2886  df-ne 2942  df-nel 3048  df-ral 3063  df-rex 3072  df-rmo 3377  df-reu 3378  df-rab 3434  df-v 3477  df-sbc 3778  df-csb 3894  df-dif 3951  df-un 3953  df-in 3955  df-ss 3965  df-pss 3967  df-nul 4323  df-if 4529  df-pw 4604  df-sn 4629  df-pr 4631  df-op 4635  df-uni 4909  df-iun 4999  df-br 5149  df-opab 5211  df-mpt 5232  df-tr 5266  df-id 5574  df-eprel 5580  df-po 5588  df-so 5589  df-fr 5631  df-we 5633  df-xp 5682  df-rel 5683  df-cnv 5684  df-co 5685  df-dm 5686  df-rn 5687  df-res 5688  df-ima 5689  df-pred 6298  df-ord 6365  df-on 6366  df-lim 6367  df-suc 6368  df-iota 6493  df-fun 6543  df-fn 6544  df-f 6545  df-f1 6546  df-fo 6547  df-f1o 6548  df-fv 6549  df-riota 7362  df-ov 7409  df-oprab 7410  df-mpo 7411  df-om 7853  df-2nd 7973  df-frecs 8263  df-wrecs 8294  df-recs 8368  df-rdg 8407  df-er 8700  df-en 8937  df-dom 8938  df-sdom 8939  df-pnf 11247  df-mnf 11248  df-xr 11249  df-ltxr 11250  df-le 11251  df-sub 11443  df-neg 11444  df-div 11869  df-nn 12210  df-n0 12470  df-z 12556  df-uz 12820  df-rp 12972  df-seq 13964  df-exp 14025  df-fac 14231
This theorem is referenced by:  faclbnd2  14248  faclbnd3  14249
  Copyright terms: Public domain W3C validator