Скачать презентацию
Идет загрузка презентации. Пожалуйста, подождите
Презентация была опубликована 10 лет назад пользователемСтанислав Неёлов
1 Мягкие тени используя иерархическую мин-макс карту теней Kirill Dmitriev Yury Uralsky
2 NVIDIA Confidential Обзор Традиционные алгоритмы мягких теней Мин-макс теневая карта Реализация PCF с большим ядром Реализация адаптивного размытия тени Идеи по улучшению производительности
3 NVIDIA Confidential Мягкие тени – это важно Важно для реалистичности Четкие тени могут получаться только от точечных источников, которых не существует в реальной жизни Важно для качества Скрывают артефакты возникающие из-за недостаточного разрешения карты теней
4 NVIDIA Confidential Обычные мягкие тени? PCF (Percentage Closer Filtering) Посчитать тень в нескольких точках вокруг и усреднить Размер фильтра (K) управляетмягкостью K
5 NVIDIA Confidential Percentage closer filtering (PCF) Важно усреднять не глубину а затенение: Железо NVIDIA реализует PCF для маленьких размеров фильтра (K) K
6 NVIDIA Confidential PCF с большим ядром PCF с большим ядром K требует много сэмплов Можно фильтровать по подмножеству текселей K: приводит к бандингу K
7 NVIDIA Confidential Рандомизированный PCF Чтобы избежать бандинга, можно в каждом фрагменте использовать свой набор сэмплов Заменяет бандинг на шум K
8 NVIDIA Confidential Дисперсные карты теней (variance shadow maps) Сохранять глубину и квадрат глубины Тогда можно вычислить дисперсию и используя неравенство Чебышева (из теории вероятностей) посчитать затенение Позволяет использовать мип-маппинг Недостаток: предположения теории вероятностей
9 NVIDIA Confidential Недостатки предыдущих алгоритмов Percentage closer filtering Нужно много сэмплов для качественной тени Дисперсные теневые карты Предположения теории вероятностей Общий недостаток Ядро фильтрации фиксировано
10 NVIDIA Confidential Новая идея Представим себе теневую карту как набор квадратиков в 3D пространстве В шейдере считаем затенение от каждого квадратика – получаем тень
11 NVIDIA Confidential Иерархическая мин-макс теневая карта Линейный проход по всем квадратикам (миллион) – слишком медленно Решение: иерархическое представление Можно отсекать целые кластеры текселей, заведомо не вносящих вклад в затенение фрагмента
12 NVIDIA Confidential Мин-макс теневая карта Мин канал 4 соседних текселя Макс канал Вычислить две мипмап пирамиды Используя мин фильтр Используя макс фильтр Можно сохранить в двухканальной текстуре
13 NVIDIA Confidential PCF с большим ядром используя минмакс теневую карту Каково затенение? 1.0 выйти 0.0 К друим текселям на том же уровне или выше Спуститься ниже иначе
14 NVIDIA Confidential Расчет затенения K SM texel Затенение одним теневым текселем равно пересечению между этим текселем и ядром фильтрации
15 NVIDIA Confidential Расчет затенения K Затенение можно считать полным если пересечение полное И макс канал меньше глубины фрагмента SM Texel
16 NVIDIA Confidential По сути – проход по дереву 0 Мип уровень 0 Мип уровень 1 Мип уровень 2
17 NVIDIA Confidential По сути – проход по дереву 0 Мип уровень 0 Мип уровень 1 Мип уровень 2 0.5
18 NVIDIA Confidential По сути – проход по дереву 0 Мип уровень 0 Мип уровень 1 Мип уровень
19 NVIDIA Confidential По сути – проход по дереву 0 Мип уровень 0 Мип уровень 1 Мип уровень
20 NVIDIA Confidential По сути – проход по дереву 0 Мип уровень 0 Мип уровень 1 Мип уровень
21 NVIDIA Confidential По сути – проход по дереву 0 Мип уровень 0 Мип уровень 1 Мип уровень
22 NVIDIA Confidential По сути – проход по дереву 0 Мип уровень 0 Мип уровень 1 Мип уровень
23 NVIDIA Confidential По сути – проход по дереву Мип уровень 0 Мип уровень 1 Мип уровень 2
24 NVIDIA Confidential Демо: мягкие тени используя иерархическую минмакс теневую карту
25 NVIDIA Confidential Как сделать размытие адаптивным? Размытие должно увеличиваться Размытие должно зависеть от взаимного расположения источника света, затеняющего и затененного объектов
26 NVIDIA Confidential Физически аккуратные тени Будем вычислять затенение от каждого текселя с учетом площади источника света
27 NVIDIA Confidential Затенение – перспективная проекция текселя на источник фрагмент тексель Источник света Проекция на источник
28 NVIDIA Confidential Физически аккуратное затенение от всех текселей Суммирование идет по всем текселям 0-го мипмапа. Теневые тексели - AABBs, Источник света - тоже AABB: вычисления очень просты EvalS(depth) depth
29 NVIDIA Confidential Большая часть теневых текселей не важны Начинаем с больших текселей; if (EvalS(DepthMin) == 0) { откидываем поддерево; } Откидывает (2^N)^2 текселей где N – текущий уровень мипмапа if (EvalS(DepthMin) == 1 && DepthMax < DepthFrag) { выходим из шейдера; }
30 NVIDIA Confidential Протекание света Так как теневая карта создается для точечного источника света, а используется для площадного, возможны протекания света Гладкая поверхность
31 NVIDIA Confidential Пример протекания света
32 NVIDIA Confidential Как уменьшить протекания света Расширить на определенную величину теневые тексели Тексели с большей глубиной расширяются так чтобы проeкции их границ точно совпали с проeкциями границ соседей
33 NVIDIA Confidential Пример уменьшения протеканий света С протеканиями
34 NVIDIA Confidential Демо физически приближенных теней
35 NVIDIA Confidential Эффективная реализация стека Нам нужно класть/вынимать: индекс мип уровня (4 бита) + индекс пикселя (2 бита) Динамическая индексация массива в шейдере – накладно. Если элемент стека мал – лучшее решение...
36 NVIDIA Confidential Операция push() Младшее слово (32 бита) Старшее слово (32 бита) Нам нужно класть/вынимать: индекс мип уровня (4 бита) + индекс пикселя (2 бита)
37 NVIDIA Confidential Операция push() Младшее слово (32 бита) Старшее слово (32 бита) Нам нужно класть/вынимать: индекс мип уровня (4 бита) + индекс пикселя (2 бита)
38 NVIDIA Confidential Идеи как ускорить Можно останавливаться не доходя до низа дерева Если затененный объект находится далеко Вычислять точные значения затенения на грубой сетке Остальные пиксели можно интерполировать/вычислять базируясь на значениях в узлах сетки… Нужна хорошая эвристика!
39 NVIDIA Confidential Эвристика интерполяции Нельзя интерполировать если сильно неплоская поверхность Нельзя интерполировать если затенение узлов слишком сильно меняется Затенение может сильно менятся если есть объекты, расположенные слишком близко к точке затенения
40 NVIDIA Confidential Для каждого узла сетки сохранять расстояние до ближайшего затенителя (всего один float на узел); Можно интерполировать только если фрагмент находится внутки бокса, образованного четырьмя ближайшими узлами сетки И расстояние до ближайшего затенителя больше чем размер бокса. Эвристика интерполяции
41 NVIDIA Confidential Ссылки [1] See NVIDIA SDK10 SoftShadows demo for details [2] Gael Guennebaud, Loic Barthe and Mathias Paulin. Real-time Soft Shadow Mapping by Backprojection. Eurographics Symposium on Rendering 2006, Nicosia, Cyprus.
42 NVIDIA Confidential Вопросы?
Еще похожие презентации в нашем архиве:
© 2024 MyShared Inc.
All rights reserved.