Студопедия Главная Случайная страница Обратная связь

Разделы: Автомобили Астрономия Биология География Дом и сад Другие языки Другое Информатика История Культура Литература Логика Математика Медицина Металлургия Механика Образование Охрана труда Педагогика Политика Право Психология Религия Риторика Социология Спорт Строительство Технология Туризм Физика Философия Финансы Химия Черчение Экология Экономика Электроника

Решение оптимизационных задач с помощью генетических алгоритмов


1. Андрейчиков А.В., Андрейчикова О.Н. Интеллектуальные информационные системы. - М: Финансы и статистика, 2004.

2. Назаров А.В., Лоскутов А.И. Нейросетевые алгоритмы прогнозирования и оптимизации систем – СПб.: Наука и Техника, 2003. – 384 с.: ил.

3. Рутковская Д., Рутковский Л. Нейронные сети, генетические алгоритмы и нечеткие системы: Пер. с. польск. И. Д. Рудинского. – М.: Горячая линия – Телеком, 2004.-452 с.

4. Усков А. А. Интеллектуальные технологии управления. Искусственные нейронные сети и нечеткая логика. - М.: Горячая линия-Телеком, 2004.- 143 с.

 

 

Лабораторная работа № 4

Решение оптимизационных задач с помощью генетических алгоритмов

 

Цель работы

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

 

1. Краткие теоретические сведения

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

При описании ГА используются определения заимствованные из генетики:

Популяция – конечное множество особей (индивидуумов), каждый индивидуум - эквивалент решения задачи.

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

Хромосомы – упорядоченные последовательности генов.

Ген – атомарный элемент хромосомы, в ГА представлен в виде двоичных цифр (единица и нуль).

Генотип (структура) – набор хромосом данной особи.

Фенотип – набор значений, соответствующих данному генотипу.

Аллель – значение конкретного гена.

Локус (позиция) – место размещения данного гена в хромосоме. Множество позиций генов - Локи.

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

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

Классический генетический алгоритм состоит из следующих этапов:

1) Инициализация – формирование исходной популяции, заключается в случайном выборе заданного количества хромосом (особей), представляемых в виде последовательности двоичных чисел.

2) Оценка приспособленности хромосом. Заключается в расчете функции приспособленности для каждой хромосомы популяции.

3) Проверка условия остановки алгоритма. Определяются условия завершения выполнения алгоритма. Алгоритм может быть остановлен по истечении определенного времени выполнения, либо после завершения заданного количества итераций. Остановка может произойти также в том случае, если работа алгоритма не приводит к улучшению уже достигнутого результата.

4) Селекция хромосом – заключается в выборе тех хромосом, которые будут участвовать в создании потомков для следующей популяции.

Среди методов селекции наиболее популярным является метод Рулетки. Метод Рулетки позволяет отбирать особей с помощью "запусков" рулетки. Колесо рулетки содержит по одному сектору для каждого члена популяции. В целом вся окружность колеса рулетки соответствует интервалу [0, 100]. Каждой хромосоме, обозначаемой для i=1,2,…, N (где N обозначает численность популяции) соответствует сектор колеса , выраженный в процентах согласно формулам (4.1) и (4.2)

(4.1)

(4.2)

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

Существуют и другие методы селекции, например, турнирный отбор, элитный отбор и т.д.

5) Применение генетических операторов. Этот этап позволяет сформировать следующую популяцию потомков от уже созданной родительской популяции. Различают два генетических оператора: оператор скрещивания и оператор мутации.

Скрещивание осуществляется следующим образом:

1. из родительской популяции случайным способом выбираются хромосомы и объединяются в пары.

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

Оператор мутации с вероятностью изменяет значение гена на противоположное (с 0 на 1 или обратно на позиции m).

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

6) Выбор наилучшей хромосомы. Лучшей считается хромосома с наилучшим значением функции приспособленности.

 

2. Описание программы Mendel

Программа Mendel предназначена для решения задач оптимизации. Реализует в себе диплоидную версию генетического алгоритма и позволяет работать с произвольными пользовательскими задачами оптимизации. Целевая функция оптимизационной задачи и ее параметры описывается во внешней dll-библиотеке задачи оптимизации.

В общем случае для решения задачи с помощью программы Mendel требуется:

1) Создать задачу оптимизации с помощью мастера Новая задача, указав dll-библиотеку задачи.

2) Задать параметры генетического алгоритма (число особей в популяции, критерии останова работы алгоритма, параметры процедур скрещивания, мутации, отбора и т.д.)

3) Запустить работу генетического алгоритма.

Информацию о результатах поиска можно сохранить в виде отчета

Рассмотрим работу с программой Mendel на следующих примерах:

Пример 1. Найти минимум функции

.

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

Рис. 1. – График функции

 

Для решения задачи необходимо проделать следующие шаги:

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

Рис. 2 – Выбор библиотеки задачи оптимизации

 

2) Далее зададим количество особей в популяции и способ их формирования (например, случайным образом) (рис. 3).

Рис. 3 – Задание параметров популяции

3) Следующее окно программы (рис. 4) позволяет управлять работой алгоритма и содержит в себе главное меню, панель инструментов, панель Поиск, переключатель показа/скрытия панели Поиск, панель Статистика, переключатель показа/скрытия панели Статистика, строку состояния.

Рис. 4

 

Главное меню содержит следующие пункты:

1) Меню Задача позволяет создавать и управлять файлами задач и шаблонов задач, содержит следующие команды:

Новая задача – запуск мастера создания новой задачи;

Новая задача по шаблону – открывает шаблон задачи и запускает мастер Новая задача с параметрами из шаблона;

Открыть задачу – открывает задачу или ее резервную копию;

Последние задачи – позволяет открыть задачу из списка последних задач;

Сохранить задачу - сохраняет текущую задачу;

Сохранить задачу как – сохраняет задачу под новым именем;

Сохранить как шаблон – сохраняет текущую задачу как шаблон в виде файла с расширением.m4p.

2) Меню Правка позволяет управлять отдельными особями в популяции

Добавить особи (Удалить особи) – позволяет редактировать число особей в популяции;

Пересчитать популяцию – пересчет приспособленности всех особей популяции.

3) Меню Работа позволяет управлять процессом поиска решения задачи и экспортировать результаты работы

Запустить – запуск алгоритма;

Остановить – останавливает работу алгоритма;

Отчет – создает отчет о процессе поиска и лучшем решении задачи в виде файла с расширением.rep;

Выполнить – запускает определенное пользователем приложение;

4) Меню Параметры позволяет произвести общую и точную настройку параметров программы

Генетический алгоритм – открывает окно с параметрами алгоритма;

Условие окончания – позволяет выбрать критерий останова алгоритма;

Меню пользователя – позволяет произвести настройку меню пользователя;

Настройка – позволяет задать настройки пользователя.

 

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

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

Область поиска – отображает положение особей популяции текущей эпохи.

 

Панель Статистика содержит закладки:

Задача – отображает сведения о задаче, статистические данные о процессе поиска решения и характеристики популяции;

Решение – отображает текущее решение задачи;

ГА – отображает статистические данные о работе генетического алгоритма.

 

Для рассматриваемого нами примера, после запуска алгоритма при следующих параметрах: число особей - 200, останов после достижения 1000 эпохи, были получены следующие результаты (рис. 6).

Рис. 6 – Результат работы генетического алгоритма

 

Пример 2. Рассмотрим пример создания библиотеки dll для решения пользовательской задачи нахождения минимума функции .

Напомним, что DLL (Dynamic Link Library) - это один или несколько логически законченных фрагментов кода, сохраненных в файле с расширением.dll. Этот код может быть запущен на выполнение в процессе функционирования какой-либо другой программы, как в случае с программой Mendel (такие приложения называются вызывающими по отношению к библиотеке), но сама dll-библиотека не является исполняемым файлом.

Общая структура такой библиотеки реализованной с помощью среды Delphi выглядит следующим образом:

library test; varEpoche: longint;RecalcNow: boolean; procedure InitTask(var TaskName: PChar; var MinimizationTask: boolean; var TaskDim: integer; var pMin,pMax,pMap,pEp,pRcN: pointer);beginTaskName:= название задачи;MinimizationTask:= тип задачи минимизации;TaskDim:= размерность задачи;pMin:= указатель на массив нижних пределов области поиска;pMax:= указатель на массив верхних пределов области поиска;pMap:= указатель на массив, описывающий карту хромосомы;pEp:= Addr(Epoche);RecalcNow:= false;pRcN:= Addr(RecalcNow);end; function FitnessFunction(parameters: pointer; var condition: boolean): double;begincondition:= выполнение условия при параметрах parameters;result:= целевая функция от параметров parameters;end;function GetKnownParameters(index: integer; parameters: pointer): boolean;beginparameters:= вектор координат известного решения номер index;result:= было ли присвоено известное значение parameters;end; EXPORTSFitnessFunction,InitTask,GetKnownParameters; BEGINEND.

 

В данной лабораторной работе будет рассмотрен способ создания dll-библиотеки с помощью среды Lazarus.

В самом начале работы необходимо запустить среду Lazarus и выполнить команду Создать меню Файл. В открывшемся окне(рис. 7) необходимо выбрать Library, после чего переходим к редактору исходного кода библиотеки.

Рис. 7 – Создание библиотеки

 

В редакторе исходного кода запишем:

library primer2;

type

m = double;

 

const

min: m=-500;

max: m=500;

map: m=16;

var

Epoche: longint;

RecalcNow: boolean;

 

procedure InitTask(var TaskName: PChar; var MinimizationTask: boolean;

var TaskDim: integer; var pMin,pMax,pMap,pEp,pRcN: pointer);

begin

TaskName:= 'primer2';

MinimizationTask:= true; {true-задача на поиск минимума, false - если поиск максимума}

TaskDim:= 1;{размерность задачи}

pMin:= addr(min);{указатель на массив нижних пределов области поиска}

pMax:= addr(max);{указатель на массив верхних пределов области поиска}

pMap:= addr(map);{указатель на массив, описывающий карту хромосомы}

pEp:= Addr(Epoche);

RecalcNow:= false; {нужно ли пересчитать популяцию}

pRcN:= Addr(RecalcNow);

end;

 

function FitnessFunction(parameters: pointer; var condition: boolean): double;

var

p:^m;

begin

p:= parameters;

condition:= true;{выполнение условия при параметрах parameters}

result:= p^*p^-4*p^+3;{целевая функция от параметров parameters}

end;

function GetKnownParameters(index: integer; parameters: pointer): boolean;

var

i:integer;

p:^m;

begin

p:=parameters;{вектор координат известного решения номер index}

result:=false;

if index<=70 then

begin

p^:=i;

result:=true;

end;

end;

 

EXPORTS

FitnessFunction,

InitTask,

GetKnownParameters;

 

BEGIN

END.

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

 




<== предыдущая лекция | следующая лекция ==>
Обучение сети | Возможности системы SCILAB

Дата добавления: 2015-10-19; просмотров: 1982. Нарушение авторских прав; Мы поможем в написании вашей работы!




Аальтернативная стоимость. Кривая производственных возможностей В экономике Буридании есть 100 ед. труда с производительностью 4 м ткани или 2 кг мяса...


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


Расчетные и графические задания Равновесный объем - это объем, определяемый равенством спроса и предложения...


Кардиналистский и ординалистский подходы Кардиналистский (количественный подход) к анализу полезности основан на представлении о возможности измерения различных благ в условных единицах полезности...

Уравнение волны. Уравнение плоской гармонической волны. Волновое уравнение. Уравнение сферической волны Уравнением упругой волны называют функцию , которая определяет смещение любой частицы среды с координатами относительно своего положения равновесия в произвольный момент времени t...

Медицинская документация родильного дома Учетные формы родильного дома № 111/у Индивидуальная карта беременной и родильницы № 113/у Обменная карта родильного дома...

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

ТЕХНИКА ПОСЕВА, МЕТОДЫ ВЫДЕЛЕНИЯ ЧИСТЫХ КУЛЬТУР И КУЛЬТУРАЛЬНЫЕ СВОЙСТВА МИКРООРГАНИЗМОВ. ОПРЕДЕЛЕНИЕ КОЛИЧЕСТВА БАКТЕРИЙ Цель занятия. Освоить технику посева микроорганизмов на плотные и жидкие питательные среды и методы выделения чис­тых бактериальных культур. Ознакомить студентов с основными культуральными характеристиками микроорганизмов и методами определения...

САНИТАРНО-МИКРОБИОЛОГИЧЕСКОЕ ИССЛЕДОВАНИЕ ВОДЫ, ВОЗДУХА И ПОЧВЫ Цель занятия.Ознакомить студентов с основными методами и показателями...

Меры безопасности при обращении с оружием и боеприпасами 64. Получение (сдача) оружия и боеприпасов для проведения стрельб осуществляется в установленном порядке[1]. 65. Безопасность при проведении стрельб обеспечивается...

Studopedia.info - Студопедия - 2014-2025 год . (0.012 сек.) русская версия | украинская версия