naginterfaces.library.sum.fft_​complex_​1d

naginterfaces.library.sum.fft_complex_1d(direct, x)[source]

fft_complex_1d calculates the discrete Fourier transform of a sequence of complex data values (using complex data type).

For full information please refer to the NAG Library document for c06pc

https://support.nag.com/numeric/nl/nagdoc_30.1/flhtml/c06/c06pcf.html

Parameters
directstr, length 1

If the forward transform as defined in Notes is to be computed, must be set equal to ‘F’.

If the backward transform is to be computed, must be set equal to ‘B’.

xcomplex, array-like, shape

If is declared with bounds in the function from which fft_complex_1d is called, must contain , for .

Returns
xcomplex, ndarray, shape

The components of the discrete Fourier transform. If is declared with bounds in the function from which fft_complex_1d is called, is contained in , for .

Raises
NagValueError
(errno )

On entry, .

Constraint: .

(errno )

On entry, .

Constraint: or .

(errno )

An internal error has occurred in this function. Check the function call and any array sizes. If the call is correct then please contact NAG for assistance.

Notes

Given a sequence of complex data values , for , fft_complex_1d calculates their (forward or backward) discrete Fourier transform (DFT) defined by

(Note the scale factor of in this definition.) The minus sign is taken in the argument of the exponential within the summation when the forward transform is required, and the plus sign is taken when the backward transform is required.

A call of fft_complex_1d with followed by a call with will restore the original data.

fft_complex_1d uses a variant of the fast Fourier transform (FFT) algorithm (see Brigham (1974)) known as the Stockham self-sorting algorithm, which is described in Temperton (1983). If is a large prime number or if contains large prime factors, then the Fourier transform is performed using Bluestein’s algorithm (see Bluestein (1968)), which expresses the DFT as a convolution that in turn can be efficiently computed using FFTs of highly composite sizes.

References

Bluestein, L I, 1968, A linear filtering approach to the computation of the discrete Fourier transform, Northeast Electronics Research and Engineering Meeting Record 10, 218–219

Brigham, E O, 1974, The Fast Fourier Transform, Prentice–Hall

Temperton, C, 1983, Self-sorting mixed-radix fast Fourier transforms, J. Comput. Phys. (52), 1–23