SPICE compact modeling of bipolar/unipolar memristor switching governed by electrical thresholds by Garcia-Redondo, Fernando et al.
1SPICE Compact Modeling of
Bipolar/Unipolar Memristor Switching
Governed by Electrical Thresholds
Fernando Garcı´a-Redondo Student Member, IEEE, Robert P. Gowers, A. Crespo-Yepes,
Marisa Lo´pez-Vallejo, Member, IEEE and Liudi Jiang
Abstract—In this work we propose a physical memristor/re-
sistive switching device SPICE compact model, that is able
to accurately fit both unipolar/bipolar devices settling to its
current-voltage relationship. The proposed model is capable of
reproducing essential device characteristics such as multilevel
storage, temperature dependence, cycle/event handling and even
the evolution of variability/parameter degradation with time.
The developed compact model has been validated against two
physical devices, fitting unipolar and bipolar switching. With no
requirement of Verilog-A code, LTSpice and Spectre simulations
reproduce distinctive phenomena such as the preforming state,
voltage/cycle dependent random telegraph noise and device
degradation.
Index Terms—Memristor, RRAM, ReRAM, Variability, RTN,
Degradation, SPICE, Compact Model, Multi-level, Circuit Sim-
ulation, Temperature
I. INTRODUCTION
Resistive switching (memristor) technologies are a promis-
ing part of next-generation nonvolatile memory. Their low
power consumption, high density, fast operation and great
endurance, as well as the integration capabilities with stan-
dard CMOS circuitry put memristive technologies under the
spotlight. However, resistive random access memory (ReRAM
or RRAM) is only one of the several applications where
memristor technology has promising applications. Memristor
based reconfigurable hardware, material-implication logic de-
sign or neuromemristive systems -neuromorphic computing
using memristors- provide a solid alternative for standard
CMOS circuits.
Close attention has been given to the fabrication of smaller,
faster and more reliable resistive switching devices, using both
oxide and semiconductor materials. Furthermore, major efforts
have been made to characterize and correctly model those
devices’ behavior, depending on the properties of the materials
and their fabrication conditions.
Previous works [1], [2] have accurately studied and re-
viewed the electrical behavior of memristor devices, gathering
Fernando Garcı´a-Redondo and Marisa Lo´pez-Vallejo are
with Technical University of Madrid - UPM, Spain (email:
fgarcia@die.upm.es, marisa@die.upm.es). Robert Gowers and Liudi
Jiang (r.gowers@warwick.ac.uk, l.jiang@soton.ac.uk)are with University
of Southampton, England. A. Crespo-Yepes (albert.crespo@uab.es) is with
Universitat Auto`noma de Barcelona, Spain.
This work was funded by the projects TOLERA TEC2012-31292, TOL-
ERA2 TEC2015-65902 of the Spanish Ministry of Economy and Competi-
tiveness, the Spanish NANOVAR Network and the Mobility Grant Program
of the Consejo Social UPM, Spain.
information of their internal dynamic processes for the design
of a compact model. This is important because the creation of
subcircuit compact components ready to be used by SPICE-
like circuit simulators is a key issue for resistive switching
based architecture design, since the trade-off between accuracy
and simulation length becomes a critical factor when a large
number of cells are computed within crossbars or substantial
neural networks.
Considering the memristor as a two terminal device, insight
into a model description can be found through two different
approaches. Physical compact models rely on the description
of current-voltage relationships together with their dependence
on a given set of internal variables (conductive filament
geometry, dopant volume elongation, ion migration proba-
bility, tunneling distances, etc.) matching the characteristics
of a specific physical device. Depending on the grade of
complexity, physical approaches include a broad variety of
models, from the simpler and more flexible ones that are more
inaccurate [3]–[5], to the more accurate but complex ones able
to model the physical behavior with high precision [6]–[10].
The compendiums [1], [2] describe in more detail examples of
both accurate and inaccurate models. Consequently, physical
models that match different devices generally present accuracy
problems, while complex approaches, with a suitable fitting
of the physical component behavior, can fit only a narrow set
of devices. Additionally, as the associated computational load
increases with the model complexity, the trade-off between
speed and accuracy restricts the use of some of the models.
Moreover, in some cases the high non-linearity of the model
behavior requires extremely short simulation time steps, clut-
tering the transient computation, and occasionally leading to
convergence problems related to hard-switching conditions [1].
On the other hand, phenomenological compact models focus
on fitting the electrical magnitude relationships, and describing
their evolution using mathematical variables which are not
necessarily related to the physical variables. Phenomenological
approaches obtain a broad flexibility regarding the range of
described devices [1]. More recent solutions update and im-
prove earlier versions such as [11]–[13], standing as a powerful
solution for general modeling, and an effective application to
neuromorphic computing [14].
In this work we present a novel solution based on the
independent modeling of the device conduction mechanisms
and device state. The proposed model fully relies on physical
magnitudes and their inter-relations, defining the tuple electri-
2TABLE I
MODEL COMPARISON AGAINST BEST WELL KNOWN MODELS
Model Physical or Require Bipolar or Variability & State Magnitude Multilevel Pristine State
Phenomenological Verilog-A Unipolar Degradation Aware Aware
Proposed Physical No Both Static and dynamic Consumed Energy Explicit Yes
Several Universities [7], [8], [10] Physical Yes Bipolar Static CF elongation CF mplicit No
Yakopcic’s [11], [14] Phenomenological No Both Static Auxiliar Adaptable No
Biolek’s and Dopant Drift [3], [5], [6] Physical No Bipolar No Dopant area length No No
TEAM’s [13], [15] Physical Yes Bipolar No Dopant area length Adaptable No
Memristor
Compact
Model
Memristor
Subcircuit
Fig. 1. Proposed Compact Modeling Design: bi-port component indepen-
dently handling conduction module (left) and state module (right).
cal and resistive switching behavior.
While voltage and current thresholds are supported, the
state modeling bases the device switching on electrical charge,
flux or energy thresholds. It is applicable to both bipolar
and unipolar devices, widening the range of devices that can
be described, and therefore the proposed approach rivals in
flexibility with the most suitable phenomenological approaches
[11], [14]. In turn the conduction module accurately fits the
conduction mechanisms of the physical component.
Fully compatible with SPICE simulators, the presented
model does not require implementation in Verilog-A or CMI to
accurately match physical components. Although components
written in Verilog-A or CMI allow more complex schemes to
be emulated, they have a major drawback: widely used SPICE
simulators do not allow Verilog-A or CMI code execution,
restricting its simulation on several platforms.
The main contributions of the proposed model are as
follows:
• Accurate modeling of dynamic resistance cleanly mim-
icking physical device response.
• Effective switching behavior for bipolar/unipolar devices.
• Availability of cycle and switching event count infor-
mation for all time, becoming a resource for additional
characteristics such as variability.
• Variability awareness.
• Provision of variability dynamics and resistive state reten-
tion handling, defining how the device degrades through
time/cycle stress.
• Explicit support for multi-level storage. Unlike CF based
models [7], [8], [10], the explicit definition of multiple
states allows more detailed level descriptions. This also
allows the modeling of Pristine State -the initial High
Resistive State (HRS) prior any electroforming-.
• The full source code for those bipolar and unipolar
devices, together with additional materials can be found
at http://vlsi.die.upm.es/memristor spice model.
Table I summarizes the key characteristics of the proposed
model comparing it against the best well known compact
models presented in literature.
The paper is structured as follows. First, we present the
proposed memristor model. Section III describes the variability
handling methods included within the modeling. The simula-
tion results fitting two different physical devices are shown
in Section IV. Some concluding remarks can be found in
Section V. Finally, Appendix A includes LTSPICE source
code describing a multilevel bipolar memristor.
II. PROPOSED MODEL
The proposed model is composed of two different sub-
components which allow matching to the device behavior
(Figure 1). The Conduction Module, addressing the memristor
component interface through the ports Plus and Minus, models
the dynamic resistance; in turn, the State Module handles the
device state.
The component behavior is defined by the transient signal
set, composed of the input voltage v(t), the current flowing
through the device i(t), and the device state vector s(t). This
vector contains all the information related to cycle count,
switching thresholds, energy and resistance state. In this paper
we will simplify the notation of the electrical and state
equations, and their dependence on time will become implicit:
consequently, as an example, v(t) will be denoted as v.
The equations describing the signal relation of the different
submodules can be written using the generalized system
i = f(v, s)
s˙ = g(v, i, s). (1)
This equation system matches most devices’ behavior [1],
and thereby both physical and phenomenological models spec-
ify f and g functions to define how the model runs.
A. Conduction Module Modeling
The Conduction Module is responsible for the computation
of the current which flows through the device. This depends
on the voltage and the memristor state. Denoting the first
component of the state vector s(1) as the discrete value
referring the device level, within our proposed model the
current function
i = f(v, s) (2)
takes the form, for different N conduction levels,
i =

f1(v, s) if s(1) = s1
f2(v, s) if s(1) = s2
...
fN (v, s) if s(1) = sN .
(3)
3-0.8 -0.6 -0.4 -0.2 0 0.2 0.4 0.6 0.8 1 1.2
voltage [V]
10-13
10-12
10-11
10-10
10-9
10-8
10-7
10-6
10-5
10-4
cu
rr
en
t [
A
]
2-bit multilevel example
l0
l1
l2
l3
Fig. 2. Example of a simulated 2 bit multilevel device, with three different
Schottky (l0, l1 and l2) and one ohmic conduction schemes (l3).
This approach, completely covering the device state design
space, allows multilevel device modeling such as [16]. Figure
2 shows an example of a simulated 2 bit multilevel memristor
using the proposed scheme. The bipolar device experiences
three partial SET events followed by their corresponding
partial RESETs. Compared against different approaches with
no explicit multi-level definition (Table I), the proposed model
eases tuning of each level’s conduction properties, including
degradation and variability. As an example, the Schottky
characteristics exhibited in Figure 2 were captured with no
effort.
For a device with two-resistance levels and no pristine state
description, equation (3) gets simplified to the basic system
i =
{
fon(v, s) if s(1) = son
foff (v, s) if s(1) = soff
(4)
where fon and foff are the low and high resistance state
currents, respectively.
The state currents fj are modeled using different methods
depending on the specific device. As an example, low resis-
tance state dependence on voltage is usually simplified to a
single resistance with temperature dependence in both oxide-
based [7], [8], [17] and semiconductor based devices [18].
However, the model accepts different schemes to be used,
such as an in-series diode-resistance approach, improving the
simulation accuracy [19].
Even though some works model the involved conduc-
tion mechanisms of the higher resistance states using diode-
resistance schemes [9], in most cases the voltage-current
relation is described by basic conduction processes like the
ones described in Table II. Modeling such processes using
behavioral current/voltage sources allows us to accurately
mimic the device behavior. Some devices require complex
schemes where not only individual conduction process take
place but concurrent processes occur [17]. Our model fully
covers this requirement allowing multi-contribution schemes,
where distinct current sources contribute to define the global
one.
In case the device conduction process is not defined by an
analytical function, or further measurement data is required,
we could model the varying resistance of the device as a
behavioral resistor. The behavioral resistor value is determined
by an auxiliary function defined using the circuit simulator
user defined functions syntax [25]. Taking advantage of the
TABLE II
EXAMPLES OF CONDUCTION PROCESSES COMPATIBLE WITH
SPICE-LIKE BEHAVIORAL SOURCES
Process Expression
Trap Assisted [20] J ∝ a1
(
V
d
)a2
Generalized Tunneling
Temperature Dependent
(II) [7], [8]
J ∝ exp
(−g
g0
)
sinh
(
V
kTV1
)
Tunneling [6] J ∝ C 2exp
[
−4
√
2m∗(qφB)3/2
3qh¯C
]
Schottky Thermionic
[17], [18], [21]
J = A∗∗T 2exp
[
−
q
(
φB −
√
qC
4pi
)
kT
]
Poole-Frenkel [22], [23] J ∝ C
[
−
q
(
φB −
√
qC
pi
)
kT
]
Ohmic [17], [18], [24] J ∝ C exp
[
−∆Eac
kT
]
Space-charge-limited
[24]
J ∝ 9µV
2
8d3
QPC [2] I =
2e
h
eV +
ln
α
 1+exp
(
α(φB−βeV )
)
1+exp
(
α(φB+(1−β)eV )
)


V and d are the voltage applied between the electrodes and the insulator
thickness respectively.
C refers to the electric field, A∗∗ stands for the effective Richardson constant.
g, g0, V0, V1 is the gap distance and matching parameters.
φ is the materials barrier height, while  is the insulator permitivity.
∆Eac is the activation energy of electrons.
α and β are parameters related to barrier thickness and fraction of dropped
voltage respectively.
Conduction Module State Module
Memristor Compact Model
Fig. 3. N-state conduction module scheme using behavioral sources.
SPICE simulator capabilities, the behavioral resistor may
refer a piecewise (PWL) function defining the voltage and
state dependent resistance based on previous voltage-current
measurements that build up the pairs vi − ri.
Summarizing, our proposed model accepts individual/cumu-
lative conduction schemes with which it models the current
flow at multilevel states for different devices/technologies. The
general subcircuit of a memristor device with N different
resistive levels modeled using N independent current behav-
ioral sources is shown in Figure 3. This approach allows us
to include additional helpful effects such as the compliance
current or control sentences shown in [1]. An example of a
constraint current source modeling an N state device using
the approach described in Figure 3 would be represented by
4Energy
Charge and
Flux
Handling
Module
Thresholds
Handling
Module
State
Handling
Module
Cycle
Handling
Module
Conduction
Module
State Module
Memristor Compact Model
Fig. 4. Proposed Device State Handler Module.
-1 -0.5 0 0.5 1
Voltage [V]
-0.5
0
0.5
1
C
ur
re
nt
 [m
A
]
Charge controlled memristor
1 Hz
4 Hz
6 Hz
8 Hz
10 Hz
20 Hz
Fig. 5. Characteristic hysteresis loops of a charge controlled memristor fed
with different sine voltages. The compact model was built following the
scheme shown in Figure 4, using a charge handling module to control the
device state.
the following equation:
i(v, s) = max(−cI,min(cI, fj(v, s))). (5)
Here, the current through the device is limited by the compli-
ance current parameter cI .
In the same manner, the scheme shown in Figure 3 allows
parasitic-overshoot effects [7], [17], [26] modeling. To that
end, parasitic impedances Z1 and Z2 are attached in series
and parallel to the global current source.
B. State Module Modeling
Several works propose models whose behavior depends on
voltage or current thresholds that trigger different mechanisms
unleashing a state change in the device [1], [11], [13].
In this work we propose an extension of this concept, broad-
ening the threshold mechanisms that define the switching.
Figure 4 describes the components the State Handler Module
is composed of. Basically, the device state will depend on the
previous state and the device electrical inputs.
This scheme is compatible with the simple approach of
voltage/current boundary threshold, leaving the magnitudes
energy, charge and flux out of the threshold management and
using instant voltages and currents to trigger the switching
mechanisms.
Moreover, the model is enriched, allowing energy, charge
or flux to be used on the simulated device as the triggering
magnitude that releases the switching events. Following the
idea shown in [27]–[31], this model computes the energy,
charge or flux levels at which the device experiences a state
change. Using individual submodules, we calculate the energy,
charge or flux applied to the device in order to define the
switching, the cycle and event count, building up the whole
state vector s. Following this approach Figure 5 shows the
characteristic pinched hysteresis loop for a charge controlled
device similar to [3].
Compared to Verilog-A implementations [7], [8], where
different variables can be used, in SPICE-like subcircuit design
we need to use signals to store the related information.
Therefore, the energy, charge, flux or cycle/event count com-
putations require individual signals, commonly node voltages,
to define their value.
Instead of using capacitors to integrate magnitudes [4], the
energy computation can be accelerated [1] using the time
integral function provided by the SPICE-like simulator idt.
On the other hand a user defined function, switching,
performs the switching conditions verification. Taking energy
as the magnitude managing the switching, switching would
be described by equation 6.
s
(1)
next = switching(E,P, s
(1)
current), (6)
There we name P as the matrix whose elements pjk define
the energy thresholds to switch from state j to state k. This
state-controlling scheme was used for the multilevel simulation
show in Figure 2. Appendix A includes the SPICE code
associated with switching function.
Pristine State Modeling: Using the proposed conduction
and switching schemes allows us to model the pristine (con-
ductive filament preforming) state. The ability of including this
additional state enriches the model capabilities. By defining the
conduction mechanism and forming energy -ep-, the pristine
state can be easily included in the netlist:
s
(1)
next =
{
s
(1)
pristine if E < ep
switching(E,P, s
(1)
current) otherwise.
(7)
Cycle and Event Count Computation: As explained in
Section III, the ability to compute how many switching events
a device has suffered is essential to accurately model its degra-
dation. Using the magnitude that defines the switching -energy,
charge or flux- we propose a novel scheme that allows the
device cycling count to be stored. For the sake of simplicity,
equations 8 and 9 will suppose devices with two states and an
initial HRS. Let E be the computed energy, parameters p set
and p reset the required energy levels to perform the SET
and RESET respectively, and p cycle = p set+ p reset. For
5Soft switching  during RESET
-0.11 -0.1 -0.09 -0.08 -0.07
voltage [V]
10-6
10-5
cu
rr
en
t [
A
]
Fig. 6. Proposed soft-switching mechanism: the softening functions make use
of the auxiliary variable b to soften the state switching. Different thresholds
and p values produce the shown effects during reset process.
unipolar devices we can compute the state vector s as
E =
∫ t
0
v × i dt
cycles =
⌊
E
p cycle
⌋
extra set =
{
1 if (E − cycles× p cycle) > p set
0 otherwise
events = 2× cycles+ extra set (8)
The same methodology can be applied to bipolar devices.
However, positive contributions E+ are required to be treated
independently from negative contributions E−:
cycles =
⌊
E−
p reset
⌋
events =
⌊
E−
p reset
⌋
+
⌊
E+
p set
⌋
(9)
Soft Switching Events: We can avoid hard-switching
events by introducing an additional variable b that softens
the transition between states. For a device experiencing a
transition from state s(1)j to state s
(1)
j+1, where ij and ij+1
are their corresponding current levels, the current switching
can be softened if the global current is redefined as
i = ...+ wj(b)× ij + wj(1− b)× ij+1 + .... (10)
where wj(b) are the softening functions that control the
different state’s current contributions. The softening variable b
can be described based on the corresponding energy thresholds
a1 =
{
Ej
ea1
}
a2 =
{
Ej
ea2
}
b =
{
min(1,max(0, a1)) if s(1) = sj
1−min(1,max(0, a2)) if s(1) = sj+1 (11)
where Ej is the total/partial energy (depending on the device
type), and ea1 and ea2 the energy thresholds required to
perform the transitions s(1)j → s(1)j+1 and s(1)j+1 → s(1)j
respectively.
0 0.5 1
Time [s]
280
290
300
310
320
330
340
350
360
370
Lo
ca
l T
em
pe
ra
tu
re
 [K
]
Local Temperature
T0=280 K
T0=300 K
T0=320 K
T0=340 K
T0=360 K
0 0.5 1
Voltage [V]
10-16
10-14
10-12
10-10
10-8
10-6
10-4
C
ur
re
nt
 [A
]
 Schottky Conduction
T0=280 K
T0=300 K
T0=320 K
T0=340 K
T0=360 K
Fig. 7. Device’s local temperature during the SET process and computed
voltage-current relation, varying circuit temperature T0.
The softening functions wj(b) make use of the state variable
b to control the partial contributions of ij and ij+1. The model
designer is able to customize these functions to better adapt
the switching mechanism to the physical measures. Figure 6
describes one of the possible softening schemes for bi-state
devices, together with the produced effects. In these proposed
functions the partial contributions depend on two thresholds,
b_th_set and b_th_reset, and the parameter p, which
manages the softening in the following expressions:
fset(b) =
{
1 if b ≥ bth set
( bbth set )
p if b < bth set
(12)
freset(b) =
{
1 if b ≤ bth reset
(1− b−bth reset1−bth reset )p if b > bth reset
C. Extensibility and Verilog-A Implementation
The modular design of the proposed scheme allows its
extension in order to consider additional phenomena. As an
example, temperature dependence has proven a key factor in
the device behavior [7], [17], [32]. Each of these extensions
can be considered as independent behavioral sources for their
later reference in dependent signals. The cited temperature
influence can be directly incorporated within our model in both
conduction mechanisms and energy thresholds computation by
simply altering the behavioral source’s nominal expressions.
Figure 7 presents the results after the incorporation of local
thermal behavior due to Joule-heating [7], [8].
Once the conduction mechanisms and the threshold param-
eters are defined, the present model can be easily ported to
the Verilog-A language, with the consequent speed up of the
circuit simulation. Each behavioral source is directly translated
into an independent variable, following the same approach
shown in [7]. Additionally, Verilog-A is more flexible re-
garding the use of user defined functions or variable data
types (such as arrays), which eases the implementation of the
methods adopted to reproduce variability effects shown in the
next section.
6However, even though some circuit simulators such as
Cadence Spectre allow Verilog-A code execution, widely
used SPICE simulators like LTSPICE do not allow Verilog-A
co-simulation, accepting SPICE-like code only. Consequently,
research community may benefit from the SPICE proposed
compact model.
III. VARIABILITY & STATE RETENTION MODELING
Variability in memristors is one of the most concerning
issues to be solved in memristive applications. Its effects are so
visible that some works even use RRAMs to provide random
pattern based circuit modules [33]. Three distinct kinds of
variability are expected to occur in resistive switching devices
[34]:
• Inter-Device Variability. Device to device variations in
size, thickness, ion-concentrations, etc.
• Intra-Device Variability. Small cycle-to-cycle fluctuations
caused by the stochastic nature of generation and recom-
bination of oxygen vacancies and ion migration.
• Read Current Fluctuations, called Random telegraph
noise (RTN), is a variation in the measured current under
constant bias during reading operations. It can be caused
either by the electron capture and emission processes that
inherently exist in oxides with high defect concentrations,
or by atomic changes in the conducting filament.
Therefore, several works have studied the variability in differ-
ent devices [34]–[37] and its inclusion into some Verilog-A
models such as the one presented in [7].
Our proposal, fully compatible with SPICE-like simulators,
allows modeling variability not only by using probability den-
sity functions but also by the direct injection of random pat-
terns extracted from physical measurements. Figure 8 shows
the scatters and histograms after measuring and normalizing
the required energy to perform consecutive cycles (SET and
RESET process). Therefore we can extract from those graphs
the energy threshold mean and standard deviation values. By
contrast, in cases where the random data does not follow a
suitable function, measurements directly from the scatter are
used.
The energy thresholds, the current flowing through the
device or any other signal requiring variability injection can be
modeled as sources whose value is composed of nominal and
variable contributions. The variable contribution is described
through a user defined function, rj(), that can directly refer
to the probability density function [35], [36]
i =
 r1(v, s)f1(v, s) if s
(1) = s1
...
rN (v, s)fN (v, s) if s(1) = sN
(13)
The probability density function can be generated using the
uniform random generator function built into the circuit simu-
lator. If the circuit simulator does not support this feature, we
can extract the random pattern by adding an additional zero
amplitude voltage source affected by uniform noise.
On the other hand, by using a piecewise function we can
include the physical measured data. In this case the measured
variable contribution is extracted from the PWL file and
Unipolar device Ni/HfO2/Si
0
50
100
150
200
250
300
350
400
C
yc
le
10-5 10-3 10-1 101
Normalized Energy
SET
RESET
10-5 10-3 10-1 101
Normalized Energy
0
50
100
150
200
O
cc
ur
re
nc
es
SET
RESET
Bipolar device Cu/aSiC/TiN
0
5
10
15
20
25
30
35
C
yc
le
10-12 10-8 10-4 100
Normalized Energy
SET
RESET
10-12 10-8 10-4 100
Normalized Energy
0
5
10
15
20
25
30
O
cc
ur
re
nc
es
SET
RESET
Fig. 8. SET and RESET scatter and histogram of measured energy levels
required to perform switching in bipolar and unipolar devices. The values
have been normalized using the maximum value of both processes.
injected using an additional source. An alternative to the PWL
defined sources are the specific noisy source components that
allow values defined via input files.
The above scheme covers two variability types: Inter-
Device Variability and Read Current Fluctuations variability.
As an additional feature, the proposed modeling scheme ad-
mits Intra-Device Variability, defining how variability changes
throughout time/cycling. This also provides the ability to
define how the device gets degraded depending on its work-
load, and consequently, the determinability of its stored data.
Therefore, by simulating consecutive switching events, the
resistance state retention can be studied. Using the device state
vector s we can access at each moment the number of cycles
and/or events experienced by the device, and provide a more
accurate variability/degradation modeling:
1) Variability dependency on time or cycle number is
extracted from physical measurements [36].
2) Variability is modeled using time/cycle dependent user
defined functions. Therefore, the statistical characteris-
tics such as standard deviation (σ) and mean (µ) values
become dynamic (σ(t), µ(t)).
Finally, as reflected in equation 13, the explicit declaration
of the different conduction mechanisms eases the tuning of
variability and degradation functions at each resistive level.
The complex, level and time dependent variability character-
istics shown in the results of Section IV-C take advantage of
the proposed variability modeling scheme.
7-1 -0.5 0 0.5 1
Voltage [V]
10-15
10-10
10-5
C
ur
re
nt
 [A
]
Measurements
Simulation
0 0.2 0.4 0.6 0.8 1
Time [s]
-1
0
1
v 
[V
]
-0.1
0
0.1
i [
m
A
]
Voltage
Current
Linear
Scale
(a) Voltage-current relationship together with the voltage-current transients. On
the upper graph the different slopes show how asymmetric behavior, depending
on the input voltage polarity, was perfectly mimicked.
Conduction Module
aSiC Compact Model
State
Module
(b) Subcircuit using four different conduction submodules: off and on states
for both positive and negative voltages.
Fig. 9. Bipolar device fitting: v − i curves together with the used circuit.
IV. PHYSICAL DEVICES SIMULATIONS
To show the model capabilities, two physical devices have
been studied and fitted: a bipolar a-SiCCu-TiN and a unipolar
NiHfO2Si device. Figure 8 shows the measured energy levels
required to perform consecutive SET-RESET processes in both
devices. The simulations shown in this section have been
performed using Cadence Spectre circuit simulator, replicating
the measurement experiments applied to the physical devices.
The full source code of those models, together with their
SPICE and Spectre implementations can be found in [25].
The parameter set fitting was automatically accomplished
using MAF simulator [1].
A. Bipolar Device
The first fitted device shows a reverse Schottky emission as
its basic HRS conduction process, even though it displays a
leakage phenomena. The model is able to fit a minimum asym-
metric behavior regarding its polarity. The LRS is modeled
using two different resistors depending on the voltage polarity.
Figure 9 presents the simulated subcircuit and the achieved
fitting compared against the measured data. The simulated
voltage follows the stimulus that fed the device during its
characterization.
0 0.5 1 1.5 2 2.5 3
Voltage [V]
10-10
10-5
C
ur
re
nt
 [A
]
0 2 4 6 8
Time [s]
0
1
2
3
v 
[V
]
-1
0
1
2
i [
m
A
]Voltage
Current
Measurements RESET
Simulated SET
Simulated RESET
Measurements SET
(a) Voltage-current relationship together with the voltage-current transients. The
measurement method imposes the input voltage waveform: right after the SET
is accomplished the sawtooth wave is reset to perform the next switch.
Conduction Module
HfO2 Compact Model
State
Module
(b) Subcircuit using two resistor-diode submodules for off and on states.
Fig. 10. Unipolar device fitting: v − i curves together with the used circuit.
B. Unipolar Device
The state handling approach described by system (8) per-
fectly fits the behavior of unipolar devices as shown in Figure
10a. The conductivity modeling follows the guidelines from
[9]: two pairs of in series resistance-diodes match both LRS
and HRS (Figure 10b). In this case the simulation input voltage
reproduces the sawtooth stimulus feeding the memristor during
the measurements.
C. Variability
The present section provides a simple example on how
variability can be included within a specific device modeling.
Two representative kinds of variability are considered: random
telegraph noise and intra-device variability.
Using the random values rnoise obtained from the normal
distribution given by a characterized noisy voltage source, we
shape the introduced RTN to affect in a higher grade the lower
currents [34]:
i =

ip(v)(1 + k0(v0 − v)p0rnoise) if s(1) = sp
ion(v)(1 + k1(v1 − v)p1rnoise) if s(1) = son
ioff (v)(1 + k2(v2 − v)p2rnoise) if s(1) = soff
(14)
8-1 -0.5 0 0.5 1 1.5 2 2.5 3
Voltage [V]
10-15
10-10
10-5
C
ur
re
nt
 [A
]
HRS/LRS
Measurements
Pristine
Measured Pristine
(a) Bipolar device suffering random telegraph noise over 50 cycles. The
included pristine state is also affected by this variability phenomena.
-1 -0.5 0 0.5 1
Voltage [V]
10-15
10-10
10-5
C
ur
re
nt
 [A
]
Mean
Max/Min
100 cycles
50 cycles
20 cycles
10 cycles
(b) Bipolar device with variability on its conduction mechanisms: intra-device
variability (cycle/event dependent) and random telegraph noise. Mean and
max/min values are shown for 10 to 100 consecutive cycle experiments.
Fig. 11. Different examples of variability/degradation modeling.
Here the fitting parameters kj (with k1 < k2), vj and pj allow
the generation of the variability effects shown in Figure 11a,
for each pristine, LRS and HRS states.
The second modeled variability effect regards the conduc-
tion parameters on both the LRS and the HRS. In this case
the parameters, cycle/time dependent in order to describe
the device degradation, are extracted from PWL functions
containing the normal distributed values and then the RTN
is added. Figure 11b presents the fingerprint of ten to one
hundred consecutive cycles with these variability character-
istics. The mean current-voltage relationship is represented
together with the maximum and minimum values achieved
during the experiment. It can be seen how the device current
response varies with the cycling, widening the curves data and
illustrating the device degradation.
V. CONCLUSIONS
We provided a customizable, physical memristor SPICE
compact model, being able to accurately fit both unipolar
and bipolar devices without requiring a Verilog-A compat-
ible simulator. The conduction modeling allows multi-level
description, each level being able to be characterized using
diverse contributions. The component state modeling is based
on the process that trigger resistive switching (device electrical
thresholds, energy, charge or flux), while omitting complex
geometry/internal process computations.
This design simplifies the arduous work of translating
physical device characteristics to the circuit compact model,
and therefore helps device manufacturers to simulate state
of the art devices. Not only is the model able to handle
variability but it also describes how variability/parameter
degradation evolves with time, making durability simulations
straightforward. Its modular scheme allows phenomena such
as temperature effects to be considered, improving memristor
SPICE simulations and making the analysis more reliable.
Finally, the model has been validated against two different
physical devices.
VI. ACKNOWLEDGMENTS
The authors would like to thank Mireia Bargallo and
Francesca Campabadal from the IMB-CNM for providing the
unipolar device samples, Montserrat Nafrı´a and Javier Martı´n
Martı´nez from the UAB for their support in the measurement
of unipolar devices and valuable suggestions. We also want
to acknowledge Kees De Groot, Katrina Morgan and Junqing
Fan, from Southampton University, for supplying the bipolar
devices, and also Ricardo Riaza from the UPM, for their
helpful discussions.
APPENDIX
MULTILEVEL DEVICE LTSPICE CODE
To illustrate the proposed model structure, we present the
LTSPICE source code related to the memristor characterized
in Figure 2. Additional resources such as the full source code
of charge controlled memristor, unipolar and bipolar devices,
temperature dependency and variability aware experiments can
be downloaded from http://vlsi.die.upm.es/memristor spice
model. Compatible simulators: Linear Technologies
LTSPICE and Cadence Spectre.
1 **************************************************
** http://vlsi.die.upm.es/memristor_spice_model
3 ** 2b-multilevel v1.0, 21/01/2016
** switching defined by energy thresholds
5 ** Three Schottky and one ohmic levels
**************************************************
7 .SUBCKT memristor Plus Minus PARAMS:
+pi=3.1415926 Kb=1.38e-23 q=1.6e-19 eps0=8.85e-12
9 +area=6.4e-9 d=4e-8 scl1=5 scl2=7 scl3=9 AA1=1e6
AA2=2e6 AA3 =5e7 Ub=0.9
+epsr=8
11 +Ron=300 T0=300 ktemp=1 cI=1e-4 ronp=6.1k ronn=8.5k
epsi=epsr*eps0
** energy threshold multilevel parameters
13 +p_th_1_2=0.5e-13 p_th_2_3=p_th_1_2+1e-8 p_th_3_4=
p_th_2_3+0.5e-5
+p_th_4_3=-1e-7 p_th_3_2=p_th_4_3-1e-8 p_th_2_1=
p_th_3_2-1e-9
15 ** internal voltages
+v_s1=0e-7 v_s2=1e-7 v_s3=2e-7 v_s4=3e-7
9***********************************************
24 ** Energy computation
***********************************************
26 * total energy
Etpospower tpp 0 value={idt( IF( V(Plus, Minus)>0 &
v(pp)<p_th_3_4, I(Gcond)*V(Plus,Minus), 0) ,0 )}
28 Etnegpower tnp 0 value={idt( IF( V(Plus, Minus)<0 &
v(np)>p_th_2_1, abs(I(Gcond))*V(Plus,Minus), 0)
,0 )}
* relative energy
30 Epospower pp 0 value={idt( IF( V(Plus, Minus)>0, I(
Gcond)*V(Plus,Minus), 0) ,0, v(trig_p)>0)}
Enegpower np 0 value={idt( IF( V(Plus, Minus)<0, abs
(I(Gcond))*V(Plus,Minus), 0),0, v(trig_n)>0)}
32 E_trigger_p trig_p 0 value={IF( v(s)==v_s1 & v(pp)>=
p_th_3_4, 1e-7, 0)}
E_trigger_n trig_n 0 value={IF( v(s)==v_s4 & v(np)<=
p_th_2_1, 1e-7, 0)}
34
***********************************************
36 ** state computation
***********************************************
38 Estate s 0 value={ switching(V(Plus, Minus), V(pp),
V(np), p_th_1_2, p_th_2_3, p_th_3_4, p_th_4_3,
p_th_3_2, p_th_2_1, v_s1, v_s2, v_s3, v_s4) }
Rstate s 0 r=100k
40
*************************************************
42 ** Conduction processes
*************************************************
44 Eon on 0 value={V(Plus, Minus)}
Ron on 0 r=ron
46 Goff1 0 off1 value={ sgn(V(Plus, Minus))*area*AA1*
ktemp*(T0**2)*exp(-q*Ub/(Kb * T0))*exp( sqrt(abs
(V(Plus, Minus)))*(scl1 + q / (Kb * T0) * ( sqrt
(q / (d * 4 * pi * epsi)))) ) }
Goff2 0 off2 value={ sgn(V(Plus, Minus))*area*AA2*
ktemp*(T0**2)*exp(-q*Ub/(Kb * T0))*exp( sqrt(abs
(V(Plus, Minus)))*(scl2 + q / (Kb * T0) * ( sqrt
(q / (d * 4 * pi * epsi)))) ) }
48 Goff3 0 off3 value={ sgn(V(Plus, Minus))*area*AA3*
ktemp*(T0**2)*exp(-q*Ub/(Kb * T0))*exp( sqrt(abs
(V(Plus, Minus)))*(scl3 + q / (Kb * T0) * ( sqrt
(q / (d * 4 * pi * epsi)))) ) }
Raux1 off1 0 r=1k
50 Raux2 off2 0 r=1k
Raux3 off3 0 r=1k
52 Gcond Plus Minus value={ max( -cI, min(cI, IF(V(s)==
v_s1, i(Goff1), IF(V(s)==v_s2, i(Goff2), IF(V(s)
==v_s3, i(Goff3), i(Ron) ) ) ) )) }
54 *************************************************
** event counters
56 *************************************************
E_p_events p_events 0 value={floor( V(tpp)/p_th_3_4
)}
58 E_n_events n_events 0 value={floor( V(tnp)/p_th_2_1
)}
60 ********************************************
** switching function
62 ********************************************
.func switching(v,pp,pn,th_1_2,th_2_3,th_3_4,th_4_3,
th_3_2,th_2_1,v_s1,v_s2,v_s3, v_s4) {
64 + IF(v>=0,
+ IF(pp>=th_3_4, v_s4,
66 + IF(pp>=th_2_3, v_s3,
+ IF(pp>=th_1_2, v_s2,
68 + v_s1) ) ),
+ IF(pn>=th_4_3, v_s4,
70 + IF(pn>=th_3_2, v_s3,
+ IF(pn>=th_2_1, v_s2,
72 + v_s1)) ) ) }
.ENDS memristor
REFERENCES
[1] F. Garcı´a-Redondo, M. Lopez-Vallejo, and P. Ituero, “Building Memris-
tor Applications: From Device Model to Circuit Design,” IEEE Trans.
Nanotechnol., vol. 13, no. 6, pp. 1154–1162, nov 2014.
[2] J. Blasco, N. Ghenzi, J. Sun˜e´, P. Levy, and E. Miranda, “Equivalent cir-
cuit modeling of the bistable conduction characteristics in electroformed
thin dielectric films,” Microelectron. Reliab., vol. 55, no. 1, pp. 1–14,
jan 2015.
[3] Z. Biolek, D. Biolek, and V. Biolkova´, “SPICE Model of Memristor with
Nonlinear Dopant Drift,” Radioengineering, vol. 18, no. 2, pp. 210–214,
2009.
[4] K. D. Xu et al., “Two Memristor SPICE Models and Their Applications
in Microwave Devices,” IEEE Trans. Nanotechnol., vol. 13, no. 3, pp.
607–616, may 2014.
[5] J. Zha, H. Huang, and Y. Liu, “Novel Window Function for Memristor
Model With Application in Programming Analog Circuits,” IEEE Trans.
Circuits Syst. II Express Briefs, vol. 7747, no. c, pp. 1–1, 2015.
[6] A. Ascoli et al., “The Art of Finding Accurate Memristor Model
Solutions,” IEEE J. Emerg. Sel. Top. Circuits Syst., vol. 5, no. 2, pp.
133–142, jun 2015.
[7] H. Li et al., “Variation-Aware, Reliability-Emphasized Design and
Optimization of RRAM Using SPICE Model,” in Des. Autom. Test Eur.
Conf. Exhib. (DATE), 2015, 2015, pp. 1425–1430.
[8] J. F. Kang et al., “Modeling and design optimization of ReRAM,” in
20th Asia South Pacific Des. Autom. Conf., vol. 1, 2015, pp. 576–581.
[9] E. Miranda, “Compact Model for the Major and Minor Hysteretic I-V
Loops in Nonlinear Memristive Devices,” IEEE Trans. Nanotechnol.,
vol. 14, no. 5, pp. 787–789, sep 2015.
[10] P.-y. Chen and S. Yu, “Compact Modeling of RRAM Devices and Its
Applications in 1T1R and 1S1R Array Design,” IEEE Trans. Electron
Devices, vol. 62, no. 12, pp. 4022–4028, dec 2015.
[11] C. Yakopcic, T. M. Taha, G. Subramanyam, and R. E. Pino, “Generalized
Memristive Device SPICE Model and its Application in Circuit Design,”
IEEE Trans. Comput. Des. Integr. Circuits Syst., vol. 32, no. 8, pp. 1201–
1214, aug 2013.
[12] L. Zheng, S. Shin, and S.-m. S. Kang, “Modular Structure of Compact
Model for Memristive Devices,” IEEE Trans. Circuits Syst. I Regul. Pap.,
vol. 61, no. 5, pp. 1390–1399, may 2014.
[13] S. Kvatinsky, M. Ramadan, E. G. Friedman, and A. Kolodny, “VTEAM:
A General Model for Voltage-Controlled Memristors,” IEEE Trans.
Circuits Syst. II Express Briefs, vol. 62, no. 8, pp. 786–790, aug 2015.
[14] C. Yakopcic, M. McLean, T. Taha, R. Hasan, and D. Palmer, “Memristor-
based neuron circuit and method for applying learning algorithm in
SPICE,” Electron. Lett., vol. 50, no. 7, pp. 492–494, mar 2014.
[15] S. Kvatinsky et al., “TEAM : ThrEshold Adaptive Memristor Model,”
Circuits Syst. I Regul. Pap. IEEE Trans., vol. 60, no. 1, pp. 211–221,
2013.
[16] W. Chen et al., “Switching characteristics of W/Zr/HfO2/TiN ReRAM
devices for multi-level cell non-volatile memory applications,” Semi-
cond. Sci. Technol., vol. 30, no. 7, p. 075002, 2015.
[17] P. Yan et al., “Conducting mechanisms of forming-free TiW/Cu2O/Cu
memristive devices,” Appl. Phys. Lett., vol. 107, no. 8, p. 083501, aug
2015.
[18] L. Zhong, L. Jiang, R. Huang, and C. H. De Groot, “Nonpolar resistive
switching in Cu/SiC/Au non-volatile resistive memory devices,” Appl.
Phys. Lett., vol. 104, no. 9, pp. 1–5, 2014.
[19] J. Blasco, N. Ghenzi, J. Suae, P. Levy, and E. Miranda, “Modeling of
the hysteretic I-V characteristics of TiO2-based resistive switches using
the generalized diode equation,” IEEE Electron Device Lett., vol. 35,
no. 3, pp. 390–392, 2014.
[20] H. Aziza et al., “Oxide based resistive RAM: ON/OFF resistance
analysis versus circuit variability,” in 2014 IEEE Int. Symp. Defect Fault
Toler. VLSI Nanotechnol. Syst. IEEE, oct 2014, pp. 81–85.
[21] K. A. Morgan et al., “Switching kinetics of SiC resistive memory for
harsh environments,” AIP Adv., vol. 5, no. 7, p. 077121, jul 2015.
[22] Y. Liu et al., “Percolation mechanism through trapping/de-trapping
process at defect states for resistive switching devices with structure
of Ag/SixC1−x/p-Si,” J. Appl. Phys., vol. 116, no. 6, p. 064505, 2014.
[23] L. Zhang et al., “Low voltage two-state-variable memristor model of
vacancy-drift resistive switches,” Appl. Phys. A, vol. 119, no. 1, pp.
1–9, apr 2015.
[24] F. Kurnia, C. U. Jung, B. W. Lee, and C. Liu, “Compliance current
induced non-reversible transition from unipolar to bipolar resistive
switching in a Cu/TaOx/Pt structure,” Appl. Phys. Lett., vol. 107, no. 7,
p. 073501, aug 2015.
10
[25] F. Garcı´a-Redondo, M. Lo´pez-Vallejo, and P. Royer, “LSI Online CAD
Resources,” 2015. [Online]. Available: http://vlsi.die.upm.es/resources
[26] M. P. Sah et al., “A Generic Model of Memristors With Parasitic
Components,” IEEE Trans. Circuits Syst. I Regul. Pap., vol. 62, no. 3,
pp. 891–898, mar 2015.
[27] C.-m. Jung, K.-h. Jo, E.-s. Lee, H. M. Vo, and K.-s. Min, “Zero-
Sleep-Leakage Flip-Flop Circuit With Conditional-Storing Memristor
Retention Latch,” IEEE Trans. Nanotechnol., vol. 11, no. 2, pp. 360–
366, mar 2012.
[28] C. M. Jung, J. M. Choi, and K. S. Min, “Two-step write scheme for
reducing sneak-path leakage in complementary memristor array,” IEEE
Trans. Nanotechnol., vol. 11, no. 3, pp. 611–618, 2012.
[29] C. Yakopcic, T. M. Taha, G. Subramanyam, and R. E. Pino, “Memristor
SPICE model and crossbar simulation based on devices with nanosecond
switching time,” Proc. Int. Jt. Conf. Neural Networks, 2013.
[30] G. Ghosh and M. K. Orlowski, “Write and Erase Threshold Voltage
Interdependence in Resistive Switching Memory Cells,” IEEE Trans.
Electron Devices, vol. 62, no. 9, pp. 2850–2856, sep 2015.
[31] M. Maestro et al., “Analysis of Set and Reset mechanisms in Ni/HfO2-
based RRAM with fast ramped voltages,” Microelectron. Eng., vol. 147,
pp. 176–179, nov 2015.
[32] E. Yalon, A. Gavrilov, S. Cohen, and D. Ritter, “Validation and Ex-
tension of Local Temperature Evaluation of Conductive Filaments in
RRAM Devices,” IEEE Trans. Electron Devices, vol. 62, no. 11, pp.
3671–3677, 2015.
[33] A. Chen, “Utilizing the Variability of Resistive Random Access Memory
to Implement Reconfigurable Physical Unclonable Functions,” IEEE
Electron Device Lett., vol. 36, no. 2, pp. 138–140, feb 2015.
[34] A. H. Edwards et al., “Reconfigurable Memristive Device Technologies,”
Proc. IEEE, vol. 103, no. 7, pp. 1004–1033, 2015.
[35] D. Garbin et al., “Resistive memory variability: A simplified trap-
assisted tunneling model,” Solid. State. Electron., sep 2015.
[36] A. Grossi et al., “Impact of Intercell and Intracell Variability on Forming
and Switching Parameters in RRAM Arrays,” IEEE Trans. Electron
Devices, pp. 1–1, 2015.
[37] A. Prakash et al., “Multi-state resistance switching and variability anal-
ysis of HfOx based RRAM for ultra-high density memory applications,”
in 2015 Int. Symp. Next-Generation Electron., vol. 27. IEEE, may 2015,
pp. 1–2.
Fernando Garcı´a-Redondo graduated from the
Technical University of Madrid in 2011 with a
degree in Telecommunication Engineering. Next,
he focused on electronics obtaining a Master of
Science in 2012. Currently he is a PhD candidate at
the Integrated Systems Laboratory, UPM. His main
research lines are RRAM modeling and simulation,
reliable circuit design including PVT and radiation
and novel circuit simulation approaches.
Robert P. Gowers received his MEng from the
University of Cambridge in July 2014, with his focus
being in Electrical Engineering. Areas of research
Robert has previously been involved with include:
flexible thin film transistors, the inkjet printing of
liquid crystals, resistive memory.
Albert Crespo Yepes , born in Barcelona (1982),
he received the degree in Telecomunications Engi-
neering in 2008 for UAB (Universitat Auto`noma
de Barcelona). In 2009 he obtained the master in
micro and nano electronics. Recently (2012), he
finalized his Ph. D. studies in Electronic Engineering
in the group of Reliability Electron DEvices and
Cricuits in the Electronic Department of the Uni-
versitat Auto`noma de Barcelona (UAB). Currently,
he is post-Ph.D. researcher in this group. His work is
focused on the study of Dielectric Breakdown and
Breakdown Reversibility characterization in MOS transistors with ultrathin
high-k gate stack, Resistive Switching phenomena, Channel Hot-Carriers
(CHC) and Bias Temperature Instability (BTI).
Marisa Lo´pez-Vallejo (M’00) received the M.S.
and Ph.D. degrees from the Universidad Polite´cnica
de Madrid, Madrid, Spain, in 1993 and 1999, re-
spectively. She is an Associate Professor with the
Department of Electronic Engineering, Universi-
dad Polite´cnica de Madrid. She was with the Lu-
cent Technologies, Bell Laboratories, Murray Hill,
NJ, as a Technical Staff Member. Her current re-
search interests include low-power, process voltage,
temperature-aware designs, computer-aided diagnos-
tic methods and tools, and application-specific high-
performance programmable architectures.
Liudi Jiang is Professor of Materials and
Electromechanical Systems at the University of
Southampton. She obtained BEng in Microelectron-
ics, MSc in Physics. She received Ph.D. in ad-
vanced materials from the University of Dundee
in 2002. She was appointed Lecturer in 2008 at
the University of Southampton, Associate Profes-
sor in 2013 and then Professor in 2015. She is
a Chartered Physicist. Current research interests
include novel micro/nano-electromechanical sys-
tems (MEMS/NEMS), advanced resistive memories,
biomedical sensor systems, functional materials and devices.
