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

Theorem bitsinv1lem 12672
Description: Lemma for bitsinv1 12673. (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 6066 . . 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 2246 . 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 6066 . . 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 2246 . 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 9416 . . . . . . . . 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 11082 . . . . . . 7  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( 2 ^ M
)  e.  NN )
105, 9zmodcld 10731 . . . . . 6  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( N  mod  (
2 ^ M ) )  e.  NN0 )
1110nn0cnd 9572 . . . . 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 9529 . . . . . . . . . 10  |-  1  e.  NN0
1413a1i 9 . . . . . . . . 9  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
1  e.  NN0 )
158, 14nn0addcld 9574 . . . . . . . 8  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( M  +  1 )  e.  NN0 )
167, 15nnexpcld 11082 . . . . . . 7  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( 2 ^ ( M  +  1 ) )  e.  NN )
175, 16zmodcld 10731 . . . . . 6  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( N  mod  (
2 ^ ( M  +  1 ) ) )  e.  NN0 )
1817nn0cnd 9572 . . . . 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 8603 . . 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 8600 . . . . . 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 11082 . . . . . 6  |-  ( ( ( N  e.  ZZ  /\  M  e.  NN0 )  /\  M  e.  (bits `  N ) )  -> 
( 2 ^ M
)  e.  NN )
2625nncnd 9268 . . . . 5  |-  ( ( ( N  e.  ZZ  /\  M  e.  NN0 )  /\  M  e.  (bits `  N ) )  -> 
( 2 ^ M
)  e.  CC )
27 2cnd 9327 . . . . . . 7  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
2  e.  CC )
287nnap0d 9300 . . . . . . 7  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
2 #  0 )
298nn0zd 9716 . . . . . . 7  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  ->  M  e.  ZZ )
3027, 28, 29expap0d 11066 . . . . . 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 12622 . . . . . . . . . 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 4152 . . . . . . . . 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 12655 . . . . . . . . . . . 12  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( M  e.  (bits `  N )  <->  -.  2  ||  ( |_ `  ( N  /  ( 2 ^ M ) ) ) ) )
36 zq 9976 . . . . . . . . . . . . . . . . 17  |-  ( N  e.  ZZ  ->  N  e.  QQ )
3736adantr 276 . . . . . . . . . . . . . . . 16  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  ->  N  e.  QQ )
38 2z 9622 . . . . . . . . . . . . . . . . . 18  |-  2  e.  ZZ
39 zq 9976 . . . . . . . . . . . . . . . . . 18  |-  ( 2  e.  ZZ  ->  2  e.  QQ )
4038, 39ax-mp 5 . . . . . . . . . . . . . . . . 17  |-  2  e.  QQ
41 qexpcl 10941 . . . . . . . . . . . . . . . . 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 9298 . . . . . . . . . . . . . . . 16  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
0  <  ( 2 ^ M ) )
44 modqdiffl 10721 . . . . . . . . . . . . . . . 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 4126 . . . . . . . . . . . . . 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 10722 . . . . . . . . . . . . . . . 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 9719 . . . . . . . . . . . . . . . . . . 19  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  ->  N  e.  CC )
5150, 11, 18nnncan1d 8634 . . . . . . . . . . . . . . . . . 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 6073 . . . . . . . . . . . . . . . . 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 8600 . . . . . . . . . . . . . . . . . 18  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( N  -  ( N  mod  ( 2 ^ M ) ) )  e.  CC )
5450, 18subcld 8600 . . . . . . . . . . . . . . . . . 18  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( N  -  ( N  mod  ( 2 ^ ( M  +  1 ) ) ) )  e.  CC )
559nncnd 9268 . . . . . . . . . . . . . . . . . 18  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( 2 ^ M
)  e.  CC )
5653, 54, 55, 30divsubdirapd 9121 . . . . . . . . . . . . . . . . 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 2269 . . . . . . . . . . . . . . . 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 8311 . . . . . . . . . . . . . . . . . . . 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 8311 . . . . . . . . . . . . . . . . . . . . 21  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( 2  x.  (
2 ^ M ) )  =  ( ( 2 ^ M )  x.  2 ) )
6027, 8expp1d 11061 . . . . . . . . . . . . . . . . . . . . 21  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( 2 ^ ( M  +  1 ) )  =  ( ( 2 ^ M )  x.  2 ) )
6159, 60eqtr4d 2270 . . . . . . . . . . . . . . . . . . . 20  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( 2  x.  (
2 ^ M ) )  =  ( 2 ^ ( M  + 
1 ) ) )
6258, 61oveq12d 6076 . . . . . . . . . . . . . . . . . . 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 9347 . . . . . . . . . . . . . . . . . . . . 21  |-  2 #  0
6463a1i 9 . . . . . . . . . . . . . . . . . . . 20  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
2 #  0 )
6554, 55, 27, 30, 64divcanap5d 9108 . . . . . . . . . . . . . . . . . . 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 9268 . . . . . . . . . . . . . . . . . . . 20  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( 2 ^ ( M  +  1 ) )  e.  CC )
6729peano2zd 9721 . . . . . . . . . . . . . . . . . . . . 21  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( M  +  1 )  e.  ZZ )
6827, 28, 67expap0d 11066 . . . . . . . . . . . . . . . . . . . 20  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( 2 ^ ( M  +  1 ) ) #  0 )
6954, 27, 66, 68div23apd 9119 . . . . . . . . . . . . . . . . . . 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 2275 . . . . . . . . . . . . . . . . . 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 10941 . . . . . . . . . . . . . . . . . . . . 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 9298 . . . . . . . . . . . . . . . . . . . 20  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
0  <  ( 2 ^ ( M  + 
1 ) ) )
74 modqdifz 10722 . . . . . . . . . . . . . . . . . . . 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 9724 . . . . . . . . . . . . . . . . . 18  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( ( ( N  -  ( N  mod  ( 2 ^ ( M  +  1 ) ) ) )  / 
( 2 ^ ( M  +  1 ) ) )  x.  2 )  e.  ZZ )
7770, 76eqeltrd 2311 . . . . . . . . . . . . . . . . 17  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( ( N  -  ( N  mod  ( 2 ^ ( M  + 
1 ) ) ) )  /  ( 2 ^ M ) )  e.  ZZ )
7849, 77zsubcld 9723 . . . . . . . . . . . . . . . 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 2311 . . . . . . . . . . . . . . 15  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( ( ( N  mod  ( 2 ^ ( M  +  1 ) ) )  -  ( N  mod  ( 2 ^ M ) ) )  /  ( 2 ^ M ) )  e.  ZZ )
80 dvdsmul2 12525 . . . . . . . . . . . . . . . . 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 8635 . . . . . . . . . . . . . . . . . 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 6073 . . . . . . . . . . . . . . . . 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 9121 . . . . . . . . . . . . . . . . 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 2275 . . . . . . . . . . . . . . . 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 4142 . . . . . . . . . . . . . . 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 12546 . . . . . . . . . . . . . . 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 8463 . . . . . . . . . . . . . . 15  |-  -u 1  =  ( 0  -  1 )
9755mulm1d 8700 . . . . . . . . . . . . . . . . 17  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( -u 1  x.  (
2 ^ M ) )  =  -u (
2 ^ M ) )
989nnred 9267 . . . . . . . . . . . . . . . . . . 19  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( 2 ^ M
)  e.  RR )
9998renegcld 8670 . . . . . . . . . . . . . . . . . 18  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  ->  -u ( 2 ^ M
)  e.  RR )
10037, 42, 43modqcld 10714 . . . . . . . . . . . . . . . . . . . 20  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( N  mod  (
2 ^ M ) )  e.  QQ )
101 qre 9975 . . . . . . . . . . . . . . . . . . . 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 8670 . . . . . . . . . . . . . . . . . 18  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  ->  -u ( N  mod  (
2 ^ M ) )  e.  RR )
10437, 72, 73modqcld 10714 . . . . . . . . . . . . . . . . . . . 20  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( N  mod  (
2 ^ ( M  +  1 ) ) )  e.  QQ )
105 qre 9975 . . . . . . . . . . . . . . . . . . . 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 8671 . . . . . . . . . . . . . . . . . 18  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( ( N  mod  ( 2 ^ ( M  +  1 ) ) )  -  ( N  mod  ( 2 ^ M ) ) )  e.  RR )
108 modqlt 10719 . . . . . . . . . . . . . . . . . . . 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 8814 . . . . . . . . . . . . . . . . . . 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 8463 . . . . . . . . . . . . . . . . . . 19  |-  -u ( N  mod  ( 2 ^ M ) )  =  ( 0  -  ( N  mod  ( 2 ^ M ) ) )
113 0red 8291 . . . . . . . . . . . . . . . . . . . 20  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
0  e.  RR )
114 modqge0 10718 . . . . . . . . . . . . . . . . . . . . 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 8852 . . . . . . . . . . . . . . . . . . 19  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( 0  -  ( N  mod  ( 2 ^ M ) ) )  <_  ( ( N  mod  ( 2 ^ ( M  +  1 ) ) )  -  ( N  mod  ( 2 ^ M ) ) ) )
117112, 116eqbrtrid 4149 . . . . . . . . . . . . . . . . . 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 8714 . . . . . . . . . . . . . . . . 17  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  ->  -u ( 2 ^ M
)  <  ( ( N  mod  ( 2 ^ ( M  +  1 ) ) )  -  ( N  mod  ( 2 ^ M ) ) ) )
11997, 118eqbrtrd 4136 . . . . . . . . . . . . . . . 16  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( -u 1  x.  (
2 ^ M ) )  <  ( ( N  mod  ( 2 ^ ( M  + 
1 ) ) )  -  ( N  mod  ( 2 ^ M
) ) ) )
120 1red 8305 . . . . . . . . . . . . . . . . . 18  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
1  e.  RR )
121120renegcld 8670 . . . . . . . . . . . . . . . . 17  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  ->  -u 1  e.  RR )
1229nnrpd 10045 . . . . . . . . . . . . . . . . 17  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( 2 ^ M
)  e.  RR+ )
123121, 107, 122ltmuldivd 10095 . . . . . . . . . . . . . . . 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 4150 . . . . . . . . . . . . . 14  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( 0  -  1 )  <  ( ( ( N  mod  (
2 ^ ( M  +  1 ) ) )  -  ( N  mod  ( 2 ^ M ) ) )  /  ( 2 ^ M ) ) )
126 0zd 9606 . . . . . . . . . . . . . . 15  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
0  e.  ZZ )
127 zlem1lt 9651 . . . . . . . . . . . . . . 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 9607 . . . . . . . . . . . . 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 9907 . . . . . . . . . . . 12  |-  NN0  =  ( ZZ>= `  0 )
133131, 132eleqtrdi 2327 . . . . . . . . . . 11  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( ( ( N  mod  ( 2 ^ ( M  +  1 ) ) )  -  ( N  mod  ( 2 ^ M ) ) )  /  ( 2 ^ M ) )  e.  ( ZZ>= `  0
) )
13416nnred 9267 . . . . . . . . . . . . . 14  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( 2 ^ ( M  +  1 ) )  e.  RR )
135 modqge0 10718 . . . . . . . . . . . . . . . 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 8828 . . . . . . . . . . . . . . 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 10719 . . . . . . . . . . . . . . 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 8414 . . . . . . . . . . . . 13  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( ( N  mod  ( 2 ^ ( M  +  1 ) ) )  -  ( N  mod  ( 2 ^ M ) ) )  <  ( 2 ^ ( M  +  1 ) ) )
142141, 60breqtrd 4140 . . . . . . . . . . . 12  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( ( N  mod  ( 2 ^ ( M  +  1 ) ) )  -  ( N  mod  ( 2 ^ M ) ) )  <  ( ( 2 ^ M )  x.  2 ) )
1437nnred 9267 . . . . . . . . . . . . 13  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
2  e.  RR )
144107, 143, 122ltdivmuld 10099 . . . . . . . . . . . 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 10506 . . . . . . . . . . 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 10585 . . . . . . . . . 10  |-  ( 0..^ 2 )  =  {
0 ,  1 }
149147, 148eleqtrdi 2327 . . . . . . . . 9  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( ( ( N  mod  ( 2 ^ ( M  +  1 ) ) )  -  ( N  mod  ( 2 ^ M ) ) )  /  ( 2 ^ M ) )  e.  { 0 ,  1 } )
150 elpri 3717 . . . . . . . . 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 9089 . . . 4  |-  ( ( ( N  e.  ZZ  /\  M  e.  NN0 )  /\  M  e.  (bits `  N ) )  -> 
( ( N  mod  ( 2 ^ ( M  +  1 ) ) )  -  ( N  mod  ( 2 ^ M ) ) )  =  ( 2 ^ M ) )
156155oveq2d 6074 . . 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 2269 . 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 9716 . . . . . . . . . 10  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( N  mod  (
2 ^ ( M  +  1 ) ) )  e.  ZZ )
16410nn0zd 9716 . . . . . . . . . 10  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( N  mod  (
2 ^ M ) )  e.  ZZ )
165163, 164zsubcld 9723 . . . . . . . . 9  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
( ( N  mod  ( 2 ^ ( M  +  1 ) ) )  -  ( N  mod  ( 2 ^ M ) ) )  e.  ZZ )
166 znq 9974 . . . . . . . . 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 9605 . . . . . . . . 9  |-  0  e.  ZZ
169 zq 9976 . . . . . . . . 9  |-  ( 0  e.  ZZ  ->  0  e.  QQ )
170168, 169mp1i 10 . . . . . . . 8  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> 
0  e.  QQ )
171 qdceq 10628 . . . . . . . 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 12623 . . . . . . . . . 10  |-  -.  2  ||  1
174 breq2 4118 . . . . . . . . . 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 9088 . . . 4  |-  ( ( ( N  e.  ZZ  /\  M  e.  NN0 )  /\  -.  M  e.  (bits `  N ) )  -> 
( ( N  mod  ( 2 ^ ( M  +  1 ) ) )  -  ( N  mod  ( 2 ^ M ) ) )  =  0 )
182158, 159, 181subeq0d 8608 . . 3  |-  ( ( ( N  e.  ZZ  /\  M  e.  NN0 )  /\  -.  M  e.  (bits `  N ) )  -> 
( N  mod  (
2 ^ ( M  +  1 ) ) )  =  ( N  mod  ( 2 ^ M ) ) )
183159addridd 8438 . . 3  |-  ( ( ( N  e.  ZZ  /\  M  e.  NN0 )  /\  -.  M  e.  (bits `  N ) )  -> 
( ( N  mod  ( 2 ^ M
) )  +  0 )  =  ( N  mod  ( 2 ^ M ) ) )
184182, 183eqtr4d 2270 . 2  |-  ( ( ( N  e.  ZZ  /\  M  e.  NN0 )  /\  -.  M  e.  (bits `  N ) )  -> 
( N  mod  (
2 ^ ( M  +  1 ) ) )  =  ( ( N  mod  ( 2 ^ M ) )  +  0 ) )
185 bitsdc 12658 . 2  |-  ( ( N  e.  ZZ  /\  M  e.  NN0 )  -> DECID  M  e.  (bits `  N )
)
1862, 4, 157, 184, 185ifbothdadc 3660 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 2205   ifcif 3624   {cpr 3695   class class class wbr 4114   ` cfv 5357  (class class class)co 6058   CCcc 8141   RRcr 8142   0cc0 8143   1c1 8144    + caddc 8146    x. cmul 8148    < clt 8324    <_ cle 8325    - cmin 8460   -ucneg 8461   # cap 8872    / cdiv 8963   NNcn 9254   2c2 9305   NN0cn0 9513   ZZcz 9594   ZZ>=cuz 9871   QQcq 9969  ..^cfzo 10498   |_cfl 10652    mod cmo 10708   ^cexp 10924    || cdvds 12498  bitscbits 12651
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 2207  ax-14 2208  ax-ext 2216  ax-coll 4230  ax-sep 4233  ax-nul 4241  ax-pow 4292  ax-pr 4327  ax-un 4559  ax-setind 4664  ax-iinf 4715  ax-cnex 8234  ax-resscn 8235  ax-1cn 8236  ax-1re 8237  ax-icn 8238  ax-addcl 8239  ax-addrcl 8240  ax-mulcl 8241  ax-mulrcl 8242  ax-addcom 8243  ax-mulcom 8244  ax-addass 8245  ax-mulass 8246  ax-distr 8247  ax-i2m1 8248  ax-0lt1 8249  ax-1rid 8250  ax-0id 8251  ax-rnegex 8252  ax-precex 8253  ax-cnre 8254  ax-pre-ltirr 8255  ax-pre-ltwlin 8256  ax-pre-lttrn 8257  ax-pre-apti 8258  ax-pre-ltadd 8259  ax-pre-mulgt0 8260  ax-pre-mulext 8261  ax-arch 8262
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 1812  df-eu 2085  df-mo 2086  df-clab 2221  df-cleq 2227  df-clel 2230  df-nfc 2375  df-ne 2415  df-nel 2510  df-ral 2527  df-rex 2528  df-reu 2529  df-rmo 2530  df-rab 2531  df-v 2817  df-sbc 3046  df-csb 3142  df-dif 3216  df-un 3218  df-in 3220  df-ss 3227  df-nul 3513  df-if 3625  df-pw 3676  df-sn 3700  df-pr 3701  df-op 3703  df-uni 3920  df-int 3955  df-iun 3998  df-br 4115  df-opab 4177  df-mpt 4178  df-tr 4214  df-id 4419  df-po 4422  df-iso 4423  df-iord 4492  df-on 4494  df-ilim 4495  df-suc 4497  df-iom 4718  df-xp 4760  df-rel 4761  df-cnv 4762  df-co 4763  df-dm 4764  df-rn 4765  df-res 4766  df-ima 4767  df-iota 5317  df-fun 5359  df-fn 5360  df-f 5361  df-f1 5362  df-fo 5363  df-f1o 5364  df-fv 5365  df-riota 6011  df-ov 6061  df-oprab 6062  df-mpo 6063  df-1st 6347  df-2nd 6348  df-recs 6549  df-frec 6635  df-pnf 8326  df-mnf 8327  df-xr 8328  df-ltxr 8329  df-le 8330  df-sub 8462  df-neg 8463  df-reap 8866  df-ap 8873  df-div 8964  df-inn 9255  df-2 9313  df-n0 9514  df-z 9595  df-uz 9872  df-q 9970  df-rp 10005  df-fz 10362  df-fzo 10499  df-fl 10654  df-mod 10709  df-seqfrec 10834  df-exp 10925  df-dvds 12499  df-bits 12652
This theorem is referenced by:  bitsinv1  12673
  Copyright terms: Public domain W3C validator