![]() |
Metamath Proof Explorer |
< Previous
Next >
Nearby theorems |
|
Mirrors > Home > MPE Home > Th. List > cyggic | Structured version Visualization version GIF version |
Description: Cyclic groups are isomorphic precisely when they have the same order. (Contributed by Mario Carneiro, 21-Apr-2016.) |
Ref | Expression |
---|---|
cygctb.b | ⊢ 𝐵 = (Base‘𝐺) |
cygctb.c | ⊢ 𝐶 = (Base‘𝐻) |
Ref | Expression |
---|---|
cyggic | ⊢ ((𝐺 ∈ CycGrp ∧ 𝐻 ∈ CycGrp) → (𝐺 ≃𝑔 𝐻 ↔ 𝐵 ≈ 𝐶)) |
Step | Hyp | Ref | Expression |
---|---|---|---|
1 | cygctb.b | . . 3 ⊢ 𝐵 = (Base‘𝐺) | |
2 | cygctb.c | . . 3 ⊢ 𝐶 = (Base‘𝐻) | |
3 | 1, 2 | gicen 19075 | . 2 ⊢ (𝐺 ≃𝑔 𝐻 → 𝐵 ≈ 𝐶) |
4 | eqid 2733 | . . . . . 6 ⊢ if(𝐵 ∈ Fin, (♯‘𝐵), 0) = if(𝐵 ∈ Fin, (♯‘𝐵), 0) | |
5 | eqid 2733 | . . . . . 6 ⊢ (ℤ/nℤ‘if(𝐵 ∈ Fin, (♯‘𝐵), 0)) = (ℤ/nℤ‘if(𝐵 ∈ Fin, (♯‘𝐵), 0)) | |
6 | 1, 4, 5 | cygzn 21000 | . . . . 5 ⊢ (𝐺 ∈ CycGrp → 𝐺 ≃𝑔 (ℤ/nℤ‘if(𝐵 ∈ Fin, (♯‘𝐵), 0))) |
7 | 6 | ad2antrr 725 | . . . 4 ⊢ (((𝐺 ∈ CycGrp ∧ 𝐻 ∈ CycGrp) ∧ 𝐵 ≈ 𝐶) → 𝐺 ≃𝑔 (ℤ/nℤ‘if(𝐵 ∈ Fin, (♯‘𝐵), 0))) |
8 | enfi 9140 | . . . . . . . 8 ⊢ (𝐵 ≈ 𝐶 → (𝐵 ∈ Fin ↔ 𝐶 ∈ Fin)) | |
9 | 8 | adantl 483 | . . . . . . 7 ⊢ (((𝐺 ∈ CycGrp ∧ 𝐻 ∈ CycGrp) ∧ 𝐵 ≈ 𝐶) → (𝐵 ∈ Fin ↔ 𝐶 ∈ Fin)) |
10 | hasheni 14257 | . . . . . . . 8 ⊢ (𝐵 ≈ 𝐶 → (♯‘𝐵) = (♯‘𝐶)) | |
11 | 10 | adantl 483 | . . . . . . 7 ⊢ (((𝐺 ∈ CycGrp ∧ 𝐻 ∈ CycGrp) ∧ 𝐵 ≈ 𝐶) → (♯‘𝐵) = (♯‘𝐶)) |
12 | 9, 11 | ifbieq1d 4514 | . . . . . 6 ⊢ (((𝐺 ∈ CycGrp ∧ 𝐻 ∈ CycGrp) ∧ 𝐵 ≈ 𝐶) → if(𝐵 ∈ Fin, (♯‘𝐵), 0) = if(𝐶 ∈ Fin, (♯‘𝐶), 0)) |
13 | 12 | fveq2d 6850 | . . . . 5 ⊢ (((𝐺 ∈ CycGrp ∧ 𝐻 ∈ CycGrp) ∧ 𝐵 ≈ 𝐶) → (ℤ/nℤ‘if(𝐵 ∈ Fin, (♯‘𝐵), 0)) = (ℤ/nℤ‘if(𝐶 ∈ Fin, (♯‘𝐶), 0))) |
14 | eqid 2733 | . . . . . . . 8 ⊢ if(𝐶 ∈ Fin, (♯‘𝐶), 0) = if(𝐶 ∈ Fin, (♯‘𝐶), 0) | |
15 | eqid 2733 | . . . . . . . 8 ⊢ (ℤ/nℤ‘if(𝐶 ∈ Fin, (♯‘𝐶), 0)) = (ℤ/nℤ‘if(𝐶 ∈ Fin, (♯‘𝐶), 0)) | |
16 | 2, 14, 15 | cygzn 21000 | . . . . . . 7 ⊢ (𝐻 ∈ CycGrp → 𝐻 ≃𝑔 (ℤ/nℤ‘if(𝐶 ∈ Fin, (♯‘𝐶), 0))) |
17 | 16 | ad2antlr 726 | . . . . . 6 ⊢ (((𝐺 ∈ CycGrp ∧ 𝐻 ∈ CycGrp) ∧ 𝐵 ≈ 𝐶) → 𝐻 ≃𝑔 (ℤ/nℤ‘if(𝐶 ∈ Fin, (♯‘𝐶), 0))) |
18 | gicsym 19072 | . . . . . 6 ⊢ (𝐻 ≃𝑔 (ℤ/nℤ‘if(𝐶 ∈ Fin, (♯‘𝐶), 0)) → (ℤ/nℤ‘if(𝐶 ∈ Fin, (♯‘𝐶), 0)) ≃𝑔 𝐻) | |
19 | 17, 18 | syl 17 | . . . . 5 ⊢ (((𝐺 ∈ CycGrp ∧ 𝐻 ∈ CycGrp) ∧ 𝐵 ≈ 𝐶) → (ℤ/nℤ‘if(𝐶 ∈ Fin, (♯‘𝐶), 0)) ≃𝑔 𝐻) |
20 | 13, 19 | eqbrtrd 5131 | . . . 4 ⊢ (((𝐺 ∈ CycGrp ∧ 𝐻 ∈ CycGrp) ∧ 𝐵 ≈ 𝐶) → (ℤ/nℤ‘if(𝐵 ∈ Fin, (♯‘𝐵), 0)) ≃𝑔 𝐻) |
21 | gictr 19073 | . . . 4 ⊢ ((𝐺 ≃𝑔 (ℤ/nℤ‘if(𝐵 ∈ Fin, (♯‘𝐵), 0)) ∧ (ℤ/nℤ‘if(𝐵 ∈ Fin, (♯‘𝐵), 0)) ≃𝑔 𝐻) → 𝐺 ≃𝑔 𝐻) | |
22 | 7, 20, 21 | syl2anc 585 | . . 3 ⊢ (((𝐺 ∈ CycGrp ∧ 𝐻 ∈ CycGrp) ∧ 𝐵 ≈ 𝐶) → 𝐺 ≃𝑔 𝐻) |
23 | 22 | ex 414 | . 2 ⊢ ((𝐺 ∈ CycGrp ∧ 𝐻 ∈ CycGrp) → (𝐵 ≈ 𝐶 → 𝐺 ≃𝑔 𝐻)) |
24 | 3, 23 | impbid2 225 | 1 ⊢ ((𝐺 ∈ CycGrp ∧ 𝐻 ∈ CycGrp) → (𝐺 ≃𝑔 𝐻 ↔ 𝐵 ≈ 𝐶)) |
Colors of variables: wff setvar class |
Syntax hints: → wi 4 ↔ wb 205 ∧ wa 397 = wceq 1542 ∈ wcel 2107 ifcif 4490 class class class wbr 5109 ‘cfv 6500 ≈ cen 8886 Fincfn 8889 0cc0 11059 ♯chash 14239 Basecbs 17091 ≃𝑔 cgic 19056 CycGrpccyg 19662 ℤ/nℤczn 20926 |
This theorem was proved from axioms: ax-mp 5 ax-1 6 ax-2 7 ax-3 8 ax-gen 1798 ax-4 1812 ax-5 1914 ax-6 1972 ax-7 2012 ax-8 2109 ax-9 2117 ax-10 2138 ax-11 2155 ax-12 2172 ax-ext 2704 ax-rep 5246 ax-sep 5260 ax-nul 5267 ax-pow 5324 ax-pr 5388 ax-un 7676 ax-inf2 9585 ax-cnex 11115 ax-resscn 11116 ax-1cn 11117 ax-icn 11118 ax-addcl 11119 ax-addrcl 11120 ax-mulcl 11121 ax-mulrcl 11122 ax-mulcom 11123 ax-addass 11124 ax-mulass 11125 ax-distr 11126 ax-i2m1 11127 ax-1ne0 11128 ax-1rid 11129 ax-rnegex 11130 ax-rrecex 11131 ax-cnre 11132 ax-pre-lttri 11133 ax-pre-lttrn 11134 ax-pre-ltadd 11135 ax-pre-mulgt0 11136 ax-pre-sup 11137 ax-addf 11138 ax-mulf 11139 |
This theorem depends on definitions: df-bi 206 df-an 398 df-or 847 df-3or 1089 df-3an 1090 df-tru 1545 df-fal 1555 df-ex 1783 df-nf 1787 df-sb 2069 df-mo 2535 df-eu 2564 df-clab 2711 df-cleq 2725 df-clel 2811 df-nfc 2886 df-ne 2941 df-nel 3047 df-ral 3062 df-rex 3071 df-rmo 3352 df-reu 3353 df-rab 3407 df-v 3449 df-sbc 3744 df-csb 3860 df-dif 3917 df-un 3919 df-in 3921 df-ss 3931 df-pss 3933 df-nul 4287 df-if 4491 df-pw 4566 df-sn 4591 df-pr 4593 df-tp 4595 df-op 4597 df-uni 4870 df-int 4912 df-iun 4960 df-br 5110 df-opab 5172 df-mpt 5193 df-tr 5227 df-id 5535 df-eprel 5541 df-po 5549 df-so 5550 df-fr 5592 df-se 5593 df-we 5594 df-xp 5643 df-rel 5644 df-cnv 5645 df-co 5646 df-dm 5647 df-rn 5648 df-res 5649 df-ima 5650 df-pred 6257 df-ord 6324 df-on 6325 df-lim 6326 df-suc 6327 df-iota 6452 df-fun 6502 df-fn 6503 df-f 6504 df-f1 6505 df-fo 6506 df-f1o 6507 df-fv 6508 df-isom 6509 df-riota 7317 df-ov 7364 df-oprab 7365 df-mpo 7366 df-om 7807 df-1st 7925 df-2nd 7926 df-tpos 8161 df-frecs 8216 df-wrecs 8247 df-recs 8321 df-rdg 8360 df-1o 8416 df-oadd 8420 df-omul 8421 df-er 8654 df-ec 8656 df-qs 8660 df-map 8773 df-en 8890 df-dom 8891 df-sdom 8892 df-fin 8893 df-sup 9386 df-inf 9387 df-oi 9454 df-card 9883 df-acn 9886 df-pnf 11199 df-mnf 11200 df-xr 11201 df-ltxr 11202 df-le 11203 df-sub 11395 df-neg 11396 df-div 11821 df-nn 12162 df-2 12224 df-3 12225 df-4 12226 df-5 12227 df-6 12228 df-7 12229 df-8 12230 df-9 12231 df-n0 12422 df-z 12508 df-dec 12627 df-uz 12772 df-rp 12924 df-fz 13434 df-fl 13706 df-mod 13784 df-seq 13916 df-exp 13977 df-hash 14240 df-cj 14993 df-re 14994 df-im 14995 df-sqrt 15129 df-abs 15130 df-dvds 16145 df-struct 17027 df-sets 17044 df-slot 17062 df-ndx 17074 df-base 17092 df-ress 17121 df-plusg 17154 df-mulr 17155 df-starv 17156 df-sca 17157 df-vsca 17158 df-ip 17159 df-tset 17160 df-ple 17161 df-ds 17163 df-unif 17164 df-0g 17331 df-imas 17398 df-qus 17399 df-mgm 18505 df-sgrp 18554 df-mnd 18565 df-mhm 18609 df-grp 18759 df-minusg 18760 df-sbg 18761 df-mulg 18881 df-subg 18933 df-nsg 18934 df-eqg 18935 df-ghm 19014 df-gim 19057 df-gic 19058 df-od 19318 df-cmn 19572 df-abl 19573 df-cyg 19663 df-mgp 19905 df-ur 19922 df-ring 19974 df-cring 19975 df-oppr 20057 df-dvdsr 20078 df-rnghom 20156 df-subrg 20262 df-lmod 20367 df-lss 20437 df-lsp 20477 df-sra 20678 df-rgmod 20679 df-lidl 20680 df-rsp 20681 df-2idl 20747 df-cnfld 20820 df-zring 20893 df-zrh 20927 df-zn 20930 |
This theorem is referenced by: (None) |
Copyright terms: Public domain | W3C validator |