Games101课程笔记(二)
光线追踪 Ray Tracing
Why Ray Tracing
-
光栅化不易于把一些全局的效果处理好
-
阴影(软阴影)
-
尤其是光线的多次反射(Glossy reflection, indirect illumination)
-
-
光栅化很快,但是质量相对较低(一种快速的近似)
-
光线追踪很准确,但是很慢
- Rasteriaztion:real-time,Ray Tracing:offline
- 生成1帧图大概需要渲染10k CPU hours
Basic Ray-Tracing Algorithm
Light Rays
关于光线的三个idea:
- 光沿直线传播(虽然实际上是错的)
- 即使光线之间彼此相交,光线也不会与彼此发生碰撞
- 光线从光源沿着一定的路径射向眼睛,且光路可逆
实际上光线追踪是从相机出发向世界中投射光线
Ray Casting
光线投射
-
从相机处此处认为相机是一个点),对成像平面上的每一个像素向场景中投射光线,记录最近的交点(类似深度)
-
(考虑记录的交点会不会被照亮)连接交点和光源(shadow ray),如果shadow ray上没有其他物体,那么说明这个交点被光源照亮,再执行shading计算得出像素的颜色
局限:还是只考虑了一次光线的反射
Recursive(Whitted-Style) Ray Tracing
data:image/s3,"s3://crabby-images/42912/429129b0abc368b7e17dcb26d349611ff4a5e067" alt="image-20221029140801196"
data:image/s3,"s3://crabby-images/b3c04/b3c04ad5a41cf691ca968b06904e05bb41fd0ac5" alt="image-20221029141444034"
Ray-Surface Intersection
Ray Equation
- 用==光源==和==一条方向向量==定义光线
data:image/s3,"s3://crabby-images/e8673/e8673a8bf42e11a6121cd74e9922d80f266a679e" alt="image-20221031134715406"
- Ray Equation:( :时间,非负 )
- Ray Intersection with Sphere:
data:image/s3,"s3://crabby-images/1820a/1820a8018a36844fdae789c09410880742e53eb4" alt="image-20221031134829060"
data:image/s3,"s3://crabby-images/9827c/9827cf6a4784b241e679070e118433cd2aa861bd" alt="image-20221031135046371"
- 推广到光线与Implicit Surface隐式表面的求交:
data:image/s3,"s3://crabby-images/159ac/159ac140feb483d286bcf0f259383bdc38ccf40d" alt="image-20221031135523563"
Plane Equation
- 用==一个点==和==一条法线向量==定义一个平面
data:image/s3,"s3://crabby-images/a1999/a19997829d477de4225ac08ee3cb4c2903bcb660" alt="image-20221031142041202"
- Plane Equation:
-
光线和三角形面求交:
转换为两步:
-
光线与平面求交
-
然后再通过cross判断交点是否在三角形内部即可
-
Moller Trumbore Algorithm
简化三角形和光线求交的算法
原理:一个点在三角形内,那么就可以写为重心坐标的形式,那么一个交点就应该同时满足光线方程和存在三角形重心坐标两个条件(通过三者之和等于一和及三者非负即可判断点在三角形内)
data:image/s3,"s3://crabby-images/89271/892712ddaaaf9f153b5106d514925339c57e1f07" alt="image-20221031143750573"
Accelerating Ray-Surface Intersection
Bounding Volumes(BVol)
- 一个可以完全包围物体的体积
- 如果光线不hit包围盒,他就不会hit物体
- 所以可以先检测BVol是否被hit,如果hit了再检测物体
data:image/s3,"s3://crabby-images/22591/22591102300dc9a4f628de28d6b2104f5d3084cb" alt="image-20221031144453059"
Ray-Intersection with Box
理解Box:Box是三组相对的面形成的交集(Box is the intersection of 3 pairs of slabs)
通常用Axis-Aligned Bounding Box(AABB)(轴对齐包围盒)
data:image/s3,"s3://crabby-images/750ad/750ad118edfb7403b8b704a24046ec49d443a5e5" alt="image-20221031144835452"
Ray Intersection with Axis-Aligned Box
原理:计算光线和平面相交的时间,并判断得到光线在BVol内部的时间(起始时间为最后一个轴向的进入时间,结束时间为最早一个轴向的离开时间)
data:image/s3,"s3://crabby-images/b31d8/b31d8d11eb5363de03a5544ea815c3060f478653" alt="image-20221031145701232"
三维空间中:
data:image/s3,"s3://crabby-images/38be3/38be356af26fd2eafc7ed3f56ad680f0cef3286f" alt="image-20221031145808578"
data:image/s3,"s3://crabby-images/ea2cf/ea2cfafffc8ba219dac533899a7a91c9292c2697" alt="image-20221031150424561"
为什么用Axis-Aligned的绑定盒:极大地简化加速求交
用随意的包围盒,进行求交时要做三个轴向上的减法,再乘法线,就会有3次减法,六次乘法和一次除法
而用轴向包围盒,只需要考虑一个轴向的距离,除上光线在该轴的分量即可
data:image/s3,"s3://crabby-images/2a7ad/2a7ad7c331598717590b26fea5e0bee5a352ee39" alt="image-20221031150546448"
AABB totally : 3 subtraction, 3 division, get min and max
Using AABBs to accelerate ray tracing
Uniform Spatial Partition(Grids)
Preprocess — Build Acceleration Grid
找到场景的包围盒,在包围盒内划分网格,判定哪些网格里与物体相交并标记与物体相交的网格(只考虑表面不考虑内部)
data:image/s3,"s3://crabby-images/0080c/0080c599d64483ea5a33856d70db76dd5fd01777" alt="image-20221031152717717"
Ray-Scene Intersection
投射光线,顺着光线方向与一个一个的盒子求交,对于预处理过程中没有被标记的盒子不需要做与实际物体求交的操作;当光线遇到在预处理过程中被标记的盒子时,意味着这个盒子里会有物体,光线有可能会与物体有交点,所以需要在这个格子内与物体求交进行判断;当找到光线与物体的第一个交点后光线就可以停下来了
data:image/s3,"s3://crabby-images/cfb4f/cfb4ffdb377b436a8944c085dbc8920c22fde71a" alt="image-20221031153948853"
”沿着光线方向“的实现方法:(一种没有在用但是很好理解的方法)光栅化一条直线的方法:知道这个盒子现在在和光线求交,那么下一次和光线进行求交的一定是他周围的盒子
Grid Resolution
包围盒内的网格太密集太疏松都不好
data:image/s3,"s3://crabby-images/883cb/883cb74b50fd448c3a4e0fe4a82bb7d5a3edf664" alt="image-20221031154933884"
data:image/s3,"s3://crabby-images/8864f/8864ff93b7bd9d12052242eedbafaa05bbbf3272" alt="image-20221031155023804"
效果不错的格子数量:(这也并非游戏中实际使用的方法,因为它还是要走过他所相交的所有格子,只用知道Grid数量不能太多或太少,有一个平衡就好)
data:image/s3,"s3://crabby-images/ea94f/ea94ff368a9e4b01eb4c86bd991988d970cac504" alt="image-20221031155110244"
When Uniform Grids Fail
适合应用于场景中有很多物体的情况
data:image/s3,"s3://crabby-images/40bf3/40bf3d24d21a61f117ff9f521e57b7640b6111ea" alt="image-20221031155418553"
但是不适合用于场景很空的情况——”Teapot in a stadium“ problem
data:image/s3,"s3://crabby-images/1dab5/1dab538aa9057e2517bdc6899f5866fd304abb5e" alt="image-20221031155604320"
Spatial Partitions
Spatial Partitioning Examples
data:image/s3,"s3://crabby-images/e4676/e4676ac005ac82af011531d3cb07890207897b82" alt="image-20221031155754217"
- Oct-Tree:八叉树(平面情况是四叉树——和维度绑定,在高维度不好计算)
- KD-Tree:和八叉树几乎完全相同,区别在每次找到一个物体就会在轴向上砍一刀,形成类似二叉树的结构;KD-Tree是层之间循环轴向切割,即这一层沿着x方向,下一层就沿着y方向,再下一层沿着z方向,以xyz顺序循环
- BSP-Tree:每一次选一个方向将节点砍开,与KD-Tree区别在于不是横平竖直地砍,且在高维度会不好计算
KD-Tree Pre-Processing
在进行光追前先做好加速结构,再去考虑与光线求交
data:image/s3,"s3://crabby-images/9d4f3/9d4f378faa416784ec1aaae1e17eda951f69d04e" alt="image-20221031160655382"
注:蓝色绿色部分都会砍开,只是没有画出来
- 中间节点只需要记录它会被如何划分
- 叶子节点(决定不再划分地节点)才需要再去存储和格子相交的几何形体的信息
Data Structure for KD-Trees
中间节点存储:
- 该节点向下分裂的轴向
- 平面沿着轴向的分裂位置
- 指向子节点的指针
- 实际物体不会储存在中间节点内
叶子节点:
- 储存实际物体的链表
Traversing a KD-Tree
光线照射进入BVol
data:image/s3,"s3://crabby-images/87dd3/87dd34dcef7ffbbcca76b880bd6e2f434c2bfb19" alt="image-20221031164219472"
data:image/s3,"s3://crabby-images/af65f/af65fb4dc34d8e8fbb8193b4dc35ae53febc5989" alt="image-20221031164252835"
发现A内有物体,就需要和A的两个子节点都进行求交(A有分支,就对A和他的子分支求交,以此递归,直到找到叶子节点)
data:image/s3,"s3://crabby-images/b1904/b190449c87d97699adcda2621a6068cdcaccb2f7" alt="image-20221031164335169"
data:image/s3,"s3://crabby-images/35a35/35a35690533dcb8fa31cabf9ee289201bb0ef9f2" alt="image-20221031164346824"
以此向下进行
data:image/s3,"s3://crabby-images/8b412/8b41274b576f728e5b9e2a01f9bd434d259f1506" alt="image-20221031164720396"
即:光线如果和该节点有交点,那么光线会向下对该节点的两个子节点求交;如果光线和该节点没有交点就不会继续对该节点的子节点求交;以此向下进行,直到找到叶子节点
Problem
- KD-Tree的建立不简单,需要考虑三角形与盒子的求交(举例:三角形三个顶点不在盒子内,但是这个盒子内有三角形的一部分的情况,不容易处理三角形与盒子的求交)
- 物体可能存在于多个盒子内
Object Partition & Bounding Volume Hierarchy(BVH)
以物体为根基,把物体”分堆“并重新计算他们的包围盒——解决了物体可能存在于多个盒子内的问题
data:image/s3,"s3://crabby-images/651b4/651b401cb359f19ad79294364491976b40b19e58" alt="image-20221031165738846"
data:image/s3,"s3://crabby-images/a9432/a9432a6d3e117cdc69cfb06411b18c65cfee4ae0" alt="image-20221031165706006"
data:image/s3,"s3://crabby-images/16799/16799bfa1eaeb11614b0fb03fa56dc1db615366e" alt="image-20221031165715402"
data:image/s3,"s3://crabby-images/e3d29/e3d29589d3544f3eed7438c3640e43efdab694d3" alt="image-20221031165725003"
data:image/s3,"s3://crabby-images/14f23/14f23fdd79d7c257f3787d1b0d64ae5c8cb4cf15" alt="image-20221031165916240"
实际上如何划分一个节点:
- 选择一个维度去划分
- Heuristic ##1:总是沿着最长的轴去划分,让最长的轴变短,让整个结构最后变得均匀
- Heuristic ##2:取中间的物体进行划分(第个),让这棵树接近平衡
- 无序的一列数快速找出中位数(不需要排序):快速选择算法,只对快排划分出的某一边进行操作,可以使时间复杂度在以内
最终取值:
- Heuristic:节点内含有少量元素时终止
Data Structure for BVHs
中间节点存储:
- 包围盒
- 指向子节点的指针
叶子节点存储:
- 包围盒
- 存储实际对象的链表
节点代表场景中原始物体的交集
- 所有物体都在subtree中
BVH Traveral
data:image/s3,"s3://crabby-images/eec97/eec97ce97c8ecbf17770d79e1ef0cacba67c8f2c" alt="image-20221031175944272"
Spatial vs Object Partitions
data:image/s3,"s3://crabby-images/60db9/60db9d78d4a6b48d63ad68fcbc818783f55fe28c" alt="image-20221102090457290"
Basic Radiometry
—— 辐射度量学
why radiomentry
data:image/s3,"s3://crabby-images/e0266/e026660e22c8f16040c080d68239e0433ecb7eb3" alt="image-20221102092649223"
Radiometry
-
Measurement system and units for illumination
-
精确测量光在空间中的属性,并且还是基于几何光学(光沿直线传播,不考虑波动性)
- New terms:Radiant flux,intensity,irradiance,radiance
-
辐射度量学实际上是在物理上准确定义光照的方法
Radiant Energy and Flux(Power)
######## Radiant Energy
Radiant energy是电磁辐射的能量,以焦耳为单位,用符号表示:
######## Radiant flux(power)
单位时间内发射、反射、转换或接收的能量
(lumen是光学上的单位,理解为光的亮度)
Flus —— 单位时间通过感光位置的光子量
Radiant intensity
data:image/s3,"s3://crabby-images/c84a4/c84a4257711846fe11e628fea9d1386a840f5ff9" alt="image-20221102094718694"
######## Definition
The radiant (luminous) intensity is the power per unit solid angle emitted by a point light source
data:image/s3,"s3://crabby-images/f9a10/f9a102e4b3bb3ad33528e6f93bb815e54f327033" alt="image-20221102095000345"
######## Solid angles and Solid angle
Angle: ratio of subtended arc length on circle to radius
-
-
Circle has 2 radians
Solid angle: ratio of subtended area on sphere to radius squared
-
-
Spere has 4 steradians
-
弧度在球面上的延申——球弧度,立体角描述空间上的角张开的大小
######## Differential Solid Angles
微分立体角:理解为取一个方向在球面上打到的点,再将这个方向向量的和都增加一个极小的量,最后投影到球面上得到的一个小曲面对应的立体角
data:image/s3,"s3://crabby-images/d623b/d623bd955469b2c2d57b57e2ac7969c38f1ab030" alt="image-20221102100229494"
对微分立体角在整个球面上积分可以得到整个球的表面积
data:image/s3,"s3://crabby-images/dfa4a/dfa4a21b6a75ae075b77703703721182763c9ce7" alt="image-20221102100253612"
######## as a direction vector
data:image/s3,"s3://crabby-images/97a55/97a55c171ec4264261d09619633b8b10ab3191f5" alt="image-20221102100509856"
######## Isotropic Point Source
Radiant intensity(intensity)就是单位时间内光源向各个方向发射的光子能量强度
data:image/s3,"s3://crabby-images/d3c4e/d3c4e5076c41b7fd494da852c0dca4555e6b785d" alt="image-20221102100617487"
intensity是单位面积上的power,因此对intensity在面积上进行积分可以得到power
Irradiance
######## Definition
The irradiance is the power per unit area incident on a surfacec point
data:image/s3,"s3://crabby-images/c7264/c72649c2f8998244297d9d0442bb7ab2a0993880" alt="image-20221103082924980"
- lambert计算漫反射时需要投影到垂直部分
data:image/s3,"s3://crabby-images/0ec4e/0ec4ea7d34db4bbd9483bbc125f599c47ea8483b" alt="image-20221103082948987"
-
四季的原因:
######## light Falloff
Light falloff的正确解释:不是intensity的衰减,而是irradiance的衰减,传播到越往外面积越小,irradiance越小
data:image/s3,"s3://crabby-images/1977f/1977f39a415c01276f900f0db8313706b3ea114c" alt="image-20221103083757218"
Radiance
######## Definition
The radiance (luminance) is the power emitted, reflected, transmitted or received by a surfae, per unit solid angle, per projected unit area
data:image/s3,"s3://crabby-images/d62ef/d62ef13676a336908d8b59b9f406c9cf6eb1558c" alt="image-20221103091228894"
对power的两次微分:单位立体角、单位投影面积
一个单位面积可能和光的朝向不垂直,在度量特定方向的光的朝向时需要进行投影,即需要确定某一个特定的面和某一个特定的方向,通过这样的方式去定义光线
######## Radiance comprehension
Recall
- Irradiance:power per projected unit area
- Intensity:power per solid angel
So
- Radiance:Irradiance per solid angle
- Radiance:Intensity per projected unit area
######## Incident Radiance
一个面接收到的能量:
入射Radiance是单位立体角上的到达入射表面的irradiance,即radiance和irradiance的区别在于是否有方向性
data:image/s3,"s3://crabby-images/8ea78/8ea78fea5a5e12bb958eae23f164303701797b50" alt="image-20221103092219803"
######## Exiting Radiance
一个面发射出去的能量:
出射Radiance是在单位投影面积上的intensity,即radiance和intensity的区别在于是否投影到单位面积
data:image/s3,"s3://crabby-images/a87e1/a87e1c22307329faa312ae657909ccc02dad3ef1" alt="image-20221103092447422"
######## Irradiance vs. Radiance
Irradiance:一个很小的范围收到的所有的能量
Radiance:一个很小的范围收到的特定方向的能量
data:image/s3,"s3://crabby-images/37966/3796609cfdc069dc651790bbac280defa267173b" alt="image-20221103092653435"
BRDF and Rendering Equation
Bidirectional Reflection Distribution Function 双向反射分布函数
BRDF
反射的解释:
Radiance从方向打到成为接收到的power,然后power会成为向任意的方向的Radiance
data:image/s3,"s3://crabby-images/eb7dd/eb7dd6d1e64820c17c05453d3ff36463a702ca28" alt="image-20221103175101463"
Differential irradiance incoming:
Differential radiance exiting (due to ):
BRDF的解释:
定义一个函数,描述微小面积,从某一个微小立体角接收到的irradiance会如何被分配到各个不同的立体角上去,即一个比例,任何一个出射方向的radiance去除以这一个小块接收到的irradiance
BRDF的定义:
The Bidirectional Reflection Distribution Function respresents how much light is reflected into each outgoing direction from each incoming direction
data:image/s3,"s3://crabby-images/4eac8/4eac85080f48c4400709369df714374703cffc28" alt="image-20221104083838585"
Reflection Equation
考虑入射的全部方向:反射方程
data:image/s3,"s3://crabby-images/fb3ec/fb3ec2d7575006adbaa078ce9bf0f8be8f48980a" alt="image-20221104084617363"
Challenge: Recursive Equation
光线在场景中不可能只弹射一次,任何出射的radiance都可能成为别的面的入射radiance,会存在一个递归的形式
data:image/s3,"s3://crabby-images/4cb49/4cb49730401ad2ae9a8835fd5c6a90ce2b0e9b1d" alt="image-20221104085337313"
Rendering Equation
考虑自发光后:
- 假定所有方向都指向外
- 同都表示半球(下半球的光不会造成影响,所以考虑的只是半个球体,而非一个球体)
Summary
data:image/s3,"s3://crabby-images/defa0/defa02627cd0ccbb038996cddffe75d7cfbde6ee" alt="image-20221104090700392"
data:image/s3,"s3://crabby-images/f844c/f844c7c21e2c6e964639789821d2f77648e852f4" alt="image-20221104090725287"
data:image/s3,"s3://crabby-images/6d7d3/6d7d31842a0e52cf6e956d743dd74523d085a080" alt="image-20221104090859301"
将渲染方程简化为一个积分方程
data:image/s3,"s3://crabby-images/eda59/eda59ce12c36df638a522038e1c046eb1dd6e40f" alt="image-20221104091148088"
可以把渲染方程进一步简化为一个线性矩阵方程
data:image/s3,"s3://crabby-images/de993/de993271fc971e60d6ad4f287f8175243d4f7b34" alt="image-20221104091157031"
最终就是要把L解出来
写成这么一种算子的形式,因为这个算子同样有类似泰勒展开的性质,虽然是矩阵,但也可以写作这样的形式
data:image/s3,"s3://crabby-images/50a2b/50a2b9c8f45e8525413cf8927dd88240b2446c5d" alt="image-20221104092026337"
最终看到的能量分解为:直接看到的光源能量(自发光)+光线弹射一次看到的能量(直接光照)+光线弹射两次看到的能量(间接光照)+…(间接光照)…
所有光线弹射的间接光照得到的集合是全局光照
data:image/s3,"s3://crabby-images/292ec/292ec0df1397a27f86225686a324fb768a272cfa" alt="image-20221104091413994"
从光栅化的角度来看渲染方程的分解,着色做的就是分解项的前两项,即光栅化能告诉我们的内容就只有自发光和直接光照部分,后面的部分就会比较麻烦
data:image/s3,"s3://crabby-images/7ac24/7ac240eb779ed3dda745612e9605605fe9299d1c" alt="image-20221104092649362"
光照弹射次数的效果对比:
路径追踪 Path Tracing
Monte Carlo Integration
What&How
What:解一个定积分:不写出不定积分积分后的解析式,而是直接获得定积分
How:在积分域内不断去采样,把整个积分区域的函数当作是一个矩形(y相等),采样采到的x对应的y就作为整个函数的y,这样多次采样后再求平均
data:image/s3,"s3://crabby-images/262e5/262e5dda3464a2c89e509c611c8e112d4c7da4e4" alt="image-20221105083750946"
Definition
通过给定的函数定义Monte Carlo Integration
-
Definite integral
-
Random variable
-
Monte Carlo estimator
是采样点在积分域上的概率,即为,所以相当于矩形的宽
如果在[a,b]上平均采样的特殊情况:
data:image/s3,"s3://crabby-images/87943/8794322a6f31adcb70a7083629222961304db451" alt="image-20221105085409582"
data:image/s3,"s3://crabby-images/ebead/ebeadb745a7b5a4a11fa6c87e1dfa80047e44e7e" alt="image-20221105085448755"
data:image/s3,"s3://crabby-images/22abc/22abcb74c4f26b267b82e4c3e3d6451f04958e8f" alt="image-20221105090535651"
note:
- 采样点越多,误差就越小
- 不用关心积分域,在考虑积分时不用考虑积分域是多少,积分域已经在PDF(Probility Distribute Function)中体现出来了
- Monte Carlo积分要求:在x方向上采样,就在x方向上积分
Path Tracing
Problems of Witted-Style Ray Tracing
Problem 1
光线应该被glossy材质(并非完全光滑的材质)反射到哪里
data:image/s3,"s3://crabby-images/021c5/021c59afb4be466ec1c088117476f0da2a90504f" alt="image-20221105091425437"
Problem 2
漫反射材质之间的相互反射
data:image/s3,"s3://crabby-images/e79a9/e79a9f859384edb7584e420956f6978f0e863990" alt="image-20221105092241071"
Whitted-Style Ray Tracing is Wrong
But Rendering equation is correct
但是这个方程包括:
- 计算在半球上的积分
- 递归计算
A Simple Monte Carlo Solution
假定渲染一个像素在所受直接光照的结果
data:image/s3,"s3://crabby-images/2cde3/2cde3bfbf6f11a78a569363e5a9df48f390f2a69" alt="image-20221105093211160"
通过反射方程来做解释(因为渲染方程也只是多了一个自发光),那么实际上就只是一个在不同方向上的积分。通过Monte Carlo积分计算就是随机取一个方向作为随机变量,找到他对应的和PDF即可
data:image/s3,"s3://crabby-images/16d13/16d1392adb9e826173f65960b17499748b19e8f0" alt="image-20221105093456799"
反射点为p
data:image/s3,"s3://crabby-images/40df9/40df9248fa994d4b4ff5bf85b94c79636af315ff" alt="image-20221105093905643"
将积分变为一个简单的求平均值
data:image/s3,"s3://crabby-images/99e3b/99e3b69002419fb73755acac1a342db01f2542b7" alt="image-20221105094308240"
算法:
data:image/s3,"s3://crabby-images/854d2/854d2c1a8c1c1ed8345da1ac3c70384e4f6a4f98" alt="image-20221105094324469"
Introducing Global Illumination
加入间接光照就相当于:眼睛在P点看Q点,获得P点的吸收能量
data:image/s3,"s3://crabby-images/1ef28/1ef287f04d79a011d3c0b73c9f0f9f096bd9a407" alt="image-20221105094541320"
递归算法:
data:image/s3,"s3://crabby-images/a3aaf/a3aaf11b1368d53aa9734152cb83d33a5918a7f5" alt="image-20221105094630621"
但是存在问题
-
Problem 1:如此计算,光线的数量会“爆炸”
N = 1 唯一能防止指数爆炸
所以进一步改进算法:目前,我们假设在每个着色点上只有一根光线被追踪
用N = 1来做Monte Carlo积分就叫做路径追踪,N != 1叫做分布式光线追踪(光线指数爆炸)
这样获得的结果会变得noisy,不过通过在每个pixel上追踪更多的path(注意不是增加N)并最后取radiance的平均即可
算法:
-
Problem 2:递归算法何时停止?
不能通过限制递归次数的方法来解决,这样做会损失能量,cutting ##bounces == cutting energy,多次弹射的能量就损失了
Solution:Russian Roulette(RR)
用俄罗斯轮盘赌的方式来决定一定的概率停止向下追踪,即不会一直向下追踪,在一定的条件下会停下来
首先,某一个着色点它的出射的radiance是,给一个概率p,,以一定的概率p向某个方向打一条光线,返回值为得到的一定的结果再除以p,即/P;在1-p的概率内不打出光线,返回0。最终,得到的结果的期望仍然为
代码:
Sampling the Light
以上已经是正确的Path Tracing了
但是这样的Path Tracing并不高效,SPP不足就会出现很多噪点
data:image/s3,"s3://crabby-images/10410/10410e268da4ba81cb300949e1415c6150a0451f" alt="image-20221105103628147"
低效的原因:
在着色点上向半球四面八方均匀采样时,从一个点打出去的很多线中只会有1根打到光源,有很多的光线被浪费
data:image/s3,"s3://crabby-images/55d3b/55d3b7d2a81f7e76a185bd61847298ed607b4cab" alt="image-20221105103929661"
Solution:
直接在光源上进行采样要对光源上的微表面面积进行积分把BRDF方程改写成对的积分
data:image/s3,"s3://crabby-images/aa1bd/aa1bd497549f996cae0a0ff7277eadba36cdc58e" alt="image-20221105104542348"
知到和的关系即可——投影的面积
data:image/s3,"s3://crabby-images/17fb2/17fb21fdf9753832ec8619722323f5446e47e9bd" alt="image-20221105104804357"
变量替换后:
data:image/s3,"s3://crabby-images/083ba/083ba28ac258b7fe1113d9c607a322c2087b7223" alt="image-20221105105007553"
所以可以把着色点接收到的radiance分为两部分:
data:image/s3,"s3://crabby-images/fbdd1/fbdd16da58de8545d648d74b9aa977d325b56242" alt="image-20221105105426685"
data:image/s3,"s3://crabby-images/8a5d0/8a5d042043265d8f7cfd2cb0f30c4a8885db30c6" alt="image-20221105105623893"
多一步判断光源和接收点p之间有物体阻挡
data:image/s3,"s3://crabby-images/02a06/02a060da6b51a13b286c3a1bb804178178daa916" alt="image-20221105105952419"
Path Tracing will Generate Photo-Realistic
data:image/s3,"s3://crabby-images/fd64c/fd64c2463e924bf7b325c53f6b5201be3855f750" alt="image-20221105110255699"
Some Side Notes
Modern Concepts of Ray tracing
-
Previous
Ray Tracing == Whitted-style ray tracing
-
Modern
The general solution of light transport, include:
- Unidirectional & bidirectional path tracing
- Photon mapping — 光子映射
- Metropolis light transport — 光线传输
- VCM — 结合双向路径追踪和光子映射
- UPBP — 结合所有方法
Haven’t covered
- 怎样对半球进行采样
- Monta Carlo积分能用在任意的pdf上,那么选择什么样的pdf是最好的(importance sampling)
- 随机数的选取(low discrepancy sequences)
- 采样半球和采样光源结合(multiple imp. sampling)
- 对能量的平均是否加权(pixel reconstruction filter)
- 一个像素里面的radiance怎么混合颜色(gamma correction,curves,color space)
材质和外观 Materials and Appearances
Material == BRDF
Diffuse/Lambertian Material(BRDF)
data:image/s3,"s3://crabby-images/396b5/396b5e608e79c51e22f6ede0d37e04d7d71f6e01" alt="image-20221106120044267"
漫反射系数的正确定义:
假设空间中各个方向进来的irradiance都相同(uniform),反射向各个方向的irradiance也都是uniform,且物体表面不吸收光,由能量守恒得到入射光的radiance和出射光的radiance相同,即,所以
data:image/s3,"s3://crabby-images/f073e/f073e58b2b663bc3f2cbc86e887dd8f57d8a9170" alt="image-20221106120610555"
即为albedo:反射率,在0-1之间
Glossy Material
data:image/s3,"s3://crabby-images/0ab9f/0ab9ff0fee987539f55876753cd162aeac422f6b" alt="image-20221106123526908"
Ideal Reflective/Refractive Material(BSDF)
BSDF = BRDF + BTDF
data:image/s3,"s3://crabby-images/befee/befee6fcf69dd64769feb84ecca4c7b00e8072ea" alt="image-20221106123806047"
Perfect Specular Reflection
data:image/s3,"s3://crabby-images/90029/900295056080f3452ca29503e351d094cf7e5ba6" alt="image-20221106124526763"
Specular Refraction
data:image/s3,"s3://crabby-images/f8eb1/f8eb1e8ee6913046bbdbd01882c211bf0a0d1adb" alt="image-20221106124741807"
Snell’s Law
data:image/s3,"s3://crabby-images/3aa73/3aa730da19a216a73b1f084426c63e7c669b389e" alt="image-20221106124957754"
data:image/s3,"s3://crabby-images/6023b/6023b98d4df2e812b112319a14e674af3699bf54" alt="image-20221106125649137"
Snell’s Window/Circle
水底只有一个锥形区域会有光线折射进入(只能看到一个锥形区域)
data:image/s3,"s3://crabby-images/63653/636537ac1cab6d8c067a8baaf79c60b070fd9d52" alt="image-20221106132831822"
Fresnel Reflection/Term
现象:不同角度看桌面,反射内容是不一样的
data:image/s3,"s3://crabby-images/8cbcd/8cbcd948183f6f7965960bd87c015777fff3fec7" alt="image-20221106133142200"
菲涅尔项:
-
绝缘体反射率随入射光角度变化
-
导体反射率随入射光角度变化
-
计算公式
Microfacet Material
Microfacet Theory
粗糙表面:
- Macroscale:flat&rough(从近处看的是几何)
- Microscale:bumpy&specular(从远处看的是材质)
单个微表面都想一面镜子一样
- 每个微表面都有自己的法线(朝向)
data:image/s3,"s3://crabby-images/c5945/c59452d8e5a3ac35f90d6a469ce72bbfb2443df1" alt="image-20221106134847542"
Microfacet BRDF
-
key:研究微表面发现的分布
-
微表面分布集中glossy
-
微表面分布分散diffuse
-
-
Microfacet BRDF
-
—— shadowing-masking term
微表面之间可能发生相互遮挡,所以有些微表面满足反射但是会被遮挡,失去了他们的作用,即实际计算得到的反射能量可能偏大。Shadowing-masking考虑的就是这个现象。定义一个Grazing Angle,十分接近与法线垂直的角度,当光线接近Grazing Angle时,shadowing-masking就用于修正这个现象。
-
—— distribution of normals
描述有多少微表面实现从入射到出射方向的反射
-
Isotropic/Anisotropic Materials
-
Key:directionality of underlying surface
-
各向同性:认为微表面并不存在一定的方向性或方向性很弱,微表面的发现分布均匀
-
各向同性:微表面有一定的方向性
-
-
Anisotropic BRDF
旋转反射的方位角(azimuthal angle),如果观测到的BRDF不变,那么说明是各向同性;如果观察到的BRDF发生变化,那么说明是各向异性(BRDF与绝对方位角有关)
Properties of BRDFs
-
Non-negativit
-
Linearity
-
Reciprocity principle
-
Energy conservation
-
Isotropic vs. anisotropic
-
If isotropic,,四维降三维
-
Then, from reciprocity,
由可逆性得,相对方位角不需要考虑正负,方便BRDF的测量和储存
-
Measuring BRDF
data:image/s3,"s3://crabby-images/389ef/389efdc1f71cd8044e54e3b68c6caceb9f3dd9da" alt="image-20221106152910444"
data:image/s3,"s3://crabby-images/2c7a9/2c7a9b7174a9c914c4bc95087bc3f5cddda69de5" alt="image-20221106153300191"
data:image/s3,"s3://crabby-images/6a634/6a634d4902628949ed510c189061cc640ec388d7" alt="image-20221106153317427"
data:image/s3,"s3://crabby-images/6d45a/6d45a6381add09e2547c100472af0a33830b4863" alt="image-20221106153334125"
data:image/s3,"s3://crabby-images/b9f42/b9f4209c21a4fe8a99e33fd43aa88ebf36caab14" alt="image-20221106153343318"
Advanced Light Transport
Unbiased light transport methods
Biased vs. Unbiased Monte Carlo Estimators
-
无偏蒙特卡罗积分不会产生任何逻辑错误
不管用多少采样点,无偏估计的期望值往往是真实值,这样的方法叫做无偏方法
-
有偏:其他情况
特例:期望值在无限多的采样点的情况下收敛于某个值,这样的情况叫做consistent
-
渲染中的biased和consistent的理解
- Biased == blurry
- Consistent == not blurry with infinite samples
Bidirectional Path Tracing(BDPT)
生成从摄像机和光源出发的子路径,再把两个子路径的端点连接起来的方法
data:image/s3,"s3://crabby-images/2c945/2c9450525793690c51c7b8ba4373b8564e455c60" alt="image-20221106162543339"
-
适用于光线传播在光源处比较复杂的情况
-
但是实现起来会很难,并且很慢
如图,因为Path Tracing从摄像机出发时的第一次bounce是diffuse,导致不好控制它能够打到之后能量集中的地方去,所以效果不好。而Bidirectional Path Tracing可以直接连接光源出发的和摄像机出发的第一次bounce
Metropolis Light Transport(MLT)
-
A Markov Chain Carlo (MCMC) application
MCMC可以生成以任意函数的形状为PDF的样本,Monte Carlo Estimator中当你采样的PDF和被积函数形状一致时(和),得到的variance最小。Markov Chain能够让任何未知的函数生成一系列分布与被积函数形状一致的样本。
-
Very good at locally exploring difficult light paths
-
Key idea :
-
Locally pertub an existing path to get a new path
-
-
特别适合做复杂的光线传播
-
只需要找到一条“种子”路径
-
caustics:specular-diffuse-specular
-
-
难以在理论上分析最终的收敛速度(难以估计sample数量和variance的关系)
Biased light transport methods
Photon Mapping
-
Very Good at hanging Specular—Diffuse—Specular(SDS) path and generating caustics
-
A two-stage method
-
Stage 1 — photon tracing
光子从光源出发,该反射就反射该折射就折射,直到光子遇到一个diffuse材质的物体,光子就停在那里
Stage 2 — photon collection
从视角出发,发射子路径,该反射就反射该折射就折射,直到路径打到diffuse材质的物体上
-
-
Calculation — local density estimation
- areas with more photons should be brighter
- 对于每一个shading point,寻找它周围最近的N的光子,划分这几个光子占据着色点周围的面积,用光子数量除以面积获得光子密度
-
为什么光子映射phonto mapping是有偏的
- Local Density esitimation
- 当有足够多的光子时,
- 所以光子映射biased但是consistent
Vertex Connection and Merging(VCM)
- 结合BDPT和Photon Mapping
data:image/s3,"s3://crabby-images/f0274/f0274b775ad44eb2b7ca0bb535136a7107fc7dd9" alt="image-20221107142834200"
Instant Radiosity(IR)
-
也叫many-light approaches
-
核心思想:把被照亮的表面看作是新的光源
data:image/s3,"s3://crabby-images/fafe2/fafe2e10e3cc4b731c65c13fe1554414e7ec50d6" alt="image-20221107143300208"
Advanced Appearance Modeling
Non-surface models
Participating Media
Participating Media: 参与介质
- 光线在参与介质中会发生①被吸收②被散射
data:image/s3,"s3://crabby-images/8e384/8e3848c2981d714587e61747ae32826cf68b8dc4" alt="image-20221107143940544"
-
使用Phase Function相位函数来描述光在参与介质中任意位置的散射角度的分布情况
Hair/Fur Fiber (BCSDF)
Human Hair
data:image/s3,"s3://crabby-images/bbfe9/bbfe900bea36ef46bcd67a4b35febcc11939e859" alt="image-20221107145029236"
-
Kajiya–Kay Model
只考虑反射和漫反射
data:image/s3,"s3://crabby-images/26f45/26f4527ba83b956286e6ea7990308c4e5ae6a004" alt="image-20221107145235799"
-
Marschner Model
光线打到圆柱后
有一部分被直接反射——R
有一部分会穿透后再穿透——TT
有一部分进头发里,在内部反射后再发生第二次穿透——TRT
Fur Appearance
data:image/s3,"s3://crabby-images/6a069/6a06950356a6d5fc3a82a1e6dd7c13ba66e24f53" alt="image-20221107150025638"
动物毛发不能通过人头发的方式进行计算:动物毛发内的髓质比头发的大得多,之前的玻璃柱的模型没有考虑髓质的存在
data:image/s3,"s3://crabby-images/2eee2/2eee2e615e60620a3811c0ed0b392d0e15ab140e" alt="image-20221107150215739"
data:image/s3,"s3://crabby-images/83f83/83f83dae7a9c34a97a1f6b67701efdc2abb24a5b" alt="image-20221107150322703"
-
Double Cylinder Model——模拟出髓质
一共五个分量
Granular material
颗粒材质
data:image/s3,"s3://crabby-images/cdd2c/cdd2cb44780303bd84948e6d7c70c9bdf7284645" alt="image-20221107150951579"
data:image/s3,"s3://crabby-images/68ee8/68ee83733d2e050ec920b0f3a85e69db6eb8dfc4" alt="image-20221107151053220"
Surface models
Translucent Materials(BSSRDF)
Translucent Materials不是实际的半透明,Semitransparent Materials才是半透明
Translucent Material说明的是光线可以从某一个地方进入物体表面,再从另一个地方出物体表面,并非光线传入一个表面并不被吸收,光线可以被导到其它地方去
-
Jade
-
Jellyfish
-
Subsurface Scattering次表面散射
-
Scattering Functions
-
BSSRDF:对BRDF概念的延申
-
Dipole Approximation
当光源照向一个点后,将BSSRDF近似为物体表面内外两个光源共同照亮这一部分的着色点
-
BSSRDF的效果:
-
Cloth
Rendering as Surface
通过给定的编织模式,计算整体的表现,通过BRDF进行计算
data:image/s3,"s3://crabby-images/a7aaf/a7aafeed4a82fe558c8b2aacf60902d635780c31" alt="image-20221107153602413"
不便于处理anisotropic
data:image/s3,"s3://crabby-images/dc375/dc3755276a42595077cde1d745a80bac8ab4292a" alt="image-20221107153703945"
Rendering as Participating Media
不再把布料当作平面渲染,而是当作体积渲染,可以得到更好的效果,但是渲染的计算量就会大得多
data:image/s3,"s3://crabby-images/7d0fd/7d0fdaa346c7122a8ed463bb8536ab1ae7efbac6" alt="image-20221107153323711"
Rendering as Actual Fibers
精确渲染每一根纤维
data:image/s3,"s3://crabby-images/37834/37834381f3ec7e2c169dc3a85557865a4be0dffa" alt="image-20221107153420900"
Detailed materials(non-statistical BRDF)
Microfacet BRDF
data:image/s3,"s3://crabby-images/70408/70408b54e0251e58a2555b355ce10eba519ed2b3" alt="image-20221107154915065"
Normal Distrubution Function(NDF)的不同——实际的NDF存在一些细节,如果能将这些细节考虑进去那么就能得到更好的细节
data:image/s3,"s3://crabby-images/682e9/682e9378da209342a5eae3fc68c7915db62707e0" alt="image-20221107155129655"
-
微表面在path tracing上会存在一些问题
- 容易发生path的miss
-
Solution:
考虑一个像素会覆盖很多的微表面,把一个微表面在一个像素对应范围内的法线分布算出来,替代原本光滑的分布并用在微表面模型里
不同大小的patch
不同的法线贴图
Wave Optics
唯一光源下的金属划痕
data:image/s3,"s3://crabby-images/3907c/3907c70bc71316dbb2a1761983fea4a2d875553c" alt="image-20221107160433755"
Detailed Material under Wave Optics
data:image/s3,"s3://crabby-images/1e443/1e443b73ec0642f2039a08f528dbd3ef4fb8c0e5" alt="image-20221107160359432"
Procedural appearance
-
Define details without textures
-
Compute a noise fuction on the fly
-
-
例如柏林噪波
Camera
Imaging = Synthesis + Capture
Inside a camera
-
Phinholes & Lenses For Image on Sensor
-
Shutter Exposes Sensor For Precise Duration
-
Sensor Accumulates Irradiance During Exposure
-
目前传感器只能记录Irradiance,所以需要有针孔或者透镜,来给定记录的方向
-
但是目前有人在研究可以记录radiance的传感器
-
Pinhole Image Formation
data:image/s3,"s3://crabby-images/b4635/b46352a2dac023b231552977a35ab0985fc348b1" alt="image-20221107162907241"
注:针孔相机拍不出深度(景深),任何地方都是锐利的,拍不到虚化的存在
光线追踪利用的是针孔相机的模型,也得不出景深效果
Field of View(FOV)
Effect of Focal Lengh on FOV
data:image/s3,"s3://crabby-images/49f3f/49f3f174d98330cc84ab8c2dbebbaa866a7bd41a" alt="image-20221107163405995"
Effect of Sensor Size of FOV
data:image/s3,"s3://crabby-images/84e6d/84e6db1f77bbe1feb02672dd30635cb3cef94138" alt="image-20221107163839867"
Exposure
H = T x E
-
Exposure = time x irradiance
-
Exposure time (T)
Controlled by shutter
-
Irradiance (E)
Power of light falling on a unit area of sensor
Controlled by lens aperture(光圈) and focal lengh
Exposure Controls in Photography
-
Aperture size
Change the f-stop(描述光圈大小的量) by opening / closing the aperture
-
Shutter speed
Change the duration the sensor pixels integrate light
-
ISO gain(感光度)
Change the amplification (analog and/or digital) between sensor values and digital values
data:image/s3,"s3://crabby-images/42c7e/42c7edad4bbf21751a60a19a041168fb23f6516f" alt="image-20221109090334524"
ISO(Gain)
能够提高曝光度,但是同时会放大噪声
data:image/s3,"s3://crabby-images/865e0/865e034b18bb2658fabe4179d047d421370e73b3" alt="image-20221109090736294"
F-Number(F-Stop) : Exposure Levels
Written as FN or F/N, N is the f-number
F-Number defined as the focal lengh divided by the diameter of te aperture
可以认为
Physical Shutter (1/25 Sec Exposure)
data:image/s3,"s3://crabby-images/4d814/4d814b70b93036e6e5b625992d2c403e8e014360" alt="image-20221109091445225"
-
Side Effect of Shutter Speed
-
Motion blur : Handshake, subject movement
-
Boubling shutter times doubles motion blur
-
Rolling shutter : different parts of photo taken at different times
-
High-Speed Photoraphy
-
Long-Exposure Photography(延时摄影)
-
Thin Lens Approximation
The Thin Lens Equation
data:image/s3,"s3://crabby-images/d27ec/d27ec91234beb87c65b527db0730ff8d28d5717f" alt="image-20221109092822163"
Defocus Blur
-
Computing Circle of Confusion(CoC) Size
一个点的成像反映到sensor上成了一个圈(近视眼)
-
Circle of Confution取决于光圈的大小
Size of CoC is Inversely Proportional to F-Stop
Ray Tracing Ideal Thin Lenses
原本的Ray Tracing是小孔呈现,但是也可以模拟Lens
data:image/s3,"s3://crabby-images/5d08f/5d08fab2fdc91d49af0fc7887e8975fa2f22f328" alt="image-20221109103931127"
Ray Tracing for Defocus Blur (Thin Lens)
Set up:
data:image/s3,"s3://crabby-images/6f561/6f561ef66af4327e23480125f82345b32b2be409" alt="image-20221109104027409"
- Choose sensor size, lens focal lengh, and aperture size
- Choose depth of subject of interest (物距)
- Calculate corresponding depth of sensor from thin lens equation
Rendering:
data:image/s3,"s3://crabby-images/55dc7/55dc76b568900663b1fe1962d0dd09ced38f4f32" alt="image-20221109104335328"
- For each pixel on the sensor
- Sample random points on lens plane
- You know the ray pssing through the lens will hit (using the thin lens formula, because is in focus, consider virtual ray (——center of the l))
- Estimate radiance on ray
Depth of Field
data:image/s3,"s3://crabby-images/934b8/934b898bba41cbc2442fdb9e761246197758987d" alt="image-20221109105618952"
data:image/s3,"s3://crabby-images/c6fa3/c6fa3bdfa7f4081f18923c37571b99717cbd12ac" alt="image-20221109105802916"
Light Field/Lumigraph
The Plenopic Function
全光函数:Parameterize everything that he can see
data:image/s3,"s3://crabby-images/b4a86/b4a86f90cb2dd84a6578cbd71467c8b8e6bc6980" alt="image-20221109112145575"
is intensity of light
- Seen from a single view point
- At a single time
- Average over the wavelenghs(color) of the visible spectrum
(can also do , but spherical coordinate are nicer)*
Grayscale snapshot
data:image/s3,"s3://crabby-images/de452/de4529546bf02fed67e94093c8146eaae0690e1e" alt="image-20221109112304734"
Color snapshot
data:image/s3,"s3://crabby-images/c7742/c7742933fec6069ba16314fe6a4094914f6a0935" alt="image-20221109112648966"
A movie
data:image/s3,"s3://crabby-images/e9b2f/e9b2ff58359f9ad18e37cd30aa2959594b9bb4bf" alt="image-20221109125813979"
Holographic movie
data:image/s3,"s3://crabby-images/4004c/4004cfc8d09ab77d7c80cc3721a19d48fb70cdf4" alt="image-20221109125910489"
The Plenoptic Function
data:image/s3,"s3://crabby-images/5d9c1/5d9c11bfd9f68147e25fd604e241e675cc3c17d8" alt="image-20221109130500712"
Ray
定义光线:
-
第一类:三维的位置+二维的方向来定义光线
-
第二类:二维的位置+二维的方向来定义光线
Light Field
data:image/s3,"s3://crabby-images/fe853/fe853f5fe6bf246c272059ffd39f92e0092c3c83" alt="image-20221109132140298"
The surface of a cube holds all the radiance information dut to enclosed object
Light Field:函数记录了物体表面不同位置往各个方向的发光情况,光场即为任何一个位置向任何一个方向的发光强度,光场只是全光函数的一部分,只是位置和方向
2D position:只有s和t轴,位置只是在一个面上进行查询,所以是二维的位置
光场的含义:从任意一个位置看向物体,都能查询到各个点的光照信息
data:image/s3,"s3://crabby-images/7e2a0/7e2a08f17b039284382ecc66ce96ac788371f1fd" alt="image-20221109133315295"
记录光场:不需要知道光场内部有什么,只需要查询到储存在表面的任何位置任意方向的光照信息即可
data:image/s3,"s3://crabby-images/24746/247466d8b7af053a1370b48c95215d36e7e24c14" alt="image-20221109133607603"
光场的参数化
-
1个位置+1个方向进行参数化
-
两个平行的平面,各自取点进行参数化
-
Lumigraph
data:image/s3,"s3://crabby-images/4a141/4a141a36feb47abf103ce2b19591a7c2f4a7d90e" alt="image-20221109134832974"
把一个像素分开并在像素前加一个lens,将来自各个方向的光分到不同的位置,即用一个像素储存了不同方向的irradiance
data:image/s3,"s3://crabby-images/4dcfd/4dcfdc35c3ea950801eff0e88f7b89feb80ebb75" alt="image-20221109135310056"
Light Field Camera
原理:微透镜(Microlens),把一个像素替换成一个透镜,使来自不同方向的光通过微透镜分开,分别记录到不同的位置
优势:可以后期动态聚焦——先拍照,再聚焦
Understanding
原本像素储存的irradiance被沿着多个方向拆开了(pixelblock of pixels)
data:image/s3,"s3://crabby-images/e0983/e098374ddba88fc0caa7e17f913fbeab2dd69976" alt="image-20221109140335954"
data:image/s3,"s3://crabby-images/36497/36497c5605146616abe8b972f26b3eb5b1e95d50" alt="image-20221109141528173"
data:image/s3,"s3://crabby-images/c406a/c406a1dd794392d89fb869bf48c8ffa65a2d30ab" alt="image-20221109142122808"
Color
Physical Basis of Color
The Visible Spectrum of Light
Electromagnetic radiance
-
Oscillations of different frequencies (wavelenghs)
Spectrual Power Distribution (SPD)
Salient property in measuring light
即光线不同的波长对应的强度
data:image/s3,"s3://crabby-images/7cd53/7cd53266f926e2373eee350a6d236998ac2f31a6" alt="image-20221109145531636"
SPD of light sources
data:image/s3,"s3://crabby-images/687d8/687d86a5108e385c2f92b5d7533dbe0ebeeb54c7" alt="image-20221109145636052"
Linearity of SPD:线性关系,可加性
data:image/s3,"s3://crabby-images/9cf0c/9cf0c16ec85a18ea682bb57c4f131c90e2545356" alt="image-20221109145703756"
Biological Basis of Color
Anatomy of the Human Eye
data:image/s3,"s3://crabby-images/cf1e4/cf1e4c8628f5083873f65f7bcdf09d6d4d9bb5c1" alt="image-20221109150128747"
Retinal Photoreceptor Cells:Rods and Cones
data:image/s3,"s3://crabby-images/d689a/d689a4c0ac9ee6571c9c257abaae55623e593483" alt="image-20221109150522267"
-
Rod cells:很多,但是只能感知光的强度,得到灰度图
-
Cone cells:相对较少,能感知光的颜色,又分为三类
- 锥形细胞分类及响应曲线图:
-
锥形细胞在不同人身上分布的差异很大
Tristimulus Theory of Color
Spectral Response of Human Cone Cells
感知:光线波长SPD和感知细胞响应曲线相乘的积分,得到的SML才是感知到的颜色,而不是光的SPD
data:image/s3,"s3://crabby-images/c9361/c93617f18155b961a7865eadc8d5aa3e83d2b754" alt="image-20221109150955582"
The Human Visual System
data:image/s3,"s3://crabby-images/7ea26/7ea26223638cf202cdbf046c52ddaa5c499211a9" alt="image-20221109151240772"
Metamerism
同色异谱现象:不同的SPD但是看到同样的颜色的现象
data:image/s3,"s3://crabby-images/dd345/dd3453e946564fc02bf420eff253518dae9bf623" alt="image-20221109151537946"
Color matching
data:image/s3,"s3://crabby-images/a5238/a52386d98c7a10fd8b2d701bdd697714530ca7fa" alt="image-20221109151629313"
Color Reproduction/Matching
Additive Color
data:image/s3,"s3://crabby-images/cd8d6/cd8d6751fbef0929893fdc59dc6378b3217ddd62" alt="image-20221109151755784"
Color Reproduction with Matching Functions
s——SPD
data:image/s3,"s3://crabby-images/3811a/3811aab4eb09c5905a205e2713a9cb26aeb9d17d" alt="image-20221109152345475"
Color Spaces
Standard Color Spaces
data:image/s3,"s3://crabby-images/3f228/3f2281ac4158c8053fdaba32d15f767b39370dc0" alt="image-20221109152657664"
A Universal Color Space: CIE XYZ
另一套匹配系统:一套人造的颜色匹配系统,初值不是存在的颜色
data:image/s3,"s3://crabby-images/6ddf4/6ddf44159a421bc4f10d39f7c5628943b12719ac" alt="image-20221109152920001"
Separating Luminance,Chromaticity
让XYZ系统能表示的颜色显示出来
对大写的XYZ做一个可视化:将XYZ进行归一化(此处的归一和向量不同,此处只是指x+y+z=1),固定了Y,可视化x,y(因为Y只是强度)
data:image/s3,"s3://crabby-images/68450/684501d5cff56f01c97a0d0009b9fdd1c6102a74" alt="image-20221109153909093"
CIE Chromaticity Diagram
data:image/s3,"s3://crabby-images/d7995/d799572195da60fab772c0abe5e48aad4cf9ff5c" alt="image-20221109154012297"
Gamut
不同的颜色空间Gamut色域是不同的
data:image/s3,"s3://crabby-images/9e8eb/9e8eb23da8881b01946566d907b2084393d36885" alt="image-20221109154421884"
HSV Color Space
Hue—Saturation—Value
data:image/s3,"s3://crabby-images/687c3/687c3ae4f515f704c2cef79e4484bf51afbe1409" alt="image-20221109154748402"
CIELAB Space(AKA L*a*b*)
data:image/s3,"s3://crabby-images/3d01c/3d01c22355f9831a710235c4b5fcc0722b00e4df" alt="image-20221109154924702"
Opponent Color Theory
data:image/s3,"s3://crabby-images/d6a63/d6a63906ed0f29d9350ade6f68a6a9c3f752d13b" alt="image-20221109155127206"
data:image/s3,"s3://crabby-images/4fadf/4fadf0ba8c563c5407c6b69acec4f87d50d26059" alt="image-20221109155137787"
CMYK: A Subtractive Color Space
data:image/s3,"s3://crabby-images/fd9ef/fd9ef856d60d53c63b520d492f785a61431e9898" alt="image-20221109155913938"
Animation Intro
Keyframe Animation
Keyframe
data:image/s3,"s3://crabby-images/1fcb6/1fcb68239d0fb8b5ffed34d181893bb55a84db01" alt="image-20221110083228747"
- Lead animator creates keyframes
- Assistant (person or computer) creates in-between frames (“tweening”)
Keyframe Interpolation
data:image/s3,"s3://crabby-images/46411/464119b3d42e031de874079aef4fa719b003625f" alt="image-20221110083455365"
data:image/s3,"s3://crabby-images/ccaec/ccaec38607c3a35f927f76a0d92d590038b6fdc8" alt="image-20221110083543341"
Physical Simulation
- Newton’s Law
-
Generate motion of objects using numerical simulation
-
Example
- Cloth Simulation
- Fluids
- 模拟流体如何运动
- 模拟位置、形状后去渲染,得出模样
- Mass Spring Rope/Mesh(质点弹簧系统)
- Hair
Mass Spring System
A Simple Spring
—— 一系列相互连接的质点和弹簧
Idealized spring
Zero length spring
-
Hooke‘s Law
Problem: this spring wants to have zero length
Non-Zero Length Spring
Spring with non-zero rest length
Problem: oscillates forever
Dot Notation for Derivatives
data:image/s3,"s3://crabby-images/06976/069761baf3fd32311ecaf3755380f3a6a5087ca2" alt="image-20221110085300203"
Internal Damping Force(Energy Loss)
data:image/s3,"s3://crabby-images/dbcfa/dbcfa58fbd0232f958db00dca975a75b9e728335" alt="image-20221110090041930"
-
is a damping coefficient
-
Viscous drag only on change in spring length
Structures from Springs
-
Behavior is determined by structure linkages
- This Structure will not resist shearing
- This structure will not resist out-of-plane bending (该形状可以折成一个平面并且没有反抗弯曲的力)
- This structure will resist shearing. Less directional bias.
- This structure will resist out-of-plane bending. Red spring should be much weaker(蓝色线力更强,红色只是用来抵抗弯曲)
Aside: FEM
Finite Element Method(FEM) Instead of Springs
有限元方法,适用于力的扩散与传导
Particle Systems
Particle system
-
Model dynamical systems as collection of large numbers of particles
-
Each particle’s motion is defined by a set of physical (or non-physical) forces (e.g. 粒子之间的碰撞、引力,粒子受到的重力)
-
Popular technique in graphics and games
- Easy to understand , implement
- Scalable: fewer particles for speed, more higher complexity
-
Challenges
- May need many particles (e.g. fluid)
- May need acceleration structure (e.g. to find nearest particles for interactions)
Particle System Animations
For each frame in animation
- [If needed] Create new particles
- Calculate forces on each particle
- Update each particle’s position and velocity
- [If needed] Remove dead particles
- Render particles
Particles System Forces
-
Attraction and repulsion forces
- Gravity, electromagnetism, …
- Springs, propulsion, …
-
Damping forces
- Friction, air drag, viscosity, …
-
Collisions
- Walls, containers, fixed objects, …
- Dynamic objects, character body parts, …
-
Gravitational Attraction
-
Newton’s universal law of gravitation
- Gravitational pull between particles
- Gravitational pull between particles
-
-
Examples
-
Galaxy Simulation
-
Particle-Based Fluids
-
Simulated Flocking as an ODE
data:image/s3,"s3://crabby-images/ce371/ce371be278543e014b50a2cd590d2c44ce42eae8" alt="image-20221110094637224"
data:image/s3,"s3://crabby-images/dda18/dda18f13e4128a780f1b19b228e2980d0f057fe1" alt="image-20221110094716284"
考虑个体与群体之间的联系
Forward Kinematics
Forward Kinematics
data:image/s3,"s3://crabby-images/1bacf/1bacf007b3d058a83c1ec6514522e79cbdd19e85" alt="image-20221110154614676"
Articulated skeleton
- Topology (what’s connected to what)
- Geometric relations from joints
- Tree structure (in absence of loops)
Joint types
-
Pin (1D rotation)
-
Ball (2D rotation)
-
Prismatic joint (translation)
data:image/s3,"s3://crabby-images/7a0e4/7a0e4e2c8e66d90b42f6041db12733fa8f2d3928" alt="image-20221110154641331"
Kinematics Pros and Cons
Strenghs
- Direct control is convenient
- Implementation is straightforward
Weakness
- Animation may be inconsistent with physics
- Time consuming for artists
Inverse Kinematics
Animator provides position of end-effector, and computer must determine joint angles that satisfy constrains
data:image/s3,"s3://crabby-images/a9080/a9080cfd3e3bcb468ae6d2bbf584873577da7e0a" alt="image-20221110221119909"
Problems(Hard):
-
Multiple solutions in configuration space
-
Solutions may not always exist
Numerical solution to general N-link IK problem
- Choose an initial configuration
- Define an error metric
- Compute gradient of error as function of configuration
- Apply gradient descent
Rigging
Rigging is a set of higher level controls on a character that allow more rapid & intuitive modification of pose, deformations, expression, etc.
Important
- Like strings on a puppet
- Captures all meaningful character changes
- Varies from character to character
Expensive to create
- Manual effort
- Requires both artistic and technical training
Blend Shapes
Instead of skeleton, interpolate directly between surfaces
Simplest scheme: take linear combination of vertex positions
Spline used to control choice of weight over time
(控制点和控制点之间做插值,blend控制点及控制点周围能够影响的区域)
Motion Capture
Data-driven approach to creating animation sequences
- Record real-world performance
- Extract pose as a function of time from the data collected
Pros and Cons
- Strenghs
- Can acpture arge amounts of real data quickly
- Realism can be high
- Weaknesses
- Complex and costly set-ups
- Captured animation may not meet artistic needs, requiring alterations
The Production Pipeline
data:image/s3,"s3://crabby-images/9e4c8/9e4c827d39454b46af32944454a56289bd2aa82d" alt="image-20221110225001723"
Animation Simulation
Single Particle Simulation
First: study motion of a single particle
Later: generalize to a multitude of particles
Velocity Field
To start, assume motion of particle determined by a velocity vector field that is a function of position and time:
data:image/s3,"s3://crabby-images/ba47c/ba47c44412c866be575cdd5e480e943f13c0efa0" alt="image-20221111104313402"
Ordinary Differential Equation(ODE)
Computing position of particle over time requires solving a first-order ordinary differential equation:
- “first-order”: the first derivative being taken
- “Ordinary”: no partial derivative (i.e. x is just a function of t)
data:image/s3,"s3://crabby-images/27eb2/27eb2e6dab402208d4a66f7225edbdc745226843" alt="image-20221111110640553"
Euler’s Method
-
Simple iterative method
-
Euler’s Method - Errors
With numerical integration, errors accumulate
增大time step可以减小误差
time step affect the accuracy
-
Instability of Euler Method
不稳定,例如要沿着下面的圆形移动,但不管time step有多小,往下进行会越来越脱离想要的结果
Errors and Instability
Solving by numerical integration with finite differences leads to two problems:
-
Errors
-
Errors at each time step accumulate
Accuracy decreases as simulation proceeds
-
Accuracy may not be critical in graphics applications
-
-
Instability
- Errors can compound, causing the simulation to diverge even when the underlying system does not
- Lack ok stability is a fundamental problem in simulation, and cannot be ignored
Combating Instability
How to determine/quantize “stability”?
-
Local truncation error(every step) / total accumulated error(overall)
-
这些数字没有意义,研究的是他们的导数
-
Implicit Euler has order 1, which means that
-
Local truncation error:
-
Global truncation error:
(h is the step, i.e. )
-
-
Understanding of
If we halve h, we can expect the error to halve as well
Midpoint Method/Modified Euler
- Average velocities at start and endpoint
data:image/s3,"s3://crabby-images/17257/17257fed9f39e280a1b39cd73b35368e367825fa" alt="image-20221111131159438"
理想运动路径是中间的曲线,实际路径是下面的直线
实际上是用了两次Euler方法,先用出发点的速度场来算出中点b的速度,在以此速度回到起始点作为真正的速度
-
Better results: 算出的局部的二次模型,优于原本的一次模型
Adaptive Step Size
试着把分成两个部分,如果两个结果相差很远,就减小step size并再次进行判断
得到右下的图,在不同的位置会有不同的
data:image/s3,"s3://crabby-images/67345/6734598aa985e072976513c6ac0e62233a235f22" alt="image-20221111132259048"
Implicit(Backward) Euler Method
-
Use derivatives in the future, for the current step
-
Solve nonlinear problem for and
-
Using root-finding algorithm
-
Offers much better stability
Rung-Kutta Families
A family of advanced methods for solving ODEs
- Especially good at dealing with non0linearity
- It’s order-four version is the most widely used
data:image/s3,"s3://crabby-images/417be/417be9bc8d093885611010a655de2051f531ccf2" alt="image-20221111192642402"
Position-Based/Verlet Integration
-
Idea:
- After modified Euler forward-step, constrain position of particles to prevent divergent, unstable behavior
- Use constrained positions to calculate velocity
- Both of these ideas will dissipate energy, stabilize
-
Pros and cons
- Fast and simple
- Not physically based, dissipates energy(error)
Rigid Body Simulation
物体内的所有点运动规律都一致
Simple case
- Similar to simulation a particle
- Just consider a bit more properties
data:image/s3,"s3://crabby-images/56db7/56db7c0787d16ada2e25791f524f73671f16d632" alt="image-20221111193458458"
Fluid Simulation
A Simple Position-Based Method
Key idea
- Assuming water is composed of small rigid-body spheres
- Assuming the water cannot be compressed(i.e. const density)
- So, as long as the density changes somewhere, it should be “corrected” via changing the position of particles
- You need to know the gradient of the density anywhere w.r.t. each particle’s position
- 任何一个位置上让原本不正确的密度恢复原本的密度,并且我知道如何调整各个小球的位置使得他的密度往我们所需的方向上去变化——Gradient Descent
data:image/s3,"s3://crabby-images/1e2d9/1e2d9c6ee353e4b26de5b3b80dd7f37a2f710cb6" alt="image-20221111194137333"
Eulerian vs. Lagrangian
Two different views to simulating large collections of matters
data:image/s3,"s3://crabby-images/4d075/4d0758db83d18281f1038065b8aa44d52554b4aa" alt="image-20221111195004578"
Material Point Method(MPM)
data:image/s3,"s3://crabby-images/3b5f8/3b5f85ebe25e39f54cc4aa4cafe06f3c753d3a85" alt="image-20221111195259997"
—Next—
- Games201 —— Advanced Physics Engines 2020: A Hands-on Tutorial
- Real-Time High Quality Rendering