The eulerian parameter inference (eulerpi) returns a parameter distribution, which is consistent with the observed data by solving the inverse problem directly. In the case of a one-to-one mapping, this is the true underlying distribution.
Project description
Euler Parameter Inference (EPI) is a Python package for inverse parameter inference. It provides an implementation of the EPI algorithm, which takes observed data and a model as input and returns a parameter distribution consistent with the observed data by solving the inverse problem directly. In the case of a one-to-one mapping, this is the true underlying distribution.
Documentation
The full documentation to this software, including a detailed tutorial on how to use EPI and the api documentation, can be found under Documentation.
Features
EPI supports
- SBML ode models
- User provided models
- Models with automatic differentation using jax
Installation
The package is available on pypi and can be installed with:
pip install eulerpi
Make sure that you have the following C++ libraries installed
sudo apt install -y swig libblas-dev libatlas-base-dev libhdf5-dev
You can also build the library from the latest source code by following the Development Quickstart Guide.
Using the library
To use EPI, derive your model from the Model
class and implement the abstract functions. Here's an example code snippet:
# my_model.py
import jax.numpy as jnp
from eulerpi.core.model import Model
class MyModel(Model):
param_dim = N # The dimension of a parameter point
data_dim = M # The dimension of a data point
def forward(self, param):
return jnp.array(...)
def jacobian(self, param):
return jnp.array(...)
To evaluate the model and infer the parameter distribution, call:
from eulerpi.sampling import inference
from my_model import MyModel
central_param = np.array([0.5, -1.5, ...])
param_limits = np.array([[0.0, 1.0], [-3.0, 0.0], ...])
model = MyModel(central_param, param_limits)
inference(model=model, data="my_data.csv")
The data
argument can be a numpy-2d-array or a PathLike object that points to a CSV file. In the example shown above, the CSV file my_data.csv
should contain the data in the following format:
datapoint_dim1, datapoint_dim2, datapoint_dim3, ..., datapoint_dimN
datapoint_dim1, datapoint_dim2, datapoint_dim3, ..., datapoint_dimN
datapoint_dim1, datapoint_dim2, datapoint_dim3, ..., datapoint_dimN
...
datapoint_dim1, datapoint_dim2, datapoint_dim3, ..., datapoint_dimN
This corresponds to a matrix with the shape nSamples x data_dim
. For more available options and parameters for the inference
method, please refer to the api documentation. Note that the inference can be done with grid-based methods (dense grids, sparse grids) or sampling methods (mcmc).
The results are stored in the following location:
./Applications/<ModelName>/.../OverallParams.csv
./Applications/<ModelName>/.../OverallSimResults.csv
./Applications/<ModelName>/.../OverallDensityEvals.csv
These files contain the sampled parameters, the corresponding data points obtained from the model forward pass, and the corresponding density evaluation.
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
Built Distribution
File details
Details for the file eulerpi-0.3.0.tar.gz
.
File metadata
- Download URL: eulerpi-0.3.0.tar.gz
- Upload date:
- Size: 129.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.4.2 CPython/3.10.11 Linux/5.15.0-1036-azure
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | bd183fe914d8545cf7b8db8e76c317236df93d5ac30900e3adc9b2421dd04626 |
|
MD5 | 5a84256ae7b037b260fa7426baad54ee |
|
BLAKE2b-256 | 31f6d6074fb5303749df736de951cc9730e3d3e730d4014704c5590ff298d6ce |
Provenance
File details
Details for the file eulerpi-0.3.0-py3-none-any.whl
.
File metadata
- Download URL: eulerpi-0.3.0-py3-none-any.whl
- Upload date:
- Size: 137.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.4.2 CPython/3.10.11 Linux/5.15.0-1036-azure
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | dcc6cb70235133cbb3fd2741160c5ad79ee9fb71d2f5c949f6140d393d12ab8e |
|
MD5 | 1f51284ab0110555446a77e81fe6d0ac |
|
BLAKE2b-256 | f0f2b5bea04eab42f92c1eaf8e84f3d52f8e02df709b07cebccade6d2fc77a99 |