jcmgray / cotengra

Hyper optimized contraction trees for large tensor networks and einsums

Home Page:https://cotengra.readthedocs.io

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

cotengra

tests codecov Codacy Badge Docs PyPI Anaconda-Server Badge

cotengra is a python library for contracting tensor networks or einsum expressions involving large numbers of tensors - the main docs can be found at cotengra.readthedocs.io. Some of the key feautures of cotengra include:

  • drop-in einsum replacement
  • an explicit contraction tree object that can be flexibly built, modified and visualized
  • a 'hyper optimizer' that samples trees while tuning the generating meta-paremeters
  • dynamic slicing for massive memory savings and parallelism
  • support for hyper edge tensor networks and thus arbitrary einsum equations
  • paths that can be supplied to numpy.einsum, opt_einsum, quimb among others
  • performing contractions with tensors from many libraries via cotengra, even if they don't provide einsum or tensordot but do have (batch) matrix multiplication

cotengra

About

Hyper optimized contraction trees for large tensor networks and einsums

https://cotengra.readthedocs.io

License:Apache License 2.0


Languages

Language:Python 96.1%Language:Rust 3.9%