Skip to main content

Compact implementation of basic operations in the tensor-train (TT) format, including TT-SVD, TT-ALS, TT-ANOVA, TT-CROSS, TT-truncate for approximation of multidimensional arrays and multivariate functions

Project description

teneva

Description

This python package, named teneva (tensor evaluation), provides a very compact implementation of basic operations in the tensor-train (TT) format, including TT-SVD, TT-ALS, TT-ANOVA, TT-cross, TT-truncate, Chebyshev interpolation, "add", "mul", "norm", "mean", "sample", etc. Our approach can be used for approximation of multidimensional arrays and multivariate functions, as well as for efficient implementation of various operations of linear algebra in the low rank TT-format. The program code is organized within a functional paradigm and it is very easy to learn and use. Each function has detailed documentation and various usage demos.

Installation

Current version "0.14.9".

The package can be installed via pip: pip install teneva (it requires the Python programming language of the version 3.8 or 3.9). It can be also downloaded from the repository teneva and installed by python setup.py install command from the root folder of the project.

Documentation, examples and tests

  • See detailed online documentation for a description of each function and various numerical examples for each function.

  • See the jupyter notebooks in the demo folder of the repository teneva with brief description and demonstration of the capabilities of each function from the teneva package, including the basic examples of using the TT-ALS, TT-ANOVA and TT-cross for approximation of the multivariable functions. Note that all examples from this folder are also presented in the online documentation.

  • See changelog.md file with a description of the changes made for new package versions and workflow.md file with a description of the rules we use to work on the code (draft!).

  • Run all the tests (based on the unittest framework) from the root of the repository teneva as python test/test.py (draft!).

Useful links

  • The github repository teneva_jax with the fast jax version of the teneva code.

  • The github repository teneva_bm with benchmarks library for testing multidimensional approximation and optimization methods.

  • The github repository teneva_opti with wrapper for various optimizers adapted to work with benchmarks from teneva_bm.

  • The github repository ttopt with the gradient-free optimization method TTOpt for multivariable functions based on the TT-format and maximal-volume principle (see also NeurIPS-2022 paper).

  • The github repository PROTES with the optimization method PROTES (PRobability Optimizer with TEnsor Sampling) for derivative-free optimization of the multidimensional arrays and discretized multivariate functions based on the TT-format (see also arxiv paper).

  • The github repository Constructive-TT with the method for constructive TT-representation of the tensors given as index interaction functions (see also ICLR-2023 paper).

  • Paper Tensor train decomposition, in which the TT-decomposition is presented and the main its properties are described.

  • Dissertation work Computational tensor methods and their applications (in Russian only), in which the TT-decomposition is proposed and all its properties are described in detail.

  • Dissertation work Tensor methods for multidimensional differential equations (in Russian only), which presents various new algorithms in the TT-format for problems of multidimensional approximation, optimization and solution of differential equations.

Authors

✭__🚂 The stars that you give to teneva, motivate us to develop faster and add new interesting features to the code 😃

Citation

If you find our approach and/or code useful in your research, please consider citing:

@article{chertkov2023black,
    author    = {Chertkov, Andrei and Ryzhakov, Gleb and Oseledets, Ivan},
    year      = {2023},
    title     = {Black box approximation in the tensor train format initialized by {ANOVA} decomposition},
    journal   = {SIAM Journal on Scientific Computing},
    volume    = {45},
    number    = {4},
    pages     = {A2101-A2118},
    doi       = {10.1137/22M1514088},
    url       = {https://arxiv.org/pdf/2208.03380.pdf}
}
@article{chertkov2023tensor,
    author    = {Chertkov, Andrei and Ryzhakov, Gleb and Novikov, Georgii and Oseledets, Ivan},
    year      = {2023},
    title     = {Tensor extrema estimation via sampling: A new approach for determining min/max elements},
    journal   = {Computing in Science \& Engineering},
    volume    = {25},
    number    = {5},
    pages     = {14-25},
    doi       = {10.1109/MCSE.2023.3346208},
    url       = {https://www.computer.org/csdl/magazine/cs/5555/01/10374217/1TbVVdPBCtW}
}

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

teneva-0.14.9.tar.gz (978.0 kB view details)

Uploaded Source

Built Distribution

teneva-0.14.9-py3-none-any.whl (63.8 kB view details)

Uploaded Python 3

File details

Details for the file teneva-0.14.9.tar.gz.

File metadata

  • Download URL: teneva-0.14.9.tar.gz
  • Upload date:
  • Size: 978.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.0 CPython/3.8.19

File hashes

Hashes for teneva-0.14.9.tar.gz
Algorithm Hash digest
SHA256 1392eb24446bb3ce7e1339541a9bd369aa957e8eba0af56dc55e28ffe27bf77e
MD5 91b3083d6c6bb90d95c970e74fbdffea
BLAKE2b-256 83f522d709a6af75e1f1bc31069c2dfff56b1aab4c58b7c3f5df8777effef26b

See more details on using hashes here.

File details

Details for the file teneva-0.14.9-py3-none-any.whl.

File metadata

  • Download URL: teneva-0.14.9-py3-none-any.whl
  • Upload date:
  • Size: 63.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.0 CPython/3.8.19

File hashes

Hashes for teneva-0.14.9-py3-none-any.whl
Algorithm Hash digest
SHA256 2f9930d7753449abe9f65c6d417c9af3d77f701edf6cd3fd854f2848e48477e3
MD5 79c556c9aee249996c19a377434713f9
BLAKE2b-256 24cef31a59f986a6f95c8f853c5ef8a7f713b1e3fdc5ceda538297996e9f5c59

See more details on using hashes here.

Supported by

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