# Using Evolutionary Strategies Algorithm in the Evolutionary Design of Sequential Logic Circuits

Parisa Soleimani $^1,$  Reza Sabbaghi-Nadooshan $^2$ , Sattar Mirzakuchaki $^3$  , and Mahdi Bagheri $^4$ 

<sup>1</sup> Member of Scientific Association of Electrical and Electronic Engineering, Islamic Azad University, Central Tehran branch Punak, Tehran, Iran

> <sup>2</sup> Department of electronic engineering Islamic Azad University, Central Tehran branch Punak, Tehran, Iran

<sup>3</sup> Department of electronic engineering Iran University of Science and Technology Narmak, Tehran, 16846-13114, Iran

<sup>4</sup> Department of electronic engineering Iran University of Science and Technology Narmak, Tehran, 16846-13114, Iran

#### Abstract

Evolvable hardware (EHW) is a set of techniques that are based on the idea of combining reconfiguration hardware systems with evolutionary algorithms. In other word, EHW has two sections; the reconfigurable hardware and evolutionary algorithm where the configurations are under the control of an evolutionary algorithm. This paper, suggests a method to design and optimize the synchronous sequential circuits. Evolutionary Strategies algorithm (ES) was applied as evolutionary algorithm. In this approach, for building input combinational logic circuit of each DFF, and also output combinational logic circuit, the cell arrays have been used. The obtained results show that our method can reduce the average number of generations by limitation the search space.

*Keywords:* Combinational logic circuit, Evolutionary algorithms, Evolvable hardware, Evolutionary Strategies algorithm, sequential logic circuit.

#### 1. Introduction

The complexity of electronic and computer systems is increasing at a rapid rate. This increase of complexity enables the designers to come up with effectively engineered systems such as airplanes, modern vehicles, mobile phones, and intelligent homes. However, this level of complexity also causes problems in the design procedure, and in the management and functioning of such systems.

Simpler structure of combinational logic circuits in compare with sequential logic circuits and the lack of feedback in this circuits is caused more researches have been done in this field. Different evolutionary algorithms have been used to evolve combinational logic circuits, for example Vasicek used Cartesian genetic programming [1], Stomeo employed evolutionary strategy [2], and Jackson used genetic programming [3].

On the other hand, relatively few efforts have been done to evolve the sequential logic circuits [4]. For example, Higuchi used GA to search for circuits that represent the desired state transition function [5]. Manovit synthesized frequency detector, odd parity detector, module-5 counter, serial adder [6]. Aporntewan evolved serial adder, 0101 detector, module-5 counter, Reversible 8-counter with genetic algorithm [7]. Solimon designed 3-bit up-counter [8], and Shanthi evolved module-6 counter, 'lion' circuit [9].

In this paper, we have proposed a method for designing and optimizing the synchronous sequential logic circuits with 100% functionality and minimal number of logic gates. In

> IJČSI www.IJCSI.org

the rest of this paper, sections 2 consider the main idea of the proposed method. Section 3 describes ES algorithm. Section 4 describes details of process to define structure of chromosomes. Section 5 explains fitness evaluation process to evaluate the performance of evolved circuits. Simulation environment has been described in section 6. Section 7 summarizes the experiment of proposed method on two sequential circuits and shows the simulation results for target circuits. Finally, in section 8 the conclusion of this paper is presented.

## **2.** The Proposed Method

The structure of sequential logic circuits comprises a set of two sections of the combinational logic circuit and D flip-flops [10]. In this approach, for designing combinational parts, we present a constant structure of two dimensional rectangular arrays of logic gates. We put this array to input of each DFF for building their next states, and before the primary outputs to build the outputs of the target circuit as Fig. 1. With evaluation of each array separately, speed of evolution is increased and the evolution time is decreased.

The described array for building combinational logic parts is shown in Fig. 2. This array has R rows and C columns, and their logic gates are chosen from AND, OR, NAND and NOT gates. Except NOT gate, the other gates have two inputs and one output. Each gate input can be obtained from primary inputs, present states of DFFs or of neighbor outputs each left gates. One Multiplexer is added to the inputs of gates in each array, the input of DFFs and before the primary outputs. We change connection between gates and DFFs by varying the selection bits of multiplexers. Hence, by determining the proposed structure of chromosome encoding (section IV) and by using the evolutionary strategies algorithm, we have evaluated the different states of logic gate connections to achieve a correct functionality and minimum number of logic gates.



Figure 1. Block diagram of the proposed method for sequential logic circuit with two DFFs



Figure 2. Schematic of the rectangular array structure for building combinational logic parts.

#### **3.** Evolutionary strategies *Algorithm*

Evolutionary strategies (ES) is one of the evolutionary algorithm that so called  $(1+\lambda)$  algorithm.  $\lambda$  is the size of population. At first stage, all of the chromosomes have been produced, randomly. At the second stage, the fitness value of any chromosome has been computed. At the third stage, the best chromosome has been selected based on the



best fitness value. At the fourth stage, the chromosome that has been selected in the previous stage is evaluated for evolution stop condition. If the stop condition has been not achieved, the new population is produced by  $\lambda$  iteration mutation of the best chromosome.

Hence, the number of member of new generation is  $\lambda$ +1. The steps 2-4 have been repeated until to reach to the evolution stop condition.

#### 4. Chromosome Encoding

The basic concept behind the combination of reconfigurable hardware systems and evolutionary algorithm (similar to ESs in EHW) is to regard the configuration bits for the reconfigurable hardware devices as chromosomes for the evolutionary strategies algorithm. If the fitness function is correctly designed for a task, then the evolutionary strategies algorithm can autonomously find the best hardware configuration in terms of the chromosomes (i.e. configuration bits).

The chromosome defines the construction of the logic circuit and the connectivity between logic gates. In this approach, we have put a multiplexer to input of each gate, DFFs, and before the primary outputs. Fig. 3 shows block diagram of cell array after adding multiplexer to it.

We changed connection between gates and DFFs by changing the selection bits of multiplexers. Inputs of multiplexers of logic gates are taken from primary inputs, present states of DFFs, outputs of all gates that is the neighbor left column, and constant values that set equal '0' and '1'. Also inputs of multiplexers of DFFs and primary outputs are obtained from primary inputs and outputs of all logic gates that are on the all left columns. Fig. 4 depicts the structure of multiplexer that is used.

Changing selection bits of multiplexers leads to different connectivity between logic gates of circuit. We have used the selection bits of multiplexer as chromosome genes as Fig. 5.



Figure 3. Block diagrom of cell array after adding multiplexer to it.



Figure 4. Structure of Multiplexer has been used in "Fig.3"



Figure 5. Structure of chromosome encoding.

#### 5. Fitness Evaluation Process

A fitness function in ES measures goodness of every individual in population with respect to the problem under consideration. We used finite state machine (FSM) for evaluation of sequential circuits. In this method, first the desired state is set in the circuit flip flops and then we changed the value in primary inputs and compared the output of circuit with the desired ones. If these two values are equal, then the fitness value is increased. In proposed method, we measured fitness function by two main criteria: design and optimization. In the first criteria, functionality of the circuit is evaluated. Our first objective indicator is evolving a circuit that has 100% functionality. Then in the second criteria, optimization has been performed by reducing the numbers of logic gates that are used in the target circuit. Fitness optimization is activated once design fitness value reaches 100% functionality.



IJCSI International Journal of Computer Science Issues, Vol. 8, Issue 3, No. 2, May 2011 ISSN (Online): 1694-0814 www.IJCSI.org

The design criterion of any individual is evaluated as these steps:

1. The initial value for design fitness has been considered to zero.

2. The primary inputs and present state of DFFs have been set externally. Then the value of next state of DFFs and primary output of the circuit is measured after sending a clock signal to DFF.

3. The corresponding output with desired output has been compared. We can use this equation to measure fitness:

 $F_{\text{Design}} = F_{\text{Design}} + \text{ number of equal output bits.}$  (1)

4. The steps 2-3 have been repeated for the remaining states of FSM and functionality of circuit has been evaluated.

The optimization criterion has been calculated as follow steps:

1. The initial value for optimization criterion has been considered as:

$$F_{\text{Optimization}} = \mathbf{R}^* \mathbf{C} \tag{2}$$

2. For each individual, total number of logic gates have been calculated. So, we can use this equation to find optimization fitness:

 $F_{\text{Optimization}} = (R^*C)$  - number of logic gates that is used in new circuit. (3)

Now, the final fitness of individual could be calculated by using this equation:

$$F_{\text{Final}} = F_{\text{Design}} + F_{\text{Optimization}} \tag{4}$$

Both of the procedures described above are applied for evaluation of combinational parts of sequential logic circuit.

#### 6. Simulation Environment

In this method, we used Modelsim as VHDL hardware programming language simulator and MATLAB software for implement ES. In addition we used simulator link <sup>TM</sup> MQ toolbox in this software. It can access to Modelsim, open HDL code, run it for different inputs that are determined in MATLAB code and save outputs in the variables of MATLAB codes. Hence this toolbox is as a link between Modelsim and MATLAB. Fig. 6 shows block diagram of this process.

MATLAB MATLAB testbench M-Function Stimulus HDL Simulator HDL Entity Arguments

Figure 6. Structure of chromosome encoding[11].

#### 7. Experiments and Results

In this section, the proposed method is experimented on two types of the sequential circuits.

#### a) 1010 Sequential detector

The first circuit is a 1010 sequential detector. The target sequence detector circuit has one input, one output, and four internal states. State transition graph of this circuit has been shown in Fig. 7. In this method, we designed the target detector based on the symbolic transition table shown in Fig. 8. In this figure, step1 shows the symbolic state table of FSM and state assignment to each state. In step2, STT of the target circuit is shown. In step3, STT of the circuit is divided into input combinational logic sub circuit C [10]. This circuit has four states that use two DFFs. As we explained in previous sections, we evaluated each sub circuit A, B, and C separately. Finally, the sequential circuit is assembled. The evolved circuit is shown in Fig. 9.



Figure 7. 1010 Detector (a) state transition graph, (b) state transition table, (c) state assignment[10].

This circuit includes two gates in sub circuit A and three gates in sub circuit C and there is not any gate in sub circuit B. The results that have been achieved by proposed method



in compare with [12] have been shown in Table 1. In this circuit, maximum number of the generations for evaluation of sub circuit A was 4230 generations, for sub circuit B was 1300 generations and for sub circuit C was 5200 generations. We attained above results after 20 runs. In comparison with the method was presented in [12], our method uses the less gates, less generations, and the less times of evaluation to get 100% functionality. Also optimization decreases search space for ES by evolution of combinational parts of sequential circuit separately.

| ſ |     |                  |            |     |             |        |               |            |           |           |            |          |             |
|---|-----|------------------|------------|-----|-------------|--------|---------------|------------|-----------|-----------|------------|----------|-------------|
|   | i/p | Ps               | Ns         | o/p |             | STT of | f the circuit | STT of sub | circuit A | STT of su | bcircuit B | STT of s | ubcircuit C |
|   | 0   | <b>S</b> 0       | <b>S</b> 0 | 0   |             | i.     | 3             | ,i a       |           | i i       | 3          | , i i    | 3           |
|   | 1   | <b>S</b> 0       | <b>S1</b>  | 0   |             |        | 3             | .0         | 1         | .0        | 1          | .0       | 1           |
|   | 0   | <b>S1</b>        | <b>S</b> 2 | 0   |             | 4      | 8 (           | .р         | 8         | .p        | 8          | .р       | 8           |
|   | 1   | <b>S1</b>        | <b>S1</b>  | 0   | S0=00       | 000    | 000           | 000        | 0         | 000       | 0          | 000      | 0           |
|   | 0   | <b>S</b> 2       | <b>S</b> 0 | 0   | S1=11       | 100    | 110           | 100        | 1         | 100       | 1          | 100      | 0           |
|   | 1   | <b>S</b> 2       | <b>S</b> 3 | 0   | S2=10       | 011    | 100           | 011        | 1         | 011       | 0          | 011      | 0           |
|   | 0   | <b>S</b> 3       | <b>S</b> 2 | 1   | S3=01       | 111    | 110           | 111        | 1         | 111       | 1          | 111      | 0           |
|   | 1   | <b>S</b> 3       | <b>S1</b>  | 0   |             | 010    | 000           | 010        | 0         | 010       | 0          | 010      | 0           |
|   |     |                  |            |     |             | 110    | 010           | 110        | 0         | 110       | 1          | 110      | 0           |
|   | i/p | input            | s          |     |             | 001    | 101           | 001        | 1         | 001       | 0          | 001      | 1           |
|   | o/p | /p outputs       |            | 101 | 110         | 101    | 1             | 101        | 1         | 101       | 0          |          |             |
|   | Ps  | 's Present state |            |     |             |        |               | 1          |           |           |            |          |             |
|   | Ns  | ls Next state    |            |     | Step1 Step2 |        | Step3         |            |           |           |            |          |             |

Figure 8. Process of STT of 1010 sequential circuit where .i input=input+present state bits, .o defined the number of outputs calculated, outputs of subcircuit A and B =next states of DFFs and output of subcircuit C =primary output bits, .p is the number of product terms



Figure 9. Evolved optimal circuit solution for 1010 detector.

| Proposed approach     | Almaini [12]                    |
|-----------------------|---------------------------------|
| D <sub>A</sub> =XB'+A | D <sub>A</sub> =X'A'B+X'AB'+XAB |
| D <sub>B</sub> =X     | D <sub>B</sub> =A'B+AB'+XB'     |
| Z=X'A'B               | Z=X'AB'                         |
| Sub circuits of A,B=2 | Sub circuits of A,B=12          |
| Sub circuit C=3       | Sub circuit C=2                 |

## b) Sequential detector with 6 states

We experiment another sequential detector in this section. This circuit has six states and uses three DFFs. State transition graph of this circuit has been shown in Fig. 10. We evolved this circuit similar to previous experiment. Fig. 11 depicts evolved circuit. In this circuit, sub circuit A has one gate, sub circuit B has five gates, sub circuit C has one gate and there is not any gate in sub circuit D.

In this experiment, the maximum number of the generations for evaluation of sub circuit A was 6120 generations, for sub circuit B was 10000 generations, for sub circuit C was 8310 generations and for sub circuit D was 8015 generations. We attained these results after 50 runs.

Table 2 compares our method with manual method and proposed method in [10]. The solution obtained by manual method, uses almost 2 times more gates than the circuit created by our method, and the method solution reported in [10] uses one gate more than our method. Maximum number of generations in [10] is 50000 generations, but in our method is 10000 generations.



Figure 10. Sequential Detector (a) state transition graph, b state transition table, (c) state assignment [10].

# TABLE I. SOLUTION OBTAINED FOR 1010 DETECTOR BASED ON FIG.9



#### IJCSI International Journal of Computer Science Issues, Vol. 8, Issue 3, No. 2, May 2011





TABLE II. SOLUTION OBTAINED FOR SEQUENTIAL DETECTOR

| Proposed method              | T.kalganova[10]         | Manual method                             |
|------------------------------|-------------------------|-------------------------------------------|
| D <sub>A</sub> =XB           | D <sub>A</sub> =XB      | D <sub>A</sub> =AC'+AX'+BCX'              |
| D <sub>B</sub> =X'           | D <sub>B</sub> =X'      | D <sub>B</sub> =BX+A'CX                   |
| D <sub>C</sub> =(XAC)'(C+XA) | Dc=XAC'+X'C+A'C         | D <sub>C</sub> =BX+A'C'X'+A'B'X'+<br>AC'X |
| Z=C                          | Z=C                     | Z=A+BC                                    |
| Sub circuits of<br>A,B,C=7   | Sub circuits of A,B,C=8 | Sub circuits of<br>A,B,C=17               |
| Sub circuit D=0              | Sub circuit D=0         | Sub circuit D=2                           |

# 8. Conclusions

This paper, has presented a method to design and optimize the synchronous sequential circuits. In this method, we have separated combinational parts and DFFs of sequential circuit and evolved them separately. This method decreased search space in ES and increased the speed of evolution. In comparison of our method with other methods, our method can design sequential logic circuits better than them and need to less time for evaluating. For future works it can be considered the evolution of the large scale sequential circuits by using proposed method that is applying more in industry.

#### References

[1] Z. Vasicek, L. Sekanina, "Hardware Accelerators for Cartesian Genetic Programming," in proceeding of the 11<sup>th</sup> European Conference on Genetic Programming, vol.4971,pp.230-241, 2008.

[2] E. Stomeo, T. Kalganova, C. Lambert, "Generalized Disjunction Decomposition for Evolvable Hardware," IEEE Trans.Part B 36(5), pp.1024-1043,2006. [3] D. Jackson, "Partitioned Incremental Evolution of Hardware using Genetic Programming," in proceedings of the 11<sup>th</sup> European Conference on Genetic Programming, vol.4971,pp.86-97,(2008).

[4] H. Liang, W. Luo and X. Wang, "A tree-step decomposition method for the evolutionary design of sequential logic circuits," in Genet Program Evolvable Mach, vol.10,pp.231-262, 2009.

[5] T. Higuchi, M. Murakawa, M. Iwata, I. Kajitani, W. Lia, and M.

[6] C. Manovit, C. Aporntewan and P. Chongstitvatana, "Synthesis of Synchronous Sequential Logic Circuits from Partial Input/Output Sequence", vol.1478, pp.98-105,1998.

[7] C. Aporntewan, P. Chongstitvatana, "An On-Line Evolvable Hardware for Learning Finite-State Machine," in Proceeding of int, pp.13-15, 2000.

[8] A. T. Soliman, H.M. Abbas, "Synchronous Sequential Circuits Design using Evolutionary Algorithm," vol.4, pp.2013-2016, 2004.

[9] A. P. Shanthi, L. K. Singaram, "Evolution of Asynchronous ential Circuits," in Proceeding of the 2005 NASA/DoD Conference volvable Hardwarex, pp.93-96, 2005.

B. Ali, A. Almaini and T. Kalganova, "Evolutionary Algorithms and Their Use in the Design of Sequential Logic Circuits," in Genetic Program, Evolvable Machine, vol.5,pp.11-29, 2004.

-[11] http://www.Mathworks.com.

C

12] A. E. A. Almaini, Electronic Logic Systems, Prentice-Hall, 3rd ED.1994,UK.

[13] E. Stomeo, T. Kalganova and C. Lambert, "Generalized Disjunction Decomposition for Evolvable Hardwar", vol.36, No.2, pp.1024-1042, October 2006.

Parisa Soleimani received B.Sc. in Bioelectric Engineering from the Science and Research Branch, Islamic Azad University, Tehran, Iran in 2005. She is M.Sc. candidate in electronic engineering from Central Tehran Branch of Islamic Azad University. Her research interest includes Evolvable Hardware and digital signal processing.

**Reza Sabbaghi-Nadooshan** received the B.Sc. and M.Sc. degree in electrical engineering from the Iran University of Science and Technology, Tehran, Iran, in 1991 and 1994 and the Ph.D. degree in electrical engineering from the Science and Research Branch, Islamic Azad University, Tehran, Iran in 2010. From 1998 he became faculty member of Department of Electronics in Central Tehran branch, Islamic Azad University, Tehran, Iran. His research interests include interconnection networks, Networks-on-Chips, Hardware design and embedded systems.

Sattar Mirzakuchaki received B.Sc. in Electrical Engineering from the University of Mississippi in 1989, and the M.Sc. and PhD in Electrical Engineering from the University of Missouri-Columbia, in 1991 and 1996, respectively. He has been a faculty member of the College of Electrical Engineering at the Iran University of Science and Technology, Tehran, since 1996. His current research interests include characterization of semiconductor devices and design of VLSI circuits. Dr. Mirzakuchaki is a member of IEEE and IET (formerly IEE) and a Chartered Engineer.

**Mahdi Bagheri** received M.Sc. degree in Electrical Engineering from the Iran University of Science and Technology, Tehran, in 2011. His research interests are in evolvable hardware, evolutionary computation, design of digital circuits, and bioengineering applications. He is currently a member of IEEE since 2008.

