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

Theorem bitsmod 16373
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 483 . . . . . . . 8 ((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) β†’ 𝑁 ∈ β„€)
2 2nn 12281 . . . . . . . . . 10 2 ∈ β„•
32a1i 11 . . . . . . . . 9 ((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) β†’ 2 ∈ β„•)
4 simpr 485 . . . . . . . . 9 ((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) β†’ 𝑀 ∈ β„•0)
53, 4nnexpcld 14204 . . . . . . . 8 ((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) β†’ (2↑𝑀) ∈ β„•)
61, 5zmodcld 13853 . . . . . . 7 ((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) β†’ (𝑁 mod (2↑𝑀)) ∈ β„•0)
76nn0zd 12580 . . . . . 6 ((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) β†’ (𝑁 mod (2↑𝑀)) ∈ β„€)
87biantrurd 533 . . . . 5 ((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) β†’ ((π‘₯ ∈ β„•0 ∧ Β¬ 2 βˆ₯ (βŒŠβ€˜((𝑁 mod (2↑𝑀)) / (2↑π‘₯)))) ↔ ((𝑁 mod (2↑𝑀)) ∈ β„€ ∧ (π‘₯ ∈ β„•0 ∧ Β¬ 2 βˆ₯ (βŒŠβ€˜((𝑁 mod (2↑𝑀)) / (2↑π‘₯)))))))
91ad2antrr 724 . . . . . . . . . . 11 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ 𝑁 ∈ β„€)
10 simplr 767 . . . . . . . . . . 11 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ π‘₯ ∈ β„•0)
11 bitsval2 16362 . . . . . . . . . . 11 ((𝑁 ∈ β„€ ∧ π‘₯ ∈ β„•0) β†’ (π‘₯ ∈ (bitsβ€˜π‘) ↔ Β¬ 2 βˆ₯ (βŒŠβ€˜(𝑁 / (2↑π‘₯)))))
129, 10, 11syl2anc 584 . . . . . . . . . 10 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ (π‘₯ ∈ (bitsβ€˜π‘) ↔ Β¬ 2 βˆ₯ (βŒŠβ€˜(𝑁 / (2↑π‘₯)))))
13 simpr 485 . . . . . . . . . . 11 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ π‘₯ < 𝑀)
1413biantrud 532 . . . . . . . . . 10 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ (π‘₯ ∈ (bitsβ€˜π‘) ↔ (π‘₯ ∈ (bitsβ€˜π‘) ∧ π‘₯ < 𝑀)))
15 2z 12590 . . . . . . . . . . . . 13 2 ∈ β„€
1615a1i 11 . . . . . . . . . . . 12 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ 2 ∈ β„€)
179zred 12662 . . . . . . . . . . . . . 14 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ 𝑁 ∈ ℝ)
182a1i 11 . . . . . . . . . . . . . . 15 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ 2 ∈ β„•)
1918, 10nnexpcld 14204 . . . . . . . . . . . . . 14 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ (2↑π‘₯) ∈ β„•)
2017, 19nndivred 12262 . . . . . . . . . . . . 13 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ (𝑁 / (2↑π‘₯)) ∈ ℝ)
2120flcld 13759 . . . . . . . . . . . 12 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ (βŒŠβ€˜(𝑁 / (2↑π‘₯))) ∈ β„€)
227ad2antrr 724 . . . . . . . . . . . . . . 15 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ (𝑁 mod (2↑𝑀)) ∈ β„€)
2322zred 12662 . . . . . . . . . . . . . 14 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ (𝑁 mod (2↑𝑀)) ∈ ℝ)
2423, 19nndivred 12262 . . . . . . . . . . . . 13 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ ((𝑁 mod (2↑𝑀)) / (2↑π‘₯)) ∈ ℝ)
2524flcld 13759 . . . . . . . . . . . 12 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ (βŒŠβ€˜((𝑁 mod (2↑𝑀)) / (2↑π‘₯))) ∈ β„€)
2619nnzd 12581 . . . . . . . . . . . . . . . . 17 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ (2↑π‘₯) ∈ β„€)
2726, 16zmulcld 12668 . . . . . . . . . . . . . . . 16 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ ((2↑π‘₯) Β· 2) ∈ β„€)
285ad2antrr 724 . . . . . . . . . . . . . . . . 17 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ (2↑𝑀) ∈ β„•)
2928nnzd 12581 . . . . . . . . . . . . . . . 16 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ (2↑𝑀) ∈ β„€)
309, 22zsubcld 12667 . . . . . . . . . . . . . . . 16 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ (𝑁 βˆ’ (𝑁 mod (2↑𝑀))) ∈ β„€)
31 2cnd 12286 . . . . . . . . . . . . . . . . . 18 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ 2 ∈ β„‚)
3231, 10expp1d 14108 . . . . . . . . . . . . . . . . 17 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ (2↑(π‘₯ + 1)) = ((2↑π‘₯) Β· 2))
33 1nn0 12484 . . . . . . . . . . . . . . . . . . . 20 1 ∈ β„•0
3433a1i 11 . . . . . . . . . . . . . . . . . . 19 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ 1 ∈ β„•0)
3510, 34nn0addcld 12532 . . . . . . . . . . . . . . . . . 18 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ (π‘₯ + 1) ∈ β„•0)
3635nn0zd 12580 . . . . . . . . . . . . . . . . . . 19 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ (π‘₯ + 1) ∈ β„€)
37 simplr 767 . . . . . . . . . . . . . . . . . . . . 21 (((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) β†’ 𝑀 ∈ β„•0)
3837adantr 481 . . . . . . . . . . . . . . . . . . . 20 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ 𝑀 ∈ β„•0)
3938nn0zd 12580 . . . . . . . . . . . . . . . . . . 19 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ 𝑀 ∈ β„€)
40 nn0ltp1le 12616 . . . . . . . . . . . . . . . . . . . . 21 ((π‘₯ ∈ β„•0 ∧ 𝑀 ∈ β„•0) β†’ (π‘₯ < 𝑀 ↔ (π‘₯ + 1) ≀ 𝑀))
4110, 38, 40syl2anc 584 . . . . . . . . . . . . . . . . . . . 20 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ (π‘₯ < 𝑀 ↔ (π‘₯ + 1) ≀ 𝑀))
4213, 41mpbid 231 . . . . . . . . . . . . . . . . . . 19 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ (π‘₯ + 1) ≀ 𝑀)
43 eluz2 12824 . . . . . . . . . . . . . . . . . . 19 (𝑀 ∈ (β„€β‰₯β€˜(π‘₯ + 1)) ↔ ((π‘₯ + 1) ∈ β„€ ∧ 𝑀 ∈ β„€ ∧ (π‘₯ + 1) ≀ 𝑀))
4436, 39, 42, 43syl3anbrc 1343 . . . . . . . . . . . . . . . . . 18 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ 𝑀 ∈ (β„€β‰₯β€˜(π‘₯ + 1)))
45 dvdsexp 16267 . . . . . . . . . . . . . . . . . 18 ((2 ∈ β„€ ∧ (π‘₯ + 1) ∈ β„•0 ∧ 𝑀 ∈ (β„€β‰₯β€˜(π‘₯ + 1))) β†’ (2↑(π‘₯ + 1)) βˆ₯ (2↑𝑀))
4616, 35, 44, 45syl3anc 1371 . . . . . . . . . . . . . . . . 17 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ (2↑(π‘₯ + 1)) βˆ₯ (2↑𝑀))
4732, 46eqbrtrrd 5171 . . . . . . . . . . . . . . . 16 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ ((2↑π‘₯) Β· 2) βˆ₯ (2↑𝑀))
4828nnrpd 13010 . . . . . . . . . . . . . . . . . 18 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ (2↑𝑀) ∈ ℝ+)
49 moddifz 13844 . . . . . . . . . . . . . . . . . 18 ((𝑁 ∈ ℝ ∧ (2↑𝑀) ∈ ℝ+) β†’ ((𝑁 βˆ’ (𝑁 mod (2↑𝑀))) / (2↑𝑀)) ∈ β„€)
5017, 48, 49syl2anc 584 . . . . . . . . . . . . . . . . 17 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ ((𝑁 βˆ’ (𝑁 mod (2↑𝑀))) / (2↑𝑀)) ∈ β„€)
51 2ne0 12312 . . . . . . . . . . . . . . . . . . . 20 2 β‰  0
5251a1i 11 . . . . . . . . . . . . . . . . . . 19 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ 2 β‰  0)
5331, 52, 39expne0d 14113 . . . . . . . . . . . . . . . . . 18 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ (2↑𝑀) β‰  0)
54 dvdsval2 16196 . . . . . . . . . . . . . . . . . 18 (((2↑𝑀) ∈ β„€ ∧ (2↑𝑀) β‰  0 ∧ (𝑁 βˆ’ (𝑁 mod (2↑𝑀))) ∈ β„€) β†’ ((2↑𝑀) βˆ₯ (𝑁 βˆ’ (𝑁 mod (2↑𝑀))) ↔ ((𝑁 βˆ’ (𝑁 mod (2↑𝑀))) / (2↑𝑀)) ∈ β„€))
5529, 53, 30, 54syl3anc 1371 . . . . . . . . . . . . . . . . 17 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ ((2↑𝑀) βˆ₯ (𝑁 βˆ’ (𝑁 mod (2↑𝑀))) ↔ ((𝑁 βˆ’ (𝑁 mod (2↑𝑀))) / (2↑𝑀)) ∈ β„€))
5650, 55mpbird 256 . . . . . . . . . . . . . . . 16 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ (2↑𝑀) βˆ₯ (𝑁 βˆ’ (𝑁 mod (2↑𝑀))))
5727, 29, 30, 47, 56dvdstrd 16234 . . . . . . . . . . . . . . 15 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ ((2↑π‘₯) Β· 2) βˆ₯ (𝑁 βˆ’ (𝑁 mod (2↑𝑀))))
5830zcnd 12663 . . . . . . . . . . . . . . . 16 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ (𝑁 βˆ’ (𝑁 mod (2↑𝑀))) ∈ β„‚)
5919nncnd 12224 . . . . . . . . . . . . . . . 16 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ (2↑π‘₯) ∈ β„‚)
6010nn0zd 12580 . . . . . . . . . . . . . . . . 17 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ π‘₯ ∈ β„€)
6131, 52, 60expne0d 14113 . . . . . . . . . . . . . . . 16 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ (2↑π‘₯) β‰  0)
6258, 59, 61divcan2d 11988 . . . . . . . . . . . . . . 15 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ ((2↑π‘₯) Β· ((𝑁 βˆ’ (𝑁 mod (2↑𝑀))) / (2↑π‘₯))) = (𝑁 βˆ’ (𝑁 mod (2↑𝑀))))
6357, 62breqtrrd 5175 . . . . . . . . . . . . . 14 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ ((2↑π‘₯) Β· 2) βˆ₯ ((2↑π‘₯) Β· ((𝑁 βˆ’ (𝑁 mod (2↑𝑀))) / (2↑π‘₯))))
6410nn0red 12529 . . . . . . . . . . . . . . . . . . . 20 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ π‘₯ ∈ ℝ)
6538nn0red 12529 . . . . . . . . . . . . . . . . . . . 20 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ 𝑀 ∈ ℝ)
6664, 65, 13ltled 11358 . . . . . . . . . . . . . . . . . . 19 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ π‘₯ ≀ 𝑀)
67 eluz2 12824 . . . . . . . . . . . . . . . . . . 19 (𝑀 ∈ (β„€β‰₯β€˜π‘₯) ↔ (π‘₯ ∈ β„€ ∧ 𝑀 ∈ β„€ ∧ π‘₯ ≀ 𝑀))
6860, 39, 66, 67syl3anbrc 1343 . . . . . . . . . . . . . . . . . 18 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ 𝑀 ∈ (β„€β‰₯β€˜π‘₯))
69 dvdsexp 16267 . . . . . . . . . . . . . . . . . 18 ((2 ∈ β„€ ∧ π‘₯ ∈ β„•0 ∧ 𝑀 ∈ (β„€β‰₯β€˜π‘₯)) β†’ (2↑π‘₯) βˆ₯ (2↑𝑀))
7016, 10, 68, 69syl3anc 1371 . . . . . . . . . . . . . . . . 17 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ (2↑π‘₯) βˆ₯ (2↑𝑀))
7126, 29, 30, 70, 56dvdstrd 16234 . . . . . . . . . . . . . . . 16 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ (2↑π‘₯) βˆ₯ (𝑁 βˆ’ (𝑁 mod (2↑𝑀))))
72 dvdsval2 16196 . . . . . . . . . . . . . . . . 17 (((2↑π‘₯) ∈ β„€ ∧ (2↑π‘₯) β‰  0 ∧ (𝑁 βˆ’ (𝑁 mod (2↑𝑀))) ∈ β„€) β†’ ((2↑π‘₯) βˆ₯ (𝑁 βˆ’ (𝑁 mod (2↑𝑀))) ↔ ((𝑁 βˆ’ (𝑁 mod (2↑𝑀))) / (2↑π‘₯)) ∈ β„€))
7326, 61, 30, 72syl3anc 1371 . . . . . . . . . . . . . . . 16 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ ((2↑π‘₯) βˆ₯ (𝑁 βˆ’ (𝑁 mod (2↑𝑀))) ↔ ((𝑁 βˆ’ (𝑁 mod (2↑𝑀))) / (2↑π‘₯)) ∈ β„€))
7471, 73mpbid 231 . . . . . . . . . . . . . . 15 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ ((𝑁 βˆ’ (𝑁 mod (2↑𝑀))) / (2↑π‘₯)) ∈ β„€)
75 dvdscmulr 16224 . . . . . . . . . . . . . . 15 ((2 ∈ β„€ ∧ ((𝑁 βˆ’ (𝑁 mod (2↑𝑀))) / (2↑π‘₯)) ∈ β„€ ∧ ((2↑π‘₯) ∈ β„€ ∧ (2↑π‘₯) β‰  0)) β†’ (((2↑π‘₯) Β· 2) βˆ₯ ((2↑π‘₯) Β· ((𝑁 βˆ’ (𝑁 mod (2↑𝑀))) / (2↑π‘₯))) ↔ 2 βˆ₯ ((𝑁 βˆ’ (𝑁 mod (2↑𝑀))) / (2↑π‘₯))))
7616, 74, 26, 61, 75syl112anc 1374 . . . . . . . . . . . . . 14 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ (((2↑π‘₯) Β· 2) βˆ₯ ((2↑π‘₯) Β· ((𝑁 βˆ’ (𝑁 mod (2↑𝑀))) / (2↑π‘₯))) ↔ 2 βˆ₯ ((𝑁 βˆ’ (𝑁 mod (2↑𝑀))) / (2↑π‘₯))))
7763, 76mpbid 231 . . . . . . . . . . . . 13 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ 2 βˆ₯ ((𝑁 βˆ’ (𝑁 mod (2↑𝑀))) / (2↑π‘₯)))
7825zcnd 12663 . . . . . . . . . . . . . 14 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ (βŒŠβ€˜((𝑁 mod (2↑𝑀)) / (2↑π‘₯))) ∈ β„‚)
7974zcnd 12663 . . . . . . . . . . . . . 14 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ ((𝑁 βˆ’ (𝑁 mod (2↑𝑀))) / (2↑π‘₯)) ∈ β„‚)
8022zcnd 12663 . . . . . . . . . . . . . . . . . . 19 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ (𝑁 mod (2↑𝑀)) ∈ β„‚)
819zcnd 12663 . . . . . . . . . . . . . . . . . . 19 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ 𝑁 ∈ β„‚)
8280, 81pncan3d 11570 . . . . . . . . . . . . . . . . . 18 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ ((𝑁 mod (2↑𝑀)) + (𝑁 βˆ’ (𝑁 mod (2↑𝑀)))) = 𝑁)
8382oveq1d 7420 . . . . . . . . . . . . . . . . 17 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ (((𝑁 mod (2↑𝑀)) + (𝑁 βˆ’ (𝑁 mod (2↑𝑀)))) / (2↑π‘₯)) = (𝑁 / (2↑π‘₯)))
8480, 58, 59, 61divdird 12024 . . . . . . . . . . . . . . . . 17 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ (((𝑁 mod (2↑𝑀)) + (𝑁 βˆ’ (𝑁 mod (2↑𝑀)))) / (2↑π‘₯)) = (((𝑁 mod (2↑𝑀)) / (2↑π‘₯)) + ((𝑁 βˆ’ (𝑁 mod (2↑𝑀))) / (2↑π‘₯))))
8583, 84eqtr3d 2774 . . . . . . . . . . . . . . . 16 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ (𝑁 / (2↑π‘₯)) = (((𝑁 mod (2↑𝑀)) / (2↑π‘₯)) + ((𝑁 βˆ’ (𝑁 mod (2↑𝑀))) / (2↑π‘₯))))
8685fveq2d 6892 . . . . . . . . . . . . . . 15 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ (βŒŠβ€˜(𝑁 / (2↑π‘₯))) = (βŒŠβ€˜(((𝑁 mod (2↑𝑀)) / (2↑π‘₯)) + ((𝑁 βˆ’ (𝑁 mod (2↑𝑀))) / (2↑π‘₯)))))
87 fladdz 13786 . . . . . . . . . . . . . . . 16 ((((𝑁 mod (2↑𝑀)) / (2↑π‘₯)) ∈ ℝ ∧ ((𝑁 βˆ’ (𝑁 mod (2↑𝑀))) / (2↑π‘₯)) ∈ β„€) β†’ (βŒŠβ€˜(((𝑁 mod (2↑𝑀)) / (2↑π‘₯)) + ((𝑁 βˆ’ (𝑁 mod (2↑𝑀))) / (2↑π‘₯)))) = ((βŒŠβ€˜((𝑁 mod (2↑𝑀)) / (2↑π‘₯))) + ((𝑁 βˆ’ (𝑁 mod (2↑𝑀))) / (2↑π‘₯))))
8824, 74, 87syl2anc 584 . . . . . . . . . . . . . . 15 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ (βŒŠβ€˜(((𝑁 mod (2↑𝑀)) / (2↑π‘₯)) + ((𝑁 βˆ’ (𝑁 mod (2↑𝑀))) / (2↑π‘₯)))) = ((βŒŠβ€˜((𝑁 mod (2↑𝑀)) / (2↑π‘₯))) + ((𝑁 βˆ’ (𝑁 mod (2↑𝑀))) / (2↑π‘₯))))
8986, 88eqtrd 2772 . . . . . . . . . . . . . 14 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ (βŒŠβ€˜(𝑁 / (2↑π‘₯))) = ((βŒŠβ€˜((𝑁 mod (2↑𝑀)) / (2↑π‘₯))) + ((𝑁 βˆ’ (𝑁 mod (2↑𝑀))) / (2↑π‘₯))))
9078, 79, 89mvrladdd 11623 . . . . . . . . . . . . 13 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ ((βŒŠβ€˜(𝑁 / (2↑π‘₯))) βˆ’ (βŒŠβ€˜((𝑁 mod (2↑𝑀)) / (2↑π‘₯)))) = ((𝑁 βˆ’ (𝑁 mod (2↑𝑀))) / (2↑π‘₯)))
9177, 90breqtrrd 5175 . . . . . . . . . . . 12 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ 2 βˆ₯ ((βŒŠβ€˜(𝑁 / (2↑π‘₯))) βˆ’ (βŒŠβ€˜((𝑁 mod (2↑𝑀)) / (2↑π‘₯)))))
92 dvdssub2 16240 . . . . . . . . . . . 12 (((2 ∈ β„€ ∧ (βŒŠβ€˜(𝑁 / (2↑π‘₯))) ∈ β„€ ∧ (βŒŠβ€˜((𝑁 mod (2↑𝑀)) / (2↑π‘₯))) ∈ β„€) ∧ 2 βˆ₯ ((βŒŠβ€˜(𝑁 / (2↑π‘₯))) βˆ’ (βŒŠβ€˜((𝑁 mod (2↑𝑀)) / (2↑π‘₯))))) β†’ (2 βˆ₯ (βŒŠβ€˜(𝑁 / (2↑π‘₯))) ↔ 2 βˆ₯ (βŒŠβ€˜((𝑁 mod (2↑𝑀)) / (2↑π‘₯)))))
9316, 21, 25, 91, 92syl31anc 1373 . . . . . . . . . . 11 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ (2 βˆ₯ (βŒŠβ€˜(𝑁 / (2↑π‘₯))) ↔ 2 βˆ₯ (βŒŠβ€˜((𝑁 mod (2↑𝑀)) / (2↑π‘₯)))))
9493notbid 317 . . . . . . . . . 10 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ (Β¬ 2 βˆ₯ (βŒŠβ€˜(𝑁 / (2↑π‘₯))) ↔ Β¬ 2 βˆ₯ (βŒŠβ€˜((𝑁 mod (2↑𝑀)) / (2↑π‘₯)))))
9512, 14, 943bitr3d 308 . . . . . . . . 9 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ π‘₯ < 𝑀) β†’ ((π‘₯ ∈ (bitsβ€˜π‘) ∧ π‘₯ < 𝑀) ↔ Β¬ 2 βˆ₯ (βŒŠβ€˜((𝑁 mod (2↑𝑀)) / (2↑π‘₯)))))
96 z0even 16306 . . . . . . . . . . . 12 2 βˆ₯ 0
971ad2antrr 724 . . . . . . . . . . . . . . . 16 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ Β¬ π‘₯ < 𝑀) β†’ 𝑁 ∈ β„€)
9897zred 12662 . . . . . . . . . . . . . . 15 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ Β¬ π‘₯ < 𝑀) β†’ 𝑁 ∈ ℝ)
99 2rp 12975 . . . . . . . . . . . . . . . . 17 2 ∈ ℝ+
10099a1i 11 . . . . . . . . . . . . . . . 16 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ Β¬ π‘₯ < 𝑀) β†’ 2 ∈ ℝ+)
10137nn0zd 12580 . . . . . . . . . . . . . . . . 17 (((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) β†’ 𝑀 ∈ β„€)
102101adantr 481 . . . . . . . . . . . . . . . 16 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ Β¬ π‘₯ < 𝑀) β†’ 𝑀 ∈ β„€)
103100, 102rpexpcld 14206 . . . . . . . . . . . . . . 15 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ Β¬ π‘₯ < 𝑀) β†’ (2↑𝑀) ∈ ℝ+)
10498, 103modcld 13836 . . . . . . . . . . . . . 14 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ Β¬ π‘₯ < 𝑀) β†’ (𝑁 mod (2↑𝑀)) ∈ ℝ)
105 simplr 767 . . . . . . . . . . . . . . . 16 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ Β¬ π‘₯ < 𝑀) β†’ π‘₯ ∈ β„•0)
106105nn0zd 12580 . . . . . . . . . . . . . . 15 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ Β¬ π‘₯ < 𝑀) β†’ π‘₯ ∈ β„€)
107100, 106rpexpcld 14206 . . . . . . . . . . . . . 14 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ Β¬ π‘₯ < 𝑀) β†’ (2↑π‘₯) ∈ ℝ+)
1086ad2antrr 724 . . . . . . . . . . . . . . 15 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ Β¬ π‘₯ < 𝑀) β†’ (𝑁 mod (2↑𝑀)) ∈ β„•0)
109108nn0ge0d 12531 . . . . . . . . . . . . . 14 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ Β¬ π‘₯ < 𝑀) β†’ 0 ≀ (𝑁 mod (2↑𝑀)))
110104, 107, 109divge0d 13052 . . . . . . . . . . . . 13 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ Β¬ π‘₯ < 𝑀) β†’ 0 ≀ ((𝑁 mod (2↑𝑀)) / (2↑π‘₯)))
111103rpred 13012 . . . . . . . . . . . . . . . . 17 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ Β¬ π‘₯ < 𝑀) β†’ (2↑𝑀) ∈ ℝ)
112107rpred 13012 . . . . . . . . . . . . . . . . 17 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ Β¬ π‘₯ < 𝑀) β†’ (2↑π‘₯) ∈ ℝ)
113 modlt 13841 . . . . . . . . . . . . . . . . . 18 ((𝑁 ∈ ℝ ∧ (2↑𝑀) ∈ ℝ+) β†’ (𝑁 mod (2↑𝑀)) < (2↑𝑀))
11498, 103, 113syl2anc 584 . . . . . . . . . . . . . . . . 17 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ Β¬ π‘₯ < 𝑀) β†’ (𝑁 mod (2↑𝑀)) < (2↑𝑀))
115100rpred 13012 . . . . . . . . . . . . . . . . . 18 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ Β¬ π‘₯ < 𝑀) β†’ 2 ∈ ℝ)
116 1le2 12417 . . . . . . . . . . . . . . . . . . 19 1 ≀ 2
117116a1i 11 . . . . . . . . . . . . . . . . . 18 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ Β¬ π‘₯ < 𝑀) β†’ 1 ≀ 2)
118102zred 12662 . . . . . . . . . . . . . . . . . . . 20 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ Β¬ π‘₯ < 𝑀) β†’ 𝑀 ∈ ℝ)
119105nn0red 12529 . . . . . . . . . . . . . . . . . . . 20 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ Β¬ π‘₯ < 𝑀) β†’ π‘₯ ∈ ℝ)
120 simpr 485 . . . . . . . . . . . . . . . . . . . 20 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ Β¬ π‘₯ < 𝑀) β†’ Β¬ π‘₯ < 𝑀)
121118, 119, 120nltled 11360 . . . . . . . . . . . . . . . . . . 19 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ Β¬ π‘₯ < 𝑀) β†’ 𝑀 ≀ π‘₯)
122 eluz2 12824 . . . . . . . . . . . . . . . . . . 19 (π‘₯ ∈ (β„€β‰₯β€˜π‘€) ↔ (𝑀 ∈ β„€ ∧ π‘₯ ∈ β„€ ∧ 𝑀 ≀ π‘₯))
123102, 106, 121, 122syl3anbrc 1343 . . . . . . . . . . . . . . . . . 18 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ Β¬ π‘₯ < 𝑀) β†’ π‘₯ ∈ (β„€β‰₯β€˜π‘€))
124115, 117, 123leexp2ad 14213 . . . . . . . . . . . . . . . . 17 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ Β¬ π‘₯ < 𝑀) β†’ (2↑𝑀) ≀ (2↑π‘₯))
125104, 111, 112, 114, 124ltletrd 11370 . . . . . . . . . . . . . . . 16 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ Β¬ π‘₯ < 𝑀) β†’ (𝑁 mod (2↑𝑀)) < (2↑π‘₯))
126107rpcnd 13014 . . . . . . . . . . . . . . . . 17 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ Β¬ π‘₯ < 𝑀) β†’ (2↑π‘₯) ∈ β„‚)
127126mulridd 11227 . . . . . . . . . . . . . . . 16 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ Β¬ π‘₯ < 𝑀) β†’ ((2↑π‘₯) Β· 1) = (2↑π‘₯))
128125, 127breqtrrd 5175 . . . . . . . . . . . . . . 15 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ Β¬ π‘₯ < 𝑀) β†’ (𝑁 mod (2↑𝑀)) < ((2↑π‘₯) Β· 1))
129 1red 11211 . . . . . . . . . . . . . . . 16 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ Β¬ π‘₯ < 𝑀) β†’ 1 ∈ ℝ)
130104, 129, 107ltdivmuld 13063 . . . . . . . . . . . . . . 15 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ Β¬ π‘₯ < 𝑀) β†’ (((𝑁 mod (2↑𝑀)) / (2↑π‘₯)) < 1 ↔ (𝑁 mod (2↑𝑀)) < ((2↑π‘₯) Β· 1)))
131128, 130mpbird 256 . . . . . . . . . . . . . 14 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ Β¬ π‘₯ < 𝑀) β†’ ((𝑁 mod (2↑𝑀)) / (2↑π‘₯)) < 1)
132 1e0p1 12715 . . . . . . . . . . . . . 14 1 = (0 + 1)
133131, 132breqtrdi 5188 . . . . . . . . . . . . 13 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ Β¬ π‘₯ < 𝑀) β†’ ((𝑁 mod (2↑𝑀)) / (2↑π‘₯)) < (0 + 1))
134104, 107rerpdivcld 13043 . . . . . . . . . . . . . 14 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ Β¬ π‘₯ < 𝑀) β†’ ((𝑁 mod (2↑𝑀)) / (2↑π‘₯)) ∈ ℝ)
135 0z 12565 . . . . . . . . . . . . . 14 0 ∈ β„€
136 flbi 13777 . . . . . . . . . . . . . 14 ((((𝑁 mod (2↑𝑀)) / (2↑π‘₯)) ∈ ℝ ∧ 0 ∈ β„€) β†’ ((βŒŠβ€˜((𝑁 mod (2↑𝑀)) / (2↑π‘₯))) = 0 ↔ (0 ≀ ((𝑁 mod (2↑𝑀)) / (2↑π‘₯)) ∧ ((𝑁 mod (2↑𝑀)) / (2↑π‘₯)) < (0 + 1))))
137134, 135, 136sylancl 586 . . . . . . . . . . . . 13 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ Β¬ π‘₯ < 𝑀) β†’ ((βŒŠβ€˜((𝑁 mod (2↑𝑀)) / (2↑π‘₯))) = 0 ↔ (0 ≀ ((𝑁 mod (2↑𝑀)) / (2↑π‘₯)) ∧ ((𝑁 mod (2↑𝑀)) / (2↑π‘₯)) < (0 + 1))))
138110, 133, 137mpbir2and 711 . . . . . . . . . . . 12 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ Β¬ π‘₯ < 𝑀) β†’ (βŒŠβ€˜((𝑁 mod (2↑𝑀)) / (2↑π‘₯))) = 0)
13996, 138breqtrrid 5185 . . . . . . . . . . 11 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ Β¬ π‘₯ < 𝑀) β†’ 2 βˆ₯ (βŒŠβ€˜((𝑁 mod (2↑𝑀)) / (2↑π‘₯))))
140120intnand 489 . . . . . . . . . . 11 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ Β¬ π‘₯ < 𝑀) β†’ Β¬ (π‘₯ ∈ (bitsβ€˜π‘) ∧ π‘₯ < 𝑀))
141139, 1402thd 264 . . . . . . . . . 10 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ Β¬ π‘₯ < 𝑀) β†’ (2 βˆ₯ (βŒŠβ€˜((𝑁 mod (2↑𝑀)) / (2↑π‘₯))) ↔ Β¬ (π‘₯ ∈ (bitsβ€˜π‘) ∧ π‘₯ < 𝑀)))
142141con2bid 354 . . . . . . . . 9 ((((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) ∧ Β¬ π‘₯ < 𝑀) β†’ ((π‘₯ ∈ (bitsβ€˜π‘) ∧ π‘₯ < 𝑀) ↔ Β¬ 2 βˆ₯ (βŒŠβ€˜((𝑁 mod (2↑𝑀)) / (2↑π‘₯)))))
14395, 142pm2.61dan 811 . . . . . . . 8 (((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) β†’ ((π‘₯ ∈ (bitsβ€˜π‘) ∧ π‘₯ < 𝑀) ↔ Β¬ 2 βˆ₯ (βŒŠβ€˜((𝑁 mod (2↑𝑀)) / (2↑π‘₯)))))
144101biantrurd 533 . . . . . . . 8 (((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) β†’ ((π‘₯ ∈ (bitsβ€˜π‘) ∧ π‘₯ < 𝑀) ↔ (𝑀 ∈ β„€ ∧ (π‘₯ ∈ (bitsβ€˜π‘) ∧ π‘₯ < 𝑀))))
145143, 144bitr3d 280 . . . . . . 7 (((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) β†’ (Β¬ 2 βˆ₯ (βŒŠβ€˜((𝑁 mod (2↑𝑀)) / (2↑π‘₯))) ↔ (𝑀 ∈ β„€ ∧ (π‘₯ ∈ (bitsβ€˜π‘) ∧ π‘₯ < 𝑀))))
146 an12 643 . . . . . . 7 ((𝑀 ∈ β„€ ∧ (π‘₯ ∈ (bitsβ€˜π‘) ∧ π‘₯ < 𝑀)) ↔ (π‘₯ ∈ (bitsβ€˜π‘) ∧ (𝑀 ∈ β„€ ∧ π‘₯ < 𝑀)))
147145, 146bitrdi 286 . . . . . 6 (((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) ∧ π‘₯ ∈ β„•0) β†’ (Β¬ 2 βˆ₯ (βŒŠβ€˜((𝑁 mod (2↑𝑀)) / (2↑π‘₯))) ↔ (π‘₯ ∈ (bitsβ€˜π‘) ∧ (𝑀 ∈ β„€ ∧ π‘₯ < 𝑀))))
148147pm5.32da 579 . . . . 5 ((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) β†’ ((π‘₯ ∈ β„•0 ∧ Β¬ 2 βˆ₯ (βŒŠβ€˜((𝑁 mod (2↑𝑀)) / (2↑π‘₯)))) ↔ (π‘₯ ∈ β„•0 ∧ (π‘₯ ∈ (bitsβ€˜π‘) ∧ (𝑀 ∈ β„€ ∧ π‘₯ < 𝑀)))))
1498, 148bitr3d 280 . . . 4 ((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) β†’ (((𝑁 mod (2↑𝑀)) ∈ β„€ ∧ (π‘₯ ∈ β„•0 ∧ Β¬ 2 βˆ₯ (βŒŠβ€˜((𝑁 mod (2↑𝑀)) / (2↑π‘₯))))) ↔ (π‘₯ ∈ β„•0 ∧ (π‘₯ ∈ (bitsβ€˜π‘) ∧ (𝑀 ∈ β„€ ∧ π‘₯ < 𝑀)))))
150 3anass 1095 . . . 4 (((𝑁 mod (2↑𝑀)) ∈ β„€ ∧ π‘₯ ∈ β„•0 ∧ Β¬ 2 βˆ₯ (βŒŠβ€˜((𝑁 mod (2↑𝑀)) / (2↑π‘₯)))) ↔ ((𝑁 mod (2↑𝑀)) ∈ β„€ ∧ (π‘₯ ∈ β„•0 ∧ Β¬ 2 βˆ₯ (βŒŠβ€˜((𝑁 mod (2↑𝑀)) / (2↑π‘₯))))))
151 elfzo2 13631 . . . . . . 7 (π‘₯ ∈ (0..^𝑀) ↔ (π‘₯ ∈ (β„€β‰₯β€˜0) ∧ 𝑀 ∈ β„€ ∧ π‘₯ < 𝑀))
152 elnn0uz 12863 . . . . . . . 8 (π‘₯ ∈ β„•0 ↔ π‘₯ ∈ (β„€β‰₯β€˜0))
1531523anbi1i 1157 . . . . . . 7 ((π‘₯ ∈ β„•0 ∧ 𝑀 ∈ β„€ ∧ π‘₯ < 𝑀) ↔ (π‘₯ ∈ (β„€β‰₯β€˜0) ∧ 𝑀 ∈ β„€ ∧ π‘₯ < 𝑀))
154 3anass 1095 . . . . . . 7 ((π‘₯ ∈ β„•0 ∧ 𝑀 ∈ β„€ ∧ π‘₯ < 𝑀) ↔ (π‘₯ ∈ β„•0 ∧ (𝑀 ∈ β„€ ∧ π‘₯ < 𝑀)))
155151, 153, 1543bitr2i 298 . . . . . 6 (π‘₯ ∈ (0..^𝑀) ↔ (π‘₯ ∈ β„•0 ∧ (𝑀 ∈ β„€ ∧ π‘₯ < 𝑀)))
156155anbi2i 623 . . . . 5 ((π‘₯ ∈ (bitsβ€˜π‘) ∧ π‘₯ ∈ (0..^𝑀)) ↔ (π‘₯ ∈ (bitsβ€˜π‘) ∧ (π‘₯ ∈ β„•0 ∧ (𝑀 ∈ β„€ ∧ π‘₯ < 𝑀))))
157 an12 643 . . . . 5 ((π‘₯ ∈ (bitsβ€˜π‘) ∧ (π‘₯ ∈ β„•0 ∧ (𝑀 ∈ β„€ ∧ π‘₯ < 𝑀))) ↔ (π‘₯ ∈ β„•0 ∧ (π‘₯ ∈ (bitsβ€˜π‘) ∧ (𝑀 ∈ β„€ ∧ π‘₯ < 𝑀))))
158156, 157bitri 274 . . . 4 ((π‘₯ ∈ (bitsβ€˜π‘) ∧ π‘₯ ∈ (0..^𝑀)) ↔ (π‘₯ ∈ β„•0 ∧ (π‘₯ ∈ (bitsβ€˜π‘) ∧ (𝑀 ∈ β„€ ∧ π‘₯ < 𝑀))))
159149, 150, 1583bitr4g 313 . . 3 ((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) β†’ (((𝑁 mod (2↑𝑀)) ∈ β„€ ∧ π‘₯ ∈ β„•0 ∧ Β¬ 2 βˆ₯ (βŒŠβ€˜((𝑁 mod (2↑𝑀)) / (2↑π‘₯)))) ↔ (π‘₯ ∈ (bitsβ€˜π‘) ∧ π‘₯ ∈ (0..^𝑀))))
160 bitsval 16361 . . 3 (π‘₯ ∈ (bitsβ€˜(𝑁 mod (2↑𝑀))) ↔ ((𝑁 mod (2↑𝑀)) ∈ β„€ ∧ π‘₯ ∈ β„•0 ∧ Β¬ 2 βˆ₯ (βŒŠβ€˜((𝑁 mod (2↑𝑀)) / (2↑π‘₯)))))
161 elin 3963 . . 3 (π‘₯ ∈ ((bitsβ€˜π‘) ∩ (0..^𝑀)) ↔ (π‘₯ ∈ (bitsβ€˜π‘) ∧ π‘₯ ∈ (0..^𝑀)))
162159, 160, 1613bitr4g 313 . 2 ((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) β†’ (π‘₯ ∈ (bitsβ€˜(𝑁 mod (2↑𝑀))) ↔ π‘₯ ∈ ((bitsβ€˜π‘) ∩ (0..^𝑀))))
163162eqrdv 2730 1 ((𝑁 ∈ β„€ ∧ 𝑀 ∈ β„•0) β†’ (bitsβ€˜(𝑁 mod (2↑𝑀))) = ((bitsβ€˜π‘) ∩ (0..^𝑀)))
Colors of variables: wff setvar class
Syntax hints:  Β¬ wn 3   β†’ wi 4   ↔ wb 205   ∧ wa 396   ∧ w3a 1087   = wceq 1541   ∈ wcel 2106   β‰  wne 2940   ∩ cin 3946   class class class wbr 5147  β€˜cfv 6540  (class class class)co 7405  β„cr 11105  0cc0 11106  1c1 11107   + caddc 11109   Β· cmul 11111   < clt 11244   ≀ cle 11245   βˆ’ cmin 11440   / cdiv 11867  β„•cn 12208  2c2 12263  β„•0cn0 12468  β„€cz 12554  β„€β‰₯cuz 12818  β„+crp 12970  ..^cfzo 13623  βŒŠcfl 13751   mod cmo 13830  β†‘cexp 14023   βˆ₯ cdvds 16193  bitscbits 16356
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-3 8  ax-gen 1797  ax-4 1811  ax-5 1913  ax-6 1971  ax-7 2011  ax-8 2108  ax-9 2116  ax-10 2137  ax-11 2154  ax-12 2171  ax-ext 2703  ax-sep 5298  ax-nul 5305  ax-pow 5362  ax-pr 5426  ax-un 7721  ax-cnex 11162  ax-resscn 11163  ax-1cn 11164  ax-icn 11165  ax-addcl 11166  ax-addrcl 11167  ax-mulcl 11168  ax-mulrcl 11169  ax-mulcom 11170  ax-addass 11171  ax-mulass 11172  ax-distr 11173  ax-i2m1 11174  ax-1ne0 11175  ax-1rid 11176  ax-rnegex 11177  ax-rrecex 11178  ax-cnre 11179  ax-pre-lttri 11180  ax-pre-lttrn 11181  ax-pre-ltadd 11182  ax-pre-mulgt0 11183  ax-pre-sup 11184
This theorem depends on definitions:  df-bi 206  df-an 397  df-or 846  df-3or 1088  df-3an 1089  df-tru 1544  df-fal 1554  df-ex 1782  df-nf 1786  df-sb 2068  df-mo 2534  df-eu 2563  df-clab 2710  df-cleq 2724  df-clel 2810  df-nfc 2885  df-ne 2941  df-nel 3047  df-ral 3062  df-rex 3071  df-rmo 3376  df-reu 3377  df-rab 3433  df-v 3476  df-sbc 3777  df-csb 3893  df-dif 3950  df-un 3952  df-in 3954  df-ss 3964  df-pss 3966  df-nul 4322  df-if 4528  df-pw 4603  df-sn 4628  df-pr 4630  df-op 4634  df-uni 4908  df-iun 4998  df-br 5148  df-opab 5210  df-mpt 5231  df-tr 5265  df-id 5573  df-eprel 5579  df-po 5587  df-so 5588  df-fr 5630  df-we 5632  df-xp 5681  df-rel 5682  df-cnv 5683  df-co 5684  df-dm 5685  df-rn 5686  df-res 5687  df-ima 5688  df-pred 6297  df-ord 6364  df-on 6365  df-lim 6366  df-suc 6367  df-iota 6492  df-fun 6542  df-fn 6543  df-f 6544  df-f1 6545  df-fo 6546  df-f1o 6547  df-fv 6548  df-riota 7361  df-ov 7408  df-oprab 7409  df-mpo 7410  df-om 7852  df-1st 7971  df-2nd 7972  df-frecs 8262  df-wrecs 8293  df-recs 8367  df-rdg 8406  df-er 8699  df-en 8936  df-dom 8937  df-sdom 8938  df-sup 9433  df-inf 9434  df-pnf 11246  df-mnf 11247  df-xr 11248  df-ltxr 11249  df-le 11250  df-sub 11442  df-neg 11443  df-div 11868  df-nn 12209  df-2 12271  df-n0 12469  df-z 12555  df-uz 12819  df-rp 12971  df-fz 13481  df-fzo 13624  df-fl 13753  df-mod 13831  df-seq 13963  df-exp 14024  df-dvds 16194  df-bits 16359
This theorem is referenced by:  sadaddlem  16403  sadadd  16404  bitsres  16410  smumul  16430
  Copyright terms: Public domain W3C validator