Синтез логіки: відмінності між версіями

Матеріал з Вікіпедії — вільної енциклопедії.
Перейти до навігації Перейти до пошуку
[неперевірена версія][неперевірена версія]
Вилучено вміст Додано вміст
Inna Z (обговорення | внесок)
Мітки: Редагування з мобільного пристрою Редагування через мобільну версію
Inna Z (обговорення | внесок)
Немає опису редагування
Рядок 9: Рядок 9:


Однак, дворівневі логічні схеми є не настільки важливими у проектуванні {{нп|Схеми із дуже великим рівнем інтеграції|схем із дуже великим рівнем інтеграції|en|very-large-scale integration}} ({{lang-en|very-large-scale integration, VLSI}}); де більшість схем використовують декілька рівнів логіки. Власне кажучи, майже будь-яка схема представлена у RTL або описом поведінкової логіки є багаторівневим поданням. Першою системою, яка використовувалася для проектування багаторівневих схем, була система LSS від IBM. Вона використовувала для спрощення логіки локальні перетворення. Робота на LSS і Силіконовому компіляторі Yorktown стимулювала швидкий прогрес у дослідженнях синтезу логіки в 1980-их роках. Декілька університетів здійснили внесок зробивши свої дослідження доступними для широкого загалу, серед яких були SIS від [[Університет Каліфорнії (Берклі)|Каліфорнійського університету в Берклі]], RASP від [[Каліфорнійський університет у Лос-Анджелесі|Каліфорнійського університету в Лос-Анджелесі]] та BOLD від [[Колорадський університет у Боулдері|Колорадського університету в Боулдері]]. За десятиліття, технологія розвинулася у комерційні продукти синтезу логіки, що пропонують компанії з автоматизації проектування електронних систем.
Однак, дворівневі логічні схеми є не настільки важливими у проектуванні {{нп|Схеми із дуже великим рівнем інтеграції|схем із дуже великим рівнем інтеграції|en|very-large-scale integration}} ({{lang-en|very-large-scale integration, VLSI}}); де більшість схем використовують декілька рівнів логіки. Власне кажучи, майже будь-яка схема представлена у RTL або описом поведінкової логіки є багаторівневим поданням. Першою системою, яка використовувалася для проектування багаторівневих схем, була система LSS від IBM. Вона використовувала для спрощення логіки локальні перетворення. Робота на LSS і Силіконовому компіляторі Yorktown стимулювала швидкий прогрес у дослідженнях синтезу логіки в 1980-их роках. Декілька університетів здійснили внесок зробивши свої дослідження доступними для широкого загалу, серед яких були SIS від [[Університет Каліфорнії (Берклі)|Каліфорнійського університету в Берклі]], RASP від [[Каліфорнійський університет у Лос-Анджелесі|Каліфорнійського університету в Лос-Анджелесі]] та BOLD від [[Колорадський університет у Боулдері|Колорадського університету в Боулдері]]. За десятиліття, технологія розвинулася у комерційні продукти синтезу логіки, що пропонують компанії з автоматизації проектування електронних систем.

==Елементи логіки==
[[Image:Baops.gif|right|thumb|450px|Різні представлення булевих операцій]]
''Проектування логіки'' це крок циклу стандартного проектування в рамках якого {{нп|функціональний дизайн||en|functional design}} [[Електронна схема|електронної схеми]] перетворюється на представлення, яке включає [[Булева алгебра|логічні операції]], [[Арифметика|арифметичні операції]], [[Потік керування|порядок виконання]], та ін. Як правилом на виході цього кроку формується {{нп|Рівень передачі регістрів|RTL описання|en|Register-transfer level}}. За проектуванням логіки як правило слідує крок [[Схемотехніка|схемотехнічного проектування]]. В сучасних [[Програми проектування електронних систем|засобах автоматизації проектування електронних систем]] логічне проектування можливо автоматизувати використавши засоби {{нп|Синтез високого рівня|високорівневого синтезу|en|High-level synthesis}} на основі опису поведінки схеми.<ref name="Sherwani1999">{{cite book|author=Naveed A. Sherwani|title=Algorithms for VLSI physical design automation|year=1999|edition=3rd|page=4|publisher=Kluwer Academic Publishers|isbn=978-0-7923-8393-2}}</ref>

До логічних операцій як правило відносять булеві операції AND, OR, XOR та NAND, що є самими базовими формами операцій в електричних схемах. Арифметичні операції як правило виконують з використанням логічних операторів. Такі кола логіки як {{нп|двійковий помножувач||en|binary multiplier}} або [[Суматор|двійкове суматор]] є прикладами більш складних двійкових операцій, які можна реалізувати із використанням базових логічних операторів.


== Див. також ==
== Див. також ==

Версія за 11:45, 4 лютого 2019

В електроніці, синтез логіки — процес за допомогою якого абстрактний опис бажаної поведінки електронної схеми, як правило на рівні передачі регістрів (англ. Register-transfer level, RTL), перетворюється на конструкторську реалізацію в термінах логічних вентилів, як правило за допомогою комп'ютерної програми, що відноситься до класу засобів синтезування (англ. synthesis tool). Типовим прикладом цієї процедури є синтез проектів, описаних мовами опису апаратури (англ. hardware description language), до яких відносяться VHDL та Verilog.[1] Деякі засоби синтезування генерують бітові потоки для ПЛІС компонентів таких як PAL або FPGA, в той час як інші мають на меті створювати ASIC компоненти. Синтез логіки є одним із аспектів автоматизації проектування електронних систем.

Історія розвитку синтезу логіки

Початком синтезу логіки можна вважати коли Джордж Буль (1815-1864) започаткував своє трактування логіки, яке зараз має назву Булева алгебра. В 1938 Клод Шеннон показав, що Булева алгебра для двох значень (двійкова) може описати операцію перемикання електричних кіл. На початку, проектування логіки передбачало використання таблиць істинності і операцій над ними представлених у вигляді карт Карно. Мінімізація логіки на основі карт Карно здійснювалася відповідно до певного набору правил, які дозволяли об'єднати елементи мапи між собою. Людина, що проектує таку логіку, як правило може працювати з картами Карно, які містять лише до чотирьох-шести змінних.

Першим кроком до автоматизації процедури мінімізації логіки[en] стала поява алгоритму Куайна — Мак-Класкі, який можна було реалізувати на комп'ютері. Ці точні методи мінімізації започаткували поняття простих імплікантів і мінімальної вартості покриття, що стали основою дворівневої мінімізації. Згодом, стандартним інструментом для здійснення цієї процедури став більш ефективний евристичний мінімізатор логіки Еспрессо[en].

Інший напрямок ранніх досліджень полягав у мінімізації станів і кодуванні скінченних автоматів. Ця задача була досить складною для проектувальників. Програмні застосунки для синтезу логіки спрямовані в основному на проектування цифрових комп'ютерів. Тому, компанії IBM і Bell Labs відігравали ключову роль у ранній автоматизації синтезу логіки. Еволюція від компонентів дискретної логіки до програмованих логічних матриць[en](англ. programmable logic array, PLA) прискорила необхідність у створенні ефективної дворівневої мінімізації, оскільки мінімізування термів у дворівневій репрезентації дозволяло зменшити площу PLA.

Однак, дворівневі логічні схеми є не настільки важливими у проектуванні схем із дуже великим рівнем інтеграції (англ. very-large-scale integration, VLSI); де більшість схем використовують декілька рівнів логіки. Власне кажучи, майже будь-яка схема представлена у RTL або описом поведінкової логіки є багаторівневим поданням. Першою системою, яка використовувалася для проектування багаторівневих схем, була система LSS від IBM. Вона використовувала для спрощення логіки локальні перетворення. Робота на LSS і Силіконовому компіляторі Yorktown стимулювала швидкий прогрес у дослідженнях синтезу логіки в 1980-их роках. Декілька університетів здійснили внесок зробивши свої дослідження доступними для широкого загалу, серед яких були SIS від Каліфорнійського університету в Берклі, RASP від Каліфорнійського університету в Лос-Анджелесі та BOLD від Колорадського університету в Боулдері. За десятиліття, технологія розвинулася у комерційні продукти синтезу логіки, що пропонують компанії з автоматизації проектування електронних систем.

Елементи логіки

Різні представлення булевих операцій

Проектування логіки це крок циклу стандартного проектування в рамках якого функціональний дизайн[en] електронної схеми перетворюється на представлення, яке включає логічні операції, арифметичні операції, порядок виконання, та ін. Як правилом на виході цього кроку формується RTL описання. За проектуванням логіки як правило слідує крок схемотехнічного проектування. В сучасних засобах автоматизації проектування електронних систем логічне проектування можливо автоматизувати використавши засоби високорівневого синтезу[en] на основі опису поведінки схеми.[2]

До логічних операцій як правило відносять булеві операції AND, OR, XOR та NAND, що є самими базовими формами операцій в електричних схемах. Арифметичні операції як правило виконують з використанням логічних операторів. Такі кола логіки як двійковий помножувач[en] або двійкове суматор є прикладами більш складних двійкових операцій, які можна реалізувати із використанням базових логічних операторів.

Див. також

Примітки

  1. Synthesis:Verilog to Gates (PDF).
  2. Naveed A. Sherwani (1999). Algorithms for VLSI physical design automation (вид. 3rd). Kluwer Academic Publishers. с. 4. ISBN 978-0-7923-8393-2.

Джерела

  • Electronic Design Automation For Integrated Circuits Handbook, by Lavagno, Martin, and Scheffer, ISBN 0-8493-3096-3 A survey of the field of Electronic design automation. The above summary was derived, with permission, from Volume 2, Chapter 2, Logic Synthesis by Sunil Khatri and Narendra Shenoy.
  • A Consistent Approach in Logic Synthesis for FPGA Architectures, by Burgun Luc, Greiner Alain, and Prado Lopes Eudes, Proceedings of the international Conference on Asic (ASICON), Pekin, October 1994, pp. 104–107.

Література

  • Jie-Hong (Roland) Jiang, Srinivas Devadas (2009). Logic synthesis in a nutshell. У Laung-Terng Wang; Yao-Wen Chang; Kwang-Ting Cheng (ред.). Electronic design automation: synthesis, verification, and test. Morgan Kaufmann. ISBN 978-0-12-374364-0. chapter 6.
  • Gary D. ....Hachtel; Fabio Somenzi (1996). Logic synthesis and verification algorithms. Springer. ISBN 0-7923-9746-0. Також опубліковано у м'якій обкладинці ISBN 0-387-31004-5 у 2006
  • Soha Hassoun; Tsutomu Sasao, ред. (2002). Logic synthesis and verification. Kluwer. ISBN 978-0-7923-7606-4.