ILE Home Intuitionistic Logic Explorer < Previous   Next >
Nearby theorems
Mirrors  >  Home  >  ILE Home  >  Th. List  >  pockthi GIF version

Theorem pockthi 12552
Description: Pocklington's theorem, which gives a sufficient criterion for a number 𝑁 to be prime. This is the preferred method for verifying large primes, being much more efficient to compute than trial division. This form has been optimized for application to specific large primes; see pockthg 12551 for a more general closed-form version. (Contributed by Mario Carneiro, 2-Mar-2014.)
Hypotheses
Ref Expression
pockthi.p 𝑃 ∈ ℙ
pockthi.g 𝐺 ∈ ℕ
pockthi.m 𝑀 = (𝐺 · 𝑃)
pockthi.n 𝑁 = (𝑀 + 1)
pockthi.d 𝐷 ∈ ℕ
pockthi.e 𝐸 ∈ ℕ
pockthi.a 𝐴 ∈ ℕ
pockthi.fac 𝑀 = (𝐷 · (𝑃𝐸))
pockthi.gt 𝐷 < (𝑃𝐸)
pockthi.mod ((𝐴𝑀) mod 𝑁) = (1 mod 𝑁)
pockthi.gcd (((𝐴𝐺) − 1) gcd 𝑁) = 1
Assertion
Ref Expression
pockthi 𝑁 ∈ ℙ

Proof of Theorem pockthi
Dummy variables 𝑥 𝑦 are mutually distinct and distinct from all other variables.
StepHypRef Expression
1 pockthi.d . 2 𝐷 ∈ ℕ
2 pockthi.p . . . . . 6 𝑃 ∈ ℙ
3 prmnn 12303 . . . . . 6 (𝑃 ∈ ℙ → 𝑃 ∈ ℕ)
42, 3ax-mp 5 . . . . 5 𝑃 ∈ ℕ
5 pockthi.e . . . . . 6 𝐸 ∈ ℕ
65nnnn0i 9274 . . . . 5 𝐸 ∈ ℕ0
7 nnexpcl 10661 . . . . 5 ((𝑃 ∈ ℕ ∧ 𝐸 ∈ ℕ0) → (𝑃𝐸) ∈ ℕ)
84, 6, 7mp2an 426 . . . 4 (𝑃𝐸) ∈ ℕ
98a1i 9 . . 3 (𝐷 ∈ ℕ → (𝑃𝐸) ∈ ℕ)
10 id 19 . . 3 (𝐷 ∈ ℕ → 𝐷 ∈ ℕ)
11 pockthi.gt . . . 4 𝐷 < (𝑃𝐸)
1211a1i 9 . . 3 (𝐷 ∈ ℕ → 𝐷 < (𝑃𝐸))
13 pockthi.n . . . . 5 𝑁 = (𝑀 + 1)
14 pockthi.fac . . . . . . 7 𝑀 = (𝐷 · (𝑃𝐸))
151nncni 9017 . . . . . . . 8 𝐷 ∈ ℂ
168nncni 9017 . . . . . . . 8 (𝑃𝐸) ∈ ℂ
1715, 16mulcomi 8049 . . . . . . 7 (𝐷 · (𝑃𝐸)) = ((𝑃𝐸) · 𝐷)
1814, 17eqtri 2217 . . . . . 6 𝑀 = ((𝑃𝐸) · 𝐷)
1918oveq1i 5935 . . . . 5 (𝑀 + 1) = (((𝑃𝐸) · 𝐷) + 1)
2013, 19eqtri 2217 . . . 4 𝑁 = (((𝑃𝐸) · 𝐷) + 1)
2120a1i 9 . . 3 (𝐷 ∈ ℕ → 𝑁 = (((𝑃𝐸) · 𝐷) + 1))
22 prmdvdsexpb 12342 . . . . . . 7 ((𝑥 ∈ ℙ ∧ 𝑃 ∈ ℙ ∧ 𝐸 ∈ ℕ) → (𝑥 ∥ (𝑃𝐸) ↔ 𝑥 = 𝑃))
232, 5, 22mp3an23 1340 . . . . . 6 (𝑥 ∈ ℙ → (𝑥 ∥ (𝑃𝐸) ↔ 𝑥 = 𝑃))
24 pockthi.m . . . . . . . . . . . . 13 𝑀 = (𝐺 · 𝑃)
25 pockthi.g . . . . . . . . . . . . . 14 𝐺 ∈ ℕ
2625, 4nnmulcli 9029 . . . . . . . . . . . . 13 (𝐺 · 𝑃) ∈ ℕ
2724, 26eqeltri 2269 . . . . . . . . . . . 12 𝑀 ∈ ℕ
2827nncni 9017 . . . . . . . . . . 11 𝑀 ∈ ℂ
29 ax-1cn 7989 . . . . . . . . . . 11 1 ∈ ℂ
3028, 29, 13mvrraddi 8260 . . . . . . . . . 10 (𝑁 − 1) = 𝑀
3130oveq2i 5936 . . . . . . . . 9 (𝐴↑(𝑁 − 1)) = (𝐴𝑀)
3231oveq1i 5935 . . . . . . . 8 ((𝐴↑(𝑁 − 1)) mod 𝑁) = ((𝐴𝑀) mod 𝑁)
33 pockthi.mod . . . . . . . . 9 ((𝐴𝑀) mod 𝑁) = (1 mod 𝑁)
34 peano2nn 9019 . . . . . . . . . . . . 13 (𝑀 ∈ ℕ → (𝑀 + 1) ∈ ℕ)
3527, 34ax-mp 5 . . . . . . . . . . . 12 (𝑀 + 1) ∈ ℕ
3613, 35eqeltri 2269 . . . . . . . . . . 11 𝑁 ∈ ℕ
37 nnq 9724 . . . . . . . . . . 11 (𝑁 ∈ ℕ → 𝑁 ∈ ℚ)
3836, 37ax-mp 5 . . . . . . . . . 10 𝑁 ∈ ℚ
3927nngt0i 9037 . . . . . . . . . . . 12 0 < 𝑀
4027nnrei 9016 . . . . . . . . . . . . 13 𝑀 ∈ ℝ
41 1re 8042 . . . . . . . . . . . . 13 1 ∈ ℝ
42 ltaddpos2 8497 . . . . . . . . . . . . 13 ((𝑀 ∈ ℝ ∧ 1 ∈ ℝ) → (0 < 𝑀 ↔ 1 < (𝑀 + 1)))
4340, 41, 42mp2an 426 . . . . . . . . . . . 12 (0 < 𝑀 ↔ 1 < (𝑀 + 1))
4439, 43mpbi 145 . . . . . . . . . . 11 1 < (𝑀 + 1)
4544, 13breqtrri 4061 . . . . . . . . . 10 1 < 𝑁
46 q1mod 10465 . . . . . . . . . 10 ((𝑁 ∈ ℚ ∧ 1 < 𝑁) → (1 mod 𝑁) = 1)
4738, 45, 46mp2an 426 . . . . . . . . 9 (1 mod 𝑁) = 1
4833, 47eqtri 2217 . . . . . . . 8 ((𝐴𝑀) mod 𝑁) = 1
4932, 48eqtri 2217 . . . . . . 7 ((𝐴↑(𝑁 − 1)) mod 𝑁) = 1
50 oveq2 5933 . . . . . . . . . . . 12 (𝑥 = 𝑃 → ((𝑁 − 1) / 𝑥) = ((𝑁 − 1) / 𝑃))
5125nncni 9017 . . . . . . . . . . . . . . 15 𝐺 ∈ ℂ
524nncni 9017 . . . . . . . . . . . . . . 15 𝑃 ∈ ℂ
5351, 52mulcomi 8049 . . . . . . . . . . . . . 14 (𝐺 · 𝑃) = (𝑃 · 𝐺)
5430, 24, 533eqtrri 2222 . . . . . . . . . . . . 13 (𝑃 · 𝐺) = (𝑁 − 1)
5536nncni 9017 . . . . . . . . . . . . . . 15 𝑁 ∈ ℂ
5655, 29subcli 8319 . . . . . . . . . . . . . 14 (𝑁 − 1) ∈ ℂ
574nnap0i 9038 . . . . . . . . . . . . . 14 𝑃 # 0
5856, 52, 51, 57divmulapi 8810 . . . . . . . . . . . . 13 (((𝑁 − 1) / 𝑃) = 𝐺 ↔ (𝑃 · 𝐺) = (𝑁 − 1))
5954, 58mpbir 146 . . . . . . . . . . . 12 ((𝑁 − 1) / 𝑃) = 𝐺
6050, 59eqtrdi 2245 . . . . . . . . . . 11 (𝑥 = 𝑃 → ((𝑁 − 1) / 𝑥) = 𝐺)
6160oveq2d 5941 . . . . . . . . . 10 (𝑥 = 𝑃 → (𝐴↑((𝑁 − 1) / 𝑥)) = (𝐴𝐺))
6261oveq1d 5940 . . . . . . . . 9 (𝑥 = 𝑃 → ((𝐴↑((𝑁 − 1) / 𝑥)) − 1) = ((𝐴𝐺) − 1))
6362oveq1d 5940 . . . . . . . 8 (𝑥 = 𝑃 → (((𝐴↑((𝑁 − 1) / 𝑥)) − 1) gcd 𝑁) = (((𝐴𝐺) − 1) gcd 𝑁))
64 pockthi.gcd . . . . . . . 8 (((𝐴𝐺) − 1) gcd 𝑁) = 1
6563, 64eqtrdi 2245 . . . . . . 7 (𝑥 = 𝑃 → (((𝐴↑((𝑁 − 1) / 𝑥)) − 1) gcd 𝑁) = 1)
66 pockthi.a . . . . . . . . 9 𝐴 ∈ ℕ
6766nnzi 9364 . . . . . . . 8 𝐴 ∈ ℤ
68 oveq1 5932 . . . . . . . . . . . 12 (𝑦 = 𝐴 → (𝑦↑(𝑁 − 1)) = (𝐴↑(𝑁 − 1)))
6968oveq1d 5940 . . . . . . . . . . 11 (𝑦 = 𝐴 → ((𝑦↑(𝑁 − 1)) mod 𝑁) = ((𝐴↑(𝑁 − 1)) mod 𝑁))
7069eqeq1d 2205 . . . . . . . . . 10 (𝑦 = 𝐴 → (((𝑦↑(𝑁 − 1)) mod 𝑁) = 1 ↔ ((𝐴↑(𝑁 − 1)) mod 𝑁) = 1))
71 oveq1 5932 . . . . . . . . . . . . 13 (𝑦 = 𝐴 → (𝑦↑((𝑁 − 1) / 𝑥)) = (𝐴↑((𝑁 − 1) / 𝑥)))
7271oveq1d 5940 . . . . . . . . . . . 12 (𝑦 = 𝐴 → ((𝑦↑((𝑁 − 1) / 𝑥)) − 1) = ((𝐴↑((𝑁 − 1) / 𝑥)) − 1))
7372oveq1d 5940 . . . . . . . . . . 11 (𝑦 = 𝐴 → (((𝑦↑((𝑁 − 1) / 𝑥)) − 1) gcd 𝑁) = (((𝐴↑((𝑁 − 1) / 𝑥)) − 1) gcd 𝑁))
7473eqeq1d 2205 . . . . . . . . . 10 (𝑦 = 𝐴 → ((((𝑦↑((𝑁 − 1) / 𝑥)) − 1) gcd 𝑁) = 1 ↔ (((𝐴↑((𝑁 − 1) / 𝑥)) − 1) gcd 𝑁) = 1))
7570, 74anbi12d 473 . . . . . . . . 9 (𝑦 = 𝐴 → ((((𝑦↑(𝑁 − 1)) mod 𝑁) = 1 ∧ (((𝑦↑((𝑁 − 1) / 𝑥)) − 1) gcd 𝑁) = 1) ↔ (((𝐴↑(𝑁 − 1)) mod 𝑁) = 1 ∧ (((𝐴↑((𝑁 − 1) / 𝑥)) − 1) gcd 𝑁) = 1)))
7675rspcev 2868 . . . . . . . 8 ((𝐴 ∈ ℤ ∧ (((𝐴↑(𝑁 − 1)) mod 𝑁) = 1 ∧ (((𝐴↑((𝑁 − 1) / 𝑥)) − 1) gcd 𝑁) = 1)) → ∃𝑦 ∈ ℤ (((𝑦↑(𝑁 − 1)) mod 𝑁) = 1 ∧ (((𝑦↑((𝑁 − 1) / 𝑥)) − 1) gcd 𝑁) = 1))
7767, 76mpan 424 . . . . . . 7 ((((𝐴↑(𝑁 − 1)) mod 𝑁) = 1 ∧ (((𝐴↑((𝑁 − 1) / 𝑥)) − 1) gcd 𝑁) = 1) → ∃𝑦 ∈ ℤ (((𝑦↑(𝑁 − 1)) mod 𝑁) = 1 ∧ (((𝑦↑((𝑁 − 1) / 𝑥)) − 1) gcd 𝑁) = 1))
7849, 65, 77sylancr 414 . . . . . 6 (𝑥 = 𝑃 → ∃𝑦 ∈ ℤ (((𝑦↑(𝑁 − 1)) mod 𝑁) = 1 ∧ (((𝑦↑((𝑁 − 1) / 𝑥)) − 1) gcd 𝑁) = 1))
7923, 78biimtrdi 163 . . . . 5 (𝑥 ∈ ℙ → (𝑥 ∥ (𝑃𝐸) → ∃𝑦 ∈ ℤ (((𝑦↑(𝑁 − 1)) mod 𝑁) = 1 ∧ (((𝑦↑((𝑁 − 1) / 𝑥)) − 1) gcd 𝑁) = 1)))
8079rgen 2550 . . . 4 𝑥 ∈ ℙ (𝑥 ∥ (𝑃𝐸) → ∃𝑦 ∈ ℤ (((𝑦↑(𝑁 − 1)) mod 𝑁) = 1 ∧ (((𝑦↑((𝑁 − 1) / 𝑥)) − 1) gcd 𝑁) = 1))
8180a1i 9 . . 3 (𝐷 ∈ ℕ → ∀𝑥 ∈ ℙ (𝑥 ∥ (𝑃𝐸) → ∃𝑦 ∈ ℤ (((𝑦↑(𝑁 − 1)) mod 𝑁) = 1 ∧ (((𝑦↑((𝑁 − 1) / 𝑥)) − 1) gcd 𝑁) = 1)))
829, 10, 12, 21, 81pockthg 12551 . 2 (𝐷 ∈ ℕ → 𝑁 ∈ ℙ)
831, 82ax-mp 5 1 𝑁 ∈ ℙ
Colors of variables: wff set class
Syntax hints:  wi 4  wa 104  wb 105   = wceq 1364  wcel 2167  wral 2475  wrex 2476   class class class wbr 4034  (class class class)co 5925  cr 7895  0cc0 7896  1c1 7897   + caddc 7899   · cmul 7901   < clt 8078  cmin 8214   / cdiv 8716  cn 9007  0cn0 9266  cz 9343  cq 9710   mod cmo 10431  cexp 10647  cdvds 11969   gcd cgcd 12145  cprime 12300
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-ia1 106  ax-ia2 107  ax-ia3 108  ax-in1 615  ax-in2 616  ax-io 710  ax-5 1461  ax-7 1462  ax-gen 1463  ax-ie1 1507  ax-ie2 1508  ax-8 1518  ax-10 1519  ax-11 1520  ax-i12 1521  ax-bndl 1523  ax-4 1524  ax-17 1540  ax-i9 1544  ax-ial 1548  ax-i5r 1549  ax-13 2169  ax-14 2170  ax-ext 2178  ax-coll 4149  ax-sep 4152  ax-nul 4160  ax-pow 4208  ax-pr 4243  ax-un 4469  ax-setind 4574  ax-iinf 4625  ax-cnex 7987  ax-resscn 7988  ax-1cn 7989  ax-1re 7990  ax-icn 7991  ax-addcl 7992  ax-addrcl 7993  ax-mulcl 7994  ax-mulrcl 7995  ax-addcom 7996  ax-mulcom 7997  ax-addass 7998  ax-mulass 7999  ax-distr 8000  ax-i2m1 8001  ax-0lt1 8002  ax-1rid 8003  ax-0id 8004  ax-rnegex 8005  ax-precex 8006  ax-cnre 8007  ax-pre-ltirr 8008  ax-pre-ltwlin 8009  ax-pre-lttrn 8010  ax-pre-apti 8011  ax-pre-ltadd 8012  ax-pre-mulgt0 8013  ax-pre-mulext 8014  ax-arch 8015  ax-caucvg 8016
This theorem depends on definitions:  df-bi 117  df-stab 832  df-dc 836  df-3or 981  df-3an 982  df-tru 1367  df-fal 1370  df-nf 1475  df-sb 1777  df-eu 2048  df-mo 2049  df-clab 2183  df-cleq 2189  df-clel 2192  df-nfc 2328  df-ne 2368  df-nel 2463  df-ral 2480  df-rex 2481  df-reu 2482  df-rmo 2483  df-rab 2484  df-v 2765  df-sbc 2990  df-csb 3085  df-dif 3159  df-un 3161  df-in 3163  df-ss 3170  df-nul 3452  df-if 3563  df-pw 3608  df-sn 3629  df-pr 3630  df-op 3632  df-uni 3841  df-int 3876  df-iun 3919  df-br 4035  df-opab 4096  df-mpt 4097  df-tr 4133  df-id 4329  df-po 4332  df-iso 4333  df-iord 4402  df-on 4404  df-ilim 4405  df-suc 4407  df-iom 4628  df-xp 4670  df-rel 4671  df-cnv 4672  df-co 4673  df-dm 4674  df-rn 4675  df-res 4676  df-ima 4677  df-iota 5220  df-fun 5261  df-fn 5262  df-f 5263  df-f1 5264  df-fo 5265  df-f1o 5266  df-fv 5267  df-isom 5268  df-riota 5880  df-ov 5928  df-oprab 5929  df-mpo 5930  df-1st 6207  df-2nd 6208  df-recs 6372  df-irdg 6437  df-frec 6458  df-1o 6483  df-2o 6484  df-oadd 6487  df-er 6601  df-en 6809  df-dom 6810  df-fin 6811  df-sup 7059  df-inf 7060  df-pnf 8080  df-mnf 8081  df-xr 8082  df-ltxr 8083  df-le 8084  df-sub 8216  df-neg 8217  df-reap 8619  df-ap 8626  df-div 8717  df-inn 9008  df-2 9066  df-3 9067  df-4 9068  df-n0 9267  df-xnn0 9330  df-z 9344  df-uz 9619  df-q 9711  df-rp 9746  df-fz 10101  df-fzo 10235  df-fl 10377  df-mod 10432  df-seqfrec 10557  df-exp 10648  df-ihash 10885  df-cj 11024  df-re 11025  df-im 11026  df-rsqrt 11180  df-abs 11181  df-clim 11461  df-proddc 11733  df-dvds 11970  df-gcd 12146  df-prm 12301  df-odz 12403  df-phi 12404  df-pc 12479
This theorem is referenced by: (None)
  Copyright terms: Public domain W3C validator