Научная статья на тему 'ТЕОРЕМА О СХОДИМОСТИ ГЕНЕТИЧЕСКОГО АЛГОРИТМА С ДВУХУРОВНЕВЫМ КОДИРОВАНИЕМ К ТОЧНОМУ РЕШЕНИЮ ЗАДАЧИ РЕКОНФИГУРАЦИИ ПЛИС'

ТЕОРЕМА О СХОДИМОСТИ ГЕНЕТИЧЕСКОГО АЛГОРИТМА С ДВУХУРОВНЕВЫМ КОДИРОВАНИЕМ К ТОЧНОМУ РЕШЕНИЮ ЗАДАЧИ РЕКОНФИГУРАЦИИ ПЛИС Текст научной статьи по специальности «Математика»

CC BY
183
12
i Надоели баннеры? Вы всегда можете отключить рекламу.
Ключевые слова
ГЕНЕТИЧЕСКИЙ АЛГОРИТМ / GENETIC ALGORITHM / ПЛИС / FPGA / РЕКОНФИГУРАЦИЯ / RECONFIGURATION / СХОДИМОСТЬ / CONVERGENCE / ОПТИМИЗАЦИЯ / OPTIMIZATION

Аннотация научной статьи по математике, автор научной работы — Городилов А.Ю., Данилова Е.Ю.

Приведена краткая постановка задачи реконфигурации ПЛИС, описаны базовый и генетический алгоритмы реконфигурации. Генетический алгоритм использует двухуровневое кодирование решений с промежуточным представлением в виде матрицы смежности полного двудольного графа. Сформулирована и доказана теорема о сходимости разработанного генетического алгоритма к точному решению задачи реконфигурации ПЛИС.

i Надоели баннеры? Вы всегда можете отключить рекламу.
iНе можете найти то, что вам нужно? Попробуйте сервис подбора литературы.
i Надоели баннеры? Вы всегда можете отключить рекламу.

A THEOREM ON THE CONVERGENCE OF TWO-LEVEL CODING GENETIC ALGORITHM TO THE EXACT SOLUTION OF THE FPGA RECONFIGURATION TASK

The article gives a brief statement of the FPGA reconfiguration problem and describes basic and genetic reconfiguration algorithms. The genetic algorithm uses a two-level solution coding and intermediate representation in the form of the complete bipartite graph adjacency matrix. A theorem on the convergence of developed genetic algorithm to the exact solution of the FPGA reconfiguration task is formulated and proved.

Текст научной работы на тему «ТЕОРЕМА О СХОДИМОСТИ ГЕНЕТИЧЕСКОГО АЛГОРИТМА С ДВУХУРОВНЕВЫМ КОДИРОВАНИЕМ К ТОЧНОМУ РЕШЕНИЮ ЗАДАЧИ РЕКОНФИГУРАЦИИ ПЛИС»

2015

ВЕСТНИК ПЕРМСКОГО УНИВЕРСИТЕТА

Математика. Механика. Информатика Вып. 4(31)

УДК 004.312+004.023

Теорема о сходимости генетического алгоритма с двухуровневым кодированием к точному решению задачи реконфигурации ПЛИС

А. Ю. Городилов

Пермский государственный национальный исследовательский университет

Россия, 614068, Пермь, ул. Букирева, 15

gora830@yandex.ru

Е. Ю. Данилова

Пермский государственный национальный исследовательский университет

Россия, 614068, Пермь, ул. Букирева, 15

ket-eref@yandex.ru

Приведена краткая постановка задачи реконфигурации ПЛИС, описаны базовый и генетический алгоритмы реконфигурации. Генетический алгоритм использует двухуровневое кодирование решений с промежуточным представлением в виде матрицы смежности полного двудольного графа. Сформулирована и доказана теорема о сходимости разработанного генетического алгоритма к точному решению задачи реконфигурации ПЛИС.

Ключевые слова: генетический алгоритм; ПЛИС; FPGA; реконфигурация; сходимость; оптимизация.

Введение

Для решения задачи реконфигурации ПЛИС необходимо совершить несколько шагов. Первый из них - проведение диагностики, по результатам которой становится известно состояние каждого логического элемента (ЛЭ). Таких состояний может быть два: 0 - неработоспособный и 1 - работоспособный.

Эти данные можно представить в виде таблицы, называемой матрицей состояний и обозначаемой A. Для реконфигурации выбирается наиболее предпочтительный набор работоспособных элементов, расположенных максимально компактно. Множество используемых ЛЭ в системах конфигурации ПЛИС описывается набором прямоугольников (координатами их левого верхнего угла и размерами). Прямоугольники не должны пересекаться и не должны содержать неработоспособных ЛЭ. Чем меньше количество прямо-

© Городилов А. Ю., Данилова Е. Ю., 2015

угольников в описании, тем быстрее будет выполнена реконфигурация.

Пусть Рху(Ь,1) - матрица размерности hx/, полученная из матрицы А удалением строк с номерами 1, 2, ..., х-1, ..., п и столбцов с номерами 1, 2, ...,у-1, у+1, ..., т. То есть

(

Рх,у (Ь I) =

*х, у+г-1

Л

^ °х+й-1,у

. (1)

лх+ь-\,у+г-\ у

Элемент ах,у будем называть якорем матрицы Рху. Если все элементы матрицы Рх,уф,!) равны 1, то это покрывающий прямоугольник. Количество элементов в нем назовем площадью покрывающего прямоугольника и обозначим S(P). Множество R покрывающих прямоугольников Р1,Р2,...,Рк назовем покрытием, если никакая пара покрывающих прямоугольников из этого множества не пересекается. Сумму площадей покрывающих прямоугольников, входящих в покрытие, назовем площадью покрытия и обозначим S(R).

а

х, у

Пусть t - количество ЛЭ, необходимых для реализации схемы устройства. Тогда задачу можно сформулировать так: дана матрица состояний A и число t. Найти покрытие площади > минимальной мощности. Данная задача является ОТ-трудной [1], поэтому на больших логических схемах точные алгоритмы будут работать неприемлемо долго. Следовательно, необходима разработка приближенных, эвристических алгоритмов.

Базовый приближенный алгоритм

Покрывающий прямоугольник Pxy(h0,l0) назовем локально-максимальным, если не существует покрывающего прямоугольника большей площади с тем же якорем.

На основе этого определения можно предложить следующий алгоритм решения задачи:

1. R ^ 0.

2. Установить порядок просмотра элементов матрицы A.

3. Выбрать очередной элемент ax,y из матрицы A в соответствии с установленным порядком.

4. Найти локально-максимальный покрывающий прямоугольник Pxy(h0,l0) с якорем axy.

5. R ^ R и Px,y(hoJo).

6. Обнулить все элементы матрицы A, входящие в Px,y(ho,lo): aij ^ 0, i=x. л+Ь-1, j=y. .у+!о- 1.

7. Вычислить, сколько «единиц» еще нужно покрыть: t ^ t -

8. Если ^0, перейти к шагу 3.

9. Покрытие R является решением задачи.

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

Генетический алгоритм

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

ключить из рассмотрения. Таким образом, длина каждой хромосомы L будет фиксирована и равна количеству "1" в таблице состояний. Но сама такая последовательность s (перестановка на множестве работоспособных ЛЭ) является только особью, но не может кодироваться в виде хромосомы, поскольку гены (элементы перестановки) зависят друг от друга. Чтобы обеспечить независимость генов, закодируем перестановку с помощью промежуточного объекта. В качестве такого объекта предлагается совершенное паросоче-тание в полном двудольном графе. Хромосомой при этом будет сам граф, заданный в виде матрицы смежности. Такое представление обладает двумя основными свойствами: независимость генов (элементов матрицы) и существование эффективной процедуры преобразования в перестановку, для этого достаточно упорядочить все ребра паросочетания по вершинам первой доли (перестановку образуют вершины второй доли). Процедуру преобразования будем обозначать Present. Для поиска самого паросочетания в графе используется эффективный "венгерский алгоритм", который находит правильный ответ за полиномиальное время [2].

Подробное описание операторов двухуровневого ГА и промежуточного представления можно найти в [3, 4, 5].

Приспособленность особи определяется после запуска алгоритма а как величина, обратная к мощности множества R.

Обоснование сходимости генетического

алгоритма к точному решению

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

Единственное, что отличает предложенный алгоритм от классических - это оригинальный способ кодирования и, соответственно, вычисления приспособленности особей. Следовательно, необходимо проверить три условия, которым должна удовлетворять фитнесс-функция в классических ГА.

1. Потомки, получающиеся в результате скрещивания, должны быть «похожими» на своих родителей.

Это означает, что в результате скрещивания двух перестановок должны получаться перестановки, «похожие» на родительские особи. Термин «похожими» в данном случае формализовать невозможно. Будем исходить из такой трактовки этого термина: перестановки должны совпадать значениями отдельных элементов в некоторых позициях. Пусть особи ц3 и ц4 являются потомками особей Ц" и ц2, S\=Present (fa ) = (i" i'2 ... i'L ), s2=Present (u2) = (i" i'2' ... i"L ), s3=Present )=(/" j2 ... jL ), S4=Present fa )=(j" j2 ... j"L). Нас интересуют позиции k, в которых значение элемента потомка j'k совпадает со значением соответствующего элемента в одном из родителей, то есть с i'k или i"k . Обозначим через Sum" количество таких номеров k для первого потомка, а через Sum2 - для второго. То есть,

Sumj = ¿7 ((jk = ik )v(jk = ik)),

k="

Sum 2 =¿7 ((jk= ik )v( jk' = ik')).

k="

Общее количество позиций, в которых может быть совпадение элементов перестановок, очевидно, равно 2L. Таким образом, нас

Sum" + Sum2 интересует отношение Q =-—-, которое имеет смысл доли генов в потомстве, унаследованных от родителей, и выражает степень «похожести» потомков на предков.

К сожалению, теоретически нельзя гарантировать, что параметр Q будет достаточно большим, поэтому значение Q проверялось эмпирически. Для проведения эксперимента было сгенерировано 35 матриц размерности "", заполненных случайными числами. Далее 80 раз был запущен оператор скрещивания, и для каждого запуска определялось значение параметра Q. По полученным данным можно сделать следующие выводы:

• во всех случаях параметр Q превысил

значение 0,4;

• более чем в 90 % случаев параметр Q

превысил значение 0,5;

• среднее значение параметра Q соста-

вило 0,732.

То есть в абсолютном большинстве случаев потомками от родителей наследуется по меньшей мере половина значений, что можно признать вполне приемлемым результатом.

2. Чем больше значение приспособленности особи, тем лучше должно быть решение, кодируемое данной особью.

Выполнение данного условия гарантируется непосредственно правилом вычисления приспособленности: чем больше величина 1/Д|, тем меньше Д|, т. е. меньше количество задействованных прямоугольников и, следовательно, элементы располагаются более компактно.

3. Существует особь с максимальной приспособленностью, кодирующая точное решение задачи.

Для проверки данного условия докажем следующую теорему.

Теорема. Существует последовательность просмотра элементов

ах у ,ах у ,...,ах у такая, что выполнение

х1, у1 ' х2, у2 ' ' хк, ук '

алгоритма а дает точное решение задачи.

Доказательство. Обозначим точное решение задачи R*, а решение, полученное алгоритмом а, обозначим R. Докажем, что для любых матрицы А и числа t существует такая последовательность просмотра элементов, что |Я|=|Я*|. Доказательство выполним по индукции по мощности покрытия R* для пары (А, 0.

База индукции |Я*|=1. То есть R* = {Р*х^1,11)}. Тогда очевидно, что последовательность, состоящая из одного элемента (аху), является искомой. Действительно, в локально-максимальном покрывающем прямоугольнике Рх,у(/0,10): /0 • 10 > к1 • 11 > t, т. е.

R = {Рх,уфо,!о)} и |Я|=|Я*|=1.

Индукционный переход. Пусть утверждение справедливо для всех пар (А, (), для которых |Я*|=к-1. Докажем, что оно будет справедливо и для пар, в которых |Я*|=к.

Лемма 1. В оптимальном покрытии R* найдется покрывающий прямоугольник Р*и,у№\,1\) такой, что локально-максимальный покрывающий прямоугольник с тем же якорем Ри,у(/0,/0) попарно не пересекается ни с одним из остальных покрывающих прямоугольников из R*, то есть

Я / ¡1): УР* е Я*, Я* * я:у С/ч, ¡1):

* (2) Риу (¿0, ¡0) п Я =0.

Доказател ьство Предположим противное:

ИА):ЗР* еЯ*,Р *Р1 ИА):

* (3)

Ри,у(И,,/0)пР* *0.

Пусть я*={Px;,y1,px;,y2,^,Рх1,у4}. Построим ориентированный граф G=(V,E). Отметим, что множество вершин соответствует множеству якорей покрывающих прямоугольников из Я*:

V = V2,...,ук}у = аХ1 ,у1,. = 1,к .

Ребро

(V,V, ) е Е о Р^ (И,,/0) пРх*,^ (И,,/,) * 0 .

То есть ребро идет из вершины 1 в вершину ,, если локально-максимальный покрывающий прямоугольник с якорем в 1-той вершине пересекается с покрывающим прямоугольником с якорем в /-той вершине. Лемма 1.1

Рх,у (И', /') п Рх,,у . (И", /") * 0 о х ' + И' > х" л

х' < х" + И" л у " + Г > у " л у " < у "' + /". Доказател ьство

^ Пусть ах,у е Рх,у (И',/') п Рх,у (И",/").

Тогда

ах,у е Рху(И',/') ^ х > х 1 х <

ах,у еР,У(Ь\Г)^х<х-+Их <х + И '

Остальные неравенства доказываются аналогично.

iНе можете найти то, что вам нужно? Попробуйте сервис подбора литературы.

Возьмем х = тах(х ', х" ). Очевидно, х > х', х > х ". Поскольку х' < х' + И ' и х " < х ' + И', то х < х ' + И'. Аналогично доказывается, что х < х " + И", у < у' + /' и у < у" + /". Таким образом,

ах,у е Рх,у,(И ',/ '),ах,у е Рх„у (И'',/"), что и требовалось доказать.

Следствие 1.1

(у. ,V,) е Е ^ + И0 > х(. лх. < х(. + И, л

; . . 1 (4)

уг + г0 > у,л у. < у, + г,.

Лемма 1.2

(У , ) е Е ^ у, > у V х, > х. Доказательство

Предположим противное, и

у, < у. л х1 < х. . По следствию 1.1

х. < х, + И, и у. < у, + /,. Следовательно,

х,. < х < х,. + И, л у,. < у. < у,. + ^

а е Р* (И , / ).

х, у. ^, уЛ ^

Кроме того, очевидно,

ах у е Р* у (И., гi). Но два покрывающих

прямоугольника из покрытия Я* не могут иметь общих элементов. Возникает противоречие. Лемма 1.2 доказана.

В соответствии с(3)

V. З], , * 1: Рх.,у. (И0, /0) п К,^ (И,,/,) *0 .

То есть, из любой вершины графа G есть хотя бы одно исходящее ребро. Следовательно, в графе G есть ориентированный цикл. Пусть его образуют вершины уиу2,...,у„. Далее будем рассматривать только вершины и ребра, составляющие этот цикл.

На основе графа G=(V,E) (точнее, вершин и ребер, образующих ориентированный цикл) построим ориентированный ортогональный граф Н=(и,Ен) на плоскости по следующим правилам. Вершины:

V = ах,,у. е V ^ иг = (х. , у. ) е и .

Ребра. В соответствии с леммой 1.2 возможны три типа ребер в графе G (рис. 1).

Рис. 1. Возможные ребра в графе G

Тип 1. у, > у., х, < х. . Добавим в граф Н вершину и, = (х., у,) и пару ребер: горизонтальное (и.,и,) и вертикальное (и,,и,) (в

случае х,=х1 вершина и, совпадает с вершиной и, и вертикальное ребро отсутствует). Заметим, что если точка (х, у) лежит на ребре (и,, и,), то у=у, ху^х^х-.

По следствию 1.1, х. < х, + И,.

1 ] ]

Из указанных соотношений получаем, что

y=y;, x;<x<xi<x;+и; ^ ах,у е Рх;,у } . (5)

Тип 2. у, < у., х, > х. . Действуем аналогично, добавляя вершину и = (х,,у1) и пару ребер: (и., и, ) и (и,, и,). Если точка (х, у) лежит на ребре (и,, и,), то

х=х^ У/■<У<Уi<У^+г^ ^ ах,у е Р*,у1 . (6)

Тип 3. Уj > yi, Xj > xi . Добавим в граф Н вершину и- = (хг, у,) и пару ребер: горизонтальное (и{, и-) и вертикальное (н,, и ■) .

По построению граф Н представляет собой граф-цикл.

Пусть уг = тах( У1, у 2,., у№). Рассмотрим соответствующую вершину \г (если для нескольких вершин у=уг, возьмем вершину с минимальным значением х). Пусть вершине \г инцидентны ребра (у^уг),(уг,у) Поскольку уГ>у-, ребро относится к типу 2. В случае уг=уг-, согласно лемме 1.2, х>х, но в случае равенства мы выбирали в качестве \г вершину с минимальным значением х. Значит, у>ух и ребро (vi,vr) относится к типу 1 или к типу 3. Разберем эти случаи.

Случай 1. Ребро (vi,vr) относится к типу 1 (рис. 2).

Уг (иг>

V; (и) и,. V] (и.) "г

Рис. 2. Варианты расположения ребер, инцидентных вершине уг.

В графе Н получим последовательность ребер (иииг),(иг,иг),(иг,иг1),(ифи]), где и1г=(хг,уг),иг]=(х],уг),у1>у1,хг<хг,у]<уг,х]>хг . (7) Последовательность двух вертикальных ребер (иг>,иг),(иг,иг) заменим одним ребром (иг>,иг). Определим его направление.

ях*, уг (И, ¡г) п ях*, у, (/ ,, ¡,) = 0, поэтому

по лемме 1.1:

хг + Иг < х, V хг > х, + И, V

(8)

уг + ¡г < у- V уг > у- + ¡,. Из (7) получаем хг<х-<х-+И-, у;<уг<уг+/г, следовательно, в выражении (8) второе и третье неравенства не выполняются.

(уг , V-) е Е, поэтому по следствию 1.1:

уг < у- + , то есть в выражении (8) четвертое неравенство тоже не выполняется. Значит, должно выполняться первое неравенство: хг + Иг < х, . (vi, vr) е Е, поэтому по следствию 1.1: х, < х + И .

Получаем xi < хг + Иг < х,. Таким образом, ребро (иг>,иг) будет направлено вниз. Вся фигура, ограниченная графом-циклом Н, располагается в правой полуплоскости относительно ребра (иг>,иг), т. е. цикл Н имеет ориентацию по часовой стрелке.

Случай 2. Ребро относится к типу

3 (рис. 2).

В графе Н получим последовательность ребер (иииг),(иг,иг),(иг,иг1),(ифи]), где и1г=(хг,уг),иг]=(х],уг),уг>у1,хг>хг,у]<уг,х]>хг. (9)

Последовательность двух вертикальных ребер (иг>,иг),(иг,иг) заменим одним ребром (иг>,иг). В соответствии с (9): х;>хг>хг-.

Таким образом, ребро (иг>,иг) будет направлено вниз. Вся фигура, ограниченная графом-циклом Н, располагается в правой полуплоскости относительно ребра (иг>,иг), то есть цикл Н имеет ориентацию по часовой стрелке.

В обоих случаях мы получили, что цикл Н имеет ориентацию по часовой стрелке. Точки самопересечения (если они есть) разбивают цикл Н на несколько отдельных замкнутых частей без самопересечений. Рассмотрим ту часть, которая включает в себя ребро (иг>, иг). По доказанному выше, этот цикл имеет ориентацию по часовой стрелке. Рассмотрим самые левые точки этого цикла и выберем из них самую нижнюю. Пусть это будет точка (х,у). Учитывая выбор точки (х, у) и тот факт, что все ребра цикла строго вертикальны либо горизонтальны, точка (х, у) находится на пересечении горизонтального ребра (и', и") и вертикального ребра (и"',и"") (возможно, в вершинах этих ребер). Учитывая ориентацию цикла (части цикла), ребро (и',и") ориентировано справа налево (цикл расположен выше), а ребро (и'1',и"") - снизу вверх (цикл расположен справа). Анализируя все возможные типы ребер, перечисленные выше, получаем, что ребро (и',и") получается только из

ребра типа 2 и является ребром вида (и-, и,), а ребро (и'1', и"") - из ребра типа 1 и является ребром типа (иЛ, и(). При рассмотрении ребер типа 2 было установлено, что, согласно (6), если точка (х,у) лежит на ребре (и, ,и,),

то аху е Рх* у. . При рассмотрении ребер типа 1 было установлено, что, согласно (5), если точка (х,у) лежит на ребре (иг1, и{), то аху е Рх* . Но тогда получается, что

Р*,у, (И, , /,) п Р*,у (И,, /,) * 0, что возможно

только при !=, .=г. Но тогда ребро (у.у^^гу) относится одновременно и к типу 1, и к типу 2, что невозможно. Получили противоречие.

Доказательство леммы 1 завершено.

Вернемся к доказательству теоремы. Рассмотрим оптимальное покрытие Я*. Согласно доказанной лемме 1, в нем найдется покрывающий прямоугольник Р;%У(И\,/\) такой, что локально-максимальный покрывающий прямоугольник с тем же якорем Риу(И0,/0) попарно не пересекается ни с одним из остальных покрывающих прямоугольников из Я*. Обнулим элементы матрицы А, входящие в РиУ(И0,/0). Получим матрицу А' = (а" ,) :

а. .,. е [1; и -1] и [м + И0; п] V

7 е [1;у-1]и[у + т]

0,. е [м; м + И0 -1] л ! е [у;у + /0 -1].

Обозначим

= ,-И0 • /0,Я'* = Я*\Р„*у(И„А).

я' 1 = |я *\Р*У (И„ А)! = |я 1 -1 = к -1.

Во-вторых,

5 (Я' •) = 5 (Я •) - 5 (Р*У И А)) = 5(Я*) - И • /1 >, - И0 • /0 =, " .

То, что мощность Я ' * минимальна, легко доказать от противного.

Доказательство леммы 2 завершено.

Возвращаемся к доказательству теоремы. Итак, покрытие Я'* является точным оптимальным решением рассматриваемой задачи для пары (А',,' )и |я'*| = к -1. Значит, по

предположению индукции, существует последовательность просмотра элементов

ах у ,ах у ,...,ах у такая, что выполнение

х1, у1 ' х2, у2 ' ' хк-1, ук-1 '

Лемма 2. Покрытие Я'* является точным оптимальным решением рассматриваемой задачи для пары (А',,').

Доказательство. Во-первых, докажем,

*

что Я действительно является покрытием в матрице А'. Рассмотрим произвольный покрывающий прямоугольник Р' е Я'* и произвольный элемент а", е Р'. Поскольку

Р' е Я '* с Я * являлся покрывающим прямоугольником в матрице А,

а.,, = 1. (11)

С другой стороны,

Р' е Я*,Р' * Р„*у(И;,А). Следовательно, по лемме 1, согласно (2): Риу (И0,/0) п Р ' = 0 . То есть, поскольку

алгоритма а дает точное решение задачи для пары (А',,' ). Обозначим это решение Я'.

(10) |Я'| = |я'*| = к -1. Тогда при выполнении алгоритма а для пары (А, ,) с последовательности аи,у , ах1,y1, ах2,y2, ахкукпри первой

итерации на шаге 4 будет выбран прямоугольник Ри У (И0, /0), на шаге 6 будет построена матрица А', а на шаге 7 вычислено , = , - И0 • /0. После первой итерации мы получаем задачу для пары (А',,' ) и последова-

а",, е Р ',

аг',;- е Р„,у (И0, /0) ^. е [1; и -1] и [и + И0; п] V

] е [1;V - 1] и [у + /0;т]

и, в соответствии с (10) и (11): а", = а., = 1.

Таким образом, все элементы прямоугольника Р' в матрице А' равны 1, то есть

*

он является покрывающим, а Я является покрытием.

тельность ах у ,ах у ,...,ах у . Дальнейшее

х1 , у1 х2 , у2 хк-1 , ук-1

выполнение алгоритма даст покрытие Я'. Результатом алгоритма а для пары (А, ,) будет покрытие Я = Риу (И0, /0) и Я', которое является точным решением задачи.

Действительно, Я по построению является покрытием с площадью > , и

\Я\ = |Р„,У (И0, /0) и Я'| = 1 + к -1 = к = |я *|.

Теорема доказана.

Таким образом, действительно существует особь генетического алгоритма, кодирующая точное решение задачи. В силу справедливости условия 2, приспособленность такой особи, очевидно, максимальна.

Заключение

iНе можете найти то, что вам нужно? Попробуйте сервис подбора литературы.

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

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

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

1. Еремеев А.В., Заозерская Л.А., Колоколов А.А. Задача о покрытии множества: сложность, алгоритмы, экспериментальные исследования. Дискретный анализ и исследование операций. Сер. 2. 2000. Т. 7, № 2. С.22-46.

2. Асанов М. О., Баранский В. А., Расин В. В. Дискретная математика: графы, матрои-

ды, алгоритмы. НИЦ "Регулярная и хаотическая динамика": Ижевск, 2001.

3. Данилова Е. Ю., Городилов А. Ю. Сравнение генетических алгоритмов на примере задачи коммивояжера // Вестник Пермского университета. Математика. Механика. Информатика. Пермь: ПГУ, 2009. Вып. 3 (29). С. 49-53.

4. Городилов А. Ю. Двухуровневый генетический алгоритм для решения задач выделения компактных групп объектов // Междисциплинарные исследования: сб. матер. науч.-практ. конф. Перм. гос. нац. исслед. ун-т. Пермь, 2013. Т. 1. С. 190-193.

5. Городилов А.Ю. Двухуровневый генетический алгоритм реконфигурации программируемых логических интегральных схем // Information Technologies and Knowledge. 2014. Vol. 8, № 2. P. 131-140.

A theorem on the convergence of two-level coding genetic algorithm to the exact solution of the FPGA reconfiguration task

A. Yu. Gorodilov

Perm State University, Russia, 614068, Perm, Bukirev st., 15 gora830@yandex.ru

E. Yu. Danilova

Perm State University, Russia, 614068, Perm, Bukirev st., 15 ket-eref@yandex.ru

The article gives a brief statement of the FPGA reconfiguration problem and describes basic and genetic reconfiguration algorithms. The genetic algorithm uses a two-level solution coding and intermediate representation in the form of the complete bipartite graph adjacency matrix. A theorem on the convergence of developed genetic algorithm to the exact solution of the FPGA reconfiguration task is formulated and proved.

Key words: genetic algorithm; FPGA; reconfiguration; convergence; optimization.

i Надоели баннеры? Вы всегда можете отключить рекламу.