#### **PAPER • OPEN ACCESS**

# A superconducting nanowire-based architecture for neuromorphic computing

To cite this article: Andres E Lombo et al 2022 Neuromorph. Comput. Eng. 2 034011

View the article online for updates and enhancements.

## You may also like

- A spiking central pattern generator for the control of a simulated lamprey robot running on SpiNNaker and Loihi neuromorphic boards
   Emmanouil Angelidis, Emanuel Buchholz, Jonathan Arreguit et al.
- HfO<sub>a</sub>-based resistive switching memory devices for neuromorphic computing S Brivio, S Spiga and D Ielmini
- A review of non-cognitive applications for neuromorphic computing
   James B Aimone, Prasanna Date, Gabriel A Fonseca-Guerra et al.

## **NEUROMORPHIC**

Computing and Engineering



#### **OPEN ACCESS**

RECEIVED 11 May 2022

REVISED 12 July 2022

ACCEPTED FOR PUBLICATION 4 August 2022

PUBLISHED
2 September 2022

Original content from this work may be used under the terms of the Creative Commons

Attribution 4.0 licence.

Any further distribution of this work must maintain attribution to the author(s) and the title of the work, journal citation and DOI.



#### PΔPFF

# A superconducting nanowire-based architecture for neuromorphic computing

Andres E Lombo<sup>1</sup>, Jesus Lares<sup>2</sup>, Matteo Castellani<sup>2</sup>, Chi-Ning Chou<sup>3</sup>, Nancy Lynch<sup>2</sup> and Karl K Berggren<sup>2,\*</sup>

- <sup>1</sup> Division of Engineering Science, University of Toronto, Toronto, Canada
- <sup>2</sup> Electrical Engineering and Computer Science Department, Massachusetts Institute of Technology, Cambridge, United States of America
- School of Engineering and Applied Sciences, Harvard University, Cambridge, United States of America
- \* Author to whom any correspondence should be addressed.

E-mail: berggren@mit.edu

Keywords: neuromorphic, superconductivity, nanowires

#### **Abstract**

Neuromorphic computing would benefit from the utilization of improved customized hardware. However, the translation of neuromorphic algorithms to hardware is not easily accomplished. In particular, building superconducting neuromorphic systems requires expertise in both superconducting physics and theoretical neuroscience, which makes such design particularly challenging. In this work, we aim to bridge this gap by presenting a tool and methodology to translate algorithmic parameters into circuit specifications. We first show the correspondence between theoretical neuroscience models and the dynamics of our circuit topologies. We then apply this tool to solve a linear system and implement Boolean logic gates by creating spiking neural networks with our superconducting nanowire-based hardware.

## 1. Introduction

Neuromorphic computing attempts to mimic the behavior of biological neurons and synapses in the human brain. Recently, increased understanding of the physics of devices for neuromorphic computing [1, 2], and the theory of algorithms for neuromorphic computing [3] has led to the development of CMOS-based neuromorphic architectures [4] that are three orders of magnitude more efficient in terms of their energy-delay product when compared to traditional multiply-and-accumulate operations [5]. However, these systems are also nowhere near the power figure of merit (energy per operation) required to create a massive scale neuromorphic computer, such as the human brain.

For these reasons, efforts to mimic neurons and synapses may need to move towards systems that have an intrinsic spiking ability and extremely low energy consumption. This is the case in superconducting electronics where the constituent elements exhibit nonlinear characteristics and have very low or no power dissipation. Superconducting circuits offer drastically lower power consumption even when cryogenic cooling energy costs is taken into account [6, 7]. Previous developments of neuromorphic architectures using superconducting electronics have used Josephson junctions [8–11], quantum-phase slip junctions [12–14], magnetic tunnel junctions [15], systems with Josephson junctions and superconducting nanowire single photon detectors [16, 17], and nanowires as relaxation oscillators [7] to construct circuits that emulate biological neurons and synapses. Superconducting nanowires offer ease of fabrication and are most easily integrated with classical circuit elements. In addition, the ability of superconducting circuits to operate with near-lossless interconnects makes them an attractive choice for implementing a low-power neuromorphic architecture.

Simultaneously, the success of artificial neural networks (ANNs) [18] in computing applications such as pattern recognition and natural language processing coupled with the widespread adoption of machine learning methods in many areas of science and engineering is an indication that abstracting a computing problem and eliminating hardware dependencies is a promising approach for going beyond Moore's law. Among these networks, spiking neural networks (SNNs) closely simulate the dynamics of biological neurons and synapses in the brain. Approaches to SNNs that possess brain-like properties have gained increased attention due to



**Figure 1.** Circuit topology for a circuit consisting of an input neuron (left) upstream, a synapse (centre), and a target neuron (right) downstream. The neuron has a control (pink) and main (blue) relaxation oscillator each with a nanowire  $nw_1$ ;  $nw_2$ . Voltage spikes at node  $V_{\text{out},1}$  generate heat (orange arrows) in close proximity of the hTron in the synapse which will be transferred to the target neuron via  $R_{\text{out}}$ .

their widespread use in applications spanning decision making [19], image recognition [20] and optimization problems [21].

The direct translation of superconducting neuromorphic architectures into algorithmic formulations of a problem has been little explored, and a complete description of an algorithmic implementation in neuromorphic hardware remains to be seen. It is very difficult for hardware designers to condense an abstract algorithmic problem into a specific hardware platform without increasing the complexity of circuits or compromising energy efficiency. This gap in the field stems from the difficulty in reconciling the algorithmic and hardware oriented approaches. At this point in time, this issue is often a question of expertise: hardware designers do not have ready knowledge of algorithmic subtleties, while algorithm developers do not have access to the hardware. Thus, there is a need for a tool to allow computer scientists to test algorithms on neuronal circuits. We devise and present such a tool here.

In this work, we address the issue of translation from theoretical algorithms to a specific implementation by using the example of solving linear systems with a superconducting neuromorphic network. We show the direct relation between a basic compositional model as well as a leaky integrate-and-fire model and the proposed superconducting nanowire-based neuromorphic hardware. We compile this correspondence into a tool to translate between hardware and algorithmic descriptions of the neuromorphic architecture. We conclude with a discussion on the outlook of the scaling of superconducting nanowire-based circuits in the context of neural networks.

#### 2. Methods

The building blocks of the hardware architecture are superconducting nanowires [22] and hTrons [23]. In a superconducting nanowire biased with a current, superconductivity breaks down when the current when the current exceeds the critical current  $I_c$ . As a consequence, the nanowire develops a resistance  $R_{hs}$  and a voltage  $v = i_{nw}R_{hs}$ . Superconductivity is restored in the nanowire when its current is reduced below the retrapping current  $I_r$ . When a superconducting nanowire is placed in parallel with a resistor, the relaxation from the normal to the superconducting state of the nanowire can couple with the resistor. When biased by a current above  $I_c$ , the nanowire switches and electrothermal feedback produces continuous voltage spikes across the nanowire. This is termed a relaxation oscillator [24].

The hTron is a circuit element that acts as a thermally activated switch. It consists of a superconducting nanowire (the channel), placed in close proximity to a resistive element (the gate) [23]. When the channel is biased by a current below its threshold  $I_{c,h}$ , heat dissipated by the gate can increase the temperature of the channel and break superconductivity. Superconductivity is restored in the channel when it has cooled and its



**Figure 2.** Simulation results of excitatory and inhibitory connections between neurons. (a) Circuit schematic for a neuron-synapse-neuron network (b) waveforms showing the spikes  $V_1$  of neuron 1, the current in the synapses  $I_{\rm syn}$ , and the spikes  $V_2$  and  $V_3$  of neurons 2 and 3. In this simulation,  $I_{\rm in,1}=22~\mu{\rm A}, I_{\rm in,2}=19~\mu{\rm A}$  and  $I_{\rm in,3}=22~\mu{\rm A}$ .



**Figure 3.** Simulation results of the frequency tunability of the nanowire neuron. (a) Plot of spike waveforms at neuron output with varying  $I_{\rm in}$ . Note that the waveforms are offset vertically for clarity. Spiking frequency increases with increased input current to the neuron. (b) Colour map of the firing rate (inverse of the spike period) of nanowire neurons as a function of  $I_{\rm in}$  and  $I_{\rm bias}$ . These tuning currents determine the firing potential of the neuron.

current is reduced below a threshold  $I_{r,h}$ . This threshold is dependent on the temperature of the channel and decreases for increasing temperature [23].

The simulations used in this work are based on models for superconducting nanowires [22] and for hTrons [23] implemented in LTSPICE [25].



**Figure 4.** Simulation results of the design space of the hTron synapse and the current-controlled tunability of the hTron synapse. (a) The time-domain response of the synaptic current plotted for various values of  $L_{\text{syn}}$ . (b) The tunability of the synapse strength for various values of  $I_{\text{bias},h}$  for  $L_{\text{syn}} = 1 \, \mu\text{H}$ . This plot is inverted for negative  $I_{\text{bias},h}$ .

### 2.1. Hardware design

In previous work [7], the application of two superconducting nanowires whose intrinsic nonlinear inductance  $L_{\text{nw}}$  was used to generate spiking behaviour is presented. We summarize the description here.

As illustrated in figure 1, the nanowire neuron consists of a main and control relaxation oscillator in a loop. A source  $I_{\text{bias}}$  biases both oscillators below their critical currents but in opposite directions. An input current pulse at  $I_{\text{in}}$  applied to the loop then results in the current in the main oscillator to exceed  $I_{\text{c}}$ , causing it to switch. Then, current is diverted counterclockwise in the loop which causes the control oscillator to switch while the main oscillator relaxes. The switching of the control oscillator diverts current clockwise and causes the main oscillator to switch again. Each time main oscillator switches, a voltage spike will be seen at node  $V_{\text{out}}$ . The main and control oscillator act analogously to the Na<sup>+</sup> and K<sup>+</sup> ion channels in the Hodgkin–Huxley neuron model [26].

The synapse consists of an hTron and an integration loop formed by  $L_{\rm syn}$ ,  $R_{\rm syn,1}$ , and  $R_{\rm syn,2}$ . When a voltage spike appears at  $V_{\rm out}$ , heat is dissipated across  $R_2$  (orange arrows).  $R_2$  acts as the gate of the hTron, and the heat from it lowers the critical current of the hTron channel, causing the hTron to switch. In the switched (normal, non-superconducting) state, the resistance of the channel is typically on the order of  $10^2 \Omega$  for NbN films. The typical resistance for  $R_{\rm syn,1}$  and  $R_{\rm syn,2}$  is on the order of  $10 \Omega$ . Thus, when the hTron channel switches, the majority of the current  $I_{\rm bias,h}$  is diverted into the integration loop. A portion of the current through  $L_{\rm syn}$  is then transmitted to the target neuron via  $R_{\rm out}$ . This process is analogous to the integration behaviour of the Hodgkin–Huxley model [26].

The simulated operation of a simple neuron-synapse-neuron connection demonstrating excitatory and inhibitory behavior is shown in figure 2. The network illustrated consists of an input neuron (1) connected to two target neurons (2, 3). The spike output from neuron 1 is connected thermally to the synapses via the hTron and the synapses are connected electrically to neuron (2, 3). When  $I_{\text{in},1}$  makes neuron 1 fire, the spikes are integrated in the synapse as shown by  $I_{\text{syn}}$  in figure 2(b). This synaptic current leads to the excitation of neuron 2 for a brief period of time. Similarly, the same current  $I_{\text{syn}}$  but in the opposite direction leads to inhibition of the firing of neuron 3 for a brief period of time.

In SNNs, information must be encoded in the timing of the spikes in the network. In figure 3, we demonstrate the time-domain response of the neuron circuit with respect to its current biasing conditions. We define the spike period as the time between the voltage spikes in a neuron. Figure 3(a) demonstrates a decrease in the spike period of the nanowire neuron as a function of increasing input current. This same behaviour is seen in overbiased relaxation oscillators, where biasing a nanowire above its critical current also results in frequency-tunable oscillations [27]. We map the effect of this current-controlled frequency-tunability in figure 3(b). From the color map a firing threshold for the nanowire neuron can be identified from the summation of the input and bias currents. Once this threshold is reached, either an increase in the bias current or an increase in the input current result in an increase in the firing rate. This behavior can be explained from the critical current dynamics of the nanowires in the neuron circuit.

Similarly, the synapse circuit presented in figure 1 also demonstrates tunable characteristics. The integration loop of the synapse acts as a leaky integrator circuit. The time-domain response of this circuit can be

set during its design, by choosing the ratio between the  $L_{\text{syn}}/R_{\text{syn}}$  time constant and the  $L_{\text{nw}}/R_2$  time constant, where  $L_{\text{nw}}$  is the inductance of  $nw_2$ . The leakiness of the synapse is illustrated in figure 4(a) where the current in the synaptic inductor is plotted for different values of synaptic inductance. In addition,  $I_{\text{bias},h}$  controls the amount of current injected into the integration loop, modifying the output of the synapse. Therefore, the strength of the synaptic connection can be updated externally by tuning  $I_{\text{bias},h}$ . Figure 4(b) shows the output current of the synapse for different values of  $I_{\text{bias},h}$ .

#### 3. Results

To connect our hardware with the computational picture of a neural network, we developed two mappings from hardware to mathematical models. First is a mapping between the physical system described in the previous section and the well-known leaky integrate-and-fire neuronal model [28], second is the mapping to a recently developed compositional model for SNNs [3].

#### 3.1. Correspondence

#### 3.1.1. Correspondence to leaky integrate-and-fire model

The leaky integrate-and-fire neural network is one of the most commonly studied network-level models in neuroscience. In a network of n neurons, each is associated with a time-varying potential value. In this model, a neuron's potential is governed by the following equation:

$$\frac{\mathrm{d}u_i(t)}{\mathrm{d}t} = -\lambda \left( u_i(t) - u_{0,i} \right) - \sum_i \alpha C_{ij} s_j(t) + I_i(t) \tag{1}$$

where  $u_i(t)$  represents the potential of the ith neuron at time t;  $u_{0,i}$  is the initial potential with no input; and  $I_i(t)$  is the external input to the neuron. The leaky integration dynamic is encapsulated in the leakiness parameter  $\lambda$  of the neuron, that is the rate at which the neuron potential decreases. The synaptic strength from a neuron i to a neuron j is represented by matrix coefficient  $C_{ij}$  and a transfer parameter  $\alpha$ . The spiking events of neuron i occur according to the following spike rule s(t):

$$s(t) = 1, \quad u_i(t) > \eta$$
  
 $s(t) = 0, \quad \text{otherwise},$  (2)

where  $\eta$  is the threshold potential. We relate the parameters of this model to our superconducting hardware as described below.

In our hardware, the current in the nanowire  $i_{nw}(t)$  of the neuron's main oscillator corresponds to the potential  $u_i(t)$  in the leaky integrate-and-fire model. In the nanowire-based implementation, the spike rule corresponds to the voltage in the nanowire, the spiking events of the nanowire neuron are described by the following spike rule:

$$v_{\text{nw}}(t) = i_{\text{nw}} R_{\text{hs}}, i_{\text{nw}}(t) > I_{\text{c}}$$

$$v_{\text{nw}}(t) = 0, \quad \text{otherwise.}$$
(3)

This relatively natural correspondence is what makes the superconducting system particularly elegant for the implementation of SNNs.

Similarly, the initial potential  $u_0$  directly corresponds to the initial value of  $i_{nw}$ . For instance, when the inductance and resistance values between the two branches of the neurons are the same, the bias current in the nanowire of the main oscillator will be  $I_{bias}/2$ .

Moreover, the integration behaviour of the model corresponds to the ability of the hTron synapses to integrate the voltage spikes generated by the upstream neurons. The switching of the hTron channel and its subsequent diversion of current into the integration loop of the synapse, can be approximated by a leaky integration circuit with dynamics described by:

$$\frac{\mathrm{d}i_{\mathrm{int}}}{\mathrm{d}t} = \frac{1}{\tau}(v_{\mathrm{in}} - i_{\mathrm{int}}). \tag{4}$$

Continuing with the analogy, the leakiness parameter  $\lambda$  corresponds to the ratio of the time constant of the relaxation of the nanowire in the neuron to the time constant of the integration loop in the synapse  $\tau_{\rm nw}/\tau_{\rm syn} = (L_{\rm nw}/R_2)/(L_{\rm syn}/R_{\rm syn_1})$ .  $\tau_{\rm syn}$  can be set such that it is larger than  $\tau_{\rm nw}$  to allow the synapse to retain the spike information from the neurons.

The transfer parameter  $\alpha$  in the model corresponds to the ratio between  $I_{\text{bias},h}$  and the current entering the nanowire of the main oscillator. The value of  $\alpha$  is dependent on the number of synapses connected to a

Table 1. Correspondence between the leaky integrate-and-fire model and the hardware description.

| Leaky integrate-and-fire model              | Physical model                                                      |
|---------------------------------------------|---------------------------------------------------------------------|
| Initial potential of a neuron $u_{0,i}$     | Initial current in the nanowire, $i_{\text{nw}}(0)$                 |
| Spike function $s(t)$                       | Voltage spikes at $V_{ m out}$                                      |
| Connection between neurons, $\alpha C_{ij}$ | Bias current in the synapse $I_{\text{bias},h}$                     |
| Potential of a neuron, $u_i(t)$             | Current in the nanowire of the main oscillator $i_{nw}(t)$          |
| Spike rule $u_i(t) > \eta$                  | Nanowire switches when $i_{nw}(t) > I_c$ with noise                 |
| Leakiness parameter, $\lambda$              | Time constants of the neuron and synapse $	au_{ m nw}/	au_{ m syn}$ |

**Table 2.** Correspondence between the compositional model and the hardware description.

| Compositional model                 | Physical model                                             |
|-------------------------------------|------------------------------------------------------------|
| Bias conditions of a neuron, $b(u)$ | $I_{\rm in}$ and $I_{ m bias}$ in figure 3                 |
| Configuration of a neuron, $C_t(u)$ | Voltage spikes at $V_{ m out}$                             |
| Weight of a synapse, $w(u, v)$      | Bias current in the synapse, $I_{\text{bias},h}$           |
| Potential of a neuron $pot_t(u)$    | Current in the nanowire of the main oscillator $i_{nw}(t)$ |
| Firing probability, $p_t(u)$        | Nanowire switches when $i_{nw}(t) > I_c$ with noise        |

neuron, the synaptic inductance, and the inductances  $L_1$  and  $L_2$  of the nanowire neuron. For a neuron with a large number of synapses connected to its input terminal, less current from each synapse enters the neuron.

The matrix coefficients  $C_{ij}$  correspond to  $I_{\text{bias},h}$  between the ith and jth neurons as it represents the strength of the connection between two neurons via a synapse. In the hardware,  $C_{ij}$  can be externally tuned as discussed in the previous section and illustrated in figure 4. Coupled together,  $C_{ij}$  can be mapped to the current added to the nanowire of the main oscillator.

The  $I_i(t)$  terms in the model correspond to the external input current source  $I_{in}$  to the *i*th neuron as shown in figure 1.

#### 3.1.2. Correspondence to a basic compositional model

An algorithmic model for SNNs has been recently introduced [3]. The model lays out a schema to track a set of neurons (nodes) *V* with a set of synapses (edges) *E*, in a graph by recording a potential for each neuron, at some discrete time.

- In the model, a neuron can be in one of two states: firing and not firing. For a neuron at node u we have  $C_t(u) = 1$  when the neuron is firing and  $C_t(u) = 0$  when not firing. We call this function the *configuration* of a neuron.
- The connection between a neuron u and neuron v via a synapse is encapsulated in a function w(u, v).
- At discrete time t, every neuron u has a potential  $\operatorname{pot}_t(u) = [\sum_{(v,u) \in E} C_t(v) w(v,u)] b(u)$ .
- The firing rule for the neuron is probabilistic and is described by  $p_t(u) = \frac{1}{1+e^{\frac{-pot_t(u)}{\lambda}}}$ . Here  $\lambda$  is distinct from the leakiness parameter of the leaky integrate-and-fire model and is instead an arbitrary real *temperature* parameter.

The neuron biasing condition b(u) is akin to the currents  $I_{in}$  and  $I_{bias}$  into a neuron as in figure 1. We associate the neuron biasing condition to be the location  $(I_{in}, I_{bias})$  as in figure 3(b).

The configuration of a neuron  $C_i(u)$  corresponds to the state of the nanowire of the main oscillator of the neuron. When the nanowire switches, the neuron is firing. Conversely, when the nanowire is in the superconducting state the neuron is not firing.

The weight of a synapse between two neurons w(u, v) is mapped to  $I_{\text{bias},h}$  of the synapse between them. As in the leaky integrate-and-fire model, this weight can be externally tuned as demonstrated in figure 4.

The potential of the neuron  $pot_t(u)$  can be associated with the current in the nanowire of the main oscillator  $i_{nw}(t)$ . As shown in figure 1, this current dependent on the on  $I_{bias}$  and  $I_{in}$  and is affected by the current coming from the connections of other synapses.

The firing rule  $p_t(u)$  can be associated with the switching of the nanowire in the main oscillators. While it is true that the nanowire switches whenever  $i_{nw}(t) > I_c$ , this is probabilistic in a physical implementation and is dependent on  $I_{in}$  and  $I_{bias}$ . The firing probability as a function of  $I_{in}$  and  $I_{bias}$  was explored in experiments with nanowire neurons here [29].

We summarize the correspondence between the two models presented and the physical parameters in the tables 1 and 2.

#### 3.2. Model and translational tool

From the above descriptions of the leaky-integrate-and-fire model and the basic compositional model for SNNs, we built a tool to directly relate the parameters of the models to the physical implementation of the nanowire neuron and synapse. This tool can help bridge the expertise gap between computer scientists and hardware engineers in designing neuronal circuits as it provides a platform for a common description of a problem.

#### 3.2.1. Implementation of the translational tool

In the tool, the network consisting of the neurons and synapses is described as a graph. A vector V describing the bias conditions to the neurons (the vertices) and a matrix E describing the strength of the synapses between them (the edges) is specified. Then, the algorithmic description from the leaky integrate-and-fire model, or the compositional model is chosen. Depending on the choice of model, V is treated as  $I_i(t)$  or  $I_i(t)$  or

The tool uses SciPy's numerical solver IVP [30] to simulate the underlying system based on a state variable description of the nanowire neuron circuit, as follows:

$$\frac{di_{1}}{dt} = (i_{2}R_{1} - i_{1}R_{hs}n_{1})/L_{nw}(i_{1})$$

$$\frac{di_{2}}{dt} = -\frac{1}{L_{1} + L_{2}} \left( L_{1} \frac{di_{in}}{dt} + i_{2}R_{1} - i_{4}R_{2} \right) - \frac{di_{1}}{dt}$$

$$\frac{di_{3}}{dt} = (i_{4}R_{2} - i_{3}R_{hs}n_{2})/L_{nw}(i_{3})$$

$$\frac{di_{4}}{dt} = \frac{1}{L_{1} + L_{2}} \left( L_{1} \frac{di_{in}}{dt} + i_{3}R_{1} - i_{4}R_{2} \right) - \frac{di_{3}}{dt}$$
(5)

in this case,  $L_{\text{nw}}(i)$  is a nonlinear function accounting for the kinetic inductance of the nanowire following the expression from [22]. We define the current  $i_{\text{in}}$  as  $I_{\text{in}} + \sum_k i_{\text{syn},k}$  where  $i_{\text{syn},k}$  is the current flowing through  $R_{\text{out}}$  from each synapse to the neuron and  $I_{\text{in}}$  is as in figure 1. The remaining current variables are further defined in the appendix A.

Note that here we make a simplifying assumption about the dynamics of a superconducting nanowire. We specify a state variable  $n_i$  for each nanowire to capture whether the nanowire is in the superconducting  $(n_i = 0)$  or the normal  $(n_i = 1)$  state. The transition from the superconducting to the normal state is brought about when  $i_{nw}(t) > I_c$ . The transition form the normal state back to the superconducting state occurs when  $i_{nw}(t) < I_r$ .

Similarly, a state-variable description for the synapse is as follows:

$$\frac{di_{1}}{dt} = \left(i_{2}R_{\text{syn,1}} - i_{1}R_{\text{hs}}h\right)/L_{\text{nw,h}}(i_{1})$$

$$\frac{di_{2}}{dt} = -\frac{di_{1}}{dt} - \frac{di_{3}}{dt}$$

$$\frac{di_{3}}{dt} = \left(i_{2}R_{\text{syn,1}} - i_{4}R_{\text{syn,2}}\right)/L_{\text{syn}}$$

$$\frac{di_{4}}{dt} = \frac{di_{3}}{dt} - \frac{di_{5}}{dt}$$

$$\frac{di_{5}}{dt} = \left(i_{4}R_{\text{syn,2}} - i_{5}R_{\text{out}}\right)/L_{2}.$$
(6)

We use the same simplifying assumption about the dynamics of the channel of the hTron as we use for the nanowires in the neuron. Transitions to the normal state in the channel of the hTron are brought about after its current surpasses  $I_{c,h}$  and its return to the superconducting state occurs when its current is below  $I_{r,h}$ . To couple neuron and the synapse, we force the hTron channel to switch everytime the neuron fires, that is we set h = 1 whenever  $n_2 = 1$ . In an effort to facilitate broad use of this model, we reference the code implementing it here [31].

As an example, using the tool to relate a leaky integrate-and-fire model to the hardware, the following steps are taken to translate the algorithmic description to the hardware:

- (a) The neurons and the synapses between them are configured as specified by the user in their graph description.
- (b) By default, the internal parameters of a neuron  $(L_{\rm nw}, L_1, L_2, R_1, R_2)$  are set to typical values (10 nH, 20 nH, 20 nH, 5  $\Omega$ , 5  $\Omega$ ) as are the parameters of a synapse  $(L_{\rm nw,h}, R_{\rm syn,1}, R_{\rm syn,2}, R_{\rm out})$  are set to (100 nH, 10  $\Omega$ , 10  $\Omega$ , 5  $\Omega$ ).
- (c)  $u_0$  and  $\eta$  are respectively mapped directly to  $I_{\text{bias}}$  in the neuron and  $I_c$  of the nanowires.
- (d)  $L_{\text{syn}}$  is set such that the leakiness parameter  $\lambda = (L_{\text{nw}}/R_2)/(L_{\text{syn}}/R_{\text{syn}})$ .
- (e) For each synapse,  $I_{\text{bias},h}$  is set such that the current in  $nw_2$  increases by a factor of  $C_{ij}$ . This ratio is maintained across all synapses. Correspondingly,  $I_{c,h}$  is set to be higher than  $I_{\text{bias},h}$ .
- (f) External inputs to the neurons  $I_i(t)$  are proportionally mapped to the input currents  $I_i$  of each neuron.
- (g) The network is simulated by solving the IVP's of underlying circuits.

In the following section apply the correspondence of our hardware to two algorithmic examples. We simulate Boolean gates and solve special linear systems with our superconducting-nanowire-based neuromorphic architecture. These choices stem from the ubiquitous nature of Boolean gates and algorithms to solve linear systems in classical computing.

#### 3.3. Solving linear systems

In a recent paper by Chou *et al* [32], non-leaky integrate-and-fire neural networks were shown to efficiently solve linear systems. Here, we demonstrate the computational power of SNNs in simulation by implementing their theoretical models using our superconducting nanowire-based architecture. As a proof of concept, we start with solving a simple two-dimensional linear system. Then, we scale up the problem to a five-dimensional linear system with Laplacian structure.

The motivation for Laplacian linear systems is two-fold: (1) many practical applications and engineering problems rely on solving large Laplacian linear systems such as diffusion models, graph models and random walks; (2) some Laplacian linear systems have infinitely many solutions. Chou *et al* [32] predicted that a SNN will converge to the solution with the least vector magnitude. We use the approach taken by Chou *et al* [32] to solve Laplacian linear systems, namely a  $2 \times 2$  and a  $5 \times 5$  system.

To translate a linear system of the form Ax = b to a SNN, we map  $C_{ij}$  to be the elements of the matrix  $A^{T}A$  and I(t) to be the vector  $A^{T}b$  to ensure that the matrix C is positive semidefinite (PSD). The number of neurons in the SNN corresponds to the dimension of A.

For the first example, we attempt to solve the following Ax = b linear system which is already PSD:

$$\begin{bmatrix} 1 & -0.5 \\ -0.5 & 1 \end{bmatrix} x = \begin{bmatrix} 0.5 \\ 3.5 \end{bmatrix} \tag{7}$$

We illustrate the network for solving this system and use the tool to handle parameter mapping as in figure 5. The connectivity matrix  $C_{ij}$  from the leaky integrate-and-fire model corresponds to the matrix  $(-1) \times A$  in the problem. We can then map the elements of matrix A from the problem to the weights of the synapses as shown in figure 5(a). Similarly, the row elements of vector b are mapped to the ramp rates of currents at  $I_{in}$  for each of the neurons relative to the timescale T of the neuron. To apply the leaky integrate-and-fire model, we set the timescale of integration  $\lambda = 0.02$  to ensure that the current in the synapse decays much slower relative to the decay of current after a neuron spike. Using the tool, we chose  $\alpha = 0.67$  and  $u_0 = 0.95\eta$ .

The evolution of the system is illustrated in figure 5(c). Initially, neither neuron is firing. As time progresses, the input current to each neuron increases at different rates. Since the external bias for neuron 2 is greater, its potential will increase faster and it will fire earlier. When neuron 2 fires, both of its outgoing synapses are activated. Neuron 2 excites neuron 1 but also inhibits itself. After some time, neuron 1 will fire as a result of the excitation from neuron 2. When neuron 1 fires, it will excite neuron 2 but inhibit itself. As can be seen in figure 5(b), two distinct firing rates emerge from the system. Specifically, we reference the approach of Chou et al [32] to define a firing rate as:

$$N(t)/t$$
, (8)

where N(t) is the cumulative number of spikes at time t. As can be seen in figure 5(b), we find that the firing rate of each neuron converges to the rows of the solution vector of the linear system  $x = \begin{bmatrix} 3 & 5 \end{bmatrix}^T$ .



**Figure 5.** Implementation of an SNN to solve a linear system using simulated superconducting hardware. (a) Graph representation of a network with two neurons (N1, N2) with synapses. The weight of each synapse is inscribed in the synapse itself. (b) Plot of the calculated firing rate of each neuron as the system evolves. (c) Voltage spike waveforms for each neuron at its output voltage node. For this simulation the timescale *T* of a neuron spike is approximately 37 ns. Note that orange arrows represent connections via the thermal domain and grey arrows represent connections via the electrical domain

To illustrate the generality of the method, we extend the approach to solving a more complex linear system. We apply the same approach to solving a cycle graph represented by the following Ax = b linear system which is again already PSD:

$$\begin{bmatrix} 1 & -0.5 & 0 & 0 & -0.5 \\ -0.5 & 1 & -0.5 & 0 & 0 \\ 0 & -0.5 & 1 & -0.5 & 0 \\ 0 & 0 & -0.5 & 1 & -0.5 \\ -0.5 & 0 & 0 & -0.5 & 1 \end{bmatrix} x = \begin{bmatrix} -2.5 \\ 0 \\ 0 \\ 0 \\ -2.5 \end{bmatrix}$$
(9)

We can map again the elements of matrix A to the connectivity matrix  $C_{ij}$  and the elements of vector b to the input currents of the neurons. We use the tool described in the previous section to simulate the system and illustrate the results in figure 6.

These results can be understood from an energy minimization perspective. When neuron 5 fires, it will excite neuron 4 after a long period of time. When neuron 4 begins firing continuously, neuron 3 will be excited. This same effect will propagate to neuron 2 after a period of time. Neuron 1 will not fire due to the fact that the input current to the neuron is negative. This is illustrated in figure 6(b) where the firing rates of the different neurons have different activation times. It must then be noted that this linear system Ax = b defined by the cycle graph has multiple solutions and the firing rate of our SNN approaches the solution with the least L1 norm as predicted in  $\begin{bmatrix} 32 \end{bmatrix}$ :  $x = \begin{bmatrix} 0 & 1 & 2 & 3 & 4 \end{bmatrix}^T$ .

To assess the evolution of the network and determine error in the firing rate, we defined the least square error as follows:

$$err = ||Ax - b|| / ||b|| \tag{10}$$

where the notation ||b|| signifies the magnitude of the vector. We take x to be the instantaneous firing rate vector. We plot the evolution of the least square error in figure 6(c).

### 3.4. Boolean gates

We also implement several Boolean gate network examples found in Lynch and Musco's paper [3]. The networks were created using their algorithmic model and then translated into our neuromorphic hardware. Boolean gates are relevant algorithmic examples to convert into neuromorphic computing hardware given



**Figure 6.** Implementation of an SNN to solve a cycle graph using simulated superconducting hardware. (a) Graph representation of a network with two neurons (N1–N5) with synapses. The weight of each synapse is inscribed in the synapse itself. (b) Plot of the firing rate of each neuron as the system simulation evolves. (c) Calculated least square error of the solution as the system evolves. For this simulation, the timescale of a neuron spike is approximately 31 ns. Note that orange arrows represent connections via the thermal domain and grey arrows represent connections via the electrical domain

their high importance in classical computing and their use in neural networks. Thus, neuromorphic versions of a universal set of Boolean gates could enable computation with both classical and neuromorphic paradigms.

We demonstrate a three-input AND gate network in figure 7. In the following paragraph, we describe the operation of this network using the compositional framework from Lynch and Musco's paper [3]. We understand the operation of the network using the compositional model. The weight of the synapses are taken to be L. When all three of the input neurons fire, the potential of the neuron is -b+3L and the probability of the output neuron firing is  $(1+\exp(b-3L))^{-1}$ . When only two input neurons fire, the probability of the output neuron firing is  $(1+\exp(b-2L))^{-1}$ . If we take  $L=2\ln(\frac{1-\delta}{\delta})$  and  $b=\frac{5}{2}L$  we can see that the probability of output neuron firing when all three input neurons fire is  $1-\delta$  for  $\delta$  being an arbitrary small parameter. In practice, the synapse and neuron biasing conditions determine  $\delta$ , allowing  $\delta$  to be set arbitrarily close to 0. In a physical implementation of the network, the probability of the output neuron firing can be attributed to current noise which causes fluctuations in the current of the nanowires. If a nanowire is biased very closely to  $I_c$  then there is a probability it may switch.

In addition, we demonstrate a three-input OR gate in figure 8. The input currents and the synapse bias currents are similar to the AND gate. Through an analogous formulation as in the AND gate, we can set the biases in the network such that the output neuron fires with probability  $1-\delta$  when one of the input neurons fires, it fires with probability  $\delta$  if none of the input neurons fire. Again,  $\delta$  can be made arbitrarily close to 0 in this model. We can understand this as a threshold problem allowing for the robust implementation of Boolean gates.

## 4. Discussion

Solving a physical system by using another physical system with similar dynamics as its model is a promising approach to computing. Here we discuss the advantages and failings of the approach and provide insight on how such a system could be realized.



Figure 7. Three-input AND gate. The synapse bias current for each connection is 27 μA, the input neuron bias current is 58 μA, and the corresponding bias for the output neuron is 54.6 μA for three inputs. The critical current for nanowires in the neurons is  $I_c = 30 \, \mu$ A. The current from an input neuron must be greater than 3.72 μA for it to fire. As more inputs are added the output neuron bias would have to be lowered accordingly.



**Figure 8.** Three-input OR gate. The synapse bias current for each connection is 27 μA, the input neuron bias current is 58 μA, and the corresponding bias for the output neuron is 57 μA for 3 inputs. The critical current for nanowires in the neurons is  $I_c = 30 \, \mu$ A. This output bias would not have to be lowered upon adding inputs because it only needs to fire if it receives enough input current from any one of the synapse connections.

#### 4.1. Solving linear systems with nanowire neurons

The approach by Chou et al for solving linear systems implemented in this paper is numerically robust. The solution of the Ax = b system is not physically tied to an experimental observable, such as voltage or current. As in [32], the numerical accuracy is a function of the total evolution time of the system. Accuracy can thus be optimized by increasing the time as well as by decreasing the time scale of the components of the circuits. Superconducting nanowires offer rise times on the order of a few ps and relaxation times as short as 2-5 ns from previous measurements [27]. Thus, least-square errors below  $10^{-3}$  might be achieved within tens of microseconds for large networks. The values of the resistors and inductors chosen to set the L/R time constants with the tool do not constraint the time scale of the SNN. Therefore, the solution can be obtained independently of the timing parameters set in the system. The implementation of this approach with superconducting hardware remains to be demonstrated experimentally. In neurons with high fan-in, that is with many incoming connections from synapses, the resistive network connecting a set of synapses to the input terminal of the neuron can result in significant power consumption. Higher current and resistances are needed to account for leakage current in such a network. Some previous approaches [25, 33] have suggested the use of fan-in trees to mitigate this problem which could be beneficial in our architecture. However, using either resistive networks or tree structure would still pose problems with either power or area scaling. An improved architecture for fan-in is needed to break this scaling

The advantage of our architecture is the decoupling of the neuron output to the synapse input via the hTron. Since no electrical connection is needed between the output node of a neuron to a synapse, there is no need for impedance matching. Hence, large fan-out can be achieved by patterning  $R_2$  to allow for heat dissipation at multiple locations where the hTron channels of multiple synapses could be located. However, this of course comes at a cost of higher power needed. An estimation of the power consumption of an implementation of the nanowire neuron can be found in previous work [7].

Due to non-idealities in the fabrication process for superconducting electronics, there can be difficulty in achieving small variance in the resistances, inductances, and critical currents of circuit components. This can lead to a spread in the distribution of the spike rise and relaxation times. However, variance across neurons is masked by the definition of the firing rate. After the network evolves for an appreciable time, the time between

the spikes need not matter more than the total number of spikes. The firing rate is thus a robust quantity. Even with non-idealities in the fabrication process, the architecture proposed in this work would not be significantly different from biological neurons and synapses, which intrinsically have variability. Here, we make the assumption that the design of the hTron can be optimized such that the synapses are still activated despite variations in the strength of the voltage spike at the neuron.

While some simple checks are implemented to check parameter ranges that are practically realizable by fabrication, additional experimental verification may still be needed. For instance, the range of synaptic weights in the synapses that can be designed via the inductance of  $L_{\rm syn}$  is limited by the kinetic inductance of the material used. We have chosen NbN with kinetic inductance 33 pH/sq for our tool owing to previous reports of implementations and measurements of nanowire neurons and synapses [7, 25]. To alleviate this problem, higher-kinetic-inductance materials such as WSi with kinetic inductance of 260 pH/sq [34] can be chosen instead. Achieving lower resistances is limited by the presence contact resistance and the inherent variability in fabrication processes. Similarly, the range of synaptic weights is also limited by the design of the hTron. The upper bound for the value of  $I_{\rm bias,h}$  stems from  $I_{\rm c,h}$ . Superconducting nanowires can be designed to have critical currents above 1 mA. However, challenges could arise with the size of components on chip. Larger critical currents typically are obtained from an increase in cross-sectional area of the superconducting trace. As a result, there is a large area cost for synaptic inductors with large kinetic inductances and high critical currents. This constraint may limit the values of  $C_{ij}$  that could be realized.

Another consideration in the design of the circuit network is the readout of the firing rate. For a fully integrated system as in [4], we envision a multi-layered system with readout and control circuitry connected by vias. For the firing rate readout circuit, superconducting counter circuits could be implemented based on nTron devices [35]. Similarly, a hybrid superconductor-transistor approach could allow for readout via classical digital logic [36]. In cases where the spike strength or the weights of the synapses are not known, the linearity of an Ax = b system could be exploited. Instead of using the individual firing rates of the neurons as the components of the solution vector x, the ratio of the firing rates of the neurons could be used instead. Superconducting single flux quantum (SFQ) logic architectures would then be available to realize more complex readout circuits [37] while still offering the advantages of superconducting electronics.

#### 4.2. Modelling

We have taken a simpler approach to modelling superconducting elements to accommodate the possibility of increased scaling. The tool ignores the microscopic electrodynamics of the system and the rigorous electrothermal physics that describes device operation. Instead, the state-variable description of the switching of the nanowires in the neuron and the hTron channel in the synapses is a simplification of the phenomenological models of [22, 25] which is convenient for algorithm designers and avoids non-linearities in the model [23]. For larger nanowires, there may be non-trivial dynamics that would deviate from the lumped element model and discrepancies that could arise from the temperature dependence of the physical parameters.

In the first example presented in the previous section, the tool enabled the translation of algorithmic parameters from the leaky integrate-and-fire model  $(\lambda, \alpha, C_{ij}, I_i)$  into specifications for the hardware  $(R_{1,2}, L_{1,2}, R_{\text{syn},1,2}, L_{\text{syn}}, R_{\text{out}}, \text{etc})$  with ease. While the approach presented in the previous section of choosing the parameters is not necessarily unique, it is possible for experts outside of superconducting electronics to understand and apply. Hence, there is no expertise in superconducting electronics required to explore further applications. Our superconducting hardware and its associated tool is versatile because it can be associated with many computational models—two are shown in this paper. Superconducting nanowires have also been applied in image recognition, Winner-Takes-All algorithms, stochastic behaviour [29]; and more conventional electronics [38]. By the same token, the tool is not dependent on circuit modelling software such as LTSPICE and uses the more common language of python rather than a higher-level professional language like Verilog A. As a result, the functionality of the tool presented in this work can be similarly extended to other superconducting systems based on Josephson junctions [8, 11, 17], and quantum phase-slip junctions [13, 14] albeit with increased complexity for the component models. Optimizing circuit layouts for power or area given a set of algorithmic constraints would also be an area of extension for the tool. These ideas constitute a useful continuation of this work.

## 5. Conclusion

We presented the fundamental components for the hardware implementation of a neural network based on superconducting nanowires. We translated the hardware architecture to its algorithmic description enabling a

straightforward understanding of the algorithmic correspondence of physical parameters. This understanding elucidates how more complicated networks of arbitrary scale can be built based on robust theoretical models. In addition, the work incites the future implementation of new models for biological neurons and synapses to replicate more complex bio-realistic behaviour. The description of a leaky integrate-and-fire model in terms of physical parameters enables the exploration of the design and fabrication of circuit layouts corresponding to linear system solvers.

Most importantly, the encapsulation of this work in a python-based tool is key in filling the gap between algorithmic designers and hardware designers. It is a point of commonality for the expertise within both of these fields. It can thus enable, in the future, concrete and fast approaches to solving neuromorphic problems using a superconducting nanowire-based neuromorphic architecture. The direct translation of superconducting neuromorphic architectures into algorithmic formulations of a problem is facilitated with this tool. As a result, it is now easier for hardware designers to condense an abstract algorithmic problem into a specific hardware platform without increasing the complexity of circuits or compromising energy efficiency as is typical of CMOS circuits. Thus, the issue is no longer a question of expertise.

## Acknowledgments

We wish to acknowledge the support of and thoughtful discussions with collaborators.

## Data availability statement

The data that support the findings of this study are openly available at the following URL/DOI: https://github.com/qnngroup/neuron.

## Appendix A. Circuit model

The nanowire neuron is made from two relaxation oscillators (figure 9). We define the currents  $i_1$  through  $i_6$  for the nanowire neuron as the currents in each branch of the three loops as in figure 10. Applying Kirchhoff's voltage law for the three loops yields the following equations:

$$L_{\text{nw}}(i_1)\frac{di_1}{dt} + i_1 R_{\text{hs}} n_1 = i_2 R_1 \tag{A1}$$

$$L_{\rm nw}(i_3)\frac{{\rm d}i_3}{{\rm d}t} + i_3 R_{\rm hs} n_2 = i_4 R_2 \tag{A2}$$

$$L_1 \frac{di_5}{dt} + i_2 R_1 = L_2 \frac{di_6}{dt} + i_3 R_2 \tag{A3}$$

The hTron synapse is similarly described by the equations from Kirchhoff's voltage law:

$$L_{\text{nw},h}(i_1)\frac{di_1}{dt} + i_1 R_{\text{hs}} h = i_2 R_{\text{syn},1}$$
 (A4)

$$i_2 R_{\text{syn},1} = L_{\text{syn}} \frac{di_3}{dt} + i_4 R_{\text{syn},2}$$
 (A5)

$$i_4 R_{\text{syn},2} = i_5 R_{\text{out}} + L_{\text{out}} \frac{\text{d}i_5}{\text{d}t}$$
(A6)

Here  $L_{\text{out}}$  is taken as  $L_2$ . We use state variables  $n_1$ ,  $n_2$  to capture the state of the nanowires in the neuron and h for the channel of the hTron. We modulate the critical current of the hTron according to the following rule:

if 
$$n_2 = 1$$
, then  $I_{c,h}' = \beta I_{bias,h}$ ,

where we define  $\beta$  to be a factor such that  $0 < \beta < 1$ . This ensures that the hTron channel switches when the nanowire in the main oscillator switches.







Figure 9. SEM images of fabricated relaxation oscillators (a), nanowire neurons (b), and synaptic integration loop in the synapse (c). Obtained from [25].



**Figure 10.** Circuit schematic for the nanowire neuron (a) and the hTron synapse (b) with definitions of currents for a state-description of the circuit in the superconducting state.

#### **ORCID** iDs

Andres E Lombo https://orcid.org/0000-0001-5842-4314 Karl K Berggren https://orcid.org/0000-0001-7453-9031

#### References

- [1] Marković D, Mizrahi A, Querlioz D and Grollier J 2020 Physics for neuromorphic computing Nat. Rev. Phys. 2 499
- [2] Berggren K *et al* 2020 Roadmap on emerging hardware and technology for machine learning *Nanotechnology* 32 012002 (Publisher: IOP Publishing)
- [3] Lynch N and Musco C 2021 A basic compositional model for spiking neural networks (arXiv:1808.03884 [cs])
- [4] Davies M et al 2018 Loihi: a neuromorphic Manycore processor with on-chip learning IEEE Micro 38 82 Conf. Name: IEEE Micro
- [5] Davies M 2021 Lessons from Loihi: progress in neuromorphic computing 2021 Symp. VLSI Circuits pp 1–2 iSSN: 2158-5636
- [6] Holmes D S, Ripple A L and Manheimer M A 2013 Energy-efficient superconducting computing-power budgets and requirements *IEEE Trans. Appl. Supercond.* 23 1701610 Conf. Name: IEEE Trans. Applied Superconductivity
- [7] Toomey E, Segall K and Berggren K K 2019 Design of a power efficient artificial neuron using superconducting nanowires *Front. Neurosci.* 13 933
- [8] Goteti U S and Dynes R C 2021 Superconducting neural networks with disordered Josephson junction array synaptic networks and leaky integrate-and-fire loop neurons *J. Appl. Phys.* 129 073901 (Publisher: American Institute of Physics)
- [9] Schneider M L and Segall K 2020 Fan-out and fan-in properties of superconducting neuromorphic circuits J. Appl. Phys. 128 214903 (Publisher: American Institute of Physics)
- [10] Crotty P, Schult D and Segall K 2010 Josephson junction simulation of neurons *Phys. Rev.* E 82 011914 (Publisher: American Physical Society)
- [11] Segall K, Guo S, Crotty P, Schult D and Miller M 2014 Phase-flip bifurcation in a coupled Josephson junction neuron system *Physica* B 455 71–5
- [12] Cheng R, Goteti U S and Hamilton M C 2019 Superconducting neuromorphic computing using quantum phase-slip junctions *IEEE Trans. Appl. Supercond.* 29 1Conference Name: IEEE Transactions on Applied Superconductivity
- [13] Cheng R, Goteti U S and Hamilton M C 2018 Spiking neuron circuits using superconducting quantum phase-slip junctions *J. Appl. Phys.* **124** 152126
- [14] Cheng R, Goteti U S, Walker H, Krause K M, Oeding L and Hamilton M C 2021 Toward learning in neuromorphic circuits based on quantum phase slip junctions *Front. Neurosci.* 15 1470

- [15] Schneider M L, Donnelly C A, Russek S E, Baek B, Pufall M R, Hopkins P F, Dresselhaus P D, Benz S P and Rippard W H 2018 Ultralow power artificial synapses using nanotextured magnetic Josephson junctions *Sci. Adv.* 4 e1701329
- [16] Shainline J M, Buckley S M, Mirin R P and Nam S W 2017 Superconducting optoelectronic circuits for neuromorphic computing Phys. Rev. Appl. 7 034013
- [17] Shainline J M et al 2019 Superconducting optoelectronic loop neurons J. Appl. Phys. 126 044902 (Publisher: American Institute of Physics)
- [18] Krizhevsky A, Sutskever I and Hinton G E 2012 ImageNet classification with deep convolutional neural networks Advances in Neural Information Processing Systems vol 25 (Long Beach, California: NeurIPS) https://proceedings.neurips.cc/paper/2012/hash/c399862d3b9d6b76c8436e924a68c45b-Abstract.html
- [19] Ye L and Li C 2021 Quantifying the landscape of decision making from spiking neural networks Front. Comput. Neurosci. 15 98
- [20] Tapson J C, Cohen G K, Afshar S, Stiefel K M, Buskila Y, Wang R M, Hamilton T J and van Schaik A 2013 Synthesis of neural networks for spatio-temporal spike pattern recognition and processing *Front. Neurosci.* 7 153
- [21] Maass W 2016 Energy-efficient neural network chips approach human recognition capabilities *Proc. Natl Acad. Sci. USA* 113 (Publisher: National Academy of Sciences Section: Commentary)
- [22] Berggren K K, Zhao Q-Y, Abebe N, Chen M, Ravindran P, McCaughan A and Bardin J C 2018 A superconducting nanowire can be modeled by using SPICE Supercond. Sci. Technol. 31 055010 (Publisher: IOP Publishing)
- [23] Baghdadi R *et al* 2020 Multilayered heater nanocryotron: a superconducting-nanowire-based thermal switch *Phys. Rev. Appl.* 14 054011 (Publisher: American Physical Society)
- [24] Toomey E, Zhao Q-Y, McCaughan A N and Berggren K K 2018 Frequency pulling and mixing of relaxation oscillations in superconducting nanowires Phys. Rev. Appl. 9 064021
- [25] Castellani M 2021 Design of superconducting nanowire-based neurons and synapses for power-efficient spiking neural networks Msc Thesis
- [26] Hodgkin A L and Huxley A F 1952 A quantitative description of membrane current and its application to conduction and excitation in nerve J. Physiol. 117 500
- [27] Toomey E 2020 Superconducting nanowire electronics for alternative computing PhD Thesis
- [28] Teeter C et al 2018 Generalized leaky integrate-and-fire models classify multiple neuron types Nat. Commun. 9 709
- [29] Toomey E, Segall K, Castellani M, Colangelo M, Lynch N and Berggren K K 2020 Superconducting nanowire spiking element for neural networks Nano Lett. 20 8059Publisher: American Chemical Society
- [30] Virtanen P et al 2020 SciPy 1.0: fundamental algorithms for scientific computing in Python Nat. Methods 17 261
- [31] https://github.com/qnngroup/neuron
- [32] Chou C-N, Chung K-M and Lu C-J 2018 On the algorithmic power of spiking neural networks (arXiv:1803.10375 [cs])
- [33] Primavera B A and Shainline J M 2021 An active dendritic tree can mitigate fan-in limitations in superconducting neurons (arXiv:2107.05777 [cs])
- [34] McCaughan A N, Toomey E, Schneider M, Berggren K K and Nam S W 2018 A kinetic-inductance-based superconducting memory element with shunting and sub-nanosecond write times Supercond. Sci. Technol. 32 015005
- [35] McCaughan A N and Berggren K K 2014 A superconducting-nanowire three-terminal electrothermal device Nano Lett. 14 5748 Publisher: American Chemical Society
- [36] Xie Q et al 2021 NbN-gated GaN transistor technology for applications in quantum computing systems 2021 Symp. VLSI Technology pp 1–2 iSSN: 2158-9682
- [37] Pasandi G, Shafaei A and Pedram M 2019 SFQmap: a technology mapping tool for single flux quantum logic circuits (arXiv:1901.00894 [quant-ph])
- [38] Zhao Q-Y, Toomey E A, Butters B A, McCaughan A N, Dane A E, Nam S-W and Berggren K K 2018 A compact superconducting nanowire memory element operated by nanowire cryotrons Supercond. Sci. Technol. 31 035009