【】Matlab 小波工具箱入门
- 格式:docx
- 大小:273.34 KB
- 文档页数:11
(2011-11-10 20:12:39)转载▼分类:学科知识标签:小波分析连续小波变换尺度系数信号最近想尝试一下小波的用法,就这matlab的帮助尝试了一下它的例子,顺便翻译了一下帮助的内容,发现matlab帮助做的确实不错,浅显易懂!现把翻译的文档写出来吧,想学习的共同学习吧!小波工具箱简介小波工具箱包含了图像化的工具和命令行函数,它可以实现如下功能:l 测试、探索小波和小波包的特性l 测试信号的统计特性和信号的组分l 对一维信号执行连续小波变换l 对一维、二维信号执行离散小波分析和综合l 对一维、二维信号执行小波包分解(参见帮助Using Wavelet Packets)l 对信号或图像进行压缩、去噪另外,工具箱使用户更方便的展示数据。
用户可以做如下选择:l 显示哪个信号l 放大感兴趣的区域l 配色设计来显示小波系数细节工具箱可以方便的导入、导出信息到磁盘或matlab工作空间。
具体详见File Menu Options一维连续小波分析这一部分来测试连续小波分析的特性。
连续小波分析只需要一个小波函数cwt。
在这一部分将学到如下内容:l 加载信号l 对信号执行连续小波变换l 绘制小波系数l 绘制指定尺度的小波系数l 绘制整个尺度小波系数中的最大值l 选择显示方式l 在尺度和伪频率之间切换l 细节放大l 在普通或绝对模式下显示系数l 选择执行小波分析的尺度使用命令行执行连续小波分析这个例子是一个包含噪声的正弦波1. 加载信号load noissin可以使用whos显示信号信息2. 执行连续小波变换c = cwt(noissin,1:48,'db4');函数cwt的参数分别为分析的信号、分析的尺度和使用的小波。
返回值c包含了在各尺度下的小波系数。
对于这里,c是一个48x1000的矩阵,每一行与一个尺度相关。
3. 绘制小波系数cwt函数可以接受第四个参数,来指定函数在执行结束后是否绘制连续小波变换系数的绝对值。
小波分析MATLAB工具箱简介MATLAB的小波分析一、小波分析用于降噪的基本过程1、分解过程:选定一种小波,对信号进行N层分解;2、作用阈值过程:对分解得到的各层系数选择一个阈值,并对细节系数进行软阈值处理;3、重建过程:降处理后的系数通过小波重建恢复原始信号;二、基本降噪模型函数一维离散小波分解命令Dwt [cA cD] = dwt(X,’wname’)使用小波’wname’对型号X 进行单层分解,求得的近似系数存放于数组cA中,细节系数存放在数组cD 中;[cA cD] = dwt(X,’wname’,’mode’,MODE) 利用MODE方式进行扩展[cA cD] = dwt(X,Lo_D,Hi_D) 利用指定滤波器进行小波分解Wanedec [C, L] = wavedec(X,N,’wname’) 使用wname的小波进行N层分解,C为层数,L为各层系数Idwt X= idwt(cA,cD,’wname’) 利用小波wname把近似系数CA和CD重建为上一层近似系数XX= idwt(cA,cD,’wname’,L) 重建至L层Waverec X= waverec(C,L,‘wname‘)重建为原始信号Wrcoef X = wrcoef(‘type’,C,L,’wname’,N) 通过分解系数重构指定的数,type为a 或者dX= wrcoef(‘type’,C,L,’wname’) 把分解系数重建至最高层Upcoef Y= upcoef(O,X,’wname’,N)用适当的滤波器作用在X上N次,求得重建系数Y,O为a表示低通滤波器,d表示高通滤波器Detcofe D= detcoef(C,L,N)从分解系数中提取第N层近似系数D= detcoef(C,L,N)提取至最后一层Appcoef A= appcoef(C,L,’wname’,N) 用小波从分解系数中提取第N层系数Wnoisest stdc = woisest(c,l,s)根据传入的小波分解系数[c,l]对s中标识的小波层数求得其标准差,作为对噪声强度的估计;Ddencmp [THR,SORH,KEEPAPP,CRIT] = ddencmp(IN1,IN2,X) 根据传入的参数IN1 和IN2所指定的方式,对输入信号X求得其降噪或压缩的各级阈值。
Matlab小波工具箱的使用2工具箱提供了如下函数做一维信号分析:在这一部分,可以学到l 加载信号l 执行一层小波分解l 从系数重建近似和细节l 显示近似和细节l 通过逆小波变换重建信号l 执行多层小波分解l 抽取近似系数和细节系数l 重构第三层近似l 重构第1、2、3层细节l 显示多层分解的结果l 从第三层分解重构原始信号l 从信号中去除噪声l 改善分析l 压缩信号l 显示信号的统计信息和直方图一维分析---使用命令行这个例子包含一个真实世界的信号---测量3天的电功耗。
这个信号很典型,因为它包含一个明显的测量噪声,而小波分析可以有效的移除噪声。
1. 加载信号load leleccum截取信号s = leleccum(1:3920);l_s = length(s);2. 对信号执行一层小波分解使用db1小波执行一层小波分解,执行下面的语句产生近似系数cA1、细节系数cD1 [cA1,cD1] = dwt(s,'db1');3. 从系数中构建近似和细节从系数cA1和cD1中构建一层近似A1和细节D1,执行以下代码A1 = upcoef('a',cA1,'db1',1,l_s);D1 = upcoef('d',cD1,'db1',1,l_s);或A1 = idwt(cA1,[],'db1',l_s);D1 = idwt([],cD1,'db1',l_s);4. 显示近似和细节subplot(1,2,1); plot(A1); title('Approximation A1')subplot(1,2,2); plot(D1); title('Detail D1')5. 使用逆小波变换恢复信号A0 = idwt(cA1,cD1,'db1',l_s);err = max(abs(s-A0))err =2.2737e-0136. 执行多层小波分解执行3层信号分解[C,L] = wavedec(s,3,'db1');函数返回3层分解的各组分系数C(连接在一个向量里),向量L里返回的是各组分的长度。
Matlab⼩波⼯具箱的使⽤3⼀维离散平稳⼩波分析离散平稳⼩波分析所⽤到的函数有swt⼩波分解和iswt⼩波重构。
在这⼀部分可以学到如下内容:l 加载信号l 执⾏平稳⼩波分解l 从⼩波系数中构造近似和细节l 显⽰第⼀层的近似和细节l 平稳⼩波逆变换恢复原始信号l 执⾏多层平稳⼩波分解l 重构第3层近似l 重构1、2、3层细节l 重构1、2层近似l 显⽰分解的结果l 从3层分解中重构原始信号l 除噪使⽤命令⾏实现⼀维分析1. 加载信号(⼀个噪声污染的多普勒效应信号)2. 设置变量s = noisdopp;对于SWT变换,如果需要在第k层分解信号,那么原始信号需要能够平分成2^k份。
所以如果原始信号的长度不满⾜要求,需要使⽤Signal Extension GUI⼯具或使⽤wextend函数来扩展它。
3. 执⾏⼀层平稳⼩波分解[swa,swd] = swt(s,1,'db1');函数执⾏将产⽣1层近似和细节的系数,两者和信号的长度是相等的,这也是平稳⼩波和普通⼩波不同的地⽅,从⽽使它在某些领域有好的效果。
4. 显⽰近似、细节⼩波系数显⽰⼀层近似和细节的系数subplot(1,2,1), plot(swa); title('Approximation cfs')subplot(1,2,2), plot(swd); title('Detail cfs')5. 使⽤平稳⼩波逆变换恢复原始信号A0 = iswt(swa,swd,'db1');重构的误差为err = norm(s-A0)2.1450e-0146. 从系数中构建近似和细节构建⼀层近似和细节,输⼊如下代码nulcfs = zeros(size(swa));A1 = iswt(swa,nulcfs,'db1');D1 = iswt(nulcfs,swd,'db1');显⽰结果如下subplot(1,2,1), plot(A1); title('Approximation A1');subplot(1,2,2), plot(D1); title('Detail D1');7. 执⾏多层平稳⼩波分解使⽤db1⼩波做3层⼩波分解[swa,swd] = swt(s,3,'db1');产⽣的近似系数在swa中,细节系数在swd中,⽽且它们有相同的长度。
MATLAB小波分析工具箱常用函数1. wfilters 函数:用于生成小波滤波器和尺度函数,可以根据指定的小波和尺度类型生成小波滤波器系数。
2. wavedec 函数:用于将信号进行小波分解,将输入信号分解为多个尺度系数和小波系数。
3. waverec 函数:用于将小波系数和尺度系数进行重构,将小波分解后的系数重构为信号。
4. cwt 函数:用于进行连续小波变换,可以获得信号在不同尺度上的时频信息。
5. icwt 函数:用于进行连续小波反变换,可以将连续小波变换的结果重构为原始信号。
6. cmorlet 函数:用于生成复数 Morlet 小波。
Morlet 小波是一种基于高斯调制正弦波的小波函数。
7. modwt 函数:用于进行无偏快速小波变换,可以获取多个尺度下的小波系数。
8. imodwt 函数:用于进行无偏快速小波反变换,可以将无偏快速小波变换的结果重构为原始信号。
9. wdenoise 函数:用于对信号进行去噪处理,可以去除信号中的噪声。
10. wavethresh 函数:用于对小波系数进行阈值处理,可以实现信号压缩。
11. wenergy 函数:用于计算小波系数的能量,可用于分析小波系数的频谱特性。
12. wscalogram 函数:用于绘制小波系数的时频谱图,可以直观地显示信号的时频信息。
13. wpdec 函数:用于进行小波包分解,可以将输入信号分解为多个尺度系数和小波系数。
14. wprec 函数:用于将小波包系数和尺度系数进行重构,将小波包分解后的系数重构为信号。
15. wptree 函数:用于提取小波包树的信息,可以获得小波包树的结构和节点信息。
这些函数可以实现小波分析中主要的操作和功能。
通过使用这些函数,你可以进行小波分析、信号去噪、信号压缩等应用。
同时,你也可以根据具体的需求使用这些函数进行函数的扩展和自定义。
使用 MATLAB 小波工具箱进行小波分析:
如上图所示的小波分解过程,可以调用 wfilters 来获得指定小波的分解和综合滤波器系数,例如:
以上例子,得到’db5’小波的分解和综合滤波器系数,并显示出来。
下面是wfilters的具体用法:
Wname 可指定为列表中的任意一种小波,直接调用
[Lo_D,Hi_D,Lo_R,Hi_R] = wfilters('wname')
会返回分解和综合滤波器系数。
如果只想返回其中的一些而不是全部,可以调用
[F1,F2] = wfilters('wname','type')
其中’type’可指定为4种类型,每种类型的具体意义详见matlab wfilters 帮助。
查看具体小波的信息
waveinfo(‘wname’)
获得一个标准的正交变换/双正交变换的尺度和小波函数(数字近似值)
[PHI,PSI,XVAL] = wavefun('wname',ITER)
[PHI1,PSI1,PHI2,PSI2,XVAL] = wavefun('wname',ITER)
例如
如果已知小波分解滤波器系数,计算小波变换的最简单方法就是
[C,S] = wavedec2(X,N,'wname')
[C,S] = wavedec2(X,N,Lo_D,Hi_D)
反过来,已知小波综合滤波器系数,计算反小波变换,只需
X = waverec2(C,S,'wname')
X = waverec2(C,S,Lo_R,Hi_R)
subplot(224),imagesc(cD);
其中C是小波变换后的结果数据,以一维矢量的形式组织,S是二维数组,记录了C中数据的分布形式,详见matlab 的帮助文档。
此外,dwtmode可以设定输入的边界处理方式。
提取小波的系数。
前面使用的wavedec2得到的[C,S]不是非常的直观,可以利用小波工具箱中的函数 appcoef2和detcoef2来提取近似矩阵和的n级的某一个细节矩阵。
A = appcoef2(C,S,'wname',N)
A = appcoef2(C,S,'wname')
D = detcoef2(O,C,S,N)
针对特定的小波系数矩阵进行阈值化处理
NC = wthcoef2('type',C,S,N,T,SORH)
NC = wthcoef2('type',C,S,N)
NC = wthcoef2('a',C,S)
NC = wthcoef2('t',C,S,N,T,SORH)
使用 wave2gray来显示小波分解的结果
关于wave2gray更多用法详见dipum_1.1.4 toolbox 的说明文档[官方网站]。
小波综合(重建):waverec2
X = waverec2(C,S,'wname')
X = waverec2(C,S,Lo_R,Hi_R)
[C,S]是使用小波分解函数wavedec2得到的小波矢量和矢量描述矩阵,或者符合这种规定形式的数据。
返回X是实数图像矩阵,由于计算误差,可能需要经过一些处理才能正常显示。