Releases: pymc-devs/pymc
PyMC3 v3.10.0 (7 December 2020)
This is a major release with many exciting new features. The biggest change is that we now rely on our own fork of Theano-PyMC. This is in line with our big announcement about our commitment to PyMC3 and Theano.
When upgrading, make sure that Theano-PyMC
and not Theano
are installed (the imports remain unchanged, however). If not, you can uninstall Theano
:
conda remove theano
And to install:
conda install -c conda-forge theano-pymc
Or, if you are using pip (not recommended):
pip uninstall theano
And to install:
pip install theano-pymc
This new version of Theano-PyMC
comes with an experimental JAX backend which, when combined with the new and experimental JAX samplers in PyMC3, can greatly speed up sampling in your model. As this is still very new, please do not use it in production yet but do test it out and let us know if anything breaks and what results you are seeing, especially speed-wise.
New features
- New experimental JAX samplers in
pymc3.sample_jax
(see notebook and #4247). Requires JAX and either TFP or numpyro. - Add MLDA, a new stepper for multilevel sampling. MLDA can be used when a hierarchy of approximate posteriors of varying accuracy is available, offering improved sampling efficiency especially in high-dimensional problems and/or where gradients are not available (see #3926)
- Add Bayesian Additive Regression Trees (BARTs) #4183)
- Added
pymc3.gp.cov.Circular
kernel for Gaussian Processes on circular domains, e.g. the unit circle (see #4082). - Added a new
MixtureSameFamily
distribution to handle mixtures of arbitrary dimensions in vectorized form for improved speed (see #4185). sample_posterior_predictive_w
can now feed onxarray.Dataset
- e.g. fromInferenceData.posterior
. (see #4042)- Change SMC metropolis kernel to independent metropolis kernel #4115)
- Add alternative parametrization to NegativeBinomial distribution in terms of n and p (see #4126)
- Added semantically meaningful
str
representations to PyMC3 objects for console, notebook, and GraphViz use (see #4076, #4065, #4159, #4217, #4243, and #4260). - Add Discrete HyperGeometric Distribution (see #4249)
Maintenance
- Switch the dependency of Theano to our own fork, Theano-PyMC.
- Removed non-NDArray (Text, SQLite, HDF5) backends and associated tests.
- 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). - Fixed numerical instability in ExGaussian's logp by preventing
logpow
from returning-inf
(see #4050). - Numerically improved stickbreaking transformation - e.g. for the
Dirichlet
distribution. #4129 - Enabled the
Multinomial
distribution to handle batch sizes that have more than 2 dimensions. #4169 - Test model logp before starting any MCMC chains (see #4211)
- Fix bug in
model.check_test_point
that caused thetest_point
argument to be ignored. (see PR #4211) - Refactored MvNormal.random method with better handling of sample, batch and event shapes. #4207
- The
InverseGamma
distribution now implements alogcdf
. #3944 - Make starting jitter methods for nuts sampling more robust by resampling values that lead to non-finite probabilities. A new optional argument
jitter-max-retries
can be passed topm.sample()
andpm.init_nuts()
to control the maximum number of retries per chain. 4298
Documentation
- Added a new notebook demonstrating how to incorporate sampling from a conjugate Dirichlet-multinomial posterior density in conjunction with other step methods (see #4199).
- Mentioned the way to do any random walk with
theano.tensor.cumsum()
inGaussianRandomWalk
docstrings (see #4048).
Release manager for 3.10.0: Eelke Spaak (@Spaak)
PyMC3 v3.9.3 (August 11, 2020)
This release includes several fixes, including (but not limited to) the following:
- Fix keep_size argument in Arviz data structures: #4006
- Pin Theano 1.0.5: #4032
- Comprehensively re-wrote radon modeling notebook using latest Arviz features: #3963
NB: The docs/*
folder is still removed from the tarball due to an upload size limit on PyPi.
PyMC3 v3.9.2 (24 June 2020)
Maintenance
- Warning added in GP module when
input_dim
is lower than the number of columns inX
to compute the covariance function (see #3974). - Pass the
tune
argument fromsample
when usingadvi+adapt_diag_grad
(see issue #3965, fixed by #3979). - Add simple test case for new coords and dims feature in
pm.Model
(see #3977). - Require ArviZ >= 0.9.0 (see #3977).
NB: The docs/*
folder is still removed from the tarball due to an upload size limit on PyPi.
PyMC3 v3.9.1 (16 June, 2020)
The v3.9.0
upload to PyPI didn't include a tarball, which is fixed in this release. Though we had to temporarily remove the docs/*
folder from the tarball due to a PyPI size limit.
PyMC3 v3.9.0 (16 June, 2020)
New features
- Use fastprogress instead of tqdm #3693.
DEMetropolis
can now tune bothlambda
andscaling
parameters, but by default neither of them are tuned. See #3743 for more info.DEMetropolisZ
, an improved variant ofDEMetropolis
brings better parallelization and higher efficiency with fewer chains with a slower initial convergence. This implementation is experimental. See #3784 for more info.- Notebooks that give insight into
DEMetropolis
,DEMetropolisZ
and theDifferentialEquation
interface are now located in the Tutorials/Deep Dive section. - Add
fast_sample_posterior_predictive
, a vectorized alternative tosample_posterior_predictive
. This alternative is substantially faster for large models. - GP covariance functions can now be exponentiated by a scalar. See PR #3852
sample_posterior_predictive
can now feed onxarray.Dataset
- e.g. fromInferenceData.posterior
. (see #3846)SamplerReport
(MultiTrace.report
) now has propertiesn_tune
,n_draws
,t_sampling
for increased convenience (see #3827)pm.sample(..., return_inferencedata=True)
can now directly return the trace asarviz.InferenceData
(see #3911)pm.sample
now has support for adapting dense mass matrix usingQuadPotentialFullAdapt
(see #3596, #3705, #3858, and #3893). Useinit="adapt_full"
orinit="jitter+adapt_full"
to use.Moyal
distribution added (see #3870).pm.LKJCholeskyCov
now automatically computes and returns the unpacked Cholesky decomposition, the correlations and the standard deviations of the covariance matrix (see #3881).pm.Data
container can now be used for index variables, i.e with integer data and not only floats (issue #3813, fixed by #3925).pm.Data
container can now be used as input for other random variables (issue #3842, fixed by #3925).- Allow users to specify coordinates and dimension names instead of numerical shapes when specifying a model. This makes interoperability with ArviZ easier. (see #3551)
- Plots and Stats API sections now link to ArviZ documentation #3927
- Add
SamplerReport
with propertiesn_draws
,t_sampling
andn_tune
to SMC.n_tune
is always 0 #3931. - SMC-ABC: add option to define summary statistics, allow to sample from more complex models, remove redundant distances #3940
Maintenance
- Tuning results no longer leak into sequentially sampled
Metropolis
chains (see #3733 and #3796). - We'll deprecate the
Text
andSQLite
backends and thesave_trace
/load_trace
functions, since this is now done with ArviZ. (see #3902) - ArviZ
v0.8.3
is now the minimum required version - In named models,
pm.Data
objects now get model-relative names (see #3843). -
pm.sample
now takes 1000 draws and 1000 tuning samples by default, instead of 500 previously (see #3855). - Moved argument division out of
NegativeBinomial
random
method. Fixes #3864 in the style of #3509. - The Dirichlet distribution now raises a ValueError when it's initialized with <= 0 values (see #3853).
- Dtype bugfix in
MvNormal
andMvStudentT
(see 3836). - End of sampling report now uses
arviz.InferenceData
internally and avoids storing
pointwise log likelihood (see #3883). - The multiprocessing start method on MacOS is now set to "forkserver", to avoid crashes (see issue #3849, solved by #3919).
- The AR1 logp now uses the precision of the whole AR1 process instead of just the innovation precision (see issue #3892, fixed by #3899).
- Forced the
Beta
distribution'srandom
method to generate samples that are in the open interval$(0, 1)$ , i.e. no value can be equal to zero or equal to one (issue #3898 fixed by #3924). - Fixed an issue that happened on Windows, that was introduced by the clipped beta distribution rvs function (#3924). Windows does not support the
float128
dtype, but we had assumed that it had to be available. The solution was to only supportfloat128
on Linux and Darwin systems (see issue #3929 fixed by #3930).
Deprecations
- Remove
sample_ppc
andsample_ppc_w
that were deprecated in 3.6. - Deprecated
sd
has been replaced bysigma
(already in version 3.7) in continuous, mixed and timeseries distributions and now raisesDeprecationWarning
whensd
is used. (see #3837 and #3688). - We'll deprecate the
Text
andSQLite
backends and thesave_trace
/load_trace
functions, since this is now done with ArviZ. (see #3902) - Dropped some deprecated kwargs and functions (see #3906)
- Dropped the outdated 'nuts' initialization method for
pm.sample
(see #3863).
PyMC3 v3.8 (29 November, 2019)
New features
- Implemented robust u turn check in NUTS (similar to stan-dev/stan#2800). See PR [#3605]
- Add capabilities to do inference on parameters in a differential equation with
DifferentialEquation
. See #3590 and #3634. - Distinguish between
Data
andDeterministic
variables when graphing models with graphviz. PR #3491. - Sequential Monte Carlo - Approximate Bayesian Computation step method is now available. The implementation is in an experimental stage and will be further improved.
- Added
Matern12
covariance function for Gaussian processes. This is the Matern kernel with nu=1/2. - Progressbar reports number of divergences in real time, when available #3547.
- Sampling from variational approximation now allows for alternative trace backends [#3550].
- Infix
@
operator now works with random variables and deterministics #3619. - ArviZ is now a requirement, and handles plotting, diagnostics, and statistical checks.
- Can use GaussianRandomWalk in sample_prior_predictive and sample_prior_predictive #3682
- Now 11 years of S&P returns in data set#3682
Maintenance
- Moved math operations out of
Rice
,TruncatedNormal
,Triangular
andZeroInflatedNegativeBinomial
random
methods. Math operations on values returned bydraw_values
might not broadcast well, and all thesize
aware broadcasting is left togenerate_samples
. Fixes #3481 and #3508 - Parallelization of population steppers (
DEMetropolis
) is now set via thecores
argument. (#3559) - Fixed a bug in
Categorical.logp
. In the case of multidimensionalp
's, the indexing was done wrong leading to incorrectly shaped tensors that consumedO(n**2)
memory instead ofO(n)
. This fixes issue #3535 - Fixed a defect in
OrderedLogistic.__init__
that unnecessarily increased the dimensionality of the underlyingp
. Related to issue issue #3535 but was not the true cause of it. - SMC: stabilize covariance matrix 3573
- SMC: is no longer a step method of
pm.sample
now it should be called usingpm.sample_smc
3579 - SMC: improve computation of the proposal scaling factor 3594 and 3625
- SMC: reduce number of logp evaluations 3600
- SMC: remove
scaling
andtune_scaling
arguments as is a better idea to always allow SMC to automatically compute the scaling factor 3625 - Now uses
multiprocessong
rather thanpsutil
to count CPUs, which results in reliable core counts on Chromebooks. sample_posterior_predictive
now preallocates the memory required for its output to improve memory usage. Addresses problems raised in this discourse thread.- Fixed a bug in
Categorical.logp
. In the case of multidimensionalp
's, the indexing was done wrong leading to incorrectly shaped tensors that consumedO(n**2)
memory instead ofO(n)
. This fixes issue #3535 - Fixed a defect in
OrderedLogistic.__init__
that unnecessarily increased the dimensionality of the underlyingp
. Related to issue issue #3535 but was not the true cause of it. - Wrapped
DensityDist.rand
withgenerate_samples
to make it aware of the distribution's shape. Added control flow attributes to still be able to behave as in earlier versions, and to control how to interpret thesize
parameter in therandom
callable signature. Fixes 3553 - Added
theano.gof.graph.Constant
to type checks done in_draw_value
(fixes issue 3595) HalfNormal
did not used to work properly indraw_values
,sample_prior_predictive
, orsample_posterior_predictive
(fixes issue 3686)- Random variable transforms were inadvertently left out of the API documentation. Added them. (See PR 3690).
PyMC3 3.7 (May 29 2019)
New features
- Add data container class (
Data
) that wraps the theano SharedVariable class and let the model be aware of its inputs and outputs. - Add function
set_data
to update variables defined asData
. Mixture
now supports mixtures of multidimensional probability distributions, not just lists of 1D distributions.GLM.from_formula
andLinearComponent.from_formula
can extract variables from the calling scope. Customizable via the neweval_env
argument. Fixing #3382.- Added the
distributions.shape_utils
module with functions used to help broadcast samples drawn from distributions using thesize
keyword argument. - Used
numpy.vectorize
indistributions.distribution._compile_theano_function
. This enablessample_prior_predictive
andsample_posterior_predictive
to ask for tuples of samples instead of just integers. This fixes issue #3422.
Maintenance
- All occurances of
sd
as a parameter name have been renamed tosigma
.sd
will continue to function for backwards compatibility. HamiltonianMC
was ignoring certain arguments liketarget_accept
, and not using the custom step size jitter function with expectation 1.- Made
BrokenPipeError
for parallel sampling more verbose on Windows. - Added the
broadcast_distribution_samples
function that helps broadcasting arrays of drawn samples, taking into account the requestedsize
and the inferred distribution shape. This sometimes is needed by distributions that call severalrvs
separately within theirrandom
method, such as theZeroInflatedPoisson
(fixes issue #3310). - The
Wald
,Kumaraswamy
,LogNormal
,Pareto
,Cauchy
,HalfCauchy
,Weibull
andExGaussian
distributionsrandom
method used a hidden_random
function that was written with scalars in mind. This could potentially lead to artificial correlations between random draws. Added shape guards and broadcasting of the distribution samples to prevent this (Similar to issue #3310). - Added a fix to allow the imputation of single missing values of observed data, which previously would fail (fixes issue #3122).
- The
draw_values
function was too permissive with what could be grabbed from insidepoint
, which lead to an error when sampling posterior predictives of variables that depended on shared variables that had changed their shape afterpm.sample()
had been called (fix issue #3346). draw_values
now adds the theano graph descendants ofTensorConstant
orSharedVariables
to the named relationship nodes stack, only if these descendants areObservedRV
orMultiObservedRV
instances (fixes issue #3354).- Fixed bug in broadcast_distrution_samples, which did not handle correctly cases in which some samples did not have the size tuple prepended.
- Changed
MvNormal.random
's usage oftensordot
for Cholesky encoded covariances. This lead to wrong axis broadcasting and seemed to be the cause for issue #3343. - Fixed defect in
Mixture.random
when multidimensional mixtures were involved. The mixture component was not preserved across all the elements of the dimensions of the mixture. This meant that the correlations across elements within a given draw of the mixture were partly broken. - Restructured
Mixture.random
to allow better use of vectorized calls tocomp_dists.random
. - Added tests for mixtures of multidimensional distributions to the test suite.
- Fixed incorrect usage of
broadcast_distribution_samples
inDiscreteWeibull
. Mixture
's default dtype is now determined bytheano.config.floatX
.dist_math.random_choice
now handles nd-arrays of category probabilities, and also handles sizes that are notNone
. Also removed unusedk
kwarg fromdist_math.random_choice
.- Changed
Categorical.mode
to preserve all the dimensions ofp
except the last one, which encodes each category's probability. - Changed initialization of
Categorical.p
.p
is now normalized to sum to1
insidelogp
andrandom
, but not during initialization. This could hide negative values supplied top
as mentioned in #2082. Categorical
now accepts elements ofp
equal to0
.logp
will return-inf
if there arevalues
that index to the zero probability categories.- Add
sigma
,tau
, andsd
to signature ofNormalMixture
. - Set default lower and upper values of -inf and inf for pm.distributions.continuous.TruncatedNormal. This avoids errors caused by their previous values of None (fixes issue #3248).
- Converted all calls to
pm.distributions.bound._ContinuousBounded
andpm.distributions.bound._DiscreteBounded
to use only and all positional arguments (fixes issue #3399). - Restructured
distributions.distribution.generate_samples
to use theshape_utils
module. This solves issues #3421 and #3147 by using thesize
aware broadcating functions inshape_utils
. - Fixed the
Multinomial.random
andMultinomial.random_
methods to make them compatible with the newgenerate_samples
function. In the process, a bug of theMultinomial.random_
shape handling was discovered and fixed. - Fixed a defect found in
Bound.random
where thepoint
dictionary was passed togenerate_samples
as anarg
instead of innot_broadcast_kwargs
. - Fixed a defect found in
Bound.random_
wheretotal_size
could end up as afloat64
instead of being an integer if givensize=tuple()
. - Fixed an issue in
model_graph
that caused construction of the graph of the model for rendering to hang: replaced a search over the powerset of the nodes with a breadth-first search over the nodes. Fix for #3458. - Removed variable annotations from
model_graph
but left type hints (Fix for #3465). This means that we supportpython>=3.5.4
. - Default
target_accept
forHamiltonianMC
is now 0.65, as suggested in Beskos et. al. 2010 and Neal 2001. - Fixed bug in
draw_values
that lead to intermittent errors in python3.5. This happened with some deterministic nodes that were drawn but not added togivens
.
Deprecations
nuts_kwargs
andstep_kwargs
have been deprecated in favor of using the standardkwargs
to pass optional step method arguments.SGFS
andCSG
have been removed (Fix for #3353). They have been moved to pymc3-experimental.- References to
live_plot
and corresponding notebooks have been removed. - Function
approx_hessian
was removed, due tonumdifftools
becoming incompatible with currentscipy
. The function was already optional, only available to a user who installednumdifftools
separately, and not hit on any common codepaths. #3485. - Deprecated
vars
parameter ofsample_posterior_predictive
in favor ofvarnames
. - References to
live_plot
and corresponding notebooks have been removed. - Deprecated
vars
parameters ofsample_posterior_predictive
andsample_prior_predictive
in favor ofvar_names
. At least for the latter, this is more accurate, since thevars
parameter actually took names.
Contributors sorted by number of commits
45 Luciano Paz
38 Thomas Wiecki
23 Colin Carroll
19 Junpeng Lao
15 Chris Fonnesbeck
13 Juan Martín Loyola
13 Ravin Kumar
8 Robert P. Goldman
5 Tim Blazina
4 chang111
4 adamboche
3 Eric Ma
3 Osvaldo Martin
3 Sanmitra Ghosh
3 Saurav Shekhar
3 chartl
3 fredcallaway
3 Demetri
2 Daisuke Kondo
2 David Brochart
2 George Ho
2 Vaibhav Sinha
1 rpgoldman
1 Adel Tomilova
1 Adriaan van der Graaf
1 Bas Nijholt
1 Benjamin Wild
1 Brigitta Sipocz
1 Daniel Emaasit
1 Hari
1 Jeroen
1 Joseph Willard
1 Juan Martin Loyola
1 Katrin Leinweber
1 Lisa Martin
1 M. Domenzain
1 Matt Pitkin
1 Peadar Coyle
1 Rupal Sharma
1 Tom Gilliss
1 changjiangeng
1 michaelosthege
1 monsta
1 579397
v3.6
This is a major new release from 3.5 with many new features and important bugfixes. The highlight is certainly our completely revamped website: https://docs.pymc.io/
Note also, that this release will be the last to be compatible with Python 2. Thanks to all contributors!
New features
- Track the model log-likelihood as a sampler stat for NUTS and HMC samplers
(accessible astrace.get_sampler_stats('model_logp')
) (#3134) - Add Incomplete Beta function
incomplete_beta(a, b, value)
- Add log CDF functions to continuous distributions:
Beta
,Cauchy
,ExGaussian
,Exponential
,Flat
,Gumbel
,HalfCauchy
,HalfFlat
,HalfNormal
,Laplace
,Logistic
,Lognormal
,Normal
,Pareto
,StudentT
,Triangular
,Uniform
,Wald
,Weibull
. - Behavior of
sample_posterior_predictive
is now to produce posterior predictive samples, in order, from all values of thetrace
. Previously, by default it would produce 1 chain worth of samples, using a random selection from thetrace
(#3212) - Show diagnostics for initial energy errors in HMC and NUTS.
- PR #3273 has added the
distributions.distribution._DrawValuesContext
context
manager. This is used to store the values already drawn in nestedrandom
anddraw_values
calls, enablingdraw_values
to draw samples from the
joint probability distribution of RVs and not the marginals. Custom
distributions that must calldraw_values
several times in theirrandom
method, or that invoke many calls to other distribution'srandom
methods
(e.g. mixtures) must do all of these calls under the same_DrawValuesContext
context manager instance. If they do not, the conditional relations between
the distribution's parameters could be broken, andrandom
could return
values drawn from an incorrect distribution. Rice
distribution is now defined with either the noncentrality parameter or the shape parameter (#3287).
Maintenance
- Big rewrite of documentation (#3275)
- Fixed Triangular distribution
c
attribute handling inrandom
and updated sample codes for consistency (#3225) - Refactor SMC and properly compute marginal likelihood (#3124)
- Removed use of deprecated
ymin
keyword in matplotlib'sAxes.set_ylim
(#3279) - Fix for #3210. Now
distribution.draw_values(params)
, will draw theparams
values from their joint probability distribution and not from combinations of their marginals (Refer to PR #3273). - Removed dependence on pandas-datareader for retrieving Yahoo Finance data in examples (#3262)
- Rewrote
Multinomial._random
method to better handle shape broadcasting (#3271) - Fixed
Rice
distribution, which inconsistently mixed two parametrizations (#3286). Rice
distribution now accepts multiple parameters and observations and is usable with NUTS (#3289).sample_posterior_predictive
no longer callsdraw_values
to initialize the shape of the ppc trace. This called could lead toValueError
's when sampling the ppc from a model withFlat
orHalfFlat
prior distributions (Fix issue #3294).
Deprecations
- Renamed
sample_ppc()
andsample_ppc_w()
tosample_posterior_predictive()
andsample_posterior_predictive_w()
, respectively.
v3.5 Final
New features
- Add documentation section on survival analysis and censored data models
- Add
check_test_point
method topm.Model
- Add
Ordered
Transformation andOrderedLogistic
distribution - Add
Chain
transformation - Improve error message
Mass matrix contains zeros on the diagonal. Some derivatives might always be zero
during tuning ofpm.sample
- Improve error message
NaN occurred in optimization.
during ADVI - Save and load traces without
pickle
usingpm.save_trace
andpm.load_trace
- Add
Kumaraswamy
distribution - Add
TruncatedNormal
distribution - Rewrite parallel sampling of multiple chains on py3. This resolves
long standing issues when transferring large traces to the main process,
avoids pickling issues on UNIX, and allows us to show a progress bar
for all chains. If parallel sampling is interrupted, we now return
partial results. - Add
sample_prior_predictive
which allows for efficient sampling from
the unconditioned model. - SMC: remove experimental warning, allow sampling using
sample
, reduce autocorrelation from
final trace. - Add
model_to_graphviz
(which uses the optional dependencygraphviz
) to
plot a directed graph of a PyMC3 model using plate notation. - Add beta-ELBO variational inference as in beta-VAE model (Christopher P. Burgess et al. NIPS, 2017)
- Add
__dir__
toSingleGroupApproximation
to improve autocompletion in interactive environments
Fixes
- Fixed grammar in divergence warning, previously
There were 1 divergences ...
could be raised. - Fixed
KeyError
raised when only subset of variables are specified to be recorded in the trace. - Removed unused
repeat=None
arguments from allrandom()
methods in distributions. - Deprecated the
sigma
argument inMarginalSparse.marginal_likelihood
in favor ofnoise
- Fixed unexpected behavior in
random
. Now therandom
functionality is more robust and will work better forsample_prior
when that is implemented. - Fixed
scale_cost_to_minibatch
behaviour, previously this was not working and alwaysFalse
v3.4.1 Final
There was no 3.4 release due to a naming issue on PyPI.
New features
- Add
logit_p
keyword topm.Bernoulli
, so that users can specify the logit of the success probability. This is faster and more stable than usingp=tt.nnet.sigmoid(logit_p)
. - Add
random
keyword topm.DensityDist
thus enabling users to pass custom random method which in turn makes sampling from aDensityDist
possible. - Effective sample size computation is updated. The estimation uses Geyer's initial positive sequence, which no longer truncates the autocorrelation series inaccurately.
pm.diagnostics.effective_n
now can reports N_eff>N. - Added
KroneckerNormal
distribution and a correspondingMarginalKron
Gaussian Process implementation for efficient inference, along with
lower-level functions such ascartesian
andkronecker
products. - Added
Coregion
covariance function. - Add new 'pairplot' function, for plotting scatter or hexbin matrices of sampled parameters.
Optionally it can plot divergences. - Plots of discrete distributions in the docstrings
- Add logitnormal distribution
- Densityplot: add support for discrete variables
- Fix the Binomial likelihood in
.glm.families.Binomial
, with the flexibility of specifying then
. - Add
offset
kwarg to.glm
. - Changed the
compare
function to accept a dictionary of model-trace pairs instead of two separate lists of models and traces. - add test and support for creating multivariate mixture and mixture of mixtures
distribution.draw_values
, now is also able to draw values from conditionally dependent RVs, such as autotransformed RVs (Refer to PR #2902).
Fixes
VonMises
does not overflow for large values of kappa. i0 and i1 have been removed and we now use log_i0 to compute the logp.- The bandwidth for KDE plots is computed using a modified version of Scott's rule. The new version uses entropy instead of standard deviation. This works better for multimodal distributions. Functions using KDE plots has a new argument
bw
controlling the bandwidth. - fix PyMC3 variable is not replaced if provided in more_replacements (#2890)
- Fix for issue #2900. For many situations, named node-inputs do not have a
random
method, while some intermediate node may have it. This meant that if the named node-input at the leaf of the graph did not have a fixed value,theano
would try to compile it and fail to find inputs, raising atheano.gof.fg.MissingInputError
. This was fixed by going through the theano variable's owner inputs graph, trying to get intermediate named-nodes values if the leafs had failed. - In
distribution.draw_values
, some named nodes could betheano.tensor.TensorConstant
s ortheano.tensor.sharedvar.SharedVariable
s. Nevertheless, indistribution._draw_value
, these would be passed todistribution._compile_theano_function
as if they weretheano.tensor.TensorVariable
s. This could lead to the following exceptionsTypeError: ('Constants not allowed in param list', ...)
orTypeError: Cannot use a shared variable (...)
. The fix was to not addtheano.tensor.TensorConstant
ortheano.tensor.sharedvar.SharedVariable
named nodes into thegivens
dict that could be used indistribution._compile_theano_function
. - Exponential support changed to include zero values.
Deprecations
- DIC and BPIC calculations have been removed
- df_summary have been removed, use summary instead
njobs
andnchains
kwarg are deprecated in favor ofcores
andchains
forsample
lag
kwarg inpm.stats.autocorr
andpm.stats.autocov
is deprecated.