#!/bin/bash

set -e

do_execution=false
force=false

# Parse command line arguments
while [[ $# -gt 0 ]]; do
    case $1 in
        -g)
            do_execution=true
            shift
            ;;
        -f)
            force=true
            shift
            ;;
        *)
            echo "Invalid option: $1" >&2
            exit 1
            ;;
    esac
done

for domain_name in "logistics" "household" "fb-lamp"; do
    # Set models based on domain
    if [ "$domain_name" == "logistics" ]; then
        models=("openrouter:meta-llama/llama-4-maverick" "openrouter:meta-llama/llama-4-scout" "gpt4.1-mini")
    elif [ "$domain_name" == "fb-lamp" ]; then
        models=("gpt4.1-mini")
    else
        models=("openrouter:meta-llama/llama-4-maverick" "gpt4.1-mini")
    fi
    
    for llm in "${models[@]}"; do
        # for variant in "guan" "sadegh" "lodge"; do
        for variant in "sadegh"; do
            echo "============================================================"
            echo "Running domain: $domain_name, LLM: $llm, Variant: $variant"

            # Set suffix 
            if [ "$variant" == "lodge" ]; then
                if [[ $domain_name == fb-* ]]; then
                    suffix="planning-*/sample-*"
                else
                    suffix="iclr-w-dk-w-ai-shared/sample-*"
                fi
            elif [ "$variant" == "sadegh" ]; then
                suffix="*docstrings/seed_*"
            elif [ "$variant" == "lionel" ]; then
                suffix="no-docstrings"
            elif [ "$variant" == "guan" ]; then
                suffix="docstrings/sample-*"
            elif [ "$variant" == "cluster" ]; then
                suffix="*-based/sample-*"
            else
                suffix=""
            fi

            echo "Using suffix: $suffix"

            if $do_execution; then
                echo "--- generate domain ----------------------------------------"
                if [ "$variant" == "sadegh" ]; then
                    python demos/scripts/01-gen_domain_for_sadegh.py --domain ${domain_name} --llm ${llm} --no-docstrings
                    python demos/scripts/01-gen_domain_for_sadegh.py --domain ${domain_name} --llm ${llm} 
                elif [ "$variant" == "lodge" ]; then
                    lodge_args=(
                        --domain ${domain_name}
                        --llm ${llm}
                        --suffix ${suffix}
                        --use-domain-knowledge
                        --no-docstrings
                        --learn-one-domain
                    )
                    if [[ $domain_name != fb-* ]]; then
                        lodge_args+=(--use-ai-planner)
                    fi
                    python demos/scripts/01-gen_domain_for_lodge.py "${lodge_args[@]}"
                elif [ "$variant" == "lionel" ]; then
                    python demos/scripts/01-gen_domain_for_lionel.py --domain ${domain_name} --llm ${llm} --no-docstrings
                elif [ "$variant" == "guan" ]; then
                    python demos/scripts/01-gen_domain_for_guan.py --domain ${domain_name} --llm ${llm}
                elif [ "$variant" == "cluster" ]; then
                    python demos/scripts/01-gen_domain_for_cluster.py --domain ${domain_name} --llm ${llm}
                fi
            fi

            echo "--- evaluate domain ----------------------------------------"
            args=()
            if $force; then
                args+=("--force")
            fi
            python demos/scripts/02-eval-domain.py \
                --domain ${domain_name} \
                --llm ${llm} \
                --variant ${variant} \
                --suffix "${suffix}" \
                --parallel \
                "${args[@]}"
        done
    done
done

echo "============================================================"

python demos/scripts/03-sum-eval.py