International Journal of Engineering Science and Innovative Technology (IJESIT) Volume 3, Issue 4, July 2014 # Fast Arithmetic Operations with QSD using Verilog HDL M Naveen krishna<sup>1</sup> and T Ravisekhar<sup>2</sup> Abstract— In this paper a higher radix number system like quaternary signed digit number system (QSD) is used for faster and more accurate arithmetic operations. In the binary number system, the computation speed is limited by formation and propagation of carry especially as the number of bits increases. By using Quaternary Signed Digit Number System it is possible to perform carry free addition, borrow free subtraction and multiplication. A QSD number system's digit is represented by a number from -3 to 3. Carry free addition and borrow free subtraction can be performed for higher number of bits with constant delay and less complexity. Design is simulated and synthesized using Xilinx 12.2. Index Terms — Carry free addition, Borrow free Subtraction, Multiplication, QSD, Verilog HDL. #### I. INTRODUCTION These high performance arithmetic's are essential since the speed of the digital processor depends heavily on the speed of the adders used is the system. Also, it serves as a building block for synthesis of all other arithmetic operations. Adders are most commonly used in various electronic applications e.g. Digital signal processing in which adders are used to perform various algorithms like FIR, IIR etc. In past, the major challenge for VLSI designer is to reduce area of chip by using efficient optimization techniques. Then the next phase is to increase the speed of operation to achieve fast calculations like, in today's microprocessors millions of instructions are performed per second. Speed of operation is one of the major constraints in designing DSP processors [12]. The redundancy associated with signed-digit numbers offers the possibility of carry free addition. The redundancy provided in signed-digit representation allows for fast addition and subtraction because the sum or difference digit is a function of only the digits in two adjacent digit positions of the operands for a radix greater than 2, and 3 adjacent digit positions for a radix of 2. Thus, the add time for two redundant signed-digit numbers is a constant independent of the word length of the operands, which is the key to high speed computation. The quaternary logic uses 0, 1, 2 and 3 logic levels. The advantage of carry free addition offered by QSD numbers is exploited in designing a fast adder circuit. Additionally, adder designed with QSD number system has a regular layout which is suitable for VLSI implementation which is the great advantage over the RBSD adder. An Algorithm for design of QSD adder is proposed. This algorithm is used to write the VHDL code for QSD adders. VHDL codes for QSD adder is simulated and synthesized and the timing report is generated. The timing report gives the delay time produced by the adder structure. Binary signed-digit numbers are known to allow limited carry propagation with a somewhat more complex addition process requiring very large circuit for implementation [5]. A special higher radix-based (QSD) representation of binary signed-digit numbers not only allows carry-free addition and borrow-free subtraction but also offers other important advantages such as simplicity in logic and higher storage density [13]. #### Theorem of Representation It offers the advantage of reduced circuit complexity both in terms of transistor count and interconnections. QSD number uses 25% less space than BSD to store number [10] and it can be verified by the theorem described as under- QSD numbers save 25% storage compared to BSD: To represent a numeric value N $\mid \log 4N \mid$ number of QSD digits and 3 $\mid \log 4N \mid$ binary bits are required while for the same $\mid \log 2N \mid$ BSD digits and 2 $\mid \log 2N \mid$ binary bits are required in BSD representation. Ratio of number of bits in QSD to BSD representation for an arbitrary number N is, $\frac{3|\log 4N|}{2|\log 2N|}$ which roughly equals to $\frac{3}{4}$ . Therefore, QSD saves $\frac{1}{4}$ of the storage used by BSD. So the proposed QSD adder is better than RBSD adder in ## International Journal of Engineering Science and Innovative Technology (IJESIT) Volume 3, Issue 4, July 2014 terms of number of gates, input connections and delay though both perform addition within constant time. Proposed design has the advantages of both parallelisms as well as reduced gate complexity. The computation speed and circuit complexity increases as the number of computation steps decreases. Twostep schemes appear to be a prudent choice in terms of computation speed and storage complexity. Quaternary is the base 4 redundant number system. The degree of redundancy usually increases with the increase of the radix. The signed digit number system allows us to implement parallel arithmetic by using redundancy. QSD numbers are the SD numbers with the digit set as: { 3, 2,1, 0,1, 2, 3 } where 3, 2, and 1 represent -3, -2, and -1 respectively. In general, a signed-digit decimal number D can be represented in terms of an n digit quaternary signed digit number as $$D = \sum_{i=0}^{n-1} X_i 4^i$$ Where xi can be any value from the set { 3, 2,1, 0,1, 2, 3 } for producing an appropriate decimal representation. For digital implementation, QSD numbers are represented using 3-bit 2's complement notation. A QSD negative number is the QSD complement of the QSD positive number [3]. For example, using primes to denote complementation, we have 3' = 3, 3' = 3, 2' = 2, 2' = 2, 1' = 1, and 1' = 1. #### II. DESIGN OF QSD ADDER AND SUBTRACTION In QSD number system carry propagation chain is eliminated, which reduce the computation time substantially, thus enhancing the speed of the machine. As range of QSD number is from -3 to 3, the addition result of two QSD numbers varies from -6 to +6. Table I depicts the output for all possible combinations of two numbers. The decimal numbers in the range of -3 to +3 are represented by one digit QSD number. As the decimal number exceeds from this range, more than one digit of QSD number is required. For the addition result, which is in the range of -6 to +6, two QSD digits are needed. In the two digits QSD result the LSB digit represents the sum bit and the MSB digit represents the carry bit. To prevent this carry bit to propagate from lower digit position to higher digit position QSD number representation is used. QSD numbers allow redundancy in the number representations. The same decimal number can be represented in more than one QSD representations. So we choose such QSD represented number which prevents further rippling of carry. To perform carry free addition, the addition of two QSD numbers can be done in two steps [5]: Step 1: First step generates an intermediate carry and intermediate sum from the input QSD digits i.e., addend and augend. Step 2: Second step combines intermediate sum of current digit with the intermediate carry of the lower significant digit. So the addition of two QSD numbers is done in two stages. - 1. First stage of adder generates intermediate carry and intermediate sum from the input digits. - Second stage of adder adds the intermediate sum of current digit with the intermediate carry of lower significant digit. To remove the further rippling of carry there are two rules to perform QSD addition in two steps: **Rule 1:** First rule states that the magnitude of the intermediate sum must be less than or equal to 2 i.e., it should be in the range of -2 to +2. **Rule 2:** Second rule states that the magnitude of the intermediate carry must be less than or equal to 1 i.e., it should be in the range of -1 to +1. According to these two rules the intermediate sum and intermediate carry from the first step QSD adder can have the range of -6 to +6. But by exploiting the redundancy feature of QSD numbers we choose such QSD represented number 655 which satisfies the above mentioned two rules. When the second step QSD adder adds the intermediate sum of current digit, which is in the range of -2 to +2, with the intermediate carry of lower significant digit, which is in the range of -1 to +1, the addition result cannot be greater than 3 i.e., it will be in the range of -3 to +3. The addition result in this range can be represented by a single digit QSD number; hence no further carry is required. In the step 1 QSD adder, the range of output is from -6 to +6 which can be represented in the intermediate carry and sum in QSD format as shown in table I. # International Journal of Engineering Science and Innovative Technology (IJESIT) Volume 3, Issue 4, July 2014 | SUM | Possible QSD Representations | QSD Number | |-----|------------------------------|------------| | -6 | <u>1</u> 2,2 2 | <u>1</u> 2 | | -5 | <u>1</u> 1,2 3 | <u>1</u> 1 | | -4 | 1 0 | 1 0 | | -3 | 1 1,0 3 | <u>1</u> 1 | | -2 | 1 2,0 2 | 0 2 | | -1 | 0 1,1 3 | 0 1 | | 0 | 0 0 | 0 0 | | 1 | 0 1,1 3 | 01 | | 2 | 1 2,0 2 | 0 2 | | 3 | 0 3,1 <del>1</del> | 1 1 | | 4 | 1 0 | 10 | | 5 | 1 1,2 3 | 11 | | 6 | 1 2,2 2 | 12 | #### Table I: The intermediate carry and sum between -6 to +6. We can see in the first column of Table I that some numbers have multiple representations, but only those that meet the above defined two rules are chosen. The chosen intermediate carry and Intermediate sum are listed in the last column of Table I as the QSD coded number. This addition process can be well Understood by following examples: *Example:* To perform QSD addition of two numbers A = 108 and B = -232 (One number is +'ve and one number is -'ve). First convert the decimal number to their equivalent QSD representation: $$(108)_{10} = 2 \times 4^{3} + \overline{2} \times 4^{2} + 3 \times 4^{1} + 0 \times 4^{0}$$ $$= (2 \overline{2} 3 0)_{QSD}$$ $$(232)_{10} = 3 \times 4^{3} + 3 \times 4^{2} + \overline{2} \times 4^{1} + 0 \times 4^{0}$$ $$= (3 3 \overline{2} 0)_{QSD}$$ Hence, $(-232)_{10} = (\overline{3} \ \overline{3} \ 2 \ 0)_{OSD}$ Now the addition of two QSD numbers can be done as follows: The sum output is $(\overline{2}\ 0\ 1\ 0)$ QSD which is equivalent to $(-124)_{10}$ and carry output is 0. From these examples it is clear that the QSD adder design process will carry two stages for addition. The first stage generates intermediate carry and sum according to the defined rules. In the second stage the intermediate carry from the lower significant digit is added to the intermediate sum of current digit which results in carry free output. In this step the current digit can always absorb the carry-in from the lower digit. International Journal of Engineering Science and Innovative Technology (IJESIT) Volume 3, Issue 4, July 2014 # III.DESIGN AND IMPLEMENTATION OF SINGLE DIGIT QSD ADDER, SUBSTRACTION AND MULTIPLICATION UNITS These arithmetic operations such as addition, subtraction, multiplication are implemented as follows. There are two steps involved in the carry-free addition. The first step generates an intermediate carry and sum from the addend and augend. The second step combines the intermediate sum of the current digit with the carry of the lower significant digit. To prevent carry from further rippling, two rules are defined. The first rule states that the magnitude of the intermediate sum must be less than or equal to 2. The second rule states that the magnitude of the carry must be less than or equal to 1. | INPUT | | OUTPUT | | | | | | | |----------------|------------------|----------------|------------------|---------|---------|-------|--------|-------| | QSD | | Binary | | Decimal | QS | SD | Binary | | | $\mathbf{A_i}$ | $\mathbf{B_{i}}$ | $\mathbf{A_i}$ | $\mathbf{B_{i}}$ | Sum | $C_{i}$ | $S_i$ | $C_i$ | $S_i$ | | 3 | 3 | 011 | 011 | 6 | 1 | 2 | 001 | 010 | | 3 | 2 | 011 | 010 | 5 | 1 | 1 | 001 | 001 | | 2 | 3 | 010 | 011 | 5 | 1 | 1 | 001 | 001 | | 3 | 1 | 011 | 001 | 4 | 1 | 0 | 001 | 000 | | 1 | 3 | 001 | 011 | 4 | 1 | 0 | 001 | 000 | | 2 | 2 | 010 | 010 | 4 | 1 | 0 | 001 | 000 | | 1 | 2 | 001 | 010 | 3 | 1 | -1 | 001 | 111 | | 2 | 1 | 010 | 001 | 3 | 1 | -1 | 001 | 111 | | 3 | 0 | 011 | 000 | 3 | 1 | -1 | 001 | 111 | | 0 | 3 | 000 | 011 | 3 | 1 | -1 | 001 | 111 | | 1 | 1 | 001 | 001 | 2 | 0 | 2 | 000 | 010 | | 0 | 2 | 000 | 010 | 2 | 0 | 2 | 000 | 010 | | 2 | 0 | 010 | 000 | 2 | 0 | 2 | 000 | 010 | | 3 | -1 | 011 | 111 | 2 | 0 | 2 | 000 | 010 | | -1 | 3 | 111 | 011 | 2 | 0 | 2 | 000 | 010 | | 0 | 1 | 000 | 001 | 1 | 0 | 1 | 000 | 001 | | 1 | O | 001 | 000 | 1 | 0 | 1 | 000 | 001 | | 2 | -1 | 010 | 111 | 1 | 0 | 1 | 000 | 001 | | -1 | 2 | 111 | 010 | 1 | 0 | 1 | 000 | 001 | | 3 | -2 | 011 | 110 | 1 | 0 | 1 | 000 | 001 | | -2 | 3 | 110 | 011 | 1 | O | 1 | 000 | 001 | | 0 | 0 | 000 | 000 | 0 | 0 | 0 | 000 | 000 | | 1 | -1 | 001 | 111 | 0 | 0 | 0 | 000 | 000 | | -1 | 1 | 111 | 001 | 0 | O | O | 000 | 000 | | 2 | -2 | 010 | 110 | 0 | 0 | 0 | 000 | 000 | | -2 | 2 | 110 | 010 | 0 | 0 | 0 | 000 | 000 | | -3 | 3 | 101 | 011 | 0 | 0 | 0 | 000 | 000 | | 3 | -3 | 011 | 101 | 0 | 0 | 0 | 000 | 000 | | 0 | -1 | 000 | 111 | -1 | 0 | -1 | 000 | 111 | | -1 | 0 | 111 | 000 | -1 | 0 | -1 | 000 | 111 | | -2 | 1 | 110 | 001 | -1 | 0 | -1 | 000 | 111 | | 1 | -2 | 001 | 110 | -1 | 0 | -1 | 000 | 111 | | -3 | 2 | 101 | 010 | -1 | 0 | -1 | 000 | 111 | | 2 | -3 | 010 | 101 | -1 | 0 | -1 | 000 | 111 | | -1 | -1 | 111 | 111 | -2 | 0 | -2 | 000 | 110 | | 0 | -2 | 000 | 110 | -2 | 0 | -2 | 000 | 110 | | -2 | 0 | 110 | 000 | -2 | 0 | -2 | 000 | 110 | | -3 | 1 | 101 | 001 | -2 | 0 | -2 | 000 | 110 | | 1 | -3 | 001 | 101 | -2 | 0 | -2 | 000 | 110 | | -1 | -2 | 111 | 110 | -3 | -1 | 1 | 111 | 001 | | -2 | -1 | 110 | 111 | -3 | -1 | 1 | 111 | 001 | | -3 | 0 | 101 | 000 | -3 | -1 | 1 | 111 | 001 | | 0 | -3 | 000 | 101 | -3 | -1 | 1 | 111 | 001 | | -3 | -1 | 101 | 111 | -4 | -1 | 0 | 111 | 000 | | -1 | -3 | 111 | 101 | -4 | -1 | 0 | 111 | 000 | | -2 | -2 | 110 | 110 | -4 | -1 | 0 | 111 | 000 | | -3 | -2 | 101 | 110 | -5 | -1 | -1 | 111 | 111 | | -3<br>-2 | -3 | 110 | 101 | -5 | -1 | -1 | 111 | 111 | | -3 | -3 | 101 | 101 | -6 | -1 | -2 | 111 | 110 | Table II: The conversion between the inputs and outputs of the Intermediate carry and intermediate sum. These Rules does not come count for multiplication. The magnitude of the second step output cannot be greater than 3 which can be represented by a single-digit QSD number; hence no further carry is required. In step 1, all possible input pairs of the addend and augend are considered. The range of input numbers can vary from -3 to +3, so the addition result will vary from -6 to +6 which needs two QSD digits. The lower significant digit serves as sum and most significant digit serves as carry. The generation of the carry can be avoided by mapping the two digits into a pair of intermediate sum and intermediate carry such that the nth intermediate sum and the (n-1)th intermediate carry never form any carry generating pair (3,3), (3,2), (3,1), (3,3), (3, 2), (3,1). If we restrict the representation such that the intermediate carry is limited to a maximum of 1, and the intermediate sum is restricted to be less than 2, then the final addition will become carry free. Both inputs and outputs can be encoded in 3-bit 2's complement binary # International Journal of Engineering Science and Innovative Technology (IJESIT) Volume 3, Issue 4, July 2014 number. The mapping between the inputs addend and augend, and the outputs, the intermediate carry and sum are shown in binary format in Table II. To remove the further carry propagation the redundancy feature of QSD numbers is used. We restrict the representation such that all the intermediate carries are limited to a maximum of 1, and the intermediate sums are restricted to be less than 3, then the final addition will become carry free. The QSD representations according to these rules are shown in Table I for the range of -6 to +6. As the range of intermediate carry is from -1 to +1, it can be represented in 2 bit binary number but we take the 3 bit representation for the bit compatibility with the intermediate sum. At the input side, the addend Ai is represented by 3 variable input as A2, A1, A0 and the augend Bi is represented by 3 variable input as B2, B1, B0. At the output side, the intermediate carry IC is represented by IC2, IC1, IC0 and the intermediate sum IS is represented by IS2, IS1, IS0. The six variable expressions for intermediate carry and intermediate sum in terms of inputs (A2, A1, A0, B2, B1 and B0) can be derived from Table II. So we get the six output expressions for IC2, IC1, ICO, IS2, IS1 and ISO. The intermediate carry can be represented by only 2 bits [6]. The Verilog HDL code for intermediate carry and sum generator in step 1 adder, by taking the six inputs (A2, A1, A0, B2, B1 and B0) and six outputs (IC2, IC1, IC0, IS2, IS1 and IS0), has been written. The Verilog HDL code is compiled and simulated using Xilinx software. The design is synthesized on FPGA Spartan 3E in Xilinx XC9500XV technology. The TABLE III shows the QSD Subtraction which is similar to QSD Addition. The Intermidiate Difference and the Intermidiate Borrow are indicated with Decimal equivalents. The Verilog HDL code corresponding to OSD subtraction is written with the help of following table. | INPUT | | DECIMAL | QSD REPRE | QSD REPRESENTATION | | | |------------------|--------|--------------|-----------|--------------------|--|--| | Α | В | SUBTRACTION | В | D | | | | -3 | -3 | 0 | 0 | 0 | | | | -3 | -2 | -1 | 0 | -1 | | | | -3 | -1 | -2 | 0 | -2 | | | | -3 | 0 | -3 | 1 | -1 | | | | -3 | 1 | -4 | -1 | 0 | | | | -3 | 2 | -5 | -1 | -1 | | | | -3 | 3 | -6 | -1 | -2 | | | | -2<br>-2 | -3 | 1<br>0 | 0 | 1<br>0 | | | | -2 | -2 | 0 | 0 | 0 | | | | -2 | -1 | -1 | 0 | -1 | | | | -2 | 0 | -2 | 0 | -2 | | | | -2 | 1 | -3 | -1 | 1<br>0 | | | | -2 | 2 | -4 | -1 | 0 | | | | -2 | 3 | -5 | -1 | -1 | | | | -1 | -3 | 2 | 0 | 2 | | | | -1 | -2 | 2<br>1<br>0 | 0 | 1 | | | | -1 | -1 | 0 | 0 | 0 | | | | -1 | 0 | -1 | 0 | -1 | | | | -1 | 1 | -2 | 0 | -2 | | | | -1 | 2 | -3 | -1 | 1 | | | | -1 | 3 | -4<br>3<br>2 | -1 | 0 | | | | 0 | -3 | 3 | 1 | -1 | | | | 0 | -2 | 2 | 0 | 2 | | | | 0 | -1 | 1 | 0 | 1 | | | | 0 | 0 | 0 | 0 | 0 | | | | 0 | 1 | -1 | 0 | -1 | | | | 0 | 2 | -2 | 0 | -2 | | | | 0 | 3 | -3 | -1 | 1<br>0 | | | | 1 | -3 | 4 | 1 | 0 | | | | 1 | -2 | 3<br>2 | 1 | -1 | | | | 1 | -1 | 2 | 0 | 2 | | | | 1 | 0 | 1 | 0 | 1 | | | | 1 | 1<br>2 | 0 | 0 | 0 | | | | 1 | 2 | -1 | 0 | -1 | | | | 1 | 3 | -2 | 0 | -2 | | | | 2 | -3 | 5<br>4 | 1 | 1 | | | | 2<br>2<br>2 | -2 | 4 | 1 | 0 | | | | 2 | -1 | 3 | 1 | -1 | | | | 2 | 0 | 2 | 0 | 2 | | | | | 1 | 1 | 0 | 1 | | | | 2 | 2 | 0 | 0 | 0 | | | | 2<br>2<br>2<br>3 | -3 | -1 | 0 | -1<br>2 | | | | 3 | -5 | 6 | 1 | 4 | | | | 3 | -2 | 5<br>4 | 1 | 1<br>0 | | | | 3 | -1 | 4 3 | 1 | | | | | | 0 | 3<br>2 | 1 | -1 | | | | 3 | 1<br>2 | 1 | | 2 | | | | ] | 3 | | 0 | 1 | | | | 3 | 5 | 0 | 0 | 0 | | | Table III: The conversion between the inputs and outputs of the Intermediate borrow and intermediate difference. # International Journal of Engineering Science and Innovative Technology (IJESIT) Volume 3, Issue 4, July 2014 In Table IV, The QSD Multiplication is sorted out with the corresponding possibilities along with their Decimal result converted to QSD Multiplication. The Verilog HDL code corresponding to QSD Multiplication is written with the help of following table. | INPUT | | DECIMAL | QSD REPRESENTATION | | | |-------|----|----------------|--------------------|----|--| | A B | | MULTIPLICATION | M1 | MO | | | -3 | -3 | 9 | 2 | 1 | | | -3 | -2 | 6 | 1 | 2 | | | -3 | -1 | 3 | 1 | -1 | | | -3 | 0 | 0 | 0 | 0 | | | -3 | 1 | -3 | -1 | 1 | | | -3 | 2 | -6 | -1 | -2 | | | -3 | 3 | -9 | -2 | -1 | | | -2 | -3 | 6 | 1 | 2 | | | -2 | -2 | 4 | 1 | 0 | | | -2 | -1 | 2 | 0 | 2 | | | -2 | 0 | 0 | 0 | 0 | | | -2 | 1 | -2 | 0 | -2 | | | -2 | 2 | -4 | -1 | 0 | | | -2 | 3 | -6 | -1 | -2 | | | -1 | -3 | 3 | 1 | -1 | | | -1 | -2 | 2 | 0 | 2 | | | -1 | -1 | 1 | 0 | 1 | | | -1 | 0 | 0 | 0 | 0 | | | -1 | 1 | -1 | 0 | -1 | | | -1 | 2 | -2 | 0 | -2 | | | -1 | 3 | -3 | -1 | 1 | | | 0 | -3 | 0 | 0 | 0 | | | 0 | -2 | 0 | 0 | 0 | | | 0 | -1 | 0 | 0 | 0 | | | 0 | 0 | 0 | 0 | 0 | | | 0 | 1 | 0 | 0 | 0 | | | 0 | 2 | 0 | 0 | 0 | | | 0 | 3 | 0 | 0 | 0 | | | 1 | -3 | -3 | -1 | 1 | | | 1 | -2 | -2 | 0 | -2 | | | 1 | -1 | -1 | 0 | -1 | | | 1 | 0 | 0 | 0 | 0 | | | 1 | 1 | 1 | 0 | 1 | | | 1 | 2 | 2 | 0 | 2 | | | 1 | 3 | 3 | 1 | -1 | | | 2 | -3 | -6 | -1 | -2 | | | 2 | -2 | -4 | -1 | 0 | | | 2 | -1 | -2 | 0 | -2 | | | 2 | 0 | 0 | 0 | 0 | | | 2 | 1 | 2 | 0 | 2 | | | 2 | 2 | 4 | 1 | 0 | | | 2 | 3 | 6 | 1 | 2 | | | 3 | -3 | -9 | -2 | -1 | | | 3 | -2 | -6 | -1 | -2 | | | 3 | -1 | -3 | -1 | 1 | | | 3 | 0 | 0 | 0 | 0 | | | 3 | 1 | 3 | 1 | -1 | | | 3 | 2 | 6 | 1 | 2 | | | 3 | 3 | 9 | 2 | 1 | | Table IV: Representation of conversion to QSD Multiplication. #### IV. SIMULATION RESULTS In this paper, we propose a high speed and low power QSD addition, subtraction, multiplication units. Xilinx Software gives us an easy way to analyze our results to get the best out of them. The simulation results of the Adder and subtraction units in QSD are shown below. International Journal of Engineering Science and Innovative Technology (IJESIT) Volume 3, Issue 4, July 2014 Fig 1: Simulation Result of QSD Adder The Simulation of QSD subtraction which is written in Verilog HDL is done in Xilinx Software. Fig 2: Simulation Result of QSD Subtraction The simulation Result corresponding to QSD Multiplication is as below Fig 3: Simulation Result of QSD Multiplication ## International Journal of Engineering Science and Innovative Technology (IJESIT) Volume 3, Issue 4, July 2014 #### V. CONCLUSION In the proposed design of Quaternary Signed Digit addition, Subtraction, Multiplication for single digit are written in Verilog HDL and Simulated in Xilinx 12.2.. These circuits consume less energy and power, and shows better performance. The delays of the proposed designs are less. The design is simulated and synthesized using Xilinx. Consequently this design is appropriate to be applied for construction of a high performance multiprocessor which consists of many processing elements. #### REFERENCES - [1]. Sachin Dubey, Reena rani "VLSI Implementation of Fast Addition using Quaternary Signed Digit Number System" IEEE International Conference on Emerging Trends in Comp...ICECCN 2013. - [2]. A. Avizinis "signed digit number representation for fast parallel arithmetic", IRE Transactions on Elec. Comp...Vol EC-10,pp 389-400,sept-1961. - [3]. A.A.S. Awwal and J.U. Ahmed, "fast carry free adder design using QSD number system," proceedings of the IEEE 1993 national aerospace and electronic conference, vol 2,pp 1085-1090,1993. - [4]. Behrooz perhami "generalized signed digit number systems, a unifying frame work for redundant number representation ".IEEE transactions on computers, vol 39, no.1, pp.89-98, January 1990. - [5]. O. Ishizuka, A. Ohta, K. Tannno, Z. Tang, D. Handoko, "VLSI design of a quaternary multiplier with direct generation of partial products," Proceedings of the 27th International Symposium on Multiple-Valued Logic, pp. 169-174, 1997. - [6]. A.A.S Awwal, Syed M. Munir, A.T.M. Shafiqul Khalid, Howard E. Michel and O. N. Garcia, "Multivalued Optical Parallel Computation Using An Optical Programmable Logic Array", Informatica, vol. 24, No. 4, pp. 467-473, 2000. - [7]. Neha W.Umredkar, M.A.Gaikwad, Ph.D. "Review of Quaternary Adders in Voltage Mode Multi-Valued Logic" International Journal of Computer Applications (0975 8887) "Recent Trends in Engineering Technology-2013". - [8]. F. Kharbash and G. M. Chaudhry, "Reliable Binary Signed Digit Number Adder Design", IEEE Computer Society Annual Symposium on VLSI, pp 479-484, 2007. - [9]. John Moskal, Erdal Oruklu and Jafar Saniie, "Design and Synthesis of a Carry-Free Signed-Digit Decimal Adder", IEEE International symposium on Circuits and Systems, pp 1089-1092, 2007. - [10].Kai Hwang, "Computer Arithmetic Principles, Architecture and Design", ISBN 0-471-03496-7, John Wiley & Sons, 1979. - [11].P. K. Dakhole, D.G. Wakde, "Multi Digit Quaternary adder on Programmable Device: Design and verification", International Conference on Electronic Design, pp. 1-4, Dec 2008. - [12].Behrooz Parhami, "Carry-Free Addition of Recoded Binary Signed- Digit Numbers", IEEE Transactions on Computers, Vol. 37, No. 11, pp. 1470-1476, November 1988. - [13].Reena Rani, Neelam Sharma, L.K.Singh, "FPGA Implementation of Fast Adders using Quaternary Signed Digit Number System" IEEE proceedings of International Conference on Emerging Trends in Electronic and Photonic Devices & Systems (ELECTRO-2009), pp 132-135, 2009. - [14].Reena Rani, Neelam Sharma, L.K.Singh, "Fast Computing using Signed Digit Number System" IEEE proceedings of International Conference on Control, Automation, Communication and Energy Conservation 2009, 4th-6th June 2009. #### **AUTHOR BIOGRAPHY** (1)Mr.M.Naveen Krishna has received his B.Tech degree from Siddartha Institute of Science and technology Affiliated to JNTU Anantapur in the Branch Electronics and Communication Engineering in 2012.He is presently pursuing M.Tech in VLSI in Sree Vidyanikethan Engineering College (Autonomous), Tirupati and would graduate in the year 2014. His research interests include Digital Logic Design, Verilog HDL. # International Journal of Engineering Science and Innovative Technology (IJESIT) Volume 3, Issue 4, July 2014 (2)Mr.T.Ravisekhar, M.Tech, is currently working as an Assistant Professor in ECE Department at Sree Vidyanikethan Engineering College (Autonomous) Tirupati. He has completed M.Tech in VLSI Design, in Satyabhama University and received B.Tech from Sri Kalahastheeswara Institute of Technology, Srikalahasti. His research areas are Digital Design and VLSI Signal Processing.