-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathbwaMapPE.sh
executable file
·122 lines (72 loc) · 3.68 KB
/
bwaMapPE.sh
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
112
113
114
115
116
117
118
119
120
121
122
source ~/.bashrc
source fileUtils.sh
source ./initvars.sh
source $configDir/bwa.config.sh
source $tophatshvar
saveIFS=$IFS
IFS=`echo -en ","`
declare -a samples=($Samples)
IFS=$saveIFS
###nodenum=1
for sample in ${samples[*]}; do
echo "initiate tophat for sample $sample"
vname=${sample}_1
lfilelist=${!vname}
vname=${sample}_2
rfilelist=${!vname}
IFS=`echo -en ","`
declare -a lfilelist=($lfilelist)
declare -a rfilelist=($rfilelist)
sizeFile=${#lfilelist[@]}
if [ ! -d $saiDir ]; then
mkdir $saiDir
fi
if [ ! -d $sampeDir ]; then
mkdir $sampeDir
fi
if [ ! -d $samseDir ]; then
mkdir $samseDir
fi
sampleSampeOutDir=$sampeDir/$sample
sampleSamseOutDir=$samseDir/$sample
if [ ! -d $sampleSampeOutDir ];then
mkdir $sampleSampeOutDir
fi
if [ ! -d $sampleSamseOutDir ]; then
mkdir $sampleSamseOutDir
fi
for((i=0;i<$sizeFile;i++)); do
lfile=${lfilelist[i]}
rfile=${rfilelist[i]}
echo processing $lfile $rfile
header="#!/bin/bash"
commandAlnL="$bwa_command aln $solexa_flag -n $ALN_N -o $ALN_o -e $ALN_e -d $ALN_d -i $ALN_i $ALN_l_FLAG -k $ALN_k -t $ALN_t -M $ALN_M -O $ALN_O -E $ALN_E $ALN_R_FLAG $ALN_c_FLAG $ALN_N_FLAG -q $ALN_q $genome $fastqDir/${lfile} > $saiDir/${lfile/.fastq/.sai} 2> $saiDir/${lfile/.fastq/.err}; echo done >> $saiDir/${lfile/.fastq/.err};"
commandAlnR="$bwa_command aln $solexa_flag -n $ALN_N -o $ALN_o -e $ALN_e -d $ALN_d -i $ALN_i $ALN_l_FLAG -k $ALN_k -t $ALN_t -M $ALN_M -O $ALN_O -E $ALN_E $ALN_R_FLAG $ALN_c_FLAG $ALN_N_FLAG -q $ALN_q $genome $fastqDir/${rfile} > $saiDir/${rfile/.fastq/.sai} 2> $saiDir/${rfile/.fastq/.err}; echo done >> $saiDir/${rfile/.fastq/.err};"
commandSamseL="$bwa_command samse -n $SAMSE_n $genome $saiDir/${lfile/.fastq/.sai} $fastqDir/${lfile} > $sampleSamseOutDir/${lfile/.fastq/.sam} 2> $sampleSamseOutDir/${lfile/.fastq/.stderr}; echo done >> $sampleSamseOutDir/${lfile/.fastq/.stderr};"
commandSamseR="$bwa_command samse -n $SAMSE_n $genome $saiDir/${rfile/.fastq/.sai} $fastqDir/${rfile} > $sampleSamseOutDir/${rfile/.fastq/.sam} 2> $sampleSamseOutDir/${rfile/.fastq/.stderr}; echo done >> $sampleSamseOutDir/${rfile/.fastq/.stderr};"
commandSampe="$bwa_command sampe -a $SAMPE_a -o $SAMPE_o $genome $saiDir/${lfile/.fastq/.sai} $saiDir/${rfile/.fastq/.sai} $fastqDir/${lfile} $fastqDir/${rfile} > $sampleSampeOutDir/${sample}.sam 2> $sampleSampeOutDir/${sample}.stderr; echo done >> $sampleSampeOutDir/${sample}.stderr;"
#commandSampe="bwa sampe -a $SAMPE_a -o $SAMPE_o $genome $saiDir/${lfile/.fastq/.sai} $saiDir/${rfile/.fastq/.sai} $fastqDir/${lfile} $fastqDir/${rfile} > $sampleSampeOutDir/${lfile/_1.fastq/.sam} 2> $sampleSampeOutDir/${lfile/_1.fastq/.stderr}; echo done >> $sampleSampeOutDir/${lfile/_1.fastq/.stderr};"
if [ ! -d $configDir/queuejobs ]; then
mkdir $configDir/queuejobs
fi
tmpshName=$configDir/queuejobs/bwa_sub_${lfile/.fastq/}.sh
echo $header > $tmpshName
echo "#$tmpshName" >> $tmpshName
echo "source ~/.bashrc" >> $tmpshName
echo $commandAlnL >> $tmpshName
echo $commandAlnR >> $tmpshName
echo $commandSamseL >> $tmpshName
echo $commandSamseR >> $tmpshName
echo $commandSampe >> $tmpshName
cat $tmpshName
#qsubcommand="qsub -e $queueJobStdWritePath/$sample.bwa.err -m a -M $queueJobEmail -o queueJobStdWritePath/$sample.bwa.out $tmpshName"
bsubcommand="$bsub_command -q $jobQueue $tmpshName"
echo $bsubcommand
eval $bsubcommand
done
IFS=$saveIFS
done
exit;
command="echo 'source ~/.bashrc; bwa index $indexFlag $genome > $logprefix/$genomeName.bwa_index.stdout 2> $logprefix/$genomeName.bwa_index.stderr' | qsub -l nodes=$nodehostname -q $jobQueue -m a -M $queueJobEmail -"
echo $command
eval $command