

**Proiect LDH  
Tema 20**

**Partea I – Proiectarea și analiza dinamică  
în SPICE a circuitului DFFNS  
CMOS\_HP\_05\_T49G**

BALINT ANTONELA\_NICOLA  
Grupa 5314  
Profesor îndrumator: Danut Burdia  
Anul de studiu: 2024-2025

## Partea I – Proiectarea și analiza dinamică în SPICE a circuitului DFFNS

Circuitul DFFNS realizat în tehnologia CMOS\_HP\_05\_T49G este un flip-flop de tip D cu funcții de set asincron(active Low). Acesta stochează un bit de informație, sincronizat cu semnalul de ceas(active Low), și oferă performanțe ridicate datorită tehnologiei CMOS cu consum redus de energie. Ideal pentru aplicații digitale de mare viteză.

1. Să se dimensioneze tranzistoarele MOS corespunzător tehnologiei date și să se scrie netlistul SPICE al circuitului. (Netlist-ul se va scrie ierarhic folosind subcircuite).

BALINT ANTONELA - NICOLAE

GRUPA 5314

### PROIECT LDH

#### \* INV

$$L = 0,5 \mu m$$

$$\frac{W_P}{W_M} = \frac{\mu_m}{\mu_p} = 2,67 \Rightarrow W_P > W_M$$

Aleg  $W_M = 1 \mu m \Rightarrow \lambda W_P = 2,67 \mu m$



• SUBCKT INV 1 10 2

MN2 2 1 0 0 CMOSN L = 0,5 μm W = 1 μm

MP1 2 1 10 10 CMOSP L = 0,5 μm W = 2,67 μm

• ENDS

#### \* INV 3

$$L = 0,5 \mu m$$

$$\frac{W_P}{W_M} = \frac{\mu_m}{\mu_p} = 2,67 \Rightarrow W_P > W_M$$

$$\lambda W_P = 2,67 \mu m$$



. SUBCKT INV3 5 8 3 10 6

MN1 6 5 7 0 CMOSN L=0,5V WJ=1U

MN2 7 8 0 0 CMOSN L=0,5V W=1U

MP1 4 3 10 10 CMOSP L=0,5V W=2,67U

MP2 6 5 4 10 CMOSP L=0,5U WJ=2,67U

\*NAND2

$$\frac{W_p}{W_m} = \frac{1}{m} \cdot \frac{\mu_m}{\mu_p} = \frac{1}{2} \cdot 2,67 = 1,33 \Rightarrow W_p > W_m$$

Aleg Wm = 1 μm  $\Rightarrow$  Wp = 1,33 μm



. SUBCKT NAND2 9 11 10 12

MN1 12 11 13 0 CMOSN L=0,5V WJ=1U

MN2 13 9 0 0 CMOSN L=0,5U WJ=1U

MP1 12 11 10 10 CMOSP L=0,5U WJ=1,33U

MP2 12 9 10 10 CMOSP L=0,5U W=1,33U

. END S

```
.SUBCKT INV 1 10 2
MNL 2 1 0 0 CMOSN L= 0.5U W=1U
MP1 2 1 10 10 CMOSP L= 0.5U W = 2.67W
.ENDS
```

```
.SUBCKT INV 5 8 3 10 6
MN1 6 5 7 0 CMOSN L= 0.5U W=1U
MN2 7 8 0 0 CMOSN L = 0.5U W=1U
MP1 4 3 10 10 CMOSP L=0.3U W = 2.67U
MP2 6 5 4 10 CMOSP L=0.5U W=2.67U
.ENDS
```

```
.SUBCKT NAND 9 11 10 12
MN1 12 11 13 0 CMOSN L= 0.5U W = 1U
MN2 13 9 0 0 CMOSN L= 0.5U W = 1U
MP1 12 11 10 10 CMOSP L=0.5U W =1.33U
MP2 12 9 10 10 CMOSP L=0.5U W =1.33U
.ENDS
```



2. Să se efectueze analiza tranzitorie a circuitului pentru a pune în evidență funcționarea sa. La fiecare ieșire a circuitului se va considera cîte o capacitate de sarcină. Valorile pentru tensiunea de alimentare VDD, timpii de tranzitie TR ai formelor de undă de la intrări și, respectiv, capacitațile de sarcină CL se vor adopta în funcție de tehnologia impusă conform tabelului următor:

| Tehnologie CMOS | 0.13 μm | 0.18μm | 0.25μm | 0.35μm | 0.50μm |
|-----------------|---------|--------|--------|--------|--------|
| VDD             | 1.2V    | 1.8V   | 2.5V   | 3.3V   | 5V     |
| TR              | 0.1ns   | 0.15ns | 0.2ns  | 0.3ns  | 0.4n   |
| CL              | 0.06pF  | 0.07pF | 0.08pF | 0.09pF | 0.1pF  |

### Descrierea circuitului:

VD 14 0 0 PULSE(0 5V 0 {TR} {TR} 10n 20n)  
 VCLK 16 0 0 PULSE(0 5V 2n {TR} {TR} 5n 10n)  
 VS 15 0 0 PULSE(0 5V 10N {TR} {TR} 100N 200N)  
 VDD 10 0 5

X1 14 20 19 10 21 INV3  
 X2 16 10 19 INV  
 X3 19 10 20 INV  
 X4 21 15 10 22 NAND2  
 X5 22 19 20 10 21 INV3  
 X6 22 19 20 10 23 INV3  
 X7 24 20 19 10 23 INV3  
 X8 23 15 10 24 NAND2  
 X9 24 10 25 INV  
 X10 24 10 18 INV  
 X11 25 10 17 INV  
 CL1 17 0 {CL}  
 CL2 18 0 {CL}

```

.inc "SUBCIRCUITE.txt"
.inc "CMOS_HP_05_T49G.txt"
.PARAM CL=0.1p
.PARAM TR=0.4n
.tran 0.1n 60n
.probe
.end
  
```



3. Determinați prin simulare parametrică și folosind funcții sănătă în *Probe* dependența timpilor de propagare a circuitului (de la intrarea de clock la ieșiri) în funcție de capacitatea de sarcină (CL), respectiv în funcție de timpul de tranziție (TR) al formei de undă al intrării de clock. În ambele analize parametrice variația parametrilor se va face în intervalul  $(0.5 \dots 1.5)^*$  val. adoptată conform tehnologiei. Determinați și notați pe graficele obținute valorile întârzierilor de propagare corespunzătoare valorilor adoptate pentru CL și TR.

Considerând că dependența timpilor de propagare în funcție de CL este de forma:

$$t_{\text{total}} = t_{\text{intrinsec}} + K_{\text{load}} * CL$$

determinați pe baza graficelor obținute valorile pentru  $t_{\text{intrinsec}}$  și  $K_{\text{load}}$  și completați un tabel de felul următor ( $t_{\text{intrinsec}}$  corespunde valorii  $CL=0\text{pF}$ ):

#### CIRCUIT

```
VD 14 0 0 PULSE(0 5V 0 {TR} {TR} 10n 20n)
VCLK 16 0 0 PULSE(0 5V 2n {TR} {TR} 5n 10n)
VS 15 0 0 PULSE(0 5V 10N {TR} {TR} 100N 200N)
VDD 10 0 5
```

```
X1 14 20 19 10 21 INV3
X2 16 10 19 INV
X3 19 10 20 INV
X4 21 15 10 22 NAND2
X5 22 19 20 10 21 INV3
X6 22 19 20 10 23 INV3
X7 24 20 19 10 23 INV3
X8 23 15 10 24 NAND2
X9 24 10 25 INV
X10 24 10 18 INV
X11 25 10 17 INV
```

```
CL1 17 0 {CL}
CL2 18 0 {CL}
```

```
.inc "SUBCIRCUITE.txt"
.inc "CMOS_HP_05_T49G.txt"
.PARAM CL=0.1p
.PARAM TR=0.4n
.STEP PARAM CL 0P 0.15P 0.01P
.tran 0.1n 60n 25n
.probe
.end
```



$tpHL\_Q(\text{intrinsic})=647.56\text{p}$

$tpHL\_Q(\text{total})=1.24\text{n}$

Edit New Goal Function

```
tpLH_Q[1,2] = x2-x1
{
  1| search forward level(50%,n) !1;
  2| search forward level(50%,p) !2;
}
```



$tpLH\_Q(\text{intrinsic})=712.41\text{p}$

$tpLH\_Q(\text{total})=1.08\text{n}$



#### View Goal Function

```
tpLH_QN[1,2] = x2-x1
{
  1| search forward level(50%,n) !1;
  2| search forward level(50%,p) !2;
}
```



tpLH\_QN(intrinsic)=543.71p

tpLH\_QN(total)=1.02n



tpHL\_QN(intrinsic)=594.04p

tpHL\_QN(total)=1.25n

| Descriere | tpLH          |        | tpHL          |        |
|-----------|---------------|--------|---------------|--------|
|           | tpLHintrinsic | Kload  | tpHLintrinsic | Kload  |
| CKN → Q   | 712.41p       | 3675.9 | 647.56p       | 5924.4 |
| CKN → QN  | 543.71p       | 47649  | 594.04p       | 6559.6 |

4. Determinați prin simulare parametrii de constrângere SETUP\_TIME, HOLD\_TIME și durata minimă a pulsului MINPW pentru pinii de intrare specificați în tabelul următor:

| Pin intrare | Parametru constrângere | Durata interval [ns] |
|-------------|------------------------|----------------------|
| D           | SETUP_TIME_LH → CKN    | 0                    |
|             | SETUP_TIME_HL → CKN    | 0                    |
|             | HOLD_TIME_LH → CKN     | 6.992                |
|             | HOLD_TIME_HL → CKN     | 6.992                |
| CKN         | MINPW_HIGH             | 233p                 |
|             | MINPW_LOW              | 345p                 |



setup\_time\_LH = 0 ns

setup\_time\_HL = 0 ns



hold\_time\_LH = 6.992 ns

hold\_time\_HL = 6.992 ns



MINPW\_HIGH = 233 ps



MINPW\_LOW = 345 ps