#!/bin/bash
#SBATCH --job-name=atlas
#SBATCH --qos=batch
#SBATCH --partition=slurm_partition_name
#SBATCH --gres=gpu:1
#SBATCH --mem=64G
#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
PORT=29530 

# 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}')"

DATASET_NAME=$1

echo "Running learn coef finetuning target task for model: $MODEL"
RESUME_IDXs=(20)
END_IDXs=(21)
SUBSAMPLEs=(0.05 0.1 0.25 0.35 0.5 0.75 0.95)

for SUBSAMPLE in "${SUBSAMPLEs[@]}"; do
    for i in "${!RESUME_IDXs[@]}"; do
        RESUME_IDX=${RESUME_IDXs[$i]}
        END_IDX=${END_IDXs[$i]}
        python src/atlas_experiments/atlas.py --model=$MODEL --target-dataset-name=$DATASET_NAME --total-trainable-params 3648 --resume-from-idx $RESUME_IDX --end-index $END_IDX --subsample=$SUBSAMPLE
    done
done

echo "Job completed at $(date)" 
