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

Theorem xpco 6262
Description: Composition of two Cartesian products. (Contributed by Thierry Arnoux, 17-Nov-2017.)
Assertion
Ref Expression
xpco (𝐵 ≠ ∅ → ((𝐵 × 𝐶) ∘ (𝐴 × 𝐵)) = (𝐴 × 𝐶))

Proof of Theorem xpco
Dummy variables 𝑥 𝑦 𝑧 are mutually distinct and distinct from all other variables.
StepHypRef Expression
1 n0 4316 . . . . . 6 (𝐵 ≠ ∅ ↔ ∃𝑦 𝑦𝐵)
21biimpi 216 . . . . 5 (𝐵 ≠ ∅ → ∃𝑦 𝑦𝐵)
32biantrurd 532 . . . 4 (𝐵 ≠ ∅ → ((𝑥𝐴𝑧𝐶) ↔ (∃𝑦 𝑦𝐵 ∧ (𝑥𝐴𝑧𝐶))))
4 ancom 460 . . . . . . . 8 ((𝑥𝐴𝑦𝐵) ↔ (𝑦𝐵𝑥𝐴))
54anbi1i 624 . . . . . . 7 (((𝑥𝐴𝑦𝐵) ∧ (𝑦𝐵𝑧𝐶)) ↔ ((𝑦𝐵𝑥𝐴) ∧ (𝑦𝐵𝑧𝐶)))
6 brxp 5687 . . . . . . . 8 (𝑥(𝐴 × 𝐵)𝑦 ↔ (𝑥𝐴𝑦𝐵))
7 brxp 5687 . . . . . . . 8 (𝑦(𝐵 × 𝐶)𝑧 ↔ (𝑦𝐵𝑧𝐶))
86, 7anbi12i 628 . . . . . . 7 ((𝑥(𝐴 × 𝐵)𝑦𝑦(𝐵 × 𝐶)𝑧) ↔ ((𝑥𝐴𝑦𝐵) ∧ (𝑦𝐵𝑧𝐶)))
9 anandi 676 . . . . . . 7 ((𝑦𝐵 ∧ (𝑥𝐴𝑧𝐶)) ↔ ((𝑦𝐵𝑥𝐴) ∧ (𝑦𝐵𝑧𝐶)))
105, 8, 93bitr4i 303 . . . . . 6 ((𝑥(𝐴 × 𝐵)𝑦𝑦(𝐵 × 𝐶)𝑧) ↔ (𝑦𝐵 ∧ (𝑥𝐴𝑧𝐶)))
1110exbii 1848 . . . . 5 (∃𝑦(𝑥(𝐴 × 𝐵)𝑦𝑦(𝐵 × 𝐶)𝑧) ↔ ∃𝑦(𝑦𝐵 ∧ (𝑥𝐴𝑧𝐶)))
12 19.41v 1949 . . . . 5 (∃𝑦(𝑦𝐵 ∧ (𝑥𝐴𝑧𝐶)) ↔ (∃𝑦 𝑦𝐵 ∧ (𝑥𝐴𝑧𝐶)))
1311, 12bitr2i 276 . . . 4 ((∃𝑦 𝑦𝐵 ∧ (𝑥𝐴𝑧𝐶)) ↔ ∃𝑦(𝑥(𝐴 × 𝐵)𝑦𝑦(𝐵 × 𝐶)𝑧))
143, 13bitr2di 288 . . 3 (𝐵 ≠ ∅ → (∃𝑦(𝑥(𝐴 × 𝐵)𝑦𝑦(𝐵 × 𝐶)𝑧) ↔ (𝑥𝐴𝑧𝐶)))
1514opabbidv 5173 . 2 (𝐵 ≠ ∅ → {⟨𝑥, 𝑧⟩ ∣ ∃𝑦(𝑥(𝐴 × 𝐵)𝑦𝑦(𝐵 × 𝐶)𝑧)} = {⟨𝑥, 𝑧⟩ ∣ (𝑥𝐴𝑧𝐶)})
16 df-co 5647 . 2 ((𝐵 × 𝐶) ∘ (𝐴 × 𝐵)) = {⟨𝑥, 𝑧⟩ ∣ ∃𝑦(𝑥(𝐴 × 𝐵)𝑦𝑦(𝐵 × 𝐶)𝑧)}
17 df-xp 5644 . 2 (𝐴 × 𝐶) = {⟨𝑥, 𝑧⟩ ∣ (𝑥𝐴𝑧𝐶)}
1815, 16, 173eqtr4g 2789 1 (𝐵 ≠ ∅ → ((𝐵 × 𝐶) ∘ (𝐴 × 𝐵)) = (𝐴 × 𝐶))
Colors of variables: wff setvar class
Syntax hints:  wi 4  wa 395   = wceq 1540  wex 1779  wcel 2109  wne 2925  c0 4296   class class class wbr 5107  {copab 5169   × cxp 5636  ccom 5642
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-ext 2701  ax-sep 5251  ax-nul 5261  ax-pr 5387
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-sb 2066  df-clab 2708  df-cleq 2721  df-clel 2803  df-ne 2926  df-ral 3045  df-rex 3054  df-rab 3406  df-v 3449  df-dif 3917  df-un 3919  df-ss 3931  df-nul 4297  df-if 4489  df-sn 4590  df-pr 4592  df-op 4596  df-br 5108  df-opab 5170  df-xp 5644  df-co 5647
This theorem is referenced by:  xpcoid  6263  ustund  24109  ustneism  24111  cosnop  32618
  Copyright terms: Public domain W3C validator