## How to convert a signed binary one's complement:

1010 1100 1011 0101 0011 0000 0011 0100_{(2)}

to an integer in decimal system (in base 10)

### 1. Is this a positive or a negative number?

#### In a signed binary one's complement, first bit (the leftmost) indicates the sign,

1 = negative, 0 = positive.

#### 1010 1100 1011 0101 0011 0000 0011 0100 is the binary representation of a negative integer, on 32 bits (4 Bytes).

### 2. Get the binary representation of the positive (unsigned) number:

#### * Run this step only if the number is negative *

#### Flip all the bits in the signed binary one's complement representation (reverse the digits) - replace the bits set on 1 with 0s and the bits on 0 with 1s:

#### !(1010 1100 1011 0101 0011 0000 0011 0100) = 0101 0011 0100 1010 1100 1111 1100 1011

### 3. Map the unsigned binary number's digits versus the corresponding powers of 2 that their place value represent:

2^{31}

0 2^{30}

1 2^{29}

0 2^{28}

1 2^{27}

0 2^{26}

0 2^{25}

1 2^{24}

1 2^{23}

0 2^{22}

1 2^{21}

0 2^{20}

0 2^{19}

1 2^{18}

0 2^{17}

1 2^{16}

0 2^{15}

1 2^{14}

1 2^{13}

0 2^{12}

0 2^{11}

1 2^{10}

1 2^{9}

1 2^{8}

1 2^{7}

1 2^{6}

1 2^{5}

0 2^{4}

0 2^{3}

1 2^{2}

0 2^{1}

1 2^{0}

1

### 4. Multiply each bit by its corresponding power of 2 and add all the terms up:

#### 0101 0011 0100 1010 1100 1111 1100 1011_{(2)} =

#### (0 × 2^{31} + 1 × 2^{30} + 0 × 2^{29} + 1 × 2^{28} + 0 × 2^{27} + 0 × 2^{26} + 1 × 2^{25} + 1 × 2^{24} + 0 × 2^{23} + 1 × 2^{22} + 0 × 2^{21} + 0 × 2^{20} + 1 × 2^{19} + 0 × 2^{18} + 1 × 2^{17} + 0 × 2^{16} + 1 × 2^{15} + 1 × 2^{14} + 0 × 2^{13} + 0 × 2^{12} + 1 × 2^{11} + 1 × 2^{10} + 1 × 2^{9} + 1 × 2^{8} + 1 × 2^{7} + 1 × 2^{6} + 0 × 2^{5} + 0 × 2^{4} + 1 × 2^{3} + 0 × 2^{2} + 1 × 2^{1} + 1 × 2^{0})_{(10)} =

#### (0 + 1 073 741 824 + 0 + 268 435 456 + 0 + 0 + 33 554 432 + 16 777 216 + 0 + 4 194 304 + 0 + 0 + 524 288 + 0 + 131 072 + 0 + 32 768 + 16 384 + 0 + 0 + 2 048 + 1 024 + 512 + 256 + 128 + 64 + 0 + 0 + 8 + 0 + 2 + 1)_{(10)} =

#### (1 073 741 824 + 268 435 456 + 33 554 432 + 16 777 216 + 4 194 304 + 524 288 + 131 072 + 32 768 + 16 384 + 2 048 + 1 024 + 512 + 256 + 128 + 64 + 8 + 2 + 1)_{(10)} =

#### 1 397 411 787_{(10)}

### 5. If needed, adjust the sign of the integer number by the first digit (leftmost) of the signed binary:

#### 1010 1100 1011 0101 0011 0000 0011 0100_{(2)} = -1 397 411 787_{(10)}

## Conclusion:

Number 1010 1100 1011 0101 0011 0000 0011 0100_{(2)} converted from signed binary one's complement representation to an integer in decimal system (in base 10):

## 1010 1100 1011 0101 0011 0000 0011 0100_{(2)} = -1 397 411 787_{(10)}

#### Spaces used to group digits: for binary, by 4; for decimal, by 3.

### More operations of this kind:

## Convert signed binary one's complement numbers to decimal system (base ten) integers

#### 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).