#!/bin/zsh
#SBATCH --mem=20g
#SBATCH -c 2
#SBATCH --time=4-0
#SBATCH --gres gg:g0:1
#SBATCH --exclude=dumfries-009,dumfries-008,dumfries-001,dumfries-002,dumfries-003,dumfries-004,dumfries-005,dumfries-006,dumfries-007,dumfries-010

#SBATCH --mail-type=END,FAIL,TIME_LIMIT
#SBATCH --array=0-9


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

# Define directories

cd $dir
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
# Activate the virtual environment
task_id=${SLURM_ARRAY_TASK_ID}
method="simclr"
dataset="cifar100"
for seed in {0..4}; do
    # Run pretraining and capture wandb ID
    output=$(python main_pretrain.py --config-path scripts/pretrain/cifar/ --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
    python 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 CL/data/avalanche/$dataset/cifar-100-batches-py \
        --feature_type backbone \
        --batch_size 10

    ## copy the results to the representations folder
    python ../copy_files.py CL/solo_learn/trained_models/$method/$run_id --dataset $dataset --seed $seed --method $method
done