Skip to main content

Python interface to Stan, a package for Bayesian inference

Project description

NOTE: This documentation describes a BETA release of PyStan 3.

PyStan is a Python interface to Stan, a package for Bayesian inference.

Stan® is a state-of-the-art platform for statistical modeling and high-performance statistical computation. Thousands of users rely on Stan for statistical modeling, data analysis, and prediction in the social, biological, and physical sciences, engineering, and business.

Notable features of PyStan include:

  • Automatic caching of compiled Stan models

  • Automatic caching of samples from Stan models

  • An interface similar to that of RStan

  • Open source software: ISC License

Getting started

NOTE: BETA versions of PyStan 3 must be installed with ``pip install –pre pystan``.

Install PyStan with pip install pystan. (PyStan requires Python 3.7 or higher running on a Linux or macOS system.)

The following block of code shows how to use PyStan with a model which studied coaching effects across eight schools (see Section 5.5 of Gelman et al (2003)). This hierarchical model is often called the “eight schools” model.

import stan

schools_code = """
data {
  int<lower=0> J;         // number of schools
  real y[J];              // estimated treatment effects
  real<lower=0> sigma[J]; // standard error of effect estimates
}
parameters {
  real mu;                // population treatment effect
  real<lower=0> tau;      // standard deviation in treatment effects
  vector[J] eta;          // unscaled deviation from mu by school
}
transformed parameters {
  vector[J] theta = mu + tau * eta;        // school treatment effects
}
model {
  target += normal_lpdf(eta | 0, 1);       // prior log-density
  target += normal_lpdf(y | theta, sigma); // log-likelihood
}
"""

schools_data = {"J": 8,
                "y": [28,  8, -3,  7, -1,  1, 18, 12],
                "sigma": [15, 10, 16, 11,  9, 11, 10, 18]}

posterior = stan.build(schools_code, data=schools_data)
fit = posterior.sample(num_chains=4, num_samples=1000)
eta = fit["eta"]  # array with shape (8, 4000)
df = fit.to_frame()  # pandas `DataFrame`

Project details


Release history Release notifications | RSS feed

Download files

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

Source Distribution

pystan-3.0.0b7.tar.gz (12.0 kB view details)

Uploaded Source

Built Distribution

pystan-3.0.0b7-py3-none-any.whl (11.6 kB view details)

Uploaded Python 3

File details

Details for the file pystan-3.0.0b7.tar.gz.

File metadata

  • Download URL: pystan-3.0.0b7.tar.gz
  • Upload date:
  • Size: 12.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.0.10 CPython/3.9.1 Linux/5.4.0-1036-azure

File hashes

Hashes for pystan-3.0.0b7.tar.gz
Algorithm Hash digest
SHA256 1e29e88cd06188188f88e7bdc204ef0b4cd5bb36c9d3c70a6bceb592d73a2b49
MD5 ca9b0bd820d93c97b29cdfa7025b5cb9
BLAKE2b-256 cbae9a65d3675055d77cfeba2e4f8a8b3261c4bd587d923d3c5f372c46ba76f6

See more details on using hashes here.

File details

Details for the file pystan-3.0.0b7-py3-none-any.whl.

File metadata

  • Download URL: pystan-3.0.0b7-py3-none-any.whl
  • Upload date:
  • Size: 11.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.0.10 CPython/3.9.1 Linux/5.4.0-1036-azure

File hashes

Hashes for pystan-3.0.0b7-py3-none-any.whl
Algorithm Hash digest
SHA256 0cfaa12bcaa95bb27fe4b9d37f3d1ebc64aaf153b9e7e98a42f7008d4d8248ce
MD5 a73ed049b9928bd3f92526cbfbd2c07c
BLAKE2b-256 caaad2f8472126279a5847ef48e5bd87bda9bca5687cc01c67b437c21a603123

See more details on using hashes here.

Supported by

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