Metamath Proof Explorer


Theorem f1od2

Description: Sufficient condition for a binary function expressed in maps-to notation to be bijective. (Contributed by Thierry Arnoux, 17-Aug-2017)

Ref Expression
Hypotheses f1od2.1 𝐹 = ( 𝑥𝐴 , 𝑦𝐵𝐶 )
f1od2.2 ( ( 𝜑 ∧ ( 𝑥𝐴𝑦𝐵 ) ) → 𝐶𝑊 )
f1od2.3 ( ( 𝜑𝑧𝐷 ) → ( 𝐼𝑋𝐽𝑌 ) )
f1od2.4 ( 𝜑 → ( ( ( 𝑥𝐴𝑦𝐵 ) ∧ 𝑧 = 𝐶 ) ↔ ( 𝑧𝐷 ∧ ( 𝑥 = 𝐼𝑦 = 𝐽 ) ) ) )
Assertion f1od2 ( 𝜑𝐹 : ( 𝐴 × 𝐵 ) –1-1-onto𝐷 )

Proof

Step Hyp Ref Expression
1 f1od2.1 𝐹 = ( 𝑥𝐴 , 𝑦𝐵𝐶 )
2 f1od2.2 ( ( 𝜑 ∧ ( 𝑥𝐴𝑦𝐵 ) ) → 𝐶𝑊 )
3 f1od2.3 ( ( 𝜑𝑧𝐷 ) → ( 𝐼𝑋𝐽𝑌 ) )
4 f1od2.4 ( 𝜑 → ( ( ( 𝑥𝐴𝑦𝐵 ) ∧ 𝑧 = 𝐶 ) ↔ ( 𝑧𝐷 ∧ ( 𝑥 = 𝐼𝑦 = 𝐽 ) ) ) )
5 2 ralrimivva ( 𝜑 → ∀ 𝑥𝐴𝑦𝐵 𝐶𝑊 )
6 1 fnmpo ( ∀ 𝑥𝐴𝑦𝐵 𝐶𝑊𝐹 Fn ( 𝐴 × 𝐵 ) )
7 5 6 syl ( 𝜑𝐹 Fn ( 𝐴 × 𝐵 ) )
8 opelxpi ( ( 𝐼𝑋𝐽𝑌 ) → ⟨ 𝐼 , 𝐽 ⟩ ∈ ( 𝑋 × 𝑌 ) )
9 3 8 syl ( ( 𝜑𝑧𝐷 ) → ⟨ 𝐼 , 𝐽 ⟩ ∈ ( 𝑋 × 𝑌 ) )
10 9 ralrimiva ( 𝜑 → ∀ 𝑧𝐷𝐼 , 𝐽 ⟩ ∈ ( 𝑋 × 𝑌 ) )
11 eqid ( 𝑧𝐷 ↦ ⟨ 𝐼 , 𝐽 ⟩ ) = ( 𝑧𝐷 ↦ ⟨ 𝐼 , 𝐽 ⟩ )
12 11 fnmpt ( ∀ 𝑧𝐷𝐼 , 𝐽 ⟩ ∈ ( 𝑋 × 𝑌 ) → ( 𝑧𝐷 ↦ ⟨ 𝐼 , 𝐽 ⟩ ) Fn 𝐷 )
13 10 12 syl ( 𝜑 → ( 𝑧𝐷 ↦ ⟨ 𝐼 , 𝐽 ⟩ ) Fn 𝐷 )
14 elxp7 ( 𝑎 ∈ ( 𝐴 × 𝐵 ) ↔ ( 𝑎 ∈ ( V × V ) ∧ ( ( 1st𝑎 ) ∈ 𝐴 ∧ ( 2nd𝑎 ) ∈ 𝐵 ) ) )
15 14 anbi1i ( ( 𝑎 ∈ ( 𝐴 × 𝐵 ) ∧ 𝑧 = ( 1st𝑎 ) / 𝑥 ( 2nd𝑎 ) / 𝑦 𝐶 ) ↔ ( ( 𝑎 ∈ ( V × V ) ∧ ( ( 1st𝑎 ) ∈ 𝐴 ∧ ( 2nd𝑎 ) ∈ 𝐵 ) ) ∧ 𝑧 = ( 1st𝑎 ) / 𝑥 ( 2nd𝑎 ) / 𝑦 𝐶 ) )
16 anass ( ( ( 𝑎 ∈ ( V × V ) ∧ ( ( 1st𝑎 ) ∈ 𝐴 ∧ ( 2nd𝑎 ) ∈ 𝐵 ) ) ∧ 𝑧 = ( 1st𝑎 ) / 𝑥 ( 2nd𝑎 ) / 𝑦 𝐶 ) ↔ ( 𝑎 ∈ ( V × V ) ∧ ( ( ( 1st𝑎 ) ∈ 𝐴 ∧ ( 2nd𝑎 ) ∈ 𝐵 ) ∧ 𝑧 = ( 1st𝑎 ) / 𝑥 ( 2nd𝑎 ) / 𝑦 𝐶 ) ) )
17 4 sbcbidv ( 𝜑 → ( [ ( 2nd𝑎 ) / 𝑦 ] ( ( 𝑥𝐴𝑦𝐵 ) ∧ 𝑧 = 𝐶 ) ↔ [ ( 2nd𝑎 ) / 𝑦 ] ( 𝑧𝐷 ∧ ( 𝑥 = 𝐼𝑦 = 𝐽 ) ) ) )
18 17 sbcbidv ( 𝜑 → ( [ ( 1st𝑎 ) / 𝑥 ] [ ( 2nd𝑎 ) / 𝑦 ] ( ( 𝑥𝐴𝑦𝐵 ) ∧ 𝑧 = 𝐶 ) ↔ [ ( 1st𝑎 ) / 𝑥 ] [ ( 2nd𝑎 ) / 𝑦 ] ( 𝑧𝐷 ∧ ( 𝑥 = 𝐼𝑦 = 𝐽 ) ) ) )
19 sbcan ( [ ( 2nd𝑎 ) / 𝑦 ] ( ( 𝑥𝐴𝑦𝐵 ) ∧ 𝑧 = 𝐶 ) ↔ ( [ ( 2nd𝑎 ) / 𝑦 ] ( 𝑥𝐴𝑦𝐵 ) ∧ [ ( 2nd𝑎 ) / 𝑦 ] 𝑧 = 𝐶 ) )
20 sbcan ( [ ( 2nd𝑎 ) / 𝑦 ] ( 𝑥𝐴𝑦𝐵 ) ↔ ( [ ( 2nd𝑎 ) / 𝑦 ] 𝑥𝐴[ ( 2nd𝑎 ) / 𝑦 ] 𝑦𝐵 ) )
21 fvex ( 2nd𝑎 ) ∈ V
22 sbcg ( ( 2nd𝑎 ) ∈ V → ( [ ( 2nd𝑎 ) / 𝑦 ] 𝑥𝐴𝑥𝐴 ) )
23 21 22 ax-mp ( [ ( 2nd𝑎 ) / 𝑦 ] 𝑥𝐴𝑥𝐴 )
24 sbcel1v ( [ ( 2nd𝑎 ) / 𝑦 ] 𝑦𝐵 ↔ ( 2nd𝑎 ) ∈ 𝐵 )
25 23 24 anbi12i ( ( [ ( 2nd𝑎 ) / 𝑦 ] 𝑥𝐴[ ( 2nd𝑎 ) / 𝑦 ] 𝑦𝐵 ) ↔ ( 𝑥𝐴 ∧ ( 2nd𝑎 ) ∈ 𝐵 ) )
26 20 25 bitri ( [ ( 2nd𝑎 ) / 𝑦 ] ( 𝑥𝐴𝑦𝐵 ) ↔ ( 𝑥𝐴 ∧ ( 2nd𝑎 ) ∈ 𝐵 ) )
27 sbceq2g ( ( 2nd𝑎 ) ∈ V → ( [ ( 2nd𝑎 ) / 𝑦 ] 𝑧 = 𝐶𝑧 = ( 2nd𝑎 ) / 𝑦 𝐶 ) )
28 21 27 ax-mp ( [ ( 2nd𝑎 ) / 𝑦 ] 𝑧 = 𝐶𝑧 = ( 2nd𝑎 ) / 𝑦 𝐶 )
29 26 28 anbi12i ( ( [ ( 2nd𝑎 ) / 𝑦 ] ( 𝑥𝐴𝑦𝐵 ) ∧ [ ( 2nd𝑎 ) / 𝑦 ] 𝑧 = 𝐶 ) ↔ ( ( 𝑥𝐴 ∧ ( 2nd𝑎 ) ∈ 𝐵 ) ∧ 𝑧 = ( 2nd𝑎 ) / 𝑦 𝐶 ) )
30 19 29 bitri ( [ ( 2nd𝑎 ) / 𝑦 ] ( ( 𝑥𝐴𝑦𝐵 ) ∧ 𝑧 = 𝐶 ) ↔ ( ( 𝑥𝐴 ∧ ( 2nd𝑎 ) ∈ 𝐵 ) ∧ 𝑧 = ( 2nd𝑎 ) / 𝑦 𝐶 ) )
31 30 sbcbii ( [ ( 1st𝑎 ) / 𝑥 ] [ ( 2nd𝑎 ) / 𝑦 ] ( ( 𝑥𝐴𝑦𝐵 ) ∧ 𝑧 = 𝐶 ) ↔ [ ( 1st𝑎 ) / 𝑥 ] ( ( 𝑥𝐴 ∧ ( 2nd𝑎 ) ∈ 𝐵 ) ∧ 𝑧 = ( 2nd𝑎 ) / 𝑦 𝐶 ) )
32 sbcan ( [ ( 1st𝑎 ) / 𝑥 ] ( ( 𝑥𝐴 ∧ ( 2nd𝑎 ) ∈ 𝐵 ) ∧ 𝑧 = ( 2nd𝑎 ) / 𝑦 𝐶 ) ↔ ( [ ( 1st𝑎 ) / 𝑥 ] ( 𝑥𝐴 ∧ ( 2nd𝑎 ) ∈ 𝐵 ) ∧ [ ( 1st𝑎 ) / 𝑥 ] 𝑧 = ( 2nd𝑎 ) / 𝑦 𝐶 ) )
33 sbcan ( [ ( 1st𝑎 ) / 𝑥 ] ( 𝑥𝐴 ∧ ( 2nd𝑎 ) ∈ 𝐵 ) ↔ ( [ ( 1st𝑎 ) / 𝑥 ] 𝑥𝐴[ ( 1st𝑎 ) / 𝑥 ] ( 2nd𝑎 ) ∈ 𝐵 ) )
34 sbcel1v ( [ ( 1st𝑎 ) / 𝑥 ] 𝑥𝐴 ↔ ( 1st𝑎 ) ∈ 𝐴 )
35 fvex ( 1st𝑎 ) ∈ V
36 sbcg ( ( 1st𝑎 ) ∈ V → ( [ ( 1st𝑎 ) / 𝑥 ] ( 2nd𝑎 ) ∈ 𝐵 ↔ ( 2nd𝑎 ) ∈ 𝐵 ) )
37 35 36 ax-mp ( [ ( 1st𝑎 ) / 𝑥 ] ( 2nd𝑎 ) ∈ 𝐵 ↔ ( 2nd𝑎 ) ∈ 𝐵 )
38 34 37 anbi12i ( ( [ ( 1st𝑎 ) / 𝑥 ] 𝑥𝐴[ ( 1st𝑎 ) / 𝑥 ] ( 2nd𝑎 ) ∈ 𝐵 ) ↔ ( ( 1st𝑎 ) ∈ 𝐴 ∧ ( 2nd𝑎 ) ∈ 𝐵 ) )
39 33 38 bitri ( [ ( 1st𝑎 ) / 𝑥 ] ( 𝑥𝐴 ∧ ( 2nd𝑎 ) ∈ 𝐵 ) ↔ ( ( 1st𝑎 ) ∈ 𝐴 ∧ ( 2nd𝑎 ) ∈ 𝐵 ) )
40 sbceq2g ( ( 1st𝑎 ) ∈ V → ( [ ( 1st𝑎 ) / 𝑥 ] 𝑧 = ( 2nd𝑎 ) / 𝑦 𝐶𝑧 = ( 1st𝑎 ) / 𝑥 ( 2nd𝑎 ) / 𝑦 𝐶 ) )
41 35 40 ax-mp ( [ ( 1st𝑎 ) / 𝑥 ] 𝑧 = ( 2nd𝑎 ) / 𝑦 𝐶𝑧 = ( 1st𝑎 ) / 𝑥 ( 2nd𝑎 ) / 𝑦 𝐶 )
42 39 41 anbi12i ( ( [ ( 1st𝑎 ) / 𝑥 ] ( 𝑥𝐴 ∧ ( 2nd𝑎 ) ∈ 𝐵 ) ∧ [ ( 1st𝑎 ) / 𝑥 ] 𝑧 = ( 2nd𝑎 ) / 𝑦 𝐶 ) ↔ ( ( ( 1st𝑎 ) ∈ 𝐴 ∧ ( 2nd𝑎 ) ∈ 𝐵 ) ∧ 𝑧 = ( 1st𝑎 ) / 𝑥 ( 2nd𝑎 ) / 𝑦 𝐶 ) )
43 31 32 42 3bitri ( [ ( 1st𝑎 ) / 𝑥 ] [ ( 2nd𝑎 ) / 𝑦 ] ( ( 𝑥𝐴𝑦𝐵 ) ∧ 𝑧 = 𝐶 ) ↔ ( ( ( 1st𝑎 ) ∈ 𝐴 ∧ ( 2nd𝑎 ) ∈ 𝐵 ) ∧ 𝑧 = ( 1st𝑎 ) / 𝑥 ( 2nd𝑎 ) / 𝑦 𝐶 ) )
44 sbcan ( [ ( 2nd𝑎 ) / 𝑦 ] ( 𝑧𝐷 ∧ ( 𝑥 = 𝐼𝑦 = 𝐽 ) ) ↔ ( [ ( 2nd𝑎 ) / 𝑦 ] 𝑧𝐷[ ( 2nd𝑎 ) / 𝑦 ] ( 𝑥 = 𝐼𝑦 = 𝐽 ) ) )
45 sbcg ( ( 2nd𝑎 ) ∈ V → ( [ ( 2nd𝑎 ) / 𝑦 ] 𝑧𝐷𝑧𝐷 ) )
46 21 45 ax-mp ( [ ( 2nd𝑎 ) / 𝑦 ] 𝑧𝐷𝑧𝐷 )
47 sbcan ( [ ( 2nd𝑎 ) / 𝑦 ] ( 𝑥 = 𝐼𝑦 = 𝐽 ) ↔ ( [ ( 2nd𝑎 ) / 𝑦 ] 𝑥 = 𝐼[ ( 2nd𝑎 ) / 𝑦 ] 𝑦 = 𝐽 ) )
48 sbcg ( ( 2nd𝑎 ) ∈ V → ( [ ( 2nd𝑎 ) / 𝑦 ] 𝑥 = 𝐼𝑥 = 𝐼 ) )
49 21 48 ax-mp ( [ ( 2nd𝑎 ) / 𝑦 ] 𝑥 = 𝐼𝑥 = 𝐼 )
50 sbceq1g ( ( 2nd𝑎 ) ∈ V → ( [ ( 2nd𝑎 ) / 𝑦 ] 𝑦 = 𝐽 ( 2nd𝑎 ) / 𝑦 𝑦 = 𝐽 ) )
51 21 50 ax-mp ( [ ( 2nd𝑎 ) / 𝑦 ] 𝑦 = 𝐽 ( 2nd𝑎 ) / 𝑦 𝑦 = 𝐽 )
52 21 csbvargi ( 2nd𝑎 ) / 𝑦 𝑦 = ( 2nd𝑎 )
53 52 eqeq1i ( ( 2nd𝑎 ) / 𝑦 𝑦 = 𝐽 ↔ ( 2nd𝑎 ) = 𝐽 )
54 51 53 bitri ( [ ( 2nd𝑎 ) / 𝑦 ] 𝑦 = 𝐽 ↔ ( 2nd𝑎 ) = 𝐽 )
55 49 54 anbi12i ( ( [ ( 2nd𝑎 ) / 𝑦 ] 𝑥 = 𝐼[ ( 2nd𝑎 ) / 𝑦 ] 𝑦 = 𝐽 ) ↔ ( 𝑥 = 𝐼 ∧ ( 2nd𝑎 ) = 𝐽 ) )
56 47 55 bitri ( [ ( 2nd𝑎 ) / 𝑦 ] ( 𝑥 = 𝐼𝑦 = 𝐽 ) ↔ ( 𝑥 = 𝐼 ∧ ( 2nd𝑎 ) = 𝐽 ) )
57 46 56 anbi12i ( ( [ ( 2nd𝑎 ) / 𝑦 ] 𝑧𝐷[ ( 2nd𝑎 ) / 𝑦 ] ( 𝑥 = 𝐼𝑦 = 𝐽 ) ) ↔ ( 𝑧𝐷 ∧ ( 𝑥 = 𝐼 ∧ ( 2nd𝑎 ) = 𝐽 ) ) )
58 44 57 bitri ( [ ( 2nd𝑎 ) / 𝑦 ] ( 𝑧𝐷 ∧ ( 𝑥 = 𝐼𝑦 = 𝐽 ) ) ↔ ( 𝑧𝐷 ∧ ( 𝑥 = 𝐼 ∧ ( 2nd𝑎 ) = 𝐽 ) ) )
59 58 sbcbii ( [ ( 1st𝑎 ) / 𝑥 ] [ ( 2nd𝑎 ) / 𝑦 ] ( 𝑧𝐷 ∧ ( 𝑥 = 𝐼𝑦 = 𝐽 ) ) ↔ [ ( 1st𝑎 ) / 𝑥 ] ( 𝑧𝐷 ∧ ( 𝑥 = 𝐼 ∧ ( 2nd𝑎 ) = 𝐽 ) ) )
60 sbcan ( [ ( 1st𝑎 ) / 𝑥 ] ( 𝑧𝐷 ∧ ( 𝑥 = 𝐼 ∧ ( 2nd𝑎 ) = 𝐽 ) ) ↔ ( [ ( 1st𝑎 ) / 𝑥 ] 𝑧𝐷[ ( 1st𝑎 ) / 𝑥 ] ( 𝑥 = 𝐼 ∧ ( 2nd𝑎 ) = 𝐽 ) ) )
61 sbcg ( ( 1st𝑎 ) ∈ V → ( [ ( 1st𝑎 ) / 𝑥 ] 𝑧𝐷𝑧𝐷 ) )
62 35 61 ax-mp ( [ ( 1st𝑎 ) / 𝑥 ] 𝑧𝐷𝑧𝐷 )
63 sbcan ( [ ( 1st𝑎 ) / 𝑥 ] ( 𝑥 = 𝐼 ∧ ( 2nd𝑎 ) = 𝐽 ) ↔ ( [ ( 1st𝑎 ) / 𝑥 ] 𝑥 = 𝐼[ ( 1st𝑎 ) / 𝑥 ] ( 2nd𝑎 ) = 𝐽 ) )
64 sbceq1g ( ( 1st𝑎 ) ∈ V → ( [ ( 1st𝑎 ) / 𝑥 ] 𝑥 = 𝐼 ( 1st𝑎 ) / 𝑥 𝑥 = 𝐼 ) )
65 35 64 ax-mp ( [ ( 1st𝑎 ) / 𝑥 ] 𝑥 = 𝐼 ( 1st𝑎 ) / 𝑥 𝑥 = 𝐼 )
66 35 csbvargi ( 1st𝑎 ) / 𝑥 𝑥 = ( 1st𝑎 )
67 66 eqeq1i ( ( 1st𝑎 ) / 𝑥 𝑥 = 𝐼 ↔ ( 1st𝑎 ) = 𝐼 )
68 65 67 bitri ( [ ( 1st𝑎 ) / 𝑥 ] 𝑥 = 𝐼 ↔ ( 1st𝑎 ) = 𝐼 )
69 sbcg ( ( 1st𝑎 ) ∈ V → ( [ ( 1st𝑎 ) / 𝑥 ] ( 2nd𝑎 ) = 𝐽 ↔ ( 2nd𝑎 ) = 𝐽 ) )
70 35 69 ax-mp ( [ ( 1st𝑎 ) / 𝑥 ] ( 2nd𝑎 ) = 𝐽 ↔ ( 2nd𝑎 ) = 𝐽 )
71 68 70 anbi12i ( ( [ ( 1st𝑎 ) / 𝑥 ] 𝑥 = 𝐼[ ( 1st𝑎 ) / 𝑥 ] ( 2nd𝑎 ) = 𝐽 ) ↔ ( ( 1st𝑎 ) = 𝐼 ∧ ( 2nd𝑎 ) = 𝐽 ) )
72 63 71 bitri ( [ ( 1st𝑎 ) / 𝑥 ] ( 𝑥 = 𝐼 ∧ ( 2nd𝑎 ) = 𝐽 ) ↔ ( ( 1st𝑎 ) = 𝐼 ∧ ( 2nd𝑎 ) = 𝐽 ) )
73 62 72 anbi12i ( ( [ ( 1st𝑎 ) / 𝑥 ] 𝑧𝐷[ ( 1st𝑎 ) / 𝑥 ] ( 𝑥 = 𝐼 ∧ ( 2nd𝑎 ) = 𝐽 ) ) ↔ ( 𝑧𝐷 ∧ ( ( 1st𝑎 ) = 𝐼 ∧ ( 2nd𝑎 ) = 𝐽 ) ) )
74 59 60 73 3bitri ( [ ( 1st𝑎 ) / 𝑥 ] [ ( 2nd𝑎 ) / 𝑦 ] ( 𝑧𝐷 ∧ ( 𝑥 = 𝐼𝑦 = 𝐽 ) ) ↔ ( 𝑧𝐷 ∧ ( ( 1st𝑎 ) = 𝐼 ∧ ( 2nd𝑎 ) = 𝐽 ) ) )
75 18 43 74 3bitr3g ( 𝜑 → ( ( ( ( 1st𝑎 ) ∈ 𝐴 ∧ ( 2nd𝑎 ) ∈ 𝐵 ) ∧ 𝑧 = ( 1st𝑎 ) / 𝑥 ( 2nd𝑎 ) / 𝑦 𝐶 ) ↔ ( 𝑧𝐷 ∧ ( ( 1st𝑎 ) = 𝐼 ∧ ( 2nd𝑎 ) = 𝐽 ) ) ) )
76 75 anbi2d ( 𝜑 → ( ( 𝑎 ∈ ( V × V ) ∧ ( ( ( 1st𝑎 ) ∈ 𝐴 ∧ ( 2nd𝑎 ) ∈ 𝐵 ) ∧ 𝑧 = ( 1st𝑎 ) / 𝑥 ( 2nd𝑎 ) / 𝑦 𝐶 ) ) ↔ ( 𝑎 ∈ ( V × V ) ∧ ( 𝑧𝐷 ∧ ( ( 1st𝑎 ) = 𝐼 ∧ ( 2nd𝑎 ) = 𝐽 ) ) ) ) )
77 16 76 syl5bb ( 𝜑 → ( ( ( 𝑎 ∈ ( V × V ) ∧ ( ( 1st𝑎 ) ∈ 𝐴 ∧ ( 2nd𝑎 ) ∈ 𝐵 ) ) ∧ 𝑧 = ( 1st𝑎 ) / 𝑥 ( 2nd𝑎 ) / 𝑦 𝐶 ) ↔ ( 𝑎 ∈ ( V × V ) ∧ ( 𝑧𝐷 ∧ ( ( 1st𝑎 ) = 𝐼 ∧ ( 2nd𝑎 ) = 𝐽 ) ) ) ) )
78 xpss ( 𝑋 × 𝑌 ) ⊆ ( V × V )
79 simprr ( ( 𝜑 ∧ ( 𝑧𝐷𝑎 = ⟨ 𝐼 , 𝐽 ⟩ ) ) → 𝑎 = ⟨ 𝐼 , 𝐽 ⟩ )
80 9 adantrr ( ( 𝜑 ∧ ( 𝑧𝐷𝑎 = ⟨ 𝐼 , 𝐽 ⟩ ) ) → ⟨ 𝐼 , 𝐽 ⟩ ∈ ( 𝑋 × 𝑌 ) )
81 79 80 eqeltrd ( ( 𝜑 ∧ ( 𝑧𝐷𝑎 = ⟨ 𝐼 , 𝐽 ⟩ ) ) → 𝑎 ∈ ( 𝑋 × 𝑌 ) )
82 78 81 sselid ( ( 𝜑 ∧ ( 𝑧𝐷𝑎 = ⟨ 𝐼 , 𝐽 ⟩ ) ) → 𝑎 ∈ ( V × V ) )
83 82 ex ( 𝜑 → ( ( 𝑧𝐷𝑎 = ⟨ 𝐼 , 𝐽 ⟩ ) → 𝑎 ∈ ( V × V ) ) )
84 83 pm4.71rd ( 𝜑 → ( ( 𝑧𝐷𝑎 = ⟨ 𝐼 , 𝐽 ⟩ ) ↔ ( 𝑎 ∈ ( V × V ) ∧ ( 𝑧𝐷𝑎 = ⟨ 𝐼 , 𝐽 ⟩ ) ) ) )
85 eqop ( 𝑎 ∈ ( V × V ) → ( 𝑎 = ⟨ 𝐼 , 𝐽 ⟩ ↔ ( ( 1st𝑎 ) = 𝐼 ∧ ( 2nd𝑎 ) = 𝐽 ) ) )
86 85 anbi2d ( 𝑎 ∈ ( V × V ) → ( ( 𝑧𝐷𝑎 = ⟨ 𝐼 , 𝐽 ⟩ ) ↔ ( 𝑧𝐷 ∧ ( ( 1st𝑎 ) = 𝐼 ∧ ( 2nd𝑎 ) = 𝐽 ) ) ) )
87 86 pm5.32i ( ( 𝑎 ∈ ( V × V ) ∧ ( 𝑧𝐷𝑎 = ⟨ 𝐼 , 𝐽 ⟩ ) ) ↔ ( 𝑎 ∈ ( V × V ) ∧ ( 𝑧𝐷 ∧ ( ( 1st𝑎 ) = 𝐼 ∧ ( 2nd𝑎 ) = 𝐽 ) ) ) )
88 84 87 bitr2di ( 𝜑 → ( ( 𝑎 ∈ ( V × V ) ∧ ( 𝑧𝐷 ∧ ( ( 1st𝑎 ) = 𝐼 ∧ ( 2nd𝑎 ) = 𝐽 ) ) ) ↔ ( 𝑧𝐷𝑎 = ⟨ 𝐼 , 𝐽 ⟩ ) ) )
89 77 88 bitrd ( 𝜑 → ( ( ( 𝑎 ∈ ( V × V ) ∧ ( ( 1st𝑎 ) ∈ 𝐴 ∧ ( 2nd𝑎 ) ∈ 𝐵 ) ) ∧ 𝑧 = ( 1st𝑎 ) / 𝑥 ( 2nd𝑎 ) / 𝑦 𝐶 ) ↔ ( 𝑧𝐷𝑎 = ⟨ 𝐼 , 𝐽 ⟩ ) ) )
90 15 89 syl5bb ( 𝜑 → ( ( 𝑎 ∈ ( 𝐴 × 𝐵 ) ∧ 𝑧 = ( 1st𝑎 ) / 𝑥 ( 2nd𝑎 ) / 𝑦 𝐶 ) ↔ ( 𝑧𝐷𝑎 = ⟨ 𝐼 , 𝐽 ⟩ ) ) )
91 90 opabbidv ( 𝜑 → { ⟨ 𝑧 , 𝑎 ⟩ ∣ ( 𝑎 ∈ ( 𝐴 × 𝐵 ) ∧ 𝑧 = ( 1st𝑎 ) / 𝑥 ( 2nd𝑎 ) / 𝑦 𝐶 ) } = { ⟨ 𝑧 , 𝑎 ⟩ ∣ ( 𝑧𝐷𝑎 = ⟨ 𝐼 , 𝐽 ⟩ ) } )
92 df-mpo ( 𝑥𝐴 , 𝑦𝐵𝐶 ) = { ⟨ ⟨ 𝑥 , 𝑦 ⟩ , 𝑧 ⟩ ∣ ( ( 𝑥𝐴𝑦𝐵 ) ∧ 𝑧 = 𝐶 ) }
93 1 92 eqtri 𝐹 = { ⟨ ⟨ 𝑥 , 𝑦 ⟩ , 𝑧 ⟩ ∣ ( ( 𝑥𝐴𝑦𝐵 ) ∧ 𝑧 = 𝐶 ) }
94 93 cnveqi 𝐹 = { ⟨ ⟨ 𝑥 , 𝑦 ⟩ , 𝑧 ⟩ ∣ ( ( 𝑥𝐴𝑦𝐵 ) ∧ 𝑧 = 𝐶 ) }
95 nfv 𝑖 ( ( 𝑥𝐴𝑦𝐵 ) ∧ 𝑧 = 𝐶 )
96 nfv 𝑗 ( ( 𝑥𝐴𝑦𝐵 ) ∧ 𝑧 = 𝐶 )
97 nfv 𝑥 ( 𝑖𝐴𝑗𝐵 )
98 nfcsb1v 𝑥 𝑖 / 𝑥 𝑗 / 𝑦 𝐶
99 98 nfeq2 𝑥 𝑧 = 𝑖 / 𝑥 𝑗 / 𝑦 𝐶
100 97 99 nfan 𝑥 ( ( 𝑖𝐴𝑗𝐵 ) ∧ 𝑧 = 𝑖 / 𝑥 𝑗 / 𝑦 𝐶 )
101 nfv 𝑦 ( 𝑖𝐴𝑗𝐵 )
102 nfcv 𝑦 𝑖
103 nfcsb1v 𝑦 𝑗 / 𝑦 𝐶
104 102 103 nfcsbw 𝑦 𝑖 / 𝑥 𝑗 / 𝑦 𝐶
105 104 nfeq2 𝑦 𝑧 = 𝑖 / 𝑥 𝑗 / 𝑦 𝐶
106 101 105 nfan 𝑦 ( ( 𝑖𝐴𝑗𝐵 ) ∧ 𝑧 = 𝑖 / 𝑥 𝑗 / 𝑦 𝐶 )
107 simpl ( ( 𝑥 = 𝑖𝑦 = 𝑗 ) → 𝑥 = 𝑖 )
108 107 eleq1d ( ( 𝑥 = 𝑖𝑦 = 𝑗 ) → ( 𝑥𝐴𝑖𝐴 ) )
109 simpr ( ( 𝑥 = 𝑖𝑦 = 𝑗 ) → 𝑦 = 𝑗 )
110 109 eleq1d ( ( 𝑥 = 𝑖𝑦 = 𝑗 ) → ( 𝑦𝐵𝑗𝐵 ) )
111 108 110 anbi12d ( ( 𝑥 = 𝑖𝑦 = 𝑗 ) → ( ( 𝑥𝐴𝑦𝐵 ) ↔ ( 𝑖𝐴𝑗𝐵 ) ) )
112 csbeq1a ( 𝑦 = 𝑗𝐶 = 𝑗 / 𝑦 𝐶 )
113 csbeq1a ( 𝑥 = 𝑖 𝑗 / 𝑦 𝐶 = 𝑖 / 𝑥 𝑗 / 𝑦 𝐶 )
114 112 113 sylan9eqr ( ( 𝑥 = 𝑖𝑦 = 𝑗 ) → 𝐶 = 𝑖 / 𝑥 𝑗 / 𝑦 𝐶 )
115 114 eqeq2d ( ( 𝑥 = 𝑖𝑦 = 𝑗 ) → ( 𝑧 = 𝐶𝑧 = 𝑖 / 𝑥 𝑗 / 𝑦 𝐶 ) )
116 111 115 anbi12d ( ( 𝑥 = 𝑖𝑦 = 𝑗 ) → ( ( ( 𝑥𝐴𝑦𝐵 ) ∧ 𝑧 = 𝐶 ) ↔ ( ( 𝑖𝐴𝑗𝐵 ) ∧ 𝑧 = 𝑖 / 𝑥 𝑗 / 𝑦 𝐶 ) ) )
117 95 96 100 106 116 cbvoprab12 { ⟨ ⟨ 𝑥 , 𝑦 ⟩ , 𝑧 ⟩ ∣ ( ( 𝑥𝐴𝑦𝐵 ) ∧ 𝑧 = 𝐶 ) } = { ⟨ ⟨ 𝑖 , 𝑗 ⟩ , 𝑧 ⟩ ∣ ( ( 𝑖𝐴𝑗𝐵 ) ∧ 𝑧 = 𝑖 / 𝑥 𝑗 / 𝑦 𝐶 ) }
118 117 cnveqi { ⟨ ⟨ 𝑥 , 𝑦 ⟩ , 𝑧 ⟩ ∣ ( ( 𝑥𝐴𝑦𝐵 ) ∧ 𝑧 = 𝐶 ) } = { ⟨ ⟨ 𝑖 , 𝑗 ⟩ , 𝑧 ⟩ ∣ ( ( 𝑖𝐴𝑗𝐵 ) ∧ 𝑧 = 𝑖 / 𝑥 𝑗 / 𝑦 𝐶 ) }
119 eleq1 ( 𝑎 = ⟨ 𝑖 , 𝑗 ⟩ → ( 𝑎 ∈ ( 𝐴 × 𝐵 ) ↔ ⟨ 𝑖 , 𝑗 ⟩ ∈ ( 𝐴 × 𝐵 ) ) )
120 opelxp ( ⟨ 𝑖 , 𝑗 ⟩ ∈ ( 𝐴 × 𝐵 ) ↔ ( 𝑖𝐴𝑗𝐵 ) )
121 119 120 bitrdi ( 𝑎 = ⟨ 𝑖 , 𝑗 ⟩ → ( 𝑎 ∈ ( 𝐴 × 𝐵 ) ↔ ( 𝑖𝐴𝑗𝐵 ) ) )
122 csbcom ( 2nd𝑎 ) / 𝑗 𝑖 / 𝑥 𝑗 / 𝑦 𝐶 = 𝑖 / 𝑥 ( 2nd𝑎 ) / 𝑗 𝑗 / 𝑦 𝐶
123 csbcow ( 2nd𝑎 ) / 𝑗 𝑗 / 𝑦 𝐶 = ( 2nd𝑎 ) / 𝑦 𝐶
124 123 csbeq2i 𝑖 / 𝑥 ( 2nd𝑎 ) / 𝑗 𝑗 / 𝑦 𝐶 = 𝑖 / 𝑥 ( 2nd𝑎 ) / 𝑦 𝐶
125 122 124 eqtri ( 2nd𝑎 ) / 𝑗 𝑖 / 𝑥 𝑗 / 𝑦 𝐶 = 𝑖 / 𝑥 ( 2nd𝑎 ) / 𝑦 𝐶
126 125 csbeq2i ( 1st𝑎 ) / 𝑖 ( 2nd𝑎 ) / 𝑗 𝑖 / 𝑥 𝑗 / 𝑦 𝐶 = ( 1st𝑎 ) / 𝑖 𝑖 / 𝑥 ( 2nd𝑎 ) / 𝑦 𝐶
127 csbcow ( 1st𝑎 ) / 𝑖 𝑖 / 𝑥 ( 2nd𝑎 ) / 𝑦 𝐶 = ( 1st𝑎 ) / 𝑥 ( 2nd𝑎 ) / 𝑦 𝐶
128 126 127 eqtri ( 1st𝑎 ) / 𝑖 ( 2nd𝑎 ) / 𝑗 𝑖 / 𝑥 𝑗 / 𝑦 𝐶 = ( 1st𝑎 ) / 𝑥 ( 2nd𝑎 ) / 𝑦 𝐶
129 csbopeq1a ( 𝑎 = ⟨ 𝑖 , 𝑗 ⟩ → ( 1st𝑎 ) / 𝑖 ( 2nd𝑎 ) / 𝑗 𝑖 / 𝑥 𝑗 / 𝑦 𝐶 = 𝑖 / 𝑥 𝑗 / 𝑦 𝐶 )
130 128 129 eqtr3id ( 𝑎 = ⟨ 𝑖 , 𝑗 ⟩ → ( 1st𝑎 ) / 𝑥 ( 2nd𝑎 ) / 𝑦 𝐶 = 𝑖 / 𝑥 𝑗 / 𝑦 𝐶 )
131 130 eqeq2d ( 𝑎 = ⟨ 𝑖 , 𝑗 ⟩ → ( 𝑧 = ( 1st𝑎 ) / 𝑥 ( 2nd𝑎 ) / 𝑦 𝐶𝑧 = 𝑖 / 𝑥 𝑗 / 𝑦 𝐶 ) )
132 121 131 anbi12d ( 𝑎 = ⟨ 𝑖 , 𝑗 ⟩ → ( ( 𝑎 ∈ ( 𝐴 × 𝐵 ) ∧ 𝑧 = ( 1st𝑎 ) / 𝑥 ( 2nd𝑎 ) / 𝑦 𝐶 ) ↔ ( ( 𝑖𝐴𝑗𝐵 ) ∧ 𝑧 = 𝑖 / 𝑥 𝑗 / 𝑦 𝐶 ) ) )
133 xpss ( 𝐴 × 𝐵 ) ⊆ ( V × V )
134 133 sseli ( 𝑎 ∈ ( 𝐴 × 𝐵 ) → 𝑎 ∈ ( V × V ) )
135 134 adantr ( ( 𝑎 ∈ ( 𝐴 × 𝐵 ) ∧ 𝑧 = ( 1st𝑎 ) / 𝑥 ( 2nd𝑎 ) / 𝑦 𝐶 ) → 𝑎 ∈ ( V × V ) )
136 132 135 cnvoprab { ⟨ ⟨ 𝑖 , 𝑗 ⟩ , 𝑧 ⟩ ∣ ( ( 𝑖𝐴𝑗𝐵 ) ∧ 𝑧 = 𝑖 / 𝑥 𝑗 / 𝑦 𝐶 ) } = { ⟨ 𝑧 , 𝑎 ⟩ ∣ ( 𝑎 ∈ ( 𝐴 × 𝐵 ) ∧ 𝑧 = ( 1st𝑎 ) / 𝑥 ( 2nd𝑎 ) / 𝑦 𝐶 ) }
137 94 118 136 3eqtri 𝐹 = { ⟨ 𝑧 , 𝑎 ⟩ ∣ ( 𝑎 ∈ ( 𝐴 × 𝐵 ) ∧ 𝑧 = ( 1st𝑎 ) / 𝑥 ( 2nd𝑎 ) / 𝑦 𝐶 ) }
138 df-mpt ( 𝑧𝐷 ↦ ⟨ 𝐼 , 𝐽 ⟩ ) = { ⟨ 𝑧 , 𝑎 ⟩ ∣ ( 𝑧𝐷𝑎 = ⟨ 𝐼 , 𝐽 ⟩ ) }
139 91 137 138 3eqtr4g ( 𝜑 𝐹 = ( 𝑧𝐷 ↦ ⟨ 𝐼 , 𝐽 ⟩ ) )
140 139 fneq1d ( 𝜑 → ( 𝐹 Fn 𝐷 ↔ ( 𝑧𝐷 ↦ ⟨ 𝐼 , 𝐽 ⟩ ) Fn 𝐷 ) )
141 13 140 mpbird ( 𝜑 𝐹 Fn 𝐷 )
142 dff1o4 ( 𝐹 : ( 𝐴 × 𝐵 ) –1-1-onto𝐷 ↔ ( 𝐹 Fn ( 𝐴 × 𝐵 ) ∧ 𝐹 Fn 𝐷 ) )
143 7 141 142 sylanbrc ( 𝜑𝐹 : ( 𝐴 × 𝐵 ) –1-1-onto𝐷 )