In floorplan design, it is common that a designer will want to control the positions of some modules in the final packing for various purposes like data path alignment, I/O connection, etc.. There are several previous works [7, 9, 8, 4, 1] 
Introduction
Floorplan design is an important step in physical design of VLSI circuits to plan the positions of a set of circuit modules on a chip in order to optimize the circuit performance. In this floorplanning step, it is common that a designer will want to control the positions of some modules in the final packing for various reasons. For example, a designer may want to restrict the separation between two modules if there are a lot of interconnections between them, or he may want to align them vertically in the middle of the chip for better data path design, etc.. This will also happen in design re-use in which a designer may want to keep the positions of some modules unchanged in the new floorplan. Unfortunately, an effective method to control the absolute or relative positions between the modules in floorplan design is non-trivial and this inadequacy has limited the application and usefulness of many floorplanning algorithms in practice.
Some previous works have been done to handle some particular kinds of placement constraints. The paper [7] focuses on handling pre-placed constraint in which some modules are fixed in positions. The paper [9] works on boundary constraint in which some modules are constrained to be placed along one of the four sides of the chip for I/O connection. The paper [8] generalizes the approach in [7] to handle range constraint in which some modules are restricted to be placed within some rectangular ranges. Different approaches are used to handle different kinds of constraints and there is no unified method that can handle all of them simultaneously. Besides, all these previous works are based on a restricted type of floorplan representation, called slicing floorplan. A slicing floorplan is one that can be obtained by recursively cutting a rectangle into two parts by either a vertical line or a horizontal line. A non-slicing floorplan is one that is not necessarily slicing. Therefore, a non-slicing floorplan is more general and it can describe any type of packing. For non-slicing floorplan, there are only a few previous works [4, 1] that can handle pre-placed constraints.
In this paper, we will present the first "unified method" that can handle different kinds of placement constraints simultaneously, including pre-placed constraint, range constraint, boundary constraint, alignment, abutment and clustering, etc., in general nonslicing floorplans. The user can input a mixed set of constraints and the unified method will be able to handle all of them simultaneously. Our method makes use of constraint graphs to handle the constraints and can thus be used with any kind of floorplan representation that computes the module positions by constraint graphs, e.g., sequence pair, BSG, O-Tree, B*-Tree, etc.. We modify the constraint graphs to enforce the required constraints in the result packing. This is done by augmenting the graphs with positive, negative or zero weighted edges. These augmented edges will restrict the modules to be placed correctly according to the requirements. This technique of adding edges to constraint graphs has been used before for layout compaction [3] and packing of rectilinear blocks [2] . We found that this method could be generalized to handle different kinds of placement constraints simultaneously in floorplan design. However, a direct implementation of the original method is very expensive computationally and thus impractical. It will take O(n 3 ) time for each iteration of the annealing process where n is the number of modules. We improved this runtime by using an interesting idea of reducing the size of the constraint graphs and by updating the constraint graphs incrementally.
We tested our method with some MCNC benchmarks (ami33, ami49 and playout) and a randomly generated data set with 100 modules. Ami33, ami49 and playout were chosen because they are the largest data sets (with 33, 49 and 62 modules respectively) among all the MCNC benchmarks. Sequence pair representation [5] is used in our implementation. The results is promising and a tight packing with all the constraints satisfied can be obtained efficiently. In the following sections, we will first describe the problem and have a brief review on the sequence pair representation and constraint graph. Section 4 will give a detailed explanation of our unified approach. Section 5 will explain the techniques to reduce the size of the constraint graphs and to update them incrementally. Experimental results will be given in Section 6.
Problem Definition
In floorplanning, we are given the information of a set of modules, including their areas and interconnection and our goal is to plan their positions on a chip to minimize the total chip area and interconnect cost. In this paper, we address this floorplanning problem with placement constraint, i.e., besides the module information, we are also given some constraints in placement between the modules and our goal is to plan their positions on the chip such that all the placement constraints can be satisfied and the area and interconnect cost are minimized.
We consider two general kinds of placement constraints, absolute and relative. For relative placement constraint, users can restrict the horizontal or vertical distance between two modules to a certain value, or to a certain range of values. We use the notation h(A B) to denote the horizontal displacement from A's lower left corner to B's. Note that this value is positive if B's lower left corner is on the right hand side of A's and is negative otherwise. We use v(A B) to denote the vertical displacement from A's lower left corner to B's. Similarly, this value is positive if B's lower left corner is above A's and is negative otherwise. (Figure 1 We assume that the input set of placement constraints will not be contradictory to each other, i.e., there exists a feasible packing in which all the constraints can be satisfied simultaneously. (If the input requirements are inherently inconsistent, the floorplanner will still generate a packing that satisfys the requirements as much as possible.)
Preliminaries
We use sequence-pair in our implementation to represent a general non-slicing floorplan. A sequence-pair of a set of modules is a pair of combinations of the module names. For example, s = ( abcd bacd) is a sequence-pair of the module set fa b c dg.
We can derive the relative positions between the modules from these two combinations. and use a pair of constraint graphs to represent these relationships. A horizontal (vertical) constraint graph Gh (Gv ) for a set of n modules is a directed graph with n vertices, the vertices represent the modules and the edges represent the horizontal (vertical) relationships between the module positions. We will have an edge from a to b labeled wa in Gh where wa is the width of a if and only if module b is on the right hand side of module a. Similarly, we will have an edge from a to b labeled ha in Gv where ha is the height of a if and only if module b is above module a. We can build these graphs directly from a sequencepair representation s: insert an edge from a to b in Gh labeled wa if and only if s = ( :: a :: b :: :: a :: b :: ), and insert an edge from b to a in Gv labeled hb if and only if s = ( : : a : : b : : : : b : : a : : ).
We can compute the positions of each module from the constraint graphs by putting the x-coordinate and y-coordinate of a module i as the length of the longest path from a source to i in the horizontal and vertical constraint graph respectively.
Handling Placement Constraints in Constraint Graphs
There are two kinds of placement constraints, relative and absolute. A relative placement constraint describes the relationship between two modules, while an absolute placement constraint describes the relationship between a module and the chip. We will first discuss the approach to handle relative placement constraint and will later discuss how this approach can be used to handle absolute placement constraint by making a simple modification to the constraint graphs.
Relative Placement Constraint
In relative placement constraint, users can restrict the horizontal or vertical distance between two modules to a certain range of 2 R and meaning that B is at a distance of to on the right hand side of A (B is at a distance of to above A). When = , we are restricting the distance to a certain value. Notice that both and can be zero, positive, negative, +1 or ;1. (It is trivial to have = ;1 and = + 1, so we assume that this will not happen.) In order to realize the required constraints in the final packing, we will add a single edge or a pair of edges to the corresponding constraint graph G as described below. We use w(e) to denote the weight of an edge e. inserting edges into the horizontal (vertical) constraint graph as described in the above cases if the packing is feasible. Proof Without loss of generality, we only prove the correctness for the horizontal direction. The proof for the vertical direction will follow similarly. To prove the correctness of these steps, we need to show that if the packing is feasible after inserting these edges, the constraint h(A B) = ] will be satisfied in the packing. In the following, Gh denotes the horizontal constraint graph and x(A) denotes the x-coordinate of the lower left corner of A. Assume that the packing is feasible, i.e., both constraint graphs have no positive cycle and the position of each module can be found by computing the longest paths from a source to its corresponding vertex in the two constraint graphs. We made the following two observations which follow simply from definition: 
Absolute Placement Constraint
Absolute placement constraint restricts the absolute placement of a module with respect to the whole chip. Users can restrict the placement of a module such that its distance from the boundary of the chip is within a certain range of values. We can handle this kind of constraint using a method similar to that for relative placement constraints, i.e., by inserting a single edge or a pair of edges to the constraint graphs. To achieve this, we augment the horizontal and vertical constraint graphs each with two extra nodes. For the horizontal constraint graph, we add two nodes: one is a source with zero weighted out-going edges to all the other nodes, and the other one is a sink with zero weighted in-coming edges from all the other nodes. The source represents the left boundary and the sink represents the right boundary of the final packing. Similarly, we add two nodes to the vertical constraint graph: one is a source with zero weighted out-going edges to all the other nodes and one is a sink with zero weighted in-coming edges from all the other nodes. The source represents the bottom boundary and the sink represents the top boundary of the final packing.
In the following, we use vl and vr to denote the two additional nodes in the horizontal constraint graph: vl represents the left boundary and vr represents the right boundary. Similarly, we use vt and vb to denote the two additional nodes in the vertical constraint graph: vt represents the top boundary and vb represents the bottom boundary. After adding these nodes, we can handle absolute placement constraint easily as described below. Notice that there is no such case for h(A LL), h(RR A), v(A BB) nor v(TT A ) and and are non-negative numbers because we will The proof of correctness for absolute placement constraint follows directly from that for relative placement constraint and we will not repeat it here.
Examples of some Commonly Used Placement Constraint
Using the above specifications for absolute and relative placement constraint, we can describe many different kinds of placement constraints. In this section, we will pick a few commonly used ones and show how each can be specified using a combination of the relative and absolute placement constraints. In the following, we use x(A) and y(A) to denote the x and y coordinates of the lower left corner of module A respectively and we use hA and wA to denote the height and width of A respectively.
Alignment
To align module A, B, C and D horizontally (Figure 3(a) ), we can impose the following constraints:
We restrict the vertical distances between these modules to be zero, they will thus all align horizontally. Six additional edges will be inserted into the vertical constraint graph.
Abutment
To abut module A, B and C horizontally (Figure 3 In this formulation, the vertical distances between these modules are zero, so they will align horizontally. On the other hand, B is restricted to be on the right hand side of A by wA units and C on the right hand side of B by wB units, so they will be abutting with each other horizontally. Four additional edges will be inserted into each constraint graph.
Preplace Constraint
To preplace module A with its lower left corner at (p q) (Figure 4(a) ), we can impose the following constraints:
h(LL A) = p^v(BB A) = q
We restrict x(A) to be p units from the left boundary and y(A) to be q units from the bottom boundary, so A will be preplaced with its lower left corner at (p q) in the final packing. Two additional edges will be inserted into each constraint graph. 
Range Constraint
To restrict the position of A to within the range f(x y)jx1 x x2 y 1 y y2g (Figure 4(b) ), we can impose the following constraints:
h(LL A) = x1 x 2]^v(BB A) = y1 y 2] In this formulation, we restrict x(A) to be x1 to x2 units from the left boundary and y(A) to be y1 to y2 units from the bottom boundary, so A will lie in the required range f(x y)jx1 x x2 y 1 y y2g. Two additional edges will be inserted into each constraint graph.
Boundary Constraint
To place module A at the upper right corner of the final packing, and place B along the top boundary ( Figure 5(a) ), we can impose the following constraints:
h(A RR) = wA^v(A TT) = hA^v(B TT) = hB In this formulation, we restrict the horizontal distance between A and the right boundary to be the width of A and the vertical distance between A and the top boundary to be the height of A, so module A will be placed at the upper right corner in the final packing. Besides, B is restricted to be hB units from the top boundary, so B will abut with the top boundary as required. We need to insert two edges into the horizontal constraint graph and four edges into the vertical constraint graph.
Clustering
To cluster module A, B and C around D at a distance of at most p units away vertically or horizontally ( Figure 5 In this formulation, we restrict the horizontal and vertical distances of A, B and C from D to be at most p units in both directions, so they will cluster around D at a distance of at most p units away.
Six additional edges will be inserted into each constraint graph. 
General Placement Constraint
We can use combinations of the above relative and absolute placement constraints to specify all mixed constraints in general. For example, to restrict the placement such that module B and C align with each other horizontally and they cluster around A at a distance of at most 20 units away (Figure 6 ), we can impose the fol- The first constraint align B and C horizontally and the next four cluster B and C around A to within a distance of 20 units away.
We need to add four additional edges to the horizontal constraint graph and six to the vertical constraint graph.
Algorithm and Implementation
We use simulated annealing with sequence pair representation. In each step of the annealing process, we will augment the constraint graphs with edges as described in the above section. We call these edges constraining edges. However it is possible that some constraints cannot be satisfied after adding these constraining edges, the packing is then infeasible. Feasibility of a packing can be checked by detecting positive cycles in the constraint graphs. If a packing is infeasible, we will pack the modules as if there is no placement constraint and compute a penalty term in the cost function to penalize the violations. This strategy ensures that all feasible solutions are reachable, and can drive the packing solution to one that satisfys the constraints as much as possible in case the user requirements are inherently inconsistent. We observed a stable convergency in the annealing process using this scheme and all the placement constraints can be satisfied at the end of the annealing process in all our experiments. We will describe the algorithm in details in the following sub-sections.
Detecting Positive Cycles by Reduced Graphs
After augmenting those constraint graphs with the constraining edges, we need to test their feasibility by detecting positive cycles in them. A direct implementation of some classical algorithm (e.g., the modified Floyd-Warshall algorithm [6] ) to check positive cycles will take O(n 3 ) time where n is the total number of modules. In order to improve the timing complexity, we will reduce the size of the constraint graphs before checking for cycles. This is possible because of the following observation. We use ing complexity can be further reduced in practice by performing incremental updates as described in the next sub-section.
Gh(V Eh
)
Moves and Incremental Updates
In every iteration of the annealing process, we will modify the sequence pair by one of the following three kinds of moves:
[M1] Change the width and height of a module.
[M2] Exchange two modules in both sequences.
[M3] Exchange two modules in the first sequence.
The constraint graphs will not change much after each move, so we do not need to reconstruct them once in every iteration. We can take advantage of this incremental updates in two different places:
construction of Gh and Gv, and construction of Hh and Hv.
Incremental Updates of G h and G v
In move M1, a module A is picked and changed in its width and height, so the structures of the constraint graphs will remain the same except that all the out-going edges from A will have their weights changed. In our implementation, the weights on the edges are stored at the source vertex because all the edges out-going from the same vertex will have the same weight. Therefore, we only need to update the weight of vertex A in both Gh and Gv after M1 and this will take constant time. In move M2, two modules A and B are picked and switched in positions in both sequences.
The structure of the constraint graphs will again remain the same except that the vertices corresponding to A and B will switch in position. This will affect the weights of the out-going edges from these two vertices. Therefore we only need to update the weights in these two vertices in both Gh and Gv and this will again take constant time. In move M3, two modules A and B are picked and switched in positions in the first sequence. The structure of the constraint graphs will change after this move. However, only those modules lying between A and B in the first sequence will be affected and there are n 3 of them on the average. Besides, each update can be done very efficiently (either an edge e(i j) in Gv is deleted and a new edge e(i j) is inserted into Gh, or an edge e(i j) in Gh is deleted and a new edge e(i j) is inserted into Gv). Therefore, Gh and Gv can be updated very efficiently in O(n) time. 
Incremental Updates

Time Complexity
In each step of the annealing process, we modify the sequence pair by performing move M1, M2 or M3. After the move, we need to update Gh, Gv, Hh and Hv. Updating Gh and Gv takes O(n) as explained above. Updating Hh and Hv takes O(mn 
Annealing Schedule and Cost Function
The temperature schedule of the annealing process is of the form T(k) = rT(k ; 1) for all k 1. At each temperature step, enough number of moves are attempted until the total number of moves exceeds a certain number N where N is a user defined constant. The temperature is initialized to a large value at the beginning and the annealing process terminates when the temperature is low enough. The best solution found will then be used to go through a "final baking" process in which only better solutions will be accepted.
The cost function is defined as A + W + P where A is the total area of the packing. In our current implementation, W is the half perimeter estimation of the interconnect cost but this term can be replaced by other more sophisticated interconnect cost estimations. P is a penalty term which is zero when all the placement constraints are satisfied, and is otherwise the sum of squares of the violations.
Handling Infeasible Packings
If a packing is infeasible, i.e., positive cycles exist in the constraint graphs, we will pack the modules as if there is no constraint and compute a penalty term P. For example, if an edge e = ( A B) labeled is inserted into the horizontal constraint graph because of a given placement constraint, the penalty term due to this edge in case of an infeasible packing will be (minfx(B) ; x(A) ; 0g) 2 . This gives a good estimation of how far the modules are from their desired positions. Note that we need to accept infeasible intermediate solutions in the annealing process because it may happen in some cases that a good feasible solution can only be reached from an initial starting point with some infeasible intermediate solutions in between during the searching process.
Experimental Results
We tested our floorplanner on a set of MCNC benchmark data (ami33, ami49 and playout) and a randomly generated data set with 100 modules. For each experiment, the temperature is set to 1:5 10 6 initially and is lowered at a constant rate of 0.95 to 0.98 until it is below 1 10 ;10 . The number of iterations at one temperature step is 80. in the cost function is set such that the costs of wirelength and total area are approximately equal. is set at a high value (30 to 40) to ensure that all the placement constraints can be satisfied at the end. All the experiments were carried out on a 400 MHz Sun Ultra III.
We tested our floorplanner using the benchmark data and a randomly generated data set by imposing different combinations of placement constraints to the modules. The result is shown in Table 1. For each data set, the result reported in each row is an average of six experiments using three different sets of placement constraints. We can see from the table that the algorithm is indeed very efficient. The percentage deadspace ranges from 5.9% to 8.4% and all the placement constraints can be satisfied in all the experiments. We have also compared our results with [8] (using 300MHz Pentium II) that focuses on handling range constraint in slicing floorplan. We repeat the same experiments on range constraint using our new unified method and the results is shown in Table 2 . The result reported in each row is an average of five different experiments using the benchmark data, ami33, ami49 and playout. We can see that our unified method is faster although the method in [8] 
