Разложение хорошо разделенных пар - Википедия - Well-separated pair decomposition
В вычислительная геометрия, а разложение хорошо разделенных пар (WSPD) набора точек , представляет собой последовательность пар множеств , такая, что каждая пара хорошо отделенный, и для каждых двух различных точек , существует ровно одна пара, разделяющая их.
Граф, индуцированный хорошо разделенным парным разложением, может служить гаечный ключ из полный Евклидов граф, и полезен при приближении решения нескольких проблем, связанных с этим.[1]
Определение
Позволять - два непересекающихся множества точек в , обозначить выровненная по оси минимальная ограничивающая рамка для точек в , и обозначить коэффициент разделения.
Мы считаем и быть хорошо отделенный, если для каждого из и существует d-мяч радиуса содержащие его, так что между двумя сферами минимальное расстояние не менее .[2]
Мы рассматриваем последовательность хорошо разделенных пар подмножеств , быть разложение хорошо разделенных пар (WSPD) из если для любых двух различных точек , существует ровно один , , так что либо
- и , или же
- и .[1]
Строительство
Разделить дерево
Путем построения ярмарка расколотое дерево, можно построить WSPD размером в время.[2]
Общий принцип разбиения дерева набора точек S что каждый узел ты дерева представляет собой набор точек Sты и что ограничивающая рамка R (Sты) из Sты делится по своей длинной стороне на две равные части, которые образуют двух дочерних элементов ты и их набор точек. Это делается рекурсивно до тех пор, пока в наборе не останется только одна точка.
Позволять LМаксимум(R (X)) обозначают размер самого длинного интервала ограничивающего гипер прямоугольника множества точек Икс и разреши Lя(R (X)) обозначают размер я-я размерность ограничивающего гипер прямоугольника множества точек Икс. Ниже мы приводим псевдокод для вычисления дерева расщепления.
SplitTree (S) Позволять ты быть узлом для S если | S | = 1 R (u): = R (S) // R (S) - гипер прямоугольник, каждая сторона которого равна нулю. Хранить в ты единственная точка в S. еще Вычислить R (S) Пусть я-е измерение будет тем, где LМаксимум(R (S)) = Lя(R (S)) Расколоть R (S) вдоль я-го измерения в двух гипер прямоугольниках одинакового размера и возьмите точки, содержащиеся в этих гипер прямоугольниках, чтобы сформировать два набора Sv и Sш. v: = SplitTree (Sv) w: = SplitTree (Sш) Магазин v и ш как, соответственно, левый и правый потомки ты. R (u): = R (S) возвращаться ты
Этот алгоритм работает в время.
Мы даем более эффективный алгоритм, который работает в время ниже. Цель состоит в том, чтобы перебрать список только за операций на шаг рекурсии, но каждый раз вызывает рекурсию не более чем в половине точек.
Позволять Sяj быть j-я координата я-я точка в S такой, что S сортируется по каждому измерению и p (Sяj) быть точкой. Кроме того, пусть ч (R (S)) быть гиперплоскостью, которая разделяет самую длинную сторону R (S) в двоем. Вот алгоритм в псевдокоде:
SplitTree (S, u) если | S | = 1 R (u): = R (S) // R (S) - гипер прямоугольник, каждая сторона которого равна нулю. Хранить в ты единственный момент в S. еще размер: = | S | повторение Вычислить R (S) R (u): = R (S) j: = 1 k: = | S | Пусть я-е измерение будет тем, где LМаксимум(R (S)) = Lя(R (S)) Sv : = ∅ Sш : = ∅ пока Sяj + 1и Sяк-1 > h (R (S)) размер: = размер - 1 Sv : = Sv ∪ {p (S_i ^ j)} Sш : = Sш ∪ {p (S_i ^ k)} j: = j + 1 к: = к - 1 Позволять v и ш быть соответственно левым и правым потомками ты. если Sяj + 1 > h (R (S)) Sш : = S Sv u: = w S: = Sш SplitTree (Sv, v) иначе если Sяк-1 Sv : = S Sш u: = v S: = Sv SplitTree (Sш, w) до того как размер ≤п⁄2 SplitTree (S, u)
Чтобы иметь возможность поддерживать отсортированные списки для каждого узла, используются связанные списки. Перекрестные указатели сохраняются для каждого списка для других, чтобы иметь возможность извлекать точку за постоянное время. В приведенном выше алгоритме на каждой итерации цикла выполняется вызов рекурсии. На самом деле, чтобы восстановить список без дополнительных затрат на пересбор точек, необходимо перестроить отсортированные списки после того, как все точки будут назначены их узлам. Чтобы выполнить перестройку, пройдите по каждому списку для каждого измерения, добавьте каждую точку в соответствующий список ее узлов и добавьте перекрестные указатели в исходный список, чтобы иметь возможность добавлять перекрестные указатели для новых списков. Наконец, вызовите рекурсию для каждого узла и его набора.
Расчет WSPD
WSPD можно извлечь из такого разбитого дерева, вызвав рекурсивный Найти пары (v, w) функция на детей каждый узел в разбитом дереве. Позволять тыл / тыр обозначают потомков узла ты. Мы даем псевдокод для FindWSPD (T, s) функция ниже.
FindWSPD (T, s) для каждого узел ты Это не лист в расколотом дереве Т делать FindPairs (uлтыр)
Мы даем псевдокод для Найти пары (v, w) функция ниже.
Найти пары (v, w) если Sv и Sш хорошо разделены по s отчет пара (Sv, Sш) еще если( LМаксимум(R (v)) ≤ LМаксимум(R (ш)) ) Рекурсивно вызывать FindPairs (v, wл) и FindPairs (v, wр) еще Рекурсивно вызывать Найти пары (vл, w) и Найти пары (vр, w)
Объединение s-хорошо отделенные пары от всех звонков Найти пары (v, w) дает WSPD для разделения s.
Доказательство правильности алгоритма |
---|
Ясно, что пары, возвращаемые алгоритмом, хорошо разделены из-за условия возврата функции FindPairs. Теперь нам нужно доказать, что для любых различных точек и в , есть уникальная пара так что я) и или (ii) и . Без ограничения общности предположим, что выполнено (i). Позволять быть самым низким общим предком и в расколотом дереве и пусть и быть детьми . В силу последнего предположения находится в поддереве и в поддереве . Звонок в Найти пары (v, w) обязательно делается в FindWSPD. Поскольку каждый раз, когда происходит рекурсия, дерево рекурсии создает две ветви, которые содержат все точки текущего вызова рекурсии, будет последовательность вызовов FindPairs приводит к в и в . Потому что является самым низким общим предком и , звоню FindPairs на дочерних элементах более высокого узла приведет к и не в паре и звоню FindPairs на потомках в одном из узлов одного из поддеревьев приведет к или же не входя ни в одну пару. Таким образом, пара единственный, разделяющий и . |
Каждый раз, когда дерево рекурсии разделяется на две части, к разложению добавляется еще одна пара. Итак, время выполнения алгоритма определяется количеством пар в окончательной декомпозиции.
Каллахан и Косараджу доказали, что этот алгоритм находит хорошо разделенное парное разложение (WSPD) размера .[2]
Характеристики
Лемма 1.: Позволять быть хорошо разделенной парой относительно . Позволять и . Потом, .
Доказательство: Потому что и находятся в одном наборе, мы имеем куда - радиус окружности и . Потому что и находятся в двух хорошо разделенных наборах, мы имеем . Получаем, что:
Лемма 2: Позволять быть хорошо разделенной парой относительно . Позволять и . Потом, .
Доказательство: По неравенству треугольника имеем:
Из леммы 1 получаем:
Приложения
Разложение на хорошо разделенные пары имеет применение при решении ряда задач. WSPD можно использовать для:
- Решить проблема ближайшей пары в время.[1]
- Решить kпроблема ближайших пар в время.[1]
- Решить k-ближайшая парная задача в время.[3]
- Решить проблема всех ближайших соседей в время.[1]
- Обеспечить -приближение из диаметр точки, установленной в время.[1]
- Непосредственно вызвать гаечный ключ набора точек.[1]
- Обеспечьте t-приближение Евклидово минимальное остовное дерево в d размеры в время.[1]
- Обеспечить -аппроксимация Евклидово минимальное остовное дерево в d размеры в время.[4]
Рекомендации
- ^ а б c d е ж грамм час Смид, Мишель (16 августа 2005 г.). «Разложение хорошо разделенных пар и его приложения» (PDF). Получено 26 марта 2014.
- ^ а б c Каллахан, П. Б. и Косараджу, С. Р. (январь 1995 г.). «Разложение многомерных наборов точек с приложениями к k-ближайшим соседям и n-частным потенциальным полям». Журнал ACM. 42 (1): 67–90. Дои:10.1145/200836.200853.
- ^ Беспамятных, Сергей; Сигал, Майкл (2002). «Быстрые алгоритмы приближения расстояний». Алгоритмика. 33 (2): 263–269. Дои:10.1007 / s00453-001-0114-7.
- ^ Арья, Сунил; Маунт, Дэвид М. (2016). «Быстрый и простой алгоритм для вычисления приблизительного евклидова минимального остовного дерева». Материалы двадцать седьмого ежегодного симпозиума ACM-SIAM по дискретным алгоритмам.