查看单个帖子
旧 2008-06-20, 11:26   #2
baltaM
初级会员
 
注册日期: 2008-06-09
年龄: 37
帖子: 12
声望力: 17
baltaM 正向着好的方向发展
默认

N=11;a=(N-1)/2;
m=0:N-1;W1=(2*pi/N)*m;
Hideal=[0.01,ones(1,3),0.2,zeros(1,6)];%此处为插值
k1=0:floor((N-1)/2);k2=(floor((N-1)/2)+1):N-1;
angH=[-a*2*pi*k1/N,a*2*pi*(N-k2)/N];
H=Hideal.*exp(j*angH);
h=ifft(H,N);%此处不必取实数
[H2,w]=freqz(h,1);
figure(1);
subplot(3,1,1);
plot(W1(1:5)/pi,Hideal(1:5),'o',Wd,Hdr);
axis([0,1,-0.2,1.2]);title('频率样本');
xlabel('频率(单位pi)');ylabel('Hideal(k)');
figure(2);
subplot(3,1,2);
stem(m,h);title('单位脉冲响应');
xlabel('n');ylabel('h(n)');
figure(3);
subplot(3,1,3);
A=max(abs(H2));
plot(w/pi,20*log10(abs(H2)/A));
axis([0,1,-100,10]);grid;
title('幅度响应');xlabel('频率(单位pi)');ylabel('dB');
你的程序中要注意抽样点,H(k)的选择原则是通带内为1,阻带内为0,另外在插值时最好不要从0直接跳变到1
baltaM 当前离线   回复时引用此帖