# SYNTHESIS OF TRANSLINEAR ANALOG SIGNAL PROCESSING SYSTEMS 

A Dissertation<br>Presented to the Faculty of the Graduate School of Cornell University in Partial Fulfillment of the Requirements for the Degree of Doctor of Philosophy

© 2004 Eric John McDonald
ALL RIGHTS RESERVED

# SYNTHESIS OF TRANSLINEAR ANALOG SIGNAL PROCESSING SYSTEMS 

Eric John McDonald, Ph.D.<br>Cornell University 2004

Even in the predominantly digital world of today, analog circuits maintain a significant and necessary role in the way electronic signals are generated and processed. A straightforward method for synthesizing analog circuits would greatly improve the way that analog circuits are currently designed. In this dissertation, I build upon a synthesis methodology for translinear circuits originally introduced by Bradley Minch that uses multiple-input translinear elements (MITEs) as its fundamental building block. Introducing a graphical representation for the way that MITEs are connected, the designer can get a feel for how the equations relate to the physical circuit structure and allows for a visual method for reducing the number of transistors in the final circuit. Having refined some of the synthesis steps, I illustrate the methodology with many examples of static and dynamic MITE networks. For static MITE networks, I present a squaring reciprocal circuit and two versions of a vector magnitude circuit. A first-order log-domain filter and an RMS-to-DC converter are synthesized showing two first-order systems, both linear and non-linear. Higher order systems are illustrated with the synthesis of a second-order log-domain filter and a quadrature oscillator. The resulting circuits from several of these examples are combined to form a phase-locked loop (PLL). I present simulated and experimental results from many of these exam-
ples. Additionally, I present information related to the process of programming the floating-gate charge for the MITEs through the use of Fowler-Nordheim tunneling and hot-electron injection. I also include code for a Perl program that determines the optimum connections to minimize the total number of MITEs for a given circuit.

## Biographical Sketch

Having grown up in Pittsburgh, PA, Eric John McDonald remained there to receive his Bachelors of Science degree in Electrical Engineering from the University of Pittsburgh in May, 1998. Continuing his education at Cornell University, he received his Masters of Science degree in Electrical Engineering in May, 2002. He is moving back to Pittsburgh to be closer to friends and family and to find a job working in the engineering industry.

I would like to dedicate this dissertation to my parents, John and Sally
McDonald, my brother and his wife, Michael and Heather McDonald, and to my Creator.

## Acknowledgements

I would like to express my thanks to my advisor, Bradley Minch. While not only advising me along my path towards completion, he has spent countless hours teaching me both in the classroom and in one on one conversations. Additionally, his previous work provided the foundation upon which I based my dissertation.

I would like to thank Paul Hasler for his assistance in learning the art of programming the mysterious floating-gate transistor.

I would like to thank Rajit Manohar, Mark Heinrich, and Alyssa Apsel for serving on my advising committee.

I would like to thank Livia Gilstrap and Sarah Spence for their advice and guidance on various aspects of completing a graduate degree at Cornell University.

I would like to thank my parents, John and Sally McDonald, who would have supported me down whatever road in life I had chosen. Their example has been a guiding force in my life. I would also like to thank my brother and his wife, Michael and Heather McDonald, who have taught me things that can not be found in any dissertation. Lastly, I would like to express my thanks to the Lord. Without the family, friends, and countless blessings He has provided in my life, I could not have made it this far.

The following work was supported under the NSF Career award CCR-9984625.

## Table of Contents

1 Analog Circuit Design ..... 1
1.1 Analog Signal Processing ..... 2
1.2 Analog Versus Digital ..... 3
1.3 Why Translinear? ..... 6
1.4 Multiple-Input Translinear Elements ..... 7
1.5 MITE Fundamentals ..... 8
1.6 Circuit Synthesis Overview ..... 10
2 Static MITE Networks ..... 11
2.1 Squaring Reciprocal Circuit ..... 12
2.1.1 System Decomposition ..... 12
2.1.2 Translinear Loops ..... 14
2.1.3 Biasing ..... 14
2.1.4 Diode Connections ..... 15
2.2 Vector Magnitude ..... 15
2.2.1 System Decomposition ..... 16
2.2.2 Translinear Loops ..... 16
2.2.3 Consolidation ..... 17
2.2.4 Biasing ..... 19
2.2.5 Diode Connections ..... 19
2.3 Vector Magnitude with Offsets ..... 20
2.3.1 System Decomposition ..... 20
2.3.2 Translinear Loops ..... 22
2.3.3 Consolidation ..... 23
2.3.4 Biasing ..... 25
2.3.5 Diode Connections ..... 29
3 Linear and Non-Linear First-Order Dynamic MITE Networks ..... 32
3.1 Dynamic MITE Networks ..... 32
3.2 First-Order Low-Pass Filter ..... 33
3.2.1 System Decomposition ..... 33
3.2.2 The Inverting Output Structure ..... 33
3.2.3 System Decomposition Continued ..... 36
3.2.4 Translinear Loops ..... 37
3.2.5 Biasing ..... 37
3.2.6 Diode Connections ..... 39
3.3 RMS-to-DC Converter ..... 39
3.3.1 System Decomposition ..... 40
3.3.2 Translinear Loops ..... 41
3.3.3 Consolidation ..... 42
3.3.4 Biasing ..... 45
3.3.5 Diode Connections ..... 45
4 Linear and Non-Linear Second-Order Dynamic MITE Networks ..... 47
4.1 Second-Order Low-Pass Filter ..... 47
4.1.1 System Decomposition ..... 47
4.1.2 Translinear Loops ..... 49
4.1.3 Consolidation ..... 49
4.1.4 Biasing ..... 52
4.1.5 Diode Connections ..... 52
4.2 Quadrature Oscillator ..... 54
4.2.1 System Decomposition ..... 54
4.2.2 Dynamic Constraints ..... 55
4.2.3 Translinear Loops ..... 57
4.2.4 Consolidation ..... 59
4.2.5 Biasing ..... 61
4.2.6 Diode Connections ..... 61
5 Phase-Locked Loop ..... 69
5.1 System Decomposition ..... 69
5.2 Multiplier ..... 70
5.3 Low-Pass Filter ..... 71
5.4 Inter-Network Connections ..... 74
6 Results and Conclusions ..... 79
6.1 Vector Magnitude Results ..... 80
6.2 First-Order Low-Pass Filter Results ..... 80
6.3 RMS-to-DC Converter Results ..... 82
6.4 Second-Order Low-Pass Filter Results ..... 85
6.5 Quadrature Oscillator Results ..... 85
6.6 Phase-Locked Loop Results ..... 91
6.7 Results Summary ..... 91
6.7.1 Mismatch ..... 94
6.7.2 Measurement Errors and Noise ..... 95
6.7.3 Feed Through and Higher Order Effects ..... 96
6.8 Conclusions ..... 97
6.9 Contributions ..... 98
A Programming Floating-Gate Charge ..... 100
A. 1 Programming Overview ..... 100
A. 2 Fowler-Norheim Tunneling ..... 101
A. 3 Hot-Electron Injection ..... 102
A. 4 Programming Method ..... 102
A. 5 Derivation ..... 103
A. 6 Data Collection ..... 106
A. 7 Programming Infrastructure ..... 108
B Circuit Practicalities ..... 111
B. 1 Power Supply ..... 111
B. 2 Current Levels ..... 112
B. 3 Frequency Limits and Higher Order Effects ..... 112
B. 4 General Design and Layout Techniques ..... 112
C Perl Code for Automated Consolidation ..... 114
Bibliography ..... 121

## List of Figures

1.1 Two possible MITE implementations. (a) An simple $k$-input MITE realized by a floating-gate PMOS transistor operated in weak in- version. (b) A more practical implementation including a cascode transistor (with bias voltage, $V_{c p}$ ) to reduce the Early effect and the gate-drain parasitic. All results are obtained from circuits us- ing this cascoded implementation. ..... 7
2.1 Synthesis of a squaring reciprocal circuit that computes the function $I_{z}=I_{x}^{2} / I_{y}$. (a) MITE connections according to the inverse of the relationship of powers between $I_{y}$ and $I_{x}^{2}$. (b) Additional MITE connections according to the inverse of the relationship of powers between $I_{x}^{2}$ and $I_{z}$. (c) Biasing the MITEs with the input currents for $I_{y}$ and $I_{x}$. (d) Completing the network by making local diode connections around the $I_{y}$ and $I_{x}$ MITEs to generate control gate voltages and force a signal flow to the output MITE passing $I_{z}$. . ..... 13
2.2 Circuit construction for a vector-magnitude circuit. ..... 18
2.3 Initial MITE connections for the radius calculation. ..... 24
2.4 Initial consolidations for the radius calculation. ..... 26
2.5 Final consolidated MITE network for the radius calculation. ..... 27
2.6 Final consolidated MITE network for the radius calculation. ..... 28
2.7 Biasing of the radius calculation network. ..... 30
2.8 Diode connections to complete the radius calculation network. ..... 31
3.1 Inverting output structure used to introduce a $d I / d t$ ..... 34
3.2 Circuit construction for a first-order low-pass filter. ..... 38
3.3 Initial MITE connections and consolidation for an RMS-to-DC con- verter. ..... 43
3.4 Biasing and diode connections to complete the RMS-to-DC con- verter circuit ..... 44
4.1 Initial MITE connections and consolidation during circuit construc- tion for the second-order low-pass filter. ..... 50
4.2 Biasing and diode connections for the completion of a second-order low pass filter. ..... 53
4.3 Initial connections for the "a" side of the dynamic constraint network. ..... 58
4.4 Initial connections for the "b" side of the dynamic constraint network ..... 60
4.5 Consolidations for the "a" side of the dynamic constraint network. ..... 62
4.6 Consolidations for the "b" side of the dynamic constraint network. ..... 63
4.7 Rearranged consolidated network for both the "a" and "b" sides. ..... 64
4.8 Rearranged consolidated network for both the "a" and "b" sides where the voltages, $V_{a}$ and $V_{b}$, are shared from the radius calcula- tion network. ..... 65
4.9 Diode connections for the dynamic constraints. Voltages $V_{a}$ and $V_{b}$ represent log-compressed currents and can be used to remove the two input MITEs in the radius calculation network. ..... 67
4.10 Final changes to complete the entire oscillator circuit linking the radius and dynamic sides. ..... 68
5.1 Phase-locked loop block diagram. ..... 69
5.2 Phase-locked loop block diagram. ..... 70
5.3 Construction of the multiplier circuit. (a) Initial connections. (b) Biasing for the circuit. (c) Completed circuit. ..... 72
5.4 Modified low-pass filter from Section 3.2 to include a gain of $k$. ..... 74
5.5 Connecting the output of the oscillator to the second input of the multiplier. ..... 75
5.6 Connecting the output of the oscillator to the second input of the multiplier. ..... 76
5.7 Additional circuit to generate the $\gamma$-scaled version of $I_{\tau}$. ..... 77
5.8 Connecting the output of the filter, $I_{y}$, to the oscillator to generate both $I_{\tau}$ and the scaled version, $I_{\gamma}$ ..... 78
6.1 Measured data from the vector magnitude circuit. Measured data is shown with circles and the ideal curves are shown with solid lines ..... 81
6.2 Frequency response for a first order low-pass filter ..... 82
6.3 Results from the RMS-to-DC converter circuit with a sinusoidal input signal. ..... 83
6.4 Results from the RMS-to-DC converter circuit with a sawtooth input signal. ..... 84
6.5 Frequency response for a second-order low-pass filter with various quality factors $(\mathrm{Q}=0.25,0.5,1,2)$ and an approximate corner fre- quency of 4 kHz . ..... 86
6.6 Frequency response for a second-order low-pass filter with various quality factors $(\mathrm{Q}=0.25,0.5,1,2)$ and an approximate corner fre- quency of 8 kHz . ..... 86
6.7 Frequency response for a second-order low-pass filter with various quality factors $(\mathrm{Q}=0.25,0.5,1,2)$ and an approximate corner fre- quency of 11 kHz ..... 87
6.8 Scope capture of the two oscillator outputs at 8.93 kHz . ..... 88
6.9 Scope capture of the two oscillator outputs at 40.3 kHz ..... 88
6.10 Scope capture of the two oscillator outputs at 81.7 kHz ..... 89
6.11 Plot of the relationship between the oscillation frequency and $I_{\tau}$. ..... 89
6.12 Plot of the two oscillator outputs, $I_{a}$ versus $I_{b}$, showing an approx- imate phase difference of 87.4 degrees. A perfect circle would be the equivalent of a 90 degrees phase difference. ..... 90
6.13 PLL simulation results. (a) Frequency-controlling current showing the locking behavior. (b) Traces of the input and output signals ..... 92
6.14 Experimental PLL results showing the output of the loop filter (which controls the oscillator frequency and is dominated by 60 Hz interference) and the output of the oscillator. ..... 93
6.15 Path by which a high frequency input signal could bypass the filter capacitor and show up at the output if the driving source for $V_{\text {ref }}$ does not have a low enough output impedance to keep $V_{\text {ref }}$ fixed to an effective DC potential. ..... 97
A. 1 Plots of injection data used to extra modeling parameters. ..... 107
A. 2 Programming infrastructure that allows for a global "erase" throughthe shared tunneling line, $V_{\text {tun }}$, and individual hot-electron injec-tion through the use of the MITE select signal, $\mathrm{Sel}_{i}$, control gatebus, $\mathrm{CG}_{\text {bus }}$, and drain bus, $\mathrm{D}_{\text {bus }}$. (a) MITE cell including two cas-code transistors and two transmission gates. (b) Effective MITEcell during the programming phase when both cascode voltages areturned off.110

## Chapter 1

## Analog Circuit Design

The recent technology trends for computers and electronics have been focused on pushing digital circuits toward faster clock speeds and smaller channel lengths while still using the analog circuits of yesterday. The lengthy design time required to go from system specification to circuit design has partially contributed to this setback in analog advancements. Even though the analog part of a mixed-signal circuit is generally quite small in comparison to its digital counterpart, it is essential for interfacing with the analog signals of the real world.

With the boom in wireless communications, low power supply and minimal power consumption have become extremely important. Low-power, compact analog circuits could be used to replace their bulky power-hungry digital counterparts if the design time could be reduced. Without a defined method for approaching analog circuit design, each design must be approached starting from scratch or alternately, modifications can be made to an existing circuit if the systems' functionalities match. A circuit synthesis methodology, originally introduced by Minch [20,21,24], allows for a straightforward path from a high-level system specification to transistor-level circuit design.

This methodology describes the construction of a class of circuits known as static and dynamic translinear circuits [12, 23, 30, 40]. These circuits are able to realize a wide range of systems whose behavior is described by polynomial constraints or algebraic differential equations. The following work is not intended to be a complete tutorial on the entirety of the methodology but rather to expand upon the already published work in this area. Specifically, I focus on some of the more ambiguous aspects of this methodology using many circuit examples to highlight the result of certain design decisions. Refining some of the original synthesis steps, I hope to make the methodology easier to understand and use. Additionally, I present a detailed discussion of issues related to actually realizing circuits in silicon using this methodology. For a more detailed discussion, see $[11,30]$ for translinear circuits in general and [17] for the basis of this methodology.

### 1.1 Analog Signal Processing

Whether we are willing to admit it or not, the world is not going digital anytime soon. It is probably true that $99 \%$ of the products on our shelves are fundamentally digital. Digital circuits are powerful. Digital signal processing is everywhere and its abilities seem limitless. At some point, the question changes from "Can a digital circuit do this?" to "Should a digital circuit do this?" There is no way of bypassing the fact that the world is analog. The best we can do is take an analog sensor (photo-sensitive transistors, microphones, stress sensors, etc.), run it through an analog anti-aliasing filter, and then feed it to an analog-to-digital converter. In the other direction, the minimum path would include the digital output passing through a digital-to-analog converter, a reconstruction filter, and then going into
whatever output device is required (loudspeaker, monitor, etc.). In either case, the signal either starts as being analog or ends as being analog.

If we have to deal with an analog signal anyway, it might be beneficial to also process that signal in an analog fashion either before we make it digital or instead of processing it digitally at all. In the case of wireless electronics, lowpower operation is ultimately the most important feature. A wireless phone that could automatically convert your voice into text and email it to a friend would be worthless if the battery only lasted 15 minutes. Every system designer must be aware of the total power consumption required by the system. If we can perform the same digital operations using a similar analog counterpart and reduce the power consumption, then it is surely worthwhile to explore the possibilities of analog signal processing.

### 1.2 Analog Versus Digital

In signal processing, as with most things, there is a tradeoff between power consumption and precision. For digital signal processing, increasing precision means adding more bits to the numbers which increases power consumption and complexity but does so in a linear way. For analog signal processing, increasing the precision sometimes means simply increasing the power by increasing the current levels. However, since power is a quadratic function of current level, doubling the current level to get an extra bit's worth of precision quadruples the power consumption. The real advantage of analog systems is that they use the physics of the actual devices to perform the calculations. The advantage of this is that it is possible to perform complex calculations with a relatively few number of tran-
sistors compared to the number of devices a similar digital system would require. This leads to small areas and lower power than the digital counterpart. However, the drawback is that the modeling of the physics of the devices is never exact, thereby limiting the precision of these calculations. Due to the inherent nature of digital circuits, each stage includes a full signal restoration and the only accumulated noise is a result of numerical rounding. Alternately, analog systems have to compete with temperature variations, mismatch, and offsets as well as the inaccuracies of the modeling. All of these sources of error for analog circuits accumulate throughout the entire system.

Power consumption, area (size), precision (noise), and signal frequency are the main characteristics to be examined when considering how to process a signal. Where high precision arithmetic is required, digital signal processing is most likely the better choice. If medium or low precision is all that is needed, then it is possible that analog signal processing may prove to be the more efficient option. Sarpeshkar suggests that analog signal processing is often better in power and area for applications requiring under 10 bits of precision ( $\sim 60 \mathrm{~dB}$ SNR) [38]. However, some more subtle factors play a role in determining which style is best suited for a certain application such as available tools, designer skills, and required time to market. Because there are seemingly endless ways of implementing various systems, deciding whether analog or digital signal processing is most appropriate is not obvious. If it can be accepted that there are some cases when analog signal processing is useful, then it follows that it is worthwhile to research ways of creating such analog systems in a straightforward and efficient manner.

There are many CAD tools on the market today that assist in creating digital circuits from high level circuit descriptions including programming languages like

VHDL and reconfigurable devices such as FPGA's that allow for fast prototyping. While current research is being done on various ways to synthesize analog circuits $[1,3,10,15,19,21,24,26,29,30,32,37,39,44,46,47]$, none have been proven to be able to be used for an automated method of circuit synthesis that can produce circuits that perform a wide range of functions. Often times, these techniques will only provide proper sizing and biasing for a fixed circuit topology and are not applicable to a wide range of applications. Alternately, several methods based on a variety of "analog cells" have be developed including a method based on the Bernoulli cell for log-domain filters [3] and one that uses a "tau-cell" to implement arbitrary differential equations [51]. An overview of some automated design techniques that use a cell-based method can be found in [1] and some more recent work in [16,43,47]. In spite of the ongoing work, the currently published synthesis methods are either very limited in what functions they can perform or are too complicated and unclear to be used by the average reader.

Without the aid of a straightforward synthesis methodology, if one wants to design an entire analog system from scratch, he will be investing a great deal of time and energy. The synthesis methodology described in this dissertation is intended to be concise enough to be understood by the majority of readers, allowing them to reduce the amount of time required for analog design and create a solid foundation upon which CAD tools can be designed to further lessen the required work. (Appendix C includes the code for a very rough Perl program that was written to perform part of the synthesis methodology described in this dissertation.)

### 1.3 Why Translinear?

In 1975, Barrie Gilbert coined the term translinear by noting that the transconductance for a bipolar junction transistor varies linearly with the current. This term also applies to the behavior of a MOSFET when operated in weak inversion or subthreshold. An emerging class of circuits, referred to as translinear circuits $[12,23,30,40]$, has been shown to provide a solid foundation for building circuits that can compute a large variety of functions. A subset of this class of circuits, known as log-domain filters, has also proven useful for performing various kinds of filtering operations.

Expanding upon this class of circuits, Minch developed another subset of translinear circuits using circuit elements labeled as multiple-input translinear elements (MITEs) [17]. MITEs can be implemented in a variety of fashions and lend themselves well to a double-poly process. It is also possible to implement MITEs in any single-poly process as detailed in [25]. When combined to form complex systems, these MITE networks are capable of performing numerous functions including any systems defined by algebraic differential equations and polynomial constraints. Minch further went on to develop a structured synthesis methodology for constructing MITE networks. The following pages expand upon this body of work in hopes that it will advance the understanding of how MITE networks are created, provide evidence as to their validity, and inspire further research into their development.

(a)

(b)

Figure 1.1: Two possible MITE implementations. (a) An simple $k$-input MITE realized by a floating-gate PMOS transistor operated in weak inversion. (b) A more practical implementation including a cascode transistor (with bias voltage, $V_{c p}$ ) to reduce the Early effect and the gate-drain parasitic. All results are obtained from circuits using this cascoded implementation.

### 1.4 Multiple-Input Translinear Elements

By limiting circuit construction to identical building blocks, MITEs, a straightforward synthesis methodology for analog circuits has become possible. Figure 1.1 shows two of many implementations of a $k$-input MITE. For an ideal MITE, the output current, $I$, is given by

$$
\begin{equation*}
I=I_{\mathrm{s}} \mathrm{e}^{\kappa\left(w_{1} V_{1}+\cdots+w_{k} V_{k}\right) / U_{\mathrm{T}}}, \tag{1.1}
\end{equation*}
$$

where $I_{\mathrm{s}}$ is a pre-exponential scaling current, $\kappa$ accounts for the back-gate effect, $V_{k}$ is the $k$ th input voltage, $w_{k}$ is a dimensionless positive weight that scales $V_{k}$, and $U_{\mathrm{T}}$ is the thermal voltage, $k T / q$. MITEs can be realized using a variety of transistor configurations $[17,21]$. However, to simplify schematics, for the entirety of
this dissertation, I implement MITEs using the non-cascoded floating-gate PMOS transistor, shown in Fig. 1.1(a). For all simulated and experimental results, MITEs are implemented with the cascoded implementation, shown in Fig. 1.1(b). From MITEs, we can build more complex translinear circuits, called static MITE networks $[21,22,24]$ (vector magnitude circuits, squaring-reciprocal circuits, etc.) and dynamic MITE networks (log-domain filters, oscillators, RMS-to-DC converters, etc.) $[18,20,21]$.

### 1.5 MITE Fundamentals

As mentioned in Section 1.4, we implement MITEs using floating-gate transistors. By connecting several capacitors to the floating-gate of a transistor, we gain the ability to have multiple controlling voltages. The effective floating-gate voltage can be calculated as the weighted sum of the control gate voltages. The weight of each control gate voltage is given by the ratio of that control gate capacitance to the total capacitance at the floating-gate, i.e.,

$$
\begin{equation*}
w_{i}=\frac{C_{i}}{\sum_{i=1}^{k} C_{i}+C_{\text {parasitic }}}=\frac{C_{i}}{C_{\text {total }}} \tag{1.2}
\end{equation*}
$$

Since we ultimately want to connect multiple MITEs together, we would like these control gate weights to be equal across all MITEs. With good layout techniques and adequately sized transistors and capacitors to make mismatch negligible (area of capacitors $\geq 100 \lambda^{2}$, W/L of transistors $\geq 20 / 4$ ), we can assume that the parasitic capacitance will be approximately equal for all MITEs. Using unit-sized control gate capacitors with an equal number per MITE will both swamp out variations in parasitics and create uniform weights. With these requirements, Eq. 1.2 simplifies
to

$$
\begin{equation*}
w=\frac{C_{\mathrm{cg}}}{k C_{\mathrm{cg}}+C_{\text {parasitic }}}=\frac{C_{\mathrm{cg}}}{C_{\text {total }}}, \tag{1.3}
\end{equation*}
$$

where $C_{\mathrm{cg}}$ is the capacitance for a unit-sized control gate thereby creating uniform weights for every control gate.

As shown in Fig. 1.1(a), a single floating-gate transistor could be used for MITE implementation. However, the gate-drain overlap capacitance causes this implementation to have an unacceptable performance. With floating-gate transistors, the drain voltage can be thought of as an additional controlling voltage where the gate-drain overlap capacitance determines its weight. We can remove almost all dependency on the drain voltage by using a cascode transistor, as shown in Fig. 1.1(b). This configuration also has the positive effect of drastically reducing the Early effect.

With the drain voltage's influence on the floating-gate voltage effectively removed, the floating-gate voltage can be calculated as the weighted sum of the control gate voltages plus the charge trapped on the floating-gate itself.

$$
\begin{equation*}
V_{\mathrm{fg}}=\sum_{i=1}^{k} w_{i} V_{i}+\frac{Q}{C_{\mathrm{total}}} \tag{1.4}
\end{equation*}
$$

(Since the drain voltage variance should be small and the gate-drain overlap capacitance is nearly constant over the operating range, the drain's influence on the floating-gate voltage can be approximated as being constant and therefore, can be thought of as being lumped in with the trapped charge, $Q$.)

We can derive the equation for the MITE drain current in Eq. 1.1 by substituting the expression for $V_{\mathrm{fg}}$ into the relationship between drain current and gate voltage for a subthreshold MOS transistor,

$$
\begin{equation*}
I_{\mathrm{d}}=I_{\mathrm{o}} e^{\left(\kappa V_{\mathrm{g}} / U_{\mathrm{T}}\right)} \tag{1.5}
\end{equation*}
$$

This substitution results in

$$
\begin{equation*}
I_{\mathrm{d}}=I_{\mathrm{o}} e^{\kappa\left(\sum_{i=1}^{k} w_{i} V_{i}+\frac{Q}{C_{\text {total }}}\right) / U_{\mathrm{T}}}, \tag{1.6}
\end{equation*}
$$

which can be rearranged to find the MITE current expression from Eq. 1.1 by grouping the floating-gate charge, $Q$, into the pre-exponential scaling factor, $I_{\mathrm{s}}$,

$$
\begin{equation*}
I_{\mathrm{d}}=\underbrace{I_{\mathrm{o}} e^{\kappa Q / C_{\text {total }} U_{\mathrm{T}}}}_{I_{\mathrm{s}}} e^{\kappa\left(\sum_{i=1}^{k} w_{i} V_{i}\right) / U_{\mathrm{T}}} . \tag{1.7}
\end{equation*}
$$

Note that the trapped charge on each control gate, $Q$, is not uniform across all MITEs initially and must be adjusted so that each MITE has the same value of $I_{s}$. Methods of programming the floating-gate charge are addressed in Appendix A.6.

### 1.6 Circuit Synthesis Overview

The following chapters detail the specifics of circuit synthesis for various types of systems and progress in increasing complexity. The synthesis methodology is summarized by the following overview. First, high-level system descriptions are broken down into equations of polynomial constraints and first-order differential equations. The dimensionless variables are replaced by ratios of currents. Any time derivatives are replaced with a product of currents according to an output structure primitive. These equations of currents are arranged into translinear loop (TL) equations and Kirchhoff Current Law (KCL) equations. The TL equations are used to generate connections between MITEs. Very often, several MITEs are determined to be redundant and can be removed through a process called consolidation [17]. Once the MITEs are biased with current sources and the constraints in any KCL equations, they are locally diode connected to force a signal flow and generate the proper control gate voltages, completing the circuit.

## Chapter 2

## Static MITE Networks

Due to the exponential relationship between the drain current and the control gate voltages, MITE networks are ideal for many system implementations. This exponential relationship coupled with the weighted summation at the floating-gate allows for the easy calculation of products of currents raised to various powers. Summations are computed by simply summing currents through Kirchhoff's Current Law (KCL).

The term static MITE networks refers to MITE networks whose high-level description does not include a dependency on time. In other words, the output is dependent upon the inputs to the network only and does not retain any kind of "state". Examples of static MITE networks are the squaring reciprocal circuit described by

$$
\begin{equation*}
I_{\mathrm{out}}=\frac{I_{x}^{2}}{I_{y}} \tag{2.1}
\end{equation*}
$$

and the vector magnitude circuit described by

$$
\begin{equation*}
I_{\text {out }}=\sqrt{I_{x}^{2}+I_{y}^{2}} . \tag{2.2}
\end{equation*}
$$

Sections 2.1, 2.2, and 2.3 outline the steps necessary to synthesize several example
static MITE networks.

### 2.1 Squaring Reciprocal Circuit

Our first example network will compute the function,

$$
\begin{equation*}
z=\frac{x^{2}}{y} \tag{2.3}
\end{equation*}
$$

where $z$ is the output given by the square of $x$ divided by $y$. The first step is to decompose the high-level description into a collection of translinear loop (TL) and Kirchhoff Current Law (KCL) equations.

### 2.1.1 System Decomposition

We replace the dimensionless variables, $x, y$, and $z$, by making substitutions of ratios of currents. We do so by defining a constant unit current, $I_{1}$, that represents the number 1. Making three definitions,

$$
\begin{equation*}
x=\frac{I_{x}}{I_{1}}, \quad y=\frac{I_{y}}{I_{1}}, \quad \text { and } \quad z=\frac{I_{z}}{I_{1}}, \tag{2.4}
\end{equation*}
$$

we can replace the original system description with

$$
\begin{equation*}
\frac{I_{z}}{I_{1}}=\left(\frac{I_{x}}{I_{1}}\right)^{2} \frac{I_{1}}{I_{y}} \tag{2.5}
\end{equation*}
$$

Multiplying through by $I_{1}$, we can simplify Eq. 2.5 to

$$
\begin{equation*}
I_{z}=\frac{I_{x}^{2}}{I_{y}} \tag{2.6}
\end{equation*}
$$

It is worthwhile to note that very often the unit currents will cancel out (as in this example). However, this cancellation does not always occur and therefore this step is strongly recommended for each decomposition. Next, we rearrange Eq. 2.6 to


Figure 2.1: Synthesis of a squaring reciprocal circuit that computes the function $I_{z}=I_{x}^{2} / I_{y}$. (a) MITE connections according to the inverse of the relationship of powers between $I_{y}$ and $I_{x}^{2}$. (b) Additional MITE connections according to the inverse of the relationship of powers between $I_{x}^{2}$ and $I_{z}$. (c) Biasing the MITEs with the input currents for $I_{y}$ and $I_{x}$. (d) Completing the network by making local diode connections around the $I_{y}$ and $I_{x}$ MITEs to generate control gate voltages and force a signal flow to the output MITE passing $I_{z}$.
remove any quotients, finding a single translinear loop equation (no KCL equations in this example),

$$
\begin{equation*}
I_{z} I_{y}=I_{x}^{2} \tag{2.7}
\end{equation*}
$$

### 2.1.2 Translinear Loops

MITE connections are made in a similar fashion to the clockwise/counter-clockwise method of traditional translinear circuit synthesis. For MITEs, connections are made from odd currents (left-hand side) to even currents (right-hand side). The only choices available for this simple circuit are connections from $I_{z}$ to $I_{x}$ and from $I_{y}$ to $I_{x}$. Considering the connection from $I_{y}$ to $I_{x}$, we connect the control gates of two MITEs according to the inverse of the ratio of their powers. In this case, we connect two control gates from an $I_{y}$ MITE to one control gate of an $I_{x}$ MITE, as shown in Fig. 2.1(a). A connection from one control gate of the $I_{x}$ MITE is then made to two control gates of the $I_{z}$ MITE according to the relationship between $I_{x}^{2}$ and $I_{z}$. This last connection is shown in Fig. 2.1(b).

### 2.1.3 Biasing

Once all connections have been made, we need to bias the MITEs. Biasing can be completed by either adding current sources for inputs, making connections according to any KCL equations, or adding NMOS current mirrors. The convention of labelling the expected MITE current at the transistor has been adopted in order to eliminate confusion during the biasing stage. This example requires only two biasing current sources for the two inputs, $I_{x}$ and $I_{y}$. The biased circuit is shown in Fig. 2.1(c).

### 2.1.4 Diode Connections

Looking at the circuit in Fig. 2.1(c), it is obvious that nothing is driving the capacitors connecting the MITEs. In order to force these control gate voltages to the appropriate potentials such that each MITE passes the expected current, we make local connections from the drains to the control gates. These kind of connections are referred to as diode connections since they give the MITE a behavior similar to that of a diode. (An NMOS transistor with the gate and drain tied together becomes very similar to a diode.) These local feed-back connections ensure that the MITEs will pass the biasing currents. Since the output MITEs are not biased, diode connections are not made around them. There is only one possible diode connection scheme for this circuit, diode connecting around the two input MITEs ( $I_{x}$ and $I_{y}$ ). The completed circuit is shown in Fig. 2.1(d).

### 2.2 Vector Magnitude

Suppose that we need a circuit to compute the magnitude of a two-dimensional vector, $[x, y]$, where we take $x$ and $y$ to be strictly positive. The magnitude can be computed as the square root of the sum of the squares,

$$
\begin{equation*}
r=\sqrt{x^{2}+y^{2}} . \tag{2.8}
\end{equation*}
$$

One possible solution would be to use two squaring circuits whose output currents are summed at a KCL node. These summed currents can then be used as the input to a square-rooting circuit. While this straightforward method will work, we can address this problem as a complete system resulting in a more efficient design.

### 2.2.1 System Decomposition

We begin by representing the input and output signals by current ratios,

$$
\begin{equation*}
r=\frac{I_{r}}{I_{1}}, \quad x=\frac{I_{x}}{I_{1}}, \quad \text { and } \quad y=\frac{I_{y}}{I_{1}} . \tag{2.9}
\end{equation*}
$$

By substituting these representations into Eq. 2.8, we find that

$$
\begin{equation*}
\frac{I_{r}}{I_{1}}=\sqrt{\left(\frac{I_{x}}{I_{1}}\right)^{2}+\left(\frac{I_{y}}{I_{1}}\right)^{2}} \tag{2.10}
\end{equation*}
$$

which can easily be arranged to obtain

$$
\begin{equation*}
\left(\frac{I_{r}}{I_{1}}\right)^{2}=\left(\frac{I_{x}}{I_{1}}\right)^{2}+\left(\frac{I_{y}}{I_{1}}\right)^{2} \tag{2.11}
\end{equation*}
$$

Multiplying through by $I_{1}^{2}$ removes all dependency on $I_{1}$ resulting in

$$
\begin{equation*}
I_{r}^{2}=I_{x}^{2}+I_{y}^{2} \tag{2.12}
\end{equation*}
$$

Dividing through by $I_{r}$ in order to get a representation of the output current to the first power,

$$
\begin{equation*}
I_{r}=\underbrace{\frac{I_{x}^{2}}{I_{r}}}_{I_{r 1}}+\underbrace{\frac{I_{y}^{2}}{I_{r}}}_{I_{r 2}}, \tag{2.13}
\end{equation*}
$$

allows us to find the following KCL equation and two TLP equations:

$$
\begin{align*}
\mathrm{KCL}: & I_{r}=I_{r 1}+I_{r 2}  \tag{2.14}\\
\mathrm{TL}: & I_{r 1} I_{r}=I_{x}^{2} \quad I_{r 2} I_{r}=I_{y}^{2} .
\end{align*}
$$

### 2.2.2 Translinear Loops

Every circuit construction begins with the TL equations. In this case, we examine the relationships of the powers of the currents in Eq. 2.14. Noting that these two TL equations are of the same form as the equation for the squaring reciprocal circuit of Section 2.1, we can make the same control gate connections (repeated here for
clarity). Because $I_{x}$ and $I_{y}$ are raised to the second power, their connections to the other MITEs must be in a relationship of one to two. Specifically, the ratio of connections between any two alternating currents (currents on opposite sides of the equation) will be the opposite of the ratio of their powers. To list the connections more succinctly, the TL equations can be rearranged into an alternating pattern that more clearly represents the MITE connections.

$$
\begin{array}{ccc}
\text { Currents } & \text { Power ratios } & \text { Connection ratios } \\
I_{r}^{1 \leftrightarrow} \leftrightarrow I_{x}^{2} \leftrightarrow I_{r 1}^{1} & 1: 2: 1 & 2: 1: 2 \\
I_{r}^{1} \leftrightarrow I_{y}^{2} \leftrightarrow I_{r 2}^{1} & 1: 2: 1 & 2: 1: 2
\end{array}
$$

Due to the circuit's symmetry, we chose to draw the MITEs in a symmetric fashion by placing the $I_{r}$ MITEs on the outside, as shown in Fig. 2.2(a).

### 2.2.3 Consolidation

Once the MITEs have been drawn with the proper connections, it is sometimes possible to examine the circuit to remove redundant components. In this example, the $I_{r}$ MITEs on the ends in Fig. 2.2(a) are identical. Since both of their control gates are tied together and they are both passing the same current, $I_{r}$, then the voltages on the control gates must be equal. Therefore, we can remove the MITE on the right end and use only the one on the left, as shown in Fig. 2.2(b). This can be seen more clearly by examining the current-voltage relationship of a MITE (with two control gates tied together),

$$
\begin{equation*}
I_{\mathrm{d}}=I_{\mathrm{s}} e^{\kappa\left(2 w V_{c g}\right) / U_{\mathrm{T}}} . \tag{2.15}
\end{equation*}
$$

Because $I_{d}$ and $V_{c g}$ are the only varying terms, if the $I_{d}$ 's are equal, then the $V_{c g}$ 's must also be equal. A more visual method for consolidation is presented in Section 2.3.


Figure 2.2: Circuit construction for a vector-magnitude circuit.

### 2.2.4 Biasing

To bias the circuit in Fig. 2.2(b), we begin by adding current sources to the drains of the $I_{x}$ and $I_{y}$ MITEs since these are the inputs. The $I_{r 1}$ and $I_{r 2}$ MITEs are biased through the use of the KCL equation in Eq. 2.14 by tying their drains together and connecting those to an NMOS transistor that is passing $I_{r}$. Since $I_{r}$ is the output of this circuit, we must use an NMOS current mirror to sink $I_{r}$ for the KCL constraint. The output MITE (passing $I_{r}$ ) is similarly biased with an NMOS transistor sinking $I_{r}$ creating the other half of the current mirror. At this point, it does not matter which direction the current mirror is going. The direction of the current mirror is determined when the diode connections are made. Figure 2.2(c) shows the appropriate biasing additions. Simple NMOS transistors are shown in all schematics to keep them compact. For all simulated and experimental results, all NMOS transistors are cascoded to reduce gain error due to the Early effect.

### 2.2.5 Diode Connections

Diode connections must be made to force the gates (for NMOS transistors) and control gates (for MITEs) to the proper voltages. Starting with the input MITEs ( $I_{x}$ and $I_{y}$ ), we diode connect from the drains to the first control gate for each. The $I_{r}$ MITE is then diode connected leaving only the NMOS transistor below the $I_{r 1}$ and $I_{r 2}$ MITEs (the KCL node) available for diode connection. The completed circuit is shown in Fig. 2.2(d). Note that another NMOS transistor is shown to provide a mirrored copy of $I_{r}$ as an output. It would also be possible to use a MITE to mirror $I_{r}$ as an output should a current source be required instead of a current sink. Experimental results for this circuit can be found in Section 6.1.

It is possible to choose a different diode connection scheme. The behavior of all
valid schemes will still be the same to the first order. However, second order effects will cause varying performance (particularly at higher frequencies). Analyzing higher order effects for translinear circuits is an ambitious task and beyond the scope of this dissertation (even more so for MITE networks whose signal flow is primarily through capacitively coupled nodes). Limited work has been done in the analysis of higher order effects in log-domain filters by Leung [14] and Frey [10].

### 2.3 Vector Magnitude with Offsets

Thus far, I have proceeded with the unmentioned assumption that all currents are positive (as is required for MITE networks). Reconsidering the vector magnitude function of Section 2.2,

$$
\begin{equation*}
r=\sqrt{x^{2}+y^{2}} \tag{2.16}
\end{equation*}
$$

we observe that $r$ will always be positive due to the squaring functions on $x$ and $y$. However, $x$ and $y$ could take on negative values. In order to ensure strictly positive currents, we can introduce an offset to both $x$ and $y$,

$$
\begin{equation*}
a=x+f \text { and } b=y+f . \tag{2.17}
\end{equation*}
$$

Squaring both sides of Eq. 2.16 and inserting these new expressions for $x$ and $y$, we find

$$
\begin{align*}
r^{2} & =x^{2}+y^{2}=(a-f)^{2}+(b-f)^{2}  \tag{2.18}\\
& =a^{2}+b^{2}+2 f^{2}-2 f a-2 f b
\end{align*}
$$

### 2.3.1 System Decomposition

Examining Eq. 2.18, we see that the factor, $2 f$, appears in three of the five terms on the right-hand side. Recognizing that by lumping the 2 and the $f$ together when
the current ratios are introduced, the three terms containing the $2 f$ factor will only contain two terms instead of three (i.e. $I_{2 f} I_{a}$ instead of $I_{2} I_{f} I_{a}$ ). Sometimes it can prove beneficial to leave dimensionless numbers in the equations until later in the decomposition process, as demonstrated in the oscillator circuit of Section 4.2. Determining whether making such a grouping simplifies the resulting circuit is often difficult to see in advance and is usually determined only after trying several different decompositions.

Defining $I_{2 f}$ as $2 I_{f}$, we introduce current ratios and solve for $I_{r}$, obtaining

$$
\begin{equation*}
\left(\frac{I_{r}}{I_{1}}\right)^{2}=\left(\frac{I_{a}}{I_{1}}\right)^{2}+\left(\frac{I_{b}}{I_{1}}\right)^{2}+\frac{I_{2 f}}{I_{1}} \frac{I_{f}}{I_{1}}-\frac{I_{2 f}}{I_{1}} \frac{I_{a}}{I_{1}}-\frac{I_{2 f}}{I_{1}} \frac{I_{b}}{I_{1}} . \tag{2.19}
\end{equation*}
$$

Finding that every $I_{1}$ cancels out, the result simplifies to

$$
\begin{equation*}
I_{r}^{2}=I_{a}^{2}+I_{b}^{2}+I_{2 f} I_{f}-I_{2 f} I_{a}-I_{2 f} I_{b} \tag{2.20}
\end{equation*}
$$

Dividing both sides by $I_{r}$, we obtain

$$
\begin{equation*}
I_{r}=\underbrace{\frac{I_{a}^{2}}{I_{r}}}_{I_{r 1}}+\underbrace{\frac{I_{b}^{2}}{I_{r}}}_{I_{r 2}}+\underbrace{\frac{I_{2 f} I_{f}}{I_{r}}}_{I_{r 3}}-\underbrace{\frac{I_{2 f} I_{a}}{I_{r}}}_{I_{r 4}}-\underbrace{\frac{I_{2 f} I_{b}}{I_{r}}}_{I_{r 5}} . \tag{2.21}
\end{equation*}
$$

By introducting five intermediate currents, we reduce this constraint to five TL equations and one KCL equation:

$$
\begin{align*}
\mathrm{KCL}: & I_{r}=I_{r 1}+I_{r 2}+I_{r 3}-I_{r 4}-I_{r 5} \\
\mathrm{TL}: & I_{r 1} I_{r}=I_{a} I_{a} \quad I_{r 2} I_{r}=I_{b} I_{b} \quad I_{r 3} I_{r}=I_{2 f} I_{f}  \tag{2.22}\\
& I_{r 4} I_{r}=I_{2 f} I_{a} \quad I_{r 5} I_{r}=I_{2 f} I_{b} .
\end{align*}
$$

For complex networks, I have found that limiting MITEs to two control gates and only one to one connections simplifies the synthesis process allowing for easier consolidation. This also has the added benefit of removing several degrees of freedom making the automation of this synthesis methodology easier to implement. (Appendix C includes a Perl program that takes advantage of the two control gate limit
and finds the best connection scheme in order to maximize consolidation resulting in the minimum number of required MITEs.) Limiting MITEs to two control gates, we represent any currents raised to a power other than one as a repeated product, as shown in the first two TL equations in Eq. 2.22. This restriction also allows a rewording of the original Translinear Loop Principal to apply to static MITE networks:

Following the connections of control gates through a static MITE network limited to one to one connections and two control gates per MITE, the product of the currents for even MITEs is equal to the product of currents for odd MITEs when the starting and ending control gates are at the same potential.

### 2.3.2 Translinear Loops

Since we have limited MITEs to only two control gates each and one to one connections only, any currents raised to powers greater than one have been repeated (i.e., $I_{a}^{2}$ becomes $I_{a} I_{a}$ ). The first TL equation, $I_{r 1} I_{r}=I_{a} I_{a}$, can be arranged in one to one connections as

$$
\begin{equation*}
I_{r 1} \leftrightarrow I_{a} \leftrightarrow I_{r} \leftrightarrow I_{a} . \tag{2.23}
\end{equation*}
$$

This configuration leaves the end MITEs ( $I_{r 1}$ and $I_{a}$ ) without a connection to their second control gate. According to the balancing theorem [21], we can connect these unused control gates to a DC reference voltage, labeled $V_{\text {ref }}$ in Fig. 2.3. Examining
the five TL equations,

$$
\begin{align*}
& I_{r 1} I_{r}=I_{a} I_{a} \\
& I_{r 2} I_{r}=I_{b} I_{b} \\
& I_{r 3} I_{r}=I_{2 f} I_{f}  \tag{2.24}\\
& I_{r 4} I_{r}=I_{2 f} I_{a} \\
& I_{r 4} I_{r}=I_{2 f} I_{b},
\end{align*}
$$

we see that the similarities will provide us with opportunities to consolidate. We arrange the above equations into the following odd-even pairings:

$$
\begin{array}{lllllll}
I_{r} & \leftrightarrow & I_{a} & \leftrightarrow & I_{r 1} & \leftrightarrow & I_{a} \\
I_{r} & \leftrightarrow & I_{b} & \leftrightarrow & I_{r 2} & \leftrightarrow & I_{b} \\
I_{r} & \leftrightarrow & I_{2 f} & \leftrightarrow & I_{r 3} & \leftrightarrow & I_{f} \\
I_{r} & \leftrightarrow & I_{2 f} & \leftrightarrow & I_{r 4} & \leftrightarrow & I_{a} \\
I_{r} & \leftrightarrow & I_{2 f} & \leftrightarrow & I_{r 5} & \leftrightarrow & I_{b} .
\end{array}
$$

Figure 2.3 shows the layout of MITEs with these connections.

### 2.3.3 Consolidation

Looking at the MITE arrangement in Fig. 2.3, we see that the $I_{r}$ MITEs on the left can all be shared and that the $I_{a}$ MITEs along with the $I_{b}$ MITEs on the right ends can be shared. When limited to the two control gate structure, opportunities to consolidate can be seen by observing the order of currents as they accumulate from the edges and proceed inward. Any time that two or more rows of currents contain the same ordering on either end, they can be shared, as indicated below for $I_{r}, I_{a}$, and $I_{b}$ :


Figure 2.3: Initial MITE connections for the radius calculation.

$$
\begin{array}{llllllllllllll}
\boldsymbol{I}_{\boldsymbol{r}} & \leftrightarrow & I_{a} & \leftrightarrow & I_{r 1} & \leftrightarrow & I_{a} & I_{r} & \leftrightarrow & I_{a} & \leftrightarrow & I_{r 1} & \leftrightarrow & \boldsymbol{I}_{\boldsymbol{a}} \\
\boldsymbol{I}_{\boldsymbol{r}} & \leftrightarrow & I_{b} & \leftrightarrow & I_{r 2} & \leftrightarrow & I_{b} & I_{r} & \leftrightarrow & I_{b} & \leftrightarrow & I_{r 2} & \leftrightarrow & \boldsymbol{I}_{\boldsymbol{b}} \\
\boldsymbol{I}_{\boldsymbol{r}} & \leftrightarrow & I_{2 f} & \leftrightarrow & I_{r 3} & \leftrightarrow & I_{f} & I_{r} & \leftrightarrow & I_{2 f} & \leftrightarrow & I_{r 3} & \leftrightarrow & I_{f} \\
\boldsymbol{I}_{\boldsymbol{r}} & \leftrightarrow & I_{2 f} & \leftrightarrow & I_{r 4} & \leftrightarrow & I_{a} & I_{r} & \leftrightarrow & I_{2 f} & \leftrightarrow & I_{r 4} & \leftrightarrow & \boldsymbol{I}_{\boldsymbol{a}} \\
\boldsymbol{I}_{\boldsymbol{r}} & \leftrightarrow & I_{2 f} & \leftrightarrow & I_{r 5} & \leftrightarrow & I_{b} & I_{r} & \leftrightarrow & I_{2 f} & \leftrightarrow & I_{r 5} & \leftrightarrow & \boldsymbol{I}_{\boldsymbol{b}} .
\end{array}
$$

The removal of the redundant MITEs is shown in Fig. 2.4. Looking towards the insides from the left side, we see that several of the $I_{2 f}$ 's can be shared as highlighted below.

$$
\begin{array}{lllllll}
I_{r} & \leftrightarrow & I_{a} & \leftrightarrow & I_{r 1} & \leftrightarrow & I_{a} \\
I_{r} & \leftrightarrow & I_{b} & \leftrightarrow & I_{r 2} & \leftrightarrow & I_{b} \\
I_{r} & \leftrightarrow & \boldsymbol{I}_{2 f} & \leftrightarrow & I_{r 3} & \leftrightarrow & I_{f} \\
I_{r} & \leftrightarrow & I_{2 f} & \leftrightarrow & I_{r 4} & \leftrightarrow & I_{a} \\
\boldsymbol{I}_{\boldsymbol{r}} & \leftrightarrow & \boldsymbol{I}_{2 f} & \leftrightarrow & I_{r 5} & \leftrightarrow & I_{b}
\end{array}
$$

The final MITE network has been reduced to 12 MITEs from the original 20. The currents highlighted below indicate the MITEs that remain after all consolidations have been completed. The reduced MITE network is shown in Fig. 2.5.

$$
\begin{array}{ccccccc}
\boldsymbol{I}_{\boldsymbol{r}} & \leftrightarrow & \boldsymbol{I}_{\boldsymbol{a}} & \leftrightarrow & \boldsymbol{I}_{\boldsymbol{r} 1} & \leftrightarrow & \boldsymbol{I}_{\boldsymbol{a}} \\
I_{r} & \leftrightarrow & \boldsymbol{I}_{\boldsymbol{b}} & \leftrightarrow & \boldsymbol{I}_{\boldsymbol{r} 2} & \leftrightarrow & \boldsymbol{I}_{\boldsymbol{b}} \\
I_{r} & \leftrightarrow & \boldsymbol{I}_{2 f} & \leftrightarrow & \boldsymbol{I}_{r 3} & \leftrightarrow & \boldsymbol{I}_{\boldsymbol{f}} \\
I_{r} & \leftrightarrow & I_{2 f} & \leftrightarrow & \boldsymbol{I}_{\boldsymbol{r}} & \leftrightarrow & I_{a} \\
I_{r} & \leftrightarrow & I_{2 f} & \leftrightarrow & \boldsymbol{I}_{\boldsymbol{r}} & \leftrightarrow & I_{b}
\end{array}
$$

### 2.3.4 Biasing

The MITEs from Fig. 2.5 have been rearranged into an array, shown in Fig. 2.6. Biasing for this circuit is very straightforward. Placing current sources for all of


Figure 2.4: Initial consolidations for the radius calculation.


Figure 2.5: Final consolidated MITE network for the radius calculation.


Figure 2.6: Final consolidated MITE network for the radius calculation.
the inputs ( $I_{a}, I_{b}, I_{f}$, and $I_{2 f}$ ) leaves only the outputs of the translinear loops and the final output, $I_{r}$. Observing that the KCL equation equates the sum of $I_{r 1}, I_{r 2}$, and $I_{r 3}$ to the sum of $I_{r 4}, I_{r 5}$, and $I_{r}$, we connect the drains of the appropriate MITEs and send these two summed currents into a current mirror by adding two NMOS transistors. The biased circuit is shown in Fig. 2.7.

### 2.3.5 Diode Connections

Making diode connections around all the MITEs passing input currents leaves just the two KCL nodes. Choosing to diode connect around the NMOS transistor passing $I_{r 4}+I_{r 5}+I_{r}$ forces us to diode connect around the $I_{r 3}$ MITE. The final circuit is shown in Fig. 2.8.


Figure 2.7: Biasing of the radius calculation network.


Figure 2.8: Diode connections to complete the radius calculation network.

## Chapter 3

## Linear and Non-Linear

## First-Order Dynamic MITE

## Networks

### 3.1 Dynamic MITE Networks

A more interesting type of MITE network is called the dynamic MITE network. These networks are identified by having a dependency on time and most easily recognized by a $d / d t$ in the system description. Some circuits that fall into this classification are RMS-to-DC converters, log-domain filters, and oscillators. Two sample system descriptions are a first-order low-pass filter,

$$
\begin{equation*}
\tau \frac{d y}{d t}=x-y \tag{3.1}
\end{equation*}
$$

and an RMS-to-DC converter,

$$
\begin{equation*}
2 \tau z \frac{d z}{d t}+z^{2}=u^{2}-2 u v+v^{2} . \tag{3.2}
\end{equation*}
$$

### 3.2 First-Order Low-Pass Filter

### 3.2.1 System Decomposition

A first-order low-pass filter of the form,

$$
\begin{equation*}
\tau \frac{d y}{d t}=x-y \tag{3.3}
\end{equation*}
$$

is a good example to demonstrate how to implement a dynamic MITE network. We can define ratios of currents to represent the variables, $x$ and $y$, given by

$$
\begin{equation*}
x=\frac{I_{x}}{I_{1}} \quad \text { and } \quad y=\frac{I_{y}}{I_{1}} . \tag{3.4}
\end{equation*}
$$

Introducing these representations, we find that

$$
\begin{equation*}
\tau \frac{d}{d t}\left(\frac{I_{y}}{I_{1}}\right)=\frac{I_{x}}{I_{1}}-\frac{I_{y}}{I_{1}}, \tag{3.5}
\end{equation*}
$$

which we can simplify by multiplying through by $I_{1}$, to obtain

$$
\begin{equation*}
\tau \frac{d I_{y}}{d t}=I_{x}-I_{y} . \tag{3.6}
\end{equation*}
$$

The form of the above equation requires us to introduce an output structure in order to generate the $d I_{y} / d t$. Either an inverting or a non-inverting output structure can be used. Experience with both kinds of output structures has indicated that the non-inverting version often requires additional transistors in order to mirror currents resulting in a more complicated circuit. Therefore, the inverting output structure, shown in Fig. 3.1 and detailed in Section 3.2.2, will be used for all dynamic MITE network examples.

### 3.2.2 The Inverting Output Structure

In order to analyze this structure (shown in Fig. 3.1) and ultimately find an expression for $d I_{\text {out }} / d t$, we represent the output current, $I_{\text {out }}$, in terms of the control


Figure 3.1: Inverting output structure used to introduce a $d I / d t$.
gate voltages, $V_{\text {ref }}$ and $V_{\text {out }}$,

$$
\begin{equation*}
I_{\text {out }}=I_{\mathrm{s}} e^{\kappa\left(w V_{\text {ref }}+w V_{\text {out }}\right) / U_{\mathrm{T}}} \tag{3.7}
\end{equation*}
$$

where $V_{\text {ref }}$ is a DC reference voltage. Similarly, the current flowing through the other MITE is represented by

$$
\begin{equation*}
I_{\mathrm{DC}}=I_{\mathrm{s}} e^{\kappa\left(w V+w V_{\mathrm{out}}\right) / U_{\mathrm{T}}} \tag{3.8}
\end{equation*}
$$

We can remove $V_{\text {out }}$ by dividing Eq. 3.7 by Eq. 3.8, obtaining

$$
\begin{equation*}
\frac{I_{\text {out }}}{I_{\mathrm{DC}}}=e^{\kappa\left(w V_{\text {ref }}+w V_{\text {out }}-w V-w V_{\text {out }}\right) / U_{\mathrm{T}}} . \tag{3.9}
\end{equation*}
$$

Solving for $I_{\text {out }}$, we find that

$$
\begin{equation*}
I_{\mathrm{out}}=I_{\mathrm{DC}} e^{\kappa\left(w V_{\mathrm{ref}}-w V\right) / U_{\mathrm{T}}} . \tag{3.10}
\end{equation*}
$$

Assuming $\kappa$ is constant (i.e., only $I_{\text {out }}$ and $V$ vary with time), the derivative of $I_{\text {out }}$ with respect to time is found to be

$$
\begin{equation*}
\frac{d I_{\mathrm{out}}}{d t}=\underbrace{I_{\mathrm{DC}} e^{\kappa\left(w V_{\mathrm{ref}}-w V\right) / U_{\mathrm{T}}}}_{I_{\mathrm{out}}}\left(-\frac{\kappa w}{U_{\mathrm{T}}}\right) \frac{d V}{d t}, \tag{3.11}
\end{equation*}
$$

which can be simplified to

$$
\begin{equation*}
\frac{d I_{\mathrm{out}}}{d t}=I_{\mathrm{out}}\left(-\frac{\kappa w}{U_{\mathrm{T}}}\right) \frac{d V}{d t} . \tag{3.12}
\end{equation*}
$$

Noticing that the capacitor current, $I_{\mathrm{C}}$, can be defined as

$$
\begin{equation*}
I_{\mathrm{C}}=C \frac{d V}{d t} \tag{3.13}
\end{equation*}
$$

we can use this expression to remove the $d V / d t$ from Eq. 3.12 to find

$$
\begin{equation*}
\frac{d I_{\mathrm{out}}}{d t}=I_{\text {out }}\left(-\frac{\kappa w}{U_{\mathrm{T}}}\right) \frac{I_{\mathrm{C}}}{C} . \tag{3.14}
\end{equation*}
$$

Multiplying both sides by $\tau$ and rearranging gives us the desired term on the lefthand side and the grouped expression on the right-hand side has units of inverse current.

$$
\begin{equation*}
\tau \frac{d I_{\mathrm{out}}}{d t}=-I_{\mathrm{out}} I_{\mathrm{C}}\left(\frac{\tau \kappa w}{U_{\mathrm{T}} C}\right) . \tag{3.15}
\end{equation*}
$$

We can define a current, $I_{\tau}$, that can be used to tune the time constant of the circuit.

$$
\begin{equation*}
I_{\tau} \equiv \frac{U_{\mathrm{T}} C}{\tau \kappa w} \tag{3.16}
\end{equation*}
$$

The final result of the analysis of this output structure is an expression for the derivative of $I_{\text {out }}$ in terms of the capacitor current and a current that controls the time constant.

$$
\begin{equation*}
\tau \frac{d I_{\mathrm{out}}}{d t}=-\frac{I_{\mathrm{out}} I_{\mathrm{C}}}{I_{\tau}} \tag{3.17}
\end{equation*}
$$

Using this expression, we can remove all time derivatives during the decomposition phase. The negative sign on the right hand side gives this structure its name, inverting output structure. The remaining chapters will assume that every output structure is of the inverting kind.

It is very important to remember that this result is only valid if the general form of the output structure is maintained. Specifically, the capacitor must connect to
the output MITE through a single MITE passing a DC current. The output MITE must also only have DC voltages connected to its "unused" control gates (shown as being connected to $V_{\text {ref }}$ in Fig. 3.1). This configuration is easily maintained by restricting the output currents to be on either end of the connection graphs with DC currents as their inner neighbors. It is a good practice to double-check that the form of the output structure has been maintained after the circuit is completed.

### 3.2.3 System Decomposition Continued

Using the expression derived from the inverting output structure, we can continue to decompose the low-pass filter description in Eq. 3.6. Note that a separate output structure is required for every derivative. See Sections. 4.1 and 4.2 for examples of higher order systems requiring multiple output structures. Replacing $\tau d I_{y} / d t$ according to the relationship in Eq. 3.17 ( $I_{\text {out }}$ is replaced with $I_{y}$ ), we find that

$$
\begin{equation*}
-\frac{I_{\mathrm{C}} I_{y}}{I_{\tau}}=I_{x}-I_{y} . \tag{3.18}
\end{equation*}
$$

Because the capacitor current, $I_{\mathrm{C}}$, is not an input current and not generated by a transistor, it cannot be a part of any TL equation. Therefore, all equations must be solved for any capacitor currents (if they are present) in order to ensure that they are only included in KCL equations. Solving for $I_{\mathrm{C}}$, we obtain

$$
\begin{equation*}
I_{\mathrm{C}}=I_{\tau}-\underbrace{\frac{I_{\tau} I_{x}}{I_{y}}}_{I_{\mathrm{TL}}}, \tag{3.19}
\end{equation*}
$$

which leaves us with the following KCL equation and TL equation:

$$
\begin{align*}
\mathrm{KCL}: & I_{\mathrm{C}}=I_{\tau}-I_{\mathrm{TL}}  \tag{3.20}\\
\mathrm{TL}: & I_{\mathrm{TL}} I_{y}=I_{\tau} I_{x} .
\end{align*}
$$

### 3.2.4 Translinear Loops

We can begin to construct this circuit by examining the TL equation shown in Eq. 3.20. Because all currents are of the first degree, we can connect them in an alternating pattern of one to one connections as shown in Fig. 3.2(a) and as detailed below:

$$
I_{x} \rightarrow I_{\mathrm{TL}} \rightarrow I_{\tau} \rightarrow I_{y} .
$$

Note that we have maintained the output structure ordering by placing the output current, $I_{y}$, on the right end with a DC current, $I_{\tau}$, as its inner neighbor.

We begin with a MITE for $I_{x}$ from the right-hand side and make a single connection to a MITE for $I_{\mathrm{TL}}$ from the left-hand side. Then using the other control gate of the $I_{\mathrm{TL}}$ MITE, we make a connection to a MITE for $I_{\tau}$ from the right-hand side. The connections are completed with a final connection from the remaining control gate of $I_{\tau}$ 's MITE to a MITE for $I_{y}$. This order was chosen because $I_{x}$ is the input and $I_{y}$ is the output thus giving a signal flow from left to right. Note that the unused control gates on both ends have been given connections that are connected to a reference voltage (also ensuring that the output structure relationship remains valid).

### 3.2.5 Biasing

Each MITE needs to be biased according to the label shown on the floating-gate transistors. We accomplish this by connecting input current sources to the drains for the $I_{x}$ and $I_{\tau}$ MITEs. The KCL equation (from Eq. 3.20) is then used to bias the $I_{\mathrm{TL}}$ MITE. Figure 3.2(b) shows the circuit with the proper biasing.


Figure 3.2: Circuit construction for a first-order low-pass filter.

### 3.2.6 Diode Connections

Since the signal flow of this circuit is very obviously left to right, we make the diode connections in the same direction starting with the input MITE passing $I_{x}$. The KCL node is then diode connected. The circuit is completed with the final diode connection of the $I_{\tau}$ MITE. Figure 3.2(c) shows the completed low-pass filter circuit and experimental data from this circuit can be found in Section 6.2.

### 3.3 RMS-to-DC Converter

Suppose that we need to implement an RMS-to-DC converter, which we can describe in the time domain with two static nonlinear constraints and a linear ordinary differential equation, given by

$$
\begin{equation*}
x=w^{2}, \quad \tau \frac{d y}{d t}+y=x, \quad \text { and } \quad z=\sqrt{y}, \tag{3.21}
\end{equation*}
$$

where $w$ is the input signal, whose RMS amplitude we want to compute, $x$ is the square of the input signal, $y$ is a low-pass filtered version of $x$, giving an approximation of the time average of the square of the input signal, and $z$ is the output of the system, giving the square-root of the time average value of the square of the input signal. We shall assume that $w$ can take on both negative and positive values. Since all variables are represented by currents and must be strictly positive, we will need to provide a DC offset, $v$, which will make positive the total input, $u=w+v$, to the circuit that computes $x$. Note that $x=w^{2}$ will always be a nonnegative quantity, so the low-pass filter only needs to be single-ended.

### 3.3.1 System Decomposition

One approach to designing such a circuit would be to synthesize separately a squaring circuit, a first-order low-pass filter, and a square-root circuit and cascade these together with current mirrors. Although this approach will work, we shall take a different tact in this example, resulting in a more efficient implementation. We begin by eliminating $x$ and $y$ from the description of the system given in Eq. 3.21. We have that

$$
\begin{equation*}
x=w^{2}, \quad y=z^{2}, \quad \text { and } \quad \frac{d y}{d t}=2 z \frac{d z}{d t} \tag{3.22}
\end{equation*}
$$

which we can substitute into the ordinary differential equation in Eq. 3.21, thereby obtaining a first-order algebraic differential equation, given by

$$
\begin{equation*}
2 \tau z \frac{d z}{d t}+z^{2}=w^{2} . \tag{3.23}
\end{equation*}
$$

However, this equation is not directly implementable as a dynamic translinear circuit because $w$ can be positive or negative. To remedy this situation, we substitute $u-v$ for $w$ into this equation and expand the right-hand side to obtain a directly-implementable equation, given by

$$
\begin{equation*}
2 \tau z \frac{d z}{d t}+z^{2}=u^{2}-2 u v+v^{2} \tag{3.24}
\end{equation*}
$$

Next, we represent $u, v$, and $z$ as ratios of signal currents to a unit current, $I_{1}$, given respectively by

$$
\begin{equation*}
u=\frac{I_{u}}{I_{1}}, \quad v=\frac{I_{v}}{I_{1}}, \quad \text { and } \quad z=\frac{I_{z}}{I_{1}} . \tag{3.25}
\end{equation*}
$$

We substitute these representations into Eq. 3.24 and after multiplying both sides of the equation by $I_{1}^{2}$, we obtain

$$
\begin{equation*}
I_{z}\left(2 \tau \frac{d I_{z}}{d t}\right)+I_{z}^{2}=I_{u}^{2}-I_{u}\left(2 I_{v}\right)+I_{v}^{2} \tag{3.26}
\end{equation*}
$$

In order to implement the time derivative in this equation, we use the inverting output structure to replace $2 \tau d I_{z} / d t$ with $-I_{z} I_{\mathrm{C}} / I_{\tau}$ to get

$$
\begin{equation*}
I_{z}\left(\frac{-I_{z} I_{\mathrm{C}}}{I_{\tau}}\right)+I_{z}^{2}=I_{u}^{2}-I_{u} I_{2 v}+I_{v}^{2} \tag{3.27}
\end{equation*}
$$

Note that we have absorbed the first 2 into the $\tau$ constant which becomes part of $I_{\tau}$,

$$
\begin{equation*}
I_{\tau}=\frac{U_{\mathrm{T}} C}{2 \tau \kappa w} \tag{3.28}
\end{equation*}
$$

and the second 2 into the offset current $I_{v}$,

$$
\begin{equation*}
I_{2 v}=2 I_{v} \tag{3.29}
\end{equation*}
$$

Solving for $I_{\mathrm{C}}$, we find

$$
\begin{equation*}
I_{\mathrm{C}}=I_{\tau}-\underbrace{\frac{I_{\tau} I_{u}^{2}}{I_{z}^{2}}}_{I_{\mathrm{TL} 1}}+\underbrace{\frac{I_{\tau} I_{u}\left(2 I_{v}\right)}{I_{z}^{2}}}_{I_{\mathrm{TL} 2}}-\underbrace{\frac{I_{\tau} I_{v}^{2}}{I_{z}^{2}}}_{I_{\mathrm{TL} 3}} . \tag{3.30}
\end{equation*}
$$

From this equation, we obtain the following KCL equation and three TL equations:

$$
\begin{align*}
\mathrm{KCL}: & I_{\mathrm{C}}=I_{\tau}-I_{\mathrm{TL} 1}+I_{\mathrm{TL} 2}-I_{\mathrm{TL} 3}  \tag{3.31}\\
\mathrm{TL}: & I_{\mathrm{TL} 1} I_{z}^{2}=I_{\tau} I_{u}^{2} \quad I_{\mathrm{TL} 2} I_{z}^{2}=I_{\tau} I_{u} I_{2 v} \quad I_{\mathrm{TL} 3} I_{z}^{2}=I_{\tau} I_{v}^{2} .
\end{align*}
$$

### 3.3.2 Translinear Loops

For this example, I have chosen to not adhere to the two control gate restriction in order to give an example where more than two control gates are used. Before we begin, it is worthwhile to point out that each of the TL equations have the same relationship between $I_{z}$ and $I_{\tau}$ (illustrated below in bold) which will provide an opportunity to simplify the network through consolidation. To take advantage of the similarity, we first make MITE connections according to the relationship between $I_{z}$ and $I_{\tau}$ and then between $I_{\tau}$ and $I_{\mathrm{TL} i}$. This arrangement maintains the
required output structure connections $\left(I_{z} \leftrightarrow I_{\tau}\right)$ and is summarized below. For this example, 3-control gate MITEs are used allowing for a connection from the $I_{\text {TL2 }}$ MITE to both the $I_{u}$ and $I_{2 v}$ MITEs, as shown on the last three lines below:


These connections are shown in Fig. 3.3(a) with all unused control gates connected to $V_{\text {ref }}$. Note that allowing more than two control gates has significantly increased the complexity of the inter-MITE connections and has also eliminated the "linear" one to one connections. (The $I_{\mathrm{TL}}$ MITE has two right neighbors instead of the usual single right neighbor.)

### 3.3.3 Consolidation

Connecting in the above order allows for the removal of several MITEs. Since there are three control gates per MITE and the connectivity is not in a straightforward left to right order, more care must be given to make sure that all sharing is valid. In this case, we can share a voltage when two MITEs are passing the same current and two of the three control gate potentials match. This observation implies that the third control gate on each MITE must be at the same potential, and therefore, can be shared. Looking at Fig. 3.3, we find that a single $I_{u}$ MITE can be shared since $V_{u 1}$ and $V_{u 2}$ must be equal. We can also share a single $I_{z}$ and a single $I_{\tau}$ MITE since nodes $V_{z 1}, V_{z 2}$, and $V_{z 3}$ must be equal which implies that nodes $V_{z \tau 1}$, $V_{z \tau 2}$, and $V_{z \tau 3}$ must also be equal. Figure 3.3(b) shows the consolidated network

(a)

(b)

Figure 3.3: Initial MITE connections and consolidation for an RMS-to-DC converter.


Figure 3.4: Biasing and diode connections to complete the RMS-to-DC converter circuit.
with the removal of those five redundant MITEs.

### 3.3.4 Biasing

The consolidated network is rearranged and shown in Fig. 3.4(a). Half of the MITEs can be biased with simple current sources $\left(I_{v}, I_{u}, I_{2 v}\right.$, and $\left.I_{\tau}\right)$. Because a current sink passing $I_{\mathrm{TL} 2}$ is required in the KCL equation, we bias the $I_{\mathrm{TL} 2}$ MITE with an NMOS current mirror. We now use the other half of that mirror in the KCL equation,

$$
\begin{equation*}
I_{\mathrm{C}}=I_{\tau}-I_{\mathrm{TL} 1}+I_{\mathrm{TL} 2}-I_{\mathrm{TL} 3}, \tag{3.32}
\end{equation*}
$$

adding a current source for $I_{\tau}$ and a capacitor. These components are connected to the two drains of the $I_{\mathrm{TL} 2}$ and $I_{\mathrm{TL} 3}$ MITEs. Figure 3.4(b) shows all biasing connections.

### 3.3.5 Diode Connections

Finally, we diode connect the MITEs by starting with those connected to current sources on the left. Choosing to diode connect the left NMOS of the $I_{\text {TL2 }}$ mirror forces us to diode connect around either the $I_{\mathrm{TL} 1}$ or $I_{\mathrm{TL} 3}$ MITE. Since the only available control gate is shared by both, a double diode connection is made at the KCL node. The final diode connection is made at the $I_{\tau}$ MITE, which also creates the inverting output structure that we were required to maintain.

The final circuit is shown in Fig. 3.4(c) where all $V_{\text {ref }}$ nodes have been connected. In practice, it is generally not wise to create any signal path that does not explicitly pass through the capacitor for a dynamic MITE network as was done when all $V_{\text {ref }}$ nodes were connected. A further explanation of reasons to avoid these kind of
connections can be found in Chapter 6. Experimental data from this circuit can be found in Section 6.3.

## Chapter 4

## Linear and Non-Linear

## Second-Order Dynamic MITE

## Networks

In this chapter, we shall consider second-order systems whose dynamics are described by a second-order algebraic differential equation (ADE) or by a system of two coupled first-order ADEs. During the initial decomposition, any high order systems must be separated into a set of first-order ADEs before continuing on with the normal decomposition process.

### 4.1 Second-Order Low-Pass Filter

### 4.1.1 System Decomposition

We can implement a second-order low-pass filter, described by

$$
\begin{equation*}
\tau^{2} \frac{d^{2} y}{d t^{2}}+\frac{\tau}{Q} \frac{d y}{d t}+y=x \tag{4.1}
\end{equation*}
$$

in much the same way as we did the first-order one by viewing it as a first-order filter embedded inside another. This way, we break down the second-order system,

$$
\begin{equation*}
\tau \frac{d}{d t} \underbrace{\left(\tau \frac{d y}{d t}+\frac{y}{Q}\right)}_{z}+y=x \tag{4.2}
\end{equation*}
$$

into two first-order systems,

$$
\begin{equation*}
\tau \frac{d z}{d t}=x-y \quad \text { and } \quad \tau \frac{d y}{d t}=z-\frac{y}{Q} \tag{4.3}
\end{equation*}
$$

We then represent the variables by current ratios to find

$$
\begin{equation*}
\tau \frac{d}{d t}\left(\frac{I_{z}}{I_{1}}\right)=\frac{I_{x}}{I_{1}}-\frac{I_{y}}{I_{1}} \quad \text { and } \quad \tau \frac{d}{d t}\left(\frac{I_{y}}{I_{1}}\right)=\frac{I_{z}}{I_{1}}-\frac{1}{Q} \frac{I_{y}}{I_{1}} . \tag{4.4}
\end{equation*}
$$

In this example, we chose to leave $Q$ as a dimensionless scaling factor because it can be combined with $I_{\tau}$ as will be shown in the next few steps. Multiplying through by $I_{1}$ simplifies the equations to

$$
\begin{equation*}
\underbrace{\tau \frac{d I_{z}}{d t}}_{-\frac{I_{\mathrm{Cz}} I_{z}}{I_{\tau}}}=I_{x}-I_{y} \quad \text { and } \quad \underbrace{\tau \frac{d I_{y}}{d t}}_{-\frac{I_{\mathrm{Cy}} I_{y}}{I_{\tau}}}=I_{z}-\frac{I_{y}}{Q} \tag{4.5}
\end{equation*}
$$

As shown above, we use the relationship for the output structure from Eq. 3.17 to remove the time derivatives. Note that multiple capacitor currents should be labeled differently, because the capacitor currents were introduced by way of two different output structures. Also, if the time constants are different, the $I_{\tau}$ currents should be labeled accordingly (not so in this example). By solving for the capacitor currents and defining the current, $I_{\tau / \mathrm{Q}}$ to be $I_{\tau} / Q$, we find

$$
\begin{equation*}
I_{\mathrm{Cz}}=\underbrace{\frac{I_{y} I_{\tau}}{I_{z}}}_{I_{\mathrm{TL} 1}}-\underbrace{\frac{I_{x} I_{\tau}}{I_{z}}}_{I_{\mathrm{TL} 2}} \quad \text { and } \quad I_{\mathrm{Cy}}=I_{\tau / \mathrm{Q}}-\underbrace{\frac{I_{z} I_{\tau}}{I_{y}}}_{I_{\mathrm{TL} 3}} . \tag{4.6}
\end{equation*}
$$

Defining TL equations as shown with the underbraces, we are left with the following final decomposed system:

$$
\begin{array}{rll}
\mathrm{KCL}: & I_{C z}=I_{T L 1}-I_{T L 2} & I_{C y}=I_{\tau / \mathrm{Q}}-I_{T L 3}  \tag{4.7}\\
\mathrm{TL}: & I_{\mathrm{TL} 1} I_{z}=I_{y} I_{\tau} & I_{\mathrm{TL} 2} I_{y}=I_{z} I_{\tau} \quad I_{\mathrm{TL} 3} I_{z}=I_{x} I_{\tau} .
\end{array}
$$

### 4.1.2 Translinear Loops

Before beginning to connect MITEs, it is useful to arrange the KCL equations in an alternating pattern to try to determine if any opportunities to consolidate MITEs exist. This is similar to factoring out common terms for algebraic manipulations. Using all one to one connections and restricting MITEs to two control gates, the connections can be arranged in the alternating odd-even order shown below. We have maintained the form for both output structures by placing the two output currents, $I_{y}$ and $I_{z}$, on the outsides with DC currents $\left(I_{\tau}\right)$ for their inner neighbors. The currents on the ends can easily be compared to look for common patterns going inwards. The following arrangement allows for the maximum amount of consolidation, as explained in Section 4.1.3. The initial connections for this arrangement is shown in Fig. 4.1(a).

$$
\begin{array}{lllllll}
I_{x} & \leftrightarrow & I_{\mathrm{TL} 2} & \leftrightarrow & I_{\tau} & \leftrightarrow & I_{z} \\
I_{y} & \leftrightarrow & I_{\mathrm{TL} 1} & \leftrightarrow & I_{\tau} & \leftrightarrow & I_{z} \\
I_{y} & \leftrightarrow & I_{\tau} & \leftrightarrow & I_{\mathrm{TL} 2} & \leftrightarrow & I_{z}
\end{array}
$$

### 4.1.3 Consolidation

As indicated below, the $I_{y}$ terms on the left end of the latter two rows imply that one of these MITEs can be removed. This consolidation arises from the fact that $V_{y 1}$ and $V_{y 2}$ in Fig. 4.1(a) must be equal. Similarly, the $I_{z}$ terms on the right end


Figure 4.1: Initial MITE connections and consolidation during circuit construction for the second-order low-pass filter.
also allow one $I_{z}$ MITE to be used for all three $I_{z}$ MITEs. This step is possible because all three $V_{z}$ voltages must also be equal.

$$
\begin{array}{lllllll}
I_{x} & \leftrightarrow & I_{\mathrm{TL} 3} & \leftrightarrow & I_{\tau} & \leftrightarrow & \boldsymbol{I}_{z} \\
\boldsymbol{I}_{y} & \leftrightarrow & I_{\mathrm{TL} 1} & \leftrightarrow & I_{\tau} & \leftrightarrow & \boldsymbol{I}_{z} \\
\boldsymbol{I}_{y} & \leftrightarrow & I_{\tau} & \leftrightarrow & I_{\mathrm{TL} 2} & \leftrightarrow & \boldsymbol{I}_{z}
\end{array}
$$

The highlighted terms below show another opportunity to consolidate. The top two rows share an $I_{\tau} I_{z}$ combination on their right ends. The top row's $I_{z}$ has already been removed, but this does not change the fact that it still matches the middle one. Thus, we can remove the $I_{\tau}$ MITE as indicated in Fig. 4.1(c). Looking at the circuit in Fig. 4.1(b), it should be fairly obvious that the $V_{\tau z}$ voltages are equal which allows us to remove one of those two $I_{\tau}$ MITEs.

$$
\begin{array}{ccccccc}
I_{x} & \leftrightarrow & I_{\mathrm{TL} 3} & \leftrightarrow & \boldsymbol{I}_{\boldsymbol{\tau}} & \ddots & \\
I_{y} & \leftrightarrow & I_{\mathrm{TL} 1} & \leftrightarrow & \boldsymbol{I}_{\boldsymbol{\tau}} & \leftrightarrow & \boldsymbol{I}_{\boldsymbol{z}} \\
& \ddots & I_{\tau} & \leftrightarrow & I_{\mathrm{TL} 2} & \ddots &
\end{array}
$$

To summarize, the original ordering is shown below on the left and the new consolidated network is shown on the right.

$$
\begin{array}{lllllllllllllll}
I_{x} & \leftrightarrow & I_{\mathrm{TL} 3} & \leftrightarrow & I_{\tau} & \leftrightarrow & I_{z} & & I_{x} & \leftrightarrow & I_{\mathrm{TL} 3} & \ddots & & \\
I_{y} & \leftrightarrow & I_{\mathrm{TL} 1} & \leftrightarrow & I_{\tau} & \leftrightarrow & I_{z} & \Rightarrow & I_{y} & \leftrightarrow & I_{\mathrm{TL} 1} & \leftrightarrow & I_{\tau} & \leftrightarrow & I_{z} \\
I_{y} & \leftrightarrow & I_{\tau} & \leftrightarrow & I_{\mathrm{TL} 2} & \leftrightarrow & I_{z} & & & \ddots & I_{\tau} & \leftrightarrow & I_{\mathrm{TL} 2} & \nrightarrow &
\end{array}
$$

Taking a closer look at the circuit in Fig. 4.1(c), we see that it is possible to remove another MITE. Thinking back to the original decomposition, we defined $I_{z}$ (or $z$ ) as the intermediate variable used to break the second-order system down into two first-order equations. Because we are not interested in what $I_{z}$ actually looks like, we can remove that MITE altogether. This does not remove the effect of having $I_{z}$ in the circuit but merely leaves this signal in a log-compressed form
at the node labeled $V_{z}$. The remaining MITEs are shown in Fig. 4.1(d). If this MITE remained until the circuit was completed, it would become obvious that it is unnecessary since it will not be diode connected (outputs are never diode connected unless mirrored) and the generated current will not be mirrored around for use elsewhere in the circuit.

### 4.1.4 Biasing

Figure 4.2(a) shows the consolidated and reduced MITEs in the same configuration but rearranged into a one dimensional array for biasing. As with all inputs, current sources are added for biasing the $I_{x}$ MITE and the two $I_{\tau}$ MITEs. The first KCL equation allows us to bias the $I_{T L 2}$ MITE with a capacitor and an NMOS transistor sinking $I_{T L 1}$. This NMOS transistor implies that it will be either the input or output of a current mirror passing $I_{T L 1}$ so another NMOS transistor is used to bias the $I_{T L 1}$ MITE. With the $I_{y}$ MITE remaining unbiased, we bias the final MITE with the second KCL equation by adding a capacitor and a current source passing $I_{\tau / Q}$.

### 4.1.5 Diode Connections

Starting at the left and forcing a left to right signal flow, we diode connect around the $I_{x}$ MITE. Choosing to diode connect around the $I_{T L 2}$ MITE forces us to also diode connect the $I_{T L 1}$ NMOS transistor. Continuing on in a straightforward left to right order, we can finish all the diode connections and complete the circuit. Figure $4.2(\mathrm{c})$ shows the completed second-order low-pass filter and experimental data can be found in Section 6.4.


Figure 4.2: Biasing and diode connections for the completion of a second-order low pass filter.

### 4.2 Quadrature Oscillator

Another useful circuit that is significantly more complicated than the earlier examples is a quadrature oscillator. There are two output signals in this system which are both sinusoidal and 90 degrees out of phase. The frequency and amplitude of these signals are controlled by inputs. Controllable oscillators have many uses and the one described in this chapter will be used in the phase-locked loop example in Chapter 5.

### 4.2.1 System Decomposition

We begin by listing the constraints for a quadrature oscillator in polar coordinates (constant radius vector of the two outputs, $r$, and frequency, $d \theta / d t$ ),

$$
\begin{equation*}
\tau \frac{d r}{d t}=\gamma r(\rho-r) \quad \text { and } \quad \tau \frac{d \theta}{d t}=1 \tag{4.8}
\end{equation*}
$$

where $\rho$ is the desired radius and $\gamma$ determines the circuit's sensitivity to deviations in the desired radius. We can transform these constraints to the Cartesian system with the following mapping:

$$
\begin{equation*}
x=r \cos (\theta) \quad \text { and } \quad y=r \sin (\theta) . \tag{4.9}
\end{equation*}
$$

Finding $d x / d t$ gives

$$
\begin{equation*}
\frac{d x}{d t}=\cos (\theta) \frac{d r}{d t}-r \sin (\theta) \frac{d \theta}{d t} \tag{4.10}
\end{equation*}
$$

Using Eqs. 4.8 and 4.9 to eliminate $\theta$ from the right-hand side results in

$$
\begin{equation*}
\frac{d x}{d t}=\frac{\gamma}{\tau} x(\rho-r)-\frac{y}{\tau} . \tag{4.11}
\end{equation*}
$$

Similarly, we can calulate $d y / d t$ as

$$
\begin{equation*}
\frac{d y}{d t}=\frac{\gamma}{\tau} y(\rho-r)+\frac{x}{\tau}, \tag{4.12}
\end{equation*}
$$

giving us the following system description:

$$
\begin{align*}
r & =\sqrt{x^{2}+y^{2}}  \tag{4.13}\\
\tau \frac{d x}{d t} & =-y+\gamma(\rho-r)  \tag{4.14}\\
\tau \frac{d y}{d t} & =x+\gamma(\rho-r) . \tag{4.15}
\end{align*}
$$

It is possible to combine the radius calculation of Eq. 4.13 into Eqs. 4.14 and 4.15 but it seems to make more sense to have a separate network calculate the radius. We have already constructed a vector magnitude circuit (with offsets applied to $x$ and $y$ ) in Section 2.3 that will be used to calculate the radius.

### 4.2.2 Dynamic Constraints

Decomposing the dynamic constraints on $x$, we add offsets and introduce current ratios for the variables in Eq. 4.14,

$$
\begin{equation*}
\tau \frac{d x}{d t}=-y+\gamma x(\rho-r) \tag{4.16}
\end{equation*}
$$

We add offsets to $x$ and $y$ (in the same way as in the vector magnitude circuit of Section 2.3), which are given by

$$
\begin{equation*}
a=x+f \quad b=y+f, \tag{4.17}
\end{equation*}
$$

finding that Eq. 4.16 becomes

$$
\begin{equation*}
\tau \frac{d(a-f)}{d t}=-(b-f)+\gamma(a-f)(\rho-r) \tag{4.18}
\end{equation*}
$$

which we can solve for $\tau d a / d t$,

$$
\begin{equation*}
\tau \frac{d a}{d t}=f-b+\gamma(a \rho-a r-f \rho+f r) \tag{4.19}
\end{equation*}
$$

Introducing current ratios, we obtain

$$
\begin{equation*}
\tau \frac{d}{d t}\left(\frac{I_{a}}{I_{1}}\right)=\frac{I_{f}}{I_{1}}-\frac{I_{b}}{I_{1}}+\gamma\left(\frac{I_{a} I_{\rho}}{I_{1}^{2}}-\frac{I_{a} I_{r}}{I_{1}^{2}}-\frac{I_{f} I_{\rho}}{I_{1}^{2}}+\frac{I_{f} I_{r}}{I_{1}^{2}}\right), \tag{4.20}
\end{equation*}
$$

and multiplying through by $I_{1}$, we find

$$
\begin{equation*}
\tau \frac{d I_{a}}{d t}=I_{f}-I_{b}+\gamma\left(\frac{I_{a} I_{\rho}}{I_{1}}-\frac{I_{a} I_{r}}{I_{1}}-\frac{I_{f} I_{\rho}}{I_{1}}+\frac{I_{f} I_{r}}{I_{1}}\right) . \tag{4.21}
\end{equation*}
$$

We chose to leave $\gamma$ as a dimensionless scaling factor that will later be combined with a DC current.

We can remove the $\tau d I_{a} / d t$ expression through the introduction of the inverting output structure of Fig. 3.1 where the output current is related to the capacitor current by

$$
\begin{equation*}
\tau \frac{d I_{a}}{d t}=-\frac{I_{a} I_{C a}}{I_{\tau}} \tag{4.22}
\end{equation*}
$$

where $I_{C a}$ is the capacitor current and $I_{\tau}$ is a function of the value of the capacitor, $\tau$, the thermal voltage, and the weighting of the MITE inputs ( $\left.I_{\tau} \equiv C U_{\mathrm{T}} / w \tau\right)$. Using this relationship and solving for the capacitor current, we obtain

$$
\begin{equation*}
I_{C a}=-\underbrace{\frac{I_{f} I_{\tau}}{I_{a}}}_{I_{a 1}}+\underbrace{\frac{I_{b} I_{\tau}}{I_{a}}}_{I_{a 2}}-\underbrace{\frac{I_{\gamma \tau} I_{\rho}}{I_{1}}}_{I_{a 3}}+\underbrace{\frac{I_{\gamma \tau} I_{r}}{I_{1}}}_{I_{a 4}}+\underbrace{\frac{I_{\gamma \tau} I_{f} I_{\rho}}{I_{a} I_{1}}}_{I_{a 5}}-\underbrace{\frac{I_{\gamma \tau} I_{f} I_{r}}{I_{a} I_{1}}}_{I_{a 6}} . \tag{4.23}
\end{equation*}
$$

By introducing intermediate currents, we obtain the following TL and KCL equations:

KCL : $\quad I_{C a}=-I_{a 1}+I_{a 2}-I_{a 3}+I_{a 4}+I_{a 5}-I_{a 6}$

$$
\begin{array}{ll}
\mathrm{TL}: & I_{a 1} I_{a}=I_{f} I_{\tau} \quad I_{a 2} I_{a}=I_{b} I_{\tau} \quad I_{a 3} I_{1}=I_{\gamma \tau} I_{\rho}  \tag{4.24}\\
& I_{a 4} I_{1}=I_{\gamma \tau} I_{r} \quad I_{a 5} I_{a} I_{1}=I_{\gamma \tau} I_{f} I_{\rho} \quad I_{a 6} I_{a} I_{1}=I_{\gamma \tau} I_{f} I_{r},
\end{array}
$$

where we define $I_{\gamma \tau}$ as $\gamma I_{\tau}$.
By following an almost identical procedure, we find the equations defining the capacitor current for the "b" side (where $y$ has been replaced with an offset variable,
$b=y+f):$

$$
\begin{equation*}
I_{C b}=\underbrace{\frac{I_{f} I_{\tau}}{I_{b}}}_{I_{b 1}}-\underbrace{\frac{I_{a} I_{\tau}}{I_{b}}}_{I_{b 2}}-\underbrace{\frac{I_{\gamma \tau} I_{\rho}}{I_{1}}}_{I_{b 3}}+\underbrace{\frac{I_{\gamma \tau} I_{r}}{I_{1}}}_{I_{b 4}}+\underbrace{\frac{I_{\gamma \tau} I_{f} I_{\rho}}{I_{b} I_{1}}}_{I_{b 5}}-\underbrace{\frac{I_{\gamma \tau} I_{f} I_{r}}{I_{b} I_{1}}}_{I_{b 6}} \tag{4.25}
\end{equation*}
$$

and

$$
\begin{align*}
\mathrm{KCL}: & I_{C b}=I_{b 1}-I_{b 2}-I_{b 3}+I_{b 4}+I_{b 5}-I_{b 6} \\
\mathrm{TL}: & I_{b 1} I_{b}=I_{f} I_{\tau} \quad I_{b 2} I_{b}=I_{a} I_{\tau} \quad I_{b 3} I_{1}=I_{\gamma \tau} I_{\rho}  \tag{4.26}\\
& I_{b 4} I_{1}=I_{\gamma \tau} I_{r} \quad I_{b 5} I_{b} I_{1}=I_{\gamma \tau} I_{f} I_{\rho} \quad I_{b 6} I_{b} I_{1}=I_{\gamma \tau} I_{f} I_{r} .
\end{align*}
$$

### 4.2.3 Translinear Loops

We can configure the TL equations for the "a" side of the dynamic constraints in the following order:


The MITE network for this ordering is shown in Fig. 4.3. The "b" side TL equations can be arranged in an ordering that is almost identical to the "a" ordering as follows:

$$
\begin{aligned}
& I_{b} \quad \leftrightarrow I_{f} \leftrightarrow I_{b 1} \leftrightarrow I_{\tau} \\
& I_{b} \leftrightarrow I_{a} \leftrightarrow I_{b 2} \leftrightarrow I_{\tau} \\
& I_{b 3} \leftrightarrow I_{\rho} \leftrightarrow I_{1} \leftrightarrow I_{\gamma \tau} \\
& I_{b 4} \leftrightarrow I_{r} \leftrightarrow I_{1} \rightarrow I_{\gamma \tau} \\
& I_{b} \leftrightarrow I_{f} \leftrightarrow I_{b 5} \leftrightarrow I_{\rho} \leftrightarrow I_{1} \leftrightarrow I_{\gamma \tau} \\
& I_{b} \leftrightarrow I_{f} \leftrightarrow I_{b 6} \leftrightarrow I_{r} \leftrightarrow I_{1} \leftrightarrow I_{\gamma \tau} .
\end{aligned}
$$



Figure 4.3: Initial connections for the "a" side of the dynamic constraint network.

This ordering was chosen from many possible choices by looking at the required inputs and the similarities of the "a" and "b" sides. The most notable of these similarities is that both sides include the $I_{\gamma \tau} \leftrightarrow I_{1}$ factor in eight of the twelve total TL equations. (The above ordering was determined by using the Perl program in Appendix C.)

### 4.2.4 Consolidation

Having taken the time to arrange the TL equations to maximize the chances for consolidation, we can now remove redundant terms. The highlighted currents below indicate which factors or combinations can be removed, because they have already appeared. For clarity, the list of shared terms are: $I_{a}, I_{a} \leftrightarrow I_{f}, I_{\tau} \leftrightarrow I_{1}$, $I_{\gamma \tau} \leftrightarrow I_{1}, I_{\gamma \tau} \leftrightarrow I_{1} \leftrightarrow I_{\rho}$, and $I_{\gamma \tau} \leftrightarrow I_{1} \leftrightarrow I_{r}$.

$$
\begin{aligned}
& I_{a} \leftrightarrow I_{f} \leftrightarrow I_{a 1} \leftrightarrow I_{\tau} \\
& \boldsymbol{I}_{\boldsymbol{a}} \leftrightarrow I_{b} \leftrightarrow I_{a 2} \leftrightarrow \boldsymbol{I}_{\boldsymbol{\tau}} \\
& I_{a 3} \leftrightarrow I_{\rho} \leftrightarrow I_{1} \leftrightarrow I_{\gamma \tau} \\
& I_{a 4} \leftrightarrow I_{r} \leftrightarrow \boldsymbol{I}_{\mathbf{1}} \leftrightarrow \boldsymbol{I}_{\boldsymbol{\gamma} \tau} \\
& \boldsymbol{I}_{\boldsymbol{a}} \leftrightarrow \boldsymbol{I}_{\boldsymbol{f}} \leftrightarrow I_{a 5} \leftrightarrow \boldsymbol{I}_{\rho} \leftrightarrow \boldsymbol{I}_{1} \leftrightarrow \boldsymbol{I}_{\gamma \tau} \\
& I_{a} \leftrightarrow I_{f} \leftrightarrow I_{a 6} \leftrightarrow I_{r} \leftrightarrow I_{1} \leftrightarrow I_{\gamma \tau} \\
& I_{b} \quad \leftrightarrow \quad I_{f} \quad \leftrightarrow I_{b 1} \leftrightarrow I_{\tau} \\
& \boldsymbol{I}_{\boldsymbol{b}} \leftrightarrow I_{a} \leftrightarrow I_{b 2} \leftrightarrow \boldsymbol{I}_{\boldsymbol{\tau}} \\
& I_{b 3} \leftrightarrow I_{\rho} \leftrightarrow I_{1} \leftrightarrow I_{\gamma \tau} \\
& I_{b 4} \leftrightarrow I_{r} \quad \rightarrow \quad \boldsymbol{I}_{\mathbf{1}} \leftrightarrow \boldsymbol{I}_{\boldsymbol{\gamma} \boldsymbol{\tau}} \\
& \boldsymbol{I}_{\boldsymbol{b}} \leftrightarrow \boldsymbol{I}_{\boldsymbol{f}} \leftrightarrow I_{b 5} \leftrightarrow \boldsymbol{I}_{\boldsymbol{\rho}} \leftrightarrow \boldsymbol{I}_{\mathbf{1}} \leftrightarrow \boldsymbol{I}_{\gamma \tau} \\
& \boldsymbol{I}_{\boldsymbol{b}} \leftrightarrow \boldsymbol{I}_{\boldsymbol{f}} \leftrightarrow I_{b 6} \leftrightarrow \boldsymbol{I}_{\boldsymbol{r}} \leftrightarrow \boldsymbol{I}_{1} \leftrightarrow \boldsymbol{I}_{\gamma \tau}
\end{aligned}
$$



Figure 4.4: Initial connections for the " b " side of the dynamic constraint network.

Because the "a" and "b" sides share some similar terms, we can share a voltage from one to remove the MITEs in the other that are used to generate that voltage. These reductions are shown in Figs. 4.5 and 4.6. (Even though $I_{a 3}=I_{b 3}$ and $I_{a 4}=I_{b 4}$, we cannot remove the MITEs that generate these currents since they are required in distinct KCL equations.)

### 4.2.5 Biasing

Figure 4.7 shows the MITE networks of Figs. 4.5 and 4.6 rearranged into two connected rows for biasing. In order to bias the network, we can add current sources for all of the MITEs except the $I_{a i}, I_{b i}, I_{a}$, and $I_{b}$ ones. Using the KCL equations,

$$
\begin{array}{ll}
\mathrm{KCL}: & I_{C a}=-I_{a 1}+I_{a 2}-I_{a 3}+I_{a 4}+I_{a 5}-I_{a 6}  \tag{4.27}\\
\mathrm{KCL}: & I_{C b}=-I_{b 1}+I_{b 2}-I_{b 3}+I_{b 4}+I_{b 5}-I_{b 6},
\end{array}
$$

we can add a capacitor to each side and sum the currents appropriately while mirroring them around to enforce the KCL constraints. Since we have two MITEs passing $I_{a}$ and two passing $I_{b}$ (the outputs), we bias these pairs with a set of NMOS current mirrors each. The fully biased circuit is shown in Fig. 4.8.

### 4.2.6 Diode Connections

The diode connections for this circuit follow the same kind of pattern as before. Starting at the left, we can choose the first MITE in each row to be the "output" MITE and diode connect around the NMOS to generate the voltages required for the mirrors. Connecting around the next two $I_{f}$ MITEs leaves us at nodes that are part of the KCL constraints. Because this system is large, we skip these nodes until later. The next set of MITES are passing the output currents. Since we have


Figure 4.5: Consolidations for the "a" side of the dynamic constraint network.


Figure 4.6: Consolidations for the "b" side of the dynamic constraint network.


Figure 4.7: Rearranged consolidated network for both the "a" and "b" sides.


Figure 4.8: Rearranged consolidated network for both the "a" and "b" sides where the voltages, $V_{a}$ and $V_{b}$, are shared from the radius calculation network.
already diode connected the other half of the mirror around the NMOS transistors, we diode connect around these MITEs. Skipping more KCL nodes, we then diode connect around the input current MITEs passing $I_{\tau}, I_{\gamma \tau}, I_{1}, I_{r}$, and $I_{\rho}$. With just the KCL nodes remaining, we can diode connect around the $I_{a 6}$ and $I_{b 6}$ MITEs which also forces diode connections around the other half of the NMOS current mirrors. These diode connections are shown in Fig. 4.9.

Looking back at the vector magnitude circuit of Fig. 2.8, we observe that there are four places where the output currents of the dynamic networks are required. Since we already have voltages that represent log-compressed currents for $I_{a}$ and $I_{b}$ (labeled $V_{a}$ and $V_{b}$ in Fig. 4.8), we can remove the two input MITEs on the right end of the radius calculation network. Recognizing that $I_{a}$ and $I_{b}$ are not actual input current sources, we replace the two remaining current sources with NMOS transistors that mirror the output currents from the dynamic side of the system. Similarly, we need to mirror $I_{r}$ from the radius calculation side to the dynamic side. Since we have not already mirrored $I_{r}$ and do not even have a MITE passing this output current, we must generate this current by adding a MITE that sources $I_{r}$ into a diode connected NMOS transistor allowing us to mirror it to the dynamic side. These changes, completing the oscillator circuit, are shown in Fig. 4.10.


Figure 4.9: Diode connections for the dynamic constraints. Voltages $V_{a}$ and $V_{b}$ represent log-compressed currents and can be used to remove the two input MITEs in the radius calculation network.


Figure 4.10: Final changes to complete the entire oscillator circuit linking the radius and dynamic sides.

## Chapter 5

## Phase-Locked Loop

### 5.1 System Decomposition

This final example illustrates how multiple MITE networks can be combined by integrating complete smaller networks into a larger complex system. We demonstrate this process by designing a phase-locked loop (PLL), as shown in Fig. 5.1. The input signal is expected to be a sinusoid whose frequency changes slowly in time. The feedback loop is expected to adjust the oscillator's output frequency to match that of the input by examining the phase difference between the two signals. When the phase difference becomes constant, the PLL is said to be "locked" onto the input signal's frequency.


Figure 5.1: Phase-locked loop block diagram.


Figure 5.2: Phase-locked loop block diagram.

The phase detector can be realized by a simple multiplier resulting in a lowfrequency component representing the frequency difference between the input and the oscillator's output. There will also be a high-frequency component (at approximately twice the input's frequency) that will be removed by the loop filter. A first-order low-pass filter is sufficient to accomplish this filtering operation. By introducing a variable gain into the low-pass filter, we can combine both the loop filter and amplifier into a single circuit as shown in Fig. 5.2. The quadrature oscillator from the previous chapter is sufficient for this system.

### 5.2 Multiplier

This section describes the process by which we transform the polynomial constraint for a multiplier,

$$
\begin{equation*}
z=x y \tag{5.1}
\end{equation*}
$$

into the necessary translinear loops. Because both the inputs and the output need to represent positive and negative values, we must introduce offsets to force the variables to be positive. Doing so, we obtain

$$
\begin{align*}
& a=x+f, \quad b=y+f, \quad \text { and } \quad c=z+f  \tag{5.2}\\
\Rightarrow & (c-f)=(a-f)(b-f) .
\end{align*}
$$

The dimensionless variables are replaced with ratios of signal currents to a unit current.

$$
\begin{equation*}
I_{c}-I_{f}=\frac{\left(I_{a}-I_{f}\right)\left(I_{b}-I_{f}\right)}{I_{1}} \tag{5.3}
\end{equation*}
$$

Solving for the output current, $I_{c}$, defining $I_{2 f}$ as $2 I_{f}$, and equating $I_{f}$ to $I_{1}$ (to help reduce the number of separate bias currents), results in

$$
\begin{equation*}
I_{c}=\underbrace{\frac{I_{a} I_{b}}{I_{f}}}_{I_{\mathrm{TL}}}-I_{a}-I_{b}+\underbrace{2 I_{f}}_{I_{2 f}} \tag{5.4}
\end{equation*}
$$

which can be represented by the following TL and KCL equation:

$$
\begin{align*}
\mathrm{KCL}: & I_{c}=I_{\mathrm{TL}}-I_{a}-I_{b}+I_{2 f}  \tag{5.5}\\
\mathrm{TL}: & I_{\mathrm{TL}} I_{f}=I_{a} I_{b}
\end{align*}
$$

Having already constructed much more complicated MITE networks, this multiplier circuit should seem trivial. Arranging the TL equation as

$$
\begin{equation*}
I_{a} \leftrightarrow I_{f} \rightarrow I_{b} \leftrightarrow I_{\mathrm{TL}}, \tag{5.6}
\end{equation*}
$$

we connect the MITEs, as shown in Fig. 5.3(a). We then bias with three input current sources on the first three MITEs and add several more current sources and an NMOS current mirror according to the KCL equation. We have added the current mirror to generate an usable copy of the output current, $I_{c}$. The biased circuit is shown in Fig. 5.3(b). Since we have to mirror the output current, we must diode connect around the left NMOS transistor. Diode connecting around the three input MITEs completes the multiplier circuit, as shown in Fig. 5.3(c).

### 5.3 Low-Pass Filter

The low-pass filter detailed in Section 3.2 could be used for the PLL loop filter if we could control the gain. Considering the transfer function for a low-pass filter


Figure 5.3: Construction of the multiplier circuit. (a) Initial connections. (b) Biasing for the circuit. (c) Completed circuit.
with a DC gain of $k$,

$$
\begin{equation*}
H(s)=\frac{k}{1+\tau s} \tag{5.7}
\end{equation*}
$$

rearranging to find

$$
\begin{equation*}
\tau s y(s)=k x(s)-y(s) \tag{5.8}
\end{equation*}
$$

allows us to use the inverse Laplace transform to get the differential equation for a first-order low-pass filter with gain, $k$,

$$
\begin{equation*}
\tau \frac{d y}{d t}=k x-y \tag{5.9}
\end{equation*}
$$

Replacing the variables with current ratios, we find that

$$
\begin{equation*}
\tau \frac{d}{d t}\left(\frac{I_{y}}{I_{1}}\right)=k \frac{I_{x}}{I_{1}}-\frac{I_{y}}{I_{1}}, \tag{5.10}
\end{equation*}
$$

which we can reduce to

$$
\begin{equation*}
\tau \frac{d I_{y}}{d t}=k I_{x}-I_{y} . \tag{5.11}
\end{equation*}
$$

Using an inverting output structure, we replace the derivative to find

$$
\begin{equation*}
-\frac{I_{\mathrm{C}} I_{y}}{I_{\tau}}=k I_{x}-I_{y} \tag{5.12}
\end{equation*}
$$

which becomes

$$
\begin{equation*}
I_{\mathrm{C}}=I_{\tau}-\underbrace{\frac{k I_{\tau} I_{x}}{I_{y}}}_{I_{\mathrm{TL}}} . \tag{5.13}
\end{equation*}
$$

Absorbing the gain factor, $k$, into one of the $I_{\tau}$ 's, we get the following KCL and TL equations.

$$
\begin{align*}
\mathrm{KCL}: & I_{\mathrm{C}}=I_{\tau}-I_{\mathrm{TL}}  \tag{5.14}\\
\mathrm{TL}: & I_{\mathrm{TL}} I_{y}=I_{k \tau} I_{x}
\end{align*}
$$

Recognizing that the final decomposition is almost identical to that of the filter described in Section 3.2, we can simply use the same circuit by just varying the rightmost current source to be $I_{k \tau}$ instead of $I_{\tau}$. This circuit is shown in Fig. 5.4.


Figure 5.4: Modified low-pass filter from Section 3.2 to include a gain of $k$.

### 5.4 Inter-Network Connections

Now that we have the phase detector (multiplier), loop filter and amplifier (modified low-pass filter), and an oscillator (quadrature oscillator), we can connect them all to form the PLL. Starting with the multiplier, we chose to have the external input be defined as $I_{\mathrm{in}}$ (replacing $I_{a}$ ) and the output of the oscillator that is fed back to the phase detector as $I_{\text {osc }}$. Since either of the oscillator's outputs will work (only a 90 degrees phase shift between them), we choose to use the $I_{a}$ output. Since the multiplier is expecting two current sinks passing $I_{\text {osc }}$, we can replace the $I_{b}$ current sources with NMOS transistors whose gates are tied to the diode connected NMOS from the oscillator circuit that is passing the $I_{b}$ output current. The relevant sections of the circuits are shown in Fig. 5.5.

The output of the multiplier can be passed to the input of the loop filter in a similar manner. Since we already have an NMOS transistor passing the multiplier's output current and the filter is expecting the input to be supplied as a current sink, we can replace the input current source of the filter with the NMOS transistor from


Figure 5.5: Connecting the output of the oscillator to the second input of the multiplier.


Figure 5.6: Connecting the output of the oscillator to the second input of the multiplier.
the multiplier, as shown in Fig. 5.6. Note that the output of the multiplier, $I_{c}$, becomes the input of the filter, $I_{x}$.

The output of the loop filter, $I_{y}$, becomes the input to the oscillator, $I_{\tau}$. The oscillator is expecting a current sink passing $I_{\tau}$, so we can mirror the output of the filter using two NMOS transistors. However, we also need a scaled version of $I_{\tau}$, $I_{\gamma \tau}=\gamma I_{\tau}$.

We approach calculating $I_{\gamma \tau}$ just as we would any other function. Beginning by replacing the dimensionless variable, $\gamma$, with a current ratio, we find that

$$
\begin{equation*}
I_{\gamma \tau}=\frac{I_{\gamma}}{I_{1}} I_{\tau} . \tag{5.15}
\end{equation*}
$$

We can then rearrange Eq. 5.15 into the following TL equation:

$$
\begin{equation*}
\mathrm{TL}: \quad I_{\gamma \tau} I_{1}=I_{\gamma} I_{\tau} \tag{5.16}
\end{equation*}
$$

Arranging the currents into the order,

$$
\begin{equation*}
I_{\tau} \leftrightarrow I_{\gamma \tau} \leftrightarrow I_{\gamma} \leftrightarrow I_{1}, \tag{5.17}
\end{equation*}
$$


(a)

(c)


(b)
(d)

Figure 5.7: Additional circuit to generate the $\gamma$-scaled version of $I_{\tau}$.
we can connect the MITEs, as shown in Fig. 5.7(a). The biasing and diode connections for the circuit are shown in Fig. 5.7(b) and (c). Recognizing that the input current, $I_{\tau}$, is the output current of the loop filter, we are able to share the voltage to remove the input MITE, as shown in Fig. 5.7(d). Figure 5.8 shows the connections from the loop filter that are used to generate the required $I_{\tau}$ and $I_{\gamma \tau}$.


Figure 5.8: Connecting the output of the filter, $I_{y}$, to the oscillator to generate both $I_{\tau}$ and the scaled version, $I_{\gamma \tau}$.

## Chapter 6

## Results and Conclusions

The following sections present results from the majority of the circuits presented in the previous chapters. I present each circuit's results separately and address global issues in Section 6.7. Comparing the results found in this dissertation to the results of similar circuits would only mislead the reader because the comparisons would rarely be fair. The majority of translinear circuits are implemented using bipolar junction transistors fabricated in a BiCMOS process allowing for much higher current levels ( $\sim$ milliamperes) and thus, higher frequencies. All results in this dissertation are measured from circuits implemented with floating-gate PMOS transistors operated in weak inversion (limiting current levels to a maximum of approximately 100 nA ). It follows that BiCMOS implementations will operate for higher frequencies but require more power than their MITE network counterparts. Additionally, signal-to-noise (SNR) ratios are not quoted in the results because for these large signal circuits, the mere definition of the SNR becomes ambiguous and the measurement is difficult. (Noise levels are dependent upon the signal levels and therefore, the best SNR will most likely not be found for the maximum allowable signal levels.)

Alternate implementations of translinear circuits can be found in $[4,6-8,15,30$, $32,36]$ for log-domain filters, in [9,28] for RMS-to-DC converters, in [33, 41, 45] for oscillators, and in $[40,42,45]$ for phase-locked loops.

### 6.1 Vector Magnitude Results

Data collected from the circuit described in Section 2.2 is shown in Fig. 6.1. The vector magnitude was calculated for values of $I_{x}$ and $I_{y}$ over the range of 1 nA to 50 nA and a Vdd of 2 V . The MITEs were programmed to pass a nominal current of 10 nA with control gate voltages at 1 V (under a $1 \%$ variance in current at that operating point). Investigation into the reason for the error in the results lead to a discovery that the subthreshold slopes of the floating-gate transistors did not match. See Section 6.7 for a detailed discussion of reasons for error in the collected data.

### 6.2 First-Order Low-Pass Filter Results

The frequency response for the first-order low-pass filter described in Section 3.2 is shown in Fig. 6.2. Data was collected for five values of $I_{\tau}$ (corner frequencies ranging from 3 kHz to approximately 13 kHz for values of $I_{\tau}$ from 5 nA to 150 nA ). Evidence of higher order effects start appearing above 10 kHz preventing the phase to level off at the expected -90 degrees and altering the roll-off rate in the magnitude response. This is probably the result of higher order effects or feed through from various control gates to others. What appears to be a double-zero around 16 kHz is most likely a direct feed through of the input through either the off-chip circuitry or the global reference signal, $V_{\text {ref }}$. See Section 6.7 for a more detailed


Figure 6.1: Measured data from the vector magnitude circuit. Measured data is shown with circles and the ideal curves are shown with solid lines.


Figure 6.2: Frequency response for a first order low-pass filter.
discussion of experimental results.

### 6.3 RMS-to-DC Converter Results

Figures 6.3 and 6.4 show input and output traces measured from the RMS-to-DC converter along with the ideal expected value. Due to high frequency feed through ( $>10 \mathrm{kHz}$ ) and a limited range of corner frequencies ( $>1 \mathrm{kHz}$, limited by the on-chip capacitor and a minimum value for $I_{\tau}$ ) it was not possible to completely filter out the AC variations of the squared input signal. Considering that a first order lowpass filter can only approximate the mean of a signal, the circuit performs within


Figure 6.3: Results from the RMS-to-DC converter circuit with a sinusoidal input signal.


Figure 6.4: Results from the RMS-to-DC converter circuit with a sawtooth input signal.
expectations. An obvious gain or offset error can be seen that may be the result of mismatch or transistors coming out of saturation. Results may be very sensitive to operating levels since this circuit must be able to handle a wide range of current levels. The input is initially squared, creating a large current which can force transistors into non-ideal operating conditions (the input current is not centered about zero since an offset is required to ensure strictly positive currents). The time constant can be observed in Fig. 6.4 by examining the output after sharp changes in the input. While no formal comparison to alternate implementations of RMS-toDC converters is presented here, it is worthwhile to note that the implementation detailed in Section 3.3 does not assume a rectified input signal as do most published implementations. Additional RMS-to-DC converters are published in [28] and [9].

### 6.4 Second-Order Low-Pass Filter Results

Frequency responses for the second-order low-pass filter of Section 4.1 are shown in Figs. 6.5, 6.6, and 6.7 for three values of $I_{\tau}$ (three corner frequencies of about $4 \mathrm{kHz}, 8 \mathrm{kHz}$, and 10 kHz ). Each plot shows the responses for various quality factors $(0.25,0.5,1$, and 2$)$. What appears to be a double-zero around 11 kHz is most likely a direct feed through of the input through either the off-chip circuitry or the global reference signal, $V_{\text {ref }}$. See Section 6.7 for a more detailed discussion of this anomaly.

### 6.5 Quadrature Oscillator Results

Plots of various experimental results from the quadrature oscillator of Section 4.2 fabricated in an AMI $0.5-\mu \mathrm{m}$ process are shown in Figs. $6.8-6.12$. Figures $6.8-$


Figure 6.5: Frequency response for a second-order low-pass filter with various quality factors $(\mathrm{Q}=0.25,0.5,1,2)$ and an approximate corner frequency of 4 kHz .


Figure 6.6: Frequency response for a second-order low-pass filter with various quality factors $(\mathrm{Q}=0.25,0.5,1,2)$ and an approximate corner frequency of 8 kHz .


Figure 6.7: Frequency response for a second-order low-pass filter with various quality factors $(\mathrm{Q}=0.25,0.5,1,2)$ and an approximate corner frequency of 11 kHz . 6.10 show a sample of the two oscillator outputs over varying oscillation frequencies where $I_{\tau}$ was swept from 10 nA to 200 nA . The only bias current that was changed during these data collections was $I_{\tau}$. It is possible to tweak other biases to get less distorted output signals for a given $I_{\tau}$. By tweaking other bias signals, valid output signals can be generated at oscillation frequencies as low as a few hundred Hz (where $I_{\tau} \approx 0.1 \mathrm{nA}$ ). Figure 6.11 shows a plot of the oscillation frequency versus $I_{\tau}$. By plotting one output versus the other, it is possible to graphically examine the phase difference as shown in Fig. 6.12. Two sinusoids at the same frequency with a 90 degrees phase shift will appear as a perfect circle. Using zerocrossings, the phase difference for this frequency $(8.93 \mathrm{kHz})$ was calculated as 87.4 degrees. The phase jitter was measured to be approximately $4 \%$ and the total harmonic distortion (THD) ranged from $6 \%(10 \mathrm{kHz})$ to $10 \%(90 \mathrm{kHz})$. The THD


Figure 6.8: Scope capture of the two oscillator outputs at 8.93 kHz .


Figure 6.9: Scope capture of the two oscillator outputs at 40.3 kHz .


Figure 6.10: Scope capture of the two oscillator outputs at 81.7 kHz .


Figure 6.11: Plot of the relationship between the oscillation frequency and $I_{\tau}$.


Figure 6.12: Plot of the two oscillator outputs, $I_{a}$ versus $I_{b}$, showing an approximate phase difference of 87.4 degrees. A perfect circle would be the equivalent of a 90 degrees phase difference.
can be expected to be fairly high considering the frequency range and the capacitive nature of the circuit (becoming increasingly worse at higher frequencies).

It is worthwhile to note that this circuit is sensitive to certain biasing conditions with an exceptionally strong dependence on the cascode voltages. This implies that small gain errors around the feedback loop have a significant impact on the output signals' distortion, phase, and frequency.

### 6.6 Phase-Locked Loop Results

Simulations run in TSpice showed that the PLL was able to lock onto frequencies in the range of 20 to 30 kHz when the free-running frequency was set to approximately 23 kHz . Figure 6.13 (a) shows the output of the filtered phase detector signal demonstrating the locking behavior. Traces of the input and output signals after locking are shown in Fig. 6.13(b).

The fabricated phase-locked loop of Chapter 5 was unable to lock onto the input signal's frequency. Figure 6.14 shows the oscillator output and the output of the loop filter (which controls the oscillator frequnecy). It is clear that the loop filter's output was able to modulate the oscillator frequency. However, the signal was too noisy (primarily from 60 Hz interference) in order to be able to serve as an effective phase detector.

### 6.7 Results Summary

The results presented in this dissertation show that the synthesis methodology is both sound and viable for a wide range of applications. The three most limiting factors in preventing better results are mismatch of the the subthreshold current-


Figure 6.13: PLL simulation results. (a) Frequency-controlling current showing the locking behavior. (b) Traces of the input and output signals.


Figure 6.14: Experimental PLL results showing the output of the loop filter (which controls the oscillator frequency and is dominated by 60 Hz interference) and the output of the oscillator.
voltage curves, difficulty in getting clean and accurate measurements due to the low current levels, and the potential for higher order effects to create unexpected behaviors due to the capacitive nature of MITE networks.

### 6.7.1 Mismatch

Being able to inject the floating-gate transistors such that they passed the same current within under one percent variance for the same control gate voltages, did not guarantee the same tolerance for different control gate voltages. For instance, programming with a $0.5 \%$ tolerance for a current level of 20 nA at a control gate voltage of 1 V , might still mean that a change of 50 mV on the control gates causes the variance in current to change to several percent. It is not exactly clear what is the fundamental cause for this error. Looking at the relationship for a two-input MITE where the control gates are shorted,

$$
\begin{equation*}
I_{d}=I_{s} e^{\kappa\left(2 w V+Q / /_{\text {total }}\right) / U_{\mathrm{T}}}, \tag{6.1}
\end{equation*}
$$

we can find the slope of the plot of $\ln \left(I_{d}\right)$ versus $V$ by examining

$$
\begin{equation*}
\ln \left(I_{d}\right)=\ln \left(I_{s}\right)+\frac{\kappa 2 w V}{U_{\mathrm{T}}}+\frac{\kappa Q}{C_{\text {total }} U_{\mathrm{T}}}, \tag{6.2}
\end{equation*}
$$

resulting in a slope of $2 \kappa w / U_{\mathrm{T}}$. By programming the MITEs, we are able to remove any offsets due to the variance in the trapped floating-gate charge, $Q$. However, it appears that there still remains a noticeable variance in the slopes which implies that either $\kappa$ or the weights are not matched well ( $U_{\mathrm{T}}$ is the thermal voltage, $k T / q$, and should remain constant across all MITEs). Since both $\kappa$ and the weights are dependent upon the geometry of the transistors and the capacitors, it is possible that using larger-sized devices might improve these errors. For the work presented here, the variance in these slopes amounted to errors as large as $6 \%$ at the edges
of the operating range. This is most likely the cause for the offset and gain errors present in the results.

### 6.7.2 Measurement Errors and Noise

The second biggest problem was trying to get clean unamplified signals into and out of a chip. With currents on the order of nanoamperes, simply dropping a chip into a breadboard and connecting up devices is not advisable. A gain factor of ten was achieved by duplicating many MITEs to effectively accept or generate ten copies of the input or output currents. Even with this boost, wires connecting the breadboard to the various biasing equipment and oscilloscopes introduced a noticeable amount of noise (especially 60 Hz line noise). Additionally, since these circuits are inherently current-mode circuits, to supply and measure any AC signals the AC currents were required to run through off-chip voltage-to-current or current-to-voltage converters which served as another potential noise source.

For optimum performance, these circuits should be run off of a single battery and the bias currents provided by on-chip programmable current sources, such as proposed in [5]. Additionally, custom designed printed circuit boards should help to reduce noise by shortening the wires and moving signal sources closer to the chip. Ideally, on-chip amplifiers would be used to reduce high-amplitude input signals down to the nA level and boost output signals to be easily measured by an oscilloscope.

If the off-chip noise influences can be reduced or eliminated, it will then become more important to investigate the nature of the noise generated within the MITE networks themselves. Because of the inherent non-linear behavior of translinear circuits, analyzing the noise is non-trivial. Additionally, the large signal behavior
of these circuits introduce signal $\times$ noise intermodulation as well as resulting in non-stationary noise sources. A complete treatment of noise present in translinear circuits is worthy of an entirely separate dissertation. Work has been done on noise analysis for various types of translinear circuits [13,27,31,34, 35, 48-50].

### 6.7.3 Feed Through and Higher Order Effects

With a class of circuits that is so inherently dependent upon capacitive coupling to relay signals, it is always possible that under certain conditions these capacitors will no longer act as one-way ports and allow a significant amount of signal to pass both ways. Using the first-order low-pass filter from Section 3.2, if the reference voltage, $V_{\text {ref }}$, were not driven by a source with a low output impedance it is probable that at some higher frequency the input signal would bypass the filter capacitor by following the path shown in Fig. 6.15. What appears to be a double zero in the frequency responses for the first and second-order low-pass filters can probably be attributed to this kind of feed through. The best way to avoid such problems in dynamic MITE networks would be to make certain that the only signal path from one side of a filtering capacitor to the other is either through that capacitor node or through a required feedback connection. For the first-order low-pass filter, this would mean having a separate voltage source for the left-hand side $V_{\text {ref }}$ and a separate voltage source for the right-hand side $V_{\text {ref }}$. As would be expected, increasing the transistor sizes to allow for higher current levels while reducing the control gate capacitor size will help to alleviate this phenomenon.

Even for static MITE networks, where no large filtering capacitor is present, the capacitive coupling becomes increasingly more relevant for higher signal frequencies. Analyzing these higher order effects is non-intuitive and is beyond the scope


Figure 6.15: Path by which a high frequency input signal could bypass the filter capacitor and show up at the output if the driving source for $V_{\text {ref }}$ does not have a low enough output impedance to keep $V_{\text {ref }}$ fixed to an effective DC potential.
of this dissertation. While higher order effects in MITE networks is not addressed, some work addressing higher order effects for log-domain filters implemented with BJTs and ways to compensate for these non-idealities can be found in [10, 14, 48].

### 6.8 Conclusions

This synthesis methodology is a powerful tool for designing a vast range of analog circuits. However, more research must be invested before it can become a reliable tool for the average circuit designer. With its very structural mathematical basis, it lends itself well to computer aided design as demonstrated by the circuit consolidation script included in Appendix C. It is not unreasonable to imagine software that accepts high-level differential equations describing a system and then returns a low-level system decomposition, a fully connected and biased MITE network, and even layout. By removing some of the ambiguity, such as limiting all MITEs to having only two control gates, the intuition required during the circuit construc-
tion can become unnecessary allowing for a fixed set of rules to govern the entire synthesis process.

### 6.9 Contributions

My contributions to this body of work include the synthesis of more complex systems (vector magnitude with offsets, quadrature oscillator, and phase-locked loop). These examples provide a greater insight into the various options that arise during synthesis that are not present for simpler circuits. While working on the decomposition of several systems, I developed the graphical representation for MITE connections used in this dissertation. This graphical representation helped me to recognize that the circuit construction phase along with the consolidation step could be simplified by restricting MITEs to two control gates and one to one connections. Once restricted, the connection ordering that provided the most opportunities to consolidate MITEs could be determined (somewhat visually) through a process of permutations on the odd and even currents within the graphs that was similar to the way in which equations are factored. Inspired to find the absolute minimum MITE configuration for the oscillator circuit of Section 4.2, I developed the Perl program in Appendix C to perform all the possible permutations for a given set of TL equations and by comparing the order of terms from the outsides progressing inwards, calculate the required number of MITEs to implement a given ordering after consolidation. This graphical representation of connections and the consolidation program should also be valid for standard translinear circuit synthesis.

After an ambitious attempt to synthesize an 8-tap adaptive filter that failed
(presumably due to our inability to balance the trapped charge on the floatinggates), I fabricated a test chip with the programming infrastructure shown in Appendix A. 7 to determine if it was possible to accurately program the floatinggate charge for a MITE network. After much experimentation and a steep learning curve, I sought advice from Paul Hasler at Georgia Institute of Technology on methods of fast and accurate programming, which lead to the modeling outlined in Appendix A.5. Having designed the largest MITE networks to date, I have included in Appendix B some generalizations about the nature of these circuits as well as some practicalities when designing large networks.

## Appendix A

## Programming Floating-Gate

## Charge

## A. 1 Programming Overview

One of the underlying assumptions that simplifies the synthesis methodology is that each floating-gate's trapped charge is equal such that for matched floatinggate transistors with equal control gate voltages, the drain currents will be equal. Due to the processes involved during fabrication, the trapped floating-gate charge across an entire chip can vary greatly. One method of equalizing this floating-gate charge was through the exposure of the silicon to UV light. Variations in fabrication technologies made it difficult to be sure that UV light exposure was sufficient in balancing the trapped floating-gate charge. For instance, the opaqueness of the overglass could vary drastically reducing the effectiveness of this method requiring additional design considerations (i.e., making cuts in the overglass layer in the layout). Since it is essential that the floating-gate charge be balanced, the combination of Fowler-Nordheim tunneling and hot-election injection are used to guarantee this
condition. (Tunneling can be used on both PMOS and NMOS floating-gate transistors but due to the lightly doped drain implants employed in most fabrication processes, hot-electron injection is only effective for PMOS transistors.) The goal of this charge-balancing process is to get the drain current of each MITE within a certain variance when all the control gates are fixed at a set voltage. The tunneling process is used to globally remove electrons from the floating-gates and injection is used to add electrons to individual floating-gates in a controlled manner.

The process by which the above techniques are used to balance the charge is as follows. Initially, all floating-gate transistors are globally tunneled to remove electrons from the floating-gate. This process continues until the "least tunneled" transistor's drain current (with a particular voltage at all control gates) is less than some threshold value. Individual transistors are then "programmed" through injection until they hit the target $\left[V_{\mathrm{CG}}, I_{\mathrm{d}}\right.$ ] condition. Since this balancing of charge of crucial to the correct operation of the circuits, great care must be shown during this process and the following section details one way in which this can be accomplished. It is important to understand the basics of tunneling and injection before we look at the overall programming process.

## A. 2 Fowler-Norheim Tunneling

The basic principle by which this process is used to remove electrons from the floating-gate involves creating a large voltage across the tunneling capacitor. (A tunneling capacitor is created when a small "finger" of the floating-gate's polysilicon overlaps highly doped N within an N -well.) This potential difference is great enough that electrons are forced through the thin oxide that separates each half
of this capacitor. (With MOSIS' AMI $0.5 \mu \mathrm{~m} 5 \mathrm{~V}$ CMOS process, I found that tunneling may begin with a tunneling voltage, $V_{\text {tun }}$, around $10-12 \mathrm{~V}$ with a 5 V Vdd and should be sufficiently fast for a quick global "erase" with $V_{\text {tun }}$ at 15 V . Note that too great a potential across the tunneling capacitor can damage the oxide insulator and therefore caution should be used. Also, additional care must be used when creating the layout since the average CMOS process is not rated for such high voltages.

## A. 3 Hot-Electron Injection

Hot-electron injection occurs when electrons traveling through the channel achieve a high enough velocity that they can travel through the gate oxide over the channel. The conditions for this to occur involve the combination of a significant sourcedrain voltage (approximately 4 V for the MOSIS AMI $0.5 \mu \mathrm{~m}$ process) and the correct "tilt" from the channel to gate (i.e., gate voltage must be more positive than the channel in order to steer the electrons into the oxide surface). Specifically, holes travel down the length of the channel from source to drain and collisions at the drain cause electron-hole pairs. These electrons then travel back up the channel with increasing velocity and are steered towards the oxide. A very small percentage of these electrons reach a high enough velocity and are able to travel through the oxide and make their way to the floating-gate.

## A. 4 Programming Method

A simple self-convergent method for a controlled injection process is described in [2] but was found to result in an unacceptably inaccurate programming for
any reasonable length process. (The self-regulation of this method does allow for increased accuracy at a cost of a longer programming time.) The method presented here involves modeling the injection process over a range of operating conditions that will allow for a faster and more accurate programming method. This method involves "pulsing" the drain voltage for various pulse lengths.

## A. 5 Derivation

Injection current is described as

$$
\begin{equation*}
I_{\mathrm{inj}}=I_{\mathrm{inj} 0}\left(\frac{I_{d}}{I_{d o}}\right)^{\alpha} e^{\left(\delta V_{\mathrm{sd}} / V_{\mathrm{inj}}\right)} \tag{A.1}
\end{equation*}
$$

where $I_{\mathrm{inj} 0}$ is a scaling current, $I_{d}$ is the drain current, $I_{d o}$ is the bias drain current, $\delta V_{\mathrm{sd}}$ is the change in $V_{s d}$ from the bias value of $V_{\mathrm{sd} 0}$, and $\alpha$ and $V_{\mathrm{inj}}$ are extracted values. Note that

$$
\begin{equation*}
\left(\frac{I_{d}}{I_{d o}}\right)^{\alpha}=\frac{\% \text { change @ } I_{d}}{\% \text { change @ } I_{d o}}\left(\frac{t_{\mathrm{norm}}}{t_{\mathrm{pulse}}}\right) \tag{A.2}
\end{equation*}
$$

and that

$$
\begin{equation*}
e^{\delta V_{\mathrm{sd}} / V_{\mathrm{inj}}}=\frac{\% \text { change } @\left(V_{\mathrm{sd} 0}+\delta V_{\mathrm{sd}}\right)}{\% \text { change } @ V_{\mathrm{sd} 0}}\left(\frac{t_{\mathrm{norm}}}{t_{\mathrm{pulse}}}\right) . \tag{A.3}
\end{equation*}
$$

Thinking of the charge flowing off of the floating-gate (or negative charge, electrons, flowing onto the floating-gate):

$$
\begin{equation*}
C_{T} \frac{d V_{f g}}{d t}=-I_{\mathrm{inj}} . \tag{A.4}
\end{equation*}
$$

The PMOS subthreshold current can be viewed as the present current, $I_{d o}$, scaled as a function of $\Delta V_{f g}$,

$$
\begin{equation*}
I_{d}=I_{d o} e^{-\left(\kappa \Delta V_{f g}\right) / U_{\mathrm{T}}} . \tag{A.5}
\end{equation*}
$$

Taking the derivative of the above results in

$$
\begin{equation*}
\frac{d I_{d}}{d t}=I_{d}\left(-\frac{\kappa}{U_{\mathrm{T}}}\right) \frac{d V_{f g}}{d t} . \tag{A.6}
\end{equation*}
$$

Substituting in $d V_{f g} / d t$ into the above, we find

$$
\begin{equation*}
\frac{d I_{d}}{d t}=I_{d}\left(-\frac{\kappa}{U_{\mathrm{T}}}\right)\left(-\frac{I_{\mathrm{inj}}}{C_{T}}\right) . \tag{A.7}
\end{equation*}
$$

Inserting the representation for $I_{\mathrm{inj}}$ (under the assumption that $I_{\mathrm{inj}}$ remains constant throughout the pulse and has no dependency on time) results in

$$
\begin{equation*}
\frac{d I_{d}}{d t}=I_{d} \frac{\kappa}{C_{T} U_{\mathrm{T}}}\left[I_{\mathrm{inj0}}\left(\frac{I_{d}}{I_{d o}}\right)^{\alpha} e^{\delta V_{\mathrm{sd}} / V_{\mathrm{inj}}}\right] . \tag{A.8}
\end{equation*}
$$

Rearranging and dividing both sides by $I_{d o}$, we find

$$
\begin{equation*}
\frac{d}{d t}\left(\frac{I_{d}}{I_{d o}}\right)=\underbrace{\frac{\kappa I_{\mathrm{injo}}}{C_{T} U_{\mathrm{T}}}}_{1 / t_{\text {pulseo }}}\left[\left(\frac{I_{d}}{I_{d o}}\right)^{1+\alpha} e^{\delta V_{\mathrm{sd}} / V_{\mathrm{inj}}}\right] \tag{A.9}
\end{equation*}
$$

Note that an $I_{d} / I_{d o}$ was grouped resulting in the $1+\alpha$ exponent. Defining $t_{\text {pulseo }}$ as $C_{T} U_{\mathrm{T}} / \kappa I_{\mathrm{inj} 0}$ and $x$ as $I_{d} / I_{d o}$ simplifies the above to

$$
\begin{equation*}
t_{\text {pulseo }} \frac{d x}{d t}=x^{1+\alpha} e^{\delta V_{\mathrm{sd}} / V_{\mathrm{inj}}} . \tag{A.10}
\end{equation*}
$$

$\delta V_{\text {sd }}$ is fixed during the pulse so defining a new $t_{\text {pulseo }}$,

$$
\begin{equation*}
t_{\text {pulseo }}^{\prime}=t_{\text {pulseo }} e^{-\delta V_{\mathrm{sd}} / V_{\text {inj }}}, \tag{A.11}
\end{equation*}
$$

results in

$$
\begin{equation*}
t_{\text {pulseo }}^{\prime} \frac{d x}{d t}=x^{1+\alpha} . \tag{A.12}
\end{equation*}
$$

Integrating across the pulse length we find

$$
\begin{equation*}
\int_{x(t=0)}^{x\left(t=t_{\text {pulse }}\right)} \frac{d x}{x^{1+\alpha}}=\int_{0}^{t_{\text {pulse }}} \frac{d t}{t_{\text {pulseo }}^{\prime}} \tag{A.13}
\end{equation*}
$$

which becomes

$$
\begin{equation*}
\left.-\left.\frac{1}{\alpha} \frac{1}{x^{\alpha}}\right|^{x\left(t=t=t_{\text {pulse }}\right)}\right)=\frac{t_{\text {pulse }}}{t_{\text {pulseo }}^{\prime}} . \tag{A.14}
\end{equation*}
$$

Evaluating the above results in

$$
\begin{equation*}
\frac{1}{x(t=0)^{\alpha}}-\frac{1}{x\left(t=t_{\text {pulse }}\right)^{\alpha}}=\alpha \frac{t_{\text {pulse }}}{t_{\text {pulseo }}^{\prime}} . \tag{A.15}
\end{equation*}
$$

Solving for $t_{\text {pulseo }}^{\prime}$, we find

$$
\begin{equation*}
t_{\text {pulseo }}^{\prime}=\frac{\alpha t_{\text {pulse }}}{\frac{1}{x(t=0)^{\alpha}}-\frac{1}{x\left(t t t_{\text {pulse }}\right)^{\alpha}}}, \tag{A.16}
\end{equation*}
$$

which becomes

$$
\begin{equation*}
t_{\text {pulseo }} e^{-\delta V_{\mathrm{sd}} / V_{\mathrm{inj}}}=\frac{\alpha t_{\text {pulse }}}{\frac{1}{x(t=0)^{\alpha}}-\frac{1}{x(t t T)^{\alpha}}} \tag{A.17}
\end{equation*}
$$

when the expression for $t_{\text {pulseo }}^{\prime}$ is inserted. Solving for $\delta V_{\text {sd }}$, we find

$$
\begin{equation*}
\delta V_{\text {sd }}=V_{\text {inj }} \ln \left(\frac{\alpha t_{\text {pulse }} / t_{\text {pulseo }}}{\frac{1}{x(t=0)^{\alpha}}-\frac{1}{x\left(t=t_{\text {pulse }}\right)^{\alpha}}}\right), \tag{A.18}
\end{equation*}
$$

which simplifies to

$$
\begin{gather*}
\delta V_{\mathrm{sd}}=V_{\mathrm{inj}} \ln \left(\alpha \frac{t_{\mathrm{pulse}}}{t_{\mathrm{pulseo}}}\right)-V_{\mathrm{inj}} \ln \left(\frac{1}{x(t=0)^{\alpha}}-\frac{1}{x(t=T)^{\alpha}}\right) .  \tag{A.19}\\
x(t=0)^{\alpha}=\left(\frac{I_{d o}}{I_{d o}}\right)^{\alpha}=1  \tag{A.20}\\
x(t=T)^{\alpha}=\left(\frac{I_{d}}{I_{d o}}\right)^{\alpha}=\left(\frac{I_{d o}+\Delta I_{d}}{I_{d o}}\right)^{\alpha}=(1+P C)^{\alpha} \tag{A.21}
\end{gather*}
$$

where $P C$ represents the percent change of $I_{d}$. Using these expressions for $x$, we substitute into Eq. A. 19 and set $\delta V_{\text {sd }}=0$ to solve for the prefactors.

$$
\begin{equation*}
0=V_{\mathrm{inj}} \ln \left(\alpha \frac{t_{\text {pulse }}}{t_{\text {pulseo }}}\right)-V_{\mathrm{inj}} \ln \left(1-\frac{1}{(1+P C)^{\alpha}}\right) \tag{A.22}
\end{equation*}
$$

Simplifying, we find

$$
\begin{equation*}
\alpha \frac{t_{\text {pulse }}}{t_{\text {pulseo }}}=1-\frac{1}{(1+P C)^{\alpha}} . \tag{A.23}
\end{equation*}
$$

Once modeling data is collected and $\alpha$ is extracted, a point can be chosen (giving $t_{\text {pulse }}$ and $P C$ ) to determine $t_{\text {pulseo }}$. Equation A. 19 can then be solved for the expected current after a certain programming pulse, $\left[t_{\text {pulse }}, \delta V_{\text {sd }}\right]$, when the starting current is $I_{d o}$.

$$
\begin{equation*}
I_{d}^{\alpha}=I_{d o}^{\alpha}\left(1-\alpha \frac{t_{\text {pulse }}}{t_{\text {pulseo }}} e^{-\delta V_{\mathrm{sd}} / V_{\mathrm{inj}}}\right) \tag{A.24}
\end{equation*}
$$

## A. 6 Data Collection

The modeling of the injection process requires data spanning across a variety of programming conditions (i.e., $V_{s d}=4 \mathrm{~V} \leftrightarrow 6 \mathrm{~V}, t_{\text {pulse }}=0.1 \mathrm{~ms} \leftrightarrow 5 \mathrm{~s}, I_{\text {start }}=1 \mathrm{nA} \leftrightarrow$ 100 nA ). Initially, all transistors should be tunneled so that they pass very small currents for the chosen programming $V_{\mathrm{cg}}$ (about an order of magnitude smaller than any current that would be chosen as the target current). Each transistor is injected according to a [ $V_{s d}, t_{\text {pulse }}$ ] pair. These pairs are determined such that the first transistor starts at the smallest $V_{s d}$ and the largest $t_{\text {pulse }}$. The $V_{s d}$ values should be scaled linearly such that the last transistor will be using the largest $V_{s d}$. The $t_{\text {pulse }}$ values should be scaled logarithmically such that the last transistor will be programmed with the smallest $t_{\text {pulse }}$ value. Measuring the drain current before every pulse, each transistor should be pulsed according to the prearranged pulsing conditions. (It might be useful to also pulse $V_{c g}$ up by a fixed amount to offset the effect of the drain coupling into the gate through the overlap capacitance to keep the transistor in weak inversion. If the transistor is forced out of weak inversion, the modeling data will not be useful.) When the current exceeds some maximum level (ie. 100 nA ), this transistor is finished and pulsing should be continued with the appropriate pulsing conditions until all transistors have been completed. For an array of ten transistors with $V_{d d}=5 \mathrm{~V}, V_{s d}=4.5 \leftrightarrow 5 \mathrm{~V}$, and $t_{\text {pulse }}=0.1 \leftrightarrow 10 \mathrm{~s}$ :

| Transistor | $V_{s d}$ | $t_{\text {pulse }}$ |
| :--- | :--- | :--- |
| $1:$ | 4.5 V | 10 s |
| $2:$ | 4.55 V | 5.99 s |
| $\vdots$ | $\vdots$ | $\vdots$ |
| $10:$ | 5 V | 0.1 s |



Figure A.1: Plots of injection data used to extra modeling parameters.

Plotting $\log \left(I_{d}\right)$ vs. pulse iteration should display an exponential relationship, as shown in Fig. A.1(a). (Displayed as plotting $I_{d}$ on a semilogy plot-type.) This signifies a "double exponential" relationship. Plotting $\log \left(\Delta I_{d} \frac{1 \text { sec }}{t_{\text {pulse }}}\right)$ (normalized $\left.\delta I_{d}\right)$ versus $\log \left(I_{d}\right)$ should result in straight parallel lines with slopes of approximately $0.7-1.2$, as shown in Fig. A.1(b). The slope of these lines is extracted as $\alpha$. Choose a fitting current, $I_{d o}$, in the middle of the programming range (ie. $\left.I_{d o}=10 n A\right)$. The slope values at this current should be interpolated and plotted versus the corresponding $V_{s d}$, as shown in Fig. A.1(c). (Note that the initial
normalization vertically shifts the log-log plot lines and only comes into play on the computation of $V_{\mathrm{inj}}$ below.) The slope (i.e., $\alpha$ ) may increase significantly with higher $V_{s d}$ values. You can account for this by extracting the slope in Fig. A.1(c) and replacing $\alpha$ with $\alpha_{0}+\alpha_{\text {slope }} V_{\text {sd }}$. Otherwise, an average of these $\alpha$ values can be used in the below model.

Using the same $I_{d o}$, extract the "Normalized \% Change" (y-value in Fig. A.1(b)) and plot these extracted values as $\log \left(\Delta I_{d} @ I_{d}=I_{d o}\right)$ versus $V_{s d}$. This should result in a straight line from $V_{\text {sdmin }}$ to $V_{\text {sdmax }}$. Choose a fitting $V_{s d}$ level, $V_{\text {sdo }}$, in the middle of the pulse range (ie. $V_{\text {sdo }}=4.75 \mathrm{~V}$ ). The extracted slope at this point is equal to $1 / V_{i n j}$. Figure A.1(d) shows the final plot used for the $V_{i n j}$ parameter extraction.

To summarize, $\alpha$ takes into account the injection current's dependency on the starting current level and $V_{i n j}$ accounts for the dependency on $V_{s d}$.

## A. 7 Programming Infrastructure

In Sections. 1.4 and 2.2, I mentioned that all MITEs are implemented with cascoded floating-gate PMOS (FGPMOS) transistors and all current mirrors are implemented with cascoded NMOS transistors. While these cascode transistors are needed to improve circuit performance, they also serve the additional purpose of assisting in the programming scheme. Figure A.2(a) shows the actual implementation of a typical "slice" of a MITE circuit. By turning the cascode transistors off (i.e., $V_{c p}=V_{d d}$ and $V_{c n}=\mathrm{Gnd}$ ), we effectively isolate the drain of the floating-gate PMOS and remove any connections to the control gates, as shown in Fig. A.2(b). Setting the global programming signal, Prog, high, all control gates are shorted
together through the transmission gates to the control gate bus, $\mathrm{CG}_{\text {bus }}$. Using a simple shift register, a single FGPMOS can be selected by setting $\operatorname{Sel}_{i}$ high, which shorts the FGPMOS drain to the drain bus, Dbus. With global control of all the control gate voltages and individual control of FGPMOS drains, each FGPMOS can be programmed separately.

The "third" control gates shown in Fig. A. 2 represent the tunneling capacitor needed for the global "erase". This tunneling capacitor is formed by running a thin poly "finger" from the floating-gate across a highly doped NWell. All MITEs share the same tunneling line, $V_{\text {tun }}$, and therefore, tunneling can only be used to tunnel all the MITEs. Individual tunneling lines are impractical because the necessary tunneling voltages ( $\sim 10-15 \mathrm{~V}$ ) exceed the voltage limitations for most CMOS processes, preventing standard digital circuitry (transmission gates, multiplexers, etc.) from passing these high voltages. When creating layout for nodes that will exceed the recommended voltage for a process, additional care must be used to prevent unexpected behavior since the standard design rules are no longer valid. i.e. The minimum well-to-well spacing for wells at different potentials should probably be doubled to prevent any unexpected well-to-well current flowing through the substrate. As an aside, the effects of the tunneling fingers on the total capacitance should be investigated to ensure that they are not the cause of mismatch across all MITEs.


Figure A.2: Programming infrastructure that allows for a global "erase" through the shared tunneling line, $V_{\text {tun }}$, and individual hot-electron injection through the use of the MITE select signal, $\operatorname{Sel}_{i}$, control gate bus, $\mathrm{CG}_{\mathrm{bus}}$, and drain bus, $\mathrm{D}_{\text {bus }}$. (a) MITE cell including two cascode transistors and two transmission gates. (b) Effective MITE cell during the programming phase when both cascode voltages are turned off.

## Appendix B

## Circuit Practicalities

## B. 1 Power Supply

Because all transistors are cascoded, most "slices" of a MITE network will involve a stack of four transistors between the power supply and ground (FGPMOS, pcascode, n-cascode, NMOS mirror). In order to remain saturated, each transistor must have a minimum of approximately $4 U_{\mathrm{T}}(\sim 100 \mathrm{mV})$ across its drain-source nodes, requiring a total power supply of at least 400 mV . Additionally, there must be enough headroom to bias the cascode transistors appropriately (i.e., $V_{c p} \sim V_{d d}-$ $1 V$ and $\left.V_{c n} \sim 0.8 \mathrm{~V}\right)$. Because the voltages are logarithmically compressed signals, a few hundred millivolts of swing can produce several decades of current levels. (The number of control gates and their size affect the coupling each control gate requiring more voltage swing for circuits with smaller control gates.) Therefore, if the FGPMOS are programmed such that the average control gate voltage is at $V_{d d} / 2$, a 1 V power supply would allow for a control gate voltage swing of 600 mV $\left(1 V-4 U_{\mathrm{T}}=600 \mathrm{mV}\right)$. With careful programming, operation, and biasing, it would be reasonable to expect these circuits to work down to a power supply as low as
$600-700 \mathrm{mV}$. (Below a $V_{d d}$ of 1 V , it would probably be necessary to consider making the cascode transistors wider to reduce the required $V_{g s}$ voltages.)

## B. 2 Current Levels

Maintaining transistor operation within the subthreshold region is necessary to take advantage of the exponential I-V relationship. Reasonably sized transistors (W/L $\sim 60 / 4)$ in the MOSIS AMI $0.5 \mu \mathrm{~m}$ process start to show deviation from the exponential curve around 150 nA . Using stacked transistor layout, it should be possible to create moderately sized transistors that allow for subthreshold current levels approaching $1 u \mathrm{~A}$ or higher. Alternately, lateral BJT's from a Bi-CMOS process could be used, allowing for much higher current levels.

## B. 3 Frequency Limits and Higher Order Effects

Methods for increasing the current levels (i.e., a bipolar MITE implementation), will allow for higher frequency operation before higher order effects cause unacceptable performance. If technology improvements allow for greater control gate coupling, decreasing the control gate size (while maintaining sufficient coupling) will help to increase the frequency range before higher order effects begin to limit operation.

## B. 4 General Design and Layout Techniques

Because these circuits inherently require many current biases and often times, several of each, it is recommended that when a current sink is required, it be gen-
erated by sourcing a current into an NMOS mirror. Alternately, if a current source is required, sinking a current from a PMOS mirror is recommended. Another important reason for using mirrors to provide currents is that taking an internal node out to a bonding pad that is not at the beginning of a MITE array adds a significant amount of capacitance to that particular node and may cause unexpected behavior. Mirroring the necessary currents maintains a similar environment seen by all MITEs. Dummy devices at all "ends" should also be used to help maintain consistent coupling between neighboring devices.

## Appendix C

## Perl Code for Automated

## Consolidation

```
#!c:\perl\bin\perl
use strict;
use warnings;
our $min_mites;
our $best_sol_cnt;
our @shared_best;
our @best;
our @LR;
my $time;
$time = localtime time;
print $time;
my ($i,$j,$k); #temp variables
#alias used for powers greater than 1 and should
# be "undone" after optimizing
my @alias=(['u2','v2'],
    ['u','v']);
#avail used for previous knowledge of terms that
#are available for sharing (presumably from another
#circuit that is already constructed
```

```
my $avail='';
my @L=(); #left side TLP terms (GLOBAL)
my @R=(); #right side TLP terms (GLOBAL)
@L=(['r1','r'],
    ['r2','r'],
    ['r3','r'],
    ['r4','r'],
    ['r5','r']
    );
@R=(['u2','u'],
    ['v2','v'],
    ['2z','z'],
    ['2z','u'],
    ['2z','v']
    );
#NEED TO IMPLEMENT FLAG TO MARK CERTAIN
#MITES AS "UNSHARABLE" (ie. OUTPUT MITES)
# - PRECEED TERMS WITH AN UNDERSCORE?
#Need to implement as method for maintaining
#output structure form
my $rows=$#L+1; #rows in L and R
my $cols=$#{$L[0]}+1; #columns in L and R
$min_mites=$rows*$cols*2;
#best solution mite count update through 'mutate#()'
$best_sol_cnt=0; #counts matches to best solution
#stick @L and @R together for mutations by row
@LR=@L;
for($i=0;$i<$rows;$i++){
    @{$LR[$i+$rows]}[0..$cols-1]=@{$R[$i]}[0..$cols-1];
}
print "\nTLP's:\n";
for($i=0;$i<$rows;$i++){
    print @{$L[$i]}," = ",@{$R[$i]},"\n";
}
&mutate1();
```

```
print "\nShared Layout: $min_mites:$best_sol_cnt\n";
for($i=0;$i<=$#best;$i++){
    for($j=0;$j<=$#{$best[0]};$j++){
        if($shared_best[$i] [$j]==0){
            print $best[$i][$j]," ";
            if(length($best [$i] [$j])==1){
            #add space is not 2-char term
                print " ";
                }
        }else{
            print " ";
        }
    }
    print "\n";
}
$time = localtime time;
print $time;
#Expects array-of-arrays of strings that contain TL terms
#Additional arrays requiring mutation are
#read from global array-of-arrays (@LR)
#If next loaded array is undef assume
#at lowest level and call consol()
#Current best-so-far mite count and
#configuration is compared/updated globally
#If not at lowest level, call mutate2()
#to mutate current array
#mutate1(@S[2-d])
sub mutate1{
    my $count;
    my @tmp;
    my $i;
    my $j;
    if($#_==$#LR){ #no more rows to mutate so call consol
        ($count,@tmp)=&consolidate(@_);
        if($count<$min_mites){
            #separate 2 matrices
            for($i=0;$i<($#tmp+1)/2;$i++){
@{$best[$i]}[0..$#{$tmp[0]}]=@{$tmp[$i]}[0 . .$#{$tmp[0]}];
@{$shared_best[$i]}[0..$#{$tmp[0]}]
    =@{$tmp[$i+($#tmp+1)/2]}[0..$#{$tmp[0]}];
```

```
        }
            $min_mites=$count;
                print "\nNew Best Layout: $min_mites\n";
                for($i=0;$i<=$#best;$i++){
                    for($j=0;$j<=$#{$best[0]};$j++){
                        if($shared_best[$i][$j]==0){
                            print $best[$i][$j]," ";
                            if(length($best[$i] [$j])==1){
                            #add space is not 2-char term
                            print " ";
                        }
                }else{
                        print " ";
                }
                }
                print "\n";
            }
            $best_sol_cnt=1; #reset "multiple best" counter
            }elsif($count==$min_mites){
                    $best_sol_cnt++; #add to multiple best
        }
    }else{
        push(@_,$LR[$#_+1]);
        #push next row from global @LR onto current set
        &mutate2(0,@_);
        #call individual row mutation sub with level 'O' status
    }
}
#mutate2($lev,@strings[2-d])
#Expects $lev to know where to start mutations
#and expects array of strings that contain TLP terms
#Current best-so-far mite count is compared
# and updated globally ($min_mites)
#If new 'best', update grid as well
#Each new mutation calls mutate2()
#recursively with that mutation
sub mutate2{
    my $lev=shift @_;
    #how many terms are already 'set'
    #(lev=2 means [0] and [1] are 'set')
    my $rows=$#_; #rows in @_
```

```
    my $cols=$#{$_[0]}+1; #cols in @_
    if($lev==$cols){
    #call mutate1 for next row/consolidation
    #(if no more rows)
        &mutate1(@_);
    }else{
        &mutate2($lev+1,@_);
        #call for more mutations at next level (column)
        my $i=0;
        for($i=$lev+1;$i<$cols;$i++){
        #make mutations after init call to mutate2
            my $temp=$_[$rows][$lev];
            $_[$rows] [$lev]=$_ [$rows][$i];
            #swap terms at current level
            $_[$rows][$i]=$temp;
            &mutate2($lev+1,@_);
            #call for more mutations at next level (column)
        }
    }
}
#expecting (@grid[2-d])
#@grid - array of arrays of strings with first
#half/2nd half of rows being L/R sides of TLP equations
sub consolidate{
    my $rows=$#_+1; #get row count
    my $cols=$#{$_[0]}+1; #get $cols
    my @g; #Grid of terms alternating odd/even per line
    my @shared=(); #flag if shared mite
    my ($i,$j); #temp vars
    for($i=0;$i<$rows/2;$i++){
        for($j=0;$j<$cols;$j++){
            #creates odd/even mix of terms
            #(1st half of rows odd, 2nd even)
            $g[$i] [$j*2]=$_ [$i] [$j];
            $g[$i] [$j*2+1]=$_[$i+$rows/2][$j];
            $shared[$i] [$j*2]=0;
            $shared[$i] [$j*2+1]=0;
        }
    }
    #recalculate the new dimensions
    $cols=$cols*2;
```

```
$rows=$rows/2;
# Find the number of unique terms and
# create a space-separated string of them
my $terms=" "; #string of terms (space-delimited)
my $nterms=0; #count of terms
my $share.=$avail;
#string to hold list of sharable chars/strings
#(add known values here)
my $nmites=$rows*$cols;
#holds the count of Mites needed
#(will decrement upon sharing)
# Left to Right terms (skipping last term)
for($i=0;$i<$rows;$i++){
    for($j=0;$j<$cols-1;$j++){
    #note that the entire line should not be added
        if($shared[$i][$j]!=1){ # if not shared so far
                my $temp=' '; #holds temporary string to match
                for($k=0;$k<=$j;$k++){
                    $temp.=$g[$i][$k];
                    #gathers terms from L->R to curr column
                }
                $temp.=' '; #will start/end match with spaces
                if(index($share, $temp)!=-1){
                #if term is already in shared list
                    $shared[$i][$j]=1; #set that it is shared
                    $nmites--; #remove from Mite count
                    #print "Sharing: ", $g[$i][$j], "\n";
                }else{
                    #print "Added: ",$temp,"\n";
                    $share.=$temp; #add term to shared list
                }
        }
    }
} # Right to Left terms (skipping last term)
for($i=0;$i<$rows;$i++){
    for($j=$cols-1;$j>0;$j--){
    #note that the entire line should not be added
        if($shared[$i][$j]!=1){ # if not shared so far
            my $temp=' '; #holds temporary string to match
            for($k=$cols-1;$k>=$j;$k--){
                $temp.=$g[$i] [$k];
                #gathers terms from R->L to curr column
```

```
                }
                    $temp.=' '; #will start/end match with spaces
                if(index($share, $temp)!=-1){
                #if term is already in shared list
                    $shared[$i][$j]=1; #set that it is shared
                        $nmites--; #remove from Mite count
                    #print "Sharing: ", $g[$i][$j], "\n";
                    }else{
                            #print "Added: ",$temp,"\n";
                    $share.=$temp; #add term to shared list
                    }
            }
        }
    }
    return ($nmites,@g,@shared);
}
```


## Bibliography

[1] L. Carley, "Synthesis tools for mixed-signal ics: progress on frontend and backend strategies," in Proc. of 33rd Design Automation Conference, vol. 1, Las Vega, NV, June 1996, pp. 298-303.
[2] C. Diorio, "A p-channel mos synapse transistor with self-convergent memory writes," IEEE Transactions on Electron Devices, vol. 47, no. 2, pp. 464-472, 2000.
[3] E. Drakakis, A. Payne, and C. Toumazou, "Bernoulli operator: A low-level approach to log-domain processing," Electronics Letters, vol. 33, no. 12, pp. 1008-1009, 1997.
[4] ——, "Log-domain state-space: A systematic transistor-level approach for log-domain filtering," IEEE Transactions on Circuits and Systems II: Analog and Digital Signal Processing, vol. 46, no. 3, pp. 290-305, 1999.
[5] C. Duffy, E. Farquhar, and P. Hasler, "Practical issues using e-pot circuits," in Proc. of the 2002 IEEE International Symposium on Circuits and Systems, vol. 5, Phoenix, AZ, May 2002, pp. 26-29.
[6] C. Enz and M. Punzenberger, "1-V log-domain filters," in Analog Circuit Design: Volt Electronics; Mixed-Mode Systems; Low-Noise and RF Power Amplifiers for Telecommunication, J. Huijsing, R. van de Plassche, and W. Sansen, Eds. Boston: Kluwer, 1999, pp. 33-67.
[7] R. Fox and M. Nagarajan, "Multiple operating points in a cmos log-domain filter," IEEE Transactions on Circuits and Systems II, vol. 46, no. 6, pp. 705-710, 1999.
[8] D. Frey, "Log-domain filtering: An approach to current-mode filtering," IEE Proc. G, vol. 140, no. 6, pp. 406-416, 1993.
[9] ——, "Explicit log-domain root-mean-square detector," December 1996, u.S. Patent No. 5,585,757.
[10] ——, "Synthesis of distortion compensated log-domain filters using state space techniques," in Proc. of the 1998 IEEE International Symposium on Circuits and Systems, vol. 1, Monterey, CA, May 1998, pp. 321-324.
[11] B. Gilbert, "Translinear circuits: An historical review," Analog Integrated Circuits and Signal Processing, vol. 9, no. 2, pp. 95-118, 1996.
[12] —, "Translinear circuits: A proposed classification," Electronics Letters, vol. 11, no. 1, pp. 14-16, 1975, see also errata, vol. 11, no. 6, p. 136, 1975.
[13] M. Kouwenhoven, J. Mulder, and A. van Roermund, "Signalnoise intermodulation in translinear filters," Electronics Letters, vol. 34, no. 8, pp. 705-706, 1998.
[14] V. Leung, M. El-Gamal, and G. Roberts, "Effects of transistor nonidealities on log-domain filters," in Proc. of the 1997 IEEE International Symposium on Circuits and Systems, vol. 1, Hong Kong, Hong Kong, June 1997, pp. 109-112.
[15] S. I. Liu and Y. H. Liao, "Table-based log-domain linear transformation filter," Electronics Letters, vol. 32, no. 19, pp. 1771-1772, 1996.
[16] J. Long and S. Colombano, "A circuit representation technique for automated circuit design," IEEE Transactions on Evolutionary Computation, vol. 3, no. 3, pp. 205-219, 1999.
[17] B. A. Minch, "Analysis, synthesis, and implementation of networks of multiple-input translinear elements," Ph.D., California Institute of Technology, Pasadena, CA, May 1997.
[18] ——, "Synthesis of multiple-input translinear element log-domain filters," in Proc. of the 1999 IEEE Inter. Symposium on Circuits and Systems, vol. 2, Orlando, FL, June 1999, pp. 697-700.
[19] ——, "Translinear analog signal processing: A modular approach to largescale analog computation with multiple-input translinear elements," in Proc. of the 20th Anniversary Conference on Advanced Research in VLSI, D. S. Wills and S. P. DeWeerth, Eds. Los Alamitos, CA: IEEE Computer Society Press, 1999, pp. 186-199.
[20] ——, "Multiple-input translinear element log-domain filters," IEEE Transactions on Circuits and Systems II: Analog and Digital Signal Processing, vol. 48, no. 1, pp. 29-36, 2001.
[21] ——, "Synthesis of static and dynamic multiple-input translinear element networks," Cornell University, Ithaca, NY, Computer Systems Laboratory Technical Report CSL-TR-2002-1024, 2002.
[22] B. A. Minch, C. Diorio, and P. Hasler, "Multiple-input translinear element networks," IEEE Transactions on Circuits and Systems II: Analog and Digital Signal Processing, vol. 48, no. 1, pp. 20-28, 2001.
[23] B. A. Minch, C. Diorio, P. Hasler, and C. A. Mead, "Translinear circuits using subthreshold floating-gate MOS transistors," Analog Integrated Circuits and Signal Processing, vol. 9, no. 2, pp. 167-180, 1996.
$[24]$ B. A. Minch, P. Hasler, and C. Diorio, "Synthesis of multiple-input translinear element networks," in Proc. of the 1999 IEEE Inter. Symposium on Circuits and Systems, vol. 2, Orlando, FL, June 1999, pp. 236-239.
[25] B. A. Minch and P. Hasler, "Floating-gate technology for digital cmos processes," in Proc. of the 1999 IEEE International Symposium on Circuits and Systems, vol. 2, Orlando, FL, May 1999, pp. 400-403.
[26] T. Morie, H. Onodera, and K. Tamaru, "A system for analog circuit design that stores and re-uses design procedures," in Proc. of the 1993 IEEE Custom Integrated Circuits Conference, vol. 5, San Diego, CA, May 1993, pp. 13.4.113.4.4.
[27] J. Mulder, M. Kouwenhoven, W. Serdijn, A. van der Woerd, and A. van Roermund, "Analysis of noise in translinear filters," in Proc. of the 1998 IEEE International Symposium on Circuits and Systems, vol. 1, Monterey, CA, May 1998, pp. 337-340.
[28] J. Mulder, W. A. Serdijn, A. C. van der Woerd, and A. H. M. van Roermund, "Dynamic translinear RMS-DC converter," Electronics Letters, vol. 32, no. 22, pp. 2067-2068, 1996.
[29] ——, "A current-mode synthesis method for translinear companding filters," in Proc. of the Fourth IEEE International Conference on Electronics, Circuits, and Systems, vol. 3, Cairo, December 1997, pp. 1419-1422.
[30] ——, Dynamic Translinear and Log-Domain Circuits: Analysis and Synthesis. Boston: Kluwer, 1999.
[31] J. Mulder, A. C. van der Woerd, W. A. Serdijn, and A. H. M. van Roermund, "General current-mode analysis method for translinear filters," IEEE Transactions on Circuits and Systems I: Fundamental Theory and Applications, vol. 44, no. 3, pp. 193-197, 1997.
[32] D. Perry and G. W. Roberts, "The design of log-domain filters based on the operational simulation of $l c$ ladders," IEEE Transactions on Circuits and Systems II: Analog and Digital Signal Processing, vol. 43, no. 11, pp. 763-774, 1996.
[33] S. Pookaiyaudom and J. Mahattanakul, "A 3.3 volt high-frequency capacitorless electronically-tunable log-domain oscillator," in Proc. of the 1995 IEEE International Symposium on Circuits and Systems, vol. 2, Seattle, WA, June 1995, pp. 829-832.
[34] M. Punzenberger and C. Enz, "Noise in instantaneous companding filters," in Proc. of the 1997 IEEE International Symposium on Circuits and Systems, vol. 1, Hong Kong, Hong Kong, June 1997, pp. 337-340.
[35] -, "Noise in high-order log-domain filters," in Proc. of the 1998 IEEE International Symposium on Circuits and Systems, vol. 1, Monterey, CA, May 1998, pp. 329-332.
[36] ——, "New 1.2 V BiCMOS log-domain integrator for companding currentmode filters," in Proc. of the 1996 IEEE International Symposium on Circuits and Systems, vol. 1, Atlanta, GA, June 1996, pp. 125-128.
[37] D. Rhodes, "A design language for analog circuits," IEEE Spectrum, vol. 33, no. 10, pp. 43-48, 1996.
[38] R. Sarpeshkar, "Analog versus digital-extrapolating from electronics to neurobiology," Neural Computation, vol. 10, no. 7, pp. 1601-1638, 1998.
[39] E. Seevinck, Analysis and Synthesis of Translinear Integrated Circuits. Amsterdam: Elsevier, 1988.
[40] W. A. Serdijn, J. Mulder, P. Poort, M. Kouwenhoven, A. van Staveren, and A. H. M. van Roermund, "Dynamic translinear circuits," in Analog Circuit Design: Volt Electronics; Mixed-Mode Systems; Low-Noise and RF Power Amplifiers for Telecommunication, J. Huijsing, R. van de Plassche, and W. Sansen, Eds. Boston: Kluwer, 1999, pp. 3-32.
[41] W. A. Serdijn, J. Mulder, A. C. van der Woerd, and A. H. M. van Roermund, "A wide-tunable translinear second-order oscillator," IEEE Journal of SolidState Circuits, vol. 33, no. 2, pp. 195-201, 1998.
[42] W. A. Serdijn, J. Mulder, and A. H. M. van Roermund, "Shortening the analog design trajectory by means of the dynamic translinear principle," in Proc. of the 1997 ProRISC Workshop on Circuits, Systems and Signal Processing, Mierlo, The Netherlands, November 1997, pp. 483-489.
[43] H. Shibata, "Automated design of analog computational circuits using cellbased structure," in Proc. of the 2002 IEEE International Symposium on Circuits and Systems, vol. 2, Phoenix-Scottsdale, AZ, MAY 2002, pp. 53-56.
[44] M. Shojaei and M. Sharif-Bakhtiar, "A method for automatic design of analog circuits based on a behavioral model," in Proc. of the 1998 IEEE International Symposium on Circuits and Systems, vol. 3, Monterey, CA, May 1998, pp. 399-402.
[45] A. Thanachayanont and A. Payne, "A current-mode phase-locked loop using a log-domain oscillator," in Proc. of the 1997 IEEE International Symposium on Circuits and Systems, vol. 1, Hong Kong, June 1997, pp. 277-280.
[46] A. Thanachayanont, S. Pookaiyaudom, and C. Toumazou, "State-space synthesis of log-domain oscillators," Electronics Letters, vol. 31, no. 21, pp. 17971799, 1995.
[47] E. Tielo-Cuautle and A. Diaz-Sanchez, "An heuristic circuit-generation technique for the design-automation of analog circuits," in Proc. of the 2003 IEEE International Symposium on Circuits and Systems, vol. 1, Bangkok, Thailand, May 2003, pp. 193-196.
[48] A. Tola and D. Frey, "Study of different class ab log domain first order filters," Analog Integrated Circuits and Signal Processing, vol. 2, no. 2.
[49] L. Toth, Y. Tsividis, and N. Krishnapura, "Analysis of noise and interference in companding signal processors," in Proc. of the 1998 IEEE International Symposium on Circuits and Systems, vol. 1, Monterey, CA, May 1998, pp. 143-146.
[50] Y. Tsividis, "Externally linear, time-invariant systems and their application to companding signal processors," IEEE Transactions on Circuits and Systems II, vol. 44, no. 2, pp. 65-85, 1997.
[51] A. van Schaik and C. Jin, "The tau-cell: a new method for the implementation of arbitrary differential equations," in Proc. of the 2003 IEEE International Symposium on Circuits and Systems, vol. 1, Bangkok, Thailand, May 2003, pp. 569-572.

