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

Theorem odzcllem 16722
Description: - Lemma for odzcl 16723, showing existence of a recurrent point for the exponential. (Contributed by Mario Carneiro, 28-Feb-2014.) (Proof shortened by AV, 26-Sep-2020.)
Assertion
Ref Expression
odzcllem ((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) → (((od𝑁)‘𝐴) ∈ ℕ ∧ 𝑁 ∥ ((𝐴↑((od𝑁)‘𝐴)) − 1)))

Proof of Theorem odzcllem
Dummy variable 𝑛 is distinct from all other variables.
StepHypRef Expression
1 odzval 16721 . . 3 ((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) → ((od𝑁)‘𝐴) = inf({𝑛 ∈ ℕ ∣ 𝑁 ∥ ((𝐴𝑛) − 1)}, ℝ, < ))
2 ssrab2 4031 . . . . 5 {𝑛 ∈ ℕ ∣ 𝑁 ∥ ((𝐴𝑛) − 1)} ⊆ ℕ
3 nnuz 12792 . . . . 5 ℕ = (ℤ‘1)
42, 3sseqtri 3981 . . . 4 {𝑛 ∈ ℕ ∣ 𝑁 ∥ ((𝐴𝑛) − 1)} ⊆ (ℤ‘1)
5 phicl 16698 . . . . . . 7 (𝑁 ∈ ℕ → (ϕ‘𝑁) ∈ ℕ)
653ad2ant1 1134 . . . . . 6 ((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) → (ϕ‘𝑁) ∈ ℕ)
7 eulerth 16712 . . . . . . 7 ((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) → ((𝐴↑(ϕ‘𝑁)) mod 𝑁) = (1 mod 𝑁))
8 simp1 1137 . . . . . . . 8 ((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) → 𝑁 ∈ ℕ)
9 simp2 1138 . . . . . . . . 9 ((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) → 𝐴 ∈ ℤ)
106nnnn0d 12464 . . . . . . . . 9 ((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) → (ϕ‘𝑁) ∈ ℕ0)
11 zexpcl 14001 . . . . . . . . 9 ((𝐴 ∈ ℤ ∧ (ϕ‘𝑁) ∈ ℕ0) → (𝐴↑(ϕ‘𝑁)) ∈ ℤ)
129, 10, 11syl2anc 585 . . . . . . . 8 ((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) → (𝐴↑(ϕ‘𝑁)) ∈ ℤ)
13 1z 12523 . . . . . . . . 9 1 ∈ ℤ
14 moddvds 16192 . . . . . . . . 9 ((𝑁 ∈ ℕ ∧ (𝐴↑(ϕ‘𝑁)) ∈ ℤ ∧ 1 ∈ ℤ) → (((𝐴↑(ϕ‘𝑁)) mod 𝑁) = (1 mod 𝑁) ↔ 𝑁 ∥ ((𝐴↑(ϕ‘𝑁)) − 1)))
1513, 14mp3an3 1453 . . . . . . . 8 ((𝑁 ∈ ℕ ∧ (𝐴↑(ϕ‘𝑁)) ∈ ℤ) → (((𝐴↑(ϕ‘𝑁)) mod 𝑁) = (1 mod 𝑁) ↔ 𝑁 ∥ ((𝐴↑(ϕ‘𝑁)) − 1)))
168, 12, 15syl2anc 585 . . . . . . 7 ((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) → (((𝐴↑(ϕ‘𝑁)) mod 𝑁) = (1 mod 𝑁) ↔ 𝑁 ∥ ((𝐴↑(ϕ‘𝑁)) − 1)))
177, 16mpbid 232 . . . . . 6 ((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) → 𝑁 ∥ ((𝐴↑(ϕ‘𝑁)) − 1))
18 oveq2 7366 . . . . . . . . 9 (𝑛 = (ϕ‘𝑁) → (𝐴𝑛) = (𝐴↑(ϕ‘𝑁)))
1918oveq1d 7373 . . . . . . . 8 (𝑛 = (ϕ‘𝑁) → ((𝐴𝑛) − 1) = ((𝐴↑(ϕ‘𝑁)) − 1))
2019breq2d 5109 . . . . . . 7 (𝑛 = (ϕ‘𝑁) → (𝑁 ∥ ((𝐴𝑛) − 1) ↔ 𝑁 ∥ ((𝐴↑(ϕ‘𝑁)) − 1)))
2120rspcev 3575 . . . . . 6 (((ϕ‘𝑁) ∈ ℕ ∧ 𝑁 ∥ ((𝐴↑(ϕ‘𝑁)) − 1)) → ∃𝑛 ∈ ℕ 𝑁 ∥ ((𝐴𝑛) − 1))
226, 17, 21syl2anc 585 . . . . 5 ((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) → ∃𝑛 ∈ ℕ 𝑁 ∥ ((𝐴𝑛) − 1))
23 rabn0 4340 . . . . 5 ({𝑛 ∈ ℕ ∣ 𝑁 ∥ ((𝐴𝑛) − 1)} ≠ ∅ ↔ ∃𝑛 ∈ ℕ 𝑁 ∥ ((𝐴𝑛) − 1))
2422, 23sylibr 234 . . . 4 ((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) → {𝑛 ∈ ℕ ∣ 𝑁 ∥ ((𝐴𝑛) − 1)} ≠ ∅)
25 infssuzcl 12847 . . . 4 (({𝑛 ∈ ℕ ∣ 𝑁 ∥ ((𝐴𝑛) − 1)} ⊆ (ℤ‘1) ∧ {𝑛 ∈ ℕ ∣ 𝑁 ∥ ((𝐴𝑛) − 1)} ≠ ∅) → inf({𝑛 ∈ ℕ ∣ 𝑁 ∥ ((𝐴𝑛) − 1)}, ℝ, < ) ∈ {𝑛 ∈ ℕ ∣ 𝑁 ∥ ((𝐴𝑛) − 1)})
264, 24, 25sylancr 588 . . 3 ((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) → inf({𝑛 ∈ ℕ ∣ 𝑁 ∥ ((𝐴𝑛) − 1)}, ℝ, < ) ∈ {𝑛 ∈ ℕ ∣ 𝑁 ∥ ((𝐴𝑛) − 1)})
271, 26eqeltrd 2835 . 2 ((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) → ((od𝑁)‘𝐴) ∈ {𝑛 ∈ ℕ ∣ 𝑁 ∥ ((𝐴𝑛) − 1)})
28 oveq2 7366 . . . . 5 (𝑛 = ((od𝑁)‘𝐴) → (𝐴𝑛) = (𝐴↑((od𝑁)‘𝐴)))
2928oveq1d 7373 . . . 4 (𝑛 = ((od𝑁)‘𝐴) → ((𝐴𝑛) − 1) = ((𝐴↑((od𝑁)‘𝐴)) − 1))
3029breq2d 5109 . . 3 (𝑛 = ((od𝑁)‘𝐴) → (𝑁 ∥ ((𝐴𝑛) − 1) ↔ 𝑁 ∥ ((𝐴↑((od𝑁)‘𝐴)) − 1)))
3130elrab 3645 . 2 (((od𝑁)‘𝐴) ∈ {𝑛 ∈ ℕ ∣ 𝑁 ∥ ((𝐴𝑛) − 1)} ↔ (((od𝑁)‘𝐴) ∈ ℕ ∧ 𝑁 ∥ ((𝐴↑((od𝑁)‘𝐴)) − 1)))
3227, 31sylib 218 1 ((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) → (((od𝑁)‘𝐴) ∈ ℕ ∧ 𝑁 ∥ ((𝐴↑((od𝑁)‘𝐴)) − 1)))
Colors of variables: wff setvar class
Syntax hints:  wi 4  wb 206  wa 395  w3a 1087   = wceq 1542  wcel 2114  wne 2931  wrex 3059  {crab 3398  wss 3900  c0 4284   class class class wbr 5097  cfv 6491  (class class class)co 7358  infcinf 9346  cr 11027  1c1 11029   < clt 11168  cmin 11366  cn 12147  0cn0 12403  cz 12490  cuz 12753   mod cmo 13791  cexp 13986  cdvds 16181   gcd cgcd 16423  odcodz 16692  ϕcphi 16693
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-3 8  ax-gen 1797  ax-4 1811  ax-5 1912  ax-6 1969  ax-7 2010  ax-8 2116  ax-9 2124  ax-10 2147  ax-11 2163  ax-12 2183  ax-ext 2707  ax-rep 5223  ax-sep 5240  ax-nul 5250  ax-pow 5309  ax-pr 5376  ax-un 7680  ax-cnex 11084  ax-resscn 11085  ax-1cn 11086  ax-icn 11087  ax-addcl 11088  ax-addrcl 11089  ax-mulcl 11090  ax-mulrcl 11091  ax-mulcom 11092  ax-addass 11093  ax-mulass 11094  ax-distr 11095  ax-i2m1 11096  ax-1ne0 11097  ax-1rid 11098  ax-rnegex 11099  ax-rrecex 11100  ax-cnre 11101  ax-pre-lttri 11102  ax-pre-lttrn 11103  ax-pre-ltadd 11104  ax-pre-mulgt0 11105  ax-pre-sup 11106
This theorem depends on definitions:  df-bi 207  df-an 396  df-or 849  df-3or 1088  df-3an 1089  df-tru 1545  df-fal 1555  df-ex 1782  df-nf 1786  df-sb 2069  df-mo 2538  df-eu 2568  df-clab 2714  df-cleq 2727  df-clel 2810  df-nfc 2884  df-ne 2932  df-nel 3036  df-ral 3051  df-rex 3060  df-rmo 3349  df-reu 3350  df-rab 3399  df-v 3441  df-sbc 3740  df-csb 3849  df-dif 3903  df-un 3905  df-in 3907  df-ss 3917  df-pss 3920  df-nul 4285  df-if 4479  df-pw 4555  df-sn 4580  df-pr 4582  df-op 4586  df-uni 4863  df-int 4902  df-iun 4947  df-br 5098  df-opab 5160  df-mpt 5179  df-tr 5205  df-id 5518  df-eprel 5523  df-po 5531  df-so 5532  df-fr 5576  df-we 5578  df-xp 5629  df-rel 5630  df-cnv 5631  df-co 5632  df-dm 5633  df-rn 5634  df-res 5635  df-ima 5636  df-pred 6258  df-ord 6319  df-on 6320  df-lim 6321  df-suc 6322  df-iota 6447  df-fun 6493  df-fn 6494  df-f 6495  df-f1 6496  df-fo 6497  df-f1o 6498  df-fv 6499  df-riota 7315  df-ov 7361  df-oprab 7362  df-mpo 7363  df-om 7809  df-1st 7933  df-2nd 7934  df-frecs 8223  df-wrecs 8254  df-recs 8303  df-rdg 8341  df-1o 8397  df-oadd 8401  df-er 8635  df-en 8886  df-dom 8887  df-sdom 8888  df-fin 8889  df-sup 9347  df-inf 9348  df-card 9853  df-pnf 11170  df-mnf 11171  df-xr 11172  df-ltxr 11173  df-le 11174  df-sub 11368  df-neg 11369  df-div 11797  df-nn 12148  df-2 12210  df-3 12211  df-n0 12404  df-xnn0 12477  df-z 12491  df-uz 12754  df-rp 12908  df-fz 13426  df-fzo 13573  df-fl 13714  df-mod 13792  df-seq 13927  df-exp 13987  df-hash 14256  df-cj 15024  df-re 15025  df-im 15026  df-sqrt 15160  df-abs 15161  df-dvds 16182  df-gcd 16424  df-odz 16694  df-phi 16695
This theorem is referenced by:  odzcl  16723  odzid  16724
  Copyright terms: Public domain W3C validator