`
womendu
  • 浏览: 1513619 次
  • 性别: Icon_minigender_2
  • 来自: 北京
文章分类
社区版块
存档分类
最新评论

小波图像分解 Matlab 程序 - V3.0版

阅读更多
下面给出 V3.0 版的 小波分解程序,主要是增加了输出参数 scf (size of coef cell matrix),画图方式也增加了塔式显示方式(原来只有分层显示方式)。
%----------------------------------------------------------%
小波图像分解 Matlab 程序 - V2.0版
小波图像重构 Matlab 程序 - V2.0版
%----------------------------------------------------------%
%----------------------------------------------------------%
小波分解矩阵 Matlab 程序 - V3.0版
%----------------------------------------------------------%
function [coef,scf]=mywavedec2(x,N,wname)
%----------------------------------------------------------%
% 函数 MYWAVEDEC2() 对输入矩阵 x 进行 dim 层分解,得到相应的分解系数矩阵 y
% 输入参数:x —— 输入矩阵
% N —— 分解级数
% wname —— 分解所用的小波函数
% 输出参数:scf —— 存储各级分解系数矩阵的大小以及原始(图像)矩阵的大小
% coef —— 分解系数矩阵,其结构如下:
% coef = {cA_N;cV_N;cH_N;cD_N;cV_N-1;cH_N-1;cD_N-1;……;cV_1;cH_1;cD_1}
%
% Copyright by Zou Yuhua ( chenyusiyuan )
% Version: 3.0, Date: 2008-07-08
%----------------------------------------------------------%
% 求出小波函数的滤波器组系数向量
[Lo_D,Hi_D] = wfilters(wname,'d');
lf=length(Lo_D);
% 画出原始图像
imshow(x);title('Original Image');
% 标明图像大小
[r,c]=size(x);
xlabel(['Size : ',num2str(r),'*',num2str(c)]);
% 将矩阵x的数据格式转换为适合数值处理的double格式
xd=double(x);
[rx,cx]=size(x);
[o2sa,f1sa,rsx]=sizcoef([rx,cx],lf,N); a=[o2sa,f1sa,rsx]
coef=[];
scf=[rx,cx];
for i=1:N
[cA,cV,cH,cD]=mydwt2(xd,Lo_D,Hi_D); % 第 i 级小波分解
xd=cA; % 将第 i 级分解得到的低频系数矩阵作为第 i+1 级分解的源矩阵
outmp={cV;cH;cD}; % 将第 i 级分解得到的高频系数矩阵cV,cH,cD存入细胞矩阵 outmp
scf=[size(cV);scf]; % 将各级分解系数矩阵的大小存入矩阵 scf
coef=[outmp;coef]; % 将细胞矩阵 outmp 存入输出矩阵 coef,coef将由空矩阵变为细胞矩阵
end
% 迭代结束后,矩阵 coef 中保存的是各级分解中的高频系数矩阵
% 故需将迭代后得到的矩阵 cA,即第 dim 级低频矩阵存入矩阵 coef
coef=[cA;coef];
scf=[size(cA);scf];
plotcoef(N,wname,coef);
plotcoef2one(N,wname,coef,rsx);
function plotcoef2one(N,wname,coef,rsx)
% 画出小波分解系数的塔式结构图
rsx=rsx(end:-1:1,:);
tmpcoef=[];
tA=wkeep(coef{1},rsx(1,:),'c');
tmpcoef=tA;
tA=uint8(tA); tA(end,:)=255; tA(:,end)=255;
for j=1:N
tV=wkeep(coef{(j-1)*3+2},rsx(j,:),'c');
tH=wkeep(coef{(j-1)*3+3},rsx(j,:),'c');
tD=wkeep(coef{(j-1)*3+4},rsx(j,:),'c');
tV=uint8(tV); tH=uint8(tH); tD=uint8(tD);
if j<N
tV(end,:)=255; tV(:,end)=255;
tH(end,:)=255; tH(:,end)=255;
tD(end,:)=255; tD(:,end)=255;
else
tV(end,:)=255; tH(:,end)=255;
end
tmpcoef=[tA,tV;tH,tD];stc=size(tmpcoef);
if stc>=rsx(j+1,:)
tA=tmpcoef(1:rsx(j+1,1),1:rsx(j+1,2));
else
tmpcoef=tmpcoef([1:end-1,end-2:end-1],[1:end-1,end-2:end-1]);
tA=tmpcoef(1:rsx(j+1,1),1:rsx(j+1,2));
end
tA=uint8(tA); tA(end,:)=255; tA(:,end)=255;
end
figure;
sc=tA;
[rx,cx]=size(sc);
imshow(sc);
xlabel(['Size : ',num2str(rx),'*',num2str(cx)]);
title(['Wavelet Decomposition -- Wavelet Type: ',wname,' ,Levels: ',num2str(N)]);
function plotcoef(N,wname,coef)
% 画出各级低频、高频系数矩阵的层次结构图
% 首先建立一个名为“Wavelet Decomposition -- Wavelet Type: ,Levels: ”的图像窗口
figure('Name',['Wavelet Decomposition -- Wavelet Type: ',wname,' ,Levels: ',num2str(N)]);
% 图像的第1行显示低频系数,置中,左右两个subplot为空
subplot(N+1,3,2);
yt=uint8(coef{1});
[yrow,ycol]=size(yt);
imshow(yt);title( ['Approximation A',num2str(N)]);
xlabel(['Size : ',num2str(yrow),'*',num2str(ycol)]);
% 第2-(N+1)行显示各级高频系数
titllist={['Vertical Detail V'];['Horizontal Detail H'];['Diagonal Detail D']};
pn=2; % pn 是子图的显示序号
for pr=1:N
for pc=1:3
subplot(N+1,3,pn+2);
yt=[];
yt=uint8(coef{pn});
[yrow,ycol]=size(yt);
imshow(yt);title([ titllist{pc},num2str(N-pr+1)]);
xlabel(['Size : ',num2str(yrow),'*',num2str(ycol)]);
% 每行的第一个图像的Y轴,显示该行高频系数对应的分解级别
if mod(pn+2,3)==1
ylabel(['Level ',num2str(N-pr+1)]);
end
pn=pn+1;
end
end
function [o2sa,f1sa,rsx]=sizcoef(sx,lf,N)
% 函数 sizcoef 计算小波分解的卷积过程中各分解级的矩阵大小
% 输入参数:sx —— 原始(图像)矩阵的大小
% lf —— 滤波器的长度
% N —— 分解级数
% 输出参数:o2sa —— 根据公式 sigLen+filLen-1 得到的卷积后矩阵大小
% f1sa —— 经过下抽样后本级分解系数矩阵的大小
% rsx —— 通过 f1sa 求出对应于原始矩阵的有效区域大小
% Copyright by Zou Yuhua ( chenyusiyuan ), Version: 1.0, Date: 2008-07-07
o2sa=sx;
f1sa=[0 0];
osx=sx;
for i=1:N
ot=osx+lf-1;
sa=floor(ot/2);
o2sa=[o2sa;ot];
f1sa=[f1sa;sa];
osx=sa;
end
rsx=zeros(N+1,2);
rsx(1,:)=sx;
addln=0;
for j=2:N+1 % 在每级卷积后,序列的长度会增长 floor(lf-1/2),
aln=floor((addln+lf-1)/2);% 据此可由卷积后的序列长度求出原来的输入序列长度
tsx=f1sa(j,:)-aln;
rsx(j,:)=tsx;
addln=aln;
end
function [cA,cV,cH,cD]=mydwt2(x,Lo_D,Hi_D)
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
% 函数 MYDWT2() 对输入的r*c维矩阵 x 进行二维小波分解,输出四个分解系数子矩阵[LL,HL,LH,HH]
% 输入参数:x —— 输入矩阵,为r*c维矩阵。
% Lo_D,Hi_D —— 小波分解的滤波器组系数向量
% 输出参数:cA,cV,cH,cD —— 是小波分解系数矩阵的四个相等大小的子矩阵
% cA:低频部分分解系数; cV:垂直方向分解系数;
% cH:水平方向分解系数; cD:对角线方向分解系数。
%
% Copyright by Zou Yuhua ( chenyusiyuan ), Version: 3.0, Date: 2008-07-07
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
[row,col]=size(x); % 读取输入矩阵的大小
for j=1:row % 首先对输入矩阵的每一行序列进行一维离散小波分解
tmp1=x(j,:);
[ca1,cd1]=mydwt(tmp1,Lo_D,Hi_D,1);
% tmp1 长度为 row ,滤波器长度为 lf
% 则 [ca1,cd1] 的总长为 2*floor(( row + lf -1 )/2)
x1(j,:)=[ca1,cd1]; % 将分解系数序列存入缓存矩阵 x1 中
end
[row1,col1]=size(x1); % row1=row + lnf -1, col1=col+lnf-1
for k=1:col1 % 再对缓存矩阵 x1 的每一列序列进行一维离散小波分解
tmp2=x1(:,k);
[ca2,cd2]=mydwt(tmp2,Lo_D,Hi_D,1);
x2(:,k)=[ca2,cd2]'; % 将分解所得系数存入缓存矩阵 x2 中
% 注意不要遗漏了上一行代码中的转置符号“ ’”。 Matlab 6.5 及以下较低的版本不支
% 持行、列向量的相互赋值,故要把行向量[ca2,cd2]转置为列向量,再存入 x2 的相应列
end
[row2,col2]=size(x2);
cA=x2(1:row2/2,1:col2/2); % cA是矩阵x2的左上角部分
cV=x2(1:row2/2,col2/2+1:col2); % cV是矩阵x2的右上角部分
cH=x2(row2/2+1:row2,1:col2/2); % cH是矩阵x2的左下角部分
cD=x2(row2/2+1:row2,col2/2+1:col2); % cD是矩阵x2的右下角部分
function [cA,cD] = mydwt(x,lpd,hpd,dim)
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
% 函数 [cA,cD]=MYDWT(X,LPD,HPD,DIM) 对输入序列x进行一维离散小波分解,输出分解序列[cA,cD]
% 输入参数:x——输入序列;
% lpd——低通滤波器;
% hpd——高通滤波器;
% dim——小波分解层数。
% 输出参数:cA——平均部分的小波分解系数;
% cD——细节部分的小波分解系数。
%
% Copyright by Zou Yuhua ( chenyusiyuan ), Version: 1.0, Date: 2007-11-10
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
cA=x; % 初始化cA,cD
cD=[];
for i=1:dim
cvl=conv(cA,lpd); % 低通滤波,为了提高运行速度,调用MATLAB提供的卷积函数conv()
dnl=downspl(cvl); % 通过下抽样求出平均部分的分解系数
cvh=conv(cA,hpd); % 高通滤波
dnh=downspl(cvh); % 通过下抽样求出本层分解后的细节部分系数
cA=dnl; % 下抽样后的平均部分系数进入下一层分解
cD=[cD,dnh]; % 将本层分解所得的细节部分系数存入序列cD
end
function y=downspl(x)
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
% 函数 Y=DOWMSPL(X) 对输入序列进行下抽样,输出序列 Y。
% 下抽样是对输入序列取其偶数位,舍弃奇数位。例如 x=[x1,x2,x3,x4,x5],则 y=[x2,x4].
%
% Copyright by Zou Yuhua ( chenyusiyuan ), Version: 1.0, Date: 2007-11-10
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
N=length(x); % 读取输入序列长度
M=floor(N/2); % 输出序列的长度是输入序列长度的一半(带小数时取整数部分)
i=1:M;
y(i)=x(2*i);
原始图像:
小波分解系数塔式结构图:
函数 sizcoef 返回的信息:
lf =
16
[o2sa,f1sa,rsx] =
192 196 0 0 192 196
207 211 103 105 96 98
118 120 59 60 48 49
74 75 37 37 24 24
分享到:
评论

相关推荐

    二维小波分解源码matlab程序,带操作演示录像,matlab2021a版本运行

    3.内容:二维小波分解源码matlab程序,带操作演示录像,matlab2021a版本运行。 % 多小波正变换 woman1=D'*X*D; % 多小波正变换 woman2=D*woman1*D'; 4.注意事项:注意MATLAB左侧当前文件夹路径,必须是程序所在...

    小波分解和重构MATLAB程序

    小波分解是将一个信号或图像分解成不同频率成分的过程,这些成分由小波函数的不同尺度和位置表示。2:1抽样比例指的是在分解过程中,每一层细节信息的分辨率减半,而时间或空间轴上的采样点数保持不变,这样可以保证...

    小波(包)分解MATLAB程序

    在提供的"小波(包)分解MATLAB程序"中,我们可以预期找到两个MATLAB脚本:一个用于处理原始信号,另一个处理加噪声的信号。这些脚本可能包含了以下步骤: 1. **数据加载**:使用`load`函数读取信号数据。 2. **...

    图像处理小波分析matlab程序

    总之,"图像处理小波分析matlab程序"是一个实用的资源,它涵盖了小波分析在图像处理中的各种应用。通过学习和实践这个程序,不仅可以深入理解小波分析的原理,还能掌握如何在MATLAB环境中实现这些高级功能,对于提升...

    小波分析在图像中的应用-matlab程序

    1. 小波分解:MATLAB中的`wavedec`函数用于进行离散小波分解,将图像分解为多个高频和低频系数,每个系数对应图像的不同特征。 2. 小波重构:与分解相对应,`waverec`函数可以将小波系数重新组合回原始图像,这在...

    图像的小波分解和系数显示matlab程序包

    这个MATLAB程序包是专门针对小波分解设计的,可以帮助用户快速有效地分析图像的频谱分布。下面我们将详细介绍这个程序包中的各个功能。 1. **wavefilter.m**: 这个函数可能涉及到滤波操作,它可能使用小波变换对...

    图像融合拼接MATLAB程序-图像处理程序集.rar

    每种方法都有其特定的MATLAB实现,如使用wavedec2进行小波分解。 5. **融合图像生成**:将提取的特征按照预设的融合规则组合,形成新的图像。这一步通常涉及自定义函数或调用MATLAB内置的图像操作函数。 6. **后...

    对图像用小波进行层小波分解MATLAB小波变换处理二维图像.rar

    本资源"对图像用小波进行层小波分解MATLAB小波变换处理二维图像.rar"显然是一份教程或代码集合,旨在指导用户如何在MATLAB中应用小波变换对图像进行层小波分解。 首先,小波变换的基础概念是关键。小波(Wavelet)...

    二维二进小波的快速分解与重构算法matlab实现-ex7-4.rar

    二维二进小波的快速分解与重构算法matlab实现-ex7-4.rar 使用matlab来实现非正交二次样条二维二进小波的快速分解和重构 编程实现例7.4中可分离二维二进小波的快速分解与重构算法 算法实现 使用matlab来实现...

    基于matlab的小波图像融合(多种算法)

    基于MATLAB实现的小波图像融合,利用了MATLAB强大的数学计算能力和丰富的图像处理工具箱,为开发者提供了便捷的平台。 在MATLAB中,小波图像融合通常涉及到以下几个主要知识点: 1. **小波理论**:小波分析是一种...

    小波变换图像处理MATLAB源程序-小波变换图像处理MATLAB源程序.rar

    - 学习这些MATLAB源程序可以帮助理解小波变换的具体实现过程,加深对小波理论的理解。 - 实践中需要注意优化算法性能,例如选择合适的小波基、调整分解层数和阈值策略等。 这个压缩包中的源程序涵盖了以上所述的...

    图像小波分解与重构代码_matlab

    小波分解是将一个图像分解成不同分辨率层次的细节和结构部分。它利用小波函数的局部性和多分辨率特性,使得图像的信息可以在时间和频率域上同时进行分析。MATLAB提供了许多内置的小波工具箱,如Wavelet Toolbox,...

    matlab程序-基于小波变换与神经网络的图像压缩

    在本项目中,开发者可能利用MATLAB的小波工具箱进行小波变换,使用神经网络工具箱构建和训练神经网络模型,实现图像压缩的全过程。 5. **性能评估**: 压缩效果通常通过两个主要指标评估:压缩比(CR)和峰值...

    MATLAB小波三级分解图像

    首先把图片倒入MATLAB,利用小波基对图像进行三层分解。第一次分解产生一个高频,三个低频,第二次对第一次产生的高频分解,产生一个低频三个高频;第三次对第二次的低频分解产生三个高频一个低频。三层分解后产生一...

    程序-MATLAB-小波分解(6层),通过编译,直接运行

    小波分解是一种强大的数学工具,常用于信号处理和图像分析,尤其在MATLAB环境中得到了广泛应用。MATLAB提供了丰富的函数库支持小波分析,使得研究人员和工程师可以方便地进行多分辨率分析,提取信号的局部特征。 小...

    图像小波分解.zip_图像分解matlab_图像小波分解_小波_小波分解_小波图像

    利用MATLAB程序进行的图像的小波分解

    图像融合拼接MATLAB程序-waveletrh.m.zip

    标题中的“图像融合拼接...为了深入了解并使用这个程序,你需要具备MATLAB基础,了解图像处理基本概念,特别是小波分析的相关知识。同时,阅读和理解"a.txt"文件的内容至关重要,它将帮助你正确运行和应用这个程序。

    matlab小波去噪

    在这个“matlab小波去噪”压缩包中,你将找到关于如何在Matlab环境中应用小波去噪的详细程序和注释。 首先,小波去噪的基础是小波理论。小波分析是一种数学工具,它将复杂的信号分解成不同频率和时间的局部成分,这...

    matlab下小波图像融合几种代码

    本节将详细介绍基于MATLAB的小波图像融合算法及其代码实现。 1. **小波理论基础** 小波分析是一种多尺度分析方法,能够同时在时间和频率域内对信号进行分析。在图像融合中,小波分解可以将图像分解为多个不同频段...

    小波图像分解与合成.rar_Standard Test Images_matlab 小波 图像_多小波_小波_小波图像分解

    3次非标准小波分解和重构, 使用两种小波:Haar小波和db9小波 设计3级小波分解和重构图像的程序 用你自己的照片作对象,显示其中任一种小波图像分解和重构过程 使用Haar小波时,计算阈值分别为0,5,10和20的情况下...

Global site tag (gtag.js) - Google Analytics