# IMPLEMENTATION OF FLOATING POINT AND LOGARITHMIC NUMBER SYSTEM ARITHMETIC UNIT AND THEIR COMPARISON FOR FPGA 

Amit Kumar', Saxena .A. $K^{2}$, Dasgupta . $S^{3}$<br>Solid State Device \&VLSI Technology Group , Dept. of Electronics and Computer Engineering, Indian Institute of Technology, Roorkee, Uttrakhand, India<br>E-mail : ' iitr.amitkumar@gmail.com, ${ }^{2}$ kumarfec@iitr.ernet.in, ${ }^{3}$ sudebfec@iitr.ernet.in


#### Abstract

Floating point (FP) representation is commonly used to represent real numbers. Some papers have suggested the use of logarithmic number system (LNS) in addition to floating point. In LNS, a real number is represented as a fixed point logarithm. Therefore multiplication and division in LNS are much simpler in comparison to that in FP , so the LNS can be beneficial if addition and subtraction can be performed with speed and accuracy equal to FP. LNS addition and subtraction requires interpolation technique for which some vales are stored in read only memory (ROM). In this paper, different sizes of ROM are used for addition and subtraction and their performances are compared to the floating point.


Key words: FPGA, Logarithmic Number Systems, ROM.

## I. INTRODUCTION

The floating point [1] and logarithmic number system $[2,3]$ are the arithmetic number systems used for representing real numbers in computer and digital hardware. Most of the implementations use single (32bit) or double (64-bit) precision for representing floating point and LNS.

The dynamic ranges of FP and LNS come at the cost of lower precision and increased complexity over fixed point. LNS provide a similar range to FP but have advantages that multiplication and division in LNS are simplified to fixed-point addition and subtraction. But thedisadvantage of LNS is that addition and subtraction are very difficult to perform in hardware descriptive language (HDL) [4] and the accuracy depends upon the size of only memory (ROM). In this paper, arithmetic operations (addition, subtraction, multiplication and division) for FP and LNS are implemented in HDL and synthesis results for both are compared to find which number system will suit better for field programmable logic array (FPGA) [5] real number representation.

## II. NUMBER SYSTEMS

## A. Floating Point

The IEEE introduced a standard IEEE 754 [1] to define floating-point representation and arithmetic. The single precision format uses 1 sign bit (S), 8 bits biased exponent bits ( E ), and 23 bits mantissa ( F ). The mantissa part has binary point to the left, and a hidden ' 1 ' to the left of the point. The storage layout for singleprecision is shown below:


Fig. 1. Floating Point Format.
The most significant bit starts from the left. The format of numbers represented by the single-precision representation is:

$$
\begin{equation*}
\text { Value }=(-1)^{\mathrm{s}} \times 2^{\mathrm{E}}-127 \times(1 . \mathrm{F}) \tag{1}
\end{equation*}
$$

where $F=\left(b_{22}+b_{21}+\ldots \ldots \ldots \ldots \ldots \ldots . . . . b_{i}+\ldots \ldots+b_{20}\right)$.
$b_{i}=1$ or 0 .
$S=\operatorname{sign}$ (0 is positive, 1 is negative).
$\mathrm{E}=$ biased exponent.
$e=$ unbiased exponent $=\mathrm{E}-127$ (bias).
The extreme exponents ( 0 and 255) are used to represent special cases, thus this format has range from $1.0^{*} 2^{126}$ to $1.11111 \ldots . .2^{127}$ i.e. from $1.2 \mathrm{E}-38$ to $3.4 \mathrm{E}+38$.

## B. Logarithmic Number System [2,3]

The format of the logarithm number system is

$$
\begin{equation*}
A=(-1)^{5 A *} 2^{E A} . \tag{2}
\end{equation*}
$$

where $S_{A}$ is the sign bit and $E_{A}$ is a signed fixed point number. The sign bit signifies the sign of the whole number. $E_{A}$ has two parts integer (I) and fraction part ( F ). The integer part is of 8 bits and the fraction part is of 23 bits. To represent the very small numbers, $\mathrm{E}_{\mathrm{A}}$ is negative.


Fig. 2. Logarithmic Number System Format

The real numbers represented by this format are in the range $\pm 2^{-128}$ to $2^{-128}$ i.e. $\pm 2.9 \mathrm{E}-39$ to $3.4 \mathrm{E}+38$.

## III. FLOATING POINT ARITHMETIC UNIT

The Floating point arithmetic unit has four operations: addition, subtraction, multiplication and division. The operations are performed on operands $A$ and $B$ and the result of the operation will be saved in $Z$, where $A, B$ and $Z$ are given as

$$
\begin{align*}
& A=(-1)^{S A *} 2^{E A-127 *}\left(1 \cdot M_{A}\right) . \\
& B=(-1)^{S B *} 2^{E B-127 *}\left(1 \cdot M_{B}\right) . \\
& Z=(-1)^{S Z *} 2^{E Z-127 *}\left(1 \cdot M_{Z}\right) . \tag{3}
\end{align*}
$$

A. FP Addition Algorithm $[6,7,8]$

Floating point addition involves the following steps:

1. Separate the sign, exponent and mantissa bits of the both operands
2. Compare $|A|$ and $|B|$. If $|B|$ is greater than $|A|$, then swapA and B.
3. Set the exponent of result $E_{Z} E_{A} S_{Z} S_{A}$.
4. Compute the difference $d=E_{B}-E_{A}$. Shift (1.M $M_{B}$ ) to the right by d times and fill the leftmost bits with zeros.
5. Compute the mantissa of result $M_{z}$ By adding $\left(1 . M_{A}\right)$ and (1.M $\mathrm{M}_{\mathrm{B}}$.
6. Normalization step : If carry is generated in step 5, shift $\left(1 . M_{z}\right)$ right by one and increase the exponent $E_{z}$ by one.
7. Check resultant exponent for overflow / underflow:

If $\mathrm{E}_{z}$ is larger than maximum emponent allowed, then set the overflow flag.
If $E_{z}$ is Smaller than minimum exponent allowed, then set the underflow flag.
8. Pack the sign bit, exponent bits and mantissa bits according to the IEEE 754 floating point standard.
B. FP Subtraction Algorithm $[6,7,8]$

Floating point subtraction involves the following steps:

1. Separate the sign, exponent and mantissa bits of the both operands.
2. Compare $|A|$ and $|B|$. If $|B|$ is greater than $|A|$, then swapAand B.
3. Set the exponent of result $E_{Z}$ equals to $E_{A}$ and sign of result $S_{Z}$ equals to $S_{A}$.
4. Compute the difference $d=E_{B}-E_{A}$. Shift (1.M $M_{B}$ ) to the right by d times and fill the leftmost bits with zeros.
5. Compute the mantissa of result $M_{Z}$ By adding (1. $M_{B}$ ) and (1.M $\mathrm{M}_{\mathrm{A}}$ ).
6. Normalization step : If carry is generated in step 5, shift ( $1 . \mathrm{M}_{\mathrm{z}}$ ) right by one and increase the exponent $\mathrm{E}_{\mathrm{z}}$ by one.
7. Check resultant exponent for overflow/underflow:

If $\mathrm{E}_{z}$ is larger than maximum exponent allowed, then set the overflow flag.
If $E_{z}$ is Smaller than minimum exponent allowed, then set the underflow flag.
8. Pack the sign bit, exponent bits and mantissa bits according to the IEEE 754 floating point standard.
C. FP multiplication algorithm $[6,7,9]$

Floating point multiplication involves the following steps:

1. Separate the sign, exponent and mantissa bits of the both operands
2. Compute the sign of the result: $S_{Z}=S_{A} X O R S_{B}$.
3. Compute the exponent of the result:

Result exponent $=E_{A}+E_{B}-$ "01111111".
4. Calculate the mantissa of the result [10]:

Multiply the mantissas : $\left(1 . \mathrm{M}_{\mathrm{A}}\right)^{*}\left(1 . \mathrm{M}_{\mathrm{B}}\right)$ The calculated mantissa will be in the 48 bits.
5. Normalize the result if needed.
6. Round the above result to the allowed number ( 24 bits) of mantissa bits.
7. Check resultant exponent for overflow/underflow:

If $E_{z}$ is larger than maximum exponent allowed, then set the overflow flag.
If $\mathrm{E}_{z}$ is larger than minimum exponent allowed, then set the Underflow flag.
8. Pack the sign bit, exponent bits and mantissa bits according to the IEEE 754 floating point standard, to give the multiplication output.
D. FP division algorithm [6, 7, 9 ]

Floating point division involves the following steps:

1. Separate the sign, exponent and mantissa bits of the both operands
2. Compute the sign of the result: $S_{Z}=S_{A} X O R S_{B}$.
3. Compute the exponent of the result:

Resultexponent $=E_{A}+E_{B}$-"01111111".
4. Calculate the mantiss of the result [10]:

Multiply the mantissas: (1.MA ${ }^{*}$ * $\left(1 . M_{B}\right)$.
5. Normalize the resultifneeded.
6. Round the above result to the allowed number (24 bits) of mantissabits.
7. Check resultant exponentfor overflow/underflow:

If $E_{z}$ is larger than maximum exponent allowed, then set the overflow flag.
If $\mathrm{E}_{z}$ is larger than minimum exponent allowed, then set the Underflow flag.
8. Pack the sign bit, exponent bits and mantissa bits according to the IEEE 754 floating point standard, to give the multiplication output.

## IV. LNS ARITHMETIC UNIT

The LNS arithmetic unit has four parts - addition, subtraction, multiplication and division. The operations are performed on operands $A$ and $B$ and the result of the operation will be saved in $Z$, where $A, B$ and $Z$ are given as

$$
\begin{align*}
& A=(-1)^{S A *} * 2^{E A} . \\
& B=(-1)^{S B} * 2^{E B} . \\
& Z=(-1)^{s Z} * 2^{E Z} . \tag{4}
\end{align*}
$$

A. LNS Addition

1) LNS Addition Algorithm 1 [11,12,13,14]:
1. Separate the sign and fixed point exponent bits of both operands.
2. Generate the $R O M$ values for the function $f(d)=\log 2$ ( $1+^{2 \cdot 5}$ ) of suitable size using $\mathrm{C}++$ and store that in a constant two dimensional array.
3. If $|A|<|B|$, then swap the numbers $A$ and $B$.
4. Sign of result, $S_{Z}=S_{A}$.
5. Calculate difference, $x=E_{A}-E_{B}$.
6. Use the second order polynomial interpolation method to obtain the value of ( $1+2^{*}$ ) [15, 16].
7. Add $_{\mathrm{A}}$ and $\log _{2}\left(1+2^{x}\right)$ to get the result exponent $\mathrm{E}_{2}$.
8. Check for overflow/underflow.
9. Assemble the result in to 32 bit LNS format.
2) LNSAddition Algorithm 2 [17]:
1. Separate the sign and fixed point exponent bits of both operands.
2. Generate the ROM values for the function $f(d)=\sqrt[1]{2}$ where $i=2,4,8,16, \ldots \ldots \ldots . . . .8388608$
i.e. of size 23 using $\mathrm{C}++$ and store that in a constant two dimensional array rom1.
3. Generate the ROM values for the function $f(d)=\sqrt[1]{2^{-1}}$ where $i=2,4,8,16, \ldots \ldots . .8388608$
i.e. of size 23 using $\mathrm{C}++$ and store that in a constant two dimensional array rom2.
4. If $|A|<|B|$, then swap the numbers $A$ and $B$.
5. Setsign of result, $\mathrm{S}_{\mathrm{Z}}=\mathrm{S}_{\mathrm{A}}$
6. Calculate difference, $x=E_{A}-E_{B} \cdot x$ is of 31 bits out of which 8 bits(from mostsignificant bit)
will be in integer part and 23 bits(from least significant bit) will be fraction part.
7. Calculate the value of $2^{*}$ following the steps given below.
7.1 Add one to the integer part and subtract the fraction partfrom one.
7.2 Initialize the variable of type std_logic_vector with name rega and setitequal to 1.
7.3 For $k$ starting from 0 to 22 repeat the steps from 7.4 to 7.5
7.4 If $F(k)=$ ' 1 ' then rega $=$ rega*rom $1(k)$.
7.5 Incrementk.
7.6 Right shift the rega by I times. Save the final result in a variable m. i.e. $m=2^{*}=2^{-1.5}$
8. Calculate the value of $\log (1+m)$ following the steps given below.
8.1 Add 1 to m and store the result in variable rega.
8.2 Initialize the variable oftype std_logic_vectorwith name regb.
8.3 For $k$ starting from 0 to 22 repeat the steps from 8.4 to 8.6 .
8.4 If rega $>=\operatorname{rom} 1(22-i)$, then $\operatorname{Set} \operatorname{regb}(22-i)=11$ and rega $=$ rega*rom2(22-I).
8.5 If rega < rom $1(22-i)$, then Setregb(22-i) $={ }^{\prime} 0$ '.
8.6 Incrementk.
9. $\quad$ Add $\mathrm{E}_{\mathrm{A}}$ and $\log _{2}(1+\mathrm{m})$ to get the result exponent $\mathrm{E}_{2}$.
10. Check for overflow/underflow.
11. Assemble the result in to 32 bit.
B. LNS Subtraction
1) LNS Subtraction Algorithm $1[11,12,14,18]$ :
1. Separate the sign and fixed point exponent bits of both operands.
2. Generate the ROM values for the function $f(d)=\log _{2}$ ( $1-2^{-d}$ ) of suitable size using $\mathrm{C}++$ and store that in a constant two dimensional array.
3. If $|A|<|B|$, then swap the numbers A and $B$.
4. Sign of result, $S_{z}=S_{A}$.
5. Calculate difference, $x=E_{A}-E_{B}$.
6. Use the second order polynomial interpolation method to obtain the value of $\log _{2}\left(1-2^{-x}\right)[15,16]$.
7. Add $E_{A}$ and $\log _{2}\left(1-2^{-d}\right)$ to get the result exponent $E_{2}$.
8. Check for overflow/underflow.
9. Assemble the result in to 32 bit LNS format.
2) LNS SubtractionAlgorithm 2 [17]:
1. Separate the sign and fixed point exponent bits of both operands.
2. Generate the ROM values for the function $f$ (d) $=\sqrt[1]{2}$ where $i=2,4,8,16,32 \ldots \ldots \ldots . . . . . .3388608$
i.e. of size 23 using $\mathrm{C}++$ and store that in a constant two dimensional array rom1.
3. Generate the ROM values for the function $f$ (d) $=\sqrt[6]{2^{-1}}$ where $i=2,4,8,16,32 \ldots . .8388608$
i.e. of size 23 using $\mathrm{C}++$ and store that in a constant two dimensional array rom2.
4. If $|A|<|B|$, then swap the numbers A and $B$.
5. Sign of result, $S_{Z}=S_{A}$.
6. Calculate difference, $x=E_{A}-E_{B} \cdot x$ is 31 bits out of which 8 bits(from mostsignificant bit)
will be in integer part(I) and 23 bits(from least significant bit) will be fraction part(F).
7. Calculate the value of $2^{-\times}$following the same steps as in step number 7 of LNS addition algorithm 2 .
8. Calculate the value of $\log (1-m)$ following the same steps as in step number 8 of LNS addition algorithm 2.
9. $\quad$ Add $E_{A}$ and $(1-m)$ to get the result exponent $E_{2}$.
10. Check for overflow/underflow.
11. Assemble the result in to 32 bit LNS format.
C. LNS Multiplication Algorithm $[11,18]$
12. Separate the sign and fixed point exponent bits of both operands.
13. Compute the sign of the result: $S_{Z}=S_{A} X O R S_{B}$
14. $E_{Z}=E_{A}+E_{B}$.
15. Check for overflow/underflow.
16. Assemble the result in to 32 bit LNS format.
D. LNS DivisionAlgorithm [11,18]
17. Separate the sign and fixed point exponent bits of both operands.
18. Compute the sign of the result: $S_{Z}=S_{A} X O R S_{B}$.
19. $E_{Z}=E_{A}+E_{B}$.
20. Check for overflow/underflow.
21. Assemble the result in to 32 bit LNS format.

## V. RESULTS

Tables I - IV show the synthesis results for different FP and LNS operations. Tables V \& VI show the variation of accuracy for LNS addition and subtraction as the size of ROM varies. In tables V and VI , all results are shown in decimal number format after conversion from LNS for easy comparison.

Table I. Addition Synthesis Results

| Number system |  | $\begin{aligned} & \text { Size of } \\ & \text { ROM } \end{aligned}$ | Number of Slices | Number of 4 input LUTs | Total delay (in ns) | Total memory usage (in KB) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| FP |  | 0 | 476 | 841 | 53.77 | 76740 |
| $\underset{Z}{n}$ | Algorithm 1 | 92 | 2959 | 3904 | 224.52 | 136196 |
|  |  | 184 | 3173 | 4302 | 224.68 | 143364 |
|  | Algorithm 2 | 46 | 26691 | 43902 | 2998.07 | 1111860 |

Table II. Subtraction Synthesis Results

| Number system |  | Size of ROM | Number of Slices | Number of 4 input LUTs | Total delay (in ns) | $\begin{aligned} & \text { Total memory } \\ & \text { usage } \\ & \text { (in KB) } \end{aligned}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | FP | 0 | 477 | 851 | 54.14 | 77828 |
| $n_{1}^{n}$ | Algorithm 1 | 184 | 6894 | 9096 | 219.29 | 169988 |
|  |  | 192 | 6720 | 9007 | 223.84 | 168964 |
|  |  | 208 | 6632 | 9007 | 224.53 | 167940 |
|  |  | 240 | 6714 | 9189 | 224.93 | 171012 |
|  |  | 304 | 6791 | 9462 | 223.63 | 174084 |
|  |  | 432 | 7447 | 10577 | 222.87 | 188804 |
|  | Algorithm 2 | 46 | 27519 | 45263 | 3047.80 | 1137524 |

Table III. Multiplication Synthesis Results

| Number <br> system | Size of <br> ROM | Number of <br> Slices | Number of 4 <br> input LUTs | Total <br> delay <br> (in ns) | Ttal memory <br> usage <br> (in KB) |
| :---: | :---: | :---: | :---: | :---: | :---: |
| FP | 0 | 672 | 1232 | 81.14 | 78852 |
| LNS | 0 | 56 | 64 | 37.37 | 64452 |

Table IV. Division Synthesis Results

| Number <br> system | Size of <br> ROM | Number of <br> Slices | Number of 4 <br> inputLUTs | Total delay <br> (in ns) | Total memory <br> usage <br> (in KB) |
| :---: | :---: | :---: | :---: | :---: | :---: |
| FP | 0 | 646 | 1197 | 171.36 | 76804 |
| LNS | 0 | 71 | 64 | 37.42 | 65404 |

Table V. LNS Addition Examples

| A | B | Exact result | Algorithm 1 |  | Algorithm 2 |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Size of ROM |  |  |
|  |  | 92 | 184 |  |  |
| 57.88618 | 16.92117 | 74.80735 | 74.80672 | 74.80718 | 74.80734 |
| 54.24420 | 48.25241 | 102.49661 | 108.48840 | 102.49658 | 102.49658 |
| 57.88618 | 48.25241 | 106.13859 | 106.13848 | 106.13855 | 106.13855 |

Table VI. LNS Subtraction Examples

| A | B | Exact result | Algorithm 1 |  |  |  |  |  | Algori <br> hm 2 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Size of ROM |  |  |  |  |  |  |
|  |  |  | 184 | 192 | 208 | 240 | 304 | 432 |  |
| 57.8861 | 16.921 | 40.965 | 40.965 | 40.965 | 40.965 | 40.9659 | 40.965 | 40.965 | 40.965 |
| 8 | 17 | 01 | 94 | 94 | 94 | 4 | 94 | 94 | 00 |
| 54.2442 | 48.252 | 5.9917 | 7.4400 | 6.0755 | 5.9970 |  | 5.9918 | 5.9918 | 5.9918 |
| 0 | 41 | 9 | 2 | 7 | 1 | 5.9923 | 8 | 0 | 0 |
| 57.8861 | 48.252 | 9.6337 | 9.6795 | 9.6435 | 9.6358 | 9.63399 | 9.6338 | 9.6337 | 9.6337 |
| 8 | 41 | 7 | 8 | 1 | 4 | 9.63399 | 1 | 8 | 8 |

## VI. CONCLUSION

LNS has very efficient implementation of multiplication and division operations in comparison to the floating point. But LNS main disadvantage is its addition and subtraction operations. To obtain good accuracy in LNS addition and subtraction, more values should be stored in the ROM. As a result, FPGA utilization increases. LNS addition and subtraction require different set of values to be stored in ROM i.e. same ROM can not be used for both operations.

FP addition and subtraction are simple and does not require ROM. The problem is more aggravate in subtraction because the value of $\log _{2}{ }^{x}$ varies from -1 to infinity as $x$ varies from 0.5 to 0 . These values of $x$ do not occur during addition. So more values are stored in ROM for $x$ variation between 0.5 and 0 . This is the reason that in LNS subtraction while increasing theROM size, the values are added for the variation of $x$ from 0.5 to 0 and keeping rest of the ROM same.As a result in table V , in
the first example result is same for all sizes of ROM for algorithm 1 because for that $x$ is 1.77439 . There are algorithms for LNS addition and subtraction (LNS addition algorithm 2 and LNS subtraction algorithm 2) for which number of values in the ROM are fixed and have good accuracy, but they require so much number of FPGA slices that their FPGA implementation is of no use. So the final choice left is to use the floating point representation to represent the large values of real numbers.

## ACKNOWLEDGMENT

This work was supported by Special Man Power Development in VLSI \& Related Softwares, Phase-II (SMDP-II), Ministry of Information Technology, and Government of India.

## REFERENCES

[1] IEEE Standards Board, "IEEE Standard for Binary Floating point Arithmetic," 1985. Technical Report ANSI/IEEE Std 754-1985, The Institute of Electrical and Electronics Engineers, New York.
[2] E. Swartzlander and Aristides G. Alexopoulos, December 1975." The Sign/Logarithm Number System," IEEE Transactions on Computers, vol. C-24, no. 12, pp. 1238-1242.
[3] I. Koren, 2002. "ComputerArithmeticAlgorithms", A.K. Peters Ltd., $2^{\text {nd }}$ edition.
[4] Douglas L. Perry, 2002. "VHDL programming by example," Tata McGraw Hills publisher, Fourth edition.
[5] Wayne Wolf, 2005. "FPGA- Based System Design," Pearson education, First edition.
[6] Loucas Louca, Todd A. Cook and William H. Johnson, April 1996. "Implementation of IEEE Single Precision Floating Point Addition and Multiplication on FPGAs, "IEEE Symposium on FPGAs for Custom Computing Machines, pp. 107-116.
[7] N.Shirazi, A.Walters and P. Athanas, April 1995. "QuantitativeAnalysis of Floating Point Arithmetic on FPGA Based Custom Computing Machines," IEEE Symposium on FPGAs for Custom Computing Machines, pp. 155-162.
[8] Jian Liang, Russell Tessier and Oskar Mencer, April 2003. "Floating Point Unit Generation and Evaluation for FPGAs," IEEE Symposium onField-Programmable Custom Computing Machines, pp. 185-194.
[9] Pierre Deschamps, Jean Antoine Bioul and Gustavo D. Sutter, 2006. "Synthesis of arithmetic circuits -FPGA, ASIC and Embedded System," John Wiley \& Sons, Inc., publication.
[10] M. Morris Mano, 2002. "Computer System Architecture," Pearson Education Inc., $3^{\text {rd }}$ edition.
[11] J.N. Coleman, E.I. Chester, April 1999. "A 32-Bit Logarithmic Arithmetic Unit and its Performance Compared to Floating-Point," 14th IEEE Symposium on Computer Arithmetic, pp. 142-151.
[12] Michael Haselman, Michael Beauchamp, Aaron Wood, Scott Hauck, Keith Underwood and K. Scott Hemmert April 2005. "A Comparison of Floating Point and Logarithmic Number Systems on FPGAs," 13th Annual IEEE Symposium on Field-Programmable Custom Computing Machines, pp 180-190.
[13] Y. Wan and C.L. Wey, May 1999. "Efficient algorithms for binary logarithmic conversion and addition," IEE Proceedings on Computers and Digital Techniques, vol. 146, no. 3, pp 168-172.
[14] Sheng-Chieh Huang, Liang-Gee Chen and Thou-Ho Chen June 1994. "The chip design of a 32-b logarithmic number system," IEEE International Symposium on Circuits and Systems, vol. 4, pp 167-170.
[15] D.M. Lewis, July 1993. "An Accurate LNS Arithmetic Unit Using Interleaved Memory Function Interpolator," Proc. $11^{\text {th }}$ IEEE Symposium ComputerArithmetic, pp. 2-9.
[16] D. M. Lewis, August 1994. "Interleaved Memory Function Interpolators with Applications to an Accurate LNS Arithmetic Unit," IEEE Transactions on Computers, vol. 43, no. 8, pp. 974-982.
[17] Demetrios K. Kostopoulos, November 1991. "An Algorithm for the Computation of Binary Logarithms," IEEE Transactions on Computers, vol. 40, no. 11, pp. 1267-1270.
[18] Lawrence K. Yu and David M. Lewis, October 1991. "A 30-b Integrated Logarithmic Number System processor," IEEE journal of Solid-state Circuits, vol. 26, no. 10, pp. 1433-1440.


Amit Kumar received B. Tech degree in Electronics and Instrumentation Control Engg. from YMCA Institute of Engineering in 2006. He is currently pursuing M. Tech degree at Indian Institute of Technology Roorkee in specialisation Semiconductor Devices and VLSI Technology. He worked on the Floating Point and Logarithmic Number system for M. Tech Dissertation.


Dr. Saxena obtained Ph.D. from Department of Electronics and Electrical Engg.,UMIST/Sheffield University (UK) in 1975 and 1978, respectively as one of the two Government of India National Scholars.He is a Professor in Solid State Electronics and VLSI Technology in IIT - Roorkee. The discovery of a level in GaAlAs is christened as 'Saxena's Deep Donor' by Philips Research Laboratory, Eindhoven (Netherlands). He is also a winner of INSA Young Scientist, Roorkee University Khosla Award Gold Medal, Kothari Scientific Research Institute Award, S. K. Mitra Memorial Awards (twice) of IETE and Bharat Excellence Award. He has published about 175 research papers in international journals and conference proceedings with very high citation index of about 775 so far..Dr. Saxena has supervised many Ph.D.IM.E./M.Tech./M.Phil. theses in the area of VLSI design, metal-semiconductor ohmic and nonohmic contacts, band structure and deep energy levels of GaAs, GaAIAs, GaP, InP, etc and quantum wells under pressure. He has also written AICTE sponsored nine volumes on the related subjects for working professionals.

