解读狗牙 显卡帝揭秘AA抗锯齿前世今生Word格式.docx

上传人:b****7 文档编号:21929787 上传时间:2023-02-01 格式:DOCX 页数:22 大小:1.59MB
下载 相关 举报
解读狗牙 显卡帝揭秘AA抗锯齿前世今生Word格式.docx_第1页
第1页 / 共22页
解读狗牙 显卡帝揭秘AA抗锯齿前世今生Word格式.docx_第2页
第2页 / 共22页
解读狗牙 显卡帝揭秘AA抗锯齿前世今生Word格式.docx_第3页
第3页 / 共22页
解读狗牙 显卡帝揭秘AA抗锯齿前世今生Word格式.docx_第4页
第4页 / 共22页
解读狗牙 显卡帝揭秘AA抗锯齿前世今生Word格式.docx_第5页
第5页 / 共22页
点击查看更多>>
下载资源
资源描述

解读狗牙 显卡帝揭秘AA抗锯齿前世今生Word格式.docx

《解读狗牙 显卡帝揭秘AA抗锯齿前世今生Word格式.docx》由会员分享,可在线阅读,更多相关《解读狗牙 显卡帝揭秘AA抗锯齿前世今生Word格式.docx(22页珍藏版)》请在冰豆网上搜索。

解读狗牙 显卡帝揭秘AA抗锯齿前世今生Word格式.docx

大家只要靠近电视仔细观察就会发现一个个红绿蓝色的小点,这即是像素点。

然而,曲线和角的如果用方块状的像素来表现,这显然是“不大方便的”,因为曲线和角容易产生“狗牙般”的锯齿。

AA就是解决这一难题的一项技术,其目的就是让图像看起来更加平滑自然。

总之,进过AA处理过后的图像消除了锯齿所带来的“方块感”。

左边的图是非常平滑的,但右边的则显得一块一块的

从上面这张图我们可以很直观的看出未采用AA抗锯齿技术处理的图像要比采用AA抗锯齿处理过后在“方块感”上面要严重许多。

AA的前提非常简单。

请看下面这个图表:

圆的平滑过渡

首先假设你要想在屏幕上表现一个圆,若圆的尺寸很大,那么通过很多很多的像素进行排列即可,但如果要表现一个小尺寸的圆,因为提供给你所控制的像素点数量很少,故而通过像素方块所构建起来的圆最后可能是啥也不像。

此刻,AA抗锯齿正好帮上了大忙。

我们先将圆放大(最左边第一个圆),再将其和一个像素栅格对齐,每个方块代表一个像素。

这时你会发现栅格里的好多像素都没有填满,且填充的比例也不尽相同。

然后,我们的目标就是找出这些不完全填充的格子,根据填充的比例挑选基本色(这里是黑色)的相应比例来填充进去,即得到了第四个圆。

仔细分析下这个圆,全填黑色的是那些格子里完全填充的,而某些50%填充的就填入一个50%的灰进去,75%的就填入75%的灰,等等。

最后我们将填好图的第四个圆缩小为原始大小,即得到了第5个圆,效果是不是很不错哈。

不过这种方法只部分适用于“像素艺术”领域里,因为像素点的尺寸和颜色的数量都是有限制的。

值得一提的是,AA有正确的用法也有错误的用法。

正确的方法是如上面所示造成平滑过渡的感觉。

错误的方法是像下图的最左边的图在黑色边线的外围全部加上50%的灰度像素:

AA有正确的用法也有错误的用法

刚刚接触AA抗锯齿时,人们往往会犯一个错误:

即将每一“步”都加入一单个浅色像素。

其实这种方法显的十分糟糕。

中间的方法是正确的:

只再需要的地方加适合的过渡像素。

虽说此刻弧线开起来平滑了些,但锯齿感还没有完全消除。

最后边的则是最佳的方法:

加两层过渡色,弧线看起来变的更加平滑。

所以,单个的分离像素通常不是最好的AA过渡,而同色线条或像素组可以将AA效果表达得更好。

OK,以上介绍了AA的基本前提,不过你会发现我们仅仅介绍了黑白两种颜色的情形。

倘若换成彩色,又该怎么办了?

其实方法和黑白情况下的AA过渡差不多,只是不再是检查黑色的百分比例,而是检查每种颜色的比例了。

上图:

每一个方块代表着两种或三种不同颜色之间准备用像素来过渡

左边第一个,是黑色和白色(在上面我们已经讨论过了)。

我们找到用来过渡黑与白的过渡色是一种中间灰。

这个颜色是靠混合白色所占的比例之白色和黑色所占的比例之黑色混合而得到的。

同样混合红色和黄色,我们得到橙色,然后深绿+蓝色=海蓝色,在最右边我们有一点点变化:

3种颜色在一起。

我们用同样的方法来对待,混合之后得到一个有点蓝的紫色。

方法确实并不复杂,但这些都是在可以无颜色限制情况下使用的,因为实际情况中是不可能有一个无限色盘来做AA过渡的,即使有也很费时间。

所以我们只能用不断尝试的方法来选出合适的AA过渡色,直到成功为止。

AA前世今生之:

HardwareAA

进过了前面对AA抗锯齿技术原来剖析,相比玩家对AA已经有了一个初步的认识。

AA抗锯齿技术在进过几十年的发展,从离线渲染逐步过渡普及到实时渲染的时代,AA在图形学中被广泛地用于了提升渲染质量上面。

接下来,我们就对实时渲染中所使用的AA方法的前世今生做一个详细阐述。

首先我们要讲的是由硬件支持的AA方法。

图1:

一个像素内部的采样点

上图是一个像素内部的采样点。

16个红圈表示16个采样点,蓝色和黄色是覆盖了这个像素的两个三角形。

我们通常所说的几倍抗锯齿指的就是一个像素点内的采样点数。

SSAA(SuperSamplingAnti-Aliasing)超级采样抗锯齿

SSAA是最为直观的一种AA,也是很早期的一种AA抗锯齿方法。

其基本思想是:

这样就等于把一幅模糊的大图,通过细腻化后再缩小成清晰的小图。

其实现方法之一:

先渲染一个大图,再Downsample(降低采样率),这可以等效为在每个最终像素内部做了一个均匀分布采样。

更通用的描述是,每个像素分布多个采样点(可以均匀分布、Poisson分布、随机分布、抖动分布等),每个采样点都有独立的color和depth,pixelshader在每个采样点都执行一遍。

如上图的情况,会得到1个白色,1个浅蓝色和14个黄色的采样点。

最后这个像素的值是这16个采样点的平均,也就是白色((1,1,1)+浅蓝色(0.77,0.77,1)+14*黄色(1,1,0))/16=(0.98,0.98,0.125)。

在这些方法中,SSAA质量最好,毕竟是个最原始最暴力的方法。

在D3D10.1+上可以选择per-sample或者per-pixel执行pixelshader,也就是直接支持了SSAA。

性能统计(采样数为N,下同):

每个像素里PS(pixelshader)执行次数为N,占用空间N个color+N个depth。

总之SSAA抗锯齿,简单直接但比较消耗资源。

MSAA(MultiSamplingAnti-Aliasing)多重采样抗锯齿

MSAA是一种特殊的超级采样抗锯齿(SSAA)。

MSAA首先来自于OpenGL,具体是MSAA只对Z缓存(Z-Buffer)和模板缓存(StencilBuffer)中的数据进行超级采样抗锯齿的处理。

只对多边形的边缘进行抗锯齿处理。

我们知道SSAA需要在每个采样点都执行一次PS并保存color和depth,时间和空间开销都是相当惊人的。

MSAA的出现极大地改善了这一点。

MSAA在每个像素只执行一次PS,输出颜色写入所有通过depth-stencil测试的采样本中。

在ShaderModel3之前,PS的输入一定取自像素的中心;

后来加入了centric插值,PS的输入属性就可以是三角形所覆盖的所有采样点的中心:

有无centric插值的对比

如图1的情况,没有centric插值的话,蓝色三角形的两个采样点将都得到纯蓝的颜色(外差而得),最终像素的颜色就是(2*(0,0,1)+14*(1,1,0))/16=(0.875,0.875,0.125)。

有centric插值的话就是个更正确的浅蓝色((1,1,1)+(0.77,0.77,1))/2=(0.885,0.885,1),最终像素颜色是(2*(0.885,0.885,1)+14*(1,1,0))/16=(0.98,0.98,0.125)。

如下图所示:

性能统计:

每个像素里PS执行次数为每个覆盖到该像素的三角形一次,占用空间N个color+N个depth。

总之,MSAA对资源的消耗需求大大降低,不过在画质上略不如SSAA。

CSAA(CoverageSamplingAnti-Aliasing)覆盖采样抗锯齿

NOAA,MSAA,CSAA的对比

CSAA是NVIDIA在G80及其衍生产品首次推向实用化的AA技术,也是目前nVidiaGeForce8/9系列独享的AA技术。

MSAA虽然解决了计算的问题,但存储量还是很大,尤其是采样率到了8以上。

而CSAA就是在MSAA基础上更进一步的节省显存使用量及带宽,简单说CSAA就是将边缘多边形里需要取样的子像素坐标覆盖掉,把原像素坐标强制安置在硬件和驱动程序预先算好的坐标中,这样就可以用较少的color/depth空间来存储原先高采样数才能得到的画质。

例如图1,我们用CSAA16x(即16个采样点)来渲染,就会把一个像素分成左上、右上、左下和右下4块区域,每块区域有4个coverage采样点,但共享同一个color和depth。

对于图1的情况,结果就是,(0.25*(0.885,0.885,1)+0.25*(0.885,0.885,1)+3.75*(1,1,0))/4=(0.98,0.98,0.125)。

每个像素里PS执行次数为每个覆盖到该像素的三角形一次,占用空间M个color+M个depth,M小于N。

总之,CSAA就好比取样标准统一的MSAA,能够最高效率的执行边缘取样,效能提升也相当显著。

比方说16xCSAA取样性能下降幅度仅比4xMSAA略高一点,效果却几乎和8xMSAA一样。

8xCSAA有着4xMSAA的处理效果,性能消耗却和2xMSAA相同。

PostprocessAA

SSAA、MSAA和CSAA这几种AA方法都是由硬件直接支持的,故而带来了不小的额外资源开销。

一方面AA对显存资源的消耗是巨大的,再者,这些AA方法对Edge(边缘)的考量都是原始边界,并没有去考虑这个边缘是否真的需要AA,故而会浪费一些计算量。

在GPUGem2的第9章DeferredShadinginS.T.A.L.K.E.R.,其首次面向游戏界宣传了DeferredShading(延迟渲染)的概念。

,同时也提及了Deferred框架无法使用硬件MSAA的问题。

虽然DeferredLighting解决了其中的问题,但再次渲染一遍场景的代价还是不小的。

更重要的是,由于Deferred框架的引入,人们终于开始正视MSAA实际上造成了很多时间和空间的浪费。

于是乎这几年基于Postprocess(后处理)的AA方法蓬勃发展,大有取代硬件式AA的气势。

EdgeAA

EdgeAA就是DeferredShadinginS.T.A.L.K.E.R提出的方法,根据“邻居像素”的depth和normal的差异程度做一个边缘检测,每个像素可以得到一个权重,表示“像边缘的程度”:

根据这个权重,就可以把邻居像素的颜色拿来插值,得到AA的效果

在GPUGems3第19章DeferredShadinginTabulaRasa中,NCsoft对EdgeAA做出了一些小改进,边缘检测不再依赖于图像分辨率,且更加稳定。

DirectionallyEdgeAA

EdgeAA开创了postprocessAA的时代,但EdgeAA暂时在质量上还无法与硬件式AA相抗衡。

随后,AMD在HPG09上的论文ADirectionallyAdaptiveEdgeAnti-AliasingFilter改进了EdgeAA,不再采用独立的edge点来决定AA混合的方式,而是根据edge点周围的状况确定出isoline(等值线),然后根据isoline的垂直方向来确定混合的方向。

这样一个边界就会沿着朝向来混合,还原出更加精确的sub-pixel信息。

这种方法进入了AMD的驱动,只要打开AdaptiveAA就会自动启用。

MLAA(MorphologicalAntialiasing)形态抗锯齿

AdaptiveEdgeAA提出了以线代替点的研究方向,但isoline的计算量毕竟比较大,启用了之后对渲染性能下降明显。

Intel推出的完全基于CPU处理的抗锯齿解决方案——MorphologicalAntialiasing再次在这个方向作出了努力。

它不计算isoline,而是把edge分门别类,总结成Z、U、L等几种特定的形状,而Z和U都可以分解成L。

Z和U都可以分解成L

最终根据L划出一个三角形,确定混合区域,这样就省去了所有繁重的计算,提高AA速度。

在AMD较新的驱动里,MLAA取代了DirectionallyEdgeAA成为AdaptiveAA的首选。

MLAA的框架又派生出多个不同的方法:

CPUMLAA

Intel在HPG09上的MorphologicalAntialiasing一文是在CPU上实现的。

代码用了非常深的分支来判断edge形状,完全是针对CPU优化的,不适合GPU硬件,也不适合实时渲染的情况。

GPUMLAA

SIGGRAPH2010poster的PracticalmorphologicalantialiasingontheGPU,通过建立SAT来判断edge形状,需要log(width)+log(height)个pass。

在确定了L之后,需要查询一个预计算的512×

512R32F的纹理,里面每个texel对应了一个特定大小的L所需要混合的面积。

也就是边长最大是512个像素。

可以看出这种方法非常暴力,虽然可能比读回CPU快,但开销还是很大。

Jimenez’sMLAA

GPUPro2里的文章PracticalMorphologicalAnti-Aliasing提出了一个更实用的GPUMLAA方法,命名为Jimenez’sMLAA以示区分。

在这种MLAA里,Z和U不需要分解成更简单的L,直接用一个预计算的表来做查询。

每个像素根据自己在形状里的位置在查找表里寻找需要混合的各个像素。

720p的分辨率下,这种方法在一般的情况下能达到Xbox360上3.79ms,Geforce9800GTX+上0.44ms。

同等条件下8xMSAA需要5ms。

FXAA(FastApproximateAnti-Aliasing)

NVIDIA在GraphicsSDK11里面提供了一个称为FastApproximateAnti-Aliasing的方法。

该方法非常接近MLAA,但只识别长边,而不识别形状。

有了长边之后,就可以根据边和像素的求交来估算每个像素中sub-pixel的覆盖率,并进行AA混合。

后来TimothyLottes还发展出了FXAAII,质量有所下降,速度提高了,在Xbox360上,720p的分辨率可以做到2.0ms。

NoAA与FXAA的对比

DLAA(DirectionallyLocalizedAnti-Aliasing)

另一个在GDC11上公开的AA方法称为DirectionallyLocalizedAnti-Aliasing(前面介绍的Jimenez’sMLAA和FXAA也在GDC11的时候公开的)。

这种方法比较特殊,它在垂直方向模糊后的图像上做水平方向边缘检测,得到的结果合成回去就得到AA后的图像。

左图为AA之前的,右图是经过DLAA的

DLAA的执行效率还是比较快的,据在Xbox360上的测试来看,720p需要2.2ms。

总之:

后处理式AA的方法就是试图通过Pixel像素信息估计出Sub-pixel级别的几何,然而再做AA。

不同的是:

EdgeAA是通过独立点来估计,MLAA是通过L形来估计,FXAA和DLAA是通过线段来估计。

HybridAA

前面我们介绍了硬件式AA和后处理式AA抗锯齿方法,那么有没有将两者结合起来的解决方案了?

这正是下面要讲的HybridAA(混合式AA)。

我们先对MSAA的计算浪费这一事实进行下对比说明:

MSAA需要计算的edge

真正需要计算AA的edge

通过上面的对比图,我们很直观的感受到:

真正需要进行AA处理的Edge边缘其实并不是特别多,而MSAA实际上是将很多的计算量浪费在了实际并不需要AA的像素上,所以采样点越多,浪费越严重。

透过前面对后处理式AA的介绍,我们知道:

而HybridAA的思想即是:

干脆就先直接存出sub-pixel的几何,没必要进行“估计”。

SRAA(SubpixelReconstructionAnti-Aliasing)

SRAA是NVIDIA的研究员在I3D2011上发表的新方法。

它寄予的事实是,shading的变化频率一般低于几何的变化频率,所以可以在较低分辨率上shading,而用较高分辨率恢复几何。

SRAA的基本流程为,在DeferredShading的框架中,渲染一个高分辨率(或者带MSAA)的G-Buffer,但在shading的时候仅在普通的分辨率(或者没有MSAA)的情况下做。

累积的结果通过G-Buffer重建sub-pixel信息,来进行类似MLAA的AA计算。

这种方法结合了MSAA和MLAA,优点是可以用较低的样本数做到较高的MSAA才能得到的效果,同时不增加shading的计算量。

SRAA由于原理问题,只能用在Deferred框架中。

SubpixelReconstructionAnti-Aliasing

GPAA(GeometricPost-processAnti-Aliasing)

GPAA是Humus独立提出来的AA方法。

基本思路是在渲染几何之后再次用线框模式渲染一遍,这时候可以得到每个三角形在每个pixel的覆盖率:

GeometricPost-processAnti-Aliasing

通过这个覆盖率,计算AA就显得相当容易了,结果比较如下:

对比

这种方法的代价是多了一遍线框渲染,但可以用于Forward和Deferred两种框架。

遗憾的是,Humus的twitter上说这种方法实际上在1996年就被别人申请专利了。

AdaptiveAA

Intel在SIGGRAPH2010的courseDeferredRenderingforCurrentandFutureRenderingPipelines上提到了一种很简单很暴力的AA方法,在edge的地方per-sample计算,在non-edge的地方per-pixel计算。

和基于postprocess的方法一样,这需要执行一个边缘检测,并在stencil(模板)中标记出来,然后就可以分别计算了。

下图中红线标记的地方就是检测出来的edge:

红线标记的地方就是检测出来的edge

这种方法的结果会和SSAA一样,同时没有MSAA重复计算的毛病。

HybridAA可以说是hardwareAA和postprocessAA这两种AA方案的折中选择。

优点是可以用低于hardwareAA的硬件开销和计算量达到一样的效果,缺点是需要修改原有的图形渲染流水线。

总结:

AA抗锯齿就是为了降低"

方块感"

通过前面系统的介绍,想必玩家朋友已经对AA抗锯齿有了更深入的认识。

锯齿的产生是因为在3D图像中,受分辨率的制约,物体边缘总会或多或少的呈现出一些不够平滑的“棱角”,而抗锯齿就是之通过对图像边缘进行柔化处理,使图像边缘看起来更平滑,更接近实物的物体。

所以AA抗锯齿是一种提高画质并使之柔和的渲染方法。

最后我们总结下本文的核心知识点:

一、AA抗锯齿的作用:

将图像边缘及其两侧的像素颜色进行混合,然后用新生成的具有混合特性的点来替换原来位置上的点以达到柔化物体外形、消除锯齿的效果;

二、我们通常所说的几倍抗锯齿,指的是是一个像素点内的采样点数;

三、AA抗锯齿按照技术发展的演进历程来分类有:

HardwareAA、PostprocessAA和HybridAA;

四、HardwareAA(硬件式AA)特点:

原理简单直接,但硬件资源消耗较大。

该类别的AA技术:

SSAA、MSAA和CSAA等;

五、PostprocessAA(后处理式AA)特点:

EdgeAA、DirectionallyEdgeAA、MLAA和DLAA等;

六、HybridAA(混合式AA)特点:

SRAA、GPAA和AdaptiveAA等;

注:

本文所参考的文章有:

KlayGE游戏引擎的《Anti-alias的前世今生》,建议对游戏引擎感兴趣的朋友可以去多关注下。

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 初中教育

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1