Modeling and Implementation of HfO2-based Ferroelectric Tunnel Junctions by Pringle, Spencer Allen








Follow this and additional works at: https://scholarworks.rit.edu/theses
This Thesis is brought to you for free and open access by the Thesis/Dissertation Collections at RIT Scholar Works. It has been accepted for inclusion
in Theses by an authorized administrator of RIT Scholar Works. For more information, please contact ritscholarworks@rit.edu.
Recommended Citation
Pringle, Spencer Allen, "Modeling and Implementation of HfO2-based Ferroelectric Tunnel Junctions" (2017). Thesis. Rochester
Institute of Technology. Accessed from
Modeling and Implementation of HfO2-based
Ferroelectric Tunnel Junctions
Spencer Allen Pringle










Department of Electrical and Microelectronic Engineering




We, the undersigned committee members, certify that Spencer Pringle has completed the
requirements for the Master of Science degree in Microelectronic Engineering.
Dr. Santosh Kurinec Advisor Date
Professor, Microelectronic Engineering
Dr. Dhireesha Kudithipudi Date
Professor, Computer Engineering
Mr. Mark Indovina Date
Lecturer, Electrical Engineering
Dr. Robert Pearson Date
Programs Director, Microelectronic Engineering
Dr. Sohail Dianat Date
Dept. Head, Kate Gleason College of Engineering
i
Acknowledgments
The author would like to thank Dr. Santosh Kurinec for being consistently helpful,
encouraging, and supportive throughout the completion of this work. Her helpful
advice and fruitful discussions of quantum mechanics were always productive. Huge
thanks to Mr. Mark Indovina for assitance implementing address systems and other
system design. Many thanks to Dr. Dhireesha Kudithipudi for help learning and
understanding the implementation of FTJ devices in neuromorphic systems and the
many applications of such architectures. Also, many thanks to NamLAB and the
University of California, Berkeley, for agreeing to deposit their own ferroelectric films
for further implementation and testing of ferroelectric tunnel junctions.
This work was supported in part by the National Science Foundation, Grant#
ECCS-1541090. Any opinions, findings, and conclusions or recommendations ex-
pressed in this material are those of the author and do not necessarily reflect the
views of the National Science Foundation.
Thanks to Dr. Pearson for consistent departmental help and process knowledge.
Lastly, the staff of engineers and technicians working at the Semiconductor & Mi-
crosystems Fabrication Laboratory (SMFL) at RIT are some of the most helpful,
hardworking, caring, and exceptional people I’ve ever had the priviledge to work
with. Thank you all so much for being incredible.
ii
I would like to dedicate this work to my mother, Sharon Allen Pringle. Without your
encouragement and help, none of this would have been possible. You’re my




HfO2-based ferroelectric tunnel junctions (FTJs) represent a unique opportunity as
both a next-generation digital non-volatile memory and as synapse devices in brain-
inspired logic systems, owing to their higher reliability compared to filamentary
resistive random-access memory (ReRAM) and higher speed and lower power con-
sumption compared to competing devices, including phase-change memory (PCM)
and state-of-the-art FTJ. Ferroelectrics are often easier to deposit and have simpler
material structure than films for magnetic tunnel junctions (MTJs). Ferroelectric
HfO2 also enables complementary metal-oxide-semiconductor (CMOS) compatibility,
since lead zirconate titanate (PZT) and BaTiO3-based FTJs often are not.
No other groups have yet demonstrated a HfO2-based FTJ (to best of the author’s
knowledge) or applied it to a suitable system. For such devices to be useful, system
designers require models based on both theoretical physical analysis and experimental
results of fabricated devices in order to confidently design control systems. Both the
CMOS circuitry and FTJs must then be designed in layout and fabricated on the
same die.
This work includes modeling of proposed device structures using a custom python
script, which calculates theoretical potential barrier heights as a function of material
properties and corresponding current densities (ranging from 8×103 to 3×10−2 A/cm2
with RHRS/RLRS ranging from 5×105 to 6, depending on ferroelectric thickness).
These equations were then combined with polynomial fits of experimental timing data
and implemented in a Verilog-A behavioral analog model in Cadence Virtuoso. The
author proposes tristate CMOS control systems, and circuits, for implementation of
FTJ devices as digital memory and presents simulated performance. Finally, a process
flow for fabrication of FTJ devices with CMOS is presented. This work has therefore
enabled the fabrication of FTJ devices at RIT and the continued investigation of





Table of Contents v
List of Figures viii
List of Tables xi
List of Symbols xii
1 Introduction 1
1.1 Research objectives . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2
1.2 Thesis organization . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2
1.3 Neuromorphic Computing with Memristors, ReRAM . . . . . . . . . 4
1.4 Using Ferroelectric Tunnel Junctions . . . . . . . . . . . . . . . . . . 5
2 Physics of Ferroelectric Materials 6
2.1 Crystal structure . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 6
2.2 Polarization in ferroelectrics and dielectrics . . . . . . . . . . . . . . . 7
2.3 Non-intrinsic ferroelectrics . . . . . . . . . . . . . . . . . . . . . . . . 8
2.4 Ferroelectric domains . . . . . . . . . . . . . . . . . . . . . . . . . . . 9
2.5 Area-dependent effects . . . . . . . . . . . . . . . . . . . . . . . . . . 9
3 Brief History and Applications of FTJ Implementations 11
3.1 Early memory using large-dimension PZT . . . . . . . . . . . . . . . 11
3.2 More recent implementations with BaTiO3 . . . . . . . . . . . . . . . 11
3.3 Applications of FTJs . . . . . . . . . . . . . . . . . . . . . . . . . . . 13
3.4 Alternative technologies . . . . . . . . . . . . . . . . . . . . . . . . . 14
3.4.1 Filamentary ReRAM . . . . . . . . . . . . . . . . . . . . . . . 14
3.4.2 Magnetic tunnel junctions . . . . . . . . . . . . . . . . . . . . 15
3.4.3 Phase-change memory . . . . . . . . . . . . . . . . . . . . . . 15
v
CONTENTS
4 Analysis of M1-Fe-M2 Structure 17
4.1 Band structure in the absence of polarization field . . . . . . . . . . . 17
4.2 Band structure under polarization . . . . . . . . . . . . . . . . . . . . 18
4.3 Extraction of tunnel Current and (by extension) resistance states . . 21
5 Design of Ferroelectric HfO2-based FTJs and Integration with CMOS
Process 23
5.1 FTJ design . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 23
5.2 State of the art FTJs . . . . . . . . . . . . . . . . . . . . . . . . . . . 26
5.3 Designed CMOS-process with FTJ-fabrication steps . . . . . . . . . . 28
5.4 Process simulation . . . . . . . . . . . . . . . . . . . . . . . . . . . . 36
6 System Design and Simulations for Digital Memory Applications 38
6.1 Read/Write scheme . . . . . . . . . . . . . . . . . . . . . . . . . . . . 38
6.2 Linear resistance change simulation . . . . . . . . . . . . . . . . . . . 40
6.3 Timing-based simulation . . . . . . . . . . . . . . . . . . . . . . . . . 41
6.4 Address systems . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 43
6.5 Simulation results - 4×4 Array . . . . . . . . . . . . . . . . . . . . . . 45
7 Conclusions 50
7.1 Future Work . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 51
A Python Program Code 59
A.1 Core Code . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 59
A.2 GUI Code . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 78
B Partial Process - FTJ-devices only 90
C Athena code 93
D sap1951 FTJ THESIS 45 97
D.1 Linear Resistance FTJ Model . . . . . . . . . . . . . . . . . . . . . . 97
D.1.1 Verilog Model . . . . . . . . . . . . . . . . . . . . . . . . . . . 98
D.2 Polarization-Timing FTJ Model . . . . . . . . . . . . . . . . . . . . . 101
D.2.1 Verilog Model . . . . . . . . . . . . . . . . . . . . . . . . . . . 102
D.3 SAP ADDRESS COLUMN R . . . . . . . . . . . . . . . . . . . . . . 115
D.4 SAP ADDRESS COLUMN W . . . . . . . . . . . . . . . . . . . . . . 118
D.5 SAP ADDRESS ROW R . . . . . . . . . . . . . . . . . . . . . . . . . 121
vi
CONTENTS
D.6 SAP ADDRESS ROW W . . . . . . . . . . . . . . . . . . . . . . . . 124
D.7 SAP ADDRESS GND vcc . . . . . . . . . . . . . . . . . . . . . . . . 127
D.8 SAP FTJ DIGITAL LOW 4 x 4 . . . . . . . . . . . . . . . . . . . . . 130
D.9 SAP TRISTATE MEM 4x vcc . . . . . . . . . . . . . . . . . . . . . . 132
D.10 SAP TRISTATE MEM 4x TESTBENCH . . . . . . . . . . . . . . . 134
D.10.1 Verilog Model . . . . . . . . . . . . . . . . . . . . . . . . . . . 135
vii
List of Figures
1.1 Diagram representation of the dependencies of various implementation
stages of the technology presented in this thesis. . . . . . . . . . . . . 3
2.1 Ferroelectric polarization (a) and weak magnetic moment (b) of multi-
ferroic Bi2NiMnO6 at 7K, from Shimakawa et. al [1]. The red line on
(a) is what this plot would look like for a perfect dielectric. . . . . . . 7
2.2 Simple representation of the atomic structures of a ferroelectric as its
prototype phase (left) relaxes into one of two polar phases (middle and
right) after the application of an external field. A ferroelectric would
remain in the corresponding state even after the removal of Eapp, while
a dielectric would deflect (as shown) during stimulus application but
relax to the non-polar phase (left) once that field was removed. . . . . 7
2.3 Simple diagram of domains in a model ferroelectric film. . . . . . . . 9
3.1 ”Bender memory” schematic from [2]. This 8-bit device stores data
as remanent polarization in the top-most ferroelectric material. Write
pulse is ≈ 1 ms of 20-30 V/mil. . . . . . . . . . . . . . . . . . . . . . 12
3.2 Performance of FTJs for (a) fresh device with PZT ferroelectric and
(b) device with BaTiO3 ferroelectric after -1.2V priming pulse, taken
from Contreras et. al [3]. . . . . . . . . . . . . . . . . . . . . . . . . . 13
3.3 Simple diagram of (left) a physical model of neurons and synapses, the
brain’s computation devices, and (right) their electronic implementa-
tion in a typical brain-inspired computing system. . . . . . . . . . . . 15
4.1 The energy band diagram of an metal-insulator-metal (MIM) with a 2
nm thick insulator with Ea = 2 eV and metals having χ1 = 4.08 eV,
χ2 = 4.85 eV, normalized to the fermi energy. . . . . . . . . . . . . . 18
4.2 The Fowler-Nordheim tunneling current of an MIM with material prop-
erties listed in Section 4.1. . . . . . . . . . . . . . . . . . . . . . . . . 19
4.3 (a) Diagram of charge densities created for left polarized ferroelectric
and (b) corresponding generated potentials across an FTJ, having elec-
trodes with dissimilar screening lengths, from Zhuravlev et. al [4]. . . 20
viii
LIST OF FIGURES
4.4 The energy band diagrams, at V = 0, of an FTJ with material prop-
erties given in Section 4.2, for positive (towards electrode 1 (M1)) and
negative (towards electrode 2 (M2)) polarization. . . . . . . . . . . . 21
4.5 The Fowler-Nordheim tunneling current of an FTJ with material prop-
erties consistent with those used in Figure 4.4, showing a memory win-
dow HRS/LRS ≈ 2.3. . . . . . . . . . . . . . . . . . . . . . . . . . . 22
5.1 Simulated HRS/LRS increases with larger screening length ratio before
plateauing around δ2
δ1
≈ 60. For an Al/Al:HfO2/p+ Si FTJ with 2 nm
ferroelectric. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 24
5.2 Simulated HRS/LRS for increasing δ1, showing a maximum. For an
Al/Al:HfO2/p+ Si FTJ with 2 nm ferroelectric. . . . . . . . . . . . . 25
5.3 Simulated HRS/LRS and HRS resistivity for an Al/Al:HfO2/p+ Si
FTJ with varying ferroelectric thickness. . . . . . . . . . . . . . . . . 25
5.4 Athena simulation of CMOS devices tuned for low threshold voltages
(left) and FTJ device (right). . . . . . . . . . . . . . . . . . . . . . . 36
5.5 Athena simulation of FTJ device (SiO2 substitued for ferroelectric). . 37
5.6 Zoom of FTJ device showing ≈ 250 nm device width. . . . . . . . . . 37
6.1 An address scheme which, though appropriate for a stand-alone device,
would be inappropriate for devices in an array. . . . . . . . . . . . . . 39
6.2 A simple schematic showing the typical connectivity of FTJ devices in
an array, for both memory or neuromorphic logic applications. Lines
and columns only connect through FTJ devices and do not connect at
intersections. Dotted lines indicate an arbitrary number of repeated
lines and columns. . . . . . . . . . . . . . . . . . . . . . . . . . . . . 39
6.3 An address scheme appropriate for FTJs in an array. . . . . . . . . . 40
6.4 Non-addressed devices in the same row, for various write/read states.
Non-addressed devices in the same column would experience the op-
posite bias. In this way, these devices will not be disturbed. . . . . . 40
6.5 Changing polarization as a function of time for varying applied voltages
for a sample with Vc ≈ 0.9 V. . . . . . . . . . . . . . . . . . . . . . . 42
6.6 Changing polarization as a function of time binned for domains existing
in 0.2V intervals for a sample with Vc ≈ 0.9 V. Only a subset of curves
are plotted. The models work best when binned from 0.2V to 3V in
0.2V intervals. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 43
ix
LIST OF FIGURES
6.7 Maximum polarization for domains binned to 0.2V intervals, resem-
bling a noisy normal distribution with a long right-sided tail. . . . . . 44
6.8 Time until polarization saturation for domains binned to 0.2V inter-
vals. Higher energy domains (oriented less parallel to the applied field)
switch faster due to excess energy. . . . . . . . . . . . . . . . . . . . . 45
6.9 Schematic of address systems connected to a single FTJ. Note the in-
verted output taken above the reference resistor and the pass transistor
to bypass that resistor while writing and applying vcc. The FTJ simu-
lates with a low resistance state (LRS) of 300 KΩ and high resistance
state (HRS) of 10 MΩ. The reference resistor is 2 MΩ. . . . . . . . . 47
6.10 Simulation results from a single FTJ device connected to address cir-
cuitry designed with 45 nm CMOS. Wen〈1〉 follows the same curve as
Wen〈2〉 in this simulation. Notice that the output, Y, transitions low
when reading (Ren high) an FTJ in LRS and transitions high when
reading an HRS FTJ. Write and read times are 10 ns. . . . . . . . . . 48
6.11 Simulation results from a single FTJ device connected to address cir-
cuitry designed with 45 nm CMOS. Wen〈1〉 is constantly off in this sim-
ulation; testing for write disturb when programming a different device
in the same row, once in an array. The FTJ state remains unchanged
even after write enable toggles for high and low writes, verifying that
this system is robust against write disturbs of non-addressed devices. 48
6.12 Small portion of waveform while writing binary 0 to 15 in one row
while all other FTJ in the 4×4 array are in HRS. . . . . . . . . . . . 49
6.13 Waveform and simulation log for random binary numbers being written
to random rows of the 4×4 array. . . . . . . . . . . . . . . . . . . . . 49
x
List of Tables
3.1 Performance of alternative technologies compiled from various sources.
MTJ values from Aziz et. al and Lee et. al. [5,6], all other from Ebong
et. al. and Kim [7,8] unless otherwise referenced in table. . . . . . . . 14
5.1 Tables comparing relevant performance data for this research work to
state of the art FTJs. LSMO stands for LaxSr1−xMnO3 and CCMO
is Ca0.96Ce0.04MnO3. Area units are µm
2. Pd is surface power density
and Pr is remanent polarization in (µC/cm





Pr Remanent polarization µC/cm
2
tsat Saturation time s
tpdf Propagation delay falling s
tpdr Propagation delay rising s
tf Fall time s
tr Rise time s
σp Polarization surface charge density (in ferroelectric) µC/cm
2
σs Screening charge density (in electrode) µC/cm
2
E Electric field V/cm
Ec Coercive electric field of ferroelectric V/cm
Vc Coercive voltage of ferroelectric film V
V Applied voltage V
d Thickness of ferroelectric nm
δx Screening length in electrode ”x” nm
Ec Energy at the conduction band edge eV
Ev Energy at the valence band edge eV
EF Fermi level eV
Eg Band gap energy eV
χx Work function of metal ”x” eV
Ea Electron affinity of dielectric eV
ψ Potential eV
kB Boltzmann’s constant 8.617×10−5 eV/K
Jtun Fowler-nordheim tunneling current density A/cm
2
Jth Thermionic emission current density A/cm
2
ψ¯ Average potential barrier eV
ψ′ Maximum potential barrier eV
m∗ Electron effective mass kg
me Electron rest mass 9.11×10−31 kg
NA Acceptor concentration cm
−3




Nx Carrier concentration (of appropriate type) cm
−3
c0 Atomic density cm
−3
VDD Write voltage high rail V
VSS Write voltage low rail V
vdda Read voltage high rail V
vssa Read voltage low rail V
gnd 0V, ground V
q Elementary charge 1.602× 10−19 C
T Temperature K
ε0 Vacuum permittivity 8.854×10−14 F/cm
εf Ferroelectric permittivity F/cm




Traditional CMOS devices are reaching fundamental physical limits of scaling and
nonvolatile memory devices based on charge-storage are no longer meeting require-
ments for future high-speed systems [9–12]. In addition, the trend towards portable
computers, smart phones, health telemetry, and smart building integration has re-
newed desire for ultra-low-power devices [13]. Neuromorphic computing (NMC) sys-
tems show huge potential to enable such power performance; taking inspiration from
information processing in electro-chemical biological systems (specifically the brain)
and emulating or reproducing that operation using electronic devices [11].
Any system for neuromorphic computing (NMC) endeavors to mimic the stimuli
response of the human brain. Often such a system is composed of an array of elements
which emulate the response of synapses (two-terminal connections) between two neu-
rons, interconnected appropriately as the system requires, which exhibit increasing
output in response to more frequent potentiation, called spike-timing dependent plas-
ticity (STDP) [14]. In simpler terms; an element which has not seen stimulus for a
long time will provide less response when presented with stimulus than an element
which has recently seen many stimulus events. Though less accurate than traditional
Von-Neumann computation schemes, neuromorphic systems have been shown to have
incredible speed and power consumption advantages when working with images, pat-
tern recognition, etc. Specifically, the ”CAVIAR” system reports speed increase of
1
CHAPTER 1. INTRODUCTION
more than 3 orders of magnitude compared to conventional image processing [15], and
the SpiNNaker chip proves power consumption improvement by consuming merely a
few nanojoules per neuron event [16]. Further, one can look to the IBM TrueNorth
and SyNAPSE chips for more proof of high speed and low power computation. How-
ever, optimal synapse devices must be two-terminal devices which exhibit low power
operation, high speed, high reliability, high endurance, and good memory window
with continuous states. Three potential candidates are ReRAM, covered more com-
pletely in Section 3.4.1, MTJs, and FTJs.
1.1 Research objectives
This thesis work evaluates incorporation of HfO2-based FTJ in NMC and nonvolatile
digital memory applications, specifically focusing on device performance/optimization
and system enablement. It explores material properties, basic device performance,
process development for CMOS integration, and related system design including sim-
ulated performance. By optimizing material properties of its various parts, the device
can exhibit a range of performance from ultra low power with large memory window
to low power with better speed performance when implemented with address systems
(lower τ = RC). This research work thereby endeavors to provide a full founda-
tion, see Figure 1.1, for further exploration and fabrication of HfO2-based FTJ, both
specifically at RIT and (with process modifications for varying CMOS device types
and sizes) at any facility.
1.2 Thesis organization
This introductory Chapter 1 highlights applications for which FTJ devices can en-
hance performance and simplify implementation and documents the research objec-















Figure 1.1: Diagram representation of the dependencies of various implementation stages
of the technology presented in this thesis.
properties of ferroelectric materials and highlights some specific aspects which are
of concern to their implementation in FTJs. Chapter 3 reviews the history of ferro-
electric memories, the discovery and subsequent explanation of FTJs, and the ideal
applications of these devices while also presenting alternative technologies and com-
paring their performance. After demonstrating the advantages of FTJs, Chapter 4
presents simulation (from quantum-mechanical basis) of device operation, with corre-
sponding band structures and current densities in each memory state (using a custom
python script). Finally, an FTJ using ferroelectric HfO2 is designed and simulated in
Chapter 5 and its performance is compared to other state of the art FTJs. In this
same chapter, a CMOS-integrated fabrication process for HfO2-based FTJ devices
is designed and discussed. Chapter 6 presents related address schemes and systems;
with schematics, simulations, Verilog descriptions, and layouts, designed for digital
memory applications using Cadence Virtuoso and a 45-nm process design kit (PDK).
Finally, the results of this work are summarized in Chapter 7 and future work is pre-
3
CHAPTER 1. INTRODUCTION
sented. This work therefore provides a nearly comprehensive overview of FTJ devices
from materials to systems, including ferroelectric HfO2 device simulation, the design
of a full CMOS-integrated fabrication process, and Cadence Virtuoso system design
and simulation with custom Verilog-A behavioral analog models of designed FTJs.
1.3 Neuromorphic Computing with Memristors, ReRAM
Neuromorphic systems with ReRAM as synapse elements have been reported which
take advantage of the intrinsic similarity between such devices and synapses (both are
two-terminal and behave memristively). ReRAM devices inherently pass more cur-
rent as they are programmed further (provided they can be so-designed) and therefore
provide both space-reduction (compared to larger CMOS elements or register imple-
mentation) and simplification of STDP response generation. In their papers, Ambro-
gio et. al report low-power (≈ 105 power reduction) generation of STDP signals with
ReRAM 1 transistor - 1 resistor (1T1R) synapse elements constituting a neuromor-
phic system capable of unsupervised learning of MNIST handwritten digits achieving
86% accuracy [17]. Further, the power consumption of the system was reduced to
1×10−12 Joules per neuron event, using a series of short pulses for write/read, and
enable ultra-low power computation [18]. Park et. al used TiOx-based ReRAM in
a neuromorphic system having a 250 node hidden layer followed by a 125 node sec-
ondary hidden layer and 10 bit output layer for recognition of 528-bit hand-drawn
digits (0 through 9) from the MNIST database. The system uses a different scheme for
pulse generation, consisting of discretizing element conductivity to 64 ”conductance
states” and achieves up to 84% accuracy [19]. Resistive devices as synaptic elements
therefore provide a unique opportunity in ultra low-power high speed systems for
applications requiring highly-parallel computation.
4
CHAPTER 1. INTRODUCTION
1.4 Using Ferroelectric Tunnel Junctions
An FTJ is very similar to a ReRAM device in function (both two terminal mem-
ristors), but differs in mechanism. Where ReRAM elements are either filamentary
(create/break a mechanical filament on program/erase) or non-filamentary (often in-
volving changing concentration of oxygen vacancies at the barrier interface) [20], a
change in resistance for an FTJ is based on the changing internal polarization field
magnitude and direction of a ferroelectric material separated by two electrodes of dif-
ferent materials (specifically having differing Debye lengths) [4]. Since, optimally, a
synaptic element will have a smooth (analog) transition from having seen no potenti-
ation (and little response) to many recent potentiations (and large response), an FTJ
for such application should include a ferroelectric material with as many domains as
possible and a low coercive electric field such that the ferroelectric depolarizes under
the absence of repeated stimuli. Such a film will be slightly thicker than typical for
FTJ used in non-volatile memory (NVM) and of a larger area. These properties are in
contrast to those required for NVM (high coercive field and low # of polarization do-
mains). Ferroelectric HfO2 is a good candidate due to the large difference in resistive
states possible,the ability to get a large number of domains in even small areas, and
high speed performance with write/read times of 10 ns [21]. Interestingly, HfO2-based
FTJ can be designed to provide optimal NVM performance or NMC performance,
explored more in Sections 5.1 and 5.2.
5
Chapter 2
Physics of Ferroelectric Materials
Ferromagnetism (permanent magnetic moment) was the first ferroic property dis-
covered and was so-named because it occurs often in iron-containing alloys. Ferro-
electricity is a property of materials which exhibit spontaneous electric polarization
(dipole moment density) and although most ferroelectrics do not contain iron, was
so-named because of it’s relation to the other ferroics (materials which can polarize
in some way) and was classified as such. In a basic sense, a ferroelectric is a dielectric
that (once stimulated) exhibits a non-zero reversible polarization at 0 applied electric
field, as shown in Figure 2.1. This remanent polarization, Pr, is due to an internal
potential, covered in more detail in the next few sections. Most ferroelectrics are ei-
ther transition metal oxides or chalcogenides. Additionally, materials can exhibit any
ferroic property independent of the others, and will also always be piezoelectric, and
a material which exhibits any two or more (excluding piezoelectricity) is considered
”multiferroic” [22].
2.1 Crystal structure
The internal electric field which ferroelectric materials exhibit, below their curie tem-
perature, is a result of their crystal structures. Though the material can maintain
a so-called ”prototype” phase above the curie temperature, due to available phonon
energy, at lower temperatures the crystal precipitates into a phase which is polar,
6
CHAPTER 2. PHYSICS OF FERROELECTRIC MATERIALS
Figure 2.1: Ferroelectric polarization (a) and weak magnetic moment (b) of multiferroic
Bi2NiMnO6 at 7K, from Shimakawa et. al [1]. The red line on (a) is what this plot would

































Figure 2.2: Simple representation of the atomic structures of a ferroelectric as its prototype
phase (left) relaxes into one of two polar phases (middle and right) after the application
of an external field. A ferroelectric would remain in the corresponding state even after the
removal of Eapp, while a dielectric would deflect (as shown) during stimulus application but
relax to the non-polar phase (left) once that field was removed.
represented in Figure 2.2, and exhibits an aggregate total polarization field based
on the orientation of domains (as a function of defects and grain boundaries). This
topic (and more complicated derivations of the physical phenomena of ferroelectrics)
is explored more completely in the famous book by Lines and Glass [22].
2.2 Polarization in ferroelectrics and dielectrics
The atoms in dielectric materials respond to external bias, as shown in Figure 2.2,
by deflecting from their zero-field position due to the applied electrostatic attrac-
tion/repulsion of the field. Considering a single unit cell, the energy required for an
7
CHAPTER 2. PHYSICS OF FERROELECTRIC MATERIALS
atom to remain in that position (along an arbitrary plane) follows a quadratic curve
with only one minimum at the zero-field position. This is because a simple dielec-
tric has a centrosymmetric crystal structure. A similar plot of atomic energy versus
position in a ferroelectric unit cell would instead behave as (x2 + a)(x2 + b) + c and
exhibit two separate minimas. This is because the crystal structure of a ferroelectric
is non-centrosymmetric, and is the physical origin of the macroscopic polarizability of
a ferroelectric film [22]. Furthermore, the polarization at zero applied field is called
remanent polarization, Pr. It can be either expressed in each polarization state (pos-
itive Pr,+ or negative Pr,−) or as the total of both states 2Pr = Pr,+ + Pr,− (often
in the case of symmetric states, where Pr,+ = −Pr,−). The electric field required
to transition from one polarization state to the other (where P passes through 0) is
called the coercive electric field, Ec = Vc/d [22]. Figure 2.1 shows a ferroelectric film
with 2Pr = 8µC/cm
2 and Ec = 0.1 MV/cm.
2.3 Non-intrinsic ferroelectrics
Though most ferroelectrics were classically demonstrated as bulk materials and later
implemented as thin films, recent improvements in film deposition technologies have
enabled the engineering of materials which could be called ”non-intrinsic” ferro-
electrics. Typically, the crystallization of a material proceeds in an effort to min-
imize total energy and occurs unconstrained (meaning the atoms are free to move
within the lattice). Recently, a group from NamLAB deposited films of HfO2 by
atomic layer deposition (ALD) and incorporated varying atomic % of Si atoms. After
annealing, unconstrained, the material crystallizes to a mixture of typical monoclin-
ic/tetragonal phases (which are centrosymmetric). However, by capping the HfO2
with a thin film of TiN and annealing at a temperature such that the TiN atoms
were likely still in a stable form, the HfO2 crystallizes to orthorhombic phase and is
non-centrosymmetric [23]. This change in state is likely due to a combined interaction
8
CHAPTER 2. PHYSICS OF FERROELECTRIC MATERIALS
↑ ← ↓ → ↓
Figure 2.3: Simple diagram of domains in a model ferroelectric film.
of the atomic stress from Si doping, the extra strain energy introduced by the cap-
ping material, and the inhibition of relaxation modes available when un-capped. The
Ferroelectric Device Research at RIT (FeDR RIT) group, working with NaMLAB,
have successfully demonstrated similar material results at RIT by doping HfO2 with
Al, using similar capping and anneal strategies.
2.4 Ferroelectric domains
A realistic ferroelectric film will not be perfectly oriented all the same direction, as
considered in Figure 2.2, but instead have many differently oriented crystal clusters,
due to defects. A very basic visualization of this effect is shown in Figure 2.3, and
is explored more thoroughly in the book by Lines and Glass [22]. In general, the
maximum size of a domain can be extracted based on crystal parameters but for
most materials is roughly 20 to 100 nm.
2.5 Area-dependent effects
The response of an FTJ can be affected by the domains which exist in the ferroelectric,
with reference to the area of the device. Consider, if the maximum domain size
is close to the area of FTJ devices, some devices will encompass only one domain
which is oriented parallel to the applied field. These devices would have maximum
performance, since the entire film contributes to polarization (Pmax). However, this
also means that some devices will happen to lie over a domain which is entirely
perpendicular to applied field and therefore cannot be polarized by the electrodes!
9
CHAPTER 2. PHYSICS OF FERROELECTRIC MATERIALS
These devices would simply not work at all. Therefore, for highest reliability, a
film should have maximum domain sizes much smaller than the desired area of FTJ
devices. This way, every device will have some domains directed parallel and some
perpendicular. Every device in an array would therefore work, but will have reduced
performance (P ≈ 0.5Pmax).
10
Chapter 3
Brief History and Applications of FTJ Implementations
3.1 Early memory using large-dimension PZT
Though not FTJs, ferroelectric memories were first reported in an MIT masters thesis
by Dudley Allen Buck in 1952 [24]. Larger ferroelectric memory arrarys by Bell
Labs were also discussed in a Scientific American article in 1955 by Ridenour [25]
though a good explanation of such devices was not given until a 1973 IEEE article
by Kaufman [2]. These ”bender memory” devices used 5 mil (127 µm) thick PZT
ferroelectric films sandwiched between conducting electrodes, shown in Figure 3.1, to
store data in polarization which creates a positive or negative pulse (while clamped,
due to the electrostrictive and piezoelectric response) in response to application of a
read voltage. These devices were very high power (30 V/mil write, 45V read) and
very slow (≈ 1 ms) [2].
3.2 More recent implementations with BaTiO3
As covered briefly in Section 4.2, Contreras et. al discovered the first FTJ using
BaTiO3, a ferroelectric well known since it’s initial synthesis as a bulk material. In
that paper, the group had investigated both Pt/PZT/SrRuO3 and SrRuO3/BaTiO3/SrRuO3
FTJs. The PZT FTJ displayed poor performance (likely due to vanishing polarization
density at small dimensions) while, although having similar electrodes, the BaTiO3-
11
CHAPTER 3. BRIEF HISTORY AND APPLICATIONS OF FTJ
IMPLEMENTATIONS
Figure 3.1: ”Bender memory” schematic from [2]. This 8-bit device stores data as re-
manent polarization in the top-most ferroelectric material. Write pulse is ≈ 1 ms of 20-30
V/mil.
based FTJ had a memory window of HRS/LRS ≈ 3, shown in Figure 3.2 [3]. As
already discussed in Section 4.2, the memory window is heavily dependent on the
dissimilarity of screening lengths between electrodes and, considering this FTJ has
the same material for both electrodes, it’s surprising that the performance is so good.
The group (Contreras, Kohlstedt, et. al) clears up this incongruity in their 2005 paper
where, in addition to using the findings of Zhuravlev et. al [4] to explain FTJ per-
formance, they report that the interface between bottom electrode and ferroelectric
exhibits a Ruddelsen-Popper interfacial layer which modifies the effective screening
length for that electrode, increasing asymmetry and therefore memory window [26].
Groups have continued to research BaTiO3-based FTJs, including a recent 2013
paper by Wang et. al which presents a device with Co and La0.67Sr0.33MnO3 as
electrodes. The group achieves a memory window HRS/LRS ≈ 100 with a 2 nm
ferroelectric and demonstrates switching times as fast as 13 ns (for relatively high
write voltages, ≈ 3Vc). They also use extracted values to design a Verilog-A model
of their devices [10].
12
CHAPTER 3. BRIEF HISTORY AND APPLICATIONS OF FTJ
IMPLEMENTATIONS
Figure 3.2: Performance of FTJs for (a) fresh device with PZT ferroelectric and (b) device
with BaTiO3 ferroelectric after -1.2V priming pulse, taken from Contreras et. al [3].
3.3 Applications of FTJs
FTJ devices are ideal for two main applications; non-volatile digital memory and
brain-inspired computing. Portable electronics demand fast, low-power storage de-
vices and, as shown in Table 3.1, FTJ provide the highest speed and lowest power.
Brain-inspired computing is the implementation of CMOS devices, which mimic
the integrate-and-fire responses of neurons, interconnected by devices with modifiable
signal strength, the function of a synapse, as shown in Figure 3.3. These types of
systems are most applicable to spatio-temporal data sets which are tolerant to noise.
For instance, facial recognition in video monitoring was demonstrated by Chevitarese
et. al using the IBM neuromorphic chip (which uses filamentary ReRAM devices) and
achieves 99% accuracy with total power consumption of 222mW [30]. Digitization of
pen-stroke inputs and word-detection in audio signals could also benefit from neuro-
morphic implementation. The easiest type of synapse to implement is a two-terminal
memristor which can be programmed to either have a high resistance (low connec-
tive strength) or low resistance (high connective strength). Of available memristor
devices, shown in Table 3.1, FTJs are at a clear advantage. Though occupying more
area than PCM and FTJ devices, FTJs are faster and operate at lower power com-
pared to all other devices. For this reason they are optimal for both neuromorphic
13
CHAPTER 3. BRIEF HISTORY AND APPLICATIONS OF FTJ
IMPLEMENTATIONS














































Speed (s) 400u [27] 500n 50n 30n [27] 10n
Power (J) 15u [28] 250n 6p 1.4u 30f








Table 3.1: Performance of alternative technologies compiled from various sources. MTJ
values from Aziz et. al and Lee et. al. [5, 6], all other from Ebong et. al. and Kim [7, 8]
unless otherwise referenced in table.
and non-volatile memory applications.
3.4 Alternative technologies
Memristors can be implemented by a few different technologies, each with their own
characteristic strengths and shortcomings, which are discussed in this section.
3.4.1 Filamentary ReRAM
These devices operate by forming and destroying a nanofilament of conducting mate-
rial in an insulating or high-resistance ”switching” medium. Many types of these de-
vices exist, but generally the most used CMOS-compatible versions are Ag/SiO2/Pt
or W/SiGe/a-Si/Ag. The first type forms/destroys Ag nanofilaments through the
SiO2 layer while the latter forms/destroys Ag nanofilaments through the a-Si layer
[31, 32]. Both switching mediums are ≈ 20 nm thick. Though these types of devices
14






Figure 3.3: Simple diagram of (left) a physical model of neurons and synapses, the brain’s
computation devices, and (right) their electronic implementation in a typical brain-inspired
computing system.
are well-understood and widely used, they are not very low power (3.5V program
pulses applied to devices with Ravg ≈ 1MΩ) and are rather slow (≈ 100 µs program
times, ≈ 500 µs read) [32].
3.4.2 Magnetic tunnel junctions
The MTJ is designed as a tunnel oxide sandwiched between two ferromagnetic ma-
terials. One of the ferromagnets is pinned to be magnetized in a direction, while
the other is free to magnetize parallel or anti-parallel to it (controlled by inducing a
magnetic field in it by passing a large current through a nearby conducting material).
When both magnetic films are oriented parallel the tunnel resistance through the de-
vice is lower than when anti-parallel (due to the effect of spin-transfer torque). These
devices can achieve memory windows as high as HRS/LRS ≈ 1000, but usually have
higher current density in both states than FTJs and also require rather large current
pulses to write the magnetic state [5, 6].
3.4.3 Phase-change memory
Lastly, PCM stores data by changing the crystal phase of a material in a junction.
When fresh, the material is in a crystalline (low resistance) state. By passing sufficient
current through a heater, the phase change material is melted and quickly quenched
15
CHAPTER 3. BRIEF HISTORY AND APPLICATIONS OF FTJ
IMPLEMENTATIONS
by passing a large current through it. This forces the material to remain amourphous
and have a higher resistance, usually HRS/LRS ≈ 1000. To return to low resistance
state, a moderate current pulse is passed through the material, melting it, and held
there long enough melt and facilitate crystalization of the material. Though typical
current density in both states are lower than MTJ, they are still not as low as FTJ
and, like MTJ, the PCM requires rather large currents to write [33]. Therefore, it is
not ideal for low-power computing.
16
Chapter 4
Analysis of M1-Fe-M2 Structure
At its core, an FTJ is a modified MIM so it’s logical to start by examining an MIM and
modifying our analysis to reflect the different material properties. All band structure
and current density figures in this section, except Figure 4.3, are simulated results
performed in this work using a custom python program included in Appendix A.
4.1 Band structure in the absence of polarization field
An MIM with non-ferroelectric insulator has no internal polarization field and there-
fore returns to the same zero-field band structure, shown in Figure 4.1, after any
external field application (for d = 2 nm thick insulator with Ea = 2 eV and metals
having χ1 = 4.08 eV, χ2 = 4.85 eV). The thermionic emission current, from electrons
which gain sufficient energy from phonon interaction to surmount the barrier, of such
a device is calculated using Equation 4.1, and for our example is roughly 1e-41 A/cm2
(practically ”0” current) at 0.5V. Since this MIM has an insulator with thickness less
than the penetration distance of the electron wave, an appreciable current occurs due
to Fowler-Nordheim tunneling, Jtun, when electrons are able to quantum-mechanically
tunnel through the triangular or trapezoidal energy barrier. This current, calculated
using Equation 4.2, is shown in Figure 4.2 and is the main current contributing mech-
anism for this type of device (7e4 A/cm2 at 0.5V for this example). Like most MIMs,
this device’s tunnel current density has a separation around zero applied voltage
17
CHAPTER 4. ANALYSIS OF M1-FE-M2 STRUCTURE
where the current becomes ”zero” and also has a slight asymmetry between curves
under negative and positive applied voltage.
























Band diagram of an MIM
Figure 4.1: The energy band diagram of an MIM with a 2 nm thick insulator with Ea = 2
eV and metals having χ1 = 4.08 eV, χ2 = 4.85 eV, normalized to the fermi energy.
Jth = AthT

































β is a correction factor, usually 1
(4.2)
4.2 Band structure under polarization
When the first FTJ was discovered by Contreras et. al in 2002, BaTiO3 ferroelectric
with SrRuO3 and PZT as electrodes, its operation went unexplained and was origi-
18
CHAPTER 4. ANALYSIS OF M1-FE-M2 STRUCTURE
























Current density versus applied voltage
Figure 4.2: The Fowler-Nordheim tunneling current of an MIM with material properties
listed in Section 4.1.
nally published purely as a dissemination of experimental results. [3] It was not until
2005 that the phenomenon was explained by Zhuravlev et. al, who postulated that
the ferroelectric polarization, P , induces equal and opposite surface charge densities,
σp = −P , which exist in infinitessimally thin sheets at the interfaces of each contact
and the ferroelectric. Shown in Figure 4.3, the surface charges must then be locally
screened by each electrode, thereby inducing screening charge densities, σs, as given
by Equation 4.3, with screening lengths (or debye lengths) in metal 1, σ1, and metal
2, σ2, given by Equation 4.4. Finally, these charges modify the zero-polarization band
structure with additional potentials within both electrodes and the ferroelectric, as
given by Equation 4.5 and shown in Figure 4.3 by Zhuravlev et. al [4]. Though not
explicitly given by the group, it is clear that the additional potential contribution
within the ferroelectric is given by Equation 4.6.
σs =
Pd
εf(δ1 + δ2) + d
(4.3)
19
CHAPTER 4. ANALYSIS OF M1-FE-M2 STRUCTURE
Figure 4.3: (a) Diagram of charge densities created for left polarized ferroelectric and
(b) corresponding generated potentials across an FTJ, having electrodes with dissimilar
screening lengths, from Zhuravlev et. al [4].









, x ≤ 0
−σsδ2 exp(−|x− d|/δ2)
ε0








, 0 < x < d (4.6)
It’s clear to see already that for electrodes with dissimilar screening lengths there
will be a non-zero depolarizing field, because of the reduced field contribution from
charges further from the interface, and there will be a difference in average potential
barriers for polarization towards M1 versus M2. Finally, integrating all the above
contributions from polarization-induced charges to the zero-field band structure, an
FTJ with material properties consistent with those used in Section 4.1 (and assuming
P = 10µ C/cm2, εf = 40ε0, δ1 = 0.06 nm, and δ2 = 0.4 nm) would exhibit band
structures as shown in Figure 4.4.
20
CHAPTER 4. ANALYSIS OF M1-FE-M2 STRUCTURE
























Band diagram of an FTJ
P=+P
P=-P
Figure 4.4: The energy band diagrams, at V = 0, of an FTJ with material properties
given in Section 4.2, for positive (towards M1) and negative (towards M2) polarization.
4.3 Extraction of tunnel Current and (by extension) resis-
tance states
The tunnel current density for each state (positive polarization and negative polariza-
tion), is calculated again using Equation 4.2, but now requires the additional potential
contributions of equations 4.5 and 4.6. For this case, positive polarization (towards
M1) has a lower barrier than negative polarization (towards M2), so we will term
each state the LRS and HRS, respectively. The corresponding current density curves
are shown in Figure 4.5, and is representative of an FTJ having Al as M1, Al:HfO2
as ferroelectric, and degenerately doped (Na = 1 × 1020 cm−3) p+ Si as M2. Since
the resistivity is given by ρ = E/J = V/(dJ), the resistance states would correspond
directly to the current densities of each state. Lastly, the memory window is a ratio
of the device’s resistivity (at the same applied voltage, usually the read voltage, vdda)
in each state, HRS/LRS = ρHRS/ρLRS = JLRS/JHRS.
21
CHAPTER 4. ANALYSIS OF M1-FE-M2 STRUCTURE
























Current density versus applied voltage
LRS
HRS
Figure 4.5: The Fowler-Nordheim tunneling current of an FTJ with material properties
consistent with those used in Figure 4.4, showing a memory window HRS/LRS ≈ 2.3.
22
Chapter 5
Design of Ferroelectric HfO2-based FTJs and Integration
with CMOS Process
For this design, a twin-well polysilicon-gate planar CMOS process flow by Lynn Fuller
[34] was modified by the addition of required steps for deposition and patterning
of the ferroelectric. If being fabricated at RIT, the author recommends keeping
designed CMOS devices at a minimum length of 2 µm to achieve highest yield, though
adaptation of these processes to another process with smaller minimum feature size
and varying gate material would be relatively straight-forward.
5.1 FTJ design
In an effort to keep the FTJ fully CMOS-compatible the electrodes were chosen to be
Al and p- doped Si, as shown to be effective in Section 4.3. Each device is designed
as a crossbar such that the area of an FTJ is the width of the p- electrode times the
width of the Al electrode. This way, a larger array of FTJ devices are designed as
horizontal p- lines (in ”oxide” mask level) and vertical Al lines.
In order to predict and optimize FTJ performance, all equations from Section 4
were integrated into a flexible python program with user-interface for input of relevant
material properties. The code for this program is given in Appendix A.
Interestingly, extracting memory window as a function of increasing screening
length in the poor metal (assuming the other metal has a screening length of δ1 =
23
CHAPTER 5. DESIGN OF FERROELECTRIC HFO2-BASED FTJs AND
INTEGRATION WITH CMOS PROCESS













Memory window versus screening length ratio, δ1 = 0.5 A˚
Figure 5.1: Simulated HRS/LRS increases with larger screening length ratio before
plateauing around δ2δ1 ≈ 60. For an Al/Al:HfO2/p+ Si FTJ with 2 nm ferroelectric.
0.5 A˚), as shown in Figure 5.1, shows a saturation starting at around 60 ≈ δ2/δ1
(corresponding to δ2 = 3 nm, p+ Si Na = 2× 1018 cm−3).
Even more interestingly, varying the screening length in the ”good” metal (while
keeping the poor metal δ2 = 3 nm), as shown in figure 5.2, yields two important
conclusions. First, a metal with incredibly high carrier concentration (δ1 < 0.05A˚)
would actually cause a sharp decay in memory window, owing likely to the total
screening of the depolarizing field at that interface and (by extension) a removal of
its positive effect on introducing dissimilar barriers. Second, the memory window
improves with increased screening length but reaches a maximum at δ1/δ2 ≈ 0.38.
This is likely due to increasing total available charges to contribute to depolarizing
field until maximizing once charges are located too far away from the interface to
contribute (as is the case in materials with a larger screening length). The screening
length of the Al electrode could be increased by interface defects, oxide charges, or
material impurities. The screening length of AlSi (10% Si) would also be larger than
pure Al and approach the ideal value (δ1 = 1.14 nm).
24
CHAPTER 5. DESIGN OF FERROELECTRIC HFO2-BASED FTJs AND
INTEGRATION WITH CMOS PROCESS














Memory window versus screening length ratio, δ2 = 3 nm
Figure 5.2: Simulated HRS/LRS for increasing δ1, showing a maximum. For an
Al/Al:HfO2/p+ Si FTJ with 2 nm ferroelectric.

































Figure 5.3: Simulated HRS/LRS and HRS resistivity for an Al/Al:HfO2/p+ Si FTJ with
varying ferroelectric thickness.
25
CHAPTER 5. DESIGN OF FERROELECTRIC HFO2-BASED FTJs AND
INTEGRATION WITH CMOS PROCESS
5.2 State of the art FTJs
For this study, it is best to assume the Al electrode will behave non-optimally (having
no impurities) and therefore, the FTJ design for the Al/Al:HfO2/p-Si device presented
in this work has material properties δ1 = 0.06 nm, χ1 = 4.08 eV, εf = 40ε0, Ea = 2
eV, Pr = 15µC/cm
2, d = 2, 3, or 5, m∗ = 0.11me, δ2 = 3 nm, and χ2 = 4.85 eV. The
Al:HfO2 ferroelectric is adapted from the process used by Polakowski et. Al [35] and
is assumed to behave with similar speed, polarization, and endurance performance.
A comparison of this device to other state of the art FTJs is shown in Table 5.1.
Importantly, the small coercive electric field (Ec) of HfO2-based ferroelectrics leads to
a lower required program voltage (the coercive voltage, Vc), and therefore lower power
consumption, compared to BaTiO3 and BiFeO3 FTJs. Speed performance between
FTJs are mostly similar, though endurance of HfO2-based devices is higher than
that of BiFeO3 devices. Most importantly, the Al/Al:HfO2/p-Si FTJ can be designed
with either a 2, 3, or 5 nm ferroelectric layer; leading to performance with either lower
high-state resistivity (ρHRS) than all other FTJs (enabling high speed performance
by minimizing τ = RC) while only exhibiting moderate power density (Pd) with
a 2 nm ferroelectric or very high ρHRS with a potentially huge memory window of
5×105 and extremely low power performance (2.5 fJ for each 500 nm2 device) with a
5 nm ferroelectric (more ideal for NMC applications where a large memory window
permits more memory states). At a more moderate performance optimization, a
3 nm ferroelectric in the Al/Al:HfO2/p-Si FTJ yields a memory window similar to
that of the BaTiO3 FTJ reported by Abuwasib et. Al [9] but achieves lower power
consumption by a factor of ≈1×10−3. All three of these simulation results indicate
that Al:HfO2-based FTJs are superior to both alternative technologies and FTJs using
competing ferroelectrics for both neuromorphic computing and nonvolatile memory
applications, excelling at low-power high-speed performance.
26
CHAPTER 5. DESIGN OF FERROELECTRIC HFO2-BASED FTJs AND
INTEGRATION WITH CMOS PROCESS
Researcher [cite] Device Materials Ec (V/cm) Area CMOS?
Chanthbouala et. Al [36] FTJ Co/BaTiO3/LSMO 1×107 0.096 No
Abuwasib et. Al [9] FTJ Co/BaTiO3/LSMO 1×107 0.303 No
Boyn et. Al [12] FTJ Co/BiFeO3/CCMO 3.3×106 0.125 No
Mueller, Schroeder et. Al [37,38] MIM Pt/TiN/Si-HfO2/TiN 1×105 10000 Yes
Polakowski et. Al [35] MIM TiN/Al:HfO2/TiN 1×105 50 Yes
This Work (Based on Simulations) FTJ Al/Al:HfO2/p-Si 1×105 0.25 Yes
Research d (nm) ρHRS (Ω·cm2) HRS/LRS Pr Speed Endurance Vc Pd (W/cm2)
[36] 2 4.8×10−2 300 - 10 ns - 2.0 83.3
[9] 2 4.8×10−3 60 - - - 2.0 823
[12] 4.6 5×10−2 1000 100 100 ns 4×106 1.5 45
[37,38] 10 - - 17 10 ns 1×1010 1.0
[35] 12 - - 15 not rep. 2×109 1.2
This Work
2 1.8×10−4 6.2
15 10 ns 2×109
0.2 222
3 1.54×10−1 90 0.3 0.584
5 2.3×105 500000 0.5 1×10−6
Table 5.1: Tables comparing relevant performance data for this research work to state of
the art FTJs. LSMO stands for LaxSr1−xMnO3 and CCMO is Ca0.96Ce0.04MnO3. Area
units are µm2. Pd is surface power density and Pr is remanent polarization in (µC/cm
2).
27
CHAPTER 5. DESIGN OF FERROELECTRIC HFO2-BASED FTJs AND
INTEGRATION WITH CMOS PROCESS

































































































































































































































































































































































































































































































































































































































































































































































































CHAPTER 5. DESIGN OF FERROELECTRIC HFO2-BASED FTJs AND


































































































































































































































































































































































































































































































































































































































































































CHAPTER 5. DESIGN OF FERROELECTRIC HFO2-BASED FTJs AND





















































































































































































































































































































































































































































































































































































































































CHAPTER 5. DESIGN OF FERROELECTRIC HFO2-BASED FTJs AND





















































































































































































































































































































































































































































































CHAPTER 5. DESIGN OF FERROELECTRIC HFO2-BASED FTJs AND































































































































































































































































































































































































































































































































































CHAPTER 5. DESIGN OF FERROELECTRIC HFO2-BASED FTJs AND

















































































































































































































































































































































CHAPTER 5. DESIGN OF FERROELECTRIC HFO2-BASED FTJs AND











































































































































































































































































































































































CHAPTER 5. DESIGN OF FERROELECTRIC HFO2-BASED FTJs AND
INTEGRATION WITH CMOS PROCESS
To minimize additional process steps, the p-Si electrode is defined by the pseudo-
STI field oxide growth (steps 3-9) which also defines the active areas of transistors.
This process does exhibit some feature thinning, so a 2 µm line on mask (transferred
to nitride) yields approximately a 250 nm line width of exposed silicon for the elec-
trode. The p- doping is introduced during the implant for PMOS-device source/drain,
step 47. A modified version of step 47, called step 47(2), can be used to study the
affect of n-doping instead of p-doping the lower (M2) electrode, but cannot be used
with full CMOS integration. To confine Al:HfO2 to FTJ areas, the same tetra-ethyl
orthosilicate (TEOS) oxide used as an interlevel dielectric (ILD) below each metal
layer is deposited, step 56, and patterned, step 57, to open windows to FTJ areas
before Al:HfO2 deposition by ALD, step 60. The Al:HfO2 is also capped in-situ with
TiN before being annealed in RTP (to form the ferroelectric state), step 61. The TiN
must then be removed, since it is conducting and would cause device shorts, and is
selectively removed, in step 63, by the SC1 chemistry used in a standard RCA clean
(at a rate of 1nm/s), as shown by Liu et. al [39]. This must be done in a pyrex
dish on a hot plate in a wet etch bench, not in the RCA bench, to avoid contamina-
tion. Finally, the same mask used to open windows in the TEOS can be used with
negative resist, in step 65, to create a soft mask protecting the FTJ areas and then
etch the Al:HfO2, in step 66, from unwanted areas (though this is not necessary).
Having already deposited the TEOS oxide, the contact cuts can be etched, step 69,
and metal 1 (Al) deposited, step 72, and patterned, steps 73 and 74. The metal 1
mask is therefore also defining the Al electrodes for the FTJs! In whole, the only
extra steps for FTJ-fabrication are the TEOS oxide etch, ferroelectric deposition and
anneal, and TiN/ferroelectric etching only requiring one extra mask. A shortened
version of this process, with only the required steps to fabricate FTJ devices, is given
in Appendix B.
35
CHAPTER 5. DESIGN OF FERROELECTRIC HFO2-BASED FTJs AND
INTEGRATION WITH CMOS PROCESS
Figure 5.4: Athena simulation of CMOS devices tuned for low threshold voltages (left)
and FTJ device (right).
5.4 Process simulation
Silvaco is a semiconductor simulation tool used often in both academic and industry
research. It has modules for process simulation, Athena, and electrical simulation of
a simulated process, Atlas ; though electrical simulations are more suited to transistor
performance and related connections. In order to verify the proposed process design,
from Section 5.3, it was simulated using Athena. The code is included in Appendix C
and important figures are shown in this section. Importantly, the CMOS devices are
shown in Figure 5.4, showing appropriate wells and junction depths for source/drain.
The window opened in TEOS is shown to be appropriate for isolating ferroelectric to
desired areas, shown in Figure 5.5 with SiO2 substituted for HfO2 since Athena does
not have it. This simulation platform was also used to fine tune the use of wet etch
before HfO2 deposition to accurately reach 250 nm device width, shown in Figure 5.6.
For implementation within another process node or with transistors of differing
threshold voltage, Athena simulation should be repeated with corrected well, thresh-
old adjust, and source/drain implants. Surface doping of the FTJ region should be
extracted and used for recalculation of δ2 and corresponding memory window.
36
CHAPTER 5. DESIGN OF FERROELECTRIC HFO2-BASED FTJs AND
INTEGRATION WITH CMOS PROCESS
Figure 5.5: Athena simulation of FTJ device (SiO2 substitued for ferroelectric).
Figure 5.6: Zoom of FTJ device showing ≈ 250 nm device width.
37
Chapter 6
System Design and Simulations for Digital Memory
Applications
The designs of all circuits were performed in Cadence Virtuoso using a 45 nm CMOS
PDK. The design rules of this PDK are consistent with those required for the 2 um
process to be performed at RIT but allowed for easier use of the DRC and LVS tools
native to this PDK. Additionally, this allowed for performance simulation represen-
tative of implementation with fairly modern devices. When implemented in the 2 um
CMOS process at RIT, the mask file from Virtuoso was simply scaled up (from 45
nm to 2 um, a factor of 44.44) before mask printing.
6.1 Read/Write scheme
When writing an FTJ, the bias applied across it must meet or exceed the coercive
voltage, Vc, in order to flip the polarization to the desired direction (over any rea-
sonable amount of time). While reading, the bias must be less than Vc in order to
prevent state disturbance. Let’s take, for example, an FTJ with Vc = 0.5 V. As shown
in Figure 6.1, these schemes would work to write the HRS and LRS as shown and to
read the device (since read will always be performed in the same direction).
However, FTJs are often (if not always) designed in an array (like most memory).
Within this array, the positive terminals are connected to rows and the negative
terminals to columns, as shown in Figure 6.2. Using the address scheme from before,
38








Figure 6.1: An address scheme which, though appropriate for a stand-alone device, would









Figure 6.2: A simple schematic showing the typical connectivity of FTJ devices in an
array, for both memory or neuromorphic logic applications. Lines and columns only connect
through FTJ devices and do not connect at intersections. Dotted lines indicate an arbitrary
number of repeated lines and columns.
other non-addressed devices in that row or column would experience the same bias
as the addressed device!
Ultimately, the best solution to this will be one of two options and will be up to the
system designer. The first option is to have rails centered around ground such that the
write rails are (for our example) VDD=0.3 V and VSS=-0.3 V, read rails are vdda=0.2V
and vssa=-0.2V and whenever a column or row is not being addressed it should be
grounded. That way, the write scheme follows Figure 6.3 for addressed devices and
non-addressed devices, shown in Figure 6.4 (in same row), are not disturbed during
39















Figure 6.4: Non-addressed devices in the same row, for various write/read states. Non-
addressed devices in the same column would experience the opposite bias. In this way, these
devices will not be disturbed.
read or write.
Though this address choice does allow non-addressed devices to stay at ground,
preventing current flow through the FTJ devices to the bulk silicon (which is typically
grounded) it does require CMOS devices with near-zero threshold voltage. If this is
undesirable, another option is to shift all rails by +VDD, leaving the write rail low
at 0V but requiring all non-addressed lines to be held (for our example) at 0.3V.
Ultimately, this is the decision of the system designer and depends on related process
constraints.
6.2 Linear resistance change simulation
The most simple way to model the changing resistance of an FTJ is to first calculate,
using equations from Chapter 4, the resistance of each state (at the read bias) using
material properties appropriate for the chosen device. The model written in Verilog-
A, given in Appendix D.1.1, assumes that the resistance would change linearly over
some chosen ”transition time” while biased above |Vc| towards the corresponding
40
CHAPTER 6. SYSTEM DESIGN AND SIMULATIONS FOR DIGITAL MEMORY
APPLICATIONS
state and saturate once reaching the resistance of that state. Simulation results using
CMOS devices from the 45nm PDK of Cadence Virtuoso (used for ease of DRC and
LVS, and for results more representative of a modern CMOS process) are shown in
Figure 6.10 and are useful for digital memory applications, with write times of ≈ 0.6
ns for HRS and ≈ 0.3 ns for LRS and read times of ≈ 10 ns for HRS and ≈ 4 ns for
LRS. However, brain-inspired computing systems, which require precise control as
the device transitions from one state to the other, need a more complicated simulation
which models polarization change versus time and corresponding resistance.
6.3 Timing-based simulation
Working with data for polarization versus program time from Schroeder et. al [41],
piece-wise polynomial models were fit to the data and used to direct further study of
the general phenomena of timing in ferroelectrics. Some modeled curves are given in
Figure 6.5 and the equation and relevant model fit parameters are given by Equation
6.1. Though these curves suggest switching times close to 1 µs, the group posits that
this data was influenced by the test setup delay and that realistic switching times are
in the 1 ns range [41].
2Pr(V, t) = MIN
MIN(13.071 ∗ V 2.929, 6.339 ∗ V + 27.357)
,MAX(MIN(D + E ∗ ln(t),MAX(A+B log(t) + C log2(t), 0)), 0)

A = MAX(445.4V − 416.102, 22V )
B = MAX(118.125V − 112.071, 5.8V )
C = MAX(7.782V − 7.525, 0.26V )
D = MIN(9.904V + 17.865, 19.375V 2 − 6.3V + 1.4)
E = MAX(9.105V − 5.152− 3.387V 2, 0.217)
(6.1)
41
CHAPTER 6. SYSTEM DESIGN AND SIMULATIONS FOR DIGITAL MEMORY
APPLICATIONS

















V = 0.2 V
V = 1.0 V
V = 1.4 V
V = 1.8 V
V = 2.2 V
V = 3.0 V
Figure 6.5: Changing polarization as a function of time for varying applied voltages for a
sample with Vc ≈ 0.9 V.
As discussed in Section 2.4, total polarization in ferroelectric materials is the
aggregate contribution of many domains, each having their own switching voltages
and times depending upon their orientation (referenced to the applied field). As
such, the model was binned into domains by subtracting a total curve of V = Va−0.2
from V = Va, therefore giving the polarization contribution for ferroelectric domains
having switching voltages Va−0.2 < Vc < Va. These curves were modified by capping
at maximum (removing decreasing polarization for increasing time) and are shown in
Figure 6.6.
One would logically expect a normal distribution of domains; with very few having
low coercive voltage, very many switching at some moderate voltage, and very few
being oriented so close to 90° from the applied field to have very high coercive voltage.
Though a bit noisy, owing likely to the multiple normalizations performed on the
curves in previous model steps, the maximum domain contributions shown in Figure
6.7 do suggest this type of normal distribution, centered around Vc = 0.9 V but
42
CHAPTER 6. SYSTEM DESIGN AND SIMULATIONS FOR DIGITAL MEMORY
APPLICATIONS
















Polarization versus time, binned for domains
0.4 < V < 0.6 V
0.8 < V < 1.0 V
1.2 < V < 1.4 V
1.6 < V < 1.8 V
2.0 < V < 2.2 V
2.4 < V < 2.6 V
Figure 6.6: Changing polarization as a function of time binned for domains existing in
0.2V intervals for a sample with Vc ≈ 0.9 V. Only a subset of curves are plotted. The
models work best when binned from 0.2V to 3V in 0.2V intervals.
having a very long right-sided tail. Further, Figure 6.8 plots switching times binned
for domains and shows that for higher voltages the switching times decrease. This
should make some sense, considering domains which require larger voltages to switch
have more excess energy while switching and therefore transition faster.
Finally, the model equations for polarization versus time binned for domains were
implemented in a Verilog-A model, given in Appendix D.2.1, which keeps track of
each domain’s contribution based on applied voltage and aggregate time. The model
then calculates corresponding resistance based on the current total polarization, given
material constants, using equations from Section 4.3.
6.4 Address systems
The interconnectivity described is shown in Figure 6.9 connected to a single FTJ
which uses the linear resistance Verilog-A model, from Appendix D.1.1. Systems for
43
CHAPTER 6. SYSTEM DESIGN AND SIMULATIONS FOR DIGITAL MEMORY
APPLICATIONS
















Maximum polarization versus max domain voltage
Figure 6.7: Maximum polarization for domains binned to 0.2V intervals, resembling a
noisy normal distribution with a long right-sided tail.
addressing FTJ devices, following the read/write scheme given in Section 6.1, were
designed as tristate CMOS cells using both 45 nm devices and 2 µm devices, though
only 45 nm system performance will be examined here (since those results more closely
describe the capabilities of these memories). The tristate devices, shown in Appen-
dices D.3 through D.7, accept read enable (Ren), write enable (Wen), and write line
(W) signals and toggle the output to desired voltages. SAP ADDRESS ROW W and
SAP ADDRESS COLUMN W are used to toggle a connected row and column (pos-
itive and negative FTJ terminal) to high (VDD) and low (VSS) write voltages, respec-
tively when Wen is high and W is high (writing the HRS). When Wen is high but W
is low (writing LRS) the row is pulled to low write voltage and column to high. Read
voltages applied by SAP ADDRESS ROW R and SAP ADDRESS COLUMN R, when
Ren is high, always bring the row to read high (vdda) and the column to read low
(vssa). The column read voltage is applied to a reference resistor in series with the
FTJ (and the rest of the column) and output is taken from an inverter taking its
44
CHAPTER 6. SYSTEM DESIGN AND SIMULATIONS FOR DIGITAL MEMORY
APPLICATIONS














Saturation time versus max domain voltage
Figure 6.8: Time until polarization saturation for domains binned to 0.2V intervals.
Higher energy domains (oriented less parallel to the applied field) switch faster due to
excess energy.
input from the node (Vo) between the reference resistor and the FTJ. In this way,
if RFTJ > Rref then Vo pulls to vssa and the inverter pulls to VDD. If RFTJ < Rref,
then Vo pulls to vdda and the inverter transitions to VSS. SAP ADDRESS GND vcc
is used to hold rows and/or columns at vcc whenever not being written or read, to
prevent write/read disturbs. To ensure all of the write voltage and vcc makes it to
the FTJ, a pass transistor is connected in series with the reference resistor and is set
to be off only while reading. Shown in figures 6.10 and 6.11 are simulation outputs
of this system, showing read times of 10 ns and write times as short as 0.3 ns.
6.5 Simulation results - 4×4 Array
A testbench, code given in Appendix D.10, was written in Verilog which programs
a 4×4 array of FTJ, as shown in Appendix D.9, all to HRS and then writes binary
numbers 0 through 15 on the first row. Writing devices in an array is a two-step
45
CHAPTER 6. SYSTEM DESIGN AND SIMULATIONS FOR DIGITAL MEMORY
APPLICATIONS
process; one step writes devices to HRS and the next step to LRS. After writing each
number, the row is read to check for write errors, then the row below it is read to
check for write disturbs, and finally the original row is read again to check for read
disturbs. A small portion of waveforms are shown in Figure 6.12, showing 10ns read
and write pulses separated by 10ns guard times for relaxation of excess voltage from
capacitive discharging. This system exhibits no write errors, write disturbs, or read
disturbs.
A series of tests writing random binary numbers from 0 to 15 to random rows
of the array exhibits 100% accuracy, shown in Figure 6.13, but often causes Spectre
simulation to crash by not converging. Minor modifications may need to be made to
the Verilog-A model to smooth edges and prevent convergence issues.
46






































































































































































CHAPTER 6. SYSTEM DESIGN AND SIMULATIONS FOR DIGITAL MEMORY
APPLICATIONS





































Figure 6.10: Simulation results from a single FTJ device connected to address circuitry
designed with 45 nm CMOS. Wen〈1〉 follows the same curve as Wen〈2〉 in this simulation.
Notice that the output, Y, transitions low when reading (Ren high) an FTJ in LRS and
transitions high when reading an HRS FTJ. Write and read times are 10 ns.





































Figure 6.11: Simulation results from a single FTJ device connected to address circuitry
designed with 45 nm CMOS. Wen〈1〉 is constantly off in this simulation; testing for write
disturb when programming a different device in the same row, once in an array. The FTJ
state remains unchanged even after write enable toggles for high and low writes, verifying
that this system is robust against write disturbs of non-addressed devices.
48
CHAPTER 6. SYSTEM DESIGN AND SIMULATIONS FOR DIGITAL MEMORY
APPLICATIONS
Figure 6.12: Small portion of waveform while writing binary 0 to 15 in one row while all
other FTJ in the 4×4 array are in HRS.
Figure 6.13: Waveform and simulation log for random binary numbers being written to




This work has laid a nearly comprehensive framework for fabrication of FTJ devices
with/without connected CMOS devices, from material to architecture. The physi-
cal phenomena present within ferroelectric materials was examined as a function of
crystal structure and domains. FTJ device structures were modeled as a function
of material properties and methods of extracting corresponding performance metrics
(using a custom-built python code) were presented and evaluated for the proposed
Al/Al:HfO2/p-Si FTJ (having δ1 = 0.06 nm, χ1 = 4.08 eV, εf = 40ε0, Ea = 2 eV,
Pr = 15µC/cm
2, d = 2, 3, or 5, m∗ = 0.11me, δ2 = 3 nm, and χ2 = 4.85 eV) which
exhibits a memory window as high as HRS/LRS ≈ 5×105 with max current density of
≈ 3×10−2 A/cm2 and power density of 1 µW/cm2 with a 5 nm ferroelectric, enabling
ultra-low power computing (compared to 45 W/cm2 for competing FTJ devices) at
high speeds. Using a 2 nm ferroelectric, the FTJ can achieve current density as high
as 8×103 A/cm2 with a memory window of HRS/LRS ≈ 6, targeting higher speed
applications. These devices are therefore capable of lower power and higher speed
performance than any alternative memristor technology, shown in sections 3.4 and
5.1, including competing FTJ devices.
The FTJs designed and simulated were then integrated into a new process flow,
based on a twin-well polysilicon gate planar-CMOS technology, which was verified by
Silvaco Athena simulation. Algorithms for read and write of devices in an array were
50
CHAPTER 7. CONCLUSIONS
proposed, implemented by systems designed using a 45nm CMOS process design kit in
Cadence Virtuoso Design Suite, and successfully simulated (using a Verilog testbench
for stimulation) as digital memory storage devices in a 4×4 array architecture, with
write and read times as low as 0.3 ns and 10ns, respectively.
7.1 Future Work
Ten device wafers are currently at step 22 of the FTJ-only process, shown in Appendix
B, and will be completed by a future student. These wafers will be split into three
groups of three wafers(with one left over), two of which will be sent to NamLAB and
UCB for Si:HfO2 and HfZrO2 film deposition, respectively, on each wafer at one of
three different thicknesses (the author recommends 2, 5, and 8nm). Once samples
are completed, experimental results for Pr, tsat, Ec, and resistances/current densities
in each state, along with more detailed timing data for switching transitions, should
be compiled and implemented in the polarization-timing FTJ model Verilog-A code,
shown in Appendix D.2.1, which will be stored on the RIT gitlab. Finally, these
models based on experimental data should be implemented with a brain-inspired
computing system to examine performance of these devices in such an application.




[1] Y. Shimakawa, M. Azuma, and N. Ichikawa, “Multiferroic Compounds with
Double-Perovskite Structures,” Materials, vol. 4, no. 1, pp. 153–168, Jan. 2011.
[Online]. Available: http://www.mdpi.com/1996-1944/4/1/153
[2] A. B. Kaufman, “An expandable ferroelectric random access memory,” IEEE
Transactions on Computers, vol. C-22, no. 2, pp. 154–158, Feb 1973.
[3] J. R. Contreras, J. Schubert, H. Kohlstedt, and R. Waser, “Memory device based
on a ferroelectric tunnel junction,” in Device Research Conference, 2002. 60th
DRC. Conference Digest, June 2002, pp. 97–98.
[4] M. Zhuravlev, R. Sabirianov, S. Jaswal, and E. Tsymbal, “Giant electroresistance
in ferroelectric tunnel junctions,” PHYSICAL REVIEW LETTERS, vol. 94,
no. 24, JUN 24 2005.
[5] A. Aziz, N. Shukla, S. Datta, and S. K. Gupta, “Coast: Correlated material
assisted stt mrams for optimized read operation,” in 2015 IEEE/ACM Interna-
tional Symposium on Low Power Electronics and Design (ISLPED), July 2015,
pp. 1–6.
[6] S. Lee, K. Kim, K. Kim, U. Pi, Y. Jang, U. i. Chung, I. Yoo, and K. Kim,
“Highly scalable stt-mram with 3-dimensional cell structure using in-plane mag-
netic anisotropy materials,” in 2012 Symposium on VLSI Technology (VLSIT),
June 2012, pp. 65–66.
[7] I. E. Ebong and P. Mazumder, “Cmos and memristor-based neural network




[8] S. Kim, H. Wong, Y. Cui, Y. Nishi, and S. U. D. of Electrical Engineering,
Scalability and Reliability of Phase Change Memory. Stanford University, 2010.
[Online]. Available: https://books.google.com/books?id=4WZq0q4wCAAC
[9] M. Abuwasib, H. Lee, P. Sharma, C. B. Eom, A. Gruverman, and U. Singisetti,
“Cmos compatible integrated ferroelectric tunnel junctions (ftj),” in 2015 73rd
Annual Device Research Conference (DRC), June 2015, pp. 45–46.
[10] Z. Wang, W. Zhao, A. Bouchenak-Khelladi, Y. Zhang, W. Lin, J. O. Klein,
D. Ravelosona, and C. Chappert, “Compact modelling for co/bto/lsmo ferro-
electric tunnel junction,” in Nanotechnology (IEEE-NANO), 2013 13th IEEE
Conference on, Aug 2013, pp. 229–232.
[11] S. Boyn, S. Girod, V. Garcia, S. Fusil, S. Xavier, C. Deranlot, H. Yamada,
C. Carre´te´ro, E. Jacquet, M. Bibes, A. Barthelemy, and J. Grollier, “High-
performance ferroelectric memory based on fully patterned tunnel junctions,”
vol. 104, p. 052909, 02 2014.
[12] S. Boyn, “Ferroelectric tunnel junctions: memristors for neuromorphic comput-
ing,” Ph.D. dissertation, Paris Saclay, 2016.
[13] J. Henkel, S. Pagani, H. Amrouch, L. Bauer, and F. Samie, “Ultra-low power
and dependability for iot devices (invited paper for iot technologies),” in Design,
Automation Test in Europe Conference Exhibition (DATE), 2017, March 2017,
pp. 954–959.
[14] J. M. Cruz-Albrecht, M. W. Yung, and N. Srinivasa, “Energy-efficient neuron,
synapse and stdp integrated circuits,” IEEE Transactions on Biomedical Circuits
and Systems, vol. 6, no. 3, pp. 246–256, June 2012.
[15] R. Serrano-Gotarredona, M. Oster, P. Lichtsteiner, A. Linares-Barranco, R. Paz-
Vicente, F. Gomez-Rodriguez, L. Camunas-Mesa, R. Berner, M. Rivas-Perez,
53
REFERENCES
T. Delbruck, S. C. Liu, R. Douglas, P. Hafliger, G. Jimenez-Moreno, A. C. Ball-
cels, T. Serrano-Gotarredona, A. J. Acosta-Jimenez, and B. Linares-Barranco,
“Caviar: A 45k neuron, 5m synapse, 12g connects/s aer hardware sensory-
processing-learning-actuating system for high-speed visual object recognition and
tracking,” IEEE Transactions on Neural Networks, vol. 20, no. 9, pp. 1417–1438,
Sept 2009.
[16] S. B. Furber, F. Galluppi, S. Temple, and L. A. Plana, “The spinnaker project,”
Proceedings of the IEEE, vol. 102, no. 5, pp. 652–665, May 2014.
[17] S. Ambrogio, S. Balatti, V. Milo, R. Carboni, Z. Wang, A. Calderoni, N. Ra-
maswamy, and D. Ielmini, “Novel rram-enabled 1t1r synapse capable of low-
power stdp via burst-mode communication and real-time unsupervised machine
learning,” in 2016 IEEE Symposium on VLSI Technology, June 2016, pp. 1–2.
[18] D. Ielmini, S. Ambrogio, V. Milo, S. Balatti, and Z. Q. Wang, “Neuromorphic
computing with hybrid memristive/cmos synapses for real-time learning,” in
2016 IEEE International Symposium on Circuits and Systems (ISCAS), May
2016, pp. 1386–1389.
[19] J. Park, M. Kwak, K. Moon, J. Woo, D. Lee, and H. Hwang, “Tiox-based rram
synapse with 64-levels of conductance and symmetric conductance change by
adopting a hybrid pulse scheme for neuromorphic computing,” IEEE Electron
Device Letters, vol. PP, no. 99, pp. 1–1, 2016.
[20] J.-C. Liu, I.-T. Wang, C. W. Hsu, W. C. Luo, and T.-H. Hou, “Investigating mlc
variation of filamentary and non-filamentary rram,” in Proceedings of Techni-
cal Program - 2014 International Symposium on VLSI Technology, Systems and
Application (VLSI-TSA), April 2014, pp. 1–2.
54
REFERENCES
[21] S. Mueller, S. R. Summerfelt, J. Muller, U. Schroeder, and T. Mikolajick, “Ten-
nanometer ferroelectric Si:HfO2 films for next-generation fram capacitors,” IEEE
Electron Device Letters, vol. 33, no. 9, pp. 1300–1302, Sept 2012.
[22] M. Lines and A. Glass, Principles and Applications of Ferroelectrics and Related
Materials, ser. International series of monographs on physics. OUP Oxford,
1977. [Online]. Available: https://books.google.com/books?id=p6ruJH8C84kC
[23] T. S. Boescke, J. Mueller, D. Brauhaus, U. Schroeder, and
U. Boettger, “Ferroelectricity in hafnium oxide thin films.” Applied
Physics Letters, vol. 99, no. 10, p. 102903, 2011. [Online]. Avail-
able: http://ezproxy.rit.edu/login?url=http://search.ebscohost.com/login.aspx?
direct=true&db=afh&AN=65503915&site=ehost-live
[24] D. A. Buck, “Ferroelectrics for digital information storage and switches,” Mas-
ter’s thesis, Massachusetts Institute of Technology, June 1952.
[25] L. N. Ridenour, “Computer memories,” Scientific American, vol. 192, no. 6,
pp. 92–100, 1955. [Online]. Available: https://www.scientificamerican.com/
magazine/sa/1955/06-01/#article-the-amateur-scientist-1955-06
[26] H. Kohlstedt, N. Pertsev, J. Contreras, and R. Waser, “Theoretical current-
voltage characteristics of ferroelectric tunnel junctions,” PHYSICAL REVIEW
B, vol. 72, no. 12, SEP 2005.
[27] H. Takishita, T. Onagi, and K. Takeuchi, “Storage class memory based ssd per-
formance in consideration of error correction capabilities and write/read laten-
cies,” in 2016 IEEE Silicon Nanoelectronics Workshop (SNW), June 2016, pp.
92–93.
[28] V. Mohan, T. Bunker, L. Grupp, S. Gurumurthi, M. R. Stan, and S. Swan-
son, “Modeling power consumption of nand flash memories using flashpower,”
55
REFERENCES
IEEE Transactions on Computer-Aided Design of Integrated Circuits and Sys-
tems, vol. 32, no. 7, pp. 1031–1044, July 2013.
[29] I. Micron Technology, “Tn-29-19: Nand flash 101,” Tech. Rep., 2006. [Online].
Available: http://www.micron.com/∼/media/Documents/Products/Technical%
20Note/NAND%20Flash/tn2919 nand 101.pdf
[30] D. S. Chevitarese and M. N. D. Santos, “Real-time face tracking and recog-
nition on ibm neuromorphic chip,” in 2016 IEEE International Symposium on
Multimedia (ISM), Dec 2016, pp. 667–672.
[31] D. Liu, H. Cheng, R. Peng, and Y. Yin, “Two resistive switching behaviors in
ag/sio2/pt memristors,” in 2016 IEEE 16th International Conference on Nan-
otechnology (IEEE-NANO), Aug 2016, pp. 651–654.
[32] K.-H. Kim, S. Gaba, D. Wheeler, J. M. Cruz-Albrecht, T. Hussain,
N. Srinivasa, and W. Lu, “A functional hybrid memristor crossbar-array/cmos
system for data storage and neuromorphic applications,” Nano Letters,
vol. 12, no. 1, pp. 389–395, 2012, pMID: 22141918. [Online]. Available:
http://dx.doi.org/10.1021/nl203687n
[33] H. S. P. Wong, S. Raoux, S. Kim, J. Liang, J. P. Reifenberg, B. Rajendran,
M. Asheghi, and K. E. Goodson, “Phase change memory,” Proceedings of the
IEEE, vol. 98, no. 12, pp. 2201–2227, Dec 2010.
[34] L. Fuller, S. Parikh, and C. Amareshbabu, “Rit’s advanced cmos process
λ = 0.25 µm, lpoly = 0.5 µm, leff = 100 nm,” 2014. [Online]. Available:
https://people.rit.edu/lffeee/AdvCmosProcessIntegration.pdf
[35] P. Polakowski, S. Riedel, W. Weinreich, M. Rudolf, J. Sundqvist, K. Seidel, and
J. Muller, “Ferroelectric deep trench capacitors based on al:hfo2 for 3d non-
56
REFERENCES
volatile memory applications,” in 2014 IEEE 6th International Memory Work-
shop (IMW), May 2014, pp. 1–4.
[36] A. Chanthbouala, A. Crassous, V. Garcia, K. Bouzehouane, S. Fusil, X. Moya,
J. Allibe, B. Dlubak, J. Grollier, S. Xavier, C. Deranlot, A. Moshar, R. Proksch,
N. D. Mathur, M. Bibes, and A. Barthelemy, “Solid-state memories based on
ferroelectric tunnel junctions,” Nature Nanotechnology, vol. 7, no. 2, pp. 101–
104, 2012.
[37] S. Mueller, J. Muller, U. Schroeder, and T. Mikolajick, “Reliability character-
istics of ferroelectric Si:HfO2 thin films for memory applications,” IEEE Trans-
actions on Device and Materials Reliability, vol. 13, no. 1, pp. 93–97, March
2013.
[38] U. Schroeder, E. Yurchuk, S. Mueller, J. Mueller, S. Slesazeck, T. Schloesser,
M. Trentzsch, and T. Mikolajick, “Non-volatile data storage in hfo2-based ferro-
electric fets,” in 2012 12th Annual Non-Volatile Memory Technology Symposium
Proceedings, Oct 2013, pp. 60–63.
[39] Y. Liu, T. Kamei, K. Endo, S. O’uchi, J. Tsukada, H. Yamauchi,
T. Hayashida, Y. Ishikawa, T. Matsukawa, K. Sakamoto, A. Ogura, and
M. Masahara, “Nanoscale wet etching of physical-vapor-deposited titanium
nitride and its application to sub-30-nm-gate-length fin-type double-gate
metal–oxide–semiconductor field-effect transistor fabrication,” Japanese Journal
of Applied Physics, vol. 49, no. 6S, p. 06GH18, 2010. [Online]. Available:
http://stacks.iop.org/1347-4065/49/i=6S/a=06GH18
[40] J. Starzynski, “Selective hafnium oxide etchant,” Mar. 16 2006, uS




[41] U. Schroeder, E. Yurchuk, S. Mueller, J. Mueller, S. Slesazeck, T. Schloesser,
M. Trentzsch, and T. Mikolajick, “Non-volatile data storage in hfo2-based ferro-
electric fets,” in 2012 12th Annual Non-Volatile Memory Technology Symposium
Proceedings, Oct 2013, pp. 60–63.
58
Appendix A: Python Program Code
A.1 Core Code
1 #−*− coding: utf−8−*−
2 ”””
3 Created on Sun May 15 18:23:58 2016
4
5 @author: Spencer Pringle @ Rochester Institute of Technology
6 ”””
7
8 from pylab import *
9 from PyQt4 import QtGui, QtCore
10 from matplotlib.backends.backend qt4agg import (
11 FigureCanvasQTAgg as FigureCanvas ,
12 NavigationToolbar2QT as NavigationToolbar)
13 from matplotlib.figure import Figure
14 import sys
15 import GUI NEW
16
17 class ExampleApp(QtGui.QMainWindow , GUI NEW.Ui MainWindow):
18 def init (self):




23 self.Metal1Box.addItems([’SrRuO 3’,’Co’,’Al’,’Metal 1’])
24 self.Metal1Box.setCurrentIndex(0)
59
APPENDIX A. PYTHON PROGRAM CODE
25 self.Metal2Box.addItems([’PZT’,’La (0.67) Sr (0.33)MnO 3’,’p+ Silicon’
, ’Metal 2’])
26 self.Metal2Box.setCurrentIndex(0)
















43 global sigma p , sigma s , q, epsilon 0 , phi, sigma, k 1 , k 2 , a 0 , x,
y, meshSpace , potentialMesh , phi 2 , phi 1 , positiveMesh ,
negativeMesh
44 global e0, m0, kT, kb, h, m 0
45 global d, E a , epsilon f , P, h, h eV
46 global delta 1 , a 1 , E f 1
47 global delta 2 , a 2 , E f 2
60
APPENDIX A. PYTHON PROGRAM CODE
48 global G 2 , G 1 , x 1 , x 2 , phi bar pos , phi bar neg , x 1 index ,
x 2 index , m 0 , A tun , J 0 , J, v app , phi diff
49 global Ath pos , Jth pos , Ath neg , Jth neg , phi prime , phi prime pos ,
phi prime neg
50 global Atun pos , J0 pos , Jtun pos , Atun neg , J0 neg , Jtun neg , V, T,
R pos , R neg , m star
51 global Ran, numchild , i, w, items, WellDir, WellFermi , Bar Length Pos
, Bar Length Neg , x 1 pos , x 2 pos , V, h bar
52
53 epsilon 0=8.854E−12#free space perm [F/m]
54 T=300 #Temperature (K)
55 #Non−adjustable Constants
56 e0=8.854E−14 #Permittivity of free space [F/cm]
57 m 0 =9.11E−31 #Electron rest mass (kg)
58 h=6.626E−34 #Planck’s constant (mˆ 2*kg/sec)
59 q=1.6E−19 #Electron charge (C)
60 kb=1.38E−23 #Boltzman constant(J/K)
61 kT=(kb/q)*T #[eV]







69 #Initialize Ferroelectric Material Values
70 epsilon f=self.FerroDielectricConst.value()
61






76 #Initialize Metal 1 Values
77 E f 1=self.Metal1FermiEnergy.value()
78 if self.Metal1ScreenLength.value()==0:





83 #Initialize Metal 2 Values
84 #if self .Metal2Box.currentIndex()==2:
85 E f 2=self.Metal2FermiEnergy.value()
86 #else:
87 # E f 2=self .Metal2FermiEnergy.value()
88 if self.Metal2ScreenLength.value()==0:





93 #Calculate and store charges and wave vector magnitudes...
94 sigma p=P*1E−2
95 sigma s=sigma p*d/(epsilon f*(delta 1+delta 2)+d)
62




99 x 1 pos=x 1
100 x 2 pos=x 2
101 positiveMesh=potentialMesh
102 phi prime pos=phi prime
103 Ath pos=(4*pi*m 0*(kb**2)*q)/((h**3))
104 Jth pos = Ath pos*1E−4*(T**2)*exp(−phi prime pos/kT)*(1−exp(−abs(V)/
kT))
105 phi diff=phi 1−phi 2
106 Bar Length Pos=x 2−x 1
107 phi bar pos=mean(y[x 1 index:x 2 index])
108 Atun pos=((2*m 0*q*m star)**(1/2))*(Bar Length Pos)*(2e−9)/h bar
109 #Atun pos=(4*pi*(x 2−x 1)*1e−9*(2*m 0)**(1/2))/h
110 #J0 pos=(q)/(2*pi*h*(((x 2−x 1)*1E−9)**2))
111 J0 pos=(6.08e8)/((Bar Length Pos)**2)
112 Jtun pos=J0 pos*((phi bar pos)*exp(−Atun pos*((phi bar pos)**(1/2)))
−(phi bar pos+V)*exp(−Atun pos*((phi bar pos+V)**(1/2))))
113 R pos=np.zeros(size(V))
114 for i in range(0, size(V)):
115 if Jtun pos[i]!=0 and Jtun pos[i]!=’nan’:




120 Jtun pos=abs(Jtun pos)
63
APPENDIX A. PYTHON PROGRAM CODE
121 Itun pos=Jtun pos[np.where(V==.5)[0]]*(250e−7)**2
122 Itun pos 1 250=Jtun pos[[110][0]]*(250e−7)**2
123 Itun pos 2 250=Jtun pos[[120][0]]*(250e−7)**2
124 Itun pos 1 500=Jtun pos[[110][0]]*(500e−7)**2
125 Itun pos 2 500=Jtun pos[[120][0]]*(500e−7)**2
126 Rtun pos 250=.5/Itun pos
127 Rtun pos 1 250 =.1/ Itun pos 1 250
128 Rtun pos 1 500 =.1/ Itun pos 1 500
129 Rtun pos 2 250 =.2/ Itun pos 2 250
130 Rtun pos 2 500 =.2/ Itun pos 2 500
131 rho pos=.5/Jtun pos[np.where(V==.5)[0]]
132 rho pos 1 =.1/Jtun pos[[110][0]]
133 self.FrontOutput.insertPlainText(’Under Positive Polarization (toward
Metal 1), at .5V bias:’)
134 self.FrontOutput.insertPlainText(’\n’)
135 self.FrontOutput.insertPlainText(’\t J th=’+’%.2e’%Jth pos[np.where(V
==.5)[0]] +’ A/cm^2’)
136 self.FrontOutput.insertPlainText(’\n’)
137 self.FrontOutput.insertPlainText(’\t J tun=’+’%.2e’%Jtun pos[np.where
(V==.5)[0]] +’ A/cm^2’)
138 self.FrontOutput.insertPlainText(’\n’)
139 self.FrontOutput.insertPlainText(’\t I tun(250nm x 250nm)=’+’%.2e’%
Itun pos +’ A’)
140 self.FrontOutput.insertPlainText(’\n’)
141 self.FrontOutput.insertPlainText(’\n’)
142 self.FrontOutput.insertPlainText(’Under Positive Polarization (toward
Metal 1), at .2V bias:’)
64
APPENDIX A. PYTHON PROGRAM CODE
143 self.FrontOutput.insertPlainText(’\n’)
144 self.FrontOutput.insertPlainText(’\t J th=’+’%.2e’%Jth pos[[120][0]]
+’ A/cm^2’)
145 self.FrontOutput.insertPlainText(’\n’)
146 self.FrontOutput.insertPlainText(’\t J tun=’+’%.2e’%Jtun pos
[[120][0]] +’ A/cm^2’)
147 self.FrontOutput.insertPlainText(’\n’)
148 self.FrontOutput.insertPlainText(’\t I tun(250nm x 250nm)=’+’%.2e’%
Itun pos 2 250 +’ A’)
149 self.FrontOutput.insertPlainText(’\n’)
150 self.FrontOutput.insertPlainText(’\n’)
151 self.FrontOutput.insertPlainText(’Under Positive Polarization (toward
Metal 1), at .1V bias:’)
152 self.FrontOutput.insertPlainText(’\n’)
153 self.FrontOutput.insertPlainText(’\t J th=’+’%.2e’%Jth pos[[110][0]]
+’ A/cm^2’)
154 self.FrontOutput.insertPlainText(’\n’)
155 self.FrontOutput.insertPlainText(’\t J tun=’+’%.2e’%Jtun pos
[[110][0]] +’ A/cm^2’)
156 self.FrontOutput.insertPlainText(’\n’)
157 self.FrontOutput.insertPlainText(’\t I tun(250nm x 250nm)=’+’%.2e’%





162 sigma s=sigma p*d/(epsilon f*(delta 1+delta 2)+d)
65
APPENDIX A. PYTHON PROGRAM CODE
163 self.Potential()
164 x 1 neg=x 1
165 x 2 neg=x 2
166 negativeMesh=potentialMesh
167 phi prime neg=phi prime
168 Ath neg=(4*pi*m 0*(kb**2)*q)/((h**3))
169 Jth neg = Ath neg*1E−4*(T**2)*exp(−phi prime neg/kT)*(1−exp(−abs(V)/
kT))
170
171 Bar Length Neg=x 2−x 1
172 phi bar neg=mean(y[x 1 index:x 2 index])
173 Atun neg=((2*m 0*q*m star)**(1/2))*(Bar Length Neg)*(2e−9)/h bar
174 J0 neg=(6.08e8)/((Bar Length Neg)**2)
175 Jtun neg=J0 neg*((phi bar neg)*exp(−Atun neg*((phi bar neg)**(1/2)))
−((phi bar neg)+V)*exp(−Atun neg*(((phi bar neg)+V)**(1/2))))
176 R neg=np.zeros(size(V))
177 for i in range(0, size(V)):
178 if Jtun neg[i]!=0 and Jtun neg[i]!=’nan’:
179 R neg[i]=V[i]/Jtun neg[i]
180 else:
181 R neg[i]=’nan’
182 Jtun neg=abs(Jtun neg)
183 Itun neg=Jtun neg[np.where(V==.5)[0]]*(250e−7)**2
184 Itun neg 1 250=Jtun neg[[110][0]]*(250e−7)**2
185 Itun neg 1 500=Jtun neg[[110][0]]*(500e−7)**2
186 Itun neg 2 250=Jtun neg[[120][0]]*(250e−7)**2
187 Itun neg 2 500=Jtun neg[[120][0]]*(500e−7)**2
66
APPENDIX A. PYTHON PROGRAM CODE
188 Rtun neg 250=.5/Itun neg
189 Rtun neg 1 250 =.1/ Itun neg 1 250
190 Rtun neg 1 500 =.1/ Itun neg 1 500
191 Rtun neg 2 250 =.2/ Itun neg 2 250
192 Rtun neg 2 500 =.2/ Itun neg 2 500
193 rho neg=.5/Jtun neg[np.where(V==.5)[0]]
194 rho neg 1 =.1/Jtun neg[[110][0]]
195 self.FrontOutput.insertPlainText(’\n’)
196 self.FrontOutput.insertPlainText(’Under Negative Polarization (toward
Metal 2), at .5V bias:’)
197 self.FrontOutput.insertPlainText(’\n’)
198 self.FrontOutput.insertPlainText(’\t J th=’+’%.2e’%Jth neg[np.where(V
==.5)[0]] +’ A/cm^2’)
199 self.FrontOutput.insertPlainText(’\n’)
200 self.FrontOutput.insertPlainText(’\t J tun=’+’%.2e’%Jtun neg[np.where
(V==.5)[0]] +’ A/cm^2’)
201 self.FrontOutput.insertPlainText(’\n’)
202 self.FrontOutput.insertPlainText(’\t I tun(250nm x 250nm)=’+’%.2e’%
Itun neg +’ A’)
203 self.FrontOutput.insertPlainText(’\n’)
204 self.FrontOutput.insertPlainText(’\n’)
205 self.FrontOutput.insertPlainText(’Under Negative Polarization (toward
Metal 2), at .2V bias:’)
206 self.FrontOutput.insertPlainText(’\n’)




APPENDIX A. PYTHON PROGRAM CODE
209 self.FrontOutput.insertPlainText(’\t J tun=’+’%.2e’%Jtun neg
[[120][0]] +’ A/cm^2’)
210 self.FrontOutput.insertPlainText(’\n’)
211 self.FrontOutput.insertPlainText(’\t I tun(250nm x 250nm)=’+’%.2e’%
Itun neg 2 250 +’ A’)
212 self.FrontOutput.insertPlainText(’\n’)
213 self.FrontOutput.insertPlainText(’\t I tun(500nm x 500nm)=’+’%.2e’%
Itun neg 2 500 +’ A’)
214 self.FrontOutput.insertPlainText(’\n’)
215 self.FrontOutput.insertPlainText(’\n’)
216 self.FrontOutput.insertPlainText(’Under Negative Polarization (toward
Metal 2), at .1V bias:’)
217 self.FrontOutput.insertPlainText(’\n’)
218 self.FrontOutput.insertPlainText(’\t J th=’+’%.2e’%Jth neg[[110][0]]
+’ A/cm^2’)
219 self.FrontOutput.insertPlainText(’\n’)
220 self.FrontOutput.insertPlainText(’\t J tun=’+’%.2e’%Jtun neg
[[110][0]] +’ A/cm^2’)
221 self.FrontOutput.insertPlainText(’\n’)
222 self.FrontOutput.insertPlainText(’\t I tun(250nm x 250nm)=’+’%.2e’%
Itun neg 1 250 +’ A’)
223 self.FrontOutput.insertPlainText(’\n’)
224 self.FrontOutput.insertPlainText(’\t I tun(500nm x 500nm)=’+’%.2e’%
Itun neg 1 500 +’ A’)
225 self.FrontOutput.insertPlainText(’\n’)
226
227 phi diff=abs(phi bar pos−phi bar neg)
68
APPENDIX A. PYTHON PROGRAM CODE
228 if Jtun neg[np.where(V==.5)[0]]>Jtun pos[np.where(V==.5)[0]]:











238 self.FrontOutput.insertPlainText(’Difference in Average Potential
Barriers:\n’)
239 self.FrontOutput.insertPlainText(’\t’+’%.3f’%phi bar pos+’−’+’%.3f’%
phi bar neg +’=’+’%.3f’%phi diff + ’ eV\n’)
240 self.FrontOutput.insertPlainText(’\n’)
241 self.FrontOutput.insertPlainText(’Ratio of Tunnel Current at .5V Bias
in HRS vs. LRS:\n’)
242 self.FrontOutput.insertPlainText(’\t’+’%.3f’%Jtun Ratio+’\n’)
243 self.FrontOutput.insertPlainText(’\n’)
244 self.FrontOutput.insertPlainText(’LRS and HRS Resistances (250nm x
250nm, at .5V):\n’)
245 self.FrontOutput.insertPlainText(’\t Pos:’+’%.3e’%Rtun pos 250 +’ Ohm
\n\t Neg:’+’%.3e’%Rtun neg 250 +’ Ohm\n’)
246 self.FrontOutput.insertPlainText(’\n’)
247 self.FrontOutput.insertPlainText(’LRS and HRS Resistivity @ .5V:\n’)
69
APPENDIX A. PYTHON PROGRAM CODE
248 self.FrontOutput.insertPlainText(’\t Pos:’+’%.3e’%rho pos +’ Ohm cm
^2\n\t Neg:’+’%.3e’%rho neg +’ Ohm cm^2\n’)
249 self.FrontOutput.insertPlainText(’\n’)
250 self.FrontOutput.insertPlainText(’\n’)
251 self.FrontOutput.insertPlainText(’LRS and HRS Resistivity @ .1V:\n’)
252 self.FrontOutput.insertPlainText(’\t Pos:’+’%.3e’%rho pos 1 +’ Ohm cm
^2\n\t Neg:’+’%.3e’%rho neg 1 +’ Ohm cm^2\n’)
253 self.FrontOutput.insertPlainText(’\n’)
254 self.FrontOutput.insertPlainText(’\n’)
255 self.FrontOutput.insertPlainText(’LRS and HRS Resistances (250nm x
250nm, at .2V):\n’)
256 self.FrontOutput.insertPlainText(’\t Pos:’+’%.3e’%Rtun pos 2 250 +’
Ohm\n\t Neg:’+’%.3e’%Rtun neg 2 250 +’ Ohm\n’)
257 self.FrontOutput.insertPlainText(’\n’)
258 self.FrontOutput.insertPlainText(’LRS and HRS Resistances (500nm x
500nm, at .2V):\n’)
259 self.FrontOutput.insertPlainText(’\t Pos:’+’%.3e’%Rtun pos 2 500 +’
Ohm\n\t Neg:’+’%.3e’%Rtun neg 2 500 +’ Ohm\n’)
260 self.FrontOutput.insertPlainText(’\n’)
261 self.FrontOutput.insertPlainText(’\n’)
262 self.FrontOutput.insertPlainText(’LRS and HRS Resistances (250nm x
250nm, at .1V):\n’)
263 self.FrontOutput.insertPlainText(’\t Pos:’+’%.3e’%Rtun pos 1 250 +’
Ohm\n\t Neg:’+’%.3e’%Rtun neg 1 250 +’ Ohm\n’)
264 self.FrontOutput.insertPlainText(’\n’)
265 self.FrontOutput.insertPlainText(’LRS and HRS Resistances (500nm x
500nm, at .1V):\n’)
70
APPENDIX A. PYTHON PROGRAM CODE
266 self.FrontOutput.insertPlainText(’\t Pos:’+’%.3e’%Rtun pos 1 500 +’
Ohm\n\t Neg:’+’%.3e’%Rtun neg 1 500 +’ Ohm\n’)
267 self.FrontOutput.insertPlainText(’\n’)
268
269 Jtunratiomax = max(np.nan to num(np.divide(Jtun pos , Jtun neg)))





274 fig1 = Figure()





280 ax1f2 = fig2.add subplot(111)
281 ax1f2.plot(V, Jth pos)
282 ax1f2.plot(V, Jth neg)
283 ExampleApp.addmpl(self,fig2)
284 fig3=Figure()
285 ax1f3 = fig3.add subplot(111)
286 ax1f3.plot(V, Jtun pos)





APPENDIX A. PYTHON PROGRAM CODE
291 self.PotentialOutput.insertPlainText(’V\tJtunpos\tJtunneg\n’)
292 for i in range(0, size(V)):
293 self.PotentialOutput.insertPlainText(’%.3f’%V[i] + ’\t’ + ’
%.3e’%Jtun pos[i] + ’\t’ + ’%.3e’%Jtun neg[i] + ’\n’)
294 self.PotentialOutput.insertPlainText(’\n’)
295 self.PotentialOutput.insertPlainText(’X\tV1pos\tV2neg\n’)
296 for p in range(0, size(x)):
297 self.PotentialOutput.insertPlainText(’%.3f’%x[p] + ’\t’ + ’




300 global numchild , i, w, items
301 numchild=self.PotentialMPlay.count()
302 items = (self.PotentialMPlay.itemAt(i) for i in range(self.
PotentialMPlay.count()))











APPENDIX A. PYTHON PROGRAM CODE
313 def closeall(self): #solution found on http://python.6.x6.nabble.com/
Completely−removing−items−from−a−layout−td1924202.html
314 def deleteItems(layout):
315 if layout is not None:
316 while layout.count():
317 item = layout.takeAt(0)
318 widget = item.widget()







326 global P, x, index, y, x prime , potentialMesh , delta 1 , delta 2 ,
E f 1 , E f 2 , phi 2 , phi 1 , x 1 , x 2 , x 1 index , x 2 index ,
phi prime , WellDir, WellFermi
327
328 x = np.linspace(−5,5+(d*1E9),(5+(d*1E9))/meshSpace)
329 y = np.zeros(size(x))
330 index = 0
331 flag = 0
332 y flag=0
333
334 if delta 1<delta 2:
335 WellFermi=E f 2
336 WellDir=−1
73
APPENDIX A. PYTHON PROGRAM CODE
337 else:
338 WellFermi=E f 1
339 WellDir=1
340
341 for x prime in x:
342 if x prime<=0:
343 y[index]=(sigma s*delta 1/epsilon 0)*exp(−abs(x prime
*1E−9)/(delta 1))
344 elif x prime>=(d*1E9):
345 y[index]=(−sigma s*delta 2/epsilon 0)*exp(−abs((
x prime*1E−9)−d)/(delta 1))
346 if x prime<=0:
347 phi 1=y[index]





353 index = 0
354 for x u in x:
355 if x u>0 and x u<(d*(1E9)):
356 y[index]=phi 1−((x u/(d*1E9))*(phi 1−phi 2))
357 index=index+1
358 self.ModelingProgress.setValue(50+(index*25/size(x)))
359 index = 0
360 for x u in x:
361 if x u>0 and x u<(d*(1E9)):
74
APPENDIX A. PYTHON PROGRAM CODE
362 y[index]=y[index]+(E f 1−E a)+((x u/(d*1E9))*(E f 2−
E f 1))
363 if x u<=0:
364 phi 1=y[index]







372 for x u in x:
373 if y flag==0 and y[index]>phi prime/10:
374 x 1=x u
375 x 1 index=index
376 y flag=1
377 if y flag==1 and y[index]<phi prime/10:
378 x 2=x u






385 def addmpl(self, fig):
386 for clos in range(self.PotentialMPlay.count()):
387 try:
75





392 self.canvas = FigureCanvas(fig)
393 self.PotentialMPlay.addWidget(self.canvas)
394 self.canvas.draw()
395 self.toolbar = NavigationToolbar(self.canvas,

















































APPENDIX A. PYTHON PROGRAM CODE
440 def main():
441 if QtCore.QCoreApplication.instance() != None:
442 app = QtCore.QCoreApplication.instance()
443 else:
444 app = QtGui.QApplication(sys.argv) #Anew instance of QApplication
445 form = ExampleApp() #We set the form to be our
ExampleApp (design)
446 form.show() #Show the form
447 app.exec () #and execute the app
448
449
450 if name == ’ main ’: # if we’re running file directly and not
importing it
451 main() # run the main function
A.2 GUI Code
1 #−*− coding: utf−8−*−
2
3 #Form implementation generated from reading ui file ’FTJ GUI Pringle Single Page.ui’
4 #
5 # Created by: PyQt4 UI code generator 4.11.4
6 #
7 #WARNING! All changes made in this file will be lost!
8
9 from PyQt4 import QtCore, QtGui
10
78
APPENDIX A. PYTHON PROGRAM CODE
11 try:






18 encoding = QtGui.QApplication.UnicodeUTF8
19 def translate(context, text, disambig):
20 return QtGui.QApplication.translate(context, text, disambig,
encoding)
21 except AttributeError:
22 def translate(context, text, disambig):
23 return QtGui.QApplication.translate(context, text, disambig)
24
25 class Ui MainWindow(object):
26 def setupUi(self, MainWindow):
27 MainWindow.setObjectName( fromUtf8("MainWindow"))
28 MainWindow.resize(941, 739)
29 self.centralwidget = QtGui.QWidget(MainWindow)
30 self.centralwidget.setObjectName( fromUtf8("centralwidget"))
31 self.gridLayout = QtGui.QGridLayout(self.centralwidget)
32 self.gridLayout.setObjectName( fromUtf8("gridLayout"))
33 self.splitter 5 = QtGui.QSplitter(self.centralwidget)
34 self.splitter 5.setOrientation(QtCore.Qt.Vertical)
35 self.splitter 5.setObjectName( fromUtf8("splitter 5"))
36 self.splitter = QtGui.QSplitter(self.splitter 5)
79
APPENDIX A. PYTHON PROGRAM CODE
37 self.splitter.setOrientation(QtCore.Qt.Horizontal)
38 self.splitter.setObjectName( fromUtf8("splitter"))
39 self.layoutWidget = QtGui.QWidget(self.splitter)
40 self.layoutWidget.setObjectName( fromUtf8("layoutWidget"))
41 self.verticalLayout 7 = QtGui.QVBoxLayout(self.layoutWidget)
42 self.verticalLayout 7.setObjectName( fromUtf8("verticalLayout 7"))
43 self.verticalLayout 4 = QtGui.QVBoxLayout()
44 self.verticalLayout 4.setObjectName( fromUtf8("verticalLayout 4"))
45 self.verticalLayout = QtGui.QVBoxLayout()
46 self.verticalLayout.setObjectName( fromUtf8("verticalLayout"))
47 self.groupBox = QtGui.QGroupBox(self.layoutWidget)
48 self.groupBox.setObjectName( fromUtf8("groupBox"))
49 self.gridLayout 3 = QtGui.QGridLayout(self.groupBox)
50 self.gridLayout 3.setObjectName( fromUtf8("gridLayout 3"))
51 self.verticalLayout 3 = QtGui.QVBoxLayout()
52 self.verticalLayout 3.setObjectName( fromUtf8("verticalLayout 3"))
53 self.horizontalLayout 2 = QtGui.QHBoxLayout()
54 self.horizontalLayout 2.setObjectName( fromUtf8("horizontalLayout 2")
)
55 self.label = QtGui.QLabel(self.groupBox)
56 self.label.setObjectName( fromUtf8("label"))
57 self.horizontalLayout 2.addWidget(self.label)
58 self.label 2 = QtGui.QLabel(self.groupBox)
59 self.label 2.setObjectName( fromUtf8("label 2"))
60 self.horizontalLayout 2.addWidget(self.label 2)
61 self.label 3 = QtGui.QLabel(self.groupBox)
62 self.label 3.setObjectName( fromUtf8("label 3"))
80
APPENDIX A. PYTHON PROGRAM CODE
63 self.horizontalLayout 2.addWidget(self.label 3)
64 self.verticalLayout 3.addLayout(self.horizontalLayout 2)
65 self.horizontalLayout = QtGui.QHBoxLayout()
66 self.horizontalLayout.setObjectName( fromUtf8("horizontalLayout"))
67 self.Metal1Box = QtGui.QComboBox(self.groupBox)
68 self.Metal1Box.setObjectName( fromUtf8("Metal1Box"))
69 self.horizontalLayout.addWidget(self.Metal1Box)
70 self.FerroBox = QtGui.QComboBox(self.groupBox)
71 self.FerroBox.setObjectName( fromUtf8("FerroBox"))
72 self.horizontalLayout.addWidget(self.FerroBox)




77 self.gridLayout 3.addLayout(self.verticalLayout 3 , 0, 0, 1, 1)
78 self.verticalLayout.addWidget(self.groupBox)
79 self.verticalLayout 4.addLayout(self.verticalLayout)
80 self.verticalLayout 7.addLayout(self.verticalLayout 4)
81 self.splitter 4 = QtGui.QSplitter(self.layoutWidget)
82 self.splitter 4.setOrientation(QtCore.Qt.Vertical)
83 self.splitter 4.setObjectName( fromUtf8("splitter 4"))
84 self.layoutWidget1 = QtGui.QWidget(self.splitter 4)
85 self.layoutWidget1.setObjectName( fromUtf8("layoutWidget1"))
86 self.verticalLayout 12 = QtGui.QVBoxLayout(self.layoutWidget1)
87 self.verticalLayout 12.setObjectName( fromUtf8("verticalLayout 12"))
88 self.label 14 = QtGui.QLabel(self.layoutWidget1)
89 self.label 14.setObjectName( fromUtf8("label 14"))
81
APPENDIX A. PYTHON PROGRAM CODE
90 self.verticalLayout 12.addWidget(self.label 14)
91 self.horizontalLayout 4 = QtGui.QHBoxLayout()
92 self.horizontalLayout 4.setObjectName( fromUtf8("horizontalLayout 4")
)
93 self.Metal1Group = QtGui.QGroupBox(self.layoutWidget1)
94 self.Metal1Group.setObjectName( fromUtf8("Metal1Group"))
95 self.horizontalLayout 3 = QtGui.QHBoxLayout(self.Metal1Group)
96 self.horizontalLayout 3.setObjectName( fromUtf8("horizontalLayout 3")
)
97 self.verticalLayout 9 = QtGui.QVBoxLayout()
98 self.verticalLayout 9.setObjectName( fromUtf8("verticalLayout 9"))
99 self.label 4 = QtGui.QLabel(self.Metal1Group)
100 self.label 4.setObjectName( fromUtf8("label 4"))
101 self.verticalLayout 9.addWidget(self.label 4)






107 self.label 5 = QtGui.QLabel(self.Metal1Group)
108 self.label 5.setObjectName( fromUtf8("label 5"))
109 self.verticalLayout 9.addWidget(self.label 5)





APPENDIX A. PYTHON PROGRAM CODE
114 self.label 7 = QtGui.QLabel(self.Metal1Group)
115 self.label 7.setObjectName( fromUtf8("label 7"))
116 self.verticalLayout 9.addWidget(self.label 7)




121 self.horizontalLayout 3.addLayout(self.verticalLayout 9)
122 self.horizontalLayout 4.addWidget(self.Metal1Group)
123 self.FerroGroup = QtGui.QGroupBox(self.layoutWidget1)
124 self.FerroGroup.setObjectName( fromUtf8("FerroGroup"))
125 self.horizontalLayout 5 = QtGui.QHBoxLayout(self.FerroGroup)
126 self.horizontalLayout 5.setObjectName( fromUtf8("horizontalLayout 5")
)
127 self.verticalLayout 11 = QtGui.QVBoxLayout()
128 self.verticalLayout 11.setObjectName( fromUtf8("verticalLayout 11"))
129 self.label 12 = QtGui.QLabel(self.FerroGroup)
130 self.label 12.setObjectName( fromUtf8("label 12"))
131 self.verticalLayout 11.addWidget(self.label 12)






137 self.label 6 = QtGui.QLabel(self.FerroGroup)
138 self.label 6.setObjectName( fromUtf8("label 6"))
83
APPENDIX A. PYTHON PROGRAM CODE
139 self.verticalLayout 11.addWidget(self.label 6)




144 self.label 9 = QtGui.QLabel(self.FerroGroup)
145 self.label 9.setObjectName( fromUtf8("label 9"))
146 self.verticalLayout 11.addWidget(self.label 9)




151 self.label 13 = QtGui.QLabel(self.FerroGroup)
152 self.label 13.setObjectName( fromUtf8("label 13"))
153 self.verticalLayout 11.addWidget(self.label 13)




158 self.horizontalLayout 5.addLayout(self.verticalLayout 11)
159 self.horizontalLayout 4.addWidget(self.FerroGroup)
160 self.Metal2Group = QtGui.QGroupBox(self.layoutWidget1)
161 self.Metal2Group.setObjectName( fromUtf8("Metal2Group"))
162 self.horizontalLayout 6 = QtGui.QHBoxLayout(self.Metal2Group)
163 self.horizontalLayout 6.setObjectName( fromUtf8("horizontalLayout 6")
)
164 self.verticalLayout 10 = QtGui.QVBoxLayout()
84
APPENDIX A. PYTHON PROGRAM CODE
165 self.verticalLayout 10.setObjectName( fromUtf8("verticalLayout 10"))
166 self.label 11 = QtGui.QLabel(self.Metal2Group)
167 self.label 11.setObjectName( fromUtf8("label 11"))
168 self.verticalLayout 10.addWidget(self.label 11)






174 self.label 8 = QtGui.QLabel(self.Metal2Group)
175 self.label 8.setObjectName( fromUtf8("label 8"))
176 self.verticalLayout 10.addWidget(self.label 8)




181 self.label 10 = QtGui.QLabel(self.Metal2Group)
182 self.label 10.setObjectName( fromUtf8("label 10"))
183 self.verticalLayout 10.addWidget(self.label 10)




188 self.horizontalLayout 6.addLayout(self.verticalLayout 10)
189 self.horizontalLayout 4.addWidget(self.Metal2Group)
190 self.verticalLayout 12.addLayout(self.horizontalLayout 4)
85
APPENDIX A. PYTHON PROGRAM CODE
191 self.splitter 3 = QtGui.QSplitter(self.splitter 4)
192 self.splitter 3.setOrientation(QtCore.Qt.Horizontal)
193 self.splitter 3.setObjectName( fromUtf8("splitter 3"))
194 self.RunModeling = QtGui.QPushButton(self.splitter 3)
195 self.RunModeling.setObjectName( fromUtf8("RunModeling"))
196 self.FrontOutput = QtGui.QTextBrowser(self.splitter 3)
197 self.FrontOutput.setMaximumSize(QtCore.QSize(16777215, 16777215))
198 self.FrontOutput.setObjectName( fromUtf8("FrontOutput"))
199 self.verticalLayout 7.addWidget(self.splitter 4)
200 self.layoutWidget2 = QtGui.QWidget(self.splitter)
201 self.layoutWidget2.setObjectName( fromUtf8("layoutWidget2"))
202 self.verticalLayout 14 = QtGui.QVBoxLayout(self.layoutWidget2)
203 self.verticalLayout 14.setObjectName( fromUtf8("verticalLayout 14"))
204 self.splitter 2 = QtGui.QSplitter(self.layoutWidget2)
205 self.splitter 2.setOrientation(QtCore.Qt.Vertical)
206 self.splitter 2.setObjectName( fromUtf8("splitter 2"))
207 self.verticalWidget 6 = QtGui.QWidget(self.splitter 2)
208 self.verticalWidget 6.setObjectName( fromUtf8("verticalWidget 6"))
209 self.verticalLayout 8 = QtGui.QVBoxLayout(self.verticalWidget 6)
210 self.verticalLayout 8.setObjectName( fromUtf8("verticalLayout 8"))
211 self.PotentialMPlay = QtGui.QVBoxLayout()
212 self.PotentialMPlay.setObjectName( fromUtf8("PotentialMPlay"))
213 self.verticalLayout 8.addLayout(self.PotentialMPlay)
214 self.PotentialOutput = QtGui.QTextBrowser(self.splitter 2)
215 self.PotentialOutput.setMaximumSize(QtCore.QSize(16777215, 16777215))
216 self.PotentialOutput.setObjectName( fromUtf8("PotentialOutput"))
217 self.verticalLayout 14.addWidget(self.splitter 2)
86
APPENDIX A. PYTHON PROGRAM CODE
218 self.widget = QtGui.QWidget(self.splitter 5)
219 self.widget.setObjectName( fromUtf8("widget"))
220 self.verticalLayout 2 = QtGui.QVBoxLayout(self.widget)
221 self.verticalLayout 2.setObjectName( fromUtf8("verticalLayout 2"))




226 self.horizontalLayout 7 = QtGui.QHBoxLayout()
227 self.horizontalLayout 7.setSizeConstraint(QtGui.QLayout.
SetDefaultConstraint)
228 self.horizontalLayout 7.setObjectName( fromUtf8("horizontalLayout 7")
)
229 self.label 16 = QtGui.QLabel(self.widget)
230 self.label 16.setObjectName( fromUtf8("label 16"))
231 self.horizontalLayout 7.addWidget(self.label 16)
232 self.label 15 = QtGui.QLabel(self.widget)
233 self.label 15.setObjectName( fromUtf8("label 15"))
234 self.horizontalLayout 7.addWidget(self.label 15)
235 self.verticalLayout 2.addLayout(self.horizontalLayout 7)
236 self.gridLayout.addWidget(self.splitter 5 , 0, 0, 1, 1)
237 MainWindow.setCentralWidget(self.centralwidget)






APPENDIX A. PYTHON PROGRAM CODE
243 QtCore.QMetaObject.connectSlotsByName(MainWindow)
244
245 def retranslateUi(self, MainWindow):
246 MainWindow.setWindowTitle( translate("MainWindow", "MainWindow", None
))
247 self.groupBox.setTitle( translate("MainWindow", "Materials", None))
248 self.label.setText( translate("MainWindow", "Metal 1", None))
249 self.label 2.setText( translate("MainWindow", "Ferroelectric", None))
250 self.label 3.setText( translate("MainWindow", "Metal 2", None))
251 self.label 14.setText( translate("MainWindow", "If you know the metal
screening lengths, enter them below and leave lattice constant
as 0.\n"
252 " Otherwise , leave them as 0 and enter the lattice constant, and the program will
calculate an approx. screening length.", None))
253 self.Metal1Group.setTitle( translate("MainWindow", "Metal 1", None))
254 self.label 4.setText( translate("MainWindow", "Screening Length (nm)"
, None))
255 self.label 5.setText( translate("MainWindow", "Fermi Energy (eV)",
None))
256 self.label 7.setText( translate("MainWindow", "Lattice Constant (
Angstrom)", None))
257 self.FerroGroup.setTitle( translate("MainWindow", "Ferroelectric",
None))
258 self.label 12.setText( translate("MainWindow", "Dielectric Constant (
E f/E 0)", None))
259 self.label 6.setText( translate("MainWindow", "Bandgap (eV)", None))
88
APPENDIX A. PYTHON PROGRAM CODE
260 self.label 9.setText( translate("MainWindow", "Polarization (micro C/
cm^2)", None))
261 self.label 13.setText( translate("MainWindow", "Thickness (nm)", None
))
262 self.Metal2Group.setTitle( translate("MainWindow", "Metal 2", None))
263 self.label 11.setText( translate("MainWindow", "Screening Length (nm)
", None))
264 self.label 8.setText( translate("MainWindow", "Fermi Energy (eV)",
None))
265 self.label 10.setText( translate("MainWindow", "Lattice Constant (
Angstrom)", None))
266 self.RunModeling.setText( translate("MainWindow", "Model This!\n"
267 "\n"
268 "Output values\n"
269 "will appear to the\n"
270 " right−−−>\n"
271 "\n"
272 "Energy band is plotted\n"
273 "at far right.\n"
274 "\n"
275 "Further plots will be found\n"
276 " on other tabs.", None))
277 self.label 16.setText( translate("MainWindow", "May 2016, sap1951@rit
.edu, (585) 236−9510", None))
278 self.label 15.setText( translate("MainWindow", "Created by Spencer
Pringle for Rochester Institute of Technology , 1 Lomb Drive,
Rochester , NY 14623", None))
89




































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































Appendix C: Athena code




5 line x loc =0.0 spac =0.02
6 line x loc =96.6 spac =0.02
7 #
8 line y loc =0.00 spac =0.02
9 line y loc=2 spac =0.02
10 line y loc=3 spac =0.1
11 line y loc=5 spac =0.1
12
13 method grid.oxide =.01 gridinit.ox=.01
14









22 diffus time =27 temp =25 t.final =800 nitro
23 diffus time =20 temp =800 t.final =1000 f.o2=5
24 diffus time =50 temp =1000 f.o2=10
25 diffus time=5 temp =1000 f.n2=15
26 diffus time =40 temp =1000 t.final =800 f.n2=10
27 diffus time =15 temp =800 t.final =25 f.n2=5
28
29 #CV02
30 deposit nitride thick =0.15
31
32 #PH03
33 deposit photoresist thick =1.00
34 etch photoresist start x=39.10 y=-2.00
35 etch cont x=49.10 y=-2.00
36 etch cont x=49.10 y=3.00
37 etch cont x=39.10 y=3.00
38 etch done x=39.10 y=-2.00
39 etch photoresist start x=87.60 y=-2.00
40 etch cont x=91.60 y=-2.00
41 etch cont x=91.60 y=3.00
42 etch cont x=87.60 y=3.00
43 etch done x=87.60 y=-2.00
44 etch photoresist left p1.x=2
45 etch photoresist right p1.x=93.6
46
47 #ET29
48 etch nitride right p1.x=93.6
49 etch nitride start x=39.10 y=-2.00
50 etch cont x=49.10 y=-2.00
51 etch cont x=49.10 y=3.00
52 etch cont x=39.10 y=3.00
53 etch done x=39.10 y=-2.00
54 etch nitride start x=87.60 y=-2.00
55 etch cont x=91.60 y=-2.00
56 etch cont x=91.60 y=3.00
57 etch cont x=87.60 y=3.00
58 etch done x=87.60 y=-2.00
59 etch nitride left p1.x=2
60
61 #ET07






68 diffus time =27 temp =25 t.final =800 nitro
69 diffus time =20 temp =800 t.final =1000 f.n2=5
70 diffus time=5 temp =1000 f.o2=2
71 diffus time =50 temp =1000 f.h2=3.6 f.o2=2
72 diffus time=5 temp =1000 f.n2=15
73 diffus time =40 temp =1000 t.final =800 f.n2=10
74 diffus time =15 temp =800 t.final =25 f.n2=5
75
76 #ET06
77 rate.etch machine=BOE(7to1) oxide u.m wet.etch
isotropic =0.1
78 etch machine=BOE(7to1) time =3.6 minutes
79
80 #OX04
81 diffus time =27 temp =25 t.final =800 nitro
82 diffus time =20 temp =800 t.final =1000 f.n2=5
83 diffus time=5 temp =1000 f.o2=2
84 diffus time =50 temp =1000 f.h2=3.6 f.o2=2
85 diffus time=5 temp =1000 f.n2=15
86 diffus time =40 temp =1000 t.final =800 f.n2=10
87 diffus time =15 temp =800 t.final =25 f.n2=5
88
89 #ET19
90 etch nitride all
91
92 #PH03
93 deposit photoresist thick =1.00
94 etch photoresist start x=0.00 y=-2.00
95 etch cont x=44.10 y=-2.00
96 etch cont x=44.10 y=3.00
97 etch cont x=0.00 y=3.00
98 etch done x=0.00 y= -2.00
99 etch photoresist start x=90.60 y=-2.00
100 etch cont x=94.6 y= -2.00
101 etch cont x=94.6 y=3.00
93
APPENDIX C. ATHENA CODE
102 etch cont x=90.6 y=3.00








110 etch photoresist all
111
112 #PH03
113 deposit photoresist thick =1.00
114 etch photoresist start x=44.1 y= -2.00
115 etch cont x=88.6 y= -2.00
116 etch cont x=88.6 y=3.00
117 etch cont x=44.1 y=3.00
118 etch done x=44.1 y= -2.00
119
120 #IM01




124 etch photoresist all
125
126 #OX06
127 diffus time =27 temp =25 t.final =800 nitro
128 diffus time =30 temp =800 t.final =1100 f.n2=10
129 diffus time =360 temp =1100 f.n2=10
130 diffus time=5 temp =1100 f.n2=10
131 diffus time =60 temp =1100 t.final =800 f.n2=10
132 diffus time =12 temp =800 t.final =25 f.n2=5
133
134 #PH03
135 deposit photoresist thick =1.00
136 etch photoresist start x=44.1 y= -2.00
137 etch cont x=88.6 y= -2.00
138 etch cont x=88.6 y=3.00
139 etch cont x=44.1 y=3.00
140 etch done x=44.1 y= -2.00
141 etch photoresist left p1.x=2
142
143 #IM01




147 etch photoresist all
148
149 #PH03
150 deposit photoresist thick =1.00
151 etch photoresist start x=2.00 y= -2.00
152 etch cont x=44.10 y=-2.00
153 etch cont x=44.10 y=3.00
154 etch cont x=2.00 y=3.00
155 etch done x=2.00 y= -2.00
156
157 #IM01




161 etch photoresist all
162




167 rate.etch machine=H2O_HF (50 to1) oxide n.m wet.etch
isotropic =18.7









177 deposit oxide thick =0.01
178
179 #CV01
180 deposit polysilicon thick =0.40
181
182 #PH03
183 deposit photoresist thick =1.00
184 etch photoresist left p1.x=30.6
185 etch photoresist start x=32.60 y=-2.00
186 etch cont x=55.60 y=-2.00
187 etch cont x=55.60 y=3.00
188 etch cont x=32.60 y=3.00
189 etch done x=32.60 y=-2.00
190 etch photoresist right p1.x=57.60
191
192 #ET08
193 etch polysilicon left p1.x=30.6
194 etch polysilicon start x=32.60 y=-2.00
195 etch cont x=55.60 y=-2.00
196 etch cont x=55.60 y=3.00
197 etch cont x=32.60 y=3.00
198 etch done x=32.60 y=-2.00
199 etch polysilicon right p1.x=57.60
200
201 #ET07






208 diffus time =27 temp =25 t.final =800 nitro
94
APPENDIX C. ATHENA CODE
209 deposit oxide thick =0.05
210 diffus time =20 temp =800 t.final =1000 f.n2=5
211 diffus time =50 temp =1000 f.n2=10
212 diffus time=5 temp =1000 f.n2=15
213 diffus time =40 temp =1000 t.final =800 f.n2=10
214 diffus time =15 temp =800 t.final =25 f.n2=5
215
216 #PH03
217 deposit photoresist thick =4.00
218 etch photoresist start x=10.00 y=-6.00
219 etch cont x=44.30 y=-6.00
220 etch cont x=44.30 y=3.00
221 etch cont x=10.00 y=3.00
222 etch done x=10.00 y=-6.00
223 etch photoresist start x=80.60 y=-6.00
224 etch cont x=88.6 y= -6.00
225 etch cont x=88.6 y=3.00
226 etch cont x=80.6 y=3.00
227 etch done x=80.6 y= -6.00
228
229 #IM01




233 etch photoresist all
234
235 #PH03
236 deposit photoresist thick =4.00
237 etch photoresist start x=44.30 y=-6.00
238 etch cont x=80.60 y=-6.00
239 etch cont x=80.60 y=3.00
240 etch cont x=44.30 y=3.00
241 etch done x=44.30 y=-6.00
242 etch photoresist left p1.x=10
243
244 #IM01




248 etch photoresist all
249
250 #CL01
251 struct outfile = CMOSPreNitride.str
252
253 #CV02
254 deposit nitride thick =0.35
255
256 #ET39
257 etch nitride dry thick =0.40
258
259 #PH03
260 deposit photoresist thick =4.00
261 etch photoresist start x=44.30 y=-6.00
262 etch cont x=80.60 y=-6.00
263 etch cont x=80.60 y=3.00
264 etch cont x=44.30 y=3.00
265 etch done x=44.30 y=-6.00
266 etch photoresist left p1.x=10
267
268 #IM01




272 etch photoresist all
273
274 #PH03
275 deposit photoresist thick =4.00
276 etch photoresist start x=10.00 y=-6.00
277 etch cont x=44.30 y=-6.00
278 etch cont x=44.30 y=3.00
279 etch cont x=10.00 y=3.00
280 etch done x=10.00 y=-6.00
281 etch photoresist start x=80.60 y=-6.00
282 etch cont x=88.6 y= -6.00
283 etch cont x=88.6 y=3.00
284 etch cont x=80.6 y=3.00
285 etch done x=80.6 y= -6.00
286 etch photoresist start x=90.60 y=-2.00
287 etch cont x=94.6 y= -2.00
288 etch cont x=94.6 y=3.00
289 etch cont x=90.6 y=3.00
290 etch done x=0.00 y= -2.00
291
292 #IM01




296 etch photoresist all
297
298 #CL01
299 struct outfile = CMOSPostNitride.str
300
301 #OX08
302 diffus time =27 temp =25 t.final =800 nitro
303 diffus time =20 temp =800 t.final =1000 f.n2=5
304 diffus time =20 temp =1000 f.n2=10
305 diffus time=5 temp =1000 f.n2=15
306 diffus time =40 temp =1000 t.final =800 f.n2=10
307 diffus time =15 temp =800 t.final =25 f.n2=5
308
309 #ET06
310 rate.etch machine=H2O_HF (50 to1) oxide n.m wet.etch
isotropic =18.7
311 etch machine=H2O_HF (50 to1) time=3 minutes
312
313 #was 3.6 minutes
314
315 struct outfile = CMOSSD2.str
95
















331 deposit oxide thick =0.50 divisions =20
332 #added the divisions =20
333
334 #PH03
335 deposit photoresist thick =1.00
336 etch photoresist start x=4.00 y= -6.00
337 etch cont x=6.00 y= -6.00
338 etch cont x=6.00 y=3.00
339 etch cont x=4.00 y=3.00
340 etch done x=4.00 y= -6.00
341 etch photoresist start x=11.00 y=-6.00
342 etch cont x=13.00 y=-6.00
343 etch cont x=13.00 y=3.00
344 etch cont x=11.00 y=3.00
345 etch done x=11.00 y=-6.00
346 etch photoresist start x=35.60 y=-6.00
347 etch cont x=37.60 y=-6.00
348 etch cont x=37.60 y=3.00
349 etch cont x=35.60 y=3.00
350 etch done x=35.60 y=-6.00
351 etch photoresist start x=50.10 y=-6.00
352 etch cont x=52.10 y=-6.00
353 etch cont x=52.10 y=3.00
354 etch cont x=50.10 y=3.00
355 etch done x=50.10 y=-6.00
356 etch photoresist start x=74.80 y=-6.00
357 etch cont x=76.80 y=-6.00
358 etch cont x=76.80 y=3.00
359 etch cont x=74.80 y=3.00
360 etch done x=74.80 y=-6.00
361 etch photoresist start x=83.60 y=-6.00
362 etch cont x=85.60 y=-6.00
363 etch cont x=85.60 y=3.00
364 etch cont x=83.60 y=3.00
365 etch done x=83.60 y=-6.00
366 etch photoresist start x=90.60 y=-6.00
367 etch cont x=94.60 y=-6.00
368 etch cont x=94.60 y=3.00
369 etch cont x=90.60 y=3.00




374 etch oxide dry thick =0.5
375
376 #ET07






383 deposit aluminum thick =0.75
384
385 #PH03
386 deposit photoresist thick =1.30
387 etch photoresist left p1.x=2.00
388 etch photoresist start x=14.00 y=-6.00
389 etch cont x=34.60 y=-6.00
390 etch cont x=34.60 y=3.00
391 etch cont x=14.00 y=3.00
392 etch done x=14.00 y=-6.00
393 etch photoresist start x=53.60 y=-6.00
394 etch cont x=73.80 y=-6.00
395 etch cont x=73.80 y=3.00
396 etch cont x=53.60 y=3.00
397 etch done x=53.60 y=-6.00
398 etch photoresist start x=87.60 y=-6.00
399 etch cont x=92.10 y=-6.00
400 etch cont x=92.10 y=3.00
401 etch cont x=87.60 y=3.00
402 etch done x=87.60 y=-6.00
403
404 #ET15
405 etch aluminum dry thick =1.00
406
407 #ET07
408 etch photoresist all
409





Appendix D: sap1951 FTJ THESIS 45
D.1 Linear Resistance FTJ Model
Library Name: sap1951 FTJ THESIS 45
Cell Name: SAP FTJ DIGITAL LOW
Layout Area:
(45nm CMOS) 0.135µm × 0.075µm = W ×H
(Scaled 2um CMOS) 6 µm × 3.3 µm= W ×H
Symbol with Port Names:
Layout:
97
APPENDIX D. SAP1951 FTJ THESIS 45
D.1.1 Verilog Model














14 parameter R_pos = 1e6; // On
resistance 9e6
15 parameter R_neg = 1e7; // Off resistance
1.4e8
16 parameter dr = 34.35e6; // abs(R_pos -
R_neg) 1.31e8
17 parameter dt = 40; //20
18 parameter x0 = 0.5;
19 parameter v_pos = 0.3; //
20 parameter v_neg = -0.3; //
21
98




25 integer voltages; // voltages
file pointer





30 voltages = $fopen("voltages.out");
31 currents = $fopen("currents.out");
32 Rm = (1-x0)*R_neg + x0*R_pos;
33 end
34
35 // Get the terminal voltage
36 Vm = V(p,n);
37
38 // Change the memristance









APPENDIX D. SAP1951 FTJ THESIS 45
47
48 Im = Vm / Rm;














APPENDIX D. SAP1951 FTJ THESIS 45
D.2 Polarization-Timing FTJ Model
Library Name: sap1951 FTJ THESIS 45
Cell Name: SAP FTJ DIGITAL LOW TIMING
Layout Area:
(45nm CMOS)0.135µm × 0.075µm = W ×H
(Scaled 2um CMOS)6 µm × 3.3 µm= W ×H
Symbol with Port Names:
Layout:
101
APPENDIX D. SAP1951 FTJ THESIS 45
D.2.1 Verilog Model














14 parameter Vc =0.4; //0.3
15 parameter Vc0 =0.9;
16 parameter kb =1.38e-23;
17 parameter pi =3.14159;
18 parameter m0 =9.11e-31;




23 parameter heV =4.13e-15;
24 parameter T=300;
102













37 parameter AA =445.402;
38 parameter AB =118.125;
39 parameter AC =7.782;
40 parameter BA = -416.102;
41 parameter BB = -112.071;
42 parameter BC= -7.525;
43 parameter ALA =22;
44 parameter ALB =5.8;
45 parameter ALC =0.26;
46 real d=10*Vc*1e-9;
47 parameter delta1 =0.06*1e-9;
48 parameter delta2 =3.0*1e-9; //0.4*1e-9
49 parameter epsilonf =40;
50 parameter epsilon0 =8.854e-12;
51 parameter Ea=2;
103
APPENDIX D. SAP1951 FTJ THESIS 45
52 parameter Ef1 =4.08;
53 parameter Ef2 =5.12;
54 real Atun=sqrt ((2*m0*q*mstar))*(d)*(2)/
hbar;
55 real J0 =(6.08 e8)/((d*1e9)**2);
56 parameter Dim =500; //dimension of FTJ (in








































94 real tPr [0:13];
95 real Pr [0:13];
96 real tSat [0:13] = ’{1e-2, 5e-4, 5e-3, 1e
-4, 5e-6, 5e-6, 5e-6, 5e-6, 2e-6, 2e-6,













107 voltages = $fopen("voltages.out");
108 currents = $fopen("currents.out");
109 Rm = 1.3e7;
110 time0 = 1e-13;
111 //$display("The coercive voltage is
currently %e at %e seconds", Vc,
$abstime);
112 //$display("J0 is %e and Atun is %e", J0,
Atun);
113 //$display("4 is %e and 4**2 is %e", 4,
4**2);
114 end
115 //Get terminal voltage
116 Vm=V(p,n);
117





122 time1 = $abstime;
106
APPENDIX D. SAP1951 FTJ THESIS 45








130 if ((Vm <0) && (tPr[i]>(0-tSat[i])))
131 begin
132 tPr[i] = tPr[i]-(time1 -time0);
133 end
134 else if ((Vm >0) && (tPr[i]<tSat[i]))
135 tPr[i] = tPr[i]+(time1 -time0);
136 //if (Vd >1.7)
137 // $display("Current time is %e while
the saturation time is %e for voltage
of %e", tPr[i], tSat[i], Vd);
138 //$display("The polarization time for
domain between %e and %e is %e at time
%e",Vd -0.2,Vd,tPr[i],$abstime);
139 //Calculate A value for Pr .4
140 Av1 = AA*Vd+BA;
141 Av2 = ALA*Vd;




APPENDIX D. SAP1951 FTJ THESIS 45
145 A=Av2;
146 //$display("A = %e",A);
147 //Calculate B value for Pr .4
148 Bv1 = AB*Vd+BB;
149 Bv2 = ALB*Vd;




154 //$display("B = %e",B);
155 //Calculate C value for Pr .4
156 Cv1 = AC*Vd+BC;
157 Cv2 = ALC*Vd;




162 //$display("C = %e",C);
163 //Calculate D value for Pr .4
164 Dv1 = 9.904* Vd +17.865;
165 Dv2 = 19.375*( Vd**2) -6.3*Vd+1.4;




170 //$display("D = %e",D);
171 //Calculate E value for Pr .4
108
APPENDIX D. SAP1951 FTJ THESIS 45
172 E = 9.105*Vd -5.152 -3.387*( Vd**2);
173 if (E <0.217)
174 E=0.217;
175 //$display("E = %e",E);
176 Pr4 = A+B*log((Vc0/Vc)*abs(tPr[i]))+C*(log
((Vc0/Vc)*abs(tPr[i]))**2);
177 Pr3 = D+E*ln((Vc0/Vc)*abs(tPr[i]));
178 Pr2 = 6.339* Vd +27.357;
179 Pr1 = 13.071*( Vd **2.929);
180
181 if (Pr4 <0)
182 Pr4 = 0;
183 if (Pr3 <Pr4)
184 Pr5 = Pr3;
185 else
186 Pr5 = Pr4;
187
188 if (Pr5 <0)
189 Pr5 = 0;
190
191 if (Pr1 <Pr2)
192 Pr6 = Pr1;
193 else
194 Pr6 = Pr2;
195
196 if (Pr5 <Pr6)
197 Pr7 = Pr5;
109
APPENDIX D. SAP1951 FTJ THESIS 45
198 else
199 Pr7 = Pr6;
200
201 //Calculate A value for Pr .2
202 Av1 = AA*(Vd -0.2)+BA;
203 Av2 = ALA*(Vd -0.2);




208 //Calculate B value for Pr .2
209 Bv1 = AB*(Vd -0.2)+BB;
210 Bv2 = ALB*(Vd -0.2);




215 //Calculate C value for Pr .2
216 Cv1 = AC*(Vd -0.2)+BC;
217 Cv2 = ALC*(Vd -0.2);




222 //Calculate D value for Pr .2
223 Dv1 = 9.904*(Vd -0.2) +17.865;
110
APPENDIX D. SAP1951 FTJ THESIS 45
224 Dv2 = 19.375*((Vd -0.2) **2) -6.3*(Vd -0.2)
+1.4;




229 //Calculate E value for Pr .2
230 E = 9.105*(Vd -0.2) -5.152 -3.387*((Vd -0.2)
**2);
231 if (E <0.217)
232 E=0.217;
233
234 Pr24 = A+B*log((Vc0/Vc)*abs(tPr[i]))+C*(
log((Vc0/Vc)*abs(tPr[i]))**2);
235 Pr23 = D+E*ln((Vc0/Vc)*abs(tPr[i]));
236 Pr22 = 6.339*(Vd -0.2) +27.357;
237 Pr21 = 13.071*((Vd -0.2) **2.929);
238
239 if (Pr24 <0)
240 Pr24 = 0;
241 if (Pr23 <Pr24)
242 Pr25 = Pr23;
243 else
244 Pr25 = Pr24;
245
246 if (Pr25 <0)
247 Pr25 = 0;
111
APPENDIX D. SAP1951 FTJ THESIS 45
248
249 if (Pr21 <Pr22)
250 Pr26 = Pr21;
251 else
252 Pr26 = Pr22;
253
254 if (Pr25 <Pr26)
255 Pr27 = Pr25;
256 else
257 Pr27 = Pr26;
258
259 Pr[i] = Pr7 - Pr27;
260
261 if (tPr[i]<0)
262 Pr[i] = 0-Pr[i];
263
264 //$display("Polarization values used were
(in order) %e %e %e %e %e %e %e %e %e %
e %e %e %e %e",Pr1,Pr2,Pr3,Pr4,Pr5,Pr6,




267 //$display("The for loop just completed Vd
= %e, at time %e", Vd, time1);
268 Vd = Vd +0.2;
269 end
112
APPENDIX D. SAP1951 FTJ THESIS 45
270
271 Prtotal =0.5*( Pr[0] + Pr[1] + Pr[2] + Pr
[3] + Pr[4] + Pr[5] + Pr[6] + Pr[7] +
Pr[8] + Pr[9] + Pr[10] + Pr[11] + Pr
[12] + Pr [13]);
272
273 //$display("The total polarization is




276 //$display("sigma_p is %e", sigmap);
277 sigmas=sigmap*d/( epsilonf *( delta1+delta2)+
d);
278 //$display("sigma_s is %e", sigmas);
279
280 Pot1=( sigmas*delta1/epsilon0)+Ea;
281 //$display("Pot1 is %e", Pot1);
282 Pot2=Ea+Ef2 -Ef1 -( sigmas*delta2/epsilon0);
283 //$display("Pot2 is %e", Pot2);
284 Pot=(Pot1+Pot2)/2;




287 //$display("Current density in A/cm^2 is %
e", Jtun);
113
APPENDIX D. SAP1951 FTJ THESIS 45
288
289 Rm = Vm/(Jtun *((Dim*1e-7) **2));
290
291 time0 = $abstime;
292 //$display("time0 became %e at %e", time0 ,
$abstime);
293 Im = Vm / Rm;











305 //$display("The total polarization is








APPENDIX D. SAP1951 FTJ THESIS 45
D.3 SAP ADDRESS COLUMN R
Library Name: sap1951 FTJ THESIS 45







Propagation Delay (tpdf and tpdr) and Output Rise/Fall Time (tf and tr):
In Out tpdf tpdr tf tr
Ren Y 561.8×10−12 603.1×10−12 473.3×10−12 1.498×10−9
WenN Y 552.2×10−12 701.6×10−12 464.5×10−12 1.746×10−9
Notice long tr because this device doesn’t drive the output high, it
can only drag it down to vssa.
Layout Area: 0.6µm × 1.71µm = W ×H
Symbol with Port Names:
115








APPENDIX D. SAP1951 FTJ THESIS 45
D.4 SAP ADDRESS COLUMN W
Library Name: sap1951 FTJ THESIS 45
Cell Name: SAP ADDRESS COLUMN W
Function/Truth Table:
Wen WenN WN Ren RenN Y
0 1 0 1 0 X
0 1 1 1 0 X
0 1 0 0 1 X
0 1 1 0 1 X
1 0 0 1 0 X
1 0 1 1 0 X
1 0 0 0 1 VDD
1 0 1 0 1 VSS
Propagation Delay (tpdf and tpdr) and Output Rise/Fall Time (tf and tr):
In Out tpdf tpdr tf tr
Wen Y 208×10−12 75.14×10−12 122.4×10−12 97.83×10−12
WN Y 66.89×10−12 177.0×10−12 54.9×10−12 94.81×10−12
Ren Y 102.8×10−12 99.16×10−12 191.4×10−12 82.92×10−12
Layout Area: 0.8µm × 1.71µm = W ×H
Symbol with Port Names:
118








APPENDIX D. SAP1951 FTJ THESIS 45
D.5 SAP ADDRESS ROW R
Library Name: sap1951 FTJ THESIS 45







Propagation Delay (tpdf and tpdr) and Output Rise/Fall Time (tf and tr):
In Out tpdf tpdr tf tr
RenN Y - 513.9×10−12 - 433.7×10−9
Wen Y - 465.7×10−12 - 451.3×10−9
Notice long tr because this device doesn’t drive the output high, it
can only drag it down to vssa.
Layout Area: 0.6µm × 1.71µm = W ×H
Symbol with Port Names:
121








APPENDIX D. SAP1951 FTJ THESIS 45
D.6 SAP ADDRESS ROW W
Library Name: sap1951 FTJ THESIS 45
Cell Name: SAP ADDRESS ROW W
Function/Truth Table:
Wen WenN W Ren RenN Y
0 1 0 1 0 X
0 1 1 1 0 X
0 1 0 0 1 X
0 1 1 0 1 X
1 0 0 1 0 X
1 0 1 1 0 X
1 0 0 0 1 VDD
1 0 1 0 1 VSS
Propagation Delay (tpdf and tpdr) and Output Rise/Fall Time (tf and tr):
In Out tpdf tpdr tf tr
Wen Y 208.7×10−12 103.4×10−12 124.0×10−12 79.94×10−12
W Y 68.36×10−12 181.5×10−12 116.8×10−12 94.81×10−12
Ren Y 102.4×10−12 99.75×10−12 116.2×10−12 90.66×10−12
Layout Area: 0.8µm × 1.71µm = W ×H
Symbol with Port Names:
124








APPENDIX D. SAP1951 FTJ THESIS 45
D.7 SAP ADDRESS GND vcc
Library Name: sap1951 FTJ THESIS 45
Cell Name: SAP ADDRESS GND vcc
Function/Truth Table:
Wen WenN Ren RenN Y
0 1 1 0 X
0 1 0 1 VCC
1 0 1 0 X
1 0 0 1 X
Propagation Delay (tpdf and tpdr) and Output Rise/Fall Time (tf and tr):
In Out tpdf tpdr tf tr
Wen Y - 165.0×10−12 - 191.9×10−12
Ren Y - 158.4×10−12 - 188.9×10−12
Layout Area: 0.8µm × 1.71µm = W ×H
Symbol with Port Names:
127








APPENDIX D. SAP1951 FTJ THESIS 45
D.8 SAP FTJ DIGITAL LOW 4 x 4
Library Name: sap1951 FTJ THESIS 45
Cell Name: SAP FTJ DIGITAL LOW 4 x 4
Layout Area: 2.07µm × 1.985µm = W ×H
Symbol with Port Names:
Schematic:
130
APPENDIX D. SAP1951 FTJ THESIS 45
Layout:
131
APPENDIX D. SAP1951 FTJ THESIS 45
D.9 SAP TRISTATE MEM 4x vcc
Library Name: sap1951 FTJ THESIS 45
Cell Name: SAP TRISTATE MEM 4x vcc
Layout Area: 27 µm × 18 µm = W ×H
Symbol with Port Names:
Schematic:
132
APPENDIX D. SAP1951 FTJ THESIS 45
Layout:
133
APPENDIX D. SAP1951 FTJ THESIS 45
D.10 SAP TRISTATE MEM 4x TESTBENCH
Library Name: sap1951 FTJ THESIS 45
Cell Name: SAP TRISTATE MEM 4x TESTBENCH
Symbol with Port Names:
134
APPENDIX D. SAP1951 FTJ THESIS 45
D.10.1 Verilog Model
1 //Verilog HDL for "sap1951_FTJ_THESIS_45",
"SAP_TRISTATE_MEM_4x_TESTBENCH" "
functional"
2 ‘timescale 10 ns / 1 fs
3 module SAP_TRISTATE_MEM_4x_TESTBENCH(Ren ,
W, Wen , Y, Y_out);
4
5 input [3:0] Y;
6 output [7:0] Ren , W, Wen;
7 output [3:0] Y_out;
8
9 reg [7:0] Ren , W, Wen;
10
11 reg [3:0] val;
12 integer out;
13 integer outnot;










APPENDIX D. SAP1951 FTJ THESIS 45
23 begin




28 Ren <= 8’b00000000;
29 W <= 8’b11111111;
30 Wen <= 8’b11111111;






37 //10us Guard Time
38 Ren <= 8’b00000000;
39 W <= 8’b00000000;
40 Wen <= 8’b00000000;
41 #1;
42 //Read Mem row 7 (1) for 10us
43 Ren <= 8’b10001111;
44 W <= 8’b00000000;
45 Wen <= 8’b00000000;
46 #1;
47 //10us Guard Time
48 Ren <= 8’b00000000;
49 W <= 8’b00000000;
136
APPENDIX D. SAP1951 FTJ THESIS 45
50 Wen <= 8’b00000000;
51 #1;
52 //Read Mem row 7 (1) for 10us
53 Ren <= 8’b10001111;
54 W <= 8’b00000000;
55 Wen <= 8’b00000000;
56 #1;
57 //10us Guard Time
58 Ren <= 8’b00000000;
59 W <= 8’b00000000;
60 Wen <= 8’b00000000;
61 #1;
62 //for loop through all 15 numbers (2^4-1)
and write each one in the first row of
the array
63 for(out=0;out <16; out=out +1)
64 begin
65 outnot =15-out;
66 //write \ac{HRS} for current val
67 W <= 8’b11111111;
68 val=out;
69 Wen <= {4’b1000 , val};
70 #1;
71 //guard time 10us
72 Ren <= 8’b00000000;
73 W <= 8’b00000000;
74 Wen <= 8’b00000000;
137
APPENDIX D. SAP1951 FTJ THESIS 45
75 #1;
76 //write LRS for current val
77 W <= 8’b00000000;
78 val=outnot;
79 Wen <= {4’b1000 , val};
80 #1;
81 //guard time 10us
82 Ren <= 8’b00000000;
83 W <= 8’b00000000;
84 Wen <= 8’b00000000;
85 val=out;
86 #1;
87 //read that shit!
88 Ren <= 8’b10001111;
89 W <= 8’b00000000;






96 //guard time 10us
97 Ren <= 8’b00000000;
98 W <= 8’b00000000;
99 Wen <= 8’b00000000;
100 #1;
101 //read the column directly below!
138
APPENDIX D. SAP1951 FTJ THESIS 45
102 Ren <= 8’b00101111;
103 W <= 8’b00000000;






110 //guard time 10us
111 Ren <= 8’b00000000;
112 W <= 8’b00000000;
113 Wen <= 8’b00000000;
114 #1;
115 //read that shit!
116 Ren <= 8’b10001111;
117 W <= 8’b00000000;






124 //guard time 10us
125 Ren <= 8’b00000000;
126 W <= 8’b00000000;
127 Wen <= 8’b00000000;
128 #1;
139
APPENDIX D. SAP1951 FTJ THESIS 45
129 end
130 $display("%d data errors , %d background 
disturbs , and %d data disturbs with a 





134 //Write all Low (LRS) for 10us and repeat
test!
135 Ren <= 8’b00000000;
136 W <= 8’b00000000;
137 Wen <= 8’b10001111;
138 bg = 4’b0000;
139 #1;
140 Ren <= 8’b00000000;
141 W <= 8’b00000000;
142 Wen <= 8’b01001111;
143 bg = 4’b0000;
144 #1;
145 Ren <= 8’b00000000;
146 W <= 8’b00000000;
147 Wen <= 8’b00101111;
148 bg = 4’b0000;
149 #1;
150 Ren <= 8’b00000000;
151 W <= 8’b00000000;
140
APPENDIX D. SAP1951 FTJ THESIS 45
152 Wen <= 8’b00011111;
153 bg = 4’b0000;
154 end
155 endmodule
141
