# Wilfried Elmenreich, J. Tenreiro Machado and Imre J. Rudas (Eds) 

# Intelligent Systems 

## at the Service of Mankind

# New Concepts Towards the Synthesis of Digital Circuits Through Genetic Algorithms 

Cecília Reis and J. A. Tenreiro Machado ${ }^{1}$, J. Boaventura Cunha ${ }^{2}$<br>${ }^{1}$ Institute of Engineering, Polytechnic Institute of Porto, Porto, Portugal<br>\{cmr, jtm\}@isep.ipp.pt<br>${ }^{2}$ Engineering Department, University of Trás-os-Montes and Alto Douro, Vila Real, Portugal<br>jboavent@utad.pt


#### Abstract

This paper analyses the performance of a Genetic Algorithm using two new concepts, namely a static fitness function including a discontinuity measure and a fractional-order dynamic fitness function, for the synthesis of combinational logic circuits. In both cases, experiments reveal superior results in terms of speed and convergence to achieve a solution.


## 1 Introduction

In the last decade genetic algorithms (GAs) have been applied in the design of electronic circuits, leading to a novel area of research called Evolutionary Electronics (EE) or Evolvable Hardware (EH) [1]. EE considers the concept for automatic design of electronic systems. Instead of using human conceived models, abstractions and techniques, EE employs search algorithms to develop good designs [2].
One decade ago Sushil and Rawlins [3] applied GAs to the combinational circuit design problem. They combined knowledge-based systems with the GA and defined a genetic operator called masked crossover. This scheme leads to other kinds of offspring that can not be achieved by classical crossover operators.
John Koza [4] adopted genetic programming to design combinational circuits. His goal was the design of functional circuits through AND, OR and NOT logic gates.

In the sequence of this work, Coello, Christiansen and Aguirre [5] presented a computer program that automatically generates high-quality circuit designs. They use five possible types of gates (AND, NOT, OR, XOR and WIRE) with the objective of finding a functional design that minimizes the use of gates other than WIRE.

Miller, Thompson and Fogarty [6] applied evolutionary algorithms for the design of arithmetic circuits. The technique was based on evolving the functionality and connectivity of a rectangular array of logic cells, with a model of the resources available on the Xilinx 6216 FPGA device.

Kalganova, Miller and Lipnitskaya [7] proposed a new technique for designing multiplevalued circuits. The EH is easily adapted to the distinct types of multiple-valued gates, associated with operations corresponding to different types of algebra, and can include other logical expressions. This approach is an extension of EH method for binary logic circuits proposed in [6].
In order to solve complex systems, Torresen [8] proposed the method of increased complexity evolution. The idea is to evolve a system gradually as a kind of divide-andconquer method. Evolution is first undertaken individually on a large number of simple cells. The evolved functions are the basic blocks adopted in further evolution or assembly of a larger and more complex system.

More recently Hollingworth, Smith and Tyrrell [9] describe the first attempts to evolve circuits using the Virtex family of devices. They implemented a simple 2-bit adder, where the inputs to the circuit are the two 2-bit numbers and the expected output is the sum of the two input values.

A major bottleneck in the evolutionary design of electronic circuits is the problem of scale. This refers to the very fast growth of the number of gates, used in the target circuit, as the number of inputs of the evolved logic function increases. This results in a huge search space that is difficult to explore even with evolutionary techniques. Another related obstacle is the time required to calculate the fitness value of a circuit [10]. A possible method to solve this problem is to use building blocks either than simple gates. Nevertheless, this technique leads to another difficulty, which is how to define building blocks that are suitable for evolution.

Timothy Gordon [11] suggests an approach that allows evolution to search for good inductive bases for solving large-scale complex problems. This scheme generates, inherently, modular and iterative structures, that exist in many real-world circuit designs but, at the same time, allows evolution to search innovative areas of space.

The idea of using memory to achieve better fitness function performances was first introduced by Sano and Kita [12,13]. Their goal was the optimization of systems with randomly fluctuating fitness function and they developed a Genetic Algorithm with Memorybased Fitness Evaluation (MFEGA). The key ideas of the MFEGA are based on storing the sampled fitness values into memory as a search history, introducing a simple stochastic model of fitness values to be able to estimate fitness values of points of interest using the history for selection operation of the GA.

Bearing these ideas in mind, and looking for better performance GAs, this paper proposes a GA for the design of combinational logic circuits using fractional-order dynamic fitness functions.

The area of Fractional Calculus (FC) deals with the operators of integration and differentiation to an arbitrary (including noninteger) order and is as old as the theory of classical differential calculus $[14,15]$. The theory of FC is a well-adapted tool to the modelling of many physical phenomena, allowing the description to take into account some peculiarities that classical integer-order models simply neglect. Nevertheless, the application of FC has been scarce until recently, but the advances on the theory of chaos motivated a renewed interest in this field. In the last two decades we can mention research on viscoelasticity/damping, chaos/fractals, biology, signal processing, system identification, diffusion and wave propagation, electromagnetism and automatic control
[16, 17, 18, 19, 20, 21, 22].
The article is organized as follows. Section 2 describes the adopted GA as well as the fractional-order dynamic fitness functions. Section 3 presents the simulation results and finally, section 4 outlines the main conclusions and addresses perspectives towards future developments.

## 2 The Adopted Genetic Algorithm

In this section we present the GA developed in the study, in terms of the circuit encoding as a chromosome, the genetic operators and the static and dynamic fitness functions.

### 2.1 Problem Definition

A GA strategy is adopted to design combinational logic circuits. The circuits are specified by a truth table and the goal is to implement a functional circuit with the least possible complexity. Two sets of logic gates have been defined, as shown in Table 1, being Gset a the simplest one (i.e., a RISC-like set) and Gset b a more complex gate set (i.e., a CISC-like set).

| Gate Set | Logic gates |
| :---: | :---: |
| Gset a | \{AND,XOR,WIRE\} |
| Gset $b$ | $\{$ AND,OR,XOR,NOT,WIRE $\}$ |

## Table 1: Gate sets

For each gate set the GA searches the solution space, based on a simulated evolution aiming the survival of the fittest strategy. In general, the best individuals of any population tend to reproduce and survive, thus improving successive generations. However, inferior individuals can, by chance, survive and also reproduce [2]. In our case, the individuals are digital circuits, which can evolve until the solution is reached (in terms of functionality and complexity).

### 2.2 Circuit encoding

In the GA scheme the each circuit is encoded as a rectangular matrix A (row $\times$ column $=r \times c$ ) of logic cells as represented in figure 1 .
Each cell is represented by three genes: <inputl><input $2><$ gate type $>$, where input 1 and input 2 are one of the circuit inputs, if the cell is in the first column of the matrix, or, one of the outputs of a previous cell, if the cell is not in the first column of the matrix. The gate type is one of the elements adopted in the gate set. The chromosome is formed by as many triplets of this kind as the matrix size demands. For example, the chromosome that represents a $3 \times 3$ matrix is depicted in figure 2 .

### 2.3 The genetic operators

The initial population of circuits (strings) is generated at random. The search is then carried out among this population. The three different operators used are reproduction, crossover and mutation, as described in the sequel.


Figure 1: A $3 \times 3$ matrix A representing a circuit with input X and output Y


Figure 2: Chromosome for the $3 \times 3$ matrix of figure 1

Concerning the reproduction operator, the successive generations of new strings are reproduced on the basis of their fitness function. In this case, it is used a tournament selection to select the strings from the old population, up to the new population.

For the crossover operator, the strings in the new population are grouped together into pairs at random. Single point crossover is then performed among pairs. The crossover point is only allowed between cells to maintain the chromosome integrity.

The mutation operator changes the characteristics of a given cell in the matrix. Therefore, it modifies the gate type and the two inputs, meaning that a completely new cell can appear in the chromosome. Moreover, it is applied an elitist algorithm and, consequently, the best solutions are always kept for the next generation.

To run the GA we have to define the number of individuals to create the initial population $P$. This population is always the same size across the generations, until the solution is reached.
The crossover rate $C R$ represents the percentage of the population $P$ that reproduces in each generation. Likewise, the mutation rate $M R$ is the percentage of the population $P$ that can mutate in each generation.

### 2.4 The Static and the Dynamic Fitness Functions

The initial population of circuits (strings) is generated at random. The search is then carried out among this population. The three different operators used are reproduction, crossover and mutation, as described in the sequel.

The goal of this study is to find new ways of evaluating the individuals of the population in order to achieve better performance GAs.

In this paper we propose two concepts for the fitness functions, namely the static fitness function $F_{s}$ and the dynamic fitness function $F_{d}$.
The calculation of $F_{s}$ in (1) is divided in two parts, $f_{1}$ and $f_{2}$, where $f_{1}$ measures the
functionality and the error discontinuity and $f_{2}$ measures the simplicity. In a first phase, we compare the output $\mathbf{Y}$ produced by the GA-generated circuit with the required values $\mathbf{Y}_{R}$, according to the truth table, on a bit-per-bit basis. By other words, $f_{11}$ is incremented by one for each correct bit of the output until $f_{11}$ reaches the maximum value $f_{10}$, that occurs, when we have a functional circuit. After this, $f_{11}$ is decremented by $\delta$ for each $\mathbf{Y}_{R}-\mathbf{Y}$ error discontinuity, where discontinuity means passing from $\mathbf{Y}_{R}-\mathbf{Y}=0$ to $\mathbf{Y}_{R}-$ $\mathbf{Y}=1$ or vice-versa when comparing two consecutive levels of the truth table. Once the circuit is functional, in a second phase, the GA tries to generate circuits with the least number of gates. This means that the resulting circuit must have as much genes $<$ gate type $>\equiv<$ wire $>$ as possible. Therefore, the index $f_{2}$, that measures the simplicity (the number of null operations), is increased by one (zero) for each wire (gate) of the generated circuit, yielding:

$$
\begin{gather*}
f_{10}=2^{n i} \times \text { no }  \tag{1a}\\
f_{11}=f_{11}+1 \text { if }\{\text { bit } i \text { of } \mathbf{Y}\}=\left\{\text { bit } \text { i of } \mathbf{Y}_{\mathbf{R}}\right\}, i=1, \ldots, f_{10}  \tag{1b}\\
f_{1}=f_{11}-\delta \text { if }_{\text {error }}^{i} \text { } \neq \text { error }_{i-1}, i=1, \ldots, f_{10}  \tag{1c}\\
f_{2}=f_{2}+1 \text { if gate type }=\text { wire }  \tag{1d}\\
F_{s}=\left\{\begin{array}{cc}
f_{1}, & F_{s}<f_{10} \\
f_{1}+f_{2}, & F_{s} \geq f_{10}
\end{array}\right. \tag{1e}
\end{gather*}
$$

where $n i$ and no represent the number of inputs and outputs of the circuit.
The concept of dynamic fitness function $F_{d}$ results from an analogy with control systems where we have a variable to be controlled similarly with the GA case where we master the population through the fitness function. The simplest control system is the proportional algorithm; nevertheless, there can be other control algorithms, like the differential and the integral schemes. Therefore, applying the static fitness function corresponds to using a kind of proportional algorithm. If we want to implement a proportional-derivative or a proportional-integrative evolution the fitness function needs a scheme of the type:

$$
\begin{equation*}
F_{d}=F_{s}+K D^{\alpha}[F s] \tag{2}
\end{equation*}
$$

where $\mathrm{t} 1 \leq \alpha \leq 1$ is the differential (integral) fractional-order for positive (negative) values of $\alpha$ and $K$ is the 'gain' of the dynamical term.

The generalization of the concept of derivative $D^{\alpha}[f(x)]$ to noninteger values of $\alpha$ goes back to the beginning of the theory of differential calculus. In fact, Leibniz, in his correspondence with Bernoulli, L'Hôpital and Wallis, had several notes about its calculation for $\alpha=1 / 2[14,15]$. Nevertheless the adoption of the $F C$ in control algorithms has been recently studied using the frequency and discrete-time domains [16, 17, 18, 19].

The mathematical definition of a derivative of fractional order $\alpha$ has been the subject of several different approaches. For example, (3) and (4), represent the Laplace (for zero
initial conditions) and the Grünwald-Letnikov definitions of the fractional derivative of order $\alpha$ of the signal $x(t)$ :

$$
\begin{gather*}
D^{\alpha}[x(t)]=L^{-1}\left\{s^{\alpha} X(s)\right\}  \tag{3}\\
D^{\alpha}[x(t)]=\lim _{h \rightarrow 0}\left[\frac{1}{h^{\alpha}} \sum_{k=0}^{\infty}(-1)^{k} \frac{\Gamma(\alpha+1)}{\Gamma(k+1) \Gamma(\alpha-k+1)} x(t-k h)\right] \tag{4}
\end{gather*}
$$

where $\Gamma$ is the gamma function and $h$ is the time increment. This formulation [19] inspired a discrete-time calculation algorithm, based on the approximation of the time increment $h$ through the sampling period $T$ and a $r$-term truncated series yielding the equation:

$$
\begin{equation*}
D^{\alpha}[x(t)] \approx \frac{1}{T^{\alpha}} \sum_{k=0}^{r} \frac{(-1)^{k} \Gamma(\alpha+1)}{k!\Gamma(\alpha-k+1)} x(t-k T) \tag{5}
\end{equation*}
$$

## 3 Experiments and Simulation Results

Reliable execution and analysis of a GA usually requires a large number of simulations to provide a reasonable assurance that stochastic effects have been properly considered [23]. Therefore, in this study are developed $n=1000$ simulations for each case under analysis.

The experiments consist on running the GA to generate a typical combinational logic circuit, namely a 2 -to-1 multiplexer ( $M 2-1$ ) and a 4-bit parity checker (PC4), using the fitness schemes described previously.
Having a superior GA performance means achieving solutions with a smaller number $N$ of generations and a smaller standard deviation in order to reduce the stochastic nature of the algorithm.

### 3.1 Using the static fitness function

In this sub-section we analyze the GA improvement when adopting a static fitness function including the discontinuity measure $\delta$ error.
Figures 3 and 4 show the average number of generations to achieve the solution $\operatorname{AV}(N)$ and the corresponding standard deviation $S D(N)$ versus the discontinuity factor $\delta=\{0$, $0.25,0.5,0.75,1\}$, using Gset a and Gset b , for the $M 2-1$ and the PC4 circuits, respectively.

The results reveal that, as it was expected from previous studies [24], the RISC-like set Gset a presents better performance than the CISC-like gate set Gset b for all values of $\delta$. On the other hand, analysing the influence of $\delta$ we conclude that the GA response is best when $\delta=0.5$ for the two circuits and for the two gate sets.

### 3.2 Experiments using dynamic fitness function

In this sub-section we analyze the GA performance when we adopt a dynamic scheme for the fitness function.

The simulations investigate an integral scheme ( $\alpha=\{-1,-0.75,-0.5,-0.25,0\}$ ) and a differential scheme $(\alpha=\{0,0.25,0.5,0.75,1\})$ in $F_{d}$ for gains $10^{-3} \leq K \leq 10^{2}$.


Figure 3: $M 2-1$ average number of generations to achieve a solution $A V(N)$ and standard deviation $S D(N)$ for $\delta=\{0,0.25,0.5,0.75,1\}$ with Gsets a and b

The implementation of the integral/differential fractional order operator adopts (5) with a series truncation $r=50$ terms.
Figures 5 to 8 show the average number of generations to achieve a solution $\operatorname{AV}(N)$ and the standard deviation $S D(N)$ for the integral and differential schemes, for the M2-1 and PC4 circuits, using Gset a and Gset b, respectively.

Tables 2 and 3 present the parameters ( $\alpha, K$ ) pair for each best solution obtained in terms of average number of generations $A V(N)$ and in terms of standard deviation $\operatorname{SD}(N)$, respectively, for the integral and the differential schemes of $F_{d}$.

| Circuit | Gset a | Gset b |
| :--- | :--- | :--- |
| $M 2-1$ | $(\alpha, K)=(0.5,0.01)$ | $(\alpha, K)=(1,0.1)$ |
|  | $(\alpha, K)=(-0.5,0.1)$ | $(\alpha, K)=(-1,0.1)$ |
| PC4 | $(\alpha, K)=(0.5,0.1)$ | $(\alpha, K)=(0.75,0.01)$ |
|  | $(\alpha, K)=(-0.5,0.1)$ | $(\alpha, K)=(-0.75,0.01)$ |

Table 2: The ( $\alpha, K$ ) parameters for each best solution obtained in terms of $A V(N)$

In general we conclude that the $F_{d}$ concept produces better results particularly for the differential scheme. Moreover, once again, the RISC-like gate set is superior to the CISClike gate set and the best results are for fractional order $\alpha$.


Figure 4: PC4 average number of generations to achieve a solution $A V(N)$ and standard deviation $S D(N)$ for $\delta=\{0,0.25,0.5,0.75,1\}$ with Gsets a and b

Circuit Gset a

| $M 2-1$ | $(\alpha, K)=(1,10)$ | $(\alpha, K)=(0,10)$ |
| :--- | :--- | :--- |
|  | $(\alpha, K)=(-0.5,0.1)$ | $(\alpha, K)=(0,100)$ |
| PC4 | $(\alpha, K)=(0.5,0.1)$ | $(\alpha, K)=(0.5,0.1)$ |
|  | $(\alpha, K)=(-0.5,0.1)$ | $(\alpha, K)=(-0.5,0.1)$ |

Table 3: The ( $\alpha, K$ ) parameters for each best solution obtained in terms of $S D(N)$


Figure 5: M2-1 average number of generations to achieve a solution $A V(N)$ and standard deviation $S D(N)$ for integral and differential control schemes with Gset a

## 4 Conclusions

This paper presented two techniques for improving the GA performance. In what concerns to the classical static fitness function we conclude that it is possible to get superior results by measuring the error discontinuity. On the other hand, the new concept of fractional-order dynamic fitness function of the GA, demonstrates to be an important method that outperforms the traditional static fitness function approach. In both cases, the tuning of the 'optimal' parameters $\delta$ or $(\alpha, K)$ was established by trial and error. Therefore, future research will address the problem of having a more systematic design method.

These conclusions encourage further studies using not only proportional-differential or proportional-integral control schemes but also proportional-integral-derivative control schemes.

## References

[1] R. Zebulum, M. Pacheco, and M. Vellasco. Evolutionary Electronics: Automatic Design of Electronic Circuits and Systems by Genetic Algorithms. CRC Press, 2001.
[2] A. Thompson and P. Layzell. Analysis of unconventional evolved electronics. Communications of the ACM, pages 71-79, 1999.
[3] S. Louis and G. Rawlins. Designer genetic algorithms: Genetic algorithms in structure design. In Proceedings of the Fourth International Conference on Genetic Algorithms, 1991.


Figure 6: $M 2-1$ average number of generations to achieve a solution $A V(N)$ and standard deviation $S D(N)$ for integral and differential control schemes with Gset b
[4] J. Koza. Genetic Programming. On the Programming of Computers by means of Natural Selection. MIT Press, 1992.
[5] C. Coello, A. Christiansen, and A. Aguirre. Using genetic algorithms to design combinational logic circuits. Intelligent Engineering through Artificial Neural Networks, pages 391-396, 1996.
[6] J. Miller, P. Thompson, and T. Fogarty. Algorithms and Evolution Strategies in Engineering and Computer Science: Recent Advancements and Industrial Applications. Wiley, 1997.
[7] T. Kalganova, J. Miller, and N. Lipnitskaya. Multiple valued combinational circuits synthesised using evolvable hardware. In Proceedings of the Seventh Workshop on Post-Binary Ultra Large Scale Integration Systems, 1998.
[8] J. Torresen. A divide-and-conquer approach to evolvable hardware. In Proceedings of the Second International Conference on Evolvable Hardware, pages 57-65, 1998.
[9] G. Hollingworth, S. Smith, and A. Tyrrell. The intrinsic evolution of virtex devices through internet reconfigurable logic. In Proceedings of the Third International Conference on Evolvable Systems, pages 72-79, 2000.
[10] V. Vassilev and J. Miller. Scalability problems of digital circuit evolution. In Proceedings of the Second NASA/DOD Workshop on Evolvable Hardware, pages 55-64, 2000.
[11] T. Gordon and P. Bentley. Towards development in evolvable hardware. In Proceedings of the 2002 NASA/DOD Conference on Evolvable Hardware, pages 241-250, 2002.
[12] Y. Sano and H. Kita. Optimization of noisy fitness functions by means of genetic algorithms using history of search. In Proceedings of the PPSN VI, pages 571-581, 2000.
[13] Y. Sano and H. Kita. Optimization of noisy fitness functions by means of genetic algorithms using history of search with test of estimation. In Proceedings of the CEC, 2002.


Figure 7: PC4 average number of generations to achieve a solution $A V(N)$ and standard deviation $S D(N)$ for integral and differential control schemes with Gset a
[14] K. Oldham and J. Spanier. The Fractional Calculus: Theory and Application of Differentiation and Integration to Arbitrary Order. Academic Press, 1974.
[15] K. Miller and B. Ross. An Introduction to the Fractional Calculus and Fractional Differential Equations. John Wiley \& Sons, 1993.
[16] A. Oustaloup. Dérivation Non Entier: Théorie, Synthèse et Applications. Editions Hermes, 1995.
[17] A. Méhauté. Fractal Geometries: Theory and Applications. Penton Press, 1991.
[18] C. Koh and J. Kelly. Application of fractional derivatives to seismic analysis of base-isolated models. Earthquake Engineering and Structural Dynamics, pages 229-241, 1990.
[19] J. Machado. Analysis and design of fractional-order digital control systems. SAMS Journal Systems Analysis, Modelling, Simulation, pages 107-122, 1997.
[20] P. Torvik and R. Bagley. On the appearance of the fractional derivative in the behaviour of real materials. ASME Journal of Applied Mechanics, pages 294-298, 1984.
[21] S. Westerlund. Dead Matter Has Memory! Causual Consulting, 2002.
[22] Y. Chen and K. Moore. Discretization schemes for fractional-order differentiators and integrators. IEEE Trans. On Circuits and Systems, pages 363-367, 2002.
[23] R. Morrison. Dispersion-based population initialization. In Proceedings of the Genetic and Evolutionary Computation Conference, pages 1210-1221, 2003.
[24] C. Reis, J. Machado, and J. Cunha. Evolutionary design of combinational logic circuits. Journal of Advanced Computational Intelligence and Intelligent Informatics, pages 507-513, 2004.


Figure 8: PC4 average number of generations to achieve a solution $A V(N)$ and standard deviation $\operatorname{SD}(N)$ for integral and differential control schemes with Gset b

## About the Authors

Cecília Reis was born in November 24, 1967. She graduated in Electrical Engineering - Industrial Control from Institute of Engineering of Polytechnic Institute of Porto, Portugal, in 1992 and received the Master's degree in Electrical and Computer Engineering from the Faculty of Engineering of the University of Porto, Portugal, in 1995. Presently she teaches at the Institute of Engineering of the Polytechnic Institute of Porto, Department of Electrical Engineering. Her research interests include digital systems, evolvable hardware, genetic algorithms and fractionalorder systems.
J.A. Tenreiro Machado was born in October 6, 1957. He graduated and received the Ph.D. degree in electrical and computer engineering from the Faculty of Engineering of the University of Porto, Portugal, in 1980 and 1989, respectively. Presently he is Coordinator Professor at the Institute of Engineering of the Polytechnic Institute of Porto, Department of Electrical Engineering. His main research interests are robotics, modelling, control, genetic algorithms, fractional-order systems and intelligent transportation systems.
J. Boaventura Cunha was born in November 21, 1961. He graduated in Electronics Engineering from the University of Aveiro in 1985 and received the Ph.D. degree in Electrical and Computer Engineering from the University of Trás-os-Montes e Alto Douro, Portugal, in 2002. Presently he is an Assistant Professor at the Engineering Department of the University of Trás-os-Montes e Alto Douro and he is a researcher at the CETAV Institute. His main research interests are automation, modelling and control systems.

