MPE Home Metamath Proof Explorer < Previous   Next >
Nearby theorems
Mirrors  >  Home  >  MPE Home  >  Th. List  >  elfm3 Structured version   Unicode version

Theorem elfm3 17987
Description: An alternate formulation of elementhood in a mapping filter that requires  F to be onto. (Contributed by Jeff Hankins, 1-Oct-2009.) (Revised by Stefan O'Rear, 6-Aug-2015.)
Hypothesis
Ref Expression
elfm2.l  |-  L  =  ( Y filGen B )
Assertion
Ref Expression
elfm3  |-  ( ( B  e.  ( fBas `  Y )  /\  F : Y -onto-> X )  ->  ( A  e.  ( ( X  FilMap  F ) `  B )  <->  E. x  e.  L  A  =  ( F " x ) ) )
Distinct variable groups:    x, B    x, F    x, X    x, A    x, L    x, Y

Proof of Theorem elfm3
Dummy variables  y 
z are mutually distinct and distinct from all other variables.
StepHypRef Expression
1 foima 5661 . . . 4  |-  ( F : Y -onto-> X  -> 
( F " Y
)  =  X )
21adantl 454 . . 3  |-  ( ( B  e.  ( fBas `  Y )  /\  F : Y -onto-> X )  ->  ( F " Y )  =  X )
3 fofun 5657 . . . 4  |-  ( F : Y -onto-> X  ->  Fun  F )
4 elfvdm 5760 . . . 4  |-  ( B  e.  ( fBas `  Y
)  ->  Y  e.  dom  fBas )
5 funimaexg 5533 . . . 4  |-  ( ( Fun  F  /\  Y  e.  dom  fBas )  ->  ( F " Y )  e. 
_V )
63, 4, 5syl2anr 466 . . 3  |-  ( ( B  e.  ( fBas `  Y )  /\  F : Y -onto-> X )  ->  ( F " Y )  e. 
_V )
72, 6eqeltrrd 2513 . 2  |-  ( ( B  e.  ( fBas `  Y )  /\  F : Y -onto-> X )  ->  X  e.  _V )
8 fof 5656 . . . . 5  |-  ( F : Y -onto-> X  ->  F : Y --> X )
9 elfm2.l . . . . . 6  |-  L  =  ( Y filGen B )
109elfm2 17985 . . . . 5  |-  ( ( X  e.  _V  /\  B  e.  ( fBas `  Y )  /\  F : Y --> X )  -> 
( A  e.  ( ( X  FilMap  F ) `
 B )  <->  ( A  C_  X  /\  E. y  e.  L  ( F " y )  C_  A
) ) )
118, 10syl3an3 1220 . . . 4  |-  ( ( X  e.  _V  /\  B  e.  ( fBas `  Y )  /\  F : Y -onto-> X )  ->  ( A  e.  ( ( X  FilMap  F ) `  B )  <->  ( A  C_  X  /\  E. y  e.  L  ( F " y )  C_  A
) ) )
12 fgcl 17915 . . . . . . . . . . . 12  |-  ( B  e.  ( fBas `  Y
)  ->  ( Y filGen B )  e.  ( Fil `  Y ) )
139, 12syl5eqel 2522 . . . . . . . . . . 11  |-  ( B  e.  ( fBas `  Y
)  ->  L  e.  ( Fil `  Y ) )
14133ad2ant2 980 . . . . . . . . . 10  |-  ( ( X  e.  _V  /\  B  e.  ( fBas `  Y )  /\  F : Y -onto-> X )  ->  L  e.  ( Fil `  Y
) )
1514ad2antrr 708 . . . . . . . . 9  |-  ( ( ( ( X  e. 
_V  /\  B  e.  ( fBas `  Y )  /\  F : Y -onto-> X
)  /\  A  C_  X
)  /\  ( y  e.  L  /\  ( F " y )  C_  A ) )  ->  L  e.  ( Fil `  Y ) )
16 simprl 734 . . . . . . . . 9  |-  ( ( ( ( X  e. 
_V  /\  B  e.  ( fBas `  Y )  /\  F : Y -onto-> X
)  /\  A  C_  X
)  /\  ( y  e.  L  /\  ( F " y )  C_  A ) )  -> 
y  e.  L )
17 cnvimass 5227 . . . . . . . . . . . 12  |-  ( `' F " A ) 
C_  dom  F
18 fofn 5658 . . . . . . . . . . . . 13  |-  ( F : Y -onto-> X  ->  F  Fn  Y )
19 fndm 5547 . . . . . . . . . . . . 13  |-  ( F  Fn  Y  ->  dom  F  =  Y )
2018, 19syl 16 . . . . . . . . . . . 12  |-  ( F : Y -onto-> X  ->  dom  F  =  Y )
2117, 20syl5sseq 3398 . . . . . . . . . . 11  |-  ( F : Y -onto-> X  -> 
( `' F " A )  C_  Y
)
22213ad2ant3 981 . . . . . . . . . 10  |-  ( ( X  e.  _V  /\  B  e.  ( fBas `  Y )  /\  F : Y -onto-> X )  ->  ( `' F " A ) 
C_  Y )
2322ad2antrr 708 . . . . . . . . 9  |-  ( ( ( ( X  e. 
_V  /\  B  e.  ( fBas `  Y )  /\  F : Y -onto-> X
)  /\  A  C_  X
)  /\  ( y  e.  L  /\  ( F " y )  C_  A ) )  -> 
( `' F " A )  C_  Y
)
2433ad2ant3 981 . . . . . . . . . . . . 13  |-  ( ( X  e.  _V  /\  B  e.  ( fBas `  Y )  /\  F : Y -onto-> X )  ->  Fun  F )
2524ad2antrr 708 . . . . . . . . . . . 12  |-  ( ( ( ( X  e. 
_V  /\  B  e.  ( fBas `  Y )  /\  F : Y -onto-> X
)  /\  A  C_  X
)  /\  y  e.  L )  ->  Fun  F )
269eleq2i 2502 . . . . . . . . . . . . . . 15  |-  ( y  e.  L  <->  y  e.  ( Y filGen B ) )
27 elfg 17908 . . . . . . . . . . . . . . . . 17  |-  ( B  e.  ( fBas `  Y
)  ->  ( y  e.  ( Y filGen B )  <-> 
( y  C_  Y  /\  E. z  e.  B  z  C_  y ) ) )
28273ad2ant2 980 . . . . . . . . . . . . . . . 16  |-  ( ( X  e.  _V  /\  B  e.  ( fBas `  Y )  /\  F : Y -onto-> X )  ->  (
y  e.  ( Y
filGen B )  <->  ( y  C_  Y  /\  E. z  e.  B  z  C_  y ) ) )
2928adantr 453 . . . . . . . . . . . . . . 15  |-  ( ( ( X  e.  _V  /\  B  e.  ( fBas `  Y )  /\  F : Y -onto-> X )  /\  A  C_  X )  ->  (
y  e.  ( Y
filGen B )  <->  ( y  C_  Y  /\  E. z  e.  B  z  C_  y ) ) )
3026, 29syl5bb 250 . . . . . . . . . . . . . 14  |-  ( ( ( X  e.  _V  /\  B  e.  ( fBas `  Y )  /\  F : Y -onto-> X )  /\  A  C_  X )  ->  (
y  e.  L  <->  ( y  C_  Y  /\  E. z  e.  B  z  C_  y ) ) )
3130simprbda 608 . . . . . . . . . . . . 13  |-  ( ( ( ( X  e. 
_V  /\  B  e.  ( fBas `  Y )  /\  F : Y -onto-> X
)  /\  A  C_  X
)  /\  y  e.  L )  ->  y  C_  Y )
32 sseq2 3372 . . . . . . . . . . . . . . . . 17  |-  ( dom 
F  =  Y  -> 
( y  C_  dom  F  <-> 
y  C_  Y )
)
3332biimpar 473 . . . . . . . . . . . . . . . 16  |-  ( ( dom  F  =  Y  /\  y  C_  Y
)  ->  y  C_  dom  F )
3420, 33sylan 459 . . . . . . . . . . . . . . 15  |-  ( ( F : Y -onto-> X  /\  y  C_  Y )  ->  y  C_  dom  F )
35343ad2antl3 1122 . . . . . . . . . . . . . 14  |-  ( ( ( X  e.  _V  /\  B  e.  ( fBas `  Y )  /\  F : Y -onto-> X )  /\  y  C_  Y )  ->  y  C_ 
dom  F )
3635adantlr 697 . . . . . . . . . . . . 13  |-  ( ( ( ( X  e. 
_V  /\  B  e.  ( fBas `  Y )  /\  F : Y -onto-> X
)  /\  A  C_  X
)  /\  y  C_  Y )  ->  y  C_ 
dom  F )
3731, 36syldan 458 . . . . . . . . . . . 12  |-  ( ( ( ( X  e. 
_V  /\  B  e.  ( fBas `  Y )  /\  F : Y -onto-> X
)  /\  A  C_  X
)  /\  y  e.  L )  ->  y  C_ 
dom  F )
38 funimass3 5849 . . . . . . . . . . . 12  |-  ( ( Fun  F  /\  y  C_ 
dom  F )  -> 
( ( F "
y )  C_  A  <->  y 
C_  ( `' F " A ) ) )
3925, 37, 38syl2anc 644 . . . . . . . . . . 11  |-  ( ( ( ( X  e. 
_V  /\  B  e.  ( fBas `  Y )  /\  F : Y -onto-> X
)  /\  A  C_  X
)  /\  y  e.  L )  ->  (
( F " y
)  C_  A  <->  y  C_  ( `' F " A ) ) )
4039biimpd 200 . . . . . . . . . 10  |-  ( ( ( ( X  e. 
_V  /\  B  e.  ( fBas `  Y )  /\  F : Y -onto-> X
)  /\  A  C_  X
)  /\  y  e.  L )  ->  (
( F " y
)  C_  A  ->  y 
C_  ( `' F " A ) ) )
4140impr 604 . . . . . . . . 9  |-  ( ( ( ( X  e. 
_V  /\  B  e.  ( fBas `  Y )  /\  F : Y -onto-> X
)  /\  A  C_  X
)  /\  ( y  e.  L  /\  ( F " y )  C_  A ) )  -> 
y  C_  ( `' F " A ) )
42 filss 17890 . . . . . . . . 9  |-  ( ( L  e.  ( Fil `  Y )  /\  (
y  e.  L  /\  ( `' F " A ) 
C_  Y  /\  y  C_  ( `' F " A ) ) )  ->  ( `' F " A )  e.  L
)
4315, 16, 23, 41, 42syl13anc 1187 . . . . . . . 8  |-  ( ( ( ( X  e. 
_V  /\  B  e.  ( fBas `  Y )  /\  F : Y -onto-> X
)  /\  A  C_  X
)  /\  ( y  e.  L  /\  ( F " y )  C_  A ) )  -> 
( `' F " A )  e.  L
)
44 foimacnv 5695 . . . . . . . . . . 11  |-  ( ( F : Y -onto-> X  /\  A  C_  X )  ->  ( F "
( `' F " A ) )  =  A )
4544eqcomd 2443 . . . . . . . . . 10  |-  ( ( F : Y -onto-> X  /\  A  C_  X )  ->  A  =  ( F " ( `' F " A ) ) )
46453ad2antl3 1122 . . . . . . . . 9  |-  ( ( ( X  e.  _V  /\  B  e.  ( fBas `  Y )  /\  F : Y -onto-> X )  /\  A  C_  X )  ->  A  =  ( F "
( `' F " A ) ) )
4746adantr 453 . . . . . . . 8  |-  ( ( ( ( X  e. 
_V  /\  B  e.  ( fBas `  Y )  /\  F : Y -onto-> X
)  /\  A  C_  X
)  /\  ( y  e.  L  /\  ( F " y )  C_  A ) )  ->  A  =  ( F " ( `' F " A ) ) )
48 imaeq2 5202 . . . . . . . . . 10  |-  ( x  =  ( `' F " A )  ->  ( F " x )  =  ( F " ( `' F " A ) ) )
4948eqeq2d 2449 . . . . . . . . 9  |-  ( x  =  ( `' F " A )  ->  ( A  =  ( F " x )  <->  A  =  ( F " ( `' F " A ) ) ) )
5049rspcev 3054 . . . . . . . 8  |-  ( ( ( `' F " A )  e.  L  /\  A  =  ( F " ( `' F " A ) ) )  ->  E. x  e.  L  A  =  ( F " x ) )
5143, 47, 50syl2anc 644 . . . . . . 7  |-  ( ( ( ( X  e. 
_V  /\  B  e.  ( fBas `  Y )  /\  F : Y -onto-> X
)  /\  A  C_  X
)  /\  ( y  e.  L  /\  ( F " y )  C_  A ) )  ->  E. x  e.  L  A  =  ( F " x ) )
5251rexlimdvaa 2833 . . . . . 6  |-  ( ( ( X  e.  _V  /\  B  e.  ( fBas `  Y )  /\  F : Y -onto-> X )  /\  A  C_  X )  ->  ( E. y  e.  L  ( F " y ) 
C_  A  ->  E. x  e.  L  A  =  ( F " x ) ) )
5352expimpd 588 . . . . 5  |-  ( ( X  e.  _V  /\  B  e.  ( fBas `  Y )  /\  F : Y -onto-> X )  ->  (
( A  C_  X  /\  E. y  e.  L  ( F " y ) 
C_  A )  ->  E. x  e.  L  A  =  ( F " x ) ) )
54 simprr 735 . . . . . . . 8  |-  ( ( ( X  e.  _V  /\  B  e.  ( fBas `  Y )  /\  F : Y -onto-> X )  /\  (
x  e.  L  /\  A  =  ( F " x ) ) )  ->  A  =  ( F " x ) )
55 imassrn 5219 . . . . . . . . 9  |-  ( F
" x )  C_  ran  F
56 forn 5659 . . . . . . . . . . 11  |-  ( F : Y -onto-> X  ->  ran  F  =  X )
57563ad2ant3 981 . . . . . . . . . 10  |-  ( ( X  e.  _V  /\  B  e.  ( fBas `  Y )  /\  F : Y -onto-> X )  ->  ran  F  =  X )
5857adantr 453 . . . . . . . . 9  |-  ( ( ( X  e.  _V  /\  B  e.  ( fBas `  Y )  /\  F : Y -onto-> X )  /\  (
x  e.  L  /\  A  =  ( F " x ) ) )  ->  ran  F  =  X )
5955, 58syl5sseq 3398 . . . . . . . 8  |-  ( ( ( X  e.  _V  /\  B  e.  ( fBas `  Y )  /\  F : Y -onto-> X )  /\  (
x  e.  L  /\  A  =  ( F " x ) ) )  ->  ( F "
x )  C_  X
)
6054, 59eqsstrd 3384 . . . . . . 7  |-  ( ( ( X  e.  _V  /\  B  e.  ( fBas `  Y )  /\  F : Y -onto-> X )  /\  (
x  e.  L  /\  A  =  ( F " x ) ) )  ->  A  C_  X
)
61 eqimss2 3403 . . . . . . . . 9  |-  ( A  =  ( F "
x )  ->  ( F " x )  C_  A )
62 imaeq2 5202 . . . . . . . . . . 11  |-  ( y  =  x  ->  ( F " y )  =  ( F " x
) )
6362sseq1d 3377 . . . . . . . . . 10  |-  ( y  =  x  ->  (
( F " y
)  C_  A  <->  ( F " x )  C_  A
) )
6463rspcev 3054 . . . . . . . . 9  |-  ( ( x  e.  L  /\  ( F " x ) 
C_  A )  ->  E. y  e.  L  ( F " y ) 
C_  A )
6561, 64sylan2 462 . . . . . . . 8  |-  ( ( x  e.  L  /\  A  =  ( F " x ) )  ->  E. y  e.  L  ( F " y ) 
C_  A )
6665adantl 454 . . . . . . 7  |-  ( ( ( X  e.  _V  /\  B  e.  ( fBas `  Y )  /\  F : Y -onto-> X )  /\  (
x  e.  L  /\  A  =  ( F " x ) ) )  ->  E. y  e.  L  ( F " y ) 
C_  A )
6760, 66jca 520 . . . . . 6  |-  ( ( ( X  e.  _V  /\  B  e.  ( fBas `  Y )  /\  F : Y -onto-> X )  /\  (
x  e.  L  /\  A  =  ( F " x ) ) )  ->  ( A  C_  X  /\  E. y  e.  L  ( F "
y )  C_  A
) )
6867rexlimdvaa 2833 . . . . 5  |-  ( ( X  e.  _V  /\  B  e.  ( fBas `  Y )  /\  F : Y -onto-> X )  ->  ( E. x  e.  L  A  =  ( F " x )  ->  ( A  C_  X  /\  E. y  e.  L  ( F " y )  C_  A ) ) )
6953, 68impbid 185 . . . 4  |-  ( ( X  e.  _V  /\  B  e.  ( fBas `  Y )  /\  F : Y -onto-> X )  ->  (
( A  C_  X  /\  E. y  e.  L  ( F " y ) 
C_  A )  <->  E. x  e.  L  A  =  ( F " x ) ) )
7011, 69bitrd 246 . . 3  |-  ( ( X  e.  _V  /\  B  e.  ( fBas `  Y )  /\  F : Y -onto-> X )  ->  ( A  e.  ( ( X  FilMap  F ) `  B )  <->  E. x  e.  L  A  =  ( F " x ) ) )
71703coml 1161 . 2  |-  ( ( B  e.  ( fBas `  Y )  /\  F : Y -onto-> X  /\  X  e. 
_V )  ->  ( A  e.  ( ( X  FilMap  F ) `  B )  <->  E. x  e.  L  A  =  ( F " x ) ) )
727, 71mpd3an3 1281 1  |-  ( ( B  e.  ( fBas `  Y )  /\  F : Y -onto-> X )  ->  ( A  e.  ( ( X  FilMap  F ) `  B )  <->  E. x  e.  L  A  =  ( F " x ) ) )
Colors of variables: wff set class
Syntax hints:    -> wi 4    <-> wb 178    /\ wa 360    /\ w3a 937    = wceq 1653    e. wcel 1726   E.wrex 2708   _Vcvv 2958    C_ wss 3322   `'ccnv 4880   dom cdm 4881   ran crn 4882   "cima 4884   Fun wfun 5451    Fn wfn 5452   -->wf 5453   -onto->wfo 5455   ` cfv 5457  (class class class)co 6084   fBascfbas 16694   filGencfg 16695   Filcfil 17882    FilMap cfm 17970
This theorem is referenced by:  fmid  17997
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-3 8  ax-gen 1556  ax-5 1567  ax-17 1627  ax-9 1667  ax-8 1688  ax-13 1728  ax-14 1730  ax-6 1745  ax-7 1750  ax-11 1762  ax-12 1951  ax-ext 2419  ax-rep 4323  ax-sep 4333  ax-nul 4341  ax-pow 4380  ax-pr 4406  ax-un 4704
This theorem depends on definitions:  df-bi 179  df-or 361  df-an 362  df-3an 939  df-tru 1329  df-ex 1552  df-nf 1555  df-sb 1660  df-eu 2287  df-mo 2288  df-clab 2425  df-cleq 2431  df-clel 2434  df-nfc 2563  df-ne 2603  df-nel 2604  df-ral 2712  df-rex 2713  df-reu 2714  df-rab 2716  df-v 2960  df-sbc 3164  df-csb 3254  df-dif 3325  df-un 3327  df-in 3329  df-ss 3336  df-nul 3631  df-if 3742  df-pw 3803  df-sn 3822  df-pr 3823  df-op 3825  df-uni 4018  df-iun 4097  df-br 4216  df-opab 4270  df-mpt 4271  df-id 4501  df-xp 4887  df-rel 4888  df-cnv 4889  df-co 4890  df-dm 4891  df-rn 4892  df-res 4893  df-ima 4894  df-iota 5421  df-fun 5459  df-fn 5460  df-f 5461  df-f1 5462  df-fo 5463  df-f1o 5464  df-fv 5465  df-ov 6087  df-oprab 6088  df-mpt2 6089  df-fbas 16704  df-fg 16705  df-fil 17883  df-fm 17975
  Copyright terms: Public domain W3C validator