# Balanced Multi-Level Multi-Way Partitioning of Large Analog Circuits for Hierarchical Symbolic Analysis * 

Xiang-Dong Tan and C.-J. Richard Shi<br>Department of Electrical Engineering<br>University of Washington<br>Seattle, WA 98195, USA


#### Abstract

Symbolic analsis of analog circuits is important in analog design automation. However, it is limited to the analysis of small analog circuits where exact symbolic expressions are required. In this paper, we present an efficient algorithm for partitioning large general analog circuits into smaller subcircuits so that symbolic analysis can be performed hierarachically. Experimental results have demontrated that our method ourperforms the best partitioning-based symbolic analyzer SCAPP.


## 1. Introduction

Symbolic analysis calculates the behavior or the characteristics of a circuit in terms of symbolic parameters. But symbolic analysis generally suffers the circuit-size limitation problem due to the exponential growth of the symbolic terms with the increase of circuit size. One way to cope with the size limitation problem in symbolic analysis is by means of hierarchical decomposition.

Hierarchical decomposition generates symbolic expressions in a nested form [4, 8]. However, the effectiveness of hierarchical decomposition depends crucially on how a circuit is partitioned. So far no effective partitioning algorithm for symbolic analysis has been reported on such less regular-structured circuits as $\mu A 741$ Opamp [3].

In this paper, we present a balanced multi-level multi-way partitioning heuristic for hierarchical symbolic analysis of large analog circuits [8]. It takes advantage of both hierarchical decomposition and a recently introduced graph-based representation, called Determinant Decision Diagrams (DDDs), for symbolic determinants [6].

The rest of the paper is organized as follows: Section 2 provides an overview of DDD-based hierarchical symbolic analysis. Section 3 formulates the partitioning problem for symbolic analysis. Section 4 presents our partitioning heuristic. Section 5 presents experimental results. Section 6 concludes the paper.

## 2. DDD-based Hierarchical Symbolic Analysis

For a linear(ized) time-invariant analog circuit, it is well-known that its system equation can be formulated by modified nodal analysis in the general matrix form: $\mathbf{A x}=\mathbf{b}$, where $\mathbf{x}$ is a vector of the node voltage variables and branch current variables, $\mathbf{A}$ is the modified nodal admittance matrix and $\mathbf{b}$ represents the independent sources.

If we partition the circuit into two device-disjointed parts, the variables $\mathbf{x}$ will be divided into three disjoint groups: $\mathbf{x}^{I}, \mathbf{x}^{B}$, and $\mathbf{x}^{R}$, where the sup-scripts $I, B, R$ stand for, respectively, internal variables, boundary variables and the rest of variables. Then the systemequation set can be rewritten in the following form:

$$
\left[\begin{array}{lll}
\mathbf{A}^{I I} & \mathbf{A}^{I B} &  \tag{1}\\
\mathbf{A}^{B I} & \mathbf{A}^{B B} & \mathbf{A}^{B R} \\
& \mathbf{A}^{R B} & \mathbf{A}^{R R}
\end{array}\right]\left[\begin{array}{c}
\mathbf{x}^{I} \\
\mathbf{x}^{B} \\
\mathbf{x}^{R}
\end{array}\right]=\left[\begin{array}{c}
\mathbf{B}^{I} \\
\mathbf{B}^{B} \\
\mathbf{B}^{R}
\end{array}\right]
$$

The basic idea that underlines all the hierarchical analysis methods is to eliminate some equations from the equation-set above until

[^0]the remaining set of equations involves only the desired variables. The resulting set of equations (1) by eliminating $\mathbf{x}^{I}$ can be written as follows:
\[

\left[$$
\begin{array}{cc}
\mathbf{A}^{B B *} & \mathbf{A}^{B R}  \tag{2}\\
\mathbf{A}^{R B} & \mathbf{A}^{R R}
\end{array}
$$\right]\left[$$
\begin{array}{l}
\mathbf{x}^{B} \\
\mathbf{x}^{R}
\end{array}
$$\right]=\left[$$
\begin{array}{c}
\mathbf{B}^{B *} \\
\mathbf{B}^{R}
\end{array}
$$\right]
\]

where

$$
\begin{equation*}
\mathbf{A}^{B B *}=\mathbf{A}^{B B}-\mathbf{A}^{B I}\left(\mathbf{A}^{I I}\right)^{-1} \mathbf{A}^{I B} \tag{3}
\end{equation*}
$$

and

$$
\begin{equation*}
\mathbf{B}^{B *}=\mathbf{B}^{B}-\mathbf{A}^{B I}\left(\mathbf{A}^{I I}\right)^{-1} \mathbf{B}^{I} \tag{4}
\end{equation*}
$$

In our application, $\mathbf{b}^{I}$ is a zero vector, we rewrite (3) in the following expanded form:

$$
\begin{equation*}
a_{u, v}^{B B *}=a_{u, v}^{B B}-\frac{1}{\operatorname{det}\left(\mathbf{A}^{I I}\right)} \sum_{k_{1}, k_{2}=1}^{l} a_{u, k_{1}}^{B I} \Delta_{k_{2}, k_{1}}^{I I} a_{k_{2}, v}^{I B} \tag{5}
\end{equation*}
$$

where $u, v=1, \ldots, k, \mathrm{k}$ is size of $\mathbf{A}^{B B *}, l$ is the size of $\mathbf{A}^{I I}$, $\operatorname{det}\left(A^{I I}\right)$ is the determinant of matrix $A^{I I}, a_{u, v}^{B B *}$ is the entry at row $u$ and column $v$ in $\mathbf{A}^{B B *}, \Delta_{k_{2}, k_{1}}^{I I}$ is the first order cofactor of $A^{I I}$ defined as $(-1)^{\left(k_{2}+k_{1}\right)} \operatorname{det}\left(A_{k_{2}, k_{1}}^{I I}\right)$ and $A_{k_{2}, k_{1}}^{I I}$ is obtained by eliminating row $k_{2}$ and column $k_{1}$ in $A^{I I}$.

Note that we need first-order cofactors $\Delta_{k_{2}, k_{1}}^{I I}$ only when $a_{u, k_{1}}$ and $a_{k_{2}, v}$ are both non-zeros. In practice $a_{u, k_{1}}$ and $a_{k_{2}, v}$ are zero for most time due to the sparsity of $A^{B I}$ and $A^{I B}$, provided a good partitioning is given. The determinant $\operatorname{det}\left(\mathbf{A}^{I I}\right)$ and a few of its required first-order cofactors can be efficiently represented by a newly proposed special graph, Determinant Decision Diagrams, described as follows.

A DDD example for a determinant is shown in Fig. 1. Its determinant is shown in the left-hand side. Except for two special


Figure 1: A matrix determinant and its DDD.
terminal vertices, namely the 0 -terminal vertex and the 1 -terminal vertex, each non-terminal vertex is labeled by a symbol in the determinant denoted by $a_{i}$, and a sign denoted by $s\left(a_{i}\right)$. It originates two outgoing edges, called 1 -edge and 0 -edge. Each vertex $a_{i}$ represents a symbolic expression $D\left(a_{i}\right)$ defined recursively as follows: $D\left(a_{i}\right)=a_{i} s\left(a_{i}\right) D_{a_{i}}+D_{\bar{a}_{i}}$. where $D_{a_{i}}$ and $D_{\bar{a}_{i}}$ represent, respectively, the vertices pointed by the 1-edge and 0-edge of $a_{i}$. A 1-path
in a DDD corresponds a product term in the original DDD, which is defined as a path from the root vertex ( $A$ in our example) to the 1terminal including all symbolic symbols and signs of the vertices that originate all the 1 -edges along the 1-path. In our example, there exist three 1-paths representing three product terms: $A D G,-A F E$ and $-C B G$. The root vertex represents the sum of these product terms.

## 3. Problem Formulation

An analog circuit can be modeled as a hypergraph $H(V, E)$ with vertex set $V=\left\{v_{1}, v_{2}, \ldots, v_{m}\right\}$ and edge set $E=\left\{e_{1}, e_{2}, \ldots, e_{n}\right\}$. Each vertex corresponds to a circuit device and each edge represents a node or net in the circuit. An edge $e_{j}$ also defines a subset of $V$ with the vertices incident on the net and $\left|e_{j}\right| \geq 2$. The $k$ way partitioning problem is to assign $v_{i}, i=1, \ldots, m$ into $k$ disjoint subsets $V_{1}, V_{2}, \ldots, V_{k}$. If $k>2$, it is a multi-way partitioning. If $V_{j}, j=1, \ldots, k$ are further decomposed into smaller subcircuits, it is called multi-level or tree partitioning, otherwise it is called two-level partitioning. The subcircuit without further subcircuit definitions is a leaf subcircuit, otherwise it is a middle subcircuit. We further define the span of a net $e_{j}$, denoted as $\operatorname{span}\left(e_{j}\right)$, as the number of the subcircuits $e_{j}$ connects. If $\operatorname{span}\left(e_{j}\right)>1, e_{j}$ is called cut net, otherwise it is an internal net.

The most important performance criterion in hierarchical symbolic analysis is how compact the generated symbolic expressions are. In our case, such requirement amounts to reducing DDD vertices used. From equation (5), we observe that the problem of reducing the DDD vertices in partitioning actually centers around reducing the number of the required first-order cofactors $\Delta_{k_{2}, k_{1}}^{I I}$ and eventually the nonzero elements in the remaining circuit. This implies that nonzero entries $a_{x, y}^{B I}$ and $a_{x, y}^{I B}$ due to boundary variables $\mathbf{x}^{B}$ should be as few as possible. Boundary variables essentially are cut nets in nodal analysis formulation. So the total number of the cut nets in all the subcircuits should to be minimized. The partitioning objective can then can be expressed as:

$$
\begin{equation*}
\min \sum_{e_{j} \in E} \operatorname{span}\left(e_{j}\right) \tag{6}
\end{equation*}
$$

To further reduce the DDD size, we also need to balance the numbers of internal nets among different subcircuits. This is due to the fact that min-cut type partitioning always gives rise to very dense interconnection within the leaf subcircuits and therefore dense circuit matrices. For a dense or full matrix, DDD representation is exponential. Suppose that the DDD size only depends on the size of determinant, then the minimal DDD size is achieved if all the determinants of subcircuits have the same size. Therefore, it is desirable to balance the number of the internal nets. For large analog circuits, each subcircuit size should also be bounded to efficiently reduce the overall DDD size. Therefore the multi-level partitioning becomes a must. Let $S$ denote the set of all cut nets $e_{j}$, i.e. $\operatorname{span}\left(e_{j}\right)>1$. The balance requirements can be expressed as following constraints:

$$
\begin{array}{ll}
\text { both: } & \frac{|E|-|S|}{k}-\tau \leq \mathrm{I}\left(V_{i}\right) \leq \frac{|E|-|S|}{k}+\tau \\
\text { tree: } & \mathrm{I}\left(V_{i}\right) \leq \alpha|E| \tag{8}
\end{array}
$$

for $i=1, \ldots, k . \mathrm{I}\left(V_{i}\right)$ is the set of internal nets in $V_{i}$, i.e. $\mathrm{I}\left(V_{i}\right)=$ $\left\{e_{j} \mid e_{j} \subseteq V_{i}\right.$ and $\left.\operatorname{span}\left(e_{j}\right)=2\right\}, \tau$ is the measure of the offset from its balanced size (referred to as deviationfactor), and $\alpha$ is a positive constant and $0<\alpha<1$.

## 4. Partitioning Algorithm

### 4.1. Multi-Way Balanced Partitioning

In this section, we describe an extention of the vertex moving partitioning heuristic due to Fiducciai and Mattheyses(FM) [2] for multi-way balanced partitioning.

The FM's algorithm begins with two initial partitions and proceeds in a series of passes. In each pass, it keeps moving vertices between two partitions until each vertex has been moved exactly once.

After each pass, the best solution observed during the pass becomes the initial solution for a new pass. During each pass, the moved vertices are locked from further exchanging. The unmoved vertices are called free vertices. The pass terminates when a pass does not improve upon the most recent solution.

For the convenience, subcircuit, partition and subset are used interchangeablely in the sequel. We first focus on the two-level, multiway balanced partitioning. Then we extend it to tree partitioning.

### 4.2. Computation of Gain and Potential Gain

Unless otherwise specified, we assume that a vertex $c$ is moved from subset $A$ to subset $B, A$ and $B$ are two subsets mong $k$ subsets and $c \in A$. We further define incident number of a net $e$ with respect to a set of vertices $A$ denoted by $\alpha_{A}(e)$ as:

$$
\begin{equation*}
\alpha_{A}(e)=\mid\{c \mid c \in A \text { and } c \in e\} \mid \tag{9}
\end{equation*}
$$

A binding force of a net with respect to the set $A$, denoted by $\beta(e)$, is defined as:

$$
\beta_{A}(e)= \begin{cases}\alpha_{A_{F}}(e) & \text { if } \alpha_{A_{L}}(e)=0  \tag{10}\\ \infty & \text { if } \alpha_{A_{L}}(e)>0\end{cases}
$$

where $A_{F}$ and $A_{L}$ denote the subsets that contain all the free vertices and locked vertices in $A$, respectively.

In order to efficiently calculate the $\operatorname{span}\left(e_{j}\right)$ of a net $e_{j}$, we divide the move operation of $c$ into two steps:

1. Vertex $c$ is selected from $A$ and put into $\bar{A}$ ( $\bar{A}$ is complement of $A, \bar{A}=V-A)$. The corresponding net cut gain, denoted by $G_{g e t}^{A}(c)$, can be written as:

$$
\begin{align*}
G_{g e t}^{A}(c)= & \mid\left\{e \in E_{c} \mid \beta_{A}(e)=1 \text { and } \beta_{\bar{A}}(e)>0\right\} \\
& -\left\{e \in E_{c} \mid \beta_{A}(e)>0 \text { and } \beta_{\bar{A}}(e)=0\right\} \tag{11}
\end{align*}
$$

where $E_{c}$ denotes the set of nets incident on vertex $c$.
2. Vertex is moved from $\bar{B}$ to $B$. Let $G_{p u t}^{B}(c)$ denote the gain of this step. Then

$$
\begin{align*}
G_{p u t}^{B}(c)= & \mid\left\{e \in E_{c} \mid \beta_{\bar{B}}(e)=1 \text { and } \beta_{B}(e)>0\right\} \\
& -\left\{e \in E_{c} \mid \beta_{\bar{B}}(e)>0 \text { and } \beta_{B}(e)=0\right\} \tag{12}
\end{align*}
$$

The total gain of the move operation of $c$ from $A$ to $B$ is given by

$$
\begin{equation*}
G_{\text {span }}(c)=G_{g e t}^{A}(c)+G_{p u t}^{B}(c) \tag{13}
\end{equation*}
$$

$G_{\text {span }}(c)$ acutally is the total decrease in spans due to the move operation of the $c$.

To ensure that constraint (7) is always satisfied after a moving operation for both subset $A$ and $B$, we need to check the following constraint at each moving step:

$$
\begin{array}{r}
\frac{|E|-|S|-G_{c u t}(c)}{k}-\tau \leq|\mathrm{I}(A)|-\left|I_{A}(c)\right| \\
\quad \leq \frac{|E|-|S|-G_{c u t}(c)}{k}+\tau \text { for set } \mathrm{A} \\
\frac{|E|-|S|-G_{c u t}(c)}{k}-\tau \leq|\mathrm{I}(B)|+\left|S_{B}(c)\right| \\
\quad \leq \frac{|E|-|S|-G_{c u t}(c)}{k}+\tau \text { for set } \mathrm{B} \tag{15}
\end{array}
$$

where $I_{A}(c)$ is the set of all the internal nets of $A$ in $E_{c}$,i.e.,

$$
\begin{equation*}
I_{A}(c)=\left\{e \in E_{c} \mid \beta_{A}(e)>0 \text { and } \beta_{\bar{A}}=0\right\} \tag{16}
\end{equation*}
$$

and $S_{B}(c)$ is the set of all the cut nets in $E_{c}$, and it becomes an internal net of $B$ after the move,i.e,

$$
\begin{equation*}
S_{B}(c)=\left\{e \in E_{c} \mid \beta_{\bar{B}}(e)=1 \text { and } \beta_{B}>0\right\} \tag{17}
\end{equation*}
$$

One way to improve the partitioning quality is to break the tie situation where two vertices have same gain [5]. In our method, we introduce a new penalty function, which is devised for multi-way partitioning, into each vertex gain as the potential gain. Let $G_{P}(e)$ denote the potential gain of net $e$ imposed on its incident vertices. The potential gain also consists of two parts corresponding to the two steps in a move operation:

$$
\begin{equation*}
G_{P}(e)=G_{P g e t}^{A}(e)+G_{P p u t}^{B}(e) \tag{18}
\end{equation*}
$$

where

$$
\begin{gather*}
G_{P g e t}^{A}(e)= \begin{cases}0 & \text { if } \beta_{A}(e)=|e| \text { or } \beta_{A}(e)=0 \\
-P & \text { if } \beta_{A}(e)=\infty \\
-P W(e) \frac{\alpha_{A}(e)}{|e|} & \text { if } 0<\beta_{A}(e)<|e|\end{cases}  \tag{19}\\
G_{P p u t}^{B}(e)= \begin{cases}0 & \text { if } \beta_{B}(e)=|e| \text { or } \beta_{B}(e)=0 \\
P & \text { if } \beta_{B}(e)=\infty \\
P W(e) \frac{\alpha_{B}(e)}{|e|} & \text { if } 0<\beta_{B}(e)<|e|\end{cases} \tag{20}
\end{gather*}
$$

where $W(e)=\frac{|e|}{D_{\max }}$ if $|e|<D_{\max }$ and $W(e)=1$ otherwise and $D_{\max }$ is the prespecified upper bound on the number of nets incident on a vertex, $P$ is a constant. Both $G_{P g e t}^{A}(e)$ and $G_{P p u t}^{B}(e)$ favor vertices incident on the cut nets which likely become internal nets of $B$ after the vertex move operation. Then, the total gain for whole move operation can be expressed as:

$$
\begin{equation*}
G_{A B}(c)=G_{\text {span }}(c)+\sum_{e \in E_{c}}\left(G_{P g e t}^{A}(e)+G_{P p u t}^{B}(e)\right) \tag{21}
\end{equation*}
$$

### 4.3. Relaxation of Balance Constraints

One issue with FM-based algorithms is that moving a vertex is only feasible if the move operation dose not violate the balance constraints involved. However this will confine the solution space especially when the constraint is strict [1]. This problem can be alleviated by temporally relaxing the balance constraints and allowing a sequence of move operations of vertices, called macro-step, to be carried out as long as the balance constraints are restored after the macro-step.

More specifically, Let MG[i] and IN[i] be the maximum gain of all vertices and number of internal nets in subset $i$. Consider a vertex $c_{v}$ to be moved from subset $V_{A}$ to subset $V_{B}$ without considering the balance constraint. We observe that after the move operation, $\operatorname{IN}[A]$ is always reduced, and $\operatorname{IN}[B]$ is always increased. So in case the move operation causes the violations of balance constraints in either $A$ or $B$, or both, the replacement strategy that involves a sequence of vertex move operations can be used to restore the balance. Let $F$ be the set of free vertices. The new balance-relaxed multi-way partitioning algorithm (BRMP) is described in Fig. 2.

### 4.4. Multi-way Tree Partitioning

Two-level partitioning can be extended to tree partitioning by recursively applying the algorithm to each subcircuit obtained from previous partitioning and decomposing each subcircuit into smaller parts until the constraint (8) on the number of the internal nets of subcircuits are satisfied. Such tree partitioning scheme can be viewed as a special two-level, multi-way partitioning where each two-level mutlti-way partitioning is solved by only allowing vertics moved among some of subsets and all the vertices in the other subsets are locked during the entire process of partitioning. So the gain calculations (21) and internal-net constraints (19) and (20) still remain valid for tree partitioning.

## 5. Experimental Results

The proposed balanced multi-level multi-way partitioning algorithm has been implemented in $\mathrm{C}++$ and integrated into our hierarchical symbolic analyzer [6, 8]. Before symbolic analysis, all the BJT and MOS transistors in a circuit are replaced by their corresponding

## BRMP ALGORITHM $(F)$

while $(|F| \neq 0)$ do $/ *$ macro-step $* /$
1 Move a free vertex $c_{v}$ with the highest gain from $V_{A}$ to $V_{B}$ without considering constraint (15) and (14), where MG[A] is the largest among all the subsets.
2 while (constraint (15) is violated) do
move a free vertex $c_{x}$ with the highest gain
out of $V_{B}$ subject to constraints (15) and (14).
while (constraint (14) is violated) do
move a free vertex $c_{x}$ with the hightest gain
from $V_{k}$ into $V_{A}$ subject to constraints (15) and (14),
where $I N[k]$ is the largest among all subsets except $V_{A}$.
Recursively repeat steps (2) and (3) until there are
no violations of balance constraints in all the subsets.
5 Lock all the moved vertices and add them into current macro-step; record the current span size.

Figure 2: Balance-relaxed multi-way partitioning.

(a) $\mu A 741$ Opamp

(b) Three-level, 2way partitioning for $\mu A 741$

Figure 3: $\mu A 741$ Opamp

SPICE small-signal models at their DC operating points computed by SPICE. The results from bipolar Opamp $\mu A 741$, which has 26 transistors and 11 resistors shown in Fig. 3(a) is presented here.

We first perform a two-level multi-way partitioning of $\mu A 741$. The total number of nets for $\mu A 741$ is 23 . For the small-signal AC analysis, the power and ground nets are the reference node in the nodal formulation method. They will not appear in the circuit matrix, and are ignored by partitioning. All the nets corresponding to the circuit inputs and outputs are always cut nets. We select the deviation factor - $\tau$ to be 2. Figures 4(a), 5(a) and 5(b) show, respectively, the results of 2-way, 3-way and 4-way balanced partitionings of $\mu A 741$, where each partitioned subcircuit is marked by an index (I up to IV). Table 1 summarizes the statistics of these partitionings. Columns 1, 2 and 3 list, respectively, the number of subcircuits, the span/number of cut nets, and the number of nets in a balanced subcircuit. Columns 4 to 7 list, respectively, the number of internal nets in each subcircuit and its corresponding DDD size. Column 8 gives the number of DDD vertices in the top-level circuit, $\mid$ top $D \mid$, where the last column describes the total number of DDD vertices, $\mid$ total $D \mid$. We have the following observations:

- The total number of DDD vertices used for representing all the subcircuits decreases from 837 in the balanced 2 -way partitioning to 237 in the balanced 4 -way partitioning. Meanwhile, the number of DDD vertices used for the top-level circuit increases from 20 to 114 . The total number of DDD vertices decreases as $k$ increases from 2 to 4 . However, if we further increase $k$, more nets will be cut and the size of the DDD for the top-level circuit will increase rapidly, and dominate the overall DDD size.
- As we have reported in [6], without partitioning and hierarchical symbolic analysis, the total number of DDD vertices
to represent the $\mu A 741$ is 7431 , where the number of product terms in fully-expanded classical symbolic analysis is 374884. Thus, hierarchical symbolic analysis with automatic balanced partitioning leads to a very compact behavioral model ( 237 vs 7431)! Since the number of multiplications is linear in the DDD size, hierarchical symbolic analysis with automated partitioning speeds up canonical symbolic analysis (without partitioning) by a factor of 31 , where canonical symbolic analysis already speeds up fully-expanded symbolic analysis by several orders of magnitude ( 7431 multiplications vs 374884 product terms)

Table 1: Statistics of 2-level, multi-way partitionings of $\mu A 741$.

| k | \#sp/\#cut | $\frac{E\|-\|S\|}{k}$ | \#internal nets/ $\mid$ D $D$ D |  |  |  | top $D$ | total $D$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | -1 | II | III | IV |  |  |
| 2 | $8 / 4$ | 9 | 91260 | 10/557 | - | - | 20 | 837 |
| 3 | 13/7 | 5 | 5/29 | 6/79 | 5/55 | - | 80 | 241 |
| 4 | 18/18 | 3 | 3/5 | $2 / 5$ | 5/53 | 5/57 | 114 | 237 |

We further perform a 3-level 2-way partitioning of $\mu A 741$ based on the hierarchical tree shown in Fig. 3(b). The third-level partitioning is based on the two-level two-way partitioning shown in Fig. 4(a). The resulting partitioning is shown in Fig. 4(b). Table 2 summarizes

Table 2: Statistics of 3-level,2-way partitioning of $\mu A 741$.

| leaf subcircuits | 11 | 12 | П1 | 112 |
| :---: | :---: | :---: | :---: | :---: |
| $D D D$ | 10 | 36 | 23 | 6 |
| \#internal nets | 3 | 4 | 4 | 3 |
| middle subcircuits |  |  |  |  |
| $D D D$ |  |  |  |  |
| \#internal nets |  |  |  |  |
| span |  |  |  |  |
| \#cut nets |  |  |  |  |
| top-level span | 6 |  |  |  |
| top-level \#cut nets | 4 |  |  |  |
| top-level $\mid D D D$ | 20 |  |  |  |
| total $\mid D D D$ | 117 |  |  |  |
| total ${ }^{\text {a }}$ ( $D D D$ ( w/o) | 7431 |  |  |  |
| SCAPP | \#mul:182, \#add:357 |  |  |  |

the partitioning statistics. Rows 2 and 3 describe the DDD sizes and the numbers of internal nets in the leaf subcircuit $I 1, I 2, I I 1, I I 2$. Rows 4 to 7 list, respectively, the DDD size, the numbers of internal nets, spans and the number of cut nets in the two middle circuits $I$ and $I I$. Note that internal nets in a middle circuit level are the cut nets in the lower level and are invisible to the parent of the current subcircuit. Rows top-level span and top-level \#cut nets are the number of spans and the number of cut nets at the top-level circuit. Rows \#toplevel $|D D D|$ and total $|D D D|$ show the corresponding DDD size for the top-level circuit and the total DDD size. Row total $|D D D|$ ( $w / o$ ) is the DDD size without partitioning. We can see that hierarchical symbolic analysis with automated 3-level 2-way partitioning reduces the number of DDD vertices from 7431 to 117! Since only one multiplication is needed for one vertex, the total number of multiplications is 117. To compare with best-known hierarchical symbolic analyzer-SCAPP [4], row SCAPP lists the best result from SCAPP with automated partitioning, where \#mul and \#add are numbers of multiplications and additions, respectively.

## 6. Conclusions

An efficient algorithm for balanced multi-way multi-level partitioning of very large analog circuits is presented for hierarchical symbolic analysis. It is based on the iterative vertex moving heuristic due


Figure 4: 2-way partitioned $\mu A 741$ Opamp


Figure 5: Multi-way partitioned $\mu A 741$ Opamp
to Fiduccia and Matheyses [2]. The novelties are the introduction of a new formula for potential gain computation in multi-way partitioning and the relaxation of the balance constraints. These ideas have been explored for digital circuit layout partitioning recently and shown to be superior to other related methods [9]. In this paper, we have described an application to analog circuit partitioning for symbolic analysis and shown its advantage over the best analog symbolic analysis program SCAPP.

## References

[1] J. Cong, L. Hagen and A. Kahng, " Net partitioning yield better module partitions", 1992, in Proc. 29th IEEE/ACM Design Automation Conference, pp. 47-52, 1992.
[2] C.M. Fiduccia and R.M. Mattheyses, "A linear time heuristic for improved network partitions", Proc. 19th ACM/IEEE Design Automation Conference, pp.175-181. 1982.
[3] G. Gielen, P. Wambacq and W. Sansen, "Symbolic analysis methods and applications for analog circuits: A tutorial overview", Proc. IEEE, vol. 82, no. 2, pp. 287-304, Feb. 1994.
[4] M. M. Hassoun and P. M. Lin, "A hierarchical network approach to symbolic analysis of large scale networks", IEEE Trans. Circuits and Systems, vol. 42, no. 4, pp. 201-211, April 1995.
[5] B. Krishnamurthy, "An improved min-cut algorithm for partitioning VLSI networks", IEEE Trans. on Computers, vol. C33, no. 5, pp.438446, 1984.
[6] C.-J. Shi and X.-D. Tan, "Symbolic analysis of large analog circuits with determinant decision diagrams", in Proc. IEEE Int. Conf. Computer Aided Design (ICCAD), pp.366-373, 1997.
[7] L. A. Sanchis, "Multiple-way network partitioning", IEEE Trans. on Computers, vol. C38, no. 1, pp.62-81, 1989.
[8] X.-D. Tan and C.-J. Shi, "Hierarchical symbolic analysis of large analog circuits with determinant decision diagrams", in Proc. IEEE Int. Symp. Circuits and Systems, CA, May 1998.
[9] X.-D. Tan, J. Tong, P. Tang and F. Lombardi, "An efficient multi-way algorithm for balanced partitioning of VLSI circuits", IEEE Int. Conf. Computer Design (ICCD'97), pp.608-613, 1997.


[^0]:    *This work was sponsored by U.S. Defense Advanced Research Projects Agency (DARPA) under grant number F33615-96-1-5601 from the United States Air Force, Wright Laboratory, Manufacturing Technology Directorate, by Rockwell Semiconductor Systems, and by NSF/Industry Center for Design of Analog-Digital Integrated Circuits (CDADIC).

