ILE Home Intuitionistic Logic Explorer < Previous   Next >
Nearby theorems
Mirrors  >  Home  >  ILE Home  >  Th. List  >  eulerthlemth GIF version

Theorem eulerthlemth 12186
Description: Lemma for eulerth 12187. The result. (Contributed by Mario Carneiro, 28-Feb-2014.) (Revised by Jim Kingdon, 2-Sep-2024.)
Hypotheses
Ref Expression
eulerth.1 (𝜑 → (𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1))
eulerth.2 𝑆 = {𝑦 ∈ (0..^𝑁) ∣ (𝑦 gcd 𝑁) = 1}
eulerth.4 (𝜑𝐹:(1...(ϕ‘𝑁))–1-1-onto𝑆)
Assertion
Ref Expression
eulerthlemth (𝜑 → ((𝐴↑(ϕ‘𝑁)) mod 𝑁) = (1 mod 𝑁))
Distinct variable groups:   𝑦,𝐴   𝑦,𝐹   𝑦,𝑁   𝜑,𝑦
Allowed substitution hint:   𝑆(𝑦)

Proof of Theorem eulerthlemth
Dummy variables 𝑢 𝑣 𝑥 𝑧 are mutually distinct and distinct from all other variables.
StepHypRef Expression
1 eulerth.1 . . . . . 6 (𝜑 → (𝑁 ∈ ℕ ∧ 𝐴 ∈ ℤ ∧ (𝐴 gcd 𝑁) = 1))
2 eulerth.2 . . . . . 6 𝑆 = {𝑦 ∈ (0..^𝑁) ∣ (𝑦 gcd 𝑁) = 1}
3 eulerth.4 . . . . . 6 (𝜑𝐹:(1...(ϕ‘𝑁))–1-1-onto𝑆)
41, 2, 3eulerthlema 12184 . . . . 5 (𝜑 → (((𝐴↑(ϕ‘𝑁)) · ∏𝑥 ∈ (1...(ϕ‘𝑁))(𝐹𝑥)) mod 𝑁) = (∏𝑥 ∈ (1...(ϕ‘𝑁))((𝐴 · (𝐹𝑥)) mod 𝑁) mod 𝑁))
51simp1d 1004 . . . . . 6 (𝜑𝑁 ∈ ℕ)
61simp2d 1005 . . . . . . . 8 (𝜑𝐴 ∈ ℤ)
75phicld 12172 . . . . . . . . 9 (𝜑 → (ϕ‘𝑁) ∈ ℕ)
87nnnn0d 9188 . . . . . . . 8 (𝜑 → (ϕ‘𝑁) ∈ ℕ0)
9 zexpcl 10491 . . . . . . . 8 ((𝐴 ∈ ℤ ∧ (ϕ‘𝑁) ∈ ℕ0) → (𝐴↑(ϕ‘𝑁)) ∈ ℤ)
106, 8, 9syl2anc 409 . . . . . . 7 (𝜑 → (𝐴↑(ϕ‘𝑁)) ∈ ℤ)
11 1zzd 9239 . . . . . . . . 9 (𝜑 → 1 ∈ ℤ)
127nnzd 9333 . . . . . . . . 9 (𝜑 → (ϕ‘𝑁) ∈ ℤ)
1311, 12fzfigd 10387 . . . . . . . 8 (𝜑 → (1...(ϕ‘𝑁)) ∈ Fin)
14 ssrab2 3232 . . . . . . . . . . 11 {𝑦 ∈ (0..^𝑁) ∣ (𝑦 gcd 𝑁) = 1} ⊆ (0..^𝑁)
152, 14eqsstri 3179 . . . . . . . . . 10 𝑆 ⊆ (0..^𝑁)
16 fzo0ssnn0 10171 . . . . . . . . . . 11 (0..^𝑁) ⊆ ℕ0
17 nn0ssz 9230 . . . . . . . . . . 11 0 ⊆ ℤ
1816, 17sstri 3156 . . . . . . . . . 10 (0..^𝑁) ⊆ ℤ
1915, 18sstri 3156 . . . . . . . . 9 𝑆 ⊆ ℤ
20 f1of 5442 . . . . . . . . . . 11 (𝐹:(1...(ϕ‘𝑁))–1-1-onto𝑆𝐹:(1...(ϕ‘𝑁))⟶𝑆)
213, 20syl 14 . . . . . . . . . 10 (𝜑𝐹:(1...(ϕ‘𝑁))⟶𝑆)
2221ffvelrnda 5631 . . . . . . . . 9 ((𝜑𝑥 ∈ (1...(ϕ‘𝑁))) → (𝐹𝑥) ∈ 𝑆)
2319, 22sselid 3145 . . . . . . . 8 ((𝜑𝑥 ∈ (1...(ϕ‘𝑁))) → (𝐹𝑥) ∈ ℤ)
2413, 23fprodzcl 11572 . . . . . . 7 (𝜑 → ∏𝑥 ∈ (1...(ϕ‘𝑁))(𝐹𝑥) ∈ ℤ)
2510, 24zmulcld 9340 . . . . . 6 (𝜑 → ((𝐴↑(ϕ‘𝑁)) · ∏𝑥 ∈ (1...(ϕ‘𝑁))(𝐹𝑥)) ∈ ℤ)
26 fveq2 5496 . . . . . . . . 9 (𝑧 = (𝐹‘((𝐴 · (𝐹𝑥)) mod 𝑁)) → (𝐹𝑧) = (𝐹‘(𝐹‘((𝐴 · (𝐹𝑥)) mod 𝑁))))
27 eqid 2170 . . . . . . . . . 10 (𝐹 ∘ (𝑦 ∈ (1...(ϕ‘𝑁)) ↦ ((𝐴 · (𝐹𝑦)) mod 𝑁))) = (𝐹 ∘ (𝑦 ∈ (1...(ϕ‘𝑁)) ↦ ((𝐴 · (𝐹𝑦)) mod 𝑁)))
281, 2, 3, 27eulerthlemh 12185 . . . . . . . . 9 (𝜑 → (𝐹 ∘ (𝑦 ∈ (1...(ϕ‘𝑁)) ↦ ((𝐴 · (𝐹𝑦)) mod 𝑁))):(1...(ϕ‘𝑁))–1-1-onto→(1...(ϕ‘𝑁)))
29 eqid 2170 . . . . . . . . . . . . 13 (1...(ϕ‘𝑁)) = (1...(ϕ‘𝑁))
30 fveq2 5496 . . . . . . . . . . . . . . . 16 (𝑣 = 𝑢 → (𝐹𝑣) = (𝐹𝑢))
3130oveq2d 5869 . . . . . . . . . . . . . . 15 (𝑣 = 𝑢 → (𝐴 · (𝐹𝑣)) = (𝐴 · (𝐹𝑢)))
3231oveq1d 5868 . . . . . . . . . . . . . 14 (𝑣 = 𝑢 → ((𝐴 · (𝐹𝑣)) mod 𝑁) = ((𝐴 · (𝐹𝑢)) mod 𝑁))
3332cbvmptv 4085 . . . . . . . . . . . . 13 (𝑣 ∈ (1...(ϕ‘𝑁)) ↦ ((𝐴 · (𝐹𝑣)) mod 𝑁)) = (𝑢 ∈ (1...(ϕ‘𝑁)) ↦ ((𝐴 · (𝐹𝑢)) mod 𝑁))
341, 2, 29, 3, 33eulerthlem1 12181 . . . . . . . . . . . 12 (𝜑 → (𝑣 ∈ (1...(ϕ‘𝑁)) ↦ ((𝐴 · (𝐹𝑣)) mod 𝑁)):(1...(ϕ‘𝑁))⟶𝑆)
35 fveq2 5496 . . . . . . . . . . . . . . . 16 (𝑣 = 𝑦 → (𝐹𝑣) = (𝐹𝑦))
3635oveq2d 5869 . . . . . . . . . . . . . . 15 (𝑣 = 𝑦 → (𝐴 · (𝐹𝑣)) = (𝐴 · (𝐹𝑦)))
3736oveq1d 5868 . . . . . . . . . . . . . 14 (𝑣 = 𝑦 → ((𝐴 · (𝐹𝑣)) mod 𝑁) = ((𝐴 · (𝐹𝑦)) mod 𝑁))
3837cbvmptv 4085 . . . . . . . . . . . . 13 (𝑣 ∈ (1...(ϕ‘𝑁)) ↦ ((𝐴 · (𝐹𝑣)) mod 𝑁)) = (𝑦 ∈ (1...(ϕ‘𝑁)) ↦ ((𝐴 · (𝐹𝑦)) mod 𝑁))
3938feq1i 5340 . . . . . . . . . . . 12 ((𝑣 ∈ (1...(ϕ‘𝑁)) ↦ ((𝐴 · (𝐹𝑣)) mod 𝑁)):(1...(ϕ‘𝑁))⟶𝑆 ↔ (𝑦 ∈ (1...(ϕ‘𝑁)) ↦ ((𝐴 · (𝐹𝑦)) mod 𝑁)):(1...(ϕ‘𝑁))⟶𝑆)
4034, 39sylib 121 . . . . . . . . . . 11 (𝜑 → (𝑦 ∈ (1...(ϕ‘𝑁)) ↦ ((𝐴 · (𝐹𝑦)) mod 𝑁)):(1...(ϕ‘𝑁))⟶𝑆)
41 fvco3 5567 . . . . . . . . . . 11 (((𝑦 ∈ (1...(ϕ‘𝑁)) ↦ ((𝐴 · (𝐹𝑦)) mod 𝑁)):(1...(ϕ‘𝑁))⟶𝑆𝑥 ∈ (1...(ϕ‘𝑁))) → ((𝐹 ∘ (𝑦 ∈ (1...(ϕ‘𝑁)) ↦ ((𝐴 · (𝐹𝑦)) mod 𝑁)))‘𝑥) = (𝐹‘((𝑦 ∈ (1...(ϕ‘𝑁)) ↦ ((𝐴 · (𝐹𝑦)) mod 𝑁))‘𝑥)))
4240, 41sylan 281 . . . . . . . . . 10 ((𝜑𝑥 ∈ (1...(ϕ‘𝑁))) → ((𝐹 ∘ (𝑦 ∈ (1...(ϕ‘𝑁)) ↦ ((𝐴 · (𝐹𝑦)) mod 𝑁)))‘𝑥) = (𝐹‘((𝑦 ∈ (1...(ϕ‘𝑁)) ↦ ((𝐴 · (𝐹𝑦)) mod 𝑁))‘𝑥)))
43 eqid 2170 . . . . . . . . . . . 12 (𝑦 ∈ (1...(ϕ‘𝑁)) ↦ ((𝐴 · (𝐹𝑦)) mod 𝑁)) = (𝑦 ∈ (1...(ϕ‘𝑁)) ↦ ((𝐴 · (𝐹𝑦)) mod 𝑁))
44 fveq2 5496 . . . . . . . . . . . . . 14 (𝑦 = 𝑥 → (𝐹𝑦) = (𝐹𝑥))
4544oveq2d 5869 . . . . . . . . . . . . 13 (𝑦 = 𝑥 → (𝐴 · (𝐹𝑦)) = (𝐴 · (𝐹𝑥)))
4645oveq1d 5868 . . . . . . . . . . . 12 (𝑦 = 𝑥 → ((𝐴 · (𝐹𝑦)) mod 𝑁) = ((𝐴 · (𝐹𝑥)) mod 𝑁))
47 simpr 109 . . . . . . . . . . . 12 ((𝜑𝑥 ∈ (1...(ϕ‘𝑁))) → 𝑥 ∈ (1...(ϕ‘𝑁)))
486adantr 274 . . . . . . . . . . . . . 14 ((𝜑𝑥 ∈ (1...(ϕ‘𝑁))) → 𝐴 ∈ ℤ)
4948, 23zmulcld 9340 . . . . . . . . . . . . 13 ((𝜑𝑥 ∈ (1...(ϕ‘𝑁))) → (𝐴 · (𝐹𝑥)) ∈ ℤ)
505adantr 274 . . . . . . . . . . . . 13 ((𝜑𝑥 ∈ (1...(ϕ‘𝑁))) → 𝑁 ∈ ℕ)
51 zmodfzo 10303 . . . . . . . . . . . . 13 (((𝐴 · (𝐹𝑥)) ∈ ℤ ∧ 𝑁 ∈ ℕ) → ((𝐴 · (𝐹𝑥)) mod 𝑁) ∈ (0..^𝑁))
5249, 50, 51syl2anc 409 . . . . . . . . . . . 12 ((𝜑𝑥 ∈ (1...(ϕ‘𝑁))) → ((𝐴 · (𝐹𝑥)) mod 𝑁) ∈ (0..^𝑁))
5343, 46, 47, 52fvmptd3 5589 . . . . . . . . . . 11 ((𝜑𝑥 ∈ (1...(ϕ‘𝑁))) → ((𝑦 ∈ (1...(ϕ‘𝑁)) ↦ ((𝐴 · (𝐹𝑦)) mod 𝑁))‘𝑥) = ((𝐴 · (𝐹𝑥)) mod 𝑁))
5453fveq2d 5500 . . . . . . . . . 10 ((𝜑𝑥 ∈ (1...(ϕ‘𝑁))) → (𝐹‘((𝑦 ∈ (1...(ϕ‘𝑁)) ↦ ((𝐴 · (𝐹𝑦)) mod 𝑁))‘𝑥)) = (𝐹‘((𝐴 · (𝐹𝑥)) mod 𝑁)))
5542, 54eqtrd 2203 . . . . . . . . 9 ((𝜑𝑥 ∈ (1...(ϕ‘𝑁))) → ((𝐹 ∘ (𝑦 ∈ (1...(ϕ‘𝑁)) ↦ ((𝐴 · (𝐹𝑦)) mod 𝑁)))‘𝑥) = (𝐹‘((𝐴 · (𝐹𝑥)) mod 𝑁)))
5621ffvelrnda 5631 . . . . . . . . . . 11 ((𝜑𝑧 ∈ (1...(ϕ‘𝑁))) → (𝐹𝑧) ∈ 𝑆)
5719, 56sselid 3145 . . . . . . . . . 10 ((𝜑𝑧 ∈ (1...(ϕ‘𝑁))) → (𝐹𝑧) ∈ ℤ)
5857zcnd 9335 . . . . . . . . 9 ((𝜑𝑧 ∈ (1...(ϕ‘𝑁))) → (𝐹𝑧) ∈ ℂ)
5926, 13, 28, 55, 58fprodf1o 11551 . . . . . . . 8 (𝜑 → ∏𝑧 ∈ (1...(ϕ‘𝑁))(𝐹𝑧) = ∏𝑥 ∈ (1...(ϕ‘𝑁))(𝐹‘(𝐹‘((𝐴 · (𝐹𝑥)) mod 𝑁))))
603adantr 274 . . . . . . . . . 10 ((𝜑𝑥 ∈ (1...(ϕ‘𝑁))) → 𝐹:(1...(ϕ‘𝑁))–1-1-onto𝑆)
61 modgcd 11946 . . . . . . . . . . . . 13 (((𝐴 · (𝐹𝑥)) ∈ ℤ ∧ 𝑁 ∈ ℕ) → (((𝐴 · (𝐹𝑥)) mod 𝑁) gcd 𝑁) = ((𝐴 · (𝐹𝑥)) gcd 𝑁))
6249, 50, 61syl2anc 409 . . . . . . . . . . . 12 ((𝜑𝑥 ∈ (1...(ϕ‘𝑁))) → (((𝐴 · (𝐹𝑥)) mod 𝑁) gcd 𝑁) = ((𝐴 · (𝐹𝑥)) gcd 𝑁))
6350nnzd 9333 . . . . . . . . . . . . 13 ((𝜑𝑥 ∈ (1...(ϕ‘𝑁))) → 𝑁 ∈ ℤ)
6463, 49gcdcomd 11929 . . . . . . . . . . . 12 ((𝜑𝑥 ∈ (1...(ϕ‘𝑁))) → (𝑁 gcd (𝐴 · (𝐹𝑥))) = ((𝐴 · (𝐹𝑥)) gcd 𝑁))
655nnzd 9333 . . . . . . . . . . . . . . . 16 (𝜑𝑁 ∈ ℤ)
666, 65gcdcomd 11929 . . . . . . . . . . . . . . 15 (𝜑 → (𝐴 gcd 𝑁) = (𝑁 gcd 𝐴))
671simp3d 1006 . . . . . . . . . . . . . . 15 (𝜑 → (𝐴 gcd 𝑁) = 1)
6866, 67eqtr3d 2205 . . . . . . . . . . . . . 14 (𝜑 → (𝑁 gcd 𝐴) = 1)
6968adantr 274 . . . . . . . . . . . . 13 ((𝜑𝑥 ∈ (1...(ϕ‘𝑁))) → (𝑁 gcd 𝐴) = 1)
7023, 63gcdcomd 11929 . . . . . . . . . . . . . 14 ((𝜑𝑥 ∈ (1...(ϕ‘𝑁))) → ((𝐹𝑥) gcd 𝑁) = (𝑁 gcd (𝐹𝑥)))
71 oveq1 5860 . . . . . . . . . . . . . . . . . 18 (𝑦 = (𝐹𝑥) → (𝑦 gcd 𝑁) = ((𝐹𝑥) gcd 𝑁))
7271eqeq1d 2179 . . . . . . . . . . . . . . . . 17 (𝑦 = (𝐹𝑥) → ((𝑦 gcd 𝑁) = 1 ↔ ((𝐹𝑥) gcd 𝑁) = 1))
7372, 2elrab2 2889 . . . . . . . . . . . . . . . 16 ((𝐹𝑥) ∈ 𝑆 ↔ ((𝐹𝑥) ∈ (0..^𝑁) ∧ ((𝐹𝑥) gcd 𝑁) = 1))
7422, 73sylib 121 . . . . . . . . . . . . . . 15 ((𝜑𝑥 ∈ (1...(ϕ‘𝑁))) → ((𝐹𝑥) ∈ (0..^𝑁) ∧ ((𝐹𝑥) gcd 𝑁) = 1))
7574simprd 113 . . . . . . . . . . . . . 14 ((𝜑𝑥 ∈ (1...(ϕ‘𝑁))) → ((𝐹𝑥) gcd 𝑁) = 1)
7670, 75eqtr3d 2205 . . . . . . . . . . . . 13 ((𝜑𝑥 ∈ (1...(ϕ‘𝑁))) → (𝑁 gcd (𝐹𝑥)) = 1)
77 rpmul 12052 . . . . . . . . . . . . . 14 ((𝑁 ∈ ℤ ∧ 𝐴 ∈ ℤ ∧ (𝐹𝑥) ∈ ℤ) → (((𝑁 gcd 𝐴) = 1 ∧ (𝑁 gcd (𝐹𝑥)) = 1) → (𝑁 gcd (𝐴 · (𝐹𝑥))) = 1))
7863, 48, 23, 77syl3anc 1233 . . . . . . . . . . . . 13 ((𝜑𝑥 ∈ (1...(ϕ‘𝑁))) → (((𝑁 gcd 𝐴) = 1 ∧ (𝑁 gcd (𝐹𝑥)) = 1) → (𝑁 gcd (𝐴 · (𝐹𝑥))) = 1))
7969, 76, 78mp2and 431 . . . . . . . . . . . 12 ((𝜑𝑥 ∈ (1...(ϕ‘𝑁))) → (𝑁 gcd (𝐴 · (𝐹𝑥))) = 1)
8062, 64, 793eqtr2d 2209 . . . . . . . . . . 11 ((𝜑𝑥 ∈ (1...(ϕ‘𝑁))) → (((𝐴 · (𝐹𝑥)) mod 𝑁) gcd 𝑁) = 1)
81 oveq1 5860 . . . . . . . . . . . . 13 (𝑦 = ((𝐴 · (𝐹𝑥)) mod 𝑁) → (𝑦 gcd 𝑁) = (((𝐴 · (𝐹𝑥)) mod 𝑁) gcd 𝑁))
8281eqeq1d 2179 . . . . . . . . . . . 12 (𝑦 = ((𝐴 · (𝐹𝑥)) mod 𝑁) → ((𝑦 gcd 𝑁) = 1 ↔ (((𝐴 · (𝐹𝑥)) mod 𝑁) gcd 𝑁) = 1))
8382, 2elrab2 2889 . . . . . . . . . . 11 (((𝐴 · (𝐹𝑥)) mod 𝑁) ∈ 𝑆 ↔ (((𝐴 · (𝐹𝑥)) mod 𝑁) ∈ (0..^𝑁) ∧ (((𝐴 · (𝐹𝑥)) mod 𝑁) gcd 𝑁) = 1))
8452, 80, 83sylanbrc 415 . . . . . . . . . 10 ((𝜑𝑥 ∈ (1...(ϕ‘𝑁))) → ((𝐴 · (𝐹𝑥)) mod 𝑁) ∈ 𝑆)
85 f1ocnvfv2 5757 . . . . . . . . . 10 ((𝐹:(1...(ϕ‘𝑁))–1-1-onto𝑆 ∧ ((𝐴 · (𝐹𝑥)) mod 𝑁) ∈ 𝑆) → (𝐹‘(𝐹‘((𝐴 · (𝐹𝑥)) mod 𝑁))) = ((𝐴 · (𝐹𝑥)) mod 𝑁))
8660, 84, 85syl2anc 409 . . . . . . . . 9 ((𝜑𝑥 ∈ (1...(ϕ‘𝑁))) → (𝐹‘(𝐹‘((𝐴 · (𝐹𝑥)) mod 𝑁))) = ((𝐴 · (𝐹𝑥)) mod 𝑁))
8786prodeq2dv 11529 . . . . . . . 8 (𝜑 → ∏𝑥 ∈ (1...(ϕ‘𝑁))(𝐹‘(𝐹‘((𝐴 · (𝐹𝑥)) mod 𝑁))) = ∏𝑥 ∈ (1...(ϕ‘𝑁))((𝐴 · (𝐹𝑥)) mod 𝑁))
8859, 87eqtr2d 2204 . . . . . . 7 (𝜑 → ∏𝑥 ∈ (1...(ϕ‘𝑁))((𝐴 · (𝐹𝑥)) mod 𝑁) = ∏𝑧 ∈ (1...(ϕ‘𝑁))(𝐹𝑧))
89 fveq2 5496 . . . . . . . . 9 (𝑧 = 𝑥 → (𝐹𝑧) = (𝐹𝑥))
9089cbvprodv 11522 . . . . . . . 8 𝑧 ∈ (1...(ϕ‘𝑁))(𝐹𝑧) = ∏𝑥 ∈ (1...(ϕ‘𝑁))(𝐹𝑥)
9190, 24eqeltrid 2257 . . . . . . 7 (𝜑 → ∏𝑧 ∈ (1...(ϕ‘𝑁))(𝐹𝑧) ∈ ℤ)
9288, 91eqeltrd 2247 . . . . . 6 (𝜑 → ∏𝑥 ∈ (1...(ϕ‘𝑁))((𝐴 · (𝐹𝑥)) mod 𝑁) ∈ ℤ)
93 moddvds 11761 . . . . . 6 ((𝑁 ∈ ℕ ∧ ((𝐴↑(ϕ‘𝑁)) · ∏𝑥 ∈ (1...(ϕ‘𝑁))(𝐹𝑥)) ∈ ℤ ∧ ∏𝑥 ∈ (1...(ϕ‘𝑁))((𝐴 · (𝐹𝑥)) mod 𝑁) ∈ ℤ) → ((((𝐴↑(ϕ‘𝑁)) · ∏𝑥 ∈ (1...(ϕ‘𝑁))(𝐹𝑥)) mod 𝑁) = (∏𝑥 ∈ (1...(ϕ‘𝑁))((𝐴 · (𝐹𝑥)) mod 𝑁) mod 𝑁) ↔ 𝑁 ∥ (((𝐴↑(ϕ‘𝑁)) · ∏𝑥 ∈ (1...(ϕ‘𝑁))(𝐹𝑥)) − ∏𝑥 ∈ (1...(ϕ‘𝑁))((𝐴 · (𝐹𝑥)) mod 𝑁))))
945, 25, 92, 93syl3anc 1233 . . . . 5 (𝜑 → ((((𝐴↑(ϕ‘𝑁)) · ∏𝑥 ∈ (1...(ϕ‘𝑁))(𝐹𝑥)) mod 𝑁) = (∏𝑥 ∈ (1...(ϕ‘𝑁))((𝐴 · (𝐹𝑥)) mod 𝑁) mod 𝑁) ↔ 𝑁 ∥ (((𝐴↑(ϕ‘𝑁)) · ∏𝑥 ∈ (1...(ϕ‘𝑁))(𝐹𝑥)) − ∏𝑥 ∈ (1...(ϕ‘𝑁))((𝐴 · (𝐹𝑥)) mod 𝑁))))
954, 94mpbid 146 . . . 4 (𝜑𝑁 ∥ (((𝐴↑(ϕ‘𝑁)) · ∏𝑥 ∈ (1...(ϕ‘𝑁))(𝐹𝑥)) − ∏𝑥 ∈ (1...(ϕ‘𝑁))((𝐴 · (𝐹𝑥)) mod 𝑁)))
9624zcnd 9335 . . . . . . . 8 (𝜑 → ∏𝑥 ∈ (1...(ϕ‘𝑁))(𝐹𝑥) ∈ ℂ)
9796mulid2d 7938 . . . . . . 7 (𝜑 → (1 · ∏𝑥 ∈ (1...(ϕ‘𝑁))(𝐹𝑥)) = ∏𝑥 ∈ (1...(ϕ‘𝑁))(𝐹𝑥))
9890, 88, 973eqtr4a 2229 . . . . . 6 (𝜑 → ∏𝑥 ∈ (1...(ϕ‘𝑁))((𝐴 · (𝐹𝑥)) mod 𝑁) = (1 · ∏𝑥 ∈ (1...(ϕ‘𝑁))(𝐹𝑥)))
9998oveq2d 5869 . . . . 5 (𝜑 → (((𝐴↑(ϕ‘𝑁)) · ∏𝑥 ∈ (1...(ϕ‘𝑁))(𝐹𝑥)) − ∏𝑥 ∈ (1...(ϕ‘𝑁))((𝐴 · (𝐹𝑥)) mod 𝑁)) = (((𝐴↑(ϕ‘𝑁)) · ∏𝑥 ∈ (1...(ϕ‘𝑁))(𝐹𝑥)) − (1 · ∏𝑥 ∈ (1...(ϕ‘𝑁))(𝐹𝑥))))
10010zcnd 9335 . . . . . 6 (𝜑 → (𝐴↑(ϕ‘𝑁)) ∈ ℂ)
101 ax-1cn 7867 . . . . . . 7 1 ∈ ℂ
102 subdir 8305 . . . . . . 7 (((𝐴↑(ϕ‘𝑁)) ∈ ℂ ∧ 1 ∈ ℂ ∧ ∏𝑥 ∈ (1...(ϕ‘𝑁))(𝐹𝑥) ∈ ℂ) → (((𝐴↑(ϕ‘𝑁)) − 1) · ∏𝑥 ∈ (1...(ϕ‘𝑁))(𝐹𝑥)) = (((𝐴↑(ϕ‘𝑁)) · ∏𝑥 ∈ (1...(ϕ‘𝑁))(𝐹𝑥)) − (1 · ∏𝑥 ∈ (1...(ϕ‘𝑁))(𝐹𝑥))))
103101, 102mp3an2 1320 . . . . . 6 (((𝐴↑(ϕ‘𝑁)) ∈ ℂ ∧ ∏𝑥 ∈ (1...(ϕ‘𝑁))(𝐹𝑥) ∈ ℂ) → (((𝐴↑(ϕ‘𝑁)) − 1) · ∏𝑥 ∈ (1...(ϕ‘𝑁))(𝐹𝑥)) = (((𝐴↑(ϕ‘𝑁)) · ∏𝑥 ∈ (1...(ϕ‘𝑁))(𝐹𝑥)) − (1 · ∏𝑥 ∈ (1...(ϕ‘𝑁))(𝐹𝑥))))
104100, 96, 103syl2anc 409 . . . . 5 (𝜑 → (((𝐴↑(ϕ‘𝑁)) − 1) · ∏𝑥 ∈ (1...(ϕ‘𝑁))(𝐹𝑥)) = (((𝐴↑(ϕ‘𝑁)) · ∏𝑥 ∈ (1...(ϕ‘𝑁))(𝐹𝑥)) − (1 · ∏𝑥 ∈ (1...(ϕ‘𝑁))(𝐹𝑥))))
10510, 11zsubcld 9339 . . . . . . 7 (𝜑 → ((𝐴↑(ϕ‘𝑁)) − 1) ∈ ℤ)
106105zcnd 9335 . . . . . 6 (𝜑 → ((𝐴↑(ϕ‘𝑁)) − 1) ∈ ℂ)
107106, 96mulcomd 7941 . . . . 5 (𝜑 → (((𝐴↑(ϕ‘𝑁)) − 1) · ∏𝑥 ∈ (1...(ϕ‘𝑁))(𝐹𝑥)) = (∏𝑥 ∈ (1...(ϕ‘𝑁))(𝐹𝑥) · ((𝐴↑(ϕ‘𝑁)) − 1)))
10899, 104, 1073eqtr2d 2209 . . . 4 (𝜑 → (((𝐴↑(ϕ‘𝑁)) · ∏𝑥 ∈ (1...(ϕ‘𝑁))(𝐹𝑥)) − ∏𝑥 ∈ (1...(ϕ‘𝑁))((𝐴 · (𝐹𝑥)) mod 𝑁)) = (∏𝑥 ∈ (1...(ϕ‘𝑁))(𝐹𝑥) · ((𝐴↑(ϕ‘𝑁)) − 1)))
10995, 108breqtrd 4015 . . 3 (𝜑𝑁 ∥ (∏𝑥 ∈ (1...(ϕ‘𝑁))(𝐹𝑥) · ((𝐴↑(ϕ‘𝑁)) − 1)))
1101, 2, 3eulerthlemrprm 12183 . . 3 (𝜑 → (𝑁 gcd ∏𝑥 ∈ (1...(ϕ‘𝑁))(𝐹𝑥)) = 1)
111 coprmdvds 12046 . . . 4 ((𝑁 ∈ ℤ ∧ ∏𝑥 ∈ (1...(ϕ‘𝑁))(𝐹𝑥) ∈ ℤ ∧ ((𝐴↑(ϕ‘𝑁)) − 1) ∈ ℤ) → ((𝑁 ∥ (∏𝑥 ∈ (1...(ϕ‘𝑁))(𝐹𝑥) · ((𝐴↑(ϕ‘𝑁)) − 1)) ∧ (𝑁 gcd ∏𝑥 ∈ (1...(ϕ‘𝑁))(𝐹𝑥)) = 1) → 𝑁 ∥ ((𝐴↑(ϕ‘𝑁)) − 1)))
11265, 24, 105, 111syl3anc 1233 . . 3 (𝜑 → ((𝑁 ∥ (∏𝑥 ∈ (1...(ϕ‘𝑁))(𝐹𝑥) · ((𝐴↑(ϕ‘𝑁)) − 1)) ∧ (𝑁 gcd ∏𝑥 ∈ (1...(ϕ‘𝑁))(𝐹𝑥)) = 1) → 𝑁 ∥ ((𝐴↑(ϕ‘𝑁)) − 1)))
113109, 110, 112mp2and 431 . 2 (𝜑𝑁 ∥ ((𝐴↑(ϕ‘𝑁)) − 1))
114 1z 9238 . . . 4 1 ∈ ℤ
115 moddvds 11761 . . . 4 ((𝑁 ∈ ℕ ∧ (𝐴↑(ϕ‘𝑁)) ∈ ℤ ∧ 1 ∈ ℤ) → (((𝐴↑(ϕ‘𝑁)) mod 𝑁) = (1 mod 𝑁) ↔ 𝑁 ∥ ((𝐴↑(ϕ‘𝑁)) − 1)))
116114, 115mp3an3 1321 . . 3 ((𝑁 ∈ ℕ ∧ (𝐴↑(ϕ‘𝑁)) ∈ ℤ) → (((𝐴↑(ϕ‘𝑁)) mod 𝑁) = (1 mod 𝑁) ↔ 𝑁 ∥ ((𝐴↑(ϕ‘𝑁)) − 1)))
1175, 10, 116syl2anc 409 . 2 (𝜑 → (((𝐴↑(ϕ‘𝑁)) mod 𝑁) = (1 mod 𝑁) ↔ 𝑁 ∥ ((𝐴↑(ϕ‘𝑁)) − 1)))
118113, 117mpbird 166 1 (𝜑 → ((𝐴↑(ϕ‘𝑁)) mod 𝑁) = (1 mod 𝑁))
Colors of variables: wff set class
Syntax hints:  wi 4  wa 103  wb 104  w3a 973   = wceq 1348  wcel 2141  {crab 2452   class class class wbr 3989  cmpt 4050  ccnv 4610  ccom 4615  wf 5194  1-1-ontowf1o 5197  cfv 5198  (class class class)co 5853  cc 7772  0cc0 7774  1c1 7775   · cmul 7779  cmin 8090  cn 8878  0cn0 9135  cz 9212  ...cfz 9965  ..^cfzo 10098   mod cmo 10278  cexp 10475  cprod 11513  cdvds 11749   gcd cgcd 11897  ϕcphi 12163
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-ia1 105  ax-ia2 106  ax-ia3 107  ax-in1 609  ax-in2 610  ax-io 704  ax-5 1440  ax-7 1441  ax-gen 1442  ax-ie1 1486  ax-ie2 1487  ax-8 1497  ax-10 1498  ax-11 1499  ax-i12 1500  ax-bndl 1502  ax-4 1503  ax-17 1519  ax-i9 1523  ax-ial 1527  ax-i5r 1528  ax-13 2143  ax-14 2144  ax-ext 2152  ax-coll 4104  ax-sep 4107  ax-nul 4115  ax-pow 4160  ax-pr 4194  ax-un 4418  ax-setind 4521  ax-iinf 4572  ax-cnex 7865  ax-resscn 7866  ax-1cn 7867  ax-1re 7868  ax-icn 7869  ax-addcl 7870  ax-addrcl 7871  ax-mulcl 7872  ax-mulrcl 7873  ax-addcom 7874  ax-mulcom 7875  ax-addass 7876  ax-mulass 7877  ax-distr 7878  ax-i2m1 7879  ax-0lt1 7880  ax-1rid 7881  ax-0id 7882  ax-rnegex 7883  ax-precex 7884  ax-cnre 7885  ax-pre-ltirr 7886  ax-pre-ltwlin 7887  ax-pre-lttrn 7888  ax-pre-apti 7889  ax-pre-ltadd 7890  ax-pre-mulgt0 7891  ax-pre-mulext 7892  ax-arch 7893  ax-caucvg 7894
This theorem depends on definitions:  df-bi 116  df-stab 826  df-dc 830  df-3or 974  df-3an 975  df-tru 1351  df-fal 1354  df-nf 1454  df-sb 1756  df-eu 2022  df-mo 2023  df-clab 2157  df-cleq 2163  df-clel 2166  df-nfc 2301  df-ne 2341  df-nel 2436  df-ral 2453  df-rex 2454  df-reu 2455  df-rmo 2456  df-rab 2457  df-v 2732  df-sbc 2956  df-csb 3050  df-dif 3123  df-un 3125  df-in 3127  df-ss 3134  df-nul 3415  df-if 3527  df-pw 3568  df-sn 3589  df-pr 3590  df-op 3592  df-uni 3797  df-int 3832  df-iun 3875  df-br 3990  df-opab 4051  df-mpt 4052  df-tr 4088  df-id 4278  df-po 4281  df-iso 4282  df-iord 4351  df-on 4353  df-ilim 4354  df-suc 4356  df-iom 4575  df-xp 4617  df-rel 4618  df-cnv 4619  df-co 4620  df-dm 4621  df-rn 4622  df-res 4623  df-ima 4624  df-iota 5160  df-fun 5200  df-fn 5201  df-f 5202  df-f1 5203  df-fo 5204  df-f1o 5205  df-fv 5206  df-isom 5207  df-riota 5809  df-ov 5856  df-oprab 5857  df-mpo 5858  df-1st 6119  df-2nd 6120  df-recs 6284  df-irdg 6349  df-frec 6370  df-1o 6395  df-oadd 6399  df-er 6513  df-en 6719  df-dom 6720  df-fin 6721  df-sup 6961  df-pnf 7956  df-mnf 7957  df-xr 7958  df-ltxr 7959  df-le 7960  df-sub 8092  df-neg 8093  df-reap 8494  df-ap 8501  df-div 8590  df-inn 8879  df-2 8937  df-3 8938  df-4 8939  df-n0 9136  df-z 9213  df-uz 9488  df-q 9579  df-rp 9611  df-fz 9966  df-fzo 10099  df-fl 10226  df-mod 10279  df-seqfrec 10402  df-exp 10476  df-ihash 10710  df-cj 10806  df-re 10807  df-im 10808  df-rsqrt 10962  df-abs 10963  df-clim 11242  df-proddc 11514  df-dvds 11750  df-gcd 11898  df-phi 12165
This theorem is referenced by:  eulerth  12187
  Copyright terms: Public domain W3C validator