Skip to content

Latest commit

 

History

History
64 lines (43 loc) · 4.09 KB

README.md

File metadata and controls

64 lines (43 loc) · 4.09 KB

Heta project GitHub release GitHub issues DOI:10.13140/RG.2.2.18935.06563 License: CC BY-ND 4.0

See more information on the Heta project page.

Heta language is a domain-specific programming language (DSL) for dynamic quantitative models used in quantitative systems pharmacology (QSP) and systems biology (SB). It describes the biological systems as the components of QSP/SB modeling platform.

The Heta language represents the dynamic model as a set of interacting components describing volumes, concentrations, amounts, rates, and others. You don't need to writing an ODE system manually. The differential equations are compiled "on the fly" where they are required.

The key idea of Heta language is the development and editing of the bio-mathematical models as expressive programming code which gives us the benefits of programming languages: compact and human-readable format, modularity, reusability, etc. The model development can be easily organized as a workflow inside a group. The Heta code is friendly for version control systems and different continuous integration and delivery (CI/CD) tools can be used to reach maximal productivity.

The important pre-formulated requirements to the language were:

  • Human-readable/writable code can be used for model creation, modification, or integration.
  • Easy code parsing and transformation for potential implementation into different tools and frameworks.
  • Modularity: QSP platform can be sub-divided into several files and spaces for better project management.
  • Polymorphism of code: code can be presented in different formats with the same meaning.
  • Reusability: modeling platforms should be easily extended. Model parts and datasets can be used for other models and applications.
  • Reach annotation capabilities for better code revision and reporting.
  • The easy transformation from/to different formats of platforms and models currently used in practice: SBML, DBSolve, tables, databases, mrgsolve, Simbiology, etc.

"Hello world!" example

The example describes a simple model with two species and one mass-action law reaction.

// Hello world! example
comp1 @Compartment;
A @Species { compartment: comp1 };
B @Species { compartment: comp1 };
r1 @Reaction { actors: A -> 2B };

comp1 .= 1;
A .= 10;
B .= 0;
r1 := k1*A*comp1;
k1 @Const = 0.01;

See more examples on Cases page.

Origin

Heta language was originally developed for internal projects of InSysBio to support the development of large-scale QSP modeling platforms and storing them in database-like formats.

Maintainers

  • Evgeny Metelkin

Versions

The latest version of Heta standard is located in master branch of the hetalang/heta-specifications repository.

The published versions are stored as tags in the repository.

Heta specifications versions follow Semantic Versioning standard. While the Heta standard is still under active development the MAJOR number is 0 and will not be changed before publishing the stable release. Each substantial change in Heta syntax or interpretation will update the MINOR number. The PATCH number means update in the format description without rules changes.

License

The Heta language specifications are licensed under Creative Commons Attribution-NoDerivatives 4.0 International License.

InSysBio, 2018-2024