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.11".

The package can be installed via pip: pip install teneva (it requires the Python programming language of the version >= 3.10). It can be also downloaded from the repository teneva and installed by pip 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.11.tar.gz (986.0 kB view details)

Uploaded Source

Built Distribution

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

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

Uploaded Python 3

File details

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

File metadata

  • Download URL: teneva-0.14.11.tar.gz
  • Upload date:
  • Size: 986.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.10.19

File hashes

Hashes for teneva-0.14.11.tar.gz
Algorithm Hash digest
SHA256 d2c5caa268a1b6e976f80852dfdee38b2170088a985190933781c1f69b9ce63d
MD5 d8a573d297fb121e593be3c0d7ef2bea
BLAKE2b-256 032463ee3033fccabd6b5a266f1e6a2753973bb4570cf9bacd28ffc1c2d58ef6

See more details on using hashes here.

File details

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

File metadata

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

File hashes

Hashes for teneva-0.14.11-py3-none-any.whl
Algorithm Hash digest
SHA256 e5359e41b554ab1dbd0edafb03007b355543cdebf7efc32a72dd552383baa26c
MD5 51b977ee5650de999062c6933f9830a1
BLAKE2b-256 e704ea3b9b81ac31a456de0f1fb6f6a07e4d452fc960666ea14fe758ad645856

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