ILE Home Intuitionistic Logic Explorer < Previous   Next >
Nearby theorems
Mirrors  >  Home  >  ILE Home  >  Th. List  >  bitsinv1lem Unicode version

Theorem bitsinv1lem 12583
Description: Lemma for bitsinv1 12584. (Contributed by Mario Carneiro, 22-Sep-2016.)
Assertion
Ref Expression
bitsinv1lem  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( N  mod  (
2 ^ ( M  +  1 ) ) )  =  ( ( N  mod  ( 2 ^ M ) )  +  if ( M  e.  (bits `  N
) ,  ( 2 ^ M ) ,  0 ) ) )

Proof of Theorem bitsinv1lem
StepHypRef Expression
1 oveq2 6036 . . 3  |-  ( ( 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 ) ) )
21eqeq2d 2243 . 2  |-  ( ( 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 6036 . . 3  |-  ( 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 ) ) )
43eqeq2d 2243 . 2  |-  ( 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 109 . . . . . . 7  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  ->  N  e.  ZZ )
6 2nn 9348 . . . . . . . . 9  |-  2  e.  NN
76a1i 9 . . . . . . . 8  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
2  e.  NN )
8 simpr 110 . . . . . . . 8  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  ->  M  e.  NN0 )
97, 8nnexpcld 11001 . . . . . . 7  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( 2 ^ M
)  e.  NN )
105, 9zmodcld 10651 . . . . . 6  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( N  mod  (
2 ^ M ) )  e.  NN0 )
1110nn0cnd 9500 . . . . 5  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( N  mod  (
2 ^ M ) )  e.  CC )
1211adantr 276 . . . 4  |-  ( ( ( N  e.  ZZ  /\  M  e.  NN0 )  /\  M  e.  (bits `  N ) )  -> 
( N  mod  (
2 ^ M ) )  e.  CC )
13 1nn0 9461 . . . . . . . . . 10  |-  1  e.  NN0
1413a1i 9 . . . . . . . . 9  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
1  e.  NN0 )
158, 14nn0addcld 9502 . . . . . . . 8  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( M  +  1 )  e.  NN0 )
167, 15nnexpcld 11001 . . . . . . 7  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( 2 ^ ( M  +  1 ) )  e.  NN )
175, 16zmodcld 10651 . . . . . 6  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( N  mod  (
2 ^ ( M  +  1 ) ) )  e.  NN0 )
1817nn0cnd 9500 . . . . 5  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( N  mod  (
2 ^ ( M  +  1 ) ) )  e.  CC )
1918adantr 276 . . . 4  |-  ( ( ( N  e.  ZZ  /\  M  e.  NN0 )  /\  M  e.  (bits `  N ) )  -> 
( N  mod  (
2 ^ ( M  +  1 ) ) )  e.  CC )
2012, 19pncan3d 8536 . . 3  |-  ( ( ( 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 ) ) ) )
2118, 11subcld 8533 . . . . . 6  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( ( N  mod  ( 2 ^ ( M  +  1 ) ) )  -  ( N  mod  ( 2 ^ M ) ) )  e.  CC )
2221adantr 276 . . . . 5  |-  ( ( ( N  e.  ZZ  /\  M  e.  NN0 )  /\  M  e.  (bits `  N ) )  -> 
( ( N  mod  ( 2 ^ ( M  +  1 ) ) )  -  ( N  mod  ( 2 ^ M ) ) )  e.  CC )
236a1i 9 . . . . . . 7  |-  ( ( ( N  e.  ZZ  /\  M  e.  NN0 )  /\  M  e.  (bits `  N ) )  -> 
2  e.  NN )
24 simplr 529 . . . . . . 7  |-  ( ( ( N  e.  ZZ  /\  M  e.  NN0 )  /\  M  e.  (bits `  N ) )  ->  M  e.  NN0 )
2523, 24nnexpcld 11001 . . . . . 6  |-  ( ( ( N  e.  ZZ  /\  M  e.  NN0 )  /\  M  e.  (bits `  N ) )  -> 
( 2 ^ M
)  e.  NN )
2625nncnd 9200 . . . . 5  |-  ( ( ( N  e.  ZZ  /\  M  e.  NN0 )  /\  M  e.  (bits `  N ) )  -> 
( 2 ^ M
)  e.  CC )
27 2cnd 9259 . . . . . . 7  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
2  e.  CC )
287nnap0d 9232 . . . . . . 7  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
2 #  0 )
298nn0zd 9643 . . . . . . 7  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  ->  M  e.  ZZ )
3027, 28, 29expap0d 10985 . . . . . 6  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( 2 ^ M
) #  0 )
3130adantr 276 . . . . 5  |-  ( ( ( N  e.  ZZ  /\  M  e.  NN0 )  /\  M  e.  (bits `  N ) )  -> 
( 2 ^ M
) #  0 )
32 z0even 12533 . . . . . . . . . 10  |-  2  ||  0
33 id 19 . . . . . . . . . 10  |-  ( ( ( ( N  mod  ( 2 ^ ( M  +  1 ) ) )  -  ( N  mod  ( 2 ^ M ) ) )  /  ( 2 ^ M ) )  =  0  ->  ( (
( N  mod  (
2 ^ ( M  +  1 ) ) )  -  ( N  mod  ( 2 ^ M ) ) )  /  ( 2 ^ M ) )  =  0 )
3432, 33breqtrrid 4131 . . . . . . . . 9  |-  ( ( ( ( N  mod  ( 2 ^ ( M  +  1 ) ) )  -  ( N  mod  ( 2 ^ M ) ) )  /  ( 2 ^ M ) )  =  0  ->  2  ||  ( ( ( N  mod  ( 2 ^ ( M  +  1 ) ) )  -  ( N  mod  ( 2 ^ M ) ) )  /  ( 2 ^ M ) ) )
35 bitsval2 12566 . . . . . . . . . . . 12  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( M  e.  (bits `  N )  <->  -.  2  ||  ( |_ `  ( N  /  ( 2 ^ M ) ) ) ) )
36 zq 9903 . . . . . . . . . . . . . . . . 17  |-  ( N  e.  ZZ  ->  N  e.  QQ )
3736adantr 276 . . . . . . . . . . . . . . . 16  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  ->  N  e.  QQ )
38 2z 9550 . . . . . . . . . . . . . . . . . 18  |-  2  e.  ZZ
39 zq 9903 . . . . . . . . . . . . . . . . . 18  |-  ( 2  e.  ZZ  ->  2  e.  QQ )
4038, 39ax-mp 5 . . . . . . . . . . . . . . . . 17  |-  2  e.  QQ
41 qexpcl 10861 . . . . . . . . . . . . . . . . 17  |-  ( ( 2  e.  QQ  /\  M  e.  NN0 )  -> 
( 2 ^ M
)  e.  QQ )
4240, 8, 41sylancr 414 . . . . . . . . . . . . . . . 16  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( 2 ^ M
)  e.  QQ )
439nngt0d 9230 . . . . . . . . . . . . . . . 16  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
0  <  ( 2 ^ M ) )
44 modqdiffl 10641 . . . . . . . . . . . . . . . 16  |-  ( ( N  e.  QQ  /\  ( 2 ^ M
)  e.  QQ  /\  0  <  ( 2 ^ M ) )  -> 
( ( N  -  ( N  mod  ( 2 ^ M ) ) )  /  ( 2 ^ M ) )  =  ( |_ `  ( N  /  (
2 ^ M ) ) ) )
4537, 42, 43, 44syl3anc 1274 . . . . . . . . . . . . . . 15  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( ( N  -  ( N  mod  ( 2 ^ M ) ) )  /  ( 2 ^ M ) )  =  ( |_ `  ( N  /  (
2 ^ M ) ) ) )
4645breq2d 4105 . . . . . . . . . . . . . 14  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( 2  ||  (
( N  -  ( N  mod  ( 2 ^ M ) ) )  /  ( 2 ^ M ) )  <->  2  ||  ( |_ `  ( N  /  ( 2 ^ M ) ) ) ) )
4738a1i 9 . . . . . . . . . . . . . . 15  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
2  e.  ZZ )
48 modqdifz 10642 . . . . . . . . . . . . . . . 16  |-  ( ( N  e.  QQ  /\  ( 2 ^ M
)  e.  QQ  /\  0  <  ( 2 ^ M ) )  -> 
( ( N  -  ( N  mod  ( 2 ^ M ) ) )  /  ( 2 ^ M ) )  e.  ZZ )
4937, 42, 43, 48syl3anc 1274 . . . . . . . . . . . . . . 15  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( ( N  -  ( N  mod  ( 2 ^ M ) ) )  /  ( 2 ^ M ) )  e.  ZZ )
505zcnd 9646 . . . . . . . . . . . . . . . . . . 19  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  ->  N  e.  CC )
5150, 11, 18nnncan1d 8567 . . . . . . . . . . . . . . . . . 18  |-  ( ( 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 ) ) ) )
5251oveq1d 6043 . . . . . . . . . . . . . . . . 17  |-  ( ( 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
) ) )
5350, 11subcld 8533 . . . . . . . . . . . . . . . . . 18  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( N  -  ( N  mod  ( 2 ^ M ) ) )  e.  CC )
5450, 18subcld 8533 . . . . . . . . . . . . . . . . . 18  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( N  -  ( N  mod  ( 2 ^ ( M  +  1 ) ) ) )  e.  CC )
559nncnd 9200 . . . . . . . . . . . . . . . . . 18  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( 2 ^ M
)  e.  CC )
5653, 54, 55, 30divsubdirapd 9053 . . . . . . . . . . . . . . . . 17  |-  ( ( 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 ) ) ) )
5752, 56eqtr3d 2266 . . . . . . . . . . . . . . . 16  |-  ( ( 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 ) ) ) )
5827, 54mulcomd 8244 . . . . . . . . . . . . . . . . . . . 20  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( 2  x.  ( N  -  ( N  mod  ( 2 ^ ( M  +  1 ) ) ) ) )  =  ( ( N  -  ( N  mod  ( 2 ^ ( M  +  1 ) ) ) )  x.  2 ) )
5927, 55mulcomd 8244 . . . . . . . . . . . . . . . . . . . . 21  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( 2  x.  (
2 ^ M ) )  =  ( ( 2 ^ M )  x.  2 ) )
6027, 8expp1d 10980 . . . . . . . . . . . . . . . . . . . . 21  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( 2 ^ ( M  +  1 ) )  =  ( ( 2 ^ M )  x.  2 ) )
6159, 60eqtr4d 2267 . . . . . . . . . . . . . . . . . . . 20  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( 2  x.  (
2 ^ M ) )  =  ( 2 ^ ( M  + 
1 ) ) )
6258, 61oveq12d 6046 . . . . . . . . . . . . . . . . . . 19  |-  ( ( 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 ) ) ) )
63 2ap0 9279 . . . . . . . . . . . . . . . . . . . . 21  |-  2 #  0
6463a1i 9 . . . . . . . . . . . . . . . . . . . 20  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
2 #  0 )
6554, 55, 27, 30, 64divcanap5d 9040 . . . . . . . . . . . . . . . . . . 19  |-  ( ( 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
) ) )
6616nncnd 9200 . . . . . . . . . . . . . . . . . . . 20  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( 2 ^ ( M  +  1 ) )  e.  CC )
6729peano2zd 9648 . . . . . . . . . . . . . . . . . . . . 21  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( M  +  1 )  e.  ZZ )
6827, 28, 67expap0d 10985 . . . . . . . . . . . . . . . . . . . 20  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( 2 ^ ( M  +  1 ) ) #  0 )
6954, 27, 66, 68div23apd 9051 . . . . . . . . . . . . . . . . . . 19  |-  ( ( 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 ) )
7062, 65, 693eqtr3d 2272 . . . . . . . . . . . . . . . . . 18  |-  ( ( 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 ) )
71 qexpcl 10861 . . . . . . . . . . . . . . . . . . . . 21  |-  ( ( 2  e.  QQ  /\  ( M  +  1
)  e.  NN0 )  ->  ( 2 ^ ( M  +  1 ) )  e.  QQ )
7240, 15, 71sylancr 414 . . . . . . . . . . . . . . . . . . . 20  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( 2 ^ ( M  +  1 ) )  e.  QQ )
7316nngt0d 9230 . . . . . . . . . . . . . . . . . . . 20  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
0  <  ( 2 ^ ( M  + 
1 ) ) )
74 modqdifz 10642 . . . . . . . . . . . . . . . . . . . 20  |-  ( ( N  e.  QQ  /\  ( 2 ^ ( M  +  1 ) )  e.  QQ  /\  0  <  ( 2 ^ ( M  +  1 ) ) )  -> 
( ( N  -  ( N  mod  ( 2 ^ ( M  + 
1 ) ) ) )  /  ( 2 ^ ( M  + 
1 ) ) )  e.  ZZ )
7537, 72, 73, 74syl3anc 1274 . . . . . . . . . . . . . . . . . . 19  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( ( N  -  ( N  mod  ( 2 ^ ( M  + 
1 ) ) ) )  /  ( 2 ^ ( M  + 
1 ) ) )  e.  ZZ )
7675, 47zmulcld 9651 . . . . . . . . . . . . . . . . . 18  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( ( ( N  -  ( N  mod  ( 2 ^ ( M  +  1 ) ) ) )  / 
( 2 ^ ( M  +  1 ) ) )  x.  2 )  e.  ZZ )
7770, 76eqeltrd 2308 . . . . . . . . . . . . . . . . 17  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( ( N  -  ( N  mod  ( 2 ^ ( M  + 
1 ) ) ) )  /  ( 2 ^ M ) )  e.  ZZ )
7849, 77zsubcld 9650 . . . . . . . . . . . . . . . 16  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( ( ( N  -  ( N  mod  ( 2 ^ M
) ) )  / 
( 2 ^ M
) )  -  (
( N  -  ( N  mod  ( 2 ^ ( M  +  1 ) ) ) )  /  ( 2 ^ M ) ) )  e.  ZZ )
7957, 78eqeltrd 2308 . . . . . . . . . . . . . . 15  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( ( ( N  mod  ( 2 ^ ( M  +  1 ) ) )  -  ( N  mod  ( 2 ^ M ) ) )  /  ( 2 ^ M ) )  e.  ZZ )
80 dvdsmul2 12436 . . . . . . . . . . . . . . . . 17  |-  ( ( ( ( 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 ) )
8175, 47, 80syl2anc 411 . . . . . . . . . . . . . . . 16  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
2  ||  ( (
( N  -  ( N  mod  ( 2 ^ ( M  +  1 ) ) ) )  /  ( 2 ^ ( M  +  1 ) ) )  x.  2 ) )
8250, 18, 11nnncan2d 8568 . . . . . . . . . . . . . . . . . 18  |-  ( ( 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 ) ) ) ) )
8382oveq1d 6043 . . . . . . . . . . . . . . . . 17  |-  ( ( 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
) ) )
8453, 21, 55, 30divsubdirapd 9053 . . . . . . . . . . . . . . . . 17  |-  ( ( 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 ) ) ) )
8583, 84, 703eqtr3d 2272 . . . . . . . . . . . . . . . 16  |-  ( ( 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 ) )
8681, 85breqtrrd 4121 . . . . . . . . . . . . . . 15  |-  ( ( 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 ) ) ) )
87 dvdssub2 12457 . . . . . . . . . . . . . . 15  |-  ( ( ( 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 ) ) ) )
8847, 49, 79, 86, 87syl31anc 1277 . . . . . . . . . . . . . 14  |-  ( ( 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 ) ) ) )
8946, 88bitr3d 190 . . . . . . . . . . . . 13  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( 2  ||  ( |_ `  ( N  / 
( 2 ^ M
) ) )  <->  2  ||  ( ( ( N  mod  ( 2 ^ ( M  +  1 ) ) )  -  ( N  mod  ( 2 ^ M ) ) )  /  ( 2 ^ M ) ) ) )
9089notbid 673 . . . . . . . . . . . 12  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( -.  2  ||  ( |_ `  ( N  /  ( 2 ^ M ) ) )  <->  -.  2  ||  ( ( ( N  mod  (
2 ^ ( M  +  1 ) ) )  -  ( N  mod  ( 2 ^ M ) ) )  /  ( 2 ^ M ) ) ) )
9135, 90bitrd 188 . . . . . . . . . . 11  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( M  e.  (bits `  N )  <->  -.  2  ||  ( ( ( N  mod  ( 2 ^ ( M  +  1 ) ) )  -  ( N  mod  ( 2 ^ M ) ) )  /  ( 2 ^ M ) ) ) )
9291biimpd 144 . . . . . . . . . 10  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( M  e.  (bits `  N )  ->  -.  2  ||  ( ( ( N  mod  ( 2 ^ ( M  + 
1 ) ) )  -  ( N  mod  ( 2 ^ M
) ) )  / 
( 2 ^ M
) ) ) )
9392con2d 629 . . . . . . . . 9  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( 2  ||  (
( ( N  mod  ( 2 ^ ( M  +  1 ) ) )  -  ( N  mod  ( 2 ^ M ) ) )  /  ( 2 ^ M ) )  ->  -.  M  e.  (bits `  N ) ) )
9434, 93syl5 32 . . . . . . . 8  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( ( ( ( N  mod  ( 2 ^ ( M  + 
1 ) ) )  -  ( N  mod  ( 2 ^ M
) ) )  / 
( 2 ^ M
) )  =  0  ->  -.  M  e.  (bits `  N ) ) )
9594con2d 629 . . . . . . 7  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( M  e.  (bits `  N )  ->  -.  ( ( ( N  mod  ( 2 ^ ( M  +  1 ) ) )  -  ( N  mod  ( 2 ^ M ) ) )  /  ( 2 ^ M ) )  =  0 ) )
96 df-neg 8396 . . . . . . . . . . . . . . 15  |-  -u 1  =  ( 0  -  1 )
9755mulm1d 8632 . . . . . . . . . . . . . . . . 17  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( -u 1  x.  (
2 ^ M ) )  =  -u (
2 ^ M ) )
989nnred 9199 . . . . . . . . . . . . . . . . . . 19  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( 2 ^ M
)  e.  RR )
9998renegcld 8602 . . . . . . . . . . . . . . . . . 18  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  ->  -u ( 2 ^ M
)  e.  RR )
10037, 42, 43modqcld 10634 . . . . . . . . . . . . . . . . . . . 20  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( N  mod  (
2 ^ M ) )  e.  QQ )
101 qre 9902 . . . . . . . . . . . . . . . . . . . 20  |-  ( ( N  mod  ( 2 ^ M ) )  e.  QQ  ->  ( N  mod  ( 2 ^ M ) )  e.  RR )
102100, 101syl 14 . . . . . . . . . . . . . . . . . . 19  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( N  mod  (
2 ^ M ) )  e.  RR )
103102renegcld 8602 . . . . . . . . . . . . . . . . . 18  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  ->  -u ( N  mod  (
2 ^ M ) )  e.  RR )
10437, 72, 73modqcld 10634 . . . . . . . . . . . . . . . . . . . 20  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( N  mod  (
2 ^ ( M  +  1 ) ) )  e.  QQ )
105 qre 9902 . . . . . . . . . . . . . . . . . . . 20  |-  ( ( N  mod  ( 2 ^ ( M  + 
1 ) ) )  e.  QQ  ->  ( N  mod  ( 2 ^ ( M  +  1 ) ) )  e.  RR )
106104, 105syl 14 . . . . . . . . . . . . . . . . . . 19  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( N  mod  (
2 ^ ( M  +  1 ) ) )  e.  RR )
107106, 102resubcld 8603 . . . . . . . . . . . . . . . . . 18  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( ( N  mod  ( 2 ^ ( M  +  1 ) ) )  -  ( N  mod  ( 2 ^ M ) ) )  e.  RR )
108 modqlt 10639 . . . . . . . . . . . . . . . . . . . 20  |-  ( ( N  e.  QQ  /\  ( 2 ^ M
)  e.  QQ  /\  0  <  ( 2 ^ M ) )  -> 
( N  mod  (
2 ^ M ) )  <  ( 2 ^ M ) )
10937, 42, 43, 108syl3anc 1274 . . . . . . . . . . . . . . . . . . 19  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( N  mod  (
2 ^ M ) )  <  ( 2 ^ M ) )
110102, 98ltnegd 8746 . . . . . . . . . . . . . . . . . . 19  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( ( N  mod  ( 2 ^ M
) )  <  (
2 ^ M )  <->  -u ( 2 ^ M
)  <  -u ( N  mod  ( 2 ^ M ) ) ) )
111109, 110mpbid 147 . . . . . . . . . . . . . . . . . 18  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  ->  -u ( 2 ^ M
)  <  -u ( N  mod  ( 2 ^ M ) ) )
112 df-neg 8396 . . . . . . . . . . . . . . . . . . 19  |-  -u ( N  mod  ( 2 ^ M ) )  =  ( 0  -  ( N  mod  ( 2 ^ M ) ) )
113 0red 8223 . . . . . . . . . . . . . . . . . . . 20  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
0  e.  RR )
114 modqge0 10638 . . . . . . . . . . . . . . . . . . . . 21  |-  ( ( N  e.  QQ  /\  ( 2 ^ ( M  +  1 ) )  e.  QQ  /\  0  <  ( 2 ^ ( M  +  1 ) ) )  -> 
0  <_  ( N  mod  ( 2 ^ ( M  +  1 ) ) ) )
11537, 72, 73, 114syl3anc 1274 . . . . . . . . . . . . . . . . . . . 20  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
0  <_  ( N  mod  ( 2 ^ ( M  +  1 ) ) ) )
116113, 106, 102, 115lesub1dd 8784 . . . . . . . . . . . . . . . . . . 19  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( 0  -  ( N  mod  ( 2 ^ M ) ) )  <_  ( ( N  mod  ( 2 ^ ( M  +  1 ) ) )  -  ( N  mod  ( 2 ^ M ) ) ) )
117112, 116eqbrtrid 4128 . . . . . . . . . . . . . . . . . 18  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  ->  -u ( N  mod  (
2 ^ M ) )  <_  ( ( N  mod  ( 2 ^ ( M  +  1 ) ) )  -  ( N  mod  ( 2 ^ M ) ) ) )
11899, 103, 107, 111, 117ltletrd 8646 . . . . . . . . . . . . . . . . 17  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  ->  -u ( 2 ^ M
)  <  ( ( N  mod  ( 2 ^ ( M  +  1 ) ) )  -  ( N  mod  ( 2 ^ M ) ) ) )
11997, 118eqbrtrd 4115 . . . . . . . . . . . . . . . 16  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( -u 1  x.  (
2 ^ M ) )  <  ( ( N  mod  ( 2 ^ ( M  + 
1 ) ) )  -  ( N  mod  ( 2 ^ M
) ) ) )
120 1red 8237 . . . . . . . . . . . . . . . . . 18  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
1  e.  RR )
121120renegcld 8602 . . . . . . . . . . . . . . . . 17  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  ->  -u 1  e.  RR )
1229nnrpd 9972 . . . . . . . . . . . . . . . . 17  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( 2 ^ M
)  e.  RR+ )
123121, 107, 122ltmuldivd 10022 . . . . . . . . . . . . . . . 16  |-  ( ( 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 ) ) ) )
124119, 123mpbid 147 . . . . . . . . . . . . . . 15  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  ->  -u 1  <  ( ( ( N  mod  (
2 ^ ( M  +  1 ) ) )  -  ( N  mod  ( 2 ^ M ) ) )  /  ( 2 ^ M ) ) )
12596, 124eqbrtrrid 4129 . . . . . . . . . . . . . 14  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( 0  -  1 )  <  ( ( ( N  mod  (
2 ^ ( M  +  1 ) ) )  -  ( N  mod  ( 2 ^ M ) ) )  /  ( 2 ^ M ) ) )
126 0zd 9534 . . . . . . . . . . . . . . 15  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
0  e.  ZZ )
127 zlem1lt 9579 . . . . . . . . . . . . . . 15  |-  ( ( 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 ) ) ) )
128126, 79, 127syl2anc 411 . . . . . . . . . . . . . 14  |-  ( ( 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 ) ) ) )
129125, 128mpbird 167 . . . . . . . . . . . . 13  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
0  <_  ( (
( N  mod  (
2 ^ ( M  +  1 ) ) )  -  ( N  mod  ( 2 ^ M ) ) )  /  ( 2 ^ M ) ) )
130 elnn0z 9535 . . . . . . . . . . . . 13  |-  ( ( ( ( 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 ) ) ) )
13179, 129, 130sylanbrc 417 . . . . . . . . . . . 12  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( ( ( N  mod  ( 2 ^ ( M  +  1 ) ) )  -  ( N  mod  ( 2 ^ M ) ) )  /  ( 2 ^ M ) )  e.  NN0 )
132 nn0uz 9834 . . . . . . . . . . . 12  |-  NN0  =  ( ZZ>= `  0 )
133131, 132eleqtrdi 2324 . . . . . . . . . . 11  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( ( ( N  mod  ( 2 ^ ( M  +  1 ) ) )  -  ( N  mod  ( 2 ^ M ) ) )  /  ( 2 ^ M ) )  e.  ( ZZ>= `  0
) )
13416nnred 9199 . . . . . . . . . . . . . 14  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( 2 ^ ( M  +  1 ) )  e.  RR )
135 modqge0 10638 . . . . . . . . . . . . . . . 16  |-  ( ( N  e.  QQ  /\  ( 2 ^ M
)  e.  QQ  /\  0  <  ( 2 ^ M ) )  -> 
0  <_  ( N  mod  ( 2 ^ M
) ) )
13637, 42, 43, 135syl3anc 1274 . . . . . . . . . . . . . . 15  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
0  <_  ( N  mod  ( 2 ^ M
) ) )
137106, 102subge02d 8760 . . . . . . . . . . . . . . 15  |-  ( ( 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 ) ) ) ) )
138136, 137mpbid 147 . . . . . . . . . . . . . 14  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( ( N  mod  ( 2 ^ ( M  +  1 ) ) )  -  ( N  mod  ( 2 ^ M ) ) )  <_  ( N  mod  ( 2 ^ ( M  +  1 ) ) ) )
139 modqlt 10639 . . . . . . . . . . . . . . 15  |-  ( ( N  e.  QQ  /\  ( 2 ^ ( M  +  1 ) )  e.  QQ  /\  0  <  ( 2 ^ ( M  +  1 ) ) )  -> 
( N  mod  (
2 ^ ( M  +  1 ) ) )  <  ( 2 ^ ( M  + 
1 ) ) )
14037, 72, 73, 139syl3anc 1274 . . . . . . . . . . . . . 14  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( N  mod  (
2 ^ ( M  +  1 ) ) )  <  ( 2 ^ ( M  + 
1 ) ) )
141107, 106, 134, 138, 140lelttrd 8347 . . . . . . . . . . . . 13  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( ( N  mod  ( 2 ^ ( M  +  1 ) ) )  -  ( N  mod  ( 2 ^ M ) ) )  <  ( 2 ^ ( M  +  1 ) ) )
142141, 60breqtrd 4119 . . . . . . . . . . . 12  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( ( N  mod  ( 2 ^ ( M  +  1 ) ) )  -  ( N  mod  ( 2 ^ M ) ) )  <  ( ( 2 ^ M )  x.  2 ) )
1437nnred 9199 . . . . . . . . . . . . 13  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
2  e.  RR )
144107, 143, 122ltdivmuld 10026 . . . . . . . . . . . 12  |-  ( ( 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 ) ) )
145142, 144mpbird 167 . . . . . . . . . . 11  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( ( ( N  mod  ( 2 ^ ( M  +  1 ) ) )  -  ( N  mod  ( 2 ^ M ) ) )  /  ( 2 ^ M ) )  <  2 )
146 elfzo2 10428 . . . . . . . . . . 11  |-  ( ( ( ( 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 ) )
147133, 47, 145, 146syl3anbrc 1208 . . . . . . . . . 10  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( ( ( N  mod  ( 2 ^ ( M  +  1 ) ) )  -  ( N  mod  ( 2 ^ M ) ) )  /  ( 2 ^ M ) )  e.  ( 0..^ 2 ) )
148 fzo0to2pr 10507 . . . . . . . . . 10  |-  ( 0..^ 2 )  =  {
0 ,  1 }
149147, 148eleqtrdi 2324 . . . . . . . . 9  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( ( ( N  mod  ( 2 ^ ( M  +  1 ) ) )  -  ( N  mod  ( 2 ^ M ) ) )  /  ( 2 ^ M ) )  e.  { 0 ,  1 } )
150 elpri 3696 . . . . . . . . 9  |-  ( ( ( ( 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 ) )
151149, 150syl 14 . . . . . . . 8  |-  ( ( 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 ) )
152151ord 732 . . . . . . 7  |-  ( ( 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 ) )
15395, 152syld 45 . . . . . 6  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( M  e.  (bits `  N )  ->  (
( ( N  mod  ( 2 ^ ( M  +  1 ) ) )  -  ( N  mod  ( 2 ^ M ) ) )  /  ( 2 ^ M ) )  =  1 ) )
154153imp 124 . . . . 5  |-  ( ( ( N  e.  ZZ  /\  M  e.  NN0 )  /\  M  e.  (bits `  N ) )  -> 
( ( ( N  mod  ( 2 ^ ( M  +  1 ) ) )  -  ( N  mod  ( 2 ^ M ) ) )  /  ( 2 ^ M ) )  =  1 )
15522, 26, 31, 154diveqap1d 9021 . . . 4  |-  ( ( ( N  e.  ZZ  /\  M  e.  NN0 )  /\  M  e.  (bits `  N ) )  -> 
( ( N  mod  ( 2 ^ ( M  +  1 ) ) )  -  ( N  mod  ( 2 ^ M ) ) )  =  ( 2 ^ M ) )
156155oveq2d 6044 . . 3  |-  ( ( ( 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 ) ) )
15720, 156eqtr3d 2266 . 2  |-  ( ( ( N  e.  ZZ  /\  M  e.  NN0 )  /\  M  e.  (bits `  N ) )  -> 
( N  mod  (
2 ^ ( M  +  1 ) ) )  =  ( ( N  mod  ( 2 ^ M ) )  +  ( 2 ^ M ) ) )
15818adantr 276 . . . 4  |-  ( ( ( N  e.  ZZ  /\  M  e.  NN0 )  /\  -.  M  e.  (bits `  N ) )  -> 
( N  mod  (
2 ^ ( M  +  1 ) ) )  e.  CC )
15911adantr 276 . . . 4  |-  ( ( ( N  e.  ZZ  /\  M  e.  NN0 )  /\  -.  M  e.  (bits `  N ) )  -> 
( N  mod  (
2 ^ M ) )  e.  CC )
16021adantr 276 . . . . 5  |-  ( ( ( N  e.  ZZ  /\  M  e.  NN0 )  /\  -.  M  e.  (bits `  N ) )  -> 
( ( N  mod  ( 2 ^ ( M  +  1 ) ) )  -  ( N  mod  ( 2 ^ M ) ) )  e.  CC )
16155adantr 276 . . . . 5  |-  ( ( ( N  e.  ZZ  /\  M  e.  NN0 )  /\  -.  M  e.  (bits `  N ) )  -> 
( 2 ^ M
)  e.  CC )
16230adantr 276 . . . . 5  |-  ( ( ( N  e.  ZZ  /\  M  e.  NN0 )  /\  -.  M  e.  (bits `  N ) )  -> 
( 2 ^ M
) #  0 )
16317nn0zd 9643 . . . . . . . . . 10  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( N  mod  (
2 ^ ( M  +  1 ) ) )  e.  ZZ )
16410nn0zd 9643 . . . . . . . . . 10  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( N  mod  (
2 ^ M ) )  e.  ZZ )
165163, 164zsubcld 9650 . . . . . . . . 9  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( ( N  mod  ( 2 ^ ( M  +  1 ) ) )  -  ( N  mod  ( 2 ^ M ) ) )  e.  ZZ )
166 znq 9901 . . . . . . . . 9  |-  ( ( ( ( N  mod  ( 2 ^ ( M  +  1 ) ) )  -  ( N  mod  ( 2 ^ M ) ) )  e.  ZZ  /\  (
2 ^ M )  e.  NN )  -> 
( ( ( N  mod  ( 2 ^ ( M  +  1 ) ) )  -  ( N  mod  ( 2 ^ M ) ) )  /  ( 2 ^ M ) )  e.  QQ )
167165, 9, 166syl2anc 411 . . . . . . . 8  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( ( ( N  mod  ( 2 ^ ( M  +  1 ) ) )  -  ( N  mod  ( 2 ^ M ) ) )  /  ( 2 ^ M ) )  e.  QQ )
168 0z 9533 . . . . . . . . 9  |-  0  e.  ZZ
169 zq 9903 . . . . . . . . 9  |-  ( 0  e.  ZZ  ->  0  e.  QQ )
170168, 169mp1i 10 . . . . . . . 8  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
0  e.  QQ )
171 qdceq 10548 . . . . . . . 8  |-  ( ( ( ( ( N  mod  ( 2 ^ ( M  +  1 ) ) )  -  ( N  mod  ( 2 ^ M ) ) )  /  ( 2 ^ M ) )  e.  QQ  /\  0  e.  QQ )  -> DECID  ( ( ( N  mod  ( 2 ^ ( M  +  1 ) ) )  -  ( N  mod  ( 2 ^ M ) ) )  /  ( 2 ^ M ) )  =  0 )
172167, 170, 171syl2anc 411 . . . . . . 7  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> DECID  (
( ( N  mod  ( 2 ^ ( M  +  1 ) ) )  -  ( N  mod  ( 2 ^ M ) ) )  /  ( 2 ^ M ) )  =  0 )
173 n2dvds1 12534 . . . . . . . . . 10  |-  -.  2  ||  1
174 breq2 4097 . . . . . . . . . 10  |-  ( ( ( ( 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 ) )
175173, 174mtbiri 682 . . . . . . . . 9  |-  ( ( ( ( N  mod  ( 2 ^ ( M  +  1 ) ) )  -  ( N  mod  ( 2 ^ M ) ) )  /  ( 2 ^ M ) )  =  1  ->  -.  2  ||  ( ( ( N  mod  ( 2 ^ ( M  +  1 ) ) )  -  ( N  mod  ( 2 ^ M ) ) )  /  ( 2 ^ M ) ) )
176152, 175syl6 33 . . . . . . . 8  |-  ( ( 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 ) ) ) )
177176, 91sylibrd 169 . . . . . . 7  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( -.  ( ( ( N  mod  (
2 ^ ( M  +  1 ) ) )  -  ( N  mod  ( 2 ^ M ) ) )  /  ( 2 ^ M ) )  =  0  ->  M  e.  (bits `  N ) ) )
178 con1dc 864 . . . . . . 7  |-  (DECID  ( ( ( N  mod  (
2 ^ ( M  +  1 ) ) )  -  ( N  mod  ( 2 ^ M ) ) )  /  ( 2 ^ M ) )  =  0  ->  ( ( -.  ( ( ( N  mod  ( 2 ^ ( M  +  1 ) ) )  -  ( N  mod  ( 2 ^ M ) ) )  /  ( 2 ^ M ) )  =  0  ->  M  e.  (bits `  N )
)  ->  ( -.  M  e.  (bits `  N
)  ->  ( (
( N  mod  (
2 ^ ( M  +  1 ) ) )  -  ( N  mod  ( 2 ^ M ) ) )  /  ( 2 ^ M ) )  =  0 ) ) )
179172, 177, 178sylc 62 . . . . . 6  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( -.  M  e.  (bits `  N )  ->  ( ( ( N  mod  ( 2 ^ ( M  +  1 ) ) )  -  ( N  mod  ( 2 ^ M ) ) )  /  ( 2 ^ M ) )  =  0 ) )
180179imp 124 . . . . 5  |-  ( ( ( N  e.  ZZ  /\  M  e.  NN0 )  /\  -.  M  e.  (bits `  N ) )  -> 
( ( ( N  mod  ( 2 ^ ( M  +  1 ) ) )  -  ( N  mod  ( 2 ^ M ) ) )  /  ( 2 ^ M ) )  =  0 )
181160, 161, 162, 180diveqap0d 9020 . . . 4  |-  ( ( ( N  e.  ZZ  /\  M  e.  NN0 )  /\  -.  M  e.  (bits `  N ) )  -> 
( ( N  mod  ( 2 ^ ( M  +  1 ) ) )  -  ( N  mod  ( 2 ^ M ) ) )  =  0 )
182158, 159, 181subeq0d 8541 . . 3  |-  ( ( ( N  e.  ZZ  /\  M  e.  NN0 )  /\  -.  M  e.  (bits `  N ) )  -> 
( N  mod  (
2 ^ ( M  +  1 ) ) )  =  ( N  mod  ( 2 ^ M ) ) )
183159addridd 8371 . . 3  |-  ( ( ( N  e.  ZZ  /\  M  e.  NN0 )  /\  -.  M  e.  (bits `  N ) )  -> 
( ( N  mod  ( 2 ^ M
) )  +  0 )  =  ( N  mod  ( 2 ^ M ) ) )
184182, 183eqtr4d 2267 . 2  |-  ( ( ( N  e.  ZZ  /\  M  e.  NN0 )  /\  -.  M  e.  (bits `  N ) )  -> 
( N  mod  (
2 ^ ( M  +  1 ) ) )  =  ( ( N  mod  ( 2 ^ M ) )  +  0 ) )
185 bitsdc 12569 . 2  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> DECID  M  e.  (bits `  N )
)
1862, 4, 157, 184, 185ifbothdadc 3643 1  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( N  mod  (
2 ^ ( M  +  1 ) ) )  =  ( ( N  mod  ( 2 ^ M ) )  +  if ( M  e.  (bits `  N
) ,  ( 2 ^ M ) ,  0 ) ) )
Colors of variables: wff set class
Syntax hints:   -. wn 3    -> wi 4    /\ wa 104    <-> wb 105    \/ wo 716  DECID wdc 842    = wceq 1398    e. wcel 2202   ifcif 3607   {cpr 3674   class class class wbr 4093   ` cfv 5333  (class class class)co 6028   CCcc 8073   RRcr 8074   0cc0 8075   1c1 8076    + caddc 8078    x. cmul 8080    < clt 8257    <_ cle 8258    - cmin 8393   -ucneg 8394   # cap 8804    / cdiv 8895   NNcn 9186   2c2 9237   NN0cn0 9445   ZZcz 9522   ZZ>=cuz 9798   QQcq 9896  ..^cfzo 10420   |_cfl 10572    mod cmo 10628   ^cexp 10844    || cdvds 12409  bitscbits 12562
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-ia1 106  ax-ia2 107  ax-ia3 108  ax-in1 619  ax-in2 620  ax-io 717  ax-5 1496  ax-7 1497  ax-gen 1498  ax-ie1 1542  ax-ie2 1543  ax-8 1553  ax-10 1554  ax-11 1555  ax-i12 1556  ax-bndl 1558  ax-4 1559  ax-17 1575  ax-i9 1579  ax-ial 1583  ax-i5r 1584  ax-13 2204  ax-14 2205  ax-ext 2213  ax-coll 4209  ax-sep 4212  ax-nul 4220  ax-pow 4270  ax-pr 4305  ax-un 4536  ax-setind 4641  ax-iinf 4692  ax-cnex 8166  ax-resscn 8167  ax-1cn 8168  ax-1re 8169  ax-icn 8170  ax-addcl 8171  ax-addrcl 8172  ax-mulcl 8173  ax-mulrcl 8174  ax-addcom 8175  ax-mulcom 8176  ax-addass 8177  ax-mulass 8178  ax-distr 8179  ax-i2m1 8180  ax-0lt1 8181  ax-1rid 8182  ax-0id 8183  ax-rnegex 8184  ax-precex 8185  ax-cnre 8186  ax-pre-ltirr 8187  ax-pre-ltwlin 8188  ax-pre-lttrn 8189  ax-pre-apti 8190  ax-pre-ltadd 8191  ax-pre-mulgt0 8192  ax-pre-mulext 8193  ax-arch 8194
This theorem depends on definitions:  df-bi 117  df-stab 839  df-dc 843  df-3or 1006  df-3an 1007  df-tru 1401  df-fal 1404  df-nf 1510  df-sb 1811  df-eu 2082  df-mo 2083  df-clab 2218  df-cleq 2224  df-clel 2227  df-nfc 2364  df-ne 2404  df-nel 2499  df-ral 2516  df-rex 2517  df-reu 2518  df-rmo 2519  df-rab 2520  df-v 2805  df-sbc 3033  df-csb 3129  df-dif 3203  df-un 3205  df-in 3207  df-ss 3214  df-nul 3497  df-if 3608  df-pw 3658  df-sn 3679  df-pr 3680  df-op 3682  df-uni 3899  df-int 3934  df-iun 3977  df-br 4094  df-opab 4156  df-mpt 4157  df-tr 4193  df-id 4396  df-po 4399  df-iso 4400  df-iord 4469  df-on 4471  df-ilim 4472  df-suc 4474  df-iom 4695  df-xp 4737  df-rel 4738  df-cnv 4739  df-co 4740  df-dm 4741  df-rn 4742  df-res 4743  df-ima 4744  df-iota 5293  df-fun 5335  df-fn 5336  df-f 5337  df-f1 5338  df-fo 5339  df-f1o 5340  df-fv 5341  df-riota 5981  df-ov 6031  df-oprab 6032  df-mpo 6033  df-1st 6312  df-2nd 6313  df-recs 6514  df-frec 6600  df-pnf 8259  df-mnf 8260  df-xr 8261  df-ltxr 8262  df-le 8263  df-sub 8395  df-neg 8396  df-reap 8798  df-ap 8805  df-div 8896  df-inn 9187  df-2 9245  df-n0 9446  df-z 9523  df-uz 9799  df-q 9897  df-rp 9932  df-fz 10287  df-fzo 10421  df-fl 10574  df-mod 10629  df-seqfrec 10754  df-exp 10845  df-dvds 12410  df-bits 12563
This theorem is referenced by:  bitsinv1  12584
  Copyright terms: Public domain W3C validator