И-инверторный график - And-inverter graph

An и-инверторный граф (AIG) направленный, ациклический график который представляет собой структурную реализацию логической функциональности цепь или сеть. AIG состоит из узлов с двумя входами, представляющих логическое соединение, конечные узлы, помеченные именами переменных, и ребра, необязательно содержащие маркеры, указывающие логическое отрицание. Такое представление логической функции редко бывает структурно эффективным для больших схем, но является эффективным представлением для манипулирования логические функции. Обычно абстрактный граф представлен в виде структура данных в программном обеспечении.

Два структурно различных AIG для функции f (x1, x2, x3) = x2 * (x1 + x3)

Конверсия из сети логические ворота в AIG быстро и масштабируемо. Требуется только, чтобы все ворота были выражены в терминах И ворота и инверторы. Это преобразование не приводит к непредсказуемому увеличению использования памяти и времени выполнения. Это делает AIG эффективным представителем по сравнению с диаграмма двоичных решений (BDD) или форма «сумма произведений» (ΣoΠ),[нужна цитата ] это каноническая форма в Булева алгебра известный как дизъюнктивная нормальная форма (ДНФ). BDD и DNF также можно рассматривать как схемы, но они содержат формальные ограничения, которые лишают их масштабируемости. Например, ΣoΠ - это схемы с максимум двумя уровнями, в то время как BDD являются каноническими, то есть они требуют, чтобы входные переменные оценивались в одном порядке на всех путях.

Цепи, состоящие из простых вентилей, включая AIG, являются «древней» исследовательской темой. Интерес к AIG начался с основополагающей статьи Алана Тьюринга 1948 года.[1] на нейронных сетях, в которых он описал рандомизированную обучаемую сеть вентилей NAND. Интерес продолжался до конца 1950-х годов.[2] и продолжился в 1970-х годах, когда были развиты различные локальные преобразования. Эти преобразования были реализованы в нескольких системах логического синтеза и проверки, таких как Darringer et al.[3] и Smith et al.,[4] которые сокращают схемы для улучшения площади и задержки во время синтеза или для ускорения формальная проверка эквивалентности. Несколько важных методов были обнаружены на ранних этапах IBM, такие как объединение и повторное использование логических выражений и подвыражений с несколькими входами, теперь известных как структурное хеширование.

В последнее время наблюдается возобновление интереса к AIG как к функциональное представление для множества задач по синтезу и проверке. Это потому, что представления, популярные в 1990-х годах (такие как BDD), достигли пределов масштабируемости во многих своих приложениях.[нужна цитата ] Еще одним важным событием стало недавнее появление гораздо более эффективных логическая выполнимость (SAT) решатели. В сочетании с AIG как представление схемы, они приводят к значительному ускорению решения самых разнообразных логические проблемы.[нужна цитата ]

AIG нашли успешное применение в различных EDA Приложения. Хорошо настроенное сочетание AIG и логическая выполнимость оказал влияние на формальная проверка, включая оба проверка модели и проверка эквивалентности.[5] Другая недавняя работа показывает, что эффективные методы сжатия схем могут быть разработаны с использованием AIG.[6] Растет понимание того, что задачи логического и физического синтеза можно решать с помощью моделирования и логическая выполнимость для вычисления функциональных свойств (таких как симметрии)[7] и гибкости узлов (например, условия безразличия, замены, и СПФД ).[8][9][10] Мищенко и др. показывает, что AIG являются многообещающим объединение представительство, которое может соединить логический синтез, картографирование технологий, физический синтез и формальная проверка. Это в значительной степени связано с простой и единообразной структурой AIG, которые позволяют переписывать, моделировать, отображать, размещать и проверять одну и ту же структуру данных.

Помимо комбинационной логики, AIG также применялись к последовательная логика и последовательные преобразования. В частности, метод структурного хеширования был расширен для работы с AIG с элементами памяти (такими как Шлепанцы D-типа с начальным состоянием, которое, как правило, может быть неизвестным), что приводит к структуре данных, специально предназначенной для приложений, связанных с повторная синхронизация.[11]

Текущие исследования включают внедрение современной системы логического синтеза, полностью основанной на AIG. Прототип назывался ABC включает пакет AIG, несколько основанных на AIG методов синтеза и проверки эквивалентности, а также экспериментальную реализацию последовательного синтеза. Один из таких методов объединяет технологическое отображение и повторное синхронизацию на одном этапе оптимизации. Эти оптимизации могут быть реализованы с использованием сетей, состоящих из произвольных вентилей, но использование AIG делает их более масштабируемыми и более простыми в реализации.

Реализации

Рекомендации

  1. ^ Статья Тьюринга 1948 года была перепечатана как Turing AM. Интеллектуальная техника. В: Ince DC, редактор. Собрание сочинений А. М. Тьюринга - Механический интеллект. Издательство Elsevier Science, 1992.
  2. ^ Л. Хеллерман (июнь 1963 г.). «Каталог логических схем с тремя переменными или инверторами и инверторами». IEEE Trans. Электрон. Вычислить. ИС-12 (3): 198–223. Дои:10.1109 / PGEC.1963.263531.
  3. ^ А. Даррингер; W. H. Joyner, Jr .; К. Л. Берман; Л. Тревиллян (Июль 1981 г.). «Логический синтез через локальные преобразования». Журнал исследований и разработок IBM. 25 (4): 272–280. CiteSeerX  10.1.1.85.7515. Дои:10.1147 / rd.254.0272.
  4. ^ Г. Л. Смит; Р. Дж. Бансен; Х. Холливелл (январь 1982 г.). «Логическое сравнение оборудования и блок-схем». Журнал исследований и разработок IBM. 26 (1): 106–116. CiteSeerX  10.1.1.85.2196. Дои:10.1147 / rd.261.0106.
  5. ^ А. Кюльманн; В. Парути; Ф. Кром; М. К. Ганаи (2002). «Надежные логические рассуждения для проверки эквивалентности и проверки функциональных свойств». IEEE Trans. CAD. 21 (12): 1377–1394. CiteSeerX  10.1.1.119.9047. Дои:10.1109 / tcad.2002.804386.
  6. ^ Пер Бьессе; Арне Боральв (2004). «Сжатие схемы с поддержкой DAG для формальной проверки» (PDF). Proc. ICCAD '04. С. 42–49.
  7. ^ К.-Х. Чанг; И. Л. Марков; В. Бертакко (2005). «Перемонтаж и переупаковка после размещения путем исчерпывающего поиска функциональных симметрий» (PDF). Proc. ICCAD '05. С. 56–63.
  8. ^ А. Мищенко; Дж. С. Чжан; С. Синха; Дж. Р. Берч; Р. Брайтон; М. Хшановска-Еске (май 2006 г.). «Использование моделирования и выполнимости для вычисления гибкости в булевых сетях» (PDF). IEEE Trans. CAD. 25 (5): 743–755. CiteSeerX  10.1.1.62.8602. Дои:10.1109 / tcad.2005.860955.
  9. ^ С. Синха; Р. К. Брайтон (1998). «Внедрение и использование SPFD для оптимизации булевых сетей». Proc. ICCAD. С. 103–110. CiteSeerX  10.1.1.488.8889.
  10. ^ С. Ямасита; Х. Савада; А. Нагоя (1996). «Новый метод выражения функциональной допустимости для ПЛИС на основе LUT и их приложений» (PDF). Proc. ICCAD. С. 254–261.
  11. ^ Дж. Баумгартнер; А. Кюльманн (2001). «Восстановление минимальной площади на гибких схемах» (PDF). Proc. ICCAD'01. С. 176–182.

Смотрите также


Эта статья адаптирована из колонки в ACM SIGDA электронная рассылка к Алан Мищенко
Доступен оригинальный текст Вот.