Машинные методы умножения чисел в прямых кодах
Операция умножения состоит из ряда последовательных сложений. Сложением управляют разряды множителя: если в очередном разряде множителя содержится единица, то к сумме добавляется множимое. При этом, в зависимости от метода умножения, выполняется сдвиг либо множимого, либо частичной суммы. Наряду с этим умножение можно начинать как с младших, так и со старших разрядов множителя. Для умножения используют модули сомножителей. Знак произведения определяется сложением по модулю 2 знаковых разрядов сомножителей.
Введем некоторые обозначения, используемые ниже: - частичное произведение, - частичная сумма.
Ниже приводится схема четырех алгоритмов умножения (рис. 5).
Остановимся более подробно на реализации умножения согласно алгоритму А.
Представим Мн = А = 0,а1а2…аn
Мт = B = 0,b1b2….bn = b12-1+b22-2+…+bn2-n+bn2-n
Мн∙Мт = С=А∙В= 0,а1а2…аn ( b12-1+b22-2+…+bn2-n) =
= 0+(b1∙0,а1а2…аn)2-1+…+(bn-1∙0,а1а2…аn)2-(n-1)+(bn∙0,а1а2…аn)2-n =
= 0+b1∙A2-1+…+bn-1∙A2-(n-1)+…+bn∙A2-n = 0+bn∙A2-n+bn-1∙A2-(n-1)+…+b1∙A2-1 =
= (…((0+bn∙A)2-1+bn-1∙A)2-1+…+b1∙A)2-1
Ниже приведены (без вывода) остальные три реализации алгоритмов (Б, В и Г) умножения.
Мн∙Мт = С=А∙В = 0+bn∙A+bn-1∙A∙22+…+b1∙A∙2n-1 (алгоритм Б)
Мн∙Мт = С=А∙В = (…(0+b1∙A) ∙21+b2∙A)∙21+…+bn∙A) (алгоритм В)
Мн∙Мт = С=А∙В = 0+b1∙A∙2-1+b2∙A∙2-2+…+bn∙A∙2-n (алгоритм Г)
Структурные схемы операционных устройств, выполняющих умножение по алгоритмам А, Б, В и Г, приведены на рис 6.
Рассмотрим пример умножения чисел согласно алгоритму А.
Пример: Мн = 0,1011
|
0,0000 начальное содержимое сумматора
+ 0,1011 = Мн ∙ b4 первое частичное произведение
0,1011 первая частичная сумма
0,0101 1 ∙ 2-1 сдвиг первой частичной суммы
+ 0,0000 = Мн ∙ b3 второе частичное произведение
0,0101 1 вторая частичная сумма
0,0010 11 ∙ 2-1 сдвиг второй частичной суммы
+ 0,1011 = Мн ∙ b2 третье частичное произведение
0,1101 11 третья частичная сумма
0,0110 111 ∙ 2-1 сдвиг третьей частичной суммы
+ 0,1011 = Мн ∙ b1 четвертое частичное произведение
1,0001 111 (возникло переполнение)
0,1000 1111 ∙ 2-1 сдвиг, получение верного результа-
та Мн∙Мт
Заметим, что при умножении чисел по алгоритму А на отдельных этапах операции возможно переполнение (попадание значащей единицы в знаковый разряд). Однако при последующем сдвиге переполнение устраняется. При использовании других алгоритмов (Б, В, Г) переполнения не возникает.
Время умножения чисел по алгоритму А tумн = ( tсл + tсдв ) n, где n - число разрядов Мт. Следовательно, сдвиг и сложение нельзя выполнять в одном автоматном такте. Это наглядно показано на рис 7.
Дата добавления: 2016-01-09; просмотров: 896;