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

Theorem bitsmod 12140
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 109 . . . . . . . 8 ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) → 𝑁 ∈ ℤ)
2 2nn 9171 . . . . . . . . . 10 2 ∈ ℕ
32a1i 9 . . . . . . . . 9 ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) → 2 ∈ ℕ)
4 simpr 110 . . . . . . . . 9 ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) → 𝑀 ∈ ℕ0)
53, 4nnexpcld 10806 . . . . . . . 8 ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) → (2↑𝑀) ∈ ℕ)
61, 5zmodcld 10456 . . . . . . 7 ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) → (𝑁 mod (2↑𝑀)) ∈ ℕ0)
76nn0zd 9465 . . . . . 6 ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) → (𝑁 mod (2↑𝑀)) ∈ ℤ)
87biantrurd 305 . . . . 5 ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) → ((𝑥 ∈ ℕ0 ∧ ¬ 2 ∥ (⌊‘((𝑁 mod (2↑𝑀)) / (2↑𝑥)))) ↔ ((𝑁 mod (2↑𝑀)) ∈ ℤ ∧ (𝑥 ∈ ℕ0 ∧ ¬ 2 ∥ (⌊‘((𝑁 mod (2↑𝑀)) / (2↑𝑥)))))))
91ad2antrr 488 . . . . . . . . . . 11 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ 𝑥 < 𝑀) → 𝑁 ∈ ℤ)
10 simplr 528 . . . . . . . . . . 11 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ 𝑥 < 𝑀) → 𝑥 ∈ ℕ0)
11 bitsval2 12128 . . . . . . . . . . 11 ((𝑁 ∈ ℤ ∧ 𝑥 ∈ ℕ0) → (𝑥 ∈ (bits‘𝑁) ↔ ¬ 2 ∥ (⌊‘(𝑁 / (2↑𝑥)))))
129, 10, 11syl2anc 411 . . . . . . . . . 10 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ 𝑥 < 𝑀) → (𝑥 ∈ (bits‘𝑁) ↔ ¬ 2 ∥ (⌊‘(𝑁 / (2↑𝑥)))))
13 simpr 110 . . . . . . . . . . 11 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ 𝑥 < 𝑀) → 𝑥 < 𝑀)
1413biantrud 304 . . . . . . . . . 10 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ 𝑥 < 𝑀) → (𝑥 ∈ (bits‘𝑁) ↔ (𝑥 ∈ (bits‘𝑁) ∧ 𝑥 < 𝑀)))
15 2z 9373 . . . . . . . . . . . . 13 2 ∈ ℤ
1615a1i 9 . . . . . . . . . . . 12 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ 𝑥 < 𝑀) → 2 ∈ ℤ)
172a1i 9 . . . . . . . . . . . . . . 15 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ 𝑥 < 𝑀) → 2 ∈ ℕ)
1817, 10nnexpcld 10806 . . . . . . . . . . . . . 14 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ 𝑥 < 𝑀) → (2↑𝑥) ∈ ℕ)
19 znq 9717 . . . . . . . . . . . . . 14 ((𝑁 ∈ ℤ ∧ (2↑𝑥) ∈ ℕ) → (𝑁 / (2↑𝑥)) ∈ ℚ)
209, 18, 19syl2anc 411 . . . . . . . . . . . . 13 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ 𝑥 < 𝑀) → (𝑁 / (2↑𝑥)) ∈ ℚ)
2120flqcld 10386 . . . . . . . . . . . 12 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ 𝑥 < 𝑀) → (⌊‘(𝑁 / (2↑𝑥))) ∈ ℤ)
227ad2antrr 488 . . . . . . . . . . . . . 14 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ 𝑥 < 𝑀) → (𝑁 mod (2↑𝑀)) ∈ ℤ)
23 znq 9717 . . . . . . . . . . . . . 14 (((𝑁 mod (2↑𝑀)) ∈ ℤ ∧ (2↑𝑥) ∈ ℕ) → ((𝑁 mod (2↑𝑀)) / (2↑𝑥)) ∈ ℚ)
2422, 18, 23syl2anc 411 . . . . . . . . . . . . 13 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ 𝑥 < 𝑀) → ((𝑁 mod (2↑𝑀)) / (2↑𝑥)) ∈ ℚ)
2524flqcld 10386 . . . . . . . . . . . 12 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ 𝑥 < 𝑀) → (⌊‘((𝑁 mod (2↑𝑀)) / (2↑𝑥))) ∈ ℤ)
2618nnzd 9466 . . . . . . . . . . . . . . . . 17 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ 𝑥 < 𝑀) → (2↑𝑥) ∈ ℤ)
2726, 16zmulcld 9473 . . . . . . . . . . . . . . . 16 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ 𝑥 < 𝑀) → ((2↑𝑥) · 2) ∈ ℤ)
285ad2antrr 488 . . . . . . . . . . . . . . . . 17 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ 𝑥 < 𝑀) → (2↑𝑀) ∈ ℕ)
2928nnzd 9466 . . . . . . . . . . . . . . . 16 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ 𝑥 < 𝑀) → (2↑𝑀) ∈ ℤ)
309, 22zsubcld 9472 . . . . . . . . . . . . . . . 16 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ 𝑥 < 𝑀) → (𝑁 − (𝑁 mod (2↑𝑀))) ∈ ℤ)
31 2cnd 9082 . . . . . . . . . . . . . . . . . 18 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ 𝑥 < 𝑀) → 2 ∈ ℂ)
3231, 10expp1d 10785 . . . . . . . . . . . . . . . . 17 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ 𝑥 < 𝑀) → (2↑(𝑥 + 1)) = ((2↑𝑥) · 2))
33 1nn0 9284 . . . . . . . . . . . . . . . . . . . 20 1 ∈ ℕ0
3433a1i 9 . . . . . . . . . . . . . . . . . . 19 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ 𝑥 < 𝑀) → 1 ∈ ℕ0)
3510, 34nn0addcld 9325 . . . . . . . . . . . . . . . . . 18 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ 𝑥 < 𝑀) → (𝑥 + 1) ∈ ℕ0)
3635nn0zd 9465 . . . . . . . . . . . . . . . . . . 19 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ 𝑥 < 𝑀) → (𝑥 + 1) ∈ ℤ)
37 simplr 528 . . . . . . . . . . . . . . . . . . . . 21 (((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) → 𝑀 ∈ ℕ0)
3837adantr 276 . . . . . . . . . . . . . . . . . . . 20 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ 𝑥 < 𝑀) → 𝑀 ∈ ℕ0)
3938nn0zd 9465 . . . . . . . . . . . . . . . . . . 19 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ 𝑥 < 𝑀) → 𝑀 ∈ ℤ)
40 nn0ltp1le 9407 . . . . . . . . . . . . . . . . . . . . 21 ((𝑥 ∈ ℕ0𝑀 ∈ ℕ0) → (𝑥 < 𝑀 ↔ (𝑥 + 1) ≤ 𝑀))
4110, 38, 40syl2anc 411 . . . . . . . . . . . . . . . . . . . 20 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ 𝑥 < 𝑀) → (𝑥 < 𝑀 ↔ (𝑥 + 1) ≤ 𝑀))
4213, 41mpbid 147 . . . . . . . . . . . . . . . . . . 19 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ 𝑥 < 𝑀) → (𝑥 + 1) ≤ 𝑀)
43 eluz2 9626 . . . . . . . . . . . . . . . . . . 19 (𝑀 ∈ (ℤ‘(𝑥 + 1)) ↔ ((𝑥 + 1) ∈ ℤ ∧ 𝑀 ∈ ℤ ∧ (𝑥 + 1) ≤ 𝑀))
4436, 39, 42, 43syl3anbrc 1183 . . . . . . . . . . . . . . . . . 18 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ 𝑥 < 𝑀) → 𝑀 ∈ (ℤ‘(𝑥 + 1)))
45 dvdsexp 12045 . . . . . . . . . . . . . . . . . 18 ((2 ∈ ℤ ∧ (𝑥 + 1) ∈ ℕ0𝑀 ∈ (ℤ‘(𝑥 + 1))) → (2↑(𝑥 + 1)) ∥ (2↑𝑀))
4616, 35, 44, 45syl3anc 1249 . . . . . . . . . . . . . . . . 17 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ 𝑥 < 𝑀) → (2↑(𝑥 + 1)) ∥ (2↑𝑀))
4732, 46eqbrtrrd 4058 . . . . . . . . . . . . . . . 16 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ 𝑥 < 𝑀) → ((2↑𝑥) · 2) ∥ (2↑𝑀))
48 zq 9719 . . . . . . . . . . . . . . . . . . 19 (𝑁 ∈ ℤ → 𝑁 ∈ ℚ)
499, 48syl 14 . . . . . . . . . . . . . . . . . 18 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ 𝑥 < 𝑀) → 𝑁 ∈ ℚ)
50 nnq 9726 . . . . . . . . . . . . . . . . . . 19 ((2↑𝑀) ∈ ℕ → (2↑𝑀) ∈ ℚ)
5128, 50syl 14 . . . . . . . . . . . . . . . . . 18 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ 𝑥 < 𝑀) → (2↑𝑀) ∈ ℚ)
5228nngt0d 9053 . . . . . . . . . . . . . . . . . 18 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ 𝑥 < 𝑀) → 0 < (2↑𝑀))
53 modqdifz 10447 . . . . . . . . . . . . . . . . . 18 ((𝑁 ∈ ℚ ∧ (2↑𝑀) ∈ ℚ ∧ 0 < (2↑𝑀)) → ((𝑁 − (𝑁 mod (2↑𝑀))) / (2↑𝑀)) ∈ ℤ)
5449, 51, 52, 53syl3anc 1249 . . . . . . . . . . . . . . . . 17 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ 𝑥 < 𝑀) → ((𝑁 − (𝑁 mod (2↑𝑀))) / (2↑𝑀)) ∈ ℤ)
5528nnne0d 9054 . . . . . . . . . . . . . . . . . 18 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ 𝑥 < 𝑀) → (2↑𝑀) ≠ 0)
56 dvdsval2 11974 . . . . . . . . . . . . . . . . . 18 (((2↑𝑀) ∈ ℤ ∧ (2↑𝑀) ≠ 0 ∧ (𝑁 − (𝑁 mod (2↑𝑀))) ∈ ℤ) → ((2↑𝑀) ∥ (𝑁 − (𝑁 mod (2↑𝑀))) ↔ ((𝑁 − (𝑁 mod (2↑𝑀))) / (2↑𝑀)) ∈ ℤ))
5729, 55, 30, 56syl3anc 1249 . . . . . . . . . . . . . . . . 17 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ 𝑥 < 𝑀) → ((2↑𝑀) ∥ (𝑁 − (𝑁 mod (2↑𝑀))) ↔ ((𝑁 − (𝑁 mod (2↑𝑀))) / (2↑𝑀)) ∈ ℤ))
5854, 57mpbird 167 . . . . . . . . . . . . . . . 16 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ 𝑥 < 𝑀) → (2↑𝑀) ∥ (𝑁 − (𝑁 mod (2↑𝑀))))
5927, 29, 30, 47, 58dvdstrd 12014 . . . . . . . . . . . . . . 15 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ 𝑥 < 𝑀) → ((2↑𝑥) · 2) ∥ (𝑁 − (𝑁 mod (2↑𝑀))))
6030zcnd 9468 . . . . . . . . . . . . . . . 16 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ 𝑥 < 𝑀) → (𝑁 − (𝑁 mod (2↑𝑀))) ∈ ℂ)
6118nncnd 9023 . . . . . . . . . . . . . . . 16 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ 𝑥 < 𝑀) → (2↑𝑥) ∈ ℂ)
6218nnap0d 9055 . . . . . . . . . . . . . . . 16 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ 𝑥 < 𝑀) → (2↑𝑥) # 0)
6360, 61, 62divcanap2d 8838 . . . . . . . . . . . . . . 15 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ 𝑥 < 𝑀) → ((2↑𝑥) · ((𝑁 − (𝑁 mod (2↑𝑀))) / (2↑𝑥))) = (𝑁 − (𝑁 mod (2↑𝑀))))
6459, 63breqtrrd 4062 . . . . . . . . . . . . . 14 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ 𝑥 < 𝑀) → ((2↑𝑥) · 2) ∥ ((2↑𝑥) · ((𝑁 − (𝑁 mod (2↑𝑀))) / (2↑𝑥))))
6510nn0zd 9465 . . . . . . . . . . . . . . . . . . 19 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ 𝑥 < 𝑀) → 𝑥 ∈ ℤ)
6610nn0red 9322 . . . . . . . . . . . . . . . . . . . 20 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ 𝑥 < 𝑀) → 𝑥 ∈ ℝ)
6738nn0red 9322 . . . . . . . . . . . . . . . . . . . 20 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ 𝑥 < 𝑀) → 𝑀 ∈ ℝ)
6866, 67, 13ltled 8164 . . . . . . . . . . . . . . . . . . 19 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ 𝑥 < 𝑀) → 𝑥𝑀)
69 eluz2 9626 . . . . . . . . . . . . . . . . . . 19 (𝑀 ∈ (ℤ𝑥) ↔ (𝑥 ∈ ℤ ∧ 𝑀 ∈ ℤ ∧ 𝑥𝑀))
7065, 39, 68, 69syl3anbrc 1183 . . . . . . . . . . . . . . . . . 18 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ 𝑥 < 𝑀) → 𝑀 ∈ (ℤ𝑥))
71 dvdsexp 12045 . . . . . . . . . . . . . . . . . 18 ((2 ∈ ℤ ∧ 𝑥 ∈ ℕ0𝑀 ∈ (ℤ𝑥)) → (2↑𝑥) ∥ (2↑𝑀))
7216, 10, 70, 71syl3anc 1249 . . . . . . . . . . . . . . . . 17 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ 𝑥 < 𝑀) → (2↑𝑥) ∥ (2↑𝑀))
7326, 29, 30, 72, 58dvdstrd 12014 . . . . . . . . . . . . . . . 16 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ 𝑥 < 𝑀) → (2↑𝑥) ∥ (𝑁 − (𝑁 mod (2↑𝑀))))
7418nnne0d 9054 . . . . . . . . . . . . . . . . 17 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ 𝑥 < 𝑀) → (2↑𝑥) ≠ 0)
75 dvdsval2 11974 . . . . . . . . . . . . . . . . 17 (((2↑𝑥) ∈ ℤ ∧ (2↑𝑥) ≠ 0 ∧ (𝑁 − (𝑁 mod (2↑𝑀))) ∈ ℤ) → ((2↑𝑥) ∥ (𝑁 − (𝑁 mod (2↑𝑀))) ↔ ((𝑁 − (𝑁 mod (2↑𝑀))) / (2↑𝑥)) ∈ ℤ))
7626, 74, 30, 75syl3anc 1249 . . . . . . . . . . . . . . . 16 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ 𝑥 < 𝑀) → ((2↑𝑥) ∥ (𝑁 − (𝑁 mod (2↑𝑀))) ↔ ((𝑁 − (𝑁 mod (2↑𝑀))) / (2↑𝑥)) ∈ ℤ))
7773, 76mpbid 147 . . . . . . . . . . . . . . 15 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ 𝑥 < 𝑀) → ((𝑁 − (𝑁 mod (2↑𝑀))) / (2↑𝑥)) ∈ ℤ)
78 dvdscmulr 12004 . . . . . . . . . . . . . . 15 ((2 ∈ ℤ ∧ ((𝑁 − (𝑁 mod (2↑𝑀))) / (2↑𝑥)) ∈ ℤ ∧ ((2↑𝑥) ∈ ℤ ∧ (2↑𝑥) ≠ 0)) → (((2↑𝑥) · 2) ∥ ((2↑𝑥) · ((𝑁 − (𝑁 mod (2↑𝑀))) / (2↑𝑥))) ↔ 2 ∥ ((𝑁 − (𝑁 mod (2↑𝑀))) / (2↑𝑥))))
7916, 77, 26, 74, 78syl112anc 1253 . . . . . . . . . . . . . 14 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ 𝑥 < 𝑀) → (((2↑𝑥) · 2) ∥ ((2↑𝑥) · ((𝑁 − (𝑁 mod (2↑𝑀))) / (2↑𝑥))) ↔ 2 ∥ ((𝑁 − (𝑁 mod (2↑𝑀))) / (2↑𝑥))))
8064, 79mpbid 147 . . . . . . . . . . . . 13 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ 𝑥 < 𝑀) → 2 ∥ ((𝑁 − (𝑁 mod (2↑𝑀))) / (2↑𝑥)))
8125zcnd 9468 . . . . . . . . . . . . . 14 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ 𝑥 < 𝑀) → (⌊‘((𝑁 mod (2↑𝑀)) / (2↑𝑥))) ∈ ℂ)
8277zcnd 9468 . . . . . . . . . . . . . 14 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ 𝑥 < 𝑀) → ((𝑁 − (𝑁 mod (2↑𝑀))) / (2↑𝑥)) ∈ ℂ)
8322zcnd 9468 . . . . . . . . . . . . . . . . . . 19 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ 𝑥 < 𝑀) → (𝑁 mod (2↑𝑀)) ∈ ℂ)
849zcnd 9468 . . . . . . . . . . . . . . . . . . 19 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ 𝑥 < 𝑀) → 𝑁 ∈ ℂ)
8583, 84pncan3d 8359 . . . . . . . . . . . . . . . . . 18 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ 𝑥 < 𝑀) → ((𝑁 mod (2↑𝑀)) + (𝑁 − (𝑁 mod (2↑𝑀)))) = 𝑁)
8685oveq1d 5940 . . . . . . . . . . . . . . . . 17 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ 𝑥 < 𝑀) → (((𝑁 mod (2↑𝑀)) + (𝑁 − (𝑁 mod (2↑𝑀)))) / (2↑𝑥)) = (𝑁 / (2↑𝑥)))
8783, 60, 61, 62divdirapd 8875 . . . . . . . . . . . . . . . . 17 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ 𝑥 < 𝑀) → (((𝑁 mod (2↑𝑀)) + (𝑁 − (𝑁 mod (2↑𝑀)))) / (2↑𝑥)) = (((𝑁 mod (2↑𝑀)) / (2↑𝑥)) + ((𝑁 − (𝑁 mod (2↑𝑀))) / (2↑𝑥))))
8886, 87eqtr3d 2231 . . . . . . . . . . . . . . . 16 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ 𝑥 < 𝑀) → (𝑁 / (2↑𝑥)) = (((𝑁 mod (2↑𝑀)) / (2↑𝑥)) + ((𝑁 − (𝑁 mod (2↑𝑀))) / (2↑𝑥))))
8988fveq2d 5565 . . . . . . . . . . . . . . 15 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ 𝑥 < 𝑀) → (⌊‘(𝑁 / (2↑𝑥))) = (⌊‘(((𝑁 mod (2↑𝑀)) / (2↑𝑥)) + ((𝑁 − (𝑁 mod (2↑𝑀))) / (2↑𝑥)))))
90 flqaddz 10406 . . . . . . . . . . . . . . . 16 ((((𝑁 mod (2↑𝑀)) / (2↑𝑥)) ∈ ℚ ∧ ((𝑁 − (𝑁 mod (2↑𝑀))) / (2↑𝑥)) ∈ ℤ) → (⌊‘(((𝑁 mod (2↑𝑀)) / (2↑𝑥)) + ((𝑁 − (𝑁 mod (2↑𝑀))) / (2↑𝑥)))) = ((⌊‘((𝑁 mod (2↑𝑀)) / (2↑𝑥))) + ((𝑁 − (𝑁 mod (2↑𝑀))) / (2↑𝑥))))
9124, 77, 90syl2anc 411 . . . . . . . . . . . . . . 15 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ 𝑥 < 𝑀) → (⌊‘(((𝑁 mod (2↑𝑀)) / (2↑𝑥)) + ((𝑁 − (𝑁 mod (2↑𝑀))) / (2↑𝑥)))) = ((⌊‘((𝑁 mod (2↑𝑀)) / (2↑𝑥))) + ((𝑁 − (𝑁 mod (2↑𝑀))) / (2↑𝑥))))
9289, 91eqtrd 2229 . . . . . . . . . . . . . 14 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ 𝑥 < 𝑀) → (⌊‘(𝑁 / (2↑𝑥))) = ((⌊‘((𝑁 mod (2↑𝑀)) / (2↑𝑥))) + ((𝑁 − (𝑁 mod (2↑𝑀))) / (2↑𝑥))))
9381, 82, 92mvrladdd 8412 . . . . . . . . . . . . 13 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ 𝑥 < 𝑀) → ((⌊‘(𝑁 / (2↑𝑥))) − (⌊‘((𝑁 mod (2↑𝑀)) / (2↑𝑥)))) = ((𝑁 − (𝑁 mod (2↑𝑀))) / (2↑𝑥)))
9480, 93breqtrrd 4062 . . . . . . . . . . . 12 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ 𝑥 < 𝑀) → 2 ∥ ((⌊‘(𝑁 / (2↑𝑥))) − (⌊‘((𝑁 mod (2↑𝑀)) / (2↑𝑥)))))
95 dvdssub2 12019 . . . . . . . . . . . 12 (((2 ∈ ℤ ∧ (⌊‘(𝑁 / (2↑𝑥))) ∈ ℤ ∧ (⌊‘((𝑁 mod (2↑𝑀)) / (2↑𝑥))) ∈ ℤ) ∧ 2 ∥ ((⌊‘(𝑁 / (2↑𝑥))) − (⌊‘((𝑁 mod (2↑𝑀)) / (2↑𝑥))))) → (2 ∥ (⌊‘(𝑁 / (2↑𝑥))) ↔ 2 ∥ (⌊‘((𝑁 mod (2↑𝑀)) / (2↑𝑥)))))
9616, 21, 25, 94, 95syl31anc 1252 . . . . . . . . . . 11 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ 𝑥 < 𝑀) → (2 ∥ (⌊‘(𝑁 / (2↑𝑥))) ↔ 2 ∥ (⌊‘((𝑁 mod (2↑𝑀)) / (2↑𝑥)))))
9796notbid 668 . . . . . . . . . 10 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ 𝑥 < 𝑀) → (¬ 2 ∥ (⌊‘(𝑁 / (2↑𝑥))) ↔ ¬ 2 ∥ (⌊‘((𝑁 mod (2↑𝑀)) / (2↑𝑥)))))
9812, 14, 973bitr3d 218 . . . . . . . . 9 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ 𝑥 < 𝑀) → ((𝑥 ∈ (bits‘𝑁) ∧ 𝑥 < 𝑀) ↔ ¬ 2 ∥ (⌊‘((𝑁 mod (2↑𝑀)) / (2↑𝑥)))))
99 simpr 110 . . . . . . . . . . 11 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ ¬ 𝑥 < 𝑀) → ¬ 𝑥 < 𝑀)
10099intnand 932 . . . . . . . . . 10 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ ¬ 𝑥 < 𝑀) → ¬ (𝑥 ∈ (bits‘𝑁) ∧ 𝑥 < 𝑀))
101 z0even 12095 . . . . . . . . . . . 12 2 ∥ 0
1021ad2antrr 488 . . . . . . . . . . . . . . . . 17 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ ¬ 𝑥 < 𝑀) → 𝑁 ∈ ℤ)
103102, 48syl 14 . . . . . . . . . . . . . . . 16 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ ¬ 𝑥 < 𝑀) → 𝑁 ∈ ℚ)
1045ad2antrr 488 . . . . . . . . . . . . . . . . 17 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ ¬ 𝑥 < 𝑀) → (2↑𝑀) ∈ ℕ)
105104, 50syl 14 . . . . . . . . . . . . . . . 16 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ ¬ 𝑥 < 𝑀) → (2↑𝑀) ∈ ℚ)
106 2rp 9752 . . . . . . . . . . . . . . . . . . 19 2 ∈ ℝ+
107106a1i 9 . . . . . . . . . . . . . . . . . 18 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ ¬ 𝑥 < 𝑀) → 2 ∈ ℝ+)
10837nn0zd 9465 . . . . . . . . . . . . . . . . . . 19 (((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) → 𝑀 ∈ ℤ)
109108adantr 276 . . . . . . . . . . . . . . . . . 18 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ ¬ 𝑥 < 𝑀) → 𝑀 ∈ ℤ)
110107, 109rpexpcld 10808 . . . . . . . . . . . . . . . . 17 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ ¬ 𝑥 < 𝑀) → (2↑𝑀) ∈ ℝ+)
111110rpgt0d 9793 . . . . . . . . . . . . . . . 16 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ ¬ 𝑥 < 𝑀) → 0 < (2↑𝑀))
112103, 105, 111modqcld 10439 . . . . . . . . . . . . . . 15 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ ¬ 𝑥 < 𝑀) → (𝑁 mod (2↑𝑀)) ∈ ℚ)
113 qre 9718 . . . . . . . . . . . . . . 15 ((𝑁 mod (2↑𝑀)) ∈ ℚ → (𝑁 mod (2↑𝑀)) ∈ ℝ)
114112, 113syl 14 . . . . . . . . . . . . . 14 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ ¬ 𝑥 < 𝑀) → (𝑁 mod (2↑𝑀)) ∈ ℝ)
115 simplr 528 . . . . . . . . . . . . . . . 16 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ ¬ 𝑥 < 𝑀) → 𝑥 ∈ ℕ0)
116115nn0zd 9465 . . . . . . . . . . . . . . 15 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ ¬ 𝑥 < 𝑀) → 𝑥 ∈ ℤ)
117107, 116rpexpcld 10808 . . . . . . . . . . . . . 14 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ ¬ 𝑥 < 𝑀) → (2↑𝑥) ∈ ℝ+)
1186ad2antrr 488 . . . . . . . . . . . . . . 15 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ ¬ 𝑥 < 𝑀) → (𝑁 mod (2↑𝑀)) ∈ ℕ0)
119118nn0ge0d 9324 . . . . . . . . . . . . . 14 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ ¬ 𝑥 < 𝑀) → 0 ≤ (𝑁 mod (2↑𝑀)))
120114, 117, 119divge0d 9831 . . . . . . . . . . . . 13 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ ¬ 𝑥 < 𝑀) → 0 ≤ ((𝑁 mod (2↑𝑀)) / (2↑𝑥)))
121110rpred 9790 . . . . . . . . . . . . . . . . 17 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ ¬ 𝑥 < 𝑀) → (2↑𝑀) ∈ ℝ)
122117rpred 9790 . . . . . . . . . . . . . . . . 17 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ ¬ 𝑥 < 𝑀) → (2↑𝑥) ∈ ℝ)
123 modqlt 10444 . . . . . . . . . . . . . . . . . 18 ((𝑁 ∈ ℚ ∧ (2↑𝑀) ∈ ℚ ∧ 0 < (2↑𝑀)) → (𝑁 mod (2↑𝑀)) < (2↑𝑀))
124103, 105, 111, 123syl3anc 1249 . . . . . . . . . . . . . . . . 17 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ ¬ 𝑥 < 𝑀) → (𝑁 mod (2↑𝑀)) < (2↑𝑀))
125107rpred 9790 . . . . . . . . . . . . . . . . . 18 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ ¬ 𝑥 < 𝑀) → 2 ∈ ℝ)
126 1le2 9218 . . . . . . . . . . . . . . . . . . 19 1 ≤ 2
127126a1i 9 . . . . . . . . . . . . . . . . . 18 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ ¬ 𝑥 < 𝑀) → 1 ≤ 2)
128109zred 9467 . . . . . . . . . . . . . . . . . . . 20 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ ¬ 𝑥 < 𝑀) → 𝑀 ∈ ℝ)
129115nn0red 9322 . . . . . . . . . . . . . . . . . . . 20 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ ¬ 𝑥 < 𝑀) → 𝑥 ∈ ℝ)
130128, 129, 99nltled 8166 . . . . . . . . . . . . . . . . . . 19 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ ¬ 𝑥 < 𝑀) → 𝑀𝑥)
131 eluz2 9626 . . . . . . . . . . . . . . . . . . 19 (𝑥 ∈ (ℤ𝑀) ↔ (𝑀 ∈ ℤ ∧ 𝑥 ∈ ℤ ∧ 𝑀𝑥))
132109, 116, 130, 131syl3anbrc 1183 . . . . . . . . . . . . . . . . . 18 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ ¬ 𝑥 < 𝑀) → 𝑥 ∈ (ℤ𝑀))
133125, 127, 132leexp2ad 10813 . . . . . . . . . . . . . . . . 17 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ ¬ 𝑥 < 𝑀) → (2↑𝑀) ≤ (2↑𝑥))
134114, 121, 122, 124, 133ltletrd 8469 . . . . . . . . . . . . . . . 16 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ ¬ 𝑥 < 𝑀) → (𝑁 mod (2↑𝑀)) < (2↑𝑥))
135117rpcnd 9792 . . . . . . . . . . . . . . . . 17 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ ¬ 𝑥 < 𝑀) → (2↑𝑥) ∈ ℂ)
136135mulridd 8062 . . . . . . . . . . . . . . . 16 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ ¬ 𝑥 < 𝑀) → ((2↑𝑥) · 1) = (2↑𝑥))
137134, 136breqtrrd 4062 . . . . . . . . . . . . . . 15 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ ¬ 𝑥 < 𝑀) → (𝑁 mod (2↑𝑀)) < ((2↑𝑥) · 1))
138 1red 8060 . . . . . . . . . . . . . . . 16 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ ¬ 𝑥 < 𝑀) → 1 ∈ ℝ)
139114, 138, 117ltdivmuld 9842 . . . . . . . . . . . . . . 15 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ ¬ 𝑥 < 𝑀) → (((𝑁 mod (2↑𝑀)) / (2↑𝑥)) < 1 ↔ (𝑁 mod (2↑𝑀)) < ((2↑𝑥) · 1)))
140137, 139mpbird 167 . . . . . . . . . . . . . 14 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ ¬ 𝑥 < 𝑀) → ((𝑁 mod (2↑𝑀)) / (2↑𝑥)) < 1)
141 1e0p1 9517 . . . . . . . . . . . . . 14 1 = (0 + 1)
142140, 141breqtrdi 4075 . . . . . . . . . . . . 13 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ ¬ 𝑥 < 𝑀) → ((𝑁 mod (2↑𝑀)) / (2↑𝑥)) < (0 + 1))
1437ad2antrr 488 . . . . . . . . . . . . . . 15 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ ¬ 𝑥 < 𝑀) → (𝑁 mod (2↑𝑀)) ∈ ℤ)
1442a1i 9 . . . . . . . . . . . . . . . 16 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ ¬ 𝑥 < 𝑀) → 2 ∈ ℕ)
145144, 115nnexpcld 10806 . . . . . . . . . . . . . . 15 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ ¬ 𝑥 < 𝑀) → (2↑𝑥) ∈ ℕ)
146143, 145, 23syl2anc 411 . . . . . . . . . . . . . 14 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ ¬ 𝑥 < 𝑀) → ((𝑁 mod (2↑𝑀)) / (2↑𝑥)) ∈ ℚ)
147 0z 9356 . . . . . . . . . . . . . 14 0 ∈ ℤ
148 flqbi 10399 . . . . . . . . . . . . . 14 ((((𝑁 mod (2↑𝑀)) / (2↑𝑥)) ∈ ℚ ∧ 0 ∈ ℤ) → ((⌊‘((𝑁 mod (2↑𝑀)) / (2↑𝑥))) = 0 ↔ (0 ≤ ((𝑁 mod (2↑𝑀)) / (2↑𝑥)) ∧ ((𝑁 mod (2↑𝑀)) / (2↑𝑥)) < (0 + 1))))
149146, 147, 148sylancl 413 . . . . . . . . . . . . 13 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ ¬ 𝑥 < 𝑀) → ((⌊‘((𝑁 mod (2↑𝑀)) / (2↑𝑥))) = 0 ↔ (0 ≤ ((𝑁 mod (2↑𝑀)) / (2↑𝑥)) ∧ ((𝑁 mod (2↑𝑀)) / (2↑𝑥)) < (0 + 1))))
150120, 142, 149mpbir2and 946 . . . . . . . . . . . 12 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ ¬ 𝑥 < 𝑀) → (⌊‘((𝑁 mod (2↑𝑀)) / (2↑𝑥))) = 0)
151101, 150breqtrrid 4072 . . . . . . . . . . 11 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ ¬ 𝑥 < 𝑀) → 2 ∥ (⌊‘((𝑁 mod (2↑𝑀)) / (2↑𝑥))))
152151notnotd 631 . . . . . . . . . 10 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ ¬ 𝑥 < 𝑀) → ¬ ¬ 2 ∥ (⌊‘((𝑁 mod (2↑𝑀)) / (2↑𝑥))))
153100, 1522falsed 703 . . . . . . . . 9 ((((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) ∧ ¬ 𝑥 < 𝑀) → ((𝑥 ∈ (bits‘𝑁) ∧ 𝑥 < 𝑀) ↔ ¬ 2 ∥ (⌊‘((𝑁 mod (2↑𝑀)) / (2↑𝑥)))))
154 nn0z 9365 . . . . . . . . . . 11 (𝑥 ∈ ℕ0𝑥 ∈ ℤ)
155 zdclt 9422 . . . . . . . . . . 11 ((𝑥 ∈ ℤ ∧ 𝑀 ∈ ℤ) → DECID 𝑥 < 𝑀)
156154, 108, 155syl2an2 594 . . . . . . . . . 10 (((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) → DECID 𝑥 < 𝑀)
157 exmiddc 837 . . . . . . . . . 10 (DECID 𝑥 < 𝑀 → (𝑥 < 𝑀 ∨ ¬ 𝑥 < 𝑀))
158156, 157syl 14 . . . . . . . . 9 (((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) → (𝑥 < 𝑀 ∨ ¬ 𝑥 < 𝑀))
15998, 153, 158mpjaodan 799 . . . . . . . 8 (((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) → ((𝑥 ∈ (bits‘𝑁) ∧ 𝑥 < 𝑀) ↔ ¬ 2 ∥ (⌊‘((𝑁 mod (2↑𝑀)) / (2↑𝑥)))))
160108biantrurd 305 . . . . . . . 8 (((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) → ((𝑥 ∈ (bits‘𝑁) ∧ 𝑥 < 𝑀) ↔ (𝑀 ∈ ℤ ∧ (𝑥 ∈ (bits‘𝑁) ∧ 𝑥 < 𝑀))))
161159, 160bitr3d 190 . . . . . . 7 (((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) → (¬ 2 ∥ (⌊‘((𝑁 mod (2↑𝑀)) / (2↑𝑥))) ↔ (𝑀 ∈ ℤ ∧ (𝑥 ∈ (bits‘𝑁) ∧ 𝑥 < 𝑀))))
162 an12 561 . . . . . . 7 ((𝑀 ∈ ℤ ∧ (𝑥 ∈ (bits‘𝑁) ∧ 𝑥 < 𝑀)) ↔ (𝑥 ∈ (bits‘𝑁) ∧ (𝑀 ∈ ℤ ∧ 𝑥 < 𝑀)))
163161, 162bitrdi 196 . . . . . 6 (((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) ∧ 𝑥 ∈ ℕ0) → (¬ 2 ∥ (⌊‘((𝑁 mod (2↑𝑀)) / (2↑𝑥))) ↔ (𝑥 ∈ (bits‘𝑁) ∧ (𝑀 ∈ ℤ ∧ 𝑥 < 𝑀))))
164163pm5.32da 452 . . . . 5 ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) → ((𝑥 ∈ ℕ0 ∧ ¬ 2 ∥ (⌊‘((𝑁 mod (2↑𝑀)) / (2↑𝑥)))) ↔ (𝑥 ∈ ℕ0 ∧ (𝑥 ∈ (bits‘𝑁) ∧ (𝑀 ∈ ℤ ∧ 𝑥 < 𝑀)))))
1658, 164bitr3d 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 10244 . . . . . . 7 (𝑥 ∈ (0..^𝑀) ↔ (𝑥 ∈ (ℤ‘0) ∧ 𝑀 ∈ ℤ ∧ 𝑥 < 𝑀))
168 elnn0uz 9658 . . . . . . . 8 (𝑥 ∈ ℕ0𝑥 ∈ (ℤ‘0))
1691683anbi1i 1192 . . . . . . 7 ((𝑥 ∈ ℕ0𝑀 ∈ ℤ ∧ 𝑥 < 𝑀) ↔ (𝑥 ∈ (ℤ‘0) ∧ 𝑀 ∈ ℤ ∧ 𝑥 < 𝑀))
170 3anass 984 . . . . . . 7 ((𝑥 ∈ ℕ0𝑀 ∈ ℤ ∧ 𝑥 < 𝑀) ↔ (𝑥 ∈ ℕ0 ∧ (𝑀 ∈ ℤ ∧ 𝑥 < 𝑀)))
171167, 169, 1703bitr2i 208 . . . . . 6 (𝑥 ∈ (0..^𝑀) ↔ (𝑥 ∈ ℕ0 ∧ (𝑀 ∈ ℤ ∧ 𝑥 < 𝑀)))
172171anbi2i 457 . . . . 5 ((𝑥 ∈ (bits‘𝑁) ∧ 𝑥 ∈ (0..^𝑀)) ↔ (𝑥 ∈ (bits‘𝑁) ∧ (𝑥 ∈ ℕ0 ∧ (𝑀 ∈ ℤ ∧ 𝑥 < 𝑀))))
173 an12 561 . . . . 5 ((𝑥 ∈ (bits‘𝑁) ∧ (𝑥 ∈ ℕ0 ∧ (𝑀 ∈ ℤ ∧ 𝑥 < 𝑀))) ↔ (𝑥 ∈ ℕ0 ∧ (𝑥 ∈ (bits‘𝑁) ∧ (𝑀 ∈ ℤ ∧ 𝑥 < 𝑀))))
174172, 173bitri 184 . . . 4 ((𝑥 ∈ (bits‘𝑁) ∧ 𝑥 ∈ (0..^𝑀)) ↔ (𝑥 ∈ ℕ0 ∧ (𝑥 ∈ (bits‘𝑁) ∧ (𝑀 ∈ ℤ ∧ 𝑥 < 𝑀))))
175165, 166, 1743bitr4g 223 . . 3 ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) → (((𝑁 mod (2↑𝑀)) ∈ ℤ ∧ 𝑥 ∈ ℕ0 ∧ ¬ 2 ∥ (⌊‘((𝑁 mod (2↑𝑀)) / (2↑𝑥)))) ↔ (𝑥 ∈ (bits‘𝑁) ∧ 𝑥 ∈ (0..^𝑀))))
176 bitsval 12127 . . 3 (𝑥 ∈ (bits‘(𝑁 mod (2↑𝑀))) ↔ ((𝑁 mod (2↑𝑀)) ∈ ℤ ∧ 𝑥 ∈ ℕ0 ∧ ¬ 2 ∥ (⌊‘((𝑁 mod (2↑𝑀)) / (2↑𝑥)))))
177 elin 3347 . . 3 (𝑥 ∈ ((bits‘𝑁) ∩ (0..^𝑀)) ↔ (𝑥 ∈ (bits‘𝑁) ∧ 𝑥 ∈ (0..^𝑀)))
178175, 176, 1773bitr4g 223 . 2 ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) → (𝑥 ∈ (bits‘(𝑁 mod (2↑𝑀))) ↔ 𝑥 ∈ ((bits‘𝑁) ∩ (0..^𝑀))))
179178eqrdv 2194 1 ((𝑁 ∈ ℤ ∧ 𝑀 ∈ ℕ0) → (bits‘(𝑁 mod (2↑𝑀))) = ((bits‘𝑁) ∩ (0..^𝑀)))
Colors of variables: wff set class
Syntax hints:  ¬ wn 3  wi 4  wa 104  wb 105  wo 709  DECID wdc 835  w3a 980   = wceq 1364  wcel 2167  wne 2367  cin 3156   class class class wbr 4034  cfv 5259  (class class class)co 5925  cr 7897  0cc0 7898  1c1 7899   + caddc 7901   · cmul 7903   < clt 8080  cle 8081  cmin 8216   / cdiv 8718  cn 9009  2c2 9060  0cn0 9268  cz 9345  cuz 9620  cq 9712  +crp 9747  ..^cfzo 10236  cfl 10377   mod cmo 10433  cexp 10649  cdvds 11971  bitscbits 12124
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-ia1 106  ax-ia2 107  ax-ia3 108  ax-in1 615  ax-in2 616  ax-io 710  ax-5 1461  ax-7 1462  ax-gen 1463  ax-ie1 1507  ax-ie2 1508  ax-8 1518  ax-10 1519  ax-11 1520  ax-i12 1521  ax-bndl 1523  ax-4 1524  ax-17 1540  ax-i9 1544  ax-ial 1548  ax-i5r 1549  ax-13 2169  ax-14 2170  ax-ext 2178  ax-coll 4149  ax-sep 4152  ax-nul 4160  ax-pow 4208  ax-pr 4243  ax-un 4469  ax-setind 4574  ax-iinf 4625  ax-cnex 7989  ax-resscn 7990  ax-1cn 7991  ax-1re 7992  ax-icn 7993  ax-addcl 7994  ax-addrcl 7995  ax-mulcl 7996  ax-mulrcl 7997  ax-addcom 7998  ax-mulcom 7999  ax-addass 8000  ax-mulass 8001  ax-distr 8002  ax-i2m1 8003  ax-0lt1 8004  ax-1rid 8005  ax-0id 8006  ax-rnegex 8007  ax-precex 8008  ax-cnre 8009  ax-pre-ltirr 8010  ax-pre-ltwlin 8011  ax-pre-lttrn 8012  ax-pre-apti 8013  ax-pre-ltadd 8014  ax-pre-mulgt0 8015  ax-pre-mulext 8016  ax-arch 8017
This theorem depends on definitions:  df-bi 117  df-dc 836  df-3or 981  df-3an 982  df-tru 1367  df-fal 1370  df-nf 1475  df-sb 1777  df-eu 2048  df-mo 2049  df-clab 2183  df-cleq 2189  df-clel 2192  df-nfc 2328  df-ne 2368  df-nel 2463  df-ral 2480  df-rex 2481  df-reu 2482  df-rmo 2483  df-rab 2484  df-v 2765  df-sbc 2990  df-csb 3085  df-dif 3159  df-un 3161  df-in 3163  df-ss 3170  df-nul 3452  df-if 3563  df-pw 3608  df-sn 3629  df-pr 3630  df-op 3632  df-uni 3841  df-int 3876  df-iun 3919  df-br 4035  df-opab 4096  df-mpt 4097  df-tr 4133  df-id 4329  df-po 4332  df-iso 4333  df-iord 4402  df-on 4404  df-ilim 4405  df-suc 4407  df-iom 4628  df-xp 4670  df-rel 4671  df-cnv 4672  df-co 4673  df-dm 4674  df-rn 4675  df-res 4676  df-ima 4677  df-iota 5220  df-fun 5261  df-fn 5262  df-f 5263  df-f1 5264  df-fo 5265  df-f1o 5266  df-fv 5267  df-riota 5880  df-ov 5928  df-oprab 5929  df-mpo 5930  df-1st 6207  df-2nd 6208  df-recs 6372  df-frec 6458  df-pnf 8082  df-mnf 8083  df-xr 8084  df-ltxr 8085  df-le 8086  df-sub 8218  df-neg 8219  df-reap 8621  df-ap 8628  df-div 8719  df-inn 9010  df-2 9068  df-n0 9269  df-z 9346  df-uz 9621  df-q 9713  df-rp 9748  df-fz 10103  df-fzo 10237  df-fl 10379  df-mod 10434  df-seqfrec 10559  df-exp 10650  df-dvds 11972  df-bits 12125
This theorem is referenced by: (None)
  Copyright terms: Public domain W3C validator