Научная статья на тему 'Алгоритмы построения виртуальных пространств'

Алгоритмы построения виртуальных пространств Текст научной статьи по специальности «Математика»

CC BY
351
59
i Надоели баннеры? Вы всегда можете отключить рекламу.

Аннотация научной статьи по математике, автор научной работы — Белоус Наталия Валентиновна, Шубин Игорь Юрьевич, Выродов Алексаццр Павлович

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

i Надоели баннеры? Вы всегда можете отключить рекламу.

Похожие темы научных работ по математике , автор научной работы — Белоус Наталия Валентиновна, Шубин Игорь Юрьевич, Выродов Алексаццр Павлович

iНе можете найти то, что вам нужно? Попробуйте сервис подбора литературы.
i Надоели баннеры? Вы всегда можете отключить рекламу.

The algorithms of virtual spaces building

The problem of 3 dimensional spaces computer real-time modeling is investigated in the article. The two algorithms of virtual spaces building is proposed. The merits and demerits of these algorithms are analyzed. A necessity of their speedup optimization is proven. The basic ways of speed-up is specified.

Текст научной работы на тему «Алгоритмы построения виртуальных пространств»

УДК 371.385:681.3

АЛГОРИТМЫ ПОСТРОЕНИЯ ВИРТУАЛЬНЫХ ПРОСТРАНСТВ

БЕЛОУС Н.В., ВЫРОДОВ А. П.,

ШУБИН И.Ю.

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

Системы построения виртуальных пространств используются при создании компьютерных презентаций, компьютерных обучающих систем и Web-страниц, использующих для представления динамических данных трехмерные объекты. Архитекторы и промышленные дизайнеры применяют системы построения виртуальных пространств при создании статических моделей в целях демонстрации их своим заказчикам. Кроме того, интерфейс операционных систем 2000 года будет также трехмерным. Все это вызывает повышенный интерес как к трехмерной компьютерной графике в целом, так и к способам построения виртуальных пространств в частности.

1. Основные этапы построения трехмерного пространства

Рассмотрим идеализированную модель трехмерного пространства — гипотетический трехмерный коридор, стены которого расположены под прямым углом. Чтобы однозначно задать такую модель, нам потребуется знать:

1) высоту всех стен коридора;

2) соразмещение стен коридора, т.е. одну из проекций коридора на координатные плоскости.

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

Таким образом, первым этапом построения трехмерного пространства является определение расстояния между наблюдателем и объектами пространства, находящимися внутри его угла обзора. Для вычисления указанного расстояния и определения видимых наблюдателем объектов применяется так называемый метод трассировки луча.

На следующем этапе осуществляем поиск текстур (плоских графических изображений), которые необходимо наложить на объекты, найденные на преды-

дущем этапе. Искомое множество текстур однозначно определяется типом объекта и его состоянием.

Вследствие того, что размеры текстур фиксированы, а размеры объектов могут изменяться, возникает необходимость динамического масштабирования текстур. Итак, следующим этапом построения трехмерного пространства является масштабирование текстур, найденных на предыдущем этапе. Подчеркнем, что данный этап необходим только в случае несовпадения размеров текстур с размерами соответствующих объектов. Более подробное описание алгоритмов наложения текстур и их масштабирования можно найти в [1].

На заключительном этапе выполняется прорисовка объектов с наложенными на них отмасштаби-рованными текстурами на экране дисплея, причем эта прорисовка выполняется в порядке, обратном нахождению этих объектов на первом этапе.

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

2. Первый вариант алгоритма трассировки луча

Зададим угол обзора наблюдателя равным 60 градусам. На рис. 1 показан вид сверху идеализированной модели трехмерного пространства с нанесенной на нем позицией наблюдателя, которая задается координатами X и Y, а также вектором направления взгляда P. Сегмент стен, заключенный между точками A и B, должен быть прорисован на экране, так как он находится внутри нашего угла обзора.

Рис.1. Идеализированная модель (вид сверху)

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

РИ, 1998, № 3

123

лучу. Количество лучей целесообразно положить равным количеству столбцов дисплея в текущем видеорежиме. С помощью этого достигается полноэкранная визуализация модели трехмерного пространства. КаЖдый луч выходит из текущих координат наблюдателя под определенным углом, отсчитываемым относительно вектора направления взгляда. Учитывая, что сумма всех углов трассируемых лучей должна быть равной углу обзора наблюдателя, шаг их изменения можно определить по формуле

ДА =

60

VM,

(1)

где да — шаг изменения угла наклона трассируемых лучей; VM — разрешение дисплея по горизонтали в текущем видеорежиме.

Чтобы определить расстояние до зафиксированных точек сегмента стены, мы из текущих координат наблюдателя под определенным углом “ведем” луч до пересечения с этими точками (рис. 1). Рассмотрим более подробно процесс “ведения” луча.

Так как для каждого трассируемого луча нам известен угол его наклона, то мы можем вычислить угловой коэффициент луча по формуле

K = tg a, (2)

где a — угол наклона трассируемого луча; K — угловой коэффициент луча.

Тогда уравнение, описывающее трассируемый луч, можно записать в следующем виде:

Yi = Y + K* (Xi - X). (3)

Здесь Xi и Yi — абсцисса и ордината возможной точки пересечения трассируемого луча со стеной; X, Y — текущие координаты наблюдателя. Координата

Xi изменяется по следующему закону:

(4)

Xi+1 = Xi ± Ь X1 = X ± 1 .

Процесс трассировки луча в данном варианте алгоритма осуществляется следующим образом. При-

давая абсциссе Xi приращение +1, если вектор направления взгляда P наблюдателя совпадает с направлением оси абсцисс, и -1 в противном случае,

вычисляем по формуле (3) ординату Yi. Если точка

с координатами (X i, Yi) не принадлежит стене, то аналогично вычисляем координаты следующей точки и т.д. В программной реализации данного алгоритма для проверки наличия стены в указанной точке мы используем ее координаты в качестве индекса элемента двухмерного массива, описывающего структуру трехмерного пространства. Ненулевое значение элемента массива свидетельствует о наличии в соответствующей точке стены.

Допустим, что в точке С наш луч пересекается со стеной (рис. 1). Обозначим через Cx и Cy координаты пересечения. Тогда по формуле

D = д/(Сх - X)2 + (Cy - Y)2 (5)

определим искомое расстояние D от наблюдателя до точки С стены.

Приведем обобщенную схему данного варианта алгоритма трассировки луча.

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

2. Даем абсциссе Xi приращение в соответствии с соотношением (4).

3. Для текущего значения Xi вычисляем по

формуле (3) соответствующее значение ординаты Yi (т.е. проводим луч для текущего угла просмотра).

4. Проверяем наличие стены в точке с координатами (Xi, Yi).

5. Продолжаем шаги 2—4 до тех пор, пока трассируемый луч не пересечется со стеной или не произойдет выход за пределы трехмерного пространства.

6. При обнаружении в точке с координатами (Xi, Yi) стены определяем расстояние до нее, используя формулу (5).

7. Увеличиваем угол просмотра на заранее вычисленное по формуле (1) значение, после чего весь алгоритм повторяется снова и снова, пока не будут протрассированы все VM пар лучей.

Разработанный выше алгоритм трассировки луча в полной мере осуществляет процесс преобразования двухмерного представления виртуального пространства в трехмерное. Кроме того, достоинством данного алгоритма является простота его программной реализации и высокая точность определения расстояния. Последнее свойство объясняется использованием для вычисления расстояния по формуле (5) математического сопроцессора. Однако описанный алгоритм трассировки луча имеет и ряд недостатков. Самым существенным из них является слишком низкая скорость выполнения. 70 % всего времени расходуется на вычисление квадратного корня по формуле (1) и на проверку пересечения в данной точке луча со стеной. Все это обуславливает необходимость модификации существующего алгоритма с целью повысить скорость выполнения.

3. Второй вариант алгоритма трассировки луча

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

— во-первых, необходимо устранить операцию извлечения квадратного корня, так как даже при использовании математического сопроцессора данная операция влечет за собой существенное замедление работы алгоритма;

— во-вторых, сократить число точек, в которых луч может пересекаться со стеной.

С этой целью создадим новый вид сверху нашего виртуального пространства. Разобьем его на одинаковые квадраты размером, например, 64х64 единиц. Это позволит наблюдателю переместиться на 64 единицы в направлении оси X или Y перед тем, как попасть в другой квадрат. Стены будем строить только на сторонах квадратов. Таким образом, мы имеем стены двух типов:

1) проектирующиеся в точку на оси X (для краткости мы будем в дальнейшем называть их X-стенами);

124

РИ, 1998, № 3

2) проектирующиеся в точку на оси Y (аналогично назовем их Y-стенами).

Вернемся опять к рис.1 и снова будем вести луч до пересечения его со стеной. Но как же определить тип стены, пересеченной лучом? Самый простой способ — трассировать по одному направлению не один луч, а два. При трассировке одного из них будем обращать внимание только на горизонтальные стороны квадратов, где могут находиться Y-стены, а при трассировке другого — только на вертикальные, где могут находиться X-стены. Первое, что нам надо найти, — координаты пересечения нашего луча с горизонтальной (вертикальной) стороной первого встретившегося на пути квадрата. А так как размеры квадратов фиксированы, то координаты следующего пересечения можно легко подсчитать.

Подробнее остановимся на вычислении координат точки пересечения трассируемого луча со стороной первого встретившегося на пути квадрата. Обозначим через Х1 — абсциссу точки пересечения луча с горизонтальной стороной квадрата, через Y1 — ординату точки пересечения луча с вертикальной стороной квадрата, а через X и Y — текущие координаты наблюдателя. Тогда уравнение, описывающее трассируемый луч (уравнение прямой с угловым коэффициентом), запишется в виде

А-Y = к

Х1 - X ,

(6)

откуда находим:

Y1 = K * (Х1 - X) + Y; (7)

Х1 = K-1 * (Y1 - Y) + X . (8)

Коэффициент К в этих формулах имеет то же значение, что и в формуле (2). Отметим, что каждое из полученных преобразований требует предварительного вычисления другого. Поэтому, чтобы избежать такой зависимости, необходимо в формулу (7) вместо абсциссы X1 подставить абсциссу любой другой точки, лежащей на трассируемом луче ( рис. 2).

Рис .2. Геометрическая интерпретация алгоритма трассировки луча

В качестве таковой удобно взять абсциссу первой граничной вертикальной линии X’. Аналогично вместо Y1 в формулу (8) подставим ординату Y’ первой граничной горизонтальной линии ( рис. 2). Теперь формулы (7) и (8) можно переписать в следующем виде:

Y1=K * (X’ - X) + Y; (7*)

Xi=K-1* (Y’ - Y) + X. (8*)

Формулы (7*) и (8*) полностью подходят для проведения вычислений, так как координаты X’ и Y’

могут быть легко определены из следующих соображений.

Пусть координаты наблюдателя X и Y могут принимать значения только из фиксированного диапазона (определяемого размерами виртуального пространства) и необходимо найти абсциссу X’ первой граничной вертикальной линии (рис. 2). Для этого сначала разделим нацело, а затем умножим координату X наблюдателя на величину стороны квадрата, кото -рую положим равной 64 единицам, как и в первом варианте алгоритма. Полученная координата есть абсцисса левой граничной вертикальной линии, а так как на рис. 2 вектор направления взгляда указывает вправо, то необходимо увеличить полученную координату на величину стороны квадрата. Если бы вектор направления взгляда указывал влево, то необходимо было бы уменьшить эту координату на величину стороны квадрата. Аналогично находим ординату Y’ первой граничной горизонтальной линии.

После вычисления координат точки первого пересечения переходим к вычислению координат следующего возможного пересечения. Так как ширина каждого квадрата фиксирована (в данном случае — 64 единицы), определяем по формуле (10) следующую координату Yj+1 точки, с которой пересечется трассируемый луч, если увеличить координату X’ на 64. Таким образом, сразу пропускаем 64 точки карты, так как из ее построения следует, что там стена находиться не может. Аналогично, увеличивая координату Y’ на 64, по рекуррентной формуле (9) определяем координату Xi+1 следующего возможного пересечения. Итак, координаты точек возможного пересечения, начиная со второй, определяются по следующим рекуррентным формулам:

Xi+1 = Xi + K-1 * c; (9)

Yi+i = Yi + K * c, (10)

где c — сторона квадрата.

Как только найдена Х-стена, то чтобы определить расстояние до нее, следует использовать координату Xi, а если найдена Y-стена — следует использовать координату Yi. Действительно, расстояние от точки с координатами (X,Y) до точки с координатами (X’,Y1) или от точки (X,Y) до точки (X1,Y’) (рис. 1) можно определить двумя способами:

1) используя формулу (5);

2) пользуясь соотношениями между сторонами и тригонометрическими функциями углов прямоугольного треугольника.

Как было сказано выше, вычисление искомого расстояния с использованием операции извлечения корня не является эффективным, даже при табулировании функции извлечения корня. Поэтому целесообразно использовать тригонометрические функции от угла наклона а трассируемого луча.

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

Dx = (Xi - X) * cos-1 а, (11)

где Dx—расстояние до точки пересечения трассируемого луча с горизонтальной стороной квадрата.

Аналогично, вычисление расстояния до точки пересечения трассируемого луча с вертикальной стороной квадрата следует производить по формуле: Dy = (Yi - Y) * sin-1 a, (12)

РИ, 1998, № 3

125

где Dy—расстояние до точки пересечения трассируемого луча с вертикальной стороной квадрата.

Угол а в формулах (11) и (12) является углом между трассируемым лучом и вектором направления взгляда.

Приведем общую схему второго варианта алгоритма трассировки луча:

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

2. Определяем абсциссу X’ первой граничной вертикальной линии: координату X наблюдателя сначала делим нацело, а затем умножаем на величину стороны квадрата. Если угол направления взгляда находится в пределах от 0 до 180 градусов (т.е. вектор направления взгляда указывает вправо), то увеличиваем полученную координату на величину стороны квадрата.

3. Для текущего угла просмотра по формуле (7*) определяем координату Ух пересечения трассируемого луча с вертикальной стороной первого квадрата.

iНе можете найти то, что вам нужно? Попробуйте сервис подбора литературы.

4. Проверяем наличие стены в точке с координатами (X’, Ух), т.е. ищем X-стену. Если стена найдена или достигнут предел виртуального пространства, то сразу переходим к п.7, минуя п.5, 6.

5. Увеличиваем координату X’ на величину стороны квадрата (в нашем случае — 64 единицы), если направление вектора взгляда совпадает с направлением оси абсцисс (вектор указывает вправо), иначе уменьшаем координату X’ на указанную величину. Определяем по формуле (10) следующую координату Yi (i=2,3,4...) точки, в которой пересечется наш луч со стороной следующего квадрата.

6. Проверяем наличие стены в точке с координатами (X’, У,). Если стена не найдена и не достигнут предел виртуального пространства, то возвращаемся к п.5, иначе переходим к п.7.

7. Используя формулу (13), определяем расстояние до соответствующей точки Х-стены. Таким образом, мы устранили необходимость вычисления квадратного корня.

8. Осуществляем трассировку второго луча для текущего угла просмотра (т.е. ищем У-стену). Действия, выполняемые на этом этапе, аналогичны действиям, выполняемым в п. 2—7, с той лишь разницей, что вместо формул (7*), (10) и (13) используем формулы (8*), (11) и (12), а вместо координат X, X’, У1, У, — координаты У, У’, X1, X, соответственно.

9. Если для текущего угла просмотра обнаруже -ны У-стена и X-стена одновременно, то сравнив расстояния до них, определяем ближайшую к нам стену, которую и следует прорисовать на экране дисплея.

10. Увеличиваем угол просмотра на заранее вычисленное по формуле (1) значение. После этого весь алгоритм повторяется снова и снова, пока не будут протрассированы все VM пар лучей.

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

4. Проекционные искажения

Оба алгоритма трассировки луча используют одновременно полярные и декартовы системы коорди-

нат. Как следствие, это привело к появлению так называемых “сферических” искажений.

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

Рис.3. Изображение на экране дисплея: а — с компенсацией сферических искажений; б — без компенсации

Так как при подготовке карты стены условно изображались в виде отрезков прямых линий, то расстояние до середины стены, расположенной перпендикулярно к вектору направления взгляда, будет всегда меньше расстояний до ее краев. Следовательно, высота колонки текстуры данной стены будет максимальной в ее середине и станет постепенно уменьшаться при приближении к ее краям. Поэтому изображение на экране дисплея будет иметь вид, показанный на рис. 3,б, вместо вида, показанного на рис. 3,а.

На рис. 3,а показан вид стены с компенсацией “сферических” искажений, а на рис. 3,б — вид стены без компенсации “сферических” искажений. Данные “сферические” искажения являются синусоидальными и поэтому для их компенсации необходимо умножить высоту колонки стены на косинус текущего угла просмотра, т.е. вычисление высоты колонки стены надо выполнять по формуле

Ch = (cos а) * 20 000 / D, (13)

где Ch — высота колонки стены; D — расстояние до стены.

5. Особенности программной реализации алгоритмов трассировки луча

Основной сложностью создания программной реализации данных алгоритмов является обеспечение необходимой частоты смены кадров изображения на экране дисплея (не менее 30 кадров в секунду). Учитывая, что указанные алгоритмы являются циклическими, любая оптимизация их программной реализации, будучи многократно повторенной, даст

126

РИ, 1998, № 3

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

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

В обоих алгоритмах интенсивно используются тригонометрические функции углов наклона трассируемых лучей. Так как угол наклона изменяется дискретно (формула (1)), становится возможным составление таблиц заранее вычисленных для всех возможных углов наклона значений следующих тригонометрических функций: sin-1 a , cos-1 a , tg a, rtg a. После этого для получения значения одной из этих функций достаточно обратиться к соответствующему элементу таблицы, что оказывается гораздо быстрее непосредственного вычисления значения функции арифметическим сопроцессором. Определим размер такой таблицы для графического режима 320x200. В соответствии с формулой (1) шаг изменения угла наклона составляет 60/320=0,1875°. Тогда таблица будет содержать 360°/0,1875°=1920 элементов. Аналогичные вычисления для графического режима 640x480 дают размер таблицы в 3840 элементов. Таким образом, в программной реализации алгоритмов угол a это индекс, изменяющийся в диапазоне от 0 до 1920 (от 0 до 3840), для таблиц тригонометрических функций. Как известно, функция тангенс стремится к бесконечности при значениях аргумента 90 и 270 градусов. Поэтому необходимо ввести дополнительные проверки угла наклона, чтобы избежать в этих точках ошибки деления на нуль.

Благодаря тому, что сторона квадрата имеет фиксированный размер 64 единицы, становится возможным составление таблиц заранее вычисленных значений от функций 64 * tg a, 64 * rtg a, которые используются во втором алгоритме для вычисления координат точек возможного пересечения трассируемого луча со стеной.

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

сто операций над числами с плавающей запятой использовать операции над числами с фиксированной запятой. Желательно применять 32-разрядный формат данных и для дробной части выделить только 8 младших разрядов. Так как для программ построения виртуальных пространств не нужна очень высокая точность (5 и более цифр после запятой), то этих 8 разрядов будет вполне достаточно. Дополнительную информацию о программной реализации алгебры дробных чисел на основе формата чисел с фиксированной запятой, а также о выполнении основных операций над числами с фиксированной запятой можно найти в [2].

Приведенные алгоритмы могут быть применены как для создания системы построения виртуальных пространств, так и для разработки трехмерного программного интерфейса. Программная реализация описанных выше алгоритмов была выполнена на языке программирования Borland C++ 4.2. Так как второй вариант алгоритма предоставляет одинаковые возможности с первым вариантом при более высоком уровне производительности, то именно этот алгоритм рекомендуем использовать в качестве основы создаваемой программной системы.

Пример изображения виртуального пространства, формируемого программой, основанной на втором варианте алгоритма трассировки луча, приведен на рис. 4. Данное трехмерное изображение получено для вида сверху виртуального пространства, показанного на рис. 5. Здесь сегментам стен A, B и D поставлены в соответствие текстуры, приведенные на рис. 7, а сегменту стен C — текстура, приведенная на рис.6.

Рис. 4. Изображение на экране дисплея

Рис. 5. Вид сверху виртуального пространства

РИ, 1998, № 3

127

Л7~и;^иіугітпп гттт.я

Рис. 6. Текстура для сегмента стен C

Рис. 7. Текстуры для сегментов стен: a — A и B; б — D

Заключение

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

тельной системы (500Кб оперативной памяти, 2 Мб пространства на жестком диске, І386 микропроцессор) обладает следующими характеристиками: использование стандартных графических видеорежимов адаптера VGA с 256 цветами, что обеспечивает практически 100% переносимость программы; частота смены кадров составляет 30 кадров в секунду; возможность разбиения виртуального пространства, превышающего объем свободной оперативной памяти на несколько частей, загружаемых в заданной последовательности; возможность наполнения виртуального пространства неподвижными объектами произвольной формы; реализация открывающихся дверей и возможность работы с анимированными текстурами; поддержка 256-цветных спрайтов в форматах PCX и LBM.

Литература:1. Белоус Н.В., Выродов А.П., Шубин И.Ю. О некоторых алгоритмах построения виртуальных пространств // Проблемы бионики. 1998. №48. C. 52—59. 2. Белоус Н.В., Выродов А.И., Шубин И.Ю. Математические модели построения виртуальных пространств //Проблемы бионики. 1998. №49. C. 203—211. 3. Ла Мот А., Ратклифф Дж, Семинаторе М, Тайлер Д. Секреты программирования игр. СПб: Питер, 1995. 616 с.

Поступила в редколлегию 19.09.98 Рецензент: д-р техн. наук Петров Э.Г.

Белоус Наталия Валентиновна, канд. техн. наук, доцент кафедры ПОЭВМ ХТУРЭ. Научные интересы: разработка обучающих программ, гипертекстовых компьютерных учебников, моделирование сложных объектов. Адрес: Украина, 310093, Харьков, ул. Социалистическая, 68-5, кв. 65, тел. 72-76-47.

Шубин Игорь Юрьевич канд. техн. наук, доцент кафедры ПОЭВМ ХТУРЭ. Научные интересы: перспективные информационные технологии, трехмерная компьютерная графика. Адрес: Украина, 310170, Харьков, ул. Акад. Павлова, 134/16, кв. 263, тел. 68-64-89.

Выродов Алексаццр Павлович, студент гр. ПОВТАС 961 ХТУРЭ. Научные интересы: трехмерная компьютерная графика. Адрес: Украина, 310726, Харьков, пр. Ленина, 14.

УДК 519.7

О ДЕЙСТВИЯХ С ЛИНЕЙНЫМИ ЛОГИЧЕСКИМИ ОПЕРАТОРАМИ

ГВОЗДИНСКАЯН.А., ДУДАРЬ З.В., 11ОСЛАВСКИЙСЛ,ШАБАЛОВ-КУШНАРШКОЮ.П.

Рассматривается затронутая в работах [4, 6] тема: линейные логические операторы и соответсвующие им матрицы. Описываются такие действия с линейными логическими операторами как дизъюнкция, произведение и умножение логического скаляра на линейный логический оператор.

Выберем в логическом пространстве L два линейных логических оператора А и В и произвольный вектор l. Применим последовательно к вектору l сначала оператор А, затем оператор В. В результате получим некоторый вектор d=B(Al).

Оператор, переводящий вектор l в вектор d, называется произведением В на А:

(BA)l=B(Al). (1)

Исходя из этого равенства, можно записать следующее, имея в виду, что а и р — некоторые логические скаляры, а l, geL:

(BA)(alvPg)=B(A(alvPg)).

В силу линейности операторов А и В имеют место равенства

B(A(alvPg))=B(a(Al) vP (Ag))=B(aAl)vB( P Ag). Иными словами,

(BA)(alvPg)=a(BA)lvp(BA)g. (2)

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

С=ВА. (3)

Для доказательства этого утверждения выберем в логическом пространстве L некоторый базис. Произвольному вектору leL отвечает координатный столбец [l] в выбранном базисе. Следовательно, [(BA)l]=C[l]. (4)

В то же время

[(BA)l]=[B(Al)]=B[Al]=BА[l]. (5)

Сравнивая равенства (4) и (5), получаем утверждение (3).

Например, возьмем вектор булева пространства размерности 4 [1, 3] l=(0, 1, 1, 0), линейные логические операторы А и В, которым отвечают логические матрицы

128

РИ, 1998, № 3

i Надоели баннеры? Вы всегда можете отключить рекламу.