sanmuhaifeng 发表于 2011-9-22 20:26

用czt函数进行频率细化的程序遇到问题,求达人

我最近想用CZT这个函数,来细化频率,结果出现问题,发现细化出来的幅值正确,可是频率不正确。
程序如下:
clc
clear

fs=1024;
N=1024;
n=0:N-1;
t=(n)/fs;
s=5*cos(2*pi*150*t)+10*cos(2*pi*200*t);

m=1024;   
f1=100;
f2=300;
w=exp(-j*2*pi*(f2-1)/(m*fs));%%%表示为沿z平面的螺旋线点之间的比例,也表示为变换的步长
a=exp(j*2*pi*f1/fs);%%%%表示为螺旋线开始点,即变换起点

y=fft(s,m);
fy=(0:length(s)-1)*fs/length(s);

z=czt(s,m,w,a);
fz=(0:length(s)-1)*(f2-f1)/length(s)+f1;

subplot(2,1,1)
plot(fy(1:512),abs(y(1:512))*2/m);
title('fft');
subplot(2,1,2)
plot(fz,abs(z)*2/m);
title('czt');


结果如下:

sanmuhaifeng 发表于 2011-9-23 09:42

问题解决了,我其中一句写错了。
w=exp(-j*2*pi*(f2-f1)/(m*fs));%%%表示为沿z平面的螺旋线点之间的比例,也表示为变换的步长
应该是f2-f1, 不是f2-1。

tommytom 发表于 2014-8-23 13:58

学习交流
页: [1]
查看完整版本: 用czt函数进行频率细化的程序遇到问题,求达人