Boise State University

ScholarWorks
Electrical and Computer Engineering Faculty
Publications and Presentations

Department of Electrical and Computer
Engineering

2019

A Spatiotemporal Pattern Detector
Robert Ivans
Boise State University

Kurtis D. Cantley
Boise State University

© 2019 IEEE. Personal use of this material is permitted. Permission from IEEE must be obtained for all other uses,
in any current or future media, including reprinting/republishing this material for advertising or promotional
purposes, creating new collective works, for resale or redistribution to servers or lists, or reuse of any copyrighted
component of this work in other works. Doi: 10.1109/MWSCAS.2019.8884799

This is an author-produced, peer-reviewed version of this article. The final, definitive version of this document can be found online at 2019 IEEE 62nd
International Midwest Symposium on Circuits and Systems (MWSCAS), published by IEEE. Copyright restrictions may apply. doi: 10.1109/
MWSCAS.2019.8884799

A Spatiotemporal Pattern Detector
Robert Ivans
Electrical and Computer Engineering Department
Boise State University
Boise, USA
RobertIvans@u.boisestate.edu

Abstract—A spatiotemporal pattern detector design is
presented which can identify three fundamental spatiotemporal
patterns consisting of two spikes (from different neurons or from
the same neuron). These fundamental cases provide the building
blocks for construction of more complicated arbitrary
spatiotemporal patterns. The overall design consists of three
primary subcircuits, and the operation of each is described. The
detection of the three cases of spatiotemporal patterns, and the
detection of a more complicated pattern by a network of
Spatiotemporal Pattern Detectors, is then demonstrated through
simulation using the Cadence Virtuoso platform.
Keywords—Neuromorphic
design,
pattern
detector,
spatiotemporal pattern recognition, spiking neural network

I. INTRODUCTION
Spatiotemporal pattern recognition (STPR), within the
context of spiking neural networks (SNN), is the process by
which a spatiotemporal pattern is abstracted down to an output
on a single neuron. STPR has been demonstrated using SNNs
with synapses with spike-timing-dependent plasticity (STDP) a
learning rule that updates synaptic weight according to a spiketiming-dependent learning rule [1]–[7]. In one common
approach to STPR, SNNs are trained to recognize a pattern by
repeatedly exposing them to the pattern embedded in noise [1],
[2]. After repeated exposures, the synaptic weights adjust in
accordance with an STDP learning rule so that the output
neuron produces a spike which tends to coincide with the
presentation of the pattern. Another approach to STPR involves
knowing the pattern to be detected and designing a system to
detect that particular pattern. One example of this approach
uses a Spike Sequence Recognition Network with a global
inhibitory neuron [7]. Another example of this approach uses a
Key-Threshold based SNN which treats spikes as bits and
“shifts in” spike trains to perform a bit-by-bit comparison with
a key [8]. The circuit we present in this work is also an
example of this approach, but unlike other approaches
mentioned, which require precise timing or time steps to
achieve pattern recognition, a user defined window of
detection.
In this work, we present a circuit which can be used to
detect simple spatiotemporal patterns and demonstrate that it
can be used to detect complex spatiotemporal patterns when
combined into networks without training. The goal of this
circuit’s design is to gain some insight into how digital SNNs
perform STPR by reducing the number of variables involved.
To do this, a network, composed of modified digital spiking
leaky-integrate-and-fire (LIF) neurons and simple logic gates,
This work was supported in part by the National Science Foundation
(NSF) under award number 1751230.

Kurtis D. Cantley
Electrical and Computer Engineering Department
Boise State University
Boise, USA
KurtisCantley@boisestate.edu

Na

Na
Nb

Δt

Na

Δt
Case 1: Na-Nb-Δt

Nb
t

Case 2: Na-Na-Δt

t

Case 3: Na-Nb-Coincidence

t

Fig. 1. The three fundamental spatiotemporal patterns that the circuit can
detect. Case 1 illustrates the case where two outputs of two different neurons,
Na and Nb, occur with some time, Δt, between them. Case 2 is a temporal
pattern where a single neuron, Na, spikes twice with some time, Δt, between
the spikes. Case 3 is a special case of Case 1 where Δt is reduced to zero
so that the two spikes coincide.

was designed that is capable of detecting three simple
spatiotemporal patterns: Na-Nb-Δt, Na-Na-Δt, and Na-Nbcoincidence, where Na and Nb are the first and second neurons
to spike, respectively [9]. The three cases are depicted in Fig.
1. All synaptic weights are maximized and leakiness is
minimized (leakiness is set by off-current). Section II of this
paper discusses the circuit operation with detailed description
of each subcircuit block. Section III demonstrates simulations
of the circuit detecting spatiotemporal patterns. Conclusions
are presented in Section IV.
II. CIRCUIT OPERATION
The circuit presented in this work is a spiking network
consisting of modified leaky integrate-and-fire neurons and
simple logic gates designed for the TSMC 0.18 µm process
and simulated in industry standard software Cadence Virtuoso
using the NCSU PDK [10].
A. Spatiotemporal Pattern Detector Subcircuit
The Spatiotemporal Pattern Detector subcircuit shown in
Fig. 2a is all that is strictly necessary to detect the three
spatiotemporal patterns of Fig. 1. It consists of a window
circuit and an AND gate. It produces a pattern detected signal
(Vpatterndetected=Vdd) when an input spike from Vin2 occurs
during a digital window (Vwindow=Vdd) produced by the
window circuit. However, the resulting pattern detected signal
may not have a full spike pulse width due to either a very short
window (“large” Vwinwidth chosen by the user) or due to the
input spike from Vin2 occurring at the edge of a window (see
Fig. 2b)
B. Window Circuit
The Window circuit consists of two modified LIF neurons
which act as analog timing circuits. The window circuit can
operate in two modes: non-coincidence and coincidence
detection modes which correspond to the state of Vcoin. Vcoin

This is an author-produced, peer-reviewed version of this article. The final, definitive version of this document can be found online at 2019 IEEE 62nd
International Midwest Symposium on Circuits and Systems (MWSCAS), published by IEEE. Copyright restrictions may apply. doi: 10.1109/
MWSCAS.2019.8884799
a) Spatiotemporal Pattern Detector
Vin1

Window
Circuit

b)

1.8
Vin1 (V)
0

Vwindow

Pulse Formatter Circuit

1.8
Vwindow (V)
0

Vin2

U5

Vpatterndetected

1.8
Vin2 (V)
0

Vdd
Vdd

Vpatterndetected

1.8
Vpatterndetected (V)
0
0

c) Window Circuit

Refractory Circuit

t (ms)

14

Vcoin

Vout

C6
Vdd

C8

Vdd
Vdd

Vdd

Vdd

Vdd

M9
Vrefractory
M10

Vpw

M11

C5

Vrefrac

M13

C7

Vdd

U1

M12

C2
Vdd

Vin1

U2

M1
Vwinstart

Vdd

A
M2

M3

Vdd

Vdd

B
C1

M14

C4
Vdd

M4
Vwinwidth

Vdd

C
M5

M6

Vdd

D
C3

U3

Vwindow

U4

M7
M8

Fig. 2. a) A block diagram of the Spatiotemporal Pattern Detector. b) The
response of the spatiotemporal pattern detector to stimulus with Vcoin tied to
gnd. The pulses applied to Vin1 and Vin2 are 1.8 V for duration 1 ms.
c) Schematic of the window circuit.

is a voltage set by the user to either gnd or Vdd for noncoincidence and coincidence modes, respectively. In the noncoincidence mode of operation, meaning that Vcoin is tied to
gnd, a simple digital pulse at Vin1 charges C1, C2, C3, and C4.
Initially, VA and VC are at logical 0. When a digital pulse
arrives at Vin1, VA quickly rises to logical 1 due to a
combination of M1 being saturated and feedback from C2 after
VB rises to Vdd. Similarly, VC quickly rises to logical 1 due to
a combination of M4 being saturated and feedback from C4
after VD rises to Vdd. This, in turn, raises the potential at nodes
B and D to raise to Vdd and quickly saturate M3 and M6. This
causes C1 and C2 to discharge at a rate controlled by M2 and,
the user selected potential, Vwinstart. When a sufficient
amount of time has passed (determined by the user’s choice of
Vwinstart) enough charge will have passed to ground from C1
and C2 via M2 and M3 that Node A will have dropped below
the inverter threshold (θ), causing node B to fall to gnd. This
places a logical 1 on U4 and causes M7 to quickly saturate.
The logical 1 due to node B being at gnd, combined with the
logical 1 due to node D being at Vdd, causes the window
circuit to output a logical 1 (Vwindow=Vdd). With M7
saturated, C3 and C4 discharge through M5, M6, M7, and M8
at a rate controlled by M5 and, the user selected potential,
Vwinwidth. When a sufficient amount of time has passed
(determined by the user’s choice of Vwinwidth) enough charge
will have passed to ground from C3 and C4 via M5, M6, M7,
and M8 that node C will have dropped below θ, causing node
D to fall to gnd and the window circuit to output a logical 0.
The result is that Vwinstart and Vwinwidth control the start
and duration, respectively, of a digital window initiated by an
input spike at Vin1.
In the coincidence mode of operation, meaning that Vcoin
is tied to Vdd, U2 prevents input spikes from reaching the LIF
neurons. Instead, Vwindow is created through simple logic
(Vin1 AND Vcoin).
C. Pulse Formatter and Refractory Circuits
To address the issue of shortened pattern detected pulses, a
pulse formatter subcircuit has been created that is attached to
the output. It consists of a single LIF circuit that produces a

Fig. 3. The Pulse Formatter and Refractory circuits. The pulse Formatter
takes Vpatterndetected signals and produces an output pulse of a width
determined by the user set Vpw. The Refractory circuit produces a signal,
Vrefractory, which prevents Vpatterndetected signals from reaching the
Pulse Formatter Circuit.

pulse, the width of which is set by Vpw, for an input from the
Spatiotemporal Pattern Detector subcircuit. This ensures that
the Spatiotemporal Pattern Detector produces pulses of a
consistent width. The refractory subcircuit consists of a single
LIF circuit that produces a pulse, the width of which is set by
Vrefrac. The refractory subcircuit prevents the pulse formatter
circuit from producing any pulses during a refractory period
set by Vrefrac. Fig. 3 depicts the pulse formatter and
refractory subcircuits.
III. SPATIOTEMPORAL PATTERN DETECTION DEMONSTRATION
A. Case 1: Na-Nb-Δt
In Case 1, the pattern consists of two input pulses, one from
each of two different neurons, separated by some time Δt. To
detect a Case 1 pattern, the circuit is placed in non-coincidence
mode (Vcoin=gnd) and the user sets the start and duration of
the desired digital window and the output pulse width and
refractory period via Vwinstart, Vwinwidth, Vpw, and Vrefrac
respectively. Fig. 4 depicts the circuit detecting a Case 1
pattern.
Initially, VA and VC are at logical 0. When a digital pulse
arrives at Vin1, VA quickly rises to logical 1 due to a
combination of M1 being saturated and feedback from C2 after
VB rises to Vdd. Similarly, VC quickly rises to logical 1 due to
a combination of M4 being saturated and feedback from C4
after VD rises to Vdd.
When the digital pulse ends, VA and VC start lowering at
rates determined by Vwinstart and the off current of M7
respectively (|d/dt VA| >> |d/dt VC|). When VA falls below θ,
VB is pulled down quickly to gnd. This places a logical 1 on
U4, resulting in Vwindow quickly rising to Vdd, and causing
M7 to quickly saturate, which causes V C to lower more rapidly
as the discharge rates of C3 and C4 are now limited by
Vwinwidth instead of the off current of M7 (since M7 is no
longer “off”).
If a digital pulse arrives at Vin2 while Vwindow is a logical
1, then Vpatterndetected quickly rises to logical 1. This is
detected by the Pulse Formatter circuit. As the Pulse Formatter
circuit is simply a LIF circuit with a maximum synaptic
connection strength, it fires immediately causing Vout to rise
quickly. This in turn causes the refractory circuit to fire
immediately (it is also a LIF circuit with a maximum synaptic
connection strength) causing Vrefractory to rise to Vdd and C7
and C8 to start discharging through M13 and M14 at a rate

VC (V) Vwindow (V) VA (V)

1.8

1.8

1.8

Vin1 (V)

Vin1 (V)

1.8

Vout (V) Vin2 (V)

This is an author-produced, peer-reviewed version of this article. The final, definitive version of this document can be found online at 2019 IEEE 62nd
International Midwest Symposium on Circuits and Systems (MWSCAS), published by IEEE. Copyright restrictions may apply. doi: 10.1109/
MWSCAS.2019.8884799

0

VA (V)

0

0

Vwindow (V)

1.8
0
1.8

0
1.8
0

VC (V)

0

1.8

1.8
0

Vout (V)

0
1.8

0

14

Fig. 4. Case 1:Na-Nb-Δt. Initially, the circuit is in non-coincidence mode
(Vcoin=gnd) and VA and VC are at logical 0. When a digital pulse arrives at
Vin1, VA and VC rise as C1, C2, C3, and C4 charge up. When the pulse ends,
VA lowers as C1 and C2 begin to discharge at a rate determined by the user
(Vwinstart) and VC lowers as C3 and C4 begin to discharge at a rate
determined by the off current of NMOS M7 (very small). When V A crosses
θ, it drops quickly to logical zero, Vwindow goes high, and V C starts to lower
more quickly as the discharge rate of C3 and C4 are now limited by
Vwinwidth (which is chosen by the user.) If a second digital pulse arrives at
Vin2 while Vwindow is high, Vpatterndetected goes high and causes the
pulse formatter circuit to generate a pulse on Vout and the refractory circuit
to initiate a refractory period.

determined by Vrefrac. Vrefractory at Vdd turns M9 off,
preventing Vpatterndetected from influencing the output while
Vrefractory is high, and turns M10 on creating a path to
discharge charge trapped by M9. Another thing that happens
when Vout rises to Vdd is that C5 and C6 begin discharging
through M11 and M12 at a rate controlled by Vpw. When the
voltage across C5 drops below θ, Vout is pulled to gnd. After
VC falls below θ, VD is pulled down quickly to gnd. This
places a logical 0 on U4, which in turn quickly pulls down
Vwindow to gnd.
B. Case 2: Na-Na-Δt
In Case 2, the pattern consists of two input pulses, each
from the same neuron, separated by some time Δt. To detect a
Case 2 pattern, the circuit is placed in non-coincidence mode
(Vcoin=gnd), the circuit inputs Vin1 and Vin2 are tied
together, and the user sets the start and duration of the desired
digital window and the output pulse width and refractory
period via Vwinstart, Vwinwidth, Vpw, and Vrefrac
respectively. Fig. 5 depicts the circuit detecting a Case 2
pattern.
Initially, VA and VC are at logical 0. When a digital pulse
arrives at Vin1 and Vin2 (they are tied together), V A quickly
rises to logical 1 due to a combination of M1 being saturated
and feedback from C2 after VB rises to Vdd. Similarly, VC
quickly rises to logical 1 due to a combination of M4 being
saturated and feedback from C4 after V D rises to Vdd.
When the digital pulse ends, V A and VC start lowering at
rates determined by Vwinstart and the off current of M7
respectively (|d/dt VA| >> |d/dt VC|). When VA falls below θ,
VB is pulled down quickly to gnd. This places a logical 1 on
U4, resulting in Vwindow quickly rising to Vdd, and causing
M7 to quickly saturate, which causes V C to lower more rapidly
as the discharge rates of C3 and C4 are now limited by M5 and
Vwinwidth instead of the off current of M7 (since M7 is no
longer “off”).

0

t (ms)

100

Fig. 5. Case 2:Na-Na-Δt. Initially, the circuit is in non-coincidence mode
(Vcoin=gnd), Vin1 and Vin2 are tied together, and V A and VC are at logical
0. When a digital pulse arrives at Vin1, V A and VC rise as C1, C2, C3, and
C4 charge up. When the pulse ends, VA lowers as C1 and C2 begin to
discharge at a rate determined by the user (Vwinstart) and V C lowers as C3
and C4 begin to discharge at a rate determined by the off current of NMOS
M7 (very small). When VA crosses θ, it drops quickly to logical zero,
Vwindow goes high, and VC starts to lower more quickly as the discharge
rate of C3 and C4 are now limited by Vwinwidth (which is chosen by the
user.) If a second digital pulse arrives at Vin1 while Vwindow is high,
Vpatterndetected goes high and causes the pulse formatter circuit to generate
a pulse on Vout and the refractory circuit to initiate a refractory period. Also,
VA and VC rise as C1, C2, C3, and C4 are recharged by the new pulse,
cutting the window off and setting up the circuit to detect another Na-Na-Δt
pattern.

If another digital pulse arrives at Vin1 and Vin2 while
Vwindow is a logical 1, then Vpatterndetected quickly rises to
logical 1. This causes VA and VC to rise as C1, C2, C3, and C4
are recharged by the new pulse, cutting the window off and
setting up the circuit to detect another Na-Na-Δt pattern, while
Vpatterndetected is detected by the pulse formatter circuit. As
the pulse formatter circuit is simply a LIF circuit with a
maximum synaptic connection strength, it fires immediately
causing Vout to rise quickly. This, in turn, causes the refractory
circuit to fire immediately (it is also a LIF circuit with a
maximum synaptic connection strength) causing Vrefractory to
rise to Vdd and C7 and C8 to start discharging through M13
and M14 at a rate determined by Vrefrac. Vrefractory at Vdd
Vin1 (V)

t (ms)

1.8

VC (V) Vwindow (V) VA (V)

0

1.8

Vout (V) Vin2 (V)

0

1.8

1.8

0

0
1.8
0
1.8
0

0
1.8
0

0

t (ms)

14

Fig. 6. Case 3: Na-Nb-coincidence. Initially, the circuit is in coincidence
mode (Vcoin=Vdd) and VA and VC are at logical 0. When a digital pulse
arrives at Vin1, VA and VC remain unchanged as the output of U2 is held at
logical 1 by Vcoin. When a digital pulse arrives at Vin1, Vwindow goes high
through U1 and U3. If a second digital pulse arrives at Vin2 while Vwindow
is high, Vpatterndetected goes high and causes the pulse formatter circuit to
generate a pulse on Vout and the refractory circuit to initiate a refractory
period.

b)

N2

a)

N3

N20
N11

Δt1

N4

Δt4

N10

N5

N10

Δt2
Δt6

N1

N6

N3

Pattern
Detected

Coin

Δt5

N7

N7
N7

Δt3

IV. CONCLUSION
A Spatiotemporal Pattern Detecting circuit was presented
capable of detecting three fundamental spatiotemporal spike
patterns. A network of Spatiotemporal Pattern Detectors was
then created to detect a more complicated spatiotemporal
pattern. Future work will continue to explore these pattern
detectors and attempt to bridge the gap between them and
more traditional spiking neural networks.

[2]

N10
N11
N12
N13
N14
N17
N18
N19
N20
N21
N22
N23
N24

Pattern
Detected
0

t (ms)

500

Fig. 7. a) A block diagram of a network of Spatiotemporal Pattern Detectors,
where each Spatiotemporal Pattern Detector is depicted as an AND gate with
the start time of the window written in the body and Vin1 above Vin2. Each
Δt indicates the amount of time between the appropriate pattern spikes. For
example Δt1 is the time between the pattern spikes from N20 and N11. This
network was designed to detect the pattern highlighted in grey. b) The
simulation results of the network depicted in Fig. 7a. A combination of
pattern and noise input spikes from neurons N1 through N25 results in a
pattern detection signal that coincides with the presentation of the pattern
(highlighted in grey) indicating that the desired pattern was detected.
[6]

K. D. Cantley, R. C. Ivans, A. Subramaniam, and E. M. Vogel, “SpatioTemporal Pattern Recognition in Neural Circuits with MemoryTransistor-Driven Memristive Synapses,” in International Joint
Conference on Neural Networks (IJCNN), 2017, pp. 4633–4640.

P. U. Diehl, D. Neil, J. Binas, M. Cook, S. C. Liu, and M. Pfeiffer,
“Fast-classifying, high-accuracy spiking deep networks through weight
and threshold balancing,” in International Joint Conference on Neural
Networks (IJCNN), 2015, pp. 1–8.

[7]

T. Masquelier, R. Guyonneau, and S. J. Thorpe, “Spike timing
dependent plasticity finds the start of repeating patterns in continuous
spike trains,” PLoS One, vol. 3, no. 1, pp. 1–9.

Q. Yu, R. Yan, H. Tang, K. C. Tan, and H. Li, “A Spiking Neural
Network System for Robust Sequence Recognition,” IEEE Trans.
Neural Networks Learn. Syst., vol. 27, no. 3, pp. 621–635, 2016.

[8]

A. V Gavrilov, A. A. Maliavko, and A. A. Yakimenko, “Key-Threshold
based spiking neural network,” in 2017 Second Russia and Pacific
Conference on Computer Technology and Applications (RPC), 2017, pp.
64–67.

[9]

C. Mead, Analog VLSI and Neural Systems. Addison-Wesley, 1989.

[10]

T. Schaffer, A. Stanaski, A. Glaser, and P. Franzon, “The NCSU Design
Kit for IC Fabrication through MOSIS,” in Int. Cadence User Group
Conf, 1998, pp. 71–80.

REFERENCES
[1]

N25

D. Larger Spatiotemporal Patterns
Larger spatiotemporal patterns can be detected by
networks of Spatiotemporal Pattern Detector circuits. Fig. 7a
shows a network of Spatiotemporal Pattern Detector circuits.
Each Spatiotemporal Pattern Detector is depicted as an AND
gate with the start time of its window written in its body and
Vin1 above Vin2. Simulation of a network with 25 spiking
input neurons is provided in Fig. 7b. The input consists of a
pattern, highlighted in grey, embedded within random activity.
The network of Fig. 7a is identifying a sub-pattern generated
by neurons 1, 3, 7, 10, 11, and 20 as indicated by the "Pattern
Detected" signal. If detecting a sub-pattern is insufficient, then
a larger detector can be used to detect the entire pattern.

N16

N15

C. Case 3: Na-Nb-Coincidence
In Case 3, the pattern consists of two input pulses, each
from one of two different neurons, occurring at the same time.
This is a special case of Case 1 where Δt=0. It should be noted
that overlapping input pulses will cause a detection and not just
coincidental pulses. However, in this mode of operation
coincidental pulses will be detected. Fig. 6 depicts the circuit
detecting a Case 3 pattern.

N9

N8

turns M9 “off”, preventing Vpatterndetected from influencing
the output while Vrefractory is high, and turns M10 “on”
creating a path to discharge charge trapped by M9. Another
thing that happens when Vout rises to Vdd is that C5 and C6
begin discharging through M11 and M12 at a rate controlled by
Vpw. When the voltage across C5 drops below θ, Vout is
pulled to gnd. After VC falls below θ, VD is pulled down
quickly to gnd. This places a logical 0 on U4, which in turn
quickly pulls down Vwindow to gnd.

N1

This is an author-produced, peer-reviewed version of this article. The final, definitive version of this document can be found online at 2019 IEEE 62nd
International Midwest Symposium on Circuits and Systems (MWSCAS), published by IEEE. Copyright restrictions may apply. doi: 10.1109/
MWSCAS.2019.8884799

[3]

X. Wu, V. Saxena, and K. Zhu, “Homogeneous Spiking Neuromorphic
System for Real-World Pattern Recognition,” Emerg. Sel. Top. Circuits
Syst. IEEE J., vol. 5, no. 2, pp. 254–266.

[4]

S. Mitra, S. Fusi, and G. Indiveri, “Real-time classification of complex
patterns using spike-based learning in neuromorphic VLSI,” IEEE
Trans. Biomed. Circuits Syst., vol. 3, no. 1, pp. 32–42, 2009.

[5]

Q. Yu, H. Tang, K. C. Tan, and H. Li, “Precise-Spike-Driven synaptic
plasticity: Learning hetero-association of spatiotemporal spike patterns,”
PLoS One, vol. 8, no. 11, pp. 1–16, 2013.

