#!/usr/bin/env bash
# on Ctrl+C, kill all background jobs and exit

trap 'echo "Interrupted—stopping all jobs"; jobs -p | xargs -r kill; exit 1' SIGINT

if [ $# -ne 2 ]; then
  echo "Usage: $0 <start_index> <end_index>"
  exit 1
fi
start_idx=$1
end_idx=$2

model="Llama-3.2-1B-Instruct"
# model="Llama-3.2-1B-Instruct_tofu_ep5"
# base_model="Llama-3.2-1B"
finetune_ep=5

settings=(
  # "RESTOR_${model}_tofu_${finetune_ep}ep RESTOR_tofu_${finetune_ep}ep"
  # "tofu_Llama-3.2-1B-Instruct_full tofu"
  # "RESTOR_${model}_tv_ep2_0.75 RESTOR_tv_ep2_0.75"
  # "RESTOR_${model}_tv_ep2_1.0 RESTOR_tv_ep2_1.0"
  # "RESTOR_${model}_tv_ep2_1.5 RESTOR_tv_ep2_1.5"
  # "RESTOR_${model}_tofu_NPO_2ep_a3 RESTOR_tofu_NPO_2ep_a3"
  # "RESTOR_${model}_tofu_NPO_3ep_a3 RESTOR_tofu_NPO_3ep_a3"
  # "RESTOR_${model}_tofu_GradDiff RESTOR_tofu_GradDiff_3ep_a1"
  # "RESTOR_${model}_tofu_NPO_2ep_a5 RESTOR_tofu_NPO_2ep_a5"
  # "RESTOR_${model}_tofu_NPO_3ep_a5 RESTOR_tofu_NPO_3ep_a5"
  # "RESTOR_${model}_tofu_NPO_4ep_a3 RESTOR_tofu_NPO_4ep_a3"
  # "RESTOR_${model}_tofu_NPO_4ep_a5 RESTOR_tofu_NPO_4ep_a5"
  # "RESTOR_${model}_tv_ep2_2.0 RESTOR_tv_ep2_2.0"
  # "RESTOR_${model}_tv_ep3_1.5 RESTOR_tv_ep3_1.5"
  # "RESTOR_${base_model}_tv_ep2_1.0 RESTOR_base_tv_ep2_1.0"
  # "RESTOR_${base_model}_tv_ep2_1.5 RESTOR_base_tv_ep2_1.5"
  # "RESTOR_${base_model}_tv_ep2_2.0 RESTOR_base_tv_ep2_2.0"
  # "RESTOR_${base_model}_tv_ep3_1.0 RESTOR_base_tv_ep3_1.0"
  # "RESTOR_${base_model}_tv_ep3_1.5 RESTOR_base_tv_ep3_1.5"
  # "RESTOR_${base_model}_tv_ep3_2.0 RESTOR_base_tv_ep3_2.0"
  # "RESTOR_${model}_tv_ep2_1.0 RESTOR_corrupted_tv_ep2_1.0"
  # "RESTOR_${model}_tv_ep2_1.5 RESTOR_corrupted_tv_ep2_1.5"
  # "RESTOR_${model}_tv_ep2_2.0 RESTOR_corrupted_tv_ep2_2.0"
  # "RESTOR_Llama-3.2-1B-Instruct_tofu_RMU_3ep_a1 RESTOR_tofu_RMU_3ep_a1"
  # "RESTOR_Llama-3.2-1B-Instruct_tofu_GradDiff_3ep_a1 RESTOR_tofu_GradDiff_3ep_a1"
  # "RESTOR_Llama-3.2-1B-Instruct_tofu_GradDiff_1ep_a3 RESTOR_tofu_GradDiff_1ep_a3"
  # "RESTOR_Llama-3.2-1B-Instruct_tofu_GradDiff_1ep_a5 RESTOR_tofu_GradDiff_1ep_a5"
  "RESTOR_${model}_tofu_NPO_5ep_a5 RESTOR_tofu_NPO_5ep_a5"
  "RESTOR_${model}_tofu_NPO_5ep_a10 RESTOR_tofu_NPO_5ep_a10"
)

# iterate over the specified range of indices
for (( i = start_idx; i <= end_idx; i++ )); do
  setting="${settings[$i]}"
  model=$(echo "$setting" | cut -d' ' -f1)
  short=$(echo "$setting" | cut -d' ' -f2)
  
  echo "Starting all judge runs for model: ${model}"
  # run judge.py for runs 0,1,2 in parallel
  for run in 0 1 2; do
    python judge.py \
      --path_to_output "${model}.json" \
      --run "$run" \
      --filename "${short}_run${run}.json" &
  done

  # wait for all background jobs to finish before aggregating
  wait
  echo "All judge runs completed for model: ${model}"

  # then aggregate
  echo "Running aggregator for \"${short}\""
  python aggregator.py --path_to_judge "${short}"
  echo
done
