Multi-Voltage and Level-Shifter Assignment Driven Floorplanning by Yu, Bei et al.
Multi-Voltage and Level-Shifter Assignment Driven Floorplanning
Bei Yu∗ , Sheqin Dong† and Satoshi GOTO‡
Abstract— As technology scales, low power design has be-
come a significant requirement for SOC designers. Among the
existing techniques, Multiple-Supply Voltage (MSV) is a pop-
ular and effective method to reduce both dynamic and static
power. Besides, level shifters consume area and delay, and
should be considered during floorplanning. In this paper, we
present a new floorplanning system, called MVLSAF, to solve
multi-voltage and level shifter assignment problem. We use a
convex cost network flow algorithm to assign arbitrary number
of legal working voltages and a minimum cost flow algorithm
to handle level-shifter assignment. The experimental results
show MVLSAF is effective.
Index Terms—Voltage-Island, Multi-Voltage As-
signment, Level Shifter Assignment, Floorplanning
I. INTRODUCTION
As technology scales, low power design has become a sig-
nificant requirement for system-on-chip designers. Many
techniques were introduced to deal with power optimiza-
tion. Among the existing techniques, Multiple-Supply Voltage
(MSV) is one of the most effective methods for both dynamic
and static power reduction while maintaining performance. In
the MSV design, one of the most important problem is volt-
age assignment: timing critical modules are assigned to higher
voltage while noncritical modules are assigned to lower volt-
age, so the power can be saved without degrading the overall
circuit performance.
There are a number of previous works addressing volt-
age assignment in floorplanning. Among these works, volt-
age assignment is considered at various stages, including pre-
floorplanning[4, 5]; during floorplanning[6, 7, 8, 9]; and post-
floorplaning[10, 11, 12].
Level-shifter [1] has to be inserted to an interconnect when
a lower voltage module drives a higher voltage module or a
circuit may suffer from excessive short-circuit current energy.
From [5, 9] we can observe that the number and the area of
level shifters can not be ignored when modules increase. As a
result, level-shifters may cause performance and area overhead,
and should be considered during floorplanning. Accordingly,
MSV aware floorplanning includes two major problems: volt-
age assignment and level shifter assignment, which make the
design process much more complicated.
∗Bei Yu is with the Department of Computer Science and
Technology, Tsinghua University, Beijing, China 100084 (e-mail:
disyulei@gmail.com)
†Sheqin Dong is with the Department of Computer Science and
Technology, Tsinghua University, Beijing, China 100084 (e-mail:
dongsq@mail.tsinghua.edu.cn)
‡Satoshi GOTO is with the Graduate School of IPS, Waseda
University, Kitakyushu, Japan 808-0135
Lee et al.[5] handle voltage assignment by dynamic pro-
gramming, and level shifters are inserted as soft blocks. An
approach based on ILP is used in [11] for voltage assignment
at the post-floorplanning stage. To make use of physical in-
formation among modules during floorplanning, Ma et al.[8]
transform voltage assignment problem into a convex cost net-
work flow problem. However, their approach consider neither
level-shifters’ area overhead nor level-shifters’ physical infoma-
tion.
Yu et al.[9] use a convex cost network flow algorithm to
assign voltage and a minimum cost flow algorithm to han-
dle level-shifter assignment which considers level-shifters’ po-
sitions and areas. However, their work can only assign two
legal working voltages. Besides, level shifters are assumed to
be soft modules and ratios can not controlled well.
In this paper, we propose a new floorplanning system MVL-
SAF, which is extended from [9]. At floorplanning phase, we
use: a convex cost network flow algorithm to assign multi-
voltages; a minimum cost flow algorithm with more accurate
model to assign level shifters.
The remainder of this paper is organized as follows. Sec-
tion 2 defines the voltage-island driven floorplanning problem.
Section 3 presents our algorithm flow. Section 4 reports our
experimental results. At last, Section 5 concludes this paper.
II. PROBLEM FORMULATION
Definition 1 (DP-Curve). The power-delay trade-
off of each module is represented by a DP-Curve
{(d1, p1), (d2, p2), . . . , (dk, pk)}, where each pair (di, pi)
is the corresponding delay and power consumption when
module is operated at voltage vi(Fig.1(a)).
We assume that power is a convex function of delay when
each point (di, pi) is connected to its neighboring point(s) by
a linear segment in the DP Curve. Besides, each level shifter
has its own DP-Curve ((di, pi) is delay and power consumption
when it is driving voltage i). Lower voltage module needs
bigger level shifter to drive other modules. Since bigger level
shifter consumes more delay and power, we assume the level
shifter’s DP-Curve is also convex(as shown if Fig.1(b)). We
extend the problem in [9] to Multi-Voltage and Level-Shifter
Assignment driven Floorplanning (MVLSAF):
Problem 1. (MVLSAF) We are given following input to gen-
erate floorplanning result: minimize the area, power cost and
wirelength; satisfying timing constraint; insert all the level-
shifters in need.
1) A set of modules, each module has its DP–curve.
2) A netlist Gˆ = (Vˆ , Eˆ) and timing constraint Tcycle.
3) Level-shifter’s area, ratio and DP-Curve.
4) Number of legal working voltage k.
ar
X
iv
:1
40
2.
28
94
v1
  [
cs
.A
R]
  1
2 F
eb
 20
14
Delay
Pow
er
Delay
Pow
er
dls3
Pls3
(d1,p1)
(d3,p3)
(d1,p1)
(d2+dls2,p2+Pls2)
(a) (b)
(d2,p2)
Delay
(d3+dls3,p3+Pls3)
Pow
er
(dls3,Pls3)
(dls2,Pls2)
(c) .
Fig. 1. Delay Power Curve of (a)module with three legal voltages; (b)corresponding level shifter. (c)modified DP-Curve of module.
s
I1
I2
O1
O2
I3 O3 t
(a)
s
I1
I2
O1
O2
I3 O3 t
(b)
Fig. 2. (a)G¯ = {V¯ , E¯}, after adding nodes s, t and diving nodes
Ni into Ii and Oi (b)Transformed G¯ = {V,E} by adding edge
e(s¯, t¯) to remove constraint µt − µs ≤ Tcycle in equation (1).
III. ALGORITHM of MVLSAF
Our work is similar to that presented in [9], in which a
two phases framework is presented to deal with voltages and
level-shifters assignment during floorplanning. However, our
approach differs from [9] in the following ways: during volt-
age assignment, we support arbitrary number of legal voltages
allowing further power reductions in certain applications; dur-
ing level-shifter assignment, we adopt more accurate model to
calculate possible level-shifter number in white space, which
control level shifter under certain H/W ratio.
A. Multi-Voltages Assignment
To take consumption of level-shifter into consider, for each
module, we modify its DP-Curve: replace each pair (di, pi) by
(di + d
i
ls, pi + p
i
ls), where (d
i
ls, p
i
ls) islevel shifter’s delay and
power consumption. Modified DP-Curve is shown in Fig.1(c).
LEMMA 1. f(x) is convex ⇐⇒ f(x1 + x2) < f(x1)+f(x2)2 ,
∀x1, x2 ∈ Z.
LEMMA 2. If f(x) and g(x) are convex, then P (x) = f(x)+
g(x) is also convex.
THEOREM 1. Modified DP-Curve is piecewise linear convex
function with integer breakpoints, and we can apply convex cost
flow algorithm to solve voltage assignment problem[3].
Given netlist Gˆ, we translate it into G¯ = (V¯ , E¯)(adding
start node s and end node t, dividing each node ni ∈ Gˆ
into 2 nodes Ii and Oi, as shown in Fig.2(a)). So V¯ =
{s, t, I1, O1, I2, O2, . . . , Im, Om}. And Ii is connected to Oi
by a directed edge. We denote these new created edges
{e(Ii, Oi)|Ii, Oi ∈ V¯ } as E¯1, denote edges {e(s, Ik)|Ik ∈ V¯ }
as E¯3, and other edges as E¯2, and E¯ = E¯1 ∪ E¯2 ∪ E¯3.
The mathematical program of voltage assignment is in
(1),where dij is delay from node i to node j.
Minimize
∑
e(i,j)∈E¯
Pij(dij) (1)
s.t.

µj − µi ≥ dij ∀e(i, j) ∈ E¯ (1a)
µt − µs ≤ Tcycle (1b)
dij ∈ {d1ij , d2ij , . . . , dkij} ∀e(i, j) ∈ E¯1 (1c)
dij = delayij ∀e(i, j) ∈ E¯2 (1d)
dij = 0 ∀e(i, j) ∈ E¯3 (1e)
We can incorporate constraints (1b) and (1a) by transform-
ing (1b) into µs − µt ≥ −Tcycle, and define dst, s.t. µt − µs =
dst & dst ≤ Tcycle. Accordingly, E¯3 = {E¯3 ∪ e(s, t)}, and
the transformed DAG G¯ is shown in Fig.2(b). Besides, we
dualize the constraints (1a) using a nonnegative Lagrangian
multiplier vector x¯, obtaining the following Lagrangian sub-
problem:
L(~x) = min
∑
e(i,j)∈E¯
[Pij(dij) + xijdij ] (2)
We define function Hij(xij) for each e(i, j) ∈ E as follows:
Hij(xij) = mindij{Pij(dij) + xijdij} (3)
THEOREM 2. The function Hij(xij) is a piecewise linear
concave function of xij, and ∀e(i, j) ∈ E1, Hij(xij) is de-
scribed in the following manner:
Hij(xij) =

Pij(d
k
ij) + d
k
ijxij 0 ≤ xij ≤ bij(k)
. . .
Pij(d
q
ij) + d
q
ijxij 0 ≤ xij ≤ bij(q)
. . .
Pij(d
1
ij) + d
1
ijxij k ≤ xij
(4)
where bij(q) =
Pij(d
q−1
ij
)−Pij(dqij)
d
q
ij
−dq−1
ij
.
To transform the problem into a minimum cost flow prob-
lem, we construct an expanded network G′ = (V ′, E′). There
are three kinds of edges to consider:
• e(i, j) in E1:we introduce k edges in G′, and the costs of
these edges are: −dkij ,−dk−1ij , . . .− d1ij ; upper capacities:
bij(k), bij(k − 1)− bij(k), bij(k − 2)− bij(k − 1), . . .M −
bij(2), where M is a huge confficient; lower capacities
are both 0.
TABLE I
Notation used in LS Assignment
rj Room containing module j
R Set of rooms, R = {r1, r2, . . . , rm}
LS Set of LSs, LS = {ls1, ls2, . . . , lsn}
pjk, k = 1, 2, 3 Three parts of white spaces in rj .
module
wmj
hmj hrj
wrj
(a)
module
(b)
Pj1
Pj1 Pj3
Pj2Pj2
Pj3
module
(c)
module
(d)
Fig. 3. (a)Area of pj1 is bigger than area of level shifter but is
too narrow to insert. (b)pj3 can merge with either pj1 or pj2. (c)If
pj3 merges with pj1, can insert only 5 level shifters. (d)If pj3
merges with pj2, can insert totally 6 level shifters.
• e(i, j) in E2: cost, lower and upper capacity is −dij , 0,
M.
• Edge in E3: two edges are introduced in G′, one with
cost, lower and upper capacity as (−Kj ,−M, 0),
another is (0, 0,M).
Using the cost-scaling algorithm, we can solve the minimum
cost flow problem in G′. For the residual network G(x∗) and
solve a shortest path problem to determine shortest path dis-
tance d(i) from node s to every other node. By implying that
µ(i) = d(i) and dij = µ(i)− µ(j) for each e(i, j) ∈ E1, we can
finally solve voltage assignment problem.
B. Level-shifters Assignment
After voltage assignment, each module is assigned a volt-
age, then the number of level shifters n is determined. In
level shifter assignment we carry out minimum cost flow algo-
rithm to try to assign every level-shifters one room. Compared
with [9], we present a more accurate model estimating possible
number of level shifters in white space to avoid too much ratio.
We construct a network graph G∗ = (V ∗, E∗), and then use
a min-cost max-flow algorithm to determine which room each
level shifter belong to.
• V ∗ = {s, t} ∪ LS ∪R.
• E∗ = {(s, lsi)|lsi ∈ LS} ∪ {(lsi, rj)|∀frij =
1} ∪ {(rj , t)|rj ∈ R}.
• Capacities:
C(s, lsi) = C(lsi, rj) = 1, C(rj , t) = NumLS(j).
• Cost: F (s, lsi) = 0, F (rj , t) = 0;F (lsi, rj) = Fij .
where frij =
{
1, if lsi can be inserted into rj
0, others
and Fij
can refer to [9].
The algorithm of NumLS(i), which accurately estimates
number of possible level shifters in white space, is shown in
Algorithm 1 NumLS(i)
1: Initialize pi1, pi2, pi3;
2: als ← area of level shifter;
3: if pi1 is too narrow then
4: areaof(pi1)← 0;
5: end if
6: if pi2 is too narrow then
7: areaof(pi2)← 0;
8: end if
9: if areaof(pi1) % als > areaof(pi2) % als then
10: pi1 ← pi1 ∪ pi3;
11: else
12: pi2 ← pi2 ∪ pi3;
13: end if
14: return bareaof(pi1)als c+ b
areaof(pi2)
als
c;
Algorithm 1. In room rj , white space is split into at most
three parts: pj1, pj2, pj3(as shown in Fig.3).
It can be shown that any flow in the network G∗ assigns level
shifters to white spaces. The minimum cost flow algorithm can
be run in polynomial time[3].
After level-shifter assignment, level shifters that can not be
assigned to any room are belong to set ELS. We use heuristic
method to assign level shifters in ELS, so more level shifters in
ELS, more ILO(Interconnect Length Overhead[9]). If white
space wsi is too narrow, then level shifters being assigned to
wsi are all belong to ELS. More accurate model we used
(Algorithm 1) can reduce the number of level shifters in ELS
and then reduces ILO.
IV. EXPERIMENTAL RESULTS
We implemented algorithm MVLSAF in the C++ pro-
gramming language and executed on a Linux machine with
a 3.0GHz CPU and 1GB Memory. Fig. 4 shows the experi-
mental results of the benchmarks n50 and n100.
We use CBL[2] to represent every floorplan generated. Be-
sides, all the multi-pin nets are decomposed into a set of
source-sink two-pin nets. Cost function in floorplanning is:
Φ = λAA + λWW + λPP + λRR + λNN , where A and W
represent the floorplan area and wire length; P represents the
total power consumption; R represents the power network re-
source; and N records the number of level shifters that can
not be assigned.
The previous work [9] is the recent one in handling floor-
planning problem considering voltage and level-shifter assign-
ment. We performed our algorithm MVLSAF and VLSAF in
[9] on the same test circuits, which are based on the GSRC
benchmarks adding power and delay specifications. For each
test circuit, we set k as 4, and run MVLSAF and VLSAF 5
times. Table II lists the average results. The column Power
Cost means the actual power consumption. When allowing
four legal working voltages, MVLSAF can save 8.5% power
while not deteriorating wirelength, dead space and run time.
The column ILO and the column LS Number show that us-
ing more accurate model in level shifter assignment, even level
shifters number increases 18.6% ILO does not increase.
TABLE II
The Comparison Between the VLSAF and the Previous Work [9]
Data Power Cost Wire Length w. LS LS Number ILO(%) White Space(%) Run Time(s)
[9] MVLSAF [9] MVLSAF [9] MVLSAF [9] MVLSAF [9] MVLSAF [9] MVLSAF
n10 189142 162794 15504 16474 9 11 0.37 0.12 10.96 11.54 3.36 3.96
n30 146483 138463 43265 45388 25 42 0.07 0.21 14.28 17.63 21.0 19.83
n50 143596 133564 94622 93296 114 151 0.28 0.50 22.63 22.95 41.37 49.35
n100 135607 120885 185382 181280 153 167 0.49 0.34 27.05 26.07 436.65 414.7
n200 129615 117538 349562 344111 203 248 0.44 0.46 36.35 34.84 1980.4 2036.4
n300 216554 206354 552616 568364 366 417 0.49 0.53 37.73 38.54 2384.3 2377.2
Avg 160166 146599 206825 208152 145 172 0.36 0.36 24.83 25.26 811.2 816.8
Diff - -8.5% - +0.6% - +18.6% - ± 0% - +1.7% - +0.7%
TABLE III
Experimental Results with More Legal Working Voltage
Data k
Power
Cost
Wire
Length
LS
Num
ILO
(%)
Dead
Space(%)
Run
Time(s)
Data k
Power
Cost
Wire
Length
LS
Num
ILO
(%)
Dead
Space(%)
Run
Time(s)
n10 2 189142 15341 9 0.10 10.21 3.05 n100 2 133775 178685 122 0.17 26.45 431.7
3 163352 16386 10 0.13 11.58 3.03 3 131394 180023 150 0.50 26.8 438.05
4 162794 16474 11 0.12 11.54 3.96 4 120885 181280 167 0.34 26.07 414.7
n30 2 146483 42591 25 0.1 15.0 21.5 n200 2 127044 344010 204 0.42 35.64 1955.8
3 139466 45103 42 0.32 15.85 20.82 3 112801 331627 242 0.55 35.44 1949.4
4 138463 45388 42 0.21 17.63 19.83 4 117538 344111 248 0.46 34.84 2036.4
n50 2 144489 93459 104 0.25 22.05 49.21 n300 2 223574 548502 321 0.23 37.88 2363.9
3 132199 94105 130 0.37 22.72 51.10 3 218636 556718 389 0.44 37.14 2390.2
4 133564 93296 151 0.50 22.95 49.35 4 206354 568364 417 0.53 38.54 2377.2
−100 0 100 200 300 400 500
0
50
100
150
200
250
300
350
400
450
500
sb0
sb1
sb2
sb3
sb4
sb5
sb6
sb7
sb8
sb9
sb10
sb11
sb12
sb13
sb14
sb15
sb16
sb17
sb18
sb19
sb20
sb21
sb22
sb23
sb24
sb25
sb26
sb27
sb28
sb29
sb30 sb31
sb32
sb33sb34
sb35
sb36
sb37
sb38
sb39
sb40
sb41
sb42
sb43
sb44
sb45
sb46
sb47
sb48
sb49
0 100 200 300 400 500
0
50
100
150
200
250
300
350
400
450
sb0
sb1
sb2
sb3
sb4
sb5
sb6
sb7
sb8
sb9
sb10
sb11
sb12
sb13
sb14
sb15
sb16
sb17
sb18
sb19
sb20
sb21
sb22 sb23sb24
sb25
sb26
sb27
sb28
sb29
sb30
sb31
sb32
sb33
sb34
sb35
sb36
sb37
sb38
sb39
sb40
sb41
sb42
sb43
sb44
sb45
sb46
sb47
sb48
sb49
sb50
sb51
sb52
sb53
sb54
sb55
sb56
sb57
sb58
sb59
sb60
sb61
sb62
sb63
sb64
sb65
sb66
sb67
sb68
sb69
sb70
sb71
sb72
sb73
sb74
sb75
sb76
sb77
sb78
sb79
sb80
sb81
sb82
sb83
sb84
sb85
sb86
sb87
sb88
sb89
sb90
sb91
sb92
sb93
sb94
sb95
sb96
sb97
sb98
sb99
Fig. 4. Experimental results of n50 and n100. Four legal working
voltages. Modules in the same voltage are nearly clustered
together to reduce the power-network resource, and level shifters
(small dark blocks) are inserted in white spaces.
In order to demonstrate the effectiveness of our approach,
we have done three sets of experiments in which the number
of legal working voltage for each module is set two, three and
four. The detailed results are listed in Table III.
V. CONCLUSIONS
We have extended framework in [9] to solve multi-voltage
and level shifter assignment problem: a convex cost network
flow algorithm to assign arbitrary number of legal working
voltages; a minimum cost flow algorithm to handle level shifter
assignment. Experimental results have shown that our frame-
work is effective in reducing power cost while considering level
shifters’ positions and areas.
References
[1] David Lackey, Paul Zuchowski and J. Cohn. Managing power
and performance for system-on- chip designs using voltage is-
lands. ICCAD, pages 195–202, 2002.
[2] Xianlong Hong, Sheqin Dong. Non-slicing floorplan and place-
ment using corner block list topological representation. IEEE
Transaction on CAS, 51:228–233, 2004.
[3] R.K. Ahuja, D.S. Hochbaum, and J.B. Orlin Solving the convex
cost integer dual network flow problem. Management Science,
49(7):950-964, 2003
[4] W.L.Hung, G.M.Link and J.Conner. Temperature-aware volt-
age islands architecting in system-on-chip design. ICCD, 2005.
[5] W.P.Lee and Y.W.Chang. Voltage island aware floorplanning
for power and timing optimization. ICCAD, pages 389–394,
2006.
[6] Q.Ma and F.Y.Young. Voltage Island-Driven Floorplanning.
ICCAD, pages 644–649, 2007.
[7] D.Sengupta and R.Saleh. Application-driven Floorplan-Aware
Voltage Island Design. DAC, pages 155–160, 2008.
[8] Q.Ma and F.Y.Young. Network flow-based power optimization
under timing constraints in MVS-driven floorplanning. ICCAD,
2008.
[9] Bei Yu, Sheqin Dong, Satoshi GOTO and Song Chen. Voltage-
Island Driven Floorplanning Considering Level-Shifter Posi-
tions. GLSVLSI, 2009.
[10] W.K.Mak and J.W.Chen. Voltage island generation under per-
formance requirement for soc designs. ASP DAC, 2007.
[11] W.P.Lee and Y.W.Chang. An ILP algorithm for post-
floorplanning voltage-island generation considering power-
network planning. ICCAD, pages 650–655, 2007.
[12] W.P.Lee, D.Marculescu and Y.W.Chang. Post-Floorplanning
Power/Ground Ring Synthesis for Multiple-Supply-Voltage De-
signs. ISPD, pages 5–12, 2009.
