gpt4 book ai didi

c++ - 如何在 Eigen 中对 MatrixXd 进行 FFT?

转载 作者:搜寻专家 更新时间:2023-10-31 00:30:30 24 4
gpt4 key购买 nike

看起来下面的代码是正确的:

#include <Eigen/Core>
#include <unsupported/Eigen/FFT>

int main ()
{
Eigen::FFT<float> fft;
Eigen::Matrix<float, dim_x, dim_y> in = setMatrix();
Eigen::Matrix<complex<float>, dim_x, dim_y> out;

for (int k = 0; k < in.rows(); k++) {
Eigen::Matrix<complex<float>, dim_x, 1> tmpOut;
fft.fwd(tmpOut, in.row(k));
out.row(k) = tmpOut;
}

for (int k = 0; k < in.cols(); k++) {
Eigen::Matrix<complex<float>, 1, dim_y> tmpOut;
fft.fwd(tmpOut, out.col(k));
out.col(k) = tmpOut;
}
}

但这必须在编译时指定矩阵的大小,当我将Matrix更改为MatrixXd时,编译时会出错。我想知道如何在 MatrixXd 上进行 FFT,以便在运行时指定矩阵大小。

最佳答案

将所有变量更改为 Eigen::Dynamic 大小而不是对它们进行硬编码,它应该可以工作。或者,使用内置类型:

#include <Eigen/Core>
#include <unsupported/Eigen/FFT>

int main ()
{
size_t dim_x = 28, dim_y = 126;
Eigen::FFT<float> fft;
Eigen::MatrixXf in = Eigen::MatrixXf::Random(dim_x, dim_y);
Eigen::MatrixXcf out;
out.setZero(dim_x, dim_y);

for (int k = 0; k < in.rows(); k++) {
Eigen::VectorXcf tmpOut(dim_x);
fft.fwd(tmpOut, in.row(k));
out.row(k) = tmpOut;
}

for (int k = 0; k < in.cols(); k++) {
Eigen::VectorXcf tmpOut(dim_y);
fft.fwd(tmpOut, out.col(k));
out.col(k) = tmpOut;
}
return 0;
}

关于c++ - 如何在 Eigen 中对 MatrixXd 进行 FFT?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36719364/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com