完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>
扫一扫,分享给好友
基于谱减法的语音增强程序如下:
clear all; [speech,fs,nbits]=wavread('d.wav'); winsize=256; n=0.04; size=length(speech); numofwin=floor(size/winsize); ham=hamming(winsize)'; hamwin=zeros(1,size); enhanced=zeros(1,size); x=speech'+n*randn(1,size); noisy=n*randn(1,winsize); N=fft(noisy); nmag=abs(N); for q=1:2*numofwin-1 frame=x(1+(q-1)*winsize/2:winsize+(q-1)*winsize/2); hamwin(1+(q-1)*winsize/2:winsize+(q-1)*winsize/2)= hamwin(1+(q-1)*winsize/2:winsize+(q-1)*winsize/2)+ham; y=fft(frame.*ham); mag=abs(y); phase=angle(y); for i=1:winsize; if mag(i)-nmag(i)>0 clean(i)=mag(i)-nmag(i); else clean(i)=0; end end spectral=clean.*exp(j*phase); enhanced(1+(q-1)*winsize/2:winsize+(q-1)*winsize/2)=enhanced(1+(q-1)*winsize/2:winsize+(q-1)*winsize/2)+real(ifft(spectral)); end for i=1:size if hamwin(i)==0 enhanced(i)=0; else enhanced(i)=enhanced(i)/hamwin(i); end end SNR1=10*log10(var(speech')/var(noisy)); SNR2=10*log10(var(speech')/var(enhanced-speech')); wavwrite(x,fs,nbits,'enhanced.wav'); figure(1); subplot(3,1,1);plot(speech'); title('原始语音波形'); xlabel('样点数');ylabel('幅度'); axis([0 2.5*10^4-0.3 0.3]); subplot(3,1,2);plot(x); title('加噪语音波形'); xlabel('样点数');ylabel('幅度'); axis([0 2.5*10^4-0.3 0.3]); subplot(3,1,3);plot(enhanced); title('增强语音波形'); xlabel('样点数');ylabel('幅度'); axis([0 2.5*10^4-0.3 0.3]); 请高人帮忙看下 Error using ==> plus Matrix dimensions must agree. 该怎么改啊 |
|
相关推荐
1个回答
|
|
新手,看不懂!
|
|
|
|
你正在撰写答案
如果你是对答案或其他答案精选点评或询问,请使用“评论”功能。
1697 浏览 1 评论
200圆!求助大佬给一份VSG并网和离网模式的simulink仿真
1973 浏览 0 评论
MATLAB(3)--矩阵的引用(sub2ind、ind2sub、reshape函数使用)
2792 浏览 0 评论
3130 浏览 0 评论
4105 浏览 1 评论
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2024-11-27 17:03 , Processed in 0.535491 second(s), Total 75, Slave 58 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191 工商网监 湘ICP备2023018690号