generated from snakemake-workflows/snakemake-workflow-template
-
Notifications
You must be signed in to change notification settings - Fork 0
/
submit.sh
66 lines (55 loc) · 1.79 KB
/
submit.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
#!/bin/bash
#Submit to the cluster, give it a unique name
#$ -S /bin/bash
#$ -cwd
#$ -V
#$ -l h_vmem=1.9G,h_rt=20:00:00,tmem=1.9G
#$ -pe smp 2
# join stdout and stderr output
#$ -j y
#$ -R y
if [[ ( $@ == "--help") || $@ == "-h" ]]; then
echo "Usage: source submit.sh CONFIG_PATH (BIND_PATH) (RUN_NAME)"
echo
echo "Submit script for UCL cluster"
echo
echo "CONFIG_PATH - Required - path to config file for snakemake run (e.g. config/config.QAPA.yaml)"
echo "BIND_PATH - Optional - path to externally mount to singularity containers. Default is /SAN/vyplab"
echo "RUN_NAME - Optional - argument to name run. Config file for run will be copied to folder containing cluster log files (.submissions/<date><time>/) with run name prefixed"
echo "-h/--help - print this help message and exit"
exit 0
fi
# define config path
CONFIG_PATH=$1
# Define bind directory, using default if not provided
if [ "$2" == "" ]; then
IN_BIND_PATH="/SAN/vyplab"
else
IN_BIND_PATH=$2
fi
# Define run name, using default if not provided
if [ "$3" == "" ]; then
RUN_NAME="QAPA"
else
RUN_NAME=$3
fi
echo "Constructed config file path: "$CONFIG_PATH
echo "Constructed singularity bind command: --bind "$IN_BIND_PATH
# Create directory for cluster job submission script outputs & copy config file
FOLDER=submissions/$(date +"%Y%m%d%H%M")
mkdir -p ${FOLDER}/${RUN_NAME}
cp $1 ${FOLDER}/${RUN_NAME}/
snakemake \
-p \
--configfile=$CONFIG_PATH \
--use-conda \
--use-singularity \
--singularity-args="--bind $IN_BIND_PATH" \
--jobscript ucl_cluster_qsub.sh \
--cluster-config config/cluster.yaml \
--cluster-sync "qsub -l tmem={cluster.tmem},h_vmem={cluster.h_vmem},h_rt={cluster.h_rt} -o $FOLDER {cluster.submission_string}" \
-j 40 \
--nolock \
--rerun-incomplete \
--latency-wait 100 \
--keep-going