libSBML Python API  5.18.0
libsbml.SBMLLevelVersionConverter Class Reference
Inheritance diagram for libsbml.SBMLLevelVersionConverter:
[legend]

Detailed Description

Whole-document SBML Level/Version converter.

This class of objects is defined by libSBML only and has no direct equivalent in terms of SBML components. It is a class used in the implementation of extra functionality provided by libSBML.

This SBML converter takes an SBML document having one SBML Level+Version combination, and attempts to convert it to an SBML document having a different Level+Version combination.

This class is also the basis for SBMLDocument.setLevelAndVersion().

Configuration and use of SBMLLevelVersionConverter

SBMLLevelVersionConverter is enabled by creating a ConversionProperties object with the option 'setLevelAndVersion', and passing this properties object to SBMLDocument.convert(). The target SBML Level and Version combination are determined by the value of the SBML namespace set on the ConversionProperties object (using ConversionProperties.setTargetNamespaces()).

In addition, this converter offers the following options:

  • 'strict': If this option has the value True, then the validity of the SBML document will be strictly preserved. This means that SBML validation will be performed, and if the original model is not valid or semantics cannot be preserved in the converted model, then conversion will not be performed. Conversely, if this option is set to False, model conversion will always be performed; if any errors are detected related to altered semantics, the errors will be logged in the usual way (i.e., the error log on the SBMLDocument object).
  • 'addDefaultUnits': By default, a conversion from SBML Level 2 to Level 3 will explicitly add UnitDefinition objects and unit attributes on the Model object to define units that are implicitly defined in SBML Level 2. This is usually desirable because in SBML Level 3, there are no default units and a conversion from Level 2 that did not add unit definitions would actually result in a loss of information. However, some users or software tools may not need or want this, or worse, may be fooled into thinking that libSBML has somehow inferred the proper units for model quantities. (It has not; it merely adds generic predefined units.) This option lets callers control this behavior.

General information about the use of SBML converters

The use of all the converters follows a similar approach. First, one creates a ConversionProperties object and calls ConversionProperties.addOption() on this object with one argument: a text string that identifies the desired converter. (The text string is specific to each converter; consult the documentation for a given converter to find out how it should be enabled.)

Next, for some converters, the caller can optionally set some converter-specific properties using additional calls to ConversionProperties.addOption(). Many converters provide the ability to configure their behavior to some extent; this is realized through the use of properties that offer different options. The default property values for each converter can be interrogated using the method SBMLConverter.getDefaultProperties() on the converter class in question .

Finally, the caller should invoke the method SBMLDocument.convert() with the ConversionProperties object as an argument.

Example of invoking an SBML converter

The following code fragment illustrates an example using SBMLReactionConverter, which is invoked using the option string 'replaceReactions':

1 config = ConversionProperties()
2 if config != None:
3  config.addOption('replaceReactions')

In the case of SBMLReactionConverter, there are no options to affect its behavior, so the next step is simply to invoke the converter on an SBMLDocument object. Continuing the example code:

1 # Assume that the variable 'document' has been set to an SBMLDocument object.
2 status = document.convert(config)
3 if status != LIBSBML_OPERATION_SUCCESS:
4  # Handle error somehow.
5  print('Error: conversion failed due to the following:')
6  document.printErrors()

Here is an example of using a converter that offers an option. The following code invokes SBMLStripPackageConverter to remove the SBML Level 3 Layout package from a model. It sets the name of the package to be removed by adding a value for the option named 'package' defined by that converter:

1 def strip_layout_example(document):
2  config = ConversionProperties()
3  if config != None:
4  config.addOption('stripPackage')
5  config.addOption('package', 'layout')
6  status = document.convert(config)
7  if status != LIBSBML_OPERATION_SUCCESS:
8  # Handle error somehow.
9  print('Error: unable to strip the Layout package.')
10  print('LibSBML returned error: ' + OperationReturnValue_toString(status).strip())
11  else:
12  # Handle error somehow.
13  print('Error: unable to create ConversionProperties object')

Available SBML converters in libSBML

LibSBML provides a number of built-in converters; by convention, their names end in Converter. The following are the built-in converters provided by libSBML 5.18.0:

Public Member Functions

def __init__ (self, args)
 This method has multiple variants; they differ in the arguments they accept. More...
 
def clone (self)
 Creates and returns a deep copy of this SBMLLevelVersionConverter object. More...
 
def convert (self)
 Perform the conversion. More...
 
def getAddDefaultUnits (self)
 Returns the flag indicating whether default units should be added when converting to L3 or not. More...
 
def getDefaultProperties (self)
 Returns the default properties of this converter. More...
 
def getDocument (self, args)
 Returns the SBML document that is the subject of the conversions. More...
 
def getName (self)
 Returns the name of this converter. More...
 
def getProperties (self)
 Returns the current properties in effect for this converter. More...
 
def getTargetLevel (self)
 Returns the target SBML Level for the conversion. More...
 
def getTargetNamespaces (self)
 Returns the target SBML namespaces of the currently set properties. More...
 
def getTargetVersion (self)
 Returns the target SBML Version for the conversion. More...
 
def getValidityFlag (self)
 Returns the flag indicating whether the conversion has been set to 'strict'. More...
 
def matchesProperties (self, props)
 Returns True if this converter object's properties match the given properties. More...
 
def setDocument (self, doc)
 This method has multiple variants; they differ in the arguments they accept. More...
 
def setProperties (self, props)
 Sets the configuration properties to be used by this converter. More...
 

Constructor & Destructor Documentation

def libsbml.SBMLLevelVersionConverter.__init__ (   self,
  args 
)

This method has multiple variants; they differ in the arguments they accept.

__init__()   SBMLLevelVersionConverter
__init__(SBMLLevelVersionConverter obj)   SBMLLevelVersionConverter

Each variant is described separately below.


Method variant with the following signature:
SBMLLevelVersionConverter()

Creates a new SBMLLevelVersionConverter object.


Method variant with the following signature:
SBMLLevelVersionConverter(SBMLLevelVersionConverter obj)

Copy constructor; creates a copy of an SBMLLevelVersionConverter object.

Parameters
objthe SBMLLevelVersionConverter object to copy.

Member Function Documentation

def libsbml.SBMLLevelVersionConverter.clone (   self)

Creates and returns a deep copy of this SBMLLevelVersionConverter object.

clone()   SBMLLevelVersionConverter
Returns
a (deep) copy of this converter.
def libsbml.SBMLLevelVersionConverter.convert (   self)

Perform the conversion.

convert()   int

This method causes the converter to do the actual conversion work, that is, to convert the SBMLDocument object set by SBMLConverter.setDocument() and with the configuration options set by SBMLConverter.setProperties().

Returns
integer value indicating success/failure of the function. The possible values returned by this function are:
def libsbml.SBMLLevelVersionConverter.getAddDefaultUnits (   self)

Returns the flag indicating whether default units should be added when converting to L3 or not.

getAddDefaultUnits()   bool
Returns
True if default units should be added, False otherwise.
def libsbml.SBMLLevelVersionConverter.getDefaultProperties (   self)

Returns the default properties of this converter.

getDefaultProperties()   ConversionProperties

A given converter exposes one or more properties that can be adjusted in order to influence the behavior of the converter. This method returns the default property settings for this converter. It is meant to be called in order to discover all the settings for the converter object.

Returns
the ConversionProperties object describing the default properties for this converter.
def libsbml.SBMLConverter.getDocument (   self,
  args 
)
inherited

Returns the SBML document that is the subject of the conversions.

getDocument()   SBMLDocument
Returns
the current SBMLDocument object.
def libsbml.SBMLConverter.getName (   self)
inherited

Returns the name of this converter.

getName()   string
Returns
a string, the name of this converter.
def libsbml.SBMLConverter.getProperties (   self)
inherited

Returns the current properties in effect for this converter.

getProperties()   ConversionProperties

A given converter exposes one or more properties that can be adjusted in order to influence the behavior of the converter. This method returns the current properties for this converter; in other words, the settings in effect at this moment. To change the property values, you can use SBMLConverter.setProperties().

Returns
the currently set configuration properties.
See also
setProperties()
matchesProperties()
def libsbml.SBMLLevelVersionConverter.getTargetLevel (   self)

Returns the target SBML Level for the conversion.

getTargetLevel()   long
Returns
an integer indicating the SBML Level.
def libsbml.SBMLConverter.getTargetNamespaces (   self)
inherited

Returns the target SBML namespaces of the currently set properties.

getTargetNamespaces()   SBMLNamespaces

SBML namespaces are used by libSBML to express the Level+Version of the SBML document (and, possibly, any SBML Level 3 packages in use). Some converters' behavior is affected by the SBML namespace configured in the converter. For example, in SBMLLevelVersionConverter (the converter for converting SBML documents from one Level+Version combination to another), the actions are fundamentally dependent on the SBML namespaces targeted.

Returns
the SBMLNamespaces object that describes the SBML namespaces in effect, or None if none are set.
def libsbml.SBMLLevelVersionConverter.getTargetVersion (   self)

Returns the target SBML Version for the conversion.

getTargetVersion()   long
Returns
an integer indicating the Version within the SBML Level.
def libsbml.SBMLLevelVersionConverter.getValidityFlag (   self)

Returns the flag indicating whether the conversion has been set to 'strict'.

getValidityFlag()   bool
Returns
True if strict validity has been requested, False otherwise.
def libsbml.SBMLLevelVersionConverter.matchesProperties (   self,
  props 
)

Returns True if this converter object's properties match the given properties.

matchesProperties(ConversionProperties props)   bool

A typical use of this method involves creating a ConversionProperties object, setting the options desired, and then calling this method on an SBMLLevelVersionConverter object to find out if the object's property values match the given ones. This method is also used by SBMLConverterRegistry.getConverterFor() to search across all registered converters for one matching particular properties.

Parameters
propsthe properties to match.
Returns
True if this converter's properties match, False otherwise.
def libsbml.SBMLConverter.setDocument (   self,
  doc 
)
inherited

This method has multiple variants; they differ in the arguments they accept.

setDocument(SBMLDocument doc)   int

Each variant is described separately below.


Method variant with the following signature:
setDocument(SBMLDocument doc)

Sets the SBML document to be converted.

Parameters
docthe document to use for this conversion.
Returns
integer value indicating the success/failure of the operation. The set of possible values that may be returned ultimately depends on the specific subclass of SBMLConverter being used, but the default method can return the following:

Method variant with the following signature:
setDocument(SBMLDocument doc)

Sets the SBML document to be converted.

Parameters
docthe document to use for this conversion.
Returns
integer value indicating the success/failure of the operation. The set of possible values that may be returned ultimately depends on the specific subclass of SBMLConverter being used, but the default method can return the following:
def libsbml.SBMLConverter.setProperties (   self,
  props 
)
inherited

Sets the configuration properties to be used by this converter.

setProperties(ConversionProperties props)   int
Parameters
propsthe ConversionProperties object defining the properties to set.
Returns
integer value indicating the success/failure of the operation. The set of possible values that may be returned ultimately depends on the specific subclass of SBMLConverter being used, but the default method can return the following values:
See also
getProperties()
matchesProperties()