#!/bin/bash

# Script to run the ablation variants

set -e  # Exit on error

# Default values
MODEL="openai/gpt-4o"
WORKERS=6
SCENARIO=""
MAX_EXAMPLES=""

# Parse command line arguments
while [[ $# -gt 0 ]]; do
    case $1 in
        --model)
            MODEL="$2"
            shift 2
            ;;
        --workers)
            WORKERS="$2"
            shift 2
            ;;
        --scenario)
            SCENARIO="$2"
            shift 2
            ;;
        --max-examples)
            MAX_EXAMPLES="$2"
            shift 2
            ;;
        --help)
            echo "Usage: $0 [OPTIONS]"
            echo "Options:"
            echo "  --model MODEL          Model to use (default: openai/gpt-4o)"
            echo "  --workers N            Number of parallel workers (default: 6)"
            echo "  --scenario N           Run specific scenario (1-5)"
            echo "  --max-examples N       Maximum examples per scenario"
            echo "  --help                 Show this help message"
            exit 0
            ;;
        *)
            echo "Unknown option: $1"
            exit 1
            ;;
    esac
done

# Create results directory with timestamp
TIMESTAMP=$(date +%Y%m%d_%H%M%S)
RESULTS_DIR="results_ablations_only_${TIMESTAMP}"
mkdir -p "$RESULTS_DIR"

echo "====================================="
echo "MIRROR Ablation Study (Components Only)"
echo "====================================="
echo "Model: $MODEL"
echo "Workers: $WORKERS"
echo "Results directory: $RESULTS_DIR"
if [ -n "$SCENARIO" ]; then
    echo "Scenario: $SCENARIO"
fi
if [ -n "$MAX_EXAMPLES" ]; then
    echo "Max examples: $MAX_EXAMPLES"
fi
echo "====================================="

# Function to run ablation
run_ablation() {
    local ablation_type=$1
    local prefix=$2
    
    echo ""
    echo "Running $ablation_type ablation..."
    echo "-----------------------------------"
    
    SCRIPT_DIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )"
    
    # Build command with full path
    cmd="python3 \"$SCRIPT_DIR/eval_ablation.py\""
    cmd="$cmd --mirror-model \"$MODEL\""
    cmd="$cmd --model-prefix \"$prefix\""
    cmd="$cmd --results-dir \"$RESULTS_DIR\""
    cmd="$cmd --ablation-type \"$ablation_type\""
    cmd="$cmd --parallel"
    cmd="$cmd --workers $WORKERS"
    
    if [ -n "$SCENARIO" ]; then
        cmd="$cmd --scenario $SCENARIO"
    fi
    
    if [ -n "$MAX_EXAMPLES" ]; then
        cmd="$cmd --max-examples $MAX_EXAMPLES"
    fi
    
    echo "Command: $cmd"
    eval $cmd
}

# Run cognitive-only ablation
echo ""
echo "===== ABLATION 1: Cognitive Controller Only (No Threads) ====="
run_ablation "cognitive_only" "ablation-cognitive-only-"

# Run threads-only ablation
echo ""
echo "===== ABLATION 2: Threads Only (No Cognitive Controller) ====="
run_ablation "threads_only" "ablation-threads-only-"

echo ""
echo "====================================="
echo "Ablation study complete!"
echo "Results saved to: $RESULTS_DIR"
echo "====================================="

# Simple comparison of the two ablations
echo ""
echo "Quick Comparison:"
echo "-----------------"
if [ -f "$RESULTS_DIR/ablation-cognitive-only-"*.xlsx ] && [ -f "$RESULTS_DIR/ablation-threads-only-"*.xlsx ]; then
    echo "✓ Both ablation results generated successfully"
    echo "Use compare_ablations.py for detailed analysis"
else
    echo "⚠ Some results may be missing"
fi 