#!/bin/bash
#SBATCH --job-name=merge
#SBATCH --qos=batch
#SBATCH --partition=slurm_partition_name
#SBATCH --gres=gpu:1
#SBATCH --mem=48G
#SBATCH --cpus-per-task=8

# Print GPU information for monitoring
nvidia-smi -L

# Display current working directory and add project to PYTHONPATH if needed
echo "Working directory: $(pwd)"
export PYTHONPATH="$PYTHONPATH:$(pwd)"

# Activate conda environment (adjust the environment name as needed)
source ~/miniconda3/etc/profile.d/conda.sh
conda activate atlas  # Replace with your actual environment name

# Set model and run
MODEL=ViT-B-32
# MODEL=ViT-L-14
PORT=29564 

# MODEL=ViT-L-14
# PORT=29565 


# Display GPU memory information
echo "GPU Memory Information:"
nvidia-smi

# Display CPU memory information available to the job
echo -e "\nCPU Memory Information:"
echo "Total Memory: $(free -h | grep Mem | awk '{print $2}')"
echo "Used Memory: $(free -h | grep Mem | awk '{print $3}')" 
echo "Free Memory: $(free -h | grep Mem | awk '{print $4}')"
echo "Available Memory: $(free -h | grep Mem | awk '{print $7}')"


export WANDB_DIR=/results/wandb
set -e
# RESUME_IDX=$1
# END_IDX=$2

ALL_DATASETS=(
"Cars" "DTD" "EuroSAT" "GTSRB" "MNIST" "RESISC45" "SUN397" "SVHN"
"CIFAR10" "CIFAR100" "ImageNet" "STL10" "Food101" "Caltech101" "Caltech256"
"FGVCAircraft" "Flowers102" "OxfordIIITPet" "CUB200" "PascalVOC" "Country211" "UCF101"
)

# DATASET_NAME="Cars"

DATASET_NAME=$1

# min is 1, max is 20
# RESUME_IDXs=(0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20)
# # always 1 more than the resume idx
# END_IDXs=(1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21)

RESUME_IDXs=(0)
END_IDXs=(1)
# RESUME_IDXs=$1
# END_IDXs=$2

for SOURCE_DATASET_NAME in "${ALL_DATASETS[@]}"; do
    # Skip if source and target datasets are the same
    if [ "$SOURCE_DATASET_NAME" = "$DATASET_NAME" ]; then
        echo "Skipping $SOURCE_DATASET_NAME because source and target datasets are the same"
        continue
    fi
    
    for i in "${!RESUME_IDXs[@]}"; do
        RESUME_IDX=${RESUME_IDXs[$i]}
        END_IDX=${END_IDXs[$i]}
        echo "Running learn coef finetuning target task for model: $MODEL"
        python src/axis_experiments/axis_top_global_corruption_test_single.py \
            --svd-threshold=0.10 \
            --model=$MODEL \
            --target-dataset-name=$DATASET_NAME \
            --source-dataset-name=$SOURCE_DATASET_NAME \
            --blockwise-coef \
            --isoc \
            --resume-from-idx=$RESUME_IDX \
            --end-index=$END_IDX
    done
done   


echo "Job completed at $(date)" 