Дерево Уоллеса — различия между версиями
Komarov (обсуждение | вклад) м (→Дерево Уоллеса) |
(→Схемная сложность) |
||
Строка 47: | Строка 47: | ||
Каждый элемент <tex>3\to2</tex> имеет глубину <tex>O(1)</tex> и размер <tex>O(n)</tex>. | Каждый элемент <tex>3\to2</tex> имеет глубину <tex>O(1)</tex> и размер <tex>O(n)</tex>. | ||
− | Подсчитаем количество элементов <tex>3\to2</tex>. На каждом шаге количество чисел, которые нужно просуммировать, уменьшается в <tex>1, | + | Подсчитаем количество элементов <tex>3\to2</tex>. На каждом шаге количество чисел, которые нужно просуммировать, уменьшается в <tex>1{,}5</tex> раза. Тогда глубина дерева будет равна <tex>\log_{3/2}n</tex>, и в нём будет <tex>n + \frac23n + \left(\frac23\right)^2n + \ldots = O(n)</tex> элементов <tex>3\to2</tex>. |
Тогда общая сложность равна | Тогда общая сложность равна | ||
Версия 04:27, 13 ноября 2010
Содержание
Определение
Дерево Уоллеса - схема для умножения двух чисел.
Принцип работы
Дерево Уоллеса
Для получения произведения, воспользуемся методом, напоминающим умножение «в столбик»: распишем произведение в сумму матричном умножителе).
чисел (как вОднако, в отличие от матричного умножителя, дерево Уоллеса складывает все числа не последовательно, а с помощью специального элемента(назовём его ), преобразующего 3 числа , и в числа и такие, что .
С помощью этого элемента на каждом шаге производятся следующие операции:
- Берутся тройки чисел , , . При этом какие-то числа могут остаться.
- Для каждой тройки применяется элемент .
- Повторяются пункты 1 и 2 пока не осталось 2 числа.
- Оставшиеся 2 числа складываются с помощью двоичного каскадного сумматора.
На выходе имеем число, которое равно сумме чисел на всех входах.
Элемент 3→2
Теперь о том, как устроен элемент
.Для построения элемента
нам потребуется элемент, который умеет складывать 3 бита и возвращать 2 бита результата. Основная идея реализации - отдельная обработка переносов и остатков.Тогда первое число ответа
может быть получена так: , где , и - входные числа, а , и - соответствующие их -е биты.Второе же число
можно получить так: , где - функция медианы (она же "голосование 2 из 3"). С помощью этой функции считается перенос.Очевидно, полученные числа
и дадут в суммеСхемная сложность
Определим схемную сложность этого элемента.
Каждый элемент
имеет глубину и размер .Подсчитаем количество элементов
. На каждом шаге количество чисел, которые нужно просуммировать, уменьшается в раза. Тогда глубина дерева будет равна , и в нём будет элементов . Тогда общая сложность равна
Литература
- Т. Кормен, Ч. Лейзерсон, Р. Ривест: Алгоритмы: построение и анализ, 1-е изд