IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 人工智能 -> 计算机图形学【GAMES-101】9、蒙特卡洛路径追踪(Path Tracing) -> 正文阅读

[人工智能]计算机图形学【GAMES-101】9、蒙特卡洛路径追踪(Path Tracing)

1 概率论复习

(1)随机变量 X: 表示所有可能取值的分布
(2)概率p(x): X取到值x的概率
(3)概率密度函数PDF: 描述随机取到某个值的概率
(4)期望E[X]: 从随机分布中反复抽取样本所得到的平均值,即把所有可能的值与它对应的概率相乘后相加

离散型随机变量例子:六面骰子
在这里插入图片描述

  • X可能取值为1,2,3,4,5,6
  • p(1) = p(2) = p(3) = p(4) = p(5) = p(6)
  • E[X] = Σxipi = (1+2+3+4+5+6)/6 = 3.5

连续型随机变量中的概率密度函数(PDF)
概率密度函数Probability Density Function
在这里插入图片描述

  • 随机变量X可能的取值为 [-3,3]内所有数,包括小数,这是一个连续的曲线
  • X取某个值的概率p(x)为以x附近取一个dx连接到曲线上所形成的微元的面积,所有面积微元的和为1,即 ∫p(x)dx = 1
  • 期望的计算方式跟离散的一样,只是求和变为求积分即可 E[X] = ∫xp(x)dx

2 蒙特卡洛积分Monte Carlo Integration

蒙特卡洛积分解决什么问题?—— 求定积分

  • 蒙特卡洛方法,其实是一种思想,把这种思想运用在求解定积分上,就是蒙特卡洛积分
  • 再把蒙特卡洛积分,这种求解积分的方法,运用在渲染方程的求解上,就是蒙特卡洛路径追踪
  • 高数课程中,求定积分用的是黎曼积分,即划分成无数的面积微元求和,但是如果函数图形非常复杂则不好用。
    在这里插入图片描述

蒙特卡洛积分

  • 利用随机采样无限逼近的思想。随机采样N个点Xi,得到其对应的函数值f(xi)与边界ab围成的面积,将这些面积加起来求平均值,则得到最终定积分结果。随着采样频率增大,即采样点的个数N增加,其定积分结果无限逼近真实值。
  • 如下图所示,目标是f(x)在[a,b]区间的定积分,我们随机采样,给定Xi ~ p(x)概率密度函数,则我们知道采样到每个Xi所对应的概率;带入蒙特卡洛积分公式得出结果。
    在这里插入图片描述
  • FN 这个公式的翻译:用每个采样点Xi对应的函数值f(Xi),除以取到 Xi 的概率,然后把N个采样点计算结果相加后求平均值即为所求。
  • 夹着概率论的方法求定积分脑子有点混乱?
    其实采样Xi就是概率论中随机变量X的所有可能取值中的第i个,然后我们自己定义采样的个数N,和每个采样数对应的概率p,一般都是均匀采样,即采样概率均等。
    这里公式看着比较抽象,看下方带入数值后的公式特别好理解

看一个简单的例子

  • (1)首先明确目标定积分
    在这里插入图片描述
  • (2)指定概率密度函数PDF
    比如,我们采用均匀采样的方式,取每个Xi的概率是均等的都为常数C,数学表达就是Xi ~ p(x) = C;又因为所有随机变量对应的概率和必须等于1,从而可以算出采样到某个数的概率p(Xi) 也就是C为1/(b-a)

在这里插入图片描述在这里插入图片描述
所以,蒙特卡洛积分所需要的量就全都有了

  • f(Xi) 就是每个随机变量Xi对应的函数值
  • p(Xi) 为常数C,即1/(b-a)
  • N为采样的次数
  • 最后带入蒙特卡洛积分公式得出结果,这个公式比起上面就很直观了,每次采样Xi算出它的函数值乘以b-a得到面积,把N个面积加起来除以N得到最终结果
    在这里插入图片描述

完整的蒙特卡洛积分公式长这样
在这里插入图片描述
注意事项:

  • 采样点越多,误差越小
  • 为啥公式里没有积分限a,b呢?因为积分限在概率密度函数里面就定义过了
  • 蒙特卡洛积分的要求:1、在x轴上积分 2、在x轴上采样,即随机变量X的取值范围是x轴的数值
  • 再次提醒 蒙特卡洛积分目的是解一个定积分

3 蒙特卡洛路径追踪Path Tracing

3.1 Whitted-Style Ray Tracing存在的问题

回忆它的做法,摄像机发射光线
(1)打到不透明物体,则认为是漫反射,直接连到光源做阴影判断、着色计算;打到透明物体,发生折射、漫反射
总之光线只有三种行为:镜面反射、折射、漫反射

  • 问题1: 怎么处理毛面光滑材质?
    在这里插入图片描述
    左边这种镜面反射,可以应用Whitted-Style光线追踪来计算。
    右边这种毛面光滑材质的茶壶,用Whitted-Style算法怎么处理??镜面反射还是漫反射? —— 都不行。
    我们明显可以分析出这个毛茶壶的反射过程,应该是光线击中茶壶后,朝着镜面反射方向附近的一个极小的区域散射出去了,击中了镜面反射应该击中的点的附近的一堆点,然后这一堆点的着色结果加到茶壶首次击中点上,形成模糊感。
  • 问题2:忽略了漫反射物体之间的反射影响:击中漫反射物体,不能直接连光源着色,还要考虑别的漫反射过来的光线
    在这里插入图片描述
    如图,左右两张图片都是PathTracing方法渲染得到的结果,区别是:
    左边: 仅计算直接光照,光线弹射0次,即击中物体直接连光源做阴影判断&着色计算。比如长方体的左面一块纯黑,因为位于那些地方的点连向光源会被阻挡,天花板也应当是黑色,因为矩形光源那个位置确实照射不到天花板。
    右边: 计算全局光照(直接+间接),光线弹射1次以上。比如天花板,摄像机射线击中天花板,天花板弹射一次到地面/左右墙体,再直接连到光源,则被照亮了,正向过程就是,光打到地面,地面反射部分比例的光到天花板,天花板反射到摄像机,从而可以看见。
    还有一个很大的区别是: 右图中长方体的左边明显染上了左墙的红色,正方体的右边明显染上右墙的绿色。这种现象叫做Color Bleeding

Whitted-Style光追是错的
渲染方程是对的

3.2 Path Tracing —— 利用蒙特卡洛方法解渲染方程

渲染方程很对,那么现在的问题就是怎么
在这里插入图片描述
这个方程涉及到:

  • 半球上的积分求解问题
  • 递归计算问题: 对于入射的Radiance Li(p,ωi)
    如果是直接光照,不用递归,Li 就是光源射出的Radiance
    如果是其他物体反射过来的间接光照,则该 Li 其实是上一个物体的 Lr ,为了求这个 Lr开始递归

3.2.1 仅考虑直接光照

假设,计算某个点的着色,这个点没有自发光并且只考虑直接光照的情况
注意:入射光本该是从光源指向着色点,但为计算方便,认为是从着色点指向光源的,
在这里插入图片描述
渲染方程如下:
公式中的Li 是来自面光源各个点的入射光,并不考虑其他间接入射光
在这里插入图片描述

注意算曲线积分的时候,采样x轴,而此时我们采样的是入射方向ωi,即对其球面上的不同方向进行采样
格外注意:我们并不会计算着色点来自球面的所有方向的入射光,而是采样抽取一部分入射光,可以均匀采样,也可以是规定某些地方采样多一些,某些地方采样少一些。

在这里插入图片描述
想要用用蒙特卡洛方法解渲染方程,那就必须知道对应的函数表达式f(x)和每次采样对应的概率即PDF是多少

  • 渲染方程中的f(x)是什么?
    就是被积函数全部: Li(p,ωi)fr(p,ωi0)(n·ωi)
  • PDF是多少?
    这要看我们如何设置采样方法,比如均匀采样,采样到每个方向的概率相等,则 p(ωi) = 1/2π
    (提醒:整个球的球面度是4π,半球则是2π)

然后就可以带入蒙特卡洛积分方程求解了:
在这里插入图片描述
到此为止,可以算出多个光源作用下的某个着色点的最终射向摄像机的Radiance,即最终着色结果。

对p点的计算着色的算法如下:
按照某种自己定的PDF,采样N个不同入射方向;
初始化L0 = 0.0;
对每个入射方向ωi:从p点向该方向发出射线r,判断如果击中了光源,则计算此方向的Lo,并且累加到之前的Lo上;
最终得到着色结果Lo
在这里插入图片描述
以上就是path tracing只考虑直接光照的计算

3.2.2 全局光照(直接光照+间接光照)

除了要计算直接光照以外,还要计算间接光照
在这里插入图片描述

间接光照要递归:

  • 设摄像机的位置为O点,光源为T点
  • 我们想要计算P点射到O点的Radiance。我们在OPQ这段路径上,直接把Q看做光源,那么对OPQ段解第一次渲染方程,方程中被积函数的 P点入射Radiance Li(p,ωi) 是未知的,而这个P点入射光 Li 又是Q点的出射光 Lo ,则可以在PQT上解第二个渲染方程。PQT的渲染方程中 Li就是光源的Radiance,这是已知的。
  • 其实计算间接光照时,每一次解渲染方程,都跟之前计算直接光照的算法是一样的,递归后相加就是间接光照。最后再跟直接光照计算结果叠加就完成了全局光照的计算。
  • 计算p点的全局光照代码如下,仅仅是在直接光照计算的代码中加了一截递归计算。
    在这里插入图片描述
    没完,目前还是存在一些问题!
    (1) 随着弹射次数的增多,打出的光线数量会指数级上升,Rays = N弹射次数,N是对入射方向的采样次数。
    在这里插入图片描述
    • 那么N等于多少的时候才不会数量爆炸呢?—— 当且仅当N = 1时
      所以算法中的采样数量就要修改了,并不是选择N个方向的入射光,而是随机选1条入射光
      在这里插入图片描述
      但是这种算法,会产生非常多的噪点。因为有些着色点计算时,随机采样的某个入射光方向wi并没有击中光源,甚至也没有击中其他物体。那就啥也没击中,Li为0,算着色可不就是算了个寂寞么。

所谓的Path Tracing ,就是因为N = 1
每次弹射都只有一个方向一条线,最终形成一条连接视点和光源的路径。

(2) 采样数N = 1而引发的噪点问题
解决办法: 每个像素追踪更多的路径,然后取平均值。所以呢只要用足够多的path,就能够确保有更大的几率击中有效光源或物体,计算出接近正确的着色。

在这里插入图片描述
相关代码如下,计算过程跟光线追踪很相似,注意调用了上面的shade()函数做递归

  • 注意1:原本可能就是相机朝着像素中心发射一条射线,但现在对1x1的像素点进行采样,采样N个位置,相机朝着这些位置发射多条光线。
  • 注意2:pixel_radiance 的计算中,只是把每个path结果加起来取平均,并不是套用蒙特卡洛公式。 蒙特卡洛积分是在shade函数里面用的。
    在这里插入图片描述
    到这里还是没完,因为shade()函数递归没有停止条件,会无限递归下去

(3) 设置终止递归条件,但是自然界中光线就是弹射无数次,我们限定弹射次数必然损失能量。不想无限递归又不想损失能量?

解决办法: 俄罗斯轮盘赌 RussianRoulette(RR)

  • 我们的目标是求着色点的着色结果,即该点到相机方向的Lo
  • 假设我们手动设置一个概率P(0 < P < 1)
    以P概率继续发射一条光线,返回Lo除以P之后的着色结果:Lo / P
    以1-P的概率不发射光线,返回0
  • 最终计算离散型随机变量的期望 E = P x (Lo / P) + (1 - P) x 0

加入RR之后的代码如下
特别注意:红色部分其实就是实现了“手动指定概率P,有P的几率继续递归,1-P的几率终止递归!”
假如静态变量P_RR = 0.8,每次执行shade(),产生一个随机数0~1的ksi,ksi 落在0.8~1的概率就只有0.2,也就0.2的概率终止执行,即不再继续产生光线,往后弹射了。
在这里插入图片描述
最终,如果对一个像素产生足够多条路径,每条路径长短不一(看每个path自身的运气了),则会得到一个比较好的效果
在这里插入图片描述
(3) 低采样数的情况下噪点太多,高采样率又费性能,太多的光线被浪费了。

  • 之前提过,视点发射光线打中物体,然后物体随机选择1个方向产生新的光线去打目标,很可能是打不中的啊!啥也没打中就会出现噪点
  • 比如下面这张图:光源很大的时候,可能大概发射无条光线,能有一条击中光源;光源很小的时候,我发射五万条光线才能一条击中,这是一种特别巨大的浪费!并不是真的发射5万根光线,只是为了说明随机采样一个方向wi,击中光源的概率是真的很低。
    在这里插入图片描述
    之前某个地方写出过猜想,比如某些方向采样率高一点,某些地方采样率低一点,这样的效率会更高。这里就确实应用上了。
    怎么办?—— 不再均匀采样,找到一种更好的PDF去采样

直接采样光源的表面,这样就没有光线被浪费

  • 之前蒙特卡洛解渲染方程,我们采样的是半球上立体角,并且渲染方程也是对wi进行积分的
  • 我们想变成对光源表面进行采样,对光源表面的dA进行积分咋办?—— 积分换元
    要做换元,就必须找到dA和dωi的关系,相应的修改被积函数,并且更换积分限
  • 回忆单位立体角的定义:dw = dA / r2 ;明确一个概念,跟角度一样,小圆的π/4角换成同心大圆依然还是π/4,立体角也是一个道理,分子dA虽然变了,但是分母(距离的平方)也跟着变化了,所以比值还是不变的!但是要注意,光源可能并不是正对着着色点的,所以要乘以一个cosθ’,相当于把光源的面积旋转到同心球面上了。
    所以dw可以写成下边这种形式。带入蒙特卡洛积分公式就完成换元了!

最终的渲染方程——效率高、对光源采样

  • 注意积分限:从半球变成了光源的表面积!
    在这里插入图片描述
  • 蒙特卡洛公式所需要的变量:
    f(x) :依然是被积函数那一大堆
    p(x) :由于对光源表面均匀采样,所以每个点的概率均等,都是1 / A

最终对于每个点的radiance计算,都是来自两部分
(1)光源(直接光照,不需要俄罗斯轮盘赌RR)。对光源进行均匀采样,求积分
(2)其他物体反射过来的光(间接光源,依然用RR)。(N = 1按概率决定是否发射、射到哪里随缘、多个path求平均)

最终的击中点着色计算伪代码:

  • 每一条路径在计算来自光源的部分时,依然只发射1条光线,由于像素有多个path,所以其实软阴影就是通过多个path实现的,而不是发射多条光线,但是我感觉好像可以发射多条光线啊,并不会产生数量爆炸的错误,因为来自光源的L_i是已知的不用继续迭代
  • 注意对光源采样的时候,要判断是否被其他物体遮挡!
Shade(p,wo)
{
	// 1、来自光源的贡
	对光源均匀采样,即随机选择光源表面一个点x';  //pdf_light = 1 / A
	shoot a ray form p to x';
	L_dir = 0.0;	
	if (the ray is not blocked in the middle)	// 判断是否被遮挡
	L_dir = L_i * f_r * cosθ * cosθ' / |x' - p|^2 /pdf_light;
	//2、来自其他物体的反射光
	L_indir = 0.0;
	Test Russian Roulette with probability P_RR;
	Uniformly sample the hemisphere toward wi;  //pdf_hemi = 1 / 2π
	Trace a ray r(p,wi);
	if (ray r hit a non-emitting object at q)
	    L_indir = shade(q, -wi) * f_r * cosθ / pdf_hemi / P_RR; 
    return L_dir + L_indir;
}

路径追踪不好做点光源的计算,建议把点光源做成有很小面积的面光源。

4 Path Tracing 结语

  • 路径追踪的学习确实比较难。涉及到物理、概率论、微积分、编码
  • 路径追踪是现代正在使用的前沿技术
  • 路径追踪几乎是100%正确的算法
    在这里插入图片描述
    对于光线追踪Ray Tracing 这一个名词
    • 以前:就是指Whitted-style ray tracing
    • 现在:所有光线传播方法的总称,包括:
      • 单向/双向路径追踪
      • 光子映射
      • Metropolis light transport
      • VCM / UPBP…一系列正在研究的学术界前沿技术

GAMES101图形学专栏

  人工智能 最新文章
2022吴恩达机器学习课程——第二课(神经网
第十五章 规则学习
FixMatch: Simplifying Semi-Supervised Le
数据挖掘Java——Kmeans算法的实现
大脑皮层的分割方法
【翻译】GPT-3是如何工作的
论文笔记:TEACHTEXT: CrossModal Generaliz
python从零学(六)
详解Python 3.x 导入(import)
【答读者问27】backtrader不支持最新版本的
上一篇文章      下一篇文章      查看所有文章
加:2022-01-11 23:59:55  更:2022-01-12 00:01:16 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/27 21:43:09-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码