forked from DonnyLe/NLP-Final-Project
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathrun_bert_random.sh
More file actions
93 lines (76 loc) · 2.65 KB
/
run_bert_random.sh
File metadata and controls
93 lines (76 loc) · 2.65 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
89
90
91
92
93
#!/bin/bash
#SBATCH --partition=gpu
#SBATCH --nodes=1
#SBATCH --gres=gpu:1
#SBATCH --time=08:00:00
#SBATCH --job-name=bert_cascade_plm
#SBATCH --mem=16GB
#SBATCH --ntasks=1
#SBATCH --cpus-per-task=4
#SBATCH --output=logs/bert_cascade_plm_%j.out
#SBATCH --error=logs/bert_cascade_plm_%j.err
echo "=========================================="
echo " BERT-BASE CASCADED BINARY (HC vs Non-HC, MCI vs Dementia) "
echo " Module: plm_cascade (MODEL_NAME=bert-base-uncased) "
echo "=========================================="
echo "Job started at: $(date)"
echo "Job ID: $SLURM_JOB_ID"
echo "Node: $SLURM_NODELIST"
echo "Submit dir: $SLURM_SUBMIT_DIR"
echo "=========================================="
echo ""
# Create logs directory
mkdir -p logs
# -------------------------------------------
# Load modules (Explorer)
# -------------------------------------------
module load anaconda3/2024.06
module load cuda/12.1.1
# -------------------------------------------
# Enable conda and activate env
# -------------------------------------------
# This line is CRUCIAL in batch jobs
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 ""
# -------------------------------------------
# GPU 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 PLM cascaded script with BERT-base
# -------------------------------------------
echo "=========================================="
echo " RUNNING plm_cascade.py (PLM_MODEL_NAME=bert-base-uncased) "
echo "=========================================="
START_TIME=$(date +%s)
cd "$SLURM_SUBMIT_DIR"
echo "Working directory: $(pwd)"
echo ""
export PLM_MODEL_NAME=bert-base-uncased
python -m pretrained_lm.plm_cascade
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 "=========================================="