-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathbatch-bowtie2-fq-paired-unfiltered.sh
executable file
·25 lines (25 loc) · 1.39 KB
/
batch-bowtie2-fq-paired-unfiltered.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
#!/bin/bash
#USAGE: give a bowtie2 index, chunsize, and a glob of pair 1 reads
#if you don't have a bowtie2 index, build it with "bowtie2-build <reference>.fa basename"
CHUNK=$2
COUNTER=0
FQ="${@:3}"
for i in $FQ; do
if [ $COUNTER -eq 0 ]; then
echo -e "#!/bin/bash\n#SBATCH -p owners\n#SBATCH --ntasks=1\n#SBATCH --cpus-per-task=3\n#SBATCH -t 12:00:00\n#SBATCH --mem 24000" > TEMPBATCH.sbatch; fi
BASE=$( basename $i _1.txt.gz )
echo "srun bowtie2 -p 3 -X 1500 --rg-id $BASE --rg SM:$BASE --very-sensitive-local -x $1 -1 ${BASE}_1.txt.gz -2 ${BASE}_2.txt.gz > $BASE.sam" >> TEMPBATCH.sbatch
echo "samtools view -bS ${BASE}.sam > ${BASE}_BTVS-UNSORTED.bam " >> TEMPBATCH.sbatch
echo "srun samtools sort ${BASE}_BTVS-UNSORTED.bam ${BASE}_UNDEDUP" >> TEMPBATCH.sbatch
echo "srun java -Xmx4g -jar /share/PI/spalumbi/programs/picard.jar MarkDuplicates REMOVE_DUPLICATES=true INPUT=${BASE}_UNDEDUP.bam OUTPUT=${BASE}.bam METRICS_FILE=${BASE}-metrics.txt VALIDATION_STRINGENCY=LENIENT" >> TEMPBATCH.sbatch
echo "srun samtools index ${BASE}.bam" >> TEMPBATCH.sbatch
echo "rm ${BASE}.sam" >> TEMPBATCH.sbatch
echo "rm ${BASE}_BTVS-UNSORTED.bam" >> TEMPBATCH.sbatch
echo "rm ${BASE}_UNDEDUP.bam" >> TEMPBATCH.sbatch
let COUNTER=COUNTER+1
if [ $COUNTER -eq $CHUNK ]; then
sbatch TEMPBATCH.sbatch
COUNTER=0; fi
done
if [ $COUNTER -ne 0 ]; then
sbatch TEMPBATCH.sbatch; fi