收藏 分享(赏)

线性邻域滤波:方框滤波、均值滤波与高斯滤波.doc

上传人:精品资料 文档编号:9998816 上传时间:2019-09-26 格式:DOC 页数:37 大小:3.80MB
下载 相关 举报
线性邻域滤波:方框滤波、均值滤波与高斯滤波.doc_第1页
第1页 / 共37页
线性邻域滤波:方框滤波、均值滤波与高斯滤波.doc_第2页
第2页 / 共37页
线性邻域滤波:方框滤波、均值滤波与高斯滤波.doc_第3页
第3页 / 共37页
线性邻域滤波:方框滤波、均值滤波与高斯滤波.doc_第4页
第4页 / 共37页
线性邻域滤波:方框滤波、均值滤波与高斯滤波.doc_第5页
第5页 / 共37页
点击查看更多>>
资源描述

1、【OpenCV 八】线性邻域滤波:方框滤波、均值滤波与高斯滤波本篇文章中,我们一起仔细探讨了 OpenCV 图像处理技术中比较热门的图像滤波操作。图像滤波系列文章浅墨准备花两次更新的时间来讲,此为上篇,为大家剖析了“方框滤波“,”均值滤波“和”高斯滤波“三种常见线性邻域滤波操作。而作为非线性滤波的“中值滤波”和“双边滤波”,留待我们下次剖析。在这里给大家一个指引,如果是单单想要掌握这篇文章中讲解的 OpenCV 线性滤波相关的三个函数:boxFilter,blur 和 GaussianBlur 的使用方法的话,直接看第三部分“浅出”和第四部分“实例”就行。在以后写的 OpenCV 系列文章中,

2、浅墨暂且准备将每篇博文中知识点都分成原理、深入、浅出和实例四大部分来讲解,第一部分为和图像处理中线性滤波相关的理论,第二部分“深入”部分主要深入 OpenCV 内部,带领大家领略 OpenCV 的开源魅力,进行 OpenCV 相关源码的剖析,做到对 OpenCV 理解深刻,做一个高端大气的 OpenCV 使用者。第三部分“浅出”主要教会大家如何快速上手当前文章中介绍的相关 OpenCV API 函数。而在第四部分,浅墨会为大家准备一个和本篇文章相关的详细注释的综合实例程序。给出本篇万字文章的结构脉络:一、理论相关图像处理概念介绍二、深入OpenCV 源码讲解三、浅出API 函数讲解四、实例详细

3、注释的博文配套程序1、 理论与概念讲解关于平滑处理“平滑处理“(smoothing)也称 “模糊处理”(bluring),是一项简单且使用频率很高的图像处理方法。平滑处理的用途有很多,最常见的是用来减少图像上的噪点或者失真。在涉及到降低图像分辨率时,平滑处理是非常好用的方法。图像滤波与滤波器图像滤波,即在尽量保留图像细节特征的条件下对目标图像的噪声进行抑制,是图像预处理中不可缺少的操作,其处理效果的好坏将直接影响到后续图像处理和分析的有效性和可靠性。消除图像中的噪声成分叫作图像的平滑化或滤波操作。信号或图像的能量大部分集中在幅度谱的低频和中频段是很常见的,而在较高频段,感兴趣的信息经常被噪声淹

4、没。因此一个能降低高频成分幅度的滤波器就能够减弱噪声的影响。图像滤波的目的有两个:一是抽出对象的特征作为图像识别的特征模式;另一个是为适应图像处理的要求,消除图像数字化时所混入的噪声。滤波处理的要求也有两条:一是不能损坏图像的轮廓及边缘等重要信息;二是使图像清晰视觉效果好。平滑滤波是低频增强的空间域滤波技术。它的目的有两类:一类是模糊;另一类是消除噪音。(各种“两“ ,:)空间域的平滑滤波一般采用简单平均法进行,就是求邻近像元点的平均亮度值。邻域的大小与平滑的效果直接相关,邻域越大平滑的效果越好,但邻域过大,平滑会使边缘信息损失的越大,从而使输出的图像变得模糊,因此需合理选择邻域的大小。关于滤

5、波器,一种形象的比喻法是:我们可以把滤波器想象成一个包含加权系数的窗口,当使用这个滤波器平滑处理图像时,就把这个窗口放到图像之上,透过这个窗口来看我们得到的图像。滤波器的种类有很多, 在新版本的 OpenCV 中,提供了如下五种常用的图像平滑处理操作方法,且他们分别被封装在单独的函数中,使用起来非常方便:方框滤波boxblur 函数均值滤波(邻域平均滤波)blur 函数高斯滤波GaussianBlur 函数中值滤波medianBlur 函数双边滤波bilateralFilter 函数今天我们要讲解的是作为线性滤波的方框滤波,均值滤波和高斯滤波。两种非线性滤波操作中值滤波和双边滤波,我们留待下次

6、讲解。对线性滤波器的简介 线性滤波器:线性滤波器经常用于剔除输入信号中不想要的频率或者从许多频率中选择一个想要的频率。几种常见的线性滤波器:允许低频率通过的低通滤波器。允许高频率通过的高通滤波器。允许一定范围频率通过的带通滤波器。阻止一定范围频率通过并且允许其它频率通过的带阻滤波器。允许所有频率通过、仅仅改变相位关系的全通滤波器。阻止一个狭窄频率范围通过的特殊带阻滤波器,陷波滤波器(Band-stop filter)。关于滤波和模糊关于滤波和模糊,大家往往在初次接触的时候会弄混淆,“一会儿说滤波,一会儿又说模糊,什么玩意儿啊”。我们上文已经提到过,滤波是将信号中特定波段频率滤除的操作,是抑制和

7、防止干扰的一项重要措施。为了方便说明,就拿我们经常用的高斯滤波来作例子吧。我们知道,滤波可分低通滤波和高通滤波两种。而高斯滤波是指用高斯函数作为滤波函数的滤波操作,至于是不是模糊,要看是高斯低通还是高斯高通,低通就是模糊,高通就是锐化。其实说白了是很简单的,对吧:高斯滤波是指用高斯函数作为滤波函数的滤波操作。高斯模糊就是高斯低通滤波。邻域算子与线性邻域滤波邻域算子(局部算子)是利用给定像素周围的像素值的决定此像素的最终输出值的一种算子。而线性邻域滤波是一种常用的邻域算子,像素的输出值取决于输入像素的加权和,具体过程如下图。邻域算子除了用于局部色调调整以外,还可以用于图像滤波,实现图像的平滑和锐

8、化,图像边缘增强或者图像噪声的去除。本篇文章,我们介绍的主角是线性邻域滤波算子,即用不同的权重去结合一个小邻域内的像素,来得到应有的处理效果。图注:邻域滤波(卷积):左边图像与中间图像的卷积产生右边图像。目标图像中蓝色标记的像素是利用原图像中红色标记的像素计算得到的。线性滤波处理的输出像素值 是输入像素值 的加权和 :其中的加权和为 ,我们称其为“核”,滤波器的加权系数,即滤波器的“滤波系数”。上面的式子可以简单写作: 其中 f 表示输入像素值,h 表示加权系数“核“,g 表示输出像素值。在新版本的 OpenCV 中,提供了如下三种常用的线性滤波操作,他们分别被封装在单独的函数中,使用起来非常

9、方便:方框滤波boxblur 函数均值滤波blur 函数高斯滤波GaussianBlur 函数方框滤波(box Filter)方框滤波(box Filter)被封装在一个名为 boxblur 的函数中,即 boxblur 函数的作用是使用方框滤波器(box filter)来模糊一张图片,从 src 输入,从 dst 输出。函数原型如下:cpp view plain copy print?C+: void boxFilter(InputArray src,OutputArray dst, int ddepth, Size ksize, Point anchor=Point(-1,-1), boo

10、lnormalize=true, int borderType=BORDER_DEFAULT ) 参数详解:第一个参数,InputArray 类型的 src,输入图像,即源图像,填 Mat 类的对象即可。该函数对通道是独立处理的,且可以处理任意通道数的图片,但需要注意,待处理的图片深度应该为 CV_8U, CV_16U, CV_16S, CV_32F 以及 CV_64F 之一。第二个参数,OutputArray 类型的 dst,即目标图像,需要和源图片有一样的尺寸和类型。第三个参数,int 类型的 ddepth,输出图像的深度,-1 代表使用原图深度,即 src.depth()。第四个参数,S

11、ize 类型(对 Size 类型稍后有讲解)的 ksize,内核的大小。一般这样写 Size( w,h )来表示内核的大小( 其中,w 为像素宽度,h 为像素高度)。Size (3,3)就表示 3x3 的核大小,Size (5,5)就表示 5x5 的核大小第五个参数,Point 类型的 anchor,表示锚点(即被平滑的那个点),注意他有默认值Point(-1,-1)。如果这个点坐标是负值的话,就表示取核的中心为锚点,所以默认值 Point(-1,-1)表示这个锚点在核的中心。第六个参数,bool 类型的 normalize,默认值为 true,一个标识符,表示内核是否被其区域归一化(norm

12、alized)了。第七个参数,int 类型的 borderType,用于推断图像外部像素的某种边界模式。有默认值BORDER_DEFAULT,我们一般不去管它。boxFilter()函数方框滤波所用的核为:其中:其中 f 表示原图,h 表示核, g 表示目标图,当 normalize=true 的时候,方框滤波就变成了我们熟悉的均值滤波。也就是说,均值滤波是方框滤波归一化(normalized)后的特殊情况。其中,归一化就是把要处理的量都缩放到一个范围内,比如(0,1),以便统一处理和直观量化。而非归一化(Unnormalized)的方框滤波用于计算每个像素邻域内的积分特性,比如密集光流算法(

13、dense optical flow algorithms)中用到的图像倒数的协方差矩阵( covariance matrices of image derivatives)如果我们要在可变的窗口中计算像素总和,可以使用 integral()函数。均值滤波均值滤波,是最简单的一种滤波操作,输出图像的每一个像素是核窗口内输入图像对应像素的像素的平均值( 所有像素加权系数相等 ),其实说白了它就是归一化后的方框滤波。我们在下文进行源码剖析时会发现,blur 函数内部中其实就是调用了一下 boxFilter。下面开始讲均值滤波的内容吧。1)均值滤波的理论简析均值滤波是典型的线性滤波算法,主要方法为邻

14、域平均法,即用一片图像区域的各个像素的均值来代替原图像中的各个像素值。一般需要在图像上对目标像素给出一个模板(内核),该模板包括了其周围的临近像素(比如以目标像素为中心的周围 8(3x3-1)个像素,构成一个滤波模板,即去掉目标像素本身)。再用模板中的全体像素的平均值来代替原来像素值。即对待处理的当前像素点(x,y ),选择一个模板,该模板由其近邻的若干像素组成,求模板中所有像素的均值,再把该均值赋予当前像素点(x,y),作为处理后图像在该点上的灰度个 g(x,y),即个 g(x,y )=1/mf (x ,y),其中 m 为该模板中包含当前像素在内的像素总个数。2)均值滤波的缺陷均值滤波本身存

15、在着固有的缺陷,即它不能很好地保护图像细节,在图像去噪的同时也破坏了图像的细节部分,从而使图像变得模糊,不能很好地去除噪声点。3)在 OpenCV 中使用均值滤波blur 函数blur 函数的作用是,对输入的图像 src 进行均值滤波后用 dst 输出。blur 函数文档中,给出的其核是这样的:这个内核一看就明了,就是在求均值,即 blur 函数封装的就是均值滤波。blur 函数的原型:cpp view plain copy print?C+: void blur(InputArray src, OutputArraydst, Size ksize, Point anchor=Point(-1

16、,-1), int borderType=BORDER_DEFAULT ) 第一个参数,InputArray 类型的 src,输入图像,即源图像,填 Mat 类的对象即可。该函数对通道是独立处理的,且可以处理任意通道数的图片,但需要注意,待处理的图片深度应该为 CV_8U, CV_16U, CV_16S, CV_32F 以及 CV_64F 之一。第二个参数,OutputArray 类型的 dst,即目标图像,需要和源图片有一样的尺寸和类型。比如可以用 Mat:Clone,以源图片为模板,来初始化得到如假包换的目标图。第三个参数,Size 类型(对 Size 类型稍后有讲解)的 ksize,内核

17、的大小。一般这样写 Size( w,h )来表示内核的大小( 其中,w 为像素宽度, h 为像素高度)。Size (3,3)就表示 3x3 的核大小,Size (5,5)就表示 5x5 的核大小第四个参数,Point 类型的 anchor,表示锚点(即被平滑的那个点),注意他有默认值Point(-1,-1)。如果这个点坐标是负值的话,就表示取核的中心为锚点,所以默认值 Point(-1,-1)表示这个锚点在核的中心。第五个参数,int 类型的 borderType,用于推断图像外部像素的某种边界模式。有默认值BORDER_DEFAULT,我们一般不去管它。高斯滤波1)高斯滤波的理论简析高斯滤波

18、是一种线性平滑滤波,适用于消除高斯噪声,广泛应用于图像处理的减噪过程。通俗的讲,高斯滤波就是对整幅图像进行加权平均的过程,每一个像素点的值,都由其本身和邻域内的其他像素值经过加权平均后得到。高斯滤波的具体操作是:用一个模板(或称卷积、掩模)扫描图像中的每一个像素,用模板确定的邻域内像素的加权平均灰度值去替代模板中心像素点的值。大家常常说高斯滤波最有用的滤波操作,虽然它用起来,效率往往不是最高的。高斯模糊技术生成的图像,其视觉效果就像是经过一个半透明屏幕在观察图像,这与镜头焦外成像效果散景以及普通照明阴影中的效果都明显不同。高斯平滑也用于计算机视觉算法中的预先处理阶段,以增强图像在不同比例大小下

19、的图像效果(参见尺度空间表示以及尺度空间实现)。从数学的角度来看,图像的高斯模糊过程就是图像与正态分布做卷积。由于正态分布又叫作高斯分布,所以这项技术就叫作高斯模糊。图像与圆形方框模糊做卷积将会生成更加精确的焦外成像效果。由于高斯函数的傅立叶变换是另外一个高斯函数,所以高斯模糊对于图像来说就是一个低通滤波操作。高斯滤波器是一类根据高斯函数的形状来选择权值的线性平滑滤波器。高斯平滑滤波器对于抑制服从正态分布的噪声非常有效。一维零均值高斯函数为:其中,高斯分布参数 Sigma 决定了高斯函数的宽度。对于图像处理来说,常用二维零均值离散高斯函数作平滑滤波器。二维高斯函数为:2)在 OpenCV 中使

20、用高斯滤波GaussianBlur 函数GaussianBlur 函数的作用是用高斯滤波器来模糊一张图片,对输入的图像 src 进行高斯滤波后用 dst 输出。它将源图像和指定的高斯核函数做卷积运算,并且支持就地过滤(In-placefiltering)。cpp view plain copy print?C+: void GaussianBlur(InputArray src,OutputArray dst, Size ksize, double sigmaX, double sigmaY=0, intborderType=BORDER_DEFAULT ) 第一个参数,InputArray

21、类型的 src,输入图像,即源图像,填 Mat 类的对象即可。它可以是单独的任意通道数的图片,但需要注意,图片深度应该为 CV_8U,CV_16U, CV_16S, CV_32F 以及 CV_64F 之一。第二个参数,OutputArray 类型的 dst,即目标图像,需要和源图片有一样的尺寸和类型。比如可以用 Mat:Clone,以源图片为模板,来初始化得到如假包换的目标图。第三个参数,Size 类型的 ksize 高斯内核的大小。其中 ksize.width 和 ksize.height 可以不同,但他们都必须为正数和奇数。或者,它们可以是零的,它们都是由 sigma 计算而来。第四个参数

22、,double 类型的 sigmaX,表示高斯核函数在 X 方向的的标准偏差。第五个参数,double 类型的 sigmaY,表示高斯核函数在 Y 方向的的标准偏差。若 sigmaY 为零,就将它设为 sigmaX,如果 sigmaX 和 sigmaY 都是 0,那么就由 ksize.width 和ksize.height 计算出来。为了结果的正确性着想,最好是把第三个参数 Size,第四个参数 sigmaX 和第五个参数sigmaY 全部指定到。第六个参数,int 类型的 borderType,用于推断图像外部像素的某种边界模式。有默认值BORDER_DEFAULT,我们一般不去管它。二、深

23、入OpenCV 源码剖析上一篇文章中我们已经和当前最新版的 OpenCV 的源码亲密接触过。 在这一部分中,浅墨将带领大家领略 OpenCV 的开源魅力,对 OpenCV 中本篇文章里讲解到线性滤波函数 boxFilter,blur 和 GaussianBlur 函数以及周边的涉及到的源码进行适当的剖析。这样,我们就可以对 OpenCV 有一个更加深刻的理解,成为一个高端大气的 OpenCV 使用者。OpenCV 中 boxFilter 函数源码解析我们可以在 OpenCV 的安装路径的 sourcesmodulesimgprocsrc 下的 smooth.cpp 源文件的第 711 行找到

24、boxFilter 函数的源代码。对应于浅墨将 OpenCV 2.4.8 安装在 D:Program Filesopencv 的路径下,那么,smooth.cpp 文件就在D:ProgramFilesopencvsourcesmodulesimgprocsrc 路径下。cpp view plain copy print?/-【 boxFilter()函数中文注释版源代码 】- / 代码作用:进行 box Filter 滤波操作的函数 / 说明:以下代码为来自于计算机开源视觉库 OpenCV 的官方源代码 / OpenCV 源代码版本:2.4.8 / 源码路径:opencvsourcesmodu

25、lesimgprocsrcsmooth.cpp / 源文件中如下代码的起始行数:711 行 / 中文注释 by 浅墨 /- void cv:boxFilter( InputArray _src,OutputArray _dst, int ddepth, Size ksize, Point anchor, bool normalize, int borderType) Mat src = _src.getMat();/拷贝源图的形参 Mat 数据到临时变量,用于稍后的操作 int sdepth =src.depth(), cn = src.channels();/定义 int 型临时变量,代表源

26、图深度的 sdepth,源图通道的引用 cn /处理 ddepth 小于零的情况 if( ddepth f = createBoxFilter( src.type(), dst.type(), ksize, anchor,normalize, borderType ); f-apply( src, dst ); 其中的 Ptr 是用来动态分配的对象的智能指针模板类。可以发现,函数的内部代码思路是很清晰的,先拷贝源图的形参 Mat 数据到临时变量,定义一些临时变量,在处理 ddepth小于零的情况,接着处理 borderType 不为 BORDER_CONSTANT 且 normalize 为真

27、的情况,最终调用 FilterEngine 滤波引擎创建一个 BoxFilter,正式开始滤波操作。这里的 FilterEngine 是 OpenCV 图像滤波功能的核心引擎,我们有必要详细剖析看其源代码。FilterEngine 类解析OpenCV 图像滤波核心引擎FilterEngine 类是 OpenCV 关于图像滤波的主力军类,OpenCV 图像滤波功能的核心引擎。各种滤波函数比如 blur, GaussianBlur,到头来其实是就是在函数末尾处定义了一个Ptr类型的 f,然后 f-apply( src, dst )了一下而已。这个类可以把几乎是所有的滤波操作施加到图像上。它包含了所

28、有必要的中间缓存器。有很多和滤波相关的 create 系函数的返回值直接就是 Ptr。比如cv:createSeparableLinearFilter(),cv:createLinearFilter(),cv:createGaussianFilter(), cv:createDerivFilter(),cv:createBoxFilter() 和 cv:createMorphologyFilter().,这里给出其中一个函数的原型吧:cpp view plain copy print?PtrcreateLinearFilter(int srcType, int dstType, InputAr

29、ray kernel, Point_anchor=Point(-1,-1), double delta=0, int rowBorderType=BORDER_DEFAULT, intcolumnBorderType=-1, const Scalar /完整的构造函数。 _filter2D 、_rowFilter 和 _columnFilter 之一,必须为非空 FilterEngine(const Ptr /默认析构函数 virtual FilterEngine(); /重新初始化引擎。释放之前滤波器申请的内存。 void init(const Ptr /开始对指定了 ROI 区域和尺寸的图

30、片进行滤波操作 virtual int start(Size wholeSize, Rect roi, int maxBufRows=-1); /开始对指定了 ROI 区域的图片进行滤波操作 virtual int start(const Mat /处理图像的下一个 srcCount 行(函数的第三个参数) virtual int proceed(const uchar* src, int srcStep, int srcCount, uchar* dst, intdstStep); /对图像指定的 ROI 区域进行滤波操作,若 srcRoi=(0,0,-1,-1),则对整个图像进行滤波操作

31、virtual void apply( const Mat /如果滤波器可分离,则返回 true boolisSeparable() const return (const BaseFilter*)filter2D = 0; /返回输入和输出行数 int remainingInputRows() const; intremainingOutputRows() const; /一些成员参数定义 int srcType, dstType, bufType; Size ksize; Point anchor; int maxWidth; Size wholeSize; Rect roi; int d

32、x1, dx2; int rowBorderType, columnBorderType; vector borderTab; int borderElemSize; vector ringBuf; vector srcRow; vector constBorderValue; vector constBorderRow; int bufStep, startY, startY0, endY, rowCount, dstY; vector rows; Ptr filter2D; Ptr rowFilter; Ptr columnFilter; ; OpenCV 中 size 类型剖析size

33、类型我们也讲一下,通过转到定义,我们可以在opencvsourcesmodulescoreincludeopencv2corecore.hpp 路径下,对应于浅墨的OpenCV 安装路径,就是在D:ProgramFilesopencvsourcesmodulescoreincludeopencv2corecore.hpp 下,找到其原型声明:cpp view plain copy print?typedef Size_ Size2i; typedef Size2i Size; Size_ 是个模板类,在这里 Size_表示其类体内部的模板所代表的类型为 int。那这两句的意思,就是首先给已知的

34、数据类型 Size_起个新名字,叫 Size2i。然后又给已知的数据类型 Size2i 起个新名字,叫 Size。所以,连起来就是,Size_、Size2i、Size 这三个类型名等价。然后我们追根溯源,找到 Size_模板类的定义:cpp view plain copy print?/-【 Size_类中文注释版源代码】- / 代码作用:作为尺寸相关数据结构的 Size_ 模板类 / 说明:以下代码为来自于计算机开源视觉库 OpenCV 的官方源代码 / OpenCV 源代码版本:2.4.8 / 源码路径:opencvsourcesmodulescoreincludeopencv2corec

35、ore.hpp / 源文件中如下代码的起始行数:816 行 / 中文注释 by 浅墨 /- template class Size_ public: typedef _Tp value_type; /不同的构造函数定义 Size_(); Size_(_Tp _width, _Tp _height); Size_(const Size_ Size_(const CvSize Size_(const CvSize2D32f Size_(const Point_ Size_ /区域(width*height) _Tp area() const; /转化另一种数据类型。 template operat

36、or Size_() const; /转换为旧式的 OpenCV 类型. operator CvSize() const; operator CvSize2D32f() const; _Tp width, height; /宽度和高度,常用属性 ; 可以看到 Size_模板类的内部又是重载了一些构造函数以满足我们的需要,其中,我们用得最多的是如下这个构造函数:cpp view plain copy print?Size_(_Tp _width, _Tp _height); 另外,代码末尾定义了模板类型的宽度和高度:cpp view plain copy print?_Tp width, hei

37、ght; /宽度和高度 于是我们可以用 XXX.width 和 XXX.height 来分别表示其宽度和高度。给大家一个示例,方便理解:cpp view plain copy print?Size(5, 5);/构造出的 Size 宽度和高度都为 5,即 XXX.width 和 XXX.height 都为 5 OpenCV 中 blur 函数源码剖析我们可以在 OpenCV 的安装路径的 sourcesmodulesimgprocsrc 下的 smooth.cpp 源文件中找到 blur 的源代码。对应于浅墨将 OpenCV 2.4.8 安装在 D:Program Filesopencv 下,

38、那么,smooth.cpp 文件就在 D:ProgramFilesopencvsourcesmodulesimgprocsrc 路径下。一起来看一下 OpenCV 中 blur 函数定义的真面目:cpp view plain copy print?/-【 blur()函数中文注释版源代码】- / 代码作用:进行 blur 均值滤波操作的函数 / 说明:以下代码为来自于计算机开源视觉库 OpenCV 的官方源代码 / OpenCV 源代码版本:2.4.8 / 源码路径:opencvsourcesmodulesimgprocsrcsmooth.cpp / 源文件中如下代码的起始行数:738 行 /

39、 中文注释 by 浅墨 /- void cv:blur(InputArray src, OutputArray dst, Size ksize, Point anchor, int borderType ) /调用 boxFilter 函数进行处理 boxFilter( src, dst, -1, ksize, anchor, true, borderType ); 可以看到在 blur 函数内部就是调用了一个 boxFilter 函数,且第六个参数为 true,即我们上文所说的 normalize=true,即均值滤波是均一化后的方框滤波。OpenCV 中 GaussianBlur 函数源码

40、剖析最后,我们看一下 OpenCV 中 GaussianBlur 函数源代码:cpp view plain copy print?/-【 GaussianBlur()函数中文注释版源代码】- / 代码作用:封装高斯滤波的 GaussianBlur()函数 / 说明:以下代码为来自于计算机开源视觉库 OpenCV 的官方源代码 / OpenCV 源代码版本:2.4.8 / 源码路径:opencvsourcesmodulesimgprocsrcsmooth.cpp / 源文件中如下代码的起始行数:832 行 / 中文注释 by 浅墨 /- void cv:GaussianBlur( InputAr

41、ray _src,OutputArray _dst, Size ksize, double sigma1, doublesigma2, int borderType ) /拷贝形参 Mat 数据到临时变量,用于稍后的操作 Mat src = _src.getMat(); _dst.create( src.size(), src.type() ); Mat dst =_dst.getMat(); /处理边界选项不为 BORDER_CONSTANT 时的情况 if( borderType != BORDER_CONSTANT ) if( src.rows = 1 ) ksize.height =

42、1; if( src.cols = 1 ) ksize.width = 1; /若 ksize 长宽都为 1,将源图拷贝给目标图 if( ksize.width = 1 return; /若之前有过 HAVE_TEGRA_OPTIMIZATION 优化选项的定义,则执行宏体中的 tegra 优化版函数并返回 #ifdef HAVE_TEGRA_OPTIMIZATION if(sigma1 = 0 #endif /如果 HAVE_IPP int bufSize = 0; ippiFilterGaussGetBufferSize_32f_C1R(roi, ksize.width, AutoBuff

43、er buf(bufSize+128); if( ippiFilterGaussBorder_32f_C1R(const Ipp32f *)src.data,(int)src.step, (Ipp32f *)dst.data, (int)dst.step, roi,ksize.width, (Ipp32f)sigma1, (IppiBorderType)borderType, 0.0, alignPtr( #endif /调动滤波引擎,正式进行高斯滤波操作 Ptr f = createGaussianFilter( src.type(), ksize,sigma1, sigma2, borde

44、rType ); f-apply( src, dst ); 三、浅出线性滤波函数快速上手攻略这一部分的内容就是为了大家能快速上手 boxFilter、blur 和 GaussianBlur 这三个函数所准备的。还等什么呢,开始吧。boxFilter 函数 方框滤波boxFilter 的函数作用是使用方框滤波(box filter)来模糊一张图片,由 src 输入,dst 输出。函数原型如下:cpp view plain copy print?C+: void boxFilter(InputArray src,OutputArray dst, int ddepth, Size ksize, Po

45、int anchor=Point(-1,-1), boolnormalize=true, int borderType=BORDER_DEFAULT ) 参数详解如下:第一个参数,InputArray 类型的 src,输入图像,即源图像,填 Mat 类的对象即可。该函数对通道是独立处理的,且可以处理任意通道数的图片,但需要注意,待处理的图片深度应该为 CV_8U, CV_16U, CV_16S, CV_32F 以及 CV_64F 之一。第二个参数,OutputArray 类型的 dst,即目标图像,需要和源图片有一样的尺寸和类型。第三个参数,int 类型的 ddepth,输出图像的深度,-1

46、代表使用原图深度,即 src.depth()。第四个参数,Size 类型的 ksize,内核的大小。一般这样写 Size( w,h )来表示内核的大小( 其中,w 为像素宽度, h 为像素高度 )。Size(3,3)就表示 3x3 的核大小,Size(5,5)就表示5x5 的核大小第五个参数,Point 类型的 anchor,表示锚点(即被平滑的那个点),注意他有默认值Point(-1,-1)。如果这个点坐标是负值的话,就表示取核的中心为锚点,所以默认值 Point(-1,-1)表示这个锚点在核的中心。第六个参数,bool 类型的 normalize,默认值为 true,一个标识符,表示内核是否被其区域归一化(normalized)了。第七个参数,int 类型的 borderType,用于推断图像外部像素的某种边界模式。有默认值BORDER_DEFAULT,我们一般不去管它。调用代码示范如下: cpp view plain copy print?/载入原图 Mat image=imread(“2.jpg“); /进行均值滤波操作 Mat out; boxFilter(image, out, -1,Size(5, 5); 用上面三句核心代码架起来的完整程

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

当前位置:首页 > 企业管理 > 管理学资料

本站链接:文库   一言   我酷   合作


客服QQ:2549714901微博号:道客多多官方知乎号:道客多多

经营许可证编号: 粤ICP备2021046453号世界地图

道客多多©版权所有2020-2025营业执照举报