#!/usr/bin/env bash

# Fire-and-forget launcher for the AntFall dispersion sweep. No CLI arguments
# are parsed – tweak the variables below to change how many seeds run and which
# algo prefix is used.

set -euo pipefail

REPO_ROOT="$(cd "$(dirname "${BASH_SOURCE[0]}")/.." && pwd)"

GPUS=(0)            # Round-robin over these device ids.
# SEEDS=(7 19 23 42 73)
SEEDS=(7)
ALGO_PREFIX="S3_AntFall_oct27"

CVAR_ALPHA=0.1
CVAR_SAMPLES=128
CHANCE_EPS=2.0

DISPERSION_ORDER=(var logdet logtrace dir_perp maxeig anisotropy w2 chance cvar)
declare -A DISPERSION_LABELS=(
  [var]="total_variance"
  [logdet]="log_det"
  [logtrace]="log_trace"
  [dir_perp]="directional_variance"
  [maxeig]="max_eigenvalue"
  [anisotropy]="anisotropy"
  [w2]="wasserstein"
  [chance]="chance_constraint"
  [cvar]="cvar_tail"
)

PIDS=()
NAMES=()

cleanup() {
  if [[ ${#PIDS[@]} -gt 0 ]]; then
    echo
    echo "[WARN] Caught signal – terminating remaining runs..."
    for pid in "${PIDS[@]}"; do
      if kill -0 "${pid}" 2>/dev/null; then
        kill "${pid}" 2>/dev/null || true
      fi
    done
  fi
}
trap cleanup INT TERM

run_index=0
num_gpus=${#GPUS[@]}

for key in "${DISPERSION_ORDER[@]}"; do
  label="${DISPERSION_LABELS[$key]}"

  extra_args=()
  case "${key}" in
    cvar)
      extra_args+=(--disp-alpha "${CVAR_ALPHA}" --disp-samples "${CVAR_SAMPLES}")
      ;;
    chance)
      extra_args+=(--disp-eps "${CHANCE_EPS}" --disp-samples "${CVAR_SAMPLES}")
      ;;
  esac

  for seed in "${SEEDS[@]}"; do
    algo_tag="${ALGO_PREFIX}_${label}_s${seed}"
    gpu="${GPUS[$((run_index % num_gpus))]}"

    cmd=(
      python "${REPO_ROOT}/main.py"
      --env_name AntFall
      --algo "${algo_tag}"
      --dispersion "${key}"
      --seed "${seed}"
    )

    cmd+=("${extra_args[@]}")

    printf '[GPU %s] Launching %s\n' "${gpu}" "${algo_tag}"
    CUDA_VISIBLE_DEVICES="${gpu}" "${cmd[@]}" &
    pid=$!
    PIDS+=("${pid}")
    NAMES+=("${algo_tag}")

    run_index=$((run_index + 1))
  done
done

exit_code=0
for idx in "${!PIDS[@]}"; do
  pid="${PIDS[$idx]}"
  name="${NAMES[$idx]}"
  if ! wait "${pid}"; then
    status=$?
    echo "[ERROR] Run '${name}' exited with code ${status}."
    exit_code=${exit_code:-0}
    if [[ "${exit_code}" -eq 0 ]]; then
      exit_code=${status}
    fi
  fi
done

exit "${exit_code}"
