Разбиение многоугольника — это множество примитивных элементов (например, квадратов), которые не накладываются и объединение которых равно многоугольнику. Задача о разбиении многоугольника — это задача поиска разбиения, которое в некотором смысле минимально, например, разбиение с наименьшим числом элементов или разбиение с наименьшей суммой длин сторон.
Разбиение многоугольника является важным классом задач в вычислительной геометрии. Существует много различных задач разбиения многоугольника в зависимости от типа многоугольника и и типа разрешённых элементов.
Термин декомпозиция многоугольника часто используется в качестве общего термина для покрытия и разбиения[1].
Декомпозиция многоугольника используется в нескольких областях[1]:
Наиболее изученная задача разбиения многоугольника — разбиение на наименьшее число треугольников (триангуляция). Для многоугольника без дыр с вершинами триангуляризация может быть вычислена за время . Для многоугольника с дырами существует нижняя оценка .
Связанная задача — разбиение на треугольники с наименьшей суммой сторон (триангуляризация с минимальным весом[en]).
Те же два варианта задачи можно поставить для случая, когда вместо треугольников используются псевдотреугольники[en] – многоугольники, которые имеют, как и треугольники, в точности три выпуклых вершины. Варианты: разбиение на меньшее число псевдотреугольников и разбиение на псевдотреугольники с наименьшей суммарной длиной сторон.
Частный случай задачи разбиения многоугольника возникает, когда разбиваемым многоугольником служит ортогональный многоугольник[en]. В этом случае наиболее важным компонентом разбиения служит прямоугольник[1].
Прямоугольные разбиения используются часто. При проектировании СБИС необходимо разложить маску на простые фигуры, имеющиеся в списке литографического генератора. Похожая задача декомпозиции возникает при разработке ДНК-микрочипов. Прямоугольные разбиения могут упростить операции свёртки при обработке изображений и могут быть использованы для сжатия битовых изображений. Тесно связанная задача разбиения матрицы применяется для планирования радиотерапии. Прямоугольное разбиение используется для проектирования последовательности самосборки роботов[2][3].
Известно несколько алгоритмов полиномиального времени работы для этой задачи, см. статьи Марка Кейла[4] и Эппштейна[5] для обзора.
Задача разбиения прямоугольного многоугольника на наименьшее число квадратов (в отличие от произвольных прямоугольников) является NP-трудной задачей[6].
В разработке СБИС часто требуется разбить многоугольную область на минимальное число трапеций с двумя горизонтальными основаниями. Треугольник с горизонтальным основанием при этом также считается трапецией, одно из оснований которой вырождено. Для многоугольников без дыр с сторонами наименьшее разбиение такого вида можно найти за время [7].
Если не требуется, чтобы число трапеций было минимальным, разбиение можно найти за время как побочный продукт алгоритма триангуляции многоугольника[8].
Если многоугольник имеет дыры, задача становится NP-полной, но 3-аппроксимация может быть найдена за время [7].
Можно поставить задачу о разбиении многоугольника на выпуклые четырёхугольники.
Существенной характеристикой задачи разбиения на четырёхугольники является, разрешены или нет точки Штейнера, т.е. разрешено ли добавлять точки, которые не являются вершинами многоугольника. Если разрешить точки Штейнера, можно получить меньшее разбиение, но существенно труднее гарантировать, что разбиения, найденные алгоритмами, будут иметь минимальный размер.
Для многоугольников без дыр существуют алгоритмы линейного времени работы для разбиения на четырёхугольники с точками Штейнера, но гарантии, что найденное решение будет наименьшим, нет[9][10].
Обобщением предыдущей задачи служит задача разбиения многоугольника на многоугольники с точно m сторонами, или не более чем с m сторонами. Целью является минимизация суммарной длины сторон. Задачу можно решить за полиномиальное от n и m время[11][12].
Изучались и более общие виды фигур, включая произвольные выпуклые многоугольники, спирали, звёздчатые многоугольники и монотонные многоугольники[en]. См. обозрение в статье Марка Кейла[1].
Для улучшения этой статьи желательно: |
Данная страница на сайте WikiSort.ru содержит текст со страницы сайта "Википедия".
Если Вы хотите её отредактировать, то можете сделать это на странице редактирования в Википедии.
Если сделанные Вами правки не будут кем-нибудь удалены, то через несколько дней они появятся на сайте WikiSort.ru .