位置: IT常识 - 正文

数字图像处理之matlab实验(三):空间滤波器(数字图像处理-应用篇)

编辑:rootadmin
数字图像处理之matlab实验(三):空间滤波器 1、空间滤波原理

推荐整理分享数字图像处理之matlab实验(三):空间滤波器(数字图像处理-应用篇),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:数字图像处理之父,数字图像处理之父,数字图像处理之MATLAB图像基本处理,数字图像处理之怀旧特效,数字图像处理之MATLAB图像基本处理,数字图像处理之MATLAB图像基本处理,数字图像处理之怀旧特效,数字图像处理之父,内容如对您有帮助,希望把文章链接给更多的朋友!

空间滤波,就是在原图像上,用一个固定尺寸的模板去做卷积运算,得到的新图像就是滤波结果。滤波,就是过滤某种信号的意思。过滤哪种信号取决于模板设计,如果是锐化模板,处理后就保留高频信号,如果是平滑模板,处理后就保留低频信号。

(1)模板运算

图像处理中模板能够看作是n*n(n通常是奇数)的窗体。模板连续地运动于整个图像中,对模板窗体范围内的像素做相应处理。

模板运算主要分为:

①模板卷积。模板卷积是把模板内像素的灰度值和模板中相应的灰度值相乘,求平均值赋给当前模板窗体的中心像素。作为它的灰度值;

②模板排序。模板排序是把模版内像素的灰度值排序,取某个顺序统计量作为模板中心像素灰度值。

Matlab中做模版卷积十分高效,取出模版内子矩阵和模版权重点乘求平均就可以,已图示为例,3X3的模板在图像上滑动,原图像f(x,y) 经过模板处理后变成了g(x,y)。

(2)边界处理

处理边界有非常多种做法:

①重复图像边缘上的行和列。

②卷绕输入图像(假设第一列紧接着最后一列)。

③在输入图像外部填充常数(例如零)。

④去掉不能计算的行列。仅对可计算的像素计算卷积。

(3)空间域滤波

把模板运算运用于图像的空间域增强的技术称为空间域滤波。依据滤波频率空间域滤波分为平滑滤波(减弱和去除高频分量)和锐化滤波(减弱和去除低频分量),依据滤波计算特点又分为线性滤波和非线性滤波。

因此空间域滤波可分为:

数字图像处理之matlab实验(三):空间滤波器(数字图像处理-应用篇)

分类     线性       非线性

平滑   线性平滑   非线性平滑

锐化   线性锐化   非线性锐化

2、平滑滤波器(1)添加噪声

噪声主要分类为两类,高斯噪声和椒盐噪声。

高斯噪声在每个像素上都会出现,赋值服从高斯分布。

椒盐噪声出现位置随机,所以可以控制椒盐噪声的密度,椒盐噪声的幅度确定,椒噪声偏暗,盐噪声偏亮。

Image = mat2gray( imread('original_pattern.jpg') ,[0 255]);noiseIsp=imnoise(Image,'salt & pepper',0.1); %添加椒盐噪声,密度为0.1 imshow(noiseIsp,[0 1]); title('椒盐噪声图像');noiseIg=imnoise(Image,'gaussian'); %添加高斯噪声,默认均值为0,方差为0.01figure;imshow(noiseIg,[0 1]); title('高斯噪声图像'); (2)平滑滤波器

 平滑滤波器可以去除图像的噪声,使图像变得模糊。包括:中值滤波、均值滤波、高斯滤波。

高斯滤波、均值滤波去除高斯噪声。

(3)均值滤波

Image=imread('Letters-a.jpg');noiseI=imnoise(Image,'gaussian'); %添加高斯噪声subplot(221),imshow(Image),title('原图');subplot(222),imshow(noiseI),title('高斯噪声图像');result1=filter2(fspecial('average',3),noiseI); %3×3均值滤波result2=filter2(fspecial('average',7),noiseI); % 7×7均值滤波subplot(223),imshow(uint8(result1)),title('3×3均值滤波');subplot(224),imshow(uint8(result2)),title('7×7均值滤波');(4)中值滤波

 

Image=rgb2gray(imread('lotus.bmp'));noiseI=imnoise(Image,'salt & pepper',0.1);result=medfilt2(noiseI); %3×3中值滤波subplot(121),imshow(noiseI),title('椒盐噪声图像');subplot(122),imshow(uint8(result)),title('3×3中值滤波');(5)自编程实现高斯滤波

Image=imread('Letters-a.jpg');sigma1=0.6; sigma2=10; r=3; % 高斯模板的参数NoiseI= imnoise(Image,'gaussian'); %加噪gausFilter1=fspecial('gaussian',[2*r+1 2*r+1],sigma1); gausFilter2=fspecial('gaussian',[2*r+1 2*r+1],sigma2); result1=imfilter(NoiseI,gausFilter1,'conv');result2=imfilter(NoiseI,gausFilter2,'conv');subplot(231);imshow(Image);title('原图');subplot(232);imshow(NoiseI);title('高斯噪声图像');subplot(233);imshow(result1);title('sigma1 =0.6高斯滤波');subplot(234);imshow(result2);title('sigma2 =10高斯滤波');%imwrite(uint8(NoiseI),'gr.bmp');%imwrite(uint8(result1),'gr1.bmp');%imwrite(uint8(result2),'gr2.bmp');%编写高斯滤波函数实现[height,width]=size(NoiseI); for x=-r:r for y=-r:r H(x+r+1,y+r+1)=1/(2*pi*sigma1^2).*exp((-x.^2-y.^2)/(2*sigma1^2)); endend H=H/sum(H(:)); %归一化高斯模板H result3=zeros(height,width); %滤波后图像 midimg=zeros(height+2*r,width+2*r); %中间图像 midimg(r+1:height+r,r+1:width+r)=NoiseI; for ai=r+1:height+r for aj=r+1:width+r temp_row=ai-r; temp_col=aj-r; temp=0; for bi=1:2*r+1 for bj=1:2*r+1 temp= temp+(midimg(temp_row+bi-1,temp_col+bj-1)*H(bi,bj)); end end result3(temp_row,temp_col)=temp; end end subplot(235);imshow(uint8(result3));title('myself高斯滤波'); 3、锐化滤波器

 (1)梯度算子

Image=im2double(rgb2gray(imread('lotus.jpg')));subplot(131),imshow(Image),title('原图像');[h,w]=size(Image);edgeImage=zeros(h,w);for x=1:w-1 for y=1:h-1 edgeImage(y,x)=abs(Image(y,x+1)-Image(y,x))+abs(Image(y+1,x)-Image(y,x)); endendsubplot(132),imshow(edgeImage),title('梯度图像');sharpImage=Image+edgeImage;subplot(133),imshow(sharpImage),title('锐化图像');(2)Robert算子 

Image=im2double(rgb2gray(imread('lotus.jpg')));subplot(221),imshow(Image),title('原图像');BW= edge(Image,'roberts');subplot(222),imshow(BW),title('边缘检测');H1=[1 0; 0 -1];H2=[0 1;-1 0];R1=imfilter(Image,H1);R2=imfilter(Image,H2);edgeImage=abs(R1)+abs(R2);subplot(223),imshow(edgeImage),title('Robert梯度图像');sharpImage=Image+edgeImage;subplot(224),imshow(sharpImage),title('Robert锐化图像');(3)Sobel算子 

Image=im2double(rgb2gray(imread('lotus.jpg')));subplot(221),imshow(Image),title('原图像');BW= edge(Image,'sobel');subplot(222),imshow(BW),title('边缘检测');H1=[-1 -2 -1;0 0 0;1 2 1];H2=[-1 0 1;-2 0 2;-1 0 1];R1=imfilter(Image,H1);R2=imfilter(Image,H2);edgeImage=abs(R1)+abs(R2);subplot(223),imshow(edgeImage),title('Sobel梯度图像');sharpImage=Image+edgeImage;subplot(224),imshow(sharpImage),title('Sobel锐化图像');(4)多个模板边缘检测 

 

clear,clc,close all;Image=im2double(rgb2gray(imread('lotus.jpg')));H1=[-1 -1 -1;0 0 0;1 1 1];H2=[0 -1 -1;1 0 -1; 1 1 0];H3=[1 0 -1;1 0 -1;1 0 -1];H4=[1 1 0;1 0 -1;0 -1 -1];H5=[1 1 1;0 0 0;-1 -1 -1];H6=[0 1 1;-1 0 1;-1 -1 0];H7=[-1 0 1;-1 0 1;-1 0 1];H8=[-1 -1 0;-1 0 1;0 1 1];R1=imfilter(Image,H1);R2=imfilter(Image,H2);R3=imfilter(Image,H3);R4=imfilter(Image,H4);R5=imfilter(Image,H5);R6=imfilter(Image,H6);R7=imfilter(Image,H7);R8=imfilter(Image,H8);edgeImage1=abs(R1)+abs(R7);sharpImage1=edgeImage1+Image;f1=max(max(R1,R2),max(R3,R4));f2=max(max(R5,R6),max(R7,R8));edgeImage2=max(f1,f2);sharpImage2=edgeImage2+Image;subplot(221),imshow(edgeImage1),title('两个模板边缘检测');subplot(222),imshow(edgeImage2),title('八个模板边缘检测');subplot(223),imshow(sharpImage1),title('两个模板边缘锐化');subplot(224),imshow(sharpImage2),title('八个模板边缘锐化');(5)Laplacian算子

Image=im2double(rgb2gray(imread('lotus.jpg')));subplot(131),imshow(Image),title('原图像');H=fspecial('laplacian',0);R=imfilter(Image,H);edgeImage=abs(R);subplot(132),imshow(edgeImage),title('Laplacian梯度图像');H1=[0 -1 0;-1 5 -1;0 -1 0];sharpImage=imfilter(Image,H1);subplot(133),imshow(sharpImage),title('Laplacian锐化图像');
本文链接地址:https://www.jiuchutong.com/zhishi/295182.html 转载请保留说明!

上一篇:【2】YOLOv8原理解析:重新定义实时目标检测的速度和精度(yolov3原理及代码解析)

下一篇:uni-app 从0 到 1 制作一个项目,收藏等于学会(uni-app实战教程)

  • qq里面的钱怎么转到微信(qq里面的钱怎么花)

    qq里面的钱怎么转到微信(qq里面的钱怎么花)

  • wps字体颜色怎么改(wps字体颜色怎么改不了)

    wps字体颜色怎么改(wps字体颜色怎么改不了)

  • 操作失败503什么意思(操作失败430007)

    操作失败503什么意思(操作失败430007)

  • 交易猫ios下载不了(交易猫ios下载安装不了)

    交易猫ios下载不了(交易猫ios下载安装不了)

  • 快手买东西拒收会产生运费吗(快手买东西拒收怎么操作)

    快手买东西拒收会产生运费吗(快手买东西拒收怎么操作)

  • qq更新后怎么回到以前的版本(升级后的qq怎么恢复原状)

    qq更新后怎么回到以前的版本(升级后的qq怎么恢复原状)

  • 群主到哪里查退群人员(群主怎么查询退群记录)

    群主到哪里查退群人员(群主怎么查询退群记录)

  • 抖音怎么查看好友在线状态(抖音怎么查看好友点赞过的作品)

    抖音怎么查看好友在线状态(抖音怎么查看好友点赞过的作品)

  • 为什么苹果手机打电话的时候没有网络(为什么苹果手机无线局域网打不开)

    为什么苹果手机打电话的时候没有网络(为什么苹果手机无线局域网打不开)

  • 6s开不了机充不进电了(6s显示充电开不了机)

    6s开不了机充不进电了(6s显示充电开不了机)

  • qq怎么看自己是不是别人的特别关心(qq怎么看自己是不是别人的置顶)

    qq怎么看自己是不是别人的特别关心(qq怎么看自己是不是别人的置顶)

  • 淘宝可以申请几次退款退货(淘宝可以申请几次价保)

    淘宝可以申请几次退款退货(淘宝可以申请几次价保)

  • 手机号如何转网(联通手机号如何注销)

    手机号如何转网(联通手机号如何注销)

  • 哪款手机同时支持双4g(哪款手机可以支持两个微信一起用)

    哪款手机同时支持双4g(哪款手机可以支持两个微信一起用)

  • QQ匿名投票怎样才能看投票人(qq匿名投票在哪儿弄)

    QQ匿名投票怎样才能看投票人(qq匿名投票在哪儿弄)

  • 手持身份证怎么拍清楚(手持身份证怎么拿)

    手持身份证怎么拍清楚(手持身份证怎么拿)

  • oppor15照相怎么显示日期(oppo手机r15照相机怎么设置)

    oppor15照相怎么显示日期(oppo手机r15照相机怎么设置)

  • qq礼物怎么提现(qq礼物如何转现金)

    qq礼物怎么提现(qq礼物如何转现金)

  • 如何定位已关机的手机(如何定位已关机的oppo手机)

    如何定位已关机的手机(如何定位已关机的oppo手机)

  • 为什么soul下载不了(为什么soul下载不了ios)

    为什么soul下载不了(为什么soul下载不了ios)

  • 抖音怎么查好友(抖音怎么查好友艾特别人)

    抖音怎么查好友(抖音怎么查好友艾特别人)

  • 苹果8p红色特别版有什么区别(苹果8p红色特别版价格)

    苹果8p红色特别版有什么区别(苹果8p红色特别版价格)

  • 京东商城如何激活白条(京东如何激活兑换码)

    京东商城如何激活白条(京东如何激活兑换码)

  • cmluc.exe进程安全吗 是病毒吗 cmluc进程的信息(cmdkill进程)

    cmluc.exe进程安全吗 是病毒吗 cmluc进程的信息(cmdkill进程)

  • 哪些保险保障基金可税前扣除
  • 增值税预缴申报和正常申报的区别
  • 增值税销项税额和进项税额
  • 税控盘280抵扣报税填在
  • 金蝶财务软件固定资产模块固定资产调拨
  • 小型制造型企业有哪些
  • 企业租赁集体土地种植经济林如何补偿
  • 固定资产报废变卖收入缴税账务处理
  • 三个月工资一次扣税多少
  • 关于处置固定资产的请示
  • 被辞退还有退休金吗
  • 一般纳税人进项税额转出会计分录
  • 企业自建房是什么意思
  • 开物流公司能挣多少钱
  • 非股东打入投资款无法返还
  • 工资计提不发放工资个税
  • 旅行社开的发票是否都要差额征税
  • 资产收购的特殊性税务处理方法
  • 劳务市场零工临时工
  • 物流公司搬运货物合法吗
  • 房地产预缴税金附加可以计提吗
  • window1020h2更新问题
  • 年底公司抵税
  • 公司出售车辆
  • deepin咋样
  • wifi信号弱了
  • linux特殊权限设置
  • php ftp上传文件
  • 哪些收入需要交消费税
  • php缩放图片
  • 消耗性生物资产减值准备一经计提不得转回
  • 企业所得税优惠事项管理目录
  • 斑鹿,滕波尔国家公园,印度 (© Ondrej Prosicky/Shutterstock)
  • 所有非批扣和所有批扣是什么意思
  • 简单的php文件
  • php获取当前页面url
  • php自动化脚本
  • span标签中的字符串怎么获取
  • sass和less的区别使用
  • Python中tkinter的 Variable类
  • 红字信息表重复了怎么办
  • 为什么要结转成本?
  • python condition条件变量
  • 织梦怎么用
  • 固定资产清理的账务处理
  • 国税局领发票是哪些项目需要收取费用
  • 新租赁准则承租人租金用什么科目
  • 本月开发票下月收款
  • 一个人可以有两张同一个银行的卡吗
  • 利息收入是一级科目还是
  • 房租预付款会计分录
  • 城市维护建设税属于中央还是地方
  • 新开立银行账户怎么办理
  • 现金支票存根联和正联怎么盖章
  • 银行总账和明细账
  • 员工预支工资现金流量
  • 联合账簿是备查账簿和序时账簿的结合
  • 会计备注一般写什么
  • mysql的多表查询语句
  • win8.1补丁打不上
  • 深度Win7 64位系统默认输入法图标如何个性化设置
  • win10系统怎么调
  • solaris vi命令
  • Win10 RedStone 2预览版14936快速版开始推送
  • linux的用法
  • win10在哪里更改软件大小
  • win8系统盘清理
  • WIN10开始菜单点不动
  • cocos2dx用checkbox实现单选框和button实现table按钮
  • js实现用户登录
  • Android 使用mp4做礼物特效
  • dos cat命令
  • AngularJs ng-change事件/指令的用法小结
  • python多线程操作
  • python的删除命令
  • js中的set
  • 详解Python的collections模块中的deque双端队列结构
  • 无偿转让股权要交税吗
  • 代扣国地税什么意思
  • 江苏电子口岸卡邮寄大概需要多久
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设