Skip to main content

Fitting and sampling vine copulas using PyTorch.

Project description

torchvinecopulib

Codacy Badge Codacy Badge Lint Pytest Deploy Docs

PyPI - Python Version OS

License: MIT PyPI - Version

A Python library for fitting and sampling vine copulas, using PyTorch.

  • C/D/R-Vine full-sampling/ quantile-regression/ conditional-sampling, all in one package
    • Flexible sampling order for experienced users
  • Vectorized tensor computation with GPU (device='cuda') support
  • Shorter runtimes for higher dimension simulations
  • Pure Python library, inspired by pyvinecopulib on Windows, Linux, MacOS
  • IO and visualization support

Citation

If you use torchvinecopulib in your work, please cite:

Cheng, Tuoyuan, Thibault Vatter, Thomas Nagler, and Kan Chen. "Vine Copulas as Differentiable Computational Graphs." arXiv preprint arXiv:2506.13318 (2025).

@article{cheng2025vine,
  title={Vine Copulas as Differentiable Computational Graphs},
  author={Cheng, Tuoyuan and Vatter, Thibault and Nagler, Thomas and Chen, Kan},
  journal={arXiv preprint arXiv:2506.13318},
  year={2025},
  url={https://arxiv.org/abs/2506.13318},
}

Examples

Visit the ./examples/ folder for .ipynb Jupyter notebooks.

Installation

pip install torchvinecopulib torch
  • Or pip from ./dist/*.whl or ./dist/*.tar.gz in this repo. Need to use proper file name.
# inside project root folder
pip install ./dist/torchvinecopulib-1.1.0-py3-none-any.whl
# or
pip install ./dist/torchvinecopulib-1.1.0.tar.gz

(Recommended) uv for Dependency Management and Packaging

After git clone https://github.com/TY-Cheng/torchvinecopulib.git, cd into the project root where pyproject.toml exists,

# inside project root folder
uv sync --extra cpu -U
# or
uv sync --extra cu126 -U

Dependencies

# inside the `./pyproject.toml` file;
fastkde = "*"
numpy = "*"
pyvinecopulib = "*"
python = ">=3.11"
scipy = "*"
# optional to facilitate customization
torch = [
    { index = "torch-cpu", extra = "cpu" },
    { index = "torch-cu126", extra = "cu126" },
]

For PyTorch with cuda:

pip install torch --index-url https://download.pytorch.org/whl/cu126 --force-reinstall
# check cuda availability
python -c "import torch; print(torch.cuda.is_available())"

[!TIP] macOS users should set device='cpu' at this stage, for using device='mps' won't support dtype=torch.float64.

Documentation

# inside project root folder
sphinx-apidoc -o ./docs ./torchvinecopulib && cd ./docs && make html && cd ..
# if using uv
uv run sphinx-apidoc -o docs torchvinecopulib/ --separate
uv run sphinx-build docs docs/_build/html

Tests

# inside project root folder
python -m pytest ./tests
# coverage report
coverage run -m pytest ./tests && coverage html
# if using uv
uv run coverage run --source=torchvinecopulib -m pytest ./tests
uv run coverage report -m

TODO

  • VineCop.rosenblatt
  • replace dict with torch.Tensor using some mod
  • vectorized union-find
  • flatten _visit logic
  • examples/someapplications.ipynb
  • flatten dynamic nested dicts into tensors
  • fastkde.pdf onto torch.Tensor

Contributing

We welcome contributions, whether it's a bug report, feature suggestion, code contribution, or documentation improvement.

  • If you encounter any issues with the project or have ideas for new features, please open an issue on GitHub or privately email us. Make sure to include detailed information about the problem or feature request, including steps to reproduce for bugs.

Code Contributions

  1. Fork the repository and create a new branch from the main branch.
  2. Make your changes and ensure they adhere to the project's coding style and conventions.
  3. Write tests for any new functionality and ensure existing tests pass.
  4. Commit your changes with clear and descriptive commit messages.
  5. Push your changes to your fork and submit a pull request to the main branch of the original repository.

Pull Request Guidelines

  • Keep pull requests focused on addressing a single issue or feature.
  • Include a clear and descriptive title and description for your pull request.
  • Make sure all tests pass before submitting the pull request.
  • If your pull request addresses an open issue, reference the issue number in the description using the syntax #issue_number.
  • in-place ops can be slower
  • torch.jit.script can be slower

License

This project is released under the MIT License (© 2024- Tuoyuan Cheng, Kan Chen).
See LICENSE for the full text, including our own grant of rights and disclaimer.

Third-Party Dependencies

See the “Third-Party Dependencies” section in LICENSE for details on the PyTorch, FastKDE, and pyvinecopulib licenses that govern those components.

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

torchvinecopulib-1.1.2.tar.gz (52.4 kB view details)

Uploaded Source

Built Distribution

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

torchvinecopulib-1.1.2-py3-none-any.whl (31.5 kB view details)

Uploaded Python 3

File details

Details for the file torchvinecopulib-1.1.2.tar.gz.

File metadata

  • Download URL: torchvinecopulib-1.1.2.tar.gz
  • Upload date:
  • Size: 52.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for torchvinecopulib-1.1.2.tar.gz
Algorithm Hash digest
SHA256 b4d8cbc544b6fee71594b6200a08d5ba4aef440ba43eafc396c094dfefd66abc
MD5 1b282ef751d6adc4ea83ac5418081be1
BLAKE2b-256 9731d3ab417a36e15822f9e0d304938f9fe612df30457506c01c3bd3b3ba60ff

See more details on using hashes here.

Provenance

The following attestation bundles were made for torchvinecopulib-1.1.2.tar.gz:

Publisher: publish-package.yml on TY-Cheng/torchvinecopulib

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file torchvinecopulib-1.1.2-py3-none-any.whl.

File metadata

File hashes

Hashes for torchvinecopulib-1.1.2-py3-none-any.whl
Algorithm Hash digest
SHA256 61b174d9a6c72396dab290c1428e98ade72a251eabffaafb48db354052858534
MD5 484907e099940cec0c4542955f71945c
BLAKE2b-256 5f5a004dc544041554830b38ef4085e7c894ee81752a2a1302c897f8efc127d6

See more details on using hashes here.

Provenance

The following attestation bundles were made for torchvinecopulib-1.1.2-py3-none-any.whl:

Publisher: publish-package.yml on TY-Cheng/torchvinecopulib

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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