数字图像处理Matlab-小波变换在图像处理中的应用(附代码)_小波分解与重构在图像处理的应用-程序员宅基地

技术标签: 计算机视觉  数字图像处理-Matlab  

1.Objectives:

1、 认识尺度函数和小波函数
2、 学习 matlab中与小波变换的函数
3、 实践小波变换应用

2.Experiment Content:

1、显示尺度函数和小波函数
2、认识小波滤波器
3、二维小波变换函数与重构函数
4、小波系数处理函数
5、用小波变换进行图像压缩与边缘提取

3.Experiment Principle:

见书《数字图像处理》

(冈萨雷斯著作,电子工业出版社于2009年12月1日出版)

4.Experiment Steps Result and Conlusion:

1、了解各种小波性质

函数:waveinfo(wfamily); 显示不同小波性质
在这里插入图片描述
在这里插入图片描述在这里插入图片描述以上是通过waveinfo获得的小波信息

2、观察各种小波函数及其尺度函数

函数 [ phi, psi, xval ] = wavefun (wname, iter)
;小波函数就是母小波,是小波变化中最基本的“基”,尺度函数就是父小波,通过父小波获得在不同尺度上,不同位移上的“基”。小波变化就可以通过这些获得概貌图,横坐标,纵坐标,对角线上的细节图
在这里插入图片描述

3、获得小波滤波器

函数 [Lo_D, Hi_D, Lo_R, Hi_R] = wfilters(wname)
例如: [Lo_D, Hi_D, Lo_R, Hi_R] = wfilters(‘sym4’) 获得’sym4’小波的低 频分解、高频分解、低频重构、高频重构滤波器。
在这里插入图片描述
各个滤波器的作用均在title有写,我们可以看到低频分解与高频分解一个上凸,一个下凹,对于相同频率的重构,分解,形状大致相同

4、二维小波变换函数与重构函数

正变换函数: [C, S] = wavedec2(X, N, Wname)
x=imread( ‘lena256.bmp’);
[C, S] = wavedec2(x, 3, ‘db4’);

了解 C、s的数据含义
查看分解系数二维图:wave2gray(C, S);
重构函数:g = waverec2(C, S, wname)

例如:
g=waverec2(C,S,‘db4’);
figure,imshow(g,[]);
在这里插入图片描述
看到左图,只剩下一个概貌图,因为是分解三次才得到的概貌图,其大小等于原图的四分之一再除以三,,经过小波重构后,可以得到原图,如右图所示对图像进行了3次分解,也就是说,第一次分解成一个概貌与三个分别是水平,垂直,对角线的细节。分解三次后,一共变成了一个概貌,9个细节
在这里插入图片描述
对于s1来说里面的信息是rgb的第一行是分解得到的最小图像的大小,第二个到第四个分别是分解到每级得到的细节图像的大小,最后一个是原图的大小 对于c1来说,里面的信息是分解之后的信息是每分解一级按照概貌 水平细节 垂直细节 对角线细节的顺序 变成的行向量。

5、查看及处理小波系数

a = appcoef2( c,s,wname );
d = detcoef2( o, c, s, n );
nc = wthcoef2( type, c, s, n, t, sorth )
在这里插入图片描述
这是我们用appcoef2函数查看的进行小波分解后的概貌图的信息
在这里插入图片描述
这里我们看到的是用detcoef2得到的分解到第三级的细节信息
在这里插入图片描述
这是我们用wthcoef2函数将细节信息都变为0之后 再用detcoef2查看后得到的信息,确实所有的值都变成了0

6、用小波变换进行图像压缩与边缘提取

在这里插入图片描述

左图是原图右图是我们将所有的细节信息都去掉后进行重构得到的结果,因此只得到了一张概貌图 在这里插入图片描述右图是我们将原来的概貌图置为0之后,进行重构得到的图像,换句话说就是只由细节构成的图,那么这些图也就构成了图像中灰度变化中比较明显的部分,达到了提取边沿的效果。

【附录】实现代码

程序一:

waveinfo('haar');
waveinfo('gaus');
[phi psi xval]=wavefun('db3',4);%迭代2^4次 xval就是返回的坐标轴的一个分度
figure(1);
subplot(211);plot(xval,phi);title('小波函数');
subplot(212);plot(xval,psi);title('尺度函数'); 

[Lo_D,Hi_D,Lo_R,Hi_R]=wfilters('sym4');%获得sym4小波的低频分解,高频分解,低频重构,高频重构滤波器

figure(2);
subplot(221);plot(Lo_D);title('低频分解');
subplot(222);plot(Hi_D);title('高频分解');
subplot(223);plot(Lo_R);title('低频重构');
subplot(224);plot(Hi_R);title('高频重构');

程序二

f=imread('E:\数字图像处理\程序与图像\标准图片\lena256.BMP');
[c s]=wavedec2(f,3,'db4');
%对图像进行了3次分解,也就是说,第一次分解成一个概貌与三个分别是水平,垂直,对角线的细节
%分解三次后,一共变成了一个概貌,9个细节 
%对于s1来说里面的信息是rgb的第一行是分解得到的最小图像的大小 
%第二个到第四个分别是分解到每级得到的细节图像的大小,最后一个是原图的大小%对于c1来说,里面的信息是分解之后的信息是每分解一级按照概貌 水平细节 垂直细节 对角线细节的顺序 变成的行向量。
%并且这种是列的连接比如H(:)'每再分解只改变上一级概貌信息所占位置的数值

figure(1);
subplot(121);
wave2gray(c,s);
%查看分解系数二维图
title('小波分解3次后图像');
g=waverec2(c,s,'db4');%用分解后的概貌与细节图重构原图
subplot(122);
imshow(g,[]);%因为重构后的图像完成后不属于图片信息,因此要加上[]
title('重构后小波图像');

程序三:

%查看及处理小波系数
a=appcoef2(c,s,'db4');%返回的a是位于最低一级的概貌信息
b=detcoef2('h',c,s,3);%这里是返回细节信息,h地表返回的是水平信息,3代表分解到第三级的细节,%用此函数就可以得到任意级的水平 垂直 对角线的细节信息
newc=wthcoef2('h',c,s,3);%这是将c中规定的区域值设为0;比如这里就是分解第“3”级的“水平”分量设为0
newb=detcoef2('h',newc,s,3);%查看改变为0后的结果,验证结论

程序四

%用小波变化进行图像压缩与边沿处理
f=imread('E:\数字图像处理\程序与图像\标准图片\lena256.BMP');
[c,s]=wavedec2(f,3,'haar');%用haar小波进行三级分解
newc1=wthcoef2('t',c,s,[2 1]);%将分解的1-2级的值全部置为0
g1=waverec2(newc1,s,'haar');
figure(1);
subplot(121);imshow(f);title('原图');
subplot(122);imshow(g1,[]);title('舍弃一二级分解后的细节信息后的压缩图');
newc2=wthcoef2('a',c,s);%这里将概貌信息的值全部置为0;
g2=waverec2(newc2,s,'haar');%用新的newc重构
figure(2);
subplot(121);imshow(f);title('原图');
subplot(122);imshow(g2,[]);title('概貌图置为0后压缩后图');

图像:上文都以截图展示

码字不易,都看到这里了不如点个赞哦~
我还写了很多文章,欢迎关注我哦~
在这里插入图片描述

亲爱的朋友,这里是我的公众号,欢迎关注!
本博客的优秀博文也将陆续搬运到公众号,之后还将推出更多优秀博文,并将优先发在公众号,敬请期待!
关注起来,让我们一起成长!

在这里插入图片描述

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/weixin_42784535/article/details/105123958

智能推荐

UE4的AI行为树基础知识_ue4行为树-程序员宅基地

文章浏览阅读1.4k次。UE4的AI基础学习_ue4行为树

【华为云技术分享】一文带你了解Web前端发展历程_华为云前端发版-程序员宅基地

文章浏览阅读2.5k次。摘要:自互联网行业发展以来,web前端不断发展变化着。在前人的基础上,后人有幸能够站在前人的肩膀上行走。前端的发展变化不仅是继承式的迭代,同时也是不断的变革和创造。一、前端到底是个什么?简单点说,浏览器呈现出来的页面,给用户看的、操作的就是前端(客户端);你看不到的,类似一些游戏数据、应用数据之类的就是后端(服务端)。那么再简单点就可以说,前端指的就是浏览器端,后端指的就是为浏览器提供服务和数据的服务器端。这是比较准确的描述,如果往大了讲,你所有看到的一切,网页、移动端网页、小程序、甚._华为云前端发版

MutationObserver - 监听Dom变化_mutationobserver.observe-程序员宅基地

文章浏览阅读783次,点赞18次,收藏26次。监听DOM变化(属性变动、目标子节点变化、观察后代节点等)_mutationobserver.observe

【C/C++】freopen 函数和 fopen 函数|标准输入输入写入文件|屏幕输出写入文件-程序员宅基地

文章浏览阅读9.8k次,点赞13次,收藏65次。freopen 和 fopen 都是C的标准库函数被包含于C标准库头文件中。fopen就是我们最熟悉的打开一个文件用于写入or读取freopen 是打开一个文件,用于接收输入输出流的数据。_freopen

python sys.path.append()和sys.path.insert()_sys. addpath-程序员宅基地

文章浏览阅读3.8k次。转载自: https://blog.csdn.net/dcrmg/article/details/79546962python程序中使用 import XXX 时,python解析器会在当前目录、已安装和第三方模块中搜索 xxx,如果都搜索不到就会报错。 使用sys.path.append()方法可以临时添加搜索路径,方便更简洁的import其他包和模块。这种方法导入的路径会在python程..._sys. addpath

Qt中的矩阵计算库eigen_qt矩阵运算-程序员宅基地

文章浏览阅读7.8k次,点赞7次,收藏44次。我的官网地址原文链接Qt中的矩阵计算库eigen在实际工程中由于需要使用矩阵计算,网上搜罗了下,发现 eigen 库比较靠谱,这里简要介绍下食用方法,以及如何避免运行断言下载库eigen 官网引入到 Qt 工程中将 源码中的 的 Eigen 目录拷贝到 Qt 工程的目录目录中新建 eigen.pri 文件内容如下INCLUDEPATH += $$PWD使用新建 C+..._qt矩阵运算

随便推点

BiLSTM双向长短期记忆神经网络回归预测算法(基于Matlab实现)_双向bilstm模型-程序员宅基地

文章浏览阅读539次,点赞11次,收藏9次。正向的LSTM网络接受序列数据的初始状态,逐步学习前向信息并更新内部隐藏状态,最终生成前向隐藏状态序列。反向的LSTM网络则以相反的顺序处理序列数据,并生成相应的反向隐藏状态序列。本文将介绍使用Matlab实现的BiLSTM算法,并展示其在多输入单输出回归问题上的应用。然后,我们定义了BiLSTM模型的层次结构,包括序列输入层、BiLSTM层、全连接层和回归层。与传统的单向LSTM相比,BiLSTM能够同时利用序列数据的前向和后向信息,从而提高模型在长期依赖关系上的学习能力。_双向bilstm模型

D78XX系列——用于各种电视机、收录机、电子仪器、设备的稳压电源电路,输出电流大,内设过热、短路保护电路,无需外接元件-程序员宅基地

文章浏览阅读295次,点赞9次,收藏11次。D78XX系列是用于各种电视机、收录机、电子仪器、设备的稳压电源电路。包括D7805、D7806、 D7808、 D7809、 D7810、 D7812、 D7815。● 输出电流大,IOMAX= 1A.● 封装形式: T0-220。● 内设过热、短路保护电路。

stm32入门学习(基于STM32F103C8T6)_stm32f103c8t6csdn-程序员宅基地

文章浏览阅读456次,点赞8次,收藏2次。じゃ、始めましょう。--最近在学外语,对于IT从业者来说,会是一项优势。_stm32f103c8t6csdn

Anaconda安装_anaconda环境变量e:\anaconda3\library\usr\bin-程序员宅基地

文章浏览阅读7.1k次,点赞41次,收藏196次。文章目录1.Anaconda是什么2.Anaconda下载3.Anaconda安装4.Anaconda环境变量配置5.检验是否安装成功6.检验Anaconda Navifator是否安装成功7.修改Anaconda镜像修改为清华大学镜像移除清华大学镜像8.PyCharm配置Anaconda方式一(建立新的项目时)方式二(已经打开项目)9.总结1.Anaconda是什么Anaconda指的是一个开源的Python发行版本,其包含了conda、Python等180多个科学包及其依赖项。Anaconda也是P_anaconda环境变量e:\anaconda3\library\usr\bin

70个常用电脑快捷键,帮你工作效率提升100倍!职场新人必备!_快捷键可以帮助自己-程序员宅基地

文章浏览阅读2k次,点赞11次,收藏44次。电脑快捷键不仅可以帮助我们熟练的操作电脑,还可以帮助我们快速提升自己的工作效率,从此跟加班说拜拜!但由于电脑快捷键过于繁多不方便我们记忆!那么今天小编为大家整理的70个Wordows、Ctrl、Alt、Shift组合快捷键,运用好的话能够帮你工作效率提升100倍!希望能为大家派上用途!下面以图片&文字的形式展现给大家!文字可以直接复制!图片也可以直接拿去收藏!..._快捷键可以帮助自己

用HTML语言制作一个非常浪漫的生日祝福网,手把手教你制作炫酷生日祝福网页_用html做一个生日快乐网页-程序员宅基地

文章浏览阅读2.2w次,点赞317次,收藏636次。明天就是女朋友的生日了, 是时候展现专属于程序员的浪漫了!你打算怎么给心爱的人表达爱意?鲜花礼物?代码表白?还是创意DIY?或者…无论那种形式,快来秀我们一脸吧!_用html做一个生日快乐网页

推荐文章

热门文章

相关标签