#!/bin/bash

# Usage:
#   ./scripts/eval.sh <model_version> <room_type>

# --- Argument Parsing ---
MODEL_VERSION=$1
ROOM_TYPE=$2

if [ -z "$MODEL_VERSION" ] || [ -z "$ROOM_TYPE" ]; then
    echo "Error: Model version and room type are required."
    echo "Usage: $0 <model_version> <room_type>"
    exit 1
fi

if [[ "$ROOM_TYPE" != "bed" && "$ROOM_TYPE" != "living" && "$ROOM_TYPE" != "dining" ]]; then
    echo "Error: Invalid room type '${ROOM_TYPE}'. Must be one of 'bed', 'living', 'dining'."
    exit 1
fi

# --- Configuration ---
# GPU to use
export CUDA_VISIBLE_DEVICES=0
# Temperatures for sampling. Add more values if needed.
TEMPERATURES=(0)
# --- End Configuration ---

export PYTHONPATH="$(pwd):${PYTHONPATH}"
BASE_OUTPUT_DIR="output/scenenat"

echo "Starting evaluation for model version: ${MODEL_VERSION}"
echo "Room type: ${ROOM_TYPE}"
echo "Checkpoint setting: ${ROOM_TYPE}.pth"
echo "Output directory will be based in: ${BASE_OUTPUT_DIR}"
echo "========================================"

for temp in "${TEMPERATURES[@]}"; do
    echo "--- Running for Room: ${ROOM_TYPE}, Temperature: ${temp} ---"

    # Construct checkpoint loading arguments
    CHECKPOINT_ARG="--checkpoint_file ${ROOM_TYPE}.pth"

    python -m src.tasks.eval \
        --model_version ${MODEL_VERSION} \
        --output_dir ${BASE_OUTPUT_DIR} \
        --tag ${ROOM_TYPE} \
        --temperature ${temp} \
        # --visualize \
        ${CHECKPOINT_ARG}
    
    if [ $? -ne 0 ]; then
        echo "Evaluation failed for room: ${ROOM_TYPE}, temp: ${temp}"
        exit 1
    fi

    echo "--- Finished for Room: ${ROOM_TYPE}, Temperature: ${temp} ---"
done

echo "========================================"
echo "Evaluation completed successfully."
