# CS 31: Intro to Systems Binary Arithmetic 

Vasanta Chaganti \& Kevin Webb
Swarthmore College
September 14, 2023

Reading Quiz

## So far: Unsigned Integers

- With N bits, we can represent values: 0 to $2^{\mathrm{n}}-1$
- We can always add 0's to the front of a number without changing it:
$10110=\underline{010110}=\underline{00010110}=\underline{0000010110}$
- 1 byte: char, unsigned char
- 2 bytes: short, unsigned short
- 4 bytes: int, unsigned int, float
- 8 bytes: long long, unsigned long long, double
- 4 or 8 bytes: long, unsigned long


## Unsigned Integers

- Suppose we had one byte
- Can represent $2^{8}$ (256) values
- If unsigned (strictly non-negative): 0-255
$252=11111100$
$253=11111101$
$254=11111110$
$255=11111111$

Traditional number line:
Addition $\longrightarrow$

| 0 | 255 |
| :--- | :--- |
|  | Larger <br> Values |

## Unsigned Integers

- Suppose we had one byte
- Can represent $2^{8}$ (256) values
- If unsigned (strictly non-negative): 0-255
$252=11111100$
$253=11111101$
$254=11111110$
$255=11111111$
What if we add one more?

Car odometer "rolls over".


Any time we are dealing with a finite storage space we cannot represent an infinite number of values!

## Unsigned Integers

- Suppose we had one byte
- Can represent $2^{8}$ (256) values
- If unsigned (strictly non-negative): 0-255

$$
\begin{aligned}
& 252=11111100 \\
& 253=11111101 \\
& 254=11111110 \\
& 255=11111111
\end{aligned}
$$

What if we add one more?


## Unsigned Addition (4-bit)

- Addition works like grade school addition:

$$
\begin{array}{r}
1 \\
0110 \\
+\quad 0100 \\
\hline 1010 \\
+\quad 4 \\
\hline 10
\end{array}
$$

Four bits give us range: 0-15

## Unsigned Addition (4-bit)

- Addition works like grade school addition:

$$
\begin{aligned}
& 1 \\
& 0110 \\
& +\quad 6100 \\
& \hline 1010
\end{aligned} \begin{array}{r}
1100 \\
\hline 10
\end{array} \begin{aligned}
& \frac{12}{10110} \begin{array}{l}
\text { ^carry out }
\end{array}
\end{aligned}
$$

Four bits give us range: 0-15
Overflow!

Suppose we want to support signed values too (positive and negative). Where should we put -1 and -127 on the circle? Why?


C: Put them somewhere else.

## Not Used: Signed Magnitude

- One bit (usually left-most) signals:
- 0 for positive
- 1 for negative

For one byte:

$$
\begin{gathered}
1=00000001 \\
-1=10000001
\end{gathered}
$$



Figure 1. A logical layout of signed magnitude values for bit sequences of length four.
Pros: Negation is very simple!

## Not Used: Signed Magnitude

- One bit (usually left-most) signals:
- 0 for positive
- 1 for negative

For one byte:

$$
\begin{aligned}
0 & =00000000 \\
-0 ? & =10000000
\end{aligned}
$$

Figure 1. A logical layout of signed magnitude values for bit sequences of length four.
Major con: Two ways to represent zero.

## Used Today: Two's Complement

- Borrow nice property from number line:


Only one instance of zero! Implies: -1 and 1 on either side of it.

- For an 8 bit range we can express 256 unique values:
- 128 non-negative values ( 0 to 127)

- 128 negative values ( -1 to -128 )


## Two's Complement

- Only one value for zero
- With N bits, can represent the range:
- $-2^{\mathrm{N}-1}$ to $2^{\mathrm{N}-1}-1$
- Most significant (first) bit still designates positive (0) /negative (1)
- Negating a value is slightly more complicated:

$$
1=00000001, \quad-1=11111111
$$

From now on, unless we explicitly say otherwise, we'll assume all integers are stored using two's complement! This is the standard!

## Two's Compliment

- Each two's compliment number is now:

$$
\left[-2^{n-1 *} d_{n-1}\right]+\left[2^{n-2 *} d_{n-2}\right]+\ldots+\left[2^{1 *} d_{1}\right] \quad+\left[2^{0 *} d_{0}\right]
$$



Note the negative sign on just the first digit.
This is why first digit tells us negative vs. positive.
(The other digits are unchanged and carry the same meaning as unsigned.)

## If we interpret 11001 as a two's complement number, what is the value in decimal?

- Each two's compliment number is now:

$$
\left[-2^{n-1 *} d_{n-1}\right]+\left[2^{n-2 *} d_{n-2}\right]+\ldots+\left[2^{1 *} d_{1}\right] \quad+\quad\left[2^{0 *} d_{0}\right]
$$

A. -2
B. -7
C. -9
D. -25

## "If we interpret..."

-What is the decimal value of 1100 ?

- ...as unsigned, 4-bit value: 12 (\%u)
- ...as signed (two's complement), 4-bit value: -4 (\%d)
- ...as an 8-bit value: 12
(i.e., 00001100)


## Two's Complement Negation

- To negate a value $x$, we want to find $y$ such that $x+y=0$.
- For N bits, $\mathrm{y}=2^{\mathrm{N}}-\mathrm{x}$



## Negation Example (8 bits)

- For N bits, $\mathrm{y}=2^{\mathrm{N}}-\mathrm{x}$
- Negate 00000010 (2)
- $2^{8}-2=256-2=254$
- Our wheel only goes to 127 !
- Put -2 where 254 would be if wheel was unsigned.
- 254 in binary is 11111110



## Negation Shortcut

- A much easier, faster way to negate:
- Flip the bits (0's become 1's, 1's become 0's)
- Add 1
- Negate 00101110 (46)
- $2^{8}-46=256-46=210$
- 210 in binary is 11010010

| $46:$ | 00101110 |
| :--- | ---: |
| Flip the bits: 11010001 |  |
| Add 1 |  |
| +1 |  |
| $-46:$ | 11010010 |

## Decimal to Two's Complement with 8-bit values

 (high-order bit is the sign bit)For positive values, use same algorithm as unsigned

```
For example, 6:
6-4 = 2 (4:2')
    2-2 = 0 (2:2'): 00000110
```

For negative values:

1. convert the equivalent positive value to binary
2. then negate binary to get the negative representation

For example, -3:
3: 00000011
negate: $11111100+1=11111101=-3$

## What is the 8-bit, two's complement representation for -7 ?

For negative values:

1. convert the equivalent positive value to binary
2. then negate binary to get the negative representation
A. 11111001
B. 00000111
C. 11111000
D. 11110011

## Addition \& Subtraction

- Addition is the same as for unsigned
- One exception: different rules for overflow
- Can use the same hardware for both
- Subtraction is the same operation as addition
- Just need to negate the second operand...
- 6-7 = $6+(-7)=6+(\sim 7+1)$
- ~7 is shorthand for "flip the bits of 7 "


## Subtraction Hardware

Negate and add 1 to second operand:
Can use the same circuit for add and subtract:

$$
6-7=6+\sim 7+1
$$



## 4-Bit Subtraction Example

Subtraction via addition: $\mathrm{a}-\mathrm{b}$ is same as $\mathrm{a}+\sim \mathrm{b}+1$

Subtraction: flip bits and add 1

```
3-6 = 0011
    1001 (6: 0110 ~ 6: 1001)
    +
    1101}=-
```

Equivalent addition: don't flip bits or add 1

$$
\begin{aligned}
3+-6= & 0011 \\
& +\frac{1010}{1101}=-3
\end{aligned}
$$

## By switching to two's complement, have we solved this value "rolling over" (overflow) problem?

A. Yes, it's gone.
B. Nope, it's still there.
C. It's even worse now.


## Overflow, Revisited



If we add a positive number and a negative number, will we have overflow? (Assume they are the same \# of bits)
A. Always
B. Sometimes
C. Never


## Two's Complement Overflow For Addition

- Addition Overflow: IFF the sign bits of operands are the same, but the sign bit of result is different.
- Not enough bits to store result!
sign of operands $=$ sign of result

| $3+4=7$ | $-2+-3=-5$ |
| :---: | :---: |
| 0011 | 1110 |
| $+\underline{0100}$ | $+\underline{1101}$ |
| 0111 | 1 |



## Two's Complement Overflow For Addition

- Addition Overflow: IFF the sign bits of operands are the same, but the sign bit of result is different.
- Not enough bits to store result!
sign of operands = sign of result

| $3+4=7$ | $-2+-3=-5$ |
| :---: | :---: |
| 0011 | 1110 |
| $+\underline{0100}$ | $+\underline{1101}$ |
| 0111 | 1 |
| 1011 |  |

sign of operands $\neq$ sign of result

| overflow |  |  |
| :---: | :---: | :---: |
| 0100 | $-6-8=-14$ |  |
| $+\frac{0111}{1011}$ | $\underline{1010}$ |  |
| $(-5)$ | 1000 |  |

## Two's Complement Overflow For Subtraction

- Rule 1:

Minuend
Subtrahend
Result

- Positive operand - Negative operand = Positive Result: No Overflow
- Positive operand - Negative operand = Negative Result: Overflow
- Intuition: We know a positive - negative is equivalent to a positive + positive. If this sum does not result in a positive value we have an overflow
- Rule 2:

Minuend
Subtrahend
Result

- Negative operand - Positive operand = Negative Result: No Overflow
- Negative operand - Positive operand = Positive Result: Overflow
- Intuition: We know a negative - positive number is equivalent to a negative + negative number. If this sum does not result in a negative value we have an overflow


## Two's Complement Overflow For Subtraction

- Rule 1:

Minuend
$\cdots$


Subtrahend
$\cdots$


- Positive operand - Negative operand = Positive Result: No Overflow
- Positive operand - Negative operand = Negative Result: Overflow
- Intuition: We know a positive - negative is equivalent to a positive + positive. If this sum does not result in a positive value we have an overflow

Subtrahend and Result have different sign bits


Subtrahend and Result have the same sign bits

| $2-(-6)=8$ | $3-(-7)=10$ |
| :---: | :---: |
| 0010 | 0011 |
| -1010 | -1001 |
| 0010 | 0011 \| |
| +0110 $\checkmark$ | +0111 |
| 1000 (-8) | $\underline{1010}(-6)$ |

## Two's Complement Overflow For Subtraction

- Rule 2:

Minuend
Subtrahend


- Negative operand - Positive operand = Negative Result: No Overflow
- Negative operand - Positive operand = Positive Result: Overflow
- Intuition: We know a negative - positive number is equivalent to a negative + negative number. If this sum does not result in a negative value we have an overflow

Subtrahend and Result have different sign bits


Subtrahend and Result have the same sign bits


## Two's Complement Overflow For Subtraction

## Subtraction Overflow Rules Summarized:

- Overflow occurs IFF the sign bits of the subtraction operands are different, and the sign bit of the Result and Subtrahend are the same as shown below:
- Minuend - Subtrahend = Result
- If positive - negative = negative (overflow)
- If negative - positive = positive (overflow)
- Now that we have rules for two's complement, let's revisit unsigned numbers and formalize the overflow rules there!


## Recall: Subtraction Hardware

Negate and add 1 to second operand:
Can use the same circuit for add and subtract:

$$
6-7=6+\sim 7+1
$$



## How many of these unsigned operations have overflowed?

Interpret these as 4-bit unsigned values (valid range 0 to 15 ):


A. 1
B. 2
C. 3
D. 4
E. 5

## How many of these unsigned operations have overflowed?

Interpret these as 4-bit unsigned values (valid range 0 to 15 ):


A. 1

Pattern?
B. 2
C. 3
D. 4
E. 5

## Overflow Rule Summary

- Signed overflow:
- The sign bits of operands are the same, but the sign bit of result is different.
- Unsigned: overflow
- The carry-in bit is different from the carry-out.

| $C_{\text {in }}$ | C $_{\text {out }}$ | $C_{\text {in }}$ | XOR |
| :---: | :---: | :---: | :---: |
| 0 | 0 | $C_{\text {out }}$ |  |
| 0 | 1 | 0 |  |
| 1 | 0 | 1 |  |
| 1 | 1 | 1 |  |

## Sign Extension

- When combining signed values of different sizes, expand the smaller value to equivalent larger size:

```
char y = 2, x = -13;
short z = 10;
```

$$
z=z+y ; \quad z=z+x ;
$$

```
0000000000001010
+ 00000010
0000000000000010
```

$$
\begin{aligned}
& 0000000000000101 \\
& + \\
& 1111111111110011
\end{aligned}
$$

Fill in high-order bits with sign-bit value to get same numeric value in larger number of bytes.

## Let's verify that this works

4-bit signed value, sign extend to 8 -bits, is it the same value?

$$
\begin{array}{lllll}
0111 & ---> & 0000 & 0111 & \text { obviously still 7 } \\
1010 & ---> & 1111 & 1010 & \text { is this still -6? }
\end{array}
$$

$-128+64+32+16+8+0+2+0=-6$ yes!

## Operations on Bits

- For these, it doesn't matter how the bits are interpreted (signed vs. unsigned)
- Bit-wise operators (AND, OR, NOT, XOR)
- Bit shifting


## Bit-wise Operators

- Bit operands, Bit result (interpret as appropriate for the context)



## More Operations on Bits (Shifting)

- Bit-shift operators: << left shift, >> right shift

```
01010101 << 2 is 01010100
    2 high-order bits shifted out
    2 ~ l o w - o r d e r ~ b i t s ~ f i l l e d ~ w i t h ~ 0 ~
01101010 << 4 is 10100000
01010101 >> 2 is 00010101
01101010 >> 4 is 00000110
10101100 >> 2 is 00101011 (logical shift)
    or 11101011 (arithmetic shift)
```

Arithmetic right shift: fills high-order bits w/sign bit
C automatically decides which to use based on type: signed: arithmetic, unsigned: logical

## Try some 4-bit examples:

bit-wise operations:

- 0101 \& 1101
- 0101| 1101

Logical (unsigned) bit shift:

- $1010 \ll 2$
- $1010 \gg 2$

Arithmetic (signed) bit shift:

- $1010 \ll 2$
- $1010 \gg 2$


## Up Next

- Circuits
- How can we build hardware to perform all these operations on bits?

