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

Theorem dis2ndc 19062
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 7314 . . 3  |-  Rel  ~<_
21brrelexi 4877 . 2  |-  ( X  ~<_  om  ->  X  e.  _V )
3 elex 2979 . . 3  |-  ( ~P X  e.  2ndc  ->  ~P X  e.  _V )
4 pwexb 6385 . . 3  |-  ( X  e.  _V  <->  ~P X  e.  _V )
53, 4sylibr 212 . 2  |-  ( ~P X  e.  2ndc  ->  X  e.  _V )
6 elex 2979 . . . . 5  |-  ( X  e.  _V  ->  X  e.  _V )
7 snex 4531 . . . . . . . 8  |-  { x }  e.  _V
87a1ii 27 . . . . . . 7  |-  ( X  e.  _V  ->  (
x  e.  X  ->  { x }  e.  _V ) )
9 vex 2973 . . . . . . . . . 10  |-  x  e. 
_V
109sneqr 4038 . . . . . . . . 9  |-  ( { x }  =  {
y }  ->  x  =  y )
11 sneq 3885 . . . . . . . . 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 7347 . . . . . 6  |-  ( X  e.  _V  ->  (
x  e.  X  |->  { x } ) : X -1-1-> _V )
15 f1f1orn 5650 . . . . . 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 7326 . . . . 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 7451 . . . 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 18598 . . . . . . 7  |-  ( X  e.  _V  ->  ~P X  e.  Top )
22 simpr 461 . . . . . . . . . 10  |-  ( ( X  e.  _V  /\  x  e.  X )  ->  x  e.  X )
239snelpw 4536 . . . . . . . . . 10  |-  ( x  e.  X  <->  { x }  e.  ~P X
)
2422, 23sylib 196 . . . . . . . . 9  |-  ( ( X  e.  _V  /\  x  e.  X )  ->  { x }  e.  ~P X )
25 eqid 2441 . . . . . . . . 9  |-  ( x  e.  X  |->  { x } )  =  ( x  e.  X  |->  { x } )
2624, 25fmptd 5865 . . . . . . . 8  |-  ( X  e.  _V  ->  (
x  e.  X  |->  { x } ) : X --> ~P X )
27 frn 5563 . . . . . . . 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 3867 . . . . . . . . . . . . 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 3355 . . . . . . . . . . 11  |-  ( ( X  e.  _V  /\  ( y  e.  ~P X  /\  z  e.  y ) )  ->  z  e.  X )
33 eqidd 2442 . . . . . . . . . . 11  |-  ( ( X  e.  _V  /\  ( y  e.  ~P X  /\  z  e.  y ) )  ->  { z }  =  { z } )
34 sneq 3885 . . . . . . . . . . . . 13  |-  ( x  =  z  ->  { x }  =  { z } )
3534eqeq2d 2452 . . . . . . . . . . . 12  |-  ( x  =  z  ->  ( { z }  =  { x }  <->  { z }  =  { z } ) )
3635rspcev 3071 . . . . . . . . . . 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 4531 . . . . . . . . . . 11  |-  { z }  e.  _V
3925elrnmpt 5084 . . . . . . . . . . 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 3904 . . . . . . . . . 10  |-  z  e. 
{ z }
4342a1i 11 . . . . . . . . 9  |-  ( ( X  e.  _V  /\  ( y  e.  ~P X  /\  z  e.  y ) )  ->  z  e.  { z } )
4431snssd 4016 . . . . . . . . 9  |-  ( ( X  e.  _V  /\  ( y  e.  ~P X  /\  z  e.  y ) )  ->  { z }  C_  y )
45 eleq2 2502 . . . . . . . . . . 11  |-  ( w  =  { z }  ->  ( z  e.  w  <->  z  e.  {
z } ) )
46 sseq1 3375 . . . . . . . . . . 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 3071 . . . . . . . . 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 1216 . . . . . . . 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 2806 . . . . . . 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 18592 . . . . . . 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 1218 . . . . . 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 2515 . . . . . . 7  |-  ( X  e.  _V  ->  ( topGen `
 ran  ( x  e.  X  |->  { x } ) )  e. 
Top )
55 tgclb 18573 . . . . . . 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 19050 . . . . . 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 2516 . . . 4  |-  ( ( X  e.  _V  /\  ran  ( x  e.  X  |->  { x } )  ~<_  om )  ->  ~P X  e.  2ndc )
60 is2ndc 19048 . . . . . 6  |-  ( ~P X  e.  2ndc  <->  E. b  e. 
TopBases  ( b  ~<_  om  /\  ( topGen `  b )  =  ~P X ) )
61 vex 2973 . . . . . . . . . 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 2518 . . . . . . . . . . . . . 14  |-  ( ( ( ( X  e. 
_V  /\  b  e.  TopBases )  /\  ( b  ~<_  om 
/\  ( topGen `  b
)  =  ~P X
) )  /\  x  e.  X )  ->  { x }  e.  ( topGen `  b ) )
66 ssnid 3904 . . . . . . . . . . . . . 14  |-  x  e. 
{ x }
67 tg2 18568 . . . . . . . . . . . . . 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 4016 . . . . . . . . . . . . . . 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 3371 . . . . . . . . . . . . . 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 2515 . . . . . . . . . . . . 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 2843 . . . . . . . . . . . 12  |-  ( ( ( ( X  e. 
_V  /\  b  e.  TopBases )  /\  ( b  ~<_  om 
/\  ( topGen `  b
)  =  ~P X
) )  /\  x  e.  X )  ->  { x }  e.  b )
7675, 25fmptd 5865 . . . . . . . . . . 11  |-  ( ( ( X  e.  _V  /\  b  e.  TopBases )  /\  ( b  ~<_  om  /\  ( topGen `  b )  =  ~P X ) )  ->  ( x  e.  X  |->  { x }
) : X --> b )
77 frn 5563 . . . . . . . . . . 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 7353 . . . . . . . . . 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 7360 . . . . . . . . 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 2839 . . . . . 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 828 . . 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 1369    e. wcel 1756   A.wral 2713   E.wrex 2714   _Vcvv 2970    C_ wss 3326   ~Pcpw 3858   {csn 3875   class class class wbr 4290    e. cmpt 4348   ran crn 4839   -->wf 5412   -1-1->wf1 5413   -1-1-onto->wf1o 5415   ` cfv 5416   omcom 6474    ~~ cen 7305    ~<_ cdom 7306   topGenctg 14374   Topctop 18496   TopBasesctb 18500   2ndcc2ndc 19040
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-3 8  ax-gen 1591  ax-4 1602  ax-5 1670  ax-6 1708  ax-7 1728  ax-8 1758  ax-9 1760  ax-10 1775  ax-11 1780  ax-12 1792  ax-13 1943  ax-ext 2422  ax-rep 4401  ax-sep 4411  ax-nul 4419  ax-pow 4468  ax-pr 4529  ax-un 6370
This theorem depends on definitions:  df-bi 185  df-or 370  df-an 371  df-3an 967  df-tru 1372  df-ex 1587  df-nf 1590  df-sb 1701  df-eu 2257  df-mo 2258  df-clab 2428  df-cleq 2434  df-clel 2437  df-nfc 2566  df-ne 2606  df-ral 2718  df-rex 2719  df-reu 2720  df-rab 2722  df-v 2972  df-sbc 3185  df-csb 3287  df-dif 3329  df-un 3331  df-in 3333  df-ss 3340  df-nul 3636  df-if 3790  df-pw 3860  df-sn 3876  df-pr 3878  df-op 3882  df-uni 4090  df-iun 4171  df-br 4291  df-opab 4349  df-mpt 4350  df-id 4634  df-xp 4844  df-rel 4845  df-cnv 4846  df-co 4847  df-dm 4848  df-rn 4849  df-res 4850  df-ima 4851  df-iota 5379  df-fun 5418  df-fn 5419  df-f 5420  df-f1 5421  df-fo 5422  df-f1o 5423  df-fv 5424  df-er 7099  df-en 7309  df-dom 7310  df-topgen 14380  df-top 18501  df-bases 18503  df-2ndc 19042
This theorem is referenced by: (None)
  Copyright terms: Public domain W3C validator