

# Step 1

schematic of the inverter:



For pmos:

Width = (w\_p) \* 1

Length = 45ns

Where w\_p = 120ns, 180ns, and 240ns

For nmos:

Width = 120ns

Length = 45ns

At 120ns:

Falling delay = 5.617ps

Rising delay = 6.464ps

| Tphl - Tplh | / min (Tphl, Tplh) = 0.151

K-ratio = 0.869



At 180ns:

Falling delay = 6.242ps

Rising delay = 5.954ps

$$| T_{phl} - T_{plh} | / \min(T_{phl}, T_{plh}) = 0.048$$

**K-ratio = 1.048**



At 240ns:

Falling delay = 6.861ps

Rising delay = 5.707ps

| Tphl - Tplh | / min (Tphl, Tplh) = 0.202

K-ratio = 1.202



$| T_{ph1} - T_{plh} | / \min(T_{ph1}, T_{plh})$  at 180ns fulfills the requirement, which = **0.048** < 0.1, and the k ratio at 180ns is **1.048**

---

## Step 2

### For INV\_1X:

INV\_1X, INV\_1X\_in\_buffer and INV\_1X\_load all use the same schematic as following:



INV\_1X testbench schematic:



INV\_1X Falling delay: **8.817ps**



INV\_1X Rising delay: **9.520ps**



### For INV\_2X:

INV\_2X and INV\_2X\_load use the same schematic as following:



### INV\_2X testbench schematic:



**INV\_2X Falling delay: 9.931ps**



**INV\_2X Rising delay: 14.2699ps**



## For NAND2\_1X:

NAND2\_1X schematic:



NAND2\_1X testbench schematic:



input-output waveforms (function verification) :



NAND2\_1X (1,1) -> (0,1) Rising delay: 10.892ps



NAND2\_1X (1,1) -> (1,0) Rising delay: 9.886ps



NAND2\_1X (1,0) -> (1,1) Falling delay: 17.909ps



NAND2\_1X (0,1) -> (1,1) Falling delay: 20.979ps



Worst case delays NAND2\_1X(input = (A,B))

| Rising delay(ps)       |               | Falling delay(ps)      |               |
|------------------------|---------------|------------------------|---------------|
| (A,B) = (1,1) -> (0,1) | <b>10.892</b> | (A,B) = (0,1) -> (1,1) | <b>20.979</b> |
| (A,B) = (1,1) -> (1,0) | 9.886         | (A,B) = (1,0) -> (1,1) | 17.909        |

## For NAND2\_2X:

NAND2\_2X schematic:



NAND2\_2X testbench schematic:



input-output waveforms (function verification) :



NAND2\_2X (1,1) -> (0,1) Rising delay: 11.593ps



NAND2\_2X (1,1) -> (1,0) Rising delay: 11.085ps



NAND2\_2X (0,1) -> (1,1) Falling delay: 32.367ps



NAND2\_2X (1, 0) -> (1, 1) Falling delay: 29.149ps



Worst case delays NAND2\_2X(input = (A, B))

| Rising delay(ps)          |               | Falling delay(ps)         |               |
|---------------------------|---------------|---------------------------|---------------|
| (A, B) = (1, 1) -> (0, 1) | <b>11.593</b> | (A, B) = (0, 1) -> (1, 1) | <b>32.367</b> |
| (A, B) = (1, 1) -> (1, 0) | 11.085        | (A, B) = (1, 0) -> (1, 1) | 29.149        |

## For Nor2\_1X:

NOR2\_1X schematic:



NOR2\_1X testbench schematic:



input-output waveforms (function verification) :



NOR2\_1X (1,0) -> (0,0) Rising Delay: 19.021ps



NOR2\_1X (0,1) -> (0,0) Rising Delay:13.807ps



NOR2\_1X (0,0) -> (1,0) Falling Delay: 13.490ps



NOR2\_1X (0,0) -> (0,1) Falling Delay: 10.667ps



Worst case delays NOR2\_1X(input = (A,B))

| Rising delay(ps)       |               | Falling delay(ps)      |               |
|------------------------|---------------|------------------------|---------------|
| (A,B) = (1,0) -> (0,0) | <b>19.021</b> | (A,B) = (0,0) -> (1,0) | <b>13.490</b> |
| (A,B) = (0,1) -> (0,0) | 13.807        | (A,B) = (0,0) -> (0,1) | 10.667        |

## For Nor2\_2X:

NOR2\_2X schematic:



NOR2\_2X testbench schematic:



input-output waveforms (function verification) :



NOR2\_2X (1,0) -> (0,0) Rising Delay: 19.729ps



NOR2\_2X (0,1) -> (0,0) Rising Delay: 13.493ps



NOR2\_2X (0,0) -> (1,0) Falling Delay: 21.713ps



NOR2\_2X (0,0) -> (0,1) Falling Delay: 15.648ps



#### Worst case delays NOR2\_2X(input = (A,B))

| Rising delay(ps)       |               | Falling delay(ps)      |               |
|------------------------|---------------|------------------------|---------------|
| (A,B) = (1,0) -> (0,0) | <b>19.729</b> | (A,B) = (0,0) -> (1,0) | <b>21.713</b> |
| (A,B) = (0,1) -> (0,0) | 13.493        | (A,B) = (0,0) -> (0,1) | 15.648        |

I'm not sure which is the USER ID for Cadence Virtuoso, So I took screenshot of my VNCviewer window and my whole demo library

