Диаметр множества точек (вращающиеся калиперы) — различия между версиями
Megabyte (обсуждение | вклад) |
Megabyte (обсуждение | вклад) |
||
Строка 8: | Строка 8: | ||
== Вращающиеся калиперы == | == Вращающиеся калиперы == | ||
+ | === Опорные прямые === | ||
{{Определение | {{Определение | ||
|definition= | |definition= | ||
Строка 34: | Строка 35: | ||
|[[Файл:max_parallel.png|170px|thumb|right]] | |[[Файл:max_parallel.png|170px|thumb|right]] | ||
|} | |} | ||
− | + | === Алгоритм === | |
Заметим, что параллельные опорные прямые можно провести не через любую пару точек. | Заметим, что параллельные опорные прямые можно провести не через любую пару точек. | ||
Строка 51: | Строка 52: | ||
|} | |} | ||
− | == | + | == Ссылки == |
* ''M.I. Shamos'' Computational geometry, 1978 {{---}} С. 76. | * ''M.I. Shamos'' Computational geometry, 1978 {{---}} С. 76. | ||
* ''Яглом И.М., Болтянский В.Г.'' Выпуклые фигуры, 1951 {{---}} С. 20, 144. | * ''Яглом И.М., Болтянский В.Г.'' Выпуклые фигуры, 1951 {{---}} С. 20, 144. | ||
+ | * [https://github.com/Megabyte777/cg/blob/master/include/cg/operations/diameter.h Реализация - Github.com] | ||
[[Категория: Вычислительная геометрия]] | [[Категория: Вычислительная геометрия]] |
Версия 17:21, 8 января 2014
Эта статья находится в разработке!
Есть множество точек на плоскости. Нужно найти две самые удалённые из них.
Найдём выпуклую оболочку исходного множества и получим более простую задачу: найти две наиболее удалённые вершины в выпуклом многоугольнике. Сделать это можно за линейное время с помощью метода, который называется вращающиеся калиперы (англ. rotating calipers).
Постановка задачи
Пусть
— выпуклый многоугольник, в котором порядок обхода вершин направлен против часовой стрелки, и никакие три последовательные точки не лежат на одной прямой. Найти пару чисел , такие, что максимально.Вращающиеся калиперы
Опорные прямые
Определение: |
Прямая | называется опорной прямой (англ. line of support) для многоугольника , если его внутренность лежит по одну сторону от , при этом проходит хотя бы через одну из вершин .
|
Так как
и — какие угодно граничные точки фигуры , принадлежащие соответственно прямым и , то из перпендикулярности отрезка к прямым и следует, что ни одна из прямых , не может иметь с фигурой целый общий отрезок. Другими словами, каждая из этих прямых содержит единственную граничную точку фигуры .
|
Алгоритм
Заметим, что параллельные опорные прямые можно провести не через любую пару точек.
Определение: |
Точки, через которые можно провести параллельные опорные прямые, будем называть противоположными (англ. antipodal). |
Благодаря предыдущей теореме нам нужно рассмотреть только противоположные точки. Задача в том, чтобы рассмотреть их, не перебирая все пары точек.
Рассмотрим рисунок справа. Теперь будет вращаться вокруг , а продолжит вращаться вокруг , и следующей парой противоположных точек станет . Продолжая таким образом, мы сгенерируем все пары противоположных точек, так как параллельные линии пройдут под всеми возможными углами. Определение новой пары противоположных точек требует только одного сравнения углов, которое можно выполнить с помощью предиката поворота. |
и — опорные прямые, проходящие через вершины и соответственно. Значит, — противоположная пара точек. Если начать вращать прямые против часовой стрелки вокруг данных точек, они будут оставаться опорными прямыми, пока одна из прямых не станет накладываться на сторону многоугольника. В нашем примере, при вращении к позиции , коснётся точки раньше, чем коснётся , поэтому становится новой парой противоположных точек.
Ссылки
- M.I. Shamos Computational geometry, 1978 — С. 76.
- Яглом И.М., Болтянский В.Г. Выпуклые фигуры, 1951 — С. 20, 144.
- Реализация - Github.com