-
Notifications
You must be signed in to change notification settings - Fork 1
/
03-bwa.py
executable file
·111 lines (95 loc) · 3.78 KB
/
03-bwa.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
99
100
101
102
103
104
105
106
107
108
109
110
111
#! /usr/bin/env python
# PBS cluster job submission in Python
# BWA alignment to Painted Turtle Genome
# By Jean P. Elbers
# Last modified 22 Jan 2015
###############################################################################
Usage = """
03-bwa.py - version 1.0
Command:
1.Uses BWA Mem to align paired reads to Painted Turtle Genome
~/bin/bwa-0.7.12/bwa mem \
-M \
-t16 \
RefDir/GCF_000241765.3_Chrysemys_picta_bellii-3.0.3_genomic \
Sample-R1-unmerged.trim.fastq.gz \
Sample-R2-unmerged.trim.fastq.gz > ../bwa-alignment/Sample-paired.bwa.sam
2.Uses BWA Mem to align single and merged reads to Painted Turtle Genome
~/bin/bwa-0.7.12/bwa mem \
-M \
-t16 \
RefDir/GCF_000241765.3_Chrysemys_picta_bellii-3.0.3_genomic \
Sample-singlesANDmerged.trim.fastq.gz > ../bwa-alignment/Sample-singlesANDmerged.bwa.sam
Directory info:
InDir = /work/jelber2/immunome_2014/run1/trimmed-data
Input Files = Sample-R1-unmerged.trim.fastq.gz
Sample-R2-unmerged.trim.fastq.gz
Sample-singlesANDmerged.trim.fastq.gz
OutDir = /work/jelber2/immunome_2014/run1/bwa-alignment
Output Files = *-singlesANDmerged.bwa.sam
*-paired.bwa.sam
Usage (execute following code in InDir):
~/scripts/immunome_2014/03-bwa.py *.trim.fastq.gz
"""
###############################################################################
import os, sys, subprocess, re #imports os, sys, subprocess, re modules
if len(sys.argv)<2:
print Usage
else:
FileList = sys.argv[1:]
RefDir = "/work/jelber2/reference"
InDir = "/work/jelber2/immunome_2014/run1/trimmed-data/"
OutDir = "/work/jelber2/immunome_2014/run1/bwa-alignment"
NewFolderName = "bwa-alignment"
os.chdir(InDir)
os.chdir("..") # go up one directory
if not os.path.exists(NewFolderName):
os.mkdir(NewFolderName) # if NewFolderName does not exist, then make it
os.chdir(InDir)
R1 = re.compile(r"\w+\-R1\-unmerged\.trim\.fastq\.gz") # search string for obtaining only -R1-paired.fastq.gz files
FileList = [f for f in FileList if R1.match(f)] # keeps only R1 files in FileList
for InFileName in FileList: # so bwa only does command once for each R1 and R2 pair
FileSuffix = "-R1-unmerged.trim.fastq.gz" # string to remove from InFileName
Sample = InFileName.replace(FileSuffix,'') # creates Sample string
# Customize your options here
Queue = "workq"
Allocation = "hpc_gopo02"
Processors = "nodes=1:ppn=16"
WallTime = "01:30:00"
LogOut = OutDir
LogMerge = "oe"
JobName = "BWA-%s" % (Sample)
Command ="""
~/bin/bwa-0.7.12/bwa mem \
-M \
-t16 \
%s/GCF_000241765.3_Chrysemys_picta_bellii-3.0.3_genomic \
%s-R1-unmerged.trim.fastq.gz \
%s-R2-unmerged.trim.fastq.gz > ../bwa-alignment/%s-paired.bwa.sam
~/bin/bwa-0.7.12/bwa mem \
-M \
-t16 \
%s/GCF_000241765.3_Chrysemys_picta_bellii-3.0.3_genomic \
%s-singlesANDmerged.trim.fastq.gz > ../bwa-alignment/%s-singlesANDmerged.bwa.sam""" % \
(RefDir, Sample, Sample, Sample,
RefDir, Sample, Sample)
JobString = """
#!/bin/bash
#PBS -q %s
#PBS -A %s
#PBS -l %s
#PBS -l walltime=%s
#PBS -o %s
#PBS -j %s
#PBS -N %s
cd %s
%s\n""" % (Queue, Allocation, Processors, WallTime, LogOut, LogMerge, JobName, InDir, Command)
#Create pipe to qsub
proc = subprocess.Popen(['qsub'], shell=True,
stdin=subprocess.PIPE, stdout=subprocess.PIPE, close_fds=True)
(child_stdout, child_stdin) = (proc.stdout, proc.stdin)
#Print JobString
jobname = proc.communicate(JobString)[0]
print JobString
print jobname