Signed binary 1111 1111 1111 1111 1001 1000 0010 0101(2) to an integer in decimal system (in base 10) = ?
1. Is this a positive or a negative number?
In a signed binary, first bit (the leftmost) is reserved for the sign, 1 = negative, 0 = positive. This bit does not count when calculating the absolute value.
1111 1111 1111 1111 1001 1000 0010 0101 is the binary representation of a negative integer, on 32 bits (4 Bytes).
2. Construct the unsigned binary number, exclude the first bit (the leftmost), that is reserved for the sign:
1111 1111 1111 1111 1001 1000 0010 0101 = 111 1111 1111 1111 1001 1000 0010 0101
3. Map the unsigned binary number's digits versus the corresponding powers of 2 that their place value represent:
230
1 229
1 228
1 227
1 226
1 225
1 224
1 223
1 222
1 221
1 220
1 219
1 218
1 217
1 216
1 215
1 214
0 213
0 212
1 211
1 210
0 29
0 28
0 27
0 26
0 25
1 24
0 23
0 22
1 21
0 20
1
4. Multiply each bit by its corresponding power of 2 and add all the terms up:
111 1111 1111 1111 1001 1000 0010 0101(2) =
(1 × 230 + 1 × 229 + 1 × 228 + 1 × 227 + 1 × 226 + 1 × 225 + 1 × 224 + 1 × 223 + 1 × 222 + 1 × 221 + 1 × 220 + 1 × 219 + 1 × 218 + 1 × 217 + 1 × 216 + 1 × 215 + 0 × 214 + 0 × 213 + 1 × 212 + 1 × 211 + 0 × 210 + 0 × 29 + 0 × 28 + 0 × 27 + 0 × 26 + 1 × 25 + 0 × 24 + 0 × 23 + 1 × 22 + 0 × 21 + 1 × 20)(10) =
(1 073 741 824 + 536 870 912 + 268 435 456 + 134 217 728 + 67 108 864 + 33 554 432 + 16 777 216 + 8 388 608 + 4 194 304 + 2 097 152 + 1 048 576 + 524 288 + 262 144 + 131 072 + 65 536 + 32 768 + 0 + 0 + 4 096 + 2 048 + 0 + 0 + 0 + 0 + 0 + 32 + 0 + 0 + 4 + 0 + 1)(10) =
(1 073 741 824 + 536 870 912 + 268 435 456 + 134 217 728 + 67 108 864 + 33 554 432 + 16 777 216 + 8 388 608 + 4 194 304 + 2 097 152 + 1 048 576 + 524 288 + 262 144 + 131 072 + 65 536 + 32 768 + 4 096 + 2 048 + 32 + 4 + 1)(10) =
2 147 457 061(10)
5. If needed, adjust the sign of the integer number by the first digit (leftmost) of the signed binary:
1111 1111 1111 1111 1001 1000 0010 0101(2) = -2 147 457 061(10)
Number 1111 1111 1111 1111 1001 1000 0010 0101(2) converted from signed binary to an integer in decimal system (in base 10):
1111 1111 1111 1111 1001 1000 0010 0101(2) = -2 147 457 061(10)
Spaces used to group digits: for binary, by 4; for decimal, by 3.
More operations of this kind:
Convert signed binary numbers to integers in decimal system (base 10)
First bit (the leftmost) is reserved for the sign, 1 = negative, 0 = positive. This bit does not count when calculating the absolute value.
Entered binary number length must be: 2, 4, 8, 16, 32, or 64 - otherwise extra bits on 0 will be added in front (to the left).