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

Theorem opeliun2xp 5709
Description: Membership of an ordered pair in a union of Cartesian products over its second component, analogous to opeliunxp 5708. (Contributed by AV, 30-Mar-2019.)
Assertion
Ref Expression
opeliun2xp (⟨𝐶, 𝑦⟩ ∈ 𝑦𝐵 (𝐴 × {𝑦}) ↔ (𝑦𝐵𝐶𝐴))

Proof of Theorem opeliun2xp
Dummy variables 𝑥 𝑧 are mutually distinct and distinct from all other variables.
StepHypRef Expression
1 df-iun 4960 . . 3 𝑦𝐵 (𝐴 × {𝑦}) = {𝑥 ∣ ∃𝑦𝐵 𝑥 ∈ (𝐴 × {𝑦})}
21eleq2i 2821 . 2 (⟨𝐶, 𝑦⟩ ∈ 𝑦𝐵 (𝐴 × {𝑦}) ↔ ⟨𝐶, 𝑦⟩ ∈ {𝑥 ∣ ∃𝑦𝐵 𝑥 ∈ (𝐴 × {𝑦})})
3 opex 5427 . . 3 𝐶, 𝑦⟩ ∈ V
4 df-rex 3055 . . . . 5 (∃𝑦𝐵 𝑥 ∈ (𝐴 × {𝑦}) ↔ ∃𝑦(𝑦𝐵𝑥 ∈ (𝐴 × {𝑦})))
5 nfv 1914 . . . . . 6 𝑧(𝑦𝐵𝑥 ∈ (𝐴 × {𝑦}))
6 nfs1v 2157 . . . . . . 7 𝑦[𝑧 / 𝑦]𝑦𝐵
7 nfcsb1v 3889 . . . . . . . . 9 𝑦𝑧 / 𝑦𝐴
8 nfcv 2892 . . . . . . . . 9 𝑦{𝑧}
97, 8nfxp 5674 . . . . . . . 8 𝑦(𝑧 / 𝑦𝐴 × {𝑧})
109nfcri 2884 . . . . . . 7 𝑦 𝑥 ∈ (𝑧 / 𝑦𝐴 × {𝑧})
116, 10nfan 1899 . . . . . 6 𝑦([𝑧 / 𝑦]𝑦𝐵𝑥 ∈ (𝑧 / 𝑦𝐴 × {𝑧}))
12 sbequ12 2252 . . . . . . 7 (𝑦 = 𝑧 → (𝑦𝐵 ↔ [𝑧 / 𝑦]𝑦𝐵))
13 csbeq1a 3879 . . . . . . . . 9 (𝑦 = 𝑧𝐴 = 𝑧 / 𝑦𝐴)
14 sneq 4602 . . . . . . . . 9 (𝑦 = 𝑧 → {𝑦} = {𝑧})
1513, 14xpeq12d 5672 . . . . . . . 8 (𝑦 = 𝑧 → (𝐴 × {𝑦}) = (𝑧 / 𝑦𝐴 × {𝑧}))
1615eleq2d 2815 . . . . . . 7 (𝑦 = 𝑧 → (𝑥 ∈ (𝐴 × {𝑦}) ↔ 𝑥 ∈ (𝑧 / 𝑦𝐴 × {𝑧})))
1712, 16anbi12d 632 . . . . . 6 (𝑦 = 𝑧 → ((𝑦𝐵𝑥 ∈ (𝐴 × {𝑦})) ↔ ([𝑧 / 𝑦]𝑦𝐵𝑥 ∈ (𝑧 / 𝑦𝐴 × {𝑧}))))
185, 11, 17cbvexv1 2340 . . . . 5 (∃𝑦(𝑦𝐵𝑥 ∈ (𝐴 × {𝑦})) ↔ ∃𝑧([𝑧 / 𝑦]𝑦𝐵𝑥 ∈ (𝑧 / 𝑦𝐴 × {𝑧})))
194, 18bitri 275 . . . 4 (∃𝑦𝐵 𝑥 ∈ (𝐴 × {𝑦}) ↔ ∃𝑧([𝑧 / 𝑦]𝑦𝐵𝑥 ∈ (𝑧 / 𝑦𝐴 × {𝑧})))
20 eleq1 2817 . . . . . 6 (𝑥 = ⟨𝐶, 𝑦⟩ → (𝑥 ∈ (𝑧 / 𝑦𝐴 × {𝑧}) ↔ ⟨𝐶, 𝑦⟩ ∈ (𝑧 / 𝑦𝐴 × {𝑧})))
2120anbi2d 630 . . . . 5 (𝑥 = ⟨𝐶, 𝑦⟩ → (([𝑧 / 𝑦]𝑦𝐵𝑥 ∈ (𝑧 / 𝑦𝐴 × {𝑧})) ↔ ([𝑧 / 𝑦]𝑦𝐵 ∧ ⟨𝐶, 𝑦⟩ ∈ (𝑧 / 𝑦𝐴 × {𝑧}))))
2221exbidv 1921 . . . 4 (𝑥 = ⟨𝐶, 𝑦⟩ → (∃𝑧([𝑧 / 𝑦]𝑦𝐵𝑥 ∈ (𝑧 / 𝑦𝐴 × {𝑧})) ↔ ∃𝑧([𝑧 / 𝑦]𝑦𝐵 ∧ ⟨𝐶, 𝑦⟩ ∈ (𝑧 / 𝑦𝐴 × {𝑧}))))
2319, 22bitrid 283 . . 3 (𝑥 = ⟨𝐶, 𝑦⟩ → (∃𝑦𝐵 𝑥 ∈ (𝐴 × {𝑦}) ↔ ∃𝑧([𝑧 / 𝑦]𝑦𝐵 ∧ ⟨𝐶, 𝑦⟩ ∈ (𝑧 / 𝑦𝐴 × {𝑧}))))
243, 23elab 3649 . 2 (⟨𝐶, 𝑦⟩ ∈ {𝑥 ∣ ∃𝑦𝐵 𝑥 ∈ (𝐴 × {𝑦})} ↔ ∃𝑧([𝑧 / 𝑦]𝑦𝐵 ∧ ⟨𝐶, 𝑦⟩ ∈ (𝑧 / 𝑦𝐴 × {𝑧})))
25 opelxp 5677 . . . . . 6 (⟨𝐶, 𝑦⟩ ∈ (𝑧 / 𝑦𝐴 × {𝑧}) ↔ (𝐶𝑧 / 𝑦𝐴𝑦 ∈ {𝑧}))
2625anbi2i 623 . . . . 5 (([𝑧 / 𝑦]𝑦𝐵 ∧ ⟨𝐶, 𝑦⟩ ∈ (𝑧 / 𝑦𝐴 × {𝑧})) ↔ ([𝑧 / 𝑦]𝑦𝐵 ∧ (𝐶𝑧 / 𝑦𝐴𝑦 ∈ {𝑧})))
27 an13 647 . . . . . 6 (([𝑧 / 𝑦]𝑦𝐵 ∧ (𝐶𝑧 / 𝑦𝐴𝑦 ∈ {𝑧})) ↔ (𝑦 ∈ {𝑧} ∧ (𝐶𝑧 / 𝑦𝐴 ∧ [𝑧 / 𝑦]𝑦𝐵)))
28 ancom 460 . . . . . . 7 ((𝐶𝑧 / 𝑦𝐴 ∧ [𝑧 / 𝑦]𝑦𝐵) ↔ ([𝑧 / 𝑦]𝑦𝐵𝐶𝑧 / 𝑦𝐴))
2928anbi2i 623 . . . . . 6 ((𝑦 ∈ {𝑧} ∧ (𝐶𝑧 / 𝑦𝐴 ∧ [𝑧 / 𝑦]𝑦𝐵)) ↔ (𝑦 ∈ {𝑧} ∧ ([𝑧 / 𝑦]𝑦𝐵𝐶𝑧 / 𝑦𝐴)))
3027, 29bitri 275 . . . . 5 (([𝑧 / 𝑦]𝑦𝐵 ∧ (𝐶𝑧 / 𝑦𝐴𝑦 ∈ {𝑧})) ↔ (𝑦 ∈ {𝑧} ∧ ([𝑧 / 𝑦]𝑦𝐵𝐶𝑧 / 𝑦𝐴)))
31 velsn 4608 . . . . . . 7 (𝑦 ∈ {𝑧} ↔ 𝑦 = 𝑧)
32 equcom 2018 . . . . . . 7 (𝑦 = 𝑧𝑧 = 𝑦)
3331, 32bitri 275 . . . . . 6 (𝑦 ∈ {𝑧} ↔ 𝑧 = 𝑦)
3433anbi1i 624 . . . . 5 ((𝑦 ∈ {𝑧} ∧ ([𝑧 / 𝑦]𝑦𝐵𝐶𝑧 / 𝑦𝐴)) ↔ (𝑧 = 𝑦 ∧ ([𝑧 / 𝑦]𝑦𝐵𝐶𝑧 / 𝑦𝐴)))
3526, 30, 343bitri 297 . . . 4 (([𝑧 / 𝑦]𝑦𝐵 ∧ ⟨𝐶, 𝑦⟩ ∈ (𝑧 / 𝑦𝐴 × {𝑧})) ↔ (𝑧 = 𝑦 ∧ ([𝑧 / 𝑦]𝑦𝐵𝐶𝑧 / 𝑦𝐴)))
3635exbii 1848 . . 3 (∃𝑧([𝑧 / 𝑦]𝑦𝐵 ∧ ⟨𝐶, 𝑦⟩ ∈ (𝑧 / 𝑦𝐴 × {𝑧})) ↔ ∃𝑧(𝑧 = 𝑦 ∧ ([𝑧 / 𝑦]𝑦𝐵𝐶𝑧 / 𝑦𝐴)))
37 sbequ12r 2253 . . . . 5 (𝑧 = 𝑦 → ([𝑧 / 𝑦]𝑦𝐵𝑦𝐵))
3813equcoms 2020 . . . . . . 7 (𝑧 = 𝑦𝐴 = 𝑧 / 𝑦𝐴)
3938eqcomd 2736 . . . . . 6 (𝑧 = 𝑦𝑧 / 𝑦𝐴 = 𝐴)
4039eleq2d 2815 . . . . 5 (𝑧 = 𝑦 → (𝐶𝑧 / 𝑦𝐴𝐶𝐴))
4137, 40anbi12d 632 . . . 4 (𝑧 = 𝑦 → (([𝑧 / 𝑦]𝑦𝐵𝐶𝑧 / 𝑦𝐴) ↔ (𝑦𝐵𝐶𝐴)))
4241equsexvw 2005 . . 3 (∃𝑧(𝑧 = 𝑦 ∧ ([𝑧 / 𝑦]𝑦𝐵𝐶𝑧 / 𝑦𝐴)) ↔ (𝑦𝐵𝐶𝐴))
4336, 42bitri 275 . 2 (∃𝑧([𝑧 / 𝑦]𝑦𝐵 ∧ ⟨𝐶, 𝑦⟩ ∈ (𝑧 / 𝑦𝐴 × {𝑧})) ↔ (𝑦𝐵𝐶𝐴))
442, 24, 433bitri 297 1 (⟨𝐶, 𝑦⟩ ∈ 𝑦𝐵 (𝐴 × {𝑦}) ↔ (𝑦𝐵𝐶𝐴))
Colors of variables: wff setvar class
Syntax hints:  wb 206  wa 395   = wceq 1540  wex 1779  [wsb 2065  wcel 2109  {cab 2708  wrex 3054  csb 3865  {csn 4592  cop 4598   ciun 4958   × cxp 5639
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-3 8  ax-gen 1795  ax-4 1809  ax-5 1910  ax-6 1967  ax-7 2008  ax-8 2111  ax-9 2119  ax-10 2142  ax-11 2158  ax-12 2178  ax-ext 2702  ax-sep 5254  ax-nul 5264  ax-pr 5390
This theorem depends on definitions:  df-bi 207  df-an 396  df-or 848  df-3an 1088  df-tru 1543  df-fal 1553  df-ex 1780  df-nf 1784  df-sb 2066  df-clab 2709  df-cleq 2722  df-clel 2804  df-nfc 2879  df-ral 3046  df-rex 3055  df-rab 3409  df-v 3452  df-sbc 3757  df-csb 3866  df-dif 3920  df-un 3922  df-ss 3934  df-nul 4300  df-if 4492  df-sn 4593  df-pr 4595  df-op 4599  df-iun 4960  df-opab 5173  df-xp 5647
This theorem is referenced by:  fldextrspunlsplem  33675  eliunxp2  48326
  Copyright terms: Public domain W3C validator