Differentiable and gpu enabled fast wavelet transforms in PyTorch
Project description
Pytorch Wavelet Toolbox (ptwt
)
Welcome to the PyTorch (adaptive) wavelet toolbox. This package implements:
- the fast wavelet transform (fwt) implemented in
wavedec
. - the inverse fwt can be used by calling
waverec
. - the 2d fwt is called
wavedec2
- and inverse 2d fwt
waverec2
. - single and two-dimensional wavelet packet forward transforms.
- 1d sparse-matrix fast wavelet transforms with boundary filters.
- adaptive wavelet support (experimental).
- 2d boundary filters (experimental).
This toolbox supports pywt-wavelets.
Installation
Install the toolbox via pip or clone this repository. In order to use pip
, type:
$ pip install ptwt
You can remove it later by typing pip uninstall ptwt
.
Example usage:
import torch
import numpy as np
import pywt
import ptwt # use " from src import ptwt " if you cloned the repo instead of using pip.
# generate an input of even length.
data = np.array([0, 1, 2, 3, 4, 5, 5, 4, 3, 2, 1, 0])
data_torch = torch.from_numpy(data.astype(np.float32))
wavelet = pywt.Wavelet('haar')
# compare the forward fwt coefficients
print(pywt.wavedec(data, wavelet, mode='zero', level=2))
print(ptwt.wavedec(data_torch, wavelet, mode='zero', level=2))
# invert the fwt.
print(ptwt.waverec(ptwt.wavedec(data_torch, wavelet, mode='zero', level=2), wavelet))
Transform by Sparse-Matrix-multiplication:
In additionally sparse-matrix-based code is available.
Generate 1d sparse matrix forward and backward transforms with the
MatrixWavedec
and MatrixWaverec
classes.
Continuing the example above try for example:
# forward
matrix_wavedec = ptwt.MatrixWavedec(wavelet, level=2)
coeff = matrix_wavedec(data_torch)
print(coeff)
# backward
matrix_waverec = ptwt.MatrixWaverec(wavelet, level=2)
rec = matrix_waverec(coeff)
print(rec)
The process for the 2d transforms MatrixWavedec2d
, MatrixWaverec2d
,
works similarly.
Adaptive Wavelets (experimental)
Code to train an adaptive wavelet layer in PyTorch is available in the examples
folder. In addition to static wavelets
from pywt,
- Adaptive product-filters
- and optimizable orthogonal-wavelets are supported.
Unit Tests
The tests
folder contains multiple tests to allow independent verification of this toolbox. After cloning the
repository, and moving into the main directory, and installing tox
with pip install tox
run:
$ tox -e py
📖 Citation
If you find this work useful please consider citing:
@phdthesis{handle:20.500.11811/9245,
urn: https://nbn-resolving.org/urn:nbn:de:hbz:5-63361,
author = {{Moritz Wolter}},
title = {Frequency Domain Methods in Recurrent Neural Networks for Sequential Data Processing},
school = {Rheinische Friedrich-Wilhelms-Universität Bonn},
year = 2021,
month = jul,
url = {https://hdl.handle.net/20.500.11811/9245}
}
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file ptwt-0.0.7.tar.gz
.
File metadata
- Download URL: ptwt-0.0.7.tar.gz
- Upload date:
- Size: 27.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.4.1 importlib_metadata/4.0.1 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.60.0 CPython/3.8.5
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 8f665d2c72f6269681cfb9684b0ae42516300fb06b46391ab885fb33b1110745 |
|
MD5 | 472974ee798b6b86a94b903fb42f699b |
|
BLAKE2b-256 | 7440bb76b218e66611ae08414c7518c5fcb31b05947a4dc06f91bb728b0d853b |
File details
Details for the file ptwt-0.0.7-py3-none-any.whl
.
File metadata
- Download URL: ptwt-0.0.7-py3-none-any.whl
- Upload date:
- Size: 29.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.4.1 importlib_metadata/4.0.1 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.60.0 CPython/3.8.5
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 67918b58d6dc5694a96f045d553d3e5f44e9e47a240051acb142dbc2698e509c |
|
MD5 | d3f0530daa087a1df37cccb0eded0966 |
|
BLAKE2b-256 | b8b1ede2b241042bf64c16954daa65df9edc9b5a25e067594fe3d51d04d05ef8 |