Users' Mathboxes Mathbox for Thierry Arnoux < Previous   Next >
Nearby theorems
Mirrors  >  Home  >  MPE Home  >  Th. List  >   Mathboxes  >  xpinpreima Structured version   Visualization version   GIF version

Theorem xpinpreima 33911
Description: Rewrite the cartesian product of two sets as the intersection of their preimage by 1st and 2nd, the projections on the first and second elements. (Contributed by Thierry Arnoux, 22-Sep-2017.)
Assertion
Ref Expression
xpinpreima (𝐴 × 𝐵) = (((1st ↾ (V × V)) “ 𝐴) ∩ ((2nd ↾ (V × V)) “ 𝐵))

Proof of Theorem xpinpreima
Dummy variable 𝑟 is distinct from all other variables.
StepHypRef Expression
1 inrab 4261 . 2 ({𝑟 ∈ (V × V) ∣ (1st𝑟) ∈ 𝐴} ∩ {𝑟 ∈ (V × V) ∣ (2nd𝑟) ∈ 𝐵}) = {𝑟 ∈ (V × V) ∣ ((1st𝑟) ∈ 𝐴 ∧ (2nd𝑟) ∈ 𝐵)}
2 f1stres 7940 . . . . 5 (1st ↾ (V × V)):(V × V)⟶V
3 ffn 6646 . . . . 5 ((1st ↾ (V × V)):(V × V)⟶V → (1st ↾ (V × V)) Fn (V × V))
4 fncnvima2 6989 . . . . 5 ((1st ↾ (V × V)) Fn (V × V) → ((1st ↾ (V × V)) “ 𝐴) = {𝑟 ∈ (V × V) ∣ ((1st ↾ (V × V))‘𝑟) ∈ 𝐴})
52, 3, 4mp2b 10 . . . 4 ((1st ↾ (V × V)) “ 𝐴) = {𝑟 ∈ (V × V) ∣ ((1st ↾ (V × V))‘𝑟) ∈ 𝐴}
6 fvres 6836 . . . . . 6 (𝑟 ∈ (V × V) → ((1st ↾ (V × V))‘𝑟) = (1st𝑟))
76eleq1d 2816 . . . . 5 (𝑟 ∈ (V × V) → (((1st ↾ (V × V))‘𝑟) ∈ 𝐴 ↔ (1st𝑟) ∈ 𝐴))
87rabbiia 3399 . . . 4 {𝑟 ∈ (V × V) ∣ ((1st ↾ (V × V))‘𝑟) ∈ 𝐴} = {𝑟 ∈ (V × V) ∣ (1st𝑟) ∈ 𝐴}
95, 8eqtri 2754 . . 3 ((1st ↾ (V × V)) “ 𝐴) = {𝑟 ∈ (V × V) ∣ (1st𝑟) ∈ 𝐴}
10 f2ndres 7941 . . . . 5 (2nd ↾ (V × V)):(V × V)⟶V
11 ffn 6646 . . . . 5 ((2nd ↾ (V × V)):(V × V)⟶V → (2nd ↾ (V × V)) Fn (V × V))
12 fncnvima2 6989 . . . . 5 ((2nd ↾ (V × V)) Fn (V × V) → ((2nd ↾ (V × V)) “ 𝐵) = {𝑟 ∈ (V × V) ∣ ((2nd ↾ (V × V))‘𝑟) ∈ 𝐵})
1310, 11, 12mp2b 10 . . . 4 ((2nd ↾ (V × V)) “ 𝐵) = {𝑟 ∈ (V × V) ∣ ((2nd ↾ (V × V))‘𝑟) ∈ 𝐵}
14 fvres 6836 . . . . . 6 (𝑟 ∈ (V × V) → ((2nd ↾ (V × V))‘𝑟) = (2nd𝑟))
1514eleq1d 2816 . . . . 5 (𝑟 ∈ (V × V) → (((2nd ↾ (V × V))‘𝑟) ∈ 𝐵 ↔ (2nd𝑟) ∈ 𝐵))
1615rabbiia 3399 . . . 4 {𝑟 ∈ (V × V) ∣ ((2nd ↾ (V × V))‘𝑟) ∈ 𝐵} = {𝑟 ∈ (V × V) ∣ (2nd𝑟) ∈ 𝐵}
1713, 16eqtri 2754 . . 3 ((2nd ↾ (V × V)) “ 𝐵) = {𝑟 ∈ (V × V) ∣ (2nd𝑟) ∈ 𝐵}
189, 17ineq12i 4163 . 2 (((1st ↾ (V × V)) “ 𝐴) ∩ ((2nd ↾ (V × V)) “ 𝐵)) = ({𝑟 ∈ (V × V) ∣ (1st𝑟) ∈ 𝐴} ∩ {𝑟 ∈ (V × V) ∣ (2nd𝑟) ∈ 𝐵})
19 xp2 7953 . 2 (𝐴 × 𝐵) = {𝑟 ∈ (V × V) ∣ ((1st𝑟) ∈ 𝐴 ∧ (2nd𝑟) ∈ 𝐵)}
201, 18, 193eqtr4ri 2765 1 (𝐴 × 𝐵) = (((1st ↾ (V × V)) “ 𝐴) ∩ ((2nd ↾ (V × V)) “ 𝐵))
Colors of variables: wff setvar class
Syntax hints:  wa 395   = wceq 1541  wcel 2111  {crab 3395  Vcvv 3436  cin 3896   × cxp 5609  ccnv 5610  cres 5613  cima 5614   Fn wfn 6471  wf 6472  cfv 6476  1st c1st 7914  2nd c2nd 7915
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-3 8  ax-gen 1796  ax-4 1810  ax-5 1911  ax-6 1968  ax-7 2009  ax-8 2113  ax-9 2121  ax-10 2144  ax-11 2160  ax-12 2180  ax-ext 2703  ax-sep 5229  ax-nul 5239  ax-pr 5365  ax-un 7663
This theorem depends on definitions:  df-bi 207  df-an 396  df-or 848  df-3an 1088  df-tru 1544  df-fal 1554  df-ex 1781  df-nf 1785  df-sb 2068  df-mo 2535  df-eu 2564  df-clab 2710  df-cleq 2723  df-clel 2806  df-nfc 2881  df-ne 2929  df-ral 3048  df-rex 3057  df-rab 3396  df-v 3438  df-sbc 3737  df-csb 3846  df-dif 3900  df-un 3902  df-in 3904  df-ss 3914  df-nul 4279  df-if 4471  df-sn 4572  df-pr 4574  df-op 4578  df-uni 4855  df-iun 4938  df-br 5087  df-opab 5149  df-mpt 5168  df-id 5506  df-xp 5617  df-rel 5618  df-cnv 5619  df-co 5620  df-dm 5621  df-rn 5622  df-res 5623  df-ima 5624  df-iota 6432  df-fun 6478  df-fn 6479  df-f 6480  df-fv 6484  df-1st 7916  df-2nd 7917
This theorem is referenced by: (None)
  Copyright terms: Public domain W3C validator