#!/bin/bash


# choose XPID from train_scripts/, find XPID for the algorithm, and subsitute this
XPID="ued-BipedalWalker-Adversarial-Easy-v0-domain_randomization-noexpgrad-lr0.0003-epoch5-mb32-v0.5-gc0.5-henv0.01-ha0.001-plr0.9-rho0.5-n1000-st0.5-positive_value_loss-rank-t0.1-editor1.0-random-n3-baseeasy-tl_0"

TEST_ENVS="BipedalWalker-v3,BipedalWalkerHardcore-v3,BipedalWalker-Med-Stairs-v0,BipedalWalker-Med-PitGap-v0,BipedalWalker-Med-StumpHeight-v0,BipedalWalker-Med-Roughness-v0"

# test model tar name with updates number
MODEL_TAR="model_20000"

# final output, change if needed
WIDE_CSV="evaluate_result/robust/robust_results.csv"

NUM_PROCESSES=16
NUM_SEEDS=128
SEED_START=0
EPISODES_PER_SEED=1


# following is the example training model you want to evaluate, input the path of its logging direcotry
BASE_PATHS=(
  "logs/bw_path_1/"
)


echo "[INFO] XPID=${XPID}"
echo "[INFO] MODEL_TAR=${MODEL_TAR}"
echo "[INFO] WIDE_CSV=${WIDE_CSV}"
echo "[INFO] BASE_PATHS count = ${#BASE_PATHS[@]}"
echo

for BASE_PATH in "${BASE_PATHS[@]}"; do
  if [ ! -d "${BASE_PATH}" ]; then
    echo "[WARN] base_path not found, skip: ${BASE_PATH}"
    continue
  fi

  TAG="$(basename "${BASE_PATH}")"
  echo "============================================================"
  echo "[RUN] base_path=${BASE_PATH}"
  echo "[RUN] column_tag=${TAG}"
  echo "============================================================"

  python -m eval_bw_robust \
    --base_path="${BASE_PATH}" \
    --xpid="${XPID}" \
    --model_tar="${MODEL_TAR}" \
    --model_name="agent" \
    --benchmark="bipedal" \
    --env_names="${TEST_ENVS}" \
    --num_processes="${NUM_PROCESSES}" \
    --num_seeds="${NUM_SEEDS}" \
    --seed_start="${SEED_START}" \
    --episodes_per_seed="${EPISODES_PER_SEED}" \
    --deterministic=True \
    --device="cuda" \
    --wide_csv="${WIDE_CSV}"

  echo "[DONE] ${TAG}"
  echo
done

echo "[ALL DONE] wrote/updated: ${WIDE_CSV}"