libSBML Python API
5.18.0
|
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 converter translates all instances of a given identifier (i.e., SBML object 'id' attribute value) of type 'SId' in a Model to another identifier. It does this based on a list of source identifiers, translating each one to its corresponding replacement value in a list of replacement identifiers. It also updates all references to the identifiers so replaced. (More technically, it replaces all values known as type SIdRef
in the SBML Level 3 specifications.)
This converter only searches the global SId namespace for the Model child of the SBMLDocument. It does not replace any IDs or SIdRefs for LocalParameters, nor does it replace any UnitSIds or UnitSIdRefs. It likewise does not replace any IDs in a new namespace introduced by a package, such as the PortSId namespace from the Hierarchical Model Composition package, nor any Model objects that are not the direct child of the SBMLDocument, such as the ModelDefinitions from the Hierarchical Model Composition package.
If, however, a package introduces a new element with an 'id' attribute of type SId, any attribute of type SIdRef, or child of type SIdRef (such as a new Math child of a package element), those IDs will be replaced if they match a source identifier.
SBMLIdConverter is enabled by creating a ConversionProperties object with the option 'renameSIds'
, and passing this properties object to SBMLDocument.convert(). The converter accepts two options, and both must be set or else no conversion is performed:
'currentIds'
: A comma-separated list of identifiers to replace. 'newIds'
: A comma-separated list of identifiers to use as the replacements. The values should correspond one-to-one with the identifiers in 'currentIds'
that should be replaced.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.
The following code fragment illustrates an example using SBMLReactionConverter, which is invoked using the option string '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:
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:
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 SBMLIdConverter object. More... | |
def | convert (self) |
Perform the conversion. 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 | getTargetNamespaces (self) |
Returns the target SBML namespaces of the currently set properties. 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... | |
def libsbml.SBMLIdConverter.__init__ | ( | self, | |
args | |||
) |
This method has multiple variants; they differ in the arguments they accept.
__init__() SBMLIdConverter __init__(SBMLIdConverter obj) SBMLIdConverter
Each variant is described separately below.
SBMLIdConverter(SBMLIdConverter obj)
Copy constructor; creates a copy of an SBMLIdConverter object.
obj | the SBMLIdConverter object to copy. |
SBMLIdConverter()
Creates a new SBMLIdConverter object.
def libsbml.SBMLIdConverter.clone | ( | self | ) |
Creates and returns a deep copy of this SBMLIdConverter object.
clone() SBMLIdConverter
def libsbml.SBMLIdConverter.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().
def libsbml.SBMLIdConverter.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.
|
inherited |
Returns the SBML document that is the subject of the conversions.
getDocument() SBMLDocument
|
inherited |
Returns the name of this converter.
getName() string
|
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().
|
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.
None
if none are set. def libsbml.SBMLIdConverter.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 SBMLIdConverter 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.
props | the properties to match. |
True
if this converter's properties match, False
otherwise.
|
inherited |
This method has multiple variants; they differ in the arguments they accept.
setDocument(SBMLDocument doc) int
Each variant is described separately below.
setDocument(SBMLDocument doc)
Sets the SBML document to be converted.
doc | the document to use for this conversion. |
setDocument(SBMLDocument doc)
Sets the SBML document to be converted.
doc | the document to use for this conversion. |
|
inherited |
Sets the configuration properties to be used by this converter.
setProperties(ConversionProperties props) int
props | the ConversionProperties object defining the properties to set. |