Efficient Mathematical Model on VLSI Circuit Partitioning

R. Manikandan, Jaladhanki Sindura, M.D.L. SriRavali and P. Swaminathan
Department of ICT, School of Computing, SASTRA University, Thanjavur-613401, India

Abstract: With the advancement of technology, there is need to develop alternative approaches to classical problems. After powerful mathematical modeling of new approach to classical problems, it is necessary to verify and validate the modeling by well formed experiments. One such area of interest is VLSI Design issue, in particular, Circuit Partitioning. In this study, we address the problem partitioning in VLSI design and layout. After reviewing earlier methods, we present an alternative mathematical model on VLSI circuit partitioning. This is our new direction and with this aim two or more number of research articles contributed by us which in comparison with other algorithms lead to research survey article.

Key words: Circuit partitioning, graph theoretical algorithms, partitioning and mathematical model

INTRODUCTION

Partitioning is a technique to divide a circuit or system into a collection of smaller parts (components). It is on one hand a design task to break a large system into pieces to be implemented on separate interacting components and on the other hand it serves as an algorithmic method to solve difficult and complex combinatorial optimization problems as in logic or layout synthesis.

Partitioning has been an active area of research for at least a quarter of a century. The main reason that partitioning has become a central and sometimes critical design task today is the enormous increase of system complexity in the past and the expected further advances of microelectronic system design and fabrication.

The size of VLSI designs has increased to systems of hundreds of millions of transistors. The complexity of the circuit has become so high that it is very difficult to design and simulate the whole system without decomposing it into sets of smaller subsystems. This divide and conquer strategy relies on partitioning to manipulate the whole system into hierarchical tree structure. In this study, we unify different techniques and problem specific perspectives so far undertaken by researchers in this field. We wish to add that earlier methods fail to address uncertainty inherent in the problem specification and procedure adopted for solution. Even though there are recently developed mathematical models which do not address completely required precision. Thus, we have developed efficient hypergraph mathematical model to solve such VLSI Design issue.

EXISTING MODELS

The main problem of portioning in VLSI Design and other related domain of study can be placed as getting sub domain of vertices in a given hyper graph. Earliest researchers like Kernighan-Lin (KL) and Fiduccia-Mattheyses (Alpert and Khang, 1996; Alpert et al., 1997; Bui and Jones, 1993) have given algorithms of iterative refinement on the specific nodes of relative importance. Some have placed the problems in searching for Max-Min cut on graphical representation of the design. In a study on hyper graph and co processor design, an approach is made to give a probability algorithm through Markov chain in which additional model for a FPGA layout is suggested using SAT Problem. The reduction in complexity is tackled through SAT Problem. (Thiyagarajan and Manikandan, 2011)

Graph partitioning play an important role in Circuit design and testing. The objective is to divide the circuits into blocks such that the components fall within prescribed sizes. The complexity of the connection between these component is reduced. Controlling of cut size for various types of graph have been studied by (Hendrickson and Leland, 1993; Karypis and Kumar, 1995). Multilevel algorithms compare spectral methods and parallel formulation for such sequential circuit partitioning. Delay minimization of VLSI circuits have been studied through global clustering and connectivity information (Yang and Wong, 1995). Prim’s algorithm can complete an optimal solution if node duplication is allowed in circuit design.

(Somasundaram, 2007) has given multilevel sequential circuit partitioning for delay minimization of VLSI circuit using special type of K-Partitioning algorithm and as achieved bench mark circuits. Any given...
partitioning problem is to decompose given circuit into $K$ blocks and for given $K$ with balanced area. Circuit delay is a measure as the longest combinatorial for delay from premier input of flip flop output to a premier output or flip of input. Researchers have an objective to perform multilevel partitioning with retiming for minimum delay in reducing cut size as much as possible.

**PROPOSED MODEL**

Consider a hypergraph $G (V, E)$. Given that function $f_v$ and $f_w$ (weight of each part) exist, and given an integer $k > 1$ and a real-valued balance criterion $0 < \epsilon < 1$, the goal is to find a partition $\Pi = \{P_1, \ldots, P_k\}$, with corresponding part weights $W_i = f_w(P_i), 1 \leq i \leq k$ such that:

$$W_i < (1 + \epsilon)W_{avg}$$

where

$$W_{avg} = \frac{1}{k} \sum_{i=1}^{k} W_i$$

and $f_v(\Pi, \epsilon)$ is optimized. (Aleksandar, 2006)

**Step 1:** Input the number of vertices to be considered, $N$.

**Step 2:** List the respective adjacent nodes for each vertex to form an adjacency matrix and their weights, $W_i$

**Step 3:** Consider a balance factor $b$, whose value lies between 0 and 1. And, input the number of partitions to be divided, $k$.

**Step 4:** Calculate the average weight of all the nodes, $W_{avg}$

**Step 5:** The adjacent nodes are classified into a partition till they satisfy the condition $W_i < (1 + \epsilon) W_{avg}$ and rest are classified into other partitions based on the same condition.

For example, consider the above graph with 6 vertices. Adjacency matrix for this graph is:

<table>
<thead>
<tr>
<th>Vertex</th>
<th>Adjacent nodes</th>
</tr>
</thead>
<tbody>
<tr>
<td>A</td>
<td>b, c</td>
</tr>
<tr>
<td>B</td>
<td>a, c</td>
</tr>
<tr>
<td>C</td>
<td>b, d</td>
</tr>
<tr>
<td>D</td>
<td>c, f</td>
</tr>
<tr>
<td>E</td>
<td>a, f</td>
</tr>
<tr>
<td>F</td>
<td>e, d</td>
</tr>
</tbody>
</table>

Weights of each vertex are considered as: 2, 1, 3, 2, 3, 1
Then weight average, $W_{avg}$ is: 2.
Consider the balance factor as: 0.5. Then, condition becomes $W_i < 3$.
When the number of partitions is considered to be 4, then nodes:
a, b come under partition 1,
e comes under partition 2,
c comes under partition 3,
d, f come under partition 4.

**CONCLUSION**

This model partitions the graph in a simple and easy way. It only considers weights of the nodes based on which the partitioning is done. By adjusting the balance factor we get more optimized results of partitioning. In future, the circuit partitioning may lead strong conjecture in major VLSI Design issue.

**REFERENCES**


