Spherical Harmonics Lighting
【转自:http://www.cnblogs.com/daniagger/archive/2012/05/29/2524133.html】
1、背景知识
1.1 光照表示
之前我们都只考虑光源点和物体表面点的光照作用,而现在,我们考虑物体表面点延伸的微型平面,这个微型平面作为半球形的底部,因此光照射进来的范围就是整个半球形,这也是BRDF的基础。
1.2 数据压缩
对于压缩信号来说,很多压缩技术基于这样一个思路:使用不同基函数的不同组合来组成一个更为复杂的数字信号表示。
保存数字信号的最繁琐方法是保存每一个数据点,然而一个复杂的信号可能有成千上万个点,所以需要找到方法来压缩。对于每一个基函数,我们用频率(frequency),振幅(amplitude)和相位(phase)来表示,这三个数被称为系数(coefficient),这样就大大减小了数据量。
在现实生活中,数字信号并不能很明显的表示成多个基函数的组合,很多例子中,系数的个数和原始数据点的个数相差无几,所以要找寻其他压缩方法。人们要寻找信号中那些信息是最为重要的,有些信息可能是噪声,这些信息需要被剔除出去。
基函数是这样一种函数,可以被裁剪和组合,来模拟任何一种数学函数。裁剪因子通常被称为系数(coefficient)。举个例子,如果要通过基函数组Bi(x)来模拟函数f(x),ci是对应的系数。
公式如下图:
这也就是傅里叶变换。
1.3 光照信息的压缩
对于diffuse lighting来说,高频率的部分需要被剔除。
2、SH的定义
Spherical harmonics是可以重构任何函数的基函数,研究二维函数的单位球。
SH是定义在单位球表面的基函数,表示在球面坐标下。
球坐标系
其中r=1。
SH的一般形式是
实际形式,也就是接下来会用到的形式是
最终形式是
公式中的项:
Plm是勒让德多项式,定义在[-1,1]范围内,递归式是
Klm是用来将函数规范化的裁剪因子,定义式是
SH的简化形式为(二维变一维)
3、构造
由SH基函数模拟的函数是
其中
上面的函数是原始函数的限制带宽版,原始函数表示为
使用SH的简化形式,则模拟的函数为
使用Monte Carlo积分算法,可以求出系数为
对于用SH构造的函数,你需要将单位球划分为n x n个样品,对于每一个系数,遍历所有的样品,应用上面的公式。最终可以得到所有系数的表达式。
4、SH的性质
4.1 正交性
4.2
4.3
5、SH应用到光照上
5.1 光照方程
最常用的光照方程是
Lo是表面顶点x在w方向上发出的光照度,其中w'是入射光线,由自发光部分(Le)和反射部分(Lr)组成,Lr的积分是对半球范围内所有的光线进行积分。
通过使用differential solid angle,光照方程可表示为
反射分量是对S中所有点的积分,入射光线从x’到x,V是x和x’之间可见度方程,G是几何项。V返回布尔值(如果x和x’相互可见,则返回1),几何项则依赖于表面点x和x’之间的几何关系。
该积分不能实时计算出来,所以需要预处理这个积分,利用性质2。
预处理步骤:
a、将入射光线投影到SH基上。入射光线需要表示成球坐标方程。
b、对于物体上的每一个点,将BRDF项、可见项、几何项的乘积投影到SH基上。该乘积也被当做转移方程。
实时积分项可以通过计算转移方程的SH系数和入射光线的SH系数的点积而得到,即利用性质2,将入射光线当成复合函数,BRDF项可见项几何项的乘积当做另一个复合函数,原始积分也就是两个复合函数乘积的积分。
同时,取样点分布在n x n的方形网格上,投影到球坐标系
现在我们需要简化光照方程,我们不考虑自发光,并且反射光线均匀分布在所有方向,BRDF是一个常量,最终我们得到
6、SH Diffuse Lighting
不考虑阴影的情况下(V项恒为1),特定点的diffuse lighting为
现在需要求入射光线的SH投影和cosine项(即转移方程)的SH投影,两者都用Monte Carlo积分法,这些都在预处理步完成。运行时,特定点的光照计算使用上述公式(将两个SH系数求点积)。
7、SH Diffuse Shadowed Lighting
现在需要考虑V项
新的转移方程变成了
要确定V项,需要从当前顶点追踪射线到场景中,如果射线和一个三角面片相交,则光线被阻挡。
8、SH Diffuse Shadowed Inter-Reflected Lighting
现在,不仅要考虑从光源发出来的光线,还要考虑在场景中互相作用的光线。也就是全局光照。简化了的光照方程如下
Spherical Harmonics Lighting的更多相关文章
- 球谐光照(Spherical Harmonics Lighting)及其应用-实验篇
简介 之前在一篇实时深度图优化的论文中看到球谐光照(Spherical Harmonics Lighting)的应用,在查阅了许许多多资料之后还是无法完全理解,我个人觉得如果之前对实时渲染技术不是很了 ...
- 球谐光照(Spherical Harmonics Lighting)及其应用-应用篇
上一篇介绍了球谐函数的一些原理和性质,本篇主要介绍如何实现球谐光照,将这种光照应用到实际的场景中去. 我们知道,球谐光照实际上就是将周围的环境光采样成几个系数,然后渲染的时候用这几个系数来对光照进行还 ...
- Luckily general gradient for spherical harmonics is defined
http://web4.cs.ucl.ac.uk/staff/j.kautz/publications/gradientSH_RS04.pdf
- Thinking in Unity3D:渲染管线中的Rendering Path
关于<Thinking in Unity3D> 笔者在研究和使用Unity3D的过程中,获得了一些Unity3D方面的信息,同时也感叹Unity3D设计之精妙.不得不说,笔者最近几年的 ...
- Physically Based Shader Development for Unity 2017 Develop Custom Lighting Systems (Claudia Doppioslash 著)
http://www.doppioslash.com/ https://github.com/Apress/physically-based-shader-dev-for-unity-2017 Par ...
- SRBF Lighting
SRBF的全称是Spherical Radial Basis Function,笔者擅自翻译为球面放射基底函数.由于SRBF并不怎么出名,相对来说,SH(Spherical Harmonic)球 ...
- Image Based Lighting In UE3
"IBL"全称为"Image-based Lighint",是一种伪装全局光照的方法.使用该方法可以获得较好的视觉效果并且可以达到实时渲染的目的. 实现的方法之 ...
- [我给Unity官方视频教程做中文字幕]beginner Graphics – Lessons系列之灯光介绍Lights
[我给Unity官方视频教程做中文字幕]beginner Graphics – Lessons系列之灯光介绍Lights 既上一篇分享了中文字幕的摄像机介绍Cameras后,本篇分享一下第2个已完工的 ...
- Computer Graphics Research Software
Computer Graphics Research Software Helping you avoid re-inventing the wheel since 2009! Last update ...
随机推荐
- mysql统计功能和数据库information_schema/performance_schema
1.去重统计数据表行数: select count(distinct col_name) from table_name; 2.统计行数 select count(*) from table_name ...
- sklearn 特征选择
1.移除低方差的特征(Removing features with low variance) VarianceThreshold 是特征选择中的一项基本方法.它会移除所有方差不满足阈值的特征.默认设 ...
- 《ASP.NET》数据绑定—DataList实践篇
上篇文章大概讲了DataList的一些基础知识,掌握这些知识在将来的应用中起到非常大的作用,如今我们就開始讲上篇文章中说的基础知识做一个小样例. 首先,我机子的数据库中有一张person表.例如以下图 ...
- [HTML5] Show Images of Differing Resolutions Depending on the Viewport Width with srcset
For small viewports, we want to save bandwidth and we may be dealing with slow speeds; so it's very ...
- 区间DP与贪心算法的联系(uav Cutting Sticks && poj Fence Repair(堆的手工实现))
由于,这两题有着似乎一样的解法所以将其放在一起总结比較,以达到更好的区分二者的差别所在. 一.区间DP uva的Cutting Sticks是一道典型的模板题. 题目描写叙述: 有一根长度为l的木棍, ...
- java开始到熟悉66-69
本次内容:DateFormat类 1.DateFormat类 package array; /** * 时间和字符串之间的转化 */ import java.text.DateFormat; impo ...
- 解决Sql server分页时第二页以上查询结果不正常的问题
有100个产品,其中最高价格的为200元,而200元的产品共有40个, 现在好了,对每页30进行分页: declare @PageSize int--30 declare @Page int decl ...
- C#连接数据库 增删改查
- find the longest of the shortest (hdu 1595 SPFA+枚举)
find the longest of the shortest Time Limit: 1000/5000 MS (Java/Others) Memory Limit: 32768/32768 ...
- android-custom-tab-with-viewpager
https://github.com/eltld/android-custom-tab-with-viewpager