-
Notifications
You must be signed in to change notification settings - Fork 0
/
slurm_bamfo_stats.py
executable file
·51 lines (42 loc) · 1.39 KB
/
slurm_bamfo_stats.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
#!/cm/shared/apps/python/2.7.6/bin/python
# -*- coding: utf-8 -*-
import sys
import os
from slurm.slurm_parse_sample_file import slurm_sample_files
from slurm.slurm_write_sh_files import write_sh_files
if __name__ == "__main__":
def slurm_cmd(sample_dir, sample_name, prefix, job_name):
cmd = "bamfo stats " + " \\\n" \
+ "--bam " + sample_dir + "/" + sample_name + " \\\n" \
+ "--output " + prefix + "_" + job_name + ".stats"
return cmd
# command line arguments
sample_file = sys.argv[1]
cpus = sys.argv[2]
mem = sys.argv[3]
time = sys.argv[4]
queue = sys.argv[5]
account = sys.argv[6]
output_dir = sys.argv[7]
prefix = sys.argv[8]
# defaults
if not cpus:
cpus = 1
if not mem:
mem = 8000
if not time:
time = "2:0:0"
if not queue:
queue = mediumq
if not account:
account = fschischlik
if not output_dir:
output_dir = os.getcwd()
#run
samples = slurm_sample_files(sample_file)
for each_sample in samples:
job_name = each_sample[1].rsplit("_",4)[0] #stripped down
cmd = slurm_cmd(each_sample[0], each_sample[1], prefix, job_name)
write_sh_files(job_name, cpus, mem,
time, queue, account,
output_dir, prefix, cmd)