Добавил:
Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
Учебники 60305.doc
Скачиваний:
14
Добавлен:
01.05.2022
Размер:
12.19 Mб
Скачать

Лекция 6. Способы синтеза функциональных узлов цифровых устройств комбинационного типа

Постановка задачи. На основе описания функционирования комбинационного устройства построить электрическую принципиальную схему данного устройства в заданном базисе.

Проектирование про­извольной логики комбинационного типа производится по этапам (укрупнено – согласно рис. 27).

Рис. 27

Сложные КС разрабатывают с помощью средств автоматизации проектирования, выполняя многоуровневую декомпозицию КС на более простые узлы. В целом последовательность этапов проектирования выглядит следующим образом.

  1. Задать автомат словесно или в виде диаграммы «входы-выходы»; уточнить словесное описание КС, раскрыв содержание использованных заказчиком терминов и понятий.

  2. Представить КС в виде функционального ЭЛЕМЕНТА («черного ящика»), затем разработать в соответствии с п. 1 его функциональную спецификацию, включающую внешнее представление (полная совокупность всех входов и выходов, УГО) и внутреннее описание, определяющее характер функционирования КС. Это может быть сделано различными способами, чаще всего формируют таблицы функ­ционирования (таблицы истинности), задающие значение искомых функций на всех наборах аргументов (некоторые значения могут быть неопределенными).

  3. От таблицы перейти к СДНФ искомых функций (СДНФ — совершенная дизъюнктивная нормальная форма, т. е. дизъюнкция конъюнктивных членов одинаковой размерности). Для этого составляют логическую сумму тех наборов аргументов, на которых функция принимает единичное значение. Иногда удобнее использовать СКНФ.

  4. Далее следует выбрать одно из средств аппаратной реализации функций.

  5. Оптимизировать представление заданной функции или системы функций применительно к выбранному типу аппаратных средств.

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

  7. Проверить функционирование КС на соответствие исходной таблице истинности и словесному описанию (просчетом состояний, моделированием или макетированием).

Алгоритм вкратце: словесное описание → УГО + таблицы функ­ционирования → формула → схема.

Содержание этапов 5, 6 зависит от сделанного в п. 4 выбора. Рассмотрим разновидности используемых аппаратных средств. К ним в современной схемотехнике относятся:

  1. Логические блоки, собираемые из логических элементов некоторого ба­зиса (SLC, Small Logic Cells).

  2. Логические блоки в виде последовательности матриц элементов И и ИЛИ с программируемыми связями (PLA, Programmable Logic Array; PAL, Programmable Array Logic).

  3. Универсальные логические блоки на основе мультиплексоров.

  4. Логические блоки табличного типа (LUTs, Look-Up Tables).

  5. Не исключается и применение функционально законченных микросхем т. наз. средней степени интеграции, которые представляют собой непрограммируемые комбинации элементов И и ИЛИ (шифраторы, дешифраторы, АЛУ и др.).

Основанием выбора служат достоинства и недостатки каждого варианта.

  1. Данное средство реализации является наиболее традиционным. Блоки на базе SLC разрабатываются для конкретного применения, существуют методы минимизации аппаратных средств, описанные ниже. Результатом такого варианта является специальное устройство, не подлежащее перенастройке и занимающее много места (печатная плата).

  2. БИС/СБИС программируемой логики сочетают в себе достоинства приспособляемости к задаче заказчика, массовости производства (следовательно, низкой цены), компактности и повышенной надежности (минимум внешних линий связи).

  3. Универсальные логические модули (УЛМ) на основе мультиплексоров отно­сятся к устройствам, настраиваемым на решение той или иной задачи. Уни­версальность их состоит в том, что для заданного числа аргументов можно настроить УЛМ на любую функцию. Известно, что общее число функций n аргументов выражается как с ростом n число функций растет чрезвычайно быстро (например, одна из БИС фирмы Actel позволяет реализовать более 700 различных функций). Хотя практический интерес представляют не все существующие функции, возможность получить любую из огромного числа функций свидетельствует о больших перспективах применения УЛМ. В то же время большое число настроечных входов затрудняет реализацию УЛМ.

  4. Табличный блок представляет собою память, в которой имеется столько ячеек, сколько необходимо для хранения всех значений функций, т. е. 2 m, где m — число аргументов функции. Набор аргументов является адресом той ячейки, в ко­торой хранится значение функции на этом наборе (0 или 1). LUTs обычно имеют множество входов и выходов и их применение целесообразно при необходимости получения большой группы функций, не поддающихся минимизации.

Рассмотрим представление заданной функции или системы функций применительно к выбранному типу аппаратных средств (см. п. 5).

  1. Синтез КС на логических блоках типа SLC, т.е. на вентильном уровне, яв­ляется самым традиционным и изученным (термином "вентиль" называют базовые логические ячейки, выполняющие простейшие операции, для многих ИС эту роль играют элементы И-НЕ с двумя-восемью входами).

В этом варианте следующими этапами проектирования КС являются:

  • минимизация логических функций;

  • переход к заданному логическому базису;

  • контроль отсутствия критических состязаний (рисков).

Минимизация в широком смысле слова — такое преобразование логических функ­ций, которое упрощает их в смысле заданного критерия. Исторически первым было стремление минимизировать число логических элементов в схеме (элементы были наиболее дорогими компонентами устройств), что приводит к критерию сложности схемы в виде числа букв в реализуемых выражениях. Этот критерий учитывается так называемой ценой по Квайну — суммарным числом входов всех логических элементов схемы. Для минимизации по этому критерию разработано несколько методов, в их числе как аналитические, ос­нованные на преобразованиях математических выражений, так и графические, основанные на применении специальных карт (карт Карно, диаграмм Вейча), удобных в использовании, если число аргументов функции не превышает 6.

С переходом на ИС и ростом уровня их интеграции критерием аппаратной сложности ЦУ стала площадь, затрачиваемая на их размещение. При этом для ИС, реализуемых непосредственно на кристалле, площадь имеет прямой физический смысл и измеряется чаще всего в квадратных миллиметрах. Для устройств, реализуемых на печатной плате, "площадь" измеряется числом корпусов в составе ЦУ. Так как корпуса ИС неодинаковы, их следует приво­дить к некоторым эквивалентным корпусам. Приведение учитывает число вы­водов корпуса, так, например, корпус с 24 выводами в 1,5 раза сложнее кор­пуса с 16 выводами. Понятно, что операции приведения соответствует оценка суммарной площади корпусов ЦУ по общему числу всех выводов корпусов ИС.

Минимизация по числу букв в реализуемом выражении перестала точно со­ответствовать новому критерию, хотя между обоими критериями сохраняет­ся известная связь.

Следующий этап проектирования — переход к заданному (или принятому за оптимальный) логическому бази­су от исходных выражений, которые обычно получают в булевском базисе (И, ИЛИ, НЕ). Рассмотрим пример перехода для функции Правила такого перехода известны, они основаны на приме­нении теоремы де Моргана. В частности, для перехода к базису И-НЕ ис­пользуется соотношение

а для перехода к базису Пирса удобно вначале получить исходную булев­скую форму для инверсии искомой функции, а затем от нее перейти к бази­су ИЛИ-НЕ по соотношениям

Традиционные методы минимизации функций алгебры логики приводят к каноническим их формам, соответствующим двухъярусной (если входные пе­ременные заданы и прямыми и инверсными значениями) реализации путем последовательного выполнения операций И и ИЛИ. Переход к базисам И-НЕ и ИЛИ-НЕ ярусность схем не изменяет. Для построения простых схем или схем на некоторых видах программируемой матричной логики такое пред­ставление может служить в качестве окончательного варианта. Для некоторых задач каноническое представление может оказаться слишком громоздким. Для упрощения выражений можно применять к ним факторизацию (вынесение общих множителей за скобки и группирование членов), различного рода эк­вивалентные подстановки и др. Упрощение функций путем факторизации может дать большой эффект, но при этом увеличивается ярусность схем и. следовательно, возрастает задержка в выработке результата. с другой стороны, использование не единого базиса, а сочетания разных функциональных элементов зачастую позволяет сократить аппаратурные затраты. Чаще всего достаточно использовать сочетание микросхем с функциями НЕ, И-НЕ (либо ИЛИ-НЕ) и Исключающее ИЛИ (приведение последних в базис Шеффера или Пирса увеличивает количество корпусов в 4 раза!). Кроме того, в ходе реализации следует учитывать возможности сокращения ассортимента применяемых микросхем за счет использования свободных вентилей с большими возможностями (числом входов, сложностью функции) вместо элементов с меньшими.

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

В работе /13, с. 6/ сказано: "Примером исчисления, которым широко поль­зуются в процессе синтеза логических схем, являются преобразования алгебры логики. Набор правил говорит лишь о том, как можно преобразовать исходное булево выражение, но ничего не говорит о том, как нужно его преобразовать, чтобы на данном логическом базисе получить минимальную задержку или минимальное число корпусов, или некоторый компромисс между этими требованиями". С 1988 года, когда это было написано, ситуация не изменилась, тем более, что базис SLC для сложных узлов неактуален.

К проблематике проектирования ЦУ относится и вопрос о критериях их каче­ства. Поскольку одну и ту же задачу можно решить многими способами, воз­никают альтернативные варианты проекта, которые нужно уметь сравнивать между собой. Объективная сложность сравнительной оценки вариантов обу­словлена тем, что при этом имеет значение целый набор свойств для каждого варианта — частных критериев его качества. Каждый частный критерий имеет ясный, определенный смысл (аппаратная сложность, быстродействие, потреб­ляемая мощность, помехоустойчивость и др.), но не может исчерпывающим образом охарактеризовать вариант. А чтобы учесть несколько частных крите­риев качества, нужно сформировать общий критерий (интегральный, многоце­левой, функцию качества, функцию ценности). Формирование такого крите­рия — чрезвычайно ответственная задача, не имеющая формального решения. В любую форму общего критерия качества входят коэффициенты, назначаемые субъективно. Таким образом, возникает ситуация, когда для оценки устройства применяется критерий, а для него самого оценки качества не существует. По­этому в практике проектирования сложные общие критерии качества не по­пулярны. Достаточно признанным можно, пожалуй, считать лишь критерий A·T, где А — аппаратная сложность устройства, Т — время решения задачи. Да и то здесь также проявляется общий недостаток, свойственный всем общим критериям — в них может происходить взаимная компенсация частных кри­териев, и уменьшение одного может быть скомпенсировано ростом другого, что формально равноценно, но не всегда разумно.

Как известно, выходные величины КС зависят только от текущего значения входных величин (аргументов). Предыстория значения не имеет. После завершения переходных процессов в КС на их выходах устанавливаются выходные величины, на ко­торые характер переходных процессов влияния не оказывает. С этой точки зрения переходные процессы в КС не опасны. Но в ЦУ в целом КС функ­ционируют совместно с АП, что кардинально меняет ситуацию. Во время переходных процессов на выходах КС появляются врéменные сигналы, не преду­смотренные описанием работы КС и называемые рисками. Сам процесс разновременности в формировании сигналов при переключении называют гонками или состязаниями (различают некритические состязания, которые происходят внутри схемы и не проявляются на выходах, и критические, ведущие к рискам). Со временем риски исчезают, и выход КС приобретает значение, предусмотренное логической формулой, описывающей работу цепи. Однако риски могут быть восприняты элементами памяти АП, необратимое изменение состояния которых может радикально изменить работу ЦУ, несмотря на исчезновение сигналов рисков на выходе КС.

Для исключения возможных сбоев в работе ЦУ из-за явлений риска имеются два пути. Первый состоит в синтезе схем, свободных от рисков, и требует сложного анализа процессов в схеме и введения избыточных элементов для исключе­ния рисков /9/. Этот путь редко используется в практике. Второй путь, основной для современной схемотехники, предусматривает запрещение восприятия сигналов КС элементами памяти на время переходных процессов. Прием информации с выходов КС разрешается только специаль­ным сигналом синхронизации, подаваемым на элементы памяти после окончания переходных процессов в КС. Таким образом, исключается воз­действие ложных сигналов на элементы памяти. Иными словами, основная идея здесь может быть выражена словами "переждать неприятности". Соответствующие структуры называются синхронными.

В общем случае нужно оценить задержку сигнала на самом коротком пути как сумму минимальных задержек элементов, составляющих этот путь, и задержку на самом длинном пути как сумму максимальных. Обычно в документации изготовителей даны только максимальные задержки, а в результате теряется возможность сравнивать времена прохождения сигналов в разных цепях (в любой цепи задержка может быть сколь угодно малой), а это затрудняет оценку работоспособности схем и может вынудить принять не лучшие схемотехнические решения. Для цепей из элементов с независимыми задержками отношение tз.тах/tз.min равно обычно 2...3, для элементов одного кристалла между задержками эле­ментов возникает сильная корреляция, и отношение tз.тах/tз.min может су­щественно снижаться.

Если данный проект реализуется на логических блоках в виде последова­тельно включенных матриц элементов И и ИЛИ либо их эквивалента в другом базисе, то исходную СДНФ можно минимизировать, если, конечно, возникает такая необходимость. Логические блоки с матрицами И и ИЛИ воспроизводят системы переключательных функций. Число входов (аргументов воспроизводи­мых функций) и число выходов (самих функций) от формы выражения функций не зависят и предопределены заданием. Число термов (имеются в виду конъюнктивные термы) зависит от формы представления функций системы. Если число термов при данной форме представления функций превышает возможности логического блока, то возникает вопрос о миними­зации функций. Целью минимизации будет сокращение числа конъюнктивных термов в данной системе функций, т. е. поиск кратчайших дизъюнктивных форм. Практически это сводится к поиску минимальных форм дизъюнктив­ных нормальных форм (ДНФ), и отбору среди них вариантов с достаточно малым числом термов. Как только находится форма с достаточно малым числом термов, поиск дру­гих форм можно прекратить, т. к. дальнейшее уменьшение числа термов сис­темы эффекта не даст: сложность аппаратных средств воспроизведения системы уже не уменьшится. Разумеется, речь идет о реализациях на уже выбранных средствах, а не о том, что могут быть применены иные логиче­ские блоки — того же типа, но иной размерности.

Логические блоки на основе мультиплексоров рассмотрены в /1, § 2.5/.

Если КС будет реализована на основе логических блоков табличного типа (см. /1, § 4.5/), то СДНФ явится окончательным выражением функции, и никаких дальнейших преобразований этой формы не потребуется. Дело в том, что табличный блок представляет собою память, в которой имеется столько ячеек, сколько необходимо для хранения всех значений функций, т. е. 2 m, где m — число аргументов функции. Набор аргументов является адресом той ячейки, в ко­торой хранится значение функции на этом наборе (0 или 1). СДНФ как раз и содержит все адреса, по которым нужно хранить единичные значения функции. Если требуется воспроизвести n функций, то в каждой ячейке нужно будет хранить n бит (по одному биту для каждой функции).

Если искомая функция выражена в какой-либо сокращенной форме, то следует перевести ее в СДНФ. Это делается либо заполнением карты Карно и последующей за­писью функции без какого-либо объединения единиц, либо введением в каждую конъюнкцию недостающих переменных хi путем домножения конъ­юнкции на равные единице выражения c последующим раскрытием скобок (хi — вводимая переменная). Пример приведения функции в СДНФ:

Для воспроизведения этой функции по пяти конъюнкциям-адресам в ППЗУ следует записать единицы, по остальным адресам – нули.

Реализация функции в СДНФ определяет большие затраты элементов памя­ти, однако цена элемента памяти значительно ниже цены логического эле­мента, поэтому даже при избыточности числа элементов памяти в несколько раз (по сравнению с числом логических элементов, необходимых для воспроизведения функции на SLC) реализация на ППЗУ может оказаться выгодной. К тому же время прохождения сигнала на выход ППЗУ одинаково для всех входов.

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