# INTERNATIONAL JOURNAL FOR RESEARCH IN APPLIED SCIENCE & ENGINEERING TECHNOLOGY Volume: 3 Issue: III Month of publication: March 2015 DOI: www.ijraset.com Call: © 08813907089 E-mail ID: ijraset@gmail.com Volume 3 Issue III, March 2015 www.ijraset.com Volume 3 Is IC Value: 13.98 ISSN: 2321-9653 ### International Journal for Research in Applied Science & Engineering Technology (IJRASET) ## **Analysis of Self Checking Additional Adder Circuit in Combinational Circuits** Abirami SB<sup>1</sup>, Manoj K<sup>2</sup>, Maruthupandian C<sup>3</sup>, Rajesh K<sup>4</sup> 1,2,3</sup> Final year ECE, <sup>4</sup>Assistant Professor ECE 1,2,3,4</sup> Knowledge Institute Of Technology, Salem, India Abstract— Digital computers perform variety of information tasks; among the functions encountered are the various arithmetic operations. The most basic arithmetic operation is the addition and subtraction of two or more binary digits. In processors adders are used not only in the arithmetic logic units, but also in other parts of the processor, where they are used to calculate addresses, table indices and similar operations. The basic building block of many complex computational systems is the full adder. VLSI integrates a large system into a single chip. Self checking scheme is becoming an important design technique to full fill the requirements of modern computer systems with full reliability. The main aim of this paper is to provide the output of ripple carry adder without any error even when any one of the full adder is fault. The proposed system is built using VHDL, simulated using Xilinx ISE 12.1 and implemented using Spartan-3E FPGA and ALTERA Universal kit. This will fit the specified functional requirements and finds a solution to overcome the problem of fault in any one full adder. Keywords—Full adder, self-checking, modified adder, modified subtractor, combinational circuit, multiplexer. #### I. INTRODUCTION For any large combinational circuit there are generally two approaches to design. Taking simpler circuits and replicates them or designs the complex circuit as a complex device. Both the circuits allow spending less time to design and more time for signals to propagate through the transistors. So attempt to replace portions of the circuit that are too slow and faulty. It is possible to create a logical circuit using multiple full adders to add N-bit numbers. Each full adder inputs a Cin, which is the Cout of the previous adder. This kind of adder is called a ripple-carry adder, since each carry bit "ripples" to the next full adder. Note that the first (and only the first) full adder may be replaced by a half adder (under the assumption that Cin = 0). The layout of a ripple-carry adder is simple, which allows for fast design time; however, the ripple-carry adder is relatively slow, since each full adder must wait for the carry bit to be calculated from the previous full adder. The gate delay can easily be calculated by inspection of the full adder circuit. Each full adder requires three levels of logic. In a 32-bit ripple-carry adder, there are 32 full adders, so the critical path (worst case) delay is 2 (from input to carry in first adder) + 31 \* 3 (for carry propagation in later adders) = 95 gatedelays. The general equation for the worst-case delay for an n-bit carry-ripple adder is $$T_{CRA}(n) = T_{HA} + (n-1)T_C + T_S$$ = $T_{FA} + (n-1)T_C$ = $6D + (n-1)T_C = (n+2).2D$ --(1) The delay from bit position 0 to the carry-out is a little different: $$T_{CRA[0:C_{out}]} = T_{HA} + nT_C = 3D + n.2D - (2)$$ The carry-in must travel through n carry-generator blocks to have an effect on the carry-out $$T_{CRA[C_0:C_{out}]}(n) = n..T_C = n.2D -- (3)$$ A design with alternating carry polarities and optimized AND-OR-Invert gates can be about twice as fast. To reduce the computation time, engineers devised faster ways to add two binary numbers by using carry-look ahead adders. They work by creating two signals (P and G) for each bit position, based on whether a carry is propagated through from a less significant bit position (at least one input is a '1'), generated in that bit position (both inputs are '1'), or killed in that bit position (both inputs are '0'). In most cases, P is simply the sum output of a half adder and G is the carry output of the same adder. After P and G are generated the carries for every bit position are created. Some advanced carry-look ahead architectures are the Manchester carry chain, Brent–Kung adder, and the Kogge–Stone adder. For all the adder circuit the combination of half adder and full adder has been used. Some other multi-bit adder architectures break the adder into blocks. It is possible to vary the length of these blocks based on the propagation delay of the circuits to optimize computation time. These block based adders include the carry-skip (or carry- www.ijraset.com Volume 3 IC Value: 13.98 ISSN: 2321-9653 ### International Journal for Research in Applied Science & Engineering Technology (IJRASET) bypass) adder which will determine P and G values for each block rather than each bit, and the carry select adder which pregenerates the sum and carry values for either possible carry input (0 or 1) to the block, using multiplexers to select the appropriate result when the carry bit is known. Other adder designs include the carry-select adder, conditional sum adder, carry-skip adder, and carry-complete adder. #### II. EXISTING SYSTEM #### A. One Bit Full Adder A one-bit full adder is a combinational circuit that performs the arithmetic sum of three bits. It consists of three inputs a, b and cin and two outputs S and Cout [3] as illustrated in Fig. 1.Expressions for S and Cout are given in (1) and (2) Fig1.A full adder block $$S = a \oplus b \oplus cin--(1)$$ $$Cout=a.b+b.cin+cin .a-- (2)$$ #### B. Full Subtractor A one-bit full subtractor is a combinational circuit that performs subtraction of three bits. It has three inputs are X, Y and Z and the two outputs are D (difference) and B (borrow) as illustrated in Fig.2. Expressions for D and B are given in (1) and (2) Fig 2.A full subtractor block $$D = X \oplus Y \oplus Z$$ $$B = \overline{X} \cdot (Y \oplus Z) + Y \cdot Z$$ #### C. Multiplexer A multiplexer (or mux) is a device that selects one of several analog or digital input signals and forwards the selected input into a single line. A multiplexer of $2^n$ inputs has n select lines, which are used to select which input line to send to the output. Multiplexers are mainly used to increase the amount of data that can be sent over the network within a certain amount of time and bandwidth. A multiplexer is also called a data selector. Fig3.A One Bit Multiplexer www.ijraset.com Volume 3 Is IC Value: 13.98 ISSN: 2321-9653 ### International Journal for Research in Applied Science & Engineering Technology (IJRASET) #### D. Four Bit Ripple Carry Adder A simple ripple carry adder (RCA) is a digital circuit that produces the arithmetic sum of two binary numbers. It can be constructed with full adders connected in cascade, with the carry output from each full adder connected to the carry input of the next full adder in the chain. Fig. 2 shows the interconnection of four full adder (FA) circuits to provide a four bit ripple carry adder. Fig4. A Four bit ripple carry adder Notice from Fig. 2 that the input is from the right side because the first cell traditionally represents the least significant bit (LSB). Bits a0 and b0 in the figure represent the least significant bits of the numbers to be added. The sum output is represented by the bits S0 - S3. The main problem with this type of adder is the delays needed to produce the carry out signal and the most significant bit. These delays increase with the increase in the number of bits to be added. #### E. Four Bit Ripple Borrow Subtractor A ripple-borrow subtract or can be composed of a cascade of full subtractor. Two binary numbers A and B are subtracted from right to left, creating a difference and a borrow at the outputs of each full subtract or for each bit position. Fig. 5 shows the interconnection of four full subtractor (FS) circuits to provide a four bit ripple borrow subtractor. Fig5.A Four bit ripple borrow subtractor #### III. PROPOSED SYSTEM The proposed system provides the modified structure of the four bit ripple carry adder, four bit borrow subtractor and four bit 2's complement borrow subtractor. The working principle and operation of the proposed system is similar as it before expect the number of adder and multiplexer increases in both the adder and subtractor. These is because the fault any full adder/subtractor is replaced with another adder /subtractor circuit. With this we can able to rectify the fault easily Fig6.A Modified Four bit ripple carry adder www.ijraset.com Volume 3 IC Value: 13.98 ISSN: 2321-9653 ### International Journal for Research in Applied Science & Engineering Technology (IJRASET) Fig 7.A Modified Four bit ripple borrow subtractor Fig 8.A Modified Four bit ripple borrow subtractor (2's complement) #### IV. SIMULATION RESULTS AND PERFORMANCE COMPARISON Even though the number of adder and mux in the modified binary adder and Subtractor architecture increases, any fault in one of the full adder can be replaced with another adder circuit. With this modified structure, we can able to rectify the fault easily. Fig shows the simulation result for 4-bit ripple carry adder done with the help of Xilinx12.1 and implemented in Spartan 3E FPGA board. Fig 9.simulation of 4-bit ripple carry adder Fig shows the timing details for 4 bit ripple carry adder done with the help of Xilinx12.1. www.ijraset.com Volume 3 IC Value: 13.98 ISSN: 2321-9653 ### International Journal for Research in Applied Science & Engineering Technology (IJRASET) | elay: | 8.959ns | (Levels o | f Logic | = 6) | |--------------------|-----------|-----------|---------|--------------------------| | Source: | b<0> (PA) | D) | | | | Destination: | cout (PA | D) | | | | Data Path: b<0> to | cout | | | | | | | Gate | Net | | | Cell:in->out | fanout | Delay | Delay | Logical Name (Net Name) | | IBUF:I->O | 2 | 1.106 | 0.532 | b 0 IBUF (b 0 IBUF) | | LUT3:10->0 | 2 | 0.612 | 0.449 | a1/cout1 (c<0>) | | LUT3:I1->0 | 2 | 0.612 | 0.449 | a2/cout1 (c<1>) | | LUT3:I1->0 | 2 | 0.612 | 0.449 | a3/cout1 (c<2>) | | LUT3: I1->0 | 1 | 0.612 | 0.357 | a4/cout1 (cout OBUF) | | OBUF: I->O | | 3.169 | | cout_OBUF (cout) | | Total | | 8.959ns | (6.723 | ns logic, 2.236ns route) | | | | | (75.0% | logic, 25.0% route) | Fig 10.Timing details of 4-bit ripple carry adder Fig shows the simulation result for 4-bit ripple borrow subtractor done with the help of Xilinx12.1 and implemented in Spartan 3E FPGA board. Fig 11.simulation of 4-bit ripple borrow subtractor Fig shows the timing details for 4 bit ripple borrow subtractor done with the help of Xilinx12.1. | Delay:<br>Source:<br>Destination: | 9.208ns<br>bin (PAD)<br>bout (PAI | | f Logic | : = 6) | |-----------------------------------|-----------------------------------|---------|---------|---------------------------| | Data Path: bin to | bout | | | | | | | Gate | Net | | | Cell:in->out | fanout | Delay | Delay | Logical Name (Net Name) | | | | | | | | IBUF:I->O | 2 | 1.106 | 0.532 | bin_IBUF (bin_IBUF) | | LUT3:10->0 | 2 | 0.612 | 0.532 | a1/bout1 (c<0>) | | LUT3:10->0 | 2 | 0.612 | 0.532 | a2/bout1 (c<1>) | | LUT3:10->0 | 2 | 0.612 | 0.532 | a3/bout1 (c<2>) | | LUT3:10->0 | 1 | 0.612 | 0.357 | a4/bout1 (bout OBUF) | | OBUF: I->O | | 3.169 | | bout_OBUF (bout) | | Total | | 9.208ns | (6.723 | ans logic, 2.485ns route) | | | | | (73.0% | logic, 27.0% route) | | | | | | | Fig 12. Timing details of 4-bit ripple carry adder Fig shows the simulation result for modified 4-bit ripple carry adder done with the help of Xilinx12.1 and implemented in Spartan 3E FPGA board. | Name | Value | mlm | 1,999,994 ps | 1,999,995 ps | 1,999,996 ps | 1,999,997 ps | 1,999,998 ps | 1,999,999 ps | |------------------------|----------------|-----|--------------|--------------|----------------|--------------|--------------|--------------| | ▶ <b>¾</b> b[3:0] | 0101 | | | | 0101 | | | | | le cin | 0 | | | | | | | | | ond[4:0] | 10000 | | | | 10000 | | | | | ► Martin Sum[3:0] | 1111 | | | | 1111 | | | | | le Cout | 0 | | | | | | | | | • 🍕 ca[4:0] | 00000 | | | | 00000 | | | | | ▶ <b>₩</b> s[4:0] | 11111 | | | | 11111 | | | | | ▶ <b>№</b> f[9:0] | 1001100000 | | | | 1001100000 | | | | | ■ sel1[4:0] | 10000 | | | | 10000 | | | | | ▶ 👹 sel[2:0] | 111 | | | | 111 | | | | | sel2[3:0] | 0000 | | | | 0000 | | | | | ▶ <b>W</b> text[110:0] | ADDERS 1,2,3,4 | | | | ADDERS 1,2,3,4 | | | | | ▶ 👹 text1[110:0] | GOOD CONDITION | | | | GOOD CONDITION | | | | Fig 13.simulation of modified4-bit ripple carry adder www.ijraset.com Volume 3 IC Value: 13.98 ISSN: 2321-9653 ### International Journal for Research in Applied Science & Engineering Technology (IJRASET) Fig shows the timing details for modified 4 bit ripple carry adder done with the help of Xilinx12.1. | Delay: | 8.304ns | (Levels o | f Logic | = 6) | |-------------------|-----------|-----------|---------|--------------------------| | Source: | b<1> (PAI | D) | | | | Destination: | Cout (PAI | D) | | | | Data Path: b<1> t | o Cout | | | | | | | Gate | Net | | | | fanout | | | Logical Name (Net Name) | | IBUF:I->O | | | | b 1 IBUF (b 1 IBUF) | | LUT4:10->0 | | | | Cout31 (Cout3) | | MUXF5: I1->0 | 3 | 0.278 | 0.481 | Cout3 f5 (Cout bdd8) | | LUT3:12->0 | | | | Cout SWO (N6) | | LUT4:12->0 | | | | Cout (Cout OBUF) | | OBUF: I->O | | 3.169 | | Cout_OBUF (Cout) | | Total | | 8.304ns | (6.389 | ns logic, 1.915ns route) | | | | | (76.9% | logic, 23.1% route) | Fig 14. Timing details of modified 4-bit ripple carry adder Fig shows the simulation result for 4 bit ripple borrow subtractor done with the help of Xilinx12.1 and implemented in Spartan 3E FPGA board. | Name | Value | <br>1,999,994 ps | 1,999,995 ps | 1,999,996 ps | 1,999,997 ps | 1,999,998 ps | 1,999,999 ps | 2, | |-------------------------|----------------|------------------|--------------|----------------|--------------|--------------|--------------|----| | ▶ <b>™</b> a[3:0] | 1111 | | | 1111 | | | | 3 | | ▶ <b>™</b> b[3:0] | 0000 | | | 0000 | | | | 3 | | le bin | 0 | | | | | | | Ш | | cond(4:0) | 01000 | | | 01000 | | | | | | ▶ 🌃 Dif[3:0] | 1111 | | | 1111 | | | | 1 | | le Bor | 1 | | | | | | | 1 | | ► <b>™</b> ca(4:0) | 00000 | | | 00000 | | | | d | | ▶ <b>™</b> s[4:0] | 11111 | | | 11111 | | | | 1 | | ► <b>™</b> f[9:0] | 1010100000 | | | 1010100000 | | | | 5 | | ▶ <b>■</b> sel1[4:0] | 01111 | | | 01111 | | | | 1 | | ▶ <b>™</b> sel[2:0] | 000 | | | 000 | | | | 1 | | ▶ <b>™</b> sel2[3:0] | 0001 | | | 0001 | | | | 1 | | ► National text[110:0] | RACTOR 2,3,4,5 | | | RACTOR 2,3,4,5 | | | | d | | ▶ <b>■</b> text1[110:0] | GOOD CONDITION | | | GOOD CONDITION | | | | 1 | Fig 15.simulation of modified 4-bit ripple borrow subtractor Fig shows the timing details for modified 4 bit ripple borrow subtractor done with the help of Xilinx12.1. | t Name) | |---------------| | UF) | | >111) | | <1> bdd0) | | 6) | | OBUF) | | 1>) | | route)<br>te) | | | Fig 16. Timing details of modified 4-bit ripple borrow subtractor Fig shows the simulation result for modified 4-bit ripple borrow subtractor 2's complement done with the help of Xilinx12.1 and implemented in Spartan 3E FPGA board. | | | ı | | | | | | | 1 | |----------------------|----------------|--------|--------------|--------------|----------------|--------------|--------------|--------------|-----| | Name | Value | and an | 1,999,994 ps | 1,999,995 ps | 1,999,996 ps | 1,999,997 ps | 1,999,998 ps | 1,999,999 ps | 2,0 | | ▶ 🕌 a[3:0] | 1111 | | | | 1111 | | | | Т | | ▶ 🌃 b[3:0] | 0000 | | | | 0000 | | | | | | la bin | 0 | | | | | | | | 1 | | ▶ 🎳 cond[4:0] | 01000 | | | | 01000 | | | | 1 | | ▶ 🌃 Dif[3:0] | 1111 | | | | 1111 | | | | | | le Bor | 1 | | | | | | | | 1 | | ▶ 🎇 ca[4:0] | 00000 | | | | 00000 | | | | | | ▶ 🎇 s[4:0] | 11111 | | | | 11111 | | | | | | ▶ 🎇 f[9:0] | 1010100000 | | | | 1010100000 | | | | 1 | | ▶ 👹 sel1[4:0] | 01111 | | | | 01111 | | | | | | ▶ 👹 sel[2:0] | 000 | | | | 000 | | | | 1 | | ▶ <b>№</b> sel2[3:0] | 0001 | | | | 0001 | | | | 1 | | ▶ 👹 text[110:0] | RACTOR 2,3,4,5 | | | | RACTOR 2,3,4,5 | | | | 1 | | ▶ 👹 text1[110:0] | GOOD CONDITION | | | | GOOD CONDITION | | | | | | | | ı | | | | | | | 1 | Fig 17.simulation of modified 4-bit ripple borrow subtractor www.ijraset.com Volume 3 Issue III, March 2015 IC Value: 13.98 ISSN: 2321-9653 ### International Journal for Research in Applied Science & Engineering Technology (IJRASET) Fig shows the timing details for modified 4 bit ripple borrow subtractor 2's complement done with the help of Xilinx12.1. | lay: | 8.328ns | (Levels o | f Logic | ; = 6) | |-------------------|-----------|-----------|---------|--------------------------| | Source: | bin (PAD) | | | | | Destination: | Dif<1> (1 | PAD) | | | | Data Path: bin to | Dif<1> | | | | | | | Gate | Net | | | Cell:in->out | fanout | Delay | Delay | Logical Name (Net Name) | | IBUF:I->O | 5 | 1.106 | 0.690 | bin IBUF (bin IBUF) | | LUT4:10->0 | 1 | 0.612 | 0.000 | Dif<1>112 (Dif<1>111) | | MUXF5:10->0 | 2 | 0.278 | 0.532 | Dif<1>11 f5 (Dif<1> bdd0 | | LUT4:10->0 | 1 | 0.612 | 0.360 | Dif<1>160 SW0 (N6) | | LUT4:13->0 | 1 | 0.612 | 0.357 | Dif<1>160 (Dif 1 OBUF) | | OBUF: I->O | | 3.169 | | Dif 1 OBUF (Dif<1>) | Fig 18. Timing details of modified 4-bit ripple borrow subtractor | TARLE1 | COMPARISON OF | ADDER AND | SUBTRACTOR | |--------|---------------|-----------|------------| | | | | | | Adder /<br>Subtractor | Delay | Auto<br>Correction | |---------------------------------|---------|--------------------| | 4 bit adder | 8.959ns | No | | 4 bit<br>Subtractor | 9.208ns | No | | Modified 4<br>bit adder | 8.304ns | Yes | | Modified 4<br>bit<br>Subtractor | 8.328ns | Yes | #### V. CONCLUSION The proposed full adder/subtractor system has been simulated and results are compared with existing full adder/subtractor system in terms of performance and delay. This proposed adder/subtractor system is having improvement in both of these aspects. The system is designed in auto correction format which is done with the help of extra one full adder/subtractor and multiplexer. #### VI. ACKNOWLEDGMENT We would like to thanks to the professor and Head of Department, Mrs.Dr.N.Santhiyakumari, Knowledge institute of technology, Salem and to the assistant Professor Mr.K.Rajesh, Kiot, Salem for his valuable help and guidance. #### REFERENCES - [1] Z. Deng and A. M. Niknejad. (2010). The Speed-Power Trade-off in the Design of CMOS True-Single-Phase-Clock Dividers. IEEE Journal of Solid-State Circuits, Vol. 45, no. 11, pp. 2457–2465. - [2] J. N. Soares, JR and W. A. M. Van Noije. (1999). A 1.6-Ghz Dual Modulus Prescaler using the Extended True-Single Phase Clock CMOS Circuit Technique (E-TSPC). IEEE Journal of Solid-state circuits, Vol. 34, no. 1, pp.97–102. - [3] A. Keshavarzi, K. Roy, and C. F. Hawkins. (1997). Intrinsic Leakage in Low Power Deep Submicron CMOS ICs. In Proc. International Test Conference, pp. 146–155. - [4] S.M. Kang, Y. Leblebici (2003). CMOS Digital Integrated Circuits Analysis and Design. Third Edition:Tata McGraw Hill. - [5] M. V. Krishna, M. A. Do, K. S. Yeo, C. Boon, and W. M. Lim (2010). Design and Analysis of Ultra Low Power True Single Phase Clock CMOS 2/3 Prescaler. IEEE Transactions: Circuits System. I, Reg. Papers, vol. 57, No. 1,pp. 72–82. - [6] H. J. M. Veendrick (1984). Short-Circuit Dissipation of Static CMOS Circuitry and its Impact on the Design of Buffer Circuits. IEEE Journal of Solid-State Circuits, Vol. SC-19, No. 4. - [7] X.-P. Yu, M. A. Do, W. M. Lim, K. S. Yeo, and J. G. Ma (2006). Design and Optimization of the Extended True Single-Phase Clock-Based Prescaler. IEEE Transactions: Microwave Theory Techniques, Vol. 54, no. 11, pp. 3828–3S835. - [8] Yin-Tsung Hwang and Jin-Fa Lin (2012). Low Voltage and Low Power Divide by 2/3 Counter Design using Pass Transistor Logic Circuit Technique. IEEE Transaction: Circuits System, I, Reg. Papers, Vol. 20, no. 9, pp. 1063–8210. Volume 3 Issue III, March 2015 www.ijraset.com Volume 3 I IC Value: 13.98 ISSN: 2321-9653 ### International Journal for Research in Applied Science & Engineering Technology (IJRASET) - [9] H. T. Bui, Y. Wang, and Y. Jiang, "Design and analysis of low-power 10-transistor full adders using XOR-XNOR gates," IEEE Transactions Circuits Systems II, Analog Digital Signal Process, vol. 49, no. 1, pp. 25–30, Jan. 2002. - [10] S. Goel. A. Kumar, M. A. Bayoumi, "Design of robust, energy efficient full adders for deep sub micrometer design using hybrid-CMOS logic style" IEEE Transactions on Very Large Scale Integration (VLSI) Systems, vol.14, no.12, pp.1309-1321, Dec. 2006. - [11] C Senthilpari, "A Low-power and High-performance Radix-4Multiplier Design Using a Modified Pass-transistor Logic Technique" IETE Journal of Research, Vol: 57, Issue No.: 2, Page: 149-155, May 2011. - [12] C.ChanneGowda Low-Power 1-Bit Full-Adder Cell Using Modified Pass Transistor Logicet al, / (IJCSIT) International Journal of Computer Science and Information Technologies, Vol. 4 (3), 2013, 489-49. - [13] PallaviSaxena, UrvashiPurohit, Priyanka Joshi. Analysis of Low Power, Area- Efficient and High Speed Fast Adder. International Journal of Advanced Research in Computer and Communication Engineering Vol. 2, Issue 9, September 2013. - [14] Senthilkumar.A, Kousalyadevi.A. "VLSI Implementation Of An Efficient Carry Select Adder Architecture". International Journal of Advance Research In Science And Engineering IJARSE, Vol. No. 2, Issue No. 4, April, 2013 ISSN-2319-8354(E)88. 10.22214/IJRASET 45.98 IMPACT FACTOR: 7.129 IMPACT FACTOR: 7.429 ## INTERNATIONAL JOURNAL FOR RESEARCH IN APPLIED SCIENCE & ENGINEERING TECHNOLOGY Call: 08813907089 🕓 (24\*7 Support on Whatsapp)