# Design and Implementation of 32-bit ALU with 16 operations using Reversible Logic Gates

# DEEPA.G<sup>1</sup>, MADHURI.E<sup>2</sup>, MALASHREE.S<sup>3</sup>, MAMATHA.K<sup>4</sup>

# SUPRIYA.K.V<sup>5</sup>

UG Student, Department of Electronics and Communication Engineering, Dr.T.T.I.T, K.G.F, India<sup>1, 2, 3, 4</sup>.

Assistant Professor, Department of Electronics and Communication Engineering, Dr.T.T.I.T, K.G.F, India<sup>5</sup>

Abstract-Reversible logic is one of the emerging technologies having promising applications in quantum computing. This paper will deal with the design of a 32 bit reversible Arithmetic Logic Unit (ALU) with 16 operations is presented by making use of Double Peres gate, Fredkin gate, Toffoli gate, DKG gate and NOT gate. A new VLSI architecture for ALU using reversible

ALU is one of the most important components of CPU that can be part of a programmable reversible computing device such as a quantum computer. A first single bit reversible ALU is designed and then 32 single bit ALU's are cascaded together taking carry out of ALU performing LSB operation as an input to carry in of ALU performing next LSB operation. Design is implemented and verified in Xilinx.

logic gates is proposed.

*Keywords- Low power ALU*, *Reversible gates*, *DPG*, *DKG*, *Fredkin*, *Toffoli*, *Feynman*.

# I. INTRODUCTION

Now-a-days, the electronic systems are an integral part of a human's life. As technology develops, the complexity of the system also increases. This gives rise to increase in power consumption, which is a great issue faced by the world today.

Energy dissipation due to information loss in high technology circuits and systems constructed using irreversible hardware was demonstrated by R. Landauer in the year 1960. According to Landauer's [5] principle, the loss of one bit of information lost will dissipate kTln2 joules of energy where, k is the Boltzmann's constant, T is the absolute temperature. In 1973, Bennett [6] showed that in order to avoid kTln2 joules of energy dissipation in a circuit it must be built from reversible circuits. Reversible circuits (gates) have the same number of inputs and outputs and there is a one to one mapping between vectors of inputs and outputs. Thus the vector of input states can be always uniquely reconstructed from the vector of output states.

# 1.1 The Arithmetic Logic Unit (ALU)

ALU is essentially the heart of a CPU. Different kinds of computers have different ALU's but all of the ALU's contain arithmetic unit and logic unit, which are the basic structures. This allows the computer to add, subtract, and to perform basic logical operations such as AND, OR etc.

### 1.2 Reversible Logic Gates

A function is reversible if each input vector produces a unique output vector. Reversible logic is of growing importance to many future computer technologies. It is not possible to realize quantum computing without implementation of reversible logic. The main purposes of designing reversible logic are to decrease quantum cost, depth of the circuits and the number of garbage outputs. The reversible circuits form the basic building block of quantum computers as all quantum operations are reversible. The two main constraints of reversible logic circuits are:-

[1] Fan-out not possible.

[2] Feedback or loops not allowed.

A reversible logic circuit should have the following salient features:

[1] Use minimum number of reversible gates.

[2] Use minimum number of garbage outputs.

[3] Use minimum number constant inputs.

### 1.2.1 NOT Gate

The simplest Reversible gate is NOT gate and is a 1\*1 gate. The Reversible 1\*1 gate is NOT Gate with zero Quantum Cost is as shown in the Figure 1.1. If input is A then output is  $P=\overline{A}$ 



Figure 1.1: NOT Gate

### 1.2.2 FEYNMAN Gate

The Feynman gate which is a 2\*2 gate and is also called as Controlled NOT and it is widely used for fan out purposes. The inputs (A, B) and outputs P=A, Q= A XOR B. It has Quantum cost one. It is the only 2x2 reversible gates available and is commonly used for fan out purposes [2].



# Figure 1.2: Feynman gate

### 1.2.3 TOFFOLI Gate

Toffoli gate is a 3\*3 gate 1with inputs (A, B, C) and outputs P=A, Q=B, R=AB XOR C. It has quantum cost of 5 and garbage outputs of 2. It is also called as CCNOT gate. It was invented by Tommaso Toffoli, is a universal reversible logic gate, which means that any reversible circuit can be constructed from Toffoli gates [6].





### **1.2.4 FREDKIN Gate**

Fredkin gate which is a 3\*3 gate with inputs (A, B, C) and outputs P=A, Q=A'B+AC, R=AB+A'C. It has Quantum cost 5 [6].





#### 1.2.5 DPG Gate

Double Peres gate which is a 4\*4 gate having inputs (A, B, C) and outputs P = A;Q = A XOR B; R = AB XOR C.



#### Figure 1.5: Double Peres Gate

It has Quantum cost four. Some of the 3x3 gates are designed for implementing some important combinational functions in addition to the basic gates. If the input is A, B, C, D then output is P, Q, R, S.

#### 1.2.6 DKG Gate

It is 4\*4 reversible gates that can work singly as a reversible Full adder and a reversible Full subtractor is shown in Figure 1.6. It can be verified that input pattern corresponding to a particular output pattern can be uniquely determined. If input A=0, the proposed gate works as a reversible Full adder, and if

input A=1, then it works as a reversible Full subtractor. Its Quantum cost is 6.



### Figure 1.6: DKG Gate

### **II. LITERATURE SURVEY**

Gordon. E. Moore in 1965 predicted that the numbers of components on the chip will double every 18 months. Initially he predicted only for 10 years but due to growth in the integrated circuit technology his prediction is valid till today

In the year 1994 Shor did a remarkable research work in creating an algorithm using reversibility for factorizing large number with better efficiency when compared to the classical computing theory. In 2010 Lihui Ni, Zhijin Guan, and Wenying Zhu described general approach to construct the Reversible full adder and can be extended to a variety of Reversible full adders with only two Reversible gates [4].

V. Rajmohan and Dr. V. Ranganathan implemented counters using reversible logic. The synchronous and asynchronous counter designs have the applications in building reversible ALU, reversible processor etc. This work forms an important move in construction of large and complex reversible sequential circuits for quantum computers [2].

# **III. PROPOSED WORK**

ALU has 2 parts, 1st which has Double Peres Gate as base of the circuit and is selected when select line s3 is zero. The operations performed here are buffer, AND, OR, NAND, NOR, EX-OR, and EX-NOR. 2nd part has DKG Gate as base of the circuit and is selected when select line s3 is one. The operations performed here are add, increment, 2's complement, set, subtract, decrement, not, and clear. The operations selected depending on various select lines are shown in the table 3.1.

| <b>S</b> 3 | S2 | S1 | SO | Operations     |
|------------|----|----|----|----------------|
| 0          | 0  | 0  | 0  | AND            |
| 0          | 0  | 0  | 1  | NAND           |
| 0          | 0  | 1  | 0  | OR.            |
| 0          | 0  | 1  | 1  | NOR            |
| 0          | 1  | 0  | 0  | BUFFER A       |
| 0          | 1  | 0  | 1  | EX-OR          |
| 0          | 1  | 1  | 0  | BUFFER B       |
| 0          | 1  | 1  | 1  | EX-NOR         |
| 1          | 0  | 0  | 0  | ADDITION       |
| 1          | 0  | 0  | 1  | INCREMENT      |
| 1          | 0  | 1  | 0  | 2'S COMPLEMENT |
| 1          | 0  | 1  | 1  | SET            |
| 1          | 1  | 0  | 0  | SUBSTRACTION   |
| 1          | 1  | 0  | 1  | DECREMENT      |
| 1          | 1  | 1  | 0  | NOT            |
| 1          | 1  | 1  | 1  | CLEAR          |

The 2:1 Multiplexer is designed using Fredkin gate when we make A as select line and (B & C) as input. B orC is selected depending on A is 0 or 1 respectively. The block diagram is shown in figure 3.1.



### Figure 3.1: 2x1 MUX

Figure 3.2 shows the block diagram of Reversible ALU. The primitive elements used in this reversible ALU are DKG gate, DPG gate 2:1mux which is designed using Fredkin gate, Feynman gate and Toffoli gate. Design of 1st1-bit ALU with 15 operations is shown in the figure 3.2.

L

International Research Journal of Engineering and Technology (IRJET) e-ISSN: 2395 -0056 Volume: 03 Issue: 05 | May-2016 www.irjet.net p-ISSN: 2395-0072



Figure 3.2: Block diagram of One bit ALU

Figure 3.4: Block diagram of Modified One bit ALU

L

e-ISSN: 2395 -0056 p-ISSN: 2395-0072

# **IV. SIMULATION RESULT**

The figure 4.1 shows the result for 1 bit ALU design for the input combinations 00, 01, 10 and 11.



Figure 4.1: Result for 1 bit ALU

The Figure 4.2 shows the result of first 4 operations (AND, NAND, OR and NOR). These operations are selected depending on select lines s3-s0 as shown in table 1.



Figure 4.2: Result for 1<sup>st</sup> 4-operations (AND, NAND, OR and NOR)

### Table 1

| <b>S</b> 3 | <b>S</b> 2 | S1 | <b>S</b> 0 | Operation | Input (A)                               | Input (B)                               | OUTPUT               |
|------------|------------|----|------------|-----------|-----------------------------------------|-----------------------------------------|----------------------|
|            |            |    |            |           |                                         |                                         |                      |
| 0          | 0          | 0  | 0          | AND       | 0000000000000000                        | 000000000000000000000000000000000000000 | 00000000000000000    |
|            |            |    |            |           | 0010001000011000                        | 0000001101101100                        | 0000001000001000     |
| 0          | 0          | 0  | 1          | NAND      | 000000000000000000000000000000000000000 | 000000000000000000000000000000000000000 | 11111111111111111111 |
|            |            |    |            |           | 0010001000011000                        | 0000001101101100                        | 1111110111110111     |
| 0          | 0          | 1  | 0          | OR        | 00000000000000000                       | 000000000000000000000000000000000000000 | 00000000000000000    |
|            |            |    |            |           | 0010001000011000                        | 0000001101101100                        | 0010001101111100     |
| 0          | 0          | 1  | 1          | NOR       | 00000000000000000                       | 000000000000000000000000000000000000000 | 1111111111111111111  |
|            |            |    |            |           | 0010001000011000                        | 0000001101101100                        | 1101110010000011     |

The Figure 4.3 shows the result of next 4 operations (BUFFER A, EX-OR, BUFFER B and EX-NOR). These operations are selected depending on select lines s3-s0 as shown in table 2.



Figure 4.3: Result for 2<sup>nd</sup> 4-operations (BUFFER A, EX-OR, BUFFER B and EX-NOR)

### Table 2

| <b>S</b> 3 | <b>S</b> 2 | <b>S</b> 1 | <b>S</b> 0 | Operation   | Input (A)                              | Input (B)                              | OUTPUT                                |
|------------|------------|------------|------------|-------------|----------------------------------------|----------------------------------------|---------------------------------------|
| 0          | 1          | 0          | 0          | BUFFER<br>A | 00000000000000000000000000000000000000 | 00000000000000000<br>0000001101101100  | 0000000000000000<br>0010001000011000  |
| 0          | 1          | 0          | 1          | EX-OR       | 00000000000000000<br>0010001000011000  | 00000000000000000<br>0000001101101100  | 00000000000000000<br>0010000101110100 |
| 0          | 1          | 1          | 0          | BUFFER<br>B | 00000000000000000<br>0010001000011000  | 00000000000000000000000000000000000000 | 0000000000000000<br>0000001101101100  |
| 0          | 1          | 1          | 1          | EX-NOR      | 00000000000000000<br>0010001000011000  | 00000000000000000<br>0000001101101100  | 1111111111111111<br>1101111010001011  |

The Figure 4.4 shows the result of next 4 operations (ADD, INCREMENT, 2'S COMPLEMENT and SET) these operations are selected depending on select lines s3-s0 as shown in table 3.



Figure 4.4: Result for 3<sup>rd</sup> 4-operations (ADD, INCREMENT, 2'S COMPLEMENT and SET)



Table 3

| <b>S</b> 3 | <mark>8</mark> 2 | <u>S1</u> | S0 | Operation  | Input (A)                               | Input (B)                               | OUTPUT                                  |
|------------|------------------|-----------|----|------------|-----------------------------------------|-----------------------------------------|-----------------------------------------|
| 1          | 0                | 0         | 0  | ADDITION   | 000000000000000000000000000000000000000 | 000000000000000000000000000000000000000 | 000000000000000000000000000000000000000 |
|            |                  |           |    |            | 0010001000011000                        | 0000001101101100                        | 0010010110000101                        |
| 1          | 0                | 0         | 1  | INCREMENT  | 000000000000000000000000000000000000000 | 000000000000000000000000000000000000000 | 11111111111111111                       |
|            |                  |           |    |            | 0010001000011000                        | 0000001101101100                        | 1101110111100111                        |
| 1          | 0                | 1         | 0  | 2'S        | 000000000000000000000000000000000000000 | 000000000000000000000000000000000000000 | 000000000000000000000000000000000000000 |
|            |                  |           |    | COMPLEMENT | 0010001000011000                        | 0000001101101100                        | 0010001000011000                        |
| 1          | 0                | 1         | 1  | SET        | 000000000000000000000000000000000000000 | 000000000000000000000000000000000000000 | 111111111111111111111111111111111111111 |
|            |                  |           |    |            | 0010001000011000                        | 0000001101101100                        | 111111111111111111111111111111111111111 |

The Figure 4.5 shows the result of next 4 operations (SUBSTRACTION, DECREMENT A, NOT and CLEAR) these operations are selected depending on select lines s3-s0 as shown in table 4.



Figure 4.5: Result for 4<sup>th</sup> 4-operations (SUBSTRACTION, DECREMENT A, NOT and CLEAR)

Table 4

| <b>S</b> 3 | <mark>8</mark> 2 | <b>S</b> 1 | S0 | Operation    | Input (A)         | Input (B)                               | OUTPUT                                  |
|------------|------------------|------------|----|--------------|-------------------|-----------------------------------------|-----------------------------------------|
| 1          | 1                | 0          | 0  | SUBSTRACTION | 00000000000000000 | 000000000000000000000000000000000000000 | 000000000000000000                      |
|            |                  |            |    |              | 0010001000011000  | 0000001101101100                        | 0001111010101011                        |
| 1          | 1                | 0          | 1  | DECREMENT A  | 00000000000000000 | 000000000000000000000000000000000000000 | 111111111111111111                      |
|            |                  |            |    |              | 0010001000011000  | 0000001101101100                        | 1101110111100111                        |
| 1          | 1                | 1          | 0  | NOT          | 00000000000000000 | 000000000000000000000000000000000000000 | 111111111111111111                      |
|            |                  |            |    |              | 0010001000011000  | 0000001101101100                        | 1101110111100111                        |
| 1          | 1                | 1          | 1  | CLEAR        | 00000000000000000 | 000000000000000000000000000000000000000 | 000000000000000000000000000000000000000 |
|            |                  |            |    |              | 0010001000011000  | 0000001101101100                        | 000000000000000000000000000000000000000 |

# **V. CONCLUSION**

In the present paper the proposed 32-bit ALU is designed using reversible logic gates such as Double Peres gate, DKG gate, Toffoli gate, Feynman gate. The multiplexers are designed using Fredkin gate. The main aim of the design in this paper is to improve the ALU.

| Parameters | 32-Bit ALU | 32-Bit   |
|------------|------------|----------|
|            |            | Modified |
|            |            | ALU      |
| Power      | 166.38mW   | 42.38mW  |
| Delay      | 44.312ns   | 40.512ns |
| Levels of  | 68%        | 67%      |
| logic      |            |          |
|            |            |          |

# VI. BIBLIOGRAPHY

- C. H. Bennett, "Logical reversibility of computation", IBM J. Research and Development, 17, pp. 525 – 532, November1973.
- [2] Feynman, R., "*Quantum mechanical computers*" Optics, News, and pp.: 11-20 11, 1985.
- [3] Fredkin, E. and T. Toffolli, "Conservative logic", Intl. J. Theoretical Phy., 21, pp.: 219-253, 1982.
- [4] Lihui Ni, Zhijin Guan, and Wenying Zhu, "A General Method of Constructing the Reversible Full-Adder", Third International Symposium on Intelligent Information Technology and Security Informatics, pp.109-113, 2010 5
- [5] R. Landauer, "*Irreversibility and heat generation in the computing process*", IBM J. Research and Development, 5(3), pp.: 183-191, 1961.
- [6] Toffoli T, *"Reversible computing", Technical Memo* MIT/LCS/TM-151, MIT Laboratory for Computer Science (February), 1980.

L

L