- •Основы прикладной теории цифровых автоматов
- •Основы прикладной теории цифровЫх автоматов
- •Оглавление
- •Предисловие
- •Глава 1. Информационные основы цифровых автоматов
- •1.1. Информация и общие принципы ее преобразования
- •1.2. Обмен информацией между различными информационными устройствами
- •1.3. Аппаратные средства хранения и обработки информации
- •1.4. Общие понятия о цифровом автомате и алгоритме
- •Глава 2. Представление числовой информации в цифровом автомате
- •2.1. Системы счисления и понятие кода
- •2.2. Выбор системы счисления
- •2.3. Формальные правила двоичной арифметики
- •2.4. Перевод числа из одной позиционной системы счисления в другую
- •Глава 3. Формы представления чисел в цифровых автоматах
- •3.1. Форма представления двоичных чисел с фиксированной запятой
- •3.2. Представление отрицательных чисел в формате с фиксированной запятой
- •3.3. Форма представление чисел с плавающей запятой
- •3.4. Перевод чисел из формата с фиксированной запятой в формат с плавающей запятой и обратно
- •3.5. Погрешности представления чисел
- •20 [A]ф 2n - 1 для целых чисел
- •Глава 4. Арифметические действия с двоичными числами
- •4.1. Сложение двоичных чисел
- •4.1.1. Алгебраическое сложение чисел, представленных в форме с фиксированной запятой
- •4.1.2. Переполнение разрядной сетки
- •4.1.3. Модифицированный прямой, обратный и дополнительный код
- •4.1.4. Алгебраическое сложение чисел, представленных в форме с плавающей запятой
- •4.2. Умножение двоичных чисел
- •4.2.1. Методы умножения двоичных чисел
- •4.2.2. Умножение чисел, представленных в форме с фиксированной запятой
- •4.2.3. Умножение чисел, представленных в форме с плавающей запятой
- •4.2.4. Ускорение операции умножения
- •4.3. Деление двоичных чисел
- •4.3.1. Деление двоичных чисел, представленных в форме с фиксированной запятой.
- •4.3.2. Деление двоичных чисел, представленных в форме с плавающей запятой.
- •4.4. Оценка точности выполнения арифметических операций
- •4.4.1. Погрешность округления
- •Глава 5. Выполнение операций над десятичными числами
- •5.1. Представление десятичных чисел в д-кодах
- •5.2. Формальные правила поразрядного сложения в д-кодах
- •5.3. Представление отрицательных чисел в д-кодах
- •5.4. Выполнение операций сложения и вычитания в д-кодах
- •5.5. Умножение чисел в д-кодах
- •5.6. Деление чисел в д-кодах
- •5.7. Перевод чисел из д-кода в двоичный и из двоичного в д-код
- •Глава 6 контроль работы цифрового автомата
- •6.1. Основные понятия теории кодирования
- •6.2. Кодирование по методу четности-нечетности
- •6.3. Коды Хеминга
- •6.4. Контроль по модулю
- •6.5. Контроль арифметических операций
- •Глава 7. Основы алгебры логики
- •7.1. Основные понятия алгебры логики
- •7.2. Свойства элементарных функций алгебры логики
- •7.3. Аналитическое представление функций алгебры логики
- •7.4. Совершенные нормальные формы
- •7.5. Системы функций алгебры логики
- •7.6. Числовое и геометрическое представление логических функций
- •Глава 8. Упрощение и минимизация логических функций
- •8.1. Задача минимизации
- •8.2. Метод Квайна и импликантные матрицы
- •8.3. Метод Карно (диаграммы Вейча)
- •Глава 9. Методы анализа и синтеза логических электронных схем
- •9.1. Логические операторы электронных схем или цепей
- •9.1.1. Задачи анализа и синтеза электронных схем
- •9.2. Синтез логических схем с одним выходом
- •9.3. Электронные схемы с несколькими выходами
- •9.4. Временные булевы функции и последовательностные автоматы
- •Глава 10. Введение в теорию автоматов и структурный синтез цифровых автоматов
- •10.1. Основные понятия и определения
- •10.2. Методы структурного синтеза и языки описания цифровых автоматов
- •10.3. Элементарный автомат (триггерный элемент)
- •10.4. Синтез цифрового автомата с памятью
- •Глава 11 алгоритмы реализации арифметических действий в цифровых автоматах
- •11.1. Общие принципы разработки алгоритмов
- •11.2. Алгоритмы реализации арифметических действий с операндами, представленными в форме с фиксированной запятой
- •11.2.1.Сложение и вычитание
- •11.2.2. Умножение
- •11.2.3. Деление
- •11.3 Алгоритмы реализации арифметических действий с операндами, представленными в форме с плавающей запятой
- •11.3.1. Сложение и вычитание
- •11.3.2. Умножение
- •11.3.3. Деление
- •11.4. Блок-схемы регистра накапливающего сумматора
- •11.4.1. Для работы с обратным кодом
- •11.4.2. Для работы с дополнительным кодом
- •11.5. Алгоритм извлечения квадратного корня операнда с плавающей запятой
- •Определения основных понятий и терминов
- •Литература
4.4.1. Погрешность округления
Так как в компьютере приходится прибегать к округлению чисел, то неизбежны погрешности округления. Если для представления мантиссы используется только n разрядов, то изображение числа разбивается на две части:
Aq = [m]qn + [A0]qp-n ,
где [A0]qp-n = A0 - "хвост" числа, не попавший в разрядную сетку.
В зависимости от того, как учитывается величина А0 в машинном изображении, существует несколько способов округления.
1. Отбрасывание А0. При этом относительная погрешность равна
окр = .
Так как q-1 |m| < 1; то 0 |A0| < 1, поэтому
окр = = q-(n-1) ,
т.е. погрешность округления не зависит от величины самого числа, а зависит только от количества разрядов в машине для любой системы счисления.
2. Симметричное округление. При этом производится анализ величины А0. Принимая, что
\
При условии |A0| q-1 производится прибавление единицы к младшему разряду мантиссы. Абсолютная погрешность при этом
Максимально возможное значение модуля абсолютной погрешности равно 0,5qp-n , а относительная погрешность равна
окр 0,5qp-n/(mqp) = 0,5q-(n-1),
т.е. ошибка не превышает половины единицы младшего разряда. Способ симметричного округления наиболее часто применяют на практике.
3. Округление по дополнению. В этом случае для округления берется информация, содержащаяся в (n+1)-м разряде. При q = 2, если в (n+1)-м разряде содержится 1, в n-й разряд добавляется 1; если же там ноль, содержимое разрядов правее n-го отбрасывается.
Глава 5. Выполнение операций над десятичными числами
5.1. Представление десятичных чисел в д-кодах
Операции над десятичными числами (десятичная арифметика) часто включается в состав основных команд универсальных компьютеров. Кроме того, десятичная арифметика широко реализуется в электронных калькуляторах и персональных компьютерах. Поэтому кроме общей информации о возможности представления десятичных чисел разработчику необходимо знать и алгоритмы выполнения арифметических операций.
Двоично-десятичный код (Д-код) десятичного числа, как уже отмечалось, это такое его представление, в котором каждая десятичная цифра изображается четырьмя двоичными разрядами (тетрадой из двоичных символов):
A = {a4,n a3,n a2,n a1,n}n {a4,n-1 a3,n-1 a2,n-1 a1,n-1}n-1 ... {a4,0 a3,0 a2,0 a1,0}0 ,
где ai,j _ двоичные разряды тетрады, i - номер разряда внутри тетрады, j - номер самой тетрады.
Для однозначности перевода чисел в Д-код и обратно желательно, чтобы разряды тетрад имели определенный вес. Тогда значение десятичной цифры ai соответствует выражению: ai = a4d4 + a3d3 + a2d2 + a1d1, где di - вес разряда тетрады. Максимальное допустимое число в тетраде - 9. Если возникает число 10 и больше, то единица переходит в следующую старшую тетраду. Существуют различные Д-коды. Мы будем рассматривать Д-код, вес разрядов тетрады которого следующий: 8, 4, 2, 1. Этот код называется также кодом Д1 прямого замещения. Но есть Д-коды с тетрадами: 5, 1, 2, 1; 2, 4, 2, 1 и т.д. Указанные комбинации в этих Д-кодах разрешены. Все другие комбинации - запрещены. Наличие разрешенных и запрещенных комбинаций - очень важное свойство Д-кодов. Оно отличает их от обычных позиционных систем счисления, в которых все комбинации - разрешенные.
В рассматриваемом Д-коде прямого замещения (8421) разрешенные комбинации соответствуют двоичным эквивалентам десятичных цифр с весами разрядов, равных степеням основания 2. Этот Д-код чаще всего используется в различных компьютерах.
В таблице 5.1 приведены примеры записи некоторых десятичных чисел в коде Д1 прямого замещения .
Т а б л и ц а 5.1
Десятичные цифры Код Д1 Десятичные цифры Код Д1 Десятичные цифры Код Д1
0 0000 10 0001 0000 20 0010 0000
1 0001 11 0001 0001 21 0010 0001
2 0010 12 0001 0010 22 0010 0010
3 0011 13 0001 0011 33 0011 0011
4 0100 14 0001 0100 34 0011 0100
5 0101 15 0001 0101 45 0100 0101
6 0110 16 0001 0110 56 0101 0110
7 0111 17 0001 0111 67 0110 0111
8 1000 18 0001 1000 78 0111 1000
9 1001 19 0001 1001 89 1000 1001