Научная статья на тему 'Задача обратной трассировки лучей в расширенной постановке'

Задача обратной трассировки лучей в расширенной постановке Текст научной статьи по специальности «Математика»

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

Текст научной работы на тему «Задача обратной трассировки лучей в расширенной постановке»

ЗАДАЧА ОБРАТНОЙ ТРАССИРОВКИ ЛУЧЕЙ В РАСШИРЕННОЙ ПОСТАНОВКЕ

В.О. Афанасьев

В основе всех подходов к построению изображений методами обратной трассировки лучей (ОТЛ) лежит алгоритм Витеда [1], в котором были развиты идеи Аппеля [2], Голдстейна и Нагеля [3]. С момента первых публикаций описания алгоритма ОТЛ прошло более 30 лет, однако он продолжает оставаться в центре внимания, составляя фундаментальную основу математического обеспечения синтеза изображений ЭЭ-объектов. Практика показала, что обратная трассировка дает наиболее реалистичные изображения искусственных объектов, так как алгоритм ОТЛ позволяет непосредственно использовать законы оптики (в том числе законы переноса энергии излучения в различных средах, например, закон Бугера [4]).

Алгоритмы ОТЛ имеют еще одно преимущество перед алгоритмами буфера глубины: изображаемую поверхность можно описывать при помощи не только полигонального приближения, но и более сложных форм [5]. В результате радикально уменьшается объем описания сцены и существенно повышается качество самого изображения.

Растущие вычислительные возможности способствуют более широкому использованию алгоритмов ОТЛ и сохраняют актуальность их дальнейшего развития. В данной работе предлагается подход к решению задачи обратной трассировки на основе параметрической модели луча и картинной поверхности произвольного вида.

Картинная поверхность и параметрический проектор

В общепринятой постановке трассировка луча -это отыскание последовательности точек встречи луча с поверхностями ЭЭ-объектов (ЭЭ-примитивов, [7]) на пути распространения луча от центра проекции до бесконечности. В каждой такой точке луч изменяет свое направление по законам геометрической оптики. Для определения координат первой точки встречи необходимо решить уравнение (систему уравнений), связывающее точку на поверхности и точку на луче (Ray Casting [2,3]).

Будем считать (см. рис.1), что в ЭЭ-про-странстве задана прямоугольная система координат с началом в точке O, центр проекции C и картинная

поверхность S (в частном случае картинная плоскость). Предположим, что на S задан массив точек {Pi}, расположенных в центрах элементов дискретного растра, и, соответственно, массив векторов {Pi}. Любой точке трассируемого луча соответствует связанный вектор V(m) с началом в точке C, проходящий через точку Pi на картинной поверхности: Vi(ffl ) = C + (Pi - C) m. (1)

Заметим, что описание трассируемого луча (1) не содержит ограничений на форму носителя точек {Pi} и положение центра проекции C (S вовсе не обязана быть плоскостью). Однако условия проецирования желательно все же ограничить отсутствием элементов растра, компланарных вектору сканирования, «складок» на картинной поверхности и т.п. В частности, картинная поверхность не должна содержать элементов растра, таких, что [Vi (m =1), ni] < 0, где [•] - символ скалярного произведения; n; - нормаль элемента растра.

Формальная запись в ЭЭ-координатах для условия встречи любого трассируемого луча V(m) и носителя M изображаемой поверхности D может быть представлена так:

V(m)=M(D), (2)

где M(D) - точка ЭЭ-носителя поверхности D.

Выражение (2) можно рассматривать как обобщенную форму уравнения относительно скалярного параметра m, которое иногда разрешимо относительно m. При отсутствии пересечений луча и объекта отсутствуют и действительные решения (2). Если действительные решения существуют, то при m<1 точка встречи не изображается. Когда решений несколько, может быть поставлена задача определения ближайшей точки пересечения

m* = Arg min (m_j), j=1,2,...,n, (3)

nV

где QV - множество всех встреч луча V(m) со всеми n примитивами.

Решением задачи (3) следует считать не только значение m*, а пару {m*, j*}, содержащую номер примитива j*, с которым произошла встреча (предполагается, что 3D-примитивы могут иметь разное математическое описание).

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

Рис. 2. Тест-объект и результаты его трассировки

Помимо ограничений на форму 8 можно отказаться от других ограничений и рассмотреть задачу трассировки в еще более общем виде. Обычно в задаче проецирования в качестве обращенного источника принято использовать один центр проецирования. Однако нет причин для запрета на выбор нескольких обращенных источников луча. Вместо одного источника обращенного луча (центра проецирования С) можно ввести множество таких источников {С}, с каждым из которых по аналогии с (2), связан вектор Р. Так как нет смысла вводить источников лучей больше, чем число элементов растра, можно использовать биекцию {Р}о(С}.

Расположение точек С может быть самым разным, например, можно разместить их на поверхности или на пространственной кривой, то есть использовать некоторый носитель X множественных центров проецирования СеХ. В этом случае будем считать, что задано множество пар ЭЭ-векторов п={(С,,Р,)}, которые образуют «трассирующее множество», или «параметрический проектор». Тогда формулу (1) нужно записать в таком виде:

У,(ш) = С, + ю (Р, - С,), (4)

где С, - вектор с концом в точке выхода луча; Р, - вектор с концом в центре элемента растра; У(ю) - точка на 1-м луче; ю - параметр, задающий положение точки на луче; N - мощность множества элементов растра.

Заметим, что задача параллельного проецирования вместо частного случая проецирования с бесконечно удаленным центром может рассматриваться как задача проецирования с множеством центров проецирования { С}.

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

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

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

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

Решение уравнений встречи

На практике для определения координат видимых точек У(ю*) вместо (2) используются более конструктивные записи условий встречи луча и поверхности. Найденное значение ю* определяет ближайшую видимую точку пересечения луча У(ю) с поверхностью. Далее можно определить все необходимые атрибуты этой точки в контексте поверхности D (вектор нормали к M(D) в точке У(ю) и т.п.).

Чаще всего применяются три формы записи (2), позволяющие построить уравнение (систему уравнений), из которых в конечном итоге можно найти ю:

- системы алгебраических уравнений в 3D-координатах;

- неявная функция в SD-координатах;

- системы алгебраических уравнений в параметрических координатах.

Алгебраические уравнения в SD-координатах. Для некоторых видов поверхностей запись (2) можно непосредственно представить в виде

11У(ю ) - М(0)11=О, (5)

где 11.11 - евклидова норма; 8eRn - вектор числовых параметров (констант, задающих форму поверхности).

Для сферы и ряда других поверхностей (эллипсоида, тора, параболоида и т.п.) конкретные формы записи (5) хорошо известны, и решение для отыскания ю может быть получено в явном виде. В частности, для сферы радиуса r с центром в точке O имеем:

11ю P + (1-ю )C - Oll = r, (6)

откуда легко получить явное выражение для ю через C, P, O и r.

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

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

F(M,8)=0. (7)

Заметим, что к виду (7) можно привести многие виды алгебраического описания поверхностей, например, в (6) для этого достаточно перенести r в левую часть выражения. Можно и наоборот, из условия F(V^),8)=0 получить явное алгебраическое выражение для ю .

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

точки по отношению к поверхности). Часто оптимальным подходом является дихотомический поиск значения ю. Число итераций составляет 0(1о§2(^е)), где d - характерное расстояние в сцене; е - допустимая погрешность определения расстояния. Одним из распространенных видов неявных функций, используемых для обратной трассировки, является описание замкнутых поверхностей 2-го порядка (квадрик), К-функций и т.п.

Уравнения в параметрических координатах. Эта форма используется в схеме формального определения поверхности как множества точек, задаваемых отображением плоской области Э в точки носителя М поверхности 8 в трехмерном пространстве. Декартовы координаты х, у и z точек носителя задаются в виде параметрических координатных функций, а система уравнений для отыскания значения параметра ю связывает значения координат трассирующего луча со значениями координатных функций: Ух(Ш)=Гх(и,У), Уу(Ю)=Гу(и,У), Vz(ю)=rz(u,v).

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

Подходы к обратной трассировке поверхностей свободной формы

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

Несколько обособленное положение занимают поверхности, образованные пересечением полупространств с плоскими границами - их описание нельзя, строго говоря, считать аналитическим (вместо формул задаются связанные нормали), но для их трассировки удалось построить эффективные алгоритмы, в частности отсекатель Сайруса-Бека [5].

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

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

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

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

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

Попробуем определить и описать более общие закономерности, сопутствующие пересечению трассирующего луча и поверхности. Если описывать координаты точек носителя поверхности в системе координат проектора, то пересечение трассирующего луча с поверхностью означает совпадение двух векторов - трассирующего вектора У(ю) и радиуса-вектора поверхности. При этом радиус-вектор поверхности исчисляется не в системе местных координат поверхности, а в системе координат, начало которой совмещено с центром проецирования С (рис. 3).

5 .

/ рЩ'иЬ-.'-'-'') 1 * (и, и) ------

[ «с---/ К \ С ( \

\ V ЩО)

----- /Ук

Рис. 3. Отображение картинной поверхности

и носителя трассируемой поверхности на единичную сферу

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

в цилиндрических координатах (наборы профилей, шпангоутов и т.п.).

Точку носителя поверхности в общем случае независимо от разновидности параметрического описания можно представить следующим образом: М(х,у^) = К + о(и,и), где К - вектор, проведенный из начала системы координат проектора; о(и,и) -сумма векторов, образующих «путь» от начала местных координат до точки на носителе поверхности. Например, для карты высот путь может быть представлен как перемещение по координатным направлениям o(u,u)=ix+jy+uh, где ,, ^ и - орты компонент местной системы координат; h - высота над плоскостью в точке (х,у) области Э. Для последовательности плоских сечений могут использоваться разные виды описаний, например о(и,и)=,х+г(ф,х) (здесь г(ф,х) - радиус-вектор по направлению ф в плоскости сечения с координатой х вдоль направления ,). При использовании сферических координат путь о определяется проще всего: о(и,и)=г(ф,А,) (однократное перемещение вдоль радиуса-вектора г(ф,А) из начала сферической системы координат).

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

Пронормируем все точки картинной поверхности и все точки носителя поверхности:

V

IV!

р(и, и) =

К + о(и, и)

(8)

При центральном проецировании поверхности М(8) на единичную сферу векторы г(и,и) переходят в нормированные векторы р(и,и). Все трассируемые лучи как продолжения векторов V растра картинной поверхности переходят в нормированные радиусы-векторы у и оказываются в пределах другого сегмента. Изображение поверхности также становится «нормированным» и лежит на единичной сфере в области пересечения этих сегментов.

Для описания факта пересечения трассируемого луча и точки на поверхности можно использовать два равносильных (в данном контексте) критерия: совпадение координатных компонент векторов р(и,и) и у либо коллинеарность векторов р(и,и) и у.

Использование совпадения векторов в качестве критерия пересечения приводит к необходимости решения системы из трех уравнений (по координатам х, у и z) относительно неизвестных и,и и ю. Критерий коллинеарности нормированных векторов р и у (фактически критерий их совпадения) равносилен критерию [р,у]=1.

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

параметров поверхности г(и,и).

В качестве функционала Е для экстремальной задачи можно использовать скалярное произведение, которое зависит от параметров и,и и вектора и: Е(и,и,у) = [р(и,и),у]. (9)

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

При встрече фиксированного трассирующего луча V с поверхностью, заданной на D=UxV, имеем (и*,и*)= Аг§тах (Е(и,и)), Е(и*,и*)=1, (10)

причем при описании замкнутых поверхностей и и и часто используются сферические координаты (Ф с {ф I ф е [-п,п]}, Лс {А I А е [0,2п]}).

Для пары (и*,и*), соответствующей точке встречи, искомое значение параметра ю* определяется из ! К + г(и*, и*)!!

соотношения ю* = -

V

Некоторые из таких точек поверхности при проецировании на сферу станут кратными, и для выбора ю* необходимо использовать дополнительное условие, аналогичное (3) (или алгоритм анализа последовательности {ю}, соответствующий конкретному виду С80-формы).

Экстремальную задачу (10) можно решать на любом из взаимно биективных множеств: К={к} (ке К нумерует элементы растра и векторы сканирования), на множестве векторов сканирования V={Vk} и множестве элементов растра Т={Тк}, например: у*=А^тах (Е(у)), Е(у*)=1. (11)

V

Заметим, что Э и V можно рассматривать как множества, сопряженные относительно функционала (9), и их можно сопоставить с двумя разновидностями алгоритмов синтеза проекций - алгоритмами трассировки и алгоритмами буфера глубины. При этом алгоритм буфера глубины, фактически работает «внутри» алгоритма обратной трассировки, поскольку основной задачей все же является определение координат точки встречи трассирующего луча и поверхности через значение параметра ю* на луче.

Алгоритмы трассировки. Для каждого вектора ик сканирования растра можно сформировать подмножество параметров П* для точек встречи, которые на множестве UxV являются точками локальных экстремумов функции скалярного произведения (10) !К + о(и*,и*) II

ю*: ю =

У8(и*, и*) = 0

(12)

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

данию эффективного алгоритма трассировки.

Иногда вместо поиска всех локальных экстремумов (12) можно рассмотреть более простую задачу перебора на конечном подмножестве упорядоченных пар из Э* с Э = ихУ

Пм. = ю= ]'К + ц* е В*1,

IVk

в которой конечное подмножество пар Э* для перебора определяется, например, следующим образом: Э* = {ц* I ( [р (ц*),ук ] < 1-е ). (13)

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

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

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

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

у* = Л^тах (р (ц),у ). (14)

Т

Эта задача может иметь единственное решение, соответствующее одному элементу растра (если трассирующие лучи пересекают картинную поверхность только по одному разу), для которого выполняется У(ю*) = Т* 11Ук11. Затем по этому решению определяется значение для обновляемого элемента бу-1К + о(ц)11

фера глубины ик :

IVk

Нужно заметить, что если синтез центральной проекции производится на более сложной по сравнению с плоскостью картинной поверхности, задача (14) может оказаться не легче, чем (12).

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

В качестве характерного примера трассировки невыпуклой поверхности можно привести трассировку так называемой поверхности Цао Ена. Эта поверхность определена в [10] как результат непрерывного преобразования (деформации) сферической поверхности. Преобразование действует в пространствах любой размерности и применимо для преобразования не только сферических поверхностей, но важ-

но, что оно применимо для замкнутых поверхностей, преобразование которых в ЭЭ-пространстве можно трактовать как «вылепливание» некоторой формы из пластического материала.

Возможности поверхности Цао Ена [9] сходны с возможностями деформации квадрик, и для трассировки применим, в частности, бинарный поиск. Однако интерес представляет реализация подхода именно к непосредственной трассировке на основе решения системы уравнений встречи (причем с параметрическим заданием поверхности).

В заключение отметим, что рассмотренной постановке задачи ОТЛ вместо общепринятых понятий и моделей трассируемого луча и картинной плоскости используются их обобщения в виде параметрического проектора и картинной поверхности. Это, в частности, позволяет получать изображения для вывода на носители растра сложной формы, а также использовать возможности ОТЛ для решения задач, не связанных непосредственно с оптикой (например, для анализа воздействия потоков твердых частиц на поверхности [11]).

Сложности, возникающие при использовании алгоритмов ОТЛ для систем реального времени, хорошо известны отсутствием развитой аппаратной поддержки. Основным путем повышения быстродействия алгоритмов трассировки является распараллеливание на уровне сегментов растра. Расширение множества ЭЭ-примитивов, дополняющих возможности полигонального описания поверхностей, дает еще один путь к распараллеливанию алгоритмов обратной трассировки - это использование множества ЭЭ-примитивов («параллелизм на уровне примитивов»).

Дополнительные перспективы для аппаратной поддержки обратной трассировки открывает появление вычислительных устройств с логикой, перепрограммируемой в режиме run-time, в том числе архитектуры на основе FPGA-чипов. При использовании вычислителей с FPGA могут быть достигнуты большие коэффициенты сжатия программного кода (до нескольких сотен инструкций, выполняемых за один тактовый цикл в процессоре S5000 [6]), что и делает перспективным использование ОТЛ составных полиморфных поверхностей.

Эти и другие появляющиеся в последнее время технологические возможности делают актуальным использование расширенной постановки задачи ОТЛ, исследование новых подходов к вычислениям для этой задачи и к созданию широко доступных вычислительных систем для поддержки ОТЛ.

Список литературы

1. Whitted T. An Improved Illumination Model for Shaded Display. - Comm. of the ACM, 23(6), pp.343-349 (June 1980).

2. Appel A. Some techniques for shading machine renderings of solids. - Proc. AFIPS JSCC, 32, pp.37-45 (1968).

3. Goldstein R.A. and Nagel R. 3D Visual Simulation. -Simulation, pp. 25-31 (January 1971).

4. Ландсберг Г.С. Оптика.-М.:Наука, 1976. - 928 с.

5. Хилл Ф. OpenGL. Программирование компьютерной графики. -СПб.: Питер, 2002.- 1088 с.

6. http://www.stretchinc.com/news/pr_051704.php.

7. Афанасьев В.О. Система полиморфных ЗБ-примити-вов для порождения виртуальных актеров. / Имитационное моделирование и автоматизация программирования: // Сб. науч. тр. /Под ред. Н.В.Макарова-Землянского. - М.: Изд-во МГУ, 1997. - С. 71-79.

8. Афанасьев В.О. Обратная трассировка на продолжении вектора сканирования картинной поверхности. - Моделирование сложных систем и виртуальная реальность: Вопр. кибернетики.- М.: Изд-во РАН, 1995. - № 181. - С.41-55.

9. Афанасьев В.О. Задачи обратной трассировки пространственных объектов произвольной формы. - Моделирова-

ние сложных систем и виртуальная реальность: Вопр. кибернетики. - М.: Изд-во РАН, 1995. - № 181. - С. 21-41.

10. Вайвил Д., Цао Ен, Тротмен А. Поверхность Цао Ена: новый подход к геометрическим моделям произвольных форм. // Программирование. - 1992. -№ 4. - С.4-16.

11. Utkin V.F., Afanasiev V.O., Brovkin A.G., Menshikov G.P., Romanchenkov V.P., Sokolov Y.A., Zinchenko L.V., Re-shetin I.A., Sokolov V.G. Risk of Functioning of International Space Station Connected with Influence of Meteoroids and Space Debris. - Proc of 49th International Astronautical Congress (Sept.28-Oct.2, 1998/Melbourne, Australia).

СИСТЕМА МОДЕЛИРОВАНИЯ И ОЦЕНКИ ЭФФЕКТИВНОСТИ

ТОРГОВЫХ СТРАТЕГИЙ

(Работа выполнена при поддержке РФФИ, грант № 05-07-90324 в)

А.М. Сунцов

Финансовый рынок мы будем рассматривать как совокупность инструмента торговли, места торговли, участников торговли (инвесторов), правил торговли и собственно торговых процессов, проводимых инвесторами в соответствии с правилами торговли. Под торговой стратегией понимается объективный и замкнутый алгоритм, определяющий взаимодействие инвестора с рынком с целью систематического получения прибыли. Данное взаимодействие осуществляется посредством выставления инвестором на рынок заявок на покупку или продажу торгуемого финансового инструмента и отслеживания результатов их исполнения. Следует отметить, что торговая стратегия сама по себе является моделью финансового рынка. Моделирование торговой стратегии - это ее приложение (применение) к конкретной динамике цен на рынке с получением показателей эффективности, включающих прежде всего полученную прибыль. Существует большое количество торговых стратегий, для решения задачи их моделирования используются различные программные системы. Обычно эти системы встроены в сложные системы анализа рыночной динамики в режиме on-line типа MetaStock или Omega TradeStation. С одной стороны, это удобно, поскольку моделирование сводится к использованию этих систем в режиме off-line на исторических данных. Однако для решения задачи сравнения торговых стратегий с разнообразными параметрами может потребоваться много времени, при этом одни и те же вычисления будут повторяться при моделировании нескольких близких стратегий, отличающихся лишь значениями некоторых параметров. Кроме этого, вышеупомянутые системы имеют сложности в построении моделей, базирующихся на нескольких торговых стратегиях, выполняемых одновременно. Следовательно, для эффективного решения задачи моделирования большого количества торговых стратегий требуются специализированные программные средства (системы моделирования). Среди необходимых требований к таким системам можно выделить следующие:

• базирование на универсальном подходе к представлению торговых стратегий;

• поддержку универсального критерия эффективности стратегий;

• поддержку универсального и доступного набора входных данных;

• широкий набор параметров с возможностью расширения набора и задания различных значений параметров;

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

Универсальный подход к представлению торговых стратегий

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

Квант имеет следующие характеристики:

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

• торговая позиция; определяется количеством (и знаком) торгового инструмента, имеющегося у

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