A 1.5μW NEO-based Spike Detector with Adaptive-Threshold for Calibration-free Multichannel Neural Interfaces by Koutsos, E et al.
A 1.5µW NEO-based Spike Detector with
Adaptive-Threshold for Calibration-free
Multichannel Neural Interfaces
Ermis Koutsos∗†, Sivylla E. Paraskevopoulou∗† and Timothy G. Constandinou∗†
∗Department of Electrical and Electronic Engineering, Imperial College London, SW7 2BT, UK
†Centre for Bio-Inspired Technology, Institute of Biomedical Engineering, Imperial College London, SW7 2AZ, UK
Email: {e.koutsos11, s.paraskevopoulou09, t.constandinou}@imperial.ac.uk
Abstract—This paper presents a novel front-end circuit for
detecting action potentials in extracellular neural recordings.
By implementing a real-time, adaptive algorithm to determine
an effective threshold for robustly detecting a spike, the need
for calibration and/or external monitoring is eliminated. The
input signal is first pre-processed by utilising a non-linear energy
operator (NEO) to effectively boost the signal-to-noise ratio
(SNR) of the spike feature of interest. The spike detection
threshold is then determined by tracking the peak NEO response
and applying a non-linear gain to realise an adaptive response
to different spike amplitudes and background noise levels. The
proposed algorithm and its implementation is shown to achieve
both accurate and robust spike detection, by minimising falsely
detected spikes and/or missed spikes. The system has been
implemented in a commercially available 0.18µm technology
requiring a total power consumption of 1.5µW from a 1.8 V
supply and occupying a compact footprint of only 0.03 mm2
silicon area. The proposed circuit is thus ideally suited for high-
channel count, calibration-free, neural interfaces.
I. INTRODUCTION
With the advert of microtechnology and the increased ca-
pability of neuroprosthetic devices has led to the development
of fully implantable wireless systems, capable of monitoring
hundreds of neurons. Moreover, with ever-advancing high
density micro-electrode arrays (MEAs) the capability will
soon be extended from recording 100s to 1000s of channels
simultaneously [1], [2].
Extracellular action potentials (EAPs) typically have ampli-
tudes between 25µV and 1 mV, with a frequency spectrum of
between 300 Hz to 3 kHz. The variation in amplitude (from
neuron to neuron) depends on each neuron’s morphology, as
well as its proximity and orientation relative to the recording
electrode. Using current MEAs (eg. Utah arrays), each channel
can observe the activity of up to five neurons [3]. In order
to extract the maximum amount of information from every
channel, each spike must be classified to specific neuron
activities. To achieve this, current systems amplify, condition,
digitise and transmit the raw neural recordings to an external
device for post-processing (eg. a workstation). Considering a
typical MEA (eg. 100 channels), with the recording sampled
at 10-bit resolution, at 30 kS/sec, the required data-rate is
30 Mbit/sec. It is however a significant challenge to increase
the communication bandwidth due to limitations imposed by
the maximum allowable thermal dissipation [4], [5].
Spike
detector output
(pulse train)
VGA
V-to-I
converter
Peak detector
Variable bias
Current
A=10
Non-linear
energy
operator
(NEO)
+
-
Adaptive
Threshold
Comparator
Automatic
gain control
(AGC)
Input signal
(from x50
biopotential
amplier)
NEO pre-processed and amplied signal
Adaptive
Threshold
Processor
Fig. 1. System-level block diagram of the adaptive-threshold spike detector.
The desire, therefore, to increase the number of channels re-
quires the amount of data transmitted per channel to decrease.
One solution is to only transmit specific spike features, for
example a simple spike event timing. There as been much work
on front-end spike detection, eg. [6]–[8]. The simplest designs
use a constant threshold to detect the spike using a comparator.
However, due to both the noisy nature of neural recordings (eg.
background activity, electrode noise/offset, etc) and the large
variability in spike shapes and amplitudes, predefining a set
threshold in not sufficient.
The need for external monitoring and calibrating each
channel’s threshold is thus essential for maintaining spike
detection accuracy. This has given rise to adaptive algorithms
for selecting this threshold level. The basic concept behind
such methods is to estimate the background noise level of the
input signal and set the threshold as a constant multiple of
that value [4], [9]–[11]. Other methods utilise a signal pre-
processor, for example, a non-linear energy operator (NEO)
[12], [13] to boost the effective SNR. The NEO gives an
estimate of the signals instantaneous change in amplitude and
frequency and this makes it ideal for spike detection [14].
Nevertheless, applying constant thresholds to this for spike
detection is not still universally robust.
This paper presents a novel CMOS neural spike detector
circuit with adaptive threshold and NEO pre-processor. This
paper is organised as follows: Section II presents the spike de-
tector system concept, Section III the circuit implementation,
Section IV the results, and finally Section V the conclusion.
II. ADAPTIVE THRESHOLD ALGORITHM
A system-level block diagram of the proposed adaptive
threshold spike detector is shown in Fig. 1. This consists of
a NEO pre-processor feeding an adaptive threshold processor
to set the detection level. The NEO output is then compared
to the adaptive threshold using a 2-stage comparator. It should
be noted that the spike detector has been designed to take its
input after front-end pre-amplification and high-pass filtering.
Specifically a front-end gain of 50× is assumed, mapping to
a 1.25 mV to 50 mV EAP input range.
The adaptive threshold processor is is annotated in Fig. 1
(within dotted line). The input signal is fed to the NEO and
then, amplified by a constant gain of 10. A peak detector
tracks the amplified-NEO maxima, but in the absence of a
spike, the output signal decreases with time due to leakage.
The non-amplified NEO signal is fed to a variable gain stage,
where the threshold is calculated. The variable threshold is
initially set at 60% of the peak-detector’s output. As the NEO
signal increases in amplitude, the variable threshold decreases,
reaching a minimum of 15% of the peak-detector output. This
essentially reduces the sensitivity for small spikes compared
to larger ones and ensures that even when the peak-detector
output has leaked to a very low value, the threshold will still be
above the background noise. Furthermore, this system exploits
the peak detector leakage, by physically lowering the threshold
as time progresses, assuring the detection of a small spike
following a much larger spike. A V-to-I converter controls the
gain of the variable gain amplifier. Finally, a spike is detected
when the amplified-NEO signal crosses the variable threshold.
III. CIRCUIT IMPLEMENTATION
The circuit has been implemented in a commercially avail-
able 0.18µm CMOS technology provided by AMS (C18A4).
A. Non-linear Energy Operator
The Non-linear Energy Operator (a.k.a. Tieger operator) is
known to be very effective in spike detection, especially for
signals with very low SNR. The NEO output is proportional to
the square of the instantaneous product of a signals amplitude
and frequency, described by Eq. 1:
v(x(t)) =
(
dx(t)
dt
)2
− x(t) ·
(
d2x(t)
dt2
)
(1)
The analog NEO implementation has been adapted from
[13]. Fig. 2(a) shows the circuit diagram of the analog
NEO implementation. The sub-threshold OTAs used in the
NEO circuit (shown in Fig. 2(b)) use source degeneration
(Ms1,Ms2) and bulk linearisation (Mb1,Mb2) to achieve
low transconductances and an increased linear input range.
Since the OTAs are operating in the sub-threshold region, the
transconductance gm is lineally proportional to the bias current
Ibias. The relation is shown below in Eq. 2,
gm =
ID
nVT
(2)
Where VT is the thermal voltage. The differentiator implemen-
tation is shown in Fig. 2(c). Considering the transfer function
of the differentiator (Eq. 3), in order to achieve the required
magnitude in the output signal of the NEO, a gain of 10
was selected. To achieve this, gm1 and gm3 are biased with a
current of 5 nA and gm2 with a current of 50 nA.
gm1
gm2
gm3
Vin
Vout
(c)
V+ V-
Ibias
Vout
Vp
Vn
M3
1/1
M4
1/1MB2
2/1
MB1
2/1
M2
1/1
M1
1/1
MS1
1/10
MS2
1/10
M10
1/1
M9
1/1
M5
1/1
M6
1/1
M8
10/1
M7
10/1
(b)
gm
gm
Vx
Vy
Vx
Vy
gm
gm
gm
Vout
Vin
Multiplier
Multiplier
1st derivative 2nd derivative
Summer
(a)
(d)
IbiasM1
5/5
M2
5/5
M3
5/5
M4
5/5
Vb2
VY2VY1
Vb1
VX2
VX1 VX1
Vout
M11
1/1
M12
1/1
M13
1/1
M14
1/1
M5
1/10
M6
1/10
M7
1/10
M8
1/10
M9
1/1
M10
1/1
M15
1/1
M16
1/1
M17
1/1
M18
1/1
Fig. 2. Circuit implementation of the NEO. Shown are: (a) NEO system-
level block diagram, (b) sub-threshold OTA circuit, (c) differentiator circuit,
(d) four-quadrant analog inverting multiplier circuit.
(a)Vin=NEO
Vout=10(Vin)
gm1
gm2
C
(b)
Vpeak
Vtheshold
gm3
gm4
Ibias1
Ibias2
NEO
gm5
Ioset
Fig. 3. Circuit implementations of: (a) fixed-gain non-inverting amplifier,
(b) variable gain non-inverting amplifier feeding the automatic gain control.
Vout
Vin
=
jωC
jωC + gm1
· gm2
gm3
(3)
Finally, Fig. 2(d) presents the four-quadrant analog multi-
plier used, for a bias current of 30 nA and achieving a 40 mV
linear range. Transistors (M1,M2) and (M3,M4) level-shift
Vy1, Vy2) down by 500 mV (from 900 mV to 400 mV).
B. Fixed Gain Amplifier
The non-inverting amplifier used to amplify the NEO sig-
nal is shown in Fig. 3(a). This utilises a similar OTA as
to those used in the NEO circuit (Fig. 2(b)), but with an
increased linear output range (300 mV). This is achieved by
designing transistors (Mb1,Mb2) to have an aspect ratio of
(W/L)=8/2 (µm/µm). The gain of the amplifier is set by the
ratio (gm1/gm2) and since the OTAs are operating in the sub-
threshold region, this becomes (Ibias1/Ibias2). The gain of the
amplifier is fixed to 10 (Ibias1=50 nA and Ibias2=5 nA).
C. Peak Detector
The purpose of the peak detector is to track the input
signal as it increases, but not as it decreases, thus storing the
maximum amplitude of the signal. The design and operation of
the peak detector circuit are detailed in [3]. The basic operation
uses a switch to charge a capacitor for increasing signals.
For decreasing signals the switch is left open so a decay is
implemented by adding a leakage. To match the dynamics
of the peak detector to the NEO output for the minimum
controllable leakage, the NEO signal is pre-amplified with a
gain of 10 and a capacitor of 3 pF is used.
D. VGA and AGC
The circuit for the VGA and AGC is shown in Fig. 3(b).
The gain of the variable gain amplifier (VGA) is controlled
by the current ratio (Ibias1/Ibias2). This ratio is controlled by
the automatic gain control (AGC) which takes the NEO input
and provides a varying bias current Ibias2. The OTAs used in
this circuit are similar to those in Fig. 2(b), but without source
degeneration or bulk linearization. Assuming a voltage input
to the OTA with a range of 30 mV (typical NEO output), the
output current of the OTA will vary from 300 pA to 30 nA. A
bias current of 300 pA would however be too low to drive the
VGA (for linear operation) and thus an offset bias is added
(Ioffset=10 nA). The total current is mirrored and forms the
Ibias2 current, with Ibias1=6 nA. Thus, the variable threshold
is Vth = Vpeak×G, where G is the variable gain (0.6 ≤ G ≤
0.15) and Vpeak is the output of the peak detector.
E. Comparator
The comparator used for the evaluating the spike detection is
a standard two-stage topology with regeneration (i.e. utilising
symmetric cross-coupling) using Ibias=40 nA per stage.
IV. SIMULATED RESULTS
The complete system was simulated using the Cadence
Spectre (5.1.41isr1) simulator, with foundry supplied PSP
models. The datasets used for the simulations were obtained
from [15] containing 4 datasets (easy1, easy2, difficult1,
difficult2) each created with different noise levels (0.05, 0.1,
0.15, 0.2) and sampled at 24 kHz. For these simulations, the
test datasets have been scaled to a 50 mV full-scale range (i.e.
corresponding to approximately a ×50 pre-amplification).
1) Transient Analysis: A simulation over a 40 ms period of
the test signal containing three spikes is shown in Fig. 4. This
illustrates the operation of the adaptive threshold, in particular
observing: (1) the SNR of the input signal is boosted by
the NEO pre-processor, (2) the peak signal tracks the NEO
maxima, (3) in the absence of a spike, the adaptive threshold
follows the peak signal trend, and (4) in the presence of
a spike, the adaptive threshold dips (see magnified feature),
effectively increasing the spike detection sensitivity.
An extended transient analysis over a 1 s period is shown
in Fig. 5 illustrating the longer term operation of the circuit.
In particular, this demonstrates the operation of the variable
threshold achieves good robustness to noise and varying spike
0.89
0.9
0.91
0.92
0.93 Spike 1 
Spike 2 
Vpeak
Vthreshold
Input Signal
Vneo(x10)
Spike 3
Spike 1 
Spike 2 Spike 3
Vneo
Output
390 400 410 420
Time (ms)
415405395
0.9
0.91
0.92
0.93
0.9
0.95
1
1.05
1.1
0
1.8
V 
(V
)
V 
(V
)
V 
(V
)
V 
(V
)
(a)
(b)
(c)
(d)
Magnied Spike 3
Comparison
Fig. 4. Operation of the adaptive threshold detector over a 40 ms period
(for difficult01 dataset at 0.2 noise level [15]). Shown are: (a) input, (b)
NEO signal, (c) amplified NEO, peak tracking and adaptive threshold, and (c)
comparator output. For (a, b): shaded area indicates the signal to noise margin,
and horizontal dashed lines indicate the signal range (for 40 ms segment).
amplitudes. The delay between the action potential and the
output pulse is negligible (less than 100µs).
2) Spike Detection Sensitivity: The performance of the
proposed method (i.e. adaptive-threshold spike detection) has
been quantified through a series of MATLAB simulations.
This is compared to 3 spike detection methods utilising
optimally-set thresholds, based on: (A) input signal compared
to α×(Vpeak), (B) NEO signal compared to β×(average
0.6
0.8
1
0.9
0.7
0.6
0.8
1
0.9
0.7
0.9
1
0.6
0.8
1
0.9
0.7
0.05 0.10 0.15 0.20 0.05 0.10 0.15 0.20
0
0.1
0
0.1
0
0.1
0
0.2
0.4
0.3
0.1
Se
n
si
ti
vi
ty
Se
n
si
ti
vi
ty
Se
n
si
ti
vi
ty
Se
n
si
ti
vi
ty
FD
R
FD
R
FD
R
FD
R
Easy01
Easy02
Difficult01
Difficult02
Easy01
Easy02
Difficult01
Difficult02
Noise Level Noise Level
.05
.05
.05
.95
This work
Method (A)
Method (B)
Method (C)
Fig. 6. Spike detection sensitivity and FDR of spike detection using the
proposed adaptive threshold method compared to applying optimally-selected
thresholds (across multiple test datasets and noise levels) [15].
Time (s)
 
V 
(V
)
NEO
Vthr
Vpeak
Output
3.0 3.1 3.2 3.3 3.4 3.5 3.6 3.7 3.8 3.9 4.0
0
1.8
0.89
0.93
0.91
1.1
1.05
1
0.95
0.9
1.15
V 
(V
)
V 
(V
)
Input
Fig. 5. Spike detector operation over a 1 s period (for difficult01 dataset at 0.2 noise level [15]). Shown are: (a) input, (b) amplified NEO, peak tracking
and adaptive threshold, and (c) output.
NEO signal), (C) NEO signal compared to γ×(maximum
NEO amplitude). Each of these threshold-selection constants
(α, β, γ) have been obtained through an exhaustive search
across all datasets and noise levels. The proposed method
however does not require any calibration. Fig. 6 shows
the sensitivity (=detected spikespresent spikes ) and false detection rates
(FDR= false positivestotal detections ) for each method. It can be observed
that the proposed method achieves good performance through
multiple datasets and noise levels.
V. CONCLUSION
This paper has presented a novel fully-autonomous spike
detector detailing its circuit implementation. The system is
capable of detecting spikes in real-time and with minimal
delay, without the aid of external monitoring and/or the need
for calibration. The system features a NEO pre-processor and
adaptive threshold engineered to maximize both the accuracy
(minimising false positives and/or false negatives) and robust-
ness (to signal variability). The total area required for this
design has been estimated by summing all the active device
areas and adding an additional 400% overheard to account for
contacts and interconnects. This results in a total (estimated)
area requirement of 0.03 mm2, implemented in a commercially
available 0.18µm CMOS technology. The circuit consumes a
total power of 1.5µW (excluding bias generation) from a 1.8 V
supply. A comparison between this work and the state-of-the-
art is shown in Table I.
TABLE I
TABLE COMPARING THIS SYSTEM WITH THE STATE-OF-THE-ART.
Detector Pre- Adaptive Area Power Tech.
Processor Threshold (mm2) (µW) (µm)
[4] 7 3 0.09 57 1.5
[6] 3 7 0.06 1 0.5
[8] 3 7 0.09 0.8 1.5
[9] 3 3 0.17 1 0.13
[10] 3 3 9 110 0.6
[13] 3 7 0.07 0.78 0.18
[16] 3 7 0.06 1 0.5
This work 3 3 0.03 (est.) 1.5 0.18
ACKNOWLEDGMENT
This work was supported by the UK Engineering & Physical
Sciences Research Council (grant EP/I000569/1). The authors
would like to thank Dr. Amir Eftekhar for useful discussions.
REFERENCES
[1] A. Eftekhar, S. Paraskevopoulou, and T. Constandinou, “Towards a
next generation neural interface: Optimizing power, bandwidth and data
quality,” Proc. IEEE BioCAS, pp. 122–125, 2010.
[2] G. Einevoll, F. Franke, E. Hagen, C. Pouzat, and K. Harris, “Towards
reliable spike-train recordings from thousands of neurons with multi-
electrodes,” Current opinion in neurobiology, 2011.
[3] S. Paraskevopoulou and T. Constandinou, “A sub-1µw neural spike-peak
detection and spike-count rate encoding circuit,” Proc. IEEE BioCAS,
pp. 29–32, 2011.
[4] R. Harrison, “A low-power integrated circuit for adaptive detection of
action potentials in noisy signals,” Proc. IEEE EMBC, vol. 4, pp. 3325–
3328, 2003.
[5] S. Kim, R. Normann, R. Harrison, and F. Solzbacher, “Preliminary study
of the thermal impact of a microelectrode array implanted in the brain,”
Proc. IEEE EMBC, pp. 2986–2989, 2006.
[6] C. Rogers, et al., “An analog vlsi implementation of a multi-scale spike
detection algorithm for extracellular neural recordings,” Proc. IEEE
EMBS Neural Eng. Conf., pp. 213–216, 2005.
[7] T. Borghi, R. Gusmeroli, A. Spinelli, and G. Baranauskas, “A simple
method for efficient spike detection in multiunit recordings,” J. Neuro-
science Methods, vol. 163, no. 1, pp. 176–180, 2007.
[8] T. Horiuchi, T. Swindell, D. Sander, and P. Abshier, “A low-power cmos
neural amplifier with amplitude measurements for spike sorting,” Proc.
IEEE ISCAS, vol. 4, pp. IV–29, 2004.
[9] J. Holleman, et al., “A micro-power neural spike detector and feature
extractor in. 13µm cmos,” Proc. IEEE CICC, pp. 333–336, 2008.
[10] D. Kim, M. Stanacevic, R. Kamoua, and Z. Mainen, “A low-power low-
data-rate neural recording system with adaptive spike detection,” Proc.
IEEE MWSCAS, pp. 822–825, 2008.
[11] H. Chan, et al., “Detection of neuronal spikes using an adaptive threshold
based on the max-min spread sorting method,” J. Neuroscience Methods,
vol. 172, no. 1, pp. 112–121, 2008.
[12] K. Kim, et al., “Neural spike sorting under nearly 0-db snr using
nonlinear energy operator and artificial neural-network classifier,” IEEE
Trans. Biomed. Eng., vol. 47, no. 10, pp. 1406–1411, 2000.
[13] B. Gosselin and M. Sawan, “An ultra low-power cmos automatic action
potential detector,” IEEE Trans. Neural Syst. Rehab. Eng., vol. 17, no. 4,
pp. 346–353, 2009.
[14] S. Mukhopadhyay and G. Ray, “A new interpretation of nonlinear energy
operator and its efficiency in spike detection,” IEEE Trans. Biomed. Eng.,
vol. 45, no. 2, pp. 180–187, 1998.
[15] R. Quian Quiroga, et al., “Unsupervised spike detection and sorting with
wavelets and superparametric clustering,” Neural Computation, vol. 16,
pp. 1661–1687, 2004.
[16] C. Rogers, et al., “A low-power analog spike detector for extracellular
neural recordings,” Proc. IEEE ICECS, pp. 290–293, 2004.
