Global IIIumination(GI)全局光照原理(一)3D空间全局光照

2023-12-08 06:36

本文主要是介绍Global IIIumination(GI)全局光照原理(一)3D空间全局光照,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • 一、Global IIIumination(GI)全局光照基本概念
  • 二、主流的全局光照方法:
  • 三、Reflective shadow maps(RSM)反射阴影贴图 全局光照
  • 四、Light Propagation Volumes (LPV)光线传播体积 全局光照
      • 1.第一步,RSM找到次级光源,如图小太阳:
      • 2.注入,即将次级光源注入到每个Volume格子:
            • 球谐光照:
      • 3.传播,每个volume格子向它相邻的6个面传播到其他6个格子里,整体迭代四五次后趋于稳定。
      • 4.最后一步 渲染,对于任意一个shading point 找到它所在的Volume格子,取格子内的SH光照进行光照着色。
  • 五、Voxel Global Illumination(VXGI)体素全局光照
      • 1.VXGI第一趟Pass:
      • 1.VXGI第二趟Pass:

一、Global IIIumination(GI)全局光照基本概念

在这里插入图片描述
渲染方程告诉我们,全局光照=自发光+直接光+间接光。前两者很好求得,解全局光照就变成了先求解间接光。

在这里插入图片描述
理论上光可以在空间内无数次反弹,但在实时渲染中通常我们所说的间接光照只计算一次反弹。
在这里插入图片描述
如上图,我们可以把一切被直接光源照射到的物体当成新的光源(次级光源),从相机出发射线到P,P所接受的间接光照就是Q点反弹的光。
在这里插入图片描述
如上图只有直接光照,物体没被照射的地方就是黑的如P点。这些被照射的地方(小太阳)我们可以把它当成次级光源。
在这里插入图片描述
那么P点受到的光照就是从所有次级光源反弹给它的光照。

二、主流的全局光照方法:

3D空间方法:
在这里插入图片描述
屏幕空间方法:
在这里插入图片描述

三、Reflective shadow maps(RSM)反射阴影贴图 全局光照

如何确定次级光源?
在这里插入图片描述
这里我们用reflective shadow maps(RSM)反射阴影贴图来确定哪些物体被直接光源照亮,也就是确定次级光源。
为了计算辐射量,我们有个基本假设:
任何次级光源都是漫反射,因此向外的辐射都是均匀的。

辐射度量学:
在这里插入图片描述
Radiant Intensity辐射强度:从光源发出的光
Irradiance辐照度:落在A表面的光
Radiance辐射率:光沿着射线传播 的辐射功率。
在这里插入图片描述
反射阴影贴图比起阴影贴图不仅只存了Depth深度,还存了world coordinate世界坐标, normal法线, flux通量等。
在这里插入图片描述
RSM效果,通常手电筒的全局光照喜欢用RSM。
RSM优点就是好实现,缺点等同于shadow map:有多少直接光源就需要多少个reflective shadow maps;不去算间接光照可见性检查会有很多失真;假设任何次级光源都是漫反射也是不符合物理的。

四、Light Propagation Volumes (LPV)光线传播体积 全局光照

LPV由CryEngine在《孤岛危机》中首次引入,其原理就是将场景划分成Volume格子,计算次级光源反射出的光(红色箭头)有多少进入到格子P(黄色)?
在这里插入图片描述

1.第一步,RSM找到次级光源,如图小太阳:

在这里插入图片描述

2.注入,即将次级光源注入到每个Volume格子:

a.引擎上一般用3维纹理划分格子
b.找到每个格子包围的虚拟光源(次级光源发出的)
c.虚拟光源加起来得出每个格子的定向辐射量
d.SH球谐函数做压缩 SH来描述此格子里的光照信息

球谐光照:

球谐光照的实质是通过球谐函数的特性将预先计算好的球谐系数还原为光照信息:
通过球谐函数将场景的环境光Cubemap,例如天空球贴图、Volume格子、计算出球谐系数
需要光照信息的时候,再通过球谐函数和系数,还原出光照信息
通过设定球谐函数的级数,可以获得更高的还原度
通常游戏引擎渲染中,只需要三阶,即9个系数,也称SH9
在这里插入图片描述

3.传播,每个volume格子向它相邻的6个面传播到其他6个格子里,整体迭代四五次后趋于稳定。

在这里插入图片描述

4.最后一步 渲染,对于任意一个shading point 找到它所在的Volume格子,取格子内的SH光照进行光照着色。

在这里插入图片描述
但这样有个问题:如图P点是次级光源,无论如何都照亮不了对背面的q点,但因为我们把空间划分成Volume格子,而格子内的光辐射是同样的,那么q点经过错误计算也会被照亮,如图:
在这里插入图片描述
LPV这种缺陷叫做:光泄漏 。是由于格子比物体大照成的,可以通过动态自适应格子大小来解决。

五、Voxel Global Illumination(VXGI)体素全局光照

在这里插入图片描述
VXGI体素全局光照和RSM一样也是一个两趟Pass算法,LPV算4趟算法。VXGI和RSM有主要以下区别:

  • RSM的次级光源是像素(物体微小表面),而VXGI的次级光源被划分成了一个一个格子,而是有层级结构的格子(八叉树实现),我们称为体素。
  • RSM采样的是3D场景中的次级光源,VXGI则是由摄像机发射出射线打到shading point反射到哪些体素来确认间接光照。
    在这里插入图片描述

1.VXGI第一趟Pass:

被主光源直接照射的同样也是次级光源,区别于RSM的像素(物体微小表面)次级光源,VXGI是由八叉树分隔的立方体格子,每个格子记录次级光源的分布和格子内的表面的法线分布。
在这里插入图片描述

1.VXGI第二趟Pass:

如果shading point是光滑的表面,那么反射就是一个圆锥体
根据(不断增长的)圆锥体大小查询格子层次结构(体素)的光照信息
在这里插入图片描述
如果shading point是漫反射表面,那就反射多个圆锥体,找到对应范围内的格子体素进行相加:
在这里插入图片描述

这篇关于Global IIIumination(GI)全局光照原理(一)3D空间全局光照的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/468874

相关文章

无人叉车3d激光slam多房间建图定位异常处理方案-墙体画线地图切分方案

墙体画线地图切分方案 针对问题:墙体两侧特征混淆误匹配,导致建图和定位偏差,表现为过门跳变、外月台走歪等 ·解决思路:预期的根治方案IGICP需要较长时间完成上线,先使用切分地图的工程化方案,即墙体两侧切分为不同地图,在某一侧只使用该侧地图进行定位 方案思路 切分原理:切分地图基于关键帧位置,而非点云。 理论基础:光照是直线的,一帧点云必定只能照射到墙的一侧,无法同时照到两侧实践考虑:关

深入探索协同过滤:从原理到推荐模块案例

文章目录 前言一、协同过滤1. 基于用户的协同过滤(UserCF)2. 基于物品的协同过滤(ItemCF)3. 相似度计算方法 二、相似度计算方法1. 欧氏距离2. 皮尔逊相关系数3. 杰卡德相似系数4. 余弦相似度 三、推荐模块案例1.基于文章的协同过滤推荐功能2.基于用户的协同过滤推荐功能 前言     在信息过载的时代,推荐系统成为连接用户与内容的桥梁。本文聚焦于

hdu4407(容斥原理)

题意:给一串数字1,2,......n,两个操作:1、修改第k个数字,2、查询区间[l,r]中与n互质的数之和。 解题思路:咱一看,像线段树,但是如果用线段树做,那么每个区间一定要记录所有的素因子,这样会超内存。然后我就做不来了。后来看了题解,原来是用容斥原理来做的。还记得这道题目吗?求区间[1,r]中与p互质的数的个数,如果不会的话就先去做那题吧。现在这题是求区间[l,r]中与n互质的数的和

hdu4407容斥原理

题意: 有一个元素为 1~n 的数列{An},有2种操作(1000次): 1、求某段区间 [a,b] 中与 p 互质的数的和。 2、将数列中某个位置元素的值改变。 import java.io.BufferedInputStream;import java.io.BufferedReader;import java.io.IOException;import java.io.Inpu

hdu4059容斥原理

求1-n中与n互质的数的4次方之和 import java.io.BufferedInputStream;import java.io.BufferedReader;import java.io.IOException;import java.io.InputStream;import java.io.InputStreamReader;import java.io.PrintWrit

MiniGPT-3D, 首个高效的3D点云大语言模型,仅需一张RTX3090显卡,训练一天时间,已开源

项目主页:https://tangyuan96.github.io/minigpt_3d_project_page/ 代码:https://github.com/TangYuan96/MiniGPT-3D 论文:https://arxiv.org/pdf/2405.01413 MiniGPT-3D在多个任务上取得了SoTA,被ACM MM2024接收,只拥有47.8M的可训练参数,在一张RTX

寻迹模块TCRT5000的应用原理和功能实现(基于STM32)

目录 概述 1 认识TCRT5000 1.1 模块介绍 1.2 电气特性 2 系统应用 2.1 系统架构 2.2 STM32Cube创建工程 3 功能实现 3.1 代码实现 3.2 源代码文件 4 功能测试 4.1 检测黑线状态 4.2 未检测黑线状态 概述 本文主要介绍TCRT5000模块的使用原理,包括该模块的硬件实现方式,电路实现原理,还使用STM32类

SAM2POINT:以zero-shot且快速的方式将任何 3D 视频分割为视频

摘要 我们介绍 SAM2POINT,这是一种采用 Segment Anything Model 2 (SAM 2) 进行零样本和快速 3D 分割的初步探索。 SAM2POINT 将任何 3D 数据解释为一系列多向视频,并利用 SAM 2 进行 3D 空间分割,无需进一步训练或 2D-3D 投影。 我们的框架支持各种提示类型,包括 3D 点、框和掩模,并且可以泛化到不同的场景,例如 3D 对象、室

TL-Tomcat中长连接的底层源码原理实现

长连接:浏览器告诉tomcat不要将请求关掉。  如果不是长连接,tomcat响应后会告诉浏览器把这个连接关掉。    tomcat中有一个缓冲区  如果发送大批量数据后 又不处理  那么会堆积缓冲区 后面的请求会越来越慢。

PHP原理之内存管理中难懂的几个点

PHP的内存管理, 分为俩大部分, 第一部分是PHP自身的内存管理, 这部分主要的内容就是引用计数, 写时复制, 等等面向应用的层面的管理. 而第二部分就是今天我要介绍的, zend_alloc中描写的关于PHP自身的内存管理, 包括它是如何管理可用内存, 如何分配内存等. 另外, 为什么要写这个呢, 因为之前并没有任何资料来介绍PHP内存管理中使用的策略, 数据结构, 或者算法. 而在我们