MATLAB函数fft(data,N)输入注意事项

x_fft = fft(data, L);

若data的数据长度为1001

这个函数中的L的取值,可以取四种情况:

  1. 不设置,缺省
  2. 是取数据本身长度:L 1= length(data)=1001;(推荐使用这个!)
  3. 取:L 2= 2^nextpow2(L1); L2=1024,总是大于或者等于L1
  4. 取L 3=2^(floor(log2(L 1))); L3=512,总是小于或者等于L1(实验室使用,要注意可能出现的错误!)

第一种情况:不设置

第二种情况:L 1= length(data)

第三种情况: L 3=2^(floor(log2(L 1))),可以看到对噪声在某些频段放大或者缩小了!

第四种情况:L 2= 2^nextpow2(L1)

实验室程序和使用数据长度fft(data,N(data))的对比

产生一个拉莫尔进动频率数据序列,数据序列长度为N=10000:然后求PSD获取共振位置,结果如图所示:

正常算法:

L_Data = length(Data);

Sy=fft(Data);

实验室算法:

L_Data = length(Data);

nfft = 2^(floor(log2(L_Data)));
Sy=fft(Data,nfft);

实验室算法获得的结果为:5750Hz, 而正常算法获取的结果为:7000kHz, 满足正确要求。

正常算法: N=10000,实验室算法:N=8192;输入fft(data,N)中导致两种差距较大的结果,值得注意!

例2:,可以看到,实验室算法依旧会出错。

可以看到PSD的幅度和原始信号幅度不一样,修改下FFT程序:

function freq,Sy = FFTfunction3(Data,Fs)

%==========================获得信号真实幅度

L_Data = length(Data);

Sy=fft(Data,L_Data);

Sy=abs(Sy)*2/L_Data;

Sy = Sy(1:L_Data/2+1);

freq = Fs*(0:L_Data/2)/L_Data;

end

则可以获得如下FFT结果,幅度和真实信号幅度一致,等于2

错误原因:

fft(data,N), 若N小于数据data的长度,自动补零,使得这些零也默认为真实信号数据,这些信号显然不符合真实信号规律,经过FFT后自然就会影响频率的大小!因此fft的第二个参数就用缺省情况或者等于数据长度,输入或大或小都会对FFT结果产生影响:这种影响包括噪声功率谱大学(PSD)和频率大小!

相关推荐
xiao5kou4chang6kai42 天前
MATLAB机器学习、深度学习--从数据预处理到模型训练
深度学习·机器学习·matlab·数据预处理
bubiyoushang8882 天前
电力线信道“五类噪声”仿真MATLAB
开发语言·matlab
cici158742 天前
彩色图像模糊增强(Fuzzy Enhancement)MATLAB 实现
开发语言·算法·matlab
kaikaile19952 天前
图像稀疏化分解 + 压缩感知(CS)重建 MATLAB
开发语言·计算机视觉·matlab
yugi9878382 天前
PNCC(Power-Normalized Cepstral Coefficients)— MATLAB 实现
开发语言·人工智能·matlab
cooldog123pp2 天前
cplex完全安装手册,适配matlab和python!
人工智能·python·matlab·cplex
2zcode2 天前
项目文档:基于MATLAB语音信号变声算法设计与实现
算法·matlab·语音识别
天疆说3 天前
在 Ubuntu 24.04 上安装 MATLAB R2021b
数据库·ubuntu·matlab
guygg883 天前
二维弹塑性有限元分析(von Mises 等向硬化)— MATLAB 实现
开发语言·人工智能·matlab
天疆说3 天前
在 Ubuntu 的 VSCode 中配置 MATLAB
vscode·ubuntu·matlab