

- In this assignment, I am tasked with designing a 32-bit ripple carry adder circuit. Below is the flow chart illustrating the structure of the 32-bit ripple carry adder, which comprises a collection of 32 full adders.



FIGURE 01: DIAGRAM OF 32-BIT RIPPLE CARRIER ADDER

- So far, I have initiated the design process by creating the design for a full adder. The information below presents the Boolean expression and the corresponding logic circuit for the full adder.

$$S_o = A_0 B_0 C_{in} + \overline{A_0} \overline{B_0} C_{in} + A_0 \overline{B_0} \overline{C_{in}} + \overline{A_0} B_0 \overline{C_{in}} = A_0 \oplus B_0 \oplus C_{in}$$

$$C_0 = A_0 B_0 + B_0 C_{in} + A_0 C_{in} = A_0 B_0 + C_{in}(A_0 + B_0)$$



FIGURE 02: LOGIC CIRCUIT OF THE FULL ADDER

- By replacing all the gates with CMOS components, the resulting circuit for a full adder is as follows.

### CMOS equivalent circuit for $C_0$



FIGURE 03: CMOS EQUIVALENT CIRCUIT FOR  $C_{out}$

### CMOS equivalent circuit for $S_0$

- To optimize the implementation and reduce the number of transistors required, let's rearrange the equation using  $\bar{C}_0$ . This rearrangement aims to simplify the circuitry and enhance efficiency while maintaining the functionality of the full adder.

| $A_0$ | $B_0$ | $C_{in}$ | $S_0$ | $C_0$ | $\bar{C}_0$ |
|-------|-------|----------|-------|-------|-------------|
| 0     | 0     | 0        | 0     | 0     | 1           |
| 0     | 0     | 1        | 1     | 0     | 1           |
| 0     | 1     | 0        | 1     | 0     | 1           |
| 0     | 1     | 1        | 0     | 1     | 0           |
| 1     | 0     | 0        | 1     | 0     | 1           |
| 1     | 0     | 1        | 0     | 1     | 0           |
| 1     | 1     | 0        | 0     | 1     | 0           |
| 1     | 1     | 1        | 1     | 1     | 0           |

$$S_0 = C_{in}\bar{C}_0 + B_0\bar{C}_0 + A_0\bar{C}_0 + A_0B_0C_{in}$$

$$S_0 = \bar{C}_0(C_{in} + B_0 + A_0) + A_0B_0C_{in}$$



FIGURE 04: CMOS EQUIVALEN CIRCUIT FOR SUM

### Full Adder (1-bit Adder)



FIGURE 05: SCHEMATIC DIAGRAM FOR THE FULL ADDER USING CMOS TECHNOLOGY



FIGURE 06: INPUT SIGNALS TO THE FULL ADDER



FIGURE 07: OUTPUT SIGNALS OF THE FULL ADDER

### Verifying the output

#### Input Signals



#### Output Signals



#### Cout



## Results of the simulation for full adder

| A <sub>0</sub> | B <sub>0</sub> | C <sub>in</sub> | Expected Output |                  | Results |                  |
|----------------|----------------|-----------------|-----------------|------------------|---------|------------------|
|                |                |                 | Sum             | C <sub>out</sub> | Sum     | C <sub>out</sub> |
| 1              | 0              | 0               | 1               | 0                | 1       | 0                |
| 0              | 0              | 0               | 0               | 0                | 0       | 0                |
| 1              | 1              | 0               | 0               | 1                | 0       | 1                |
| 0              | 0              | 0               | 0               | 0                | 0       | 0                |
| 1              | 1              | 1               | 1               | 1                | 1       | 1                |

- According to the input and output waveforms observed in the table, the simulation output aligns precisely with the expected results. Consequently, it can be concluded that the designed 2-bit adder circuit functions correctly.
- Now, the next step is to expand this circuit for a 2-bit adder.

## 2-bit Adder



FIGURE 07: SCHEMATIC DIAGRAM OF THE 2 BIT ADDER CIRCUIT

## Verifying the output



FIGURE 08: INPUT WAVEFORMS TO THE 2 BIT ADDER CIRCUIT





FIGURE 09: OUTPUT WAVEFORMS OF THE 2 BIT ADDER CIRCUIT

### Results of the simulation for 2-bit adder

| Time (us) | A <sub>0</sub> | B <sub>0</sub> | C <sub>0</sub> | Expected Output |                | Results        |                |
|-----------|----------------|----------------|----------------|-----------------|----------------|----------------|----------------|
|           |                |                |                | S <sub>0</sub>  | C <sub>1</sub> | S <sub>0</sub> | C <sub>1</sub> |
| 0-2       | 1              | 1              | 1              | 1               | 1              | 1              | 1              |
| 2-4       | 1              | 1              | 0              | 0               | 1              | 0              | 1              |
| 4-6       | 1              | 0              | 0              | 1               | 0              | 1              | 0              |
| 6-8       | 1              | 0              | 0              | 1               | 0              | 1              | 0              |
| 8-10      | 0              | 0              | 0              | 0               | 0              | 0              | 0              |

| Time (us) | A <sub>1</sub> | B <sub>1</sub> | C <sub>1</sub> | Expected Output |                | Results        |                |
|-----------|----------------|----------------|----------------|-----------------|----------------|----------------|----------------|
|           |                |                |                | S <sub>1</sub>  | C <sub>2</sub> | S <sub>1</sub> | C <sub>2</sub> |
| 0-2       | 1              | 1              | 1              | 1               | 1              | 1              | 1              |
| 2-4       | 1              | 1              | 1              | 1               | 1              | 1              | 1              |
| 4-6       | 0              | 1              | 0              | 1               | 0              | 1              | 0              |
| 6-8       | 0              | 1              | 0              | 1               | 0              | 1              | 0              |
| 8-10      | 1              | 0              | 0              | 1               | 0              | 1              | 0              |

- Based on the provided table, it is evident that the expected values and the simulation results align perfectly for the above case. Therefore, it is reasonable to proceed with expanding this circuit to an 8-bit configuration.

## 8-bit Adder

- Since the schematic diagram for the 8-bit adder is extensive, it is attached as a PDF within the zip file. Let's proceed to verify the output of the 8-bit ripple carry adder.





**FIGURE 10: INPUT WAVEFORMS TO THE 8 BIT ADDER CIRCUIT**





FIGURE 10: INPUT WAVEFORMS OF THE 8 BIT ADDER CIRCUIT

Results of the simulation for 8-bit adder

| Time<br>(us) | A <sub>0</sub> | B <sub>0</sub> | C <sub>0</sub> | Expected Output |                | Results        |                |
|--------------|----------------|----------------|----------------|-----------------|----------------|----------------|----------------|
|              |                |                |                | S <sub>0</sub>  | C <sub>1</sub> | S <sub>0</sub> | C <sub>1</sub> |
| 0-2          | 1              | 1              | 1              | 1               | 1              | 1              | 1              |
| 2-4          | 1              | 1              | 0              | 0               | 1              | 0              | 1              |
| 4-6          | 1              | 0              | 0              | 0               | 0              | 1              | 0              |

| Time<br>(us) | A <sub>1</sub> | B <sub>1</sub> | C <sub>1</sub> | Expected Output |                | Results        |                |
|--------------|----------------|----------------|----------------|-----------------|----------------|----------------|----------------|
|              |                |                |                | S <sub>1</sub>  | C <sub>2</sub> | S <sub>1</sub> | C <sub>2</sub> |
| 0-2          | 1              | 1              | 1              | 1               | 1              | 1              | 1              |
| 2-4          | 1              | 1              | 1              | 1               | 1              | 1              | 1              |
| 4-6          | 0              | 1              | 0              | 1               | 0              | 1              | 0              |

| Time<br>(us) | A <sub>2</sub> | B <sub>2</sub> | C <sub>2</sub> | Expected Output |                | Results        |                |
|--------------|----------------|----------------|----------------|-----------------|----------------|----------------|----------------|
|              |                |                |                | S <sub>2</sub>  | C <sub>3</sub> | S <sub>2</sub> | C <sub>3</sub> |
| 0-2          | 1              | 0              | 1              | 0               | 1              | 0              | 1              |
| 2-4          | 1              | 1              | 1              | 1               | 1              | 1              | 1              |
| 4-6          | 1              | 1              | 0              | 0               | 1              | 0              | 1              |

| Time<br>(us) | A <sub>3</sub> | B <sub>3</sub> | C <sub>3</sub> | Expected Output |                | Results        |                |
|--------------|----------------|----------------|----------------|-----------------|----------------|----------------|----------------|
|              |                |                |                | S <sub>3</sub>  | C <sub>4</sub> | S <sub>3</sub> | C <sub>4</sub> |
| 0-2          | 0              | 1              | 1              | 0               | 1              | 0              | 1              |
| 2-4          | 1              | 1              | 1              | 1               | 1              | 1              | 1              |
| 4-6          | 1              | 1              | 1              | 1               | 1              | 1              | 1              |

| Time<br>(us) | A <sub>4</sub> | B <sub>4</sub> | C <sub>4</sub> | Expected Output |                | Results        |                |
|--------------|----------------|----------------|----------------|-----------------|----------------|----------------|----------------|
|              |                |                |                | S <sub>4</sub>  | C <sub>5</sub> | S <sub>4</sub> | C <sub>5</sub> |
| 0-2          | 1              | 0              | 1              | 0               | 1              | 0              | 1              |
| 2-4          | 1              | 1              | 1              | 1               | 1              | 1              | 1              |
| 4-6          | 1              | 1              | 1              | 1               | 1              | 1              | 1              |

| Time<br>(us) | A <sub>5</sub> | B <sub>5</sub> | C <sub>5</sub> | Expected Output |                | Results        |                |
|--------------|----------------|----------------|----------------|-----------------|----------------|----------------|----------------|
|              |                |                |                | S <sub>5</sub>  | C <sub>6</sub> | S <sub>5</sub> | C <sub>6</sub> |
| 0-2          | 0              | 1              | 1              | 0               | 1              | 0              | 1              |
| 2-4          | 1              | 1              | 1              | 1               | 1              | 1              | 1              |
| 4-6          | 1              | 1              | 1              | 1               | 1              | 1              | 1              |

| Time<br>(us) | A <sub>6</sub> | B <sub>6</sub> | C <sub>6</sub> | Expected Output |                | Results        |                |
|--------------|----------------|----------------|----------------|-----------------|----------------|----------------|----------------|
|              |                |                |                | S <sub>6</sub>  | C <sub>7</sub> | S <sub>6</sub> | C <sub>7</sub> |
| 0-2          | 1              | 0              | 1              | 0               | 1              | 0              | 1              |
| 2-4          | 1              | 1              | 1              | 1               | 1              | 1              | 1              |
| 4-6          | 1              | 1              | 1              | 1               | 1              | 1              | 1              |

| Time<br>(us) | A <sub>7</sub> | B <sub>7</sub> | C <sub>7</sub> | Expected Output |                | Results        |                |
|--------------|----------------|----------------|----------------|-----------------|----------------|----------------|----------------|
|              |                |                |                | S <sub>7</sub>  | C <sub>8</sub> | S <sub>7</sub> | C <sub>8</sub> |
| 0-2          | 0              | 1              | 1              | 0               | 1              | 0              | 1              |
| 2-4          | 1              | 1              | 1              | 1               | 1              | 1              | 1              |
| 4-6          | 1              | 1              | 1              | 1               | 1              | 1              | 1              |

- According to the tables and the output waveforms, it is evident that the expected values align precisely with the resulting values for every considered condition. Consequently, we can conclude that the 8-bit ripple carry adder is functioning properly.
- Similarly, we can connect 32 full adders to create the 32-bit ripple carry adder.