NAG C Library Function Document

nag_fft_multiple_hermitian (c06fqc)


nag_fft_multiple_hermitian (c06fqc) computes the discrete Fourier transforms of m  Hermitian sequences, each containing n  complex data values.


#include <nag.h>
#include <nagc06.h>
void  nag_fft_multiple_hermitian (Integer m, Integer n, double x[], const double trig[], NagError *fail)


Given m  Hermitian sequences of n  complex data values z j p , for j=0,1,,n - 1 and p=1,2,,m, this function simultaneously calculates the Fourier transforms of all the sequences defined by
x ^ k p = 1 n j=0 n-1 z j p exp -2 π ijk / n ,   for ​ k = 0 , 1 , , n - 1 ; p = 1 , 2 , , m .  
(Note the scale factor 1 / n  in this definition.)
The transformed values are purely real.
The first call of nag_fft_multiple_hermitian (c06fqc) must be preceded by a call to nag_fft_init_trig (c06gzc) to initialize the array trig with trigonometric coefficients according to the value of n.
The discrete Fourier transform is sometimes defined using a positive sign in the exponential term
x ^ k p = 1 n j=0 n-1 z j p exp +2 π ijk / n .  
For that form, this function should be preceded by a call to nag_multiple_conjugate_hermitian (c06gqc) to form the complex conjugates of the z ^ j p .
The function uses a variant of the fast Fourier transform algorithm (Brigham (1974)) known as the Stockham self-sorting algorithm, which is described in Temperton (1983). Special code is included for the factors 2, 3, 4, 5 and 6.


Brigham E O (1974) The Fast Fourier Transform Prentice–Hall
Temperton C (1983) Fast mixed-radix real Fourier transforms J. Comput. Phys. 52 340–350


1:     m IntegerInput
On entry: the number of sequences to be transformed, m .
Constraint: m1 .
2:     n IntegerInput
On entry: the number of data values in each sequence, n .
Constraint: n1 .
3:     x[m×n] doubleInput/Output
On entry: the m  Hermitian sequences must be stored consecutively in x in Hermitian form. Sequence 1 should occupy the first n  elements of x, sequence 2 the elements n  to 2 n - 1 , so that in general sequence p  occupies the array elements p-1 n  to pn - 1 . If the n  data values z j p  are written as x j p + iy j p , then for 0 j n / 2 , x j p  should be in array element x[ p-1 × n + j ]  and for 1 j n-1 / 2 , y j p  should be in array element x[ p-1 × n + n-j ] .
On exit: the components of the m  discrete Fourier transforms, stored consecutively. Transform p  occupies the elements p-1 n  to pn - 1  of x overwriting the corresponding original sequence; thus if the n  components of the discrete Fourier transform are denoted by x ^ k p , for k=0,1,,n - 1, then the mn  elements of the array x contain the values
x ^ 0 1 , x ^ 1 1 , , x ^ n-1 1 , x ^ 0 2 , x ^ 1 2 , , x ^ n-1 2 , , x ^ 0 m , x ^ 1 m , , x ^ n-1 m .  
4:     trig[2×n] const doubleInput
On entry: trigonometric coefficients as returned by a call of nag_fft_init_trig (c06gzc). nag_fft_multiple_hermitian (c06fqc) makes a simple check to ensure that trig has been initialized and that the initialization is compatible with the value of n
5:     fail NagError *Input/Output
The NAG error argument (see Section 3.7 in How to Use the NAG Library and its Documentation).

Error Indicators and Warnings

Dynamic memory allocation failed.
Value of n and trig array are incompatible or trig array not initialized.
On entry, m=value.
Constraint: m1.
On entry, n=value.
Constraint: n1.


Some indication of accuracy can be obtained by performing a subsequent inverse transform and comparing the results with the original sequence (in exact arithmetic they would be identical).

Parallelism and Performance

nag_fft_multiple_hermitian (c06fqc) is not threaded in any implementation.

Further Comments

The time taken is approximately proportional to nm logn , but also depends on the factors of n . The function is fastest if the only prime factors of n  are 2, 3 and 5, and is particularly slow if n  is a large prime, or has large prime factors.


This program reads in sequences of real data values which are assumed to be Hermitian sequences of complex data stored in Hermitian form. The sequences are expanded into full complex form using nag_multiple_hermitian_to_complex (c06gsc) and printed. The discrete Fourier transforms are then computed (using nag_fft_multiple_hermitian (c06fqc)) and printed out. Inverse transforms are then calculated by calling nag_fft_multiple_real (c06fpc) followed by nag_multiple_conjugate_hermitian (c06gqc) showing that the original sequences are restored.

Program Text

Program Text (c06fqce.c)

Program Data

Program Data (c06fqce.d)

Program Results

Program Results (c06fqce.r)