# Design and Implementation of High Speed Low Power and area Efficient Parallel Prefix Adder for Processor Applications 

${ }^{1}$ Y.Navya Sruthi, ${ }^{2}$ P.Sanjeeva Reddy<br>${ }^{1}$ MTECH (VLSI \&EMBD), Mallareddy College of Eng and Technology<br>${ }^{2}$ BE, M.TECH (IIT-M), MIEEE, FIETE Professor, Director- ECE DEPARTMENT, Dean, International Studies.


#### Abstract

Conventional adders like BINARY ADDITION, HALFADDER (HA), FULLADDER (FA), Ripple Carry Adder (RCA), Carry Look ahead Adder (CLA) and Carry Skip Adder (CSA) cannot satisfy optimization goals so, in this paper we proposed four types of parrell prefix adders like Kogge Stone Adder (KSA), Spanning Tree Adder (STA), Brent Kung Adder (BKA) and Sparse Kogge Stone Adder (SKA) to achieve high speed and area optimization. These adders are designed using (VHSIC) Hardware Description Language (HDL) and simulation, synthesis using Xilinx Integrated Software Environment (ISE) 13.2 Design Suite. These designs are implemented in Xilinx SPARTAN 3E Field Programmable Gate Arrays (FPGA).


Keywords: Kogge Stone Adder, Brent Kung Adder, Sparse Kogge Stone Adder, Spanning Tree Adder.

## INTRODUCTION

Adders are commonly found in the critical path of many building blocks of microprocessors and digital signal processing chips. Adders are essential not only for addition, but also for subtraction, multiplication, and division. Addition is one of the fundamental arithmetic operations. A fast and accurate operation of a digital system is greatly influenced by the performance of the resident adders. The most important for measuring the quality of adder designs in the past were propagation delay, and area. Adders are the basic building blocks of all arithmetic circuits; adders add two binary numbers and give out sum and carry as output. Basically we have two types of adders. The design of a binary adder begins by considering the process of addition in base 2 , In this example, the two numbers to be added, $1101+0110$, are written one above the other. The carries from one position to the next (called internal carries) are written above them. The result is the 5-bit number 10011. Interpreting the values of the binary numbers, this sum corresponds to the decimal addition $13+6=19$.From this example, we observe that the problem of adding two 4-bit numbers can be reduced to the problem of adding a column of two or three bits and passing the carry along to the next column. (For the sake of regularity, we can 11 in a 0 as the input carry in the rightmost column, so then each column is always the sum of three bits.) A circuit that adds a column of three bits is called a full-adder. (The name full-adder comes from the fact that it can be constructed by combining two half-adders, each of which adds only two bits, in a way that we shall see shortly.) We can design such a Circuit by making a table listing the outputs for all possible input combinations. Note that in each column there is a sum bit which is put at the bottom and a carry bit That is taken to the next column. So we need to specify two output bits for each input combination. Let us call the two data bits x and y .

A full-adder can be constructed from two half-adders and an OR gate. The explanation of why this works is as follows. (In this paragraph, + denotes addition, not the OR operation.) Consider the addition of $x+y+z$. This can be grouped as $(x+y)+z$ where $(x+y)$ represents the output of the halfadder that receives x and y . This partial sum is added to z by the other half-adder, yielding the complete sum bitS. As for C , consider that there are two possible ways to make $\mathrm{C}=1$ : rst, if $\mathrm{x}+\mathrm{y}=2$, then adding z can only make the total sum 2 or 3 , and either way $\mathrm{C}=1$. In this case, the rst halfadder's carry-out is a 1 . Second, if $x+y=1$, then C will be 1 only if $\mathrm{z}=1$ to make the total sum 2 . In

[^0]this case, the second half-adder's carry output will be 1 . Thus we see that $\mathrm{C}=1$ if and only if at least one of the half-adders produces a carry-out of 1 . This corresponds to the OR of the two partial carry bits. Now, to complete the design we need only construct the half-adder out of basic gates. The straightforward design methodology will not yield the simplest design. Instead we use some cleverness that will allow c and s to share some logic. With the full-adder design in hand, we can now construct an n-bit adder simply by stringing full-adders together. Each full-adder adds the bits in one bit position, say i , where $\mathrm{i}=0 ; 1 ;:: \% \mathrm{n} \quad 1$. Thus the i -th full-adder receives the data bits Ai and Bi from the two numbers to be added. It also receives a carry-in Ci from the full-adder in the next-lowernumbered bit position. It produces bit Si of the sum, and sends a carry-out $\mathrm{Ci}+1$ to the full-adder in the next-higher-numbered bit position. The full-adder for the least-significant bit, $\mathrm{i}=0$, is an exception: it receives its carry-in from an external source. The full-adder for the most-significant bit, i $=\mathrm{n} 1$, is also an exception: its Carry-out is sent out externally as the end-carry Cn Thus, improving the speed of addition will improve the speed of all other arithmetic operations. Accordingly, reducing the carry propagation delay of adders is of great importance. Different logic design approaches have been employed to overcome the carry propagation problem. One widely used approach employs the principle of carry look-ahead solves this problem. By calculating the carry signals in advance, based on the input signals. This type of adder circuit is called as carry look-ahead adder (CLA adder). It is based on the fact that a carry signal will be generated in two cases: when both bits Ai and Bi are 1, or when one of the two bits is 1 and the carry-in (carry of the previous stage) is 1 . To understand the carry propagation problem, let's consider the case of adding two n-bit numbers Aand B. Generates all the P \& G signals. Four sets of P \& G logic (each consists of an XOR gate and an AND gate). Output signals of this level (P's \& G's) The Carry Look-Ahead (CLA) logic block which consists of four 2level Implementation logic circuits. It generates the carry signals ( $\mathrm{C} 1, \mathrm{C} 2, \mathrm{C} 3$, and C 4 ) as defined by the above expressions. Output signals of this level ( $\mathrm{C} 1, \mathrm{C} 2, \mathrm{C} 3$, and C 4$)$ Four XOR gates which generate the sum signals $(\mathrm{Si})(\mathrm{Si}=\mathrm{Pi} \oplus \mathrm{Ci})$. Output signals of this level ( $\mathrm{S} 0, \mathrm{~S} 1, \mathrm{~S} 2$, and S 3 ).

## PARALLEL-PREFIX ADDER STRUCTURE

PPA's basically consists of 3 stages

- Pre computation
- Prefix stage
- Final computation


In pre computation stage, propagates and generates are Computed In the prefix stage, The black cell (BC) and gray cell (GC) generates only the building prefix structures. Final computation, the sum and carryout are the final output.

## BLACK CELL AND GRAY CELL



In black cell having four inputs and two outputs propagation means and operation and generation means and-or operation.

In gray cell having three inputs and one output here generation means and-or operation.

## RIPPLE CARRY ADDER


full adder


## 16 BIT SPARSE KOGGE-STONE ADDER

In this adder initially pre computation stage we are doing propagation and generation operations. After that stage 1 used 6 black cells. Stage2 used 3 black cells. Stage 3 used. 2 black cell and one gray cell.stage4 used two gray cells. Then apply ripple carry adder operation.
Y.Navya Sruthi \& P. Sanjeeva Reddy "Design and Implementation of High Speed Low Power and area Efficient Parallel Prefix Adder for Processor Applications"


## 16 BIT SPANNING TREE ADDER

In this adder initially pre computation stage we are doing propagation and generation operations. After that stage 1 used 6 black cells. Stage 2 used 3 black cells. Stage3 used. 2 black cells and one gray cell.stage 4 used two gray cells and one black cell.stage5 used one gray cell Then applies ripple carry adder operation.


## 16 BIT KOGGE STONE ADDER

In this adder initially pre computation stage we are doing propagation and generation operations. After that stage 1 used 14 black cells and one gray cell. Stage 2 used 12 black cells and two gray cells. Stage3 used. 8 black cells and 4 gray cell. Stage4 used 8 gray cells Then final computing operation.
Y.Navya Sruthi \& P. Sanjeeva Reddy "Design and Implementation of High Speed Low Power and area Efficient Parallel Prefix Adder for Processor Applications"


## 16 BIT BRENT KUNG ADDER

In this adder initially pre computation stage we are doing propagation and generation operations. After that stage 1 used 7 black cells and one gray cell. Stage 2 used 3 black cells and one gray cell. Stage 3 used. 1 black cells and one gray cell.stage 4 used one gray cell.stage 5 used one gray cell.stage 6 Used 3 gray cells. Stage 7 used 7 gray cells Then final computing operation.


- Half Adder.
- Full Adder.
Y.Navya Sruthi \& P. Sanjeeva Reddy "Design and Implementation of High Speed Low Power and area Efficient Parallel Prefix Adder for Processor Applications"


## SIMULATION WAVEFORMS AND SCHEMATIC DIAGRAMS

## Brent Kung adder



## Kogge Stone Adder



Spanning Tree Adder



## CONCULSION

In this studied about prefix adder's concept. Here we have four types of prefix adders. Those are Brent Kung adder, Kogge stone adder, sparse Kogge stone adder, spanning tree adder are simulated and synthesize using Xilinx 13.2 and hardware kit Spartan 3e.

## REFERENCES

[1] David H.K.Hoe, Chris Martinez and Sri Jyothsna Vundavalli", Design and Characterization of Parallel Prefix Adders using FPGAs", 2011 IEEE 43rd Southeastern Symposium in pp. 168-172, 2011.
[2] N. H. E. Weste and D. Harris, CMOS VLSI Design, 4th edition, Pearson-Addison-Wesley, 2011.
[3] R. P. Brent and H. T. Kung, "A regular layout for parallel adders," IEEE Trans. Comput., vol. C31, pp. 260-264, 1982.
[4] D. Harris, "A Taxonomy of Parallel Prefix Networks," in Proc. 37th Asilomar Conf. Signals Systems and Computers, pp. 2213-7, 2003.
[5] P. M. Kogge and H. S. Stone, "A Parallel Algorithm for the Efficient Solution of a General Class of Recurrence Equations," IEEE Trans. on Computers, Vol. C-22, No 8, August 1973.
[6] D. Gizopoulos, M. Psarakis, A. Paschalis, and Y. Zorian, "Easily Testable Cellular Carry Lookahead Adders," Journal of Electronic Testing: Theory and Applications 19, 285-298, 2003.
[7] T. Lynch and E. E. Swartzlander, "A Spanning Tree Carry Lookahead Adder," IEEE Trans. on Computers, vol. 41, no. 8, pp. 931-939, Aug. 1992.
[8] Beaumont-Smith, A, Cheng-Chew Lim ,"Parallel prefix adder design", Computer Arithmetic, 2001. Proceedings. 15th IEEE Symposium,pp. 218 - 225,2001.M. Young, The Technical Writer's Handbook. Mill Valley, CA: University Science, 1989
[9] K. Vitoroulis and A. J. Al-Khalili, "Performance of Parallel Prefix Adders Implemented with FPGA technology," IEEE Northeast Workshop on Circuits and Systems, pp. 498-501, Aug. 2007. 172.
[10] S. Xing and W. W. H. Yu, "FPGA Adders: Performance Evaluation and Optimal Design," IEEE Design \& Test of Computers, vol. 15, no. 1, pp. 24-29, Jan. 1998

## AUTHOR' BIOGRAPHY


Y.Navya Sruthi, received the B.Tech. degree in Electronics and Communication Engineering from VISHNU INSTITUTE OF TECHNOLOGY,Bhimavaram in 2012, with the first class in Distinction. She is currently pursuing the M.Tech in specialization of VLSI AND EMBEDDED SYTEMS with the Department of Electronics And Communication Engineering in MALLAREDDY COLLEGE OF ENGINEERING AND TECHNOLOGY, Hyderabad.
P.Sanjeeva Reddy, received the B.E degree in Electronics and communication
 engineering, the M.Tech. Degree in Electronics and communication engineering from the University of Indian Institute Of Technology Madras. He is the Director of Electronics and Communication Engineer Department, MALLAREDDY COLLEGE OF ENGINEERING AND TECHNOLOGY, Hyderabad. He is the Member of Institute of Electrical and Electronics Engineer (MIEEE) , and have a membership in Fellow Of Institute Of Electronics and Telecommunication Engineers (FIETE)., He was with the Department of Electronics and Communication Engineer, MALLAREDDY COLLEGE OF ENGINEERING AND TECHNOLOGY, Hyderabad, where he is currently a Professor.


[^0]:    *Address for correspondence:
    y.navyasruthi@gmail.com

