Processamento com memristores by Lopes, Flávio Leonel Paradinha
Universidade de Aveiro
Departamento de
Electro´nica, Telecomunicac¸o˜es e Informa´tica,
2011
Fla´vio Leonel
Paradinha Lopes
Processamento com Memristors

Universidade de Aveiro
Departamento de
Electro´nica, Telecomunicac¸o˜es e Informa´tica,
2011
Fla´vio Leonel
Paradinha Lopes
Processing With Memristors
Dissertac¸a˜o apresentada a` Universidade de Aveiro para cumprimento dos
requisitos necessa´rios a` obtenc¸a˜o do grau de Mestre em Engenharia
Electro´nica e de Telecomunicac¸o˜es, realizada sob a orientac¸a˜o cient´ıfica de
Prof. Dr. Jose´ Manuel Neto Vieira, Departamento de Electro´nica, Teleco-
municac¸o˜es e Informa´tica, Universidade de Aveiro; de Prof. Dr. Rui Manuel
Escadas Ramos Martins, Departamento de Electro´nica, Telecomunicac¸o˜es
e Informa´tica, Universidade de Aveiro.

o ju´ri / the jury
presidente / president Prof. Dr. Alexandre Manuel Moutela Nunes da Mota
Professor Associado do Departamento de Electro´nica, Telecomunicac¸o˜es e
Informa´tica da Universidade de Aveiro
orientador / adviser Prof. Dr. Jose´ Manuel Neto Vieira
Professor Auxiliar do Departamento de Electro´nica, Telecomunicac¸o˜es e
Informa´tica da Universidade de Aveiro
co-orientador / co-adviser Prof. Dr. Rui Manuel Escadas Ramos Martins
Professor Auxiliar do Departamento de Electro´nica, Telecomunicac¸o˜es e In-
forma´tica da Universidade de Aveiro
arguente / examiner Prof. Dr. Joa˜o Paulo de Castro Canas Ferreira
Professor Auxiliar do Departamento de Engenharia Electrote´cnica e de Computa-
dores da Faculdade de Engenharia da Universidade do Porto

agradecimentos /
acknowledgements
Prestes a concluir mais uma importante etapa da minha carreira acade´mica,
que chegou a esta fase na˜o apenas pelo meu trabalho e dedicac¸a˜o, mas
tambe´m pelo apoio que me teˆm manifestado todos aqueles que me teˆm
acompanhado neste u´ltimos anos, e´ com enorme satisfac¸a˜o e orgulho que
aqui deixo expressos os meus sinceros agradecimentos a todos os que, directa
ou indirectamente, contribu´ıram para a consecuc¸a˜o deste projecto e me
incentivaram ao longo deste ta˜o sinuoso percurso.
Em primeiro lugar, e com um carinho muito peculiar, manifesto a minha
eterna gratida˜o aos meus pais, pelos esforc¸os que fizeram ao longo da vida
para que fosse poss´ıvel chegar a esta fase, pelo apoio incondicional que
sempre me dedicaram, sem o qual, certamente, eu na˜o estaria aqui a finalizar
esta dissertac¸a˜o. A eles dedico este meu trabalho e agradec¸o o terem-
me facultado as ferramentas indispensa´veis para eu poder construir o meu
futuro.
O meu especial agradecimento ao meu orientador, Professor Doutor Jose´
Neto Vieira e ao meu co-orientador Professor Doutor Rui Escadas Martins,
pelo tempo e disponibilidade que sempre me dispensaram, pela sua com-
preensa˜o e profissionalismo e, sobretudo, por terem aceite este meu desafio
e, tambe´m, me terem feito acreditar que eu tinha as capacidades e conhec-
imentos necessa´rios para desenvolver e levar este projecto ate´ ao fim.
A todos os meus amigos e colegas que me ajudaram na integrac¸a˜o nesta
nova cidade e tornaram a vida longe de casa mais agrada´vel.
E por fim, mas com uma particular importaˆncia, a` Elisabete pela pacieˆncia
que teve comigo nos momentos em que me afastava e me isolava para
trabalhar e quando as coisas corriam menos bem era ela que suportava o
meu mau humor

palavras-chave Memristor, modelo SPICE do memristor, combinac¸a˜o linear, computac¸a˜o
analo´gica, memo´ria analo´gica
Resumo Em engenharia procura-se sempre melhorar o produto anterior. Torna´-lo
mais eficaz, mais ra´pido, enaltecer a sua funcionalidade. Entretanto chega-
-se a um ponto onde o desenvolvimento se torna muito complexo e dis-
pendioso. Chegados a esse ponto e´ necessa´rio procurar novos me´todos para
continuar o desenvolvimento desse produto.
Numa dessas procuras foi descoberta a realizac¸a˜o f´ısica de um novo com-
ponente electro´nico, o memristor. Este novo componente compromete-se
a revolucionar o mundo electro´nico, pois promete ser usa´vel num leque
bastante alargado de aplicac¸o˜es.
O memristor promete ser um elemento de memo´ria na˜o vola´til, pois con-
segue fixar o seu valor resistivo mesmo na˜o estando a ser alimentado. Dado
que o estado interno de um memristor se traduz num valor resistivo, pensa-
se que um memristor pode ser usado para realizar combinac¸o˜es lineares,
em que os coeficientes variam ao longo do tempo, ao inve´s de serem fixos,
como era a u´nica maneira de fazer ate´ agora.
Nesta dissertac¸a˜o pretende-se provar que esta aplicac¸a˜o de memristores e´
poss´ıvel. Para tal ser provado, e´ criado o modelo de um memristor ideal, que
e´ utilizado para simular os circuitos que provam se e´, ou na˜o, poss´ıvel im-
plementar a func¸a˜o pretendida. E´ tambe´m desenvolvido um circuito usado
para forc¸ar, ou ler, um estado do memristor, sem ser necessa´ria qualquer
preocupac¸a˜o com as caracter´ısticas f´ısicas deste componente.
Apo´s se obter o modelo, sa˜o discutidos os resultados obtidos, por forma a
comprovar que estes sa˜o satisfato´rios e que se pode continuar o trabalho.
O mesmo processo de validac¸a˜o e´ usado com o programador. Dado que o
modelo e o programador funcionaram como esperado, e´ poss´ıvel passar ao
aˆmago desta dissertac¸a˜o, criando-se o circuito necessa´rio para se provar se
e´, ou na˜o, poss´ıvel implementar a operac¸a˜o desejada.
Findo este trabalho, conclui-se que os memristores podem, de facto, ser
usados para a aplicac¸a˜o pretendida, pelo que se abrem muitas portas para
trabalhos futuros, por forma a implementar e testar esta soluc¸a˜o em va´rias
aplicac¸o˜es.

keywords Memristor, memristor SPICE model, Linear Combination, Analog Compu-
tation, Analog Memory
Abstract In engineering we are always trying to make a product better. Making
it faster, more efficient, adding new and better features. Meanwhile we
reach a point where that product’s development becomes too complex and
expensive. When that point is reached it is necessary to search for new
methods to continue the product’s development.
In one of those searches the implementation of a new device was found,
the memristor’s. This new device promises to revolutionize the electronic’s
world, since it is expected to be useful in a wide range of applications.
The memristor has potential to be a non-volatile memory element, since
it holds its resistive value, even after it is unplugged from a power source.
Given that the memristor’s inner state is translated into a resistive value, it
is possible to think that memristors can be used to perform linear combina-
tions, where the coefficients will change along the time, between iterations,
instead of being fixed, like it was the only way, until now.
In this thesis we aim to prove that this memristor’s application is possible.
For that to be proven, an ideal memristor model is created, in order to
simulate the circuits that will prove, or not, that the application is realizable.
A circuit that forces a state, or reads one is also developed, in order to
provide an abstraction of the device’s physical characteristics.
Right after the model is obtained, we discuss the simulation’s results, in
order to decide if we can keep with the work or not. The same approach
is used with the programmer. Being that the model and the programmed
worked as expected, we will now carry on to the fulcra point of this thesis,
hence creating the necessary circuitry in order to prove our point.
At the end of this task, we conclude that memristors can actually be used to
perform the desired operation. With this being proved lots of works appear,
to test and implement the proposed solution in other applications.

Contents
Contents i
List of Figures iii
List of Tables v
Acronyms vii
1 Introduction 1
1.1 Motivation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1
1.2 Objectives . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2
1.3 Contributions of this Thesis . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2
1.4 Outline . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2
2 Insights into the memristor 3
2.1 Memristor’s History . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4
2.2 Types of Memristors . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5
2.2.1 Molecular and Ionic Thin Film Memristors . . . . . . . . . . . . . . . 5
2.2.2 Spin Based and Magnetic Memristive Systems . . . . . . . . . . . . . 6
2.3 Applications . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 6
2.3.1 Memories . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7
2.3.2 Field Programmable Gate Arrays . . . . . . . . . . . . . . . . . . . . . 7
2.3.3 Artificial Neural Networks . . . . . . . . . . . . . . . . . . . . . . . . . 8
2.3.4 Logic Implementation . . . . . . . . . . . . . . . . . . . . . . . . . . . 8
2.4 Memristor . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9
2.4.1 Electromagnetic Interpretation . . . . . . . . . . . . . . . . . . . . . . 11
3 Memristor Simulation Model 17
3.1 Device . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 17
3.2 Model . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 19
3.3 Simulations . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 20
3.3.1 Voltage Controlled Simulation . . . . . . . . . . . . . . . . . . . . . . 20
3.3.2 Current Controlled Simulation . . . . . . . . . . . . . . . . . . . . . . 26
3.3.3 Charge Controlled versus Flux Controlled . . . . . . . . . . . . . . . . 28
i
4 Memristor Memory Programing 29
4.1 Programmer . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 29
4.2 Memory . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 33
5 Linear Combinations 37
5.1 Operation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 37
5.2 Simple Implementation Test . . . . . . . . . . . . . . . . . . . . . . . . . . . . 37
5.3 Changing Coefficients on-the-fly . . . . . . . . . . . . . . . . . . . . . . . . . 40
6 Conclusion & Future Work 45
Bibliography 47
ii
List of Figures
2.1 How to implement logic implication with memristors . . . . . . . . . . . . . . 9
3.1 Memristor implementation from [2] . . . . . . . . . . . . . . . . . . . . . . . . 18
3.2 Memristor’s inner dimensions . . . . . . . . . . . . . . . . . . . . . . . . . . . 18
3.3 Circuit used to simulate a memristor . . . . . . . . . . . . . . . . . . . . . . 19
3.4 Testing circuit for memristor’s model . . . . . . . . . . . . . . . . . . . . . . 21
3.5 Test signal applied to the memristor . . . . . . . . . . . . . . . . . . . . . . . 21
3.6 Memristor’s Current . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 21
3.7 Memristor’s Resistance . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 22
3.8 Memristor’s dopant width . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 22
3.9 Memristor’s voltage current characteristic at 1Hz . . . . . . . . . . . . . . . 22
3.10 Memristor’s voltage current characteristic at 2Hz . . . . . . . . . . . . . . . 22
3.11 Memristor’s voltage current characteristic at 10Hz . . . . . . . . . . . . . . . 22
3.12 Memristor’s voltage current characteristic at 100Hz . . . . . . . . . . . . . . 22
3.13 Memristor model upper boundary test . . . . . . . . . . . . . . . . . . . . . . 23
3.14 Memristor model lower boundary test . . . . . . . . . . . . . . . . . . . . . . 23
3.15 Memristor model upper boundary test resistance evolution . . . . . . . . . . 23
3.16 Memristor model lower boundary test resistance evolution . . . . . . . . . . 23
3.17 Memristor model upper boundary test current . . . . . . . . . . . . . . . . . 24
3.18 Memristor model lower boundary test current . . . . . . . . . . . . . . . . . 24
3.19 Saturated memristor voltage current relationship . . . . . . . . . . . . . . . . 24
3.20 Current from testing the model with Table 3.2 parameters . . . . . . . . . . 24
3.21 Regions ratio from Table 3.2 parameters test . . . . . . . . . . . . . . . . . . 24
3.22 Voltage current relation from Table 3.2 parameters . . . . . . . . . . . . . . 24
3.23 Current when testing the device with Table’s 3.3 parameters . . . . . . . . . 25
3.24 Ratio of the two regions when testing using Table’s 3.3 parameters . . . . . . 25
3.25 Voltage current characteristic when using Table’s 3.3 parameters for testing . 25
3.26 Test signal applied to the memristor . . . . . . . . . . . . . . . . . . . . . . . 26
3.27 Memristor’s Voltage . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 26
3.28 Memristor’s Inner State . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 27
3.29 Memristor’s Resistance . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 27
3.30 Memristor’s Voltage . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 27
3.31 Memristor’s Current Voltage Relationship . . . . . . . . . . . . . . . . . . . . 27
3.32 Memristor’s Inner State . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 27
3.33 Memristor’s Resistance . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 27
iii
4.1 Circuit used to program a memristor . . . . . . . . . . . . . . . . . . . . . . 30
4.2 Programmer’s input signal matched with memristor’s voltage . . . . . . . . . 31
4.3 Programmer’s test signals . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 32
4.4 Analog Memory Array . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 34
5.1 Operational Amplifier Summer Configuration . . . . . . . . . . . . . . . . . . 37
5.2 Linear Combinator Circuit . . . . . . . . . . . . . . . . . . . . . . . . . . . . 38
5.3 Linear Combinator Circuit Expected Output . . . . . . . . . . . . . . . . . . 39
5.4 Linear Combinator Circuit Simulated Output . . . . . . . . . . . . . . . . . . 39
5.5 Second Approach Linear Combinator Circuit . . . . . . . . . . . . . . . . . . 39
5.6 Linear Combinator Circuit Expected Output . . . . . . . . . . . . . . . . . . 40
5.7 Linear Combinator Circuit Simulated Output . . . . . . . . . . . . . . . . . . 40
5.8 Linear Combinator Circuit, for changing the coefficients on-the-fly . . . . . . 41
5.9 Simulated output of the programable linear combiner . . . . . . . . . . . . . 43
5.10 Simulated output of the programable linear combiner (focus on the operation) 43
iv
List of Tables
2.1 Variables and Parameters used . . . . . . . . . . . . . . . . . . . . . . . . . . 3
2.2 Implication Truth Table . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9
3.1 Memristor model voltage controlled test parametrs . . . . . . . . . . . . . . . 21
3.2 Memristor model verification parameters . . . . . . . . . . . . . . . . . . . . 25
3.3 Memristor model test parameters . . . . . . . . . . . . . . . . . . . . . . . . 25
3.4 Memristor model test parameters for current simulation . . . . . . . . . . . . 26
3.5 Memristor’s initial parameters used for comparing the two programming modes 26
4.1 Truth table for the writing process . . . . . . . . . . . . . . . . . . . . . . . . 30
v
vi
Acronyms
AC Alternate Current
ADALINE Adaptive Linear Neuron
ANN Artificial Neural Network
CMOS Complementary Metal-Oxide-Semiconductor
DC Direct Current
FIR Finite Impulsive Response
FPGA Field Programable Gate Array
HP Hewlett Packard
MRAM Magnetoresistive Random Access Memory
PES Polyethersulfone
RAM Random Access Memory
RRAM Resistive Random Access Memory
SPICE Simulation Program with Integrated Circuit Emphasis
vii
viii
Chapter 1
Introduction
Back in May 2008, at Hewlett-Packard research labs, a team announced the discovery
of the physical implementation of the fourth fundamental electrical device, the memristor.
This device was first predicted by Chua, Leon [1] almost forty years ago, and belongs to the
non-linear circuit elements.
This device has memory, it is not volatile, and can store a continuous value between the
two boundaries, hence it is possible to think immediately in an endless number of applications.
This thesis is based in one of those applications, and will be explained in section 1.1.
1.1 Motivation
From many years ago, engineers are trying to perform some operations in the digital world,
faster and less power hungry. This lead them to search for analog implementation of those
operations.
Some of the operations that were critical in the digital domain could never be implemented
in the analog world, such as linear combinations, because they were too dynamical and there
was no way to achieve that level of dynamism with conventional discrete analog components.
When back in May of 2008 the implementation of the memristor was presented, that piece
of dynamism appeared undercover. With a component that has the kind of characteristics of
a memristor, we can achieve the desired level of dynamism to implement whatever operation
we need.
This was what lead us to this thesis. We are trying to prove that memristors can be
used to implement that kind of operations. Operations such as linear combinations that can
change its coefficients between iterations, that is our main goal in this thesis.
This is our main goal because that operation is the basis to implement whatever operation
we need, that weren’t yet achieved, and this could mean a huge leap forward in a tremendous
variety of applications.
1
1.2 Objectives
This thesis has three main objectives. Provide a better understanding of this new device,
create a system that is capable of performing linear combinations in hardware, and provide
a basis for future work.
1.3 Contributions of this Thesis
The research performed in this work resulted in the following contributions:
• A better understanding of the memristor;
• An architecture for realization of linear combinations.
• A basis for future work with memristors
1.4 Outline
This thesis is structured as follows. In Chapter 2, we do an introduction to the device
itself, we talk about the history of this device, we give a little insight into the types of
memristors that exist or are under research, then we give a brief explanation on some of the
most known research areas that are trying to adopt the memristor, and finally we explain
thoroughly the physical principles behind the memristor. Following in Chapter 3 we will
describe a memristor of the type that we considered on this text, and how to obtain a model
to use in circuit simulators, and the we test the model. In Chapter 4 we create a programmer
in order to create an abstraction of the different process that is needed, and discuss how
it is possible to create a memory based on a matrix of memristors. Then in Chapter 5 we
conclude our work by creating a circuit that is capable of performing linear combinations,
while between operations, the coefficients change. Finally, in Chapter 6 we talk about what
we achieved with this thesis and provide some guidelines for future research.
2
Chapter 2
Insights into the memristor
In this chapter we will introduce this device as extensively as possible. First we will
introduce the device’s history, from the early publications about a device like this, to the
physical implementation. Then we will talk about the state-of-the-art.
Along this text we will use some variables that describe units or parameters. They are all
explained on the table bellow:
Table 2.1: Variables and Parameters used
Symbol Interpretation Unit
ϕ Magnetic Flux Webber
V Voltage across a device Volt
t Time second
q Charge Coulomb
I Electric current flowing through the device Ampere
R Resistance to the current flow of the device Ohm
C Capacitance of the device Farad
L Inductance of the device Henry
M Memristance of the device Ohm
W Memductance of the device Siemens
w Internal state of the device/ width of the dopped region meter
D Height of the Memristor meter
RON Memristor’s resistance when w = D Ohm
ROFF Memristor’s resistance when w = 0 Ohm
vd Ion drift velocity m/s
µ Ion mobility (µT iO2 = 10
−14) m2/(V.s)
E Electric field intensity V/m
H Magnetic field intensity A/m
B Magnetic flux density Wb/m2
J Electric current density A/m2
D Electric flux density C/m2
ρ Electric charge density C/m3
3
2.1 Memristor’s History
After the presentation of a memristor’s physical realization, we are now able to look back
in time and analyze some curious published results, as well as a similar device.
Back in 1961, when Widrow et al. were introducing their adaptive neuron (ADALINE),
they created a device, which they called memistor (in [8]). It was a three terminal device
in which the resistance, across two of the terminals, was given by the current’s time integral
on the other terminal. It’s working principle is much like the one in a transistor, with the
difference of the current’s time integral versus the instantaneous value.
This was an electrochemical device that changes, and stores, it’s value based on electro-
plating. It consists of a conductive substrate with insulated connecting leads, and a metallic
anode, all in an electrolytic plating bath.
They claim that they have built an analog capable memory element, capable of storing
thousand of possible values, in which the values range from 100Ω to 1Ω, and take about 10s
to switch from one end to the other.
The most curious thing was the programming, and sensing method. The programming
was accomplished by applying a DC signal to the device, while the reading was made applying
an AC signal, exactly like Chua’s memristor [1][8].
Looking back to the memistor history, we note that it wasn’t successful, maybe for it’s
electrochemical nature, which could not be used in integrated circuits, the growing technology
of that time, therefore fading in relevance.
Some years after the memistor introduction, a paper appeared, reporting a switching
phenomena in titanium dioxide thin films. This paper [9] was presented by Argall, from the
Chelsea College of Science and Technology, in 1967. Once more, looking back with today’s
knowledge, we now understand that they were seeing memristance, even before it’s existence
has been introduced. It is relevant to notice that this paper take us to previous works,
where they try to explain this switching effect in other materials. This is why this paper
is interesting. This paper was the first that tried to understand this phenomena, that was
exactly the same, but could not be explained by the same reasons as the ones before. Given
that it is fair to say that this time was the very first time where someone talked/thought
about the concept of memristance, even though not knowing what it was at that time.
It is quite curious that Chua and Argall never looked into each other’s work, but as they
are from “non-related” areas, it is understandable.
The memristor’s story keeps getting written when in 1971 Chua publishes it’s paper en-
titled “Memristor – The missing circuit element”, where he wrote what we describe in sec-
tion 2.4. Then again, in 1976, when he generalizes its concept to a broader range of devices
and systems, the so called “memristive systems”, which were used to provide more accurate
models of some systems, and we also discuss that on section 2.4.
After all these happenings in such short time, the memristor’s history remained idle for
a long period of time. It was only in May of 2008 that another paragraph of this device’s
history was written. A HP’s researching team published a paper in nature ([3]), that was
about to change the electronics world. Finally a physical implementation of a memristor was
discovered.
4
2.2 Types of Memristors
After looking back, and analyzing some device property’s, we are now able to identify
several cases of memristance that have been observed throughout the time.
There are two types of memristors, the molecular and ionic thin film devices, and the spin
based and magnetic memristive systems, which will be explained below.
2.2.1 Molecular and Ionic Thin Film Memristors
These types of memristors are based on the different thin film crystal’s properties, which
exhibit hysterethic behavior when charge is applied to them. This type of devices can be
divided into multiple sub-types, that we will describe right away.
Titanium Dioxide Memristors
These memristors are the ones where the memristance effect was observed, and published,
by HP Labs, consequently it is the type that has more research and publications. We will
focus on this type of devices too.
The titanium dioxide memristor is accomplished by layering stoichiometric titanium diox-
ide on top of positively doped titanium dioxide, in between two platinum electrodes. The
positively doped region, since it has free charge carriers, acts as a conductor, while the stoi-
chiometric layer acts as an insulator. The line that divide’s the two layers, moves according
to the device state, and this is the fact that is responsible for the memristance effect.
The overall resistance is given by the sum of the two layer’s resistance.
Polymeric (ionic) Memristors
Polymeric memristors explore dynamic doping of polymer and inorganic dielectric type
material to attempt and provoke hysterethic behavior. One component of the structure is
free to move as a charge carrier, it could be the cationic or the anionic.
A single passive layer, between the active thin film and the electrode, attempt to exag-
gerate the extraction of ions from the electrode.
Graphene-Oxide Memristor
Two terminal devices consisting of graphitic sheets grown on nano cables or transferred
onto a silicon oxide substrate exhibited an enormous and reversible nonvolatile memory effect,
which was attributed to the formation and breaking of carbon atomic chains. Recently, reliable
and reproducible resistive switching of graphene-oxide thin films and conjugated polymer
functionalized graphene-oxide films were reported [7].
A trilayer device, in which we stack a layer of aluminum, one of graphene-oxide film and
finally another of aluminum, with a cross-point structure was made on flexible polyether-
sulfone (PES) substrate with a uniform graphene-oxide film prepared by spin-casting. This
device showed reliable and reproducible bipolar resistive switching with an on/off ratio of
∼ 100, a retention time of longer than 105s, and switching voltages of ∼ 2.5V .
5
Manganite Memristive Systems
Back in 2001, a substrate of bilayer oxide films based on manganite, describing memristive
properties, has been shown, at the University of Houston.
Resonant-Tunneling Diode Memristor
Some certain types of quantum-well diodes, with special doping designs, have been shown
to exhibit memristive properties.
2.2.2 Spin Based and Magnetic Memristive Systems
This type of memristors rely on the degree of freedom in electron spin. The electron spin
polarization is altered through the magnetic “domain” wall, separating polarities. This allows
the occurrence of hysterethic behavior.
Spin Torque Memristors
Some labs, including Seagate [7], are developing spintronic memristors.
These devices, much like the titanium dioxide memristors, change its state by altering
the ratio between two types of material. This state alteration is achieved by the use of
magnetization, to change the spin directions in one of the two regions of the device. These
two regions are kept separated, by using s moving “wall”, that is controlled by magnetization.
The overall resistance is given by the ratio of the two regions.
Spin Torque Transfer Magnetoresistive Random Access Memory
The development of MRAM has shown, in some cases, memristive properties.
The spin valve, the simplest configuration for a MRAM bit, allows the state to change.
The spin valve consists of two (or more) conducting magnetic materials, that when they
have the same spin moment, it is in the high conductance state, when the spin moment of
the different materials, is opposed, the device is in the low conductance state. This type of
devices, since the materials that make them, always have different magnetic properties (one
soft, one hard, or so), which gives this device the hysterethic behavior.
The resistance is, consequently, controlled by a spin torque, which is induced by a current
flowing through a magnetic junction, and is dependent on the difference in spin orientation
between the two sides of the junction.
Depending on the material used in these devices, they can exhibit both ionic and magnetic
properties. Sometimes they are referred to as “second-order memristive systems”.
2.3 Applications
Nowadays there isn’t yet any market product that uses memristors, but there are some
on the horizon. We will now explain how memristors would be important in any of the
applications that may benefit more from this device.
6
2.3.1 Memories
Memristors can be used to store information indirectly. Since memristors are not capable
of storing energy, they cannot store the information directly.
As the memristors have the ability to switch between two values of resistance, they can
be used to store information, using these two states of resistance. This is an advantage, since
it is possible to build a memory cell with just one device, achieving an huge storage density.
We referred to digital storage, but the memristors capacities as a memory element go
beyond the digital world. It can change its value to any value between RON and ROFF , so it
can be used, in the same way as with the digital memory, to store analog values.1
Going back to the memories, wouldn’t it be great to have a computer that has the operative
system always loaded in the RAM, eliminating therefore the boot time wait? A computer
that doesn’t lose a byte in a power failure? Memristors can provide non-volatile RAM, thus
making things like the ones mentioned before possible.
Beside RAM, memristors can be used for permanent data storage, much like as today
flash memory cells, but with the advantage that it doesn’t have to be a digital memory, it
could be analog.
2.3.2 Field Programmable Gate Arrays
Field programable gate arrays (FPGAs) are used to build, with not much effort, appli-
cation specific processors from scratch. They provide interconnected digital gates, where the
connections between them are chosen by the programmers, implementing therefore what they
need to build a complete system.
Developers only chose FPGAs to build a system, when they have to meet tight timing
schedules, such as in telecommunications, signal processing, and so on, since they can have full
control over the data-path of a specific function, getting therefore the maximum performance
of the system. In some applications even FPGAs can be too slow, so there is the need to
improve the performance of these devices.
We can use memristors to implement analog adders, where we can control the resistance
electronically according to previous values, making it therefore valuable for FPGAs, since the
digital equivalent takes a lot more of resources and time. This could be a great advantage
if we will process large vectors of information, so all the multiplying and accumulating in a
FPGA become quite complex.
Lets follow a practical example. If we want to implement a 200th order FIR filter, we
will going to have 201 multiplications and sums. Trying to make this work in the minimum
time possible, requires 201 multipliers, with at least 64 bits each if we are working with a
regular 32 bit word, and another bunch of adders with lots of bits too. If we look at the
equivalent implemented with memristors, it only requires 201 memristors, and the necessary
programming and reading equipment, which is much less than the digital solution.
1This is the goal of this thesis.
7
2.3.3 Artificial Neural Networks
An artificial neural network is used to solve complex problems with simple operations,
such as the multiplication and sum. They are based on the biological neural networks, like
our brain, or other animal that has cognitive capabilities.
Biological neural networks are made from neurons, which are the fundamental element
of a neural network, dendrites, that capture the signal from synapses and transmit it to the
neuron, axons, that transmit the signal from the neuron to the synapses, and finally synapses
that make the connection between the extremities of an axon to a dendrite. One single neuron
can have multiple inputs, and multiple outputs as well.
Artificial neural networks are modeled from the biological ones, described above, so they
will have equivalents to all its components. Now we will describe the function of each com-
ponent and how they are implemented artificially.
Lets start by the dendrites. Dendrites capture a fraction of the signal provided by the
previous axon, that fraction depends on the synapse, and it can be modeled by a linear
combination of the input signal with a coefficient, much like a digital FIR filter. Now we
approach the neuron. The neuron simply sums the input values, and if the signal is sufficient,
it produces a single output. This single output can be transmitted to several neurons, by the
axon, so it is quite simple to model, as we just have to grab the neuron’s output value. We
have already talked about synapse’s function, but to clarify their role in the network we will
discuss them again. Synapses modify the input value by a weight that is defined according
to each function that the neuron is implementing.
The learning process that all neural networks have to pass, in order to do something, is
called learning or training. What this process does is to modify the synapse’s values.
All these functions are implemented in an artificial neuron, leaving it with only simple
inputs and outputs. An artificial neural network can have several neurons, organized in layers
to accomplish the desired application.
A memristor behaves exactly as a synapse, changing its value into a new one according to
its past, what makes them perfect to implement neural networks. Since an electronic analog
adder is very simple to make, the only element that was missing, to build an analog version
of an artificial neural network, was the memristor.
2.3.4 Logic Implementation
Memristors can be used to perform logic operations as well. These devices implement
material implication, a fundamental logic operation [10].
That operation’s truth table is the following:
So the function that it implements is:
f(x, y) = x¯+ y (2.1)
As we can see in the table, the operation is represented by the symbol ‘→’, so it is written
“x→ y” and it is read “x implies y”, or “if x, then y”.
8
Table 2.2: Implication Truth Table
x y x→ y
0 0 1
0 1 1
1 0 0
1 1 1
It could be proved that with implication and the false operation (despite the input value,
it’s output is always 0) one can implement all the other logic operations, providing therefore
a complete logic basis.
In order to achieve this logic operation with memristors, a circuit like the one of the next
figure, must be implemented.
vIn
m1
R0
vset
m2
vout
Figure 2.1: How to implement logic implication with memristors
Recalling that m1 stores the value of x, m2 stores y’s value, and that implication’s result
will be stored in m2 (m2 = m1 → m2), we will briefly explain how the implication is achieved.
In order to perform a logical operation, the values of x and y must be preloaded to m1
and m2 respectively. After the pre-charge of the values, a control signal is applied in both the
inputs. According to the state of the memristors, and the value of R0, the value of vout will
be pulled up or down, therefore changing the state of m2. This state must later be sensed.
This construction can be scaled up to multiple inputs, outputs, and to perform a complete
set of logic operations, as explained in [11].
2.4 Memristor
Back in 1971, Chua noticed that among the six possible relationships between two of
the four basic electric variables (magnetic flux, charge, voltage and current), only five were
known. The five shown below.
9
δϕ = V δt (2.2)
δq = Iδt (2.3)
δV = RδI (2.4)
δq = CδV (2.5)
δϕ = LδI (2.6)
From these relationships, Equation 2.4, Equation 2.5 and Equation 2.6 supply us with the
basic well known circuit elements (resistor, capacitor and inductor, respectively), and the two
remaining relationships provide us with the capability of calculating the voltage or current
value from the magnetic flux or charge, respectively.
Hence the relationship that wasn’t established yet, was the relationship between the mag-
netic flux and charge. It was then necessary to postulate this new device that provide us the
missing relationship, shown below.
δϕ =Mδq (2.7)
Since the magnetic flux is directly proportional to the charge, and recalling equations 2.2
and 2.3, we can conclude right away that the I-V relation will not be linear. With those
equations still in mind, dividing both sides of the above equation by δt, and differentiating
them, we obtain the following equation that gives us the voltage across a charge-controlled
memristor.
V (t) =M(q(t))I(t) (2.8)
Where
M(q) ≡
δϕ(q)
δq
(2.9)
Similarly, the current in a flux-controlled memristor is
I(t) =W (ϕ(t))V (t) (2.10)
Where
W (ϕ) ≡
δq(ϕ)
δϕ
(2.11)
Notice that M(q) has the unit of resistance (arrange equation 2.8 to confirm), so it will be
called incremental memristance. The function W (ϕ) has units of conductance, so similarly,
it will be called incremental memductance.
A memristor at a given instant behaves like an ordinary resistor, but its value on that
moment depends on the complete past history of the current. Notice that the value of the
memristance (memductance) at an instant t0 depends upon the time integral of the memristor
current (voltage) from t = −∞ to t = t0. Given these properties, and in order to simplify
the explanations and understanding of the device, henceforth we will describe it as if it were
a resistance instead of memristance.
10
Going a bit further on the topic, we can change the device’s resistance to the value we
want, programming it therefore. If we want to read the information that was previously set
on the memristor, we have to apply a signal (voltage or current) with null mean value, in
order to assure that the time integral stays unchanged.
Given all these properties it is now possible to understand the choice of the name memristor
for this device, as it has two functionalities, memory and resistance.
Chua postulated some theorems that we will not explain here, we will only mention one of
them, that is quite important, the passivity theorem. It says that a memristor characterized
by a differentiable charge-controlled ϕ − q curve is passive if, and only if, its incremental
memristance is nonnegative. If its incremental memristance is negative, this means that the
device is providing power to the circuit, therefore it is an active device.
Five years after this concept presentation, Chua and his student, Kang, published a pa-
per [6], broadening the concept of a memristor into a whole class of systems, the memristive
systems. According to that paper a system can be called a memristive system if it is described
by a system of equations like,
v(t) = R(w, i, t)i(t) (2.12)
w˙(t) = f(w, i, t) (2.13)
whereR is the system’s resistance according to its internal state variable w, which dynamic
is described by f(w, i, t). Some examples of memristive systems were found, long before the
memristor itself, such as an old tungsten light bulb. It is important to realize that the
memristor, itself, is a particularization of these systems.
2.4.1 Electromagnetic Interpretation
As electrical engineers know, the fundamental devices can be understood by analyzing
the quasi-static expansion of Maxwell’s equations. The memristor is no exception, and these
interpretations provide us with a deeper understanding of this new device. Chua [1] used this
interpretation to suggest that a physical memristor realization was possible.
Let’s begin by recalling Maxwell’s equations in their differential form:
∇×E = −
δB
δt
(2.14)
∇×H = J+
δD
δt
(2.15)
∇ ·D = ρ (2.16)
∇ · J = −
δρ
δt
(2.17)
∇ ·B = 0 (2.18)
and that
D = ε0E+P (2.19)
B = µ0(H+M) (2.20)
11
Where P is the polarization, and M is the magnetization, ε0 and µ0 are the electric
permittivity and magnetic permeability of free space, respectively.
It’s possible to see that if we have a varying magnetic flux , we will have a varying electrical
field, which generates a varying magnetic field, and vice-versa. If we want to calculate one
of the fields, we will have to solve a system of equations, in order to have an accurate result.
This is not needed if we are working with static fields, in which case we can obtain a solution
by solving a simple equation, as the fields are independent.
In order to simplify the resolution of the system, we should look for a method that resem-
bles the static fields resolution. To achieve that, we start by making a linear transformation,
substituting t with
τ = αt (2.21)
where α is a time-rate parameter. The time-rate parameter can be used to describe
a family of functions τ , that have the same shape as the ones in t, but are compressed or
stretched in time, depending on α being greater than 1, or otherwise, smaller. This parameter
can be seen as a frequency variation parameter, in order to simplify the explanation. If we
rewrite Eqs. 2.14 to 2.18, in order to include this linear transformation, we have:
∇×E = −α
δB
δτ
(2.22)
∇×H = J+ α
δD
δτ
(2.23)
∇ ·D = ρ (2.24)
∇ · J = −α
δρ
δτ
(2.25)
∇ ·B = 0 (2.26)
It is straight-forward that if α = 0, the equations describe the static field solution, thus
can be solved separately.
When we have a very small α, but still not equal to zero, the factors that will affect the
system, will be attenuated by the small α, so E and H will not differ too much from those
when α = 0. It is, then, possible to say, that when α is small, the following is true
E = (E)0 + α
(
δE
δα
)
0
(2.27)
H = (H)0 + α
(
δH
δα
)
0
(2.28)
The subscripted zero indicates that the quantities in parentheses are evaluated for α = 0.
In this equation there is the static field solution, to which we added the variation of α.
The derivatives with respect to α in the equations above, can be obtained directly by the
field laws, in fact, differentiating eqs. 2.22 through 2.26 in order to α, and setting α = 0, it is
possible to obtain the following expressions
12
∇×
(
δE
δα
)
0
= −
δ
δτ
(B)0 (2.29)
∇×
(
δH
δα
)
0
=
(
δJ
δα
)
0
+
δ
δτ
(D)0 (2.30)
∇ ·
(
δJ
δα
)
0
= −
δ
δτ
(ρ)0 (2.31)
This leads us to what we wanted since the beginning, the chance to solve the equation
without solving the system. It is easy to see that the terms that are differentiated in order
to τ can be obtained by the static field equations.
If this approximation isn’t satisfactory, it is possible to add square terms in α, proportional
to the second derivatives, then cubic terms, and so on, until the approximation satisfies the
requirements, always with α = 0. If we do so, this will yield in a power series, like the
following,
E = E0 + αE1 + . . .+ α
kEk (2.32)
H = H0 + αH1 + . . .+ α
kHk (2.33)
and recalling that
E0 = [E]α=0 (2.34)
E1 =
[
δE
δα
]
α=0
(2.35)
...
Ek =
1
k!
[
δkE
δαk
]
α=0
(2.36)
the procedure to obtain H0, H1, and so on, is similar to the one explained above for the
various Ex.
We can see that what was true for the first order derivatives, – the possibility to calculate
the first order derivative, as being the static case solution – is still true for the higher order
derivatives. It is possible to have a solution based on the previous degree iteration, recall
from Equation 2.29 to Equation 2.31. Therefore it is possible to solve a field equation alone,
without having to solve a system, and it can be done achieving the desired error.
A good result can be achieved by making a quasi-static approach to the problem, this
is, considering only the zero and first order solutions. If we assume this and if α = 1,
Equation 2.32, and Equation 2.33, will yield
E = E0 +E1 (2.37)
H = H0 +H1 (2.38)
13
If we assume that all materials under consideration, are linear and isotropic, the con-
stituent relations are simply given by
D = εE (2.39)
B = µH (2.40)
And we should recall another important relation
J = σE (2.41)
With all this in mind, we can write the zero-order equations as:
∇×E0 = 0 (2.42)
∇×H0 = J0 (2.43)
∇ · εE0 = ρ0 (2.44)
∇ · µH0 = 0 (2.45)
∇ · J0 = 0 (2.46)
and the first-order ones as
∇×E1 = −µ
δH0
δt
(2.47)
∇×H1 = ε
δE0
δt
+ J1 (2.48)
∇ · εE1 = ρ1 (2.49)
∇ · µH1 = 0 (2.50)
∇ · J1 = −
δρ0
δt
(2.51)
If we analyze the above equations, we can see that there are three types of solutions. We
can have solutions of the electric type, characterized by the absence of a zero-order magnetic
field, and solutions of the magnetic type, characterized by the absence of a zero-order electric
field, and these solutions only appear when there is no coupling between electric and magnetic
fields, i.e, the conductivity is infinite. And finally, we have the solution where we have the
zero-order electric field, and a zero-order magnetic-field, coupled by currents in a material
that doesn’t have infinite conductivity.
If we have the electrical field, and the magnetic field coupled, it should, somehow, be
possible to relate them. Electric and magnetic fields, cause/are caused by voltage and current
respectively, and we can think in at least three ways to relate voltage and current. The
definitions of the three basic electrical components, the resistor, capacitor and inductor, and
their voltage current relationship is the one mentioned in Equation 2.4, Equation 2.5, and
Equation 2.6, respectively.
So let’s start by the resistor. On a resistor, the first-order fields are negligible, so if we
apply a zero-order electric field, that results on a current density, as shown in Equation 2.41
14
and that creates a zero-order magnetic field as stated by Equation 2.43, and this is the only
way that this combination (first-order fields negligible) can be related.
Now if we think that we have a varying zero-order electric field, a negligible first-order
electric field, and a zero-order magnetic field, we will have a non-negligible first-order magnetic
field. If we have a varying zero-order electric field, we are considering Equation 2.48, where
J1 comes from Equation 2.51, which takes us to Equation 2.44 to complete the relationship,
and to have H1 in order to E0, only. When we think in what this relationship means, we
conclude that a component that has a relationship where the variation of the voltage yields
in a current, is a capacitor, as can be seen in Equation 2.5.
From the three basic components, the one that we didn’t talk yet is the inductor. The
inductor relates the zero-order magnetic-field with the first-order electric field, hence the
negligible fields are the first-order magnetic field, and zero-order electric field. Here we grab
Equation 2.47, substitute H0 from Equation 2.43, and we have a relationship that results
in a first-order electric field that results from a zero-order magnetic field, and to make the
connection to Equation 2.6, the magnetic field is created by the current density J0.
We talked about the fields relationships when both first-order, and only one first-order,
and one zero-order fields are negligible. We now should talk about the case when both the
zero-order fields are negligible, hence only the first-order fields are taken in account. First we
should be aware that is only when we take in account a first-order field, that a field generates
the other one, so when we take in account both first-order fields, we should expect a non-linear
dynamic behavior, as mentioned earlier.
When we take in account only the first-order fields, we are looking at Equation 2.48 where
the term that mentions E0 is neglected, and J1 comes from Equation 2.41. This relationship
is very similar to the one presented by the resistor, but has a major difference. Here we are
considering only the first-order fields, while when talking about the resistor we considered
only the zero-order fields. This relationship is non-linear, as we said above. The only known
component that seems like a resistor, but has a non-linear behavior is the memristor, and this
is his fields relationship.
15
16
Chapter 3
Memristor Simulation Model
We have introduced the basics of the memristor, the physics behind it and how it works.
We presented before the relationship between voltage and current, but that isn’t enough to
start a circuit simulator and start designing a circuit with memristors. Hence now we will
describe how to create a simulation model, that will let us observe the memristor’s behavior
in a circuit.
3.1 Device
If we want to create a simulation model for a device, we must know the physical imple-
mentation of that device, in order to understand the physics behind its working principle.
Here we will introduce the physical implementation of a Titanium Dioxide memristor, like
the ones HP Labs introduced back in May of 2008.
The device that Stanley Williams presented is achieved by making a sandwich of titanium
dioxide (T iO2) between two platinum electrodes. The layer of T iO2 is divided in two regions,
one is stoichiometric T iO2, while the other is constituted by positively doped titanium dioxide
(T iO2−x). The stoichiometric portion of the device is a pure semiconductor, working as an
insulator, while the doped portion works as a conductor. This construction is shown in
Figure 3.1.
Since we have two regions with different resistances, we can describe the total resistance
by the sum of two resistances in series, while its value is given by the relationship between
the region thickness over the total thickness.
Recalling that a memristor is a particularization of memristive systems, thus being de-
scribed by the system of Equation 2.12 and Equation 2.13 it is possible to start understanding
how the device works. The device’s resistance according to its state is given by
R(w(t)) = RON
w(t)
D
+ROFF
(
1−
w(t)
D
)
(3.1)
where w is the frontier between the two regions of T iO2 andD is the overall T iO2 thickness,
as shown in Figure 3.2.
As the current flows through the device, the doped region gets thicker or thinner, depend-
ing on the amount of current flowing and the device’s past, changing its state and therefore
17
Figure 3.1: Memristor implementation from [2]
its equivalent resistance of the doped and undoped regions. As this change is structural, it is
a non-volatile change.
Now it is necessary to discover the relation between w and the charge that flows through
the device. To do so, we will use the concept of drift velocity. The drift velocity of a particle
is given by
vd = µE (3.2)
where µ is the ion mobility and E is the applied electrical field.
The drift velocity is the time derivative of the memristor’s width, so we can describe the
Figure 3.2: Memristor’s inner dimensions
18
system dynamic’s by this equation. Rearranging it into a more usable form we get:
vd = µ
RON
D
i(t) (3.3)
Right now, we have a couple of equations, which, according to [6], are enough to describe
a memristive system. Being the memristor itself a particularization of a memristive system,
it can be described using this couple of equations. Let’s recall them:
v(t) =
(
RON
w(t)
D
+ROFF
(
1−
w(t)
D
))
i(t) (3.4)
w˙(t) = µ
RON
D
i(t) (3.5)
Given this, we can create a simulation model in a circuit simulation program, like PSpice,
which we will do in Section 3.2. After that we can create circuits with memristors, and observe
their behavior in a circuit.
3.2 Model
In order to create a SPICE model, one must choose between two types of models, a sub-
circuit and a model. We chose the sub-circuit type. A sub-circuit consists in encapsulating a
small circuit, that implements the desired function.
We want to implement a function that returns a resistance value according to its past.
So we want to implement Equation 3.1. If we recall that RON  ROFF , we can make the
following approximation
R(w(t)) = ROFF
(
1−
w(t)
D
)
(3.6)
If we integrate Equation 3.5, in order to have w(t), and substitute that in Equation 3.6,
we get what we should implement:
R(w(t)) = ROFF
(
1−
µRON
D2
q(t)
)
(3.7)
Where q(t) is the charge that flowed through the device. Given this, we started by
implementing the circuit in Figure 3.3.
ROFF
iMEM
−
+ ∆RV (x)
x
Cx
µRON
D2
iMEM
Figure 3.3: Circuit used to simulate a memristor
19
This circuit uses two controlled sources, one is a voltage controlled voltage source, and the
other is a current controlled current source. The current source charges a capacitor, whose
voltage is used to change the voltage of the voltage source.
The capacitor is charged using a current source, in order to make its voltage directly
depending on the charge that flowed through the device, as shown in Equation 3.8. Solving
the equation, we have:
v(t) =
1
C
∫
i(t)dt (3.8)
v(t) =
1
C
∫
µRON
D2
iMEMdt (3.9)
v(t) =
µRON
CD2
q(t) (3.10)
If the capacitor has the value of 1F , we have a term of the Equation 3.7. If we multiply
that by ROFF , and then subtract ROFF , we implement Equation 3.7. That is why there is
also a voltage source.
This yields in a malfunctioning model, since the device can present a voltage superior to
iMEMROFF , and a negative one inferior to iMEMRON . To workaround this glitch, we have
to assure that VCx does not go above, or below, certain values. In order to accomplish this,
we have to, somehow, limit VCx .
We can multiply the value of the current source, with a window function, so it limits
the charge or discharge of the capacitor when it approaches the limit values. The window
function we used is
f(x) = 1− (2x− 1)2p (3.11)
where p is a positive integer, and x is the ratio between w and D.
The form of this window function guarantees zero speed of the coordinate when approach-
ing either limit, therefore ensuring that the boundaries are respected.
In our model implementation, we used some parameters so we can define the memristor’s
characteristics for each simulation. Those parameters are used to define, RON , ROFF and
the initial resistance Rinit, D, p and µ.
3.3 Simulations
There are two ways of changing the state of a memristor. Making charge, or a magnetic
flux, flow through the device. In this section we will test the created model under these two
conditions.
3.3.1 Voltage Controlled Simulation
With this model implemented in PSpice, we created a circuit to test the model. The
circuit was the one presented in Figure 3.4.
20
−
+
vin
Figure 3.4: Testing circuit for memristor’s model
Variable Value
RON 1kΩ
ROFF 100kΩ
Rinit 80kΩ
D 10nm
µ 10fm
2
V s
p 1
vin 1.2V
f0 1Hz
Table 3.1: Memristor model voltage controlled test parametrs
For the first set of tests, we used Table’s 3.1 values for the memristor’s specifications, and
inputs. With these parameters, and the signal in Figure 3.5 applied to the test memristor we
obtained the current curve presented in Figure 3.6. We don’t obtained a perfect sinusoidal
signal, what proves that the resistance of the device is varying along the simulation, and that
is depicted in Figure 3.7. This can be seen as a variation of dopant’s width in the memristor,
and that is depicted in Figure 3.8. This figure is not represented in an absolute measure,
but instead is represented in relative terms due to the total memristor width (w/D). Given
all this, we are able to see that the voltage current relationship is non-linear, as is depicted
in Figure 3.9. As said before, as we increase the frequency, the memristor degenerates in an
ordinary resistor, as shown in Figure 3.10, Figure 3.11 and Figure 3.12.
After these tests we tested the window function. To do so, we used the same circuit
configuration, but this time with a direct current (DC) source, and we used two values for
Rinit, RON and ROFF . Starting at these values, the memristor’s resistance has to stop on
0 0.2 0.4 0.6 0.8 1−1.5
−1
−0.5
0
0.5
1
1.5
Time (s)
Vo
lta
ge
 (V
)
Figure 3.5: Test signal applied to the
memristor
0 0.2 0.4 0.6 0.8 1−4
−2
0
2
4x 10
−5
Time (s)
Cu
rre
nt
 (A
)
Figure 3.6: Memristor’s Current
21
0 0.2 0.4 0.6 0.8 10
2
4
6
8
10x 10
4
Time (s)
R
es
is
ta
nc
e 
(O
hm
)
Figure 3.7: Memristor’s Resistance
0 0.2 0.4 0.6 0.8 10.2
0.4
0.6
0.8
1
Time (s)
D
op
an
t W
id
th
 R
at
io
Figure 3.8: Memristor’s dopant
width
−2 −1 0 1 2−4
−2
0
2
4x 10
−5
Voltage (V)
Cu
rre
nt
 (A
)
Figure 3.9: Memristor’s voltage cur-
rent characteristic at 1Hz
−2 −1 0 1 2−2
−1
0
1
2x 10
−5
Voltage (V)
Cu
rre
nt
 (A
)
Figure 3.10: Memristor’s voltage cur-
rent characteristic at 2Hz
−2 −1 0 1 2−2
−1
0
1
2x 10
−5
Voltage (V)
Cu
rre
nt
 (A
)
Figure 3.11: Memristor’s voltage cur-
rent characteristic at 10Hz
−2 −1 0 1 2−2
−1
0
1
2x 10
−5
Voltage (V)
Cu
rre
nt
 (A
)
Figure 3.12: Memristor’s voltage cur-
rent characteristic at 100Hz
22
0 0.5 1 1.5−0.5
0
0.5
1
1.5
Time (s)
D
op
an
t W
id
th
 R
at
io
Figure 3.13: Memristor model upper
boundary test
0 0.5 1 1.5−0.5
0
0.5
1
1.5
Time (s)
D
op
an
t W
id
th
 R
at
io
Figure 3.14: Memristor model lower
boundary test
0 0.5 1 1.50
5
10
15x 10
4
Time (s)
R
es
is
ta
nc
e 
(O
hm
)
Figure 3.15: Memristor model upper
boundary test resistance evolution
0 0.5 1 1.50
5
10
15x 10
4
Time (s)
R
es
is
ta
nc
e 
(O
hm
)
Figure 3.16: Memristor model lower
boundary test resistance evolution
the other, when a DC signal is applied.
In Figure 3.13 is represented the evolution of the barrier between the doped and undoped
regions of the memristor, when it is switching from the OFF state to the ON state, while
Figure 3.14 shows the opposite. Figure 3.15 and Figure 3.16 represent the evolution of the
resistance while the device it’s switching, to ON , and OFF respectively, while the current that
is being consumed in that transition is depicted in Figure 3.17 and Figure 3.18, accordingly.
When the device reaches the boundaries, the voltage current relationship suffers the dis-
tortion shown in Figure 3.19.
With these tests,we verified that the created model behaves as a memristor. Yet we can’t
conclude that the model behaves as expected. To conclude that, we have to test the model
with the same parameters that are presented in [4], and compare the results that we obtained
with the ones that are presented there.
Those parameters are the ones presented in Table 3.2, followed by the parameters of
Table 3.3. Using Table 3.2 parameters we obtained a current curve that is depicted in Fig-
ure 3.20, which comes by the barrier change of position, shown in Figure 3.21. This results
in the voltage current relationship represented in Figure 3.22. Then, using the values of Ta-
ble 3.3 we obtained Figure’s 3.23 current curve, that is a consequence of the change of the
dopant width, which is seen in Figure 3.24. The voltage current relationship is the one shown
in Figure 3.25.
23
0 0.5 1 1.50
0.5
1
1.5
2
2.5x 10
−3
Time (s)
Cu
rre
nt
 (A
)
Figure 3.17: Memristor model upper
boundary test current
0 0.5 1 1.5−2.5
−2
−1.5
−1
−0.5
0
0.5x 10
−3
Time (s)
Cu
rre
nt
 (A
)
Figure 3.18: Memristor model lower
boundary test current
−2 −1 0 1 2−2
−1
0
1
2x 10
−3
Voltage (V)
Cu
rre
nt
 (A
)
Figure 3.19: Saturated memristor
voltage current relationship
0 1 2 3−2
−1
0
1
2x 10
−4
Time (s)
Cu
rre
nt
 (A
)
Figure 3.20: Current from testing the
model with Table 3.2 parameters
0 1 2 30.2
0.4
0.6
0.8
1
Time (s)
D
op
an
t W
id
th
 R
at
io
Figure 3.21: Regions ratio from Ta-
ble 3.2 parameters test
−2 −1 0 1 2−2
−1
0
1
2x 10
−4
Voltage (V)
Cu
rre
nt
 (A
)
Figure 3.22: Voltage current relation
from Table 3.2 parameters
24
0 1 2 3 4−5
0
5
10x 10
−3
Time (s)
Cu
rre
nt
 (A
)
Figure 3.23: Current when testing
the device with Table’s 3.3 parame-
ters
0 1 2 3 4−0.5
0
0.5
1
1.5
Time (s)
D
op
an
t W
id
th
 R
at
io
Figure 3.24: Ratio of the two regions
when testing using Table’s 3.3 param-
eters
Variable Value
RON 100Ω
ROFF 16kΩ
Rinit 11kΩ
D 10nm
µ 10fm
2
V s
p 10
vin 1.2V
f0 1Hz
Table 3.2: Memristor model verifica-
tion parameters
Variable Value
RON 100Ω
ROFF 5kΩ
Rinit 1kΩ
D 10nm
µ 10fm
2
V s
p 10
vin 2V
f0 1Hz
Table 3.3: Memristor model test pa-
rameters
−2 −1.5 −1 −0.5 0 0.5 1 1.5 2−4
−2
0
2
4
6
8
10 x 10
−3
Voltage (V)
Cu
rre
nt
 (A
)
Figure 3.25: Voltage current characteristic when using Table’s 3.3 parameters for testing
25
Variable Value
RON 100Ω
ROFF 10kΩ
Rinit 10kΩ
D 10nm
µ 10fm
2
V s
p 10
iin 100µA
f0 0.25Hz
Table 3.4: Memristor model test pa-
rameters for current simulation
Variable Value
RON 100Ω
ROFF 16kΩ
Rinit 11kΩ
D 10nm
µ 10fm
2
V s
p 10
iin 150µA
f0 1Hz
Table 3.5: Memristor’s initial param-
eters used for comparing the two pro-
gramming modes
0 2 4 6 8−1
−0.5
0
0.5
1x 10
−4
Time (s)
Cu
rre
nt
 (A
)
Figure 3.26: Test signal applied to
the memristor
0 2 4 6 8−1
−0.5
0
0.5
1
Time (s)
Vo
lta
ge
 (V
)
Figure 3.27: Memristor’s Voltage
With as much accurate as a reading of [4] graphs can be, we see that what we obtained
is quite similar to what we should have. Therefore we can conclude that the model is a
completely functional model, with satisfying results.
3.3.2 Current Controlled Simulation
After seeing how this model behaves when tension is applied to it, now we will perform
the same type of analysis, but applying current this time.
The circuit we used for this purpose is similar to the one we used for the voltage controlled
simulation, but instead of having a voltage source, obviously we have a current source. The
memristor parameters we used this time, are the ones of the Table 3.4.
In this simulation, we applied the signal depicted in Figure 3.26, and that resulted in the
voltage shown if Figure 3.27. From this we obtained the device’s resistance variation along
time, which is the curve in Figure 3.29, which is what we expected form the memristor’s inner
state presented in Figure 3.28.
After this simulation, we performed another one, similar, as much as possible as the one
in Table 3.2, which parameters are in Table 3.5, in order to compare the two control methods.
26
0 2 4 6 8−0.5
0
0.5
1
1.5
Time (s)
D
op
an
t W
id
th
 R
at
io
Figure 3.28: Memristor’s Inner State
0 2 4 6 80
2000
4000
6000
8000
10000
12000
Time (s)
R
es
is
ta
nc
e 
(O
hm
)
Figure 3.29: Memristor’s Resistance
0 1 2 3 4−1.5
−1
−0.5
0
0.5
1
1.5
Time (s)
Vo
lta
ge
 (V
)
Figure 3.30: Memristor’s Voltage
−2 −1 0 1 2
x 10−4
−1.5
−1
−0.5
0
0.5
1
1.5
Current (A)
Vo
lta
ge
 (V
)
Figure 3.31: Memristor’s Current
Voltage Relationship
0 1 2 3 4
0.4
0.5
0.6
0.7
0.8
Time (s)
D
op
an
t W
id
th
 R
at
io
Figure 3.32: Memristor’s Inner State
0 1 2 3 42000
4000
6000
8000
10000
12000
Time (s)
R
es
is
ta
nc
e 
(O
hm
)
Figure 3.33: Memristor’s Resistance
27
The results from that simulation are the ones presented from Figure 3.30 to Figure 3.33,
where we can see that the results are pretty much the dual of those obtained when simulating
with the parameters from Table 3.2.
3.3.3 Charge Controlled versus Flux Controlled
So in order to summarize this section, we will discuss the advantages and disadvantages
of these two control processes, and compare its ease of use. To this discussion we will have
in mind the programming of a value on a memristor, or its switching between states.
The two methods are quite similar, they make the perfect dual, as it was expected since
underneath it all, a memristor behaves like a resistor.
The major difference between the two modes is the current that flows through the device.
Let’s take, for example, the memristor’s parameters mentioned in Table 3.4, and assuming
that we will work with 100µA when we want a charge controlled mode, and that we will use
1V when we want the flux controlled mode.
If it is a charge controlled switching, the current is fixed, and then the voltage will drop
or raise, according to and from which state it is changing. Comparing this current to the
current that is yielded in the flux controlled case, this current can be lower at many points
of the switching operation. In fact it will only be equal in the lower value case. When we are
working in the flux controlled mode, the current can be as much high as 100 times the value
we used in the charge controlled mode.
Here, in our simulations, we did not take in account the electrical disruption or thermal
constraints of the used material, which could cause problems in real conditions, so we could
not say that this current is too high, or the other one is too low. We can say, though, is that
with the memristor’s dimensions in mind, the power dissipated over the area in the second
case, is extremely high, and would probably bring problems.
Despite the fact of the physical constraints the two modes used with the parameters
mentioned above, should differ significantly in the switching times, because what changes a
memristor’s state is the amount of current that flows through it, and here we are talking
about a huge difference between the two modes current.
What we have talked above is the main difference between the two programming modes.
It could be an advantage or a disadvantage depending on the case.
Other differences are for example the closed loop control of the value that is being stored,
if we want to store continuous values, or wait for the switching to complete, in order to start
another task. A voltage is easier to sense that a current, so the charge controlled mode wins
this battle.
28
Chapter 4
Memristor Memory Programing
In this chapter we will explain how we program a memristor, and how to build a memory
based on these devices.
4.1 Programmer
Now that we studied thoroughly the memristor, we should create a circuit that provide
us with a little abstraction on the reading and writing processes of a memristor.
On our agenda we have that we should prove that memristors can be used to store continu-
ous values, and not only the two binary states, as usual. So we should have this in mind when
creating our programmer. We should also be aware that we want to store voltage samples,
and what we can store are resistance values.
As said previously, to program a memristor, we can do one of two things. Apply a voltage,
or a current to the device. If we apply a current, we read a voltage that tells us the memristor’s
state. If we compare this value to the sample value that we want to store, we know if we
should stop the writing process or not. So we achieved our goal of having a method that
converts a voltage into a resistance value. In order to ensure consistency, we should make
sure that we always have the same current flowing through the device.
Now we are able to create a circuit that programs a continuous value on a memristor. We
just need a current source controlled by a comparator.
This is not all. We should also include the capability of reading a memristor’s state, and
to do so, as we saw earlier, we need to apply an alternating signal with a null mean value,
and ensure that the period isn’t in the same magnitude as the memristor’s switching time.
To do so, we should start by including two control bits, a ReadEn bit and a WriteEn bit, so
we can choose the correct programmer’s function. To include these bits we need a few logic
gates. We need an and gate to only care about the comparison when the WriteEn signal is
active, and then we need an or gate to actuate on the current source, whether we are writing
or reading.
But we haven’t assured yet that when we read, we do not destroy the stored value.
To accomplish that we should use another current source, with opposite direction than the
previous one, and when we read, we should alternate, with a fixed period, between them.
We need one Clock signal, in order to synchronize them. With this clock a few more logic
29
WriteEn
vcharge
− +
vin vsense
ReadEn
Clock
vclear
Clear
Iout
G1vcharge
G2vclear
Figure 4.1: Circuit used to program a memristor
WriteEn Comparator Programmed Output
0 X X 0
1 0 0 1
1 0 1 0
1 1 0 1
1 1 1 1
Table 4.1: Truth table for the writing process
gates come to our programmer. Now we should give the previous or gate the output of an
and operation between the ReadEn and Clock signals, while the new current source will be
actuated by the and between the ReadEn and the Clock’s complement.
Now that we are able to read and write on a memristor, what if we want to change its
value to another one? We should be able to clean the memristor’s state in order to start
a clean and controlled writing. To accomplish this we need another signal and another or
gate. We need a Clear signal that will actuate on the second current source, but this source
already is actuated by a gate output, so we have to put an or gate between this and and the
current source. This gate output should be the or comparison between the said and gate and
the Clear signal.
Analyzing the circuit there’s only one thing left. We should assure the writing start-up
conditions, because if the comparator output is 0, the writing process will not start. On the
other hand, if we implement a simple pull-up, we do not stop writing when we should.
Now the things get a little more complex than they were until now. To perform the start-
up, and the proper writing finish, we have to implement a function. This function should
respect the truth table in Table 4.1, that yields in the following equation. We used letters to
create a more compact equation, and W corresponds to WriteEn, C to Comparator and P
to Programmed.
30
Figure 4.2: Programmer’s input signal matched with memristor’s voltage
Output = (W · C · P ) + (W · C · P ) + (W · C · P ) (4.1)
Output = W · (C · P + C · P + C · P ) (4.2)
Output = W · (C · P + C · (P + P )) (4.3)
Output = W · (C · P + C) (4.4)
Output = W · C · P +W · C (4.5)
In order to implement this function, we substituted the and gate that operated between
the WriteEn and the comparator’s output for a few more logic gates. For the W · C · P
member, we choose to use two separate gates instead of just one with three inputs, so one
gate computes W ·C, and the other one computes the logic and between this output and P .
Then this output is the input to an or gate along with the output of another gate that solves
W · C.
To see if the memristor was already written or not, we used a simple level detector, that
resets itself when theWriteEn signal goes down. We apply the not logic function to the level
detector’s output, and supply it to the and gate that implements the second part of the first
member in the equation above.
To finalize this programmer the only thing that needs to be cleared is how the comparison
between the memristor’s voltage, and the desired voltage is achieved. It can be achieved by
a single operation amplifier, with open loop. To achieve the output that we assumed in the
31
0 2 4 6 8 10 120
0.5
1
Vin
Time (s)
Vo
lta
ge
 (V
)
0 2 4 6 8 10 120
2
4
WriteEn
Time (s)
Vo
lta
ge
 (V
)
0 2 4 6 8 10 120
2
4
Clear
Time (s)
Vo
lta
ge
 (V
)
0 2 4 6 8 10 120
2
4
ReadEn
Time (s)
Vo
lta
ge
 (V
)
Figure 4.3: Programmer’s test signals
truth table above, we need to take in account that when the memristor starts being written,
its resistance has the highest value possible, and in our configuration this means that the first
moment of vsense is always greater than vin. With this in mind we know that in order to
have a null output on the comparator, we should have the vsense on the + op-amp’s terminal,
while vin should be on the − one.
After having all this in mind, we designed the circuit in Figure’s 4.1. With this circuit we
can program a memristor, to store any value between RON and ROFF , as well as read any
value that is stored in it. We can also clear the memristor’s state.
The current sources values, G1 and G2, should be tuned to achieve the desired currents,
assuring that when a read cycle is done, the signal that flows through the device has no DC
component. To our first test we used 30.3µ for both, since the logic gates should have a
maximum output voltage of 3.3V , and we wanted a current of 100µA.
In order to prove what we explained before, we will run a set of simulations. The test
signals are the ones in Figure 4.3, and a clock signal at 100Hz, with a dutty-cycle of 50%,
which we don’t think necessary to show here.
If we analyze the voltage across the memristor during the test, and match it with the
input signal, we can see that the circuit behaves as expected, as shown in Figure 4.2.
Right now we will be explaining the time line present in the test (the signal’s form Fig-
ure 4.3), in order to understand it. The first thing we do, is clearing the memristor state, to
assure that there aren’t glitches during the programming stage. Following the erase of the
32
iin
A3 A2
0011
A1 A0
0000
1111
1100
− +
iin
vout
R/WEn
Figure 4.4: Analog Memory Array
memristor, we check that it is properly erased. At this point, we are sure that we have all
the conditions to perform a good and successful writing, we proceed to it, checking what has
been stored right after the writing process. We repeat this process three times.
It may come to mind a question. Why there is a negative voltage in the output, when
we only have positive voltages? The answer is simple. As we have to reset the memristor to
ensure a proper writing, we have to make flow a current through it in the opposite direction,
hence the negative voltage.
4.2 Memory
Given that we can now program a memristor easily, we can now think of scaling from on
memristor to a lot of them.
33
The memristor’s implementation makes it easy to create crossbars arrays1, that the mem-
ristors are on the junctions between the lines and rows of a memory array.
What we are explaining can easily be understood on Figure 4.4, where we have the crossbar
architecture, with a line and row address decoder.
In Figure 4.4 we have a little programmer’s detail that we don’t explained before. In the
previous section we said that we compared the memristor’s voltage against a reference, but
the memristor’s voltage was supposedly measured on the same terminal that is used to output
the current. That was true if we were programming a single memristor, and that’s not the
case here.
Here we have a circuit that calculates the amount of voltage that is dropped on the lines
and rows address decoder, in order to assure us that we don’t make any errors during the
reading or writing cycles.
The lithography process of making a memristor crossbar array makes it possible, and easy,
to stack several layers of crossbars arrays, creating an incredibly dense non-volatile memory.
If we consider the fact that each memory cell, can store a multi-level, or even continuous,
value, this yields in an unprecedented level of denseness.
With such a level of denseness, it is possible to think of using such quantity of memristors
to not only store values, but use them for other purposes, like the ones talked in Chapter 2.
1Actually the memristors were found when they were trying to implement a crossbar resistive memory, that
would save a lot of space when comparing to a transistorized one.
34
Chapter 5
Linear Combinations
On this chapter we will verify if it is possible to perform linear combinations on the fly,
using memristors, and if so, provide some examples of it.
5.1 Operation
A linear combination is a widely used operation, with the following form
f = a1b1 + a2b2 + . . .+ anbn (5.1)
When we use this operation in electronics, we say that bi are the inputs, and ai are weights
of that inputs.
If we have the following equation,
vo(t) = 2v1(t) + 0.5v2(t) + 5v3(t) (5.2)
this means that vo(t) will be a linear combination of the inputs, being that the inputs will
weigh differently on the output, as it can be seen easily by the equation.
Here we intend to implement this operation quickly enough that it only takes the sampling
time to perform the entire operation.
5.2 Simple Implementation Test
If we want to implement a linear combination in hardware, we can use a basic operational
amplifier configuration, called summer. This configuration is the one depicted in Figure 5.1,
and its transfer function, is given by:
−
+
R1
vo
R2
v1
R3
v2
Figure 5.1: Operational Amplifier Summer Configuration
35
vo =
−R1
R2
v1 +
−R1
R3
v2 (5.3)
It is important to note that in this case the weights are the resistors ratio. If we want to
perform this operation on-the-fly, we should be able to define those weights, on-the-fly also,
which was not possible until we have programable resistors. Now that we have them, we
should see if this can actually be accomplished.
To do so we start by testing that memristors can be used to implement a linear combiner,
without suffering from any problem, be it the fluctuation of the state, or some non-linearity
that is transmitted to the output of the system.
In order to try to maintain the memristor’s state unaltered, we should work at frequencies
that are above the limit where the memristance mechanism works. On our tests we used
10kHz, and with our model that proved to be sufficient. It is also important to recall that
the minus signs in the equation, will only affect the output’s signal phase.
For the first test we used a simple summer configuration, with 4 memristors, that were
previously initiated with the desired resistance, to achieve the wished weight for that branch.
The circuit used was the one presented in the Figure 5.2.
−
+
R1
vo
M1v1
M2v2
M3v3
M4v4
Figure 5.2: Linear Combinator Circuit
Using this circuit, with memristor’s values of 500Ω, 2kΩ, 1kΩ and 750Ω, fromM1 through
M4 respectively, and R1 assuming the value of 1kΩ, we expect the output to be the following
linear combination of the inputs.
vo = −2v1 −
v2
2
− v3 −
4
3
v4 (5.4)
If we apply the following voltage sequences to this circuit,
v1 = [1.2 2.0 0.7 1.0 2.5] (5.5)
v2 = [3.0 1.0 4.0 0.6 2.0] (5.6)
v3 = [1.5 0.3 1.5 1.0 0.2] (5.7)
v4 = [1.5 1.2 0.5 3.0 1.7] (5.8)
we expect the following sequence in the output, that is also represented in Figure 5.3, for
better comparison of the result.
v0 = [7.4 6.4 5.6 7.3 8.4] (5.9)
36
0 1 2 3 4 5
x 10−3
−10
−5
0
5
10
Time (s)
Vo
lta
ge
 (V
)
Figure 5.3: Linear Combinator Circuit
Expected Output
0 1 2 3 4 5
x 10−3
−10
−5
0
5
10
Time (s)
Vo
lta
ge
 (V
)
Figure 5.4: Linear Combinator Circuit
Simulated Output
In these conditions we obtained the output represented in Figure 5.4, that is exactly what
we expected, including the phase inversion of the signal.
With this implementation, we can only make one sign operations, we cannot add one pair
of coefficients and subtract the others or vice-versa. In order to try and workaround this
limitation, we implemented another circuit, the one shown in Figure 5.5.
−
+
A1
R1
vo
M1v1
M2v2
M3v3
R2−
+
A2
R3
M4v4
M5v5
M6v6
Figure 5.5: Second Approach Linear Combinator Circuit
In this circuit, the inputs from v1 to v3 suffer from an inversion of phase, while the inputs
v4 to v6 don’t suffer any change in its phase. The rest of the circuit behavior is exactly like
the one explained before.
One thing that must be taken in account is the R1, R2 resistor’s ratio, since this is
important on how the amplifier’s A2 signal is transmitted to the output. It represents the
weight of the circuit attached to A2.
If the memristor’s state is initialized in order to obtain the resistance of 2kΩ, 3kΩ, 1kΩ,
800Ω, 3kΩ and 7.2kΩ for memristors M1 through M6, and the resistors have the values of
1kΩ, 1kΩ and 3kΩ respectively, we expect the output to be
vo = −
v1
2
−
v2
3
− v3 +
15
4
v4 + v5 +
5
12
v6 (5.10)
In order to make a simple test, like we did for the first case, we are going to use the
following values for the inputs
37
v1 = [1.2 2.0 0.7 1.0 2.5] (5.11)
v2 = [3.0 1.0 4.0 0.6 2.0] (5.12)
v3 = [1.5 0.3 1.5 1.0 0.2] (5.13)
v4 = [1.5 1.2 0.1 3.0 1.7] (5.14)
v5 = [0.5 1.8 0.5 0.3 0.8] (5.15)
v6 = [2.3 0.7 2.6 1.4 1.3] (5.16)
so we expect the sequence that is shown in Figure 5.6 and below, in the output
v0 = [4.0 5.0 −1.2 10.4 5.6] (5.17)
0 1 2 3 4 5
x 10−3
−15
−10
−5
0
5
10
15
Time (s)
Vo
lta
ge
 (V
)
Figure 5.6: Linear Combinator Circuit
Expected Output
0 1 2 3 4 5
x 10−3
−15
−10
−5
0
5
10
15
Time (s)
Vo
lta
ge
 (V
)
Figure 5.7: Linear Combinator Circuit
Simulated Output
We should be aware that since we are working with alternate current, a perfect synchro-
nization of the input signals is mandatory, in order to ensure that there are no miscalculations
at any point during the operation.
After we ensure this fact, if we analyze the expected output values, we can see that
one value has a different polarity than the others. This is seen in the output results, both
theoretical and simulation, when the signal makes a phase change of half wave.
This circuit has yet another limitation. We cannot change a coefficient form positive to
negative and vice-versa. We are stuck with one of these two parts.
5.3 Changing Coefficients on-the-fly
Being proved that linear combinations can be performed in hardware, now we should
prove our point. To prove our point we should change the circuit depicted in Figure 5.2, in
order to support memristor’s programming.
To do so, we have combined that circuit with the one from Figure 4.1, which was properly
encapsulated to simplify this schematic, and a few more components to create the circuit of
Figure 5.8.
38
−+
R1
vo
M1
v1
M2
v2
M3
v3
M4
v4
Prog
Dec
A0
A1
vin Clear
WriteEn
VDD
GND
vsense
Iout
Clock
ReadEn
vin
Clear
WriteEn
VDD
GND
B1
B0
O0
O1
O2
O3
Figure 5.8: Linear Combinator Circuit, for changing the coefficients on-the-fly
With this circuit we should be able to configure the memristor’s state, and thus change
its weight on the operation. To test this, we will use the following weights, respectively, from
M1 through M4, 2500Ω, 4kΩ, 3200Ω and 1500Ω. The feedback resistor, R1, has the value of
1kΩ. To the inputs we will apply 1.5V , 1V , 2 and 0.6V from v1 to v4 accordingly.
With this setup we will have the following equation
vo = −
2
5
v1 −
1
4
v2 −
5
16
v3 −
2
3
v4 (5.18)
Which yields a vo = −1.875V . We should have in mind that we expect this value with
ideal conditions.
When we look at the circuit, and look for points where we expect that will not behave
ideally, we find a few components, with the control switches being the most relevant ones.
On our simulation, we defined the switches as having an off state resistance of 1MΩ,
and an on resistance of 1Ω. With this in mind we can see that with a memristor being
programmed, we have its resistance in parallel with 3 “resistors” with a resistance high enough
that the current drained by them should be irrelevant.
This is the normal assumption on similar cases, but here we should have in mind the
memristor programming stop conditions. The memristor should stop programming when we
reach a certain voltage level, when a pre-determined current flows through it. When we have
some resistors in parallel with the memristor, some current of the pre-determined one, will
not flow through the device, therefore creating an error on the voltage that is being read.
39
If we assumed that with a certain current, we should expect a corresponding voltage, in
order to know the resistance state of the device. If we change the current value, we change
the read voltage, thus changing the resistance final value.
Let’s try and see what is the error that we should expect. If we plan to program the
memristors M1 through M4 with the resistances of 2500Ω,4kΩ, 3200Ω and 1500Ω, with the
programmer sourcing 200µA to the circuit, the stop conditions for the programming are when
we reach 0.5V , 0.8V , 0.64V and 0.3V , from M1 through M4, respectively.
We expect that the voltage at M1 memristor’s terminals should be
200µA =
v
2500Ω
+
3v
1MΩ
(5.19)
since we know the final voltage and the real current value 1, and we are trying to discover
the real resistance, we can solve the following equation
61
µA
V
× 3.3V =
0.5V
M1
+
3× 0.5V
1MΩ
(5.20)
M1 =
0.5V
61µA
V
× 3.3V − 3×0.5V
1MΩ
(5.21)
And we get a resistance value of 2502.5Ω. Applying this calculations to the other mem-
ristors we have 4022.1Ω, 3210Ω and 1497Ω from M2 to M4 correspondingly.
Rewriting Equation 5.18, we have
vo = −
1kΩ
2502.5Ω
v1 −
1kΩ
4022.1Ω
v2 −
1kΩ
3210Ω
v3 −
1kΩ
1497Ω
v4 (5.22)
If we use the above input voltage values we get the value of −1.8719V for vo. When we com-
pare this value to results we obtained from the simulation, and feed them to MATLAB R© and
then run the following command, that is the value that we get (remember that we are working
with AC, with none DC component, so the values we are talking are both positive and nega-
tive, and they are symmetrical too ). The results from the simulation are shown in Figure 5.9,
where we can see all programming cycles of the four memristors, and the computed result.
Then in Figure 5.10 we have a figure that focus the operation computation.
>> max(Vout(:))
ans =
1.8721
>>
We didn’t got a perfect match for the expected value, but this doesn’t mean that what
we tried isn’t possible. It only means that we didn’t considered some fact. And the value
difference is so small that it can be the result of a lack of precision on the simulation results.
1We used a trans-conductance gain of 61µA
V
over a voltage of 3.3V
40
0 5 10 15 20 25−2
−1.5
−1
−0.5
0
0.5
1
1.5
2
Time (s)
Vo
lta
ge
 (V
)
Figure 5.9: Simulated output of the programable linear combiner
20 20.02 20.04 20.06 20.08 20.1−2
−1.5
−1
−0.5
0
0.5
1
1.5
2
Time (s)
Vo
lta
ge
 (V
)
Figure 5.10: Simulated output of the programable linear combiner (focus on the operation)
41
42
Chapter 6
Conclusion & Future Work
The main goal of this thesis work, was achieved, as explained in Chapter 5, more precisely
in Section 5.3.
With our point proved, we can now move on and try to implement what we discussed in
Section 1.1, and Section 2.3, or we can move on and develop what we will talk below.
While we proved our point, we also provided an abstraction of the physical characteristics
of a memristor, when it comes to writing or reading it.
This thesis introduces a new working area, an area that will have to be developed from
ground up.
To do so, the first thing that must be done is creating a new memristor model. The
model presented here is ideal, and does not have the capability of show us the size, power
and material’s interference in the memristance effect. It would be needed that the created
model would work like a memristor simulator itself, giving him the desired parameters like
the height, width and depth, the conductor’s dimensions and so on, and then the model gives
us back the detailed information about its state, temperature across the device, etc.. Some
pertinent literature on this matter, was published recently [12].
Another ground work that can, and should, be done is a new programmer. A programmer
that does not need the clearing step before writing, and that doesn’t need an external clock
signal to perform safe readings. Maybe even create a programmer that uses voltage and senses
current.
Another interesting work would be to implement the basic boolean logic functions, in
order to provide a good background to CMOS replacement and start some new reconfigurable
electronic paradigms. A starting point would be [11] and [13].
After this step a fully memristorized memory could be implemented. For fully memris-
torized memory we understand a memory that uses memristors to store the pretended data,
and uses memristors to create the memory control (row and line decoders).
Now that we are talking in memories, a multi-level memory should also be created, i.e.,
a memory that would store one of various levels on a single cell. And this could be taken
seriously, and to some noise critical applications, such as audio, the number of levels could
be infinite, this means, continuous.
43
Here we arrive at the point where we talk about the future development of the main goal of
this thesis. It should be created a circuit that somehow simplifies the process of programing
the memristors and then perform a linear combination, that enables this and at the same
time provides a good abstraction in order to be scalable. We should also be aware of the
limitation mentioned before, in Section 5.2, of a coefficient only can behave as positive or
negative at a time, depending to what operational amplifier it is connected, and provide a
simple workaround for it.
When the previous goal is achieved, it will be easy to connect several of those circuits in
order to perform a meaningful operation, be it a simple signal filter, or an artificial neural
network.
Until now we talked about ground work. When this work is done, we have good layer of
abstraction to start creating some good products on top of it, and some novel applications
also.
After we have all these tools, we can integrate them in a manner to simulate an artificial
brain, with areas to store information, areas to process information from the “senses”, and
areas to perform logic operations, using mainly memristors. That respects one of the basic
laws of artificial intelligence, the one that says that the delay between the input and output
of a system should not be greater than the propagation time.
Talking in novel applications, we can think in a system that encrypts/decrypts high speed
transmissions, like the ones used in optic fiber connections. Instant-on computational systems.
Improved and quicker beamforming solutions.
44
Bibliography
[1] CHUA. Memristor - The Missing Circuit Element. IEEE Transactions on Circuit Theory
(1971) vol. ct-18 (5) pp. 507 – 519
[2] Williams. How We Found The Missing Memristor. Spectrum, IEEE (2008) vol. 45 (12)
pp. 28 – 35
[3] Strukov et al. The missing memristor found. Nature (2008) vol. 453 (7191) pp. 80-83
[4] Biolek et al. SPICE Model of Memristor with Nonlinear Dopant Drift. Radioengineering
(2009) vol. 18 (2) pp. 210 – 214
[5] Kavehei et al. The fourth element: Insights into the memristor. International Conference
on Communications, Circuits and Systems (2009) pp. 921 – 927
[6] Chua and Sung Mo Kang;. Memristive devices and systems. Proceedings of the IEEE
(1976) vol. 64 (2) pp. 209 – 223
[7] http://www.memristor.org/reference/295/types-of-memristors on May, 14th of 2010
[8] Widrow et al. Birth, Life, and Death in Microelectronic Systems. Military Electronics,
IRE Transactions on (1961) vol. MIL-5 (3) pp. 191 – 201
[9] Argall. Switching Phenomena in Titanium Oxide Thin Films. Solid-State Electronics
(1968) vol. 11, pp. 535 – 541
[10] Borghetti et al. ‘Memristive’ switches enable ‘stateful’ logic operations via material im-
plication. Nature (2010)
[11] Raja and Mourad. Digital Logic Implementation in Memristor-Based Crossbars - A Tuto-
rial. Electronic Design, Test and Application, 2010. DELTA ’10. Fifth IEEE International
Symposium on (2010) pp. 303 - 309
[12] J. P. Strachan, D. B. Strukov, J. Borghetti, J. Joshua Yang, G. Medeiros-Ribeiro, and
R. Stanley Williams, “The switching location of a bipolar memristor: chemical, thermal
and structural mapping,” Nanotechnology, vol. 22, no. 25, p. 254015, May. 2011.
[13] T. Raja and S. Mourad, “Digital Logic Implementation in Memristor-based Crossbars”
in 2009 International Conference on Communications, Circuits and Systems (ICCCAS),
2009, pp. 939–943.
[14] E. Nedaaee Oskoee and M. Sahimi, “Electric currents in networks of interconnected
memristors,” Physical Review E, vol. 83, no. 3, Mar. 2011.
45
[15] H. Yan et al., “Programmable nanowire circuits for nanoprocessors,” Nature, vol. 470,
no. 7333, pp. 240–244, Feb. 2011.
[16] K. Eshraghian, K. R. Cho, O. Kavehei, S.-K. Kang, D. Abbott, and S.-M. S. Kang,
“Memristor MOS Content Addressable Memory (MCAM): Hybrid Architecture for Fu-
ture High Performance Search Engines,” arXiv, vol. cond-mat.mes-hall. 11-May-2010.
[17] S. Shin, K. Kim, and S. Kang, “Memristor Applications For Programmable Analog ICs,”
Nanotechnology, IEEE Transactions on, vol. PP, no. 99, pp. 1–1, 2010.
[18] D. Strukov and A. Mishchenko, Monolithically stackable hybrid FPGA. European Design
and Automation Association, 2010, pp. 661–666.
[19] S. H. Jo, T. Chang, I. Ebong, B. B. Bhadviya, P. Mazumder, and W. Lu, “Nanoscale
Memristor Device as Synapse in Neuromorphic Systems,” Nano Letters, vol. 10, no. 4,
pp. 1297–1301, 2010.
[20] S. Chaudhuri, W. Zhao, J.-O. Klein, C. Chappert, and P. Mazoyer, “Design of Embedded
MRAM Macros for Memory-in-Logic Applications,” Great Lakes Symposium on VLSI,
Proceedings of the 20th symposium on Great lakes symposium on VLS, pp. 155–158,
2010.
[21] H. Kim, M. P. Sah, C. Yang, and L. O. Chua, “Memristor-based Multilevel Memory” in
2010 12th International Workshop on Cellular Nanoscale Networks and their Applications
(CNNA 2010), 2010, pp. 1–6.
[22] Y. V. Pershin and M. Di Ventra, “Experimental demonstration of associative memory
with memristive neural networks,” Neural Networks, vol. 23, no. 7, pp. 881–886, 2010.
[23] T. A. Wey and W. D. Jemison, “An automatic gain control circuit with TiO2 memristor
variable gain amplifier,” 2010 8th IEEE International NEWCAS Conference (NEWCAS),
pp. 49–52, 2010.
[24] M. Stork, J. Hrusak, and D. Mayer, “Feedback systems with memristors,” ELECO 2009.
International Conference on Electrical and Electronics Engineering, 2009., pp. II–58 –
II–62, Nov. 2009.
[25] J. Borghetti et al., “A hybrid nanomemristor/transistor logic circuit capable of self-
programming,” Proceedings of the National Academy of Sciences of the United States of
America, vol. 106, no. 6, pp. 1699–1703, 2009.
[26] D. L. Lewis and H.-H. S. Lee, “Architectural evaluation of 3D stacked RRAM caches,”
in 2009 IEEE International Conference on 3D System Integration (3DIC), 2009, pp. 1–4.
46
