Published October 9, 2020 | Version v1
Software Open

Paradoxes of probabilistic programming, and how to condition on events of measure zero with infinitesimal probabilities

Creators

  • 1. TU Delft

Description

Abstract Probabilistic programming languages allow programmers to write down conditional probability distributions that represent statistical and machine learning models as programs that use observe statements. These programs are run by accumulating likelihood at each observe statement, and using the likelihood to steer random choices and weigh results with inference algorithms such as importance sampling or MCMC. We argue that naive likelihood accumulation does not give desirable semantics and leads to paradoxes when an observe statement is used to condition on a measure-zero event, particularly when the observe statement is executed conditionally on random data. We show that the paradoxes disappear if we explicitly model measure-zero events as a limit of positive measure events, and that we can execute these type of probabilistic programs by accumulating infinitesimal probabilities rather than probability densities. Our extension improves probabilistic programming languages as an executable notation for probability distributions by making it more well-behaved and more expressive, by allowing the programmer to be explicit about which limit is intended when conditioning on an event of measure zero.

Notes

Since it is a single file of code I did not make a virtual machine. If you think it is better to make a virtual machine I can still do so. I will remove this notice eventually.

Files

Files (11.9 kB)

Name Size Download all
md5:45a1832a4d52333a53975c004378a4e8
11.9 kB Download