Proof of Theorem bitsinv1lem
Step | Hyp | Ref
| Expression |
1 | | oveq2 7283 |
. . 3
⊢
((2↑𝑀) =
if(𝑀 ∈
(bits‘𝑁),
(2↑𝑀), 0) →
((𝑁 mod (2↑𝑀)) + (2↑𝑀)) = ((𝑁 mod (2↑𝑀)) + if(𝑀 ∈ (bits‘𝑁), (2↑𝑀), 0))) |
2 | 1 | eqeq2d 2749 |
. 2
⊢
((2↑𝑀) =
if(𝑀 ∈
(bits‘𝑁),
(2↑𝑀), 0) →
((𝑁 mod (2↑(𝑀 + 1))) = ((𝑁 mod (2↑𝑀)) + (2↑𝑀)) ↔ (𝑁 mod (2↑(𝑀 + 1))) = ((𝑁 mod (2↑𝑀)) + if(𝑀 ∈ (bits‘𝑁), (2↑𝑀), 0)))) |
3 | | oveq2 7283 |
. . 3
⊢ (0 =
if(𝑀 ∈
(bits‘𝑁),
(2↑𝑀), 0) →
((𝑁 mod (2↑𝑀)) + 0) = ((𝑁 mod (2↑𝑀)) + if(𝑀 ∈ (bits‘𝑁), (2↑𝑀), 0))) |
4 | 3 | eqeq2d 2749 |
. 2
⊢ (0 =
if(𝑀 ∈
(bits‘𝑁),
(2↑𝑀), 0) →
((𝑁 mod (2↑(𝑀 + 1))) = ((𝑁 mod (2↑𝑀)) + 0) ↔ (𝑁 mod (2↑(𝑀 + 1))) = ((𝑁 mod (2↑𝑀)) + if(𝑀 ∈ (bits‘𝑁), (2↑𝑀), 0)))) |
5 | | simpl 483 |
. . . . . . 7
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ 𝑁 ∈
ℤ) |
6 | | 2nn 12046 |
. . . . . . . . 9
⊢ 2 ∈
ℕ |
7 | 6 | a1i 11 |
. . . . . . . 8
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ 2 ∈ ℕ) |
8 | | simpr 485 |
. . . . . . . 8
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ 𝑀 ∈
ℕ0) |
9 | 7, 8 | nnexpcld 13960 |
. . . . . . 7
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ (2↑𝑀) ∈
ℕ) |
10 | 5, 9 | zmodcld 13612 |
. . . . . 6
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ (𝑁 mod (2↑𝑀)) ∈
ℕ0) |
11 | 10 | nn0cnd 12295 |
. . . . 5
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ (𝑁 mod (2↑𝑀)) ∈
ℂ) |
12 | 11 | adantr 481 |
. . . 4
⊢ (((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑀 ∈
(bits‘𝑁)) →
(𝑁 mod (2↑𝑀)) ∈
ℂ) |
13 | | 1nn0 12249 |
. . . . . . . . . 10
⊢ 1 ∈
ℕ0 |
14 | 13 | a1i 11 |
. . . . . . . . 9
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ 1 ∈ ℕ0) |
15 | 8, 14 | nn0addcld 12297 |
. . . . . . . 8
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ (𝑀 + 1) ∈
ℕ0) |
16 | 7, 15 | nnexpcld 13960 |
. . . . . . 7
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ (2↑(𝑀 + 1))
∈ ℕ) |
17 | 5, 16 | zmodcld 13612 |
. . . . . 6
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ (𝑁 mod
(2↑(𝑀 + 1))) ∈
ℕ0) |
18 | 17 | nn0cnd 12295 |
. . . . 5
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ (𝑁 mod
(2↑(𝑀 + 1))) ∈
ℂ) |
19 | 18 | adantr 481 |
. . . 4
⊢ (((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑀 ∈
(bits‘𝑁)) →
(𝑁 mod (2↑(𝑀 + 1))) ∈
ℂ) |
20 | 12, 19 | pncan3d 11335 |
. . 3
⊢ (((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑀 ∈
(bits‘𝑁)) →
((𝑁 mod (2↑𝑀)) + ((𝑁 mod (2↑(𝑀 + 1))) − (𝑁 mod (2↑𝑀)))) = (𝑁 mod (2↑(𝑀 + 1)))) |
21 | 18, 11 | subcld 11332 |
. . . . . 6
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ ((𝑁 mod
(2↑(𝑀 + 1))) −
(𝑁 mod (2↑𝑀))) ∈
ℂ) |
22 | 21 | adantr 481 |
. . . . 5
⊢ (((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑀 ∈
(bits‘𝑁)) →
((𝑁 mod (2↑(𝑀 + 1))) − (𝑁 mod (2↑𝑀))) ∈ ℂ) |
23 | 6 | a1i 11 |
. . . . . . 7
⊢ (((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑀 ∈
(bits‘𝑁)) → 2
∈ ℕ) |
24 | | simplr 766 |
. . . . . . 7
⊢ (((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑀 ∈
(bits‘𝑁)) →
𝑀 ∈
ℕ0) |
25 | 23, 24 | nnexpcld 13960 |
. . . . . 6
⊢ (((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑀 ∈
(bits‘𝑁)) →
(2↑𝑀) ∈
ℕ) |
26 | 25 | nncnd 11989 |
. . . . 5
⊢ (((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑀 ∈
(bits‘𝑁)) →
(2↑𝑀) ∈
ℂ) |
27 | | 2cnd 12051 |
. . . . . . 7
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ 2 ∈ ℂ) |
28 | | 2ne0 12077 |
. . . . . . . 8
⊢ 2 ≠
0 |
29 | 28 | a1i 11 |
. . . . . . 7
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ 2 ≠ 0) |
30 | 8 | nn0zd 12424 |
. . . . . . 7
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ 𝑀 ∈
ℤ) |
31 | 27, 29, 30 | expne0d 13870 |
. . . . . 6
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ (2↑𝑀) ≠
0) |
32 | 31 | adantr 481 |
. . . . 5
⊢ (((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑀 ∈
(bits‘𝑁)) →
(2↑𝑀) ≠
0) |
33 | | z0even 16076 |
. . . . . . . . . 10
⊢ 2 ∥
0 |
34 | | id 22 |
. . . . . . . . . 10
⊢ ((((𝑁 mod (2↑(𝑀 + 1))) − (𝑁 mod (2↑𝑀))) / (2↑𝑀)) = 0 → (((𝑁 mod (2↑(𝑀 + 1))) − (𝑁 mod (2↑𝑀))) / (2↑𝑀)) = 0) |
35 | 33, 34 | breqtrrid 5112 |
. . . . . . . . 9
⊢ ((((𝑁 mod (2↑(𝑀 + 1))) − (𝑁 mod (2↑𝑀))) / (2↑𝑀)) = 0 → 2 ∥ (((𝑁 mod (2↑(𝑀 + 1))) − (𝑁 mod (2↑𝑀))) / (2↑𝑀))) |
36 | | bitsval2 16132 |
. . . . . . . . . . 11
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ (𝑀 ∈
(bits‘𝑁) ↔ ¬
2 ∥ (⌊‘(𝑁
/ (2↑𝑀))))) |
37 | 5 | zred 12426 |
. . . . . . . . . . . . . . 15
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ 𝑁 ∈
ℝ) |
38 | 9 | nnrpd 12770 |
. . . . . . . . . . . . . . 15
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ (2↑𝑀) ∈
ℝ+) |
39 | | moddiffl 13602 |
. . . . . . . . . . . . . . 15
⊢ ((𝑁 ∈ ℝ ∧
(2↑𝑀) ∈
ℝ+) → ((𝑁 − (𝑁 mod (2↑𝑀))) / (2↑𝑀)) = (⌊‘(𝑁 / (2↑𝑀)))) |
40 | 37, 38, 39 | syl2anc 584 |
. . . . . . . . . . . . . 14
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ ((𝑁 − (𝑁 mod (2↑𝑀))) / (2↑𝑀)) = (⌊‘(𝑁 / (2↑𝑀)))) |
41 | 40 | breq2d 5086 |
. . . . . . . . . . . . 13
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ (2 ∥ ((𝑁
− (𝑁 mod
(2↑𝑀))) /
(2↑𝑀)) ↔ 2
∥ (⌊‘(𝑁 /
(2↑𝑀))))) |
42 | | 2z 12352 |
. . . . . . . . . . . . . . 15
⊢ 2 ∈
ℤ |
43 | 42 | a1i 11 |
. . . . . . . . . . . . . 14
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ 2 ∈ ℤ) |
44 | | moddifz 13603 |
. . . . . . . . . . . . . . 15
⊢ ((𝑁 ∈ ℝ ∧
(2↑𝑀) ∈
ℝ+) → ((𝑁 − (𝑁 mod (2↑𝑀))) / (2↑𝑀)) ∈ ℤ) |
45 | 37, 38, 44 | syl2anc 584 |
. . . . . . . . . . . . . 14
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ ((𝑁 − (𝑁 mod (2↑𝑀))) / (2↑𝑀)) ∈ ℤ) |
46 | 5 | zcnd 12427 |
. . . . . . . . . . . . . . . . . 18
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ 𝑁 ∈
ℂ) |
47 | 46, 11, 18 | nnncan1d 11366 |
. . . . . . . . . . . . . . . . 17
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ ((𝑁 − (𝑁 mod (2↑𝑀))) − (𝑁 − (𝑁 mod (2↑(𝑀 + 1))))) = ((𝑁 mod (2↑(𝑀 + 1))) − (𝑁 mod (2↑𝑀)))) |
48 | 47 | oveq1d 7290 |
. . . . . . . . . . . . . . . 16
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ (((𝑁 − (𝑁 mod (2↑𝑀))) − (𝑁 − (𝑁 mod (2↑(𝑀 + 1))))) / (2↑𝑀)) = (((𝑁 mod (2↑(𝑀 + 1))) − (𝑁 mod (2↑𝑀))) / (2↑𝑀))) |
49 | 46, 11 | subcld 11332 |
. . . . . . . . . . . . . . . . 17
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ (𝑁 − (𝑁 mod (2↑𝑀))) ∈ ℂ) |
50 | 46, 18 | subcld 11332 |
. . . . . . . . . . . . . . . . 17
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ (𝑁 − (𝑁 mod (2↑(𝑀 + 1)))) ∈ ℂ) |
51 | 9 | nncnd 11989 |
. . . . . . . . . . . . . . . . 17
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ (2↑𝑀) ∈
ℂ) |
52 | 49, 50, 51, 31 | divsubdird 11790 |
. . . . . . . . . . . . . . . 16
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ (((𝑁 − (𝑁 mod (2↑𝑀))) − (𝑁 − (𝑁 mod (2↑(𝑀 + 1))))) / (2↑𝑀)) = (((𝑁 − (𝑁 mod (2↑𝑀))) / (2↑𝑀)) − ((𝑁 − (𝑁 mod (2↑(𝑀 + 1)))) / (2↑𝑀)))) |
53 | 48, 52 | eqtr3d 2780 |
. . . . . . . . . . . . . . 15
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ (((𝑁 mod
(2↑(𝑀 + 1))) −
(𝑁 mod (2↑𝑀))) / (2↑𝑀)) = (((𝑁 − (𝑁 mod (2↑𝑀))) / (2↑𝑀)) − ((𝑁 − (𝑁 mod (2↑(𝑀 + 1)))) / (2↑𝑀)))) |
54 | 27, 50 | mulcomd 10996 |
. . . . . . . . . . . . . . . . . . 19
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ (2 · (𝑁
− (𝑁 mod
(2↑(𝑀 + 1))))) =
((𝑁 − (𝑁 mod (2↑(𝑀 + 1)))) · 2)) |
55 | 27, 51 | mulcomd 10996 |
. . . . . . . . . . . . . . . . . . . 20
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ (2 · (2↑𝑀)) = ((2↑𝑀) · 2)) |
56 | 27, 8 | expp1d 13865 |
. . . . . . . . . . . . . . . . . . . 20
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ (2↑(𝑀 + 1)) =
((2↑𝑀) ·
2)) |
57 | 55, 56 | eqtr4d 2781 |
. . . . . . . . . . . . . . . . . . 19
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ (2 · (2↑𝑀)) = (2↑(𝑀 + 1))) |
58 | 54, 57 | oveq12d 7293 |
. . . . . . . . . . . . . . . . . 18
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ ((2 · (𝑁
− (𝑁 mod
(2↑(𝑀 + 1))))) / (2
· (2↑𝑀))) =
(((𝑁 − (𝑁 mod (2↑(𝑀 + 1)))) · 2) / (2↑(𝑀 + 1)))) |
59 | 50, 51, 27, 31, 29 | divcan5d 11777 |
. . . . . . . . . . . . . . . . . 18
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ ((2 · (𝑁
− (𝑁 mod
(2↑(𝑀 + 1))))) / (2
· (2↑𝑀))) =
((𝑁 − (𝑁 mod (2↑(𝑀 + 1)))) / (2↑𝑀))) |
60 | 16 | nncnd 11989 |
. . . . . . . . . . . . . . . . . . 19
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ (2↑(𝑀 + 1))
∈ ℂ) |
61 | 30 | peano2zd 12429 |
. . . . . . . . . . . . . . . . . . . 20
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ (𝑀 + 1) ∈
ℤ) |
62 | 27, 29, 61 | expne0d 13870 |
. . . . . . . . . . . . . . . . . . 19
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ (2↑(𝑀 + 1))
≠ 0) |
63 | 50, 27, 60, 62 | div23d 11788 |
. . . . . . . . . . . . . . . . . 18
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ (((𝑁 − (𝑁 mod (2↑(𝑀 + 1)))) · 2) / (2↑(𝑀 + 1))) = (((𝑁 − (𝑁 mod (2↑(𝑀 + 1)))) / (2↑(𝑀 + 1))) · 2)) |
64 | 58, 59, 63 | 3eqtr3d 2786 |
. . . . . . . . . . . . . . . . 17
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ ((𝑁 − (𝑁 mod (2↑(𝑀 + 1)))) / (2↑𝑀)) = (((𝑁 − (𝑁 mod (2↑(𝑀 + 1)))) / (2↑(𝑀 + 1))) · 2)) |
65 | 16 | nnrpd 12770 |
. . . . . . . . . . . . . . . . . . 19
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ (2↑(𝑀 + 1))
∈ ℝ+) |
66 | | moddifz 13603 |
. . . . . . . . . . . . . . . . . . 19
⊢ ((𝑁 ∈ ℝ ∧
(2↑(𝑀 + 1)) ∈
ℝ+) → ((𝑁 − (𝑁 mod (2↑(𝑀 + 1)))) / (2↑(𝑀 + 1))) ∈ ℤ) |
67 | 37, 65, 66 | syl2anc 584 |
. . . . . . . . . . . . . . . . . 18
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ ((𝑁 − (𝑁 mod (2↑(𝑀 + 1)))) / (2↑(𝑀 + 1))) ∈ ℤ) |
68 | 67, 43 | zmulcld 12432 |
. . . . . . . . . . . . . . . . 17
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ (((𝑁 − (𝑁 mod (2↑(𝑀 + 1)))) / (2↑(𝑀 + 1))) · 2) ∈
ℤ) |
69 | 64, 68 | eqeltrd 2839 |
. . . . . . . . . . . . . . . 16
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ ((𝑁 − (𝑁 mod (2↑(𝑀 + 1)))) / (2↑𝑀)) ∈ ℤ) |
70 | 45, 69 | zsubcld 12431 |
. . . . . . . . . . . . . . 15
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ (((𝑁 − (𝑁 mod (2↑𝑀))) / (2↑𝑀)) − ((𝑁 − (𝑁 mod (2↑(𝑀 + 1)))) / (2↑𝑀))) ∈ ℤ) |
71 | 53, 70 | eqeltrd 2839 |
. . . . . . . . . . . . . 14
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ (((𝑁 mod
(2↑(𝑀 + 1))) −
(𝑁 mod (2↑𝑀))) / (2↑𝑀)) ∈ ℤ) |
72 | | dvdsmul2 15988 |
. . . . . . . . . . . . . . . 16
⊢ ((((𝑁 − (𝑁 mod (2↑(𝑀 + 1)))) / (2↑(𝑀 + 1))) ∈ ℤ ∧ 2 ∈
ℤ) → 2 ∥ (((𝑁 − (𝑁 mod (2↑(𝑀 + 1)))) / (2↑(𝑀 + 1))) · 2)) |
73 | 67, 43, 72 | syl2anc 584 |
. . . . . . . . . . . . . . 15
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ 2 ∥ (((𝑁
− (𝑁 mod
(2↑(𝑀 + 1)))) /
(2↑(𝑀 + 1))) ·
2)) |
74 | 46, 18, 11 | nnncan2d 11367 |
. . . . . . . . . . . . . . . . 17
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ ((𝑁 − (𝑁 mod (2↑𝑀))) − ((𝑁 mod (2↑(𝑀 + 1))) − (𝑁 mod (2↑𝑀)))) = (𝑁 − (𝑁 mod (2↑(𝑀 + 1))))) |
75 | 74 | oveq1d 7290 |
. . . . . . . . . . . . . . . 16
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ (((𝑁 − (𝑁 mod (2↑𝑀))) − ((𝑁 mod (2↑(𝑀 + 1))) − (𝑁 mod (2↑𝑀)))) / (2↑𝑀)) = ((𝑁 − (𝑁 mod (2↑(𝑀 + 1)))) / (2↑𝑀))) |
76 | 49, 21, 51, 31 | divsubdird 11790 |
. . . . . . . . . . . . . . . 16
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ (((𝑁 − (𝑁 mod (2↑𝑀))) − ((𝑁 mod (2↑(𝑀 + 1))) − (𝑁 mod (2↑𝑀)))) / (2↑𝑀)) = (((𝑁 − (𝑁 mod (2↑𝑀))) / (2↑𝑀)) − (((𝑁 mod (2↑(𝑀 + 1))) − (𝑁 mod (2↑𝑀))) / (2↑𝑀)))) |
77 | 75, 76, 64 | 3eqtr3d 2786 |
. . . . . . . . . . . . . . 15
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ (((𝑁 − (𝑁 mod (2↑𝑀))) / (2↑𝑀)) − (((𝑁 mod (2↑(𝑀 + 1))) − (𝑁 mod (2↑𝑀))) / (2↑𝑀))) = (((𝑁 − (𝑁 mod (2↑(𝑀 + 1)))) / (2↑(𝑀 + 1))) · 2)) |
78 | 73, 77 | breqtrrd 5102 |
. . . . . . . . . . . . . 14
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ 2 ∥ (((𝑁
− (𝑁 mod
(2↑𝑀))) /
(2↑𝑀)) −
(((𝑁 mod (2↑(𝑀 + 1))) − (𝑁 mod (2↑𝑀))) / (2↑𝑀)))) |
79 | | dvdssub2 16010 |
. . . . . . . . . . . . . 14
⊢ (((2
∈ ℤ ∧ ((𝑁
− (𝑁 mod
(2↑𝑀))) /
(2↑𝑀)) ∈ ℤ
∧ (((𝑁 mod
(2↑(𝑀 + 1))) −
(𝑁 mod (2↑𝑀))) / (2↑𝑀)) ∈ ℤ) ∧ 2 ∥ (((𝑁 − (𝑁 mod (2↑𝑀))) / (2↑𝑀)) − (((𝑁 mod (2↑(𝑀 + 1))) − (𝑁 mod (2↑𝑀))) / (2↑𝑀)))) → (2 ∥ ((𝑁 − (𝑁 mod (2↑𝑀))) / (2↑𝑀)) ↔ 2 ∥ (((𝑁 mod (2↑(𝑀 + 1))) − (𝑁 mod (2↑𝑀))) / (2↑𝑀)))) |
80 | 43, 45, 71, 78, 79 | syl31anc 1372 |
. . . . . . . . . . . . 13
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ (2 ∥ ((𝑁
− (𝑁 mod
(2↑𝑀))) /
(2↑𝑀)) ↔ 2
∥ (((𝑁 mod
(2↑(𝑀 + 1))) −
(𝑁 mod (2↑𝑀))) / (2↑𝑀)))) |
81 | 41, 80 | bitr3d 280 |
. . . . . . . . . . . 12
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ (2 ∥ (⌊‘(𝑁 / (2↑𝑀))) ↔ 2 ∥ (((𝑁 mod (2↑(𝑀 + 1))) − (𝑁 mod (2↑𝑀))) / (2↑𝑀)))) |
82 | 81 | notbid 318 |
. . . . . . . . . . 11
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ (¬ 2 ∥ (⌊‘(𝑁 / (2↑𝑀))) ↔ ¬ 2 ∥ (((𝑁 mod (2↑(𝑀 + 1))) − (𝑁 mod (2↑𝑀))) / (2↑𝑀)))) |
83 | 36, 82 | bitrd 278 |
. . . . . . . . . 10
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ (𝑀 ∈
(bits‘𝑁) ↔ ¬
2 ∥ (((𝑁 mod
(2↑(𝑀 + 1))) −
(𝑁 mod (2↑𝑀))) / (2↑𝑀)))) |
84 | 83 | con2bid 355 |
. . . . . . . . 9
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ (2 ∥ (((𝑁 mod
(2↑(𝑀 + 1))) −
(𝑁 mod (2↑𝑀))) / (2↑𝑀)) ↔ ¬ 𝑀 ∈ (bits‘𝑁))) |
85 | 35, 84 | syl5ib 243 |
. . . . . . . 8
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ ((((𝑁 mod
(2↑(𝑀 + 1))) −
(𝑁 mod (2↑𝑀))) / (2↑𝑀)) = 0 → ¬ 𝑀 ∈ (bits‘𝑁))) |
86 | 85 | con2d 134 |
. . . . . . 7
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ (𝑀 ∈
(bits‘𝑁) → ¬
(((𝑁 mod (2↑(𝑀 + 1))) − (𝑁 mod (2↑𝑀))) / (2↑𝑀)) = 0)) |
87 | | df-neg 11208 |
. . . . . . . . . . . . . . 15
⊢ -1 = (0
− 1) |
88 | 51 | mulm1d 11427 |
. . . . . . . . . . . . . . . . 17
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ (-1 · (2↑𝑀)) = -(2↑𝑀)) |
89 | 9 | nnred 11988 |
. . . . . . . . . . . . . . . . . . 19
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ (2↑𝑀) ∈
ℝ) |
90 | 89 | renegcld 11402 |
. . . . . . . . . . . . . . . . . 18
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ -(2↑𝑀) ∈
ℝ) |
91 | 37, 38 | modcld 13595 |
. . . . . . . . . . . . . . . . . . 19
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ (𝑁 mod (2↑𝑀)) ∈
ℝ) |
92 | 91 | renegcld 11402 |
. . . . . . . . . . . . . . . . . 18
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ -(𝑁 mod
(2↑𝑀)) ∈
ℝ) |
93 | 37, 65 | modcld 13595 |
. . . . . . . . . . . . . . . . . . 19
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ (𝑁 mod
(2↑(𝑀 + 1))) ∈
ℝ) |
94 | 93, 91 | resubcld 11403 |
. . . . . . . . . . . . . . . . . 18
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ ((𝑁 mod
(2↑(𝑀 + 1))) −
(𝑁 mod (2↑𝑀))) ∈
ℝ) |
95 | | modlt 13600 |
. . . . . . . . . . . . . . . . . . . 20
⊢ ((𝑁 ∈ ℝ ∧
(2↑𝑀) ∈
ℝ+) → (𝑁 mod (2↑𝑀)) < (2↑𝑀)) |
96 | 37, 38, 95 | syl2anc 584 |
. . . . . . . . . . . . . . . . . . 19
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ (𝑁 mod (2↑𝑀)) < (2↑𝑀)) |
97 | 91, 89 | ltnegd 11553 |
. . . . . . . . . . . . . . . . . . 19
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ ((𝑁 mod
(2↑𝑀)) <
(2↑𝑀) ↔
-(2↑𝑀) < -(𝑁 mod (2↑𝑀)))) |
98 | 96, 97 | mpbid 231 |
. . . . . . . . . . . . . . . . . 18
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ -(2↑𝑀) <
-(𝑁 mod (2↑𝑀))) |
99 | | df-neg 11208 |
. . . . . . . . . . . . . . . . . . 19
⊢ -(𝑁 mod (2↑𝑀)) = (0 − (𝑁 mod (2↑𝑀))) |
100 | | 0red 10978 |
. . . . . . . . . . . . . . . . . . . 20
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ 0 ∈ ℝ) |
101 | | modge0 13599 |
. . . . . . . . . . . . . . . . . . . . 21
⊢ ((𝑁 ∈ ℝ ∧
(2↑(𝑀 + 1)) ∈
ℝ+) → 0 ≤ (𝑁 mod (2↑(𝑀 + 1)))) |
102 | 37, 65, 101 | syl2anc 584 |
. . . . . . . . . . . . . . . . . . . 20
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ 0 ≤ (𝑁 mod
(2↑(𝑀 +
1)))) |
103 | 100, 93, 91, 102 | lesub1dd 11591 |
. . . . . . . . . . . . . . . . . . 19
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ (0 − (𝑁 mod
(2↑𝑀))) ≤ ((𝑁 mod (2↑(𝑀 + 1))) − (𝑁 mod (2↑𝑀)))) |
104 | 99, 103 | eqbrtrid 5109 |
. . . . . . . . . . . . . . . . . 18
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ -(𝑁 mod
(2↑𝑀)) ≤ ((𝑁 mod (2↑(𝑀 + 1))) − (𝑁 mod (2↑𝑀)))) |
105 | 90, 92, 94, 98, 104 | ltletrd 11135 |
. . . . . . . . . . . . . . . . 17
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ -(2↑𝑀) <
((𝑁 mod (2↑(𝑀 + 1))) − (𝑁 mod (2↑𝑀)))) |
106 | 88, 105 | eqbrtrd 5096 |
. . . . . . . . . . . . . . . 16
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ (-1 · (2↑𝑀)) < ((𝑁 mod (2↑(𝑀 + 1))) − (𝑁 mod (2↑𝑀)))) |
107 | | 1red 10976 |
. . . . . . . . . . . . . . . . . 18
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ 1 ∈ ℝ) |
108 | 107 | renegcld 11402 |
. . . . . . . . . . . . . . . . 17
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ -1 ∈ ℝ) |
109 | 108, 94, 38 | ltmuldivd 12819 |
. . . . . . . . . . . . . . . 16
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ ((-1 · (2↑𝑀)) < ((𝑁 mod (2↑(𝑀 + 1))) − (𝑁 mod (2↑𝑀))) ↔ -1 < (((𝑁 mod (2↑(𝑀 + 1))) − (𝑁 mod (2↑𝑀))) / (2↑𝑀)))) |
110 | 106, 109 | mpbid 231 |
. . . . . . . . . . . . . . 15
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ -1 < (((𝑁 mod
(2↑(𝑀 + 1))) −
(𝑁 mod (2↑𝑀))) / (2↑𝑀))) |
111 | 87, 110 | eqbrtrrid 5110 |
. . . . . . . . . . . . . 14
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ (0 − 1) < (((𝑁 mod (2↑(𝑀 + 1))) − (𝑁 mod (2↑𝑀))) / (2↑𝑀))) |
112 | | 0zd 12331 |
. . . . . . . . . . . . . . 15
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ 0 ∈ ℤ) |
113 | | zlem1lt 12372 |
. . . . . . . . . . . . . . 15
⊢ ((0
∈ ℤ ∧ (((𝑁
mod (2↑(𝑀 + 1)))
− (𝑁 mod
(2↑𝑀))) /
(2↑𝑀)) ∈ ℤ)
→ (0 ≤ (((𝑁 mod
(2↑(𝑀 + 1))) −
(𝑁 mod (2↑𝑀))) / (2↑𝑀)) ↔ (0 − 1) < (((𝑁 mod (2↑(𝑀 + 1))) − (𝑁 mod (2↑𝑀))) / (2↑𝑀)))) |
114 | 112, 71, 113 | syl2anc 584 |
. . . . . . . . . . . . . 14
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ (0 ≤ (((𝑁 mod
(2↑(𝑀 + 1))) −
(𝑁 mod (2↑𝑀))) / (2↑𝑀)) ↔ (0 − 1) < (((𝑁 mod (2↑(𝑀 + 1))) − (𝑁 mod (2↑𝑀))) / (2↑𝑀)))) |
115 | 111, 114 | mpbird 256 |
. . . . . . . . . . . . 13
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ 0 ≤ (((𝑁 mod
(2↑(𝑀 + 1))) −
(𝑁 mod (2↑𝑀))) / (2↑𝑀))) |
116 | | elnn0z 12332 |
. . . . . . . . . . . . 13
⊢ ((((𝑁 mod (2↑(𝑀 + 1))) − (𝑁 mod (2↑𝑀))) / (2↑𝑀)) ∈ ℕ0 ↔
((((𝑁 mod (2↑(𝑀 + 1))) − (𝑁 mod (2↑𝑀))) / (2↑𝑀)) ∈ ℤ ∧ 0 ≤ (((𝑁 mod (2↑(𝑀 + 1))) − (𝑁 mod (2↑𝑀))) / (2↑𝑀)))) |
117 | 71, 115, 116 | sylanbrc 583 |
. . . . . . . . . . . 12
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ (((𝑁 mod
(2↑(𝑀 + 1))) −
(𝑁 mod (2↑𝑀))) / (2↑𝑀)) ∈
ℕ0) |
118 | | nn0uz 12620 |
. . . . . . . . . . . 12
⊢
ℕ0 = (ℤ≥‘0) |
119 | 117, 118 | eleqtrdi 2849 |
. . . . . . . . . . 11
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ (((𝑁 mod
(2↑(𝑀 + 1))) −
(𝑁 mod (2↑𝑀))) / (2↑𝑀)) ∈
(ℤ≥‘0)) |
120 | 16 | nnred 11988 |
. . . . . . . . . . . . . 14
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ (2↑(𝑀 + 1))
∈ ℝ) |
121 | | modge0 13599 |
. . . . . . . . . . . . . . . 16
⊢ ((𝑁 ∈ ℝ ∧
(2↑𝑀) ∈
ℝ+) → 0 ≤ (𝑁 mod (2↑𝑀))) |
122 | 37, 38, 121 | syl2anc 584 |
. . . . . . . . . . . . . . 15
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ 0 ≤ (𝑁 mod
(2↑𝑀))) |
123 | 93, 91 | subge02d 11567 |
. . . . . . . . . . . . . . 15
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ (0 ≤ (𝑁 mod
(2↑𝑀)) ↔ ((𝑁 mod (2↑(𝑀 + 1))) − (𝑁 mod (2↑𝑀))) ≤ (𝑁 mod (2↑(𝑀 + 1))))) |
124 | 122, 123 | mpbid 231 |
. . . . . . . . . . . . . 14
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ ((𝑁 mod
(2↑(𝑀 + 1))) −
(𝑁 mod (2↑𝑀))) ≤ (𝑁 mod (2↑(𝑀 + 1)))) |
125 | | modlt 13600 |
. . . . . . . . . . . . . . 15
⊢ ((𝑁 ∈ ℝ ∧
(2↑(𝑀 + 1)) ∈
ℝ+) → (𝑁 mod (2↑(𝑀 + 1))) < (2↑(𝑀 + 1))) |
126 | 37, 65, 125 | syl2anc 584 |
. . . . . . . . . . . . . 14
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ (𝑁 mod
(2↑(𝑀 + 1))) <
(2↑(𝑀 +
1))) |
127 | 94, 93, 120, 124, 126 | lelttrd 11133 |
. . . . . . . . . . . . 13
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ ((𝑁 mod
(2↑(𝑀 + 1))) −
(𝑁 mod (2↑𝑀))) < (2↑(𝑀 + 1))) |
128 | 127, 56 | breqtrd 5100 |
. . . . . . . . . . . 12
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ ((𝑁 mod
(2↑(𝑀 + 1))) −
(𝑁 mod (2↑𝑀))) < ((2↑𝑀) · 2)) |
129 | 7 | nnred 11988 |
. . . . . . . . . . . . 13
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ 2 ∈ ℝ) |
130 | 94, 129, 38 | ltdivmuld 12823 |
. . . . . . . . . . . 12
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ ((((𝑁 mod
(2↑(𝑀 + 1))) −
(𝑁 mod (2↑𝑀))) / (2↑𝑀)) < 2 ↔ ((𝑁 mod (2↑(𝑀 + 1))) − (𝑁 mod (2↑𝑀))) < ((2↑𝑀) · 2))) |
131 | 128, 130 | mpbird 256 |
. . . . . . . . . . 11
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ (((𝑁 mod
(2↑(𝑀 + 1))) −
(𝑁 mod (2↑𝑀))) / (2↑𝑀)) < 2) |
132 | | elfzo2 13390 |
. . . . . . . . . . 11
⊢ ((((𝑁 mod (2↑(𝑀 + 1))) − (𝑁 mod (2↑𝑀))) / (2↑𝑀)) ∈ (0..^2) ↔ ((((𝑁 mod (2↑(𝑀 + 1))) − (𝑁 mod (2↑𝑀))) / (2↑𝑀)) ∈ (ℤ≥‘0)
∧ 2 ∈ ℤ ∧ (((𝑁 mod (2↑(𝑀 + 1))) − (𝑁 mod (2↑𝑀))) / (2↑𝑀)) < 2)) |
133 | 119, 43, 131, 132 | syl3anbrc 1342 |
. . . . . . . . . 10
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ (((𝑁 mod
(2↑(𝑀 + 1))) −
(𝑁 mod (2↑𝑀))) / (2↑𝑀)) ∈ (0..^2)) |
134 | | fzo0to2pr 13472 |
. . . . . . . . . 10
⊢ (0..^2) =
{0, 1} |
135 | 133, 134 | eleqtrdi 2849 |
. . . . . . . . 9
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ (((𝑁 mod
(2↑(𝑀 + 1))) −
(𝑁 mod (2↑𝑀))) / (2↑𝑀)) ∈ {0, 1}) |
136 | | elpri 4583 |
. . . . . . . . 9
⊢ ((((𝑁 mod (2↑(𝑀 + 1))) − (𝑁 mod (2↑𝑀))) / (2↑𝑀)) ∈ {0, 1} → ((((𝑁 mod (2↑(𝑀 + 1))) − (𝑁 mod (2↑𝑀))) / (2↑𝑀)) = 0 ∨ (((𝑁 mod (2↑(𝑀 + 1))) − (𝑁 mod (2↑𝑀))) / (2↑𝑀)) = 1)) |
137 | 135, 136 | syl 17 |
. . . . . . . 8
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ ((((𝑁 mod
(2↑(𝑀 + 1))) −
(𝑁 mod (2↑𝑀))) / (2↑𝑀)) = 0 ∨ (((𝑁 mod (2↑(𝑀 + 1))) − (𝑁 mod (2↑𝑀))) / (2↑𝑀)) = 1)) |
138 | 137 | ord 861 |
. . . . . . 7
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ (¬ (((𝑁 mod
(2↑(𝑀 + 1))) −
(𝑁 mod (2↑𝑀))) / (2↑𝑀)) = 0 → (((𝑁 mod (2↑(𝑀 + 1))) − (𝑁 mod (2↑𝑀))) / (2↑𝑀)) = 1)) |
139 | 86, 138 | syld 47 |
. . . . . 6
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ (𝑀 ∈
(bits‘𝑁) →
(((𝑁 mod (2↑(𝑀 + 1))) − (𝑁 mod (2↑𝑀))) / (2↑𝑀)) = 1)) |
140 | 139 | imp 407 |
. . . . 5
⊢ (((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑀 ∈
(bits‘𝑁)) →
(((𝑁 mod (2↑(𝑀 + 1))) − (𝑁 mod (2↑𝑀))) / (2↑𝑀)) = 1) |
141 | 22, 26, 32, 140 | diveq1d 11759 |
. . . 4
⊢ (((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑀 ∈
(bits‘𝑁)) →
((𝑁 mod (2↑(𝑀 + 1))) − (𝑁 mod (2↑𝑀))) = (2↑𝑀)) |
142 | 141 | oveq2d 7291 |
. . 3
⊢ (((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑀 ∈
(bits‘𝑁)) →
((𝑁 mod (2↑𝑀)) + ((𝑁 mod (2↑(𝑀 + 1))) − (𝑁 mod (2↑𝑀)))) = ((𝑁 mod (2↑𝑀)) + (2↑𝑀))) |
143 | 20, 142 | eqtr3d 2780 |
. 2
⊢ (((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑀 ∈
(bits‘𝑁)) →
(𝑁 mod (2↑(𝑀 + 1))) = ((𝑁 mod (2↑𝑀)) + (2↑𝑀))) |
144 | 18 | adantr 481 |
. . . 4
⊢ (((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ ¬ 𝑀 ∈
(bits‘𝑁)) →
(𝑁 mod (2↑(𝑀 + 1))) ∈
ℂ) |
145 | 11 | adantr 481 |
. . . 4
⊢ (((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ ¬ 𝑀 ∈
(bits‘𝑁)) →
(𝑁 mod (2↑𝑀)) ∈
ℂ) |
146 | 21 | adantr 481 |
. . . . 5
⊢ (((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ ¬ 𝑀 ∈
(bits‘𝑁)) →
((𝑁 mod (2↑(𝑀 + 1))) − (𝑁 mod (2↑𝑀))) ∈ ℂ) |
147 | 51 | adantr 481 |
. . . . 5
⊢ (((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ ¬ 𝑀 ∈
(bits‘𝑁)) →
(2↑𝑀) ∈
ℂ) |
148 | 31 | adantr 481 |
. . . . 5
⊢ (((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ ¬ 𝑀 ∈
(bits‘𝑁)) →
(2↑𝑀) ≠
0) |
149 | | n2dvds1 16077 |
. . . . . . . . . 10
⊢ ¬ 2
∥ 1 |
150 | | breq2 5078 |
. . . . . . . . . 10
⊢ ((((𝑁 mod (2↑(𝑀 + 1))) − (𝑁 mod (2↑𝑀))) / (2↑𝑀)) = 1 → (2 ∥ (((𝑁 mod (2↑(𝑀 + 1))) − (𝑁 mod (2↑𝑀))) / (2↑𝑀)) ↔ 2 ∥ 1)) |
151 | 149, 150 | mtbiri 327 |
. . . . . . . . 9
⊢ ((((𝑁 mod (2↑(𝑀 + 1))) − (𝑁 mod (2↑𝑀))) / (2↑𝑀)) = 1 → ¬ 2 ∥ (((𝑁 mod (2↑(𝑀 + 1))) − (𝑁 mod (2↑𝑀))) / (2↑𝑀))) |
152 | 138, 151 | syl6 35 |
. . . . . . . 8
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ (¬ (((𝑁 mod
(2↑(𝑀 + 1))) −
(𝑁 mod (2↑𝑀))) / (2↑𝑀)) = 0 → ¬ 2 ∥ (((𝑁 mod (2↑(𝑀 + 1))) − (𝑁 mod (2↑𝑀))) / (2↑𝑀)))) |
153 | 152, 83 | sylibrd 258 |
. . . . . . 7
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ (¬ (((𝑁 mod
(2↑(𝑀 + 1))) −
(𝑁 mod (2↑𝑀))) / (2↑𝑀)) = 0 → 𝑀 ∈ (bits‘𝑁))) |
154 | 153 | con1d 145 |
. . . . . 6
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ (¬ 𝑀 ∈
(bits‘𝑁) →
(((𝑁 mod (2↑(𝑀 + 1))) − (𝑁 mod (2↑𝑀))) / (2↑𝑀)) = 0)) |
155 | 154 | imp 407 |
. . . . 5
⊢ (((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ ¬ 𝑀 ∈
(bits‘𝑁)) →
(((𝑁 mod (2↑(𝑀 + 1))) − (𝑁 mod (2↑𝑀))) / (2↑𝑀)) = 0) |
156 | 146, 147,
148, 155 | diveq0d 11758 |
. . . 4
⊢ (((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ ¬ 𝑀 ∈
(bits‘𝑁)) →
((𝑁 mod (2↑(𝑀 + 1))) − (𝑁 mod (2↑𝑀))) = 0) |
157 | 144, 145,
156 | subeq0d 11340 |
. . 3
⊢ (((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ ¬ 𝑀 ∈
(bits‘𝑁)) →
(𝑁 mod (2↑(𝑀 + 1))) = (𝑁 mod (2↑𝑀))) |
158 | 145 | addid1d 11175 |
. . 3
⊢ (((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ ¬ 𝑀 ∈
(bits‘𝑁)) →
((𝑁 mod (2↑𝑀)) + 0) = (𝑁 mod (2↑𝑀))) |
159 | 157, 158 | eqtr4d 2781 |
. 2
⊢ (((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ ¬ 𝑀 ∈
(bits‘𝑁)) →
(𝑁 mod (2↑(𝑀 + 1))) = ((𝑁 mod (2↑𝑀)) + 0)) |
160 | 2, 4, 143, 159 | ifbothda 4497 |
1
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ (𝑁 mod
(2↑(𝑀 + 1))) = ((𝑁 mod (2↑𝑀)) + if(𝑀 ∈ (bits‘𝑁), (2↑𝑀), 0))) |