# SBML2HYB
## Overview
Hybrid modelling combine parametric functions (derived from knowledge) and nonparametric functions (derived from data) in the same model structure.
The sbml2hyb tool is an stand-alone executable application for [SBML](https://synonym.caltech.edu/) compatible hybrid modelling. The tool is written in Python and is intended as an interface to convert existing SBML models into a hybrid model (combines mechanistic equations and ML techniques).
The new internal hybrid model format HMOD (intermediate format — enables communication between the essential components of the mechanistic and hybrid models) can be translated to SBML and vice-versa in sbml2hyb. See [HMOD](https://github.com/rs-costa/sbml2hyb/raw/main/models/chassagnole1standard.hmod) file example.
[![DOI](https://zenodo.org/badge/DOI/10.5281/zenodo.7293206.svg)](https://doi.org/10.5281/zenodo.7293206) [![Code style: black](https://img.shields.io/badge/code%20style-black-000000.svg)](https://github.com/psf/black) [![Documentation Status](https://readthedocs.org/projects/sbml2hyb/badge/?version=latest)](https://sbml2hyb.readthedocs.io/en/latest/?badge=latest) [![License: GPL v3](https://img.shields.io/badge/License-GPLv3-blue.svg)](https://www.gnu.org/licenses/gpl-3.0) [![PyPI version](https://badge.fury.io/py/sbml2hyb.svg)](https://badge.fury.io/py/sbml2hyb)
## Quick start guide
### Installation
- Users have two options to install sbml2hyb:
(i) As a typical stand-alone executable Windows application; download the [files](https://figshare.com/ndownloader/files/38688132). After saving the Windows folder where you prefer on your computer, double-click the executable (`sbml2hyb_exe.exe`) file to open the tool. It works also on [macOS](https://figshare.com/ndownloader/files/38688432) system.
(ii) As a Python package (pip installer); run the following command via `pip`:
`pip install sbml2hyb`
- sbml2hyb is written in Python (requires version 3.8 or higher).
- Alternatively, you can clone this GitHub repository to a location on your computer's file system and then run `sbml2hyb.py` from the command-line.
After installing the package the user can simply import the library and call it. This is an example on how to use:
from sbml2hyb import sbml2hyb
### Package Dependencies
- tkinter 3.10.7
- Pillow 9.0
- libsbml 5.19.6
- Python 3.8.2
- Tensorflow 2.10.0
### Getting Started
#### ► How to use SBML2HYB
The users can use sbml2hyb either via the command line interface or via a graphical user interface (GUI) that allows to convert SBML files into HMOD files and vice versa.
Once the simple Graphical User Interface (GUI) window opens, click the *"Translate SBML file"* or *"Translate HMOD file"* button, to find the SBML or HMOD mechanistic model file you want to convert on the tool, respectively. After few seconds, the user get the final output in the main panel of the GUI. Here, the user can save (click *"Save file"* button) the standard model file (.xml or .hmod).
The user can then add the information of the neural network component (Click *"Add ML"* button) into the HMOD/SBML model format (note that first the user needs to load a mechanistic HMOD/SBML model file). Once the user do this, they need select the *"inputs"* and *"outputs"* options of the neural network, and the Keras H5 file (i.e., add the ML component information). Click the *"Confirm"* button. Finally, the resulting hybrid model in HMOD (or SBML) format can then be reconverted in SBML (or HMOD), respectively. Click *"Translate HMOD file"* or *"Translate SBML file"* button.
NOTE: To generate an Keras H5 file that serves as a blueprint of the machine learning segment of a hybrid model, the Keras library from Tensorflow should be used (see [instructions](https://github.com/r-costa/sbml2hyb/raw/main/createH5_instructions.txt) and an example as [notebook](https://github.com/rs-costa/sbml2hyb/raw/main/models/keras_H5/create_keras_h5.ipynb)).
Visit also the documentation of the tool hosted on [Read the Docs](https://sbml2hyb.readthedocs.io/en/latest/index.html#).
#### ► Creating a hybrid SBML model
Example: *Park&Ramirez* model
You can view the mechanistic model SBML file input for this example in a [separate file](https://github.com/rs-costa/sbml2hyb/raw/main/models/parkramstandard.xml). The screenshot below (Figure 1) illustrates the output of the *Park&Ramirez* [mechanistic HMOD model](https://github.com/r-costa/sbml2hyb/raw/main/models/parkramstandard.hmod) after the SBML conversion. The user select then the model *"inputs"* (*S*) and *"outputs"* (*miu*, *vPM*, *VPT*) options of the neural network, and the [Keras H5 file](https://github.com/r-costa/sbml2hyb/raw/main/models/Park_Keras.h5) (Figure 2) to convert directly to the hybrid model. You can view the resulting final hybrid HMOD file from the tool [here](https://github.com/rs-costa/sbml2hyb/raw/main/models/parkramhyb.hmod) and printscreens below (Figure 3). The hybrid model in HMOD format is then reconverted in the [hybrid SBML model](https://github.com/rs-costa/sbml2hyb/raw/main/models/parkramhyb.xml).
<div align="center"> Figure 1. </div>
![alt text](https://github.com/rs-costa/sbml2hyb/raw/main/img/Figure1.PNG)
<div align="center"> Figure 2. </div>
![alt text](https://github.com/rs-costa/sbml2hyb/raw/main/img/Figure2.PNG)
<div align="center"> Figure 3. </div>
![alt text](https://github.com/rs-costa/sbml2hyb/raw/main/img/Figure_3.png)
## Developed at
- NOVA School of Science and Technology, Universidade NOVA de Lisboa (since 2021)
![alt text](https://github.com/rs-costa/sbml2hyb/raw/main/img/logo_new.png)
## Help
If you have any trouble using the tool or suggestions, please contact: rs [dot] costa [at] fct [dot] unl [dot] pt OR open an [issue](https://github.com/r-costa/sbml2hyb/issues).
## License
This work is licensed under a <a href="https://www.gnu.org/licenses/gpl-3.0.html"> GNU Public License (version 3.0).</a>
Raw data
{
"_id": null,
"home_page": "https://github.com/r-costa/sbml2hyb",
"name": "sbml2hyb",
"maintainer": "",
"docs_url": null,
"requires_python": "",
"maintainer_email": "",
"keywords": "python,converter,gui,neural-network,interface,systems-biology,hybrid-model,keras-tensorflow,sbml-model",
"author": "Rafael Costa",
"author_email": "rs.costa@fct.unl.pt",
"download_url": "https://files.pythonhosted.org/packages/3a/bc/337b6245e453e6c2e5e88cff2b4da25edb0f31a82d769a93f28ff4534653/sbml2hyb-1.0.3.tar.gz",
"platform": null,
"description": "# SBML2HYB\r\n## Overview\r\nHybrid modelling combine parametric functions (derived from knowledge) and nonparametric functions (derived from data) in the same model structure.\r\nThe sbml2hyb tool is an stand-alone executable application for [SBML](https://synonym.caltech.edu/) compatible hybrid modelling. The tool is written in Python and is intended as an interface to convert existing SBML models into a hybrid model (combines mechanistic equations and ML techniques).\r\n\r\nThe new internal hybrid model format HMOD (intermediate format \u2014 enables communication between the essential components of the mechanistic and hybrid models) can be translated to SBML and vice-versa in sbml2hyb. See [HMOD](https://github.com/rs-costa/sbml2hyb/raw/main/models/chassagnole1standard.hmod) file example.\r\n\r\n[![DOI](https://zenodo.org/badge/DOI/10.5281/zenodo.7293206.svg)](https://doi.org/10.5281/zenodo.7293206) [![Code style: black](https://img.shields.io/badge/code%20style-black-000000.svg)](https://github.com/psf/black) [![Documentation Status](https://readthedocs.org/projects/sbml2hyb/badge/?version=latest)](https://sbml2hyb.readthedocs.io/en/latest/?badge=latest) [![License: GPL v3](https://img.shields.io/badge/License-GPLv3-blue.svg)](https://www.gnu.org/licenses/gpl-3.0) [![PyPI version](https://badge.fury.io/py/sbml2hyb.svg)](https://badge.fury.io/py/sbml2hyb)\r\n\r\n## Quick start guide\r\n### Installation\r\n- Users have two options to install sbml2hyb:\r\n\r\n(i) As a typical stand-alone executable Windows application; download the [files](https://figshare.com/ndownloader/files/38688132). After saving the Windows folder where you prefer on your computer, double-click the executable (`sbml2hyb_exe.exe`) file to open the tool. It works also on [macOS](https://figshare.com/ndownloader/files/38688432) system. \r\n\r\n(ii) As a Python package (pip installer); run the following command via `pip`:\r\n`pip install sbml2hyb`\r\n- sbml2hyb is written in Python (requires version 3.8 or higher).\r\n- Alternatively, you can clone this GitHub repository to a location on your computer's file system and then run `sbml2hyb.py` from the command-line.\r\n\r\nAfter installing the package the user can simply import the library and call it. This is an example on how to use:\r\n\r\n from sbml2hyb import sbml2hyb\r\n\r\n### Package Dependencies\r\n- tkinter 3.10.7 \r\n- Pillow 9.0 \r\n- libsbml 5.19.6 \r\n- Python 3.8.2\r\n- Tensorflow 2.10.0\r\n\r\n### Getting Started\r\n#### \u25ba How to use SBML2HYB\r\n\r\nThe users can use sbml2hyb either via the command line interface or via a graphical user interface (GUI) that allows to convert SBML files into HMOD files and vice versa. \r\nOnce the simple Graphical User Interface (GUI) window opens, click the *\"Translate SBML file\"* or *\"Translate HMOD file\"* button, to find the SBML or HMOD mechanistic model file you want to convert on the tool, respectively. After few seconds, the user get the final output in the main panel of the GUI. Here, the user can save (click *\"Save file\"* button) the standard model file (.xml or .hmod). \r\n\r\nThe user can then add the information of the neural network component (Click *\"Add ML\"* button) into the HMOD/SBML model format (note that first the user needs to load a mechanistic HMOD/SBML model file). Once the user do this, they need select the *\"inputs\"* and *\"outputs\"* options of the neural network, and the Keras H5 file (i.e., add the ML component information). Click the *\"Confirm\"* button. Finally, the resulting hybrid model in HMOD (or SBML) format can then be reconverted in SBML (or HMOD), respectively. Click *\"Translate HMOD file\"* or *\"Translate SBML file\"* button. \r\n\r\nNOTE: To generate an Keras H5 file that serves as a blueprint of the machine learning segment of a hybrid model, the Keras library from Tensorflow should be used (see [instructions](https://github.com/r-costa/sbml2hyb/raw/main/createH5_instructions.txt) and an example as [notebook](https://github.com/rs-costa/sbml2hyb/raw/main/models/keras_H5/create_keras_h5.ipynb)).\r\n\r\nVisit also the documentation of the tool hosted on [Read the Docs](https://sbml2hyb.readthedocs.io/en/latest/index.html#).\r\n\r\n#### \u25ba Creating a hybrid SBML model\r\n\r\nExample: *Park&Ramirez* model\r\n\r\nYou can view the mechanistic model SBML file input for this example in a [separate file](https://github.com/rs-costa/sbml2hyb/raw/main/models/parkramstandard.xml). The screenshot below (Figure 1) illustrates the output of the *Park&Ramirez* [mechanistic HMOD model](https://github.com/r-costa/sbml2hyb/raw/main/models/parkramstandard.hmod) after the SBML conversion. The user select then the model *\"inputs\"* (*S*) and *\"outputs\"* (*miu*, *vPM*, *VPT*) options of the neural network, and the [Keras H5 file](https://github.com/r-costa/sbml2hyb/raw/main/models/Park_Keras.h5) (Figure 2) to convert directly to the hybrid model. You can view the resulting final hybrid HMOD file from the tool [here](https://github.com/rs-costa/sbml2hyb/raw/main/models/parkramhyb.hmod) and printscreens below (Figure 3). The hybrid model in HMOD format is then reconverted in the [hybrid SBML model](https://github.com/rs-costa/sbml2hyb/raw/main/models/parkramhyb.xml). \r\n\r\n<div align=\"center\"> Figure 1. </div>\r\n\r\n![alt text](https://github.com/rs-costa/sbml2hyb/raw/main/img/Figure1.PNG)\r\n\r\n<div align=\"center\"> Figure 2. </div>\r\n\r\n![alt text](https://github.com/rs-costa/sbml2hyb/raw/main/img/Figure2.PNG)\r\n\r\n<div align=\"center\"> Figure 3. </div>\r\n\r\n![alt text](https://github.com/rs-costa/sbml2hyb/raw/main/img/Figure_3.png)\r\n\r\n## Developed at\r\n- NOVA School of Science and Technology, Universidade NOVA de Lisboa (since 2021)\r\n\r\n![alt text](https://github.com/rs-costa/sbml2hyb/raw/main/img/logo_new.png)\r\n\r\n## Help\r\nIf you have any trouble using the tool or suggestions, please contact: rs [dot] costa [at] fct [dot] unl [dot] pt OR open an [issue](https://github.com/r-costa/sbml2hyb/issues).\r\n\r\n## License\r\nThis work is licensed under a <a href=\"https://www.gnu.org/licenses/gpl-3.0.html\"> GNU Public License (version 3.0).</a>\r\n",
"bugtrack_url": null,
"license": "",
"summary": "sbml2hyb is a Pyton tool for SBML compatible hybrid modelling.",
"version": "1.0.3",
"split_keywords": [
"python",
"converter",
"gui",
"neural-network",
"interface",
"systems-biology",
"hybrid-model",
"keras-tensorflow",
"sbml-model"
],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "95538bcda860e1cec789f9a5077e55c7b1b9bf20e6aac6bc251a7b31dc3455ff",
"md5": "7da65bede63dc902acda651a429c1021",
"sha256": "d45f1dfe39ec8adacbc041d2a29b8d7d4d37d6efabff612a4a89e2e8677c700e"
},
"downloads": -1,
"filename": "sbml2hyb-1.0.3-py3-none-any.whl",
"has_sig": false,
"md5_digest": "7da65bede63dc902acda651a429c1021",
"packagetype": "bdist_wheel",
"python_version": "py3",
"requires_python": null,
"size": 136724,
"upload_time": "2023-01-03T10:31:31",
"upload_time_iso_8601": "2023-01-03T10:31:31.303546Z",
"url": "https://files.pythonhosted.org/packages/95/53/8bcda860e1cec789f9a5077e55c7b1b9bf20e6aac6bc251a7b31dc3455ff/sbml2hyb-1.0.3-py3-none-any.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "3abc337b6245e453e6c2e5e88cff2b4da25edb0f31a82d769a93f28ff4534653",
"md5": "c5c2fa583006b56266f1286731b4eebd",
"sha256": "4c6c25daa279ee8cf3504e0c0f397975f5307b9a823624fe8ec9a4ddbb4f619c"
},
"downloads": -1,
"filename": "sbml2hyb-1.0.3.tar.gz",
"has_sig": false,
"md5_digest": "c5c2fa583006b56266f1286731b4eebd",
"packagetype": "sdist",
"python_version": "source",
"requires_python": null,
"size": 138322,
"upload_time": "2023-01-03T10:31:33",
"upload_time_iso_8601": "2023-01-03T10:31:33.455732Z",
"url": "https://files.pythonhosted.org/packages/3a/bc/337b6245e453e6c2e5e88cff2b4da25edb0f31a82d769a93f28ff4534653/sbml2hyb-1.0.3.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2023-01-03 10:31:33",
"github": true,
"gitlab": false,
"bitbucket": false,
"github_user": "r-costa",
"github_project": "sbml2hyb",
"travis_ci": false,
"coveralls": false,
"github_actions": false,
"lcname": "sbml2hyb"
}