| Step | Hyp | Ref | Expression | 
						
							| 1 |  | bitsf |  |-  bits : ZZ --> ~P NN0 | 
						
							| 2 |  | simpl |  |-  ( ( x e. ZZ /\ y e. ZZ ) -> x e. ZZ ) | 
						
							| 3 | 2 | zcnd |  |-  ( ( x e. ZZ /\ y e. ZZ ) -> x e. CC ) | 
						
							| 4 | 3 | adantr |  |-  ( ( ( x e. ZZ /\ y e. ZZ ) /\ ( -u x e. NN /\ ( bits ` x ) = ( bits ` y ) ) ) -> x e. CC ) | 
						
							| 5 |  | simpr |  |-  ( ( x e. ZZ /\ y e. ZZ ) -> y e. ZZ ) | 
						
							| 6 | 5 | zcnd |  |-  ( ( x e. ZZ /\ y e. ZZ ) -> y e. CC ) | 
						
							| 7 | 6 | adantr |  |-  ( ( ( x e. ZZ /\ y e. ZZ ) /\ ( -u x e. NN /\ ( bits ` x ) = ( bits ` y ) ) ) -> y e. CC ) | 
						
							| 8 | 4 | negcld |  |-  ( ( ( x e. ZZ /\ y e. ZZ ) /\ ( -u x e. NN /\ ( bits ` x ) = ( bits ` y ) ) ) -> -u x e. CC ) | 
						
							| 9 | 7 | negcld |  |-  ( ( ( x e. ZZ /\ y e. ZZ ) /\ ( -u x e. NN /\ ( bits ` x ) = ( bits ` y ) ) ) -> -u y e. CC ) | 
						
							| 10 |  | 1cnd |  |-  ( ( ( x e. ZZ /\ y e. ZZ ) /\ ( -u x e. NN /\ ( bits ` x ) = ( bits ` y ) ) ) -> 1 e. CC ) | 
						
							| 11 |  | simprr |  |-  ( ( ( x e. ZZ /\ y e. ZZ ) /\ ( -u x e. NN /\ ( bits ` x ) = ( bits ` y ) ) ) -> ( bits ` x ) = ( bits ` y ) ) | 
						
							| 12 | 11 | difeq2d |  |-  ( ( ( x e. ZZ /\ y e. ZZ ) /\ ( -u x e. NN /\ ( bits ` x ) = ( bits ` y ) ) ) -> ( NN0 \ ( bits ` x ) ) = ( NN0 \ ( bits ` y ) ) ) | 
						
							| 13 |  | bitscmp |  |-  ( x e. ZZ -> ( NN0 \ ( bits ` x ) ) = ( bits ` ( -u x - 1 ) ) ) | 
						
							| 14 | 13 | ad2antrr |  |-  ( ( ( x e. ZZ /\ y e. ZZ ) /\ ( -u x e. NN /\ ( bits ` x ) = ( bits ` y ) ) ) -> ( NN0 \ ( bits ` x ) ) = ( bits ` ( -u x - 1 ) ) ) | 
						
							| 15 |  | bitscmp |  |-  ( y e. ZZ -> ( NN0 \ ( bits ` y ) ) = ( bits ` ( -u y - 1 ) ) ) | 
						
							| 16 | 15 | ad2antlr |  |-  ( ( ( x e. ZZ /\ y e. ZZ ) /\ ( -u x e. NN /\ ( bits ` x ) = ( bits ` y ) ) ) -> ( NN0 \ ( bits ` y ) ) = ( bits ` ( -u y - 1 ) ) ) | 
						
							| 17 | 12 14 16 | 3eqtr3d |  |-  ( ( ( x e. ZZ /\ y e. ZZ ) /\ ( -u x e. NN /\ ( bits ` x ) = ( bits ` y ) ) ) -> ( bits ` ( -u x - 1 ) ) = ( bits ` ( -u y - 1 ) ) ) | 
						
							| 18 |  | nnm1nn0 |  |-  ( -u x e. NN -> ( -u x - 1 ) e. NN0 ) | 
						
							| 19 | 18 | ad2antrl |  |-  ( ( ( x e. ZZ /\ y e. ZZ ) /\ ( -u x e. NN /\ ( bits ` x ) = ( bits ` y ) ) ) -> ( -u x - 1 ) e. NN0 ) | 
						
							| 20 | 19 | fvresd |  |-  ( ( ( x e. ZZ /\ y e. ZZ ) /\ ( -u x e. NN /\ ( bits ` x ) = ( bits ` y ) ) ) -> ( ( bits |` NN0 ) ` ( -u x - 1 ) ) = ( bits ` ( -u x - 1 ) ) ) | 
						
							| 21 |  | ominf |  |-  -. _om e. Fin | 
						
							| 22 |  | nn0ennn |  |-  NN0 ~~ NN | 
						
							| 23 |  | nnenom |  |-  NN ~~ _om | 
						
							| 24 | 22 23 | entr2i |  |-  _om ~~ NN0 | 
						
							| 25 |  | enfii |  |-  ( ( NN0 e. Fin /\ _om ~~ NN0 ) -> _om e. Fin ) | 
						
							| 26 | 24 25 | mpan2 |  |-  ( NN0 e. Fin -> _om e. Fin ) | 
						
							| 27 | 21 26 | mto |  |-  -. NN0 e. Fin | 
						
							| 28 |  | difinf |  |-  ( ( -. NN0 e. Fin /\ ( bits ` x ) e. Fin ) -> -. ( NN0 \ ( bits ` x ) ) e. Fin ) | 
						
							| 29 | 27 28 | mpan |  |-  ( ( bits ` x ) e. Fin -> -. ( NN0 \ ( bits ` x ) ) e. Fin ) | 
						
							| 30 |  | bitsfi |  |-  ( ( -u x - 1 ) e. NN0 -> ( bits ` ( -u x - 1 ) ) e. Fin ) | 
						
							| 31 | 19 30 | syl |  |-  ( ( ( x e. ZZ /\ y e. ZZ ) /\ ( -u x e. NN /\ ( bits ` x ) = ( bits ` y ) ) ) -> ( bits ` ( -u x - 1 ) ) e. Fin ) | 
						
							| 32 | 14 31 | eqeltrd |  |-  ( ( ( x e. ZZ /\ y e. ZZ ) /\ ( -u x e. NN /\ ( bits ` x ) = ( bits ` y ) ) ) -> ( NN0 \ ( bits ` x ) ) e. Fin ) | 
						
							| 33 | 29 32 | nsyl3 |  |-  ( ( ( x e. ZZ /\ y e. ZZ ) /\ ( -u x e. NN /\ ( bits ` x ) = ( bits ` y ) ) ) -> -. ( bits ` x ) e. Fin ) | 
						
							| 34 | 11 33 | eqneltrrd |  |-  ( ( ( x e. ZZ /\ y e. ZZ ) /\ ( -u x e. NN /\ ( bits ` x ) = ( bits ` y ) ) ) -> -. ( bits ` y ) e. Fin ) | 
						
							| 35 |  | bitsfi |  |-  ( y e. NN0 -> ( bits ` y ) e. Fin ) | 
						
							| 36 | 34 35 | nsyl |  |-  ( ( ( x e. ZZ /\ y e. ZZ ) /\ ( -u x e. NN /\ ( bits ` x ) = ( bits ` y ) ) ) -> -. y e. NN0 ) | 
						
							| 37 | 5 | znegcld |  |-  ( ( x e. ZZ /\ y e. ZZ ) -> -u y e. ZZ ) | 
						
							| 38 |  | elznn |  |-  ( -u y e. ZZ <-> ( -u y e. RR /\ ( -u y e. NN \/ -u -u y e. NN0 ) ) ) | 
						
							| 39 | 38 | simprbi |  |-  ( -u y e. ZZ -> ( -u y e. NN \/ -u -u y e. NN0 ) ) | 
						
							| 40 | 37 39 | syl |  |-  ( ( x e. ZZ /\ y e. ZZ ) -> ( -u y e. NN \/ -u -u y e. NN0 ) ) | 
						
							| 41 | 6 | negnegd |  |-  ( ( x e. ZZ /\ y e. ZZ ) -> -u -u y = y ) | 
						
							| 42 | 41 | eleq1d |  |-  ( ( x e. ZZ /\ y e. ZZ ) -> ( -u -u y e. NN0 <-> y e. NN0 ) ) | 
						
							| 43 | 42 | orbi2d |  |-  ( ( x e. ZZ /\ y e. ZZ ) -> ( ( -u y e. NN \/ -u -u y e. NN0 ) <-> ( -u y e. NN \/ y e. NN0 ) ) ) | 
						
							| 44 | 40 43 | mpbid |  |-  ( ( x e. ZZ /\ y e. ZZ ) -> ( -u y e. NN \/ y e. NN0 ) ) | 
						
							| 45 | 44 | adantr |  |-  ( ( ( x e. ZZ /\ y e. ZZ ) /\ ( -u x e. NN /\ ( bits ` x ) = ( bits ` y ) ) ) -> ( -u y e. NN \/ y e. NN0 ) ) | 
						
							| 46 | 45 | ord |  |-  ( ( ( x e. ZZ /\ y e. ZZ ) /\ ( -u x e. NN /\ ( bits ` x ) = ( bits ` y ) ) ) -> ( -. -u y e. NN -> y e. NN0 ) ) | 
						
							| 47 | 36 46 | mt3d |  |-  ( ( ( x e. ZZ /\ y e. ZZ ) /\ ( -u x e. NN /\ ( bits ` x ) = ( bits ` y ) ) ) -> -u y e. NN ) | 
						
							| 48 |  | nnm1nn0 |  |-  ( -u y e. NN -> ( -u y - 1 ) e. NN0 ) | 
						
							| 49 | 47 48 | syl |  |-  ( ( ( x e. ZZ /\ y e. ZZ ) /\ ( -u x e. NN /\ ( bits ` x ) = ( bits ` y ) ) ) -> ( -u y - 1 ) e. NN0 ) | 
						
							| 50 | 49 | fvresd |  |-  ( ( ( x e. ZZ /\ y e. ZZ ) /\ ( -u x e. NN /\ ( bits ` x ) = ( bits ` y ) ) ) -> ( ( bits |` NN0 ) ` ( -u y - 1 ) ) = ( bits ` ( -u y - 1 ) ) ) | 
						
							| 51 | 17 20 50 | 3eqtr4d |  |-  ( ( ( x e. ZZ /\ y e. ZZ ) /\ ( -u x e. NN /\ ( bits ` x ) = ( bits ` y ) ) ) -> ( ( bits |` NN0 ) ` ( -u x - 1 ) ) = ( ( bits |` NN0 ) ` ( -u y - 1 ) ) ) | 
						
							| 52 |  | bitsf1o |  |-  ( bits |` NN0 ) : NN0 -1-1-onto-> ( ~P NN0 i^i Fin ) | 
						
							| 53 |  | f1of1 |  |-  ( ( bits |` NN0 ) : NN0 -1-1-onto-> ( ~P NN0 i^i Fin ) -> ( bits |` NN0 ) : NN0 -1-1-> ( ~P NN0 i^i Fin ) ) | 
						
							| 54 | 52 53 | ax-mp |  |-  ( bits |` NN0 ) : NN0 -1-1-> ( ~P NN0 i^i Fin ) | 
						
							| 55 |  | f1fveq |  |-  ( ( ( bits |` NN0 ) : NN0 -1-1-> ( ~P NN0 i^i Fin ) /\ ( ( -u x - 1 ) e. NN0 /\ ( -u y - 1 ) e. NN0 ) ) -> ( ( ( bits |` NN0 ) ` ( -u x - 1 ) ) = ( ( bits |` NN0 ) ` ( -u y - 1 ) ) <-> ( -u x - 1 ) = ( -u y - 1 ) ) ) | 
						
							| 56 | 54 55 | mpan |  |-  ( ( ( -u x - 1 ) e. NN0 /\ ( -u y - 1 ) e. NN0 ) -> ( ( ( bits |` NN0 ) ` ( -u x - 1 ) ) = ( ( bits |` NN0 ) ` ( -u y - 1 ) ) <-> ( -u x - 1 ) = ( -u y - 1 ) ) ) | 
						
							| 57 | 19 49 56 | syl2anc |  |-  ( ( ( x e. ZZ /\ y e. ZZ ) /\ ( -u x e. NN /\ ( bits ` x ) = ( bits ` y ) ) ) -> ( ( ( bits |` NN0 ) ` ( -u x - 1 ) ) = ( ( bits |` NN0 ) ` ( -u y - 1 ) ) <-> ( -u x - 1 ) = ( -u y - 1 ) ) ) | 
						
							| 58 | 51 57 | mpbid |  |-  ( ( ( x e. ZZ /\ y e. ZZ ) /\ ( -u x e. NN /\ ( bits ` x ) = ( bits ` y ) ) ) -> ( -u x - 1 ) = ( -u y - 1 ) ) | 
						
							| 59 | 8 9 10 58 | subcan2d |  |-  ( ( ( x e. ZZ /\ y e. ZZ ) /\ ( -u x e. NN /\ ( bits ` x ) = ( bits ` y ) ) ) -> -u x = -u y ) | 
						
							| 60 | 4 7 59 | neg11d |  |-  ( ( ( x e. ZZ /\ y e. ZZ ) /\ ( -u x e. NN /\ ( bits ` x ) = ( bits ` y ) ) ) -> x = y ) | 
						
							| 61 | 60 | expr |  |-  ( ( ( x e. ZZ /\ y e. ZZ ) /\ -u x e. NN ) -> ( ( bits ` x ) = ( bits ` y ) -> x = y ) ) | 
						
							| 62 | 3 | negnegd |  |-  ( ( x e. ZZ /\ y e. ZZ ) -> -u -u x = x ) | 
						
							| 63 | 62 | eleq1d |  |-  ( ( x e. ZZ /\ y e. ZZ ) -> ( -u -u x e. NN0 <-> x e. NN0 ) ) | 
						
							| 64 | 63 | biimpa |  |-  ( ( ( x e. ZZ /\ y e. ZZ ) /\ -u -u x e. NN0 ) -> x e. NN0 ) | 
						
							| 65 |  | simprr |  |-  ( ( ( x e. ZZ /\ y e. ZZ ) /\ ( x e. NN0 /\ ( bits ` x ) = ( bits ` y ) ) ) -> ( bits ` x ) = ( bits ` y ) ) | 
						
							| 66 |  | fvres |  |-  ( x e. NN0 -> ( ( bits |` NN0 ) ` x ) = ( bits ` x ) ) | 
						
							| 67 | 66 | ad2antrl |  |-  ( ( ( x e. ZZ /\ y e. ZZ ) /\ ( x e. NN0 /\ ( bits ` x ) = ( bits ` y ) ) ) -> ( ( bits |` NN0 ) ` x ) = ( bits ` x ) ) | 
						
							| 68 | 15 | ad2antlr |  |-  ( ( ( x e. ZZ /\ y e. ZZ ) /\ ( x e. NN0 /\ ( bits ` x ) = ( bits ` y ) ) ) -> ( NN0 \ ( bits ` y ) ) = ( bits ` ( -u y - 1 ) ) ) | 
						
							| 69 |  | bitsfi |  |-  ( x e. NN0 -> ( bits ` x ) e. Fin ) | 
						
							| 70 | 69 | ad2antrl |  |-  ( ( ( x e. ZZ /\ y e. ZZ ) /\ ( x e. NN0 /\ ( bits ` x ) = ( bits ` y ) ) ) -> ( bits ` x ) e. Fin ) | 
						
							| 71 | 65 70 | eqeltrrd |  |-  ( ( ( x e. ZZ /\ y e. ZZ ) /\ ( x e. NN0 /\ ( bits ` x ) = ( bits ` y ) ) ) -> ( bits ` y ) e. Fin ) | 
						
							| 72 |  | difinf |  |-  ( ( -. NN0 e. Fin /\ ( bits ` y ) e. Fin ) -> -. ( NN0 \ ( bits ` y ) ) e. Fin ) | 
						
							| 73 | 27 71 72 | sylancr |  |-  ( ( ( x e. ZZ /\ y e. ZZ ) /\ ( x e. NN0 /\ ( bits ` x ) = ( bits ` y ) ) ) -> -. ( NN0 \ ( bits ` y ) ) e. Fin ) | 
						
							| 74 | 68 73 | eqneltrrd |  |-  ( ( ( x e. ZZ /\ y e. ZZ ) /\ ( x e. NN0 /\ ( bits ` x ) = ( bits ` y ) ) ) -> -. ( bits ` ( -u y - 1 ) ) e. Fin ) | 
						
							| 75 |  | bitsfi |  |-  ( ( -u y - 1 ) e. NN0 -> ( bits ` ( -u y - 1 ) ) e. Fin ) | 
						
							| 76 | 74 75 | nsyl |  |-  ( ( ( x e. ZZ /\ y e. ZZ ) /\ ( x e. NN0 /\ ( bits ` x ) = ( bits ` y ) ) ) -> -. ( -u y - 1 ) e. NN0 ) | 
						
							| 77 | 76 48 | nsyl |  |-  ( ( ( x e. ZZ /\ y e. ZZ ) /\ ( x e. NN0 /\ ( bits ` x ) = ( bits ` y ) ) ) -> -. -u y e. NN ) | 
						
							| 78 | 44 | adantr |  |-  ( ( ( x e. ZZ /\ y e. ZZ ) /\ ( x e. NN0 /\ ( bits ` x ) = ( bits ` y ) ) ) -> ( -u y e. NN \/ y e. NN0 ) ) | 
						
							| 79 | 78 | ord |  |-  ( ( ( x e. ZZ /\ y e. ZZ ) /\ ( x e. NN0 /\ ( bits ` x ) = ( bits ` y ) ) ) -> ( -. -u y e. NN -> y e. NN0 ) ) | 
						
							| 80 | 77 79 | mpd |  |-  ( ( ( x e. ZZ /\ y e. ZZ ) /\ ( x e. NN0 /\ ( bits ` x ) = ( bits ` y ) ) ) -> y e. NN0 ) | 
						
							| 81 | 80 | fvresd |  |-  ( ( ( x e. ZZ /\ y e. ZZ ) /\ ( x e. NN0 /\ ( bits ` x ) = ( bits ` y ) ) ) -> ( ( bits |` NN0 ) ` y ) = ( bits ` y ) ) | 
						
							| 82 | 65 67 81 | 3eqtr4d |  |-  ( ( ( x e. ZZ /\ y e. ZZ ) /\ ( x e. NN0 /\ ( bits ` x ) = ( bits ` y ) ) ) -> ( ( bits |` NN0 ) ` x ) = ( ( bits |` NN0 ) ` y ) ) | 
						
							| 83 |  | simprl |  |-  ( ( ( x e. ZZ /\ y e. ZZ ) /\ ( x e. NN0 /\ ( bits ` x ) = ( bits ` y ) ) ) -> x e. NN0 ) | 
						
							| 84 |  | f1fveq |  |-  ( ( ( bits |` NN0 ) : NN0 -1-1-> ( ~P NN0 i^i Fin ) /\ ( x e. NN0 /\ y e. NN0 ) ) -> ( ( ( bits |` NN0 ) ` x ) = ( ( bits |` NN0 ) ` y ) <-> x = y ) ) | 
						
							| 85 | 54 84 | mpan |  |-  ( ( x e. NN0 /\ y e. NN0 ) -> ( ( ( bits |` NN0 ) ` x ) = ( ( bits |` NN0 ) ` y ) <-> x = y ) ) | 
						
							| 86 | 83 80 85 | syl2anc |  |-  ( ( ( x e. ZZ /\ y e. ZZ ) /\ ( x e. NN0 /\ ( bits ` x ) = ( bits ` y ) ) ) -> ( ( ( bits |` NN0 ) ` x ) = ( ( bits |` NN0 ) ` y ) <-> x = y ) ) | 
						
							| 87 | 82 86 | mpbid |  |-  ( ( ( x e. ZZ /\ y e. ZZ ) /\ ( x e. NN0 /\ ( bits ` x ) = ( bits ` y ) ) ) -> x = y ) | 
						
							| 88 | 87 | expr |  |-  ( ( ( x e. ZZ /\ y e. ZZ ) /\ x e. NN0 ) -> ( ( bits ` x ) = ( bits ` y ) -> x = y ) ) | 
						
							| 89 | 64 88 | syldan |  |-  ( ( ( x e. ZZ /\ y e. ZZ ) /\ -u -u x e. NN0 ) -> ( ( bits ` x ) = ( bits ` y ) -> x = y ) ) | 
						
							| 90 | 2 | znegcld |  |-  ( ( x e. ZZ /\ y e. ZZ ) -> -u x e. ZZ ) | 
						
							| 91 |  | elznn |  |-  ( -u x e. ZZ <-> ( -u x e. RR /\ ( -u x e. NN \/ -u -u x e. NN0 ) ) ) | 
						
							| 92 | 91 | simprbi |  |-  ( -u x e. ZZ -> ( -u x e. NN \/ -u -u x e. NN0 ) ) | 
						
							| 93 | 90 92 | syl |  |-  ( ( x e. ZZ /\ y e. ZZ ) -> ( -u x e. NN \/ -u -u x e. NN0 ) ) | 
						
							| 94 | 61 89 93 | mpjaodan |  |-  ( ( x e. ZZ /\ y e. ZZ ) -> ( ( bits ` x ) = ( bits ` y ) -> x = y ) ) | 
						
							| 95 | 94 | rgen2 |  |-  A. x e. ZZ A. y e. ZZ ( ( bits ` x ) = ( bits ` y ) -> x = y ) | 
						
							| 96 |  | dff13 |  |-  ( bits : ZZ -1-1-> ~P NN0 <-> ( bits : ZZ --> ~P NN0 /\ A. x e. ZZ A. y e. ZZ ( ( bits ` x ) = ( bits ` y ) -> x = y ) ) ) | 
						
							| 97 | 1 95 96 | mpbir2an |  |-  bits : ZZ -1-1-> ~P NN0 |