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

Theorem fpwrelmap 29508
Description: Define a canonical mapping between functions from  A into subsets of  B and the relations with domain  A and range within  B. Note that the same relation is used in axdc2lem 9270 and marypha2lem1 8341. (Contributed by Thierry Arnoux, 28-Aug-2017.)
Hypotheses
Ref Expression
fpwrelmap.1  |-  A  e. 
_V
fpwrelmap.2  |-  B  e. 
_V
fpwrelmap.3  |-  M  =  ( f  e.  ( ~P B  ^m  A
)  |->  { <. x ,  y >.  |  ( x  e.  A  /\  y  e.  ( f `  x ) ) } )
Assertion
Ref Expression
fpwrelmap  |-  M :
( ~P B  ^m  A ) -1-1-onto-> ~P ( A  X.  B )
Distinct variable groups:    x, f,
y, A    B, f, x, y
Allowed substitution hints:    M( x, y, f)

Proof of Theorem fpwrelmap
Dummy variable  r is distinct from all other variables.
StepHypRef Expression
1 fpwrelmap.3 . . 3  |-  M  =  ( f  e.  ( ~P B  ^m  A
)  |->  { <. x ,  y >.  |  ( x  e.  A  /\  y  e.  ( f `  x ) ) } )
2 fpwrelmap.1 . . . . . 6  |-  A  e. 
_V
32a1i 11 . . . . 5  |-  ( f  e.  ( ~P B  ^m  A )  ->  A  e.  _V )
4 simpr 477 . . . . . . . . 9  |-  ( ( ( f  e.  ( ~P B  ^m  A
)  /\  x  e.  A )  /\  y  e.  ( f `  x
) )  ->  y  e.  ( f `  x
) )
5 elmapi 7879 . . . . . . . . . . 11  |-  ( f  e.  ( ~P B  ^m  A )  ->  f : A --> ~P B )
65ffvelrnda 6359 . . . . . . . . . 10  |-  ( ( f  e.  ( ~P B  ^m  A )  /\  x  e.  A
)  ->  ( f `  x )  e.  ~P B )
76adantr 481 . . . . . . . . 9  |-  ( ( ( f  e.  ( ~P B  ^m  A
)  /\  x  e.  A )  /\  y  e.  ( f `  x
) )  ->  (
f `  x )  e.  ~P B )
8 elelpwi 4171 . . . . . . . . 9  |-  ( ( y  e.  ( f `
 x )  /\  ( f `  x
)  e.  ~P B
)  ->  y  e.  B )
94, 7, 8syl2anc 693 . . . . . . . 8  |-  ( ( ( f  e.  ( ~P B  ^m  A
)  /\  x  e.  A )  /\  y  e.  ( f `  x
) )  ->  y  e.  B )
109ex 450 . . . . . . 7  |-  ( ( f  e.  ( ~P B  ^m  A )  /\  x  e.  A
)  ->  ( y  e.  ( f `  x
)  ->  y  e.  B ) )
1110alrimiv 1855 . . . . . 6  |-  ( ( f  e.  ( ~P B  ^m  A )  /\  x  e.  A
)  ->  A. y
( y  e.  ( f `  x )  ->  y  e.  B
) )
12 abss 3671 . . . . . . 7  |-  ( { y  |  y  e.  ( f `  x
) }  C_  B  <->  A. y ( y  e.  ( f `  x
)  ->  y  e.  B ) )
13 fpwrelmap.2 . . . . . . . 8  |-  B  e. 
_V
1413ssex 4802 . . . . . . 7  |-  ( { y  |  y  e.  ( f `  x
) }  C_  B  ->  { y  |  y  e.  ( f `  x ) }  e.  _V )
1512, 14sylbir 225 . . . . . 6  |-  ( A. y ( y  e.  ( f `  x
)  ->  y  e.  B )  ->  { y  |  y  e.  ( f `  x ) }  e.  _V )
1611, 15syl 17 . . . . 5  |-  ( ( f  e.  ( ~P B  ^m  A )  /\  x  e.  A
)  ->  { y  |  y  e.  (
f `  x ) }  e.  _V )
173, 16opabex3d 7145 . . . 4  |-  ( f  e.  ( ~P B  ^m  A )  ->  { <. x ,  y >.  |  ( x  e.  A  /\  y  e.  ( f `  x ) ) }  e.  _V )
1817adantl 482 . . 3  |-  ( ( T.  /\  f  e.  ( ~P B  ^m  A ) )  ->  { <. x ,  y
>.  |  ( x  e.  A  /\  y  e.  ( f `  x
) ) }  e.  _V )
192mptex 6486 . . . 4  |-  ( x  e.  A  |->  { y  e.  B  |  x r y } )  e.  _V
2019a1i 11 . . 3  |-  ( ( T.  /\  r  e. 
~P ( A  X.  B ) )  -> 
( x  e.  A  |->  { y  e.  B  |  x r y } )  e.  _V )
2110imdistanda 729 . . . . . . . . . 10  |-  ( f  e.  ( ~P B  ^m  A )  ->  (
( x  e.  A  /\  y  e.  (
f `  x )
)  ->  ( x  e.  A  /\  y  e.  B ) ) )
2221ssopab2dv 5004 . . . . . . . . 9  |-  ( f  e.  ( ~P B  ^m  A )  ->  { <. x ,  y >.  |  ( x  e.  A  /\  y  e.  ( f `  x ) ) } 
C_  { <. x ,  y >.  |  ( x  e.  A  /\  y  e.  B ) } )
2322adantr 481 . . . . . . . 8  |-  ( ( f  e.  ( ~P B  ^m  A )  /\  r  =  { <. x ,  y >.  |  ( x  e.  A  /\  y  e.  ( f `  x
) ) } )  ->  { <. x ,  y >.  |  ( x  e.  A  /\  y  e.  ( f `  x ) ) } 
C_  { <. x ,  y >.  |  ( x  e.  A  /\  y  e.  B ) } )
24 simpr 477 . . . . . . . 8  |-  ( ( f  e.  ( ~P B  ^m  A )  /\  r  =  { <. x ,  y >.  |  ( x  e.  A  /\  y  e.  ( f `  x
) ) } )  ->  r  =  { <. x ,  y >.  |  ( x  e.  A  /\  y  e.  ( f `  x
) ) } )
25 df-xp 5120 . . . . . . . . 9  |-  ( A  X.  B )  =  { <. x ,  y
>.  |  ( x  e.  A  /\  y  e.  B ) }
2625a1i 11 . . . . . . . 8  |-  ( ( f  e.  ( ~P B  ^m  A )  /\  r  =  { <. x ,  y >.  |  ( x  e.  A  /\  y  e.  ( f `  x
) ) } )  ->  ( A  X.  B )  =  { <. x ,  y >.  |  ( x  e.  A  /\  y  e.  B ) } )
2723, 24, 263sstr4d 3648 . . . . . . 7  |-  ( ( f  e.  ( ~P B  ^m  A )  /\  r  =  { <. x ,  y >.  |  ( x  e.  A  /\  y  e.  ( f `  x
) ) } )  ->  r  C_  ( A  X.  B ) )
28 selpw 4165 . . . . . . 7  |-  ( r  e.  ~P ( A  X.  B )  <->  r  C_  ( A  X.  B
) )
2927, 28sylibr 224 . . . . . 6  |-  ( ( f  e.  ( ~P B  ^m  A )  /\  r  =  { <. x ,  y >.  |  ( x  e.  A  /\  y  e.  ( f `  x
) ) } )  ->  r  e.  ~P ( A  X.  B
) )
305feqmptd 6249 . . . . . . . 8  |-  ( f  e.  ( ~P B  ^m  A )  ->  f  =  ( x  e.  A  |->  ( f `  x ) ) )
3130adantr 481 . . . . . . 7  |-  ( ( f  e.  ( ~P B  ^m  A )  /\  r  =  { <. x ,  y >.  |  ( x  e.  A  /\  y  e.  ( f `  x
) ) } )  ->  f  =  ( x  e.  A  |->  ( f `  x ) ) )
32 nfv 1843 . . . . . . . . 9  |-  F/ x  f  e.  ( ~P B  ^m  A )
33 nfopab1 4719 . . . . . . . . . 10  |-  F/_ x { <. x ,  y
>.  |  ( x  e.  A  /\  y  e.  ( f `  x
) ) }
3433nfeq2 2780 . . . . . . . . 9  |-  F/ x  r  =  { <. x ,  y >.  |  ( x  e.  A  /\  y  e.  ( f `  x ) ) }
3532, 34nfan 1828 . . . . . . . 8  |-  F/ x
( f  e.  ( ~P B  ^m  A
)  /\  r  =  { <. x ,  y
>.  |  ( x  e.  A  /\  y  e.  ( f `  x
) ) } )
36 df-rab 2921 . . . . . . . . . 10  |-  { y  e.  B  |  x r y }  =  { y  |  ( y  e.  B  /\  x r y ) }
3736a1i 11 . . . . . . . . 9  |-  ( ( ( f  e.  ( ~P B  ^m  A
)  /\  r  =  { <. x ,  y
>.  |  ( x  e.  A  /\  y  e.  ( f `  x
) ) } )  /\  x  e.  A
)  ->  { y  e.  B  |  x
r y }  =  { y  |  ( y  e.  B  /\  x r y ) } )
38 nfv 1843 . . . . . . . . . . . 12  |-  F/ y  f  e.  ( ~P B  ^m  A )
39 nfopab2 4720 . . . . . . . . . . . . 13  |-  F/_ y { <. x ,  y
>.  |  ( x  e.  A  /\  y  e.  ( f `  x
) ) }
4039nfeq2 2780 . . . . . . . . . . . 12  |-  F/ y  r  =  { <. x ,  y >.  |  ( x  e.  A  /\  y  e.  ( f `  x ) ) }
4138, 40nfan 1828 . . . . . . . . . . 11  |-  F/ y ( f  e.  ( ~P B  ^m  A
)  /\  r  =  { <. x ,  y
>.  |  ( x  e.  A  /\  y  e.  ( f `  x
) ) } )
42 nfv 1843 . . . . . . . . . . 11  |-  F/ y  x  e.  A
4341, 42nfan 1828 . . . . . . . . . 10  |-  F/ y ( ( f  e.  ( ~P B  ^m  A )  /\  r  =  { <. x ,  y
>.  |  ( x  e.  A  /\  y  e.  ( f `  x
) ) } )  /\  x  e.  A
)
449adantllr 755 . . . . . . . . . . . . 13  |-  ( ( ( ( f  e.  ( ~P B  ^m  A )  /\  r  =  { <. x ,  y
>.  |  ( x  e.  A  /\  y  e.  ( f `  x
) ) } )  /\  x  e.  A
)  /\  y  e.  ( f `  x
) )  ->  y  e.  B )
45 df-br 4654 . . . . . . . . . . . . . . . . 17  |-  ( x r y  <->  <. x ,  y >.  e.  r
)
46 eleq2 2690 . . . . . . . . . . . . . . . . . 18  |-  ( r  =  { <. x ,  y >.  |  ( x  e.  A  /\  y  e.  ( f `  x ) ) }  ->  ( <. x ,  y >.  e.  r  <->  <. x ,  y >.  e.  { <. x ,  y
>.  |  ( x  e.  A  /\  y  e.  ( f `  x
) ) } ) )
47 opabid 4982 . . . . . . . . . . . . . . . . . 18  |-  ( <.
x ,  y >.  e.  { <. x ,  y
>.  |  ( x  e.  A  /\  y  e.  ( f `  x
) ) }  <->  ( x  e.  A  /\  y  e.  ( f `  x
) ) )
4846, 47syl6bb 276 . . . . . . . . . . . . . . . . 17  |-  ( r  =  { <. x ,  y >.  |  ( x  e.  A  /\  y  e.  ( f `  x ) ) }  ->  ( <. x ,  y >.  e.  r  <-> 
( x  e.  A  /\  y  e.  (
f `  x )
) ) )
4945, 48syl5bb 272 . . . . . . . . . . . . . . . 16  |-  ( r  =  { <. x ,  y >.  |  ( x  e.  A  /\  y  e.  ( f `  x ) ) }  ->  ( x r y  <->  ( x  e.  A  /\  y  e.  ( f `  x
) ) ) )
5049ad2antlr 763 . . . . . . . . . . . . . . 15  |-  ( ( ( f  e.  ( ~P B  ^m  A
)  /\  r  =  { <. x ,  y
>.  |  ( x  e.  A  /\  y  e.  ( f `  x
) ) } )  /\  x  e.  A
)  ->  ( x
r y  <->  ( x  e.  A  /\  y  e.  ( f `  x
) ) ) )
51 elfvdm 6220 . . . . . . . . . . . . . . . . . . . 20  |-  ( y  e.  ( f `  x )  ->  x  e.  dom  f )
5251adantl 482 . . . . . . . . . . . . . . . . . . 19  |-  ( ( f  e.  ( ~P B  ^m  A )  /\  y  e.  ( f `  x ) )  ->  x  e.  dom  f )
53 fdm 6051 . . . . . . . . . . . . . . . . . . . . 21  |-  ( f : A --> ~P B  ->  dom  f  =  A )
545, 53syl 17 . . . . . . . . . . . . . . . . . . . 20  |-  ( f  e.  ( ~P B  ^m  A )  ->  dom  f  =  A )
5554adantr 481 . . . . . . . . . . . . . . . . . . 19  |-  ( ( f  e.  ( ~P B  ^m  A )  /\  y  e.  ( f `  x ) )  ->  dom  f  =  A )
5652, 55eleqtrd 2703 . . . . . . . . . . . . . . . . . 18  |-  ( ( f  e.  ( ~P B  ^m  A )  /\  y  e.  ( f `  x ) )  ->  x  e.  A )
5756ex 450 . . . . . . . . . . . . . . . . 17  |-  ( f  e.  ( ~P B  ^m  A )  ->  (
y  e.  ( f `
 x )  ->  x  e.  A )
)
5857pm4.71rd 667 . . . . . . . . . . . . . . . 16  |-  ( f  e.  ( ~P B  ^m  A )  ->  (
y  e.  ( f `
 x )  <->  ( x  e.  A  /\  y  e.  ( f `  x
) ) ) )
5958ad2antrr 762 . . . . . . . . . . . . . . 15  |-  ( ( ( f  e.  ( ~P B  ^m  A
)  /\  r  =  { <. x ,  y
>.  |  ( x  e.  A  /\  y  e.  ( f `  x
) ) } )  /\  x  e.  A
)  ->  ( y  e.  ( f `  x
)  <->  ( x  e.  A  /\  y  e.  ( f `  x
) ) ) )
6050, 59bitr4d 271 . . . . . . . . . . . . . 14  |-  ( ( ( f  e.  ( ~P B  ^m  A
)  /\  r  =  { <. x ,  y
>.  |  ( x  e.  A  /\  y  e.  ( f `  x
) ) } )  /\  x  e.  A
)  ->  ( x
r y  <->  y  e.  ( f `  x
) ) )
6160biimpar 502 . . . . . . . . . . . . 13  |-  ( ( ( ( f  e.  ( ~P B  ^m  A )  /\  r  =  { <. x ,  y
>.  |  ( x  e.  A  /\  y  e.  ( f `  x
) ) } )  /\  x  e.  A
)  /\  y  e.  ( f `  x
) )  ->  x
r y )
6244, 61jca 554 . . . . . . . . . . . 12  |-  ( ( ( ( f  e.  ( ~P B  ^m  A )  /\  r  =  { <. x ,  y
>.  |  ( x  e.  A  /\  y  e.  ( f `  x
) ) } )  /\  x  e.  A
)  /\  y  e.  ( f `  x
) )  ->  (
y  e.  B  /\  x r y ) )
6362ex 450 . . . . . . . . . . 11  |-  ( ( ( f  e.  ( ~P B  ^m  A
)  /\  r  =  { <. x ,  y
>.  |  ( x  e.  A  /\  y  e.  ( f `  x
) ) } )  /\  x  e.  A
)  ->  ( y  e.  ( f `  x
)  ->  ( y  e.  B  /\  x
r y ) ) )
6460biimpd 219 . . . . . . . . . . . 12  |-  ( ( ( f  e.  ( ~P B  ^m  A
)  /\  r  =  { <. x ,  y
>.  |  ( x  e.  A  /\  y  e.  ( f `  x
) ) } )  /\  x  e.  A
)  ->  ( x
r y  ->  y  e.  ( f `  x
) ) )
6564adantld 483 . . . . . . . . . . 11  |-  ( ( ( f  e.  ( ~P B  ^m  A
)  /\  r  =  { <. x ,  y
>.  |  ( x  e.  A  /\  y  e.  ( f `  x
) ) } )  /\  x  e.  A
)  ->  ( (
y  e.  B  /\  x r y )  ->  y  e.  ( f `  x ) ) )
6663, 65impbid 202 . . . . . . . . . 10  |-  ( ( ( f  e.  ( ~P B  ^m  A
)  /\  r  =  { <. x ,  y
>.  |  ( x  e.  A  /\  y  e.  ( f `  x
) ) } )  /\  x  e.  A
)  ->  ( y  e.  ( f `  x
)  <->  ( y  e.  B  /\  x r y ) ) )
6743, 66abbid 2740 . . . . . . . . 9  |-  ( ( ( f  e.  ( ~P B  ^m  A
)  /\  r  =  { <. x ,  y
>.  |  ( x  e.  A  /\  y  e.  ( f `  x
) ) } )  /\  x  e.  A
)  ->  { y  |  y  e.  (
f `  x ) }  =  { y  |  ( y  e.  B  /\  x r y ) } )
68 abid2 2745 . . . . . . . . . 10  |-  { y  |  y  e.  ( f `  x ) }  =  ( f `
 x )
6968a1i 11 . . . . . . . . 9  |-  ( ( ( f  e.  ( ~P B  ^m  A
)  /\  r  =  { <. x ,  y
>.  |  ( x  e.  A  /\  y  e.  ( f `  x
) ) } )  /\  x  e.  A
)  ->  { y  |  y  e.  (
f `  x ) }  =  ( f `  x ) )
7037, 67, 693eqtr2rd 2663 . . . . . . . 8  |-  ( ( ( f  e.  ( ~P B  ^m  A
)  /\  r  =  { <. x ,  y
>.  |  ( x  e.  A  /\  y  e.  ( f `  x
) ) } )  /\  x  e.  A
)  ->  ( f `  x )  =  {
y  e.  B  |  x r y } )
7135, 70mpteq2da 4743 . . . . . . 7  |-  ( ( f  e.  ( ~P B  ^m  A )  /\  r  =  { <. x ,  y >.  |  ( x  e.  A  /\  y  e.  ( f `  x
) ) } )  ->  ( x  e.  A  |->  ( f `  x ) )  =  ( x  e.  A  |->  { y  e.  B  |  x r y } ) )
7231, 71eqtrd 2656 . . . . . 6  |-  ( ( f  e.  ( ~P B  ^m  A )  /\  r  =  { <. x ,  y >.  |  ( x  e.  A  /\  y  e.  ( f `  x
) ) } )  ->  f  =  ( x  e.  A  |->  { y  e.  B  |  x r y } ) )
7329, 72jca 554 . . . . 5  |-  ( ( f  e.  ( ~P B  ^m  A )  /\  r  =  { <. x ,  y >.  |  ( x  e.  A  /\  y  e.  ( f `  x
) ) } )  ->  ( r  e. 
~P ( A  X.  B )  /\  f  =  ( x  e.  A  |->  { y  e.  B  |  x r y } ) ) )
74 ssrab2 3687 . . . . . . . . . . . 12  |-  { y  e.  B  |  x r y }  C_  B
7513elpw2 4828 . . . . . . . . . . . 12  |-  ( { y  e.  B  |  x r y }  e.  ~P B  <->  { y  e.  B  |  x
r y }  C_  B )
7674, 75mpbir 221 . . . . . . . . . . 11  |-  { y  e.  B  |  x r y }  e.  ~P B
7776a1i 11 . . . . . . . . . 10  |-  ( ( r  e.  ~P ( A  X.  B )  /\  x  e.  A )  ->  { y  e.  B  |  x r y }  e.  ~P B )
78 eqid 2622 . . . . . . . . . 10  |-  ( x  e.  A  |->  { y  e.  B  |  x r y } )  =  ( x  e.  A  |->  { y  e.  B  |  x r y } )
7977, 78fmptd 6385 . . . . . . . . 9  |-  ( r  e.  ~P ( A  X.  B )  -> 
( x  e.  A  |->  { y  e.  B  |  x r y } ) : A --> ~P B
)
8079adantr 481 . . . . . . . 8  |-  ( ( r  e.  ~P ( A  X.  B )  /\  f  =  ( x  e.  A  |->  { y  e.  B  |  x r y } ) )  ->  ( x  e.  A  |->  { y  e.  B  |  x r y } ) : A --> ~P B
)
81 simpr 477 . . . . . . . . 9  |-  ( ( r  e.  ~P ( A  X.  B )  /\  f  =  ( x  e.  A  |->  { y  e.  B  |  x r y } ) )  ->  f  =  ( x  e.  A  |->  { y  e.  B  |  x r y } ) )
8281feq1d 6030 . . . . . . . 8  |-  ( ( r  e.  ~P ( A  X.  B )  /\  f  =  ( x  e.  A  |->  { y  e.  B  |  x r y } ) )  ->  ( f : A --> ~P B  <->  ( x  e.  A  |->  { y  e.  B  |  x r y } ) : A --> ~P B
) )
8380, 82mpbird 247 . . . . . . 7  |-  ( ( r  e.  ~P ( A  X.  B )  /\  f  =  ( x  e.  A  |->  { y  e.  B  |  x r y } ) )  ->  f : A
--> ~P B )
8413pwex 4848 . . . . . . . 8  |-  ~P B  e.  _V
8584, 2elmap 7886 . . . . . . 7  |-  ( f  e.  ( ~P B  ^m  A )  <->  f : A
--> ~P B )
8683, 85sylibr 224 . . . . . 6  |-  ( ( r  e.  ~P ( A  X.  B )  /\  f  =  ( x  e.  A  |->  { y  e.  B  |  x r y } ) )  ->  f  e.  ( ~P B  ^m  A
) )
87 elpwi 4168 . . . . . . . . . 10  |-  ( r  e.  ~P ( A  X.  B )  -> 
r  C_  ( A  X.  B ) )
8887adantr 481 . . . . . . . . 9  |-  ( ( r  e.  ~P ( A  X.  B )  /\  f  =  ( x  e.  A  |->  { y  e.  B  |  x r y } ) )  ->  r  C_  ( A  X.  B
) )
89 xpss 5226 . . . . . . . . 9  |-  ( A  X.  B )  C_  ( _V  X.  _V )
9088, 89syl6ss 3615 . . . . . . . 8  |-  ( ( r  e.  ~P ( A  X.  B )  /\  f  =  ( x  e.  A  |->  { y  e.  B  |  x r y } ) )  ->  r  C_  ( _V  X.  _V )
)
91 df-rel 5121 . . . . . . . 8  |-  ( Rel  r  <->  r  C_  ( _V  X.  _V ) )
9290, 91sylibr 224 . . . . . . 7  |-  ( ( r  e.  ~P ( A  X.  B )  /\  f  =  ( x  e.  A  |->  { y  e.  B  |  x r y } ) )  ->  Rel  r )
93 relopab 5247 . . . . . . . 8  |-  Rel  { <. x ,  y >.  |  ( x  e.  A  /\  y  e.  ( f `  x
) ) }
9493a1i 11 . . . . . . 7  |-  ( ( r  e.  ~P ( A  X.  B )  /\  f  =  ( x  e.  A  |->  { y  e.  B  |  x r y } ) )  ->  Rel  { <. x ,  y >.  |  ( x  e.  A  /\  y  e.  ( f `  x ) ) } )
95 id 22 . . . . . . 7  |-  ( ( r  e.  ~P ( A  X.  B )  /\  f  =  ( x  e.  A  |->  { y  e.  B  |  x r y } ) )  ->  ( r  e.  ~P ( A  X.  B )  /\  f  =  ( x  e.  A  |->  { y  e.  B  |  x r y } ) ) )
96 nfv 1843 . . . . . . . . 9  |-  F/ x  r  e.  ~P ( A  X.  B )
97 nfmpt1 4747 . . . . . . . . . 10  |-  F/_ x
( x  e.  A  |->  { y  e.  B  |  x r y } )
9897nfeq2 2780 . . . . . . . . 9  |-  F/ x  f  =  ( x  e.  A  |->  { y  e.  B  |  x r y } )
9996, 98nfan 1828 . . . . . . . 8  |-  F/ x
( r  e.  ~P ( A  X.  B
)  /\  f  =  ( x  e.  A  |->  { y  e.  B  |  x r y } ) )
100 nfv 1843 . . . . . . . . 9  |-  F/ y  r  e.  ~P ( A  X.  B )
10142nfci 2754 . . . . . . . . . . 11  |-  F/_ y A
102 nfrab1 3122 . . . . . . . . . . 11  |-  F/_ y { y  e.  B  |  x r y }
103101, 102nfmpt 4746 . . . . . . . . . 10  |-  F/_ y
( x  e.  A  |->  { y  e.  B  |  x r y } )
104103nfeq2 2780 . . . . . . . . 9  |-  F/ y  f  =  ( x  e.  A  |->  { y  e.  B  |  x r y } )
105100, 104nfan 1828 . . . . . . . 8  |-  F/ y ( r  e.  ~P ( A  X.  B
)  /\  f  =  ( x  e.  A  |->  { y  e.  B  |  x r y } ) )
106 nfcv 2764 . . . . . . . 8  |-  F/_ x
r
107 nfcv 2764 . . . . . . . 8  |-  F/_ y
r
108 brelg 29421 . . . . . . . . . . . . . . . 16  |-  ( ( r  C_  ( A  X.  B )  /\  x
r y )  -> 
( x  e.  A  /\  y  e.  B
) )
10987, 108sylan 488 . . . . . . . . . . . . . . 15  |-  ( ( r  e.  ~P ( A  X.  B )  /\  x r y )  ->  ( x  e.  A  /\  y  e.  B ) )
110109adantlr 751 . . . . . . . . . . . . . 14  |-  ( ( ( r  e.  ~P ( A  X.  B
)  /\  f  =  ( x  e.  A  |->  { y  e.  B  |  x r y } ) )  /\  x
r y )  -> 
( x  e.  A  /\  y  e.  B
) )
111110simpld 475 . . . . . . . . . . . . 13  |-  ( ( ( r  e.  ~P ( A  X.  B
)  /\  f  =  ( x  e.  A  |->  { y  e.  B  |  x r y } ) )  /\  x
r y )  ->  x  e.  A )
112110simprd 479 . . . . . . . . . . . . . 14  |-  ( ( ( r  e.  ~P ( A  X.  B
)  /\  f  =  ( x  e.  A  |->  { y  e.  B  |  x r y } ) )  /\  x
r y )  -> 
y  e.  B )
113 simpr 477 . . . . . . . . . . . . . 14  |-  ( ( ( r  e.  ~P ( A  X.  B
)  /\  f  =  ( x  e.  A  |->  { y  e.  B  |  x r y } ) )  /\  x
r y )  ->  x r y )
11481fveq1d 6193 . . . . . . . . . . . . . . . . . 18  |-  ( ( r  e.  ~P ( A  X.  B )  /\  f  =  ( x  e.  A  |->  { y  e.  B  |  x r y } ) )  ->  ( f `  x )  =  ( ( x  e.  A  |->  { y  e.  B  |  x r y } ) `  x ) )
11513rabex 4813 . . . . . . . . . . . . . . . . . . 19  |-  { y  e.  B  |  x r y }  e.  _V
11678fvmpt2 6291 . . . . . . . . . . . . . . . . . . 19  |-  ( ( x  e.  A  /\  { y  e.  B  |  x r y }  e.  _V )  -> 
( ( x  e.  A  |->  { y  e.  B  |  x r y } ) `  x )  =  {
y  e.  B  |  x r y } )
117115, 116mpan2 707 . . . . . . . . . . . . . . . . . 18  |-  ( x  e.  A  ->  (
( x  e.  A  |->  { y  e.  B  |  x r y } ) `  x )  =  { y  e.  B  |  x r y } )
118114, 117sylan9eq 2676 . . . . . . . . . . . . . . . . 17  |-  ( ( ( r  e.  ~P ( A  X.  B
)  /\  f  =  ( x  e.  A  |->  { y  e.  B  |  x r y } ) )  /\  x  e.  A )  ->  (
f `  x )  =  { y  e.  B  |  x r y } )
119118eleq2d 2687 . . . . . . . . . . . . . . . 16  |-  ( ( ( r  e.  ~P ( A  X.  B
)  /\  f  =  ( x  e.  A  |->  { y  e.  B  |  x r y } ) )  /\  x  e.  A )  ->  (
y  e.  ( f `
 x )  <->  y  e.  { y  e.  B  |  x r y } ) )
120 rabid 3116 . . . . . . . . . . . . . . . 16  |-  ( y  e.  { y  e.  B  |  x r y }  <->  ( y  e.  B  /\  x
r y ) )
121119, 120syl6bb 276 . . . . . . . . . . . . . . 15  |-  ( ( ( r  e.  ~P ( A  X.  B
)  /\  f  =  ( x  e.  A  |->  { y  e.  B  |  x r y } ) )  /\  x  e.  A )  ->  (
y  e.  ( f `
 x )  <->  ( y  e.  B  /\  x
r y ) ) )
122111, 121syldan 487 . . . . . . . . . . . . . 14  |-  ( ( ( r  e.  ~P ( A  X.  B
)  /\  f  =  ( x  e.  A  |->  { y  e.  B  |  x r y } ) )  /\  x
r y )  -> 
( y  e.  ( f `  x )  <-> 
( y  e.  B  /\  x r y ) ) )
123112, 113, 122mpbir2and 957 . . . . . . . . . . . . 13  |-  ( ( ( r  e.  ~P ( A  X.  B
)  /\  f  =  ( x  e.  A  |->  { y  e.  B  |  x r y } ) )  /\  x
r y )  -> 
y  e.  ( f `
 x ) )
124111, 123jca 554 . . . . . . . . . . . 12  |-  ( ( ( r  e.  ~P ( A  X.  B
)  /\  f  =  ( x  e.  A  |->  { y  e.  B  |  x r y } ) )  /\  x
r y )  -> 
( x  e.  A  /\  y  e.  (
f `  x )
) )
125124ex 450 . . . . . . . . . . 11  |-  ( ( r  e.  ~P ( A  X.  B )  /\  f  =  ( x  e.  A  |->  { y  e.  B  |  x r y } ) )  ->  ( x
r y  ->  (
x  e.  A  /\  y  e.  ( f `  x ) ) ) )
126121simplbda 654 . . . . . . . . . . . 12  |-  ( ( ( ( r  e. 
~P ( A  X.  B )  /\  f  =  ( x  e.  A  |->  { y  e.  B  |  x r y } ) )  /\  x  e.  A
)  /\  y  e.  ( f `  x
) )  ->  x
r y )
127126expl 648 . . . . . . . . . . 11  |-  ( ( r  e.  ~P ( A  X.  B )  /\  f  =  ( x  e.  A  |->  { y  e.  B  |  x r y } ) )  ->  ( (
x  e.  A  /\  y  e.  ( f `  x ) )  ->  x r y ) )
128125, 127impbid 202 . . . . . . . . . 10  |-  ( ( r  e.  ~P ( A  X.  B )  /\  f  =  ( x  e.  A  |->  { y  e.  B  |  x r y } ) )  ->  ( x
r y  <->  ( x  e.  A  /\  y  e.  ( f `  x
) ) ) )
12945, 128syl5bbr 274 . . . . . . . . 9  |-  ( ( r  e.  ~P ( A  X.  B )  /\  f  =  ( x  e.  A  |->  { y  e.  B  |  x r y } ) )  ->  ( <. x ,  y >.  e.  r  <-> 
( x  e.  A  /\  y  e.  (
f `  x )
) ) )
130129, 47syl6bbr 278 . . . . . . . 8  |-  ( ( r  e.  ~P ( A  X.  B )  /\  f  =  ( x  e.  A  |->  { y  e.  B  |  x r y } ) )  ->  ( <. x ,  y >.  e.  r  <->  <. x ,  y >.  e.  { <. x ,  y
>.  |  ( x  e.  A  /\  y  e.  ( f `  x
) ) } ) )
13199, 105, 106, 107, 33, 39, 130eqrelrd2 29426 . . . . . . 7  |-  ( ( ( Rel  r  /\  Rel  { <. x ,  y
>.  |  ( x  e.  A  /\  y  e.  ( f `  x
) ) } )  /\  ( r  e. 
~P ( A  X.  B )  /\  f  =  ( x  e.  A  |->  { y  e.  B  |  x r y } ) ) )  ->  r  =  { <. x ,  y
>.  |  ( x  e.  A  /\  y  e.  ( f `  x
) ) } )
13292, 94, 95, 131syl21anc 1325 . . . . . 6  |-  ( ( r  e.  ~P ( A  X.  B )  /\  f  =  ( x  e.  A  |->  { y  e.  B  |  x r y } ) )  ->  r  =  { <. x ,  y
>.  |  ( x  e.  A  /\  y  e.  ( f `  x
) ) } )
13386, 132jca 554 . . . . 5  |-  ( ( r  e.  ~P ( A  X.  B )  /\  f  =  ( x  e.  A  |->  { y  e.  B  |  x r y } ) )  ->  ( f  e.  ( ~P B  ^m  A )  /\  r  =  { <. x ,  y
>.  |  ( x  e.  A  /\  y  e.  ( f `  x
) ) } ) )
13473, 133impbii 199 . . . 4  |-  ( ( f  e.  ( ~P B  ^m  A )  /\  r  =  { <. x ,  y >.  |  ( x  e.  A  /\  y  e.  ( f `  x
) ) } )  <-> 
( r  e.  ~P ( A  X.  B
)  /\  f  =  ( x  e.  A  |->  { y  e.  B  |  x r y } ) ) )
135134a1i 11 . . 3  |-  ( T. 
->  ( ( f  e.  ( ~P B  ^m  A )  /\  r  =  { <. x ,  y
>.  |  ( x  e.  A  /\  y  e.  ( f `  x
) ) } )  <-> 
( r  e.  ~P ( A  X.  B
)  /\  f  =  ( x  e.  A  |->  { y  e.  B  |  x r y } ) ) ) )
1361, 18, 20, 135f1od 6885 . 2  |-  ( T. 
->  M : ( ~P B  ^m  A ) -1-1-onto-> ~P ( A  X.  B
) )
137136trud 1493 1  |-  M :
( ~P B  ^m  A ) -1-1-onto-> ~P ( A  X.  B )
Colors of variables: wff setvar class
Syntax hints:    -> wi 4    <-> wb 196    /\ wa 384   A.wal 1481    = wceq 1483   T. wtru 1484    e. wcel 1990   {cab 2608   {crab 2916   _Vcvv 3200    C_ wss 3574   ~Pcpw 4158   <.cop 4183   class class class wbr 4653   {copab 4712    |-> cmpt 4729    X. cxp 5112   dom cdm 5114   Rel wrel 5119   -->wf 5884   -1-1-onto->wf1o 5887   ` cfv 5888  (class class class)co 6650    ^m cmap 7857
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-3 8  ax-gen 1722  ax-4 1737  ax-5 1839  ax-6 1888  ax-7 1935  ax-8 1992  ax-9 1999  ax-10 2019  ax-11 2034  ax-12 2047  ax-13 2246  ax-ext 2602  ax-rep 4771  ax-sep 4781  ax-nul 4789  ax-pow 4843  ax-pr 4906  ax-un 6949
This theorem depends on definitions:  df-bi 197  df-or 385  df-an 386  df-3an 1039  df-tru 1486  df-ex 1705  df-nf 1710  df-sb 1881  df-eu 2474  df-mo 2475  df-clab 2609  df-cleq 2615  df-clel 2618  df-nfc 2753  df-ne 2795  df-ral 2917  df-rex 2918  df-reu 2919  df-rab 2921  df-v 3202  df-sbc 3436  df-csb 3534  df-dif 3577  df-un 3579  df-in 3581  df-ss 3588  df-nul 3916  df-if 4087  df-pw 4160  df-sn 4178  df-pr 4180  df-op 4184  df-uni 4437  df-iun 4522  df-br 4654  df-opab 4713  df-mpt 4730  df-id 5024  df-xp 5120  df-rel 5121  df-cnv 5122  df-co 5123  df-dm 5124  df-rn 5125  df-res 5126  df-ima 5127  df-iota 5851  df-fun 5890  df-fn 5891  df-f 5892  df-f1 5893  df-fo 5894  df-f1o 5895  df-fv 5896  df-ov 6653  df-oprab 6654  df-mpt2 6655  df-1st 7168  df-2nd 7169  df-map 7859
This theorem is referenced by:  fpwrelmapffs  29509
  Copyright terms: Public domain W3C validator