Artifacts 瑕疵,频率方面的基础知识,傅里叶变换,卷积 ,从频率的角度看采样,减少走样的方法,深度缓存 Z-Buffer

本文主要是介绍Artifacts 瑕疵,频率方面的基础知识,傅里叶变换,卷积 ,从频率的角度看采样,减少走样的方法,深度缓存 Z-Buffer,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Artifacts 瑕疵

在计算机图形学中Artifacts(瑕疵)指的是Errors / Mistakes / Inaccuracies

采样产生的Artifacts

锯齿

在这里插入图片描述

摩尔纹

Moire Pattterns(去掉图像的奇数行和奇数列)—— 由欠采样undersampling造成
在这里插入图片描述

产生Artifacts 的原因

很多Artifact产生的原因是信号变换太快而采样太慢

一种反走样的方法 —— 在采样之前做模糊(滤波)

对原始的信号做模糊(滤波)再进行采样即可进行反走样。(注意:顺序不能变,先采样再模糊无法反走样
在这里插入图片描述

频率方面的基础知识

频域 Frequency Domain

频域是描述信号在频率方面特性时用到的一种坐标系。 在电子学,控制系统工程和统计学中,频域图显示了在一个频率范围内每个给定频带内的信号量 。

频率和周期

频率是f,周期是T。
频率越快,函数变化越快,如下图所示。
在这里插入图片描述

傅里叶变换

傅里叶级数展开

一切函数都可以写成一系列正弦函数和余弦函数的线性组合与一个常数项。任何函数分解为频率从低到高的若干函数。
在这里插入图片描述

傅里叶变换

下面展示了傅里叶变换和逆傅里叶变换。
在这里插入图片描述

从频率图像上来分析走样

频率越高的函数,采样回复到原函数的效果越差。即:高频率需要更快的采样。
在这里插入图片描述
在这里插入图片描述
走样:从频率分析角度定义走样:同样的采样方法采样两种频率的函数,但是得出的结果无法区分。

滤波

(频率角度上)滤波就是去掉一系列的频率。

傅里叶变化的作用

傅里叶变换可以把图像从时域变到频域。对下左图进行傅里叶变换,得到下右图。下右图中,中心是低频区域,向外延伸,频率越来越高,为高频区域亮度代表信息密度,区域越亮表示信息越集中,下图表示图片的大多数信息都处于低频。右下图右成为频谱。
在这里插入图片描述

高通滤波(High-pass filter)

消除低频的信号,只让高频信号可以通过,再使用逆傅里叶变换得到图像。
在这里插入图片描述
边界的特点:图像中发生突变的位置(颜色差的很多)。对应信号变换特别大,频率大,所有高通滤波器显示边界。

低通滤波/模糊(Low-pass filter/Blur)

消除高频的信号,只让低频信号可以通过,然后进行逆傅里叶变换。
在这里插入图片描述
低筒滤波器消除边界,让图片变得模糊。

带通滤波(Band-pass filter)

去掉高频和低频的信息,然后进行逆傅里叶变换。
在这里插入图片描述

卷积 Convolution

滤波 Filtering = 卷积 Convolution (= 平均 Averaging)
卷积是多个变量在某范围内相乘后求和的结果。
简单理解:有一个滑动窗口(滤波器),窗口的每个格子有权重,将这个窗口在信号上从左向右滑动做点乘。如下图所示。
在这里插入图片描述

卷积定理 Convolution Theorem

卷积定理指出,函数卷积的傅立叶变换是函数傅立叶变换的乘积。
具体分为时域卷积定理和频域卷积定理,两者具有对偶关系。

卷积定理的应用

如下图所示上面一行图片是时域的卷积(*是卷积操作)下面一行图片是频域的乘积。
在这里插入图片描述

卷积中的低通滤波器

下面盒子形状的滤波器(Box Filter)就是低通滤波器。
在这里插入图片描述
乘上1/9是为了卷积后的图片颜色与原来基本一致,否则图片就太亮了(归一化)。

卷积核大小与频率的关系

越小的box,留下频率种类越多。
在这里插入图片描述
在这里插入图片描述
越大的box,留下越低的频率,结果更加模糊。

从频率的角度看采样

采样就是重复频域上的内容。

冲激函数

在这里插入图片描述

获得采样(与冲激函数相乘)

对于原始信号a,让它与冲激函数相乘,就可以得到采样的结果。
在这里插入图片描述
**采样就是重复原始信号的频谱。**采样就是将原始信号粘贴了一份。

走样 = 频谱在搬移后出现了混合 Aliasing=Mixed Frequency Contents

在这里插入图片描述
走样的原因是:在频谱的角度,原始信号在复制粘贴时出现了信号的重叠。

减少走样的方法

增加采样率

可以使用高分辨率的显示器、传感器、帧缓冲器。

进行反走样

不是通过提高分辨率抗锯齿。
反走样简单来说就是:在对频谱重复之前,先让频谱更窄,减少信号的重叠。即先去掉一些的高频信息,然后再采样。这就解释了为什么模糊一个图像后采样能够抗走样。,如下图所示。
在这里插入图片描述

如何模糊三角形—通过在像素区域平均来反走样

使用一个低通滤波器,针对每个像素做卷积操作,然后对每个像素中心进行采样。
在这里插入图片描述
像素区域的亮度等于覆盖的图案覆盖这个像素的面积(即把像素内部的值平均起来)
在这里插入图片描述

多重采样 Antialiasing By Supersampling(MSAA)

我们通过在一个像素内划分出更多的中心点来用更多的采用点进行反走样,将一个划分多个像素,判断这些更小的像素点是否在三角形内部,统计在三角形内部小像素点的个数判断覆盖率但注意这只是反走样的近似,并不能真正解决反走样问题

超采样 Supersampling

第一步:对每个像素划分N × N的采样点。
在这里插入图片描述

第二步:在每个像素里对这个N × N的采样点做平均。
在这里插入图片描述

结果:
在这里插入图片描述
抗锯齿了:
在这里插入图片描述
这种方法增大了计算量实现抗锯齿。

其他抗锯齿的方法

FXAA(Fast Approxiamate AA):先获得有锯齿的图,然后找到边界,然后将有锯齿的边界替换成没有锯齿的边界。
TAA(Temporal AA):复用上一帧感知到的结果,相当于把MSAA的样本分布到时间上,然后不对当前这一帧引入额外的操作。

超分辨率问题 Super resolution / super sampling

  • 超分辨率就是从低分辨率到高分辨率(比如把256 × 256图片拉大到1024 × 1024)
  • 本质上仍是采样不足的问题,与抗锯齿的问题相似。
  • 可以采用DLSS(Deep Learning Super Sampling)的方法,利用深度学习猜出来。

可见性 / 遮挡 Visiblity / occlusion

画家算法 Painter’s Algorithm

思想:首先绘制距离较远的场景,然后用绘制距离较近的场景覆盖较远的部分。
存在的问题:首先画家算法需要按照深度排序需要将物体按照深度进行排序,但是对于以下三个三角形,无法确定深度的顺序,所以实际上我们无法使用画家算法。
在这里插入图片描述

深度缓存 Z-Buffer

  1. 存储每个像素当前最小的z值(深度值)
  2. 需要一个额外的缓存来存储深度值
  • frame buffer 存储颜色值
  • depth buffer(z-buffer)存储深度值(为了简化,我们假设所有z都是正数,z越小越近)
    在这里插入图片描述
    上述两张图同步生成,左边的图实际渲染,右边的是深度缓存图,离我们近颜色越深,反之离我们越远。

Z-Buffer 算法

  1. 初始化深度缓存为无限大
  2. 在光栅化时,有:
    在这里插入图片描述
    例子:
    在这里插入图片描述

这篇关于Artifacts 瑕疵,频率方面的基础知识,傅里叶变换,卷积 ,从频率的角度看采样,减少走样的方法,深度缓存 Z-Buffer的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/253430

相关文章

Nginx设置连接超时并进行测试的方法步骤

《Nginx设置连接超时并进行测试的方法步骤》在高并发场景下,如果客户端与服务器的连接长时间未响应,会占用大量的系统资源,影响其他正常请求的处理效率,为了解决这个问题,可以通过设置Nginx的连接... 目录设置连接超时目的操作步骤测试连接超时测试方法:总结:设置连接超时目的设置客户端与服务器之间的连接

Java判断多个时间段是否重合的方法小结

《Java判断多个时间段是否重合的方法小结》这篇文章主要为大家详细介绍了Java中判断多个时间段是否重合的方法,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录判断多个时间段是否有间隔判断时间段集合是否与某时间段重合判断多个时间段是否有间隔实体类内容public class D

Python使用国内镜像加速pip安装的方法讲解

《Python使用国内镜像加速pip安装的方法讲解》在Python开发中,pip是一个非常重要的工具,用于安装和管理Python的第三方库,然而,在国内使用pip安装依赖时,往往会因为网络问题而导致速... 目录一、pip 工具简介1. 什么是 pip?2. 什么是 -i 参数?二、国内镜像源的选择三、如何

IDEA编译报错“java: 常量字符串过长”的原因及解决方法

《IDEA编译报错“java:常量字符串过长”的原因及解决方法》今天在开发过程中,由于尝试将一个文件的Base64字符串设置为常量,结果导致IDEA编译的时候出现了如下报错java:常量字符串过长,... 目录一、问题描述二、问题原因2.1 理论角度2.2 源码角度三、解决方案解决方案①:StringBui

Linux使用nload监控网络流量的方法

《Linux使用nload监控网络流量的方法》Linux中的nload命令是一个用于实时监控网络流量的工具,它提供了传入和传出流量的可视化表示,帮助用户一目了然地了解网络活动,本文给大家介绍了Linu... 目录简介安装示例用法基础用法指定网络接口限制显示特定流量类型指定刷新率设置流量速率的显示单位监控多个

Java覆盖第三方jar包中的某一个类的实现方法

《Java覆盖第三方jar包中的某一个类的实现方法》在我们日常的开发中,经常需要使用第三方的jar包,有时候我们会发现第三方的jar包中的某一个类有问题,或者我们需要定制化修改其中的逻辑,那么应该如何... 目录一、需求描述二、示例描述三、操作步骤四、验证结果五、实现原理一、需求描述需求描述如下:需要在

JavaScript中的reduce方法执行过程、使用场景及进阶用法

《JavaScript中的reduce方法执行过程、使用场景及进阶用法》:本文主要介绍JavaScript中的reduce方法执行过程、使用场景及进阶用法的相关资料,reduce是JavaScri... 目录1. 什么是reduce2. reduce语法2.1 语法2.2 参数说明3. reduce执行过程

C#中读取XML文件的四种常用方法

《C#中读取XML文件的四种常用方法》Xml是Internet环境中跨平台的,依赖于内容的技术,是当前处理结构化文档信息的有力工具,下面我们就来看看C#中读取XML文件的方法都有哪些吧... 目录XML简介格式C#读取XML文件方法使用XmlDocument使用XmlTextReader/XmlTextWr

C++初始化数组的几种常见方法(简单易懂)

《C++初始化数组的几种常见方法(简单易懂)》本文介绍了C++中数组的初始化方法,包括一维数组和二维数组的初始化,以及用new动态初始化数组,在C++11及以上版本中,还提供了使用std::array... 目录1、初始化一维数组1.1、使用列表初始化(推荐方式)1.2、初始化部分列表1.3、使用std::

oracle DBMS_SQL.PARSE的使用方法和示例

《oracleDBMS_SQL.PARSE的使用方法和示例》DBMS_SQL是Oracle数据库中的一个强大包,用于动态构建和执行SQL语句,DBMS_SQL.PARSE过程解析SQL语句或PL/S... 目录语法示例注意事项DBMS_SQL 是 oracle 数据库中的一个强大包,它允许动态地构建和执行