forked from RuleWorld/mcellRules
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathnfsim_python.py
102 lines (80 loc) · 3.61 KB
/
nfsim_python.py
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
from ctypes import *
class QueryResultsStruct(Structure):
_fields_ = [("numOfResults", c_int),
("results", POINTER(c_char_p))]
class NFSim:
def __init__(self, libPath):
self.lib = cdll.LoadLibrary(libPath)
def init_nfsim(self, fileName, verbose):
"""
inits an nfsim object with a given xml file and a verbosity setting
"""
self.lib.setupNFSim_c(fileName, verbose)
def reset_system(self):
"""
Resets an nfsim system to having no seeds species
"""
return self.lib.resetSystem_c()
def init_system_nauty(self, initDict):
"""
Initializes an nfsim simulation with a given nfsim dictionary with the species in nauty format
"""
species = [x for x in initDict]
seeds = [initDict[x] for x in initDict]
CArray = c_char_p * len(initDict)
speciesCArray = CArray(*species)
seedCArray = CArray(*seeds)
return self.lib.initSystemNauty_c(speciesCArray, seedCArray, len(initDict))
def init_system_xml(self, initXML):
"""
Initializes an nfsim simulation with a given seed species XML string
"""
return self.lib.initSystemXML_c(initXML)
def querySystemStatus(self, option):
"""
returns all species that participate in active reactions with numReactants reactants
"""
#self.lib.querySystemStatus_c.restype = QueryResultsStruct
mem = self.lib.mapvector_create()
#queryResults = self.lib.querySystemStatus_c(option, mem)
self.lib.querySystemStatus_c.argtypes = [c_char_p, c_void_p]
self.lib.map_get.restype = c_char_p
key = c_char_p(option)
self.lib.querySystemStatus_c(key,mem)
#results = [queryResults.results[i] for i in range(0, queryResults.numOfResults)]
results = []
for idx in range(0, self.lib.mapvector_size(mem)):
#XXX:ideally i would like to returns all key values but that will require a lil more work on teh wrapper side
partialResults = self.lib.mapvector_get(mem, idx)
results.append(self.lib.map_get(partialResults,"label"))
self.lib.mapvector_delete(mem)
return sorted(results, key=len)
if __name__ == "__main__":
nfsim = NFSim('./debug/libnfsim_c.so')
nfsim.init_nfsim("cbngl_test_empty.xml", 0)
nfsim.reset_system()
#nfsim.init_system_nauty({"c:a~NO_STATE!4!2,c:l~NO_STATE!3,c:l~NO_STATE!3!0,m:Lig!2!1,m:Rec!0":1})
#nfsim.init_system_nauty({"c:a~NO_STATE!4!2,c:l~NO_STATE!3,c:l~NO_STATE!3!0,m:Lig!1!2,m:Rec!0,":1})
#print '---', nfsim.querySystemStatus("observables")
nfsim.init_system_nauty({"c:l~NO_STATE!3!1,c:r~NO_STATE!2!0,m:L@EC!1,m:R@PM!0,":1})
print('----', nfsim.querySystemStatus("complex"))
"""
nfsim.initSystemXML('''<Model><ListOfSpecies><Species id="S1" concentration="1" name="@PM::Lig(l!1,l).Rec(a!1)" compartment="PM">
<ListOfMolecules>
<Molecule id="S1_M1" name="Lig" compartment="PM">
<ListOfComponents>
<Component id="S1_M1_C1" name="l" numberOfBonds="0"/>
<Component id="S1_M1_C2" name="l" numberOfBonds="1"/>
</ListOfComponents>
</Molecule>
<Molecule id="S1_M2" name="Rec" compartment="PM">
<ListOfComponents>
<Component id="S1_M2_C1" name="a" numberOfBonds="1"/>
</ListOfComponents>
</Molecule>
</ListOfMolecules>
<ListOfBonds>
<Bond id="S1_B1" site1="S1_M1_C1" site2="S1_M2_C1"/>
</ListOfBonds>
</Species></ListOfSpecies></Model>''')
"""