重要性采样的方法有多种,这里我们介绍其中一种,你的实现也可以使用其他方法。我们将通过 GGX 采样来完成 E(µ)的预计算工作。先从理论上讨论 GGX

采样算法,对于给定出射方向 o 的 GGX采样,目标是采样生成入射方向 i 以计算

\(\frac{f r (i,o,h)(i,n)}{pdf i (i)}\)。因此,对于 GGX 算法有两个核心问题需要解决:如何采样和对应的概率 pdf 是什么

第一个问题,如何采样入射方向 i。

我们首先根据选用的 NDF模型,重要性采样微表面法向 m(也就是 i,o 之间的半程向量h),随后通过采样得到的微表面法向 m,利用反射关系来计算入射方向 i:

\[i = 2(m · o)m − o
\]

同时对于任意 NDF 下,采样 m 对应的概率密度 pdf m (m),有:

\[pdf_m (m) = D(m)(m · n)
\]

(这是由 NDF 中

\(∫D(m)(m · n) = 1\) 这一性质得出,文档不会涉及到关于

NDF 性质的讨论。同样,关于下述 GGX 采样点生成的推导过程也会被略去)

通过该 \(pdf_m (m)\),可以计算出 GGX NDF 对应的采样点应该为:

\[θ_m = arctan(
\frac{
α \sqrt{ξ_1}}
{\sqrt{1 − ξ_1}
}) \\
ϕ_h = 2πξ_2
\]

其中,ξ_1 ,ξ_2 ∈ [0,1)。

补充:

\[pdf_m (m) = D(m)(m · n) \\
= \frac{a^2}{PI*(((n \cdot h)^2)*(a^2-1)+1)^2} (n \cdot h) \\
= \frac{a^2}{PI*(cos^2 \theta*(a^2-1)+1)^2} cos \theta
\]

因为我们可以用球面坐标(\(\phi\),\(\theta\))表示半径向量m,因此我们可以把\(pdf_m\)表示为\(pdf_{\phi}\)和\(pdf_{\theta}\)的乘法。\(pdf_{\phi}\)不依赖角度\(\phi\),所以我们可以简单的推导出:

\[pdf_{\phi} = \frac{1}{2\pi}
\]

所以:

\[pdf_{\theta} = \frac{pdf_m(m)}{pdf_{\phi}} = \frac{2 a^2}{(cos^2 \theta*(a^2-1)+1)^2} cos \theta
\]

运用逆变换采样(Inverse Transform Sampling Method)生成具有指定概率密度分布的随机变量,我们需要先得到概率密度的累积分布,这里直接给出结果。

\[cdf_{\phi} = \int_{0}^{\phi}\frac{1}{2\pi}dx = \frac{1}{2 \pi} \phi \\
cdf_{\theta} = \int_0^{q} \frac{2a^2x}{(x^2(a^2-1)+1)^2} dx = \frac{1-q^2}{1+q^2(a^2-1)}
\]

其中 \(q=cos(\theta)\).现在反转cdf函数,以产生从均匀值\(\epsilon_1,\epsilon_2\)到角度\(\phi,\theta\)的映射:

\[\phi = \epsilon_1 * 2 \pi \\
\theta = arccos \sqrt{\frac{1-\epsilon_2}{1+\epsilon_2(a^2-1)}}
\]

或者

\[\theta = arctan \frac{a \sqrt{\epsilon_2}}{\sqrt{1-\epsilon_2}}
\]

两者是等价的。

第二个问题,如何计算采样得到的入射方向的概率。

因为我们最后生成的采

样方向是入射方向 i, 所以最后结果的权重应该是:

\[weight(i) = \frac
{f_r (i,o,h)(i,n)}
{pdf_i (i)}
\]

所以需要将之前采样微表面法线的概率密度 \(pdf_m (m)\) 转换成采样入射的概率密

度 \(pdf_i (i)\),而两者之间的转换只需要简单的乘一个 Jacobian 项即可,即:

\[pdf_i (i) = pdf_m (m) ∥
\frac
{∂ω_m}
{∂ω_i}

\]

其中,对于反射有:

\[∥
\frac
{∂ω_m}
{∂ω_i}
∥=
\frac
{1}
{4(i · m)}
\]

讨论完以上两点后,最终对于采样入射的权重可以整理为:

\[weight(i) = \frac
{(o · m)G(i,o,h)}
{(o · n)(m · n)}
\]

补充

Jacobian项

直观理解

法线分布会以宏观法线为中心对应于一个波瓣lobe,在视线确定情况下,经过反射,反射光线又会形成于另一个波瓣。这两个波瓣的大小不同,因此对应点的概率密度分布也不同。

以一定概率任意取一个法线和以其中为中心的微小的立体角范围,会对应于另一个反射光线和其微小范围;这两个范围的光线的对应概率相等,因为它们直接是1-1映射的关系;又因为范围足够小,可以近似认为是概率密度在这个小区间均匀分布,因此:

\[pdf_h*A_h = pdf_o*A_o
\]

因此概率密度分布之比与微表面积之比成反比。

Kulla-Conty BRDF补充_重要性采样GGX的更多相关文章

  1. 转 如何理解 重要性采样(importance sampling)

    分类: 我叫学术帖2011-03-25 13:22 3232人阅读 评论(4) 收藏 举报 图形 重要性采样是非常有意 思的一个方法.我们首先需要明确,这个方法是基于采样的,也就是基于所谓的蒙特卡洛法 ...

  2. 【RAY TRACING THE REST OF YOUR LIFE 超详解】 光线追踪 3-4 基于重要性采样的材质初探

     Preface 我们今天来把第三本书从开局到现在讲的一大堆理论运用到我们的框架中,那么今天我们首先将原始的材质改为基于重要性采样原理的材质 这一篇是代码工程中进行MC理论应用的初步尝试篇  Read ...

  3. 【RAY TRACING THE REST OF YOUR LIFE 超详解】 光线追踪 3-2 蒙特卡罗(二) 重要性采样

    书本内容:见相册 preface 还记的我们上一篇说的Monte Carlo 维度诅咒吗 上一篇算是二维的例子吧,大家看了之后是否想着写一个一维的Monte Carlo模拟积分?(我想了,没写出来) ...

  4. Flutter实战视频-移动电商-16.补充_保持页面状态

    16.补充_保持页面状态 修正一个地方: 设置了item的高度为380 横向列表为380.最终build的高度也增加了50为430. 增加了上面的高度以后,下面那个横线划掉的价格可以显示出来了. 但是 ...

  5. 对pathtracing的一些个人理解

    本人水平有限,若有错误也请指正~ 上面说到pathtracing(pt)的一些优点和缺点,优点即其实现很简单,这就是大概为什么当今市面上流行的很多渲染器如今都相继采用pathtracing算法为核心进 ...

  6. Microfacet模型采样下的brdf

    本文前言 在学习图形学(games101 from bilibili)的时候,也遇到了像这样的问题,Cook-Torrance模型无法实现粗糙度为0时,物体微表面呈现绝对镜面的效果(呈现出一面镜子), ...

  7. Ward BRDF实现心得

    最近做了Ward BRDF的实现,相对于之前的lambert,phong来说,Ward是一个真正意义上的各向异性BRDF,但同样的,Ward模型也是一个基于经验的模型,并不是物理上正确的.它由ward ...

  8. 随机采样和随机模拟:吉布斯采样Gibbs Sampling

    http://blog.csdn.net/pipisorry/article/details/51373090 吉布斯采样算法详解 为什么要用吉布斯采样 通俗解释一下什么是sampling. samp ...

  9. PGL图学习之图神经网络GraphSAGE、GIN图采样算法[系列七]

    0. PGL图学习之图神经网络GraphSAGE.GIN图采样算法[系列七] 本项目链接:https://aistudio.baidu.com/aistudio/projectdetail/50619 ...

  10. MCMC等采样算法

    一.直接采样 直接采样的思想是,通过对均匀分布采样,实现对任意分布的采样.因为均匀分布采样好猜,我们想要的分布采样不好采,那就采取一定的策略通过简单采取求复杂采样. 假设y服从某项分布p(y),其累积 ...

随机推荐

  1. SpringBoot配置过滤器、拦截器

    拦截器概述 Spring Boot提供了一种简单且强大的方式来定义和使用拦截器(Interceptor).Spring Boot的拦截器基于Spring框架的拦截器机制,可以在请求的处理过程中插入自定 ...

  2. 【Dos-BatchPrograming】04

    --1.PING 主机联通性检测 Microsoft Windows [版本 10.0.19041.746] (c) 2020 Microsoft Corporation. 保留所有权利. C:\Us ...

  3. 【Git】04 文件删除

    版本分支的概念提示: 工作区就是我们的Git本地仓库,也就是一个很普通的目录 . 通过ADD指令添加文件到暂存区中, 在通过COMMIT指令提交到版本分支, 所谓的版本分支,就是就是这个蓝色的Mast ...

  4. 【转载】 Python格式化字符串f-string概览

    版权声明:本文为CSDN博主「sunxb10」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明.原文链接:https://blog.csdn.net/sunxb10/a ...

  5. NVRM: Xid (PCI:0000:b1:00): 13, pid=1375637, Graphics SM Global Exception on (GPC 0, TPC 1, SM 1): Multiple Warp Errors

    显卡服务器中一个显卡崩溃了: May 16 05:38:58 dell kernel: [14244871.006970] NVRM: Xid (PCI:0000:b1:00): 13, pid=13 ...

  6. vue&element项目实战

    1.背景 百度脑图链接:http://naotu.baidu.com/file/26ee2d8db38ad67e9905ae065bb0445e?token=e538157034f38f0d 1.1. ...

  7. Java如何防御XSS攻击?

    Q1.什么是XSS攻击? 定义很多,这里我找一个比较详细的解释 https://www.cnblogs.com/csnd/p/11807592.html Q2.为什么会有XSS攻击 也看上面的链接 Q ...

  8. rk3568 | rk平台GPIO冲突检测小技巧

    上一篇我们讲解了如何编写gpio驱动,但是实际操作中,经常发现gpio引脚被占用的情况发生,那么本篇文章就详细讲解rxw平台下如何快速定位gpio复用问题以及如何解决. 一.GPIO寄存器查找 要想查 ...

  9. 手把手教你利用鸿蒙OS实现智慧家居·LOT上云项目

    手把手教你利用鸿蒙OS实现智慧家居·LOT上云项目 一.前言 今天使用鸿蒙OS,做一个LOT上云的智慧家居项目.我们想实现的场景是这样的:云端WEB有一个控制界面,能够操控家房间里的灯和风扇,同时将房 ...

  10. 关于如何解决IDEA中同一个src下多个类中之一运行时自动报错其他类中的问题导致想要运行的类无法正常运行的问题的解决思路

    关于如何解决IDEA中同一个src下多个类中之一运行时自动报错其他类中的问题导致想要运行的类无法正常运行的问题的解决思路 WrongFirst: 我准备了一个正常类BG和一个有错误的类HelloWor ...