Skip to main content

Free probability for large matrices

Project description

https://raw.githubusercontent.com/ameli/freealg/refs/heads/main/docs/source/_static/images/icons/logo-freealg-light.png

Paper | Slides | Docs | Live Demo

freealg is a Python package that employs free probability to evaluate the spectral densities of large matrix forms. The fundamental algorithm employed by freealg is free decompression, which extrapolates from the empirical spectral densities of small submatrices to infer the eigenspectrum of extremely large matrices.

Install

pypi

Install with pip:

pip install freealg

Alternatively, clone the source code and install with

cd source_dir
pip install .

Documentation

deploy-docs

Documentation is available at ameli.github.io/freealg.

Quick Usage

The following code estimates the eigenvalues of a very large Wishart matrix using a much smaller Wishart matrix.

>>> import freealg as fa
>>> mp = fa.distributions.MarchenkoPastur(1/50) # Wishart matrices with aspect ratio 1/50
>>> A = mp.matrix(1000)                         # Sample a 1000 x 1000 Wishart matrix
>>> eigs = fa.eigvalsh(A, 100_000)              # Estimate the eigenvalues of 100000 x 100000

For more details on how to interface with freealg check out the Live Demo.

Test

build-linux

You may test the package with tox:

cd source_dir
tox

Alternatively, test with pytest:

cd source_dir
pytest

How to Contribute

We welcome contributions via GitHub’s pull request. Developers should review our Contributing Guidelines before submitting their code. If you do not feel comfortable modifying the code, we also welcome feature requests and bug reports.

How to Cite

If you use this work, please cite our arXiv paper.

@article{spectral2025,
    title={Spectral Estimation with Free Decompression},
    author={Siavash Ameli and Chris van der Heide and Liam Hodgkinson and Michael W. Mahoney},
    year={2025},
    eprint={2506.11994},
    archivePrefix={arXiv},
    primaryClass={stat.ML},
    url={https://arxiv.org/abs/2506.11994},
    journal={arXiv preprint arXiv:2506.11994},
}

License

license

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

freealg-0.6.2.tar.gz (59.4 kB view details)

Uploaded Source

Built Distribution

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

freealg-0.6.2-py3-none-any.whl (75.6 kB view details)

Uploaded Python 3

File details

Details for the file freealg-0.6.2.tar.gz.

File metadata

  • Download URL: freealg-0.6.2.tar.gz
  • Upload date:
  • Size: 59.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for freealg-0.6.2.tar.gz
Algorithm Hash digest
SHA256 1813d18b36b0987e7a9f618d2cdf58724d5b3817ac8c4d97f0a1411468c6dc59
MD5 39f3cd4a36a55b2e8e62997622fae0c5
BLAKE2b-256 f62caf25cf0d2e9caa47220f1da3079450334b31163b8b2ac9aa197ed8c3d5a8

See more details on using hashes here.

File details

Details for the file freealg-0.6.2-py3-none-any.whl.

File metadata

  • Download URL: freealg-0.6.2-py3-none-any.whl
  • Upload date:
  • Size: 75.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for freealg-0.6.2-py3-none-any.whl
Algorithm Hash digest
SHA256 e3d8e3589ce562cadcc02e683c70eaa54745df52af71a40e384997d22c0338cf
MD5 744e3f6ff7cb15635192fe36ab6a7d50
BLAKE2b-256 c0fd39a05472c84d013b906e28ec6e78d3f1724e0f55c72421e4acb67ef9b49e

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