Stochastic and PWM coding for an efficient implementation of Cellular Neural Networks by Colodro Ruiz, Francisco et al.
Stochastic and PWM coding for an ef®cient
implementation of Cellular Neural Networks
F.Colodro, A.Torralba, R.G.Carvajal and L.G.Franquelo
Dpto. de IngenierÂõa Electr Âonica,
Escuela Superior de Ingenieros
Avda. Reina Mercedes, s/n, SEVILLA±41012 (Spain)
Tlf: 34±5±4556849, Fax: 34±5±4629205
e±mail: pcolr@gte.esi.us.es
AbstractÐ This paper present the application of Pulse Stream Tech-
niques (PSTs) to the hardware implementation of a Cellular Neural
Network. The time differential equation of this networks suggests
that the dynamic of one neuron status can be emulated by adding
discretized packets of charge to a capacitor. This task can be carried
out by driving a current source with a pulse stream signal.
I. INTRODUCTION
Different strategies of design have been used for inte-
grated electronic implementation of Neural Networks
(NNs). Based on digital or/and analog technologies,
many arquitectures have been described in the liter-
ature. The advantages and drawbacks of analog and
digital computing are well±known. To overcome these
drawbacks, Pulse Stream Techniques (PSTs) have been
proposed [1]. PSTs take the advantages of both, digi-
tal and analog implementations, as the information is
carried by digital signals and analog circuitry is used
to control them.
The most common PSTs are Stochastic Logic (SL) and
Pulse Width Modulation (PWM). In SL, a signal is rep-
resented by a stochastic pulse stream which takes the
value 1 with a probability proportional to the instan-
taneous value of the signal. The main advantage of
SL relies on the fact that the product of two stochas-
tic signals can be implemented by means of a simple
AND gate. On the other hand, there is not a direct
way to implement the summation in a digital way. In
[2], a digital circuit called F was proposed, which is
able to make the summation of n stochastic pulses in
one clock cycle, at the cost of some hardware com-
plexity. A more ef®cient implementation can be made
if current±mode analog summation is used, as shown
bellow.
If one of the two stochastic signals in the input of a
AND gate is replaced by a Pulse Width Modulation
(PWM) signal, the AND gate still carries out the mul-
tiplication operation. The product signal can be used
to switch on/off a constant current which feeds a ca-
pacitor. In this way it is possible to carry out the
sysnapses product of a Neural Network. Based on
this principles, the basic architecture of one neuron is
presented in this paper. In section II the architecture
is used to build an ef®cient implementation of a Cel-
lular Neural Network (CNN). A detailed description of
the basic modules and the result obtained from sim-
ulations are presented in section III, and ®nally some
conclusions are discussed in section IV.
II. THE NEURON STATE OF A CNN
.. . .
.
. +
-
sum line
Io
I off I Rx
AND1
AND2
AND3
S1
S2
CMT
A(i,j;k,l)S
Pv’kl
{A(i,j;k,l}SGN
{A(i,j;k,l}SGN
Pvyij
Io
Io
φ1
φ2
Figure 1: Block diagram of a neuron
A Cellular Neural Network (CNN) is an analog dy-
namic processor array, where the processing elements
interact within a ®nite local neighborhood. The orig-
inal CNN paradigm was ®rst proposed by Chua and
Yang in [3] and [4]. A concise tutorial on CNNs can
be found in [5]. A review of selected communications
in the ®eld of CNN theory and applications, and a
simulator with many examples, can be found in [6].
Integrated implementation of CNNs can be found in
[7]±[15]. An implementation based on Pulse Stream
current mode can be found in [16]
The differential equations governing the (i; j)±th neu-
ron in a CNN is given by [3]:
Cd v
xij
d t
=  
1
R
x
v
xij
+
X
C(k;l) 2 N
r
(i;j)
A(i; j; k; l)  v
ykl
+
(1)
X
C(k;l) 2 N
r
(i;j)
B(i; j; k; l)  v
ukl
+ I
off
v
yij
= f(v
xij
) (2)
where v
xij
, v
yij
and v
uij
are the status, output and
input of cell (i; j), respectively. C and R
x
are CNN
parameters. I
off
is a bias term. N
r
(i; j) is a neighbor-
hood of radius r around the (i; j)±th cell. A(i; j;k; l)
and B(i; j; k; l) are the feedback and forward matri-
ces associated to the cell (i; j), respectively [3]. The
piece-wise linear function f is a saturated activation
function. The time discretized charging equations (1)
and (2) of a CNN is implemented electronically by the
circuit shown in ®gure 1. This architecture reproduces
the behavioural of one unipolar neuron. (Note that
CNNs with bipolar neurons are easily converted to
unipolar neurons, with only a change in the bias term
I
off
).
The stochactic signal S
A(i;j;k;l) and the PWM signal
P
v
ykl
are pulse streams which represent the values of
A(i; j; k; l) and v
ykl
, respectively. So, the gate AND1
performs the product A(i; j; k; l) v
ykl
. The product
pulse drives a bipolar current source and, depend-
ing on the sign of A(i; j; k; l), charges o discharges a
summation capacitor. In a space±invariant CNN, the
templates A and B are shared by all the neurons, so
that the stochastic pulses S
A(i;j;k;l) and SB(i;j;k;l) are
obtained only once in a common module and later
propagated to the rest of the chip with a considerable
saving in silicon area. Note that a broadcast propaga-
tion is possible in our implementation, because these
pulse streams are digital signals.
III. BASIC MODULES OF THE NEURON STATE
PWM signals are associated to neuron outputs. PWM
coding has been selected, because it can be imple-
mented with a local ramp generator and a comparator
(®gures 1 and 2). The comparator and the local ramp
generator are used to generate the PWM signalP
v
yij
,
which is fedback to drive the slave part of a high±
swing cascade current mirror (Fig.- 2). In this way it is
possible to take into account the effect of the resistor
R
x
(equation 1) using the current I
R
x
. A dummy tran-
sistor was used to reduce the charge±injection prob-
lem; the capacitor can be implemented by means of
the gate capacitance of a transistor in a digital CMOS
technology.
The circuit in ®gure 2 has been designed using a 1:0m
Vref
Vref
.
.
+
-
I off
CMT
P.
. ..
.
.
. RAMP
GEN.
sum line
.
.
vyij
IRx +
-
xijV
Figure 2: State of a CNN using a PST
Figure 3: Continuous time dimamic of a circuit RC and the circuit in
®gure 2: a) Charging and b) Discharging.
φφ
φ
φ
φ
1
1 1
2 2
φ2
.
.
.
.
. .
..
.
.
.
V
V
V
V
VDD
ref1
ref2
ref
ref
I
I
o
o
sum line
Figure 4: Current mirrors used for driving the cell capacitor.
5V , digital CMOS technology. The current I
off
was
adjusted to obtain a steady state value of 2:5V in
the capacitor. The simulation results (obtained from
HSPICE) of the circuit in Fig. 2 using two different ini-
tial values are depicted in ®gures 3.a and 3.b. The time
evolution of a RC circuit for the same initial values is
superimposed.
The current sources and the switches,which are driven
by the productsA(i; j;k; l)v
ykl
andB(i; j; k; l)V
ukl
,
have been built using two high±swing cascode current
mirrors as shown in ®gure 4. The pulse stream signals
1 and 2 represent the synaptic products (outputs of
the gates AND2 and AND3 in Fig. 1, respectivelly)
associated to the cell in ®gure 4.
High±level language C simulations have shown that
the computational strategy proposed in this paper is
a good way for implementation Cellular Neural Net-
works. The simulated networks was able to success-
fully solve an edge extraction problem of a 21  21
picture.
The comparation of the evolution of the summation ca-
pacitance voltage when the results are obtained from
language C and HSPICE simulations are shown in ®g-
ures 5.a and 5.b in two different cases. In both cases,
the same stochastic signals associated to the synap-
tic weight were used in C and HSPICE. In this way
we avoid that the simulation results were affected by
different behaviour due to the random nature of the
stochastic signals. The neighbor pixel values were cho-
sen so that the ®nal values of the cell state voltage was
0V in the ®rst case (Fig. 5.a) and 5V in the second case
(Fig. 5.b). Both ®gures verify that the pulse stream
computational strategy can be implemented using a
CMOS technology while preserving high accuracy.
−2.3 17.7 37.7
Time (microsecond)
0.6
1.1
1.6
2.1
2.6
Vo
lta
ge
 (V
)
High−level language simulation result
HSPICE result
−10.0 40.0 90.0 140.0 190.0
Time (microsecond)
1.9
2.4
2.9
3.4
3.9
Vo
lta
ge
 (V
)
High−level simulation result
HSPICE result
Figure 5: Comparation between the language C and HSPICE results
when the ®nal values of the cell state voltage is (a) 0V and (b) 5V
IV. CONCLUSIONS
The application of Pulse Stream Techniques (PSTs) to
the hardware implementation of Cellullar Neural Net-
works has been presented in this paper. The main
features of the proposed architecture are:
 The information is codi®ed by digital signals
which are very robust againts noise and inter-
ferences.
 The stochastic nature of some signals allow to im-
plement the multiplication using a simple AND
gate. The summation is performed in a current
mode approach. Both features allow to perform
the computation using a simple circuitry with
high accuaracy.
 The feedforward and feedback operators can be
stored in digital memory. In case of CNNs with
invariant templates, the number of these weights
is small and the ef®ciency in silicon area is pre-
served.
 Due to the stochastic codi®cation of these
weights, they can be propagated through the
ASIC without corruption using a reduced num-
ber of physical lines.
High±level language simulations have been done in
order to check the behaviour of a network when it is
implemented using PSTs. Results of transistor±level
simulations have been compared with the results of
high±level simulations for the case of one neuron and
they have been demonstrated negligible non±ideal ef-
fect. PSTs seem to be a promising way to build large
arrays with programmable synapses. Presently we are
designing the neuron layout to build a 21  21 CNN
array using a 1 digital CMOS technology to experi-
mentally demonstrate the advantages of the proposed
architecture.
ACKNOWLEDGMENTS
This work has been supported by the Spanish
ComisiÂon Interministerial de Ciencia y TecnologÂõa (CI-
CYT), under project TIC96±0860.
REFERENCES
[1] A.Murray, D.del Corso and L.Tarassenlo. ªPulse±
Stream VLSI neural networks mixing analog and
digital techniquesº. IEEE Trans. on Neural Net-
works, vol. 2, n. 2, pp. 193±204, Mar. 1991.
[2] A.Torralba, F.Colodro. ªTwo digital circuits for a
Fully Parallel Stochastic Neural Networkº. IEEE.
Trans. of Neural Network, vol. 6, no 5, 1264±1268,
SEP. 1995.
[3] L.O.Chua and L.Yang. ªCellular Neural Net-
works: Theoryº. IEEE Trans. on CAS, vol. 35, n.
10, pp. 1257±1272. Oct. 1988.
[4] L.O.Chua and L.Yang. ªCellular Neural Net-
works: Applicationsº. IEEE Trans. on CAS, vol.
35, n. 10, pp. 1273±1290. Oct. 1988.
[5] L.O.Chua and T.Toska. ªThe CNN Paradigmº.
IEEE Trans. on CAS±I, vol. 40, n. 3, pp. 147±156.
March 1993.
[6] Cellular
Neural Networks. T.Roska and J.Vandewalle eds.
John Wiley & Sons: Chichester 1993.
[7] J.M.Cruz, L.O.Chua. ªA CNN chip for connected
component detectionº. IEEE Trans. on Circuits and
Systems, vol. 38, pp. 812±817, July 1991.
[8] H.Harrer, J.A.Nossek and R.Stelzl. ªAn analog
implementation of discrete±time cellular neural
networksº. IEEE Trans. on Neural Networks, vol. 3,
pp. 466±476, May 1992.
[9] A.RodrÂõguez VÂaquez, S.Espejo, R.DomÂõnguez
Castro, J.L.Huertas and E.SÂanchez Sinencio.
ªCurrent±mode techniques for the implementa-
tion of continuous± and discrete±time cellular
neural networksº, IEEE Trans. on Circuits and
Systems±II, vol. 40, pp. 132±146, Mar. 1993.
[10] J.E.Varrientos, E.SÂanchez Sinencio and J.RamÂõrez
Angulo. ªA current±mode cellular neural net-
work implementationº. IEEE Trans. on Circuits
and Systems±II, vol. 40, pp. 147±155, Mar. 1993.
[11] I.A.Baktir, M.A.Tan. ªAnalog CMOS implemen-
tation of cellular neural networksº, IEEE Trans. on
Circuits and Systems±II, vol. 40, pp. 200±206, Mar.
1993.
[12] G.F.D.Betta, S.Graf®, Z.M.Kovacs, G.Massetti.
ªCMOS implementation of an analogically pro-
grammable cellular neural networkº, IEEE Trans.
on Circuits and Systems±II, vol. 40, pp. 206±215,
Mar. 1993.
[13] M.Anguita, F.J.Pelayo, A.Prieto and J.Ortega.
ªAnalog CMOS implementation of a discrete±
time CNN with programmable cloning tem-
platesº. IEEE Trans. on Circuits and Systems±II, vol.
40, pp. 215±218, Mar. 1993.
[14] A.Paasio, A. Dawidziuk and V. Porra ªVLSI Im-
plementation of Cellular Neural Network Uni-
versal Machineº. IEEE Int. Symp. on Circ. and Syst.
ISCAS'97, vol. 1, pp. 545±548, Jun. 1996.
[15] M.Salerno, F.Sargeni and
V.Bonaiuto ª6x6DPCNN: a programable mixed
analogue±digital chip for Cellular Neural Net-
worksº. Fourth IEEE Int. Work. on CNN and Their
Appl., pp. 451±456, 1996
[16] Ari Paasio, Adam Dawidziuk and Veikko Porra.
ªPulse Stream Current Mode CMOS CNN chipº.
Fourth IEEE Int. Work. on CNN and Their Appl., pp.
457±460, 1996.
