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

Theorem znunithash 20501
Description: The size of the unit group of ℤ/n. (Contributed by Mario Carneiro, 19-Apr-2016.)
Hypotheses
Ref Expression
znchr.y 𝑌 = (ℤ/nℤ‘𝑁)
znunit.u 𝑈 = (Unit‘𝑌)
Assertion
Ref Expression
znunithash (𝑁 ∈ ℕ → (♯‘𝑈) = (ϕ‘𝑁))

Proof of Theorem znunithash
Dummy variable 𝑥 is distinct from all other variables.
StepHypRef Expression
1 dfphi2 16308 . 2 (𝑁 ∈ ℕ → (ϕ‘𝑁) = (♯‘{𝑥 ∈ (0..^𝑁) ∣ (𝑥 gcd 𝑁) = 1}))
2 nnnn0 12080 . . . . . . . . 9 (𝑁 ∈ ℕ → 𝑁 ∈ ℕ0)
3 znchr.y . . . . . . . . . 10 𝑌 = (ℤ/nℤ‘𝑁)
4 eqid 2734 . . . . . . . . . 10 (Base‘𝑌) = (Base‘𝑌)
5 eqid 2734 . . . . . . . . . 10 ((ℤRHom‘𝑌) ↾ if(𝑁 = 0, ℤ, (0..^𝑁))) = ((ℤRHom‘𝑌) ↾ if(𝑁 = 0, ℤ, (0..^𝑁)))
6 eqid 2734 . . . . . . . . . 10 if(𝑁 = 0, ℤ, (0..^𝑁)) = if(𝑁 = 0, ℤ, (0..^𝑁))
73, 4, 5, 6znf1o 20488 . . . . . . . . 9 (𝑁 ∈ ℕ0 → ((ℤRHom‘𝑌) ↾ if(𝑁 = 0, ℤ, (0..^𝑁))):if(𝑁 = 0, ℤ, (0..^𝑁))–1-1-onto→(Base‘𝑌))
82, 7syl 17 . . . . . . . 8 (𝑁 ∈ ℕ → ((ℤRHom‘𝑌) ↾ if(𝑁 = 0, ℤ, (0..^𝑁))):if(𝑁 = 0, ℤ, (0..^𝑁))–1-1-onto→(Base‘𝑌))
9 nnne0 11847 . . . . . . . . 9 (𝑁 ∈ ℕ → 𝑁 ≠ 0)
10 ifnefalse 4441 . . . . . . . . 9 (𝑁 ≠ 0 → if(𝑁 = 0, ℤ, (0..^𝑁)) = (0..^𝑁))
11 reseq2 5835 . . . . . . . . . . 11 (if(𝑁 = 0, ℤ, (0..^𝑁)) = (0..^𝑁) → ((ℤRHom‘𝑌) ↾ if(𝑁 = 0, ℤ, (0..^𝑁))) = ((ℤRHom‘𝑌) ↾ (0..^𝑁)))
1211f1oeq1d 6645 . . . . . . . . . 10 (if(𝑁 = 0, ℤ, (0..^𝑁)) = (0..^𝑁) → (((ℤRHom‘𝑌) ↾ if(𝑁 = 0, ℤ, (0..^𝑁))):if(𝑁 = 0, ℤ, (0..^𝑁))–1-1-onto→(Base‘𝑌) ↔ ((ℤRHom‘𝑌) ↾ (0..^𝑁)):if(𝑁 = 0, ℤ, (0..^𝑁))–1-1-onto→(Base‘𝑌)))
13 f1oeq2 6639 . . . . . . . . . 10 (if(𝑁 = 0, ℤ, (0..^𝑁)) = (0..^𝑁) → (((ℤRHom‘𝑌) ↾ (0..^𝑁)):if(𝑁 = 0, ℤ, (0..^𝑁))–1-1-onto→(Base‘𝑌) ↔ ((ℤRHom‘𝑌) ↾ (0..^𝑁)):(0..^𝑁)–1-1-onto→(Base‘𝑌)))
1412, 13bitrd 282 . . . . . . . . 9 (if(𝑁 = 0, ℤ, (0..^𝑁)) = (0..^𝑁) → (((ℤRHom‘𝑌) ↾ if(𝑁 = 0, ℤ, (0..^𝑁))):if(𝑁 = 0, ℤ, (0..^𝑁))–1-1-onto→(Base‘𝑌) ↔ ((ℤRHom‘𝑌) ↾ (0..^𝑁)):(0..^𝑁)–1-1-onto→(Base‘𝑌)))
159, 10, 143syl 18 . . . . . . . 8 (𝑁 ∈ ℕ → (((ℤRHom‘𝑌) ↾ if(𝑁 = 0, ℤ, (0..^𝑁))):if(𝑁 = 0, ℤ, (0..^𝑁))–1-1-onto→(Base‘𝑌) ↔ ((ℤRHom‘𝑌) ↾ (0..^𝑁)):(0..^𝑁)–1-1-onto→(Base‘𝑌)))
168, 15mpbid 235 . . . . . . 7 (𝑁 ∈ ℕ → ((ℤRHom‘𝑌) ↾ (0..^𝑁)):(0..^𝑁)–1-1-onto→(Base‘𝑌))
17 f1ofn 6651 . . . . . . 7 (((ℤRHom‘𝑌) ↾ (0..^𝑁)):(0..^𝑁)–1-1-onto→(Base‘𝑌) → ((ℤRHom‘𝑌) ↾ (0..^𝑁)) Fn (0..^𝑁))
18 elpreima 6867 . . . . . . 7 (((ℤRHom‘𝑌) ↾ (0..^𝑁)) Fn (0..^𝑁) → (𝑥 ∈ (((ℤRHom‘𝑌) ↾ (0..^𝑁)) “ 𝑈) ↔ (𝑥 ∈ (0..^𝑁) ∧ (((ℤRHom‘𝑌) ↾ (0..^𝑁))‘𝑥) ∈ 𝑈)))
1916, 17, 183syl 18 . . . . . 6 (𝑁 ∈ ℕ → (𝑥 ∈ (((ℤRHom‘𝑌) ↾ (0..^𝑁)) “ 𝑈) ↔ (𝑥 ∈ (0..^𝑁) ∧ (((ℤRHom‘𝑌) ↾ (0..^𝑁))‘𝑥) ∈ 𝑈)))
20 fvres 6725 . . . . . . . . . 10 (𝑥 ∈ (0..^𝑁) → (((ℤRHom‘𝑌) ↾ (0..^𝑁))‘𝑥) = ((ℤRHom‘𝑌)‘𝑥))
2120adantl 485 . . . . . . . . 9 ((𝑁 ∈ ℕ ∧ 𝑥 ∈ (0..^𝑁)) → (((ℤRHom‘𝑌) ↾ (0..^𝑁))‘𝑥) = ((ℤRHom‘𝑌)‘𝑥))
2221eleq1d 2818 . . . . . . . 8 ((𝑁 ∈ ℕ ∧ 𝑥 ∈ (0..^𝑁)) → ((((ℤRHom‘𝑌) ↾ (0..^𝑁))‘𝑥) ∈ 𝑈 ↔ ((ℤRHom‘𝑌)‘𝑥) ∈ 𝑈))
23 elfzoelz 13226 . . . . . . . . 9 (𝑥 ∈ (0..^𝑁) → 𝑥 ∈ ℤ)
24 znunit.u . . . . . . . . . 10 𝑈 = (Unit‘𝑌)
25 eqid 2734 . . . . . . . . . 10 (ℤRHom‘𝑌) = (ℤRHom‘𝑌)
263, 24, 25znunit 20500 . . . . . . . . 9 ((𝑁 ∈ ℕ0𝑥 ∈ ℤ) → (((ℤRHom‘𝑌)‘𝑥) ∈ 𝑈 ↔ (𝑥 gcd 𝑁) = 1))
272, 23, 26syl2an 599 . . . . . . . 8 ((𝑁 ∈ ℕ ∧ 𝑥 ∈ (0..^𝑁)) → (((ℤRHom‘𝑌)‘𝑥) ∈ 𝑈 ↔ (𝑥 gcd 𝑁) = 1))
2822, 27bitrd 282 . . . . . . 7 ((𝑁 ∈ ℕ ∧ 𝑥 ∈ (0..^𝑁)) → ((((ℤRHom‘𝑌) ↾ (0..^𝑁))‘𝑥) ∈ 𝑈 ↔ (𝑥 gcd 𝑁) = 1))
2928pm5.32da 582 . . . . . 6 (𝑁 ∈ ℕ → ((𝑥 ∈ (0..^𝑁) ∧ (((ℤRHom‘𝑌) ↾ (0..^𝑁))‘𝑥) ∈ 𝑈) ↔ (𝑥 ∈ (0..^𝑁) ∧ (𝑥 gcd 𝑁) = 1)))
3019, 29bitrd 282 . . . . 5 (𝑁 ∈ ℕ → (𝑥 ∈ (((ℤRHom‘𝑌) ↾ (0..^𝑁)) “ 𝑈) ↔ (𝑥 ∈ (0..^𝑁) ∧ (𝑥 gcd 𝑁) = 1)))
3130abbi2dv 2870 . . . 4 (𝑁 ∈ ℕ → (((ℤRHom‘𝑌) ↾ (0..^𝑁)) “ 𝑈) = {𝑥 ∣ (𝑥 ∈ (0..^𝑁) ∧ (𝑥 gcd 𝑁) = 1)})
32 df-rab 3063 . . . 4 {𝑥 ∈ (0..^𝑁) ∣ (𝑥 gcd 𝑁) = 1} = {𝑥 ∣ (𝑥 ∈ (0..^𝑁) ∧ (𝑥 gcd 𝑁) = 1)}
3331, 32eqtr4di 2792 . . 3 (𝑁 ∈ ℕ → (((ℤRHom‘𝑌) ↾ (0..^𝑁)) “ 𝑈) = {𝑥 ∈ (0..^𝑁) ∣ (𝑥 gcd 𝑁) = 1})
3433fveq2d 6710 . 2 (𝑁 ∈ ℕ → (♯‘(((ℤRHom‘𝑌) ↾ (0..^𝑁)) “ 𝑈)) = (♯‘{𝑥 ∈ (0..^𝑁) ∣ (𝑥 gcd 𝑁) = 1}))
35 f1ocnv 6662 . . . . 5 (((ℤRHom‘𝑌) ↾ (0..^𝑁)):(0..^𝑁)–1-1-onto→(Base‘𝑌) → ((ℤRHom‘𝑌) ↾ (0..^𝑁)):(Base‘𝑌)–1-1-onto→(0..^𝑁))
36 f1of1 6649 . . . . 5 (((ℤRHom‘𝑌) ↾ (0..^𝑁)):(Base‘𝑌)–1-1-onto→(0..^𝑁) → ((ℤRHom‘𝑌) ↾ (0..^𝑁)):(Base‘𝑌)–1-1→(0..^𝑁))
3716, 35, 363syl 18 . . . 4 (𝑁 ∈ ℕ → ((ℤRHom‘𝑌) ↾ (0..^𝑁)):(Base‘𝑌)–1-1→(0..^𝑁))
38 ovexd 7237 . . . 4 (𝑁 ∈ ℕ → (0..^𝑁) ∈ V)
394, 24unitss 19650 . . . . 5 𝑈 ⊆ (Base‘𝑌)
4039a1i 11 . . . 4 (𝑁 ∈ ℕ → 𝑈 ⊆ (Base‘𝑌))
4124fvexi 6720 . . . . 5 𝑈 ∈ V
4241a1i 11 . . . 4 (𝑁 ∈ ℕ → 𝑈 ∈ V)
43 f1imaen2g 8678 . . . 4 (((((ℤRHom‘𝑌) ↾ (0..^𝑁)):(Base‘𝑌)–1-1→(0..^𝑁) ∧ (0..^𝑁) ∈ V) ∧ (𝑈 ⊆ (Base‘𝑌) ∧ 𝑈 ∈ V)) → (((ℤRHom‘𝑌) ↾ (0..^𝑁)) “ 𝑈) ≈ 𝑈)
4437, 38, 40, 42, 43syl22anc 839 . . 3 (𝑁 ∈ ℕ → (((ℤRHom‘𝑌) ↾ (0..^𝑁)) “ 𝑈) ≈ 𝑈)
45 hasheni 13897 . . 3 ((((ℤRHom‘𝑌) ↾ (0..^𝑁)) “ 𝑈) ≈ 𝑈 → (♯‘(((ℤRHom‘𝑌) ↾ (0..^𝑁)) “ 𝑈)) = (♯‘𝑈))
4644, 45syl 17 . 2 (𝑁 ∈ ℕ → (♯‘(((ℤRHom‘𝑌) ↾ (0..^𝑁)) “ 𝑈)) = (♯‘𝑈))
471, 34, 463eqtr2rd 2781 1 (𝑁 ∈ ℕ → (♯‘𝑈) = (ϕ‘𝑁))
Colors of variables: wff setvar class
Syntax hints:  wi 4  wb 209  wa 399   = wceq 1543  wcel 2110  {cab 2712  wne 2935  {crab 3058  Vcvv 3401  wss 3857  ifcif 4429   class class class wbr 5043  ccnv 5539  cres 5542  cima 5543   Fn wfn 6364  1-1wf1 6366  1-1-ontowf1o 6368  cfv 6369  (class class class)co 7202  cen 8612  0cc0 10712  1c1 10713  cn 11813  0cn0 12073  cz 12159  ..^cfzo 13221  chash 13879   gcd cgcd 16034  ϕcphi 16298  Basecbs 16684  Unitcui 19629  ℤRHomczrh 20438  ℤ/nczn 20441
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-3 8  ax-gen 1803  ax-4 1817  ax-5 1918  ax-6 1976  ax-7 2016  ax-8 2112  ax-9 2120  ax-10 2141  ax-11 2158  ax-12 2175  ax-ext 2706  ax-rep 5168  ax-sep 5181  ax-nul 5188  ax-pow 5247  ax-pr 5311  ax-un 7512  ax-cnex 10768  ax-resscn 10769  ax-1cn 10770  ax-icn 10771  ax-addcl 10772  ax-addrcl 10773  ax-mulcl 10774  ax-mulrcl 10775  ax-mulcom 10776  ax-addass 10777  ax-mulass 10778  ax-distr 10779  ax-i2m1 10780  ax-1ne0 10781  ax-1rid 10782  ax-rnegex 10783  ax-rrecex 10784  ax-cnre 10785  ax-pre-lttri 10786  ax-pre-lttrn 10787  ax-pre-ltadd 10788  ax-pre-mulgt0 10789  ax-pre-sup 10790  ax-addf 10791  ax-mulf 10792
This theorem depends on definitions:  df-bi 210  df-an 400  df-or 848  df-3or 1090  df-3an 1091  df-tru 1546  df-fal 1556  df-ex 1788  df-nf 1792  df-sb 2071  df-mo 2537  df-eu 2566  df-clab 2713  df-cleq 2726  df-clel 2812  df-nfc 2882  df-ne 2936  df-nel 3040  df-ral 3059  df-rex 3060  df-reu 3061  df-rmo 3062  df-rab 3063  df-v 3403  df-sbc 3688  df-csb 3803  df-dif 3860  df-un 3862  df-in 3864  df-ss 3874  df-pss 3876  df-nul 4228  df-if 4430  df-pw 4505  df-sn 4532  df-pr 4534  df-tp 4536  df-op 4538  df-uni 4810  df-int 4850  df-iun 4896  df-br 5044  df-opab 5106  df-mpt 5125  df-tr 5151  df-id 5444  df-eprel 5449  df-po 5457  df-so 5458  df-fr 5498  df-we 5500  df-xp 5546  df-rel 5547  df-cnv 5548  df-co 5549  df-dm 5550  df-rn 5551  df-res 5552  df-ima 5553  df-pred 6149  df-ord 6205  df-on 6206  df-lim 6207  df-suc 6208  df-iota 6327  df-fun 6371  df-fn 6372  df-f 6373  df-f1 6374  df-fo 6375  df-f1o 6376  df-fv 6377  df-riota 7159  df-ov 7205  df-oprab 7206  df-mpo 7207  df-om 7634  df-1st 7750  df-2nd 7751  df-tpos 7957  df-wrecs 8036  df-recs 8097  df-rdg 8135  df-1o 8191  df-oadd 8195  df-er 8380  df-ec 8382  df-qs 8386  df-map 8499  df-en 8616  df-dom 8617  df-sdom 8618  df-fin 8619  df-sup 9047  df-inf 9048  df-card 9538  df-pnf 10852  df-mnf 10853  df-xr 10854  df-ltxr 10855  df-le 10856  df-sub 11047  df-neg 11048  df-div 11473  df-nn 11814  df-2 11876  df-3 11877  df-4 11878  df-5 11879  df-6 11880  df-7 11881  df-8 11882  df-9 11883  df-n0 12074  df-xnn0 12146  df-z 12160  df-dec 12277  df-uz 12422  df-rp 12570  df-fz 13079  df-fzo 13222  df-fl 13350  df-mod 13426  df-seq 13558  df-exp 13619  df-hash 13880  df-cj 14645  df-re 14646  df-im 14647  df-sqrt 14781  df-abs 14782  df-dvds 15797  df-gcd 16035  df-phi 16300  df-struct 16686  df-ndx 16687  df-slot 16688  df-base 16690  df-sets 16691  df-ress 16692  df-plusg 16780  df-mulr 16781  df-starv 16782  df-sca 16783  df-vsca 16784  df-ip 16785  df-tset 16786  df-ple 16787  df-ds 16789  df-unif 16790  df-0g 16918  df-imas 16985  df-qus 16986  df-mgm 18086  df-sgrp 18135  df-mnd 18146  df-mhm 18190  df-grp 18340  df-minusg 18341  df-sbg 18342  df-mulg 18461  df-subg 18512  df-nsg 18513  df-eqg 18514  df-ghm 18592  df-cmn 19144  df-abl 19145  df-mgp 19477  df-ur 19489  df-ring 19536  df-cring 19537  df-oppr 19613  df-dvdsr 19631  df-unit 19632  df-rnghom 19707  df-subrg 19770  df-lmod 19873  df-lss 19941  df-lsp 19981  df-sra 20181  df-rgmod 20182  df-lidl 20183  df-rsp 20184  df-2idl 20242  df-cnfld 20336  df-zring 20408  df-zrh 20442  df-zn 20445
This theorem is referenced by:  dchrfi  26108  dchrsum2  26121
  Copyright terms: Public domain W3C validator