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

Theorem odzdvds 16115
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 11893 . . . . . . . . 9 (𝐾 ∈ ℕ0𝐾 ∈ ℝ)
21adantl 484 . . . . . . . 8 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → 𝐾 ∈ ℝ)
3 odzcl 16113 . . . . . . . . . 10 ((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) → ((od𝑁)‘𝐴) ∈ ℕ)
43adantr 483 . . . . . . . . 9 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → ((od𝑁)‘𝐴) ∈ ℕ)
54nnrpd 12416 . . . . . . . 8 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → ((od𝑁)‘𝐴) ∈ ℝ+)
6 modlt 13238 . . . . . . . 8 ((𝐾 ∈ ℝ ∧ ((od𝑁)‘𝐴) ∈ ℝ+) → (𝐾 mod ((od𝑁)‘𝐴)) < ((od𝑁)‘𝐴))
72, 5, 6syl2anc 586 . . . . . . 7 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (𝐾 mod ((od𝑁)‘𝐴)) < ((od𝑁)‘𝐴))
8 nn0z 11992 . . . . . . . . . . 11 (𝐾 ∈ ℕ0𝐾 ∈ ℤ)
98adantl 484 . . . . . . . . . 10 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → 𝐾 ∈ ℤ)
109, 4zmodcld 13250 . . . . . . . . 9 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (𝐾 mod ((od𝑁)‘𝐴)) ∈ ℕ0)
1110nn0red 11943 . . . . . . . 8 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (𝐾 mod ((od𝑁)‘𝐴)) ∈ ℝ)
124nnred 11639 . . . . . . . 8 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → ((od𝑁)‘𝐴) ∈ ℝ)
1311, 12ltnled 10773 . . . . . . 7 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → ((𝐾 mod ((od𝑁)‘𝐴)) < ((od𝑁)‘𝐴) ↔ ¬ ((od𝑁)‘𝐴) ≤ (𝐾 mod ((od𝑁)‘𝐴))))
147, 13mpbid 234 . . . . . 6 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → ¬ ((od𝑁)‘𝐴) ≤ (𝐾 mod ((od𝑁)‘𝐴)))
15 oveq2 7150 . . . . . . . . . . . 12 (𝑛 = (𝐾 mod ((od𝑁)‘𝐴)) → (𝐴𝑛) = (𝐴↑(𝐾 mod ((od𝑁)‘𝐴))))
1615oveq1d 7157 . . . . . . . . . . 11 (𝑛 = (𝐾 mod ((od𝑁)‘𝐴)) → ((𝐴𝑛) − 1) = ((𝐴↑(𝐾 mod ((od𝑁)‘𝐴))) − 1))
1716breq2d 5064 . . . . . . . . . 10 (𝑛 = (𝐾 mod ((od𝑁)‘𝐴)) → (𝑁 ∥ ((𝐴𝑛) − 1) ↔ 𝑁 ∥ ((𝐴↑(𝐾 mod ((od𝑁)‘𝐴))) − 1)))
1817elrab 3671 . . . . . . . . 9 ((𝐾 mod ((od𝑁)‘𝐴)) ∈ {𝑛 ∈ ℕ ∣ 𝑁 ∥ ((𝐴𝑛) − 1)} ↔ ((𝐾 mod ((od𝑁)‘𝐴)) ∈ ℕ ∧ 𝑁 ∥ ((𝐴↑(𝐾 mod ((od𝑁)‘𝐴))) − 1)))
19 ssrab2 4044 . . . . . . . . . . 11 {𝑛 ∈ ℕ ∣ 𝑁 ∥ ((𝐴𝑛) − 1)} ⊆ ℕ
20 nnuz 12268 . . . . . . . . . . 11 ℕ = (ℤ‘1)
2119, 20sseqtri 3991 . . . . . . . . . 10 {𝑛 ∈ ℕ ∣ 𝑁 ∥ ((𝐴𝑛) − 1)} ⊆ (ℤ‘1)
22 infssuzle 12318 . . . . . . . . . 10 (({𝑛 ∈ ℕ ∣ 𝑁 ∥ ((𝐴𝑛) − 1)} ⊆ (ℤ‘1) ∧ (𝐾 mod ((od𝑁)‘𝐴)) ∈ {𝑛 ∈ ℕ ∣ 𝑁 ∥ ((𝐴𝑛) − 1)}) → inf({𝑛 ∈ ℕ ∣ 𝑁 ∥ ((𝐴𝑛) − 1)}, ℝ, < ) ≤ (𝐾 mod ((od𝑁)‘𝐴)))
2321, 22mpan 688 . . . . . . . . 9 ((𝐾 mod ((od𝑁)‘𝐴)) ∈ {𝑛 ∈ ℕ ∣ 𝑁 ∥ ((𝐴𝑛) − 1)} → inf({𝑛 ∈ ℕ ∣ 𝑁 ∥ ((𝐴𝑛) − 1)}, ℝ, < ) ≤ (𝐾 mod ((od𝑁)‘𝐴)))
2418, 23sylbir 237 . . . . . . . 8 (((𝐾 mod ((od𝑁)‘𝐴)) ∈ ℕ ∧ 𝑁 ∥ ((𝐴↑(𝐾 mod ((od𝑁)‘𝐴))) − 1)) → inf({𝑛 ∈ ℕ ∣ 𝑁 ∥ ((𝐴𝑛) − 1)}, ℝ, < ) ≤ (𝐾 mod ((od𝑁)‘𝐴)))
2524ancoms 461 . . . . . . 7 ((𝑁 ∥ ((𝐴↑(𝐾 mod ((od𝑁)‘𝐴))) − 1) ∧ (𝐾 mod ((od𝑁)‘𝐴)) ∈ ℕ) → inf({𝑛 ∈ ℕ ∣ 𝑁 ∥ ((𝐴𝑛) − 1)}, ℝ, < ) ≤ (𝐾 mod ((od𝑁)‘𝐴)))
26 odzval 16111 . . . . . . . . 9 ((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) → ((od𝑁)‘𝐴) = inf({𝑛 ∈ ℕ ∣ 𝑁 ∥ ((𝐴𝑛) − 1)}, ℝ, < ))
2726adantr 483 . . . . . . . 8 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → ((od𝑁)‘𝐴) = inf({𝑛 ∈ ℕ ∣ 𝑁 ∥ ((𝐴𝑛) − 1)}, ℝ, < ))
2827breq1d 5062 . . . . . . 7 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (((od𝑁)‘𝐴) ≤ (𝐾 mod ((od𝑁)‘𝐴)) ↔ inf({𝑛 ∈ ℕ ∣ 𝑁 ∥ ((𝐴𝑛) − 1)}, ℝ, < ) ≤ (𝐾 mod ((od𝑁)‘𝐴))))
2925, 28syl5ibr 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 402 . . . . 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 11886 . . . . . 6 ((𝐾 mod ((od𝑁)‘𝐴)) ∈ ℕ0 ↔ ((𝐾 mod ((od𝑁)‘𝐴)) ∈ ℕ ∨ (𝐾 mod ((od𝑁)‘𝐴)) = 0))
3410, 33sylib 220 . . . . 5 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → ((𝐾 mod ((od𝑁)‘𝐴)) ∈ ℕ ∨ (𝐾 mod ((od𝑁)‘𝐴)) = 0))
3534ord 860 . . . 4 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (¬ (𝐾 mod ((od𝑁)‘𝐴)) ∈ ℕ → (𝐾 mod ((od𝑁)‘𝐴)) = 0))
3632, 35syld 47 . . 3 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (𝑁 ∥ ((𝐴↑(𝐾 mod ((od𝑁)‘𝐴))) − 1) → (𝐾 mod ((od𝑁)‘𝐴)) = 0))
37 simpl1 1187 . . . . . . 7 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → 𝑁 ∈ ℕ)
3837nnzd 12073 . . . . . 6 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → 𝑁 ∈ ℤ)
39 dvds0 15610 . . . . . 6 (𝑁 ∈ ℤ → 𝑁 ∥ 0)
4038, 39syl 17 . . . . 5 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → 𝑁 ∥ 0)
41 simpl2 1188 . . . . . . . . 9 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → 𝐴 ∈ ℤ)
4241zcnd 12075 . . . . . . . 8 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → 𝐴 ∈ ℂ)
4342exp0d 13494 . . . . . . 7 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (𝐴↑0) = 1)
4443oveq1d 7157 . . . . . 6 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → ((𝐴↑0) − 1) = (1 − 1))
45 1m1e0 11696 . . . . . 6 (1 − 1) = 0
4644, 45syl6eq 2872 . . . . 5 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → ((𝐴↑0) − 1) = 0)
4740, 46breqtrrd 5080 . . . 4 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → 𝑁 ∥ ((𝐴↑0) − 1))
48 oveq2 7150 . . . . . 6 ((𝐾 mod ((od𝑁)‘𝐴)) = 0 → (𝐴↑(𝐾 mod ((od𝑁)‘𝐴))) = (𝐴↑0))
4948oveq1d 7157 . . . . 5 ((𝐾 mod ((od𝑁)‘𝐴)) = 0 → ((𝐴↑(𝐾 mod ((od𝑁)‘𝐴))) − 1) = ((𝐴↑0) − 1))
5049breq2d 5064 . . . 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 11942 . . . . . . . . 9 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → ((od𝑁)‘𝐴) ∈ ℕ0)
542, 4nndivred 11678 . . . . . . . . . 10 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (𝐾 / ((od𝑁)‘𝐴)) ∈ ℝ)
55 nn0ge0 11909 . . . . . . . . . . . 12 (𝐾 ∈ ℕ0 → 0 ≤ 𝐾)
5655adantl 484 . . . . . . . . . . 11 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → 0 ≤ 𝐾)
574nngt0d 11673 . . . . . . . . . . . 12 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → 0 < ((od𝑁)‘𝐴))
58 ge0div 11493 . . . . . . . . . . . 12 ((𝐾 ∈ ℝ ∧ ((od𝑁)‘𝐴) ∈ ℝ ∧ 0 < ((od𝑁)‘𝐴)) → (0 ≤ 𝐾 ↔ 0 ≤ (𝐾 / ((od𝑁)‘𝐴))))
592, 12, 57, 58syl3anc 1367 . . . . . . . . . . 11 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (0 ≤ 𝐾 ↔ 0 ≤ (𝐾 / ((od𝑁)‘𝐴))))
6056, 59mpbid 234 . . . . . . . . . 10 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → 0 ≤ (𝐾 / ((od𝑁)‘𝐴)))
61 flge0nn0 13180 . . . . . . . . . 10 (((𝐾 / ((od𝑁)‘𝐴)) ∈ ℝ ∧ 0 ≤ (𝐾 / ((od𝑁)‘𝐴))) → (⌊‘(𝐾 / ((od𝑁)‘𝐴))) ∈ ℕ0)
6254, 60, 61syl2anc 586 . . . . . . . . 9 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (⌊‘(𝐾 / ((od𝑁)‘𝐴))) ∈ ℕ0)
6353, 62nn0mulcld 11947 . . . . . . . 8 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (((od𝑁)‘𝐴) · (⌊‘(𝐾 / ((od𝑁)‘𝐴)))) ∈ ℕ0)
64 zexpcl 13434 . . . . . . . 8 ((𝐴 ∈ ℤ ∧ (((od𝑁)‘𝐴) · (⌊‘(𝐾 / ((od𝑁)‘𝐴)))) ∈ ℕ0) → (𝐴↑(((od𝑁)‘𝐴) · (⌊‘(𝐾 / ((od𝑁)‘𝐴))))) ∈ ℤ)
6541, 63, 64syl2anc 586 . . . . . . 7 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (𝐴↑(((od𝑁)‘𝐴) · (⌊‘(𝐾 / ((od𝑁)‘𝐴))))) ∈ ℤ)
6665zred 12074 . . . . . 6 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (𝐴↑(((od𝑁)‘𝐴) · (⌊‘(𝐾 / ((od𝑁)‘𝐴))))) ∈ ℝ)
67 1red 10628 . . . . . 6 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → 1 ∈ ℝ)
68 zexpcl 13434 . . . . . . 7 ((𝐴 ∈ ℤ ∧ (𝐾 mod ((od𝑁)‘𝐴)) ∈ ℕ0) → (𝐴↑(𝐾 mod ((od𝑁)‘𝐴))) ∈ ℤ)
6941, 10, 68syl2anc 586 . . . . . 6 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (𝐴↑(𝐾 mod ((od𝑁)‘𝐴))) ∈ ℤ)
7037nnrpd 12416 . . . . . 6 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → 𝑁 ∈ ℝ+)
7142, 62, 53expmuld 13503 . . . . . . . 8 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (𝐴↑(((od𝑁)‘𝐴) · (⌊‘(𝐾 / ((od𝑁)‘𝐴))))) = ((𝐴↑((od𝑁)‘𝐴))↑(⌊‘(𝐾 / ((od𝑁)‘𝐴)))))
7271oveq1d 7157 . . . . . . 7 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → ((𝐴↑(((od𝑁)‘𝐴) · (⌊‘(𝐾 / ((od𝑁)‘𝐴))))) mod 𝑁) = (((𝐴↑((od𝑁)‘𝐴))↑(⌊‘(𝐾 / ((od𝑁)‘𝐴)))) mod 𝑁))
73 zexpcl 13434 . . . . . . . . 9 ((𝐴 ∈ ℤ ∧ ((od𝑁)‘𝐴) ∈ ℕ0) → (𝐴↑((od𝑁)‘𝐴)) ∈ ℤ)
7441, 53, 73syl2anc 586 . . . . . . . 8 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (𝐴↑((od𝑁)‘𝐴)) ∈ ℤ)
75 1zzd 12000 . . . . . . . 8 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → 1 ∈ ℤ)
76 odzid 16114 . . . . . . . . . 10 ((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) → 𝑁 ∥ ((𝐴↑((od𝑁)‘𝐴)) − 1))
7776adantr 483 . . . . . . . . 9 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → 𝑁 ∥ ((𝐴↑((od𝑁)‘𝐴)) − 1))
78 moddvds 15603 . . . . . . . . . 10 ((𝑁 ∈ ℕ ∧ (𝐴↑((od𝑁)‘𝐴)) ∈ ℤ ∧ 1 ∈ ℤ) → (((𝐴↑((od𝑁)‘𝐴)) mod 𝑁) = (1 mod 𝑁) ↔ 𝑁 ∥ ((𝐴↑((od𝑁)‘𝐴)) − 1)))
7937, 74, 75, 78syl3anc 1367 . . . . . . . . 9 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (((𝐴↑((od𝑁)‘𝐴)) mod 𝑁) = (1 mod 𝑁) ↔ 𝑁 ∥ ((𝐴↑((od𝑁)‘𝐴)) − 1)))
8077, 79mpbird 259 . . . . . . . 8 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → ((𝐴↑((od𝑁)‘𝐴)) mod 𝑁) = (1 mod 𝑁))
81 modexp 13589 . . . . . . . 8 ((((𝐴↑((od𝑁)‘𝐴)) ∈ ℤ ∧ 1 ∈ ℤ) ∧ ((⌊‘(𝐾 / ((od𝑁)‘𝐴))) ∈ ℕ0𝑁 ∈ ℝ+) ∧ ((𝐴↑((od𝑁)‘𝐴)) mod 𝑁) = (1 mod 𝑁)) → (((𝐴↑((od𝑁)‘𝐴))↑(⌊‘(𝐾 / ((od𝑁)‘𝐴)))) mod 𝑁) = ((1↑(⌊‘(𝐾 / ((od𝑁)‘𝐴)))) mod 𝑁))
8274, 75, 62, 70, 80, 81syl221anc 1377 . . . . . . 7 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (((𝐴↑((od𝑁)‘𝐴))↑(⌊‘(𝐾 / ((od𝑁)‘𝐴)))) mod 𝑁) = ((1↑(⌊‘(𝐾 / ((od𝑁)‘𝐴)))) mod 𝑁))
8354flcld 13158 . . . . . . . . 9 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (⌊‘(𝐾 / ((od𝑁)‘𝐴))) ∈ ℤ)
84 1exp 13448 . . . . . . . . 9 ((⌊‘(𝐾 / ((od𝑁)‘𝐴))) ∈ ℤ → (1↑(⌊‘(𝐾 / ((od𝑁)‘𝐴)))) = 1)
8583, 84syl 17 . . . . . . . 8 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (1↑(⌊‘(𝐾 / ((od𝑁)‘𝐴)))) = 1)
8685oveq1d 7157 . . . . . . 7 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → ((1↑(⌊‘(𝐾 / ((od𝑁)‘𝐴)))) mod 𝑁) = (1 mod 𝑁))
8772, 82, 863eqtrd 2860 . . . . . 6 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → ((𝐴↑(((od𝑁)‘𝐴) · (⌊‘(𝐾 / ((od𝑁)‘𝐴))))) mod 𝑁) = (1 mod 𝑁))
88 modmul1 13282 . . . . . 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 1377 . . . . 5 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (((𝐴↑(((od𝑁)‘𝐴) · (⌊‘(𝐾 / ((od𝑁)‘𝐴))))) · (𝐴↑(𝐾 mod ((od𝑁)‘𝐴)))) mod 𝑁) = ((1 · (𝐴↑(𝐾 mod ((od𝑁)‘𝐴)))) mod 𝑁))
9042, 10, 63expaddd 13502 . . . . . . 7 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (𝐴↑((((od𝑁)‘𝐴) · (⌊‘(𝐾 / ((od𝑁)‘𝐴)))) + (𝐾 mod ((od𝑁)‘𝐴)))) = ((𝐴↑(((od𝑁)‘𝐴) · (⌊‘(𝐾 / ((od𝑁)‘𝐴))))) · (𝐴↑(𝐾 mod ((od𝑁)‘𝐴)))))
91 modval 13229 . . . . . . . . . . 11 ((𝐾 ∈ ℝ ∧ ((od𝑁)‘𝐴) ∈ ℝ+) → (𝐾 mod ((od𝑁)‘𝐴)) = (𝐾 − (((od𝑁)‘𝐴) · (⌊‘(𝐾 / ((od𝑁)‘𝐴))))))
922, 5, 91syl2anc 586 . . . . . . . . . 10 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (𝐾 mod ((od𝑁)‘𝐴)) = (𝐾 − (((od𝑁)‘𝐴) · (⌊‘(𝐾 / ((od𝑁)‘𝐴))))))
9392oveq2d 7158 . . . . . . . . 9 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → ((((od𝑁)‘𝐴) · (⌊‘(𝐾 / ((od𝑁)‘𝐴)))) + (𝐾 mod ((od𝑁)‘𝐴))) = ((((od𝑁)‘𝐴) · (⌊‘(𝐾 / ((od𝑁)‘𝐴)))) + (𝐾 − (((od𝑁)‘𝐴) · (⌊‘(𝐾 / ((od𝑁)‘𝐴)))))))
9463nn0cnd 11944 . . . . . . . . . 10 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (((od𝑁)‘𝐴) · (⌊‘(𝐾 / ((od𝑁)‘𝐴)))) ∈ ℂ)
952recnd 10655 . . . . . . . . . 10 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → 𝐾 ∈ ℂ)
9694, 95pncan3d 10986 . . . . . . . . 9 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → ((((od𝑁)‘𝐴) · (⌊‘(𝐾 / ((od𝑁)‘𝐴)))) + (𝐾 − (((od𝑁)‘𝐴) · (⌊‘(𝐾 / ((od𝑁)‘𝐴)))))) = 𝐾)
9793, 96eqtrd 2856 . . . . . . . 8 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → ((((od𝑁)‘𝐴) · (⌊‘(𝐾 / ((od𝑁)‘𝐴)))) + (𝐾 mod ((od𝑁)‘𝐴))) = 𝐾)
9897oveq2d 7158 . . . . . . 7 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (𝐴↑((((od𝑁)‘𝐴) · (⌊‘(𝐾 / ((od𝑁)‘𝐴)))) + (𝐾 mod ((od𝑁)‘𝐴)))) = (𝐴𝐾))
9990, 98eqtr3d 2858 . . . . . 6 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → ((𝐴↑(((od𝑁)‘𝐴) · (⌊‘(𝐾 / ((od𝑁)‘𝐴))))) · (𝐴↑(𝐾 mod ((od𝑁)‘𝐴)))) = (𝐴𝐾))
10099oveq1d 7157 . . . . 5 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (((𝐴↑(((od𝑁)‘𝐴) · (⌊‘(𝐾 / ((od𝑁)‘𝐴))))) · (𝐴↑(𝐾 mod ((od𝑁)‘𝐴)))) mod 𝑁) = ((𝐴𝐾) mod 𝑁))
10169zcnd 12075 . . . . . . 7 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (𝐴↑(𝐾 mod ((od𝑁)‘𝐴))) ∈ ℂ)
102101mulid2d 10645 . . . . . 6 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (1 · (𝐴↑(𝐾 mod ((od𝑁)‘𝐴)))) = (𝐴↑(𝐾 mod ((od𝑁)‘𝐴))))
103102oveq1d 7157 . . . . 5 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → ((1 · (𝐴↑(𝐾 mod ((od𝑁)‘𝐴)))) mod 𝑁) = ((𝐴↑(𝐾 mod ((od𝑁)‘𝐴))) mod 𝑁))
10489, 100, 1033eqtr3d 2864 . . . 4 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → ((𝐴𝐾) mod 𝑁) = ((𝐴↑(𝐾 mod ((od𝑁)‘𝐴))) mod 𝑁))
105104eqeq1d 2823 . . 3 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (((𝐴𝐾) mod 𝑁) = (1 mod 𝑁) ↔ ((𝐴↑(𝐾 mod ((od𝑁)‘𝐴))) mod 𝑁) = (1 mod 𝑁)))
106 zexpcl 13434 . . . . 5 ((𝐴 ∈ ℤ ∧ 𝐾 ∈ ℕ0) → (𝐴𝐾) ∈ ℤ)
10741, 106sylancom 590 . . . 4 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (𝐴𝐾) ∈ ℤ)
108 moddvds 15603 . . . 4 ((𝑁 ∈ ℕ ∧ (𝐴𝐾) ∈ ℤ ∧ 1 ∈ ℤ) → (((𝐴𝐾) mod 𝑁) = (1 mod 𝑁) ↔ 𝑁 ∥ ((𝐴𝐾) − 1)))
10937, 107, 75, 108syl3anc 1367 . . 3 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (((𝐴𝐾) mod 𝑁) = (1 mod 𝑁) ↔ 𝑁 ∥ ((𝐴𝐾) − 1)))
110 moddvds 15603 . . . 4 ((𝑁 ∈ ℕ ∧ (𝐴↑(𝐾 mod ((od𝑁)‘𝐴))) ∈ ℤ ∧ 1 ∈ ℤ) → (((𝐴↑(𝐾 mod ((od𝑁)‘𝐴))) mod 𝑁) = (1 mod 𝑁) ↔ 𝑁 ∥ ((𝐴↑(𝐾 mod ((od𝑁)‘𝐴))) − 1)))
11137, 69, 75, 110syl3anc 1367 . . 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 15596 . . 3 ((((od𝑁)‘𝐴) ∈ ℕ ∧ 𝐾 ∈ ℤ) → (((od𝑁)‘𝐴) ∥ 𝐾 ↔ (𝐾 mod ((od𝑁)‘𝐴)) = 0))
1144, 9, 113syl2anc 586 . 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 398  wo 843  w3a 1083   = wceq 1537  wcel 2114  {crab 3142  wss 3924   class class class wbr 5052  cfv 6341  (class class class)co 7142  infcinf 8891  cr 10522  0cc0 10523  1c1 10524   + caddc 10526   · cmul 10528   < clt 10661  cle 10662  cmin 10856   / cdiv 11283  cn 11624  0cn0 11884  cz 11968  cuz 12230  +crp 12376  cfl 13150   mod cmo 13227  cexp 13419  cdvds 15592   gcd cgcd 15826  odcodz 16083
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-3 8  ax-gen 1796  ax-4 1810  ax-5 1911  ax-6 1970  ax-7 2015  ax-8 2116  ax-9 2124  ax-10 2145  ax-11 2161  ax-12 2177  ax-ext 2793  ax-rep 5176  ax-sep 5189  ax-nul 5196  ax-pow 5252  ax-pr 5316  ax-un 7447  ax-cnex 10579  ax-resscn 10580  ax-1cn 10581  ax-icn 10582  ax-addcl 10583  ax-addrcl 10584  ax-mulcl 10585  ax-mulrcl 10586  ax-mulcom 10587  ax-addass 10588  ax-mulass 10589  ax-distr 10590  ax-i2m1 10591  ax-1ne0 10592  ax-1rid 10593  ax-rnegex 10594  ax-rrecex 10595  ax-cnre 10596  ax-pre-lttri 10597  ax-pre-lttrn 10598  ax-pre-ltadd 10599  ax-pre-mulgt0 10600  ax-pre-sup 10601
This theorem depends on definitions:  df-bi 209  df-an 399  df-or 844  df-3or 1084  df-3an 1085  df-tru 1540  df-ex 1781  df-nf 1785  df-sb 2070  df-mo 2622  df-eu 2654  df-clab 2800  df-cleq 2814  df-clel 2893  df-nfc 2963  df-ne 3017  df-nel 3124  df-ral 3143  df-rex 3144  df-reu 3145  df-rmo 3146  df-rab 3147  df-v 3488  df-sbc 3764  df-csb 3872  df-dif 3927  df-un 3929  df-in 3931  df-ss 3940  df-pss 3942  df-nul 4280  df-if 4454  df-pw 4527  df-sn 4554  df-pr 4556  df-tp 4558  df-op 4560  df-uni 4825  df-int 4863  df-iun 4907  df-br 5053  df-opab 5115  df-mpt 5133  df-tr 5159  df-id 5446  df-eprel 5451  df-po 5460  df-so 5461  df-fr 5500  df-we 5502  df-xp 5547  df-rel 5548  df-cnv 5549  df-co 5550  df-dm 5551  df-rn 5552  df-res 5553  df-ima 5554  df-pred 6134  df-ord 6180  df-on 6181  df-lim 6182  df-suc 6183  df-iota 6300  df-fun 6343  df-fn 6344  df-f 6345  df-f1 6346  df-fo 6347  df-f1o 6348  df-fv 6349  df-riota 7100  df-ov 7145  df-oprab 7146  df-mpo 7147  df-om 7567  df-1st 7675  df-2nd 7676  df-wrecs 7933  df-recs 7994  df-rdg 8032  df-1o 8088  df-oadd 8092  df-er 8275  df-map 8394  df-en 8496  df-dom 8497  df-sdom 8498  df-fin 8499  df-sup 8892  df-inf 8893  df-card 9354  df-pnf 10663  df-mnf 10664  df-xr 10665  df-ltxr 10666  df-le 10667  df-sub 10858  df-neg 10859  df-div 11284  df-nn 11625  df-2 11687  df-3 11688  df-n0 11885  df-xnn0 11955  df-z 11969  df-uz 12231  df-rp 12377  df-fz 12883  df-fzo 13024  df-fl 13152  df-mod 13228  df-seq 13360  df-exp 13420  df-hash 13681  df-cj 14443  df-re 14444  df-im 14445  df-sqrt 14579  df-abs 14580  df-dvds 15593  df-gcd 15827  df-odz 16085  df-phi 16086
This theorem is referenced by:  odzphi  16116  pockthlem  16224  odz2prm2pw  43810  fmtnoprmfac2  43814
  Copyright terms: Public domain W3C validator