Алгоритм муравья для решения задачи коммивояжера
Применимость алгоритма муравьиной колонии к задаче коммивояжера. Использование системы кооперирующихся интеллектуальных агентов, названных муравьями. Понятие "фермента" на гранях транспортной сети, оставляемого в процессе поиска оптимального решения.
Рубрика | Программирование, компьютеры и кибернетика |
Вид | статья |
Язык | русский |
Дата добавления | 23.10.2010 |
Размер файла | 57,2 K |
Отправить свою хорошую работу в базу знаний просто. Используйте форму, расположенную ниже
Студенты, аспиранты, молодые ученые, использующие базу знаний в своей учебе и работе, будут вам очень благодарны.
Сумський государственный университет
Алгоритм муравья для решения задачи коммивояжера
Б.О. Кузиков, студ.;
С.П. Шаповалов, доц.
Аннотация
Данная статья рассматривает применимость алгоритма муравьиной колонии (ACS) к задаче коммивояжера (TSP). В данном алгоритме используется система кооперирующихся интеллектуальных агентов, названных муравьями, для нахождения решений указанной задачи. Для кооперации агенты используют "фермент", оставляемый на гранях транспортной сети, в процессе поиска оптимального решения. Алгоритм показывает хорошую производительность, как для симметричной, так и для асимметричной задачи коммивояжера.
Введение
Эффективность созданных человечеством алгоритмов в главном своем предначертании проверяется практической их реализацией, а решение задач прикладного характера сопровождается детализацией используемых при этом алгоритмов [1].
Алгоритмы муравья [2,3], основанные на применении нескольких агентов, позволяют решать самые разнообразные проблемы статики и динамики. Предложим детализацию этого алгоритма к проблеме маршрутизации в сетях, рассмотрев задачу коммивояжера.
Общая задача коммивояжера (traveling salesmen problem, TSP) [4,5] состоит в следующем: используя заданную систему транспортных соединений (дорог и т.п.) между пунктами (городами, фирмами и т.п.) в конкретной зоне обслуживания, посетить все пункты в такой последовательности, чтобы пройденный путь был минимальным [1,5]. В терминах теории графов задачу можно сформулировать следующим образом: в конечном взвешенном графе G= (V,E) найти гамильтонов цикл наименьшего веса. То есть для каждого ребра известна его стоимость . Необходимо построить цикл А, проходящий по всем вершинам ровно один раз, причем . В случае задача называется асимметричной (ATSP). Симметрия и выполнение неравенства треугольника в значительной мере облегчают решение задачи, однако они не всегда применимы.
Общая задача коммивояжера является NP-полной, то есть не разрешимой за полиномиальное время [1]. В случае небольшой дорожной сети она разрешима методом перебора с использованием различных вариантов его сокращения (например, метод ветвей и границ). Однако в большинстве практических приложений задача имеет большую размерность, и потому переборные алгоритмы слабо применимы.
Принцип алгоритмов муравья (Ant algorithms), или оптимизации по принципу муравьиной колонии, был предложен Марко Доринго (Marco Doringo) [2,3,4]. Идея алгоритмов состоит в том, что хотя муравьи слепы, они умеют ориентироваться на сложной местности, находя оптимальный путь между муравейником и внешними точками. При этом в качестве маркера используется фермент, который тем концентрированней, чем больше муравьев прошли по данному пути.
Проиллюстрируем вышесказанное.
Обозначим муравья, идущего по верхней грани, - первым, а по нижней - вторым. Пусть верхняя грань вдвое длиннее нижней. Первоначально путь от муравейника к цели неизвестен. К тому времени как второй муравей достигнет цели, первый пройдет только пол пути. На пути в муравейник второй муравей пойдет по нижней грани, так как только она помечена ферментом. К тому моменту как первый муравей достигнет цели, верхняя грань будет помечена ферментом 1 раз, а нижняя уже 2. А значит, муравей выберет нижнюю, более короткую грань.
Рассмотрим термины данного алгоритма применительно к задаче коммивояжера.
Путь муравья - данная нам по условию задачи транспортная сеть. Исходный граф двунаправлен, значит, муравей может путешествовать вдоль грани в любом направлении.
Муравей - программный агент, который является членом большой колонии, используемой при решении некоторой задачи. Для того чтобы удовлетворить свойства гамильтонова цикла, каждый муравей поддерживает список табу - список узлов, которые он уже посетил. Узлы в этом списке располагаются в порядке их посещения - позже этот список будет использован для определения длины пути. Фермент муравьи "оставляют" на пройденных ребрах графа.
Популяция. Перед началом движения муравьев случайным образом распределяют по узлам графа. Этим самым повышается вероятность быстрого нахождения оптимального маршрута. Оптимизация количества муравьев в популяции будет рассмотрена ниже, наряду со значениями остальных параметров. Движение муравья (state transition rule) Направление движения муравья задается вероятностным уравнением. Формула 1 устанавливает вероятность, с которой k-й муравей системы, находящийся в городе r, отправится в город s:
(1)
В уравнении (1) s понимается как случайная величина. Для повышения эффективности при дальнейшем развитии алгоритма для выбора пункта назначения была введена формула (2):
(2)
где S - результат, полученный при использовании формулы (1);
- интенсивность фермента на грани между узлами i и j;
- функция, обратная длине соответствующей грани;
Jk (r) - множество узлов, еще не посещенных муравьем k, находящимся в узле r;
- параметр, контролирующий относительный приоритет фермента на пути над видимостью следующего города;
q - случайное число в диапазоне [0...1], выбираемое каждый раз при пересчете формулы;
0<q0<1- параметр, показывает относительную важность поиска новых маршрутов, над использованием старых.
Путешествие муравья. Заметим, что при движении циклы невозможны благодаря списку табу. При переходе муравья от одного узла к другому уровень фермента изменяется по формуле (3):
, (3)
где 0<р<1 - параметр. В зависимости от применяемых эвристик величина формулы (3) может находиться по следующим формулам: (I) , (II) или (III) . В первом случае алгоритм носит название Ant-Q, второй - используется для повышения производительности и называется ACS. Первый и второй алгоритмы дают аналогичные результаты. Третий случай может быть использован в случае симметричной задачи коммивояжера, хотя и резко снижает производительность алгоритма и потому редко используется на практике [2,4].
Испарение фермента (global updating rule). После завершения всеми муравьями их путешествий выделяется наиболее оптимальный путь. Для повышения эффективности поиска пути на следующей итерации ко всем граням применяется формула (4):
, (4)
где
Lgb - длина лучшего маршрута, найденного на данный момент, 0<б<1 - параметр. Вместо Lgb может быть использована длина лучшего маршрута текущей итерации. Согласно практическим наблюдениям разница между этими двумя вариантами незначительна.
Повторный запуск. После того как путь всех муравьев завершен, а количество фермента на гранях обновлено согласно (4), происходит повторный запуск алгоритма. При повторном запуске необходимо очистить список табу и длину пути каждого из муравьев. Повторный запуск осуществляется оговоренное число раз или до момента, когда на протяжении нескольких запусков не было отмечено изменений.
В целом алгоритм применительно к задаче коммивояжера можно сформулировать следующим образом:
Инициализация переменных
Loop /* итерация поиска решения*/
Разметить всех муравьев
Loop /* шаги поиска*/
Для каждого муравья выбрать следующий узел, используя (2)
переместить муравья
обновить уровень фермента, используя (3)
Until все муравьи закончат построение пути
Применить испарение фермента ко всей сети, используя (4)
Until выполнено нужное число итераций
Между алгоритмами муравья и генетическими алгоритмами можно провести некую параллель. Аналог наследственной информации о лучшем решении в данном случае сохраняется в виде фермента на гранях. Величина q вносит элемент случайности в действие популяции.
Отдельно стоит оговорить подбор параметров, так как они существенно влияют на скорость нахождения качественного решения. Подчеркнем также, что значение параметров слабо зависит от размерности задачи.
Параметр определяет важность выбора более короткой грани. Кроме того, этот параметр позволяет проследить ценность функции з для нахождения эффективных решений за приемлемое время. На практике часто используется = 2. Параметр q0 отвечает за нахождение новых путей, б и - за испарение фермента. Для задач небольшой размерности (n>100) используют значения q0=0,9, б==0,1. Для определения значения ф0 используют эвристику , где Lnn - оценка длины маршрута; n - количество узлов. Отдельным вопросом является также численность популяции. Зависимость величины найденного решения от количества муравьев при фиксированном числе итераций можно представить графиком, приведенном на рис.2.
Рисунок 2 - Зависимость длины найденного пути от количества муравьев
График был получен при тестировании алгоритма по следующей методике. Исходные данные: набор из 50, случайно сгенерированных городов, расстояние между которыми не превышает 500. Полученная таблица инцидентности является симметричной. Алгоритм в каждом случае производил 20 итераций поиска. Результат был усреднен между 50 запусками с одинаковым количеством муравьев.
Из графика видно, что с увеличением количества муравьев растет и качество решения. Однако не следует забывать, что время работы алгоритма линейно зависит от числа агентов. Практические исследования показывают, что оптимальное соотношение качества решения и времени работы алгоритм дает при соотношении , где m - численность муравьев; n - количество узлов [2].
Вывод
В работе рассмотрены алгоритм колонии муравьев и его применение к задаче коммивояжера. Алгоритм имеет хорошую производительность как в случае симметричной, так и асимметричной задачи коммивояжера. Важно также подчеркнуть возможность распараллеливания его работы между различными вычислительными ресурсами [3]. В работе рассмотрена оптимизация алгоритма с помощью эвристики изменения коэффициента .
Для иллюстрации качества работы алгоритма проведено сравнение результатов работы с результатами, полученными при помощи алгоритма MST-Prim. В среднем за аналогичное время были получены результаты, на 24% качественнее.
Summary
This paper content common arrangement of traveling salesman problem (TSP), introduces ant colony system (ACS) and distributed algorithm that is applied to the TSP. In ACS, a set of cooperating agents called ants cooperate to find good solutions to TSPs. Ants cooperate using an indirect form of communication mediated by pheromone they deposit on the edges of the TSP graph while building solutions. The results show that ACS outperforms other nature-inspired algorithms such as simulated annealing and evolutionary computation. It's appear for some of the best performing algorithms for symmetric and asymmetric TSPs.
Список литературы
1. Кормен Т., Лейзерсон Ч., Ривест Р. Алгоритмы: построение и анализ. - М.: МЦНМО, 2000. - 960 с.: ил.
2. Dorigo M., Gambardella L. M. Ant Colony System: A Cooperative Learning Approach to the Traveling Salesman Problem. IEEE Transactions on Evolutionary Computation, 1997 1 (1): 53-66.
3. Dorigo M., G. Di Caro, Gambardella L. M. Ant Algorithms for Discrete Optimization. Artificial Life, 1999 5 (2): 137-172.
4. Джонс М.Т. Программирование искусственного интеллекта. - М.: ДМК Пресс, 2004. - 312 с.: ил.
5. Кутковецкий В.Я. Дослідження операцій. - К.: Професіонал, 2004.
Подобные документы
Моделирование передвижения муравьев. Метод ветвей и границ, ближайшего соседа. Ограничения, накладываемые на агента в стандартной постановке задачи коммивояжера. Использование графа видимости в алгоритме муравья. Структура данных алгоритма муравья.
дипломная работа [1,7 M], добавлен 07.02.2013Оптимизация решения задачи с помощью алгоритма отжига. Анализ теории оптимизации как целевой функции. Метод градиентного спуска. Переменные и описание алгоритма отжига. Представление задачи коммивояжера через граф. Сведение задачи к переменным и решение.
курсовая работа [784,0 K], добавлен 21.05.2015Математическая модель решения задачи коммивояжера. Поиск кратчайшего замкнутого пути обхода нескольких городов и возвращения в исходную точку. Описание программы и результатов ее тестирования. Основная форма программы после вывода конечных данных.
курсовая работа [603,3 K], добавлен 21.10.2012Сравнение результатов работы генетического алгоритма по решению "несимметричной незамкнутой задачи коммивояжера" с результатами работы алгоритма динамического программирования по параметрам - время работы, точность результата и объем используемой памяти.
курсовая работа [65,3 K], добавлен 16.04.2014Этапы работы генетического алгоритма, область его применения. Структура данных, генерация первоначальной популяции. Алгоритм кроссинговера - поиск локальных оптимумов. Селекция особей в популяции. Техническое описание программы и руководство пользователя.
реферат [1014,2 K], добавлен 14.01.2016Создание и реализация алгоритма решения транспортной задачи методом наименьших стоимостей. Схема алгоритма основной программы. Основные шаги алгоритма решения транспортной задачи. Инструкция по эксплуатации программы и обзор результатов ее выполнения.
курсовая работа [2,0 M], добавлен 12.02.2013Описание генетических алгоритмов. Применение генетического алгоритма для решения задачи коммивояжера. Постановка задачи безусловной оптимизации. Изучение распространения генетических алгоритмов на модель с несколькими взаимодействующими популяциями.
дипломная работа [979,1 K], добавлен 30.05.2015Описание алгоритма решения транспортной задачи по планированию перевозки зерна. Ход решения задачи вручную, в программе TORA методом наименьшего элемента, с помощью MS Excel. Разработка программы для решения задачи в общем виде средствами Delphi.
курсовая работа [2,5 M], добавлен 22.11.2012Особенности решения транспортной задачи распределительным методом и анализ результатов. Построение математической модели, алгоритма. Создание программы для решения транспортной задачи распределительным методом в программной среде Borland Delphi 7.
курсовая работа [1000,7 K], добавлен 23.06.2012Основные этапы решения транспортной задачи, использование метода потенциалов. Алгоритм решения методом аппроксимации Фогеля. Процедура построения цикла. Планирование перевозок из конечного числа пунктов отправления в конечное число пунктов назначения.
контрольная работа [32,6 K], добавлен 26.04.2011