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

LOG_ROOT="../logs/model"
RES_ROOT="../results/model"
PROB_ROOT="../data"

declare -A MAP=(
    [ipho]="IPhO_2025"
    [apho]="APhO_2025"
    [eupho]="EuPhO_2025"
    [nbpho]="NBPhO_2025"
    [panpho]="PanPhO_2025"
    [panmechanics]="PanMechanics_2025"
    [fma]="F=MA_2025"
)

for ds in "${!MAP[@]}"; do
    upper_file="${MAP[$ds]}"
    (
        echo "[$(date '+%F %T')] === $ds  STEP-1: process_predictions.py ==="
        python process_predictions.py \
            --log-dir    "$LOG_ROOT/$upper_file" \
            --output     "${ds}_2025_with_predictions.json" \
            --output-dir "$RES_ROOT/$ds" \
            --json-file  "$PROB_ROOT/$upper_file.json"
        echo "[$(date '+%F %T')] === $ds  STEP-1  DONE ==="

        echo "[$(date '+%F %T')] === $ds  STEP-2: add_boxed_answers.py ==="
        python add_boxed_answers.py \
            --input      "$RES_ROOT/$ds/${ds}_2025_with_predictions.json" \
            --output-dir "$RES_ROOT/$ds" \
            --output-file "${ds}_2025_with_predictions_boxed.json"
        echo "[$(date '+%F %T')] === $ds  STEP-2  DONE ==="

        echo "[$(date '+%F %T')] === $ds  STEP-3: eval_physics.py ==="
        python eval_physics.py \
            --dataset    "${ds}_2025" \
            --judge-model gemini-2.5-flash \
            --nproc       8 \
            --results-dir "$RES_ROOT/$ds" \
            --output-dir  "$RES_ROOT/$ds"
        echo "[$(date '+%F %T')] === $ds  STEP-3  DONE ==="
    ) &
done

wait
echo "[$(date '+%F %T')] === ALL DATASETS FINISHED ==="