维纳滤波

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
举例:基于频域维纳滤波的语音增强

还是利用上面的模型:

y(n)=x(n)+w(n)

这里y(n)是麦克风接收的带噪语音,x(n)是干净语音信号,w(n)为白噪声。显然相关函数我们无法得知。

利用一种近似的处理思路:利用前面几个分帧不带语音,估计噪声,从而得到噪声的功率谱近似,利用带噪语音功率减去噪声功率,得到

H(ωk) = Pxy(ωk) / Pyy(ωk) = Pxx(ωk) / (Pxx(ωk)+Pnn(ωk)) = (Pyy(ωk)−Pnn(ωk))/ Pyy(ωk)

利用估计出的维纳滤波器,即可实现信号的频域滤波。这里只是想到的一个实际例子,至于参数估计、迭代方式则是百花齐放了。

附上主要代码:

nw = 512; ni = 64;
NIS = 100;
Y = fft(enframe(y,hamming(nw),ni)');
Yab = abs(Y);
Nest = mean(Yab(:,1:NIS),2);
Yest = zeros(size(Y));
for i = 1:size(Y,2)
    Yest(:,i) = Yab(:,i).*((Yab(:,i)-Nest)./Yab(:,i));
end
Ye = Yest.*exp(1j*angle(Y));
result = zeros(1,length(y));%estimation
for i =1:size(Y,2);
    pos = ((i-1)*ni+1):((i-1)*ni+nw);
   result(pos) = result(pos)+real(ifft(Ye(:,i))).';
end
result = result/max(abs(result));

上面思路处理结果:
在这里插入图片描述

可以看出维纳降噪多少还是有些效果的,H(ωk) = Pxy(ωk) / Pyy(ωk) = Pxx(ωk) / (Pxx(ωk)+Pnn(ωk))= 11 + 1/SNR可以看出SNR越小,维纳滤波器衰减越大。

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值