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

Theorem odzdvds 16822
Description: The only powers of 𝐴 that are congruent to 1 are the multiples of the order of 𝐴. (Contributed by Mario Carneiro, 28-Feb-2014.) (Proof shortened by AV, 26-Sep-2020.)
Assertion
Ref Expression
odzdvds (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (𝑁 ∥ ((𝐴𝐾) − 1) ↔ ((od𝑁)‘𝐴) ∥ 𝐾))

Proof of Theorem odzdvds
Dummy variable 𝑛 is distinct from all other variables.
StepHypRef Expression
1 nn0re 12484 . . . . . . . . 9 (𝐾 ∈ ℕ0𝐾 ∈ ℝ)
21adantl 485 . . . . . . . 8 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → 𝐾 ∈ ℝ)
3 odzcl 16820 . . . . . . . . . 10 ((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) → ((od𝑁)‘𝐴) ∈ ℕ)
43adantr 484 . . . . . . . . 9 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → ((od𝑁)‘𝐴) ∈ ℕ)
54nnrpd 13029 . . . . . . . 8 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → ((od𝑁)‘𝐴) ∈ ℝ+)
6 modlt 13884 . . . . . . . 8 ((𝐾 ∈ ℝ ∧ ((od𝑁)‘𝐴) ∈ ℝ+) → (𝐾 mod ((od𝑁)‘𝐴)) < ((od𝑁)‘𝐴))
72, 5, 6syl2anc 593 . . . . . . 7 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (𝐾 mod ((od𝑁)‘𝐴)) < ((od𝑁)‘𝐴))
8 nn0z 12586 . . . . . . . . . . 11 (𝐾 ∈ ℕ0𝐾 ∈ ℤ)
98adantl 485 . . . . . . . . . 10 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → 𝐾 ∈ ℤ)
109, 4zmodcld 13896 . . . . . . . . 9 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (𝐾 mod ((od𝑁)‘𝐴)) ∈ ℕ0)
1110nn0red 12537 . . . . . . . 8 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (𝐾 mod ((od𝑁)‘𝐴)) ∈ ℝ)
124nnred 12219 . . . . . . . 8 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → ((od𝑁)‘𝐴) ∈ ℝ)
1311, 12ltnled 11324 . . . . . . 7 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → ((𝐾 mod ((od𝑁)‘𝐴)) < ((od𝑁)‘𝐴) ↔ ¬ ((od𝑁)‘𝐴) ≤ (𝐾 mod ((od𝑁)‘𝐴))))
147, 13mpbid 234 . . . . . 6 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → ¬ ((od𝑁)‘𝐴) ≤ (𝐾 mod ((od𝑁)‘𝐴)))
15 oveq2 7399 . . . . . . . . . . . 12 (𝑛 = (𝐾 mod ((od𝑁)‘𝐴)) → (𝐴𝑛) = (𝐴↑(𝐾 mod ((od𝑁)‘𝐴))))
1615oveq1d 7406 . . . . . . . . . . 11 (𝑛 = (𝐾 mod ((od𝑁)‘𝐴)) → ((𝐴𝑛) − 1) = ((𝐴↑(𝐾 mod ((od𝑁)‘𝐴))) − 1))
1716breq2d 5109 . . . . . . . . . 10 (𝑛 = (𝐾 mod ((od𝑁)‘𝐴)) → (𝑁 ∥ ((𝐴𝑛) − 1) ↔ 𝑁 ∥ ((𝐴↑(𝐾 mod ((od𝑁)‘𝐴))) − 1)))
1817elrab 3649 . . . . . . . . 9 ((𝐾 mod ((od𝑁)‘𝐴)) ∈ {𝑛 ∈ ℕ ∣ 𝑁 ∥ ((𝐴𝑛) − 1)} ↔ ((𝐾 mod ((od𝑁)‘𝐴)) ∈ ℕ ∧ 𝑁 ∥ ((𝐴↑(𝐾 mod ((od𝑁)‘𝐴))) − 1)))
19 ssrab2 4031 . . . . . . . . . . 11 {𝑛 ∈ ℕ ∣ 𝑁 ∥ ((𝐴𝑛) − 1)} ⊆ ℕ
20 nnuz 12872 . . . . . . . . . . 11 ℕ = (ℤ‘1)
2119, 20sseqtri 3982 . . . . . . . . . 10 {𝑛 ∈ ℕ ∣ 𝑁 ∥ ((𝐴𝑛) − 1)} ⊆ (ℤ‘1)
22 infssuzle 12926 . . . . . . . . . 10 (({𝑛 ∈ ℕ ∣ 𝑁 ∥ ((𝐴𝑛) − 1)} ⊆ (ℤ‘1) ∧ (𝐾 mod ((od𝑁)‘𝐴)) ∈ {𝑛 ∈ ℕ ∣ 𝑁 ∥ ((𝐴𝑛) − 1)}) → inf({𝑛 ∈ ℕ ∣ 𝑁 ∥ ((𝐴𝑛) − 1)}, ℝ, < ) ≤ (𝐾 mod ((od𝑁)‘𝐴)))
2321, 22mpan 700 . . . . . . . . 9 ((𝐾 mod ((od𝑁)‘𝐴)) ∈ {𝑛 ∈ ℕ ∣ 𝑁 ∥ ((𝐴𝑛) − 1)} → inf({𝑛 ∈ ℕ ∣ 𝑁 ∥ ((𝐴𝑛) − 1)}, ℝ, < ) ≤ (𝐾 mod ((od𝑁)‘𝐴)))
2418, 23sylbir 237 . . . . . . . 8 (((𝐾 mod ((od𝑁)‘𝐴)) ∈ ℕ ∧ 𝑁 ∥ ((𝐴↑(𝐾 mod ((od𝑁)‘𝐴))) − 1)) → inf({𝑛 ∈ ℕ ∣ 𝑁 ∥ ((𝐴𝑛) − 1)}, ℝ, < ) ≤ (𝐾 mod ((od𝑁)‘𝐴)))
2524ancoms 462 . . . . . . 7 ((𝑁 ∥ ((𝐴↑(𝐾 mod ((od𝑁)‘𝐴))) − 1) ∧ (𝐾 mod ((od𝑁)‘𝐴)) ∈ ℕ) → inf({𝑛 ∈ ℕ ∣ 𝑁 ∥ ((𝐴𝑛) − 1)}, ℝ, < ) ≤ (𝐾 mod ((od𝑁)‘𝐴)))
26 odzval 16818 . . . . . . . . 9 ((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) → ((od𝑁)‘𝐴) = inf({𝑛 ∈ ℕ ∣ 𝑁 ∥ ((𝐴𝑛) − 1)}, ℝ, < ))
2726adantr 484 . . . . . . . 8 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → ((od𝑁)‘𝐴) = inf({𝑛 ∈ ℕ ∣ 𝑁 ∥ ((𝐴𝑛) − 1)}, ℝ, < ))
2827breq1d 5107 . . . . . . 7 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (((od𝑁)‘𝐴) ≤ (𝐾 mod ((od𝑁)‘𝐴)) ↔ inf({𝑛 ∈ ℕ ∣ 𝑁 ∥ ((𝐴𝑛) − 1)}, ℝ, < ) ≤ (𝐾 mod ((od𝑁)‘𝐴))))
2925, 28imbitrrid 248 . . . . . 6 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → ((𝑁 ∥ ((𝐴↑(𝐾 mod ((od𝑁)‘𝐴))) − 1) ∧ (𝐾 mod ((od𝑁)‘𝐴)) ∈ ℕ) → ((od𝑁)‘𝐴) ≤ (𝐾 mod ((od𝑁)‘𝐴))))
3014, 29mtod 200 . . . . 5 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → ¬ (𝑁 ∥ ((𝐴↑(𝐾 mod ((od𝑁)‘𝐴))) − 1) ∧ (𝐾 mod ((od𝑁)‘𝐴)) ∈ ℕ))
31 imnan 403 . . . . 5 ((𝑁 ∥ ((𝐴↑(𝐾 mod ((od𝑁)‘𝐴))) − 1) → ¬ (𝐾 mod ((od𝑁)‘𝐴)) ∈ ℕ) ↔ ¬ (𝑁 ∥ ((𝐴↑(𝐾 mod ((od𝑁)‘𝐴))) − 1) ∧ (𝐾 mod ((od𝑁)‘𝐴)) ∈ ℕ))
3230, 31sylibr 236 . . . 4 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (𝑁 ∥ ((𝐴↑(𝐾 mod ((od𝑁)‘𝐴))) − 1) → ¬ (𝐾 mod ((od𝑁)‘𝐴)) ∈ ℕ))
33 elnn0 12477 . . . . . 6 ((𝐾 mod ((od𝑁)‘𝐴)) ∈ ℕ0 ↔ ((𝐾 mod ((od𝑁)‘𝐴)) ∈ ℕ ∨ (𝐾 mod ((od𝑁)‘𝐴)) = 0))
3410, 33sylib 220 . . . . 5 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → ((𝐾 mod ((od𝑁)‘𝐴)) ∈ ℕ ∨ (𝐾 mod ((od𝑁)‘𝐴)) = 0))
3534ord 875 . . . 4 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (¬ (𝐾 mod ((od𝑁)‘𝐴)) ∈ ℕ → (𝐾 mod ((od𝑁)‘𝐴)) = 0))
3632, 35syld 47 . . 3 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (𝑁 ∥ ((𝐴↑(𝐾 mod ((od𝑁)‘𝐴))) − 1) → (𝐾 mod ((od𝑁)‘𝐴)) = 0))
37 simpl1 1204 . . . . . . 7 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → 𝑁 ∈ ℕ)
3837nnzd 12588 . . . . . 6 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → 𝑁 ∈ ℤ)
39 dvds0 16296 . . . . . 6 (𝑁 ∈ ℤ → 𝑁 ∥ 0)
4038, 39syl 17 . . . . 5 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → 𝑁 ∥ 0)
41 simpl2 1205 . . . . . . . . 9 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → 𝐴 ∈ ℤ)
4241zcnd 12672 . . . . . . . 8 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → 𝐴 ∈ ℂ)
4342exp0d 14147 . . . . . . 7 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (𝐴↑0) = 1)
4443oveq1d 7406 . . . . . 6 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → ((𝐴↑0) − 1) = (1 − 1))
45 1m1e0 12284 . . . . . 6 (1 − 1) = 0
4644, 45eqtrdi 2812 . . . . 5 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → ((𝐴↑0) − 1) = 0)
4740, 46breqtrrd 5125 . . . 4 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → 𝑁 ∥ ((𝐴↑0) − 1))
48 oveq2 7399 . . . . . 6 ((𝐾 mod ((od𝑁)‘𝐴)) = 0 → (𝐴↑(𝐾 mod ((od𝑁)‘𝐴))) = (𝐴↑0))
4948oveq1d 7406 . . . . 5 ((𝐾 mod ((od𝑁)‘𝐴)) = 0 → ((𝐴↑(𝐾 mod ((od𝑁)‘𝐴))) − 1) = ((𝐴↑0) − 1))
5049breq2d 5109 . . . 4 ((𝐾 mod ((od𝑁)‘𝐴)) = 0 → (𝑁 ∥ ((𝐴↑(𝐾 mod ((od𝑁)‘𝐴))) − 1) ↔ 𝑁 ∥ ((𝐴↑0) − 1)))
5147, 50syl5ibrcom 249 . . 3 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → ((𝐾 mod ((od𝑁)‘𝐴)) = 0 → 𝑁 ∥ ((𝐴↑(𝐾 mod ((od𝑁)‘𝐴))) − 1)))
5236, 51impbid 214 . 2 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (𝑁 ∥ ((𝐴↑(𝐾 mod ((od𝑁)‘𝐴))) − 1) ↔ (𝐾 mod ((od𝑁)‘𝐴)) = 0))
534nnnn0d 12536 . . . . . . . . 9 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → ((od𝑁)‘𝐴) ∈ ℕ0)
542, 4nndivred 12261 . . . . . . . . . 10 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (𝐾 / ((od𝑁)‘𝐴)) ∈ ℝ)
55 nn0ge0 12500 . . . . . . . . . . . 12 (𝐾 ∈ ℕ0 → 0 ≤ 𝐾)
5655adantl 485 . . . . . . . . . . 11 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → 0 ≤ 𝐾)
574nngt0d 12256 . . . . . . . . . . . 12 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → 0 < ((od𝑁)‘𝐴))
58 ge0div 12053 . . . . . . . . . . . 12 ((𝐾 ∈ ℝ ∧ ((od𝑁)‘𝐴) ∈ ℝ ∧ 0 < ((od𝑁)‘𝐴)) → (0 ≤ 𝐾 ↔ 0 ≤ (𝐾 / ((od𝑁)‘𝐴))))
592, 12, 57, 58syl3anc 1389 . . . . . . . . . . 11 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (0 ≤ 𝐾 ↔ 0 ≤ (𝐾 / ((od𝑁)‘𝐴))))
6056, 59mpbid 234 . . . . . . . . . 10 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → 0 ≤ (𝐾 / ((od𝑁)‘𝐴)))
61 flge0nn0 13824 . . . . . . . . . 10 (((𝐾 / ((od𝑁)‘𝐴)) ∈ ℝ ∧ 0 ≤ (𝐾 / ((od𝑁)‘𝐴))) → (⌊‘(𝐾 / ((od𝑁)‘𝐴))) ∈ ℕ0)
6254, 60, 61syl2anc 593 . . . . . . . . 9 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (⌊‘(𝐾 / ((od𝑁)‘𝐴))) ∈ ℕ0)
6353, 62nn0mulcld 12541 . . . . . . . 8 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (((od𝑁)‘𝐴) · (⌊‘(𝐾 / ((od𝑁)‘𝐴)))) ∈ ℕ0)
64 zexpcl 14083 . . . . . . . 8 ((𝐴 ∈ ℤ ∧ (((od𝑁)‘𝐴) · (⌊‘(𝐾 / ((od𝑁)‘𝐴)))) ∈ ℕ0) → (𝐴↑(((od𝑁)‘𝐴) · (⌊‘(𝐾 / ((od𝑁)‘𝐴))))) ∈ ℤ)
6541, 63, 64syl2anc 593 . . . . . . 7 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (𝐴↑(((od𝑁)‘𝐴) · (⌊‘(𝐾 / ((od𝑁)‘𝐴))))) ∈ ℤ)
6665zred 12671 . . . . . 6 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (𝐴↑(((od𝑁)‘𝐴) · (⌊‘(𝐾 / ((od𝑁)‘𝐴))))) ∈ ℝ)
67 1red 11176 . . . . . 6 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → 1 ∈ ℝ)
68 zexpcl 14083 . . . . . . 7 ((𝐴 ∈ ℤ ∧ (𝐾 mod ((od𝑁)‘𝐴)) ∈ ℕ0) → (𝐴↑(𝐾 mod ((od𝑁)‘𝐴))) ∈ ℤ)
6941, 10, 68syl2anc 593 . . . . . 6 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (𝐴↑(𝐾 mod ((od𝑁)‘𝐴))) ∈ ℤ)
7037nnrpd 13029 . . . . . 6 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → 𝑁 ∈ ℝ+)
7142, 62, 53expmuld 14156 . . . . . . . 8 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (𝐴↑(((od𝑁)‘𝐴) · (⌊‘(𝐾 / ((od𝑁)‘𝐴))))) = ((𝐴↑((od𝑁)‘𝐴))↑(⌊‘(𝐾 / ((od𝑁)‘𝐴)))))
7271oveq1d 7406 . . . . . . 7 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → ((𝐴↑(((od𝑁)‘𝐴) · (⌊‘(𝐾 / ((od𝑁)‘𝐴))))) mod 𝑁) = (((𝐴↑((od𝑁)‘𝐴))↑(⌊‘(𝐾 / ((od𝑁)‘𝐴)))) mod 𝑁))
73 zexpcl 14083 . . . . . . . . 9 ((𝐴 ∈ ℤ ∧ ((od𝑁)‘𝐴) ∈ ℕ0) → (𝐴↑((od𝑁)‘𝐴)) ∈ ℤ)
7441, 53, 73syl2anc 593 . . . . . . . 8 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (𝐴↑((od𝑁)‘𝐴)) ∈ ℤ)
75 1zzd 12596 . . . . . . . 8 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → 1 ∈ ℤ)
76 odzid 16821 . . . . . . . . . 10 ((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) → 𝑁 ∥ ((𝐴↑((od𝑁)‘𝐴)) − 1))
7776adantr 484 . . . . . . . . 9 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → 𝑁 ∥ ((𝐴↑((od𝑁)‘𝐴)) − 1))
78 moddvds 16288 . . . . . . . . . 10 ((𝑁 ∈ ℕ ∧ (𝐴↑((od𝑁)‘𝐴)) ∈ ℤ ∧ 1 ∈ ℤ) → (((𝐴↑((od𝑁)‘𝐴)) mod 𝑁) = (1 mod 𝑁) ↔ 𝑁 ∥ ((𝐴↑((od𝑁)‘𝐴)) − 1)))
7937, 74, 75, 78syl3anc 1389 . . . . . . . . 9 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (((𝐴↑((od𝑁)‘𝐴)) mod 𝑁) = (1 mod 𝑁) ↔ 𝑁 ∥ ((𝐴↑((od𝑁)‘𝐴)) − 1)))
8077, 79mpbird 259 . . . . . . . 8 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → ((𝐴↑((od𝑁)‘𝐴)) mod 𝑁) = (1 mod 𝑁))
81 modexp 14245 . . . . . . . 8 ((((𝐴↑((od𝑁)‘𝐴)) ∈ ℤ ∧ 1 ∈ ℤ) ∧ ((⌊‘(𝐾 / ((od𝑁)‘𝐴))) ∈ ℕ0𝑁 ∈ ℝ+) ∧ ((𝐴↑((od𝑁)‘𝐴)) mod 𝑁) = (1 mod 𝑁)) → (((𝐴↑((od𝑁)‘𝐴))↑(⌊‘(𝐾 / ((od𝑁)‘𝐴)))) mod 𝑁) = ((1↑(⌊‘(𝐾 / ((od𝑁)‘𝐴)))) mod 𝑁))
8274, 75, 62, 70, 80, 81syl221anc 1399 . . . . . . 7 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (((𝐴↑((od𝑁)‘𝐴))↑(⌊‘(𝐾 / ((od𝑁)‘𝐴)))) mod 𝑁) = ((1↑(⌊‘(𝐾 / ((od𝑁)‘𝐴)))) mod 𝑁))
8354flcld 13802 . . . . . . . . 9 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (⌊‘(𝐾 / ((od𝑁)‘𝐴))) ∈ ℤ)
84 1exp 14098 . . . . . . . . 9 ((⌊‘(𝐾 / ((od𝑁)‘𝐴))) ∈ ℤ → (1↑(⌊‘(𝐾 / ((od𝑁)‘𝐴)))) = 1)
8583, 84syl 17 . . . . . . . 8 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (1↑(⌊‘(𝐾 / ((od𝑁)‘𝐴)))) = 1)
8685oveq1d 7406 . . . . . . 7 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → ((1↑(⌊‘(𝐾 / ((od𝑁)‘𝐴)))) mod 𝑁) = (1 mod 𝑁))
8772, 82, 863eqtrd 2800 . . . . . 6 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → ((𝐴↑(((od𝑁)‘𝐴) · (⌊‘(𝐾 / ((od𝑁)‘𝐴))))) mod 𝑁) = (1 mod 𝑁))
88 modmul1 13931 . . . . . 6 ((((𝐴↑(((od𝑁)‘𝐴) · (⌊‘(𝐾 / ((od𝑁)‘𝐴))))) ∈ ℝ ∧ 1 ∈ ℝ) ∧ ((𝐴↑(𝐾 mod ((od𝑁)‘𝐴))) ∈ ℤ ∧ 𝑁 ∈ ℝ+) ∧ ((𝐴↑(((od𝑁)‘𝐴) · (⌊‘(𝐾 / ((od𝑁)‘𝐴))))) mod 𝑁) = (1 mod 𝑁)) → (((𝐴↑(((od𝑁)‘𝐴) · (⌊‘(𝐾 / ((od𝑁)‘𝐴))))) · (𝐴↑(𝐾 mod ((od𝑁)‘𝐴)))) mod 𝑁) = ((1 · (𝐴↑(𝐾 mod ((od𝑁)‘𝐴)))) mod 𝑁))
8966, 67, 69, 70, 87, 88syl221anc 1399 . . . . 5 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (((𝐴↑(((od𝑁)‘𝐴) · (⌊‘(𝐾 / ((od𝑁)‘𝐴))))) · (𝐴↑(𝐾 mod ((od𝑁)‘𝐴)))) mod 𝑁) = ((1 · (𝐴↑(𝐾 mod ((od𝑁)‘𝐴)))) mod 𝑁))
9042, 10, 63expaddd 14155 . . . . . . 7 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (𝐴↑((((od𝑁)‘𝐴) · (⌊‘(𝐾 / ((od𝑁)‘𝐴)))) + (𝐾 mod ((od𝑁)‘𝐴)))) = ((𝐴↑(((od𝑁)‘𝐴) · (⌊‘(𝐾 / ((od𝑁)‘𝐴))))) · (𝐴↑(𝐾 mod ((od𝑁)‘𝐴)))))
91 modval 13875 . . . . . . . . . . 11 ((𝐾 ∈ ℝ ∧ ((od𝑁)‘𝐴) ∈ ℝ+) → (𝐾 mod ((od𝑁)‘𝐴)) = (𝐾 − (((od𝑁)‘𝐴) · (⌊‘(𝐾 / ((od𝑁)‘𝐴))))))
922, 5, 91syl2anc 593 . . . . . . . . . 10 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (𝐾 mod ((od𝑁)‘𝐴)) = (𝐾 − (((od𝑁)‘𝐴) · (⌊‘(𝐾 / ((od𝑁)‘𝐴))))))
9392oveq2d 7407 . . . . . . . . 9 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → ((((od𝑁)‘𝐴) · (⌊‘(𝐾 / ((od𝑁)‘𝐴)))) + (𝐾 mod ((od𝑁)‘𝐴))) = ((((od𝑁)‘𝐴) · (⌊‘(𝐾 / ((od𝑁)‘𝐴)))) + (𝐾 − (((od𝑁)‘𝐴) · (⌊‘(𝐾 / ((od𝑁)‘𝐴)))))))
9463nn0cnd 12538 . . . . . . . . . 10 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (((od𝑁)‘𝐴) · (⌊‘(𝐾 / ((od𝑁)‘𝐴)))) ∈ ℂ)
952recnd 11204 . . . . . . . . . 10 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → 𝐾 ∈ ℂ)
9694, 95pncan3d 11539 . . . . . . . . 9 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → ((((od𝑁)‘𝐴) · (⌊‘(𝐾 / ((od𝑁)‘𝐴)))) + (𝐾 − (((od𝑁)‘𝐴) · (⌊‘(𝐾 / ((od𝑁)‘𝐴)))))) = 𝐾)
9793, 96eqtrd 2796 . . . . . . . 8 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → ((((od𝑁)‘𝐴) · (⌊‘(𝐾 / ((od𝑁)‘𝐴)))) + (𝐾 mod ((od𝑁)‘𝐴))) = 𝐾)
9897oveq2d 7407 . . . . . . 7 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (𝐴↑((((od𝑁)‘𝐴) · (⌊‘(𝐾 / ((od𝑁)‘𝐴)))) + (𝐾 mod ((od𝑁)‘𝐴)))) = (𝐴𝐾))
9990, 98eqtr3d 2798 . . . . . 6 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → ((𝐴↑(((od𝑁)‘𝐴) · (⌊‘(𝐾 / ((od𝑁)‘𝐴))))) · (𝐴↑(𝐾 mod ((od𝑁)‘𝐴)))) = (𝐴𝐾))
10099oveq1d 7406 . . . . 5 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (((𝐴↑(((od𝑁)‘𝐴) · (⌊‘(𝐾 / ((od𝑁)‘𝐴))))) · (𝐴↑(𝐾 mod ((od𝑁)‘𝐴)))) mod 𝑁) = ((𝐴𝐾) mod 𝑁))
10169zcnd 12672 . . . . . . 7 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (𝐴↑(𝐾 mod ((od𝑁)‘𝐴))) ∈ ℂ)
102101mullidd 11194 . . . . . 6 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (1 · (𝐴↑(𝐾 mod ((od𝑁)‘𝐴)))) = (𝐴↑(𝐾 mod ((od𝑁)‘𝐴))))
103102oveq1d 7406 . . . . 5 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → ((1 · (𝐴↑(𝐾 mod ((od𝑁)‘𝐴)))) mod 𝑁) = ((𝐴↑(𝐾 mod ((od𝑁)‘𝐴))) mod 𝑁))
10489, 100, 1033eqtr3d 2804 . . . 4 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → ((𝐴𝐾) mod 𝑁) = ((𝐴↑(𝐾 mod ((od𝑁)‘𝐴))) mod 𝑁))
105104eqeq1d 2763 . . 3 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (((𝐴𝐾) mod 𝑁) = (1 mod 𝑁) ↔ ((𝐴↑(𝐾 mod ((od𝑁)‘𝐴))) mod 𝑁) = (1 mod 𝑁)))
106 zexpcl 14083 . . . . 5 ((𝐴 ∈ ℤ ∧ 𝐾 ∈ ℕ0) → (𝐴𝐾) ∈ ℤ)
10741, 106sylancom 597 . . . 4 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (𝐴𝐾) ∈ ℤ)
108 moddvds 16288 . . . 4 ((𝑁 ∈ ℕ ∧ (𝐴𝐾) ∈ ℤ ∧ 1 ∈ ℤ) → (((𝐴𝐾) mod 𝑁) = (1 mod 𝑁) ↔ 𝑁 ∥ ((𝐴𝐾) − 1)))
10937, 107, 75, 108syl3anc 1389 . . 3 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (((𝐴𝐾) mod 𝑁) = (1 mod 𝑁) ↔ 𝑁 ∥ ((𝐴𝐾) − 1)))
110 moddvds 16288 . . . 4 ((𝑁 ∈ ℕ ∧ (𝐴↑(𝐾 mod ((od𝑁)‘𝐴))) ∈ ℤ ∧ 1 ∈ ℤ) → (((𝐴↑(𝐾 mod ((od𝑁)‘𝐴))) mod 𝑁) = (1 mod 𝑁) ↔ 𝑁 ∥ ((𝐴↑(𝐾 mod ((od𝑁)‘𝐴))) − 1)))
11137, 69, 75, 110syl3anc 1389 . . 3 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (((𝐴↑(𝐾 mod ((od𝑁)‘𝐴))) mod 𝑁) = (1 mod 𝑁) ↔ 𝑁 ∥ ((𝐴↑(𝐾 mod ((od𝑁)‘𝐴))) − 1)))
112105, 109, 1113bitr3d 311 . 2 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (𝑁 ∥ ((𝐴𝐾) − 1) ↔ 𝑁 ∥ ((𝐴↑(𝐾 mod ((od𝑁)‘𝐴))) − 1)))
113 dvdsval3 16281 . . 3 ((((od𝑁)‘𝐴) ∈ ℕ ∧ 𝐾 ∈ ℤ) → (((od𝑁)‘𝐴) ∥ 𝐾 ↔ (𝐾 mod ((od𝑁)‘𝐴)) = 0))
1144, 9, 113syl2anc 593 . 2 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (((od𝑁)‘𝐴) ∥ 𝐾 ↔ (𝐾 mod ((od𝑁)‘𝐴)) = 0))
11552, 112, 1143bitr4d 313 1 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (𝑁 ∥ ((𝐴𝐾) − 1) ↔ ((od𝑁)‘𝐴) ∥ 𝐾))
Colors of variables: wff setvar class
Syntax hints:  ¬ wn 3  wi 4  wb 208  wa 399  wo 858  w3a 1097   = wceq 1559  wcel 2141  {crab 3413  wss 3902   class class class wbr 5097  cfv 6516  (class class class)co 7391  infcinf 9381  cr 11066  0cc0 11067  1c1 11068   + caddc 11070   · cmul 11072   < clt 11210  cle 11211  cmin 11408   / cdiv 11838  cn 12204  0cn0 12475  cz 12562  cuz 12833  +crp 12987  cfl 13794   mod cmo 13873  cexp 14068  cdvds 16277   gcd cgcd 16519  odcodz 16789
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-3 8  ax-gen 1814  ax-4 1828  ax-5 1929  ax-6 1986  ax-7 2027  ax-8 2143  ax-9 2151  ax-10 2174  ax-11 2190  ax-12 2211  ax-ext 2733  ax-rep 5224  ax-sep 5243  ax-nul 5253  ax-pow 5319  ax-pr 5387  ax-un 7713  ax-cnex 11123  ax-resscn 11124  ax-1cn 11125  ax-icn 11126  ax-addcl 11127  ax-addrcl 11128  ax-mulcl 11129  ax-mulrcl 11130  ax-mulcom 11131  ax-addass 11132  ax-mulass 11133  ax-distr 11134  ax-i2m1 11135  ax-1ne0 11136  ax-1rid 11137  ax-rnegex 11138  ax-rrecex 11139  ax-cnre 11140  ax-pre-lttri 11141  ax-pre-lttrn 11142  ax-pre-ltadd 11143  ax-pre-mulgt0 11144  ax-pre-sup 11145
This theorem depends on definitions:  df-bi 209  df-an 400  df-or 859  df-3or 1098  df-3an 1099  df-tru 1562  df-fal 1572  df-ex 1799  df-nf 1803  df-sb 2090  df-mo 2565  df-eu 2595  df-clab 2740  df-cleq 2753  df-clel 2836  df-nfc 2910  df-ne 2957  df-nel 3061  df-ral 3076  df-rex 3086  df-rmo 3366  df-reu 3367  df-rab 3414  df-v 3455  df-sbc 3743  df-csb 3851  df-dif 3905  df-un 3907  df-in 3909  df-ss 3919  df-pss 3922  df-nul 4284  df-if 4478  df-pw 4554  df-sn 4580  df-pr 4582  df-op 4586  df-uni 4863  df-int 4903  df-iun 4948  df-br 5098  df-opab 5160  df-mpt 5179  df-tr 5205  df-id 5538  df-eprel 5543  df-po 5551  df-so 5552  df-fr 5596  df-we 5598  df-xp 5649  df-rel 5650  df-cnv 5651  df-co 5652  df-dm 5653  df-rn 5654  df-res 5655  df-ima 5656  df-pred 6283  df-ord 6344  df-on 6345  df-lim 6346  df-suc 6347  df-iota 6472  df-fun 6518  df-fn 6519  df-f 6520  df-f1 6521  df-fo 6522  df-f1o 6523  df-fv 6524  df-riota 7348  df-ov 7394  df-oprab 7395  df-mpo 7396  df-om 7842  df-1st 7965  df-2nd 7966  df-frecs 8256  df-wrecs 8287  df-recs 8336  df-rdg 8375  df-1o 8431  df-oadd 8435  df-er 8672  df-en 8922  df-dom 8923  df-sdom 8924  df-fin 8925  df-sup 9382  df-inf 9383  df-card 9891  df-pnf 11212  df-mnf 11213  df-xr 11214  df-ltxr 11215  df-le 11216  df-sub 11410  df-neg 11411  df-div 11839  df-nn 12205  df-2 12274  df-3 12275  df-n0 12476  df-xnn0 12549  df-z 12563  df-uz 12834  df-rp 12988  df-fz 13507  df-fzo 13654  df-fl 13796  df-mod 13874  df-seq 14009  df-exp 14069  df-hash 14338  df-cj 15117  df-re 15118  df-im 15119  df-sqrt 15253  df-abs 15254  df-dvds 16278  df-gcd 16520  df-odz 16791  df-phi 16792
This theorem is referenced by:  odzphi  16823  pockthlem  16932  aks4d1p9  42666  odz2prm2pw  48133  fmtnoprmfac2  48137
  Copyright terms: Public domain W3C validator