

# Course – Computer Organization and Architecture

---

## Course Instructor

Dr. Umadevi V

Department of CSE, BMSCE



# Unit-4

---

**Arithmetic:** Addition and Subtraction of Signed Numbers, Design of Fast Adders, Multiplication of Unsigned Numbers, Multiplication of Signed Numbers

**Fast Multiplication:** Bit-Pair Recoding of Multipliers, Integer Division, Floating-Point Numbers and Operations : Arithmetic Operations on Floating-Point Numbers, Guard Bits and Truncation , Implementing Floating-Point Operations

# Addition and Subtraction of Signed Numbers

---

# Rough Slide to explain Designing Logic Circuit for Addition of Two numbers

---

$$\begin{array}{r} X \quad 7 \\ Y \quad +6 \\ \hline 13 \end{array} \quad \begin{array}{cccccccccc} 0 & 1 & 1 & 1 & 0 & 0 \\ | & | & | & | & | & | \\ 0 & 1 & 1 & 0 & 1 & 0 \\ \hline & 1 & 1 & 0 & 1 & 0 \end{array} \quad \leftarrow \text{Carry In}$$

# Rough Slide to explain Designing Logic Circuit for Addition of Two numbers

---

| X | Y | Ex-OR<br>$X \oplus Y$ |
|---|---|-----------------------|
| 0 | 0 | 0                     |
| 0 | 1 | 1                     |
| 1 | 0 | 1                     |
| 1 | 1 | 0                     |



$$X \oplus Y = \bar{X}Y + X\bar{Y}$$

# Rough Slide to explain Designing Logic Circuit for Addition of Two numbers

---

| X | Y | Logical OR<br>X+Y | $\bar{X} + \bar{Y}$ | $\bar{X}$ | $\bar{Y}$ | $\bar{X} \bar{Y}$ | Logical AND<br>XY | $\bar{X}\bar{Y}$ | $\bar{X} + \bar{Y}$ |
|---|---|-------------------|---------------------|-----------|-----------|-------------------|-------------------|------------------|---------------------|
| 0 | 0 | 0                 | 1                   | 1         | 1         | 1                 | 0                 | 1                | 1                   |
| 0 | 1 | 1                 | 0                   | 1         | 0         | 0                 | 0                 | 1                | 1                   |
| 1 | 0 | 1                 | 0                   | 0         | 1         | 0                 | 0                 | 1                | 1                   |
| 1 | 1 | 1                 | 0                   | 0         | 0         | 0                 | 1                 | 0                | 0                   |

$$\overline{X + Y} = \bar{X} \bar{Y}$$

$$\overline{XY} = \bar{X} + \bar{Y}$$

| X | $\bar{X}$ | $\bar{\bar{X}}$ |
|---|-----------|-----------------|
| 0 | 1         | 0               |
| 1 | 0         | 1               |

$$\bar{X} = \bar{\bar{X}}$$

# Rough Slide to explain Designing Logic Circuit for Addition of Two numbers

| $x_i$ | $y_i$ | Carry-in $c_i$ | Sum $s_i$ | Carry-out $c_{i+1}$ |
|-------|-------|----------------|-----------|---------------------|
| 0     | 0     | 0              | 0         | 0                   |
| 0     | 0     | 1              | 1         | 0                   |
| 0     | 1     | 0              | 1         | 0                   |
| 0     | 1     | 1              | 0         | 1                   |
| 1     | 0     | 0              | 1         | 0                   |
| 1     | 0     | 1              | 0         | 1                   |
| 1     | 1     | 0              | 0         | 1                   |
| 1     | 1     | 1              | 1         | 1                   |

# Rough Slide to explain Designing Logic Circuit for Addition of Two numbers

| $x_i$ | $y_i$ | Carry-in $c_i$ | Sum $s_i$ | Carry-out $c_{i+1}$ |
|-------|-------|----------------|-----------|---------------------|
| 0     | 0     | 0              | 0         | 0                   |
| 0     | 0     | 1              | 1         | 0                   |
| 0     | 1     | 0              | 1         | 0                   |
| 0     | 1     | 1              | 0         | 1                   |
| 1     | 0     | 0              | 1         | 0                   |
| 1     | 0     | 1              | 0         | 1                   |
| 1     | 1     | 0              | 0         | 1                   |
| 1     | 1     | 1              | 1         | 1                   |

$$S_i = \bar{X}_i \bar{Y}_i C_i + \bar{X}_i Y_i \bar{C}_i + X_i \bar{Y}_i \bar{C}_i + X_i Y_i C_i$$

$$= \bar{X}_i \bar{Y}_i C_i + X_i Y_i C_i + \bar{X}_i Y_i \bar{C}_i + X_i \bar{Y}_i \bar{C}_i$$

$$= C_i (\bar{X}_i \bar{Y}_i + X_i Y_i) + \bar{C}_i (\bar{X}_i Y_i + X_i \bar{Y}_i)$$

$$= C_i (X_i \oplus Y_i) + \bar{C}_i (X_i \oplus Y_i)$$

$$S_i = C_i \oplus X_i \oplus Y_i$$

$$\begin{aligned}
 \overline{X_i \oplus Y_i} &= \overline{\bar{X}_i Y_i + X_i \bar{Y}_i} \\
 &= \overline{\bar{X}_i Y_i} \overline{X_i \bar{Y}_i} \\
 &= (\bar{\bar{X}}_i + \bar{Y}_i)(\bar{X}_i + \bar{\bar{Y}}_i) \\
 &= X_i \bar{X}_i + X_i Y_i + \bar{Y}_i \bar{X}_i + \bar{Y}_i Y_i \\
 &= X_i Y_i + \bar{Y}_i \bar{X}_i
 \end{aligned}$$

# Rough Slide to explain Designing Logic Circuit for Addition of Two numbers

| $x_i$ | $y_i$ | Carry-in $c_i$ | Sum $s_i$ | Carry-out $c_{i+1}$ |
|-------|-------|----------------|-----------|---------------------|
| 0     | 0     | 0              | 0         | 0                   |
| 0     | 0     | 1              | 1         | 0                   |
| 0     | 1     | 0              | 1         | 0                   |
| 0     | 1     | 1              | 0         | 1                   |
| 1     | 0     | 0              | 1         | 0                   |
| 1     | 0     | 1              | 0         | 1                   |
| 1     | 1     | 0              | 0         | 1                   |
| 1     | 1     | 1              | 1         | 1                   |

$$\overline{C}_i = \overline{X}_i Y_i C_i + X_i \overline{Y}_i C_i + X_i Y_i \overline{C}_i + X_i Y_i C_i$$

Karnaugh map

$$C_{i+1} = X_i Y_i + X_i C_i + Y_i C_i$$



# Addition of signed numbers

| $x_i$ | $y_i$ | Carry-in $c_i$ | Sum $s_i$ | Carry-out $c_{i+1}$ |
|-------|-------|----------------|-----------|---------------------|
| 0     | 0     | 0              | 0         | 0                   |
| 0     | 0     | 1              | 1         | 0                   |
| 0     | 1     | 0              | 1         | 0                   |
| 0     | 1     | 1              | 0         | 1                   |
| 1     | 0     | 0              | 1         | 0                   |
| 1     | 0     | 1              | 0         | 1                   |
| 1     | 1     | 0              | 0         | 1                   |
| 1     | 1     | 1              | 1         | 1                   |

$$s_i = \overline{x_i} \overline{y_i} \overline{c_i} + \overline{x_i} y_i \overline{c_i} + x_i \overline{y_i} \overline{c_i} + x_i y_i c_i = x_i \oplus y_i \oplus c_i$$

$$c_{i+1} = y_i c_i + x_i c_i + x_i y_i$$

At the  $i^{th}$  stage:

Input:

$c_i$  is the carry-in

Output:

$s_i$  is the sum

$c_{i+1}$  carry-out to  $(i+1)^{st}$  state

Example:

$$\begin{array}{r} X \\ + Y \\ \hline Z \end{array} = \begin{array}{r} 7 \\ + 6 \\ \hline 13 \end{array} = \begin{array}{r} & 0 & 1 & 1 \\ & 0 & 0 & 1 & 1 \\ + & 1 & 1 & 1 & 0 \\ \hline & 0 & 1 & 0 & 1 \end{array}$$



# Addition logic for a single stage



**Full Adder (FA):** Symbol for the complete circuit for a single stage of addition.

# Full Adder

- Full adder is a logic circuit that adds two input operand bits plus a Carry in bit and outputs a Carry out bit and a sum bit.. The Sum out (Sout) of a full adder is the XOR of input operand bits A, B and the Carry in (Cin) bit.

| Inputs |   |     | Outputs |   |
|--------|---|-----|---------|---|
| A      | B | Cin | Cout    | S |
| 0      | 0 | 0   | 0       | 0 |
| 1      | 0 | 0   | 0       | 1 |
| 0      | 1 | 0   | 0       | 1 |
| 1      | 1 | 0   | 1       | 0 |
| 0      | 0 | 1   | 0       | 1 |
| 1      | 0 | 1   | 1       | 0 |
| 0      | 1 | 1   | 1       | 0 |
| 1      | 1 | 1   | 1       | 1 |



1 bit full adder truth table & schematic

# Full Adder

$$S = X_i \oplus Y_i \oplus C_i$$

$$C_{i+1} = X_i Y_i + X_i C_i + Y_i C_i$$



## Two 4-bit Adder (Two 4-Bit Ripple Carry Adder) using four Full Adder (FA)



$$\begin{array}{r} X \quad 7 \\ Y \quad +6 \\ \hline 13 \end{array} \quad \begin{array}{r} 0 \quad 1 \quad 1 \quad 1 \quad 0 \quad 0 \quad 0 \\ 0 \quad 1 \quad 1 \quad 1 \quad 0 \quad 0 \quad 0 \\ \hline 1 \quad 1 \quad 0 \quad 1 \end{array} \quad \text{Carry In}$$

# Ripple carry adder

A ripple carry adder is a digital circuit that produces the arithmetic sum of two binary numbers. It can be constructed with full adders connected in cascaded, with the carry output from each full adder connected to the carry input of the next full adder in the chain. Figure below, shows the interconnection of four full adder (FA) circuits to provide a 4-bit ripple carry adder. Notice from the Figure that the input is from the right side because the first cell traditionally represents the least significant bit (LSB). Bits A0 and B0 in the figure represent the least significant bits of the numbers to be added. The sum output is represented by the bits S0 to S3 .



# $n$ -bit adder

- Cascade  $n$  full adder (FA) blocks to form a  $n$ -bit adder.
- Carries propagate or ripple through this cascade,  $n$ -bit ripple carry adder.



- Carry-in  $c_0$  into the LSB position provides a convenient way to perform subtraction.

# Question

---

Using Full adders, how many full adders are required to construct 16-bit ripple carry adder ?

# Computing the Delay



Consider 0<sup>th</sup> stage:

- $c_1$  is available after 2 gate delays.
- $s_0$  is available after 1 gate delay.

$$S = X_i \oplus Y_i \oplus C_i$$

$$C_{i+1} = X_i Y_i + X_i C_i + Y_i C_i$$



Full Adder Implementation

# Computing the Delay

Cascade of 4 Full Adders, or a 4-bit adder



For an  $n$ -bit adder,  $s_{n-1}$  is available after,

$$s_{n-1} = 2(n-1) + 1 = 2n - 1 \text{ Gate delays}$$

$c_n$  is available after  $2n$  Gate delays

# Delay in Ripple carry adder

---

- Carry propagation delay of a full adder is the time taken by it to produce the output carry bit.
- Sum propagation delay of a full adder is the time taken by it to produce the output sum bit.
- Worst case delay of a ripple carry adder is the time after which the output sum bit and carry bit becomes available from the last full adder.
- We know, In ripple carry adder, a full adder becomes active only when its carry in is made available by its adjacent less significant full adder.
- When carry in becomes available to the full adder, it starts its operation and produces the corresponding output sum bit and carry bit.

# Question

Following figure shows the implementation of full adders in a 16-bit ripple carry adder realized using 16 identical full adders. The propagation delay of the XOR, AND and OR gates are 20 ns, 15 ns and 10 ns respectively. The worst case delay of this 16 bit adder will be \_\_\_\_\_?

- A) 395 ns
- B) 220 ns
- C) 400 ns
- D) 300 ns



Full Adder Implementation

# Answer

We will consider the last full adder for worst case delay.

**Time after which output carry bit** becomes available from the last full adder

= Total number of full adders x Carry propagation delay of a full adder



# Answer

We will consider the last full adder for worst case delay.

**Time after which output carry bit** becomes available from the last full adder

- = Total number of full adders x Carry propagation delay of a full adder
- = Total number of full adders x { Propagation delay of AND gate + Propagation delay of OR gate }



# Answer

We will consider the last full adder for worst case delay.

**Time after which output carry bit becomes available from the last full adder**

= Total number of full adders x Carry propagation delay of a full adder

= Total number of full adders x { Propagation delay of AND gate +  
Propagation delay of OR gate }

$$= 16 \times \{ 15 \text{ ns} + 10 \text{ ns} \}$$

$$= 16 \times 25 \text{ ns}$$

$$= 400 \text{ ns}$$



Full Adder Implementation

# Answer (Contd...)

---

We will consider the last full adder for worst case delay.

Time after which output carry bit becomes available from the last full adder

$$= \text{Total number of full adders} \times \text{Carry propagation delay of a full adder}$$

$$= \text{Total number of full adders} \times \{ \text{Propagation delay of AND gate} + \\ \text{Propagation delay of OR gate} \}$$

$$= 16 \times \{ 15 \text{ ns} + 10 \text{ ns} \}$$

$$= 16 \times 25 \text{ ns}$$

$$= 400 \text{ ns}$$

**Time after which output sum bit becomes available from the last full adder**

$$= \text{Time taken for its carry in to become available} + \\ \text{Sum propagation delay of a full adder}$$

# Answer (Contd...)

---

We will consider the last full adder for worst case delay.

Time after which output carry bit becomes available from the last full adder

$$= \text{Total number of full adders} \times \text{Carry propagation delay of a full adder}$$

$$= \text{Total number of full adders} \times \{ \text{Propagation delay of AND gate} + \\ \text{Propagation delay of OR gate} \}$$

$$= 16 \times \{ 15 \text{ ns} + 10 \text{ ns} \}$$

$$= 16 \times 25 \text{ ns}$$

$$= 400 \text{ ns}$$

**Time after which output sum bit** becomes available from the last full adder

$$= \text{Time taken for its carry in to become available} + \\ \text{Sum propagation delay of a full adder}$$

$$= \{ \text{Total number of full adders before last full adder} \times \text{Carry propagation delay of a full adder} \} + \text{Propagation delay of XOR gate}$$

$$= \{ 15 \times (15 \text{ ns} + 10 \text{ ns}) \} + 20 \text{ ns}$$

$$= 395 \text{ ns}$$

# Computing the Delay



Consider 0<sup>th</sup> stage:

- $c_1$  is available after 2 gate delays.
- $s_0$  is available after 1 gate delay.

$$S = X_i \oplus Y_i \oplus C_i$$

$$C_{i+1} = X_i Y_i + X_i C_i + Y_i C_i$$



Full Adder Implementation

# n-bit subtractor

- Recall  $X - Y$  is equivalent to adding 2's complement of  $Y$  to  $X$ .
- 2's complement is equivalent to 1's complement + 1.
- $X - Y = X + \bar{Y} + 1$
- 2's complement of positive and negative numbers is computed similarly.



# *n*-bit adder/subtractor (contd..)



# Rough Slide to explain Design of two four bit subtractor

---



| X | Y | Ex-OR<br>$X \oplus Y$ |
|---|---|-----------------------|
| 0 | 0 | 0                     |
| 0 | 1 | 1                     |
| 1 | 0 | 1                     |
| 1 | 1 | 0                     |

# Design of two four bit subtractor

0: Add  
1: Sub



$$\begin{array}{r}
 X \quad 7 \quad 0 \quad 1 \quad 1 \quad 1 \\
 -Y \quad -6 \quad + \quad 1 \quad 0 \quad 1 \quad 0 \quad \leftarrow \text{2's Complement of 6} \\
 \hline
 1 \quad 1 \quad 0 \quad 0 \quad 0 \quad 1
 \end{array}$$

Ignore Carryout

# Detecting Overflows

It occurs when the signs of the two operands are the same, but the sign of the result is different.

Overflow can be added to the  $n$ -bit adder by implementing the logic expression

Recall that the MSB represents the sign.

- $x_{n-1}, y_{n-1}, s_{n-1}$  represent the sign of operand  $x$ , operand  $y$  and result  $s$  respectively.

Circuit to detect overflow can be implemented by the following logic expressions:

$$\text{Overflow} = x_{n-1}y_{n-1}\bar{s}_{n-1} + \bar{x}_{n-1}\bar{y}_{n-1}s_{n-1}$$

**OR**

$$\text{Overflow} = c_n \oplus c_{n-1}$$

|   |    |   |   |   |   |   |   |            |
|---|----|---|---|---|---|---|---|------------|
| X | 7  | 0 | 1 | 1 | 1 | 1 | 1 |            |
| Y | +6 | 0 | 1 | 1 | 1 | 0 | 0 | ← Carry In |
|   |    | 1 | 1 | 0 | 0 | 1 |   |            |

# Question

Consider the ALU shown below. If the operands are in 2's complement representation, which of the following operations can be performed by suitably setting the control lines K and C0 only (+ and - denote addition and subtraction respectively) ?



- a.  $A + B$ , and  $A - B$ , but not  $A + 1$
- b.  $A + B$ , and  $A + 1$ , but not  $A - B$
- c.  $A + B$ , but not  $A - B$ , or  $A + 1$
- d.  $A + B$ , and  $A - B$ , and  $A + 1$

**Answer:** (a). $A + B$ , and  $A - B$ , but not  $A + 1$

# Answer

**Explanation:** We can set value of k and c as 0 or 1

Two things we need to know—

If we take xor of any number with 1 we get it in its complement form.

If we take xor of any number with 0 we get that number itself.

So on setting  $k=1$  we can get  $-B$  and  $c$  will work like select signal

Like  $c=0$  means add

$C=1$  means subtract

Hence with  $k=1$   $c=1$  we get  $A-B$

With  $K=0$   $c=0$  we get  $A+B$

We need  $b=1, c=0$  or  $b=0, c=1$  to get  $A+1$  since  $b$  isn't predefined we can't get  $A+1$

So Ans is (a) part A + B, and A - B, but not A + 1



# Unit-4

---

## Design of Fast Adders

# Design of Fast Adders

---

- Source of bottleneck with Ripple Carry Adder is Carry Signal Generation
- Propogation of Carry Signals should be Faster

# Fast addition

---

Recall the equations:

$$S_i = x_i \oplus y_i \oplus c_i$$

$$c_{i+1} = x_i y_i + x_i c_i + y_i c_i$$

Second equation can be written as:

$$c_{i+1} = x_i y_i + (x_i + y_i) c_i$$

We can write:

$$c_{i+1} = G_i + P_i c_i$$

where  $G_i = x_i y_i$  and  $P_i = x_i + y_i$

- $G_i$  is called **generate** function and  $P_i$  is called **propagate** function
- $G_i$  and  $P_i$  are computed only from  $x_i$  and  $y_i$  and not  $c_i$ , thus they can be computed in one gate delay after  $X$  and  $Y$  are applied to the inputs of an  $n$ -bit adder.

# Carry Lookahead Addition

---

$$S = X_i \oplus Y_i \oplus C_i$$

$$C_{i+1} = X_i Y_i + X_i C_i + Y_i C_i$$

$$\begin{aligned}C_{i+1} &= X_i Y_i + C_i(X_i + Y_i) \\&= G_i + C_i P_i\end{aligned}$$

Where  $G_i = X_i Y_i$  Generate Function  
 $P_i = X_i + Y_i$  Propogate Function

**Note:** Propogate function means whether an input carry produces and output carryout

**Note:** Irrespective of  $P_i$  and  $C_i$ , if  $G_i$  is 1 then carry out is 1

# Carry Lookahead Addition (Contd...)

---

$$S = X_i \oplus Y_i \oplus C_i$$

$$\begin{aligned}C_{i+1} &= X_i Y_i + C_i (X_i + Y_i) \\&= G_i + C_i P_i\end{aligned}$$

Where  $G_i = X_i Y_i$  Generate Function  
 $P_i = X_i + Y_i$  Propogate Function

| $X_i$    | $Y_i$    | $G_i = X_i Y_i$ |
|----------|----------|-----------------|
| 0        | 0        | 0               |
| 0        | <b>X</b> | 0               |
| <b>X</b> | 0        | 0               |
| 1        | 1        | 1               |

Note: **X** any thing 0 or 1

# Carry Lookahead Addition (Contd...)

$$S = X_i \oplus Y_i \oplus C_i$$

$$\begin{aligned}C_{i+1} &= X_i Y_i + C_i (X_i + Y_i) \\&= G_i + C_i P_i\end{aligned}$$

Where  $G_i = X_i Y_i$  Generate Function  
 $P_i = X_i + Y_i$  Propagate Function

| $X_i$    | $Y_i$    | $G_i = X_i Y_i$ |
|----------|----------|-----------------|
| 0        | 0        | 0               |
| 0        | <b>X</b> | 0               |
| <b>X</b> | 0        | 0               |
| 1        | 1        | 1               |

| $X_i$    | $Y_i$    | $C_i$    | $P_i = X_i + Y_i$ | $P_i C_i$ |
|----------|----------|----------|-------------------|-----------|
| <b>X</b> | <b>X</b> | <b>0</b> | <b>X</b>          | <b>0</b>  |
| <b>0</b> | <b>0</b> | 1        | 0                 | <b>0</b>  |
| <b>X</b> | 1        | 1        | 1                 | 1         |
| 1        | <b>X</b> | 1        | 1                 | 1         |

Note: **X** any thing 0 or 1

# Carry Lookahead Addition (Contd...)

$$S = X_i \oplus Y_i \oplus C_i$$

$$\begin{aligned}C_{i+1} &= X_i Y_i + C_i(X_i + Y_i) \\&= G_i + C_i P_i\end{aligned}$$

Where  $G_i = X_i Y_i$  Generate Function  
 $P_i = X_i + Y_i$  Propogate Function

| $X_i$    | $Y_i$    | $G_i = X_i Y_i$ |
|----------|----------|-----------------|
| 0        | 0        | 0               |
| 0        | <b>X</b> | 0               |
| <b>X</b> | 0        | 0               |
| 1        | 1        | 1               |

| $X_i$    | $Y_i$    | $C_i$    | $P_i = X_i + Y_i$ | $P_i C_i$ |
|----------|----------|----------|-------------------|-----------|
| <b>X</b> | <b>X</b> | <b>0</b> | <b>X</b>          | <b>0</b>  |
| 0        | 0        | 1        | 0                 | <b>0</b>  |
| <b>X</b> | 1        | 1        | 1                 | 1         |
| 1        | <b>X</b> | 1        | 1                 | 1         |

Note: **X** any thing 0 or 1

| $X$ | $Y$ | $X \oplus Y$ |
|-----|-----|--------------|
| 0   | 0   | 0            |
| 0   | 1   | 1            |
| 1   | 0   | 1            |
| 1   | 1   | 0            |

We can re-write  
 $P_i = X_i + Y_i$  as  $P_i = X_i \oplus Y_i$

# Carry Lookahead Addition (Contd...)

$$S = X_i \oplus Y_i \oplus C_i$$

$$\begin{aligned}C_{i+1} &= X_i Y_i + C_i(X_i + Y_i) \\&= G_i + C_i P_i\end{aligned}$$

Where  $G_i = X_i Y_i$  Generate Function  
 $P_i = X_i + Y_i$  Propogate Function

| $X_i$    | $Y_i$    | $G_i = X_i Y_i$ |
|----------|----------|-----------------|
| 0        | 0        | 0               |
| 0        | <b>X</b> | 0               |
| <b>X</b> | 0        | 0               |
| 1        | 1        | 1               |

| $X_i$    | $Y_i$    | $C_i$    | $P_i = X_i + Y_i$ | $P_i C_i$ |
|----------|----------|----------|-------------------|-----------|
| <b>X</b> | <b>X</b> | <b>0</b> | <b>X</b>          | <b>0</b>  |
| 0        | 0        | 1        | 0                 | <b>0</b>  |
| <b>X</b> | 1        | 1        | 1                 | 1         |
| 1        | <b>X</b> | 1        | 1                 | 1         |

Note: **X** any thing 0 or 1

| $X$ | $Y$ | $X \oplus Y$ |
|-----|-----|--------------|
| 0   | 0   | 0            |
| 0   | 1   | 1            |
| 1   | 0   | 1            |
| 1   | 1   | 0            |

We can re-write

$$P_i = X_i + Y_i \text{ as } P_i = X_i \oplus Y_i$$

$P_i = X_i \oplus Y_i$  differs from

$P_i = X_i + Y_i$  only when  $X_i=Y_i=1$

But in this case  $G_i=1$ , so it doe not matter

Whether  $P_i$  is 0 or 1

# Designing 4-bit Carry Lookahead Adder (CLA)

|   | $c_3$ | $c_2$ | $c_1$ | $c_0$ |       |
|---|-------|-------|-------|-------|-------|
| X | $x_3$ | $x_2$ | $x_1$ | $x_0$ |       |
| Y | $y_3$ | $y_2$ | $y_1$ | $y_0$ |       |
| S | $c_4$ | $S_3$ | $S_2$ | $S_1$ | $S_0$ |

$$S_0 = X_0 \oplus Y_0 \oplus C_0$$

$$C_1 = G_0 + C_0 P_0$$

Where  $G_0 = X_0 Y_0$

$$P_0 = X_0 \oplus Y_0$$



Bit Stage Cell or B-Cell

# Designing 4-bit Carry Lookahead Adder (CLA)

|   | $c_3$ | $c_2$ | $c_1$ | $c_0$ |
|---|-------|-------|-------|-------|
| X | $x_3$ | $x_2$ | $x_1$ | $x_0$ |
| Y | $y_3$ | $y_2$ | $y_1$ | $y_0$ |
| S | $c_4$ | $S_3$ | $S_2$ | $S_1$ |
|   |       |       |       | $S_0$ |

$$S_0 = X_0 \oplus Y_0 \oplus C_0$$

$$C_1 = G_0 + C_0 P_0$$

Where  $G_0 = X_0 Y_0$   
 $P_0 = X_0 \oplus Y_0$



Bit Stage Cell or B-Cell

# Designing 4-bit Carry Look Ahead (CLA) Adder using four Bit Stage cell or B-Cell

---

$$S_0 = X_0 \oplus Y_0 \oplus C_0 \quad C_1 = G_0 + P_0 C_0 \quad G_0 = X_0 Y_0 \quad P_0 = X_0 \oplus Y_0$$

# Designing 4-bit Carry Look Ahead (CLA) Adder using four Bit Stage cell or B-Cell

---

$$S_0 = X_0 \oplus Y_0 \oplus C_0 \quad C_1 = G_0 + P_0 C_0 \quad G_0 = X_0 Y_0 \quad P_0 = X_0 \oplus Y_0$$

$$S_1 = X_1 \oplus Y_1 \oplus C_1 \quad C_2 = G_1 + P_1 C_1 \quad G_1 = X_1 Y_1 \quad P_1 = X_1 \oplus Y_1$$
$$C_2 = G_1 + P_1 G_0 + P_1 P_0 C_0$$

# Designing 4-bit Carry Look Ahead (CLA) Adder using four Bit Stage cell or B-Cell

---

$$S_0 = X_0 \oplus Y_0 \oplus C_0 \quad C_1 = G_0 + P_0 C_0 \quad G_0 = X_0 Y_0 \quad P_0 = X_0 \oplus Y_0$$

$$S_1 = X_1 \oplus Y_1 \oplus C_1 \quad C_2 = G_1 + P_1 C_1 \quad G_1 = X_1 Y_1 \quad P_1 = X_1 \oplus Y_1$$
$$C_2 = G_1 + P_1 G_0 + P_1 P_0 C_0$$

$$S_2 = X_2 \oplus Y_2 \oplus C_2 \quad C_3 = G_2 + P_2 C_2 \quad G_2 = X_2 Y_2 \quad P_2 = X_2 \oplus Y_2$$
$$C_3 = G_2 + P_2 G_1 + P_2 P_1 G_0 + P_2 P_1 P_0 C_0$$

$$S_3 = X_3 \oplus Y_3 \oplus C_3 \quad C_4 = G_3 + P_3 C_3 \quad G_3 = X_3 Y_3 \quad P_3 = X_3 \oplus Y_3$$
$$C_4 = G_3 + P_3 G_2 + P_3 P_2 G_1 + P_3 P_2 P_1 G_0 + P_3 P_2 P_1 P_0 C_0$$

# Designing 4-bit Carry Look Ahead (CLA) Adder using four Bit Stage cell or B-Cell (Contd...)



# Performance Analysis of CLA

Number of gate Delays for **Carry** Signal Generation

$$\begin{array}{ccc} 1 & + & 2 \\ \uparrow & & \uparrow \end{array} = 3 \text{ Gate Delays}$$

$G_i$     $P_i$   
Generation      AND , OR of  
 $G_i + P_i C_i$

$$\begin{aligned} C_1 &= G_0 + P_0 C_0 \\ G_0 &= X_0 Y_0 \\ P_0 &= X_0 \oplus Y_0 \end{aligned}$$

Number of gate Delays for **Sum** Signal Generation

$$\begin{array}{ccc} 3 & + & 1 \\ \uparrow & & \uparrow \end{array} = 4 \text{ Gate Delays}$$

For Carry       $S_i = X_i \oplus Y_i \oplus C_i$



# Comparison between RCA and CLA

|     | Number of Gate Delays |   |           |    |           |      |
|-----|-----------------------|---|-----------|----|-----------|------|
|     | For 4-bit             |   | For 8-bit |    | For n-bit |      |
|     | S                     | C | S         | C  | S         | C    |
| RCA | 7                     | 8 | 15        | 16 | $2n-1$    | $2n$ |
| CLA | 4                     | 3 | 4         | 3  | 4         | 3    |

S: Sum Signal  
C: Carry Signal

← Remains Same

## Disadvantages of CLA

### 1. For 4-bit Adder

$$c_4 = G_3 + P_3G_2 + P_3P_2G_1 + P_3P_2P_1G_0 + P_3P_2P_1P_0c_0 \quad \text{We need Five Input AND Gate}$$

### 2. For 8-bit Adder

$$\begin{aligned} c_8 = & G_7 + P_7G_6 + P_7P_6G_5 + P_7P_6P_5G_4 + P_7P_6P_5P_4G_3 + P_7P_6P_5P_4P_3G_2 \\ & + P_7P_6P_5P_4P_3P_2G_1 + P_7P_6P_5P_4P_3P_2P_1G_0 + P_7P_6P_5P_4P_3P_2P_1P_0c_0 \end{aligned}$$

We need Nine Input AND Gate

# Performance Analysis of CLA

---

| <b>CLA</b> | <b>Fan-In Required</b> |
|------------|------------------------|
| 4-Bit      | 5                      |
| 8-bit      | 9                      |
| n-bit      | (n+1)                  |

Fan-In: Number of Input's to the Gate

## Advantages of CLA

Number of Gate Delays are Less

## Disadvantages of CLA

Fan-In required is Very high i.e., (n+1)

# Designing 16-bit adder using 4-bit CLA adders



# Designing 32-bit adder using 4-bit CLA adders

Cascading eight 4-bit CLA adder to obtain 32-bit adder



# Unit-4

---

Multiplication of Unsigned Numbers, Multiplication of Signed Numbers,  
Fast Multiplication, Floating-Point Numbers and Operations

# Unit-4

---

Array Multiplication: Using Full Adders

# Multiplication of Unsigned Numbers: Array Multiplier

Example

$$\begin{array}{r} 11 \text{ Multiplicand (M)} \\ \times 13 \text{ Multiplier (Q)} \\ \hline 33 \\ 11 \\ \hline 143 \text{ Product (P)} \end{array}$$

## Multiplication of Unsigned Numbers: Array Multiplier

---

Example

$$\begin{array}{r} & 1 & 0 & 1 & 1 & (11) \\ \times & 1 & 1 & 0 & 1 & \hline \end{array}$$

---

---

## Multiplication of Unsigned Numbers: Array Multiplier

---

Example

$$\begin{array}{r} & 1 & 0 & 1 & 1 & (11) \\ \times & 1 & 1 & 0 & 1 & (13) \\ \hline & 1 & 0 & 1 & 1 & \end{array}$$

---

---

## Multiplication of Unsigned Numbers: Array Multiplier

---

Example

$$\begin{array}{r} & 1 & 0 & 1 & 1 & (11) \\ \times & 1 & 1 & 0 & 1 & (13) \\ \hline & 1 & 0 & 1 & 1 \\ 0 & 0 & 0 & 0 & \\ \hline \end{array}$$

---

---

## Multiplication of Unsigned Numbers: Array Multiplier

Example

$$\begin{array}{r} & 1 & 0 & 1 & 1 & (11) \\ \times & 1 & 1 & 0 & 1 & (13) \\ \hline & 1 & 0 & 1 & 1 \\ 0 & 0 & 0 & 0 \\ 1 & 0 & 1 & 1 \\ \hline 1 & 0 & 1 & 1 \\ \hline 1 & 0 & 0 & 1 & 1 & 1 & 1 \end{array}$$

11 Multiplicand ( $M$ )  
 $\times 13$  Multiplier ( $A$ )  
 $\hline$   
 $\overline{11}$  Product ( $P$ )

# Multiplication of Unsigned Numbers: Array Multiplier

Example

$$\begin{array}{r} & 1 & 0 & 1 & 1 & (11) \\ \times & 1 & 1 & 0 & 1 & (13) \\ \hline & 1 & 0 & 1 & 1 \\ 0 & 0 & 0 & 0 \\ 1 & 0 & 1 & 1 \\ 1 & 0 & 1 & 1 \\ \hline 1 & 0 & 0 & 1 & 1 & 1 & 1 \end{array}$$

11 Multiplicand ( $M$ )  
 $\times 13$  Multiplier ( $Q$ )  
 $\underline{\underline{33}}$   
 $\underline{\underline{11}}$  Product ( $P$ )  
 $\underline{\underline{143}}$

$$\begin{array}{r} & 1 & 0 & 1 & 1 & (11) \\ \times & 1 & 1 & 0 & 1 & (13) \\ \hline & 1 & 0 & 1 & 1 \\ 0 & 0 & 0 & 0 \\ \hline 0 & 1 & 0 & 1 & 1 & 1 \end{array}$$

Partial Sum or  
Partial Product

# Multiplication of Unsigned Numbers: Array Multiplier

Example

$$\begin{array}{r} & 1 & 0 & 1 & 1 & (11) \\ \times & 1 & 1 & 0 & 1 & (13) \\ \hline & 1 & 0 & 1 & 1 \\ 0 & 0 & 0 & 0 \\ 1 & 0 & 1 & 1 \\ 1 & 0 & 1 & 1 \\ \hline 1 & 0 & 0 & 1 & 1 & 1 & 1 \end{array}$$

11 Multiplicand ( $M$ )  
 $\times 13$  Multiplier ( $Q$ )  
 $\hline 33$   
 $\frac{11}{143}$  Product ( $P$ )

$$\begin{array}{r} & 1 & 0 & 1 & 1 & (11) \\ \times & 1 & 1 & 0 & 1 & (13) \\ \hline & 1 & 0 & 1 & 1 \\ 0 & 0 & 0 & 0 \\ 0 & 1 & 0 & 1 & 1 & 1 \leftarrow \text{Partial Sum or Partial Product} \\ 1 & 0 & 1 & 1 \\ \hline 1 & 1 & 0 & 1 & 1 & 1 \\ 1 & 0 & 1 & 1 \\ \hline 1 & 0 & 0 & 1 & 1 & 1 \end{array}$$

# Multiplication of Unsigned Numbers: Array Multiplier

$$\begin{array}{r} & 1 & 0 & 1 & 1 & (11) \\ \times & 1 & 1 & 0 & 1 & (13) \\ \hline & 1 & 0 & 1 & 1 \\ 0 & 0 & 0 & 0 \\ 1 & 0 & 1 & 1 \\ 1 & 0 & 1 & 1 \\ \hline 1 & 0 & 0 & 1 & 1 & 1 \end{array}$$

|       | $m_3$    | $m_2$    | $m_1$    | $m_0$    | Multiplicand (M) |
|-------|----------|----------|----------|----------|------------------|
|       | $q_3$    | $q_2$    | $q_1$    | $q_0$    | Multiplier (Q)   |
|       | $m_3q_0$ | $m_2q_0$ | $m_1q_0$ | $m_0q_0$ |                  |
|       | $m_3q_1$ | $m_2q_1$ | $m_1q_1$ | $m_0q_1$ |                  |
|       | $m_3q_2$ | $m_2q_2$ | $m_1q_2$ | $m_0q_2$ |                  |
|       | $m_3q_3$ | $m_2q_3$ | $m_1q_3$ | $m_0q_3$ |                  |
| $P_7$ | $P_6$    | $P_5$    | $P_4$    | $P_3$    | $P_2$            |
|       |          |          |          |          | $P_1$            |
|       |          |          |          |          | $P_0$            |

# Array Multiplication of Unsigned Numbers using Full Adders

|                |                | m <sub>3</sub>                | m <sub>2</sub>                | m <sub>1</sub>                | m <sub>0</sub>                | Multiplicand (M) |                |
|----------------|----------------|-------------------------------|-------------------------------|-------------------------------|-------------------------------|------------------|----------------|
|                | x              | q <sub>3</sub>                | q <sub>2</sub>                | q <sub>1</sub>                | q <sub>0</sub>                | Multiplier (Q)   |                |
|                |                | m <sub>3</sub> q <sub>0</sub> | m <sub>2</sub> q <sub>0</sub> | m <sub>1</sub> q <sub>0</sub> | m <sub>0</sub> q <sub>0</sub> |                  |                |
|                |                | m <sub>3</sub> q <sub>1</sub> | m <sub>2</sub> q <sub>1</sub> | m <sub>1</sub> q <sub>1</sub> | m <sub>0</sub> q <sub>1</sub> |                  |                |
|                |                | m <sub>3</sub> q <sub>2</sub> | m <sub>2</sub> q <sub>2</sub> | m <sub>1</sub> q <sub>2</sub> | m <sub>0</sub> q <sub>2</sub> |                  |                |
|                |                | m <sub>3</sub> q <sub>3</sub> | m <sub>2</sub> q <sub>3</sub> | m <sub>1</sub> q <sub>3</sub> | m <sub>0</sub> q <sub>3</sub> |                  |                |
| P <sub>7</sub> | P <sub>6</sub> | P <sub>5</sub>                | P <sub>4</sub>                | P <sub>3</sub>                | P <sub>2</sub>                | P <sub>1</sub>   | P <sub>0</sub> |

$$S = X_i \oplus Y_i \oplus C_i$$

$$C_{i+1} = X_i Y_i + X_i C_i + Y_i C_i$$



Full Adder Implementation

# Array Multiplication of Unsigned Numbers using Full Adders

|       | $m_3$    | $m_2$    | $m_1$    | $m_0$    | Multiplicand (M) |
|-------|----------|----------|----------|----------|------------------|
| $x$   | $q_3$    | $q_2$    | $q_1$    | $q_0$    | Multiplier (Q)   |
|       | $m_3q_0$ | $m_2q_0$ | $m_1q_0$ | $m_0q_0$ |                  |
|       | $m_3q_1$ | $m_2q_1$ | $m_1q_1$ | $m_0q_1$ |                  |
|       | $m_3q_2$ | $m_2q_2$ | $m_1q_2$ | $m_0q_2$ |                  |
|       | $m_3q_3$ | $m_2q_3$ | $m_1q_3$ | $m_0q_3$ |                  |
| $p_7$ | $p_6$    | $p_5$    | $p_4$    | $p_3$    | $p_2$            |
|       |          |          |          | $p_1$    | $p_0$            |



# Array Multiplication of Unsigned Numbers using Full Adders



Number of full Adders required is  $(n-1)n$ . Hence we can use sequential Multiplication which uses one n-bit adder

# Performance of Array Multiplication using Full Adders



# Performance of Array Multiplication using Full Adders



Total no of gate delays

$$= 1 + (2+2)(n-2) + 2n$$

↑  
initial AND gate delays  
↑  
no of gate delays from level  $i$  to level  $(i+1)$

$$= 1 + 4(n-2) + 2n$$
$$= 1 + 4n - 8 + 2n$$
$$= 6n - 7$$
$$= 6(n-1) - 1$$

↓  
last level Ripple carry Adder

# Performance of Array Multiplication using Full Adders



The worst-case signal propagation delay path is from the upper right corner of the array to the high-order product bit output at the bottom left corner of the array. This critical path consists of the staircase pattern that includes the two cells at the right end of each row, followed by all the cells in the bottom row. Assuming that there are two gate delays from the inputs to the outputs of a full-adder block, FA, the critical path has a total of  $6(n - 1) - 1$  gate delays, including the initial AND gate delay in all cells, for an  $n \times n$  array.

$$\begin{aligned} \text{Total no of gate delays} &= 1 + (2+2)(n-2) + 2n \\ &\quad \uparrow \qquad \uparrow \qquad \uparrow \\ &\quad \text{initial AND gate delay} \qquad \text{no of gate delays from level } i \text{ to level } (i+1) \qquad \text{last level Ripple carry adder} \\ &= 1 + 4(n-2) + 2n \\ &= 1 + 4n - 8 + 2n \\ &= 6n - 7 \\ &= 6(n-1) - 1 \end{aligned}$$

# Performance of Array Multiplication using Full Adders

The worst case delay path is shown in the following figure:



Each of the two FA blocks in rows 2 through  $n - 1$  introduces 2 gate delays, for a total of  $4(n - 2)$  gate delays. Row  $n$  introduces  $2n$  gate delays. Adding in the initial AND gate delay for row 1 and all other cells, total delay is:

$$4(n - 2) + 2n + 1 = 6n - 8 + 1 = 6(n - 1) - 1$$

# Multiplication of Unsigned Numbers: Sequential Multiplication

---

## Sequential Multiplication

- This is an Add Shift method
- Using One n-bit Adder

# Multiplication of Unsigned Numbers: Sequential Multiplication

Hardware Structure of Add-Shift Method of Multiplication



$$\begin{array}{r} & 1 & 0 & 1 & 1 & (11) \\ \times & 1 & 1 & 0 & 1 & (13) \\ \hline & 1 & 0 & 1 & 1 & \\ & 0 & 0 & 0 & 0 & \\ & 1 & 0 & 1 & 1 & \\ \hline & 1 & 0 & 0 & 1 & 1 & 1 & 1 \end{array}$$

# Sequential Circuit Multiplier



## Sequential Multiplication or Add-Shift Method of Multiplication

---

If  $q_0 = 1$  then {

Add  $A=A+M$

Shift Right 1-bit  $C \rightarrow A \rightarrow Q$

}

Else {

No Add

Shift Right 1-bit  $C \rightarrow A \rightarrow Q$

}

# Sequential or Add-Shift method of Multiplication

| Multiplicand (M) (11) |              |   |   |   | Multiplier (Q) (13) |   |   |   |       |  |
|-----------------------|--------------|---|---|---|---------------------|---|---|---|-------|--|
| C                     | Register (A) |   |   |   | Multiplier (Q) (13) |   |   |   | $q_0$ |  |
| 0                     | 0            | 0 | 0 | 0 | 1                   | 1 | 0 | 1 |       |  |
| <hr/>                 |              |   |   |   |                     |   |   |   |       |  |
| <hr/>                 |              |   |   |   |                     |   |   |   |       |  |
| <hr/>                 |              |   |   |   |                     |   |   |   |       |  |
| <hr/>                 |              |   |   |   |                     |   |   |   |       |  |
| <hr/>                 |              |   |   |   |                     |   |   |   |       |  |
| <hr/>                 |              |   |   |   |                     |   |   |   |       |  |
| <hr/>                 |              |   |   |   |                     |   |   |   |       |  |
| <hr/>                 |              |   |   |   |                     |   |   |   |       |  |
| <hr/>                 |              |   |   |   |                     |   |   |   |       |  |
| <hr/>                 |              |   |   |   |                     |   |   |   |       |  |

# Sequential or Add-Shift method of Multiplication

| Multiplicand (M) (11) |              |   |   |   | Multiplier (Q) (13) |   |   |   |
|-----------------------|--------------|---|---|---|---------------------|---|---|---|
| C                     | Register (A) |   |   |   |                     |   |   |   |
| 0                     | 0            | 0 | 0 | 0 | 1                   | 1 | 0 | 1 |
|                       |              |   |   |   | $q_0$               |   |   |   |

Initial Configuration

If  $q_0 = 1$  then Add M and A

# Sequential or Add-Shift method of Multiplication

| Multiplicand (M) (11) |              |   |   |   | Multiplier (Q) (13) |   |   |   |                               |
|-----------------------|--------------|---|---|---|---------------------|---|---|---|-------------------------------|
| C                     | Register (A) |   |   |   | Multiplier (Q)      |   |   |   | q <sub>0</sub>                |
| 0                     | 0            | 0 | 0 | 0 | 1                   | 1 | 0 | 1 |                               |
| 0                     | 1            | 0 | 1 | 1 | 1                   | 1 | 0 | 1 | Add A=A+M ∵ q <sub>0</sub> =1 |

# Sequential or Add-Shift method of Multiplication

| Multiplicand (M) (11) |              |   |   |   |                     |   |   |   |                                             |
|-----------------------|--------------|---|---|---|---------------------|---|---|---|---------------------------------------------|
| C                     | Register (A) |   |   |   | Multiplier (Q) (13) |   |   |   |                                             |
| 0                     | 0            | 0 | 0 | 0 | 1                   | 1 | 0 | 1 | $q_0$                                       |
| 0                     | 1            | 0 | 1 | 1 | 1                   | 1 | 0 | 1 | Add $A=A+M \because q_0=1$                  |
| 0                     | 0            | 1 | 0 | 1 | 1                   | 1 | 1 | 0 | Shift Right $C \rightarrow A \rightarrow Q$ |

# Sequential or Add-Shift method of Multiplication

| Multiplicand (M) (11) |              |   |   |   |                     |   |   |   |                                             |
|-----------------------|--------------|---|---|---|---------------------|---|---|---|---------------------------------------------|
| C                     | Register (A) |   |   |   | Multiplier (Q) (13) |   |   |   |                                             |
| 0                     | 0            | 0 | 0 | 0 | 1                   | 1 | 0 | 1 |                                             |
| 0                     | 1            | 0 | 1 | 1 | 1                   | 1 | 0 | 1 | Add $A=A+M \because q_0=1$                  |
| 0                     | 0            | 1 | 0 | 1 | 1                   | 1 | 1 | 0 | Shift Right $C \rightarrow A \rightarrow Q$ |
| 0                     | 0            | 1 | 0 | 1 | 1                   | 1 | 1 | 0 | No Add , Because $q_0=0$                    |
| 0                     | 0            | 0 | 1 | 0 | 1                   | 1 | 1 | 1 | Shift                                       |
|                       |              |   |   |   |                     |   |   |   |                                             |
|                       |              |   |   |   |                     |   |   |   |                                             |
|                       |              |   |   |   |                     |   |   |   |                                             |

# Sequential or Add-Shift method of Multiplication

| Multiplicand (M) (11) |              |   |   |   |                     |   |   |   |                                             |
|-----------------------|--------------|---|---|---|---------------------|---|---|---|---------------------------------------------|
| C                     | Register (A) |   |   |   | Multiplier (Q) (13) |   |   |   |                                             |
| 0                     | 0            | 0 | 0 | 0 | 1                   | 1 | 0 | 1 |                                             |
| 0                     | 1            | 0 | 1 | 1 | 1                   | 1 | 0 | 1 | Add $A=A+M \because q_0=1$                  |
| 0                     | 0            | 1 | 0 | 1 | 1                   | 1 | 1 | 0 | Shift Right $C \rightarrow A \rightarrow Q$ |
| 0                     | 0            | 1 | 0 | 1 | 1                   | 1 | 1 | 0 | No Add , Because $q_0=0$                    |
| 0                     | 0            | 0 | 1 | 0 | 1                   | 1 | 1 | 1 | Shift                                       |
| 0                     | 1            | 1 | 0 | 1 | 1                   | 1 | 1 | 1 | Add $A=A+M \because q_0=1$                  |
| 0                     | 0            | 1 | 1 | 0 | 1                   | 1 | 1 | 1 | Shift Right $C \rightarrow A \rightarrow Q$ |

# Sequential or Add-Shift method of Multiplication

| Multiplicand (M) (11) |              |   |   |   | Multiplier (Q) (13) |   |   |   |       | Initial Configuration                       |
|-----------------------|--------------|---|---|---|---------------------|---|---|---|-------|---------------------------------------------|
| C                     | Register (A) |   |   |   | Multiplier (Q)      |   |   |   |       |                                             |
| 0                     | 0            | 0 | 0 | 0 | 1                   | 1 | 0 | 1 | $q_0$ | If $q_0 = 1$ then Add M and A               |
| 0                     | 1            | 0 | 1 | 1 | 1                   | 1 | 0 | 1 |       | Add $A = A + M \because q_0 = 1$            |
| 0                     | 0            | 1 | 0 | 1 | 1                   | 1 | 1 | 0 |       | Shift Right $C \rightarrow A \rightarrow Q$ |
| 0                     | 0            | 1 | 0 | 1 | 1                   | 1 | 1 | 0 |       | No Add , Because $q_0=0$                    |
| 0                     | 0            | 0 | 1 | 0 | 1                   | 1 | 1 | 1 |       | Shift                                       |
| 0                     | 1            | 1 | 0 | 1 | 1                   | 1 | 1 | 1 |       | Add $A = A + M \because q_0 = 1$            |
| 0                     | 0            | 1 | 1 | 0 | 1                   | 1 | 1 | 1 | 1     | Shift Right $C \rightarrow A \rightarrow Q$ |
| 1                     | 0            | 0 | 0 | 1 | 1                   | 1 | 1 | 1 |       | Add $A = A + M \because q_0 = 1$            |
| 0                     | 1            | 0 | 0 | 0 | 1                   | 1 | 1 | 1 |       | Shift Right $C \rightarrow A \rightarrow Q$ |

**Product**

# Sequential Multiplication : Add-Shift Method of Multiplication



# Sequential or Add-Shift method of Multiplication

| Initial Configuration     |                   |                                                              |
|---------------------------|-------------------|--------------------------------------------------------------|
| Multiplicand ( $M$ ) (14) | 1 1 1 0           |                                                              |
| Register ( $A$ )          | 0 0 0 0           |                                                              |
| Multiplier ( $a$ ) (10)   | 1 0 1 0           |                                                              |
| c                         | 0                 |                                                              |
| 1st cycle                 | 0 0 0 0           | 1 0 1 0 No Add : $q_0=0$<br>Shift                            |
|                           | 0 0 0 0           | 0 1 0 1 Add : $q_0=1$<br>Shift                               |
| 2nd cycle                 | 0 1 1 0           | 0 1 0 1                                                      |
|                           | 0 1 1 1           | 0 0 1 0 No Add : $q_0=0$<br>Shift                            |
| 3rd cycle                 | 0 1 1 1           | 0 0 1 0                                                      |
|                           | 0 0 1 1           | 1 0 0 1 Add : $q_0=1$<br>Shift                               |
| 4th cycle                 | 0 0 0 1           | 1 0 0 1                                                      |
|                           | 1 0 0 0           | 1 1 0 0 Shift                                                |
| Product                   |                   |                                                              |
| 2^7                       | 1 0 0 0           | 1 1 0 0                                                      |
| 2^3 2^2                   |                   |                                                              |
|                           | 128 + 8 + 4 = 140 | $\begin{array}{r} 14 \\ \times 10 \\ \hline 140 \end{array}$ |

# Unit-4

---

## Signed Multiplication

# Signed Multiplication

First, consider the case of a positive multiplier and a negative multiplicand. When we add a negative multiplicand to a partial product, we must extend the sign-bit value of the multiplicand to the left as far as the product will extend. Figure shows an example in which a 5-bit signed operand,  $-13$ , is the multiplicand. It is multiplied by  $+11$  to get the 10-bit product,  $-143$ . The sign extension of the multiplicand is shown in blue. The hardware discussed earlier can be used for negative multiplicands if it is augmented to provide for sign extension of the partial products.

1 0 0 1 1 (- 13)  
0 1 0 1 1 (+11)

---

1 1 1 1 1 1 0 0 1 1  
1 1 1 1 1 0 0 1 1  
0 0 0 0 0 0 0 0  
1 1 1 0 0 1 1  
0 0 0 0 0 0

---

1 1 0 1 1 1 0 0 0 1 (- 143)

Sign extension is shown in blue

Sign extension of negative multiplicand.

# Signed Operands Multiplication: Different cases

## Case-1

+ve Multiplicand  
+ve Multiplier

$$\begin{array}{r} +2 \\ \times +1 \\ \hline +2 \end{array}$$

$$\begin{array}{r} 0 & 1 & 0 & +2 \\ \times 0 & 0 & 1 & +1 \\ \hline 0 & 1 & 0 \\ 0 & 0 & 0 \\ \hline 0 & 0 & 0 \\ \hline 0 & 0 & 0 & 1 & 0 & +2 \end{array}$$

# Signed Operands Multiplication: Different cases

| Case-1                                                                                                                                                                                                                                                                                | Case-2                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| <p>+ve Multiplicand<br/>+ve Multiplier</p> $  \begin{array}{r}  +2 \\  \times +1 \\  \hline  +2  \end{array}  $<br>$  \begin{array}{r}  0 & 1 & 0 & +2 \\  \times 0 & 0 & 1 & +1 \\  \hline  0 & 1 & 0 \\  0 & 0 & 0 \\  0 & 0 & 0 \\  \hline  0 & 0 & 0 & 1 & 0 & +2  \end{array}  $ | <p>-ve Multiplicand<br/>+ve Multiplier</p> $  \begin{array}{r}  -2 \\  \times +1 \\  \hline  -2  \end{array}  $ <p>2's complement of +2</p> $  \begin{array}{r}  +2 & 010 \\  101 \\  \hline  1  \end{array}  $<br>$  \begin{array}{r}  1 & 1 & 0 & -2 \\  \times 0 & 0 & 1 & +1 \\  \hline  1 & 1 & 1 & 1 & 0 \\  0 & 0 & 0 & 0 & 0 \\  0 & 0 & 0 & 0 & 0 \\  \hline  1 & 1 & 1 & 1 & 1 & 0 & -2  \end{array}  $ |  |  |
|                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |

# Signed Operands Multiplication: Different cases

| Case-1                                                                                                                                                                                                                                                                             | Case-2                                                                                                                                                                                                                                                                                                                                                                                        | Case-3                                                                                                                                                                                 |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <p>+ve Multiplicand<br/>+ve Multiplier</p> $  \begin{array}{r}  +2 \\  \times +1 \\  \hline  +2  \end{array}  $ $  \begin{array}{r}  0 & 1 & 0 & +2 \\  \times 0 & 0 & 1 & +1 \\  \hline  0 & 1 & 0 \\  0 & 0 & 0 \\  0 & 0 & 0 \\  \hline  0 & 0 & 0 & 1 & 0 & +2  \end{array}  $ | <p>-ve Multiplicand<br/>+ve Multiplier</p> $  \begin{array}{r}  -2 \\  \times +1 \\  \hline  -2  \end{array}  $ <p>2's complement of +2</p> $  \begin{array}{r}  +2 & 010 \\  101 \\  \hline  110  \end{array}  $ $  \begin{array}{r}  1 & 1 & 1 & 1 & 1 & 0 \\  \times 0 & 0 & 1 & +1 \\  \hline  0 & 0 & 0 & 0 & 0 \\  0 & 0 & 0 & 0 \\  \hline  1 & 1 & 1 & 1 & 1 & 0 & -2  \end{array}  $ | <p>+ve Mud<br/>-ve Mur</p> $  \begin{array}{r}  +2 \\  \times -1 \\  \hline  -2  \end{array}  $ <p>Use Case-2</p> $  \begin{array}{r}  -2 \\  \times +1 \\  \hline  -2  \end{array}  $ |
|                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                        |

# Signed Operands Multiplication: Different cases

| Case-1                                                                                                                                                                                                                                                                             | Case-2                                                                                                                                                                                                                                                                                                                                                                                              | Case-3                                                                                                                                    | Case-4                                                                                                                                 |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------|
| <p>+ve Multiplicand<br/>+ve Multiplier</p> $  \begin{array}{r}  +2 \\  \times +1 \\  \hline  +2  \end{array}  $ $  \begin{array}{r}  0 & 1 & 0 & +2 \\  \times 0 & 0 & 1 & +1 \\  \hline  0 & 1 & 0 \\  0 & 0 & 0 \\  0 & 0 & 0 \\  \hline  0 & 0 & 0 & 1 & 0 & +2  \end{array}  $ | <p>-ve Multiplicand<br/>+ve Multiplier</p> $  \begin{array}{r}  -2 \\  \times +1 \\  \hline  -2  \end{array}  $ <p>2's complement of +2</p> $  \begin{array}{r}  +2 & 010 \\  101 \\  1 \\  \hline  110  \end{array}  $ $  \begin{array}{r}  1 & 1 & 1 & 1 & 1 & 0 \\  \times 0 & 0 & 1 & +1 \\  \hline  0 & 0 & 0 & 0 & 0 \\  0 & 0 & 0 & 0 \\  \hline  1 & 1 & 1 & 1 & 1 & 0 & -2  \end{array}  $ | $  \begin{array}{r}  +2 \\  \times -1 \\  \hline  -2  \end{array}  $ $  \begin{array}{r}  -2 \\  \times +1 \\  \hline  -2  \end{array}  $ | $  \begin{array}{r}  -2 \\  \times -1 \\  \hline  -2  \end{array}  $ $  \begin{array}{r}  2 \\  \times 1 \\  \hline  2  \end{array}  $ |
|                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                     | <p>Use Case-2</p> $  \begin{array}{r}  -2 \\  \times +1 \\  \hline  -2  \end{array}  $                                                    | <p>Use Case-1</p> $  \begin{array}{r}  2 \\  \times 1 \\  \hline  2  \end{array}  $                                                    |
|                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                           |                                                                                                                                        |

## Booths Algorithm for Signed Operand Multiplication

---

1. It reduces the number of additions
2. Negative Multiplier and Positive multiplier are treated as same

# Booth Multiplier Recoding Table

Booth Multiplier Recoding Table

| Multiplier |            |    |
|------------|------------|----|
| Bit<br>i   | Bit<br>i-1 |    |
| 0          | 0          | 0  |
| 0          | 1          | +1 |
| 1          | 0          | -1 |
| 1          | 1          | 0  |

Example of  
Booth Multiplier Recording



# Booths Algorithm: Example

Booth Multiplier Recoding Table

| Multiplier |         |    |
|------------|---------|----|
| Bit i      | Bit i-1 |    |
| 0          | 0       | 0  |
| 0          | 1       | +1 |
| 1          | 0       | -1 |
| 1          | 1       | 0  |

$$\begin{array}{r} +2 \\ \times +3 \\ \hline +6 \end{array}$$

| Multiplicand | 0 | 0 | 1 | 0 |
|--------------|---|---|---|---|
| Multiplier   | 0 | 0 | 1 | 1 |

# Booths Algorithm: Example

Booth Multiplier Recoding Table

| Multiplier |         |    |
|------------|---------|----|
| Bit i      | Bit i-1 |    |
| 0          | 0       | 0  |
| 0          | 1       | +1 |
| 1          | 0       | -1 |
| 1          | 1       | 0  |

|      |                          |   |    |   |    |                                         |
|------|--------------------------|---|----|---|----|-----------------------------------------|
| +2   | Multiplicand             | 0 | 0  | 1 | 0  |                                         |
| X +3 | Multiplier               | 0 | 0  | 1 | 1  | 0                                       |
| +6   | Booth Recoded Multiplier | 0 | +1 | 0 | -1 | <p>Add Implied zero to right of LSB</p> |

# Booths Algorithm: Example

Booth Multiplier Recoding Table

| Multiplier |         |    |
|------------|---------|----|
| Bit i      | Bit i-1 |    |
| 0          | 0       | 0  |
| 0          | 1       | +1 |
| 1          | 0       | -1 |
| 1          | 1       | 0  |

|                                                                         |                                             |                                                     |                                                           |                                                                    |                             |              |                                                                 |
|-------------------------------------------------------------------------|---------------------------------------------|-----------------------------------------------------|-----------------------------------------------------------|--------------------------------------------------------------------|-----------------------------|--------------|-----------------------------------------------------------------|
| $+2$<br>$\times +3$<br>$\hline$ $+6$                                    | Multiplicand<br>$0 \quad 0 \quad 1 \quad 0$ | Multiplier<br>$0 \quad 0 \quad 1 \quad 1$           | Booth Recoded Multiplier<br>$0 \quad +1 \quad 0 \quad -1$ | <span style="color: gray;">Add Implied zero to right of LSB</span> |                             |              |                                                                 |
|                                                                         |                                             |                                                     |                                                           | <span style="color: gray;">2's Complement Of Multipliand</span>    |                             |              |                                                                 |
| 2's Complement of +2<br>$+2 \ 0010$<br>$1101$<br>$1$<br>$\hline$ $1110$ | Multiplicand<br>$0 \quad 0 \quad 1 \quad 0$ | Recoded Multiplier<br>$0 \quad +1 \quad 0 \quad -1$ | $\hline$                                                  | <span style="color: gray;">2's Complement Of Multipliand</span>    |                             |              |                                                                 |
|                                                                         |                                             |                                                     |                                                           | $1 \quad 1 \quad 1 \quad 1$                                        | $1 \quad 1 \quad 1 \quad 0$ | $\leftarrow$ | <span style="color: gray;">2's Complement Of Multipliand</span> |

# Booths Algorithm: Example

Booth Multiplier Recoding Table

| Multiplier |         |    |
|------------|---------|----|
| Bit i      | Bit i-1 |    |
| 0          | 0       | 0  |
| 0          | 1       | +1 |
| 1          | 0       | -1 |
| 1          | 1       | 0  |

|                                                            |                                                       |                                                 |                                                                    |
|------------------------------------------------------------|-------------------------------------------------------|-------------------------------------------------|--------------------------------------------------------------------|
| $+2$<br>$\times +3$<br>$\hline$ $+6$                       | <b>Multiplicand</b><br>0    0    1    0               | <b>Multiplier</b><br>0    0    1    1    0      | <span style="color: gray;">Add Implied zero to right of LSB</span> |
|                                                            | <b>Booth Recoded Multiplier</b><br>0    +1    0    -1 |                                                 |                                                                    |
|                                                            | <b>Multiplicand</b><br>0    0    1    0               | <b>Recoded Multiplier</b><br>0    +1    0    -1 |                                                                    |
|                                                            |                                                       | $\hline$                                        |                                                                    |
| 2's Complement of +2<br>+2 0010<br>1101<br>1<br>----- 1110 | 1    1    1    1    1    1    1    0                  | 0    0    0    0    0    0    0    0            | <span style="color: gray;">2's Complement Of Multiplicand</span>   |

# Booths Algorithm: Example

Booth Multiplier Recoding Table

| Multiplier |         |    |
|------------|---------|----|
| Bit i      | Bit i-1 |    |
| 0          | 0       | 0  |
| 0          | 1       | +1 |
| 1          | 0       | -1 |
| 1          | 1       | 0  |

|                                                            |                                                       |                                                                              |                                                                    |
|------------------------------------------------------------|-------------------------------------------------------|------------------------------------------------------------------------------|--------------------------------------------------------------------|
| $+2$<br>$\times +3$<br>$\hline$ $+6$                       | <b>Multiplicand</b><br>0    0    1    0               | <b>Multiplier</b><br>0    0    1    1    0                                   | <span style="color: gray;">Add Implied zero to right of LSB</span> |
|                                                            | <b>Booth Recoded Multiplier</b><br>0    +1    0    -1 |                                                                              |                                                                    |
|                                                            | <b>Multiplicand</b><br>0    0    1    0               |                                                                              |                                                                    |
|                                                            | <b>Recoded Multiplier</b><br>0    +1    0    -1       |                                                                              |                                                                    |
|                                                            |                                                       | $2^{\text{'s}}$<br><b>Complement Of Multipliand</b><br>0    1    1    1    0 |                                                                    |
| 2's Complement of +2<br>+2 0010<br>1101<br>1<br>----- 1110 | 0    0    0    0    0    0    0                       | 0    +1    0    -1                                                           |                                                                    |
|                                                            | 0    0    0    0    1    0                            |                                                                              |                                                                    |

# Booths Algorithm: Example

Booth Multiplier Recoding Table

| Multiplier |         |    |
|------------|---------|----|
| Bit i      | Bit i-1 |    |
| 0          | 0       | 0  |
| 0          | 1       | +1 |
| 1          | 0       | -1 |
| 1          | 1       | 0  |

|                      |             |                          |   |    |   |    |                                      |
|----------------------|-------------|--------------------------|---|----|---|----|--------------------------------------|
|                      | +2          | Multiplicand             | 0 | 0  | 1 | 0  | 0 ← Add Implied zero to right of LSB |
|                      | $\times +3$ | Multiplier               | 0 | 0  | 1 | 1  |                                      |
|                      | +6          | Booth Recoded Multiplier | 0 | +1 | 0 | -1 |                                      |
|                      |             | Multiplicand             | 0 | 0  | 1 | 0  |                                      |
|                      |             | Recoded Multiplier       | 0 | +1 | 0 | -1 |                                      |
| 2's Complement of +2 | 1 1 1 1     |                          | 1 | 1  | 1 | 0  | 2's Complement Of Multiplier         |
| +2 0010              | 0 0 0 0     |                          | 0 | 0  | 0 | 0  |                                      |
| 1101                 |             |                          |   |    |   |    |                                      |
| 1                    | 0 0 0 0     |                          | 0 | 1  | 0 |    |                                      |
| -----                |             |                          |   |    |   |    |                                      |
| 1110                 | 0 0 0 0     |                          | 0 | 0  | 0 |    |                                      |
|                      |             |                          |   |    |   |    |                                      |
|                      |             |                          | 0 | 0  | 1 | 1  | +6                                   |

# Booths Algorithm: Example

---

Booth Multiplier Recoding Table

| Multiplier |         |    |
|------------|---------|----|
| Bit i      | Bit i-1 |    |
| 0          | 0       | 0  |
| 0          | 1       | +1 |
| 1          | 0       | -1 |
| 1          | 1       | 0  |

$$\begin{array}{r} -2 \\ \times +3 \\ \hline -6 \end{array}$$

| Multiplicand | 1 | 1 | 1 | 0 |
|--------------|---|---|---|---|
| Multiplier   | 0 | 0 | 1 | 1 |
|              |   |   |   |   |

# Booths Algorithm: Example

Booth Multiplier Recoding Table

| Multiplier |         |    |
|------------|---------|----|
| Bit i      | Bit i-1 |    |
| 0          | 0       | 0  |
| 0          | 1       | +1 |
| 1          | 0       | -1 |
| 1          | 1       | 0  |

2's Complement of +2

$$+2 \quad 0010$$

$$1101$$

1

-----

$$1110$$

2's Complement of +6

$$+6 \quad 0110$$

$$1001$$

1

-----

$$1010$$

|                                                             |                                                                                                                                                                           |              |   |    |   |   |            |    |   |   |   |                                                                                                                   |                          |   |    |   |    |                                                                                                                                                                                     |              |   |   |   |   |                    |   |    |   |    |                                                                                                                        |   |   |   |   |   |   |   |   |                                                                                                                        |   |   |   |   |   |   |   |   |                                                                                                                        |   |   |   |   |   |   |   |   |                                                                                                                        |   |   |   |   |   |   |   |   |
|-------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|---|----|---|---|------------|----|---|---|---|-------------------------------------------------------------------------------------------------------------------|--------------------------|---|----|---|----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|---|---|---|---|--------------------|---|----|---|----|------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|---|---|---|------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|---|---|---|------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|---|---|---|------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|---|---|---|
| $\begin{array}{r} -2 \\ \times +3 \\ \hline -6 \end{array}$ | <table border="0"> <tr> <td>Multiplicand</td><td>1</td><td>1</td><td>1</td><td>0</td></tr> <tr> <td>Multiplier</td><td>0</td><td>0</td><td>1</td><td>1</td></tr> </table> | Multiplicand | 1 | 1  | 1 | 0 | Multiplier | 0  | 0 | 1 | 1 | <table border="0"> <tr> <td>Booth Recoded Multiplier</td><td>0</td><td>+1</td><td>0</td><td>-1</td></tr> </table> | Booth Recoded Multiplier | 0 | +1 | 0 | -1 | <table border="0"> <tr> <td>Multiplicand</td><td>1</td><td>1</td><td>1</td><td>0</td></tr> <tr> <td>Recoded Multiplier</td><td>0</td><td>+1</td><td>0</td><td>-1</td></tr> </table> | Multiplicand | 1 | 1 | 1 | 0 | Recoded Multiplier | 0 | +1 | 0 | -1 | <table border="0"> <tr> <td>0</td><td>0</td><td>0</td><td>0</td><td>0</td><td>0</td><td>1</td><td>0</td></tr> </table> | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | <table border="0"> <tr> <td>0</td><td>0</td><td>0</td><td>0</td><td>0</td><td>0</td><td>0</td><td>0</td></tr> </table> | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | <table border="0"> <tr> <td>1</td><td>1</td><td>1</td><td>1</td><td>1</td><td>0</td><td>1</td><td>0</td></tr> </table> | 1 | 1 | 1 | 1 | 1 | 0 | 1 | 0 | <table border="0"> <tr> <td>1</td><td>1</td><td>1</td><td>1</td><td>0</td><td>1</td><td>1</td><td>0</td></tr> </table> | 1 | 1 | 1 | 1 | 0 | 1 | 1 | 0 |
| Multiplicand                                                | 1                                                                                                                                                                         | 1            | 1 | 0  |   |   |            |    |   |   |   |                                                                                                                   |                          |   |    |   |    |                                                                                                                                                                                     |              |   |   |   |   |                    |   |    |   |    |                                                                                                                        |   |   |   |   |   |   |   |   |                                                                                                                        |   |   |   |   |   |   |   |   |                                                                                                                        |   |   |   |   |   |   |   |   |                                                                                                                        |   |   |   |   |   |   |   |   |
| Multiplier                                                  | 0                                                                                                                                                                         | 0            | 1 | 1  |   |   |            |    |   |   |   |                                                                                                                   |                          |   |    |   |    |                                                                                                                                                                                     |              |   |   |   |   |                    |   |    |   |    |                                                                                                                        |   |   |   |   |   |   |   |   |                                                                                                                        |   |   |   |   |   |   |   |   |                                                                                                                        |   |   |   |   |   |   |   |   |                                                                                                                        |   |   |   |   |   |   |   |   |
| Booth Recoded Multiplier                                    | 0                                                                                                                                                                         | +1           | 0 | -1 |   |   |            |    |   |   |   |                                                                                                                   |                          |   |    |   |    |                                                                                                                                                                                     |              |   |   |   |   |                    |   |    |   |    |                                                                                                                        |   |   |   |   |   |   |   |   |                                                                                                                        |   |   |   |   |   |   |   |   |                                                                                                                        |   |   |   |   |   |   |   |   |                                                                                                                        |   |   |   |   |   |   |   |   |
| Multiplicand                                                | 1                                                                                                                                                                         | 1            | 1 | 0  |   |   |            |    |   |   |   |                                                                                                                   |                          |   |    |   |    |                                                                                                                                                                                     |              |   |   |   |   |                    |   |    |   |    |                                                                                                                        |   |   |   |   |   |   |   |   |                                                                                                                        |   |   |   |   |   |   |   |   |                                                                                                                        |   |   |   |   |   |   |   |   |                                                                                                                        |   |   |   |   |   |   |   |   |
| Recoded Multiplier                                          | 0                                                                                                                                                                         | +1           | 0 | -1 |   |   |            |    |   |   |   |                                                                                                                   |                          |   |    |   |    |                                                                                                                                                                                     |              |   |   |   |   |                    |   |    |   |    |                                                                                                                        |   |   |   |   |   |   |   |   |                                                                                                                        |   |   |   |   |   |   |   |   |                                                                                                                        |   |   |   |   |   |   |   |   |                                                                                                                        |   |   |   |   |   |   |   |   |
| 0                                                           | 0                                                                                                                                                                         | 0            | 0 | 0  | 0 | 1 | 0          |    |   |   |   |                                                                                                                   |                          |   |    |   |    |                                                                                                                                                                                     |              |   |   |   |   |                    |   |    |   |    |                                                                                                                        |   |   |   |   |   |   |   |   |                                                                                                                        |   |   |   |   |   |   |   |   |                                                                                                                        |   |   |   |   |   |   |   |   |                                                                                                                        |   |   |   |   |   |   |   |   |
| 0                                                           | 0                                                                                                                                                                         | 0            | 0 | 0  | 0 | 0 | 0          |    |   |   |   |                                                                                                                   |                          |   |    |   |    |                                                                                                                                                                                     |              |   |   |   |   |                    |   |    |   |    |                                                                                                                        |   |   |   |   |   |   |   |   |                                                                                                                        |   |   |   |   |   |   |   |   |                                                                                                                        |   |   |   |   |   |   |   |   |                                                                                                                        |   |   |   |   |   |   |   |   |
| 1                                                           | 1                                                                                                                                                                         | 1            | 1 | 1  | 0 | 1 | 0          |    |   |   |   |                                                                                                                   |                          |   |    |   |    |                                                                                                                                                                                     |              |   |   |   |   |                    |   |    |   |    |                                                                                                                        |   |   |   |   |   |   |   |   |                                                                                                                        |   |   |   |   |   |   |   |   |                                                                                                                        |   |   |   |   |   |   |   |   |                                                                                                                        |   |   |   |   |   |   |   |   |
| 1                                                           | 1                                                                                                                                                                         | 1            | 1 | 0  | 1 | 1 | 0          |    |   |   |   |                                                                                                                   |                          |   |    |   |    |                                                                                                                                                                                     |              |   |   |   |   |                    |   |    |   |    |                                                                                                                        |   |   |   |   |   |   |   |   |                                                                                                                        |   |   |   |   |   |   |   |   |                                                                                                                        |   |   |   |   |   |   |   |   |                                                                                                                        |   |   |   |   |   |   |   |   |
|                                                             |                                                                                                                                                                           |              |   |    |   |   |            | -6 |   |   |   |                                                                                                                   |                          |   |    |   |    |                                                                                                                                                                                     |              |   |   |   |   |                    |   |    |   |    |                                                                                                                        |   |   |   |   |   |   |   |   |                                                                                                                        |   |   |   |   |   |   |   |   |                                                                                                                        |   |   |   |   |   |   |   |   |                                                                                                                        |   |   |   |   |   |   |   |   |
|                                                             |                                                                                                                                                                           |              |   |    |   |   |            |    |   |   |   |                                                                                                                   |                          |   |    |   |    |                                                                                                                                                                                     |              |   |   |   |   |                    |   |    |   |    |                                                                                                                        |   |   |   |   |   |   |   |   |                                                                                                                        |   |   |   |   |   |   |   |   |                                                                                                                        |   |   |   |   |   |   |   |   |                                                                                                                        |   |   |   |   |   |   |   |   |
|                                                             |                                                                                                                                                                           |              |   |    |   |   |            |    |   |   |   |                                                                                                                   |                          |   |    |   |    |                                                                                                                                                                                     |              |   |   |   |   |                    |   |    |   |    |                                                                                                                        |   |   |   |   |   |   |   |   |                                                                                                                        |   |   |   |   |   |   |   |   |                                                                                                                        |   |   |   |   |   |   |   |   |                                                                                                                        |   |   |   |   |   |   |   |   |

Add Implied zero to right of LSB

2's Complement Of Multiplier

# Booths Algorithm: Example

Booth Multiplier Recoding Table

| Multiplier |         |    |
|------------|---------|----|
| Bit i      | Bit i-1 |    |
| 0          | 0       | 0  |
| 0          | 1       | +1 |
| 1          | 0       | -1 |
| 1          | 1       | 0  |

|                                                            |                                         |                                                  |                                                        |                                                                         |
|------------------------------------------------------------|-----------------------------------------|--------------------------------------------------|--------------------------------------------------------|-------------------------------------------------------------------------|
| $+2$<br>$\times -3$<br><hr/> $-6$                          | <b>Multiplicand</b><br>0    0    1    0 | <b>Multiplier</b><br>1    1    0    1            | <b>Booth Recoded Multiplier</b><br>0    -1    +1    -1 | <span style="font-size: small;">Add Implied zero to right of LSB</span> |
|                                                            | <b>Multiplicand</b><br>0    0    1    0 | <b>Recoded Multiplier</b><br>0    -1    +1    -1 | <hr/> 0    1    1    1    0                            | <span style="font-size: small;">2's Complement Of Multiplier</span>     |
| 2's Complement of +3<br>+3 0011<br>1100<br>1<br>----- 1101 | 0    0    0    0    0                   | 1    1    1    1    0                            | 1    1    1    0                                       | <span style="font-size: small;">2's Complement Of Multiplicand</span>   |
| 2's Complement of +6<br>+6 0110<br>1001<br>1<br>----- 1010 | 0    0    0    0    0                   | 1    1    1    1    0                            | 1    1    1    0                                       | <span style="font-size: small;">-----</span>                            |
|                                                            | 1    1    1    1    1    0    1    0    |                                                  | -----<br>-6                                            |                                                                         |

# Booths Algorithm: Example

Booth Multiplier Recoding Table

| Multiplier |         |    |
|------------|---------|----|
| Bit i      | Bit i-1 |    |
| 0          | 0       | 0  |
| 0          | 1       | +1 |
| 1          | 0       | -1 |
| 1          | 1       | 0  |

| $\begin{array}{r} -2 \\ \times -3 \\ \hline +6 \end{array}$ | <table style="width: 100%; border-collapse: collapse;"> <thead> <tr> <th style="text-align: center;">Multiplicand</th><th style="text-align: center;">1</th><th style="text-align: center;">1</th><th style="text-align: center;">1</th><th style="text-align: center;">0</th><th style="text-align: right; vertical-align: bottom;">0 ←</th></tr> </thead> <tbody> <tr> <td style="text-align: center;">Multiplier</td><td style="text-align: center;">1</td><td style="text-align: center;">1</td><td style="text-align: center;">0</td><td style="text-align: center;">1</td><td style="text-align: right; vertical-align: bottom;">Add Implied zero to right of LSB</td></tr> <tr> <td style="text-align: center;">Booth Recoded Multiplier</td><td style="text-align: center;">0</td><td style="text-align: center;">-1</td><td style="text-align: center;">+1</td><td style="text-align: center;">-1</td><td></td></tr> </tbody> </table><br><table style="width: 100%; border-collapse: collapse;"> <thead> <tr> <th style="text-align: center;">Multiplicand</th><th style="text-align: center;">1</th><th style="text-align: center;">1</th><th style="text-align: center;">1</th><th style="text-align: center;">0</th><th style="text-align: right; vertical-align: bottom;">0 ←</th></tr> </thead> <tbody> <tr> <td style="text-align: center;">Recoded Multiplier</td><td style="text-align: center;">0</td><td style="text-align: center;">-1</td><td style="text-align: center;">+1</td><td style="text-align: center;">-1</td><td style="text-align: right; vertical-align: bottom;">2's Complement Of Multiplier</td></tr> <tr> <td style="text-align: center;">0 0 0 0 0 0 1 0</td><td style="text-align: center;">0</td><td style="text-align: center;">0</td><td style="text-align: center;">0</td><td style="text-align: center;">1</td><td style="text-align: center;">0</td></tr> <tr> <td style="text-align: center;">1 1 1 0</td><td style="text-align: center;">1</td><td style="text-align: center;">1</td><td style="text-align: center;">1</td><td style="text-align: center;">0</td><td></td></tr> </tbody> </table><br>$\begin{array}{r} 2\text{'s Complement of } +2 \\ +2 \quad 0010 \\ 1101 \\ \hline 1 \end{array}$<br>$\begin{array}{r} 2\text{'s Complement of } +3 \\ +3 \quad 0011 \\ 1100 \\ \hline 1 \end{array}$<br>$\begin{array}{r} 1101 \\ \hline \end{array}$ | Multiplicand | 1  | 1  | 1                                | 0 | 0 ← | Multiplier | 1 | 1 | 0 | 1 | Add Implied zero to right of LSB | Booth Recoded Multiplier | 0 | -1 | +1 | -1 |  | Multiplicand | 1 | 1 | 1 | 0 | 0 ← | Recoded Multiplier | 0 | -1 | +1 | -1 | 2's Complement Of Multiplier | 0 0 0 0 0 0 1 0 | 0 | 0 | 0 | 1 | 0 | 1 1 1 0 | 1 | 1 | 1 | 0 |  |
|-------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|----|----|----------------------------------|---|-----|------------|---|---|---|---|----------------------------------|--------------------------|---|----|----|----|--|--------------|---|---|---|---|-----|--------------------|---|----|----|----|------------------------------|-----------------|---|---|---|---|---|---------|---|---|---|---|--|
| Multiplicand                                                | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 1            | 1  | 0  | 0 ←                              |   |     |            |   |   |   |   |                                  |                          |   |    |    |    |  |              |   |   |   |   |     |                    |   |    |    |    |                              |                 |   |   |   |   |   |         |   |   |   |   |  |
| Multiplier                                                  | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 1            | 0  | 1  | Add Implied zero to right of LSB |   |     |            |   |   |   |   |                                  |                          |   |    |    |    |  |              |   |   |   |   |     |                    |   |    |    |    |                              |                 |   |   |   |   |   |         |   |   |   |   |  |
| Booth Recoded Multiplier                                    | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | -1           | +1 | -1 |                                  |   |     |            |   |   |   |   |                                  |                          |   |    |    |    |  |              |   |   |   |   |     |                    |   |    |    |    |                              |                 |   |   |   |   |   |         |   |   |   |   |  |
| Multiplicand                                                | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 1            | 1  | 0  | 0 ←                              |   |     |            |   |   |   |   |                                  |                          |   |    |    |    |  |              |   |   |   |   |     |                    |   |    |    |    |                              |                 |   |   |   |   |   |         |   |   |   |   |  |
| Recoded Multiplier                                          | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | -1           | +1 | -1 | 2's Complement Of Multiplier     |   |     |            |   |   |   |   |                                  |                          |   |    |    |    |  |              |   |   |   |   |     |                    |   |    |    |    |                              |                 |   |   |   |   |   |         |   |   |   |   |  |
| 0 0 0 0 0 0 1 0                                             | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 0            | 0  | 1  | 0                                |   |     |            |   |   |   |   |                                  |                          |   |    |    |    |  |              |   |   |   |   |     |                    |   |    |    |    |                              |                 |   |   |   |   |   |         |   |   |   |   |  |
| 1 1 1 0                                                     | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 1            | 1  | 0  |                                  |   |     |            |   |   |   |   |                                  |                          |   |    |    |    |  |              |   |   |   |   |     |                    |   |    |    |    |                              |                 |   |   |   |   |   |         |   |   |   |   |  |

# Question

---

Assuming 5-bit 2's-complement number representation, multiply the multiplicand  $A = +13$  by the multiplier  $B = -6$  using the normal Booth algorithm

Booth Multiplier Recoding Table

| Multiplier |            |    |
|------------|------------|----|
| Bit<br>i   | Bit<br>i-1 |    |
| 0          | 0          | 0  |
| 0          | 1          | +1 |
| 1          | 0          | -1 |
| 1          | 1          | 0  |

# Answer

$$\begin{array}{r} 0 \ 1 \ 1 \ 0 \ 1 \quad (+13) \\ \times 1 \ 1 \ 0 \ 1 \ 0 \quad (-6) \\ \hline \end{array} \quad \Rightarrow \quad \begin{array}{r} 0 \ 1 \ 1 \ 0 \ 1 \\ 0 -1 +1 -1 \ 0 \\ \hline 0 \ 0 \ 0 \ 0 \ 0 \quad 0 \ 0 \ 0 \ 0 \ 0 \\ 1 \ 1 \ 1 \ 1 \ 1 \quad 1 \ 0 \ 0 \ 1 \ 1 \\ 0 \ 0 \ 0 \ 0 \ 1 \quad 0 \ 1 \ 1 \ 0 \ 1 \\ 1 \ 1 \ 1 \ 0 \ 0 \quad 0 \ 1 \ 1 \\ 0 \ 0 \ 0 \ 0 \ 0 \quad 0 \ 0 \ 0 \ 0 \ 0 \\ \hline 1 \ 1 \ 1 \ 0 \ 1 \ 1 \ 1 \ 0 \ 0 \ 1 \ 0 \quad (-78) \end{array}$$

Booth multiplication with a negative multiplier.

Booth Multiplier Recoding Table

| Multiplier |            |    |
|------------|------------|----|
| Bit<br>i   | Bit<br>i-1 |    |
| 0          | 0          | 0  |
| 0          | 1          | +1 |
| 1          | 0          | -1 |
| 1          | 1          | 0  |

# Question

---

Multiply each of the following pairs of signed 2's-complement numbers using the Booth algorithm. In each case, assume that A is the multiplicand and B is the multiplier.

- (a) A = 010111 and B = 110110
- (b) A = 110011 and B = 101100
- (c) A = 001111 and B = 001111

# Answer

Multiply each of the following pairs of signed 2's-complement numbers using the Booth algorithm. In each case, assume that A is the multiplicand and B is the multiplier.

(a) A = 010111 and B = 110110

(b) A = 110011 and B = 101100

(c) A = 001111 and B = 001111

(a) 
$$\begin{array}{r} 010111 \\ \times 110110 \\ \hline -230 \end{array}$$

sign extension

$$\begin{array}{r} 0\ 1\ 0\ 1\ 1\ 1 \\ \times 0\ -1+1\ 0\ -1\ 0 \\ \hline 0 \\ \boxed{\begin{array}{cccccc} 1 & 1 & 1 & 1 & 1 & 1 \\ 0 & 0 & 0 & 0 & 1 & 0 \\ 1 & 1 & 1 & 1 & 0 & 2 \\ \hline 1 & 1 & 1 & 1 & 0 & 0 \end{array}} \\ 0 \\ \hline 1\ 1\ 1\ 1\ 0\ 0\ 0\ 1\ 1\ 0\ 1\ 0 \end{array}$$

(b) 
$$\begin{array}{r} 110011 \\ \times 101100 \\ \hline 260 \end{array}$$

sign extension

$$\begin{array}{r} 1\ 1\ 0\ 0\ 1\ 1 \\ \times -1+1\ 0\ -1\ 0\ 0 \\ \hline 0 \\ \boxed{\begin{array}{cccccc} 0 & 0 & 0 & 0 & 0 & 0 \\ 1 & 1 & 1 & 1 & 0 & 0 \\ 0 & 1 & 0 & 1 & 1 & 1 \\ \hline 0 & 0 & 0 & 1 & 0 & 0 \end{array}} \\ 0 \\ \hline 0\ 0\ 0\ 1\ 0\ 0\ 0\ 0\ 0\ 1\ 0\ 0 \end{array}$$

# Answer

Multiply each of the following pairs of signed 2's-complement numbers using the Booth algorithm. In each case, assume that A is the multiplicand and B is the multiplier.

- (a) A = 010111 and B = 110110
- (b) A = 110011 and B = 101100
- (c) A = 001111 and B = 001111

$$(c) \begin{array}{r} 110101 \\ \times 011011 \\ \hline -297 \end{array}$$

sign extension

$$\begin{array}{r} & & & & 1 & 1 & 0 & 1 & 0 & 1 \\ & & & & \times & +1 & 0 & -1 & +1 & 0 & -1 \\ & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 1 & 0 & 1 & 1 \\ & 1 & 1 & 1 & 1 & 1 & 1 & 1 & 0 & 1 & 0 & 1 \\ & 0 & 0 & 0 & 0 & 0 & 0 & 1 & 0 & 1 & 0 & 1 \\ & 1 & 1 & 1 & 1 & 1 & 1 & 0 & 1 & 1 & 0 & 1 \\ \hline & 1 & 1 & 1 & 0 & 1 & 1 & 0 & 1 & 0 & 1 & 1 \end{array}$$

$$(d) \begin{array}{r} 001111 \\ \times 001111 \\ \hline 225 \end{array}$$

$$\begin{array}{r} & & & & 0 & 0 & 1 & 1 & 1 & 1 \\ & & & & \times & 0 & +1 & 0 & 0 & 0 & -1 \\ & 1 & 1 & 1 & 1 & 1 & 1 & 1 & 1 & 0 & 0 & 1 \\ & 0 & 0 & 0 & 0 & 1 & 1 & 1 & 1 & 0 & 0 & 1 \\ \hline & 0 & 0 & 0 & 0 & 1 & 1 & 1 & 0 & 0 & 0 & 1 \end{array}$$

# Booth Algorithm

- Best case: a long string of 1's (skipping over 1s)
- Worst case: 0's and 1's are alternating



# Fast Multiplication

---

- Bit-Pair Recoding
- Carry-Save Addition
- Summand Addition tree using 3-2 Reducers

# Bit-Pair Recoding of Multipliers

| Multiplier Bit Pair |          | Multiplier Bit on the right<br><b>(i-1)</b> | Multiplicand selected at position <b>i</b> | Remarks                                                         |
|---------------------|----------|---------------------------------------------|--------------------------------------------|-----------------------------------------------------------------|
| <b>(i-1)</b>        | <b>i</b> |                                             |                                            |                                                                 |
| 0                   | 0        | 0                                           | <b>0</b>                                   | No Addition required only shift Partial Product (PP)            |
| 0                   | 0        | 1                                           | <b>+1</b>                                  | Add Multiplicand to PP                                          |
| 0                   | 1        | 0                                           | <b>+1</b>                                  | Add Multiplicand to PP                                          |
| 0                   | 1        | 1                                           | <b>+2</b>                                  | Add two times Multiplicand and then add to PP                   |
| 1                   | 0        | 0                                           | <b>-2</b>                                  | Add two times 2's complement of Multiplicand and then add to PP |
| 1                   | 0        | 1                                           | <b>-1</b>                                  | Add 2's Complement of Multiplicand to PP                        |
| 1                   | 1        | 0                                           | <b>-1</b>                                  | Add 2's Complement of Multiplicand to PP                        |
| 1                   | 1        | 1                                           | <b>0</b>                                   | No Addition required only shift PP                              |

# Bit-Pair Recoding of Multipliers

Bit-pair recoding is the product of the multiplier results in using at most one summand for each pair of bits in the multiplier. It is derived directly from the Booth algorithm. Grouping the Booth-recoded multiplier bits in pairs will decrease the multiplication only by  $n/2$  summands.

| Multiplier bit-pair |     | Multiplier bit on the right | Multiplicand selected at position $i$ |
|---------------------|-----|-----------------------------|---------------------------------------|
| $i+1$               | $i$ | $i-1$                       |                                       |
| 0                   | 0   | 0                           | 0 X M                                 |
| 0                   | 0   | 1                           | + 1 X M                               |
| 0                   | 1   | 0                           | + 1 X M                               |
| 0                   | 1   | 1                           | + 2 X M                               |
| 1                   | 0   | 0                           | - 2 X M                               |
| 1                   | 0   | 1                           | - 1 X M                               |
| 1                   | 1   | 0                           | - 1 X M                               |
| 1                   | 1   | 1                           | 0 X M                                 |

(b) Table of multiplicand selection decisions

# Bit-Pair Recoding of Multipliers

| Multiplier Bit Pair |   | Multiplier Bit on the right<br>(i-1) | Multiplicand selected at position i | Remarks                                                         |
|---------------------|---|--------------------------------------|-------------------------------------|-----------------------------------------------------------------|
| (i-1)               | i |                                      |                                     |                                                                 |
| 0                   | 0 | 0                                    | 0                                   | No Addition required only shift Partial Product (PP)            |
| 0                   | 0 | 1                                    | +1                                  | Add Multiplicand to PP                                          |
| 0                   | 1 | 0                                    | +1                                  | Add Multiplicand to PP                                          |
| 0                   | 1 | 1                                    | +2                                  | Add two times Multiplicand and then add to PP                   |
| 1                   | 0 | 0                                    | -2                                  | Add two times 2's complement of Multiplicand and then add to PP |
| 1                   | 0 | 1                                    | -1                                  | Add 2's Complement of Multiplicand to PP                        |
| 1                   | 1 | 0                                    | -1                                  | Add 2's Complement of Multiplicand to PP                        |
| 1                   | 1 | 1                                    | 0                                   | No Addition required only shift PP                              |

$$\begin{array}{r}
 0 & 1 & 1 & 0 & 1 & (+13) \\
 \times & 1 & 1 & 0 & 1 & 0 & (-6) \\
 \hline
 \end{array}$$

↓

$$\begin{array}{r}
 0 & 1 & 1 & 0 & 1 \\
 0 -1 +1 -1 0 \\
 \hline
 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
 1 & 1 & 1 & 1 & 1 & 0 & 0 & 1 & 1 \\
 0 & 0 & 0 & 0 & 1 & 1 & 0 & 1 \\
 1 & 1 & 1 & 0 & 0 & 1 & 1 \\
 0 & 0 & 0 & 0 & 0 & 0 \\
 \hline
 1 & 1 & 1 & 0 & 1 & 1 & 0 & 0 & 1 & 0 & (-78)
 \end{array}$$

↓

$$\begin{array}{r}
 0 & 1 & 1 & 0 & 1 \\
 0 -1 -2 \\
 \hline
 1 & 1 & 1 & 1 & 1 & 0 & 0 & 1 & 1 & 0 \\
 1 & 1 & 1 & 1 & 0 & 0 & 1 & 1 \\
 0 & 0 & 0 & 0 & 0 & 0 \\
 \hline
 1 & 1 & 1 & 0 & 1 & 1 & 0 & 0 & 1 & 0
 \end{array}$$

Multiplication requiring only  $n/2$  summands.

# Rough Slide to explain Bit-Pair Recoding of Multipliers

| Multiplier Bit Pair | Multiplier Bit on the right<br>(i-1) | Multiplicand selected at position i | Remarks                                                            |
|---------------------|--------------------------------------|-------------------------------------|--------------------------------------------------------------------|
| (i-1)               | i                                    |                                     |                                                                    |
| 0                   | 0                                    | 0                                   | 0 No Addition required only shift Partial Product (PP)             |
| 0                   | 0                                    | 1                                   | +1 Add Multiplicand to PP                                          |
| 0                   | 1                                    | 0                                   | +1 Add Multiplicand to PP                                          |
| 0                   | 1                                    | 1                                   | +2 Add two times Multiplicand and then add to PP                   |
| 1                   | 0                                    | 0                                   | -2 Add two times 2's complement of Multiplicand and then add to PP |
| 1                   | 0                                    | 1                                   | -1 Add 2's Complement of Multiplicand to PP                        |
| 1                   | 1                                    | 0                                   | -1 Add 2's Complement of Multiplicand to PP                        |
| 1                   | 1                                    | 1                                   | 0 No Addition required only shift PP                               |

$$\begin{array}{r}
 \text{Multiplic} \\
 +13 \\
 \times -6 \\
 \hline
 -78
 \end{array}
 \quad
 \begin{array}{l}
 \text{and} \\
 \text{Multiplier} \\
 \hline
 \end{array}
 \quad
 \begin{array}{ccccccc}
 0 & 1 & 1 & 0 & 1 & 0 & 0
 \end{array}$$

2's Complement of +13

$$\begin{array}{r}
 +13 \ 01101 \\
 10010 \\
 \hline
 1
 \end{array}$$

$$10011$$

2's Complement of +6

$$\begin{array}{r}
 +6 \ 00110 \\
 11001 \\
 \hline
 1
 \end{array}$$

$$11010$$

# Rough Slide to explain Bit-Pair Recoding of Multipliers

| Multiplier Bit Pair | Multiplier Bit on the right<br>(i-1) | Multiplicand selected at position i | Remarks                                                         |
|---------------------|--------------------------------------|-------------------------------------|-----------------------------------------------------------------|
| (i-1)               | i                                    |                                     |                                                                 |
| 0 0                 | 0                                    | 0                                   | No Addition required only shift Partial Product (PP)            |
| 0 0                 | 1                                    | +1                                  | Add Multiplicand to PP                                          |
| 0 1                 | 0                                    | +1                                  | Add Multiplicand to PP                                          |
| 0 1                 | 1                                    | +2                                  | Add two times Multiplicand and then add to PP                   |
| 1 0                 | 0                                    | -2                                  | Add two times 2's complement of Multiplicand and then add to PP |
| 1 0                 | 1                                    | -1                                  | Add 2's Complement of Multiplicand to PP                        |
| 1 1                 | 0                                    | -1                                  | Add 2's Complement of Multiplicand to PP                        |
| 1 1                 | 1                                    | 0                                   | No Addition required only shift PP                              |

$$\begin{array}{r}
 +13 \\
 \times -6 \\
 \hline
 -78
 \end{array}
 \quad \begin{array}{l}
 \text{Multiplic} \\
 \text{and} \\
 \text{Multiplier} \\
 \text{Booth} \\
 \text{Recoded} \\
 \text{Multiplier}
 \end{array}
 \quad \begin{array}{cccccccccc}
 0 & 1 & 1 & 0 & 1 & 0 & 0 \\
 1 & 1 & 1 & 0 & 1 & 0 & 0 \\
 0 & & & -1 & & -2 &
 \end{array}$$

2's Complement of +13

$$\begin{array}{r}
 +13 \ 01101 \\
 10010 \\
 \hline
 1
 \end{array}$$

$$\hline
 10011$$

2's Complement of +6

$$\begin{array}{r}
 +6 \ 00110 \\
 11001 \\
 \hline
 1
 \end{array}$$

$$\hline
 11010$$

# Rough Slide to explain Bit-Pair Recoding of Multipliers

| Multiplier Bit Pair | Multiplier Bit on the right<br>(i-1) | Multiplicand selected at position i | Remarks                                                         |
|---------------------|--------------------------------------|-------------------------------------|-----------------------------------------------------------------|
| (i-1)               | i                                    |                                     |                                                                 |
| 0 0                 | 0                                    | 0                                   | No Addition required only shift Partial Product (PP)            |
| 0 0                 | 1                                    | +1                                  | Add Multiplicand to PP                                          |
| 0 1                 | 0                                    | +1                                  | Add Multiplicand to PP                                          |
| 0 1                 | 1                                    | +2                                  | Add two times Multiplicand and then add to PP                   |
| 1 0                 | 0                                    | -2                                  | Add two times 2's complement of Multiplicand and then add to PP |
| 1 0                 | 1                                    | -1                                  | Add 2's Complement of Multiplicand to PP                        |
| 1 1                 | 0                                    | -1                                  | Add 2's Complement of Multiplicand to PP                        |
| 1 1                 | 1                                    | 0                                   | No Addition required only shift PP                              |

2's Complement of +13

+13 01101

10010

1

-----

10011

$$\begin{array}{r}
 \begin{array}{c} +13 \\ \times -6 \\ \hline -78 \end{array} & \begin{array}{c} \text{Multiplic} \\ \text{and} \end{array} & \begin{array}{ccccccccc} 0 & 1 & 1 & 0 & 1 & 0 & 1 & 0 & 0 \end{array} \\
 & \begin{array}{c} \text{Multiplier} \end{array} & \begin{array}{ccccccccc} 1 & 1 & 1 & 0 & 1 & 0 & 1 & 0 & 0 \end{array} \\
 & \begin{array}{c} \text{Booth} \\ \text{Recoded} \\ \text{Multiplier} \end{array} & \begin{array}{ccccccccc} 0 & & -1 & & -2 & & & & \end{array} \\
 & & \begin{array}{c} \text{Multiplic} \\ \text{and} \end{array} & \begin{array}{ccccccccc} 0 & 1 & 1 & 0 & 1 & 0 & 1 & 0 & 1 \end{array} \\
 & & \begin{array}{c} \text{Recoded} \\ \text{Multiplier} \end{array} & \begin{array}{ccccccccc} 0 & & -1 & & -2 & & & & \end{array}
 \end{array}$$

2's Complement of +6

+6 00110

11001

1

-----

11010

# Rough Slide to explain Bit-Pair Recoding of Multipliers

| Multiplier Bit Pair | Multiplier Bit on the right<br>(i-1) | Multiplicand selected at position i | Remarks                                                         |
|---------------------|--------------------------------------|-------------------------------------|-----------------------------------------------------------------|
| (i-1)               | i                                    |                                     |                                                                 |
| 0 0                 | 0                                    | 0                                   | No Addition required only shift Partial Product (PP)            |
| 0 0                 | 1                                    | +1                                  | Add Multiplicand to PP                                          |
| 0 1                 | 0                                    | +1                                  | Add Multiplicand to PP                                          |
| 0 1                 | 1                                    | +2                                  | Add two times Multiplicand and then add to PP                   |
| 1 0                 | 0                                    | -2                                  | Add two times 2's complement of Multiplicand and then add to PP |
| 1 0                 | 1                                    | -1                                  | Add 2's Complement of Multiplicand to PP                        |
| 1 1                 | 0                                    | -1                                  | Add 2's Complement of Multiplicand to PP                        |
| 1 1                 | 1                                    | 0                                   | No Addition required only shift PP                              |

$$\begin{array}{r}
 +13 \\
 \times -6 \\
 \hline
 -78
 \end{array}
 \quad \text{Multiplicand} \quad 0 \quad 1 \quad 1 \quad 0 \quad 1 \quad 1 \quad 0 \quad 0$$

Booth Recoded Multiplier

2's Complement of +13

$$+13 \quad 01101$$

$$\begin{array}{r}
 10010 \\
 1 \\
 \hline
 \end{array}$$

$$\begin{array}{r}
 \text{Multiplicand} \quad 0 \quad 1 \quad 1 \quad 0 \quad 1
 \end{array}$$

$$\begin{array}{r}
 \text{Recoded Multiplier} \quad 0 \quad -1 \quad -2
 \end{array}$$

$$10011$$

$$\begin{array}{ccccccccc}
 1 & 1 & 1 & 1 & 1 & 0 & 0 & 1 & 1 & 0
 \end{array}$$

2's Complement of +6

$$+6 \quad 00110$$

$$\begin{array}{r}
 11001 \\
 1 \\
 \hline
 \end{array}$$

$$\begin{array}{ccccccccc}
 1 & 1 & 1 & 1 & 0 & 0 & 1 & 1
 \end{array}$$

$$11010$$

$$\begin{array}{ccccccccc}
 1 & 1 & 1 & 0 & 1 & 1 & 0 & 0 & 1 & 0
 \end{array}
 \quad -78$$

# Example: Bit-Pair Recoding of Multipliers

$$\begin{array}{r} +13 \\ \times -6 \\ \hline -78 \end{array}$$

$$\begin{array}{r} +13 \\ 01101 \\ 10010 \quad \text{2's complement} \\ \hline 10011 \quad (-13) \end{array}$$

$$\begin{array}{r} +6 \\ 00110 \\ 11001 \\ \hline 11010 \quad (-6) \end{array}$$

Multiplicand (+13) : 0 1101

Multiplier (-6) : 1 1010

Sign Extension

Bit pair  
recoding  
of Multiplier

1 1 1 0 1 0 ← Implied  
0 to right  
of LSB  
we take 3-bits  
and do recoding

0 -1 -2

$$\begin{array}{r} 01101 \\ 0 -1 -2 \\ \hline 1111100100 \\ 11110011 \\ 0000000 \\ \hline 1110110010 \quad (-78) \end{array}$$

$$\begin{array}{r} -6 \\ 11010 \\ 11010 \\ \hline 10100 \\ -13 \\ 10011 \\ 10011 \\ \hline 00100 \end{array}$$

$$\begin{array}{r} 0001001101 \\ 00010011010 \quad (78) \\ \hline 64 + 8 + 4 + 2 = 78 \end{array}$$

# Question

---

Assuming 6-bit 2's-complement number representation, multiply the multiplicand A = -13 by the multiplier B = -20 using the Booth Bit-Pair Recoding algorithm

Booth Bit Pair Recoding Table

| Multiplicand Bit Pair<br><b>(i-1) i</b> | Multiplicand Bit on the right<br><b>(i-1)</b> | Multiplicand selected at position i | Remarks                                                         |
|-----------------------------------------|-----------------------------------------------|-------------------------------------|-----------------------------------------------------------------|
| 0 0                                     | 0                                             | <b>0</b>                            | No Addition required only shift Partial Product (PP)            |
| 0 0                                     | 1                                             | <b>+1</b>                           | Add Multiplicand to PP                                          |
| 0 1                                     | 0                                             | <b>+1</b>                           | Add Multiplicand to PP                                          |
| 0 1                                     | 1                                             | <b>+2</b>                           | Add two times Multiplicand and then add to PP                   |
| 1 0                                     | 0                                             | <b>-2</b>                           | Add two times 2's complement of Multiplicand and then add to PP |
| 1 0                                     | 1                                             | <b>-1</b>                           | Add 2's Complement of Multiplicand to PP                        |
| 1 1                                     | 0                                             | <b>-1</b>                           | Add 2's Complement of Multiplicand to PP                        |
| 1 1                                     | 1                                             | <b>0</b>                            | No Addition required only shift PP                              |

# Booth Bit-Pair Recoding Multiplication : Example

$A = 110011$  ( $-13 \rightarrow$  2's compliment of 110011)

$B = 101100$  ( $-20 \rightarrow$  2's compliment of 101100)

Multiply the signed 2's complement numbers using the bit-pair recoding of the multiplier.

$$\begin{array}{r} 1 \ 1 \ 0 \ 0 \ 1 \ 1 & -13 \\ \times \quad -1 \quad -1 & \times -20 \text{ (Booth recoding } -1 \ +1 \ 0 \ -1 \ 0 \ 0 \text{)} \\ \hline 0 \ 0 \ 0 \ 0 \ 0 \ 0 \ 0 \ 0 \ 0 \ 0 \ 0 \ 0 \\ 0 \ 0 \ 0 \ 0 \ 0 \ 0 \ 1 \ 1 \ 0 \ 1 & \text{-2's compliment} \\ \hline 0 \ 0 \ 0 \ 0 \ 1 \ 1 \ 0 \ 1 \\ \hline 0 \ 0 \ 0 \ 1 \ 0 \ 0 \ 0 \ 0 \ 1 \ 0 \ 0 & = (+260) \end{array}$$

Thus, the resultant value is  $+ (260)$ .

# Booth Bit-Pair Recoding Multiplication : Example

$$A = 010111 \text{ (+23)}$$

$$B = 110110 \text{ (-10 → 2's compliment of 110110)}$$

Multiply the signed 2's complement numbers using the bit-pair recoding of the multiplier.

$$\begin{array}{r} 0\ 1\ 0\ 1\ 1\ 1 \\ \times -1\ +2\ -2 \\ \hline 1\ 1\ 1\ 1\ 1\ 10\ 1\ 0\ 0\ 1\ 0 \\ 0\ 0\ 0\ 0\ 1\ 0\ 1\ 1\ 1\ 0 \\ 1\ 1\ 1\ 0\ 1\ 0\ 0\ 1 \\ \hline 1\ 1\ 1\ 1\ 0\ 0\ 0\ 1\ 1\ 0\ 1\ 0 \end{array} \quad \begin{array}{l} 23 \\ \times -10 \text{ (Booth recoding } 0\ -1+1\ 0\ -1\ 0) \\ = -230 \end{array}$$

Thus, the resultant value is  $-(230)$ .

# Carry-Save Addition of Summands

---

Multiplication requires the addition of several summands. A technique called *carry-save addition* (CSA) can be used to speed up the process. Consider the  $4 \times 4$  multiplication array shown in Figure 9.16a. This structure is in the form of the array shown in Figure 9.6, in which the first row consists of just the AND gates that produce the four inputs  $m3q_0$ ,  $m2q_0$ ,  $m1q_0$ , and  $m0q_0$ .

Instead of letting the carries ripple along the rows, they can be “saved” and introduced into the next row, at the correct weighted positions, as shown in Figure 9.16b. This frees up an input to each of three full adders in the first row. These inputs can be used to introduce

# Carry-Save Addition of Summands



(a) Ripple-carry array



(b) Carry-save array

Figure 9.16 Ripple-carry and carry-save arrays for a  $4 \times 4$  multiplier.

# Rough Slide to explain Carry-Save Addition of Summands

|   |   |   |   |   |      |
|---|---|---|---|---|------|
|   | 1 | 0 | 1 | 1 | (11) |
| x | 1 | 1 | 0 | 1 | (13) |
|   | 1 | 0 | 1 | 1 |      |
| 0 | 0 | 0 | 0 |   |      |
| 1 | 0 | 1 | 1 |   |      |
| 1 | 0 | 1 | 1 |   |      |
| 1 | 0 | 0 | 0 | 1 | 1    |
| 1 | 0 | 0 | 0 | 1 | 1    |

|       | $m_3$    | $m_2$    | $m_1$    | $m_0$    | Multiplicand (M) |
|-------|----------|----------|----------|----------|------------------|
| x     | $q_3$    | $q_2$    | $q_1$    | $q_0$    | Multiplier (Q)   |
|       | $m_3q_0$ | $m_2q_0$ | $m_1q_0$ | $m_0q_0$ |                  |
|       | $m_3q_1$ | $m_2q_1$ | $m_1q_1$ | $m_0q_1$ |                  |
|       | $m_3q_2$ | $m_2q_2$ | $m_1q_2$ | $m_0q_2$ |                  |
|       | $m_3q_3$ | $m_2q_3$ | $m_1q_3$ | $m_0q_3$ |                  |
| $P_7$ | $P_6$    | $P_5$    | $P_4$    | $P_3$    | $P_2$            |
|       |          |          |          |          | $P_1$            |
|       |          |          |          |          | $P_0$            |



# Rough Slide to explain Carry-Save Addition of Summands

|       | $m_3$    | $m_2$    | $m_1$    | $m_0$    | Multiplicand (M) |       |       |
|-------|----------|----------|----------|----------|------------------|-------|-------|
| X     | $q_3$    | $q_2$    | $q_1$    | $q_0$    | Multiplier (Q)   |       |       |
|       | $m_3q_0$ | $m_2q_0$ | $m_1q_0$ | $m_0q_0$ |                  |       |       |
|       | $m_3q_1$ | $m_2q_1$ | $m_1q_1$ | $m_0q_1$ |                  |       |       |
|       | $m_3q_2$ | $m_2q_2$ | $m_1q_2$ | $m_0q_2$ |                  |       |       |
|       | $m_3q_3$ | $m_2q_3$ | $m_1q_3$ | $m_0q_3$ |                  |       |       |
| $P_7$ | $P_6$    | $P_5$    | $P_4$    | $P_3$    | $P_2$            | $P_1$ | $P_0$ |



(b) Carry-save array

# Summand Addition Tree using 3-2 Reducers

---

A more significant reduction in delay can be achieved when dealing with longer operands than those considered in Figure 9.16. We can group the summands in threes and perform carry-save addition on each of these groups in parallel to generate a set of  $S$  and  $C$  vectors in one full-adder delay. Here, we will refer to a full-adder circuit as simply an adder. Next, we group all the  $S$  and  $C$  vectors into threes, and perform carry-save addition on them, generating a further set of  $S$  and  $C$  vectors in one more adder delay. We continue with this process until there are only two vectors remaining. The adder at each bit position of the three summands is called a *3-2 reducer*, and the logic circuit structure that reduces a number of summands to two is called a *CSA tree*. The final two  $S$  and  $C$  vectors can be added in a carry-lookahead adder to produce the desired product. Consider the example shown in Figure 9.17. It involves adding the six shifted versions of the multiplicand for the case of multiplying two, 6-bit, unsigned numbers, where all six bits of the multiplier are equal to 1. The six summands, A, B, . . . , F are added by carry-save addition in Figure 9.18. The blue boxes in these two figures indicate the same operand bits, and show how they are reduced to sum and carry bits in Figure 9.18 by carry-save addition. Three levels of carry-save addition are performed, as shown schematically in Figure 9.19. This figure shows that the final two vectors  $S_4$  and  $C_4$  are available in three adder delays after the six input summands are applied to level 1. The final regular addition operation on  $S_4$  and  $C_4$ , which produces the product, can be done with a carry-lookahead adder.

## Summand Addition Tree using 3-2 Reducers (Contd..)

$$\begin{array}{r}
 & 1 & 0 & 1 & 1 & 0 & 1 \\
 \times & 1 & 1 & 1 & 1 & 1 & 1 \\
 \hline
 & 1 & 0 & 1 & 1 & 0 & 1 & A \\
 & 1 & 0 & 1 & 1 & 0 & 1 & B \\
 & 1 & 0 & 1 & 1 & 0 & 1 & C \\
 & 1 & 0 & 1 & 1 & 0 & 1 & D \\
 & 1 & 0 & 1 & 1 & 0 & 1 & E \\
 & 1 & 0 & 1 & 1 & 0 & 1 & F \\
 \hline
 & 1 & 0 & 1 & 1 & 0 & 1 & (2,835) \quad \text{Product}
 \end{array}$$

**Figure 9.17** A multiplication example used to illustrate carry-save addition as shown in Figure 9.18.



**Figure 9.19** Schematic representation of the carry-save addition operations in Figure 9.18.

## Summand Addition Tree using 3-2 Reducers (Contd..)

$$\begin{array}{r}
 & 1 & 0 & 1 & 1 & 0 & 1 & M \\
 \times & 1 & 1 & 1 & 1 & 1 & 1 & Q \\
 \hline
 & 1 & 0 & 1 & 1 & 0 & 1 & \\
 & 1 & 0 & 1 & 1 & 0 & 1 & \\
 \hline
 & 1 & 1 & 0 & 0 & 0 & 0 & 1 & 1 \\
 & 0 & 0 & 1 & 1 & 1 & 1 & 0 & 0 \\
 & 1 & 0 & 1 & 1 & 0 & 1 & \\
 & 1 & 0 & 1 & 1 & 0 & 1 & \\
 \hline
 & 1 & 1 & 0 & 0 & 0 & 0 & 1 & 1 \\
 & 0 & 0 & 1 & 1 & 1 & 1 & 0 & 0 \\
 & 1 & 1 & 0 & 0 & 0 & 0 & 1 & 1 \\
 & 1 & 1 & 0 & 0 & 0 & 0 & 1 & 1 \\
 \hline
 & 1 & 1 & 0 & 1 & 0 & 0 & 0 & 1 & 1 \\
 & 0 & 0 & 0 & 0 & 1 & 0 & 1 & 1 & 0 & 0 \\
 & 0 & 0 & 1 & 1 & 1 & 1 & 0 & 0 \\
 & 0 & 1 & 0 & 1 & 1 & 1 & 0 & 0 & 1 & 1 \\
 + & 0 & 1 & 0 & 1 & 0 & 1 & 0 & 0 & 0 & 0 \\
 \hline
 & 1 & 0 & 1 & 1 & 0 & 0 & 0 & 1 & 0 & 0 & 1 & 1
 \end{array}$$



**Figure 9.19** Schematic representation of the carry-save addition operations in Figure 9.18.

**Figure 9.18** The multiplication example from Figure 9.17 performed using carry-save addition.

# Unit-4

---

Integer Division

Two Methods: Restoring and Non-restoring algorithms

# Manual Division

---

## □ Longhand division examples.

$$\begin{array}{r} 21 \\ 13 ) 274 \\ \underline{-26} \\ 14 \\ \underline{-13} \\ 1 \end{array}$$

$$\begin{array}{r} 10101 \\ 1101 ) 100010010 \\ \underline{-1101} \\ 10000 \\ \underline{-1101} \\ 1110 \\ \underline{-1101} \\ 1 \end{array}$$

# Longhand Division Steps

---

- Position the divisor appropriately with respect to the dividend and performs a subtraction.
- If the remainder is zero or positive, a quotient bit of 1 is determined, the remainder is extended by another bit of the dividend, the divisor is repositioned, and another subtraction is performed.
- If the remainder is negative, a quotient bit of 0 is determined, the dividend is restored by adding back the divisor, and the divisor is repositioned for another subtraction.

# Rough slide to explain Manual Division

---

## □ Longhand division examples.

$$\begin{array}{r} 21 \\ 13 ) \overline{274} \\ \underline{26} \\ 14 \\ \underline{13} \\ 1 \end{array}$$

**13** is Divisor  
**274** is Dividend  
**21** is Quotient  
**1** is Remainder

# Circuit Arrangement for Binary Division



# Restoring Division Example



# Restoring division algorithm

Initially Register M=Divisor (n+1 bits)

A=0 (n+1 bits)

Q=Dividend (n bits)

After completion of Division:

Register Q=Quotient

Register A: Remainder

Algorithm:

Do the following for n-times

- Shift A and Q left one binary position
- Subtract M from A and Place the answer back in A
- If the Sign of A is 1, set  $q_0$  to 0 and add M back to A (i.e., Restore A) Otherwise Set  $q_0$  to 1



# Restoring division algorithm example



# Rough Slide to explain Restoring division

|         | M (n+1) Bits |   |   |   |   |    | Q(n Bits) |   |   |   |   |    |
|---------|--------------|---|---|---|---|----|-----------|---|---|---|---|----|
| Divisor | 0            | 0 | 0 | 1 | 1 | +3 |           | 0 | 0 | 0 | 0 | +8 |
|         | A(n+1 Bits)  |   |   |   |   |    |           | 1 | 0 | 0 | 0 |    |
|         | 0            | 0 | 0 | 0 | 0 |    |           |   |   |   |   |    |

Handwritten long division diagram:

Dividend: 8  
Divisor: 3  
Quotient: 2  
Remainder: 2

Calculation steps:

$$\begin{array}{r} 8 \\ 3 \overline{)8} \\ -6 \\ \hline 2 \end{array}$$

Initially Register  
M=Divisor (n+1 bits)  
A=0 (n+1 bits)  
Q=Dividend (n bits)

# Rough Slide to explain Restoring division

|         | M (n+1) Bits |   |   |   |   |    | Q(n Bits)   |   |   |   |   |    |
|---------|--------------|---|---|---|---|----|-------------|---|---|---|---|----|
| Divisor | 0            | 0 | 0 | 1 | 1 | +3 | A(n+1 Bits) | 0 | 0 | 0 | 0 | +8 |
| Shift   | 0            | 0 | 0 | 0 | 1 |    | Q(n Bits)   | 1 | 0 | 0 | 0 |    |
|         | 0            | 0 | 0 | 0 | 0 |    | 0           | 0 | 0 | 0 |   |    |

Algorithm:

Do the following for n-times

- Shift A and Q left one binary position
- Subtract M from A and Place the answer back in A
- If the Sign of A is 1, set  $q_0$  to 0 and add M back to A (i.e., Restore A) Otherwise Set  $q_0$  to 1

# Rough Slide to explain Restoring division

|                     | M (n+1) Bits |   |   |   |   |    | Q(n Bits) |                         |   |   |    |  |
|---------------------|--------------|---|---|---|---|----|-----------|-------------------------|---|---|----|--|
| Divisor             | 0            | 0 | 0 | 1 | 1 | +3 |           |                         |   |   |    |  |
|                     | A(n+1 Bits)  |   |   |   |   |    |           |                         |   |   |    |  |
|                     | 0            | 0 | 0 | 0 | 0 |    | 1         | 0                       | 0 | 0 | +8 |  |
| Shift               | 0            | 0 | 0 | 0 | 1 |    | 0         | 0                       | 0 |   |    |  |
| Subtract<br>(A=A-M) | +            | 1 | 1 | 1 | 0 | 1  | ←         | Add 2's Complement of M |   |   |    |  |

Algorithm:

Do the following for n-times

- Shift A and Q left one binary position
- Subtract M from A and Place the answer back in A
- If the Sign of A is 1, set  $q_0$  to 0 and add M back to A (i.e., Restore A) Otherwise Set  $q_0$  to 1

# Rough Slide to explain Restoring division

|                     | M (n+1) Bits |   |   |   |   |    | Q(n Bits)   |   |   |   |   |                         |
|---------------------|--------------|---|---|---|---|----|-------------|---|---|---|---|-------------------------|
| Divisor             | 0            | 0 | 0 | 1 | 1 | +3 | A(n+1 Bits) | 0 | 0 | 0 | 0 | +8                      |
| Shift               | 0            | 0 | 0 | 0 | 1 |    | 1           | 0 | 0 | 0 |   |                         |
| Subtract<br>(A=A-M) | +            | 1 | 1 | 1 | 0 | 1  | ←           |   |   |   |   | Add 2's Complement of M |
| Set $q_0$           | 1            | 1 | 1 | 1 | 0 |    |             |   |   |   |   |                         |

Algorithm:

Do the following for n-times

- Shift A and Q left one binary position
- Subtract M from A and Place the answer back in A
- If the Sign of A is 1, set  $q_0$  to 0 and add M back to A (i.e., Restore A) Otherwise Set  $q_0$  to 1

# Rough Slide to explain Restoring division



Algorithm:

Do the following for n-times

- Shift A and Q left one binary position
- Subtract M from A and Place the answer back in A
- If the Sign of A is 1, set  $q_0$  to 0 and add M back to A (i.e., Restore A) Otherwise Set  $q_0$  to 1

# Rough Slide to explain Restoring division

|                     | M (n+1) Bits |   |   |   |   | Q(n Bits) |             |   |   |       |    |
|---------------------|--------------|---|---|---|---|-----------|-------------|---|---|-------|----|
| Divisor             | 0            | 0 | 0 | 1 | 1 | +3        | A(n+1 Bits) | 1 | 0 | 0     | +8 |
| Shift               | 0            | 0 | 0 | 0 | 0 |           | 1           | 0 | 0 |       |    |
| Subtract<br>(A=A-M) | + 1          | 1 | 1 | 0 | 1 | ←         |             |   |   |       |    |
| Set $q_0$           | 1            | 1 | 1 | 1 | 0 |           |             |   |   |       |    |
| Add<br>$A=A+M$      | + 0          | 0 | 0 | 1 | 1 |           | 0           | 0 | 0 | $q_0$ |    |
|                     | 0            | 0 | 0 | 0 | 1 |           | 0           | 0 | 0 |       |    |

Algorithm:  
 Do the following for n-times  
 a. Shift A and Q left one binary position  
 b. Subtract M from A and Place the answer back in A  
 c. If the Sign of A is 1, set  $q_0$  to 0 and add M back to A (i.e., Restore A) Otherwise Set  $q_0$  to 1

Add 2's Complement of M  
 1st Cycle

# Rough Slide to explain Restoring division

|                     | M (n+1) Bits |   |   |   |   | Q(n Bits) |   |   |   |       |
|---------------------|--------------|---|---|---|---|-----------|---|---|---|-------|
| Divisor             | 0            | 0 | 0 | 1 | 1 | +3        |   |   |   |       |
|                     | A(n+1 Bits)  |   |   |   |   |           |   |   |   |       |
| Shift               | 0            | 0 | 0 | 0 | 0 | 1         | 0 | 0 | 0 | +8    |
| Subtract<br>(A=A-M) | + 1 1 1 0 1  |   |   |   |   |           |   |   |   |       |
| Set $q_0$           | 1            | 1 | 1 | 1 | 0 |           |   |   |   |       |
| Add<br>A=A+M        | + 0 0 0 1 1  |   |   |   |   | 0 0 0 0 0 | 0 | 0 | 0 | $q_0$ |
|                     | 0 0 0 0 1    |   |   |   |   | 0 0 0 0 0 |   |   |   |       |
| Shift               | 0            | 0 | 0 | 1 | 0 | 0         | 0 | 0 | 0 |       |
| Subtract<br>(A=A-M) | + 1 1 1 0 1  |   |   |   |   |           |   |   |   |       |
| Set $q_0$           | 1            | 1 | 1 | 1 | 1 |           |   |   |   |       |
| Add<br>A=A+M        | + 0 0 0 1 1  |   |   |   |   | 0 0 0 0 0 | 0 | 0 | 0 | $q_0$ |
|                     | 0 0 0 1 0    |   |   |   |   | 0 0 0 0 0 |   |   |   |       |

Add 2's Complement of M

1st Cycle

Add 2's Complement of M

2nd Cycle

Algorithm:

- Do the following for n-times
- a. Shift A and Q left one binary position
- b. Subtract M from A and Place the answer back in A
- c. If the Sign of A is 1, set  $q_0$  to 0 and add M back to A (i.e., Restore A) Otherwise Set  $q_0$  to 1

# Rough Slide to explain Restoring division

|                     | M (n+1) Bits |   |   |   |          |                          |
|---------------------|--------------|---|---|---|----------|--------------------------|
| Divisor             | 0            | 0 | 0 | 1 | 1        | +3                       |
|                     | A(n+1 Bits)  |   |   |   |          | Q(n Bits)                |
| Shift               | 0            | 0 | 0 | 0 | 0        | 1 0 0 0 +8               |
| Subtract<br>(A=A-M) | + 1          | 1 | 1 | 0 | 1        | ←                        |
| Set $q_0$           | 0            | 0 | 0 | 0 | 1        | 0 0 0 0 1 q <sub>0</sub> |
| Shift               | 0            | 0 | 0 | 1 | 0        | 0 0 1                    |
| Subtract<br>(A=A-M) | + 1          | 1 | 1 | 0 | 1        | ←                        |
| Set $q_0$           | 1            | 1 | 1 | 1 | 1        | 0 0 1 0 0 q <sub>0</sub> |
| Add<br>A=A+M        | + 0          | 0 | 0 | 1 | 1        | 0 0 1 0 0                |
| Remainder           |              |   |   |   | Quotient |                          |

Algorithm:

- Do the following for n-times
- a. Shift A and Q left one binary position
- b. Subtract M from A and Place the answer back in A
- c. If the Sign of A is 1, set  $q_0$  to 0 and add M back to A (i.e., Restore A) Otherwise Set  $q_0$  to 1

Add 2's Complement of M

3<sup>rd</sup> Cycle

Add 2's Complement of M

4<sup>th</sup> Cycle

# Question

---

Using restoring division algorithm, divided 25 by 4

## **Restoring Division Algorithm**

Initially Register M=Divisor (n+1 bits)

A=0 (n+1 bits)

Q=Dividend (n bits)

After completion of Division:

Register Q=Quotient

Register A: Remainder

Algorithm:

Do the following for n-times

- a. Shift A and Q left one binary position
- b. Subtract M from A and Place the answer back in A
- c. If the Sign of A is 1, set  $q_0$  to 0 and add M back to A (i.e., Restore A) Otherwise Set  $q_0$  to 1

# Restoring division algorithm example



# Non-Restoring division algorithm

Non Restoring Division Algorithm

Initially Register M = Divisor (n+1 bits)  
Register Q = Dividend (n+1 bits)  
Register A = ~~zero~~ 0 (n+1 bits)

After completion of division  
Register A = Remainder  
Register Q = Quotient

Algorithm:

Step 1: Do the following 'N' times

① If sign of A is 0 then  
    Shift A and Q left one bit position  
    Subtract  $A = A - M$

else {  
    Shift A and Q left  
    Add  $A = A + M$

② If sign of A is 0 then  
    { Set  $Q_0$  to 1 }  
else  
    { Set  $Q_0$  to 0 }

Step 2: After N iterations are over,  
if sign of A is 1, add M to A



# Non-Restoring division algorithm

---

Initially Register M=Divisor (n+1 bits)

A=0 (n+1 bits)

Q=Dividend (n bits)

After completion of Division:

Register Q: Quotient

Register A: Remainder

Algorithm:

**Step 1:** (Repeat  $n$  times)

- If the sign of A is 0 shift A and Q left one bit position and subtract M from A; otherwise, shift A and Q left and add M to A.
- Now, if the sign of A is 0, set  $q_0$  to 1; otherwise, set  $q_0$  to 0.

**Step2:** If the sign of A is 1, add M to A

# Non-Restoring division algorithm: Example



# Rough Slide to explain Non-Restoring division algorithm: Example

M ( $n+1$ ) Bits  
Divisor    0    0    0    1    1    +3

A( $n+1$  Bits)                          Q( $n$  Bits)

0    0    0    0    0                1    0    0    0    +8

Shift

0    0    0    0    1                0    0    0      

Subtract  
( $A = A - M$ )

+    1    1    1    0    1    ←

Set  $q_0$

1    1    1    1    0                0    0    0    0     $q_0$

Algorithm:

**Step 1:** (Repeat  $n$  times)

- If the sign of A is 0 shift A and Q left one bit position and subtract M from A; otherwise, shift A and Q left and add M to A.
  - Now, if the sign of A is 0, set  $q_0$  to 1; otherwise, set  $q_0$  to 0.
- Step 2:** If the sign of A is 1, add M to A

Add 2's Complement of M

1st Cycle

# Rough Slide to explain Non-Restoring division algorithm: Example

M (n+1) Bits  
Divisor 0 0 0 1 1 +3

Q(n Bits)

A(n+1 Bits) 0 0 0 0 0 1 0 0 0 0 +8

Shift 0 0 0 0 1 0 0 0 0

Subtract (A=A-M) + 1 1 1 0 1 0 0 0 0

Set  $q_0$  1 1 1 1 0 0 0 0 0  $q_0$

Algorithm:

**Step 1:** (Repeat n times)

- If the sign of A is 0 shift A and Q left one bit position and subtract M from A; otherwise, shift A and Q left and add M to A.
  - Now, if the sign of A is 0, set  $q_0$  to 1; otherwise, set  $q_0$  to 0.
- Step 2:** If the sign of A is 1, add M to A

Add 2's Complement of M

1st Cycle

Shift 1 1 1 0 0 0 0 0

Add A=A+M 0 0 0 1 1 0 0 0

1 1 1 1 1 0 0 0 0

2nd Cycle

# Rough Slide to explain Non-Restoring division algorithm: Example

|                | M (n+1) Bits |   |   |   |           |
|----------------|--------------|---|---|---|-----------|
| Divisor        | 0            | 0 | 0 | 1 | 1         |
|                |              |   |   |   | +3        |
|                | A(n+1 Bits)  |   |   |   | Q(n Bits) |
| Shift          | 0            | 0 | 0 | 0 | 0         |
| Add<br>$A=A+M$ | 1            | 1 | 1 | 1 | 0         |
| Set $q_0$      | + 0          | 0 | 0 | 1 | 1         |
|                | 0            | 0 | 0 | 0 | 1         |

| Shift               | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 1 |
|---------------------|---|---|---|---|---|---|---|---|
| Subtract<br>$A=A-M$ | 1 | 1 | 1 | 0 | 1 | < | 0 | 0 |

| Sign of A is<br>1 ∴ Add<br>$A=A+M$ | 0 | 0 | 0 | 1 | 1 |
|------------------------------------|---|---|---|---|---|
|                                    | 0 | 0 | 0 | 1 | 0 |

Algorithm:

**Step 1:** (Repeat  $n$  times)

- If the sign of A is 0 shift A and Q left one bit position and subtract M from A; otherwise, shift A and Q left and add M to A.
  - Now, if the sign of A is 0, set  $q_0$  to 1; otherwise, set  $q_0$  to 0.
- Step 2:** If the sign of A is 1, add M to A

} 3rd Cycle

} Add 2's Complement of M  
4th Cycle



# Question

---

Using non-restoring division algorithm, divided 25 by 4

## Restoring Division Algorithm

Initially Register M=Divisor (n+1 bits)

A=0 (n+1 bits)

Q=Dividend (n bits)

After completion of Division:

Register Q=Quotient

Register A: Remainder

Algorithm:

- Step 1: (Repeat  $n$  times)
  - If the sign of A is 0 shift A and Q left one bit position and subtract M from A; otherwise, shift A and Q left and add M to A.
  - Now, if the sign of A is 0, set  $q_0$  to 1; otherwise, set  $q_0$  to 0.
- Step2: If the sign of A is 1, add M to A

# Non-Restoring division algorithm: Example



# Unit-4

---

## Floating-point Numbers and Operations

# Floating-Point Representation

---

- Floating-point numbers allow an arbitrary number of decimal places to the right of the decimal point.
  - For example:  $0.5 \times 0.25 = 0.125$
- They are often expressed in scientific notation.
  - For example:  
 $0.125 = 1.25 \times 10^{-1}$   
 $5,000,000 = 5.0 \times 10^6$

# Floating-Point Representation

- Computers use a form of scientific notation for floating-point representation
- Numbers written in scientific notation have three components:



# Floating-Point Representation

- Computer representation of a floating-point number consists of three fixed-size fields:



- This is the standard arrangement of these fields.

*Note: Although “significand” and “mantissa” do not technically mean the same thing, many people use these terms interchangeably.*

# Rough Slide to explain Excess Notation

1. Add the excess value ( $2^{N-1}$ , where N is the number of bits used to represent the number) to the number.
2. Convert the resulting number into binary format.

The  $2^{N-1}$  is often referred to as the *Magic Number* for computing the excess representation of the number (except that there is no magic in it). Table 7 presents all the numbers that can be represented using the excess-8 notation.

| Number | Excess Number | Bit Pattern |
|--------|---------------|-------------|
| 7      | 15            | 1111        |
| 6      | 14            | 1110        |
| 5      | 13            | 1101        |
| 4      | 12            | 1100        |
| 3      | 11            | 1011        |
| 2      | 10            | 1010        |
| 1      | 9             | 1001        |
| 0      | 8             | 1000        |
| -1     | 7             | 0111        |
| -2     | 6             | 0110        |
| -3     | 5             | 0101        |
| -4     | 4             | 0100        |
| -5     | 3             | 0011        |
| -6     | 2             | 0010        |
| -7     | 1             | 0001        |
| -8     | 0             | 0000        |

Table 7. Numbers using the Excess-8 representation

# Excess Notation

The excess notation is a means of representing both negative and positive numbers in a manner in which the order of the bit patterns is maintained. The algorithm for computing the excess notation bit pattern is as follows:

1. Add the excess value ( $2^{N-1}$ , where N is the number of bits used to represent the number) to the number.
2. Convert the resulting number into binary format.

The  $2^{N-1}$  is often referred to as the *Magic Number* for computing the excess representation of the number (except that there is no magic in it). Table 7 presents all the numbers that can be represented using the excess-8 notation.

| Number | Excess Number | Bit Pattern |
|--------|---------------|-------------|
| 7      | 15            | 1111        |
| 6      | 14            | 1110        |
| 5      | 13            | 1101        |
| 4      | 12            | 1100        |
| 3      | 11            | 1011        |
| 2      | 10            | 1010        |
| 1      | 9             | 1001        |
| 0      | 8             | 1000        |
| -1     | 7             | 0111        |
| -2     | 6             | 0110        |
| -3     | 5             | 0101        |
| -4     | 4             | 0100        |
| -5     | 3             | 0011        |
| -6     | 2             | 0010        |
| -7     | 1             | 0001        |
| -8     | 0             | 0000        |

Table 7. Numbers using the Excess-8 representation

The number of bits used to represent a code in excess-8 is 4 bits ( $2^{4-1} = 8$ ). Also, the bit patterns are in sequence (the largest number that can be represented has the bit pattern 1111).

Example 11. Consider the following operation  $7 - 2$ . Substituting the bit patterns from the table:

$$\begin{array}{r} 1111 \\ + 0110 \\ \hline 10101 \end{array}$$

The result of the addition operation is the bit-pattern used for 5 in binary. The excess notation representation however takes longer to compute than the 2's complement notation. The excess notation will however play an important part in computing floating-point representations.

# IEEE floating point number representation

---

- The IEEE Standard for Floating-Point Arithmetic (IEEE 754) is a technical standard for floating-point computation which was established in 1985 by the **Institute of Electrical and Electronics Engineers (IEEE)**. The standard addressed many problems found in the diverse floating point implementations that made them difficult to use reliably and reduced their portability. IEEE Standard 754 floating point is the most common representation today for real numbers on computers, including Intel-based PC's, Macs, and most Unix platforms.

There are several ways to represent floating point number but IEEE 754 is the most efficient in most cases. IEEE 754 has 3 basic components:

## **The Sign of Mantissa –**

This is as simple as the name. 0 represents a positive number while 1 represents a negative number.

## **The Biased exponent –**

The exponent field needs to represent both positive and negative exponents. A bias is added to the actual exponent in order to get the stored exponent.

## **The Normalised Mantissa –**

The mantissa is part of a number in scientific notation or a floating-point number, consisting of its significant digits. Here we have only 2 digits, i.e. 0 and 1. So a normalised mantissa is one with only one 1 to the left of the decimal.

# IEEE floating point number representation

---

IEEE 754 numbers are divided into two based on the three components (Sign, Exponent, Mantissa) :

1. Single Precision
2. Double Precision

# IEEE standard floating-point formats: Single Precision

The basic IEEE format is a 32-bit representation, shown in Figure below. The leftmost bit represents the sign, S, for the number. The next 8 bits, E', represent the signed exponent of the scale factor (with an implied base of 2), and the remaining 23 bits, M, are the fractional part of the significant bits.



# IEEE standard floating-point formats: Single Precision (Contd....)

---

The full 24-bit string, B, of significant bits, called the mantissa, always has a leading 1, with the binary point immediately to its right. Therefore, the mantissa

$$B = 1.M = 1.b_{-1}b_{-2}\dots b_{-23}$$

has a value

$$V(B) = 1 + b_{-1} \times 2^{-1} + b_{-2} \times 2^{-2} + \dots + b_{-23} \times 2^{-23}$$

Instead of the actual signed exponent, E, the value stored in the exponent field is an unsigned integer  $E = E + 127$ . This is called the excess-127 format. Thus, E is in the range  $0 \leq E \leq 255$ . The end values of this range, 0 and 255, are used to represent special values, as described later. Therefore, the range of E for normal values is  $1 \leq E \leq 254$ . This means that the actual exponent, E, is in the range  $-126 \leq E \leq 127$ . The use of the excess-127 representation for exponents simplifies comparison of the relative sizes of two floating-point numbers. The 32-bit standard representation in Figure (in previous slide) is called a single-precision representation because it occupies a single 32-bit word. The scale factor has a range of  $2^{-126}$  to  $2^{+127}$ , which is approximately equal to  $10^{\pm 38}$ . The 24-bit mantissa provides approximately the same precision as a 7-digit decimal value.

# IEEE standard floating-point formats: Double Precision

To provide more precision and range for floating-point numbers, the IEEE standard also specifies a double-precision format, as shown in Figure. The double-precision format has increased exponent and mantissa ranges. The 11-bit excess-1023 exponent E has the range  $1 \leq E \leq 2046$  for normal values, with 0 and 2047 used to indicate special values, as before. Thus, the actual exponent E is in the range  $-1022 \leq E \leq 1023$ , providing scale factors of  $2^{-1022}$  to  $2^{1023}$  (approximately  $10^{\pm 308}$ ). The 53-bit mantissa provides a precision equivalent to about 16 decimal digits.



# Example: Single and Double Precision

Represent the number **-307.1875** in IEEE single and double precision floating point number formats

**Step 1:** Convert Decimal number to binary

**Integer**

|   |     |   |   |
|---|-----|---|---|
| 2 | 307 |   |   |
| 2 | 153 | - | 1 |
| 2 | 76  | - | 1 |
| 2 | 38  | - | 0 |
| 2 | 19  | - | 0 |
| 2 | 9   | - | 1 |
| 2 | 4   | - | 1 |
| 2 | 2   | - | 0 |
|   | 1   | - | 0 |

Therefore 307 is 100110011

**Fraction**

$$\begin{array}{rcl} 0.1875 \times 2 & = 0.3750 & 0 \\ 0.375 \times 2 & = 0.750 & 0 \\ 0.75 \times 2 & = 1.50 & 1 \\ 0.5 \times 2 & = 1.0 & 1 \end{array}$$

Therefore 0.1875 is 0.0011

$$307.1875 = 100110011.0011$$

# Example: Single and Double Precision

---

Represent the number -307.1875 in IEEE single and double precision floating point number formats

## Step 2: Normalize the Number

$$-307.1875 = -100110011.0011$$

$$-100110011.0011 = -1.00110011 \times 2^8$$

## Step 3: Representation

### a. Single Precision

$$S = 1 ; E = 8 \quad E' = E + 127 = 8 + 127 = 135 = 10000111 ; M = 001100110011$$

| S     | E'       | M                  |
|-------|----------|--------------------|
| 1     | 10000111 | 00110011001100...0 |
| 1-Bit | 8-Bits   | 23-Bits            |

# Example: Single and Double Precision

---

Represent the number -307.1875 in IEEE single and double precision floating point number formats

**Step 2:** Normalize the Number

$$-307.1875 = -100110011.0011$$

$$-100110011.0011 = -1.001100110011 \times 2^8$$

**Step 3:** Representation

**b. Double Precision**

$$S = 1 ; E = 8 \quad E' = E + 1023 = 8 + 1023 = 1031 = 10000000111 ; M = 00110011001100...0$$

| S     | E'          | M                  |
|-------|-------------|--------------------|
| 1     | 10000000111 | 00110011001100...0 |
| 1-Bit | 11-Bits     | 52-Bits            |

# Example: Single and Double Precision

Represent -307.1875 in single-precision and double precision floating point representation format

Solution:

Step 1: Convert decimal number to binary

Integer:

$$\begin{array}{r} 2 \mid 307 \\ 2 \mid 153-1 \\ 2 \mid 76-1 \\ 2 \mid 38-0 \\ 2 \mid 19-0 \\ 2 \mid 9-1 \\ 2 \mid 4-1 \\ 2 \mid 2-0 \\ 2 \mid 1-0 \end{array}$$

$$\therefore 307 = 100110011$$

Fraction!

$$\begin{array}{ll} 0.1875 \times 2 = 0.3750 & 0 \\ 0.3750 \times 2 = 0.750 & 0 \\ 0.750 \times 2 = 1.50 & 1 \\ 0.50 \times 2 = 1.0 & 1 \end{array}$$

$$\therefore 0.1875 = 0.011$$

$$\therefore \text{Binary number of } 307.1875 = 100110011.0011$$

Step 2: Normalize the number

$$-100110011.0011 = -1.001100110011 \times 2^8$$

Step 3: Representation

② Single precision

$$S=1, E=8, M=001100110011$$

$$E = E' + 127 \Rightarrow 8 + 127 = 135 = 1000011_2$$

∴ number is

| S | E        | M                |
|---|----------|------------------|
| 1 | 10000111 | 0011001100110000 |

1-bit

8-bits

23 bits

③ Double precision

$$S=1, E'=E+1023 = 8+1023 = 1031_{10}$$

$$= 10000000111_2$$

∴ number is

| S | E          | M                    |
|---|------------|----------------------|
| 1 | 1000000111 | 00110011001100000000 |

1-bit

11-bits

52 bits

$$\begin{array}{r} 2 \mid 135 \\ 2 \mid 67-1 \\ 2 \mid 33-1 \\ 2 \mid 16-1 \\ 2 \mid 8-0 \\ 2 \mid 4-0 \\ 2 \mid 2-0 \\ 2 \mid 1-0 \end{array}$$
$$\begin{array}{r} 2 \mid 1031 \\ 2 \mid 515-1 \\ 2 \mid 257-1 \\ 2 \mid 128-1 \\ 2 \mid 64-0 \\ 2 \mid 32-0 \\ 2 \mid 16-0 \\ 2 \mid 8-0 \\ 2 \mid 4-0 \\ 2 \mid 2-0 \\ 2 \mid 1-0 \end{array}$$

# Example: Single and Double Precision

---

Represent the number 0.0625 in IEEE single and double precision floating point number formats

**Step 1:** Convert Decimal number to binary

**Integer Part = 0**

**Fraction Part**

|            |          |   |
|------------|----------|---|
| 0.0625 x 2 | = 0.1250 | 0 |
| 0.1250 x 2 | = 0.250  | 0 |
| 0.25 x 2   | = 0.50   | 0 |
| 0.5 x 2    | = 1.0    | 1 |

Therefore 0.0625 is 0.0001

0.0625 = 0.0001

# Example: Single and Double Precision

---

Represent the number 0.0625 in IEEE single and double precision floating point number formats

**Step 2:** Normalize the Number

$$0.0625 = 0.0001 = 1.0 \times 2^{-4}$$

**Step 3:** Representation

a. Single Precision

$$S = 0 ; E = -4 \quad E' = E + 127 = -4 + 127 = 123 = \textcolor{magenta}{01111011} ; M = \textcolor{blue}{0}$$

| S     | E'                              | M               |
|-------|---------------------------------|-----------------|
| 0     | $\textcolor{magenta}{01111011}$ | $000000000...0$ |
| 1-Bit | 8-Bits                          | 23-Bits         |

# Example: Single and Double Precision

---

Represent the number 0.0625 in IEEE single and double precision floating point number formats

**Step 2:** Normalize the Number

$$0.0625 = 0.0001 = 1.0 \times 2^{-4}$$

**Step 3:** Representation

**a. Double Precision**

$$S = 0 ; E = -4 \quad E' = E + 1023 = -4 + 1023 = 1019 = \textcolor{magenta}{01111111011} ; M = \textcolor{blue}{0}$$

| S     | E'                                 | M                                 |
|-------|------------------------------------|-----------------------------------|
| 0     | $\textcolor{magenta}{01111111011}$ | $\textcolor{blue}{000000000...0}$ |
| 1-Bit | 11-Bits                            | 52-Bits                           |

# Example: Single and Double Precision

Represent 0.0625 in single-precision and double precision formats.

Solution:

Step 1: Convert decimal number to binary

Integer part: 0

Fractional part:  $0.0625 \times 2 = 0.1250 = 0$   
 $0.1250 \times 2 = 0.250 = 0$   
 $0.25 \times 2 = 0.5 = 0$   
 $0.5 \times 2 = 1.0 = 1$   
 $\therefore 0.0625 = 0.0001$

Step 2: Normalizing the number

$$0.0001 = 1.0 \times 2^{-4}$$

Step 3: Representation

① Single precision

$$S=0 \quad E' = -4 + 127 = 123 \\ = 01111011_2$$

$$\begin{array}{r} 2 \longdiv{123} \\ 2 \longdiv{61} \\ 2 \longdiv{30} \\ 2 \longdiv{15} \\ 2 \longdiv{7} \\ 2 \longdiv{3} \\ 2 \longdiv{1} \end{array}$$

$$M = 0 \\ \therefore \text{The number is}$$

|   |             |             |
|---|-------------|-------------|
| 0 | 01111011    | 0000-----0  |
| S | E' (2-bits) | M (23-bits) |

② Double precision

$$S=0 \quad E' = -4 + 1023 = 1019 = 0111111011_2$$

$$M = 0$$

$\therefore$  The number is

|   |              |             |
|---|--------------|-------------|
| 0 | 0111111011   | 0000-----0  |
| S | E' (11-bits) | M (52-bits) |

Precision format

Solution:

Step 1: Convert decimal number to binary

Integer part:  $5 = 101_2$

Fractional part:  $0.2 \times 2 = 0.4$  0

$$0.4 \times 2 = 0.8 \quad 0$$

$$0.8 \times 2 = 1.6 \quad 1$$

$$0.6 \times 2 = 1.2 \quad 1$$

$$0.2 \times 2 = 0.4$$

$$\therefore 0.2 = 0.001100110011\ldots$$

$\therefore$  Binary number is  $101.001100110011\ldots$

Step 2: Normalize the number

$$101.001100110011\ldots = 1.01001100110011\ldots \times 2^2$$

Step 3: Representation

(a) Single precision

$$S=0 \quad E=2$$

$$\therefore E' = 2 + 127 = 129 = 10000001_2$$

$$M = 01001100110011\ldots$$

|   |             |                   |
|---|-------------|-------------------|
| 0 | 1000 0001   | 01001100110011... |
| S | E' (8-bits) | M (23-bits)       |

(b) Double precision

$$S=0 \quad E=2$$

$$\therefore E' = 2 + 1023 = 1025 = 1000 000 0001$$

|   |               |                   |
|---|---------------|-------------------|
| 0 | 1000 000 0001 | 01001100110011... |
| S | E' (52-bits)  | M (52-bits)       |

# Precision

# Unit-4

---

Arithmetic Operations on Floating-Point Numbers, Guard Bits and Truncation , Implementing Floating-Point Operations

# Arithmetic Operations on Floating-Point Numbers

---

## Add/Subtract Rule

1. Choose the number with the smaller exponent and shift its mantissa right a number of steps equal to the difference in exponents.
2. Set the exponent of the result equal to the larger exponent.
3. Perform addition/subtraction on the mantissas and determine the sign of the result.
4. Normalize the resulting value, if necessary

Example: Add  $1.110 \times 2^4$  and  $1.100 \times 2^2$

Alignment:  $1.100 \times 2^2$  has to be aligned to  $0.01100 \times 2^4$

Addition: Add two numbers to get  $10.0010 \times 2^4$

Normalize:  $1.00010 \times 2^5$

# Implementing Floating-Point Operations



# Arithmetic Operations on Floating-Point Numbers

---

## Multiply Rule

1. Add the exponents and subtract 127 to maintain the excess-127 representation.
2. Multiply the mantissas and determine the sign of the result.
3. Normalize the resulting value, if necessary

Multiplication of a pair of Floating Point numbers

$$X = m_x \times 2^a \quad Y = m_y \times 2^b$$
$$X * Y = (m_x + m_y) \times 2^{(a+b)}$$

Example:

Multiply  $X = 1.00 \times 2^{-2}$  and  $Y = -1.01 \times 2^{-1}$

Add Exponents:  $(-2) + (-1) = (-3)$  Subtract 127:  $(-3) - 127 = -130$

Multiply mantissa:  $1.00 * -1.01 = -1.010000$

Normalize:  $-1.0100 \times 2^{-130}$

# Arithmetic Operations on Floating-Point Numbers

---

## Divide Rule

1. Subtract the exponents and add 127 to maintain the excess-127 representation.
2. Divide the mantissas and determine the sign of the result.
3. Normalize the resulting value, if necessary

Divide of a pair of Floating Point numbers

$$X = m_x \times 2^a \quad Y = m_y \times 2^b$$

$$X / Y = (m_x / m_y) \times 2^{(a-b)}$$

Example:

Divide  $X = 1.0000 \times 2^{-2}$  and  $Y = -1.0100 \times 2^{-1}$

Subtract Exponents:  $(-2) - (-1) = (-1)$  Subtract 127:  $(-1)+127 = 126$

Divide mantissa:  $1.0000 / -1.0100 = -0.1101$

Result:  $-0.1101 \times 2^{126}$

Normalize:  $-1.101 \times 2^{125}$

# Rough Slide to explain: Guard bits

---

Example of Subtracting two FP numbers

$$\begin{array}{r} 2.95 \times 10^2 \\ -2.39 \times 10^0 \end{array}$$

We will allow two Guard digits

$$\begin{array}{r} 2 \quad . \quad 9 \quad 5 \quad \boxed{\phantom{0}} \quad \boxed{\phantom{0}} \quad \times \quad 10^2 \\ - \quad 0 \quad . \quad 0 \quad 2 \quad 3 \quad 9 \quad \times \quad 10^2 \\ \hline 2 \quad . \quad 9 \quad 2 \quad 6 \quad 1 \quad \times \quad 10^2 \end{array}$$

# Rough Slide to explain: Truncation

---

Removing guard bits in generating a final result requires that the extended mantissa be truncated to create a 24-bit number that approximates the longer version.

Three different Ways of Truncations:

1. Chopping

0.000000    0.000111

2. Von Neumann rounding

0.000000                0.000001    0.000010    0.000100    0.000111

3. Rounding

0.000000                0.000001    0.000010                0.000100    0.000111

# Guard Bits and Truncation

---

- Let us consider some important aspects of implementing the steps in the preceding algorithms. Although the mantissas of initial operands and final results are limited to 24 bits, including the implicit leading 1, it is important to retain extra bits, often called guard bits, during the intermediate steps. This yields maximum accuracy in the final results.
- Removing guard bits in generating a final result requires that the extended mantissa be truncated to create a 24-bit number that approximates the longer version. This operation also arises in other situations, for instance, in converting from decimal to binary numbers. We should mention that the general term rounding is also used for the truncation operation, but a more restrictive definition of rounding is used here as one of the forms of truncation. There are several ways to truncate. The simplest way is to remove the guard bits and make no changes in the retained bits. This is called **chopping**. Suppose we want to truncate a fraction from six to three bits by this method. All fractions in the range  $0.b_{-1}b_{-2}b_{-3}000$  to  $0.b_{-1}b_{-2}b_{-3}111$  are truncated to  $0.b_{-1}b_{-2}b_{-3}$ . The error in the 3-bit result ranges from 0 to 0.000111. In other words, the error in chopping ranges from 0 to almost 1 in the least significant position of the retained bits. In our example, this is the  $b_{-3}$  position. The result of chopping is a biased approximation because the error range is not symmetrical about 0.

# Guard Bits and Truncation (Contd...)

---

The next simplest method of truncation is **von Neumann rounding**. If the bits to be removed are all 0s, they are simply dropped, with no changes to the retained bits. However, if any of the bits to be removed are 1, the least significant bit of the retained bits is set to 1. In our 6-bit to 3-bit truncation example, all 6-bit fractions with  $b_{-4}b_{-5}b_{-6}$  not equal to 000 are truncated to  $0.b_{-1}b_{-2}1$ . The error in this truncation method ranges between  $-1$  and  $+1$  in the LSB position of the retained bits. Although the range of error is larger with this technique than it is with chopping, the maximum magnitude is the same, and the approximation is unbiased because the error range is symmetrical about 0.

Unbiased approximations are advantageous if many operands and operations are involved in generating a result, because positive errors tend to offset negative errors as the computation proceeds. Statistically, we can expect the results of a complex computation to be more accurate.

The third truncation method is a **rounding** procedure. Rounding achieves the closest approximation to the number being truncated and is an unbiased technique. The procedure is as follows: A 1 is added to the LSB position of the bits to be retained if there is a 1 in the MSB position of the bits being removed. Thus,  $0.b_{-1}b_{-2}b_{-3}1 \dots$  is rounded to  $0.b_{-1}b_{-2}b_{-3} + 0.001$ , and  $0.b_{-1}b_{-2}b_{-3}0 \dots$  is rounded to  $0.b_{-1}b_{-2}b_{-3}$ .

# Thanks for Listening

---