#!/bin/bash

# Creative Reasoning - Run All Algorithms Script
# This script runs all available algorithms from the README sequentially

echo "🚀 Starting Creative Reasoning Algorithm Suite"
echo "=============================================="

# Set default task and LLM
TASK_NAME="electricity"
LLM_NAME="gpt-4o"

# Function to run command with error handling
run_command() {
    local cmd="$1"
    local description="$2"
    
    echo ""
    echo "🔄 Running: $description"
    echo "Command: $cmd"
    echo "----------------------------------------"
    
    if eval "$cmd"; then
        echo "✅ Successfully completed: $description"
    else
        echo "❌ Failed: $description"
        echo "Continuing with next algorithm..."
    fi
}

# Basic Usage
run_command "python -m src.main --task-name $TASK_NAME --algorithm-name commercialized_reasoning_model --backbone-llm-name gpt-4o --num-final-solutions 10" \
    "Commercialized Reasoning Model (GPT-4o)"

# Basic Usage
run_command "python -m src.main --task-name $TASK_NAME --algorithm-name commercialized_reasoning_model --backbone-llm-name gpt-5 --num-final-solutions 10" \
    "Commercialized Reasoning Model (GPT-5)"

# Basic Usage
run_command "python -m src.main --task-name $TASK_NAME --algorithm-name commercialized_reasoning_model --backbone-llm-name deepseek-reasoner --num-final-solutions 10" \
    "Commercialized Reasoning Model (DeepSeek Reasoner)"

# Advanced Algorithms
run_command "python -m src.main --task-name $TASK_NAME --algorithm-name chain_of_thoughts --backbone-llm-name $LLM_NAME --num-final-solutions 10" \
    "Chain of Thoughts"

run_command "python -m src.main --task-name $TASK_NAME --algorithm-name tot --backbone-llm-name $LLM_NAME --num-final-solutions 10" \
    "Tree of Thoughts"

run_command "python -m src.main --task-name $TASK_NAME --algorithm-name egot --backbone-llm-name $LLM_NAME --num-final-solutions 10" \
    "Enhanced Graph of Thoughts (EGoT)"

run_command "python -m src.main --task-name $TASK_NAME --algorithm-name combinational_creative_reasoning --backbone-llm-name $LLM_NAME --num-analogous-problems 50 --num-solutions-per-problem 10 --num-final-solutions 10 --num-solutions-combinational 50 --num-exploratory-ideas 500 --num-new-rule-sets 10" \
    "Combinational Creative Reasoning"

run_command "python -m src.main --task-name $TASK_NAME --algorithm-name exploratory_creative_reasoning --backbone-llm-name $LLM_NAME --num-exploratory-ideas 500 --num-analogous-problems 50 --num-solutions-per-problem 10 --num-final-solutions 10 --num-solutions-combinational 50" \
    "Exploratory Creative Reasoning"

run_command "python -m src.main --task-name $TASK_NAME --algorithm-name transformative_creative_reasoning --backbone-llm-name $LLM_NAME --num-new-rule-sets 10 --num-analogous-problems 50 --num-solutions-per-problem 10 --num-final-solutions 10 --num-solutions-combinational 50 --num-exploratory-ideas 100" \
    "Transformative Creative Reasoning"

echo ""
echo "🎉 All algorithms completed!"
echo "=============================================="
echo "Check the results/results.csv file for detailed outputs."
echo "Each algorithm's results are logged with timestamps and unique solution IDs."
