# Robust Analog Circuit Sizing Using Ellipsoid Method and Affine Arithmetic 

Xuexin Liu, Wai-Shing Luk*, Yu Song, Pushan Tang and Xuan Zeng<br>ASIC \& System State Key Lab., Microelectronics Dept.

Fudan University, Shanghai 200433, P.R.China
luk@fudan.edu.cn


#### Abstract

Analog circuit sizing under process/parameter variations is formulated as a mini-max geometric programming problem. To tackle such problem, we present a new method that combines the ellipsoid method and affine arithmetic. Affine arithmetic is not only used for keeping tracks of variations and correlations, but also helps to determine the sub-gradient at each iteration of the ellipsoid method. An example of designing a CMOS operational amplifier is given to demonstrate the effectiveness of the proposed method. Finally numerical results are verified by SPICE simulation.


## I. Introduction

In this paper, we will introduce a new method for analog circuit sizing under process/parameter variations via convex programming formulation. In addition, we take a design of a CMOS op-amp as an example to illustrate our method.

Several performance parameters of the CMOS op-amp are determined by the geometries and bias currents settled down by designers. Before the design process is started, a suite of detailed specifications is given, which in usual includes commonmode input voltage, output voltage swing range, open-loop voltage gain, unity-gain bandwidth, phase margin, commonmode rejection ratio, slew rate, power dissipation, total die area, and so on. Provided that all the specifications are achieved in the design, the designer can optimize some aspects of performances in his/her best. Thus this scenario can be formulated in a mathematical terminology "constrained optimization". Correspondingly those specifications become the constraints we must obey.

The CMOS op-amp design has been studied extensively and a lot of excellent design tutorials are available today [1]. With their help a list of equations can be set up so that every performance can be determined by design parameters. Obviously, the main focus of optimization is on a specific configuration that some aspects of performance achieve optima, provided all restrictions are not broken. Circuit optimization of this style does give an optimal solution at a narrow operating condition range.

[^0]However, a slight variation of process or working environment may arise wrong function or even complete failure in the circuit (e.g., field failure, when the chip is used under extreme operating conditions like high temperatures). This case will drastically damage the robustness or reduce the yield. Hence industrial practice not only demands fully optimized design solutions, but also expects high robustness and yield under the varying operating conditions, statistical process tolerances and mismatches [2].

Traditional worst-case analysis suffers expensive computation that even the optimization of some small and simple circuit will take a terribly long time. This disadvantage roots in the reason that worst case is calculated on the base of real arithmetic, which also leads to underestimation of true worst case. Consequently, the results may be too optimistic and cause the final design to violate the specifications if process variation or operating condition changes a little [3].

To take variations into account, a robust mathematical programming problem is formulated in a mini-max form:

$$
\begin{array}{ll}
\operatorname{minimize} & \sup _{q \in Q} f_{0}(y, q) \\
\text { subject to } & f_{j}(y, q) \leq 0 \\
& \forall q \in Q \text { and } j=1,2, \cdots, m . \tag{1}
\end{array}
$$

In this formulation, $Q$ stands for all the variations of parameter space and $y$ still represents our design space. In this way the constraints $f_{j}(y, q) \leq 0$ are the specifications that must be met with, while the object function is the supremum of all the possible values of $f_{0}(y, q)$. In case of the CMOS op-amp design, almost every critical equation can be expressed in form of geometric programming (GP) [4]. The most helpful characteristic of geometric programming is that it can be easily reformulated as a convex optimization problem, thus we can further assume that the function $f_{0}(y, q)$ and the constraints $f_{j}(y, q)$ are convex for all $q \in Q$. Hence the feasible region is convex because the intersection of convex sets remains a convex set. As a result, the overall mini-max objective function is still convex but non-differentiable in general. In addition, there are infinite number of constraints in mini-max form (1) because of the variations of $q$. The standard interior point method may not be able to handle such problem effectively. To deal with this special form of convex programming, we propose using the ellipsoid method, which can be classified as the geometric approach and treat the programming progress by approximating the feasible region by a sequence of ellipsoids with decreasing

## 2C-3

volumes. It can be proved that the ellipsoid method preserves the property of containing a bounded convex feasible region and converges to an ellipsoid the center of which is the optimal result [5].

With the aim to implement a variation-tolerant analog circuit optimization, we propose using affine arithmetic to participate at each iteration of the ellipsoid method. Affine arithmetic has been developed for a wide range of applications in which process variations are considered. One of the advantages of affine arithmetic over interval arithmetic is that it can keep tracks of correlations in computations, by sharing a set of global variables named noise symbols. Nevertheless, it is usually employed in analysis rather than in optimization. In this paper, we further utilize affine arithematic for finding the sub-gradient at each iteration of the ellipsoid method.

This paper is organized as follows. Section II reviews previous works on geometric programming. Some issues related to this area are summarized. Section III describes the ellipsoid method that will be applied in our proposed optimization program. In Section IV, we propose our affine arithmetic based method to optimize circuits as well as analyze and predict the impacts of process variations. Experimental results are described in Section V. Finally, Section VI will give the conclusion.

## II. Geometric Programming in Convex Form

The geometric programming is an optimization problem which has the following form:

$$
\begin{array}{cl}
\operatorname{minimize} & p_{0}(x) \\
\text { subject to } & p_{i}(x) \leq 1, \quad i=1, \ldots, l \\
& g_{j}(x)=1, \quad j=1, \ldots, m  \tag{2}\\
& x_{k}>0, \quad k=1, \ldots, n
\end{array}
$$

where $p_{0}, p_{1}, \ldots, p_{l}$ are posynomial functions and $g_{1}, \ldots, g_{m}$ are monomial functions. A posynomial function is real-valued function of $n$ real, positive variable $x_{k}$, which is defined as

$$
\begin{equation*}
p\left(x_{1}, \ldots, x_{n}\right)=\sum_{s=1}^{t} c_{s} x_{1}^{\alpha_{1 s}} x_{2}^{\alpha_{2 s}} \cdots x_{n}^{\alpha_{n s}}, \quad x_{k}>0 \tag{3}
\end{equation*}
$$

where nonnegative coefficient $c_{s} \geq 0$ and $\alpha_{k s} \in \mathrm{R}$. When the posynomial has only one nonzero term in the sum, i.e., with the following form, it is called monomial.

$$
\begin{equation*}
g\left(x_{1}, \ldots, x_{n}\right)=c x_{1}^{\alpha_{1}} x_{2}^{\alpha_{2}} \cdots x_{n}^{\alpha_{n}}, \quad x_{k}>0 \tag{4}
\end{equation*}
$$

By taking the logarithm of $x_{k}$ and define $y_{k}=\log x_{k}$ as well as $x_{k}=e^{y_{k}}$, we obtain $f_{i}(y)=\log \left(p_{i}\left(e^{y_{1}}, \ldots, e^{y_{n}}\right)\right)=$ $\log \left(\sum_{k=1}^{t} e^{\alpha_{k}^{T} y+b_{k}}\right)$. Thus the problem is transformed into convex form:

$$
\begin{array}{ll}
\operatorname{minimize} & f_{0}(y) \\
\text { subject to } & f_{i}(y) \leq 0, \quad i=1, \ldots, l \\
& g_{j}(y)=0, \quad j=1, \ldots, m
\end{array}
$$



Fig. 1. A typical two-stage CMOS op-amp.

The most essential advantage of convex programming is the efficient solution of global optimum, and is especially apt to handle a large number of concurrent constraints. It can handle the problems with hundreds of variables and thousands of constraints. Furthermore, it gives an unambiguous recognition of infeasible specifications. It is also a rather versatile method that it is recommended to solve floor planning, gate scaling, Elmore delay modeling, and even analog filter or RF circuit optimization [6].

Previous works have formulated the design optimization of two-stage CMOS op-amp, with the structure in Fig. 1, as a convex optimization problem after expressing the object and constraint functions in geometric programming form [4]. It also shows that if the equations are constructed by some data fitting approaches, the results of the optimization will be more accurate and reliable when compared with simulation tools such as SPICE.

To solve the convex programming problem, it is reported in [4] that an interior-point method is implemented, which consists a primal barrier method for solving the convex form problem, and applies a modified Newton's method to minimize a smoothed convex function. However, in case that some quasiconvex or non-differentiable functions are presented as in robust design, the interior-point method may not perform well. In addition, even though an optimization is finished successfully using this method, the designers can obtain nothing more than an optimal result, i.e., some helpful hints about the covariance of the design space considering uncertainty are still unavailable. In the next section we will describe how to apply the ellipsoid method to tackle this problem.

## III. The Ellipsoid Method

The ellipsoid method first generates an ellipsoid large enough to contain the feasible region. A hyperplane $g^{T} x=b$, can be constructed by linearizing the region boundary at a


Fig. 2. In each iteration, new ellipsoid is constructed according to Algorithm 1.
boundary point. Assume $g$ is the gradient of $f$, the constraint active at the boundary point $x_{B}$ (if $f$ is non-differentiable or quasi-convex, sub-gradient or quasi-gradient of $f$ is used [7]), then the constructed hyperplane $b=g^{T} x_{B}$ divides the current ellipsoid into two parts. For a convex feasible region, one part, $g^{T} x>b$, is completely infeasible; the other, $g^{T} x<b$, contains the feasible region. Hence we can construct a new ellipsoid with a smaller volume to replace the old one. Fig. 2 illustrates this updating process in one iteration of the algorithm.

Assume that an ellipsoid is

$$
\begin{equation*}
E(x, A)=\left\{z \in \mathrm{R}^{n} \mid(z-x)^{T} A^{-1}(z-x) \leq 1\right\} \tag{6}
\end{equation*}
$$

with the center at $x$ and a positive definite matrix $A$ indicating its size and feature. The center of the starting ellipsoid may be feasible or infeasible. In case that the center is infeasible, the volume of the starting ellipsoid is expected to be larger.The basic ellipsoid method for unconstrained problem is presented in Algorithm 1.

```
Algorithm 1 The basic ellipsoid method [8]
Input: A convex function \(f: \mathrm{R}^{n} \rightarrow \mathrm{R}\). An initial ellipsoid
    \(E(x, A)\) large enough to contain the optimum \(x^{*}\).
Output: Return optimum \(x^{*}\) after converging to tolerance \(\epsilon\).
    repeat
        compute \(\nabla f(x)\)
        if \(\sqrt{\nabla f(x)^{T} A \nabla f(x)} \leq \epsilon\) then
            return \(x\)
        end if
        /* update ellipsoid */
        \(\tilde{g}=\nabla f(x) / \sqrt{\nabla f(x)^{T} A \nabla f(x)}\)
        \(x=x-\frac{1}{n+1} A \tilde{g}\)
        \(A=\frac{n^{2}}{n^{2}-1}\left(A-\frac{2}{n+1} A \tilde{g} \tilde{g}^{T} A\right)\)
    until converge
```

The ellipsoid method has the following properties. First, it reduces to a bisection method when the space dimension re-
duces to one-dimension, i.e., $\mathrm{R}^{n}$ is R if $n=1$. Second, the calculations about generating a new ellipsoid are less complex and arduous than other methods. If $E\left(x^{(k)}, A^{(k)}\right)$ and $\nabla f\left(x^{(k+1)}\right)$ are known, $E\left(x^{(k+1)}, A^{(k+1)}\right)$ is found out with the complexities at most matrix-vector multiplication. Third, the new el$\operatorname{lipsoid} E\left(x^{(k+1)}, A^{(k+1)}\right)$ may be larger than $E\left(x^{(k)}, A^{(k)}\right)$ in diameter (max semi-axis length), but is always smaller in volume, and we have

$$
\operatorname{vol}\left(E\left(x^{(k+1)}, A^{(k+1)}\right)\right)<e^{-\frac{1}{2 n}} \operatorname{vol}\left(E\left(x^{(k)}, A^{(k)}\right)\right)
$$

where $n$ is the dimension of variable space. This inequality ensures the convergence after a finite number of iterations. Lastly, this method can handle non-differentiable (or non-smooth) or quasi-convex constraints.

## IV. Optimization Using Affine Arithmetic

The analog circuits face to the challenges posed by process variations and if designers do not give enough consideration to these impacts before manufacturing, the performance and yield of the chips will suffer much. That is why design for manufacturability (DFM) technology becomes a prerequisite in the early stage of design to enhance yield of devices in the final stage. Monte Carlo analysis is a popular method most useful in the production phase as a fine-tuning method of design. It is necessary to find the respond surface model that describes the circuit sensitivities and correlations to and among the process parameters and design variables. However, this method suffers from large computation effort and lacks reliable information of the statistical circuit response [5]. Another widely used technique is the corner-enumeration worst-case design optimization in which the circuit performance is optimized for all the corners. However, this method suffers from inefficiency and often produces an over-conservative design [9].

In this paper we propose a new methodology using affine arithmetic and give a practical algorithm implementing this optimization under process variations. In our approach, traditional standard real arithmetic are replaced by affine arithmetic. Therefore it will estimate the worst case more accurately without sacrificing the computational efficiency. Recent researches in affine arithmetic have brought innovative ideas to the field of IC design in which process/parameter variations are considered. One of such applications is the use of affine arithmetic in model order reduction (MOR) and statistical modeling of interconnect and effective capacitance [10], in which they developed new correlated interval technique for representing statistics inside algorithms, for example, an interval involved LU decomposition are solved when statistical uncertainties are encountered.

Affine arithmetic was developed from interval arithmetic, they are both self-validated numerical algorithms keeping track of the accuracy of all quantities that it computes, as part of the process of computing them. In interval arithmetic, a real quantity $x$ is represented by an interval of floating-point numbers:

$$
\begin{equation*}
\bar{x}=\left[x_{\min }, x_{\max }\right]:=\left\{x \in \mathrm{R} \mid x_{\min } \leq x \leq x_{\max }\right\} \tag{7}
\end{equation*}
$$

```
Algorithm 2 Ellipsoid method for Robust Convex Program-
ming
    while not converge do
        if for some \(j, \sup _{q \in Q} f_{j}(y, q)>0\) then \(/ * y\) infeasible */
            Let \(q_{\text {max }}=\arg \sup _{q \in Q} f_{j}(y, q)\)
            Find \(g=\nabla f_{j}\left(y, q_{\max }\right)\)
            if \(f_{j}\left(y, q_{\max }\right)-\sqrt{g^{T} A g}>0\) then
            return infeasible
            end if
        else /* \(y\) feasible */
            Let \(q_{\text {max }}=\arg \sup _{q \in Q} f_{0}(y, q)\)
            Find \(g=\nabla f_{0}\left(y, q_{\text {max }}\right)\)
            if \(\sqrt{g^{T} A g}<\epsilon\) then
            return optimal solution
            end if
        end if
        Update Ellipsoid (y, A)
    end while
```

It also guaranteed that functions defined on real arithmetic can be safely extended to interval arithmetic and some necessary properties are preserved, such as inclusion isotonicity [3].

Unfortunately, interval arithmetic often yields a result wider in range than the exact result. For instance, assume $x=$ $[-1,1]$, it will give a subtraction $x-x=[(-1)-1,1-(-1)]=$ $[-2,2]$ instead of $[0,0]$, which is the exact range of the result. The reason for this overestimation is the missing of information on the correlation of intervals in (7) where an interval is defined.

Affine arithmetic was proposed to overcome the error overestimation in such a method that besides recording a range for each quantity, it also keeps track of correlations between those quantities, in order to add information to the process of computing [11]. In affine arithmetic a quantity $x$ is formulated in an affine form $\hat{x}$ :

$$
\begin{align*}
\hat{x} & =x_{0}+x_{1} \varepsilon_{1}+x_{2} \varepsilon_{2}+\cdots+x_{k} \varepsilon_{k} \\
& =x_{0}+\sum_{i=1}^{k} x_{i} \varepsilon_{i}, \quad-1 \leq \varepsilon_{i} \leq 1, \quad x_{i} \in R \tag{8}
\end{align*}
$$

All $\varepsilon_{i}$ are called noise symbols whose values are unknown but assumed to lie in the interval $[-1,1]$ and they are all global variables that can be shared by all affine forms. Thus if we take out a computation between two variables sharing the same noise symbol, the error will not be exaggerated as in the preceding case that an interval arithmetic came across.

Now we propose our affine arithmetic based ellipsoid method which is illustrated in Algorithm 2. As defined in minimax form (1), assume all $q \in Q$ represent the parameters under process variations and are initialized as affine forms, our algorithm starts a modified ellipsoid method for robust convex programming.

In Section III, we have known that a hyperplane is constructed at a boundary point and then the gradient at that point
is computed. The key issue is to determine this point, and here affine arithmetic is applied with special consideration. In our algorithm, this point have an intimate relation with $q_{\max }$ which is defined in supremum over a set of convex functions.

For instance, let $q_{\max }$ denotes the parameter $q$ where $f_{j}(y, q)$ is maximized for a fixed $y$, i.e.,

$$
\begin{equation*}
q_{\max }=\arg \sup _{q \in Q} f_{j}(y, q) \tag{9}
\end{equation*}
$$

After affine arithmetic operations, $f_{j}$ is approximated as an affine form:

$$
\begin{align*}
\hat{f}_{j} & =f_{j, 0}+f_{j, 1} \varepsilon_{1}+f_{j, 2} \varepsilon_{2}+\cdots+f_{j, k} \varepsilon_{k} \\
& =f_{j, 0}+\sum_{i=1}^{k} f_{j, i} \varepsilon_{i}, \quad \varepsilon_{i} \in[-1,1] \tag{10}
\end{align*}
$$

We have that $\hat{f}_{j}$ is maximized when

$$
\varepsilon_{i}= \begin{cases}+1 & \text { if } f_{j, i}>0  \tag{11}\\ -1 & \text { if } f_{j, i}<0\end{cases}
$$

This is to say that we can determine $\varepsilon_{j}$ be either +1 or -1 and hence $q_{\text {max }}$ is determined.

As can be proved in [7], if all $f_{j}(y, q)$ functions are convex, the supremum $\sup f_{j}(y, q)$ is also convex, though it is non-differentiable in general. Nevertheless, this will not make much difficulty for the ellipsoid method to solve it.

## V. Example

In this section, we will describe a simple example and show the performance of our approach. We implemented an optimization tool prototype on two-stage CMOS op-amp based on our proposed method in C++ with the Libaffa package [12]. In fact, it is convenient that the researchers of different interest can build customized affine arithmetic libraries for their own use. We have fulfilled many useful functions and added them to the library, which will greatly facilitate our computations.

The schematic of our circuit is shown in Fig. 1. The specifications of the op-amp, which are the constraints of the optimization tool, are listed in Table I. The objective is the term to be maximized or minimized subject to all the specifications. Here our object is the unity gain frequency. The design verification of our results are based on HSPICE level-1 model.

If process variations are not considered, the design progress is purely a geometric programming to obtain an optimization of some terms of performance. The results of our tool are the parameters shown in column "Standard" in Table II. And the corresponding performance are listed in column "Standard" in Table III. It is very reliable that the results of HSPICE meet the specifications in Table I.

If we set some process parameters to be affine arithmetic variables, which means these parameters are under the impacts of process variations, our optimization tools will exert the improved ellipsoid method that we described in last section and finally give an optimal answer under process variations.

TABLE I
Specifications for the Example of Op-Amp.

| Constraint | Units | Spec. |
| :--- | :---: | :--- |
| Device Width | $\mu \mathrm{m}$ | $\geq 2.0$ |
| Device Length | $\mu \mathrm{m}$ | $\geq 0.8$ |
| Estimated Area | $\mu \mathrm{m}^{2}$ | $\leq 20000$ |
|  | V | $V_{D D}=5$ |
| Supply Voltage | V | $V_{S S}=0$ |
| Common-Mode Input | V | $V_{D D} / 2$ |
| Output Range | V | $[0.1,0.9] V_{D D}$ |
| Gain | dB | $\geq 80$ |
| Unity Gain Freq. | MHz | Maximize |
| Phase Margin | degree | $\geq 60$ |
| Slew Rate | $\mathrm{V} / \mu \mathrm{s}$ | $\geq 10$ |
| Load Capacitance | pF | 3 |
| CMRR | dB | $\geq 60$ |
| Neg. PSRR | dB | $\geq 80$ |
| Power | mW | $\leq 5$ |
| Noise, Flicker | $\mathrm{nV} / \sqrt{\mathrm{Hz}}$ | $\leq 300$ |

TABLE II
Optimal Design Results Using the Proposed Method.

| Variable | Standard | Robust |
| :--- | ---: | ---: |
| $W_{1}=W_{2}$ | $401.3 \mu \mathrm{~m}$ | $422.9 \mu \mathrm{~m}$ |
| $W_{3}=W_{4}$ | $132.6 \mu \mathrm{~m}$ | $139.7 \mu \mathrm{~m}$ |
| $W_{5}$ | $91.5 \mu \mathrm{~m}$ | $67.4 \mu \mathrm{~m}$ |
| $W_{6}$ | $183.8 \mu \mathrm{~m}$ | $134.9 \mu \mathrm{~m}$ |
| $W_{7}$ | $62.9 \mu \mathrm{~m}$ | $32.2 \mu \mathrm{~m}$ |
| $W_{8}$ | $2.0 \mu \mathrm{~m}$ | $2.0 \mu \mathrm{~m}$ |
| $L_{1}=L_{2}$ | $0.8 \mu \mathrm{~m}$ | $0.8 \mu \mathrm{~m}$ |
| $L_{3}=L_{4}$ | $0.8 \mu \mathrm{~m}$ | $0.8 \mu \mathrm{~m}$ |
| $L_{5}=L_{7}=L_{8}$ | $0.8 \mu \mathrm{~m}$ | $0.8 \mu \mathrm{~m}$ |
| $L_{6}$ | $0.8 \mu \mathrm{~m}$ | $0.8 \mu \mathrm{~m}$ |
| $R_{c}$ | $110.0 \Omega$ | $200.0 \Omega$ |
| $C_{c}$ | 7.4 pF | 9.8 pF |
| $I_{\text {bias }}$ | $12.7 \mu \mathrm{~A}$ | $19.3 \mu \mathrm{~A}$ |

For example, here we set the MOSFET threshold voltage, lateral diffusion length, gate oxide thickness and power supply voltage under process/parameter variations:

$$
\begin{aligned}
V_{T H, N M O S} & =[0.65,0.75] \mathrm{V} \\
V_{T H, P M O S} & =[-0.95,-0.85] \mathrm{V} \\
L_{D} & =[0.19,0.21] \mu \mathrm{m} \\
T_{O X} & =[16,24] \mathrm{nm} \\
V_{D D} & =[4.7,5.3] \mathrm{V}
\end{aligned}
$$

Then the optimal design will like the values in column "Robust" in Table II. And the performances of the circuit using these parameters are shown in column "Robust" in Table III. If we compare the transistors' geometric parameters, e.g. $W_{1}$ to $W_{8}$ in "Standard" and "Robust" columns in Table II, it can be inferred that after the process variations are considered

TABLE III
Performance of Op-Amp with Optimal Design's Results.

| Performance | Standard | Robust |
| :--- | ---: | ---: |
| Estimated Area | $16400 \mu \mathrm{~m}^{2}$ | $18200 \mu \mathrm{~m}^{2}$ |
| Output Range | $[0.08,0.92] V_{D D}$ | $[0.08,0.92] V_{D D}$ |
| Gain | 92 dB | 91 dB |
| Unity Gain Freq. | 70 MHz | 74 MHz |
| Phase Margin | 61.3 degree | 64.5 degree |
| Slew Rate | $21 \mathrm{~V} / \mu \mathrm{s}$ | $22 \mathrm{~V} / \mu \mathrm{s}$ |
| CMRR | 95 dB | 95 dB |
| Neg. PSRR | 101 dB | 101 dB |
| Power | 5.0 mW | 4.9 mW |
| Noise, Flicker | $298 \mathrm{nV} / \sqrt{\mathrm{Hz}}$ | $290 \mathrm{nV} / \sqrt{\mathrm{Hz}}$ |

in the design, the standard sizing results must be relaxed so as to allocate enough margins for the performances. Therefore the circuits can still meet the specifications even though process/parameter variations occur.

Each of the two cases was solved in less than one second on Intel Pentium IV running at 2.4 GHz .

Fig. 3 illustrates the variation of lateral diffusion $L_{D}$, and here we plot three lines which are the cases $L_{D}=0.19 \mu \mathrm{~m}$, $L_{D}=0.20 \mu \mathrm{~m}$, and $L_{D}=0.21 \mu \mathrm{~m}$. We can find out that the performances in the range of $L_{D}$ satisfy our specifications. The open loop gains are larger than the one we set in Table I and phase margins are all greater than 60 degree. Fig. 4(a) shows the case when power supply voltage $V_{D D}$ and $L_{D}$ are changed simultaneously in the range $V_{D D}=[4.7,5.3] \mathrm{V}$ and $L_{D}=[0.19,0.21] \mu \mathrm{m}$, while Fig. 4(b) plots how the value of phase margin changes when $L_{D}$ and oxide thickness $T_{O X}$ are both under variations in the range $L_{D}=[0.19,0.21] \mu \mathrm{m}$ and $T_{O X}=[16,24] \mathrm{nm}$. As a result, the phase margin never become less than 60 degree. It confirms the validity of our optimization tool again since the constraints we set previously are strictly met.

## VI. Conclusions

In this paper we have presented a novel approach to variation-tolerant analog circuit sizing via robust convex programming formulation. We proposed using the ellipsoid method to approximate the feasible region at each iteration, thus guarantee the bounding of the whole design space with good efficiency. Furthermore, we adopt affine arithmetic rather than standard real arithmetic to solve the optimization problem. It can precisely take the variations and worst-case performances into account without loss of efficiency. The example of a two-stage CMOS op-amp given in this paper demonstrated the practical usability of our solution.

## REFERENCES

[1] Behzad Razavi. Design of Analog CMOS Integrated Circuits. McGrawHill, 2001.


Fig. 3. Open loop gain and phase margin versus frequency. (The solid line represent the case when $L_{D}=0.20 \mu \mathrm{~m}$, the dash-dot line $L_{D}=0.19 \mu \mathrm{~m}$, and the dotted line $L_{D}=0.21 \mu \mathrm{~m}$.)
[2] S. Director, W. Maly, and A. Strojwas. VLSI Design for Manufacturing: Yield enhancement. Kluwer, Norwell, MA, 1990.
[3] Andreas Lemke, Lars Hedrich, and Erich Barke. Analog circuit sizing based on formal methods using affine arithmetic. In IEEE/ACM Proc. Int. Conf. Computer Aided Design, pages 486-489, November 2002.
[4] Maria del Mar Hershenson, Stephen P. Boyd, and Thomas H. Lee. Optimal design of a CMOS op-amp via geometric programming. IEEE Trans. Comput.-Aided Des. Integr. Circuits Syst., 20(1):1-21, January 2001.
[5] Hany L. Abdel-Malek and Abdel-Karim S. O. Hassan. The ellipsoidal technique for design centering and region approximation. IEEE Trans. Comput.-Aided Des. Integr. Circuits Syst., 10(8):1006-1014, August 1991.
[6] S. Boyd, S.-J. Kim, L. Vandenberghe, and A. Hassibi. A tutorial on geometric programming. Technical report, Electrical Engineering Department, Stanford University, September 2004. Available at http: //www. stanford.edu/~boyd/gp_tutorial.html.
[7] Stephen Boyd and Lieven Vandenberghe. Convex Optimization. Cambridge University Press, 2004.
[8] S. Boyd. Lecture notes of convex porgramming. Available at http: //www.stanford.edu/class/ee364.
[9] Yang Xu, Kan-Lin Hsiung, Xin Li, Ivan Nausieda, Stephen Boyd, and Lawrence Pileggi. OPERA: Optimization with ellipsoidal uncertainty for robust analog IC design. Proc. Design Automation Conf., pages 632637, June 2005.
[10] James. D. Ma and Rob. A. Rutenbar. Fast interval-valued statistical modeling of interconnect and effective capacitance. IEEE Trans. Comput.Aided Des. Integr. Circuits Syst., 25(4):710-724, April 2006.
[11] J. Stolfi and L. H. de Figueiredo. An introduction to affine arithmetic. Tend. Mat. Apl. Comput., 4(3):297-312, 2003.
[12] Olivier Gay, David Coeurjolly, and Nathan Hurst. Libaffa: C++ affine arithmetic library for GNU/Linux. Available at http: / /savannah. nongnu.org/projects/libaa/, May 2005.

(a) Phase margin vs. the power supply voltage $V_{D D}$ and MOSFET Lateral diffusion Length $L_{D}$.

(b) Phase margin vs. MOSFET Lateral diffusion Length $L_{D}$ and gate oxide thickness $T_{O X}$.

Fig. 4. Frequency response under the variation of power supply, Lateral diffusion Length and gate oxide thickness.


[^0]:    This work is supported in part by National Science Foundation of China (NSFC) Research Project 90307017 and 60676018, by National Basic Research Program of China under Grant 2005CB321701, by Cross-Century Outstanding Scholar's Fund of Ministry of Education of China, by Doctoral Program Foundation of Ministry of Education of China 20050246082, by Shanghai Science and Technology Committee (STCSM) Key Project 05JC14007 and 04JC14015, and by Shanghai AM R\&D Fund 0418.

