Multi-level Memristive Memory with Resistive Networks by Irmanova, Aidana & James, Alex Pappachen
Multi-level Memristive Memory with Resistive
Networks
Aidana Irmanova, and Alex Pappachen James
Department of Electrical and Electronics Engineering
Nazarbayev University, Astana
Email: http://www.biomicrosystems.info/alex
Abstract—Analog memory is of great importance in neurocom-
puting technologies field, but still remains difficult to implement.
With emergence of memristors in VLSI technologies the idea of
designing scalable analog data storage elements finds its second
wind. A memristor, known for its history dependent resistance
levels, independently can provide blocks of binary or discrete
state data storage. However, using single memristor to save the
analog value is practically limited due to the device variability
and implementation complexity. In this paper, we present a
new design of discrete state memory cell consisting of sub-
cells constructed from a memristor and its resistive network. A
memristor in the sub-cells provides the storage element, while its
resistive network is used for programming its resistance. Several
sub-cells are then connected in parallel, resembling potential
divider configuration. The output of the memory cell is the
voltage resulting from distributing the input voltage among the
sub-cells. Here, proposed design was programmed to obtain 10
and 27 different output levels depending on the configuration
of the combined resistive networks within the sub-cell. Despite
the simplicity of the circuit, this realization of multilevel memory
provides increased number of output levels compared to previous
designs of memory technologies based on memristors. Simulation
results of proposed memory are analyzed providing explicit data
on the issues of distinguishing discrete analog output levels and
sensitivity of the cell to oscillations in write signal patterns.
Keywords—Analog memory, memristor, neuron, multilevel,
weighted logic, discrete state memory, ternary logic
I. INTRODUCTION
Majority of the memory technologies in the market today
can store two logic states reflecting the widespread need and
use of binary logic of computing [1]. Therefore the data
obtained from sensors that are analog in nature has to be
digitized before it is processed and stored in the memory
[2] consuming time, energy and die area [3]. An alternative
approach would be to process and store the signals in analog
domain, which requires traditional memory technologies to be
exploited beyond binary logic.
There are several reasons to make an effort towards de-
veloping non-binary memory devices. One of them is the
evolution of many valued logic gates that push the speed limits
of computing [4]. The other motivation of designing analog
memory is that it can be used in neuromorphic designs, as it is
useful for synaptic-weight storage in artificial neural networks
[5]. One of the early designs that exploited analog memory
in neural networks was Adaline (Adaptive Linear Neuron
or later Adaptive Linear Element) which memory element
consisted of memistors [6]. A memistor (memory resistor) is
a three-terminal device, made from an electroplating cell, that
had thousands of possible analog storage levels [7].The main
limitation of the technology was its non-scaling property, and
due to this, it was eventually abandoned.
Another three-terminal device that was widely used to
implement analog memory cells is a floating gate transistor.
Analog output of floating gate memory devices heavily relied
on accurate control of charge injections and operated in high
range of voltage levels [8]. Since the state and dynamics of the
device are directly controlled by pulsatile inputs, this similarity
with neuron’s behavior was exploited and described in [9]. In
[10] floating gate devices were used for building analog data
storage of synaptic weights.
Multi-level Flash cells [11] and PRAM [12] are another
set of attempts to build analog memory. Multi-level flash is
also a floating gate device that uses multiple levels per cell
that can store more than one bit using the same number
of transistors. The use of flash memory in neural network
architecture was described in [13], [14]. PRAM is a type of
non-volatile random-access memory that exploits behavior of
chalcogenide glass [15]. PRAM’s switching time and inherent
scalability makes it appealing element for building analog data
storage, but its temperature sensitivity presents a notable issue
[16], that should be taken into account during fabrication.
PRAM for brain-like associative learning is described in [17]
There are also emerging memory technologies such as
based on magnetic devices that are claimed to achieve sig-
nificantly high integration with GP SIMD (General purpose
single instruction, multiple data) and utilizes resistive crossbar
technology [18]. A different approach to realise the resistive
multilevel memory would be using a memristor, a two terminal
electrical component, the value of which is the linear relation
between the charge and flux [19], [20], [21]. Memistor has
multilevel resistance property that can be controlled by the
voltage or current applied across the device as a function of
time and can be programmed to any resistance level between
a maximum possible resistance and minimum resistance [22].
To develop a memristor based multilevel memory, the earlier
designs widely used reference resistance arrays [23], crossbar
technology [24], [25], hybrid structure with Complementary
Metal-Oxide Semiconductors [20]. In this paper, we propose
a novel design of a memory cell that exploits the multilevel
property of memristors. The memristors are programed to
ternary states, using a simplistic memristor circuit in a po-
ar
X
iv
:1
70
9.
04
14
9v
1 
 [c
s.E
T]
  1
3 S
ep
 20
17
tential divider configuration, where the potential differences
across the individual memristor states are controlled to gen-
erate multiple states that can be combined to achieve discrete
analog states.
The Section II explains the design of the proposed memory
focusing on the number of stored values, setting the resistive
states of memristive sub-circuits and simulation results of the
proposed memory cell. Further, the analyses on discrete analog
output levels are provided.
Fig. 1. Circuit design of the proposed discrete analog memory cell.
II. PROPOSED RESISTIVE MEMORY NETWORK
Memristors can store two logic states reflecting its ability
to switch between two distinct resistance levels [26]. The use
of memristor to store multiple state requires the number of
resistance levels to increase to multiple levels. While there
have been attempts to quantize the resistance levels, it also
increases the complexity of the devices. In this work, we
propose a circuit configuration that uses a set of memristors
to build a multi-level memory cell.
A. Number of stored values
Figure 1 shows the proposed design of a memory cell that
has 5 input (reset, read and 3 write ports) and 1 output ports
constructed from 3 sub-cells. Each sub-cell of the memory
consists of a memristor and equal valued 4 resistors, which
are regarded as resistive network. Resistive network serves
to separate each sub-cell from others. Another function of
resistors is to separate Vr read, Vs reset, Vw1, Vw2, Vw3 write
and Vout output ports in the cell.
In general, the memory cell with n sub-cells can store mn
discrete values, where m is the number of different levels of
voltage that is applied through Vw1, Vw2, Vw3. To program
each memristor to the desired state the write signal Vw is
applied at the positive terminal of the memristors and the reset
signal Vs, that precedes every write operation to erase previous
states, is applied from the negative terminal of the device.
Read signal Vr is applied for reading the mn combination of
memory states at the output Vout of the circuit.
In this paper we present simulation results of the memory
cell with n = 3 sub-cells, each of them programmable to
m = 3(0,1,2) states which results in up to 27 level discrete
analog memory.
(a) (b)
(c)
Fig. 2. Timeline of the single cycle of (a) reset, (b) write and (c) read
operations.
B. Setting the resistive states of a memristor
The real-time programming of the memristor requires the
application of a voltage pulse such that it is greater than
its threshold switching voltage. The range of writing voltage
can be selected according to the memristor model, so the
highest positive values are for writing highest resistance levels
and highest negative value is used for the reset operation.
Throughout this paper, we have used Pickett memristor model
[27], and kept the voltage in the range of -3V and +3V.
Implementation of the proposed design with three memris-
tors in a single cell results in a multi-valued memory with
(33=27) levels. Each sub-cell can store three different values
indicating a ternary logic system with the possible Vw values
of Vmax, Vmax/2, and Vgnd voltage levels (Figure 1).
The reset pulse signal with an amplitude of Vmax and time
period of 100ns precede every write operation to restore the
initial state of the sub-cell. In case of writing logic 0 write
signal Vw is set to 0V. The writing process itself is quite
simple, for the desired value of logic 1 or logic 2 respective
1.5V, 3V voltage level is driven into the write line for the same
100 ns period. The write signal activates the cell and changes
the resistive value of the memristor. Figure 2 illustrates the
timeline example of writing the value of 021 to the cell
overall, applying 0V, 3V and 1.5V to the Vw1, Vw2, Vw3 ports
respectively, after resetting the sub-cells with single 3V Vs
pulse.
1) Read operation: The read voltages Vr of 0.1V that is
much lower than Vmax is applied for shorter period - 50ns to
enable the read operation without changing the resistive states
of sub-cells. As it is shown in Fig.2 the control signal Vs
and the write enable signal Vw are connected to the ground
(a) (b)
Fig. 3. The discrete analog levels for (a) 10 level memory cell, and (b) 27 level memory cell.
during the operation. The output voltage Vout is indicative of
the effective discrete analog level of the memory cell:
Vout = Vr
3∑
i=1
(
1
Ri1ki
)
(
3∑
i=1
1
Ri1
(1− 1
ki
) +
1
R0
)
(1)
where n ∈ {1, 2, 3}, kn = 2 + Rn1Rn2 , Rn1 = Rn + MnRn2Rn+Mn ,
and Rn2 = Rn +
R2n
2Rn+Mn
.
C. Simulations and results
The simulation of the proposed circuit was done using HP
memristor model [27]. Configuring the resistive network as
R1 = R2 = R3 = 20Ω resulted in 10 output levels, but
to achieve 27 output levels the values of resistors was set as
R1 = 20Ω, R2 = 60Ω, and R3 = 180Ω. These semiconductor
resistors account for the wire resistances and also help with
differentiating voltage levels between the sub-cells. Figure 3(a)
shows that output voltage levels resulting from simulation of
the three memristor cells shown in Fig. 1 achieves 10 distinct
discrete levels, when the resistors R1, R2 and R3 set to same
value of 20Ω. Changing the resistance values of the sub-cells
i.e. ∀R1 6= R2 6= R3 results in changing the voltage drop
across the potential divider configuration within each sub-cells
shown in Fig. 1. This change in output voltage of the sub-
cells lead to differentiated voltage levels at the output of the
proposed memory cell. Figure 3(b) shows an example of the
increased number of discrete voltage levels to 27 when the
resistor values are set to R1 = 20Ω, R2 = 60Ω, and R3 =
180Ω.
In Fig. 3(b) it can be noted that some of the values like
112 and 121, 121 and 220, 201 and 102, 102 and 110 have
very close discrete voltages that can reduce the discrimination
between the output voltage levels. On the other hand, when
the wire resistance of the memristors are the same in each sub-
cell (20 ohms) only 10 different output values can be achieved.
Looking at the differences of its voltage levels in Fig. 2(a) it
can be noticed that there is only one pair of closest values that
are 222 and 122.
TABLE I
RESISTANCE LEVELS
M1(Ω) M2 (Ω) M3(Ω)
0 232,068 232,132 233,760
1 918,906 749,831 463,077
2 1537996,116 498863,843 26853,357
Table 1 shows the different logical states within each of the
three sub-cells (Fig. 1) to achieve 27 different levels. Within
a given sub-cell memristors are set to work in a ternary logic,
with each logic state taking a different resistance value to
ensure sufficient separation between the output voltages of the
three sub-cells. It can be seen that resistance values for logic
state 2 is extremely high which reflects the modeling issue
of physical behaviour of memristors. This may be calibrated
working with a real device, configuring the values of resistive
network around the sub-cell.
Fig. 4. The histogram of relative percentage difference between the subse-
quent levels.
The histogram of differences between subsequent output
levels like 222 and 122, 122 and 112 shown in Fig. 3(a)
are given as a relative percentage in Fig. 4. It can be seen
that an increase in the number of levels decreases the out-
put voltage differences between the levels. For example in
27 level memory 23 subsequent levels have less than 20%
relative change in their values, while 10 level memory exhibits
greater change with most of the values being between 20 and
40%.This relative change indicates that a 10 level cell can be
more robust in operation than a 27 level cell for the given set
of programming voltage levels (i.e. [0V, 3V]).
Table 2 on the other hand provides analysis on the sensitivity
of the output states relative to the changes in write signal pat-
tern applied through the write signal (Vw). The table indicates
the results for a 5% change in write signal Vw pattern for 27
level and 10 level memory cell. In the column corresponding
to 10 level memory cell same values of different write patterns
like 001, 010, 100 and 002, 020, 200 are highlighted with the
same colors. Overall, the 27 level cell exhibits higher degree
of tolerance to changes in write signal pattern as opposed to
10 level cell, with average relative errors being 8.55%, and
14.98%, respectively.
TABLE II
RELATIVE ERROR FOR 5% CHANGE IN WRITE SIGNAL PATTERN
Write Pattern Relative error (%)
27 levels 10 levels
222 89.22 ± 44.68 32.61 ± 13.38
212 21.44 ± 3.25 53.72 ± 1.34
122 17.20 ± 3.46 53.72 ± 1.34
221 11.41 ± 0.33 53.72 ± 1.34
211 12.77 ± 0.51 30.60 ± 11.85
112 11.52 ± 4.97 30.60 ± 11.85
121 9.16 ± 2.44 30.60 ± 11.85
220 0.18 ± 0.11 5.70 ± 0.15
210 4.36 ± 0.29 5.57 ± 1.42
120 13.25 ± 15.56 5.57 ± 1.42
202 1.66 ± 0.56 5.70 ± 0.15
111 7.72 ± 3.67 16.78 ± 10.97
022 2.98 ± 0.67 5.70 ± 0.15
201 2.55 ± 0.03 5.57 ± 1.42
102 3.86 ± 1.15 5.57 ± 1.42
110 4.06 ± 2.82 3.40 ± 2.28
021 2.33 ± 0.29 5.57 ± 1.42
200 0.06 ± 0.03 0.32 ± 0.07
012 3.31 ± 0.90 5.57 ± 1.42
101 3.15 ± 1.16 3.40 ± 2.28
020 0.60 ± 0.26 0.32 ± 0.07
100 1.40 ± 0.97 1.08 ± 0.74
011 2.48 ± 0.85 3.40 ± 2.28
002 1.38 ± 0.14 0.32 ± 0.07
010 1.70 ± 0.03 1.08 ± 0.74
001 0.98 ± 0.01 1.08 ± 0.74
000 0.00 ± 0.00 0.00 ± 0.00
Average error 8.55 ± 3.30 14.98 ± 5.49
III. CONCLUSIONS
Designing analog memory amongst vast possible applica-
tions of memristors draws extraordinary interest in neuromor-
phic engineering field. Taking into account the nanoscale size
and fast switching property of memristors, memristive analog
memory cells provide desirable means for building artificial
neural networks. In this paper discrete analog memory is
proposed using multiple memristive sub-cells. It is of note that
increasing the number of memristive sub-cells of the memory
results in increased number of analog output levels of the cell,
therefore it can be concluded that continuous output levels can
be achieved by combination of additional sub-cells.
REFERENCES
[1] J. P. Eckert, “A survey of digital computer memory systems,” Proceed-
ings of the IRE, vol. 41, no. 10, pp. 1393–1406, 1953.
[2] R. H. Walden, “Analog-to-digital converter survey and analysis,” IEEE
Journal on selected areas in communications, vol. 17, no. 4, pp. 539–
550, 1999.
[3] M. Bushnell and V. D. Agrawal, Essentials of electronic testing for
digital, memory and mixed-signal VLSI circuits. Springer Science &
Business Media, 2000, vol. 17.
[4] G. Malinowski, “Many-valued logic and its philosophy,” Handbook of
the History of Logic, vol. 8, pp. 13–94, 2007.
[5] G. Nagy, “A survey of analog memory devices,” IEEE TRANSACTIONS
ON ELECTRONIC COMPUTERS, no. 6, pp. 388–393, 1962.
[6] J. A. Anderson and E. Rosenfeld, Talking nets: An oral history of neural
networks. MIT Press, 2000.
[7] A. J. Widrow B, Pierce W. H., “Birth, life, and death in microelectronic,”
may 1961, technical Report No. 1552-2/1851-1.
[8] P. H. B. M. C. M. Chris Diorio, Sunit Mahajan, “A high-resolution
nonvolatile analog memory cell,” in Proceedings of the 1995 IEEE
International Symposium on Circuits and Systems, vol. 3. IEEE, 1995,
p. 22332236.
[9] O. Fujita and Y. Amemiya, “A floating-gate analog memory device
for neural networks,” IEEE Transactions on Electron Devices, vol. 40,
no. 11, pp. 2029–2035, 1993.
[10] B. W. Lee, B. J. Sheu, and H. Yang, “Analog floating-gate synapses for
general-purpose vlsi neural computation,” IEEE transactions on circuits
and systems, vol. 38, no. 6, pp. 654–658, 1991.
[11] S.-K. Lee and D.-H. Park, “Multi level flash memory device and program
method,” may 2006, uS Patent 7,054,199.
[12] J.-W. S. Lee, “Multilevel phase change memory,” Feb. 10 2009, uS
Patent 7,488,968.
[13] S. Khan, “The divided flash memory device for implementing neurons
and neural networks,” in Informatics, Electronics & Vision (ICIEV), 2013
International Conference on. IEEE, 2013, pp. 1–5.
[14] D. Strukov, F. Merrikh-Bayat, M. Prezioso, X. Guo, B. Hoskins, and
K. Likharev, “Memory technologies for neural networks,” in Memory
Workshop (IMW), 2015 IEEE International. IEEE, 2015, pp. 1–4.
[15] R. Simpson, P. Fons, A. Kolobov, T. Fukaya, M. Krbal, T. Yagi, and
J. Tominaga, “Interfacial phase-change memory,” Nature nanotechnol-
ogy, vol. 6, no. 8, pp. 501–505, 2011.
[16] B. C. Lee, P. Zhou, J. Yang, Y. Zhang, B. Zhao, E. Ipek, O. Mutlu, and
D. Burger, “Phase-change technology and the future of main memory,”
IEEE micro, vol. 30, no. 1, 2010.
[17] S. B. Eryilmaz, D. Kuzum, R. Jeyasingh, S. Kim, M. BrightSky,
C. Lam, and H.-S. P. Wong, “Brain-like associative learning using
a nanoscale non-volatile phase change synaptic device array,” arXiv
preprint arXiv:1406.4951, 2014.
[18] A. Morad, L. Yavits, S. Kvatinsky, and R. Ginosar, “Resistive gp-simd
processing-in-memory,” ACM Transactions on Architecture and Code
Optimization (TACO), vol. 12, no. 4, p. 57, 2016.
[19] L. Chua, “Memristor-the missing circuit element,” IEEE Transactions
on circuit theory, vol. 18, no. 5, pp. 507–519, 1971.
[20] P. Rabbani, R. Dehghani, and N. Shahpari, “A multilevel memristor–
cmos memory cell as a reram,” Microelectronics Journal, vol. 46, no. 12,
pp. 1283–1290, 2015.
[21] H. Mostafa and Y. Ismail, “Process variation aware design of multi-
valued spintronic memristor-based memory arrays,” IEEE Transactions
on Semiconductor Manufacturing, vol. 29, no. 2, pp. 145–152, 2016.
[22] S. Kannan, N. Karimi, R. Karri, and O. Sinanoglu, “Modeling, detection,
and diagnosis of faults in multilevel memristor memories,” IEEE Trans-
actions on Computer-Aided Design of Integrated Circuits and Systems,
vol. 34, no. 5, pp. 822–834, 2015.
[23] H. Kim, M. P. Sah, C. Yang, and L. O. Chua, “Memristor-based mul-
tilevel memory,” in Cellular nanoscale networks and their applications
(CNNA), 2010 12th international workshop on. IEEE, 2010, pp. 1–6.
[24] S. Sahebkarkhorasani, “A non-destructive crossbar architecture of multi-
level memory-based resistor,” 2015.
[25] S. Duan, X. Hu, L. Wang, and C. Li, “Analog memristive memory
with applications in audio signal processing,” Science China Information
Sciences, vol. 57, no. 4, pp. 1–15, 2014.
[26] R. S. Williams, “How we found the missing memristor,” IEEE spectrum,
vol. 45, no. 12, pp. 28–35, 2008.
[27] Z. Kolka, D. Biolek, and V. Biolkova, “Improved model of tio2 mem- ristor,” Radioengineering, vol. 24, no. 2, pp. 378–383, 2015.
