WikiDer > Кинетическая ближайшая пара - Википедия
А кинетическая ближайшая пара структура данных - это кинетическая структура данных который поддерживает ближайшая пара точек, учитывая набор п из п точки, которые непрерывно движутся со временем в метрическом пространстве. Хотя многие эффективный алгоритмы были известны в статическом случае, их оказалось трудно кинетизировать,[1] поэтому для решения этой проблемы были разработаны новые статические алгоритмы.
2D корпус
Подход 1
Самый простой кинетический подход к поддержанию ближайшей пары - использование вариантов Триангуляции Делоне.[2]
Рассмотрим шестиугольник и разделим его на шесть равносторонние треугольники, а затем создайте триангуляцию Делоне на основе каждого равностороннего треугольника, поскольку каждый из них имеет выпуклую форму. Объединение этих шести триангуляций Делоне, так называемый равносторонний граф Делоне (EDG), является суперграфом для граф ближайшего соседа (NNG); конечные точки ребра с минимальной длиной в EDG дают ближайшую пару. Поддерживать триангуляции Делоне, основанные на выпуклых формах, несложно. Учитывая EDG с течением времени, создавая кинетическое турнирное дерево по краям EDG можно легко провести ближайшую пару.
Эта ближайшая пара KDS эффективна, быстро реагирует на амортизацию и компактна, но в целом не является локальной. Следующий подход представляет собой локальный KDS для обслуживания ближайшей пары.
Подход 2
Второй кинетический подход основан на следующих наблюдениях.[3][4]
Разделяй и властвуй
Если пространство вокруг точки п делится под углом на шесть «клиньев», каждый 60° широкий, ближайшая точка к п является ближайшей из ближайших точек в каждом из клиньев. Остальная часть этой статьи будет сосредоточена на «основных» клиньях (тех, которые делятся пополам по оси x), а аргументы симметрии будут применяться к другим клиньям после поворота плоскости на ±60°.
Совпадающие очки
Точки п и q называются «совпадающими», если они являются ближайшими точками друг к другу. Ясно, что ближайшая пара точек - это совпадающая пара.
Учитывайте моменты п и q, так что п находится слева от q и q лежит в клине с центром в п описано выше. Если п это ближайшая точка к q, тогда q должна быть ближайшей точкой (в этом клине) к п, в x-направлении. Таким образом, набор пар ближайших точек (в пределах этого клина) в x-направлении является надмножеством набора пар ближайших точек.
Строительство
- Нанесите на карту каждую точку п=(Икс, у) в наборе п к новой точке п' = (ты, v) = (х +√3у, у-√3Икс), образуя множество П' преобразованных точек. Обратите внимание, что для точки п, точки в «основных» клиньях имеют ты и v координаты больше или меньше чем п' в этой новой системе координат.
- Сортировать точки по Икс,ты и v координаты и сохраните их в кинетические отсортированные списки.
- Постройте 2D дерево диапазона Т по пунктам в П'. Для каждого узла ш в первичном дереве пусть Т(ш) быть вторичным деревом, связанным с ш. Это дерево диапазонов будет использоваться для определения точек в "основном" клине для точки. ш.
- Для каждого узла ш в основном дереве, и каждый узел е в Т(ш), вычислить пару π(w, e) = (б, р), куда б (или же р) определяется как точка с максимальной (или минимальной) координатой x в левом (или правом) поддереве е. Позволять Π (0) быть набором π(w, e) для всех пар ш, е в Т. Это надмножество множества пар ближайших точек (внутри основного клина).
- Построить очередь с кинетическим приоритетом на парах в Π (0), с приоритетом, определяемым расстоянием (измеренным в исходной системе координат) между точками в паре.
- Повторите вышеуказанные шаги для повернутой плоскости. ±60°, чтобы получить очереди с кинетическим приоритетом Π (1) и Π (-1) соответственно.
Ближайшая пара точек в п соответствует минимуму из минимумов, полученных из трех приоритетных очередей Π над.
Обслуживание
Сбои сертификатов могут происходить в очередях с приоритетом и в отсортированных списках. Смена порядка точек приведет к изменению Т (что займет O (бревно2 п) time) и может вызывать вставки / удаления в приоритетных очередях.
Обратите внимание, что количество изменений в наборах Π как определено выше, не обязательно должно быть постоянным числом. Однако любая пара, которая начинает или прекращает сопоставление в результате изменения порядка p и q, должна содержать p и / или q, и, следовательно, есть только постоянное количество сопоставленных пар, которые должны быть вставлены / удалены из приоритета очереди. Можно обновлять только эти согласованные пары, поскольку по определению только согласованные пары имеют шанс быть ближайшей парой.
Анализ
Этот KDS:
- Отзывчивый: принимает O (бревно2 п) время обрабатывать событие
- Местный: поскольку каждая точка присутствует в постоянном количестве кинетических отсортированных списков и кинетических приоритетных очередей, локальность следует из локальности этих структур
- Компактность: компактность следует из компактности кинетических отсортированных списков и кинетических приоритетных очередей
- Эффективный: каждый обмен в отсортированных списках вызывает постоянное количество вставок и удалений в очередях с кинетическим приоритетом. Предполагая, что движение точек является псевдоалгебраическим, существует полиномиальное количество перестановок, и, следовательно, полиномиальное количество событий обрабатывается этим KDS, что делает его эффективным
Этот подход можно использовать для поддержания ближайшей пары в более высоких измерениях.
Рекомендации
- ^ Basch, J., Guibas, L.J., Hershberger, J (1997). «Структуры данных для мобильных данных». Материалы восьмого ежегодного симпозиума ACM-SIAM по дискретным алгоритмам. СОДА. Общество промышленной и прикладной математики. стр. 747–756. Получено 17 мая, 2012.CS1 maint: несколько имен: список авторов (связь)
- ^ Rahmati, Z .; Кинг, В.; Уайтсайдс, С. (2013). Кинетические структуры данных для всех ближайших соседей и ближайшей пары на плоскости. Материалы 29-го симпозиума ACM по вычислительной геометрии. С. 137–144. Дои:10.1145/2462356.2462378.
- ^ Баш, Жюльен; Guibas, Leonidas J .; Чжан, Ли (1997). Проблемы близости движущихся точек. Материалы 13-го симпозиума ACM по вычислительной геометрии. С. 344–351.
- ^ Agarwal, P.K .; Каплан, Хаим; Шарир, Миха (ноябрь 2008 г.). «Кинетические и динамические структуры данных для ближайшей пары и всех ближайших соседей». Транзакции по алгоритмам (TALG). 5 (1).