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

Theorem dis2ndc 19755
Description: A discrete space is second-countable iff it is countable. (Contributed by Mario Carneiro, 13-Apr-2015.)
Assertion
Ref Expression
dis2ndc  |-  ( X  ~<_  om  <->  ~P X  e.  2ndc )

Proof of Theorem dis2ndc
Dummy variables  w  b  x  y  z are mutually distinct and distinct from all other variables.
StepHypRef Expression
1 reldom 7522 . . 3  |-  Rel  ~<_
21brrelexi 5040 . 2  |-  ( X  ~<_  om  ->  X  e.  _V )
3 elex 3122 . . 3  |-  ( ~P X  e.  2ndc  ->  ~P X  e.  _V )
4 pwexb 6595 . . 3  |-  ( X  e.  _V  <->  ~P X  e.  _V )
53, 4sylibr 212 . 2  |-  ( ~P X  e.  2ndc  ->  X  e.  _V )
6 elex 3122 . . . . 5  |-  ( X  e.  _V  ->  X  e.  _V )
7 snex 4688 . . . . . . . 8  |-  { x }  e.  _V
87a1ii 27 . . . . . . 7  |-  ( X  e.  _V  ->  (
x  e.  X  ->  { x }  e.  _V ) )
9 vex 3116 . . . . . . . . . 10  |-  x  e. 
_V
109sneqr 4194 . . . . . . . . 9  |-  ( { x }  =  {
y }  ->  x  =  y )
11 sneq 4037 . . . . . . . . 9  |-  ( x  =  y  ->  { x }  =  { y } )
1210, 11impbii 188 . . . . . . . 8  |-  ( { x }  =  {
y }  <->  x  =  y )
1312a1ii 27 . . . . . . 7  |-  ( X  e.  _V  ->  (
( x  e.  X  /\  y  e.  X
)  ->  ( {
x }  =  {
y }  <->  x  =  y ) ) )
148, 13dom2lem 7555 . . . . . 6  |-  ( X  e.  _V  ->  (
x  e.  X  |->  { x } ) : X -1-1-> _V )
15 f1f1orn 5827 . . . . . 6  |-  ( ( x  e.  X  |->  { x } ) : X -1-1-> _V  ->  ( x  e.  X  |->  { x } ) : X -1-1-onto-> ran  ( x  e.  X  |->  { x } ) )
1614, 15syl 16 . . . . 5  |-  ( X  e.  _V  ->  (
x  e.  X  |->  { x } ) : X -1-1-onto-> ran  ( x  e.  X  |->  { x }
) )
17 f1oeng 7534 . . . . 5  |-  ( ( X  e.  _V  /\  ( x  e.  X  |->  { x } ) : X -1-1-onto-> ran  ( x  e.  X  |->  { x }
) )  ->  X  ~~  ran  ( x  e.  X  |->  { x }
) )
186, 16, 17syl2anc 661 . . . 4  |-  ( X  e.  _V  ->  X  ~~  ran  ( x  e.  X  |->  { x }
) )
19 domen1 7659 . . . 4  |-  ( X 
~~  ran  ( x  e.  X  |->  { x } )  ->  ( X  ~<_  om  <->  ran  ( x  e.  X  |->  { x }
)  ~<_  om ) )
2018, 19syl 16 . . 3  |-  ( X  e.  _V  ->  ( X  ~<_  om  <->  ran  ( x  e.  X  |->  { x }
)  ~<_  om ) )
21 distop 19291 . . . . . . 7  |-  ( X  e.  _V  ->  ~P X  e.  Top )
22 simpr 461 . . . . . . . . . 10  |-  ( ( X  e.  _V  /\  x  e.  X )  ->  x  e.  X )
239snelpw 4693 . . . . . . . . . 10  |-  ( x  e.  X  <->  { x }  e.  ~P X
)
2422, 23sylib 196 . . . . . . . . 9  |-  ( ( X  e.  _V  /\  x  e.  X )  ->  { x }  e.  ~P X )
25 eqid 2467 . . . . . . . . 9  |-  ( x  e.  X  |->  { x } )  =  ( x  e.  X  |->  { x } )
2624, 25fmptd 6045 . . . . . . . 8  |-  ( X  e.  _V  ->  (
x  e.  X  |->  { x } ) : X --> ~P X )
27 frn 5737 . . . . . . . 8  |-  ( ( x  e.  X  |->  { x } ) : X --> ~P X  ->  ran  ( x  e.  X  |->  { x } ) 
C_  ~P X )
2826, 27syl 16 . . . . . . 7  |-  ( X  e.  _V  ->  ran  ( x  e.  X  |->  { x } ) 
C_  ~P X )
29 elpwi 4019 . . . . . . . . . . . . 13  |-  ( y  e.  ~P X  -> 
y  C_  X )
3029ad2antrl 727 . . . . . . . . . . . 12  |-  ( ( X  e.  _V  /\  ( y  e.  ~P X  /\  z  e.  y ) )  ->  y  C_  X )
31 simprr 756 . . . . . . . . . . . 12  |-  ( ( X  e.  _V  /\  ( y  e.  ~P X  /\  z  e.  y ) )  ->  z  e.  y )
3230, 31sseldd 3505 . . . . . . . . . . 11  |-  ( ( X  e.  _V  /\  ( y  e.  ~P X  /\  z  e.  y ) )  ->  z  e.  X )
33 eqidd 2468 . . . . . . . . . . 11  |-  ( ( X  e.  _V  /\  ( y  e.  ~P X  /\  z  e.  y ) )  ->  { z }  =  { z } )
34 sneq 4037 . . . . . . . . . . . . 13  |-  ( x  =  z  ->  { x }  =  { z } )
3534eqeq2d 2481 . . . . . . . . . . . 12  |-  ( x  =  z  ->  ( { z }  =  { x }  <->  { z }  =  { z } ) )
3635rspcev 3214 . . . . . . . . . . 11  |-  ( ( z  e.  X  /\  { z }  =  {
z } )  ->  E. x  e.  X  { z }  =  { x } )
3732, 33, 36syl2anc 661 . . . . . . . . . 10  |-  ( ( X  e.  _V  /\  ( y  e.  ~P X  /\  z  e.  y ) )  ->  E. x  e.  X  { z }  =  { x } )
38 snex 4688 . . . . . . . . . . 11  |-  { z }  e.  _V
3925elrnmpt 5249 . . . . . . . . . . 11  |-  ( { z }  e.  _V  ->  ( { z }  e.  ran  ( x  e.  X  |->  { x } )  <->  E. x  e.  X  { z }  =  { x } ) )
4038, 39ax-mp 5 . . . . . . . . . 10  |-  ( { z }  e.  ran  ( x  e.  X  |->  { x } )  <->  E. x  e.  X  { z }  =  { x } )
4137, 40sylibr 212 . . . . . . . . 9  |-  ( ( X  e.  _V  /\  ( y  e.  ~P X  /\  z  e.  y ) )  ->  { z }  e.  ran  (
x  e.  X  |->  { x } ) )
42 ssnid 4056 . . . . . . . . . 10  |-  z  e. 
{ z }
4342a1i 11 . . . . . . . . 9  |-  ( ( X  e.  _V  /\  ( y  e.  ~P X  /\  z  e.  y ) )  ->  z  e.  { z } )
4431snssd 4172 . . . . . . . . 9  |-  ( ( X  e.  _V  /\  ( y  e.  ~P X  /\  z  e.  y ) )  ->  { z }  C_  y )
45 eleq2 2540 . . . . . . . . . . 11  |-  ( w  =  { z }  ->  ( z  e.  w  <->  z  e.  {
z } ) )
46 sseq1 3525 . . . . . . . . . . 11  |-  ( w  =  { z }  ->  ( w  C_  y 
<->  { z }  C_  y ) )
4745, 46anbi12d 710 . . . . . . . . . 10  |-  ( w  =  { z }  ->  ( ( z  e.  w  /\  w  C_  y )  <->  ( z  e.  { z }  /\  { z }  C_  y
) ) )
4847rspcev 3214 . . . . . . . . 9  |-  ( ( { z }  e.  ran  ( x  e.  X  |->  { x } )  /\  ( z  e. 
{ z }  /\  { z }  C_  y
) )  ->  E. w  e.  ran  ( x  e.  X  |->  { x }
) ( z  e.  w  /\  w  C_  y ) )
4941, 43, 44, 48syl12anc 1226 . . . . . . . 8  |-  ( ( X  e.  _V  /\  ( y  e.  ~P X  /\  z  e.  y ) )  ->  E. w  e.  ran  ( x  e.  X  |->  { x }
) ( z  e.  w  /\  w  C_  y ) )
5049ralrimivva 2885 . . . . . . 7  |-  ( X  e.  _V  ->  A. y  e.  ~P  X A. z  e.  y  E. w  e.  ran  ( x  e.  X  |->  { x }
) ( z  e.  w  /\  w  C_  y ) )
51 basgen2 19285 . . . . . . 7  |-  ( ( ~P X  e.  Top  /\ 
ran  ( x  e.  X  |->  { x }
)  C_  ~P X  /\  A. y  e.  ~P  X A. z  e.  y  E. w  e.  ran  ( x  e.  X  |->  { x } ) ( z  e.  w  /\  w  C_  y ) )  ->  ( topGen ` 
ran  ( x  e.  X  |->  { x }
) )  =  ~P X )
5221, 28, 50, 51syl3anc 1228 . . . . . 6  |-  ( X  e.  _V  ->  ( topGen `
 ran  ( x  e.  X  |->  { x } ) )  =  ~P X )
5352adantr 465 . . . . 5  |-  ( ( X  e.  _V  /\  ran  ( x  e.  X  |->  { x } )  ~<_  om )  ->  ( topGen `
 ran  ( x  e.  X  |->  { x } ) )  =  ~P X )
5452, 21eqeltrd 2555 . . . . . . 7  |-  ( X  e.  _V  ->  ( topGen `
 ran  ( x  e.  X  |->  { x } ) )  e. 
Top )
55 tgclb 19266 . . . . . . 7  |-  ( ran  ( x  e.  X  |->  { x } )  e.  TopBases 
<->  ( topGen `  ran  ( x  e.  X  |->  { x } ) )  e. 
Top )
5654, 55sylibr 212 . . . . . 6  |-  ( X  e.  _V  ->  ran  ( x  e.  X  |->  { x } )  e.  TopBases )
57 2ndci 19743 . . . . . 6  |-  ( ( ran  ( x  e.  X  |->  { x }
)  e.  TopBases  /\  ran  ( x  e.  X  |->  { x } )  ~<_  om )  ->  ( topGen `
 ran  ( x  e.  X  |->  { x } ) )  e. 
2ndc )
5856, 57sylan 471 . . . . 5  |-  ( ( X  e.  _V  /\  ran  ( x  e.  X  |->  { x } )  ~<_  om )  ->  ( topGen `
 ran  ( x  e.  X  |->  { x } ) )  e. 
2ndc )
5953, 58eqeltrrd 2556 . . . 4  |-  ( ( X  e.  _V  /\  ran  ( x  e.  X  |->  { x } )  ~<_  om )  ->  ~P X  e.  2ndc )
60 is2ndc 19741 . . . . . 6  |-  ( ~P X  e.  2ndc  <->  E. b  e. 
TopBases  ( b  ~<_  om  /\  ( topGen `  b )  =  ~P X ) )
61 vex 3116 . . . . . . . . . 10  |-  b  e. 
_V
62 simpr 461 . . . . . . . . . . . . . . . 16  |-  ( ( ( ( X  e. 
_V  /\  b  e.  TopBases )  /\  ( b  ~<_  om 
/\  ( topGen `  b
)  =  ~P X
) )  /\  x  e.  X )  ->  x  e.  X )
6362, 23sylib 196 . . . . . . . . . . . . . . 15  |-  ( ( ( ( X  e. 
_V  /\  b  e.  TopBases )  /\  ( b  ~<_  om 
/\  ( topGen `  b
)  =  ~P X
) )  /\  x  e.  X )  ->  { x }  e.  ~P X
)
64 simplrr 760 . . . . . . . . . . . . . . 15  |-  ( ( ( ( X  e. 
_V  /\  b  e.  TopBases )  /\  ( b  ~<_  om 
/\  ( topGen `  b
)  =  ~P X
) )  /\  x  e.  X )  ->  ( topGen `
 b )  =  ~P X )
6563, 64eleqtrrd 2558 . . . . . . . . . . . . . 14  |-  ( ( ( ( X  e. 
_V  /\  b  e.  TopBases )  /\  ( b  ~<_  om 
/\  ( topGen `  b
)  =  ~P X
) )  /\  x  e.  X )  ->  { x }  e.  ( topGen `  b ) )
66 ssnid 4056 . . . . . . . . . . . . . 14  |-  x  e. 
{ x }
67 tg2 19261 . . . . . . . . . . . . . 14  |-  ( ( { x }  e.  ( topGen `  b )  /\  x  e.  { x } )  ->  E. y  e.  b  ( x  e.  y  /\  y  C_ 
{ x } ) )
6865, 66, 67sylancl 662 . . . . . . . . . . . . 13  |-  ( ( ( ( X  e. 
_V  /\  b  e.  TopBases )  /\  ( b  ~<_  om 
/\  ( topGen `  b
)  =  ~P X
) )  /\  x  e.  X )  ->  E. y  e.  b  ( x  e.  y  /\  y  C_ 
{ x } ) )
69 simprrl 763 . . . . . . . . . . . . . . . 16  |-  ( ( ( ( ( X  e.  _V  /\  b  e. 
TopBases )  /\  ( b  ~<_  om  /\  ( topGen `  b )  =  ~P X ) )  /\  x  e.  X )  /\  ( y  e.  b  /\  ( x  e.  y  /\  y  C_  { x } ) ) )  ->  x  e.  y )
7069snssd 4172 . . . . . . . . . . . . . . 15  |-  ( ( ( ( ( X  e.  _V  /\  b  e. 
TopBases )  /\  ( b  ~<_  om  /\  ( topGen `  b )  =  ~P X ) )  /\  x  e.  X )  /\  ( y  e.  b  /\  ( x  e.  y  /\  y  C_  { x } ) ) )  ->  { x }  C_  y )
71 simprrr 764 . . . . . . . . . . . . . . 15  |-  ( ( ( ( ( X  e.  _V  /\  b  e. 
TopBases )  /\  ( b  ~<_  om  /\  ( topGen `  b )  =  ~P X ) )  /\  x  e.  X )  /\  ( y  e.  b  /\  ( x  e.  y  /\  y  C_  { x } ) ) )  ->  y  C_  { x } )
7270, 71eqssd 3521 . . . . . . . . . . . . . 14  |-  ( ( ( ( ( X  e.  _V  /\  b  e. 
TopBases )  /\  ( b  ~<_  om  /\  ( topGen `  b )  =  ~P X ) )  /\  x  e.  X )  /\  ( y  e.  b  /\  ( x  e.  y  /\  y  C_  { x } ) ) )  ->  { x }  =  y )
73 simprl 755 . . . . . . . . . . . . . 14  |-  ( ( ( ( ( X  e.  _V  /\  b  e. 
TopBases )  /\  ( b  ~<_  om  /\  ( topGen `  b )  =  ~P X ) )  /\  x  e.  X )  /\  ( y  e.  b  /\  ( x  e.  y  /\  y  C_  { x } ) ) )  ->  y  e.  b )
7472, 73eqeltrd 2555 . . . . . . . . . . . . 13  |-  ( ( ( ( ( X  e.  _V  /\  b  e. 
TopBases )  /\  ( b  ~<_  om  /\  ( topGen `  b )  =  ~P X ) )  /\  x  e.  X )  /\  ( y  e.  b  /\  ( x  e.  y  /\  y  C_  { x } ) ) )  ->  { x }  e.  b )
7568, 74rexlimddv 2959 . . . . . . . . . . . 12  |-  ( ( ( ( X  e. 
_V  /\  b  e.  TopBases )  /\  ( b  ~<_  om 
/\  ( topGen `  b
)  =  ~P X
) )  /\  x  e.  X )  ->  { x }  e.  b )
7675, 25fmptd 6045 . . . . . . . . . . 11  |-  ( ( ( X  e.  _V  /\  b  e.  TopBases )  /\  ( b  ~<_  om  /\  ( topGen `  b )  =  ~P X ) )  ->  ( x  e.  X  |->  { x }
) : X --> b )
77 frn 5737 . . . . . . . . . . 11  |-  ( ( x  e.  X  |->  { x } ) : X --> b  ->  ran  ( x  e.  X  |->  { x } ) 
C_  b )
7876, 77syl 16 . . . . . . . . . 10  |-  ( ( ( X  e.  _V  /\  b  e.  TopBases )  /\  ( b  ~<_  om  /\  ( topGen `  b )  =  ~P X ) )  ->  ran  ( x  e.  X  |->  { x } )  C_  b
)
79 ssdomg 7561 . . . . . . . . . 10  |-  ( b  e.  _V  ->  ( ran  ( x  e.  X  |->  { x } ) 
C_  b  ->  ran  ( x  e.  X  |->  { x } )  ~<_  b ) )
8061, 78, 79mpsyl 63 . . . . . . . . 9  |-  ( ( ( X  e.  _V  /\  b  e.  TopBases )  /\  ( b  ~<_  om  /\  ( topGen `  b )  =  ~P X ) )  ->  ran  ( x  e.  X  |->  { x } )  ~<_  b )
81 simprl 755 . . . . . . . . 9  |-  ( ( ( X  e.  _V  /\  b  e.  TopBases )  /\  ( b  ~<_  om  /\  ( topGen `  b )  =  ~P X ) )  ->  b  ~<_  om )
82 domtr 7568 . . . . . . . . 9  |-  ( ( ran  ( x  e.  X  |->  { x }
)  ~<_  b  /\  b  ~<_  om )  ->  ran  (
x  e.  X  |->  { x } )  ~<_  om )
8380, 81, 82syl2anc 661 . . . . . . . 8  |-  ( ( ( X  e.  _V  /\  b  e.  TopBases )  /\  ( b  ~<_  om  /\  ( topGen `  b )  =  ~P X ) )  ->  ran  ( x  e.  X  |->  { x } )  ~<_  om )
8483ex 434 . . . . . . 7  |-  ( ( X  e.  _V  /\  b  e.  TopBases )  ->  (
( b  ~<_  om  /\  ( topGen `  b )  =  ~P X )  ->  ran  ( x  e.  X  |->  { x } )  ~<_  om ) )
8584rexlimdva 2955 . . . . . 6  |-  ( X  e.  _V  ->  ( E. b  e.  TopBases  ( b  ~<_  om  /\  ( topGen `  b )  =  ~P X )  ->  ran  ( x  e.  X  |->  { x } )  ~<_  om ) )
8660, 85syl5bi 217 . . . . 5  |-  ( X  e.  _V  ->  ( ~P X  e.  2ndc  ->  ran  ( x  e.  X  |->  { x } )  ~<_  om ) )
8786imp 429 . . . 4  |-  ( ( X  e.  _V  /\  ~P X  e.  2ndc )  ->  ran  ( x  e.  X  |->  { x } )  ~<_  om )
8859, 87impbida 830 . . 3  |-  ( X  e.  _V  ->  ( ran  ( x  e.  X  |->  { x } )  ~<_  om  <->  ~P X  e.  2ndc ) )
8920, 88bitrd 253 . 2  |-  ( X  e.  _V  ->  ( X  ~<_  om  <->  ~P X  e.  2ndc ) )
902, 5, 89pm5.21nii 353 1  |-  ( X  ~<_  om  <->  ~P X  e.  2ndc )
Colors of variables: wff setvar class
Syntax hints:    <-> wb 184    /\ wa 369    = wceq 1379    e. wcel 1767   A.wral 2814   E.wrex 2815   _Vcvv 3113    C_ wss 3476   ~Pcpw 4010   {csn 4027   class class class wbr 4447    |-> cmpt 4505   ran crn 5000   -->wf 5584   -1-1->wf1 5585   -1-1-onto->wf1o 5587   ` cfv 5588   omcom 6684    ~~ cen 7513    ~<_ cdom 7514   topGenctg 14693   Topctop 19189   TopBasesctb 19193   2ndcc2ndc 19733
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-3 8  ax-gen 1601  ax-4 1612  ax-5 1680  ax-6 1719  ax-7 1739  ax-8 1769  ax-9 1771  ax-10 1786  ax-11 1791  ax-12 1803  ax-13 1968  ax-ext 2445  ax-rep 4558  ax-sep 4568  ax-nul 4576  ax-pow 4625  ax-pr 4686  ax-un 6576
This theorem depends on definitions:  df-bi 185  df-or 370  df-an 371  df-3an 975  df-tru 1382  df-ex 1597  df-nf 1600  df-sb 1712  df-eu 2279  df-mo 2280  df-clab 2453  df-cleq 2459  df-clel 2462  df-nfc 2617  df-ne 2664  df-ral 2819  df-rex 2820  df-reu 2821  df-rab 2823  df-v 3115  df-sbc 3332  df-csb 3436  df-dif 3479  df-un 3481  df-in 3483  df-ss 3490  df-nul 3786  df-if 3940  df-pw 4012  df-sn 4028  df-pr 4030  df-op 4034  df-uni 4246  df-iun 4327  df-br 4448  df-opab 4506  df-mpt 4507  df-id 4795  df-xp 5005  df-rel 5006  df-cnv 5007  df-co 5008  df-dm 5009  df-rn 5010  df-res 5011  df-ima 5012  df-iota 5551  df-fun 5590  df-fn 5591  df-f 5592  df-f1 5593  df-fo 5594  df-f1o 5595  df-fv 5596  df-er 7311  df-en 7517  df-dom 7518  df-topgen 14699  df-top 19194  df-bases 19196  df-2ndc 19735
This theorem is referenced by: (None)
  Copyright terms: Public domain W3C validator