#!/usr/bin/env bash
# Run ONLY Iterative+context on the 5-kernel subset with Gemini 3 Flash.
#
# "Iterative+context" = the same iterative refinement algorithm
# (--num_chains 18 --turns 8, 144 samples total), but the prompt is
# prepended with Autocomp's full agent profile:
#   architecture.md + per-problem ISA sections + code examples + rules.yaml
#
# This isolates "context quality" from "search algorithm" in the paper:
#   minimal iterative  vs.  iterative+context  vs.  Autocomp (beam search)
#
# Output:
#   output/baselines-flash/iterative_context/{prob_id}/summary.json
set -euo pipefail
cd /path/to/autocomp
export AUTOCOMP_JAXBENCH_PROFILE=1

MODEL="gemini-3-flash-preview"
OUTBASE="output/baselines-flash"

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
    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 "$OUTBASE/iterative_context/$k"
done

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