#!/bin/bash

TARGET_MODEL_NAMES=("gpt-4o-2024-11-20" "DeepSeek-R1-0528")
SHOT_NUMS=(0 3)

CONCLUDE_MODEL_NAME="Your Model Name"
CONCLUDE_MODEL_PATH="path/to/models/${CONCLUDE_MODEL_NAME}"
CONCLUDE_CUDA_DEVICES="2,3"

INPUT_BASE_PATH="../llm-evaluation-api/results"
OUTPUT_BASE_PATH="./results"
LOG_BASE_PATH="logs"

get_tensor_parallel_size() {
    local gpu_devices=$1
    local gpu_count=$(echo "$gpu_devices" | tr ',' '\n' | wc -l | tr -d ' ')
    echo $gpu_count
}

#################### Configuration Validation ####################
echo "Configuration validation passed ✓"
echo "Target model names: ${TARGET_MODEL_NAMES[@]}"
echo "Shot num list: ${SHOT_NUMS[@]}"
echo "Conclude model: ${CONCLUDE_MODEL_NAME}"
echo "Conclude model path: ${CONCLUDE_MODEL_PATH}"
echo "Conclude GPU devices: ${CONCLUDE_CUDA_DEVICES}"
echo "Input file directory: ${INPUT_BASE_PATH}"
echo "Output file directory: ${OUTPUT_BASE_PATH}"
echo "Log file directory: ${LOG_BASE_PATH}"
echo ""

#################### Execute Conclusion Tasks ####################
echo "Starting batch conclusion tasks..."
echo "=================================="

TENSOR_PARALLEL_SIZE=$(get_tensor_parallel_size "$CONCLUDE_CUDA_DEVICES")

for MODEL_NAME in "${TARGET_MODEL_NAMES[@]}"; do
    echo "Processing model inference results: ${MODEL_NAME}"
    for shot_num in "${SHOT_NUMS[@]}"; do
        INPUT_FILE="${INPUT_BASE_PATH}/${MODEL_NAME}-shot${shot_num}.json"
        OUTPUT_FILE="${OUTPUT_BASE_PATH}/${MODEL_NAME}-shot${shot_num}.json"
        LOG_FILE="${LOG_BASE_PATH}/${MODEL_NAME}-shot${shot_num}.log"

        if [ ! -f "$INPUT_FILE" ]; then
            echo "  Skipping: Input file $INPUT_FILE does not exist"
            continue
        fi

        echo "  Concluding: $INPUT_FILE -> $OUTPUT_FILE"
        echo "  Log file: $LOG_FILE"

        CUDA_VISIBLE_DEVICES=${CONCLUDE_CUDA_DEVICES} python conclude_llm.py \
            --model-path "$CONCLUDE_MODEL_PATH" \
            --input-file "$INPUT_FILE" \
            --output-file "$OUTPUT_FILE" \
            --structured-output \
            --tensor-parallel-size ${TENSOR_PARALLEL_SIZE} \
            --max-tokens 2048 \
            --temperature 0.0 \
            > "$LOG_FILE" 2>&1

        if [ $? -eq 0 ]; then
            echo "  ✓ ${MODEL_NAME} shot-num=${shot_num} conclusion completed"
        else
            echo "  ✗ ${MODEL_NAME} shot-num=${shot_num} conclusion failed, check log $LOG_FILE"
        fi
        echo "  ................................."
    done
    echo "All conclusion tasks for model ${MODEL_NAME} completed!"
    echo "=================================="
done

echo "All conclusion tasks for all models completed!"
echo "Result files location: ${OUTPUT_BASE_PATH}/*-shot*.json"
echo "Log files location: ${LOG_BASE_PATH}/*-shot*.log"
