#!/bin/bash

# Define variables
MODEL_NAME="/data/share_weight/Llama-3.2-11B-Vision-Instruct"
MODEL_QUANTITY=7

# Parse command line arguments
GPU="7"  # Default GPU
while [[ $# -gt 0 ]]; do
    case $1 in
        --gpu|-g)
            GPU="$2"
            shift 2
            ;;
        *)
            echo "Unknown option: $1"
            echo "Usage: $0 [--gpu|-g GPU_NUMBER(S)]"
            echo "Example: $0 --gpu 0,1 (for tensor parallelism across 2 GPUs)"
            exit 1
            ;;
    esac
done

echo "Using GPU(s): $GPU"

# Check if Multi-LLM-Debate environment is already activated
if [[ "$CONDA_DEFAULT_ENV" != "Multi-LLM-Debate" ]]; then
    echo "Activating Multi-LLM-Debate conda environment..."
    eval "$(conda shell.bash hook)"
    conda activate Multi-LLM-Debate
else
    echo "Multi-LLM-Debate conda environment is already activated."
fi

# Define cleanup function
cleanup() {
    echo "Cleaning up..."
    if [[ -n "$SERVER_PID" ]]; then
        echo "Terminating VLLM server (PID: $SERVER_PID)..."
        kill $SERVER_PID 2>/dev/null || true
        # Wait a moment and force kill if still running
        sleep 2
        if kill -0 $SERVER_PID 2>/dev/null; then
            echo "Server still running, force killing..."
            kill -9 $SERVER_PID 2>/dev/null || true
        fi
    fi
    echo "Cleanup complete."
    exit ${1:-0}
}

# Set trap to catch exit signals
trap cleanup SIGINT SIGTERM EXIT

# For port, use the first GPU in case of multiple GPUs
FIRST_GPU=$(echo $GPU | cut -d',' -f1)
PORT=$((8007 + FIRST_GPU * 10))

export VLLM_LOGGING_LEVEL=ERROR

# Check if we have multiple GPUs and set tensor parallelism accordingly
if [[ "$GPU" == *","* ]]; then
    # Count the number of GPUs
    IFS=',' read -ra GPU_ARRAY <<< "$GPU"
    NUM_GPUS=${#GPU_ARRAY[@]}
    
    echo "Using tensor parallelism with ${NUM_GPUS} GPUs"
    # Start VLLM server with tensor parallelism using the number of GPUs provided
    env CUDA_VISIBLE_DEVICES=$GPU vllm serve $MODEL_NAME --host 0.0.0.0 --port $PORT --max-model-len 16000 --tensor-parallel-size ${NUM_GPUS} --gpu-memory-utilization 0.9 --enforce-eager --max-num-seqs 8 &
else
    # Single GPU mode
    # env CUDA_VISIBLE_DEVICES=$GPU vllm serve $MODEL_NAME --host 0.0.0.0 --port $PORT --max-model-len 12000 max-num-seqs=16 --gpu-memory-utilization 0.98 --enforce-eager --max-num-seqs 8 &
    env CUDA_VISIBLE_DEVICES=$GPU vllm serve $MODEL_NAME --host 0.0.0.0 --port $PORT --max-model-len 16000 max-num-seqs=8 --gpu-memory-utilization 0.9 --enforce-eager --max-num-seqs 8 &
fi

SERVER_PID=$!

# Wait for the server to be ready by checking the connection
echo "Waiting for server to start..."
sleep 30
MAX_ATTEMPTS=100
ATTEMPT=2
while ! curl -s "http://localhost:${PORT}/v1/models" > /dev/null 2>&1; do
    if [ $ATTEMPT -ge $MAX_ATTEMPTS ]; then
        echo "Server did not start after $MAX_ATTEMPTS attempts. Exiting."
        cleanup 1
    fi
    echo "Attempt $ATTEMPT: Server not ready yet. Waiting..."
    sleep 6
    ATTEMPT=$((ATTEMPT+1))
done
echo "Server is ready!"

# Define the configuration as a JSON string
CONFIG='[
    [
        {
            "name": "'$MODEL_NAME'",
            "quantity": '$MODEL_QUANTITY',
            "base_url": "http://localhost:'$PORT'/v1"
        }
    ]
]'

# Run the evaluation using module path with direct JSON config
CUDA_VISIBLE_DEVICES=all python -m multi_llm_debate.run.judge_anything_pair.main \
    --task-name "judge_anything_pair" \
    --config-json "$CONFIG" \
    --batch \
    --batch-size 11 \
    --sample-size 800 \

# Run the evaluation using module path with direct JSON config
CUDA_VISIBLE_DEVICES=all python -m multi_llm_debate.run.judge_anything_pair.main \
    --config-json "$CONFIG" \
    --task-name "mllm_judge_pair_pruning" \
    --diversity-pruning "answer" \
    --diversity-pruning-amount 5 \
    --batch \
    --batch-size 11 \
    --sample-size 800 \

cleanup 1

