LibSBML
LibSBML is an open-source software library that provides an application programming interface (API) for the SBML (Systems Biology Markup Language [1][2][3]) format. The libSBML library can be embedded in a software application or used in a web servlet (such as one that might be served by Apache Tomcat) as part of the application or servlet's implementation of support for reading, writing, and manipulating SBML documents and data streams. The core of libSBML is written in ISO standard C++; the library provides API for many programming languages via interfaces generated with the help of SWIG. The libSBML library is free software released under the terms of the GNU Lesser General Public License as published by the Free Software Foundation; either version 2.1 of the License, or any later version. LibSBML was developed thanks to funding from many agencies, particularly the National Institute of General Medical Sciences (NIGMS, USA) as well as the Defense Advanced Research Projects Agency (DARPA, USA) under the Bio-SPICE program. DescriptionThe Systems Biology Markup Language (SBML) is an XML-based format for encoding computational models of a sort common in systems biology. Although SBML is based upon XML, and thus software developers could support SBML using off-the-shelf XML parser libraries, libSBML offers numerous advantages that make it easier for developers to implement support for SBML in their software. The premise behind the development of libSBML is that it is more convenient and efficient for developers to start with a higher-level API tailored specifically to SBML and its distinctive features than it is to start with a plain XML parser library. Significant features of libSBMLThe following is a partial list of libSBML's features:
Manipulation of mathematical formulasSome further explanations may be warranted concerning libSBML's support for working with mathematical formulas. In SBML Level 1, mathematical formulas are represented as text strings using a C-like syntax. This representation was chosen because of its simplicity, widespread familiarity and use in applications such as GEPASI[4] and Jarnac,[5] whose authors contributed to the initial design of SBML. In SBML Levels 2 and 3, there was a need to expand the mathematical vocabulary of Level 1 to include additional functions (both built-in and user-defined), mathematical constants, logical operators, relational operators and a special symbol to represent time. Rather than growing the simple C-like syntax into something more complicated and esoteric in order to support these features, and consequently having to manage two standards in two different formats (XML and text string formulas), SBML Levels 2 and 3 leverage an existing standard for expressing mathematical formulas, namely the content portion of MathML. As mentioned above, LibSBML provides an abstraction for working with mathematical expressions in both text-string and MathML form: Abstract Syntax Trees (ASTs). Abstract Syntax Trees are well known in the computer science community; they are simple recursive data structures useful for representing the syntactic structure of sentences in certain kinds of languages (mathematical or otherwise). Much as libSBML allows programmers to manipulate SBML at the level of domain-specific objects, regardless of SBML Level or version, it also allows programmers to work with mathematical formula at the level of ASTs regardless of whether the original format was C-like infix or MathML. LibSBML goes one step further by allowing programmers to work exclusively with infix formula strings and instantly convert them to the appropriate MathML whenever needed. DependenciesLibSBML requires a separate library to do low-level read/write operations on XML. It can use any one of three XML parser libraries: Xerces, expat or libxml2. Users can specify which library they wish to use at libSBML compilation time. LibSBML hides the differences between these parser libraries behind an abstraction layer; it seamlessly uses whichever library against which a given instance of libSBML has been compiled. (However, released binary distributions of libSBML all make use of the libxml2 library.) UsageLibSBML uses software objects (i.e., instances of classes) that correspond to SBML components, with member variables representing the attributes of the corresponding SBML objects. The libSBML API is constructed to provide an intuitive way of relating SBML and the code needed to create or manipulate it with a class hierarchy that mimics the SBML structure. More information about the libSBML objects is available in the libSBML API documentation. Reading and writing SBMLLibSBML enables reading from and writing to either files or strings. Once an SBML document is read, libSBML stores the SBML content in an SBMLDocument object. This object can be written out again later. The following is an example written in Python: >>> import libsbml
>>>
>>> # read a document
>>> doc = libsbml.readSBMLFromFile(filename)
>>> doc = libsbml.readSBMLFromString(string)
>>>
>>> # helper function that takes either a string
>>> # or filename as argument
>>> doc = libsbml.readSBML(filename)
>>> doc = libsbml.readSBML(string)
>>>
>>> # write a document
>>> libsbml.writeSBMLToFile(doc, filename)
True
>>>
>>> libsbml.writeSBMLToString(doc)
'<?xml version="1.0" encoding="UTF-8"?>\n
<sbml xmlns="http://www.sbml.org/sbml/level3/version1/core"
level="3" version="1">\n
<model/>\n
</sbml>\n'
Creating and manipulating SBMLThe libSBML API allows easy creation of objects and subobjects representing SBML elements and the subelements contained within them. The following is an example written in C++: void createSBML()
{
// create an SBML Level 3 Version 1 document
SBMLDocument* doc = new SBMLDocument(3, 1);
// create the model as a sub element of the document
Model * model = doc->createModel();
// create a compartment as a sub element of the model
Compartment * compartment1 = model->createCompartment();
// create an independent compartment and then add it to the model
Compartment * compartment2 = new Compartment(3, 1);
model->addCompartment(compartment2);
}
Accessing attributesEach component in SBML has a number of attributes associated with it. These are stored as member variables of a given class, and libSBML provides functions to retrieve and query these values. The syntax of these functions is consistent throughout libSBML. The following is an example written in Python: >>> import libsbml
>>>
>>> # create an SBML Level 3 Version 1 document
>>> sbmlns = libsbml.SBMLNamespaces(3, 1)
>>> doc = libsbml.SBMLDocument(sbmlns)
>>>
>>> #create the model as a sub element of the document
>>> model = doc.createModel()
>>>
>>> #create a compartment as a sub element of the model
>>> compartment = model.createCompartment()
>>>
>>> # set the attributes on the compartment
>>> # note a return value of 0 indicates success
>>> compartment.setId("cell")
0
>>> compartment.setSize(2.3)
0
>>> compartment.setSpatialDimensions(3)
0
>>> compartment.setUnits("litre")
0
>>> compartment.setConstant(True)
0
>>>
>>> # get the attribute values
>>> compartment.getId()
'cell'
>>> compartment.getSpatialDimensions()
3
>>>
>>> # examine the status of the attribute
>>> compartment.isSetSize()
True
>>> compartment.getSize()
2.3
>>>
>>> #unset an attribute value
>>> compartment.unsetSize()
0
>>> compartment.isSetSize()
False
>>> compartment.getSize()
nan
See also
References
External links |