Автор работы: Пользователь скрыл имя, 21 Февраля 2012 в 22:52, контрольная работа
Операция сдвига широко используется в современной вычислительной технике для реализации умножения, деления, нормализации двоичных чисел с плавающей точкой и т.д.
Структурная электрическая схема устройства сдвига двоичных чисел представлена на рисунке 13.
Рассмотрим назначение узлов, входящих в структурную электрическую схему устройства.
ТЕМА
№ 3. УСТРОЙСТВО СДВИГА ДВОИЧНЫХ
ЧИСЕЛ
3.1 Описание
принципа работы заданной
структурной электрической
схемы устройства сдвига
двоичных чисел
Операция сдвига широко используется в современной вычислительной технике для реализации умножения, деления, нормализации двоичных чисел с плавающей точкой и т.д.
Структурная электрическая схема устройства сдвига двоичных чисел представлена на рисунке 13.
Рассмотрим
назначение узлов, входящих в структурную
электрическую схему
Комбинационный программируемый сдвигатель Y4 предназначен для логического сдвига влево или вправо без округления четырехразрядного двоичного числа X, представленного разрядами x0, x1, x2, x3. На выходе сдвигателя формируется 10-разрядное слово Y, представленное разрядами y6, y5, …, y0, y-1, y-2, y-3.
Счетчик Y1 предназначен для параллельного ввода четырехразрядного числа X.
Триггер
Y2 предназначен для ввода управляющего
сигнала D, определяющего направление
сдвига (D=0 означает сдвиг влево, D = 1 – сдвиг
вправо).
Рисунок 13 – Устройство сдвига двоичных чисел.
Схема электрическая
структурная
Регистр Y3 предназначен для параллельного ввода управляющих сигналов S0 и S1, определяющих шаг сдвига. Например, если S1 = 0, S0 = 1, то выполняется сдвиг на один разряд.
Регистр Y5 предназначен для параллельного вывода результата сдвига, который представляет собой 10-разрядное слово.
Загрузка числа X и управляющих сигналов D, S0, S1, а также вывод результата сдвига синхронизируется тактовыми импульсами UС. Причем ввод осуществляется по отрицательным фронтам тактовых импульсов, а вывод результата сдвига – по положительным.
Процесс
функционирования устройства поясняется
временной диаграммой, которая представлена
на рисунке 14.
Рисунок
14 – Временная диаграмма, поясняющая
процесс функционирования устройства
В момент времени t1 по отрицательному фронту тактового импульса начинается ввод числа X в счетчик Y1 и управляющих сигналов в триггер Y2 и регистр Y3 (рисунок 13). К моменту времени t2 ввод заканчивается, и начинается процесс сдвига в сдвигателе Y4.
Этот процесс в худшем случае завершается к моменту времени t3. Затем по положительному фронту тактового импульса результат сдвига записывается в регистр Y5 и т.д.
При подаче низкого уровня напряжения на вход (рисунок 13) устройство сбрасывается в исходное нулевое состояние.
Рассмотрим
пример логического сдвига влево
без округления на два разряда
для двоичного числа1) X=1101(2):
x3 | x2 | x1 | x0 | |||||||
0 | 0 | 0 | 1 | 1 | 0 | 1 | 0 | 0 | 0 | – до сдвига |
0 | 1 | 1 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | – после сдвига |
y6 | y5 | y4 | y3 | y2 | y1 | y0 | y–1 | y–2 | y–3 |
Из
примера следует, что сдвигаемые
цифры сохранены (сдвиг без округления)
и произошло умножение
3.2 Задание
на проектирование к
теме № 3
Описать
принцип построения и разработать
логическую схему комбинационного
программируемого сдвигателя четырехразрядных
двоичных чисел без округления в базисе
И-НЕ. Разработать логическую схему суммирующего
четырехразрядного недвоичного счетчика
на JK-триггерах с коэффициентом пересчета
Кпер, заданным в таблице 5. В принципиальной
электрической схеме устройства использовать
двоичный счетчик. Разработать принципиальную
электрическую схему устройства сдвига
по заданной структурной схеме (рисунок
13) на микросхемах схемотехники КМОП, серии
которых указаны в таблице 5.
Таблица
5 – Исходные данные для проектирования
устройства логического сдвига двоичных
чисел
Номер варианта | Значение числа X (P=2) | Направление сдвига | Шаг сдвига | Серии микросхем | К пер |
3.1 | 1010 | влево | 2 | 1594, 5564 | 11 |
3.2 | 0101 | вправо | 2 | 1554, 1564 | 9 |
3.3 | 0011 | вправо | 3 | 1594, 5564 | 12 |
3.4 | 1011 | влево | 2 | 1554, 1564 | 15 |
3.5 | 0111 | влево | 3 | 1594, 5564 | 13 |
3.6 | 1110 | вправо | 3 | 1554, 1564 | 14 |
3.7 | 1011 | влево | 3 | 1594, 5564 | 12 |
3.8 | 1010 | вправо | 3 | 1554, 1564 | 11 |
3.9 | 1000 | влево | 2 | 1594, 5564 | 13 |
3.10 | 0010 | вправо | 2 | 1554, 1564 | 14 |
Описать
работу принципиальной электрической
схемы устройства в течение одного
периода сигнала синхронизации UC
при сдвиге числа X. Значение числа X, направление
и шаг сдвига заданы в таблице 5.
3.3 Назначение
и принцип построения
комбинационных программируемых
сдвигателей
Операция сдвига заключается в смещении двоичного слова влево или вправо по разрядной сетке на заданное число разрядов [8, 9].
В современной вычислительной технике сдвиг является одним из основных видов обработки информации. Он может реализовываться как составная часть других операций (умножение, деление, нормализация и др.).
Поэтому даже в самых ранних ЭВМ использовались так называемые сдвигающие регистры. Такие регистры применяются и в новейших машинах, но наряду с ними стали использоваться и комбинационные многоразрядные программируемые сдвигатели. Дело в том, что в сдвигающих регистрах время сдвига прямо пропорционально величине (шагу) сдвига, поскольку в них на каждом такте осуществляется сдвиг только на один разряд. Комбинационные устройства по своей природе являются однотактными. Время сдвига информации в таких устройствах не зависит от величины сдвига. Естественно, что их реализация сопровождается значительными аппаратурными затратами.
Различают четыре вида сдвигов: логический, арифметический, редакторский и циклический.
При логическом сдвиге смещаются все биты слова, включая знаковый. Высвобождающиеся разряды сетки заполняются нулями независимо от направления сдвига.
При арифметическом сдвиге смещаются только значащие цифры слова. При сдвиге вправо высвобождающиеся разряды заполняются знаковой цифрой, а при сдвиге влево – нулями. В некоторых случаях шаг сдвига влево не должен превышать количество незначащих цифр между знаковым разрядом и первой значащей цифрой. В противном случае происходит переполнение разрядной сетки, что должно индицироваться в устройстве специальным осведомительным сигналом.
Обычно при логическом и арифметическом сдвигах величина шага сдвига не превышает qmax = n – 1 (где n – разрядность сдвигаемого слова), так как в противном случае ни одна цифра сдвигаемого слова не останется в начальной разрядной сетке, что, как правило, не имеет смысла при обработке реальной информации.
Арифметический и в некоторой степени логический сдвиг на q разрядов влево равносилен умножению исходного слова на величину 2q; аналогично соответствующий сдвиг вправо равносилен делению исходного слова на эту же величину.
При редакторском сдвиге высвобождающиеся разряды слова заполняются любой, нужной пользователю информацией.
При
циклическом сдвиге разрядная сетка условно
замыкается в кольцо, и таким образом сдвигаемое
слово перемещается по этому кольцу. При
сдвиге вправо высвобождающиеся старшие
разряды автоматически заполняются младшими
цифрами слова, а при сдвиге влево высвобождающиеся
младшие разряды – старшими цифрами слова.
Циклический сдвиг интересен тем, что
он обеспечивает любое положение слова
в кольце только при одностороннем сдвиге.
Сдвигателем называется комбинационное цифровое устройство, реализующее операцию сдвига над исходным двоичным словом в соответствии с заданным типом, направлением и шагом сдвига. При разрядности сдвигаемого слова n сдвигатель должен иметь n информационных и 1 + log2n управляющих входов, а также m = 3n – 2 информационных выходов (в некоторых частных случаях число выходов может быть меньше).
Рассмотрим работу четырехразрядного сдвигателя, осуществляющего логические сдвиги в любую сторону с сохранением выдвигаемых цифр (часто такой сдвигатель называют сдвигателем без округления чисел). Ограничения на разрядность сдвигателя и вид сдвигов упрощают рассмотрение затронутых вопросов, не приводя к существенному уменьшению общности результатов.
Условное
графическое обозначение
Описание сдвигателя в содержательных терминах дает возможность построить его сокращенную таблицу истинности. Полная таблица истинности имела бы семь логических аргументов (x3, x2, x1, x0, D, S1, S0), десять функций (y6, y5, y4, y3, y2, y1, y0, y–1, y–2, y–3) и была очень громоздкой и плохо обозримой. Таблицу можно значительно сократить, если аргументы x3, x2, x1, x0 вывести из левой ее части и ввести в рабочие поля правой части вместо единиц, как это сделано в таблице 6.