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

Theorem odzdvds 16714
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 12401 . . . . . . . . 9 (𝐾 ∈ ℕ0𝐾 ∈ ℝ)
21adantl 481 . . . . . . . 8 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → 𝐾 ∈ ℝ)
3 odzcl 16712 . . . . . . . . . 10 ((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) → ((od𝑁)‘𝐴) ∈ ℕ)
43adantr 480 . . . . . . . . 9 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → ((od𝑁)‘𝐴) ∈ ℕ)
54nnrpd 12938 . . . . . . . 8 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → ((od𝑁)‘𝐴) ∈ ℝ+)
6 modlt 13791 . . . . . . . 8 ((𝐾 ∈ ℝ ∧ ((od𝑁)‘𝐴) ∈ ℝ+) → (𝐾 mod ((od𝑁)‘𝐴)) < ((od𝑁)‘𝐴))
72, 5, 6syl2anc 584 . . . . . . 7 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (𝐾 mod ((od𝑁)‘𝐴)) < ((od𝑁)‘𝐴))
8 nn0z 12503 . . . . . . . . . . 11 (𝐾 ∈ ℕ0𝐾 ∈ ℤ)
98adantl 481 . . . . . . . . . 10 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → 𝐾 ∈ ℤ)
109, 4zmodcld 13803 . . . . . . . . 9 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (𝐾 mod ((od𝑁)‘𝐴)) ∈ ℕ0)
1110nn0red 12454 . . . . . . . 8 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (𝐾 mod ((od𝑁)‘𝐴)) ∈ ℝ)
124nnred 12151 . . . . . . . 8 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → ((od𝑁)‘𝐴) ∈ ℝ)
1311, 12ltnled 11271 . . . . . . 7 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → ((𝐾 mod ((od𝑁)‘𝐴)) < ((od𝑁)‘𝐴) ↔ ¬ ((od𝑁)‘𝐴) ≤ (𝐾 mod ((od𝑁)‘𝐴))))
147, 13mpbid 232 . . . . . 6 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → ¬ ((od𝑁)‘𝐴) ≤ (𝐾 mod ((od𝑁)‘𝐴)))
15 oveq2 7363 . . . . . . . . . . . 12 (𝑛 = (𝐾 mod ((od𝑁)‘𝐴)) → (𝐴𝑛) = (𝐴↑(𝐾 mod ((od𝑁)‘𝐴))))
1615oveq1d 7370 . . . . . . . . . . 11 (𝑛 = (𝐾 mod ((od𝑁)‘𝐴)) → ((𝐴𝑛) − 1) = ((𝐴↑(𝐾 mod ((od𝑁)‘𝐴))) − 1))
1716breq2d 5107 . . . . . . . . . 10 (𝑛 = (𝐾 mod ((od𝑁)‘𝐴)) → (𝑁 ∥ ((𝐴𝑛) − 1) ↔ 𝑁 ∥ ((𝐴↑(𝐾 mod ((od𝑁)‘𝐴))) − 1)))
1817elrab 3643 . . . . . . . . 9 ((𝐾 mod ((od𝑁)‘𝐴)) ∈ {𝑛 ∈ ℕ ∣ 𝑁 ∥ ((𝐴𝑛) − 1)} ↔ ((𝐾 mod ((od𝑁)‘𝐴)) ∈ ℕ ∧ 𝑁 ∥ ((𝐴↑(𝐾 mod ((od𝑁)‘𝐴))) − 1)))
19 ssrab2 4029 . . . . . . . . . . 11 {𝑛 ∈ ℕ ∣ 𝑁 ∥ ((𝐴𝑛) − 1)} ⊆ ℕ
20 nnuz 12781 . . . . . . . . . . 11 ℕ = (ℤ‘1)
2119, 20sseqtri 3979 . . . . . . . . . 10 {𝑛 ∈ ℕ ∣ 𝑁 ∥ ((𝐴𝑛) − 1)} ⊆ (ℤ‘1)
22 infssuzle 12835 . . . . . . . . . 10 (({𝑛 ∈ ℕ ∣ 𝑁 ∥ ((𝐴𝑛) − 1)} ⊆ (ℤ‘1) ∧ (𝐾 mod ((od𝑁)‘𝐴)) ∈ {𝑛 ∈ ℕ ∣ 𝑁 ∥ ((𝐴𝑛) − 1)}) → inf({𝑛 ∈ ℕ ∣ 𝑁 ∥ ((𝐴𝑛) − 1)}, ℝ, < ) ≤ (𝐾 mod ((od𝑁)‘𝐴)))
2321, 22mpan 690 . . . . . . . . 9 ((𝐾 mod ((od𝑁)‘𝐴)) ∈ {𝑛 ∈ ℕ ∣ 𝑁 ∥ ((𝐴𝑛) − 1)} → inf({𝑛 ∈ ℕ ∣ 𝑁 ∥ ((𝐴𝑛) − 1)}, ℝ, < ) ≤ (𝐾 mod ((od𝑁)‘𝐴)))
2418, 23sylbir 235 . . . . . . . 8 (((𝐾 mod ((od𝑁)‘𝐴)) ∈ ℕ ∧ 𝑁 ∥ ((𝐴↑(𝐾 mod ((od𝑁)‘𝐴))) − 1)) → inf({𝑛 ∈ ℕ ∣ 𝑁 ∥ ((𝐴𝑛) − 1)}, ℝ, < ) ≤ (𝐾 mod ((od𝑁)‘𝐴)))
2524ancoms 458 . . . . . . 7 ((𝑁 ∥ ((𝐴↑(𝐾 mod ((od𝑁)‘𝐴))) − 1) ∧ (𝐾 mod ((od𝑁)‘𝐴)) ∈ ℕ) → inf({𝑛 ∈ ℕ ∣ 𝑁 ∥ ((𝐴𝑛) − 1)}, ℝ, < ) ≤ (𝐾 mod ((od𝑁)‘𝐴)))
26 odzval 16710 . . . . . . . . 9 ((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) → ((od𝑁)‘𝐴) = inf({𝑛 ∈ ℕ ∣ 𝑁 ∥ ((𝐴𝑛) − 1)}, ℝ, < ))
2726adantr 480 . . . . . . . 8 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → ((od𝑁)‘𝐴) = inf({𝑛 ∈ ℕ ∣ 𝑁 ∥ ((𝐴𝑛) − 1)}, ℝ, < ))
2827breq1d 5105 . . . . . . 7 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (((od𝑁)‘𝐴) ≤ (𝐾 mod ((od𝑁)‘𝐴)) ↔ inf({𝑛 ∈ ℕ ∣ 𝑁 ∥ ((𝐴𝑛) − 1)}, ℝ, < ) ≤ (𝐾 mod ((od𝑁)‘𝐴))))
2925, 28imbitrrid 246 . . . . . 6 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → ((𝑁 ∥ ((𝐴↑(𝐾 mod ((od𝑁)‘𝐴))) − 1) ∧ (𝐾 mod ((od𝑁)‘𝐴)) ∈ ℕ) → ((od𝑁)‘𝐴) ≤ (𝐾 mod ((od𝑁)‘𝐴))))
3014, 29mtod 198 . . . . 5 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → ¬ (𝑁 ∥ ((𝐴↑(𝐾 mod ((od𝑁)‘𝐴))) − 1) ∧ (𝐾 mod ((od𝑁)‘𝐴)) ∈ ℕ))
31 imnan 399 . . . . 5 ((𝑁 ∥ ((𝐴↑(𝐾 mod ((od𝑁)‘𝐴))) − 1) → ¬ (𝐾 mod ((od𝑁)‘𝐴)) ∈ ℕ) ↔ ¬ (𝑁 ∥ ((𝐴↑(𝐾 mod ((od𝑁)‘𝐴))) − 1) ∧ (𝐾 mod ((od𝑁)‘𝐴)) ∈ ℕ))
3230, 31sylibr 234 . . . 4 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (𝑁 ∥ ((𝐴↑(𝐾 mod ((od𝑁)‘𝐴))) − 1) → ¬ (𝐾 mod ((od𝑁)‘𝐴)) ∈ ℕ))
33 elnn0 12394 . . . . . 6 ((𝐾 mod ((od𝑁)‘𝐴)) ∈ ℕ0 ↔ ((𝐾 mod ((od𝑁)‘𝐴)) ∈ ℕ ∨ (𝐾 mod ((od𝑁)‘𝐴)) = 0))
3410, 33sylib 218 . . . . 5 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → ((𝐾 mod ((od𝑁)‘𝐴)) ∈ ℕ ∨ (𝐾 mod ((od𝑁)‘𝐴)) = 0))
3534ord 864 . . . 4 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (¬ (𝐾 mod ((od𝑁)‘𝐴)) ∈ ℕ → (𝐾 mod ((od𝑁)‘𝐴)) = 0))
3632, 35syld 47 . . 3 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (𝑁 ∥ ((𝐴↑(𝐾 mod ((od𝑁)‘𝐴))) − 1) → (𝐾 mod ((od𝑁)‘𝐴)) = 0))
37 simpl1 1192 . . . . . . 7 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → 𝑁 ∈ ℕ)
3837nnzd 12505 . . . . . 6 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → 𝑁 ∈ ℤ)
39 dvds0 16189 . . . . . 6 (𝑁 ∈ ℤ → 𝑁 ∥ 0)
4038, 39syl 17 . . . . 5 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → 𝑁 ∥ 0)
41 simpl2 1193 . . . . . . . . 9 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → 𝐴 ∈ ℤ)
4241zcnd 12588 . . . . . . . 8 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → 𝐴 ∈ ℂ)
4342exp0d 14054 . . . . . . 7 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (𝐴↑0) = 1)
4443oveq1d 7370 . . . . . 6 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → ((𝐴↑0) − 1) = (1 − 1))
45 1m1e0 12208 . . . . . 6 (1 − 1) = 0
4644, 45eqtrdi 2784 . . . . 5 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → ((𝐴↑0) − 1) = 0)
4740, 46breqtrrd 5123 . . . 4 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → 𝑁 ∥ ((𝐴↑0) − 1))
48 oveq2 7363 . . . . . 6 ((𝐾 mod ((od𝑁)‘𝐴)) = 0 → (𝐴↑(𝐾 mod ((od𝑁)‘𝐴))) = (𝐴↑0))
4948oveq1d 7370 . . . . 5 ((𝐾 mod ((od𝑁)‘𝐴)) = 0 → ((𝐴↑(𝐾 mod ((od𝑁)‘𝐴))) − 1) = ((𝐴↑0) − 1))
5049breq2d 5107 . . . 4 ((𝐾 mod ((od𝑁)‘𝐴)) = 0 → (𝑁 ∥ ((𝐴↑(𝐾 mod ((od𝑁)‘𝐴))) − 1) ↔ 𝑁 ∥ ((𝐴↑0) − 1)))
5147, 50syl5ibrcom 247 . . 3 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → ((𝐾 mod ((od𝑁)‘𝐴)) = 0 → 𝑁 ∥ ((𝐴↑(𝐾 mod ((od𝑁)‘𝐴))) − 1)))
5236, 51impbid 212 . 2 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (𝑁 ∥ ((𝐴↑(𝐾 mod ((od𝑁)‘𝐴))) − 1) ↔ (𝐾 mod ((od𝑁)‘𝐴)) = 0))
534nnnn0d 12453 . . . . . . . . 9 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → ((od𝑁)‘𝐴) ∈ ℕ0)
542, 4nndivred 12190 . . . . . . . . . 10 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (𝐾 / ((od𝑁)‘𝐴)) ∈ ℝ)
55 nn0ge0 12417 . . . . . . . . . . . 12 (𝐾 ∈ ℕ0 → 0 ≤ 𝐾)
5655adantl 481 . . . . . . . . . . 11 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → 0 ≤ 𝐾)
574nngt0d 12185 . . . . . . . . . . . 12 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → 0 < ((od𝑁)‘𝐴))
58 ge0div 12000 . . . . . . . . . . . 12 ((𝐾 ∈ ℝ ∧ ((od𝑁)‘𝐴) ∈ ℝ ∧ 0 < ((od𝑁)‘𝐴)) → (0 ≤ 𝐾 ↔ 0 ≤ (𝐾 / ((od𝑁)‘𝐴))))
592, 12, 57, 58syl3anc 1373 . . . . . . . . . . 11 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (0 ≤ 𝐾 ↔ 0 ≤ (𝐾 / ((od𝑁)‘𝐴))))
6056, 59mpbid 232 . . . . . . . . . 10 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → 0 ≤ (𝐾 / ((od𝑁)‘𝐴)))
61 flge0nn0 13731 . . . . . . . . . 10 (((𝐾 / ((od𝑁)‘𝐴)) ∈ ℝ ∧ 0 ≤ (𝐾 / ((od𝑁)‘𝐴))) → (⌊‘(𝐾 / ((od𝑁)‘𝐴))) ∈ ℕ0)
6254, 60, 61syl2anc 584 . . . . . . . . 9 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (⌊‘(𝐾 / ((od𝑁)‘𝐴))) ∈ ℕ0)
6353, 62nn0mulcld 12458 . . . . . . . 8 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (((od𝑁)‘𝐴) · (⌊‘(𝐾 / ((od𝑁)‘𝐴)))) ∈ ℕ0)
64 zexpcl 13990 . . . . . . . 8 ((𝐴 ∈ ℤ ∧ (((od𝑁)‘𝐴) · (⌊‘(𝐾 / ((od𝑁)‘𝐴)))) ∈ ℕ0) → (𝐴↑(((od𝑁)‘𝐴) · (⌊‘(𝐾 / ((od𝑁)‘𝐴))))) ∈ ℤ)
6541, 63, 64syl2anc 584 . . . . . . 7 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (𝐴↑(((od𝑁)‘𝐴) · (⌊‘(𝐾 / ((od𝑁)‘𝐴))))) ∈ ℤ)
6665zred 12587 . . . . . 6 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (𝐴↑(((od𝑁)‘𝐴) · (⌊‘(𝐾 / ((od𝑁)‘𝐴))))) ∈ ℝ)
67 1red 11124 . . . . . 6 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → 1 ∈ ℝ)
68 zexpcl 13990 . . . . . . 7 ((𝐴 ∈ ℤ ∧ (𝐾 mod ((od𝑁)‘𝐴)) ∈ ℕ0) → (𝐴↑(𝐾 mod ((od𝑁)‘𝐴))) ∈ ℤ)
6941, 10, 68syl2anc 584 . . . . . 6 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (𝐴↑(𝐾 mod ((od𝑁)‘𝐴))) ∈ ℤ)
7037nnrpd 12938 . . . . . 6 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → 𝑁 ∈ ℝ+)
7142, 62, 53expmuld 14063 . . . . . . . 8 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (𝐴↑(((od𝑁)‘𝐴) · (⌊‘(𝐾 / ((od𝑁)‘𝐴))))) = ((𝐴↑((od𝑁)‘𝐴))↑(⌊‘(𝐾 / ((od𝑁)‘𝐴)))))
7271oveq1d 7370 . . . . . . 7 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → ((𝐴↑(((od𝑁)‘𝐴) · (⌊‘(𝐾 / ((od𝑁)‘𝐴))))) mod 𝑁) = (((𝐴↑((od𝑁)‘𝐴))↑(⌊‘(𝐾 / ((od𝑁)‘𝐴)))) mod 𝑁))
73 zexpcl 13990 . . . . . . . . 9 ((𝐴 ∈ ℤ ∧ ((od𝑁)‘𝐴) ∈ ℕ0) → (𝐴↑((od𝑁)‘𝐴)) ∈ ℤ)
7441, 53, 73syl2anc 584 . . . . . . . 8 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (𝐴↑((od𝑁)‘𝐴)) ∈ ℤ)
75 1zzd 12513 . . . . . . . 8 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → 1 ∈ ℤ)
76 odzid 16713 . . . . . . . . . 10 ((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) → 𝑁 ∥ ((𝐴↑((od𝑁)‘𝐴)) − 1))
7776adantr 480 . . . . . . . . 9 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → 𝑁 ∥ ((𝐴↑((od𝑁)‘𝐴)) − 1))
78 moddvds 16181 . . . . . . . . . 10 ((𝑁 ∈ ℕ ∧ (𝐴↑((od𝑁)‘𝐴)) ∈ ℤ ∧ 1 ∈ ℤ) → (((𝐴↑((od𝑁)‘𝐴)) mod 𝑁) = (1 mod 𝑁) ↔ 𝑁 ∥ ((𝐴↑((od𝑁)‘𝐴)) − 1)))
7937, 74, 75, 78syl3anc 1373 . . . . . . . . 9 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (((𝐴↑((od𝑁)‘𝐴)) mod 𝑁) = (1 mod 𝑁) ↔ 𝑁 ∥ ((𝐴↑((od𝑁)‘𝐴)) − 1)))
8077, 79mpbird 257 . . . . . . . 8 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → ((𝐴↑((od𝑁)‘𝐴)) mod 𝑁) = (1 mod 𝑁))
81 modexp 14152 . . . . . . . 8 ((((𝐴↑((od𝑁)‘𝐴)) ∈ ℤ ∧ 1 ∈ ℤ) ∧ ((⌊‘(𝐾 / ((od𝑁)‘𝐴))) ∈ ℕ0𝑁 ∈ ℝ+) ∧ ((𝐴↑((od𝑁)‘𝐴)) mod 𝑁) = (1 mod 𝑁)) → (((𝐴↑((od𝑁)‘𝐴))↑(⌊‘(𝐾 / ((od𝑁)‘𝐴)))) mod 𝑁) = ((1↑(⌊‘(𝐾 / ((od𝑁)‘𝐴)))) mod 𝑁))
8274, 75, 62, 70, 80, 81syl221anc 1383 . . . . . . 7 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (((𝐴↑((od𝑁)‘𝐴))↑(⌊‘(𝐾 / ((od𝑁)‘𝐴)))) mod 𝑁) = ((1↑(⌊‘(𝐾 / ((od𝑁)‘𝐴)))) mod 𝑁))
8354flcld 13709 . . . . . . . . 9 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (⌊‘(𝐾 / ((od𝑁)‘𝐴))) ∈ ℤ)
84 1exp 14005 . . . . . . . . 9 ((⌊‘(𝐾 / ((od𝑁)‘𝐴))) ∈ ℤ → (1↑(⌊‘(𝐾 / ((od𝑁)‘𝐴)))) = 1)
8583, 84syl 17 . . . . . . . 8 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (1↑(⌊‘(𝐾 / ((od𝑁)‘𝐴)))) = 1)
8685oveq1d 7370 . . . . . . 7 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → ((1↑(⌊‘(𝐾 / ((od𝑁)‘𝐴)))) mod 𝑁) = (1 mod 𝑁))
8772, 82, 863eqtrd 2772 . . . . . 6 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → ((𝐴↑(((od𝑁)‘𝐴) · (⌊‘(𝐾 / ((od𝑁)‘𝐴))))) mod 𝑁) = (1 mod 𝑁))
88 modmul1 13838 . . . . . 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 1383 . . . . 5 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (((𝐴↑(((od𝑁)‘𝐴) · (⌊‘(𝐾 / ((od𝑁)‘𝐴))))) · (𝐴↑(𝐾 mod ((od𝑁)‘𝐴)))) mod 𝑁) = ((1 · (𝐴↑(𝐾 mod ((od𝑁)‘𝐴)))) mod 𝑁))
9042, 10, 63expaddd 14062 . . . . . . 7 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (𝐴↑((((od𝑁)‘𝐴) · (⌊‘(𝐾 / ((od𝑁)‘𝐴)))) + (𝐾 mod ((od𝑁)‘𝐴)))) = ((𝐴↑(((od𝑁)‘𝐴) · (⌊‘(𝐾 / ((od𝑁)‘𝐴))))) · (𝐴↑(𝐾 mod ((od𝑁)‘𝐴)))))
91 modval 13782 . . . . . . . . . . 11 ((𝐾 ∈ ℝ ∧ ((od𝑁)‘𝐴) ∈ ℝ+) → (𝐾 mod ((od𝑁)‘𝐴)) = (𝐾 − (((od𝑁)‘𝐴) · (⌊‘(𝐾 / ((od𝑁)‘𝐴))))))
922, 5, 91syl2anc 584 . . . . . . . . . 10 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (𝐾 mod ((od𝑁)‘𝐴)) = (𝐾 − (((od𝑁)‘𝐴) · (⌊‘(𝐾 / ((od𝑁)‘𝐴))))))
9392oveq2d 7371 . . . . . . . . 9 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → ((((od𝑁)‘𝐴) · (⌊‘(𝐾 / ((od𝑁)‘𝐴)))) + (𝐾 mod ((od𝑁)‘𝐴))) = ((((od𝑁)‘𝐴) · (⌊‘(𝐾 / ((od𝑁)‘𝐴)))) + (𝐾 − (((od𝑁)‘𝐴) · (⌊‘(𝐾 / ((od𝑁)‘𝐴)))))))
9463nn0cnd 12455 . . . . . . . . . 10 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (((od𝑁)‘𝐴) · (⌊‘(𝐾 / ((od𝑁)‘𝐴)))) ∈ ℂ)
952recnd 11151 . . . . . . . . . 10 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → 𝐾 ∈ ℂ)
9694, 95pncan3d 11486 . . . . . . . . 9 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → ((((od𝑁)‘𝐴) · (⌊‘(𝐾 / ((od𝑁)‘𝐴)))) + (𝐾 − (((od𝑁)‘𝐴) · (⌊‘(𝐾 / ((od𝑁)‘𝐴)))))) = 𝐾)
9793, 96eqtrd 2768 . . . . . . . 8 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → ((((od𝑁)‘𝐴) · (⌊‘(𝐾 / ((od𝑁)‘𝐴)))) + (𝐾 mod ((od𝑁)‘𝐴))) = 𝐾)
9897oveq2d 7371 . . . . . . 7 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (𝐴↑((((od𝑁)‘𝐴) · (⌊‘(𝐾 / ((od𝑁)‘𝐴)))) + (𝐾 mod ((od𝑁)‘𝐴)))) = (𝐴𝐾))
9990, 98eqtr3d 2770 . . . . . 6 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → ((𝐴↑(((od𝑁)‘𝐴) · (⌊‘(𝐾 / ((od𝑁)‘𝐴))))) · (𝐴↑(𝐾 mod ((od𝑁)‘𝐴)))) = (𝐴𝐾))
10099oveq1d 7370 . . . . 5 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (((𝐴↑(((od𝑁)‘𝐴) · (⌊‘(𝐾 / ((od𝑁)‘𝐴))))) · (𝐴↑(𝐾 mod ((od𝑁)‘𝐴)))) mod 𝑁) = ((𝐴𝐾) mod 𝑁))
10169zcnd 12588 . . . . . . 7 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (𝐴↑(𝐾 mod ((od𝑁)‘𝐴))) ∈ ℂ)
102101mullidd 11141 . . . . . 6 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (1 · (𝐴↑(𝐾 mod ((od𝑁)‘𝐴)))) = (𝐴↑(𝐾 mod ((od𝑁)‘𝐴))))
103102oveq1d 7370 . . . . 5 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → ((1 · (𝐴↑(𝐾 mod ((od𝑁)‘𝐴)))) mod 𝑁) = ((𝐴↑(𝐾 mod ((od𝑁)‘𝐴))) mod 𝑁))
10489, 100, 1033eqtr3d 2776 . . . 4 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → ((𝐴𝐾) mod 𝑁) = ((𝐴↑(𝐾 mod ((od𝑁)‘𝐴))) mod 𝑁))
105104eqeq1d 2735 . . 3 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (((𝐴𝐾) mod 𝑁) = (1 mod 𝑁) ↔ ((𝐴↑(𝐾 mod ((od𝑁)‘𝐴))) mod 𝑁) = (1 mod 𝑁)))
106 zexpcl 13990 . . . . 5 ((𝐴 ∈ ℤ ∧ 𝐾 ∈ ℕ0) → (𝐴𝐾) ∈ ℤ)
10741, 106sylancom 588 . . . 4 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (𝐴𝐾) ∈ ℤ)
108 moddvds 16181 . . . 4 ((𝑁 ∈ ℕ ∧ (𝐴𝐾) ∈ ℤ ∧ 1 ∈ ℤ) → (((𝐴𝐾) mod 𝑁) = (1 mod 𝑁) ↔ 𝑁 ∥ ((𝐴𝐾) − 1)))
10937, 107, 75, 108syl3anc 1373 . . 3 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (((𝐴𝐾) mod 𝑁) = (1 mod 𝑁) ↔ 𝑁 ∥ ((𝐴𝐾) − 1)))
110 moddvds 16181 . . . 4 ((𝑁 ∈ ℕ ∧ (𝐴↑(𝐾 mod ((od𝑁)‘𝐴))) ∈ ℤ ∧ 1 ∈ ℤ) → (((𝐴↑(𝐾 mod ((od𝑁)‘𝐴))) mod 𝑁) = (1 mod 𝑁) ↔ 𝑁 ∥ ((𝐴↑(𝐾 mod ((od𝑁)‘𝐴))) − 1)))
11137, 69, 75, 110syl3anc 1373 . . 3 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (((𝐴↑(𝐾 mod ((od𝑁)‘𝐴))) mod 𝑁) = (1 mod 𝑁) ↔ 𝑁 ∥ ((𝐴↑(𝐾 mod ((od𝑁)‘𝐴))) − 1)))
112105, 109, 1113bitr3d 309 . 2 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (𝑁 ∥ ((𝐴𝐾) − 1) ↔ 𝑁 ∥ ((𝐴↑(𝐾 mod ((od𝑁)‘𝐴))) − 1)))
113 dvdsval3 16174 . . 3 ((((od𝑁)‘𝐴) ∈ ℕ ∧ 𝐾 ∈ ℤ) → (((od𝑁)‘𝐴) ∥ 𝐾 ↔ (𝐾 mod ((od𝑁)‘𝐴)) = 0))
1144, 9, 113syl2anc 584 . 2 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (((od𝑁)‘𝐴) ∥ 𝐾 ↔ (𝐾 mod ((od𝑁)‘𝐴)) = 0))
11552, 112, 1143bitr4d 311 1 (((𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1) ∧ 𝐾 ∈ ℕ0) → (𝑁 ∥ ((𝐴𝐾) − 1) ↔ ((od𝑁)‘𝐴) ∥ 𝐾))
Colors of variables: wff setvar class
Syntax hints:  ¬ wn 3  wi 4  wb 206  wa 395  wo 847  w3a 1086   = wceq 1541  wcel 2113  {crab 3396  wss 3898   class class class wbr 5095  cfv 6489  (class class class)co 7355  infcinf 9336  cr 11016  0cc0 11017  1c1 11018   + caddc 11020   · cmul 11022   < clt 11157  cle 11158  cmin 11355   / cdiv 11785  cn 12136  0cn0 12392  cz 12479  cuz 12742  +crp 12896  cfl 13701   mod cmo 13780  cexp 13975  cdvds 16170   gcd cgcd 16412  odcodz 16681
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 1968  ax-7 2009  ax-8 2115  ax-9 2123  ax-10 2146  ax-11 2162  ax-12 2182  ax-ext 2705  ax-rep 5221  ax-sep 5238  ax-nul 5248  ax-pow 5307  ax-pr 5374  ax-un 7677  ax-cnex 11073  ax-resscn 11074  ax-1cn 11075  ax-icn 11076  ax-addcl 11077  ax-addrcl 11078  ax-mulcl 11079  ax-mulrcl 11080  ax-mulcom 11081  ax-addass 11082  ax-mulass 11083  ax-distr 11084  ax-i2m1 11085  ax-1ne0 11086  ax-1rid 11087  ax-rnegex 11088  ax-rrecex 11089  ax-cnre 11090  ax-pre-lttri 11091  ax-pre-lttrn 11092  ax-pre-ltadd 11093  ax-pre-mulgt0 11094  ax-pre-sup 11095
This theorem depends on definitions:  df-bi 207  df-an 396  df-or 848  df-3or 1087  df-3an 1088  df-tru 1544  df-fal 1554  df-ex 1781  df-nf 1785  df-sb 2068  df-mo 2537  df-eu 2566  df-clab 2712  df-cleq 2725  df-clel 2808  df-nfc 2882  df-ne 2930  df-nel 3034  df-ral 3049  df-rex 3058  df-rmo 3347  df-reu 3348  df-rab 3397  df-v 3439  df-sbc 3738  df-csb 3847  df-dif 3901  df-un 3903  df-in 3905  df-ss 3915  df-pss 3918  df-nul 4283  df-if 4477  df-pw 4553  df-sn 4578  df-pr 4580  df-op 4584  df-uni 4861  df-int 4900  df-iun 4945  df-br 5096  df-opab 5158  df-mpt 5177  df-tr 5203  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 7312  df-ov 7358  df-oprab 7359  df-mpo 7360  df-om 7806  df-1st 7930  df-2nd 7931  df-frecs 8220  df-wrecs 8251  df-recs 8300  df-rdg 8338  df-1o 8394  df-oadd 8398  df-er 8631  df-en 8880  df-dom 8881  df-sdom 8882  df-fin 8883  df-sup 9337  df-inf 9338  df-card 9843  df-pnf 11159  df-mnf 11160  df-xr 11161  df-ltxr 11162  df-le 11163  df-sub 11357  df-neg 11358  df-div 11786  df-nn 12137  df-2 12199  df-3 12200  df-n0 12393  df-xnn0 12466  df-z 12480  df-uz 12743  df-rp 12897  df-fz 13415  df-fzo 13562  df-fl 13703  df-mod 13781  df-seq 13916  df-exp 13976  df-hash 14245  df-cj 15013  df-re 15014  df-im 15015  df-sqrt 15149  df-abs 15150  df-dvds 16171  df-gcd 16413  df-odz 16683  df-phi 16684
This theorem is referenced by:  odzphi  16715  pockthlem  16824  aks4d1p9  42254  odz2prm2pw  47725  fmtnoprmfac2  47729
  Copyright terms: Public domain W3C validator