-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathwrapper.sh
executable file
·26 lines (22 loc) · 1.16 KB
/
wrapper.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
#!/bin/bash
# Script to execute code on the slurm cluster in the current conda environment.
# Example Usage: bash scripts/gpu_cluster/wrapper.sh python src/train.py +trainer.fast_dev_run=true
SCRIPT_DIR=$(dirname $0)
# check if an environment file is provided in the current directory
ENV_FILE="$(pwd)/.pegasus-bridle.env"
if [ -f "$ENV_FILE" ]; then
echo "INFO: .pegasus-bridle.env file found in current directory. load environment variables from $ENV_FILE"
else
ENV_FILE="$SCRIPT_DIR"/.env
echo "WARNING: no .pegasus-bridle.env file found in current directory. use environment variables from $ENV_FILE"
fi
# import and check required environment variables
. "$SCRIPT_DIR"/import_vars.sh "$ENV_FILE" "CONTAINER_IMAGE" "PARTITION" "RESOURCE_ALLOCATION" "CONTAINER_WORKDIR" "CONTAINER_MOUNTS" "EXPORT" "JOB_NAME" "MAX_TIME_LIMIT"
srun -K -p $PARTITION $RESOURCE_ALLOCATION \
--container-image="$CONTAINER_IMAGE" \
--container-workdir="$CONTAINER_WORKDIR" \
--container-mounts="$CONTAINER_MOUNTS","$SCRIPT_DIR":"$SCRIPT_DIR" \
--job-name="$JOB_NAME" \
--export="$EXPORT" \
--time="$MAX_TIME_LIMIT" \
bash "$SCRIPT_DIR"/activate_and_execute.sh $*