0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

图像处理基础自适应中值滤波器(基于OpenCV实现)

Dbwd_Imgtec 来源:未知 作者:邓佳佳 2018-03-05 17:02 次阅读

前言

本文主要介绍了自适应的中值滤波器,并基于OpenCV实现了该滤波器,并且将自适应的中值滤波器和常规的中值滤波器对不同概率的椒盐噪声的过滤效果进行了对比。最后,对中值滤波器的优缺点了进行了总结。

空间滤波器

一个空间滤波器包括两个部分:

• 一个邻域,滤波器进行操作的像素集合,通常是一个矩形区域

• 对邻域中像素进行的操作

一个滤波器就是在选定的邻域像素上执行预先定义好的操作产生新的像素,并用新的像素替换掉原来像素形成新的图像。通常,也可以将滤波器称之为核(kernel),模板(template)或者窗口(window)。

根据预定义的操作,可以将滤波器分为:

• 线性滤波器• 非线性滤波器

而根据滤波器最终对图像造成的影响,可以将滤波器分为:

• 平滑滤波器 ,通常用于模糊图像或者去除图像中的噪声• 锐化滤波器,突出图像中的边缘细节部分

中值滤波器 Median Filter

中值滤波器是一种常用的非线性滤波器,其基本原理是选择待处理像素的一个邻域中各像素值的中值来代替待处理的像素,其主要功能是像素的灰度值与周围像素比较接近,从而消除孤立的噪声点,所以中值滤波器能够很好的消除椒盐噪声。不仅如此,中值滤波器在消除噪声的同时,还能有效的保护图像的边界信息,不会对图像造成很大的模糊(相比于均值滤波器)。

中值滤波器的效果受滤波窗口尺寸的影响较大,在消除噪声和保护图像的细节存在着矛盾:滤波窗口较小,则能很好的保护图像中的某些细节,但对噪声的过滤效果就不是很好;反之,窗口尺寸较大有较好的噪声过滤效果,但是会对图像造成一定的模糊。另外,根据中值滤波器原理,如果在滤波窗口内的噪声点的个数大于整个窗口内像素的个数,则中值滤波就不能很好的过滤掉噪声。

自适应中值滤波器 Adaptive Median Filter

上面提到常规的中值滤波器,在噪声的密度不是很大的情况下(根据经验,噪声的出现的概率小于0.2),效果不错。但是当概率出现的概率较高时,常规的中值滤波的效果就不是很好了。有一个选择就是增大滤波器的窗口大小,这虽然在一定程度上能解决上述的问题,但是会给图像造成较大的模糊。

常规的中值滤波器的窗口尺寸是固定大小不变的,就不能同时兼顾去噪和保护图像的细节。这时就要寻求一种改变,根据预先设定好的条件,在滤波的过程中,动态的改变滤波器的窗口尺寸大小,这就是自适应中值滤波器 Adaptive Median Filter。在滤波的过程中,自适应中值滤波器会根据预先设定好的条件,改变滤波窗口的尺寸大小,同时还会根据一定的条件判断当前像素是不是噪声,如果是则用邻域中值替换掉当前像素;不是,则不作改变。

自适应中值滤波器有三个目的:

• 滤除椒盐噪声• 平滑其他非脉冲噪声• 尽可能的保护图像中细节信息,避免图像边缘的细化或者粗化。

自使用中值滤波算法描述

自适应滤波器不但能够滤除概率较大的椒盐噪声,而且能够更好的保护图像的细节,这是常规的中值滤波器做不到的。自适应的中值滤波器也需要一个矩形的窗口SxySxy,和常规中值滤波器不同的是这个窗口的大小会在滤波处理的过程中进行改变(增大)。需要注意的是,滤波器的输出是一个像素值,该值用来替换点(x,y)(x,y)处的像素值,点(x,y)(x,y)是滤波窗口的中心位置。

在描述自适应中值滤波器时需要用到如下的符号:

• Zmin= Sxy中的最小灰度值• Zmax= Sxy中的最大灰度值• Zmed= Sxy中的灰度值的中值• Zxy表示坐标(x,y)处的灰度值• Smax= Sxy允许的最大窗口尺寸

自适应中值滤波器有两个处理过程,分别记为:A和B。

A:A1 = Zmed− ZminA2 = Zmed− Zmax如果A1 > 0 且 A2 < 0,跳转到 B;否则,增大窗口的尺寸如果增大后窗口的尺寸 ≤Smax,则重复A过程。否则,输出Zmed

B:B1 = Zxy− ZminB2 = Zxy− Zmax如果B1 > 0 且 B2 < 0,则输出Zxy否则输出Zmed

自适应中值滤波原理说明

过程A的目的是确定当前窗口内得到中值ZmedZmed是否是噪声。如果Zmin< Zmed < Zmax,则中值Zmed不是噪声,这时转到过程B测试,当前窗口的中心位置的像素Zxy是否是一个噪声点。如果Zmin < Zxy < Zmax,则Zxy不是一个噪声,此时滤波器输出Zxy;如果不满足上述条件,则可判定Zxy是噪声,这是输出中值Zmed(在A中已经判断出Zmed不是噪声)。

如果在过程A中,得到则Zmed不符合条件Zmin< Zmed < Zmax,则可判断得到的中值Zmed是一个噪声。在这种情况下,需要增大滤波器的窗口尺寸,在一个更大的范围内寻找一个非噪声点的中值,直到找到一个非噪声的中值,跳转到B;或者,窗口的尺寸达到了最大值,这时返回找到的中值,退出。

从上面分析可知,噪声出现的概率较低,自适应中值滤波器可以较快的得出结果,不需要去增加窗口的尺寸;反之,噪声的出现的概率较高,则需要增大滤波器的窗口尺寸,这也符合种中值滤波器的特点:噪声点比较多时,需要更大的滤波器窗口尺寸。

实现

有了算法的详细描述,借助于OpenCV对图像的读写,自适应中值滤波器实现起来也不是很困难。

首先定义滤波器最小的窗口尺寸以及最大的窗口尺寸。

要进行滤波处理,首先要扩展图像的边界,以便对图像的边界像素进行处理。copyMakeBorder根据选择的BorderTypes使用不同的值扩充图像的边界像素,具体可参考OpenCV的文档信息。

下面就是遍历图像的像素,对每个像素进行滤波处理。需要注意一点,不论滤波器多么的复杂,其每次的滤波过程,都是值返回一个值,来替换掉当前窗口的中心的像素值。函数adpativeProcess就是对当前像素的滤波过程,其代码如下:

首先,根据当前窗口的大小,取得所有像素值存放到vector中,然后对vector进行排序,取得像素的最小值、最大值和中值。然后测试当前取得的中值是否在(min,max)之间,如果是,则中值不是噪声点,则开始对当前像素值进行处理,判断其是否是噪声点。如果,测试当前已取得的中值是噪声点,则扩大窗口的尺寸,在更大的空间中重新寻找中值。

上面自适应中值滤波器实现起来比较简单,所以问题就来了:效率及其的低下。这里,这是对自适应中值滤波器的原理的学习,可以忽略这个不必要的细节。

结果对比

左边是添加概率为0.2的椒盐噪声,右边是原图。下面是使用常规的中值滤波和本文实现的自适应中值滤波器后的处理结果

左边是自适应中值滤波器(最小窗口为3,最大窗口为7)的结果,右图是常规中值滤波器(窗口大小为5)的结果。可以看出,无论是中值滤波还是自适应的中值滤波,都能过滤掉图像中的噪声,自适应中值滤波器的效果要好些,常规的还有一些噪声没有过滤掉。而且,常规的中值滤波器对图像造成的模糊较明显,而自适应中值滤波器很好的的保存了图像中的细节。

下面测试更大概率噪声下,两种滤波器的工作情况。噪声概率为0.4时,

可以看出,常规的中值滤波器已经不能很好的过滤掉噪声,而自适应的中值滤波还可以胜任。

中值滤波器总结

中值滤波器能够很好的滤除“椒盐”噪声。椒盐噪声是在图像上随机出现的孤立点,根据中值滤波器的原理,使用邻域像素的中值代替原像素,能够有效的消除这些孤立的噪声点。

和均值滤波器相比,中值滤波在消除噪声的同时,还能在很大程度保护图像的细节,不会造成很大的模糊。和常规的中值滤波器相比,自适应中值滤波器能够更好的保护图像中的边缘细节部分。

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 图像处理
    +关注

    关注

    27

    文章

    1274

    浏览量

    56540
  • OpenCV
    +关注

    关注

    29

    文章

    623

    浏览量

    41202

原文标题:图像处理基础(2):自适应中值滤波器(基于OpenCV实现)

文章出处:【微信号:Imgtec,微信公众号:Imagination Tech】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    滤波器的基本原理、分类及实现方式

    滤波器是一种信号处理设备,用于从信号中去除不需要的频率成分,保留所需的频率成分。在信号处理中,滤波器起着至关重要的作用。 滤波器的基本原理
    的头像 发表于 08-25 14:44 389次阅读

    中值滤波窗口大小对结果影响有哪些

    中值滤波是一种常用的数字滤波技术,它通过将信号中的每个点用其邻域内的中值替换来实现信号的平滑和去噪。中值
    的头像 发表于 07-29 09:10 562次阅读

    如何区分IIR滤波器和FIR滤波器

    IIR(无限脉冲响应)滤波器和FIR(有限脉冲响应)滤波器是数字信号处理领域中两种非常重要的滤波器类型。它们在许多应用中都发挥着关键作用,如音频处理
    的头像 发表于 07-19 09:44 2137次阅读

    高通滤波器和低通滤波器判别方法

    高通滤波器和低通滤波器是信号处理领域中非常重要的两种滤波器。它们在各种应用中都有广泛的应用,如音频处理
    的头像 发表于 07-15 11:15 778次阅读

    滤波器原理及其作用 滤波器电路图分析

    滤波器是一种电子设备或算法,用于从信号中去除不需要的频率成分,只保留所需的频率成分。滤波器在许多领域都有广泛应用,如通信、音频处理图像处理
    的头像 发表于 06-20 15:59 6797次阅读
    <b class='flag-5'>滤波器</b>原理及其作用 <b class='flag-5'>滤波器</b>电路图分析

    FPGA verilog HDL实现中值滤波

    paper的设计思想进行编程实现; 整个中值滤波模块分为几个小的模块:3*3窗口生成模块、计数控制模块、3*3中值
    发表于 06-18 18:50

    滤波器的类型介绍

    滤波器是电子系统中不可或缺的组成部分,其主要功能是对信号进行筛选和处理,使得特定频率的信号能够顺利通过,而其它频率的信号则被抑制或消除。在通信、音频处理图像
    的头像 发表于 05-21 15:42 998次阅读

    滤波器的定义、分类及应用

    滤波器,作为一种在电子和信号处理领域广泛应用的设备,对于信号的传输和处理起到了至关重要的作用。无论是在音频处理、无线通信、图像
    的头像 发表于 05-12 17:36 1960次阅读

    高通滤波器、低通滤波器、带通滤波器怎样测幅频特性?

    高通滤波器、低通滤波器、带通滤波器怎样测幅频特性? 高通滤波器、低通滤波器和带通滤波器是常用的
    的头像 发表于 03-28 17:28 3850次阅读

    OpenCV图像卷积与滤波详解

    图像滤波器是一种用于增强或抑制图像中特定特征的工具。它通常是一个小矩阵,定义了如何对图像中的像素进行操作。
    的头像 发表于 03-26 14:57 1391次阅读
    <b class='flag-5'>OpenCV</b><b class='flag-5'>图像</b>卷积与<b class='flag-5'>滤波</b>详解

    中值滤波去除噪声的原理

    中值滤波去除噪声的原理  中值滤波是一种数字图像处理中常用的去噪方法,其原理是通过将每个像素周围
    的头像 发表于 03-14 16:54 1619次阅读

    滤波器:信号处理中的重要利器!

    在现代信号处理领域,滤波器是一种至关重要的工具,它可以对信号进行处理、改善和增强,广泛应用于通信、音频处理图像
    的头像 发表于 03-07 13:53 741次阅读

    中值滤波的原理和C代码

    中值滤波是一种非线性数字滤波技术,主要应用于信号处理图像处理领域,用于减小信号中的噪声和离群值
    的头像 发表于 12-05 08:00 1415次阅读
    <b class='flag-5'>中值</b><b class='flag-5'>滤波</b>的原理和C代码

    FPGA图像处理方法

    图像细节。 FPGA 图像处理方法 1、图像增强 两大方法:空间域方法和时间域方法(以后再详述) 2、图像
    的头像 发表于 12-02 13:15 996次阅读

    LabVIEW开发自适应降噪ANC

    ,使用自适应滤波器来执行噪声消除、回声消除。 项目采用LabVIEW图形化开发环境和Compact RIO硬件执行实时自适应降噪。典型的自适应降噪系统如下图所示。 其中s(n)是需要
    发表于 11-30 19:38