| Step |
Hyp |
Ref |
Expression |
| 1 |
|
oveq2 |
|- ( ( 2 ^ M ) = if ( M e. ( bits ` N ) , ( 2 ^ M ) , 0 ) -> ( ( N mod ( 2 ^ M ) ) + ( 2 ^ M ) ) = ( ( N mod ( 2 ^ M ) ) + if ( M e. ( bits ` N ) , ( 2 ^ M ) , 0 ) ) ) |
| 2 |
1
|
eqeq2d |
|- ( ( 2 ^ M ) = if ( M e. ( bits ` N ) , ( 2 ^ M ) , 0 ) -> ( ( N mod ( 2 ^ ( M + 1 ) ) ) = ( ( N mod ( 2 ^ M ) ) + ( 2 ^ M ) ) <-> ( N mod ( 2 ^ ( M + 1 ) ) ) = ( ( N mod ( 2 ^ M ) ) + if ( M e. ( bits ` N ) , ( 2 ^ M ) , 0 ) ) ) ) |
| 3 |
|
oveq2 |
|- ( 0 = if ( M e. ( bits ` N ) , ( 2 ^ M ) , 0 ) -> ( ( N mod ( 2 ^ M ) ) + 0 ) = ( ( N mod ( 2 ^ M ) ) + if ( M e. ( bits ` N ) , ( 2 ^ M ) , 0 ) ) ) |
| 4 |
3
|
eqeq2d |
|- ( 0 = if ( M e. ( bits ` N ) , ( 2 ^ M ) , 0 ) -> ( ( N mod ( 2 ^ ( M + 1 ) ) ) = ( ( N mod ( 2 ^ M ) ) + 0 ) <-> ( N mod ( 2 ^ ( M + 1 ) ) ) = ( ( N mod ( 2 ^ M ) ) + if ( M e. ( bits ` N ) , ( 2 ^ M ) , 0 ) ) ) ) |
| 5 |
|
simpl |
|- ( ( N e. ZZ /\ M e. NN0 ) -> N e. ZZ ) |
| 6 |
|
2nn |
|- 2 e. NN |
| 7 |
6
|
a1i |
|- ( ( N e. ZZ /\ M e. NN0 ) -> 2 e. NN ) |
| 8 |
|
simpr |
|- ( ( N e. ZZ /\ M e. NN0 ) -> M e. NN0 ) |
| 9 |
7 8
|
nnexpcld |
|- ( ( N e. ZZ /\ M e. NN0 ) -> ( 2 ^ M ) e. NN ) |
| 10 |
5 9
|
zmodcld |
|- ( ( N e. ZZ /\ M e. NN0 ) -> ( N mod ( 2 ^ M ) ) e. NN0 ) |
| 11 |
10
|
nn0cnd |
|- ( ( N e. ZZ /\ M e. NN0 ) -> ( N mod ( 2 ^ M ) ) e. CC ) |
| 12 |
11
|
adantr |
|- ( ( ( N e. ZZ /\ M e. NN0 ) /\ M e. ( bits ` N ) ) -> ( N mod ( 2 ^ M ) ) e. CC ) |
| 13 |
|
1nn0 |
|- 1 e. NN0 |
| 14 |
13
|
a1i |
|- ( ( N e. ZZ /\ M e. NN0 ) -> 1 e. NN0 ) |
| 15 |
8 14
|
nn0addcld |
|- ( ( N e. ZZ /\ M e. NN0 ) -> ( M + 1 ) e. NN0 ) |
| 16 |
7 15
|
nnexpcld |
|- ( ( N e. ZZ /\ M e. NN0 ) -> ( 2 ^ ( M + 1 ) ) e. NN ) |
| 17 |
5 16
|
zmodcld |
|- ( ( N e. ZZ /\ M e. NN0 ) -> ( N mod ( 2 ^ ( M + 1 ) ) ) e. NN0 ) |
| 18 |
17
|
nn0cnd |
|- ( ( N e. ZZ /\ M e. NN0 ) -> ( N mod ( 2 ^ ( M + 1 ) ) ) e. CC ) |
| 19 |
18
|
adantr |
|- ( ( ( N e. ZZ /\ M e. NN0 ) /\ M e. ( bits ` N ) ) -> ( N mod ( 2 ^ ( M + 1 ) ) ) e. CC ) |
| 20 |
12 19
|
pncan3d |
|- ( ( ( N e. ZZ /\ M e. NN0 ) /\ M e. ( bits ` N ) ) -> ( ( N mod ( 2 ^ M ) ) + ( ( N mod ( 2 ^ ( M + 1 ) ) ) - ( N mod ( 2 ^ M ) ) ) ) = ( N mod ( 2 ^ ( M + 1 ) ) ) ) |
| 21 |
18 11
|
subcld |
|- ( ( N e. ZZ /\ M e. NN0 ) -> ( ( N mod ( 2 ^ ( M + 1 ) ) ) - ( N mod ( 2 ^ M ) ) ) e. CC ) |
| 22 |
21
|
adantr |
|- ( ( ( N e. ZZ /\ M e. NN0 ) /\ M e. ( bits ` N ) ) -> ( ( N mod ( 2 ^ ( M + 1 ) ) ) - ( N mod ( 2 ^ M ) ) ) e. CC ) |
| 23 |
6
|
a1i |
|- ( ( ( N e. ZZ /\ M e. NN0 ) /\ M e. ( bits ` N ) ) -> 2 e. NN ) |
| 24 |
|
simplr |
|- ( ( ( N e. ZZ /\ M e. NN0 ) /\ M e. ( bits ` N ) ) -> M e. NN0 ) |
| 25 |
23 24
|
nnexpcld |
|- ( ( ( N e. ZZ /\ M e. NN0 ) /\ M e. ( bits ` N ) ) -> ( 2 ^ M ) e. NN ) |
| 26 |
25
|
nncnd |
|- ( ( ( N e. ZZ /\ M e. NN0 ) /\ M e. ( bits ` N ) ) -> ( 2 ^ M ) e. CC ) |
| 27 |
|
2cnd |
|- ( ( N e. ZZ /\ M e. NN0 ) -> 2 e. CC ) |
| 28 |
|
2ne0 |
|- 2 =/= 0 |
| 29 |
28
|
a1i |
|- ( ( N e. ZZ /\ M e. NN0 ) -> 2 =/= 0 ) |
| 30 |
8
|
nn0zd |
|- ( ( N e. ZZ /\ M e. NN0 ) -> M e. ZZ ) |
| 31 |
27 29 30
|
expne0d |
|- ( ( N e. ZZ /\ M e. NN0 ) -> ( 2 ^ M ) =/= 0 ) |
| 32 |
31
|
adantr |
|- ( ( ( N e. ZZ /\ M e. NN0 ) /\ M e. ( bits ` N ) ) -> ( 2 ^ M ) =/= 0 ) |
| 33 |
|
z0even |
|- 2 || 0 |
| 34 |
|
id |
|- ( ( ( ( N mod ( 2 ^ ( M + 1 ) ) ) - ( N mod ( 2 ^ M ) ) ) / ( 2 ^ M ) ) = 0 -> ( ( ( N mod ( 2 ^ ( M + 1 ) ) ) - ( N mod ( 2 ^ M ) ) ) / ( 2 ^ M ) ) = 0 ) |
| 35 |
33 34
|
breqtrrid |
|- ( ( ( ( N mod ( 2 ^ ( M + 1 ) ) ) - ( N mod ( 2 ^ M ) ) ) / ( 2 ^ M ) ) = 0 -> 2 || ( ( ( N mod ( 2 ^ ( M + 1 ) ) ) - ( N mod ( 2 ^ M ) ) ) / ( 2 ^ M ) ) ) |
| 36 |
|
bitsval2 |
|- ( ( N e. ZZ /\ M e. NN0 ) -> ( M e. ( bits ` N ) <-> -. 2 || ( |_ ` ( N / ( 2 ^ M ) ) ) ) ) |
| 37 |
5
|
zred |
|- ( ( N e. ZZ /\ M e. NN0 ) -> N e. RR ) |
| 38 |
9
|
nnrpd |
|- ( ( N e. ZZ /\ M e. NN0 ) -> ( 2 ^ M ) e. RR+ ) |
| 39 |
|
moddiffl |
|- ( ( N e. RR /\ ( 2 ^ M ) e. RR+ ) -> ( ( N - ( N mod ( 2 ^ M ) ) ) / ( 2 ^ M ) ) = ( |_ ` ( N / ( 2 ^ M ) ) ) ) |
| 40 |
37 38 39
|
syl2anc |
|- ( ( N e. ZZ /\ M e. NN0 ) -> ( ( N - ( N mod ( 2 ^ M ) ) ) / ( 2 ^ M ) ) = ( |_ ` ( N / ( 2 ^ M ) ) ) ) |
| 41 |
40
|
breq2d |
|- ( ( N e. ZZ /\ M e. NN0 ) -> ( 2 || ( ( N - ( N mod ( 2 ^ M ) ) ) / ( 2 ^ M ) ) <-> 2 || ( |_ ` ( N / ( 2 ^ M ) ) ) ) ) |
| 42 |
|
2z |
|- 2 e. ZZ |
| 43 |
42
|
a1i |
|- ( ( N e. ZZ /\ M e. NN0 ) -> 2 e. ZZ ) |
| 44 |
|
moddifz |
|- ( ( N e. RR /\ ( 2 ^ M ) e. RR+ ) -> ( ( N - ( N mod ( 2 ^ M ) ) ) / ( 2 ^ M ) ) e. ZZ ) |
| 45 |
37 38 44
|
syl2anc |
|- ( ( N e. ZZ /\ M e. NN0 ) -> ( ( N - ( N mod ( 2 ^ M ) ) ) / ( 2 ^ M ) ) e. ZZ ) |
| 46 |
5
|
zcnd |
|- ( ( N e. ZZ /\ M e. NN0 ) -> N e. CC ) |
| 47 |
46 11 18
|
nnncan1d |
|- ( ( N e. ZZ /\ M e. NN0 ) -> ( ( N - ( N mod ( 2 ^ M ) ) ) - ( N - ( N mod ( 2 ^ ( M + 1 ) ) ) ) ) = ( ( N mod ( 2 ^ ( M + 1 ) ) ) - ( N mod ( 2 ^ M ) ) ) ) |
| 48 |
47
|
oveq1d |
|- ( ( N e. ZZ /\ M e. NN0 ) -> ( ( ( N - ( N mod ( 2 ^ M ) ) ) - ( N - ( N mod ( 2 ^ ( M + 1 ) ) ) ) ) / ( 2 ^ M ) ) = ( ( ( N mod ( 2 ^ ( M + 1 ) ) ) - ( N mod ( 2 ^ M ) ) ) / ( 2 ^ M ) ) ) |
| 49 |
46 11
|
subcld |
|- ( ( N e. ZZ /\ M e. NN0 ) -> ( N - ( N mod ( 2 ^ M ) ) ) e. CC ) |
| 50 |
46 18
|
subcld |
|- ( ( N e. ZZ /\ M e. NN0 ) -> ( N - ( N mod ( 2 ^ ( M + 1 ) ) ) ) e. CC ) |
| 51 |
9
|
nncnd |
|- ( ( N e. ZZ /\ M e. NN0 ) -> ( 2 ^ M ) e. CC ) |
| 52 |
49 50 51 31
|
divsubdird |
|- ( ( N e. ZZ /\ M e. NN0 ) -> ( ( ( N - ( N mod ( 2 ^ M ) ) ) - ( N - ( N mod ( 2 ^ ( M + 1 ) ) ) ) ) / ( 2 ^ M ) ) = ( ( ( N - ( N mod ( 2 ^ M ) ) ) / ( 2 ^ M ) ) - ( ( N - ( N mod ( 2 ^ ( M + 1 ) ) ) ) / ( 2 ^ M ) ) ) ) |
| 53 |
48 52
|
eqtr3d |
|- ( ( N e. ZZ /\ M e. NN0 ) -> ( ( ( N mod ( 2 ^ ( M + 1 ) ) ) - ( N mod ( 2 ^ M ) ) ) / ( 2 ^ M ) ) = ( ( ( N - ( N mod ( 2 ^ M ) ) ) / ( 2 ^ M ) ) - ( ( N - ( N mod ( 2 ^ ( M + 1 ) ) ) ) / ( 2 ^ M ) ) ) ) |
| 54 |
27 50
|
mulcomd |
|- ( ( N e. ZZ /\ M e. NN0 ) -> ( 2 x. ( N - ( N mod ( 2 ^ ( M + 1 ) ) ) ) ) = ( ( N - ( N mod ( 2 ^ ( M + 1 ) ) ) ) x. 2 ) ) |
| 55 |
27 51
|
mulcomd |
|- ( ( N e. ZZ /\ M e. NN0 ) -> ( 2 x. ( 2 ^ M ) ) = ( ( 2 ^ M ) x. 2 ) ) |
| 56 |
27 8
|
expp1d |
|- ( ( N e. ZZ /\ M e. NN0 ) -> ( 2 ^ ( M + 1 ) ) = ( ( 2 ^ M ) x. 2 ) ) |
| 57 |
55 56
|
eqtr4d |
|- ( ( N e. ZZ /\ M e. NN0 ) -> ( 2 x. ( 2 ^ M ) ) = ( 2 ^ ( M + 1 ) ) ) |
| 58 |
54 57
|
oveq12d |
|- ( ( N e. ZZ /\ M e. NN0 ) -> ( ( 2 x. ( N - ( N mod ( 2 ^ ( M + 1 ) ) ) ) ) / ( 2 x. ( 2 ^ M ) ) ) = ( ( ( N - ( N mod ( 2 ^ ( M + 1 ) ) ) ) x. 2 ) / ( 2 ^ ( M + 1 ) ) ) ) |
| 59 |
50 51 27 31 29
|
divcan5d |
|- ( ( N e. ZZ /\ M e. NN0 ) -> ( ( 2 x. ( N - ( N mod ( 2 ^ ( M + 1 ) ) ) ) ) / ( 2 x. ( 2 ^ M ) ) ) = ( ( N - ( N mod ( 2 ^ ( M + 1 ) ) ) ) / ( 2 ^ M ) ) ) |
| 60 |
16
|
nncnd |
|- ( ( N e. ZZ /\ M e. NN0 ) -> ( 2 ^ ( M + 1 ) ) e. CC ) |
| 61 |
30
|
peano2zd |
|- ( ( N e. ZZ /\ M e. NN0 ) -> ( M + 1 ) e. ZZ ) |
| 62 |
27 29 61
|
expne0d |
|- ( ( N e. ZZ /\ M e. NN0 ) -> ( 2 ^ ( M + 1 ) ) =/= 0 ) |
| 63 |
50 27 60 62
|
div23d |
|- ( ( N e. ZZ /\ M e. NN0 ) -> ( ( ( N - ( N mod ( 2 ^ ( M + 1 ) ) ) ) x. 2 ) / ( 2 ^ ( M + 1 ) ) ) = ( ( ( N - ( N mod ( 2 ^ ( M + 1 ) ) ) ) / ( 2 ^ ( M + 1 ) ) ) x. 2 ) ) |
| 64 |
58 59 63
|
3eqtr3d |
|- ( ( N e. ZZ /\ M e. NN0 ) -> ( ( N - ( N mod ( 2 ^ ( M + 1 ) ) ) ) / ( 2 ^ M ) ) = ( ( ( N - ( N mod ( 2 ^ ( M + 1 ) ) ) ) / ( 2 ^ ( M + 1 ) ) ) x. 2 ) ) |
| 65 |
16
|
nnrpd |
|- ( ( N e. ZZ /\ M e. NN0 ) -> ( 2 ^ ( M + 1 ) ) e. RR+ ) |
| 66 |
|
moddifz |
|- ( ( N e. RR /\ ( 2 ^ ( M + 1 ) ) e. RR+ ) -> ( ( N - ( N mod ( 2 ^ ( M + 1 ) ) ) ) / ( 2 ^ ( M + 1 ) ) ) e. ZZ ) |
| 67 |
37 65 66
|
syl2anc |
|- ( ( N e. ZZ /\ M e. NN0 ) -> ( ( N - ( N mod ( 2 ^ ( M + 1 ) ) ) ) / ( 2 ^ ( M + 1 ) ) ) e. ZZ ) |
| 68 |
67 43
|
zmulcld |
|- ( ( N e. ZZ /\ M e. NN0 ) -> ( ( ( N - ( N mod ( 2 ^ ( M + 1 ) ) ) ) / ( 2 ^ ( M + 1 ) ) ) x. 2 ) e. ZZ ) |
| 69 |
64 68
|
eqeltrd |
|- ( ( N e. ZZ /\ M e. NN0 ) -> ( ( N - ( N mod ( 2 ^ ( M + 1 ) ) ) ) / ( 2 ^ M ) ) e. ZZ ) |
| 70 |
45 69
|
zsubcld |
|- ( ( N e. ZZ /\ M e. NN0 ) -> ( ( ( N - ( N mod ( 2 ^ M ) ) ) / ( 2 ^ M ) ) - ( ( N - ( N mod ( 2 ^ ( M + 1 ) ) ) ) / ( 2 ^ M ) ) ) e. ZZ ) |
| 71 |
53 70
|
eqeltrd |
|- ( ( N e. ZZ /\ M e. NN0 ) -> ( ( ( N mod ( 2 ^ ( M + 1 ) ) ) - ( N mod ( 2 ^ M ) ) ) / ( 2 ^ M ) ) e. ZZ ) |
| 72 |
|
dvdsmul2 |
|- ( ( ( ( N - ( N mod ( 2 ^ ( M + 1 ) ) ) ) / ( 2 ^ ( M + 1 ) ) ) e. ZZ /\ 2 e. ZZ ) -> 2 || ( ( ( N - ( N mod ( 2 ^ ( M + 1 ) ) ) ) / ( 2 ^ ( M + 1 ) ) ) x. 2 ) ) |
| 73 |
67 43 72
|
syl2anc |
|- ( ( N e. ZZ /\ M e. NN0 ) -> 2 || ( ( ( N - ( N mod ( 2 ^ ( M + 1 ) ) ) ) / ( 2 ^ ( M + 1 ) ) ) x. 2 ) ) |
| 74 |
46 18 11
|
nnncan2d |
|- ( ( N e. ZZ /\ M e. NN0 ) -> ( ( N - ( N mod ( 2 ^ M ) ) ) - ( ( N mod ( 2 ^ ( M + 1 ) ) ) - ( N mod ( 2 ^ M ) ) ) ) = ( N - ( N mod ( 2 ^ ( M + 1 ) ) ) ) ) |
| 75 |
74
|
oveq1d |
|- ( ( N e. ZZ /\ M e. NN0 ) -> ( ( ( N - ( N mod ( 2 ^ M ) ) ) - ( ( N mod ( 2 ^ ( M + 1 ) ) ) - ( N mod ( 2 ^ M ) ) ) ) / ( 2 ^ M ) ) = ( ( N - ( N mod ( 2 ^ ( M + 1 ) ) ) ) / ( 2 ^ M ) ) ) |
| 76 |
49 21 51 31
|
divsubdird |
|- ( ( N e. ZZ /\ M e. NN0 ) -> ( ( ( N - ( N mod ( 2 ^ M ) ) ) - ( ( N mod ( 2 ^ ( M + 1 ) ) ) - ( N mod ( 2 ^ M ) ) ) ) / ( 2 ^ M ) ) = ( ( ( N - ( N mod ( 2 ^ M ) ) ) / ( 2 ^ M ) ) - ( ( ( N mod ( 2 ^ ( M + 1 ) ) ) - ( N mod ( 2 ^ M ) ) ) / ( 2 ^ M ) ) ) ) |
| 77 |
75 76 64
|
3eqtr3d |
|- ( ( N e. ZZ /\ M e. NN0 ) -> ( ( ( N - ( N mod ( 2 ^ M ) ) ) / ( 2 ^ M ) ) - ( ( ( N mod ( 2 ^ ( M + 1 ) ) ) - ( N mod ( 2 ^ M ) ) ) / ( 2 ^ M ) ) ) = ( ( ( N - ( N mod ( 2 ^ ( M + 1 ) ) ) ) / ( 2 ^ ( M + 1 ) ) ) x. 2 ) ) |
| 78 |
73 77
|
breqtrrd |
|- ( ( N e. ZZ /\ M e. NN0 ) -> 2 || ( ( ( N - ( N mod ( 2 ^ M ) ) ) / ( 2 ^ M ) ) - ( ( ( N mod ( 2 ^ ( M + 1 ) ) ) - ( N mod ( 2 ^ M ) ) ) / ( 2 ^ M ) ) ) ) |
| 79 |
|
dvdssub2 |
|- ( ( ( 2 e. ZZ /\ ( ( N - ( N mod ( 2 ^ M ) ) ) / ( 2 ^ M ) ) e. ZZ /\ ( ( ( N mod ( 2 ^ ( M + 1 ) ) ) - ( N mod ( 2 ^ M ) ) ) / ( 2 ^ M ) ) e. ZZ ) /\ 2 || ( ( ( N - ( N mod ( 2 ^ M ) ) ) / ( 2 ^ M ) ) - ( ( ( N mod ( 2 ^ ( M + 1 ) ) ) - ( N mod ( 2 ^ M ) ) ) / ( 2 ^ M ) ) ) ) -> ( 2 || ( ( N - ( N mod ( 2 ^ M ) ) ) / ( 2 ^ M ) ) <-> 2 || ( ( ( N mod ( 2 ^ ( M + 1 ) ) ) - ( N mod ( 2 ^ M ) ) ) / ( 2 ^ M ) ) ) ) |
| 80 |
43 45 71 78 79
|
syl31anc |
|- ( ( N e. ZZ /\ M e. NN0 ) -> ( 2 || ( ( N - ( N mod ( 2 ^ M ) ) ) / ( 2 ^ M ) ) <-> 2 || ( ( ( N mod ( 2 ^ ( M + 1 ) ) ) - ( N mod ( 2 ^ M ) ) ) / ( 2 ^ M ) ) ) ) |
| 81 |
41 80
|
bitr3d |
|- ( ( N e. ZZ /\ M e. NN0 ) -> ( 2 || ( |_ ` ( N / ( 2 ^ M ) ) ) <-> 2 || ( ( ( N mod ( 2 ^ ( M + 1 ) ) ) - ( N mod ( 2 ^ M ) ) ) / ( 2 ^ M ) ) ) ) |
| 82 |
81
|
notbid |
|- ( ( N e. ZZ /\ M e. NN0 ) -> ( -. 2 || ( |_ ` ( N / ( 2 ^ M ) ) ) <-> -. 2 || ( ( ( N mod ( 2 ^ ( M + 1 ) ) ) - ( N mod ( 2 ^ M ) ) ) / ( 2 ^ M ) ) ) ) |
| 83 |
36 82
|
bitrd |
|- ( ( N e. ZZ /\ M e. NN0 ) -> ( M e. ( bits ` N ) <-> -. 2 || ( ( ( N mod ( 2 ^ ( M + 1 ) ) ) - ( N mod ( 2 ^ M ) ) ) / ( 2 ^ M ) ) ) ) |
| 84 |
83
|
con2bid |
|- ( ( N e. ZZ /\ M e. NN0 ) -> ( 2 || ( ( ( N mod ( 2 ^ ( M + 1 ) ) ) - ( N mod ( 2 ^ M ) ) ) / ( 2 ^ M ) ) <-> -. M e. ( bits ` N ) ) ) |
| 85 |
35 84
|
imbitrid |
|- ( ( N e. ZZ /\ M e. NN0 ) -> ( ( ( ( N mod ( 2 ^ ( M + 1 ) ) ) - ( N mod ( 2 ^ M ) ) ) / ( 2 ^ M ) ) = 0 -> -. M e. ( bits ` N ) ) ) |
| 86 |
85
|
con2d |
|- ( ( N e. ZZ /\ M e. NN0 ) -> ( M e. ( bits ` N ) -> -. ( ( ( N mod ( 2 ^ ( M + 1 ) ) ) - ( N mod ( 2 ^ M ) ) ) / ( 2 ^ M ) ) = 0 ) ) |
| 87 |
|
df-neg |
|- -u 1 = ( 0 - 1 ) |
| 88 |
51
|
mulm1d |
|- ( ( N e. ZZ /\ M e. NN0 ) -> ( -u 1 x. ( 2 ^ M ) ) = -u ( 2 ^ M ) ) |
| 89 |
9
|
nnred |
|- ( ( N e. ZZ /\ M e. NN0 ) -> ( 2 ^ M ) e. RR ) |
| 90 |
89
|
renegcld |
|- ( ( N e. ZZ /\ M e. NN0 ) -> -u ( 2 ^ M ) e. RR ) |
| 91 |
37 38
|
modcld |
|- ( ( N e. ZZ /\ M e. NN0 ) -> ( N mod ( 2 ^ M ) ) e. RR ) |
| 92 |
91
|
renegcld |
|- ( ( N e. ZZ /\ M e. NN0 ) -> -u ( N mod ( 2 ^ M ) ) e. RR ) |
| 93 |
37 65
|
modcld |
|- ( ( N e. ZZ /\ M e. NN0 ) -> ( N mod ( 2 ^ ( M + 1 ) ) ) e. RR ) |
| 94 |
93 91
|
resubcld |
|- ( ( N e. ZZ /\ M e. NN0 ) -> ( ( N mod ( 2 ^ ( M + 1 ) ) ) - ( N mod ( 2 ^ M ) ) ) e. RR ) |
| 95 |
|
modlt |
|- ( ( N e. RR /\ ( 2 ^ M ) e. RR+ ) -> ( N mod ( 2 ^ M ) ) < ( 2 ^ M ) ) |
| 96 |
37 38 95
|
syl2anc |
|- ( ( N e. ZZ /\ M e. NN0 ) -> ( N mod ( 2 ^ M ) ) < ( 2 ^ M ) ) |
| 97 |
91 89
|
ltnegd |
|- ( ( N e. ZZ /\ M e. NN0 ) -> ( ( N mod ( 2 ^ M ) ) < ( 2 ^ M ) <-> -u ( 2 ^ M ) < -u ( N mod ( 2 ^ M ) ) ) ) |
| 98 |
96 97
|
mpbid |
|- ( ( N e. ZZ /\ M e. NN0 ) -> -u ( 2 ^ M ) < -u ( N mod ( 2 ^ M ) ) ) |
| 99 |
|
df-neg |
|- -u ( N mod ( 2 ^ M ) ) = ( 0 - ( N mod ( 2 ^ M ) ) ) |
| 100 |
|
0red |
|- ( ( N e. ZZ /\ M e. NN0 ) -> 0 e. RR ) |
| 101 |
|
modge0 |
|- ( ( N e. RR /\ ( 2 ^ ( M + 1 ) ) e. RR+ ) -> 0 <_ ( N mod ( 2 ^ ( M + 1 ) ) ) ) |
| 102 |
37 65 101
|
syl2anc |
|- ( ( N e. ZZ /\ M e. NN0 ) -> 0 <_ ( N mod ( 2 ^ ( M + 1 ) ) ) ) |
| 103 |
100 93 91 102
|
lesub1dd |
|- ( ( N e. ZZ /\ M e. NN0 ) -> ( 0 - ( N mod ( 2 ^ M ) ) ) <_ ( ( N mod ( 2 ^ ( M + 1 ) ) ) - ( N mod ( 2 ^ M ) ) ) ) |
| 104 |
99 103
|
eqbrtrid |
|- ( ( N e. ZZ /\ M e. NN0 ) -> -u ( N mod ( 2 ^ M ) ) <_ ( ( N mod ( 2 ^ ( M + 1 ) ) ) - ( N mod ( 2 ^ M ) ) ) ) |
| 105 |
90 92 94 98 104
|
ltletrd |
|- ( ( N e. ZZ /\ M e. NN0 ) -> -u ( 2 ^ M ) < ( ( N mod ( 2 ^ ( M + 1 ) ) ) - ( N mod ( 2 ^ M ) ) ) ) |
| 106 |
88 105
|
eqbrtrd |
|- ( ( N e. ZZ /\ M e. NN0 ) -> ( -u 1 x. ( 2 ^ M ) ) < ( ( N mod ( 2 ^ ( M + 1 ) ) ) - ( N mod ( 2 ^ M ) ) ) ) |
| 107 |
|
1red |
|- ( ( N e. ZZ /\ M e. NN0 ) -> 1 e. RR ) |
| 108 |
107
|
renegcld |
|- ( ( N e. ZZ /\ M e. NN0 ) -> -u 1 e. RR ) |
| 109 |
108 94 38
|
ltmuldivd |
|- ( ( N e. ZZ /\ M e. NN0 ) -> ( ( -u 1 x. ( 2 ^ M ) ) < ( ( N mod ( 2 ^ ( M + 1 ) ) ) - ( N mod ( 2 ^ M ) ) ) <-> -u 1 < ( ( ( N mod ( 2 ^ ( M + 1 ) ) ) - ( N mod ( 2 ^ M ) ) ) / ( 2 ^ M ) ) ) ) |
| 110 |
106 109
|
mpbid |
|- ( ( N e. ZZ /\ M e. NN0 ) -> -u 1 < ( ( ( N mod ( 2 ^ ( M + 1 ) ) ) - ( N mod ( 2 ^ M ) ) ) / ( 2 ^ M ) ) ) |
| 111 |
87 110
|
eqbrtrrid |
|- ( ( N e. ZZ /\ M e. NN0 ) -> ( 0 - 1 ) < ( ( ( N mod ( 2 ^ ( M + 1 ) ) ) - ( N mod ( 2 ^ M ) ) ) / ( 2 ^ M ) ) ) |
| 112 |
|
0zd |
|- ( ( N e. ZZ /\ M e. NN0 ) -> 0 e. ZZ ) |
| 113 |
|
zlem1lt |
|- ( ( 0 e. ZZ /\ ( ( ( N mod ( 2 ^ ( M + 1 ) ) ) - ( N mod ( 2 ^ M ) ) ) / ( 2 ^ M ) ) e. ZZ ) -> ( 0 <_ ( ( ( N mod ( 2 ^ ( M + 1 ) ) ) - ( N mod ( 2 ^ M ) ) ) / ( 2 ^ M ) ) <-> ( 0 - 1 ) < ( ( ( N mod ( 2 ^ ( M + 1 ) ) ) - ( N mod ( 2 ^ M ) ) ) / ( 2 ^ M ) ) ) ) |
| 114 |
112 71 113
|
syl2anc |
|- ( ( N e. ZZ /\ M e. NN0 ) -> ( 0 <_ ( ( ( N mod ( 2 ^ ( M + 1 ) ) ) - ( N mod ( 2 ^ M ) ) ) / ( 2 ^ M ) ) <-> ( 0 - 1 ) < ( ( ( N mod ( 2 ^ ( M + 1 ) ) ) - ( N mod ( 2 ^ M ) ) ) / ( 2 ^ M ) ) ) ) |
| 115 |
111 114
|
mpbird |
|- ( ( N e. ZZ /\ M e. NN0 ) -> 0 <_ ( ( ( N mod ( 2 ^ ( M + 1 ) ) ) - ( N mod ( 2 ^ M ) ) ) / ( 2 ^ M ) ) ) |
| 116 |
|
elnn0z |
|- ( ( ( ( N mod ( 2 ^ ( M + 1 ) ) ) - ( N mod ( 2 ^ M ) ) ) / ( 2 ^ M ) ) e. NN0 <-> ( ( ( ( N mod ( 2 ^ ( M + 1 ) ) ) - ( N mod ( 2 ^ M ) ) ) / ( 2 ^ M ) ) e. ZZ /\ 0 <_ ( ( ( N mod ( 2 ^ ( M + 1 ) ) ) - ( N mod ( 2 ^ M ) ) ) / ( 2 ^ M ) ) ) ) |
| 117 |
71 115 116
|
sylanbrc |
|- ( ( N e. ZZ /\ M e. NN0 ) -> ( ( ( N mod ( 2 ^ ( M + 1 ) ) ) - ( N mod ( 2 ^ M ) ) ) / ( 2 ^ M ) ) e. NN0 ) |
| 118 |
|
nn0uz |
|- NN0 = ( ZZ>= ` 0 ) |
| 119 |
117 118
|
eleqtrdi |
|- ( ( N e. ZZ /\ M e. NN0 ) -> ( ( ( N mod ( 2 ^ ( M + 1 ) ) ) - ( N mod ( 2 ^ M ) ) ) / ( 2 ^ M ) ) e. ( ZZ>= ` 0 ) ) |
| 120 |
16
|
nnred |
|- ( ( N e. ZZ /\ M e. NN0 ) -> ( 2 ^ ( M + 1 ) ) e. RR ) |
| 121 |
|
modge0 |
|- ( ( N e. RR /\ ( 2 ^ M ) e. RR+ ) -> 0 <_ ( N mod ( 2 ^ M ) ) ) |
| 122 |
37 38 121
|
syl2anc |
|- ( ( N e. ZZ /\ M e. NN0 ) -> 0 <_ ( N mod ( 2 ^ M ) ) ) |
| 123 |
93 91
|
subge02d |
|- ( ( N e. ZZ /\ M e. NN0 ) -> ( 0 <_ ( N mod ( 2 ^ M ) ) <-> ( ( N mod ( 2 ^ ( M + 1 ) ) ) - ( N mod ( 2 ^ M ) ) ) <_ ( N mod ( 2 ^ ( M + 1 ) ) ) ) ) |
| 124 |
122 123
|
mpbid |
|- ( ( N e. ZZ /\ M e. NN0 ) -> ( ( N mod ( 2 ^ ( M + 1 ) ) ) - ( N mod ( 2 ^ M ) ) ) <_ ( N mod ( 2 ^ ( M + 1 ) ) ) ) |
| 125 |
|
modlt |
|- ( ( N e. RR /\ ( 2 ^ ( M + 1 ) ) e. RR+ ) -> ( N mod ( 2 ^ ( M + 1 ) ) ) < ( 2 ^ ( M + 1 ) ) ) |
| 126 |
37 65 125
|
syl2anc |
|- ( ( N e. ZZ /\ M e. NN0 ) -> ( N mod ( 2 ^ ( M + 1 ) ) ) < ( 2 ^ ( M + 1 ) ) ) |
| 127 |
94 93 120 124 126
|
lelttrd |
|- ( ( N e. ZZ /\ M e. NN0 ) -> ( ( N mod ( 2 ^ ( M + 1 ) ) ) - ( N mod ( 2 ^ M ) ) ) < ( 2 ^ ( M + 1 ) ) ) |
| 128 |
127 56
|
breqtrd |
|- ( ( N e. ZZ /\ M e. NN0 ) -> ( ( N mod ( 2 ^ ( M + 1 ) ) ) - ( N mod ( 2 ^ M ) ) ) < ( ( 2 ^ M ) x. 2 ) ) |
| 129 |
7
|
nnred |
|- ( ( N e. ZZ /\ M e. NN0 ) -> 2 e. RR ) |
| 130 |
94 129 38
|
ltdivmuld |
|- ( ( N e. ZZ /\ M e. NN0 ) -> ( ( ( ( N mod ( 2 ^ ( M + 1 ) ) ) - ( N mod ( 2 ^ M ) ) ) / ( 2 ^ M ) ) < 2 <-> ( ( N mod ( 2 ^ ( M + 1 ) ) ) - ( N mod ( 2 ^ M ) ) ) < ( ( 2 ^ M ) x. 2 ) ) ) |
| 131 |
128 130
|
mpbird |
|- ( ( N e. ZZ /\ M e. NN0 ) -> ( ( ( N mod ( 2 ^ ( M + 1 ) ) ) - ( N mod ( 2 ^ M ) ) ) / ( 2 ^ M ) ) < 2 ) |
| 132 |
|
elfzo2 |
|- ( ( ( ( N mod ( 2 ^ ( M + 1 ) ) ) - ( N mod ( 2 ^ M ) ) ) / ( 2 ^ M ) ) e. ( 0 ..^ 2 ) <-> ( ( ( ( N mod ( 2 ^ ( M + 1 ) ) ) - ( N mod ( 2 ^ M ) ) ) / ( 2 ^ M ) ) e. ( ZZ>= ` 0 ) /\ 2 e. ZZ /\ ( ( ( N mod ( 2 ^ ( M + 1 ) ) ) - ( N mod ( 2 ^ M ) ) ) / ( 2 ^ M ) ) < 2 ) ) |
| 133 |
119 43 131 132
|
syl3anbrc |
|- ( ( N e. ZZ /\ M e. NN0 ) -> ( ( ( N mod ( 2 ^ ( M + 1 ) ) ) - ( N mod ( 2 ^ M ) ) ) / ( 2 ^ M ) ) e. ( 0 ..^ 2 ) ) |
| 134 |
|
fzo0to2pr |
|- ( 0 ..^ 2 ) = { 0 , 1 } |
| 135 |
133 134
|
eleqtrdi |
|- ( ( N e. ZZ /\ M e. NN0 ) -> ( ( ( N mod ( 2 ^ ( M + 1 ) ) ) - ( N mod ( 2 ^ M ) ) ) / ( 2 ^ M ) ) e. { 0 , 1 } ) |
| 136 |
|
elpri |
|- ( ( ( ( N mod ( 2 ^ ( M + 1 ) ) ) - ( N mod ( 2 ^ M ) ) ) / ( 2 ^ M ) ) e. { 0 , 1 } -> ( ( ( ( N mod ( 2 ^ ( M + 1 ) ) ) - ( N mod ( 2 ^ M ) ) ) / ( 2 ^ M ) ) = 0 \/ ( ( ( N mod ( 2 ^ ( M + 1 ) ) ) - ( N mod ( 2 ^ M ) ) ) / ( 2 ^ M ) ) = 1 ) ) |
| 137 |
135 136
|
syl |
|- ( ( N e. ZZ /\ M e. NN0 ) -> ( ( ( ( N mod ( 2 ^ ( M + 1 ) ) ) - ( N mod ( 2 ^ M ) ) ) / ( 2 ^ M ) ) = 0 \/ ( ( ( N mod ( 2 ^ ( M + 1 ) ) ) - ( N mod ( 2 ^ M ) ) ) / ( 2 ^ M ) ) = 1 ) ) |
| 138 |
137
|
ord |
|- ( ( N e. ZZ /\ M e. NN0 ) -> ( -. ( ( ( N mod ( 2 ^ ( M + 1 ) ) ) - ( N mod ( 2 ^ M ) ) ) / ( 2 ^ M ) ) = 0 -> ( ( ( N mod ( 2 ^ ( M + 1 ) ) ) - ( N mod ( 2 ^ M ) ) ) / ( 2 ^ M ) ) = 1 ) ) |
| 139 |
86 138
|
syld |
|- ( ( N e. ZZ /\ M e. NN0 ) -> ( M e. ( bits ` N ) -> ( ( ( N mod ( 2 ^ ( M + 1 ) ) ) - ( N mod ( 2 ^ M ) ) ) / ( 2 ^ M ) ) = 1 ) ) |
| 140 |
139
|
imp |
|- ( ( ( N e. ZZ /\ M e. NN0 ) /\ M e. ( bits ` N ) ) -> ( ( ( N mod ( 2 ^ ( M + 1 ) ) ) - ( N mod ( 2 ^ M ) ) ) / ( 2 ^ M ) ) = 1 ) |
| 141 |
22 26 32 140
|
diveq1d |
|- ( ( ( N e. ZZ /\ M e. NN0 ) /\ M e. ( bits ` N ) ) -> ( ( N mod ( 2 ^ ( M + 1 ) ) ) - ( N mod ( 2 ^ M ) ) ) = ( 2 ^ M ) ) |
| 142 |
141
|
oveq2d |
|- ( ( ( N e. ZZ /\ M e. NN0 ) /\ M e. ( bits ` N ) ) -> ( ( N mod ( 2 ^ M ) ) + ( ( N mod ( 2 ^ ( M + 1 ) ) ) - ( N mod ( 2 ^ M ) ) ) ) = ( ( N mod ( 2 ^ M ) ) + ( 2 ^ M ) ) ) |
| 143 |
20 142
|
eqtr3d |
|- ( ( ( N e. ZZ /\ M e. NN0 ) /\ M e. ( bits ` N ) ) -> ( N mod ( 2 ^ ( M + 1 ) ) ) = ( ( N mod ( 2 ^ M ) ) + ( 2 ^ M ) ) ) |
| 144 |
18
|
adantr |
|- ( ( ( N e. ZZ /\ M e. NN0 ) /\ -. M e. ( bits ` N ) ) -> ( N mod ( 2 ^ ( M + 1 ) ) ) e. CC ) |
| 145 |
11
|
adantr |
|- ( ( ( N e. ZZ /\ M e. NN0 ) /\ -. M e. ( bits ` N ) ) -> ( N mod ( 2 ^ M ) ) e. CC ) |
| 146 |
21
|
adantr |
|- ( ( ( N e. ZZ /\ M e. NN0 ) /\ -. M e. ( bits ` N ) ) -> ( ( N mod ( 2 ^ ( M + 1 ) ) ) - ( N mod ( 2 ^ M ) ) ) e. CC ) |
| 147 |
51
|
adantr |
|- ( ( ( N e. ZZ /\ M e. NN0 ) /\ -. M e. ( bits ` N ) ) -> ( 2 ^ M ) e. CC ) |
| 148 |
31
|
adantr |
|- ( ( ( N e. ZZ /\ M e. NN0 ) /\ -. M e. ( bits ` N ) ) -> ( 2 ^ M ) =/= 0 ) |
| 149 |
|
n2dvds1 |
|- -. 2 || 1 |
| 150 |
|
breq2 |
|- ( ( ( ( N mod ( 2 ^ ( M + 1 ) ) ) - ( N mod ( 2 ^ M ) ) ) / ( 2 ^ M ) ) = 1 -> ( 2 || ( ( ( N mod ( 2 ^ ( M + 1 ) ) ) - ( N mod ( 2 ^ M ) ) ) / ( 2 ^ M ) ) <-> 2 || 1 ) ) |
| 151 |
149 150
|
mtbiri |
|- ( ( ( ( N mod ( 2 ^ ( M + 1 ) ) ) - ( N mod ( 2 ^ M ) ) ) / ( 2 ^ M ) ) = 1 -> -. 2 || ( ( ( N mod ( 2 ^ ( M + 1 ) ) ) - ( N mod ( 2 ^ M ) ) ) / ( 2 ^ M ) ) ) |
| 152 |
138 151
|
syl6 |
|- ( ( N e. ZZ /\ M e. NN0 ) -> ( -. ( ( ( N mod ( 2 ^ ( M + 1 ) ) ) - ( N mod ( 2 ^ M ) ) ) / ( 2 ^ M ) ) = 0 -> -. 2 || ( ( ( N mod ( 2 ^ ( M + 1 ) ) ) - ( N mod ( 2 ^ M ) ) ) / ( 2 ^ M ) ) ) ) |
| 153 |
152 83
|
sylibrd |
|- ( ( N e. ZZ /\ M e. NN0 ) -> ( -. ( ( ( N mod ( 2 ^ ( M + 1 ) ) ) - ( N mod ( 2 ^ M ) ) ) / ( 2 ^ M ) ) = 0 -> M e. ( bits ` N ) ) ) |
| 154 |
153
|
con1d |
|- ( ( N e. ZZ /\ M e. NN0 ) -> ( -. M e. ( bits ` N ) -> ( ( ( N mod ( 2 ^ ( M + 1 ) ) ) - ( N mod ( 2 ^ M ) ) ) / ( 2 ^ M ) ) = 0 ) ) |
| 155 |
154
|
imp |
|- ( ( ( N e. ZZ /\ M e. NN0 ) /\ -. M e. ( bits ` N ) ) -> ( ( ( N mod ( 2 ^ ( M + 1 ) ) ) - ( N mod ( 2 ^ M ) ) ) / ( 2 ^ M ) ) = 0 ) |
| 156 |
146 147 148 155
|
diveq0d |
|- ( ( ( N e. ZZ /\ M e. NN0 ) /\ -. M e. ( bits ` N ) ) -> ( ( N mod ( 2 ^ ( M + 1 ) ) ) - ( N mod ( 2 ^ M ) ) ) = 0 ) |
| 157 |
144 145 156
|
subeq0d |
|- ( ( ( N e. ZZ /\ M e. NN0 ) /\ -. M e. ( bits ` N ) ) -> ( N mod ( 2 ^ ( M + 1 ) ) ) = ( N mod ( 2 ^ M ) ) ) |
| 158 |
145
|
addridd |
|- ( ( ( N e. ZZ /\ M e. NN0 ) /\ -. M e. ( bits ` N ) ) -> ( ( N mod ( 2 ^ M ) ) + 0 ) = ( N mod ( 2 ^ M ) ) ) |
| 159 |
157 158
|
eqtr4d |
|- ( ( ( N e. ZZ /\ M e. NN0 ) /\ -. M e. ( bits ` N ) ) -> ( N mod ( 2 ^ ( M + 1 ) ) ) = ( ( N mod ( 2 ^ M ) ) + 0 ) ) |
| 160 |
2 4 143 159
|
ifbothda |
|- ( ( N e. ZZ /\ M e. NN0 ) -> ( N mod ( 2 ^ ( M + 1 ) ) ) = ( ( N mod ( 2 ^ M ) ) + if ( M e. ( bits ` N ) , ( 2 ^ M ) , 0 ) ) ) |