#!/usr/bin/env bash
# Table 4 — Llama-3.2-1B-Instruct via HuggingFace Inference API (provider: auto)
# 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/llama_hf_api.yaml"
N_SEEDS=5
N_EPISODES=64
OUTPUT_DIR="outputs/eval/table4/llama_hf_api"
WANDB_PROJECT="${WANDB_PROJECT:-meta-rg-s2b}"

for O in 1 4; do
  for S in 1 2; do
    echo "========================================"
    echo "  Llama-3.2-1B (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 Llama-3.2-1B (HF API) conditions complete. Results in ${OUTPUT_DIR}/"
