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

相关文章

Java 中的 @SneakyThrows 注解使用方法(简化异常处理的利与弊)

《Java中的@SneakyThrows注解使用方法(简化异常处理的利与弊)》为了简化异常处理,Lombok提供了一个强大的注解@SneakyThrows,本文将详细介绍@SneakyThro... 目录1. @SneakyThrows 简介 1.1 什么是 Lombok?2. @SneakyThrows

判断PyTorch是GPU版还是CPU版的方法小结

《判断PyTorch是GPU版还是CPU版的方法小结》PyTorch作为当前最流行的深度学习框架之一,支持在CPU和GPU(NVIDIACUDA)上运行,所以对于深度学习开发者来说,正确识别PyTor... 目录前言为什么需要区分GPU和CPU版本?性能差异硬件要求如何检查PyTorch版本?方法1:使用命

Qt实现网络数据解析的方法总结

《Qt实现网络数据解析的方法总结》在Qt中解析网络数据通常涉及接收原始字节流,并将其转换为有意义的应用层数据,这篇文章为大家介绍了详细步骤和示例,感兴趣的小伙伴可以了解下... 目录1. 网络数据接收2. 缓冲区管理(处理粘包/拆包)3. 常见数据格式解析3.1 jsON解析3.2 XML解析3.3 自定义

SpringMVC 通过ajax 前后端数据交互的实现方法

《SpringMVC通过ajax前后端数据交互的实现方法》:本文主要介绍SpringMVC通过ajax前后端数据交互的实现方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价... 在前端的开发过程中,经常在html页面通过AJAX进行前后端数据的交互,SpringMVC的controll

Java中的工具类命名方法

《Java中的工具类命名方法》:本文主要介绍Java中的工具类究竟如何命名,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录Java中的工具类究竟如何命名?先来几个例子几种命名方式的比较到底如何命名 ?总结Java中的工具类究竟如何命名?先来几个例子JD

Spring Security自定义身份认证的实现方法

《SpringSecurity自定义身份认证的实现方法》:本文主要介绍SpringSecurity自定义身份认证的实现方法,下面对SpringSecurity的这三种自定义身份认证进行详细讲解,... 目录1.内存身份认证(1)创建配置类(2)验证内存身份认证2.JDBC身份认证(1)数据准备 (2)配置依

python获取网页表格的多种方法汇总

《python获取网页表格的多种方法汇总》我们在网页上看到很多的表格,如果要获取里面的数据或者转化成其他格式,就需要将表格获取下来并进行整理,在Python中,获取网页表格的方法有多种,下面就跟随小编... 目录1. 使用Pandas的read_html2. 使用BeautifulSoup和pandas3.

Spring 中的循环引用问题解决方法

《Spring中的循环引用问题解决方法》:本文主要介绍Spring中的循环引用问题解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录什么是循环引用?循环依赖三级缓存解决循环依赖二级缓存三级缓存本章来聊聊Spring 中的循环引用问题该如何解决。这里聊

Java学习手册之Filter和Listener使用方法

《Java学习手册之Filter和Listener使用方法》:本文主要介绍Java学习手册之Filter和Listener使用方法的相关资料,Filter是一种拦截器,可以在请求到达Servl... 目录一、Filter(过滤器)1. Filter 的工作原理2. Filter 的配置与使用二、Listen

Pandas统计每行数据中的空值的方法示例

《Pandas统计每行数据中的空值的方法示例》处理缺失数据(NaN值)是一个非常常见的问题,本文主要介绍了Pandas统计每行数据中的空值的方法示例,具有一定的参考价值,感兴趣的可以了解一下... 目录什么是空值?为什么要统计空值?准备工作创建示例数据统计每行空值数量进一步分析www.chinasem.cn处