-
Notifications
You must be signed in to change notification settings - Fork 59
/
Copy pathOBO.py
98 lines (81 loc) · 2.68 KB
/
OBO.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
class OBO(object):
def __init__(self, file_name, save_synonyms = False):
import OboParser
self.g = OboParser.getOboGraph(file_name, save_synonyms)
self.precalculated_descendants = {}
self.child_to_parent = None
return
def get_term(self, v):
return self.g.node[v]
def get_term_name(self, v):
return self.g.node[v]['n']
def get_term_synonyms(self, v):
return self.g.node[v]['s']
def get_term_relations(self, v):
#return self.g.neighbors(v)
return [ (u, data['r']) for u, data in self.g[v].iteritems() ]
def get_term_relation_dict(self, v):
return self.g[v]
def get_xref_mapping(self, left_id, right_id):
left_id_to_right_ids = {}
for node, data in self.g.nodes(data=True):
left_vals = []
right_vals = []
for xref in data["xref"]:
id_type, id_val = xref.split(":")
id_type = id_type.lower()
if id_type == left_id:
left_vals.append(id_val)
if id_type == right_id:
right_vals.append(id_val)
for left_val in left_vals:
left_id_to_right_ids[left_val] = right_vals
return left_id_to_right_ids
def get_descendants(self, id):
"""
Gets all the descendants
"""
if self.precalculated_descendants.has_key(id):
return self.precalculated_descendants[id]
result = set()
for current_descendant_id in self.g.neighbors(id):
if current_descendant_id == id:
return result
else:
if current_descendant_id not in result:
result.add(current_descendant_id)
result.update(self.get_descendants(current_descendant_id))
self.precalculated_descendants[id] = result
return result
def get_ontology_extended_id_mapping(self, terms=None):
if terms is not None:
nodes = terms
else:
if self.child_to_parent is not None:
return self.child_to_parent
nodes = self.g.nodes()
for id in nodes:
self.get_descendants(id)
self.child_to_parent = {}
for key, values in self.precalculated_descendants.iteritems():
for value in values:
self.child_to_parent.setdefault(value, set()).add(key)
return self.child_to_parent
def get_nested_ontology_mapping(self, from_ontology_prefix,
to_ontology_prefix):
hsdl_to_hge = {} # hsdl_to_go
for v, data in self.g.nodes(data=True):
if not v.startswith(to_ontology_prefix): #"HGE:"):
continue
relations = self.g[v]
while len(relations) > 0:
for child, values in relations.iteritems(): # Currently tracing only the last child
if from_ontology_prefix == "*" or child.startswith(from_ontology_prefix): #"HSDL:"):
#type = values['r']
hsdl_to_hge.setdefault(child, set()).add(v)
relations = {}
else:
relations = self.g[child]
#for key, value in hsdl_to_hge.iteritems():
# print key, sorted(list(value))
return hsdl_to_hge