Добавил:
Upload Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
shpory_OPEVS.docx
Скачиваний:
1
Добавлен:
01.03.2025
Размер:
3.44 Mб
Скачать

39 Логические методы ускорения умножения: модифицированный алгоритм Бута, алгоритм Лемана

Модифицированный алгоритм Бута. На практике большее распространение получила модификация алгоритма Бута, где количество операций сложения при любом сочетании единиц и нулей в множителе всегда равно n/2. В модифицированном алгоритме производится перекодировка цифр множителя из стандартной двоичной системы (0, 1) в избыточную систему (-2, - Основы проектирования ЭВС Лекции, часть 2

1, 0, 1, 2), где каждое число представляет собой коэффициент, на который умножается множимое перед добавлением к СЧП. Одновременно анализируются три разряда множителя bi+1bibi-1 (два текущих и старший разряд из предыдущей тройки) и, в зависимости от комбинации 0 и 1 в этих разрядах, выполняется прибавление или вычитание множимого, прибавление или вычитание удвоенного множимого, либо никакие действия не производятся

bi+1

bi

bi-1

Код(-2 -1 0 1 2)

Выполняемые действия

0

0

0

0

Не выполнять никаких действий

0

0

1

1

Прибавить к СЧП множимое

0

1

0

1

Прибавить к СЧП множимое

0

1

1

2

Прибавить к СЧП удвоенное множимое

1

0

0

-2

Вычесть к СЧП удвоенное множимое

1

0

1

-1

Вычесть к СЧП множимое

1

1

0

-1

Вычесть к СЧП множимое

1

1

1

0

Не выполнять никаких действий

Пример. Умножить два целых числа со знаком по модифицированному алгоритму Бута: A = 26, B = -18, n = 5.

Решение. [A]пр = [A]доп = 0.0000011010; [-A]доп = 1.1111100110; [-2A]доп = 1.1111001100; [B]пр = 0.10010; [B]доп = 1.01110

Шаг

Мт

Мн и СЧП

Действие

0

1.01110

0.0000000000

СЧП0=0

1

1.011100

-2

1.1111001100

1.1111001100

0.0001101000

-2Мн

СЧП1

Сдвиг Мн влево на 2 разряда

2

1.01110

0

------------

1.1111001100

0.0110100000

СЧП2

Сдвиг Мн влево на 2 разряда

3

1.01110

-1

1.1001100000

1.1000101100

-Мн

[P]доп = СЧП3

1.0111010100

[P]пр

Алгоритм Лемана. Еще большее сокращение количества сложений может дать модификация, предложенная Леманом. Здесь, даже при наименее лагоприятном сочетании цифр множителя, количество операций сложения не превышает величины n/2, а в среднем же оно составляет n/3. Суть модификации

заключается в следующем:

– если две группы нулей разделены единицей, стоящей в k-й позиции, то вместо вычитания в k-й позиции и сложения в (k+1)-й позиции достаточно выполнить только сложение в k-й позиции;

– если две группы единиц разделены нулем, стоящим в k-й позиции, то вместо сложения в k-й позиции и вычитания в (k+1)-й позиции достаточно выполнить только вычитание в k-й позиции.

Соседние файлы в предмете [НЕСОРТИРОВАННОЕ]