-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathfull_benchmark.py
98 lines (83 loc) · 3.01 KB
/
full_benchmark.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
#!/usr/bin/env python2
#$ -S /usr/bin/python
#$ -cwd
#$ -r yes
#$ -l h_rt=48:00:00
#$ -t 1-2500
#$ -j y
#$ -l arch=linux-x64
#$ -l mem_free=2G
#$ -l netapp=1G
import sys
import socket
import os
import subprocess
import shutil
print "Python:", sys.version
print "Host:", socket.gethostname()
sge_task_id = long( os.environ["SGE_TASK_ID"] )
job_id = long(os.environ["JOB_ID"])
coupled_moves_path = os.path.expanduser("~/bin/rosetta_static/coupled_moves.static.linuxgccrelease")
nstruct = 50
total_jobs = 2500
def run_coupled_moves( name, extra, nstruct_i ):
pdb = name.split('_')[0]
lig = name.split('_')[1]
pdb_file = os.path.join( name, pdb + "_with_" + lig + ".pdb" )
params_file = os.path.join( name, lig + "_from_" + pdb + ".params" )
res_file = os.path.join(name, pdb + '.resfile' )
extra_params = ''
if extra != '':
extra_params = name + '/' + extra + "_from_" + pdb + ".params"
output_directory = os.path.join( 'output', os.path.join( name, '%02d' % nstruct_i ) )
if not os.path.isdir(output_directory):
os.makedirs(output_directory)
coupled_moves_args = [
os.path.abspath(coupled_moves_path),
"-s %s" % os.path.abspath(pdb_file),
"-resfile %s" % os.path.abspath(res_file),
"-extra_res_fa %s" % os.path.abspath(params_file),
"-mute protocols.backrub.BackrubMover",
"-ex1",
"-ex2",
"-extrachi_cutoff 0",
"-nstruct %d" % 1,
"-coupled_moves::mc_kt 0.6",
"-coupled_moves::initial_repack false",
"-coupled_moves::ligand_mode true",
"-coupled_moves::fix_backbone false",
"-coupled_moves::bias_sampling true",
"-coupled_moves::boltzmann_kt 0.6",
"-coupled_moves::bump_check true",
]
if extra_params != '':
coupled_moves_args.append("-extra_res_fa %s" % os.path.abspath(extra_params))
log_path = os.path.join(output_directory, name + '.log')
print 'Running Rosetta with args:'
print ' '.join(coupled_moves_args)
print 'Output logged to:', os.path.abspath(log_path)
print
outfile = open(log_path, 'w')
process = subprocess.Popen(coupled_moves_args, stdout=outfile, stderr=subprocess.STDOUT, close_fds = True, cwd = output_directory)
returncode = process.wait()
outfile.close()
sge_log = 'full_benchmark.py.o%d.%d' % (job_id, sge_task_id)
if os.path.isfile( sge_log ):
shutil.move( sge_log, output_directory )
systems = []
with open('full_benchmark.txt', 'r') as f:
for line in f:
if len(line.strip()) > 0:
name = line.split()[0]
extra = ''
if len(line.split()) > 1:
extra = line.split()[1]
systems.append( [name, extra] )
job_args = []
for nstruct_i in range(1, nstruct + 1 ):
for name, extra in systems:
job_args.append( (name, extra, nstruct_i) )
if len(job_args) != total_jobs:
print nstruct, len(systems), len(job_args), total_jobs
assert( len(job_args) == total_jobs )
run_coupled_moves( *job_args[sge_task_id-1] )