- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我正在尝试使用 FFTW3 进行实数到复数的 FFT 变换。到目前为止,我已经设法使用异地转换来完成它,但是我在实现它的就地版本时遇到了麻烦。我的印象是,就地转换你唯一需要改变的是:1)确保你的数据数组有足够的空间来容纳操作的复杂部分,2)当你创建计划时使用相同的输入和输出数据的地址,3)执行计划时,对输入和输出数据使用相同的地址。我已经做了所有这些事情,但我总是得到错误的结果。我正在对值为 [[1,1],[1,1]] 的 2x2 数组执行二维 FFT。预期结果(根据 Matlab)是一个 2x2 数组,其值为 [[4+0i, 0+0i], [0+0i, 0+0i]]。当我进行异地变换时,我得到了这个结果。但是当我进行就地转换时,我得到以下 [[2+0i, 0+0i],[2+0i,0+0i]]。我选择了 2x2 大小的 2D FFT,因为输入和输出数据的长度相同并且有助于调试。这是我的代码:
bool inplace = true; // true for in-place, false for out-of-place
int dim_size[] = {2,2};
int N[] = {2,2};
int data_length = N[0]*(N[1]); // 2 * (2) = 4
int data_fft_length = N[0]*(N[1]/2+1); // 2 * (2/2+1) = 4
float* h_data_r = nullptr; // fftw data array
fftwf_complex* h_data_c = nullptr; // fftw data array (only used in out-of-place tranforms)
// allocate fftw memory
if(inplace) {
h_data_r = (float*)fftwf_malloc(data_fft_length*sizeof(fftwf_complex));
h_data_c = (fftwf_complex*)h_data_r;
} else {
h_data_r = (float*)fftwf_malloc(data_length*sizeof(float));
h_data_c = (fftwf_complex*)fftwf_malloc(data_fft_length*sizeof(fftwf_complex));
}
// create plane
unsigned int flags = FFTW_MEASURE;
fftwf_plan m_plan = fftwf_plan_dft_r2c_2d(N[0],N[1],h_data_r,h_data_c,flags);
// initialize data array
h_data_r[0] = 1;
h_data_r[1] = 1;
h_data_r[2] = 1;
h_data_r[3] = 1;
// execute fft plan
fftwf_execute(m_plan);
std::cout << "result:" << std::endl;
for(int i = 0; i < data_fft_length; ++i)
std::cout << "[" << i << "]: " << h_data_c[i][0] << " " << h_data_c[i][1] << std::endl;
变量“就地”决定 FFT 变换是否就地。有人能告诉我我的代码有什么问题吗?代码非常简单。我没有做任何特别的事情。我只想要一个就地 FFT 实数到复数变换。如果您不愿意检查我的代码,但您有一个非常简单的 fftw3 就地 fft 转换代码,请随时复制粘贴它。
谢谢。
编辑 1:我进一步简化了代码,现在我使用 fftwf_plan_dft_r2c_2d() 来创建计划,使用 fftwf_execute() 来执行计划。问题依旧。
编辑 2:我将代码翻译成 cufft,它应该与 fftw3 具有几乎相同的语法。我对袖口有同样的问题。但默认情况下,cuFFT 启用了 FFTW 兼容模式 (CUFFT_COMPATIBILITY_FFTW_PADDING)。如果我使用标志 CUFFT_COMPATIBILITY_NATIVE 禁用 FFTW 兼容模式,则就地转换与 cuFFT 一起工作得很好。奇怪的是,根据 cuFFT 文档,CUFFT_COMPATIBILITY_FFTW_PADDING 应该在您进行批量转换时有所作为。就我而言,我不进行任何批量转换。我现在更糊涂了。
最佳答案
几个月前我设法解决了这个问题。结果我不得不使用高级计划创建界面并手动设置 inembed 和 onembed 指针的值。
关于c++ - FFTW3、cuFFT 和就地变换,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22594010/
上周我一直在用 FFTW 编程一些二维卷积,方法是将两个信号传递到频域,相乘,然后返回。 令人惊讶的是,只有当输入大小小于固定数字时,我才能得到正确的结果! 我发布了一些工作代码,其中我采用简单的初始
有没有办法检查 - 凋零 FFTW 是以单精度还是 double 编译的? 最佳答案 如果库的名称以 f 为后缀,则为单精度。否则就是双标。例如, libfftw3.a 是 double libfft
我正在学习如何使用 Fortran 处理 FFTW 包。为了生成一个易于验证的示例,我计算了一个二维平面的功率谱,我用两个不同的叠加波填充它。这样,我就可以确切地知道功率谱中的峰值在哪里。 由于 FF
我需要使用具有不同算术精度和多线程计划的 FFTW。 我需要为所有精度设置多线程?像这样: fftwf_init_threads(); fftwf_plan_with_nthreads(nthread
我正在尝试在 C 中使用 fftw3.3.5 进行 DFT。但是我目前在将 DFT 应用于实际数据时遇到了麻烦,它会导致一些奇怪的结果,比如极大的数字,以及不对称的东西。 这是测试代码: #inclu
我正在使用 FFTW 来计算二维复数数据的逆 DFT。默认设置(复数到复数)的输出是复数,虚部不为零。但是,我只对结果的实部感兴趣,而不对复数部分感兴趣。 FFTW 的交错实数复数输出对我来说并不理想
我在程序中使用 FFTW3 对 2D 数组(大约 3k x 3k,复杂数据类型)进行一些处理。 该计划最激烈的部分基本上是这样做的: Break the array up into N threads
我正在读取一个原始声音文件,并尝试对其运行 fft,目的是在最后获取 PSD,但我在开始时收到了一个错误,我可以'不太明白,希望在这里得到一些帮助,代码是: #include #include i
我使用以下代码来执行复数数组的 COMPLEX IFFT(我必须获得复数结果): #include #include #include #include #include #include
我正在努力为 FFTW 操作实现更好的性能。出于这个原因,我决定使用智慧文件来创建计划,但问题是它无法从智慧文件中加载计划(导出智慧效果很好)。我试图将智慧导出到一个文件,并在下一个程序运行时将其加载
我想在线程中使用 fftw3。但是代码粘贴在http://codepad.org/lIjdGF5z导致“double free or corruption”错误。如何正确调用线程中的 fftw3 例程
我的最终目标是从单声道波形文件中提取所有低于 15KHz 的声音信息。该程序将样本加载到内存中,并将其表示为 16 位有符号整数数组。 我用的是FFTW,它有复数多维fft、实数多维fft、实数一维f
我正在尝试在拆分数组上使用 fftw (3.3.4)。我从 C/MEX 指南 (PDF: http://www.researchgate.net/publictopics.PublicPostFile
我安装了一个新系统和上面的所有库。但是,我对 fftw 有疑问。 cmake 命令后出现以下错误 CMake Error at /usr/share/cmake/Modules/FindPackage
我正试图让 FFTW 在 C 中工作。它曾经为另一个项目(在 JNI 中)工作,我或多或少地从那个项目中复制代码,遗憾的是没有结果。 首先我生成一个正弦信号,如下所示: double* generat
我正在尝试使用 FFTW 库计算 53k 双样本的 FFT,并在此基础上猜测信号的基频是多少。样本由sndfile库在wav输入文件的基础上生成(程序加载wav文件,生成double数据的样本并保存到
我对信号处理还很陌生,所以请原谅我的吐槽。我已经下载并安装了适用于 Windows 的 FFTW。文档没问题,但我仍有疑问。 我的总体目标是从计算机上的声卡捕获以 44100 采样/秒采样的原始音频数
我正在使用 FFTW 的线程版本(一个 FFT 库)来尝试加速双 CPU 机器上的一些代码。这是只有 1 个线程的时间输出: 131.838u 1.979s 2:13.91 99.9% 这里有 2 个
我想知道是否可以存储来自 FFTW 的一维 FFT 调用的转置矩阵。考虑我的矩阵 nrows_1 x w_size。目前它存储在大小为 w_size 的 block 中 for (ix = 0 ; i
我实现了一个 fftw (fftw.org) 示例来使用快速傅立叶变换...这是代码.... 我加载了一张我从 uint8_t 转换为 double 的图像(此代码工作正常...)。 string b
我是一名优秀的程序员,十分优秀!