#!/usr/bin/env python3
"""
Interactive script to regenerate plots from saved YAML results.

This version allows you to import and use the function programmatically.
"""

import sys
import os

from decomposition_ablation_study_2 import load_and_replot


def quick_replot(yaml_file, baseline_solvers=None, metrics=None):
    """
    Quick function to replot with sensible defaults.

    Parameters:
    -----------
    yaml_file : str
        Path to YAML results file
    baseline_solvers : dict, optional
        Baseline solver results, e.g., {'WS': {'hypervolume': 0.5, 'runtime': 10.0}}
    metrics : list, optional
        List of metrics to plot, defaults to ['hypervolume', 'runtime', 'tour_length']
    """
    if metrics is None:
        metrics = ['hypervolume', 'runtime', 'tour_length']

    return load_and_replot(
        yaml_file=yaml_file,
        plot_metrics=metrics,
        baseline_solvers=baseline_solvers,
        output_suffix='replot'
    )


# ============================================================================
# EXAMPLE USAGE PATTERNS
# ============================================================================

if __name__ == "__main__":

    # Pattern 1: Simple replot with baselines
    # ----------------------------------------
    baseline_solvers = {
        'WS': {'hypervolume': 0.5, 'runtime': 10.0},
        'NSGA-II': {'hypervolume': 0.48, 'runtime': 8.5}
    }

    # Find the most recent YAML file in a directory
    result_dir = 'ablation_results_complete_overlap_thompson'
    yaml_files = [f for f in os.listdir(result_dir) if f.endswith('.yaml')]

    if yaml_files:
        # Sort by modification time and get the most recent
        yaml_files.sort(key=lambda x: os.path.getmtime(os.path.join(result_dir, x)), reverse=True)
        most_recent = os.path.join(result_dir, yaml_files[0])

        print(f"Found most recent YAML: {most_recent}")
        print(f"Last modified: {os.path.getmtime(most_recent)}")

        # Replot with baselines
        quick_replot(
            yaml_file=most_recent,
            baseline_solvers=baseline_solvers,
            metrics=['hypervolume', 'runtime']
        )
    else:
        print(f"No YAML files found in {result_dir}")


    # Pattern 2: Replot multiple files with same baselines
    # -----------------------------------------------------
    # baseline_solvers = {
    #     'WS': {'hypervolume': 0.52, 'runtime': 9.5},
    #     'NSGA-II': {'hypervolume': 0.48, 'runtime': 8.5},
    # }

    # yaml_files = [
    #     'ablation_results/result1.yaml',
    #     'ablation_results/result2.yaml',
    #     'ablation_results/result3.yaml',
    # ]

    # for yaml_file in yaml_files:
    #     if os.path.exists(yaml_file):
    #         print(f"\nProcessing: {yaml_file}")
    #         quick_replot(yaml_file, baseline_solvers=baseline_solvers)


    # Pattern 3: Different baselines for different problem sizes
    # -----------------------------------------------------------
    # baselines_small = {
    #     'WS': {'hypervolume': 0.45, 'runtime': 5.0},
    # }

    # baselines_medium = {
    #     'WS': {'hypervolume': 0.52, 'runtime': 10.0},
    # }

    # baselines_large = {
    #     'WS': {'hypervolume': 0.58, 'runtime': 20.0},
    # }

    # problem_baselines = {
    #     'small': baselines_small,
    #     'medium': baselines_medium,
    #     'large': baselines_large
    # }

    # for problem_size, baselines in problem_baselines.items():
    #     yaml_pattern = f'ablation_results/*_{problem_size}_*.yaml'
    #     # Find matching files and replot...


    # Pattern 4: Only add baselines to hypervolume plots
    # ---------------------------------------------------
    # baseline_solvers = {
    #     'WS': {'hypervolume': 0.5},  # Only HV, no runtime
    #     'NSGA-II': {'hypervolume': 0.48}
    # }

    # quick_replot(
    #     yaml_file='ablation_results/result.yaml',
    #     baseline_solvers=baseline_solvers,
    #     metrics=['hypervolume', 'runtime', 'solutions']
    # )
