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

Theorem phplem4 7699
Description: Lemma for Pigeonhole Principle. Equinumerosity of successors implies equinumerosity of the original natural numbers. (Contributed by NM, 28-May-1998.) (Revised by Mario Carneiro, 24-Jun-2015.)
Hypotheses
Ref Expression
phplem2.1  |-  A  e. 
_V
phplem2.2  |-  B  e. 
_V
Assertion
Ref Expression
phplem4  |-  ( ( A  e.  om  /\  B  e.  om )  ->  ( suc  A  ~~  suc  B  ->  A  ~~  B ) )

Proof of Theorem phplem4
Dummy variable  f is distinct from all other variables.
StepHypRef Expression
1 bren 7525 . 2  |-  ( suc 
A  ~~  suc  B  <->  E. f 
f : suc  A -1-1-onto-> suc  B )
2 f1of1 5814 . . . . . . . . . 10  |-  ( f : suc  A -1-1-onto-> suc  B  ->  f : suc  A -1-1-> suc 
B )
32adantl 466 . . . . . . . . 9  |-  ( ( A  e.  om  /\  f : suc  A -1-1-onto-> suc  B
)  ->  f : suc  A -1-1-> suc  B )
4 phplem2.2 . . . . . . . . . 10  |-  B  e. 
_V
54sucex 6625 . . . . . . . . 9  |-  suc  B  e.  _V
6 sssucid 4955 . . . . . . . . . 10  |-  A  C_  suc  A
7 phplem2.1 . . . . . . . . . 10  |-  A  e. 
_V
8 f1imaen2g 7576 . . . . . . . . . 10  |-  ( ( ( f : suc  A
-1-1-> suc  B  /\  suc  B  e.  _V )  /\  ( A  C_  suc  A  /\  A  e.  _V ) )  ->  (
f " A ) 
~~  A )
96, 7, 8mpanr12 685 . . . . . . . . 9  |-  ( ( f : suc  A -1-1-> suc 
B  /\  suc  B  e. 
_V )  ->  (
f " A ) 
~~  A )
103, 5, 9sylancl 662 . . . . . . . 8  |-  ( ( A  e.  om  /\  f : suc  A -1-1-onto-> suc  B
)  ->  ( f " A )  ~~  A
)
1110ensymd 7566 . . . . . . 7  |-  ( ( A  e.  om  /\  f : suc  A -1-1-onto-> suc  B
)  ->  A  ~~  ( f " A
) )
12 nnord 6687 . . . . . . . . . 10  |-  ( A  e.  om  ->  Ord  A )
13 orddif 4971 . . . . . . . . . 10  |-  ( Ord 
A  ->  A  =  ( suc  A  \  { A } ) )
1412, 13syl 16 . . . . . . . . 9  |-  ( A  e.  om  ->  A  =  ( suc  A  \  { A } ) )
1514imaeq2d 5336 . . . . . . . 8  |-  ( A  e.  om  ->  (
f " A )  =  ( f "
( suc  A  \  { A } ) ) )
16 f1ofn 5816 . . . . . . . . . . 11  |-  ( f : suc  A -1-1-onto-> suc  B  ->  f  Fn  suc  A
)
177sucid 4957 . . . . . . . . . . 11  |-  A  e. 
suc  A
18 fnsnfv 5926 . . . . . . . . . . 11  |-  ( ( f  Fn  suc  A  /\  A  e.  suc  A )  ->  { (
f `  A ) }  =  ( f " { A } ) )
1916, 17, 18sylancl 662 . . . . . . . . . 10  |-  ( f : suc  A -1-1-onto-> suc  B  ->  { ( f `  A ) }  =  ( f " { A } ) )
2019difeq2d 3622 . . . . . . . . 9  |-  ( f : suc  A -1-1-onto-> suc  B  ->  ( ( f " suc  A )  \  {
( f `  A
) } )  =  ( ( f " suc  A )  \  (
f " { A } ) ) )
21 imadmrn 5346 . . . . . . . . . . . 12  |-  ( f
" dom  f )  =  ran  f
2221eqcomi 2480 . . . . . . . . . . 11  |-  ran  f  =  ( f " dom  f )
23 f1ofo 5822 . . . . . . . . . . . 12  |-  ( f : suc  A -1-1-onto-> suc  B  ->  f : suc  A -onto-> suc  B )
24 forn 5797 . . . . . . . . . . . 12  |-  ( f : suc  A -onto-> suc  B  ->  ran  f  =  suc  B )
2523, 24syl 16 . . . . . . . . . . 11  |-  ( f : suc  A -1-1-onto-> suc  B  ->  ran  f  =  suc  B )
26 f1odm 5819 . . . . . . . . . . . 12  |-  ( f : suc  A -1-1-onto-> suc  B  ->  dom  f  =  suc  A )
2726imaeq2d 5336 . . . . . . . . . . 11  |-  ( f : suc  A -1-1-onto-> suc  B  ->  ( f " dom  f )  =  ( f " suc  A
) )
2822, 25, 273eqtr3a 2532 . . . . . . . . . 10  |-  ( f : suc  A -1-1-onto-> suc  B  ->  suc  B  =  ( f " suc  A
) )
2928difeq1d 3621 . . . . . . . . 9  |-  ( f : suc  A -1-1-onto-> suc  B  ->  ( suc  B  \  { ( f `  A ) } )  =  ( ( f
" suc  A )  \  { ( f `  A ) } ) )
30 dff1o3 5821 . . . . . . . . . . 11  |-  ( f : suc  A -1-1-onto-> suc  B  <->  ( f : suc  A -onto-> suc  B  /\  Fun  `' f ) )
3130simprbi 464 . . . . . . . . . 10  |-  ( f : suc  A -1-1-onto-> suc  B  ->  Fun  `' f )
32 imadif 5662 . . . . . . . . . 10  |-  ( Fun  `' f  ->  ( f
" ( suc  A  \  { A } ) )  =  ( ( f " suc  A
)  \  ( f " { A } ) ) )
3331, 32syl 16 . . . . . . . . 9  |-  ( f : suc  A -1-1-onto-> suc  B  ->  ( f " ( suc  A  \  { A } ) )  =  ( ( f " suc  A )  \  (
f " { A } ) ) )
3420, 29, 333eqtr4rd 2519 . . . . . . . 8  |-  ( f : suc  A -1-1-onto-> suc  B  ->  ( f " ( suc  A  \  { A } ) )  =  ( suc  B  \  { ( f `  A ) } ) )
3515, 34sylan9eq 2528 . . . . . . 7  |-  ( ( A  e.  om  /\  f : suc  A -1-1-onto-> suc  B
)  ->  ( f " A )  =  ( suc  B  \  {
( f `  A
) } ) )
3611, 35breqtrd 4471 . . . . . 6  |-  ( ( A  e.  om  /\  f : suc  A -1-1-onto-> suc  B
)  ->  A  ~~  ( suc  B  \  {
( f `  A
) } ) )
37 fnfvelrn 6017 . . . . . . . . . 10  |-  ( ( f  Fn  suc  A  /\  A  e.  suc  A )  ->  ( f `  A )  e.  ran  f )
3816, 17, 37sylancl 662 . . . . . . . . 9  |-  ( f : suc  A -1-1-onto-> suc  B  ->  ( f `  A
)  e.  ran  f
)
3924eleq2d 2537 . . . . . . . . . 10  |-  ( f : suc  A -onto-> suc  B  ->  ( ( f `
 A )  e. 
ran  f  <->  ( f `  A )  e.  suc  B ) )
4023, 39syl 16 . . . . . . . . 9  |-  ( f : suc  A -1-1-onto-> suc  B  ->  ( ( f `  A )  e.  ran  f 
<->  ( f `  A
)  e.  suc  B
) )
4138, 40mpbid 210 . . . . . . . 8  |-  ( f : suc  A -1-1-onto-> suc  B  ->  ( f `  A
)  e.  suc  B
)
42 fvex 5875 . . . . . . . . 9  |-  ( f `
 A )  e. 
_V
434, 42phplem3 7698 . . . . . . . 8  |-  ( ( B  e.  om  /\  ( f `  A
)  e.  suc  B
)  ->  B  ~~  ( suc  B  \  {
( f `  A
) } ) )
4441, 43sylan2 474 . . . . . . 7  |-  ( ( B  e.  om  /\  f : suc  A -1-1-onto-> suc  B
)  ->  B  ~~  ( suc  B  \  {
( f `  A
) } ) )
4544ensymd 7566 . . . . . 6  |-  ( ( B  e.  om  /\  f : suc  A -1-1-onto-> suc  B
)  ->  ( suc  B 
\  { ( f `
 A ) } )  ~~  B )
46 entr 7567 . . . . . 6  |-  ( ( A  ~~  ( suc 
B  \  { (
f `  A ) } )  /\  ( suc  B  \  { ( f `  A ) } )  ~~  B
)  ->  A  ~~  B )
4736, 45, 46syl2an 477 . . . . 5  |-  ( ( ( A  e.  om  /\  f : suc  A -1-1-onto-> suc  B )  /\  ( B  e.  om  /\  f : suc  A -1-1-onto-> suc  B ) )  ->  A  ~~  B
)
4847anandirs 829 . . . 4  |-  ( ( ( A  e.  om  /\  B  e.  om )  /\  f : suc  A -1-1-onto-> suc  B )  ->  A  ~~  B )
4948ex 434 . . 3  |-  ( ( A  e.  om  /\  B  e.  om )  ->  ( f : suc  A -1-1-onto-> suc 
B  ->  A  ~~  B ) )
5049exlimdv 1700 . 2  |-  ( ( A  e.  om  /\  B  e.  om )  ->  ( E. f  f : suc  A -1-1-onto-> suc  B  ->  A  ~~  B ) )
511, 50syl5bi 217 1  |-  ( ( A  e.  om  /\  B  e.  om )  ->  ( suc  A  ~~  suc  B  ->  A  ~~  B ) )
Colors of variables: wff setvar class
Syntax hints:    -> wi 4    <-> wb 184    /\ wa 369    = wceq 1379   E.wex 1596    e. wcel 1767   _Vcvv 3113    \ cdif 3473    C_ wss 3476   {csn 4027   class class class wbr 4447   Ord word 4877   suc csuc 4880   `'ccnv 4998   dom cdm 4999   ran crn 5000   "cima 5002   Fun wfun 5581    Fn wfn 5582   -1-1->wf1 5584   -onto->wfo 5585   -1-1-onto->wf1o 5586   ` cfv 5587   omcom 6679    ~~ cen 7513
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-sep 4568  ax-nul 4576  ax-pow 4625  ax-pr 4686  ax-un 6575
This theorem depends on definitions:  df-bi 185  df-or 370  df-an 371  df-3or 974  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-rab 2823  df-v 3115  df-sbc 3332  df-dif 3479  df-un 3481  df-in 3483  df-ss 3490  df-pss 3492  df-nul 3786  df-if 3940  df-pw 4012  df-sn 4028  df-pr 4030  df-tp 4032  df-op 4034  df-uni 4246  df-br 4448  df-opab 4506  df-tr 4541  df-eprel 4791  df-id 4795  df-po 4800  df-so 4801  df-fr 4838  df-we 4840  df-ord 4881  df-on 4882  df-lim 4883  df-suc 4884  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 5550  df-fun 5589  df-fn 5590  df-f 5591  df-f1 5592  df-fo 5593  df-f1o 5594  df-fv 5595  df-om 6680  df-er 7311  df-en 7517
This theorem is referenced by:  nneneq  7700
  Copyright terms: Public domain W3C validator