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

相关推荐
Matlab程序猿21 小时前
【MATLAB源码-第431期】基于MATLAB的六自由度机械臂正逆运动学建模、阻尼逆解与多目标平滑轨迹仿真。
matlab·轨迹规划·逆运动学·正运动学·六自由度机械臂·移动底盘机械臂·阻尼最小二乘
yugi9878381 天前
MATLAB 实现平板裂纹扩展模拟、气孔/夹杂物分析
开发语言·matlab
EW Frontier2 天前
6G ISAC新范式:基于智能漏波天线的Wi‑Fi通感一体化系统设计与实测【附MATLAB+python代码】
开发语言·python·matlab·music·isac·doa·wi‑fi
jllllyuz2 天前
MATLAB 回声抵消(AEC)、噪声抑制(NS)、自动增益控制(AGC)完整实现
开发语言·matlab
yongui478342 天前
MATLAB 使用遗传算法求解微电网优化配置数学模型
开发语言·matlab
rit84324992 天前
基于博弈论的小区分簇算法MATLAB实现
开发语言·算法·matlab
2zcode2 天前
基于MATLAB的家用场景下扫地机器人路径规划研究设计
开发语言·matlab·机器人
可编程芯片开发2 天前
基于双Qlearning强化学习的温差发电系统电压动态补偿算法matlab仿真
算法·matlab·双qlearning强化学习·电压动态补偿·温差发电系统
yu85939582 天前
matlab实现ARMA(自回归移动平均)模型
开发语言·matlab·回归
民乐团扒谱机2 天前
【微实验】平滑轨迹的数学基石:二次贝塞尔曲线原理、插值逻辑、形态控制与MATLAB全解析
开发语言·matlab