Ориентация кривой - Curve orientation

В математика, а положительно ориентированная кривая плоский простая замкнутая кривая (то есть кривая на плоскости, начальная точка которой также является конечной точкой и которая не имеет других самопересечений), так что при движении по ней внутренняя кривая всегда находится слева (и, следовательно, кривая, внешняя по отношению к верно). Если в приведенном выше определении поменять местами влево и вправо, то получится отрицательно ориентированная кривая.

Важным для этого определения является тот факт, что каждая простая замкнутая кривая допускает четко определенную внутренность; что следует из Теорема Жордана.

Все простые замкнутые кривые можно отнести к отрицательно ориентированным (по часовой стрелке ), положительно ориентированные (против часовой стрелки ), или же неориентируемый. В внутренний цикл кольцевой дороги в Соединенных Штатах (или других странах, где люди ездят по правой стороне дороги) будет примером отрицательно ориентированной кривой (по часовой стрелке). А круг ориентированный против часовой стрелки является примером положительно ориентированной кривой. Тот же круг, ориентированный по часовой стрелке, будет отрицательно ориентированной кривой.

Концепция чего-либо ориентация кривой - это лишь частный случай понятия ориентация из многообразие (то есть помимо ориентации кривой можно говорить еще об ориентации поверхность, гиперповерхность, так далее.). Здесь внутренняя и внешняя части кривой наследуют обычную ориентацию плоскости. Положительная ориентация на кривой - это ориентация, которую она наследует как границу ее внутренней части; негативная ориентация унаследована извне.

Ориентация простого многоугольника

Выбор опорных точек.

В двух измерениях, если задан упорядоченный набор из трех или более связанных вершин (точек) (например, в соедините точки ) который образует простой многоугольник, ориентация полученного многоугольник напрямую связано с знак угла в любом вершина из выпуклый корпус многоугольника, например, угла ABC на рисунке. В расчетах знак меньшего угла, образованного парой векторов, обычно определяется знаком перекрестное произведение векторов. Последний можно рассчитать как знак детерминант матрицы их ориентации. В частном случае, когда два вектора определяются двумя отрезки линии с общей конечной точкой, такой как стороны BA и BC угла ABC в нашем примере, матрица ориентации может быть определена следующим образом:

Формулу для его определителя можно получить, например, используя метод расширение кофактора:

Если определитель отрицательный, то многоугольник ориентирован по часовой стрелке. Если определитель положительный, многоугольник ориентирован против часовой стрелки. Определитель отличен от нуля, если точки A, B и C не равны нулю.коллинеарен. В приведенном выше примере с точками, расположенными в порядке A, B, C и т. Д., Определитель отрицательный, и поэтому многоугольник повернут по часовой стрелке.

Практические соображения

В практических приложениях обычно учитываются следующие соображения.

Чтобы найти подходящую вершину, не нужно строить выпуклую оболочку многоугольника. Обычный выбор - это вершина многоугольника с наименьшей X-координатой. Если их несколько, выбирается тот с наименьшей Y-координатой. Гарантируется, что это вершина выпуклой оболочки многоугольника. В качестве альтернативы, вершина с наименьшей координатой Y среди вершин с наибольшими координатами X или вершина с наименьшей координатой X среди вершин с наибольшими координатами Y (или любая другая из 8 "наименьших, наибольших" X / Y комбинации) также подойдут. После выбора вершины выпуклой оболочки можно применить формулу, используя предыдущую и следующую вершины, даже если они не находятся на выпуклой оболочке, так как на этой вершине не может быть локальной вогнутости.

Если ориентация выпуклый многоугольник ищется, то, конечно, можно выбрать любую вершину.

По числовым причинам обычно используется следующая эквивалентная формула для определителя:

Последняя формула имеет на четыре умножения меньше. Что более важно в компьютерных вычислениях, используемых в большинстве практических приложений, таких как компьютерная графика или же CAD, абсолютные значения множителей обычно меньше (например, когда A, B, C находятся в пределах одного квадрант ), что дает меньшее числовая ошибка или, в крайних случаях, избегая арифметическое переполнение.

Если заранее не известно, что последовательность точек определяет простой многоугольник, следует иметь в виду следующее.

Для самопересекающийся многоугольник (сложный многоугольник ) (или для любой самопересекающейся кривой) не существует естественного понятия «внутренность», следовательно, ориентация не определена. В то же время в геометрия и компьютерная графика существует ряд концепций, заменяющих понятие «внутренности» для замкнутых непростых кривых; см., например, "заливка " и "номер намотки ".

В «легких» случаях самопересечения с выродиться вершины, когда разрешены три последовательные точки, находятся на одном и том же прямая линия и образуют угол с нулевым градусом, концепция «внутреннего» все еще имеет смысл, но при выборе проверяемого угла необходимо проявлять особую осторожность. В данном примере представьте, что точка A лежит на отрезке BC. В этой ситуации угол ABC и его определитель будут равны 0, следовательно, бесполезны. Решение состоит в том, чтобы проверить последовательные углы вдоль многоугольника (BCD, DEF, ...), пока не будет найден ненулевой определитель (если все точки не лежат на одном и том же прямая линия ). (Обратите внимание, что точки C, D, E находятся на одной прямой и образуют угол 180 градусов с нулевым определителем.)

Местная вогнутость

Как только ориентация многоугольника, сформированного из упорядоченного набора вершин, известна, вогнутость локальной области многоугольника можно определить с помощью второй матрицы ориентации. Эта матрица состоит из трех последовательных вершин, которые проверяются на вогнутость. Например, в изображенном выше многоугольнике, если бы мы хотели узнать, соответствует ли последовательность точек F-G-H вогнутый, выпуклый, или коллинеарной (плоской), строим матрицу

Если определитель этой матрицы равен 0, то последовательность коллинеарна - не вогнутая и не выпуклая. Если определитель имеет тот же знак, что и матрица ориентации для всего многоугольника, то последовательность выпуклая. Если знаки различаются, то последовательность вогнутая. В этом примере многоугольник ориентирован отрицательно, но определитель для точек F-G-H положительный, поэтому последовательность F-G-H вогнута.

В следующей таблице показаны правила определения того, является ли последовательность точек выпуклой, вогнутой или плоской:

Отрицательно ориентированный многоугольник (по часовой стрелке)Положительно ориентированный многоугольник (против часовой стрелки)
определитель матрицы ориентации для локальных точек отрицателенвыпуклая последовательность точеквогнутая последовательность точек
определитель матрицы ориентации для локальных точек положителенвогнутая последовательность точеквыпуклая последовательность точек
определитель матрицы ориентации для локальных точек равен 0коллинеарная последовательность точекколлинеарная последовательность точек

Смотрите также

Рекомендации

внешняя ссылка