-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathslurm_guppy_taiyaki_qscore.sh
executable file
·78 lines (63 loc) · 2.23 KB
/
slurm_guppy_taiyaki_qscore.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
#!/bin/bash
# Settings to be modified:
# gres setup:
# - gpu:tesla is currently fixed as we only have GPUs as extract resource
# - Moreover we only have cards of the tesla type
# - The number after the clon specifies the number of GPUs required,
# e.g. something between 1 and 4
#SBATCH --gres=gpu:pascal:1
# Modifiy other SLURM variables as needed
#SBATCH --partition=gpu
#SBATCH -n 1
#SBATCH -N 1
#SBATCH -c 10
#SBATCH --mem=100G
#SBATCH --mail-type=END,FAIL,TIME_LIMIT_80
#SBATCH --mail-user=tobias.jakobi@med.uni-heidelberg.de
# Template for SLURM GPU handling scripts
# From https://techfak.net/gpu-cluster
# please do not modify the following parts
################################################################################################
echo "==== Start of GPU information ===="
CUDA_DEVICE=$(echo "$CUDA_VISIBLE_DEVICES," | cut -d',' -f $((SLURM_LOCALID + 1)) );
T_REGEX='^[0-9]$';
if ! [[ "$CUDA_DEVICE" =~ $T_REGEX ]]; then
echo "error no reserved gpu provided"
exit 1;
fi
# Print debug information
echo -e "SLURM job:\t$SLURM_JOBID"
#echo -e "SLURM process:\t$SLURM_PROCID"
#echo -e "SLURM GPU ID:\t$SLURM_LOCALID"
#echo -e "CUDA_DEVICE ID:\t$CUDA_DEVICE"
echo -e "CUDA_VISIBLE_DEVICES:\t$CUDA_VISIBLE_DEVICES"
echo "Device list:"
echo "$(nvidia-smi --query-gpu=name,gpu_uuid --format=csv -i $CUDA_VISIBLE_DEVICES | tail -n +2)"
echo "==== End of GPU information ===="
echo ""
#################################################################################################
# actual script calls start here
# $CUDA_VISIBLE_DEVICES contains the GPU IDs assigned by SLURM separated with comma
# e.g. "0,1,2"
module load guppy
# check if we have 2 arguments
if [ ! $# == 5 ]; then
echo "Usage: $0 [Input folder (recursive)] [Output folder] [Kit] [Flow cell type] [model] [offset] [scale]"
exit
fi
guppy_basecaller --trim_strategy none\
--verbose_logs \
--compress_fastq \
--fast5_out \
-r \
-i ${1} \
-s ${2} \
--model_file ${5} \
--num_callers 4 \
--chunks_per_runner 768 \
--chunk_size 500 \
--gpu_runners_per_device 8 \
--cpu_threads_per_caller 10 \
--device auto \
--flowcell ${4} \
--kit ${3}