均值滤波的原理是对图像以一个区域(方形,圆形)等为模板,对该区域内的数据求平均后赋值给区域的中心

这种滤波方式原理简单,但是在滤波的同时会造成图像模糊。

本文将尝试对matlab中的filter2()均值函数用自定义函数averfilter()实现。

%x是需要滤波的图像,n是模板大小(即n×n)

function d=averfilter(x,n)

a(1:n,1:n)=1; %a即n×n模板,元素全是1

[height, width]=size(x); %输入图像是hightxwidth的,且hight>n,width>n

x1=double(x);

x2=x1;

for i=1:height-n+1

for j=1:width-n+1

c=x1(i:i+(n-1),j:j+(n-1)).*a; %取出x1中从(i,j)开始的n行n列元素与模板相乘

s=sum(sum(c)); %求c矩阵中各元素之和

x2(i+(n-1)/2,j+(n-1)/2)=s/(n*n); %将与模板运算后的各元素的均值赋给模板中心位置的元素

end

end

%未被赋值的元素取原值

d=uint8(x2);

原始彩色图apple.bmp如下:

转换后的灰度图如下:

加入高斯噪声的灰度图如下:

接下来将比较matlab自带filter2()均值函数和自定义的均值函数averfilter()的滤波效果:

matlab自带的filter2()测试代码如下:

A=fspecial('average'); %生成系统预定义的3X3滤波器

Y=filter2(A,g)/255; %用生成的滤波器进行滤波,并归一化

figure,imshow(Y),title('用系统函数进行均值滤波后的结果'); %显示滤波后的图象

结果图:

使用自己定义的均值滤波函数averfilter()进行测试:

Y2=averfilter(g,n); %调用自编函数进行均值滤波,n为模板大小

figure,imshow(Y2),title('用自己的编写的函数进行均值滤波之后的结果'); %显示滤波后的图象

其中自定义均值滤波函数averfilter()的matlab实现代码为:

%x是需要滤波的图像,n是模板大小(即n×n)

function d=averfilter(x,n)

a(1:n,1:n)=1; %a即n×n模板,元素全是1

[height, width]=size(x); %输入图像是hightxwidth的,且hight>n,width>n

x1=double(x);

x2=x1;

for i=1:height-n+1

for j=1:width-n+1

c=x1(i:i+(n-1),j:j+(n-1)).*a; %取出x1中从(i,j)开始的n行n列元素与模板相乘

s=sum(sum(c)); %求c矩阵中各元素之和

x2(i+(n-1)/2,j+(n-1)/2)=s/(n*n); %将与模板运算后的各元素的均值赋给模板中心位置的元素

end

end

%未被赋值的元素取原值

d=uint8(x2);

结果图如下:

显然比较filter2()和自定义的averfilter()函数其滤波结果是基本一致的,这说明我们对于均值滤波的

matlab实现是成功的。文中的图片效果不是太好,如果需要原图的读者请给我发邮件vpoet_sir@163.com

matlab中滤波函数

matlab自带滤波器函数小结(图像处理)   1 线性平滑滤波器 用MATLAB实现领域平均法抑制噪声程序: I=imread(' c4.jpg '); subplot(231) imshow(I) ...

OpenCV计算机视觉学习(4)——图像平滑处理(均值滤波,高斯滤波,中值滤波,双边滤波)

如果需要处理的原图及代码,请移步小编的GitHub地址 传送门:请点击我 如果点击有误:https://github.com/LeBron-Jian/ComputerVisionPractice &q ...

Win8Metro(C#)数字图像处理--2.9图像均值滤波

原文:Win8Metro(C#)数字图像处理--2.9图像均值滤波  [函数名称] 图像均值滤波函数MeanFilterProcess(WriteableBitmap src) [函数代码]    ...

基于MATLAB的均值滤波算法实现

在图像采集和生成中会不可避免的引入噪声,图像噪声是指存在于图像数据中的不必要的或多余的干扰信息,这对我们对图像信息的提取造成干扰,所以要进行去噪声处理,常见的去除噪声的方法有均值滤波.中值滤波.高斯滤 ...

matlab中fspecial Create predefined 2-D filter以及中值滤波均值滤波以及高斯滤波

来源: 1.https://ww2.mathworks.cn/help/images/ref/fspecial.html?searchHighlight=fspecial&s_tid=doc_ ...

基于MATLAB的中值滤波均值滤波以及高斯滤波的实现

基于MATLAB的中值滤波均值滤波以及高斯滤波的实现 作者:lee神 1.   背景知识 中值滤波法是一种非线性平滑技术,它将每一像素点的灰度值设置为该点某邻域窗口内的所有像素点灰度值的中值. 中值滤 ...

opencv3.2.0图像处理之均值滤波blur API函数

##.均值滤波:blur函数 ##函数原型 : ,-),int borderType=BORDER_DEFAULT) (参数详解同boxFilter函数) /**********新建Qt控制台程序** ...

均值滤波去除图像噪声的matlab程序

所谓均值滤波实际上就是用均值替代原图像中的各个像素值. 均值滤波的方法是:对待处理的当前像素,选择一个模板,该模板为其近邻的若干像素组成,用模板中的像素的均值来替代原像素. 优点:算法简单,计算速度快 ...

Matlab中imfilter()函数的用法

Matlab中imfilter()函数的用法 功能:对任意类型数组或多维图像进行滤波.用法:B = imfilter(A,H) B = imfilter(A,H,option1,option2,... ...

随机推荐

基于Proteus仿真的Arduino学习(2)——LED点阵探究A(LED点阵基础)

一.前言: 随着LED的普及,以LED点阵为基础的显示设置层出不穷.例如,公交车的线路提示牌.高速公路的信息提示牌,安装在大楼上的广告屏幕等.下面,我们将由简单到复杂地探索各种LED点阵的使用方法,同 ...

升级到 PHP-7 遇到的坑 及 经验分享

注意:上面这张图是QQ群网友分享的,图中提到的“被移除的函数”,call_user_func 和 call_user_func_array 在 PHP-7.0 的正式版中是可用的,也许是当时的 测试版 ...

Fouandation(NSString ,NSArray,NSDictionary,NSSet) 中常见的理解错误区

Fouandation 中常见的理解错误区 1.NSString //快速创建(实例和类方法) 存放的地址是 常量区 NSString * string1 = [NSString alloc]init ...

力挺8天入门wpf【转载】

8天入门wpf—— 第八天 最后的补充 摘要: 从这一篇往前看,其实wpf中还有很多东西没有讲到,不过我的原则还是将比较常用的知识点过一遍,如果大家熟悉了这些知识,基本功也就打的差不多了,后续可以等待 ...

记使用sed的一次坑

sed做为linux下的三剑客,自然功能强大,但是如果使用不当,反而适得其反,今天就因为这个命令采了很深坑,分析一下原因,以谏后来者. 情景回顾: 项目中使用的一个python爬虫采用的是多线程并发爬 ...

zookeeper的集群介绍、搭建、环境、安装

zookeeper是本身是一种分布式协调服务(英文意思动物园园长因为Hadoop就是一个动物园,storm.hadoop.kafkaka.hbaser都是基于zookeeper开发的) 原理:Zook ...

【Netty】(3)—源码NioEventLoopGroup

netty(3)-源码NioEventLoopGroup 一.概念 NioEventLoopGroup对象可以理解为一个线程池,内部维护了一组线程,每个线程负责处理多个Channel上的事件,而一个C ...

Timeline Storyteller 现已加入自定义图表库

前言 下载地址: https://store.office.com/en-us/app.aspx?assetid=WA104381136&sourcecorrid=328f5e2b-e973- ...

关于transition和animation

最近的工作以移动端项目居多,经常会涉及一些比较小的动画效果,所以使用css3设计动画效果也就越发熟练起来.但是不得不承认,一直以来都是凭感觉使用transform, transition, anima ...

matlab中blur函数_matlab-----均值滤波函数的实现相关推荐

  1. Matlab中一维和二维滤波函数及其典型用法【随时更新】

    Matlab中一维和二维滤波函数及其典型用法[随时更新] 一维滤波函数 均值滤波器movmean 中值滤波器movmedian 二维滤波函数 用fspecial预定义各种二维滤波器 主要用于自查,如果 ...

  2. 将函数当做参数 matlab,Matlab中如何将(自定义)函数作为参数传递给另一个函数...

    假如我们编写了一个积分通用程序,想使它更具有通用性,那么可以把被积函数也作为一个参数.在c/c++中,可以使用函数指针来实现上边的功能,在matlab中如何实现呢?使用函数句柄--这时类似于函数指针的 ...

  3. matlab中饼图绘制程序,MATLAB中绘制二维饼图的函数是(? ? ) (1.5分)

    MATLAB中绘制二维饼图的函数是(? ? ) (1.5分) 答:pie 计算机的内存储器比外存储器读写速度 ______ 答:快 新民主主义革命时期,提出了反帝反封建这个任务就等于真正懂得了什么叫反 ...

  4. MatLab中的多项式拟合(lsqcurvefit函数的非线性曲线拟合)

    MatLab中的多项式拟合(lsqcurvefit函数的非线性曲线拟合) lsqcurvefit函数 函数原型 x=lsqcurvefit(fun, x0, xdata, ydata) == 其中的参 ...

  5. matlab得到计算机时间,Matlab中处理日期与时间的函数

    Matlab用三种格式来表示日期与时间 (1)双精度型日期数字:一个日期型数字代表从公元0年到某一日期的的天数,例如,2008年8月26日夜时0点钟被表示为733646,而这同一天的中午12点就被表示 ...

  6. MatLab中rand randi randn 三个函数的解析

    MatLab中rand randi randn 三个函数的解析 1.rand 概括:生成(0,1)之间的均匀分布的伪随机数 示例1: >>rand %什么参数也没有,生成一个(0,1)的数 ...

  7. matlab对数收益直方图,科学网—MATLAB中绘制数据直方图的新函数histogram2 - 王福昌的博文...

    MATLAB中有命令hist3() 可以绘制直方图,竖坐标是频数,这与一些教科书中用纵轴表示频率的做法不一致,有些时候不便于使用.当然,使用者可以自己编写定制能够在纵轴绘出频率的直方图.在MATLAB ...

  8. matlab函数fftshift,matlab中fft算法_matlab中fftshift函数_matlab中fft函数的用法(2)

    plot([0 : PointNum/2 - 1], x1(1:PointNum/2)); grid on subplot(3,1,2); % [REX IMX] am = sqrt(abs(REX. ...

  9. MATLAB中rand,randi,randn函数,及rand('state',0)和rand('seed',0)产生随机种子详解

    一.问题来源: 在学习matlab中看到书上有许多关于生成随机数的应用,y书上一开始会写一个rand('state',0),注释是为了方便验证,一开始并不是很理解,最近搜索网上文章等深入理解了下关于M ...

  10. c 调用上层类中函数_Matlab系列之函数嵌套

    昨天的那一篇讲的几个函数,不知道你们理解的如何,是否懂得怎么去使用了,如果还没懂,一定要再多看几遍,并且去在软件上进行实操,今天的话,将要介绍一下函数的嵌套,不过在正式讲嵌套之前,先对主函数和子函数做 ...

最新文章

  1. HTTP的KeepAlive是开启还是关闭?
  2. [置顶]       webservice系列2---javabeanhandler
  3. IOS 笔试题(二)
  4. php大商创 安装,大商创X2020最新纯净服务器安装教程
  5. 管理信息系统 课程设计(2018-6-16)
  6. 深入剖析ASP.NET的编译原理之二:预编译(Precompilation)
  7. 「一本通 4.1 练习 2」简单题
  8. 【小白的CFD之旅】22 好网格与坏网格
  9. 【七夕特殊礼物】Dubbo学习之SPI实战与debug源码
  10. 我想开一家美团外卖店,不做堂食,有什么好的建议吗?
  11. ALGO-146算法训练 4-2找公倍数
  12. 思科三层交换机开启ipv6路由功能_三层交换机实现路由功能配置示例与详解 (Cisco Packer Tracer 模拟器)...
  13. MVVM 架构解析及 Jetpack 架构组件的使用
  14. CDA I级学习 - EDIT数字化模型
  15. Linux/windows下java调用lingo
  16. 如何一个月左右拿下PAT甲级(浙大机试)满分
  17. windows强制删除文件
  18. 深信服 一面 2018 秋招
  19. JSON风格指南-真经
  20. 1908: 【18NOIP提高组】填数游戏

热门文章

  1. Web前端:一些用于Web开发的最佳精选IDE和代码编辑器
  2. php获取多选框的值
  3. codebook实现源码
  4. Unity3D 一些工具总结
  5. java毕业设计商品货物信息管理系统源码+lw文档+mybatis+系统+mysql数据库+调试
  6. VMWare 安装XP-SP3虚拟机
  7. JAVA复习 (期末重点考点总结)
  8. 柱状图中xy轴怎么出现_如何用Excel绘制双Y轴柱状图?
  9. 思维导图——史上最详细的计算机基础进制转换讲解
  10. arcgis地理空间数据库学习记录01-复制地理数据库