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

Theorem odzcllem 16758
Description: - Lemma for odzcl 16759, 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 16757 . . 3 ((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) → ((od𝑁)‘𝐴) = inf({𝑛 ∈ ℕ ∣ 𝑁 ∥ ((𝐴𝑛) − 1)}, ℝ, < ))
2 ssrab2 4014 . . . . 5 {𝑛 ∈ ℕ ∣ 𝑁 ∥ ((𝐴𝑛) − 1)} ⊆ ℕ
3 nnuz 12822 . . . . 5 ℕ = (ℤ‘1)
42, 3sseqtri 3965 . . . 4 {𝑛 ∈ ℕ ∣ 𝑁 ∥ ((𝐴𝑛) − 1)} ⊆ (ℤ‘1)
5 phicl 16734 . . . . . . 7 (𝑁 ∈ ℕ → (ϕ‘𝑁) ∈ ℕ)
653ad2ant1 1140 . . . . . 6 ((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) → (ϕ‘𝑁) ∈ ℕ)
7 eulerth 16748 . . . . . . 7 ((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) → ((𝐴↑(ϕ‘𝑁)) mod 𝑁) = (1 mod 𝑁))
8 simp1 1143 . . . . . . . 8 ((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) → 𝑁 ∈ ℕ)
9 simp2 1144 . . . . . . . . 9 ((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) → 𝐴 ∈ ℤ)
106nnnn0d 12493 . . . . . . . . 9 ((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) → (ϕ‘𝑁) ∈ ℕ0)
11 zexpcl 14033 . . . . . . . . 9 ((𝐴 ∈ ℤ ∧ (ϕ‘𝑁) ∈ ℕ0) → (𝐴↑(ϕ‘𝑁)) ∈ ℤ)
129, 10, 11syl2anc 591 . . . . . . . 8 ((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) → (𝐴↑(ϕ‘𝑁)) ∈ ℤ)
13 1z 12552 . . . . . . . . 9 1 ∈ ℤ
14 moddvds 16227 . . . . . . . . 9 ((𝑁 ∈ ℕ ∧ (𝐴↑(ϕ‘𝑁)) ∈ ℤ ∧ 1 ∈ ℤ) → (((𝐴↑(ϕ‘𝑁)) mod 𝑁) = (1 mod 𝑁) ↔ 𝑁 ∥ ((𝐴↑(ϕ‘𝑁)) − 1)))
1513, 14mp3an3 1459 . . . . . . . 8 ((𝑁 ∈ ℕ ∧ (𝐴↑(ϕ‘𝑁)) ∈ ℤ) → (((𝐴↑(ϕ‘𝑁)) mod 𝑁) = (1 mod 𝑁) ↔ 𝑁 ∥ ((𝐴↑(ϕ‘𝑁)) − 1)))
168, 12, 15syl2anc 591 . . . . . . 7 ((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) → (((𝐴↑(ϕ‘𝑁)) mod 𝑁) = (1 mod 𝑁) ↔ 𝑁 ∥ ((𝐴↑(ϕ‘𝑁)) − 1)))
177, 16mpbid 234 . . . . . 6 ((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) → 𝑁 ∥ ((𝐴↑(ϕ‘𝑁)) − 1))
18 oveq2 7368 . . . . . . . . 9 (𝑛 = (ϕ‘𝑁) → (𝐴𝑛) = (𝐴↑(ϕ‘𝑁)))
1918oveq1d 7375 . . . . . . . 8 (𝑛 = (ϕ‘𝑁) → ((𝐴𝑛) − 1) = ((𝐴↑(ϕ‘𝑁)) − 1))
2019breq2d 5087 . . . . . . 7 (𝑛 = (ϕ‘𝑁) → (𝑁 ∥ ((𝐴𝑛) − 1) ↔ 𝑁 ∥ ((𝐴↑(ϕ‘𝑁)) − 1)))
2120rspcev 3562 . . . . . 6 (((ϕ‘𝑁) ∈ ℕ ∧ 𝑁 ∥ ((𝐴↑(ϕ‘𝑁)) − 1)) → ∃𝑛 ∈ ℕ 𝑁 ∥ ((𝐴𝑛) − 1))
226, 17, 21syl2anc 591 . . . . 5 ((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) → ∃𝑛 ∈ ℕ 𝑁 ∥ ((𝐴𝑛) − 1))
23 rabn0 4320 . . . . 5 ({𝑛 ∈ ℕ ∣ 𝑁 ∥ ((𝐴𝑛) − 1)} ≠ ∅ ↔ ∃𝑛 ∈ ℕ 𝑁 ∥ ((𝐴𝑛) − 1))
2422, 23sylibr 236 . . . 4 ((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) → {𝑛 ∈ ℕ ∣ 𝑁 ∥ ((𝐴𝑛) − 1)} ≠ ∅)
25 infssuzcl 12877 . . . 4 (({𝑛 ∈ ℕ ∣ 𝑁 ∥ ((𝐴𝑛) − 1)} ⊆ (ℤ‘1) ∧ {𝑛 ∈ ℕ ∣ 𝑁 ∥ ((𝐴𝑛) − 1)} ≠ ∅) → inf({𝑛 ∈ ℕ ∣ 𝑁 ∥ ((𝐴𝑛) − 1)}, ℝ, < ) ∈ {𝑛 ∈ ℕ ∣ 𝑁 ∥ ((𝐴𝑛) − 1)})
264, 24, 25sylancr 594 . . 3 ((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) → inf({𝑛 ∈ ℕ ∣ 𝑁 ∥ ((𝐴𝑛) − 1)}, ℝ, < ) ∈ {𝑛 ∈ ℕ ∣ 𝑁 ∥ ((𝐴𝑛) − 1)})
271, 26eqeltrd 2841 . 2 ((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) → ((od𝑁)‘𝐴) ∈ {𝑛 ∈ ℕ ∣ 𝑁 ∥ ((𝐴𝑛) − 1)})
28 oveq2 7368 . . . . 5 (𝑛 = ((od𝑁)‘𝐴) → (𝐴𝑛) = (𝐴↑((od𝑁)‘𝐴)))
2928oveq1d 7375 . . . 4 (𝑛 = ((od𝑁)‘𝐴) → ((𝐴𝑛) − 1) = ((𝐴↑((od𝑁)‘𝐴)) − 1))
3029breq2d 5087 . . 3 (𝑛 = ((od𝑁)‘𝐴) → (𝑁 ∥ ((𝐴𝑛) − 1) ↔ 𝑁 ∥ ((𝐴↑((od𝑁)‘𝐴)) − 1)))
3130elrab 3631 . 2 (((od𝑁)‘𝐴) ∈ {𝑛 ∈ ℕ ∣ 𝑁 ∥ ((𝐴𝑛) − 1)} ↔ (((od𝑁)‘𝐴) ∈ ℕ ∧ 𝑁 ∥ ((𝐴↑((od𝑁)‘𝐴)) − 1)))
3227, 31sylib 220 1 ((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) → (((od𝑁)‘𝐴) ∈ ℕ ∧ 𝑁 ∥ ((𝐴↑((od𝑁)‘𝐴)) − 1)))
Colors of variables: wff setvar class
Syntax hints:  wi 4  wb 208  wa 397  w3a 1093   = wceq 1548  wcel 2121  wne 2936  wrex 3065  {crab 3393  wss 3885  c0 4264   class class class wbr 5075  cfv 6489  (class class class)co 7360  infcinf 9348  cr 11032  1c1 11034   < clt 11174  cmin 11372  cn 12169  0cn0 12432  cz 12519  cuz 12783   mod cmo 13823  cexp 14018  cdvds 16216   gcd cgcd 16458  odcodz 16728  ϕcphi 16729
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-3 8  ax-gen 1803  ax-4 1817  ax-5 1918  ax-6 1975  ax-7 2016  ax-8 2123  ax-9 2131  ax-10 2154  ax-11 2170  ax-12 2191  ax-ext 2713  ax-rep 5202  ax-sep 5221  ax-nul 5231  ax-pow 5297  ax-pr 5365  ax-un 7682  ax-cnex 11089  ax-resscn 11090  ax-1cn 11091  ax-icn 11092  ax-addcl 11093  ax-addrcl 11094  ax-mulcl 11095  ax-mulrcl 11096  ax-mulcom 11097  ax-addass 11098  ax-mulass 11099  ax-distr 11100  ax-i2m1 11101  ax-1ne0 11102  ax-1rid 11103  ax-rnegex 11104  ax-rrecex 11105  ax-cnre 11106  ax-pre-lttri 11107  ax-pre-lttrn 11108  ax-pre-ltadd 11109  ax-pre-mulgt0 11110  ax-pre-sup 11111
This theorem depends on definitions:  df-bi 209  df-an 398  df-or 855  df-3or 1094  df-3an 1095  df-tru 1551  df-fal 1561  df-ex 1788  df-nf 1792  df-sb 2075  df-mo 2545  df-eu 2575  df-clab 2720  df-cleq 2733  df-clel 2816  df-nfc 2890  df-ne 2937  df-nel 3041  df-ral 3056  df-rex 3066  df-rmo 3346  df-reu 3347  df-rab 3394  df-v 3435  df-sbc 3726  df-csb 3834  df-dif 3888  df-un 3890  df-in 3892  df-ss 3902  df-pss 3905  df-nul 4265  df-if 4458  df-pw 4534  df-sn 4559  df-pr 4561  df-op 4565  df-uni 4842  df-int 4881  df-iun 4926  df-br 5076  df-opab 5138  df-mpt 5157  df-tr 5183  df-id 5516  df-eprel 5521  df-po 5529  df-so 5530  df-fr 5574  df-we 5576  df-xp 5627  df-rel 5628  df-cnv 5629  df-co 5630  df-dm 5631  df-rn 5632  df-res 5633  df-ima 5634  df-pred 6256  df-ord 6317  df-on 6318  df-lim 6319  df-suc 6320  df-iota 6445  df-fun 6491  df-fn 6492  df-f 6493  df-f1 6494  df-fo 6495  df-f1o 6496  df-fv 6497  df-riota 7317  df-ov 7363  df-oprab 7364  df-mpo 7365  df-om 7811  df-1st 7935  df-2nd 7936  df-frecs 8225  df-wrecs 8256  df-recs 8305  df-rdg 8343  df-1o 8399  df-oadd 8403  df-er 8637  df-en 8888  df-dom 8889  df-sdom 8890  df-fin 8891  df-sup 9349  df-inf 9350  df-card 9858  df-pnf 11176  df-mnf 11177  df-xr 11178  df-ltxr 11179  df-le 11180  df-sub 11374  df-neg 11375  df-div 11803  df-nn 12170  df-2 12239  df-3 12240  df-n0 12433  df-xnn0 12506  df-z 12520  df-uz 12784  df-rp 12938  df-fz 13457  df-fzo 13604  df-fl 13746  df-mod 13824  df-seq 13959  df-exp 14019  df-hash 14288  df-cj 15056  df-re 15057  df-im 15058  df-sqrt 15192  df-abs 15193  df-dvds 16217  df-gcd 16459  df-odz 16730  df-phi 16731
This theorem is referenced by:  odzcl  16759  odzid  16760
  Copyright terms: Public domain W3C validator