You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
"""Test bed for FBC version 3.For latest SBML fbc v3 specification seehttps://github.com/bgoli/sbml-fbc-spec/blob/main/sf_svn/spec/main.pdf"""fromloggingimportgetLoggerfrompathlibimportPathimportlibsbmllogger=getLogger(__name__)
defcheck(value: int, message: str) ->bool:
"""Check the libsbml return value and prints message if something happened. If 'value' is None, prints an error message constructed using 'message' and then exits with status code 1. If 'value' is an integer, it assumes it is a libSBML return status code. If the code value is LIBSBML_OPERATION_SUCCESS, returns without further action; if it is not, prints an error message constructed using 'message' along with text from libSBML explaining the meaning of the code, and exits with status code 1. """valid=TrueifvalueisNone:
logger.error(f"Error: LibSBML returned a null value trying to <{message}>.")
valid=Falseelifisinstance(value, int):
ifvalue!=libsbml.LIBSBML_OPERATION_SUCCESS:
logger.error(f"Error encountered trying to '{message}'.")
logger.error(
f"LibSBML returned error code {str(value)}: "f"{libsbml.OperationReturnValue_toString(value).strip()}"
)
valid=Falsereturnvalid# create document with new fbc version 3 namespacesbmlns: libsbml.SBMLNamespaces=libsbml.SBMLNamespaces(3, 2)
sbmlns.addPkgNamespace("fbc", 3)
doc: libsbml.SBMLDocument=libsbml.SBMLDocument(sbmlns)
doc_fbc: libsbml.FbcSBMLDocumentPlugin=doc.getPlugin("fbc")
doc_fbc.setRequired(False)
model: libsbml.Model=doc.createModel()
model_fbc: libsbml.FbcModelPlugin=model.getPlugin("fbc")
model_fbc.setStrict(True)
# Support for key value pairs existsc: libsbml.Compartment=model.createCompartment()
c.setId("c1")
c.setSize(1.0)
c.setConstant(True)
s1: libsbml.Species=model.createSpecies()
s1.setId("s1")
s1.setCompartment("c1")
s1.setInitialConcentration(1.0)
s1.setConstant(False)
s1.setHasOnlySubstanceUnits(False)
s1.setBoundaryCondition(False)
s2: libsbml.Species=model.createSpecies()
s2.setId("s2")
s2.setCompartment("c1")
s2.setInitialConcentration(1.0)
s2.setConstant(False)
s2.setHasOnlySubstanceUnits(False)
s2.setBoundaryCondition(False)
# Support exists for user constraintsreaction: libsbml.Reaction=model.createReaction()
reaction.setId("r1")
reaction.setReversible(True)
reaction.setFast(False)
fbc_reaction: libsbml.FbcReactionPlugin=reaction.getPlugin("fbc")
fbc_reaction.setUpperFluxBound("ub")
fbc_reaction.setLowerFluxBound("lb")
reactant: libsbml.SpeciesReference=reaction.createReactant()
reactant.setSpecies("s1")
reactant.setConstant(True)
reactant.setStoichiometry(1.0)
product: libsbml.SpeciesReference=reaction.createProduct()
product.setSpecies("s2")
product.setConstant(True)
product.setStoichiometry(1.0)
constraint: libsbml.UserDefinedConstraint=model_fbc.createUserDefinedConstraint()
constraint.setId("constraint1")
constraint.setLowerBound("lb")
constraint.setUpperBound("ub")
component: libsbml.UserDefinedConstraintComponent= (
constraint.createUserDefinedConstraintComponent()
)
component.setCoefficient(10.0)
component.setVariable("r1")
component.setVariableType(libsbml.FBC_FBCVARIABLETYPE_LINEAR)
sbml_str: str=libsbml.writeSBMLToString(doc)
print("-"*80)
# console.log(sbml_str)print(sbml_str)
print("-"*80)
# checking that SBML string can be read againdoc2=libsbml.readSBMLFromString(sbml_str)
ifdoc2.getNumErrors() >0:
ifdoc2.getError(0).getErrorId() ==libsbml.XMLFileUnreadable:
err_message="Unreadable SBML file"elifdoc2.getError(0).getErrorId() ==libsbml.XMLFileOperationError:
err_message="Problems reading SBML file: XMLFileOperationError"else:
err_message="SBMLDocumentErrors encountered while reading the SBML file."# log_sbml_errors_for_doc(doc)logger.error(f"`read_sbml` error `{err_message}`")
forkinrange(doc2.getNumErrors()):
error: libsbml.SBMLError=doc2.getError(k)
print(f"Error {k}")
print(error.getMessage())
The UserDefinedConstraintComponents are not written in SBML L3V2.
Only the empty component is written in SBML, but not the attributes:
See full example below:
Results in
If you change the line to
the component is serialized correctly as
The text was updated successfully, but these errors were encountered: