-
Notifications
You must be signed in to change notification settings - Fork 34
Expand file tree
/
Copy path__init__.py
More file actions
276 lines (245 loc) · 6.19 KB
/
__init__.py
File metadata and controls
276 lines (245 loc) · 6.19 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
#
# Root of the pints module.
# Provides access to all shared functionality (optimisation, mcmc, etc.).
#
# This file is part of PINTS (https://github.com/pints-team/pints/) which is
# released under the BSD 3-clause license. See accompanying LICENSE.md for
# copyright notice and full license details.
#
"""
Pints: Probabilistic Inference on Noisy Time Series.
This module provides several optimisation and sampling methods that can be
applied to find the parameters of a model (typically a time series model) that
are most likely, given an experimental data set.
"""
import os
import sys
#
# Check Python version
#
if sys.hexversion < 0x03050000: # pragma: no cover
raise RuntimeError('PINTS requires Python 3.5 or newer.')
#
# Version info
#
def _load_version_int():
try:
root = os.path.abspath(os.path.dirname(__file__))
with open(os.path.join(root, 'version'), 'r') as f:
version = f.read().strip().split(',')
major, minor, revision = [int(x) for x in version]
return major, minor, revision
except Exception as e: # pragma: no cover
raise RuntimeError('Unable to read version number (' + str(e) + ').')
__version_int__ = _load_version_int()
__version__ = '.'.join([str(x) for x in __version_int__])
#
# Expose pints version
#
def version(formatted=False):
"""
Returns the version number, as a 3-part integer (major, minor, revision).
If ``formatted=True``, it returns a string formatted version (for example
"Pints 1.0.0").
"""
if formatted:
return 'Pints ' + __version__
else:
return __version_int__
#
# Constants
#
# Float format: a float can be converted to a 17 digit decimal and back without
# loss of information
FLOAT_FORMAT = '{: .17e}'
#
# Core classes
#
from ._core import ForwardModel, ForwardModelS1
from ._core import TunableMethod
from ._core import (
SingleOutputProblem,
MultiOutputProblem,
ProblemCollection,
SubProblem
)
#
# Utility classes and methods
#
from ._util import strfloat, vector, matrix2d
from ._util import Timer
from ._logger import Logger, Loggable
#
# Logs of probability density functions (not necessarily normalised)
#
from ._log_pdfs import (
LogPDF,
LogPrior,
LogPosterior,
PooledLogPDF,
ProblemLogLikelihood,
SumOfIndependentLogPDFs,
)
#
# Log-priors
#
from ._log_priors import (
BetaLogPrior,
CauchyLogPrior,
ComposedLogPrior,
ExponentialLogPrior,
GammaLogPrior,
GaussianLogPrior,
HalfCauchyLogPrior,
InverseGammaLogPrior,
LogNormalLogPrior,
MultivariateGaussianLogPrior,
NormalLogPrior,
StudentTLogPrior,
TruncatedGaussianLogPrior,
UniformLogPrior,
)
#
# Log-likelihoods
#
from ._log_likelihoods import (
AR1LogLikelihood,
ARMA11LogLikelihood,
CauchyLogLikelihood,
ConstantAndMultiplicativeGaussianLogLikelihood,
GaussianIntegratedUniformLogLikelihood,
GaussianKnownSigmaLogLikelihood,
GaussianLogLikelihood,
KnownNoiseLogLikelihood,
MultiplicativeGaussianLogLikelihood,
ScaledLogLikelihood,
StudentTLogLikelihood,
UnknownNoiseLogLikelihood,
)
#
# Boundaries
#
from ._boundaries import (
Boundaries,
LogPDFBoundaries,
RectangularBoundaries,
)
#
# Error measures
#
from ._error_measures import (
ErrorMeasure,
MeanSquaredError,
NormalisedRootMeanSquaredError,
ProbabilityBasedError,
ProblemErrorMeasure,
RootMeanSquaredError,
SumOfErrors,
SumOfSquaresError,
)
#
# Parallel function evaluation
#
from ._evaluation import (
evaluate,
Evaluator,
ParallelEvaluator,
SequentialEvaluator,
)
#
# Optimisation
#
from ._optimisers import (
curve_fit,
fmin,
Optimisation,
OptimisationController,
optimise,
Optimiser,
PopulationBasedOptimiser,
TriangleWaveTransform,
)
from ._optimisers._cmaes import CMAES
from ._optimisers._cmaes_bare import BareCMAES
from ._optimisers._gradient_descent import GradientDescent
from ._optimisers._nelder_mead import NelderMead
from ._optimisers._pso import PSO
from ._optimisers._snes import SNES
from ._optimisers._xnes import XNES
#
# Diagnostics
#
from ._diagnostics import (
effective_sample_size,
rhat,
rhat_all_params,
)
#
# MCMC
#
from ._mcmc import (
mcmc_sample,
MCMCController,
MCMCSampler,
MCMCSampling,
MultiChainMCMC,
SingleChainMCMC,
)
# base classes first
from ._mcmc._adaptive_covariance import AdaptiveCovarianceMC
# methods
from ._mcmc._differential_evolution import DifferentialEvolutionMCMC
from ._mcmc._dram_ac import DramACMC
from ._mcmc._dream import DreamMCMC
from ._mcmc._dual_averaging import DualAveragingAdaption
from ._mcmc._emcee_hammer import EmceeHammerMCMC
from ._mcmc._haario_ac import HaarioACMC
from ._mcmc._haario_bardenet_ac import HaarioBardenetACMC
from ._mcmc._haario_bardenet_ac import AdaptiveCovarianceMCMC
from ._mcmc._hamiltonian import HamiltonianMCMC
from ._mcmc._mala import MALAMCMC
from ._mcmc._metropolis import MetropolisRandomWalkMCMC
from ._mcmc._monomial_gamma_hamiltonian import MonomialGammaHamiltonianMCMC
from ._mcmc._nuts import NoUTurnMCMC
from ._mcmc._population import PopulationMCMC
from ._mcmc._rao_blackwell_ac import RaoBlackwellACMC
from ._mcmc._relativistic import RelativisticMCMC
from ._mcmc._slice_doubling import SliceDoublingMCMC
from ._mcmc._slice_rank_shrinking import SliceRankShrinkingMCMC
from ._mcmc._slice_stepout import SliceStepoutMCMC
from ._mcmc._summary import MCMCSummary
#
# Nested samplers
#
from ._nested import NestedSampler
from ._nested import NestedController
from ._nested._rejection import NestedRejectionSampler
from ._nested._ellipsoid import NestedEllipsoidSampler
#
# Sampling initialising
#
from ._sample_initial_points import sample_initial_points
#
# Transformations
#
from ._transformation import (
ComposedTransformation,
IdentityTransformation,
LogitTransformation,
LogTransformation,
RectangularBoundariesTransformation,
ScalingTransformation,
Transformation,
TransformedBoundaries,
TransformedErrorMeasure,
TransformedLogPDF,
TransformedLogPrior,
)
#
# Noise generators (always import!)
#
from . import noise
#
# Remove any imported modules, so we don't expose them as part of pints
#
del(os, sys)