# **Detection and Identification of Gate Faults in Reversible Circuit**



#### **B. Mondal, C. Bandyopadhyay, A. Bhattacharjee and H. Rahaman**

**Abstract** In recent time, efficient implementation of reversible logic circuits has come out as an important research area before the design industry. With the advancement in reversible logic synthesis, developing mechanism for identification of faults finds importance. Though there exist well-known testing techniques, but developing improved testing algorithms is the need of the hour. Aiming to develop efficient testing technique, here in this work, we show an improved testing scheme based on Boolean logic function. Two different testing approaches are presented here, where in the first work, by using Boolean difference method SMGFs in reversible circuit are tracked successfully, where a test vector generator is derived to find the faults. In the second work, a Reed–Muller (RM) form based testing approach is developed that not only detects the faults but also locates the exact position of the faulty area. A limitation for the second testing scheme is that it can only be employed over a specific type of reversible circuit known as Exclusive-Or Sum-Of-Product (ESOP) design. Both the testing techniques have been executed over different benchmark suites and a comparative study with state-of-the-art testing approaches have been included in the work.

e-mail: [bappa.arya@gmail.com](mailto:bappa.arya@gmail.com)

C. Bandyopadhyay e-mail: [chandanb.iiest@gmail.com](mailto:chandanb.iiest@gmail.com)

- A. Bhattacharjee e-mail: [anirbanbhattacharjee330@gmail.com](mailto:anirbanbhattacharjee330@gmail.com)
- H. Rahaman e-mail: [hafizur@it.iiests.ac.in](mailto:hafizur@it.iiests.ac.in)

© Springer Nature Singapore Pte Ltd. 2020 A. K. Singh et al. (eds.), *Design and Testing of Reversible Logic*, Lecture Notes in Electrical Engineering 577, [https://doi.org/10.1007/978-981-13-8821-7\\_10](https://doi.org/10.1007/978-981-13-8821-7_10)

B. Mondal (B) · C. Bandyopadhyay · A. Bhattacharjee · H. Rahaman

Department of Information Technology, Indian Institute of Engineering Science and Technology, Shibpur 711103, India

## **1 Introduction**

Heat dissipation is considered as the essential concern in modern day's VLSI circuit. As per Launder's principles [\[1\]](#page-14-0), loss of information generates *KTlog<sub>2</sub>joule* amount of heat, where *k* is Boltzmann constant and *T* is absolute temperature. Hence, alternative technology is required so that heat generation can be minimized in the circuit. Bennet [\[2\]](#page-14-1) claimed that dissipation of energy can be made zero only when the circuit is constructed with reversible gates. Therefore, reversible logic design is considered as the prerequisite needed to minimize heat dissipation during logic computation. On the other side, as the quantum circuit [\[3\]](#page-15-0) follows the principle of reversibility, the implementation of quantum functionality using reversible circuit is possible. Reversible circuit not only has the dominance in the field of quantum circuit design, but it too has applications in adiabatic computing [\[4,](#page-15-1) [5\]](#page-15-2), Cryptography and Optical Computing. In the last couple of years, several progresses have been made on efficient design strategies of reversible circuit.

Synthesis algorithms have been developed for making the designs of reversible circuit generic. But, not only designing the cost-efficient circuits get the high importance but simultaneously developing testing algorithms [\[6–](#page-15-3)[11\]](#page-15-4) for checking the correctness of such designs find popularity. In recent time, some promising works on efficient testing strategies have been developed where improved algorithms are formulated to make the testing process easier.

Here, in this work, we show two different approaches to find faults in reversible circuit. In the first work, a Boolean difference-based testing technique is developed, where a Boolean generator is formulated to produce test vectors and then the faults are tracked. This approach is very generic as it can be employed over any type of circuits. The second testing scheme is not very generic like the first one as it can only operate over ESOP-based designs. In this testing scheme, the functional power of Reed–Muller expression is used to find and locate the faults.

The remaining portion of the article is formulated as follows: preliminaries associated with reversible testing are stated in Sect. [2.](#page-1-0) Section [3](#page-5-0) summarizes previous research works on reversible testing. The developed methodologies are presented in Sect. [4.](#page-6-0) The experimental data of our work are summarized in Sect. [5.](#page-12-0) Finally, the chapter is concluded in Sect. [6.](#page-14-2)

## <span id="page-1-0"></span>**2 Preliminaries**

## *2.1 Reversible Circuits and Gates*

**Definition 1** A circuit C<sub>nf</sub> over a set of circuit lines  $L = \{c_1, c_2, ..., c_n\}$  is said to be reversible if it satisfies the following three cri*teria*:

(i). input (m) lines are equal with the output (n) lines

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

- (ii). if the circuit is fan-out free
- (iii). circuit consists of reversible gates only.

**Definition 2** A reversible gate G can be described as  $G(C; T)$ , where parameters C, T represents the control and target connection inputs. In that gate G, the control input set C may contain an empty value but the set T must have a minimum of one target line in such that  $C \cap T = \Phi$ .

In classical circuit different logic gates are used to implement a circuit, similarly there are well-known reversible gates like Toffoli [\[12\]](#page-15-5), Fredkin [\[13\]](#page-15-6), Feynman [\[14\]](#page-15-7) that are used to construct reversible circuits. Some examples of reversible gates are depicted in Fig. [1.](#page-2-0)

## *2.2 ESOP-Based Design*

A reversible circuit may have different designs and such variations in design depend on the type of algorithm deployed or heuristic employed. Among the several design models, due to the scalable feature property, ESOP (Exclusive Sum-Of-Products) [\[15\]](#page-15-8)-based representation has been found as one of the widely used design model for reversible circuit. Now in the following, we introduce this special type of circuit.

ESOP can be represented in the form of Sum-Of-Products (SOP) form except that the SOP product terms which are separated by '+' operator, it is separated by "⊕" operator. To express any *n*-input, *m*-output reversible function in ESOP representation, it requires  $(n + m)$  numbers of input lines in the circuit, where *n* represents the control set and the rest *m* lines operate as functional output lines.

Cube list a special data structure from which the ESOP designs are formed. Such cube list contains the detail gate specification and control structure for the ESOP circuit. Each cube in the cube list denotes a gate in the design. For an ease of understanding, cube list and its corresponding ESOP expression are given in Fig. [2a](#page-3-0) and b, where it can be seen that each of the cubes from the list has been mapped to an equivalent gate and finally a complete design is formed Fig. [2b](#page-3-0).



<span id="page-3-0"></span>**Fig. 2** a Cubelist for  $f(a_1, a_2, a_3, a_4) = a_2a_3 \oplus a_4 \oplus a_1 \oplus a_1a_2a_4 \oplus a_1a_2a_3\overline{a}_4$ , **b** ESOP expression of Fig. [2a](#page-3-0)

# *2.3 Reed–Muller Form*

For efficient design and testing of reversible circuit, the concept of Boolean algebra operator is used widely. The modulo-2 arithmetic is applied and any Boolean function can be realized using this algebra. For implementation purpose, Reed–Muller expansion can be represented using sum-of-products expression of modulo-2 arithmetic. Reversible circuit based on module-2 expansion can be realized using only exclusive OR (EXOR) gates. For any Boolean function  $f(x_1x_2 \ldots x_n)$ , it is expressed in the form of Reed–Muller expansion [\[16,](#page-15-9) [17\]](#page-15-10).

**PPRM**: The positive polarity based Reed–Muller (PPRM) expression can be realized in the form of an EXOR canonical sum-of-products expression in which each variable represents a positive polarity (un-complimented). A PPRM expression of *n* variable can be expressed as

 $f(x_1x_2 ... x_n) = a_0 \oplus a_1x_1 \oplus a_2x_2 \oplus a_3x_1x_2 \oplus ... \oplus a_{2^{n}-1}x_1x_2 ... x_n$ , where  $a_i \in$  ${0, 1}$ . The variable  $a_i$  in the above expression represents coefficient vector, where  $x_i$  denotes input variables. If the coefficient becomes zero, then the corresponding product term is not present in the PPRM expression otherwise the product term is included in the given expression.

**FPRM**: In fixed polarity Reed–Muller (FPRM) expression, the *n* variable function can be represented as

 $f(x_1x_2 \ldots x_n) = a_0 \oplus a_1\dot{x}_1 \oplus a_2\dot{x}_2 \oplus a_3\dot{x}_1\dot{x}_2 \oplus \ldots \oplus a_{2^n-1}\dot{x}_1\dot{x}_2 \ldots \dot{x}_n$  where  $a_i \in \{0, 1\}$  and  $\dot{x} \in \{x, \bar{x}\}$ , where x denoted un-complemented literals and  $\bar{x}$  denotes complemented literals.

**GRM/MPRM**: The Mixed polarity Reed–Muller (MPRM) expression can be considered as the generalization of FPRM expression in which there is hardly any limitation in the polarity of each variable. The Boolean function having *n* variable can be represented by a number of  $2^{n2^{n-1}}$  GRM form. The MPRM expression for n variable function is represented as

 $f(x_1x_2 \ldots x_n) = a_0 \oplus a_1\dot{x}_1 \oplus a_2\dot{x}_2 \oplus a_3\dot{x}_1\dot{x}_2 \oplus \ldots \oplus a_{2^n-1}\dot{x}_1\dot{x}_2 \ldots \dot{x}_n$  where  $a_i \in \{0, 1\}$  and  $\dot{x} \in \{x, \bar{x}\}.$ 

The association among various Reed–Muller configurations can be represented as PPRM  $\subset$  FPRM  $\subset$  GRM/MPRM.

#### *2.4 Different Fault Models and Their Properties*

Faults in a circuit may originate due to several reasons [\[18–](#page-15-11)[20\]](#page-15-12). Depending on the type of errors, there are four types of faults such as—single missing gate fault (SMGF), repeated gate fault (RGF), partial missing gate fault (PMGF) and multiple missing gate fault (MMGF).

**Definition 3** Complete disappearance of a gate from a given circuit results in a single missing gate fault.

The Fig. [3a](#page-4-0) shows an SMGF in a benchmark circuit *ham3\design#*, where the faulty area has been marked with a dotted box. In the dotted region, the first 2-CNOT gates are missing. A SMGF fault can be detected by providing value 1 to all the control line set of the gate and either 0 or 1 at the target node of corresponding gate.

**Definition 4** A fault can be considered as repeated gate fault if the same gate consecutively reappears in the design and may change the functionality of the circuit.

In Fig. [3b](#page-4-0), the RGF is shown in the first gate of the *ham3\design#1*. It can be ascertained that if a gate reappears even number of times then its effect becomes equivalent to an SMGF fault while odd occurrence makes the RGF fault as redundant indicating the circuit functionality remains unchanged.

**Definition 5** Disappearance of control connection input of a gate results in a fault in a circuit known as partial missing gate fault (PMGF).



<span id="page-4-0"></span>**Fig. 3 a** SMGF fault in circuit*ham3\design#*, **b** RGF in *ham3\design#1* circuit, **c** PMGF in circuit*ham3\design#1*, **d** MMGF in *ham3#design#1*

In Fig. [3c](#page-4-0), a PMGF fault is shown in the first gate of the circuit. It is considered that a PMGF fault can only be uncovered by applying value 0 to at the missing control inputs and a value 1 is set for other control lines.

**Definition 6** Missing of two or more successive gates from the circuit generates a fault known as multiple missing gate fault (MMGF).

Consider the circuit shown in Fig. [3d](#page-4-0), where the first two gates enclosed within the dotted box are missing.

Still so far we have seen the fundamentals related to reversible circuit and its associated fault models. Now, here we are discussing some of the works in testing and highlighting their contributions.

## <span id="page-5-0"></span>**3 Related Works and Contributions**

An efficient approach of stuck-at-fault detection by the adaptive tree-based technique is proposed in [\[6\]](#page-15-3). Here, in this technique at first the fault in half of the circuit is detected and then by applying the reversible property, a mirror image of the remaining part of the circuit is developed to detect faults in the remaining part of the circuit.

Furthermore, a generalized approach of "stuck-at" fault detection for all k-CNOT based circuit has been reported in [\[7\]](#page-15-13), where a universal test of size 3 has been used for the fault detection.

Taking one step more, a novel technique for fault detection is shown in [\[8\]](#page-15-14), where an  $(n \times n)$  reversible circuit constructed with k-CNOT gates is tested for possible faults. In this method, a testable design has been developed by copying gates along with an additional line. Though some overhead is incurred to transform the original circuit into the testable form, but the modified testable design becomes very sufficient and easy to detect all existing fault models in the given circuit.

To make the faults detection easier, not only fault specific test vectors have been generated but the way of making simpler testable designs also have been explored and such a work is reported in [\[9\]](#page-15-15), where extra inputs and additional *k*-CNOT gates are added in the design to make the design testing friendly. This modified testing design methodology determines a universal test set of size  $(n + 2)$  and thereby identifies the said faults in the given circuit.

Instead of applying huge number of test vectors in fault detection and also to reduce the design complexity, testing of SMGFs and RGFs and MMGFs in reversible circuit with minimum number of test vectors is presented in [\[10\]](#page-15-16).

# <span id="page-6-0"></span>**4 Proposed Testing Methods**

Here we state both the testing schemes with examples. The first testing scheme is based on Boolean difference method, whereas the second one relies on Reed–Muller expansion.

## *4.1 Boolean-Based Testing Method1*

Here we state the technique to determine the existence of SMGF in a circuit. The proposed approach is divided into three phases. At first, Boolean difference of the circuit is computed for each of the missing gate. In the second phase, a Boolean generator for the entire circuit is constructed and in the third phase, test vectors are constructed from the Boolean generator which finally checks the presence of SMGF in the circuit. All three phases are stated next in detail.

#### **4.1.1 Computation of the Boolean Difference for Missing Gate Faults**

Let us assume a reversible circuit having *n* number of input lines and *N* number of gates.

**Definition 7** The Boolean expression generated at the *j*th line of a fault-free circuit is known as the OriginalExpression<sub>i</sub>, where  $(0 \le j \le n - 1)$ . For any given reversible circuit with n inputs can be represented by OriginalExpression<sub>0</sub>, OriginalExpression<sub>1</sub>, OriginalExpression<sub>n−1</sub>.

**Definition 8** For a faulty circuit, the Boolean expression produced at the *j*th line as a result of the gate missing from the *i*th level of circuit can be represented as the FaultyExpression<sub>i,j</sub>, where ( $0 \le i \le N - 1$ ), ( $0 \le j \le n - 1$ ).

For any reversible circuit with *n* lines can be expressed as  $FaultyExpression_{i,0}$ , *FaultyExpressioni,1*, … *, FaultyExpressioni,n*−<sup>1</sup> for the detected fault occurring at *i*th gate. The computed Boolean expression of the *j*th line in the faulty circuit may not be identical to the one generated at the *j*th line of the corresponding fault-free circuit.

Boolean difference method [\[21\]](#page-15-17) is basically used to determine the complete test set for detecting stuck-at faults. We have employed the same it in reversible circuit for identifying SMGF faults.

**Definition 9** The Boolean difference  $\begin{pmatrix} \frac{dF_j}{dG} \end{pmatrix}$  $\frac{dF_j}{dG_i}$  estimated at the *j*th line for the gate missing from the *i*th level can be expressed as  $\frac{dF_j}{dG_i} = F_j^o \oplus F_j^i$ , where  $F_j^o$  is the OriginalExpression<sub>j</sub>,  $F_j^i$  is the FaultyExpression<sub>i,j</sub>, ( $0 \le i \le N - 1$ ) and ( $0 \le j \le n - 1$ ) 1).

**Definition 10** The Boolean difference resulted due to removal of gate located at *i*th level is represented as  $\frac{dF}{dG_i}$  which can be determined as follows:

$$
\frac{dF}{dG_i} = \sum \frac{dF_j}{dG_i} = \left(\frac{dF_0}{dG_i}\right) + \left(\frac{dF_1}{dG_i}\right) + \dots + \left(\frac{dF_{n-1}}{dG_i}\right), (0 \le i \le N-1), (0 \le j \le n-1)
$$

In this way, at first the Boolean difference for the missing of each gate in the circuit is computed and then the Boolean difference of the circuit is constructed using the Boolean difference for each gate of the given circuit.

**Definition 11** The Boolean generator can be defined as the Boolean expression needed for the test set construction so as to identify all the possible SMGFs in the circuit.

**Lemma 1** *For a reversible circuit of n number input lines and N number of gates,* then computation of individual Boolean difference  $\left(\frac{\text{dF}}{\text{dG}_{\text{i}}}\right)$  enables to identify SMGF *at the i*th *level.*

Proof For the reversible circuit with *n* lines and *N* gates, the Boolean difference  $\left(\frac{dF}{dG_i}\right)$  for detecting the gate missing at the *i*th level is computed as:

<span id="page-7-0"></span>
$$
\frac{dF}{dG_i} = \sum \frac{dF_j}{dG_i}, (0 \le i \le N-1), (0 \le j \le n-1)
$$
 (1)

 $\Sigma$  denotes the OR operation and

<span id="page-7-1"></span>
$$
\frac{dF_j}{dG_i} = F_j^o \oplus F_j^i, (0 \le i \le N - 1), (0 \le j \le n - 1)
$$
\n(2)

From the expression given at Eq. [\(1\)](#page-7-0), it can be noticed that the possible values for  $\frac{dF}{dG_i}$  can be either 0 or some other Boolean representation. Furthermore, it can be determined that the estimated result of  $\frac{dF}{dG_i}$  becomes zero provided each of the terms  $\frac{dF_j}{dG_i}$  evaluates to "0" as logical OR is being performed between any two successive terms of  $\frac{dF}{dG_i}$ .

By analyzing the expression given in Eq. [\(2\)](#page-7-1), it can be observed that the term  $\frac{dF_j}{dG_i}$ returns the value "0", if both  $F_j^o$  and  $F_j^i$  are becomes identical only if the circuit is fault free. This in turns suggests that, if the expression  $\frac{dF}{dG_i}$  returns 0 then the circuit is said to be fault free.

For any SMGF in the circuit, it is obvious that the output expression obtained at any of the n input lines varies with the one derived for fault-free circuit. It means that at least a single line say j must be present for which the terms  $F_j^o$  and  $F_j^i$  turns out to be different due to existence of fault. It implies that  $\frac{dF}{dG_i}$  cannot be equal to 0 in the faulty reversible circuit as logical OR is implemented between the consecutive terms  $\frac{dF}{dG_i}$  and  $\frac{dF_j}{dG_i}$ .

#### **4.1.2 Implementation of Boolean Generator for Detection of Single Missing Gate Fault**

In the proposed method, the Boolean generator of the given circuit is estimated using the function  $B_{Gen} = \frac{dF}{dG_0} \wedge \frac{dF}{dG_1} \wedge \dots \wedge \frac{dF}{dG_{N-1}}$ , where  $\wedge$  represents the logical AND operation and N represents number of gates in the circuit. For BGen  $\neq 0$ , the BGen is minimized to construct the Boolean generator of the circuit. For  $BGen = 0$ , the expressions  $B_{Gen}^1$  and  $B_{Gen}^2$  need to be computed to determine the Boolean generator of the given circuit. The computation method of the expressions  $B_{Gen}^1$  and  $B_{Gen}^2$  are as follows:

Let S = (so, s1, ..., sN – 1) be the set of all  $\frac{dF}{dG_i}$ , where si =  $\frac{dF}{dG_i}$  for (0  $\leq$  $i \le N - 1$ ). Let S1 ⊆ S contains maximum number of si's such that  $B_{Gen}^1$  =  $\text{Si1}\,\Lambda\text{Si2}\Lambda\cdots\Lambda\text{Sik} \neq 0$ , where Sik ∈ S1. B<sup>2</sup><sub>Gen</sub> are remaining si's of S. For each of the  $B_{Gen}^2$ , the  $B_{Gen}^1 = 0$ .

After the formation  $B_{Gen}^1$  and  $B_{Gen}^2$ , the expression  $B_{Gen}^1$  is upgraded to compute the final form of the Boolean generator as follows:

- (i) If any term of  $B^2_{Gen}$  completely matches or is subset of any term of  $B^1_{Gen}$ , no need to upgrade the  $B_{Gen}^1$ , else compare different terms of the  $B_{Gen}^1$  with each term of the  $B_{Gen}^2$  and upgrade the  $B_{Gen}^1$  as:  $B_{Gen}^1 = B_{Gen}^1$ + highest matching term  $[i]$ ,  $i = 0$  to (number of highest matching term  $-1$ ). Repeat the same procedure between upgraded  $B_{Gen}^1$  and other available  $B_{Gen}^2$ , if exist.
- (ii) The minimized form of  $B_{Gen}^1$  is the Boolean generator of the circuit.

#### **4.1.3 Test Vector Construction from the Boolean Generator of the Circuit**

The minterms and their corresponding decimal values for the generator are calculated and the collection of those decimal values is the test set of the circuit that will be used for the detection of SMGF.

*Example 1* The *ham3tc* benchmark circuit of Fig. [4a](#page-9-0) is considered here. The circuits consisting of three lines ( $n = 3$ ) and five gates ( $N = 5$ ).

As per the first phase of the proposed technique, output expressions *Original-Expression*<sub>0</sub>, *OriginalExpression*<sub>1</sub> and *OriginalExpression*<sub>2</sub> are computed from the fault-free circuit of Fig. [4a](#page-9-0).

The output expression generated for each circuit line is  $OriginalExpression_0 =$  $(a \oplus b \cdot c)$ , *OriginalExpression*<sub>1</sub> =  $((b \oplus c) \oplus ((c \oplus (b \oplus c)) \oplus (a \oplus b \cdot c)))$ , OriginalExpression<sub>2</sub> = (( $c \oplus (b \oplus c)$ )  $\oplus (a \oplus b \cdot c)$ ).

Now, let us assume that the gate  $G_0$  at the *level*<sub>0</sub> is removed from the circuit. Hence, the circuit *ham*3*tc* becomes a faulty circuit (as shown in Fig. [4b](#page-9-0)) and its output expressions are FaultyExpression0,0, FaultyExpression0,1, FaultyExpression0,2.



<span id="page-9-0"></span>**Fig. 4 a** Fault free *ham3tc* circuit, **b** testable circuit for *SMGF* (Faulty *ham3tc* circuit where dotted box indicates missing of that gate)

Each expression of the faulty circuit are Faulty Expression<sub>00</sub> = (*a*), *Faulty Expres* $sion_{0,1} = ((b \oplus c) \oplus ((c \oplus (b \oplus c) \oplus (a))),$  FaultyExpression $0_{,2} = ((c \oplus (b \oplus c)) \oplus$ (a)).

After finding out fault free expression of each line and the faulty expression of each line of the circuit, the Eqs. [1](#page-7-0) and [2](#page-7-1) as discussed earlier are used to compute the Boolean difference of the circuit. The Boolean difference of the circuit for the missing of the gate G0 is as  $\frac{dF}{dG_0} = \left(\frac{dF_0}{dG_0}\right) + \left(\frac{dF_1}{dG_0}\right) + \left(\frac{dF_2}{dG_0}\right), \frac{dF}{dG_0} =$  (Original Expression 0  $\oplus$  FaultyExpression0,0) + (OriginalExpression1  $\oplus$  FaultyExpression<sub>0,1</sub>) + (OriginalExpression2 ⊕ FaultyExpression0,2) =  $((a \oplus b \cdot c) \oplus a) + (((b \oplus c) \oplus ((c \oplus (b \oplus c))$  $\oplus$ (a  $\oplus$  b · c)))  $\oplus$  ((b  $\oplus$  c)  $\oplus$  ((c  $\oplus$  (b  $\oplus$  c)  $\oplus$  (a))))) +(((c  $\oplus$  (b  $\oplus$  c))  $\oplus$  (a  $\oplus$  b · c))  $\bigoplus((c \oplus (b \oplus c)) \oplus (a))) = bc$ 

Similarly, each gate is removed at a time and the Boolean difference of the given circuit for the remaining gates is computed.

 $\frac{dF}{dG_1} = c$ ,  $\frac{dF}{dG_2} = b\bar{c} + \bar{b}c$ ,  $\frac{dF}{dG_3} = \bar{a}bc + a\bar{b} + a\bar{c}$ ,  $\frac{dF}{dG_4} = \bar{a}b\bar{c} + a\bar{b} + a\bar{c}$ .

Now as per the second phase of the proposed testing method, the Boolean generator of the circuit is computed by the statement  $B_{Gen}$ , where  $B_{Gen}$  =  $\frac{dF}{dG_0}$ )*AND*( $\frac{dF}{dG_1}$ )*AND*( $\frac{dF}{dG_2}$ )*AND*( $\frac{dF}{dG_3}$ )*AND*( $\frac{dF}{dG_4}$ ) = (*bc*)*AND*(*c*) *AND*( $b\bar{c}$  +  $bc)$ *AND*( $\bar{a}bc + ab + a\bar{c}$ ) *AND*( $\bar{a}b\bar{c} + ab + ac$ ) = 0. As  $B_{Gen}$  is 0, we have to find out the  $B_{Gen}^1$  and  $B_{Gen}^2$  to calculate the final form of the Boolean generator.

For this example, as gate count is  $N = 5$ , we need 5 iterations to generate the resultant Boolean generator of the circuit.

First Iteration: Let us assume  $B_{Gen}^1 = \frac{dF}{dG_0} = bc$ .

Second Iteration: Here  $B_{Gen}^1$  is upgraded as follows:  $B_{Gen}^1 = B_{Gen}^1 AND(\frac{dF}{dG_1}) =$  $(bc)$ *AND* $(c) = bc$ .

Detection and Identification of Gate Faults … 179

Third Iteration: Similarly,  $B_{Gen}^1 = B_{Gen}^1 AND(\frac{dF}{dG_2}) = (bc) AND(b\bar{c} + \bar{b}c) = 0.$ That means the term  $(b\bar{c} + \bar{b}c)$  converts the term  $B_{Gen}^1$  to 0 and therefore, the  $B_{Gen}^2(0)$ is computed and  $B_{Gen}^1$  will not be upgraded. Now,  $B_{Gen}^2(0) = (b\bar{c} + \bar{b}c)$ .

Fourth Iteration:  $B_{Gen}^1 = B_{Gen}^1 AND(\frac{dF}{dG_3}) = (bc) AND(\bar{a}bc + a\bar{b} + a\bar{c}) = \bar{a}bc$ . Fifth Iteration:  $B_{Gen}^1 = B_{Gen}^1 AND(\frac{dF}{dG_4}) = (\bar{a}bc) AND(\bar{a}b\bar{c} + a\bar{b} + ac) = 0.$ Once again as per the third iteration, the  $B_{Gen}^2(1)$  is computed and the function  $B_{Gen}^1$ will not be modified. Now,  $B_{Gep}^2(1) = (\bar{a}b\bar{c} + a\bar{b} + ac)$ .

Now, we need to compare  $B_{Gen}^1$  with  $B_{Gen}^2$  (0) and  $B_{Gen}^2$  (1) once again to upgrade the  $B_{Gen}^1$ . At First, the expression  $B_{Gen}^1(\bar{a}bc)$  is compared with both the terms of  $B_{Gen}^2$  (0). The term (*abc*) of  $B_{Gen}^1$  contains a single literal matching with both the terms of  $B_{Gen}^2(0)$  and hence,  $B_{Gen}^1(0) = (\bar{a}bc + b\bar{c})$  and  $B_{Gen}^1(1) = (\bar{a}bc + \bar{b}c)$ .

Now, we need to compare both the  $B_{Gen}^1$  with the  $B_{Gen}^2(1)$  to determine the updated value of  $B_{Gen}^1(0)$  and  $B_{Gen}^1(1)$ . The  $B_{Gen}^1(0)$  is compared with the  $B_{Gen}^2(1)$  and the term ( $\bar{a}bc$ ) of  $B_{Gen}^1(0)$  and the term ( $\bar{a}b\bar{c}$ ) of  $B_{Gen}^2(1)$  has the highest literal matching. So, the  $B_{Gen}^1(0)$  is upgraded to  $B_{Gen}^1(0) = (\bar{a}bc + b\bar{c} + \bar{a}b\bar{c})$ . Similarly, the  $B_{Gen}^1$ (1) is upgraded to  $B_{Gen}^1(1) = (\bar{a}bc + \bar{b}c + \bar{a}b\bar{c}).$ 

After the minimization, the  $B_{Gen}^1(0) = (\bar{a}b + b\bar{c})$  and  $B_{Gen}^1(1) = (\bar{a}b + \bar{b}c)$ .

As both  $B_{Gen}^1(0)$  and  $B_{Gen}^1(1)$  contains similar number of literals, there will be only two generators to identify all the possible *SMGF* in the given circuit. generator(0) =  $B_{Gen}^1(0) = (\bar{a}b + b\bar{c})$  and generator(1) =  $B_{Gen}^1(1) = (\bar{a}b + \bar{b}c)$ 

Now as per the third phase, the test vector formation from the Boolean generator is explained as follows:

 $Minterm_{generator(0)} = \bar{a}b(c + \bar{c}) + b\bar{c}(a + \bar{a}) = \bar{a}bc + \bar{a}b\bar{c} + ab\bar{c} + \bar{a}b\bar{c} =$  $\bar{a}bc + \bar{a}b\bar{c} + ab\bar{c} = \{3, 2, 6\} = \{2, 3, 6\}.$  The test set derived from the generator(0) is {2, 3, 6}. Similarly, *Minterm*<sub>generator(1)</sub> =  $\bar{a}b(c+\bar{c}) + bc(a+\bar{a}) = \bar{a}bc + \bar{a}b\bar{c} +$  $abc + \bar{a}bc = \{3, 2, 5, 1\} = \{3, 2, 5, 1\}.$ 

The test set derived from the generator(1) is  $\{1, 2, 3, 5\}$ . As the generator(0) contains lesser number of test vectors, the generator(0) will be used to uncover the *SMGF* fault.

#### *4.2 Boolean Based Testing Method2*

In this method, the ESOP-based reversible circuit is considered for the detection of SMGF fault and also to diagnosis the detected fault. Let us assume that  $C_{test}$  is the testable circuit in which the test has to be performed. To test the  $C_{test}$  circuit, initially a fault-free ESOP-based circuit ( $C_{true}$ ) is read from a given specification files ( $T_{spec}$ ) and then the logical XOR is performed between  $C_{true}$  and  $C_{test}$ .

But the design of fault-free ESOP circuit from the  $T_{spec}$  creates problem because number of distinct ESOP circuits can be generated from the  $T_{spec}$  and due to this reason MPRM can be considered as the subclass of an ESOP expression. A fault-free ESOP circuit  $(C_{true})$  can be identified from a number of distinct ESOP circuits by the help of some complex calculation. To solve the said problem, we have used the PPRM class from which only one circuit can be designed.

The proposed testing method is segmented into two stages. At first, fault detection is performed in the  $C_{test}$  and after that in second stage, identification of the detected fault in the  $C_{test}$  is performed and proper diagnosis is done in the  $C_{test}$  to transform the circuit from faulty to fault-free circuit.

#### **4.2.1 Detection of SMGF**

Here in this phase, a PPRM expression  $f_{true}^{PPRM}$  from the given circuit specification file  $T_{\text{spec}}$  is obtained for the circuit,  $C_{\text{test}}$ . After that the MPRM expression  $f_{test}^{MPRM}$ is derived from testable ESOP circuit  $C_{test}$ . Now, for each variable contained within MPRM expression ( $f_{\text{test}}^{\text{MPRM}}$ ), the polarity of such variables is converted to positive form and thereby a FPRM form  $(f_{test}^{FPRM})$  can be derived. Now, the  $L_{XOR}$  is computed as follows:  $L_{XOR} = f_{true}^{PPRM} \oplus f_{test}^{FPRM}$ , where  $\oplus$  denotes the XOR operation. If  $L_{XOR}$ is zero that means fault is not detected in the  $C_{test}$  else SMGF is detected in the  $C_{test}$ .

#### **4.2.2 Detection and Correction of SMGF**

Here, both fault identification and correction of the specified fault in a given circuit. The output expression obtained from  $L_{XOR}$  is considered as the specification details of the corresponding missing gate and represented in the form of a Boolean expression and the variables contained within such expression  $L_{XOR}$  designates the control inputs for the gate  $Mg$ , where  $Mg$  denotes the missing gate in  $C_{test}$  circuit.

To make the circuit function correctly, if the identified missing gate  $(M_g)$  is attached to the input circuit  $C_{test}$  to convert it to a fault-free circuit.

Now, the proposed method of SMGF identification and medication in an ESOP based circuit has been discussed with supportive examples below.

*Example 2* The benchmark ESOP circuit 4gt4 [\[22\]](#page-15-18) is used here for testing the pro-posed methodology. The T<sub>spec</sub> of 4gt4 is represented in Fig. [5a](#page-12-1). The testable circuit,  $C_{test}$  for the given circuit 4gt4 is also shown in Fig. [5c](#page-12-1). Now, the PPRM cover of the fault-free circuit is obtained from file  $T_{spec}$  employing [\[23\]](#page-15-19). In Fig. [5b](#page-12-1), the corresponding PPRM cube can be observed and the derived PPRM expression is  $f_{true}^{PPRM} = a \oplus bd \oplus bc \oplus bcd \oplus abd \oplus abc \oplus abcd$ . Now, the obtained expression from the circuit C<sub>test</sub> is  $f_{test}^{MPRM} = a \oplus \bar{a} b \bar{c} \bar{d} \oplus \bar{a} b$  and changing the polarity of each literal in the expression  $f_{test}^{MPRM}$  to positive value is required to derive the corresponding FPRM expression ( $(f_{test}^{FPRM} = a \oplus bd \oplus bc \oplus bcd \oplus abd \oplus abc \oplus abcd)$ . Now L<sub>XOR</sub> is computed as  $L_{XOR} = f_{true}^{PPRM} \oplus f_{test}^{FPRM} = \emptyset$ .

Hence, it can be confirmed that there an SMGF does not exist in the circuit  $C_{test}$ as  $L_{XOR}$  is null.

| # Function: 4gt4<br>(a)<br>.input $a b c d$<br>.output $f$<br>a b c df<br>01011<br>01101 |                       |                |                  |                  |  |  |
|------------------------------------------------------------------------------------------|-----------------------|----------------|------------------|------------------|--|--|
| 01111                                                                                    |                       |                |                  |                  |  |  |
| 1000 1                                                                                   | (b)                   |                |                  | (c)              |  |  |
| 10011                                                                                    | Ь<br>$\boldsymbol{a}$ | $\overline{c}$ | $\boldsymbol{d}$ |                  |  |  |
| 10101                                                                                    | 1                     |                | 1                |                  |  |  |
| 10111                                                                                    | 1                     | $\mathbf{1}$   |                  | $\boldsymbol{a}$ |  |  |
| 1100 1                                                                                   | 1                     | $\mathbf{1}$   | 1                | $\boldsymbol{b}$ |  |  |
| 11011                                                                                    | 1                     |                |                  | $\boldsymbol{c}$ |  |  |
| 11101                                                                                    | 1<br>1                |                | 1                | $\boldsymbol{d}$ |  |  |
|                                                                                          | 1<br>1                | $\mathbf{1}$   |                  |                  |  |  |
| 11111                                                                                    | 1<br>1                | 1              | 1                | $t=0$            |  |  |

<span id="page-12-1"></span>**Fig. 5** Illustration of Example 2. **a** Input specification file of *4gt4* **b** Equivalent PPRM cube list of *4gt4* **c** Testable input ESOP circuit for function *4gt4*

*Example 3* The benchmark circuit 4mod5 [\[22\]](#page-15-18) is considered here once again to explain the proposed technique. The specification file  $T_{\text{spec}}$  for 4mod5 and  $C_{\text{test}}$ circuit are represented in Fig. [6a](#page-13-0) and b, respectively. Initially,  $f_{true}^{PPRM} = 1 \oplus \text{ad } \oplus$ ab ⊕ bc ⊕ cd ⊕ a ⊕ b ⊕ c ⊕ d is obtained from  $T_{\text{spec}}$ . Then, MPRM expression  $(f_{test}^{MPRM} = 1 \oplus \overline{ad} \oplus \overline{a} \cdot \overline{b} \cdot \overline{bc})$  is derived from the circuit C<sub>test</sub>. Now, an FPRM logic expression ( $f_{test}^{FPRM} = 1 \oplus \text{ad} \oplus \text{ab} \oplus \text{bc} \oplus \text{ad} \oplus \text{b} \oplus \text{c}$ ) is formed. The equivalent ESOP structure of derived  $f_{test}^{FPRM}$  and  $f_{true}^{PPRM}$  expressions are represented in Fig. [6c](#page-13-0) and d, respectively. Now,  $L_{XOR} = f_{true}^{PPRM} \oplus f_{test}^{FPRM} = \text{cd} \oplus \text{d} = \bar{c}\text{d}$ .

Hence, it is confirmed that a SMGF fault is present in  $C_{test}$  exists as  $L_{XOR}$  is equal to some Boolean value. As per the proposed method, the expression  $L_{XOR}$  represents the control lines of the gate  $M<sub>g</sub>$  (as depicted in Fig. [6e](#page-13-0)) which is completely missing in the testable circuit. Thereafter, it can be described that the  $M<sub>g</sub>$  is having a negative control and positive control at lines *c* and *d,* respectively.

The circuit can be made fault free if the corresponding missing gate  $(M_g)$  is adjoined to the input circuit  $C_{test}$  and the resultant original ESOP structure of  $4mod5$ is depicted in Fig. [6f](#page-13-0).

## <span id="page-12-0"></span>**5 Experimental Results**

We have tested both of our approaches against different benchmark suites [\[22\]](#page-15-18). The results obtained from first testing approach is summarized in Table [1,](#page-14-3) where first three columns represent the circuit name, the number of lines (n) and the number of gates (N) present in a benchmark function. The Boolean generator is shown in



<span id="page-13-0"></span>**Fig. 6** Illustration of Example 3. **a** Specification file  $T_{spec}$  for circuit 4mod5 **b** Testable input circuit *4mod5* **c**  $f_{test}^{FPRM}$  function equivalent ESOP circuit **d**  $f_{test}^{FPRM}$  function equivalent ESOP circuit **e** Detected missing gate details **f** Fault free circuit of *4mod5*

column 4 and the set of test patterns produced from the generator are tabulated in column 5 of Table [1.](#page-14-3)

The second testing technique is also checked over several benchmark circuits and the effectiveness of RM form also has been verified for successful detection and localization of faults.

| Name of<br>benchmark<br>function | Number of<br>lines $(n)$ | Number of<br>gates (N) | Boolean generator of the<br>circuit                                                                                                  | Derived test set from the<br>boolean generator                         |
|----------------------------------|--------------------------|------------------------|--------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------|
| rd32d1                           | 4                        | 4                      | $(ab + \bar{a}bc)$<br><sub>or</sub><br>$(ab + abc)$                                                                                  | $\{6, 7, 12, 13, 14, 15\}$<br>$\alpha$<br>$\{10, 11, 12, 13, 14, 15\}$ |
| xor5d1                           | 5                        | $\overline{4}$         | $(a\overline{b}\overline{c}\overline{d})$                                                                                            | $\{16, 17\}$                                                           |
| ham3tc                           | 3                        | 5                      | $(\bar{a}b + b\bar{c})$<br>$\alpha$<br>$(\bar{a}b + \bar{b}c)$                                                                       | $\{2, 3, 6\}$<br>$\alpha$<br>$\{1, 2, 3, 5\}$                          |
| 3 17tc                           | 3                        | 6                      | $(abc + ab\bar{c})$<br>$\alpha$<br>$(abc + \bar{a}b\bar{c})$                                                                         | $\{5, 6\}$<br><sub>or</sub><br>$\{5, 0\}$                              |
| mod5d1                           | 5                        | 8                      | (abcd)                                                                                                                               | $\{30, 31\}$                                                           |
| mod5d2                           | 5                        | 9                      | $(\overline{abcd})$                                                                                                                  | $\{6, 7\}$                                                             |
| 4_49d3                           | 4                        | 12                     | $(abd + \overline{a}cd)$                                                                                                             | $\{3, 7, 13, 15\}$                                                     |
| hwb4d1                           | 4                        | 17                     | $(abcd + \bar{c}d + acd)$                                                                                                            | $\{1, 5, 9, 10, 11, 13, 14\}$                                          |
| $2$ of $5d1$                     | 6                        | 15                     | $(\overline{a}c\overline{e} + a\overline{b}d\overline{e} + \overline{a}b\overline{d}\overline{e} +$<br>$\overline{a}b\overline{c}df$ | {8, 9, 12, 13, 20, 21, 23,<br>24, 25, 28, 29, 34, 35,<br>42}           |
| mod5adders1 6                    |                          | 21                     | $(abc\bar{e}\bar{f} + ab\bar{c}d\bar{e} + ad\bar{e}\bar{f} +$<br>$b\bar{c}\bar{ef}$                                                  | $\{0, 4, 32, 36, 40, 48, 49,$<br>56, 60}                               |

<span id="page-14-3"></span>**Table 1** Boolean generator for the detection of SMGF

# <span id="page-14-2"></span>**6 Conclusions**

This work has presented two Boolean based approaches for testing of SMGF faults in reversible circuit. In the first method, a Boolean generator has developed for a reversible circuit and in later time, from this generator test vectors are constructed to a test a circuit. The second testing technique has mainly targeted to test a special class of reversible circuit known as ESOP designs. But, the first testing technique is very generic and can be employed over any type of circuits. In both the testing approaches, we have addressed SMGF only, but other types of faults like RGF, MMGF also can be tracked by following the same strategy as used to find SMGF. The presented techniques have successfully tested over a wide spectrum of benchmarks also.

## **References**

- <span id="page-14-0"></span>1. Landauer R (1961) Irreversibility and Heat Generation in the Computing Process. IBM J Res Dev 5:183–191
- <span id="page-14-1"></span>2. Bennett CH (1973) Logical Reversibility of Computation. IBM J Res Dev 17:525–532
- <span id="page-15-0"></span>3. Nielsen M, Chuang I (2000) Quantum Computation and Quantum Information. Cambridge University Press, Cambridge
- <span id="page-15-1"></span>4. Wille R, Keszocze O, Hillmich S, Walter M, Ortiz AG (2016) Synthesis of approximate coders for on-chip interconnects using reversible logic. In: Design, automation and test in Europe
- <span id="page-15-2"></span>5. Rauchenecker A, Ostermann T, Wille R (2017) Exploiting reversible logic design for implementing adiabatic circuits. In: International conference mixed design of integrated circuits and systems
- <span id="page-15-3"></span>6. Ramasamy K, Tagare R, Perkins E, Perkowski M (2004) Fault localization in reversible circuits is easier than for classical circuits. In: Proceedings of international workshop on logic and synthesis
- <span id="page-15-13"></span>7. Chakraborty A (2005) Synthesis of reversible circuits for testing with universal test set and C-testability of reversible iterative logic arrays. In: Proceedings of VLSI design, pp 249–254
- <span id="page-15-14"></span>8. Rahaman H, Kole DK, Das DK, Bhattacharya BB (2011) Fault diagnosis for missing-gate fault (SMGF) model in reversible quantum circuits. Int J Comput Electr Eng (Elsevier) 37:475–485
- <span id="page-15-15"></span>9. Mondal J, Das DK, Kole DK, Rahaman H, Bhattacharya BB (2013) On designing testable reversible circuits using gate duplication. In: International symposium on VLSI design and test, pp 322–329
- <span id="page-15-16"></span>10. Kole DK, Rahaman H, Das DK, Bhattacharya BB (2010) Derivation of optimal test set for detection of multiple missing-gate faults in reversible circuits. In: Proceedings of Asian test symposium, pp 33–38
- <span id="page-15-4"></span>11. Mahammad SN, Hari SKS, Shroff S, Kamakoti V (2006) Constructing online testable circuits using reversible logic. In: International symposium on VLSI design and test, pp 373–383
- <span id="page-15-5"></span>12. Toffoli T (1980) Reversible computing. Technical memo MIT/LCS/TM-151, MIT Lab for Computer Science
- <span id="page-15-6"></span>13. Fredkin E, Toffoli T (1982) Conservative logic. Int J Theor Phys 21(3–4):219–253
- <span id="page-15-7"></span>14. Feynman RP (1996) Feynman lectures on computation. Perseus books
- <span id="page-15-8"></span>15. Fazel K, Thornton MA, Rice JE (2007) ESOP-based Toffoli gate cascade generation. In: Pacific rim conference on communications, computers and signal processing (PacRim). Victoria, Canada, pp 206–209
- <span id="page-15-9"></span>16. Zhang YZ, Rayner PJW (1984) Minimization of Reed-Muller polynomials with fixed polarity. IEE Proc Comput Digit Tech 131(5):177–186
- <span id="page-15-10"></span>17. Harking B (1990) Efficient algorithm for canonical Reed-Muller expansion of Boolean function. IEE Proc Comput Digit Tech 137(5):366–377
- <span id="page-15-11"></span>18. Hayes JP, Polian I, Becker B (2004) Testing for missing-gate faults inreversible circuits. In: Proceedings of Asian test symposium, pp 100–105
- 19. Perkowski M, Biamonte J, Lukac M (2005) Test generation and fault localization for quantum circuits. In: Proceedings of international symposium on multi-valued logic, pp 62–68
- <span id="page-15-12"></span>20. Polian I, Hayes JP, Fienn T, Becker B (2005) A family of logical fault models for reversible circuits. In: Proceedings of Asian test symposium, pp 422–427
- <span id="page-15-17"></span>21. Kohavi Z (1978) Switching and finite automata theory, 2nd edn. Tata McGraw- Hill, New York
- <span id="page-15-18"></span>22. Wille R, Grosse D, Teuber L, Dueck GW, Drechsler R (2008) Revlib: an online resources for reversible functions and reversible circuits. IEEE ISMVL 24:220–225
- <span id="page-15-19"></span>23. Bandyopadhyay C, Rahaman H (2014) Synthesis of ESOP-based reversible logic using positive polarity reed-muller form. In: IEEE emerging trends in computing and communication (ETCC-2014), Calcutta, India