Tensor-Train decomposition in pytorch.
Project description
torchTT
Tensor-Train decomposition in pytorch
Tensor-Train decomposition package written in Python on top of pytorch. Supports GPU acceleration and automatic differentiation.
It also contains routines for solving linear systems in the TT format and performing adaptive cross approximation (the AMEN solver/cross interpolation is inspired form the MATLAB TT-Toolbox).
Some routines are implemented in C++ for an increased execution speed.
Installation
Requirements
Following requirements are needed:
python>=3.6torch>=1.7.0numpy>=1.18opt_einsum
The GPU (if available) version of pytorch is recommended to be installed. Read the official installation guide for further info.
Using pip
You can install the package using the pip command:
pip install torchTT
The latest github version can be installed using:
pip install git+https://github.com/ion-g-ion/torchTT
One can also clone the repository and manually install the package:
git clone https://github.com/ion-g-ion/torchTT
cd torchTT
python setup.py install
Using conda
TODO
Components
The main modules/submodules that can be accessed after importing torchtt are briefly desctibed in the following table.
Detailed description can be found here.
| Component | Description |
|---|---|
torchtt |
Basic TT class and basic linear algebra functions. |
torchtt.solvers |
Implementation of the AMEN solver. |
torchtt.grad |
Wrapper for automatic differentiation. |
torchtt.manifold |
Riemannian gradient and projection onto manifolds of tensors with fixed TT rank. |
torchtt.nn |
Basic TT neural network layer. |
torchtt.interpolate |
Cross approximation routines. |
Tests
The directory tests/ from the root folder contains all the unittests. To run them use the command:
pytest tests/
Documentation and examples
The documentation can be found here. Following example scripts (as well as python notebooks) are also provied provided as part of the documentation:
- basic_tutorial.py / basic_tutorial.ipynp: This contains a basic tutorial on decomposing full tensors in the TT format as well as performing rank rounding, slicing (Try on Google Colab).
- basic_linalg.py / basic_linalg.ipynp: This tutorial presents all the algebra operations that can be performed in the TT format (Try on Google Colab).
- efficient_linalg.py / efficient_linalg.ipynb: contains the DMRG for fast matves and AMEN for elementwise inversion in the TT format (Try on Google Colab).
- automatic_differentiation.py / automatic_differentiation.ipynp: Basic tutorial on AD in
torchtt(Try on Google Colab). - cross_interpolation.py / cross_interpolation.ipynb: In this script, the cross interpolation emthod is exemplified (Try on Google Colab).
- system_solvers.py / system_solvers.ipynb: This contains the bais ussage of the multilinear solvers (Try on Google Colab).
- cuda.py / cuda.ipynb: This provides an example on how to use the GPU acceleration (Try on Google Colab).
- basic_nn.py / basic_nn.ipynb: This provides an example on how to use the TT neural network layers (Try on Google Colab).
- mnist_nn.py / mnist_nn.ipynb: Example of TT layers used for image classification (Try on Google Colab).
The documentation is generated using shpinx with:
make html
after installing the packages
pip install sphinx sphinx_rtd_theme
Author
Ion Gabriel Ion, e-mail: ion.ion.gabriel@gmail.com
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
File details
Details for the file torchtt-0.3.tar.gz.
File metadata
- Download URL: torchtt-0.3.tar.gz
- Upload date:
- Size: 524.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.0.1 CPython/3.12.8
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
f317f57eec5b2eda6af11f7eed8bbf97b18bb1fac8f00f1d22c97703fc1bd4d9
|
|
| MD5 |
69a1873e082955392722f382fdab0b1e
|
|
| BLAKE2b-256 |
9efd7020c0128be303812dfc96426b6b295706ebd3da948b0464803be09e3fa9
|
Provenance
The following attestation bundles were made for torchtt-0.3.tar.gz:
Publisher:
publish.yml on ion-g-ion/torchTT
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
torchtt-0.3.tar.gz -
Subject digest:
f317f57eec5b2eda6af11f7eed8bbf97b18bb1fac8f00f1d22c97703fc1bd4d9 - Sigstore transparency entry: 154280487
- Sigstore integration time:
-
Permalink:
ion-g-ion/torchTT@c43b664c74d21e5e69611fe80c3b9853ea54d15f -
Branch / Tag:
refs/tags/v0.3 - Owner: https://github.com/ion-g-ion
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@c43b664c74d21e5e69611fe80c3b9853ea54d15f -
Trigger Event:
push
-
Statement type: