From ca5319b1b4da937b85c8763aacda8040715e04cd Mon Sep 17 00:00:00 2001 From: Penelope Yong Date: Fri, 27 Sep 2024 02:00:05 +0100 Subject: [PATCH 01/10] Add workflows --- .github/workflows/Docs.yml | 37 ++++++++++++++++++++++++++ .github/workflows/DocsNav.yml | 49 +++++++++++++++++++++++++++++++++++ 2 files changed, 86 insertions(+) create mode 100644 .github/workflows/Docs.yml create mode 100644 .github/workflows/DocsNav.yml diff --git a/.github/workflows/Docs.yml b/.github/workflows/Docs.yml new file mode 100644 index 000000000..0bd4a71f7 --- /dev/null +++ b/.github/workflows/Docs.yml @@ -0,0 +1,37 @@ +name: Documentation + +on: + push: + branches: + - master + tags: '*' + pull_request: + branches: + - master + +concurrency: + # Skip intermediate builds: always. + # Cancel intermediate builds: only if it is a pull request build. + group: ${{ github.workflow }}-${{ github.ref }} + cancel-in-progress: ${{ startsWith(github.ref, 'refs/pull/') }} + +permissions: + contents: write + pull-requests: read + statuses: write + +jobs: + docs: + runs-on: ubuntu-latest + steps: + - uses: actions/checkout@v2 + - uses: julia-actions/setup-julia@latest + with: + version: '1' + - name: Install dependencies + run: julia --project=docs/ -e 'using Pkg; Pkg.develop(PackageSpec(path=pwd())); Pkg.instantiate()' + - name: Build and deploy + env: + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + DOCUMENTER_KEY: ${{ secrets.DOCUMENTER_KEY }} + run: julia --project=docs/ docs/make.jl diff --git a/.github/workflows/DocsNav.yml b/.github/workflows/DocsNav.yml new file mode 100644 index 000000000..14614d1fd --- /dev/null +++ b/.github/workflows/DocsNav.yml @@ -0,0 +1,49 @@ +name: Add Navbar + +on: + page_build: # Triggers the workflow on push events to gh-pages branch + workflow_dispatch: # Allows manual triggering + schedule: + - cron: '0 0 * * 0' # Runs every week on Sunday at midnight (UTC) + +jobs: + add-navbar: + runs-on: ubuntu-latest + permissions: + contents: write + steps: + - name: Checkout gh-pages + uses: actions/checkout@v4 + with: + ref: gh-pages + fetch-depth: 0 + + - name: Download insert_navbar.sh + run: | + curl -O https://raw.githubusercontent.com/TuringLang/turinglang.github.io/main/assets/scripts/insert_navbar.sh + chmod +x insert_navbar.sh + + - name: Update Navbar + env: + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + run: | + git config user.name github-actions[bot] + git config user.email github-actions[bot]@users.noreply.github.com + + # Define the URL of the navbar to be used + NAVBAR_URL="https://raw.githubusercontent.com/TuringLang/turinglang.github.io/main/assets/scripts/TuringNavbar.html" + + # Update all HTML files in the current directory (gh-pages root) + ./insert_navbar.sh . $NAVBAR_URL + + # Remove the insert_navbar.sh file + rm insert_navbar.sh + + # Check if there are any changes + if [[ -n $(git status -s) ]]; then + git add . + git commit -m "Added navbar and removed insert_navbar.sh" + git push "https://${GITHUB_ACTOR}:${GITHUB_TOKEN}@github.com/${GITHUB_REPOSITORY}.git" gh-pages + else + echo "No changes to commit" + fi From 7a42a89e8ffb6f03a5b2c3ab94e1669fa918fe42 Mon Sep 17 00:00:00 2001 From: Penelope Yong Date: Wed, 25 Sep 2024 12:48:54 +0100 Subject: [PATCH 02/10] Add API docs --- docs/Project.toml | 6 ++ docs/README.md | 5 - docs/make.jl | 37 +++++++ docs/src/api.md | 168 +++++++++++++++++++++++++++++++ docs/src/api/Inference.md | 6 ++ docs/src/api/Optimisation.md | 6 ++ docs/src/index.md | 5 + docs/src/library/advancedhmc.md | 25 ----- docs/src/library/api.md | 45 --------- docs/src/library/bijectors.md | 25 ----- src/Turing.jl | 4 +- src/mcmc/Inference.jl | 6 +- src/mcmc/emcee.jl | 11 ++ src/mcmc/particle_mcmc.jl | 5 + src/optimisation/Optimisation.jl | 14 ++- src/stdlib/distributions.jl | 4 +- 16 files changed, 266 insertions(+), 106 deletions(-) create mode 100644 docs/Project.toml delete mode 100644 docs/README.md create mode 100644 docs/make.jl create mode 100644 docs/src/api.md create mode 100644 docs/src/api/Inference.md create mode 100644 docs/src/api/Optimisation.md create mode 100644 docs/src/index.md delete mode 100644 docs/src/library/advancedhmc.md delete mode 100644 docs/src/library/api.md delete mode 100644 docs/src/library/bijectors.md diff --git a/docs/Project.toml b/docs/Project.toml new file mode 100644 index 000000000..02c0d03de --- /dev/null +++ b/docs/Project.toml @@ -0,0 +1,6 @@ +[deps] +Bijectors = "76274a88-744f-5084-9051-94815aaf08c4" +Distributions = "31c24e10-a181-5473-b8eb-7969acd0382f" +Documenter = "e30172f5-a6a5-5a46-863b-614d45cd2de4" +DocumenterInterLinks = "d12716ef-a0f6-4df4-a9f1-a5a34e75c656" +Turing = "fce5fe82-541a-59a6-adf8-730c64b5f9a0" diff --git a/docs/README.md b/docs/README.md deleted file mode 100644 index 7a1ad9119..000000000 --- a/docs/README.md +++ /dev/null @@ -1,5 +0,0 @@ -Turing's documentation in this directory is in markdown format. - -If you want to build the doc locally, please refer to the [README](https://github.com/TuringLang/turinglang.github.io) file in [turinglang.github.io](https://github.com/TuringLang/turinglang.github.io). - -Please also visit [this repo](https://github.com/TuringLang/TuringTutorials/tree/master/tutorials) for the docs. diff --git a/docs/make.jl b/docs/make.jl new file mode 100644 index 000000000..ebde41521 --- /dev/null +++ b/docs/make.jl @@ -0,0 +1,37 @@ +using Documenter +using Turing +# Need to import Distributions and Bijectors to generate docs for functions +# from those packages. +using Distributions +using Bijectors + +using DocumenterInterLinks + +links = InterLinks( + "DynamicPPL" => "https://turinglang.org/DynamicPPL.jl/stable/objects.inv", + "AbstractPPL" => "https://turinglang.org/AbstractPPL.jl/dev/objects.inv", + "ADTypes" => "https://sciml.github.io/ADTypes.jl/stable/objects.inv", +) + +# Doctest setup +DocMeta.setdocmeta!(Turing, :DocTestSetup, :(using Turing); recursive=true) + +makedocs(; + sitename="Turing", + modules=[Turing, Distributions, Bijectors], + pages=[ + "Home" => "index.md", + "API" => "api.md", + "Submodule APIs" => [ + "Inference" => "api/Inference.md", + "Optimisation" => "api/Optimisation.md", + ] + ], + checkdocs=:exports, + # checkdocs_ignored_modules=[Turing, Distributions, DynamicPPL, AbstractPPL, Bijectors], + doctest=false, + warnonly=true, + plugins=[links], +) + +deploydocs(; repo="github.com/TuringLang/Turing.jl.git", push_preview=true) diff --git a/docs/src/api.md b/docs/src/api.md new file mode 100644 index 000000000..cedc35bb6 --- /dev/null +++ b/docs/src/api.md @@ -0,0 +1,168 @@ +# API +## Module-wide re-exports + +Turing.jl directly re-exports the entire public API of the following packages: + + - [Distributions.jl](https://juliastats.org/Distributions.jl) + - [MCMCChains.jl](https://turinglang.org/MCMCChains.jl) + - [AbstractMCMC.jl](https://turinglang.org/AbstractMCMC.jl) + - [Bijectors.jl](https://turinglang.org/Bijectors.jl) + - [Libtask.jl](https://github.com/TuringLang/Libtask.jl) + +Please see the individual packages for their documentation. + +## Individual exports and re-exports + +**All** of the following symbols are exported unqualified by Turing, even though the documentation suggests that many of them are qualified. +That means, for example, you can just write + +```julia +using Turing + +@model function my_model(...) + +sample(my_model(), Prior(), 100) +``` + +instead of + +```julia +sample(model, Turing.Inference.Prior(), 100) +``` + +even though [`Prior()`](@ref) is actually defined in the `Turing.Inference` module. + +### Modelling + +| Exported symbol | Documentation | Description | +| --- | --- | --- | +| `@model` | [`DynamicPPL.@model`](@extref) | Define a probabilistic model | +| `@varname` | [`AbstractPPL.@varname`](@extref) | Generate a `VarName` from a Julia expression | +| `@submodel` | [`DynamicPPL.@submodel`](@extref) | Define a submodel | + +### Inference + +| Exported symbol | Documentation | Description | +| --- | --- | --- | +| `sample` | [`StatsBase.sample`](https://turinglang.org/AbstractMCMC.jl/stable/api/#Sampling-a-single-chain) | Sample from a model | + +### Samplers + +| Exported symbol | Documentation | Description | +| --- | --- | --- | +| `Prior` | [`Turing.Inference.Prior`](@ref) | Sample from the prior distribution | +| `MH` | [`Turing.Inference.MH`](@ref) | Metropolis–Hastings | +| `Emcee` | [`Turing.Inference.Emcee`](@ref) | Affine-invariant ensemble sampler | +| `ESS` | [`Turing.Inference.ESS`](@ref) | Elliptical slice sampling | +| `Gibbs` | [`Turing.Inference.Gibbs`](@ref) | Gibbs sampling | +| `GibbsConditional` | [`Turing.Inference.GibbsConditional`](@ref) | A "pseudo-sampler" to provide analytical conditionals to `Gibbs` | +| `HMC` | [`Turing.Inference.HMC`](@ref) | Hamiltonian Monte Carlo | +| `SGLD` | [`Turing.Inference.SGLD`](@ref) | Stochastic gradient Langevin dynamics | +| `SGHMC` | [`Turing.Inference.SGHMC`](@ref) | Stochastic gradient Hamiltonian Monte Carlo | +| `HMCDA` | [`Turing.Inference.HMCDA`](@ref) | Hamiltonian Monte Carlo with dual averaging | +| `NUTS` | [`Turing.Inference.NUTS`](@ref) | No-U-Turn Sampler | +| `PolynomialStepsize` | [`Turing.Inference.PolynomialStepsize`](@ref) | A function to generate a polynomially decaying step size | +| `IS` | [`Turing.Inference.IS`](@ref) | Importance sampling | +| `SMC` | [`Turing.Inference.SMC`](@ref) | Sequential Monte Carlo | +| `PG` | [`Turing.Inference.PG`](@ref) | Particle Gibbs | +| `CSMC` | [`Turing.Inference.CSMC`](@ref) | The same as PG | +| `externalsampler` | [`Turing.Inference.externalsampler`](@ref) | Wrap an external sampler for use in Turing | + +### Variational inference + +These functions are not (yet) formally documented. +Please see the [variational inference tutorial](https://turinglang.org/docs/tutorials/09-variational-inference/) for a walkthrough on how to use these. + +TODO: Generate docs for AdvancedVI 0.2, update the InterLinks object.inv, and update the table below to include `@extref`. + +| Exported symbol | Documentation | Description | +| --- | --- | --- | +| `vi` | `AdvancedVI.vi` | Perform variational inference | +| `ADVI` | `AdvancedVI.ADVI` | Construct an instance of a VI algorithm | + +### Automatic differentiation types + +These are used to specify the automatic differentiation backend to use. + +| Exported symbol | Documentation | Description | +| --- | --- | --- | +| `AutoForwardDiff` | [`ADTypes.AutoForwardDiff`](@extref) | ForwardDiff.jl backend | +| `AutoReverseDiff` | [`ADTypes.AutoReverseDiff`](@extref) | ReverseDiff.jl backend | +| `AutoZygote` | [`ADTypes.AutoZygote`](@extref) | Zygote.jl backend | +| `AutoTracker` | [`ADTypes.AutoTracker`](@extref) | Tracker.jl backend | +| `AutoTapir` | [`ADTypes.AutoTapir`](@extref) | Tapir.jl backend, only for ADTypes >= 1.0 | + +### Debugging + +```@docs +setprogress! +``` + +### Distributions + +These distributions are defined in Turing.jl, but not in Distributions.jl. + +```@docs +Flat +FlatPos +BinomialLogit +OrderedLogistic +LogPoisson +``` + +`BernoulliLogit` is part of Distributions.jl since version 0.25.77. +If you are using an older version of Distributions where this isn't defined, Turing will export the same distribution. + +```@docs +Distributions.BernoulliLogit +``` + +### Tools to work with distributions + +TODO: DistributionsAD needs docs + +| Exported symbol | Documentation | Description | +| --- | --- | --- | +| `filldist` | `DistributionsAD.filldist` | Create a product distribution from a distribution and integers | +| `arraydist` | `DistributionsAD.arraydist` | Create a product distribution from an array of distributions | +| `NamedDist` | [`DynamicPPL.NamedDist`](@extref) | A distribution that carries the name of the variable | + +### Predictions + +```@docs +predict +``` + +### Re-exports from DynamicPPL / AbstractPPL + +| Exported symbol | Documentation | Description | +| --- | --- | --- | +| `pointwise_loglikelihoods` | [`DynamicPPL.pointwise_loglikelihoods`](@extref) | Compute log likelihoods for each sample in a chain | +| `generated_quantities` | [`DynamicPPL.generated_quantities`](@extref) | Calculate additional quantities defined in a model | +| `logprior` | [`DynamicPPL.logprior`](@extref) | Compute log prior probability | +| `logjoint` | [`DynamicPPL.logjoint`](@extref) | Compute log joint probability | +| `LogDensityFunction` | [`DynamicPPL.LogDensityFunction`](@extref) | Wrap a Turing model to satisfy LogDensityFunctions.jl interface | +| `condition` | [`AbstractPPL.condition`](@extref) | Condition a model on data | +| `decondition` | [`AbstractPPL.decondition`](@extref) | Remove conditioning on data | +| `conditioned` | [`DynamicPPL.conditioned`](@extref) | Return the conditioned values of a model | +| `fix` | [`DynamicPPL.fix`](@extref) | Fix the value of a variable | +| `unfix` | [`DynamicPPL.unfix`](@extref) | Unfix the value of a variable | +| `OrderedDict` | [`OrderedCollections.OrderedDict`](https://juliacollections.github.io/OrderedCollections.jl/dev/ordered_containers/#OrderedDicts) | An ordered dictionary | + +### Extra re-exports from Bijectors + +Note that Bijectors itself does not export `ordered`. + +```@docs +Bijectors.ordered +``` + +### Point estimates + +| Exported symbol | Documentation | Description | +| --- | --- | --- | +| `maximum_a_posteriori` | [`Turing.Optimisation.maximum_a_posteriori`](@ref) | Find a MAP estimate for a model | +| `maximum_likelihood` | [`Turing.Optimisation.maximum_likelihood`](@ref) | Find a MLE estimate for a model | +| `MAP` | [`Turing.Optimisation.MAP`](@ref) | Type to use with Optim.jl for MAP estimation | +| `MLE` | [`Turing.Optimisation.MLE`](@ref) | Type to use with Optim.jl for MLE estimation | + diff --git a/docs/src/api/Inference.md b/docs/src/api/Inference.md new file mode 100644 index 000000000..7c1bbb430 --- /dev/null +++ b/docs/src/api/Inference.md @@ -0,0 +1,6 @@ +# API: `Turing.Inference` + +```@autodocs +Modules = [Turing.Inference] +Order = [:type, :function] +``` diff --git a/docs/src/api/Optimisation.md b/docs/src/api/Optimisation.md new file mode 100644 index 000000000..91e7b1ede --- /dev/null +++ b/docs/src/api/Optimisation.md @@ -0,0 +1,6 @@ +# API: `Turing.Optimisation` + +```@autodocs +Modules = [Turing.Optimisation] +Order = [:type, :function] +``` diff --git a/docs/src/index.md b/docs/src/index.md new file mode 100644 index 000000000..93e7e3b95 --- /dev/null +++ b/docs/src/index.md @@ -0,0 +1,5 @@ +# Turing.jl + +This site contains the API documentation for the identifiers exported by Turing.jl. + +If you are looking for usage examples and guides, please visit [https://turinglang.org/docs](https://turinglang.org/docs). diff --git a/docs/src/library/advancedhmc.md b/docs/src/library/advancedhmc.md deleted file mode 100644 index 84f712f4d..000000000 --- a/docs/src/library/advancedhmc.md +++ /dev/null @@ -1,25 +0,0 @@ ---- -title: AdvancedHMC -permalink: /docs/library/advancedhmc/ -toc: true ---- - -## Index - -```@index -Modules = [AdvancedHMC] -``` - -## Functions - -```@autodocs -Modules = [AdvancedHMC] -Order = [:function] -``` - -## Types - -```@autodocs -Modules = [AdvancedHMC] -Order = [:type] -``` diff --git a/docs/src/library/api.md b/docs/src/library/api.md deleted file mode 100644 index c598820b7..000000000 --- a/docs/src/library/api.md +++ /dev/null @@ -1,45 +0,0 @@ ---- -title: API -permalink: /docs/library/ -toc: true ---- - -```@meta -CurrentModule = Turing -``` - -## Index - -```@index -Modules = [Turing, Turing.Essential, Turing.Inference, Libtask] -``` - -## Modelling - -```@docs -@model -``` - -## Samplers - -```@docs -Sampler -Gibbs -HMC -HMCDA -IS -MH -NUTS -PG -SMC -``` - -## Distributions - -```@docs -Flat -FlatPos -BinomialLogit -VecBinomialLogit -OrderedLogistic -``` diff --git a/docs/src/library/bijectors.md b/docs/src/library/bijectors.md deleted file mode 100644 index 471da45fe..000000000 --- a/docs/src/library/bijectors.md +++ /dev/null @@ -1,25 +0,0 @@ ---- -title: Bijectors -permalink: /docs/library/bijectors/ -toc: true ---- - -## Index - -```@index -Modules = [Bijectors] -``` - -## Functions - -```@autodocs -Modules = [Bijectors] -Order = [:function] -``` - -## Types - -```@autodocs -Modules = [Bijectors] -Order = [:type] -``` diff --git a/src/Turing.jl b/src/Turing.jl index 8dfb8df28..873c270fa 100644 --- a/src/Turing.jl +++ b/src/Turing.jl @@ -100,8 +100,8 @@ export @model, # modelling vi, # variational inference ADVI, sample, # inference - @logprob_str, - @prob_str, + @logprob_str, # TODO: Remove, see https://github.com/TuringLang/DynamicPPL.jl/issues/356 + @prob_str, # TODO: Remove, see https://github.com/TuringLang/DynamicPPL.jl/issues/356 externalsampler, AutoForwardDiff, # ADTypes AutoReverseDiff, diff --git a/src/mcmc/Inference.jl b/src/mcmc/Inference.jl index fb9d5d4ef..c564602eb 100644 --- a/src/mcmc/Inference.jl +++ b/src/mcmc/Inference.jl @@ -197,7 +197,11 @@ function DynamicPPL.unflatten(vi::SimpleVarInfo, θ::NamedTuple) return SimpleVarInfo(θ, vi.logp, vi.transformation) end -# Algorithm for sampling from the prior +""" + Prior() + +Algorithm for sampling from the prior. +""" struct Prior <: InferenceAlgorithm end function AbstractMCMC.step( diff --git a/src/mcmc/emcee.jl b/src/mcmc/emcee.jl index 4ebe49ea5..ebdfa041d 100644 --- a/src/mcmc/emcee.jl +++ b/src/mcmc/emcee.jl @@ -2,6 +2,17 @@ ### Sampler states ### +""" + Emcee(n_walkers::Int, stretch_length=2.0) + +Affine-invariant ensemble sampling algorithm. + +# Reference + +Foreman-Mackey, D., Hogg, D. W., Lang, D., & Goodman, J. (2013). +emcee: The MCMC Hammer. Publications of the Astronomical Society of the +Pacific, 125 (925), 306. https://doi.org/10.1086/670067 +""" struct Emcee{space,E<:AMH.Ensemble} <: InferenceAlgorithm ensemble::E end diff --git a/src/mcmc/particle_mcmc.jl b/src/mcmc/particle_mcmc.jl index 02a53766e..579ebfae2 100644 --- a/src/mcmc/particle_mcmc.jl +++ b/src/mcmc/particle_mcmc.jl @@ -220,6 +220,11 @@ function PG(nparticles::Int, space::Tuple) return PG(nparticles, AdvancedPS.ResampleWithESSThreshold(), space) end +""" + CSMC(...) + +Equivalent to [`PG`](@ref). +""" const CSMC = PG # type alias of PG as Conditional SMC struct PGTransition{T,F<:AbstractFloat} <: AbstractTransition diff --git a/src/optimisation/Optimisation.jl b/src/optimisation/Optimisation.jl index eecfcad22..414561bde 100644 --- a/src/optimisation/Optimisation.jl +++ b/src/optimisation/Optimisation.jl @@ -25,10 +25,22 @@ export MAP, MLE ModeEstimator An abstract type to mark whether mode estimation is to be done with maximum a posteriori -(MAP) or maximum likelihood estimation (MLE). +(MAP) or maximum likelihood estimation (MLE). This is only needed for the Optim.jl interface. """ abstract type ModeEstimator end + +""" + MLE <: ModeEstimator + +Concrete type for maximum likelihood estimation. Only used for the Optim.jl interface. +""" struct MLE <: ModeEstimator end + +""" + MAP <: ModeEstimator + +Concrete type for maximum a posteriori estimation. Only used for the Optim.jl interface. +""" struct MAP <: ModeEstimator end """ diff --git a/src/stdlib/distributions.jl b/src/stdlib/distributions.jl index c2b92c29d..568ab3ae3 100644 --- a/src/stdlib/distributions.jl +++ b/src/stdlib/distributions.jl @@ -207,12 +207,12 @@ end The *Poisson distribution* with logarithmic parameterization of the rate parameter describes the number of independent events occurring within a unit time interval, given the -average rate of occurrence ``exp(logλ)``. +average rate of occurrence ``\\exp(\\log\\lambda)``. The distribution has the probability mass function ```math -P(X = k) = \\frac{e^{k \\cdot logλ}{k!} e^{-e^{logλ}}, \\quad \\text{ for } k = 0,1,2,\\ldots. +P(X = k) = \\frac{e^{k \\cdot \\log\\lambda}}{k!} e^{-e^{\\log\\lambda}}, \\quad \\text{ for } k = 0,1,2,\\ldots. ``` See also: [`Poisson`](@ref) From faaae41acff72fb69da761d0cbcd0d8ff5e9063c Mon Sep 17 00:00:00 2001 From: Penelope Yong Date: Fri, 27 Sep 2024 12:08:37 +0100 Subject: [PATCH 03/10] Format --- docs/make.jl | 6 ++--- docs/src/api.md | 66 ++++++++++++++++++++++++------------------------- 2 files changed, 35 insertions(+), 37 deletions(-) diff --git a/docs/make.jl b/docs/make.jl index ebde41521..ba1b6990e 100644 --- a/docs/make.jl +++ b/docs/make.jl @@ -22,10 +22,8 @@ makedocs(; pages=[ "Home" => "index.md", "API" => "api.md", - "Submodule APIs" => [ - "Inference" => "api/Inference.md", - "Optimisation" => "api/Optimisation.md", - ] + "Submodule APIs" => + ["Inference" => "api/Inference.md", "Optimisation" => "api/Optimisation.md"], ], checkdocs=:exports, # checkdocs_ignored_modules=[Turing, Distributions, DynamicPPL, AbstractPPL, Bijectors], diff --git a/docs/src/api.md b/docs/src/api.md index cedc35bb6..7be87f6f9 100644 --- a/docs/src/api.md +++ b/docs/src/api.md @@ -1,13 +1,14 @@ # API + ## Module-wide re-exports Turing.jl directly re-exports the entire public API of the following packages: - - [Distributions.jl](https://juliastats.org/Distributions.jl) - - [MCMCChains.jl](https://turinglang.org/MCMCChains.jl) - - [AbstractMCMC.jl](https://turinglang.org/AbstractMCMC.jl) - - [Bijectors.jl](https://turinglang.org/Bijectors.jl) - - [Libtask.jl](https://github.com/TuringLang/Libtask.jl) + - [Distributions.jl](https://juliastats.org/Distributions.jl) + - [MCMCChains.jl](https://turinglang.org/MCMCChains.jl) + - [AbstractMCMC.jl](https://turinglang.org/AbstractMCMC.jl) + - [Bijectors.jl](https://turinglang.org/Bijectors.jl) + - [Libtask.jl](https://github.com/TuringLang/Libtask.jl) Please see the individual packages for their documentation. @@ -19,7 +20,7 @@ That means, for example, you can just write ```julia using Turing -@model function my_model(...) +@model function my_model() end sample(my_model(), Prior(), 100) ``` @@ -35,7 +36,7 @@ even though [`Prior()`](@ref) is actually defined in the `Turing.Inference` modu ### Modelling | Exported symbol | Documentation | Description | -| --- | --- | --- | +|:--------------- |:--------------------------------- |:-------------------------------------------- | | `@model` | [`DynamicPPL.@model`](@extref) | Define a probabilistic model | | `@varname` | [`AbstractPPL.@varname`](@extref) | Generate a `VarName` from a Julia expression | | `@submodel` | [`DynamicPPL.@submodel`](@extref) | Define a submodel | @@ -43,30 +44,30 @@ even though [`Prior()`](@ref) is actually defined in the `Turing.Inference` modu ### Inference | Exported symbol | Documentation | Description | -| --- | --- | --- | +|:--------------- |:------------------------------------------------------------------------------------------------ |:------------------- | | `sample` | [`StatsBase.sample`](https://turinglang.org/AbstractMCMC.jl/stable/api/#Sampling-a-single-chain) | Sample from a model | ### Samplers -| Exported symbol | Documentation | Description | -| --- | --- | --- | -| `Prior` | [`Turing.Inference.Prior`](@ref) | Sample from the prior distribution | -| `MH` | [`Turing.Inference.MH`](@ref) | Metropolis–Hastings | -| `Emcee` | [`Turing.Inference.Emcee`](@ref) | Affine-invariant ensemble sampler | -| `ESS` | [`Turing.Inference.ESS`](@ref) | Elliptical slice sampling | -| `Gibbs` | [`Turing.Inference.Gibbs`](@ref) | Gibbs sampling | -| `GibbsConditional` | [`Turing.Inference.GibbsConditional`](@ref) | A "pseudo-sampler" to provide analytical conditionals to `Gibbs` | -| `HMC` | [`Turing.Inference.HMC`](@ref) | Hamiltonian Monte Carlo | -| `SGLD` | [`Turing.Inference.SGLD`](@ref) | Stochastic gradient Langevin dynamics | -| `SGHMC` | [`Turing.Inference.SGHMC`](@ref) | Stochastic gradient Hamiltonian Monte Carlo | -| `HMCDA` | [`Turing.Inference.HMCDA`](@ref) | Hamiltonian Monte Carlo with dual averaging | -| `NUTS` | [`Turing.Inference.NUTS`](@ref) | No-U-Turn Sampler | -| `PolynomialStepsize` | [`Turing.Inference.PolynomialStepsize`](@ref) | A function to generate a polynomially decaying step size | -| `IS` | [`Turing.Inference.IS`](@ref) | Importance sampling | -| `SMC` | [`Turing.Inference.SMC`](@ref) | Sequential Monte Carlo | -| `PG` | [`Turing.Inference.PG`](@ref) | Particle Gibbs | -| `CSMC` | [`Turing.Inference.CSMC`](@ref) | The same as PG | -| `externalsampler` | [`Turing.Inference.externalsampler`](@ref) | Wrap an external sampler for use in Turing | +| Exported symbol | Documentation | Description | +|:-------------------- |:--------------------------------------------- |:------------------------------------------------------------------- | +| `Prior` | [`Turing.Inference.Prior`](@ref) | Sample from the prior distribution | +| `MH` | [`Turing.Inference.MH`](@ref) | Metropolis–Hastings | +| `Emcee` | [`Turing.Inference.Emcee`](@ref) | Affine-invariant ensemble sampler | +| `ESS` | [`Turing.Inference.ESS`](@ref) | Elliptical slice sampling | +| `Gibbs` | [`Turing.Inference.Gibbs`](@ref) | Gibbs sampling | +| `GibbsConditional` | [`Turing.Inference.GibbsConditional`](@ref) | A "pseudo-sampler" to provide analytical conditionals to `Gibbs` | +| `HMC` | [`Turing.Inference.HMC`](@ref) | Hamiltonian Monte Carlo | +| `SGLD` | [`Turing.Inference.SGLD`](@ref) | Stochastic gradient Langevin dynamics | +| `SGHMC` | [`Turing.Inference.SGHMC`](@ref) | Stochastic gradient Hamiltonian Monte Carlo | +| `PolynomialStepsize` | [`Turing.Inference.PolynomialStepsize`](@ref) | Returns a function which generates polynomially decaying step sizes | +| `HMCDA` | [`Turing.Inference.HMCDA`](@ref) | Hamiltonian Monte Carlo with dual averaging | +| `NUTS` | [`Turing.Inference.NUTS`](@ref) | No-U-Turn Sampler | +| `IS` | [`Turing.Inference.IS`](@ref) | Importance sampling | +| `SMC` | [`Turing.Inference.SMC`](@ref) | Sequential Monte Carlo | +| `PG` | [`Turing.Inference.PG`](@ref) | Particle Gibbs | +| `CSMC` | [`Turing.Inference.CSMC`](@ref) | The same as PG | +| `externalsampler` | [`Turing.Inference.externalsampler`](@ref) | Wrap an external sampler for use in Turing | ### Variational inference @@ -76,7 +77,7 @@ Please see the [variational inference tutorial](https://turinglang.org/docs/tuto TODO: Generate docs for AdvancedVI 0.2, update the InterLinks object.inv, and update the table below to include `@extref`. | Exported symbol | Documentation | Description | -| --- | --- | --- | +|:--------------- |:----------------- |:--------------------------------------- | | `vi` | `AdvancedVI.vi` | Perform variational inference | | `ADVI` | `AdvancedVI.ADVI` | Construct an instance of a VI algorithm | @@ -85,7 +86,7 @@ TODO: Generate docs for AdvancedVI 0.2, update the InterLinks object.inv, and up These are used to specify the automatic differentiation backend to use. | Exported symbol | Documentation | Description | -| --- | --- | --- | +|:----------------- |:------------------------------------ |:----------------------------------------- | | `AutoForwardDiff` | [`ADTypes.AutoForwardDiff`](@extref) | ForwardDiff.jl backend | | `AutoReverseDiff` | [`ADTypes.AutoReverseDiff`](@extref) | ReverseDiff.jl backend | | `AutoZygote` | [`ADTypes.AutoZygote`](@extref) | Zygote.jl backend | @@ -122,7 +123,7 @@ Distributions.BernoulliLogit TODO: DistributionsAD needs docs | Exported symbol | Documentation | Description | -| --- | --- | --- | +|:--------------- |:--------------------------------- |:-------------------------------------------------------------- | | `filldist` | `DistributionsAD.filldist` | Create a product distribution from a distribution and integers | | `arraydist` | `DistributionsAD.arraydist` | Create a product distribution from an array of distributions | | `NamedDist` | [`DynamicPPL.NamedDist`](@extref) | A distribution that carries the name of the variable | @@ -136,7 +137,7 @@ predict ### Re-exports from DynamicPPL / AbstractPPL | Exported symbol | Documentation | Description | -| --- | --- | --- | +|:-------------------------- |:--------------------------------------------------------------------------------------------------------------------------------- |:--------------------------------------------------------------- | | `pointwise_loglikelihoods` | [`DynamicPPL.pointwise_loglikelihoods`](@extref) | Compute log likelihoods for each sample in a chain | | `generated_quantities` | [`DynamicPPL.generated_quantities`](@extref) | Calculate additional quantities defined in a model | | `logprior` | [`DynamicPPL.logprior`](@extref) | Compute log prior probability | @@ -160,9 +161,8 @@ Bijectors.ordered ### Point estimates | Exported symbol | Documentation | Description | -| --- | --- | --- | +|:---------------------- |:-------------------------------------------------- |:-------------------------------------------- | | `maximum_a_posteriori` | [`Turing.Optimisation.maximum_a_posteriori`](@ref) | Find a MAP estimate for a model | | `maximum_likelihood` | [`Turing.Optimisation.maximum_likelihood`](@ref) | Find a MLE estimate for a model | | `MAP` | [`Turing.Optimisation.MAP`](@ref) | Type to use with Optim.jl for MAP estimation | | `MLE` | [`Turing.Optimisation.MLE`](@ref) | Type to use with Optim.jl for MLE estimation | - From 8fa7017092fe18795af46adcbc019a0bfa4aa378 Mon Sep 17 00:00:00 2001 From: Penelope Yong Date: Fri, 4 Oct 2024 21:05:44 +0100 Subject: [PATCH 04/10] Add link to AdvancedVI@0.2.8 docs --- docs/make.jl | 1 + docs/src/api.md | 11 ++++------- 2 files changed, 5 insertions(+), 7 deletions(-) diff --git a/docs/make.jl b/docs/make.jl index ba1b6990e..36998ebce 100644 --- a/docs/make.jl +++ b/docs/make.jl @@ -11,6 +11,7 @@ links = InterLinks( "DynamicPPL" => "https://turinglang.org/DynamicPPL.jl/stable/objects.inv", "AbstractPPL" => "https://turinglang.org/AbstractPPL.jl/dev/objects.inv", "ADTypes" => "https://sciml.github.io/ADTypes.jl/stable/objects.inv", + "AdvancedVI" => "https://turinglang.org/AdvancedVI.jl/v0.2.8/objects.inv", ) # Doctest setup diff --git a/docs/src/api.md b/docs/src/api.md index 7be87f6f9..aa39a315e 100644 --- a/docs/src/api.md +++ b/docs/src/api.md @@ -71,15 +71,12 @@ even though [`Prior()`](@ref) is actually defined in the `Turing.Inference` modu ### Variational inference -These functions are not (yet) formally documented. Please see the [variational inference tutorial](https://turinglang.org/docs/tutorials/09-variational-inference/) for a walkthrough on how to use these. -TODO: Generate docs for AdvancedVI 0.2, update the InterLinks object.inv, and update the table below to include `@extref`. - -| Exported symbol | Documentation | Description | -|:--------------- |:----------------- |:--------------------------------------- | -| `vi` | `AdvancedVI.vi` | Perform variational inference | -| `ADVI` | `AdvancedVI.ADVI` | Construct an instance of a VI algorithm | +| Exported symbol | Documentation | Description | +| :--------------- | :----------------- | :--------------------------------------- | +| `vi` | [`AdvancedVI.vi`](@extref) | Perform variational inference | +| `ADVI` | [`AdvancedVI.ADVI`](@extref) | Construct an instance of a VI algorithm | ### Automatic differentiation types From 6f17a1d759ae454ca53f4a3f75b36f4f99b5d66d Mon Sep 17 00:00:00 2001 From: Penelope Yong Date: Fri, 4 Oct 2024 21:11:02 +0100 Subject: [PATCH 05/10] Format Markdown table right Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> --- docs/src/api.md | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/docs/src/api.md b/docs/src/api.md index aa39a315e..72092baa1 100644 --- a/docs/src/api.md +++ b/docs/src/api.md @@ -73,10 +73,10 @@ even though [`Prior()`](@ref) is actually defined in the `Turing.Inference` modu Please see the [variational inference tutorial](https://turinglang.org/docs/tutorials/09-variational-inference/) for a walkthrough on how to use these. -| Exported symbol | Documentation | Description | -| :--------------- | :----------------- | :--------------------------------------- | -| `vi` | [`AdvancedVI.vi`](@extref) | Perform variational inference | -| `ADVI` | [`AdvancedVI.ADVI`](@extref) | Construct an instance of a VI algorithm | +| Exported symbol | Documentation | Description | +|:--------------- |:---------------------------- |:--------------------------------------- | +| `vi` | [`AdvancedVI.vi`](@extref) | Perform variational inference | +| `ADVI` | [`AdvancedVI.ADVI`](@extref) | Construct an instance of a VI algorithm | ### Automatic differentiation types From db9111170edc24dd96dfea0770c135479e09dea0 Mon Sep 17 00:00:00 2001 From: Penelope Yong Date: Mon, 7 Oct 2024 00:29:20 +0100 Subject: [PATCH 06/10] Correct MH docstrings --- src/mcmc/mh.jl | 59 +++++++++++--------------------------------------- 1 file changed, 13 insertions(+), 46 deletions(-) diff --git a/src/mcmc/mh.jl b/src/mcmc/mh.jl index ffc064eb1..945e7f41c 100644 --- a/src/mcmc/mh.jl +++ b/src/mcmc/mh.jl @@ -27,7 +27,7 @@ The arguments `space` can be # Examples -The default `MH` will use propose samples from the prior distribution using `AdvancedMH.StaticProposal`. +The default `MH` will draw proposal samples from the prior distribution using `AdvancedMH.StaticProposal`. ```julia @model function gdemo(x, y) @@ -45,34 +45,21 @@ Alternatively, you can specify particular parameters to sample if you want to co from multiple samplers: ```julia -@model function gdemo(x, y) - s² ~ InverseGamma(2,3) - m ~ Normal(0, sqrt(s²)) - x ~ Normal(m, sqrt(s²)) - y ~ Normal(m, sqrt(s²)) -end - -# Samples s with MH and m with PG -chain = sample(gdemo(1.5, 2.0), Gibbs(MH(:s), PG(10, :m)), 1_000) +# Samples s² with MH and m with PG +chain = sample(gdemo(1.5, 2.0), Gibbs(MH(:s²), PG(10, :m)), 1_000) mean(chain) ``` -Using custom distributions defaults to using static MH: +Specifying a single distribution implies the use of static MH: ```julia -@model function gdemo(x, y) - s² ~ InverseGamma(2,3) - m ~ Normal(0, sqrt(s²)) - x ~ Normal(m, sqrt(s²)) - y ~ Normal(m, sqrt(s²)) -end - -# Use a static proposal for s and random walk with proposal -# standard deviation of 0.25 for m. +# Use a static proposal for s² (which happens to be the same +# as the prior) and a static proposal for m (note that this +# isn't a random walk proposal). chain = sample( gdemo(1.5, 2.0), MH( - :s => InverseGamma(2, 3), + :s² => InverseGamma(2, 3), :m => Normal(0, 1) ), 1_000 @@ -83,19 +70,12 @@ mean(chain) Specifying explicit proposals using the `AdvancedMH` interface: ```julia -@model function gdemo(x, y) - s² ~ InverseGamma(2,3) - m ~ Normal(0, sqrt(s²)) - x ~ Normal(m, sqrt(s²)) - y ~ Normal(m, sqrt(s²)) -end - -# Use a static proposal for s and random walk with proposal +# Use a static proposal for s² and random walk with proposal # standard deviation of 0.25 for m. chain = sample( gdemo(1.5, 2.0), MH( - :s => AdvancedMH.StaticProposal(InverseGamma(2,3)), + :s² => AdvancedMH.StaticProposal(InverseGamma(2,3)), :m => AdvancedMH.RandomWalkProposal(Normal(0, 0.25)) ), 1_000 @@ -106,19 +86,12 @@ mean(chain) Using a custom function to specify a conditional distribution: ```julia -@model function gdemo(x, y) - s² ~ InverseGamma(2,3) - m ~ Normal(0, sqrt(s²)) - x ~ Normal(m, sqrt(s²)) - y ~ Normal(m, sqrt(s²)) -end - # Use a static proposal for s and and a conditional proposal for m, # where the proposal is centered around the current sample. chain = sample( gdemo(1.5, 2.0), MH( - :s => InverseGamma(2, 3), + :s² => InverseGamma(2, 3), :m => x -> Normal(x, 1) ), 1_000 @@ -128,16 +101,10 @@ mean(chain) Providing a covariance matrix will cause `MH` to perform random-walk sampling in the transformed space with proposals drawn from a multivariate -normal distribution. The provided matrix must be positive semi-definite and square. Usage: +normal distribution. The provided matrix must be positive semi-definite and +square: ```julia -@model function gdemo(x, y) - s² ~ InverseGamma(2,3) - m ~ Normal(0, sqrt(s²)) - x ~ Normal(m, sqrt(s²)) - y ~ Normal(m, sqrt(s²)) -end - # Providing a custom variance-covariance matrix chain = sample( gdemo(1.5, 2.0), From 64905490460162a842f0f9dcb52186e8b0f9daed Mon Sep 17 00:00:00 2001 From: Penelope Yong Date: Mon, 7 Oct 2024 00:39:19 +0100 Subject: [PATCH 07/10] Add more links to the main docs --- docs/src/api.md | 11 ++++++++--- 1 file changed, 8 insertions(+), 3 deletions(-) diff --git a/docs/src/api.md b/docs/src/api.md index 72092baa1..55c519969 100644 --- a/docs/src/api.md +++ b/docs/src/api.md @@ -71,7 +71,7 @@ even though [`Prior()`](@ref) is actually defined in the `Turing.Inference` modu ### Variational inference -Please see the [variational inference tutorial](https://turinglang.org/docs/tutorials/09-variational-inference/) for a walkthrough on how to use these. +See the [variational inference tutorial](https://turinglang.org/docs/tutorials/09-variational-inference/) for a walkthrough on how to use these. | Exported symbol | Documentation | Description | |:--------------- |:---------------------------- |:--------------------------------------- | @@ -81,6 +81,7 @@ Please see the [variational inference tutorial](https://turinglang.org/docs/tuto ### Automatic differentiation types These are used to specify the automatic differentiation backend to use. +See the [AD guide](https://turinglang.org/docs/tutorials/docs-10-using-turing-autodiff/) for more information. | Exported symbol | Documentation | Description | |:----------------- |:------------------------------------ |:----------------------------------------- | @@ -131,12 +132,14 @@ TODO: DistributionsAD needs docs predict ``` -### Re-exports from DynamicPPL / AbstractPPL +### Querying model probabilities and quantities + +Please see the [generated quantities](https://turinglang.org/docs/tutorials/usage-generated-quantities/) and [probability interface](https://turinglang.org/docs/tutorials/usage-probability-interface/) guides for more information. | Exported symbol | Documentation | Description | |:-------------------------- |:--------------------------------------------------------------------------------------------------------------------------------- |:--------------------------------------------------------------- | -| `pointwise_loglikelihoods` | [`DynamicPPL.pointwise_loglikelihoods`](@extref) | Compute log likelihoods for each sample in a chain | | `generated_quantities` | [`DynamicPPL.generated_quantities`](@extref) | Calculate additional quantities defined in a model | +| `pointwise_loglikelihoods` | [`DynamicPPL.pointwise_loglikelihoods`](@extref) | Compute log likelihoods for each sample in a chain | | `logprior` | [`DynamicPPL.logprior`](@extref) | Compute log prior probability | | `logjoint` | [`DynamicPPL.logjoint`](@extref) | Compute log joint probability | | `LogDensityFunction` | [`DynamicPPL.LogDensityFunction`](@extref) | Wrap a Turing model to satisfy LogDensityFunctions.jl interface | @@ -157,6 +160,8 @@ Bijectors.ordered ### Point estimates +See the [mode estimation tutorial](https://turinglang.org/docs/tutorials/docs-17-mode-estimation/) for more information. + | Exported symbol | Documentation | Description | |:---------------------- |:-------------------------------------------------- |:-------------------------------------------- | | `maximum_a_posteriori` | [`Turing.Optimisation.maximum_a_posteriori`](@ref) | Find a MAP estimate for a model | From 8f1585d84e2747075428a186e6d60f746df44eba Mon Sep 17 00:00:00 2001 From: Penelope Yong Date: Mon, 7 Oct 2024 00:47:10 +0100 Subject: [PATCH 08/10] Fix introductory example --- docs/src/api.md | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/docs/src/api.md b/docs/src/api.md index 55c519969..a5e062cf8 100644 --- a/docs/src/api.md +++ b/docs/src/api.md @@ -28,10 +28,12 @@ sample(my_model(), Prior(), 100) instead of ```julia -sample(model, Turing.Inference.Prior(), 100) +DynamicPPL.@model function my_model() end + +sample(my_model(), Turing.Inference.Prior(), 100) ``` -even though [`Prior()`](@ref) is actually defined in the `Turing.Inference` module. +even though [`Prior()`](@ref) is actually defined in the `Turing.Inference` module and [`@model`](@ref) in the `DynamicPPL` package. ### Modelling From 263adc96704d80c3f454f36b18ede51ae1be8cee Mon Sep 17 00:00:00 2001 From: Penelope Yong Date: Tue, 8 Oct 2024 16:21:29 +0100 Subject: [PATCH 09/10] Add links to DistributionsAD docs --- docs/make.jl | 1 + docs/src/api.md | 12 +++++------- 2 files changed, 6 insertions(+), 7 deletions(-) diff --git a/docs/make.jl b/docs/make.jl index 36998ebce..cc50045a0 100644 --- a/docs/make.jl +++ b/docs/make.jl @@ -12,6 +12,7 @@ links = InterLinks( "AbstractPPL" => "https://turinglang.org/AbstractPPL.jl/dev/objects.inv", "ADTypes" => "https://sciml.github.io/ADTypes.jl/stable/objects.inv", "AdvancedVI" => "https://turinglang.org/AdvancedVI.jl/v0.2.8/objects.inv", + "DistributionsAD" => "https://turinglang.org/DistributionsAD.jl/stable/objects.inv", ) # Doctest setup diff --git a/docs/src/api.md b/docs/src/api.md index a5e062cf8..e2b193c01 100644 --- a/docs/src/api.md +++ b/docs/src/api.md @@ -120,13 +120,11 @@ Distributions.BernoulliLogit ### Tools to work with distributions -TODO: DistributionsAD needs docs - -| Exported symbol | Documentation | Description | -|:--------------- |:--------------------------------- |:-------------------------------------------------------------- | -| `filldist` | `DistributionsAD.filldist` | Create a product distribution from a distribution and integers | -| `arraydist` | `DistributionsAD.arraydist` | Create a product distribution from an array of distributions | -| `NamedDist` | [`DynamicPPL.NamedDist`](@extref) | A distribution that carries the name of the variable | +| Exported symbol | Documentation | Description | +|:--------------- |:-------------------------------------- |:-------------------------------------------------------------- | +| `filldist` | [`DistributionsAD.filldist`](@extref) | Create a product distribution from a distribution and integers | +| `arraydist` | [`DistributionsAD.arraydist`](@extref) | Create a product distribution from an array of distributions | +| `NamedDist` | [`DynamicPPL.NamedDist`](@extref) | A distribution that carries the name of the variable | ### Predictions From 446f278eeffa5cd478de38f27c8afa904424fa86 Mon Sep 17 00:00:00 2001 From: Penelope Yong Date: Wed, 9 Oct 2024 10:36:35 +0100 Subject: [PATCH 10/10] Bump actions/checkout version Co-authored-by: Xianda Sun <5433119+sunxd3@users.noreply.github.com> --- .github/workflows/Docs.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/Docs.yml b/.github/workflows/Docs.yml index 0bd4a71f7..441b4b56e 100644 --- a/.github/workflows/Docs.yml +++ b/.github/workflows/Docs.yml @@ -24,7 +24,7 @@ jobs: docs: runs-on: ubuntu-latest steps: - - uses: actions/checkout@v2 + - uses: actions/checkout@v4 - uses: julia-actions/setup-julia@latest with: version: '1'