# EE577A Lab3

HONGXIANG GAO 8095639536 University of Southern California April 5, 2019

# Contents

| 1 | Intr | roduction |                                   |    |  |  |  |  |  |
|---|------|-----------|-----------------------------------|----|--|--|--|--|--|
| 2 | Finl | FET Cir   | ccuit Design                      | 3  |  |  |  |  |  |
|   | 2.1  | Balan     | ced Inverter Design               | 3  |  |  |  |  |  |
|   | 2.2  | Balan     | ced NAND2 & NOR2 Design           | 5  |  |  |  |  |  |
|   |      | 2.2.1     | NAND2 Simulation                  | 5  |  |  |  |  |  |
|   |      | 2.2.2     | NOR2 Simulation                   | 6  |  |  |  |  |  |
|   | 2.3  | 2x & 4    | Ix INV, NAND2 and NOR2 Simulation | 9  |  |  |  |  |  |
|   |      | 2.3.1     | 2x Cells Simulation               | 9  |  |  |  |  |  |
|   |      | 2.3.2     | 4x Cells Simulation               | 12 |  |  |  |  |  |
|   | 2.4  | 1x NC     | DR2 Analysis                      | 16 |  |  |  |  |  |
|   | 2.5  | Full A    | dder Simulation                   | 21 |  |  |  |  |  |
|   |      | 2.5.1     | Circuit Build                     | 21 |  |  |  |  |  |
|   |      | 2.5.2     | Simulation Result                 | 23 |  |  |  |  |  |
| 3 | PTN  | /I FinFI  | ET DRAM                           | 24 |  |  |  |  |  |
|   | 3.1  | Single    | e Test Case                       | 24 |  |  |  |  |  |
|   | 3.2  | Pytho     | n Code                            | 25 |  |  |  |  |  |
|   | 3.3  | Simul     | ation Result                      | 27 |  |  |  |  |  |
|   | 3.4  | MATI      | AB Analysis                       | 28 |  |  |  |  |  |
|   |      | 3.4.1     | 3-D Plot                          | 28 |  |  |  |  |  |
|   |      | 3.4.2     | Evaluation                        | 31 |  |  |  |  |  |



# 1 Introduction

In this lab, we're going to apply the state-of-art FinFET technology to build some basic circuit cells including inverters, NAND gates, NOR gates, full adders and DRAM. Figure 1 shows the basic two structures of FinFET.



Figure 1: (a) SG-mode FinFET; (b) IG-mode FinFET

# 2 FinFET Circuit Design

#### 2.1 Balanced Inverter Design

In this section, we need to design the number of fin of both PMOS and NMOS to balance the pull-up strength of PMOS and the pull-down strength of NMOS. In principle, modifying the number of fin should has the same effect when we change the width of a planar MOSFET. The Hspice code is shown below.

```
*****
2 * INV_1X sample hspice
  ******
5 . include '. / hp7nfet.pm'
6 . include '. / hp7pfet.pm'
8 *Define parameters
9 .param vdd=0.7
10 .param vss=0
11 .param fin_height=18n
12 .param fin_width=7n
13 .param lg=11n
14 . param p_{fin} = 4
15 . param n_{fin} = 3
16 .param LoadCap = 1 f
17
18 *Add transistors
19 mp1 Z A Vdd A pfet L=lg NFIN=p_fin
20 mn1 Z A Gnd A nfet L=lg NFIN=n_fin
21
22 *Add cap
23 Cz Z Gnd 'LoadCap'
24
25 *Add voltage sourse
26 VA A 0 PULSE (0 'vdd' 10ps 10ps 10ps 1ns 2ns)
27 VDD Vdd 0 'vdd'
28 VSS Gnd 0 'vss'
29
30 *Do transient analysis
31 .tran 10p 10n
32
33 *Print waveform file *.tr0
_{34} . print V(Z)
35 . print V(A)
36
  *Simulation options (you can modify this. Post is needed for .tran
37
       analysis)
  .OPTION Post Brief NoMod probe measout
38
30
40 *Measurement
```



```
41 .measure tran tdlay1 trig V(A) val=0.35 TD=1n rise=3
42 + targ V(Z) val=0.35 fall=3
43 .measure tran tdlay2 trig V(A) val=0.35 TD=1n fall=3
44 + targ V(Z) val=0.35 rise=3
45 .measure tran trise trig V(Z) val=0.14 TD=1n rise=2
46 + targ V(Z) val=0.56 rise=2
47 .measure tran tfall trig V(Z) val=0.14 TD=1n fall=2
48 + targ V(Z) val=0.56 fall=2
49 .measure tran avg_power AVG p(Cz)
50
51 .end
```



Figure 2: Functionality of 1xINV

The functionality diagram is shown in Figure 2. To balance the rising time and falling time, I choose the PMOS fin number as 4 and 3 for NMOS fin number. The rising delay is about 3.940ps, the falling delay is about 3.516ps. The rising time is 3.265ps and the falling time is 3.371ps, which is quite balanced.

#### 2.2 Balanced NAND2 & NOR2 Design

For NAND2 and NOR2 gates design, I applied the 1XINV template, say the ratio between PMOS and NMOS is 4:3. Then the number of PMOS and NMOS of 1XNAND2 is 2 and 3. And similarly, for NOR2, they are 8 and 3.

#### 2.2.1 NAND2 Simulation

For NAND2 functionality, the Hspice code and diagram are shown below.

```
2 * NAND2_1 sample hspice
5 . include './hp7nfet.pm'
6 . include './hp7pfet.pm'
8 *Define parameters
9 .param vdd=0.7
10 . param vss=0
in .param fin_height=18n
12 .param fin_width=7n
13 .param lg=11n
14 . param p_{fin} = 4
15 .param n_{fin} = 6
16 . param LoadCap = 1 f
17
18 *Add transistors
19 mp1 Z A Vdd A pfet L=lg NFIN=p_fin
20 mp2 Z B Vdd B pfet L=lg NFIN=p_fin
21 mn1 Z A Y A nfet L=lg NFIN=n_fin
22 mn2 Y B Gnd B nfet L=lg NFIN=n_fin
23
24 *Add cap
25 Cz Z Gnd 'LoadCap'
26
27 *Add voltage sourse
28 VB B 0 PULSE (0 'vdd' 10ps 10ps 10ps 1ns 2ns)
29 VA A 0 PULSE (0 'vdd' 10ps 10ps 10ps 2ns 4ns)
30 VDD Vdd 0 'vdd'
31 VSS Gnd 0 'vss'
32
33 *Do transient analysis
34 .tran 1p 20n
35
36 *Print waveform file *.tr0
37 . print V(Z)
38 . print V(A)
39 . print V(B)
40
```



```
41 *Simulation options (you can modify this. Post is needed for .tran
       analysis)
  .OPTION Post Brief NoMod probe measout
42
43
44 *Measurement
45 .measure tran rise_delay trig V(B) val=0.35 TD=0.5n fall=1
46 + targ V(Z) val=0.35 TD=0.5n rise=1
47 .measure tran fall_delay trig V(A) val=0.35 TD=3.5n rise=1
48 + targ V(Z) val=0.35 TD=3.5n fall=1
49 .measure tran trise trig V(Z) val=0.14 TD=4.5n rise=1
50 + targ V(Z) val=0.56 rise=1
51 .measure tran tfall trig V(Z) val=0.14 TD=7.5n fall=1
52 + targ V(Z) val=0.56 fall=1
53 .measure tran avg_power AVG p(Cz)
54
55 . end
```



Figure 3: Functionality of 1xNAND2

The rising delay is about 4.150ps, the falling delay is about 4.069ps. The rising time is 3.405ps and the falling time is 3.136ps, which is also balanced.

#### 2.2.2 NOR2 Simulation

For NOR2 functionality, the Hspice code and diagram are shown below.

```
6 . include './hp7pfet.pm'
8 *Define parameters
9 .param vdd=0.7
10 .param vss=0
11 .param fin_height=18n
12 .param fin_width=7n
13 . param lg=11n
14 .param p_{fin} = 8
15 .param n_{fin} = 3
16 . param LoadCap = 1 f
17
18 *Add transistors
19 mp1 Y A Vdd A pfet L=lg NFIN=p_fin
20 mp2 Z B Y B pfet L=lg NFIN=p_fin
21 mn1 Z A Gnd A nfet L=lg NFIN=n_fin
22 mn2 Z B Gnd B nfet L=lg NFIN=n_fin
23
24 *Add cap
25 Cz Z Gnd 'LoadCap'
26
27 *Add voltage sourse
28 VB B 0 PULSE (0 'vdd' 10ps 10ps 10ps 1ns 2ns)
29 VA A 0 PULSE (0 'vdd' 1260ps 10ps 10ps 2ns 4ns)
30 VDD Vdd 0 'vdd'
31 VSS Gnd 0 'vss'
32
33 *Do transient analysis
34 .tran 1p 20n
35
36 *Print waveform file *.tr0
37 . print V(Z)
38 . print V(A)
39 . print V(B)
40
41 *Simulation options (you can modify this. Post is needed for .tran
       analysis)
42 .OPTION Post Brief NoMod probe measout
43
44 *Measurement
45 .measure tran rise_delay trig V(B) val=0.35 TD=8.5n fall=1
46 + targ V(Z) val=0.35 TD=8.5n rise=1
47 .measure tran fall_delay trig V(A) val=0.35 TD=8.5n rise=1
48 + targ V(Z) val=0.35 TD=8.5n fall=1
49 .measure tran trise trig V(Z) val=0.14 TD=8.5n rise=1
50 + targ V(Z) val=0.56 TD=8.5n rise=1
51 .measure tran tfall trig V(Z) val=0.14 TD=8.5n fall=1
52 + targ V(Z) val=0.56 TD=8.5n fall=1
53 .measure tran avg_power_Cz AVG p(Cz)
54 .measure tran avg_power_mp1 AVG p(mp1)
55 .measure tran avg_power_mp2 AVG p(mp2)
```





Figure 4: Functionality of 1xNOR2

The rising delay is about 3.282ps, the falling delay is about 4.645ps. The rising time is 3.447ps and the falling time is 3.756ps, which is almost balanced.

|       | num_P | num_N | Rise Delay | Fall Delay | Rise Time | Fall Time |
|-------|-------|-------|------------|------------|-----------|-----------|
| INV   | 4     | 3     | 3.940(ps)  | 3.516(ps)  | 3.265(ps) | 3.371(ps) |
| NAND2 | 4     | 6     | 4.150(ps)  | 4.069(ps)  | 3.405(ps) | 3.136(ps) |
| NOR2  | 8     | 3     | 3.282(ps)  | 4.645(ps)  | 3.447(ps) | 3.756(ps) |

Table 1: Simulation of 1xINV, 1xNAND2, 1xNOR2

Table 1 shows the conclusion of number of fins, rise and fall delay, rise and fall time.

## 2.3 2x & 4x INV, NAND2 and NOR2 Simulation

#### 2.3.1 2x Cells Simulation

Here shows the simulation code of each gate. For 2xINV,

```
* INV_2X sample hspice
2
5 . include './hp7nfet.pm'
6 . include './hp7pfet.pm'
8 *Define parameters
9 .param vdd=0.7
10 .param vss=0
11 .param fin_height=18n
12 .param fin_width=7n
13 .param lg=11n
14 . param p_{fin} = 8
15 . param n_{fin} = 6
_{16} . param LoadCap = 1 f
17
18 *Add transistors
19 mp1 Z A Vdd A pfet L=lg NFIN=p_fin
20 mn1 Z A Gnd A nfet L=lg NFIN=n_fin
21
22 *Add cap
23 Cz Z Gnd 'LoadCap'
24
25 *Add voltage sourse
26 VA A 0 PULSE (0 'vdd' 10ps 10ps 10ps 1ns 2ns)
27 VDD Vdd 0 'vdd'
28 VSS Gnd 0 'vss'
29
30 *Do transient analysis
31 . tran 10p 10n
32
33 *Print waveform file *.tr0
34 . print V(Z)
35 . print V(A)
36
37 *Simulation options (you can modify this. Post is needed for .tran
       analysis)
38 .OPTION Post Brief NoMod probe measout
39
40 *Measurement
41 .measure tran tdlay1 trig V(A) val=0.35 TD=1n rise=3
42 + targ V(Z) val=0.35 fall=3
43 .measure tran tdlay2 trig V(A) val=0.35 TD=1n fall=3
44 + targ V(Z) val=0.35 rise=3
_{45} .measure tran trise trig V(Z) val=0.14 TD=1n rise=2
```



9



```
46 + targ V(Z) val=0.56 rise=2
47 .measure tran tfall trig V(Z) val=0.14 TD=1n fall=2
48 + targ V(Z) val=0.56 fall=2
49 .measure tran avg_power AVG p(Cz)
50
51 .end
```

For 2xNAND2,

```
2 * NAND2_2X sample hspice
3 **********
4
5 .include './hp7nfet.pm'
6 . include './hp7pfet.pm'
8 * define parameters
9 . param vdd=0.7
10 .param vss=0
11 .param fin_height=18n
12 .param fin_width=7n
13 .param lg=11n
14 . param p_{fin} = 8
15 . param n_{fin} = 12
16 . param LoadCap = 1f
17
18 *Add transistors
19 mp1 Z A Vdd A pfet L=lg NFIN=p_fin
20 mp2 Z B Vdd B pfet L=lg NFIN=p_fin
21 mn1 Z A Y A nfet L=lg NFIN=n_fin
22 mn2 Y B Gnd B nfet L=lg NFIN=n_fin
23
24 *Add cap
25 Cz Z Gnd 'LoadCap'
26
27 *Add voltage sourse
28 VB B 0 PULSE (0 'vdd' 10ps 10ps 10ps 1ns 2ns)
29 VA A 0 PULSE (0 'vdd' 10ps 10ps 10ps 2ns 4ns)
30 VDD Vdd 0 'vdd'
31 VSS Gnd 0 'vss'
32
33 *Do transient analysis
34 . tran 1p 20n
35
36 *Print waveform file *.tr0
37 . print V(Z)
38 . print V(A)
39 . print V(B)
40
41 *Simulation options (you can modify this. Post is needed for .tran
       analysis)
42 .OPTION Post Brief NoMod probe measout
```

```
Ð)
```

43

```
44 *Measurement
45 .measure tran rise_delay trig V(B) val=0.35 TD=0.5n fall=1
46 + targ V(Z) val=0.35 TD=0.5n rise=1
47 .measure tran fall_delay trig V(A) val=0.35 TD=3.5n rise=1
48 + targ V(Z) val=0.35 TD=3.5n fall=1
49 .measure tran trise trig V(Z) val=0.14 TD=4.5n rise=1
50 + targ V(Z) val=0.56 rise=1
51 .measure tran tfall trig V(Z) val=0.14 TD=7.5n fall=1
52 + targ V(Z) val=0.56 fall=1
53 .measure tran avg_power AVG p(Cz)
54
```

55 . end

For 2xNOR2,

```
1 ***********************
2 * NOR2_2X sample hspice
5 .include './hp7nfet.pm'
6 . include './hp7pfet.pm'
8 *Define parameters
9 .param vdd=0.7
10 . param vss=0
in .param fin_height=18n
12 .param fin_width=7n
<sup>13</sup>.param lg=11n
14 .param p_{fin} = 16
15 .param n_{fin} = 6
<sup>16</sup> . param LoadCap = 1 f
17
18 *Add transistors
19 mp1 Y A Vdd A pfet L=lg NFIN=p_fin
20 mp2 Z B Y B pfet L=lg NFIN=p_fin
21 mn1 Z A Gnd A nfet L=lg NFIN=n_fin
22 mn2 Z B Gnd B nfet L=lg NFIN=n_fin
23
24 *Add cap
25 Cz Z Gnd 'LoadCap'
26
27 *Add voltage sourse
28 VB B 0 PULSE (0 'vdd' 10ps 10ps 10ps 1ns 2ns)
29 VA A 0 PULSE (0 'vdd' 1260ps 10ps 10ps 2ns 4ns)
30 VDD Vdd 0 'vdd'
31 VSS Gnd 0 'vss'
32
33 *Do transient analysis
34 . tran 1p 20n
35
36 *Print waveform file *.tr0
```

```
37 . print V(Z)
38 . print V(A)
39 . print V(B)
40
41 *Simulation options (you can modify this. Post is needed for .tran
       analysis)
42 .OPTION Post Brief NoMod probe measout
43
44 *Measurement
45 .measure tran rise_delay trig V(B) val=0.35 TD=8.5n fall=1
46 + targ V(Z) val=0.35 TD=8.5n rise=1
47 .measure tran fall_delay trig V(A) val=0.35 TD=8.5n rise=1
48 + targ V(Z) val=0.35 TD=8.5n fall=1
_{49} .measure tran trise trig V(Z) val=0.14 TD=8.5n rise=1
50 + targ V(Z) val=0.56 TD=8.5n rise=1
51 .measure tran tfall trig V(Z) val=0.14 TD=8.5n fall=1
52 + targ V(Z) val=0.56 TD=8.5n fall=1
53 .measure tran avg_power AVG p(Cz)
54
55 . end
```

| Table | e 2: Sim | ulation c | of 2xIN | JV, 2xNAI | ND2, 2 | 2xNOR2 | 2 |
|-------|----------|-----------|---------|-----------|--------|--------|---|
|       | -        |           |         |           | 1 -    |        |   |

|       | num_P | num_N | Rise Delay | Fall Delay | Rise Time | Fall Time |
|-------|-------|-------|------------|------------|-----------|-----------|
| INV   | 8     | 6     | 2.794(ps)  | 2.196(ps)  | 3.641(ps) | 2.950(ps) |
| NAND2 | 8     | 12    | 3.407(ps)  | 3.124(ps)  | 3.500(ps) | 2.509(ps) |
| NOR2  | 16    | 6     | 2.301(ps)  | 3.833(ps)  | 2.459(ps) | 3.193(ps) |

Table 2 shows the simulation of all 2x cells.

#### 2.3.2 4x Cells Simulation

Here shows the simulation code of each gate. For 4xINV,



```
18 *Add transistors
19 mp1 Z A Vdd A pfet L=lg NFIN=p_fin
20 mn1 Z A Gnd A nfet L=lg NFIN=n_fin
21
22 *Add cap
23 Cz Z Gnd 'LoadCap'
24
25 *Add voltage sourse
26 VA A 0 PULSE (0 'vdd' 10ps 10ps 10ps 1ns 2ns)
27 VDD Vdd 0 'vdd'
28 VSS Gnd 0 'vss'
29
30 *Do transient analysis
31 . tran 10p 10n
32
33 *Print waveform file *.tr0
34 . print V(Z)
35 . print V(A)
36
37 *Simulation options (you can modify this. Post is needed for .tran
       analysis)
38 .OPTION Post Brief NoMod probe measout
39
40 *Measurement
41 .measure tran tdlay1 trig V(A) val=0.35 TD=1n rise=3
42 + targ V(Z) val=0.35 fall=3
43 .measure tran tdlay2 trig V(A) val=0.35 TD=1n fall=3
44 + targ V(Z) val=0.35 rise=3
45 .measure tran trise trig V(Z) val=0.14 TD=1n rise=2
_{46} + targ V(Z) val=0.56 rise=2
47 .measure tran tfall trig V(Z) val=0.14 TD=1n fall=2
48 + targ V(Z) val=0.56 fall=2
49 .measure tran avg_power AVG p(Cz)
50
51 . end
```

For 4xNAND2,

```
٢
```

```
15 . param n_{fin} = 24
16 . param LoadCap = 1f
17
18 *Add transistors
19 mp1 Z A Vdd A pfet L=lg NFIN=p_fin
20 mp2 Z B Vdd B pfet L=lg NFIN=p_fin
21 mn1 Z A Y A nfet L=lg NFIN=n_fin
22 mn2 Y B Gnd B nfet L=lg NFIN=n_fin
23
24 *Add cap
25 Cz Z Gnd 'LoadCap'
26
27 *Add voltage sourse
28 VB B 0 PULSE (0 'vdd' 10ps 10ps 10ps 1ns 2ns)
29 VA A 0 PULSE (0 'vdd' 10ps 10ps 10ps 2ns 4ns)
30 VDD Vdd 0 'vdd'
31 VSS Gnd 0 'vss'
32
33 *Do transient analysis
34 .tran 1p 20n
35
36 *Print waveform file *.tr0
37 . print V(Z)
38 . print V(A)
39 . print V(B)
40
41 *Simulation options (you can modify this. Post is needed for .tran
       analysis)
42
  .OPTION Post Brief NoMod probe measout
43
44 *Measurement
45 .measure tran rise_delay trig V(B) val=0.35 TD=0.5n fall=1
46 + targ V(Z) val=0.35 TD=0.5n rise=1
47 .measure tran fall_delay trig V(A) val=0.35 TD=3.5n rise=1
48 + targ V(Z) val=0.35 TD=3.5n fall=1
<sup>49</sup> .measure tran trise trig V(Z) val=0.14 TD=4.5n rise=1
50 + targ V(Z) val=0.56 rise=1
51 .measure tran tfall trig V(Z) val=0.14 TD=7.5n fall=1
52 + targ V(Z) val=0.56 fall=1
53 .measure tran avg_power AVG p(Cz)
54
55 . end
  For 4xNOR2,
```

```
8 * Define parameters
9 .param vdd=0.7
10 .param vss=0
11 .param fin_height=18n
12 .param fin_width=7n
13 .param lg=11n
14 . param p_{fin} = 32
15 . param n_{fin} = 12
16 .param LoadCap = 1f
17
18 *Add transistors
19 mp1 Y A Vdd A pfet L=lg NFIN=p_fin
20 mp2 Z B Y B pfet L=lg NFIN=p_fin
21 mn1 Z A Gnd A nfet L=lg NFIN=n_fin
22 mn2 Z B Gnd B nfet L=lg NFIN=n_fin
23
24 *Add cap
25 Cz Z Gnd 'LoadCap'
26
27 *Add voltage sourse
28 VB B 0 PULSE (0 'vdd' 10ps 10ps 10ps 1ns 2ns)
29 VA A 0 PULSE (0 'vdd' 1260ps 10ps 10ps 2ns 4ns)
30 VDD Vdd 0 'vdd'
31 VSS Gnd 0 'vss'
32
33 *Do transient analysis
34 . tran 1p 20n
35
36 *Print waveform file *.tr0
37 . print V(Z)
38 . print V(A)
39 . print V(B)
40
41 *Simulation options (you can modify this. Post is needed for .tran
       analysis)
42 .OPTION Post Brief NoMod probe measout
43
44 *Measurement
45 .measure tran rise_delay trig V(B) val=0.35 TD=8.5n fall=1
46 + targ V(Z) val=0.35 TD=8.5n rise=1
47 .measure tran fall_delay trig V(A) val=0.35 TD=8.5n rise=1
48 + targ V(Z) val=0.35 TD=8.5n fall=1
49 .measure tran trise trig V(Z) val=0.14 TD=8.5n rise=1
50 + targ V(Z) val=0.56 TD=8.5n rise=1
51 .measure tran tfall trig V(Z) val=0.14 TD=8.5n fall=1
52 + targ V(Z) val=0.56 TD=8.5n fall=1
53 .measure tran avg_power AVG p(Cz)
54
55 . end
```

Table 3 shows the simulation of all 4x cells.

|       | num_P | num_N | Rise Delay | Fall Delay | Rise Time | Fall Time |
|-------|-------|-------|------------|------------|-----------|-----------|
| INV   | 16    | 12    | 2.027(ps)  | 1.861(ps)  | 2.233(ps) | 1.871(ps) |
| NAND2 | 16    | 24    | 2.833(ps)  | 2.492(ps)  | 3.160(ps) | 2.082(ps) |
| NOR2  | 32    | 12    | 1.705(ps)  | 3.022(ps)  | 2.057(ps) | 2.862(ps) |

Table 3: Simulation of 4xINV, 4xNAND2, 4xNOR2

### 2.4 1x NOR2 Analysis

In this section, we need to apply four structures of a NOR2 gate according to the material given about the NAND2 gate and analyze its performance. The four structures of the NOR2 gate is shown in Figure 5. From left to right, they are SG, LP, IG and IGLP.



Figure 5: 4 Structures of NOR2 gate. From left to right, they are SG, LP, IG and IGLP.

The code of each mode is given below. LP mode:

```
*****
   NOR2_1X_LP sample hspice
  .include './hp7nfet.pm'
5
 .include './hp7pfet.pm'
6
8 *Define parameters
9 .param vdd=0.7
10 .param vss=0
11 .param fin_height=18n
12 .param fin_width=7n
13 . param lg=11n
14 .param p_{fin} = 8
15 .param n_{fin} = 3
16 . param LoadCap = 1 f
17
```





```
18 *Add transistors
19 mp1 Y A Vdd Vdd pfet L=1g NFIN=p_fin
20 mp2 Z B Y Vdd pfet L=lg NFIN=p_fin
21 mn1 Z A Gnd Gnd nfet L=lg NFIN=n_fin
22 mn2 Z B Gnd Gnd nfet L=1g NFIN=n_fin
23
24 *Add cap
25 Cz Z Gnd 'LoadCap'
26
27 *Add voltage sourse
28 VB B 0 PULSE (0 'vdd' 10ps 10ps 10ps 1ns 2ns)
29 VA A 0 PULSE (0 'vdd' 1260ps 10ps 10ps 2ns 4ns)
30 VDD Vdd 0 'vdd'
31 VSS Gnd 0 'vss'
32
33 *Do transient analysis
34 . tran 1p 20n
35
36 *Print waveform file *.tr0
37 . print V(Z)
38 . print V(A)
39 . print V(B)
40
41 *Simulation options (you can modify this. Post is needed for .tran
       analysis)
42 .OPTION Post Brief NoMod probe measout
43
44 *Measurement
45 .measure tran rise_delay trig V(B) val=0.35 TD=8.5n fall=1
46 + targ V(Z) val=0.35 TD=8.5n rise=1
47 .measure tran fall_delay trig V(A) val=0.35 TD=8.5n rise=1
48 + targ V(Z) val=0.35 TD=8.5n fall=1
49 .measure tran trise trig V(Z) val=0.14 TD=8.5n rise=1
50 + targ V(Z) val=0.56 TD=8.5n rise=1
51 .measure tran tfall trig V(Z) val=0.14 TD=8.5n fall=1
52 + targ V(Z) val=0.56 TD=8.5n fall=1
53 .measure tran avg_power AVG p(Cz)
54 .measure tran avg_power_mp1 AVG p(mp1)
55 .measure tran avg_power_mp2 AVG p(mp2)
56 .measure tran avg_power_mn1 AVG p(mn1)
57 .measure tran avg_power_mn2 AVG p(mn2)
58 . end
  IG mode:
```

```
8 * Define parameters
9 .param vdd=0.7
10 .param vss=0
11 .param fin_height=18n
12 .param fin_width=7n
13 . param lg=11n
14 .param p_{fin} = 8
15 .param n_{fin} = 6
16 .param LoadCap = 1f
17
18 *Add transistors
19 mp1 Y A Vdd A pfet L=lg NFIN=p_fin
20 mp2 Z B Y B pfet L=lg NFIN=p_fin
21 mn1 Z A Gnd B nfet L=lg NFIN=n_fin
22
23 *Add cap
24 Cz Z Gnd 'LoadCap'
25
26 *Add voltage sourse
27 VB B 0 PULSE (0 'vdd' 10ps 10ps 10ps 1ns 2ns)
28 VA A 0 PULSE (0 'vdd' 1260ps 10ps 10ps 2ns 4ns)
29 VDD Vdd 0 'vdd'
30 VSS Gnd 0 'vss'
31
32 *Do transient analysis
33 .tran 1p 20n
34
35 *Print waveform file *.tr0
_{36} . print V(Z)
37 . print V(A)
38 . print V(B)
39
40 *Simulation options (you can modify this. Post is needed for .tran
       analysis)
41 .OPTION Post Brief NoMod probe measout
42
43 *Measurement
44 .measure tran rise_delay trig V(B) val=0.35 TD=8.5n fall=1
45 + targ V(Z) val=0.35 TD=8.5n rise=1
46 .measure tran fall_delay trig V(A) val=0.35 TD=8.5n rise=1
47 + targ V(Z) val=0.35 TD=8.5n fall=1
48 .measure tran trise trig V(Z) val=0.14 TD=8.5n rise=1
49 + targ V(Z) val=0.56 TD=8.5n rise=1
50 .measure tran tfall trig V(Z) val=0.14 TD=8.5n fall=1
51 + targ V(Z) val=0.56 TD=8.5n fall=1
_{52} .measure tran avg_power AVG p(Cz)
53 .measure tran avg_power_mp1 AVG p(mp1)
54 .measure tran avg_power_mp2 AVG p(mp2)
55 .measure tran avg_power_mn1 AVG p(mn1)
56
57 . end
```



```
IGLP mode:
```

```
*****
  * NOR2_1X_IGLP sample hspice
2
3 *********************
5 . include '. / hp7nfet.pm'
6 . include '. / hp7pfet.pm'
8 *Define parameters
9 .param vdd=0.7
10 .param vss=0
11 .param fin_height=18n
12 .param fin_width=7n
13 .param lg=11n
14 .param p_{fin} = 8
15 .param n_{fin} = 6
_{16} . param LoadCap = 1 f
17
18 *Add transistors
19 mp1 Y A Vdd Vdd pfet L=lg NFIN=p_fin
20 mp2 Z B Y Vdd pfet L=lg NFIN=p_fin
21 mn1 Z A Gnd B nfet L=lg NFIN=n_fin
22
23 *Add cap
24 Cz Z Gnd 'LoadCap'
25
26 *Add voltage sourse
27 VB B 0 PULSE (0 'vdd' 10ps 10ps 10ps 1ns 2ns)
28 VA A 0 PULSE (0 'vdd' 1260ps 10ps 10ps 2ns 4ns)
29 VDD Vdd 0 'vdd'
30 VSS Gnd 0 'vss'
31
32 *Do transient analysis
33 .tran 1p 20n
34
35 *Print waveform file *.tr0
_{36} . print V(Z)
37 . print V(A)
38 . print V(B)
39
40 *Simulation options (you can modify this. Post is needed for .tran
       analysis)
41 .OPTION Post Brief NoMod probe measout
42
43 *Measurement
44 .measure tran rise_delay trig V(B) val=0.35 TD=8.5n fall=1
45 + targ V(Z) val=0.35 TD=8.5n rise=1
46 .measure tran fall_delay trig V(A) val=0.35 TD=8.5n rise=1
47 + targ V(Z) val=0.35 TD=8.5n fall=1
48 .measure tran trise trig V(Z) val=0.14 TD=8.5n rise=1
49 + targ V(Z) val=0.56 TD=8.5n rise=1
```



```
50 .measure tran tfall trig V(Z) val=0.14 TD=8.5n fall=1
51 + targ V(Z) val=0.56 TD=8.5n fall=1
<sup>52</sup> .measure tran avg_power AVG p(Cz)
53 .measure tran avg_power_mp1 AVG p(mp1)
54 .measure tran avg_power_mp2 AVG p(mp2)
55 .measure tran avg_power_mn1 AVG p(mn1)
56
57 . end
```

For IG and IGLP mode, since there is only one NMOS for the pull down part, the number of fins are compressed into one NMOS, then the number of fin of NMOS is 6 in these two modes. However, for IG and IGLP mode, because of the asymmetry of the structure, the pull down strength of gate and back is far different from each other, which lead to the error of functionality, which is shown in Figure 6. When the input signal A falls from '1' to '0' while B is still at '1', the output signal would also pull down, however, when B falls from '1' to '0' while A is still at '1', the output signal would just give a glitch instead of pull down the output signal, which means the pull-down strength of A is much stronger than B.



Figure 6: Error Functionality of IG Mode

|                                                                                           | Table 4: Simulation of SG, LP, IG, IGLP Wode TXNOK2 |           |           |           |             |             |               |  |  |
|-------------------------------------------------------------------------------------------|-----------------------------------------------------|-----------|-----------|-----------|-------------|-------------|---------------|--|--|
| Rise Delay   Fall Delay   Rise Time   Fall Time   Leakage Power   Switch Power   Switch E |                                                     |           |           |           |             |             | Switch Energy |  |  |
| SG                                                                                        | 3.282(ps)                                           | 4.645(ps) | 3.447(ps) | 3.756(ps) | 305.39(nW)  | 309.766(nW) | 1.239(fJ)     |  |  |
| LP                                                                                        | 3.273(ps)                                           | 4.644(ps) | 3.439(ps) | 3.745(ps) | 305.07(nW)  | 309.87(nW)  | 1.239(fJ)     |  |  |
| IG                                                                                        | 2.253(ps)                                           | 2.970(ps) | 2.753(ps) | 3.124(ps) | 177.700(nW) | 183.361(nW) | 0.837(fJ)     |  |  |
| IGLP                                                                                      | 2.253(ps)                                           | 2.970(ps) | 2.753(ps) | 3.123(ps) | 177.710(nW) | 183.327(nW) | 0.733(fJ)     |  |  |

Table 4: Simulation of SC ID IC ICID Mode 1, NOD2

Table 4 shows the parameters of each mode. The timing parameters for IG and IGLP mode are based on input A.

#### 2.5 Full Adder Simulation

### 2.5.1 Circuit Build

The schematic of a full adder is given in Figure 7. The Hspice is also given below.



Figure 7: Schematic of Full Adder

```
******
     Full Adder hspice
2
  ******
  .include './hp7nfet.pm'
.include './hp7pfet.pm'
5
6
8 *Define parameters
9 .param vdd=0.7
10 .param vss=0
11 .param fin_height=18n
12 .param fin_width=7n
13 . param lg=11n
14 .param p_{fin} = 4
15 .param n_{fin} = 3
<sup>16</sup> .param LoadCap = 1 f
17
18 *Add transistors
19 mp1 U1 A Vdd A pfet L=lg NFIN=p_fin
```

```
20 mp2 Cout_bar C U1 C pfet L=lg NFIN=p_fin
21 mp3 U1 B Vdd B pfet L=lg NFIN=p_fin
22 mp4 V1 A Vdd A pfet L=lg NFIN=p_fin
23 mp5 Cout_bar B V1 B pfet L=lg NFIN=p_fin
24 mp6 W1 A Vdd A pfet L=lg NFIN=p_fin
25 mp7 W1 B Vdd B pfet L=lg NFIN=p_fin
26 mp8 W1 C Vdd C pfet L=lg NFIN=p_fin
27 mp9 S_bar Cout_bar W1 Cout_bar pfet L=lg NFIN=p_fin
28 mp10 X1 A Vdd A pfet L=lg NFIN=p_fin
29 mp11 Y1 B X1 B pfet L=lg NFIN=p_fin
30 mp12 S_bar C Y1 C pfet L=lg NFIN=p_fin
31 mp13 Cout Cout_bar Vdd Cout_bar pfet L=lg NFIN=p_fin
32 mp14 S S_bar Vdd S_bar pfet L=lg NFIN=p_fin
33 mn1 U2 A Gnd A nfet L=lg NFIN=n_fin
34 mn2 Cout_bar C U2 C nfet L=lg NFIN=n_fin
35 mn3 U2 B Gnd B nfet L=lg NFIN=n_fin
36 mn4 V2 A Gnd A nfet L=lg NFIN=n_fin
37 mn5 Cout_bar B V2 B nfet L=lg NFIN=n_fin
38 mn6 W2 A Gnd A nfet L=lg NFIN=n_fin
39 mn7 W2 B Gnd B nfet L=lg NFIN=n_fin
40 mn8 W2 C Gnd C nfet L=lg NFIN=n_fin
41 mn9 S_bar Cout_bar W2 Cout_bar nfet L=lg NFIN=n_fin
42 mn10 X2 A Gnd A nfet L=lg NFIN=n_fin
43 mn11 Y2 B X2 B nfet L=lg NFIN=n_fin
44 mn12 S_bar C Y2 C nfet L=lg NFIN=n_fin
45 mn13 Cout Cout_bar Gnd Cout_bar nfet L=lg NFIN=n_fin
46 mn14 S S_bar Gnd S_bar nfet L=lg NFIN=n_fin
48 *Add cap
49 Cz1 S Gnd 'LoadCap'
50 Cz2 Cout Gnd 'LoadCap'
51
52 *Add voltage sourse
53 VA A 0 PULSE (0 'vdd' 10ps 10ps 10ps 1ns 2ns)
54 VB B 0 PULSE (0 'vdd' 10ps 10ps 10ps 2ns 4ns)
55 VC C 0 PULSE (0 'vdd' 10ps 10ps 10ps 4ns 8ns)
56 VDD Vdd 0 'vdd'
57 VSS Gnd 0 'vss'
58
59 *Do transient analysis
60 .tran 10p 12n
61
62 *Print waveform file *.tr0
63 . print V(A)
64 . print V(B)
65 . print V(C)
66 . print V(Cout)
67 . print V(S)
68
69 *Simulation options (you can modify this. Post is needed for .tran
       analysis)
```



```
70 .OPTION Post Brief NoMod probe measout
71
72 *Measurement Cout Delay
73 .measure tran Cout_tdlay1 trig V(A) val=0.35 TD=2.5n fall=1
74 + targ V(Cout) val=0.35 fall=1
75 .measure tran Cout_tdlay2 trig V(A) val=0.35 TD=3.5n rise=1
76 + targ V(Cout) val=0.35 rise=1
77 .measure tran Cout_trise trig V(Cout) val=0.14 TD=3.5n rise=1
78 + targ V(Cout) val=0.56 rise=1
79 .measure tran Cout_tfall trig V(Cout) val=0.14 TD=2.5n fall=1
80 + targ V(Cout) val=0.56 TD=2.5n fall=1
81
82 *Measurement S Delay
83 .measure tran S_tdlay1 trig V(A) val=0.35 TD=0.5n fall=1
84 + targ V(S) val=0.35 fall=1
85 .measure tran S_tdlay2 trig V(A) val=0.35 TD=2.5n fall=1
86 + targ V(S) val=0.35 rise=1
87 .measure tran S_trise trig V(S) val=0.14 TD=2.5n rise=1
88 + targ V(S) val=0.56 rise=1
89 .measure tran S_tfall trig V(S) val=0.14 TD=0.5n fall=1
90 + targ V(S) val=0.56 TD=0.5n fall=1
91
92 .measure tran avg_power AVG p(Cz1)
93 .measure tran avg_power AVG p(Cz2)
94
95 . end
```



#### 2.5.2 Simulation Result

Figure 8: Functionality Simulation of Full Adder

Figure 8 shows the functionality simulation of the full adder. The rise and fall delay of  $C_{out}$  is 7.204ps and 4.551ps. For *S*, they are 6.653ps and 9.554ps.

## **3 PTM FinFET DRAM**

## 3.1 Single Test Case



Figure 9: 1-Bit DRAM Setup

A basic 1-bit DRAM circuit setup is shown in Figure 9. The Y node is connected to the gate of the PMOS, which is set to be '0'. We measure the discharge time, average current and average power to analyze this circuit.

The Hspice code is given below.



```
16 . param length = 1n
17 .param LoadCap = 1f
18
19 *Add transistors
20 mp1 X Y Z Gnd pfet L=lg NFIN=number_fin
21
22
23 *Add cap
24 Cz Z Gnd 'LoadCap'
25
26 *Add voltage sourse
27 VX X 0 'vdd/2'
28 VY Y 0 'vss'
29 VSS Gnd 0 'vss'
30
31 *Define the initial condition of V(Z)
32 . IC V(Z) = 'vdd'
33
34 *Do transient analysis
35 .tran 'step' 'length'
36
37 *Print the V(Z) to waveform file *.tr0
38 . print V(Z)
39
40 *Simulation options (you can modify this. Post is needed for .tran
       analysis)
  .OPTION Post Brief NoMod probe measout
41
42
43 *Measurement
44 .measure tran RTL TRIG AT=0 TARG v(Z) VAL=0.35 FALL=1
45 .measure tran avg_current AVG I(Cz) from 0 to 'RTL'
_{\rm 46} .measure tran avg_power AVG p(Cz)
47
48 . end
```

# 3.2 Python Code

The Python code contains two parts. First part is to read from the sample Hspice file and generate a new one whose parameters, say load capacitance, number of fin, time step and time length has been changed. For this part, the Python code is shown below. For simplicity, the number of fins follows the value in 1xINV template.

```
import re
import sys
filein = open('sample.sp','r')
fileout = open('new.sp','w')
stepfind = '.param step = ' + sys.argv[1]
stepsub = '.param step = ' + sys.argv[2]
lengthfind = '.param length = ' + sys.argv[3]
```



```
8 lengthsub = '.param length = ' + sys.argv[4]
9 Cffind = '.param LoadCap = ' + sys.argv[5]
10 Cfsub = '.param LoadCap = '+ sys.argv[6]
ii finfind = '.param number_fin = ' + sys.argv[7]
12 finsub = '.param number_fin = ' + sys.argv[8]
13
  for i in filein:
14
    if re.search(stepfind, i) != None:
15
      u = re.sub(stepfind, stepsub, i)
16
      fileout.write(u)
17
    elif re.search(lengthfind, i) != None:
18
      v = re.sub(lengthfind, lengthsub, i)
19
      fileout.write(v)
20
    elif re.search(Cffind, i) != None:
21
     w = re.sub(Cffind, Cfsub, i)
22
23
      fileout.write(w)
24
    elif re.search(finfind, i) != None:
25
     x = re.sub(finfind, finsub, i)
      fileout.write(x)
26
    else:
27
      fileout.write(i)
28
29 filein.close()
30 fileout.close()
```

For second part, which is the operating part, it provides the value of each case and apply a large for loop to do the iteration. And I used the "os" operation to run Hspice simulation in the command line. After each simulation, data will also be collected automatically. This part of code is given below.

```
1 import re
2 import os
3 import sys
  def write_array(files, array):
5
    for i in array:
6
       files.write(i + ' \setminus t')
7
     files.write(' \ n')
8
10 def write_data(filesin, filesout):
    count = 0
11
    for i in filesin:
12
13
      ss = i.split()
      if len(ss) == 4:
14
        count = count + 1
15
         if count != 1:
16
           write_array(filesout, ss[0:-1])
17
18
19 fileout=open('dram.txt','w')
  step = ['0.01p','0.01p','0.01p','2p','2p','2p','2p','0.5n','0.5n',
20
      '0.5n','0.5n']
```

```
21 tlength = ['1n', '1n', '150n', '150n', '150n', '150n', '8u', '8u', '8
      u','8u']
22 Cf = ['1f', '2.951f', '8.705f', '25.69f', '75.79f', '223.6f', '659.8f', '
      1947 f', '5743 f', '16950 f', '50000 f']
23 fin = ['1','2','3','4','5']
  for i in range(len(fin)):
24
    for j in range(len(tlength)):
25
      if i == 0 and j == 0:
26
        cmd = 'python sub.py'+' '+step[j]+' '+step[j]+' '+tlength[j]
      ]+' '+tlength[j]+' '+Cf[j]+' '+Cf[j]+' '+fin[j]+' '+fin[j]
      else:
28
        cmd = 'python sub.py'+' '+step[0]+' '+step[j]+' '+tlength
29
      [0]+' '+tlength[j]+' '+Cf[0]+' '+Cf[j]+' '+fin[0]+' '+fin[i]
      os.system(cmd)
30
31
      os.system('hspice new.sp > new.lis')
      filein = open('new.mt0','r')
32
33
      write_data(filein , fileout)
    fileout.write(' \ n')
34
```

#### 3.3 Simulation Result

The simulation result is given below. The first column is the RTL time, second column is the average current and third column is the average power. They are negative because the load capacitor is discharging.

```
1 7.397e - 11 - 4.442e - 06
                             -1.707e - 07
2 1.737e - 10 - 5.791e - 06
                            -5.348e - 07
                            -1.605e - 06
3 7.812e-10 -3.863e-06
                            -3.188e - 08
4 1.588e - 09 - 5.642e - 06
5 5.232e-09 -5.065e-06 -9.410e-08
6 1.376e-08 -5.685e-06
                           -2.764e - 07
7 4.621e-08 -4.997e-06 -8.135e-07
8 1.545e-07 -4.386e-06
                           -4.511e - 08
9 4.181e-07 -4.798e-06 -1.337e-07
10 1.183e - 06 - 5.010e - 06
                            -3.945e - 07
11 3.911e - 06 - 4.473e - 06
                            -1.162e - 06
12
13 4.112e-11 -7.179e-06
                             -1.507e - 07
14 7.344e - 11 - 1.341e - 05
                            -5.161e - 07
15 3.450e - 10 - 8.668e - 06
                             -1.581e-06
16 \ 1.051 e - 09 \ -8.498 e - 06
                             -3.171e-08
17 2.561e - 09 - 1.033e - 05
                             -9.409e - 08
18 6.766e - 09 - 1.156e - 05
                             -2.776e - 07
19 2.082e - 08 - 1.109e - 05
                             -8.154e - 07
20 7.106e - 08 - 9.487e - 06
                             -4.495e - 08
21 1.991e - 07 - 1.006e - 05
                             -1.335e - 07
                             -3.950e-07
22 5.054e - 07 - 1.172e - 05
23 1.749e-06 -9.999e-06
                             -1.162e - 06
24
25 1.709e - 11 - 1.722e - 05 - 1.469e - 07
```



| 26 | 7.316e-11                | -1.324e-05    | -5.031e-07    |
|----|--------------------------|---------------|---------------|
| 27 | 1.711e - 10              | -1.734e-05    | -1.576e - 06  |
| 28 | 4.357 e - 10             | -2.044e-05    | -3.166e - 08  |
| 29 | 1.572e - 09              | -1.682e - 05  | -9.403 e - 08 |
| 30 | 5.214 e - 09             | -1.499e - 05  | -2.776e - 07  |
| 31 | 1.367 e - 08             | -1.689e - 05  | -8.155e - 07  |
| 32 | 3.077 e - 08             | -2.180e - 05  | -4.505e - 08  |
| 33 | 1.530e - 07              | -1.307e - 05  | -1.330e - 07  |
| 34 | $4.045  \mathrm{e}{-07}$ | -1.464e-05    | -3.947e - 07  |
| 35 | 1.184e - 06              | -1.477e - 05  | -1.164e - 06  |
| 36 |                          |               |               |
| 37 | 1.959e - 11              | -1.394e-05    | -1.354e - 07  |
| 38 | 6.101e-11                | -1.567e - 05  | -4.928e - 07  |
| 39 | 1.753  e - 10            | -1.679e - 05  | -1.553e - 06  |
| 40 | 5.077 e - 10             | -1.748e - 05  | -3.156e - 08  |
| 41 | 1.320 e - 09             | -2.001e-05    | -9.380e - 08  |
| 42 | 3.927 e - 09             | -1.990e-05    | -2.774e-07    |
| 43 | 9.706e - 09              | -2.378e - 05  | -8.163e - 07  |
| 44 | 3.570 e - 08             | -1.870e - 05  | -4.492e-08    |
| 45 | 6.666e - 08              | -2.993e-05    | -1.329e - 07  |
| 46 | $3.594 \mathrm{e}{-07}$  | -1.647 e - 05 | -3.951e - 07  |
| 47 | 7.091 e - 07             | -2.466e - 05  | -1.167e - 06  |
| 48 |                          |               |               |
| 49 | 1.620e - 11              | -1.653e - 05  | -1.297e - 07  |
| 50 | $4.440  \mathrm{e}{-11}$ | -2.074e-05    | -4.699e - 07  |
| 51 | 8.423 e - 11             | -3.470e - 05  | -1.536e - 06  |
| 52 | 2.333e - 10              | -3.792e-05    | -3.157e - 08  |
| 53 | $1.143 \mathrm{e}{-09}$  | -2.308e - 05  | -9.364e-08    |
| 54 | 2.717 e - 09             | -2.875e - 05  | -2.774e-07    |
| 55 | 9.088e-09                | -2.539e - 05  | -8.176e - 07  |
| 56 | 1.944e - 08              | -3.418e - 05  | -4.425 e - 08 |
| 57 | 5.711 e - 08             | -3.487e - 05  | -1.328e - 07  |
| 58 | 1.674e - 07              | -3.533e - 05  | -3.946e - 07  |
| 59 | 6.597 e - 07             | -2.650e - 05  | -1.166e - 06  |

#### 3.4 MATLAB Analysis

#### 3.4.1 3-D Plot

```
1 clear all
2 Cf =
        [1,2.951,8.705,25.69,75.79,223.6,659.8,1947,5743,16950,50000];
3 fin = [1 2 3 4 5];
4
5 archive = fopen('dram.txt');
6 b = fscanf(archive,'%f',[3,60]);
7 b=b';
8 for i = 1:11
9       rtl(1,i) = b(i,1);
10       current(1,i) = b(i,2);
```

```
power(1,i) = b(i,3);
11
12 end
13 for i = 12:22
       rtl(2,i-11) = b(i,1);
14
       current(2, i-11) = b(i, 2);
15
       power(2, i-11) = b(i, 3);
16
17 end
  for i = 23:33
18
19
       rtl(3,i-22) = b(i,1);
       current(3, i-22) = b(i, 2);
20
       power(3, i-22) = b(i, 3);
21
22 end
  for i = 34:44
23
       rtl(4,i-33) = b(i,1);
24
       current(4, i-33) = b(i, 2);
25
26
      power(4, i-33) = b(i, 3);
27 end
28 for i = 45:55
29
       rtl(5,i-44) = b(i,1);
       current(5, i-44) = b(i, 2);
30
       power(5, i-44) = b(i, 3);
31
32 end
33 h=gca;
34
35 surf(log(Cf),fin,log(rtl))
36 title('R.T.L')
37 xlabel('Cf in log scale')
38 ylabel ('Num of Fin')
39 figure;
40 surf(log(Cf), fin, log(abs(current)))
41 title ('Current')
42 xlabel('Cf in log scale')
43 ylabel ( 'Num of Fin')
44 figure;
45 surf(log(Cf), fin, log(abs(power)))
46 title ('Power')
47 xlabel('Cf in log scale')
48 ylabel ('Num of Fin')
```

The MATLAB code for 3-D plot is given above.







Figure 11: 3-D Plot of Average Current



Figure 12: 3-D Plot of Average Power

#### 3.4.2 Evaluation

The MATLAB code for calculating statistic values are given below.

```
1 clear all
2 Cf =
      [1,2.951,8.705,25.69,75.79,223.6,659.8,1947,5743,16950,50000];
<sup>3</sup> fin = [1 2 3 4 5];
4
5 archive = fopen('dram.txt');
6 b = fscanf(archive, '%f', [3,60]);
7 b=b';
 s for i = 1:55 
       rtl(1,i) = b(i,1);
9
      current(1,i) = b(i,2);
10
      power(1,i) = b(i,3);
12 end
13 RTL_min = \min(rtl);
14 RTL_max = max(rtl);
15 RTL_avg = mean(rtl);
16 RTL_std = std(rtl);
17 current_min = min(current);
18 current_max = max(current);
19 current_avg = mean(current);
20 current_std = std(current);
21 power_min = min(power);
22 power_max = max(power);
```

```
23 power_avg = mean(power);
24 power_std = std(power);
```

The minimum value, maximum value, average value and standard deviation is given in the table below.

| Table 5: Statistic | values of | R.T.L, Aver | age Current | t and A | Average Power |
|--------------------|-----------|-------------|-------------|---------|---------------|
|                    |           |             | 1 .         |         |               |

|                 | Minimum   | Maximum   | Average    | Standard Deviation |  |
|-----------------|-----------|-----------|------------|--------------------|--|
| R.T.L           | 16.20(ps) | 3.91(µs)  | 221.59(ns) | 612.38(ns)         |  |
| Average Current | 3.86(µA)  | 37.92(µA) | 16.05(µA)  | 9.16(µA)           |  |
| Average Power   | 31.56(nW) | 1.61(µW)  | 470.53(nW) | 489.64(nW)         |  |

# References