-
Notifications
You must be signed in to change notification settings - Fork 0
/
validate-baskerville.sh
44 lines (37 loc) · 1.1 KB
/
validate-baskerville.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
#!/bin/bash
#SBATCH --qos turing
#SBATCH --account=vjgo8416-climate
#SBATCH --nodes 1
#SBATCH --gpus-per-task 1
#SBATCH --tasks-per-node 1
#SBATCH --gpus 1
#SBATCH --cpus-per-gpu 36
#SBATCH --time 20:00:00
#SBATCH --job-name OpticalFlowTVL1-validation
# drop into baskerville
module purge
module restore system
module load bask-apps/live
module load Python/3.11.3-GCCcore-12.3.0
cd /bask/projects/v/vjgo8416-climate/shared/cloudcasting-validation
# set wandb credentials
export WANDB_API_KEY=f54a416d3367861e299350d1c50ebd22904ffb40
# check if repo exists
if [ ! -d "ocf-optical-flow-tvl1" ]; then
echo "Repo does not exist; cloning..."
git clone https://github.com/alan-turing-institute/ocf-optical-flow-tvl1.git
fi
cd ocf-optical-flow-tvl1
# ensure that we have the latest changes
git pull
# create virtual environment if it doesn't exist
if [ ! -d ".venv" ]; then
echo "Virtual environment does not exist; creating..."
python -m venv .venv
fi
source .venv/bin/activate
pip install -e .
# upgrade jax to run metrics on GPU
pip install --upgrade "jax[cuda12]"
# run validation
cloudcasting validate