GitPedia

Torch dct

DCT (discrete cosine transform) functions for pytorch

From zh217·Updated June 16, 2026·View on GitHub·

This library implements DCT in terms of the built-in FFT operations in pytorch so that back propagation works through it, on both CPU and GPU. For more information on DCT and the algorithms used here, see [Wikipedia](https://en.wikipedia.org/wiki/Discrete_cosine_transform) and the paper by [J. Makhoul](https://ieeexplore.ieee.org/document/1163351/). This [StackExchange article](https://dsp.stackexchange.com/questions/2807/fast-cosine-transform-via-fft) might also be helpful. The project is written primarily in Python, distributed under the MIT License license, first published in 2018. Key topics include: dct, dft, fct, fft, pytorch.

DCT (Discrete Cosine Transform) for pytorch

Build Status
codecov
PyPI version
PyPI version
PyPI status
GitHub license

This library implements DCT in terms of the built-in FFT operations in pytorch so that
back propagation works through it, on both CPU and GPU. For more information on
DCT and the algorithms used here, see
Wikipedia and the paper by
J. Makhoul. This
StackExchange article
might also be helpful.

The following are currently implemented:

  • 1-D DCT-I and its inverse (which is a scaled DCT-I)
  • 1-D DCT-II and its inverse (which is a scaled DCT-III)
  • 2-D DCT-II and its inverse (which is a scaled DCT-III)
  • 3-D DCT-II and its inverse (which is a scaled DCT-III)

Install

pip install torch-dct

Requires torch>=0.4.1 (lower versions are probably OK but I haven't tested them).

You can run test by getting the source and run pytest. To run the test you also
need scipy installed.

Usage

python
import torch import torch_dct as dct x = torch.randn(200) X = dct.dct(x) # DCT-II done through the last dimension y = dct.idct(X) # scaled DCT-III done through the last dimension assert (torch.abs(x - y)).sum() < 1e-10 # x == y within numerical tolerance

dct.dct1 and dct.idct1 are for DCT-I and its inverse. The usage is the same.

Just replace dct and idct by dct_2d, dct_3d, idct_2d, idct_3d, etc
to get the multidimensional versions.

Contributors

Showing top 6 contributors by commit count.

View all contributors on GitHub →

This article is auto-generated from zh217/torch-dct via the GitHub API.Last fetched: 6/29/2026