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

Theorem znf1o 20243
Description: The function 𝐹 enumerates all equivalence classes in ℤ/n for each 𝑛. When 𝑛 = 0, ℤ / 0ℤ = ℤ / {0} ≈ ℤ so we let 𝑊 = ℤ; otherwise 𝑊 = {0, ..., 𝑛 − 1} enumerates all the equivalence classes. (Contributed by Mario Carneiro, 15-Jun-2015.) (Revised by Mario Carneiro, 2-May-2016.) (Revised by AV, 13-Jun-2019.)
Hypotheses
Ref Expression
znf1o.y 𝑌 = (ℤ/nℤ‘𝑁)
znf1o.b 𝐵 = (Base‘𝑌)
znf1o.f 𝐹 = ((ℤRHom‘𝑌) ↾ 𝑊)
znf1o.w 𝑊 = if(𝑁 = 0, ℤ, (0..^𝑁))
Assertion
Ref Expression
znf1o (𝑁 ∈ ℕ0𝐹:𝑊1-1-onto𝐵)

Proof of Theorem znf1o
Dummy variables 𝑥 𝑦 𝑧 are mutually distinct and distinct from all other variables.
StepHypRef Expression
1 znf1o.y . . . . . . 7 𝑌 = (ℤ/nℤ‘𝑁)
21zncrng 20236 . . . . . 6 (𝑁 ∈ ℕ0𝑌 ∈ CRing)
3 crngring 19302 . . . . . 6 (𝑌 ∈ CRing → 𝑌 ∈ Ring)
4 eqid 2798 . . . . . . 7 (ℤRHom‘𝑌) = (ℤRHom‘𝑌)
54zrhrhm 20205 . . . . . 6 (𝑌 ∈ Ring → (ℤRHom‘𝑌) ∈ (ℤring RingHom 𝑌))
6 zringbas 20169 . . . . . . 7 ℤ = (Base‘ℤring)
7 znf1o.b . . . . . . 7 𝐵 = (Base‘𝑌)
86, 7rhmf 19474 . . . . . 6 ((ℤRHom‘𝑌) ∈ (ℤring RingHom 𝑌) → (ℤRHom‘𝑌):ℤ⟶𝐵)
92, 3, 5, 84syl 19 . . . . 5 (𝑁 ∈ ℕ0 → (ℤRHom‘𝑌):ℤ⟶𝐵)
10 znf1o.w . . . . . 6 𝑊 = if(𝑁 = 0, ℤ, (0..^𝑁))
11 sseq1 3940 . . . . . . 7 (ℤ = if(𝑁 = 0, ℤ, (0..^𝑁)) → (ℤ ⊆ ℤ ↔ if(𝑁 = 0, ℤ, (0..^𝑁)) ⊆ ℤ))
12 sseq1 3940 . . . . . . 7 ((0..^𝑁) = if(𝑁 = 0, ℤ, (0..^𝑁)) → ((0..^𝑁) ⊆ ℤ ↔ if(𝑁 = 0, ℤ, (0..^𝑁)) ⊆ ℤ))
13 ssid 3937 . . . . . . 7 ℤ ⊆ ℤ
14 elfzoelz 13033 . . . . . . . 8 (𝑥 ∈ (0..^𝑁) → 𝑥 ∈ ℤ)
1514ssriv 3919 . . . . . . 7 (0..^𝑁) ⊆ ℤ
1611, 12, 13, 15keephyp 4494 . . . . . 6 if(𝑁 = 0, ℤ, (0..^𝑁)) ⊆ ℤ
1710, 16eqsstri 3949 . . . . 5 𝑊 ⊆ ℤ
18 fssres 6518 . . . . 5 (((ℤRHom‘𝑌):ℤ⟶𝐵𝑊 ⊆ ℤ) → ((ℤRHom‘𝑌) ↾ 𝑊):𝑊𝐵)
199, 17, 18sylancl 589 . . . 4 (𝑁 ∈ ℕ0 → ((ℤRHom‘𝑌) ↾ 𝑊):𝑊𝐵)
20 znf1o.f . . . . 5 𝐹 = ((ℤRHom‘𝑌) ↾ 𝑊)
2120feq1i 6478 . . . 4 (𝐹:𝑊𝐵 ↔ ((ℤRHom‘𝑌) ↾ 𝑊):𝑊𝐵)
2219, 21sylibr 237 . . 3 (𝑁 ∈ ℕ0𝐹:𝑊𝐵)
2320fveq1i 6646 . . . . . . . 8 (𝐹𝑥) = (((ℤRHom‘𝑌) ↾ 𝑊)‘𝑥)
24 fvres 6664 . . . . . . . . 9 (𝑥𝑊 → (((ℤRHom‘𝑌) ↾ 𝑊)‘𝑥) = ((ℤRHom‘𝑌)‘𝑥))
2524ad2antrl 727 . . . . . . . 8 ((𝑁 ∈ ℕ0 ∧ (𝑥𝑊𝑦𝑊)) → (((ℤRHom‘𝑌) ↾ 𝑊)‘𝑥) = ((ℤRHom‘𝑌)‘𝑥))
2623, 25syl5eq 2845 . . . . . . 7 ((𝑁 ∈ ℕ0 ∧ (𝑥𝑊𝑦𝑊)) → (𝐹𝑥) = ((ℤRHom‘𝑌)‘𝑥))
2720fveq1i 6646 . . . . . . . 8 (𝐹𝑦) = (((ℤRHom‘𝑌) ↾ 𝑊)‘𝑦)
28 fvres 6664 . . . . . . . . 9 (𝑦𝑊 → (((ℤRHom‘𝑌) ↾ 𝑊)‘𝑦) = ((ℤRHom‘𝑌)‘𝑦))
2928ad2antll 728 . . . . . . . 8 ((𝑁 ∈ ℕ0 ∧ (𝑥𝑊𝑦𝑊)) → (((ℤRHom‘𝑌) ↾ 𝑊)‘𝑦) = ((ℤRHom‘𝑌)‘𝑦))
3027, 29syl5eq 2845 . . . . . . 7 ((𝑁 ∈ ℕ0 ∧ (𝑥𝑊𝑦𝑊)) → (𝐹𝑦) = ((ℤRHom‘𝑌)‘𝑦))
3126, 30eqeq12d 2814 . . . . . 6 ((𝑁 ∈ ℕ0 ∧ (𝑥𝑊𝑦𝑊)) → ((𝐹𝑥) = (𝐹𝑦) ↔ ((ℤRHom‘𝑌)‘𝑥) = ((ℤRHom‘𝑌)‘𝑦)))
32 simpl 486 . . . . . . 7 ((𝑁 ∈ ℕ0 ∧ (𝑥𝑊𝑦𝑊)) → 𝑁 ∈ ℕ0)
33 simprl 770 . . . . . . . 8 ((𝑁 ∈ ℕ0 ∧ (𝑥𝑊𝑦𝑊)) → 𝑥𝑊)
3417, 33sseldi 3913 . . . . . . 7 ((𝑁 ∈ ℕ0 ∧ (𝑥𝑊𝑦𝑊)) → 𝑥 ∈ ℤ)
35 simprr 772 . . . . . . . 8 ((𝑁 ∈ ℕ0 ∧ (𝑥𝑊𝑦𝑊)) → 𝑦𝑊)
3617, 35sseldi 3913 . . . . . . 7 ((𝑁 ∈ ℕ0 ∧ (𝑥𝑊𝑦𝑊)) → 𝑦 ∈ ℤ)
371, 4zndvds 20241 . . . . . . 7 ((𝑁 ∈ ℕ0𝑥 ∈ ℤ ∧ 𝑦 ∈ ℤ) → (((ℤRHom‘𝑌)‘𝑥) = ((ℤRHom‘𝑌)‘𝑦) ↔ 𝑁 ∥ (𝑥𝑦)))
3832, 34, 36, 37syl3anc 1368 . . . . . 6 ((𝑁 ∈ ℕ0 ∧ (𝑥𝑊𝑦𝑊)) → (((ℤRHom‘𝑌)‘𝑥) = ((ℤRHom‘𝑌)‘𝑦) ↔ 𝑁 ∥ (𝑥𝑦)))
39 elnn0 11887 . . . . . . 7 (𝑁 ∈ ℕ0 ↔ (𝑁 ∈ ℕ ∨ 𝑁 = 0))
40 simpl 486 . . . . . . . . . 10 ((𝑁 ∈ ℕ ∧ (𝑥𝑊𝑦𝑊)) → 𝑁 ∈ ℕ)
41 simprl 770 . . . . . . . . . . 11 ((𝑁 ∈ ℕ ∧ (𝑥𝑊𝑦𝑊)) → 𝑥𝑊)
4217, 41sseldi 3913 . . . . . . . . . 10 ((𝑁 ∈ ℕ ∧ (𝑥𝑊𝑦𝑊)) → 𝑥 ∈ ℤ)
43 simprr 772 . . . . . . . . . . 11 ((𝑁 ∈ ℕ ∧ (𝑥𝑊𝑦𝑊)) → 𝑦𝑊)
4417, 43sseldi 3913 . . . . . . . . . 10 ((𝑁 ∈ ℕ ∧ (𝑥𝑊𝑦𝑊)) → 𝑦 ∈ ℤ)
45 moddvds 15610 . . . . . . . . . 10 ((𝑁 ∈ ℕ ∧ 𝑥 ∈ ℤ ∧ 𝑦 ∈ ℤ) → ((𝑥 mod 𝑁) = (𝑦 mod 𝑁) ↔ 𝑁 ∥ (𝑥𝑦)))
4640, 42, 44, 45syl3anc 1368 . . . . . . . . 9 ((𝑁 ∈ ℕ ∧ (𝑥𝑊𝑦𝑊)) → ((𝑥 mod 𝑁) = (𝑦 mod 𝑁) ↔ 𝑁 ∥ (𝑥𝑦)))
4742zred 12075 . . . . . . . . . . 11 ((𝑁 ∈ ℕ ∧ (𝑥𝑊𝑦𝑊)) → 𝑥 ∈ ℝ)
48 nnrp 12388 . . . . . . . . . . . 12 (𝑁 ∈ ℕ → 𝑁 ∈ ℝ+)
4948adantr 484 . . . . . . . . . . 11 ((𝑁 ∈ ℕ ∧ (𝑥𝑊𝑦𝑊)) → 𝑁 ∈ ℝ+)
50 nnne0 11659 . . . . . . . . . . . . . . . 16 (𝑁 ∈ ℕ → 𝑁 ≠ 0)
51 ifnefalse 4437 . . . . . . . . . . . . . . . 16 (𝑁 ≠ 0 → if(𝑁 = 0, ℤ, (0..^𝑁)) = (0..^𝑁))
5250, 51syl 17 . . . . . . . . . . . . . . 15 (𝑁 ∈ ℕ → if(𝑁 = 0, ℤ, (0..^𝑁)) = (0..^𝑁))
5310, 52syl5eq 2845 . . . . . . . . . . . . . 14 (𝑁 ∈ ℕ → 𝑊 = (0..^𝑁))
5453adantr 484 . . . . . . . . . . . . 13 ((𝑁 ∈ ℕ ∧ (𝑥𝑊𝑦𝑊)) → 𝑊 = (0..^𝑁))
5541, 54eleqtrd 2892 . . . . . . . . . . . 12 ((𝑁 ∈ ℕ ∧ (𝑥𝑊𝑦𝑊)) → 𝑥 ∈ (0..^𝑁))
56 elfzole1 13041 . . . . . . . . . . . 12 (𝑥 ∈ (0..^𝑁) → 0 ≤ 𝑥)
5755, 56syl 17 . . . . . . . . . . 11 ((𝑁 ∈ ℕ ∧ (𝑥𝑊𝑦𝑊)) → 0 ≤ 𝑥)
58 elfzolt2 13042 . . . . . . . . . . . 12 (𝑥 ∈ (0..^𝑁) → 𝑥 < 𝑁)
5955, 58syl 17 . . . . . . . . . . 11 ((𝑁 ∈ ℕ ∧ (𝑥𝑊𝑦𝑊)) → 𝑥 < 𝑁)
60 modid 13259 . . . . . . . . . . 11 (((𝑥 ∈ ℝ ∧ 𝑁 ∈ ℝ+) ∧ (0 ≤ 𝑥𝑥 < 𝑁)) → (𝑥 mod 𝑁) = 𝑥)
6147, 49, 57, 59, 60syl22anc 837 . . . . . . . . . 10 ((𝑁 ∈ ℕ ∧ (𝑥𝑊𝑦𝑊)) → (𝑥 mod 𝑁) = 𝑥)
6244zred 12075 . . . . . . . . . . 11 ((𝑁 ∈ ℕ ∧ (𝑥𝑊𝑦𝑊)) → 𝑦 ∈ ℝ)
6343, 54eleqtrd 2892 . . . . . . . . . . . 12 ((𝑁 ∈ ℕ ∧ (𝑥𝑊𝑦𝑊)) → 𝑦 ∈ (0..^𝑁))
64 elfzole1 13041 . . . . . . . . . . . 12 (𝑦 ∈ (0..^𝑁) → 0 ≤ 𝑦)
6563, 64syl 17 . . . . . . . . . . 11 ((𝑁 ∈ ℕ ∧ (𝑥𝑊𝑦𝑊)) → 0 ≤ 𝑦)
66 elfzolt2 13042 . . . . . . . . . . . 12 (𝑦 ∈ (0..^𝑁) → 𝑦 < 𝑁)
6763, 66syl 17 . . . . . . . . . . 11 ((𝑁 ∈ ℕ ∧ (𝑥𝑊𝑦𝑊)) → 𝑦 < 𝑁)
68 modid 13259 . . . . . . . . . . 11 (((𝑦 ∈ ℝ ∧ 𝑁 ∈ ℝ+) ∧ (0 ≤ 𝑦𝑦 < 𝑁)) → (𝑦 mod 𝑁) = 𝑦)
6962, 49, 65, 67, 68syl22anc 837 . . . . . . . . . 10 ((𝑁 ∈ ℕ ∧ (𝑥𝑊𝑦𝑊)) → (𝑦 mod 𝑁) = 𝑦)
7061, 69eqeq12d 2814 . . . . . . . . 9 ((𝑁 ∈ ℕ ∧ (𝑥𝑊𝑦𝑊)) → ((𝑥 mod 𝑁) = (𝑦 mod 𝑁) ↔ 𝑥 = 𝑦))
7146, 70bitr3d 284 . . . . . . . 8 ((𝑁 ∈ ℕ ∧ (𝑥𝑊𝑦𝑊)) → (𝑁 ∥ (𝑥𝑦) ↔ 𝑥 = 𝑦))
72 simpl 486 . . . . . . . . . 10 ((𝑁 = 0 ∧ (𝑥𝑊𝑦𝑊)) → 𝑁 = 0)
7372breq1d 5040 . . . . . . . . 9 ((𝑁 = 0 ∧ (𝑥𝑊𝑦𝑊)) → (𝑁 ∥ (𝑥𝑦) ↔ 0 ∥ (𝑥𝑦)))
74 id 22 . . . . . . . . . . . . 13 (𝑁 = 0 → 𝑁 = 0)
75 0nn0 11900 . . . . . . . . . . . . 13 0 ∈ ℕ0
7674, 75eqeltrdi 2898 . . . . . . . . . . . 12 (𝑁 = 0 → 𝑁 ∈ ℕ0)
7776, 34sylan 583 . . . . . . . . . . 11 ((𝑁 = 0 ∧ (𝑥𝑊𝑦𝑊)) → 𝑥 ∈ ℤ)
7876, 36sylan 583 . . . . . . . . . . 11 ((𝑁 = 0 ∧ (𝑥𝑊𝑦𝑊)) → 𝑦 ∈ ℤ)
7977, 78zsubcld 12080 . . . . . . . . . 10 ((𝑁 = 0 ∧ (𝑥𝑊𝑦𝑊)) → (𝑥𝑦) ∈ ℤ)
80 0dvds 15622 . . . . . . . . . 10 ((𝑥𝑦) ∈ ℤ → (0 ∥ (𝑥𝑦) ↔ (𝑥𝑦) = 0))
8179, 80syl 17 . . . . . . . . 9 ((𝑁 = 0 ∧ (𝑥𝑊𝑦𝑊)) → (0 ∥ (𝑥𝑦) ↔ (𝑥𝑦) = 0))
8277zcnd 12076 . . . . . . . . . 10 ((𝑁 = 0 ∧ (𝑥𝑊𝑦𝑊)) → 𝑥 ∈ ℂ)
8378zcnd 12076 . . . . . . . . . 10 ((𝑁 = 0 ∧ (𝑥𝑊𝑦𝑊)) → 𝑦 ∈ ℂ)
8482, 83subeq0ad 10996 . . . . . . . . 9 ((𝑁 = 0 ∧ (𝑥𝑊𝑦𝑊)) → ((𝑥𝑦) = 0 ↔ 𝑥 = 𝑦))
8573, 81, 843bitrd 308 . . . . . . . 8 ((𝑁 = 0 ∧ (𝑥𝑊𝑦𝑊)) → (𝑁 ∥ (𝑥𝑦) ↔ 𝑥 = 𝑦))
8671, 85jaoian 954 . . . . . . 7 (((𝑁 ∈ ℕ ∨ 𝑁 = 0) ∧ (𝑥𝑊𝑦𝑊)) → (𝑁 ∥ (𝑥𝑦) ↔ 𝑥 = 𝑦))
8739, 86sylanb 584 . . . . . 6 ((𝑁 ∈ ℕ0 ∧ (𝑥𝑊𝑦𝑊)) → (𝑁 ∥ (𝑥𝑦) ↔ 𝑥 = 𝑦))
8831, 38, 873bitrd 308 . . . . 5 ((𝑁 ∈ ℕ0 ∧ (𝑥𝑊𝑦𝑊)) → ((𝐹𝑥) = (𝐹𝑦) ↔ 𝑥 = 𝑦))
8988biimpd 232 . . . 4 ((𝑁 ∈ ℕ0 ∧ (𝑥𝑊𝑦𝑊)) → ((𝐹𝑥) = (𝐹𝑦) → 𝑥 = 𝑦))
9089ralrimivva 3156 . . 3 (𝑁 ∈ ℕ0 → ∀𝑥𝑊𝑦𝑊 ((𝐹𝑥) = (𝐹𝑦) → 𝑥 = 𝑦))
91 dff13 6991 . . 3 (𝐹:𝑊1-1𝐵 ↔ (𝐹:𝑊𝐵 ∧ ∀𝑥𝑊𝑦𝑊 ((𝐹𝑥) = (𝐹𝑦) → 𝑥 = 𝑦)))
9222, 90, 91sylanbrc 586 . 2 (𝑁 ∈ ℕ0𝐹:𝑊1-1𝐵)
93 zmodfzo 13257 . . . . . . . . . . . 12 ((𝑧 ∈ ℤ ∧ 𝑁 ∈ ℕ) → (𝑧 mod 𝑁) ∈ (0..^𝑁))
9493ancoms 462 . . . . . . . . . . 11 ((𝑁 ∈ ℕ ∧ 𝑧 ∈ ℤ) → (𝑧 mod 𝑁) ∈ (0..^𝑁))
9553adantr 484 . . . . . . . . . . 11 ((𝑁 ∈ ℕ ∧ 𝑧 ∈ ℤ) → 𝑊 = (0..^𝑁))
9694, 95eleqtrrd 2893 . . . . . . . . . 10 ((𝑁 ∈ ℕ ∧ 𝑧 ∈ ℤ) → (𝑧 mod 𝑁) ∈ 𝑊)
97 zre 11973 . . . . . . . . . . . . . 14 (𝑧 ∈ ℤ → 𝑧 ∈ ℝ)
98 modabs2 13268 . . . . . . . . . . . . . 14 ((𝑧 ∈ ℝ ∧ 𝑁 ∈ ℝ+) → ((𝑧 mod 𝑁) mod 𝑁) = (𝑧 mod 𝑁))
9997, 48, 98syl2anr 599 . . . . . . . . . . . . 13 ((𝑁 ∈ ℕ ∧ 𝑧 ∈ ℤ) → ((𝑧 mod 𝑁) mod 𝑁) = (𝑧 mod 𝑁))
100 simpl 486 . . . . . . . . . . . . . 14 ((𝑁 ∈ ℕ ∧ 𝑧 ∈ ℤ) → 𝑁 ∈ ℕ)
10115, 94sseldi 3913 . . . . . . . . . . . . . 14 ((𝑁 ∈ ℕ ∧ 𝑧 ∈ ℤ) → (𝑧 mod 𝑁) ∈ ℤ)
102 simpr 488 . . . . . . . . . . . . . 14 ((𝑁 ∈ ℕ ∧ 𝑧 ∈ ℤ) → 𝑧 ∈ ℤ)
103 moddvds 15610 . . . . . . . . . . . . . 14 ((𝑁 ∈ ℕ ∧ (𝑧 mod 𝑁) ∈ ℤ ∧ 𝑧 ∈ ℤ) → (((𝑧 mod 𝑁) mod 𝑁) = (𝑧 mod 𝑁) ↔ 𝑁 ∥ ((𝑧 mod 𝑁) − 𝑧)))
104100, 101, 102, 103syl3anc 1368 . . . . . . . . . . . . 13 ((𝑁 ∈ ℕ ∧ 𝑧 ∈ ℤ) → (((𝑧 mod 𝑁) mod 𝑁) = (𝑧 mod 𝑁) ↔ 𝑁 ∥ ((𝑧 mod 𝑁) − 𝑧)))
10599, 104mpbid 235 . . . . . . . . . . . 12 ((𝑁 ∈ ℕ ∧ 𝑧 ∈ ℤ) → 𝑁 ∥ ((𝑧 mod 𝑁) − 𝑧))
106 nnnn0 11892 . . . . . . . . . . . . . 14 (𝑁 ∈ ℕ → 𝑁 ∈ ℕ0)
107106adantr 484 . . . . . . . . . . . . 13 ((𝑁 ∈ ℕ ∧ 𝑧 ∈ ℤ) → 𝑁 ∈ ℕ0)
1081, 4zndvds 20241 . . . . . . . . . . . . 13 ((𝑁 ∈ ℕ0 ∧ (𝑧 mod 𝑁) ∈ ℤ ∧ 𝑧 ∈ ℤ) → (((ℤRHom‘𝑌)‘(𝑧 mod 𝑁)) = ((ℤRHom‘𝑌)‘𝑧) ↔ 𝑁 ∥ ((𝑧 mod 𝑁) − 𝑧)))
109107, 101, 102, 108syl3anc 1368 . . . . . . . . . . . 12 ((𝑁 ∈ ℕ ∧ 𝑧 ∈ ℤ) → (((ℤRHom‘𝑌)‘(𝑧 mod 𝑁)) = ((ℤRHom‘𝑌)‘𝑧) ↔ 𝑁 ∥ ((𝑧 mod 𝑁) − 𝑧)))
110105, 109mpbird 260 . . . . . . . . . . 11 ((𝑁 ∈ ℕ ∧ 𝑧 ∈ ℤ) → ((ℤRHom‘𝑌)‘(𝑧 mod 𝑁)) = ((ℤRHom‘𝑌)‘𝑧))
111110eqcomd 2804 . . . . . . . . . 10 ((𝑁 ∈ ℕ ∧ 𝑧 ∈ ℤ) → ((ℤRHom‘𝑌)‘𝑧) = ((ℤRHom‘𝑌)‘(𝑧 mod 𝑁)))
112 fveq2 6645 . . . . . . . . . . 11 (𝑦 = (𝑧 mod 𝑁) → ((ℤRHom‘𝑌)‘𝑦) = ((ℤRHom‘𝑌)‘(𝑧 mod 𝑁)))
113112rspceeqv 3586 . . . . . . . . . 10 (((𝑧 mod 𝑁) ∈ 𝑊 ∧ ((ℤRHom‘𝑌)‘𝑧) = ((ℤRHom‘𝑌)‘(𝑧 mod 𝑁))) → ∃𝑦𝑊 ((ℤRHom‘𝑌)‘𝑧) = ((ℤRHom‘𝑌)‘𝑦))
11496, 111, 113syl2anc 587 . . . . . . . . 9 ((𝑁 ∈ ℕ ∧ 𝑧 ∈ ℤ) → ∃𝑦𝑊 ((ℤRHom‘𝑌)‘𝑧) = ((ℤRHom‘𝑌)‘𝑦))
115 iftrue 4431 . . . . . . . . . . . . 13 (𝑁 = 0 → if(𝑁 = 0, ℤ, (0..^𝑁)) = ℤ)
116115eleq2d 2875 . . . . . . . . . . . 12 (𝑁 = 0 → (𝑧 ∈ if(𝑁 = 0, ℤ, (0..^𝑁)) ↔ 𝑧 ∈ ℤ))
117116biimpar 481 . . . . . . . . . . 11 ((𝑁 = 0 ∧ 𝑧 ∈ ℤ) → 𝑧 ∈ if(𝑁 = 0, ℤ, (0..^𝑁)))
118117, 10eleqtrrdi 2901 . . . . . . . . . 10 ((𝑁 = 0 ∧ 𝑧 ∈ ℤ) → 𝑧𝑊)
119 eqidd 2799 . . . . . . . . . 10 ((𝑁 = 0 ∧ 𝑧 ∈ ℤ) → ((ℤRHom‘𝑌)‘𝑧) = ((ℤRHom‘𝑌)‘𝑧))
120 fveq2 6645 . . . . . . . . . . 11 (𝑦 = 𝑧 → ((ℤRHom‘𝑌)‘𝑦) = ((ℤRHom‘𝑌)‘𝑧))
121120rspceeqv 3586 . . . . . . . . . 10 ((𝑧𝑊 ∧ ((ℤRHom‘𝑌)‘𝑧) = ((ℤRHom‘𝑌)‘𝑧)) → ∃𝑦𝑊 ((ℤRHom‘𝑌)‘𝑧) = ((ℤRHom‘𝑌)‘𝑦))
122118, 119, 121syl2anc 587 . . . . . . . . 9 ((𝑁 = 0 ∧ 𝑧 ∈ ℤ) → ∃𝑦𝑊 ((ℤRHom‘𝑌)‘𝑧) = ((ℤRHom‘𝑌)‘𝑦))
123114, 122jaoian 954 . . . . . . . 8 (((𝑁 ∈ ℕ ∨ 𝑁 = 0) ∧ 𝑧 ∈ ℤ) → ∃𝑦𝑊 ((ℤRHom‘𝑌)‘𝑧) = ((ℤRHom‘𝑌)‘𝑦))
12439, 123sylanb 584 . . . . . . 7 ((𝑁 ∈ ℕ0𝑧 ∈ ℤ) → ∃𝑦𝑊 ((ℤRHom‘𝑌)‘𝑧) = ((ℤRHom‘𝑌)‘𝑦))
12527, 28syl5eq 2845 . . . . . . . . 9 (𝑦𝑊 → (𝐹𝑦) = ((ℤRHom‘𝑌)‘𝑦))
126125eqeq2d 2809 . . . . . . . 8 (𝑦𝑊 → (((ℤRHom‘𝑌)‘𝑧) = (𝐹𝑦) ↔ ((ℤRHom‘𝑌)‘𝑧) = ((ℤRHom‘𝑌)‘𝑦)))
127126rexbiia 3209 . . . . . . 7 (∃𝑦𝑊 ((ℤRHom‘𝑌)‘𝑧) = (𝐹𝑦) ↔ ∃𝑦𝑊 ((ℤRHom‘𝑌)‘𝑧) = ((ℤRHom‘𝑌)‘𝑦))
128124, 127sylibr 237 . . . . . 6 ((𝑁 ∈ ℕ0𝑧 ∈ ℤ) → ∃𝑦𝑊 ((ℤRHom‘𝑌)‘𝑧) = (𝐹𝑦))
129128ralrimiva 3149 . . . . 5 (𝑁 ∈ ℕ0 → ∀𝑧 ∈ ℤ ∃𝑦𝑊 ((ℤRHom‘𝑌)‘𝑧) = (𝐹𝑦))
1301, 7, 4znzrhfo 20239 . . . . . 6 (𝑁 ∈ ℕ0 → (ℤRHom‘𝑌):ℤ–onto𝐵)
131 fofn 6567 . . . . . 6 ((ℤRHom‘𝑌):ℤ–onto𝐵 → (ℤRHom‘𝑌) Fn ℤ)
132 eqeq1 2802 . . . . . . . 8 (𝑥 = ((ℤRHom‘𝑌)‘𝑧) → (𝑥 = (𝐹𝑦) ↔ ((ℤRHom‘𝑌)‘𝑧) = (𝐹𝑦)))
133132rexbidv 3256 . . . . . . 7 (𝑥 = ((ℤRHom‘𝑌)‘𝑧) → (∃𝑦𝑊 𝑥 = (𝐹𝑦) ↔ ∃𝑦𝑊 ((ℤRHom‘𝑌)‘𝑧) = (𝐹𝑦)))
134133ralrn 6831 . . . . . 6 ((ℤRHom‘𝑌) Fn ℤ → (∀𝑥 ∈ ran (ℤRHom‘𝑌)∃𝑦𝑊 𝑥 = (𝐹𝑦) ↔ ∀𝑧 ∈ ℤ ∃𝑦𝑊 ((ℤRHom‘𝑌)‘𝑧) = (𝐹𝑦)))
135130, 131, 1343syl 18 . . . . 5 (𝑁 ∈ ℕ0 → (∀𝑥 ∈ ran (ℤRHom‘𝑌)∃𝑦𝑊 𝑥 = (𝐹𝑦) ↔ ∀𝑧 ∈ ℤ ∃𝑦𝑊 ((ℤRHom‘𝑌)‘𝑧) = (𝐹𝑦)))
136129, 135mpbird 260 . . . 4 (𝑁 ∈ ℕ0 → ∀𝑥 ∈ ran (ℤRHom‘𝑌)∃𝑦𝑊 𝑥 = (𝐹𝑦))
137 forn 6568 . . . . . 6 ((ℤRHom‘𝑌):ℤ–onto𝐵 → ran (ℤRHom‘𝑌) = 𝐵)
138130, 137syl 17 . . . . 5 (𝑁 ∈ ℕ0 → ran (ℤRHom‘𝑌) = 𝐵)
139138raleqdv 3364 . . . 4 (𝑁 ∈ ℕ0 → (∀𝑥 ∈ ran (ℤRHom‘𝑌)∃𝑦𝑊 𝑥 = (𝐹𝑦) ↔ ∀𝑥𝐵𝑦𝑊 𝑥 = (𝐹𝑦)))
140136, 139mpbid 235 . . 3 (𝑁 ∈ ℕ0 → ∀𝑥𝐵𝑦𝑊 𝑥 = (𝐹𝑦))
141 dffo3 6845 . . 3 (𝐹:𝑊onto𝐵 ↔ (𝐹:𝑊𝐵 ∧ ∀𝑥𝐵𝑦𝑊 𝑥 = (𝐹𝑦)))
14222, 140, 141sylanbrc 586 . 2 (𝑁 ∈ ℕ0𝐹:𝑊onto𝐵)
143 df-f1o 6331 . 2 (𝐹:𝑊1-1-onto𝐵 ↔ (𝐹:𝑊1-1𝐵𝐹:𝑊onto𝐵))
14492, 142, 143sylanbrc 586 1 (𝑁 ∈ ℕ0𝐹:𝑊1-1-onto𝐵)
Colors of variables: wff setvar class
Syntax hints:  wi 4  wb 209  wa 399  wo 844   = wceq 1538  wcel 2111  wne 2987  wral 3106  wrex 3107  wss 3881  ifcif 4425   class class class wbr 5030  ran crn 5520  cres 5521   Fn wfn 6319  wf 6320  1-1wf1 6321  ontowfo 6322  1-1-ontowf1o 6323  cfv 6324  (class class class)co 7135  cr 10525  0cc0 10526   < clt 10664  cle 10665  cmin 10859  cn 11625  0cn0 11885  cz 11969  +crp 12377  ..^cfzo 13028   mod cmo 13232  cdvds 15599  Basecbs 16475  Ringcrg 19290  CRingccrg 19291   RingHom crh 19460  ringzring 20163  ℤRHomczrh 20193  ℤ/nczn 20196
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-3 8  ax-gen 1797  ax-4 1811  ax-5 1911  ax-6 1970  ax-7 2015  ax-8 2113  ax-9 2121  ax-10 2142  ax-11 2158  ax-12 2175  ax-ext 2770  ax-rep 5154  ax-sep 5167  ax-nul 5174  ax-pow 5231  ax-pr 5295  ax-un 7441  ax-cnex 10582  ax-resscn 10583  ax-1cn 10584  ax-icn 10585  ax-addcl 10586  ax-addrcl 10587  ax-mulcl 10588  ax-mulrcl 10589  ax-mulcom 10590  ax-addass 10591  ax-mulass 10592  ax-distr 10593  ax-i2m1 10594  ax-1ne0 10595  ax-1rid 10596  ax-rnegex 10597  ax-rrecex 10598  ax-cnre 10599  ax-pre-lttri 10600  ax-pre-lttrn 10601  ax-pre-ltadd 10602  ax-pre-mulgt0 10603  ax-pre-sup 10604  ax-addf 10605  ax-mulf 10606
This theorem depends on definitions:  df-bi 210  df-an 400  df-or 845  df-3or 1085  df-3an 1086  df-tru 1541  df-ex 1782  df-nf 1786  df-sb 2070  df-mo 2598  df-eu 2629  df-clab 2777  df-cleq 2791  df-clel 2870  df-nfc 2938  df-ne 2988  df-nel 3092  df-ral 3111  df-rex 3112  df-reu 3113  df-rmo 3114  df-rab 3115  df-v 3443  df-sbc 3721  df-csb 3829  df-dif 3884  df-un 3886  df-in 3888  df-ss 3898  df-pss 3900  df-nul 4244  df-if 4426  df-pw 4499  df-sn 4526  df-pr 4528  df-tp 4530  df-op 4532  df-uni 4801  df-int 4839  df-iun 4883  df-br 5031  df-opab 5093  df-mpt 5111  df-tr 5137  df-id 5425  df-eprel 5430  df-po 5438  df-so 5439  df-fr 5478  df-we 5480  df-xp 5525  df-rel 5526  df-cnv 5527  df-co 5528  df-dm 5529  df-rn 5530  df-res 5531  df-ima 5532  df-pred 6116  df-ord 6162  df-on 6163  df-lim 6164  df-suc 6165  df-iota 6283  df-fun 6326  df-fn 6327  df-f 6328  df-f1 6329  df-fo 6330  df-f1o 6331  df-fv 6332  df-riota 7093  df-ov 7138  df-oprab 7139  df-mpo 7140  df-om 7561  df-1st 7671  df-2nd 7672  df-tpos 7875  df-wrecs 7930  df-recs 7991  df-rdg 8029  df-1o 8085  df-oadd 8089  df-er 8272  df-ec 8274  df-qs 8278  df-map 8391  df-en 8493  df-dom 8494  df-sdom 8495  df-fin 8496  df-sup 8890  df-inf 8891  df-pnf 10666  df-mnf 10667  df-xr 10668  df-ltxr 10669  df-le 10670  df-sub 10861  df-neg 10862  df-div 11287  df-nn 11626  df-2 11688  df-3 11689  df-4 11690  df-5 11691  df-6 11692  df-7 11693  df-8 11694  df-9 11695  df-n0 11886  df-z 11970  df-dec 12087  df-uz 12232  df-rp 12378  df-fz 12886  df-fzo 13029  df-fl 13157  df-mod 13233  df-seq 13365  df-dvds 15600  df-struct 16477  df-ndx 16478  df-slot 16479  df-base 16481  df-sets 16482  df-ress 16483  df-plusg 16570  df-mulr 16571  df-starv 16572  df-sca 16573  df-vsca 16574  df-ip 16575  df-tset 16576  df-ple 16577  df-ds 16579  df-unif 16580  df-0g 16707  df-imas 16773  df-qus 16774  df-mgm 17844  df-sgrp 17893  df-mnd 17904  df-mhm 17948  df-grp 18098  df-minusg 18099  df-sbg 18100  df-mulg 18217  df-subg 18268  df-nsg 18269  df-eqg 18270  df-ghm 18348  df-cmn 18900  df-abl 18901  df-mgp 19233  df-ur 19245  df-ring 19292  df-cring 19293  df-oppr 19369  df-dvdsr 19387  df-rnghom 19463  df-subrg 19526  df-lmod 19629  df-lss 19697  df-lsp 19737  df-sra 19937  df-rgmod 19938  df-lidl 19939  df-rsp 19940  df-2idl 19998  df-cnfld 20092  df-zring 20164  df-zrh 20197  df-zn 20200
This theorem is referenced by:  zzngim  20244  znleval  20246  zntoslem  20248  znhash  20250  znunithash  20256  dchrisumlem1  26073
  Copyright terms: Public domain W3C validator