Skip to main content

Fast Discrete Wavelet Transform TensorFlow Layers

Project description

TFDWT: Fast Discrete Wavelet Transform TensorFlow Layers arXiv

PyPI Version PyPI Version TensorFlow Version Keras Version CUDA Version License

Fast $1\text{D}$, $2\text{D}$ and $3\text{D}$ Discrete Wavelet Transform ($\text{DWT}$) and Inverse Discrete Wavelet Transform ($\text{IDWT}$) layers for backpropagation networks.

Available wavelet families ―

        Haar (haar)
        Daubechies (db)
        Symlets (sym)
        Coiflets (coif)
        Biorthogonal (bior)
        Reverse biorthogonal (rbio)

Note ― Shape requirements

  • Single‑level: dimensions must be even. For 1D, N is even; for 2D and 3D, each side is even and the input is square/cubic respectively.
  • Multilevel (L levels): each side must be divisible by $2^L$. In practice, pad to the nearest multiple of $2^L$ when needed.
  • Our examples and tests center‑pad rather than crop, to preserve data.





Installation guide

The installation of the TFDWT package is recommended inside a virtual environment with tensorflow[and-cuda] installed at first.


Pre-installation checks (Tested in Gentoo and Debian bookworm)

  • Create a new virtual enironment with a specific Python version (use the Python version supported by TensorFlow)
conda info --envs
env_name='tf219'
conda create -n $env_name python=3.12 ipykernel

# activate virtual environment
conda activate tf219
# For GPU users
pip install tensorflow[and-cuda]
# Verify setup
python3 -c "import tensorflow as tf; print(f'{tf.config.list_physical_devices('GPU')}, \nTF version {tf.__version__}')"



Install TFDWT from PyPI (Option $1$)

pip install TFDWT



Install TFDWT from Github (Option $2$)

Download the package

git clone https://github.com/kkt-ee/TFDWT.git

Change directory to the downloaded TFDWT 

cd TFDWT

Run the following command to install the TFDWT package

pip install .





Verify installation

Compute $\text{DWT}$ $1\text{D}$ and $\text{IDWT}$ $1\text{D}$ of batched, multichannel $x$ of shape $(\text{batch, length, channels})$

"""Perfect Reconstruction 1D DWT level-1 Filter bank"""
from TFDWT.DWT1DFB import DWT1D, IDWT1D

LH = DWT1D(wave='bior3.1')(x)       # Analysis
x_hat = IDWT1D(wave='bior3.1')(LH)  # Synthesis



Compute $\text{DWT}$ $2\text{D}$ and $\text{IDWT}$ $2\text{D}$ of batched, multichannel $x$ of shape $(\text{batch, height, width, channels})$

"""Perfect Reconstruction 2D DWT level-1 Filter bank"""
from TFDWT.DWT2DFB import DWT2D, IDWT2D

LLLHHLHH = DWT2D(wave='bior1.3')(x)        # Analysis
x_hat = IDWT2D(wave='bior1.3')(LLLHHLHH)   # Synthesis
# `wave` can be any supported orthogonal or biorthogonal wavelet



Compute $\text{DWT}$ $3\text{D}$ and $\text{IDWT}$ $3\text{D}$ of batched, multichannel $x$ of shape $(\text{batch, height, width, depth, channels})$

"""Perfect Reconstruction 3D DWT level-1 Filter bank"""
from TFDWT.DWT3DFB import DWT3D, IDWT3D

LLLLLHLHLLHHHLLHLHHHLHHH = DWT3D(wave='bior1.3')(x)        # Analysis
x_hat = IDWT3D(wave='bior1.3')(LLLLLHLHLLHHHLLHLHHHLHHH)   # Synthesis
# `wave` can be any supported orthogonal or biorthogonal wavelet




NOTE ― Using the above forward and inverse transforms the above $\text{DWT}$ and $\text{IDWT}$ layers can be used to construct multilevel $\text{DWT}$ filter banks and $\text{Wave Packet Transform}$ filter banks.

Multilevel helpers (convenience API)

The package also provides simple helpers for building multilevel pyramids using the single‑level layers internally.

1D

from TFDWT.multilevel.dwt import dwt, idwt

level = 3
subbands = dwt(x, level=level, Ψ='haar')   # returns [H1, H2, ..., HL, LL]
x_hat    = idwt(subbands, level=level, Ψ='haar')

2D

from TFDWT.multilevel.dwt2 import dwt2, idwt2

level = 3
subbands = dwt2(x, level=level, Ψ='haar')  # [H1, H2, ..., HL, LL]
x_hat    = idwt2(subbands, level=level, Ψ='haar')

3D

from TFDWT.multilevel.dwt3 import dwt3, idwt3

level = 3
subbands = dwt3(x, level=level, Ψ='haar')  # [H1, H2, ..., HL, LL]
x_hat    = idwt3(subbands, level=level, Ψ='haar')

Each Hi contains all high‑pass subbands at level i (1 for 1D, 3 for 2D, 7 for 3D), concatenated along the channel axis; the last element is the final low‑pass LL.





Package is tested with dependency versions

        Python 3.12.7
        TensorFlow 2.15+ (verified on 2.21.0)
        Keras 2 and 3
        CUDA 12+





Uninstall TFDWT

pip uninstall TFDWT







TFDWT (C) 2026 Kishore Kumar Tarafdar, भारत 🇮🇳

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

tfdwt-0.1.1.tar.gz (3.7 MB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

tfdwt-0.1.1-py3-none-any.whl (66.5 kB view details)

Uploaded Python 3

File details

Details for the file tfdwt-0.1.1.tar.gz.

File metadata

  • Download URL: tfdwt-0.1.1.tar.gz
  • Upload date:
  • Size: 3.7 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.13

File hashes

Hashes for tfdwt-0.1.1.tar.gz
Algorithm Hash digest
SHA256 7b2e5c1ac5fddc99f522f3ba276e25a00fb12da486aa62ac3c918638f31cf946
MD5 2a8d7078d7e00795c3570895111de601
BLAKE2b-256 9fb9b69db98394ce2aa04bb55a4292cffac42693888c130c1d458392aa5f8bda

See more details on using hashes here.

File details

Details for the file tfdwt-0.1.1-py3-none-any.whl.

File metadata

  • Download URL: tfdwt-0.1.1-py3-none-any.whl
  • Upload date:
  • Size: 66.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.13

File hashes

Hashes for tfdwt-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 08268faa4a05b6e641727dc174691241f025fd6fefc4d46697b72556efad3254
MD5 661fb12468600c8c68eca52542799c70
BLAKE2b-256 bad5cb24f30d5713e81213d9e1556ed926afa72c33f426c9d1fd365b8b143f10

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page