使用小波变换进行音频去噪,实验环境:Matlab
推荐课程:数字信号处理(北京交通大学 陈后金) 第八章内容
B站链接:https://www.bilibili.com/video/BV1at411Q75D?p=101
(慕课上也有)
%读取原信号
[audio,Fs] = audioread("summer.wav");
[len,~] = size(audio);
%加噪声
n = audio + 0.03.*randn([len,1]);
%求信噪比
snr0 = snr(audio,n-audio)
%画图
subplot(211);plot(audio);
title('原信号');
subplot(212);plot(n);
title('含噪信号,信噪比=13.5231');
也不一定非选这个sym8,也可以选其他的小波,matlab有很多可供选择
lev =5;
%选择"sym8"小波进行去噪
wname = 'sym8';
%选取两种阈值规则:minimaxi与sqtwolog
[dnsig2,c2,l2,threshold_Minimax] = wden(n,'minimaxi','h','mln',lev,wname);
[dnsig3,c3,l3,threshold_DJ] = wden(n,'sqtwolog','h','mln',lev,wname);
%画图
subplot(211);plot(dnsig2)
title('sym8小波去噪 -信噪比16.8500 -阈值规则Minimax ');grid on
subplot(212);plot(dnsig3);
title('sym8小波去噪 -信噪比15.2136 -阈值规则DonohoJohnstone ');grid on;
%求信噪比
sym2 = snr(audio,dnsig2-audio)
sym3 = snr(audio,dnsig3-audio)
sound(dnsig3,Fs)
%%绘制出db2的尺度函数和小波函数
Iter=20;
wname='sym8';
[s,w,t]=wavefun(wname,Iter);
subplot(211);plot(t,s);
title('db2的尺度函数');
subplot(212);plot(t,w);
t=title('db2的小波函数');
去噪效果如下:
绘制出db2的尺度函数和小波函数
%%绘制出db2的尺度函数和小波函数
Iter=20;
wname='db2';
[s,w,t]=wavefun(wname,Iter);
subplot(211);plot(t,s);
title('db2的尺度函数');
subplot(212);plot(t,w);
t=title('db2的小波函数');
%选择"db2"小波进行去噪
wname = 'db2';
lev = 4;
[xd1,~,~,~] = wden(n,'sqtwolog','s','mln',lev,wname);
[xd2,~,~,~] = wden(n,'minimaxi','s','mln',lev,wname);
subplot(211);plot(xd1);grid on
title('db2小波去噪 -信噪比10.9619 -阈值规则sqtwolog')
subplot(212);plot(xd2);grid on
title('db2小波去噪 -信噪比12.5183 -阈值规则minimaxi')
dbsnr1=snr(audio,xd1-audio)
dbsnr2=snr(audio,xd2-audio)