Теоретические основы вычислительной техники 2 страница

Признаком необходимости нормализации вправо является переполнение поля разрядной сетки, отводимое под МS. Это возможно лишь при суммировании чисел с одинаковыми знаками.

Признаком необходимости нормализации влево является совпадение цифр в знаковом разряде и старшем разряде мантиссы. Это возможно лишь при суммировании чисел с разными знаками, т. е. при представлении мантисс в обратном или дополнительных кодах.

Пример. Выполнить суммирование двоичных чисел и

В данном случае , следовательно проведём предварительное выравнивание порядков.

, .

Так как A>0 и B>0, то выполним суммирование в прямом коде

(мантиссы суммируются в прямом коде)

  порядок знак мантисса
+А
B
S

Так как 0,5<MS<1, то нормализация результата не требуется и получим

.

Пример. Выполнить суммирование двоичных чисел и с представлением мантиссы шестью разрядами.

Так как РАВ, то выравнивание порядков не требуется. Для случая В>0 нахождение суммы S проведём используя прямой код.

  порядок знак мантисса
+А
В
 

Так как возникло переполнение поля разрядной сетки, отведённого под мантиссу, проведём нормализацию результата вправо на один разряд, соответственно увеличив значение порядка на единицу, т. е.

0

В итоге получим результат

Для случая В<0 нахождение суммы S проведём используя дополнительный код (мантиссы суммируются в дополнительном коде).

  порядок знак мантисса в доп. коде
+А
В
S

Так как возникло совпадение цифр в знаковом разряде и старшем разряде мантиссы, то проведём нормализацию результата влево на два разряда, соответственно уменьшив значение порядка на два, т. е.

S 0
S

В итоге получим результат

Задание 35. Выполнить суммирование двоичных чисел и .

Задание 36. Выполнить суммирование двоичных чисел +1101,11 и -1000,01 в форме с ПЗ.

Задание 37. Выполнить суммирование двоичных чисел и .

 

1.2.3. Сложение и вычитание чисел в двоично-десятичных кодах (Д-кодах).

….

Соответствие десятичных цифр их двоично-десятичным кодам дано таблицей.

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

Сложение чисел в Д-кодах сводится к суммированию тетрад, соответствующих их разрядам, по правилам двоичной арифметики и коррекции тетрад суммы. Для тетрад суммы, значение которых превышают 1001, необходимо организовать перенос в следующую тетраду и выполнить коррекцию. Коррекция представляет собой вычитание 1010, что соответствует сложению тетрады с 0110 без переноса (т. к. 0110 есть дополнительный код числа 1010).

Пример. Определить сумму чисел А=753­(10) и В=439­(10) в двоично-десятичном коде.

Представим числа А и В в Д-коде и выполним суммирование:

+А =
В =
S’ =
выполним коррекцию   +0110   +0110
S = 1

,что соответствует 1192(10).

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

Пример. Определить разность чисел А=753­(10) и В=439(10) в двоично-десятичном коде.

Представим число В в дополнительном коде

  -1001 -1001 -1001 дополнение каждой тетрады до 1001
   
  добавление к младшей тетраде единицы
      +1  
Вдоп=  

 

Теперь выполним операцию S=А-В=А+Вдоп.

+А
Вдоп
S’
коррекция +0110 +0110  
S

, что соответствует 314(10).

Задание 38. Выполнить сложение чисел 280(10) и 157(10) в Д-коде.

Задание 39. Определить разность чисел 1092(10) и 956­(10) в Д-коде.

 

1.2.4. Умножение и деление двоичных чисел.

Ограничимся рассмотрением выполнения операций умножения и деления над двоичными числами в прямом коде с учётом их знаков. Эти операции выполняются с многократным применением операций сложения и сдвига и могут быть реализованы схемой показанной на рисунке.

 

 


Операция умножения чисел А и В выполняется в несколько тактов. Множимое А записывается в Рег.1, а множитель В в Рег.3. Рег.2 предварительно устанавливается в 0. На каждом такте анализируется содержимое старшего (левого) разряда Рег.3. Если в нём находится 1-ца, то производится общий сдвиг влево содержимого Рег.3 и Рег.2 (с переносом между ними) и суммирование содержимого регистров Рег.1 и Рег.2 с занесением результата в Рег.2. Если в старшем разряде Рег.3 находится 0, то производится лишь сдвиг влево содержимого Рег.3 и Рег.2. Число тактов равно числу разрядов множителя В. В результате произведение будет располагаться в Рег.3 и Рег.2.

Код знака результата операции умножения получаем суммированием по mod2 кодов знаков сомножителей (логическая функция сложения по mod2 показана далее).

Пример. Выполнить умножение чисел А=11(10)=1011(2) и В=13(10)=1101(2).

х1011

Для наглядности последующих действий предварительно умножим числа «в столбиках».

Теперь рассмотрим выполнение операции умножения схемой, представленной на рис. 1.

Операция проводится в 4 такта (число В четырёхразрядное).

 

Начальное содержимое регистров:

 
 

 

 


Такт 1. Так как в старшем разряде Рег.3 находится 1-ца, то производится сдвиг содержимого Рег.3 и Рег.2 и суммирование содержимого Рег.1 и Рег.2 с записью результата в Рег.2.

Рег.2
Рег.3
1 0 1 0
1 0 1 1
Получим:

 

 

Такт 2. В старшем разряде Рег.3 опять 1-ца, следовательно, в результате сдвига и суммирования получим:

           
   
 
Рег.3
   
Рег.2
 


Такт 3. В старшем разряде Рег.3 находится 0, поэтому производится только сдвиг.

           
   
 
Рег.3
   
Рег.2
 


Такт 4. В старшем разряде Рег.3 опять 1-ца. Выполняются сдвиг и суммирование.

           
   
 
Рег.3
   
Рег.2
 

 


Проверим правильность выполнения умножения.

10001111(2)=143(10), т. е.

Задание 40. Выполнить операцию умножения чисел 14(10) и -9(10) реализуя алгоритм работы схемы рис. 1.

Задание 41. Выполнить операцию умножения чисел -19(10) и -7(10), реализуя алгоритм работы схемы рис. 1.

 

Операция деления чисел А и В выполняется схемой рис. 1 также за несколько тактов. Делимое А располагается одновременно в Рег.3 и Рег.2, а делитель В в Рег.1. На каждом такте сравнивается содержимое Рег.3 и Рег.1. Если число в Рег.3 больше числа в Рег.1, то производится:

- вычитание из содержимого Рег.3 содержимого Рег.1 с записью результата в Рег.3;

- общий сдвиг влево содержимого Рег.3 и Рег.2 (с переносом между ними);

- запись 1-цы в младший разряд Рег.2.

Если число в Рег.3 меньше числа в Рег.1, то производится лишь сдвиг влево содержимого Рег.3 и Рег.2. Итоговый результат операции деления будет располагаться в Рег.2.

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

Пример. Выполнить деление числа 143(10)=10001111(2) на число 11(10)=1011(2).

-
         
  -            
                 
      -        
                 

Для наглядности последующих действий предварительно разделим числа «в столбик».

Теперь рассмотрим выполнение операции деления схемой, представленной на рис.1. Начальное содержимое регистров:

 
 

 

 


Такт 1. Так как число в Рег.3 меньше числа в Рег.1 то производится общий сдвиг влево содержимого Рег.3 и Рег.2. Получим

 
 

 

 


Такт 2. Теперь число в Рег.3 больше числа в Рег.1, поэтому производится вычитание из содержимого Рег.3 содержимого Рег.1 с записью результата в Рег.3.

 
 

 


а затем выполняется общий сдвиг всего содержимого Рег.3 и Рег.2 и запись 1-цы в младший разряд Рег.2 Получим

 
 

 


Такт 3. Так как сейчас число в Рег.3 больше числа в Рег.1, то действия предыдущего такта повторяются. После вычитания получим

 
 

 


а после сдвига влево в Рег.3 и Рег.2 и записи 1-цы в младший разряд Рег.2 будем иметь

 
 

 


Такт 4. В этом случае число в Рег.3 стало меньше числа в Рег.1, поэтому производится только общий сдвиг влево Рег.3 и Рег.2

 
 

 


Такт 5. Теперь опять число в Рег.3 больше числа в Рег.1. Поэтому выполняется вычитание

 

сдвиг и запись 1-цы в младший разряд Рег.2

 
 

 

 


Проверим правильность выполнения деления:

1101(2)=13(10), т. е. 143(10):11(10)=13(10).

Замечание. Чтобы реализовать операцию вычитания в сумматоре (рис.1) нужно заменить её операцией сложения с числом в дополнительном коде, т. е. к содержимому Рег.3 прибавлять содержимое Рег.1 взятое в дополнительном коде. В рассмотренном примере вычиталось число 1011, следовательно нужно прибавлять число 0101. (Проверить самостоятельно).

Задание 42. Выполнить операцию деления чисел 126(10) и 14(10), реализуя алгоритм работы схемы рис.1.

Задание 43. Выполнить операцию деления чисел 123(10) и -7(10), реализуя алгоритм работы схемы рис.1.

Замечание. При выполнении операции умножения и деления чисел в форме с ПЗ необходимо выполнить:

- умножение или деление мантисс исходных чисел (по алгоритмам рассмотренным выше);

- определение порядка результата (получается соответственно сложением или вычитанием порядков исходных чисел с учётом их знаков);

- нормализацию результата с соответствующей коррекцией порядка.

 

1.3. Логические основы вычислительной техники.

Комбинационные схемы и конечные автоматы.

Устройство преобразовывающее информацию

 
 

 


Входной и выходной сигналы.

В цифровой вычислительной машине (ЦВМ) время дискретно, т. е. переход от 0 в 1 за момент. Интервал между моментами – такт.

 
 

 


Преобразующее устройство Р:

, где X(t)={x1, x2 … xn} – множество входных дискретных тактиров-х сигналов, Y(t)={y1, y2 … ym} – множество выходных сигналов, Р – функция или функционал преобразования.

Если элементарный сигнал может быть представлен с различными состояниями:

то можно ввести понятие k-значной логики.

k-значной логикой называют математический аппарат, позволяющий описать функционирование Р-преобразователей. k-значная логика может приведена быть к 2-ой логике, т. к. k-значную переменную можно заменить на log2k двоичных переменных.

Поэтому дальше 2-ая (Булева) логика.

Устройство реализующее Р называется в ЦВМ автоматом.

2 вида дискретных автоматов:

1) Если совокупность выходных сигналов (выходного слова) Y(t) зависит от X(t) и не зависит от внутреннего состояния автомата, то это комбинационная схема. Y(t)=P[X(t)].

Структурная схема:

ЭП комбинационный автомат не содержит.

Закон функционирования комбинационного автомата определяется заданием соответствия между входным и выходным словами.

Можно задать: таблицей

аналитически (булевыми функциями)

2) Если Y(t)=P[X(t), S(t-1)], то автомат с памятью (конечный).

r+1 внутренних состояний S(t)={S0, S1, … Sr}. При подаче X(t) в t-ом такте автомат переходит их S(t-1) в S(t). Структурная схема

 
 

 

 


КС – комбинационная схема.

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

Элементы теории конечных автоматов в главе 3.

 

 

1.3.1. Переключательные (булевы, логические) функции.

I. Основные понятия и определения.

x1 x2 xn f(x1…xn)
… … … …   …

Булевой функцией называется f(x1, x2, … xn), аргументы которой и сами функции принимают значение из множества Е2={0,1}. Они могут быть заданы таблицей. Полная таблица функции от n переменных имеет 2n строк и n+1 столбцов. Упорядоченная таблица называется таблицей истинности. Другая форма – булевы выражения.

Теорема: число различных переключательных функций n-аргументов равно

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

Определение: Переключательная функция f называется существенно зависимой от x­i, если выполняется неравенство: . Не все переключательные f существенно зависимы.

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

 

II. Элементарные логические функции.

Называются функции 1 или 2-х аргументов.

Логическая функция 1-ой переменной:

x
f1(x) f2(x) f3(x) f4(x)

- нулевая функция;

- функция повторения аргумента

- функция инверсии аргумента

- единичная функция

 

Логические функции 2-х переменных:

функции аргументы х1 0011 х2 0101 обозначение функции название функции и комментарии
f0(x1,x2) 0 0 0 0 Нулевая
f1(x1,x2) 0 0 0 1 x1 Ù x2 Конъюнкция
f2(x1,x2) 0 0 1 0 запрет по х2
f3(x1,x2) 0 0 1 1 х1 повторение х1
f4(x1,x2) 0 1 0 0 запрет по х1
f5(x1,x2) 0 1 0 1 х2 повторение х2
f6(x1,x2) 0 1 1 0 сумма по mod2
f7(x1,x2) 0 1 1 1 Дизъюнкция
f8(x1,x2) 1 0 0 0 стрелка Пирса
f9(x1,x2) 1 0 0 1 эквивалентность (равнозначность)
f10(x1,x2) 1 0 1 0 отрицание х2
f11(x1,x2) 1 0 1 1 импликация от х2 к х1
f12(x1,x2) 1 1 0 0 отрицание х1
f13(x1,x2) 1 1 0 1 импликация от х1 к х2 ( )
f14(x1,x2) 1 1 1 0 x1\x2 штрих Шеффера
f15(x1,x2) 1 1 1 1 Единичная

 

III. Системы элементарных логических функций.

Определение: Набор элементарных логических функций, используемый для записи любых логических выражений называется системой логических функций (СЛФ).

Определение: Набор элементарных логических функций достаточный для записи любых логических выражений называется функционально полной СЛФ (ФП СЛФ).

Определение: Если исключение любой элементарной логической функции из ФП СЛФ приводит к функциональной неполноте, то исходная ФП СЛФ называется безызбыточной. Иначе ФП СЛФ называется избыточной.

Теорема о функциональной полноте СЛФ (Постников, Яблонский).

СЛФ называется функционально полной в том и только том случае, если она включает хотя бы одну функцию, не принадлежащую к 5 важнейшим замкнутым классам:

1) – класс функций сохраняющих 0,

2) – класс функций сохраняющих 1,

3) – класс самодвойственных функций,








Дата добавления: 2016-04-06; просмотров: 636;


Поиск по сайту:

При помощи поиска вы сможете найти нужную вам информацию.

Поделитесь с друзьями:

Если вам перенёс пользу информационный материал, или помог в учебе – поделитесь этим сайтом с друзьями и знакомыми.
helpiks.org - Хелпикс.Орг - 2014-2024 год. Материал сайта представляется для ознакомительного и учебного использования. | Поддержка
Генерация страницы за: 0.066 сек.