FUZZIFIED SIMULATED EVOLUTION ALGORITHM FOR MULTI-OBJECTIVE OPTIMIZATION OF COMBINATIONAL LOGIC CIRCUITS by Sait, Sadiq M. et al.
FUZZIFIED SIMULATED EVOLUTION ALGORITHM FOR MULTI-OBJECTIVE
OPTIMIZATION OF COMBINATIONAL LOGIC CIRCUITS
Sadiq M. Sait, Mostafa Abd-El-Barr, Uthman Al-Saiari and Bambang A. B. Sarif
Computer Engineering Department
KFUPM Box 673, Dhahran-31261, Saudi Arabia
 sadiq, mostafa, saiarios, sarif@ccse.kfupm.edu.sa
ABSTRACT
In this paper, we employ fuzzified Simulated Evolution (SimE)
Algorithm for combinational logic design. SimE algorithm
consists of three steps: evaluation, selection and allocation.
Multilevel Logic Based Goodness measure is designed to
guide the selection and allocation operations of SimE. Area,
power and delay are considered in the optimization of cir-
cuits. The performance of the proposed algorithm is evalu-
ated using selected ISCAS’85 benchmark circuits. The re-
sults obtained are compared to those obtained using SIS.
1. INTRODUCTION
Design of logic circuits requires knowledge of a large col-
lection of domain-specific rules. The process of implement-
ing a logic circuit in hardware involves transforming the
original specification into a form suitable for the target tech-
nology, optimizing the representation with respect to a num-
ber of user defined objectives and constraints (i.e., timing,
fan-in/out, power, etc.), and finally carrying out technology
mapping onto the target technology [1].
In designing a complex system, circuit designers usually
have to tradeoff one design objective for another. For exam-
ple, often a designer tries to find a possibly faster circuit
compared to a previously designed one. However, the num-
ber of gates used and power dissipation are strongly related
to delay. Thus, in seeking a faster circuit, the designer may
end up having a complex system or a system that has higher
power dissipation. Logic synthesis attempts to provide an
answer to this problem. The purpose of a logic synthesis
tool is to aid circuit designers reaching an optimal tradeoff.
Several logic synthesis algorithms are found in the litera-
ture [2].
Evolutionary algorithms allow designers to define the
search space of circuit design in a way that is natural to both
the problem and the implementation. These algorithms have
the tendency to search for a solution to the circuit design
problem in a much larger, and often richer, design space
beyond the realms of the conventional design tools. It is
therefore possible to use evolutionary algorithms to obtain
novel designs that are difficult to discover by conventional
heuristics [3].
In this paper, fuzzified Simulated Evolution (SimE) al-
gorithm for combinational logic design targeting area, power
and delay optimization is proposed. The results from the
fuzzified Simulated Evolution (SimE) algorithm using se-
lected ISCAS’85 benchmark circuits are compared to the
results obtained by a conventional logic design technique
using SIS synthesis tool [4].
2. PROPOSED SIMULATED EVOLUTION
The SimE algorithm is a general search strategy for solv-
ing a variety of combinatorial optimization problems. It
starts from an initial assignment, and then, following an
evolution-based approach, it seeks to reach better assign-
ments from one generation to the next. A goodness mea-
sure is used to guide the algorithm in its search [5].
Assume there are a set   of     distinct locations and a
set  of  elements of two inputs logic gates. SimE algo-
rithm proceeds as follows. Initially, a population 1 is created
at random. Therefore,     locations (cells) will be filled ran-
domly by different logic gates from  . The algorithm has
one main loop consisting of three basic steps, Evaluation,
Selection, and Allocation. The algorithm evaluates every
location (cell) of the set   using the new Multilevel Logic
Based Goodness Measure designed. Some cells will be se-
lected for reallocation (mutation) by the Selection step ac-
cording to their goodness values. Next, in Allocation step,
selected cells will be assigned different gate types in order
to improve their goodness. The three steps are executed in
sequence until the population average goodness reaches a
maximum value, or no noticeable improvement to the pop-
ulation goodness is observed after a number of iterations.
Another possible stopping criterion could be to run the al-
gorithm for a prefixed number of iterations. Figure 1 is an
1In SimE terminology, a population refers to a single solution. Individ-
uals of the population are componentsof the solution; they are the movable
elements.
ALGORITHM Simulated Evolution(E, ,L, Stopping-Criteria);
      ;
Repeat
 	  :
ForEach 
    Do 
 
 

 

 
EndForEach;
  :
ForEach 
    Do
If 
   
 
  
Then 

  

 
;
Else 

  

 
;
EndIf;
EndForEach;
Sort the elements of 

;
  :
ForEach 
   

Do 


 EndForEach;
Until Stopping-criteria are met;
Return ();
End Simulated Evolution.
Fig. 1. Simulated Evolution algorithm [5].
outline of the SimE algorithm and Figure 2 is a representa-
tion of the problem considered.
3. COST FUNCTION FORMULATION
The cost function or the fitness of a solution consists of two
parts: functional fitness and objective fitness.
3.1. Functional Fitness
The functional cost measure is the correctness of the ob-
tained logic circuit in matching the truth table of the re-
quired function. In this work, we propose functional cost
measure called Multilevel Logic Based Goodness Measure
and it is based on the multilevel logic synthesis. As an ex-
ample, if we have a 4 inputs circuits, it is represented by a 4
 4 matrix. Also, there are 16 outputs that should be gener-
ated correctly to get a functionally correct circuit. Initially,
these patterns are distributed among the levels of the circuit
evenly and progressively. Each column in the 4  4 matrix
should cover 4 outputs more than it’s previous column. If a
logic gate located at the second level (second column of the
matrix), it should cover 8 outputs. If the same logic gate is
located at the second level and it covers less than 8 outputs,
then it will be considered to have less goodness. Therefore,
the goodness of a gate is affected by the number of outputs
covered and the level where the gate is located. Figure 3
illustrates this goodness measure.
In general, for an  input circuit (   outputs), to have a
goodness of 1 at a cell in level , there should be   
correct patterns produced at this cell. Thus, the multilevel
logic goodness measure is formulated as follows:
1 2 k
K+1 2k
L2k
L locations
1 k2
2kK+1
n2k
Set of Logic gates (M)
consist of n elements
1 2 k
K+1 2k
L2k
Assign n’ elements selected from M
to L locations
Fig. 2. Representation of logic design problem.




 
 

where 

is the goodness of cell ,  is the level number or
column number,  is the number of inputs of the required
circuit and  is the number of matching patterns at the out-
put of cell  compared to the intended truth table.
3.2. Objective Fitness
The objective fitness (

) is a measure of the quality of solu-
tion in terms of optimization of area, delay and power con-
sumption. It contains two aspects: constraints satisfaction
and multi-objective optimization.
The cost for area of VLSI circuits is stated as follows.
	



 
   	



 (1)
Where 

 is the area of a gate 

.
The propagation delay of signals in a VLSI circuit con-
sists of two elements, switching delay of gates and intercon-
nect delay. If a path  consists of  gates 

 

  
 
,
then, the delay 

along  is expressed as



 
 
	

  



 	

 (2)
Where 	

is the switching delay of the cell driving gate


.  

is the load factor of the driving block, 

is the
Number of Minterms covered increases
16 Minterms should be covered for a 4
inputs circuit
4
Minterms
8
Minterms
12
Minterms
16
Minterms
Fig. 3. Multilevel logic goodness assumption.
interconnect resistance of net 

, and 	

is the load capac-
itance of cell  given by Equation 4. Since the value of 

at logic synthesis level is not known, it can be neglected or
estimated. The overall circuit delay is determined by the
delay along the longest path (the most critical path)as given
by Equation 3.
	


 


 (3)
The total capacitance 	

of gate  consists of the inter-
connect capacitance at the output node of gate  and the sum
of the capacitances of the input nodes of the gates driven by
gate .
	

 	



 
 

	


(4)
Where 	

is the capacitance of the input node of a gate 
driven by gate  and 	

represents the interconnect capaci-
tance at the output node of cell .
The total power consumption can be approximated by
the following equation [6].



 
 

 
	

 


   

  (5)
Where 

is the total power consumption, 

is the supply
voltage, 

is the switching probability at the output node of
cell , i.e., the average number of transitions per clock cycle
at the output of gate ,  is the clock frequency and  is a
technology dependent constant.
The cost of the overall power consumption in VLSI cir-
cuits can then be estimated as follows.
	



 
 


	

(6)
In this paper, fuzzy logic is used to represent the cost
function for area, delay and power. In order to build the
membership function, the lower bound and upper bound of
1
t
µ
µ
area
minimumarea targetarea

Fig. 4. Membership function for area as optimization ob-
jective
the cost function must be determined. In order to guide the
search intelligently, the maximum value must be carefully
estimated. For this purpose, SIS tool [4] is used to estimate
the minimum area and minimum delay of the target circuits.
The estimated lower bound of maximum area (called


) is associated with a specific degree of member-
ship called target membership (

). The shape of the
membership function is depicted in Figure 4.
The membership function for delay and power are built
using similar rules. These three membership functions will
be aggregated into one unit (the objective fitness) using or-
dered weighted average (OWA) operator [7].
4. EXPERIMENTS AND RESULTS
In this section, comparison of the proposed algorithm with
an existing conventional technique is given. For this pur-
pose, SIS is used. However, SIS does not consider capaci-
tance load in its delay calculation and does not have power
optimization. Therefore, the results obtained from SIS are
in the form of netlist file. These netlist files will be used as
input to the cost function calculation procedures of the pro-
posed algorithm to determine the area, delay and power of
the circuits. Both SIS and the proposed algorithm use the
same gate library.
Area Optimization: The results from SIS are the area opti-
mized circuits obtained by executing rugged.script mapped
for area minimization.
Table 1 shows the results for delay optimization for both
techniques. The table shows that the highest improvements
are obtained in the cost of cm82a and mul3 circuits by 58.3%
and 51.63 % respectively.
Delay Optimization: For delay optimization, the results
from SIS are obtained by executing delay.script mapped for
delay minimization. The test cases used are the same cir-
cuits used for area optimization.
Table 2 shows the results for delay optimization for both
techniques. It can be seen that the results obtained from
SIS Proposed Algorithm % ImprovementCircuit
Area Delay Power Area Delay Power Area Delay Power
mul2 18225 6.587026 5.561531 12636 3.56 4.66 44.23 84.98 19.35
mul3 112752 43.385843 37.745321 74358 13.14 21.65 51.63 230.23 74.38
cm42a 40824 8.864164 13.648234 40824 8.86 13.64 0.00 0.00 0.00
cm82a 39609 19.539984 14.879328 25029 11.84 9.24 58.3 64.98 61.12
b1 10206 3.225844 3.994219 11215 2.91 2.78 -8.93 10.85 43.68
c17 9963 3.559452 3.64207 9963 3.55 3.64 0.00 0.00 0.00
con1 31590 8.637996 11.21212 30233 6.90 14.23 4.49 25.19 -21.21
majority 14823 6.276723 5.405396 13851 4.57 5.06 7.02 37.32 6.93
Table 1. Comparison with SIS in area optimization
SIS Proposed Algorithm % ImprovementCircuit
Area Delay Power Area Delay Power Area Delay Power
mul2 25272 4.331142 7.157387 12636 3.56 4.66 100 21.66 53.59
mul3 174231 31.663494 47.161334 74358 13.14 21.65 51.63 230.23 74.38
cm42a 43740 8.46137 12.233066 40824 8.86 13.64 0 0 0
cm82a 64638 19.011371 18.936375 28552 9.34 9.1 38.73 109.21 63.51
b1 10206 3.225844 3.994219 11215 2.91 2.78 -8.93 10.85 43.68
c17 9963 3.559452 3.64207 9963 3.55 3.64 0 0 0
con1 31590 8.637996 11.21212 30233 6.9 14.23 4.49 25.19 -21.21
majority 14823 6.276723 5.405396 13851 4.57 5.06 7.02 37.32 6.93
Table 2. Comparison with SIS in delay optimization
SimE algorithm for area and delay optimization are the same
except cm82a improved in the delay with larger area. The
table shows that the highest improvements are obtained at
cm82a and mul3 circuits.
5. CONCLUSION
In this paper, the use of Simulated Evolution (SimE) algo-
rithm in logic design is being proposed. A goodness mea-
sure to guide SimE algorithm through the search space of
digital logic design is suggested. Comparison of the pro-
posed approach with SIS is shown. The proposed approach
has shown better results in most cases compared to SIS con-
sidering area optimization and delay optimization.
Acknowledgment: The authors would like to acknowledge
the support received from King Fahd University of Petroleum
& Minerals under project entitled “Iterative Heuristics for
the Design of Combinational Logic Circuits”.
6. REFERENCES
[1] J. F. Miller, D. Job, and Vassilev V. K., “Principles in
the Evolutionary Design of Digital Circuits - Part I,”
Journal of Genetic Programming and Evolvable Ma-
chines, vol. 1, no. 1, pp. 8–35, 2000.
[2] R. Brayton, G. D. Hachtel, C. T. McMullen, and A.L.
Sangiovanni-Vincentelli, Logic Minimisation Algo-
rithms for VLSI Synthesis, Kluwer Academic Publisher,
1984.
[3] J. F. Miller and P. Thomson, “A Developmental Method
for Growing Graphs and Circuits,” Fifth International
Conference on Evolvable Systems: From Biology to
Hardware, vol. 2606, pp. 93–104, Mar 2003.
[4] E. M. Sentovic, K. J. Singh, L. Lavagno, C. Moon,
R. Murgai, A. Saldanha, H. Savoj, P. R. Stephan, R. K.
Brayton, and A. L. Sangiovanni-Vincentelli, “SIS: A
System for Sequential Circuit Synthesis,” Technical
Report UCB/ERL M92/41, University of California,
Berkeley, May 1992.
[5] S. Sait and H. Youssef, Iterative Computer Algorithms
with Applications in Engineering: Solving Combinato-
rial Optimization Problems, IEEE, 1999.
[6] Srinivas Devadas and Sharad Malik, “A Survey of Op-
timization Techniques Targeting Low Power VLSI Cir-
cuits,” 32nd ACM/IEEE Design Automation Confer-
ence, 1995.
[7] Ronald R. Yager, “On Ordered Weighted Averaging
Aggregation Operators in Multicriteria Decision Mak-
ing,” IEEE Transaction on Systems, MAN, and Cyber-
netics, vol. 18, no. 1, January 1988.
