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 |