以下代码产生一个污染的正弦曲线。
init=1000;
[xref,x]=wnoise(5,11,7,init);
(1)对曲线使用'sym4'小波进行5层分解,使用wdencmp全局阈值对上述污染的曲线进行去噪;
(2)对曲线使用'sym4'小波进行5层分解,使用wdencmp多层阈值对上述污染的曲线进行去噪,使用软阈值。你的程序代码和运行结果截图粘贴在下面。
![](https://profile-avatar.csdnimg.cn/default.jpg!4)
用Matlab使用wdencmp进行去燥
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
1条回答 默认 最新
关注
clc; clear; %加载信号 load leleccum; %采样点 s=leleccum(300:2000); %画出原始信号 subplot(2,2,1);plot(s);title('原始信号');grid on;axis tight; %% 用sym4小波对原始信号进行5层小波分解并提取系数 [c,l]=wavedec(s,5,'sym4'); ca5=appcoef(c,l,'sym4',5); cd5=detcoef(c,l,5); cd4=detcoef(c,l,4); cd3=detcoef(c,l,3); cd2=detcoef(c,l,2); cd1=detcoef(c,l,1); %对信号进行强制性去噪处理:将每层的高频系数置零 cdd5=zeros(1,length(cd5)); cdd4=zeros(1,length(cd4)); cdd3=zeros(1,length(cd3)); cdd2=zeros(1,length(cd2)); cdd1=zeros(1,length(cd1)); c1=[ca5 cdd5 cdd4 cdd3 cdd2 cdd1]; s1=waverec(c1,l,'sym4'); subplot(2,2,2);plot(s1);title('强制去噪后信号');grid on;axis tight; %% 用默认阈值对信号进行去噪 % 用ddencmp函数获得信号的默认阈值 [THR,SORH,KEEPAPP]=ddencmp('den','wv',s); s2 =wdencmp('gbl' ,s,'sym4',5,THR,SORH,KEEPAPP); subplot(2,2,3);plot(s2);title('ddencmp/wdencmp默认阈值去噪后信号');grid on;axis tight; %% 用多层软阈值去噪,利用wthresh函数产生阈值 thr=thselect(s,'rigrsure'); softd5=wthresh(cd5,'s',thr); softd4=wthresh(cd4,'s',thr); softd3=wthresh(cd3,'s',thr); softd2=wthresh(cd2,'s',thr); softd1=wthresh(cd1,'s',thr); c2=[ca5 softd5 softd4 softd3 softd2 softd1]; s3=waverec(c2,l,'sym4'); subplot(2,2,4);plot(s3);title('多层软阈值去噪后信号');grid on;axis tight;
以下为运行结果截图:
注意这里有一个新的函数
thselect
,需要将softd5-softd1
的阈值选择为信噪比最优阈值,可以利用该函数进行选择,具体用法可参考Matlab文档。解决 无用评论 打赏 举报
悬赏问题
- ¥15 metadata提取的PDF元数据,如何转换为一个Excel
- ¥15 关于arduino编程toCharArray()函数的使用
- ¥100 vc++混合CEF采用CLR方式编译报错
- ¥15 coze 的插件输入飞书多维表格 app_token 后一直显示错误,如何解决?
- ¥15 vite+vue3+plyr播放本地public文件夹下视频无法加载
- ¥15 c#逐行读取txt文本,但是每一行里面数据之间空格数量不同
- ¥50 如何openEuler 22.03上安装配置drbd
- ¥20 ING91680C BLE5.3 芯片怎么实现串口收发数据
- ¥15 无线连接树莓派,无法执行update,如何解决?(相关搜索:软件下载)
- ¥15 Windows11, backspace, enter, space键失灵