International Journal of Advanced Research in Engineering and Technology (IJARET)
Volume 12, Issue 2, February 2021, pp.743-748 Article ID: IJARET_12_02_074
Available online at http://www.iaeme.com/IJARET/issues.asp?JType=IJARET&VType=12&IType=2
ISSN Print: 0976-6480 and ISSN Online: 0976-6499
DOI: 10.34218/IJARET.12.2.2021.074
© IAEME Publication
Scopus Indexed
DESIGN OF AN AREA EFFICIENT 16-BIT
LOGARITHMIC MULTIPLIER
R. Odaiah
Associate Professor, Department of Electronics and Communication Engineering,
Geethanjali College of Engineering and Technology, Hyderabad, India
M. Krishna
Assistant Professor, Department of Electronics and Communication Engineering,
Geethanjali College of Engineering and Technology, Hyderabad, India
T. Sai Ganesh, A. Vineeth, M. Bhaskar Yadav
Department of Electronics and Communication Engineering,
Geethanjali College of Engineering and Technology, Hyderabad, India
ABSTRACT
Digital signal processing applications often use major mathematical operations
such as multiplication, which consume more power and time. Operations like Fast
Fourier Transform, Convolution and correlation depends heavily on a large number of
multiplications. There are many techniques available to perform multiplications. One
such technique is logarithmic multiplication. logarithmic multiplication is achieved by
adding the binary logarithms of two numbers and deriving the antilog of the result. In
this paper, an efficient algorithm for logarithmic multiplication is presented with the
use of adders, decoders, multiplexers and a few combinational circuits that effectively
reduce the power and area of the multiplier.
Key words: Logarithmic number system, Digital Signal Processing, logarithmic
multiplication, Verilog HDL, Multiplexer.
Cite this Article: R. Odaiah, M. Krishna, T. Sai Ganesh, A. Vineeth and M. Bhaskar
Yadav, Design of an Area Efficient 16-bit Logarithmic Multiplier, International
Journal of Advanced Research in Engineering and Technology (IJARET), 12(2), 2021,
pp. 743-748.
http://www.iaeme.com/IJARET/issues.asp?JType=IJARET&VType=12&IType=2
1. INTRODUCTION
Multipliers play an important role in today’s digital signal processing and various other
applications. With advances in technology, many researchers have tried and are trying to design
multipliers which offer either of the following design targets– high speed, low power
consumption, regularity of layout and hence less area or even combination of them in one
http://www.iaeme.com/IJARET/index.asp
743
[email protected]
Design of an Area Efficient 16-bit Logarithmic Multiplier
multiplier thus making them suitable for various high speed, low power and compact VLSI
implementation. The common multiplication method is “add and shift” algorithm.
In order to reduce the error generated by the Logarithmic Number System, techniques such
as iterative and non-iterative methods are used.
Mitchell algorithm (MA) is one of the non- iterative multiplication methods are used. In
MA, log(1+m) is approximated as m to reduce the complexity of logarithms. Here m represents
the mantissa of a number. But MA is proved to be generating nearly 11% error in the product
as stated.
To overcome such errors, an iterative algorithm similar to Mitchell algorithm was proposed.
In this method, the product is given by the sum of the approximate product and error. The error
here refers to the residues that are discarded in the process. These residues are again fed into
the algorithm and the products are added to get result with the least possible error. In our
presented architecture, we optimized the performance of the algorithm by redesigning the
shifter and leading one detector.
A Logarithmic number system is introduced to simplify multiplication, especially in cases
when the accuracy requirements are not rigorous. As shown in figure 1. general blockdiagram
of logarithmicnumber system. In LNS two operands are multiplied by finding their logarithms,
adding them, and after that looking for the antilogarithm of the sum.
The logarithm of the product is: Log2(N1. N2) =K1+K2+log2(1+X1) +log2 (1+X2)
where K1 and K2 represents the places of the most significant operands’ bits with the value
of ‘1’For 16-bit numbers the range is from 0 to 15. The fractions X1 and X2 are in range(0,1).
2. LOGARITHMIC MULTIPLIER
In this section, Mitchell’s algorithm based logarithmic multiplier is explained. Mitchell’s
Algorithm based Logarithmic multiplier is shown in fig 2
2.1 Steps
•
•
•
•
•
•
•
•
•
•
•
Inputs N1, N2 are n-bit binary numbers to be multiplied, Output Papprox is product
of that two numbers with 2n-bits.
N1, N2 are taken as inputs to the Leading One Detectors (LODs), outputs of LODs
will be 2^x1 and 2^x2. Where x1 and x2 are the leading one positions of N1 and N2.
With inputs as 2^x1 and 2^x2, encoders calculate the values of x1 and x2.
4. (N1 – 2^x1) and (N2 – 2^x2) are the outputs of the two XOR banks, where the
operands and output of LODs are given as input.
By using Barrel Shifters, (N1 2^x1) is left-shifted by x2 bits and (N2 – 2^x2) is leftshifted by x1 bits then the obtained result is (N1 – 2^x1)2^x2 and (N2 – 2^x2)2^x1.
The above result is added using 32-bit adder to obtain the resultant sum as:
(N1 –2^x1)2^x2 +(N2 – 2^x2)2^x1.
The values of x1 and x2 obtained in step-3 are added and the result is given as an
input to the Decoder which gives the output as 2^x1+x2.
The results obtained in the step 6 and step 7 are added to give output as 2^x1+x2
+ (N1 – 2^x1)2^x2 +(N2 – 2^x2)2^x1.
The outputs of XOR banks are taken as error operands and repeat the above same
procedure, the accurate product can be achieved at some iteration.
http://www.iaeme.com/IJARET/index.asp
744
[email protected]
R. Odaiah, M. Krishna, T. Sai Ganesh, A. Vineeth and M. Bhaskar Yadav
Figure 1 Mitchell’s algorithm based logarithmic multiplier
3. BRAUN ARRAY MULTIPLIER
Array Multiplier is well known due to its regular structure as shown in the fig- 2b. Multiplier
circuit is based on add and shift algorithm. Each partial product is generated by the
multiplication of the multiplicand with one multiplier bit.
The partial product are shifted according to their bit orders and then added. The addition
can be performed with normal carry propagate adder. N-1 adders are required where n is the
multiplier length.
Although the method is simple as it can be seen from the below example shown in the fig
2a. Example of 4- bit multiplication. The addition is done serially as well as in parallel. To
improve on the delay and area the CRAs are replaced with Carry Save Adders, in which every
carry and sum signal is passed to the adders of the next stage. Final product is obtained in a
final adder by any fast adder (usually carry ripple adder). In array multiplication we need to
add, as many partial products as there are multiplier bits
Although the method is simple as it can be seen from the below example shown in the fig
2a. Example of 4- bit multiplication. The addition is done serially as well as in parallel. To
improve on the delay and area the CRAs are replaced with Carry Save Adders, in which every
carry and sum signal is passed to the adders of the next stage. Final product is obtained in a
final adder by any fast adder (usually carry ripple adder). In array multiplication we need to
add, as many partial products as there are multiplier bits.
http://www.iaeme.com/IJARET/index.asp
745
[email protected]
Design of an Area Efficient 16-bit Logarithmic Multiplier
Figure 2a Example of 4bit multiplication
Figure 2b Structure of array multiplier
4. SIMULATION RESULTS
Figure 3 Logarithmic multiplier output
http://www.iaeme.com/IJARET/index.asp
746
[email protected]
R. Odaiah, M. Krishna, T. Sai Ganesh, A. Vineeth and M. Bhaskar Yadav
Figure 4 Braun array multiplier output
5. COMPARISON
Table 1
Parameter
Logarithmic
multiplier
Delay
24.637ns
Braun
array
multiplier
417.779ns
Levels of logic
Total Gates count
45
2,773
392
23,313
AND gate count
OR gate count
NOT gate count
XOR Gate count
1,636
381
692
64
12,398
4,612
6,303
--
6. CONCLUSIONS
From the above parameters compared in the table comparison of various parameters, we can
come to a conclusion that all factors like Delay, gate count and Levels of Logic are very less
for the Logarithmic Multiplier designed using Mitchell’s algorithm than that of Braun Array
Multiplier. Hence, the logarithmic multipliers can be used in the Signal processing applications
so that the area can be reduced and more efficient output can be observed.
http://www.iaeme.com/IJARET/index.asp
747
[email protected]
Design of an Area Efficient 16-bit Logarithmic Multiplier
REFERENCES
[1]
Babić, Z., Avramović, A. and Bulić, P. (2011). “An iterative logarithmic multiplier”,
Microprocessors and Microsystems, 35(1), pp.23-33.
[2]
Weiqiang Liu, Danye Wang, Jiahua Xu, Chenghua Wang, Fabrizio Lombardi, and Paolo
Montuschi. “Design and Evaluation of Approximate Logarithmic Multipliers for Low Power
Error-Tolerant Applications”, IEEE Transactions on Circuits and Systems I: Regular Papers,
65(9), pp.2856-2868.
[3]
Alelsej Avramovk, Zdenka babi, Patrido Bulic, “A simple pipelined logarithmic multiplier,”
2010 IEEE International Conference on Computer Design, 2010.
[4]
S. Ahmed and M. Srinivas, "An Improved Logarithmic Multiplier for Media Processing",
Journal of Signal Processing Systems, 2018. Available: 10.1007/s11265-018-1350-2.
[5]
R. K. Agrawal and H. M. Kittur, “ASIC based logarithmic multiplier using iterative pipelined
architecture,” 2013 IEEE Conference on Information And Communication Technologies, 2013.
[6]
Hoefflinger, F. Warkowski, and B. M. Selzer, “Digital logarithmic CMOS multiplier for veryhigh- speed signal processing,” Proceedings of the IEEE 1991 Custom Integrated Circuits
Conference.
[7]
Ch. Achuth Reddy, Alen Anurag Pandit, Dr. Gautam Narayan, “Design and Simulation of
16×16 bit Iterative LogarithmicMultiplier for Accurate Results,” 2018 Second International
Conference on Electronics, Communication and Aerospace Technology (ICECA), 2018.
[8]
Raymond E. Siferd, Khalid H. Abed, “VLSI Implementations of Low Power Leading-One
Detector Circuits,” Proceedings of the IEEE SoutheastCon 2006.
http://www.iaeme.com/IJARET/index.asp
748
[email protected]