0

0

C++如何实现快速傅里叶变换FFT_C++数字信号处理算法代码【数学】

穿越時空

穿越時空

发布时间:2026-02-25 12:13:19

|

510人浏览过

|

来源于php中文网

原创

应使用fftw库实现fft,因其经过高度优化且避免手写cooley-tukey的边界、索引、缩放等错误;安装后链接-lfftw3 -lfftw3f,注意内存对齐、计划复用及手动归一化。

c++如何实现快速傅里叶变换fft_c++数字信号处理算法代码【数学】

FFT 在 C++ 中该用哪个库实现

直接用 FFTW,别手写。自己实现 Cooley-Tukey 容易出边界错误、位逆序索引错、缩放因子漏处理,且性能远不如 FFTW 经过高度优化的 SIMD 和多线程版本。

常见误区是看到“C++ 没内置 FFT”就去抄网上各种 20 行递归版,结果输入长度不是 2 的幂就崩,或者实数输入输出顺序混乱。

  • FFTW 支持任意长度(通过混合算法),但 2 的幂最快;安装后链接 -lfftw3 -lfftw3f
  • 若不能引入第三方,std::complex + 自己写迭代版 Cooley-Tukey 仅建议用于教学或固定小尺寸(如 1024 点以内)
  • C++23 的 <numbers></numbers><complex></complex> 不提供 FFT,别白找

FFTW 基本三步怎么写才不崩

核心是内存生命周期、计划复用、方向与缩放三个坑点。下面是最小安全用法:

#include <fftw3.h>
#include <vector>
<p>std::vector<std::complex<double>> fft(const std::vector<std::complex<double>>& x) {
int n = x.size();
std::vector<std::complex<double>> out(n);</p><pre class='brush:php;toolbar:false;'>// 1. 分配对齐内存(关键!)
fftw_complex* in  = fftw_alloc_complex(n);
fftw_complex* out_ptr = fftw_alloc_complex(n);

// 2. 复制数据(FFTW 不接受 std::vector.data() 直接传入)
for (int i = 0; i < n; ++i) {
    in[i][0] = x[i].real();
    in[i][1] = x[i].imag();
}

// 3. 创建一次计划,缓存重用(不要每次调用都 fftw_plan_dft_1d)
static fftw_plan plan = fftw_plan_dft_1d(n, in, out_ptr, FFTW_FORWARD, FFTW_ESTIMATE);

fftw_execute(plan);

// 4. 复制回 vector,并注意:FFTW 不自动归一化
std::vector<std::complex<double>> result(n);
for (int i = 0; i < n; ++i) {
    result[i] = std::complex<double>(out_ptr[i][0], out_ptr[i][1]);
}

// 清理(实际中应放在 RAII 类里,这里仅示意)
fftw_free(in);
fftw_free(out_ptr);
return result;

}

立即学习C++免费学习笔记(深入)”;

常见错误:fftw_plan_dft_1d 第四个参数传 FFTW_MEASURE 会导致首次调用极慢;忘记 fftw_free 引发内存泄漏;用 std::vector::data() 直接传给 FFTW 导致段错误(因内存未按 16 字节对齐)。

Pliny
Pliny

创建、分享和重新组合AI应用程序

下载

实数序列 FFT 怎么避免虚部乱跳

fftw_plan_dft_r2c_1d 而不是强行塞进复数接口。它专为实输入设计,输出是“半复数”格式:长度为 n/2+1 的数组,含 DC 项和 Nyquist 项(若 n 为偶),其余复数共轭对称隐含。

  • 输入是 double*,输出是 fftw_complex*,但只填前 n/2+1 个元素
  • 逆变换必须用 fftw_plan_dft_c2r_1d,且输出需手动除以 n 归一化
  • 若你拿 std::vector<double></double> 输入,别用 .data() 直接传——仍要确保 16 字节对齐,否则 FFTW 可能崩溃或结果异常

为什么 FFT 结果相位总差 π 或幅度翻倍

根本原因是缩放约定不一致。FFTW 默认不做归一化,正向变换不除 n,逆变换也不除 n;而 MATLAB、NumPy 默认正向除 n,逆向不除;有些论文公式又要求双向都除 √n

所以:如果你对比 Python 的 np.fft.fft(x),FFTW 输出要手动除以 n 才对得上;如果做滤波后再 ifft,记得 ifft 后再除以 n,否则信号幅度爆炸。

另一个隐藏点:fftw_plan_dft_1d 的方向参数用 FFTW_FORWARD 还是 FFTW_BACKWARD 决定了指数符号,但不改变缩放行为——缩放永远由你手动控制。

真正难的不是写循环,是搞清你的数据来源、目标平台、数学文档用的是哪套归一化惯例。这点漏掉,所有调试都是徒劳。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

智谱清言 - 免费全能的AI助手
智谱清言 - 免费全能的AI助手

智谱清言 - 免费全能的AI助手

相关专题

更多
fprintf在matlab中的用法
fprintf在matlab中的用法

fprintf是MATLAB中用于格式化输出的函数。fprintf的基本语法为“fprintf(fileID, format, A)”,其中,fileID是一个标识符,用于指定要写入的文件,如果要将数据写入到命令窗口中,则可以使用1作为fileID的值,format是一个字符串,用于指定输出的格式,A是要输出的数据。

496

2023.09.28

数据分析工具有哪些
数据分析工具有哪些

数据分析工具有Excel、SQL、Python、R、Tableau、Power BI、SAS、SPSS和MATLAB等。详细介绍:1、Excel,具有强大的计算和数据处理功能;2、SQL,可以进行数据查询、过滤、排序、聚合等操作;3、Python,拥有丰富的数据分析库;4、R,拥有丰富的统计分析库和图形库;5、Tableau,提供了直观易用的用户界面等等。

1027

2023.10.12

Matlab中length函数的用法
Matlab中length函数的用法

在Matlab中,length函数用于返回向量、数组或字符串中的元素个数。想了解更多length函数的相关内容,可以阅读本专题下面的文章。

330

2023.11.22

Matlab中axis函数用法
Matlab中axis函数用法

在Matlab中,axis函数用于控制坐标轴的范围和比例。想了解更多axis函数的相关内容,可以阅读本专题下面的文章。

777

2023.11.23

subplot在matlab中的用法
subplot在matlab中的用法

subplot在matlab中用于在同一个图窗中创建多个子图。通过指定子图的行数、列数和当前绘图位置,可以在每个子图中绘制不同的图形。想了解更多subplot在matlab中的用法,可以访问下面的文章。

149

2023.11.27

scilab和matlab的区别
scilab和matlab的区别

scilab和matlab的区别:1、注释符号;2、预设变量的表示;3、操作符的用法;4、矩阵的定义与调用;5、程序的编辑与执行;6、数据类型;7、函数库;8、图形界面;9、社区支持与生态系统;10、跨平台兼容性;11、价格。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

190

2023.12.11

Matlab如何四舍五入
Matlab如何四舍五入

Matlab可以通过round函数和格式化输出函数来对数值来进行四舍五入操作。更多关于Matlab相关的问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

422

2023.12.12

Matlab中axis函数用法介绍
Matlab中axis函数用法介绍

在Matlab中,axis函数用于设置当前坐标轴的范围和刻度。想了解更多axis函数的相关内容,可以阅读本专题下面的文章。

163

2023.12.13

batoto漫画官网入口与网页版访问指南
batoto漫画官网入口与网页版访问指南

本专题系统整理batoto漫画官方网站最新可用入口,涵盖最新官网地址、网页版登录页面及防走失访问方式说明,帮助用户快速找到batoto漫画官方平台,稳定在线阅读各类漫画内容。

21

2026.02.25

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
C# 教程
C# 教程

共94课时 | 10.1万人学习

C 教程
C 教程

共75课时 | 4.9万人学习

C++教程
C++教程

共115课时 | 19.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号