xݕɬ[' d Z ddlmZmZmZmZmZ ddlmZm Z g dZ
eefZddZ
ee
d dd Z ee
d dd
Z e d dd Z e d dd
ZdS )z*
Discrete Fourier Transforms - helper.py
)integeremptyarangeasarrayroll)array_function_dispatch
set_module)fftshift ifftshiftfftfreqrfftfreqNc | fS N )xaxess d/builddir/build/BUILD/cloudlinux-venv-1.0.10/venv/lib64/python3.11/site-packages/numpy/fft/helper.py_fftshift_dispatcherr s
4K z numpy.fft)modulec t |3t t j }d j D }n4t |t r j | dz }n fd|D }t || S )ad
Shift the zero-frequency component to the center of the spectrum.
This function swaps half-spaces for all axes listed (defaults to all).
Note that ``y[0]`` is the Nyquist component only if ``len(x)`` is even.
Parameters
----------
x : array_like
Input array.
axes : int or shape tuple, optional
Axes over which to shift. Default is None, which shifts all axes.
Returns
-------
y : ndarray
The shifted array.
See Also
--------
ifftshift : The inverse of `fftshift`.
Examples
--------
>>> freqs = np.fft.fftfreq(10, 0.1)
>>> freqs
array([ 0., 1., 2., ..., -3., -2., -1.])
>>> np.fft.fftshift(freqs)
array([-5., -4., -3., -2., -1., 0., 1., 2., 3., 4.])
Shift the zero-frequency component only along the second axis:
>>> freqs = np.fft.fftfreq(9, d=1./9).reshape(3, 3)
>>> freqs
array([[ 0., 1., 2.],
[ 3., 4., -4.],
[-3., -2., -1.]])
>>> np.fft.fftshift(freqs, axes=(1,))
array([[ 2., 0., 1.],
[-4., 3., 4.],
[-1., -3., -2.]])
Nc g | ]}|d z S r .0dims r