120 std::vector<double> &evenFieldSampling) {
121 std::vector<double> fourierCoefficients(2 * accuracy - 1);
126 RealValues[ii] = evenFieldSampling[i];
127 RealValues[iii] = evenFieldSampling[i];
130 gsl_fft_real_wavetable *
real = gsl_fft_real_wavetable_alloc(2 *
num_gridpz_m);
131 gsl_fft_real_workspace *work = gsl_fft_real_workspace_alloc(2 *
num_gridpz_m);
135 gsl_fft_real_workspace_free(work);
136 gsl_fft_real_wavetable_free(
real);
139 fourierCoefficients[0] = RealValues[0] / (2 *
num_gridpz_m);
140 for(
int i = 1; i < 2 * accuracy - 1; i++) {
144 return fourierCoefficients;
148 double interiorDerivative, base;
149 double coskzl, sinkzl, z = 0.0;
151 std::vector<double> higherDerivatives[3];
160 for(
int l = 1; l < accuracy; ++l) {
161 int coefIndex = 2 * l - 1;
163 interiorDerivative = base;
164 coskzl =
cos(kz * l);
165 sinkzl =
sin(kz * l);
167 higherDerivatives[0][i] += interiorDerivative * (-fourierComponents[coefIndex] * sinkzl
168 - fourierComponents[coefIndex + 1] * coskzl);
169 interiorDerivative *= base;
170 higherDerivatives[1][i] += interiorDerivative * (-fourierComponents[coefIndex] * coskzl
171 + fourierComponents[coefIndex + 1] * sinkzl);
172 interiorDerivative *= base;
173 higherDerivatives[2][i] += interiorDerivative * (fourierComponents[coefIndex] * sinkzl
174 + fourierComponents[coefIndex + 1] * coskzl);
178 for(
int i = 1; i < 4; ++i) {
FLieGenerator< T, N > real(const FLieGenerator< std::complex< T >, N > &)
Take real part of a complex generator.