# Variability-aware Memristive Crossbars - A Tutorial

A.P. James, Fellow, IET, and L.O. Chua, Fellow, IEEE

Abstract—Memristor crossbar architecture is one of the most popular circuit configurations due to its wide range of practical applications. The crossbar architecture can emulate the weighted summation operation, called multiply and accumulate operation (MAC). The errors to MAC computing get introduced due to a range of crossbar variability. We broadly group the variability in three categories: (1) device-to-device variations, (2) programming nonlinearity, and (3) those from peripheral circuits. This tutorial provides insights into the variability and compensation approaches that can be adopted to reduce its impact when designing for practical applications with crossbars.

Index Terms—Memristor crossbar, variability, memristor applications, compensation

#### I. INTRODUCTION

**M**EMRISTIVE systems are abundant in nature, with many biological and natural systems exhibiting memristive properties. The idealistic models in Fig. 1, can be used for understanding and laying the foundation dynamic behavior of memristor using dynamic route maps (DRM) and i - v plots [1]–[3]. The DRM in the phase plane can determine the optimal programming pulse height and width along the identified equilibrium points. While these equations can describe the devices in idealistic situations, experimentally, it is harder to validate under noisy conditions. In contrast, *Coincident Zero-Crossing Signatures* can be experimentally observed in many devices. The ideal models do not consider the impact of noises or the variability that practical devices show, and the development of generic *imperfect memristor* models [1], [4] remains an open problem.

| Extended Memristor                       | v=R(x,i)i<br>$R(x,0) eq\infty$ | $\frac{dx}{dt} = f(x,i)$     | $egin{array}{l} i = G(x,v)v \ G(x,0)  eq \infty \end{array}$ | $\frac{dx}{dt} = f(x,v)$      |
|------------------------------------------|--------------------------------|------------------------------|--------------------------------------------------------------|-------------------------------|
| Generic Memristor                        | v=R(x)i                        | $\frac{dx}{dt} = f(x,i)$     | i=G(x)v                                                      | $\frac{dx}{dt} = f(x, v)$     |
| Ideal Generic Memristor                  | v = R(x)i                      | $rac{dx}{dt} = \hat{f}(x)i$ | i=R(x)v                                                      | $\frac{dx}{dt} = \hat{f}(x)v$ |
| Ideal Memristor                          | v = R(q)i                      | $rac{dq}{dt} = i$           | i=R(q)v                                                      | $rac{d\phi}{dt} = v$         |
| Idealistic memristor<br>universal models | Current controlled             |                              | Voltage controlled                                           |                               |

Fig. 1. Universe of memristor models, excluding the parasitic and other device variability.

Several devices show the resistive switching behavior having nonvolatile properties, grouped under the board class of memristive devices. This classification assumes that not all of these devices show idealistic properties of the memristor but have many properties of ideal memristor that can be used for building practical memristive systems [5], [6]. For example, nonvolatility, switching between conductance values, small form factors, integration with CMOS, and synaptic behavior, are all attractive properties useful for building emerging onchip applications. Emulating neural networks, analog comput-



Fig. 2. Example of memristor crossbar of array size  $3 \times 4$ . Each crossbar node has a memristor and selector device.

ing, and in-memory computing are growing applications of memristive systems.

Crossbar arrangement of memristor [7]–[9] is a popular approach to build memristive computing applications. Any errors in the crossbar will impact the overall accuracy of computations [10]. Such errors develop due to the variability of devices, circuit parasitic, and device aging [11]. For ensuring reliable use of memristive crossbars, it is important to design the overall system so that variability is compensated or reduced to practical limits allowable for a given application. The attempts to include variability in simulations [12]–[14] are important for accurate analysis of circuit performance.

This tutorial draws motivation from the above mentioned emerging design and performance challenges of building memristor crossbar based systems. So far, the previous works [5], [8], [9], [15] in the domain largely focuses on the applications and less on the issues of variability. This tutorial contributes to give a concise account of the types of variability, its implications, and possible directions to create a variability-aware crossbar in the practical design of memristive applications. Section II gives an overview of the crossbar, while Section III provides insights on variability and compensation approaches, and Section IV provides the summary.

#### II. CROSSBAR OVERVIEW

The crossbar consists of memristors connected in a matrix arrangement, as shown in Fig. 2, with multiple inputs and outputs. The inputs are applied along the rows, and outputs are read along the columns.

#### A. Crossbar structure

The most popular memristor structure is the crossbar with inputs as voltages  $v_m$  and outputs as currents  $i_n$ . The nodes of the crossbar consist of a memristor and selector device (e.g., transistor or diode), having a conductance of  $G_{mn}$ . The selector devices are required to avoid the sneak path currents from the neighborhood columns. The overall column current  $i_n = \sum_{m=1}^{M} G_{mn} v_m$ , is equivalent to the weighted summation

operation, called multiply and accumulate (MAC) operation in analog computations.



Fig. 3. Examples of major applications using crossbar arrays.

### B. Crossbar applications

The analog MAC operation is the hallmark of the crossbar, useful for a range of applications. For example, in neural computations, for M inputs  $y_m$  with weights  $w_m$ , the output of neuron is expressed as  $\sum_{m=1}^{M} w_m y_m$ , which maps with each column current outputs of the crossbar. Thus, each crossbar column can be considered as partial neuron computations, and the crossbar as a single neuron layer. The variability in the crossbar can be problematic for some applications while useful for others. Figure 3 shows the broad classification of major crossbar applications. Neural networks [15] such as Spiking neural networks [16], Hierarchical Memory Networks [17], or Deep Learning Networks [16] can be implemented in both analog/digital crossbar circuits, with a range of variability using the neural training schemes. Application of logic computing is also robust to variability due to the binary logic, while bit errors are possible when there are thresholds to compare or are stuck at fault errors. The use of crossbar for binary or analog/discrete memory with high density 2D and 3D crossbar arrays could be limited in readout speeds with increased variability. The crossbar variability can be used to build unique physically unclonable functions (PUFs) useful for a variety of cryptographic algorithms [18]. The crossbar analog MAC computations can be used for building solvers such as for PDE [19], discrete Markov chains [20], or linear program solvers [21], where the accuracy of analog MAC becomes crucial in controlling with increasing variability. Image processing [22] is another popular application, with crossbar useful for edge detection [23], face detection [24], and object detection, where the accuracy and speed of detection is sensitive to aging and variability.

## III. CROSSBAR VARIABILITY AND COMPENSATION

The definition of the variability in memristive crossbar systems varies from the device level to the hardware system level.



Fig. 4. The broad classification of the types of the variability faced in memristor crossbars.

The inaccuracy of the MAC computation can significantly impact the reliability of using crossbar in various applications. Figure 4 shows a broad classification of variability in a memristive crossbar.

### A. Device-to-device variability

Most of the memristive devices used for building crossbars are in their experimental stage. For commercial use, a new device is expected to have a low device-to-device variability [15], [25]–[27] and less unpredictable output current errors. The main design considerations include the following:

- Material stack and switching physics. The material stack has a direct role in the thermal effects, chemical reactions, ionic transfers, spin polarization, and phase transition of resistive switching. The variations in material stacks due to defects and unstable manufacturing process leads to non-uniform resistive switching between the devices.
- 2) CMOS technology node. CMOS transistors used in crossbar nodes and at the inputs or outputs of crossbar usually have varying levels of technology-specific leakage currents and parasitic effects that impact the dynamic response times of the crossbar column computations.
- 3)  $R_{on}/R_{off}$  ratio. Changes in ratio (low-resistance state (LRS)  $R_{on}$  and high-resistance state (HRS)  $R_{off}$ ) can complicate the programing of memristors and increase the relative current errors. This can introduce changes to dynamic switching behavior expected for a certain frequency of programming pulses, which require readjusting the pulse frequency and amplitude from one device to another to achieve the same state outcomes.
- 4) Range of operating currents from devices. The write, read and erase currents in a memristor need to be much higher than sneak path currents, while a larger current would increase the power dissipation in the crossbar. Optimizing the operating range of current memristors for power, density, and accuracy is essential to ensure the practical usefulness of the crossbar.
- 5) *Read and write voltage ranges.* Lower voltages would imply the need for longer pulses to program the memristors, while higher voltages would increase the power

dissipation in the crossbar. The variation in voltages that the memristor supports, if varied between the devices, introduces uneven distribution of power within the crossbar leading to different stress levels on the devices.

- 6) Endurance and retention. The four major memristor mechanisms are based on a redox reaction, phase change, magnetic polarization, and ferroelectric polarization. In each of these device types, endurance varies from 10<sup>9</sup> to 10<sup>14</sup>, and retention is more than ten years. Any reduction in endurance implies a reduced lifespan in applications involving frequent updates of conductance. Reduction in retention times makes the crossbar unreliable as a memory or for in-memory computing applications, such as neural networks.
- 7) Temperature dependence. The temperature can influence the flow of current in the semiconductor material. The memristor current increases with an increase in temperature while switching delays decrease. The temperature change from 200k to 400k increases the currents by an order of two, implying higher power dissipation during crossbar computations. The changes in switching delays with varying temperatures can make memristor programming unreliable.
- 8) Random telegraph noise (RTN). RTN with current signals is observed in memristors made of metal-insulator-metal. The nature of the RTN signals is influenced by materials used for electrodes and insulators, type of deposition method, and insulator thickness.

The variations in these parameters result in MAC computation errors. It has been shown that device-to-device variation in phase-change random access memory arrays is more difficult to train than devices exhibiting consistent cycle-to-cycle variation. This indicates that any reduction in the device-to-device variability in practical applications can improve the overall application reliability.

#### B. Programming nonlinearity

In many memristors such as  $HfO_2$  or PCM, the memristance can be represented as a nonlinear function of time [28], [29]. Both linear and nonlinear drift models [30] can be used for modeling the memristance. In contrast, if memristance variation is linear in time, their programming is easier as memristance is proportional to the width of a programming voltage pulse.

In practical realization of memristive devices, such as analog RRAMs, linear adjustment (tuning) of conductance is not possible with a sequence of identical pulses [29]. Both the SET and RESET cycles observe nonlinearity and require device level modifications or circuit level node design to ensure linearity.

A device level solution has been demonstrated in the past by linearly setting SET and RESET using HfOx type memristors by adding electro-thermal modulation layer to the switching layer to control the dynamics of the conductance changes. The circuit level solution includes an anti-serial architecture by connecting two memristors of opposite polarities. The complementary action of the serially connected memristors in such configuration shows linear behavior in time, useful for linearly programming the crossbar node.

## C. Peripheral circuits

1) Crossbar circuits: Several interface circuits are required to make crossbars useful for practical applications. The crossbar array is directly influenced by variations in yield, redundancy, circuit parasitics, current-resistance (IR) drop, and array size.

*a) Yield and redundancy:* High yield and redundancy are required for the use of crossbars as memories. Redundancy is essential in applications where data recovery becomes important [31], [32], and in-memory computing should be highly accurate.

*b) Circuit parasitics:* The circuit parasitics [33], [34] include the effects of wire resistance [35] from metal lines connecting the memristors, stray capacitors, and resistors in the CMOS switches, creating RC delays along the crossbar lines. The impact is more pronounced as the size of the crossbar array increases, reducing the read speeds of the system. The parasitic coupled with large device-to-device variations in the crossbar can eventually lead to high relative current errors making real-time applications unreliable.

c) IR drops: Both static and dynamic IR drops happen in a memristor crossbar. The voltage IR-drop [36] results from the resistance of the crossbar arrays and metal wires. The node resistance G becomes a function of parasitic resistance of switches, memristance, and wire resistance. The variability in memristor devices, wires, or switches will impact the 1T1M crossbar read and write accuracy. The IR drops, if not compensated in write stages by readjusting the conductance values, will also impact the readout values.

Compensation by readjusting the programming pulse amplitude and width can effectively reduce the IR drop impact. Suppose T is the programming pulse widths, and V is the pulse amplitude for programming the crossbar without considering IR drops. When IR drops are considered, the voltage distribution V gets distorted to V'. For compensating for the drop in amplitude, the pulse width for V' is reworked to get a new time period T' that gives the desired state under IR drops.

2) Crossbar I/O: The I/O blocks to the crossbar often involve a variety of analog or digital circuits. The most common circuits are OpAmps and sense amplifiers, line selector switches, programming circuits, data converters (ADCs and DACs), buffers, and multiplexing circuits. The variability and reliability of these circuit elements determine the practical feasibility of using crossbars in a range of applications.

*a)* Sense amplifiers: Sense amplifiers are required to readout the column currents. In analog neural networks designed with crossbars, the difference between two column currents is used to account for the negative weights of the networks. In most other applications, one column current output is readout using an opamp or set of amplifiers. The opamps are expected to have low input offsets (current and voltage), low delays, and work in high frequencies. The parasitic capacitors and resistances from the sense amplifiers can uneven delays in parallel column reads of the crossbar, requiring timing and

memory controls before passing the signals to the subsequent crossbars or circuits.

b) Control circuits: Different sets of control circuits are required to control various switches within and on the peripherals of the crossbar. For example, the most commonly used 1T1M crossbar configuration will require control signals applied to the gate of the transistor and input/output lines for the read, write, and erase operations. In noise-free control signals, accurate timing is essential for programing the memristors in the crossbar. Further, in neural networks with multiple crossbars, control circuits are required to access the intermediate storage and multiplex the signals across multiple crossbars, such as in tiled crossbar configuration.

c) ADC/DAC: ADC is required to convert the analog column outputs from the crossbar to digital for further processing and storage. DAC is required for converting the digital input signal to analog for use in binary crossbar arrays. The precision of ADC/DAC and the ADC multiplexing would form the primary design considerations. The common errors in ADC include quantization error, offset error, gain error, and nonlinearity, all of which impact the overall use of crossbar for applications. The absolute errors from the ADC can lead to increased output current errors, which, when implemented in applications such as neural networks, leads to reduced inference accuracy.

*d) Binary crossbar and quantization:* If the crossbar is used for storing binary weights as in binary neural networks, errors from partial sum quantization are also possible. Any inaccuracy in DAC and ADC further degrades the errors due to partial sum quantization.

*e) Process, voltage and temperature (PVT), and noise:* The peripheral circuits can be PVT sensitive and induce noise in the crossbar circuits. The PVT sensitivity of the peripheral circuits can limit the practical operating range in applications. Further, the noise induced by the peripheral circuits can pass from one crossbar stage to another, causing errors in crossbar computations.

## D. Compensation techniques

a) Devices: There are no universal techniques that compensate device-to-device variability. Each memristive device type is developed differently with various chemical and physical processes, which requires different approaches. For example, (1) in HfO<sub>x</sub> RRAM, the device variability was compensated by introducing an ultra-thin ALD-TiN buffer layer [37], (2) in Al<sub>2</sub>O<sub>3</sub>/TiO<sub>2</sub> (VMCO) RRAM, the use of non-filamentary RRAM reduces the impact [38], and (3) in SiO<sub>x</sub> RRAM, increasing the roughness of bottom electrodes reduces the device-to-device variability [39].

*b) Peripheral circuits and programming:* The compensating schemes in literature are limited and largely an open problem. However, they are indirectly addressed via architectural modifications and system training, examples of which are listed below.

*b.1)* Architecture variants: Modular crossbar array [40] or tiled crossbar [41] is a method to split larger crossbars into smaller ones. Usually, large crossbars will have higher leakage

and sneak path currents in their columns. The current errors can be reduced by performing MAC computations across multiple smaller crossbars. Simultaneously, it allows for a scalable configuration for large array processing applications.

The choice of the selector device [42] is critical for the reliable operation of the crossbar. The common selectors used are transistors, diodes, nonlinear devices, and volatile switches. Both planar and vertical transistors could be used as a selector device depending on the 2D or 3D crossbar structure. Among diodes, Si p-n junctions, oxide/oxide heterojunction, and metal-oxide Schottky junctions are the most popular. The nonlinear devices include tunneling-based selections, complementary circuits, and mixed ionic electronic conduction, while volatile switches include phase transition, threshold, and short-retention switches.

Introducing redundancy in the crossbar node by parallelly combining memristors can help increase the stability and robustness of crossbar computation. Such nodes, known as superresolution nodes [43], can create a larger number of stable conductance levels per crossbar node for accurate analog computing.

*b.2) Training variants:* Training that involves updating the node conductance against a performance metric is useful in reducing errors resulting from crossbar variability. A variation-aware training often involves the addition of a "penalty for variation" to conventional training for solving the conductance optimization process. This is practically useful for designing crossbar neural networks where the obtained weights deviate to new values due to crossbar variability and requires readjusting weights for optimal inference accuracy [44].

Rather than an on-chip inference checking and training for the error, another approach is to perform offline training accounting for various crossbar variabilities [45]. This is useful for applications such as neural networks, where they need to be trained for variability and for reducing sensitivity to signal noise.

#### **IV. CONCLUSION**

In conclusion, we note that the reliability of the memristor device and its ease of integration with matured technologies such as CMOS is crucial for realizing the majority of the practical applications with crossbars. Memristive devices need to have long retention and endurance, irrespective of the variability subjected in the crossbar for commercial use. Innovations in device material stack, crossbar architectures, and adaptive conductance adjustments through training effectively reduce the negative impacts of variability. In contrast, variability can also be useful for building systems requiring stochastic computing, including cryptography and stochastic neural networks.

#### REFERENCES

- C. Leon, "Everything you wish to know about memristors but are afraid to ask," *Radioengineering*, vol. 24, no. 2, p. 319, 2015.
- [2] L. Chua, "Five non-volatile memristor enigmas solved," *Applied Physics A*, vol. 124, no. 8, pp. 1–43, 2018.
- [3] A. Ascoli, R. Tetzlaff, L. O. Chua, J. P. Strachan, and R. S. Williams, "History erase effect in a non-volatile memristor," *IEEE Transactions* on Circuits and Systems I: Regular Papers, vol. 63, no. 3, pp. 389–400, 2016.

- [4] E. Linn, A. Siemon, R. Waser, and S. Menzel, "Applicability of wellestablished memristive models for simulations of resistive switching devices," *IEEE Transactions on Circuits and Systems I: Regular Papers*, vol. 61, no. 8, pp. 2402–2410, 2014.
- [5] M. A. Zidan, J. P. Strachan, and W. D. Lu, "The future of electronics based on memristive systems," *Nature electronics*, vol. 1, no. 1, pp. 22–29, 2018.
- [6] J. Jiménez-León, L. A. Sarmiento-Reyes, and P. Rosales-Quintero, "A compact modeling methodology for experimental memristive devices," *IEEE Transactions on Computer-Aided Design of Integrated Circuits* and Systems, 2021.
- [7] I. Vourkas and G. C. Sirakoulis, "A novel design and modeling paradigm for memristor-based crossbar circuits," *IEEE Transactions on Nanotechnology*, vol. 11, no. 6, pp. 1151–1159, 2012.
- [8] Q. Xia and J. J. Yang, "Memristive crossbar arrays for brain-inspired computing," *Nature materials*, vol. 18, no. 4, pp. 309–323, 2019.
- [9] H. Li, S. Wang, X. Zhang, W. Wang, R. Yang, Z. Sun, W. Feng, P. Lin, Z. Wang, L. Sun *et al.*, "Memristive crossbar arrays for storage and computing applications," *Advanced Intelligent Systems*, vol. 3, no. 9, p. 2100017, 2021.
- [10] J. Chen, J. Li, Y. Li, and X. Miao, "Multiply accumulate operations in memristor crossbar arrays for analog computing," *Journal of Semiconductors*, vol. 42, no. 1, p. 013104, 2021.
- [11] L. Gao, Q. Ren, J. Sun, S.-T. Han, and Y. Zhou, "Memristor modeling: challenges in theories, simulations, and device variability," *Journal of Materials Chemistry C*, vol. 9, no. 47, pp. 16859–16884, 2021.
- [12] J. Reuben, M. Biglari, and D. Fey, "Incorporating variability of resistive ram in circuit simulations using the stanford-pku model," *IEEE Transactions on Nanotechnology*, vol. 19, pp. 508–518, 2020.
- [13] V. Ostrovskii, P. Fedoseev, Y. Bobrova, and D. Butusov, "Structural and parametric identification of knowm memristors," *Nanomaterials*, vol. 12, no. 1, p. 63, 2022.
- [14] K. Adam, K. Smagulova, and A. James, "Generalised analog lstms recurrent modules for neural computing," *Frontiers in computational neuroscience*, p. 85, 2021.
- [15] Y. Li, Z. Wang, R. Midya, Q. Xia, and J. J. Yang, "Review of memristor devices in neuromorphic computing: materials sciences and device challenges," *Journal of Physics D: Applied Physics*, vol. 51, no. 50, p. 503002, 2018.
- [16] A. Mehonic, A. Sebastian, B. Rajendran, O. Simeone, E. Vasilaki, and A. J. Kenyon, "Memristors from in-memory computing, deep learning acceleration, and spiking neural networks to the future of neuromorphic and bioinspired computing," *Advanced Intelligent Systems*, vol. 2, no. 11, p. 2000085, 2020.
- [17] O. Krestinskaya, I. Dolzhikova, and A. P. James, "Hierarchical temporal memory using memristor networks: A survey," *IEEE Transactions on Emerging Topics in Computational Intelligence*, vol. 2, no. 5, pp. 380– 395, 2018.
- [18] A. P. James, "An overview of memristive cryptography," *The European Physical Journal Special Topics*, vol. 228, no. 10, pp. 2301–2312, 2019.
- [19] M. A. Zidan, Y. Jeong, J. Lee, B. Chen, S. Huang, M. J. Kushner, and W. D. Lu, "A general memristor-based partial differential equation solver," *Nature Electronics*, vol. 1, no. 7, pp. 411–420, 2018.
- [20] G. Zoppo, A. Korkmaz, F. Marrone, S. Palermo, F. Corinto, and R. S. Williams, "Analog solutions of discrete markov chains via memristor crossbars," *IEEE Transactions on Circuits and Systems I: Regular Papers*, vol. 68, no. 12, pp. 4910–4923, 2021.
- [21] R. Cai, A. Ren, Y. Wang, S. Soundarajan, Q. Qiu, B. Yuan, and P. Bogdan, "A low-computation-complexity, energy-efficient, and highperformance linear program solver using memristor crossbars," in 2016 29th IEEE International System-on-Chip Conference (SOCC). IEEE, 2016, pp. 317–322.
- [22] C. Li, M. Hu, Y. Li, H. Jiang, N. Ge, E. Montgomery, J. Zhang, W. Song, N. Dávila, C. E. Graves *et al.*, "Analogue signal and image processing with large memristor crossbars," *Nature electronics*, vol. 1, no. 1, pp. 52–59, 2018.
- [23] J. S. Pannu, S. Raj, S. L. Fernandes, D. Chakraborty, S. Rafiq, N. Cady, and S. K. Jha, "Design and fabrication of flow-based edge detection memristor crossbar circuits," *IEEE Transactions on Circuits and Systems II: Express Briefs*, vol. 67, no. 5, pp. 961–965, 2020.
- [24] A. P. James, I. Fedorova, T. Ibrayev, and D. Kudithipudi, "Htm spatial pooler with memristor crossbar circuits for sparse biometric recognition," *IEEE Transactions on Biomedical Circuits and Systems*, vol. 11, no. 3, pp. 640–651, 2017.
- [25] J. H. Nickel, J. P. Strachan, M. D. Pickett, C. T. Schamp, J. J. Yang, J. A. Graham, and R. S. Williams, "Memristor structures for high scalability:

Non-linear and symmetric devices utilizing fabrication friendly materials and processes," *Microelectronic engineering*, vol. 103, pp. 66–69, 2013.

- [26] S. M. Laube and N. TaheriNejad, "Device variability analysis for memristive material implication," arXiv preprint arXiv:2101.07231, 2021.
- [27] R. Kumar, A. Chordia, A. Aswani, A. James, and J. N. Tripathi, "Uncertainty quantification of memristor crossbar array for vector matrix multiplication," in 2021 IEEE 25th Workshop on Signal and Power Integrity (SPI). IEEE, 2021, pp. 1–4.
- [28] S. Ambrogio, P. Narayanan, H. Tsai, R. M. Shelby, I. Boybat, C. Di Nolfo, S. Sidler, M. Giordano, M. Bodini, N. C. Farinha *et al.*, "Equivalent-accuracy accelerated neural-network training using analogue memory," *Nature*, vol. 558, no. 7708, pp. 60–67, 2018.
- [29] W. Wu, H. Wu, B. Gao, P. Yao, X. Zhang, X. Peng, S. Yu, and H. Qian, "A methodology to improve linearity of analog rram for neuromorphic computing," in 2018 IEEE Symposium on VLSI Technology. IEEE, 2018, pp. 103–104.
- [30] N. R. McDonald, R. E. Pino, P. J. Rozwood, and B. T. Wysocki, "Analysis of dynamic linear and non-linear memristor device models for emerging neuromorphic computing hardware design," in *The 2010 International Joint Conference on Neural Networks (IJCNN)*. IEEE, 2010, pp. 1–5.
- [31] S. Kannan, N. Karini, R. Karri, and O. Sinanoglu, "Detection, diagnosis, and repair of faults in memristor-based memories," in 2014 IEEE 32nd VLSI Test Symposium (VTS). IEEE, 2014, pp. 1–6.
- [32] Y. Shen, W. Zheng, K. Zhu, Y. Xiao, C. Wen, Y. Liu, X. Jing, and M. Lanza, "Variability and yield in h-bn-based memristive circuits: The role of each type of defect," *Advanced Materials*, vol. 33, no. 41, p. 2103656, 2021.
- [33] M. Itoh and L. O. Chua, "Parasitic effects on memristor dynamics," *International Journal of Bifurcation and Chaos*, vol. 26, no. 06, p. 1630014, 2016.
- [34] Y. Jeong, M. A. Zidan, and W. D. Lu, "Parasitic effect analysis in memristor-array-based neuromorphic systems," *IEEE Transactions on Nanotechnology*, vol. 17, no. 1, pp. 184–193, 2017.
- [35] L. Zhang, D. Borggreve, F. Vanselow, and R. Brederlow, "Impact of parasitic wire resistance on accuracy and size of resistive crossbars," in 2021 IEEE International Symposium on Circuits and Systems (ISCAS). IEEE, 2021, pp. 1–5.
- [36] B. Liu, H. Li, Y. Chen, X. Li, T. Huang, Q. Wu, and M. Barnell, "Reduction and ir-drop compensations techniques for reliable neuromorphic computing systems," in 2014 IEEE/ACM International Conference on Computer-Aided Design (ICCAD). IEEE, 2014, pp. 63–70.
- [37] Y. Fang, Z. Yu, Z. Wang, T. Zhang, Y. Yang, Y. Cai, and R. Huang, "Improvement of hfo x-based rram device variation by inserting ald tin buffer layer," *IEEE Electron Device Letters*, vol. 39, no. 6, pp. 819–822, 2018.
- [38] B. Govoreanu, A. Redolfi, L. Zhang, C. Adelmann, M. Popovici, S. Clima, H. Hody, V. Paraschiv, I. Radu, A. Franquet *et al.*, "Vacancymodulated conductive oxide resistive ram (vmco-rram): An area-scalable switching current, self-compliant, highly nonlinear and wide on/offwindow resistive switching cell," in 2013 IEEE International Electron Devices Meeting. IEEE, 2013, pp. 10–2.
- [39] A. J. Kenyon, M. S. Munde, W. H. Ng, M. Buckwell, D. Joksas, and A. Mehonic, "The interplay between structure and function in redoxbased resistance switching," *Faraday discussions*, vol. 213, pp. 151–163, 2019.
- [40] D. Mikhailenko, C. Liyanagedera, A. P. James, and K. Roy, "M 2 ca: Modular memristive crossbar arrays," in 2018 IEEE International Symposium on Circuits and Systems (ISCAS). IEEE, 2018, pp. 1–5.
- [41] D. J. Mountain, M. R. McLean, and C. D. Krieger, "Memristor crossbar tiles in a flexible, general purpose neural processor," *IEEE Journal on Emerging and Selected Topics in Circuits and Systems*, vol. 8, no. 1, pp. 137–145, 2017.
- [42] J. Zhou, K.-H. Kim, and W. Lu, "Crossbar rram arrays: Selector device requirements during read operation," *IEEE Transactions on Electron Devices*, vol. 61, no. 5, pp. 1369–1376, 2014.
- [43] A. P. James and L. O. Chua, "Analog neural computing with superresolution memristor crossbars," *IEEE Transactions on Circuits and Systems I: Regular Papers*, 2021.
- [44] B. Liu, H. Li, Y. Chen, X. Li, Q. Wu, and T. Huang, "Vortex: Variationaware training for memristor x-bar," in *Proceedings of the 52nd Annual Design Automation Conference*, 2015, pp. 1–6.
- [45] O. Krestinskaya, K. N. Salama, and A. P. James, "Automating analogue ai chip design with genetic search," *Advanced Intelligent Systems*, vol. 2, no. 8, p. 2000075, 2020.