

# Design and Implementation of Floating Point Multiplier based on Vedic Multiplication Technique

Aniruddha Kanhe  
Dept. of Electronics & Telecomm.  
KITE Raipur, India  
kanheaniruddha@gmail.com

Shishir Kumar Das  
Dept. of Electronics & Telecomm.  
KITE Raipur, India  
shisdas@gmail.com

Ankit Kumar Singh  
Dept. of Electronics & Telecomm.  
KITE Raipur, India  
singhankit491@gmail.com

**Abstract—** In this paper, Vedic Multiplication Technique is used to implement IEEE 754 Floating point multiplier. The Urdhva-triyakbhyam sutra is used for the multiplication of Mantissa. The underflow and over flow cases are handled. The inputs to the multiplier are provided in IEEE 754, 32 bit format. The multiplier is implemented in VHDL and Virtex-5 FPGA is used.

**Keywords:** *Vedic Mathematics, Urdhva-triyakbhyam sutra, Floating Point multiplier, FPGA.*

## I. INTRODUCTION

DSP applications essentially require the multiplication of binary floating point numbers. The IEEE 754 standard provides the format for representation of Binary Floating point numbers [1, 2]. The Binary Floating point numbers are represented in Single and Double formats. The Single consist of 32 bits and the Double consist of 64 bits. The formats are composed of 3 fields; Sign, Exponent and Mantissa. The Figure 1 shows the structure of Single and Double formats of IEEE 754 standard. In case of Single, the Mantissa is represented in 23 bits and 1 bit is added to the MSB for normalization, Exponent is represented in 8 bits which is biased to 127, actually the Exponent is represented in excess 127 bit format and MSB of Single is reserved for Sign bit. When the sign bit is 1 that means the number is negative and when the sign bit is 0 that means the number is positive. In 64 bits format the Mantissa is represented in 52 bits, the Exponent is represented in 11 bits which is biased to 1023 and the MSB of Double is reserved for sign bit.



**Fig 1. IEEE Format for single and double**

Multiplication of two floating point numbers represented in IEEE 754 format is done by multiplying the normalized 24 bit mantissa, adding the biased 8 bit exponent and resultant is converted in excess 127 bit format, for the sign calculation the input sign bits are XORed. In this paper, we propose the Vedic Multiplication algorithm [3] for multiplication of 24 bit

mantissa. The details of Vedic Multiplication with their advantages over the conventional multiplication method are discussed in the section III.

The paper describes the implementation and design of IEEE 754 Floating Point Multiplier based on Vedic Multiplication Technique. Section II explores the basics of IEEE 754 floating point representation and implementation of floating point multiplier using Vedic multiplication technique. Section III describes the idea behind Vedic multiplication. Section IV comprises of result and conclusion.

## II. FLOATING POINT MULTIPLICATION

The multiplier for the floating point numbers represented in IEEE 754 format can be divided in four different units:

Mantissa Calculation Unit

Exponent Calculation Unit

Sign Calculation Unit

Control Unit



**Fig 2. Proposed architecture for Floating point multiplier**



**Fig 4. The Vedic Multiplication method**

Now the final result of multiplication of A and B is c4s4s3s2s1s0.

The block diagram of 24x24 BIT multiplier is shown in Figure 5. This multiplier is modeled using structural style of modeling using VHDL. In this paper first a 3x3 Vedic multiplier is implemented using the above mentioned method. The 6x6 is designed using 3x3. After that the 12x12 is implemented using four 6x6 BIT multiplier. Finally the 24x24 BIT multiplier is made using four 12x12 BIT multipliers. The 24x24 BIT multiplier requires four 12x12 BIT multipliers and two 24 BIT ripple carry adders.

**Fig 5. Block diagram of 24x24 BIT Vedic multiplier.**

Consider the inputs A and B of 24 BIT each. The lower twelve BITS of input A (A11-A0) are multiplied with the lower twelve BIT of B (B11-B0). This produces the 24 BIT result out of which lower 12 BITS are considered as the lower 12 BITS of the final result and the upper 12 BITS are considered as carry. The lower 12 BITS of A are multiplied with the upper 12 BITS of B, similarly the lower 12 BITS of B are multiplied with the upper 12 BITS of A and the result of this multiplication are added with the previous carry as shown in Figure 5. Again this will produce altogether 24 BITS out of which lower 12 BITS are considered as the (23-12) BITS of the final result and upper 12 BITS are the carry BITS which are added to the multiplication result of last step. The last step is to multiply the upper 12 BITS of both A and B and to add the previous carry. This will result in 24 BITS which are considered as the upper 24 BITS of the final result.

The number of LUTs and slices required for the Vedic Multiplier is less and due to which the power consumption is reduced [9]. Also the repetitive and regular structure of the multiplier makes it easier to design. And the time required for computing multiplication is less than the other multiplication techniques.

An Overflow or Underflow case occurs when the result Exponent is higher than the 8 BIT or lower than 8 BIT respectively. Overflow may occur during the addition of two Exponents which can be compensated at the time of subtracting the bias from the exponent result. When overflow occurs the overflow flag goes up. The under flow can occur after the subtraction of bias from the exponent, it is the case when the number goes below 0 and this situation can be handled by adding 1 at the time of normalization. When the underflow case occur the under flow flag goes high.

#### IV. RESULT AND CONCLUSION

The multiplier is designed in VHDL and simulated using Modelsim Simulator. The design was synthesized using Xilinx ISE 12.1 tool targeting the Xilinx Virtex 5 xc5vlx30-3-ff324 FPGA. A test bench is used to generate the stimulus and the multiplier operation is verified. The over flow and under flow flags are incorporated in the design in order to show the over flow and under flow cases.

The paper shows the efficient use of Vedic multiplication method in order to multiply two floating point numbers. The lesser number of LUTs verifies that the hardware requirement is reduced, thereby reducing the power consumption. The power is reduced affectively still not compromising delay so much. The Table 1 shows the summary of the multiplier tested.

**Table1. Design Summary**

| Parameters          | This work | [10]      |
|---------------------|-----------|-----------|
| Device              | Virtex 5  | Virtex 2p |
| Power Consumption   | 27.29mW   | 55mW      |
| Time delay          | 5.246ns   | 3.070ns   |
| Number of LUTs      | 966       | 1316      |
| Number of IOs       | 99        | 100       |
| Power Delay Product | 143.16pJ  | 168.85pJ  |

#### REFERENCES

- [1] IEEE 754-2008, IEEE Standard for Floating-Point Arithmetic, 2008.
- [2] Brian Hickmann, Andrew Krioukov, and Michael Schulte, Mark Erle, "A Parallel IEEE 754 Decimal Floating-Point Multiplier," In 25th International Conference on Computer Design ICCD, Oct. 2007
- [3] Jagadguru Swami Sri Bharati Krisna Tirthaji Maharaja, "Vedic Mathematics Sixteen Simple Mathematical Formulae from the Veda," 1965.
- [4] Metin Mete ÖZBLEN, Mustafa GÖK, "A Single/Double Precision Floating-Point Multiplier Design for Multimedia Applications," Journal

- of Electrical & Electronics Engineering. Vol.9, Number 1, pp 827-831  
2009
- [5] Al-Ashrafy, M.; Salem, A.; Anis, W, "An efficient implementation of floating point multiplier," Electronics Communications and Photonics Conference (SIECPC), 2011
- [6] Rekha K James, Poulose K Jacob, Sreela Sasi, "Decimal Floating Point Multiplication using RPS Algorithm," IJCA Proceedings on International Conference on VLSI, Communications and Instrumentation (ICVCI), 2011.
- [7] Chetana Nagendra, Robert Michael Owens, and mary Jane Irwin, "Power-Delay Characteristics of CMOSAdders", IEEE Transactions on Very Large Scale Integration (VLSI) Systems, Vol. 2, No. 3, September 1994.
- [8] S. S. Kerur, Prakash Narchi, Jayashree C N, Harish M Kittur, Girish V A, "Implementation of Vedic Multiplier for Digital Signal Processing," International Journal of Computer Applications (IJCA) 2011
- [9] Aniruddha Kanhe, Shishir Kumar Das and Ankit Kumar Singh, "Design And Implementation Of Low Power Multiplier Using Vedic Multiplication Technique," International Journal of Computer Science and Communication (IJCSC) Vol. 3, No. 1, January-June 2012, pp. 131-132.
- [10] Kavita Khare, R.P.Singh, Nilay Khare,"Comparison of pipelined IEEE-754 standard floating point multiplier with unpipelined multiplier" Journal of Scientific & Industrial Research Vol.65, pages 900-904 November 2006.