#!/usr/bin/env bash
# Run ONLY Iterative+context on the 5-kernel subset with Gemini 3.1 Pro.
#
# Completes the {Flash, Pro} x {iterative, iterative+context, Autocomp} grid
# for the model-capacity ablation in Section 5.2 (Figure: trajectory_pro).
# Mirrors run_5kernel_flash_iter_context.sh:
#   18 chains x 8 turns = 144 samples per benchmark, same Autocomp agent
#   profile (architecture + ISA + code examples + rules) prepended.
#
# Output:
#   output/baselines/iterative_context/{prob_id}/summary.json
#   (sibling to the existing Pro iterative/ and best_of_n/ dirs)
set -euo pipefail
cd /path/to/autocomp
export AUTOCOMP_JAXBENCH_PROFILE=1

MODEL="gemini-3.1-pro-preview"
OUTBASE="output/baselines"

KERNELS=(
    "12p_RMSNorm"
    "5p_Flex_Attention"
    "15p_RetNet_Retention"
    "16p_Mamba2_SSD"
    "1p_Flash_Attention"
)

echo "============================================"
echo "Iterative+context on 5-kernel subset"
echo "Model: $MODEL"
echo "Budget: 18 chains x 8 turns = 144 samples/benchmark"
echo "Context: Autocomp's built:tpu-v6e agent profile"
echo "============================================"

for k in "${KERNELS[@]}"; do
    OUT="$OUTBASE/iterative_context/$k"
    if [[ -f "$OUT/summary.json" ]]; then
        echo ""
        echo ">>> Iterative+context: $k  SKIP (summary.json exists)"
        continue
    fi
    echo ""
    echo ">>> Iterative+context: $k"
    python -m autocomp.baselines.iterative \
        --prob_id "$k" \
        --prob_type jaxbench-baseline \
        --num_chains 18 \
        --turns 8 \
        --model "$MODEL" \
        --context full \
        --agent_dir built:tpu-v6e \
        --output_dir "$OUT"
done

echo ""
echo "============================================"
echo "DONE: Iterative+context on 5-kernel subset (Pro)"
echo "============================================"
