I. INTRODUCTION
I N ORDER to automatically produce analog device-level layouts matching in density and performance the high-quality manual layouts, a placement tool must not only provide a good rectangle packing functionality (which must be common to any placement method) but, additionally, it must include also analog-specific capabilities. Such specific features are, for instance; 1) the ability to deal with topological constraints for symmetry and device matching; 2) the ability to arrange devices such that critical structures are shared in common (also known as device merging) in order to reduce both layout density and induced parasitics; and 3) the existence of a (built-in) library of predefined module generators and the ability to exploit their reshaping capabilities during the placement process.
Besides these specific features of analog placement, the main goal of optimally packing arbitrarily sized modules is similar to that of other very large scale integrated circuits (VLSI) placement problems-chip floorplanning, standard cell and macro cell digital placement. Due to the complexity of the basic problem, 1 several heuristic classes of placement techniques have been attempted.
Manuscript received August 25, 1999; revised December 9, 1999 . This paper was recommended by Associate Editor M. Sarrafzadeh.
F. Balasa is with the Univ. of Illinois at Chicago, Chicago, IL 60607 USA (e-mail: fbalasa@eecs.uic.edu).
K. Lampaert is with the Conexant Systems Inc., Newport Beach, CA 92660 USA.
Publisher Item Identifier S 0278-0070(00)05853-X.
A. Overview of Analog Placement Methods
The constructive placement techniques, which consist in evolving gradually the placement solution by selecting one module at a time and positioning it in the "best" available location, were among the first developed for VLSI layout. Several systems for analog placement employ constructive methods: Kayal et al. developed an expert knowledge base to guide the placement [8] ; Mehranfar suggested a schematic-driven approach, using a constructive scheme based on connectivity and relative positioning in the input schematic [15] . Although these methods are fast, scaling well with the problem size, the results can be poor due to the order dependence, lacking of global view in dealing with a variety of interacting quality measures.
Branch-and-bound placement techniques use a controlled enumeration of all possible layout configurations in the search space, where a lower bound of the chosen cost function is used to prune the search. The branch-and-bound algorithms eventually find the optimal solution as they explore exhaustively the search space. However, they are effective only for problems of very small size (the manageable number of blocks in [17] is six), as the number of visited configurations grows exponentially with the size of the problem. The related integer linear programming (ILP) placement models [21] suffer the same scaling drawback (see also Section VI), as most ILP packages are based on branch-and-bound approaches. Even if the placement problems are tackled hierarchically, the branch-and-bound methods are less attractive for analog device placement due to usually a much larger search space than digital problems of similar size (for instance, due to the presence of "soft" capacitors which can be implemented in a large number of versions).
More recently, a placement technique iteratively combining min-cut partitioning and force-directed placement (DLP) has been employed in an interactive environment for full-custom designs [13] .
For the time being, the simulated annealing [9] and genetic algorithms [5] are the most effective choice for solving industrial analog placement problems. These algorithms use stochastically controlled hill-climbing to avoid local minima during the optimization process. In addition, they do not impose severe constraints on the size of the problems or on the mathematical properties of the cost function. While efficiently trading off between a variety of layout factors as area, total net length, aspect ratio, maximum chip width and/or height, cell orientation, "soft" cell shape, etc., they are very flexible-supporting incremental addition of new functionality, and they are relatively easy to implement (although good tunning needs more time). This is why simulated annealing, the most mature of the stochastic techniques, provided the engine for effective software packages both in digital (TimberWolfSC v7.0 [20] ) and analog design: ILAC [19] , KOAN/ANAGRAM II [3] , PUPPY-A [12] , and LAYLA [10] .
B. Absolute and Topological Representations
A simulated annealing algorithm can equally operate with two distinct spatial representations of placement configurations. The first is the so-called flat or absolute representation introduced by Jepsen and Gellat [7] , where the cells are specified in terms of absolute coordinates on a gridless plane. The moves are simple coordinate shifts or changes in cell orientation. Cells are allowed to overlap in possibly illegal ways, 2 as no restriction is made referring to the relative position of a cell with respect to another cell. A (weighted) penalty cost term is associated with infeasible overlaps, and this penalty must be driven to zero in the optimization process. The flat representation is wellsuited to handle device matching and symmetry constraints, typical to analog layout; it also allows to explore the beneficial device overlaps. For these reasons, the flat representation was the choice for KOAN/ANAGRAM II [3] , PUPPY-A [12] , and LAYLA [10] systems.
However, this representation has also revealed a drawback, for instance, in [20] . Due to the complexity of the cost function, the total (infeasible) overlap in the final placement solution is not necessarily equal to zero: a final step eliminating the gaps and overlaps must be performed, degrading the computation time and the solution optimality (in terms of the cost function). Moreover, the weight of the overlap term must be carefully chosen: if it is too small, the cells may have the tendency to collapse; if it is too large, the search ability of the annealer for a good placement (in terms of area, total net length, etc.) may be impeded. To combat this effect, an earlier version of the TimberWolf system [20] used a sophisticated negative control scheme to determine the optimum values of the cost term weights.
The flat representation approach trades off a larger number of annealing moves for easier and quicker to build layout configurations-which may not be always physically realizable, though. On the other hand, a second class of placement representations-named topological-allows trading off more complex, physically correct, layout constructions per each annealing move for a smaller number of moves.
In contrast to the flat representation where cell positions are defined in terms of absolute coordinates, in the topological representations cell positions are specified relatively, based on topological relations. The most popular representations are based on the slicing model, first introduced by Otten [18] , assuming the cells are organized in a set of slices which recursively bisect the layout horizontally and vertically. The direction and nesting of the slices is recorded in a slicing tree or, equivalently, in a normalized Polish expression [22] . The annealing algorithm does not move the cells explicitly: it rather alters their relative positions, modifying the slicing tree or Polish expression. In this representation, cells cannot overlap, which may lead to an improved efficiency in the placement optimization.
However, the slicing representation limits the set of reachable layout topologies. This can degrade layout density, especially when cells may be very different in size, which is often the case in analog layout. Furthermore, symmetry and matching constraints are difficult to maintain: for instance, slicing style placement tools have to implement symmetry constraints in the cost function through the use of virtual symmetry axes [11] , which is a less efficient solution. Although the ILAC system [19] employs this model, it is widely acknowledged that slicing placement is not a good choice for high-performance analog design.
More recently, several novel topological representations, not restricted to slicing floorplan topologies, have been proposed. Murata et al. suggested to encode the "left-right" and "up-down" positioning relations between cells using two sequences of cell permutations, named sequence-pair [14] . Nakatake et al.devised a meta-grid structure (called bounded-sliceline grid (BSG) without physical dimensions to define orthogonal relations between modules [16] . Very recently, Guo et al. proposed the ordered tree (O-tree) data structure to reduce the drawback of redundancies in the two previous representations [6] .
The goal of our paper is to show that sequence-pair-the most popular nonslicing topological representation-is adequate for high-performance analog layout, as symmetry and device matching constraints can be easily handled. In this way, the superior efficiency of the topological representations is combined with the completeness of the search space of placement configurations and the ability to handle typical analog constraints. The results obtained so far with our placement tool, already active in an industrial environment, will substantiate the validity of these claims. The analog examples shown in [2] contain only one symmetry group of cells; this paper displays a complex frequency divider with selectable ratio having five symmetry groups. In addition, a complete proof of the theoretical computation of the solution space size is also included. This paper is organized as follows. Section II will briefly describe the sequence-pair representation. Section III will explain the nature of the symmetry constraints in analog design, while Section IV will thoroughly analyze the symmetry handling during simulated annealing, when this optimization operates on sequence-pair representations. Section V briefly reviews the device-matching constraints and Section VI proves the effectiveness of our analog placement solution. Then, Section VII concludes with final remarks, while the Appendix presents a thorough evaluation of the solution space size for placement problems with symmetry constraints.
II. THE SEQUENCE-PAIR REPRESENTATION
The basic idea of the sequence-pair representation, briefly described below for the sake of consistency, is to encode any rectangle packing as an ordered pair of cell sequences . In [14] , a method of deriving such an encoding is informally described. 3 In particular, there exists at least a sequence-pair encoding corresponding to (one of) the optimal rectangle packing. 4 In addition, all the encodings are feasible in the sense that a placement configuration can be derived from any encoding; moreover, the solution is optimal in terms of area and it can be constructed in time, where is the number of placeable cells. As the total number of encodings is finite although large 5 , the solution space can be effectively explored employing simulated annealing or genetic algorithms.
Denoting by the cell occupying the position in sequence , and by the position of the cell in the sequence, 6 the topological relations between two cells and are given by the following: if and then cell is to the left of cell ; (T) if and then cell is above cell . Example: The sequence-pair encoding of the seven-cell placement configuration in Fig. 1 is (see Section IV). With the notations employed, we have, for instance, , and also, , etc. As and ( and ), it follows that cell is positioned above cell . Murata et al. have conceived the sequence-pair representation as a general rectangle packing method [14] . In order to apply this topological representation to analog placement, handling symmetry is an essential requirement. Section IV will show how to handle the symmetry constraints within the sequence-pair topological representation.
III. SYMMETRY CONSTRAINTS IN ANALOG LAYOUT
In high-performance analog circuits, it is often required that groups of devices are placed symmetrically with respect to one or several (vertical) axes. The main reason of symmetric placement and routing is to match the layout-induced parasitics in If the cells can be rotated, or rotated and mirrored, the size is (m!) 4 or (m!) 8 , respectively. 6 and are one-to-one mappings and, therefore, the inverse mappings are well defined. the two halves of a group of devices. Failure to match these parasitics in, for instance, differential analog circuits can lead to higher offset voltages and degraded power-supply rejection ratio [4] .
Placement symmetry can also be used to reduce the circuit sensitivity to thermal gradients. Failure to adequately balance thermal couplings in a differential circuit can even introduce unwanted oscillations. In order to combat potentially induced mismatches, the thermally sensitive device couples should be placed symmetrically relative to the thermally radiating devices. The typical forms of symmetry which should be handled by an analog placement tool are as follows [4] : 1) mirror symmetry-which consists in placing a symmetry group of cells about a common axis such that the cells in every pair have identical geometry and mirror-symmetric orientation; 2) perfect symmetry-which differs from the previous by the identical (rather than mirror-symmetric) orientations of the paired devices. This type of symmetry is sometimes required in order to meet very stringent matching requirements; 3) self-symmetry-characteristic for devices presenting a geometrical symmetry and sharing the same axis with other pairs of symmetric devices. A subset of cells is called a symmetry group if all cells are exhibiting a form of symmetry and, in addition, they all share a common symmetry axis.
Usually, the analog circuits have a mix of symmetric and asymmetric components. Fig. 2 shows the schematic of a highspeed CMOS comparator, circuit used in a CMOS A/D converter. This comparator converts a differential input signal into a single-ended output value. Therefore, the input stage is symmetric while the single-ended output stage introduces an asymmetric part.
IV. HANDLING SYMMETRY CONSTRAINTS WITH THE SEQUENCE-PAIR REPRESENTATION
Assuming that a given subset of the placeable cells must constitute a symmetry group, not all the sequence-pair codes are feasible any more. For instance, suppose the cell couple in the Section II example should be symmetric relative to a vertical axis: the encoding is not feasible as it leads to a placement configuration where cell lays above .
At a first glance, one would be tempted to perform minor changes to the search space exploration: if the current encoding proves to be consistent with the symmetry constraints then the cost of the placement configuration is evaluated and the annealing algorithm operates normally; otherwise, the current encoding is infeasible (in symmetry point of view) and, therefore, disregarded. Unfortunately, such a simple solution is not effective: taking into account that the size of the search space without symmetry constraints is (the total number of sequence-pairs), the size of the solution space becomes significantly smaller if the placement configuration must contain a symmetry group. Indeed, the size of this new search space is given by the formula (see Appendix for a proof) (1) where is the number of symmetric pairs, and is the number of self-symmetric cells in the group.
Formula (1) shows that the size of the search space is if . Therefore, when there are only two pairs of symmetric cells more than 95.83% of the full sequence-pair search space contains symmetric-infeasible solutions. This has been confirmed experimentally when trying to place the cells in Fig. 1 such that the pairs of cells and are, respectively, symmetric relative to a common axis: the CPU time was several times higher and, in addition, the final solution was poor because the number of feasible codes investigated during the simulated annealing was insufficient (most of the codes being rejected).
A better strategy is to explore only those sequence-pairs which comply with the symmetry constraints. This section will show 1) how to recognize such sequence-pairs and 2) how to efficiently restrict the annealer exploration only to their subspace.
Let be the sequence-pair of a placement configuration containing a symmetry group composed of several pairs of (mirrored/perfect) symmetric cells and self-symmetric cells relative to a common vertical axis. 7 We denote by the symmetric of cell , and we consider by convention that when is a self-symmetric cell. shows that any symmetric pair of cells appears in the same order in both sequences and cells in 7 The case of multiple symmetry groups can be similarly approached, as it will be shown further. According to condition of symmetric-feasibility, two cells belonging to distinct symmetric pairs and, respectively, their symmetric cells appear in reversed order in the two sequences of the encoding. In addition, any two self-symmetric cells appear in reversed order in the sequences and , as it can be easily seen taking and in . Example (Continued): Assumming there is a symmetry group composed of two symmetric pairs and two self-symmetric cells and , the encoding (see Fig. 1 ) is not symmetric-feasible: for instance, the symmetric cells and do not satisfy condition as they do not appear in the same order in the sequences and ( , but ). On the other hand, the encoding , derived from the placement configuration in Fig. 3 , is symmetric-feasible. Taking, for instance, the self-symmetric cell and comparing its positions and in the sequences and, respectively, to the corresponding positions of the other cells in the symmetry group, it may be concluded, from the pairs of valid inequalities , that condition is satisfied whenever cell is involved. Similar comparisons involving the positions of the other cells in will conclude the verification. 8 The following two lemmas will prove that, in order to find a cell packing of minimum area, containing a symmetry group of cells, it is sufficient to explore the subspace of symmetric-feasible sequence-pairs, rather than the entire sequence-pair space, which is significantly larger (as mentioned above, e.g., 24 times larger for only two pairs of symmetric cells).
Lemma 1: Any placement configuration containing a symmetry group can be encoded with a symmetric-feasible sequence-pair.
Proof: According to [14] , any placement configuration can be encoded with a sequence-pair. In particular, this is true also for those configurations containing symmetry groups.
The procedure described below is similar to the Gridding encoding in [14] . However, ConstructSequenceAlpha avoids the ambiguity of the Gridding encoding by providing priority to the horizontal relation. In addition, the resulting sequence-pair has the property when the procedure is applied to a placement configuration with a symmetry group. First, it must be noticed that the topological relations specific to the sequence-pair representation (see Section II) are satisfied due to lines (*) and (**). In particular, for a pair of symmetric cells being placed to the left of , the routines ConstructSequenceAlpha and Beta yield, due to line (**), a sequence-pair where and, respectively, . Therefore, cells and satisfy condition . It can be verified by analyzing all the possible relative positions between two pairs of symmetric cells that the encoding generated by the procedures described above satisfies condition . For the sake of clarity, the pairs and in the example from Fig. 3 will be considered. There are two cases of relative positions of the two pairs (less the possible cell interchanges within the same pair, or interchanges between pairs) as follows.
1) The pair lies between cells and , as shown in Fig. 3 . Due to line (**), the procedures ConstructSequenceAlpha and Beta generate a sequence-pair such that and 2) The pair lies below the pair , such that the horizontal projections of cells and and, respectively, and , are overlapping. Due to line (*) in the procedures, and . In addition, due to line (**) and The two inequalities above and their equivalent ones obtained by interchange operations show that any two cells in the subset satisfy condition . The relative positions between two self-symmetric cells, or between one symmetric pair and one self-symmetric cell, may be similarly analyzed: in all cases, condition is satisfied for every two cells in the symmetry group.
Example (Continued): Applying the encoding procedure to the illustrative placement configurations in Fig. 1 and Fig. 3 , the sequence-pairs and, respectively, are obtained. The latter encoding is symmetric-feasible, as already shown.
Lemma 1 shows that there is at least one symmetric-feasible sequence-pair corresponding to a placement configuration with a symmetry group, optimal in terms of a cost function (for instance, area).
Lemma 2: Given a set of placeable cells containing a symmetry group and a symmetric-feasible sequence-pair, then one can build in polynomial time an optimal placement configuration (in terms of area) satisfying the positioning and symmetry constraints.
Proof: Denoting the coordinates of the left-bottom corner of cell of width and height , and given a symmetric-feasible sequence-pair , a construction with the properties stated in Lemma 2 is described below.
First, the coordinates of the cells are computed such that the positioning constraints (compatible with the given sequencepair) are satisfied This part of the algorithm determines in time the coordinates of the cells such that the horizontal positioning constraints resulting from the sequence-pair are satisfied. In the absence of a symmetry group, the computation of the coordinates is over; otherwise (symmetryAxis ), the coordinates must be trimmed in order to satisfy also the conditions of symmetry. This is done in two steps: first, a "sweep to the right" which finds the final positions for the cells to the right of the symmetry axis, including the self-symmetric ones; second, a "sweep to the left" which determines the positions of the cells to the left of the symmetry axis. It must be noticed that the symmetric-feasibility condition is sufficient in order to ensure the correct -positioning after only two sweeps-one to the right and one to the left. If the sequence-pair does not satisfy the condition, it could happen that two pairs of symmetric cells and may prevent each other from being simultaneously symmetric about the axis if, for instance, is pushing to the right when achieving the symmetry of the first pair, and afterwards is pushing to the left achieving the symmetry of but destroying again the symmetry of . Moreover, the complexity of the algorithm is still , the same as in the absence of any symmetry constraint. In order to prove the statement of Lemma 2, it must be shown that the construction described above yields a valid placement configuration (i.e., cells do not overlap), satisfying the positioning constraints specific to the given sequence-pair, and verifying also the conditions of symmetry; in addition, the resulting placement has minimum width and minimum height subject to the topological and symmetry constraints.
During the "computation of coordinates", we have (as ). If, in addition, then cell will be placed to the right of , as : these cells do not overlap. The "sweep to the right" will not alter this situation: when a cell is pushed to the right, all the cells such that and are equally displaced to the right. The "sweep to the left" preserves the left-right relations as well.
During the "computation of coordinates", we have (as ). If, in addition, then cell will be positioned above , as : neither these cells do overlap. As any two cells and appear in the sequences and either in the same order or in reversed order , at least one of the relation types holds. It follows that no overlap occurs in the resulting placement configuration; moreover, the topological constraints derived from the given sequence-pair are satisfied.
Due to lines (*) and (**), together with (***), for any pair of symmetric cells , cell is pushed in order to make it satisfy the symmetry conditions symmetryAxis and . (For self-symmetric cells , the symmetry condition is symmetryAxis .) As explained earlier, when the value of is trimmed in order to satisfy the symmetry constraints, no alteration of the previously trimmed coordinates can occur due to the symmetric-feasibility of the given sequence-pair. It follows that the resulting placement configuration satisfy also the symmetry constraints.
Finally, it must be shown that the resulting placement configuration has minimum width and height, while satisfying the constraints.
Suppose for the time being that there are no symmetry constraints and let us construct the horizontal-and vertical-constraint graphs and as described in [14] . These are two vertex-weighted directed acyclic graphs, having a source and a sink, and nodes labeled with the cell names. In , the arcs represent the left-right relations between cells, while the vertex-weights are the cell widths; in the arcs represent top-down relations between cells, and the vertex-weights are the cell heights (the weights of source and sink being zero). It must be noticed that the first part of the construction algorithm ("computation of coordinates") determines in fact the longest path lengths (denoted ) from source to the nodes in . Similarly, the "computation of coordinates" determines the longest path lengths (denoted ) from source to the vertices in . Due to the absence of symmetry constraints, the "sweep to the right/left" operations are not taking place.
The width and the height of the placement configuration result to be the longest path lengths between source and sink in and, respectively, in . The width and height have independently minimum values (relative to the positioning constraints derived from the sequence-pair): lesser values would imply violations of positioning constraints in and/or . In the presence of a symmetry group, the constraint graphs will be modified in order to encompass the additional symmetry constraints. Let be two nodes corresponding to symmetric cells. Then, for every arc in , an additional arc must be added (unless it already exists), and vice versa. In this way, the longest paths from the source of to and to will have same lengths . At the same time, an extra node of zero weight, corresponding to the symmetry axis, along with the new arcs and for every pair of symmetric cells are added to . The first part of the construction algorithm determines as before the longest path lengths from the source of to every vertex . (symmetryAxis will be the length of the longest path to node .) Afterwards, in topological order, for every cell having a symmetric cell to the left, whenever symmetryAxis symmetryAxis (i.e., in "sweep to the right"), the arc is replaced by an additional node of weight equal to , and the arcs and . The longest path lengths from the source to the descendents of in are also updated in topological order. A similar operation, but in reversed topological order, has to be done for every cell having a symmetric cell to the right, new nodes being added between and in order to compensate the symmetry violations. 9 In the modified graphs and , which model both the topological and symmetry constraints, and still represent the longest path lengths in and from the respective source to node . The width and height of the placement configuration are still the longest path lengths between the 9 If the weights of the "compensation" nodes j ; k are chosen larger with the same amount for any pair of symmetric cells (j; k), the topological and symmetry constraints will still be satisfied: the width of the placement will result larger, though.
source and sink in the two constraint graphs. Due to similar arguments, they have minimum values subject to both types of constraints.
The two lemma's presented above show that, in order to find an optimal cell packing containing a symmetry group, it is not necessary to explore the entire space of sequence-pairs; it suffices to explore the significantly smaller space of symmetricfeasible sequence-pairs.
The annealing algorithm can be easily adapted to explore the space of symmetric-feasible sequence-pairs taking the following caveats.
1) The initial sequence-pair must be symmetric-feasible. Such a sequence-pair is, for instance where are the pairs of symmetric cells and are the self-symmetric cells. 10 The initial sequence-pair can be built in different ways: our tests show that the choice is irrelevant with respect to CPU time and the quality of the final solution.
2) The move-set of the annealer must be selected such that the property of symmetric-feasibility is preserved for all the visited sequence-pairs. The modifications of cell positions or cell interchanges in sequence and/or are valid moves for the cells outside the symmetry group. However, if two cells from distinct symmetric couples are interchanged in sequence , then their symmetric counterparts must be also interchanged in sequence . The requirement of several symmetry groups-that is, groups of cells having distinct symmetry axes-can be modeled in a similar way: the cells within every group must comply with the condition; in addition, the construction of the placement solution from a given sequence-pair must be refined, along with the move-set of the annealing algorithm. This extension is quite straightforward and it will be subsequently exemplified in Section VI (Fig. 7) .
The symmetry about a horizontal symmetry axis can be equally modeled starting from the modified condition cells in and inverting the construction of the and coordinates presented in the proof of Lemma 2. Actually, the last remarks lead to the conclusion that, within the sequence-pair representation, one can model symmetry relative to any number of vertical and horizontal axes.
V. HANDLING DEVICE-MATCHING CONSTRAINTS
The degree to which the electrical properties of identically specified components fail to match can often limit the circuit performance in analog design. Device mismatches are due both to random events in the manufacturing process-leading to small unpredictable variations in the electrical characteristics of devices-and to dissimilar geometrical choices for matching devices during the design process.
The latter systematically induced mismatches are handled during placement. For instance, in order to reduce the degree of electrical mismatch due to area effects, matching groups of cells can be defined, all members being constrained to the same orientation and device variant. The matching groups are handled as constraints at the move-set level of the annealer [15] , [3] , [10] .
In addition, device proximity constraints which offer the designer the possibility to specify devices to be placed in close proximity are modeled both with an imaginary proximity net of a relatively high weight, similar to the method employed by other layout systems (e.g., [3] ), and also restricting the move-set by keeping together the cells in the matching group in the sequences and .
The device separation constraints which allow the designer to specify a maximum separation distance between pairs of critically matched devices are modeled with a penalty quadratic term in the annealer's cost function. Performance constraints specifying the maximum capacitance of certain critical nets are handled similarly.
In addition to handling matching constraints, the shape optimization of parametric cells with a discrete number of possible implementations [10] and of "soft" cells-with the aspect ratio varying continuously between given limits-is also performed during placement.
VI. OVERVIEW OF THE MAIN RESULTS
The placement tool is currently implemented in Mainsail-object-oriented language which is a trademark of Xidak, Inc. The tool is embedded in ROSE, an in-house retargetable object symbolic environment for layout design, which is in use for industrial purpose and is available on HP UX and SunOS platforms. The results presented below have been obtained on an HP 9000/777 workstation.
The simple illustrative example in Fig. 3 has been processed by our tool in 4 s. In contrast, the same example with only seven cells was processed in over 15 min by an ILP-based placer, implementing for testing purpose the analytic model described in [21] . This result shows clearly that the branch-and-bound and related ILP-based techniques are ineffective (unless the number of blocks on each hierarchical level is at most six [17] , which is not common). Fig. 4 shows a more realistic example which allows to evaluate the packing capability of the placement tool. The 116-block example represents a frequency divider with selectable ratio (two or four). Without specifying any symmetry constraint, the placement has been performed in 50 min. This example is relevant due to the fact that analog circuits seldom contain more than 100 cells per hierarchical level. The placement of analog cells is very demanding not because of their size, but due to the characteristics and constraints explained in the previous sections, like symmetry, existence of "soft" cells, device matching. 5 shows the final layout of a gain-boost amplifier containing several self-symmetric and pairs of symmetric devices. As already mentioned, Murata's rectangle packing algorithm based on sequence-pair [14] cannot handle directly this example due to the symmetry constraints. Fig. 6 shows a telescopic opamp with gain-boost amplifiers (one of which is displayed in Fig. 5 ). The placement has been performed in 7.8 min. Although the theoretical complexity is not affected, the symmetry constraints increase the computation time as they affect the construction of the placement configuration corresponding to a sequence-pair encoding (see Section IV). Without any symmetry constraint, the placement for the 36 cell telescopic opamp took only 3.2 min and the area was about 15% smaller.
Finally, the frequency divider-which placement had been initially performed without symmetry constraints (see Fig. 4 )-was processed once again, the second time deriving the five symmetry groups of cells specified in the attribute section of the netlist. This time the placement took (as expected!) longer (68 min) and the area was about 26.7% larger. The final solution-displayed in Fig. 7 -clearly proves the ability of the placement tool to deal simultaneously with several symmetry groups. Table I displays the results obtained for several benchmark analog circuits. The computation time is dependent not only on the circuit size and on the number and type of constraints, but also on the schedule employed during the simulated annealing. This is why comparative time evaluations with other annealing-based placement techniques are somewhat difficult to make. 11 However, because of the schedule similitude, we can report that our experiments indicate a better speed performance by a factor of 1.2-1.4 compared to the analog placement tool described in [10] which operates on flat Gellat-Jepsen spatial 11 Murata et al. reported three results [14] : the ami49 example (from the MCNC benchmark) processed in 31.36 min; a 146 cell example solved in 29.9 min, and a large example containing 500 blocks processed in 18.83 h. No constraints (like symmetry or device matching) are mentioned for any of those examples.
representations [7] . Due to the good capability in handling symmetry, device alignment and matching, the sequence-pair representation proves to be very effective for device-level placement of analog circuits.
VII. CONCLUSION
This paper has addressed the problem of device-level placement for analog layout. Different from most of the existent tools based on a simulated annealing algorithm employing flat, absolute representations, this paper has advocated the use of sequence-pair, a topological representation not restricted to slicing structures. Handling of symmetry constraints, essential requirement for any analog placement method, has been thoroughly studied in the context of the sequence-pair representation. The effectiveness of our placement tool, already employed in an industrial environment, has been demonstrated by typical examples from analog design. The solutions of the designs marked with * are displayed.
APPENDIX
If the number of sequence-pairs for placeable cells is , the number of symmetric-feasible sequence-pairs (therefore, the size of the search space in the presence of symmetry constraints) is given by the following:
Lemma: The number of symmetric-feasible sequence-pairs corresponding to a placement configuration with cells and symmetry groups, each containing pairs of symmetric cells and self-symmetric cells , is given by the formula (2) where each factor -denoting the contribution of the symmetry group -is equal to .
Proof: We may assume without any lack of generality that the number of symmetry groups is . This is possible due to the fact that the contributions of the asymmetric component of the circuit and those of each of the symmetry groups are independent and, therefore, the total number of symmetric-feasible sequence-pairs is the product of these contributions. Then, we may consider the simplified formula (1) to be proven.
The contribution of the asymmetric part (having cells) of the circuit is as there are sets of positions in sequence (and the same number in sequence ) for the cells, and there are also possibilities of assigning these cells to the selected positions in both sequences. It may be noticed that when there are no symmetry constraints , the contribution results to be , which is the total number of sequence-pairs. When the symmetry group contains pairs of symmetric cells , and self-symmetric cells , the set of symmetric-feasible sequence-pairs may be constructed recurrently as the union of the following sets: 1) ; 2)
. where are the symmetric-feasible sequence-pairs generated by all the cells in the symmetry group except in and except in ; similarly, are the symmetric-feasible sequence-pairs generated by all the pairs of symmetric cells and all the self-symmetric cells except .
It follows that where is a permutation and is the reverse permutation of . (Example: . Therefore, the number of symmetric-feasible sequence-pairs is equal to the number of permutations , and the lemma is proven. Example (Continued): Given the example in Fig. 3 having the symmetry group , the number of symmetric-feasible sequence-pairs is
