Skip to main content

NumPyro integration for dynamical systems

Project description

GitHub Actions Workflow Status GitHub License

Welcome to Dynestyx

dynestyx logo

dynestyx is a library designed for Bayesian modeling and inference of dynamical systems. It is an extension of NumPyro, and incorporates a wide variety of state-of-the-art inference methods for state space models.

To get started, you can read the documentation (version menu: stable = latest release, latest = main) or go straight to the quickstart. See Versioned documentation for details.

Goals of dynestyx

The goal of dynestyx is to decouple model code and inference code for dynamical systems, a common theme in probabilistic programming languages like NumPyro. The benefits of this are two-fold: modellers get an interface that is simple to use, with access to advanced inference methods for free. Methods researchers simultaneously get a platform where their methodologies can be immediately used, with a natural testbed of problems to evaluate performance on.

Relation to Existing Libraries

While many probabilistic programming languages now exist (e.g., Pyro, NumPyro, and Stan), these solutions do not offer support of structured inference methods specifically designed for the dynamical systems setting, leading to subpar inference and ad-hoc code that may be difficult to write for practitioners. In dynestyx, we treat dynamical systems as first-class objects, with direct interfacing to methods like pseudo-marginal MCMC and stochastic variational inference for parameter inference.

Simultaneously, many strong solutions exist for inference in dynamical systems; modern examples include dynamax for discrete-time dynamical systems, cd-dynamax for continuous-time dynamical systems, and PFJax for nonlinear and non-Gaussian discrete-time dynamical systems. While featureful, one drawback of this suite of methods is a varied set of APIs, with model code that is tightly coupled with the resulting inference method. In dynestyx, we offer a large variety of different inference methods under the same roof in a unified, abstract API. Iterating and selecting the appropriate inference methods is thus a significantly simpler process. Using tools from PPLs, we are also able to introspectively analyze a given model, and select appropriate inference methods which take advantage of model structure (e.g., linearity or Gaussianity).

Installation

For installation, we recommend uv:

uv venv
source .venv/bin/activate
uv pip install git+https://github.com/BasisResearch/dynestyx.git

But pip works as well:

pip install git+https://github.com/BasisResearch/dynestyx.git

Quickstart

We provide a more mathematical introduction in the Introduction section. For a hands-on tutorial with code examples, check out the Quickstart Tutorial.

Contributing

Contributions are welcome. See Contributing Guidelines for development setup, testing expectations, and the pull request workflow.

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

dynestyx-0.0.5.tar.gz (25.6 MB view details)

Uploaded Source

Built Distribution

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

dynestyx-0.0.5-py3-none-any.whl (75.6 kB view details)

Uploaded Python 3

File details

Details for the file dynestyx-0.0.5.tar.gz.

File metadata

  • Download URL: dynestyx-0.0.5.tar.gz
  • Upload date:
  • Size: 25.6 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for dynestyx-0.0.5.tar.gz
Algorithm Hash digest
SHA256 14b9341c1ec5c074818bfac31f8f74365d786a3df30417e7b3ebd9cfebc1aaee
MD5 40a60df75590ca36d1d5b34078a4b18a
BLAKE2b-256 cebde1d18b53bac5cdc4c53fb7f28d9fd192f4eea749ab325985c890bdc21ae4

See more details on using hashes here.

Provenance

The following attestation bundles were made for dynestyx-0.0.5.tar.gz:

Publisher: python-publish.yml on BasisResearch/dynestyx

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

File details

Details for the file dynestyx-0.0.5-py3-none-any.whl.

File metadata

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

File hashes

Hashes for dynestyx-0.0.5-py3-none-any.whl
Algorithm Hash digest
SHA256 eb066312e3fb5a287c397afb39d242fdcb33c450ca6d24fe54f99c4eebeec84f
MD5 5942a997ed3ba17bf8820641239b2803
BLAKE2b-256 ea8510f894700fd3e160df490f075ab811e377411a557a68444478741160919d

See more details on using hashes here.

Provenance

The following attestation bundles were made for dynestyx-0.0.5-py3-none-any.whl:

Publisher: python-publish.yml on BasisResearch/dynestyx

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