# **Analog Circuit Design**

## Harald Pretl Michael Koefinger

## 2024-08-20

## Table of contents

| Introduction                                                     |
|------------------------------------------------------------------|
| IHP's SG13G2 130nm CMOS Technology                               |
| Schematic Entry Using Xschem                                     |
| Circuit Simulation Using ngspice                                 |
| Integrated IC Design Environment (IIC-OSIC-TOOLS)                |
| First Steps                                                      |
| The Metal-Oxide-Semiconductor Field-Effect-Transistor (MOSFET) 4 |
| Conclusion                                                       |
| Transistor Sizing Using gm/ID Methodology                        |
| MOSFET Characterization Testbench                                |
| NMOS Characterization                                            |
| PMOS Characterization                                            |
| First Circuit: MOSFET Diode                                      |
| MOSFET Diode Sizing                                              |
| MOSFET Diode Large-Signal Behaviour                              |
| MOSFET Diode Small-Signal Analysis                               |
| MOSFET Diode Stability Analysis                                  |
| MOSFET Diode Noise Calculation                                   |
| Conclusion                                                       |
| Current Mirror                                                   |
| Differential Pair                                                |
| Cascode Stage                                                    |
| A Basic 5-Transistor OTA                                         |
| A Fully-Differential OTA                                         |
| Biasing the OTA                                                  |
| An RC-OPAMP Filter                                               |
| Summary & Conclusion                                             |
| Appendix: ngspice Cheat Sheet                                    |
| Appendix: Xschem Cheat Sheet                                     |

#### Introduction

This is the material for an intermediate-level MOSFET circuit design course, held at JKU under course number 336.009 ("KV Analoge Schaltungstechnik").

The course makes heavy use of circuit simulation, using **Xschem** for schematic entry and **ngspice** for simulation. The 130nm CMOS technology **SG13G2** from IHP Microelectronics is used.

Tools and PDK are integrated in the **IIC-OSIC-TOOLS** Docker image, which will be used during the coursework.

## Note

All course material is made publicly available on GitHub and shared under the Apache-2.0 license.

#### IHP's SG13G2 130nm CMOS Technology

SG13G2 is the name of a 130nm CMOS technology (strictly speaking BiCMOS) from IHP Microelectronics. It features low-voltage (thin-oxide) core MOSFET, high-voltage (thick-oxide) I/O MOSFET, various types of linear resistors, and 7 layers of Aluminium metallization (5 thin plus 2 thick metal layers). This PDK is open-source, and the complete process specification can be found at SG13G2 process specification. While we will not do layouts in this course, the layout rules can be found at SG13G2 layout rules.

For our circuit design, the most important parameters of the available devices are summarized in the following:

- Low-voltage NMOS: Device sg13\_lv\_nmos; operating voltage nominal  $V_{\rm DD}=1.5\,{\rm V},$   $L_{\rm min}=0.13\,\mu{\rm m},\,V_{\rm th}\approx0.5\,{\rm V};$  a triple-well option for the NMOS is available.
- Low-voltage PMOS: Device sg13\_lv\_pmos; operating voltage nominal  $V_{\rm DD}=1.5\,{\rm V},$   $L_{\rm min}=0.13\,\mu{\rm m},\,V_{\rm th}\approx-0.47\,{\rm V}.$
- High-voltage NMOS: Device sg13\_hv\_nmos; operating voltage nominal  $V_{\rm DD} = 3.3 \, {\rm V}, \, L_{\rm min} = 0.45 \, \mu {\rm m}, \, V_{\rm th} \approx 0.7 \, {\rm V};$  a triple-well option for the NMOS is available.
- High-voltage PMOS: Device sg13\_hv\_pmos; operating voltage nominal  $V_{\rm DD}=3.3\,{\rm V},\,L_{\rm min}=0.45\,\mu{\rm m},\,V_{\rm th}\approx-0.65\,{\rm V}.$
- Silicided poly resistor: Device rsil;  $R_{\square} = 7 \Omega \pm 10\%$ ,  $TC_1 = 3100 \text{ ppm/K}$
- Poly resistor: Device rppd;  $R_{\square} = 260 \,\Omega \pm 10\%$ ,  $TC_1 = 170 \,\mathrm{ppm/K}$
- Poly resistor high: Device rhigh;  $R_{\square}=1360\,\Omega\pm15\%,\,\mathrm{TC_1}=-2300\,\mathrm{ppm/K}$
- MIM capacitor: Device cap\_cmim;  $C'=1.5\,\mathrm{fF}/\mu\mathrm{m}^2\pm10\%,~\mathrm{VC_1}=-26\mathrm{ppm/V},~\mathrm{TC_1}=3.6\mathrm{ppm/K},~\mathrm{breakdown~voltage}>15\,\mathrm{V}$
- MOM capacitor: The metal stack is well-suited for MOM capacitors due to 5 thin metal layers, but no primitive capacitor device is available at this point.

#### Schematic Entry Using Xschem

Xschem is an open-source schematic entry tool with emphasis on integrated circuits. For up-to-date information of the many features of Xschem and the basic operation of it please look at the available online documentation. Usage of Xschem will be learned with the first few basic examples, essentially using a single MOSFET. The usage model of Xschem is that the schematic is hierarchically drawn, and the simulation and evaluation statements are contained in the schematics. Further, Xschem offers embedded graphing, which we will mostly use.

#### Circuit Simulation Using ngspice

ngspice is an open-source circuit simulator with SPICE dependency (Nagel 1975). Besides the usual simulated types like op (operating point), dc (dc sweeps), tran (time-domain), or ac (small-signal frquency sweeps), ngspice offers a script-like control interface, where many different simulation controls and result evaluations can be done. For detailed information please refer to the latest online manual.

#### Integrated IC Design Environment (IIC-OSIC-TOOLS)

In order to make use of the various required components (tools like Xschem and ngspice, PDKs like SG13G2) easier, we will use the **IIC-OSIC-TOOLS**. This is a pre-compiled Docker image which allows to do circuit design on a virtual machine on virtually any type of computing equipment (personal PC, Raspberry Pi, cloud server) on various operating systems (Windows, macOS, Linux). For further information like installed tools, how to setup a VM, etc. please look at IIC-OSIC-TOOLS GitHub page.



Please make sure to receive information about your personal VM access ahead of the course start.

Experienced users can install this image on their personal computer, for JKU students the IIC will host a VM on our compute cluster and provide personal login credentials.

#### Note

In this course, we assume that students have a basic knowledge of Linux and how to operate it using the terminal. If you are not yet familiar with Linux (which is basically a must when doing integrated circuit design as many tools are only available on Linux), then please check out a Linux introductory course or tutorial online, there are many ressources available.

#### First Steps

In this first chapter we will learn to use Xschem for schematic entry, and how to operate the ngspice SPICE simulator for circuit simulations. Further, we will make ourself familiar with the transistor and other passive components available in the IHP Microelectronics SG13G2 technology. While this is strictly speaking a BiCMOS technology offering MOSFETs as well as SiGe HBTs, we will use it as a pure CMOS technology.

#### The Metal-Oxide-Semiconductor Field-Effect-Transistor (MOSFET)

In this course, we will not dive into semiconductor physics and derive the device operation bottom-up starting from a fundamental level governed by quantum mechanics. Instead, we will treat the MOSFET as a macroscopic by assuming we have a 4-terminal device, and the performance of this device regarding its terminal voltages and currents we will largely derive from the simulation model.

The circuit symbol that we will use for the n-channel MOSFET is shown in Figure 1, and for the p-channel MOSFET it is shown in Figure 2. A control voltage between gate ("G") and source ("S") causes a current to flow between drain ("D") and source. The MOSFET is a 4-terminal device, so the bulk ("B") can also control the drain-source current flow. Often, the bulk is connected to source, and then the bulk terminal is not shown to declutter the schematics.

## Note

Strictly speaking is the drain-source current of a MOSFET controlled by the voltage between gate and bulk and the voltage between drain and source. Since bulk is often connected to source anyway, and many circuit designers historically were already familiar with the operation of the bipolar junction transistor, it is common to consider the gate-source voltage (besides the drain-source voltage) as the controlling voltage. This focus on gate-source implies that the source is special compared to the drain. In a typical physical MOSFET, however, the drain and source are constructed exactly the same, and which terminal is drain, and which terminal is source, is only determined by the applied voltage potentials, and can change dynamically during operation (think of a MOSFET operating as a switch... which side is the drain, which side is the source?). Unfortunately, this focus on a "special" source has made its way into some MOSFET compact models. The model that is used in SG13G2 luckily uses the PSP model, which is formulated symmetrically with regards to drain and source, and is thus very well suited for analog and RF circuit design. For a detailed understanding of the PSP model please refer to the model documentation.



Figure 1: Circuit symbol of n-channel MOSFET.



Figure 2: Circuit symbol of p-channel MOSFET.

Source: Article Notebook

For hand calculations and theoretical discussions we will use the following simplified large-signal model, shown in Figure 3. A current source  $I_{\rm DS}$  models the current flow between drain and source, and it is controlled by the three control voltages  $V_{\rm GS}, V_{\rm DS}$ , and  $V_{\rm SB}$ . Note that in this way (since  $I_{\rm DS}=f(V_{\rm DS})$ ) also a resistive behavior between D and S can be modelled. In case that B and S are shorted then simply  $V_{\rm SB}=0$ .

Source: Article Notebook



Figure 3: The MOSFET large-signal model.

In an ideal MOSFET no dc current is flowing into the gate, the behavior is purely capacitive. We model this by two capacitors:  $C_{\rm GG} = C_{\rm GS} + C_{\rm GD}$  is the total capacitance when looking into the gate of the MOSFET.  $C_{\rm GS}$  is usually the dominant capacitance, and  $C_{\rm GD}$  models the capacitive feedback between D and G, usually induced by a topological overlap capacitance in the physical construction of the MOSFET. This capacitance is often small compared to  $C_{\rm GS}$ , but in situations where we have a large voltage swing at the drain this capacitance will be affected by the Miller effect. In hand calculations we will often set  $C_{\rm GD} = 0$ .

#### Note

The bulk connection in Figure 3 seems floating as we only consider it a control terminal, where the potential difference between source and bulk influences the behaviour of the MOSFET. However, we do not consider resistive or capacitive effects associated with this node, which is of course a gross simplification, but nevertheless one we will make in this course.

Now, as we are skipping the bottom-up approach of deriving the MOSFET large-signal behaviour from basic principles, we need to understand the behaviour of the elements of the large-signal model in Figure 3 by using a circuit simulator and observing what happens. And generally, a first step in any new IC technology should be to investigate basic MOSFET performance, by doing simple dc sweeps of  $V_{\rm GS}$  and  $V_{\rm DS}$  and looking at  $I_{\rm DS}$  and other large-and small-signal parameters.

As a side note, the students who want to understand MOSFET behaviour from a physical angle should consult the MOSFET chapter from the JKU course "Design of Complex Integrated Circuits" (VL 336.048). A great introduction into MOSFET operation and fabrication is given in (Hu 2010), which is available freely online and is a recommended read. A very detailed description of the MOSFET (leaving usually no question unanswered) is provided in (Tsividis and McAndrew 2011).

Now, in order to get started, basic Xschem testbenches are prepared, and first simple dc sweeps of various voltages and currents will be done. But before that, please look at the import note below!

#### Important

Throughout this material, we will stick to the following notations:

- A dc quantity is shown with an upper-case letter with upper-case subscripts, like  $V_{\rm GS}$ .
- Double-subscripts denote dc sources, like  $V_{\rm DD}$  and  $V_{\rm SS}$ .
- An ac (small-signal) quantity is a lower-case letter with a lower-case subscript, like  $g_{\rm m}$ .
- A total quantity (dc plus ac) is shown as a lowercase letter with upper-case subscript, like  $i_{DS}$ .
- A upper-case letter with a lower-case subscript is used to denote RMS quantities, like  $I_{ds}$ .

#### Large-Signal MOSFET Model

We start with an investigation into the large-signal MOSFET model shown in Figure 3 by using the simple testbench for the LV NMOS shown in Figure 4.



Figure 4: Testbench for NMOS dc sweeps.

## Exercise

Please try to execute the following steps and answer these questions:

- 1. Get the LV NMOS testbench (available at https://github.com/iic-jku/analog-circuit-design/blob/main/xschem/dc\_lv\_nmos.sch) working in your IIC-OSIC-TOOLS environment.
- 2. Make yourself familiar with Xschem (change the schematic in various ways, run a simulation, graph the result).
- 3. Make youself familiar with ngspice (run various simulations, save nets and parameters, use the embedded Xschem graphing, explore the interactive ngspice shell to look at MOSFET model parameters).
- 4. Explore the LV NMOS sg13\_lv\_nmos:
  - 1. How is  $I_{DS}$  affected by  $V_{GS}$  and  $V_{DS}$ ?
  - 2. Change W and L of the MOSFET. What is the impact on the above parameters? Can you explain the variations?
  - 3. When looking at the model parameters in ngspice, you see that there is a  $C_{\rm GD}$  and a  $C_{\rm DG}$ . Why is this, what could be the difference? Sometimes these capacitors show a negative value, why?
- 5. Build testbenches in Xschem for the LV PMOS, the HV NMOS, and the HV PMOS. Explore the different results.
  - 1. For a given W and L, which device provides more drain current? How are the capacitances related?
  - 2. If you would have to size an inverter, what would be the ideal ratio of  $W_n/W_n$ ? Will you exactly design this ratio, or are the reasons to deviate?
  - 3. There are LV and HV MOSFETs, and you investigated the difference in performance. What is the rationale when designing circuits for selection either an LV type, and when to choose an HV type?
- 6. Build a test bench to explore the body effect, start with LV NMOS.
  - 1. What happens when  $V_{\rm BS} \neq 0$ ?

#### Small-Signal MOSFET Model

As you have seen in the previous investigations, the large-signal model of Figure 3 describes the behaviour of the MOSFET across a wide range of voltages applied at the MOSFET terminals. Unfortunately, for hand analysis dealing with a nonlinear model is close to impossible, at the very least it is quite tedious.

However, for many practical situations, we bias a MOSFET with a set of dc voltages applied to its terminal, and only apply small signal excursions during operation. If we do this, we can linearize the large-signal model in this dc operating point, and resort to a small-signal model which can be very useful for hand calculations. Many experienced designers analyze

their circuits by doing these kind of hand calculations and describing the circuit analytically, which is a great way to understand fundamental performance limits and relationships between parameters.

We will use the small-signal MOSFET model shown in Figure 5 for this course. The current-source  $i_{\rm ds}=g_{\rm m}v_{\rm gs}$  models the drain current as a function of  $v_{\rm gs}$ , and the resistor  $g_{\rm ds}$  models the dependency of the drain current by  $v_{\rm ds}$ . The drain current dependency on the source-bulk voltage (the so-called "body effect") is introduced by the current source  $i_{\rm ds}=g_{\rm mb}v_{\rm sb}$ .

Source: Article Notebook



Figure 5: The MOSFET small-signal model.

Source: Article Notebook

As any electronic device the MOSFET introduces noise into the circuit. In this course we will only consider the drain-source current noise of the MOSFET, given by  $\overline{I_{\rm n}^2} = 4kT\gamma g_{\rm d0}$  ( $\overline{I_{\rm n}^2}$  is the power-spectral density of the noise in A²/Hz; k is the Boltzmann constant; T is the absolute temperature;  $\gamma$  is a parameter in simplified theory changing between  $\gamma=2/3$  in saturation and  $\gamma=1$  for triode operation;  $g_{\rm d0}$  is equal to  $g_{\rm m}$  in saturation and  $g_{\rm ds}$  in triode).

## Note

Sometimes we will refer to different operating modes of the MOSFET like "saturation" or "triode". Generally speaking, when the drain-source voltage is small, then the MOSFET acts as a resistor, and this mode of operation we call "triode" mode. When the drain-source voltage is increased, at some point the drain-source current saturates and is no longer a strong function of the drain-source voltage. This mode is called "saturation" mode. As you can see in the large-signal investigations, these transitions happen gradually, and it is difficult to define a precise point where one operating mode switches to the other one. In this sense we use terms like "triode" and "saturation" only in an approximative sense.

Now we need to see how the small-signal parameters seen in Figure 5 can be investigated and estimated using circuit simulation.

## Exercise

Please try to execute the following steps and answer the following questions:

- 1. Reuse the LV NMOS testbench (available at https://github.com/iic-jku/analogcircuit-design/blob/main/xschem/dc lv nmos.sch).
- 2. Explore the LV NMOS sg13\_lv\_nmos:

  - 1. How are  $g_{\rm m}$  and  $g_{\rm ds}$  changing when you change the dc node voltages? 2. What is the ratio of  $g_{\rm m}$  to  $g_{\rm mb}$ ? What is the physical reason behind this ratio (you might want to revisit MOSFET device physics at this point)?
  - 3. Take a look at the device capacitances  $C_{\rm gs}$  and  $C_{\rm gd}$ . Why are they important? What is the relation to  $f_T$ ? Note:  $f_T$  is the transit frequency where the current gain of the MOSFET drops to 1, and can be approximated by  $2\pi f_{\rm T} = g_{\rm m}/C_{\rm gg}.$
  - 4. Look at the drain noise current according to the MOSFET model and compare with a hand calculation of the noise. In the noise equation there is the factor  $\gamma$ , which in triode is  $\gamma = 1$  and in saturation is  $\gamma = 2/3$  according to basic text books. Which value of  $\gamma$  are you calculating? Why might it be different?
- 3. Go back to your testbench for the LVS PMOS sg13\_lv\_pmos:
  - 1. What is the difference in  $g_{\rm m}$ ,  $g_{\rm ds}$ , and other parameters between the NMOS and the PMOS? Why could they be different?

#### Conclusion

Congratulations for making it thus far! By now you should have a solid grasp of the tool handling of Xschem and ngspice, and you should be familiar with the large- and small-signal operation of both NMOS and PMOS, and the parameters describing these behaviours. If you feel you are not sufficiently fluent in these things, please go back to the beginning of Section and revisit the relevant sections, or dive into further reading about the MOSFET operation, like in (Hu 2010).

#### Transistor Sizing Using gm/ID Methodology

When designing integrated circuits it is an important question how to select various parameters of a MOSFET, like W, L, or the bias current  $I_D$ . In comparison to using discrete components in PCB design, or also compared to a bipolar junction transistor (BJT), we have these degrees of freedom, which make integrated circuit design so interesting.

Often, transistor sizing in entry-level courses is based on the square-law model, where a simple analytical equation for the drain current can be derived. However, in nanometer CMOS, the MOSFET behaviour is much more complex than these simple models. Also, this highly simplified derivations introduce concepts like the threshold voltage or the overdrive voltage, which are interesting from a theoretical viewpoint, but bear little practical use.

## Note

One of the many simplifactions of the square-law model is that the mobility of the charge carriers is assumed constant (it is not). Further, the existence of a threshold voltage is assumed, but in fact this voltage is just existing given a certain definition, and depending on definition, its value changed. In addition, in nm CMOS, the threshold voltage is a function on many thing, like W and L.

An additional shortcoming of the square-law model is that it is only valid in strong inversion, i.e. for large  $V_{\rm GS}$  where the drain current is dominated by the drift current. As soon as the gate-source voltage gets smaller, the square-law model breaks, as the drain current component based on diffusion currents gets dominant. Modern compact MOSFET models (like the PSP model used in SG13G2) use hundreds of parameters and fairly complex equations to somewhat properly describe MOSFET behaviour over a wide range of parameters like W, L, and temperature. A modern approach to MOSFET sizing is thus based on the thought to use exactly these MOSFET models, characterize them, put the resulting data into tables and charts, and thus learn about the complext MOSFET behaviour and use it for MOSFET sizing.

Being a well-established approach we select the  $g_{\rm m}/I_{\rm D}$  methodology introduced by P. Jespers and B. Murmann in (Jespers and Murmann 2017). A brief introduction is available here as well.

The  $g_{\rm m}/I_{\rm D}$  methodology has the huge advantage that is catches MOSFET behavior quite accurately over a wide range of operating conditions, and the curves look very similar for pretty much all CMOS technologies, form micrometer bulk CMOS down to nanometer FinFET devices. Of course the absolute values change, but the method applies universally.

#### **MOSFET Characterization Testbench**

In order to get the required tabulated data we use a testbench in Xschem which sweeps the terminal voltages, and records various large- and small-signal parameters, which are then stored in large tables. The testbench for the LV NMOS is shown in Figure 6, and the TB for the LV PMOS is shown in Figure 7.

We will use Jupyter notebooks to inspect the resulting data, and interpret some important graphs. This will greatly help to understand the MOSFET behaviour.

#### **NMOS Characterization**

First, we will start looking at the LV NMOS. In Section we have the corresponding graphs for the LV PMOS. In this lecture, we will only use the LV MOSFETs. While there are also the HV types available, they are mainly used for high-voltage circuits, like circuits



Figure 6: Testbench for LV NMOS  $g_{\rm m}/I_{\rm D}$  characterization.

connecting to the outside world. Here, we only will design low-voltage circuits running at a nominal supply voltage of 1.5 V, so only the LV types are of interest to us.

The first import graph is the plot of  $g_{\rm m}/I_{\rm D}$  and  $f_{\rm T}$  versus the gate-source voltage  $V_{\rm GS}$ . First let us answer the question why  $g_{\rm m}/I_{\rm D}$  is a good parameter to look at, and actually this is also the central parameter in the  $g_{\rm m}/I_{\rm D}$  methodology. In many circuits that are biased in class-A (i.e., with a constant quiescent current that is larger than the largest signal excursion, see biasing) we want to get a large amplification from a MOSFET, which corresponds to a large  $g_{\rm m}$ . We want this by spending the minimum biasing current possible (ideally zero), as we always design for minimum power consumption. Thus, a high  $g_{\rm m}/I_{\rm D}$  ratio is good.

#### Note

Designing for minimum power consumption is pretty much always mandated. For battery-operated equipment it is a paramount requirement, but also in other equipment electrical energy consumption is a concern, and often severly limited by the cooling capabilities of the electrical system.

However, as can be seen in the below plot, there exists a strong and unfortunate trade-off with device speed, characterized here by the transit frequency  $f_{\rm T}$ . It would be ideal if there exists a design point where we get high transconductance per bias current concurrently to having the fastest operation, but unfortunately, this is clearly not the case. The  $g_{\rm m}/I_{\rm D}$  peaks for  $V_{\rm GS} < 0.3\,{\rm V}$ , and the highest speed we get at  $V_{\rm GS} \approx 1.2\,{\rm V}$ . The dashed vertical

```
.save b d g n
.save (m.xml.nsg13 \ v \ pmos[cgsol]
.save (m.xml.nsg13 \ v \ pmos[cgdol]
.save (m.xml.nsg13 \ v \ pmos[cgdol]
.save (m.xml.nsg13 \ v \ pmos[cgdol]
.save (m.xml.nsg13 \ v \ pmos[cgd]
.save (m.xml.nsg13 \ v \ pmos[cgs]
.save (m.xml.nsg13 \ v \ pmos[cgs]
.save (m.xml.nsg13 \ v \ pmos[ds]
.save (m.xml.nsg13 \ v \ pmos[vgs]
.save (m.xml.nsg13 \ v \ pmos[cjd]
       .option sparse
.param temp=27
.param wx=5u lx=0.13u vbx=0
.noise v(n) vg lin 1 1 1 1
.control
option numdgt=3
set wr_singlescale
set wr_vecnames
        compose l_vec values 0.13u 0.2u 0.3u 0.4u 0.5u 1u 5u 10u compose vg_vec start= 0 stop=1.5 step=25m compose vd_vec start= 0 stop=1.5 step=25m compose vb_vec values 0 0.4 0.8 1.2
    foreach var1 $6l vec
    alterparam lx=\( \frac{5}{2}\text{var1} \)
    reset
    foreach var2 \( \frac{5}{2}\text{vg} \) vec
    alter vg \( \frac{5}{2}\text{var2} \)
    foreach var3 \( \frac{5}{2}\text{vd} \) vec
    alter vd \( \frac{5}{2}\text{var3} \)
    foreach var4 \( \frac{5}{2}\text{vb} \) vec
    alter vsb \( \frac{5}{2}\text{var4} \)
    run
    wrdata techsweep_sg13_lv_pmos.txt noise1.all
    destroy all
    set appendwrite
    unset set wr_vecnames
    end
                                                                                                                                                                                                                                      > simulate
                              end
                                                                                                                                                                                                                                                                            annotate OP
         set appendwrite=0
        alterparam lx=0.13u
alterparam vbx=0
reset
         op
*showmod
         write techsweep_sg13g2_lv_pmos.raw
                                                                                                                                                                                                                                                                                                                              sg13 lv pmos
   MODEL
.lib cornerMOSlv.lib mos_tt
                                                  XSCHEM
                                                                                                                                                                                                                        (c) 2024 Harald Pretl (adapted from Boris Murmann) 2024-08-18 13:00:18
```

NGSPICE\_SAVE

NGSPICE\_CTRL

Figure 7: Testbench for LV PMOS  $g_{\rm m}/I_{\rm D}$  characterization.

 $techsweep\_sg13g2\_lv\_pmos.sch$ 

line plots the nominal threshold voltage, as you can see in this continuum of parameter space, it marks not a particularly special point.

Note that

$$\frac{g_{\rm m}}{I_{\rm D}} = \frac{1}{nV_{\rm T}} \tag{1}$$

for a MOSFET in weak inversion (i.e., small gate-source voltage). n is the subthreshold slope, and  $V_{\rm T}=kT/q$  which is 25.8 mV at 300 K. We thus have  $n\approx 1.38$  for this LV NMOS, which falls nicely into the usual range for n of 1.3 to 1.5 for bulk CMOS (FinFET have n very close to 1).

For the classical square-law model of the MOSFET in strong inversion,  $g_{\rm m}/I_{\rm D}$  is given as

$$\frac{g_{\rm m}}{I_{\rm D}} = \frac{2}{V_{\rm GS} - V_{\rm th}} = \frac{2}{V_{\rm od}} \tag{2}$$

with  $V_{\rm th}$  the threshold voltage and  $V_{\rm od}$  the so-called "overdrive voltage."

#### Note

Why are we so often using  $300\,\mathrm{K}$  for a typical condition? As this corresponds to roughly  $27^{\circ}\mathrm{C}$ , this accounts for some self heating compared to otherwise usual room temperatures. Further, engineers like round numbers which are easy to remember, so  $300\,\mathrm{K}$  is used as a proxy for room temperature.

As we can also see from belows plot, the peak transit frequency of the LV NMOS is about 75 GHz, which allows building radio-frequency circuits up to ca.  $f_{\rm T}/10=7.5\,{\rm GHz}$ , which is a respectible number. It is no coincidence, that the transition for RF design in the GHz-range switched from BJT-based technologies to CMOS roughly in the timeframe when 130nm CMOS became available (ca. 2000).



The following figure plots  $f_{\rm T}$  against  $g_{\rm m}/I_{\rm D}$  for several different L. As you can see, device speeds maximizes for a low  $g_{\rm m}/I_{\rm D}$  and a short L. As you can see the drain-source voltage is kept at  $V_{\rm DS}=0.75\,{\rm V}=V_{\rm DD}/2$ , which is a typical value keeping the MOSFET in saturation across the characterization sweeps. Further, the source-bulk voltage is kept at  $V_{\rm SB}=0\,{\rm V}$ , which means bulk and source terminals are connected.



The next plot shows the ratio of  $g_{\rm m}/g_{\rm ds}$  versus  $g_{\rm m}/I_{\rm D}$ . The ratio  $g_{\rm m}/g_{\rm ds}$  is the so-called "self-gain" of the MOSFET, and shows the maximum voltage gain we can achieve in a single transistor configuration. As one can see the self gain increases for increasing L, but this also gives a slower transistor, so again there is a trade-off. This plot allows us to select the proper L of a MOSFET if we know which amount of self gain we need.



The following figure plots the drain current density  $I_{\rm D}/W$  as a function of  $g_{\rm m}/I_{\rm D}$  and L. With this plot we can find out how to set the W of a MOSFET once we know the biasing current  $I_{\rm D}$ , the L (selected according to self gain,  $f_{\rm T}$ , and other considerations) and the  $g_{\rm m}/I_{\rm D}$  design point we selected. The drain current density  $I_{\rm D}/W$  is a very useful nomalized metric to use, because the physical action in the MOSFET establishes a charge density in the channel below the gate, and the changing of the W of the device merely transforms this charge density into an absolute parameter (together with L).



The following plot shows the minimum drain-source voltage  $V_{\rm ds,sat}$  that we need to establish in order to keep the MOSFET in saturation. As you can see, this value is almost independent of L, and increases for small  $g_{\rm m}/I_{\rm D}$ . So for low-voltage circuits, where headroom is precious, we tend to bias at  $g_{\rm m}/I_{\rm D} \geq 10$ , wheres for fast circuits we need to go to small  $g_{\rm m}/I_{\rm D} \leq 5$  requiring substantial voltage headroom per MOSFET stage that we stack on top of each other.



For analog circuits the noise performance is usually quite important. Thermal noise of a resistor (the Johnson-Nyquist noise) has a flat power-spectral density (PSD) given by  $\overline{V_{\rm n}^2}/\Delta f = 4kTR$ , where k is Boltzmann's constant, T absolute temperature, and R the value of the resistor (the unit of  $\overline{V_{\rm n}^2}/df$  is  $V^2/{\rm Hz}$ ). This PSD is essentially flat until very high frequencies where quantum effects start to kick in.

## i Note

We usually leave the  $\Delta f$  away for a shorter notation, so we write  $\overline{V_n^2}$  when we actually mean  $\overline{V_n^2}/\Delta f$ .

Please also note that the pair of kT pretty much always shows up together, so when you do a calculation and you miss the one or the other, that is often a sign for miscal-culation

Fuerther, when working with PSD there is the usage of a one-sided (f runs from 0 to  $\infty$ ) or two-sided PSD (f runs from  $-\infty$  to  $\infty$ ). The default in this lecture is the usage of a **one-sided PSD**.

In this lecture the only MOSFET noise we consider is the drain noise, showing up as a current noise between drain and source, and given by

$$\overline{I_{\rm d.n}^2} = 4kT\gamma g_{\rm d0} \tag{3}$$

In saturation (the MOSFET operating as a current source),  $g_{d0} = g_{m}$ , whereas in triode (the MOSFET operating as a switch),  $g_{d0} = g_{ds}$ .

The factor  $\gamma$  is a function of many things (in classical theory,  $\gamma=2/3$  in saturation and  $\gamma=1$  in triode), and it is characterized in the following plot as a function of  $g_{\rm m}/I_{\rm D}$  and L. So when calculating MOSFET noise we can lookup  $\gamma$  in the below plot, and use Equation 3 to calculate the effective drain current noise.



Source: Article Notebook

In a MOSFET, unfortunately, besides the thermal noise according to Equation 3, there is also a substantial low-frequency excess noise, called "flicker noise" due to its characteristic  $\overline{I_{\rm d,nf}^2}=K_{\rm f}/f$  behaviour (this means that this noise PSD decreases versus frequency). In order to characterize this flicker noise the following plot shows the cross-over frequency  $f_{\rm co}$ , where the flicker noise is as large as the thermal noise. As can be seen in the below plot, this frequency is a strong function of L and  $g_{\rm m}/I_{\rm D}$ . Generally, the flicker noise is proportional to  $(WL)^{-1}$ , so the larger the device is, the lower the flicker noise. The parameter  $g_{\rm m}/I_{\rm D}$  largely stays constant when we keep W/L constant, so for a given  $g_{\rm m}/I_{\rm D}$  flicker noise is proportinal to  $1/L^2$ . However, increasing L lowers device speed dramatically, so here we have a trade-off between flicker-noise performance and MOSFET speed, and this can have dramatic consequences for high-speed circuits.

## Note

The physical origin of flicker noise is the crystal interface between silicon (Si) and the silicondioxide ( $SiO_2$ ). Since these are different materials, there are dangling bonds, which can capture charge charriers travelling in the channel. After a random time, these carriers are released, and flicker noise is the result. The amount of flicker noise is a function of the manufacturing process, and will generally be different between device types and wafer foundries.

As you can see in the following plot,  $f_{co}$  can reach well into the 10's of MHz for short MOSFETs, significantly degrading the noise performance of a circuit.



Source: Article Notebook

#### **PMOS Characterization**

In the following, we have the same plots as discussed in Section, but now for the PMOS.

## Note

In all PMOS plots we plot positive values for voltages and currents, to have compatible plots to the NMOS. Of course, in a PMOS, voltages and currents have different polarity

 $g_{\rm m}/I_{\rm D}$  and  $f_{\rm T}$  versus the gate-source voltage  $V_{\rm GS}$ :



Source: Article Notebook

 $f_{\rm T}$  against  $g_{\rm m}/I_{\rm D}$  for several different L. One can see significantly lower top speed for the PMOS compared to the NMOS, which means for high-speed circuits the NMOS should be used.



 $g_{\rm m}/g_{\rm ds}$  versus  $g_{\rm m}/I_{\rm D}$ . Unfortunately, one can see a modelling error for the PMOS in this plot. The self gain  $g_{\rm m}/g_{\rm ds}$  reaches non-physical values, which indicates an issue with the  $g_{\rm ds}$  modelling for the PMOS. We can not use these values for our circuit sizing, so we will use the respective NMOS plots also for the PMOS.

## ! Important

This example shows how important it is to benchmark the device models when starting to use a new technology. Modelling artifacts like the one shown are quite often happening, as setting up the device compact models and parametrizing them according to measurement data is a very complex task. In any case, just be aware that modelling issues could exist in whatever PDK you are using!



Drain current density  $I_{\rm D}/W$  as a function of  $g_{\rm m}/I_{\rm D}$  and  $L\!\!:$ 



Minimum drain-source voltage  $V_{\rm ds,sat}$  versus  $g_{\rm m}/I_{\rm D}$  and L:



Noise factor  $\gamma$  versus  $g_{\rm m}/I_{\rm D}$  and  $L\!\!:$ 



Flicker noise corner frequency  $f_{\rm co}$  versus  $g_{\rm m}/I_{\rm D}$  and L. If you compare this figure carefully with the NMOS figure you can see that for some operating points the flicker noise for the PMOS is lower than for the NMOS. This is often true for CMOS technologies, so it can be an advantage to use a PMOS transistor in places where flicker noise is critical, like an OTA input stage. Using PMOS has the further advantage that the bulk node can be tied to source (which for NMOS is only possible in a triple-well technology, which is often not available), which gets rid of the body effect.



## First Circuit: MOSFET Diode

The first (simple) circuit we will investigate is a MOSFET, where the gate is shorted with a drain, a so-called MOSFET "diode", which is shown in Figure 8. This diode is one half of a current mirror, which we will investigate in a future section.

Source: Article Notebook



Figure 8: A MOSFET connected as a diode.

Why looking at a single-transistor circuit at all? By starting with the simplest possible circuit we can develop important skills in circuit analysis (setting up and calculating a small-signal model, calculating open-loop gain, calculate noise) and Xschem/ngspice simulation testbench creation. We safely assume that also the Mona Lisa was not Leonardo da Vinci's first painting, so let's start slow.

This diode is usually biased by a current source, shown as  $I_{\rm bias}$  in the figure. Depending on MOSFET sizing with W and L, a certain gate-source voltage  $V_{\rm GS}$  will develop. This voltage can be used as a biasing voltage for other circuit parts, for example.

#### Note

It is important to realize that this configuration essentially employs a feedback loop for operation. The voltage at the drain of the MOSFET is sensed by the gate, and the gate voltage changes until the  $I_{\rm D}$  is exactly equal to  $I_{\rm bias}$ . In this sense this is probably the smallest feedback circuit one can build.

#### **MOSFET Diode Sizing**

We will now build this circuit in Xschem. For sizing the MOSFET we will use the  $g_{\rm m}/I_{\rm D}$  methodology introduced in Section .



Please build a MOSFET diode circuit in Xschem where you use an LV NMOS, set  $I_{\rm bias}=20\,\mu{\rm A},\,L=0.13\,\mu{\rm m},$  and we want to use  $g_{\rm m}/I_{\rm D}=10$  (often a suitable compromise between transistor speed and  $g_{\rm m}$  efficiency).

- 1. Use the figures in Section to find out the proper value for W.
- 2. What is  $f_T$  for this MOSFET? What is the value for  $g_m$  and  $g_{ds}$ ?
- 3. Draw the circuit in Xschem, and simulate the operating point. Do the values match to the values found out before during circuit sizing?

Before continuing, please finish the previous exercise. Once you are done, compare with the below provided solution.



- 1. Using the fact that  $I_{\rm bias}=I_{\rm D}=20\,\mu{\rm A}$  and  $g_{\rm m}/I_{\rm D}=10$  directly provides  $g_{\rm m}=0.2\,{\rm mS}.$
- 2. Using the self-gain plot, we see that  $g_{\rm m}/g_{\rm ds}\approx 21$ , so  $g_{\rm ds}\approx 9.5\,\mu{\rm S}$ . The  $f_{\rm T}$  can easily be found in the respective plot to be  $f_{\rm T}=23\,{\rm GHz}$ .
- 3. The W of the MOSFET we find using the drain current density plot and the given bias current. Rounding to half-microns results in  $W=1\,\mu\mathrm{m}$ .
- 4. Since we are looking at the graphs, we further find  $\gamma=0.84,~V_{\rm ds,sat}=0.18\,\rm V,$  and  $f_{\rm co}\approx15\,\rm MHz.$
- 5. In addition, we expect  $V_{\rm GS} \approx 0.6\,{\rm V}.$

An example Jupyter notebook to extract these values accurately you can find here. An Xschem schematic for this exercise is provide as well.

#### MOSFET Diode Large-Signal Behaviour

As discussed above, the MOSFET diode configuration is essentially a feedback loop. Before we will analyse this loop in small-signal, we want to investgate how this loop settles in the time domain, and by doing this we can observe the large-signal settling behaviour. To simulate this, we change the dc bias source from the previous example to a transient current source, which we will turn on after some ns. The resulting Xschem testbench is shown in Figure 9.

In Figure 9 another interesting effect can be observed: While the turn-on happens quite rapidly (essentially the bias current source charges the gate capacitance, until the gate-source voltage is large enough that the drain current counteracts the bias current), the turn-off shows a very long settling tail. This is due to the fact that as the gate capacitance is discharged by the drain current the  $V_{\rm GS}$  drops, which in turn reduces the drain current, which will make the discharge even slower. We have an effect similar to the capacitor discharge by a diode (Hellen 2003).

It is thus generally a good idea to add power-down switches to the circuits to disable the circuit quickly by pulling floating nodes to a defined potential (usually  $V_{\rm DD}$  or  $V_{\rm SS}$ ) and to avoid long intermediate states during power down. This will also allow a turn-on from a well-defined off-state.



Figure 9: Testbench for MOSFET diode transient settling.

## **MOSFET Diode Small-Signal Analysis**

We now want to investigate the small-signal behaviour of the MOSFET diode. Based on the small-signal model of the MOSFET in Figure 5 we realize that gate and drain are shorted, and we also connect bulk to source. We can thus simplify the circit to the one shown in Figure 10.

Source: Article Notebook



Figure 10: The MOSFET diode small-signal model.

Source: Article Notebook

#### i Note

For small-signal analysis we would not need to declare one node as the ground potential. However, when doing so, and selecting the ground node strategically, we can simplify the analysis, as we usually do not formulate KCL for the ground node (as we have only N-1 independent KCL equations, N being the number of nodes of a circuit), and the potential difference equations are simpler if one node is at 0V.

For calculating the small-signal impedance of the MOSFET diode we formulate KCL at the top node to get

$$i_{\rm bias} - s C_{\rm gs} v_{\rm gs} - g_{\rm m} v_{\rm gs} - g_{\rm ds} v_{\rm gs} = 0. \label{eq:scale}$$

It follows that

$$Z_{\rm diode}(s) = \frac{v_{\rm gs}}{i_{\rm bias}} = \frac{1}{g_{\rm m} + g_{\rm ds} + sC_{\rm gs}}. \tag{4}$$

When neglecting  $g_{\rm ds}$  and at dc we get  $Z_{\rm diode}=1/g_{\rm m},$  which is an important result and should be memorized.

## ! Important

In circuit analysis it is often algebraically easier to work with conductances instead of impedances, so please remember that Ohm's law for a conductance is I = GU, and for a capacitance is I = sCU. When writing equations, it is also practical to keep sC together, so we will strive to sort terms accordingly.

Looking at Equation 4 we see that for low frequencies, the diode impedance is resistive, and for high frequencies it becomes capacitive as the gate-source capacitance starts to dominate. The corner frequency of this low-pass can be calculated as

$$\omega_{\rm c} = \frac{g_{\rm m} + g_{\rm ds}}{C_{\rm gs}} \approx \omega_{\rm T}$$

which is pretty much the transit frequency of the MOSFET!

#### **MOSFET Diode Stability Analysis**

The diode-connected MOSFET forms a feedback loop. What is the open-loop gain? For calculating it, we are breaking the loop, and apply a dummy  $C_{\rm gs}^*$  at the right side to keep the impedances correct. A circuit diagram is shown in Figure 11, we break the loop at the dotted connection. As we can see in this example, it is critically important when breaking up a loop for analysis (also for simulation!) to keep the terminal impedances the same. Only in special cases where the load impedance is very high or the driving impedance is very low is it acceptable to disregard loading effects!

Source: Article Notebook



Figure 11: The MOSFET diode small-signal circuit for open-loop analysis.

By inspecting Figure 11 we see that

$$v_{\text{out}} = -g_{\text{m}}v_{\text{in}}\frac{1}{g_{\text{ds}} + sC_{\text{gs}}}.$$

The open-loop gain  $H_{\rm ol}(s)$  is thus

$$H_{\rm ol}(s) = \frac{v_{\rm out}}{v_{\rm in}} = -\frac{g_{\rm m}}{g_{\rm ds} + sC_{\rm gs}}. \tag{5}$$

Inspecting Equation 5 we realize that

- 1. the dc gain  $g_{\rm m}/g_{\rm ds}$  is the self-gain of the MOSFET, so  $20\log(0.2\cdot10^{-3}/9.6\cdot10^{-6})=26.4\,\rm dB$ , and
- 2. there is a pole at  $\omega_{\rm p} = -g_{\rm ds}/C_{\rm gs}$ , which is at  $9.6 \cdot 10^{-6}/(2\pi \cdot 1.4 \cdot 10^{-15}) = 1.1 \, {\rm GHz}$ .

With this single pole location in  $H_{ol}(s)$  this loop is perfectly stable at under all conditions.

The question is now how to simulate this open-loop gain, and how to break the loop open in simulation? In general there are various methods, as we can use artificially large (ideal) inductors and capacitors to break loops open and still establish the correct dc operating points for the ac loop analysis. However, mimicking the correct loading can be an issue, and requires a lot of careful consideration. There is an alternative method which breaks the loop open only by adding an ac voltage source in series (thus keeps the dc operating point intact), or injects current using a current source. Based on both measurements the open-loop gain can be calculated. This is called **Middlebrook's method** (Middlebrook 1975) which is based on double injection, and we will use it for our loop simulations.

#### 🕊 Middlebrook's Method

When we want to do an open-loop gain analysis, we break the loop at one point by inserting (1) an ac voltage source, and (2) attach an ac current source, as shown in Figure 12 and Figure 13.



Figure 12: Middlebrook voltage loop gain simulation.



Figure 13: Middlebrook current loop gain simulation.

For both cases we do an ac analysis, and find the corresponding transfer functions  $T_{\rm v}$  and  $T_{\rm i}$ :

 $T_{\rm v} = -\frac{V_{\rm r}}{V_{\rm f}}$ 

and

$$T_{\mathrm{i}} = -rac{I_{\mathrm{r}}}{I_{\mathrm{f}}}$$

Then, we can calculate the closed-loop transfer function T(s) as

$$T(s) = \frac{T_{\mathrm{v}}T_{\mathrm{i}} - 1}{T_{\mathrm{v}} + T_{\mathrm{i}} + 2}$$

We now want to simulate the open-loop transfer function  $H_{\rm ol}(s)$  by using Middlebrook's method and confirm our analysis above.

#### Exercise

Please build a simulation testbench in Xschem to simulate the open-loop transfer function of the MOSFET diode. Confirm the dc gain and pole location as given by Equation 5.

If you are getting stuck you can look at this Xschem testbench, shown in Figure 14.



From simulation we see that the open-loop gain is  $24.9 \, dB$  at low frequencies, which matches quite well our prediction of  $26.4 \, dB$ . In the Bode plot we see a low-pass with a  $-3 \, dB$  corner frequency of  $1.4 \, GHz$ , which again is fairly close to our prediction of  $1.1 \, GHz$ .

#### **MOSFET Diode Noise Calculation**

As a final exercise on the MOSFET diode circuit we want to calculate the output noise when we consider  $V_{\rm GS}$  the output reference voltage which is created when passing a bias current through the MOSFET diode. The bias current we will assume noiseless.

We will use the small-signal circuit shown in Figure 15.

Source: Article Notebook



Figure 15: The MOSFET diode small-signal model with drain noise source.

As we have already calculated the small-signal diode impedance in Equation 4 we will use this result, and just note that the drain current noise of the MOSFET flows through this impedance. The noise voltage at  $v_{\rm gs}$  is this given as

$$\overline{V_{\mathrm{n}}^2} = Z_{\mathrm{diode}}^2 \overline{I_{\mathrm{n.d}}^2}.$$

The drain current noise of the MOSFET is given as (introduced in @#sec-mosfet-smallsignal-model)

$$\overline{I_{\rm n,d}^2} = 4kT\gamma g_{\rm m}.$$

For low frequencies (ignoring  $g_{\rm ds}$  and  $C_{\rm gs}$ ) we get

$$\overline{V_{\rm n}^2} = Z_{\rm diode}^2 \overline{I_{\rm n,d}^2} = \frac{1}{g_{\rm m}^2} 4kT\gamma g_{\rm m} = \frac{4kT\gamma}{g_{\rm m}}$$

which is the thermal noise of a resistor of value  $1/g_{\rm m}$  enhanced by the factor  $\gamma$ .

We now calculate the full equation, and after a bit of algebra arrive at

$$\overline{V_{\rm n}^2}(f) = \frac{4kT\gamma g_{\rm m}}{(g_{\rm m} + g_{\rm ds})^2 + (2\pi f C_{\rm gs})^2}.$$
 (6)

If we are interested in the PSD of the noise then Equation 6 gives us the result. If we are interested in the rms value (the total noise) we need to integrate this equation.

$$\int_0^\infty \frac{a}{b^2 + (cf)^2} df = \frac{\pi a}{2bc}$$

Using the integral help from the previous info box, we can easily get at

$$V_{\rm n,rms}^2 = \int_0^\infty \overline{V_{\rm n}^2}(f)df = \frac{kT\gamma g_{\rm m}}{(g_{\rm m} + g_{\rm ds})C_{\rm gs}}.$$
 (7)

The form of Equation 7 is the exact solution, but we gain additional insight if we assume that  $g_{\rm m}+g_{\rm ds}\approx g_{\rm m}$  and then

$$V_{\rm n,rms}^2 = \frac{kT\gamma}{C_{\rm os}}.$$
 (8)

Inspecting Equation 8 we see our familiar kT/C noise enhanced by the factor  $\gamma!$  Calculating this value for our MOSFET diode we get  $\sqrt{V_{\rm n,rms}^2} = \sqrt{1.38 \cdot 10^{-23} \cdot 300 \cdot 0.84/1.4 \cdot 10^{-15}} = 1.58 \, {\rm mV}$ , which is a sizeable value! We run circuits in this technology at  $V_{\rm DD} = 1.5 \, {\rm V}$ , which leaves us with a signal swing of ca.  $1.1 \, {\rm V_{pp}}$ , resulting in a dynamic range in this case of  $20 \log(1.58 \cdot 10^{-3}/0.39) \approx -48 \, {\rm dB}$ .

#### Important

Large BW circuits can integrate noise over a wide bandwidth resulting in considerable rms noise.



Please build a simulation testbench in Xschem to simulate the noise performance of the MOSFET diode, and confirm the rms noise value that we just calculated. Look at the rms value and the PSD of the noise, and play around with the integration limits. What is the effect? Can you see the flicker noise in the PSD? How much is its contribution to the rms noise?

If you are getting stuck you can look at this Xschem testbench, shown in Figure 16.



#### Conclusion

In this section we investigated the simple MOSFET-diode circuit. We learned important skills like how to derive a small-signal model, how to calculate important features like noise and open-loop gain for stability analysis. We introduced Middlebrook's method to have a mechanism to open up loops in simulation (and calculation) without disturbing operating points for change loading conditions.

If you feel that you have not yet mastered these topics or are uncertain in the operation of ngspice, please go back to the beginning of the section and read through the theory and redo the exercises.

**Current Mirror** 

**Differential Pair** 

Cascode Stage

A Basic 5-Transistor OTA

A Fully-Differential OTA

Biasing the OTA

An RC-OPAMP Filter

**Summary & Conclusion** 

Appendix: ngspice Cheat Sheet

**Appendix: Xschem Cheat Sheet** 

Source: Article Notebook

Hellen, Edward H. 2003. "Verifying the diode–capacitor circuit voltage decay." *American Journal of Physics* 71 (8): 797–800. https://doi.org/10.1119/1.1578070.

Hu, Chenming. 2010. Modern Semiconductor Devices for Integrated Circuits. Pearson.

Jespers, Paul G. A., and Boris Murmann. 2017. Systematic Design of Analog CMOS Circuits: Using Pre-Computed Lookup Tables. Cambridge University Press.

Middlebrook, R. D. 1975. "Measurement of loop gain in feedback systems." *International Journal of Electronics* 38 (4): 485–512. https://doi.org/10.1080/00207217508920421.

Nagel, Laurence W. 1975. "SPICE2: A Computer Program to Simulate Semiconductor Circuits." PhD thesis, EECS Department, University of California, Berkeley. http://www2.eecs.berkeley.edu/Pubs/TechRpts/1975/9602.html.

Tsividis, Yannis, and Colin McAndrew. 2011. Operation and Modeling of the MOS Transistor. Oxford University Press.