Трехмерная компьютерная графика
| Категория реферата: Рефераты по информатике, программированию
| Теги реферата: шпаргалки по гражданскому, свобода реферат
| Добавил(а) на сайт: Патрикия.
Предыдущая страница реферата | 3 4 5 6 7 8 9 10 11 12 13 | Следующая страница реферата
3. Удаление невидимых линий и поверхностей
Задача удаления невидимых линий и поверхностей является одной из наиболее сложных в машинной графике. Алгоритмы удаления невидимых линий и поверхностей служат для определения линий ребер, поверхностей или объемов, которые видимы или невидимы для наблюдателя, находящегося в заданной точке пространства.
Необходимость удаления невидимых линий, ребер, поверхностей или объемов
проиллюстрирована рис.3.1. На рис.4.1, а приведен типичный каркасный чертеж
куба. Его можно интерпретировать двояко: как вид куба сверху, слева или
снизу, справа. Удаление тех линий или поверхностей, которые невидимы с
соответствующей точки зрения, позволяют избавиться от неоднозначности.
Результаты показаны на рис.4.1, b и c.
Сложность задачи удаления невидимых линий и поверхностей привела к
появлению большого числа, различных способов ее решения. Многие из них
ориентированы на специализированные приложения. Наилучшего решения общей
задачи удаления невидимых линий и поверхностей не существует. Для
моделирования процессов в реальном времени, например, для авиа тренажеров, требуются быстрые алгоритмы, которые могут порождать результаты с частотой
видео генерации (30 кадр/с). Для машинной мультипликации требуются
алгоритмы, которые могут генерировать сложные реалистические изображения, в
которых представлены тени, прозрачность и фактура, учитывающие эффекты
отражения и преломления цвета в мельчайших оттенках. Подобные алгоритмы
работают медленно, и зачастую на вычисления требуется несколько минут или
даже часов. Строго говоря, учет эффектов прозрачности, фактуры, отражения и
т. п. не входит в задачу удаления невидимых линий или поверхностей.
Естественнее считать их частью процесса визуализации изображения. Процесс
визуализации является интерпретацией или представлением изображения или
сцены в реалистической манере. Однако многие из этих эффектов встроены в
алгоритмы удаления невидимых поверхностей и поэтому будут затронуты.
Существует тесная взаимосвязь между скоростью работы алгоритма и
детальностью его результата. Ни один из алгоритмов не может достигнуть
хороших оценок для этих двух показателей одновременно. По мере создания все
более быстрых алгоритмов можно строить все более детальные изображения.
Реальные задачи, однако, всегда будут требовать учета еще большего
количества деталей.
Алгоритмы удаления невидимых линий или поверхностей можно классифицировать по способу выбора системы координат или пространства, в котором они работают. Алгоритмы, работающие в объектном пространстве, имеют дело с физической системой координат, в которой описаны эти объекты. При этом получаются весьма точные результаты, ограниченные, вообще говоря, лишь точностью вычислений. Полученные изображения можно свободно увеличивать во много раз. Алгоритмы, работающие в объектном пространстве, особенно полезны в тех приложениях, где необходима высокая точность. Алгоритмы же, работающие в пространстве изображения, имеют дело с системой координат того экрана, на котором объекты визуализируются. При этом точность вычислений ограничена разрешающей способностью экрана. Результаты, полученные в пространстве изображения, а затем увеличенные во много раз, не будут соответствовать исходной сцене. Алгоритмы, формирующие список приоритетов работают попеременно в обеих упомянутых системах координат.
Объем вычислений для любого алгоритма, работающего в объектном
пространстве, и сравнивающего каждый объект сцены со всеми остальными
объектами этой сцены, растет теоретически как квадрат числа объектов ( n2
). Аналогично, объем вычислений любого алгоритма, работающего в
пространстве изображения и сравнивающего каждый объект сцены с позициями
всех пикселов в системе координат экрана, растет теоретически, как nN.
Здесь n обозначает количество объектов (тел, плоскостей или ребер) в сцене, а N - число пикселов. Теоретически трудоемкость алгоритмов, работаюoих в
объектном пространстве, меньше трудоемкости алгоритмов, работающих в
пространстве изображения, при n < N. Поскольку N обычно равно ( 512 )2, то
теоретически большинство алгоритмов следует реализовывать в объектном
пространстве. Однако на практике это не так. Дело в том, что алгоритмы, работающие в пространстве изображения, более эффективны потому, что для них
легче воспользоваться преимуществом когерентности при растровой реализации.
Далее дается изложение некоторых алгоритмов, работающих как в объектном пространстве, так и в пространстве изображения. Каждый из них иллюстрирует одну или несколько основополагающих идей теории алгоритмов удаления невидимых линий и поверхностей.
1. Алгоритм плавающего горизонта
Алгоритм плавающего горизонта чаще всего используется для удаления невидимых линий трехмерного представления функций, описывающих поверхность в виде
F ( x, у, z ) = 0
Подобные функции возникают во многих приложениях в математике, технике, естественных науках и других дисциплинах.
Существует много алгоритмов, использующих этот подход. Поскольку в приложениях в основном нас интересует описание поверхности, этот алгоритм обычно работает в пространстве изображения. Главная идея данного метода заключается в сведении трехмерной задачи к двумерной путем пересечения исходной поверхности последовательностью параллельных секущих плоскостей, имеющих постоянные значения координат x, y или z.
На рис. 3.2 приведен пример, где указанные параллельные плоскости определяются постоянными значениями z. Функция F ( x, у, z ) = 0 сводится к последовательности кривых, лежащих в каждой из этих параллельных плоскостей, например к последовательности y = f ( x, z ) или y = g ( y, z ) где z постоянно на каждой из заданных параллельных плоскостей.
Итак, поверхность теперь складывается из последовательности кривых, лежащих в каждой из этих плоскостей, как показано на рис. 3.3. Здесь
предполагается, что полученные кривые являются однозначными функциями
независимых переменных. Если спроецировать полученные кривые на плоскость z
= 0, то сразу становится ясна идея алгоритма удаления невидимых участков
исходной поверхности. Алгоритм сначала упорядочивает плоскости
z = const по возрастанию расстояния до них от точки наблюдения. Затем для каждой плоскости, начиная с ближайшей к точке наблюдения, строится кривая, лежащая на ней. Алгоритм удаления невидимой линии заключается в следующем:
Если на текущей плоскости при некотором заданном значении x соответствующее значение y на кривой больше значения y для всех предыдущих кривых при этом значении x, то текущая кривая видима в этой точке; в противном случае она невидима.
Реализация данного алгоритма достаточно проста. Для хранения максимальных
значений y при каждом значении x используется массив, длина которого равна
числу различимых точек (разрешению) по оси x в пространстве изображения.
Значения, хранящиеся в этом массиве, представляют собой текущие значения
«горизонта». Поэтому по мере рисования каждой очередной кривой этот
горизонт «всплывает». Фактически этот алгоритм удаления невидимых линий
работает каждый раз с одной линией.
Алгоритм работает очень хорошо до тех пор, пока какая-нибудь очередная
кривая не окажется ниже самой первой из кривых. Как показано на рис.3.4,а.
Подобные кривые, естественно, видимы и представляют собой нижнюю сторону
исходной поверхности. Однако алгоритм будет считать их невидимыми. Нижняя
сторона поверхности делается видимой, если модифицировать этот алгоритм, включив в него нижний горизонт, который опускается вниз по ходу работы
алгоритма. Это реализуется при помощи второго массива, длина которого равна
числу различимых точек по оси x в пространстве изображения. Этот массив
содержит наименьшие значения y для каждого значения x. Алгоритм теперь
становится таким:
Если на текущей плоскости при некотором заданном значении x соответствующее значение y на кривой больше максимума или меньше минимума по y для всех предыдущих кривых при этом x, то текущая кривая видима. В противном случае она невидима.
Полученный результат показан на рис. 3.4, b.
В изложенном алгоритме предполагается, что значение функции, т. е. y, известно для каждого значения x в пространстве изображения. Однако если
для каждого значения x нельзя указать (вычислить) соответствующее ему
значение у, то невозможно поддерживать массивы верхнего и нижнего плавающих
горизонтов. В таком случае используется линейная интерполяция значений у
между известными значениями для того, чтобы заполнить массивы верхнего и
нижнего плавающих горизонтов, как показано на рис. 3.5. Если видимость
кривой меняется, то метод с такой простой интерполяцией не даст корректного
результата. Этот эффект проиллюстрирован рис. 3.6,а. Предполагая, что
операция по заполнению массивов проводится после проверки видимости, получаем, что при переходе текущей кривой от видимого к невидимому
состоянию (сегмент АВ на рис. 3.6,а), точка (xn+k, yn+k ) объявляется
невидимой. Тогда участок кривой между точками (xn, yn) и (xn+k, yn+k ) не
изображается и операция по заполнению массивов не производится. Образуется
зазор между текущей и предыдущей кривыми Если на участке текущей кривой
происходит переход от невидимого состояния к видимому (сегмент CD на рис.
3.6,а), то точка (xm+k, ym+k ) объявляется видимой, а участок кривой между
точками (xm, ym) и (xm+k, ym+k ) изображается и операция по заполнению
массивов проводится. Поэтому изображается и невидимый кусок сегмента CD.
Кроме того, массивы плавающих горизонтов не будут содержать точных значений
у. А это может повлечь за собой дополнительные нежелательные эффекты для
последующих кривы. Следовательно, необходимо решать задачу о поиске точек пересечения сегментов текущей и
предшествующей кривых.
Существует несколько методов получения точек пересечения кривых. На растровых дисплеях значение координаты x можно увеличивать на 1, начиная с xn или xm (рис. 3.6,а). Значение у, соответствующее текущему значению координаты х в пространстве изображения, получается путем добавления к значению у, соответствующему предыдущему значению координаты x, вертикального приращения (y вдоль заданной кривой. Затем определяется видимость новой точки с координатами (x + 1, y + (y ). Если эта точка видима, то активируется связанный с ней пиксел. Если невидима, то пиксел не активируется, а x увеличивается на 1. Этот процесс продолжается до тех пор, пока не встретится xn+k или xm+k. Пересечения для растровых дисплеев определяются изложенным методом с достаточной точностью. Близкий и даже более элегантный метод определения пересечений основан на двоичном поиске.
Точное значение точки пересечения двух прямолинейных отрезков, которые
интерполируют текущую и предшествующую кривые, между точками (xn, yn) и
(xn+k, yn+k ) (рис. 3.6) задается формулами:
[pic] где
[pic]
а индексы c и p соответствуют текущей и предшествующей кривым. Полученный результат показан на рис. 3.6,b. Теперь алгоритм излагается более формально.
Рекомендуем скачать другие рефераты по теме: предмет культурологии, реферат на тему организация.
Категории:
Предыдущая страница реферата | 3 4 5 6 7 8 9 10 11 12 13 | Следующая страница реферата