УДК 004.312.2, 004.021, 510.649
ИСПОЛЬЗОВАНИЕ РЕЛЯЦИОННОЙ ТЕОРИИ ПРИ ОПТИМАЛЬНОМ ПРОЕКТИРОВАНИИ ИНТЕГРАЛЬНЫХ СХЕМ Д.В. Демидовa, b
a Университет ИТМО, 197101, Санкт-Петербург, Россия
b ЗАО «Интел А/О», 196247, Санкт-Петербург, Россия, [email protected]
Аннотация. Предложен подход к адаптации реляционной теории для решения задач систем автоматизированного проектирования интегральных схем. Разработан алгоритм оптимального поиска неявных Don't Care (безразличных) значений. Алгоритм описан в терминах адаптированной теории, что позволило получить простое описание алгоритма как для неформального понимания, так и для формального анализа. Предложенный подход позволяет использовать позитивный опыт реляционных баз данных по эффективной (в том числе распределенной) реализации операций реляционной алгебры.
Проведен сравнительный анализ предложенного алгоритма и классического алгоритма оптимального поиска неявных Don't Care значений. В ходе сравнительного анализа формально доказана корректность предложенного алгоритма. Показано, что предложенный алгоритм, по сравнению с классическим, имеет значительно меньшую асимптотическую сложность в худшем случае.
Поиск неявных Don't Care значений в процессе проектирования интегральных схем позволяет повысить такие качества схем, как занимаемая площадь кристалла, энергопотребление, верифицируемость и надежность. Однако классический алгоритм оптимального поиска неявных Don't Care значений не применяется на практике ввиду его чрезмерно высокой вычислительной сложности. Применение алгоритмов субоптимального поиска не позволяет в полной мере реализовать возможности оптимизации интегральных схем. Реализация предложенного в работе алгоритма в системах автоматизированного проектирования интегральных схем целесообразна в силу значительно меньшей вычислительной сложности, потенциально позволяет улучшить соотношение скорости процесса разработки и качества получаемых интегральных схем в аспектах занимаемой площади кристалла, энергопотребления, верифицируемости и надежности. Предложенный подход делает возможным создание распределенной системы автоматизированного проектирования интегральных схем, что позволит повысить доступную системе вычислительную мощность и автоматизировать проектирование более сложных интегральных схем соответственно.
Ключевые слова: САПР, интегральные схемы, оптимизация комбинационных схем, логические сети, частично определенные булевы функции, неявные Don't Care значения, ODC, реляционная теория, реляционная алгебра, естественное соединение.
RELATIONAL THEORY APPLICATION FOR OPTIMAL DESIGN OF INTEGRATED CIRCUITS D.V. Demidova, b
a ITMO University, 197101, Saint Petersburg, Russia
b "Intel A/O", Ltd., 196247, Saint Petersburg, Russia, [email protected]
Abstract. This paper deals with a method of relational theory adaptation for integrated circuits CAD systems. A new algorithm is worked out for optimal search of implicit Don't Care values for combinational multiple-level digital circuits. The algorithm is described in terms of the adapted relational theory that gives the possibility for a very simple algorithm description for both intuitive understanding and formal analysis. The proposed method makes it possible to apply progressive experience of relational databases in efficient implementation of relational algebra operations (including distributed ones). Comparative analysis of the proposed algorithm and a classic one for optimal search of implicit Don't Cares is carried out. The analysis has proved formal correctness of the proposed algorithm and its considerably less worst-case complexity. The search of implicit Don't Care values in the integrated circuits design makes it easier to optimize such characteristics of IC as chip area, power, verifiability and reliability. However, the classic algorithm for optimal search of implicit Don't Care values is not used in practice due to its very high computational complexity. Application of algorithms for sub-optimal search doesn't give the possibility to realize the potential of IC optimization to the full. Implementation of the proposed algorithm in IC CAD (a.k.a., EDA) systems is adequate due to much lower computational complexity, and potentially makes it possible to improve the quality-development time ratio of IC (chip area, power, verifiability and reliability). Developed method gives the possibility for creation of distributed EDA system with higher computational power and, consequently, for design automation of more complex IC.
Keywords: CAD, EDA, VLSI, optimization of combinational schemes, Boolean networks, partially defined Boolean functions, implicit Don't Cares, ODC, relational theory, relational algebra, natural join.
Введение
В силу возрастающей сложности и миниатюризации, а также ускоряющихся темпов производства электронных устройств возрастают требования к занимаемой площади кристалла, энергопотреблению, верифицируемости, надежности и скорости разработки интегральных схем (ИС). Неотъемлемой частью процесса проектирования ИС является решение задачи оптимизации логических схем, причем противоречивые ограничения требуют создания многоуровневых логических схем. Однако поиск оптимальной многоуровневой логической схемы неприемлемо сложен, поэтому на практике решается задача поиска субоптимальной схемы, а многие исследования направлены на разработку методов и эвристик, позволяющих снизить сложность решаемой задачи и приблизить результат к оптимальному [1-5].
Одним из ключевых моментов при оптимизации многоуровневых логических схем является поиск так называемых неявных Don't Care (безразличных или DC) значений, который, с одной стороны, позволяет существенно приблизиться к оптимальному решению, но, с другой стороны, заключает в себе значительную часть сложности исходной задачи [6].
Автором было замечено, что используемые при решении этой задачи структуры данных по своей семантике весьма близки к отношениям, используемым в теории реляционных баз данных. Алгоритмы работы с такими структурами хорошо проработаны как теоретически, так и практически, что потенциально позволяет сократить сложность поиска DC-значений, а также разработать распределенную версию алгоритма.
В работе предложен алгоритм оптимального поиска неявных DC-значений, описанный в терминах реляционной теории, адаптированной к задачам систем автоматизированного проектирования интегральных схем (САПР ИС), и доказана корректность последнего. Показано, что для предложенного алгоритма вычислительная сложность в худшем случае значительно ниже, чем для классического (экспоненциальная сложность против более чем факториальной).
Возможно внедрение результатов предлагаемой работы в существующие САПР ИС, что позволит ускорить (соответственно удешевить) и повысить качество разработки ИС (в том числе сократить занимаемую площадь кристалла и энергопотребление, повысить верифицируемо сть и надежность ИС [7-12]). На основе предложенного подхода к адаптации реляционной теории возможно создание распределенной САПР ИС, что позволит автоматизировать проектирование более сложных ИС, требующее высокой вычислительной мощности.
Объект исследования
В работе исследуется алгоритм оптимального поиска неявных DC-значений, применяемый на одном из этапов оптимизации многоуровневых комбинационных схем - неотъемлемой части проектирования ИС. В силу противоречивых требований к ИС используются многоуровневые комбинационные схемы, позволяющие производить минимизацию как по площади (занимаемой схемой), так и по задержке (при которой схема работает корректно). Математически многоуровневые комбинационные схемы представляют в виде логических сетей [13, 14] - ациклических ориентированных графов, которые подробно описаны в следующем разделе.
Процесс оптимизации многоуровневой комбинационной схемы является итерационным [1-5, 14, 15]. Основные этапы данного процесса показаны на рис. 1.
Рис. 1. Основные этапы процесса оптимизации многоуровневых комбинационных схем. Этапы, на которых используются исследуемые алгоритмы, выделены цветом
На этапе оптимизации структуры сети изменяется структура графа, представляющего логическую сеть (объединяются или разделяются узлы), и процесс, в основном, направлен на минимизацию задержки схемы.
На этапе оптимизации узлов сети структура графа остается неизменной, а изменяется внутреннее представление узлов, и процесс направлен на минимизацию площади (занимаемой схемой) и косвенно энергопотребления. Данный этап разделяется на два подэтапа - выделение неявных DC-значений и двухуровневую оптимизацию. На подэтапе двухуровневой оптимизации происходит собственно оптимизация внутреннего представления узла с применением точных (например, метод Квайна-Мак-Класки) или эвристических (например, используемых в семействе программ Espresso) алгоритмов [13-16]. Однако, если не выполнять предшествующий подэтап выделения неявных DC-значений, данный подэтап оперирует
только информацией о внутреннем представлении узла, не учитывая структуру сети, и ограничен в возможностях оптимизации. Кроме того, выполнение подэтапа выделения неявных DC-значений позволяет упростить генерацию тестов единичного отказа, а соответственно, повышает верифицируемость и надежность конечной ИС [7-12].
Представление многоуровневых комбинационных схем
Как упоминалось выше, многоуровневую комбинационную схему представляют в виде логической сети - ориентированного ациклического графа, в котором:
- выделена специальная вершина «Primary Inputs», имеющая только исходящие дуги, помеченные литералами, обозначающими входы схемы;
- выделена специальная вершина «Primary Outputs», имеющая только входящие дуги, помеченные литералами, обозначающими выходы схемы;
- прочие вершины помечены булевыми функциями общего вида, представленными в некоторой канонической форме;
- дуги между прочими вершинами помечены литералами, обозначающими внутренние переменные -выходные значения и аргументы для булевых функций, помечающих начальные вершины и конечные вершины дуги соответственно.
Способы представления булевой функции f: Bn ^ B, B = {0,1} в узле можно разделить на два
больших класса: бинарные диаграммы решений (БДР или BDD) и структуры, задающие дизъюнктивную или конъюнктивную нормальную форму (ДНФ или КНФ) функции (например, Positional Cube Notation). В настоящей работе рассматриваются способы, задающие ДНФ функции. Семантически такие способы задают множество множеств литералов (аргументов функции), взятых в положительной или отрицательной форме:
S е 2LxB,(S> = v д </> © n ,
seS (l,n )es
где L с {a,b,с...} - множество литералов; s - терм ДНФ; (l^ - значение аргумента обозначаемого литералом l .
В действительности для задаваемой функций обычно существует такое множество DCf значений
аргументов, что значение выхода функции неважно. Примерами причин существования подобных входных значений являются следующие ситуации:
- некоторые сочетания входных значений могут быть запрещенными и, при корректной работе окружения схемы, никогда не будут поданы на ее входы (например, незаданные коды операций);
- в соответствии с некоторым протоколом при определенных условиях (например, схема находится в состоянии сброса или определенном режиме) некоторые выходы схемы могут быть проигнорированы окружением схемы.
Если множество DCf не пусто, говорят, что функция f определена частично. Математически частично определенная булева функция f задается парой (fON, fOFF) обычных (полностью определенных) булевых функций при выполнении условия Vx. fON (x) д fOFF (x), где fON - ON-set, определяющий значения аргументов x, при которых f (x) должна равняться логической единице, а fOFF - OFF-set, определяющий значения аргументов x, при которых f (x) должна равняться логическому нулю. Тогда можно определить функцию fDC (x) = fON (x) д fOFF (x), такую, что DCf ={x: fDC (x)} . Также можно сказать, что частично определенная функция задает множество функций F = {f: (on ( x) ^ f (x))д ((Off (x) ^ f (x))}, среди которых производится выбор наилучшей альтернативы на подэтапе двухуровневой оптимизации.
Неявные Don't Care значения. Классический алгоритм поиска
Для каждого узла f сети множество DC-значений определяется как объединение пяти подмножеств: DCf = XCDCf и CDCf и SDCf и ODCf иXODCf (рис. 2). Здесь XCDCf и XODCf - так называемые внешние (external) DC-значения, которые задаются инженером для всей схемы (в явном виде или выделяются из описания схемы на уровне регистровых передач (register transfer layer, RTL)). Примеры причин, по которым возникают XCDCf и XODCf соответственно, были приведены в предыдущем разделе. Оставшиеся три множества - SDCf, CDCf и ODCf - называют внутренними или неявными
БС-значениями и вычисляют для каждого узла, исходя из структуры сети. Рассмотрим подробнее, по каким причинам возникает и как вычисляется каждое из этих множеств.
Л
XCDCf 4
> XODCf
SDCf ODCf
Рис. 2. Подмножества множества DC-значений для узла f логической сети
SDCf - Satesfability Don't Cares, определяют для узла f комбинации значений его входных и выходных переменных (аргументов и собственно значений функции), которые являются запрещенными (никогда не наблюдаются при корректной работе узла) в силу зависимости выходного значения от входного. Данное подмножество DC-значений не использует информации о структуре сети, но используется для
вычисления прочих DC-значений. Вычисляются SDCf = {(f, x) : fsDc (f, x)} следующим образом:
fsDC (f, X) = f( X) © f . (1)
CDCf - Controlobility Don't Cares, определяют для узла f комбинации значений его входных переменных, которые являются запрещенными (никогда не наблюдаются при корректной работе данного узла, а также узлов, от которых он зависит) в силу имеющихся зависимостей между ними. Вычисляются
CDCf = {x: fCDC(x)} на основе определенных выше SDCg:
(2)
(аргументов функции) f,
fCDC (x) = Vz É inPuts(f). V gsDC , geinputs*( f)
где inPuts( f ) - множество входных переменных узла inputs* (f) = inputs(f) u J inputs* (g) - транзитивное замыкание последних, а выражение вида
geinputs( f)
Vx. y (x, z) вычисляется как y\ л y|x = y(1, z) л y(0, z) .
ODCf - Observability Don't Cares, определяют для узла f комбинации значений его входных переменных (аргументов функции), которые делают выходное значение данного узла (функции) ненаблюдаемым всеми узлами, зависящими от него, т.е. при которых изменение выходного значения узла не повлечет изменения выходного значения какого-либо из узлов, зависящих от данного. Вычисляются ODCf ={x: fODC(x)} следующим образом:
Pf.
(3)
/аос О) = £ тртвС f). д
^еои1ри1Б*( f
где outputs( f) — множество конечных узлов, выходных дуг узла f, outputs*(f) = outputs(f) и ^ outputs*(g) - транзитивное замыкание последних, а дк/дf обозна-
gEOUtputs( f )
чает так называемую булеву производную функции к по переменной f .
Булева производная дк/дf является функцией от inputs*(k)\ f и возвращает единицу, если изменение значения f приводит к изменению к, и ноль - в противном случае. Если f входит в к в явном виде (f е inputs(k)), то дк/ дf вычисляется как булева разность: к\ 0 кк. Если же к зависит от f кос -
венно (через другие функции), то необходимо применять цепное правило (chaining rule):
dh
f dh dgi ©_© dh dg л
= ®
G cinputs(h)
dgi df
(
dl Gh
dgn df
\
©
( d2 h dgi dg2 dgldg2 df df dgidg3 df df
©
d2 h dgi dg3
©
©••• =
ndg ' gA
V geG
df
Адаптированная реляционная теория
В данном разделе описан используемый в работе частный случай реляционной теории, адаптированной к задачам САПР ИС, и семантика отношений и некоторых операторов реляционной алгебры в
контексте решаемой задачи. Будем называть отношением Я пару (И,Т), где И е 2Ь, Ь = {,Ь,с---} - подмножество литералов, называемое заголовком, и Т = {t е в'И} - множество кортежей размера Щ , заданных на расширенном булевом множестве В' = {0,1,*}, в которое включено специальное значение *, называемое телом. Отношение Я можно интерпретировать как некоторую булеву функцию (Я) = /: ВИ ^ В , заданную следующей ДНФ: х, если = 1
f (x) = VA
tGRxGk
если tx = 0 если tx =*
Над отношениями можно производить ряд операций; в данной работе используются проекция п Я, селекция а Я , переименование р Я , объединение А и В и две модификации естественного
Р ( h )
x=f (h)
соединения - А х В и А х В . Первые три операции взяты из реляционной алгебры без каких-либо
изменений; остальные операции имеют небольшие изменения, позволяющие естественным образом отобразить их на операции булевой алгебры над соответствующими функциями и, в то же время, сохранить все основные свойства операций.
В классической реляционной алгебре операция объединения разрешена только для отношений с одинаковыми заголовками и возвращает отношение с тем же заголовком и объединением тел, а операция естественного соединения объединяет кортежи двух отношений, если они строго равны по всем общим атрибутам [17-19]. В адаптированной реляционной алгебре разрешается объединять отношения с разными заголовками, при этом значения «недостающих» атрибутов картежей принимаются равными *, а операция естественного соединения игнорирует значения атрибутов, равные * :
А х В = С ^ Vt е ТА Vt' е ТВ (V* е Ис (^ ~ tX) ^ 3. е Тс (= 8е1ес^х,г'х))),
где х ~ у О (х = у) V (х = *) V (у = *), 8е1ес1;(х, *) = х и 8е1ес1;(*, у) = у .
Вторая модификация естественного соединения А хИ В , названная ограниченным естественным соединением, вводится аналогичным способом с заменой х ~ у на Ь \х ~ у, если(х г И') л (у г И') [ х = у, иначе
В таком случае перечисленные операции можно интерпретировать следующим образом (таблица).
Реляционная алгебра Булева алгебра
Объединение А и В Дизъюнкция А V ^ В
Естественное соединение А х В Конъюнкция А Л (В
Проекция п Я И\х Квантор существования зх ^Щ =
Селекция Ях = я а Я ; И\ х\х ~1 ) Я- = п ( а Я) х й\х\х~0 / Кофактор Шеннона • (Я)|-
Таблица. Интерпретация основных операций адаптированной реляционной алгебры
Определим понятие «функционального» заголовка отношения Я как /кЯ = {у е ИЯ : Яу х Яу = []}, где [] - пустое отношение (с пустым телом). Тогда можно также интерпретировать отношение Я относительно атрибута у е /ИЯ как частично определенную функцию (Я)у = Яу ^ Яу ^). Также легко показать, что будут верны следующие тождества:
R=<Ry ®y; (Rb = р_R ; (4)
ly
(F x G)g = Gg о (F)f, если f e fhF, g e fhG, f e hG, g г hF . (5)
Описание предлагаемого алгоритма поиска неявных DC-значений
Особенность предлагаемого алгоритма по сравнению с классическим заключается в том, что множество DCf вычисляется неявно. При классическом подходе для каждого узла f явным образом конструируется пара ((ON = f л fee, fee), являющаяся входом для следующего подэтапа в процессе оптимизации
сети. В предлагаемом алгоритме для каждого узла f вначале предполагается пара (fON = f, fOFF = f) (т.е. предполагается, что DCf пусто), а затем fON и fOFF уточняются, и на вход следующего подэтапа
передается пара ((ON = f л fDC, fOpF = f л fDC) (для алгоритмов из семейства Espresso в действительности необходимо передать любые две функции из тройки (fON, fOFF, fDC) [13-15]). Таким образом, DCf
не конструируется в явном виде, что во многом определяет более низкую вычислительную сложность.
Описание предлагаемого алгоритма в терминах адаптированной реляционной теории состоит из трех шагов: первый шаг является подготовительным, второй неявно рассчитывает CDCf для каждого
узла f , а третий - ODCf :
1. для каждого узла f = (R составить отношение R' = р R u р R ,
f=1 f=o
где R = ху р_[], R = R;
teTR xet x=x
2. рекурсивно, начиная с вершины «Primary Inputs» (от входов схемы к выходам) для всех смежных вершин произвести естественное соединение соответствующих отношений и спроецировать результат на конечную вершину;
3. рекурсивно, начиная с вершины «Primary Outputs» (от выходов схемы к входам) для всех смежных вершин произвести естественное соединение соответствующих отношений, ограниченное по помечающему дугу литералу, и спроецировать результат на начальную вершину.
Первый шаг в общем случае обладает высокой вычислительной сложностью, но он выполняется только на первой итерации процесса оптимизации логической сети. Кроме того, так как логическая сеть на первой итерации получена из RTL-описания схемы и обычно ее узлы помечены булевыми функциями из ограниченного набора, вычисления первого шага можно табулировать. Таким образом, первый этап не влияет на асимптотическую сложность всего алгоритма в целом, что является важным преимуществом предлагаемого алгоритма.
Доказательство корректности предлагаемого алгоритма
В силу ограничений на объем настоящей работы доказательства приведены в сжатом виде. Под корректностью предлагаемого алгоритма подразумевается то, что для заданной логической сети он рассчитывает в точности то же множество DCf, что и классический алгоритм (с той лишь разницей, что предлагаемый алгоритм рассчитывает DC f неявно, см. предыдущий раздел).
Докажем корректность расчета CDCf, т.е. докажем, что, согласно (2), для Г Г
F х
X G
V gemputs*(f)
верно fDc =Vz ginputs(f ). v gsDc • (6)
gemputs*( f ) f
Рассмотрим отрицание правой части тождества (6) и перепишем его в терминах реляционной алгебры (см. (1), (4) и таблицу):
Vz г inputs( f ). v gSDc = Vz г inputs( f )./ у
gEinputs*(f) \geinputs
U p-G
^gernputs*(f )g: g
Теперь рассмотрим
f
X ~Vg
v geinputs*( f ) g= g
p_ g\ = 3z : z г inputs(f)./ U =
gemputs*(f) g=g / \gemputs*(f)g:g /
W I f
X G
v geinputs*(f) y
( , /'off ) = ((F) Л fDC,(F) л fDC ) = ) 1 (( x DC) u y> ^ (( x DC)) = (f x D^ , где (DC) = f^ ,
т.е. выполняется тождество f ' = ( F x n
, что и требовалось доказать.
X о
V, gеinputs*( f) у
Докажем корректность расчета ОБС^ . Заметим, что если f е к, то в результирующее отношение входят только те картежи из отношения Е, для которых атрибут f в отношении О имеет значение, отличное от *, т.е. дg/дf = 1.
Аналогично, если f е fкF и g е _/кО, то
h (( x{f!G xig!H) = j^Bz : z гinputs(f).f
dg dh dg dh
ON' Bz : z g inputs(f). fOFF
df dg df dg
Учитывая (5), получим, что F Xх{= F X^}О, где
gl Vg2, если g = {}
gl ° g2, если g ^ ^^ g = (ko1 ^ кo2);
g2 ° gl, если g С
G g = (G1 X G) g =
тогда
V
,df
= F xif!|G1 xia!(Hu xM...) x...j x^G2 xig2Î(H21 x^
geoutputs*( f )
Преобразуем (3) следующим образом:
X
{g2
fODC =Vz g inputs(f ) ■ Л | f I =
geoutputs*( f )
dg
/ -
= Bz : z г inputs(f ). л
gGOutputs*( f )
■df | = Bz : z г inputs( f )
V
gE Outputs *( f )
df
тогда для /", вычисляемого согласно третьему шагу предлагаемого алгоритма, {/on ' fOFF) = {n • /'oDC' /'off ' /'odc ), что доказывает корректность расчета ODC/ .
Сравнение вычислительной сложности предложенного и классического алгоритмов
Произведем оценку асимптотической вычислительной сложности в худшем случае для классического и предложенного алгоритмов. Пусть логическая сеть - граф G = {V,E) - имеет |V| = m вершин, а
каждая вершина vi, i е 0, m -1 имеет |inputs(vi )| = ni входных дуг (равно аргументов соответствующей
булевой функции, равно мощность заголовка соответствующего отношения) и ti, ti < 2n -1 термов ДНФ, задающей булеву функцию (равно количество кортежей в соответствующем отношении). Будем обозначать n = max ni.
i
Рассмотрим классический алгоритм. В сложности /SDCi (ni) расчета SDCVi (см. (1)) доминирует сложность расчета отрицания vi: /SDC ^ е O {ni'i) с O {nt), причем результирующая ДНФ будет иметь
П +1 аргументов и до 2 • ^ термов. Сложность расчета СБСУ (см. (2)) в худшем случае складывается из сложности расчета SDCV для т вершин и сложности квантора всеобщности по (т — 1)- п — 1е О (т • п)
переменным (что в худшем случае сводится к конъюнкции 2тп—2 ДНФ по два терма):
(/ 2п \\ / 2т—п \
т-Iп )) + 012 ). Наихудший случай для расчета ODCv достигается при такой конфигурации графа, что п = ' и максимальная длина пути в графе - т. Тогда сложность задается рекуррент-
X-"' к I 2'2+1+1 I
ным соотношением /0ГС (') = g(') + ^ /опс (' — к) • Сг- , g е ОI I I. Точно решить данное соотношение не представляется возможным, однако с уверенностью можно сказать, что сложность расчета
I 2т2+1 +1
0DCv и всего классического алгоритма не лучше чем ОI т! • т
Анализ сложности предложенного алгоритма значительно проще, причем асимптотическая сложность расчета CDCv и ODCV совпадают. Достаточно заметить, что в худшем случае необходимо произвести естественное соединение отношений для всех пар (vi, Vj) вершин графа, причем сложность естественного соединения в худшем случае будет составлять O (ti • tj). Таким образом, асимптотическая сложность предложенного алгоритма в худшем случае составляет
O (j • t]) O ((• 2" • 2" ) = O (m2 • 22" ) O (m2 • 2m ) .
Заключение
Описан подход к адаптации реляционной теории к решению задач систем автоматизированного проектирования интегральных схем. На основе предложенного подхода разработан алгоритм оптимального поиска неявных Don't Care значений. Доказана корректность предложенного алгоритма.
Применение предложенного алгоритма в системах автоматизированного проектирования потенциально позволит ускорить процесс разработки интегральных схем, а также сократить занимаемую площадь кристалла, энергопотребление, повысить верифицируемость и надежность получаемых схем.
В перспективе создание распределенной версии исследуемых алгоритмов позволит решать задачи систем автоматизированного проектирования для более сложных схем, требующих высокой вычислительной мощности.
Литература
1. De Micheli G. Synchronous logic synthesis: algorithms for cycle-time minimization // IEEE Transactions on Computer-Aided Design of Integrated Circuits and Systems. 1991. V. 10. N 1. P. 63-73.
2. Hachtel G.D., Rho J.K., Somenzi F., Jacoby R. Exact and heuristic algorithms for the minimization of incompletely specified state machines // Proc. of European Conference on Design Automation. Amsterdam, Netherlands, 1992. P. 184-191.
3. Bogatyrev V.A., Bogatyrev S.V., Golubev I.Yu. Optimization and the process of task distribution between computer system clusters // Automatic Control and Computer Sciences. 2012. V. 46. N 3. P. 103-111.
4. Sentovich E.M., Singh K.J., Lavagno L., Moon C., Murgai R., Saldanha A., Savoj H., Stephan P.R., Brayton R.K., Sangiovanni-Vincentelli A.L. SIS: A System for Sequential Circuit Synthesis. Technical Report UCB/ERL M92/41, Electronics Research Lab, Univ. of California, Berkeley, 1992.
5. Pederson D.O. The VIS Group. VIS: Verification Interacting with Synthesis, 1995 [Электронный ресурс]. Режим доступа: http://embedded.eecs.berkeley.edu/Respep/Research/vis, свободный. Яз. англ. (дата обращения 04.12.2013).
6. Bartlett K.A., Brayton R.K., Hachtel G.D., Jacoby R.M., Morrison C.R., Rudell R.L., Sangiovanni-Vincentelli A., Wang A. Multi-level logic minimization using implicit don't cares // IEEE Transactions on Computer-Aided Design of Integrated Circuits and Systems. 1988. V. 7. N 6. P. 723-740.
7. Fujiwara H. Logic Testing and Design for Testability. Cambridge: MIT Press, 1985. 304 p.
8. Chang A.C.L., Reed I.S., Beans A.V. Path sensitization, partial boolean difference and automated fault diagnosis // IEEE Transactions on Computers. 1972. V. C-21. N 2. P. 189-195.
9. Bogatyrev V.A. Exchange of duplicated computing complexes in fault-tolerant systems // Automatic Control and Computer Sciences. 2011. V. 45. N 5. P. 268-276.
10. Bogatyrev V.A. Fault tolerance of clusters configurations with direct connection of storage devices // Automatic Control and Computer Sciences. 2011. V. 45. N 6. P. 330-337.
11. Богатырев В. А., Богатырев С.В. Критерии оптимальности многоуровневых отказоустойчивых компьютерных систем // Научно-технический вестник СПбГУ ИТМО. 2009. № 5 (63). С. 92-97.
12. Богатырев В.А., Богатырев А.В. Функциональная надежность систем реального времени // Научно-технический вестник информационных технологий, механики и оптики. 2013. № 4 (86). С. 150-151.
13. Muroga S., Kambayashi Y., Lai H.C., Culliney J.N. Transduction method - design of logic networks based on permissible functions // IEEE Transactions of Computers. 1989. V. 38. N 10. P. 1404-1424.
14. Lin B., Touati H.J., Newton A.R. Don't care minimization of multi-level sequential logic networks // Proc. IEEE International Conference on Computer-Aided Design. 1990. P. 414-417.
15. Brayton R.K., Hachtel G., McMullen C., Sangiovanni-Vincentelli A. Logic Minimization Algorithms for VLSI Synthesis. Kluwer Academic Publishers, 1985. 206 p.
16. Theobald M., Nowick S.M., Wu T. Espresso-HF: a heuristic hazard-free minimizer for two-level logic // Proceedings - Design Automation Conference. Las Vegas, USA, 1996. P. 71-76.
17. Codd E.F. A relational model of data for large shared data banks // M.D. Computing. 1998. V. 15. N 3. P. 162-166.
18. Abiteboul S., Hull R., Vianu V. Foundations of Databases. Addison-Wesley, 1995. 685 p.
19. Date C.J., Darwen H. Foundation for Future Database Systems: The Third Manifesto. 2nd ed. Addison-Wesley, 2000. 608 p.
Демидов Даниил Валентинович
Daniil V Demidov
Принято к печати 02.07.14 Accepted 02.07.14
- аспирант, Университет ИТМО, 197101, Санкт-Петербург, Россия; инженер, ЗАО «Интел А/О», 196247, Санкт-Петербург, Россия, [email protected]
- postgraduate, ITMO University, 197101, Saint Petersburg, Russia; software engineer, "Intel A/O", Ltd., 196247, Saint Petersburg, Russia, [email protected]