#!/bin/bash
#SBATCH --partition=gpu
#SBATCH --gres=gpu:h100:1              # Number of GPUs
#SBATCH --ntasks=1                     # <--- CHANGE THIS
#SBATCH --cpus-per-task=4              # Number of CPU cores per task
#SBATCH --mem=8G                      # Size of cpu memory
#SBATCH --time 0-8:00:00         # Max duration days-hours:minutes:seconds
#SBATCH --mail-user=example@email.com  # Where to send mail
#SBATCH --mail-type=ALL           # Mail events (stop/start job)
#SBATCH --job-name=pbsac_imp_lstd-array     # A single name for the whole array
#SBATCH --output=logs/pbsac_imp_lstd_%A_%a.out  # Log file for each task. %A=jobID, %a=taskID
#SBATCH --error=logs/pbsac_imp_lstd_%A_%a.err   # Error file for each task
#SBATCH --array=0-4                    # Creates n tasks with IDs 0, 1, 2, 3, ...

# --- Configuration ---
WORKDIR="<path-to>/BenchRL/src/benchrl"
PREFIX="HYDRA_FULL_ERROR=1 MUJOCO_GL=egl"
PYFILE="experiments/run_v2.py"
# EXTRA_ARGS="algorithm=pbsac_mujoco environment=mujoco_delayed algorithm.name=pbsac_improved_15_low_std"
EXTRA_ARGS="algorithm=pbsac_mujoco environment=mujoco algorithm.name=pbsac_improved_15_low_std"


# --- Array Logic ---
# A bash array of the seeds you want to run.
SEEDS=(0 1 2 3 4)

# Use the Slurm task ID to get the corresponding seed for this job.
CURRENT_SEED=${SEEDS[$SLURM_ARRAY_TASK_ID]}

echo "Starting Slurm task $SLURM_ARRAY_TASK_ID"
echo "Running with seed: $CURRENT_SEED"

# --- Execution ---
set -e
cd "$WORKDIR"

# Create logs directory if it doesn't exist
mkdir -p logs

# Load the environment module
module load Programming_Languages/python/3.12.2

# Run the command directly. Slurm handles all logging.
env $PREFIX $HOME/.local/bin/poetry run python "$PYFILE" experiment.seed="$CURRENT_SEED" $EXTRA_ARGS

echo "Task $SLURM_ARRAY_TASK_ID finished successfully."