#!/bin/bash


# ---------------- Common config ----------------

# choose the corresponding XPID from train_scripts of the specific algorithm
XPID="ued-MultiGrid-GoalLastEmptyAdversarialEnv-Edit-v0-domain_randomization-noexpgrad-lstm256a-lr0.0001-epoch5-mb1-v0.5-gc0.5-henv0.0-ha0.0-plr0.8-rho0.5-n4000-st0.3-positive_value_loss-rank-t0.3-editor1.0-random-n5-baseeasy-tl_0" 
CKPT_NAME="model_20000.tar"
ENV_NAME="MultiGrid-Seeded-v0"


NUM_SEEDS=1000
SEED_START=1
EPISODES_PER_SEED=1
NUM_PROCESSES=5

OUT_DIR="eval_results/general"

# ------------------------------------------------
# select the algorithm log directory
RUN_DIRS=(
  "logs/MG_PATH_1/${XPID}"
)

SAFE_ENV="${ENV_NAME//[^a-zA-Z0-9._-]/_}"

for RUN_DIR in "${RUN_DIRS[@]}"; do
  echo "============================================================"
  echo "[Eval] XPID=$XPID"
  echo "[Eval] RUN_DIR=$RUN_DIR"
  echo "============================================================"

  TAG="$(basename "$RUN_DIR")"
  OUT_CSV="${OUT_DIR}/mg_accel_20k_general.csv"
  echo "[Eval] OUT_CSV=$OUT_CSV"

  # basic checks
  if [[ ! -f "${RUN_DIR}/meta.json" ]]; then
    echo "[Skip] meta.json not found in ${RUN_DIR}"
    continue
  fi
  if [[ ! -f "${RUN_DIR}/${CKPT_NAME}" ]]; then
    echo "[Skip] checkpoint not found: ${RUN_DIR}/${CKPT_NAME}"
    continue
  fi

 
  python -m eval_minigrid_generalization \
    --run_dir "$RUN_DIR" \
    --env_name "$ENV_NAME" \
    --checkpoint_name "$CKPT_NAME" \
    --model_name agent \
    --num_seeds "$NUM_SEEDS" \
    --seed_start "$SEED_START" \
    --episodes_per_seed "$EPISODES_PER_SEED" \
    --num_processes "$NUM_PROCESSES" \
    --result_csv "$OUT_CSV"

done

echo "[Done] All evaluations finished."