# Lecture 13 EE 421 / C\$ 425 Digital System Design

Spring 2023
Shahid Masud



## Topics

- Binary Array Multipliers
- Operation of Sequential Multiplier
- Control Circuits for Multipliers
- Reducing Registers in Sequential Multipliers
- Taking care of sign in Signed Multiplication
- Fractional Binary numbers
- QUIZ 3 Today



# Decimal Multiplication using Pencil and paper





Keep shifting right

Keep shifting left



# **Array Multipliers – Parallel and Serial forms**

$$X = \sum_{i=0}^{m-1} X_i \cdot 2^i$$

$$Y = \sum_{j=0}^{n-1} Y_j 2^j$$

$$P = X.Y = \sum_{i=0}^{m-1} X_i \ 2^i. \sum_{j=0}^{m-1} Y_j, 2^j$$

$$P = \sum_{i=0}^{m-1} \sum_{j=0}^{n-1} (X_i Y_j) 2^{i+j}$$

$$P = \sum_{k=0}^{m+n-1} P_k 2^k$$



## Complexity of Binary Array Multiplier

|      |          |                       |          | <b>X</b> <sub>3</sub> | X <sub>2</sub> | X <sub>1</sub> | X <sub>o</sub>   |
|------|----------|-----------------------|----------|-----------------------|----------------|----------------|------------------|
|      |          |                       |          | Y <sub>3</sub>        | Y <sub>2</sub> | Y <sub>1</sub> | $\mathbf{Y}_{0}$ |
|      |          |                       |          | $X_3Y_0$              | $X_2Y_0$       | $X_1Y_0$       | $X_0Y_0$         |
|      |          |                       | $X_3Y_1$ | $X_2Y_1$              | $X_1Y_1$       | $X_0Y_1$       | 0                |
|      |          | $X_3Y_2$              | $X_2Y_2$ | $X_1Y_2$              | $X_0Y_2$       | 0              | 0                |
|      | $X_3Y_3$ | $X_2Y_3$              | $X_1Y_3$ | $X_0Y_3$              | 0              | 0              | 0                |
| Cout | $P_6$    | <b>P</b> <sub>5</sub> | $P_4$    | $P_3$                 | $P_2$          | $P_1$          | $P_0$            |

How many AND gates?
How many Adders?
Identify longest Carry path?

**Complexity and Timing** 

For an n-bit x n-bit multiplier; We need:

n(n-2) full adders

n half adders

n<sup>2</sup> AND Gates

Worst Case Delay is (2n+1) C
Where C is the worst adder delay



## An Array Multiplier Cell

|      |                |                |                | A <sub>3</sub> | A <sub>2</sub> | $A_1$          | $A_0$          |
|------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|
|      |                |                |                | B <sub>3</sub> | B <sub>2</sub> | $B_1$          | $B_0$          |
|      |                |                |                | $A_3B_0$       | $A_2B_0$       | $A_1B_0$       | $A_0B_0$       |
|      |                |                | $A_3B_1$       | $A_2B_1$       | $A_1B_1$       | $A_0B_1$       | 0              |
|      |                | $A_3B_2$       | $A_2B_2$       | $A_1B_2$       | $A_0B_2$       | 0              | 0              |
|      | $A_3B_3$       | $A_2B_3$       | $A_1B_3$       | $A_0B_3$       | 0              | 0              | 0              |
| Cout | 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> |



# 4-Bit Array Multiplier connected as AND and ADD

|      |                |                |                | A <sub>3</sub> | A <sub>2</sub> | $A_1$          | $A_0$          |
|------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|
|      |                |                |                | B <sub>3</sub> | B <sub>2</sub> | $B_1$          | B <sub>0</sub> |
|      |                |                |                | $A_3B_0$       | $A_2B_0$       | $A_1B_0$       | $A_0B_0$       |
|      |                |                | $A_3B_1$       | $A_2B_1$       | $A_1B_1$       | $A_0B_1$       | 0              |
|      |                | $A_3B_2$       | $A_2B_2$       | $A_1B_2$       | $A_0B_2$       | 0              | 0              |
|      | $A_3B_3$       | $A_2B_3$       | $A_1B_3$       | $A_0B_3$       | 0              | 0              | 0              |
| Cout | 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> |





Embedded Systems Lab (EESL)

#### Array Multiplier Circuit Delays

**Building Block**  $B_{i}$ Sum\_in Cout Cin Full Adder Sum\_out I

Worst case delay path is shaded
This is Critical Path
LUMS



## Operation of Sequential Multiplier





#### Data Path Architecture of Sequential Mult







# STG for a 4 Bit Sequential Binary



Machine returns to Idle state after Completion of 4 bit multiplication



# Sequential Multiplier with Reduced Registers



STG of Reduced Register Sequential

Multiplier



#### **Example of a 4-bit Serial Parallel** Multiplier

Product Accumulator Register (8 + 1) bits



Shift the contents To the right after Every step

15



## **Example continued**

|   |   |   |   | 1 | 1 | 0 | 1    | Multiplicand                      |
|---|---|---|---|---|---|---|------|-----------------------------------|
|   |   |   | X | 1 | 0 | 1 | 1    | Multiplier                        |
|   |   |   |   | 1 | 1 | 0 | 1    |                                   |
|   |   |   | 1 | 1 | 0 | 1 | (X)— | → Shift Left by one               |
|   |   | 1 | 0 | 0 | 1 | 1 | 1    | Partial product after first step  |
|   |   | 0 | 0 | 0 | 0 | X | X    | Another shift left                |
|   |   | 1 | 0 | 0 | 1 | 1 | 1    | Partial product after second step |
|   | 1 | 1 | 0 | 1 | X | X | X    | Another shift left                |
| 1 | 0 | 0 | 0 | 1 | 1 | 1 | 1    | Partial product after final step  |
|   |   |   |   |   |   |   |      |                                   |

Answer =  $(10001111)_2 = (143)_{10}$ 



Embedded Systems Lab (EESL)

Multiplier Register
Operation Initial Conte

**Initial Contents of Accumulator** 

Multiplicand bit [0] is '1'

After Add operation

After Shift Right

**Next bit M = 1 hence Add** 

**After Add** 

**After Shift Right** 

Next bit M=0, hence Skip Add

operation

**After Shift Right** 

Next bit M=1, hence Add

**After Addition** 

After Shift Right, final answer





#### STG Control Diagram for this Multiplier





# Flexible STG for any no. of multiplicand bits





**Embedded Systems Lab (EESL)** 

Parallel-Serial Multiplier -





### Multiplication of **Signed Binary Numbers**

Case I: Negative Multiplicand, Positive Multiplier

Example: -3<sub>10</sub> x 6<sub>10</sub>

Sign-bit of the multiplicand must be extended to the word length of the final product before Operating on the 2's Complement words.

This sign-extended multiplicand is used when forming Partial products and accumulated sums.

The result of the multiplication is the 2's Complement of the Product. The final magnitude is found by taking 2's Complement. Bit Assignment: We assign 8 bits to both numbers.

The product will thus be 16 bits.

+3 = 0000 0011

Thus 2's Complement = -3 = 1111 1101

+6 = 0000 0110

| 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 1 |
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
|   |   |   |   |   |   |   | X | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 0 |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 1 | X |
| 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 1 | X | X |
| 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | 1 | 0 |

Remember: Sign Extension to maximum number of bits in datapath



### **Multiplication of Fractions**

#### Convert from decimal to binary $(\frac{3}{4})$

= 0.75 0.75 x 2 = 1.5, keep 1 0.5 x 2 = 1.0, keep 1 0 x 2 = 0 keep 0 And only zeros afterwards

$$= 2^{-1} + 2^{-2} + 0 + 0$$

= 0.1100; assigning four fractional bits

