# Josephson Junction Stuck-At Fault Detection in SFQ Circuits

Abdelrahman G. Qoutb<sup>®</sup>[,](https://orcid.org/0000-0002-4173-0566) Student Member, IEEE, Stephen Whiteley<sup>®</sup>, Life Member, IEEE, Jamil Kawa, and Eby G. Friedman<sup>®</sup>[,](https://orcid.org/0000-0002-5549-7160) Fellow, IEEE

*Abstract***—High reliability is an important requirement for all electronic integrated circuits including superconductive systems. Reliability and yield can be categorized by the failure paths, sequence of faults due to a physical failure, and failure mechanism. Determining the defects and faults is essential to enhance the lifetime of superconductive systems. Josephson junctions (JJs) are the base element of single flux quantum systems. The primary contributions described in this article are a set of JJ-based fault models followed by a methodology for developing high-level fault models. Based on these models, test vectors can be generated to detect the type and/or location of these JJ faults.**

*Index Terms***—Design for testability (DFT), fault models, single flux quantum (SFQ), superconductive digital electronics, superconductive (SC) integrated circuits.**

## I. INTRODUCTION

**T** HE challenge of achieving high performance with high reliability is escalating due to dimensional scaling, novel materials and devices, and operation in severe conditions (such as extreme cryogenic temperatures and subterahertz frequencies). These reliability challenges, combined with yield issues, are exacerbated by exotic manufacturing technologies.

Single flux quantum (SFQ) logic is a superconductive (SC) technology for low-power, high-performance cryogenic computing. The development of SFQ technology has enabled complex integrated circuits achieving over 11 000 Josephson junctions (JJs) for digital signal processors [\[1\]](#page-7-0) and similar complexity prototype RSFQ microprocessors [\[2\].](#page-7-0) SFQ circuits with a regular layout structure, such as an ac-biased SFQ shift register have reached 800000 JJs [\[3\],](#page-7-0) operating at subterahertz clock frequencies. The achievable frequencies and cryogenic environment make SFQ circuits difficult to control via external probing. Prototype evaluation of these circuits, therefore, requires advanced testing methodologies.

Abdelrahman G. Qoutb and Eby G. Friedman are with the Department of Electrical and Computer Engineering, University of Rochester, Rochester, NY 14627 USA (e-mail: [a.qoutb@rochester.edu;](mailto:a.qoutb@rochester.edu) [friedman@ece.rochester.edu\)](mailto:friedman@ece.rochester.edu).

Stephen Whiteley and Jamil Kawa are with Synopsys, Inc., Mountain View, CA 94043 USA (e-mail: [whiteley@synopsys.com;](mailto:whiteley@synopsys.com) [jamil@synopsys.com\)](mailto:jamil@synopsys.com).

Digital Object Identifier 10.1109/TASC.2023.3260144

Reliability and yield can be categorized by the failure paths and failure mechanisms. Determining the defects and faults is essential to enhancing the lifetime and testability of SC systems. This capability is achieved by improving the fault coverage, where the system is evaluated to identify the characteristics of the faults, such as the quantity, location, and type. Understanding the behavior of each failure mechanism and the development of effective and reliable methodologies that exploit design for testability (DFT) techniques prior to fabrication are vital to the development of testable SC systems.

The basic elements of SFQ systems are JJs, resistors, inductors, and interconnects [\[4\].](#page-7-0) In this article, high-level JJ-based fault models are proposed, and the required test vectors are described to detect the location and type of these faults [\[5\],](#page-7-0) [\[6\].](#page-7-0)

Several significant differences exist between conventional transistor-based CMOS fault models and JJ-based SFQ fault models beyond subterahertz clock frequencies and the cryogenic environment. An SFQ signal is represented by the existence of an SFQ pulse not as a voltage level (as in CMOS). In both CMOS and SFQ device-based faults, it is challenging to identify the location and type of faults within a system. The following additional differences prevent the use of standard CMOS-based DFT techniques [\[6\],](#page-7-0) [\[7\].](#page-7-0)

- 1) Only two states exist in SFQ logic, zero (the absence of a pulse) or one (existence of a pulse). In CMOS logic, output states, such as zero, one, and floating may exist.
- 2) SFQ logic gates are inherently clocked and latched within at least one storage loop, where several clock cycles are required to produce an output [\[8\].](#page-7-0) Unlike CMOS, in SFQ systems, additional information, such as the number of cycles, is required by a test controller.
- 3) Limited fan-out of SFQ gates and flip flops [\[9\].](#page-7-0) Splitters are required to provide additional outputs [\[9\].](#page-7-0)

The previous work on enhancing the testability of SC electronics, emphasizing process variations, defects, and structural testing, has been considered in  $[6]$ ,  $[10]$ ,  $[11]$ , and  $[12]$ . In  $[10]$ , a methodology is proposed to test timing violations due to process variations. This methodology is achieved by characterizing logic cells due to process variations and identifying the delay excitations [\[10\].](#page-7-0) Hence, test patterns are generated that guarantee to excite the worst case delay along each target multicycle path [\[10\].](#page-7-0) In [\[11\],](#page-7-0) fault models are produced based on a large number of simulations. These models are based on variation-induced failures by varying the value of the inductors, resistors, and critical currents [\[10\].](#page-7-0) Kerkhof and Speek [\[12\]](#page-7-0)

1051-8223 © 2023 IEEE. Personal use is permitted, but republication/redistribution requires IEEE permission.

See https://www.ieee.org/publications/rights/index.html for more information.

Manuscript received 28 September 2022; revised 24 January 2023; accepted 6 February 2023. Date of publication 22 March 2023; date of current version 25 April 2023. This work was supported in part by the National Science Foundation under Grant 2124453, in part by the Intelligence Advanced Research Projects Activity (IARPA) under Grant W911NF-17-9-0001, and in part by the Qualcomm and Synopsys. This article was recommended by Associate Editor Masamitsu Tanaka. *(Corresponding author: Abdelrahman Qoutb.)*

<span id="page-1-0"></span>

Fig. 1. SFQ fault mechanisms. Component-based faults are attached to a specific SFQ component. High-level models detect the faults associated with resistively shunted JJs. Other SFQ fault mechanisms include faults associated with the physical layout, faults due to connectivity between the devices, and faults due to limitations in the manufacturing process.

suggested defect-oriented testing by introducing possible defects, such as shorts in the same layer, bridges between layers, opens in layers and vias, and pinholes in the thin oxide layer. Hence, elements are inserted to detect these defects (as an example, inserting large and small capacitors to detect pinholes). Based on statistical information from detecting these defects, a model is presented to measure the quality of the fabrication process. From a literature survey, fault models that target specific defect mechanisms are missing. More research in this area is required to produce more efficient SFQ-based test methodologies.

A methodology is proposed here to include DFT within SFQ systems. To the best of our knowledge, this work is the first to describe JJ-based stuck-at faults. This objective is achieved by developing high-level fault models that target JJ-based faults, such as stuck-at in a SC state or an open state. These fault models can be exploited to develop a fault simulation algorithm. The required test vectors to identify the type and location of these sets of faults are generated based on a high-level fault model. A summary of the quality measures of each fault model is discussed in this article. The fault coverage of open-circuit (OC) and shortcircuit faults and the location of each logic cell are identified.

Potential faults within SFQ systems are categorized by devicebased faults, fabrication-based faults, and dc bias network faults, as shown in Fig. 1. JJ-based fault models are evaluated to generate the required test vectors to determine the location and/or type of defect.

The primary contribution of this article is a test methodology for SFQ systems. High-level JJ-based fault models are described followed by a methodology for developing a fault model to target a specific block or type of fault.

The rest of this article is organized as follows. JJ-based fault mechanisms and related fault models are discussed in Section II. These proposed JJ-based fault models are validated in Section [III.](#page-3-0) The required test vectors to detect and allocate JJ-based faults within an SFQ system are presented in Section [IV.](#page-3-0) The fault coverage of the proposed models are presented in Section [V.](#page-4-0) A methodology to develop a block-level JJ-based fault model to generate the required test vectors is described in Section [VI.](#page-6-0) Finally, Section [VII](#page-6-0) concludes this article.

# II. JJ-BASED HIGH-LEVEL FAULT MODELS

Multiple types of JJs exist within SFQ systems, such as unshunted, self-shunted, resistively shunted, and  $\pi$  junctions. Resistively shunted JJs are the most advanced fault type within state-of-the-art high-performance SFQ circuits. Faults associated with resistively shunted JJs are the focus of this article.

A faulty resistively shunted JJ has four modes of operation, stuck-at SC, stuck-at resistive, OC, and noisy switching. Further simplifications are necessary to develop JJ-based fault models that support complex testability mechanisms considering millions of JJs.

The great majority of physical failures results in stuck-at shorts and opens [\[13\].](#page-7-0) In this article, two JJ-based fault modes are considered, stuck-at SC state and stuck-at OC state.

Multiple physical defects can lead to a JJ stuck in the SC state, such as a JJ with a higher critical current than the expected value. Typical margins for a bias network are 20% to 30% of the critical current  $[14]$ ,  $[15]$ . If the critical current of a JJ is above this margin, the device behaves as a stuck-at SC state.

<span id="page-2-0"></span>

Fig. 2. Configuration of the logic cell under test where a Josephson transmission line is placed at the primary inputs and outputs of the logic cell under test.





Fig. 4. Splitter faults, (a) splitter cell, and (b) simulation of J2 stuck-at SC or OC state.

Fig. 3. JTL faults, (a) model of a JTL, and (b) simulation of a JJ stuck-at SC or OC state, indicating additional failure behaviors (circled). The squared JJ is the faulty JJ. Out\_ref is the output of a JTL with a reference cell (without faults). Out\_SC and Out\_OC are, respectively, the output of a JTL with a JJ stuck-at SC state and OC state.

A JJ stuck in the OC state can occur if a break exists in the tunneling barrier or interconnect. In this article, a JJ stuck in the SC state is modeled as a JJ with a high critical current (5 mA) to ensure the operation is in the stuck-at SC state, whereas a JJ stuck-at in the OC state is modeled as an OC.

#### *A. Fault Simulation and Analysis*

To develop a high-level fault model of a logic cell with a faulty JJ, the response of a circuit is considered to be only due to one fault type in a single JJ at a time. The logic cells within an SFQ cell library are based on the configuration shown in Fig. 2. A JJ-based fault model is presented for the following SFQ cells: Josephson transmission line (JTL), splitter, DFF, OR, and AND gates.

The simulation environment to model JJ-based faults within a JTL is illustrated in Fig.  $3(a)$ . The output of a JTL due to a JJ stuck-at SC state is zero. The output of a JTL with a JJ stuck-at OC state is challenging to detect. This output exhibits a small difference in delay from a reference JTL without faults, as shown in the circled areas depicted in Fig. 3(b).

Two types of JJs exist within a splitter, the driver JJ and the branch JJ. The simulation environment to model JJ-based faults within a splitter cell is shown in Fig. 4. The faulty output of a splitter with the driver JJ stuck in the OC state [see Fig.  $4(a)$ ] is similar to a reference output (without JJ faults), as illustrated in Fig.  $4(a)$ . In this condition, a stuck-at OC fault in the driver JJ is undetectable. The output of a splitter cell with a branch JJ

stuck in the SC state depends upon the location of the faulty JJ, as shown in Fig. 4(b). The output of a splitter cell, attached to a faulty JJ (stuck in the SC state), exhibits a single pulse followed by zeros, as depicted in Fig. 4(b).

The same procedure is followed to model other SFQ cells, such as DFF, AND, and OR gates. These logic cells have multiinput and multioutput ports, including an input clock signal. To provide a fault model for these gates, the cell under test is analyzed for all input conditions with the clock signal enabled or disabled. Testing all input cases is essential to determine the location and type of faulty JJs within a cell.

At least one storage loop exists in these logic gates. The location of a JJ within these logic gates sets the dependence of the cell function on the clock signal or latching operation. For the example shown in Fig.  $5(a)$ , a fault in J2 influences the clock signal, whereas a fault in J1 or J3 affects the storage loop. At least two test vectors are required to detect faults within these clocked logic gates, as discussed in Section [III.](#page-3-0)

As previously discussed in Section [II,](#page-1-0) high-level fault models are based on different cell behaviors caused by JJ-based faults. The fault models of a JTL, splitter, and DFF cell are, respectively, tabulated in Table  $II(a)$ –(c). These fault models are independent of technology and/or manufacturing process. As listed in Table [II,](#page-4-0) the output of each logic cell due to a fault in a JJ is compared with a reference cell (without faults). The faulty output is highlighted as a gray cell.

As shown in Fig. [5\(b\),](#page-3-0) an OR cell is composed of eight JJs with four control JJs and one DFF, whereas, as illustrated in Fig. [5\(c\),](#page-3-0) an AND cell is composed of 11 JJs, forming two DFFs and three control JJs. To provide a high-level JJ-based fault model of both an OR cell and an AND cell, the output is evaluated with and without the clock signal. As an example, when the clock signal is ON, a clock pulse is inserted after each input. High-level JJ-based

TABLE I HIGH-LEVEL JJ-BASED FAULT MODELS, (A) OR CELL, AND (B) AND CELL

<span id="page-3-0"></span>

| lА       | B               | Ref |                                                                                                      | J1       |  | J2           |          | J3       |  | J4           |          | J <sub>5</sub> |              | $J6$ w/o<br>clck |          | clck         |          | clck     |          | clck     |          | J6 w   J7 w/o   J7 w   J8 w/o  <br>clck |          | J8 w<br>clck |          |
|----------|-----------------|-----|------------------------------------------------------------------------------------------------------|----------|--|--------------|----------|----------|--|--------------|----------|----------------|--------------|------------------|----------|--------------|----------|----------|----------|----------|----------|-----------------------------------------|----------|--------------|----------|
|          |                 |     | W clck W/o clck   OC   SC   OC |          |  |              |          |          |  |              |          |                |              |                  |          |              |          |          |          |          |          | SC   OC   SC   OC                       |          | SC   OC   SC |          |
| $\Omega$ | $-101$          | 0   | $\Omega$                                                                                             | $\Omega$ |  | $\mathbf{1}$ | $\Omega$ | $\Omega$ |  | $\mathbf{1}$ | $\Omega$ | $\Omega$       | $\Omega$     | $\Omega$         | $\Omega$ | $\Omega$     | $\Omega$ | $\Omega$ | $\Omega$ | $\Omega$ | $\Omega$ | $\Omega$                                | $\Omega$ | $\Omega$     | $\Omega$ |
| $\Omega$ |                 |     | $\Omega$                                                                                             | 1        |  |              |          | 1        |  | 1            |          | $\Omega$       | 1            |                  | $\Omega$ |              | $\Omega$ | $\Omega$ | $\Omega$ | $\Omega$ |          |                                         |          |              | $\Omega$ |
|          | $\overline{10}$ |     | $\Omega$                                                                                             | 1        |  |              |          | 1        |  | 1            | $\Omega$ | $\Omega$       | $\mathbf{1}$ |                  | $\Omega$ |              | $\Omega$ | $\Omega$ | $\Omega$ | $\Omega$ | 1        |                                         | $\Omega$ |              | $\Omega$ |
|          |                 |     | $\Omega$                                                                                             | 1        |  |              |          | 1        |  |              |          | $\Omega$       | 1            |                  | $\Omega$ | $\mathbf{1}$ | $\Omega$ | $\Omega$ | $\Omega$ | $\Omega$ | 1        |                                         | $\Omega$ |              | $\Omega$ |



The faulty output is highlighted as a gray cell.



Fig. 5. Circuit structure of (a) DFF, (b) OR cell, and (c) AND cell.

 $(b)$ 

# III. VALIDATION OF PROPOSED JJ-BASED FAULT MODELS

The benchmark circuit shown in Fig. [7](#page-5-0) is used here to validate the proposed JJ-based fault models. This validation process identifies the logic paths of JJ-based faults within an SFQ system. As an example, one fault is inserted at J2 within the AND\_1 gate. As listed in Table  $I(b)$ , when J2 is stuck in the SC state within an AND gate, the faulty output is one when  $A = 1$  and  $B = 0$ . As shown in Fig. [6\(a\),](#page-4-0) the faulty and reference AND gates produce a correct output when  $A = 1$  and  $B = 1$ . When  $A = 1$  and  $B = 0$ , output AND 1 is one when J2 is stuck in the SC state. This faulty output propagates to the second stage of the benchmark circuit, as shown in Fig.  $6(b)$ . Out\_Ref is the result of an AND operation between AND\_1 and C\_1. The second-stage AND gate is free of faults. Hence, the source of the fault is only from AND\_1.

Based on these validation results the following: 1) the proposed JJ-based high-level fault models describe the operation of a cell with JJs stuck-at in either the OC or the SC state; 2) the influence of JJ-based stuck-at faults is localized within the gate where the fault exists. Hence, a JJ stuck-at fault in a specific gate does not cause additional faults in other gates. Based on these characteristics, the proposed technique for developing high-level fault models can shift JJ-based faults from a gate-level model to a block-level model. This technique can be used to develop a fault simulation tool for JJ-based stuck-at faults.

### IV. TEST VECTOR GENERATION

The required test vectors that identify the location and/or type of JJ-based fault are based on the proposed fault models. As an example, consider a JJ-based fault model of a JTL, as listed in Table  $II(a)$ . OC faults cannot be identified since the output of a faulty JTL with J1 stuck-at in the OC state is similar to a reference cell. The output of a faulty JTL with a JJ stuck in the SC state can be identified by detecting zero when a one is

signal is ON.

fault models of OR gate and AND gate are, respectively, listed in Table  $I(a)$  and (b). Note that a fault in the JJs forming the DFFs within the OR and AND gates may exhibit a different behavior when the clock signal is ON or when it is OFF. However, a fault in the control JJs can only be identified when the clock

<span id="page-4-0"></span>

Fig. 6. Validation of the proposed JJ-based fault models where a single JJ fault is inserted at AND\_1 gate. J2 is stuck-at SC, as shown in Fig. [7.](#page-5-0) Output of the reference cell without any faults, (a) at the first stage, faulty output AND\_1\_F is one when either  $A = 1$  and  $B = 1$  or  $A = 1$  and  $B = 0$ , whereas the true operation AND<sub>1</sub> is one only when A = 1 and B = 1. (b) At the second stage, where no faults exist, but the faulty output of the first stage propagates to the second stage. This behavior exemplifies that JJ-based stuck-at faults are localized faults that only affect the operation of a specific cell (the cell with the faulty JJ).

TABLE II HIGH-LEVEL JJ-BASED FAULT MODELS, (A) JTL, (B) SPLITTER, AND (C) DFF

|          |            |                |                             |    |                |                |                | Ref              |          | <b>OC</b>        | SC             |              |  |
|----------|------------|----------------|-----------------------------|----|----------------|----------------|----------------|------------------|----------|------------------|----------------|--------------|--|
|          |            |                |                             |    |                | In             | Out1           | Out <sub>2</sub> | Out1     | Out <sub>2</sub> | Out1           | Out2         |  |
| Out      |            |                |                             |    | J1             | $\theta$       | $\overline{0}$ | $\mathbf{0}$     | $\theta$ | $\mathbf{0}$     | $\theta$       | $\theta$     |  |
| In       | Ref        | <b>OC</b>      | SC                          |    |                | 1              | 1              | 1                | 1        | 1                | $\overline{0}$ | $\mathbf{0}$ |  |
| $\theta$ | $\theta$   | $\overline{0}$ | $\mathbf{0}$                |    | J2             | $\theta$       | $\theta$       | $\theta$         | $\theta$ | $\theta$         | $\theta$       | $\Omega$     |  |
| 1        | 1          | 1              | $\boldsymbol{0}$            |    |                | 11             | 11             | 11               | 11       | 11               | 0 <sub>0</sub> | 10           |  |
|          | (a)        |                |                             |    | J3             | $\theta$       | $\theta$       | $\theta$         | $\theta$ | $\theta$         | $\theta$       | $\theta$     |  |
|          |            |                |                             |    |                | 10             | 11             | 11               | 11       | 11               | 10             | 00           |  |
|          | <b>CLK</b> |                |                             |    |                | 00             | $\mathbf{1}$   | 010              | 101      | (b)              |                |              |  |
|          |            |                | Input<br>In                 |    |                | 11             | $\bf{0}$       | 101              | 010      |                  |                |              |  |
|          | Ref        |                |                             |    |                | 0 <sub>0</sub> | $\theta$       | 010              | 001      |                  |                |              |  |
|          |            |                | <b>OC</b><br>J <sub>0</sub> |    |                | 0 <sub>0</sub> | $\overline{0}$ | 000              | 000      |                  |                |              |  |
|          |            |                | SC                          |    |                | 00             | $\overline{0}$ | 010              | 001      |                  |                |              |  |
|          |            | J1             | <b>OC</b>                   |    | 00             | $\overline{0}$ | 010            | 001              |          |                  |                |              |  |
|          |            |                |                             | SC |                | 0 <sub>0</sub> | $\theta$       | 000              | 000      |                  |                |              |  |
|          |            | J2             | <b>OC</b>                   |    | 0 <sub>0</sub> | $\theta$       | 000            | 000              |          |                  |                |              |  |
|          |            |                | SC                          |    | 0 <sub>0</sub> | $\theta$       | 010            | 001              |          |                  |                |              |  |
|          |            | OС<br>J3       |                             |    |                | 0 <sub>1</sub> | $\mathbf{0}$   | 010              | 001      |                  |                |              |  |
|          |            |                | SC                          |    | 00             | $\bf{0}$       | 000            | 000              |          |                  |                |              |  |
|          |            |                |                             |    |                |                |                |                  |          |                  |                |              |  |

The faulty output is highlighted as a gray cell. Two test vectors are required to detect the fault if J2 or J3 is stuck-at SC. Detecting JJ-based faults within a DFF is achieved by applying up to three test vectors to set or reset the stored value within the storage loop of a DFF, regardless of the initial condition before testing.

inserted at the JTL. Another example, listed in Table  $\Pi(b)$ , is the location of stuck-at SC faults, which can be identified by detecting the two outputs of a splitter. If a one is inserted into a splitter and a zero is detected at the two outputs, a stuck-at SC is

identified at the driver JJ. If a one is inserted into a splitter and a one is detected in one branch and a zero in the other branch, a stuck-at SC is detected at the JJ located in the other branch.

A complete list of test vectors to detect the location and/or type of JJ-based fault within an SFQ system is listed in Table [III.](#page-5-0) Based on this list, different types of test vectors can be applied, given as follows.

- 1) Test vectors can be applied to detect a specific fault at a specific location. For example, detecting if J1 (at a specific location) is stuck-at SC (for a specific fault) within a splitter cell or if J3 is stuck-at OC within a DFF cell.
- 2) Test vectors can be applied to detect if a specific location has a JJ-based fault (stuck-at SC or OC); for example, detecting if J4 is stuck-at SC or OC fault within an OR gate by applying  $A=10$  and  $B=00$ .
- 3) Test vectors can be applied to detect if a JJ-based stuck-at fault occurs within a cell (without identifying the type or location of the fault); for example, applying A=X and B=X to an OR cell, where X means any value.

### V. FAULT COVERAGE OF JJ-BASED FAULTS

A summary of JJ-based faults within an SFQ system is listed in Table [IV.](#page-5-0) Considering specific logic cells, 100% of OC faults and 64% of SC faults can be detected within an AND cell; 100% of JJs stuck in the SC state within a splitter cell can be identified and located. It is, however, challenging to determine the type and/or location of all JJ stuck faults within JTL, DFF, and OR cells.



<span id="page-5-0"></span>

The JJ labels are illustrated in the circuit structures shown in Figs. 3, 4, 5, 9, and 10.

TABLE IV FAULT COVERAGE OF JJ-BASED FAULTS WITHIN MULTIPLE SFQ CELLS WHERE THE NUMBER OF HS WITHIN EACH CELL, TOTAL NUMBER OF HE FAULTS THAT MAY EXIST, NUMBER OF TOTAL FAULTS THAT CAN BE DETECTED, NUMBER OF ONLY OC OR ONLY SC FAULTS THAT CAN BE DETECTED, AND NUMBER OF SPECIFIC OC OR SC FAULT THAT CAN BE DETECTED AT A SPECIFIC LOCATION



A total of 72% of JJ faults can be identified within an SFQ cell library composed of JTL, splitter, DFF, OR, and AND cells. Only 70% of OC faults can be identified, and 74% stuck-at SC state faults can be determined. The location of only 19% of stuck-at SC state faults can be identified, whereas the location of 7% stuck-at OC faults can be determined.

These numbers do not directly reflect a fault coverage of a logic cell but do reflect an estimate of the fault coverage of JJbased faults. As an example, for the benchmark circuit presented in Fig. 7, the circuit is composed of two AND gates and one DFF



Fig. 7. Benchmark circuit to evaluate JJ-based fault models. A single JJ fault is inserted in a two-level logic cell. The output is compared with the predicted output based on the fault model.

with a total of 25 JJs with a possibility of 50 JJ-based faults. Assuming the ability to detect and observe the primary input and output of all of the logic gates, the following fault coverage can be achieved: 80% of JJ-based faults, 96% of OC faults, and 64% of SC faults.

These low fault coverage results are due to the response of SFQ cells to stuck OC faults. In most cases, JJs stuck-at OC fault pass an SFQ pulse without interruption, such as the JJs within a JTL, as illustrated in Fig. [3\(b\).](#page-2-0) In these scenarios, it is challenging to detect stuck-at OC faults through the proposed high-level functional model.

One method to enhance the fault coverage of stuck-at OC faults can be achieved by applying a test methodology to detect and distinguish a transition failure between a faulty output of a

<span id="page-6-0"></span>

Fig. 8. Block diagram of proposed algorithm to generate test vectors to identify JJ-based faults within an SFQ system.

stuck-at OC fault and a reference cell. As illustrated in Fig. [3\(b\),](#page-2-0) a small delay is detected between the faulty output of a JTL with a stuck-at OC fault and a reference cell. Depending upon the location of a JJ, a different delay is detected. Transition faults have been widely used to model stuck-open faults for determining transistor-based faults in CMOS systems [\[16\].](#page-7-0) These on-chip transition-based testing mechanisms are challenging to design, require significant power, and increase the test time [\[16\].](#page-7-0)

It is difficult to identify stuck-at faults at the device level. In CMOS systems, gate-level or node-level stuck-at faults are preferred over transistor stuck-at faults since it is easier to detect and locate faults with high fault coverage [\[17\].](#page-7-0) CMOS-based node or gate stuck-at faults simultaneously affect several transistor terminals [\[13\].](#page-7-0) High fault coverage is to be expected. For most CMOS stuck-at fault models, the coverage of a transistor-level stuck-at fault is significantly less than the fault model of gatelevel stuck-at faults[\[17\].](#page-7-0) A higher coverage is obtained for node stuck-at faults than gate stuck-at faults.

#### VI. JJ-BASED TARGETED TESTING

A test vector generation algorithm is required to target a specific cell and fault. The objective of this algorithm is to provide a block-level fault model to generate test vectors to detect faults and determine the fault coverage within a block, as illustrated in Fig. 8.

To increase the fault coverage of JJ-based faults within an SFQ system, a test methodology is necessary that generates the required test vectors to detect only stuck-at SC faults or only OC faults. As an example, within an OR cell, J1, J2, J3, and J4 stuck-at SC faults can be detected by applying two test vectors  $(A=10 \text{ and } B=01)$  with a clock pulse applied after each of the test vectors.

Pseudocode describing the algorithm generating test vectors to target a specific fault type or specific fault location is shown in Algorithm 1. The time complexity of the proposed algorithm for different benchmark circuits is  $O(N)$ , where N is the number of gates. The proposed algorithm generates the required test vectors, given as follows.

1) The block under test is evaluated for all possible fault scenarios. A fault is inserted. Each JJ is modeled as either stuck-at SC or OC. A stuck-at OC JJ is modeled as an OC, whereas a stuck-at SC JJ is modeled as a JJ with a high critical current (such as 5 mA).

**Algorithm 1:** Pseudocode of Algorithm for Generating Test Vectors to Identify JJ-Based Faults.

- **Input:** Number of gates N, number of input conditions C, JJ-based fault models of all logic cells  $LM$  with JJ number  $JJn$  under JJ-based fault f of 0 for SC or 1 for OC fault, target testing requirements
- **Output:** Block JJ-based fault model BM, test vector of target testing  $Test\_Vector$ , undetected faults  $DF$ , and detected faults DF
- 1: Evaluate the behavior of the netlist with reference cells under all input conditions  $Out\_Ref$
- 2: **For**  $k \leftarrow 1$  to N **do**<br>3: **For**  $i \leftarrow 1$  to  $JJn$  $\triangleright$  Evaluate each logic cell
- 3: **For**  $i \leftarrow 1$  to  $JJn$  **do**  $\triangleright$  Evaluate each JJ-based fault within the logic cell
- 4: **For**  $j \leftarrow 1$  to C **do**  $\rhd$  Evaluate each input condition
- 5: Evaluate the behavior of the netlist with LM*<sup>k</sup>* under a fault in JJ  $i$  with fault type  $f$  under input condition  $j$ ,
- 6:  $BM \leftarrow (Out, k, i, f, j)$ <br>7: **if**  $(Out) = Out \; Ref \; th$
- $\mathbf{if}(Out) = Out\_Ref$  then
- 8:  $UF \leftarrow (k, i, f, j)$   $\triangleright$  Undetected fault in K cell,  $i$  JJ, fault  $f$ , and input condition  $i$

9: 
$$
uf = uf + 1
$$

10: **else**

11:  $DF \leftarrow (Out, k, i, f, j)$   $\triangleright$  Detected fault in  $K$  cell,  $i$  JJ, fault  $f$ , and input condition  $i$ 

- 12:  $df = df + 1$ 13: **end if**
- 14: **end for**
- 15: **end for**
- 
- 16: **end for**
- 17: Extract DF with  $f = 0$  to group stuck-at SC faults BM*SC*
- 18: Extract DF with  $f = 1$  to group stuck-at SC faults BM*OC*
- 19: Extract  $DF$  regardless f to group a stuck-at a fault BM*<sup>U</sup>*
- 20: Generate the test vector for each group  $Test\_Vector_{SC}$ , Test\_Vector<sub>OC</sub>, Test\_Vector<sub>U</sub>
- 2) The output of each fault scenario is compared with a reference output (where no fault is inserted). Undetected faults are those faults where the faulty output is similar to the reference output.
- 3) All identical faulty outputs due to the same input combination(s) are grouped together. These faults share the same test vectors.

#### VII. CONCLUSION

Advanced testing methodologies are required to support complex digital SFQ systems. In this article, JJ-based fault models are proposed for specific gate types. A faulty JJ has four modes of operation, stuck-at SC, resistive, OC, or noisy switching. In total, two JJ-based fault modes are considered in this article, stuck-at SC state and stuck-at OC state. A JJ stuck in the SC state

<span id="page-7-0"></span>is modeled as a JJ with a high critical current, whereas a JJ stuck in the OC state is modeled as an OC. A high-level JJ-based fault model is presented for the following RSFQ cells: JTL, splitter, DFF, OR, and AND. Test vectors to identify the type and location of a set of faults are generated based on these high-level fault models. The fault coverage of the OC and SC faults and the location of each logic cell are identified; specifically, 72% of JJ-based faults (OC, SC, or both) can be detected within an SFQ system. The fault coverage of a JJ-based fault is 74% of SC faults and 70% of OC faults. While it is challenging to identify the location of OC faults within an SFQ system, all SC faults within a splitter cell can be identified, and the location of 18% of the SC faults within an AND cell can be determined. A methodology is also proposed to develop a block-level fault model to produce the required test vectors to identify the type and location of JJ faults within SFQ systems.

#### **REFERENCES**

- [1] H.-D. Hahlbohm and H. Lübbig Eds., *SQUID '85 Superconducting Quantum Interference Devices and Their Applications*. Berlin, Germany: De Gruyter, 1986.
- [2] O. A. Mukhanov et al., "Superconductor digital-RF receiver systems," *IEICE Trans. Electron.*, vol. E91-C, no. 3, pp. 306–317, Mar. 2008.
- [3] V. K. Semenov, Y. A. Polyakov, and S. K. Tolpygo, "AC-biased shift registers as fabrication process benchmark circuits and flux trapping diagnostic tool," *IEEE Trans. Appl. Supercond.*, vol. 27, no. 4, Jun. 2017, Art. no. 1301409.
- [4] T. Jabbari, G. Krylov, S. Whiteley, E. Mlinar, J. Kawa, and E. G. Friedman, "Interconnect routing for large-scale RSFQ circuits," *IEEE Trans. Appl. Supercond.*, vol. 29, no. 5, Mar. 2019, Art. no. 1102805.
- [5] G. Krylov and E. G. Friedman, *Single Flux Quantum Integrated Circuit Design*. Cham, Switzerland: Springer, 2022.
- [6] G. Krylov and E. G. Friedman, "Design for testability of SFQ circuits," *IEEE Trans. Appl. Supercond.*, vol. 27, no. 8, Dec. 2017, Art. no. 1302307.
- [7] M. Bushnell and V. Agrawal, *Essentials of Electronic Testing for Digital, Memory and Mixed-Signal VLSI Circuits*. New York, NY, USA: Springer, 2004.
- [8] G. Krylov and E. G. Friedman, "Globally asynchronous, locally synchronous clocking and shared interconnect for large-scale SFQ systems,' *IEEE Trans. Appl. Supercond.*, vol. 29, no. 5, Aug. 2019, Art. no. 3603205.
- [9] T. Jabbari, G. Krylov, J. Kawa, and E. G. Friedman, "Splitter trees in single flux quantum circuits," *IEEE Trans. Appl. Supercond.*, vol. 31, no. 5, Aug. 2021, Art. no. 1302606.
- [10] F. Wang and S. K. Gupta, "An effective and efficient automatic test pattern generation (ATPG) paradigm for certifying performance of RSFQ circuits," *IEEE Trans. Appl. Supercond.*, vol. 30, no. 5, Jan. 2020, Art. no. 1300711.
- [11] M. Li, F. Wang, and S. Gupta, "Data-driven fault model development for superconducting logic," in *Proc. IEEE Int. Test Conf.*, 2020, pp. 1–5.
- [12] H. G. Kerkhoff and H. Speek, "Defect-oriented testing of Josephson logic circuits and systems," *Physica C: Supercond.*, vol. 350, no. 3/4, pp. 261–268, Feb. 2001.
- [13] J. Galiay, Y. Crouzet, and M. Vergniault, "Physical versus logical fault models MOS LSI circuits: Impact on their testability," *IEEE Trans. Comput.*, vol. 29, no. 6, pp. 527–531, Jun. 1980.
- [14] A. F. Kirichenko et al., "ERSFQ 8-bit parallel arithmetic logic unit," *IEEE Trans. Appl. Supercond.*, vol. 29, no. 5, Aug. 2019, Art. no. 1302407.
- [15] G. Krylov and E. G. Friedman, "Design methodology for distributed largescale ERSFQ bias networks," *IEEE Trans. Very Large Scale Integr. Syst.*, vol. 28, no. 11, pp. 2438–2447, Nov. 2020.
- [16] S. D. Millman and E. J. McCluskey, "Detecting stuck-open faults with stuck-at test sets," in *Proc. IEEE Custom Integr. Circuits Conf.*, 1989, pp. 22.3/1–22.3/4.
- [17] P. Liden and P. Dahlgren, "Coverage of transistor-level and gate-level stuck-at-faults in CMOS checkers," in *Proc. IEEE Int. Symp. Circuits Syst.*, 1995, pp. 2124–2127.