#!/bin/bash
#SBATCH --partition=s_standard
#SBATCH --exclusive
#SBATCH --mem=32G
#SBATCH --cpus-per-task=8

export executable=./iopddl_ablation

# Define input files and their corresponding timeouts
declare -A problems=(    
    ["A"]="asplos-2025-iopddl-A.json 60 12"
    ["K"]="asplos-2025-iopddl-K.json 180 12"
    ["L"]="asplos-2025-iopddl-L.json 180 12"
    ["M"]="asplos-2025-iopddl-M.json 180 12"
    ["R"]="asplos-2025-iopddl-R.json 240 12"
    ["S"]="asplos-2025-iopddl-S.json 240 12"
    ["F"]="asplos-2025-iopddl-F.json 120 12"
    ["V"]="asplos-2025-iopddl-V.json 300 12" # to get results for comparison with XLA
    ["W"]="asplos-2025-iopddl-W.json 300 30"
    ["X"]="asplos-2025-iopddl-X.json 300 12"
    ["Y"]="asplos-2025-iopddl-Y.json 300 12"
)

# Seeds to use
seeds=(1 43 1457 789 2468 3579 9876 5432 6543 8765)

# Function to run solver and validator for a problem
run_problem() {
    local problem=$1
    local filename=$2
    local timeout=$3
    local seed=$4
    local solver_timeout=$5
    
    export IP="../../benchmarks/$filename"
    $executable $IP $timeout -s $seed -t $5 > "${problem}_solver.out"
}

# Main loop
for seed in "${seeds[@]}"; do
    echo "Processing seed $seed"
    mkdir -p "s$seed"
    cd "s$seed"
    for key in "${!problems[@]}"; do
        read -r filename timeout solver_timeout<<< "${problems[$key]}"
        run_problem "$key" "$filename" "$timeout" "$seed" "$solver_timeout"
    done
    cd ..
done