ПРИБЛИЖЕННЫЕ АЛГОРИТМЫ. Задачи Запишем оптимизационную задачу в виде Например, булеву задачу о ранце можно переписать, введя функции и положив k = b.

Презентация:



Advertisements
Похожие презентации
Основные понятия теории NP-полноты P NP?. Задачи распознавания свойств Класс задач распознавания свойств (ЗРС) – множество проблем, решением которых является.
Advertisements

Динамическое программирование (Dynamic Programming)
Паросочетания и задача о назначениях. Определения Задан граф G = (V, E). Подмн. ребер M E является паросочетанием в G, если v V инцидентно 1 ребра из.
ПОТОКИ В СЕТЯХ. Определения Сеть - связный ориентированный граф G = (V, A) без петель и мультидуг, с 1 источником s V и 1 стоком t V. (Запретим одновременное.
Введение в теорию сетевого планированияВведение в теорию сетевого планирования.
Методы неявного перебора. Рассмотрим общую постановку задачи дискретной оптимизации где n-мерный вектор x конечному мн. доп. решений D. Постановка задачи.
Приближенные схемы Задачи теории расписаний. Полиномиальная приближенная схема (PTAS) Семейство приближенных алгоритмов для задачи Π, {A ε } ε называется.
Элементы теории матричных игр. Определения процесс принятия решений в конфликтных ситуациях… игры 2 (парные) и n 3 лиц. участники игры - игроки. Игра.
1 Приближенные алгоритмы Комбинаторные алгоритмы.
Приближенные схемы Задачи теории расписаний. Полиномиальная приближенная схема (PTAS) Семейство приближенных алгоритмов для задачи Π, {A ε } ε называется.
1 Комбинаторные алгоритмы Локальный поиск. 2 Простейшая задача o размещениях Дано: Полный граф G = (F D, E), стоимости вершин f: F Q + и ребер c: E Q.
Линейное программирование Задача о покрытии. Задача «Покрытие» Дано: Совокупность U из n элементов, и набор подмножеств U, Ω = {S 1,…, S k }, и веса(стоимости)
Линейное программирование Задача теории расписаний.
ГЕНЕТИЧЕСКИЕ АЛГОРИТМЫ Область применения 1.Нахождение экстремумов функций 2. Решение задач размещения ресурсов 3. Решение задач экономического планирования.
Раскраски графов Раскраска вершин Пусть Г (V,E,Ф) – граф, раскраска вершин Г в n цветов – отображение f : V {1,2,…,n } Правильная раскраска вершин графа.
МЕТОДЫ ЭКСПЕРИМЕНТАЛЬНОЙ ОПТИМИЗАЦИИ. Метод деления отрезка пополам Метод позволяет исключать на каждой итерации в точности половину интервала. Иногда.
M-чередующаяся декомпозиция Лекция 10. Нечетная декомпозиция Теорема 9.7 (Lovász [1972] ) Граф является фактор-критическим тогда и только тогда, когда.
Остовные деревья Лекция 4. Задача «Минимальное остовное дерево» Дано: Граф G, веса c: E(G) R. Найти остовное дерево в G наименьшего веса или определить,
МЕТОДЫ ОПТИМИЗАЦИИ § 1. Основные понятия. Под оптимизацией понимают процесс выбора наилучшего варианта из всех возможных В процессе решения задачи оптимизации.
Л АБОРАТОРНАЯ РАБОТА 6 Тема: Численные методы решения задачи Коши для обыкновенных дифференциальных уравнений.
Транксрипт:

ПРИБЛИЖЕННЫЕ АЛГОРИТМЫ

Задачи Запишем оптимизационную задачу в виде Например, булеву задачу о ранце можно переписать, введя функции и положив k = b. Предположим v(S {j}) v(S) 0

Жадный алгоритм Жадный алгоритм (greedy algorithm) состоит из итераций, общее число кот. L. На каж. итерации t по текущему решению S t строится новое решение. Предположим, что является недоп. и положим c( ) = +. Шаг 1. Положить начальное решение S 0 = и t = 1. Шаг 3. Если реш. S t-1 явл. доп., а зн. ц.ф. не уменьшилось (т.е. c(S t- 1 {j t }) – c(S t-1 ) 0), то положить S G = S t-1 и остановить алг. Шаг 4. Положить S t = S t-1 {j t }. Если решение S t доп., а зн. ц.ф. не уменьшилось, или t=L, то положить S G = S t и остановить алг. Шаг 5. Если t=L, и не найдено ни 1 доп. реш., то остановить алг. Шаг 6. Положить t=t+1 и перейти на шаг 2. Шаг 2. Найти

Пример З. размещения: n=|I|=4, m=|J|=6, c=(21,16,11,24) Шаг 1. S 0 =, t=1 (S 0 недоп. мн. c(S 0 ) = + ). Шаг 2. c(1)= 63, c(2)= 66, c(3)= 31, c(4)= 64 j t = 3. Шаг 4. S 1 =S 0 {3}={3} – доп. мн. Зн. c(S 1 )= 31 уменьш. Шаг 6. t=t+1=2 и – на шаг 2. Шаг 2. c(1,3) – c(3)=18, c(2,3) – c(3)=11, c(3,4) – c(3)=11. Шаг 3. Функционал не уменьшается полагаем S G =S 1 ={3} – решение, построенное жадным алг. Стоп. Жадный алг. должен быть адаптирован… Для КМ «иди в ближайший город, где еще не был»…

Локальный поиск Для описания алг. лок. поиска (local search) перепишем з. в виде: где g(S) 0 назовем мерой недопустимости множества S. Так v(S) k переписывается: g(S)=(k – v(S)) +, где a + = max{0,a}. Для алг. лок. поиска необходимо определить: решение S N, окрестность решения Q(S) функцию цели f(S). Функция f(S) может = c(S), если S доп., или + в прот. сл. Или можно положить f(S)=c(S)+ag(S), при нек. a > 0. Пусть S нек. начальное решение (не обязательно доп.). Алг. лок. поиска состоит из повторения однотипных итераций.

Локальный поиск Итерация. Найти мн. S Q(S) : f(S ) < f(S). Если такого мн. нет, то алг. останавливается, решение S H = S явл. лок. оптимумом. Иначе, положить S = S и повторить итерацию. Выбор подходящей окрестности реш. зависит от решаемой задачи. 1 из простых способов опред. окрестности – это добавление или удаление 1 элемента. Такая окрестность содержит O(n) элементов. Другой способ опред. окрестности, применимый в случае, когда все доп. мн. одной мощности это замена 1 элемента из S другим, кот. S. Такая окрестность имеет O(n 2 ) решений.

Локальный поиск Иногда решения из окрестности Q(S) отличаются от текущего решения S 2 элементами. Например, для КМ не ГЦ, кот. отличался бы от другого ГЦ 1 ребром. Если же удалить 2 ребра ГЦ, то ! другой ГЦ, содержащий оставшиеся ребра. На этом свойстве основан 1 из алг. приближенного решения КМ на полном графе. В алг. лок. поиска для решении симметричной КМ, если S является гам. циклом, то окрестность этого решения а функция цели Полученное после остановки алг. решение наз. 2-opt туром.

Поиск с запретами Основной недостаток л.п. остановка в точке лок. оптимума. Метаэвристики… Поиск с запретами (tabu search) использует историю поиска решений. Чтобы покинуть окрестность лок. opt, разрешается осуществлять переход к след. решению окрестности, даже если оно хуже (по функционалу) предыдущего. Недостаток возм. зацикливание, когда происходит возврат к уже просмотренному ранее решению. Чтобы избежать зацикливания, определенные решения, или переходы от решения к решению объявляются запрещенными (табу). Для этого создается и хранится «список запретов» (СЗ), в кот. помещается информация о последних решениях, или последних изменениях решений.

Поиск с запретами Шаг 1. Положить СЗ =. Шаг 2. Найти нач. решение S. Шаг 3. Пока не вып. крит. остановки, выполнить шаги 3.1– В окрест. текущего реш. S найти подмн. не запрещ. реш. Q (S) Q(S) Выбрать S =argmin{f(s) : s Q (S)} Заменить S на S и обновить СЗ. При вып. крит. остановки, лучшее найденное реш. – результат работы алг. Для реализации алг. следует определить: окрестность Q(S), СЗ, способ задания запретов, критерий остановки (можно задать max число итераций)

Поиск с запретами Пример окрестности Q(S) = {s V : s =(S \ {i}) {j}, i S, j V \ S}, получаемую заменой 1 элемента другим. СЗ может содержать последние t исключенных элементов {i 1,…,i t } и последние t добавленных элементов {j 1,…,j t }. Решение s Q(S) является запрещенным, если s={S\{i p }} {j} для некот. p=1,…,t, или s={S\{i}} {j q } для некот. q=1,…,t.

Имитация отжига В методе «имитация отжига» (simulated annealing) новое решение замещает текущее всегда, если оно лучше (по целевой функции), и с некоторой вероятностью, зависящей от параметра, кот. принято называть температурой, если целевая функция на нем хуже. Вероятность перехода к худшему решению обратно пропорциональна величине увеличения значения функционала на новом решении и прямо пропорциональна температуре. Для сходимости метода на каждой последующей итерации вероятность перехода к худшему решению уменьшается. Это обеспечивается уменьшением температуры (остыванием). Формально схему метода можно записать, например, след. обр.

Имитация отжига Шаг 1. Найти начальное решение S. Шаг 2. Задать начальную температуру T и коэффициент остывания r (0,1). Шаг 3. Пока температура достаточно высока (T T min ), выполнить шаги 3.1– Выполнить шаги 3.1.1–3.1.4 L раз Выбрать случайно решение S из окрестности Q(S) Вычислить = f(S ) – f(S) Если 0, то положить S = S Если > 0, то положить S = S с вероятностью e /T Положить T = Tr. (Уменьшить температуру.) Шаг 4. Запомнить лучшее из найденных решений. Конкретизация алг. зависит от специфики решаемой задачи. При этом требуется найти нач. доп. решение, определить нач. темп. T, скорость остывания r, число циклов L и критерий остановки.

Генетический алгоритм Генетический алг. на каж. итер. ищет не 1 новое решение, а целую популяцию (мн.) решений {S 1,…,S n }. Популяция развивается случайным образом, переходя от 1 поколения к следующему. Каж. итерация алг. состоит из след. шагов. Оценка. Оцен. пригодность (качество) каж. члена популяции. Выбор родителей. На осн. качеств выбираются пары решений (родители). Скрещивание. Каж. пара родителей используется для создания 1 или 2 новых решений (потомков). Мутация. Некот. потомки изменяются (модифицируются) случ. образом. Выбор популяции. На осн. качеств особей, выбирается новая популяция, кот. частично или полностью заменяет предыдущую, сохраняя общее количество элементов n.

Генетический алгоритм Оценка. Для оценки качества решения S можно использовать 1 функционал f(S) или пару функций: стоимость c(S) и степень недопустимости g(S). Выбор родителей. Родителей можно выбирать случайно пропорционально их качеству. Например, решение S i может быть выбрано в качестве родителя с вероятностью

Скрещивание 2-скрещивание. Заданы 2 строки x 1 x 2 … x r и y 1 y 2 … y r, а также целые числа p,q {1,…,r 1}, p

Мутация Простая мутация решения z 1 z 2 … z r это случ. выбор номера p {1,…,r}, а также символа m, и замена элемента z p символом m. Эта операция приводит к решению z 1 … z p-1 mz p+1 … z r. Перекрестная мутация – это перестановка случ. выбранных элементов z p и z q, приводящая к новому решению z 1 … z p-1 z q z p+1 … z q-1 z p z q+1 … z r.

Анализ точности приближенных алгоритмов 2 основных подхода: 1.Апостериорный анализ. Решается достаточно большое количество инд. задач и вычисляется отклонение функционала на построенных приближенным алг. решениях от opt зн. ц.ф. или оценки оптимума. 2. Априорный анализ. Ищется гарантированная оценка погрешности, кот. справедлива инд. задач и известна заранее, т.е. до применения алг. (априори).

Аппроксимационная схема Пусть рассматривается opt задача P. инд. з. I P обоз.: W * (I) opt зн. ц.ф., W A (I) – зн. ф. на решении, построенном алг. A. Алг. A является аппроксимационной схемой для з. P, если инд. з. I P и 0 алг. A строит доп. решение з. I с гарантированной оценкой отн. погрешности

Полиномиальные аппроксимационные схемы Аппр. схема наз. полиномиальной (PTAS – Polynomial Time Approximation Scheme), если фикс. зн. труд. алг. полиномом от длины входа з. где p полином, а |I| вход. длина з. I, то такой алг. является PTAS. В частности, если Аппр. схема наз. вполне полиномиальной (FPTAS – Fully Polynomial Time Approximation Scheme), если труд. алг. полиномом от длины входа и величины 1/. Для оценки погрешности используют также отношение Тогда если решается з. на min, то для оценки погрешности следует искать ВГ для этого отношения. В случае же поиска max ф., интерес представляет оценка величины отношения снизу.

Субоптимальные решения Доп. решение, имеющее гарантированную оценку отн. погр. = const, наз. -приближенным или субоптимальным. APX – класс задач NPO, для которых полиномиальный алгоритм с гарантированной оценкой

Отношение между классами NP P APX PTAS FPTAS Псевдополиномиальные алгоритмы

Задача о ранце Предположим, что a j b и Тогда жадный алг. и z H = cx H T = M = O(n) Теорема. Имеет место априорная оценка: Доказательство. Если отказаться от целочисл. переменных, то решением релаксированной з. явл. вектор с координатами x 1 =b/a 1, x j =0, j 2, и Т.к. a j b, то Положим Из f < 1

Задача коммивояжера Граф G = (V, E) наз. эйлеровым, если степени всех его в. четные. Лемма. Если G = (V, E) связный эйлеров граф и v V произв. в., то обход, начинающийся и заканчивающийся в v, в кот. ребро графа встречается 1 раз. Теорема. Пусть задан полный взвешенный гр. H с мн. в. V, в кот. веса ребер удовл.. Пусть G=(V,E) – связный эйлеров подгр. гр. H. Тогда гр. H содержит ГЦ длины Доказательство. Пусть m = |E| и v=v 0,e 1,v 1,e 2,…,e m,v m =v – обход всех ребер графа G, в кот. каж. р. e i =(v i-1,v i ) встречается 1 раз. Рассм. список в. в пор. их появления в обходе v 0,v 1,…,v m. Пусть – k-я по счету в. обхода отлич. от предыдущих. Тогда посл. – ГЦ. Оценим его длину.

Задача коммивояжера Из длина пути между в. и циклу длины ребра Построим реш. КМ с помощью алг., кот. состоит из след. шагов. Шаг 1. В исх. гр. найти остов min веса T. Пусть он содержит ребра E T и его вес Шаг 2. Продублировать каж. ребро мн. E T, чтобы получить связный эйлеров граф. Шаг 3. Построить ГЦ из эйлерова обхода, как это было сделано выше. Пусть длина построенного цикла равна z H. T=M=O(n2)T=M=O(n2)

Задача коммивояжера

Теорема. Справедлива оценка где z * – opt зн. ц.ф. КМ. Доказательство. Если из ГЦ исключить 1 ребро, то получится цепь, кот. явл. частным случаем остова z T z *. Вес построенного Эйлерова графа = 2z T. Согласно, длина постр. ГЦ имеет верхнюю оценку z H 2z T Приведем еще 1 приближенный алг., кот. основан на использовании min остова и совершенного паросочетания min веса.

Задача коммивояжера Шаг 1. В исх. гр. найти min остов (V,E T ). Пусть его вес Шаг 2. Пусть V мн. в. построенного дерева с нечетными степенями. Заметим, что |V | четно (это известное свойство, основанное на том, что степеней в. графа четна.) Найти совершенное пар. M min веса z M в гр. G =(V,E ), где E E, оба конца кот. V. Тогда (V, E T M) связ. эйлеров граф. Шаг 3. Используя процедуру построения ГЦ, описанную выше, находим ГЦ. Обозначим его длину z C.

Задача коммивояжера

Теорема. Имеет место неравенство Доказательство. Очевидно, z T z *. Предположим, что opt цикл – {1,2,…,n}. Пусть в. j 1,j 2,…,j 2k V упорядочены в порядке увеличения номеров. Рассмотрим совершенные паросочетания M 1 = {(j 1, j 2 ), (j 3, j 4 ), …, (j 2k-1, j 2k )} веса M 2 = {(j 2, j 3 ), (j 4, j 5 ), …, (j 2k-2, j 2k-1 ), (j 2k, j 1 )} веса j1j1 j2j2 j3j3 j4j4

Задача коммивояжера Из Т.к., i = 1, 2, то