Дерево Уоллеса — различия между версиями
Komarov (обсуждение | вклад) (→Дерево Уоллеса) |
Komarov (обсуждение | вклад) (→Дерево Уоллеса) |
||
Строка 12: | Строка 12: | ||
С помощью этого элемента на каждом шаге производятся следующие операции: | С помощью этого элемента на каждом шаге производятся следующие операции: | ||
− | # Берутся тройки чисел <math>(x_1, x_2, x_3)</math>, <math>(x_4, x_5, x_6)</math> <math>\ldots</math>. При этом какие-то числа могут остаться. | + | # Берутся тройки чисел <math>(x_1, x_2, x_3)</math>, <math>(x_4, x_5, x_6)</math>, <math>\ldots</math>. При этом какие-то числа могут остаться. |
# Для каждой тройки применяется элемент <math>3\to2</math>. | # Для каждой тройки применяется элемент <math>3\to2</math>. | ||
− | # | + | # Повторяются пункты 1 и 2 пока не осталось 2 числа. |
# Оставшиеся 2 числа складываются с помощью [[Двоичный каскадный сумматор|двоичного каскадного сумматора]]. | # Оставшиеся 2 числа складываются с помощью [[Двоичный каскадный сумматор|двоичного каскадного сумматора]]. | ||
Версия 08:05, 11 октября 2010
Определение
Дерево Уоллеса --- схема для умножения двух чисел.
Принцип работы
Дерево Уоллеса
В отличие от ещё одной схемы для умножения --- матричного умножителя, дерево Уоллеса складывает все числа не последовательно, а с помощью специального элемента(назовём его ), преобразующего 3 числа и в числа и такие, что .
С помощью этого элемента на каждом шаге производятся следующие операции:
- Берутся тройки чисел , , . При этом какие-то числа могут остаться.
- Для каждой тройки применяется элемент .
- Повторяются пункты 1 и 2 пока не осталось 2 числа.
- Оставшиеся 2 числа складываются с помощью двоичного каскадного сумматора.
На выходе имеем число, которое равно сумме чисел на всех входах.
Элемент 3→2
Теперь о том, как устроен элемент
.Для построения элемента
нам потребуется элемент, который умеет складывать 3 бита и возвращать 2 бита результата. Основная идея реализации --- отдельная обработка переносов и остатков.Тогда первое число ответа
может быть получена так: , где , и --- входные числа, а , и --- соответствующие их -е биты.Второе же число
можно получить так: , где --- функция медианы(она же "голосование 2 из 3"). С помощью этой функции считается перенос.Очевидно, полученные числа
и дадут в суммеСхемная сложность
Теперь подсчитаем схемную сложность этого элемента.
Каждый элемент
имеет глубину и размер .Теперь разберёмся, сколько в этой схеме элементов
. На каждом шаге количество чисел, которые нужно просуммировать, уменьшается на . Тогда глубина дерева будет равна элементов . Тогда общая сложность равна