#!/usr/bin/env bash

# Launcher for AntFall with annealed exploration noise.

set -euo pipefail

SEED=${SEED:-19}
GPU=${GPU:-0}
MAN_REW=${MAN_REW:-0.24}
MAN_NOISE_START=${MAN_NOISE_START:-0.5}
MAN_NOISE_FINAL=${MAN_NOISE_FINAL:-0.1}
CTRL_NOISE_START=${CTRL_NOISE_START:-0.8}
CTRL_NOISE_FINAL=${CTRL_NOISE_FINAL:-0.3}
ANNEAL_START=${ANNEAL_START:-100000}
ANNEAL_STEPS=${ANNEAL_STEPS:-800000}
USE_ADJ=${USE_ADJ:-1}

if [[ "$USE_ADJ" -eq 0 ]]; then
  echo "[GPU ${GPU}] Running AntFall (seed=${SEED}) with annealed noise (adj_net=off)"
else
  echo "[GPU ${GPU}] Running AntFall (seed=${SEED}) with annealed noise (adj_net=on)"
fi

ARGS=(
  --env_name AntFall
  --algo "HAWK_AntFall_s${SEED}_annealed_noise"
  --seed "$SEED"
  --man_rew_scale "$MAN_REW"
  --manager_propose_freq 10
  --train_manager_freq 10
  --man_ctrl_rew_balance_start 0.1
  --man_ctrl_rew_balance_end 0.22
  --man_ctrl_rew_balance_steps 320000
  --man_noise_sigma "$MAN_NOISE_START"
  --man_noise_sigma_final "$MAN_NOISE_FINAL"
  --ctrl_noise_sigma "$CTRL_NOISE_START"
  --ctrl_noise_sigma_final "$CTRL_NOISE_FINAL"
  --noise_anneal_start "$ANNEAL_START"
  --noise_anneal_steps "$ANNEAL_STEPS"
  --reach_warmup_samples 3000
  --reach_warmup_rounds 1
)

if [[ "$USE_ADJ" -eq 0 ]]; then
  ARGS+=(--disable_adj_net)
fi

CUDA_VISIBLE_DEVICES=$GPU \
python main.py "${ARGS[@]}"

echo "Run finished."
