Probabilistic programming
A probabilistic programming language (PPL) is a programming language designed to describe probabilistic models and then perform inference in those models. PPLs are closely related to graphical models and Bayesian networks, but are more expressive and flexible.[1] Probabilistic programming represents an attempt to "[unify] general purpose programming with probabilistic modeling."[2]
Probabilistic reasoning is a foundational technology of machine learning. It is used by companies such as Google, Amazon.com and Microsoft. Probabilistic reasoning has been used for predicting stock prices, recommending movies, diagnosing computers, detecting cyber intrusions and image detection.[3]
PPLs often extend from a basic language. The choice of underlying basic language depends on the similarity of the model to the basic language's ontology, as well as commercial considerations and personal preference. For instance, Dimple[4] and Chimple[5] are based on Java, Infer.NET is based on .NET framework,[6] while PRISM extends from Prolog.[7] However, some PPLs such as WinBUGS and Stan offer a self-contained language, with no obvious origin in another language.[8][9]
Several PPLs are in active development, including some in beta test.
Relational
A probabilistic relational programming language (PRPL) is a PPL specially designed to describe and infer with probabilistic relational models (PRMs).
A PRM is usually developed with a set of algorithms for reducing, inference about and discovery of concerned distributions, which are embedded into the corresponding PRPL.
Probabilistic programming
Probabilistic programming creates systems that help make decisions in the face of uncertainty. Probabilistic reasoning combines knowledge of a situation with the laws of probability. Until recently, probabilistic reasoning systems have been limited in scope, and have not successfully addressed real world situations. Probabilistic programming is a new approach that makes probabilistic reasoning systems easier to build and more widely applicable.[10] Reasoning about variables as probability distributions causes difficulties for novice programmers, but these difficulties can be addressed through use of Bayesian network visualisations and graphs of variable distributions embedded within the source code editor.[11]
Applications
In 2015, a 50-line PPL computer vision program was used to generate 3D models of human faces based on 2D images of those faces. The program used inverse graphics as the basis of its inferencing.[3] This made possible "in 50 lines of code what used to take thousands [whereas their experiments used their] probabilistic programming language they call Picture, which is an extension of Julia language, another language developed at MIT".[12][13] A paper on the Picture language, shown at the 2015 Computer Vision and Pattern Recognition conference, was awarded "Best Paper Honorable Mention".[14]
List of probabilistic programming languages
Name | Extends from | Host language |
---|---|---|
Analytica[15] | C++ | |
bayesloop[16][17] | Python | Python |
Venture[18] | Scheme | C++ |
Probabilistic-C[19] | C | C |
Anglican[20] | Clojure | Clojure |
IBAL[21] | OCaml | |
PRISM[7] | B-Prolog | |
Infer.NET[6] | .NET Framework | .NET Framework |
dimple[4] | MATLAB, Java | |
chimple[5] | MATLAB, Java | |
BLOG[22] | Java | |
PSQL[23] | SQL | |
BUGS[8] | ||
FACTORIE[24] | Scala | |
PMTK[25] | MATLAB | MATLAB |
Alchemy[26] | C++ | |
Dyna[27] | Prolog | |
Figaro[28] | Scala | |
Church[29] | Scheme | Various: JavaScript, Scheme |
ProbLog[30] | Prolog | Python, Jython |
ProBT[31] | C++, Python | |
Stan[9] | C++ | |
Hakaru[32] | Haskell | Haskell |
BAli-Phy (software)[33] | Haskell | C++ |
ProbCog[34] | Java, Python | |
Gamble[35] | Racket | |
PWhile[36] | While | Python |
Tuffy[37] | Java | |
PyMC3[38] | Python, Theano | Python |
greta[39] | TensorFlow | R |
pomegranate[40] | Python | Python |
Lea[41] | Python | Python |
WebPPL[42] | JavaScript | JavaScript |
Picture[3] | Julia | Julia |
Turing.jl[43] | Julia | Julia |
Troll[44] | Moscow ML | |
Edward[45] | TensorFlow | Python |
TensorFlow Probability[46] | TensorFlow | Python |
Edward2[47] | TensorFlow Probability | Python |
Pyro[48] | PyTorch | Python |
Saul[49] | Scala | Scala |
RankPL[50] | Java | |
Birch[51] | C++ |
See also
Notes
- ^ "Probabilistic programming does in 50 lines of code what used to take thousands". phys.org. April 13, 2015. Retrieved April 13, 2015.
- ^ "Probabilistic Programming". probabilistic-programming.org.
- ^ a b c "Short probabilistic programming machine-learning code replaces complex programs for computer-vision tasks". KurzweilAI. April 13, 2015. Retrieved November 27, 2017.
- ^ a b "Dimple Home Page". analog.com.
- ^ a b "Chimple Home Page". analog.com.
- ^ a b "Infer.NET". microsoft.com. Microsoft.
- ^ a b "PRISM: PRogramming In Statistical Modeling". rjida.meijo-u.ac.jp.
- ^ a b "The BUGS Project - MRC Biostatistics Unit". cam.ac.uk.
- ^ a b "Stan". mc-stan.org.
- ^ Pfeffer, Avrom (2014), Practical Probabilistic Programming, Manning Publications. p.28. ISBN 978-1 6172-9233-0
- ^ Gorinova, Maria I.; Sarkar, Advait; Blackwell, Alan F.; Syme, Don (January 1, 2016). "A Live, Multiple-Representation Probabilistic Programming Environment for Novices". Proceedings of the 2016 CHI Conference on Human Factors in Computing Systems. CHI '16. New York, NY, USA: ACM: 2533–2537. doi:10.1145/2858036.2858221. ISBN 9781450333627.
- ^ Hardesty, Larry (April 13, 2015). "Graphics in reverse".
- ^ "MIT shows off machine-learning script to make CREEPY HEADS".
- ^ "CVPR 2015 Webpage - Awards". www.pamitc.org.
- ^ "Analytica-- A Probabilistic Modeling Language". lumina.com.
- ^ "bayesloop: Probabilistic programming framework that facilitates objective model selection for time-varying parameter models".
- ^ "GitHub -- bayesloop".
- ^ "Venture -- a general-purpose probabilistic programming platform". mit.edu.
- ^ "Probabilistic C". ox.ac.uk.
- ^ "The Anglican Probabilistic Programming System". ox.ac.uk.
- ^ "IBAL Home Page". Archived from the original on December 26, 2010.
{{cite web}}
: Unknown parameter|deadurl=
ignored (|url-status=
suggested) (help) - ^ "Bayesian Logic (BLOG)". mit.edu. Archived from the original on June 16, 2011.
{{cite web}}
: Unknown parameter|deadurl=
ignored (|url-status=
suggested) (help) - ^ "PSQL: A query language for probabilistic relational data". Data & Knowledge Engineering. 28: 107–120. doi:10.1016/S0169-023X(98)00015-9.
- ^ "Factorie - Probabilistic programming with imperatively-defined factor graphs - Google Project Hosting". google.com.
- ^ "PMTK3 - probabilistic modeling toolkit for Matlab/Octave, version 3 - Google Project Hosting". google.com.
- ^ "Alchemy - Open Source AI". washington.edu.
- ^ "Dyna". www.dyna.org.
- ^ "Charles River Analytics - Probabilistic Modeling Services". cra.com.
- ^ "Church". mit.edu.
- ^ "ProbLog: Probabilistic Programming". dtai.cs.kuleuven.be.
- ^ ProbaYes. "ProbaYes - Ensemble, nous valorisations vos données". probayes.com.
- ^ "Hakaru Home Page". hakaru-dev.github.io/.
- ^ "BAli-Phy Home Page". bali-phy.org.
- ^ "ProbCog". GitHub.
- ^ Culpepper, Ryan (January 17, 2017). "gamble: Probabilistic Programming" – via GitHub.
- ^ "PWhile Compiler". GitHub.
- ^ "Tuffy: A Scalable Markov Logic Inference Engine". stanford.edu.
- ^ PyMC devs. "PyMC3". pymc-devs.github.io.
- ^ "greta: simple and scalable statistical modelling in R". GitHub. Retrieved October 2, 2018.
{{cite web}}
: Cite has empty unknown parameter:|dead-url=
(help) - ^ "Home — pomegranate 0.10.0 documentation". pomegranate.readthedocs.io. Retrieved October 2, 2018.
- ^ "Lea Home Page". bitbucket.org.
- ^ "WebPPL Home Page". github.com/probmods/webppl.
- ^ "The Turing language for probabilistic programming".
- ^ "Troll dice roller and probability calculator".
- ^ "Edward – Home". edwardlib.org. Retrieved January 17, 2017.
- ^ TensorFlow (April 11, 2018). "Introducing TensorFlow Probability". TensorFlow. Retrieved October 2, 2018.
- ^ "'Edward2' TensorFlow Probability module". GitHub. Retrieved October 2, 2018.
{{cite web}}
: Cite has empty unknown parameter:|dead-url=
(help) - ^ "Pyro". pyro.ai. Retrieved February 9, 2018.
- ^ "CogComp - Home".
- ^ Rienstra, Tjitze (January 18, 2018), RankPL: A qualitative probabilistic programming language based on ranking theory, retrieved January 18, 2018
- ^ "Probabilistic Programming in Birch". birch-lang.org. Retrieved April 20, 2018.