

**Name – SAI POOJITH (2025122010)**

**Assignment – 3**

**VLSI DESIGN**

1-A

Netlist used



```
1 * Pseudo-NMOS Inverter VTC
2 .include TSMC_180nm.txt
3 .param Wn = 0.27u *(4/3)
4 .param Wp = Wn/2
5 .param L  = 0.18u
6 .param Cload = 10f
7 .param VDD = 1.8
8 .subckt pseudo_nmox in out vdd gnd Wn={Wn} Wp={Wp} L=
9 M1}out 0 vdd vdd CMOS W={Wp} L={L}
10 M2 out in gnd gnd CMOSN W={Wn} L={L}
11 .ends pseudo_nmox
12 VDD vdd gnd {VDD}
13 Vin in gnd 0
14 Xinv in out vdd gnd pseudo_nmox Wn={Wn} Wp={Wp} L={L}
15 Cload out 0 {Cload}
16 .control
17 dc Vin 0 1.8 0.01
18 run
19 set curplottitle="mididoddisaipoojith-2025122010-1-A"
20 plot v(out) vs v(in)
21 .endc
22 .end
23
```

simulation data



Pseudo-NMOS inverter - VTC

In a Pseudo-NMOS inverter, the PMOS transistor is always ON because its gate is permanently tied to ground.

SO,

1. When the input  $V_{in} = 0$ :  
The NMOS is OFF, and the PMOS pulls the output to  $V_{DD}$  (logic HIGH).  
Only a small leakage current flows, resulting in negligible static power dissipation.
2. When the input  $V_{in} = V_{DD}$ :  
The NMOS is ON and the PMOS is also ON, so both transistors conduct simultaneously.  
A direct path from  $V_{DD}$  to ground exists, causing a continuous static current  $I_{DD,static}$ .  
This leads to static power dissipation.

Because the PMOS never turns OFF completely, static current exists whenever the output is low, even when the circuit is not switching. As a result, the output never reaches exactly 0 V but settles slightly above ground.

This is the main disadvantage of pseudo-NMOS logic—it consumes static power even in steady state.

1-B

Netlist used

```
1 * Pseudo-NMOS Inverter Transient Simulation
2 .include TSMC_180nm.txt
3 .param Wn = 0.27u *(4/3)
4 .param Wp = Wn/2
5 .param L = 0.18u
6 .param Cload = 10f
7 .param VDD = 1.8
8 .subckt pseudo_nmos in out vdd gnd Wn={Wn} Wp={Wp} L=
9 M1}out 0 vdd vdd CMOSP W={Wp} L={L}
10 M2 out in gnd gnd CMOSN W={Wn} L={L}
11 .ends pseudo_nmos
12 VDD vdd gnd {VDD}
13 Vin in gnd PULSE(0 {VDD} 1n 1n 1n 2.5n 5n)
14 Xinv in out vdd gnd pseudo_nmos Wn={Wn} Wp={Wp} L={L}
15 Cload out gnd {Cload}
16 .control
17 tran 0.01n 10n
18 set curplottitle="mididoddisaipoojith-2025122010-1-B"
19 plot v(in) v(out)
20 plot -i(VDD)
21 .endc
22 .end
```

simulation data



consumes static power



2-A

## Netlist used

```

1 * NMOS Pass-Transistor 2:1 MUX (No Weak Keeper)
2 .include TSMC_180nm.txt
3 .param VDD = 1.8
4 .param Wn = 0.27u
5 .param Wp = 0.54u
6 .param L = 0.18u
7 .param Wpass = 0.27u
8 .param Cload = 10f
9 .subckt cmos_inv in out vdd gnd Wn={Wn} Wp={Wp} L={L}
10 Mp out in vdd gnd CMOSP W={Wp} L={L}
11 Mn out in gnd gnd CMOSN W={Wn} L={L}
12 .ends cmos_inv
13 .subckt mux2to1 a b sel1 out vdd gnd Wpass={Wpass} L={L}
14 Mp1 sel_bar sel vdd vdd CMOSP W={Wp} L={L}
15 Mn1 sel_bar sel gnd gnd CMOSN W={Wn} L={L}
16 Ma out sel a gnd CMOSN W={Wpass} L={L}
17 Mb out sel_bar b gnd CMOSN W={Wpass} L={L}
18 .ends mux2to1
19 VDD vdd gnd {VDD}
20 Va a gnd VDD
21 Vb b gnd 0
22 Vsel sel gnd PULSE(0 {VDD} 2.5n 0.in 0.in 3n 6n)
23 X1 a b sel1 mux_out vdd gnd mux2to1 Wpass={Wpass} L={L}
24 X2 mux_out mux_out_inv vdd gnd cmos_inv Wn={Wn} Wp={Wp} L={L}
25 Cload mux_out_inv gnd {Cload}
26 .control
27 tran 0.01n 20n
28 set curplottitle="mididoddisaipoojith-2025122010-2-A"
29 plot v(sel) v(a) v(b)
30 plot v(mux_out) v(mux_out_inv)
31 plot -i(VDD)
32 meas tran Trise TRIG v(mux_out_inv) VAL=0.18 RISE=1 TARG v(mux_out_inv) VAL=1.62 RISE=
33 #meas tran Tfall TRIG v(mux_out_inv) VAL=1.62 FALL=1 TARG v(mux_out_inv) VAL=0.18 FALL=
34 lendc
35 .end
36

```

## simulation data





```
No. of Data Rows : 2044
trise           = 1.398714e-10
tfall           = 3.186693e-10
ngspice 1 ->
```

### 2 input multiplexor (without Weak-Keeper)



In an NMOS pass-transistor 2:1 MUX, the output node does not always achieve full logic levels because NMOS transistors can only pass a strong '0' but degrade a '1' by a threshold voltage drop ( $V_{DD} - V_{TN}$ ). As a result, when a logic HIGH is passed, the MUX output may only reach  $V_{DD} - V_{TN}$  instead of the full  $V_{DD}$ . By connecting a CMOS inverter at the MUX output, the degraded logic levels are restored, ensuring that the output swings fully between 0 V and  $V_{DD}$ , providing proper logic levels for subsequent stages.

2-B

## Netlist used

```
1 * NMOS Pass-Transistor 2:1 MUX (With Weak Keeper)
2 .include TSMC_180nm.txt
3 .param VDD      = 1.8
4 .param Wn       = 0.27u
5 .param Wp       = 0.54u
6 .param L        = 0.18u
7 .param Wpass    = 0.27u
8 .param Cload    = 10f
9 .param Wp_keep  = 0.14u
10 .subckt cmos_inv in out vdd gnd Wn={Wn} Wp={Wp} L={L}
11 Mp out in vdd vdd CMOSP W={Wp} L={L}
12 Mn out in gnd gnd CMOSN W={Wn} L={L}
13 .ends cmos_inv
14 .subckt mux2to1 a b sel out vdd gnd Wpass={Wpass} L={L}
15 Mp1 sel_bar sel vdd vdd CMOSP W={Wp} L={L}
16 Mn1 sel_bar sel gnd gnd CMOSN W={Wn} L={L}
17 Ma out sel a gnd CMOS W={Wpass} L={L}
18 Mb out sel_bar b gnd CMOSN W={Wpass} L={L}
19 .ends mux2to1
20 VDD vdd gnd {VDD}
21 Va a gnd VDD
22 Vb b gnd 0
23 Vsel sel gnd PULSE(0 {VDD} 2.5n 0.1n 0.1n 3n 6n)
24 X1 a b sel mux_out vdd gnd mux2to1 Wpass={Wpass} L={L}
25 X2 mux_out mux_out_inv vdd gnd cmos_inv Wn={Wn} Wp={Wp} L={L}
26 Mkeeper mux_out mux_out_inv vdd vdd CMOSP W={Wp_keep} L={L}
27 Cload mux_out_inv gnd {Cload}
28 .control
29 tran 0.01n 20n
30 set curplottitle="mididoddisaipoojith-2025122010-2-B"
31 plot v(sel) v(a) v(b)
32 plot v(mux_out) v(mux_out_inv)
33 plot -i(VDD)
34 meas tran Trise TRIG v(mux_out_inv) VAL=0.18 RISE=1 TARG v(mux_out_inv) VAL=1.62 RISE=
35 meas tran Tfall TRIG v(mux_out_inv) VAL=1.62 FALL=1 TARG v(mux_out_inv) VAL=0.18 FALL=
36 iendc
37 .end
38
```

## simulation data





```
No. of Data Rows : 2044
trise           = 1.465586e-10
tfall           = 2.376982e-10
ngspice 1 ->
```

2 input multiplexor (with Weak-Keeper)



In the NMOS pass-transistor MUX without a keeper, the output node often reaches only  $VDD - VTN$  instead of a full logic HIGH. So, the NMOS transistor operates in the linear region while the PMOS remains partially ON in saturation, creating a direct path from VDD to GND and resulting in static current. By adding a weak keeper at the MUX output, the node is pulled up to full VDD. This ensures that the inverter input sees a proper logic HIGH, turning the PMOS completely OFF and the NMOS completely ON, thereby eliminating the DC path and reducing the static current to nearly zero.

3

### Netlist used

```

1  * NMOS Pass-Transistor 2:1 MUX
2 .include TSMC_180nm.txt
3 .param VDD = 1.8
4 .param L = 0.18u
5 .param W = 1.8u
6 .param Wn_inv= 4*W
7 .param Wp_inv= (6*W-Wn_inv)
8 .param Wn = W
9 .param Wp = 2*W
10 .param Wpass = W
11 .subckt cmos_inv in out vdd gnd Wn_inv={Wn_inv} Wp_inv={Wp_inv} L={L}
12 Mp out in vdd vdd CMOSP W={Wp_inv} L={L} AS={Wp_inv*0.5u} AD={Wp_inv*0.5u} PS={2*(Wp_inv+L)} PD={2*(Wp_inv+L)}
13 Mb out gnd gnd CMOSN W={Wn_inv} L={L} AS={Wn_inv*0.5u} AD={Wn_inv*0.5u} PS={2*(Wn_inv+L)} PD={2*(Wn_inv+L)}
14 Lends cmos_inv
15 .subckt mux2to1 a b sel out vdd gnd Wpass={Wpass} L={L} Wn={Wn} Wp={Wp}
16 Mp1 sel_bar sel vdd vdd CMOSP W={Wp} L={L} AS={Wp*0.5u} AD={Wp*0.5u} PS={2*(Wp+L)} PD={2*(Wp+L)}
17 Mn1 sel_bar sel gnd gnd CMOSN W={Wn} L={L} AS={Wn*0.5u} AD={Wn*0.5u} PS={2*(Wn+L)} PD={2*(Wn+L)}
18 Ma out sel a gnd CMOSN W={Wpass} L={L} AS={Wpass*0.5u} AD={Wpass*0.5u} PS={2*(Wpass+L)} PD={2*(Wpass+L)}
19 Mb out sel_bar b gnd CMOSN W={Wpass} L={L} AS={Wpass*0.5u} AD={Wpass*0.5u} PS={2*(Wpass+L)} PD={2*(Wpass+L)}
20 .ends mux2to1
21 VDD vdd gnd {VDD}
22 Va a gnd VDD
23 Vb b gnd 0
24 Vsel sel gnd PULSE(0 {VDD} 2.5n 0.1n 0.1n 3n 6n)
25 X1 a b sel mux_out vdd gnd mux2to1 Wpass={Wpass} L={L} Wn={Wn} Wp={Wp}
26 X2 mux_out mux_out_inv vdd gnd cmos_inv Wn_inv={Wn_inv} Wp_inv={Wp_inv} L={L}
27 X3 mux_out_inv Z vdd gnd cmos_inv Wn_inv={Wn} Wp_inv={Wp} L={L}
28 X4 mux_out_inv Y vdd gnd cmos_inv Wn_inv={Wn} Wp_inv={Wp} L={L}
29 .control
30 tran 0.01n 20n
31 set curplottitle="mididoddisaipoojith-2025122010-3"
32 plot v(sel) v(a) v(b)
33 plot v(mux_out_inv)
34 meas tran Trise TRIG v(mux_out_inv) VAL=0.18 RISE=1 TARG v(mux_out_inv) VAL=1.62 RISE=1
35 meas tran Tfall TRIG v(mux_out_inv) VAL=1.62 FALL=1 TARG v(mux_out_inv) VAL=0.18 FALL=1
36 let Tpd = (Trise+Tfall)/2
37 print Tpd
38 .endc
39 .end

```



simulation data



A pass-transistor logic (PTL) based 2:1 multiplexer selects one of the two input signals using NMOS pass transistors controlled by a select signal. The output inverter restores the logic level degraded by the NMOS threshold voltage drop. The overall delay of the circuit depends on the sizing of the pass transistors and the inverter, as larger widths reduce resistance but increase parasitic capacitance. Hence, transistor dimensions are optimized through NGSPICE simulations to achieve the minimum average propagation delay while ensuring correct functionality and full logic-level restoration

| $W$         | $W_n = W$              | $W_n = 2W$              | $W_n = 3W$              | $W_n = 4W$              | $W_n = 5W$              |
|-------------|------------------------|-------------------------|-------------------------|-------------------------|-------------------------|
| $20\lambda$ | $5.43 \times 10^{-10}$ | $2.011 \times 10^{-10}$ | $1.050 \times 10^{-10}$ | $1.037 \times 10^{-10}$ | $1.068 \times 10^{-10}$ |
| $40\lambda$ | $5.99 \times 10^{-10}$ | $2.019 \times 10^{-10}$ | $1.055 \times 10^{-10}$ | $1.040 \times 10^{-10}$ | $1.071 \times 10^{-10}$ |
| $60\lambda$ | $6.19 \times 10^{-10}$ | $2.024 \times 10^{-10}$ | $1.058 \times 10^{-10}$ | $1.043 \times 10^{-10}$ | $1.074 \times 10^{-10}$ |
| $80\lambda$ | $6.30 \times 10^{-10}$ | $2.028 \times 10^{-10}$ | $1.061 \times 10^{-10}$ | $1.045 \times 10^{-10}$ | $1.076 \times 10^{-10}$ |

∴ minimum delay is offered when  
 $W_n = 4W$  and  $W = 20\lambda = 1.08\mu$

 $\tau_{delay\_min} = 1.037 \times 10^{-10}$

(4-0)

Given

$$\bar{a}aV = A$$

$$0 = \bar{a}$$

$$\text{Given function } f = a_1a_2 + a_1a_3 + a_1a_4 + a_2a_3 + a_2a_4 + a_3a_4$$

when  $a_1 = 0$ 

$$f_1 = a_2a_3 + a_2a_4 + a_3a_4$$

$$= a_2a_3 + a_2a_4 + a_3a_4$$

when  $a_1 \neq 0$ 

$$f_2 = a_2 + a_3 + a_4$$

$$= a_2 + a_3 + a_4$$

$$\Rightarrow f = \bar{a}_1(a_2a_3 + a_2a_4 + a_3a_4) + a_1(a_2 + a_3 + a_4)$$

$$\Rightarrow f = \bar{a}_1(\bar{a}_2(a_3a_4) + a_2(a_3 + a_4)) + \bar{a}_1(\bar{a}_2(a_3a_4) + a_2(1))$$

works both for 2<sup>nd</sup> prob remainin = 0

$$\Rightarrow f = \bar{a}_1(\bar{a}_2(a_3a_4) + a_2(\bar{a}_3a_4 + a_3)) + \bar{a}_1(\bar{a}_2(\bar{a}_3a_4 + a_3) + a_2)$$



$2 \times 1$   
MUX



## Netlist used

```

1  * NMOS Pass-Transistor 2:1 MUX netlist for f = x1x2 + x1x3 + x1x4 + x2x3 + x2x4 + x3x
2 4include TSMC_180nm.txt
3 .param VDD    = 1.8
4 .param Wn     = 1.8u
5 .param Wp     = 2*Wn
6 .param L      = 0.18u
7 .param Wpass  = Wn
8 .subckt cmos_inv in out vdd gnd Wn_inv={Wn} Wp_inv={Wp} L={L}
9 Mp out in vdd vdd CMOSP W={Wp_inv} L={L}
10 Mn out in gnd gnd CMOSN W={Wn_inv} L={L}
11 .ends cmos_inv
12 .subckt mux2to1 a b sel out vdd gnd Wpass={Wpass} L={L}
13 Mp1 sel_bar sel vdd vdd CMOSP W={Wp} L={L}
14 Mn1 sel_bar sel gnd gnd CMOSN W={Wn} L={L}
15 Ma out sel a gnd CMOSN W={Wpass} L={L}
16 Mb out sel_bar b gnd CMOSN W={Wpass} L={L}
17 .ends mux2to1
18 VDD vdd gnd {VDD}
19 Vx1 x1 gnd PULSE(0 {VDD} 0n 0.1n 0.1n 6n 12n)
20 Vx2 x2 gnd PULSE(0 {VDD} 0n 0.1n 0.1n 3n 6n)
21 Vx3 x3 gnd PULSE(0 {VDD} 0n 0.1n 0.1n 1.5n 3n)
22 Vx4 x4 gnd PULSE(0 {VDD} 0n 0.1n 0.1n 0.75n 1.5n)
23 X1 VDD gnd x4 X1_out vdd gnd mux2to1 Wpass={Wpass} L={L}
24 X2 X1_out gnd x3 X2_out vdd gnd mux2to1 Wpass={Wpass} L={L}
25 X3 VDD X1_out x3 X3_out vdd gnd mux2to1 Wpass={Wpass} L={L}
26 X4 X3_out X2_out x2 X4_out vdd gnd mux2to1 Wpass={Wpass} L={L}
27 X5 VDD X3_out x2 X5_out vdd gnd mux2to1 Wpass={Wpass} L={L}
28 X6 X5_out X4_out x1 X6_out vdd gnd mux2to1 Wpass={Wpass} L={L}
29 X_load_1 X6_out Z_1 vdd gnd cmos_inv Wn_inv={0.27u} Wp_inv={0.54u} L={L}
30 X_load_2 X6_out Z_2 vdd gnd cmos_inv Wn_inv={0.27u} Wp_inv={0.54u} L={L}
31 X_load_3 X6_out Z_3 vdd gnd cmos_inv Wn_inv={0.27u} Wp_inv={0.54u} L={L}
32 X_load_4 X6_out Z_4 vdd gnd cmos_inv Wn_inv={0.27u} Wp_inv={0.54u} L={L}
33 .control
34 tran 0.01n 20n
35 set curplottitle="mididoddisaipoojith-2025122010-4-B"
36 meas tran VMAX MAX V(X6_out)
37 meas tran VMIN MIN V(X6_out)
38 plot v(x1) v(x2) v(x3) v(x4) v(X6_out)
39 meas tran Trise TRIG v(X6_out) VAL=0.1*VMIN RISE=1 TARG v(X6_out) VAL=0.9*VMAX RISE=1
40 meas tran Tfall TRIG v(X6_out) VAL=0.9*VMAX FALL=1 TARG v(X6_out) VAL=0.1*VMIN FALL=1
41 .endc
42 .end
43

```

## simulation data



## Netlist used

```

1  * NMOS Pass-Transistor 2:1 MUX netlist for f = x1x2 + x1x3 + x1x4 + x2x3 + x2x4 + x3x
2  4include TSMC_180nm.txt
3  .param VDD    = 1.8
4  .param Wn     = 1.8u
5  .param Wp     = 2*Wn
6  .param L      = 0.18u
7  .param Wpass  = Wn
8  .subckt cmos_inv in out vdd gnd Wn_inv={Wn} Wp_inv={Wp} L={L}
9  Mp out in vdd vdd CMOSP W={Wp_inv} L={L}
10 Mn out in gnd gnd CMOSN W={Wn_inv} L={L}
11 .ends cmos_inv
12 .subckt mux2to1 a b sel out vdd gnd Wpass={Wpass} L={L}
13 Mp1 sel_bar sel vdd vdd CMOSP W={Wp} L={L}
14 Mn1 sel_bar sel gnd gnd CMOSN W={Wn} L={L}
15 Ma out sel a gnd CMOSN W={Wpass} L={L}
16 Mb out sel_bar b gnd CMOSN W={Wpass} L={L}
17 .ends mux2to1
18 VDD vdd gnd {VDD}
19 Vx1 x1 gnd 0
20 Vx2 x2 gnd 0
21 Vx3 x3 gnd PULSE(0 {VDD} 2.5n 0.1n 0.1n 3n 6n)
22 Vx4 x4 gnd VDD
23 X1 VDD gnd x4 X1_out vdd gnd mux2to1 Wpass={Wpass} L={L}
24 X2 X1_out gnd x3 X2_out vdd gnd mux2to1 Wpass={Wpass} L={L}
25 X3 VDD X1_out x3 X3_out vdd gnd mux2to1 Wpass={Wpass} L={L}
26 X4 X3_out X2_out x2 X4_out vdd gnd mux2to1 Wpass={Wpass} L={L}
27 X5 VDD X3_out x2 X5_out vdd gnd mux2to1 Wpass={Wpass} L={L}
28 X6 X5_out X4_out x1 X6_out vdd gnd mux2to1 Wpass={Wpass} L={L}
29 X_load_1 X6_out Z_1 vdd gnd cmos_inv Wn_inv={0.27u} Wp_inv={0.54u} L={L}
30 X_load_2 X6_out Z_2 vdd gnd cmos_inv Wn_inv={0.27u} Wp_inv={0.54u} L={L}
31 X_load_3 X6_out Z_3 vdd gnd cmos_inv Wn_inv={0.27u} Wp_inv={0.54u} L={L}
32 X_load_4 X6_out Z_4 vdd gnd cmos_inv Wn_inv={0.27u} Wp_inv={0.54u} L={L}
33 .control
34 tran 0.01n 20n
35 set curplottitle="mididoddisaipoojith-2025122010-4-C"
36 meas tran VMAX MAX V(X6_out)
37 meas tran VMIN MIN V(X6_out)
38 plot v(x1) v(x2) v(x3) v(x4)
39 plot v(X6_out)
40 meas tran Trise TRIG v(X6_out) VAL=0.1*VMIN RISE=1 TARG v(X6_out) VAL=0.9*VMAX RISE=1
41 meas tran Tfall TRIG v(X6_out) VAL=0.9*VMAX FALL=1 TARG v(X6_out) VAL=0.1*VMIN FALL=1
42 print Trise-Tfall
43 .endc
44 .end

```

## simulation data





```

trise          = 3.543807e-10
tfall          = 5.713439e-11
trise-tfall   = 2.972463e-10
ngspice 1 ->

```



## Netlist used

```

1 * NMOS Pass-Transistor 2:1 MUX netlist for f = x1x2 + x1x3 + x1x4 + x2x3 + x2x4 + x3x4 with Repeater
2 sinclude TSMC_180nm.txt
3 .param VDD = 1.8
4 .param Wn = 1.8u
5 .param Wp = 2*Wn
6 .param L = 0.18u
7 .param Wpass = Wn
8 .subckt cmos_inv in out vdd gnd Wn_inv={Wn} Wp_inv={Wp} L={L}
9 Mp out in vdd vdd CMOSP W={Wp_inv} L={L}
10 Mn out in gnd gnd CMOSN W={Wn_inv} L={L}
11 .ends cmos_inv
12 .subckt mux2to1 a b sel out vdd gnd Wpass={Wpass} L={L}
13 Mp1 sel_bar sel vdd vdd CMOSP W={Wp} L={L}
14 Mn1 sel_bar sel gnd gnd CMOSN W={Wn} L={L}
15 Ma out sel a gnd CMOSN W={Wpass} L={L}
16 Mb out sel_bar b gnd CMOSN W={Wpass} L={L}
17 .ends mux2to1
18 VDD vdd gnd {VDD}
19 Vx1 x1 gnd 0
20 Vx2 x2 gnd 0
21 Vx3 x3 gnd PULSE(0 {VDD} 2.5n 0.1n 0.1n 3n 6n)
22 Vx4 x4 gnd VDD
23 X1 VDD gnd x4 X1_out vdd gnd mux2to1 Wpass={Wpass} L={L}
24 X2 X1_out gnd x3 X2_out vdd gnd mux2to1 Wpass={Wpass} L={L}
25
26 X_rep1 X2_out K_1 vdd gnd cmos_inv Wn_inv={Wn} Wp_inv={Wp} L={L}
27 X_rep2 K_1 K_2 vdd gnd cmos_inv Wn_inv={Wn} Wp_inv={Wp} L={L}
28
29 X3 VDD X1_out x3 X3_out vdd gnd mux2to1 Wpass={Wpass} L={L}
30 X4 X3_out K_2 x2 X4_out vdd gnd mux2to1 Wpass={Wpass} L={L}
31 X5 VDD X3_out x2 X5_out vdd gnd mux2to1 Wpass={Wpass} L={L}
32 X6 X5_out X4_out x1 X6_out vdd gnd mux2to1 Wpass={Wpass} L={L}
33 X_load_1 X6_out Z_1 vdd gnd cmos_inv Wn_inv={0.27u} Wp_inv={0.54u} L={L}
34 X_load_2 X6_out Z_2 vdd gnd cmos_inv Wn_inv={0.27u} Wp_inv={0.54u} L={L}
35 X_load_3 X6_out Z_3 vdd gnd cmos_inv Wn_inv={0.27u} Wp_inv={0.54u} L={L}
36 X_load_4 X6_out Z_4 vdd gnd cmos_inv Wn_inv={0.27u} Wp_inv={0.54u} L={L}
37 .control
38 tran 0.01n 20n
39 set curplottitle="mididoddisaipoojith-2025122010-4-D"
40 meas tran VMAX MAX V(X6_out)
41 meas tran VMIN MIN V(X6_out)
42 plot v(x1) v(x2) v(x3) v(x4)
43 plot v(X6_out)
44 meas tran Trise TRIG v(X6_out) VAL=0.1*VMIN RISE=1 TARG v(X6_out) VAL=0.9*VMAX RISE=1
45 meas tran Tfall TRIG v(X6_out) VAL=0.9*VMAX FALL=1 TARG v(X6_out) VAL=0.1*VMIN FALL=1
46 print Trise-Tfall
47 .endc
48 .end

```

To equalize tPLH and tPHL, the charging path (VDD to out) and the discharging path (out to gnd) should have an equal number of transistors of the same size. Therefore, we inserted two inverters at the output of X2 (the intermediate MUX node). This ensures that the charging and discharging paths have comparable drive strength and effectively the same number of transistors in series, resulting in nearly equal rise and fall times.



### simulation data

```

trise          = 1.898644e-10
tfall          = 5.666284e-11
trise-tfall = 1.332016e-10
ngspice 1 ->

```

After inserting two inverters at the output of X2, the difference between rise and fall times reduced significantly to  $t_{PLH} - t_{PHL} = 1.33 \times 10^{-10}$  s, becoming nearly equal, compared to the previous value of  $2.97 \times 10^{-10}$  s. This demonstrates that the inverter insertion effectively balanced the charging and discharging paths.