Skip to main content

Python+JAX code relating to the textbook, Stochastic modelling for systems biology, third edition

Project description

JAX-SMfSB (jsmfsb)

Code style: black

SMfSB code in Python+JAX

Python code relating to the book Stochastic Modelling for Systems Biology, third edition.

There is a regular Python+Numpy package on PyPI, smfsb, which has complete coverage of the book. If you are new to the book and/or this codebase, that might be a simpler place to start.

This package covers all of the core simulation and inference algorithms from the book, including the parsing of SBML and SBML-shorthand models. These core algorithms will run very fast, using JAX. Computationally intensive algorithms will typically run between 50 and 150 times faster than they would using the regular smfsb package, even without a GPU (but YMMV). You must install JAX (which is system dependent), before attempting to install this package. See the JAX documentation for details, but for a CPU-only installation, it should be as simple as pip install jax.

Once you have JAX installed and working correctly, you can install this package with:

pip install jsmfsb

To upgrade already installed package:

pip install --upgrade jsmfsb

Note that a number of breaking syntax changes (more pythonic names) were introduced in version 1.1.0. If you upgrade to a version >= 1.1.0 from a version prior to 1.1.0 you will have to update syntax to the new style.

You can test that your installation is working by entering the following at a python prompt:

import jax
import jsmfsb

If these both return silently, you are probably good to go.

Documentation

Note that the book, and its associated github repo is the main source of documentation for this library. The code in the book is in R, but the code in this library is supposed to mirror the R code, but in Python.

For an introduction to this library, see the jax-smfsb tutorial.

Converting from the smfsb python package

The API for this package is very similar to that of the smfsb package. The main difference is that non-deterministic (random) functions have an extra argument (typically the first argument) that corresponds to a JAX random number key. See the relevant section of the JAX documentation for further information regarding random numbers in JAX code.

Further information

For further information, see the demo directory and the API documentation. Within the demos directory, see shbuild.py for an example of how to specify a (SEIR epidemic) model using SBML-shorthand and step_cle_2df.py for a 2-d reaction-diffusion simulation. For parameter inference (from time course data), see abc-cal.py for ABC inference, abc_smc.py for ABC-SMC inference and pmmh.py for particle marginal Metropolis-Hastings MCMC-based inference. There are many other demos besides these.

You can view this package on GitHub or PyPI.

Contributing

If you have problems with this software, please start an Issue or a Discussion. Pull requests containing bug fixes are welcome.

Copyright (C) 2024 Darren J Wilkinson

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

jsmfsb-1.1.1.tar.gz (2.3 MB view details)

Uploaded Source

Built Distribution

jsmfsb-1.1.1-py3-none-any.whl (22.6 kB view details)

Uploaded Python 3

File details

Details for the file jsmfsb-1.1.1.tar.gz.

File metadata

  • Download URL: jsmfsb-1.1.1.tar.gz
  • Upload date:
  • Size: 2.3 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.12.3

File hashes

Hashes for jsmfsb-1.1.1.tar.gz
Algorithm Hash digest
SHA256 a90e41a3fa2e2ede80205117adac714b7fc3b8f919d3a65ca04e6ef4bdf06fdf
MD5 e22fb016ff4f2c45fdb548eb3b0650f3
BLAKE2b-256 efdce7a46dd446cb5c4d7398727e7cf15bd430c0a1524c2bbfe039dc75648602

See more details on using hashes here.

File details

Details for the file jsmfsb-1.1.1-py3-none-any.whl.

File metadata

  • Download URL: jsmfsb-1.1.1-py3-none-any.whl
  • Upload date:
  • Size: 22.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.12.3

File hashes

Hashes for jsmfsb-1.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 543275ebf53b2e4dd77e3108fc2e05c7052e0e784b04840c5ec3d8b21aa960f3
MD5 c56cffa7ef446db9bb4ff48ac03c2694
BLAKE2b-256 a73f5ba7637c19402c3ef278242811e7e80e0dab68a90eeea9e378630104b655

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