In this paper, the problem of bus-driven floorplanning is addressed. Given a set of blocks and bus specifications (the width of each bus and the blocks that the bus need to go through), we will generate a floorplan solution such that all the buses go through their blocks, with the area of the floorplan and the total area of the buses minimized. The approach proposed is based on a simulated annealing framework. Using the sequence pair representation, we derived and proved some necessary conditions for feasible buses, for which we allow 0-bend, one-bend, or two-bend. A checking will be performed to identify those buses that cannot be placed simultaneously. Finally, a solution will be generated giving the coordinates of the modules and the buses. 
Introduction
Floorplanning is to plan the positions and shapes of a set of modules at the beginning of the design cycle to optimize circuit performance. Interconnect-driven floorplanning is considered to be one of the most important problems in physical design today. As the complexity of chip design increases, the amount of interconnections between different modules on a chip also increases rapidly. Bus is a collection of wires, which can be used to carry signals between different modules. Bus routing has become more and more important as the complexity of chip design increases. An area-compacted floorplan is not necessarily bus-routable. In order to ease bus routing and avoid unnecessary iterations of the physical design cycle, it would be favourable to incorporate this bus routing problem in the early designing phases. Bus-driven floorplanning considers bus placement. Buses are of different widths and need to go through different sets of modules. Therefore, the positions of the modules will affect the placement of the buses. The objective of the problem is to obtain a bus-routable floorplan such that the area of the chip and the total area of the buses are minimized.
The floorplanning problem in general is a well-studied problem. There are three kinds of floorplan: slicing, nonslicing and mosaic. Many new representations were introduced in the past decade to represent different kinds of floorplans, including sequence pair [1] , bounded-sliceline grid [2] , O-tree [3] , B*-tree [4] , transitive closure graph [5] , corner block list (CBL) [6] , Q-sequence [7] , twin binary tree [8] and twin binary sequence [9] , etc. Some of these floorplanners are extended to handle placement constraints in floorplan design. The floorplanners in [4, 10, 11] can handle pre-place constraint in which some modules are fixed in position. The paper [12] [13] [14] work 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 [15] generalizes the approach in [10] to handle range constraint in which some modules are restricted to be placed within some rectangular ranges. In [16] , the authors tried to enforce the abutment constraint based on the CBL representation. It is shown that the abutment information of the blocks can be deduced from the CBL representation. However, the blocks on a bus are not necessarily abutted. Thus, their approach cannot be used to solve the bus driven-floorplanning problem. In [17] , the authors proposed a unified method to handle simultaneously different kinds of placement constraints, including pre-placed constraint, range constraint, boundary constraint, alignment, abutment and clustering constraint, etc. All these constraints were modeled as a collection of ''relative placement constraints'' and ''absolute placement constraints'', and were enforced by inserting edges in the constraint graphs. However, this approach is not suitable for bus-driven floorplanning as for a bus, the order in which the blocks are placed on a bus is not fixed. Besides, we do not know beforehand the shape of a bus which can be 0-bend, 1-bend, or 2-bend in our problem.
Based on the sequence pair representation, the authors of [18] proposed a method to enforce alignment constraint and some other performance constraints in floorplanning. Although the alignment constraint mentioned in [18] is not applicable for bus-driven floorplanning, their intuition on deducing the approximate positions of the blocks by looking at the sequence pair is very helpful. In [19] , the authors have made use of the idea from [18] to design an intact algorithm to solve the bus-driven floorplanning problem. In [19] , the authors aimed at solving the busdriven floorplanning problem, based on a simulated annealing (SA) framework. Each candidate floorplanning solution were checked in an evaluation step to see if the buses are feasible, i.e., the required set of blocks can be passed through by a 0-bend bus. Sequence pair representation was used. One major drawback of this approach is that, only horizontal and vertical buses are considered and the solution quality will deteriorate if the number of blocks involved in each bus is large. Our proposed algorithm has made a significant improvement over [19] by allowing 0-bend, 1-bend, and 2-bend buses.
In this paper, this bus-driven floorplanning problem will be re-visited. Unlike [19] , our proposed algorithm allows 0-bend, 1-bend (or 1-via), and 2-bend (or 2-via) buses. Experimental results have shown that our algorithm can generate solutions with high quality especially when the number of blocks in each bus is large. For example, if the buses have to go through more than 10 blocks each, the approach in [19] is not able to generate any solution while our algorithm can still give solutions of good quality.
The rest of this paper is organized as follows. A formal definition of the problem will be given in Section 2. After that, an algorithm is proposed to solve the problem, and details will be discussed in Section 3. Experimental results will be presented in Section 4. Finally, a conclusion will be drawn in Section 5.
Problem formulation
We assume that buses are routed on two layers, one for horizontal buses and the other for vertical buses. The busdriven floorplanning problem can be formulated as follows.
Given the following:
(1) A set of n blocks B ¼ fb 0 ; b 1 ; . . . ; b nÀ1 g, where each block b i is associated with a width w i and a height h i , where
. . . ; u mÀ1 g, where each bus u i has a width t i where t i 2 R þ , and need to go through a set of blocks B i ; B i B.
Our task is to decide the position of each block and the route of each bus such that every bus u i goes through all its blocks, there is no overlapping between any two blocks and there is no overlapping between the horizontal (vertical) components of the buses (since there are only two layers for bus routing). The goal is to minimize the chip area and the total bus area. We consider buses of 0-bend, 1-bend, or 2-bend only in our problem to minimize the number of vias used.
We will define the meaning of ''going through'' in the following. For a horizontal component of a bus u i to go through a set of blocks fA; B; Cg, the vertical overlapping between the blocks has to be greater than or equal to the bus width t i of u i . An example is shown in Fig. 1 . The condition for a vertical component of a bus to go through a set of blocks can be defined similarly.
Methodology
SA will be used as the searching engine. A candidate solution will be evaluated according to (1) the number of buses routed successfully, (2) the total area of the buses, and (3) the total area of the floorplan. There are three main steps to evaluate a solution. The first step is to determine the shapes of the buses by examining the sequence pair. After that, a bus ordering is found such that all feasible buses can be layed out successfully by following this order. Finally, a flooplan is obtained by calculating the coordinates of the blocks and the buses. Bus feasibility is performed on the sequence pair representation of a candidate solution first because some candidate floorplans cannot be realized under the bus constraints, and it will be more efficient if we can check that out by just looking at the sequence pair representation before the floorplan realization step. Details of each step will be given in the following sections.
ARTICLE IN PRESS

Shape validation
We can deduce the shape of a bus by looking at the sequence pair representation of the floorplan. As we allow buses of at most two bends, buses that cannot be realized in two bends will be considered as infeasible and will be excluded from further checking. A penalty will be added to the cost of the annealing process for each infeasible bus.
An example is shown in Fig. 2 . Consider a sequence pair (FGHICDEAB, ABCDEFGHI), a bus u i that need to go through the blocks in fD; E; Gg can be realized as a 1-bend bus ( Fig. 2(a) ). Another bus u j that need to go through the blocks in fA; C; D; E; G; H; Ig will have at least three bends ( Fig. 2(b) ) and it will be marked as infeasible. The aim of this step is to find out all the infeasible buses and to determine the shape of each feasible bus.
Given a bus u i that need to go through B i ¼ fb 1 ; b 2 ; . . . ; b k g, we will first extract those blocks in B i from the sequence pair, without altering their relative positions. For example, if we are checking a bus that need to go through a set of blocks fA; B; Eg in a floorplan represented by the sequence pair (ADBCE, EBCAD), we will first extract sp i ¼ ðABE; EBAÞ from the sequence pair and examine sp i to decide whether u i can be routed successfully as a 0-bend, 1-bend, or 2-bend bus one after another.
0-Bend bus shape validation
A 0-bend bus is simply a horizontal or a vertical bus. For a bus u i to be 0-bend, the orders of the blocks in the two sequences of sp i ¼ ða; bÞ have to be either the same, i.e., a ¼ b (for horizontal bus) or reversed, i.e., a ¼ b R (for vertical bus). For example, given a sequence pair (DEFABC, ABCDEF) and a bus u 0 that need to go through the blocks in fA; B; Cg, the first step is to extract the corresponding blocks from the sequence pair: sp 0 ¼(ABC, ABC). As the blocks appear in the same order in both sequences, it can be concluded that u 0 can be realized as a horizontal bus. For another bus u 1 that has to go through the blocks in fC; F g, the extracted sp 1 is (FC, CF). As the blocks appear in reversed order, it can be realized as a vertical bus. This example is illustrated in Fig. 3 . The 0-bendcondition is stated formally as follows:
Condition 0-bend: A pair of sequences s i ¼ ða i ; b i Þ satisfies the 0-bend condition if and only if
1-Bend bus shape validation
A 1-bend bus is also called an L-shaped bus. For a bus to be 1-bend, a necessary condition is that it consists of one vertical component and one horizontal component. This can be checked easily by identifying the longest common subsequence (LCS) in sp i first, and then check if the remaining blocks (after removing the blocks in the LCS) in the two sequences are in reversed order. The 1-bend condition is stated formally as follows: Proof. To pass through a set of blocks with a 1-bend bus, some of the blocks must be horizontally related while the remaining is vertically related. Those horizontally related will form one common subsequence in s i . To check the feasibility, we only need to look at the LCS, instead of any common subsequence. This is because if taking an LCS as the horizontal component fails to form a valid L-shape, taking any other LCS or shorter subsequences will also fail. Let l 1 be the LCS of sp i we picked and l 2 be another common subsequence such that jl 2 jpjl 1 j. There are two different cases according to the number of blocks in l 1 but not in l 2 . The first case is that there are at least two blocks n 1 and n 2 in l 1 but not in l 2 . Then, a valid L-shape cannot be formed with l 2 as the horizontal component because n 1 and n 2 , which are not in l 2 , must also be ina left-right relationship with each other. This implies two separate horizontal components and a valid L-shape cannot be formed.
The second case is that there is only one block n 1 in l 1 but not in l 2 . There are two sub-cases according to the lengths of l 1 and l 2 . In the first sub-case, jl 2 jojl 1 j, i.e., jl 2 j ¼ jl 1 j À 1, the block n 1 can serve as the joint between the vertical and the horizontal components if a valid L-shape can be formed, and taking either l 1 or l 2 as the horizontal component is the same. In the second sub-case, jl 2 j ¼ jl 1 j, then there will be another block n 2 in l 2 but not in l 1 . Notice that n 1 and n 2 must be in an upper-lower relationship with each other. If n 2 is not the leftmost nor the rightmost block in l 2 , a valid L-shape cannot be formed by taking l 2 as the horizontal component since the vertical component will appear in the middle part of the horizontal component otherwise. If n 2 is the leftmost or the rightmost block in l 2 (and so as n 1 in l 1 ), taking either l 1 or l 2 as the horizontal component is the same, as the block n 1 or n 2 can serve as the joint between the vertical and the horizontal components if a valid L-shape can be formed. &
In the following steps, we will regard the first and the last block of the LCS as in the vertical component and will keep them for checking whether the vertical component is on the left or on the right of the horizontal component. Let us look at an example. Given a sequence pair (DEFABC, ABCDEF) and a bus u 3 that has to go through the blocks fA; B; C; Dg, the first step is to extract the corresponding blocks sp 3 ¼ ðDABC; ABCDÞ from the sequence pair. As it failed the 0-bend checking, the next step is to check if it can be realized as a 1-bend bus. The LCS of sp 3 is ABC, so ABC will be taken as the horizontal component of u 3 and B will be removed from sp 3 . Then we have to check whether the remaining block D can form a vertical component with the block A or C. As the blocks A and D appear in reversed order in sp 3 , AD can form the vertical component of u 3 (Note that C and D also appear in reversed order in sp 3 and we can pick either AC or CD.). After checking, u 3 is classified as a valid 1-bend bus. This example is illustrated in Fig. 4 . Let us look at anotherexample. given the same sequence pair (DEFABC, ABCDEF) and another bus u 4 that has to go through the blocks in fA; B; E; F g, we first extract the corresponding blocks sp 4 ¼ ðEFAB; ABEF Þ from the sequence pair. The LCS is AB or EF. As there exist more than one LCS, we can take any one of them. Suppose that we take AB, the remaining subsequences are not in reversed order, so it is not a valid 1-bend bus and it will proceed to the 2-bend checking. This example is illustrated in Fig. 5 .
2-Bend shape validation
If a bus is found to be neither 0-bend nor 1-bend, we will check whether it is a 2-bend bus. There are several kinds of 2-bend buses, Z-shaped, mirrored Z-shaped, C-shaped, or mirrored C-shaped. There will be two horizontal (vertical) components and one vertical (horizontal) component in the bus, denoted by HVH or VHV, respectively. Assuming the case of HVH in the following discussion, we will first identify the vertical component of the bus. Let the extracted sequence pair sp i of bus u i be ða; bÞ, where a and b are strings of blocks. The vertical component can be found by finding the LCS in ða; b R Þ, where b R denotes the reverse of the string b. Similar to 1-bend checking, the first block and the last block of the LCS will be kept for horizontal component checking. Besides, we have to pick an LCS but not any other shorter subsequence, and if there are more than one LCSs, picking any one of them will be the same. The argument is similar to that in 1-bend shape validation.
After identifying the vertical component, we will classify the remaining blocks of the bus into different relationships with the vertical component. For example, consider a bus u i with extracted sequence pair sp i ¼ ða; bÞ ¼ ðABCFDE; AEDCBF Þ. The LCS of a and b R is BCDE. The block A will be classified as in the set Left, as A is on the left of all the blocks in the vertical component. On the other hand, block F will be classified as in the set UpperRight, as F is on the right-hand side of the blocks B and C and on top of the blocks D and E. We can deduce these relationships easily from the sequence pair. There are totally eight position sets:
(1) A block is in the set Upper if it is above all the blocks in the LCS. UpperLeft and LowerRight have to be emptied. The blocks in the set Upper, UpperRight, and Right will form one horizontal component, and the blocks in the set Lower, LowerLeft, and Left will form another horizontal component. Details are shown in Fig. 6 . The last step is to check both horizontal components to ensure that the blocks in each component can indeed align horizontally, i.e., the blocks appear in the same order in both sequences of sp i . The 2-bend condition is stated formally as follows: Lemma 2. The 2-bend condition is necessary for a sequence pair s i that allows a bus passing through all its blocks with only two bends.
Proof. To pass through a set of blocks with a 2-bend bus that has a horizontal (vertical) trunk, some of the blocks must be horizontally (vertically) related to form the trunk while the remaining will form two vertical (horizontal) components, one on the left (upper) side and one on the right (lower). Those horizontally (vertically) related blocks will form one common subsequence in a i and b i (a i and b R i ). To check feasibility, we only need to look at the LCS, instead of any common subsequence and the argument is similar to that for Lemma 1. & The shape validation step for 0-bend, 1-bend, and 2-bend buses can be incorporated into one whole process and the overall algorithm is shown in Figs. 7-9. 
Bus ordering
In this step, we aim at determining an ordering between the valid buses, and removing those that have conflicts with others. For example, given a sequence pair (CADB, ACBD), block C has to be placed above block A according to the orderings in the sequence pair, so any horizontal bus going through block C has to be placed above any horizontal bus going through block A. This kind of constraint is called the bus ordering constraint.
However, some ordering constraints may be contradictory to each other. An example is shown in Fig. 10 . In this example, block A is on the left of block B according to the sequence pair, so any vertical bus going through A has to be placed on the left of any vertical bus going through block B. Similarly, block C is on the left of block D and thus, any vertical bus going through C has to be placed on the left of any vertical bus going through D. Problem will occur if there are two 2-bend buses u i and u j , where a vertical component of u i has to go through blocks A and D, and a vertical component of u j has to go through blocks B and C. These two vertical components have to be placed on the left-hand side of each other, which is impossible. This step aims at removing the least number of buses such that the remaining buses do not have any conflict with each other. For simplicity, our discussion below is limited to the horizontal components of the buses, where the case for the vertical components can be derived similarly.
Assuming that buses are routed on two layers, one layer for horizontal buses and the other for vertical buses. We can consider the constraints between horizontal components and the constraints between vertical components separately. For 1-bend or 2-bend buses, we will first break them down into two or three 0-bend components, respectively, before checking the ordering constraints (Fig. 11) . For horizontal components, we will use a graph G h ¼ ðV ; EÞ to determine whether all the ordering constraints can be satisfied. Each vertex in V represents a 0-bend horizontal component, and E ¼ fðv i ; v j Þj component v i has to be placed above component v j g. In order to check if ðv a ; v b Þ 2 E, we will first extract sp ab from the sequence pair, where sp ab contains only the blocks in u a and u b . For example, if the sequence pair is (ABCDEF, DEACBF), and u a has to go through block A and B and u b has to go through block C and D, the extracted sp ab will be (ABCD, DACB). Let m be a block, s 1 ½m denotes the position of block m in the first sequence of sp ab , e.g., s 1 ½A in the above example is one. Similarly, s 2 ½m is the position of block m in the second sequence of sp ab . In the above example, s 2 ½A is two. After computing the s 1 ½m and s 2 ½m for each related block m, we will check if sp ab falls into one of the following three cases according to [19] (Fig. 12 In the floorplanner, we simply perform the checking for every pair of horizontal (vertical) bus components directly. As some of the buses cannot be placed simultaneously, our ARTICLE IN PRESS aim in this step is to remove the least number of buses such that all the remaining buses can be placed. Besides, we aim at finding an ordering for the remaining buses such that they can be placed one after another successfully in a bottom-up (left-right) manner. To do so, we have to examine the graph G h . Contradiction exists if cycle presences. Therefore the first step is to check whether cycles exist in G h . If there are cycles, we want to remove the least number of nodes (bus components) to make the graph acyclic. However, this Node-Deleting Problem is proved to be NP-complete [19] . Our heuristic to solve the problem is to keep on removing the node with the highest degree (in-degree plus out-degree), until the graph is acyclic. Assume that a 2-bend bus u i is broken into three 0-bend components u 1 , u 2 , and u 3 , where u 1 and u 3 are horizontal and u 2 is vertical. When processing the horizontal components, a graph G h is built. If u 1 is selected to be removed in order to make G h acyclic, u 3 in the horizontal graph and u 2 in the vertical graph have to be removed as well. This is obvious since we should not keep partial bus components in the solution, if some other components of the bus are already marked as invalid. In some cases, bending can help to resolve conflicts in the ordering constraint graphs G v and G h . An example is shown in Fig. 13 . In this example u i and u j are horizontal buses that contradict with each other. Changing u i from 0-bend to 1-bend can resolve the conflictwithout removing any bus from the graph. However, this technique of adding bends to a bus to resolve conflict can only be used for buses that are 0-bend or 1-bend, so that one more bend can be added to resolve the conflict by the method as illustrated in Fig. 13 . This can be done by processing those buses marked as invalid during the cycle removing step of G h or G v again to form buses with one more bend by calling the procedures ONE_BEND_CHECK(), TWO_BEND_ CHECK_VHV() or TWO_BEND_CHECK_HVH().
ARTICLE IN PRESS
After obtaining an acyclic graph, an ordering of the remaining valid components can be obtained from a topological sort of G h .
Floorplan realization
The final step to evaluate a candidate solution is to realize the floorplan, i.e., obtaining the coordinates of the blocks and the buses, to determine the chip area and the total bus area. After the previous checkings, all the invalid buses are removed, and a correct bus ordering is found. Based on these information, we can compute the coordinates of all the blocks and the valid buses, and thus the chip area and total bus area. In order to obtain the coordinates of the blocks, we used the algorithm FAST-SP in [20] to construct a floorplan from the sequence pair. Then we use the same approach as in [19] to align blocks on the same bus, which can be described in brief as follows. The following process is repeated OðmÞ times, where m is the total number of valid buses. Note that all 1-bend and 2-bend buses will have been broken down into 0-bend buses for processing. Let us consider horizontal buses only. In iteration i, bus u i will be processed.
The coordinates of the blocks that u i goes through will be computed first. Then, the position of u i will be calculated by performing some basic alignment steps between the blocks that u i goes through. These basic alignment steps for horizontal buses are shown in Fig. 14. An example is shown in Fig. 15 .
After doing the basic alignment steps, we will check if u i overlaps with any previously placed bus. If so, u i will be moved up and the coordinate y u i will be updated. If u i is moved up, the positions of all the blocks that u i goes through may need to be computed again.
Time complexity
For a bus u i passing through k blocks, the shape validation step will take Oðk log kÞ time to find the LCS in sp i . It then takes OðkÞ time to put the remaining blocks into the position sets and to perform ONE_BEND_CHECK() and TWO_BEND_CHECK()s. To find the bus ordering, for each pair of horizontal (or vertical) bus components u a and u b , we need to scan the extracted sequence pair sp ab once, so the total time will be Oðm 2 KÞ where m is the number of buses and K is the largest number of blocks a bus passes through. For the floorplan realization step, the packing step takes Oðn log nÞ using a simpler version of the FAST-SP algorithm in [20] , while the alignment step will take OðKÞ for each bus component. Therefore, the total time taken will be OðmK log K þ m 2 K þ n log n þ mKÞ ¼ OðmK log K þ m 2 K þ n log nÞ.
Simulated annealing
SA is used to search for a good solution. In this section, the set of moves and the cost function used in the SA will be discussed. 
ARTICLE IN PRESS
Moves
To change from one candidate solution to another, we use two operations, swap and rotate.
(1) Swap is to exchange the positions of two blocks in either the first sequence or the second sequence. This can be done in constant time. (2) Rotate is to exchange a block's height with its width.
This can be done in constant time.
Cost function
As mentioned above, our objectives are to (1) accommodate all the buses, (2) minimize the total area of the buses, and (3) minimize the area of the floorplan. Thus, the cost function is defined as follows.
where A is the chip area, B is the total bus area, I is the number of invalid bus, and a, b, and g are parameters that can be specified by the users. In this busdriven floorplanning problem, we focused on fitting all the buses in a compact floorplan solution. Other aspects like the total wire length and routing congestion can also be considered by including more terms in the cost function.
Handling soft blocks
In order to compare with the results presented in [19] , we have added the feature of ''soft block adjustment''. The adjustment is the same as that in [19] . This step makes use of the fact that the width and height of a block can be altered as long as the area is unchanged and the dimension is constrained by an aspect ratio bound. The process is again done by SA. The cost function is the same as before. In each pass, a block lying on a critical path will be selected, and the width or height of it will be changed a little bit. Then, the floorplan realization step is repeated to obtain a new chip area and total bus area. Note that if a valid bus is made invalid by this soft block adjustment step, the new candidate solution will be discarded. Besides, when changing a block width or height, the aspect ratio constraint cannot be violated.
Experimental results
The proposed algorithm is implemented using the C þ þ language and the experiments are conducted using an Intel Xeon (2.2 GHz) machine with 1 G memory. The test cases are derived from the MCNC benchmarks for floorplanning. In order to compare with the results presented in [19] , the same test cases (Table 1) are tried using our proposed algorithm and all the experiments (including those of [19] ) [19] and by our algorithm, respectively.
ARTICLE IN PRESS
are run on the same machine. The annealing processes are implemented in such a way that the stopping criteria of both programs are the same. The results are listed in Table 3 . Comparing with the results of [19] , the dead space of the floorplan obtained by our algorithm is reduced on average. The runtimes of our approach have increased because of the extra steps in processing 2-bend buses. The shape validation step has become more complicated with 2-bend buses in comparison with that in [19] which considers only 0-bend and 1-bend buses.
To demonstrate the importance of having 1-bend and 2-bend buses, we have created another set of test cases (Table 2 ) based on the ami33 and ami49 benchmarks. In these test cases, each bus will go through at least 10 blocks. The annealing process stops when the deadspace percentage is less than a certain threshold. The results are shown in Table 4 . For this data set, the approach in [19] is not able to generate any solution for most of the test cases, while our algorithm can still generate solution of high quality (with average dead space of 1.8% only). We can see that our algorithm can obtain much better performance. As their approach allows only 0-bend bus, it is very difficult to accommodate several buses that go through many blocks. Some resultant packings are shown in Figs. 16 and 17. 
Conclusion and future work
In this paper, an algorithm to solve the bus-driven floorplanning problem allowing 0-bend, 1-bend, and 2-bend buses is proposed. Experimental results show that our approach is effective. The presence of 1-bend and 2-bend buses is important especially when the number of blocks that a bus goes through is large. It is difficult to find a solution if only 0-bend bus is allowed in those cases. One feasible extension of this work is to consider buses of other shapes with small number of vias.
