An extrinsic function-level evolvable hardware approach by Kalganova, T
An Extrinsic FunctionLevel Evolvable Hardware
Approach
Tatiana Kalganova
School of Computing Napier University
 Colinton Road Edinburgh EH DJ UK
tkalganovadcsnapieracuk
WWW home page httpwwwdcsnapieracuk tatiana
Abstract
 
The function level evolvable hardware approach to syn
thesize the combinational multiplevalued and binary logic functions is
proposed in 	rst time
 The new representation of logic gate in extrinsic
EHW allows us to describe behaviour of any multiinput multioutput
logic function
 The circuit is represented in the form of connections and
functionalities of a rectangular array of building blocks
 Each building
block can implement primitive logic function or any multiinput multi
output logic function de	ned in advance
 The method has been tested
on evolving logic circuits using half adder full adder and multiplier
 The
eectiveness of this approach is investigated for multiplevalued and bi
nary arithmetical functions
 For these functions either method appears to
be much more ecient than similar approach with twoinput oneoutput
cell representation

  Introduction
Evolvable Hardware EHW is technique to synthesize electronic circuits using
genetic algorithms The search for an electronic circuits realization of a desired
transfer characteristic can be made in software as in extrinsic evolution or in
hardware as in intrinsic evolution In extrinsic evolution the entire evolution
process is implemented in the software simulator based on a model of the imple
mentation technology In intrinsic evolution the hardware actively participate in
evolution process 	
In the context of electronic synthesis the con
guration of evolved circuit as
well as connecting elements inside circuit is represented by chromosome Any
genetic operators are applied to the chromosome and obtained new circuits are
compared with target logic function The process in usually ended after a given
number of generation or when the closeness to the target response has been
reached If connecting element is represented by primitive logic function a gate
level EHW approach is applied In the functionlevel EHW approach high level
hardware functions such as adders multipliers etc rather than simple logic func
tions are used as primitive functions in evolution 	 	 Therefore the building
 
To appear in R
 Poli W
 Banzhaf editors Proc of the rd European Conference on
Genetic Programming EuroGP Edinburgh UK SpringerVerlag Spring 

 Tatiana Kalganova
block implements the multiinput oneoutput or multiinput multioutput logic
function
A variety of extrinsic EHW methods have been used to synthesise digital
circuits Table  In most cases primitive functions or multiplexers have been
considered as connecting elements In our work we use multiinput multioutput
logic functions to de
ne the behaviour of connecting elements
Table  Summary of extrinsic EHW approaches for digital circuit design
Author Building
Block
Fitness
function
Evolutionary
approach
Application
Kitano H
   f    Evolutionary pro
gramming
Digital design

Zebulum R
S
 et al
 
f   F GA Binary logic de
sign

Murakawa M
 et al
 
fn   F VGA Adaptive equal
ization

Miller J
 et al 

f  
fnm 
F Cartesian GP Arithmetic bi
nary circuit
design

Kalganova T
 et al
 
f  r
f
m
r    r
F Cartesian GP Multivalued cir
cuit design

Damiani E
 et al
 
f   F Conventional GA Hash function de
sign

Aguirre A
H
 et al
 
f
m
   F F GP Binary circuit de
sign

Kalganova T
 et al
 
f  
f
m
  
F F Cartesian GP Binary circuit de
sign

Masher J
 et al 

f   F F Conventional GA Sorting network
design

Miller J
   f  
f  
F Cartesian GP Low pass 	lter
design

Proposed method f  r
fnm r
F F Cartesian GP Multivalued
logic design

VGA  an variablelength chromosome GA GP  Genetic Programming fnm r is
an ninput moutput rvalued logic function f
m
   is an logic function described
the behaviour of multiplexer F de	nes the correctness of outputs of logic circuit
evolved F is the minimal number of logic cells used F is the correctness of input
combinations F is an error based 	tness

The proposed method is an extension of EHW approach applied for binary
circuit design 	 and multivalued logic MVL functions 	 Some aspects of
this approach have been investigated in the past Thus it has been found that
functional set of logic gates 	 as well as circuit layout and connectivity re
strictions 	 inuence on the GA performance Some attempts to evolve circuit
layout together with circuit functionality have been reported in 	 A dynamic
An Extrinsic FunctionLevel Evolvable Hardware Approach 

tness function has been proposed in 	 that allow us to evolve functional
complete circuit with minimal number of logic gates employed
In this paper we proposed to use multiinput multioutput logic functions as
logic cell so called building block in an extrinsic evolvable hardware approach
We limit our focus to binary and multivalued combinational logic circuit design
problems We introduce the new chromosome representation that allows us to
evolve logic circuits using highlevel logic functions A number of binary and
multivalued circuit structures evolved are discussed The experimental results
show us that the proposed method performs better than one earlier reported in
case if the suitable functional set of logic gates is chosen
 A Problem Statement
Any design problem can be represented as follows Let C
 
and C

be the sets of
values and let X  fx

 x
 
     x
n  
g be an input vector of n variables where
x
k
takes on values from C
 
 Let Y  fy

 y
 
     y
m  
g be an output vector of
m variables where y
k
 C

 Let G be the set of primitive operations over values
from sets C
 
and C

 The cardinality of X de
nes the number of members
of X and denoted as jX j Then jX j  n Let f be the function such that
F  C
n
 
 C
m

 Let function F be represented as a matrix mapping denoted as
X  Y  whereX is a kn matrix of all the given inputs and k is the number of
input combinations and Y is a km matrix of the corresponding m outputs
Then the synthesis of function can be stated as follows Design a sequence of
operations that accomplishes the mapping X  Y  This mapping is achieved
by applying a sequence of primitive or complex operations This statement of
design problem can be applied to any type of functions We will consider the
logic design of binary and multivalued logic functions
Binary circuit design Let B  f g be the set of binary logic values
Then the design of binary circuits can be represented by the equations given
above if C
 
 B  C

 B 
Multivalued circuit design Let R  f      r  g be the set of r
valued logic values Then the multivalued circuit design can be described by
the equations given above if C
 
 R and C

 R The primitive twoinput
multivalued logic operators are de
ned as follows
NOT  x
 
 x
 
 r   x
 
SUCCESSOR  x

 x

  mod r
MIN  x
 
 x

 minx
 
 x


MAX  x
 
 x

 maxx
 
 x


MODSUM  x
 
 x

 x
 
 x

mod r
MODPRODUCT  x
 
	 x

 x
 

 x

mod r
TSUM  x
 
 x

 minx
 
 x

 r  
TPRODUCT  x
 
 x

 minx
 
 x

 r   

where  is an ordinary addition The TPRODUCT operator has been 
rst in
troduced in 	 	 The symbolic representation of MVL operators mentioned
 Tatiana Kalganova
above are shown in Fig  More information about multiplevalued logic can be
found in 	
x1
x2
y
NOT
x1 y
SUCCESSOR MODSUM MODPRODUCT
MIN MAX TSUM TPRODUCT
x1
y x1
x2
y x1
x2
y
x1
x2
y x1
x2
y
x1
x2
y
Fig  Symbols and analytic representation of twoinput r valued logic gates
 FunctionLevel Extrinsic Evolvable Hardware Approach
There are several issues of interest concerning the use of cartesian generic pro
gramming 	 in this domain such as the encoding of building blocks imple
mented multiinput multioutput logic functions mutation operator repair pro
cedures The representation chosen for our work allows us to synthesise the logic
circuits using multiinput multioutput logic subfunctions de
ned in advance
Circuit structure
Circuit Inputs: Circuit Outputs:x0, x1, ..., xn-1 y0, y1, ..., ym-1
n
n+N
r
cur
n+N
r
-1
... ...
n+N
r
*N
c
cur
n+N
r
*N
c
cur +N
r
cur
n+N
r
*N
c
cur+N
r
-1
n+N
r
*(N
c
-1)
0 Nc
cur
...
...
...
...
...
...
Nc-1
... ...
0
Nrcur
N
r
-1
n+N
r
*(N c-1)+N rcur
n+N
r
*Nc-1
...
...
Building block
structure
type: b0
input type: b1
# outputs: b2=p
# inputs: b3=k
inputs [ ]: ih, h {0,..., b3}
i0
i1 Z
(n+N
r
*Nc-1)...ik-1
Z.0
Z.1
...
Z.(p-1)
circuit outputs [ ]: o j, j {0,...,m-1}
building block structures [ ] [ ]: Bs, s {0,..., Nc*Nr-1}
Circuit layout
structure
# columns: Nc
# rows: N
r
connectivity:
N
connect
circuit structure
0   1  ...   (n-1)Input labels:
Fig  Schematic of chromosome structure N
c
 N
r
are the number of columns and
rows respectively N
cur
c
 N
cur
r
are current column and row respectively

 Encoding
A combinational logic circuit is represented as a rectangular array of building
blocks Fig  Each building block is uncommitted and can be removed from
the actual circuit design if they prove to be redundant The building block can
An Extrinsic FunctionLevel Evolvable Hardware Approach 
implement any primary logic operation or multiinput multioutput logic func
tion de
ned in advance The inputs to any building block in the combinational
network may be the primary inputs or any outputs of building blocks which
are in columns to the left of the building block in question The circuit inputs
x

 x
 
     x
n  
are numbered       n respectively The building blocks
which from the array are numbered columnwise from n to nN
c

N
r
 where
N
c
andN
r
are the number of columns and rows in rectangular array The outputs
of building block Bz are labeled from z  D
order
 to z  p D
order

where z is the building block in question p is the number of outputs in building
block B
z
and D
order
de
nes the decimal order of the maximum number of out
puts allowed to be used in building block For example if the maximum number
of output in building block can not exceed  then D
order
  If  outputs
are allowed to be used in building block then D
order
  Thus each output
of building block is de
ned by real number In the work reported we consider
evolving binary and MVL functions Table  shows the set of both binary and
MVL functions employed in evolution
Table  Gate functionality according to the b

z gene in chromosome  denotes
that the logic function is not assigned for encoding value

Gene functionality Gate logic function
b

z binary multivalued
 Logic constant Logic constant
  SUCCESSOR x

 NOT  x

NOT x

  Literal Lx

 c
  Clockwise Operator c x

  Counter Clockwise Operator c x

 Wire x

Wire x

 AND  x

 x
 
MIN  x

 x
 
 OR  x

 x
 
MAX  x

 x
 
 EXOR  x

 x
 
MODSUM  x

 x
 
  MODPRODUCT  x

 x
 
  TSUM  x

 x
 
  TPRODUCT  x

 x
 
  x

 x
 
over GF r
  x

 x
 
over GF r
 Multiplexer Tgate
  digit multiplier
 digit full adder digit full adder
 digit multiplier digit multiplier
 digit full adder digit full adder
 digit multiplier digit multiplier
 digit full adder digit full adder
 Half adder Half adder
 Tatiana Kalganova
The chromosome is represented by a level structure  Circuit layout struc
ture  Circuit structure  Building block structure
Circuit layout structure At the 
rst level the global characteristics of the
circuit are de
ned These are connectivity parameter N
connect
 the number of
rows N
r
and columns N
c
 Note that these parameters are allowed to be variable
but in this paper we consider that the circuit layout is de
ned in advance and
it is not allowed to be changed during evolution process
Circuit structure At the second level the array of building blocks B
i
is
created and the circuit outputs O  fo

 o
 
     o
m
g are determined
(a)
i0i1
ik
z.0
z.1
z.k-1
i2
...
...
...
(b)
Non-standard k-input ( k-1)-output 
building block Z
Z
i0
i1
ik
z.0
z.1
z.p
k-input p-output building block
b
z
=< b0, b 1, b 2, b 3, I>
Fig  Schematic of building block structure

Building block structure Finally the third level represents the structure
of each building block in the networkN  This data consists of the functional gene
b

 the type of inputs b
 
 the number of outputs b

and inputs b

and the input
connections i
h
 Fig  Fig a  In this work the gene b
 
de
ning the type of
inputs in building block has not been taken into account The number of inputs
and outputs in building block depend on the functional type of building block b

and are de
ned if the value of functional gene is known Thus if functional gene
de
nes the primitive logic function then variable number of inputs in building
block can be used In this case the primitive logic gates are connected as shown
in Fig b For example let    de
nes the input output logic primitive
function and b

  The number of outputs in building block is  These outputs
can be analytically represented as follows
o

z  i

 i
 

o
 
z  i

 i
 
  i


o

z  i

 i
 
  i

  i


If multiinput multioutput logic functions de
ned in advance is employed then
the number of inputs and outputs in building block are 
xed and can not be
changed For example the binary twobit full adder has  inputs and  outputs
So if the functional gene of building block is  b

  then b

  and
b

 
An Extrinsic FunctionLevel Evolvable Hardware Approach 
Logic function : add2c.pla
Functionality: 100%
The number of active gates:  11
Circuit structure:
Circuit layout: 5 x 2
Circuit outputs:   13.0   11.0   8.1
x3
x4
9 0 1 2 {3 4 3}
5
x1
5
8
add1
22  0 2 2 {1 5 1}
8.0
8.1Y2
x3
x4
7 0 1 2 {3 4 3}
6
8
6
8 0 1 2 {8 6 2}
9
x0
7
9 0 1 2 {0 7 5}
10
x2
x0
9 0 1 2 {2 0 1}
7
9
7
9 0 1 2 {9 7 5}
11
Y1
10
7
7 0 1 2 {10 7 1}
12
x0
12
9 0 1 2 {0 12 5}
13
Y0
x4
8.1
14
add1
22  0 2 2 {4 8.1 5}
14.0
14.1
0:  x0
1:  x1
2:  x2
3:  x3
4:  x4
Circuit inputs:
Fig  An example of the phenotype and corresponding genotype of a chromosome
with x circuit layout
 An example
An example of chromosome representation with the actual circuit structure is
given in Fig  This circuit represents the full bit adder evolved using AND
OR EXOR and half adder binary logic functions This function has  inputs
and  outputs and is implemented on a combinational network with x circuit
layout N
c
 N
r
 The labels of circuit inputs      correspond to the
input variables x

 x
 
 x

 x

and x

respectively The type of building block is
de
ned by functional gene shown in bold The encoding table of functional gene
is given in Table 
Each cell is assigned an individual address Thus the building block located
in th column and th row is labeled as  The building block located in th
column st row is labeled as  Each output of building block is labeled with real
number The main part of this number de
nes the code of building block and the
fractional part determines the position of output in building block For example
the th building block B

located in st row and st column has  outputs
The 
rst output is numbered as  and the second one as  The number
of circuit outputs is de
ned by the number of outputs in the logic function
implemented Let us examine the encoding of the th building block represented
as      f  g  We refer to this representation of the building block
as building block genotype The functional gene de
ning the type of this gate is
 This corresponds to the half adder in encoding table Table  The examined
cell has two inputs and two outputs The 
rst input is connected to the input x

and second to the second output of building block  labeled as  The inputs
of building block  are connected to input variable x
 
and output of building
block  The logic function of building block  depends on the input variables x

and x

 Therefore the logic function implemented in building block  depends
on three input variables x
 
 x

and x

 The outputs of circuit are connected to
the outputs of building blocks   and 
 Tatiana Kalganova
 Fitness Function
Our goal is to produce a fully functional design and minimize the number of
building blocks actually used in circuit A fully functional design produces the
expected behavior stated by its truth table Therefore we decided to use two
stage 
tness strategy 	 At the beginning of search only compliance with the
truth table is taken into account Once the 
rst functional solution appears we
switch to a new 
tness function in which fully functional circuits with less cost
are rewarded The cost or size of the fully functional circuit N is de
ned as
costN  
jN
c
N
r
  
X
j
costB
j
 
and the cost of building block B
j
is calculated as
costB
j
 

N
p
j
 B
j
is committed building block
 B
j
is uncommitted building block

where N
p
j
is the minimum number of primitive logic cells required to implement
the logic function described behaviour of building block B
j

We consider the building block B
j
as a subcircuit with the structure that
is not allowed to be changed So the cost of building block does not take into
account whatever all outputs of building block has been involved or not For
example let the twobit multiplier be represented as building block B
j
and the

rst digit of this twobit multiplier be only involved in circuitN  The cost of two
bit multiplier is  	 Despite the 
rst digit of twobit multiplier is implemented
using only one primitive logic gate the cost of building block B
j
is  Members
of the population with changed genotype have their 
tness calculated
 Evolutionary algorithm
The circuit evolution has been performed using a rudimentary    evolu
tionary strategy ES with uniform mutation 	 In this case a population of
random chromosomes is generated and the 
ttest chromosome is selected The
new population is then 
lled with mutated versions of this
Initialisation The initial population is generated randomly During initial
isation of cell inputs and circuit outputs is performed in accordance with the
levelsback constraint and the type of variables which are able to be present
throughout all circuit Thus if the logic constants are allowed as input connec
tions throughout the circuit then during initialisation procedure the inputs of
gates can be chosen from the set of inputs constrained by levelsback or from the
set of logical constants The same procedure is true for the primary and inverted
primary inputs
Mutation The circuit mutation allows us to change the following three
features of the circuit  Cell input  Cell type  Circuit output Each
of these parameters is considered as an elementary unit of the genotype Cell
An Extrinsic FunctionLevel Evolvable Hardware Approach 
type is de
ned by the functional gene and the functionality gene The mutation
rate de
nes how many genes in the population are involved in mutation The
chromosome contains  dierent types of genes whose number is 
N
genes


X
i 
 N

gates
N
outputs
 
where N
outputs
is the number of outputs in the circuit N
i
gates
is the number of
gates in the ith chromosome  is the population size
 Experimental Results
In this section we will consider some experimental results obtained for function
and gatelevel EHW Two applications to EHW approach has been examined 
Binary arithmetic circuit design  Multivalued arithmetic circuit design For
the purposes of this paper  examples were chosen to illustrate our approach The
performance of functionand gate level EHW approaches has been compared
The initial data for the experiments is given in Table 
Table  Initial data
Logic functions
binary multivalued
Circuit mult mult addc add c mult 
Circuit layout x x x x x
Connectivity parameter     
Population size     
Number of generations          
Number of GA runs     
Mutation rate     
Twobit full adder	 addcpla One of the principles used by human to
construct larger adders is known as the ripplecarry principle The block dia
gram for a two bit adder is shown in Fig a Each of the blocks in Fig a
are identical to onebit full adder The two bit full adder evolved using onebit
full adder is produced by connecting the two smaller adders in a con
guration
identical to that shown in Fig a This structure has been appeared in the
most circuit designs approximately   of all fully functional designs evolved
using onebit full adder as a building block This demonstrates that the ES 
nds
principles of the ripplecarry adder
The circuit shown in Fig  b has been evolved using onebit full adder and
twobit multiplier as building blocks This circuit requires  logic cells Note
that only third output of two bit multiplier is used This shows that there is not
necessary that all outputs of multiinput multioutput building blocks can be
exploited in the circuit
 Tatiana Kalganova
(a)
1
x4
x3
2
x3
x0
x2
3
x1
x3
mult2
4 Y1 6
FA
7
x0
x2
Y0
5
x4 Y2
(b)
x4
x3 x2
x0
Y0FA
1
FA
2
x1
Y1
Y2
Fig  Evolved bit full adder FA is onebit full adder mult is twobit multiplier

x2
x5
Y5
x0
x3
x3
x0
mult2
2
x4
x1
5
x4
x1
mult2
3
x5
x2
Y4
8
7
Y3
10
Y0
9
6
11
12
Y2
13
Y1
mult2
1 4
Fig 	 Evolved threebit multiplier most ecient   gates mult is twobit multi
plier

An Extrinsic FunctionLevel Evolvable Hardware Approach 
Threebit multiplier	 multpla The bit multiplier can calculate the
product of two integers a and b in range  The conventional bit multiplier
designed at gatelevel requires  primitive logic gates 	 The most ecient
bit multiplier evolved at gatelevel requires only  gates 	 Note that this
structure contains  logic cells implemented AND logic function with one in
verted input In our approach we count only the number of NOT AND EXOR
and OR gates Therefore in our calculations AND with one inverted input re
quires  primitive logic gates AND and NOT From this point of view the circuit
structure reported in 	 contains  primitive logic gates such as AND OR
EXOR and NOT It is more important to point out that this solution has been
evolved after  generations whereas in case of using the functionlevel
EHW the fully functional solution has been evolved after  generations In
this particular example the evolution process has been improved in  times It
shows that using functionlevel EHW allows us to improve the ES performance
The most ecient evolved bit multiplier at function level is shown in Fig
 This circuit requires  gates The cost of this circuit has been calculated
regardless the outputs used in twobit multiplier building blocks Note that the
second output of multipliers  and  is not used This output requires  logic
gates to be implemented Only one logic gate is used to implement another
output of twobit multiplier 	 This means that  logic gates are employed
to implement the second output and are not used in implementation of other
circuit outputs Therefore the circuit shown in Fig  requires  primitive logic
gates  such as AND OR and NOT Therefore we can conclude that
this is the most ecient circuit structure evolved using both gate and function
level EHW
S1
x0
S0
2
add1
1.0
1.1
x1
x2
1
add1 2.0
2.1
(a)
S1
x2
S0
2
add1
1.0
1.1
x1
x0
1
add1 2.0
2.1
(b)
Fig 
 Evolved valued digit full adders add is valued half adder

Onedigit valued full adder	 add cpla Evolving a fully functional
valued onedigit adder using a circuit layout of  columns and  row with
connectivity parameter equaled  proved to be relatively easy and the designs
shown in Fig  were obtained The circuit shown in Fig  a contains only 
building blocks Note that the optimal implementation of half adder contains 
primitive logic cells 	 Therefore the circuit in question requires  primitive logic
cells It is interesting to note that in this structure all outputs of half adder have
been used actively In case when the MAX gate is not allowed to be involved
in evolution the circuit structure shown in Fig  b has been evolved This
 Tatiana Kalganova
structure contains  building blocks and requires  primitive logic cells Note
that both structures mentioned above use all outputs of half adder
The 
digit Multiplier	 mult pla An digit multiplier multiplies
the r valued numbers A
 
A

 by B

to produce the twodigit r valued number
P
 
P

 where A
 
 B

and P
 
are the most signi
cant digits Thus this is a circuit
with  inputs and  outputs and it requires  input and output conditions for full
speci
cation in case of valued logic An example of circuit structures evolved
using proposed method are shown in Fig  It is interesting to note that in
case of circuit shown in Fig a ES uses the outputs of half adder and one
digit multiplier as subfunctions and some of its outputs are not in use Thus
the 
rst output of valued digit multiplier labeled as  does not employed
At the same time all outputs of half adder are used The circuit contains 
building blocks and involves  primitive logic cells Note that the most ecient
digit multiplier evolved requires  primitive logic cells Fig b shows the
circuit evolved using only half adder This circuit requires  building blocks and
 primitive logic cells Note that the implementation of digit P
 
is the same
for both cases It is interesting to note that the circuit evolved with half adder
and onedigit multiplier requires less number of primitive logic cells then the
alternative logic function evolved using only half adder The circuits shown in
Fig  can not be obtained using the rules of standard multiplication process
P1
x0
x1
x2
P0
2
add1
2.0
2.1
x0
x1
x2
6
mult1x2
6.0
6.1
1
3
4
5
7
(a)
P1x0
x1
x2
P0
2
add1
2.0
2.1
x0
x1
3
add1 x2
3.0
3.1
1
4
5 6
(b)
Fig  Evolved valued 
digit multiplier
 add is a valued half adder mult is
valued digit multiplier

Binary circuit design In this section we will discuss some experimental
results obtained for twobit full adder addcpla two multpla and three bit
multipliers multpla evolved at gate and function level EHW The ES performs
the 
xed number of generations for both approaches The functional set of logic
gates for gatelevel EHW is a subset of fAND OR EXOR NOTg Note that
using functional set of NOT AND OR EXORie  according to encoding
An Extrinsic FunctionLevel Evolvable Hardware Approach 
Table  Comparison function and gatelevels EHW
 avF is the mean functionality
	tness function of the best chromosomes obtained  runs avF is the mean number
of active logic gates in the best chromosomes obtained after  runs avF is the
mean number of active logic gates in the fully functional designs evolved 
cases is the number of fully functional circuits evolved

Circuit n m Functional set avF avF avF  cases
mult
pla    
 
 
 
 
 
  
 
 
 
 
 
 
 
 
mult
pla    
 
  
 
 
 
 
 
 
  
 
 
 
 	
addc
pla    
 
 
 
 
 
 
 
 
 
 
 	
 
 
 
 
add c    
 
  
 
 
 
 


 
 
  
 
 
  	
 
 
  
 
 
 
 	
mult     
 
  
 
 
 
 	
 
 
 
 
 
 
  
 
 
 
 
 
 
  
 
 
 
 	
 
 
 
 

table Table  in evolution corresponds performing EHW at gatelevel The
number of inputs in building block for gatelevel EHW can not be more then 
Half bit adder onebit full multiplier twobit multiplier together with primitive
logic gates have been used at functionlevel EHW The experimental results
obtained using initial data shown in Table  are summarized in Table  The
number of fully functional solutions evolved at functionlevel EHW is shown in
bold 
Let us consider how ES performs at gate and functionlevel EHW during
evolution of twobit multiplier  Analysing these data we can conclude that
in terms of the number of active primitive logic gates used in circuit the gate
and functionlevel EHW perform better Thus the average number of active
logic gates avF in fully functional circuits evolved at gatelevel is 
and at functionlevel is  or more In terms of the number of fully functional
 Tatiana Kalganova
circuits evolved during  ES runs both methods perform nearly the same 
 fully functional designs have been evolved during  ES runs Considering
ES performance for threebit multiplier carried out at gate and functionlevel we
can conclude that the functionlevel EHW executes much better Thus during
evolution at gate level the average functionality of evolved circuits is 
and at function level it has been signi
cantly increased to  No fully
functional solutions have been evolved for threebit multiplier at gatelevel EHW
Some functional solutions has been found using functionlevel EHW Comparing
function and gatelevel EHW used to evolve twobit full adder we 
nd that
the number of fully functional designs obtained at functionlevel EHW has been
signi
cantly improved in comparison with the similar EHW performed at gate
level The average functionality 
tness function is higher for functionlevel EHW
rather then for gatelevel EHW
Note that in all cases mentioned above the average best functionality 
t
ness functions avF for tested logic functions we can conclude that the best
functionality 
tness function is lower in case when the gatelevel EHW has been
applied Analysing the average number of active primitive logic gates in best
fully functional chromosomes avF we 
nd that there is no signi
cant dif
ference between function and gatelevel EHW in case when threebit multiplier
and twobit full adder have bit evolved Note that in case of evolving the twobit
multiplier the ES at gatelevel performs better in terms of the number of active
primitive logic gates in circuit Thus we can conclude that functionlevel EHW
performs better then gatelevel EHW in terms of the number of fully functional
binary circuits evolved when the suitable functional set of logic gates has been
chosen
Multivalued circuit design The similar experimental results have been
carried out for valued onedigit full adder add pla and valued  digit
multiplier mult pla
Let us consider valued onedigit full adder Three dierent functional sets
of primitive logic gates have been employed during gatelevel EHW execution At
functionlevel EHW the valued half adder has been added to these functional
sets In all cases the functionlevel EHW method performs better Thus when
we use functional set of fCOMPLEMENT MIN MAX TSUM TPRODUCTg
no fully functional solutions have been evolved Adding only half digit adder in
functional set improves the GA performance in  times The same conclusion
we can made about other functional sets of logic gates used Three dierent
functional sets of primitive logic gates have been used at gatelevel EHW Half
adder and onedigit multiplier have been added to functional set of logic gates
at functionlevel EHW Analysis of  digit multiplier allows us to make the
conclusion that the functionlevel EHW performs better in term of the number
of fully functional circuits evolved Note that no fully functional designs have
been evolved at gatelevel This number has been signi
cantly increased when
functionlevel evolution has been applied
An Extrinsic FunctionLevel Evolvable Hardware Approach 
Thus we can conclude that the functionlevel EHW approach applied to
multivalued logic design performs better then the similar approach implemented
at gatelevel if the suitable functional set of logic cells has been chosen
 Conclusion
We have introduced a new representation of logic cell in extrinsic EHW This
representation allows us to evolve circuits at functionlevel evolvable hardware
WE showed that this approach can be applied to synthesize both multiplevalued
and binary logic functions The advantage of proposed method is that it does
not restricted by the radix of logic or the set of logic cells functions chosen to
describe the behaviour of building blocks
We have compared the ES performance for function and gatelevel EHW
methods applied to design binary and multivalued logic circuits The obtained
results show that the functionlevel EHW performs better in terms of the num
ber of fully functional solutions evolved Also it has been shown that the most
ecient bit multiplier evolved at function level evolution contains  primi
tive logic gates This design less the number of active primitive logic gates then
the similar conventional one Also it has been shown that the evolved design
contains less the number of primitive logic gates such as NOTAND EXOR
and OR then the similar most ecient design evolved at gate level 	 The
experimental results show that the proposed chromosome representation allows
us easier to evolve arithmetic MVL functions if the appropriate set of standard
logic functions has been chosen
The future work can be focused on the using multiinput multioutput au
tomatically de
ned logic functions as a building blocks in proposed method as
well as attempts to evolve logic functions of large number of variables
References

 Stoica A
 Keymeulen D
 Tawel R
 SalazarLazaro C
 and Li W
 Evolutionary
experiments with a 	negrained recon	gurable architecture for analog and digital
cmos circuits
 In Stoica A
 Keymeulen D
 and Lohn J
 editors Proc of the
First NASADoD Workshop on Evolvable Hardware pages 
 IEEE Computer
Society July 


 Murakawa M
 Yoshizawa S
 Kajitani I
 Furuya T
 Iwata M
 and Higuchi T

Hardware evolution at function level
 In Proc of the Fifth International Conference
on Parallel Problem Solving from Nature PPSNIV	 Lecture Notes in Computer
Science
 SpringerVerlag Heidelberg 


 Higuchi T
 Murakawa M
 Iwata M
 Kajitani I
 Liu W
 and Salami M
 Evolvable
hardware at function level
 In Proc of IEEE 
th Int Conference on Evolutionary
Computation CEC
 IEEE Press NJ 


 Kitano H
 Morphogenesis for evolvable systems
 In Sanchez E
 and Tomassini M

editors Towards Evolvable Hardware The Evolutionary Engineering Approach
volume  of Lecture Notes in Computer Science pages 
 SpringerVerlag


 Tatiana Kalganova

 ZebulumR
 M
 Vellasco and M
 Pacheco
 Evolvable hardware systems Taxonomy
survey and applications
 In Proc Of the st Int Conf on Evolvable Systems
From Biology to Hardware ICES	 volume  of Lecture Notes in Computer
Science pages  Tsukuba Japan 
 SpringerVerlag Heidelberg


 Murakawa M
 Yoshizawa S
 and Higuchi T
 Adaptive equalization of digital com
munication channels using evolvable hardware
 In Proc Of the st Int Conf
on Evolvable Systems From Biology to Hardware ICES	 volume  of Lec
ture Notes in Computer Science pages  Tsukuba Japan 
 Springer
Verlag Heidelberg


 Miller J
 F
 Thomson P
 and Fogarty T
 C
 Genetic algorithms and evolution
strategies
 In Quagliarella D
 Periaux J
 Poloni C
 and Winter G
 editors Engi
neering and Computer Science Recent Advancements and Industrial Applications

Wiley 


 Kalganova T
 Miller J
 and Fogarty T
 Some aspects of an evolvable hardware
approach for multiplevalued combinational circuit design
 In Sipper M
 Mange
D
 and PerezUribe A
 editors Proc Of the nd Int Conf on Evolvable Systems
From Biology to Hardware ICES	 volume  of Lecture Notes in Computer
Science pages  Lausanne Switzerland 
 SpringerVerlag Heidelberg


 Damiani E
 Tettamanzi A
G
B
 and Liberali V
 Online evolution of fpgabased
circuits A case study on hash functions
 In Stoica A
 Keymeulen D
 and Lohn
J
 editors Proc of the First NASADoD Workshop on Evolvable Hardware pages

 IEEE Computer Society July 


 Aguirre A
H
 Coello Coello C
A
 and Buckles B
P
 A genetic programming ap
proach to logic function sunthesis by means of multiplexer
 In Stoica A
 Keymeulen
D
 and Lohn J
 editors Proc of the First NASADoD Workshop on Evolvable
Hardware pages 
 IEEE Computer Society July 


 Kalganova T
 and Miller J
 Evolving more ecient digital circuits by allowing cir
cuit layout evolution and multiobjective 	tness
 In Stoica A
 Keymeulen D
 and
Lohn J
 editors Proc of the First NASADoD Workshop on Evolvable Hardware
pages 
 IEEE Computer Society July 


 Masher J
 Cavalieri J
 Frenzel J
 and Foster J
A
 Representation and robustness
for evolved sorting networks
 In Stoica A
 Keymeulen D
 and Lohn J
 editors
Proc of the First NASADoD Workshop on Evolvable Hardware pages 

IEEE Computer Society July 


 Miller J
 On the 	ltering properties of evolved gate arrays
 In Stoica A
 Keymeulen
D
 and Lohn J
 editors Proc of the First NASADoD Workshop on Evolvable
Hardware pages 
 IEEE Computer Society July 


 Kalganova T
 Miller J
 and Lipnitskaya N
 Multiplevalued combinational circuits
synthesized using evolvable hardware approach
 In Proc of the th Workshop on
PostBinary Ultra Large Scale Integration Systems ULSI	 in association with
ISMVL Fukuoka Japan May 
 IEEE Press


 Utsumi T
 Kamiura N
 Nata Y
 and Yamato K
 Multiplevalued programmable
logic arrays with universal literals
 In Proc of the th Int Symposium on Miltiple
Valued Logic ISMVL	 pages  Nova Scotia Canada May 
 IEEE
CSPress


 Hata Y
 and K
 Yamato
 Multiplevalued logic functions represented by tsum
tproduct not and variables
 In Proc of the th Int Symposium on Miltiple
Valued Logic ISMVL	 pages 
 IEEECSPress May 


 D
 C
 Rine
 An Introduction to MultipleValued Logic
 NorthHolland Amsterdam


An Extrinsic FunctionLevel Evolvable Hardware Approach 

 Miller J
 An empirical study of the eciency of learning boolean functions using a
cartesian genetic programming approach
 In Proc of the Genetic and Evolutionary
Computation Conference GECCO	 volume  of ISBN 
 pages
 Orlando USA July 
 Morgan Kaufmann San Francisco CA


 Miller J
 Digital 	lter design at gatelevel using evolutionary algorithms
 In Proc
of the Genetic and Evolutionary Computation Conference GECCO	 volume 
of ISBN 
 pages  Orlando USA July 
 Morgan Kauf
mann San Francisco CA


 Miller J
F
 Kalganova T
 Lipnitskaya N
 and Job D
 The genetic algorithm as
a discovery engine Strange circuits and new principles
 In Proc of the AISB
Symposium on Creative Evolutionary Systems CES ISBN  pages

 Edinburgh UK The Society for the Study of Ari	cial Intelligence and
Simulation of Behaviour April 


 Coello C
 A
 Christiansen A
 D
 and Hernndez A
 A
 Use of evolutionary tech
niques to automate the design of combinational circuits
 International Journal of
Smart Engineering System Design 

