#!/usr/bin/env bash
set -euo pipefail

# ============================================
# Configuration - Edit these values as needed
# ============================================

# Environment parameters
N=100
ALPHA=0.05
M=0.45
MU=0.40
CONC=1.0
# Parameterize output names by m, mu, and N (e.g., m0.43_mu0.40_n100)
SUFFIX="m${M}_mu${MU}_n${N}_conc${CONC}"
# File paths
POLICY_PATH="checkpoints/DQN.pt"
PLOT_DIR="plots"
REJECTION_PLOT="$PLOT_DIR/rejection_curves_$SUFFIX.pdf"
EPS_PLOT="$PLOT_DIR/eps_on_logwealth_$SUFFIX.pdf"
MODAL_EPS_PLOT="$PLOT_DIR/modal_eps_grid_$SUFFIX.pdf"
MODAL_CONFIDENCE_PLOT="$PLOT_DIR/modal_confidence_grid_$SUFFIX.pdf"
MIN_VISITS=20
MODAL_GRID_TRIALS=10000
T_BIN_WIDTH=5

# Hedge parameters
ETA=0
GAMMA=0
SCORE_MODE="capital"  # "shadow" or "capital"



# Python entrypoint (wrapper around the modular dqn/ package)
PYTHON_SCRIPT="dqn_entrypoint.py"




# ============================================
# Run evaluation
# ============================================

echo "========================================="
echo "DQN Evaluation Configuration:"
echo "========================================="
echo "Environment:"
echo "  N (horizon): $N"
echo "  alpha: $ALPHA"
echo "  m (null): $M"
echo "  mu (true): $MU"
echo ""
echo "Input/Output:"
echo "  Policy file: $POLICY_PATH"
echo "  Rejection plot: $REJECTION_PLOT"
echo "  Epsilon plot: $EPS_PLOT"
echo "  Modal epsilon grid plot: $MODAL_EPS_PLOT"
echo "  Modal confidence grid plot: $MODAL_CONFIDENCE_PLOT"
echo "  Min visits for masking: $MIN_VISITS"
echo "  Modal grid evaluation trials: $MODAL_GRID_TRIALS"
echo "  Time bin width: $T_BIN_WIDTH"
echo ""

# Ensure output directory exists
mkdir -p "$PLOT_DIR"

python "$PYTHON_SCRIPT" evaluate \
    --policy_path "$POLICY_PATH" \
    --N "$N" \
    --alpha "$ALPHA" \
    --m "$M" \
    --mu "$MU" \
    --rejection_plot "$REJECTION_PLOT" \
    --eps_plot "$EPS_PLOT" \
    --modal_eps_plot "$MODAL_EPS_PLOT" \
    --modal_confidence_plot "$MODAL_CONFIDENCE_PLOT" \
    --min_visits "$MIN_VISITS" \
    --modal_grid_trials "$MODAL_GRID_TRIALS" \
    --t_bin_width "$T_BIN_WIDTH" \
    --conc "$CONC" \
    --expweights_eta "$ETA" \
    --expweights_gamma "$GAMMA" \
    --expweights_score_mode "$SCORE_MODE" \
    --include_star \
    --include_expweights_hedge

EXIT_CODE=$?

if [ $EXIT_CODE -eq 0 ]; then
    echo ""
    echo "========================================="
    echo "Evaluation completed successfully!"
    echo "========================================="
else
    echo ""
    echo "========================================="
    echo "Evaluation failed with exit code $EXIT_CODE"
    echo "========================================="
    exit $EXIT_CODE
fi

