WikiDer > Проблема k-центра вершины

Vertex k-center problem


В вершина k-центровая проблема это классический NP-жесткий проблема в Информатика. Он имеет применение в расположение объекта и кластеризация.[1][2] По сути, вершина k-центральная проблема моделирует следующую реальную проблему: дан город с удобства, найди лучшее объекты, где построить пожарные депо. Поскольку пожарные должны проявлять чрезвычайную помощь как можно быстрее, расстояние от самого дальнего объекта до ближайшего пожарного депо должно быть как можно меньше. Другими словами, расположение пожарных депо должно быть таким, чтобы устранять все возможные пожары как можно быстрее.

Формальное определение

Вершина k-центровая задача - классическая NP-Hard проблема в Информатика. Впервые он был предложен Хакими в 1964 году.[3] Формально вершина k-центровая проблема состоит в том, чтобы дать полную неориентированную график в метрическое пространство, и положительное целое число , найдите подмножество такой, что и целевая функция сводится к минимуму. Расстояние определяется как расстояние от вершины до ближайшего центра в .

Алгоритмы аппроксимации

Если , вершина k-центровая задача не может быть (оптимально) решена за полиномиальное время. Однако есть несколько алгоритмов с полиномиальным временем, которые близки к оптимальным решениям. Конкретно, 2-приближенные решения. Собственно, если наилучшее возможное решение, которое может быть достигнуто с помощью алгоритма с полиномиальным временем, - это 2-приближенное решение.[4][5][6][7] В контексте задачи минимизации, такой как вершина k-центральная задача, 2-приближенное решение - любое решение такой, что , куда размер оптимального решения. Алгоритм, который гарантирует генерацию 2-приближенных решений, известен как алгоритм 2-приближения. Основные 2-приближенные алгоритмы для вершины k-центровой проблемой, описанной в литературе, является алгоритм Sh,[8] алгоритм HS,[7] и алгоритм Гона.[5][6] Несмотря на то, что эти алгоритмы являются (полиномиальными) наилучшими из возможных, их производительность на большинстве наборов данных тестов очень низкая. Из-за этого многие эвристика и метаэвристика были разработаны с течением времени. Вопреки здравому смыслу одна из наиболее практичных (полиномиальных) эвристик для вершины k-центровая задача основана на алгоритме CDS, который является 3-приближенным алгоритмом[9]

Алгоритм Sh

Формально характеризуется Давид Шмойс в 1995 г.[8] алгоритм Sh принимает на вход полный неориентированный граф , положительное целое число , и предположение от того, каков оптимальный размер решения. Алгоритм Sh работает следующим образом: выбирает первый центр наугад. Пока решение состоит только из одной вершины, . Далее выбирает центр случайным образом из множества, содержащего все вершины, удаленные от больше, чем . На этой точке, . Наконец, выбирает оставшиеся центры точно так же был выбран. Сложность алгоритма Sh составляет , куда количество вершин.

Алгоритм HS

Предложено Дорит Хохбаум и Давид Шмойс в 1985 году алгоритм HS берет за основу алгоритм Sh.[7] Заметив, что ценность должно быть равно стоимости некоторого преимущества в , и поскольку есть края в , алгоритм HS в основном повторяет алгоритм Sh с каждой стоимостью ребра. Сложность алгоритма HS составляет . Однако, запустив бинарный поиск по упорядоченному набору граничных затрат его сложность снижается до .

Алгоритм Гона

Предложено независимо Теофило Гонсалес,[5] и Мартин Дайер и Алан Фриз[6] в 1985 году алгоритм Гона по сути является более мощной версией алгоритма Sh. Хотя алгоритм Sh требует предположения на , алгоритм Гона предупреждает о таком предположении, замечая, что если любой набор вершин на расстоянии больше, чем существует, то самая дальняя вершина должна находиться внутри такого множества. Следовательно, вместо вычисления на каждой итерации набора вершин на расстоянии, превышающем а затем выбирая случайную вершину, алгоритм Гона просто выбирает самую дальнюю вершину из каждого частичного решения . Сложность алгоритма Гона составляет , куда количество вершин.

Алгоритм CDS

Предложено Гарсией Диасом и др. в 2017 г.[9] Алгоритм CDS - это алгоритм с 3 приближениями, который берет идеи из алгоритма Гона (эвристика самой дальней точки), алгоритма HS (параметрическое отсечение) и отношения между вершинами k-центровая проблема и Доминирующий набор проблема. Алгоритм CDS имеет сложность . Однако, выполняя двоичный поиск по упорядоченному набору стоимостей ребер, предлагается более эффективная эвристика с именем CDSh. Сложность алгоритма CDSh составляет . Несмотря на неоптимальную производительность алгоритма CDS и эвристическую производительность CDSh, оба они имеют гораздо лучшую производительность, чем алгоритмы Sh, HS и Gon.

Экспериментальное сравнение

Некоторые из наиболее широко используемых наборов данных тестов для вершины k-центровой проблемой являются экземпляры pmed из OR-Lib.,[10] и несколько экземпляров из TSP-Lib.[11] В таблице 1 показаны среднее значение и стандартное отклонение экспериментальных коэффициентов аппроксимации решений, сгенерированных каждым алгоритмом, для 40 экземпляров pmed из OR-Lib.[9]

Таблица 1. Фактор экспериментальной аппроксимации для экземпляров pmed из OR-Lib
АлгоритмСложность
HS1.5320.175
Гон1.5030.122
CDSh1.0350.031
CDS1.0200.027
Таблица 2. Фактор экспериментальной аппроксимации по экземплярам из TSP-Lib
АлгоритмАлгоритм
Гон1.3960.091
HS1.3180.108
CDSh1.1240.065
CDS1.0420.038

Полиномиальная эвристика

Жадный чистый алгоритм

Жадный чистый алгоритм (или Gr) следует основной идее жадные алгоритмы: принимать оптимальные локальные решения. В случае вершины k-центровой задачи оптимальное локальное решение состоит в выборе каждого центра таким образом, чтобы размер решения (радиус покрытия) был минимальным на каждой итерации. Другими словами, первый выбранный центр - это тот, который решает проблему с одним центром. Второй выбранный центр - это тот, который вместе с предыдущим центром создает решение с минимальным радиусом покрытия. Остальные центры выбираются аналогично. Сложность алгоритма Gr составляет .[12] Эмпирическая производительность алгоритма Gr в большинстве тестовых примеров оставляет желать лучшего.

Алгоритм подсчета очков

Алгоритм подсчета очков (или Scr) был введен Юрием Михеличем и Борутом Робичем в 2005 году.[13] В этом алгоритме используется редукция из вершины k-центрируйте задачу на минимальную доминирующую задачу. Проблема решается путем обрезки входного графа со всеми возможными значениями оптимального размера решения и последующего эвристического решения задачи с минимальным доминирующим набором. Эта эвристика следует за ленивый принцип, которая принимает каждое решение как можно медленнее (в отличие от жадной стратегии). Сложность алгоритма Scr составляет . Эмпирическая производительность алгоритма Scr очень хорошая на большинстве тестовых примеров. Однако его время работы быстро становится непрактичным по мере роста ввода. Таким образом, кажется, что это хороший алгоритм только для небольших случаев.

Рекомендации

  1. ^ Пачеко, Хоакин А .; Касадо, Сильвия (декабрь 2005 г.). «Решение двух моделей местоположения с небольшим количеством средств обслуживания с использованием гибридной эвристики: реальный случай ресурсов здравоохранения». Компьютеры и исследования операций. 32 (12): 3075–3091. Дои:10.1016 / j.cor.2004.04.009. ISSN 0305-0548.
  2. ^ Kaveh, A .; Наср, Х. (август 2011 г.). «Решение проблемы условного и безусловного центра с помощью модифицированного поиска гармонии: реальный пример». Scientia Iranica. 18 (4): 867–877. Дои:10.1016 / j.scient.2011.07.010. ISSN 1026-3098.
  3. ^ Хакими, С. Л. (1964). «Оптимальные положения центров коммутации, абсолютных центров и медиан графа». Исследование операций. 12 (3): 450–459. Дои:10.1287 / opre.12.3.450. JSTOR 168125.
  4. ^ Карив, О .; Хакими, С. Л. (декабрь 1979 г.). «Алгоритмический подход к проблемам сетевого размещения. I: p-центры». Журнал SIAM по прикладной математике. 37 (3): 513–538. Дои:10.1137/0137040. ISSN 0036-1399.
  5. ^ а б c Гонсалес, Теофило Ф. (1985). «Кластеризация для минимизации максимального межкластерного расстояния». Теоретическая информатика. 38: 293–306. Дои:10.1016/0304-3975(85)90224-5. ISSN 0304-3975.
  6. ^ а б c Дайер, M.E; Frieze, A.M (февраль 1985 г.). «Простая эвристика для проблемы p-центра». Письма об исследованиях операций. 3 (6): 285–288. Дои:10.1016/0167-6377(85)90002-1. ISSN 0167-6377.
  7. ^ а б c Hochbaum, Dorit S .; Шмойс, Дэвид Б. (май 1985 г.). "Лучшая возможная эвристика для k-Центр проблемы ». Математика исследования операций. 10 (2): 180–184. Дои:10.1287 / moor.10.2.180. ISSN 0364-765X.
  8. ^ а б Шмойс, Дэвид Б. (1995). Вычисление почти оптимальных решений комбинаторных задач оптимизации. В комбинаторной оптимизации, ряды Димака в дискретной математике и теоретической информатике. Серия DIMACS по дискретной математике и теоретической информатике. 20. С. 355––397. CiteSeerX 10.1.1.33.1719. Дои:10.1090 / dimacs / 020/07. ISBN 9780821802397.
  9. ^ а б c Гарсиа-Диас, Хесус; Санчес-Эрнандес, Хайро; Менчака-Мендес, Рикардо; Менчака-Мендес, Роландо (01.07.2017). "Когда худший коэффициент приближения дает лучшую производительность: алгоритм с 3 приближениями для вершины k-центровая проблема ». Журнал эвристики. 23 (5): 349–366. Дои:10.1007 / s10732-017-9345-х. ISSN 1381-1231.
  10. ^ Бисли, Дж. Э. (1990). «OR-библиотека: рассылка тестовых заданий по электронной почте». Журнал Общества оперативных исследований. 41 (11): 1069–1072. Дои:10.2307/2582903. JSTOR 2582903.
  11. ^ Райнельт, Герхард (ноябрь 1991 г.). «TSPLIB - Библиотека задач коммивояжера». Журнал ORSA по вычислительной технике. 3 (4): 376–384. Дои:10.1287 / ijoc.3.4.376. ISSN 0899-1499.
  12. ^ Рана, ротанг; Гарг, Дипак (март 2009 г.). Эвристические подходы для k-Центр проблемы. 2009 Международная конференция по передовым вычислениям IEEE. IEEE. Дои:10.1109 / iadcc.2009.4809031. ISBN 9781424429271.
  13. ^ Михелич, Юрий; Робич, Борут (2005). "Решение k-центровая задача эффективно с алгоритмом доминирующего множества ". Журнал вычислительной техники и информационных технологий. 13 (3): 225. Дои:10.2498 / cit.2005.03.05. ISSN 1330-1136.