-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathrun_bert_mnli_zero_shot.sh
More file actions
88 lines (72 loc) · 2.43 KB
/
run_bert_mnli_zero_shot.sh
File metadata and controls
88 lines (72 loc) · 2.43 KB
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
79
80
81
82
83
84
85
86
87
88
#!/bin/bash
#SBATCH --partition=gpu
#SBATCH --nodes=1
#SBATCH --gres=gpu:1
#SBATCH --time=02:00:00
#SBATCH --job-name=bert_mnli_zs
#SBATCH --mem=16GB
#SBATCH --ntasks=1
#SBATCH --cpus-per-task=4
#SBATCH --output=logs/bert_mnli_zs_%j.out
#SBATCH --error=logs/bert_mnli_zs_%j.err
echo "=========================================="
echo " BERT-MNLI ZERO-SHOT (NEU GPU) "
echo "=========================================="
echo "Job started at: $(date)"
echo "Job ID: $SLURM_JOB_ID"
echo "Node: $SLURM_NODELIST"
echo "Submit dir: $SLURM_SUBMIT_DIR"
echo "=========================================="
echo ""
mkdir -p logs
# -------------------------------------------
# Load modules (Explorer)
# -------------------------------------------
module load anaconda3/2024.06
module load cuda/12.1.1
# -------------------------------------------
# Enable conda and activate env
# -------------------------------------------
source /shared/EL9/explorer/anaconda3/2024.06/etc/profile.d/conda.sh
conda activate cs4120-bert
echo "Environment activated."
echo "Python executable: $(which python)"
python -c "import sys; print('sys.executable:', sys.executable)"
echo ""
# -------------------------------------------
# Quick GPU sanity check
# -------------------------------------------
echo "=========================================="
echo " GPU CHECK "
echo "=========================================="
python << 'EOF'
import torch
print("PyTorch:", torch.__version__)
print("CUDA available:", torch.cuda.is_available())
print("CUDA version:", torch.version.cuda)
if torch.cuda.is_available():
print("GPU:", torch.cuda.get_device_name(0))
props = torch.cuda.get_device_properties(0)
print("Total GPU Memory: {:.2f} GB".format(props.total_memory / 1e9))
print()
EOF
# -------------------------------------------
# Run zero-shot script
# -------------------------------------------
echo "=========================================="
echo " RUNNING BERT-MNLI ZERO-SHOT "
echo "=========================================="
START_TIME=$(date +%s)
cd "$SLURM_SUBMIT_DIR"
echo "Working directory: $(pwd)"
echo ""
python -m mnli_tuned_model.bert_mnli_zero_shot
END_TIME=$(date +%s)
ELAPSED=$((END_TIME - START_TIME))
echo ""
echo "=========================================="
echo " JOB COMPLETED "
echo "=========================================="
echo "Total time: $ELAPSED seconds ($((ELAPSED/60)) minutes)"
echo "Finished at: $(date)"
echo "=========================================="