Skip to main content

Yet Another Bayesian Framework

Project description

https://img.shields.io/pypi/v/yabf.svg https://codecov.io/gh/steven-murray/yabf/branch/main/graph/badge.svg?token=fuxNCeAtof Documentation Status pre-commit.ci status

Yet Another Bayesian Framework

Features

Why another Bayesian Framework? There are a relative host of Bayesian codes in Python, including major players such as PyMC3, emcee and stan, as well as a seemingly never-ending set of scientific-field-specific codes (eg. cosmology has CosmoMC, CosmoHammer, MontePython, cobaya…).

yabf was written because the author found that all the frameowrks they tried were either too lean or too involved. yabf tries to find the happy medium. It won’t be the right tool for everyone, but it might be the right tool for you.

yabf is designed to support “black box” likelihoods, by which we mean those that don’t necessarily have analytic derivatives. This separates it from codes such as PyMC3 and stan, and limits its use to samplers that do not require that information. This is more often the case in scientific applications, where likelihoods can in principle depend on some enormous black-box simulation code. Thus, in this regard it is more like emcee or polychord.

On the other hand, yabf is not another MCMC sampler. Apart from the limitations concerning likelihood derivatives, it is sampler-agnostic. It is rather a specification of a format, and an implementation of that specification. That is, it specifies that likelihoods should have certain properties (like parameters), and gives tools that enable that. Or as another example, it specifies that samplers should contain certain attributes pre- and post-sampling. In this regard, yabf is more like PyMC3 or stan, and unlike emcee or polychord.

yabf is perhaps most similar to codes such as CosmoHammer or cobaya, which provide an interface for creating (cosmological) likelihoods which can then be sampled by somie specified sampler. However, yabf is different in that it is intended to be field-agnostic, and entirely general. In addition, I found that these codes didn’t quite satisfy my criteria for ease-of-use and extensibility.

I hope that yabf provides these. Here are a few of its features:

  • Deisgn is both DRY/modular and easy-to-use: while components of the model can be separately defined (to make it DRY), they don’t need to be combined into a rigid structure in order to perform most calculations. This makes it easy to evaluate partial models for debugging.

  • Extremely extensible: write your own class that subclasses from the in-built Component or Likelihood classes, and it is immediately useable.

  • Parameters are attached to to the model, for encapsulation, but they can be specified at run-time externally for modularity.

  • Models are heirarchical, in the sense that parameters may be specified at any of three levels, and they are propagated through the model heirarchy (note that this doesn’t refer to heirarchical parameters, i.e. parameters that depend on other parameters).

  • Parameters can be set as fixed or constrained at run-time.

  • Models are well-specified, in the sense that they can be entirely specified by a YAML file (and/or written to YAML file), for reproducibility.

Credits

This package was created with Cookiecutter and the audreyr/cookiecutter-pypackage project template.

Many of the ideas in this code are adaptations of other MCMC codes, especially CosmoHammer and cobaya.

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

yabf-2.1.4.tar.gz (144.1 kB view details)

Uploaded Source

Built Distribution

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

yabf-2.1.4-py3-none-any.whl (35.3 kB view details)

Uploaded Python 3

File details

Details for the file yabf-2.1.4.tar.gz.

File metadata

  • Download URL: yabf-2.1.4.tar.gz
  • Upload date:
  • Size: 144.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for yabf-2.1.4.tar.gz
Algorithm Hash digest
SHA256 78857a69b4de5512f35f57a96bbd0c875cebf0a2aedafb8640101b105624c144
MD5 6ae0e4b057e229388440e3c737f25936
BLAKE2b-256 2d0f0de39773fd3a7ba402c1a75aef598c194600d90e352538f035287d450650

See more details on using hashes here.

Provenance

The following attestation bundles were made for yabf-2.1.4.tar.gz:

Publisher: deploy.yaml on steven-murray/yabf

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

File details

Details for the file yabf-2.1.4-py3-none-any.whl.

File metadata

  • Download URL: yabf-2.1.4-py3-none-any.whl
  • Upload date:
  • Size: 35.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for yabf-2.1.4-py3-none-any.whl
Algorithm Hash digest
SHA256 9b3d2363a4ed5547ba0db5a8a9f0ce356b1f47e8fdb445b7b168bc01171edac0
MD5 bc3c6d7f579814d30d0c9d5e7e6ef7f7
BLAKE2b-256 d45b5a9b72da88f6736a54ca7de2ef1ef20da2e0ab568d7d0beeac32042a5a8e

See more details on using hashes here.

Provenance

The following attestation bundles were made for yabf-2.1.4-py3-none-any.whl:

Publisher: deploy.yaml on steven-murray/yabf

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