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)和频率大小!

相关推荐
吃好睡好便好8 小时前
矩阵的乘法运算
数据结构·人工智能·学习·线性代数·算法·matlab·矩阵
学不懂飞行器12 小时前
电赛保姆级教程】从炸管到国一:电赛电源类(DC-DC/单相逆变)硬核避坑与拓扑全指南
stm32·单片机·嵌入式硬件·电赛·fft
listhi52012 小时前
基于MATLAB的自适应粒子群算法(APSO)实现大规模分类特征选择
算法·matlab·分类
可编程芯片开发13 小时前
基于PSO粒子群优化的配电网可靠性指标matlab仿真
matlab·pso粒子群优化·配电网可靠性
yu859395813 小时前
基于MATLAB的层合板等效模量及极限强度计算实现
开发语言·matlab
ytttr87313 小时前
基于MATLAB的三维六面体有限元网格模型
开发语言·matlab
吃好睡好便好14 小时前
矩阵的求幂运算
人工智能·学习·线性代数·算法·matlab·矩阵
强盛机器学习~15 小时前
2026年SCI一区新算法-灰叶猴优化算法(GLO)-公式原理详解与性能测评 Matlab代码免费获取
算法·matlab·进化计算·群体智能·智能优化算法·元启发式算法
Evand J15 小时前
【图像去噪例程】自适应窗口长度的滑动窗口中值滤波(附MATLAB下载链接)
图像处理·计算机视觉·matlab·滤波·自适应
简简单单做算法15 小时前
基于AES的图像加解密算法matlab仿真
matlab·aes·图像加解密