Proof of Theorem faclbnd3
Step | Hyp | Ref
| Expression |
1 | | elnn0 9116 |
. 2
⊢ (𝑀 ∈ ℕ0
↔ (𝑀 ∈ ℕ
∨ 𝑀 =
0)) |
2 | | nnre 8864 |
. . . . . 6
⊢ (𝑀 ∈ ℕ → 𝑀 ∈
ℝ) |
3 | 2 | adantr 274 |
. . . . 5
⊢ ((𝑀 ∈ ℕ ∧ 𝑁 ∈ ℕ0)
→ 𝑀 ∈
ℝ) |
4 | | nnge1 8880 |
. . . . . 6
⊢ (𝑀 ∈ ℕ → 1 ≤
𝑀) |
5 | 4 | adantr 274 |
. . . . 5
⊢ ((𝑀 ∈ ℕ ∧ 𝑁 ∈ ℕ0)
→ 1 ≤ 𝑀) |
6 | | nn0z 9211 |
. . . . . . 7
⊢ (𝑁 ∈ ℕ0
→ 𝑁 ∈
ℤ) |
7 | 6 | adantl 275 |
. . . . . 6
⊢ ((𝑀 ∈ ℕ ∧ 𝑁 ∈ ℕ0)
→ 𝑁 ∈
ℤ) |
8 | | uzid 9480 |
. . . . . 6
⊢ (𝑁 ∈ ℤ → 𝑁 ∈
(ℤ≥‘𝑁)) |
9 | | peano2uz 9521 |
. . . . . 6
⊢ (𝑁 ∈
(ℤ≥‘𝑁) → (𝑁 + 1) ∈
(ℤ≥‘𝑁)) |
10 | 7, 8, 9 | 3syl 17 |
. . . . 5
⊢ ((𝑀 ∈ ℕ ∧ 𝑁 ∈ ℕ0)
→ (𝑁 + 1) ∈
(ℤ≥‘𝑁)) |
11 | 3, 5, 10 | leexp2ad 10617 |
. . . 4
⊢ ((𝑀 ∈ ℕ ∧ 𝑁 ∈ ℕ0)
→ (𝑀↑𝑁) ≤ (𝑀↑(𝑁 + 1))) |
12 | | nnnn0 9121 |
. . . . 5
⊢ (𝑀 ∈ ℕ → 𝑀 ∈
ℕ0) |
13 | | faclbnd 10654 |
. . . . 5
⊢ ((𝑀 ∈ ℕ0
∧ 𝑁 ∈
ℕ0) → (𝑀↑(𝑁 + 1)) ≤ ((𝑀↑𝑀) · (!‘𝑁))) |
14 | 12, 13 | sylan 281 |
. . . 4
⊢ ((𝑀 ∈ ℕ ∧ 𝑁 ∈ ℕ0)
→ (𝑀↑(𝑁 + 1)) ≤ ((𝑀↑𝑀) · (!‘𝑁))) |
15 | | nn0re 9123 |
. . . . . . 7
⊢ (𝑀 ∈ ℕ0
→ 𝑀 ∈
ℝ) |
16 | | reexpcl 10472 |
. . . . . . 7
⊢ ((𝑀 ∈ ℝ ∧ 𝑁 ∈ ℕ0)
→ (𝑀↑𝑁) ∈
ℝ) |
17 | 15, 16 | sylan 281 |
. . . . . 6
⊢ ((𝑀 ∈ ℕ0
∧ 𝑁 ∈
ℕ0) → (𝑀↑𝑁) ∈ ℝ) |
18 | | peano2nn0 9154 |
. . . . . . 7
⊢ (𝑁 ∈ ℕ0
→ (𝑁 + 1) ∈
ℕ0) |
19 | | reexpcl 10472 |
. . . . . . 7
⊢ ((𝑀 ∈ ℝ ∧ (𝑁 + 1) ∈
ℕ0) → (𝑀↑(𝑁 + 1)) ∈ ℝ) |
20 | 15, 18, 19 | syl2an 287 |
. . . . . 6
⊢ ((𝑀 ∈ ℕ0
∧ 𝑁 ∈
ℕ0) → (𝑀↑(𝑁 + 1)) ∈ ℝ) |
21 | | reexpcl 10472 |
. . . . . . . 8
⊢ ((𝑀 ∈ ℝ ∧ 𝑀 ∈ ℕ0)
→ (𝑀↑𝑀) ∈
ℝ) |
22 | 15, 21 | mpancom 419 |
. . . . . . 7
⊢ (𝑀 ∈ ℕ0
→ (𝑀↑𝑀) ∈
ℝ) |
23 | | faccl 10648 |
. . . . . . . 8
⊢ (𝑁 ∈ ℕ0
→ (!‘𝑁) ∈
ℕ) |
24 | 23 | nnred 8870 |
. . . . . . 7
⊢ (𝑁 ∈ ℕ0
→ (!‘𝑁) ∈
ℝ) |
25 | | remulcl 7881 |
. . . . . . 7
⊢ (((𝑀↑𝑀) ∈ ℝ ∧ (!‘𝑁) ∈ ℝ) → ((𝑀↑𝑀) · (!‘𝑁)) ∈ ℝ) |
26 | 22, 24, 25 | syl2an 287 |
. . . . . 6
⊢ ((𝑀 ∈ ℕ0
∧ 𝑁 ∈
ℕ0) → ((𝑀↑𝑀) · (!‘𝑁)) ∈ ℝ) |
27 | | letr 7981 |
. . . . . 6
⊢ (((𝑀↑𝑁) ∈ ℝ ∧ (𝑀↑(𝑁 + 1)) ∈ ℝ ∧ ((𝑀↑𝑀) · (!‘𝑁)) ∈ ℝ) → (((𝑀↑𝑁) ≤ (𝑀↑(𝑁 + 1)) ∧ (𝑀↑(𝑁 + 1)) ≤ ((𝑀↑𝑀) · (!‘𝑁))) → (𝑀↑𝑁) ≤ ((𝑀↑𝑀) · (!‘𝑁)))) |
28 | 17, 20, 26, 27 | syl3anc 1228 |
. . . . 5
⊢ ((𝑀 ∈ ℕ0
∧ 𝑁 ∈
ℕ0) → (((𝑀↑𝑁) ≤ (𝑀↑(𝑁 + 1)) ∧ (𝑀↑(𝑁 + 1)) ≤ ((𝑀↑𝑀) · (!‘𝑁))) → (𝑀↑𝑁) ≤ ((𝑀↑𝑀) · (!‘𝑁)))) |
29 | 12, 28 | sylan 281 |
. . . 4
⊢ ((𝑀 ∈ ℕ ∧ 𝑁 ∈ ℕ0)
→ (((𝑀↑𝑁) ≤ (𝑀↑(𝑁 + 1)) ∧ (𝑀↑(𝑁 + 1)) ≤ ((𝑀↑𝑀) · (!‘𝑁))) → (𝑀↑𝑁) ≤ ((𝑀↑𝑀) · (!‘𝑁)))) |
30 | 11, 14, 29 | mp2and 430 |
. . 3
⊢ ((𝑀 ∈ ℕ ∧ 𝑁 ∈ ℕ0)
→ (𝑀↑𝑁) ≤ ((𝑀↑𝑀) · (!‘𝑁))) |
31 | | elnn0 9116 |
. . . . . . 7
⊢ (𝑁 ∈ ℕ0
↔ (𝑁 ∈ ℕ
∨ 𝑁 =
0)) |
32 | | 0exp 10490 |
. . . . . . . . 9
⊢ (𝑁 ∈ ℕ →
(0↑𝑁) =
0) |
33 | | 0le1 8379 |
. . . . . . . . 9
⊢ 0 ≤
1 |
34 | 32, 33 | eqbrtrdi 4021 |
. . . . . . . 8
⊢ (𝑁 ∈ ℕ →
(0↑𝑁) ≤
1) |
35 | | oveq2 5850 |
. . . . . . . . 9
⊢ (𝑁 = 0 → (0↑𝑁) = (0↑0)) |
36 | | 0exp0e1 10460 |
. . . . . . . . . 10
⊢
(0↑0) = 1 |
37 | | 1le1 8470 |
. . . . . . . . . 10
⊢ 1 ≤
1 |
38 | 36, 37 | eqbrtri 4003 |
. . . . . . . . 9
⊢
(0↑0) ≤ 1 |
39 | 35, 38 | eqbrtrdi 4021 |
. . . . . . . 8
⊢ (𝑁 = 0 → (0↑𝑁) ≤ 1) |
40 | 34, 39 | jaoi 706 |
. . . . . . 7
⊢ ((𝑁 ∈ ℕ ∨ 𝑁 = 0) → (0↑𝑁) ≤ 1) |
41 | 31, 40 | sylbi 120 |
. . . . . 6
⊢ (𝑁 ∈ ℕ0
→ (0↑𝑁) ≤
1) |
42 | | 1nn 8868 |
. . . . . . . 8
⊢ 1 ∈
ℕ |
43 | | nnmulcl 8878 |
. . . . . . . 8
⊢ ((1
∈ ℕ ∧ (!‘𝑁) ∈ ℕ) → (1 ·
(!‘𝑁)) ∈
ℕ) |
44 | 42, 23, 43 | sylancr 411 |
. . . . . . 7
⊢ (𝑁 ∈ ℕ0
→ (1 · (!‘𝑁)) ∈ ℕ) |
45 | 44 | nnge1d 8900 |
. . . . . 6
⊢ (𝑁 ∈ ℕ0
→ 1 ≤ (1 · (!‘𝑁))) |
46 | | 0re 7899 |
. . . . . . . 8
⊢ 0 ∈
ℝ |
47 | | reexpcl 10472 |
. . . . . . . 8
⊢ ((0
∈ ℝ ∧ 𝑁
∈ ℕ0) → (0↑𝑁) ∈ ℝ) |
48 | 46, 47 | mpan 421 |
. . . . . . 7
⊢ (𝑁 ∈ ℕ0
→ (0↑𝑁) ∈
ℝ) |
49 | | 1re 7898 |
. . . . . . . 8
⊢ 1 ∈
ℝ |
50 | | remulcl 7881 |
. . . . . . . 8
⊢ ((1
∈ ℝ ∧ (!‘𝑁) ∈ ℝ) → (1 ·
(!‘𝑁)) ∈
ℝ) |
51 | 49, 24, 50 | sylancr 411 |
. . . . . . 7
⊢ (𝑁 ∈ ℕ0
→ (1 · (!‘𝑁)) ∈ ℝ) |
52 | | letr 7981 |
. . . . . . . 8
⊢
(((0↑𝑁) ∈
ℝ ∧ 1 ∈ ℝ ∧ (1 · (!‘𝑁)) ∈ ℝ) → (((0↑𝑁) ≤ 1 ∧ 1 ≤ (1
· (!‘𝑁)))
→ (0↑𝑁) ≤ (1
· (!‘𝑁)))) |
53 | 49, 52 | mp3an2 1315 |
. . . . . . 7
⊢
(((0↑𝑁) ∈
ℝ ∧ (1 · (!‘𝑁)) ∈ ℝ) → (((0↑𝑁) ≤ 1 ∧ 1 ≤ (1
· (!‘𝑁)))
→ (0↑𝑁) ≤ (1
· (!‘𝑁)))) |
54 | 48, 51, 53 | syl2anc 409 |
. . . . . 6
⊢ (𝑁 ∈ ℕ0
→ (((0↑𝑁) ≤ 1
∧ 1 ≤ (1 · (!‘𝑁))) → (0↑𝑁) ≤ (1 · (!‘𝑁)))) |
55 | 41, 45, 54 | mp2and 430 |
. . . . 5
⊢ (𝑁 ∈ ℕ0
→ (0↑𝑁) ≤ (1
· (!‘𝑁))) |
56 | 55 | adantl 275 |
. . . 4
⊢ ((𝑀 = 0 ∧ 𝑁 ∈ ℕ0) →
(0↑𝑁) ≤ (1 ·
(!‘𝑁))) |
57 | | oveq1 5849 |
. . . . . 6
⊢ (𝑀 = 0 → (𝑀↑𝑁) = (0↑𝑁)) |
58 | | oveq12 5851 |
. . . . . . . . 9
⊢ ((𝑀 = 0 ∧ 𝑀 = 0) → (𝑀↑𝑀) = (0↑0)) |
59 | 58 | anidms 395 |
. . . . . . . 8
⊢ (𝑀 = 0 → (𝑀↑𝑀) = (0↑0)) |
60 | 59, 36 | eqtrdi 2215 |
. . . . . . 7
⊢ (𝑀 = 0 → (𝑀↑𝑀) = 1) |
61 | 60 | oveq1d 5857 |
. . . . . 6
⊢ (𝑀 = 0 → ((𝑀↑𝑀) · (!‘𝑁)) = (1 · (!‘𝑁))) |
62 | 57, 61 | breq12d 3995 |
. . . . 5
⊢ (𝑀 = 0 → ((𝑀↑𝑁) ≤ ((𝑀↑𝑀) · (!‘𝑁)) ↔ (0↑𝑁) ≤ (1 · (!‘𝑁)))) |
63 | 62 | adantr 274 |
. . . 4
⊢ ((𝑀 = 0 ∧ 𝑁 ∈ ℕ0) → ((𝑀↑𝑁) ≤ ((𝑀↑𝑀) · (!‘𝑁)) ↔ (0↑𝑁) ≤ (1 · (!‘𝑁)))) |
64 | 56, 63 | mpbird 166 |
. . 3
⊢ ((𝑀 = 0 ∧ 𝑁 ∈ ℕ0) → (𝑀↑𝑁) ≤ ((𝑀↑𝑀) · (!‘𝑁))) |
65 | 30, 64 | jaoian 785 |
. 2
⊢ (((𝑀 ∈ ℕ ∨ 𝑀 = 0) ∧ 𝑁 ∈ ℕ0) → (𝑀↑𝑁) ≤ ((𝑀↑𝑀) · (!‘𝑁))) |
66 | 1, 65 | sylanb 282 |
1
⊢ ((𝑀 ∈ ℕ0
∧ 𝑁 ∈
ℕ0) → (𝑀↑𝑁) ≤ ((𝑀↑𝑀) · (!‘𝑁))) |