Skip to main content

Tensor Networks for Machine Learning

Project description

logo

Tensor Networks for Machine Learning

CI Pre-merge checks Docs
tn4ml is a Python library that handles tensor networks for machine learning applications.
It is built on top of Quimb, for Tensor Network objects, and JAX, for optimization pipeline.
For now, the library supports 1D Tensor Network structures:

  • Matrix Product State
  • Matrix Product Operator
  • Spaced Matrix Product Operator

It supports different embedding functions, initialization techniques, objective functions and optimization strategies.

Installation

First create a virtualenv using pyenv or conda. Then install the package and its dependencies.

With pip (tag v1.1.0):

pip install tn4ml

or directly from github:

pip install -U git+https://github.com/bsc-quantic/tn4ml.git

If you want to test and edit the code, you can clone the local version of the package and install it.

git clone https://github.com/bsc-quantic/tn4ml.git
pip install -e tn4ml/

If you want to install dependices for docs, test and examples:

pip install "tn4ml[docs]"
pip install "tn4ml[test]"
pip install "tn4ml[examples]"

Developer checks

Install the pre-commit hooks before contributing:

pip install pre-commit
pre-commit install

Run all hooks manually:

pre-commit run --all-files

The hooks run fast local checks from CI/CD (ruff, mypy, bandit) and strip notebook outputs/local metadata with nbstripout, including notebook kernel display names such as local environment names.

Accelerated runtime

(Optional) To improve runtime precision set these flags:

jax.config.update("jax_enable_x64", True)
jax.config.update('jax_default_matmul_precision', 'highest')

Running on GPU
Before everything install JAX version that supports CUDA and its suitable for runs on GPU.
Checkout how to install here: jax[cuda]

Next, at the beginning of your script set:

import os
os.environ["CUDA_VISIBLE_DEVICES"] = "0"  # Use GPU 0 - or set any GPU ID
import jax
jax.config.update("jax_platform_name", 'gpu')

Then when training Model set:

device = 'gpu'
model.configure(device=device)

Documentation

Visit tn4ml.readthedocs.io

Example notebooks

TN for Classification
TN for Anomaly Detection
TN for Anomaly Detection with DMRG-like method

Examples from the paper

Breast Cancer Classification
Unsupervised Learning with MNIST
MPS for Anomaly Detection in the Latent Space of Proton Collision Events at the LHC

Citation

If you use tn4ml in your work, please cite the following paper: arXiv:2502.13090

@article{puljak2025tn4mltensornetworktraining,
      title={tn4ml: Tensor Network Training and Customization for Machine Learning},
      author={Ema Puljak and Sergio Sanchez-Ramirez and Sergi Masot-Llima and Jofre Vallès-Muns and Artur Garcia-Saez and Maurizio Pierini},
      year={2025},
      eprint={2502.13090},
      archivePrefix={arXiv},
      primaryClass={cs.LG},
      url={https://arxiv.org/abs/2502.13090},
      }

License

MIT license - check it out here

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

tn4ml-1.1.0.tar.gz (63.6 kB view details)

Uploaded Source

Built Distribution

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

tn4ml-1.1.0-py3-none-any.whl (72.1 kB view details)

Uploaded Python 3

File details

Details for the file tn4ml-1.1.0.tar.gz.

File metadata

  • Download URL: tn4ml-1.1.0.tar.gz
  • Upload date:
  • Size: 63.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.9.25

File hashes

Hashes for tn4ml-1.1.0.tar.gz
Algorithm Hash digest
SHA256 ccbbafcd1a14f663d2daa9337c7febcd9944486ef9af45d9a245da2bc7e93d10
MD5 2df5c8db0ec6cbdc880a6c08cb3b0d6f
BLAKE2b-256 1dc3a2dde5ef161164dd768ae40c440b502e2f3aedbdcb9d1f60b0c9f5b17e71

See more details on using hashes here.

File details

Details for the file tn4ml-1.1.0-py3-none-any.whl.

File metadata

  • Download URL: tn4ml-1.1.0-py3-none-any.whl
  • Upload date:
  • Size: 72.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.9.25

File hashes

Hashes for tn4ml-1.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 5f998a9d7cbaeeb196d7f6ca3a1f86ec26d8ae37409fbac09f6f4996569f1735
MD5 1c77292c001767360c1b58c79479e1e3
BLAKE2b-256 1a0783d1982bad17697b8a3f8c2cad6e2f299837abc0efbbacd0bb7b4f779cc0

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