Users' Mathboxes Mathbox for Alexander van der Vekens < Previous   Next >
Nearby theorems
Mirrors  >  Home  >  MPE Home  >  Th. List  >   Mathboxes  >  fmtnoprmfac2 Structured version   Visualization version   GIF version

Theorem fmtnoprmfac2 44907
Description: Divisor of Fermat number (special form of Lucas' result, see fmtnofac2 44909): Let Fn be a Fermat number. Let p be a prime divisor of Fn. Then p is in the form: k*2^(n+2)+1 where k is a positive integer. (Contributed by AV, 26-Jul-2021.)
Assertion
Ref Expression
fmtnoprmfac2 ((𝑁 ∈ (ℤ‘2) ∧ 𝑃 ∈ ℙ ∧ 𝑃 ∥ (FermatNo‘𝑁)) → ∃𝑘 ∈ ℕ 𝑃 = ((𝑘 · (2↑(𝑁 + 2))) + 1))
Distinct variable groups:   𝑘,𝑁   𝑃,𝑘

Proof of Theorem fmtnoprmfac2
StepHypRef Expression
1 breq1 5073 . . . . . . 7 (𝑃 = 2 → (𝑃 ∥ (FermatNo‘𝑁) ↔ 2 ∥ (FermatNo‘𝑁)))
21adantr 480 . . . . . 6 ((𝑃 = 2 ∧ 𝑁 ∈ (ℤ‘2)) → (𝑃 ∥ (FermatNo‘𝑁) ↔ 2 ∥ (FermatNo‘𝑁)))
3 eluzge2nn0 12556 . . . . . . . . 9 (𝑁 ∈ (ℤ‘2) → 𝑁 ∈ ℕ0)
4 fmtnoodd 44873 . . . . . . . . 9 (𝑁 ∈ ℕ0 → ¬ 2 ∥ (FermatNo‘𝑁))
53, 4syl 17 . . . . . . . 8 (𝑁 ∈ (ℤ‘2) → ¬ 2 ∥ (FermatNo‘𝑁))
65adantl 481 . . . . . . 7 ((𝑃 = 2 ∧ 𝑁 ∈ (ℤ‘2)) → ¬ 2 ∥ (FermatNo‘𝑁))
76pm2.21d 121 . . . . . 6 ((𝑃 = 2 ∧ 𝑁 ∈ (ℤ‘2)) → (2 ∥ (FermatNo‘𝑁) → ∃𝑘 ∈ ℕ 𝑃 = ((𝑘 · (2↑(𝑁 + 2))) + 1)))
82, 7sylbid 239 . . . . 5 ((𝑃 = 2 ∧ 𝑁 ∈ (ℤ‘2)) → (𝑃 ∥ (FermatNo‘𝑁) → ∃𝑘 ∈ ℕ 𝑃 = ((𝑘 · (2↑(𝑁 + 2))) + 1)))
98a1d 25 . . . 4 ((𝑃 = 2 ∧ 𝑁 ∈ (ℤ‘2)) → (𝑃 ∈ ℙ → (𝑃 ∥ (FermatNo‘𝑁) → ∃𝑘 ∈ ℕ 𝑃 = ((𝑘 · (2↑(𝑁 + 2))) + 1))))
109ex 412 . . 3 (𝑃 = 2 → (𝑁 ∈ (ℤ‘2) → (𝑃 ∈ ℙ → (𝑃 ∥ (FermatNo‘𝑁) → ∃𝑘 ∈ ℕ 𝑃 = ((𝑘 · (2↑(𝑁 + 2))) + 1)))))
11103impd 1346 . 2 (𝑃 = 2 → ((𝑁 ∈ (ℤ‘2) ∧ 𝑃 ∈ ℙ ∧ 𝑃 ∥ (FermatNo‘𝑁)) → ∃𝑘 ∈ ℕ 𝑃 = ((𝑘 · (2↑(𝑁 + 2))) + 1)))
12 simpr1 1192 . . . . 5 ((¬ 𝑃 = 2 ∧ (𝑁 ∈ (ℤ‘2) ∧ 𝑃 ∈ ℙ ∧ 𝑃 ∥ (FermatNo‘𝑁))) → 𝑁 ∈ (ℤ‘2))
13 neqne 2950 . . . . . . . . . 10 𝑃 = 2 → 𝑃 ≠ 2)
1413anim2i 616 . . . . . . . . 9 ((𝑃 ∈ ℙ ∧ ¬ 𝑃 = 2) → (𝑃 ∈ ℙ ∧ 𝑃 ≠ 2))
15 eldifsn 4717 . . . . . . . . 9 (𝑃 ∈ (ℙ ∖ {2}) ↔ (𝑃 ∈ ℙ ∧ 𝑃 ≠ 2))
1614, 15sylibr 233 . . . . . . . 8 ((𝑃 ∈ ℙ ∧ ¬ 𝑃 = 2) → 𝑃 ∈ (ℙ ∖ {2}))
1716ex 412 . . . . . . 7 (𝑃 ∈ ℙ → (¬ 𝑃 = 2 → 𝑃 ∈ (ℙ ∖ {2})))
18173ad2ant2 1132 . . . . . 6 ((𝑁 ∈ (ℤ‘2) ∧ 𝑃 ∈ ℙ ∧ 𝑃 ∥ (FermatNo‘𝑁)) → (¬ 𝑃 = 2 → 𝑃 ∈ (ℙ ∖ {2})))
1918impcom 407 . . . . 5 ((¬ 𝑃 = 2 ∧ (𝑁 ∈ (ℤ‘2) ∧ 𝑃 ∈ ℙ ∧ 𝑃 ∥ (FermatNo‘𝑁))) → 𝑃 ∈ (ℙ ∖ {2}))
20 simpr3 1194 . . . . 5 ((¬ 𝑃 = 2 ∧ (𝑁 ∈ (ℤ‘2) ∧ 𝑃 ∈ ℙ ∧ 𝑃 ∥ (FermatNo‘𝑁))) → 𝑃 ∥ (FermatNo‘𝑁))
21 fmtnoprmfac2lem1 44906 . . . . 5 ((𝑁 ∈ (ℤ‘2) ∧ 𝑃 ∈ (ℙ ∖ {2}) ∧ 𝑃 ∥ (FermatNo‘𝑁)) → ((2↑((𝑃 − 1) / 2)) mod 𝑃) = 1)
2212, 19, 20, 21syl3anc 1369 . . . 4 ((¬ 𝑃 = 2 ∧ (𝑁 ∈ (ℤ‘2) ∧ 𝑃 ∈ ℙ ∧ 𝑃 ∥ (FermatNo‘𝑁))) → ((2↑((𝑃 − 1) / 2)) mod 𝑃) = 1)
23 simpl 482 . . . . . . . . . 10 ((𝑃 ∈ ℙ ∧ ¬ 𝑃 = 2) → 𝑃 ∈ ℙ)
24 2nn 11976 . . . . . . . . . . . . 13 2 ∈ ℕ
2524a1i 11 . . . . . . . . . . . 12 ((𝑃 ∈ ℙ ∧ ¬ 𝑃 = 2) → 2 ∈ ℕ)
26 oddprm 16439 . . . . . . . . . . . . . 14 (𝑃 ∈ (ℙ ∖ {2}) → ((𝑃 − 1) / 2) ∈ ℕ)
2716, 26syl 17 . . . . . . . . . . . . 13 ((𝑃 ∈ ℙ ∧ ¬ 𝑃 = 2) → ((𝑃 − 1) / 2) ∈ ℕ)
2827nnnn0d 12223 . . . . . . . . . . . 12 ((𝑃 ∈ ℙ ∧ ¬ 𝑃 = 2) → ((𝑃 − 1) / 2) ∈ ℕ0)
2925, 28nnexpcld 13888 . . . . . . . . . . 11 ((𝑃 ∈ ℙ ∧ ¬ 𝑃 = 2) → (2↑((𝑃 − 1) / 2)) ∈ ℕ)
3029nnzd 12354 . . . . . . . . . 10 ((𝑃 ∈ ℙ ∧ ¬ 𝑃 = 2) → (2↑((𝑃 − 1) / 2)) ∈ ℤ)
3123, 30jca 511 . . . . . . . . 9 ((𝑃 ∈ ℙ ∧ ¬ 𝑃 = 2) → (𝑃 ∈ ℙ ∧ (2↑((𝑃 − 1) / 2)) ∈ ℤ))
3231ex 412 . . . . . . . 8 (𝑃 ∈ ℙ → (¬ 𝑃 = 2 → (𝑃 ∈ ℙ ∧ (2↑((𝑃 − 1) / 2)) ∈ ℤ)))
33323ad2ant2 1132 . . . . . . 7 ((𝑁 ∈ (ℤ‘2) ∧ 𝑃 ∈ ℙ ∧ 𝑃 ∥ (FermatNo‘𝑁)) → (¬ 𝑃 = 2 → (𝑃 ∈ ℙ ∧ (2↑((𝑃 − 1) / 2)) ∈ ℤ)))
3433impcom 407 . . . . . 6 ((¬ 𝑃 = 2 ∧ (𝑁 ∈ (ℤ‘2) ∧ 𝑃 ∈ ℙ ∧ 𝑃 ∥ (FermatNo‘𝑁))) → (𝑃 ∈ ℙ ∧ (2↑((𝑃 − 1) / 2)) ∈ ℤ))
35 modprm1div 16426 . . . . . 6 ((𝑃 ∈ ℙ ∧ (2↑((𝑃 − 1) / 2)) ∈ ℤ) → (((2↑((𝑃 − 1) / 2)) mod 𝑃) = 1 ↔ 𝑃 ∥ ((2↑((𝑃 − 1) / 2)) − 1)))
3634, 35syl 17 . . . . 5 ((¬ 𝑃 = 2 ∧ (𝑁 ∈ (ℤ‘2) ∧ 𝑃 ∈ ℙ ∧ 𝑃 ∥ (FermatNo‘𝑁))) → (((2↑((𝑃 − 1) / 2)) mod 𝑃) = 1 ↔ 𝑃 ∥ ((2↑((𝑃 − 1) / 2)) − 1)))
37 prmnn 16307 . . . . . . . . . . . . 13 (𝑃 ∈ ℙ → 𝑃 ∈ ℕ)
3837adantr 480 . . . . . . . . . . . 12 ((𝑃 ∈ ℙ ∧ ¬ 𝑃 = 2) → 𝑃 ∈ ℕ)
39 2z 12282 . . . . . . . . . . . . 13 2 ∈ ℤ
4039a1i 11 . . . . . . . . . . . 12 ((𝑃 ∈ ℙ ∧ ¬ 𝑃 = 2) → 2 ∈ ℤ)
4113necomd 2998 . . . . . . . . . . . . . 14 𝑃 = 2 → 2 ≠ 𝑃)
4241adantl 481 . . . . . . . . . . . . 13 ((𝑃 ∈ ℙ ∧ ¬ 𝑃 = 2) → 2 ≠ 𝑃)
43 2prm 16325 . . . . . . . . . . . . . . . . 17 2 ∈ ℙ
4443a1i 11 . . . . . . . . . . . . . . . 16 𝑃 = 2 → 2 ∈ ℙ)
4544anim2i 616 . . . . . . . . . . . . . . 15 ((𝑃 ∈ ℙ ∧ ¬ 𝑃 = 2) → (𝑃 ∈ ℙ ∧ 2 ∈ ℙ))
4645ancomd 461 . . . . . . . . . . . . . 14 ((𝑃 ∈ ℙ ∧ ¬ 𝑃 = 2) → (2 ∈ ℙ ∧ 𝑃 ∈ ℙ))
47 prmrp 16345 . . . . . . . . . . . . . 14 ((2 ∈ ℙ ∧ 𝑃 ∈ ℙ) → ((2 gcd 𝑃) = 1 ↔ 2 ≠ 𝑃))
4846, 47syl 17 . . . . . . . . . . . . 13 ((𝑃 ∈ ℙ ∧ ¬ 𝑃 = 2) → ((2 gcd 𝑃) = 1 ↔ 2 ≠ 𝑃))
4942, 48mpbird 256 . . . . . . . . . . . 12 ((𝑃 ∈ ℙ ∧ ¬ 𝑃 = 2) → (2 gcd 𝑃) = 1)
5038, 40, 493jca 1126 . . . . . . . . . . 11 ((𝑃 ∈ ℙ ∧ ¬ 𝑃 = 2) → (𝑃 ∈ ℕ ∧ 2 ∈ ℤ ∧ (2 gcd 𝑃) = 1))
5150, 28jca 511 . . . . . . . . . 10 ((𝑃 ∈ ℙ ∧ ¬ 𝑃 = 2) → ((𝑃 ∈ ℕ ∧ 2 ∈ ℤ ∧ (2 gcd 𝑃) = 1) ∧ ((𝑃 − 1) / 2) ∈ ℕ0))
5251ex 412 . . . . . . . . 9 (𝑃 ∈ ℙ → (¬ 𝑃 = 2 → ((𝑃 ∈ ℕ ∧ 2 ∈ ℤ ∧ (2 gcd 𝑃) = 1) ∧ ((𝑃 − 1) / 2) ∈ ℕ0)))
53523ad2ant2 1132 . . . . . . . 8 ((𝑁 ∈ (ℤ‘2) ∧ 𝑃 ∈ ℙ ∧ 𝑃 ∥ (FermatNo‘𝑁)) → (¬ 𝑃 = 2 → ((𝑃 ∈ ℕ ∧ 2 ∈ ℤ ∧ (2 gcd 𝑃) = 1) ∧ ((𝑃 − 1) / 2) ∈ ℕ0)))
5453impcom 407 . . . . . . 7 ((¬ 𝑃 = 2 ∧ (𝑁 ∈ (ℤ‘2) ∧ 𝑃 ∈ ℙ ∧ 𝑃 ∥ (FermatNo‘𝑁))) → ((𝑃 ∈ ℕ ∧ 2 ∈ ℤ ∧ (2 gcd 𝑃) = 1) ∧ ((𝑃 − 1) / 2) ∈ ℕ0))
55 odzdvds 16424 . . . . . . 7 (((𝑃 ∈ ℕ ∧ 2 ∈ ℤ ∧ (2 gcd 𝑃) = 1) ∧ ((𝑃 − 1) / 2) ∈ ℕ0) → (𝑃 ∥ ((2↑((𝑃 − 1) / 2)) − 1) ↔ ((od𝑃)‘2) ∥ ((𝑃 − 1) / 2)))
5654, 55syl 17 . . . . . 6 ((¬ 𝑃 = 2 ∧ (𝑁 ∈ (ℤ‘2) ∧ 𝑃 ∈ ℙ ∧ 𝑃 ∥ (FermatNo‘𝑁))) → (𝑃 ∥ ((2↑((𝑃 − 1) / 2)) − 1) ↔ ((od𝑃)‘2) ∥ ((𝑃 − 1) / 2)))
57 eluz2nn 12553 . . . . . . . . . 10 (𝑁 ∈ (ℤ‘2) → 𝑁 ∈ ℕ)
58573ad2ant1 1131 . . . . . . . . 9 ((𝑁 ∈ (ℤ‘2) ∧ 𝑃 ∈ ℙ ∧ 𝑃 ∥ (FermatNo‘𝑁)) → 𝑁 ∈ ℕ)
5958adantl 481 . . . . . . . 8 ((¬ 𝑃 = 2 ∧ (𝑁 ∈ (ℤ‘2) ∧ 𝑃 ∈ ℙ ∧ 𝑃 ∥ (FermatNo‘𝑁))) → 𝑁 ∈ ℕ)
60 fmtnoprmfac1lem 44904 . . . . . . . 8 ((𝑁 ∈ ℕ ∧ 𝑃 ∈ (ℙ ∖ {2}) ∧ 𝑃 ∥ (FermatNo‘𝑁)) → ((od𝑃)‘2) = (2↑(𝑁 + 1)))
6159, 19, 20, 60syl3anc 1369 . . . . . . 7 ((¬ 𝑃 = 2 ∧ (𝑁 ∈ (ℤ‘2) ∧ 𝑃 ∈ ℙ ∧ 𝑃 ∥ (FermatNo‘𝑁))) → ((od𝑃)‘2) = (2↑(𝑁 + 1)))
62 breq1 5073 . . . . . . . . . 10 (((od𝑃)‘2) = (2↑(𝑁 + 1)) → (((od𝑃)‘2) ∥ ((𝑃 − 1) / 2) ↔ (2↑(𝑁 + 1)) ∥ ((𝑃 − 1) / 2)))
6362adantl 481 . . . . . . . . 9 (((¬ 𝑃 = 2 ∧ (𝑁 ∈ (ℤ‘2) ∧ 𝑃 ∈ ℙ ∧ 𝑃 ∥ (FermatNo‘𝑁))) ∧ ((od𝑃)‘2) = (2↑(𝑁 + 1))) → (((od𝑃)‘2) ∥ ((𝑃 − 1) / 2) ↔ (2↑(𝑁 + 1)) ∥ ((𝑃 − 1) / 2)))
6424a1i 11 . . . . . . . . . . . . . . . 16 (𝑁 ∈ (ℤ‘2) → 2 ∈ ℕ)
65 peano2nn 11915 . . . . . . . . . . . . . . . . . 18 (𝑁 ∈ ℕ → (𝑁 + 1) ∈ ℕ)
6657, 65syl 17 . . . . . . . . . . . . . . . . 17 (𝑁 ∈ (ℤ‘2) → (𝑁 + 1) ∈ ℕ)
6766nnnn0d 12223 . . . . . . . . . . . . . . . 16 (𝑁 ∈ (ℤ‘2) → (𝑁 + 1) ∈ ℕ0)
6864, 67nnexpcld 13888 . . . . . . . . . . . . . . 15 (𝑁 ∈ (ℤ‘2) → (2↑(𝑁 + 1)) ∈ ℕ)
69 nndivides 15901 . . . . . . . . . . . . . . 15 (((2↑(𝑁 + 1)) ∈ ℕ ∧ ((𝑃 − 1) / 2) ∈ ℕ) → ((2↑(𝑁 + 1)) ∥ ((𝑃 − 1) / 2) ↔ ∃𝑘 ∈ ℕ (𝑘 · (2↑(𝑁 + 1))) = ((𝑃 − 1) / 2)))
7068, 27, 69syl2an 595 . . . . . . . . . . . . . 14 ((𝑁 ∈ (ℤ‘2) ∧ (𝑃 ∈ ℙ ∧ ¬ 𝑃 = 2)) → ((2↑(𝑁 + 1)) ∥ ((𝑃 − 1) / 2) ↔ ∃𝑘 ∈ ℕ (𝑘 · (2↑(𝑁 + 1))) = ((𝑃 − 1) / 2)))
71 eqcom 2745 . . . . . . . . . . . . . . . . . . 19 ((𝑘 · (2↑(𝑁 + 1))) = ((𝑃 − 1) / 2) ↔ ((𝑃 − 1) / 2) = (𝑘 · (2↑(𝑁 + 1))))
7271a1i 11 . . . . . . . . . . . . . . . . . 18 (((𝑁 ∈ (ℤ‘2) ∧ 𝑃 ∈ ℙ) ∧ 𝑘 ∈ ℕ) → ((𝑘 · (2↑(𝑁 + 1))) = ((𝑃 − 1) / 2) ↔ ((𝑃 − 1) / 2) = (𝑘 · (2↑(𝑁 + 1)))))
7337nncnd 11919 . . . . . . . . . . . . . . . . . . . . . 22 (𝑃 ∈ ℙ → 𝑃 ∈ ℂ)
74 peano2cnm 11217 . . . . . . . . . . . . . . . . . . . . . 22 (𝑃 ∈ ℂ → (𝑃 − 1) ∈ ℂ)
7573, 74syl 17 . . . . . . . . . . . . . . . . . . . . 21 (𝑃 ∈ ℙ → (𝑃 − 1) ∈ ℂ)
7675adantl 481 . . . . . . . . . . . . . . . . . . . 20 ((𝑁 ∈ (ℤ‘2) ∧ 𝑃 ∈ ℙ) → (𝑃 − 1) ∈ ℂ)
7776adantr 480 . . . . . . . . . . . . . . . . . . 19 (((𝑁 ∈ (ℤ‘2) ∧ 𝑃 ∈ ℙ) ∧ 𝑘 ∈ ℕ) → (𝑃 − 1) ∈ ℂ)
78 simpr 484 . . . . . . . . . . . . . . . . . . . . 21 (((𝑁 ∈ (ℤ‘2) ∧ 𝑃 ∈ ℙ) ∧ 𝑘 ∈ ℕ) → 𝑘 ∈ ℕ)
7968ad2antrr 722 . . . . . . . . . . . . . . . . . . . . 21 (((𝑁 ∈ (ℤ‘2) ∧ 𝑃 ∈ ℙ) ∧ 𝑘 ∈ ℕ) → (2↑(𝑁 + 1)) ∈ ℕ)
8078, 79nnmulcld 11956 . . . . . . . . . . . . . . . . . . . 20 (((𝑁 ∈ (ℤ‘2) ∧ 𝑃 ∈ ℙ) ∧ 𝑘 ∈ ℕ) → (𝑘 · (2↑(𝑁 + 1))) ∈ ℕ)
8180nncnd 11919 . . . . . . . . . . . . . . . . . . 19 (((𝑁 ∈ (ℤ‘2) ∧ 𝑃 ∈ ℙ) ∧ 𝑘 ∈ ℕ) → (𝑘 · (2↑(𝑁 + 1))) ∈ ℂ)
82 2cnne0 12113 . . . . . . . . . . . . . . . . . . . 20 (2 ∈ ℂ ∧ 2 ≠ 0)
8382a1i 11 . . . . . . . . . . . . . . . . . . 19 (((𝑁 ∈ (ℤ‘2) ∧ 𝑃 ∈ ℙ) ∧ 𝑘 ∈ ℕ) → (2 ∈ ℂ ∧ 2 ≠ 0))
84 divmul3 11568 . . . . . . . . . . . . . . . . . . 19 (((𝑃 − 1) ∈ ℂ ∧ (𝑘 · (2↑(𝑁 + 1))) ∈ ℂ ∧ (2 ∈ ℂ ∧ 2 ≠ 0)) → (((𝑃 − 1) / 2) = (𝑘 · (2↑(𝑁 + 1))) ↔ (𝑃 − 1) = ((𝑘 · (2↑(𝑁 + 1))) · 2)))
8577, 81, 83, 84syl3anc 1369 . . . . . . . . . . . . . . . . . 18 (((𝑁 ∈ (ℤ‘2) ∧ 𝑃 ∈ ℙ) ∧ 𝑘 ∈ ℕ) → (((𝑃 − 1) / 2) = (𝑘 · (2↑(𝑁 + 1))) ↔ (𝑃 − 1) = ((𝑘 · (2↑(𝑁 + 1))) · 2)))
86 nncn 11911 . . . . . . . . . . . . . . . . . . . . . . 23 (𝑘 ∈ ℕ → 𝑘 ∈ ℂ)
8786adantl 481 . . . . . . . . . . . . . . . . . . . . . 22 (((𝑁 ∈ (ℤ‘2) ∧ 𝑃 ∈ ℙ) ∧ 𝑘 ∈ ℕ) → 𝑘 ∈ ℂ)
8868nncnd 11919 . . . . . . . . . . . . . . . . . . . . . . 23 (𝑁 ∈ (ℤ‘2) → (2↑(𝑁 + 1)) ∈ ℂ)
8988ad2antrr 722 . . . . . . . . . . . . . . . . . . . . . 22 (((𝑁 ∈ (ℤ‘2) ∧ 𝑃 ∈ ℙ) ∧ 𝑘 ∈ ℕ) → (2↑(𝑁 + 1)) ∈ ℂ)
90 2cnd 11981 . . . . . . . . . . . . . . . . . . . . . 22 (((𝑁 ∈ (ℤ‘2) ∧ 𝑃 ∈ ℙ) ∧ 𝑘 ∈ ℕ) → 2 ∈ ℂ)
9187, 89, 90mulassd 10929 . . . . . . . . . . . . . . . . . . . . 21 (((𝑁 ∈ (ℤ‘2) ∧ 𝑃 ∈ ℙ) ∧ 𝑘 ∈ ℕ) → ((𝑘 · (2↑(𝑁 + 1))) · 2) = (𝑘 · ((2↑(𝑁 + 1)) · 2)))
92 2cnd 11981 . . . . . . . . . . . . . . . . . . . . . . . . . 26 (𝑁 ∈ ℕ → 2 ∈ ℂ)
9365nnnn0d 12223 . . . . . . . . . . . . . . . . . . . . . . . . . 26 (𝑁 ∈ ℕ → (𝑁 + 1) ∈ ℕ0)
9492, 93expp1d 13793 . . . . . . . . . . . . . . . . . . . . . . . . 25 (𝑁 ∈ ℕ → (2↑((𝑁 + 1) + 1)) = ((2↑(𝑁 + 1)) · 2))
95 nncn 11911 . . . . . . . . . . . . . . . . . . . . . . . . . . 27 (𝑁 ∈ ℕ → 𝑁 ∈ ℂ)
96 add1p1 12154 . . . . . . . . . . . . . . . . . . . . . . . . . . 27 (𝑁 ∈ ℂ → ((𝑁 + 1) + 1) = (𝑁 + 2))
9795, 96syl 17 . . . . . . . . . . . . . . . . . . . . . . . . . 26 (𝑁 ∈ ℕ → ((𝑁 + 1) + 1) = (𝑁 + 2))
9897oveq2d 7271 . . . . . . . . . . . . . . . . . . . . . . . . 25 (𝑁 ∈ ℕ → (2↑((𝑁 + 1) + 1)) = (2↑(𝑁 + 2)))
9994, 98eqtr3d 2780 . . . . . . . . . . . . . . . . . . . . . . . 24 (𝑁 ∈ ℕ → ((2↑(𝑁 + 1)) · 2) = (2↑(𝑁 + 2)))
10057, 99syl 17 . . . . . . . . . . . . . . . . . . . . . . 23 (𝑁 ∈ (ℤ‘2) → ((2↑(𝑁 + 1)) · 2) = (2↑(𝑁 + 2)))
101100ad2antrr 722 . . . . . . . . . . . . . . . . . . . . . 22 (((𝑁 ∈ (ℤ‘2) ∧ 𝑃 ∈ ℙ) ∧ 𝑘 ∈ ℕ) → ((2↑(𝑁 + 1)) · 2) = (2↑(𝑁 + 2)))
102101oveq2d 7271 . . . . . . . . . . . . . . . . . . . . 21 (((𝑁 ∈ (ℤ‘2) ∧ 𝑃 ∈ ℙ) ∧ 𝑘 ∈ ℕ) → (𝑘 · ((2↑(𝑁 + 1)) · 2)) = (𝑘 · (2↑(𝑁 + 2))))
10391, 102eqtrd 2778 . . . . . . . . . . . . . . . . . . . 20 (((𝑁 ∈ (ℤ‘2) ∧ 𝑃 ∈ ℙ) ∧ 𝑘 ∈ ℕ) → ((𝑘 · (2↑(𝑁 + 1))) · 2) = (𝑘 · (2↑(𝑁 + 2))))
104103eqeq2d 2749 . . . . . . . . . . . . . . . . . . 19 (((𝑁 ∈ (ℤ‘2) ∧ 𝑃 ∈ ℙ) ∧ 𝑘 ∈ ℕ) → ((𝑃 − 1) = ((𝑘 · (2↑(𝑁 + 1))) · 2) ↔ (𝑃 − 1) = (𝑘 · (2↑(𝑁 + 2)))))
10573adantl 481 . . . . . . . . . . . . . . . . . . . . 21 ((𝑁 ∈ (ℤ‘2) ∧ 𝑃 ∈ ℙ) → 𝑃 ∈ ℂ)
106105adantr 480 . . . . . . . . . . . . . . . . . . . 20 (((𝑁 ∈ (ℤ‘2) ∧ 𝑃 ∈ ℙ) ∧ 𝑘 ∈ ℕ) → 𝑃 ∈ ℂ)
107 1cnd 10901 . . . . . . . . . . . . . . . . . . . 20 (((𝑁 ∈ (ℤ‘2) ∧ 𝑃 ∈ ℙ) ∧ 𝑘 ∈ ℕ) → 1 ∈ ℂ)
108 id 22 . . . . . . . . . . . . . . . . . . . . . . . . . . 27 (𝑁 ∈ ℕ → 𝑁 ∈ ℕ)
10924a1i 11 . . . . . . . . . . . . . . . . . . . . . . . . . . 27 (𝑁 ∈ ℕ → 2 ∈ ℕ)
110108, 109nnaddcld 11955 . . . . . . . . . . . . . . . . . . . . . . . . . 26 (𝑁 ∈ ℕ → (𝑁 + 2) ∈ ℕ)
111110nnnn0d 12223 . . . . . . . . . . . . . . . . . . . . . . . . 25 (𝑁 ∈ ℕ → (𝑁 + 2) ∈ ℕ0)
11257, 111syl 17 . . . . . . . . . . . . . . . . . . . . . . . 24 (𝑁 ∈ (ℤ‘2) → (𝑁 + 2) ∈ ℕ0)
11364, 112nnexpcld 13888 . . . . . . . . . . . . . . . . . . . . . . 23 (𝑁 ∈ (ℤ‘2) → (2↑(𝑁 + 2)) ∈ ℕ)
114113nncnd 11919 . . . . . . . . . . . . . . . . . . . . . 22 (𝑁 ∈ (ℤ‘2) → (2↑(𝑁 + 2)) ∈ ℂ)
115114ad2antrr 722 . . . . . . . . . . . . . . . . . . . . 21 (((𝑁 ∈ (ℤ‘2) ∧ 𝑃 ∈ ℙ) ∧ 𝑘 ∈ ℕ) → (2↑(𝑁 + 2)) ∈ ℂ)
11687, 115mulcld 10926 . . . . . . . . . . . . . . . . . . . 20 (((𝑁 ∈ (ℤ‘2) ∧ 𝑃 ∈ ℙ) ∧ 𝑘 ∈ ℕ) → (𝑘 · (2↑(𝑁 + 2))) ∈ ℂ)
117106, 107, 116subadd2d 11281 . . . . . . . . . . . . . . . . . . 19 (((𝑁 ∈ (ℤ‘2) ∧ 𝑃 ∈ ℙ) ∧ 𝑘 ∈ ℕ) → ((𝑃 − 1) = (𝑘 · (2↑(𝑁 + 2))) ↔ ((𝑘 · (2↑(𝑁 + 2))) + 1) = 𝑃))
118 eqcom 2745 . . . . . . . . . . . . . . . . . . . 20 (((𝑘 · (2↑(𝑁 + 2))) + 1) = 𝑃𝑃 = ((𝑘 · (2↑(𝑁 + 2))) + 1))
119118a1i 11 . . . . . . . . . . . . . . . . . . 19 (((𝑁 ∈ (ℤ‘2) ∧ 𝑃 ∈ ℙ) ∧ 𝑘 ∈ ℕ) → (((𝑘 · (2↑(𝑁 + 2))) + 1) = 𝑃𝑃 = ((𝑘 · (2↑(𝑁 + 2))) + 1)))
120104, 117, 1193bitrd 304 . . . . . . . . . . . . . . . . . 18 (((𝑁 ∈ (ℤ‘2) ∧ 𝑃 ∈ ℙ) ∧ 𝑘 ∈ ℕ) → ((𝑃 − 1) = ((𝑘 · (2↑(𝑁 + 1))) · 2) ↔ 𝑃 = ((𝑘 · (2↑(𝑁 + 2))) + 1)))
12172, 85, 1203bitrd 304 . . . . . . . . . . . . . . . . 17 (((𝑁 ∈ (ℤ‘2) ∧ 𝑃 ∈ ℙ) ∧ 𝑘 ∈ ℕ) → ((𝑘 · (2↑(𝑁 + 1))) = ((𝑃 − 1) / 2) ↔ 𝑃 = ((𝑘 · (2↑(𝑁 + 2))) + 1)))
122121rexbidva 3224 . . . . . . . . . . . . . . . 16 ((𝑁 ∈ (ℤ‘2) ∧ 𝑃 ∈ ℙ) → (∃𝑘 ∈ ℕ (𝑘 · (2↑(𝑁 + 1))) = ((𝑃 − 1) / 2) ↔ ∃𝑘 ∈ ℕ 𝑃 = ((𝑘 · (2↑(𝑁 + 2))) + 1)))
123122biimpd 228 . . . . . . . . . . . . . . 15 ((𝑁 ∈ (ℤ‘2) ∧ 𝑃 ∈ ℙ) → (∃𝑘 ∈ ℕ (𝑘 · (2↑(𝑁 + 1))) = ((𝑃 − 1) / 2) → ∃𝑘 ∈ ℕ 𝑃 = ((𝑘 · (2↑(𝑁 + 2))) + 1)))
124123adantrr 713 . . . . . . . . . . . . . 14 ((𝑁 ∈ (ℤ‘2) ∧ (𝑃 ∈ ℙ ∧ ¬ 𝑃 = 2)) → (∃𝑘 ∈ ℕ (𝑘 · (2↑(𝑁 + 1))) = ((𝑃 − 1) / 2) → ∃𝑘 ∈ ℕ 𝑃 = ((𝑘 · (2↑(𝑁 + 2))) + 1)))
12570, 124sylbid 239 . . . . . . . . . . . . 13 ((𝑁 ∈ (ℤ‘2) ∧ (𝑃 ∈ ℙ ∧ ¬ 𝑃 = 2)) → ((2↑(𝑁 + 1)) ∥ ((𝑃 − 1) / 2) → ∃𝑘 ∈ ℕ 𝑃 = ((𝑘 · (2↑(𝑁 + 2))) + 1)))
126125expr 456 . . . . . . . . . . . 12 ((𝑁 ∈ (ℤ‘2) ∧ 𝑃 ∈ ℙ) → (¬ 𝑃 = 2 → ((2↑(𝑁 + 1)) ∥ ((𝑃 − 1) / 2) → ∃𝑘 ∈ ℕ 𝑃 = ((𝑘 · (2↑(𝑁 + 2))) + 1))))
1271263adant3 1130 . . . . . . . . . . 11 ((𝑁 ∈ (ℤ‘2) ∧ 𝑃 ∈ ℙ ∧ 𝑃 ∥ (FermatNo‘𝑁)) → (¬ 𝑃 = 2 → ((2↑(𝑁 + 1)) ∥ ((𝑃 − 1) / 2) → ∃𝑘 ∈ ℕ 𝑃 = ((𝑘 · (2↑(𝑁 + 2))) + 1))))
128127impcom 407 . . . . . . . . . 10 ((¬ 𝑃 = 2 ∧ (𝑁 ∈ (ℤ‘2) ∧ 𝑃 ∈ ℙ ∧ 𝑃 ∥ (FermatNo‘𝑁))) → ((2↑(𝑁 + 1)) ∥ ((𝑃 − 1) / 2) → ∃𝑘 ∈ ℕ 𝑃 = ((𝑘 · (2↑(𝑁 + 2))) + 1)))
129128adantr 480 . . . . . . . . 9 (((¬ 𝑃 = 2 ∧ (𝑁 ∈ (ℤ‘2) ∧ 𝑃 ∈ ℙ ∧ 𝑃 ∥ (FermatNo‘𝑁))) ∧ ((od𝑃)‘2) = (2↑(𝑁 + 1))) → ((2↑(𝑁 + 1)) ∥ ((𝑃 − 1) / 2) → ∃𝑘 ∈ ℕ 𝑃 = ((𝑘 · (2↑(𝑁 + 2))) + 1)))
13063, 129sylbid 239 . . . . . . . 8 (((¬ 𝑃 = 2 ∧ (𝑁 ∈ (ℤ‘2) ∧ 𝑃 ∈ ℙ ∧ 𝑃 ∥ (FermatNo‘𝑁))) ∧ ((od𝑃)‘2) = (2↑(𝑁 + 1))) → (((od𝑃)‘2) ∥ ((𝑃 − 1) / 2) → ∃𝑘 ∈ ℕ 𝑃 = ((𝑘 · (2↑(𝑁 + 2))) + 1)))
131130ex 412 . . . . . . 7 ((¬ 𝑃 = 2 ∧ (𝑁 ∈ (ℤ‘2) ∧ 𝑃 ∈ ℙ ∧ 𝑃 ∥ (FermatNo‘𝑁))) → (((od𝑃)‘2) = (2↑(𝑁 + 1)) → (((od𝑃)‘2) ∥ ((𝑃 − 1) / 2) → ∃𝑘 ∈ ℕ 𝑃 = ((𝑘 · (2↑(𝑁 + 2))) + 1))))
13261, 131mpd 15 . . . . . 6 ((¬ 𝑃 = 2 ∧ (𝑁 ∈ (ℤ‘2) ∧ 𝑃 ∈ ℙ ∧ 𝑃 ∥ (FermatNo‘𝑁))) → (((od𝑃)‘2) ∥ ((𝑃 − 1) / 2) → ∃𝑘 ∈ ℕ 𝑃 = ((𝑘 · (2↑(𝑁 + 2))) + 1)))
13356, 132sylbid 239 . . . . 5 ((¬ 𝑃 = 2 ∧ (𝑁 ∈ (ℤ‘2) ∧ 𝑃 ∈ ℙ ∧ 𝑃 ∥ (FermatNo‘𝑁))) → (𝑃 ∥ ((2↑((𝑃 − 1) / 2)) − 1) → ∃𝑘 ∈ ℕ 𝑃 = ((𝑘 · (2↑(𝑁 + 2))) + 1)))
13436, 133sylbid 239 . . . 4 ((¬ 𝑃 = 2 ∧ (𝑁 ∈ (ℤ‘2) ∧ 𝑃 ∈ ℙ ∧ 𝑃 ∥ (FermatNo‘𝑁))) → (((2↑((𝑃 − 1) / 2)) mod 𝑃) = 1 → ∃𝑘 ∈ ℕ 𝑃 = ((𝑘 · (2↑(𝑁 + 2))) + 1)))
13522, 134mpd 15 . . 3 ((¬ 𝑃 = 2 ∧ (𝑁 ∈ (ℤ‘2) ∧ 𝑃 ∈ ℙ ∧ 𝑃 ∥ (FermatNo‘𝑁))) → ∃𝑘 ∈ ℕ 𝑃 = ((𝑘 · (2↑(𝑁 + 2))) + 1))
136135ex 412 . 2 𝑃 = 2 → ((𝑁 ∈ (ℤ‘2) ∧ 𝑃 ∈ ℙ ∧ 𝑃 ∥ (FermatNo‘𝑁)) → ∃𝑘 ∈ ℕ 𝑃 = ((𝑘 · (2↑(𝑁 + 2))) + 1)))
13711, 136pm2.61i 182 1 ((𝑁 ∈ (ℤ‘2) ∧ 𝑃 ∈ ℙ ∧ 𝑃 ∥ (FermatNo‘𝑁)) → ∃𝑘 ∈ ℕ 𝑃 = ((𝑘 · (2↑(𝑁 + 2))) + 1))
Colors of variables: wff setvar class
Syntax hints:  ¬ wn 3  wi 4  wb 205  wa 395  w3a 1085   = wceq 1539  wcel 2108  wne 2942  wrex 3064  cdif 3880  {csn 4558   class class class wbr 5070  cfv 6418  (class class class)co 7255  cc 10800  0cc0 10802  1c1 10803   + caddc 10805   · cmul 10807  cmin 11135   / cdiv 11562  cn 11903  2c2 11958  0cn0 12163  cz 12249  cuz 12511   mod cmo 13517  cexp 13710  cdvds 15891   gcd cgcd 16129  cprime 16304  odcodz 16392  FermatNocfmtno 44867
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-3 8  ax-gen 1799  ax-4 1813  ax-5 1914  ax-6 1972  ax-7 2012  ax-8 2110  ax-9 2118  ax-10 2139  ax-11 2156  ax-12 2173  ax-ext 2709  ax-rep 5205  ax-sep 5218  ax-nul 5225  ax-pow 5283  ax-pr 5347  ax-un 7566  ax-inf2 9329  ax-cnex 10858  ax-resscn 10859  ax-1cn 10860  ax-icn 10861  ax-addcl 10862  ax-addrcl 10863  ax-mulcl 10864  ax-mulrcl 10865  ax-mulcom 10866  ax-addass 10867  ax-mulass 10868  ax-distr 10869  ax-i2m1 10870  ax-1ne0 10871  ax-1rid 10872  ax-rnegex 10873  ax-rrecex 10874  ax-cnre 10875  ax-pre-lttri 10876  ax-pre-lttrn 10877  ax-pre-ltadd 10878  ax-pre-mulgt0 10879  ax-pre-sup 10880
This theorem depends on definitions:  df-bi 206  df-an 396  df-or 844  df-3or 1086  df-3an 1087  df-tru 1542  df-fal 1552  df-ex 1784  df-nf 1788  df-sb 2069  df-mo 2540  df-eu 2569  df-clab 2716  df-cleq 2730  df-clel 2817  df-nfc 2888  df-ne 2943  df-nel 3049  df-ral 3068  df-rex 3069  df-reu 3070  df-rmo 3071  df-rab 3072  df-v 3424  df-sbc 3712  df-csb 3829  df-dif 3886  df-un 3888  df-in 3890  df-ss 3900  df-pss 3902  df-nul 4254  df-if 4457  df-pw 4532  df-sn 4559  df-pr 4561  df-tp 4563  df-op 4565  df-uni 4837  df-int 4877  df-iun 4923  df-br 5071  df-opab 5133  df-mpt 5154  df-tr 5188  df-id 5480  df-eprel 5486  df-po 5494  df-so 5495  df-fr 5535  df-se 5536  df-we 5537  df-xp 5586  df-rel 5587  df-cnv 5588  df-co 5589  df-dm 5590  df-rn 5591  df-res 5592  df-ima 5593  df-pred 6191  df-ord 6254  df-on 6255  df-lim 6256  df-suc 6257  df-iota 6376  df-fun 6420  df-fn 6421  df-f 6422  df-f1 6423  df-fo 6424  df-f1o 6425  df-fv 6426  df-isom 6427  df-riota 7212  df-ov 7258  df-oprab 7259  df-mpo 7260  df-om 7688  df-1st 7804  df-2nd 7805  df-frecs 8068  df-wrecs 8099  df-recs 8173  df-rdg 8212  df-1o 8267  df-2o 8268  df-oadd 8271  df-er 8456  df-map 8575  df-en 8692  df-dom 8693  df-sdom 8694  df-fin 8695  df-sup 9131  df-inf 9132  df-oi 9199  df-dju 9590  df-card 9628  df-pnf 10942  df-mnf 10943  df-xr 10944  df-ltxr 10945  df-le 10946  df-sub 11137  df-neg 11138  df-div 11563  df-nn 11904  df-2 11966  df-3 11967  df-4 11968  df-5 11969  df-6 11970  df-7 11971  df-8 11972  df-n0 12164  df-xnn0 12236  df-z 12250  df-uz 12512  df-q 12618  df-rp 12660  df-ioo 13012  df-ico 13014  df-fz 13169  df-fzo 13312  df-fl 13440  df-mod 13518  df-seq 13650  df-exp 13711  df-fac 13916  df-hash 13973  df-cj 14738  df-re 14739  df-im 14740  df-sqrt 14874  df-abs 14875  df-clim 15125  df-prod 15544  df-dvds 15892  df-gcd 16130  df-prm 16305  df-odz 16394  df-phi 16395  df-pc 16466  df-lgs 26348  df-fmtno 44868
This theorem is referenced by:  fmtnofac2  44909  fmtno4prmfac  44912
  Copyright terms: Public domain W3C validator