![]() |
NFFT
3.4.1
|
This module implements fast polynomial transforms. More...
Macros | |
| #define | FPT_NO_FAST_ALGORITHM (1U << 2) |
| If set, TODO complete comment. | |
| #define | FPT_NO_DIRECT_ALGORITHM (1U << 3) |
| If set, TODO complete comment. | |
| #define | FPT_NO_STABILIZATION (1U << 0) |
| If set, no stabilization will be used. | |
| #define | FPT_PERSISTENT_DATA (1U << 4) |
| If set, TODO complete comment. | |
| #define | FPT_FUNCTION_VALUES (1U << 5) |
| If set, the output are function values at Chebyshev nodes rather than Chebyshev coefficients. | |
| #define | FPT_AL_SYMMETRY (1U << 6) |
| If set, TODO complete comment. | |
Functions | |
| fpt_set | fpt_init (const int M, const int t, const unsigned int flags) |
| void | fpt_precompute (fpt_set set, const int m, double *alpha, double *beta, double *gam, int k_start, const double threshold) |
| void | fpt_transposed (fpt_set set, const int m, double _Complex *x, double _Complex *y, const int k_end, const unsigned int flags) |
This module implements fast polynomial transforms.
In the following, we abbreviate the term "fast polynomial transforms" by FPT.
| fpt_set fpt_init | ( | const int | M, |
| const int | t, | ||
| const unsigned int | flags | ||
| ) |
Initializes a set of precomputed data for DPT transforms of equal length.
. The individual transforms are addressed by and index number
with range
. The total number of transforms is therefore
.
of the transform length
Definition at line 755 of file fpt.c.
References fpt_set_s_::dpt, fpt_set_s_::flags, FPT_NO_DIRECT_ALGORITHM, FPT_NO_FAST_ALGORITHM, fpt_set_s_::kinds, fpt_set_s_::kindsr, fpt_set_s_::lengths, fpt_set_s_::M, fpt_set_s_::N, nfft_free(), nfft_malloc(), fpt_set_s_::plans_dct2, fpt_set_s_::plans_dct3, fpt_data_::steps, fpt_set_s_::t, X, and fpt_set_s_::xcvecs.
Referenced by main(), and nfsft_precompute().
| void fpt_precompute | ( | fpt_set | set, |
| const int | m, | ||
| double * | alpha, | ||
| double * | beta, | ||
| double * | gam, | ||
| int | k_start, | ||
| const double | threshold | ||
| ) |
Computes the data required for a single DPT transform.
.
for
such that alpha[k]
.
for
such that beta[k]
.
for
such that gamma[k]
.
.Definition at line 881 of file fpt.c.
References fpt_data_::_alpha, fpt_data_::_beta, fpt_data_::_gamma, fpt_step_::a22, fpt_data_::alpha_0, fpt_data_::alphaN, fpt_data_::beta_0, fpt_data_::betaN, fpt_set_s_::dpt, FIRST_L, fpt_set_s_::flags, FPT_AL_SYMMETRY, FPT_NO_DIRECT_ALGORITHM, FPT_NO_FAST_ALGORITHM, FPT_NO_STABILIZATION, FPT_PERSISTENT_DATA, fpt_data_::gamma_m1, fpt_data_::gammaN, fpt_data_::k_start, K_START_TILDE, LAST_L, fpt_set_s_::N, nfft_free(), nfft_malloc(), fpt_step_::Ns, fpt_step_::stable, fpt_data_::steps, fpt_set_s_::t, fpt_step_::ts, X, and fpt_set_s_::xcvecs.
Referenced by main(), and nfsft_precompute().
| void fpt_transposed | ( | fpt_set | set, |
| const int | m, | ||
| double _Complex * | x, | ||
| double _Complex * | y, | ||
| const int | k_end, | ||
| const unsigned int | flags | ||
| ) |
Computes a single DPT transform.
Definition at line 1566 of file fpt.c.
References fpt_step_::a22, fpt_data_::alpha_0, fpt_data_::alphaN, fpt_data_::beta_0, fpt_data_::betaN, fpt_set_s_::dpt, FIRST_L, fpt_set_s_::flags, FPT_AL_SYMMETRY, FPT_NO_FAST_ALGORITHM, fpt_data_::gamma_m1, fpt_data_::gammaN, K_END_TILDE, fpt_data_::k_start, K_START_TILDE, LAST_L, fpt_step_::Ns, fpt_step_::stable, fpt_data_::steps, fpt_step_::ts, X, and fpt_set_s_::xcvecs.
Referenced by main(), and nfsft_adjoint().
1.8.6