# The BasIC PDK

## April 11th 2025

Appendix A

## 1 Overview

The BasIC PDK User Guide includes the respective Verilog-A module parameters, constants, and associated circuit theory.

# 2 Physical Constants

| Constant        | Value        | Units     |
|-----------------|--------------|-----------|
| $\epsilon_o$    | 8.854e - 12  | F/m       |
| $\epsilon_{si}$ | 1.036e - 11  | F/m       |
| k               | 1.38e - 23   | J/K       |
| q               | $1.60e{-19}$ | C         |
| $n_i$           | $10^{10}$    | $cm^{-3}$ |

## 2.1 NMOS/PMOS Physical Parameters

| NMOS         | Value                | PMOS         | Value                | Units     |
|--------------|----------------------|--------------|----------------------|-----------|
| $V_{THN}$    | 1.0                  | $V_{THP}$    | -1.05                | V         |
| $N_{nsub}$   | 9e + 14              | $N_{psub}$   | 5e + 14              | $cm^{-3}$ |
| $t_{nox}$    | 9e - 3               | $t_{pox}$    | 9e - 3               | um        |
| $C_{jswn}$   | $0.35e^{-11}$        | $C_{jswp}$   | $0.32e^{-11}$        | F/m       |
| $C_{jn}$     | $0.56e^{-3}$         | $C_{jp}$     | $0.94e^{-3}$         | $F/m^2$   |
| $\Phi_{msn}$ | 0.31                 | $\Phi_{msp}$ | -1.36                | V         |
| $\mu_n$      | $350 \times 10^{-4}$ | $\mu_p$      | $100 \times 10^{-4}$ | $m^2/V/s$ |
| $C_{ovn}$    | $0.4 \times 10^{-9}$ | $C_{ovp}$    | $0.3 \times 10^{-9}$ | F/m       |
| $E_n$        | $10^{-6}$            | $E_p$        | $10^{-6}$            | m         |
| $I_{s0n}$    | $10^{-9}$            | $I_{s0p}$    | $10^{-9}$            | A         |
| $\lambda_n$  | 0.1                  | $\lambda_p$  | 0.2                  | $V^{-1}$  |

 $N_{sub}$ : substrate doping.  $t_{ox}$ : Gate-oxide thickness.

 $C_j$ : Junction capacitance.

 $C_{isw}$ : Junction sidewall capacitance.

 $\Phi_{ms}$ : Gate work function.

 $\mu$ : Carrier mobility.

Cov: Gate-drain, Gate-source overlap capacitance.

E: Drain and source length.

 $I_{s0}$ : Subthreshold leakage current.

 $\lambda$ : Channel length modulation coefficient.

### 3 Models

#### 3.1 NMOS

#### 3.1.1 External Parameters

| Parameter     | Type    | Supported Values | Description                        |
|---------------|---------|------------------|------------------------------------|
| body_effect   | Integer | [0, 1]           | Enables body effect.               |
| cl_modulation | Integer | [0, 1]           | Enables Channel Length Modulation. |
| parasitics    | Integer | [0, 1]           | Enables Parasitic Capacitors.      |
| width         | Real    | $(0, 100\mu]$    | Channel width in $m$ .             |
| length        | Real    | $(0, 100\mu]$    | Channel length in $m$ .            |
| mismatch      | Integer | [0,1]            | Enables component mismatch.        |
| procVar       | Integer | [0,1]            | Enables process variation.         |
| procVal       | Real    | [0,0.1)          | Process variation factor.          |

Table 1: NMOS Verilog-A Model Parameters

#### 3.1.2 Equations and Internal Parameters

$$L = length(1 + procVar * procVal * 0.2) + mmatch * mmVal * rand(seed) (1)$$

$$W = width(1 + procVar * procVal * 0.2) + mmatch * mmVal * rand(seed) (2)$$

$$t'_{ox} = t_{ox}(1 + procVar * procVal * 0.2) + mmatch * mmVal * rand(seed) \quad (3)$$

$$C_{ox} = \frac{\epsilon_{ox}}{t'_{ox}} \tag{4}$$

$$I_{D} = \left\{ \begin{array}{l} I_{0} \frac{W}{L} e^{\frac{V_{GS}}{\xi V_{T}}}, V_{GS} < V_{THN} \\ 0.5 \mu_{n} C_{ox} \frac{W}{L} (V_{GS} - V_{THN})^{2} (1 + \lambda V_{DS}), V_{THN} < V_{GS} \leq V_{DS} + V_{THN} \\ \frac{WLC_{ox}}{2} + WC_{ov}, V_{GS} \geq V_{DS} + V_{THN} \end{array} \right\}$$

$$(5)$$

$$\Gamma = I_{sub}(V_{GS})\delta_{cl}(V_{GS}) \tag{6}$$

$$\delta_{cl}(V_{GS}) = \left\{ \begin{array}{l} clme(1 + \lambda V_{DS}), \ (V_{THN} \le V_{GS} \le V_{DS} + V_{THN}) \\ 1, \ V_{GS} < V_{THN} \ or \ V_{GS} > V_{DS} + V_{THN} \end{array} \right\}$$
(7)

$$I_{sub}(V_{GS}) = \left\{ \begin{array}{l} 1, \ V_{GS} > V_{THN} \\ (isth) \exp(\frac{V_{GS}}{EV_T}), \ V_{GS} \le V_{THN} \end{array} \right\}$$
 (8)

$$V_{THN} = V_{THN0} + (be \times \gamma)(\sqrt{2\Phi_F + |V_{SB}|} - \sqrt{|2\Phi_F|})$$
 (9)

$$\gamma = \frac{\sqrt{2q\epsilon_{si}N_{sub}}}{C_{cr}} \tag{10}$$

$$V_{THN0} = \Phi_{MS} + 2\Phi_F + \frac{\sqrt{4q\epsilon_{si}|\Phi_F|N_{sub}}}{C_{cr}}$$
(11)

$$\Phi_F = \frac{kT}{q} \ln(\frac{N_{sub}}{n_i}) \tag{12}$$

#### 3.1.3 Internal Parasitic Capacitance

The BasICPDK NMOS model captures parasitic gate-source, gate-drain, drain-body, source-body, and gate-body parasitic capacitance through a set of piecewise and linear equations.

$$C_{SB} = C_{DB} = WEC_{J0}(1 + \frac{V_R}{\Phi_B})^{-m} + 2(W + E)C_{J0}(1 + \frac{V_R}{\Phi_B})^{-m}$$
 (13)

$$C_{GB} = \left\{ \begin{array}{l} \frac{WLC_{ox}C_d}{WLC_{ox}+C_d}, \ V_{GS} < V_{THN} \\ 0, \ V_{GS} \ge V_{THN} \end{array} \right\}$$
 (14)

$$C_{GD} = \left\{ \begin{array}{l} WC_{ov}, \ V_{GS} < V_{DS} + V_{THN} \\ \frac{WLC_{ox}}{2} + WC_{ov}, \ V_{GS} \ge V_{DS} + V_{THN} \end{array} \right\}$$
 (15)

$$C_{GS} = \left\{ \begin{array}{l} WC_{ov}, \ V_{GS} < V_{THN} \\ \frac{2}{3}WLC_{ox} + WC_{ov}, V_{THP} < V_{GS} \le V_{DS} + V_{THN} \\ \frac{WLC_{ox}}{2} + WC_{ov}, \ V_{GS} \ge V_{DS} + V_{THN} \end{array} \right\}$$
(16)

#### 3.2 **PMOS**

#### 3.2.1 External Parameters

| Parameter | Type    | Supported Values | Description                        |
|-----------|---------|------------------|------------------------------------|
| be        | Integer | [0, 1]           | Enables body effect.               |
| clme      | Integer | [0, 1]           | Enables Channel Length Modulation. |
| width     | Real    | (0, 100]         | Channel width in $m$ .             |
| length    | Real    | (0, 100]         | Channel length in $m$ .            |
| mmatch    | Integer | [0,1]            | Enables component mismatch.        |
| procVar   | Integer | [0,1]            | Enables process variation.         |
| procVal   | Real    | [0,1]            | Process variation factor.          |

Table 2: PMOS Verilog-A Model Parameters

#### 3.2.2 Equations and Internal Parameters

$$L = length(1 + procVar **procVal0.2) + mmatch *mmVal *rand(seed) (17)$$

$$W = width(1 + procVar * procVal * 0.2) + mmatch * mmVal * rand(seed) (18)$$

$$t_{ox}' = t_{ox}(1 + procVar * procVal * 0.2) + mmatch * mmVal * rand(seed) \ \ (19)$$

$$C_{ox} = \frac{\epsilon_{ox}}{t'_{ox}} \tag{20}$$

$$I_{off} = I_{s0p} e^{\frac{V_{GS}}{V_t}} \tag{21}$$

$$I_{tri} = -\mu_p C_{ox} \frac{W}{L} [(V_{GS} - |V_{THP}|) V_{DS} - \frac{1}{2} V_{DS}^2]$$
 (22)

$$I_{sat} = -\mu_p C_{ox} \frac{W}{L} [(V_{GS} - |V_{THP}|)^2 (1 + clme\lambda V_{DS})$$
 (23)

$$I_{ds} = \begin{cases} I_{off}, |V_{GS}| < |V_{THP}| \\ I_{tri}, |V_{DS}| \le |V_{GS}| - |V_{THP}| \\ I_{sat}, |V_{DS}| > |V_{GS}| - |V_{THP}| \end{cases}$$

$$(24)$$

$$V_{THP} = V_{THP0} + (be \times \gamma)(\sqrt{2\Phi_F + |V_{SB}|} - \sqrt{2\Phi_F}) \tag{25}$$

$$\gamma = \frac{\sqrt{2q\epsilon_{si}N_{sub}}}{C_{or}} \tag{26}$$

$$V_{THP0} = \Phi_{msp} + 2\Phi_F + \frac{\sqrt{4q\epsilon_{si}|\Phi_F|N_{sub}}}{C_{ox}}$$
 (27)

$$\Phi_F = \frac{kT}{q} \ln(\frac{N_{sub}}{n_i}) \tag{28}$$

#### 3.2.3 Internal Parasitic Capacitance

The BasICPDK PMOS model captures parasitic gate-source, gate-drain, drain-body, source-body, and gate-body parasitic capacitance through a set of piecewise and linear equations.

$$C_{SB} = C_{DB} = WEC_{jp} + 2(W+E)C_{jswp}$$
 (29)

$$C_{GB} = \left\{ \begin{array}{l} \frac{WLC_{ox}C_d}{WLC_{ox}+C_d}, \ V_{GS} < V_{THP} \\ 0, \ V_{GS} \ge V_{THP} \end{array} \right\}$$
 (30)

$$C_{GD} = \left\{ \begin{array}{l} WC_{ov}, \ V_{GS} < V_{DS} + V_{THP} \\ \frac{WLC_{ox}}{2} + WC_{ov}, \ V_{GS} \ge V_{DS} + V_{THP} \end{array} \right\}$$
(31)

$$C_{GS} = \left\{ \begin{array}{l} WC_{ov}, \ V_{GS} < V_{THP0} \\ \frac{2}{3}WLC_{ox} + WC_{ov}, V_{THP} < V_{GS} \le V_{DS} + V_{THP} \\ \frac{WLC_{ox}}{2} + WC_{ov}, \ V_{GS} \ge V_{DS} + V_{THP} \end{array} \right\}$$
(32)

### 3.3 Resistor

#### 3.3.1 External Parameters

| Parameter | Type    | Supported Values | Description                                           |
|-----------|---------|------------------|-------------------------------------------------------|
| α         | Real    | [0, 1)           | First order temperature coefficient.                  |
| β         | Real    | [0, 1)           | Second order temperature coefficient.                 |
| $\kappa$  | Real    | [0, 1)           | Third order temperature coefficient.                  |
| $ ho_o$   | Real    | $(0, \infty)$    | Material resistivity, $\frac{\Omega m}{K}$ at $T_o$ . |
| $T_o$     | Real    | $(0, \infty)$    | Measurement Temperature (K) of $\rho_o$               |
| width     | Real    | $(0, 10^{-4}]$   | Width in $m$ .                                        |
| length    | Real    | $(0, 10^{-4}]$   | Length in $m$ .                                       |
| thick     | Real    | $(0, 10^{-4}]$   | Thickness of material in $m$ .                        |
| mmatch    | Integer | [0,1]            | Enables component mismatch.                           |
| procVar   | Integer | [0,1]            | Enables process variation.                            |
| procVal   | Real    | [0,1)            | Process variation factor.                             |

Table 3: Resistor Verilog-A Model Parameters

### 3.3.2 Equation and Internal Parameters

$$R = \frac{\rho_o}{t} (1 + \alpha (T - T_o) + \beta (T - T_o)^2 + \kappa (T - T_o)^3) \frac{L}{W}$$
 (33)

$$L = length(1 + procVar * procVal) + mmatch * rand(seed)$$
 (34)

$$W = width(1 + procVar * proVal) + mmatch * rand(seed)$$
 (35)

$$t = thick(1 + procVar * procVal) + mmatch * rand(seed)$$
 (36)

## 3.4 Capacitor

#### 3.4.1 External Parameters

| Parameter    | Type    | Supported Values | Description                                 |
|--------------|---------|------------------|---------------------------------------------|
| $\alpha$     | Real    | [0, 1)           | First order temperature coefficient.        |
| β            | Real    | [0, 1)           | Second order temperature coefficient.       |
| $\kappa$     | Real    | [0, 1)           | Third order temperature coefficient.        |
| $\epsilon_r$ | Real    | $(0, \infty)$    | Material permittivity at $T_0$ .            |
| $T_o$        | Real    | $(0, \infty)$    | Measurement Temperature (K) of $\epsilon_r$ |
| width        | Real    | (0, 100]         | Width in $m$ .                              |
| length       | Real    | (0, 100]         | Length in $m$ .                             |
| distance     | Real    | (0, 100]         | Distance between planes in $m$              |
| mismatch     | Integer | [0,1]            | Enables component mismatch.                 |
| procVar      | Integer | [0,1]            | Enables process variation.                  |
| procVal      | Real    | [0,1)            | Process variation factor.                   |

Table 4: Capacitor Verilog-A Model Parameters

### 3.4.2 Equation and Internal Parameters

$$C = \frac{\epsilon WL}{d} (1 + \alpha (T - T_o) + \beta (T - T_o)^2 + \kappa (T - T_o)^3)$$
 (37)

$$L = length(1 + procVar * procVal) + mmatch * rand(seed)$$
 (38)

$$W = width(1 + procVar * proVal) + mmatch * rand(seed)$$
 (39)

$$t = thick(1 + procVar * procVal) + mmatch * rand(seed)$$
 (40)

$$d = distance(1 + procVar * procVal) + mmatch * rand(seed)$$
 (41)

### 3.5 Inductor

### 3.5.1 External Parameters

| Parameter | Type    | Supported Values | Description                                    |
|-----------|---------|------------------|------------------------------------------------|
| α         | Real    | [0, 1)           | First order temperature coefficient.           |
| β         | Real    | [0, 1)           | Second order temperature coefficient.          |
| $\kappa$  | Real    | [0, 1)           | Third order temperature coefficient.           |
| $\mu_r$   | Real    | $(0, \infty)$    | Relative permeability of material at $T_0$ .   |
| $T_o$     | Real    | $(0, \infty)$    | Temperature (K) at which $\mu_r$ was measured. |
| length    | Real    | (0, 100]         | Length of the material wire in $m$ .           |
| radius    | Real    | (0, 100]         | radius of the material wire core $m$ .         |
| mmatch    | Integer | [0,1]            | Enables component mismatch.                    |
| procVar   | Integer | [0,1]            | Enables process variation.                     |
| procVal   | Real    | [0,1)            | Process variation factor.                      |

Table 5: Inductor Verilog-A Model Parameters

### 3.5.2 Equation and Internal Parameters

$$L = L_0(1 + \alpha(T - T_o) + \beta(T - T_o)^2 + \kappa(T - T_o)^3)$$
(42)

$$L_o = \frac{\mu_o \mu_r}{len} \pi r^2 \tag{43}$$

$$len = length(1 + procVar * procVal + mmatch * rand(seed))$$
 (44)

$$r = radius(1 + procVar * procVal + mmatch * rand(seed))$$
 (45)

## 3.6 NPN Transistor

### 3.6.1 External Parameters

| Parameter     | Type    | Supported Values       | Description                       |
|---------------|---------|------------------------|-----------------------------------|
| $\eta$        | Real    | (1,2)                  | Fitting factor.                   |
| $I_{se}$      | Real    | $(10^{-15}, 10^{-12})$ | Saturation current in Amperes.    |
| β             | Real    | (0, 1000)              | Beta in active mode.              |
| $V_{BE}$      | Real    | (0, 1000)              | Base Emitter Voltage.             |
| $\beta_{sat}$ | Real    | (0, 1000)              | Beta in saturation mode.          |
| $\beta_{rev}$ | Real    | (0, 1000)              | Beta in reverse mode.             |
| mismatch      | Integer | [0,1]                  | Enables component mismatch.       |
| procVar       | Integer | [0,1]                  | Enables process variation factor. |
| procVal       | Real    | [0,1)                  | Process variation factor.         |

Table 6: NPN Verilog-A Model Parameters

## 3.6.2 Equation and Internal Parameters

$$I_E = I_S(e^{\frac{V_{BE}q}{\eta kT}} - 1) \tag{46}$$

$$I_E = I_C + I_B \tag{47}$$

$$I_{B-active} = \beta I_C \tag{48}$$

$$I_{B-saturation} = \beta_{sat} I_C \tag{49}$$

$$I_{B-reverse} = \beta_{rev} I_C \tag{50}$$

$$I_{SE} = (10^{-15})(1 + procVar * procVal) + mmatch * rand(seed)$$
 (51)

## 3.7 PNP Transistor

### 3.7.1 External Parameters

| Parameter     | Type    | Supported Values       | Description                       |
|---------------|---------|------------------------|-----------------------------------|
| $\eta$        | Real    | (1,2)                  | Fitting factor.                   |
| $I_{se}$      | Real    | $(10^{-15}, 10^{-12})$ | Saturation current in Amperes.    |
| β             | Real    | (0, 1000)              | Beta in active mode.              |
| $V_{BE}$      | Real    | (0, 1000)              | Base Emitter Voltage.             |
| $\beta_{sat}$ | Real    | (0, 1000)              | Beta in saturation mode.          |
| $\beta_{rev}$ | Real    | (0, 1000)              | Beta in reverse mode.             |
| mismatch      | Integer | [0,1]                  | Enables component mismatch.       |
| procVar       | Integer | [0,1]                  | Enables process variation factor. |
| procVal       | Real    | [0,1)                  | Process variation factor.         |

Table 7: PNP Verilog-A Model Parameters

## 3.7.2 Equation and Internal Parameters

$$I_E = I_S(e^{\frac{V_{BE}q}{\eta kT}} - 1) \tag{52}$$

$$I_E = I_C + I_B \tag{53}$$

$$I_{B-active} = \beta I_C \tag{54}$$

$$I_{B-saturation} = \beta_{sat} I_C \tag{55}$$

$$I_{B-reverse} = \beta_{rev} I_C \tag{56}$$

$$I_{SE} = (10^{-15})(1 + procVar * procVal) + mismatch * rand(seed)$$
 (57)

## 3.8 Single Pole Amplifier

#### 3.8.1 External Parameters

| Parameter | Type    | Supported Values | Description                       |
|-----------|---------|------------------|-----------------------------------|
| f         | Real    | $(0,\infty)$     | Pole frequency in Hertz.          |
| A         | Real    | $(1,\infty)$     | DC gain.                          |
| mismatch  | Integer | [0,1]            | Enables component mismatch.       |
| procVar   | Integer | [0,1]            | Enables process variation factor. |
| procVal   | Real    | [0,1)            | Process variation factor.         |

Table 8: Single Pole Amplifier Verilog-A Model Parameters

### 3.8.2 Equation and Internal Parameters

$$V_{out} = \frac{A}{1 + \omega j} V_{in}, \ \omega = 2\pi f \tag{58}$$

## 3.9 Two-Pole Amplifier

#### 3.9.1 External Parameters

| Parameter | Type    | Supported Values | Description                       |
|-----------|---------|------------------|-----------------------------------|
| $f_1$     | Real    | $(0,\infty)$     | First pole frequency in Hertz.    |
| $f_2$     | Real    | $(0,\infty)$     | Second pole frequency in Hertz.   |
| A         | Real    | $(1,\infty)$     | DC gain.                          |
| mismatch  | Integer | [0,1]            | Enables component mismatch.       |
| procVar   | Integer | [0,1]            | Enables process variation factor. |
| procVal   | Real    | [0,1)            | Process variation factor.         |

Table 9: Two-Pole Amplifier Verilog-A Model Parameters

### 3.9.2 Equation and Internal Parameters

$$V_{out} = \frac{A}{(1 + \omega_{p1}j)(1 + \omega_{p2}j)} V_{in}, \ \omega_{p1,p2} = 2\pi f_{1,2}$$
 (59)

## 3.10 Three-Pole Amplifier

### 3.10.1 External Parameters

| Parameter | Type    | Supported Values | Description                       |
|-----------|---------|------------------|-----------------------------------|
| f1        | Real    | $(0,\infty)$     | First pole frequency in Hertz.    |
| f2        | Real    | $(0,\infty)$     | Second pole frequency in Hertz.   |
| f3        | Real    | $(0,\infty)$     | Third pole frequency in Hertz.    |
| A         | Real    | $(1,\infty)$     | DC gain.                          |
| mismatch  | Integer | [0,1]            | Enables component mismatch.       |
| procVar   | Integer | [0,1]            | Enables process variation factor. |
| procVal   | Real    | [0,1)            | Process variation factor.         |

Table 10: Three-Pole Amplifier Verilog-A Model Parameters

## ${\bf 3.10.2}\quad {\bf Equation\ and\ Internal\ Parameters}$

$$V_{out} = \frac{A}{(1 + \omega_{p1}j)(1 + \omega_{p2}j)(1 + \omega_{p3}j)} V_{in}, \ \omega_{p1,p2,p3} = 2\pi f_{1,2,3}$$
 (60)