10 #include <unsupported/Eigen/FFT>
14 #include "oops/util/Logger.h"
20 void fft_fwd_f(
const int & kk,
const double * xx,
double * ff) {
21 static Eigen::FFT<double> fft;
22 std::vector<double> grid(kk);
23 const unsigned int size = kk/2+1;
24 std::vector<std::complex<double> > coefs(size);
26 for (
int jj = 0; jj < kk; ++jj) grid[jj] = xx[jj];
30 for (
unsigned int jj = 0; jj < size; ++jj) {
31 ff[2*jj] = coefs[jj].real();
32 ff[2*jj+1] = coefs[jj].imag();
38 void fft_inv_f(
const int & kk,
const double * ff,
double * xx) {
39 static Eigen::FFT<double> fft;
40 std::vector<double> grid(kk);
41 std::vector<std::complex<double> > coefs(kk);
43 const std::complex<double> zero(0.0, 0.0);
44 const int size = kk/2+1;
45 for (
int jj = 0; jj < size; ++jj) {
46 std::complex<double> zz(ff[2*jj], ff[2*jj+1]);
49 for (
int jj = size; jj < kk; ++jj) coefs[jj] = zero;
53 for (
int jj = 0; jj < kk; ++jj) xx[jj] = grid[jj];
The namespace for the qg model.
void fft_inv_f(const int &kk, const double *ff, double *xx)
void fft_fwd_f(const int &kk, const double *xx, double *ff)