Synthesis of Low-Power Digital Circuits Derived from Binary Decision
  Diagrams by Popel, Denis V.
ar
X
iv
:c
s/0
20
70
12
v1
  [
cs
.A
R]
  4
 Ju
l 2
00
2
Synthesis of Low-Power Digital Circuits
Derived from Binary Decision Diagrams
Denis V. Popel∗
Abstract — This paper introduces a novel method
for synthesizing digital circuits derived from Binary
Decision Diagrams (BDDs) that can yield to reduc-
tion in power dissipation. The power reduction is
achieved by decreasing the switching activity in a
circuit while paying close attention to information
measures as an optimization criterion.
We first present the technique of efficient BDD-
based computation of information measures which
are used to guide the power optimization proce-
dures. Using this technique, we have developed an
algorithm of BDD reordering which leads to reduc-
ing the power consumption of the circuits derived
from BDDs. Results produced by the synthesis on
the ISCAS benchmark circuits are very encouraging.
1 Introduction
With the progress in VLSI technologies and such
areas as portable computing and wireless commu-
nication, power dissipation is becoming critical fac-
tor of circuits design. Such consideration has re-
sulted in the growing need for minimizing power
consumption in today’s digital systems. Consider-
ing the impact of design strategies on power dissi-
pation, it is important to integrate the technology-
independent and technology-dependent stages. In
other words, logic specification should be closer to
the final topological structures and physical im-
plementation of circuit. To move in this direc-
tion, we address the problem of automatic syn-
thesizing transistor-level implementations starting
from technology-independent structures like BDDs.
BDD-based circuits, implemented as networks of
transistors, are of great interest to researchers as
they address the class of low-power dissipation cir-
cuits [1]. Concepts and techniques developed for
low-power dissipation circuits, and for circuits de-
rived from BDDs separately can therefore be used
concurrently in the study of VLSI circuits.
The dominant part of power dissipation in CMOS
circuits is the dynamic power dissipation [2], which
is directly proportional to the signal switching ac-
tivity (charging and discharging of load capaci-
tances of logic gates). The problem of estimat-
ing switching activity could be solved efficiently
if fast procedures for probabilities estimation are
∗Department of Computer Science, University of
Wollongong, Dubai Campus, P.O. Box 20183, Dubai,
U.A.E. E-mail: popel@ieee.org, Tel.: +9714 3954422,
Fax: +9714 3955622.
available. In our research, we modify the approach
proposed in [3] to compute probabilities based on
BDD. Probabilities are used for computing infor-
mation measures as characteristics of switching ac-
tivity. It is quite natural and useful to consider
switching activity in terms of information mea-
sures [4] and use entropy as a complexity charac-
teristic of the optimization process [5]. Thus, we
describe a new method of synthesizing circuits de-
rived from BDDs whose distinctive feature is the
use of entropy driven reordering of BDDs.
The paper is structured as follows. Section 2
explains the background. Section 3 describes the
technique of probability calculation and accurate
computing of information measures using BDDs.
We describe the applications of this technique to
low-power digital circuits design in Section 4 and
show case-study results on ISCAS benchmark cir-
cuits. The results obtained with the proposed tech-
nique are very promising and show that an average
of 14% saving was gained in power. We conclude
and open a discussion forum in Section 5.
2 Preliminaries and Assumptions
Consider logic representation of a digital circuit
in the form of Boolean function f treated as
the mapping Bn → Bm over the variable set
X = {x1, · · · , xn}, where B={0,1}. Here, n is the
number of variables (inputs), and m is the number
of functions (outputs).
2.1 Graph-based Representation
Binary Decision Diagrams (BDDs) have become
the advanced structures in CAD of integrated
circuits for representation and manipulation of
Boolean functions. BDD is a connected, directed
acyclic graph, where:
(i) each non-terminal node corresponds to Shan-
non expansion S of the function f with re-
spect to variable x (incoming edge) into sub-
functions (outgoing edges: edgel and edger):
f = x · f|x=0 ∨ x · f|x=1;
(ii) a starting node is called root; a terminal node
is labeled with the leaf value and has no suc-
cessors; a non-terminal node has exactly two
successors.
A BDD is called ordered if the variable x appears
in the same order in each path from the root to a
terminal node. A BDD is called reduced if it does
not contain any nodes either with isomorthic sub-
graphs or with both edges pointing to the same
node. In our study, we always deal with reduced
ordered BDDs (here, simply BDDs).
2.2 Entropy and Conditional Entropy
In order to quantify the content of information for
a finite field of events A = {a1, a2, · · · , an} with
probabilities distribution {p(ai)}, i = 1, 2, · · · , n,
Shannon introduced the concept of entropy [6]:
H(A) = −
n∑
i=1
p(ai) · log p(ai), (1)
where log denotes the base 2 logarithm. For two
finite fields of events A and B with probability
distribution {p(ai)}, i = 1, 2, · · · , n, and {p(bj)},
j = 1, 2, · · · ,m, probability of the joint occurrence
of ai and bj is joint probability p(ai, bj), and there
is conditional probability, p(ai|bj) = p(ai, bj)/p(bj).
The conditional entropy of A given B is defined by
H(A|B) = −
n∑
i=1
m∑
j=1
p(ai, bj) · log p(ai|bj). (2)
In case of Boolean functions, we assume that the
sets of values of a function f and arbitrary variable
x are two finite fields [5]. We calculate the proba-
bility p|f=b = k|f=b/k, where k|f=b is the number of
assignments of values to variables for which f = b
and k is the total number of assignments. Other
probabilities are calculated in the same way.
Example 1 For the function f = x3 · x2 ∨ x1
with truth vector [10001111]: H(f) = −5/8 ·
log2(
5/8) −
3/8 · log2(
3/8) = 0.96 bit, H(f |x1) =
−1/8 · log2(
1/4)−
3/8 · log2(
3/4)−
4/8 · log2(
4/4)−
0 = 0.41 bit. By the same computations we have
H(f |x2) = 0.91 bit, H(f |x3) = 0.91 bit.
2.3 High-level Power Estimation
Very high power losses in CMOS circuits are dy-
namic losses related to gate switching [4]. The av-
erage power dissipated by the gate is given by
Pgate = 0.5 · C · V
2
DD · Sw, (3)
where C is the load capacitance, VDD is the supply
voltage, Sw is the switching activity. The power
dissipation of a circuit containing N gates can be
derived from Equation (3): P =
∑N
gate=1 Pgate. All
of the parameters can be determined from technol-
ogy or layout information except Sw, which de-
pends on both the function being performed and
the statistical properties of the inputs. Thus, by re-
ducing switching activity on the logic level, we can
decrease the power dissipation. The entropy char-
acterizes the uncertainty of a sequence of applied
vectors and thus is intuitively related to switching
activity. In [4] it is shown that the average switch-
ing activity is upper bounded by half of its entropy.
For an excellent review of high-level power estima-
tion methods, we refer to [7].
3 BDD Based Technique for Calculation of
Information Measures
The first step of calculation of information mea-
sures is to determine the probabilities of a Boolean
function and their sub-functions.
3.1 Probability
An attempt to compute the output probabilities us-
ing BDDs was proposed in [3], where an exact strat-
egy is described which is linear in the size of the
graph. In the case of completely specified Boolean
function f : p(x = 0) = p(x = 1) = 1/2, and
since each node of BDD is an instance of Shan-
non expansion, probability assignment algorithm
in a down-top fashion works as follows: p(f) =
1/2 · p(f|x=0) +
1/2 · p(f|x=1).
We have extended this approach consid-
ering p(leaf |f = 1) = 1 and p(leaf |f = 0) = 0,
and output probability p(f = 1) =p(root) and
p(f = 0) =1− p(root). For generalization the com-
ing next recursive algorithm is proposed:
p(node) = p(x = 0) · p(edgel) + p(x = 1) · p(edger).
This algorithm allows to calculate conditional and
joint probabilities for computing conditional en-
tropy according to Equation (2). Thus, for joint
probability p(f = 1, x = 1) it is needed to set
p(x = 1) = 1 and p(x = 0) = 0 before BDD traver-
sal. Such approach allowed us to develop a tech-
nique for calculating the whole range of probabili-
ties using only one BDD traversal.
Example 2 Down-top approach with assigning
p(leaf |f = 1) = 1 for the function f from Exam-
ple 1 gives us p(f = 1) = p(root) = 0.625, as shown
in Figure 1(a). The results of setting p(x2 = 0) = 1
give us conditional probability p(f = 1|x2 = 0) =
0.75.

x1
(a)  (b)
f


x3  x3
0
x2

x1 x1
p( f |x3=0,x2=0=1)=1

x2
f


x3 x3
S
0
S

x2
x2
S

x1
x1
1
down-top
f


x1
S
0
S

x2  x2
S

x3  x3
1

p( f |x3=0=1)=0.75
p( f=1)=0.625
p( f |x3=1=1)=0.5
H( f |x1)=0.81
H( f |x1x2 )=0.25


Figure 1: Calculation of probabilities
3.2 Information Measures
In [8] an algorithm was proposed based on symbolic
computations for exactly determining the entropies
of digital circuits. It was reported that the tech-
nique is viable, as proved by the results obtained
on a large set of mid-scale functions. This exact
approach breaks down when applied to large exam-
ples. Our technique for exact computation of infor-
mation measures for Boolean functions represented
in the form of BDDs exploits the following. Equa-
tion (1) is used for computing the entropy H(f) of
the function f together with the described above al-
gorithm for calculation of output probabilities. The
conditional entropy H(f |x) of the function f with
respect to the variable x can be simplified using the
statement below:
H(f |x) = p(x = 0) ·H(f|x=0)+p(x = 1) ·H(f|x=1) (4)
It means that entropy of all sub-functions are
needed to calculate conditional entropy.
Example 3 The conditional entropy of the func-
tion f from Example 1 given x2 be: H(f |x2) =
1/2 ·
H(f|x2=0)+
1/2 ·H(f|x2=1) = 0.41+ 0.5 = 0.91 bit.
The same manipulation yields: H(f |x1) = 0.41 bit
and H(f |x3) = 0.91 bit. The conditional entropy
of the function f given a set of variables {x1, x2}
be: H(f |x1x2) = 0.25 bit.
4 Low-power Synthesis of Circuits Derived
from BDDs: Case Study
We have observed that the energy dissipation of a
CMOS circuit is directly related to the switching
activity. We take into consideration the following
assumptions: (i) the only capacitance in a logic-
gate is at the output node of the gate; (ii) either
current is flowing through some path from VDD to
the output capacitor, or current is flowing from the
output capacitor to ground. During the design of
Input BDD for the given function f
Output New order of the variables
InfoR(f)
{
for (∀level : level = 1 . . . n ) {
for (∀x of the level ≥ level) {
Calculate p(f = 1|x = 0) and p(f = 1|x = 1);
Calculate H(f |xi) using Equation (4);}
Reorder variables according to
Equation (5): H(f |xj1) ≤ . . . ≤ H(f |xjn);
Rebuild BDD using xj1 for current level;}
}
Figure 2: The sketch of the algorithm InfoR
BDD we are trying to minimize the switching ac-
tivity for each level.
The criterion to choose a decomposition variable
x for the arbitrary level of BDD is that the condi-
tional entropy of the function with respect to this
variable has to be minimal:
H(f |x) = min(H(f |xi) | ∀ xi). (5)
Example 4 According to the criterion (Equa-
tion (5)) and the values of conditional entropy (Ex-
ample 3), the order of variables in BDD for the
function f will be < x1x2x3 > (Figure 1(b)). The
power dissipated by circuits
Variables’ order P , µW
< x1x2x3 >, or < x1x3x2 > 31.87
< x2x1x3 >, or < x3x1x2 > 45.0
< x3x2x1 >, or < x2x3x1 > 37.50
The power consumption for best case is 1.5 times
smaller than for the worst case taking into account
the same size of BDDs for both cases.
4.1 BDD Reordering Algorithm
Our algorithm for generating new order for lower-
power design of BDD for a given Boolean function is
a recursive heuristic which proceeds level by level
(Figure 2). The variables are arranged in order
from the the most significant (top level) to the least
significant (bottom level) taking into consideration
the information criterion (Equation (5)).
4.2 Experiments
We have implemented our technique for calcula-
tion of information measures within CUDD pack-
age1, using SIS2 as an environment for modelling
1F. Somenzi, CUDD: University of Colorado Decision
Diagrams Package
2SIS Release 1.2., UC Berkeley, 1994. The power was
estimated by executing procedure power estimate (zero delay
model) by the power estimator available in SIS at 20MHz.


BDD
circuit.blifOther
reordering
methods
circuit.dd.blif
derivedfrom
BDD
CUDD

Entropy

reordering
algorithm
SIS Power
consumption
Power
estimation
Buildinitial
BDD


Figure 3: Evaluation flow
Power [µW]
Test Window Genetic Sifting InfoR
C17 125 125 125 105
C1908 - - - 80583
C432 25860 25860 25860 28470
S1238 30268 30268 30268 19643
S1423 - - - 87082
S27 182 182 182 162
S298 1688 1688 1688 1363
S349 2865 2865 2345 2899
S526 3216 3216 3216 2395
S713 18215 18215 18215 15341
S953 18464 18464 18464 15661
Table 1: Power dissipation
of power dissipation. We have run experiments on
benchmarks (combinational and sequential circuits)
selected from the ISCAS suites on Pentium III
650Mhz with 64Mb. Our experiments have been
performed according to the flow on Figure 3.
In Table 1, we report the results of experiments,
where BDDs have been built for circuits using dif-
ferent reordering approaches (window, genetic, sift-
ing and our InfoR). Results show that power dissi-
pation for the circuits derived from BDD reordered
by InfoR method are on an average 14% better
than the corresponding circuits derived from BDD
with utilization other reordering methods.
5 Concluding Remarks and Discussion
We have presented a complete synthesis flow for the
low-power circuits derived from BDDs. The pro-
posed technique features a novel BDD reordering
algorithm based on information theoretic measures.
We have considered a proper criterion for BDD re-
ordering which leads to minimal power consump-
tion.
5.1 CMOS Implementation
The tabulated results for CMOS implementation
shown above indicate that BDD reordering using
information measures yields the best characteristics
in terms of power dissipation for some circuits de-
rived from these BDDs. Experimental results have
confirmed the effectiveness of the proposed tech-
nique; in fact, the synthesized circuits have proven
to be superior with an average of 14% to circuits
obtained using other reordering methods.
5.2 nMOS Implementation
For many circuits specifications, implementation in
Pass-Transistor Logic (PTL) has been shown to
be superior in terms of area, timing, and power
to static CMOS. BDDs have been used for PTL
synthesis because of similarity between BDDs and
PTL [1]. Our future direction is to develop the
methods of low-power PTL circuits design.
Acknowledgements
Partial support from the University of Wollon-
gong (AUSTRALIA) and Technical University of
Szczecin (POLAND) is acknowledged.
References
[1] R. Mehrotra, M. Pedram, and X. Wu. Compar-
ison between nMOS pass transistor logic style
vs. CMOS complementary cells. In Proc. IEEE
International Conference on Computer Design
- ICCD’97, 1997.
[2] F. Najm. A survey of power estimation tech-
niques in VLSI. IEEE Trans. on VLSI Systems,
2(4):446–455, 1994.
[3] D. Miller. An improved method for computing
a generalized spectral coefficient. IEEE Trans.
on CAD of Integrated Circuits and Systems,
17(3):233–238, 1998.
[4] D. Marculescu, R. Marculesku, and M. Pedram.
Information theoretic measures for power analy-
sis. IEEE Trans. on CAD of Integrated Circuits
and Systems, 15(6):599–610, 1996.
[5] D. Popel. Information Theoretic Approach to
Logic Functions Minimization. PhD thesis,
Technical University of Szczecin, Poland, 2000.
[6] C. Shannon. A mathematical theory of commu-
nication. Bell Syst. Tech. J., 27:379–423, 623–
656, 1948.
[7] M. Nemani and F. Najm. Towards a high-level
power estimation capability. IEEE Trans. on
CAD, 15(6):588–598, 1996.
[8] E. Macii and M. Poncino. Exact computation
of the entropy of a logic circuit. In Proc. Great
Lakes Symp. on VLSI, pages 162–167, 1996.
