| Step | Hyp | Ref
| Expression |
| 1 | | simpl 109 |
. . . . . . . 8
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ 𝑁 ∈
ℤ) |
| 2 | | 2nn 9154 |
. . . . . . . . . 10
⊢ 2 ∈
ℕ |
| 3 | 2 | a1i 9 |
. . . . . . . . 9
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ 2 ∈ ℕ) |
| 4 | | simpr 110 |
. . . . . . . . 9
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ 𝑀 ∈
ℕ0) |
| 5 | 3, 4 | nnexpcld 10789 |
. . . . . . . 8
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ (2↑𝑀) ∈
ℕ) |
| 6 | 1, 5 | zmodcld 10439 |
. . . . . . 7
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ (𝑁 mod (2↑𝑀)) ∈
ℕ0) |
| 7 | 6 | nn0zd 9448 |
. . . . . 6
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ (𝑁 mod (2↑𝑀)) ∈
ℤ) |
| 8 | 7 | biantrurd 305 |
. . . . 5
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ ((𝑥 ∈
ℕ0 ∧ ¬ 2 ∥ (⌊‘((𝑁 mod (2↑𝑀)) / (2↑𝑥)))) ↔ ((𝑁 mod (2↑𝑀)) ∈ ℤ ∧ (𝑥 ∈ ℕ0 ∧ ¬ 2
∥ (⌊‘((𝑁
mod (2↑𝑀)) /
(2↑𝑥))))))) |
| 9 | 1 | ad2antrr 488 |
. . . . . . . . . . 11
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ 𝑥 < 𝑀) → 𝑁 ∈ ℤ) |
| 10 | | simplr 528 |
. . . . . . . . . . 11
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ 𝑥 < 𝑀) → 𝑥 ∈ ℕ0) |
| 11 | | bitsval2 12111 |
. . . . . . . . . . 11
⊢ ((𝑁 ∈ ℤ ∧ 𝑥 ∈ ℕ0)
→ (𝑥 ∈
(bits‘𝑁) ↔ ¬
2 ∥ (⌊‘(𝑁
/ (2↑𝑥))))) |
| 12 | 9, 10, 11 | syl2anc 411 |
. . . . . . . . . 10
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ 𝑥 < 𝑀) → (𝑥 ∈ (bits‘𝑁) ↔ ¬ 2 ∥
(⌊‘(𝑁 /
(2↑𝑥))))) |
| 13 | | simpr 110 |
. . . . . . . . . . 11
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ 𝑥 < 𝑀) → 𝑥 < 𝑀) |
| 14 | 13 | biantrud 304 |
. . . . . . . . . 10
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ 𝑥 < 𝑀) → (𝑥 ∈ (bits‘𝑁) ↔ (𝑥 ∈ (bits‘𝑁) ∧ 𝑥 < 𝑀))) |
| 15 | | 2z 9356 |
. . . . . . . . . . . . 13
⊢ 2 ∈
ℤ |
| 16 | 15 | a1i 9 |
. . . . . . . . . . . 12
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ 𝑥 < 𝑀) → 2 ∈ ℤ) |
| 17 | 2 | a1i 9 |
. . . . . . . . . . . . . . 15
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ 𝑥 < 𝑀) → 2 ∈ ℕ) |
| 18 | 17, 10 | nnexpcld 10789 |
. . . . . . . . . . . . . 14
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ 𝑥 < 𝑀) → (2↑𝑥) ∈ ℕ) |
| 19 | | znq 9700 |
. . . . . . . . . . . . . 14
⊢ ((𝑁 ∈ ℤ ∧
(2↑𝑥) ∈ ℕ)
→ (𝑁 / (2↑𝑥)) ∈
ℚ) |
| 20 | 9, 18, 19 | syl2anc 411 |
. . . . . . . . . . . . 13
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ 𝑥 < 𝑀) → (𝑁 / (2↑𝑥)) ∈ ℚ) |
| 21 | 20 | flqcld 10369 |
. . . . . . . . . . . 12
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ 𝑥 < 𝑀) → (⌊‘(𝑁 / (2↑𝑥))) ∈ ℤ) |
| 22 | 7 | ad2antrr 488 |
. . . . . . . . . . . . . 14
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ 𝑥 < 𝑀) → (𝑁 mod (2↑𝑀)) ∈ ℤ) |
| 23 | | znq 9700 |
. . . . . . . . . . . . . 14
⊢ (((𝑁 mod (2↑𝑀)) ∈ ℤ ∧ (2↑𝑥) ∈ ℕ) → ((𝑁 mod (2↑𝑀)) / (2↑𝑥)) ∈ ℚ) |
| 24 | 22, 18, 23 | syl2anc 411 |
. . . . . . . . . . . . 13
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ 𝑥 < 𝑀) → ((𝑁 mod (2↑𝑀)) / (2↑𝑥)) ∈ ℚ) |
| 25 | 24 | flqcld 10369 |
. . . . . . . . . . . 12
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ 𝑥 < 𝑀) → (⌊‘((𝑁 mod (2↑𝑀)) / (2↑𝑥))) ∈ ℤ) |
| 26 | 18 | nnzd 9449 |
. . . . . . . . . . . . . . . . 17
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ 𝑥 < 𝑀) → (2↑𝑥) ∈ ℤ) |
| 27 | 26, 16 | zmulcld 9456 |
. . . . . . . . . . . . . . . 16
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ 𝑥 < 𝑀) → ((2↑𝑥) · 2) ∈
ℤ) |
| 28 | 5 | ad2antrr 488 |
. . . . . . . . . . . . . . . . 17
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ 𝑥 < 𝑀) → (2↑𝑀) ∈ ℕ) |
| 29 | 28 | nnzd 9449 |
. . . . . . . . . . . . . . . 16
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ 𝑥 < 𝑀) → (2↑𝑀) ∈ ℤ) |
| 30 | 9, 22 | zsubcld 9455 |
. . . . . . . . . . . . . . . 16
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ 𝑥 < 𝑀) → (𝑁 − (𝑁 mod (2↑𝑀))) ∈ ℤ) |
| 31 | | 2cnd 9065 |
. . . . . . . . . . . . . . . . . 18
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ 𝑥 < 𝑀) → 2 ∈ ℂ) |
| 32 | 31, 10 | expp1d 10768 |
. . . . . . . . . . . . . . . . 17
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ 𝑥 < 𝑀) → (2↑(𝑥 + 1)) = ((2↑𝑥) · 2)) |
| 33 | | 1nn0 9267 |
. . . . . . . . . . . . . . . . . . . 20
⊢ 1 ∈
ℕ0 |
| 34 | 33 | a1i 9 |
. . . . . . . . . . . . . . . . . . 19
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ 𝑥 < 𝑀) → 1 ∈
ℕ0) |
| 35 | 10, 34 | nn0addcld 9308 |
. . . . . . . . . . . . . . . . . 18
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ 𝑥 < 𝑀) → (𝑥 + 1) ∈
ℕ0) |
| 36 | 35 | nn0zd 9448 |
. . . . . . . . . . . . . . . . . . 19
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ 𝑥 < 𝑀) → (𝑥 + 1) ∈ ℤ) |
| 37 | | simplr 528 |
. . . . . . . . . . . . . . . . . . . . 21
⊢ (((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) → 𝑀 ∈
ℕ0) |
| 38 | 37 | adantr 276 |
. . . . . . . . . . . . . . . . . . . 20
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ 𝑥 < 𝑀) → 𝑀 ∈
ℕ0) |
| 39 | 38 | nn0zd 9448 |
. . . . . . . . . . . . . . . . . . 19
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ 𝑥 < 𝑀) → 𝑀 ∈ ℤ) |
| 40 | | nn0ltp1le 9390 |
. . . . . . . . . . . . . . . . . . . . 21
⊢ ((𝑥 ∈ ℕ0
∧ 𝑀 ∈
ℕ0) → (𝑥 < 𝑀 ↔ (𝑥 + 1) ≤ 𝑀)) |
| 41 | 10, 38, 40 | syl2anc 411 |
. . . . . . . . . . . . . . . . . . . 20
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ 𝑥 < 𝑀) → (𝑥 < 𝑀 ↔ (𝑥 + 1) ≤ 𝑀)) |
| 42 | 13, 41 | mpbid 147 |
. . . . . . . . . . . . . . . . . . 19
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ 𝑥 < 𝑀) → (𝑥 + 1) ≤ 𝑀) |
| 43 | | eluz2 9609 |
. . . . . . . . . . . . . . . . . . 19
⊢ (𝑀 ∈
(ℤ≥‘(𝑥 + 1)) ↔ ((𝑥 + 1) ∈ ℤ ∧ 𝑀 ∈ ℤ ∧ (𝑥 + 1) ≤ 𝑀)) |
| 44 | 36, 39, 42, 43 | syl3anbrc 1183 |
. . . . . . . . . . . . . . . . . 18
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ 𝑥 < 𝑀) → 𝑀 ∈ (ℤ≥‘(𝑥 + 1))) |
| 45 | | dvdsexp 12028 |
. . . . . . . . . . . . . . . . . 18
⊢ ((2
∈ ℤ ∧ (𝑥 +
1) ∈ ℕ0 ∧ 𝑀 ∈ (ℤ≥‘(𝑥 + 1))) → (2↑(𝑥 + 1)) ∥ (2↑𝑀)) |
| 46 | 16, 35, 44, 45 | syl3anc 1249 |
. . . . . . . . . . . . . . . . 17
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ 𝑥 < 𝑀) → (2↑(𝑥 + 1)) ∥ (2↑𝑀)) |
| 47 | 32, 46 | eqbrtrrd 4058 |
. . . . . . . . . . . . . . . 16
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ 𝑥 < 𝑀) → ((2↑𝑥) · 2) ∥ (2↑𝑀)) |
| 48 | | zq 9702 |
. . . . . . . . . . . . . . . . . . 19
⊢ (𝑁 ∈ ℤ → 𝑁 ∈
ℚ) |
| 49 | 9, 48 | syl 14 |
. . . . . . . . . . . . . . . . . 18
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ 𝑥 < 𝑀) → 𝑁 ∈ ℚ) |
| 50 | | nnq 9709 |
. . . . . . . . . . . . . . . . . . 19
⊢
((2↑𝑀) ∈
ℕ → (2↑𝑀)
∈ ℚ) |
| 51 | 28, 50 | syl 14 |
. . . . . . . . . . . . . . . . . 18
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ 𝑥 < 𝑀) → (2↑𝑀) ∈ ℚ) |
| 52 | 28 | nngt0d 9036 |
. . . . . . . . . . . . . . . . . 18
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ 𝑥 < 𝑀) → 0 < (2↑𝑀)) |
| 53 | | modqdifz 10430 |
. . . . . . . . . . . . . . . . . 18
⊢ ((𝑁 ∈ ℚ ∧
(2↑𝑀) ∈ ℚ
∧ 0 < (2↑𝑀))
→ ((𝑁 − (𝑁 mod (2↑𝑀))) / (2↑𝑀)) ∈ ℤ) |
| 54 | 49, 51, 52, 53 | syl3anc 1249 |
. . . . . . . . . . . . . . . . 17
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ 𝑥 < 𝑀) → ((𝑁 − (𝑁 mod (2↑𝑀))) / (2↑𝑀)) ∈ ℤ) |
| 55 | 28 | nnne0d 9037 |
. . . . . . . . . . . . . . . . . 18
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ 𝑥 < 𝑀) → (2↑𝑀) ≠ 0) |
| 56 | | dvdsval2 11957 |
. . . . . . . . . . . . . . . . . 18
⊢
(((2↑𝑀) ∈
ℤ ∧ (2↑𝑀)
≠ 0 ∧ (𝑁 −
(𝑁 mod (2↑𝑀))) ∈ ℤ) →
((2↑𝑀) ∥ (𝑁 − (𝑁 mod (2↑𝑀))) ↔ ((𝑁 − (𝑁 mod (2↑𝑀))) / (2↑𝑀)) ∈ ℤ)) |
| 57 | 29, 55, 30, 56 | syl3anc 1249 |
. . . . . . . . . . . . . . . . 17
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ 𝑥 < 𝑀) → ((2↑𝑀) ∥ (𝑁 − (𝑁 mod (2↑𝑀))) ↔ ((𝑁 − (𝑁 mod (2↑𝑀))) / (2↑𝑀)) ∈ ℤ)) |
| 58 | 54, 57 | mpbird 167 |
. . . . . . . . . . . . . . . 16
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ 𝑥 < 𝑀) → (2↑𝑀) ∥ (𝑁 − (𝑁 mod (2↑𝑀)))) |
| 59 | 27, 29, 30, 47, 58 | dvdstrd 11997 |
. . . . . . . . . . . . . . 15
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ 𝑥 < 𝑀) → ((2↑𝑥) · 2) ∥ (𝑁 − (𝑁 mod (2↑𝑀)))) |
| 60 | 30 | zcnd 9451 |
. . . . . . . . . . . . . . . 16
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ 𝑥 < 𝑀) → (𝑁 − (𝑁 mod (2↑𝑀))) ∈ ℂ) |
| 61 | 18 | nncnd 9006 |
. . . . . . . . . . . . . . . 16
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ 𝑥 < 𝑀) → (2↑𝑥) ∈ ℂ) |
| 62 | 18 | nnap0d 9038 |
. . . . . . . . . . . . . . . 16
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ 𝑥 < 𝑀) → (2↑𝑥) # 0) |
| 63 | 60, 61, 62 | divcanap2d 8821 |
. . . . . . . . . . . . . . 15
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ 𝑥 < 𝑀) → ((2↑𝑥) · ((𝑁 − (𝑁 mod (2↑𝑀))) / (2↑𝑥))) = (𝑁 − (𝑁 mod (2↑𝑀)))) |
| 64 | 59, 63 | breqtrrd 4062 |
. . . . . . . . . . . . . 14
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ 𝑥 < 𝑀) → ((2↑𝑥) · 2) ∥ ((2↑𝑥) · ((𝑁 − (𝑁 mod (2↑𝑀))) / (2↑𝑥)))) |
| 65 | 10 | nn0zd 9448 |
. . . . . . . . . . . . . . . . . . 19
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ 𝑥 < 𝑀) → 𝑥 ∈ ℤ) |
| 66 | 10 | nn0red 9305 |
. . . . . . . . . . . . . . . . . . . 20
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ 𝑥 < 𝑀) → 𝑥 ∈ ℝ) |
| 67 | 38 | nn0red 9305 |
. . . . . . . . . . . . . . . . . . . 20
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ 𝑥 < 𝑀) → 𝑀 ∈ ℝ) |
| 68 | 66, 67, 13 | ltled 8147 |
. . . . . . . . . . . . . . . . . . 19
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ 𝑥 < 𝑀) → 𝑥 ≤ 𝑀) |
| 69 | | eluz2 9609 |
. . . . . . . . . . . . . . . . . . 19
⊢ (𝑀 ∈
(ℤ≥‘𝑥) ↔ (𝑥 ∈ ℤ ∧ 𝑀 ∈ ℤ ∧ 𝑥 ≤ 𝑀)) |
| 70 | 65, 39, 68, 69 | syl3anbrc 1183 |
. . . . . . . . . . . . . . . . . 18
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ 𝑥 < 𝑀) → 𝑀 ∈ (ℤ≥‘𝑥)) |
| 71 | | dvdsexp 12028 |
. . . . . . . . . . . . . . . . . 18
⊢ ((2
∈ ℤ ∧ 𝑥
∈ ℕ0 ∧ 𝑀 ∈ (ℤ≥‘𝑥)) → (2↑𝑥) ∥ (2↑𝑀)) |
| 72 | 16, 10, 70, 71 | syl3anc 1249 |
. . . . . . . . . . . . . . . . 17
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ 𝑥 < 𝑀) → (2↑𝑥) ∥ (2↑𝑀)) |
| 73 | 26, 29, 30, 72, 58 | dvdstrd 11997 |
. . . . . . . . . . . . . . . 16
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ 𝑥 < 𝑀) → (2↑𝑥) ∥ (𝑁 − (𝑁 mod (2↑𝑀)))) |
| 74 | 18 | nnne0d 9037 |
. . . . . . . . . . . . . . . . 17
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ 𝑥 < 𝑀) → (2↑𝑥) ≠ 0) |
| 75 | | dvdsval2 11957 |
. . . . . . . . . . . . . . . . 17
⊢
(((2↑𝑥) ∈
ℤ ∧ (2↑𝑥)
≠ 0 ∧ (𝑁 −
(𝑁 mod (2↑𝑀))) ∈ ℤ) →
((2↑𝑥) ∥ (𝑁 − (𝑁 mod (2↑𝑀))) ↔ ((𝑁 − (𝑁 mod (2↑𝑀))) / (2↑𝑥)) ∈ ℤ)) |
| 76 | 26, 74, 30, 75 | syl3anc 1249 |
. . . . . . . . . . . . . . . 16
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ 𝑥 < 𝑀) → ((2↑𝑥) ∥ (𝑁 − (𝑁 mod (2↑𝑀))) ↔ ((𝑁 − (𝑁 mod (2↑𝑀))) / (2↑𝑥)) ∈ ℤ)) |
| 77 | 73, 76 | mpbid 147 |
. . . . . . . . . . . . . . 15
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ 𝑥 < 𝑀) → ((𝑁 − (𝑁 mod (2↑𝑀))) / (2↑𝑥)) ∈ ℤ) |
| 78 | | dvdscmulr 11987 |
. . . . . . . . . . . . . . 15
⊢ ((2
∈ ℤ ∧ ((𝑁
− (𝑁 mod
(2↑𝑀))) /
(2↑𝑥)) ∈ ℤ
∧ ((2↑𝑥) ∈
ℤ ∧ (2↑𝑥)
≠ 0)) → (((2↑𝑥) · 2) ∥ ((2↑𝑥) · ((𝑁 − (𝑁 mod (2↑𝑀))) / (2↑𝑥))) ↔ 2 ∥ ((𝑁 − (𝑁 mod (2↑𝑀))) / (2↑𝑥)))) |
| 79 | 16, 77, 26, 74, 78 | syl112anc 1253 |
. . . . . . . . . . . . . 14
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ 𝑥 < 𝑀) → (((2↑𝑥) · 2) ∥ ((2↑𝑥) · ((𝑁 − (𝑁 mod (2↑𝑀))) / (2↑𝑥))) ↔ 2 ∥ ((𝑁 − (𝑁 mod (2↑𝑀))) / (2↑𝑥)))) |
| 80 | 64, 79 | mpbid 147 |
. . . . . . . . . . . . 13
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ 𝑥 < 𝑀) → 2 ∥ ((𝑁 − (𝑁 mod (2↑𝑀))) / (2↑𝑥))) |
| 81 | 25 | zcnd 9451 |
. . . . . . . . . . . . . 14
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ 𝑥 < 𝑀) → (⌊‘((𝑁 mod (2↑𝑀)) / (2↑𝑥))) ∈ ℂ) |
| 82 | 77 | zcnd 9451 |
. . . . . . . . . . . . . 14
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ 𝑥 < 𝑀) → ((𝑁 − (𝑁 mod (2↑𝑀))) / (2↑𝑥)) ∈ ℂ) |
| 83 | 22 | zcnd 9451 |
. . . . . . . . . . . . . . . . . . 19
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ 𝑥 < 𝑀) → (𝑁 mod (2↑𝑀)) ∈ ℂ) |
| 84 | 9 | zcnd 9451 |
. . . . . . . . . . . . . . . . . . 19
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ 𝑥 < 𝑀) → 𝑁 ∈ ℂ) |
| 85 | 83, 84 | pncan3d 8342 |
. . . . . . . . . . . . . . . . . 18
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ 𝑥 < 𝑀) → ((𝑁 mod (2↑𝑀)) + (𝑁 − (𝑁 mod (2↑𝑀)))) = 𝑁) |
| 86 | 85 | oveq1d 5938 |
. . . . . . . . . . . . . . . . 17
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ 𝑥 < 𝑀) → (((𝑁 mod (2↑𝑀)) + (𝑁 − (𝑁 mod (2↑𝑀)))) / (2↑𝑥)) = (𝑁 / (2↑𝑥))) |
| 87 | 83, 60, 61, 62 | divdirapd 8858 |
. . . . . . . . . . . . . . . . 17
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ 𝑥 < 𝑀) → (((𝑁 mod (2↑𝑀)) + (𝑁 − (𝑁 mod (2↑𝑀)))) / (2↑𝑥)) = (((𝑁 mod (2↑𝑀)) / (2↑𝑥)) + ((𝑁 − (𝑁 mod (2↑𝑀))) / (2↑𝑥)))) |
| 88 | 86, 87 | eqtr3d 2231 |
. . . . . . . . . . . . . . . 16
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ 𝑥 < 𝑀) → (𝑁 / (2↑𝑥)) = (((𝑁 mod (2↑𝑀)) / (2↑𝑥)) + ((𝑁 − (𝑁 mod (2↑𝑀))) / (2↑𝑥)))) |
| 89 | 88 | fveq2d 5563 |
. . . . . . . . . . . . . . 15
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ 𝑥 < 𝑀) → (⌊‘(𝑁 / (2↑𝑥))) = (⌊‘(((𝑁 mod (2↑𝑀)) / (2↑𝑥)) + ((𝑁 − (𝑁 mod (2↑𝑀))) / (2↑𝑥))))) |
| 90 | | flqaddz 10389 |
. . . . . . . . . . . . . . . 16
⊢ ((((𝑁 mod (2↑𝑀)) / (2↑𝑥)) ∈ ℚ ∧ ((𝑁 − (𝑁 mod (2↑𝑀))) / (2↑𝑥)) ∈ ℤ) →
(⌊‘(((𝑁 mod
(2↑𝑀)) / (2↑𝑥)) + ((𝑁 − (𝑁 mod (2↑𝑀))) / (2↑𝑥)))) = ((⌊‘((𝑁 mod (2↑𝑀)) / (2↑𝑥))) + ((𝑁 − (𝑁 mod (2↑𝑀))) / (2↑𝑥)))) |
| 91 | 24, 77, 90 | syl2anc 411 |
. . . . . . . . . . . . . . 15
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ 𝑥 < 𝑀) → (⌊‘(((𝑁 mod (2↑𝑀)) / (2↑𝑥)) + ((𝑁 − (𝑁 mod (2↑𝑀))) / (2↑𝑥)))) = ((⌊‘((𝑁 mod (2↑𝑀)) / (2↑𝑥))) + ((𝑁 − (𝑁 mod (2↑𝑀))) / (2↑𝑥)))) |
| 92 | 89, 91 | eqtrd 2229 |
. . . . . . . . . . . . . 14
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ 𝑥 < 𝑀) → (⌊‘(𝑁 / (2↑𝑥))) = ((⌊‘((𝑁 mod (2↑𝑀)) / (2↑𝑥))) + ((𝑁 − (𝑁 mod (2↑𝑀))) / (2↑𝑥)))) |
| 93 | 81, 82, 92 | mvrladdd 8395 |
. . . . . . . . . . . . 13
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ 𝑥 < 𝑀) → ((⌊‘(𝑁 / (2↑𝑥))) − (⌊‘((𝑁 mod (2↑𝑀)) / (2↑𝑥)))) = ((𝑁 − (𝑁 mod (2↑𝑀))) / (2↑𝑥))) |
| 94 | 80, 93 | breqtrrd 4062 |
. . . . . . . . . . . 12
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ 𝑥 < 𝑀) → 2 ∥ ((⌊‘(𝑁 / (2↑𝑥))) − (⌊‘((𝑁 mod (2↑𝑀)) / (2↑𝑥))))) |
| 95 | | dvdssub2 12002 |
. . . . . . . . . . . 12
⊢ (((2
∈ ℤ ∧ (⌊‘(𝑁 / (2↑𝑥))) ∈ ℤ ∧
(⌊‘((𝑁 mod
(2↑𝑀)) / (2↑𝑥))) ∈ ℤ) ∧ 2
∥ ((⌊‘(𝑁
/ (2↑𝑥))) −
(⌊‘((𝑁 mod
(2↑𝑀)) / (2↑𝑥))))) → (2 ∥
(⌊‘(𝑁 /
(2↑𝑥))) ↔ 2
∥ (⌊‘((𝑁
mod (2↑𝑀)) /
(2↑𝑥))))) |
| 96 | 16, 21, 25, 94, 95 | syl31anc 1252 |
. . . . . . . . . . 11
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ 𝑥 < 𝑀) → (2 ∥ (⌊‘(𝑁 / (2↑𝑥))) ↔ 2 ∥ (⌊‘((𝑁 mod (2↑𝑀)) / (2↑𝑥))))) |
| 97 | 96 | notbid 668 |
. . . . . . . . . 10
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ 𝑥 < 𝑀) → (¬ 2 ∥
(⌊‘(𝑁 /
(2↑𝑥))) ↔ ¬ 2
∥ (⌊‘((𝑁
mod (2↑𝑀)) /
(2↑𝑥))))) |
| 98 | 12, 14, 97 | 3bitr3d 218 |
. . . . . . . . 9
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ 𝑥 < 𝑀) → ((𝑥 ∈ (bits‘𝑁) ∧ 𝑥 < 𝑀) ↔ ¬ 2 ∥
(⌊‘((𝑁 mod
(2↑𝑀)) / (2↑𝑥))))) |
| 99 | | simpr 110 |
. . . . . . . . . . 11
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ ¬ 𝑥 < 𝑀) → ¬ 𝑥 < 𝑀) |
| 100 | 99 | intnand 932 |
. . . . . . . . . 10
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ ¬ 𝑥 < 𝑀) → ¬ (𝑥 ∈ (bits‘𝑁) ∧ 𝑥 < 𝑀)) |
| 101 | | z0even 12078 |
. . . . . . . . . . . 12
⊢ 2 ∥
0 |
| 102 | 1 | ad2antrr 488 |
. . . . . . . . . . . . . . . . 17
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ ¬ 𝑥 < 𝑀) → 𝑁 ∈ ℤ) |
| 103 | 102, 48 | syl 14 |
. . . . . . . . . . . . . . . 16
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ ¬ 𝑥 < 𝑀) → 𝑁 ∈ ℚ) |
| 104 | 5 | ad2antrr 488 |
. . . . . . . . . . . . . . . . 17
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ ¬ 𝑥 < 𝑀) → (2↑𝑀) ∈ ℕ) |
| 105 | 104, 50 | syl 14 |
. . . . . . . . . . . . . . . 16
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ ¬ 𝑥 < 𝑀) → (2↑𝑀) ∈ ℚ) |
| 106 | | 2rp 9735 |
. . . . . . . . . . . . . . . . . . 19
⊢ 2 ∈
ℝ+ |
| 107 | 106 | a1i 9 |
. . . . . . . . . . . . . . . . . 18
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ ¬ 𝑥 < 𝑀) → 2 ∈
ℝ+) |
| 108 | 37 | nn0zd 9448 |
. . . . . . . . . . . . . . . . . . 19
⊢ (((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) → 𝑀 ∈ ℤ) |
| 109 | 108 | adantr 276 |
. . . . . . . . . . . . . . . . . 18
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ ¬ 𝑥 < 𝑀) → 𝑀 ∈ ℤ) |
| 110 | 107, 109 | rpexpcld 10791 |
. . . . . . . . . . . . . . . . 17
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ ¬ 𝑥 < 𝑀) → (2↑𝑀) ∈
ℝ+) |
| 111 | 110 | rpgt0d 9776 |
. . . . . . . . . . . . . . . 16
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ ¬ 𝑥 < 𝑀) → 0 < (2↑𝑀)) |
| 112 | 103, 105,
111 | modqcld 10422 |
. . . . . . . . . . . . . . 15
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ ¬ 𝑥 < 𝑀) → (𝑁 mod (2↑𝑀)) ∈ ℚ) |
| 113 | | qre 9701 |
. . . . . . . . . . . . . . 15
⊢ ((𝑁 mod (2↑𝑀)) ∈ ℚ → (𝑁 mod (2↑𝑀)) ∈ ℝ) |
| 114 | 112, 113 | syl 14 |
. . . . . . . . . . . . . 14
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ ¬ 𝑥 < 𝑀) → (𝑁 mod (2↑𝑀)) ∈ ℝ) |
| 115 | | simplr 528 |
. . . . . . . . . . . . . . . 16
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ ¬ 𝑥 < 𝑀) → 𝑥 ∈ ℕ0) |
| 116 | 115 | nn0zd 9448 |
. . . . . . . . . . . . . . 15
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ ¬ 𝑥 < 𝑀) → 𝑥 ∈ ℤ) |
| 117 | 107, 116 | rpexpcld 10791 |
. . . . . . . . . . . . . 14
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ ¬ 𝑥 < 𝑀) → (2↑𝑥) ∈
ℝ+) |
| 118 | 6 | ad2antrr 488 |
. . . . . . . . . . . . . . 15
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ ¬ 𝑥 < 𝑀) → (𝑁 mod (2↑𝑀)) ∈
ℕ0) |
| 119 | 118 | nn0ge0d 9307 |
. . . . . . . . . . . . . 14
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ ¬ 𝑥 < 𝑀) → 0 ≤ (𝑁 mod (2↑𝑀))) |
| 120 | 114, 117,
119 | divge0d 9814 |
. . . . . . . . . . . . 13
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ ¬ 𝑥 < 𝑀) → 0 ≤ ((𝑁 mod (2↑𝑀)) / (2↑𝑥))) |
| 121 | 110 | rpred 9773 |
. . . . . . . . . . . . . . . . 17
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ ¬ 𝑥 < 𝑀) → (2↑𝑀) ∈ ℝ) |
| 122 | 117 | rpred 9773 |
. . . . . . . . . . . . . . . . 17
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ ¬ 𝑥 < 𝑀) → (2↑𝑥) ∈ ℝ) |
| 123 | | modqlt 10427 |
. . . . . . . . . . . . . . . . . 18
⊢ ((𝑁 ∈ ℚ ∧
(2↑𝑀) ∈ ℚ
∧ 0 < (2↑𝑀))
→ (𝑁 mod (2↑𝑀)) < (2↑𝑀)) |
| 124 | 103, 105,
111, 123 | syl3anc 1249 |
. . . . . . . . . . . . . . . . 17
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ ¬ 𝑥 < 𝑀) → (𝑁 mod (2↑𝑀)) < (2↑𝑀)) |
| 125 | 107 | rpred 9773 |
. . . . . . . . . . . . . . . . . 18
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ ¬ 𝑥 < 𝑀) → 2 ∈ ℝ) |
| 126 | | 1le2 9201 |
. . . . . . . . . . . . . . . . . . 19
⊢ 1 ≤
2 |
| 127 | 126 | a1i 9 |
. . . . . . . . . . . . . . . . . 18
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ ¬ 𝑥 < 𝑀) → 1 ≤ 2) |
| 128 | 109 | zred 9450 |
. . . . . . . . . . . . . . . . . . . 20
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ ¬ 𝑥 < 𝑀) → 𝑀 ∈ ℝ) |
| 129 | 115 | nn0red 9305 |
. . . . . . . . . . . . . . . . . . . 20
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ ¬ 𝑥 < 𝑀) → 𝑥 ∈ ℝ) |
| 130 | 128, 129,
99 | nltled 8149 |
. . . . . . . . . . . . . . . . . . 19
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ ¬ 𝑥 < 𝑀) → 𝑀 ≤ 𝑥) |
| 131 | | eluz2 9609 |
. . . . . . . . . . . . . . . . . . 19
⊢ (𝑥 ∈
(ℤ≥‘𝑀) ↔ (𝑀 ∈ ℤ ∧ 𝑥 ∈ ℤ ∧ 𝑀 ≤ 𝑥)) |
| 132 | 109, 116,
130, 131 | syl3anbrc 1183 |
. . . . . . . . . . . . . . . . . 18
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ ¬ 𝑥 < 𝑀) → 𝑥 ∈ (ℤ≥‘𝑀)) |
| 133 | 125, 127,
132 | leexp2ad 10796 |
. . . . . . . . . . . . . . . . 17
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ ¬ 𝑥 < 𝑀) → (2↑𝑀) ≤ (2↑𝑥)) |
| 134 | 114, 121,
122, 124, 133 | ltletrd 8452 |
. . . . . . . . . . . . . . . 16
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ ¬ 𝑥 < 𝑀) → (𝑁 mod (2↑𝑀)) < (2↑𝑥)) |
| 135 | 117 | rpcnd 9775 |
. . . . . . . . . . . . . . . . 17
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ ¬ 𝑥 < 𝑀) → (2↑𝑥) ∈ ℂ) |
| 136 | 135 | mulridd 8045 |
. . . . . . . . . . . . . . . 16
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ ¬ 𝑥 < 𝑀) → ((2↑𝑥) · 1) = (2↑𝑥)) |
| 137 | 134, 136 | breqtrrd 4062 |
. . . . . . . . . . . . . . 15
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ ¬ 𝑥 < 𝑀) → (𝑁 mod (2↑𝑀)) < ((2↑𝑥) · 1)) |
| 138 | | 1red 8043 |
. . . . . . . . . . . . . . . 16
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ ¬ 𝑥 < 𝑀) → 1 ∈ ℝ) |
| 139 | 114, 138,
117 | ltdivmuld 9825 |
. . . . . . . . . . . . . . 15
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ ¬ 𝑥 < 𝑀) → (((𝑁 mod (2↑𝑀)) / (2↑𝑥)) < 1 ↔ (𝑁 mod (2↑𝑀)) < ((2↑𝑥) · 1))) |
| 140 | 137, 139 | mpbird 167 |
. . . . . . . . . . . . . 14
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ ¬ 𝑥 < 𝑀) → ((𝑁 mod (2↑𝑀)) / (2↑𝑥)) < 1) |
| 141 | | 1e0p1 9500 |
. . . . . . . . . . . . . 14
⊢ 1 = (0 +
1) |
| 142 | 140, 141 | breqtrdi 4075 |
. . . . . . . . . . . . 13
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ ¬ 𝑥 < 𝑀) → ((𝑁 mod (2↑𝑀)) / (2↑𝑥)) < (0 + 1)) |
| 143 | 7 | ad2antrr 488 |
. . . . . . . . . . . . . . 15
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ ¬ 𝑥 < 𝑀) → (𝑁 mod (2↑𝑀)) ∈ ℤ) |
| 144 | 2 | a1i 9 |
. . . . . . . . . . . . . . . 16
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ ¬ 𝑥 < 𝑀) → 2 ∈ ℕ) |
| 145 | 144, 115 | nnexpcld 10789 |
. . . . . . . . . . . . . . 15
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ ¬ 𝑥 < 𝑀) → (2↑𝑥) ∈ ℕ) |
| 146 | 143, 145,
23 | syl2anc 411 |
. . . . . . . . . . . . . 14
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ ¬ 𝑥 < 𝑀) → ((𝑁 mod (2↑𝑀)) / (2↑𝑥)) ∈ ℚ) |
| 147 | | 0z 9339 |
. . . . . . . . . . . . . 14
⊢ 0 ∈
ℤ |
| 148 | | flqbi 10382 |
. . . . . . . . . . . . . 14
⊢ ((((𝑁 mod (2↑𝑀)) / (2↑𝑥)) ∈ ℚ ∧ 0 ∈ ℤ)
→ ((⌊‘((𝑁
mod (2↑𝑀)) /
(2↑𝑥))) = 0 ↔ (0
≤ ((𝑁 mod (2↑𝑀)) / (2↑𝑥)) ∧ ((𝑁 mod (2↑𝑀)) / (2↑𝑥)) < (0 + 1)))) |
| 149 | 146, 147,
148 | sylancl 413 |
. . . . . . . . . . . . 13
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ ¬ 𝑥 < 𝑀) → ((⌊‘((𝑁 mod (2↑𝑀)) / (2↑𝑥))) = 0 ↔ (0 ≤ ((𝑁 mod (2↑𝑀)) / (2↑𝑥)) ∧ ((𝑁 mod (2↑𝑀)) / (2↑𝑥)) < (0 + 1)))) |
| 150 | 120, 142,
149 | mpbir2and 946 |
. . . . . . . . . . . 12
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ ¬ 𝑥 < 𝑀) → (⌊‘((𝑁 mod (2↑𝑀)) / (2↑𝑥))) = 0) |
| 151 | 101, 150 | breqtrrid 4072 |
. . . . . . . . . . 11
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ ¬ 𝑥 < 𝑀) → 2 ∥ (⌊‘((𝑁 mod (2↑𝑀)) / (2↑𝑥)))) |
| 152 | 151 | notnotd 631 |
. . . . . . . . . 10
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ ¬ 𝑥 < 𝑀) → ¬ ¬ 2 ∥
(⌊‘((𝑁 mod
(2↑𝑀)) / (2↑𝑥)))) |
| 153 | 100, 152 | 2falsed 703 |
. . . . . . . . 9
⊢ ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) ∧ ¬ 𝑥 < 𝑀) → ((𝑥 ∈ (bits‘𝑁) ∧ 𝑥 < 𝑀) ↔ ¬ 2 ∥
(⌊‘((𝑁 mod
(2↑𝑀)) / (2↑𝑥))))) |
| 154 | | nn0z 9348 |
. . . . . . . . . . 11
⊢ (𝑥 ∈ ℕ0
→ 𝑥 ∈
ℤ) |
| 155 | | zdclt 9405 |
. . . . . . . . . . 11
⊢ ((𝑥 ∈ ℤ ∧ 𝑀 ∈ ℤ) →
DECID 𝑥 <
𝑀) |
| 156 | 154, 108,
155 | syl2an2 594 |
. . . . . . . . . 10
⊢ (((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) → DECID 𝑥 < 𝑀) |
| 157 | | exmiddc 837 |
. . . . . . . . . 10
⊢
(DECID 𝑥 < 𝑀 → (𝑥 < 𝑀 ∨ ¬ 𝑥 < 𝑀)) |
| 158 | 156, 157 | syl 14 |
. . . . . . . . 9
⊢ (((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) → (𝑥 < 𝑀 ∨ ¬ 𝑥 < 𝑀)) |
| 159 | 98, 153, 158 | mpjaodan 799 |
. . . . . . . 8
⊢ (((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) → ((𝑥 ∈ (bits‘𝑁) ∧ 𝑥 < 𝑀) ↔ ¬ 2 ∥
(⌊‘((𝑁 mod
(2↑𝑀)) / (2↑𝑥))))) |
| 160 | 108 | biantrurd 305 |
. . . . . . . 8
⊢ (((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) → ((𝑥 ∈ (bits‘𝑁) ∧ 𝑥 < 𝑀) ↔ (𝑀 ∈ ℤ ∧ (𝑥 ∈ (bits‘𝑁) ∧ 𝑥 < 𝑀)))) |
| 161 | 159, 160 | bitr3d 190 |
. . . . . . 7
⊢ (((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) → (¬ 2 ∥ (⌊‘((𝑁 mod (2↑𝑀)) / (2↑𝑥))) ↔ (𝑀 ∈ ℤ ∧ (𝑥 ∈ (bits‘𝑁) ∧ 𝑥 < 𝑀)))) |
| 162 | | an12 561 |
. . . . . . 7
⊢ ((𝑀 ∈ ℤ ∧ (𝑥 ∈ (bits‘𝑁) ∧ 𝑥 < 𝑀)) ↔ (𝑥 ∈ (bits‘𝑁) ∧ (𝑀 ∈ ℤ ∧ 𝑥 < 𝑀))) |
| 163 | 161, 162 | bitrdi 196 |
. . . . . 6
⊢ (((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
∧ 𝑥 ∈
ℕ0) → (¬ 2 ∥ (⌊‘((𝑁 mod (2↑𝑀)) / (2↑𝑥))) ↔ (𝑥 ∈ (bits‘𝑁) ∧ (𝑀 ∈ ℤ ∧ 𝑥 < 𝑀)))) |
| 164 | 163 | pm5.32da 452 |
. . . . 5
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ ((𝑥 ∈
ℕ0 ∧ ¬ 2 ∥ (⌊‘((𝑁 mod (2↑𝑀)) / (2↑𝑥)))) ↔ (𝑥 ∈ ℕ0 ∧ (𝑥 ∈ (bits‘𝑁) ∧ (𝑀 ∈ ℤ ∧ 𝑥 < 𝑀))))) |
| 165 | 8, 164 | bitr3d 190 |
. . . 4
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ (((𝑁 mod
(2↑𝑀)) ∈ ℤ
∧ (𝑥 ∈
ℕ0 ∧ ¬ 2 ∥ (⌊‘((𝑁 mod (2↑𝑀)) / (2↑𝑥))))) ↔ (𝑥 ∈ ℕ0 ∧ (𝑥 ∈ (bits‘𝑁) ∧ (𝑀 ∈ ℤ ∧ 𝑥 < 𝑀))))) |
| 166 | | 3anass 984 |
. . . 4
⊢ (((𝑁 mod (2↑𝑀)) ∈ ℤ ∧ 𝑥 ∈ ℕ0 ∧ ¬ 2
∥ (⌊‘((𝑁
mod (2↑𝑀)) /
(2↑𝑥)))) ↔
((𝑁 mod (2↑𝑀)) ∈ ℤ ∧ (𝑥 ∈ ℕ0
∧ ¬ 2 ∥ (⌊‘((𝑁 mod (2↑𝑀)) / (2↑𝑥)))))) |
| 167 | | elfzo2 10227 |
. . . . . . 7
⊢ (𝑥 ∈ (0..^𝑀) ↔ (𝑥 ∈ (ℤ≥‘0)
∧ 𝑀 ∈ ℤ
∧ 𝑥 < 𝑀)) |
| 168 | | elnn0uz 9641 |
. . . . . . . 8
⊢ (𝑥 ∈ ℕ0
↔ 𝑥 ∈
(ℤ≥‘0)) |
| 169 | 168 | 3anbi1i 1192 |
. . . . . . 7
⊢ ((𝑥 ∈ ℕ0
∧ 𝑀 ∈ ℤ
∧ 𝑥 < 𝑀) ↔ (𝑥 ∈ (ℤ≥‘0)
∧ 𝑀 ∈ ℤ
∧ 𝑥 < 𝑀)) |
| 170 | | 3anass 984 |
. . . . . . 7
⊢ ((𝑥 ∈ ℕ0
∧ 𝑀 ∈ ℤ
∧ 𝑥 < 𝑀) ↔ (𝑥 ∈ ℕ0 ∧ (𝑀 ∈ ℤ ∧ 𝑥 < 𝑀))) |
| 171 | 167, 169,
170 | 3bitr2i 208 |
. . . . . 6
⊢ (𝑥 ∈ (0..^𝑀) ↔ (𝑥 ∈ ℕ0 ∧ (𝑀 ∈ ℤ ∧ 𝑥 < 𝑀))) |
| 172 | 171 | anbi2i 457 |
. . . . 5
⊢ ((𝑥 ∈ (bits‘𝑁) ∧ 𝑥 ∈ (0..^𝑀)) ↔ (𝑥 ∈ (bits‘𝑁) ∧ (𝑥 ∈ ℕ0 ∧ (𝑀 ∈ ℤ ∧ 𝑥 < 𝑀)))) |
| 173 | | an12 561 |
. . . . 5
⊢ ((𝑥 ∈ (bits‘𝑁) ∧ (𝑥 ∈ ℕ0 ∧ (𝑀 ∈ ℤ ∧ 𝑥 < 𝑀))) ↔ (𝑥 ∈ ℕ0 ∧ (𝑥 ∈ (bits‘𝑁) ∧ (𝑀 ∈ ℤ ∧ 𝑥 < 𝑀)))) |
| 174 | 172, 173 | bitri 184 |
. . . 4
⊢ ((𝑥 ∈ (bits‘𝑁) ∧ 𝑥 ∈ (0..^𝑀)) ↔ (𝑥 ∈ ℕ0 ∧ (𝑥 ∈ (bits‘𝑁) ∧ (𝑀 ∈ ℤ ∧ 𝑥 < 𝑀)))) |
| 175 | 165, 166,
174 | 3bitr4g 223 |
. . 3
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ (((𝑁 mod
(2↑𝑀)) ∈ ℤ
∧ 𝑥 ∈
ℕ0 ∧ ¬ 2 ∥ (⌊‘((𝑁 mod (2↑𝑀)) / (2↑𝑥)))) ↔ (𝑥 ∈ (bits‘𝑁) ∧ 𝑥 ∈ (0..^𝑀)))) |
| 176 | | bitsval 12110 |
. . 3
⊢ (𝑥 ∈ (bits‘(𝑁 mod (2↑𝑀))) ↔ ((𝑁 mod (2↑𝑀)) ∈ ℤ ∧ 𝑥 ∈ ℕ0 ∧ ¬ 2
∥ (⌊‘((𝑁
mod (2↑𝑀)) /
(2↑𝑥))))) |
| 177 | | elin 3347 |
. . 3
⊢ (𝑥 ∈ ((bits‘𝑁) ∩ (0..^𝑀)) ↔ (𝑥 ∈ (bits‘𝑁) ∧ 𝑥 ∈ (0..^𝑀))) |
| 178 | 175, 176,
177 | 3bitr4g 223 |
. 2
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ (𝑥 ∈
(bits‘(𝑁 mod
(2↑𝑀))) ↔ 𝑥 ∈ ((bits‘𝑁) ∩ (0..^𝑀)))) |
| 179 | 178 | eqrdv 2194 |
1
⊢ ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0)
→ (bits‘(𝑁 mod
(2↑𝑀))) =
((bits‘𝑁) ∩
(0..^𝑀))) |