WikiDer > Алгоритм Рамера – Дугласа – Пекера
В Алгоритм Рамера – Дугласа – Пекера, также известный как Алгоритм Дугласа – Пекера и итеративный алгоритм подбора конечной точки, это алгоритм, который уничтожает кривая, составленная из отрезков прямой, аналогичная кривой с меньшим количеством точек. Это был один из первых успешных алгоритмов, разработанных для Картографическое обобщение.
Идея
Назначение алгоритма состоит в том, кривая, состоящая из отрезков линий (который также называют Ломаная линия в некоторых случаях), чтобы найти похожую кривую с меньшим количеством точек. Алгоритм определяет «несходство» на основе максимального расстояния между исходной кривой и упрощенной кривой (т. Е. Расстояние Хаусдорфа между кривыми). Упрощенная кривая состоит из подмножества точек, определяющих исходную кривую.
Алгоритм
Начальная кривая - это упорядоченный набор точек или линий и размер расстояния ε > 0.
Алгоритм рекурсивно разделяет линию. Первоначально ему даются все баллы между первой и последней точкой. Он автоматически отмечает первую и последнюю точку, которую нужно сохранить. Затем он находит точку, которая наиболее удалена от отрезка линии, причем первая и последняя точки являются конечными точками; эта точка, очевидно, является самой дальней на кривой от аппроксимирующего отрезка прямой между конечными точками. Если точка ближе, чем ε к линейному сегменту, то любые точки, которые в настоящее время не отмечены для сохранения, могут быть отброшены без упрощенной кривой хуже, чем ε.
Если точка, наиболее удаленная от отрезка линии, больше, чем ε исходя из приближения, эту точку необходимо сохранить. Алгоритм рекурсивно вызывает себя с первой точкой и самой дальней точкой, а затем с самой дальней точкой и последней точкой, которая включает самую дальнюю точку, отмеченную как сохраняемую.
Когда рекурсия завершена, может быть сгенерирована новая выходная кривая, состоящая из всех и только тех точек, которые были отмечены как сохраненные.
Непараметрический Рамер – Дуглас – Пойкер
Выбор ε обычно определяется пользователем. Как и большинство методов аппроксимации линии / полигональной аппроксимации / обнаружения доминирующих точек, его можно сделать непараметрическим, используя границу ошибки из-за оцифровки / квантования в качестве условия завершения.[1]
Псевдокод
(Предполагается, что ввод - это массив с единицей)
функция DouglasPeucker (PointList [], epsilon) // Найти точку с максимальным расстоянием dmax = 0 index = 0 end = length (PointList) для от i = 2 до (конец - 1) {d = perpendicularDistance (PointList [i], Line (PointList [1], PointList [end])) если (d> dmax) {index = i dmax = d}} ResultList [] = пусто; // Если максимальное расстояние больше эпсилон, рекурсивно упрощаем если (dmax> epsilon) {// Рекурсивный вызов recResults1 [] = DouglasPeucker (PointList [1 ... index], epsilon) recResults2 [] = DouglasPeucker (PointList [index ... end], epsilon) // Строим список результатов ResultList [] = {recResults1 [1 ... длина (recResults1) - 1], recResults2 [1 ... длина (recResults2)]}} еще {ResultList [] = {PointList [1], PointList [end]}} // Возвращаем результат вернуть ResultList []конец
Ссылка на сайт: https://karthaus.nl/rdp/
заявка
Алгоритм используется для обработки векторная графика и картографическое обобщение. Он не всегда сохраняет свойство несамопересечения кривых, что привело к разработке вариантных алгоритмов.[2]
Алгоритм широко используется в робототехнике.[3] для упрощения и удаления шума данных о дальности, полученных с помощью вращающегося дальномер; в этой области он известен как алгоритм разделения и слияния и относится к Дуда и Харт.[4]
Сложность
Время работы этого алгоритма при работе на ломаной линии, состоящей из сегменты и вершины задаются повторением где это ценность показатель в псевдокоде. В худшем случае или при каждом рекурсивном вызове, и этот алгоритм имеет время работы . В лучшем случае или при каждом рекурсивном вызове, и в этом случае время выполнения имеет хорошо известное решение (через основная теорема для повторений "разделяй и властвуй") из .
Использование (полностью или частично)Динамическая выпуклая оболочка структуры данных, упрощение, выполняемое алгоритмом, может быть выполнено в время [5].
Смотрите также
Альтернативные алгоритмы упрощения линий включают:
дальнейшее чтение
- Урс Рамер, "Итерационная процедура многоугольной аппроксимации плоских кривых", Компьютерная графика и обработка изображений, 1 (3), 244–256 (1972) Дои:10.1016 / S0146-664X (72) 80017-0
- Дэвид Дуглас и Томас Пекер, "Алгоритмы уменьшения количества точек, необходимых для представления оцифрованной линии или ее карикатуры", The Canadian Cartographer 10 (2), 112–122 (1973) Дои:10.3138 / FM57-6770-U75U-7727
- Джон Хершбергер и Джек Сноиинк, «Ускорение алгоритма упрощения линии Дугласа – Пекера», Proc 5th Symp on Data Handling, 134–143 (1992). Технический отчет UBC TR-92-07 доступен по адресу http://www.cs.ubc.ca/cgi-bin/tr/1992/TR-92-07
- Р.О. Дуда и П. Харт, "Классификация паттернов и анализ сцены", (1973), Wiley, New York (https://web.archive.org/web/20110715184521/http://rii.ricoh.com/~stork/DHS.html)
- Visvalingam, M; Уайатт, JD (1992). Обобщение линии путем многократного исключения наименьшего участка (Технический отчет). Документ для обсуждения. Группа исследования картографических информационных систем (CISRG), Университет Халла. 10.
использованная литература
- ^ Прасад, Дилип К .; Leung, Maylor K.H .; Квек, Чай; Чо, Сиу-Юнг (2012). «Новая основа для непараметрических методов обнаружения доминирующих точек». Вычисления изображений и зрения. 30 (11): 843–859. Дои:10.1016 / j.imavis.2012.06.010.
- ^ Ву, Син-Тинг; Маркес, Мерседес (2003). «Алгоритм Дугласа-Пекера без самопересечения». 16-й Бразильский симпозиум по компьютерной графике и обработке изображений (SIBGRAPI 2003). Сан-Карлос, Бразилия: IEEE. С. 60–66. CiteSeerX 10.1.1.73.5773. Дои:10.1109 / SIBGRA.2003.1240992. ISBN 978-0-7695-2032-2.
- ^ Нгуен, Вьетнам; Гехтер, Стефан; Мартинелли, Агостино; Томатис, Никола; Сигварт, Роланд (2007). Сравнение алгоритмов выделения линий с использованием данных 2D диапазона для внутренней мобильной робототехники (PDF). Автономные роботы. 23 (2). С. 97–111. Дои:10.1007 / s10514-007-9034-у.
- ^ Дуда, Ричард О.; Харт, Питер Э. (1973). Классификация паттернов и анализ сцены. Нью-Йорк: Вили. ISBN 0-471-22361-1.
- ^ Хершбергер, Джон; Snoeyink, Джек (1992). Ускорение алгоритма упрощения линии Дугласа-Пекера (PDF) (Технический отчет).
внешние ссылки
- Boost.Geometry support Алгоритм упрощения Дугласа – Пекера
- Реализация алгоритмов Рамера – Дугласа – Пекера и многих других алгоритмов упрощения с открытым исходным кодом на C ++
- XSLT-реализация алгоритма для использования с данными KML.
- Вы можете увидеть алгоритм, примененный к журналу GPS во время поездки на велосипеде, внизу этой страницы.
- Интерактивная визуализация алгоритма
- Реализация на F #
- Реализация Ruby gem
- JTS, Java Topology Suite, содержит Java-реализацию многих алгоритмов, включая Алгоритм Дугласа-Пекера