Другие журналы
|
научное издание МГТУ им. Н.Э. БауманаНАУКА и ОБРАЗОВАНИЕИздатель ФГБОУ ВПО "МГТУ им. Н.Э. Баумана". Эл № ФС 77 - 48211. ISSN 1994-0408
Исследование канонического метода роя частиц (PSO) для топологий типа ╚клика╩ и ╚кластер╩
# 06, июнь 2009
А.Э. Антух
МГТУ им. Н.Э. Баумана, 105005, Москва,
Введение Оптимизация с использованием роя частиц (Particle Swarm Optimization, PSO) – это метод поиска, который базируется на понятии популяции и моделирует поведение птиц в стае и косяков рыб. Первоначальной целью использования концепции роя частиц была графическая имитация красивого и непредсказуемого движения птиц или рыб в стае с целью обнаружения базовых принципов, благодаря которым птицы летают (рыбы плавают) синхронно и умеют менять направление движения с перегруппировкой в оптимальные формации. С тех пор концепция развилась в простой и перспективный оптимизационный метод. В PSO-методе агентами являются частицы в пространстве параметров задачи оптимизации. В каждый момент времени (на каждой итерации) частицы имеют в этом пространстве некоторое положение и вектор скорости. Для каждого положения частицы вычисляется соответствующее значение целевой функции, и на этой основе по определенным правилам частица меняет свое положение и скорость в пространстве поиска. В основу метода PSO положена социально-психологическая поведенческая модель толпы. Существует несколько разновидностей метода. В каноническом методе роя частиц, предложенном в 1995 году в работе Kennedy, Eberhart [3], на каждой итерации при определении следующего положения частицы учитывается информация о наилучшей частице из числа «соседей» данной частицы, а также информация о данной частице на той итерации, когда этой частице соответствовало наилучшее значение целевой функции.
1. Описание метода Будем рассматривать задачу глобальной безусловной минимизации целевой функции в -мерном арифметическом пространстве : . (1) Множество частиц обозначим , где - количество частиц в рое (размер популяции). В момент времени координаты частицы определяются вектором , а ее скорость - вектором . Начальные координаты и скорости частицы равны , , соответственно. Итерации в каноническом методе PSO выполняются по следующей схеме: ; (2) . (3) Здесь представляет собой -мерный вектор псевдослучайных чисел, равномерно распределенных в интервале ; - символ покомпонентного умножения векторов; - вектор координат частицы с наилучшим (в смысле (1)) значением целевой функции за все время поиска; - вектор координат соседней с данной частицы с наилучшим за время поиска значением целевой функции ; - свободные параметры алгоритма. Пересчет координат частиц по формулам (2), (3) может происходить по синхронной схеме (обновление координат частиц выполняется только после определения текущих скоростей всех частиц) или по асинхронной схеме (расчет новых координат части производится до завершения указанных вычислений). В процессе итераций вектор образует т.н. собственный путь (private guide) частицы , а вектор - локальный путь (local guide) этой частицы. Свободный параметр определяет «инерционные» свойства частиц (при движение частиц, очевидно, замедляется). Рекомендуемое значение параметра равно 0.7298. В процессе оптимизации может быть эффективным постепенное уменьшение коэффициента от 0.9 до 0.4. При этом большие значения параметра обеспечивают широкий обзор пространства поиска, а малые – точную локализацию минимума целевой функции. Рекомендуемые значения свободных параметров равны 1.49618. Второй компонент в формуле (3) называется «когнитивным» компонентом (по социальной аналогии) и формализует тенденцию частицы вернуться в положение с минимальным значением целевой функции. Третий компонент в формуле (3) называется «социальным» компонентом. Компонент отражает влияние на данную частицу ее соседей. Вместо формулы (3) часто используют ее вариант . (4) Коэффициент в этом случае называется ограничивающим фактором (restriction factor), , . Рекомендуемые значения параметров в этом случае равны 2.05, а их оптимальные значения определяются классом целевой функции [3].
2. Топологии соседства частиц Эффективность метода PSO в значительной мере зависит от топологии соседства частиц (population topology, neighbourhood topology, swarm topology, sociometry). Топология соседства определяется неориентированным графом, вершины которого соответствуют частицам роя, а ребра связывают непосредственных соседей. В вычислительной практике чаще всего используются следующие топологии соседства частиц:
В данной работе рассмотрены две топологии: «клика» и кластерная.
В топологии «клика» (полносвязном графе) соседями каждой из частиц , являются остальные частицы. Диаметр полносвязного графа равен единице. Каждая частица может взаимодействовать со всеми другими частицами, и она тяготеет к лучшему решению целого роя. Частица имитирует общее оптимальное решение, поэтому её скорость зависит от информации, получаемой от всех остальных. В данном случае социальным компонентом скорости является наилучшая достигнутая позиция роя (в пространстве решений).
В кластерной топологии граф имеет в качестве узлов клики из узлов. Клики числом объединяются в полносвязный граф, ребра которого связаны с теми узлами в кликах, степени которых равны . Очевидно, что диаметр такого графа равен 3. Соседями каждой из частиц , являются частиц.
Рис. 2. Кластерная топология соседства частиц: Диаметр графа, соответствующего используемой роем топологии соседства частиц, определяет скорость распространения информации в рое. Поэтому в рое с топологией соседства «клика» лучшее значение целевой функции, достигнутое той или иной частицей, сразу становится известным всем остальным частицам роя. В рое с кластерной топологией достигаются меньшие значения скорости распространения информации.
3. Тестовые функции Рассмотрим основные функции, на которых проводилось тестирование данного метода оптимизации для топологий «клика» и кластерной. На рисунках 3а, 4а, 5а и 6а изображены линии уровня и траектория частиц по пути к минимуму, на рисунках 3б, 4б, 5б и 6б – вид функции в трехмерном пространстве. При построении графиков данных функций использовался Matlab 6.5.
1) Эллиптический параболоид (4.1)
2) Функция Розенброка (Rosenbrock)
(4.2)
3) Функция Химмельблау (Himmelblau) (4.3)
4) Функция Растригина (Rastrigin) (4.4)
Ниже рассмотрены результаты исследования эффективности PSO-метода данных топологий для выбранных тестовых функций. Приведены таблицы вычисленных значений оптимизируемой функции при различных топологиях, построены графики сходимости функции по итерациям, а также гистограммы разброса выходных значений. В конце раздела проведен сравнительный анализ топологий на основе полученных результатов. Начальные позиции частиц генерируются случайным образом в диапазоне [-100, 100]DIM.
Таблица 1. Параметры исследования.
4.1. Результаты исследования эффективности для функции эллиптического параболоида
1) Топология «клика»
Вычисленные величины после 100 итераций:
Разброс значений после 100 итераций:
Здесь и далее Δ – ширина интервала при разбиении всех значений на 10 интервалов по значениям.
Рис. 7. Гистограмма достигнутых минимумов целевой функции для топологии «клика»
2) Кластерная топология
Вычисленные значения после 100 итераций:
Разброс значений после 100 итераций:
Рис. 10. Гистограмма достигнутых минимумов целевой функции для кластерной топологии
Для эллиптического параболоида более эффективной оказалась кластерная топология: Σ=5,22E-06, для топологии «клика» Σ=8,14E-06. Разброс значений незначительный (см. Рис. 7, 10)
4.2. Результаты исследования эффективности для функции Розенброка
1) Топология «клика»
Вычисленные величины после 100 итераций:
Разброс значений после 100 итераций:
Рис. 13. Гистограмма достигнутых минимумов целевой функции для топологии «клика»
2) Кластерная топология
Вычисленные значения после 100 итераций:
Разброс значений после 100 итераций:
Рис. 16. Гистограмма достигнутых минимумов целевой функции для кластерной топологии
Для функции Розенброка более эффективной оказалась кластерная топология: Σ=3,011753, для «клики» Σ=12,57033. Разброс значений незначительный (см. Рис. 13, 16)
4.3. Результаты исследования эффективности для функции Химмельблау
1) Топология «клика»
Вычисленные величины после 100 итераций:
Разброс значений после 100 итераций:
Рис. 19. Гистограмма достигнутых минимумов целевой функции для топологии «клика» Рис. 20. Сходимость итераций для топологии «клика» (итерации 1-100)
2) Кластерная топология
Вычисленные значения после 100 итераций:
Разброс значений после 100 итераций:
Рис. 21. Гистограмма достигнутых минимумов целевой функции для кластерной топологии
Рис. 22. Сходимость итераций для кластерной топологии (итерации 1-100)
Для функции Химмельблау более эффективной оказалась топология «клика»: Σ=2,84E-12, для кластерной Σ=9,17E-12. Разброс значений незначительный (см. Рис. 19, 21)
4.4. Результаты исследования эффективности для функции Растригина
1) Топология «клика»
Вычисленные величины после 100 итераций:
Разброс значений после 100 итераций:
Рис. 23. Гистограмма достигнутых минимумов целевой функции для топологии «клика»
2) Кластерная топология
Вычисленные значения после 100 итераций:
Разброс значений после 100 итераций:
Рис. 26. Гистограмма достигнутых минимумов целевой функции для кластерной топологии
Для функции Растригина более эффективной оказалась кластерная топология: Σ=1,961365, для «клики» Σ=2,751632. В данном случае разброс значений существенный (см. Рис. 23, 26), для «клики» дисперсия вносит основной вклад в общую сумму (D=1,45901)
4.5. Анализ результатов Сравнение оптимизационных свойств метода PSO проводилось по сумме матожидания и дисперсии для достигнутого значения минимума заданной функции. Для эллиптического параболоида и функции Химмельблау обе топологии обеспечивают очень хорошую сходимость (порядка 10-6 и 10-12 соответственно) и малый разброс значений (см. Рис. 7, 10, 19, 21). Стоит отметить, что для функции Химмельблау оптимизация проводилось при размерности пространства DIM = 2 (см. формулу 4.3), что и явилось причиной столь хорошей сходимости (Σ=2,8410-12) Для канонического метода PSO функции Розенброка и Растригина слишком сложны, и для обеих топологий при заданных начальных условиях достигается плохая сходимость (порядка 103), поэтому для данных функций была принята размерность пространства DIM = 3 без изменения других параметров. Для функции Розенброка более эффективной оказалась кластерная топология (Σ=3,011753), в то время как для клики Σ=12,57033. Это наглядно показано на графиках сходимости итераций (см. Рис. 15, 18). Наконец, для функции Растригина также лучше оказалась кластерная топология (Σ=1,961365), в то время как для клики Σ=2,751632. Видно, что в данном случае разброс значений уже существенный в обоих случаях (см. Рис. 23, 26). При использовании топологии «клика» функция чаще попадает в локальный минимум, один из которых изображен на соответствующем графике сходимости для итераций 50-100 (см. Рис. 25)
Заключение На основании результатов можно сделать выводы:
Список литературы 1. Субботин С.А., Олейник Ан.А., Олейник Ал.А. (2006) PSO-метод. //«Интеллектуальные мультиагентные методы (Swarm Intelligence)» – Ч.3 – С.55-70. 2. Карпенко А.П., Селиверстов Е.Ю. (2008) «Обзор методов роя частиц (PSO) для задачи глобальной оптимизации» // Наука и образование: электронное научно-техническое издание, www.technomag.edu.ru, март, 2009. 3. J. Kennedy, R. Eberhart (1995) Particle swarm optimization. // Proceedings of IEEE International conference on Neural Networks. – 1995, pp. 1942 - 1948. 4. Marco Doringo et al. (2008) Particle swarm optimization. // Scholarpedia, 3(11):1486. 5. J. Kennedy. Stereotyping: improving particle swarm performance with cluster analysis. // Proceedings of the 2000 Congress on Evolutionary Computation. - 2002, v.2, pp. 1507—1512. 6. R. Mendes, Member, IEEE, J. Kennedy and J. Neves. The Fully Informed Particle Swarm: Simpler, Maybe Better. // IEEE Transactions of Evolutionary Computation, vol. 1, no. 1, January 2025. 7. C. Zhang, H. Shao, Y. Li. Particle swarm optimization for evolving artificial network. //Proceedings of IEEE International Conference on System, Man and Cybernetics, 2000, pp. 2487-2490. Публикации с ключевыми словами: глобальная оптимизация, метод роя частиц, метод PSO Публикации со словами: глобальная оптимизация, метод роя частиц, метод PSO Смотри также: Тематические рубрики: Поделиться:
|
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|