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 NumPy Version MIT

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=wave)(x)      # Analysis
x_hat = IDWT2D(wave=wave)(LLLHHLHH) # Synthesis



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=wave)(x)      # Analysis
x_hat = IDWT3D(wave=wave)(LLLLLHLHLLHHHLLHLHHHLHHH) # Synthesis




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 (2 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 to 2.19
        Keras 2 and 3
        Numpy 2.0.2
        CUDA 12.5.1





Uninstall TFDWT

pip uninstall TFDWT







TFDWT (C) 2025 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.0.9.tar.gz (10.6 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.0.9-py3-none-any.whl (75.2 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: tfdwt-0.0.9.tar.gz
  • Upload date:
  • Size: 10.6 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.11

File hashes

Hashes for tfdwt-0.0.9.tar.gz
Algorithm Hash digest
SHA256 08388234fdca9bee7ffd0c6a4526d40be00e996129342369d7d8f405f39c7dca
MD5 b365d498863d29d459c7bda7309f4db6
BLAKE2b-256 e7a74b7a867e36493458580c7b89258811042083dd4cbc73b39df53d0f20a3c0

See more details on using hashes here.

File details

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

File metadata

  • Download URL: tfdwt-0.0.9-py3-none-any.whl
  • Upload date:
  • Size: 75.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.11

File hashes

Hashes for tfdwt-0.0.9-py3-none-any.whl
Algorithm Hash digest
SHA256 879b61d9ea6e9630ae84a2ef00ed0bd484601818a01eeda37c6b9eea68e29fef
MD5 63bde39790a97b6a5bcef1411483d014
BLAKE2b-256 651614680592b30862a1f3cd7d570d8b8c1f1960d538110923e4ba8b46e89abd

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