Модифицированный алгоритм триангуляции Делоне::Журнал СА 10.2017
www.samag.ru
Журнал «БИТ. Бизнес&Информационные технологии»      
Поиск   
              
 www.samag.ru    Web  0 товаров , сумма 0 руб.
E-mail
Пароль  
 Запомнить меня
Регистрация | Забыли пароль?
Журнал "Системный администратор"
Журнал «БИТ»
Подписка
Архив номеров
Где купить
Наука и технологии
Авторам
Рекламодателям
Контакты
   

  Опросы
1001 и 1 книга  
19.03.2018г.
Просмотров: 6828
Комментарии: 0
Машинное обучение с использованием библиотеки Н2О

 Читать далее...

12.03.2018г.
Просмотров: 7360
Комментарии: 0
Особенности киберпреступлений в России: инструменты нападения и защита информации

 Читать далее...

12.03.2018г.
Просмотров: 4611
Комментарии: 0
Глубокое обучение с точки зрения практика

 Читать далее...

12.03.2018г.
Просмотров: 3159
Комментарии: 0
Изучаем pandas

 Читать далее...

12.03.2018г.
Просмотров: 3965
Комментарии: 0
Программирование на языке Rust (Цветное издание)

 Читать далее...

19.12.2017г.
Просмотров: 3966
Комментарии: 0
Глубокое обучение

 Читать далее...

19.12.2017г.
Просмотров: 6470
Комментарии: 0
Анализ социальных медиа на Python

 Читать далее...

19.12.2017г.
Просмотров: 3311
Комментарии: 0
Основы блокчейна

 Читать далее...

19.12.2017г.
Просмотров: 3591
Комментарии: 0
Java 9. Полный обзор нововведений

 Читать далее...

16.02.2017г.
Просмотров: 7450
Комментарии: 0
Опоздавших не бывает, или книга о стеке

 Читать далее...

17.05.2016г.
Просмотров: 10814
Комментарии: 0
Теория вычислений для программистов

 Читать далее...

30.03.2015г.
Просмотров: 12526
Комментарии: 0
От математики к обобщенному программированию

 Читать далее...

18.02.2014г.
Просмотров: 14231
Комментарии: 0
Рецензия на книгу «Читаем Тьюринга»

 Читать далее...

13.02.2014г.
Просмотров: 9263
Комментарии: 0
Читайте, размышляйте, действуйте

 Читать далее...

12.02.2014г.
Просмотров: 7210
Комментарии: 0
Рисуем наши мысли

 Читать далее...

10.02.2014г.
Просмотров: 5518
Комментарии: 3
Страна в цифрах

 Читать далее...

18.12.2013г.
Просмотров: 4749
Комментарии: 0
Большие данные меняют нашу жизнь

 Читать далее...

18.12.2013г.
Просмотров: 3567
Комментарии: 0
Компьютерные технологии – корень зла для точки роста

 Читать далее...

04.12.2013г.
Просмотров: 3276
Комментарии: 0
Паутина в облаках

 Читать далее...

03.12.2013г.
Просмотров: 3508
Комментарии: 1
Рецензия на книгу «MongoDB в действии»

 Читать далее...

02.12.2013г.
Просмотров: 3161
Комментарии: 0
Не думай о минутах свысока

 Читать далее...

Друзья сайта  

 Модифицированный алгоритм триангуляции Делоне

Архив номеров / 2017 / Выпуск №10 (179) / Модифицированный алгоритм триангуляции Делоне

Рубрика: Наука и технологии

Без фото ТЕПЛОВ А.А., бакалавр, МГТУ имени Н.Э. Баумана, кафедра «Программное обеспечение ЭВМ и информационные технологии», Москва, teploff.a@mail.ru

Без фото МАЙКОВ К.А., д.т.н., профессор, МГТУ имени Н.Э. Баумана, кафедра «Программное обеспечение ЭВМ и информационные технологии», Москва, maikov@bmstu.ru

Модифицированный алгоритм
триангуляции Делоне

Приведены результаты сравнительного анализа методов триангуляции Делоне, обладающих высоким быстродействием и низкой ресурсоемкостью. Обосновывается выбор прототипа для последующей модернизации применительно кпостроению динамических трехмерных объектов в реальном времени с практически необходимой степенью детализации. Предложен алгоритм интервального разбиения массива точек триангуляции в соответствии с плотностью распределения, позволяющий избежать ошибок при аппаратной реализации. Проведен анализ предложенного модифицированного алгоритма триангуляции Делоне

Введение

Одним из этапов, определяющих ресурсоемкость построения динамических 3D объектов с заданной степенью детализации, является триангуляция [3, 4]. На практике возникает необходимость определения прототипа метода триангуляции, удовлетворяющего требованию высокого быстродействия и низкой ресурсоемкости с последующей модификацией для конкретного класса задач.

Постановка решаемых задач

Ряд практических задач характеризуется необходимостью моделирования 3D объектов, описанных соответствующим набором точек с неизвестным законом распределения. Примером подобных задач является моделирование горной гряды или сложных и нерегулярных поверхностных структур, значения высот которых заранее получены средствами дистанционного зондирования. В этом случае необходимо произвести триангуляцию на исходном наборе точек, обеспечивающую наибольшую «степень правильности» треугольников, для которой характерно исключение построения «тонких» треугольников [6] с минимальным значением суммы радиусов описанных окружностей.

Проблема «степени правильности» треугольников решается триангуляцией, удовлетворяющей условию Делоне [3].

Известные алгоритмы триангуляции Делоне можно разделить на следующие четыре категории [6]: итеративные алгоритмы, алгоритмы слияния, двухпроходные алгоритмы и пошаговые; основные особенности указанных алгоритмов рассматриваются ниже.

Итеративные алгоритмы построения триангуляции Делоне

В итеративных алгоритмах реализуется последовательное добавление точек в частично построенную триангуляцию Делоне [4]. Трудоемкость итеративных алгоритмов Делоне определяется как O(N2) [6], а для случая равномерного распределения точек – O(N) [6]. Недостатками итеративных алгоритмов Делоне являются большое число итеративных циклов, зависимость алгоритма сортировки от структуры исходных данных, а также необходимость проверки на условие Делоне в каждом цикле. Преимущества итеративных алгоритмов Делоне – простота реализации и высокое быстродействие выбора эффективного алгоритма сортировки, основывающегося на определенном наборе входных данных [4, 8].

Алгоритмы построения триангуляции Делоне слиянием

Алгоритмы слияния реализуют разбиение исходного множества точек на ряд подмножеств, в которых производится построение триангуляций с последующим объединением ряда решений [6]. Трудоемкость алгоритмов слияния составляет всреднем O(N) [6]. Алгоритмам слияния свойственна избыточность, определяемая необходимостью построения выпуклых областей для «узких» полос [6], а следовательно, формированием длинных, «узких» треугольников [6], перестраиваемых при слиянии. Алгоритмы слияния обладают высоким быстродействием, что обуславливает их практическое преимущество.

Двухпроходные алгоритмы построения триангуляции Делоне

Преимущественная особенность двухпроходных алгоритмов состоит в том, что на первом цикле строится некоторая триангуляция без учета условия Делоне, которая на втором этапе модифицируется согласно условию Делоне [6]. Трудоемкость двухпроходных алгоритмов составляет в среднем O(N) [6], а в наименее благоприятном случае – O(N2) [6]. Недостатком двухпроходных алгоритмов Делоне является необходимость в большом количестве сортировок длякаждой полосы. В то же время данный алгоритм характеризуется высоким быстродействием, т.к. очередной треугольник, попадающий в триангуляцию, не подвергается проверке на удовлетворение условию Делоне, требующему значительных аппаратных ресурсов.

Пошаговые алгоритмы построения триангуляции Делоне

Алгоритмы пошагового построения реализуют лишь треугольники, удовлетворяющие условию Делоне в конечной триангуляции, а поэтому не требуют перестроения [6]. При большой концентрации точек применение пошагового клеточного алгоритма является нецелесообразным. Трудоемкость данного алгоритма в среднем составляет O(N), а в худшем случае – O(N2).

Выбор прототипа для модификации триангуляции Делоне

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

Из приведенных выше результатов сравнительного анализа следует, что двухпроходные алгоритмы триангуляции Делоне, в частности двухпроходной веерный алгоритм [4], лишь частично удовлетворяют критериям высокого быстродействия и низкой ресурсоемкости.

Однако алгоритмы данного типа нуждаются в модификации в целях повышения быстродействия применимо к задачам реального времени. Двухпроходной веерный алгоритм избыточен в определении центра масс точек. Определяя координату точки центр масс по OX или OY, при большом количестве точек нецелесообразно вычислять значение среднего арифметического, и при больших значениях координат точек может произойти переполнение данных, что повлечет за собой ошибку или сбой программы. Поэтому целесообразно все значения точек триангуляции разделить на интервалы по оси X на Δх1, Δх2, Δх3 ... Δхn и по оси Y на Δy1, Δy2, Δy3 ... Δyn. Также необходимо определить количество точек, принадлежащих соответствующим интервалам по осям X и Y. Результирующие формулы получения центра координат масс точек имеют следующий вид:

для координаты хc

Формула 1(1)

где:

  • хc – x-координата точки центра масс;
  • ni – количество точек на i-м интервале;
  • Δхi – i-й интервал на оси X;
  • Xmax – максимальное значение по оси X среди всех точек триангуляции;
  • Xmin – минимальное значение по оси X среди всех точек триангуляции;

для координаты yc

Формула 2(2)

где:

  • yc – y-координата точки центра масс;
  • ni – количество точек на i-м интервале;
  • Δyi – i-й интервал на оси Y;
  • Ymax – максимальное значение по оси Y среди всех точек триангуляции;
  • Ymin – минимальное значение по оси Y среди всех точек триангуляции.

Последующие этапы триангуляции реализуются согласно классическому веерному алгоритму [4]. Схема разработанного модифицированного веерного алгоритма триангуляции Делоне представлена на рис. 1.

Рисунок 1. Схема модифицированного веерного алгоритма триангуляции Делоне
Рисунок 1. Схема модифицированного веерного алгоритма триангуляции Делоне
 
Рисунок 2. Схема определения значений интервалов по оси X
Рисунок 2. Схема определения значений интервалов по оси X
 
Рисунок 3. Схема определения значений полярного угла для исходного массива координат точек
Рисунок 3. Схема определения значений полярного угла для исходного массива координат точек
 
Рисунок 4. Схема построения ребра, соединяющего точки исходного массива
Рисунок 4. Схема построения ребра, соединяющего точки исходного массива

Наиболее трудоемкими этапами в представленной схеме являются этапы сортировки и построения триангуляции до выпуклой. В качестве алгоритма сортировки был выбран алгоритм слияния [2], а в качестве алгоритма построения выпуклой триангуляции – алгоритм Грэхема [7]. Оба алгоритма работают за приемлемое время и являются наиболее предпочтительными в практическом аспекте среди своих представителей.

Анализ модифицированного веерного алгоритма триангуляции Делоне

Из приведенной на рис. 1 схемы видно, что значение времени построения триангуляции модифицируемым веерным алгоритмом определяется выражением:

Формула 3(3)

где:

  • T1,T2 – значения времени вычислений оптимального числа интервалов по осям X и Y соответственно;
  • T3,T4 – значения времени вычислений Xmin и Xmax соответственно;
  • T5,T6 – значения времени вычислений Ymin и Ymax соответственно;
  • T7,T8 – значения времени вычислений величин интервалов по осям X и Y соответственно;
  • T9 – значение времени вычисления величин полярного угла каждой точки массива относительно точки A(Xc,Yc);
  • T10 – значение времени сортировки слиянием [2] всех точек по полярному углу относительно точки A(Xc,Yc);
  • T11 – значение времени построения ребра от каждой точки массива к точке A(Xc,Yc);
  • T12 – значение времени достроения триангуляции до выпуклой;
  • T13 – значение времени перестроения триангуляции, удовлетворяющей условию Делоне;
  • n – массив значений координат точек.

Рассмотрим каждую временную зависимость отдельно.

При определении оптимального числа интервалов по оси X и Y, воспользуемся правилом Стерджеса [9], согласно которому количество интервалов n определяется как:

Формула 4,

где:

  • N – общее число наблюдений величины;
  • [x] – целая часть числа x.

Очевидно, что временные зависимости T1 и T2 имеют константные представления c1 и c2.

На этапах определения значений Xmin, Xmax, Ymin, Ymax псевдокод будет выглядеть следующим образом:

Xmin ← M[0]

for i ← 1 to lenght(M) – 1

    if Xmin › M[i]

       Xmin ← M[i]

Xmax ← M[0]

for i ← 1 to lenght(M) – 1

    if Xmax < M[i]

       Xmax ← M[i]

Ymin ← M[0]

for i ← 1 to lenght(M) – 1

    if Ymin › M[i]

       Ymin ← M[i]

Ymax ← M[0]

for i ← 1 to lenght(M) – 1

    if Ymax < M[i]

       Ymax ← M[i]

Из вышеуказанного псевдокода отчетливо видно, что время нахождения максимального или минимального значения величин x или y имеет линейную зависимость O(N), следовательно, T3(n), T4(n),T5(n),T6(n), имеют временную характеристику O(N) соответственно.

Схема определения значений интервалов по оси X представлена на рис. 2.

Из выше представленной схемы также видна линейная временная зависимость O(N), т.к. в определении величин участвует весь набор координат значений массива точек. Схема определения величин интервалов по оси Y имеет аналогичную структуру и временные характеристики, следовательно, временная зависимость для T7(n) и T8(n) имеет вид O(N).

Схема определения значений полярного угла для исходного массива точек представлена на рис. 3.

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

for points to points

    # Если точка лежит на оси координат между I и IV четвертями

    if point.x ≥ Xc and point.y = Yc

        point.angle ← 0

    # Если точка лежит строго в I четверти

    else if point.x > Xc and point.y > Yc

        foundation ← |point.x – Xc|

        perpendicular ← |point.y – Yc|

        point.angle ← arctg(perpendicular/foundation)

    # Если точка лежит на оси координат между I и II четвертями

    else if point.x = Xc and point.y > Yc

        point.angle ← p/2

    # Если точка лежит строго в II четверти

    else if point.x < Xc and point.y > Yc

        foundation ← |point.y – Yc|

        perpendicular ← |point.x – Xc|

        point.angle ← p/2 + arctg(perpendicular/foundation)

    # Если точка лежит на оси координат между II и III четвертями

    if point.x < Xc and point.y = Yc

        point.angle ← p

    # Если точка лежит строго в III четверти

    if point.x < Xc and point.y > Yc

        foundation ← |point.x – Xc|

        perpendicular ← |point.y – Yc|

        point.angle ← p + arctg(perpendicular/foundation)

    # Если точка лежит на оси координат между III и IV четвертями

    if point.x = Xc and point.y < Yc

        point.angle ← 3p/2

    # Если точка лежит строго в IV четверти

    if point.x > Xc and point.y < Yc

        foundation ← |point.y – Yc|

        perpendicular ← |point.x – Xc|

        point.angle ← 3p/2 + arctg(perpendicular/foundation)

Очевидно, что временная характеристика определения значений полярного угла для исходного массива координат точек имеет вид O(N), следовательно, T9(n) = O(N).

Как показано в [2], сортировка слиянием имеет временную зависимость вида O(N), следовательно, T10(n) = O(NlnN).

Схема построения ребра, соединяющего точки исходного массива, представлена на рис. 4.

Псевдокод вышеуказанной схемы будет иметь вид:

for i ← 0 to length(Points) – 1

    draw(Xc,Yc,Points[i].x, Points[i].y)

Временная характеристика также линейна, следовательно, T11(n) = O(N).

Достроение получившейся триангуляции до выпуклой осуществляется согласно алгоритму Грэхема [1, 7]. В качестве входных данных процедуры выступает множество точек Q, где |Q|≥3. В ней вызывается функция Top(S), которая возвращает точку, находящуюся на вершине стека S, не изменяя при этом его содержимое. Кроме того, используется также функция NextToTop(S), которая возвращает точку, расположенную в стеке S, на одну позицию ниже от верхней точки; стек S при этом не изменяется.

Graham(Q)

    Пусть p0 – точка из множества Q с минимальной координатой.

    Пусть ‹p1, p2,...,pN› – точки множества Q, отсортированные

    в порядке возрастания полярного угла.

Push(p0,S)

Push(p1,S)

 

for i=2 to N do

    while угол, образованный точками NextToTop(S), Top(S) и pi,

    образуют не левый поворот

        # при движении по ломаной, образованной этими

        # точками, движение осуществляется прямо или вправо

            do Pop(S)

            Push(pi,S)

return S

Время работы процедуры Graham равно O(NlnN), где N=length(Q). Как несложно показать, что циклу while потребуется время O(N), а сортировка полярных углов займет O(NlnN) времени, откуда и следует общая асимптотика процедуры Graham, следовательно, T12(n) = O(NlnN).

Временная характеристика перестроения триангуляции, удовлетворяющей условию Делоне, как показано в [4], имеет линейную зависимость O(N), таким образом, T13(n) = O(N).

Если подставить все найденные временные характеристики в выражение (3), то результирующая временная зависимость будет иметь вид:

T(n) = c1+c2+O(N)+O(N)+O(N)+O(N)+O(N)+O(N)+O(N)+ +O(NlnN)+O(N)+O(NlnN)+O(N)

или

T(n) = O(NlnN)

Проведенный теоретический анализ временных характеристик модифицированного алгоритма триангуляции Делоне подтверждает работоспособность и высокое быстродействие предложенного алгоритма.

Выводы

В результате проведенного сравнительного анализа практически востребованных алгоритмов триангуляции Делоне, показано, что рассмотренные методы не удовлетворяют требованиям построения в реальном времени динамических трехмерных объектов с заранее определенной степенью детализации, а следовательно, возникает практическая необходимость их модификации. Предложена модификация веерного двухпроходного алгоритма триангуляции Делоне, функциональной особенностью которого является вычисление значений центра масс массива координат точек триангуляции посредством разбиения массива точек на подмножества по оси X и Y. Произведен анализ временных характеристик модифицированного алгоритма триангуляции Делоне. Указанные вычисления позволяют существенно выиграть в производительности на большом массиве точек при определении координат точки центра масс и избежать переполнения данных, а следовательно, ошибки при программной реализации.

  1. Кнут Д.Э. Искусство программирования. Том 1. Основные алгоритмы. – М.: Вильямс, 2008. – 680 с.
  2. Кнут Д.Э. Искусство программирования. Том 3. Сортировка и поиск. – М.: Вильямс, 2008. – 800 с.
  3. Мандельброт Б. Фрактальная геометрия природы. – М.: Институт компьютерных исследований, 2002. – 656 с.
  4. Скворцов А. В. Триангуляция Делоне и ее применение. – Томск: Изд-во Томского университета, 2002. – 128 с.
  5. Скворцов А.В. Построение триангуляции Делоне за линейное время. – Томск: Изд-во Томского университета, 1999. – С.120-126.
  6. Скворцов А.В., Мирза Н.С. Алгоритмы построения и анализа триангуляции. – Томск: Изд-во Томского университета, 2006. – 168 с.
  7. Томас Х. Кормен, Чарльз И. Лейзерон, Рональд Л. Ривест, Клиффорд Штайн. Алгоритмы: построение и анализ, 3-е изд.: Пер. с англ. – М.: Вильямс, 2013. – 1328 с.
  8. Шайдуров В.В. Многосеточные методы конечных элементов. – М.: Наука, 1989. – 288 с.
  9. Sturges H. (1926). The choice of a class-interval. J. Amer. Statist. Assoc., 21, 65-66.

Ключевые слова: виртуальная реальность, триангуляция на заданном массиве точек, триангуляция Делоне, построение динамических трехмерных объектов.


The modified Delaunay’s triangulation algorithm

Teplov A.A., Bachelor, MSTU Bauman, Department of "Software and Information Technologies", Moscow, teploff.a@mail.ru

Maikov K.A., Doctor of Technical Sciences, Professor, MSTU Bauman, Department of "Software and Information Technologies", Moscow, maikov@bmstu.ru

Abstract: The results of the comparative analysis of the virtually popular methods of the Delaunay’s triangulation with high performance and low resource consumption are described in this article. The choice of the method for further modernization with the aim of building of dynamic 3-D objects in real time with a certain degree of detail is justified. One of the main stages of a fibered the two-pass algorithm of the Delaunay’s triangulation is modified. There is the proposal of the algorithm for the interval partitioning of the cell array of the triangulation in accordance with the density of distribution, allowing to avoid the errors in the hardware implementation.

Keywords: virtual reality, triangulation on a given cell array, Delaunay’s triangulation, building of dynamic 3-D objects.


Комментарии отсутствуют

Добавить комментарий

Комментарии могут оставлять только зарегистрированные пользователи

               Copyright © Системный администратор

Яндекс.Метрика
Tel.: (499) 277-12-45
E-mail: sa@samag.ru