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

# Module A: sweep N for continuous_decay

PROMPTS_FILE=${PROMPTS_FILE:-outputs/stage2/prompts/wjb_adv_good_intervened.json}
OUT_DIR=${OUT_DIR:-outputs/stage2/moduleA_N_sweep}
BASE_MODEL=${BASE_MODEL:-Qwen/Qwen2.5-7B-Instruct}
DETECTORS=${DETECTORS:-configs/detectors_stage1_qwenhx_deficit.json}
CONTROLLER=${CONTROLLER:-configs/controller_stage2_star_qwenhx_stride2_epsm0p5_es2.json}
SELECTED_DIMS=${SELECTED_DIMS:-configs/selected_dims_12.json}
SCORER_DIR=${SCORER_DIR:-outputs/aegis_scorer/ckpt_aegis_scorer_v2_20260117_192621}
MAX_NEW_TOKENS=${MAX_NEW_TOKENS:-256}
SEED=${SEED:-2026}
TEMPERATURE=${TEMPERATURE:-1.0}
TOP_P=${TOP_P:-1.0}
TOP_K=${TOP_K:-0}
DEVICE=${DEVICE:-cuda}

mkdir -p "${OUT_DIR}"

for N in 20 30 40 50; do
  OUT_PATH="${OUT_DIR}/continuous_decay_N${N}.jsonl"
  echo "[run] N=${N} -> ${OUT_PATH}"
  python scripts/run_stage2_joint_cbf_continuous_decay.py \
    --prompts_file "${PROMPTS_FILE}" \
    --output_path "${OUT_PATH}" \
    --detectors_config "${DETECTORS}" \
    --controller_config "${CONTROLLER}" \
    --selected_dims "${SELECTED_DIMS}" \
    --scorer_dir "${SCORER_DIR}" \
    --base_model "${BASE_MODEL}" \
    --max_new_tokens "${MAX_NEW_TOKENS}" \
    --seed "${SEED}" \
    --temperature "${TEMPERATURE}" \
    --top_p "${TOP_P}" \
    --top_k "${TOP_K}" \
    --device "${DEVICE}" \
    --continuous_steps "${N}"
done
