1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122
|
#
# @file multi_example1.py
# @brief multi create example
# @author Sarah Keating
# @author Frank Bergmann
#
# <!--------------------------------------------------------------------------
# This file is part of libSBML. Please visit http://sbml.org for more
# information about SBML, and the latest version of libSBML.
#
# Copyright (C) 2009-2013 jointly by the following organizations:
# 1. California Institute of Technology, Pasadena, CA, USA
# 2. EMBL European Bioinformatics Institute (EMBL-EBI), Hinxton, UK
#
# Copyright (C) 2006-2008 by the California Institute of Technology,
# Pasadena, CA, USA
#
# Copyright (C) 2002-2005 jointly by the following organizations:
# 1. California Institute of Technology, Pasadena, CA, USA
# 2. Japan Science and Technology Agency, Japan
#
# This library is free software; you can redistribute it and/or modify it
# under the terms of the GNU Lesser General Public License as published by
# the Free Software Foundation. A copy of the license agreement is provided
# in the file named "LICENSE.txt" included with this software distribution
# and also available online as http://sbml.org/software/libsbml/license.html
# ------------------------------------------------------------------------ -->
#
from libsbml import *
sbmlns = SBMLNamespaces(3,1,"multi",1)
# create the document
document = SBMLDocument(sbmlns)
# set the required attribute to True
docPlug = document.getPlugin("multi")
docPlug.setRequired(True)
# create the Model
model=document.createModel()
# create the compartments
c = model.createCompartment()
c.setId("membrane")
c.setConstant(True)
# set the multi attribute isType via the compartmentPlugin
compPlug = c.getPlugin("multi")
compPlug.setIsType(True)
c = model.createCompartment()
c.setId("inter_membrane")
c.setConstant(True)
# set the multi attribute isType via the compartmentPlugin
compPlug = c.getPlugin("multi")
compPlug.setIsType(True)
# create the compartmentReferences
compRef = compPlug.createCompartmentReference()
compRef.setId("m1")
compRef.setCompartment("membrane")
compRef = compPlug.createCompartmentReference()
compRef.setId("m2")
compRef.setCompartment("membrane")
# create the speciesTypes
modelPlug = model.getPlugin("multi")
st = modelPlug.createMultiSpeciesType()
st.setId("stX")
st.setCompartment("ct")
st = modelPlug.createMultiSpeciesType()
st.setId("stXXcis")
st.setCompartment("ct")
# create speciesTypeInstances
sti = st.createSpeciesTypeInstance()
sti.setId("stiX1")
sti.setSpeciesType("stX")
sti = st.createSpeciesTypeInstance()
sti.setId("stiX2")
sti.setSpeciesType("stX")
# create speciesTypeBond
istb = st.createInSpeciesTypeBond()
istb.setBindingSite1("stiX1")
istb.setBindingSite2("stiX2")
# another speciesType
st = modelPlug.createMultiSpeciesType()
st.setId("stXXtrans")
st.setCompartment("cct")
# create speciesTypeInstances
sti = st.createSpeciesTypeInstance()
sti.setId("stiX1")
sti.setSpeciesType("stX")
sti.setCompartmentReference("cr1")
sti = st.createSpeciesTypeInstance()
sti.setId("stiX2")
sti.setSpeciesType("stX")
sti.setCompartmentReference("cr2")
# create speciesTypeBond
istb = st.createInSpeciesTypeBond()
istb.setBindingSite1("stiX1")
istb.setBindingSite2("stiX2")
writeSBML(document,"multi_example1.xml")
|