#!/bin/zsh
#SBATCH --mem=20g
#SBATCH -c 2
#SBATCH --time=4-0
#SBATCH --gres gg:g0:1
#SBATCH --mail-type=END,FAIL,TIME_LIMIT
#SBATCH --array=0-149%12


echo "Starting job with ID: ${SLURM_JOB_ID}"


run_dir="$dir/representations/run_${SLURM_ARRAY_JOB_ID}"

# Activate the virtual environment

# Create the run directory using the main job ID (SLURM_ARRAY_JOB_ID)
mkdir -p $run_dir

methods=("simclr" "vicreg" "dino")
total_seeds=5
total_tasks=10
total_methods=${#methods[@]}
method_idx=$(( SLURM_ARRAY_TASK_ID / (total_seeds * total_tasks) ))
seed=$(( (SLURM_ARRAY_TASK_ID / total_tasks) % total_seeds ))
task_id=$(( SLURM_ARRAY_TASK_ID % total_tasks ))
method=${methods[$method_idx + 1]}

dataset="tinyimg"
echo "Method: $method | Seed: $seed | Task ID: $task_id"

# Run pretraining and capture wandb ID
/bin/python3.9 CL/solo_learn/check.py
output=$(/bin/python3.9 CL/solo_learn/main_pretrain.py --config-path scripts/pretrain/${dataset}/ --config-name $method.yaml +seed=$seed +id=${task_id})

# Extract the run ID
run_id=$(echo "$output" | grep "WANDB_RUN_ID:" | cut -d':' -f2)

# Run KNN evaluation
/bin/python3.9 main_knn.py --seed $seed --exp ${task_id} \
    --pretrained_checkpoint_dir CL/solo_learn/trained_models/$method/$run_id \
    --k 20 \
    --distance_function euclidean \
    --dataset $dataset \
    --train_data_path data/avalanche/tiny_imagenet/train \
    --feature_type backbone \
    --batch_size 10

