转自:http://www.cgfancy.com/Article/1715.html
01.概述
    CGI技术是一门非常年轻而且发展迅速的科学。其它相关的还有许多技术也在很短的时间内迅速的壮大,用于模拟自然现象,但它们只限于解决某一方面的问题,对我们来说选择合适的技术来解决相应的问题比较困难。出于人们认识光与物质相互作用的方式,一些主要的技术脱颖而出,这其中最常用的是工作于物体表面的技术,另外就是CGI技术的到来。它的原理是向场景里发射光线来收集必要的信息,重建真实自然现象的一个关键问题是需要大量的信息。假设在我们所处的环境里,包括看不见的地方,有大量带有能量的光线穿过,它们在场景中哪怕是最狭小的地方以某种方式相互作用,这些光线的能量以不连续的形式存在(爱因斯坦光子说)。物体表面的原子会吸收光子使自已的能级升高,受到激发的不稳定原子会自发的地回到最低能级,并将减少的那部分能量以光子的形式释放出来,这些光子根据发射它原子的种类有特定的波长。打个比方吧,太阳光包含很多不同波长的电磁波,但这里面只有一小部分能被我们的眼睛所识别。人造光源一般都有特定的颜色,因为它们含有各自特定的元素。一个典型的钨极光源发出的光有一定的频率范围,这就是我们看到的橙色。同样,氖光源发出的光是绿色。
    自然界的这种吸收和发出光能的现象无时无刻不在我们的身边出现。我们的眼睛扮演着摄像机的角色,收集和识别从四面八方射过来的光线的波长(颜色)和光子数量(强度)。我们看到的图像正是在空间的某一点处众多光线的静止状态。前面的内容仅仅从物理学的角度粗略的介绍了一下,但这样就足够了,我们没有必要考虑更深一层的物理知识。这些内容足已解释我们看到的真实世界,今后的学习制作过程也足够用了。

02.用CGI技术重现生活中的例子
    前面说过每个原子都会吸收和发射光线,物体的颜色决定于反射光线的波长和物质原子的种类。入射光线反射后向四面八方散射,但要根据入射光线方向反射(否则反射也不会进行),也许多物体不会直接在表面反射光线,像气体。光线会在大多数物质里传播,并被物质内部的原子吸收和反射掉。像下图中的蜡球,这种蜡物质吸收除了绿色和黄色之外的所有波长的光线(至少除黄绿色外的绝大多数光线),然后像大多数物体一样作为绿光的发射物体(除了黑洞之外)。你们可以看到当蜡球靠近光源后它显现出黄绿色。

 


 


    你们当中很多人可能都知道,在过去的几年中出现的很多光线跟踪渲染器都能模拟在“电脑产生的表面内部散射光线”,也叫做SSS(Sub Surface scattering)。很多渲染器都使用相似的原理,像GI中的采样方式,在某一点发射多条光线到场景中,这些光线经反射后携带了物体表面的颜色信息,以此来确采样点的颜色,典型的例子-Monte Carlo。不同的渲染器在保证图像质量不变的前提下有不同的缩短渲染时间的方式,因为有大量的光线信息需要收集。这之中有简单的采样点插值算法过滤器;也有智能化的能识别物体边缘尖锐部分的高级插值算法过滤器,它能在需要的地方放置合适的采样点;还有适用于动画的采样引擎。听起来这些算法都很高深,其实我们只要知道我们的工作是要找到合适的方法对付巨长的渲染时间就行了。我在95到96年第一次接触3D软件的时候试着用一个光源照亮一个镜面属性的球体,但失败了。当我用手电照射整个卧室的时候,卧室会有一点亮光,但在3D中除了聚光灯的圆锥范围内其它的地方一片黑暗。我想,为什么会这样呢?后来我知道了,因为所有的物体都是反光体,我们平时看到光大多数光线都是反射光线。
    朋友们你们是否知道,Blinn和Phong这些表面Saders是怎样工作的吗?固有色,高光到底是什么呢?在很长的一段时间里,我只知道怎样使用它们,怎样用它们达到预期的效果,但我从不知道它们真正代表着什么。

 


    上面提到过,所有的物体都会吸收和发出光线。一个全反射材质,也就是反射全部光线的材质,像表面镀了金属的玻璃,它表面的每一个点都包含了环境的信息。当光线在物体表面反射后一部分光线被吸收,反射光线变弱且被“染色”。因此过渡色就是物体表面除吸收的那一部分的带有表面颜色的反射光线。在现实中绝大多数表面都会有一定程度的粗糙度,我不是说肉眼可以看到的凹凸不平,而是微观上的表面粗糙。不同的Saders能够快速有效地模拟表面的粗糙方式。高光就是反射最多,光线聚集最强烈的那一部分表面产生的。地过渡色区域也会有小面积的高光,但随着表面和光源的距离拉大高光也渐渐地变的不明显了。这样的高光在现实世界并不存在,这是因为现实世界不存在3D软件中的理想光源(点光源和面光源)。现实世界中的光源总会有一定的形状,这样高光区会表现有一定的细节而且可以看到光源的形态。参考下图中的皮革,射到高光区的光线来自窗外的阳光,可以看到真实表面的细节是很复杂的。可以说高光区只是过渡色区域中反射较强的表面。像这样的反光表面只用一个简单的Sader是不可能实现的,我们必需用真正的光源来模拟窗外的光线。或许还要用反射模糊来模拟过渡色区域的光线散射,用一点过滤色模拟表面吸收不同的光线产生的颜色。这可能就是这几年来HDRI如此流行的缘故吧。HDRI不仅可以产生高质量的间接照明,还可以用渲染出真实的反射和高光区的精彩细节。

 


 


    这是一幅勺子的照片,主光来自上方。勺子的中心有非常强烈的高光,有趣的是周围还有一圈圈的刮痕。每一圈刮痕可以看成在它边缘处反光的圆柱形凸痕。光线在它们之间反射,这样反射光线在某个方向上散射开来,也就是CGI里所谓反射的各向异性。
在这张图片中我们看到主光在高光区的中心形成一个十字。像打磨过的金属和毛发这类物质常发生这种现象,而且针对这种高光已经有不同的Shaders算法了。我要指出的是这些算法都必需能快速的产生各向异性的高光。如果想渲染出正确的高光就必需用真实的物体,或者至少用凹凸贴图模拟刮痕(这个Shaders用在CGI毛发上一点意义都没有,因为这种现象是由许多许多细小的圆柱体产生的)。我只发现在使用不透明贴图的时候这种Shaders才管用。

 


    光线还可以表现出另一种特性。当光线与表面的夹角很小的时候光线趋向于在表面反射,但当光线跟表面接近垂直时趋向于穿透表面介质。这也是一种很重要的特性,叫做Fresnel(菲涅耳效应)光学纤维这种物质常发生这种现象。许多渲染器都支持这个特效。下面的图我们能很清楚地看到这个效应,在角度很小的情下况液晶屏反射很强烈,但垂直看时大多光线都穿过了塑料壳而被黑色的LCD吸收了。几乎所有的材质都或多或少的表现出这种特性,特别是透明物体(几乎所有的物体都是“透明”的,只不过这取决于物体原子吸收光线的多少罢了)。

 


 


    好,我想到现在为止我已向你们介绍了光线的反射原理。我希望你们能在这里学到一些有用的东西。下面的是一些焦散(Caustics)和散射(Dispersion)的图片。还有一张图片,上面是一个物体和阴影,我想告诉你们的是这个透明物体的阴影和我的手一样也是不透明的,这是初学者对透明物体使用光线跟踪阴影时常犯的一个毛病。
    如果你们有问题的话尽管问吧。请睁大眼睛随时留心你的身边,发觉周围不经意的小事,有时它也是美丽的。作为一个艺术家这样有助于提高你技术方面的理解。





01.反射的奥秘-第二部分
    在第二部分中Philipp Zaufel用通俗的语言描述了BRDF(双向反射分布函数)--一个CG中最常用的用来描述材质反射行为的数学模型。

02.总论
    BRDF-双向反射分布函数,是用来描述材质反射行为的函数,是一个数学模型。这篇小教程是为艺术工作者写的,而不程序员。有关BRDF的技术资料有很多,但我的目的是想让你们了解如何让它正确的工作,而不是大篇幅的罗列。BRDF在CG中无处不在。当你使用Phong,Blinn或者其它Shader的时候你就在使用BRDF模型。要是你用光线跟踪制作反射,阴影或者产生GI效果的时候,你也在无形中使用着BRDF模型。
    一个BRDF模型描述了一种表面上入射和反射光线的关系。因此说简单点就是光线射到表面上,表面对光线产生作用。光线可以被反射(镜面的或漫射的),吸收,或两者都有。我们可以通过测量一种真实物体表面上的反射和入射光线来描述这种材质和它形成的BRDF,测量的结果可以用在CG程序中来产生有相同表面属性的材质。但大多数情况下会使用简化的,带可调节参数的模型来产生CG表面。这些反射模型可以是精确的,也可以是经验化的。这里我们关心的是精确的分析反射模型。因为它里面的参数或者说方程是基于真实世界的,并且为了能使材质叠加产生复杂的SHADERS,它们也使用在CGI中。像Robertson-Sandford和Beard-maxwell这些经验模型,它们用的是虚构的参数来构建简化的BRDF。下面我会提到一些高级的反射模型。像BTDF,BSDF,BDF和BSSDF,这是为了澄清一个事实:一个BRDF只是依据表面属性,入射光角度(同它的参数)和视角来描述光线的反射。
    BTDF-双向传输分布函数,描述了透明的表面属性,过程是通过矢量计算表面的两个方向(不是同一个计算过程)。BRDF和BTDF合起来就是BSDF,简称BDF--双向散射分布函数,描述表面上同一点处两个方向的半球的函数。这些就是高级(镜面)光线跟踪渲染的基础函数。BSSDF--双向表面散射反射分布函数,它的发明者就是发明光子贴图的那个人,Henrik Jensen。它描述了物体内部的光线散射。好莱坞,概论就这么多,下面我们一一介绍吧。

03.完美的漫射材质——Lambert
    这是个非常简单的模型,而且距今已有200年的历史了。在CG场景中它无处不在。这个模型描述了一个完美的漫射表面。入射光在表面上向四周等量的散开,如果从不同的角度观察表面的话会看到同样的颜色(各向同性)。唯一不同的是入射的角度。入射击角为90度时表面亮,反之则暗。这种模型在生活中是很常见的,但生活中这种的完美的漫射表面非常少,这就是CG表面看不去是电脑产生的表面的原因。就因为它的速度相当快,而且非常普及,因此它成为实时渲染表面SHADER中最常见常用的一个。
    Gourad Sading是实时渲染技术中的一员,因为它不是基于每像素计算的,而是基于顶点的计算方法,计算顶点色值后在各顶点间运用插值算法来形成多边形。(新一代的显卡都支持实时像素阴影渲染,并且这些成熟的模型都成为了今天的标准,但这不是今天我们讨论的话韪。)
    这个模型大多数情况下在物理上是正确的,这意味着一些重要的物理规则被保留了。其中有一个就是反射光线的能量总和一定小于入射光线的能量。另一条是对不同颜色的吸收原则,比如说过渡色为黑色的物体吸收掉所有的入射光线,并不产生反射(过渡色——一个Lambert模型引申出的重要参数)。

按此在新窗口浏览图片

04.Lambert的例子
    上图中的个球体都被赋予了Lambert材质。第1,2个是同一个球休的不同视角。图中红圈表示球上的同一个点。可以看到Lambert材质在不同的视角产生相同的颜色。第3,4个球体是同一个模型。它们反射的光线较前两个少,第三个是BRDF的典型模型——环境色(ambient)。它只是在整个图像中增加了另一种颜色来模拟环境的光照,但这种方法没什么大用,因为它只会让你的图像变的不真实。要模拟环境光的话试着多打几个灯或者干脆用GI。

按此在新窗口浏览图片



05.简易的镜面反射模型————Phong,Blinn-Phong.
    上面的图显示的是物理上真实的境面反射--高光。左边一个是Lambert,完美的漫射。红色的入射光线反射后被等量的向四周反射。第二个是完美的镜面反射,渲染器用这个原理来产生完美的镜面,像镜子等。第三个是反射模糊,反射光线由于表面的微小凹突在镜面反射的路线上产生了偏移。现在我们已经了解了许多描述表面上不同部分的模型,上面介绍的只是最简单的几个。还有一些描述不同类型镜面反射的模型(因为许多表面都有不规则的地方)。最简单的几个:
    1975年Phong Bui Tong发明的Phong模型,由于它的速度相当快,成为了CG表面镜面反射应用最多最广泛的模型。它不是物理上精确的模型,你可以设置高光的强度使发送的光线大于接收的光线,而这在现实中是不可能的。但因为CGI是一种艺术创作,那么这也是可行的。

    下图中最左侧的球体是Phong模型,这种模型的一大优点是你可以跟其它的模型混合使用来达到不同的效果。最常见的就是把phong跟Lambert混合产生第二个球体的效果。注意我用了相同的灯光照亮球体(位置,强度)。混合后的结果是高光变亮了。这样做的优点是你可以调整模型中的不同参数(颜色,高光强度....)来达到真实的效果。右面的两张图显示了Phong的高光在入射角上和视角上都是独立的。这个三维图中的白色线框代表了蓝色垂直入射光线在红色板处反射的反射光线的方向和强度大小。入射点周围的半球是完美的Lambert漫射,而由于Phong高光的存在在顶部有一小部分的突起。实质上Phong高光就是在入射光方向上产生了较强的反射,加上入射点周围的高光区,再加上Lambert的漫射区形成了整个球体。当光线从另一个角度入射时只是反射角度依据入射角=反射角定理变化。

按此在新窗口浏览图片



    Blinn-Phong模型,也叫Blinn,是Phong模型最常见的变化类型。做为CG领域的先驱,Blinn改进了Phong模型的一些高光上的问题。Blinn模型混合了Lambert的漫射部分和标准的高光,在速度上相当快,因此成为许多CG软件中的默认材质。此外它也集成在了大多数图形芯片中,用以产生实时快速的渲染。如下图:这两个球体使用相同的光照和相同的参数(Blinn和Phong高光的基本参数是相同的)。看上去上图中的Phong球和下图中的Blinn球没什么区别,除了Blinn球看上去更加柔和。但我们来看看不同角度下的反射值(图3,4),就能看到非常明显的区别。在入射角为90度的情况下反射就像是非常柔和的的Phong高光,但角度很小时高光的反射处明显被撕裂。这是因为这两个的BRDF模型的算法有微小的区别,但这有什么用呢?

按此在新窗口浏览图片



    下图说明了Phong和Blinn视觉上的不同。在入射角很小的情况下有个主要的区别。因此我为球体打了两个灯,一个从顶部,一个从底部,都与摄像机成90度角。第一个是Phong球,第二个是相同条件下的Blinn球。结果是由于球体上三角面的角度不同Phong的高光被扭曲了,但Blinn球保证了高光的完整性。好了,你可以根据你自己的需要选择Phong还是Blinn,我个人认为Phong高光更正确一些,但Blinn高光的可控性更好。因为它可预测,特别是在复杂的表面上,因此它被用做CG软件中最基本,也最快的BRDF模型。图中第3,4个球使用了光线跟踪的镜面反射,反射出了一个环境,同样是第一个用Phong,第二个用Blinn的BRDF模型。注意,许多渲染程序并不支持镜面反射渲染的BRDF模型,而是使用自己的聚焦算法。
    你们可以看到Phong上相同的扭曲效果和Blinn球上清晰柔和的反射(渲染条件完全相同,唯一不同的是不同的渲染结果)。

按此在新窗口浏览图片

06.背部反射:Minnaert,Hapkel/Lommel-Seelinger
    到此我们已经了解了最基本的均匀漫射和高光反射部分的反射模型,但是Phong和Blinn只适用于遵守入射角=反射角原理的镜面反射。现实中的表面都会有各种各样的缺陷,因此光线会以不同的方式散射----SSS特效或称背部散射。
    明显,背部散射就是表面在其背面反射光线。为达到这种效果出现了许多不同的模型,同时还与其它的模型混合来达到更加复杂的效果。最常见的一个是Minnaert模型。它使用与Lambert相同的算法,只是增加了一个使表面变暗的参数来降低正常反射方向上的亮度。下图中的第一个球就是Minnaert模型。它最初是用来描述月亮的BRDF的(基本Lambert反射加一点背部反射,世间少有)。Minnaert模型不允许有过大的背部散射值和边缘光照效果。但由于它是基于Lambert漫射的因此它的速度相当快。而Hapkel/Lommel-seelinger模型就有一点复杂了,但是你也可以改变背部和前部的散射量来产生更多的光线散射效果。这些模型很广泛的应用在表面上有微小毛发的材质和天鹅绒材质,这些材质会在其毛发的顶部产生边缘背部散射光线。第三个球体是Hapke/Lommel-Seelinger的一个变种,主要用来模拟带有绒毛的纤维。我在其背部打了一个蓝色的灯,以区别白色的过渡色。注意这些模型都加上了一些其它的参数,因为很少有渲染器能支持没有更改过的纯模型。

按此在新窗口浏览图片

07.基于Lambert三角面的高级粗糙表面:Torrance,Sparrow,Cook,Blinn,Oren-Nayar
    建立一个描述粗糙表面的数学模型的想法很早就有了。Torrance和Sparrow1967年设计出了一个以表面作为基准面的BRDF(早于Phong)。基面上分布有许多微小的三角面,用它们之间形成的角度来描述表面的粗糙程度。由于相邻三角面间形成的槽之间的角度正好相反,因此也叫它为V形槽。这个模型在物理上是正确的,因为它使用的是真实世界的参数来描述反射的分布,而且它具有波长独立性,意思就是说表面上的某一点因视角的不同而有不同的颜色。以后的几种模型都是基于这个基本模型而建立的。
    之后Cook和Torrance在1982年迈出了重要的一步(有时称为Cook-Torrance模型,有时也称为Blinn-Cook-Torrance模型,因为它也把Blinn模型考虑进去了)。它是一种由Blinn和Torrance-Sparrow混合而成的模型,也是物理上精确的并而渲染速度上有所改进,其中之一是集成了更多的三角面分布函数。Torrance-Sparrow,基于著名的高斯分布;内建基于Phong式分布的Cook-Torrance;Trowbridge-Reitz和Beckmann分布。不过这只是一小部分,重要的是集成了关于光线的计算信息,光线照射在三角面上,依据两个参数来反射。一个是著名的菲涅耳效应(简单的说就是反射量依据反射角和表面折射率--参见第一部分)。第二是基于自身的阴影投射和三角面遮罩的几何衰减因子,如下图。

按此在新窗口浏览图片

    Cook-Torrance这种常见模型主要是建立高光和模拟金属质感。有时也会混合Lambert的漫射部分,但由于它在物理上的正确性它不适用于艺术表现,而且它的速度也不是最快的一个。下图的第一个球体是Cook-Torrance高光,在表面粗糙度很小的情况下它跟Blinn高光的形态很相似。另一个常见的三角面模型是Oren-Nayar模型(实际上我们常用三角面模型是出于它的快速,而且它是Lambert漫射之外一个很好的选择)。它是Cook-Torrance模型的一个简易版,能建立漫射表和Blinn高光。我见过很多Oren-Nayar模型不同的应用方法,所以我很难解释它。这中间很多不使用遮罩和自身阴影投射,也不把波长计算算在其中。大多数情况下这个模型看起来像Lambert漫射加上视线正对处的暗淡,再加上一些背部散射。下图中的2,3号球是oren-Nayar模型的简单渲染,画圈的部位是同一点的不同视角,说明了反射值依据视角的不同而不同。我很喜欢这个模型,因为它比Lambert更具真实性。

按此在新窗口浏览图片

    下图中的1号球是另一种Oren-Nayar模型的应用。它看上去更像没有暗淡的lambert和背部散射的混合。不要问我它的算法是什么,它只是千万种经典模型中的一个变种。2号球体是复杂表面上的Oren Nayar漫射,带有尖锐的Blinn高光。3号球体使用相同的设置,只是漫射部分是Lambert,高光是Phong。

按此在新窗口浏览图片

08.各向异性和序乱的模型:Ward, He, Schlick, Lewis, Lafortune等...
    在上世纪90年代出现了大量的模型,而且有很多模型发展到了现在。这之中最流行的是He-Torrance-Sillion-Greenberg模型(1991--非常复杂,引入SSS特效,有着新型漫射部分叫直接漫射,基于物理真实和三角面),Schilick模型(1994--类似遮罩的三角面,漫射 和高光部分一起计算,支持各向异性的新算法),Ward模型(1992--带有高斯分布的快速各向异性模型,物理上正确),Lewis模型(1993--也叫著名的经典cosine-lobe模型,物理上正确的Phong分布的扩展)和lafortune模型(1997--由于它是Lewis模型的普及,也叫普通版的cosine-lobe模型)。在一些3D软件中你可以看到它们的应用,但软件中不是用的它们的真名,因为软件的程序员只是用这些模型来达到他们特定的需求。这也是许多不同的模型存在的原因。举例来说,如果你安装了3ds max的第三方渲染插件和材质包,以及一些带有BRDF模型的插件(像HairFX,MooDee shaders,Facialstudio),你会看到有20-30种不同的模型供你选择。再让我们来看看名向异性吧。到现在为止我们只介绍了各向同性模型,就是说反射值不随模型的旋转而发生变化。同样基本的三角面模型也是各向同性的,因为三角面的尺寸一样,且在表面上均匀分布。如果反射值随摄像机的角度旋转而不同也不能说明是各向异性的模型,就像我在第一部分里讲到的那样,各向异性是你在某一方向观察时表面上的凹凸和刮痕表现出同一性。来看看图片吧。
    球1的高光是Ward模型。很像Blinn是吗,但我认为这个看上去要好点,因为高斯分布使得高光处有更多的细节,不像Blinn那么柔和。这个球只是有高光,但是当你使用物理上正确的镜面反射光线跟踪时你就明白我在说什么了。球2就是Ward模型的光线跟踪反射,球3是同样条件下的Blinn模型。球2我使用了各向异性的参数,还做了一段动画来看这个效果。有趣的是我也可以把Blinn模型弄成各向异性,这就是我所说的序乱的模型。你可以看到,Blinn模型上的各向异性有点问题,Blinn反射像平常那样柔和,但左下的那道细长高光表现的非常尖锐,这不像我想像中的那样。第三个球体是另个一种有趣的各向异性模型,它是finalshaders的distant fur,是3ds max的渲染插件finalrender stage-1的材质插件。它可以做为高级BRDF模型的很好的例子,它含有许多不同的基本BRDF模型和一些扩展的功能,能方便的使用户创建他们想要的效果。

按此在新窗口浏览图片

    下图中的1号球是在绒绒的粗糙球体上使用了柔和的不均等色和Lambert漫射。在做成动画的时候不均等色也会使球体看上去模糊,像长绒毛一样。2号球使用非常尖锐的各向异性高光来模拟油油的表面。第3个球使用了自定义曲线来控制一个强大模型的光线反射分布。很遗憾这个类型的模型没有在大多数渲染器里得到支持,这种类型的著名模型有FALLOFF贴图和Zauner模型。我希望在渲染程序里能够很好的整合镜面反射衰减和各向异性分布的自定义曲线。4号球使用Zauner模型来产生模拟的SSS效果。看来我们已经接触到了SSS,好吧我们开始下一个话题吧。

按此在新窗口浏览图片

09.高级渲染技巧和SSS模型:Kubelka-Munk,Hanrahan-Krueger,Jensen
    首先,Kubelka-Munk和Hanrahan-Krueger模型跟高级渲染没什么关系。它们跟上面讲的模型一样,跟表面和摄像机有关,这两个又跟SSS特效有关。实际上它们是跟SSS特效最有关的模型,除了He模型之外。但它们只是处理表面的漫射部分,就是说它们不能真的计算表面下面的光线来达到实现真实物理属性的目的。这种技术需要新的渲染技术,像高级光线跟踪算法(MONTE CARLO)和光子贴图技术的支持。Kubelka-Munk模型是一个非常简单的用来描述表面上色素层的BRDF。它先考虑一层色素,下一步通过一个拥有众多参数的函数来模拟多层表面下的光线散射。就是说你可以指定表面的层数,漫射和散射行为,吸收光线的颜色和厚度。
    下图的的1号球是Hanrahan-Krueger模型的动画。红色的过渡色是基本层,然会我在之上加了一层皮肤色的层,做成动画。第二个球是复杂表面上的Hanrahan-Krueger,打了背部散射的灯光来模拟毛发的细微模糊效果。这个模型模拟皮肤效果很好,特别是结合纹理贴图的时候。但注意它只是一个BRDF(R表示反射),毕竟有它的局限性。三号球是使用了正确物理属性MONTE CARLO算法的SSS效果。这种效果很慢,你可以把它当做是加强的光线跟踪算法,因为要从表面上某一点发射出多条光线到场景中来收集必要的信息,这比只发射一条光线要慢很多。这也可以是一种序乱的Lambert光线跟踪算法,因为从这一点处的半球体射出的光线是随机的。我不肯定MONTE CARLO算法的光线跟踪渲染器是否考虑了BRDF模型,来达到多种效果的目的。典型的基于Lambert的电脑图像看上去是死板的,这时典型的GI来到了,但这种算法渲染动画的速度太慢了。因此,Henrik Jensen,光子贴图的发明者(几乎所有的渲染器都集成了这种特效)结合了这两种方法各自的优点,它使用了普及化的Hanrahan-Kruger作为散射部分(直接散射和漫射)和一种优化的漫射逼进算法作为多重散射的漫射部分(加上菲涅耳效应),他称他的这种快速SSS为BSSRDF宝贝。他成功了,看看Gollum,哈里波特,或其它一些大预算的电脑动画你就知道我的意思了。最后一个球体使用了Hanrahan-Kruger和低品质的MONTE CARLO的混合来加速SSS特效。 

按此在新窗口浏览图片


只有注册用户登录后才能发表评论。
网站导航: 博客园   IT新闻   BlogJava   博问   Chat2DB   管理