20 Wrappers for the iAlign utility.
24 Mu Gao and Jeffrey Skolnick, 2010. iAlign: a method for the structural comparison
25 of protein-protein interfaces. Bioinformatics, 26(18):2259-65.
26 Mu Gao and Jeffrey Skolnick, 2010. Structural space of protein-protein interfaces
27 is degenerate, close to complete, and highly connected. PNAS 107(52):22517-22.
29 Authors: Pascal Benkert, Marco Biasini, Martino Bertoni
32 import subprocess, os, tempfile, platform
33 from ost
import settings, io, geom, seq
35 def _SetupFiles(models):
37 tmp_dir_name=tempfile.mkdtemp()
39 for index, model
in enumerate(models):
40 for chain
in model.chains:
41 if len(chain.name) > 1:
44 for res
in chain.residues:
48 io.SavePDB(model, os.path.join(tmp_dir_name,
'model%02d.pdb' % (index+1)), dialect=dia)
51 def _CleanupFiles(dir_name):
53 shutil.rmtree(dir_name)
57 Holds the result of running iAlign
61 The RMSD of the common Calpha atoms of both structures
63 .. attribute:: transform
65 The transform that superposes the model onto the reference structure.
67 :type: :class:`~ost.geom.Mat4`
69 .. attribute:: alignment
71 The alignment of the structures, that is the pairing of Calphas of both
72 structures. Since the programs only read ATOM records, residues consisting
73 of HETATMs (MSE) are not included in the alignment.
75 :type: :class:`~ost.seq.AlignmentHandle`
77 .. attribute:: IS_score
79 The IS-score of the structural superposition
81 .. attribute:: aligned_residues
83 The total number of aligned residues
85 .. attribute:: aligned_contacts
87 The total number of aligned contacts
90 def __init__(self, rmsd, transform, alignment, is_score,
91 aligned_residues, aligned_contacts):
100 def _ParseiAlign(lines):
101 info_line=lines[18].split(
',')
102 is_score=float(info_line[0].split(
'=')[1].strip())
103 aln_residues=int(lines[19].split(
'=')[1].strip())
104 aln_contacts=int(lines[20].split(
'=')[1].strip())
105 info_line=lines[21].split(
',')
106 rmsd=float(info_line[0].split(
'=')[1].strip())
108 tf1=[float(i.strip())
for i
in lines[25][1:].split()]
109 tf2=[float(i.strip())
for i
in lines[26][1:].split()]
110 tf3=[float(i.strip())
for i
in lines[27][1:].split()]
111 rot=
geom.Mat3(tf1[2], tf1[3], tf1[4], tf2[2], tf2[3],
112 tf2[4], tf3[2], tf3[3], tf3[4])
114 tf.PasteTranslation(
geom.Vec3(tf1[1], tf2[1], tf3[1]))
115 seq1 = seq.CreateSequence(
"1",lines[32].strip())
116 seq2 = seq.CreateSequence(
"2",lines[34].strip())
117 alignment = seq.CreateAlignment()
118 alignment.AddSequence(seq2)
119 alignment.AddSequence(seq1)
120 return iAlignResult(rmsd, tf, alignment, is_score, aln_residues, aln_contacts)
122 def _RuniAlign(ialign, tmp_dir, options={}):
128 for k, v
in opts.items():
129 if type(v) == type(
True):
131 cmd_opts.append(
'-%s' % str(k))
133 cmd_opts.append(
'-%s %s' % (str(k), str(v)))
134 cmd_opts =
' '.join(cmd_opts)
135 model1_filename=os.path.join(tmp_dir,
'model01.pdb')
136 model2_filename=os.path.join(tmp_dir,
'model02.pdb')
137 if platform.system() ==
"Windows":
138 ialign_path=settings.Locate(
'ialign.pl', explicit_file_name=ialign)
139 command=
"\"%s\" %s %s %s" % (os.path.normpath(ialign_path), model1_filename, model2_filename, cmd_opts)
141 ialign_path=settings.Locate(
'ialign.pl', explicit_file_name=ialign)
142 command=
"\"%s\" \"%s\" \"%s\" %s" % (ialign_path, model1_filename, model2_filename, cmd_opts)
144 ps=subprocess.Popen(command, shell=
True, stdout=subprocess.PIPE)
145 stdout,_=ps.communicate()
146 lines=stdout.decode().splitlines()
149 _CleanupFiles(tmp_dir)
152 raise RuntimeError(
"iAlign superposition failed")
153 return _ParseiAlign(lines)
158 Compare protein-protein interfaces of the structures of two pairs of
159 protein complexes and suporpose them.
162 :param model1: The model structure. If the superposition is successful, will
163 be superposed onto the reference structure
164 :type model1: :class:`~ost.mol.EntityView` or :class:`~ost.mol.EntityHandle`
165 :param model2: The reference structure
166 :type model2: :class:`~ost.mol.EntityView` or :class:`~ost.mol.EntityHandle`
167 :param ialign: If not None, the path to the ialign executable.
168 :returns: The result of the tmscore superposition
169 :rtype: :class:`iAlignResult`
171 :raises: :class:`~ost.settings.FileNotFound` if tmalign could not be located.
172 :raises: :class:`RuntimeError` if the superposition failed
174 tmp_dir_name=_SetupFiles((model1, model2))
175 result=_RuniAlign(ialign, tmp_dir_name)
176 model1.handle.EditXCS().ApplyTransform(result.transform)
177 _CleanupFiles(tmp_dir_name)
Three dimensional vector class, using Real precision.
def __init__(self, rmsd, transform, alignment, is_score, aligned_residues, aligned_contacts)
def iAlign(model1, model2, ialign=None)