共回答了21个问题采纳率:95.2%
sinx中角频率omega为1,周期为2×pi/omega=2*pi,2*pi/步长=628,你花的就是周期2*pi的函数
fft就是把时域上的曲线变成频域上的曲线,所以fft变换后横坐标是频率,比如你的这个函数,注意到频域图中第三个点出出现最大值,计算2/1257×100=0.159,其实它就是sinx的频率,即1/(2*pi)=0.159,不过你只用stem(abs(fft(y1)));这条语句显然不能表示横坐标的情况,一般横坐标是0~采样频率,并且由于采样定理,进一步缩小为0~采样频率/2.,也就是说,横轴坐标应该是
f=(0:1256)/1257*100;
纵坐标上,你用了abs,所以应该是幅值.
另外,fft指快速傅立叶变换,其变换点是2^n个,你虽然没有指定,不过程序仍然是这么做的,所以你下次根据数据多少制定变换点数就行了,比如1024
最后,可以参见matlab中关于fft的帮助
1年前
追问
4
非常感谢,你回答的很认真。不过我还是有不理解的地方……
既然这个函数频率就是1/(2*pi)=0.159,那怎样写语句才能在频谱图上看出它的频率就是0.159呢?
另外,你写的 “横轴坐标应该是f=(0:1256)/1257*100;” 我也看不懂~
f=(0:1256)/1257*100;
这句就是用来输出频率的横坐标的,因为你采样频率是100Hz,所以横轴就是0-100Hz。
换个简单的角度来想,如果你只用plot(fft())这样的语句,那么它的横坐标就是数据点的位置,1,2,3,...,1257,现在你要用0~100Hz表示。
f=(0:1256)/1257*100;
stem(f,abs(fft(y1)));
这样你就能在频谱图上看到了。
还得在强调一次,应该是只取一半的点
f=(0:1256/2)/1257*100;
fft1=abs(fft(y1));
stem(f,fft1(1:1256/2+1));