Skip to main content

pyemcee: Python implementation of the affine-invariant MCMC Hammer

Project description

PyPI Version Build Status Build Status Coverage Status GitHub license Anaconda Cloud Documentation Status Support Python versions 2.7, 3.4 and 3.5 Zenodo https://mybinder.org/badge_logo.svg

Description

pyemcee is a Python implementation of the affine-invariant Markov chain Monte Carlo (MCMC) ensemble sampler, based on sl_emcee by M. A. Nowak, an S-Lang/ISIS implementation of the MCMC Hammer proposed by Goodman & Weare (2010), and also implemented in Python (emcee) by Foreman-Mackey et al. (2013).

Installation

To install the last version, all you should need to do is

$ python setup.py install

To install the stable version, you can use the preferred installer program (pip):

$ pip install pyemcee

or you can install it from the cross-platform package manager conda:

$ conda install -c conda-forge pyemcee

This package requires the following packages:

How to Use

The Documentation of the functions provides in detail in the API Documentation (mcfit.github.io/pyemcee/doc). This Python library creates the MCMC sampling for given upper and lower uncertainties, and propagates uncertainties of parameters into the function.

See Jupyter Notebook: Notebook.ipynb

Run Jupyter Notebook on Binder:

https://mybinder.org/badge_logo.svg

First, you need to load the pyemcee library as follows:

import pyemcee
import numpy as np

You need to define your function. For example:

def myfunc21(input1):
   result1 = np.sum(input1)
   result2 = input1[1] ** input1[0]
   return [result1, result2]

Then, specify the upper and lower uncertainties of the prior parameters:

input1 = np.array([1., 2.])
input1_err = np.array([0.2, 0.5])
input1_err_p = input1_err
input1_err_m = -input1_err
output1 = myfunc21(input1)
output1_num = len(output1)

Choose the appropriate uncertainty distribution. For example, for a uniform distribution, use_gaussian=0, and a Gaussian distribution use_gaussian=1. Then, specify the number of walkers and the number of iterations, e.g. walk_num=30 and iteration_num=100. You can then create the MCMC sample and propagate the uncertainties of the input parameters into your defined functions as follows:

use_gaussian=0 # uniform distribution from min value to max value
walk_num=30 # number of walkers
iteration_num=100 # number of samplers
mcmc_sim = pyemcee.hammer(myfunc21, input1, input1_err_m,
                          input1_err_p, output1, walk_num,
                          iteration_num, use_gaussian)

To determine the upper and lower errors of the function outputs, you need to run with the chosen appropriate confidence level. For example, a 1.645-sigma standard deviation can be specified with clevel=0.90. For a 1-sigma standard deviation, we have clevel=0.682:

clevel=0.68268949 # 1-sigma
output1_error = pyemcee.find_errors(output1, mcmc_sim, clevel, do_plot=1)

which shows the following distribution histograms:

https://raw.githubusercontent.com/mcfit/pyemcee/master/examples/images/histogram0.png https://raw.githubusercontent.com/mcfit/pyemcee/master/examples/images/histogram1.png

To prevent plotting, you should set do_plot=None. To print the results:

for i in range(0, output1_num):
   print(output1[i], output1_error[i,:])

which provide the upper and lower limits on each parameter:

3.0 [-0.35801017 0.35998471]
2.0 [-0.37573196 0.36297235]

For other standard deviation, you should use different confidence levels:

clevel=0.38292492 # 0.5-sigma
clevel=0.68268949 # 1.0-sigma
clevel=0.86638560 # 1.5-sigma
clevel=0.90       # 1.645-sigma
clevel=0.95       # 1.960-sigma
clevel=0.95449974 # 2.0-sigma
clevel=0.98758067 # 2.5-sigma
clevel=0.99       # 2.575-sigma
clevel=0.99730020 # 3.0-sigma
clevel=0.99953474 # 3.5-sigma
clevel=0.99993666 # 4.0-sigma
clevel=0.99999320 # 4.5-sigma
clevel=0.99999943 # 5.0-sigma
clevel=0.99999996 # 5.5-sigma
clevel=0.999999998# 6.0-sigma

Documentation

For more information on how to use the API functions from the pyemcee library, please read the API Documentation published on mcfit.github.io/pyemcee.

Learn More

Documentation

https://pyemcee.readthedocs.io/

Repository

https://github.com/mcfit/pyemcee

Issues & Ideas

https://github.com/mcfit/pyemcee/issues

Conda-Forge

https://anaconda.org/conda-forge/pyemcee

PyPI

https://pypi.org/project/pyemcee/

Archive

10.5281/zenodo.4495911

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

pyemcee-0.2.6.tar.gz (22.7 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

pyemcee-0.2.6-py2.py3-none-any.whl (33.4 kB view details)

Uploaded Python 2Python 3

File details

Details for the file pyemcee-0.2.6.tar.gz.

File metadata

  • Download URL: pyemcee-0.2.6.tar.gz
  • Upload date:
  • Size: 22.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.9.16

File hashes

Hashes for pyemcee-0.2.6.tar.gz
Algorithm Hash digest
SHA256 6277bb06a133a5ab8f4cff1296ff8698ffebbdc41cce600e44b43ff199879721
MD5 48a2636ccb9a19af19954e39da1c4c29
BLAKE2b-256 a013dbebc939751d62d2a3a489fdab06494dcfcfcf45020eb82aa80fefde0498

See more details on using hashes here.

File details

Details for the file pyemcee-0.2.6-py2.py3-none-any.whl.

File metadata

  • Download URL: pyemcee-0.2.6-py2.py3-none-any.whl
  • Upload date:
  • Size: 33.4 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.9.16

File hashes

Hashes for pyemcee-0.2.6-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 5a44217598be0cbfa774221974a886a104f495a54bc60a6500865df596f62b78
MD5 a4a817cfce1d21fca653b5f1a2e3406e
BLAKE2b-256 3efcbf2f80207fea9409595faac2a52e2a7f00abb5182acda1d51734266f954f

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page