| Mathbox for Alexander van der Vekens |
< Previous
Next >
Nearby theorems |
||
| Mirrors > Home > MPE Home > Th. List > Mathboxes > dig2bits | Structured version Visualization version GIF version | ||
| Description: The 𝐾 th digit of a nonnegative integer 𝑁 in a binary system is its 𝐾 th bit. (Contributed by AV, 24-May-2020.) |
| Ref | Expression |
|---|---|
| dig2bits | ⊢ ((𝑁 ∈ ℕ0 ∧ 𝐾 ∈ ℕ0) → ((𝐾(digit‘2)𝑁) = 1 ↔ 𝐾 ∈ (bits‘𝑁))) |
| Step | Hyp | Ref | Expression |
|---|---|---|---|
| 1 | nn0re 12424 | . . . . . 6 ⊢ (𝑁 ∈ ℕ0 → 𝑁 ∈ ℝ) | |
| 2 | 1 | adantr 480 | . . . . 5 ⊢ ((𝑁 ∈ ℕ0 ∧ 𝐾 ∈ ℕ0) → 𝑁 ∈ ℝ) |
| 3 | 2re 12233 | . . . . . . 7 ⊢ 2 ∈ ℝ | |
| 4 | 3 | a1i 11 | . . . . . 6 ⊢ (𝑁 ∈ ℕ0 → 2 ∈ ℝ) |
| 5 | reexpcl 14015 | . . . . . 6 ⊢ ((2 ∈ ℝ ∧ 𝐾 ∈ ℕ0) → (2↑𝐾) ∈ ℝ) | |
| 6 | 4, 5 | sylan 581 | . . . . 5 ⊢ ((𝑁 ∈ ℕ0 ∧ 𝐾 ∈ ℕ0) → (2↑𝐾) ∈ ℝ) |
| 7 | 2cnd 12237 | . . . . . 6 ⊢ ((𝑁 ∈ ℕ0 ∧ 𝐾 ∈ ℕ0) → 2 ∈ ℂ) | |
| 8 | 2ne0 12263 | . . . . . . 7 ⊢ 2 ≠ 0 | |
| 9 | 8 | a1i 11 | . . . . . 6 ⊢ ((𝑁 ∈ ℕ0 ∧ 𝐾 ∈ ℕ0) → 2 ≠ 0) |
| 10 | nn0z 12526 | . . . . . . 7 ⊢ (𝐾 ∈ ℕ0 → 𝐾 ∈ ℤ) | |
| 11 | 10 | adantl 481 | . . . . . 6 ⊢ ((𝑁 ∈ ℕ0 ∧ 𝐾 ∈ ℕ0) → 𝐾 ∈ ℤ) |
| 12 | 7, 9, 11 | expne0d 14089 | . . . . 5 ⊢ ((𝑁 ∈ ℕ0 ∧ 𝐾 ∈ ℕ0) → (2↑𝐾) ≠ 0) |
| 13 | 2, 6, 12 | redivcld 11983 | . . . 4 ⊢ ((𝑁 ∈ ℕ0 ∧ 𝐾 ∈ ℕ0) → (𝑁 / (2↑𝐾)) ∈ ℝ) |
| 14 | 13 | flcld 13732 | . . 3 ⊢ ((𝑁 ∈ ℕ0 ∧ 𝐾 ∈ ℕ0) → (⌊‘(𝑁 / (2↑𝐾))) ∈ ℤ) |
| 15 | mod2eq1n2dvds 16288 | . . 3 ⊢ ((⌊‘(𝑁 / (2↑𝐾))) ∈ ℤ → (((⌊‘(𝑁 / (2↑𝐾))) mod 2) = 1 ↔ ¬ 2 ∥ (⌊‘(𝑁 / (2↑𝐾))))) | |
| 16 | 14, 15 | syl 17 | . 2 ⊢ ((𝑁 ∈ ℕ0 ∧ 𝐾 ∈ ℕ0) → (((⌊‘(𝑁 / (2↑𝐾))) mod 2) = 1 ↔ ¬ 2 ∥ (⌊‘(𝑁 / (2↑𝐾))))) |
| 17 | 2nn 12232 | . . . . 5 ⊢ 2 ∈ ℕ | |
| 18 | 17 | a1i 11 | . . . 4 ⊢ ((𝑁 ∈ ℕ0 ∧ 𝐾 ∈ ℕ0) → 2 ∈ ℕ) |
| 19 | simpr 484 | . . . 4 ⊢ ((𝑁 ∈ ℕ0 ∧ 𝐾 ∈ ℕ0) → 𝐾 ∈ ℕ0) | |
| 20 | nn0rp0 13385 | . . . . 5 ⊢ (𝑁 ∈ ℕ0 → 𝑁 ∈ (0[,)+∞)) | |
| 21 | 20 | adantr 480 | . . . 4 ⊢ ((𝑁 ∈ ℕ0 ∧ 𝐾 ∈ ℕ0) → 𝑁 ∈ (0[,)+∞)) |
| 22 | nn0digval 48989 | . . . 4 ⊢ ((2 ∈ ℕ ∧ 𝐾 ∈ ℕ0 ∧ 𝑁 ∈ (0[,)+∞)) → (𝐾(digit‘2)𝑁) = ((⌊‘(𝑁 / (2↑𝐾))) mod 2)) | |
| 23 | 18, 19, 21, 22 | syl3anc 1374 | . . 3 ⊢ ((𝑁 ∈ ℕ0 ∧ 𝐾 ∈ ℕ0) → (𝐾(digit‘2)𝑁) = ((⌊‘(𝑁 / (2↑𝐾))) mod 2)) |
| 24 | 23 | eqeq1d 2739 | . 2 ⊢ ((𝑁 ∈ ℕ0 ∧ 𝐾 ∈ ℕ0) → ((𝐾(digit‘2)𝑁) = 1 ↔ ((⌊‘(𝑁 / (2↑𝐾))) mod 2) = 1)) |
| 25 | nn0z 12526 | . . 3 ⊢ (𝑁 ∈ ℕ0 → 𝑁 ∈ ℤ) | |
| 26 | bitsval2 16366 | . . 3 ⊢ ((𝑁 ∈ ℤ ∧ 𝐾 ∈ ℕ0) → (𝐾 ∈ (bits‘𝑁) ↔ ¬ 2 ∥ (⌊‘(𝑁 / (2↑𝐾))))) | |
| 27 | 25, 26 | sylan 581 | . 2 ⊢ ((𝑁 ∈ ℕ0 ∧ 𝐾 ∈ ℕ0) → (𝐾 ∈ (bits‘𝑁) ↔ ¬ 2 ∥ (⌊‘(𝑁 / (2↑𝐾))))) |
| 28 | 16, 24, 27 | 3bitr4d 311 | 1 ⊢ ((𝑁 ∈ ℕ0 ∧ 𝐾 ∈ ℕ0) → ((𝐾(digit‘2)𝑁) = 1 ↔ 𝐾 ∈ (bits‘𝑁))) |
| Colors of variables: wff setvar class |
| Syntax hints: ¬ wn 3 → wi 4 ↔ wb 206 ∧ wa 395 = wceq 1542 ∈ wcel 2114 ≠ wne 2933 class class class wbr 5100 ‘cfv 6502 (class class class)co 7370 ℝcr 11039 0cc0 11040 1c1 11041 +∞cpnf 11177 / cdiv 11808 ℕcn 12159 2c2 12214 ℕ0cn0 12415 ℤcz 12502 [,)cico 13277 ⌊cfl 13724 mod cmo 13803 ↑cexp 13998 ∥ cdvds 16193 bitscbits 16360 digitcdig 48984 |
| 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 1912 ax-6 1969 ax-7 2010 ax-8 2116 ax-9 2124 ax-10 2147 ax-11 2163 ax-12 2185 ax-ext 2709 ax-rep 5226 ax-sep 5245 ax-nul 5255 ax-pow 5314 ax-pr 5381 ax-un 7692 ax-cnex 11096 ax-resscn 11097 ax-1cn 11098 ax-icn 11099 ax-addcl 11100 ax-addrcl 11101 ax-mulcl 11102 ax-mulrcl 11103 ax-mulcom 11104 ax-addass 11105 ax-mulass 11106 ax-distr 11107 ax-i2m1 11108 ax-1ne0 11109 ax-1rid 11110 ax-rnegex 11111 ax-rrecex 11112 ax-cnre 11113 ax-pre-lttri 11114 ax-pre-lttrn 11115 ax-pre-ltadd 11116 ax-pre-mulgt0 11117 ax-pre-sup 11118 |
| This theorem depends on definitions: df-bi 207 df-an 396 df-or 849 df-3or 1088 df-3an 1089 df-tru 1545 df-fal 1555 df-ex 1782 df-nf 1786 df-sb 2069 df-mo 2540 df-eu 2570 df-clab 2716 df-cleq 2729 df-clel 2812 df-nfc 2886 df-ne 2934 df-nel 3038 df-ral 3053 df-rex 3063 df-rmo 3352 df-reu 3353 df-rab 3402 df-v 3444 df-sbc 3743 df-csb 3852 df-dif 3906 df-un 3908 df-in 3910 df-ss 3920 df-pss 3923 df-nul 4288 df-if 4482 df-pw 4558 df-sn 4583 df-pr 4585 df-op 4589 df-uni 4866 df-iun 4950 df-br 5101 df-opab 5163 df-mpt 5182 df-tr 5208 df-id 5529 df-eprel 5534 df-po 5542 df-so 5543 df-fr 5587 df-we 5589 df-xp 5640 df-rel 5641 df-cnv 5642 df-co 5643 df-dm 5644 df-rn 5645 df-res 5646 df-ima 5647 df-pred 6269 df-ord 6330 df-on 6331 df-lim 6332 df-suc 6333 df-iota 6458 df-fun 6504 df-fn 6505 df-f 6506 df-f1 6507 df-fo 6508 df-f1o 6509 df-fv 6510 df-riota 7327 df-ov 7373 df-oprab 7374 df-mpo 7375 df-om 7821 df-1st 7945 df-2nd 7946 df-frecs 8235 df-wrecs 8266 df-recs 8315 df-rdg 8353 df-er 8647 df-en 8898 df-dom 8899 df-sdom 8900 df-sup 9359 df-inf 9360 df-pnf 11182 df-mnf 11183 df-xr 11184 df-ltxr 11185 df-le 11186 df-sub 11380 df-neg 11381 df-div 11809 df-nn 12160 df-2 12222 df-n0 12416 df-z 12503 df-uz 12766 df-rp 12920 df-ico 13281 df-fl 13726 df-mod 13804 df-seq 13939 df-exp 13999 df-dvds 16194 df-bits 16363 df-dig 48985 |
| This theorem is referenced by: (None) |
| Copyright terms: Public domain | W3C validator |