| 341312304 | שרה גריפית |
|-----------|------------|
| 207223066 | טל שמיר    |

#### 2.1: Implementation of 2->1 Mux

A truth table for a mux with two inputs (d0 and d1), one selector (sel), and one output (z):

| sel | d0 | d1 | Z |
|-----|----|----|---|
| 0   | 0  | 0  | 0 |
| 0   | 0  | 1  | 0 |
| 0   | 1  | 1  | 1 |
| 0   | 1  | 0  | 1 |
| 1   | 0  | 0  | 0 |
| 1   | 0  | 1  | 1 |
| 1   | 1  | 1  | 1 |
| 1   | 1  | 0  | 0 |

Let: w = sel, x = d0, y = d1

The following is the Karnaugh Map that corresponds to the above truth table:

| w\xy | 00 | 01 | 11 | 10 |
|------|----|----|----|----|
| 0    | 0  | 0  | 1  | 1  |
| 1    | 0  | 1  | 1  | 0  |

From the above truth table, we get the following minimal expression for mux: z = wy + w'x

Using the given gates, this is an implementation of mux with six logic gates:



The following table describes the times for the different gates:

|       | t <sub>PDLH</sub> | t <sub>PDHL</sub> |
|-------|-------------------|-------------------|
| NAND2 | 4                 | 1                 |
| OR2   | 1                 | 2                 |
| XNOR2 | 3                 | 3                 |

The following table describes the  $t_{PD}$  of each possible path throughout the implementation above:

| Path                        | d0     | d1     | sel    | t <sub>PD</sub>                                                                     |
|-----------------------------|--------|--------|--------|-------------------------------------------------------------------------------------|
|                             | 0 -> 1 | 0      | 0      | $t_{PDHL}(g2) + t_{PDLH}(g3) + t_{PDLH}(g6) = 1 + 4 + 1 = 6$                        |
| d0 -> g2 -> g3 -> g6        | 0 -> 1 | 1      | 0      | $t_{PDHL}(g2) + t_{PDLH}(g3) + t_{PDLH}(g6) = 1 + 4 + 1 = 6$                        |
|                             | 1->0   | 0      | 0      | $t_{PDLH}(g2) + t_{PDHL}(g3) + t_{PDHL}(g6) = 4 + 1 + 2 = 7$                        |
|                             | 1->0   | 1      | 0      | $t_{PDLH}(g2) + t_{PDHL}(g3) + t_{PDHL}(g6) = 4 + 1 + 2 = 7$                        |
|                             | 1      | 0 -> 1 | 1      | $t_{PDHL}(g4) + t_{PDLH}(g5) + t_{PDLH}(g6) = 1 + 4 + 1 = 6$                        |
| d1 > g1 > g5 > g6           | 0      | 0 -> 1 | 1      | $t_{PDHL}(g4) + t_{PDLH}(g5) + t_{PDLH}(g6) = 1 + 4 + 1 = 6$                        |
| d1 -> g4 -> g5 -> g6        | 1      | 1->0   | 1      | $t_{PDLH}(g4) + t_{PDHL}(g5) + t_{PDHL}(g6) = 4 + 1 + 2 = 7$                        |
|                             | 0      | 1->0   | 1      | $t_{PDLH}(g4) + t_{PDHL}(g5) + t_{PDHL}(g6) = 4 + 1 + 2 = 7$                        |
| sel -> g1 -> g2 -> g3 -> g6 | 1      | 0      | 0 -> 1 | $t_{PDIIL}(g1) + t_{PDLII}(g2) + t_{PDIIL}(g3) + t_{PDIIL}(g6) = 1 + 4 + 1 + 2 = 8$ |
| (longest path to z)         | 1      | 0      | 1 -> 0 | $t_{PDLH}(g1) + t_{PDHL}(g2) + t_{PDLH}(g3) + t_{PDLH}(g6) = 4 + 1 + 4 + 1 = 10$    |
| sel -> g4 -> g5 -> g6       | 0      | 1      | 0 -> 1 | $t_{PDHL}(g4) + t_{PDLH}(g5) + t_{PDLH}(g6) = 1 + 4 + 1 = 6$                        |
| (No change on longest path) | 0      | 1      | 1 -> 0 | $t_{PDLH}(g4) + t_{PDHL}(g5) + t_{PDHL}(g6) = 4 + 1 + 2 = 7$                        |

#### 2.2: Implementation of 4-1 mux using 2-1 mux:

Implementation of 4-1 mux using three 2-1 selectors:



The following is a table of the times of the different gates:

|       | t <sub>PDLH</sub> | t <sub>PDHL</sub> |
|-------|-------------------|-------------------|
| NAND2 | 4                 | 4                 |
| OR2   | 2                 | 2                 |
| XNOR2 | 3                 | 3                 |

The following is a table showing the calculations of  $t_{PD}$  for changes on a selected input:

| Path                              | d0     | d1 | d2 | d3 | sel[0] | sel[1] | t <sub>PD</sub> |
|-----------------------------------|--------|----|----|----|--------|--------|-----------------|
| d0-> NAND-> NAND-> OR-> NAND-> OR | 0 -> 1 | 0  | 0  | 0  | 0      | 0      | 20              |
|                                   | 1->0   | 0  | 0  | 0  | 0      | 0      | 20              |

Calculations for first change: 
$$t_{PDHL}(\textit{NAND}) + t_{PDLH}(\textit{NAND}) + t_{PDLH}(\textit{NA$$

Calculations for second change:

$$\begin{aligned} t_{PDLH}(\textit{NAND}) \ + \ t_{PDHL}(\textit{NAND}) \ + \ t_{PDHL}(\textit{OR}) \ + \ t_{PDLH}(\textit{NAND}) \ + \ t_{PDHL}(\textit{NAND}) \ + \ t_{PDHL}(\textit{NAND}) \ + \ t_{PDHL}(\textit{NAND}) \end{aligned}$$

### 2.3: Implementation of Full Adder/Subtracter using 9 logic gates:



The following is a table of the times used for the calculations:

|       | t <sub>PDLH</sub> | t <sub>PDHL</sub> |
|-------|-------------------|-------------------|
| NAND2 | 4                 | 4                 |
| OR2   | 2                 | 2                 |
| XNOR2 | 3                 | 3                 |

The following is a table showing the maximum time for each input:

| Max Path                                         | а      | a_ns   | b    | cin  | t <sub>pd</sub>                                                                            |
|--------------------------------------------------|--------|--------|------|------|--------------------------------------------------------------------------------------------|
| a -> XNOR -> NAND -><br>NAND -> OR -> cout       | 0 -> 1 | 0      | 1    | 0    | $t_{PDHL}(XNOR) + t_{PDLH}(NAND) + t_{PDHL}(NAND) + t_{PDHL}(OR)$ $= 3 + 4 + 4 + 2 = 13$   |
| a -> XNOR -> XNOR -><br>s                        | 0 -> 1 | 0      | 0    | 0    | $t_{PDHL}(XNOR) + t_{PDLH}(XNOR) = 3 + 3 = 6$                                              |
| a_ns -> XNOR -><br>NAND -> NAND -> OR<br>-> cout | 0      | 0 -> 1 | 1    | 0    | $t_{PDHL}(XNOR) + t_{PDLH}(NAND) + t_{PDHL}(NAND) + t_{PDHL}(OR)$ $= 3 + 4 + 4 + 2 = 13$   |
| b -> OR -> NAND -><br>NAND -> OR -> cout         | 0      | 0      | 1->0 | 0    | $t_{PDHL}(OR) + t_{PDHL}(NAND) + t_{PDHL}(NAND) + t_{PDHL}(OR)$ $= 2 + 4 + 4 + 2 = 12$     |
| b->XNOR->XNOR-><br>s                             | 0      | 0      | 1->0 | 0    | $t_{PDLH}(XNOR) + t_{PDHL}(XNOR) = 3 + 3 = 6$                                              |
| cin -> OR -> NAND -><br>NAND -> OR -> cout       | 0      | 0      | 0    | 1->0 | $t_{PDIIL}(OR) + t_{PDLII}(NAND) + t_{PDIIL}(NAND) + t_{PDIIL}(OR)$ $= 2 + 4 + 4 + 2 = 12$ |
| cin -> XNOR -> s                                 | 0      | 0      | 0    | 1->0 | $t_{PDHL}(XNOR) = 3$                                                                       |

2.4: Implementation of ALU using one mux, one full adder/subtracter, and 5 logic gates:



The following is a table showing the maximum time for each input and output:

| Max Path                            | а         | b     | cin  | op[0] | op[1] | t <sub>PD</sub>                                                                                                                             |
|-------------------------------------|-----------|-------|------|-------|-------|---------------------------------------------------------------------------------------------------------------------------------------------|
| a -><br>XNOR -><br>NAND-<br>>MUX->s | 0 ->      | 0     | 0    | 1     | 0     | $t_{PDHL}(XNOR) + t_{PDLH}(NAND) + 2(t_{PDHL}(NAND) + t_{PDLH}(NAND) + t_{PDLH}(OR))$ $= 3 + 4 + 2(4 + 4 + 2) = 27$                         |
| a -> FA/S<br>-> cout                | 0 -><br>1 | 1     | 0    | 1     | 0     | $t_{PDHL}(XNOR) + t_{PDLH}(NAND) + t_{PDHL}(NAND) + t_{PDHL}(OR)$<br>= 3 + 4 + 4 + 2 = 13                                                   |
| b-><br>XNOR-><br>NAND-<br>>MUX->s   | 0         | 1-> 0 | 0    | 1     | 0     | $t_{PDIH}(XNOR) + t_{PDHL}(NAND) + 2(t_{PDIH}(NAND) + t_{PDHL}(NAND) + t_{PDHL}(NAND) + t_{PDHL}(OR))$ = 3 + 3 + 4 + 4 + 2 + 4 + 4 + 2 = 27 |
| b -> FA/S<br>-> cout                | 0         | 1->0  | 0    | 1     | 0     | $t_{PDHL}(OR) + t_{PDHL}(NAND) + t_{PDHL}(NAND) + t_{PDHL}(OR)$ $= 2 + 4 + 4 + 2 = 12$                                                      |
| cin -><br>FA/S-><br>Mux -> s        | 0         | 0     | 0->1 | 1     | 1     | $t_{PDLII}(XNOR) + 2(t_{PDIIL}(NAND) + t_{PDLII}(NAND) + t_{PDLII}(OR))$<br>= 3 + 2(4 + 4 + 2) = 23                                         |

| cin -><br>FA/S-><br>cout            | 0 | 0 | 1->0 | 1    | 0    | $t_{PDHL}(OR) + t_{PDHL}(NAND) + t_{PDHL}(NAND) + t_{PDHL}(OR)$ $= 2 + 4 + 4 + 2 = 12$                        |
|-------------------------------------|---|---|------|------|------|---------------------------------------------------------------------------------------------------------------|
| op[0] -><br>Mux -> s                | 0 | 0 | 0    | 1->0 | 0    | $t_{PDLII}(NAND) + 2\left(t_{PDIIL}(NAND) + t_{PDLII}(NAND) + t_{PDLII}(OR)\right)$ $= 4 + 2(4+4+2) = 24$     |
| op[0]-><br>NAND-><br>FA/s-><br>cout | 0 | 1 | 0    | 1->0 | 1    | $t_{PDLH}(NAND) + t_{PDHL}(XNOR) + t_{PDLH}(NAND) + t_{PDHL}(NAND) + t_{PDLH}(OR)$ $= 4 + 3 + 4 + 4 + 2 = 17$ |
| op[1]-><br>Mux->s                   | 0 | 0 | 0    | 0    | 0->1 | $t_{PDIIL}(NAND) + t_{PDIIL}(NAND) + t_{PDIIL}(NAND) + t_{PDIIL}(OR) = $ $4 + 4 + 4 + 2 = 14$                 |

 $2.5\colon The following is an implementation of an ALU with 64-bit data inputs.$ 



| Max Path          | а    | b   | cin | op[0]  | op[1] | t <sub>PD</sub>                                                                                        |
|-------------------|------|-----|-----|--------|-------|--------------------------------------------------------------------------------------------------------|
| op[0] -> cout0 -> | 1000 | 001 | 0   | 0 -> 1 | 1     | $t_{PD}(op\lfloor 0\rfloor - > cout0) + 62t_{PD}(cin - > cout) + t_{PD}(cin63 - > s\lfloor 63\rfloor)$ |
| cin1 -> cout1 ->> |      |     |     |        |       | $= 17 + 62 \cdot 12 + 23 = 784$                                                                        |
| cin63 ->s[63]     |      |     |     |        |       |                                                                                                        |

### 3.3: Testbench of MUX4:



We defined a wait time of 25 ps in our testbench, and as seen in the photo the output changes after 20 ps each time. This change matches our calculations from question 2.2. Until 20 ps, the output z was undefined (value of x) in accordance with our calculations from before. After 20 ps, the output changed to the value of 0, according to the initial input received (all inputs are 0). At 25 ps, we changed the input and only 20 ps later, at the time 45 ps, the output changed. Lastly, at the time 50 ps, we changed the input again (back to 0) and the output changed again at the time 70 ps, again with a delay of 20 ps.

#### 3.5: Testbench of FAS:



We defined a wait time of 20 ps for our testbench. As seen in the photo, the outputs s and cout start off uninitialized (value of x). After 6 ps, s changes to match the input, and after 13 ps cout changes accordingly. These times match our calculations from question 2.3. At the time 20 ps the input a changes from 0 to 1, and at the time 26 ps, s changes accordingly. Cout changes at the time 33 ps. At the time 40 ps, we change a back to 0. At the time 46 ps s changes, and at the time 53 ps cout changes. At 60 ps, the value of a\_ns is changed, and s is no longer affected. At 73 ps cout changes according to the new value of a\_ns which matches our calculations. At the time 80 ps, we changed a\_ns back, and cout changed after a delay of 13 ps.

#### 3.8: Testbench of ALU64bit:



In our testbench we defined a waiting period of 900 ps. At the time 40 ps, the values s and cout are initialized. At time 900 ps, the input is changed, and at the time 1684 ps, the value of s changes accordingly (cout has no change in value). This matches our previous calculations of the maximum tpd it takes for the output s to change (784 ps).