# Implementing a one-bit reversible full adder using quantum-dot cellular automata

Zahra Mohammadi · Majid Mohammadi

Received: 9 July 2013 / Accepted: 14 June 2014 / Published online: 6 August 2014 © Springer Science+Business Media New York 2014

Abstract Quantum-dot cellular automata (QCA) technique is one of the emerging and promising nanotechnologies. It has considerable advantages versus CMOS technology in various aspects such as extremely low power dissipation, high operating frequency and small size. In this paper, designing of a one-bit full adder is investigated using a QCA implementation of Toffoli and Fredkin gates. Then, a full adder design with reversible QCA1 gates is proposed regarding to overhead and power savings. Our proposed full adder design is more preferable when considering both circuit area and speed. The proposed design uses only two QCA1 gates and maximizes the circuit density and focuses on a layout of the circuit which is minimal in using QCA cells.

Keywords QCA · Full adder · Reversible · QCA1 gate

# **1** Introduction

Nanotechnology has been the focus of extensive research in the recent years. Power dissipation of the circuit is one of the most important difficulties in the development of the modern computational systems [1]. A possible solution is reversible computations. Reversible computing considers the relation between information dissipation and energy dissipation at the logical level. Energy dissipation could be caused by information dissipation [2]. If a one-to-one mapping is established between the input

Z. Mohammadi

Department of Computer Engineering, Kerman Branch, Islamic Azad University, Kerman, Iran e-mail: z\_mohammadi81@yahoo.com

M. Mohammadi (🖂)

Department of Computer Engineering, Shahid Bahonar University of Kerman, Kerman, Iran e-mail: M\_mohamadi@sbu.ac.ir; mjmohamadi@yahoo.com; mohammadi@mail.uk.ac.ir

and output vectors, reversible computation would be achieved at the logical level [3]. The one-to-one mapping is called *bijective* property. The *bijective* property investigated by Landauer. He proved heat dissipation for losing any bit of information would be KTln2 joules, where k is Boltzmann's constant and T is the temperature at which computation is performed. Consequently, without losing any bit of information, no energy dissipation occurs [3].

The CMOS technology is accompanied by various problems such as high leakage currents, high power density levels and extremely high lithography costs [4]. One of the alternatives for CMOS technology is quantum-dot cellular automata (QCA). QCA has none of these problems and potentially has small feature size and ultra-low power consumption. An electron pair configuration within a quantum-dot cell specifies the logical states. The information is transferred by propagation of a polarization state in QCA technology [5]. QCA circuits can be constructed through molecular implementations by a self-assembly process [6]. QCA has a very high density, 10<sup>12</sup> devices/cm<sup>2</sup>, and operates at THZ frequencies [7].

Following paper presents a novel one-bit QCA full adder using QCA1 gates which uses the minimum number of QCA cells and clock zones. The proposed full adder is more efficient and less complex than previously reported designs. The structure of the paper is as follows. In Sect. 2, the background of QCA concept, reversible QCA gates and reversible full adders are presented. In Sect. 3, designing of a one-bit reversible full adder with reversible QCA1 gates is investigated. Our proposed QCA one-bit full adder is compared to available counterparts. In Sect. 4, simulation results verifying the proposed full adder are provided. We conclude in Sect. 5.

#### 2 Background

#### 2.1 Basic QCA devices

A QCA cell, which is a set of four quantum dots located at the corners and an electron pair, is used for constructing all components of circuits and wires [8]. If two electrons are placed in two quantum dots, they would be far from each other to possible space due to electron repulsion force. How electrons move in two quantum dots without getting away is simply justifiable by tunneling predicted by quantum physics. Three states can be occurred by providing tunneling junctions with potential barriers. The potential barriers are raised to prevent electron movement and lowered to permit electron movement. The mobile electrons can localize on any dot when barriers are low which is named as null state; two other states can occur when barriers are raised and the cell is polarized. These two states representing logical "1" and "0" are shown in Fig. 1 as P = +1 and P = -1, respectively. Due to columbic interactions and depending on the polarization of a cell, the other cells next to the cell are forced into matching polarization. Hence, the polarization is propagated and information is transferred [9]. Majority gate is the fundamental logic gate in QCA implementations and is shown in Fig. 2a. Majority gate has three inputs and one output. The logic function of majority gate is as Eq. 1. Depending on the value of the inputs A, B and C, two mobile electrons in the other cells as well as output cell are forced into matching polarization and are

Fig. 1 Binary states







Fig. 2 a Majority gate, b inverter gate, c AND gate, d OR gate, e binary wire, f inverter chain

located to the corner positions by columbic repulsion [8]. If the number of "1" states is more than "0" states in an input vector, the output of majority gate would be "1." For instance, if inputs A = 1, C = 1 and B = 0, then the middle cell would be "1" because only two electrons are in the vicinity of each other in this case; Otherwise, If the middle cell is set to "0" state, four electrons would be in the vicinity of each other. Similarly, it is possible to obtain the outputs for other input vectors. The other basic gate is inverter gate and is shown in Fig. 2b. QCA cells are arranged in a way that the opposite polarization of the input-A is transmitted to the output-F in the inverter gate. Other logical functions such as AND and OR can be implemented by setting one input of the majority gate to "0" and "1," respectively. The logic functions of AND and OR gates are as Eqs. 2a and 2b.

$$Majority(A, B, C) = AB + BC + AC$$
(1)

$$Majority(A, B, 0) = AB + B \times 0 + A \times 0 = AB = AND(A, B)$$
(2a)  

$$Majority(A, B, 1) = AB + B \times 1 + A \times 1 = AB + A + B = A(B + 1) + B$$
  

$$= A + B = OR(A, B)$$
(2b)

AND and OR gates are shown in Fig. 2c, d. The binary wire and inverter chain are shown in Fig. 2e, f. The polarization of one QCA cell will be directly affected by the polarization of its neighbors. Hence, QCA cells are forced to synchronize their polarizations; the state of the input-A is transmitted to the output-F by columbic interactions in a QCA binary wire. For instance, if the input cell of a binary wire is set to "0," since electrons tend to get to the farthest state, nearest neighbor of the input cell would set to "0" (two electrons would be consumedly approached to each other if the cell is set to "1"). This leads to getting the third cell to "0"; consequently, fourth and other cells would set to "0," and the "0" state is propagated to the output cell (Fig. 2e). The polarization of 45°-quantum cell is on the opposite state of its nearest neighbor in the inverter chain [5].

#### 2.2 Clocking in QCA

Clock is a reference signal which controls timing in sequential CMOS circuits, whereas timing in QCA technology is performed by clocking in four periodic phases such as switch, hold, release and relax [6]. The four-phase clocking scheme is called Landauer clocking and is used to modulate the inter-dot tunneling barrier of QCA cells [8]. During the switch phase, in which actual computations are occurred, barriers are raised and a cell is affected by the polarization of its neighbors and a distinctive polarity is obtained. During the hold phase, barriers are high and the polarization of the cell is retained. During the release phase, barriers are lowered and the cell loses the polarity. In the relax phase, the cell is non-polarized. Four phases are shown in Fig. 3a in which a cell is controlled by a clock signal (clock0). A signal is latched and remained latched until the cells of the next clocking zone switches to the hold phase and acts as an input to the subsequent zone. Hence, inherent pipeline [10,11] is possible in *Landauer* clocking scheme in which the cell is released after one clock cycle and it can participate in the next operation [12]. Inherent pipeline allows transferring multi-bit of information in QCA implementations [8]. Landauer clocking scheme uses four clocks to control QCA circuits. These four clocks are shown in Fig. 3b as clock0, clock1, clock2 and clock3.



**(a)** 



Fig. 3 a Four phases of Landauer clocking scheme, b a binary wire

Each clock of *Landauer* clocking scheme is  $90^{\circ}$  out-of-phase from its previous clock [13]. To figure out how the clocking scheme operates, a binary wire is shown in Fig. 3b.

A QCA circuit is partitioned into a number of clocking zones. QCA cells included in the same clocking zone are controlled by one clocking signal. The clocking signals are provided by CMOS wires which are located under the QCA circuit [12]. QCA cells of the binary wire are divided into four clocking zones as shown Fig. 3b. Each zone is controlled by a common clock signal. zone0 (input cell, cell1 and cell2) is controlled by clock0, zone1 (cell3 and cell4) by clock1, zone2 (cell5 and cell6) by clock2 and zone3 (cell7, cell8 and the output cell) by clock3. When QCA cells included in the zone0 are in the switch phase of clock0, QCA cells included in the zone1 would be in the relax phase of clock1, QCA cells in the zone2 in the release phase of clock2 and QCA cells in the zone3 in the hold phase of clock3. Three remained phases of each clock would be applied to these four zones, sequentially. After four phases of each clock applied to the four zones, one clock cycle is accomplished. During a clock cycle, all four clocks traverse four phases, however, with different starting phases [13].

During the switch phase of clock0, cell1 and cell2 are affected by the polarization of the input cell. During the switch phase of clock1, which clock0 is in the hold phase, cell3 and cell4 are polarized by cell2. When clock2 is in the switch phase and clock1 in the hold phase, cell5 and cell6 are polarized by cell4. When clock3 is in the switch phase and clock2 is in the hold phase, cell7, cell8, and finally the output cell are affected by the polarization of cell6. At the end, cell7, cell8 and the output cell switch to the hold phase and this cycle repeats [13]. In other words, a signal is latched when one clocking zone goes into the hold phase and acts as an input to the next zone. During a clock cycle, the polarization of the input cell is exactly propagated to the output cell and information propagation is performed in the binary wire.Clock0, clock1, clock2 and clock3 are shown with green, violet, blue and white colors, respectively, in QCA implementations.

#### 2.3 Reversible QCA Fredkin and Toffoli gates

In this section, the QCA implementations of Toffoli and Fredkin gates are presented [14, 15]. There is neither energy loss nor information loss in reversible circuits. Reversible circuits are very attractive in nanotechnologies such as QCA where extremely low power consumption or heat dissipation is desirable.

#### 2.3.1 Fredkin gate

The Fredkin gate is a  $3 \times 3$  universal gate. Using Fedkin gate, any logical reversible circuit can be implemented [15]. The truth table of this gate is shown in Table 1 [8].

Input *u* acts as a control input. If the control input is u = 1, then outputs  $Y_1$  and  $Y_2$  are exactly duplicates of the inputs  $x_1$  and  $x_2$ ; otherwise, if u = 0, then two inputs  $x_1$  and  $x_2$  are swapped and transmitted to the outputs  $Y_1$  and  $Y_2$ . The output functions of Fredkin gate are shown in Eq. 3 [8].

$$V = u$$
  

$$Y1 = \overline{u}.x_2 + u.x_1$$
  

$$Y2 = \overline{u}.x_1 + u.x_2$$
(3)



| и | <i>x</i> <sub>1</sub> | <i>x</i> <sub>2</sub> | V | <i>Y</i> <sub>1</sub> | <i>Y</i> <sub>2</sub> |
|---|-----------------------|-----------------------|---|-----------------------|-----------------------|
| 0 | 0                     | 0                     | 0 | 0                     | 0                     |
| 0 | 0                     | 1                     | 0 | 1                     | 0                     |
| 0 | 1                     | 0                     | 0 | 0                     | 1                     |
| 0 | 1                     | 1                     | 0 | 1                     | 1                     |
| 1 | 0                     | 0                     | 1 | 0                     | 0                     |
| 1 | 0                     | 1                     | 1 | 0                     | 1                     |
| 1 | 1                     | 0                     | 1 | 1                     | 0                     |
| 1 | 1                     | 1                     | 1 | 1                     | 1                     |



Fig. 4 QCA implementation of Fredkin gate

When two identical Fredkin gates are cascaded, the outputs of the second gate are same as the inputs of the first gate. Hence, Fredkin gate is named self-inverse. A QCA implementation of the gate is shown in Fig. 4 [8]. Inverter chains, which are usually

| Table 2         Truth table of Toffoli           gate | x1 | x2 | x3 | Y1 | Y2 | ¥3 |
|-------------------------------------------------------|----|----|----|----|----|----|
|                                                       | 0  | 0  | 0  | 0  | 0  | 0  |
|                                                       | 0  | 0  | 1  | 0  | 0  | 1  |
|                                                       | 0  | 1  | 0  | 0  | 1  | 0  |
|                                                       | 0  | 1  | 1  | 1  | 1  | 1  |
|                                                       | 1  | 0  | 0  | 1  | 0  | 0  |
|                                                       | 1  | 0  | 1  | 1  | 0  | 1  |
|                                                       | 1  | 1  | 0  | 1  | 1  | 0  |
|                                                       | 1  | 1  | 1  | 0  | 1  | 1  |

used to implement wire crossings in the same layers, are used for crossing wires in the QCA implementation of Fredkin gate. The wire which is along the horizontal direction is a binary wire, and the other wire is an inverter chain located in the perpendicular direction.

The QCA implementation of Fredkin gate uses a two-level majority implementation with six majority gates; four of them are programmed as AND gates and two of them as OR gates [12].

# 2.3.2 Toffoli gate

The Toffoli gate is a reversible gate with three inputs and three outputs. It is also a universal and self-inverse gate [15]. The truth table of Toffoli gate is shown in Table 2 [8]. It passes inputs  $x^2$  and  $x^3$  to the outputs  $Y^2$  and  $Y^3$  without any changes but inverts input  $x^1$  when  $x^2 = 1$  and  $x^3 = 1$ .

The output functions of Toffoli gate are shown in Eq. 4.

$$Y1 = x1\overline{x2} + x1\overline{x3} + \overline{x1}x2x3$$
  

$$Y2 = x2$$
  

$$Y3 = x3$$
(4)

The QCA implementation of Toffoli gate (Fig. 5) uses four majority gates which are implemented in two levels. Two numbers of majority gates are programmed as AND and OR gates [8].

## 2.3.3 Reversible QCA Feynman gate

Feynman gate is a reversible  $2 \times 2$  gate. The truth table of Feynman gate is shown in Table 3 [8]. The input *x*1 acts as a control input. If the control input *x*1 = 0, then the output *Y*2 is simply a duplicate of the input *x*2; otherwise, if the control input *x*1 = 1, then the output *Y*2 is inverse of the input *x*2.

The output functions of Feynman gate are shown in Eq. 5.

$$Y1 = X1$$
  

$$Y2 = X1xorX2 = x1\overline{x2} + \overline{x1}x2$$
(5)



Fig. 5 QCA implementation of Toffoli gate

| <b>Table 3</b> Truth table ofFeynman gate | x1 | x2 | Y1 | Y2 |
|-------------------------------------------|----|----|----|----|
|                                           | 0  | 0  | 0  | 0  |
|                                           | 0  | 1  | 0  | 1  |
|                                           | 1  | 0  | 1  | 1  |
|                                           | 1  | 1  | 1  | 0  |

As shown in Fig. 6, four clocking zones are used in the QCA implementation of Feynman gate. The rectangular area occupied by its entire layout is an area of  $15 \times 15$  cells [8].



Fig. 6 QCA implementation of Feynman gate

2.4 QCA1 and QCA2 gates

Two new reversible gates, called QCA1 and QCA2 were proposed for reversible QCA implementations in [12] and compared to QCA reversible Fredkin and Toffoli gates. QCA1 is a reversible gate and has three inputs and three outputs. The truth table of QCA1 gate is shown in Table 4 [8]. There is a one-to-one mapping between inputs and outputs.

The output functions are expressed by Eq. 6.

$$Y1 = Majority(x1 + x2 + x3)$$
  

$$Y2 = Majority(x1 + x2 + \overline{x3})$$
  

$$Y3 = Majority(\overline{x1} + x2 + x3)$$
  
(6)

| Table 4         Truth table of QCA1 | x1 | x2 | x3 | Y1 | Y2 | ¥3 |
|-------------------------------------|----|----|----|----|----|----|
|                                     | 0  | 0  | 0  | 0  | 0  | 0  |
|                                     | 0  | 0  | 1  | 0  | 0  | 1  |
|                                     | 0  | 1  | 0  | 0  | 1  | 1  |
|                                     | 0  | 1  | 1  | 1  | 0  | 1  |
|                                     | 1  | 0  | 0  | 0  | 1  | 0  |
|                                     | 1  | 0  | 1  | 1  | 0  | 0  |
|                                     | 1  | 1  | 0  | 1  | 1  | 0  |
|                                     | 1  | 1  | 1  | 1  | 1  | 1  |



Fig. 7 QCA implementation of QCA1 gate

The QCA implementation of QCA1 gate is shown in Fig. 7 [8]. It requires only one level of majority gates [12]. QCA implementation of QCA1 has only a delay of two clocking zones and requires three majority gates [12].

QCA2 has similar properties to QCA1. The QCA implementation of QCA2 is shown in Fig. 8 [8]. The truth table of QCA2 gate is shown in Table 5. Three output functions of QCA2 gate are shown in Eq. 7 [8]:

$$Y1 = Majority(x1 + x2 + x3)$$
  

$$Y2 = Majority(x1 + x2 + \overline{x3})$$
  

$$Y3 = Majority(\overline{x1} + x2 + \overline{x3})$$
(7)

Figure 9 shows a schematic diagram of the reversible Fredkin, Toffoli, Feynman, QCA1 and QCA2 gates.

A comparison was done among four QCA reversible Fredkin, Toffoli, QCA1 and QCA2 gates by [12]. The QCA1 and QCA2 gates have a one-level majority implementation and require only two clocking zones; therefore, their delays are less than



Fig. 8 QCA implementation of QCA2 gate

| Table 5Truth table of QCA2gate | x1 | x2 | x3 | Y1 | Y2 | ¥3 |
|--------------------------------|----|----|----|----|----|----|
|                                | 0  | 0  | 0  | 0  | 0  | 1  |
|                                | 0  | 0  | 1  | 0  | 0  | 0  |
|                                | 0  | 1  | 0  | 0  | 1  | 1  |
|                                | 0  | 1  | 1  | 1  | 0  | 1  |
|                                | 1  | 0  | 0  | 0  | 1  | 0  |
|                                | 1  | 0  | 1  | 1  | 0  | 0  |
|                                | 1  | 1  | 0  | 1  | 1  | 1  |
|                                | 1  | 1  | 1  | 1  | 1  | 0  |

Fredkin and Toffoli gates. QCA1 and QCA2 occupy a smaller area with a reduced number of QCA cells with no control cells. The thirteen standard combinational functions are implemented using each of the four reversible QCA gates by [12] and the number of required gates and clocking zones are obtained. The results are shown in Table 6. In comparison, QCA1 and QCA2 gates are more preferable than Fredkin and Toffoli gates for QCA implementation considering both circuit area and speed [12].



Fig. 9 a Toffoli gate, b Fredkin gate, c Feynman gate, d QCA1 gate and e QCA2 gate

## 2.5 Reversible QCA full adder

In this section, designing of Full adder, which is a basic circuit in computing circuits, is investigated using reversible QCA Fredkin and Toffoli gates. To implement a reversible full adder, a reversible truth table is required. Hence, some extra don't care inputs or outputs are usually added to the truth table of full adder to provide the *bijective* property and reversibility condition. Don't cares (DCs) are some inputs whose corresponding outputs are not determined in the truth table of the function. These extra inputs and outputs are called constant inputs and garbage outputs. The value of a constant input is arbitrary [16]. It is proved that there is an optimum value for the number of constant inputs to obtain a circuit with minimum quantum cost (QC) [17]. The QC of a reversible logic circuit is the number of  $1 \times 1$  or  $2 \times 2$  reversible, and quantum logic gates are used to implement the circuit [18]. The truth table of reversible full adder is depicted in Table 7 [16].

In [16], some heuristic methods are presented to use these DCs when an optimization algorithm such as the genetic algorithm is used as a synthesis tool. Figure 10 shows some optimal circuits of a Toffoli full adder using a genetic algorithm (optimized for quantum cost [18]).

Toffoli full adder has four inputs and four outputs which one of the inputs is a constant input and two of the outputs are garbage outputs. Four gates are used to synthesize Toffoli full adder. QCA implementation of Toffoli and Feynman gates are investigated in Sects. 2.3.2 and 2.3.3, respectively. Each Toffoli gate consists of four majority gates, and Feynman gate has three majority gates; therefore, 14 majority gates are totally needed in the full adder design. Full adder with Toffoli gates totally uses 19 clocking zones, four clocking zones for each gate and three additional clocking zones [12] for interconnections. The QC is extensively used as a figure of merit in reversible and quantum designs. The QC of Toffoli full adder is 12 [19]. Toffolli full adder layout is complex because of using two-level majority implementations.

| -                                                                         |                          |               |          |                          |              |          |                 |         |                 |           |
|---------------------------------------------------------------------------|--------------------------|---------------|----------|--------------------------|--------------|----------|-----------------|---------|-----------------|-----------|
| Functions                                                                 | Fredkin+INV<br>Of Fre Of | INV<br>Of INV | Clk zone | Toffoli+INV<br>Of Toff ( | JV<br>Of INV | Clk zone | QCA1<br>Of QCA1 | Clkzone | QCA2<br>Of QCA2 | Clk zones |
| $F1 = A\overline{B}C$                                                     | 5                        | 0             | 6        | 2                        | 0            | 6        | 5               | 5       | 2               | 5         |
| F2 = AB                                                                   | 1                        | 0             | 4        | 1                        | 0            | 4        | 1               | 7       | 1               | 2         |
| $F3 = \overline{ABC} + \overline{ABC}$                                    | 2                        | 1             | 9        | 2                        | 1            | 9        | 2               | 5       | 2               | 5         |
| $F4 = \overline{ABC} + A\overline{BC}$                                    | 2                        | 0             | 9        | 3                        | 1            | 9        | 3               | 8       | 3               | 8         |
| $F5 = \overline{A}B + B\overline{C}$                                      | 2                        | 0             | 9        | 2                        | 0            | 9        | 2               | 5       | 2               | 5         |
| $F6 = A\overline{B} + \overline{A}BC$                                     | 2                        | 0             | 6        | 3                        | 0            | 6        | 3               | 5       | 3               | 5         |
| $F7 = \overline{A}BC + AB\overline{C} + \overline{ABC}$                   | 3                        | 1             | 9        | 3                        | 2            | 9        | 3               | 5       | 3               | 5         |
| F8 = A                                                                    | 1                        | 0             | 4        | 1                        | 0            | 4        | 1               | 2       | 1               | 2         |
| F9 = AB + AC + BC                                                         | 3                        | 1             | 6        | 4                        | 0            | 14       | 1               | 2       | 1               | 2         |
| $F10 = \overline{A}B + \overline{B}C$                                     | 1                        | 0             | 4        | 3                        | 0            | 6        | 3               | 5       | 3               | 5         |
| $F11 = \overline{A}B + BC + A\overline{BC}$                               | 3                        | 1             | 6        | 1                        | 0            | 4        | 4               | 5       | 4               | 5         |
| $F12 = AB + \overline{AB}$                                                | 1                        | 1             | 4        | 1                        | 0            | 4        | 2               | 5       | 2               | 5         |
| $F13 = AB\overline{C} + \overline{ABC} + A\overline{B}C + \overline{A}BC$ | 2                        | 2             | 6        | 2                        | 1            | 6        | 2               | 5       | 2               | 5         |
|                                                                           |                          |               |          |                          |              |          |                 |         |                 |           |

 Table 6
 Reversible implementation of thirteen standard functions

| Constant input | а | b | Cin | Cout | Sum | Garbage output | Garbage output |
|----------------|---|---|-----|------|-----|----------------|----------------|
| 0              | 0 | 0 | 0   | 0    | 0   | Х              | Х              |
| 0              | 0 | 0 | 1   | 0    | 1   | Х              | Х              |
| 0              | 0 | 1 | 0   | 0    | 1   | Х              | Х              |
| 0              | 0 | 1 | 1   | 1    | 0   | Х              | Х              |
| 0              | 1 | 0 | 0   | 0    | 1   | Х              | Х              |
| 0              | 1 | 0 | 1   | 1    | 0   | Х              | Х              |
| 0              | 1 | 1 | 0   | 1    | 0   | Х              | Х              |
| 0              | 1 | 1 | 1   | 1    | 1   | Х              | Х              |

 Table 7
 Truth table of a reversible full adder



Fig. 10 Different implementation of full adder using Toffoli gates



Fig. 11 Different implementation of full adder using Fredkin gates

It is impossible to synthesize Fredkin full adder with four inputs and four outputs. One extra constant input and one garbage output are added to the truth table of the full adder to satisfy reversibility condition. The synthesis result of a Fredkin full adder using genetic algorithm is a circuit consists of five Fredkin gates and a five-to-five mapping with three garbage outputs. The QC of Fredkin full adder is 25. The results are shown in Fig. 11. The Fredkin gate uses a two-level majority implementation with 6 majority gates. Synthesized Fredkin full adder uses totally 30 majority gates, which is much more than Toffoli full adder. As a result, Toffoli full adder is more preferable than Fredkin full adder for reversible implementations. In the next section, a new reversible full adder with QCA1 gate is proposed which has significant improvements.

## 3 Proposed full adder design using QCA1 gates

In this section, a one-bit full adder is proposed using only two QCA1 gates, whereas the conventional reversible Toffoli and Fredkin full adders use four and five gates, respectively. On the other hand, QCA1 is more preferable for QCA implementation compared to reversible QCA Toffoli and Fredkin gates considering circuit area and speed [12]. Two clocking zones are only used in QCA1 implementation in comparison



Fig. 12 One-bit QCA full adder

with Toffoli gate which needs four clocking zones. As a result, occupied rectangular area by the entire layout of our proposed full adder is lower and the number of clocking zones is significantly reduced.

A one-bit full adder is defined as Eq. 8 [19]:

$$Sum = abCin + \bar{a}\bar{b}Cin + \bar{a}b\bar{C}in + a\bar{b}\bar{C}in \tag{8a}$$

$$Cout = ab + aCin + bCin \tag{8b}$$

where a, b and Cin are inputs; sum and Cout are the outputs of the full adder. Implementing a one-bit irreversible full adder requires five majority gates and three inverters to satisfy the set of equations *sum* and Cout, as shown in Fig. 12 [19].

An algorithm is proposed in [19] to reduce the number of required majority and inverter gates in a QCA circuit. The simplified majority expressions of the thirteen standard functions are presented in [20] using corresponding 3-cube structure. The algorithm enables us to convert any three-variable Boolean functions into the simplest majority expressions for QCA implementations. [20] proposes a procedure to build simplified majority expressions for a given Boolean function; then applies the proposed majority reduction method to QCA adders. The procedure uses a 4-step algorithm to generate a majority gate expression. For more information, refer to [20]. Sum and Cout equations are obtained as Eq. 9 using the reduction method [19]:

$$Cout = Majority(a, b, Cin)$$
(9a)

$$Sum = Majority(\overline{Cout}, Cin, M(a, b, \overline{Cin}))$$
(9b)

*Proof* The proof of the Eq. 9b is as follows [19]:

Using the majority function (Eq. 1) and the Eq. 9a:

$$\overline{Cout} = \overline{a}\overline{b} + \overline{a}\overline{C}in + \overline{b}\overline{C}in = Majority(\overline{a}, \overline{b}, \overline{C}in)$$

Then, the Eq. 9b can be rewritten as:

$$\begin{split} ∑ = (ab + \overline{ab})Cin + (\overline{ab}Cin + a\overline{b}Cin) \\ &= [(\overline{ab} + \overline{a}\overline{Cin} + \overline{Cinb}) + (ab + a\overline{Cin} + \overline{Cinb})]Cin \\ &+ (\overline{ab}Cin + a\overline{b}Cin) = (\overline{ab} + \overline{a}\overline{Cin} + \overline{Cinb})Cin + (ab + a\overline{Cin} + \overline{Cinb})Cin \\ &+ (\overline{ab}Cin + a\overline{b}Cin) = (\overline{ab} + \overline{a}\overline{Cin} + \overline{Cinb})Cin + (ab + a\overline{Cin} + \overline{Cinb})Cin \\ &+ (\overline{a}\overline{Cin} + \overline{a}\overline{b}\overline{cin}) = (\overline{ab} + \overline{a}\overline{Cin} + \overline{cinb})Cin + (ab + a\overline{Cin} + \overline{Cinb})Cin \\ &+ (\overline{a}\overline{Cin} + \overline{Cinb})(a\overline{Cin} + b\overline{Cin}) \\ &= (\overline{ab} + \overline{a}\overline{Cin} + \overline{Cinb})Cin + (ab + a\overline{Cin} + \overline{Cinb})Cin \\ &+ (\overline{ab} + \overline{a}\overline{Cin} + \overline{Cinb})(ab + a\overline{Cin} + b\overline{Cin}) \\ &= Majority(\overline{a}, \overline{b}, \overline{Cin})Cin + Majority(a, b, \overline{Cin})Cin \\ &+ Majority(\overline{a}, \overline{b}, \overline{Cin}).Majority(a, b, \overline{Cin}) \\ &= Majority(Majority(\overline{a}, \overline{b}, \overline{Cin}), Cin, M(a, b, \overline{Cin})) \\ &= Majority(\overline{Cout}, Cin, Majority(a, b, \overline{Cin})) \end{split}$$

Based on the reduction method, Cout function involves one majority gate and sum function involves two majority gates. There is no inverter gates to get inversions and they can be directly obtained from interconnections of QCA cell lines ( $\overline{Cout}$  and  $\overline{Cin}$ ). The truth table of our proposed reversible full adder (Table 8) has the reversibility condition with  $n \leq m$ , in which *n* is the number of inputs and *m* is the number of outputs. The inputs and outputs can be uniquely determined from each other and the full adder is reversible. Our proposed QCA1full adder is implemented regarding to the Eq. 9b.

We cascaded two reversible QCA1 gates to implement our proposed full adder design as shown in Fig. 13. Our proposed full adder design is reversible because it uses only reversible gates and its truth table has the reversibility condition.

| a | b | Cin | Cout | Sum | Gar1 | Gar2 | Gar3 |
|---|---|-----|------|-----|------|------|------|
| 0 | 0 | 0   | 0    | 0   | 0    | 0    | 0    |
| 0 | 0 | 1   | 0    | 1   | 1    | 0    | 0    |
| 0 | 1 | 0   | 0    | 1   | 1    | 0    | 1    |
| 0 | 1 | 1   | 1    | 0   | 1    | 1    | 0    |
| 1 | 0 | 0   | 0    | 1   | 0    | 0    | 1    |
| 1 | 0 | 1   | 1    | 0   | 0    | 1    | 0    |
| 1 | 1 | 0   | 1    | 0   | 0    | 1    | 1    |
| 1 | 1 | 1   | 1    | 1   | 1    | 1    | 1    |

Table 8 Truth table of the proposed reversible full adder



Fig. 13 Schematic diagram of the proposed full adder implementation with QCA1 gates

If we define inputs of the first QCA1 gate as x1 = a, x2 = b, and x3 = Cin, and Yij as  $i_{th}$  output of  $j_{th}$  QCA1 gate, then the outputs of the first QCA1 gate are as follows:

$$\begin{array}{l} Y11 = Majority(X1, X2, X3) = Majority(a, b, Cin) = Cout\\ Y21 = Majority(X1, X2, \overline{X3}) = Majority(a, b, \overline{Cin})\\ Y31 = Majority(\overline{X1}, X2, X3) = Majority(\overline{a}, b, Cin) = Gar1 \end{array}$$

Therefore, Cout is directly obtained by  $Y_{11}$ . The output  $Y_{31}$  is garbage output and is denoted as *Gar1*. Then,  $Y_{11}$  and  $Y_{21}$  are applied to the first and second inputs of the next QCA1 gate as shown in Fig. 13. The outputs of the second QCA1 gate are obtained as follows:

$$\begin{array}{l} Y12 = Majority(X1, X2, X3) = Majority(Cout, Majority(a, b, Cin), Cin) = Gar2\\ Y22 = Majority(X1, X2, \overline{X3}) = Majority(Cout, Majority(a, b, \overline{Cin}), \overline{Cin}) = Gar3\\ Y32 = Majority(\overline{X1}, X2, X3) = Majority(\overline{Cout}, Majority(a, b, \overline{Cin}), Cin) = sum \end{array}$$

The output *Y*32 satisfies the sum function of the full adder (Eq. 9a). As a result, sum and Cout functions of the one-bit full adder are obtained by cascading two reversible QCA1 gates. QCA implementation of the proposed full adder is shown in Fig. 14. To obtain the minimum delay in the proposed circuit, the second QCA1 gate is implemented in a way that inputs to the sum output delay is minimal. In other words, the second QCA1 gate is implemented reversely; the sum function is obtained in the first output of the second QCA1 gate. The rectangular area occupied by the entire layout as well as interconnections is only  $35 \times 31$ , which in one QCA cell is considered as a unit area. Inverter chains are usually used to implement wire crossings in the same layers, but it is shown that binary wires can tolerate defects more than inverter chains [21]. Therefore, a multi-layer crossover scheme is used to decrease failure rate and wires are passed over each other to ensure that no interferences occur in the proposed design.

The proposed full adder design implemented by reversible QCA1 gates requires only two gates, and it has a total delay of 6 clocking zones. [12] verifies an additional clocking zone that is required for interconnection between two reversible QCA gates. We, however, added two additional clocking zones for interconnection between QCA1 gates to ensure correct operation of our proposed full adder. The number of used clocking zones is lower than Toffoli full adder. The proposed design decreases QCA cell counts and input to output delays.



Fig. 14 QCA implementation of the proposed full adder design

### 4 Simulation and verification results

QCA designer software which is a popular simulation tool for complex QCA circuits is used to simulate and verify the proposed full adder. The simulator tool uses an extensive set of CAD tools [22]. The simulator version is 2.0.3 and the following parameters are used: cell size = 18 nm, number of samples = 12,800, convergence tolerance = 0.001000, radius of effect = 65 nm, relative permittivity = 12.9, clock high = 9.8e-22, clock low = 3.8e-23, clock amplitude factor = 2.000, layer separation = 11.5000 nm and maximum iterations per sample = 100. Implementing a workable design with a compact layout is considered in our proposed QCA layout. It is considerable that the results are correct after one clock. Inputs a, b and Cin are marked with blue color, and the outputs sum and Cout are shown with yellow color in the simulation box (Fig. 15).

Two reversible QCA full adders are compared and the results are shown in Table 9. In this paper, five figures of merit (FoM) are evaluated. *Majority gates* figure identifies the number of majority gates used in the QCA implementation. The number of *constant inputs* and the number of *garbage outputs* are provided. These two FoMs are used to evaluate reversible and quantum designs. The number of *clocking zones* is presented to quantify the delay between inputs and outputs. The number of *control cells* are also provided, which are the input cells with fixed polarization used for programming 2-input OR and AND gates.



Fig. 15 Simulation results of the proposed full adder using QCA1 gates

| Table 9 | Comparison b | between two | reversible | QCA full adders |
|---------|--------------|-------------|------------|-----------------|
|---------|--------------|-------------|------------|-----------------|

|                          | Constant inputs | Garbage outputs | Clocking zones | Majority<br>gates | Control cells |
|--------------------------|-----------------|-----------------|----------------|-------------------|---------------|
| Toffoli full adder       | 1               | 2               | 19             | 14                | 10            |
| Proposed QCA1 full adder | 0               | 3               | 6              | 6                 | 0             |

The obtained results by comparing designs indicate that our proposed full adder design has demonstrated significant improvements and is more preferable for reversible QCA implementation considering both circuit area and speed. Proposed implementation of the reversible full adder design uses the minimum number of clocking zones and gates, maximizes the circuit density and focuses on a layout of the circuit which is minimal in using QCA cells. Hence, the proposed design greatly reduces occupied area and decreases signal propagation delay from input to output. The design is also very simple to implement by QCA cells.

# **5** Conclusions

Recently, QCA has attracted a lot of researchers' attention for implementing reversible computing. In this paper, designing a one-bit full adder investigated using reversible QCA gates. Reversible QCA gates compared and the results indicated that QCA1 and QCA2 gates are more preferable than Toffoli and Fredkin gates for reversible implementations. The conventional reversible full adders investigated using Toffoli and Fredkin gates and a new reversible full adder design proposed using only two QCA1

gates. Our proposed reversible full adder uses the minimum number of QCA cells, clocking zones and gates versus Toffoli full adder. Therefore, the proposed reversible QCA full adder is more efficient and less complex than its previous counterparts.

# References

- 1. Landauer, R.: Irreversibility and heat generation in the computing processes. IBM J. Res. Dev. 5, 183–191 (1961)
- Huang, J., Metra, Ma, X., Metra, C., Lombardi, F.: Testing reversible 1D arrays for molecular QCA. In: Proceedings of the 21st IEEE International Symposium on Defect and Fault-Tolerance in VLSI Systems, pp. 71–79 (2006)
- 3. Bennett, C.: Logic reversibility of computation. IBM J. Res. Dev. 17, 525-532 (1973)
- Gupta, P., Jha, N.K., Lingappan, L.: test generation framework for combinational quantum cellular automata circuits. IEEE Trans. VLSI Syst. 15(1), 24–36 (2007)
- Askari, M., Taghizadeh, M.: Logic circuit design in nano-scale using quantum-dot cellular automata. Eur. J. Sci. Res. 48(3), 516–526 (2011). ISSN 1450–216X
- Hennessy, K., Lent, C.S.: Clocking of molecular quantum-dot cellular automata. J. Vac. Sci. Technol. 19(5), 1752–1755 (2001)
- Tahoori, M.B., Huang, J., Momenzadeh, M., Lombardi, F.: Testing of quantum cellular automata. IEEE Trans. Nanotechnol. 3(4), 432–442 (2004)
- Ma, X., Huang, J., Metra, C., Lombardi, F.: Reversible and Testable Circuits for Molecular QCA Design. Northeastern University, ECE Department, Internal report (2007)
- 9. Amlani, I., Orlov, A.O., Snider, G.L., Lent, C.S.: Demonstration of a six-dot quantum cellular automata system. Appl. Phys. Lett. **72**(17), 2179–2181 (1998)
- Orlov, A.O., Amlani, I., Bernstein, G.H., Lent, C.S., Snider, G.L.: Realization of a functional cell for quantum-dot cellular automata. Science 277, 928–930 (1997)
- 11. Walus, K., Jullien, G.A., Dimitrov, V.S.: Computer arithmetic structures for quantum cellular automata. In: Proceedings of Asimolar Conference (2003)
- 12. Ma, X.: Physical/biochemical inspired computing models for reliability Nano-technology systems. Computer Engineering Dissertations (2008). Paper 2. http://hdl.handle.net/2047/d10017859
- Kyosun, K., Kaijie, W., Ramesh, K.: Quantum-dot cellular automata design guideline. IEICE Trans. Fundam. Electron. Commun. Comput. Sci. E89–A(6), 1607–1614 (2006)
- Toffoli, T.: Reversible Computing. MIT Laboratory for Computer Science, Technical Report MIT/LCS/TM-151, Feb (1980)
- 15. Maslov, D., Dueck, G.W.: Synthesis of Fredkin-Toffoli reversible networks. IEEE Trans. VLSI (2004)
- Mohammadi, M., Eshghi, M.: Heuristic Methods to use don't cares in automated design of reversible and quantum logic circuits. Quantum Inf. Process. 7(4), 175–192 (2008)
- 17. Maslov, D., Dueck, G.W.: Garbage in reversible design of multiple output functions. In: 6th International Symposium on Representations and Methodology of Future Computing Technologies, Trier (1980)
- Mohammadi, M., Eshghi, M.: On figures of merit in reversible and quantum logic designs. Quantum Inf. Process. 8(4), 297–318 (2009)
- Wang, W., Walus, K., Jullien, G.A.: Quantum-dot cellular automata adders. IEEE-Nano Third IEEE Conf. Nanotechnol. 1, 461–464 (2003)
- Wang, W., Zhang, R., Walus, K., Jullien, G.A.: A method of majority logic reduction for quantum cellular automata. IEEE Trans. Nanotechnol. 3(4), 443–450 (2004)
- Walus, K., Schulhof, G., Jullien, G.A.: High level exploration of quantum-dot cellular automata. In: Proc. Conf. Signals, Systems, and Computers, pp. 7–10, Nov (2004)
- 22. QCA Designer [Online]. Available: http://www.mina.ubc.ca