#!/bin/bash

# Curriculum scheduling mode: dummy, plr, robust_plr, hats (mab-robust_plr)
MODE=${1:-"hats"}
GPU=${2:-"0"}

# default search bounds
MIN_X="-1.0"
MAX_X="1.0"

case $MODE in
    "dummy")
        CURRICULUM_ARGS=""
        NAME_PREFIX="standard-dummy"
        ;;
    "plr")
        CURRICULUM_ARGS="--curriculum --random_stop_grad 0.0"
        NAME_PREFIX="standard-plr"
        ;;
    "robust_plr")
        CURRICULUM_ARGS="--curriculum --random_stop_grad 1.0"
        NAME_PREFIX="standard-robust-plr"
        ;;
    "mab-plr")
        # CEC21 + MAB-based PLR
        CURRICULUM_ARGS="--curriculum --random_stop_grad 0.0 --mab_curriculum --mab_eta 0.5 --mab_gamma 0.95 --mab_epsilon 0.05 --mab_logit_clip 1.5"
        NAME_PREFIX="mab-plr"
        ;;
    "hats"|"mab-robust_plr")
        # HATS: CEC21 + MAB-based Robust PLR (our proposed method)
        CURRICULUM_ARGS="--curriculum --random_stop_grad 1.0 --mab_curriculum --mab_eta 0.5 --mab_gamma 0.95 --mab_epsilon 0.05 --mab_logit_clip 1.5"
        NAME_PREFIX="hats"
        ;;
    *)
        echo "Unknown mode: $MODE. Supported: dummy, plr, robust_plr, mab-plr, hats (mab-robust_plr)"
        exit 1
        ;;
esac

echo "Running in mode: $MODE on GPU: $GPU"

CUDA_VISIBLE_DEVICES=$GPU \
    python3 run.py \
    --train --log_step 1 \
    --run_name ${NAME_PREFIX}-symbol_lp_-0.5_4.0 \
    --epoch_len 18 \
    $CURRICULUM_ARGS \
    --min_x ${MIN_X} --max_x ${MAX_X} \
    --min_c -0.01 --max_c 0.01 \
    --c_interval 0.001 \
    --lgpc_gap_min -0.5 --lgpc_gap_max 4.0
