RunMat
GitHub

fftshift — Shift zero-frequency components to the center of a spectrum.

fftshift(X) circularly shifts the output of an FFT so that the zero-frequency component moves to the center of each transformed dimension. This makes spectra easier to inspect and aligns with MATLAB's plotting conventions.

How fftshift works in RunMat

  • When called without a dimension list, fftshift shifts along every dimension by floor(size(X, dim) / 2).
  • fftshift(X, dims) shifts only the specified dimensions. dims can be a scalar, vector, or logical mask.
  • Dimensions of length 0 or 1 are left unchanged.
  • Inputs can be real or complex and may already reside on the GPU (gpuArray).

How fftshift runs on the GPU

RunMat asks the active acceleration provider to execute fftshift via the circshift hook (with predetermined offsets). If the provider cannot satisfy the request, the tensor is gathered exactly once, shifted on the host, and optionally re-uploaded. Scalars remain on their existing device.

GPU memory and residency

RunMat's auto-offload keeps FFT spectra on the GPU whenever the active provider exposes the circshift hook. In that case fftshift runs entirely on the device and downstream fused operations continue without a gather. If no GPU provider is registered—or it does not expose circshift—RunMat gathers the data once, performs the host shift, and uploads the result back to the device so subsequent work can still benefit from acceleration. You can always call gpuArray explicitly when you need MATLAB compatibility or want to guarantee a specific residency boundary.

Examples

Centering the spectrum of a 1-D FFT result with even length

x = [0 1 2 3 4 5 6 7];
fx = fft(x);
y = fftshift(fx)

Expected output:

y = [-4 -4-1.6569i -4-4i -4-9.6569i 28 -4+9.6569i -4+4i -4+1.6569i]

Handling odd-length vectors

x = 1:5;
y = fftshift(x)

Expected output:

y = [4 5 1 2 3]

Centering both axes of a 2-D FFT

A = [1 2 3; 4 5 6];
C = fftshift(A)

Expected output:

C =
     6     4     5
     3     1     2

Shifting only one dimension of a matrix

A = [1 2 3; 4 5 6];
rowCentered = fftshift(A, 1)   % shift rows only

Expected output:

rowCentered =
     4     5     6
     1     2     3

Applying fftshift to a gpuArray spectrum

G = gpuArray(0:7);
centered = fftshift(G);
H = gather(centered)

Expected output:

H = [4 5 6 7 0 1 2 3]

FAQ

When should I call fftshift?

Call fftshift whenever you need to center FFT outputs before visualising spectra, computing radial averages, or applying filters that expect zero frequency in the middle of the array.

Does fftshift modify the phase or magnitude of the FFT?

No. fftshift only reorders the samples. Magnitudes, phases, and the overall information content remain unchanged.

How do I undo fftshift?

Use ifftshift, which performs the inverse rearrangement. The sequence ifftshift(fftshift(X)) returns X for all supported inputs.

Can I apply fftshift to only one dimension?

Yes. Pass a dimension index or vector, e.g. fftshift(X, 2) to shift column channels only.

Does fftshift work with gpuArray inputs?

Yes. RunMat keeps data on the GPU whenever the provider exposes the circshift hook, matching MATLAB's gpuArray behaviour.

How does fftshift handle empty inputs?

Empty arrays are returned unchanged with identical shape metadata.

Can I use fftshift on logical arrays?

Yes. Logical arrays are shifted without changing their logical element type.

These functions work well alongside fftshift. Each page has runnable examples you can try in the browser.

fft, ifft, ifftshift, circshift, gpuArray, gather, fft2, ifft2

Open-source implementation

Unlike proprietary runtimes, every RunMat function is open-source. Read exactly how fftshift works, line by line, in Rust.

About RunMat

RunMat is an open-source runtime that executes MATLAB-syntax code — faster, on any GPU, with no license required.

  • Simulations that took hours now take minutes. RunMat automatically optimizes your math for GPU execution on Apple, Nvidia, and AMD hardware. No code changes needed.
  • Start running code in seconds. Open the browser sandbox or download a single binary. No license server, no IT ticket, no setup.
  • A full development environment. GPU-accelerated 2D and 3D plotting, automatic versioning on every save, and a browser IDE you can share with a link.

Getting started · Benchmarks · Pricing

Try RunMat — free, no sign-up

Start running MATLAB code immediately in your browser.