Mercurial > repos > guerler > springsuite
comparison spring_package/Energy.py @ 17:c790d25086dc draft
"planemo upload commit b0ede77caf410ab69043d33a44e190054024d340-dirty"
author | guerler |
---|---|
date | Wed, 28 Oct 2020 05:11:56 +0000 |
parents | |
children |
comparison
equal
deleted
inserted
replaced
16:16eb2acaaa20 | 17:c790d25086dc |
---|---|
1 import math | |
2 | |
3 NTYPE = 21 | |
4 NDIST = 20 | |
5 NSCALE = 2.0 | |
6 | |
7 class Energy: | |
8 def __init__(self): | |
9 self.dfire = list() | |
10 with open("spring_package/dfire/dfire.txt") as file: | |
11 for index, line in enumerate(file): | |
12 self.dfire.append(float(line)) | |
13 | |
14 def get(self, moleculeA, moleculeB): | |
15 result = 0 | |
16 chainA = list(moleculeA.calpha.keys())[0] | |
17 chainB = list(moleculeB.calpha.keys())[0] | |
18 for i in moleculeA.calpha[chainA]: | |
19 atomA = moleculeA.calpha[chainA][i] | |
20 indexA = self.toResCode(atomA["residue"]) | |
21 for j in moleculeB.calpha[chainB]: | |
22 atomB = moleculeB.calpha[chainB][j] | |
23 indexB = self.toResCode(atomB["residue"]) | |
24 dist2 = (atomA["x"] - atomB["x"]) ** 2 + (atomA["y"] - atomB["y"]) ** 2 + (atomA["z"] - atomB["z"]) ** 2 | |
25 dist = int ((math.sqrt(dist2) * NSCALE)) | |
26 if dist < NDIST: | |
27 index = indexA * NTYPE * NDIST + indexB * NDIST + dist | |
28 result = result + self.dfire[index] | |
29 return result | |
30 | |
31 def toResCode (self, seq): | |
32 code = dict(ALA=0, CYS=1, ASP=2, GLU=3, PHE=4, GLY=5, HIS=6, ILE=7, LYS=8, LEU=9, MET=10, | |
33 ASN=11, PRO=12, GLN=13, ARG=14, SER=15, THR=16, VAL=17, TRP=18, TYR=19) | |
34 return code[seq] if seq in code else 20 |