Добавил:
Upload Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
Bilety_EVM.doc
Скачиваний:
21
Добавлен:
21.09.2019
Размер:
1.68 Mб
Скачать

28. Применение сумматоров: различные структуры для выполнения арифметических операций.

29. Организация суммирования чисел: параллельный и последовательный способ.

Последовательный способ суммирования выполняется путём поразрядного сложения на базе одноразрядного сумматора и сдвигающих регистров. При этом значение переносов при сложении младших битов запоминается и используется при сложении послед. Окончательный результат формируется за m=n+1 тактов, где n – кол-во битов (разряд) числа.

Параллельные сумматоры.

Сумматоры с параллельным переносом.

При использовании сумматоров с послед. переносом оконч. результат получаем только после формирования переноса. В самом старшем разряде. Для увеличения быстродействия работы сумматора используют параллельный способ формирования переноса. Для построения комбинационной схемы такого сумматора вводятся вспомогательные функции генерации и прозрачности. Ф-ция генерации принимает 1, если сигнал переноса на выходе данного разряда появляется независимо от входного перtноса gi=ai*bi.

Ф -я прозрачности или транзита определяет появление переноса на выходе только при наличии входного. hi=ai bi.

Тогда общее выражение для формирования сигнала переноса можно записать в виде: Сi=gi\/(ci*hi).

На основании такой зависимости и формирования логической схемы блоков формирования переносов:

a

b

c

0

0

0

0

0

1

0

1

0

0

1

1

1

0

0

1

0

1

1

1

0

1

1

1


30. Запись чисел в прямом, обратном и дополнительном коде. Использование сумматоров для вычитания.

Прямой код числа. При этом способе кодирования чисел кодируется только знак числа, а значащая часть остается без изменения.

Пример: A=+0,1101 A=+ 1101

[A]пр=0,1101 [A]пр=0.1101

Пример: A = - 0,1101 A = - 1101

[A]пр=1,1101 [A]пр=1.1101

Диапазон изменения машинных изображений для прямого кода лежит в пределах: -(1-2-n) [A]пр (1-2-n).

Недостатком прямого кода является сложность выполнения операции сложения чисел с разными знаками.

Для арифметических операций над числами в прямом коде используется сумматор прямого кода. В этом сумматоре отсутствует цепь поразрядного переноса между старшим значащим и знаковым разрядами, то есть на этом сумматоре невозможно выполнение операции алгебраического сложения.

Дополнительный код числа. Число А называется дополнением к числу А, если выполняется соотношение: А + А = rn для целых чисел, или А + А'=r0 для дробных чисел, где n- количество цифр в записи числа A.

Пример: A10 =378

n=3

A10 =103 – А10=1000 - 378=622

378

621 - все разряды дополняются до младшей цифры системы счисления

1 - младший разряд дополняется до основания системы счисления

1000

n=4

А2 =1011, A2 =24 - А=10000 - 1011 = 0101 или А2 = 0101

Замена операции вычитания операцией сложения. В ЭВМ достаточно сложно выполнить операцию вычитания (А-В). Для этого требуется:

  1. сравнить числа и выявить наибольшее по абсолютной величине;

  2. наибольшее число разместить на входах вычитающего устройства;

  3. выполнить операцию вычитания;

  4. присвоить знак разности наибольшего по величине числа.

Для сложения чисел требуется сумматор и неважно, какие слагаемые подаются на его входы А или В. Пусть необходимо сложить

А = 487 А = 487

В = -348 В = 652

А-В = 139 А-В = 1 139

А + (103 – В) = А-В+103 (103 игнорируется).

А = 348 А = 348

В = -487 В = 513

А-В = -139 А-В = 861

Дополнительный код является математическим дополнением основания системы счисления.

- для дробных чисел, - для целых чисел

где - абсолютное значение числа А, n – число цифр числа.

Положительные числа в дополнительном коде не меняют своего изображения. Правило преобразования числа в дополнительный код можно записать:

Рассмотрим несколько примеров сложения чисел в дополнительных кодах.

А= 0,1001 [A]доп = 0,1001 А= - 0,1001 [A]доп = 1,0111

В= - 0,0100 [B]доп = 1,1100 В= 0,0100 [B]доп = 0,0100

10,0101 1,1011

Теорема. Сумма дополнительных кодов чисел есть дополнительный код результата.

Доказательство теоремы приведено в [1].

Теорема справедлива для всех случаев, в которых не возникает переполнения разрядной сетки, что позволяет складывать машинные представления чисел по правилам двоичной арифметики, не разделяя знаковую и значащую части числа. Для выполнения арифметических операций над числами в дополнительном коде используется двоичный сумматор дополнительного кода, характерной особенностью которого является наличие поразрядного переноса из старшего значащего в знаковый разряд.

Обратный код числа. Обратный код двоичного числа является инверсным изображением числа, в котором все разряды исходного числа принимают инверсное (обратное) значение. Правила преобразования чисел в обратный код аналитически можно определить следующим образом:

,

.

Выполнение арифметических операций над числами в обратном коде осуществляется на сумматоре обратного кода. Этот код имеет несущественный недостаток: требует наличия в сумматоре цепи циклического переноса из знакового разряда в младший значащий. Это может привести к увеличению времени выполнения арифметических операций. Ниже приведены несколько примеров выполнения арифметических операций над числами, записанными в дополнительном коде.

А= 0,1001 [A]обр = 0,1001 А= - 0,1001 [A]обр = 1,0110

В= - 0,0100 [B]обр = 1,1011 В= 0,0100 [B]обр = 0,0100

10,0100 1,1010

1

0,0101

Теорема. Сумма обратных кодов чисел есть обратный код результата.

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