Русская Википедия:Sparse Voxel Octree

Материал из Онлайн справочника
Перейти к навигацииПерейти к поиску

Файл:SVO-voxel-snowman-slice-01.gif
Построение воксельного октодерева

Sparse Voxel Octree (SVO, Шаблон:Lang-ru) — программная технология, позволяющая делать эффективную детализацию визуализируемых объектов и эффективную обработку облаков точек.

SVO — регулярная иерархическая структура данных, в основе которой лежит регулярная трёхмерная сетка. Первый узел дерева — корень, является кубом, содержащим весь объект целиком. Каждый узел или имеет 8 потомков или не имеет никаких потомков. Эти 8 потомков формируют 2×2×2 регулярных подразбиения родительского узла. Узел с потомками называют внутренним узлом, узел без потомков называют листом. В результате всех подразбиений получается регулярная трёхмерная сетка вокселей, однако, не все воксели содержат части объекта, поэтому в созданном дереве такие воксели не будут содержаться, то есть дерево будет разреженным. Для того, чтобы каждый раз не обрабатывать пустой воксел — вместо сетки используется октодерево, оно также имеет информацию об индексации вокселей и позволяет оптимальным образом находить соседей вокселя и другую информацию.

Использование

«Sparse Voxel Octree» в качестве структуры данных используется в игровом движке «CryEngine 3» немецкой компании Crytek. В отличие от своего классического назначения, в «CryEngine 3» SVO служит не для хранения вокселей, а для хранения полигонов и «запеченных» геометрии и текстур уровня во время его экспорта. Crytek отдала предпочтение технологии SVO, так как она, в отличие от виртуальных текстур, не требует вычислений на графическом процессоре, обеспечивает автоматическое и корректное создание уровней детализации (LOD), предоставляет возможность создания адаптивных геометрических и текстурных деталей в зависимости от геймплея, а также благодаря ей очень легко управлять геометрией и текстурами и производить их «стриминг» (подгрузку в реальном времени во время работы приложения). Вместе с тем было отмечено большое требование к объёму памяти для SVO. Для ликвидации этого недостатка Crytek использовала агрессивное сжатие текстур и применяла SVO не для всего уровня, а лишь для определённых его частей.[1]

Согласно Crytek, «Sparse Voxel Octree», наряду с «Sparse Surfel Octrees», может стать одной из ключевых технологий хранения и представления данных в компьютерной графике реального времени в будущем. Были выделены её основные преимущества и недостатки.[1]

Преимущества[1]:
  • SVO как структура данных ориентирована в будущее и подходит для альтернативных методов рендеринга;
  • очень хорошо подходит для уникальных геометрии и текстур, что будет актуальным в будущем, так как бюджеты на геометрические объекты и текстуры утрачивают свою актуальность;
  • Обеспечивает истинную свободу для художников;
  • Естественным образом автоматически реализует схему уровня детализации;
  • Хорошо подходит для трассировки лучей.
Недостатки[1]:
  • SVO не имеет ни инфраструктуры, ни специализированного аппаратного обеспечения;
  • имеет большие требования к памяти;
  • всё ещё слишком медленная.

Примечания

Шаблон:Примечания

Ссылки

Шаблон:Деревья (структуры данных)

  1. 1,0 1,1 1,2 1,3 Ошибка цитирования Неверный тег <ref>; для сносок crytek_future_hpg2010 не указан текст