计算机图形学十五菲涅尔方程

这篇具有很好参考价值的文章主要介绍了计算机图形学十五菲涅尔方程。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

菲涅尔效应

现实场景:

菲涅尔效应在我们的日常生活中无处不在,下面来个例子三连:

我们去公园的池塘喂鲤鱼,当爆米花丢的比较近的时候,我们可以看见水底下成群的鲤鱼在抢吃的。但是当我们把爆米花丢的很远时,却看不见水底下那些如狼似虎的鲤鱼,只能看见水面上的倒影。

即近处可以看清水底细节,远处只能看清倒影。

我们在坐公交车的时候,从身边的窗户往外看,可以清晰的看清楚车外的世界,但是当我们去看离得比较远的玻璃的时候,往往会看见很多车内的倒影,例如司机和别的乘客。

即较近的玻璃可以很清楚的看清后面的东西,远处的玻璃出现了路面的倒影。

对于放置在桌面上的物体,当我们从不同的角度去观察它时,也会发现很神奇的现象,如下:

水平看时,可以看见物体的倒影
从上往下看时,几乎看不见物体的倒影。

上面这些生活中常见的现象就是菲涅尔效应。

菲涅尔效应的科学定义

菲涅尔项:入射角度不同,反射光所占的比例。

那么我们怎么用更科学的术语来描述这个它们呢?
我们能够看见水底下或者玻璃后的东西,那肯定是光线发生了折射所导致的。而对于水面上的倒影或者是玻璃变得像镜子一样这些都是因为光线发生了反射所导致的。
通过前面的现象,我们可以发现,当我们人眼离物体表面(玻璃,水,或者桌子等)比较近时,此时我们的视线几乎与表面垂直,我们可以看见更多折射过来的光(水底的鱼,玻璃外的东西)。而当人们眼睛离物体表面比较远时,此时我们的视线几乎与表面平行,我们可以看见更多反射过来的光(倒影)。
我们知道当光线打向一个物体表面(介质)时,会发生反射与折射。其中反射光的方向以及入射光的方向我们可以通过反射定律折射定律来计算出。
计算机图形学十五菲涅尔方程,c++
但是到底是反射光更强还是折射光更强呢?

了解过辐射度量学应该知道这里比较的是辐射率(Radiance)的大小,通过菲涅尔效应我们不难发现,当入射光方向接近垂直表面时,大部分的能量会被折射,所以我们能看清水底的东西。而当入射光方向接近平行表面时,大部分的能量会被反射,所以我们会看见远处的倒影。

那么在我们渲染的时候,自然要把这个现象给考虑进去,才能够达到以假乱真的目的。因此我们自然需要一个公式,能够描述出在不同入射光的情况下,反射光与折射光所占的比例,这个公式就是菲涅尔方程。

菲涅尔方程

当光线碰撞到一个表面的时候,菲涅尔方程会根据观察角度告诉我们被反射的光线所占的百分比。利用这个反射比率和能量守恒原则,我们可以直接得出光线被折射的部分以及光线剩余的能量。将其应用在BRDF中,我们就可以更加精准的计算出渲染方程中计算机图形学十五菲涅尔方程,c++的值。
我们假设入射光与法线的夹角为计算机图形学十五菲涅尔方程,c++,折射光与法线的夹角为计算机图形学十五菲涅尔方程,c++。由于折射还和介质的折射率有关,例如空气中的光射入水中,我们需要知道空气和水分别对应的折射率,我们再假设入射光所在的介质的折射率为n1,物体的折射率为n2。
由于光的偏振(极化)现象,我们可以得到S偏振光和P偏振光分别对应的菲涅尔方程,如下:
计算机图形学十五菲涅尔方程,c++
根据折射定律:
计算机图形学十五菲涅尔方程,c++
可以推导出:
计算机图形学十五菲涅尔方程,c++
因此上面的菲涅尔方程可以写成没有计算机图形学十五菲涅尔方程,c++的形式:
计算机图形学十五菲涅尔方程,c++
如果我们不考虑偏振的情况,那么菲涅尔方程即是上面两者的平均值:
计算机图形学十五菲涅尔方程,c++
利用菲涅尔方程,我们就可以根据不同的反射率画出R与计算机图形学十五菲涅尔方程,c++的对应关系图,如下:
计算机图形学十五菲涅尔方程,c++
图中代表的是折射率为1.5的绝缘体(例如某种玻璃)的反射情况。可以发现当夹角为0时,即入射光垂直于表面,反射光的比例只有4%左右,而当夹角为90度时,即入射光平行于表面,反射比例将近100%,符合我们前面所说的菲涅尔效应。
我们再来看一个导体(比如铜镜)的关系图,如下:
计算机图形学十五菲涅尔方程,c++
可以发现即使光线垂直于导体表面,但是依旧有90%的光被反射。这也证实了为什么我们可以用铜来做镜子,却没法使用玻璃来做镜子。

Schlick近似法

很明显,前面的式子实在太复杂了,计算量会非常的多,那么有没有什么近似的方法来求得菲涅尔方程的值呢?
从上面两个关系图中,我们可以发现,反射比例和夹角的关系,基本上都是由基础反射率计算机图形学十五菲涅尔方程,c++的值,假设为R0)以某种类似的曲线增长到1。
其中基础反射率的值我们很好求得,因此此时计算机图形学十五菲涅尔方程,c++,带入前面的公式可得:
计算机图形学十五菲涅尔方程,c++
例如水的折射率为1.333,对应的R0即为(0.333/2.333)²=0.02。接下来的问题就是怎么用一个简单的函数使得反射率能随着计算机图形学十五菲涅尔方程,c++的增长以类似某种指数增长的方式从基础反射率变为1,这里Schlick为我们提供了一种近似方程:
计算机图形学十五菲涅尔方程,c++
上面的方程就是我们在渲染时常用的菲涅尔方程,用代码可以表示为:

vec3 fresnelSchlick(float cosTheta, vec3 R0)
{
    return R0 + (1.0 - R0) * pow(1.0 - cosTheta, 5.0);
}

其中一个问题是它仅仅对电介质或者说非金属表面有定义,而对于导体表面,使用它们的折射率(导体的折射率为负数)计算并不能得出正确的结果,这样我们就需要使用一种不同的菲涅尔方程来对导体表面进行计算,但是这样很不方便。所以我们预先计算出导体的基础反射率,然后用Schlick方法来对其进行插值估算,这样我们就能对金属和非金属材质使用同一个公式了。

下面是一些常见材质的基础反射率:
计算机图形学十五菲涅尔方程,c++

从中可以发现大多数电介质(绝缘体)的基础反射率要低于0.17,而导体(金属)的往往在0.5-1之间,对于导体而言它们的反射率一般都是带有颜色的,这也是为什么要用RGB三原色来表示。

金属表面的这个特性也引出了所谓的金属工作流概念,也就是我们需要额外使用一个被称为金属度(Metalness)的参数来参与编写表面材质。金属度用来描述一个材质表面时金属还是非金属的

理论上来说,一个表面的金属度应该是个布尔值,即要么是金属要么不是金属,不能两者皆是,但是,大多数的渲染管线都允许在0.0至1.0之间线性的调配金属度。这主要是由于材质纹理精度不足以描述一个拥有诸如细沙/沙状粒子/刮痕的金属表面。因此我们需要一个可调整的金属度模拟这些效果,来获得非常好看的视觉效果。

通过预先计算物体的基础反射率的值,我们可以对两种类型的表面使用相同的Fresnel-Schlick近似,但是如果四金属表面的话就需要对基础反射率添加色彩。我么一般是按下面这个样子来实现的:

vec3 R0 = vec3(0.04);
R0 = mix(R0, surfaceColor.rgb, metalness);//根据金属度作插值
外发光

根绝菲涅尔效应我们可以知道,当物体表面的法线平行于屏幕的时候,也就是Camera基本水平看向这个平面的时候,此时的反射光应该是最强的,示意图如下:
计算机图形学十五菲涅尔方程,c++
因此我们就可以使用这个性质在shader中制作外发光的效果,视频教程如下:
https://www.bilibili.com/video/BV1Fb411p7hN
下面是效果图。
计算机图形学十五菲涅尔方程,c++文章来源地址https://www.toymoban.com/news/detail-611149.html

到了这里,关于计算机图形学十五菲涅尔方程的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 计算机图形学——大作业

    绘制一个简单的三维场景,可以是室内:卧室,办公室,教室,也可以是室外:运动场,公园等,加上光照效果,简单的纹理映射,透视投影;不能过于简单;可以加动画、鼠标和键盘交互。     上交材料: project和word文档(具体内容展示,思路和心得) 首先初始化窗口,

    2024年02月11日
    浏览(48)
  • 计算机图形与图像技术

    可以使用Python、Java等语言。 下图中,图中各事物比例失调 如何使用代码去掉某个人(不允许使用抠图工具)?         像素(Pixel)是“图像元素”的缩写, 指的是图像的最小单位 。 它是构成数码图像或屏幕显示图像的基本单元,代表了图像中的一个小点或一个小方块

    2024年02月07日
    浏览(55)
  • Unity中URP下的菲涅尔效果实现(URP下的法线和视线向量怎么获取)

    我们在这篇文章中,了解一下URP中Shader怎么实现菲涅尔效果,同时学习一下URP下怎么获取法线 和 视线向量。 Lambert光照模型公式: Diffuse = Ambient + Kd * LightColor * max(0,dot(N,L)) 实现灯光照射中间亮 周围暗的效果,核心是dot(N,L) Unity中Shader的Lambert光照的实现 光照效果下, 视线单

    2024年02月02日
    浏览(45)
  • 计算机图形学 期末复习笔记

    目录 第一章-导论 1. 计算机图形学的定义 2. 计算机图形学的应用领域 2.1 计算机图形学与其他学科的关系 3. 图形显示器的发展及其工作原理 3.1 阴极射线管(CRT) 3.2 随机扫描显示器 3.3 直视存储管显示器 3.4 光栅扫描显示器 4. 图形软件标准的形成 5. 三维图形渲染管线 第二章

    2024年02月12日
    浏览(43)
  • 计算机图形学(三) -- 3D 变换

    同样引入齐次坐标: 3D 点 = ( x , y , z , 1 ) T (x, y, z, 1)^T ( x , y , z , 1 ) T 3D 向量 = ( x , y , z , 0 ) T (x, y, z, 0)^T ( x , y , z , 0 ) T 通常, ( x , y , z , w ) (x, y, z, w) ( x , y , z , w ) (w != 0) 表示一个坐标为 ( x / w , y / w , z / w ) (x/w, y/w, z/w) ( x / w , y / w , z / w ) 的 3D 点 用一个 4x4 的矩阵来表示

    2024年02月08日
    浏览(39)
  • 【计算机图形学01】坐标变换

             将坐标变换为标准化设备坐标,接着再转化为屏幕坐标的过程通常是分步进行的,也就是类似于流水线那样子。在流水线中,物体的顶点在最终转化为屏幕坐标之前还会被变换到多个坐标系统(Coordinate System)。将物体的坐标变换到几个 过渡 坐标系(Intermediate Coor

    2024年02月10日
    浏览(37)
  • 计算机图形学 | 变换与观察

    华中科技大学《计算机图形学》课程 MOOC地址:计算机图形学(HUST) 回顾几何阶段 整体流程: 这其中存在3种变换: 坐标系的变换 模型本身的运动 观察者的运动 几何变换 以上各种变换都可以通过以下变换的复合来计算: 平移 比例 旋转 对称 错切 图形的几何变换是指对图

    2023年04月27日
    浏览(44)
  • 【计算机图形学】曲线和曲面

    模块5 曲线和曲面 一 实验目的 编写曲线和曲面的算法 二 实验内容 1 :绘制Bezier曲线,并采用自行设计输入和交互修改数据点的方式。 实验结果如下图所示: 第一步:输入特征多边形的顶点个数,并按照顺序输入顶点的坐标。 第二步:点击左键生成bezier曲线(白色部分)和

    2024年02月06日
    浏览(43)
  • 【计算机图形学】三维图形投影和消隐(三视图构造)

    模块4-1 三维图形投影和消隐 一 实验目的 编写三维图形各种变换的投影算法 二 实验内容 1 :自行选择三维物体(不能选长方体),建立坐标系,给定点的三维坐标值,建立边表结构。完成三视图。 实验结果如下图所示: 左上显示为主视图,右上显示为侧视图,右下显示为

    2024年02月01日
    浏览(88)
  • 计算机图形学-GAMES101-4

    当我们旋转Q角度和旋转-Q角度时,变换矩阵中旋转的部分如下图所示: 旋转Q和旋转-Q的变换矩阵应该互为逆矩阵,而我们可以看到它们互为对方矩阵的转置。其实Rq是一个正交矩阵,因此其逆矩阵就是它自己的转置。当我们旋转图形一个角度为Q时,如果我们想旋转为-Q,可以

    2024年02月05日
    浏览(46)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包