【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​

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

相关推荐
南檐巷上学9 小时前
基于Zynq-7020的带有正弦波发生器的8051软核设计
单片机·嵌入式硬件·fpga开发·fpga
思尔芯S2C9 小时前
FPGA原型验证中的内存模型应用:基于DDR5的Linux系统启动与测试
fpga开发·内存模型·ddr4·ddr5·memory model·hbm3·prototyping
hai31524754318 小时前
RISC-V CVA6 AXI适配器+DMA桥蜂鸟E203处理器的总线接口单元(BIU)仲裁器
驱动开发·fpga开发·硬件架构·硬件工程·精益工程
高速上的乌龟1 天前
Lattice LFCPNX-100 HSB+Fpga开发详解:2.3 Hololink 顶层模块深度全解析
linux·fpga开发
Ricky05531 天前
搭载实时 FPGA 处理系统的航天器上用于海上监视的超分辨率YOLO目标检测技术(意大利2026年研究)
yolo·目标检测·fpga开发
kaizq1 天前
在线设计模仿平台StepFPGA应用实践
fpga开发·verilog编程·在线设计仿真·小脚丫stepfpga·图形化设计·risc-v_soc·ima-copilot-ds
学不懂飞行器1 天前
电赛保姆级教程】从炸管到国一:电赛电源类(DC-DC/单相逆变)硬核避坑与拓扑全指南
stm32·单片机·嵌入式硬件·电赛·fft
cjie2211 天前
图像缩放需要哪些参数和端口
计算机视觉·fpga开发
思尔芯S2C1 天前
FPGA Prototyping That Creates Useful Pre-Silicon Evidence
fpga开发
啄缘之间1 天前
10.【学习】SPI & UART 验证环境与测试用例
开发语言·经验分享·学习·fpga开发·测试用例·verilog