# ИНФОРМАТИКА

# июль-сентябрь

# СТАТЬИ ПО МАТЕРИАЛАМ СЕДЬМОЙ МЕЖДУНАРОДНОЙ НАУЧНОЙ КОНФЕРЕНЦИИ «ТАНАЕВСКИЕ ЧТЕНИЯ»

# УДК 004.43

# П.Н. Бибило

# СХЕМНАЯ РЕАЛИЗАЦИЯ VHDL-ОПИСАНИЙ СИСТЕМ НЕ ПОЛНОСТЬЮ ОПРЕДЕЛЕННЫХ БУЛЕВЫХ ФУНКЦИЙ

Предлагаются синтезируемые VHDL-модели систем не полностью определенных булевых функций. Приводятся результаты экспериментов по различным способам схемной реализации VHDL-описаний таких систем функций комбинационными схемами в библиотеке проектирования заказных СБИС и FPGA.

### Введение

Современные синтезаторы осуществляют высокоуровневый синтез логических схем заменой описания каждой VHDL-конструкции функциональным описанием соответствующей логической подсхемы. После этапа высокоуровневого синтеза выполняются этапы оптимизации и отображения в заданный технологический базис логических элементов [1]. Результаты синтеза в значительной мере зависят от вида исходного VHDL-описания, подаваемого на вход синтезатора. В результате синтеза по исходным VHDL-описаниям частичных булевых функций получаются комбинационные схемы, моделями поведения которых являются системы полностью определенных функций. Известно, что использование при синтезе логических схем неопределенных булевых функций может приводить к более экономичным схемам [2].

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

## 1. Частичные булевы функции и их VHDL-описания

На практике достаточно часто приходится проектировать функциональные блоки комбинационной логики, характеризующиеся неопределенностью поведения для некоторых (многих) наборов значений входных сигналов. К таким блокам относятся кодовые преобразователи, комбинационные части конечных автоматов, цепочки последовательных арифметических VHDL-операторов с операндами, которым присущи неполные диапазоны значений и т. д. Математическими моделями этих блоков являются системы частичных булевых функций. Области неопределенности таких функций могут занимать почти всю область их определения, тогда говорят о слабоопределенной булевой функции или системе функций. Эффективность использования VHDL-моделей частичных функций была изучена в работе [3], где описана методика выделения последовательных VHDL-конструкций и замены таких конструкций эквивалентными по поведению матричными представлениями систем частичных булевых функций, при этом функции задавались на наборах значений аргументов.

В данной работе предлагается VHDL-модель для системы частичных функций, заданных в интервальной матричной форме.

Под векторной булевой функцией f(x) будем понимать упорядоченную систему частичных булевых функций  $f(x) = (f^1(x), ..., f^m(x))$ , значениями векторных функций на элементах  $x^*$  булева пространства аргументов вектора  $x = (x_1, ..., x_n)$  являются *m*-компонентные тро-

2016

ичные векторы  $f(x^*)$ . Пример интервального матричного задания частичной векторной функции  $f(x) = (f^{1}(x), f^{2}(x))$  представлен в табл. 1. Частичная булева функция  $f^{1}(x)$  может быть задана парой дизъюнктивных нормальных форм (ДНФ): множество  $M_{\ell^1}^1$  задается в виде  $D_{\ell^1}^1 =$  $\overline{x}_1 x_3 x_4 \lor x_1 \overline{x}_3 \overline{x}_4 \lor \overline{x}_1 \overline{x}_2 \overline{x}_3 \overline{x}_4$ ; множество  $M_{f^1}^0$  – в виде  $D_{f^1}^0 = x_1 x_2 x_3 x_4 \lor x_2 x_3 \overline{x}_4$ . Аналогично в виде пары ДНФ может быть задана частичная булева функция  $f^{2}(\mathbf{x})$ . Интервальная матричная форма системы частичных функций состоит из троичной матрицы *T<sup>x</sup>* задания элементарных конъюнкций и троичной матрицы T<sup>f</sup> вхождений конъюнкций в ДНФ, представляющих области нулевых и единичных значений функций  $f^{j}$  компонент векторной функции f(x). Неопределенное значение «--» элемента  $t_{ij}$  матрицы  $T^x$  не означает, что функция  $f^j$  имеет неопределенное значение на наборах, которые порождает троичный вектор строки i матрицы  $T^x$ . Например, на пересечении первой строки и первого столбца матрицы Т<sup>f</sup> находится неопределенное значение «--», однако это не означает, что на наборах 0001, 0011, 0101, 0111 функция  $f^1$ не определена. Рассмотрев вторые строки матриц  $T^x$ ,  $T^f$ , можно убедиться, что на наборах 0011, 0111 функция  $f^1$  принимает единичное значение. Если же все строки матрицы  $T^x$ являются попарно ортогональными, то в строках матрицы  $T^x$  задаются значения 0,1, «-» компонентных частичных функций  $f^{j}$  векторной функции f(x).

Таблица 1

Интервальная форма системы частичных булевых функций

|   |            | $T^{f}$ |       |  |   |   |  |
|---|------------|---------|-------|--|---|---|--|
|   | $x_1  x_2$ | $f^1$   | $f^2$ |  |   |   |  |
| 0 | - 1        | -       | 1     |  | - | 1 |  |
| 0 | -          | 1       | 1     |  | 1 | - |  |
| 1 | _          | 0       | 0     |  | 1 | - |  |
| _ | · _        | 1       | 0     |  | - | 0 |  |
| 0 | 0          | 0       | 0     |  | 1 | 0 |  |
| 1 | . 1        | 1       | 1     |  | 0 | 1 |  |
| _ | • 1        | 1       | 0     |  | 0 | - |  |

Частичная функция  $f^{1}(\mathbf{x})$  реализуется частичной функцией  $f^{2}(\mathbf{x})$  (обозначается  $f^{1}(\mathbf{x}) \prec f^{2}(\mathbf{x})$ ), если и только если  $D_{f^{1}}^{1} \rightarrow D_{f^{2}}^{1}$ ,  $D_{f^{1}}^{0} \rightarrow D_{f^{2}}^{0}$ , где через  $\rightarrow$  обозначена операция логической импликации. Для полностью определенных булевых функций отношение реализации является отношением равенства. Отношение реализации векторных функций сводится к выполнению отношения реализации между компонентными функциями: если каждая компонентная функция  $f^{j^{*}}(\mathbf{x})$ , j = 1, ..., m, векторной функции  $f^{*}(\mathbf{x}) = (f^{l^{*}}(\mathbf{x}), ..., f^{m^{*}}(\mathbf{x}))$  реализует  $(f^{j} \prec f^{j^{*}})$  соответствующую компонентную функцию  $f^{j}$  векторной функции  $f = (f^{1}, ..., f^{m})$ , то тогда векторная функция  $f^{*}$  реализует векторную функцию f. В этом случае векторная функция  $f^{*}$  называется *доопределением* векторной функции f. Подробное описание различных форм представлений систем полностью определенных и частичных булевых функций дано в работе [3].

В языке VHDL при синтезе логических схем используется девятизначный алфавит на базе перечислимого типа *std\_logic*. Массив (вектор) значений типа *std\_logic* обозначается как *std\_logic\_vector* [1]. На базе типов *std\_logic, std\_logic\_vector* предлагается строить VHDL-модели частичных функций. Дело в том, что одно из девяти значений данного типа называется *don't care* (неопределенное значение), обозначается как «-» и предназначается для оптимизации при логическом синтезе. Однако в литературе не показано, каким именно образом значение

*don't care* используется при составлении VHDL-описаний частичных функций и как использование неопределенности влияет на результаты синтеза по VHDL-описаниям частичных булевых функций.

Предлагаемое VHDL-описание интервальной формы системы частичных функций состоит из двух частей. В первой части с помощью логических операторов записываются ДНФ  $D_{f^i}^1$ ,

 $D_{f^i}^0$ , вторая часть – это вызов VHDL-функции value\_f, формирующей значения функций систе-

мы. Описание функции value\_f приводится в VHDL-пакете chast\_pack. В листинге 1 задан пример VHDL-модели системы функций из табл. 1. Если при моделировании системы частичных функций хотя бы в одном векторе F значений выходных сигналов будет содержаться символ 'X', то это означает, что на соответствующем наборе значений входных сигналов система функций задана противоречиво.

*Листинг 1*. VHDL-описание системы частичных функций (табл. 1), заданных в интервальной матричной форме

LIBRARY ieee; USE ieee.std logic 1164.all; package chast pack is constant N : natural := 4; constant M : natural := 2; Function **value f** (constant M : natural; f nul : std logic vector; f ed :std logic vector ) return std logic vector ; end chast\_pack; package body chast pack is Function value f (constant M : natural; f nul : std logic vector; f ed : std logic vector ) return std logic vector is variable z : std logic vector (1 to M); variable e : std logic vector (1 to 2); begin for i in f nul'range loop e := (f nul(i), f ed(i)); case e is when "10" => z(i):='0'; when "01" => z(i):='1'; when "00" => z(i):='-'; when others => z(i):='X'; -- error end case; end loop; return z ; end value f ; end; LIBRARY ieee; USE ieee.std logic 1164.all; use work.chast pack.all; ENTITY **EXAMPLE1** IS PORT (x1, x2, x3, x4 : IN std logic; F : OUT std logic vector (1 to M)); end; ARCHITECTURE BEH OF EXAMPLE1 IS signal f\_0 : std\_logic\_vector (1 to M); signal f\_1 : std\_logic\_vector (1 to M);

Если же функции системы заданы на наборах значений аргументов (табл. 2), то VHDL-модель становится менее компактной (листинг 2).

#### Таблица 2

Задание системы частичных булевых функций на наборах значений аргументов

|                       |                       |                       |                       | 1 2       |
|-----------------------|-----------------------|-----------------------|-----------------------|-----------|
|                       | <b>B</b> <sup>2</sup> | r                     | $T^{f}$               |           |
| <i>x</i> <sub>1</sub> | $x_2$                 | <i>x</i> <sub>3</sub> | <i>x</i> <sub>4</sub> | $f^1 f^2$ |
| 0                     | 0                     | 0                     | 0                     | 1 0       |
| 0                     | 0                     | 0                     | 1                     | - 1       |
| 0                     | 0                     | 1                     | 0                     | - 0       |
| 0                     | 0                     | 1                     | 1                     | 1 1       |
| 0                     | 1                     | 0                     | 1                     | - 1       |
| 0                     | 1                     | 1                     | 0                     | 0 0       |
| 0                     | 1                     | 1                     | 1                     | 1 1       |
| 1                     | 0                     | 0                     | 0                     | 1 -       |
| 1                     | 0                     | 1                     | 0                     | - 0       |
| 1                     | 1                     | 0                     | 0                     | 1 -       |
| 1                     | 1                     | 1                     | 0                     | 0 0       |
| 1                     | 1                     | 1                     | 1                     | 0 1       |

Предполагается, что на остальных четырех наборах 0100, 1001, 1011, 1101 булева пространства, не приведенных в табл. 2, значения частичных функций  $f^1$ ,  $f^2$  не определены.

Листинг 2. VHDL-описание системы частичных функций, заданных на наборах (табл. 2)

```
Library ieee;
use ieee.std_logic_1164.all;
ENTITY EXAMPLE2 IS
PORT (x : IN std_logic_vector(1 to 4);
F : OUT std_logic_vector (1 to 2));
end;
ARCHITECTURE BEH OF EXAMPLE2 IS
begin
F <= "10" when x = "0000" else
"-1" when x = "0001" else
"11" when x = "0010" else
"11" when x = "0011" else
"00" when x = "0101" else
"11" when x = "0111" else
```

"1-" when x = "1000" else "-0" when x = "1010" else "1-" when x = "1100" else "00" when x = "1110" else "01" when x = "1111" else "--";

end;

Предлагаемые VHDL-модели систем частичных функций являются синтезируемыми (по ним синтезатор может построить комбинационные схемы) и позволяют проводить проверку отношения реализации частичных функций полностью определенными функциями (либо логическими схемами, реализующими полностью определенные булевы функции) путем формальной верификации, например, используя систему верификации *FormalPro* [4].

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

Основными направлениями оптимизации представлений систем частичных булевых функций являются минимизация в классе ДНФ, т. е. оптимизация двухуровневых представлений, оптимизация многоуровневых представлений на основе разложения Шеннона (BDD(Binary Decision Diagram)-оптимизация) [5, 6] и декомпозиция [7, 8]. Теоретические методы по указанным направлениям оптимизации различных форм представлений систем частичных функций достаточно хорошо изучены [2, 3]. Влияние способов логической оптимизации на результаты логического синтеза в библиотеке проектирования отечественных заказных СБИС экспериментально исследовано в работах [3, 9] для систем полностью определенных функций. Эксперименты над программами логической оптимизации на потоке практических примеров показали, что для различных комбинационных схем целесообразно использовать различные оптимизационные процедуры (минимизацию в классе ДНФ, BDD-оптимизацию, декомпозицию) [9]. Однако BDD-оптимизация наиболее часто приводила к схемам, требующим меньшую площадь кристалла заказной СБИС, даже если сравниваться с результатами использования эффективной программы ESPRESSO [10] совместной минимизации систем полностью определенных функций в классе ДНФ.

ВDD-оптимизация булевых функций основана на разложении Шеннона. *Разложением* Шеннона булевой функции  $f(\mathbf{x}) = f(x_1, ..., x_n)$  по переменной  $x_i$  называется представление  $f(\mathbf{x})$  в виде

$$f(\boldsymbol{x}) = x_i f_0 \vee x_i f_1. \tag{1}$$

Если исходная функция  $f(\mathbf{x})$  является частичной, то и коэффициенты  $f_0$ ,  $f_1$  разложения являются частичными функциями. Каждый из коэффициентов  $f_0 = f(x_1, ..., x_{i-1}, 0, x_{i+1}, ..., x_n)$ ,  $f_1 = f(x_1, ..., x_{i-1}, 1, x_{i+1}, ..., x_n)$  может быть разложен по одной из переменных из множества  $\{x_1, ..., x_{i-1}, x_{i+1}, ..., x_n\}$ . Процесс разложения коэффициентов заканчивается, когда все n переменных будут использованы для разложения. В процессе разложения либо на последнем шаге разложения коэффициенты вырождаются до констант 0, 1, «-». На каждом шаге разложения выполняется сравнение на равенство полученных коэффициентов и из множества равных коэффициентов остается один. Под диаграммой двоичного выбора (BDD) понимается ориентированный ациклический граф, задающий последовательные разложения Шеннона булевой функции  $f(x_1, ..., x_n)$  по всем ее переменным  $x_1, ..., x_n$  при заданном порядке (перестановке) переменных, по которым проводятся разложения. Функциональная вершина, соответствующая функции f, называется корнем. Под *сложностью (размером) BDD* будем понимать число функциональных вершин BDD.

Далее для векторной булевой функции f(x) будут рассматриваться BDD, которые построены по общей для всех компонентных функций  $f^{i}(x)$  перестановке переменных. В результате BDD-оптимизации [3] матричная форма системы частичных функций заменяется графом BDD, представляющим систему полностью определенных булевых функций. Такая BDD имеет *m* корневых и две листовые вершины 0, 1, которые обычно дублируются для упрощения изображения графа. BDD, реализующая систему частичных функций (см. табл. 1), изображена на рис. 1. VHDL-описание BDD дано в листинге 3. Каждая функциональная вершина BDD, за исключением вершин-переменных либо их инверсий, задается соответствующей формулой разложения Шеннона.

Листинг 3. VHDL-описание BDD (рис. 1)

```
LIBRARY ieee;
USE ieee.std_logic_1164.all;
ENTITY EXAMPLE3 IS
PORT (x1,x2,x3,x4,x5 : IN std_logic;
F : OUT std_logic_vector (1 to 2));
end;
ARCHITECTURE BDD OF EXAMPLE3 IS
signal p1: std_logic;
BEGIN
p1 <= not x1 and x4;
F(1) <= (not x3) or (x3 and p1);
F(2) <= (not x3 and p1) or x3 and x4;
end;
```



Рис. 1. BDD, реализующая систему частичных булевых функций

### 3. Экспериментальные исследования

В этом разделе приводятся результаты экспериментов по схемной реализации систем частичных булевых функций на заказных СБИС (ASIC) и на программируемых логических интегральных схемах типа FPGA. В качестве программы совместной минимизации векторных частичных функций в классе ДНФ использовалась программа [11], позволяющая минимизировать общее число элементарных конъюнкций, на которых задана минимизированная векторная полностью определенная функция, реализующая исходную частичную векторную функцию.

Эксперимент 1. Синтез схем кодовых преобразователей в библиотеке проектирования заказной СБИС

Синтез осуществлялся по двум видам исходных описаний: матричным формам систем частичных функций и BDD-представлениям полностью определенных функций, построенным в результате оптимизации исходных матричных форм систем функций в классе многоуровневых представлений. Исходные системы частичных функций, заданные на наборах значений аргументов, и BDD представлялись на языке VHDL. Исходные VHDL-описания матричных форм систем частичных функций поступали на вход синтезатора LeonardoSpectrum [1], который по этим описаниям строил схемы в библиотеке проектирования заказной СБИС.

Влияние различных режимов синтеза на сложность получаемых логических схем и их быстродействие подробно исследовано для синтезатора LeonardoSpectrum в работе [12]. При экспериментах в данной работе синтез (optimize) всех схем в LeonardoSpectrum осуществлялся с устранением иерархии (hierarchy flatten) в исходном описании. Режим синтеза (optimize effort) выполнялся по опции (effort standard), при установке которой синтезатор осуществляет несколько итераций оптимизации и технологического отображения на основе различных методов [12]. Для увеличения быстродействия синтезированной схемы выполнялась ее перестройка согласно установленной опции (optimize timing).

Состав библиотеки логических элементов приведен в [3]. Полученные схемы сравнивались со схемами, построенными по VHDL-описаниям полностью определенных систем функций, полученных с помощью программы оптимизации BDD для систем частичных функций.

Результаты эксперимента 1 для практических примеров Verg1 и Verg2 систем частичных функций (таблиц для хранения микропрограмм команд микропроцессоров) представлены в табл. 3. Каждая система частичных функций была задана на наборах значений аргументов двумя булевыми матрицами  $B^x$ ,  $B^f$ , т. е. троичная матрица  $T^f$  выродилась до булевой матрицы  $B^f$ . Первая булева матрица  $B^x$  имела размерность  $n \times k$  (*n* столбцов, *k* строк), вторая матрица  $B^f$  значений функций имела размерность  $m \times k$ . В табл. 3 используются следующие обозначения: n – число аргументов; m – число функций; k – число двоичных наборов в задании системы функций; L – число элементов схемы;  $S_{ASIC}$  – суммарная площадь всех элементов схемы, нс.

Затем пара булевых матриц была интерпретирована как система совершенных ДНФ (СДНФ) полностью определенных булевых функций, заданных в матричной форме, и проведен синтез по оптимизированной BDD. Заметим, что синтезатор LeonardoSpectrum не смог построить логическую схему по исходному VHDL-описанию, интерпретируемому как система полностью определенных функций, поэтому в табл. 3 отсутствуют данные по результатам синтеза по таким описаниям. При поиске лучшей перестановки последовательности переменных, по которым строится BDD, для примера Verg1 эвристический алгоритм испытал 500 перестановок, для более сложного примера Verg2 – 100 перестановок аргументов.

Результаты эксперимента 1 показывают, что использование BDD позволяет уменьшить площадь схемы в несколько раз по сравнению со схемной реализацией исходного неоптимизированного VHDL-описания системы частичных функций. Кроме того, использование частичной определенности функций, даже без BDD-оптимизации, позволяет в полтора-два раза уменьшить площадь схем.

Результаты эксперимента 1

Таблица 3

| r esymetation skelleprimetria i |       |   |     |                                                      |                    |                    |              |                                               |      |       |  |
|---------------------------------|-------|---|-----|------------------------------------------------------|--------------------|--------------------|--------------|-----------------------------------------------|------|-------|--|
| Пример                          | n m k |   | k   | Интерпретация<br>пары                                | Схемна матрич      | я реали<br>чной фо | зация<br>рмы | Схемная реализация<br>минимизированных<br>BDD |      |       |  |
|                                 |       |   |     | булевых матриц                                       | S <sub>ASIC</sub>  | L                  | τ            | S <sub>ASIC</sub>                             | L    | τ     |  |
|                                 |       |   |     | Система частичных<br>булевых функций                 | 8940               | 2183               | 17,79        | 3741                                          | 991  | 12,15 |  |
| Verg1                           | 17    | 1 | 003 | Система полностью<br>определенных<br>булевых функций | Синтез не выполнен |                    | олнен        | 5562                                          | 1488 | 17,38 |  |
|                                 |       |   |     | Система частичных<br>булевых функций                 | 8884               | 2272               | 20,29        | 5809                                          | 1508 | 12,59 |  |
| Verg2                           | 18    | 3 | 129 | Система полностью<br>определенных<br>булевых функций | Синтез не выполнен |                    |              | 7670                                          | 1924 | 20,39 |  |

Эксперимент 2. Схемная реализация систем псевдослучайных частичных булевых функций в библиотеке проектирования заказной СБИС

Генерируемые случайным образом частичные векторные функции представлялись в матричной форме, пример которой дан в табл. 1. При генерации варьировались значения:  $\alpha$  – число определенных (0,1) значений в строке матрицы  $T^x$ ;  $\beta$  – число определенных значений в строке матрицы  $T^f$ . Матричные представления конвертировались в VHDL-описания, после чего синтезировались логические схемы. Затем исходные матричные представления минимизировались в классах ДНФ и BDD, преобразовывались в VHDL-описания, по которым синтезировались комбинационные схемы. Результаты эксперимента 2 приведены в табл. 4. Анализ результатов показывает, что для систем псевдослучайных частичных функций предварительная совместная минимизация в классе ДНФ чаще приводит к схемам меньшей площади. Величина площади уменьшается при уменьшении чисел определенных элементов в матрицах  $T^x$  и  $T^f$ . При небольшом ( $\alpha = 4$ ) числе определенных элементов в процессе BDD-оптимизации частичные функции системы вырождаются (доопределяются) до констант 0,1.

Эксперимент 3. Схемная реализация систем псевдослучайных частичных функций на FPGA

Эксперимент 3 отличается от эксперимента 2 только тем, что в качестве технологического базиса была выбрана программируемая логическая схема (ПЛИС) типа FPGA Spartan 3-1000, в качестве примеров систем функций были взяты те же примеры Gen1 – Gen8, что и в эксперименте 2. Синтез осуществлялся с помощью синтезатора XST, входящего в состав ISE (САПР фирмы XILINX) при опциях, установленных по умолчанию. Результаты эксперимента 3 представлены в табл. 5, где в столбцах LUT приводится число программируемых элементов FPGA, требуемых для реализации комбинационной схемы, через  $\tau$  обозначена задержка схемы, нс;  $k_{min}$  – число конъюнкций в минимизированной системе ДНФ.

Таблица 4

| При-<br>мер | α  | β | Схемная реализация<br>исходных частичных<br>функций |                   |       | Схемная реализация<br>минимизированных<br>ДНФ (полностью опре-<br>деленных функций) |                      |               | Схемная реализация<br>минимизированных BDD<br>(полностью определенных функций) |                     |                    |      |               |
|-------------|----|---|-----------------------------------------------------|-------------------|-------|-------------------------------------------------------------------------------------|----------------------|---------------|--------------------------------------------------------------------------------|---------------------|--------------------|------|---------------|
| _           |    |   |                                                     | S <sub>ASIC</sub> | L     | τ                                                                                   | S <sub>ASIC</sub>    | L             | τ                                                                              | S <sub>ASIC</sub>   | L                  | τ    | Размер<br>BDD |
| Gen1        | 16 | 4 | 483875                                              | 1351              | 8,76  | 246815                                                                              | 662                  | 6,36          | 605737                                                                         | 1609                | 9,48               | 1486 |               |
| Gen2        | 12 | 4 | 474908                                              | 1320              | 8,63  | 167880                                                                              | 448                  | 5,70          | 336837                                                                         | 874                 | 7,56               | 983  |               |
| Gen3        | 8  | 4 | 343304                                              | 917               | 10,74 | 11260                                                                               | 33                   | 3,39          | 14620                                                                          | 43                  | 3,33               | 75   |               |
| Gen4        | 4  | 4 | 454268                                              | 1164              | 11,36 | Доог<br>функци                                                                      | іределеі<br>й до кої | ние<br>нстант | До                                                                             | определен<br>до кон | ние функ<br>нстант | ций  |               |
| Gen5        | 16 | 8 | 527271                                              | 1495              | 12,23 | 373257                                                                              | 104<br>1             | 9,23          | 822492                                                                         | 2072                | 10,57              | 2161 |               |
| Gen6        | 12 | 8 | 464479                                              | 1299              | 11,65 | 256334                                                                              | 687                  | 8,17          | 274542                                                                         | 716                 | 8,75               | 911  |               |
| Gen7        |    |   | 387793                                              | 1057              | 11,64 | 1836                                                                                | 7                    | 2,22          | 1735                                                                           | 7                   | 2,08               | 8    |               |
| Gen8        |    |   | 258583                                              | 687               | 0,69  | Доопределение<br>функций до констант                                                |                      |               | До                                                                             | определе<br>до кој  | ние функ<br>нстант | ций  |               |

# Результаты эксперимента 2 (n = 16, m = 16, $k_{mp} = 256$ )

#### Таблица 5

|        | гезультаты эксперимента 5 $(n - 10, m - 10, k_{mp} - 250)$ |   |                            |                                                                                                                                       |     |                                      |                  |                                                                                  |                        |               |  |  |  |
|--------|------------------------------------------------------------|---|----------------------------|---------------------------------------------------------------------------------------------------------------------------------------|-----|--------------------------------------|------------------|----------------------------------------------------------------------------------|------------------------|---------------|--|--|--|
| Пример | α                                                          | β | Схемная<br>исходных<br>фун | Схемная реализация<br>исходных частичных<br>функций Схемная реализация<br>минимизированных ДНФ<br>(полностью определенных<br>функций) |     |                                      |                  | Схемная реализация<br>минимизированных BDD (пол-<br>ностью определенных функций) |                        |               |  |  |  |
|        |                                                            |   | LUT                        | τ                                                                                                                                     | LUT | τ                                    | k <sub>min</sub> | LUT                                                                              | τ                      | Размер<br>BDD |  |  |  |
| Gen1   | 16                                                         | 4 | 891                        | 3,67                                                                                                                                  | 406 | 3,73                                 | 212              | 926                                                                              | 4,88                   | 1486          |  |  |  |
| Gen2   | 12                                                         | 4 | 846                        | 3,66                                                                                                                                  | 279 | 3,78                                 | 166              | 575                                                                              | 4,33                   | 983           |  |  |  |
| Gen3   | 8                                                          | 4 | 663                        | 3,77                                                                                                                                  | 24  | 2,30                                 | 27               | 26                                                                               | 2,56                   | 75            |  |  |  |
| Gen4   | 4                                                          | 4 | 98                         | 3,43                                                                                                                                  | Доо | Доопределение функций<br>до констант |                  |                                                                                  | ределение<br>до конста | функций<br>нт |  |  |  |
| Gen5   | 16                                                         | 8 | 1047                       | 3,85                                                                                                                                  | 569 | 3,79                                 | 244              | 1440                                                                             | 4,49                   | 2161          |  |  |  |

**D**ODULI TOTU DIVOLUTO 2(n-16, m-16, k-256)

| Пример | α  | β | Схемная реализация<br>исходных<br>частичных функций |                              | С:<br>мині<br>(полн               | хемная реал<br>имизирован<br>ностью опр<br>функци | пизация<br>іных ДНФ<br>еделенных<br>й) | Схемная реализация<br>минимизированных BDD (пол-<br>ностью определенных функций) |      |     |  |
|--------|----|---|-----------------------------------------------------|------------------------------|-----------------------------------|---------------------------------------------------|----------------------------------------|----------------------------------------------------------------------------------|------|-----|--|
|        |    |   | LUT                                                 | τ                            | LUT                               | τ                                                 | k <sub>min</sub>                       | LUT                                                                              | LUT  | τ   |  |
| Gen6   | 12 | 8 | 956                                                 | 3,89                         | 418                               | 3,86                                              | 227                                    | 489                                                                              | 4,25 | 911 |  |
| Gen7   | 8  | 8 | 662                                                 | 4,00                         | 3                                 | 1,00                                              | 10                                     | 3                                                                                | 1,00 | 8   |  |
| Gen8   | 4  | 8 | Доопро<br>фун<br>до ко                              | еделение<br>нкций<br>ристант | Доопределение функций до констант |                                                   | е функций<br>ант                       | Доопределение функций<br>до констант                                             |      |     |  |

Окончание табл. 5

Эксперимент 4. Схемная реализация систем псевдослучайных полностью определенных функций на FPGA

Системы псевдослучайных полностью определенных функций в эксперименте 4 генерировались в виде систем ДНФ, заданных в матричной форме парой матриц  $T^x$  и  $B^f$ , где  $T^x$  – троичная матрица, строки которой задают троичные векторы, соответствующие элементарным конъюнкциям ДНФ функций системы;  $B^{f}$  – булева матрица, в которой единичные значения элементов в строке отмечают факт вхождения соответствующей элементарной коньюнкции в ДНФ функций системы [2]. Результаты эксперимента 4 приведены в табл. 6. Анализ результатов показывает, что предварительная минимизация в классе ДНФ псевдослучайных систем полностью определенных функций практически не улучшает (а процедура BDD-оптимизации ухудшает) результаты последующего синтеза в базисе FPGA в отличие от их значительной эффективности [3, 9] при синтезе примеров схем (benchmarks), взятых из практики проектирования.

Таблица 6

|        | Результаты эксперимента 4 ( $n = 16$ , $m = 16$ , $k_{mp} = 256$ ) |   |                                                                               |      |                                                                                   |      |     |                                                                                   |           |       |   |            |  |  |
|--------|--------------------------------------------------------------------|---|-------------------------------------------------------------------------------|------|-----------------------------------------------------------------------------------|------|-----|-----------------------------------------------------------------------------------|-----------|-------|---|------------|--|--|
| Пример | α                                                                  | β | Схемная реализация<br>исходных функций<br>(полностью определенных<br>функций) |      | Схемная реализация<br>минимизированных ДНФ<br>(полностью определенных<br>функций) |      |     | Схемная реализация<br>минимизированных BDD<br>(полностью определенных<br>функций) |           |       |   |            |  |  |
|        |                                                                    |   |                                                                               |      | LUT                                                                               | τ    | LUT | τ                                                                                 | $k_{min}$ | LUT   | τ | Размер BDD |  |  |
| Gen9   | 16                                                                 | 4 | 803                                                                           | 3,91 | 803                                                                               | 3,92 | 256 | 6919                                                                              | 4,32      | 9479  |   |            |  |  |
| Gen10  | 12                                                                 | 4 | 787                                                                           | 3,82 | 783                                                                               | 3,88 | 256 | 10384                                                                             | 4,39      | 13700 |   |            |  |  |
| Gen11  | 8                                                                  | 4 | 688                                                                           | 3,89 | 695                                                                               | 4,00 | 255 | 18029                                                                             | 4,66      | 23227 |   |            |  |  |
| Gen12  | 6                                                                  | 4 | 628                                                                           | 3,72 | 541                                                                               | 3,76 | 235 | 5359                                                                              | 4,83      | 7951  |   |            |  |  |
| Gen13  | 4                                                                  | 4 | 57                                                                            | 3,18 | 54                                                                                | 3,13 | 77  | 59                                                                                | 3,23      | 203   |   |            |  |  |

### Заключение

Доопределение частичных булевых функций при оптимизации позволяет в несколько раз уменьшить сложность логических схем при проектировании заказных СБИС и структур FPGA по сравнению с реализацией матричных форм функций, интерпретируемых как системы полностью определенных булевых функций. В отличие от случая промышленных примеров систем ДНФ предварительная совместная минимизация в классе ДНФ матричных форм систем псевдослучайных частичных функций в данном эксперименте позволила получить при синтезе лучшие результаты по сравнению с предварительной оптимизацией их BDD-представлений.

# Список литературы

1. Бибило, П.Н. Системы проектирования интегральных схем на основе языка VHDL. StateCAD, ModelSim, LeonardoSpectrum / П.Н. Бибило. – М.: СОЛОН-Пресс, 2005. – 384 с.

2. Закревский, А.Д. Логический синтез каскадных схем / А.Д. Закревский. – М. : Наука, 1981. – 416 c.

3. Бибило, П.Н. Применение диаграмм двоичного выбора при синтезе логических схем / П.Н. Бибило. – Минск : Беларус. навука, 2014. – 231 с.

4. Лохов, А. Функциональная верификация СБИС в свете решений Mentor Graphics / А. Лохов // Электроника: наука, технология, бизнес. – 2004. – № 1. – С. 58–62.

5. Yang, S. BDS: a BDD-based logic optimization system / S. Yang, M. Ciesielski // IEEE Transactions on Computer-Aided Design of Integrated Circuits and Systems. -2002. - Vol. 21. - No. 7. - P. 866–876.

6. Stojkovich, S. Determining Assignment of Incompletely Specified Boolean Functions for Compact Representations by Binary Decision Diagrams / S. Stojkovich, M. Stanković, R. Stanković // 10th Intern. Workshop on Boolean Problems, Freiberg (Sachsen), 2012. – Freiberg (Sachsen), 2012. – P. 233–238.

7. Taghavi Afshord, S. An input variable partitioning algorithm for functional decomposition of a system of Boolean functions based on the tabular method / S. Taghavi Afshord, Yu.V. Pottosin, B. Arasteh // Discrete Applied Mathematics. – 2015. – No. 185. – P. 208–219.

8. Lee , R.-R. Bi-decomposing large Boolean functions via interpolation and satisfiability solving / R.-R. Lee , J.-H. R. Jiang , W.-L. Hung // Proc. of the 45th Annual Design Automation Conference, Anaheim, California, 8-13 June 2008. – N. Y., 2008. – P. 636–641.

9. Авдеев, Н.А. Эффективность логической оптимизации при синтезе комбинационных схем из библиотечных элементов / Н.А. Авдеев, П.Н. Бибило // Микроэлектроника. – 2015. – Т. 44, № 5. – С. 383–399.

10. Logic minimization algorithm for VLSI synthesis / K.R. Brayton [et al.]. – Boston : Kluwer Academic Publishers, 1984. – 193 p.

11. Торопов, Н.Р. Минимизация систем булевых функций в классе ДНФ / Н.Р. Торопов // Логическое проектирование. – Минск : Ин-т техн. кибернетики НАН Беларуси, 1999. – Вып. 4. – С. 4–19.

12. Авдеев, Н.А. Эффективность проектирования заказных схем в синтезаторе LeonardoSpectrum / Н.А. Авдеев, П.Н. Бибило // Современная электроника. – 2015. – № 1. – С. 58–61.

# Поступила 26.05.2016

Объединенный институт проблем информатики НАН Беларуси, Минск, Сурганова, 6 e-mail: bibilo@newman.bas-net.by

# P.N. Bibilo

# CIRCUIT IMPLEMENTATION OF VHDL-DESCRIPTIONS OF SYSTEMS OF PARTIAL BOOLEAN FUNCTIONS

Method for description of incompletely specified (partial) Boolean functions in VHDL is proposed. Examples of synthesized VHDL models of partial Boolean functions are presented; and the results of experiments on circuit implementation of VHDL descriptions of systems of partial functions. The realizability of original partial functions in logical circuits was verified by formal verification. The results of the experiments show that the preliminary minimization in DNF class and in the class of BDD representations for pseudo-random systems of completely specified functions does not improve practically (and in the case of BDD sometimes worsens) the results of the subsequent synthesis in the basis of FPGA unlike the significant efficiency of these procedures for the synthesis of benchmark circuits taken from the practice of the design.