Continuous time filter design using stochastic logic by Quero Reboul, José Manuel et al.
Continuous Time Filter Design Using Stochastic Logic 
J.M. Quero, Member IEEE, 8.L. Toral, J.G. Ortega and L.G. Franquelo, Senior Member, IEEE 
Dpto. de Ingenierfa Electronica 
Universidad de Sevilla 
Seville 41011 Spain 
Abstract-Stochastic logic is based on digital pro-
cessing of random pulse stream. In this paper we pro-
pose a stochastic approach to the digital implementa-
tion of continuous time filters. The similarity between 
probability and Boolean algebras is exploited to obtain 
simple realizations. A design of a fourth order filter is 
presented. 
1. INTRODUCTION 
Stochastic systems make pseudo analog operations us-
ing stochastically coded pulse sequences [1], [2]. Informa-
tion is represented by the statistical mean value of a pulse 
sequence. In a binary logic, it is codified as the proba-
bility of taking a "high" level. Such a sequence can be 
generated by comparing a register to a random number 
generator (Fig. 1). Equation 1 give us the probability of 
an output high level. 
P(O " 1") Digital Value utput = = -~-::----2n (1) 
A probability can not be exactly measured but only esti-
REGISTER 
RANDOM NUMBER 
Fig. 1. Digital to stochastic conversion (DSC). 
mated as the relative frequency of "high" levels in a long· 
enough sequence. As a consequence, the stochastic com-
puting technique introduces errors in the form of variance 
when we attempt to estimate the number from the se-
quence. 
The two most common arithmetic operations on 
stochastic signals are multiplication and summation, 
shown in Fig. 2. Assuming that two stochastic signals are 
stochastically uncorrelated, the product of both of them 
can be computed by a single AND gate. Summation is 
a more difficult operation to perform. The simplest way 
is to use wired OR summation [3], but it is a non linear 
scheme: as the probability of "high" levels increase, pulse 
overlap also increases, and the summation saturates grad-
ually (Fig. 2b). Nevertheless, for low pulse densities is an 
~ =D- --.lLfL Product m =D-- JlfL Non-linear 
sum 
0.6 JlMlJUl 0.2 JlrLJL O.06L 0.6 JlMlJUl 
o.sW 0.31UlJl 0.2 JlrLJL o.sW 
o.31lU o.06L O.26m 0.75 fl1Jlfl 
Fig. 2. Stochastic multiplication and summation. 
accuracy enough approach. Other techniques to perform 
summation are described in [4]-[6]. A low pass RC filter 
that integrates stochastic pulses is well suited to obtain 
its analog mean value. 
In this paper, we introduce a new approach to digi-
tal signal processing using stochastic logic. The informa-
tion carried out by a random pulse stream is dynamically 
processed with the elemental operations described before. 
The only premise is that the stochastic computation must 
be several order of magnitude faster than input signal dy-
namics. 
II. Low PASS FILTER 
Fig. 3a illustrates the basic scheme of a first order sys-
tem. The input signal is stochastic pulse stream repre-
senting a sinusoidal waveform. This analog information 
may be recovered with an analog low pass filter [7]. The 
input signal is compared with the output one with the 
block ADDER. Basically, this block is developing a wired 
OR summation, but taking into account a positive and a 
negative sign. It is a combinational module that imple-
ments the following equations: 
add(Xk,Yk) 
sig[add(xk' Yk)} 
= Xk Ef) Yk + xk(sig(Xk) Ef) sig(Yk) 
= xksig(Xk)(fik + Sig(Yk))+ 
Yksig(Yk)(Xk + Sig(Xk)) 
(2) 
The OR summation technique is justified because the out-
put of the ADDER block is an error Signal. So, it is a low 
density pulse stream. The error is time integrated with an 
up/down counter and then stochastically converted with 
a digital random number generator, following the scheme 
of figure 1. The most typical random number generator 
C_" --ocl-----
(a) First order system with unity gain factor 
K 
(b) First order system with 11k gain factor 
Fig. 3. Low pass filter scheme. 
for stochastic computing is a linear feedback shift register 
(LFSR) [8] that allows a very simple and low area cost 
implementation of a random number generator. 
The output signal is a stochastic pulse sequence that 
follows the input pulse stream, but with a dynamic that 
depends on the counter size and the clock frequency [9]. 
Particularly, the time constant and the cutoff frequency 
of the system described is: 
(3) 
where n is the counter size and Fclk the system clock fre-
quency. The system transfer function is then given by: 
1 
G(s) = 1 + ST (4) 
The output is digitally available, from the counter, or ana-
logically available, through an external low pass filter. 
It can be noticed that our first order system has an 
infinite input impedance and a zero output impedance. 
So, it can be serialized to obtain higher order systems, 
but without loosing a unity gain. An equivalent analog 
systems appears in Fig. 4. In fact, a gain factor can 
Fig. 4. Equivalent analog systems with impedance isolation. 
be easily introduced (Fig. 3b). A k factor is introduced 
in the feed-back loop to achieve a 11k gain. The only 
restriction is that stochastic representation of information 
is ranged from 0 to 1. As a consequence, the input signal 
multiplied by the gain factor 11k must not exceed a unity 
value, because there is a saturation effect. Nevertheless, 
it is not a heavy restriction if we scale the whole problem 
to the required range. With a gain factor, the system 
transfer function is: 
G(S) _ 11k 
- 1 + s(Tlk) (5) 
From this equation it can be observed that a gain factor 
produces a proportional increment in the time constant. 
III. HIGH PASS FILTER 
The high pass filter can be obtained from the low pass 
one. The output pulse stream in Fig. 5 is obtained sub-
j -IL---LP_F _~ 
~-------------- :kct 
o 
.. 
Fig. 5. High pass filter scheme. 
tracting the input pulse stream with the low pass filter 
output. In this case, a sign summation can not be per-
formed using the OR technique, because we are not work-
ing with low pulse densities. An alternative solution is a 
multiplexed scheme. Using a multiplexor, we avoid pulse 
overlap, but the information is divided by two. To elim-
inate correlations, a stochastic bit sequence of the LFSR 
with probability 0.5 is utilized as the select input if the 
multiplexor [10]. 
The high pass filter transfer function is given by: 
ST 
G(s) = 1 + ST 
With the gain factor k, the new transfer function is: 
G(S) = (k - 1) + ST 
k+ST 
IV. ANALOG TO STOCHASTIC CONVERSION 
(6) 
(7) 
A digital to stochastic and a stochastic to digital con-
verter is well known in the literature and has been exten-
sively used from the beginning of stochastic computation 
[11]-[13]. An analog to digital and digital to analog con-
verter based on stochastic logic has been also developed 
in [14]. But there is not a clear structure to implement an 
analog to stochastic conversion. An analog random sig-
nal generator [15] may be used, but we propose a mixed 
analogi digital approach to this conversion, using a gen-
eralization of the first order system described before. In 
Fig. 6 there is a basic scheme for this conversion. The 
analog input signal Viet) is compared with the stochas-
tic pulse sequence integrated with simple RC integrating 
circuit. and the resulting error signal is integrated with 
the up I down counter. This structure is similar to the 
L-__________________ o~JUrL 
STOCHASTIC 
Fig. 6. Analog to stochastic conversion. 
stochastic first order system, but with an external ana-
log comparator that leads to a PWM representation of 
information, instead of an error signal proportional to the 
input difference. 
RC integrating circuit dynamic must be higher than the 
input signal viet) dynamic. Again, we have a first order 
system with a transfer function determined by the counter 
size and frequency clock. Cutoff frequency is given by 
equation 3. 
V. PRACTICAL REALIZATION 
As an example, we have composed the previous circuits 
to obtain a fourth order low pass filter and a first order 
high pass filter. The block diagram of the 4th order one is 
shown in Fig. 7. The analog signal is stochastically con-
Fig. 7. Fourth order low pass filter block diagram. 
verted through the analog to stochastic converter. Four 
stochastic first order filters are then concatenated. All 
the digital processing has been implemented in a Xilinx 
programmable device (FPGA, 401OXL). Analogically we 
have only a signal adaptation and the RC integrating cir-
cuit plus the comparator for the analog to stochastic con-
version. In the FPGA is include the rest of the converter 
and the fourth order low pass filter. The design has been 
implemented with 8 bits for the analog to stochastic con-
version and 14 bits for the low pass filters. Frequency 
clock is 36 MHz. Mapping, placement and routing has 
been done with XACT M1.3 Foundation Series. In fig-
ure 8a we have the experimental frequency response for 
each stage of the filter, which has a cutoff frequency of 350 
Hz according to equation 3. Figure 9 is the experimen-
tal frequency response of the first order high pass filter. 
Figure 10 shows the waveforms directly captured from 
the oscilloscope display. They correspond to a 1st and 4th 
order low pass filter for a 50 Hz and 350 Hz sinusoidal 
input waveform. 
VI. CONCLUSIONS 
The use of stochastic logic for implementing systems 
dynamic provides a set of very simple circuits that can be 
1.0 r===~<;;:::::::-r-------~~-rr---~~~""--' ---~~':-- " ­
'-.. " 
O.S 
0.6 
0.4 
0.2 
\''. 
I ' , \ 
\\ \ 
\ . \ 
\\ \ 
\ '- \ 
\ \ \. 
\' \ 
\\ \ 
\, \ 
\ \ i 
\ ', \ 
\\ \ 
\ ', \ 
\ \ " \ \. ", 
Bl _.- F2 - - _. F3 --- F4 
,,~ , ~~::-
0.0 1:-0 ---~---:1:-:-00::-------:1:'::OO""O"""""--~~---'10000 
Fig. 8. Frequency response of each stage in the 4th order low-pass 
filter 
O.B 
0.6 
0.4 
0.2 
0.0 1:-0 ---~~1:-:-00::----~~1~O'::-::OO--~----'10000 
Fig. 9. Frequency response of the pt high-pass filter 
digitally implemented. As a result, the implementation of 
a continuous time system using digital circuits is achieved. 
The analog to stochastic conversion solves the problem of 
the stochastic pulse stream generation. This approach 
to filter designs allows a low area cost implementation 
in programmable devices and can be applied to develop 
embedded systems [16] that process digitally an analog 
information. 
REFERENCES 
[1] B.R. Gaines, "Stochastic computing systems," Adv. Inform. 
Syst. Sci., vol. 2, pp. 37-172, 1969. 
[2] C.L. Janer, J.M. Quero, J.G. Ortega and L.G. Franquelo, 
"Fully parallel stochastic computation architect ure," IEEE 
Trans. on Sig. Proc., vol. 44, no. 8, pp. 2110-2117, August 
1996. ' 
[3J A.F. Murray, D. del Corso and L. Tarassenko, "Pulse-Stream 
VLSI Neural Networks Mixing Analog and Digital Tech-
2-0ct-98 
20:08:46 
-
Moin Menu 
.... . -... .. . -..... .... . ... .... . ... . ... 
f\ 1/\ J\ '\ 1\ 
\ 
.\ \ .I .\ .I. .\ 
I I .\ I \ J \ 
V IV J J IJ \ 
.... . .... .... .... .... .... .... . ... . ... Chon 1 
10ms .6 V 
Chon 2 
10ms .5 V 
CHI 0.07 V DC CH1.6 V • 
-"- BWl CH2 .5 V • 
T/div 10 ms 
(a) 1st order low-pass filter response to a 50 Hz 
sinusoidal waveform 
2-Occ-9B 
20:00:05 
Moin Manu 
ltv I~ (!\ (~ ltv 
',/ II 
\\ \\ \\ 
IW; 
Chon t f--I--+-t-+---'!'-+--+-l-+--+IOm •. 5 V 
CH2 -0.01 V DC 
-"-
Chon 2 
10 ms .5 V 
CHI .5 V -
CH2 .5 V • 
aWL 
T/dlv 10 ms 
(c) 4th order low-pass filter response to a 50 Hz 
sinusoidal waveform 
2-0cc-98 
19:37:31 
MOln Menu 
-
.. /\ .... . ... I/y 
lit II 
'.1 \\ ./11 
f \ I 
\Y; 
.... .... .... . ... 
----
. ... . ... r-,:" .... '.j' . 
11;\ I It 
l \' II/ .\\ 
1\ ij 1\ 'j \' \(1 1\ 'f 
. ... . ... . ... .... . ... . .. Chon 1 
-- I ms .6 V 
Chon 2 
1m • . 5 V 
CH2-0.11 V DC CH1.5 V • 
-"- 8Wl CH2 .5 V • 
T/dlv 1 ms 
(b) 1st order low-pass filter response to a 350 Hz 
sinusoidal waveform 
2-oc<-98 
20:05:30 
Moin Menu 
----
Chon '1 1--+--+--l-.-t-'}-+--+-+--+----1 5m •. 5 V 
Chon 2 
L.....+.--l_..L--L._L-....L.........l_..L--'---' 5 ms .5 V 
CHI 0.07 V DC 
.....II... 
CHI .5 V • 
CH2 .5 V • 
eWL 
TId.!..., 5 ms 
(d) 4th order low-pass filter response to a 350 Hz 
sinusoidal waveform 
Fig. 10. Experimental response of stochastic filters. 
niques," IEEE Trans. on Neural Net., vol. 2, no. 2, pp. 193-
204, 1991. 
[4J D.E. Van den Bout and T.K. Miller, "A Digital Architec-
ture Employing Stochasticism for the Simulation of Hopfield," 
IEEE Trans. on Circ. and Syst., vol. 36, no. 5, pp. 732-738, 
May, 1989. 
[5] C.L. Janer, J.M. Quero and L.G. Franquelo, "Fully Parallel 
Summation in a New Stochastic Neural Network Architec-
ture," IEEE Int. Conf. on Neural Net., pp. 1498-1503, San 
Francisco, 1993. 
[6] M. van Daalen, J. Shawe-Taylor and J. Zhao, "Real Time Out-
put Derivatives for on Chip Learning Using Digital Stochastic 
Bit Stream Neurons," IEEE Elec. Lett., vol. 30, pp. 1775-1777, 
1994. 
[7J J.G. Ortega, C.L. Janer, J.M. Quero and L.G. Franquelo, J. 
Pinilla and J. Serrano, "Analog to digital and digital to analog 
conversion based on stochastic logic," IEEE Int. Conf. on Ind. 
Electr., pp. 995-999, Orlando, Nov. 1995. 
[8J S.W. Golomb, "On the classification of balanced binary se-
quences," IEEE Trans. Inf. Theory, vol. IT-26 , no. 6, pp. 
730-732, November 1980. 
[9] J.M. Quero and L.G. Franquelo, "Controladores digitales 
estocasticos," Diseo de Circuit os Integrados, pp. 272-276, 
Zaragoza, November, 1995. 
[10] E. Petriu, K. Watanabe, T. Yeap and S. Ogawa, "Neural 
Network Architecture Using Random-Pulse Data Processing," 
IEEE Int. Symp. on Circ. and Syst., pp. 2185-2188, Seattle, 
WA,1995. 
[11] B.R. Gaines, "Stochastic Computer Thrives on noise," Elec-
tronics, pp. 72-79, July 1967. 
(12] S. Ribeiro, "Random-pulse machines", IEEE Trans. on Elec. 
Comp., voL EC-16, no. 3, pp. 261-276, June 1967. 
[13J A.J. Miller, A.W. Brown and P. Mars, "Moving-average Out-
put Interface for Digital Stochastic Computers," Electron. 
Lett., vol. 10, no. 20, pp. 419-420, October 1974. 
[14J J.M. Quero, C.L. Janer, J.G. Ortega and L.G. Franquelo, 
"DjA converter ASIC uses stochastic logiC," EDN, pp. 86-88, 
October 1996. 
[15J E. Petriu, K. Watanabe and T. Yeap, "Applications of 
Random-Pulse Machine Concept to Neural Network Design," 
IEEE Trans. Instrum. Meas., vol. 45, no. 2, pp. 665-669, 1996. 
[16] S.L. Toral, J.M. Quero and L.G. Franquelo, "Power energy 
metering based on random signal processing (EC-RPS)," Int. 
Con!. on Circ. and Syst., Monterrey (CA), May-June, 1998. 
