package prbnmcn-dagger

  1. Overview
  2. Docs
Probabilistic programming library

Install

Dune Dependency

Authors

Maintainers

Sources

0.0.6.tar.gz
md5=737f9e0a0647afa4cc55d6b75e62faec
sha512=d29223e5830454c102a4423f2799006f73abb75a5137c677665bbb8ae6adf2909fc982cc072fb7c51dd81b4b3d0faac5cc00e630a0a3be2d99554910a6b4bd31

Description

A library for probabilistic programming. It takes the form of a signature for a monadic language exposing sampling and scoring primitives together with inference algorithms implementing that signature, including:

  • sequential Monte Carlo (SMC)
  • single-site lightweight Metropolis-Hastings

Tags

statistics

Published: 20 Jan 2025

README

dagger: a probabilistic programming library

The dagger library for probabilistic programming in OCaml. Currently implements:

  • Single-site Metropolis-Hastings, a.k.a. lightweight Metropolis-Hastings

  • Incrementalized single-site MH, similar to that implemented in Hakaru10

  • Sequential Monte-Carlo, with systematic and stratified resampling plus facilities for defining custom resampling strategies.

The main package is prbnmcn-dagger. Packages prbnmcn-dagger-gsl and prbnmcn-dagger-stats provide distributions implemented respectively through the GSL (GPL-licensed) and prbnmcn-stats (MIT-licensed).

Look no further for the documentation and the examples it contains.

Some more examples are made available in the examples subdirectory. For now, you'll find:

  • an implementation of a 2d ising model and a toy study of its behaviour around its critical temperature

  • a basic kalman filter example

  • an experiment on forecasting wind power production using an ad-hoc Kalman filter

  • an implementation of the algorithm described in Adaptive approximate Bayesian computation by Beaumont et al.

Contributing

Contributions and issue reports are welcome. Development currently happen on https://gitlab.com/igarnier/monorepo/ but I can take care of cherry-picking pull requests submitted here.

Trivia

The name dagger refers to two things:

  • a good mathematical framework for giving a semantics to probabilistic programming is a certain dagger category of Markov kernels, see eg this or that paper; Bayesian inversion corresponds to a particular symmetry of a mathematical structure and this symmetry is denoted using the † symbol.

  • the underlying representation of the probabilistic model when using the incrementalized backend is as a directed acyclic graph (ie a DAG, which sounds exactly like the French translation of dagger)

Dependencies (4)

  1. prbnmcn-cgrph = "0.0.2"
  2. domainslib >= "0.5"
  3. ocaml >= "5.0.0"
  4. dune >= "2.8"

Dev Dependencies (1)

  1. odoc with-doc

Used by (3)

  1. prbnmcn-dagger-gsl >= "0.0.6"
  2. prbnmcn-dagger-stats >= "0.0.6"
  3. prbnmcn-dagger-test >= "0.0.6"

Conflicts

None

OCaml

Innovation. Community. Security.