MPE Home Metamath Proof Explorer < Previous   Next >
Nearby theorems
Mirrors  >  Home  >  MPE Home  >  Th. List  >  bitsmod Structured version   Visualization version   GIF version

Theorem bitsmod 16384
Description: Truncating the bit sequence after some 𝑀 is equivalent to reducing the argument mod 2↑𝑀. (Contributed by Mario Carneiro, 6-Sep-2016.)
Assertion
Ref Expression
bitsmod ((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) β†’ (bitsβ€˜(𝑁 mod (2↑𝑀))) = ((bitsβ€˜π‘) ∩ (0..^𝑀)))

Proof of Theorem bitsmod
Dummy variable π‘₯ is distinct from all other variables.
StepHypRef Expression
1 simpl 482 . . . . . . . 8 ((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) β†’ 𝑁 ∈ β„€)
2 2nn 12292 . . . . . . . . . 10 2 ∈ β„•
32a1i 11 . . . . . . . . 9 ((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) β†’ 2 ∈ β„•)
4 simpr 484 . . . . . . . . 9 ((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) β†’ 𝑀 ∈ β„•0)
53, 4nnexpcld 14215 . . . . . . . 8 ((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) β†’ (2↑𝑀) ∈ β„•)
61, 5zmodcld 13864 . . . . . . 7 ((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) β†’ (𝑁 mod (2↑𝑀)) ∈ β„•0)
76nn0zd 12591 . . . . . 6 ((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) β†’ (𝑁 mod (2↑𝑀)) ∈ β„€)
87biantrurd 532 . . . . 5 ((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) β†’ ((π‘₯ ∈ β„•0 ∧ Β¬ 2 βˆ₯ (βŒŠβ€˜((𝑁 mod (2↑𝑀)) / (2↑π‘₯)))) ↔ ((𝑁 mod (2↑𝑀)) ∈ β„€ ∧ (π‘₯ ∈ β„•0 ∧ Β¬ 2 βˆ₯ (βŒŠβ€˜((𝑁 mod (2↑𝑀)) / (2↑π‘₯)))))))
91ad2antrr 723 . . . . . . . . . . 11 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ 𝑁 ∈ β„€)
10 simplr 766 . . . . . . . . . . 11 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ π‘₯ ∈ β„•0)
11 bitsval2 16373 . . . . . . . . . . 11 ((𝑁 ∈ β„€ ∧ π‘₯ ∈ β„•0) β†’ (π‘₯ ∈ (bitsβ€˜π‘) ↔ Β¬ 2 βˆ₯ (βŒŠβ€˜(𝑁 / (2↑π‘₯)))))
129, 10, 11syl2anc 583 . . . . . . . . . 10 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ (π‘₯ ∈ (bitsβ€˜π‘) ↔ Β¬ 2 βˆ₯ (βŒŠβ€˜(𝑁 / (2↑π‘₯)))))
13 simpr 484 . . . . . . . . . . 11 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ π‘₯ < 𝑀)
1413biantrud 531 . . . . . . . . . 10 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ (π‘₯ ∈ (bitsβ€˜π‘) ↔ (π‘₯ ∈ (bitsβ€˜π‘) ∧ π‘₯ < 𝑀)))
15 2z 12601 . . . . . . . . . . . . 13 2 ∈ β„€
1615a1i 11 . . . . . . . . . . . 12 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ 2 ∈ β„€)
179zred 12673 . . . . . . . . . . . . . 14 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ 𝑁 ∈ ℝ)
182a1i 11 . . . . . . . . . . . . . . 15 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ 2 ∈ β„•)
1918, 10nnexpcld 14215 . . . . . . . . . . . . . 14 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ (2↑π‘₯) ∈ β„•)
2017, 19nndivred 12273 . . . . . . . . . . . . 13 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ (𝑁 / (2↑π‘₯)) ∈ ℝ)
2120flcld 13770 . . . . . . . . . . . 12 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ (βŒŠβ€˜(𝑁 / (2↑π‘₯))) ∈ β„€)
227ad2antrr 723 . . . . . . . . . . . . . . 15 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ (𝑁 mod (2↑𝑀)) ∈ β„€)
2322zred 12673 . . . . . . . . . . . . . 14 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ (𝑁 mod (2↑𝑀)) ∈ ℝ)
2423, 19nndivred 12273 . . . . . . . . . . . . 13 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ ((𝑁 mod (2↑𝑀)) / (2↑π‘₯)) ∈ ℝ)
2524flcld 13770 . . . . . . . . . . . 12 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ (βŒŠβ€˜((𝑁 mod (2↑𝑀)) / (2↑π‘₯))) ∈ β„€)
2619nnzd 12592 . . . . . . . . . . . . . . . . 17 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ (2↑π‘₯) ∈ β„€)
2726, 16zmulcld 12679 . . . . . . . . . . . . . . . 16 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ ((2↑π‘₯) Β· 2) ∈ β„€)
285ad2antrr 723 . . . . . . . . . . . . . . . . 17 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ (2↑𝑀) ∈ β„•)
2928nnzd 12592 . . . . . . . . . . . . . . . 16 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ (2↑𝑀) ∈ β„€)
309, 22zsubcld 12678 . . . . . . . . . . . . . . . 16 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ (𝑁 βˆ’ (𝑁 mod (2↑𝑀))) ∈ β„€)
31 2cnd 12297 . . . . . . . . . . . . . . . . . 18 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ 2 ∈ β„‚)
3231, 10expp1d 14119 . . . . . . . . . . . . . . . . 17 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ (2↑(π‘₯ + 1)) = ((2↑π‘₯) Β· 2))
33 1nn0 12495 . . . . . . . . . . . . . . . . . . . 20 1 ∈ β„•0
3433a1i 11 . . . . . . . . . . . . . . . . . . 19 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ 1 ∈ β„•0)
3510, 34nn0addcld 12543 . . . . . . . . . . . . . . . . . 18 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ (π‘₯ + 1) ∈ β„•0)
3635nn0zd 12591 . . . . . . . . . . . . . . . . . . 19 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ (π‘₯ + 1) ∈ β„€)
37 simplr 766 . . . . . . . . . . . . . . . . . . . . 21 (((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) β†’ 𝑀 ∈ β„•0)
3837adantr 480 . . . . . . . . . . . . . . . . . . . 20 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ 𝑀 ∈ β„•0)
3938nn0zd 12591 . . . . . . . . . . . . . . . . . . 19 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ 𝑀 ∈ β„€)
40 nn0ltp1le 12627 . . . . . . . . . . . . . . . . . . . . 21 ((π‘₯ ∈ β„•0 ∧ 𝑀 ∈ β„•0) β†’ (π‘₯ < 𝑀 ↔ (π‘₯ + 1) ≀ 𝑀))
4110, 38, 40syl2anc 583 . . . . . . . . . . . . . . . . . . . 20 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ (π‘₯ < 𝑀 ↔ (π‘₯ + 1) ≀ 𝑀))
4213, 41mpbid 231 . . . . . . . . . . . . . . . . . . 19 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ (π‘₯ + 1) ≀ 𝑀)
43 eluz2 12835 . . . . . . . . . . . . . . . . . . 19 (𝑀 ∈ (β„€β‰₯β€˜(π‘₯ + 1)) ↔ ((π‘₯ + 1) ∈ β„€ ∧ 𝑀 ∈ β„€ ∧ (π‘₯ + 1) ≀ 𝑀))
4436, 39, 42, 43syl3anbrc 1342 . . . . . . . . . . . . . . . . . 18 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ 𝑀 ∈ (β„€β‰₯β€˜(π‘₯ + 1)))
45 dvdsexp 16278 . . . . . . . . . . . . . . . . . 18 ((2 ∈ β„€ ∧ (π‘₯ + 1) ∈ β„•0 ∧ 𝑀 ∈ (β„€β‰₯β€˜(π‘₯ + 1))) β†’ (2↑(π‘₯ + 1)) βˆ₯ (2↑𝑀))
4616, 35, 44, 45syl3anc 1370 . . . . . . . . . . . . . . . . 17 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ (2↑(π‘₯ + 1)) βˆ₯ (2↑𝑀))
4732, 46eqbrtrrd 5172 . . . . . . . . . . . . . . . 16 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ ((2↑π‘₯) Β· 2) βˆ₯ (2↑𝑀))
4828nnrpd 13021 . . . . . . . . . . . . . . . . . 18 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ (2↑𝑀) ∈ ℝ+)
49 moddifz 13855 . . . . . . . . . . . . . . . . . 18 ((𝑁 ∈ ℝ ∧ (2↑𝑀) ∈ ℝ+) β†’ ((𝑁 βˆ’ (𝑁 mod (2↑𝑀))) / (2↑𝑀)) ∈ β„€)
5017, 48, 49syl2anc 583 . . . . . . . . . . . . . . . . 17 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ ((𝑁 βˆ’ (𝑁 mod (2↑𝑀))) / (2↑𝑀)) ∈ β„€)
51 2ne0 12323 . . . . . . . . . . . . . . . . . . . 20 2 β‰  0
5251a1i 11 . . . . . . . . . . . . . . . . . . 19 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ 2 β‰  0)
5331, 52, 39expne0d 14124 . . . . . . . . . . . . . . . . . 18 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ (2↑𝑀) β‰  0)
54 dvdsval2 16207 . . . . . . . . . . . . . . . . . 18 (((2↑𝑀) ∈ β„€ ∧ (2↑𝑀) β‰  0 ∧ (𝑁 βˆ’ (𝑁 mod (2↑𝑀))) ∈ β„€) β†’ ((2↑𝑀) βˆ₯ (𝑁 βˆ’ (𝑁 mod (2↑𝑀))) ↔ ((𝑁 βˆ’ (𝑁 mod (2↑𝑀))) / (2↑𝑀)) ∈ β„€))
5529, 53, 30, 54syl3anc 1370 . . . . . . . . . . . . . . . . 17 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ ((2↑𝑀) βˆ₯ (𝑁 βˆ’ (𝑁 mod (2↑𝑀))) ↔ ((𝑁 βˆ’ (𝑁 mod (2↑𝑀))) / (2↑𝑀)) ∈ β„€))
5650, 55mpbird 257 . . . . . . . . . . . . . . . 16 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ (2↑𝑀) βˆ₯ (𝑁 βˆ’ (𝑁 mod (2↑𝑀))))
5727, 29, 30, 47, 56dvdstrd 16245 . . . . . . . . . . . . . . 15 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ ((2↑π‘₯) Β· 2) βˆ₯ (𝑁 βˆ’ (𝑁 mod (2↑𝑀))))
5830zcnd 12674 . . . . . . . . . . . . . . . 16 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ (𝑁 βˆ’ (𝑁 mod (2↑𝑀))) ∈ β„‚)
5919nncnd 12235 . . . . . . . . . . . . . . . 16 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ (2↑π‘₯) ∈ β„‚)
6010nn0zd 12591 . . . . . . . . . . . . . . . . 17 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ π‘₯ ∈ β„€)
6131, 52, 60expne0d 14124 . . . . . . . . . . . . . . . 16 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ (2↑π‘₯) β‰  0)
6258, 59, 61divcan2d 11999 . . . . . . . . . . . . . . 15 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ ((2↑π‘₯) Β· ((𝑁 βˆ’ (𝑁 mod (2↑𝑀))) / (2↑π‘₯))) = (𝑁 βˆ’ (𝑁 mod (2↑𝑀))))
6357, 62breqtrrd 5176 . . . . . . . . . . . . . 14 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ ((2↑π‘₯) Β· 2) βˆ₯ ((2↑π‘₯) Β· ((𝑁 βˆ’ (𝑁 mod (2↑𝑀))) / (2↑π‘₯))))
6410nn0red 12540 . . . . . . . . . . . . . . . . . . . 20 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ π‘₯ ∈ ℝ)
6538nn0red 12540 . . . . . . . . . . . . . . . . . . . 20 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ 𝑀 ∈ ℝ)
6664, 65, 13ltled 11369 . . . . . . . . . . . . . . . . . . 19 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ π‘₯ ≀ 𝑀)
67 eluz2 12835 . . . . . . . . . . . . . . . . . . 19 (𝑀 ∈ (β„€β‰₯β€˜π‘₯) ↔ (π‘₯ ∈ β„€ ∧ 𝑀 ∈ β„€ ∧ π‘₯ ≀ 𝑀))
6860, 39, 66, 67syl3anbrc 1342 . . . . . . . . . . . . . . . . . 18 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ 𝑀 ∈ (β„€β‰₯β€˜π‘₯))
69 dvdsexp 16278 . . . . . . . . . . . . . . . . . 18 ((2 ∈ β„€ ∧ π‘₯ ∈ β„•0 ∧ 𝑀 ∈ (β„€β‰₯β€˜π‘₯)) β†’ (2↑π‘₯) βˆ₯ (2↑𝑀))
7016, 10, 68, 69syl3anc 1370 . . . . . . . . . . . . . . . . 17 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ (2↑π‘₯) βˆ₯ (2↑𝑀))
7126, 29, 30, 70, 56dvdstrd 16245 . . . . . . . . . . . . . . . 16 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ (2↑π‘₯) βˆ₯ (𝑁 βˆ’ (𝑁 mod (2↑𝑀))))
72 dvdsval2 16207 . . . . . . . . . . . . . . . . 17 (((2↑π‘₯) ∈ β„€ ∧ (2↑π‘₯) β‰  0 ∧ (𝑁 βˆ’ (𝑁 mod (2↑𝑀))) ∈ β„€) β†’ ((2↑π‘₯) βˆ₯ (𝑁 βˆ’ (𝑁 mod (2↑𝑀))) ↔ ((𝑁 βˆ’ (𝑁 mod (2↑𝑀))) / (2↑π‘₯)) ∈ β„€))
7326, 61, 30, 72syl3anc 1370 . . . . . . . . . . . . . . . 16 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ ((2↑π‘₯) βˆ₯ (𝑁 βˆ’ (𝑁 mod (2↑𝑀))) ↔ ((𝑁 βˆ’ (𝑁 mod (2↑𝑀))) / (2↑π‘₯)) ∈ β„€))
7471, 73mpbid 231 . . . . . . . . . . . . . . 15 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ ((𝑁 βˆ’ (𝑁 mod (2↑𝑀))) / (2↑π‘₯)) ∈ β„€)
75 dvdscmulr 16235 . . . . . . . . . . . . . . 15 ((2 ∈ β„€ ∧ ((𝑁 βˆ’ (𝑁 mod (2↑𝑀))) / (2↑π‘₯)) ∈ β„€ ∧ ((2↑π‘₯) ∈ β„€ ∧ (2↑π‘₯) β‰  0)) β†’ (((2↑π‘₯) Β· 2) βˆ₯ ((2↑π‘₯) Β· ((𝑁 βˆ’ (𝑁 mod (2↑𝑀))) / (2↑π‘₯))) ↔ 2 βˆ₯ ((𝑁 βˆ’ (𝑁 mod (2↑𝑀))) / (2↑π‘₯))))
7616, 74, 26, 61, 75syl112anc 1373 . . . . . . . . . . . . . 14 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ (((2↑π‘₯) Β· 2) βˆ₯ ((2↑π‘₯) Β· ((𝑁 βˆ’ (𝑁 mod (2↑𝑀))) / (2↑π‘₯))) ↔ 2 βˆ₯ ((𝑁 βˆ’ (𝑁 mod (2↑𝑀))) / (2↑π‘₯))))
7763, 76mpbid 231 . . . . . . . . . . . . 13 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ 2 βˆ₯ ((𝑁 βˆ’ (𝑁 mod (2↑𝑀))) / (2↑π‘₯)))
7825zcnd 12674 . . . . . . . . . . . . . 14 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ (βŒŠβ€˜((𝑁 mod (2↑𝑀)) / (2↑π‘₯))) ∈ β„‚)
7974zcnd 12674 . . . . . . . . . . . . . 14 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ ((𝑁 βˆ’ (𝑁 mod (2↑𝑀))) / (2↑π‘₯)) ∈ β„‚)
8022zcnd 12674 . . . . . . . . . . . . . . . . . . 19 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ (𝑁 mod (2↑𝑀)) ∈ β„‚)
819zcnd 12674 . . . . . . . . . . . . . . . . . . 19 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ 𝑁 ∈ β„‚)
8280, 81pncan3d 11581 . . . . . . . . . . . . . . . . . 18 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ ((𝑁 mod (2↑𝑀)) + (𝑁 βˆ’ (𝑁 mod (2↑𝑀)))) = 𝑁)
8382oveq1d 7427 . . . . . . . . . . . . . . . . 17 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ (((𝑁 mod (2↑𝑀)) + (𝑁 βˆ’ (𝑁 mod (2↑𝑀)))) / (2↑π‘₯)) = (𝑁 / (2↑π‘₯)))
8480, 58, 59, 61divdird 12035 . . . . . . . . . . . . . . . . 17 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ (((𝑁 mod (2↑𝑀)) + (𝑁 βˆ’ (𝑁 mod (2↑𝑀)))) / (2↑π‘₯)) = (((𝑁 mod (2↑𝑀)) / (2↑π‘₯)) + ((𝑁 βˆ’ (𝑁 mod (2↑𝑀))) / (2↑π‘₯))))
8583, 84eqtr3d 2773 . . . . . . . . . . . . . . . 16 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ (𝑁 / (2↑π‘₯)) = (((𝑁 mod (2↑𝑀)) / (2↑π‘₯)) + ((𝑁 βˆ’ (𝑁 mod (2↑𝑀))) / (2↑π‘₯))))
8685fveq2d 6895 . . . . . . . . . . . . . . 15 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ (βŒŠβ€˜(𝑁 / (2↑π‘₯))) = (βŒŠβ€˜(((𝑁 mod (2↑𝑀)) / (2↑π‘₯)) + ((𝑁 βˆ’ (𝑁 mod (2↑𝑀))) / (2↑π‘₯)))))
87 fladdz 13797 . . . . . . . . . . . . . . . 16 ((((𝑁 mod (2↑𝑀)) / (2↑π‘₯)) ∈ ℝ ∧ ((𝑁 βˆ’ (𝑁 mod (2↑𝑀))) / (2↑π‘₯)) ∈ β„€) β†’ (βŒŠβ€˜(((𝑁 mod (2↑𝑀)) / (2↑π‘₯)) + ((𝑁 βˆ’ (𝑁 mod (2↑𝑀))) / (2↑π‘₯)))) = ((βŒŠβ€˜((𝑁 mod (2↑𝑀)) / (2↑π‘₯))) + ((𝑁 βˆ’ (𝑁 mod (2↑𝑀))) / (2↑π‘₯))))
8824, 74, 87syl2anc 583 . . . . . . . . . . . . . . 15 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ (βŒŠβ€˜(((𝑁 mod (2↑𝑀)) / (2↑π‘₯)) + ((𝑁 βˆ’ (𝑁 mod (2↑𝑀))) / (2↑π‘₯)))) = ((βŒŠβ€˜((𝑁 mod (2↑𝑀)) / (2↑π‘₯))) + ((𝑁 βˆ’ (𝑁 mod (2↑𝑀))) / (2↑π‘₯))))
8986, 88eqtrd 2771 . . . . . . . . . . . . . 14 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ (βŒŠβ€˜(𝑁 / (2↑π‘₯))) = ((βŒŠβ€˜((𝑁 mod (2↑𝑀)) / (2↑π‘₯))) + ((𝑁 βˆ’ (𝑁 mod (2↑𝑀))) / (2↑π‘₯))))
9078, 79, 89mvrladdd 11634 . . . . . . . . . . . . 13 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ ((βŒŠβ€˜(𝑁 / (2↑π‘₯))) βˆ’ (βŒŠβ€˜((𝑁 mod (2↑𝑀)) / (2↑π‘₯)))) = ((𝑁 βˆ’ (𝑁 mod (2↑𝑀))) / (2↑π‘₯)))
9177, 90breqtrrd 5176 . . . . . . . . . . . 12 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ 2 βˆ₯ ((βŒŠβ€˜(𝑁 / (2↑π‘₯))) βˆ’ (βŒŠβ€˜((𝑁 mod (2↑𝑀)) / (2↑π‘₯)))))
92 dvdssub2 16251 . . . . . . . . . . . 12 (((2 ∈ β„€ ∧ (βŒŠβ€˜(𝑁 / (2↑π‘₯))) ∈ β„€ ∧ (βŒŠβ€˜((𝑁 mod (2↑𝑀)) / (2↑π‘₯))) ∈ β„€) ∧ 2 βˆ₯ ((βŒŠβ€˜(𝑁 / (2↑π‘₯))) βˆ’ (βŒŠβ€˜((𝑁 mod (2↑𝑀)) / (2↑π‘₯))))) β†’ (2 βˆ₯ (βŒŠβ€˜(𝑁 / (2↑π‘₯))) ↔ 2 βˆ₯ (βŒŠβ€˜((𝑁 mod (2↑𝑀)) / (2↑π‘₯)))))
9316, 21, 25, 91, 92syl31anc 1372 . . . . . . . . . . 11 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ (2 βˆ₯ (βŒŠβ€˜(𝑁 / (2↑π‘₯))) ↔ 2 βˆ₯ (βŒŠβ€˜((𝑁 mod (2↑𝑀)) / (2↑π‘₯)))))
9493notbid 318 . . . . . . . . . 10 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ (Β¬ 2 βˆ₯ (βŒŠβ€˜(𝑁 / (2↑π‘₯))) ↔ Β¬ 2 βˆ₯ (βŒŠβ€˜((𝑁 mod (2↑𝑀)) / (2↑π‘₯)))))
9512, 14, 943bitr3d 309 . . . . . . . . 9 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ ((π‘₯ ∈ (bitsβ€˜π‘) ∧ π‘₯ < 𝑀) ↔ Β¬ 2 βˆ₯ (βŒŠβ€˜((𝑁 mod (2↑𝑀)) / (2↑π‘₯)))))
96 z0even 16317 . . . . . . . . . . . 12 2 βˆ₯ 0
971ad2antrr 723 . . . . . . . . . . . . . . . 16 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ Β¬ π‘₯ < 𝑀) β†’ 𝑁 ∈ β„€)
9897zred 12673 . . . . . . . . . . . . . . 15 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ Β¬ π‘₯ < 𝑀) β†’ 𝑁 ∈ ℝ)
99 2rp 12986 . . . . . . . . . . . . . . . . 17 2 ∈ ℝ+
10099a1i 11 . . . . . . . . . . . . . . . 16 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ Β¬ π‘₯ < 𝑀) β†’ 2 ∈ ℝ+)
10137nn0zd 12591 . . . . . . . . . . . . . . . . 17 (((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) β†’ 𝑀 ∈ β„€)
102101adantr 480 . . . . . . . . . . . . . . . 16 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ Β¬ π‘₯ < 𝑀) β†’ 𝑀 ∈ β„€)
103100, 102rpexpcld 14217 . . . . . . . . . . . . . . 15 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ Β¬ π‘₯ < 𝑀) β†’ (2↑𝑀) ∈ ℝ+)
10498, 103modcld 13847 . . . . . . . . . . . . . 14 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ Β¬ π‘₯ < 𝑀) β†’ (𝑁 mod (2↑𝑀)) ∈ ℝ)
105 simplr 766 . . . . . . . . . . . . . . . 16 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ Β¬ π‘₯ < 𝑀) β†’ π‘₯ ∈ β„•0)
106105nn0zd 12591 . . . . . . . . . . . . . . 15 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ Β¬ π‘₯ < 𝑀) β†’ π‘₯ ∈ β„€)
107100, 106rpexpcld 14217 . . . . . . . . . . . . . 14 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ Β¬ π‘₯ < 𝑀) β†’ (2↑π‘₯) ∈ ℝ+)
1086ad2antrr 723 . . . . . . . . . . . . . . 15 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ Β¬ π‘₯ < 𝑀) β†’ (𝑁 mod (2↑𝑀)) ∈ β„•0)
109108nn0ge0d 12542 . . . . . . . . . . . . . 14 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ Β¬ π‘₯ < 𝑀) β†’ 0 ≀ (𝑁 mod (2↑𝑀)))
110104, 107, 109divge0d 13063 . . . . . . . . . . . . 13 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ Β¬ π‘₯ < 𝑀) β†’ 0 ≀ ((𝑁 mod (2↑𝑀)) / (2↑π‘₯)))
111103rpred 13023 . . . . . . . . . . . . . . . . 17 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ Β¬ π‘₯ < 𝑀) β†’ (2↑𝑀) ∈ ℝ)
112107rpred 13023 . . . . . . . . . . . . . . . . 17 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ Β¬ π‘₯ < 𝑀) β†’ (2↑π‘₯) ∈ ℝ)
113 modlt 13852 . . . . . . . . . . . . . . . . . 18 ((𝑁 ∈ ℝ ∧ (2↑𝑀) ∈ ℝ+) β†’ (𝑁 mod (2↑𝑀)) < (2↑𝑀))
11498, 103, 113syl2anc 583 . . . . . . . . . . . . . . . . 17 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ Β¬ π‘₯ < 𝑀) β†’ (𝑁 mod (2↑𝑀)) < (2↑𝑀))
115100rpred 13023 . . . . . . . . . . . . . . . . . 18 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ Β¬ π‘₯ < 𝑀) β†’ 2 ∈ ℝ)
116 1le2 12428 . . . . . . . . . . . . . . . . . . 19 1 ≀ 2
117116a1i 11 . . . . . . . . . . . . . . . . . 18 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ Β¬ π‘₯ < 𝑀) β†’ 1 ≀ 2)
118102zred 12673 . . . . . . . . . . . . . . . . . . . 20 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ Β¬ π‘₯ < 𝑀) β†’ 𝑀 ∈ ℝ)
119105nn0red 12540 . . . . . . . . . . . . . . . . . . . 20 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ Β¬ π‘₯ < 𝑀) β†’ π‘₯ ∈ ℝ)
120 simpr 484 . . . . . . . . . . . . . . . . . . . 20 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ Β¬ π‘₯ < 𝑀) β†’ Β¬ π‘₯ < 𝑀)
121118, 119, 120nltled 11371 . . . . . . . . . . . . . . . . . . 19 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ Β¬ π‘₯ < 𝑀) β†’ 𝑀 ≀ π‘₯)
122 eluz2 12835 . . . . . . . . . . . . . . . . . . 19 (π‘₯ ∈ (β„€β‰₯β€˜π‘€) ↔ (𝑀 ∈ β„€ ∧ π‘₯ ∈ β„€ ∧ 𝑀 ≀ π‘₯))
123102, 106, 121, 122syl3anbrc 1342 . . . . . . . . . . . . . . . . . 18 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ Β¬ π‘₯ < 𝑀) β†’ π‘₯ ∈ (β„€β‰₯β€˜π‘€))
124115, 117, 123leexp2ad 14224 . . . . . . . . . . . . . . . . 17 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ Β¬ π‘₯ < 𝑀) β†’ (2↑𝑀) ≀ (2↑π‘₯))
125104, 111, 112, 114, 124ltletrd 11381 . . . . . . . . . . . . . . . 16 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ Β¬ π‘₯ < 𝑀) β†’ (𝑁 mod (2↑𝑀)) < (2↑π‘₯))
126107rpcnd 13025 . . . . . . . . . . . . . . . . 17 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ Β¬ π‘₯ < 𝑀) β†’ (2↑π‘₯) ∈ β„‚)
127126mulridd 11238 . . . . . . . . . . . . . . . 16 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ Β¬ π‘₯ < 𝑀) β†’ ((2↑π‘₯) Β· 1) = (2↑π‘₯))
128125, 127breqtrrd 5176 . . . . . . . . . . . . . . 15 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ Β¬ π‘₯ < 𝑀) β†’ (𝑁 mod (2↑𝑀)) < ((2↑π‘₯) Β· 1))
129 1red 11222 . . . . . . . . . . . . . . . 16 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ Β¬ π‘₯ < 𝑀) β†’ 1 ∈ ℝ)
130104, 129, 107ltdivmuld 13074 . . . . . . . . . . . . . . 15 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ Β¬ π‘₯ < 𝑀) β†’ (((𝑁 mod (2↑𝑀)) / (2↑π‘₯)) < 1 ↔ (𝑁 mod (2↑𝑀)) < ((2↑π‘₯) Β· 1)))
131128, 130mpbird 257 . . . . . . . . . . . . . 14 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ Β¬ π‘₯ < 𝑀) β†’ ((𝑁 mod (2↑𝑀)) / (2↑π‘₯)) < 1)
132 1e0p1 12726 . . . . . . . . . . . . . 14 1 = (0 + 1)
133131, 132breqtrdi 5189 . . . . . . . . . . . . 13 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ Β¬ π‘₯ < 𝑀) β†’ ((𝑁 mod (2↑𝑀)) / (2↑π‘₯)) < (0 + 1))
134104, 107rerpdivcld 13054 . . . . . . . . . . . . . 14 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ Β¬ π‘₯ < 𝑀) β†’ ((𝑁 mod (2↑𝑀)) / (2↑π‘₯)) ∈ ℝ)
135 0z 12576 . . . . . . . . . . . . . 14 0 ∈ β„€
136 flbi 13788 . . . . . . . . . . . . . 14 ((((𝑁 mod (2↑𝑀)) / (2↑π‘₯)) ∈ ℝ ∧ 0 ∈ β„€) β†’ ((βŒŠβ€˜((𝑁 mod (2↑𝑀)) / (2↑π‘₯))) = 0 ↔ (0 ≀ ((𝑁 mod (2↑𝑀)) / (2↑π‘₯)) ∧ ((𝑁 mod (2↑𝑀)) / (2↑π‘₯)) < (0 + 1))))
137134, 135, 136sylancl 585 . . . . . . . . . . . . 13 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ Β¬ π‘₯ < 𝑀) β†’ ((βŒŠβ€˜((𝑁 mod (2↑𝑀)) / (2↑π‘₯))) = 0 ↔ (0 ≀ ((𝑁 mod (2↑𝑀)) / (2↑π‘₯)) ∧ ((𝑁 mod (2↑𝑀)) / (2↑π‘₯)) < (0 + 1))))
138110, 133, 137mpbir2and 710 . . . . . . . . . . . 12 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ Β¬ π‘₯ < 𝑀) β†’ (βŒŠβ€˜((𝑁 mod (2↑𝑀)) / (2↑π‘₯))) = 0)
13996, 138breqtrrid 5186 . . . . . . . . . . 11 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ Β¬ π‘₯ < 𝑀) β†’ 2 βˆ₯ (βŒŠβ€˜((𝑁 mod (2↑𝑀)) / (2↑π‘₯))))
140120intnand 488 . . . . . . . . . . 11 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ Β¬ π‘₯ < 𝑀) β†’ Β¬ (π‘₯ ∈ (bitsβ€˜π‘) ∧ π‘₯ < 𝑀))
141139, 1402thd 265 . . . . . . . . . 10 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ Β¬ π‘₯ < 𝑀) β†’ (2 βˆ₯ (βŒŠβ€˜((𝑁 mod (2↑𝑀)) / (2↑π‘₯))) ↔ Β¬ (π‘₯ ∈ (bitsβ€˜π‘) ∧ π‘₯ < 𝑀)))
142141con2bid 354 . . . . . . . . 9 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ Β¬ π‘₯ < 𝑀) β†’ ((π‘₯ ∈ (bitsβ€˜π‘) ∧ π‘₯ < 𝑀) ↔ Β¬ 2 βˆ₯ (βŒŠβ€˜((𝑁 mod (2↑𝑀)) / (2↑π‘₯)))))
14395, 142pm2.61dan 810 . . . . . . . 8 (((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) β†’ ((π‘₯ ∈ (bitsβ€˜π‘) ∧ π‘₯ < 𝑀) ↔ Β¬ 2 βˆ₯ (βŒŠβ€˜((𝑁 mod (2↑𝑀)) / (2↑π‘₯)))))
144101biantrurd 532 . . . . . . . 8 (((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) β†’ ((π‘₯ ∈ (bitsβ€˜π‘) ∧ π‘₯ < 𝑀) ↔ (𝑀 ∈ β„€ ∧ (π‘₯ ∈ (bitsβ€˜π‘) ∧ π‘₯ < 𝑀))))
145143, 144bitr3d 281 . . . . . . 7 (((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) β†’ (Β¬ 2 βˆ₯ (βŒŠβ€˜((𝑁 mod (2↑𝑀)) / (2↑π‘₯))) ↔ (𝑀 ∈ β„€ ∧ (π‘₯ ∈ (bitsβ€˜π‘) ∧ π‘₯ < 𝑀))))
146 an12 642 . . . . . . 7 ((𝑀 ∈ β„€ ∧ (π‘₯ ∈ (bitsβ€˜π‘) ∧ π‘₯ < 𝑀)) ↔ (π‘₯ ∈ (bitsβ€˜π‘) ∧ (𝑀 ∈ β„€ ∧ π‘₯ < 𝑀)))
147145, 146bitrdi 287 . . . . . 6 (((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) β†’ (Β¬ 2 βˆ₯ (βŒŠβ€˜((𝑁 mod (2↑𝑀)) / (2↑π‘₯))) ↔ (π‘₯ ∈ (bitsβ€˜π‘) ∧ (𝑀 ∈ β„€ ∧ π‘₯ < 𝑀))))
148147pm5.32da 578 . . . . 5 ((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) β†’ ((π‘₯ ∈ β„•0 ∧ Β¬ 2 βˆ₯ (βŒŠβ€˜((𝑁 mod (2↑𝑀)) / (2↑π‘₯)))) ↔ (π‘₯ ∈ β„•0 ∧ (π‘₯ ∈ (bitsβ€˜π‘) ∧ (𝑀 ∈ β„€ ∧ π‘₯ < 𝑀)))))
1498, 148bitr3d 281 . . . 4 ((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) β†’ (((𝑁 mod (2↑𝑀)) ∈ β„€ ∧ (π‘₯ ∈ β„•0 ∧ Β¬ 2 βˆ₯ (βŒŠβ€˜((𝑁 mod (2↑𝑀)) / (2↑π‘₯))))) ↔ (π‘₯ ∈ β„•0 ∧ (π‘₯ ∈ (bitsβ€˜π‘) ∧ (𝑀 ∈ β„€ ∧ π‘₯ < 𝑀)))))
150 3anass 1094 . . . 4 (((𝑁 mod (2↑𝑀)) ∈ β„€ ∧ π‘₯ ∈ β„•0 ∧ Β¬ 2 βˆ₯ (βŒŠβ€˜((𝑁 mod (2↑𝑀)) / (2↑π‘₯)))) ↔ ((𝑁 mod (2↑𝑀)) ∈ β„€ ∧ (π‘₯ ∈ β„•0 ∧ Β¬ 2 βˆ₯ (βŒŠβ€˜((𝑁 mod (2↑𝑀)) / (2↑π‘₯))))))
151 elfzo2 13642 . . . . . . 7 (π‘₯ ∈ (0..^𝑀) ↔ (π‘₯ ∈ (β„€β‰₯β€˜0) ∧ 𝑀 ∈ β„€ ∧ π‘₯ < 𝑀))
152 elnn0uz 12874 . . . . . . . 8 (π‘₯ ∈ β„•0 ↔ π‘₯ ∈ (β„€β‰₯β€˜0))
1531523anbi1i 1156 . . . . . . 7 ((π‘₯ ∈ β„•0 ∧ 𝑀 ∈ β„€ ∧ π‘₯ < 𝑀) ↔ (π‘₯ ∈ (β„€β‰₯β€˜0) ∧ 𝑀 ∈ β„€ ∧ π‘₯ < 𝑀))
154 3anass 1094 . . . . . . 7 ((π‘₯ ∈ β„•0 ∧ 𝑀 ∈ β„€ ∧ π‘₯ < 𝑀) ↔ (π‘₯ ∈ β„•0 ∧ (𝑀 ∈ β„€ ∧ π‘₯ < 𝑀)))
155151, 153, 1543bitr2i 299 . . . . . 6 (π‘₯ ∈ (0..^𝑀) ↔ (π‘₯ ∈ β„•0 ∧ (𝑀 ∈ β„€ ∧ π‘₯ < 𝑀)))
156155anbi2i 622 . . . . 5 ((π‘₯ ∈ (bitsβ€˜π‘) ∧ π‘₯ ∈ (0..^𝑀)) ↔ (π‘₯ ∈ (bitsβ€˜π‘) ∧ (π‘₯ ∈ β„•0 ∧ (𝑀 ∈ β„€ ∧ π‘₯ < 𝑀))))
157 an12 642 . . . . 5 ((π‘₯ ∈ (bitsβ€˜π‘) ∧ (π‘₯ ∈ β„•0 ∧ (𝑀 ∈ β„€ ∧ π‘₯ < 𝑀))) ↔ (π‘₯ ∈ β„•0 ∧ (π‘₯ ∈ (bitsβ€˜π‘) ∧ (𝑀 ∈ β„€ ∧ π‘₯ < 𝑀))))
158156, 157bitri 275 . . . 4 ((π‘₯ ∈ (bitsβ€˜π‘) ∧ π‘₯ ∈ (0..^𝑀)) ↔ (π‘₯ ∈ β„•0 ∧ (π‘₯ ∈ (bitsβ€˜π‘) ∧ (𝑀 ∈ β„€ ∧ π‘₯ < 𝑀))))
159149, 150, 1583bitr4g 314 . . 3 ((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) β†’ (((𝑁 mod (2↑𝑀)) ∈ β„€ ∧ π‘₯ ∈ β„•0 ∧ Β¬ 2 βˆ₯ (βŒŠβ€˜((𝑁 mod (2↑𝑀)) / (2↑π‘₯)))) ↔ (π‘₯ ∈ (bitsβ€˜π‘) ∧ π‘₯ ∈ (0..^𝑀))))
160 bitsval 16372 . . 3 (π‘₯ ∈ (bitsβ€˜(𝑁 mod (2↑𝑀))) ↔ ((𝑁 mod (2↑𝑀)) ∈ β„€ ∧ π‘₯ ∈ β„•0 ∧ Β¬ 2 βˆ₯ (βŒŠβ€˜((𝑁 mod (2↑𝑀)) / (2↑π‘₯)))))
161 elin 3964 . . 3 (π‘₯ ∈ ((bitsβ€˜π‘) ∩ (0..^𝑀)) ↔ (π‘₯ ∈ (bitsβ€˜π‘) ∧ π‘₯ ∈ (0..^𝑀)))
162159, 160, 1613bitr4g 314 . 2 ((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) β†’ (π‘₯ ∈ (bitsβ€˜(𝑁 mod (2↑𝑀))) ↔ π‘₯ ∈ ((bitsβ€˜π‘) ∩ (0..^𝑀))))
163162eqrdv 2729 1 ((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) β†’ (bitsβ€˜(𝑁 mod (2↑𝑀))) = ((bitsβ€˜π‘) ∩ (0..^𝑀)))
Colors of variables: wff setvar class
Syntax hints:  Β¬ wn 3   β†’ wi 4   ↔ wb 205   ∧ wa 395   ∧ w3a 1086   = wceq 1540   ∈ wcel 2105   β‰  wne 2939   ∩ cin 3947   class class class wbr 5148  β€˜cfv 6543  (class class class)co 7412  β„cr 11115  0cc0 11116  1c1 11117   + caddc 11119   Β· cmul 11121   < clt 11255   ≀ cle 11256   βˆ’ cmin 11451   / cdiv 11878  β„•cn 12219  2c2 12274  β„•0cn0 12479  β„€cz 12565  β„€β‰₯cuz 12829  β„+crp 12981  ..^cfzo 13634  βŒŠcfl 13762   mod cmo 13841  β†‘cexp 14034   βˆ₯ cdvds 16204  bitscbits 16367
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-3 8  ax-gen 1796  ax-4 1810  ax-5 1912  ax-6 1970  ax-7 2010  ax-8 2107  ax-9 2115  ax-10 2136  ax-11 2153  ax-12 2170  ax-ext 2702  ax-sep 5299  ax-nul 5306  ax-pow 5363  ax-pr 5427  ax-un 7729  ax-cnex 11172  ax-resscn 11173  ax-1cn 11174  ax-icn 11175  ax-addcl 11176  ax-addrcl 11177  ax-mulcl 11178  ax-mulrcl 11179  ax-mulcom 11180  ax-addass 11181  ax-mulass 11182  ax-distr 11183  ax-i2m1 11184  ax-1ne0 11185  ax-1rid 11186  ax-rnegex 11187  ax-rrecex 11188  ax-cnre 11189  ax-pre-lttri 11190  ax-pre-lttrn 11191  ax-pre-ltadd 11192  ax-pre-mulgt0 11193  ax-pre-sup 11194
This theorem depends on definitions:  df-bi 206  df-an 396  df-or 845  df-3or 1087  df-3an 1088  df-tru 1543  df-fal 1553  df-ex 1781  df-nf 1785  df-sb 2067  df-mo 2533  df-eu 2562  df-clab 2709  df-cleq 2723  df-clel 2809  df-nfc 2884  df-ne 2940  df-nel 3046  df-ral 3061  df-rex 3070  df-rmo 3375  df-reu 3376  df-rab 3432  df-v 3475  df-sbc 3778  df-csb 3894  df-dif 3951  df-un 3953  df-in 3955  df-ss 3965  df-pss 3967  df-nul 4323  df-if 4529  df-pw 4604  df-sn 4629  df-pr 4631  df-op 4635  df-uni 4909  df-iun 4999  df-br 5149  df-opab 5211  df-mpt 5232  df-tr 5266  df-id 5574  df-eprel 5580  df-po 5588  df-so 5589  df-fr 5631  df-we 5633  df-xp 5682  df-rel 5683  df-cnv 5684  df-co 5685  df-dm 5686  df-rn 5687  df-res 5688  df-ima 5689  df-pred 6300  df-ord 6367  df-on 6368  df-lim 6369  df-suc 6370  df-iota 6495  df-fun 6545  df-fn 6546  df-f 6547  df-f1 6548  df-fo 6549  df-f1o 6550  df-fv 6551  df-riota 7368  df-ov 7415  df-oprab 7416  df-mpo 7417  df-om 7860  df-1st 7979  df-2nd 7980  df-frecs 8272  df-wrecs 8303  df-recs 8377  df-rdg 8416  df-er 8709  df-en 8946  df-dom 8947  df-sdom 8948  df-sup 9443  df-inf 9444  df-pnf 11257  df-mnf 11258  df-xr 11259  df-ltxr 11260  df-le 11261  df-sub 11453  df-neg 11454  df-div 11879  df-nn 12220  df-2 12282  df-n0 12480  df-z 12566  df-uz 12830  df-rp 12982  df-fz 13492  df-fzo 13635  df-fl 13764  df-mod 13842  df-seq 13974  df-exp 14035  df-dvds 16205  df-bits 16370
This theorem is referenced by:  sadaddlem  16414  sadadd  16415  bitsres  16421  smumul  16441
  Copyright terms: Public domain W3C validator