Nonequispaced Fast Cosine Transform (NFCT)
NDCT and NFCT
We consider the even, 1-periodic trigonometric polynomial
\[ f^c(\pmb{x}) \coloneqq \sum_{\pmb{k} \in I_{\pmb{N},\mathrm{c}}^d} \hat{f}_{\pmb{k}}^c \, \cos(2\pi \, \pmb{k} \odot \pmb{x}), \quad \pmb{x} \in \mathbb{R}^d,\]
with multibandlimit $\pmb{N} \in \mathbb{N}^d$ and index set
\[ I_{\pmb{N},\mathrm{c}}^d \coloneqq \left\{ \pmb{k} \in \mathbb{Z}^d: 0 \leq k_i \leq N_i - 1, \, i = 1,2,\ldots,d \right\}.\]
Note that we define $\cos(\pmb{k} \circ \pmb{x}) \coloneqq \prod_{i=1}^d \cos(k_i \cdot x_i)$. The NDCT is the evaluation of
\[ f^c(\pmb{x}_j) = \sum_{\pmb{k} \in I_{\pmb{N},\mathrm{c}}^d} \hat{f}_{\pmb{k}}^c \, \cos(2\pi \, \pmb{k} \odot \pmb{x}_j)\]
at arbitrary nodes $\pmb{x}_j \in [0,0.5]^d$ for given coefficients $\hat{f}_{\pmb{k}}^c \in \mathbb{R}, \pmb{k} \in I_{\pmb{N},\mathrm{c}}^d$. Similarly to the NDFT, the transposed NDCT is the evaluation of
\[ \hat{h}^c_{\pmb{k}} = \sum_{j=1}^M f^c_j \, \cos(2\pi \, \pmb{k} \odot \pmb{x}_j)\]
for the frequencies $\pmb{k} \in I_{\pmb{N},\mathrm{c}}^d$ with given coefficients $f^c_j \in \mathbb{R}, j = 1,2,\ldots,M$.
We modify the NFFT in order to derive a fast algorithm for the computation of the NDCT and transposed NDCT, obtaining the NFCT and its transposed counterpart. For details we refer to Chapter 7 in [Plonka, Potts, Steidl, Tasche, 2018].
Plan structure
NFFT3.NFCT — TypeNFCT{D}A NFCT (nonequispaced fast cosine transform) plan, where D is the dimension.
The NFCT realizes a direct and fast computation of the discrete nonequispaced cosine transform. The aim is to compute
\[f^c(\pmb{x}_j) = \sum_{\pmb{k} \in I_{\pmb{N},\mathrm{c}}^D} \hat{f}_{\pmb{k}}^c \, \cos(2\pi \, \pmb{k} \odot \pmb{x}_j)\]
at given arbitrary knots $\pmb{x}_j \in [0,0.5]^D, j = 1, \cdots, M$, for coefficients $\hat{f}^{c}_{\pmb{k}} \in \mathbb{R}$, $\pmb{k} \in I_{\pmb{N},\mathrm{c}}^D \coloneqq \left\{ \pmb{k} \in \mathbb{Z}^D: 1 \leq k_i \leq N_i - 1, \, i = 1,2,\ldots,D \right\}$, and a multibandlimit vector $\pmb{N} \in \mathbb{N}^{D}$. Note that we define $\cos(\pmb{k} \circ \pmb{x}) \coloneqq \prod_{i=1}^D \cos(k_i \cdot x_i)$. The transposed problem reads as
\[\hat{h}^c_{\pmb{k}} = \sum_{j=1}^M f^c_j \, \cos(2\pi \, \pmb{k} \odot \pmb{x}_j)\]
for the frequencies $\pmb{k} \in I_{\pmb{N},\mathrm{c}}^D$ with given coefficients $f^c_j \in \mathbb{R}, j = 1,2,\ldots,M$.
Fields
- N- the multibandlimit $(N_1, N_2, \ldots, N_D)$ of the trigonometric polynomial $f^s$.
- M- the number of nodes.
- n- the oversampling $(n_1, n_2, \ldots, n_D)$ per dimension.
- m- the window size. A larger m results in more accuracy but also a higher computational cost.
- f1- the NFCT flags.
- f2- the FFTW flags.
- init_done- indicates if the plan is initialized.
- finalized- indicates if the plan is finalized.
- x- the nodes $x_j \in [0,0.5]^D, \, j = 1, \ldots, M$.
- f- the values $f^c(\pmb{x}_j)$ for the NFCT or the coefficients $f_j^c \in \mathbb{R}, j = 1, \ldots, M,$ for the transposed NFCT.
- fhat- the Fourier coefficients $\hat{f}_{\pmb{k}}^c \in \mathbb{R}$ for the NFCT or the values $\hat{h}_{\pmb{k}}^c, \pmb{k} \in I_{\pmb{N},\mathrm{c}}^D,$ for the adjoint NFCT.
- plan- plan (C pointer).
Constructor
NFCT{D}( N::NTuple{D,Int32}, M::Int32, n::NTuple{D,Int32}, m::Int32, f1::UInt32, f2::UInt32 ) where {D}Additional Constructor
NFCT( N::NTuple{D,Int32}, M::Int32, n::NTuple{D,Int32}, m::Int32, f1::UInt32, f2::UInt32) where {D}
NFCT( N::NTuple{D,Int32}, M::Int32) where {D}See also
Functions
NFFT3.nfct_trafo — Functionnfct_trafo(P)computes the NDCT via the fast NFCT algorithm for provided nodes $\pmb{x}_j, j =1,2,\dots,M,$ in P.X and coefficients $\hat{f}_{\pmb{k}}^c \in \mathbb{R}, \pmb{k} \in I_{\pmb{N},\mathrm{c}}^D,$ in P.fhat.
Input
- P- a NFCT plan structure.
See also
NFFT3.nfct_trafo_direct — Functionnfct_trafo_direct(P)computes the NDCT via naive matrix-vector multiplication for provided nodes $\pmb{x}_j, j =1,2,\dots,M,$ in P.X and coefficients $\hat{f}_{\pmb{k}}^c \in \mathbb{R}, \pmb{k} \in I_{\pmb{N},\mathrm{c}}^D,$ in P.fhat.
Input
- P- a NFCT plan structure.
See also
NFFT3.nfct_transposed — Functionnfct_transposed(P)computes the transposed NDCT via the fast transposed NFCT algorithm for provided nodes $\pmb{x}_j, j =1,2,\dots,M,$ in P.X and coefficients $f_j^c \in \mathbb{R}, j =1,2,\dots,M,$ in P.f.
Input
- P- a NFCT plan structure.
See also
NFFT3.nfct_transposed_direct — Functionnfct_transposed_direct(P)computes the transposed NDCT via naive matrix-vector multiplication for provided nodes $\pmb{x}_j, j =1,2,\dots,M,$ in P.X and coefficients $f_j^c \in \mathbb{R}, j =1,2,\dots,M,$ in P.f.
Input
- P- a NFCT plan structure.
See also
NFFT3.nfct_finalize_plan — Functionnfct_finalize_plan(P::NFCT{D})destroys a NFCT plan structure.
Input
- P- a NFCT plan structure.
See also
NFFT3.nfct_init — Functionnfct_init(P)intialises the NFCT plan in C. This function does not have to be called by the user.
Input
- P- a NFCT plan structure.
See also
Literature
- [Plonka, Potts, Steidl, Tasche, 2018] G. Plonka, D. Potts, G. Steidl and M. Tasche. Numerical Fourier Analysis: Theory and Applications. Springer Nature Switzerland AG, 2018. doi: 10.1007/978-3-030-04306-3.