Sunteți pe pagina 1din 9

INTERNATIONAL JOURNAL

OF PROFESSIONAL ENGINEERING STUDIES Volume VIII /Issue 4 / APR


2017

DESIGN AND IMPLEMENTATION OF MAC UNIT


FOR DSP APPLICATIONS USING VERILOG HDL
Amit kumar 1 Nidhi Verma 2
amitjaiswalec162icfai@gmail.com1 verma.nidhi17@gmail.com2
1 2
PG Scholar, VLSI, Bhagwant University Assistant Professor, Bhagwant University
Ajmer, Sikar Road Ajmer,Rajasthan,India. Ajmer, Sikar Road Ajmer,Rajasthan,India.

Abstract: In this paper, we proposed a new lowering down the power consumption to
architecture of multiplier -and- accumulator prolong the operating time on the basis of given
(MAC) for high-speed arithmetic and low limited energy supply from batteries. Owing to
power. With the rapid advances in multimedia the vigorous development of the wireless
and communication system, high capacity signal infrastructure and the personal electronic
processing are in demand, so High Speed MAC devices like video mobile phones, mobile TV
are essential to improve performance of signal sets, PDAs, etc., multimedia and DSP
processing System. Multiplication occurs applications have been adopted in wireless
frequently in finite impulse response filters, fast environments. Increasing demands of high
Fourier transforms, discrete cosine transforms, speed data signal processing motivated the
convolution, and other important DSP and researchers to seek fastest processors. The
multimedia kernels. The objective of a good multiplier and multiplier-and-accumulator
multiplier and accumulator (MAC) is to provide (MAC) [1] are the building blocks of the
a physically compact, good speed and low processor and has a great impact on the speed of
power consuming chip. The proposed SPST the processor. MAC is the necessary element of
separates the target designs into two parts, i.e., the digital signal and image/audio processing
the most significant part and least significant system such as filtering, convolution and inner
part (MSP and LSP), and turns off the MSP products hence high speed is crucial to develop
when it does not affect the computation results for real processing applications. Many
to save power. In this paper, we propose a high researchers have attempted in designing MAC
speed MAC adopting the new SPST for high computational performance and low
implementing approach. This multiplier and power consumption. High throughput MAC is
accumulator is designed by equipping the always a key factor to achieve high performance
Spurious Power Suppression Technique (SPST) digital signal processing applications for real
on a modified Booth encoder which is time signal processing applications. Since the
controlled by a detection unit using an AND multiplier requires the longest delay among the
gate. The modified booth encoder will reduce basic operation in digital system, the critical
the number of partial products generated by a path is limited by the multiplier. Multiplier
factor of 2. The SPST adder will avoid the basically consists of three operational steps:
unwanted addition and thus minimize the Booth Encoder, Partial product reduction
switching power dissipation. network (Wallace Tree) and final adder. For
Keywords: Booth encoder, computer high speed multiplication, Modified Booth
arithmetic, digital signal processing, spurious Algorithm (MBA) [4] is most commonly used,
power suppression technique, low power. in which partial product is generated from
Multiplicand (X) and Multiplier (Y) .Booth
I. INTRODUCTION multiplication allows for the smaller ,faster
multiplication circuits through encoding the
One of the accompanying challenges in signed bits to 2’s complement which is also the
designing ICs for portable electrical devices is

IJPRES
49
INTERNATIONAL JOURNAL
OF PROFESSIONAL ENGINEERING STUDIES Volume VIII /Issue 4 / APR
2017

standard technique in chip design and provide CSA structure is proposed to reduce the critical
substantial improvement by reducing the partial path and improve the output rate. It uses MBA
products. Although the partial products are algorithm based on 1’s complement number
further reduced by using higher radix (4, 8, 16, system. A modified array structure for the sign
32) Booth Encoder which increases complexity bits is used to increase the density of the
and improves the performance. operands. A carry look-ahead adder (CLA) is
II. OVER VIEW OF MAC inserted in the CSA tree to reduce the number of
In this section, basic MAC operation is bits in the final adder. In addition, in order to
introduced. A multiplier can be divided into increase the output rate by optimizing the
three operational steps. The first is radix-2 pipeline efficiency, intermediate calculation
Booth encoding in which a partial product is results are accumulated in the form of sum and
generated from the multiplicand (X ) and the carry instead of the final adder outputs.
multiplier (Y). The second is adder array or A general hardware architecture of this
partial product compression to add all partial MAC is shown in Fig. 2. It executes the
products and convert them into the form of sum multiplication operation by multiplying the
and carry. The last is the final addition in which input multiplier and the multiplicand. This is
the final multiplication result is produced by added to the previous multiplication result as the
adding the sum and the carry. If the process to accumulation step.
accumulate the multiplied results is included, a
MAC consists of four steps, as shown in Fig. 1,
which shows the operational steps explicitly.

Fig. 2. Hardware architecture of general MAC.


Modified Booth Encoder
In order to achieve high-speed
multiplication, multiplication algorithms using
parallel counters, such as the modified Booth
algorithm has been proposed, and some
multipliers based on the algorithms have been
implemented for practical use. This type of
multiplier operates much faster than an array
multiplier for longer operands because its
computation time is proportional to the
logarithm of the word length of operands.

Figure 1: Basic Arithmetic Steps of Multiplication


and Accumulation

In this paper, a new architecture for a high-


speed MAC is proposed. In this MAC, the
computations of multiplication and
accumulation are combined and a hybrid-type Fig 3. Modified Booth Encoder

IJPRES
50
INTERNATIONAL JOURNAL
OF PROFESSIONAL ENGINEERING STUDIES Volume VIII /Issue 4 / APR
2017

Booth multiplication is a technique that reduce the number of partial products for
allows for smaller, faster multiplication circuits, roughly one half. For multiplication of 2‟s
by recoding the numbers that are multiplied. It is complement numbers, the two-bit encoding
possible to reduce the number of partial using this algorithm scans a triplet of bits. When
products by half, by using the technique of the multiplier B is divided into groups of two
radix-4 Booth recoding. The basic idea is that, bits, the algorithm is applied to this group of
instead of shifting and adding for every column divided bits. Figure 4, shows a computing
of the multiplier term and multiplying by 1 or 0, example of Booth multiplying two numbers
we only take every second column, and multiply ”2AC9” and “006A”. The shadow denotes that
by ±1, ±2, or 0, to obtain the same results. The the numbers in this part of Booth multiplication
advantage of this method is the halving of the are all zero so that this part of the computations
number of partial products. To Booth recode the can be neglected. Saving those computations
multiplier term, we consider the bits in blocks of can significantly reduce the power consumption
three, such that each block overlaps the previous caused by the transient signals. According to the
block by one bit. Grouping starts from the LSB, analysis of the multiplication shown in figure 4,
and the first block only uses two bits of the we propose the SPST-equipped modified-Booth
multiplier. Figure 3 shows the grouping of bits encoder, which is controlled by a detection unit.
from the multiplier term for use in modified The detection unit has one of the two operands
booth encoding. as its input to decide whether the Booth encoder
calculates redundant computations. As shown in
figure 9. The latches can, respectively, freeze
the inputs of MUX-4 to MUX-7 or only those of
MUX-6 to MUX-7 when the PP4 to PP7 or the
Fig.3.1 Grouping of bits from the multiplier PP6 to PP7 are zero; to reduce the transition
term power dissipation. Figure 10, shows the booth
Each block is decoded to generate the partial product generation circuit. It includes
correct partial product. The encoding of the AND/OR/EX-OR logic.
multiplier Y, using the modified booth
algorithm, generates the following five signed III. Partial product generator:
digits, -2, -1, 0, +1, +2. Each encoded digit in
the multiplier performs a certain operation on
the multiplicand, X, as illustrated in Table 1

For the partial product generation, we Fig4.Booth partial product selector logic
adopt Radix-4 Modified Booth algorithm to

IJPRES
51
INTERNATIONAL JOURNAL
OF PROFESSIONAL ENGINEERING STUDIES Volume VIII /Issue 4 / APR
2017

The multiplication first step generates


from A and X a set of bits whose weights sum is
the product P. For unsigned multiplication, P
most significant bit weight is positive, while in
2's complement it is negative.
The partial product is generated by
doing AND between ‘a’ and ‘b’ which are a 4
bit vectors as shown in fig. If we take, four bit
multiplier and 4-bit multiplicand we get sixteen
partial products in which the first partial product
is stored in ‘q’. Similarly, the second, third and
fourth partial products are stored in 4-bit vector
n, x, y.
The multiplication second step reduces
the partial products from the preceding step into Fig 6.Booth Decoder
two numbers while preserving the weighted
III. Existing System
sum. The sough after product P is the sum of -
NR4SD Encoding Scheme
those two numbers. The two numbers will be
added during the third step The "Wallace trees"
synthesis follows the Dadda's algorithm, which
assures of the minimum counter number. If on
top of that we impose to reduce as late as (or as
soon as) possible then the solution is unique.
The two binary number to be added during the
third step may also be seen a one number in
CSA notation (2 bits per digit).

Fig.7. Block Diagram of the NR4SD- Encoding


Scheme at the (a) Digit and (b) Word Level.

The following Boolean equations summarize the


HA* operation:

Fig 5.Booth Encoder

Calculate the value of the

IJPRES

52
INTERNATIONAL JOURNAL
OF PROFESSIONAL ENGINEERING STUDIES Volume VIII /Issue 4 / APR
2017

For the computation of the least and the


most significant bits of the partial product we
Table 2 shows how the NR4SD digits are consider and respectively. Note that in case that
formed. The NR4SD encoding signals , the number of the resulting partial products is
of Table 2 are and the most significant MB digit is formed
generated. based on sign extension of the initial 2’s
complement number.
After the partial products are generated,
they are added, properly weighted, through a
Carry-Save Adder (CSA) tree .
Finally, the carry-save output of the
Wallace CSA tree is leaded to a fast Carry Look
Ahead (CLA) adder to form the final result Z =
X . Y.

NR4SD+ Encoding Scheme

Fig. 8. Block Diagram of the NR4SD+ Fig.9 .System Architecture of the NR4SD
Encoding Scheme at the (a) Digit and (b) Word Multipliers
Level. In the pre-encoded MB multiplier
scheme, the coefficient B is encoded off-line
Calculate the value of the
according to the conventional MB form (Table
Table 3 shows how the NR4SD digits are 1). The resulting encoding signals of B are
formed. The NR4SD encoding signals stored in a ROM. The circled part of Fig. 3,
which contains the ROM with coefficients in 2’s
of Table 3 are generated
complement form and the MB encoding circuit,
is now totally replaced by the ROM .The MB
encoding blocks of Fig. 3 are omitted. The new
ROM is used to store the encoding signals of B
and feed them into the partial product generators
(P Pj Generators - PPG) on each clock cycle.
Targeting to decrease switching activity, the
value ’1’ of s j in the last entry of Table 1 is
replaced by ’0’. The sign s j is now given by the
relation:

IJPRES
53
INTERNATIONAL JOURNAL
OF PROFESSIONAL ENGINEERING STUDIES Volume VIII /Issue 4 / APR
2017

However, the ROM width is increased. The SPST uses a detection logic circuit
Each digit requests three encoding bits (i.e., s, to detect the effective data range of arithmetic
two and one (Table 1)) to be stored in the ROM. units, e.g., adders or multipliers. When a portion
Since the n-bit coefficient B needs three bits per of data does not affect the final computing
digit when encoded in MBform, the ROM width results, the data controlling circuits of the SPST
requirement is 3n/2 bits per coefficient. Thus, latch this portion to avoid useless data
the width and the overall size of the ROM are transitions occurring inside the arithmetic units.
increased by 50% compared to the ROM of the Besides, there is a data asserting control realized
conventional scheme. by using registers to further filter out the useless
The system architecture for the pre- spurious signals of arithmetic unit every time
encoded NR4SD multipliers is presented in Fig. when the latched portion is being turned on.
6. Two bits are now stored in ROM: n2j+1, This asserting control brings evident power
n+2j(Table 2) for the NR4SDor n+2j+1, reduction. Figure 5 shows the design of low
n2j(Table 3) for the NR4SD+form. In this way, power adder/subtractor with SPST.
we reduce the memory requirement to +1 bits
per coefficient while the corresponding memory
required for the pre-encoded MB scheme is 3n/2
bits per coefficient. Thus, the amount of stored
bits is equal to that of the conventional MB
design, except for the most significant digit that
needs an extra bit as it is MB encoded.
Compared to the pre-encoded MB multiplier,
where the MB encoding blocks are omitted, the
pre-encoded NR4SD multipliers need extra
hardware to generate the signals of (6) and (8)
for the NR4SD and NR4SD+ form, respectively.
Each partial product of the pre-encoded
NR4SD and NR4SD+ multipliers is
implemented based on Fig. 4c and 4d,
respectively, except for the P Pk 1 that
corresponds to the most significant digit. As this Fig 10. Spurious transition cases in
digit is in MB form, we use the PPG of Fig. 4b multimedia/ DSP processing
applying the change mentioned in Section 4.2
for the s j bit. The partial products, properly AMSP = A[15:8]; BMSP = B[15:8] ;
weighted, and the correction term (COR) of (11) Aand = A[15] A[14] A[8];
are fed into a CSA tree. The input carry cin;j of
(11) is calculated as cin;j = twoj_ onej and cin;j Band = B[15] B[14] B[8];]
= onej for the NR4SDand NR4SD+pre-encoded
multipliers, respectively ,based on Tables 2 and
3. The carry-save output of the CSA tree is
finally summed using a fast CLA adder.
IV.PROPOSED SPST
Besides the explanations presented in our The adder /subtractor is divided into two
former studies, this paper provides further parts, the most significant part (MSP) and the
illustrations of the proposed SPST as described least significant part (LSP). The MSP of the
in the following sections. original adder/subtractor is modified to include
detection logic circuits, data controlling circuits,
sign extension circuits, logics for calculating

IJPRES

54
INTERNATIONAL JOURNAL
OF PROFESSIONAL ENGINEERING STUDIES Volume VIII /Issue 4 / APR
2017

carry in and carry out signals. The most the data latches to let the data in. Hence, the
important part of this study is the design of the delay caused by the detection-logic unit will
control signal asserting circuits, denoted as contribute to the delay of the whole
asserting circuits in Figure 5. Although this combinational circuitry, i.e., the16-bit
asserting circuit brings evident power reduction, adder/subtractor in this design example.
it may induce additional delay. There are two
implementing approaches for the control signal When the detection-logic unit remains its
assertion circuits. The first implementing decision:
approach of control signal assertion circuit is No matter whether the last decision is
using registers. This is illustrated in Figure 6. turning on or turning off the MSP, the delay of
The three output signals of the detection logic the detection logic is negligible because the path
are close, Carr_ctrl, sign. The three output of the combinational circuitry (i.e., the 16-bit
signals the detection logic unit are given a adder/subtractor in this design example) remains
certain amount of delay before they assert. The the same. From the analysis earlier, we can
delay , used to assert the three output signals, know that the total delay is affected only when
must be set in a range of, denotes the data the detection-logic unit turns on the MSP.
transient period the earliest required time of all However, the detection-logic unit should be a
the inputs. This will filter out the glitch signals speed-oriented design. When the SPST is
as well as to keep the computation results applied on combinational circuitries, we should
correct. The restriction that must be greater than first determine the longest transitions of the
to guarantee the registers from latching the interested cross sections of each combinational
wrong values of control usually decreases the circuitry, which is timing characteristic and is
overall speed of the applied designs also related to the adopted technology. The
longest transitions can be obtained from
analyzing the timing differences between the
earliest arrival and the latest arrival signals of
the cross sections of a combinational circuitry.
Then, a delay generator similar to the delay line
used in the DLL

Fig 11. Low-power adder/subtractor design


example adopting the proposed SPST.

When the detection-logic unit turns off the


MSP: Fig 12.SPST Modified Booth encoder
At this moment, the outputs of the MSP are V. Results
directly compensated by the SE unit; therefore, Simulation Results of MAC:
the time saved from skipping the computations
in the MSP circuits shall cancel out the delay
caused by the detection-logic unit.

When the detection-logic unit turns on the


MSP:

The MSP circuits must wait for the


notification of the detection-logic unit to turn on

IJPRES
55
INTERNATIONAL JOURNAL
OF PROFESSIONAL ENGINEERING STUDIES Volume VIII /Issue 4 / APR
2017

Fig 13 Simulation Waveform of MAC heights that provides the minimum number of
reduction stages for a given size multiplier. This
sequence determined by working back from the
final two row matrix, limit the height of each
intermediate matrix to the largest integer that is
no more than 1.5 times the height of its
successor.

Fig 14 Schematic with Basic Inputs and


Output
CONCLUSIONS

In this project, we propose a high speed


low-power multiplier and accumulator (MAC)
adopting the newSPST implementing approach.
This MAC is designed by equipping the
Spurious Power Suppression Technique (SPST)
on a modified Booth encoder which is
controlled by a detection unit using an AND
gate. The modifiedbooth encoder will reduce the
number of partial products generated by a factor REFERENCES
of 2. The SPST adder will avoid the unwanted
addition and thus minimize the switching power [1] T. Stockhammer, M. Hannuksela, and T.
dissipation. The SPST MAC implementation Wiegand, “H.264/AVC in wireless
with AND gates have an extremely high environments,” IEEE Trans. Circuits Syst.
flexibility on adjusting the data asserting time. Video Technol., vol.13, no. 7, pp. 657–673, Jul.
This facilitates the robustness of SPST can 2003.
attain 30% speed improvement and 22% power [2] R. Schafer, T. Wiegand, and H. Schwarz,
reduction in the modified booth encoder. This “The emerging H.264/AVC standard,” EBU
design can be verified using Modelsim and Technique Review Jan. 2003 [Online].
Xilinx using verilog. Available:http://www.ebu.ch/trev_293-
schaefer.pdf
Future Scope: [3] A. Bellaouar and M. I. Elmasry, Low-Power
Digital VLSI Design"Circuitsand Systems.
The proposed system can be done using
Norwell, MA: Kluwer, 1995.
Dadda multiplier, by using this delay will be
[4] A. P. Chandrakasan and R. W. Brodersen,
reduced.
“Minimizing power consumption
The process of Dadda multiplication is as
in digital CMOS circuits,” Proc. IEEE, vol. 83,
follows: The entire 16 × 16 multiplication
no. 4, pp. 498–523, Apr. 1995.
requires six stages. Always the first stage is
[5] K. K. Parhi, “Approaches to low-power
partial products stage, which is obtained by
implementations of DSP systems,”IEEE Trans.
simple multiplication of multiplicand with
Circuits Syst. I, Fundam. Theory Appl., vol. 48,
multiplier. The number of rows (height) present
no.10, pp. 1214–1224, Oct. 2001.
at this stage is 16. Now reduce the number of
[6] K. Choi, R. Soma, and M. Pedram,
rows further in such a way that final stage
“Dynamic voltage and frequency scaling based
contains only two rows. For this, Dadda
on workload decomposition,” in Proc. IEEE Int.
introduces a sequence of intermediate matrix

IJPRES
56
INTERNATIONAL JOURNAL
OF PROFESSIONAL ENGINEERING STUDIES Volume VIII /Issue 4 / APR
2017

Symp.Low Power Electron. Des., 2004, pp. 174–


179.
[7] J. Choi, J. Jeon, and K. Choi, “Power
minimization of functional units by partially
guarded computation,” in Proc. IEEE Int. Symp.
Low Power Electron. Des., 2000, pp. 131–136.
[8] O. Chen, R. Sheen, and S. Wang, “A low-
power adder operating on effective dynamic
data ranges,” IEEE Trans. Very Large Scale
Integr. (VLSI) Syst., vol. 10, no. 4, pp. 435–453,
Aug. 2002.
[9] O. Chen, S.Wang, and Y. W.Wu,
“Minimization of switching activities of partial
products for designing low-power multipliers,”
IEEE Trans. Very Large Scale Integr. (VLSI)
Syst., vol. 11, no. 3, pp. 418–433, Jun.
2003.
[10] L. Benini, G. D. Micheli, A. Macii, E.
Macii, M. Poncino, and R. Scarsi, “Glitch power
minimization by selective gate freezing,” IEEE
Trans. Very Large Scale Integr. (VLSI) Syst.,
vol. 8, no. 3, pp. 287–298, Jun. 2000.

IJPRES

57

S-ar putea să vă placă și