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

Theorem setscom 16733
Description: Component-setting is commutative when the x-values are different. (Contributed by Mario Carneiro, 5-Dec-2014.) (Revised by Mario Carneiro, 30-Apr-2015.)
Hypotheses
Ref Expression
setscom.1 𝐴 ∈ V
setscom.2 𝐵 ∈ V
Assertion
Ref Expression
setscom (((𝑆𝑉𝐴𝐵) ∧ (𝐶𝑊𝐷𝑋)) → ((𝑆 sSet ⟨𝐴, 𝐶⟩) sSet ⟨𝐵, 𝐷⟩) = ((𝑆 sSet ⟨𝐵, 𝐷⟩) sSet ⟨𝐴, 𝐶⟩))

Proof of Theorem setscom
StepHypRef Expression
1 rescom 5877 . . . . . 6 ((𝑆 ↾ (V ∖ {𝐴})) ↾ (V ∖ {𝐵})) = ((𝑆 ↾ (V ∖ {𝐵})) ↾ (V ∖ {𝐴}))
21uneq1i 4073 . . . . 5 (((𝑆 ↾ (V ∖ {𝐴})) ↾ (V ∖ {𝐵})) ∪ {⟨𝐴, 𝐶⟩}) = (((𝑆 ↾ (V ∖ {𝐵})) ↾ (V ∖ {𝐴})) ∪ {⟨𝐴, 𝐶⟩})
32uneq1i 4073 . . . 4 ((((𝑆 ↾ (V ∖ {𝐴})) ↾ (V ∖ {𝐵})) ∪ {⟨𝐴, 𝐶⟩}) ∪ {⟨𝐵, 𝐷⟩}) = ((((𝑆 ↾ (V ∖ {𝐵})) ↾ (V ∖ {𝐴})) ∪ {⟨𝐴, 𝐶⟩}) ∪ {⟨𝐵, 𝐷⟩})
4 un23 4082 . . . 4 ((((𝑆 ↾ (V ∖ {𝐵})) ↾ (V ∖ {𝐴})) ∪ {⟨𝐴, 𝐶⟩}) ∪ {⟨𝐵, 𝐷⟩}) = ((((𝑆 ↾ (V ∖ {𝐵})) ↾ (V ∖ {𝐴})) ∪ {⟨𝐵, 𝐷⟩}) ∪ {⟨𝐴, 𝐶⟩})
53, 4eqtri 2765 . . 3 ((((𝑆 ↾ (V ∖ {𝐴})) ↾ (V ∖ {𝐵})) ∪ {⟨𝐴, 𝐶⟩}) ∪ {⟨𝐵, 𝐷⟩}) = ((((𝑆 ↾ (V ∖ {𝐵})) ↾ (V ∖ {𝐴})) ∪ {⟨𝐵, 𝐷⟩}) ∪ {⟨𝐴, 𝐶⟩})
6 setsval 16720 . . . . . . 7 ((𝑆𝑉𝐶𝑊) → (𝑆 sSet ⟨𝐴, 𝐶⟩) = ((𝑆 ↾ (V ∖ {𝐴})) ∪ {⟨𝐴, 𝐶⟩}))
76ad2ant2r 747 . . . . . 6 (((𝑆𝑉𝐴𝐵) ∧ (𝐶𝑊𝐷𝑋)) → (𝑆 sSet ⟨𝐴, 𝐶⟩) = ((𝑆 ↾ (V ∖ {𝐴})) ∪ {⟨𝐴, 𝐶⟩}))
87reseq1d 5850 . . . . 5 (((𝑆𝑉𝐴𝐵) ∧ (𝐶𝑊𝐷𝑋)) → ((𝑆 sSet ⟨𝐴, 𝐶⟩) ↾ (V ∖ {𝐵})) = (((𝑆 ↾ (V ∖ {𝐴})) ∪ {⟨𝐴, 𝐶⟩}) ↾ (V ∖ {𝐵})))
9 resundir 5866 . . . . . 6 (((𝑆 ↾ (V ∖ {𝐴})) ∪ {⟨𝐴, 𝐶⟩}) ↾ (V ∖ {𝐵})) = (((𝑆 ↾ (V ∖ {𝐴})) ↾ (V ∖ {𝐵})) ∪ ({⟨𝐴, 𝐶⟩} ↾ (V ∖ {𝐵})))
10 setscom.1 . . . . . . . . . 10 𝐴 ∈ V
11 elex 3426 . . . . . . . . . . 11 (𝐶𝑊𝐶 ∈ V)
1211ad2antrl 728 . . . . . . . . . 10 (((𝑆𝑉𝐴𝐵) ∧ (𝐶𝑊𝐷𝑋)) → 𝐶 ∈ V)
13 opelxpi 5588 . . . . . . . . . 10 ((𝐴 ∈ V ∧ 𝐶 ∈ V) → ⟨𝐴, 𝐶⟩ ∈ (V × V))
1410, 12, 13sylancr 590 . . . . . . . . 9 (((𝑆𝑉𝐴𝐵) ∧ (𝐶𝑊𝐷𝑋)) → ⟨𝐴, 𝐶⟩ ∈ (V × V))
15 opex 5348 . . . . . . . . . 10 𝐴, 𝐶⟩ ∈ V
1615relsn 5674 . . . . . . . . 9 (Rel {⟨𝐴, 𝐶⟩} ↔ ⟨𝐴, 𝐶⟩ ∈ (V × V))
1714, 16sylibr 237 . . . . . . . 8 (((𝑆𝑉𝐴𝐵) ∧ (𝐶𝑊𝐷𝑋)) → Rel {⟨𝐴, 𝐶⟩})
18 dmsnopss 6077 . . . . . . . . 9 dom {⟨𝐴, 𝐶⟩} ⊆ {𝐴}
19 disjsn2 4628 . . . . . . . . . . 11 (𝐴𝐵 → ({𝐴} ∩ {𝐵}) = ∅)
2019ad2antlr 727 . . . . . . . . . 10 (((𝑆𝑉𝐴𝐵) ∧ (𝐶𝑊𝐷𝑋)) → ({𝐴} ∩ {𝐵}) = ∅)
21 disj2 4372 . . . . . . . . . 10 (({𝐴} ∩ {𝐵}) = ∅ ↔ {𝐴} ⊆ (V ∖ {𝐵}))
2220, 21sylib 221 . . . . . . . . 9 (((𝑆𝑉𝐴𝐵) ∧ (𝐶𝑊𝐷𝑋)) → {𝐴} ⊆ (V ∖ {𝐵}))
2318, 22sstrid 3912 . . . . . . . 8 (((𝑆𝑉𝐴𝐵) ∧ (𝐶𝑊𝐷𝑋)) → dom {⟨𝐴, 𝐶⟩} ⊆ (V ∖ {𝐵}))
24 relssres 5892 . . . . . . . 8 ((Rel {⟨𝐴, 𝐶⟩} ∧ dom {⟨𝐴, 𝐶⟩} ⊆ (V ∖ {𝐵})) → ({⟨𝐴, 𝐶⟩} ↾ (V ∖ {𝐵})) = {⟨𝐴, 𝐶⟩})
2517, 23, 24syl2anc 587 . . . . . . 7 (((𝑆𝑉𝐴𝐵) ∧ (𝐶𝑊𝐷𝑋)) → ({⟨𝐴, 𝐶⟩} ↾ (V ∖ {𝐵})) = {⟨𝐴, 𝐶⟩})
2625uneq2d 4077 . . . . . 6 (((𝑆𝑉𝐴𝐵) ∧ (𝐶𝑊𝐷𝑋)) → (((𝑆 ↾ (V ∖ {𝐴})) ↾ (V ∖ {𝐵})) ∪ ({⟨𝐴, 𝐶⟩} ↾ (V ∖ {𝐵}))) = (((𝑆 ↾ (V ∖ {𝐴})) ↾ (V ∖ {𝐵})) ∪ {⟨𝐴, 𝐶⟩}))
279, 26syl5eq 2790 . . . . 5 (((𝑆𝑉𝐴𝐵) ∧ (𝐶𝑊𝐷𝑋)) → (((𝑆 ↾ (V ∖ {𝐴})) ∪ {⟨𝐴, 𝐶⟩}) ↾ (V ∖ {𝐵})) = (((𝑆 ↾ (V ∖ {𝐴})) ↾ (V ∖ {𝐵})) ∪ {⟨𝐴, 𝐶⟩}))
288, 27eqtrd 2777 . . . 4 (((𝑆𝑉𝐴𝐵) ∧ (𝐶𝑊𝐷𝑋)) → ((𝑆 sSet ⟨𝐴, 𝐶⟩) ↾ (V ∖ {𝐵})) = (((𝑆 ↾ (V ∖ {𝐴})) ↾ (V ∖ {𝐵})) ∪ {⟨𝐴, 𝐶⟩}))
2928uneq1d 4076 . . 3 (((𝑆𝑉𝐴𝐵) ∧ (𝐶𝑊𝐷𝑋)) → (((𝑆 sSet ⟨𝐴, 𝐶⟩) ↾ (V ∖ {𝐵})) ∪ {⟨𝐵, 𝐷⟩}) = ((((𝑆 ↾ (V ∖ {𝐴})) ↾ (V ∖ {𝐵})) ∪ {⟨𝐴, 𝐶⟩}) ∪ {⟨𝐵, 𝐷⟩}))
30 setsval 16720 . . . . . . 7 ((𝑆𝑉𝐷𝑋) → (𝑆 sSet ⟨𝐵, 𝐷⟩) = ((𝑆 ↾ (V ∖ {𝐵})) ∪ {⟨𝐵, 𝐷⟩}))
3130reseq1d 5850 . . . . . 6 ((𝑆𝑉𝐷𝑋) → ((𝑆 sSet ⟨𝐵, 𝐷⟩) ↾ (V ∖ {𝐴})) = (((𝑆 ↾ (V ∖ {𝐵})) ∪ {⟨𝐵, 𝐷⟩}) ↾ (V ∖ {𝐴})))
3231ad2ant2rl 749 . . . . 5 (((𝑆𝑉𝐴𝐵) ∧ (𝐶𝑊𝐷𝑋)) → ((𝑆 sSet ⟨𝐵, 𝐷⟩) ↾ (V ∖ {𝐴})) = (((𝑆 ↾ (V ∖ {𝐵})) ∪ {⟨𝐵, 𝐷⟩}) ↾ (V ∖ {𝐴})))
33 resundir 5866 . . . . . 6 (((𝑆 ↾ (V ∖ {𝐵})) ∪ {⟨𝐵, 𝐷⟩}) ↾ (V ∖ {𝐴})) = (((𝑆 ↾ (V ∖ {𝐵})) ↾ (V ∖ {𝐴})) ∪ ({⟨𝐵, 𝐷⟩} ↾ (V ∖ {𝐴})))
34 setscom.2 . . . . . . . . . 10 𝐵 ∈ V
35 elex 3426 . . . . . . . . . . 11 (𝐷𝑋𝐷 ∈ V)
3635ad2antll 729 . . . . . . . . . 10 (((𝑆𝑉𝐴𝐵) ∧ (𝐶𝑊𝐷𝑋)) → 𝐷 ∈ V)
37 opelxpi 5588 . . . . . . . . . 10 ((𝐵 ∈ V ∧ 𝐷 ∈ V) → ⟨𝐵, 𝐷⟩ ∈ (V × V))
3834, 36, 37sylancr 590 . . . . . . . . 9 (((𝑆𝑉𝐴𝐵) ∧ (𝐶𝑊𝐷𝑋)) → ⟨𝐵, 𝐷⟩ ∈ (V × V))
39 opex 5348 . . . . . . . . . 10 𝐵, 𝐷⟩ ∈ V
4039relsn 5674 . . . . . . . . 9 (Rel {⟨𝐵, 𝐷⟩} ↔ ⟨𝐵, 𝐷⟩ ∈ (V × V))
4138, 40sylibr 237 . . . . . . . 8 (((𝑆𝑉𝐴𝐵) ∧ (𝐶𝑊𝐷𝑋)) → Rel {⟨𝐵, 𝐷⟩})
42 dmsnopss 6077 . . . . . . . . 9 dom {⟨𝐵, 𝐷⟩} ⊆ {𝐵}
43 ssv 3925 . . . . . . . . . . 11 {𝐴} ⊆ V
44 ssv 3925 . . . . . . . . . . 11 {𝐵} ⊆ V
45 ssconb 4052 . . . . . . . . . . 11 (({𝐴} ⊆ V ∧ {𝐵} ⊆ V) → ({𝐴} ⊆ (V ∖ {𝐵}) ↔ {𝐵} ⊆ (V ∖ {𝐴})))
4643, 44, 45mp2an 692 . . . . . . . . . 10 ({𝐴} ⊆ (V ∖ {𝐵}) ↔ {𝐵} ⊆ (V ∖ {𝐴}))
4722, 46sylib 221 . . . . . . . . 9 (((𝑆𝑉𝐴𝐵) ∧ (𝐶𝑊𝐷𝑋)) → {𝐵} ⊆ (V ∖ {𝐴}))
4842, 47sstrid 3912 . . . . . . . 8 (((𝑆𝑉𝐴𝐵) ∧ (𝐶𝑊𝐷𝑋)) → dom {⟨𝐵, 𝐷⟩} ⊆ (V ∖ {𝐴}))
49 relssres 5892 . . . . . . . 8 ((Rel {⟨𝐵, 𝐷⟩} ∧ dom {⟨𝐵, 𝐷⟩} ⊆ (V ∖ {𝐴})) → ({⟨𝐵, 𝐷⟩} ↾ (V ∖ {𝐴})) = {⟨𝐵, 𝐷⟩})
5041, 48, 49syl2anc 587 . . . . . . 7 (((𝑆𝑉𝐴𝐵) ∧ (𝐶𝑊𝐷𝑋)) → ({⟨𝐵, 𝐷⟩} ↾ (V ∖ {𝐴})) = {⟨𝐵, 𝐷⟩})
5150uneq2d 4077 . . . . . 6 (((𝑆𝑉𝐴𝐵) ∧ (𝐶𝑊𝐷𝑋)) → (((𝑆 ↾ (V ∖ {𝐵})) ↾ (V ∖ {𝐴})) ∪ ({⟨𝐵, 𝐷⟩} ↾ (V ∖ {𝐴}))) = (((𝑆 ↾ (V ∖ {𝐵})) ↾ (V ∖ {𝐴})) ∪ {⟨𝐵, 𝐷⟩}))
5233, 51syl5eq 2790 . . . . 5 (((𝑆𝑉𝐴𝐵) ∧ (𝐶𝑊𝐷𝑋)) → (((𝑆 ↾ (V ∖ {𝐵})) ∪ {⟨𝐵, 𝐷⟩}) ↾ (V ∖ {𝐴})) = (((𝑆 ↾ (V ∖ {𝐵})) ↾ (V ∖ {𝐴})) ∪ {⟨𝐵, 𝐷⟩}))
5332, 52eqtrd 2777 . . . 4 (((𝑆𝑉𝐴𝐵) ∧ (𝐶𝑊𝐷𝑋)) → ((𝑆 sSet ⟨𝐵, 𝐷⟩) ↾ (V ∖ {𝐴})) = (((𝑆 ↾ (V ∖ {𝐵})) ↾ (V ∖ {𝐴})) ∪ {⟨𝐵, 𝐷⟩}))
5453uneq1d 4076 . . 3 (((𝑆𝑉𝐴𝐵) ∧ (𝐶𝑊𝐷𝑋)) → (((𝑆 sSet ⟨𝐵, 𝐷⟩) ↾ (V ∖ {𝐴})) ∪ {⟨𝐴, 𝐶⟩}) = ((((𝑆 ↾ (V ∖ {𝐵})) ↾ (V ∖ {𝐴})) ∪ {⟨𝐵, 𝐷⟩}) ∪ {⟨𝐴, 𝐶⟩}))
555, 29, 543eqtr4a 2804 . 2 (((𝑆𝑉𝐴𝐵) ∧ (𝐶𝑊𝐷𝑋)) → (((𝑆 sSet ⟨𝐴, 𝐶⟩) ↾ (V ∖ {𝐵})) ∪ {⟨𝐵, 𝐷⟩}) = (((𝑆 sSet ⟨𝐵, 𝐷⟩) ↾ (V ∖ {𝐴})) ∪ {⟨𝐴, 𝐶⟩}))
56 ovex 7246 . . 3 (𝑆 sSet ⟨𝐴, 𝐶⟩) ∈ V
57 simprr 773 . . 3 (((𝑆𝑉𝐴𝐵) ∧ (𝐶𝑊𝐷𝑋)) → 𝐷𝑋)
58 setsval 16720 . . 3 (((𝑆 sSet ⟨𝐴, 𝐶⟩) ∈ V ∧ 𝐷𝑋) → ((𝑆 sSet ⟨𝐴, 𝐶⟩) sSet ⟨𝐵, 𝐷⟩) = (((𝑆 sSet ⟨𝐴, 𝐶⟩) ↾ (V ∖ {𝐵})) ∪ {⟨𝐵, 𝐷⟩}))
5956, 57, 58sylancr 590 . 2 (((𝑆𝑉𝐴𝐵) ∧ (𝐶𝑊𝐷𝑋)) → ((𝑆 sSet ⟨𝐴, 𝐶⟩) sSet ⟨𝐵, 𝐷⟩) = (((𝑆 sSet ⟨𝐴, 𝐶⟩) ↾ (V ∖ {𝐵})) ∪ {⟨𝐵, 𝐷⟩}))
60 ovex 7246 . . 3 (𝑆 sSet ⟨𝐵, 𝐷⟩) ∈ V
61 simprl 771 . . 3 (((𝑆𝑉𝐴𝐵) ∧ (𝐶𝑊𝐷𝑋)) → 𝐶𝑊)
62 setsval 16720 . . 3 (((𝑆 sSet ⟨𝐵, 𝐷⟩) ∈ V ∧ 𝐶𝑊) → ((𝑆 sSet ⟨𝐵, 𝐷⟩) sSet ⟨𝐴, 𝐶⟩) = (((𝑆 sSet ⟨𝐵, 𝐷⟩) ↾ (V ∖ {𝐴})) ∪ {⟨𝐴, 𝐶⟩}))
6360, 61, 62sylancr 590 . 2 (((𝑆𝑉𝐴𝐵) ∧ (𝐶𝑊𝐷𝑋)) → ((𝑆 sSet ⟨𝐵, 𝐷⟩) sSet ⟨𝐴, 𝐶⟩) = (((𝑆 sSet ⟨𝐵, 𝐷⟩) ↾ (V ∖ {𝐴})) ∪ {⟨𝐴, 𝐶⟩}))
6455, 59, 633eqtr4d 2787 1 (((𝑆𝑉𝐴𝐵) ∧ (𝐶𝑊𝐷𝑋)) → ((𝑆 sSet ⟨𝐴, 𝐶⟩) sSet ⟨𝐵, 𝐷⟩) = ((𝑆 sSet ⟨𝐵, 𝐷⟩) sSet ⟨𝐴, 𝐶⟩))
Colors of variables: wff setvar class
Syntax hints:  wi 4  wb 209  wa 399   = wceq 1543  wcel 2110  wne 2940  Vcvv 3408  cdif 3863  cun 3864  cin 3865  wss 3866  c0 4237  {csn 4541  cop 4547   × cxp 5549  dom cdm 5551  cres 5553  Rel wrel 5556  (class class class)co 7213   sSet csts 16716
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 2708  ax-sep 5192  ax-nul 5199  ax-pr 5322  ax-un 7523
This theorem depends on definitions:  df-bi 210  df-an 400  df-or 848  df-3an 1091  df-tru 1546  df-fal 1556  df-ex 1788  df-nf 1792  df-sb 2071  df-mo 2539  df-eu 2568  df-clab 2715  df-cleq 2729  df-clel 2816  df-nfc 2886  df-ne 2941  df-ral 3066  df-rex 3067  df-rab 3070  df-v 3410  df-sbc 3695  df-dif 3869  df-un 3871  df-in 3873  df-ss 3883  df-nul 4238  df-if 4440  df-sn 4542  df-pr 4544  df-op 4548  df-uni 4820  df-br 5054  df-opab 5116  df-id 5455  df-xp 5557  df-rel 5558  df-cnv 5559  df-co 5560  df-dm 5561  df-res 5563  df-iota 6338  df-fun 6382  df-fv 6388  df-ov 7216  df-oprab 7217  df-mpo 7218  df-sets 16717
This theorem is referenced by:  rescabs  17339  mgpress  19515
  Copyright terms: Public domain W3C validator