数字图像处理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后压缩后图');

图像:上文都以截图展示

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

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

在这里插入图片描述

  • 41
    点赞
  • 134
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 7
    评论
以下是使用MATLAB进行二维图像的小波变换处理的代码: ```matlab clear all; close all; clc; A = imread('poly.png'); % 读取图像 B = rgb2gray(A); % 将图像转换为灰度图像 % 小波压缩 \[C,S\] = wavedec2(B, 4, 'db1'); % 进行4级小波分解,使用db1小波基函数 Coeff_sort = sort(abs(C(:))); % 对小波系数进行排序 count = 1; for keep = \[.1 .05 .01 .005\] % 设置不同的保留比例 subplot(2,2,count) thresh = Coeff_sort(floor((1-keep)*length(Coeff_sort))); % 计算阈值 index = abs(C) > thresh; % 根据阈值进行系数选择 C_filter = C.*index; % 进行系数过滤 Areacon = uint8(waverec2(C_filter, S, 'db1')); % 进行小波重建 imshow(uint8(Areacon)) % 显示重建后的图像 title(\['', num2str(keep*100),'%'\], 'FontSize',12) count = count+1; end set(gcf, 'Position', \[1750 100 1750 2000\]) % 设置图像窗口位置和大小 ``` 这段代码首先读取了一个二维图像,并将其转换为灰度图像。然后使用`wavedec2`函数对图像进行4级小波分解,使用db1小波基函数。接着对小波系数进行排序,并根据设定的保留比例计算阈值,然后根据阈值对小波系数进行选择和过滤。最后使用`waverec2`函数进行小波重建,并显示重建后的图像。 #### 引用[.reference_title] - *1* [【图像分解】基于小波变换实现二维图像分解matlab代码](https://blog.csdn.net/m0_60703264/article/details/129638818)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [二维离散小波变换及其在MATLAB数字图像处理应用](https://blog.csdn.net/code2day/article/details/129171006)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

来一块葱花饼

谢谢好兄弟的支持~

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值