УДК 621.382

### П.Н. Бибило, А.Л. Соловьев

# Оценка энергопотребления комбинационных КМОП-схем на основе логического моделирования с учетом временных задержек элементов

Предложены *VHDL*-модели библиотечных КМОП-элементов, позволяющие уменьшить погрешности оценок энергопотребления комбинационных схем из таких элементов и значительно сократить время получения оценок путем использования быстрого логического моделирования структурного описания схем.

VHDL models of CMOS library components are suggested. The models allow decreasing estimation inaccuracy of power consumption of the circuits built on such components and significant reducing the estimation time at the expense of using the fast logical modeling of structural descriptions of the circuits.

Запропоновано *VHDL*-моделі бібліотечних КМОП-елементів, які дозволяють зменшити похибки оцінок енергоспоживання комбінаційних схем з таких елементів та значно скорочують час отримання оцінок шляхом використання швидкого логічного моделювання структурного опису схем.

Введение. Снижение энергопотребления интегральных комплементарных структур металлоксид-полупроводник (КМОП) схем – одна из актуальных проблем [1]. КМОП-схемы для космических и специальных применений выполняются по технологическим нормам, для которых основную долю (до 80 процентов) потребляемой мощности составляет динамическая мощность, связанная с переключением транзисторов. Оценивать энергопотребление схем по их переключательной активности предложено в [2], применять для этих целей системы логического моделирования в [3-5]. Оценка энергопотребления КМОП-схем на основе моделирования структурных *VHDL*-описаний этих схем [3, 4] осуществляется очень быстро, так как использует в качестве оценки энергопотребления суммарное (по всем элементам схемы) число переключающихся транзисторов в сеансе моделирования схемы. При таком подходе исследованы две VHDL-модели логических элементов для подсчета числа переключений транзисторов.

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

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

Погрешность оценок энергопотребления нерегулярных комбинационных КМОП-схем для таких моделей составляла в среднем 15 процентов в сравнении с оценками, получаемыми с помощью моделирования транзисторных *SPICE*описаний схем. Однако для некоторых схем погрешность оценок энергопотребления была значительна и достигала 30 процентов, что и привело к необходимости создания более точных моделей логических элементов.

В статье предлагаются новые *VHDL*-модели комбинационных логических КМОП-элементов для оценки энергопотребления. Данные модели позволяют учитывать временные задержки элементов, входящих в схему. Информацию

о таких задержках можно получить после выполнения синтеза схемы, например, используя известный синтезатор *LeonardoSpectrum* [6]. Временные задержки, в свою очередь, учитывают нагрузки элементов и различия в энергопотреблении при переходах значений входных и выходных сигналов элементов из нулевых состояний в единичные, и наоборот – из единичных в нулевые. Эксперименты показывают значительное уменьшение погрешностей оценок энергопотребления при использовании новых моделей элементов.

## Синтез логической схемы и получение информации о задержках элементов

Рассмотрим логическую схему из КМОПэлементов, показанную на рис. 1. Функции и площади элементов приведены в табл. 1.



Рис. 1. Комбинационная логическая схема из КМОП-элементов

Полный состав библиотеки КМОП-элементов приведен в [3]. Данная схема (рис. 1) получена синтезатором *LeonardoSpectrum* [6], сформировавшим в результате синтеза не только структурное описание схемы, но и соответствующий текстовый SDF-файл, в котором для каждого элемента указываются задержки сигналов от входных полюсов к выходному полюсу (листинг 1). Отметим, что в листинге 1 задержки задаются в наносекундах (нс) и это максимальные задержки, так как в SDFфайле в соответствующей строке до первого двоеточия указывается минимальная задержка, после первого двоеточия указывается средняя задержка, после второго двоеточия - максимальная. Например, в девятой строке

*IOPATH A Y* (::0,53) (::0,42)

значение 0,53 задает максимальное время 0,53 нс установки значения выходного полюса *У* элемента *XNOR*2 при изменении входного полюса А из нулевого состояния в единичное, значение 0,42 – максимальное время 0,42 нс установки выходного полюса *Y* при изменении входного полюса *A* из единичного состояния в нулевое.

| Г | a | б | Л | И | Ц | a | 1. | Логические | элементы |
|---|---|---|---|---|---|---|----|------------|----------|
|---|---|---|---|---|---|---|----|------------|----------|

| Элемент | Функция                     | Площадь (условные единицы) |  |  |
|---------|-----------------------------|----------------------------|--|--|
| NO      | $y = \overline{(A \lor B)}$ | 268                        |  |  |
| A2      | y = A & B                   | 435                        |  |  |
| XNOR2   | $y = A \oplus B$            | 742                        |  |  |

Заметим, что о моделях логических элементов и *SDF*-файлах, получаемых синтезатором *LeonardoSpectrum*, можно прочитать в [6]. Формирование *SDF*-файла осуществляется с учетом описаний задержек библиотечных элементов, задаваемых в *LGN*-файле описания библиотеки синтеза.

Листинг 1. SDF-файл для схемы (рис. 1)

```
--1-- (TIMESCALE 1 ns)
  --2-- (CELL
  --3--( (CELLTYPE "XNOR2")
  --4--( (INSTANCE ix5)
  --5--( (DELAY
  --6--(
          (ABSOLUTE
  --7--(
           (PORT A (::0,00) (::0,00))
           (PORT B (::0,00) (::0,00))
  --8--(
  --9--( (IOPATH A Y (::0,53) (::0,42))
  --10--( (IOPATH B Y (::0,47)
(::0.30))))))
  --11--( (CELL
  --12--( (CELLTYPE "NO")
  --13--( (INSTANCE ix113)
  --14--( (DELAY
  --15--( (ABSOLUTE
  --16--( (PORT A (::0,00) (::0,00))
  --17--((PORT B (::0,00))(::0,00))
  --18--( (IOPATH A Y (::0.56) (::0.33))
  --19--( (IOPATH B Y (::0.52)
(::0.26)))))
  --20--( (CELL
  --21--( (CELLTYPE "A2")
  --22--( (INSTANCE ix1)
  --23--( (DELAY
  --24-- ( (ABSOLUTE
  --25--( (PORT A (::0,00) (::0,00))
  --26--((PORT B (::0,00))(::0,00))
  --27--( (IOPATH A Y
```

```
(::0,56) (::0,53))
--28--( (IOPATH B Y
(::0,56) (::0,48)))))
)
```

В SDF-файле курсивом выделен элемент A2, в строках 27 и 28 листинга указываются для этого элемента *максимальные* задержки распространения сигнала от полюса A и полюса B к выходному полюсу Y. Значения задержек формируются программой синтеза LeonardoSpectrum и учитывают нагрузки выходных полюсов Y КМОП-элементов. По этим значениям за-

держек далее будет рассчитываться энергопотребление элемента A2 при оценке энергопотребления схемы. Аналогично и для элементов XNOR2, NO, входящих в схему (рис. 1).

#### Проблемы согласования логического и схемотехнического моделирования схемы

В общем процессе проектирования логических схем из библиотечных элементов сначала по алгоритму функционирования схемы осуществляется синтез логической схемы, затем проводится логическое и схемотехническое моделирование полученной схемы. На этапе логического моделирования схемы можно определить ее задержку, используя *SDF*-файл. Схемотехническое моделирование позволяет проверить правильность функционирования на основе схемотехнических *SPICE*-моделей логических элементов, оценить задержки и энергопотребление.

Основная идея состоит в разработке таких *VHDL*-моделей элементов, чтобы можно было оценить энергопотребление схемы, используя систему логического, а не схемотехнического моделирования. Общая схема информационного согласования логического и схемотехнического моделирования для оценки энергопотребления показана на рис. 2. Для замены трудоемкого схемотехнического моделирования быстродействующим логическим моделированием требуется выполнить:



Рис. 2. Логическое и схемотехническое моделирование для оценки энергопотребления схем

• Согласование структурных описаний (нетлистов) схемы. Данное согласование не вызывает трудностей, так как сводится к преобразованию формата VHDL-нетлиста схемы в SPICE-нетлист той же схемы.

• Согласование схемотехнических моделей элементов библиотеки с логическими моделями. Это согласование есть стандартным и всегда выполняется при создании библиотеки проектирования, имеется в виду согласование параметров в LGN-файле с параметрами в SPICE-описаниях схемотехнических моделей логических элементов. Считается, что такое согласование уже выполнено разработчиками технологической библиотеки проектирования, в качестве которой рассматривается библиотека КМОП-элементов, приведенная в [3].

• Согласование форматов представления одинаковых тестовых наборов. Это также не вызывает затруднений и легко реализуется на практике.

Основные проблемы, возникающие при реализации предлагаемого подхода, это:

– определение зависимости энергопотребления логического элемента от задержек, указываемых для него в *SDF*-файле;

 – создание новых VHDL-моделей элементов, позволяющих учитывать при оценке энергопотребления задержку каждого из элементов по отдельности и схемы в целом. Логическое моделирование с учетом SDFфайла в системе VHDL-моделирования Model-Sim осуществляется с использованием включенных в данную систему пакетов библиотеки VITAL [6], поэтому решение указанных проблем будет осуществляться с использованием именно этих пакетов.

### Получение зависимостей энергопотребления логических элементов от нагрузки и смены состояний входных полюсов

Зависимости энергопотребления от нагрузки для каждого типа логических элементов строилась экспериментальным путем, т.е. путем схемотехнического моделирования в системе *Accusim* [8] *SPICE*-описаний библиотечных элементов. Отметим, что модели были построены для инверторов, а также двух- и трехвходовых элементов библиотеки [3].

В результате многочисленных экспериментов было установлено.

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

• Величина потребляемой элементом энергии зависит от нагрузки элемента и достаточно точно аппроксимируется линейной функцией.

• Задержка элемента также имеет линейную зависимость от нагрузки элемента, поэтому можно показать, что величина потребляемой элементом энергии линейно зависит от задержки элемента.

Для нахождения зависимости энергопотребления логического элемента от его нагрузки строились специальные схемы, имитирующие окружение этого элемента в «больших» схемах, после чего проводилось моделирование в системе *Accusim*. В качестве специальных использовались схемы, в которых тестируемый логический элемент был подключен таким образом, что сигнал на каждый вход элемента проходил через повторитель (для имитации реальных фронтов сигналов в схеме), а к выходу этого элемента параллельно подключено от одного до четырех повторителей (для имитации разной нагрузки элемента). Затем создавались упорядоченные пары тестовых наборов, подаваемых многократно на входы такой тестовой схемы. Число всех таких упорядоченных пар <предыдущий набор, текущий набор> для двухвходовых элементов равно 16: <00, 00>, <00,01>, <00,10>, <00,11>, <01,00>, ..., <11,11>. Таким образом, для каждой комбинации <предыдущий набор, текущий набор> состояний входов элемента определялась зависимость энергопотребления от разветвления по выходу.

Например, для элемента A2 (конъюнктора) и пары <00,11> сменяемых состояний на входах элемента, был получен график (рис. 3) линейной зависимости энергопотребления от числа N элементов, подключенных к выходу (нагрузки).



Рис. 3. Зависимость энергопотребления *E* элемента *A*2 при увеличении нагрузки *N* элемента при смене <00,11> входных сигналов

График зависимости, показанной на рис. 3 описывается линейной функций E = kn + b. Для *VHDL*-моделирования требуется вычислить коэффициенты k, b и согласовать их с параметрами времени, задаваемыми в *SDF*-файле. Это было сделано для каждого типа элемента и каждой пары сменяемых наборов на входах элемента при различной нагрузке. Для фиксированной нагрузки N по среднему току (*Average*) и времени моделирования подсчитывалась средняя энергия, потребленная логическим элементом. Так получалась каждая точка на графике (рис. 3). График зависимости, построенный по полученным четырем точкам, аппроксимировался прямой линией, т.е. фор-

мировались значения k, b. Полученные таким образом значения k, b были пересчитаны в значения  $k_1$ ,  $b_1$  для получения линейной зависимости  $E = k_1 t + b_1$  энергии от задержек t, задаваемых в SDF-файле, и записаны в VHDLпакет perecl (рис. 2) для использования при VHDL-моделировании. При подстановке полученных констант в линейную функцию E =  $= k_1 t + b_1$  при *VHDL*-моделировании получается зависимость значения энергии (в кулонах) от значений задержки элемента, указываемой в SDF-файле. Для элемента A2 значения констант  $k_1$ ,  $b_1$  (в пакете эти константы имеют имена А2 К, А2 В) приведены ниже в фрагменте текста *VHDL*-пакета *perecl* (листинг 2) для 16 пар входных наборов. Для третьей пары наборов <00, 11> эти коэффициенты выделены жирным шрифтом. Уравнение  $E = k_1 t + b_1$  в данном примере имеет вид  $E = 1,39243051 \times 10^{-12} t + 10^{-12} t$  $+5,49307101 \times 10^{-14}$ , где E – энергия (кулоны); *t* – задержка элемента, формируемая по значениям задержек элемента, указанным в SDFфайле.

Листинг 2. Фрагмент VHDL-пакета perecl

TYPE IN2 IS ARRAY (0 to 15) OF real;

```
CONSTANT A2 K : IN2 := (
-4,08989174E-26, -3,78323165E-19,
-2,9035714E-19,
                  1,39243051E-12,
-3,78323165E-19, -0,0000000E+00,
-6,29843327E-19,
                 1,37150945E-12,
                  6,29843327E-19,
-2,9035714E-19,
-0,0000000E+00,
                 1,38196824E-12,
-1,39243051E-12,
                  1,37150945E-12,
                  2,04494586E-25);
1,38196824E-12,
CONSTANT A2 B : IN2 := (
4,00545274E-19, -6,27862605E-17,
5,17463467E-19,
                 5,49307101E-14,
-6,27862605E-17, 6,7574314E-19,
1,31658847E-13,
                 1,81446961E-13,
5,17463467E-19,
                 1,31658847E-13,
4,00545204E-19,
                 4,48169774E-14,
5,49307101E-14,
                 1,81446961E-13,
4,48169774E-14,
                 6,01086803E-19);
```

Создание *VHDL*-моделей логических КМОП-элементов для оценки энергопотребления

Уточнения *VHDL*-моделей элементов, предложенных ранее в [3, 4], заключаются в следующем.

В новых моделях считается, что логические элементы имеют «реальные» временные задержки, т.е. задержки, передаваемые из *SDF*файла. Ранее задержки элементов полагались либо нулевыми, либо единичными (1 *ns*).

Функциональность элемента не связана с оценкой энергопотребления. Функция элемента при моделировании вычисляется с использованием средств библиотеки VITAL (пакеты  $VITAL\_Timing$ , VCOMPONENTS). Оценка энергопотребления осуществляется в отдельном процессе. При этом глобальный сигнал ZK, декларированный в VHDL-пакете perecl, служит для суммирования значений потребляемой энергии по всем экземплярам элементов схемы. Каждый элемент имеет доступ к данному глобальному сигналу и командой  $ZK <= temp\_c$ ; пересылает значение переменной, вычисляемой с использованием разрешающей функции  $sum\_percl$ .

В листинге 3 приводится *VHDL*-модель логического элемента, предназначенная для оценки энергопотребления. Функция элемента (конъюнкция входных сигналов) вычисляется с помощью компонента A2\_V, описанного в *VITAL*пакетах. В операторе

p0: A2\_V generic map (TimingChecksOn, InstancePath, Xon, MsgOn, tpd\_A\_Y, tpd\_B\_Y, tipd\_A, tipd\_B) port map (A=>A, B=>B, Y=>Y);

передаются параметры и создается экземпляр компонента A2 V.

Энергопотребление элемента A2 подсчитывается в процессе, вызываемом оператором *process* (*A*, *B*). Данный процесс выполняется, когда изменяется хотя бы один из сигналов *A*, *B*, которые есть входными сигналами элемента. Основное назначение процесса: по параметрам  $tpd_A_Y$ ,  $tpd_A_Y$ ,  $tpd_B_Y$ ,  $tpd_B_Y$ , значения которых для каждого компонента схемы при моделировании передаются из *SDF*-файла, определить время задержки элемента, предыдущую и новую комбинацию состояний входов элемента и по этим значениям подсчитать энергопотребление этого элемента в текущем такте моделирования схемы. Переменная average delay в выражении

average\_delay:=real((tpd\_A\_Y(tr01)+ tpd\_A\_Y(tr10)+tpd\_B\_Y(tr01)+tpd\_B\_Y(tr10))/(4\*10) fs);

задает среднее время задержки распространения сигнала в десятках фемтосекунд. Параметры tr01, tr10 определены в пакетах VITAL. Моделирование надо выполнять с учетом установки VHDL-параметра resolution меньше, чем 4\*10 фемтосекунд, чтобы не было деления на нуль в результате округления.

*Листинг* 3. *VHDL*-модель логического элемента *A*2

```
library IEEE;
use IEEE.STD_LOGIC_1164.all;
use IEEE.NUMERIC_STD.all;
use IEEE.VITAL_Timing.all;
library work;
use work.VCOMPONENTS.all;
use work.perecl.all;
```

```
entity A2 is
   generic(
        TimingChecksOn: Boolean := True;
        InstancePath: STRING := "*";
        Xon: Boolean := False;
        MsgOn: Boolean := True;
        tpd A Y
                        :
                            VitalDe-
layType01 := (0, 56 ns, 0, 53 ns);
        tpd B Y
                :
                             VitalDe-
layType01 := (0, 56 ns, 0, 48 ns);
        tipd A
                             VitalDe-
                       :
layType01 := (0,000 ps, 0,000 ps);
       tipd B
                        :
                            VitalDe-
layType01 := (0,000 ps, 0,000 ps));
  port (A: IN std ulogic;
     B: IN std ulogic;
     Y:OUT std ulogic);
  end;
  architecture BEHAVIOR of A2 is
```

begin p0: A2\_V generic map (TimingChecksOn, I nstancePath, Xon, MsgOn, tpd\_A\_Y, tpd\_B\_Y, tipd\_A, tipd\_B) port map (A=>A, B=>B, Y=>Y);

#### process (A,B)

```
variable case_number : integer;
variable average_delay,temp : real;
variable ptime : time:=0 ps;
variable pbits : std_logic_vector (1
to 2):=(OTHERS=>'U');
```

```
variable case vector :
std logic vector (3 downto 0);
  variable temp c: REAL V:=0.0;
  begin
  average delay:=real((tpd A Y(tr01)+
tpd A Y(tr10) + tpd B Y(tr01) + tpd B Y(tr10))
/(4*10) fs); --50 0000 *10E-6 ns
      average delay:=average delay*1.0E-
5;--ns
      case vector:=pbits&A&B;
      case number:=
TO INTEGER (unsigned (case vector));
temp:=average delay*A2 K(case number)+A2
B(case number);
      pbits(1):=A;
      pbits(2) := B;
      temp_c:=temp_c+temp;
      ZK<=temp c;
      ptime:=now;
  end process;
  end;
```

Подсчет энергопотребления осуществляется следующим образом. Выражение

```
tpd_A_Y(tr01)+tpd_A_Y(tr10)+tpd_B_
Y(tr01)+tpd_B_Y(tr10)
```

задает (в условных единицах, приведенных к десяткам фемтосекунд) время задержки элемента, затем определяется номер пары наборов, сменяемых на входах элемента A2.

Переменная

case vector:=pbits&A&B;

задает конкатенацию предыдущих и текущих значений входных полюсов элемента. Для этой пары определяются значения констант *A2\_к*, *A2\_*В в соответствующих массивах констант. После этого вычисляется значение аппроксимирующей функции

temp:=average\_delay\*A2\_K(case\_number) +
A2\_B(case\_number),

задающей энергопотребление (в кулонах). В примере значение *case\_number* равно трем, что соответствует паре <00,11>. Параметр *av-erage\_delay* – это время в наносекундах, полученное с помощью выражения

average\_delay:=average\_delay\*1.0E-5. Именно в данных единицах (нс) указываются задержки в *SDF*-файле. Достоинством предложенных *VHDL*-моделей элементов является и то, что их использование не требует изменения структурных *VHDL*описаний схем, получаемых программами синтеза. Для оценки энергопотребления схемы путем *VHDL*-моделирования требуется создать только *VHDL*-модели элементов библиотеки, подобные рассмотренной модели для элемента *A*2.

#### Эксперимент

Эксперимент проведен для комбинационных схем, исходные описания которых взяты из известной библиотеки Berkeley PLA Test Set и синтезированы схемы в синтезаторе LeonardoSpectrum. Синтез осуществлялся в базисе одно-, двух- и трехвходовых элементов библиотеки [3] КМОП-элементов. Логическое моделирование для оценки энергопотребления схем проводилось в системе ModelSim [6]. Сравнение полученных оценок энергопотребления проведено с эталонными результатами, полученными путем моделирования в системе схемотехнического (аналогового) моделирования AccuSim II (ф. Menthor Graphics), использующей моделирующее ядро *Eldo* [7], на тех же тестовых наборах и в одном и том же модельном времени. Эксперименты для всех схем при схемотехническом моделировании проводились с одинаковыми значениями параметров: длительности передних и задних фронтов входных сигналов 1 нс; период подачи входных сигналов 40 нс; температура +27°С. Задержка каждой из схем не превышала 40 нс.

Были применены следующие типы *T* тестовых последовательностей (тестов):

*Тест типа* T = 1. Тестовые наборы с равновероятными значениями нулей и единиц, т.е. на любом входе логической схемы для любого входного набора вероятность появления единицы (нуля) равна 0,5.

*Тест типа* T = 2. Тестовые наборы, состоящие из упорядоченной по возрастанию десятичного эквивалента последовательности из  $2^n$  всех наборов булева пространства размерности *n*.

*Тест типа T* = 3. Специальная последовательность тестовых наборов, генерируемая с помощью алгоритма [8] и задающая все упорядоченные пары входных наборов из булева пространства размерности *r*.

Результаты экспериментального сравнения представлены в табл. 2, где используются следующие обозначения:

*n* – число входов схемы;

*S* – суммарная площадь (в условных единицах) всех элементов схемы;

T – тип теста T = 1, 2, 3;

К – число наборов в тесте (длина теста);

*A* (*Average*) – средний потребляемый ток (мА), измеренный с помощью схемотехничес-кого моделирования в системе *Accusim* (ф. *Mentor Graphics*);

 $E_{ModelSim}$  – предсказанное значение потребляемой энергии в кулонах (логическое моделирование в системе *ModelSim*);

 $E_{Accusim}$  – эталонное значение потребляемой энергии в кулонах (схемотехническое моделирование в системе *Accusim*), получаемое как произведение среднего тока на время моделирования;

σ – погрешность предсказания значения
 энергии, потребляемой схемой,

$$\sigma = \frac{(E_{ModelSim} - E_{Accusim})}{E_{Accusim}} 100 \%.$$

Анализ представленных в табл. 2 и других полученных экспериментальных данных позволяет сделать следующие выводы.

• Скорость получения оценок энергопотребления на основе VHDL-моделирования значительно (на несколько порядков) выше, чем получение таких оценок с помощью схемотехнического моделирования. Например, VHDL-моделирование схемы С1908 (табл. 2) на 4096 тестовых наборах потребовало 15 с, а схемотехническое моделирование на тех же тестовых наборах - один час времени работы компьютера. Оценка на 1024 тестовых наборах энергопотребления схемы INTB, состоящей из 1322 элементов суммарной площадью 444709 условных единиц, в системе AccuSim II заняла 6 часов, а оценка предложенным способом на основе VHDL-моделирования - 20 с, погрешность составила 0,5 процента. На практике, однако, требуется выполнение тестов, включаю-

УСиМ, 2014, № 6

## Таблица 2. Результаты эксперимента

| Имя схемы     | S      | п   | Т | K    | A                       | $E_{Accusim}$            | $E_{ModelSim}$          | σ,%  |
|---------------|--------|-----|---|------|-------------------------|--------------------------|-------------------------|------|
| b12           | 19826  | 15  | 1 | 110  | 3,302·10 <sup>-4</sup>  | 1,453·10 <sup>-9</sup>   | 1,547·10 <sup>-9</sup>  | 6,5  |
| <i>C</i> 1355 | 96065  | 41  | 1 | 4096 | 2,441 ·10 <sup>-3</sup> | 3,999·10 <sup>-7</sup>   | 4,250 ·10 <sup>-7</sup> | 6,3  |
| CHT           | 47770  | 47  | 1 | 4096 | 1,602·10 <sup>-3</sup>  | 2,625·10 <sup>-7</sup>   | 2,599·10 <sup>-7</sup>  | -1,0 |
| FRG2          | 299501 | 143 | 1 | 4096 | 7,249·10 <sup>-3</sup>  | 1,188·10 <sup>-6</sup>   | 1,223.10-6              | 2,9  |
| <i>I</i> 8    | 205684 | 133 | 1 | 4096 | 9,127·10 <sup>-4</sup>  | 1,495·10 <sup>-7</sup>   | 1,552 10-7              | 3,8  |
| <i>C</i> 1908 | 92522  | 33  | 1 | 4096 | 2,228 ·10 <sup>-3</sup> | 3,651·10 <sup>-7</sup>   | 4,046 ·10 <sup>-7</sup> | 10,8 |
| life          | 15178  | 9   | 2 | 512  | 2,394 ·10 <sup>-4</sup> | 4,904·10 <sup>-9</sup>   | 4,896·10 <sup>-9</sup>  | -0,2 |
| C432          | 43357  | 36  | 1 | 4096 | 9,491·10 <sup>-4</sup>  | 1,555·10 <sup>-7</sup>   | 1,689·10 <sup>-7</sup>  | 8,6  |
| FRG1          | 40154  | 28  | 1 | 4096 | 5,973·10 <sup>-4</sup>  | 9,787·10 <sup>-8</sup>   | 1,015 10-7              | 3,7  |
| C880          | 25808  | 60  | 1 | 4096 | 3,431 ·10 <sup>-4</sup> | 5,622·10 <sup>-8</sup>   | 5,764 ·10 <sup>-8</sup> | 2,5  |
| C499          | 46917  | 41  | 1 | 4096 | 1,850·10 <sup>-4</sup>  | 3,032·10 <sup>-8</sup>   | 2,882·10 <sup>-8</sup>  | -4,9 |
| I3            | 30545  | 132 | 1 | 4096 | 5,591·10 <sup>-4</sup>  | 9,160·10 <sup>-8</sup>   | 9,629·10 <sup>-8</sup>  | 5,1  |
| <i>I</i> 9    | 32236  | 88  | 1 | 512  | 5,784 ·10 <sup>-4</sup> | 1,185·10 <sup>-8</sup>   | 1,070·10 <sup>-8</sup>  | -9,6 |
| DALU          | 124071 | 75  | 1 | 1024 | 2,117·10 <sup>-3</sup>  | 8,673·10 <sup>-8</sup>   | 8,630·10 <sup>-8</sup>  | -0,5 |
| MY_ADDER      | 28904  | 4   | 1 | 2048 | 7,134 ·10 <sup>-4</sup> | 5,844 ·10 <sup>-8</sup>  | 5,761 ·10 <sup>-8</sup> | -1,4 |
| CM42A         | 1830   | 4   | 3 | 241  | 3,082·10 <sup>-5</sup>  | 2,971 ·10 <sup>-10</sup> | 3,093·10 <sup>-10</sup> | 4,1  |
| CM82A         | 3437   | 5   | 3 | 993  | 6,522·10 <sup>-5</sup>  | 2,591·10 <sup>-9</sup>   | 2,649·10 <sup>-9</sup>  | 2,3  |
| CM85A         | 4994   | 11  | 1 | 2048 | 9,514 ·10 <sup>-5</sup> | 7,794 ·10 <sup>-9</sup>  | 7,662·10 <sup>-9</sup>  | -1,7 |
| CM138A        | 1099   | 6   | 1 | 2048 | 1,194 ·10 <sup>-5</sup> | 9,777·10 <sup>-10</sup>  | 1,014 ·10 <sup>-9</sup> | 3,7  |
| CM162A        | 6283   | 14  | 1 | 2048 | 1,189.10-4              | 9,742 ·10 <sup>-9</sup>  | 9,382·10 <sup>-9</sup>  | -3,7 |
| INTB          | 444709 | 15  | 1 | 1024 | 4,798 ·10 <sup>-3</sup> | 1,965 ·10 <sup>-7</sup>  | 1,975 ·10 <sup>-7</sup> | 0,5  |

щих десятки тысяч (и более) тестовых наборов, поэтому сокращение времени, требуемого для оценки энергопотребления, может быть гораздо более значительным, так требуется моделировать схемы и большей размерности, чем схемы *C*1908, *INTB*.

• Предложенные VHDL-модели КМОП-элементов позволили значительно уменьшить погрешности оценок энергопотребления комбинационных КМОП-схем в сравнении с полученными ранее [3, 4] оценками погрешности. Достигнута *средняя погрешность* 3,39 процентов оценки энергопотребления схем в сравнении с аналоговым моделированием. Получаемые по новым VHDL-моделям оценки являются практически полезными, что позволяет многократно оценивать энергопотребление схем на этапе логического проектирования, не выполняя трудоемкое схемотехническое моделирование транзисторных SPICE-описаний схем.

Заключение. Применение логического моделирования на основе предложенных *VHDL*моделей КМОП-элементов позволяет на несколько порядков увеличить быстродействие процессов оценки энергопотребления в сравнении со схемотехническим моделированием и может быть использовано на этапе логического проектирования для оценки различных вариантов схемной реализации проекта цифровой КМОП-схемы.

- Рабаи Ж.М., Чандракасан А., Николич Б. Цифровые интегральные схемы. – М.: Вильямс, 2007. – 912 с.
- Estimation of Average Switching Activity in Combinational and Sequential Circuits / A. Ghosh, S. Devadas, K. Keutzer et al. // Proc. 29th ACM/ IEEE Design Automation Conf. – 1992. – P. 253–259.
- Бибило П.Н., Кириенко Н.А. Оценка энергопотребления логических КМОП-схем по их переключательной активности // Микроэлектроника. – 2012. – № 1. – С. 65–77.
- 4. Бибило П.Н., Соловьев А.Л. Оценка энергопотребления КМОП-схем на базе логического моделирования // Информатика. – 2012. – № 1 (33). – С. 76–85.
- 5. Оценка энергопотребления цифровых КМОП-схем на основе логического моделирования их структурных описаний / П.Н. Бибило, А.Л. Соловьев, В.Ш. Меликян и др. // Вестн. инженерной академии Армении. 2012, Т. 9. № 3. С. 600–610.
- 6. Бибило П.Н., Авдеев Н.А. VHDL. Эффективное использование при проектировании цифровых систем. - М.: СОЛОН-Пресс, 2006. – 344 с.
- 7. *Eldo* User's Manual, v. 6.5 1. 2005.
- Закревский А.Д. Минимизация перебора ориентированных пар // Танаевские чтения: доклады Четвертой междунар. науч. конф., Минск, 29–30 марта 2010 г. / ОИПИ НАН Беларуси. – Минск, 2010. – С. 58–62.

Поступила 21.10.2014 Тел. для справок: +37 517 284-2084, 284-2076 (Минск) *E-mail: bibilo@newman.bas-net.by* © П.Н. Бибило, А.Л. Соловьев, 2014