Sie sind auf Seite 1von 21

A Wallace tree is an efficient hardwire implementation of a digital circuit that multiplies two integers.

The Wallace tree has three steps: Multiply (that is - AND) each bit of one of the arguments, by each bit of the other, yielding n2 results. Depending on position of the multiplied bits, the wires carry different weights, for example wire of bit carrying result of a2b3 is 32. Reduce the number of partial products to two by layers of full and half adders. Group the wires in two numbers, and add them with a conventional adder.

Take any three wires with the same weights and input them into a full adder. The result will be an output wire of the same weight and an output wire with a higher weight for each three input wires.

If there are two wires of the same weight left, input them into a half adder. If there is just one wire left, connect it to the next layer.

Suppose two numbers are being multiplied: a3a2a1a0 X b3b2b1b0 ___________________________________ a3b0 a2b0 a1b0 a0b0 a3b1 a2b1 a1b1 a0b1 a3b2 a2b2 a1b2 a0b2 a3b3 a2b3 a1b3 a0b3 _____________________________________

a3b3 a2b3 a1b3 a0b3 a0b2 a0b1 a0b0 a3b2 a2b2 a1b2 a1b1 a1b0 a3b1 a2b1 a2b0 a3b0

Example for 4bit Multiplication using Wallace tree:


Partial Products

1111 x 1101 1 1 1 1

First stage

1 1

1 1 0

0 1

1 0 0 0 0 1 1 1 1 1 1 1 1
Second stage

1 0 0 1 1 HA

Final Adder

1 0 1

1 1 1 1 0 1 11 1 1 1 0 1 1 FA 0 0 1 1

1
1 1 0

0 0 1 1 1 1 1 0
0 0 0 1 1

a1b3

a3b0
a2b1

Partial products

a3b3

a2b3 a3b2

a3b1

a2b2

a1b2 a2b0 a1b0 a0b3 a1b1 a0b2 a0b1 a0b0

HA

FULL ADDER

HALF ADDER

Each layer of the tree reduces the number of vectors by a factor of 3:2 Minimum propagation delay. The benefit of the Wallace tree is that there are only O(log n) reduction layers, but adding partial products with regular adders would require O(log n)2 time.

Wallace trees do not provide any advantage over ripple adder trees in many FPGAs. Due to the irregular routing, they may actually be slower and are certainly more difficult to route. Adder structure increases for increased bit multiplication.

Wallace

Tree multiplier can also be implemented using Carry Save Adders. Sometimes Wallace Tree Multiplier is Combined with Booth Encoding. Various other researches have been done to reduce the number of adders, for higher order bits such as 16 & 32. Applications, as the use in DSP for performing FFT,FIR, etc.,

Das könnte Ihnen auch gefallen