#!/usr/bin/env bash
# Table 4 — Mixtral-8x22B-Instruct-v0.1 via HuggingFace Inference API
# (Mixtral-8x7B-Instruct-v0.1 is no longer available via HF's provider network;
#  8x22B is the closest available Mixtral variant.)
# Runs all 4 (O, S) conditions: O∈{1,4} × S∈{1,2}
# Requires HF_TOKEN to be set.
set -euo pipefail

if [[ -z "${HF_TOKEN:-}${HF_API_TOKEN:-}${HUGGINGFACE_TOKEN:-}" ]]; then
  echo "Error: HF_TOKEN (or HF_API_TOKEN / HUGGINGFACE_TOKEN) is not set." >&2
  exit 1
fi

SCRIPT_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)"
REPO_ROOT="$(cd "${SCRIPT_DIR}/../.." && pwd)"
VENV="${REPO_ROOT}/../p311TheRockLM_venv"

if [[ -d "${VENV}" ]]; then
  source "${VENV}/bin/activate"
fi

cd "${REPO_ROOT}"

CONFIG="configs/eval/mixtral_hf_api.yaml"
N_SEEDS=5
N_EPISODES=64
OUTPUT_DIR="outputs/eval/table4/mixtral_hf_api"
WANDB_PROJECT="${WANDB_PROJECT:-meta-rg-s2b}"

for O in 1 4; do
  for S in 1 2; do
    echo "========================================"
    echo "  Mixtral-8x22B (HF API)  O=${O}  S=${S}"
    echo "========================================"
    python run_eval.py \
      --config "${CONFIG}" \
      --o "${O}" \
      --shots "${S}" \
      --n_seeds "${N_SEEDS}" \
      --n_episodes "${N_EPISODES}" \
      --output_dir "${OUTPUT_DIR}" \
      --wandb_project "${WANDB_PROJECT}"
  done
done

echo ""
echo "All Mixtral-8x22B (HF API) conditions complete. Results in ${OUTPUT_DIR}/"
