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

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

相关推荐
小麦嵌入式6 小时前
FPGA入门(一):手把手教你用 Vivado 创建工程并仿真
stm32·单片机·嵌入式硬件·mcu·fpga开发·硬件架构·硬件工程
m0_46644103詹湛16 小时前
(一)FPGA :基础概念详解(Xilinx平台)
笔记·学习·fpga开发·verilog
xyx-3v1 天前
ZYNQ 简介
fpga开发
xyx-3v1 天前
Zynq-7000
fpga开发
xyx-3v2 天前
zynq7010和zynq7020的区别
fpga开发
xyx-3v2 天前
LUT(Look-Up Table,查找表)的定义与核心概念
fpga开发
明德扬2 天前
K7+AD9144 多模式实测|8 种 JESD204B 配置全覆盖验证
fpga开发
xyx-3v3 天前
SOC相对于版上系统的优势是什么?
fpga开发
Aaron15884 天前
RFSOC+VU13P+GPU 在6G互联网中的技术应用
大数据·人工智能·算法·fpga开发·硬件工程·信息与通信·信号处理
stars-he4 天前
基于 Design Compiler 的 UDP Payload 追加控制模块综合与门级后仿真
笔记·fpga开发·udp