#!/usr/bin/env bash
export CUDA_VISIBLE_DEVICES=2 # ,1,2
set -euo pipefail

NET="vit_tiny"
SEED=0
LR=0.005
OPT="AdamW"
EPOCHS=300

PLOT_PATH="./images/wd_reg"
IMGS="500,5000"

# 1-2-5 * 10^k grid, covering [5e-5, 2.0]
RHOS=(
  0.00005
  0.0001 0.0002 0.0005
  0.001  0.002  0.005
  0.01   0.02   0.05
  0.1    0.2    0.5
  1.0    2.0
)

LOG_ROOT="./logs/asam_rho_125_sweep/${NET}/seed_${SEED}"
mkdir -p "${LOG_ROOT}"

echo "Rhos to sweep:"
printf '%s\n' "${RHOS[@]}"
echo

for RHO in "${RHOS[@]}"; do
  RHO_TAG=$(echo "${RHO}" | sed 's/\./p/g')
  EXP_NAME="${NET}_no_aug_asam_rho_${RHO_TAG}"
  LOG_FILE="${LOG_ROOT}/${EXP_NAME}.log"

  echo "============================================================"
  echo "Running: ${EXP_NAME} (rho=${RHO})"
  echo "Log: ${LOG_FILE}"
  echo "============================================================"

  python train_sam.py \
    --net "${NET}" \
    --set_seed "${SEED}" \
    --save_net "${EXP_NAME}" \
    --plot_path "${PLOT_PATH}" \
    --imgs "${IMGS}" \
    --lr "${LR}" \
    --opt "${OPT}" \
    --epochs "${EPOCHS}" \
    --sam \
    --adaptive_sam \
    --rho "${RHO}" 2>&1 | tee "${LOG_FILE}"

  echo
done

echo "All ASAM experiments finished."
echo "Logs saved under: ${LOG_ROOT}"
echo "To see best epochs quickly:"
echo "  grep -H \"The best epoch is\" ${LOG_ROOT}/*.log"
