-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathrun_roberta_random.sh
More file actions
99 lines (82 loc) · 2.82 KB
/
run_roberta_random.sh
File metadata and controls
99 lines (82 loc) · 2.82 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
94
95
96
97
98
99
#!/bin/bash
#SBATCH --partition=gpu
#SBATCH --nodes=1
#SBATCH --gres=gpu:1
#SBATCH --time=08:00:00
#SBATCH --job-name=plm_roberta_large_search
#SBATCH --mem=24GB
#SBATCH --ntasks=1
#SBATCH --cpus-per-task=4
#SBATCH --output=logs/plm_roberta_large_%j.out
#SBATCH --error=logs/plm_roberta_large_%j.err
echo "=========================================="
echo " PLM RANDOM SEARCH – roberta-large "
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
# -------------------------------------------
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
# -------------------------------------------
# Set model to roberta-large
# -------------------------------------------
export PLM_MODEL_NAME="roberta-large"
echo "Using PLM_MODEL_NAME=${PLM_MODEL_NAME}"
echo ""
# -------------------------------------------
# Run PLM random search
# -------------------------------------------
echo "=========================================="
echo " RUNNING RANDOM SEARCH (MODEL = ${PLM_MODEL_NAME}) "
echo "=========================================="
START_TIME=$(date +%s)
cd "$SLURM_SUBMIT_DIR"
echo "Working directory: $(pwd)"
echo ""
# If plm_random_search.py is in a plm/ package:
python -m pretrained_lm.plm_random_search
# If it's in the current directory instead, use:
# python plm_random_search.py
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 "=========================================="