The SciPy module scipy.fft is a more comprehensive superset
of numpy.fft, which includes only a basic set of routines.
fft(a[, n, axis, norm])
Compute the one-dimensional discrete Fourier Transform.
ifft(a[, n, axis, norm])
Compute the one-dimensional inverse discrete Fourier Transform.
fft2(a[, s, axes, norm])
Compute the 2-dimensional discrete Fourier Transform.
ifft2(a[, s, axes, norm])
Compute the 2-dimensional inverse discrete Fourier Transform.
fftn(a[, s, axes, norm])
Compute the N-dimensional discrete Fourier Transform.
ifftn(a[, s, axes, norm])
Compute the N-dimensional inverse discrete Fourier Transform.
rfft(a[, n, axis, norm])
Compute the one-dimensional discrete Fourier Transform for real input.
irfft(a[, n, axis, norm])
Computes the inverse of rfft.
rfft2(a[, s, axes, norm])
Compute the 2-dimensional FFT of a real array.
irfft2(a[, s, axes, norm])
Computes the inverse of rfft2.
rfftn(a[, s, axes, norm])
Compute the N-dimensional discrete Fourier Transform for real input.
irfftn(a[, s, axes, norm])
Computes the inverse of rfftn.
hfft(a[, n, axis, norm])
Compute the FFT of a signal that has Hermitian symmetry, i.e., a real spectrum.
ihfft(a[, n, axis, norm])
Compute the inverse FFT of a signal that has Hermitian symmetry.
Return the Discrete Fourier Transform sample frequencies.
Return the Discrete Fourier Transform sample frequencies (for usage with rfft, irfft).
Shift the zero-frequency component to the center of the spectrum.
The inverse of fftshift.
Fourier analysis is fundamentally a method for expressing a function as a
sum of periodic components, and for recovering the function from those
components. When both the function and its Fourier transform are
replaced with discretized counterparts, it is called the discrete Fourier
transform (DFT). The DFT has become a mainstay of numerical computing in
part because of a very fast algorithm for computing it, called the Fast
Fourier Transform (FFT), which was known to Gauss (1805) and was brought
to light in its current form by Cooley and Tukey [CT]. Press et al. [NR]
provide an accessible introduction to Fourier analysis and its
Because the discrete Fourier transform separates its input into
components that contribute at discrete frequencies, it has a great number
of applications in digital signal processing, e.g., for filtering, and in
this context the discretized input to the transform is customarily
referred to as a signal, which exists in the time domain. The output
is called a spectrum or transform and exists in the frequency
There are many ways to define the DFT, varying in the sign of the
exponent, normalization, etc. In this implementation, the DFT is defined
The DFT is in general defined for complex inputs and outputs, and a
single-frequency component at linear frequency is
represented by a complex exponential
is the sampling interval.
The values in the result follow so-called “standard” order: If A =
fft(a, n), then A contains the zero-frequency term (the sum of
the signal), which is always purely real for real inputs. Then A[1:n/2]
contains the positive-frequency terms, and A[n/2+1:] contains the
negative-frequency terms, in order of decreasingly negative frequency.
For an even number of input points, A[n/2] represents both positive and
negative Nyquist frequency, and is also purely real for real input. For
an odd number of input points, A[(n-1)/2] contains the largest positive
frequency, while A[(n+1)/2] contains the largest negative frequency.
The routine np.fft.fftfreq(n) returns an array giving the frequencies
of corresponding elements in the output. The routine
np.fft.fftshift(A) shifts transforms and their frequencies to put the
zero-frequency components in the middle, and np.fft.ifftshift(A) undoes
When the input a is a time-domain signal and A = fft(a), np.abs(A)
is its amplitude spectrum and np.abs(A)**2 is its power spectrum.
The phase spectrum is obtained by np.angle(A).
A = fft(a)
The inverse DFT is defined as
It differs from the forward transform by the sign of the exponential
argument and the default normalization by .
numpy.fft promotes float32 and complex64 arrays to float64 and
complex128 arrays respectively. For an FFT implementation that does not
promote input arrays, see scipy.fftpack.
The argument norm indicates which direction of the pair of direct/inverse
transforms is scaled and with what normalization factor.
The default normalization ("backward") has the direct (forward) transforms
unscaled and the inverse (backward) transforms scaled by . It is
possible to obtain unitary transforms by setting the keyword argument norm
to "ortho" so that both direct and inverse transforms are scaled by
. Finally, setting the keyword argument norm to
"forward" has the direct transforms scaled by and the inverse
transforms unscaled (i.e. exactly opposite to the default "backward").
None is an alias of the default option "backward" for backward
When the input is purely real, its transform is Hermitian, i.e., the
component at frequency is the complex conjugate of the
component at frequency , which means that for real
inputs there is no information in the negative frequency components that
is not already available from the positive frequency components.
The family of rfft functions is
designed to operate on real inputs, and exploits this symmetry by
computing only the positive frequency components, up to and including the
Nyquist frequency. Thus, n input points produce n/2+1 complex
output points. The inverses of this family assumes the same symmetry of
its input, and for an output of n points uses n/2+1 input points.
Correspondingly, when the spectrum is purely real, the signal is
Hermitian. The hfft family of functions exploits this symmetry by
using n/2+1 complex points in the input (time) domain for n real
points in the frequency domain.
In higher dimensions, FFTs are used, e.g., for image analysis and
filtering. The computational efficiency of the FFT means that it can
also be a faster way to compute large convolutions, using the property
that a convolution in the time domain is equivalent to a point-by-point
multiplication in the frequency domain.
In two dimensions, the DFT is defined as
which extends in the obvious way to higher dimensions, and the inverses
in higher dimensions also extend in the same way.
Cooley, James W., and John W. Tukey, 1965, “An algorithm for the
machine calculation of complex Fourier series,” Math. Comput.
Press, W., Teukolsky, S., Vetterline, W.T., and Flannery, B.P.,
2007, Numerical Recipes: The Art of Scientific Computing, ch.
12-13. Cambridge Univ. Press, Cambridge, UK.
For examples, see the various functions.