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

Theorem gsumwrev 19297
Description: A sum in an opposite monoid is the regular sum of a reversed word. (Contributed by Stefan O'Rear, 27-Aug-2015.) (Proof shortened by Mario Carneiro, 28-Feb-2016.)
Hypotheses
Ref Expression
gsumwrev.b 𝐵 = (Base‘𝑀)
gsumwrev.o 𝑂 = (oppg𝑀)
Assertion
Ref Expression
gsumwrev ((𝑀 ∈ Mnd ∧ 𝑊 ∈ Word 𝐵) → (𝑂 Σg 𝑊) = (𝑀 Σg (reverse‘𝑊)))

Proof of Theorem gsumwrev
Dummy variables 𝑥 𝑦 𝑧 are mutually distinct and distinct from all other variables.
StepHypRef Expression
1 oveq2 7366 . . . . 5 (𝑥 = ∅ → (𝑂 Σg 𝑥) = (𝑂 Σg ∅))
2 fveq2 6833 . . . . . . 7 (𝑥 = ∅ → (reverse‘𝑥) = (reverse‘∅))
3 rev0 14689 . . . . . . 7 (reverse‘∅) = ∅
42, 3eqtrdi 2786 . . . . . 6 (𝑥 = ∅ → (reverse‘𝑥) = ∅)
54oveq2d 7374 . . . . 5 (𝑥 = ∅ → (𝑀 Σg (reverse‘𝑥)) = (𝑀 Σg ∅))
61, 5eqeq12d 2751 . . . 4 (𝑥 = ∅ → ((𝑂 Σg 𝑥) = (𝑀 Σg (reverse‘𝑥)) ↔ (𝑂 Σg ∅) = (𝑀 Σg ∅)))
76imbi2d 340 . . 3 (𝑥 = ∅ → ((𝑀 ∈ Mnd → (𝑂 Σg 𝑥) = (𝑀 Σg (reverse‘𝑥))) ↔ (𝑀 ∈ Mnd → (𝑂 Σg ∅) = (𝑀 Σg ∅))))
8 oveq2 7366 . . . . 5 (𝑥 = 𝑦 → (𝑂 Σg 𝑥) = (𝑂 Σg 𝑦))
9 fveq2 6833 . . . . . 6 (𝑥 = 𝑦 → (reverse‘𝑥) = (reverse‘𝑦))
109oveq2d 7374 . . . . 5 (𝑥 = 𝑦 → (𝑀 Σg (reverse‘𝑥)) = (𝑀 Σg (reverse‘𝑦)))
118, 10eqeq12d 2751 . . . 4 (𝑥 = 𝑦 → ((𝑂 Σg 𝑥) = (𝑀 Σg (reverse‘𝑥)) ↔ (𝑂 Σg 𝑦) = (𝑀 Σg (reverse‘𝑦))))
1211imbi2d 340 . . 3 (𝑥 = 𝑦 → ((𝑀 ∈ Mnd → (𝑂 Σg 𝑥) = (𝑀 Σg (reverse‘𝑥))) ↔ (𝑀 ∈ Mnd → (𝑂 Σg 𝑦) = (𝑀 Σg (reverse‘𝑦)))))
13 oveq2 7366 . . . . 5 (𝑥 = (𝑦 ++ ⟨“𝑧”⟩) → (𝑂 Σg 𝑥) = (𝑂 Σg (𝑦 ++ ⟨“𝑧”⟩)))
14 fveq2 6833 . . . . . 6 (𝑥 = (𝑦 ++ ⟨“𝑧”⟩) → (reverse‘𝑥) = (reverse‘(𝑦 ++ ⟨“𝑧”⟩)))
1514oveq2d 7374 . . . . 5 (𝑥 = (𝑦 ++ ⟨“𝑧”⟩) → (𝑀 Σg (reverse‘𝑥)) = (𝑀 Σg (reverse‘(𝑦 ++ ⟨“𝑧”⟩))))
1613, 15eqeq12d 2751 . . . 4 (𝑥 = (𝑦 ++ ⟨“𝑧”⟩) → ((𝑂 Σg 𝑥) = (𝑀 Σg (reverse‘𝑥)) ↔ (𝑂 Σg (𝑦 ++ ⟨“𝑧”⟩)) = (𝑀 Σg (reverse‘(𝑦 ++ ⟨“𝑧”⟩)))))
1716imbi2d 340 . . 3 (𝑥 = (𝑦 ++ ⟨“𝑧”⟩) → ((𝑀 ∈ Mnd → (𝑂 Σg 𝑥) = (𝑀 Σg (reverse‘𝑥))) ↔ (𝑀 ∈ Mnd → (𝑂 Σg (𝑦 ++ ⟨“𝑧”⟩)) = (𝑀 Σg (reverse‘(𝑦 ++ ⟨“𝑧”⟩))))))
18 oveq2 7366 . . . . 5 (𝑥 = 𝑊 → (𝑂 Σg 𝑥) = (𝑂 Σg 𝑊))
19 fveq2 6833 . . . . . 6 (𝑥 = 𝑊 → (reverse‘𝑥) = (reverse‘𝑊))
2019oveq2d 7374 . . . . 5 (𝑥 = 𝑊 → (𝑀 Σg (reverse‘𝑥)) = (𝑀 Σg (reverse‘𝑊)))
2118, 20eqeq12d 2751 . . . 4 (𝑥 = 𝑊 → ((𝑂 Σg 𝑥) = (𝑀 Σg (reverse‘𝑥)) ↔ (𝑂 Σg 𝑊) = (𝑀 Σg (reverse‘𝑊))))
2221imbi2d 340 . . 3 (𝑥 = 𝑊 → ((𝑀 ∈ Mnd → (𝑂 Σg 𝑥) = (𝑀 Σg (reverse‘𝑥))) ↔ (𝑀 ∈ Mnd → (𝑂 Σg 𝑊) = (𝑀 Σg (reverse‘𝑊)))))
23 gsumwrev.o . . . . . . 7 𝑂 = (oppg𝑀)
24 eqid 2735 . . . . . . 7 (0g𝑀) = (0g𝑀)
2523, 24oppgid 19287 . . . . . 6 (0g𝑀) = (0g𝑂)
2625gsum0 18611 . . . . 5 (𝑂 Σg ∅) = (0g𝑀)
2724gsum0 18611 . . . . 5 (𝑀 Σg ∅) = (0g𝑀)
2826, 27eqtr4i 2761 . . . 4 (𝑂 Σg ∅) = (𝑀 Σg ∅)
2928a1i 11 . . 3 (𝑀 ∈ Mnd → (𝑂 Σg ∅) = (𝑀 Σg ∅))
30 oveq2 7366 . . . . . 6 ((𝑂 Σg 𝑦) = (𝑀 Σg (reverse‘𝑦)) → (𝑧(+g𝑀)(𝑂 Σg 𝑦)) = (𝑧(+g𝑀)(𝑀 Σg (reverse‘𝑦))))
3123oppgmnd 19285 . . . . . . . . . 10 (𝑀 ∈ Mnd → 𝑂 ∈ Mnd)
3231adantr 480 . . . . . . . . 9 ((𝑀 ∈ Mnd ∧ (𝑦 ∈ Word 𝐵𝑧𝐵)) → 𝑂 ∈ Mnd)
33 simprl 771 . . . . . . . . 9 ((𝑀 ∈ Mnd ∧ (𝑦 ∈ Word 𝐵𝑧𝐵)) → 𝑦 ∈ Word 𝐵)
34 simprr 773 . . . . . . . . . 10 ((𝑀 ∈ Mnd ∧ (𝑦 ∈ Word 𝐵𝑧𝐵)) → 𝑧𝐵)
3534s1cld 14529 . . . . . . . . 9 ((𝑀 ∈ Mnd ∧ (𝑦 ∈ Word 𝐵𝑧𝐵)) → ⟨“𝑧”⟩ ∈ Word 𝐵)
36 gsumwrev.b . . . . . . . . . . 11 𝐵 = (Base‘𝑀)
3723, 36oppgbas 19282 . . . . . . . . . 10 𝐵 = (Base‘𝑂)
38 eqid 2735 . . . . . . . . . 10 (+g𝑂) = (+g𝑂)
3937, 38gsumccat 18768 . . . . . . . . 9 ((𝑂 ∈ Mnd ∧ 𝑦 ∈ Word 𝐵 ∧ ⟨“𝑧”⟩ ∈ Word 𝐵) → (𝑂 Σg (𝑦 ++ ⟨“𝑧”⟩)) = ((𝑂 Σg 𝑦)(+g𝑂)(𝑂 Σg ⟨“𝑧”⟩)))
4032, 33, 35, 39syl3anc 1374 . . . . . . . 8 ((𝑀 ∈ Mnd ∧ (𝑦 ∈ Word 𝐵𝑧𝐵)) → (𝑂 Σg (𝑦 ++ ⟨“𝑧”⟩)) = ((𝑂 Σg 𝑦)(+g𝑂)(𝑂 Σg ⟨“𝑧”⟩)))
4137gsumws1 18765 . . . . . . . . . . 11 (𝑧𝐵 → (𝑂 Σg ⟨“𝑧”⟩) = 𝑧)
4241ad2antll 730 . . . . . . . . . 10 ((𝑀 ∈ Mnd ∧ (𝑦 ∈ Word 𝐵𝑧𝐵)) → (𝑂 Σg ⟨“𝑧”⟩) = 𝑧)
4342oveq2d 7374 . . . . . . . . 9 ((𝑀 ∈ Mnd ∧ (𝑦 ∈ Word 𝐵𝑧𝐵)) → ((𝑂 Σg 𝑦)(+g𝑂)(𝑂 Σg ⟨“𝑧”⟩)) = ((𝑂 Σg 𝑦)(+g𝑂)𝑧))
44 eqid 2735 . . . . . . . . . 10 (+g𝑀) = (+g𝑀)
4544, 23, 38oppgplus 19280 . . . . . . . . 9 ((𝑂 Σg 𝑦)(+g𝑂)𝑧) = (𝑧(+g𝑀)(𝑂 Σg 𝑦))
4643, 45eqtrdi 2786 . . . . . . . 8 ((𝑀 ∈ Mnd ∧ (𝑦 ∈ Word 𝐵𝑧𝐵)) → ((𝑂 Σg 𝑦)(+g𝑂)(𝑂 Σg ⟨“𝑧”⟩)) = (𝑧(+g𝑀)(𝑂 Σg 𝑦)))
4740, 46eqtrd 2770 . . . . . . 7 ((𝑀 ∈ Mnd ∧ (𝑦 ∈ Word 𝐵𝑧𝐵)) → (𝑂 Σg (𝑦 ++ ⟨“𝑧”⟩)) = (𝑧(+g𝑀)(𝑂 Σg 𝑦)))
48 revccat 14691 . . . . . . . . . . 11 ((𝑦 ∈ Word 𝐵 ∧ ⟨“𝑧”⟩ ∈ Word 𝐵) → (reverse‘(𝑦 ++ ⟨“𝑧”⟩)) = ((reverse‘⟨“𝑧”⟩) ++ (reverse‘𝑦)))
4933, 35, 48syl2anc 585 . . . . . . . . . 10 ((𝑀 ∈ Mnd ∧ (𝑦 ∈ Word 𝐵𝑧𝐵)) → (reverse‘(𝑦 ++ ⟨“𝑧”⟩)) = ((reverse‘⟨“𝑧”⟩) ++ (reverse‘𝑦)))
50 revs1 14690 . . . . . . . . . . 11 (reverse‘⟨“𝑧”⟩) = ⟨“𝑧”⟩
5150oveq1i 7368 . . . . . . . . . 10 ((reverse‘⟨“𝑧”⟩) ++ (reverse‘𝑦)) = (⟨“𝑧”⟩ ++ (reverse‘𝑦))
5249, 51eqtrdi 2786 . . . . . . . . 9 ((𝑀 ∈ Mnd ∧ (𝑦 ∈ Word 𝐵𝑧𝐵)) → (reverse‘(𝑦 ++ ⟨“𝑧”⟩)) = (⟨“𝑧”⟩ ++ (reverse‘𝑦)))
5352oveq2d 7374 . . . . . . . 8 ((𝑀 ∈ Mnd ∧ (𝑦 ∈ Word 𝐵𝑧𝐵)) → (𝑀 Σg (reverse‘(𝑦 ++ ⟨“𝑧”⟩))) = (𝑀 Σg (⟨“𝑧”⟩ ++ (reverse‘𝑦))))
54 simpl 482 . . . . . . . . 9 ((𝑀 ∈ Mnd ∧ (𝑦 ∈ Word 𝐵𝑧𝐵)) → 𝑀 ∈ Mnd)
55 revcl 14686 . . . . . . . . . 10 (𝑦 ∈ Word 𝐵 → (reverse‘𝑦) ∈ Word 𝐵)
5655ad2antrl 729 . . . . . . . . 9 ((𝑀 ∈ Mnd ∧ (𝑦 ∈ Word 𝐵𝑧𝐵)) → (reverse‘𝑦) ∈ Word 𝐵)
5736, 44gsumccat 18768 . . . . . . . . 9 ((𝑀 ∈ Mnd ∧ ⟨“𝑧”⟩ ∈ Word 𝐵 ∧ (reverse‘𝑦) ∈ Word 𝐵) → (𝑀 Σg (⟨“𝑧”⟩ ++ (reverse‘𝑦))) = ((𝑀 Σg ⟨“𝑧”⟩)(+g𝑀)(𝑀 Σg (reverse‘𝑦))))
5854, 35, 56, 57syl3anc 1374 . . . . . . . 8 ((𝑀 ∈ Mnd ∧ (𝑦 ∈ Word 𝐵𝑧𝐵)) → (𝑀 Σg (⟨“𝑧”⟩ ++ (reverse‘𝑦))) = ((𝑀 Σg ⟨“𝑧”⟩)(+g𝑀)(𝑀 Σg (reverse‘𝑦))))
5936gsumws1 18765 . . . . . . . . . 10 (𝑧𝐵 → (𝑀 Σg ⟨“𝑧”⟩) = 𝑧)
6059ad2antll 730 . . . . . . . . 9 ((𝑀 ∈ Mnd ∧ (𝑦 ∈ Word 𝐵𝑧𝐵)) → (𝑀 Σg ⟨“𝑧”⟩) = 𝑧)
6160oveq1d 7373 . . . . . . . 8 ((𝑀 ∈ Mnd ∧ (𝑦 ∈ Word 𝐵𝑧𝐵)) → ((𝑀 Σg ⟨“𝑧”⟩)(+g𝑀)(𝑀 Σg (reverse‘𝑦))) = (𝑧(+g𝑀)(𝑀 Σg (reverse‘𝑦))))
6253, 58, 613eqtrd 2774 . . . . . . 7 ((𝑀 ∈ Mnd ∧ (𝑦 ∈ Word 𝐵𝑧𝐵)) → (𝑀 Σg (reverse‘(𝑦 ++ ⟨“𝑧”⟩))) = (𝑧(+g𝑀)(𝑀 Σg (reverse‘𝑦))))
6347, 62eqeq12d 2751 . . . . . 6 ((𝑀 ∈ Mnd ∧ (𝑦 ∈ Word 𝐵𝑧𝐵)) → ((𝑂 Σg (𝑦 ++ ⟨“𝑧”⟩)) = (𝑀 Σg (reverse‘(𝑦 ++ ⟨“𝑧”⟩))) ↔ (𝑧(+g𝑀)(𝑂 Σg 𝑦)) = (𝑧(+g𝑀)(𝑀 Σg (reverse‘𝑦)))))
6430, 63imbitrrid 246 . . . . 5 ((𝑀 ∈ Mnd ∧ (𝑦 ∈ Word 𝐵𝑧𝐵)) → ((𝑂 Σg 𝑦) = (𝑀 Σg (reverse‘𝑦)) → (𝑂 Σg (𝑦 ++ ⟨“𝑧”⟩)) = (𝑀 Σg (reverse‘(𝑦 ++ ⟨“𝑧”⟩)))))
6564expcom 413 . . . 4 ((𝑦 ∈ Word 𝐵𝑧𝐵) → (𝑀 ∈ Mnd → ((𝑂 Σg 𝑦) = (𝑀 Σg (reverse‘𝑦)) → (𝑂 Σg (𝑦 ++ ⟨“𝑧”⟩)) = (𝑀 Σg (reverse‘(𝑦 ++ ⟨“𝑧”⟩))))))
6665a2d 29 . . 3 ((𝑦 ∈ Word 𝐵𝑧𝐵) → ((𝑀 ∈ Mnd → (𝑂 Σg 𝑦) = (𝑀 Σg (reverse‘𝑦))) → (𝑀 ∈ Mnd → (𝑂 Σg (𝑦 ++ ⟨“𝑧”⟩)) = (𝑀 Σg (reverse‘(𝑦 ++ ⟨“𝑧”⟩))))))
677, 12, 17, 22, 29, 66wrdind 14647 . 2 (𝑊 ∈ Word 𝐵 → (𝑀 ∈ Mnd → (𝑂 Σg 𝑊) = (𝑀 Σg (reverse‘𝑊))))
6867impcom 407 1 ((𝑀 ∈ Mnd ∧ 𝑊 ∈ Word 𝐵) → (𝑂 Σg 𝑊) = (𝑀 Σg (reverse‘𝑊)))
Colors of variables: wff setvar class
Syntax hints:  wi 4  wa 395   = wceq 1542  wcel 2114  c0 4284  cfv 6491  (class class class)co 7358  Word cword 14438   ++ cconcat 14495  ⟨“cs1 14521  reversecreverse 14683  Basecbs 17138  +gcplusg 17179  0gc0g 17361   Σg cgsu 17362  Mndcmnd 18661  oppgcoppg 19276
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 1912  ax-6 1969  ax-7 2010  ax-8 2116  ax-9 2124  ax-10 2147  ax-11 2163  ax-12 2183  ax-ext 2707  ax-rep 5223  ax-sep 5240  ax-nul 5250  ax-pow 5309  ax-pr 5376  ax-un 7680  ax-cnex 11084  ax-resscn 11085  ax-1cn 11086  ax-icn 11087  ax-addcl 11088  ax-addrcl 11089  ax-mulcl 11090  ax-mulrcl 11091  ax-mulcom 11092  ax-addass 11093  ax-mulass 11094  ax-distr 11095  ax-i2m1 11096  ax-1ne0 11097  ax-1rid 11098  ax-rnegex 11099  ax-rrecex 11100  ax-cnre 11101  ax-pre-lttri 11102  ax-pre-lttrn 11103  ax-pre-ltadd 11104  ax-pre-mulgt0 11105
This theorem depends on definitions:  df-bi 207  df-an 396  df-or 849  df-3or 1088  df-3an 1089  df-tru 1545  df-fal 1555  df-ex 1782  df-nf 1786  df-sb 2069  df-mo 2538  df-eu 2568  df-clab 2714  df-cleq 2727  df-clel 2810  df-nfc 2884  df-ne 2932  df-nel 3036  df-ral 3051  df-rex 3060  df-rmo 3349  df-reu 3350  df-rab 3399  df-v 3441  df-sbc 3740  df-csb 3849  df-dif 3903  df-un 3905  df-in 3907  df-ss 3917  df-pss 3920  df-nul 4285  df-if 4479  df-pw 4555  df-sn 4580  df-pr 4582  df-op 4586  df-uni 4863  df-int 4902  df-iun 4947  df-br 5098  df-opab 5160  df-mpt 5179  df-tr 5205  df-id 5518  df-eprel 5523  df-po 5531  df-so 5532  df-fr 5576  df-we 5578  df-xp 5629  df-rel 5630  df-cnv 5631  df-co 5632  df-dm 5633  df-rn 5634  df-res 5635  df-ima 5636  df-pred 6258  df-ord 6319  df-on 6320  df-lim 6321  df-suc 6322  df-iota 6447  df-fun 6493  df-fn 6494  df-f 6495  df-f1 6496  df-fo 6497  df-f1o 6498  df-fv 6499  df-riota 7315  df-ov 7361  df-oprab 7362  df-mpo 7363  df-om 7809  df-1st 7933  df-2nd 7934  df-tpos 8168  df-frecs 8223  df-wrecs 8254  df-recs 8303  df-rdg 8341  df-1o 8397  df-er 8635  df-en 8886  df-dom 8887  df-sdom 8888  df-fin 8889  df-card 9853  df-pnf 11170  df-mnf 11171  df-xr 11172  df-ltxr 11173  df-le 11174  df-sub 11368  df-neg 11369  df-nn 12148  df-2 12210  df-n0 12404  df-xnn0 12477  df-z 12491  df-uz 12754  df-fz 13426  df-fzo 13573  df-seq 13927  df-hash 14256  df-word 14439  df-lsw 14488  df-concat 14496  df-s1 14522  df-substr 14567  df-pfx 14597  df-reverse 14684  df-sets 17093  df-slot 17111  df-ndx 17123  df-base 17139  df-ress 17160  df-plusg 17192  df-0g 17363  df-gsum 17364  df-mgm 18567  df-sgrp 18646  df-mnd 18662  df-submnd 18711  df-oppg 19277
This theorem is referenced by:  symgtrinv  19403
  Copyright terms: Public domain W3C validator