This paper proposes a Satisfiability Modulo Theory based formulation for flooplanning in VLSI circuits. The proposed approach allows a number of fixed blocks to be placed within a layout region without overlapping of one block over the other and at the same time area of the layout region is minimized. The proposed approach also allows a number of fixed blocks with ability to rotate and flexible blocks (with variable width and height) to be placed within a layout without overlap. Our target in all cases is reduction in area occupied on a chip which is of vital importance in obtaining a good circuit design. Satisfiability Modulo Theory provides a richer modeling language than is possible with pure Boolean SAT formulas.
I. INTRODUCTION
Floorplanning is an important step in physical design. Floorplanning helps to provide tentative location of IC building blocks. It is vitally important because it helps to determine size and yield of VLSI chips.
The goal of floorplanning is to optimize a predefined cost function, such as the area of a resulting floorplan given by the minimum bounding rectangle of the layout region. The floorplan area is directly related to the chip silicon cost. The larger the area, the higher the silicon cost. The free space in the floorplan bounding rectangle which is not covered by any module is called white space or dead space. In floorplanning step a design can contain two types of blocks: hard and soft blocks. A hard block is a circuit module with area and aspect ratio fixed. While a soft block has fixed area but variable aspect ratio. This paper presents a Satisfiability Modulo Theory based approach for floorplanning with hard, soft and rotating basic blocks.
A. Previous Work
Sutanthavibul [5] formulated the floorplanning problem as a mixed integer linear program. The method proposed divides the given problem into various subproblems. Each sub problem is solved using 0-1 mixed integer programming method. The optimal solution for each subproblem is found and the final solution is achieved using successive addition of new elements to an already existing partial solution. Chen [2] have solved the floorplanning problem using particle swarm optimization which is population based evolutionary algorithm. Their objective is also to minimize the area of hard blocks. Young [3] in this paper derived a method to handle all kinds of placement constraints at the same time including preplace constraints, range constraints, boundary constraints, alignment constraint, abutement, clustering etc. In this paper simulated annealing with sequence pair representation is used. Vertical and Horizontal constraint graph is used to compute the position of each module. Evangeline and Young [1] used twin binary trees to represent mosaic floorplan. A mosaic floorplan is a floorplan which has zero spaces. Then a twin binary sequence is constructed. To construct twin binary trees, they start from the module at the lower left corner and travel upward in case of left subtree and to the right in case of right subtree. On reaching the lower left corner of another module a node is inserted in the tree. This process is repeated until all modules are visited. A similar process is done starting from the upper right corner and traveling downward. Then a binary sequence corresponding to the trees is determined.
Tang and Wong [7] discussed about fixed frame floorplanning where the problem is addressed by handling alignment constraint which arise in bus structure. Here, several blocks are aligned in a range (for eg. bus width) abutting one by one horizontally or vertically. Here, the concept of Sequence Pair Representation was used. Recent work on floorplanning by Jackey Z Yan and Chris Chu [6] designed an algorithm for soft blocks. Here, a parameter called slack is used which denote the difference in x-coordinate, y-coordinate position between two layouts generated by packing blocks to right, left and top, bottom respectively. The width of the soft blocks on vertical control path are increased and height is decreased correspondingly. Similarly in Horizontal control path height is decreased and width is decreased. In [4] it is observed that when two modules are put together, at least one of which has range constraint, the combined supermodule will also have range constraint. Here, mainly four variables are used to represent the constraint at the right, left, top and bottom. For a particular module with fixed width and height it is constrained to be placed within a bounding rectangle. Then a shape curve is calculated at each internal node till the root which gives us the representation of the possible shapes of the final floorplan. A shape curve is peicewise linear decreasing curve which represents the tradeoff between the 978-1-5090-2541-1/16/$31.00 c 2016 IEEE height and width of a module as mentioned by Wong [4] . Yan [8] in this paper have induced a nonslicing floorplan by using a compacting technique for slicing floorplan. In comparison to traditional annealing based approaches, one single slicing tree is being considered which is generated by recursive partitioning. The technique here is used to defer the decision on four factors, subfloorpaln orientation, subfloorplan order, slice line direction and slicing tree structure. This technique achieves a generalized slicing tree.
B. Our contribution
This paper presents an efficient way to handle the floorplanning problem of minimizing the floorplanning region area by using Satisfiability Modulo Theory (SMT)where the task is to find a satisfying assignment to a set of constraints that minimizes a given objective function. We have successfully placed blocks for the three scenarios as follows: Case-1: Floorplanning with blocks which have fixed width and height in a layout region. Case-2: Floorplanning with blocks with fixed width and height but with possibility of change in orientation (blocks may rotate). Case-3: Floorplanning with blocks with fixed area but flexible width and height. The constraints which we are using are boundary constraints and non-overlap constraints. The boundary constraints are responsible for maintaining the boundary of the modules within the floorplaning region. The overlap constraints are responsible for maintaining non overlapping position of the modules within the region. Including these constraints the objective of area minimization is achieved using SMT.
The paper is organized as follows: Section II describes the problem formulation. Section III deals with experimental results. Section IV concludes the paper.
II. PROBLEM FORMULATION
The Satisfiability Modulo Theory is the task of finding a satisfying interpretation to a set of variables which satisfies all the constraints. A SMT constraint is expressed as (assert (≥ x 0)). The command assert adds a formula into the solver's internal stack. To use a constant we need to declare it as (declare-const x Int). The formula is satisfiable if there is an interpretation that makes all the asserted formula true.
A. Case-1: Floorplanning with blocks which have fixed width and height
Given two rectangular hard blocks b i and b j where b i is of height h i and width w i and b j is of height h j and width w j , our target is to place the modules within a block whose bottom left hand corner position is assumed to be (0,0) and top right hand corner position is assumed to be (c,d), such that they do not overlap and at the same time area of the block is minimized.
Let (x i ,y i ) and (x j ,y j ) be the left hand corner position of block b i and b j respectively. Thus, the constraints for placing the blocks within the floorplanning region are formulated as follows:
1) Non-Overlap Constraints: Two blocks i, j are said to be non overlapping if at least one of the following cases is satisfied [5] . To obtain a valid placement of the rectangular modules in the floorplanning region, one of the following constraints must be satisfied:
In order to ensure that of the four inequalities, at least one holds true, two additional Boolean variables x ij and y ij are introduced. These variables can take only values 0 or 1.
Here, W and H are maximum allowable width and height of the layout region and (x i ,y i ) and (x j ,y j ) are the bottom left hand corner positions of blocks b i and b j respectively. The width and height of the blocks b i and b j are w i , h i and w j , h j as mentioned earlier.
2) Boundary Constraints:
To ensure that the blocks lies within boundary of the floorplanning region the following constraints are used:
3) The objective function: Since the target of the problem is to minimize the area of the floorplanning region, the objective function is formulated as : minimize: c + d where (c,d) is the top right hand corner position of the floorplanning region and the lower left hand corner position is considered to be (0,0).
Example:
As an example let us consider 5 rigid or hard blocks with fixed width and height (10,15), (8,6), (9,5), (9,7), (7, 8) respectively. To place these blocks we have used the non-overlapping and boundary constraints as mentioned above. Our objective is to place the blocks within the layout region at the same time minimizing the total area. The result after placement of the blocks after applying our technique is represented in the following Figure 1 . Add boundary constraint 4: end for 5: for i= 1 to n do 6: for j= 1 to n do 7: if i ! = j then 8:
Add non-overlapping constraint 9: for block i and j 10: 
B. Case-2: Floorplanning with blocks which can rotate
Given two rectangular hard blocks b i and b j where b i is of height h i and width w i and b j is of height h j and width w j , our target is to place the blocks within a floorplanning region whose bottom left hand corner position is assumed to be (0,0) and top right hand corner position is assumed to be (c,d), such that they do not overlap and at the same time area of the layout is minimized. For the second category blocks have additional condition of rotation. The blocks can rotate by 90 0 .
1) Non-Overlap Constraints: Two blocks i, j are said to be non overlapping if at least one of the following cases is satisfied [5] . Here, one additional Boolean variable z i is used to enable change in orientation of the block where z i = 1 when the module is rotated by 90 0 and z i = 0 when placed in its initial orientation.
Here, M = maximum of W or H mentioned earlier.
2) Boundary Constraints: To ensure that the block lies within boundary of the floorplanning region the following constraints are used: 
3) The objective function: In this case also the target of the problem is to minimize the area of the floorplanning region, the objective function is formulated as : minimize: c + d
As an example we have considered the same 5 rigid or hard blocks with fixed width and height taken earlier. After applying our method the result improved as depicted in Figure 2 .
C. Case-3 : Floorplanning with soft blocks
Given two blocks of fixed area A i and A j respectively. The width and height of the blocks (w i , h i ) and (w j , h j ) may vary. Our target is to place the blocks within a floorplanning region whose bottom left hand corner position is assumed to be (0,0) and top right hand corner position is assumed to be (c,d), such that they do not overlap and at the same time area of the layout is minimized.
1) Constraints: The non-overlap constraints and boundary constraints are used which are same as in Case-2. Apart from these constraints additional constraint are used is as follows:
To maintain the shape of the blocks we have used an aspect ratio range of [0.1,10]. As an example we have considered the same 5 flexible blocks with fixed area of 150, 48, 45, 63 and 56 units respectively. After applying our method the resulting placement of the blocks are depicted in Figure 3 .
III. EXPERIMENTAL RESULTS
We have implemented the proposed SMT based technique for floorplanning of fixed dimension blocks and run it on the standard MCNC benchmark circuits and the GSRC benchmark circuits. All experiments have been performed on a machine with 128 GB memory and operating system Cent-OS. Satisfiability Modulo Theory technique is used to find a floorplan with no overlapping and occupying minimal area.
Sixth International Symposium on Embedded Computing and System Design (ISED)
In Table I , we have given 5 MCNC benchmark circuits whose total area is calculated in mm 2 . In Table II , we have given the resultant area of the layout region for 3 GSRC benchmark circuits.
In Table III , we have given a comparison of our result with the results given in [2] for benchmark circuits, expressed as area occupied by the blocks. It can be seen that our technique gives better result in MCNC circuits ami33, xerox and GSRC benchmark circuits n30 and n50 and bears out our claim to be better. Figure 4 , 5 and 6 depict the resultant placement of the blocks for GSRC and MCNC benchmark circuits using rotation. It has been observed after performing the experiments that the results improved after applying rotation to the fixed blocks while no great improvement in result was being observed for flexible blocks.
IV. CONCLUSION
The proposed technique performs an important step in placing fixed blocks on a floorplanning region without over- lapping using the concept of Satisfiability Modulo Theory. Our technique is useful in floorplanning with realistic blocks whose width and height are fixed. The objective is to minimize the area of the floorplanning region so that chip area is best utilized. A SMT based solution provides an optimal solution to the problem after exploring all possibilities.
