Skip to content

Commit 022c7be

Browse files
committed
Merge remote-tracking branch 'upstream/master'
2 parents 17309e4 + bf8f0bc commit 022c7be

Some content is hidden

Large Commits have some content hidden by default. Use the searchbox below for content that may be hidden.

50 files changed

+6988
-3794
lines changed

.github/FUNDING.yml

Lines changed: 0 additions & 12 deletions
This file was deleted.

.gitignore

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -41,3 +41,4 @@ benchmarks/results/
4141
pytestdebug.log
4242
.dir-locals.el
4343
.pycheckers
44+

.travis.yml

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -48,8 +48,8 @@ jobs:
4848
stage: test
4949
install:
5050
- . ./scripts/create_testenv.sh
51-
- pip uninstall arviz -y
52-
# replace ArviZ with the lastest master
51+
- conda activate testenv
52+
# replace ArviZ with the latest master
5353
- pip install git+git://github.com/arviz-devs/arviz.git
5454
- pip install codecov
5555
- conda list && pip freeze

README.rst

Lines changed: 20 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -158,6 +158,8 @@ Software using PyMC3
158158
- `sampled <https://github.com/ColCarroll/sampled>`__: Decorator for PyMC3 models.
159159
- `NiPyMC <https://github.com/PsychoinformaticsLab/nipymc>`__: Bayesian mixed-effects modeling of fMRI data in Python.
160160
- `beat <https://github.com/hvasbath/beat>`__: Bayesian Earthquake Analysis Tool.
161+
- `pymc-learn <https://github.com/pymc-learn/pymc-learn>`__: Custom PyMC models built on top of pymc3_models/scikit-learn API
162+
- `fenics-pymc3 <https://github.com/IvanYashchuk/fenics-pymc3>`__: Differentiable interface to FEniCS, a library for solving partial differential equations.
161163

162164
Please contact us if your software is not listed here.
163165

@@ -177,6 +179,18 @@ Support
177179

178180
PyMC3 is a non-profit project under NumFOCUS umbrella. If you want to support PyMC3 financially, you can donate `here <https://numfocus.salsalabs.org/donate-to-pymc3/index.html>`__.
179181

182+
PyMC for enterprise
183+
===================
184+
`PyMC is now available as part of the Tidelift Subscription!`
185+
186+
Tidelift is working with PyMC and the maintainers of thousands of other open source
187+
projects to deliver commercial support and maintenance for the open source dependencies
188+
you use to build your applications. Save time, reduce risk, and improve code health,
189+
while contributing financially to PyMC -- making it even more robust, reliable and,
190+
let's face it, amazing!
191+
192+
|tidelift_learn| |tidelift_demo|
193+
180194
Sponsors
181195
========
182196

@@ -202,3 +216,9 @@ Sponsors
202216
:target: http://www.numfocus.org/
203217
.. |ODSC| image:: https://raw.githubusercontent.com/pymc-devs/pymc3/master/docs/odsc_logo.png
204218
:target: https://odsc.com
219+
.. |tidelift| image:: https://img.shields.io/badge/-lifted!-2dd160.svg?colorA=58595b&style=flat&logo=%2FwCjUTnDygkGoVERFQaZFlE9nreO%2BdM5u5wkifvuee892Pu3CyEcA0DeIc%2B9IwftJsR6Cko3uCjguZdjuBZhhwmYDjGrOC96WED41UtsgEdGEAPlmAfpuAbFF%2BFZLfoMfRBGzThDtLgePPwBIpdddGzOArhPHUXowbNptE2www6a%2Fm96Y3pHN7oQ1s%2B13pxt1ENaKzBFWyWzaJ%2BRO0C9Jny6VPSoKjLVbMDC5bn5OPuJF%2BBSe95PVEMuugY5AegS9fCh7BedP45hRnj8TC34QQUe9bTZyh2KgvFk2vc8GIlXyTfsvqr6bPpNgv52ynnlomZJNpB70Xhl%2Bf6Sa02p1bApEfnETwxVa%2Faj%2BW%2FFtHltmxS%2FO3krvpTtTnVgu%2F6gvHRFvG78Ef3kOe5PimJXycY74blT5R%2BAAAAAElFTkSuQmCC
220+
:target: https://tidelift.com/subscription/pkg/pypi-pymc3?utm_source=pypi-pymc3&utm_medium=referral&utm_campaign=enterprise
221+
.. |tidelift_learn| image:: https://img.shields.io/badge/-learn%20more-2dd160.svg?color=orange&labelColor=58595b&style=flat&logo=%2FwCjUTnDygkGoVERFQaZFlE9nreO%2BdM5u5wkifvuee892Pu3CyEcA0DeIc%2B9IwftJsR6Cko3uCjguZdjuBZhhwmYDjGrOC96WED41UtsgEdGEAPlmAfpuAbFF%2BFZLfoMfRBGzThDtLgePPwBIpdddGzOArhPHUXowbNptE2www6a%2Fm96Y3pHN7oQ1s%2B13pxt1ENaKzBFWyWzaJ%2BRO0C9Jny6VPSoKjLVbMDC5bn5OPuJF%2BBSe95PVEMuugY5AegS9fCh7BedP45hRnj8TC34QQUe9bTZyh2KgvFk2vc8GIlXyTfsvqr6bPpNgv52ynnlomZJNpB70Xhl%2Bf6Sa02p1bApEfnETwxVa%2Faj%2BW%2FFtHltmxS%2FO3krvpTtTnVgu%2F6gvHRFvG78Ef3kOe5PimJXycY74blT5R%2BAAAAAElFTkSuQmCC
222+
:target: https://tidelift.com/subscription/pkg/pypi-pymc3?utm_source=pypi-pymc3&utm_medium=referral&utm_campaign=enterprise
223+
.. |tidelift_demo| image:: https://img.shields.io/badge/-request%20a%20demo-2dd160.svg?color=orange&labelColor=58595b&style=flat&logo=%2FwCjUTnDygkGoVERFQaZFlE9nreO%2BdM5u5wkifvuee892Pu3CyEcA0DeIc%2B9IwftJsR6Cko3uCjguZdjuBZhhwmYDjGrOC96WED41UtsgEdGEAPlmAfpuAbFF%2BFZLfoMfRBGzThDtLgePPwBIpdddGzOArhPHUXowbNptE2www6a%2Fm96Y3pHN7oQ1s%2B13pxt1ENaKzBFWyWzaJ%2BRO0C9Jny6VPSoKjLVbMDC5bn5OPuJF%2BBSe95PVEMuugY5AegS9fCh7BedP45hRnj8TC34QQUe9bTZyh2KgvFk2vc8GIlXyTfsvqr6bPpNgv52ynnlomZJNpB70Xhl%2Bf6Sa02p1bApEfnETwxVa%2Faj%2BW%2FFtHltmxS%2FO3krvpTtTnVgu%2F6gvHRFvG78Ef3kOe5PimJXycY74blT5R%2BAAAAAElFTkSuQmCC
224+
:target: https://tidelift.com/subscription/request-a-demo?utm_source=pypi-pymc3&utm_medium=referral&utm_campaign=enterprise

RELEASE-NOTES.md

Lines changed: 23 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -2,24 +2,43 @@
22

33
## PyMC3 3.9.x (on deck)
44

5+
### Maintenance
6+
- Mentioned the way to do any random walk with `theano.tensor.cumsum()` in `GaussianRandomWalk` docstrings (see [#4048](https://github.com/pymc-devs/pymc3/pull/4048)).
7+
- Fixed numerical instability in ExGaussian's logp by preventing `logpow` from returning `-inf` (see [#4050](https://github.com/pymc-devs/pymc3/pull/4050)).
8+
- Use dill to serialize user defined logp functions in `DensityDist`. The previous serialization code fails if it is used in notebooks on Windows and Mac. `dill` is now a required dependency. (see [#3844](https://github.com/pymc-devs/pymc3/issues/3844)).
9+
10+
### Documentation
11+
12+
### New features
13+
- `sample_posterior_predictive_w` can now feed on `xarray.Dataset` - e.g. from `InferenceData.posterior`. (see [#4042](https://github.com/pymc-devs/pymc3/pull/4042))
14+
15+
16+
## PyMC3 3.9.3 (11 August 2020)
17+
518
### Maintenance
619
- Fix an error on Windows and Mac where error message from unpickling models did not show up in the notebook, or where sampling froze when a worker process crashed (see [#3991](https://github.com/pymc-devs/pymc3/pull/3991)).
20+
- Require Theano >= 1.0.5 (see [#4032](https://github.com/pymc-devs/pymc3/pull/4032)).
721

822
### Documentation
9-
- Notebook on [multilevel modeling](https://docs.pymc.io/notebooks/multilevel_modeling.html) has been rewritten to showcase ArviZ and xarray usage for inference result analysis (see [#3963](https://github.com/pymc-devs/pymc3/pull/3963))
23+
- Notebook on [multilevel modeling](https://docs.pymc.io/notebooks/multilevel_modeling.html) has been rewritten to showcase ArviZ and xarray usage for inference result analysis (see [#3963](https://github.com/pymc-devs/pymc3/pull/3963)).
1024

1125
### New features
12-
- Introduce optional arguments to `pm.sample`: `mp_ctx` to control how the processes for parallel sampling are started, and `pickle_backend` to specify which library is used to pickle models in parallel sampling when the multiprocessing cnotext is not of type `fork`. (see [#3991](https://github.com/pymc-devs/pymc3/pull/3991))
26+
- Introduce optional arguments to `pm.sample`: `mp_ctx` to control how the processes for parallel sampling are started, and `pickle_backend` to specify which library is used to pickle models in parallel sampling when the multiprocessing context is not of type `fork` (see [#3991](https://github.com/pymc-devs/pymc3/pull/3991)).
1327
- Add sampler stats `process_time_diff`, `perf_counter_diff` and `perf_counter_start`, that record wall and CPU times for each NUTS and HMC sample (see [ #3986](https://github.com/pymc-devs/pymc3/pull/3986)).
14-
- Extend `keep_size` argument handling for `sample_posterior_predictive` and `fast_sample_posterior_predictive`, to work on arviz InferenceData and xarray Dataset input values. (see [PR #4006](https://github.com/pymc-devs/pymc3/pull/4006) and [Issue #4004](https://github.com/pymc-devs/pymc3/issues/4004).
15-
- SMC-ABC: add the wasserstein and energy distance functions. Refactor API, the distance, sum_stats and epsilon arguments are now passed `pm.Simulator` instead of `pm.sample_smc`. Add random method to `pm.Simulator`. Add option to save the simulated data. Improves LaTeX representation [#3996](https://github.com/pymc-devs/pymc3/pull/3996)
28+
- Extend `keep_size` argument handling for `sample_posterior_predictive` and `fast_sample_posterior_predictive`, to work on ArviZ `InferenceData` and xarray `Dataset` input values (see [PR #4006](https://github.com/pymc-devs/pymc3/pull/4006) and issue [#4004](https://github.com/pymc-devs/pymc3/issues/4004)).
29+
- SMC-ABC: add the Wasserstein and energy distance functions. Refactor API, the distance, sum_stats and epsilon arguments are now passed `pm.Simulator` instead of `pm.sample_smc`. Add random method to `pm.Simulator`. Add option to save the simulated data. Improved LaTeX representation [#3996](https://github.com/pymc-devs/pymc3/pull/3996).
30+
- SMC-ABC: Allow use of potentials by adding them to the prior term. [#4016](https://github.com/pymc-devs/pymc3/pull/4016).
31+
32+
_NB: The `docs/*` folder is still removed from the tarball due to an upload size limit on PyPi._
33+
1634

1735
## PyMC3 3.9.2 (24 June 2020)
1836
### Maintenance
1937
- Warning added in GP module when `input_dim` is lower than the number of columns in `X` to compute the covariance function (see [#3974](https://github.com/pymc-devs/pymc3/pull/3974)).
2038
- Pass the `tune` argument from `sample` when using `advi+adapt_diag_grad` (see issue [#3965](https://github.com/pymc-devs/pymc3/issues/3965), fixed by [#3979](https://github.com/pymc-devs/pymc3/pull/3979)).
2139
- Add simple test case for new coords and dims feature in `pm.Model` (see [#3977](https://github.com/pymc-devs/pymc3/pull/3977)).
2240
- Require ArviZ >= 0.9.0 (see [#3977](https://github.com/pymc-devs/pymc3/pull/3977)).
41+
- Fixed issue [#3962](https://github.com/pymc-devs/pymc3/issues/3962) by making a change in the `_random()` method of `GaussianRandomWalk` class (see PR [#3985](https://github.com/pymc-devs/pymc3/pull/3985)). Further testing revealed a new issue which is being tracked by [#4010](https://github.com/pymc-devs/pymc3/issues/4010).
2342

2443
_NB: The `docs/*` folder is still removed from the tarball due to an upload size limit on PyPi._
2544

docs/release-notes/pymc3-3.0.md

Lines changed: 0 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1 +0,0 @@
1-

docs/source/history.rst renamed to docs/source/about.rst

Lines changed: 120 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -1,9 +1,10 @@
1-
.. _intro:
1+
.. _about:
22

3-
************
4-
Introduction
5-
************
3+
***********
4+
About PyMC3
5+
***********
66

7+
.. _intro:
78

89
Purpose
910
=======
@@ -86,14 +87,116 @@ Python 3 compatibility, improved summary plots, and some important bug fixes.
8687

8788
In 2011, John Salvatier began thinking about implementing gradient-based MCMC samplers, and developed the ``mcex`` package to experiment with his ideas. The following year, John was invited by the team to re-engineer PyMC to accomodate Hamiltonian Monte Carlo sampling. This led to the adoption of Theano as the computational back end, and marked the beginning of PyMC3's development. The first alpha version of PyMC3 was released in June 2015. Over the following 2 years, the core development team grew to 12 members, and the first release, PyMC3 3.0, was launched in January 2017.
8889

90+
.. _support:
91+
92+
************
93+
Support PyMC
94+
************
95+
96+
PyMC3 is a non-profit project under NumFOCUS umbrella. If you want to support PyMC3
97+
financially, consider donating to the project.
98+
99+
.. raw:: html
100+
101+
<style>.centered {text-align: center;}</style>
102+
<div class="centered"><a href="https://numfocus.org/donate-to-pymc3">
103+
<div class="ui huge primary button">Donate to PyMC3</div>
104+
</a></div>
105+
106+
Citing PyMC3
107+
============
108+
If you use PyMC3 in your reseach please cite: Salvatier J., Wiecki T.V., Fonnesbeck C. (2016) Probabilistic programming in Python using PyMC3. PeerJ Computer Science 2:e55 [DOI: 10.7717/peerj-cs.55](https://doi.org/10.7717/peerj-cs.55).
109+
110+
The BibTeX entry is:
111+
112+
.. code-block:: none
113+
114+
@article{pymc3,
115+
title={Probabilistic programming in Python using PyMC3},
116+
author={Salvatier, John and Wiecki, Thomas V and Fonnesbeck, Christopher},
117+
journal={PeerJ Computer Science},
118+
volume={2},
119+
pages={e55},
120+
year={2016},
121+
publisher={PeerJ Inc.}
122+
}
123+
124+
125+
PyMC for enterprise
126+
===================
127+
`PyMC is now available as part of the Tidelift Subscription!`
128+
129+
Tidelift is working with PyMC and the maintainers of thousands of other open source
130+
projects to deliver commercial support and maintenance for the open source dependencies
131+
you use to build your applications. Save time, reduce risk, and improve code health,
132+
while contributing financially to PyMC -- making it even more robust, reliable and,
133+
let's face it, amazing!
134+
135+
.. raw:: html
136+
137+
<style>.centered {text-align: center;}</style>
138+
<p><div class="centered">
139+
<a href="https://tidelift.com/subscription/pkg/pypi-pymc3?utm_source=undefined&utm_medium=referral&utm_campaign=enterprise">
140+
<button class="ui large orange button" color="orange">Learn more</button>
141+
</a>
142+
<a href="https://tidelift.com/subscription/request-a-demo?utm_source=undefined&utm_medium=referral&utm_campaign=enterprise">
143+
<button class="ui large orange button">Request a demo</button>
144+
</a>
145+
</div></p>
146+
147+
Enterprise-ready open source software — managed for you
148+
-------------------------------------------------------
89149

150+
The Tidelift Subscription is a managed open source subscription for application
151+
dependencies covering millions of open source projects across JavaScript, Python, Java,
152+
PHP, Ruby, .NET, and more. And now, your favorite probabilistic programming language is included in the Tidelift subscription!
153+
154+
Your subscription includes:
155+
156+
* **Security updates**: Tidelift’s security response team coordinates patches for new breaking security vulnerabilities and alerts immediately through a private channel, so your software supply chain is always secure.
157+
158+
* **Licensing verification and indemnification**: Tidelift verifies license information to enable easy policy enforcement and adds intellectual property indemnification to cover creators and users in case something goes wrong. You always have a 100% up-to-date bill of materials for your dependencies to share with your legal team, customers, or partners.
159+
160+
* **Maintenance and code improvement**: Tidelift ensures the software you rely on keeps working as long as you need it to work. Your managed dependencies are actively maintained and Tidelift recruits additional maintainers where required.
161+
162+
* **Package selection and version guidance**: Tidelift helps you choose the best open source packages from the start—and then guides you through updates to stay on the best releases as new issues arise.
163+
164+
* **Roadmap input**: Take a seat at the table with the creators behind the software you use. PyMC developers and other Tidelift’s participating maintainers earn more income as our software is used by more subscribers, so we’re interested in knowing what you need.
165+
166+
* **Tooling and cloud integration**: Tidelift works with GitHub, GitLab, BitBucket, and more. It supports every cloud platform (and other deployment targets, too).
167+
168+
The end result? All of the capabilities you expect from commercial-grade software, for the full breadth of open source you use. That means less time grappling with esoteric open source trivia, and more time building your own applications — and your business.
169+
170+
.. raw:: html
171+
172+
<style>.centered {text-align: center;}</style>
173+
<p><div class="centered">
174+
<a href="https://tidelift.com/subscription/pkg/pypi-pymc3?utm_source=undefined&utm_medium=referral&utm_campaign=enterprise">
175+
<button class="ui large orange button" color="orange">Learn more</button>
176+
</a>
177+
<a href="https://tidelift.com/subscription/request-a-demo?utm_source=undefined&utm_medium=referral&utm_campaign=enterprise">
178+
<button class="ui large orange button">Request a demo</button>
179+
</a>
180+
</div></p>
181+
182+
Sponsors
183+
========
184+
185+
|NumFOCUS| |Quantopian| |ODSC|
186+
187+
More details about sponsoring PyMC3 can be found `here <https://github.com/pymc-devs/pymc3/blob/master/GOVERNANCE.md#institutional-partners-and-funding>`_.
188+
If you are interested in becoming a sponsor, reach out to `[email protected] <[email protected]>`_
189+
190+
**************
90191
Usage Overview
91-
==============
192+
**************
92193

93194
For a detailed overview of building models in PyMC3, please read the appropriate sections in the rest of the documentation. For a flavor of what PyMC3 models look like, here is a quick example.
94195

95196
First, let's import PyMC3 and `ArviZ <https://arviz-devs.github.io/arviz/>`__ (which handles plotting and diagnostics):
96197

198+
::
199+
97200
import arviz as az
98201
import numpy as np
99202
import pymc3 as pm
@@ -146,9 +249,21 @@ This example will generate 1000 posterior samples on each of two cores using the
146249
The sample is returned as arrays inside a ``MultiTrace`` object, which is then passed to the plotting function. The resulting graph shows a forest plot of the random variables in the model, along with a convergence diagnostic (R-hat) that indicates our model has converged.
147250

148251
.. image:: ./images/forestplot.png
252+
:width: 1000px
149253

150254
See also
151255
========
152256

153257
* `Tutorials <nb_tutorials/index.html>`__
154258
* `Examples <nb_examples/index.html>`__
259+
260+
261+
.. |NumFOCUS| image:: https://numfocus.org/wp-content/uploads/2017/07/NumFocus_LRG.png
262+
:target: http://www.numfocus.org/
263+
:height: 120px
264+
.. |Quantopian| image:: https://raw.githubusercontent.com/pymc-devs/pymc3/master/docs/quantopianlogo.jpg
265+
:target: https://quantopian.com
266+
:height: 120px
267+
.. |ODSC| image:: https://raw.githubusercontent.com/pymc-devs/pymc3/master/docs/odsc_logo.png
268+
:target: https://odsc.com
269+
:height: 120px

docs/source/conf.py

Lines changed: 3 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -156,7 +156,7 @@
156156
("Books + Videos", "learn"),
157157
("API", "api"),
158158
("Developer Guide", "developer_guide"),
159-
("About PyMC3", "history")
159+
("About PyMC3", "about")
160160
],
161161
# "fixed_sidebar": "false",
162162
# "description": "Probabilistic Programming in Python: Bayesian Modeling and Probabilistic Machine Learning with Theano"
@@ -331,8 +331,8 @@
331331

332332

333333
def setup(app):
334-
app.add_stylesheet(
334+
app.add_css_file(
335335
"https://cdn.jsdelivr.net/npm/[email protected]/dist/semantic.min.css"
336336
)
337-
app.add_stylesheet("default.css")
337+
app.add_css_file("default.css")
338338

0 commit comments

Comments
 (0)