forked from bethsheets/palumbi_scripts
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathbatch-bowtie2-fq-paired-strict.sh
executable file
·25 lines (25 loc) · 1.41 KB
/
batch-bowtie2-fq-paired-strict.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 --score-min L,0,-0.384 -L 20 -i S,1,0.50 -x $1 -1 ${BASE}_1.txt.gz -2 ${BASE}_2.txt.gz > $BASE.sam" >> TEMPBATCH.sbatch
echo "samtools view -bSq 10 ${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