Skip to main content

Python interface to CmdStan

Project description

CmdStanPy

codecov

CmdStanPy is a lightweight pure-Python interface to CmdStan which provides access to the Stan compiler and all inference algorithms. It supports both development and production workflows. Because model development and testing may require many iterations, the defaults favor development mode and therefore output files are stored on a temporary filesystem. Non-default options allow all aspects of a run to be specified so that scripts can be used to distributed analysis jobs across nodes and machines.

CmdStanPy is distributed via PyPi: https://pypi.org/project/cmdstanpy/

or Conda Forge: https://anaconda.org/conda-forge/cmdstanpy

Goals

  • Clean interface to Stan services so that CmdStanPy can keep up with Stan releases.

  • Provide access to all CmdStan inference methods.

  • Easy to install,

    • minimal Python library dependencies: numpy, pandas
    • Python code doesn't interface directly with c++, only calls compiled executables
  • Modular - CmdStanPy produces a MCMC sample (or point estimate) from the posterior; other packages do analysis and visualization.

  • Low memory overhead - by default, minimal memory used above that required by CmdStanPy; objects run CmdStan programs and track CmdStan input and output files.

Source Repository

CmdStanPy and CmdStan are available from GitHub: https://github.com/stan-dev/cmdstanpy and https://github.com/stan-dev/cmdstan

Docs

The latest release documentation is hosted on https://mc-stan.org/cmdstanpy, older release versions are available from readthedocs: https://cmdstanpy.readthedocs.io

Licensing

The CmdStanPy, CmdStan, and the core Stan C++ code are licensed under new BSD.

Example

import os
from cmdstanpy import cmdstan_path, CmdStanModel

# specify locations of Stan program file and data
stan_file = os.path.join(cmdstan_path(), 'examples', 'bernoulli', 'bernoulli.stan')
data_file = os.path.join(cmdstan_path(), 'examples', 'bernoulli', 'bernoulli.data.json')

# instantiate a model; compiles the Stan program by default
model = CmdStanModel(stan_file=stan_file)

# obtain a posterior sample from the model conditioned on the data
fit = model.sample(chains=4, data=data_file)

# summarize the results (wraps CmdStan `bin/stansummary`):
fit.summary()

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

cmdstanpy-1.3.0.tar.gz (122.9 kB view details)

Uploaded Source

Built Distribution

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

cmdstanpy-1.3.0-py3-none-any.whl (99.1 kB view details)

Uploaded Python 3

File details

Details for the file cmdstanpy-1.3.0.tar.gz.

File metadata

  • Download URL: cmdstanpy-1.3.0.tar.gz
  • Upload date:
  • Size: 122.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for cmdstanpy-1.3.0.tar.gz
Algorithm Hash digest
SHA256 60b10d110993bd8345735994786b2b17782fdc5530a6adbc0cd8ec836d82c2b9
MD5 9717dea50e35fbd57e6162294862df89
BLAKE2b-256 400acc5cbec39155e5ab76b96cbb1acd23bd7f19a4e2203fdf9948a7cbec65b8

See more details on using hashes here.

Provenance

The following attestation bundles were made for cmdstanpy-1.3.0.tar.gz:

Publisher: release.yml on stan-dev/cmdstanpy

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file cmdstanpy-1.3.0-py3-none-any.whl.

File metadata

  • Download URL: cmdstanpy-1.3.0-py3-none-any.whl
  • Upload date:
  • Size: 99.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for cmdstanpy-1.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 67d83fbb823948c3ca8a84912359d6c0a5c616a62025526dba5f43a1d970bc52
MD5 645e5f43a16e1a9a8edd7b6dc3a0cbde
BLAKE2b-256 ef047bbe85aa6abf99236cc657ceb5a629f63a82a01910a095533111ea3860f3

See more details on using hashes here.

Provenance

The following attestation bundles were made for cmdstanpy-1.3.0-py3-none-any.whl:

Publisher: release.yml on stan-dev/cmdstanpy

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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