【3.3】FFT变换的FPGA实现整体概述以及模块划分

目录

1.FFT变换的FPGA实现概述

2.FFT变换的FPGA实现模块划分

[2.1 第一级16点FFT运算](#2.1 第一级16点FFT运算)

[2.2 旋转因子复数乘法](#2.2 旋转因子复数乘法)

[2.3 第二级16点FFT运算](#2.3 第二级16点FFT运算)

[2.4 模平方计算单元](#2.4 模平方计算单元)


1.FFT变换的FPGA实现概述

在本课题中,我们将实现256点的FFT变换。其中256点FFT采用二维分治策略进行。

即:

将256点输入拆分为16组×16点,先对每组做16点FFT→乘以旋转因子→再做16点FFT→输出结果。也就是通过2次16点FFT变换,来实现256点FFT,从而大大简化系统实现的复杂性。

其对应的数学公式可以表示为:

其中,中括号中的表达式

这一级做的就是内层16点FFT。

然后做蝶形运算,每个蝶形单元:

可以统一表示为:

其中,A、B为输入复数;W为旋转因子。

2.FFT变换的FPGA实现模块划分

根据上一个小节关于FFT变换实现的基本原理,我们给出如下的整体设计构架(大致的模块划分,后续课程,如果细微的调整,会做说明):

2.1 第一级16点FFT运算

第一级16点FFT蝶形运算,其内部由多级基16蝶形运算单元阵列构成,采用流水线结构,对每组16点数据执行蝶形计算X=A+W16p​⋅B 。该模块包含复数加法器与复数乘法器,调用内置旋转因子W16。这个模块运算完成,进入归一化阶段。通过这个模块可以完成256点分治FFT的内层16点变换,大幅降低FFT计算量。

2.2 旋转因子复数乘法

这个模块通过FPGA的内部ROM核预存储256点旋转因子W256的余弦、正弦值。根据当前数据组序号,查表取出对应旋转因子。执行复数乘法(a+jb)(c+jd)=(ac−bd)+j(ad+bc),最后将乘法结果直接输出。通过这个模块衔接两级16点FFT,完成分治FFT的跨级相位校正。

2.3 第二级16点FFT运算

与第一级FFT16完全一致,仅输入位宽更宽。对转置后的16点组再次执行基16蝶形运算。完成256点FFT的外层16点变换,得到完整频域复数结果。通过这个模块最终完成全部256点快速傅里叶变换,输出频域数据。

2.4 模平方计算单元

对复数实部、虚部进行补码绝对值运算,对绝对值后的实部、虚部分别做平方乘法。将两个平方结果相加,得到幅度平方:

∣X(k)∣^2=Xr^2​+Xi^2​

最终输出作为频谱能量结果。

相关推荐
何如呢2 小时前
FIFO的IP核学习
学习·fpga开发
星华云2 小时前
[FPGA] Spartan6 单总线协议 (One-Wire) 读取DS18B20温度传感器
fpga开发·温度传感器·ds18b20·单总线协议·one-wire bus
s09071363 小时前
ZYNQ 软硬件协同踩坑日记:PS写BRAM后,PL端连续4个地址读出相同数据的原因与解决办法
fpga开发·zynq·硬件设计
tiger11920 小时前
FPGA独立实现LLM推理方案——FlighLLM
fpga开发·llm·fpga·ai推理
fei_sun21 小时前
Systemverilog和Verilog区别
fpga开发
史蒂芬_丁1 天前
TI F28P65 使用 ePWM 模块模拟 SPI 时钟的详细方法
单片机·嵌入式硬件·fpga开发
fei_sun1 天前
HDLBits-Verilog Practice
fpga开发
Aaron15881 天前
RFSOC+VU13P中在线部分可重构技术的应用分析
人工智能·算法·matlab·fpga开发·重构·信息与通信·信号处理
qxl_7999151 天前
PCB元件对位:相机采集+YOLO定位完整工程方案(含坐标转换公式)
数码相机·yolo·fpga开发