AnabelSMRuggiero / sbmltoodepy

A tool for creating Python implementations of SBML models.
BSD 3-Clause "New" or "Revised" License
13 stars 4 forks source link

SBMLtoODEpy

DOI status

Overview

SBMLtoODEpy is a software package that converts Systems Biology Markup Language (SBML) models into Python classes that can be rapidly incorporated into biomedical systems modeling projects written in Python, such as the multiscale simulation platform CompuCell3D, or used simulated directly as ordinary equations models in Python.

Authors

Steve M. Ruggiero and Ashlee N. Ford Versypt (ashleefv@okstate.edu), School of Chemical Engineering, Oklahoma State University

Usage

The simplest use of this package is to use the ParseAndGenerate function to quickly create a python implementation of an SBML model.

import sbmltoodepy
ParseAndCreateModel(inputFilePath, jsonFilePath = None, outputFilePath = None, className = "SBMLmodel")

The parameters are:

This creates a new python file containing a class implementing the SBML model.

To run the model, instantiate the class and call the RunSimulation method with the desired timestep deltaT and optional specification of tolerances.

model = SBMLmodel()
model.RunSimulation(deltaT, absoluteTolerance = 1e-12, relativeTolerance = 1e-6)

Installation Instructions

SBMLtoODEpy requires either Python version 3.5, 3.6, or 3.7. SBMLtoODEpy can be downloaded using pip:

pip install sbmltoodepy

Alternatively, SBMLtoODEpy can be installed from its source code by running the setup.py file included.

python setup.py install

To test the package, use the TestPackage function.

import sbmltoodepy
sbmltoodepy.utilities.TestPackage()

The TestPackage function raises a warning about trying to set a constant species and 6 numbers.

1.27949533562e-06

9.42747177955e-10

1.33080766722e-07

9.79758065656e-08

4.05696056523e-07

2.66117319017e-05

These are the average relative errors for species, parameters, and compartments between the model results generated using SBMLtoODEpy and results calculated by COPASI for six different models provided in the sbmltoodepy/sbml_files subdirectory: Smallbone2013, Borisov2009, Guyton1972, Kerkhoven2013, Waugh2006, and Zi2011, respectively. These examples are discussed in more detail in the tutorial.

Supporting Python packages

The following Python packages were used in this project and are needed to generate and run python models:

Links

For more information on using this package, click here to see the tutorial.

For more information on SBML, including specifications and other software that supports SBML, click here for the SBML web site

For a good source of SBML models, the BioModels repository is a great place to search.

For this project's code documentation, click here.

For this project's github repository, click here.

Acknowledgments

The software package described here was made possible in part by funding through the award for project number HR17-057, from the Oklahoma Center for the Advancement of Science and Technology.

Community Guidelines

To contribute a change, users can contact Ashlee Ford Versypt by email ashleefv@okstate.edu or submit a pull request.