Missouri University of Science and Technology

Scholars' Mine
Electrical and Computer Engineering Faculty
Research & Creative Works

Electrical and Computer Engineering

01 Jan 2003

Evolving Digital Circuits Using Particle Swarm
Ganesh K. Venayagamoorthy
Missouri University of Science and Technology

Venu Gopal Gudise

Follow this and additional works at: https://scholarsmine.mst.edu/ele_comeng_facwork
Part of the Electrical and Computer Engineering Commons

Recommended Citation
G. K. Venayagamoorthy and V. G. Gudise, "Evolving Digital Circuits Using Particle Swarm," Proceedings of
the International Joint Conference on Neural Networks, 2003, Institute of Electrical and Electronics
Engineers (IEEE), Jan 2003.
The definitive version is available at https://doi.org/10.1109/IJCNN.2003.1223391

This Article - Conference proceedings is brought to you for free and open access by Scholars' Mine. It has been
accepted for inclusion in Electrical and Computer Engineering Faculty Research & Creative Works by an authorized
administrator of Scholars' Mine. This work is protected by U. S. Copyright Law. Unauthorized use including
reproduction for redistribution requires the permission of the copyright holder. For more information, please
contact scholarsmine@mst.edu.

Evolving Digital Circuits Using Particle Swarm
Venu G. Gudise and Ganesh K. Venayagamoorthy
Dept. of Electrical and Computer Engineering
University of Missouri - Rolla, USA.
ugggwb@umr.edu ondgkumor@ieee.org

Abstract --- Particle swarm optimization (F‘SO) motivated by the
social behavior of organisms is proposed for evolution of
combinational logic circuits. Results are presented to show that
PSO based evolution of digital circuits are equivalent to or even
with better solutions (with minimum number of logic gates) than
that of a human designer and other genetic algorithm (GA) based
techniques. This PSO based approach converges faster than
other approaches reported in literature using genetic algorithms
and as a result the computational intensity involved in hardware
evolution is reduced. Examples taken from the literature are used
to evaluate the performance of the proposed PSO approach.

I. INTRODUCTION
There are many methods to design combinational circuits.
Generally used methods are Kamaugh maps [I], QuineMcCluskey method [2]-[3] and Sasao method [4]. The
problem with the human designs is that they become
cumbersome and ,problematic when the number of inputs,
number of outputs, and complexity of the function increase.
The intricacy of the combinational circuit depends on the
number of gates in the circuit, and that of the gate depends on
the number of inputs to the gate. For real world applications,
Combinational circuits with a minimum number of gates are
preferred for simpler hardware realization.
In recent decades, algorithms that employ the principles
of Darwinian evolution have been applied to the design of
electronic systems [ 5 ] . Such work has become known as
Evolvable Hardware (EHW), and this field has matured
considerably in the last 3-6 years [6]. One of the goals of
EHW has been to evolve complex designs, not achievable
with the traditional design methods. This goal is still beyond
our reach. EHW is built on software-reconfigurable logic
devices, such as the programmable logic device (PLD) and the
field programmable gate array (FPGA), whose architecture
can be re-configured using an evolutionary tecbnique(s). This
reconfiguration can continue on-line to improve performance
adaptively [7]. To design conventional hardware, it is
necessary to know all the specifications of the hardware
functions in advance. In contrast to this, EHW can configure
itself without such specifications known in advance.
To date, hardware evolution has been reported using
genetic algorithms (GAS) [7] and recently, many papers have
proposed designing combinational circuits using genetic
algorithms [8-141. Genetic algorithms involve a population of
chromosomes that are mutated and the chromosomes with
greatest fitness survive over a number of generations. The
convergence of a genetic algorithm can take a large number of
generations and real-time implementation capability is still a
gray area.
0-7 803-7898-9/03/$17.OO 02003 IEEE

A new technique called the particle swarm optimization
(PSO) that emerges and allies itself to evolutionary
ofthe behavior o f a flock of
based on
birds or school offish, has proven to have great potential for
multi-objective optimization
algorithms differ
importantly in both
from evolutionary
and how they
What is new
with the Swarm algorithm is that the individuals @articles)
persist over time, influencing one another’s search of the
problem space, unlike in the genetic algorithms where the
weakest chromosomes are immediately discarded. The
particles in PSO (similar to chromosomes in GA) are known
to have fast convergence to local/global optimum position(s)
over a small number of iterations [16].
The design of combinational digital circuits using
particle swarm is presented and preliminary investigations
show that PSO can evolve equally well as genetic
algorithms and their variants [IO]. The paper is organized as
follows: Section 11, a brief overview of the particle swarm
optimization is given. Section Ill, evolving combinational
circuits with PSO is described. Section IV, examples of
swarm evolved combinational circuits are presented and
compared against other techniques.
11. PARTICLE SWARM OPTIMIZATION

Particle swarm optimization is an evolutionary
computation technique (a search method based on a natural
system) developed by Kennedy and Eberhart [I71 - [22].
PSO, like a generic algorithm (GA), is a population based
optimization tool. However, unlike GA, PSO has no
evolution operators such as crossover and mutation, and
moreover, PSO has less parameters. PSO is an evolutionary
algorithm that does not implement suryival of the fittest, and
unlike other evolutionary algorithms where an evolutionary
operator is manipulated, the velocity is dynamically
adjusted.
The system initially bas a population of random solutions.
Each potential solution, called aparticle, is given a random
velocity and is flown through the problem space. .The
particles have memory and each particle keeps track of its
previous best position (called the pbest) and its
corresponding fitness. There exist a number ofpbest for the
respective particles in the swarm and the particle with
greatest fitness is called the global best (gbest) of the
swarm. The basic concept of the PSO technique lies in
accelerating each particle towards its pbest and gbest
locations, with a random weighted acceleration at each time
step and this is illustrated in Fig. I , where 9 is the current

468

position of a particle, P'" is its modified position, V,i is its
initial velocity, Vmod is its modified velocity, Vphesris the
is the velocity
velocity considering itspbest location and V,
considering its gbest location.
Y

f

I

p.1

Pk

asynchronous updates. Vmar is the maximum allowable
velocity for the particles (i.e. in the case where the velocity
of the particle exceeds Vmm, then it is limited to Vmm).
Thus, resolution and fitness of search depends on Vmar. If
Vmar is too high, then particles will move beyond a good
solution, and if Vmm is too low, particles will be trapped in
local minima. The constants e l and c2 in (1) and (2),
termed as cognition and social components, respectively, are
the acceleration constants which changes the velocity of a
particle towards pbesi and gbest (generally, somewhere
between p b m and gbesr). The velocities of the particles
determine the tension in the swarm. A swarm of particles
can be used locally or globally in a search space. In the local
version of the PSO, ghesr is replaced with [best and the entire
process is the same.

YX

111. EVOLVING COMBINATIONAL CIRCUITS

Particle swarm theory described above is used to evolve
combinational logic circuits. The basic process of hardware
evolution is illustrated in Fig. 2. The "desired" circuit refers
The main steps in the particle swarm optimization process
to the circuit required to map 100 % exactly the outputs for
are described as follows:
corresponding inputs typically given by a truth table for
digital circuits. The hardware evolution~iscarried out until
Initialize a population of particles with random
the "desired" circuit is evolved and then downloaded to a
positions and velocities in d dimensions of the problem
reconfigurable hardware platform.
space and fly them.
Evaluate thd'fitness ofeach particle in the swarm.
For every iteration compare each particle's fitness with
its previous best fitness (pbesf)obtained. If the current
value is better than pbest, then set pbest equal to the
current value and the pbesi location equal to the current
location in the d-dimensional space.
Compare pbesf of particles with each other and update
the swarm global hest location with the greatest fitness
RBgD"W#l
arm>*
(gbest).
uimg PSO
Change the velocity and position of the particle
according to equations (1) and (2) respectively. V;d and
Fig. 2 "Deskcc circuit hardwarc evolution.
&represent the velocity and position of the j h particle
with d dimensions, respectively, rundl and rand2 are
The matrix shown in Fig. 3 is used to represent a circuit
two uniform random functions, and W is the inertia
with m rows and n columns. The elements of the circuit are
weight, which is chosen beforehand [22].
the logic gates which are selected from a predefined library
=w*v,+cl*rand,
-X,)+cZ*rand2 *(P&-xjd)(1) of 2-input l-output gates. The inputs to the first column of
the matrix come from the truth table of the function to be
= x, +
(2)
implemented. For all other columns, the inputs may come
from any of the previous column outputs.
Repeat steps (ii) to (v) until convergence is reached
based on some desired single or multiple criteria.
Fig. 1 Concept of a warm particle's position.

L--i

v,

*(ed

v,

PSO has many parameters and these are described as
follows: W called the inertia weight controls the exploration
and exploitation of the search space because it dynamically
adjusts velocity. Local minima are avoided by small local
neighborhoods, but faster convergence is obtained by a larger
global neighborhood, and in general a global neighborhood is
preferred. Synchronous updates are more costly than the
469

1

input matrices is given in Fig. 4. The results obtained by a
human designer (HDI) and by the PSO are shown in Table
2. Here, the PSO does only as good as the human designer.

;1-1

TABLE I :
TRUTH TABLE FOR EXAMPLE I

1 0 0

0

1 0 1
1 1 0
1 1 1

0

Fig. 3 Structure ofthc random circuit matrix (inputs to each gate are abtainca

from gatcs in thc previous columns).

For circuit evolution with PSO two matrices are used, one
to represent the gate types, called the gate motrix, and the
other to represent the interconnectivity between the gates,
called the input matrix. The size of the input matrix is 2n by
m. There are 2n rows because two elements of the input matrix
correspond to one gate. The order of traversing the elements in
the matrix is column wise, starting from the first column,
going down through all the rows and then to the next column.
For example, if there are 3 rows and 5 columns, then the input
matrix is of size 6 by 5. The first two elements in the first
column are inputs to the first gate, the next 2 to the second
gate, and the last 2 to the third gate, in the first column of the
gate matrix.
The initialization of the p (number of swarm particles)
random circuits’ gate and input matrices are carried out first.
Then their fitness is evaluated against the desired function to
be implemented, given by a truth table. If the output of the
circuit is equal to the output of the truth table for the
corresponding inputs, then the fitness is increased by one. This
i s carried out for all inputs listed in the truth table. For each
particle, thepbest gate matrix is determined and then the gbest
matrix for the swarm is updated. The PSO algorithm is then
applied to modify the gate matrix and the corresponding input
matrix of each particle. This process i s repeated until the
fitness value of the gbest particle is equal to the number of the
truth table outputs.

IV. EXAMPLES OF EVOLVED CIRCUITS

TABLE 2:
COMPARISON OF THE BEST SOLUTIONS BY
THE HUMAN DESIGNER AND THE PSO.

Fig. 4 Circuit cvolved by the PSO for the first cxample.

Circuits used by Coello [IO] using genetic algorithms
and its variants, are studied with the PSO technique for
comparison purposes. The second example is taken from
[IO]. This is a 3-even parity problem and its truth table is
shown in Table 3. Again, this example has three inputs and
one output. The evolved. circuit satisfying the “desired
circuit” is expected to have a fitness of eight in this case. A
gate matrix size of 3 by 3 was chosen for the evolution with
five swarm particles. The gbest evolved circuit over 227
generations contained one XOR gate, two AND gates, and
one OR gate.

Two examples are presented to describe the capability of
particle swarm for hardware evolution. The library of gates
used in this study is comurised of AND. OR. NOT. XOR. and
a wire. The wird means ho gate. The first example has three
inputs and one output, as shown in Table 1. The evolved
circuit satisfying the “desired” circuit is expected to have a
fitness of eight in this case. A gate matrix size of 3 by 3 was
chosen for the evolution with five swarm particles. The gbest
evolved circuit over 300 generations contained two XOR gates
and a NOT gate. The evolved circuit based on its gate and

470

TABLE 3:
TRUTH TABLE FOR THE SECOND EXAMPLE

0 0 1
0

1

0

0 1 1
1 0 0
1 0 1
1 1 0
~~

I o 1

Ii I

F

Y

evolution. Future work consists of concentrating on
minimizing the active gates with multi-objective criteria,
like considering a two level fitness function, where the first
level obtains 100 % functional circuits, while the second
level minimizes the number of active gates and increases the
number of wires used in the circuit evolution.

=xzIY(Xt2)

REFERENCES
1.

Fig. 5 Circuit cvolved by PSO for thc second cxample.

For comparison, the result obtained by Coello is repeated
in Table 4. Coello has used the n-cardinality GA (NGA)and
multiobjective CA to evolve circuits with four gates and
shown improvement over the human designer (HDI- five
gates based on Karnaugh maps). A population of 90
chromosomes was used in both the M G A and NGA by the
authors [IO] and mutated over 300 generations. But with the
PSO, a population size of five particles was used to get similar
results with less than 300 iterations. This basically shows that
PSO has faster convergence and fewer computations for these
examples. Therefore, this is a potential technique for real-time
hardware self-reconfiguration and needs to be further
evaluated on large digital circuits. Similar results were
obtained for other combinational circuit designs.
A large swarm population with 25 particles was initially
chosen and gradually decreased. It was found that a population
of five particles was sufficient to determine the best circuit
(minimum number of gates) for this example. It is expected
that for larger digital circuit designs, a large swarm population
is required.
TABLE 4:
COMPARISON OF THE BEST SOLUTIONS BY THE HUMAN
DESIGNER (HD I), MULTIOBIECTIVE GENETIC ALGORITHM (MGAI,
N-CARDINALITY CA (NGA), AND PSO.

HDt

I

NGA

F=Z(XfDYi F=Z(X+Y)

2 AND,I OR,
2 XOR

I MGA

I

I F=(X+Y)ZI

PSO

F=XZ@

2 AND,] OR,

2 AND,] OR,

2 AND,\ OR,

I XOR

I XOR.

I XOR,

V. CONCLUSIONS

In this paper, it is shown that particle swarm optimization
can also be applied to evolve combinational logic circuits. The
emphasis was only on the generation of circuit functionality.
From the few examples carried out, it is clear that particle
swarm has potential for hardware evolution and even real-time
hardware self-reconfiguration, since the convergence is faster.
Reinforcement learning is a potential tool to he employed to
minimize the number of active gates which are used in circuit

M. Kamaugh, “A Map Method for Synthesis o f Combinational Logic
Circuits,” Tronracriom o/ rhe AIEE, Communicariom and
Eledronics, Vol. 7 2 1 , pp. 593-599, 1953.
E. 1. McCluskey, “Minimization of Boolean Functions,” Bell Systems
TechnicalJournol, Val. 3 5 5 , pp. 1417-1444, 1956.
W. V. Quine, “Away to Simplify TNth Functions,” Americon
MorhemaricolMonrhly, Vol. 62:9, pp. 627-631, 1955.
T. Sasaa, cditar, Logic Synrhesis and Oprimizorion, Kluwcr Academic
Press, 1993.
M. Sipper, E. Sanchez. D. Mange, M. Tomassini, A. Perez-Uribe and
A. Stauffer, “A phylogcnetic, ontogenetic, and epigenctic view of
hio-inspired hardware Systems,” IEEE Tronrocriom on Evolurionary
Compulat;on,Vol. l : l , p p . 83-97, 1997.
6. T. Higuchi, Firs1 Inrernalional Conference on Evolvable Sysrems,
Spnngcr Verlag, 1997.
7. T. Higuchi, H. Iba, and B. Manderick, "Evolvable hardwarc with
gcnctic lcaming,” in Mossive!v Porallel Amrrqiciol Inlelligence, MIT
press, 1994.
8. A Coello Coello Carlos, D Christiansen Alan and A H e m i n d n
Aguirrc “Automated Design of Combinational Logic Circuits using
Fenctic Algorithms,” Pioceedings o/lhe Internarional Con/wence on
A n f l c i d Neural Ners ond Generic Algorithms. ICANNGA’97.
Springer Vnlag, pp. 335-338. 1997.
9. 1. F. Miller, P. Thomson, and T. Fogarty, “Designing Electronic
Circuits Using Evolutionary Algorithms. Arithmetic Circuits: A Cast
Study,” In D. Quagliarella, I. P’eriaux, C. Poloni, and G. Winter,
editors, Genetic Alprilhms and Evolution Slrore&v in Engineering
andCompurerScience,pp. 105-131. 1997.
10. A Coello Coello Carlos and A Hemander Aguirrc, “Design of
Combinational Logic Circuits through an Evolutionary Multiobjective
Optimization,” A n f i c i d hlelligence /or Engineering, Design,
Analysis and Manu/ocrure, Vol. l6.l.2002.
1 I . A Coello Coello Carlos. D Christiansen Alan and A Hemindcz
Aguinc, “Towards Automated Evolutionary Design of Combinational
Circuits,” Compurers and Elecrricol Engineering, Vol. 27: I,pp. 1-28,
2001
12. T. Kalganava, 1. Millcr, and T. Fogarty, “Some AspcctS of an
Evolvahlc Hardware for Multiple-Valued Combinational Circuit
Dcsign,” Proceedings o/ rhe Second lnrernolional Confimnce on
Evolvable Syslems (ICES’98). Springer-Verlag pp. 78-89, 1998.
13. J. Torrescn, “A Divide-and-Conquer Approach to Evalvahlc
Hardware,” Proceedings oJ rhe Second lnrernorionol Conference on
EvolvobleSyslems (ICES’98), Springer-Verlag. pp. 5 7 4 5 , 1998.
14. A Cacllo Caello Carlos, “A Comprehensive Survey of EvolutionaryBased Multiobjectivc Optimization Techniqucs,” Knowledge ond
In/ormotion Sysrems. An Internorional Journal, Vol. 1:3, pp. 269308,1999.
15. A Cacllo Caello Carlos and M.S Lechuga, “MOPSO: A proposal for
multiple objectiw particle swarm optimization,” Proceedings sf
Inlernariunol Con/erence on Evolurionary Compulolion, pp. 105 I 1056.2002.
16. V.G Gudisc and G.K Vcnayagamoorthy, “Comparison of particle
swarm optimization and backpropagation as training algorithms for
neural nctwuorks,” IEEE Sx.orm Inreiligence Symposium. April, 2003.

47 1

~

17. I. Kennedy

and R. Ebcrhan. "Particle s w a m optimization,"
Proceedings, IEEE lnrernorionol Con! on Neurol Nehuorks, Vol. 4, pp.
1942-1948.
18. Y. Shi and R. Ebcrhart, "Empirical study o f . particle swarm
optimization." Proceedings of Ihe 1999 Congress on Evobrionory
Compurariun, Vol. 3, 1999.
19. Y. Shi and R. Eberhart. "A modifid particle swarm optimizer," IEEE
lnrernarionol Con! on Evolurionory Compumrion, pp. 69 -73, 1998.
20. R. Eberhan and Y Shi. "Panicle swarm optimization: developments.
'
applications and rcsources," Proceedings of rhe 2001 Congress on
Evolurionory Compulorion, Vol. I , pp. 81 -86,2001
21. Y. Shi and R. Eberhart, "Parametcr Sclectian in Panicle Swarm
Optimization," Proc. Seventh Annual Conf on Evolurionq
Programming,pp. 591-601, 1998.
22. J. Kenncdy, R Ebcrhart and Y. Shi, Swarm infelligence, Morgan
Kaufmann Publishcrs, 2001.

472

