

# **Simplifcation and modifcation of multiple controlled Tofoli circuits for testability**

**Hari Mohan Gaur1 · Ashutosh Kumar Singh2 · Umesh Ghanekar1**

Published online: 22 January 2019 © Springer Science+Business Media, LLC, part of Springer Nature 2019

### **Abstract**

Testability dramatically enhances the operating cost in reversible logic circuits as it increases the cost metrics such as gate count, quantum cost, number of wires and garbage output. This increase also afects the utilization of resources, which further enhances overall cost of testing. This paper presents a new design for testability methodology for reversible circuits by exploring the properties of multiple controlled Tofoli and Fredkin gates, to produce online testable circuits at lower cost metrics. The method includes simplifcation and modifcation of Tofoli circuits to form parity-preserving Tofoli–Fredkin cascades. The testability in these cascades can be achieved by comparing the parity of inputs and outputs using controlled-NOT gates on an additional wire. Single-point failures in reversible logic circuits are targeted by means of detecting bit faults. In contrast to the existing work, the present model is robust, low cost and has lesser design complexity. Experiments are conducted on a set of benchmark circuits to prove the efficacy of the present work. The results show an average reduction by 15.9 % in gate cost and 11.0 % in total operating cost when compared to the most recent existing work formulated on the same platform.

**Keywords** Reversible logic circuits · Design for testability · Fault detection · Testing

## **1 Introduction**

The upcoming technologies like trapped atoms [[1\]](#page-6-0), nuclear magnetic resonance [\[2](#page-6-1)], quantum dots [[3\]](#page-6-2) and superconductors [\[4](#page-6-3)] allow quantum communication to enable the sharing of secrets by the laws of physics. Reversible logic circuits are one of the foundations for future generation systems with its applications to quantum computation. They are theoretically proven for providing nearly energy-free computation by preventing the loss of information in the form of heat [\[5\]](#page-6-4). A few physical realizations of reversible and partially reversible circuits have also been reported [[4,](#page-6-3) [6](#page-7-0)]. Due to the phenomenon of quantum de-coherence, quantum systems are much more fault-prone [[7\]](#page-7-1). The consideration of faults and fault tolerance cannot be ignored. Testing of these circuits has also achieved a notable attention for the detection of various types of fault models. Since any kind of fault

<sup>2</sup> Department of Computer Applications, NIT, Kurukshetra, Kurukshetra, India

occurrence results in the change of single-/multiple-bit values at the output wires of the circuit, the detection is done by means of single-/multiple-bit faults [\[8](#page-7-2)]. Based on reviews and analysis of the existing work, parity checking is found the most favorable method of testing due to the property of having the same number of inputs and outputs. The parity is preserved or generated by means of testable gates [[6–](#page-7-0)[9\]](#page-7-3) and modifcation principles [\[10](#page-7-4)[–13\]](#page-7-5). These processes largely increase the hardware requirements to produce testable circuits and consume a signifcant time. Another solution is designing with built-in parity-preserving features [[14\]](#page-7-6), but it requires modifcation of existing synthesis algorithm which may increase design complexity. Exploiting the properties of multiple controlled Toffoli (MCT) and multiple controlled Fredkin (MCF) gates, we present a new methodology for the modification of Toffoli circuits into simplified Toffoli–Fredkin cascades to produce parity-preserving circuits. This property facilitates cursive testing with these circuits using a parity checker at the outputs which reduces hardware requirements and, consequently, reduces the cost of testing.

 $\boxtimes$  Hari Mohan Gaur leoharimohan84@gmail.com

<sup>&</sup>lt;sup>1</sup> Department of Electronics and Communication Engineering, NIT, Kurukshetra, Kurukshetra, India

#### **1.1 Related work**

Numerous methodologies are available in the literature, which are based on the principles of designing using novel testable gates, designing using modifcation of an original circuit and designing with built-in testability features. Concentrating on modifcation principles, the key innovations related to the proposed work are discussed as follows:

The gates of an arbitrary circuit are modifed and cascaded with an identity gate to form a respective testable reversible cell (*TRC*), which produces two-parity output on additional wires [[13](#page-7-5)]. The original gates are then replaced by these cells to form a testable circuit. Another method is the conversion of Tofoli gates of a circuit into respective extended Toffoli gates (*ETG*) to preserve the parity of whole circuit on an extra wire  $[15]$  $[15]$ . The gate cascading approach is followed by adding another gate of same size after each gate keeping the same control input and target input on the new wire to preserve the parity of circuit [\[3\]](#page-6-2). In the modifed gates approach, Toffoli and Peres gates are modified into a respective testable form by adding one gate of the same type and fve controlled-NOT gates (CNOT-A NOT gate with a control), to preserve the parity of the input and output  $[16]$ . These gates will take the place of the original gates to form testable circuits. The methodologies consume a large amount of hardware cost in producing testable circuits for the detection of fault models by means of single-bit faults. The additional cost required in all these methods is summarized in Table [1](#page-1-0), where *N* is the number of gates, *n* represents the number of wires present in original circuit and  $k_i$  denotes the size of  $i^{th}$  gate of the circuit [[17\]](#page-7-9).

#### **1.2 Simulation setup**

The simulations for evaluating the efficacy of the proposed work in this paper are performed on a machine with a 64-bit Ubuntu 16.04 LTS equipped with Intel Core I7-4790, 3.60 GHz clock and 4 GB of memory. The perquisites used in diferent parts of this paper are listed as follows:

- The benchmark circuits description in the form of Toffoli–Fredkin cascade (TFC) and programmable logic array (PLA) fles is taken from reversible logic synthesis and benchmark pages [\[18](#page-7-10), [19](#page-7-11)].
- Revkit—It is an open-source tool kit for reversible circuit designs. It is a modular and extensible framework which provides a signifcant number of approaches and algorithms, but also easily enables the addition of new methods and ideas. Several optimization and verifcation methods based on existing synthesis algorithms are also incorporated within the tool kit.
- The circuits are synthesized using well-known garbagefree transformation-based synthesis algorithm [\[20](#page-7-12)]. The functions of given benchmarks are converted into the corresponding reversible circuit using binary decision diagram (BDD) to reversible binary decision diagram (RBDD) and synthesized into Toffoli circuits.
- RCViewer—It is an application which is intended to aid in the visualization of reversible quantum circuits made up of Tofoli and Fredkin gates in cascade format. It can calculate the quantum cost of the circuit and assist in analyzing the output of a circuit in truth table form and verifying the output of a circuit against a programmable logic array fle.

## **2 Proposed design for testability methodology**

The methodology is directed by three courses of action after obtaining reversible Toffoli specification of a given Boolean function to obtain testable multiple controlled Toffoli–Fredkin (MCTF) circuits. They are simplification of Toffoli circuits, gates cascading and parity checking in order to detect the occurrence of single-bit faults as demonstrated in Fig. [1.](#page-1-1) The predefned patterns of three MCT gates in the synthesized circuit are replaced by their equivalent MCF gates to optimize number of gates in the frst stage. The gates cascading explained in the previous section will be done on non-simplifed MCT gates, where another gate is cascaded

<span id="page-1-0"></span>**Table 1** Testing parameters of existing methods



*n* number of wires, *N* gate cost,  $k_i$  gate size of *i*-*th* gate of the circuit

<span id="page-1-1"></span>**Fig. 1** Design process





<span id="page-2-0"></span>**Fig. 2** MCT gate and corresponding modifcation

using an extra wire followed by the parity checking. Detailed methodology and subsequent algorithm are explained in this section with an example.

The essence of the proposed approach is based on the explored properties of MCT and MCF gates. Preposition 1 and 2 elaborate the properties of these gates, respectively.

An MCT gate has *k* control inputs and one target input *T*, as shown in Fig. [2a](#page-2-0). The control inputs follow the same input-to-output relationship, and the output function  $f(k_n, T)$ can be calculated by Eq.  $(1)$  $(1)$ . The gate without any control is called as NOT gate, which inverts its target input.

$$
f_i(k_n, T_i) = (k_1 \bullet k_2 \bullet \dots k_n) \oplus T_i \quad ; i = \{1, 2\}
$$
 (1)

**Proposition 1** *If another MCT gate is cascaded with same control inputs and the target input is kept on a wire other than the place assigned for previous gate, the circuit produced is parity preserving.*

*Proof* Consider an MCT is cascaded with same control inputs and the target input  $(T_2)$  is kept on a wire other than the place assigned for  $T_1$ , as shown in Fig. [2b](#page-2-0). The outputs  $f(k_n, T_1)$  and  $f(k_n, T_2)$  can be calculated by Eq. ([3](#page-2-2)). The exclusive sum of all the inputs (*I*) and outputs (*O*) calculated in Eq. ([2\)](#page-2-3) is a null value. Hence, the circuit produced is parity preserving.

$$
I \oplus O = [k^* \oplus T1 \oplus T_2] \oplus [k^* \oplus f_1(k_n, T_1) \oplus f_2(k_n, T_2)]
$$
  
= 
$$
[k^* \oplus T1 \oplus T_2] \oplus [k^* \oplus (k \oplus T_1) \oplus (k \oplus T_2)] = 0
$$

An MCF gate has *k* control inputs and two target inputs  $T_1$  and  $T_2$ , as shown in Fig. [3.](#page-2-4) The control inputs follow the same relationship as that of MCT gates, and the output functions  $f_1(k_n, T_1, T_2)$  and  $f_2(k_n, T_1, T_2)$  can be calculated by Eq. [\(3](#page-2-2)). Depending upon the values of control inputs, the gate interchanges or transfers its target inputs to its output. The gate without any control is called as swap gate, which interchanges its target inputs.

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

<span id="page-2-2"></span>
$$
f_j(k, T_1, T_2) = k_1 \cdot t_1 + k_2 \cdot t_2 \begin{cases} \text{ for } j = 1; & k_1 = \bar{k}, & k_2 = k \\ \text{ for } j = 2; & k_1 = k, & k_2 = \bar{k} \end{cases}
$$
  
(3)

**Proposition 2** *MCF gates themselves are parity-preserving gates.*

<span id="page-2-1"></span>*Proof* For a gate to be parity preserving, the EXOR of all inputs and output should result a null value. Considering an MCF gate shown in Fig. [3,](#page-2-4) the EXOR of inputs (*I*) and output  $(O)$  calculated in Eq.  $(4)$  $(4)$  results a null value, where *k* =( $k_1$  ⋅  $k_2$  ⋅ …  $k_n$ ) and  $k^*$  =( $k_1$  ⊕  $k_2$  ⊕ …  $k_n$ ). Hence, MCF gates themselves are parity-preserving gates.

<span id="page-2-5"></span>
$$
I \oplus O = [k^* \oplus T_1 \oplus T_2] \oplus [k^* \oplus f_1(k_n, T_1) \oplus f_2(k_n, T_2)]
$$
  
\n
$$
= [k^* \oplus T_1 \oplus T_2] \oplus [k^* \oplus (\overline{k} \cdot T_1 + k \cdot T_2) \oplus (k \cdot T_1 + \overline{k} \cdot T_2)]
$$
  
\n
$$
= [T_1 \oplus T_2] \oplus [T_1 \oplus T_2] = 0
$$
  
\n(4)

#### **2.1 Design process**

<span id="page-2-3"></span>(2)

*(a) Simplifcation* In this process, the combinations of gates from a synthesized MCT circuit are replaced by their equivalent MCF gates. This process is performed by searching equivalent MCF binary decision diagram (BDD) structure in reversible binary decision diagram (RBDD). For instance, the combination of three controlled-NOT (CNOT) gates shown in Fig. [4](#page-3-0)a is replaced by a swap gate, the combina-tion of three Toffoli gates shown in Fig. [4b](#page-3-0) is replaced by a Fredkin gate, and similarly the combination of three MCT gates shown in Fig. [4](#page-3-0)c is replaced by an MCF gate. The motivation behind the transformation is to reduce the number of gates and quantum cost of the circuit, as three MCT gates can be replaced by single gate and the quantum cost of MCF gates is lesser than MCF gates which is summarized in Table [2](#page-3-1). There are several tools available for designing reversible circuits, and the variation in the results can be



<span id="page-3-0"></span>**Fig. 4** Transformation of MCT to **a** swap gate, **b** Fredkin gate, **c** MCF gate

<span id="page-3-1"></span>**Table 2** Quantum cost of MCF and MCF gates

| $1/O$ | Quantum cost |            | $IO$ | Quantum cost |            |
|-------|--------------|------------|------|--------------|------------|
|       | <b>MCF</b>   | <b>MCT</b> |      | <b>MCF</b>   | <b>MCT</b> |
|       |              |            | 6    | 31           | 61         |
| 2     | 3            |            |      | 54           | 125        |
| 3     | 3            | 5          | 8    | 82           | 253        |
|       |              | 13         | 9    | 102          | 509        |
|       | 15           | 29         | 10   | 130          | 1021       |

seen in diferent tools in terms of performance metrics. We have opted RCViewer [[18](#page-7-10)] to obtain the quantum costs.

*(b) Gates cascading* In this stage, the MCT gates which are left after transformation will be cascaded with another MCT gate of same size keeping the control input same as that of the previous gate. The target output is placed on a new constant input wire, as shown in Fig. [2b](#page-2-0). For a NOT gate, another NOT gate is placed on the new wire after it. This process transforms Toffoli-Fredkin circuit into Toffoli–Fredkin cascades in which the MCT gates are placed in a set of two gates along with MCF gates.

## **Theorem 1** *Circuit produced by cascading modifed MCT blocks and MCF gates is parity preserving.*

*Proof* Consider a circuit containing *N* gates on *n* wires, in which  $(I_1, I_2, \ldots, I_n)$  are the input and  $(O_1, O_2, \ldots, O_n)$  are the output of the circuit and the intermediate stages are  $(O_{i1}, O_{i2}, \ldots O_{in})$ , where  $i = (1 \text{ to } n)$ .

The intermediate I/O mapping can be given by:

$$
[O_{11}, O_{12}, \dots O_{1n}] \rightarrow [O_{21}, O_{22}, \dots O_{2n}] \rightarrow \dots [O_{N1}, O_{N2}, \dots O_{Nn}]
$$

Since intermediate stages are parity preserving, the EXOR of the previous stage  $(P_s)$  and the next stage  $(N_s)$  is given by Eq.  $(5)$  $(5)$ 

<span id="page-3-2"></span>
$$
\oplus N_{s} = 0 \quad \forall \begin{cases} P_{s} = O_{N1} \oplus O_{N2} \oplus \dots O_{Nn} \\ N_{s} = O_{(N+1)1} \oplus O_{(N+1)2} \oplus \dots O_{(N+1)n} \end{cases}
$$
(5)

 $P_s$ 

For  $N_s = (O_{11} \oplus O_{12} \oplus ... O_{1n}), P_s = (I_1 \oplus I_2 \oplus ... I_n)$ If  $P_s$  ⊕  $N_s = 0$  ∀  $i = (1$  *to*  $N$ ), then  $(I_1 \oplus I_2 \oplus \ldots I_n) \oplus (O_1 \oplus O_2 \oplus \ldots O_n) = 0$ 

Hence, the circuit produced will be parity preserving which provides the ease of testing at lower costs. The parity (*P*) of the circuit can be given by Eq. [\(6](#page-3-3)), where  $I_i$  are the input to the circuit,  $O_i$  are the output of the circuit and  $\sum$ denotes EXOR sum of inputs and outputs.

<span id="page-3-3"></span>
$$
P = \left(\sum_{i=1}^{n} I_i\right) \oplus \left(\sum_{i=1}^{n} O_i\right) \tag{6}
$$

$$
\mathcal{L}^{\mathcal{L}}(\mathcal{L}^{\mathcal{L}}(\mathcal{L}^{\mathcal{L}}(\mathcal{L}^{\mathcal{L}}(\mathcal{L}^{\mathcal{L}}(\mathcal{L}^{\mathcal{L}}(\mathcal{L}^{\mathcal{L}}(\mathcal{L}^{\mathcal{L}}(\mathcal{L}^{\mathcal{L}}(\mathcal{L}^{\mathcal{L}}(\mathcal{L}^{\mathcal{L}}(\mathcal{L}^{\mathcal{L}}(\mathcal{L}^{\mathcal{L}}(\mathcal{L}^{\mathcal{L}}(\mathcal{L}^{\mathcal{L}}(\mathcal{L}^{\mathcal{L}}(\mathcal{L}^{\mathcal{L}}(\mathcal{L}^{\mathcal{L}}(\mathcal{L}^{\mathcal{L}}(\mathcal{L}^{\mathcal{L}}(\mathcal{L}^{\mathcal{L}}(\mathcal{L}^{\mathcal{L}}(\mathcal{L}^{\mathcal{L}}(\mathcal{L}^{\mathcal{L}}(\mathcal{L}^{\mathcal{L}}(\mathcal{L}^{\mathcal{L}}(\mathcal{L}^{\mathcal{L}}(\mathcal{L}^{\mathcal{L}}(\mathcal{L}^{\mathcal{L}}(\mathcal{L}^{\mathcal{L}}(\mathcal{L}^{\mathcal{L}}(\mathcal{L}^{\mathcal{L}}(\mathcal{L}^{\mathcal{L}}(\mathcal{L}^{\mathcal{L}}(\mathcal{L}^{\mathcal{L}}(\mathcal{L}^{\mathcal{L}}(\mathcal{L}^{\mathcal{L}}(\mathcal{L}^{\mathcal{L}}(\mathcal{L}^{\mathcal{L}}(\mathcal{L}^{\mathcal{L}}(\mathcal{L}^{\mathcal{L}}(\mathcal{L}^{\mathcal{L}}(\mathcal{L}^{\mathcal{L}}(\mathcal{L}^{\mathcal{L}}(\mathcal{L}^{\mathcal{L}}(\mathcal{L}^{\mathcal{L}}(\mathcal{L}^{\mathcal{L}}(\mathcal{L}^{\mathcal{L}}(\mathcal{L}^{\mathcal{L}}(\mathcal{L}^{\mathcal{L}}(\mathcal{L}^{\mathcal{L}}(\mathcal{L}^{\mathcal{L}}(\mathcal{L}^{\mathcal{L}}(\mathcal{L}^{\mathcal{L}}(\mathcal{L}^{\mathcal{L}}(\mathcal{L}^{\mathcal{L}}(\mathcal{L}^{\mathcal{L}}(\mathcal{L}^{\mathcal{L}}(\mathcal{L}
$$

*(c) Parity checking* Fault detection is achieved by generating input and output parity of the circuit. For *n*-wire reversible circuit, the parity checking is processed by using *n* CNOT gates from a wire of the circuit to a wire on which gates cascading was done. This addition is done before and after the whole circuit as explained with gates cascading method shown in Fig. [5](#page-3-4). The output of the new wire  $(T<sub>out</sub>)$ can be given by Eq. ([7](#page-3-5)). The input to this new wire is kept constant 0. Since the circuit is parity preserving, the test output will always result a null value for a fault-free circuit. It will result a logic value 1 due to the occurrence of any single-bit fault for its detection.

<span id="page-3-5"></span>
$$
T_{\text{out}} = \left(\sum_{i=1}^{n} I_i\right) \oplus \left(\sum_{i=1}^{n} O_i\right) \oplus T_{\text{in}} \tag{7}
$$

Consider a circuit on three wires, and assigning  $T_{in} = 0$ ,  $T_{\text{out}}$  can be given by Eq.  $(8)$  $(8)$ 

$$
T_{\text{out}} = [(I_1 \oplus I_2 \oplus I_3) \oplus (O_1 \oplus O_2 \oplus O_3)] \tag{8}
$$

<span id="page-3-6"></span>Since the circuit is parity preserving,  $T_{\text{out}} = 0$ . Consider any fault occurred at any level of the circuit. As each block of the circuit is also parity preserving, the same parity information will be transferred to the next level. Hence, the values at the output will be inverted in odd numbers. Considering



<span id="page-3-4"></span>**Fig. 5** Fault detection

 $O_1 \rightarrow \overline{O_1}$ ,  $T_{\text{out}}$  will flip to 1 and the fault occurrence can be detected, as shown in Eq. ([9\)](#page-4-0).

$$
T_{\text{out}} = [(I_1 \oplus I_2 \oplus I_3) \oplus (\overline{O_1} \oplus O_2 \oplus O_3)]
$$
  
=  $[O_1 \oplus \overline{O_1}] = [O_1 + \overline{O_1}] = 1$  (9)

#### **2.2 Algorithm**

The proposed algorithm covers the steps for designing reversible circuits with testability. For a given programmed logic array (PLA) of an original circuit (*P*), Algorithm 1 produces a testable circuit  $(C^T)$ . Initially, the registers assigned for circuit parameters such as the number of wires (*n*), gates (*N*) and gates position in  $C<sup>T</sup>$  are kept empty. In the first stage of modifcation, *P* is reformed into a binary decision diagram and then embedded in a reversible binary decision diagram for its synthesis into the reversible Tofoli circuit. The information will be stored in  $C<sup>T</sup>$  and the corresponding parameters *n* and *N* get updated. The MCT to MCF gates are transformed on the MCT gate combinations  $(Xc_{T_3})$  basis with corresponding swap  $(X_{F_s})$  and MCF gate  $(X_{F_t})$  in the second stage. Since the combinations are to be checked in a set of three gates, the total number of checking positions (*Chk*) will be *N* − 2. Starting from the frst iteration (*Count*), if  $Xc_{T_3}$  equivalent to  $X_{F_s}$  is identified, a swap gate will take place for three MCT gates. Identification of  $Xc_{T_3}$  equivalent to  $X_{F_t}$  will result in the placement of an MCF gate with the corresponding Toffoli circuit.

<span id="page-4-0"></span>After each replacement, *chk* will jump to *chk* + 3. If the combinations do not fnd any equivalence, *chk* will jump to  $chk + 1$ . This process will end after the last three combinations, and the respective values of  $n$ ,  $N$  and  $C<sup>T</sup>$  will be updated simultaneously. The process is followed by the gates cascading process  $(\psi)$ . The gates left after the transformation will be cascaded by another gate keeping the same control input and target input on a new constant input wire. For an MCT gate, another MCT gate is cascaded and a NOT gate is cascaded by another NOT gate on the extra wire (process  $\psi_t$ ). Finally, the parity checker incorporation process is performed for producing a testable circuit  $(C^T)$  containing *N* gates and *n* wires.

#### **2.3 An example**

Consider a synthesized Toffoli circuit on three wires shown in Fig. [6a](#page-5-0), containing 11 gates with input  $(a, b, c)$  and output  $(a', b', c')$ . The calculated quantum cost for this circuit is 37. There are three MCT gate combinations present in the circuit which can be replaced by their equivalent MCF gates for the frst modifcation process, as shown in Fig. [6b](#page-5-0). In the second stage of modifcation, the left MCT gates are cascaded with another gate to form parity-preserving Toffoli–Fredkin cascades, as shown in Fig. [6](#page-5-0)c. This circuit is then included with CNOT gates to incorporate parity checking for the detection of faults, as shown in Fig. [6d](#page-5-0). The process transformed the original circuit into corresponding testable form on the cost of only two extra gates and single wire. Moreover, the calculated quantum cost is 27 which gets reduced due to the inclusion of MCF gates.



<span id="page-5-0"></span>**Fig. 6** Circuit transformation, **a** original circuit, **b** simplifcation, **c** gate cascading, **d** parity checker inclusion

proposed methodology



<span id="page-5-1"></span>**Table 3** Operating costs for the Circuit Original circuit (non-testable) Proposed work (testable) *n N TD TC q G n N TD TC q G* 4gt4\_73 5 30 141 329 6 4 6 41 318 742 6 4 4gt5\_75 5 38 300 700 6 4 6 23 339 791 6 4 4gt10-v1\_81 5 19 57 133 5 4 6 14 60 140 6 4 4gt11\_82 5 9 3 7 5 4 6 33 228 532 6 4 4gt12-v0\_88 5 15 45 105 5 4 6 9 141 329 6 4 4gt13\_91 5 10 12 28 5 4 6 10 12 28 6 4 4mod5-v0\_18 5 47 291 679 6 4 6 12 12 28 6 4 4mod7-v0\_94 5 26 141 329 6 2 6 32 196 331 6 2 alu-v0\_26 5 66 597 1393 6 4 6 72 618 1997 6 4 cm82a\_208 6 85 867 2023 7 5 7 18 84 196 7 5 decode24-enable\_124 6 14 63 147 6 2 7 9 27 63 7 2 decode24-v0\_39 4 9 12 28 4 0 5 12 81 189 5 0 ex1\_226 5 20 90 210 5 4 6 7 0 0 6 4 ex2\_227 6 86 1107 2583 7 5 7 10 120 280 7 5 ex3\_229 6 66 636 1484 7 5 7 7 63 147 7 5 graycode6\_47 6 15 0 0 6 0 7 5 0 0 7 0 ham3\_102 3 6 3 7 4 0 4 3 3 7 4 0 majority 6 14 246 574 7 5 7 14 216 504 7 5 c17 7 12 102 238 7 0 8 14 129 301 8 0

5mod5 7 22 144 336 7 5 7 22 171 399 7 5

## **3 Simulation and results**

A set of benchmark circuits are synthesized on the basis of the proposed methodology using transformation-based synthesis algorithm on Revkit tool kit [[18,](#page-7-10) [19\]](#page-7-11). Initially, the original function is implemented into corresponding reversible Toffoli circuit using BDD to RBDD conversion. This circuit is further simplifed and modifed in accordance with the proposed method.

The synthesis report for original and corresponding testable circuits (based on the proposed algorithm) is demonstrated in terms of wires (*n*), gates (*N*), T-depth (*TD*), T-count (*TC*), logical qubits (*q*) and garbage output (*G*) of the circuit in Table [3](#page-5-1). The operating cost is calculated by taking summation of all the measures. It is analyzed that the present method produces testable circuits at lower costs due to the incorporation of MCF gates. For instance, the testable circuits of *ex*1\_226, *ex*2\_227 and *ex*3\_229 are synthesized at lesser number of gates using the proposed method than corresponding original circuits. Due to non-availability of MCT to MCF transformations, the gate count will increase for 4*gt*4\_73, 4*gt*11\_82 and 4*mod*7 − *v*0\_94 circuits.

Same circuits are also implemented in accordance with the Toffoli-based ESOP approach [[15\]](#page-7-7), gate cascading approach [[3](#page-6-2)] and inbuilt testable design methodology [\[14](#page-7-6)]. Due to slight variation in *TD*, *TC* and *q*, these matrices are ignored in the comparisons listed in Table [4.](#page-6-5) The most efficient methodology is based on designing with inbuilt

362 Journal of Computational Electronics (2019) 18:356–363

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

|               | Table 4 Comparison with the |
|---------------|-----------------------------|
| existing work |                             |



testability features which gives motivation to develop a new synthesis algorithm that may increase the designing complexity [\[14\]](#page-7-6). The wires and garbage are the same as this approach, but the proposed work has achieved a 15.9% reduction in gate costs and 11.0% in total operating cost, except fo the r 5*mod*5 circuit. As each gate will be cascaded by another gate without MCT to MCF transformation where the simplifcation is not possible, the proposed methodology will produce the same results as that of the gates cascading approach [\[3\]](#page-6-2). The modifed circuits in accordance with the ESOP and gates cascading-based approach result in the same number of wires and garbage, but a large reduction in gate count can be seen. Overall, the calculations show an excellent result in producing testable circuits from their original form. The proposed work has achieved a reduction of 75.7% and 66.7% in total operating costs as compared to the ESOP and gate cascading approaches, respectively.

## **4 Conclusion and future scope**

This paper presents a new method of designing reversible logic circuits with testability using multiple controlled Toffoli and Fredkin gates. The two-stage simplifcation and modifcation process produces parity-preserving circuits which can be tested using a parity checker at the outputs using CNOT gates on an extra wire. The methodology

provides full coverage of single-bit faults by utilizing few gates and an extra wire, without an increase in garbage output. Diminution in the size and power requirements can be achieved as a consequence. The efficiency of the work in this area also corresponds to a large reduction in the operating cost. The quantum cost is also minimized during the conversion process, which is a key metric in quantum circuits. The reduction in operating cost by exploring new parity-preserving gates and synthesis algorithms will be the primary concern for the future foundation of this work.

## **References**

- <span id="page-6-0"></span>1. Polian, I., Fiehn, T., Becker, B., Hayes, J.P.: A family of logical fault models for reversible circuits. In: 14th Asian Test Symposium (ATS05), pp. 422–427 (2005)
- <span id="page-6-1"></span>2. Chuang, I.L., et al.: Experimental realization of Shors quantum factoring algorithm using nuclear magnetic resonance. Nature **414**, 883–887 (2001)
- <span id="page-6-2"></span>3. Gaur, H.M., Singh, A.K., Ghanekar, U.: A new DFT methodology for k-CNOT reversible circuits and its implementation using quantum-dot cellular automata. Int. J. Light Electron Opt. **127**(22), 10593–10601 (2016)
- <span id="page-6-3"></span>4. Takeuchi, N., Yamanashi, Y., Yoshikawa, N.: Reversible logic gate using adiabatic superconducting devices. Nature **4**, (2014) Article no. 6354
- <span id="page-6-4"></span>5. Bennett, C.H.: Logical reversibility of computation. IBM J. Res. Dev. **17**(66), 525–532 (1974)
- <span id="page-7-0"></span>6. Vandersypen, L.M.K., Stefen, M., Breyta, G., Yannoni, C.S., Sherwood, M.H., Chuang, I.L.: Experimental realization of Shors quantum factoring algorithm using nuclear magnetic resonance. Nature **414**, 883–887 (2001)
- <span id="page-7-1"></span>7. Nielsen, M., Chuang, I.L.: Quantum Computation and Quantum Information. Cambridge University Press, Cambridge (2000)
- <span id="page-7-2"></span>8. Gaur, H.M., Singh, A.K., Ghanekar, U.: A review on online testability for reversible logic. Procedia Comput. Sci. **70**, 384–391 (2015)
- <span id="page-7-3"></span>9. Vasudevan, D.P., Lala, P.K., Jia, D., Parkerson, J.P.: Reversible logic design with online testability. IEEE Trans. Instrum. Meas. **55**(2), 406–414 (2006)
- <span id="page-7-4"></span>10. Thapliyal, H., Vinod, A.P.: Designing efficient online testable reversible adders with new reversible gate. In: IEEE International Symposium on Circuits and Systems (ISCAS), pp. 1085–1088
- 11. Thapliyal, H., Ranganathan, N.: Reversible logic based concurrent error detection methodology for emerging nanocircuit. In: 10th IEEE International Conference on Nano Technology, pp. 217–222 (2004)
- 12. Farazmand, N., Zamani, M., Tahoori, M.B.: Online fault testing of reversible logic using dual rail coding. In: 16th IEEE International Symposium on On-Line Testing (IOLTS), pp. 204–205 (2010)
- <span id="page-7-5"></span>13. Mahammad, S.K.N., Veezhinathan, K.: Constructing online testable circuits using reversible logic. IEEE Trans Instrum. Meas. **59**(1), 101–109 (2010)
- <span id="page-7-6"></span>14. Gaur, H.M., Singh, A.K.: Design of reversible logic circuits with high testability. IET Electron. Lett. **52**(13), 1102–1104 (2016)
- <span id="page-7-7"></span>15. Nayeem, N.M., Rice, J.E.: Online testable approaches in reversible logic. J. Electron Test. **29**(6), 763–778 (2013)
- <span id="page-7-8"></span>16. Sen, B., Das, J., Sikdar, B.K.: A DFT methodology targeting online testing of reversible circuit. In: IEEE International Conference of Devices, Circuits and Systems, pp. 689–693 (2012)
- <span id="page-7-9"></span>17. Mohammadi, M., Eshghi, M.: On fgures of merit in reversible logic designs. J. Quant. Info Process. **8**(4), 297–318 (2009)
- <span id="page-7-10"></span>18. Maslov, D., Dueck, G., Scott, N.: Reversible Logic Synthesis Benchmark, [http://www.cs.uvic.ca/~dmaslov](http://www.cs.uvic.ca/%7edmaslov) (2017)
- <span id="page-7-11"></span>19. An Online Resource for Reversible Functions and Reversible Circuits. <http://www.informatik.uni-bremen.de/revkit/>
- <span id="page-7-12"></span>20. Miller, D.M., Maslov, D., Dueck, G.W.: A transformation based algorithm for reversible logic synthesis. In: Proceedings of DAC, pp. 318–323 (2010)