Analog content addressable memories with memristors by Li, Can et al.
Analog content addressable memories with memristors
Can Li1,*, Catherine E. Graves1,*, Darrin Miller2, and John Paul Strachan1,*
1Hewlett Packard Labs, Palo Alto, CA 94304
2Silicon Design Lab, Hewlett Packard Enterprise, Fort Collins, CO 80528
*Emails: can.li@hpe.com; catherine.graves@hpe.com; john-paul.strachan@hpe.com
Abstract
A content addressable memory (CAM) is a special form of memory that compares an in-
put search word against all rows of stored words in an array in a highly parallel manner.
While supplying a very powerful functionality for many applications in pattern matching
and search, CAMs suffer from large area, cost and power consumption, limiting their use.
Past improvements have been realized by using non-volatile memristors to replace the static-
random-access memory in conventional designs, but employ similar schemes based only on
binary or ternary states for storage and search. We propose a new analog CAM concept and
circuit to overcome these limitations by utilizing the analog conductance tunability of mem-
ristors. Our analog CAM stores data within the programmable conductance and can take as
input either analog or digital search values. Experimental demonstrations and scaled simu-
lations validated the concept and performance, with analysis showing that our analog CAM
can reduce area and power consumption (37×) compared to a digital version. The analog
processing nature enables the acceleration of existing CAM applications, but also new com-
puting application areas including fuzzy logic, probabilistic computing, and decision trees.
1
ar
X
iv
:1
90
7.
08
17
7v
1 
 [c
s.E
T]
  1
8 J
ul 
20
19
Introduction
To increase power efficiency and cost performance, there is growing interest in computing ar-
chitectures that allow for in-memory processing1 in order to reduce data movement and address
the memory wall. In this vein, recent work has shown the promise of using non-volatile memory
devices, or memristors, for accelerating matrix multiplication directly in memory arrays, accelerat-
ing a range of applications such as machine learning2–6, analog signal processing7, 8, and scientific
computing9–11. The performance improvements from this approach originate from two principles.
First, computation is performed where the data is stored, removing the expensive power and la-
tency costs of data movement between separate computing and memory units in a von-Neumann
machine. Second, computation is performed in the analog domain, which provides exponential
efficiency gains over digital, particularly at lower precision requirements. Each device performs
analog computations that would otherwise require multiple digital elements. Despite the great
promise of this approach, demonstrations have thus far been limited to the acceleration of matrix
multiplication via crossbars.
Meanwhile, in-memory computational approaches in the digital domain have been exten-
sively explored over the years12. While many proposed circuit topologies have not been imple-
mented in commercial systems, content addressable memory (CAM) and the related ternary CAM
(TCAM) have stood as a notable exception13, 14. CAM/TCAM circuits natively perform a match-
ing operation between an input data word (search key) and a stored set of data patterns in the
CAM/TCAM array. The operation is highly parallel and another example of an in-memory op-
eration, leading to extremely high throughput compares at low latency, and therefore commercial
2
success in applications such as network routing15, 16, real-time network traffic monitoring17, and
access control lists (ACL)18. While powerful, CAM performance benefits come at the cost of large
power and low memory density, limiting modern usage to high cost niche areas that demand high
performance. Recent work has shown that utilizing non-volatile memristors (or resistive memory
devices) in TCAM circuits reduces area and power19–27 and provides the flexibility to accelerate
powerful finite state machines, particularly for Regular Expression matching used in Network In-
trusion Detection Systems23, 28. However, nearly all memristor-based CAM designs utilize schemes
similar to conventional static random-access-memory (SRAM) designs where the memristor only
encodes binary states. The highly tunable analog conductance in memristor devices, with many
stable intermediate states is not leveraged29.
Here, we propose a memristor-based analog CAM that significantly increases data density
and reduces operational energy and area for these in-memory processing circuits. Our analog CAM
design stores a range of values in each cell using the tunable conductance of memristive devices,
and compares an analog input with this stored range to determine a match or mis-match. The
concept has been validated with proof-of-concept experiments, as well as simulations to establish
performance and scalability. When used to store narrow ranges as discrete levels, our analog
CAM can be a direct replacement to digital CAMs, but providing higher memory densities and
smaller power consumption. This may enable the use of CAMs for more generic scenarios30–33 that
otherwise struggle with the limited memory densities and high power consumption of conventional
CAMs. More importantly, our analog CAM can store wide intervals of continuous levels, thereby
enabling novel search and matching functionality in the analog domain. The analog CAM cell
3
presented here can also be searched with analog input signals, allowing the processing of analog
sensor data without the need for an analog-to-digital conversion step.
Results
Six-transistors two-memristors analog content addressable memory The proposed analog CAM
concept is illustrated in FIGURE 1, where analog voltage values are input to the analog CAM to
be searched against the analog ranges encoded by multilevel conductances in the memristors. This
is distinct from all previously reported CAMs (SRAM or memristor-based), where only digital
signals are searched and stored (FIGURE 1a). Similar to a digital CAM, the ‘match’ signal for
each row is generated on the matchline (ML) only when all the inputs match the data stored in that
row’s memory. In contrast to digital CAMs, each analog CAM cell can match a range of analog
input voltages (FIGURE 1b), instead of a digital value. The analog CAM can be configured to
match a narrow range of discrete values, and therefore one analog CAM cell is a direct functional
replacement for multiple digital CAM cells. In addition, similar to storing a ‘wild card’ or ‘X’ in
the TCAM, the proposed analog CAM also stores a range of continuous values, which would oth-
erwise be difficult to implement with digital CAMs/TCAMs, but (as described later) is beneficial
in internet packet (IP) routing, and more novel applications in genomic sequencing, associative
memories, decision trees, and random forests.
To realize the proposed analog CAM concept, we have designed an analog CAM cell circuit
where each cell is composed of six transistors and two memristors (6T2M) (FIGURE 2a). The
analog input search data is mapped to voltage amplitudes VDL applied along datalines (DL), and
4
Analog CAM
0.48~ 0.76 0.00 ~ 0.15
0.25 ~ 0.63 0.25 ~ 1.00
0.12~ 0.40 0.00 ~ 1.00
0.00 ~ 0.28 0.58 ~ 1.00
0.62 0.12
Input
Match 
Mismatch
Mismatch
Mismatch
ML
a b
X
1
0
0
1
Input
DL
0
0.00 ~ 1.00
0.62 ~ 1.00
0.26 ~ 0.61
0.00 ~ 0.43
0.81
DL
0 1 0 11
1
X
0
0
0
1
X
1
ML
1 0
Match 
Mismatch
Mismatch
Mismatch
Digital CAM / TCAM
Figure 1: Schematic of the memristor analog TCAM concept. a, A digital content-addressable memory
(CAM) compares the input word against all stored words or rows in parallel. Ternary CAM (TCAM) is
an extension where in addition to search/stored ‘0’ and ‘1’ values, ‘X’ is a wildcard that always yields a
match. Data is searched along vertical datalines (DL) and the binary match result of the compare operation
between searched and stored words in each row is sensed on horizontal matchlines (ML). The CAM returns
the match location of stored data and the searched input (first row here). b, The analog CAM searches
and stores analog data, where the input data can be a continuous value, and the stored data is a continuous
interval with a lower and upper bound representing an acceptance range for a match.
5
the stored analog range is configured by the programmed conductances of the two memristors of
the cell (FIGURE 2b). Similar to existing CAM circuit implementations, the search operation starts
by pre-charging each row’s ML to a high logic level, and the MLs stay high (match) only when
all of the attached CAM cells of a row match the corresponding input, otherwise discharging and
leading to a low logic level (mis-match) on the ML. In the 6T2M design, the ML is connected to
pull-down transistors (T1, T2), and is kept high for a ‘match’ result when the gate voltage of the
pull-down transistors is smaller than the threshold voltage, keeping the transistor channel in a high
resistance state.
Each analog CAM cell has an upper and lower bound for matching against the input search
value. These bounds are encoded by a voltage divider sub-circuit which determines the gate voltage
of the pull-down transistor connected to the ML. As shown in FIGURE 2c, the voltage divider sub-
circuit consists of a transistor and a series connected memristor, which generates the gate voltage
(G1) of the pull-down transistor (T1) in the 6T2M analog CAM circuit to embody analog CAM
cell’s lower match threshold. When VDL is larger than a certain threshold voltage, the transistor
is highly conductive and thus the search voltage between SL hi and SL lo (typically at GND) will
mainly drop across the M1 memristor, resulting in a small voltage on G1 that does not turn on
the pull-down transistor, yielding a match result. The lower bound of the input voltage VDL that
yields a match is configured by tuning the memristor conductance in the voltage divider. The upper
bound of the search range is configured similarly with an independent voltage divider using M2
and an inverter to control the gate voltage (G2) of the second pull-down transistor (T2) (FIGURE
2b). This concept is shown by the simulation of the voltage on G1 and G2 depending on VDL with
6
Match
a
ML
DL1
G1
M2M1
T1 T2
DL2
NS NS
Match result
V_DL as search input data
G2
V_DL = search input data
Match
M1 M2
0 0.2 0.4 0.6 0.8 1
Voltage on DL (V)
0
0.1
0.2
0.3
0.4
0.5
0.6
0.7
0.8
V
o
lt
a
g
e
 o
n
 G
1
 (
V
)
200 nS 200 μS
c
G1
M1
DL
b
0 0.2 0.4 0.6 0.8 1
Voltage on DL (V)
0
0.1
0.2
0.3
0.4
0.5
0.6
0.7
0.8
V
o
lt
a
g
e
 o
n
 G
2
200 nS 200 uS
Mismatch
Match
M2
DL
G2
Mismatch
M1 sets V_DL
lower bound
M2 sets V_DL
upper bound
0 1
G(M1)
G(M2)
Lower bound
Upper bound
Match
Match
SL_lo
SL_hi
d
Figure 2: 6T2M analog CAM circuit. a, Schematic of our proposed analog CAM circuit, composed
of six-transistors and two-memristors (6T2M). The input is represented by the voltage amplitude on the
dataline (DL), and the matching result is sensed as the voltage level on the matchline (ML). b, The analog
cell will return a ‘match’ result when the analog input value is within the range (narrow green band) that is
stored by the cell. The range is defined by the conductances of two memristors (M1 and M2) in the cell,
with M1 determining the lower bound and M2 determining the upper bound of the matching range. c, d,
The voltage divider sub-circuits relate the input voltage (a search value) to the gate voltage on the ML pull-
down transistors. (c) When the input voltage is smaller than a threshold, the voltage on the gate of the T1
is large enough to pull down the match line (ML), yielding a ‘mismatch’ result. The threshold is tuned by
the memristor conductance. (d) Similarly, when the input voltage is larger than a threshold, which is tuned
by the second memristor conductance, the cell returns a ‘mismatch’ result by pulling down the ML. Here,
SL hi is at 0.8V which sets the max G1 and G2 voltage.
7
different M1 and M2 memristor conductances (FIGURE 2c, d). As a result, the cell keeps ML high
only when VDL is within a certain range as defined by the M1 and M2 conductances. As several
cells are connected on the same ML in a row, just as in digital CAMs, a row ML outputs ‘high’
only when each cell in the row matches.
Simulations and experiments We validated the operation of our memristor analog circuit with
circuit simulations (see Methods for details) based on a layout using commercial 180 nm design
rules. FIGURE 3a shows the layout with the required peripherals (such as on-chip pre-charging
circuits) and an analog CAM array. The memristor conductance tuning in an analog CAM array is
similar to the ‘write’ operation in a 1T1M array and described in the SUPPLEMENTARY SECTION
1. The current design prioritizes feasibility and demonstration of this new circuit concept, and is
not yet optimized for speed or power consumption.
We first set the conductance of two memristors in one analog CAM cell to 50 µS and 100 µS
and apply different VDL values to observe the changing VML behavior during the search operation.
All other cells are programmed to the ‘always match’ or ‘don’t care’ state, and therefore do not
impact VML. From simulations we see that after the search is initiated (by pulling SL hi high), VML
stays high (FIGURE 3b) when VDL is 0.6 V, indicating a ‘match’, but is discharged low when VDL
is either 0.4 V or 0.8 V for a ‘mismatch’. The operation timing diagram and voltage parameters are
presented in SUPPLEMENTARY FIGURE 2. Therefore, the search result can be measured from the
transient VML at some time following the search when the voltage difference (i.e. sensing margin)
between match and mismatch scenarios is large enough for a sense circuit. The simulated VML
value at 10 ns following the search operation for different VDL (FIGURE 3c) shows that this pro-
8
0 50 100 150 200
Memristor Conductance (µS)
0.3
0.4
0.5
0.6
0.7
0.8
V
_
h
i 
(V
)
0.3
0.4
0.5
0.6
0.7
0.8
V
_
lo
 (V
)
a
8 μm
1
5
 μ
m
Peripheral aCAM array
0.3 0.4 0.5 0.6 0.7 0.8 0.9
VDL (V)
0.3
0.35
0.4
0.45
0.5
0.55
0.6
V
o
lt
a
g
e
 o
n
 M
L
 @
 1
0
 n
s
 (
V
)
VDL (V)
V
o
lt
a
g
e
 o
n
 M
L
 @
 1
0
 n
s
 (
V
)
0.1
0.2
0.3
0.4
0.5
0.6
0.7
0.0 1.00.90.80.70.60.50.40.30.20.1
5 µS (M2)
20 µS (M1)
200 µS (M2)
0.1 µS (M1)ed
b
0 5 10 15 20
Time (ns)
0.1
0.2
0.3
0.4
0.5
0.6
V
o
lt
a
g
e
 o
n
 M
L
 (
V
)
VDL=0.4 V
VDL=0.8 V
VDL=0.6 V
0 0.2 0.4 0.6 0.8 1
V
DL
 (V)
0.1
0.2
0.3
0.4
0.5
0.6
V
o
lt
a
g
e
 o
n
 M
L
 @
 1
0
 n
s
 (
V
)
100 μS50 μS
Match
M1 M2V_lo V_hic
f
Figure 3: Simulations of the memristor analog CAM. a, The layout design of one analog CAM cell in an
analog CAM array with peripherals using commercial 180 nm design rules. The transistors in this proof-of-
concept design are over-sized to allow driving larger currents. b, Simulated transient voltage response on the
ML where the different curves show searches with different data line (DL) voltages for a matching case (red)
and two mismatching cases (blue, yellow). c, The circuit simulation with the same memristor configuration
shown in (b) shows that the cell matches a range of DL voltage, whose bounds are independently controlled
by the conductances of the two memristors in the cell. d, The simulated relation between the search range
and the memristor conductance. The blue curve shows the lower bound of the range, while red shows the
upper bound. e, f, Using differently configured memristor conductances, the cells in the array can store (e)
a continuous range of values, or (f) discrete levels (showing eight levels or 3-bits).
9
grammed memristor configuration corresponds to matching for 0.53 V<VDL <0.65 V. The lower
bound (V lo) and the upper bound (V hi) of the analog CAM cell’s acceptable matching range can
be configured independently by tuning the corresponding memristor conductance in the cell. Using
the resulting mapping between the voltage bound and conductances (FIGURE 3d) as a guide, we
configured analog CAM cells to match various voltage ranges (FIGURE 3e and SUPPLEMENTARY
FIGURE 3) or eight narrower ranges (FIGURE 3f) for representing 3-bit discrete voltage levels.
The results show that the proposed analog CAM cell implements the desired functionality and can
be used to search for both discrete levels, encoding multiple bits in a single cell, or for arbitrary
analog voltage ranges to encode continuous values.
We experimentally verified the proposed analog CAM cell operation using 1T1M structures
with a test point between the memristor and transistor (see FIGURE 4a and Methods), allowing us to
measure the FIGURE 2c voltage divider sub-circuit. The memristor devices were integrated through
a back-end-of-the-line (BEOL) CMOS process in our lab, with Ta/HfO2 memristor devices34 with
a wide > 104 range of conductance tunability (FIGURE 4b) and a programming voltage ∼1 V
(FIGURE 4c), enabling us to validate the simulations described previously. With memristor con-
ductances programmed across this wide range, we measured the G1 voltage while sweeping VDL
up from zero (FIGURE 4d). The relationship between the search lower bound and the memris-
tor conductance is extracted and plotted in FIGURE 4e. Comparing experimental results (FIGURE
4d and 4e) to simulation (FIGURE 2c and 3d) shows qualitative agreement, and the operational
memristor conductance range experimentally demonstrated more than meets the required range to
encode 3-bits of information in this analog CAM cell.
10
aG1
DL
SL_lo
SL_hi
Ground
d
G
1
 V
o
lt
a
g
e
 (
V
)
0.5
0.4
0.3
0.2
0.0
0.1
DL Voltage (V)
0.5 1.0 1.5 2.0 2.5 3.0
960 µS58 nS
Threshold
e
0 200 400 600 800 1000
G
memristor ( S)
1
1.2
1.4
1.6
1.8
2
V_
lo
 
(V
)
Experiment
b
C
u
rr
e
n
t 
(A
)
Voltage (V)
-0.2 -0.1 0 0.1 0.2
10-9
10-3
10-4
10-5
10-6
10-7
10-8
> 4 orders
of magnitude
960 µS
58 nS
Experiment c
-1.5 -1 -0.5 0 0.5 1 1.5
Voltage (V)
-400
-300
-200
-100
0
100
200
300
C
u
rr
e
n
t 
(
A
)
SET
RESET
Memristor
Experiment
Mismatch
Match
Figure 4: Proof-of-principle experimental demonstration. a, An optical microscopic image of a mem-
ristor integrated monolithically on top of silicon transistors. Scale bar, 4 µm b, The current-voltage relation
of the memristor in the proposed analog CAM circuit for many programmed states, showing the wide con-
tinuously tunable conductance range. c, The conductance can be tuned from a low conductance state to a
high conductance state by a large voltage (> 0.5V) on SL hi, and reversely by a large voltage on SL lo.
d, After configuring the memristor to different conductances, the experimentally measured gate voltage of
the pull-down transistor (corresponding to G1 node in Fig. 2c) drops below the threshold voltage with in-
creasing voltage on DL. During the measurement, SLhi and SLlo is biased at 0.5 V and 0 V respectively.
e, The boundary DL voltage for the analog CAM outputting a ’match’ (i.e. the pull-down transistor stays
off) increases with the programmed memristor conductance. Despite the different transistor size in this
proof-of-concept experiment, the result qualitatively matches the simulation in FIGURE 3d.
11
The relationship between an analog CAM cell’s stored range for a match and the programmed
memristor conductances can be understood by the series connected transistor and memristor volt-
age divider (see FIGURE 2c, 2d). During a search operation, the serial transistors in the divider
are working in the triode regime, as the voltage drop across the transistor channel is fairly small.
Under this condition, VML stays high when VDL follows EQUATION 1, with bounds from the lower
bound M1 voltage divider and the higher bound M2 voltage divider.
GM1 · (VSLhi/VTH,ML−1)/β +VTH ≤VDL ≤ GM2 · (VSLhi/VTH,inv−1)/β +VTH (1)
where VTH, VTH,ML, VTH,inv are the threshold voltages of the transistor in the M1 voltage divider, the
T1 pull-down transistor, and the inverter respectively. β (= ∂GT/∂VDL) is a constant coefficient in
the transistor transfer function. GM1 and GM2 are the memristor conductances, which are linearly
related to the accepted VDL for a match according to the above equation. This analysis is consistent
with the results shown in FIGURE 3d and FIGURE 4e, with an exception when the memristor
conductance is very small such that the transistor voltage drop is also small, requiring the addition
of nonlinear effects to the equation. Under this assumption, we can scale up our simulations from
single cells to large analog CAM arrays to predict performance.
Memristor analog CAM arrays While we have demonstrated single analog CAM cell operation
in a small array, it is crucial to investigate whether large arrays can be operated without fatal
degradation effects. Using extracted parasitic parameters from layout, we constructed analog CAM
arrays with arbitrary numbers of rows and columns (see Methods) to study how the analog CAM
performs with increasing array size. FIGURE 5a shows the simulation configuration, where the
two memristors in all of the analog CAM cells are configured to 50 µS and 100 µS to accept VDL
12
from 0.53 V to 0.65 V. All DLs are biased to 0.6 V, except for one column DL that is swept from
0.0 V to 1.0 V to observe how VML changes. This single-bit mismatch is the worst-case scenario as
it represents the situation where the mismatch VML is closest to the match VML behavior. Since all
cells with VDL =0.6 V match, the VML drop leading to a ‘mismatch’ is initiated by the cells in the
column with the sweeping DL. Analog CAM arrays with two columns but an increasing number
of rows show no change (FIGURE 5b,c) in VML with additional rows (simulated up to 1024 rows),
demonstrating negligible row-wise interference.
As expected even with conventional CAMs, increasing the number of columns can lead to a
degradation of the VML (FIGURE 5d) such that the acceptable search range is slightly changed. Our
analysis shows that this results from the sub-threshold leakage current of the pull-down transis-
tors (see SUPPLEMENTARY SECTION 3 for more details). Nevertheless, the results show that the
change in the accepted voltage range is within 0.05 V, which is sufficient to separate eight discrete
levels for 3-bit searching capability in a 72-column analog CAM array.
To address the issue of sub-threshold current leakage which limits the word length and the
number of stored bits per cell, we propose to replace the standard ML pull-down transistor with
volatile threshold switching (TS) memristors35–37. Our analog CAM cell is converted to a circuit
that is composed of four transistors, two non-volatile memristors, and two volatile TS memristors,
as shown in FIGURE 6a. In contrast to our above implementation using pull-down transistors to
discharge the ML for a mismatch result, a search operation in this case starts with ML at ground,
and the ML is charged up only for mismatch cases. The performance of the proposed cell is
evaluated in simulation (see Methods), where the Verilog-A based volatile TS memristor model
13
a b
c d
N
u
m
b
e
r o
f ro
w
s
12 24 36 48 60 72
Number of columns with row# = 2
0.2
0.3
0.4
0.5
0.6
0.7
0.8
M
a
tc
h
in
g
 V
o
lt
a
g
e
 (
V
) V_hi
V_lo
0.53~ 0.65 0.53 ~ 0.65
0.53 ~ 0.65 0.53 ~ 0.65
0.53 ~ 0.65 0.53 ~ 0.65
0.53 ~ 0.65 0.53 ~ 0.65
0.60 0.60
Input
ML
0
0.53 ~ 0.65
0.53 ~ 0.65
0.53 ~ 0.65
0.53 ~ 0.65
V_DL
DL
0 1 0 11
Number of columns
128 256 384 512 640 768 896 1024
Number of rows with col# = 2
0.2
0.3
0.4
0.5
0.6
0.7
0.8
M
a
tc
h
in
g
 V
o
lt
a
g
e
 (
V
) V_hi
V_lo
1024
768
N
um
be
r 
of
 r
ow
s
w
ith
 c
ol
# 
= 
2
5120.1
2560
0.2
VDL (V )
0.3
0.5
V
_
M
L
 @
 5
0
 n
s
 (
V
)
0.4
1
0.5
V_lo
V_hi
Figure 5: Analog CAM arrays. a, Simulated analog CAM arrays with different sizes using extracted
parasitic parameters. b, The sensed ML voltage with respect to the input voltage applied to the DL in arrays
with an increasing number of rows (or words). High logic level on the ML indicates that the searching input
matches the stored memory, where the lower and the higher bounds (V lo and V high) are labeled in the
plot. c, With an increasing number of rows, the searching range of one cell in the array stays unchanged.
d, On the other hand, it changes noticeably with an increasing number of columns. In the worst case, up
to 50 mV change is observed in an array of 72 columns. This still allows the capability to store and search
3-bits of information per analog cell across the 72 columns, but going beyond this would be challenged by
the present circuit.
14
cd
b
DL1
M2M1
DL
DL2
SLhi
SLlo
nDischarge
ML
MLso
G2G1
Threshold switching 
memristor
TS1 TS2
a
fe
10
-3
10
-5
10
-7
10
-9
10
-11
10
-13
10
-15
0.0 0.1 0.2 0.3 0.4 0.5 0.6
Voltage (V)
C
u
rr
e
n
t 
(A
)
Simulation
Vth
1 mV / dec
Vhold
0.0 0.2 0.4 0.6 0.8 1.0
V_DL (V)
G_M1 = 50 µS G_M2 = 100 µS
0.7
0.6
0.5
0.4
0.3
0.2
0.1
0.0
V
_
M
L
 @
 5
0
 n
s
 (
V
)
0.35
0.30
0.25
0.20
0.15
0.10
0.05
0.00
V
_
M
L
s
o
 @
 5
0
 n
s
 (
V
)
0.3 0.4 0.5 0.6 0.7 0.8 0.9 1.0
V_DL (V)
0.40
0.35
0.30
0.25
0.20
0.15
0.10
0.05
0.00
V
_
M
L
s
o
 @
 5
0
 n
s
 (
V
)
12 24 36 48 60 72
Number of columns
0.2
0.3
0.4
0.5
0.6
0.7
0.8
M
a
tc
h
in
g
 V
o
lt
a
g
e
 (
V
)
72
48
N
um
be
r 
of
 c
ol
um
ns
w
ith
 r
ow
# 
= 
20 24
0
0.2
V_DL (V)
0.2 0.4 0.6
0.4
V
_
M
L
  
(V
)
0.8 1
0.6
0.8
V_lo V_hi
V_lo
V_hi
Figure 6: An analog CAM circuit using both volatile and non-volatile memristors a, Schematic for our
analog CAM circuit, composed of four transistors and four memristors (two non-volatile and two volatile).
The volatile threshold switching memristors pull up the ML in the case of a mismatch, which replaces
the pull-down transistors in the 6T2M circuit. b, The volatile memristor is a threshold switching device
with a very sharp transition between states (e.g.1 mV/dec35), therefore reducing column interference issues
exposed in earlier simulations. c, The match line stays low only when the input pattern (VDL) matches the
stored range. The dashed line shows the signal after the match line sense amplifier output (VMLSO), which
inverts and converts the analog signal to a binary ‘match’ (high) or ‘mismatch’ (low) signal. d, Due to
the much smaller ∂Gpu/∂VG, the cell promises the capability to store more accurate ranges and accordingly
more bits of discrete levels (showing 16 levels). e, f The search operation with a simulated array of different
word width. The programmed memristor configuration and the expected searching range is the same as that
in FIGURE 5, but the searching range is altered less than 10mV indicating the capability to store 5-bits of
information, which is close to the precision limit of most non-volatile memristor devices.
15
is extracted from published experimental data35. FIGURE 6b shows t he simulated current-voltage
(IV) curve for the TS memristor, from which one sees a significantly smaller sub-threshold swing
than MOSFET transistors, thereby greatly decreasing the sub-threshold current leakage on the ML.
The ML voltage sensed at 50 ns after the search starts (FIGURE 6) shows a match for VDL between
0.53 V and 0.65 V (see SUPPLEMENTARY SECTION 4 for additional details). As with the previous
analog CAM cell, the simulated analog cell can be configured to match different VDL ranges by
programming different memristor conductances. FIGURE 6d shows the successful analog CAM
cell with 16 discrete programmable matching states. Further simulations (FIGURE 6e and f) of the
analog CAM arrays show that the change in the matching voltage range moves by less than 0.01 V
with columns of up to 72, indicating the capability to store and search 5-6 bits of information,
showing a significant improvement from conventional designs with pull-down transistors.
Discussion The main advantages of our proposed analog CAM are the improvements in energy
and area over existing digital approaches. To demonstrate the potential scale of these improve-
ments, we compared our analog CAM approach with the digital-equivalent for the usecase of clas-
sifying Internet protocol (IP) packets, which is a common commercial application for CAMs13.
The ternary wildcard ‘X’ capability of TCAMs is frequently used to compress multiple table en-
tries into one row in the IP routing look-up table, owing to the fact that most classifying ranges
are continuous. With our proposed analog CAM that is able to store broad ranges, this look-up
table can be further compressed. Analysis in the previous section suggested that one analog CAM
cell is capable of searching 8-64 discrete levels, depending on the implementation. This enables
compressed rows, where fewer cells are required to store the same number of bits of information.
16
Additionally, taking advantage of the range storage capability, fewer rows are also required than
in a digital CAM/TCAM representation. A real example is given in SUPPLEMENTARY SECTION
5, which shows a 14x reduction in number of required cells (from conventional TCAM to 16 level
analog CAM cells, further reduction is possible with improved analog CAM cells). In addition,
with only six transistors in an analog CAM cell, and 16 in an SRAM-based TCAM cell, an overall
37× reduction in chip area (or increased memory density) is achieved as well as a similar reduc-
tion in dynamic power consumption as this is dominated by wire capacitances. Static power is also
reduced due to the non-volatility of the memristor device. We anticipate additional benefits when
analog rather than digital data is directly processed by our analog CAM.
In summary, we have proposed an analog CAM cell circuit taking advantage of the analog
memristor conductance tunability for the first time. A practical circuit implementation composed
of six transistors and two memristors has been demonstrated in both experiment and simulation.
The analog CAM increases memory density significantly, as one analog CAM cell can store multi-
ple bits with only six transistors while an SRAM CAM cell stores 1 bit values with 10 transistors,
or ternary values with 16 transistors in a TCAM cell. The analog capability opens up the possibility
for directly processing analog signals acquired from sensors, and is particularly attractive for Inter-
net of Things applications due to the potential low power and footprint. The output of the analog
CAM after the sense amplifiers is digital, and thus can also remove the analog-digital conversion
cost entirely. Finally, the functionality of our analog CAM with interval storage is intrinsically
different from digital CAMs, which may enable new computing applications in fuzzy logic and
probabilistic processing where inexact compares and real-valued analog transition probabilities
17
are common.
Methods
Memristor integration The memristor is monolithically integrated on top of transistors that are
fabricated in a commercial foundry under 2 µm technology node. The integration starts with a
removal of native oxide on the surface metal with physical bombardment with argon ions. An
about 100 nm palladium is then sputtered and patterned as the bottom electrode, followed by a
atomic layer deposited 5 nm hafnium dioxide as switching layer and a sputtered 50 nm tantalum as
the top electrode. The device stack is finalized by a sputtered 10 nm palladium for passivation and
improved electric conduction.
Circuit simulation for analog CAM cell and arrays The proposed 6T2M analog CAM cells de-
signed in the Cadence Virtuoso Custom IC design environment (version 6.1.7), and the simulation
result is analyzed and post-processed with HP-SPICE (version 4.11). The simulations utilize the
TSMC 180 nm library and the designs follow the corresponding rules. The voltage parameters
and timing diagram are shown in SUPPLEMENTARY FIGURE 2. A custom python script gener-
ates the netlist for analog CAM arrays with different numbers of rows and columns and arbitrary
configured memristor conductances and input voltages. In the netlist, the parasitic parameters are
extracted from the taped out layout, including the wire resistance (for ML, SL, DL, etc) of 1.4Ω
per block and capacitance of 1.9 fF between different analog CAM cells. The voltage stimulus is
always applied to the nodes that are the furthest from the ML sensing node, so that the impact of
the wire resistance is the most significant, i.e. the worst case scenario.
18
Electrical characterization The electrical characterization is conducted with a semiconductor
parameter analyzer (Keysight B1500A) and Cascade probe station under room temperature. The
conductance programming is performed with quasi-static direct-current (DC) sweeps, and where
the current through the device is limited and controlled by the series connected transistor. After
programming, the memristor conductance is readout by applying a small voltage across the mem-
ristor with the series-connected transistor fully turned on. The search operation is conducted by
applying and sensing voltages from the corresponding node to/from a source measurement unit
(SMU) on the B1500A.
19
Reference
1. Williams, R. S. What’s next?[the end of moore’s law]. Computing in Science & Engineering
19, 7–13 (2017).
2. Hu, M. et al. Memristor-based analog computation and neural network classification with a
dot product engine. Advanced Materials (2018).
3. Li, C. et al. Efficient and self-adaptive in-situ learning in multilayer memristor neural net-
works. Nature Communications 9, 2385 (2018).
4. Ambrogio, S. et al. Equivalent-accuracy accelerated neural-network training using analogue
memory. Nature 558, 60 (2018).
5. Bayat, F. M. et al. Implementation of multilayer perceptron network with highly uniform
passive memristive crossbar circuits. Nature communications 9, 2331 (2018).
6. Yao, P. et al. Face classification using electronic synapses. Nature Communications 8, 15199
(2017).
7. Li, C. et al. Analogue signal and image processing with large memristor crossbars. Nature
Electronics 1, 52 (2018).
8. Sheridan, P. M. et al. Sparse coding with memristor networks. Nature nanotechnology 12,
784 (2017).
9. Zidan, M. A. et al. A general memristor-based partial differential equation solver. Nature
Electronics 1, 411 (2018).
20
10. Le Gallo, M. et al. Mixed-precision in-memory computing. Nature Electronics 1, 246 (2018).
11. Sun, Z. et al. Solving matrix equations in one step with cross-point resistive arrays. Proceed-
ings of the National Academy of Sciences 116, 4123–4128 (2019).
12. Zhang, H., Chen, G., Ooi, B. C., Tan, K.-L. & Zhang, M. In-memory big data management
and processing: A survey. IEEE Transactions on Knowledge and Data Engineering 27, 1920–
1948 (2015).
13. Pagiamtzis, K. & Sheikholeslami, A. Content-addressable memory (cam) circuits and archi-
tectures: A tutorial and survey. IEEE journal of solid-state circuits 41, 712–727 (2006).
14. Meiners, C. R., Patel, J., Norige, E., Torng, E. & Liu, A. X. Fast regular expression matching
using small tcams for network intrusion detection and prevention systems. In Proceedings of
the 19th USENIX conference on Security, 8–8 (USENIX Association, 2010).
15. Chao, H. J. Next generation routers. Proceedings of the IEEE 90, 1518–1558 (2002).
16. McAuley, A. J. & Francis, P. Fast routing table lookup using cams. In INFOCOM’93. Proceed-
ings. Twelfth Annual Joint Conference of the IEEE Computer and Communications Societies.
Networking: Foundation for the Future, IEEE, 1382–1391 (IEEE, 1993).
17. Xu, C., Chen, S., Su, J., Yiu, S. & Hui, L. C. A survey on regular expression matching for deep
packet inspection: Applications, algorithms, and hardware platforms. IEEE Communications
Surveys & Tutorials 18, 2991–3029 (2016).
21
18. Bechtolsheim, A. V. & Cheriton, D. R. Access control list processing in hardware (2002). US
Patent 6,377,577.
19. Huang, L.-Y. et al. Reram-based 4t2r nonvolatile tcam with 7x nvm-stress reduction, and
4x improvement in speed-wordlength-capacity for normally-off instant-on filter-based search
engines used in big-data processing. In 2014 Symposium on VLSI Circuits Digest of Technical
Papers, 1–2 (IEEE, 2014).
20. Chang, M.-F. et al. 17.5 a 3t1r nonvolatile tcam using mlc reram with sub-1ns search time. In
Solid-State Circuits Conference-(ISSCC), 2015 IEEE International, 1–3 (IEEE, 2015).
21. Lin, C.-C. et al. 7.4 a 256b-wordlength reram-based tcam with 1ns search-time and 14×
improvement in wordlength-energyefficiency-density product using 2.5 t1r cell. In Solid-State
Circuits Conference (ISSCC), 2016 IEEE International, 136–137 (IEEE, 2016).
22. Li, J. et al. 1mb 0.41 µm 2 2t-2r cell nonvolatile tcam with two-bit encoding and clocked
self-referenced sensing. In VLSI Circuits (VLSIC), 2013 Symposium on, C104–C105 (IEEE,
2013).
23. Graves, C. E. et al. Regular expression matching with memristor tcams for network security.
In 2018 IEEE/ACM International Symposium on Nanoscale Architectures (NANOARCH), 1–7
(IEEE, 2018).
24. Grossi, A. et al. Experimental investigation of 4-kb rram arrays programming conditions
suitable for tcam. IEEE Transactions on Very Large Scale Integration (VLSI) Systems (2018).
22
25. Bayram, I. & Chen, Y. Nv-tcam: Alternative designs with nvm devices. Integration 62, 114–
122 (2018).
26. Li, S., Liu, L., Gu, P., Xu, C. & Xie, Y. Nvsim-cam: a circuit-level simulator for emerging non-
volatile memory based content-addressable memory. In Proceedings of the 35th International
Conference on Computer-Aided Design, 2 (ACM, 2016).
27. Yang, R. et al. Ternary content-addressable memory with mos 2 transistors for massively
parallel data search. Nature Electronics 1 (2019).
28. Graves, C. E. et al. Regular expression matching with memristor tcams. In 2018 IEEE Inter-
national Conference on Rebooting Computing (ICRC), 1–11 (IEEE, 2018).
29. Sheng, X. et al. Low-conductance and multilevel cmos-integrated nanoscale oxide memristors.
Advanced Electronic Materials 1800876 (2019).
30. Batcher, K. E. Staran parallel processor system hardware. In Proceedings of the May 6-10,
1974, national computer conference and exposition, 405–410 (ACM, 1974).
31. Tracy, T., Fu, Y., Roy, I., Jonas, E. & Glendenning, P. Towards machine learning on the
automata processor. In International Conference on High Performance Computing, 200–218
(Springer, 2016).
32. Guo, Q., Guo, X., Bai, Y. & I˙pek, E. A resistive tcam accelerator for data-intensive computing.
In Proceedings of the 44th Annual IEEE/ACM International Symposium on Microarchitecture,
339–350 (ACM, 2011).
23
33. Guo, Q., Guo, X., Patel, R., Ipek, E. & Friedman, E. G. Ac-dimm: associative computing with
stt-mram. ACM SIGARCH Computer Architecture News 41, 189–200 (2013).
34. Jiang, H. et al. Sub-10 nm Ta Channel Responsible for Superior Performance of a HfO2
Memristor. Scientific Reports 6, 1–8 (2016).
35. Midya, R. et al. Anatomy of ag/hafnia-based selectors with 1010 nonlinearity. Advanced
Materials 29, 1604457 (2017).
36. Kim, S. et al. Ultrathin (< 10nm) Nb2O5/NbO2 hybrid memory with both memory and selec-
tor characteristics for high density 3d vertically stackable rram applications. In 2012 Sympo-
sium on VLSI Technology (VLSIT), 155–156 (IEEE, 2012).
37. Son, M. et al. Excellent selector characteristics of nanoscale VO2 for high-density bipolar
reram applications. IEEE Electron Device Letters 32, 1579–1581 (2011).
Acknowledgement This research was based upon work supported by the Office of the Director of National
Intelligence (ODNI), Intelligence Advanced Research Projects Activity (IARPA), via contract number 2017-
17013000002. The views and conclusions contained herein are those of the authors and should not be
interpreted as necessarily representing the official policies or endorsements, either expressed or implied, of
the ODNI, IARPA, or the U.S. Government.
Competing Interests The authors declare that they have no competing financial or non-financial interests.
Correspondence Correspondence and requests for materials should be addressed to first-name.last-name@hpe.com.
24
Supplemental Information
1 Programming of memristor devices in an analog CAM array
The memristors in the analog CAM need to be properly programmed before the search operation,
and the search operation has been introduced in the main text. SUPPLEMENTARY FIGURE 1 shows
the schematic operation during memristor programming. The key elements that are involved in
the write operation is highlighted in the figure, while other lines not used for writing are greyed
out. From the schematic, one sees that the write operation is similar to that of a one-transistor
one-memristor (1T1M) array: The DLs (data lines) select the memristor device to be programmed
(as well as the aCAM array column), and the programming voltage is applied through the SL hi
and SL lo row wires to set (program the device from a low conductance state to a high conductance
state) or reset the the device (and select the aCAM array row). An analog voltage can be applied
to DLs to set a compliance current during the set operation for a better multilevel tunability2, 7.
ML
DL1
G1
M2M1
T2
T3
T6
T4
T5
DL
DL2
NS NS
SL_hi
SL_lo
T1
Supplementary Figure 1: The schematic for the programming operation of the memristors in an
analog CAM cell
In the case that the programmed memristor conductance needs to be verified after the write
operation, the conductance of a given memristor be read out by measuring the current while ap-
25
plying a reading voltage across SL hi and SL lo, with DL activated to select the device. TABLE 1
summarizes the detailed voltage signals required for various operations.
Supplementary Table 1: Write operation of the analog CAM cell
Operation SL hi SL lo DL1 DL2
Set M1 Vset 0 Vg,set 0
Reset M1 0 Vreset VDD 0
Set M2 Vset 0 0 Vg,set
Reset M2 0 Vreset 0 VDD
Read M1 Vread 0 VDD 0
Read M2 Vread 0 0 VDD
26
2 Supplementary data for the search operation in the analog CAM
a
ML
0.0
2.0
0.0
1.0
0.0
PC
SL_hi
0.6
Precharge Search Precharge Search
Match
Mismatches
Match
Mismatches
DL
ML
G1
M2M1
T1 T2
NS NS
G2
SL_lo
SL_hi
PC
VPC
b
c
DL D0 D1 D2
PC
SL_hi
ML
Supplementary Figure 2: a, A simplified schematic of one analog CAM cell with precharging p-type
MOSFET attached to its ML. b, The timing diagram for a search operation, where ML precharging is
initiated by setting PC high, and the search operation by SL hi. c, HPSPICE plot of the transient simulation
of the precharging and search operation for two cycles. The ML is pulled down when the DL voltage
mismatches the stored range, and is kept high in the case of a match.
27
ca
0
0
0.2
5
V
o
lt
a
g
e
 o
n
 M
L
 (
V
)
0.4
Time (ns)
110
0.6
0.8
Voltage on DL (V)
0.615 0.4
0.220 0
0
0
0.2
5
V
o
lt
a
g
e
 o
n
 M
L
 (
V
)
1
Time (ns)
0.4
10 0.8
Voltage on DL (V)
0.615
0.6
0.4
0.220 0
0 0.2 0.4 0.6 0.8 1
 VDL (V)
0.1
0.2
0.3
0.4
0.5
0.6
V
o
lt
a
g
e
 o
n
 M
L
 @
 1
0
 n
s
 (
V
)
GM2=100 μSGM1=50 μS
0 0.2 0.4 0.6 0.8 1
0.1
0.2
0.3
0.4
0.5
0.6
V
o
lt
a
g
e
 o
n
 M
L
 @
 1
0
 n
s
 (
V
)
 VDL (V)
GM1=80 μS GM2=200 μS
b
d
Supplementary Figure 3: The search operation in the analog CAM with different DL voltages and
memristor conductance configurations a, The three-dimensional (3D) plot for the transient ML voltage
response after the search is initiated with various voltage applied to the DL. The memristor in the analog
CAM cell is configured to 50 µS and 100 µS respectively. b, The same 3D plot with the memristors in the
cell configured to 80 µS and 200 µS. c, d Relationship between the sensed ML voltage (search result), and
the voltage on DL, for the two different configurations in (a) and (b) respectively.
28
3 Analysis on the effect of word length
The search operation of our analog CAM can be illustrated in SUPPLEMENTARY FIGURE 4. In the
schematic, each dashed square represents a ML pull-down path in one analog CAM cell, which
is a transistor whose channel conductance is low when the stored content matches the input and
high when mismatches. Therefore, the ML stays high only when all the cells in a row match
the given input, and the result is sensed by a sense amplifier attached to the ML. However, since
all the pull-down paths are connected in parallel, when the word is long enough the overall pull-
down conductance for a ‘match’ case could be higher than a mismatch worst case (i.e. a single-bit
mismatch), leading to a sensing error and/or changes in the accepted search range of an analog
CAM cell.
ML
... ...
Match
Mismatch
Supplementary Figure 4: The schematic of an analog TCAM word in with only one-bit is mismatch
during the search operation.
The problem is examined by quantitative analysis. The ML discharge process can be mod-
elled by a RC decay or the discharging of a capacitor with a constant current sink (see SUPPLE-
MENTARY FIGURE 4). When all the analog CAM cells match the input, the equivalent conductance
of the pull-down path is roughly N ·GT, OFF, where N is the word length (i.e. width of the analog
CAM array row). The pull-down path conductance for a mismatched case is larger or equal to
GT, ON +(N− 1) ·GT, OFF. A margin is required to differentiate the ‘match’ and the ‘mismatch’
29
cases, which requires that the match case overall pull-down conductance is larger than that for a
mismatch case. If we define the ratio of the conductance difference as β (> 1), the requirement can
be described in EQUATION 2, and therefore the word length is limited by the conductance ON/OFF
ratio (dynamic range) of the pull-down transistor.
GT, ON > [(β −1)N+1] ·GT, OFF (2)
In addition, when the margin is large enough, the small pull-down leakage from the ‘match’
cells could change the search result as pointed out in the main text. This is because the conductance
of the pull-down transistor is continuous with respect to the DL voltage (G = f (VDL)), and so the
search range for one analog CAM cell in an array is affected by other cells attached to the same
ML, described in EQUATION 3.
GT = f (VDL)< Gth− (N−1) ·GT, OFF (3)
where Gth is the criteria to differentiate the ‘match’ and ‘mismatch’ case. It is clear that other cells
attached to the same ML equivalently shift the criteria, and therefore the search range. The amount
of the change is reflected by ∂GT/∂VDL, i.e. the conductance sensitivity to the change of analog
voltage signal. The sensitivity can be written as (αSs)−1, where α is the ratio between changes in
VDL and VG, and Ss is the subthreshold swing slope of the transistor. As an example, considering
a typical value for the VDL to VG ratio of 0.1 (simulated data shown in FIGURE 3d and 3e), and Ss
of 100 mV/dec, the equation gives the overall sensitivity of about dec/10 mV. In simulation, the
30
change in the search range simulated in FIGURE 5 is tens of mV, which is fairly consistent with
our analysis here. Therefore, employing the volatile threshold switching memristor with small
sub-threshold swing great improves the performance, as simulated in FIGURE 6 and described in
the main text.
4 Analog CAM with emerging threshold switching memristor
0 5 10 15 20 25 30
Time (ns)
0.6
0.4
0.2
0.0
0.6
0.4
0.2
0.0
V
o
lt
a
g
e
 (
V
)
C
u
rr
e
n
t 
(m
A
)
a b
-20 0 20 40 60 80
Time (ns)
VDL= 0.6 V (Match)
VDL= 0.8 V (Mismatch)
VDL= 0.4 V (Mismatch)
0.7
0.6
0.5
0.4
0.3
0.2
0.1
0.0
V
_
m
l 
(V
)
Memristor Conductance (µS)
V
_
h
i 
(V
)
1.0
0.9
0.8
0.7
0.6
0.5
0.4
0.3
0.2
500 100 150 200 250 300
V
_
lo
 (
V
)
1.0
0.9
0.8
0.7
0.6
0.5
0.4
0.3
0.2
Crossing VG2 = Vth
Crossing VG2 = Vth
0.7
0.6
0.5
0.4
0.3
0.2
0.1
0.0
0.3 0.4 0.5 0.6 0.7 0.8 0.9 1.0
V_dl (V)
V
_
m
l 
@
 5
0
 n
s
 (
V
)
c d
Supplementary Figure 5: Additional information on the analog CAM with threshold switching mem-
ristor. a, The transient response of the simulated threshold switching device. The applied voltage is swept
from 0 V to 0.6 V. The current flowing through the device abruptly increases when the voltage reached the
threshold voltage (0.4 V in this case), and decreases abruptly after the voltage drops below the hold voltage
(0.1 V in this case). b, The transient voltage response on the match line (ML) during the search operation,
for the cases that the stored range matches (in red) and mismatches (in blue and yellow) the input (VDL)
respectively. c, The relation between the searching ranges and the corresponding memristor conductance.
d, The match line readout voltage at the time of 50 ns after the search operation for differently configured
searching ranges. The correspondig output after a sense amplifier is plotted in FIGURE 6d. The plots show
the device can be used to store and search at least 16 discrete levles.
31
5 Comparison between the range search with TCAM and multibit analog CAM
21
16
a b
c
9
6
4
6
Supplementary Figure 6: CAM tables for searching the range between 365 and 58630, with (a)
TCAM, (b) 3-bit analog CAM and (c) 4-bit analog CAM.
Here we consider the CAMs that are used in a network router for classifying a random range in
a 16-bit Class B IP address space (0-65535). In a TCAM, a continuous range can be represented
by storing ‘X’ in the least significant bits - for example, 01XX is a range between the binary
number of 0100 and 0111 (or decimal number 4-7). However, in most cases a random range will
need to be split into multiple entries to fit in a TCAM. Taking a random range between 385 and
58630 (or hexadecimal number 0181 - E506), we observe that this range can be implemented by
a 21×16 TCAM array as shown in SUPPLEMENTARY FIGURE 6. Although it may seem to be an
acceptable overhead in this example here, this may not be the case when the ranges in a larger
32
space are considered (e.g. 128 bit for IPv6). Here, we restrict ourselves to this smaller example for
comparison purposes.
First, we observe that the whole TCAM array described above for a range search can be
replaced by a single 16-bit analog cell. Admittedly, it is challenging to realize a 16-bit analog CAM
cell currently, but we’ve shown that it is very feasible for a 3-bit or 4-bit cell to be implemented,
as demonstrated in FIGURE 3e,f. With limited bit-precision analog CAM cells, the range can be
split in a similar way as in TCAM entries. SUPPLEMENTARY FIGURE 6b and SUPPLEMENTARY
FIGURE 6c show implementations with 3-bit analog CAM and 4-bit analog CAM respectively. In
the table, ‘X’ is similar to that in the TCAM, which matches everything, i.e. 0-7 in a 3-bit cell or
0-15 in a 4-bit cell. {n−m} represent the cell is configured to match part of the range between n
and m. From the figure, one sees that by using a multi-bit analog CAM, both columns and rows
can be compressed, leading to a reduction from 336 TCAM cells to 54 3-bit cells or 24 4-bit cells.
In addition, there are only six transistors in an analog CAM cell, while 16 in a SRAM-based one.
With these factors taken into consideration, the overall transistor count required for this specific
function results in a 37× reduction in chip area. We also expect a similar reduction in operational
power with the analog CAM cell in comparison to conventional TCAMs, as a major portion of the
dynamic energy consumption for a CAM operation is charging parasitic wire capacitances, and the
reduced cell count and area also results in shorter wires and reduces total wire capacitance.
33
