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