-
Notifications
You must be signed in to change notification settings - Fork 258
/
Copy pathcolor_by_conservation.py
58 lines (45 loc) · 1.69 KB
/
color_by_conservation.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
from pymol import cmd, CmdException
@cmd.extend
def color_by_conservation(aln, names=(), color=None, as_putty=0, _self=cmd):
'''
See more here: http://www.pymolwiki.org/index.php/color_by_conservation
PARAMETERS
aln
(string) the alignment object name
names
(list) a list of object names that are in the alignment;
if (), then PyMOL will attempt to glean the names
from the alignment object
color
(string) valid PyMOL spectrum name
as_putty
(0 or 1) if 0 display is not changed, else participating objects are shown
as cartoon putty, colored by the 'color' field
'''
if _self.get_type(aln) != "object:alignment":
raise CmdException("Error: Bad or incorrectly specified alignment object.")
r = _self.get_raw_alignment(aln)
if names == ():
known_objs = []
list(map(known_objs.extend, [[y[0] for y in x] for x in r]))
known_objs = set(known_objs)
# highest number of matches seen
M = max(list(map(len, r))) + 1
else:
known_objs = set(names)
M = len(known_objs) + 1
for obj in known_objs:
_self.alter(obj, "b=0.0")
for af in r:
c = float(1.0 + len(af)) / float(M)
for y in af:
_self.alter("%s and index %s" % (y[0], y[1]), "b=c", space={'c': c})
if int(as_putty) != 0:
for obj in known_objs:
_self.show_as("cartoon", "%s" % obj)
_self.cartoon("putty", "%s" % obj)
if color is not None:
for obj in known_objs:
_self.spectrum('b', color, obj)
_self.sort()
_self.rebuild()