Developer Reference


Fourier Transform Functions

The general form of the discrete Fourier transform is:
LaTex Math image.
for LaTex Math image., where
is a scale factor, LaTex Math image. for the forward transform, and LaTex Math image. for the inverse (backward) transform. In the forward transform, the input (periodic) sequence LaTex Math image. belongs to the set of complex-valued sequences or the set of real-valued sequences, and the output sequence belongs to the set of complex-valued sequences or the set of complex-valued conjugate-even sequences, respectively.
The Intel® oneAPI Math Kernel Library (oneMKL) provides a DPC++ interface for computing a discrete Fourier transform through the fast Fourier transform algorithm. The DPC++ interface emulates the usage model of the oneMKL C and Fortran Discrete Fourier Transform Interface (DFTI).
The DPC++ interface computes an FFT in four steps:
  1. Allocate a fresh descriptor for the problem with a call to the descriptor object constructor,
    descriptor<PRECISION, DOMAIN> desc(dimensions);
    The descriptor captures the configuration of the transform, such as the dimensionality (or rank), sizes, number of transforms, memory layout of the input/output data (defined by strides), and scaling factors. Many of the configuration settings are assigned default values in this call which you might need to modify in your application.
  2. Optionally adjust the descriptor configuration with a call to the
    descriptor<PRECISION, DOMAIN>::set_value
    function as needed. Typically, you must carefully define the data storage layout for an FFT. The configuration settings of the descriptor, such as the default values, can be obtained with the
    descriptor<PRECISION, DOMAIN>::get_value
  3. Commit the descriptor with a call to the
    descriptor<PRECISION, DOMAIN>::commit
    function, that is, make the descriptor ready for the transform computation. Once the descriptor is committed, the parameters of the transform, such as the type and number of transforms, strides and distances, the type and storage layout of the data, and so on, are “frozen” in the descriptor. The commit function takes in a
    object to determine the device associated with the descriptor.
  4. Compute the transform with a call to the
    functions as many times as needed. Because the descriptor is defined and committed separately, the compute functions just take the input and output data and compute the transform as defined. To modify any configuration parameters for another call to a compute function, use
    descriptor<PRECISION, DOMAIN>::set_value
    followed by
    descriptor<PRECISION, DOMAIN>::commit
    before calling the compute function again.
All the above functions throw a named
in the event of failure.
To use the DPC++ interface, include
. The DPC++ interface supports host, CPU, and Intel GPU devices. Some functionality supported on the host device is not yet fully supported on Intel GPU devices. Some device-specific limitations are noted in the descriptor<precision, domain>::set_value section of this document. Refer to the Intel® oneAPI Math Kernel Library Release Notes for known limitations. Working usage examples can be found in the oneMKL installation directory under
The FFT functions assume the Cartesian representation of complex data (that is, the real and imaginary parts define a complex number). The Intel® oneAPI Math Kernel Library Vector Mathematical Functions provide efficient tools for conversion to and from polar representation. See the Conversion from Cartesian to polar representation of complex data and Conversion from polar to Cartesian representation of complex data examples.

Product and Performance Information


Performance varies by use, configuration and other factors. Learn more at