Abstract-Efficient algorithms are presented to generate approximate expressions for transfer functions and characteristics of large linear-analog circuits. The algorithms are based on a compact determinant decision diagram (DDD) representation of exact transfer functions and characteristics. Several theoretical properties of DDDs are characterized, and three algorithms, namely, based on dynamic programming, based on consecutive -shortest path (SP), and based on incremental -SP, are presented in this paper. We show theoretically that all three algorithms have time complexity linearly proportional to , the number of vertices of a DDD, and that the incremental -SP-based algorithm is fastest and the most flexible one. Experimental results confirm that the proposed algorithms are the most efficient ones reported so far, and are capable of generating thousands of dominant terms for typical analog blocks in CPU seconds on a modern computer workstation.
I. INTRODUCTION
A S MORE custom very large scale integrated (VLSI) circuit designs become system-on-a-chip (SoC) designs, efficient implementations of analog/radio frequency (RF) building blocks in SoC systems become increasingly important. But design automation techniques for analog circuits are significantly lagging behind their counterparts for digital circuits. One of the challenging problems in analog design is that analog circuits typically have many characteristics, and they depend in a very complicated way on circuit, layout process, and environment parameters.
In this paper, we consider the problem of generating simple yet accurate symbolic representation of circuit-transfer function and characteristics in terms of circuit parameters for linear(ized) analog integrated circuits. It is well known that circuit-transfer function and characteristics are dominated by a small number of product terms called significant or dominant. For instance, Fig. 1 shows a CMOS two-stage opamp circuit. The simplified MOS small-signal model is shown in Fig. 2 . If we ignore , , and (as they are typically small compared to other parameters) in the MOS model and treat the as an ideal current source and as a resistor, the exact transfer function from input to ( is shunted to ground), as shown in the Appendix, contains 16 product terms in the numerator and 60 terms in the denominator. We can see that each coefficient expression of is dominated by a few product terms. For example, for the coefficient of in the denominator, the first product term amounts to 86% of the total magnitude of the coefficient and the first two terms amount to 97% of the total magnitude. If these errors are acceptable, the remaining terms can be neglected. With 5% error, the transfer function can be simplified as shown in (1) . (See equation (1) at bottom of the next page)
Notice that the symbolic approximations are typically carried out around some nominal numerical values (points) of the devices involved, the generated model will approximate actual devices well when the sized device parameters are close to the nominal values used for model generation. However, when using a staged-optimization approach, the nominal points will move and the model will be updated adaptively. As a result, the optimized devices will be very close to the nominal points of the model generated in the final stage (as the model is recentered after every stage). Such nominal point-approximation 0278-0070/04$20.00 © 2004 IEEE strategy used in this work is also adopted by most symbolic approximation methods [1] - [7] . During the approximation, we monitor both magnitudes and phases of the transfer functions until errors are within the user-specified error bounds for the frequency range.
As illustrated in [9] , simple yet accurate symbolic expressions can be interpretable by analog designers to gain insight into the circuit behavior, performance and stability, and are important for many applications in circuit design such as transistor sizing and optimization, topology selection, sensitivity analysis, behavioral modeling, fault simulation, testability analysis, and yield enhancement [10] . Efficient symbolic techniques for linear(ized) analog-circuit analysis are the basis of distortion analysis of weakly nonlinear circuits [11] , [12] , symbolic modeling of time-varying systems such as mixers [13] .
Previous attempts to generate interpretable expressions use various symbolic analysis methods to generate sum-of-product representations for network functions. This area has been studied extensively in the 1960s-1980s [14] . The resulting approaches, however, are only feasible for very small circuits, since the number of expanded product terms grows exponentially with the size of a circuit, and the resulting expressions are no longer interpretable by analog designers. Recently, various approximation schemes have been developed. Approximation after generation is reliable but it requires the expansion of product terms first [6] , [9] , [15] . Some improvements based on nested expressions have been proposed [16] , [17] , but they generally suffer symbolic term-cancellation and align-term problems. Approximation during generation extracts only significant product terms [2] , [5] , [7] . It is very fast, but has two major deficiencies. First, if accurate expressions are needed, the complexity of the approach becomes exponential. Second, it works only for transfer functions. Other small-signal characteristics such as sensitivities, symbolic poles, and zeros, cannot be extracted in general. At the same time, several approximations before generation techniques [7] , [18] were proposed in which the complexity of a circuit is simplified before symbolic analysis methods are applied. Recently, a signal-flow graph-based approximation before generation method was proposed [19] and demonstrated successfully to symbolic pole and zero generation. Symbolic analysis based on the concept of signal paths in control theory was employed for pole-and zero-location analysis [3] , [20] .
In this paper, we present efficient algorithms of generating dominant terms for deriving interpretable symbolic expressions based on a compact determinant decision diagram (DDD) representation of circuit-transfer functions [21] , [22] . We show that dominant-term generation can be performed elegantly by DDD graph manipulations. Since we start with exact symbolic expressions in DDD representations, our new approximation methods feature both the reliability in the approximation-after-generation methods and the capability in approximation-before/after-generation for analyzing large analog circuits. Experimental results show that our algorithms outperform the best dominant-term generation method reported so far [4] , [23] .
Some preliminary results of this paper were presented in [24] and [25] . This paper is organized as follows. Section II reviews the concepts of DDDs and -expanded DDDs. Section III presents a dynamic programming (DP)-based term-generation algorithm based on the work of [4] and [23] . Section IV describes the consecutive -SP generation algorithm. Section V presents the most efficient algorithms based on incremental -SPs. Experimental results are presented in Section VI. Section VII concludes the paper.
II. DDDS AND -EXPANDED COEFFICIENT DDDS
In this section, we provide a brief overview of the notion of DDDs [21] . We review how a multiple-root DDD can be used to represent the symbolic coefficients of an polynomial [22] .
DDDs [21] are compact and canonical graph-based representation of determinants. The concept is best illustrated using a simple RC filter circuit shown in Fig. 3 . Its system equations can be written as
We view each entry in the circuit matrix as one distinct symbol, and rewrite its system determinant in the left-hand side of Fig. 4 . Then its DDD representation is shown in the right-hand side.
(1)
A DDD is a signed, rooted, ordered, and directed acyclic graph with two terminal vertices, namely the 0-terminal vertex and the 1-terminal vertex. Each nonterminal DDD vertex is labeled by a symbol in the determinant denoted by ( to in Fig. 4 , where and represent, respectively, the symbolic expressions of the vertices pointed by the 1-edge and 0-edge of . The 1-terminal vertex represents expression 1, whereas the 0-terminal vertex represents expression 0. For example, vertex in Fig. 4 represents expression , and vertex represents expression , and vertex represents expression . We also say that a DDD vertex represents an expression defined by the DDD subgraph rooted at .
A 1-path in a DDD corresponds a product term in the original DDD, which is defined as a path from the root vertex ( in our example) to the 1-terminal 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: , , and . The root vertex represents the sum of these product terms. Size of a DDD is the number of DDD vertices, denoted by . DDD graph is also an ordered graph like binary decision diagrams (BDDs). This implies that the order of each symbol in any 1-path from (root vertex to 1-terminal) is fixed with respect to other symbols. The ordering used in our example is . Notice that the size of a DDD depends on the size of a circuit in a complicated way. Both circuit topology and vertex ordering have huge impacts on the DDD sizes. Given the best vertex ordering, if the underlying circuit is a ladder circuit, is a linear function of the sizes of the circuit. For general circuits, the size of a DDD graph may grow exponentially in the worse case. However, like BDDs, with proper vertex ordering, the DDD representations are very compact for many real circuits [21] , [22] .
Given a symbolic matrix where each entry is a distinct symbol, and a fixed order of each label appears in the DDD starting from its root. Then the expansion of matrix can be carried out with respect to a nonzero element:
A DDD vertex pointed by 0-edge, which comes from vertex , represents a determinant obtained by setting and is denoted as . The corresponding portion of the DDD graph for one-step determinant expansion of (2) is shown in Fig. 5 .
It can be seen that the multiplication operation is represented by a 1-edge and the addition operation is represented by a 0-edge. The sign of each vertex is the sign used when the vertex is used to develop the determinant. If a DDD is constructed by using Laplace development, all the DDD vertices linked by 0-edges will have the same row index or column index. If the vertex ordering that we use to develop a determinant is fixed, there exists a unique DDD representation of the determinant for that vertex ordering. This is the DDD canonical property. To exploit the DDD to derive circuit characteristics, we need to directly represent circuit parameters not matrix entries. To this end, -expanded DDDs are introduced [22] . Consider again the circuit in Fig. 3 and its system determinant. Let us introduce a unique symbol for each circuit parameter in its admittance form. Specifically, we introduce , , , , , , and . Then, the circuit matrix can be rewritten as
The original three product terms will be expanded to 23 product terms in different powers of . We can represent these product terms nicely using a slight extension of the original DDD, as shown in Fig. 6 . This DDD has exactly the same properties as the original DDD except that there are four roots representing coefficients of -. Each DDD root represents a symbolic expression of a coefficient in the corresponding polynomial. Each such DDD is called a coefficient DDD, and the resulting DDD is a multiple-root DDD. The original DDD in which is contained in some vertices is called complex DDD. The -expanded DDD can be constructed from the complex DDD in linear time in the size of the original complex DDD [22] , [26] .
Before we generate the dominant terms, one problem we need to consider is symbolic cancellation. Symbolic canceling terms arise from the use of the MNA formulation in analog circuits. For instance, consider the -expanded DDD in Fig. 6 . Since and , term cancels term in the coefficient of . Our experiments show that 70%-90% of the terms are canceling terms. Clearly it is inefficient to generate the 70%-90% of the terms that will not show up in the final expressions.
For this example, the resulting cancellation-free DDD is shown in Fig. 7 .
III. DP-BASED GENERATIONOF DOMINANT TERMS
In this section, we present a DP-based algorithm for generating dominant terms using DDDs. The original idea of using DP was proposed by Verhaegen and Gielen [4] , [23] , but was implemented based on noncanonical DDD graphs with node duplication. Our implementation is based on canonical DDD graphs without dynamic removal of canceling terms and, therefore, is faster than the one in [4] and [23] . To derive the DP algorithm, we characterize here some theoretical properties of DDDs. First, we note that the vertex ordering heuristic used to construct DDDs is based on Laplace expansion of a circuit matrix along the row or column [21] . We also know from the canonical property of DDD that the structure of a DDD is unique under a fixed-vertex order, i.e., independent of how it is constructed. We thus have the following lemma.
Lemma 1: All 0-edge-linked vertices come from either the same row or the same column of the original circuit matrix.
Proof: We know that a complex DDD is constructed by using Laplace development. To ease our proof, we repeat the determinant expansion rule (2) in the following:
In a DDD graph, the addition relationship between cofactor and remainder is represented by a 0-edge between two DDD vertices representing the two expressions as shown in Fig. 5 . Since all the are selected from a row or a column by the Laplace development rule, so all the 0-edge linked DDD vertices will have the same row index or column index. Further, the row or column must exist in the remainder . With Lemma 1 as the basis, we can show the following main result.
Theorem 1: The incoming edges of a nonterminal vertex in a complex DDD or native -expanded DDD are either all 0-edges or all 1-edges.
Proof: Suppose there exists a DDD vertex that has an incoming 0-edge from DDD vertex , and an incoming 1-edge from vertex as shown in Fig. 8(a) . The DDD subgraph rooted at , therefore, represents a remainder by the development of . According to the determinant development rule (2), the 0-edge between and means that both the row and column of exist in the remainder represented by (actually, and are in the same row or column according to Lemma 1) . Also, the element of in the remainder will become zero as shown in Fig. 8(b) .
On the other hand, and are not in the same row and column as is obtained by Laplace development, with respect to . Since element is zero, will appear before with a 0-edge in the path (or there could be a number of elements in between linked with 0-edges; as they must come from the same row or column). Let the first non 0-edge linked vertex to be ( can be ). The fact that is 1-edge-linked implies the minor after Z is developed will not have the row and column of . As a result, would have been crossed out since it is in the same row or column as . This contrasts with the fact that appears in the remainder .
This lemma also holds for native -expanded DDDs by noticing that 0-edges between DDD vertices may also represent the relationship among the different symbolic circuit parameters in a nonzero element in a determinant. Native here means that the -expanded DDDs are obtained from complex DDDs without any structure modification. Now we are ready to describe a DDD-based DP algorithm for generating dominant terms. From Lemma 1 and Theorem 1, we know that we only need to calculate dominant terms for 1-edge pointed DDD vertices. Let be a 1-edge pointed vertex. We use to keep track of the number of dominant terms generated for the vertex ( is included in the terms). We use an ordered array, denoted as , to keep track of those generated dominant terms in the minor represented by , where represents the largest term (first dominant term), the second largest term (second dominant term).
is initially set to 1 for all 1-edge pointed vertices, and can be increased up to .
As shown in the pseudocode in Fig. 9 , to find the dominant terms at a 1-edge pointed vertex , we first check if such terms already exist in the term-list in GETKDOMITERMS . If they do not exist, they will be generated by invoking COMPUTEKDOMINANTTERM . In COMPUTEKDOMINANTTERM , the largest term is computed and stored in the term-list of by visiting all the 0-edge linked DDD vertices. Each time a dominant term is computed, the corresponding vertex will be increased by 1. UPDATETERM() adds a vertex (its symbol) into a term represented by a DDD tree. COMPUTETERMVALUE() computes the numerical value of a given term. We use to represent the vertex pointed to by the 1-edge originating from vertex .
Let be the number of vertices in a path from 1-terminal to the root vertex, i.e., the depth of the DDD graph. Let each circuit node be connected by, at most, devices. Then, each matrix entry can be a sum of, at most, individual elements. The algorithm takes linear time in terms of the size of a DDD, if UPDATETERM() and COMPUTETERMVALUE() are implemented to use constant time each time when a vertex is added to a term. This can be accomplished by using memory caching. After obtaining the first dominant term, the next dominant can be found in time assuming the UPDATETERM() and COMPUTETERMVALUE() take constant time and the number of 0-edge linked vertices is bounded by and (due to line 04 in Fig. 9 ). However, depends on the circuit topologies and may become comparable to for some strongly connected circuit structures and the time complexity of the DP algorithm will become in this case. We note that cancellation-free -expanded DDDs do not satisfy Theorem 1. For example, Fig. 7 shows the cancellation-free -expanded DDD of the -expanded DDD in Fig. 6 , vertex in the coefficient of has both incoming 1-edge and incoming 0-edge. Verhaegen and Gielen [4] , [23] resolved this problem by duplicating vertex . Their approach, however, would destroy the DDD canonical property, a property that enables many efficient DDD-based graph manipulations. In this paper, we apply the proposed DP-based term-generation approach on the -expanded DDDs before decancellation.
IV. CONSECUTIVE K-SHORTEST PATH (SP) ALGORITHM FOR GENERATION OF DOMINANT TERMS
We proposed an efficient algorithm for finding dominant terms in [27] . The algorithm does not require DDDs to be native or to satisfy aforementioned graph theoretical property (Theorem 1), and thus can be applicable to any DDD graph. To differentiate this algorithm from the one presented in Section V, we refer to this algorithm as consecutive -SP algorithm.
The SP algorithm is based on the observation that the most significant term in coefficient DDDs can be transformed into the shortest path in edge-weighted DDD graphs by introducing the following edge weight in a DDD:
• 0-edge costs 0.
• 1-edge costs , and denotes the numerical value of the DDD vertex that originates the corresponding 1-edge. The weight of a path in a coefficient DDD is defined to be the total weights of the edges along the path from the root to the 1-terminal. As a result, given a path, say , their path weight is (3) If is the value of the largest term, value of will be the smallest, which actually is (3). The shortest (weighted) path in a coefficient DDD, which is a direct acyclic graph (DAG), can be found by depth-first search in time , where is the number of DDD vertices and is number of edges [28] . So, it is in DDDs. Once we find the shortest path from a DDD, we can subtract it from the DDD using SUBTRACT() operation [21] , and then we can find the next shortest path in the resulting DDD.
DDD function SUBTRACT() is the key operation in our SP algorithm. The pseudocode of SUBTRACT() operation is shown in Fig. 10 .
Function GETVERTEX is to generate a vertex for a symbol and two subgraphs (pointed by 1-edge) and (pointed by 0-edge) [21] . Let be the number of vertices in a path from 1-terminal to the root vertex, i.e., the depth of the DDD graph, given the fact that is a DDD graph and is a path in the DDD form, then we have the following theorem.
Theorem 2: The number of new DDD vertices created in function SUBTRACT
is bounded by and the time complexity of the function is . Proof: As we know that DDD graph contains path . As is a single-path DDD graph, is always 0-terminal. So lines 5 and SUBTRACT in line 6 will immediately return and , respectively (actually, line 5 will never be reached if contains path ). As a result, we will descend one level down in graph each time, depending on which line we choose to go for lines 4 and 6. In fact, function SUBTRACT actually will traverse the embedded path in until it hits a common subgraph in both and as indicated in line 3. After this, new vertices will be created on its way back to the new root vertex, is the number of vertices visited in in the whole operation and
. If the common subgraph is 1-terminal, then . We then have following results. Theorem 3: The time complexity of the SP algorithm for finding k shortest paths is (4) where is the depth of the DDD graph.
Proof: According to Theorem 2, the number of new DDD vertices created in SUBTRACT() operation is bounded by and the time complexity of the function is . Therefore, we can find the shortest paths in time , which actually is (4).
V. INCREMENTAL -SP ALGORITHM FOR GENERATION OF DOMINANT TERMS
In this section, we introduce a more efficient term-generation algorithm based on our previous work in [27] . The new algorithm is still based on the shortest path concept. However, unlike the consecutive -SP method, the new algorithm does not need to visit every vertex in a DDD graph to find the dominant term as required by the shortest path search algorithm [28] after every vertex has been visited once (i.e., after the first dominant term is found). The new algorithm is based on the observation that not all the vertices are needed to be visited, after the DDD graph is modified due to the subtraction of a dominant term from the graph. We show that only the newly added DDD vertices are needed to be relaxed and the number of newly added DDD vertices is bounded by the depth of a DDD graph.
In the sequel, we first introduce the concept of reverse DDD graphs. As shown in Fig. 4 , a DDD graph is a direct graph with two terminal vertices and one root vertex. Remember that the 1-path in a DDD graph is defined from the root vertex to the 1-terminal. Now, we define a new type of DDD graphs, called reverse DDD graphs, where all the edges have their directions reversed and the root of the new graph are 1-terminal and 0-terminal vertices and new terminal vertex becomes the root vertex of the original DDD graph. The reverse DDD graph for the DDD graph in Fig. 4 is shown in Fig. 11 . For the clarification, the root vertex and terminal vertices are still referred to as those in the original DDD graphs. With the concept of the reverse DDD graph, we further define 1-path and path weight in a reverse DDD graph.
Definition 1: A 1-path in a reverse DDD is defined as a path from the 1-terminal to root vertex ( in our example) including all symbolic symbols and signs of the vertices that the 1-edges point to along the 1-path.
Definition 2: The weight of a path in a DDD is defined to be the total weights of the edges along the path where each 0-edge costs 0 and each 1-edge costs , and denotes the numerical value of the DDD vertex that the corresponding 1-edge points to.
We then have the following result.
Lemma 2:
The most significant product (dominant) term in a symbolic determinant corresponds to the minimum cost (shortest) path in the corresponding reverse DDD between the 1-terminal and the root vertex.
The shortest path in a reverse -expanded DDD, which is still a DAG and, thus, can be found in time as the normal DDD graph does.
Following the same strategy in [27] , after we find the shortest path from a DDD, we can subtract it from the DDD using SUBTRACT() DDD operation, and then we can find the next shortest path in the resulting DDD. We have the following result:
Lemma 3: In a reverse DDD graph, after all the vertices have been visited (after finding the first shortest path), the next shortest path can be found by only visiting newly added vertices created by the subtraction operation.
Proof: The proof of Lemma 3 lies in the canonical nature of DDD graphs. A new DDD vertex is generated if and only if the subgraph rooted at the new vertex is a new and unique subgraph for the existing DDD graph. In other words, there do not exist two identical subgraphs in a DDD graph due to the canonical nature of DDD graphs. On the other hand, if an existing DDD vertex becomes part of the new DDD graph, its corresponding subgraphs will remain the same. As a result, the shortest path from 1-terminal to all vertices in the subgraph will remain the same. Hence, it is sufficient to visit the newly added vertices to find the shortest paths from 1-terminal to those vertices. The root vertex of the new DDD graph is one of those newly added vertices. Fig. 12 illustrates the incremental -SP algorithm. The figure in the left-hand side shows consecutive -SP algorithm to find the shortest path. Every time when a new DDD graph is created which is rooted at , we have to visit the whole graph to find the shortest path. The figure shown in the right-hand side is the new incremental -SP algorithm, where we only need to visit all the newly created DDD nodes (in the upper left triangle) to be able to find the shortest path. As shortest paths are found from the source to all the nodes in a graph, the shortest paths, shown in dashed lines, in the existing subgraphs can be reused in the new DDD graph.
It turns out that finding the shortest path from 1-terminal to the new vertices can be done very efficiently when those new vertices get created. The shortest path searching can virtually take no time during the subtraction operation. Suppose that every vertex in reverse DDD graph has a shortest path from 1-terminal to it (be visited once). Then the new algorithm for searching the next dominant term is given in Fig. 13 .
In GETNEXTSHORTESTPATH , EXTRACTPATH obtains the found shortest path from and returns the path in a single DDD graph form. This is done by simply traversing from the root vertex to 1-terminal. Each vertex will remember its immediate parent who is on the shortest path to the vertex in a fully relaxed graph (relaxation concept will be explained soon). Once the shortest path is found, we subtract it from the existing DDD graph and relax the newly created DDD vertices (line [15] [16] [17] at same time to find the shortest paths from 1-terminal to those vertices, which is performed in the modified function SUBTRACT , now called SUBTRACTANDRELAX . In function SUBTRACTANDRELAX , RELAX performs the relaxation operation, an operation that checks if a path from a vertex's parent is the shortest path seen so far and remember the parent if it is, for vertices and , where is the immediate parent of in the reverse DDD graph. The relaxation operation is shown in Fig. 14. Here, is the shortest path value to see so far for vertex ;
is the weight of the edge from to , which actually is the circuit parameter value that represents in the reverse DDD graph. Line remembers the parent of in the shortest path from the 1-terminal to . In the reverse DDD graph, each vertex has only two incoming edges (from its two children in the normal DDD graph), so the relaxation with its two parents in lines 16 and 17 are sufficient for the relaxation of vertex . Moreover, the relaxation for happens after all its parents have been relaxed due to the DFS-type traversal in SUBTRACTANDRELAX(). This is consistent with the ordering requirement of the shortest path search algorithm. Therefore by repeatedly invoking function GETNEXTSHORTESTPATH , we can find all the dominant terms in a decreasing order. We have following result for incremental -SP-based algorithm.
Theorem 4: The time complexity of the incremental -SP algorithm for finding -SPs is (5) where is the depth of the DDD graph.
Proof: The RELAX() operation shown in Fig. 14 takes constant time to finish. As a result, the time complexity of the operation SUBTRACTANDRELAX() will still be according to Theorem 2. After finding the first shortest path, which takes to finish, the algorithm will take to find each shortest path. Therefore, it takes to find the rest of shortest paths and the total time complexity of finding the -SPs becomes . Notice that both the DP-based algorithm and the incremental -SP-based algorithm have time complexity to find a dominant term, where is the size of a DDD graph. After the first dominant term, however, both algorithms show better time complexities for generating next dominant terms, that is . However, in contrast to the DP-based algorithm, the actual running time of the incremental -SP-based algorithm does not depend on the topology of a circuit. Notice that the new incremental -SP generation algorithm can be performed on any DDD graph, including cancellation-free -expanded . We note that the variant of DDD used by Verhaegen and Gielen in [4] , [23] does not satisfy the canonical property due to vertex duplication. As a result, except for the first shortest path, remaining dominant paths cannot easily be generated by using the shortest path algorithm as the found shortest path is hard to be subtracted (if possible at all) as most DDD graph operations are not valid for a noncanonical DDD graph.
Following the same strategy in [5] , our approach also handles numerical cancellation. Since numerical canceling terms are extracted one after another, they can be eliminated by examining two consecutive terms.
VI. EXPERIMENTAL RESULTS
The proposed three algorithms have been implemented and tested on a number of practical analog circuits. For each circuit, dc analysis is first carried out using SPICE and our program reads in small-signal element values from the SPICE output. The algorithms described in [21] and [22] are used to construct complex DDDs and -expanded DDDs.
First, we apply the proposed dominant-term generation algorithms to derive interpretable symbolic expressions for transfer functions and poles from simple two-stage CMOS Opamp circuit shown in Fig. 1 . The exact transfer function generated by our program is shown in the Appendix. In the approximation process, we monitor both the magnitude and phase of the simplified expressions to control the accumulated error within a given frequency range. Before we generate dominant terms, we first simplify DDD graphs by device removal and node contraction on the complex DDD representation [24] , [27] , which will remove many insignificant terms and result in smaller complex DDDs.
For TwoStage, the simplified gain for TwoStage given by our program is shown in (1). Table I shows the exact values of three zeros and three poles.
Since three poles are far away from each other, the pole-splitting method can be used to find their symbolic expressions. For instance, the resulting expression of the first pole based on DDD manipulations is as follows:
This agrees with the exact first pole described in Table I .
We then compare three dominant-term generation algorithms-the consecutive -SP-based algorithm, dynamic programming-based algorithm as well as the incremental -SP-based algorithm. Table II summarizes the comparison results in terms of CPU time and memory usage for the three algorithms. A total of 10 000 dominant terms are generated for a number of test circuits ranging from more regularly structured ladder circuits to less regularly structured such as Cascode and amplifiers. In Table II , columns 1-3 list for each circuit, respectively, its name Circuit, the number of nodes #nodes, and the number of nonzero elements #nonzero in its circuit MNA matrix. Columns 4-7 show, respectively, the CPU time and memory usage, for generating 10 000 dominant terms by the DP-based algorithm and by the consecutive -SP-based algorithm, respectively. The last column gives the CPU time of the incremental -SP-based algorithm. The memory usage for the incremental -SP-based algorithm is the same as consecutive -SP-based algorithm for each circuit. From Table II , we see that the incremental -SP-based algorithm consistently outperforms the DP-based algorithm for all the circuits in both CPU time and memory usage. The difference becomes even more significant for circuits with regular structures like ladder circuits. Notice that for ladder circuits, . So is satisfied for large ladder circuits and the DP-based algorithm is linear also after the first dominant term is found. For less regularly structured circuits like , the incremental -SP-based method also shows impressive improvements over the DP-based algorithm.
As we know that for both DP-based algorithm and incremental -SP-based algorithm, the actual time to generate a new path is close to , where is the size of the circuit or the depth of DDD graphs. But for the consecutive -SP-based algorithm, we have to visit all the vertices every time to generate a new path. Such difference is clearly demonstrated for circuits Cascode and , where the sizes of DDDs are significantly larger than the sizes of the circuits. So the CPU time for the consecutive -SP-based algorithm is longer than that of two other algorithms.
Note that the CPU time of generating dominant terms by the shortest path depends on the sizes of -expanded DDDs. As a result, ladder circuits should have shown a much better performance than less structured circuits like opamp circuits as DDD representations for ladder circuit are optimal. However, as more terms are subtracted from the -expanded DDDs, the sizes of resulting -expanded DDDs will increase as a certain amount of sharing is destroyed. (According to Theorem 2, maximum nodes may be added to the resulting DDD graphs after one SUBTRACTANDRELAX() operation, is the size of the circuit or #nodes). Such an increase of DDD sizes will become significant for ladder circuits as ladder circuits have the maximum sharing (optimal representations) at the beginning. Therefore, the CPU time for some large ladder circuits is comparable to that of some small opamp circuits. But for the incremental -SP algorithm, after the first dominant term, the CPU time for generating a new dominant term is . So the CPU time is asymptotically proportional to the #nodes as shown in the Table II . Fig. 15 shows the CPU time for different ladder circuits. The CPU time increases almost linearly with the size of a ladder circuit for all three algorithms. Both the SP-based algorithms consistently outperforms DP-based algorithm in terms of CPU time. The reason is that sizes of DDDs for representing ladder circuits grow linearly with the sizes of the ladder circuits, that is [21] , so the time complexities of all three algorithms, , become . But the DP-based algorithm need to take extra efforts to loop through all 0-linked vertices to compute the dominant terms and restore them at each 1-edged pointed vertex. Those extra efforts will become significantly when the graph become very deep as with the higher order ladder circuits. Fig. 16 shows the memory usage for different ladder circuits. The memory usage of DP-based method increases linearly with the sizes of ladder circuits, while the consecutive -SP and incremental -SP algorithms take much smaller amount of memory for the same set of ladder circuits. The DP-based method will use more memory when more terms are generated as more memory will be used for caching the generated terms at each 1-edge pointed DDD vertex.
VII. CONCLUSION
Efficient algorithms were proposed to generate dominant terms for ac characteristics of large linear analog circuits. The new algorithms are based on a DDD graph-based compact and canonical representation of symbolic expressions. We formulate the dominant-term generation problem as the one of searching for the shortest paths in DDD graphs. Theoretically, we showed that DP-based dominant-term generation method is restricted to certain DDD graphs. Practically, we proposed an incremental -SP search algorithm, which can be applied to any DDD graphs, based on the canonical property of DDD graphs. Experimental results indicate that the proposed incremental -SP algorithm outperform the best known algorithm based on the DP [4] , [23] in terms of CPU time and memory usage. Fig. 1 The numerical value at the end of each line is the magnitude of the coefficient of if the line starts with or the magnitude of the product term in the same line otherwise. All the products in each coefficient are sorted with respect to their numerical magnitudes.
APPENDIX

Exact transfer function of two-stage CMOS opamp in
numerator: -----------------------------denominator:
