Jump to content

Алгоритм отсечения Грейнера – Хормана

Алгоритм Грейнера-Хормана используется в компьютерной графике для отсечения полигонов . [ 1 ] Он работает лучше, чем алгоритм отсечения Ватти , но не может справиться с вырождениями . [ 2 ] Он может обрабатывать как самопересекающиеся, так и невыпуклые многоугольники. Его можно тривиально обобщить для вычисления других логических операций над многоугольниками , таких как объединение и разность.

Алгоритм основан на определении «внутренности» многоугольника по числу витков . Он считает, что области с нечетным числом витков находятся внутри многоугольника; это известно как правило чет-нечет . В качестве входных данных он принимает два списка полигонов.

В своей исходной форме алгоритм разделен на три этапа:

  • На первом этапе вычисляются попарные пересечения ребер многоугольников. В оба полигона в точках пересечения вставляются дополнительные вершины; вершина пересечения содержит указатель на свою копию в другом многоугольнике.
  • На втором этапе каждый перекресток помечается либо как въездной, либо как выездной перекресток . Это достигается путем оценки правила четности-нечета для первой вершины, которое позволяет узнать, находится ли первая вершина внутри или снаружи другого многоугольника. Затем, следуя границам многоугольника, пересечения отмечаются чередующимися флажками (следующее пересечение после входного пересечения должно быть выходным).
  • На третьем этапе формируется результат. Алгоритм начинается с необработанного перекрестка и выбирает направление обхода на основе флага входа/выхода: для входного пересечения он движется вперед, а для выходного пересечения он движется в обратном направлении. Вершины добавляются к результату до тех пор, пока не будет найдено следующее пересечение; затем алгоритм переключается на соответствующую вершину пересечения в другом многоугольнике и снова выбирает направление обхода, используя то же правило. Если следующее пересечение уже обработано, алгоритм завершает текущий компонент вывода и начинает снова с необработанного пересечения. Вывод считается завершенным, когда необработанных пересечений больше нет.

Алгоритм не ограничивается полигонами и может обрабатывать произвольные параметрические кривые как сегменты, если существует подходящая процедура попарного пересечения.

Основным недостатком оригинального алгоритма Грейнера-Хормана является тот факт, что он не может обрабатывать вырождения, такие как общие ребра или пересечения точно в вершине. В оригинальной статье предлагается возмущать вершины, чтобы удалить их.

См. также

[ редактировать ]
  1. ^ Грейнер, Гюнтер; Кай Хорманн (1998). «Эффективное отсечение произвольных полигонов» . Транзакции ACM с графикой . 17 (2): 71–83. дои : 10.1145/274363.274364 .
  2. ^ Ионел Дэниел Строу. «Эффективное отсечение произвольных многоугольников» . Проверено 17 мая 2014 г.
[ редактировать ]
Arc.Ask3.Ru: конец переведенного документа.
Arc.Ask3.Ru
Номер скриншота №: 9d92dc56c3231dd6297443a9548cb9ca__1691894040
URL1:https://arc.ask3.ru/arc/aa/9d/ca/9d92dc56c3231dd6297443a9548cb9ca.html
Заголовок, (Title) документа по адресу, URL1:
Greiner–Hormann clipping algorithm - Wikipedia
Данный printscreen веб страницы (снимок веб страницы, скриншот веб страницы), визуально-программная копия документа расположенного по адресу URL1 и сохраненная в файл, имеет: квалифицированную, усовершенствованную (подтверждены: метки времени, валидность сертификата), открепленную ЭЦП (приложена к данному файлу), что может быть использовано для подтверждения содержания и факта существования документа в этот момент времени. Права на данный скриншот принадлежат администрации Ask3.ru, использование в качестве доказательства только с письменного разрешения правообладателя скриншота. Администрация Ask3.ru не несет ответственности за информацию размещенную на данном скриншоте. Права на прочие зарегистрированные элементы любого права, изображенные на снимках принадлежат их владельцам. Качество перевода предоставляется как есть. Любые претензии, иски не могут быть предъявлены. Если вы не согласны с любым пунктом перечисленным выше, вы не можете использовать данный сайт и информация размещенную на нем (сайте/странице), немедленно покиньте данный сайт. В случае нарушения любого пункта перечисленного выше, штраф 55! (Пятьдесят пять факториал, Денежную единицу (имеющую самостоятельную стоимость) можете выбрать самостоятельно, выплаичвается товарами в течение 7 дней с момента нарушения.)