【FFT】信号处理——快速傅里叶变换【通俗易懂】

快速傅里叶变换(Fast Fourier Transform, FFT)是一种用于将信号从时间域转换到频率域的算法。

傅里叶变换的核心思想是:任何周期性信号都可以分解成多个不同频率的正弦波或余弦波的叠加。

简单来说,FFT可以帮助我们理解一个信号的频率成分,即它由哪些频率组成,每个频率对应的振幅是多少,如下图所示。

1、时间转换为频率

假设我们有一个随时间变化的信号(例如音乐、心跳信号、电压波形等),这个信号可以用一系列数值来表示,比如一个音频文件中的采样值。在时间域,信号随时间变化,而通过傅里叶变换,我们可以将这些时间域的信号转换为频率域的表示。

具体步骤如下:

①采样:首先,我们需要对时间信号进行采样,得到一系列离散的数值点。假设采样频率是 fs,采样点数是 N,即我们有 N 个采样值。

②计算频率分量:FFT 将这些采样点转换为频率域的分量。结果是一个复数序列,其中每个复数值对应一个频率分量。FFT 的结果告诉我们信号中不同频率的"权重"是多少。

③频率分辨率:FFT 结果中的每个点对应一个频率值。计算方式为:

其中,fs​ 是采样频率,N 是采样点数。这个 Δf 是频率分辨率,即每个频率分量之间的间隔。

④频率范围:FFT 的输出频率范围是从 0 到 fs/2(即采样频率的一半),这是因为奈奎斯特定理表明,采样频率必须是最高频率分量的两倍,才能避免混叠。

2、幅值计算

FFT 的输出结果是复数形式,表示频率分量的振幅和相位。每个频率分量的幅值(或叫"强度")可以通过复数的模计算出来。对于复数 Z=a+bi,其模可以表示为:

具体步骤:

①FFT 输出的复数形式:FFT 的结果是频率分量的复数形式 X(f),其中实部 a 和虚部 b 分别表示余弦和正弦分量的系数。

②计算幅值:我们对每个复数值计算其模,即:

这个模值就是每个频率分量对应的幅值,也可以理解为该频率在信号中的"强度"或"能量"。

幅值归一化:通常,FFT 输出的幅值需要除以采样点数 N 才能得到正确的幅值大小,尤其是当信号是周期性的或者我们对幅值的绝对大小感兴趣时。即:

3、总结

FFT 是一种将时间域信号转换为频率域信号的高效算法。

时间信号通过采样得到离散的数据点,FFT 将这些数据点转换成不同频率分量的复数值。

每个频率分量的幅值(即"强度")可以通过计算复数的模得到,而频率则是由采样频率和采样点数决定的。

频率域的表示让我们能够理解信号中包含了哪些频率成分,以及每个频率成分的强度如何。

相关推荐
强盛机器学习~4 天前
2026年SCI一区新算法-傅里叶变换优化算法(FTO)-公式原理详解与性能测评 Matlab代码免费获取
算法·matlab·进化计算·群体智能·傅里叶变换·元启发式算法
黄大刀6 天前
STM32F单片机实现ADC采集正弦波的FFT变换和逆变换
stm32·单片机·嵌入式硬件·fft
我爱C编程12 天前
【3.4】双口RAM模块的FPGA实现
fpga开发·fpga·fft·双口ram
tzy23316 天前
为什么电网负荷变化影响的是频率
电网·频率·发电机·有功功率
B325帅猫-量子前沿技术研究所16 天前
MATLAB函数fft(data,N)输入注意事项
matlab·傅里叶分析·fft·噪声功率谱
我爱C编程18 天前
【3.3】FFT变换的FPGA实现整体概述以及模块划分
fpga开发·fft·多级fft·二维分治fft
斯内科21 天前
FFT快速傅里叶变换
算法·fft
我爱C编程22 天前
【3.2】FFT/IFFT变换的数学原理概述与MATLAB仿真
算法·matlab·fpga·fft·ifft
我爱C编程1 个月前
【3.1】基于FPGA的FFT/IFFT模块开发——前言/目录
fpga开发·教程·通信·fft·傅里叶变换
Sagittarius_A*2 个月前
傅里叶变换:从空域到频域的图像分析【计算机视觉】
图像处理·人工智能·python·opencv·计算机视觉·傅里叶变换·频域滤波