Skip to content

TuringLang/Turing.jl

Folders and files

NameName
Last commit message
Last commit date

Latest commit

Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 

Repository files navigation

Turing.jl logo

Turing.jl

Probabilistic programming and Bayesian inference in Julia

Tutorials API docs Tests Coverage ColPrac: Contributor's Guide on Collaborative Practices for Community Packages

πŸš€ Get started

Install Julia (see the official Julia website; you will need at least Julia 1.10 will be required for the latest version of Turing.jl. Then, launch a Julia REPL and run:

julia> using Pkg; Pkg.add("Turing")

You can define models using the @model macro, and then perform Markov chain Monte Carlo sampling using the sample function:

julia> using Turing

julia> @model function my_first_model(data)
           mean ~ Normal(0, 1)
           sd ~ truncated(Cauchy(0, 3); lower=0)
           data ~ Normal(mean, sd)
       end

julia> model = my_first_model(randn())

julia> chain = sample(model, NUTS(), 1000)

You can find the main TuringLang documentation at https://turinglang.org, which contains general information about Turing.jl's features, as well as a variety of tutorials with examples of Turing.jl models.

API documentation for Turing.jl is specifically available at https://turinglang.org/Turing.jl/stable.

πŸ› οΈ Contributing

Issues

If you find any bugs or unintuitive behaviour when using Turing.jl, please do open an issue! Please don't worry about finding the correct repository for the issue; we can migrate the issue to the appropriate repository if we need to.

Pull requests

We are of course also very happy to receive pull requests. If you are unsure about whether a particular feature would be welcome, you can open an issue for discussion first.

When opening a PR, non-breaking releases (patch versions) should target the main branch. Breaking releases (minor version) should target the breaking branch.

If you have not received any feedback on an issue or PR for a while, please feel free to ping @TuringLang/maintainers in a comment.

πŸ’¬ Other channels

The Turing.jl userbase tends to be most active on the #turing channel of Julia Slack. If you do not have an invitation to Julia's Slack, you can get one from the official Julia website.

There are also often threads on Julia Discourse (you can search using, e.g., the turing tag).

πŸ”„ What's changed recently?

We publish a fortnightly newsletter summarising recent updates in the TuringLang ecosystem, which you can view on our website, GitHub, or Julia Slack.

For Turing.jl specifically, you can see a full changelog in HISTORY.md or our GitHub releases.

🧩 Where does Turing.jl sit in the TuringLang ecosystem?

Turing.jl is the main entry point for users, and seeks to provide a unified, convenient interface to all of the functionality in the TuringLang (and broader Julia) ecosystem.

In particular, it takes the ability to specify probabilistic models with DynamicPPL.jl, and combines it with a number of inference algorithms, such as:

Citing Turing.jl

If you have used Turing.jl in your work, we would be very grateful if you could cite the following:

Turing.jl: a general-purpose probabilistic programming language
Tor Erlend Fjelde, Kai Xu, David Widmann, Mohamed Tarek, Cameron Pfiffer, Martin Trapp, Seth D. Axen, Xianda Sun, Markus Hauru, Penelope Yong, Will Tebbutt, Zoubin Ghahramani, Hong Ge
ACM Transactions on Probabilistic Machine Learning, 2025 (Just Accepted)

Turing: A Language for Flexible Probabilistic Inference
Hong Ge, Kai Xu, Zoubin Ghahramani
Proceedings of the Twenty-First International Conference on Artificial Intelligence and Statistics, PMLR 84:1682-1690, 2018.

Expand for BibTeX
@article{10.1145/3711897,
author = {Fjelde, Tor Erlend and Xu, Kai and Widmann, David and Tarek, Mohamed and Pfiffer, Cameron and Trapp, Martin and Axen, Seth D. and Sun, Xianda and Hauru, Markus and Yong, Penelope and Tebbutt, Will and Ghahramani, Zoubin and Ge, Hong},
title = {Turing.jl: a general-purpose probabilistic programming language},
year = {2025},
publisher = {Association for Computing Machinery},
address = {New York, NY, USA},
url = {https://doi.org/10.1145/3711897},
doi = {10.1145/3711897},
note = {Just Accepted},
journal = {ACM Trans. Probab. Mach. Learn.},
month = feb,
}

@InProceedings{pmlr-v84-ge18b,
  title = 	 {Turing: A Language for Flexible Probabilistic Inference},
  author = 	 {Ge, Hong and Xu, Kai and Ghahramani, Zoubin},
  booktitle = 	 {Proceedings of the Twenty-First International Conference on Artificial Intelligence and Statistics},
  pages = 	 {1682--1690},
  year = 	 {2018},
  editor = 	 {Storkey, Amos and Perez-Cruz, Fernando},
  volume = 	 {84},
  series = 	 {Proceedings of Machine Learning Research},
  month = 	 {09--11 Apr},
  publisher =    {PMLR},
  pdf = 	 {http://proceedings.mlr.press/v84/ge18b/ge18b.pdf},
  url = 	 {https://proceedings.mlr.press/v84/ge18b.html},
}

You can see the full list of publications that have cited Turing.jl on Google Scholar.