举个C++例子
时间: 2023-07-11 17:20:17 浏览: 93
好的,这里是一个使用 fftw_plan_dft_1d() 函数创建一维 DFT 计划并执行的 C++ 代码示例:
```c++
#include <iostream>
#include <fftw3.h>
using namespace std;
int main() {
int n = 8;
fftw_complex *in, *out;
fftw_plan plan;
in = (fftw_complex*) fftw_malloc(sizeof(fftw_complex) * n);
out = (fftw_complex*) fftw_malloc(sizeof(fftw_complex) * n);
plan = fftw_plan_dft_1d(n, in, out, FFTW_FORWARD, FFTW_ESTIMATE);
for(int i = 0; i < n; i++) {
in[i][0] = i; // 实部赋值
in[i][1] = 0; // 虚部赋值
}
fftw_execute(plan);
for(int i = 0; i < n; i++) {
cout << out[i][0] << " + " << out[i][1] << "i" << endl;
}
fftw_destroy_plan(plan);
fftw_free(in);
fftw_free(out);
return 0;
}
```
该程序创建了一个长度为 8 的输入信号和输出信号数组,使用 fftw_plan_dft_1d() 函数创建了一个计划,然后对输入信号进行赋值,并使用 fftw_execute() 函数执行计划,最后输出变换后的结果。最后需要使用 fftw_destroy_plan() 函数销毁计划并释放内存。
阅读全文