Free probability for large matrices
Project description
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
Install with pip:
pip install freealg
Alternatively, clone the source code and install with
cd source_dir
pip install .
Documentation
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
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
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
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file freealg-0.5.0.tar.gz.
File metadata
- Download URL: freealg-0.5.0.tar.gz
- Upload date:
- Size: 54.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.12.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
f45b7b9164d803be793f1a4bf45715253d450d0e8cc98d97b56b233df20e2510
|
|
| MD5 |
ed659fae01922b2210d598e54756c9d9
|
|
| BLAKE2b-256 |
8a52de2df3c28da877f7bdfbb96a003d43299a6b86faf9c9fab1962a9ad8ed98
|
File details
Details for the file freealg-0.5.0-py3-none-any.whl.
File metadata
- Download URL: freealg-0.5.0-py3-none-any.whl
- Upload date:
- Size: 70.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.12.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
034b6c13baf0029eb80df1df2207b965e32f0692291faf99ca82aef11ddcd552
|
|
| MD5 |
a596d9d0de538d3f8c6234efa0c95162
|
|
| BLAKE2b-256 |
da7e59b7a59cd802df4cd00251df7f9a6d9b70d0064d9e3a6f12ce7b86417e50
|