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

This script allows you to:
1. Load saved ablation study results from YAML files
2. Add baseline solver reference lines
3. Change which metrics to plot
4. Regenerate plots without re-running experiments

Usage:
------
python replot_from_yaml.py

Then edit the configuration below and run again.
"""

import sys
from decomposition_ablation_study_2 import load_and_replot

# ============================================================================
# CONFIGURATION - EDIT THIS SECTION
# ============================================================================

# Path to your saved YAML file
YAML_FILE = './ablation_results_complete_overlap_UCB/ablation_overlap_decomp_BiTSP_20251228-133548.yaml' #'ablation_results/ablation_overlap_decomp_BiTSP_20250124-143025.yaml'

# Metrics to plot (choose 3 from: 'hypervolume', 'runtime', 'solutions', 'tour_length')
PLOT_METRICS = ['hypervolume', 'runtime', 'tour_length']

# Baseline solver results (optional)
# Set to None if you don't want baseline lines
BASELINE_SOLVERS = {
    'WS-LKH': {'hypervolume': 0.625, 'runtime': 1.8},
    # 'NSGA-II': {'hypervolume': 0.48, 'runtime': 8.5},
    # 'MOEA/D': {'hypervolume': 0.49, 'runtime': 11.0},
}

# Output directory (None = same directory as YAML file)
OUTPUT_DIR = None

# Suffix for output filenames
OUTPUT_SUFFIX = 'with_baselines'

# ============================================================================
# RUN REPLOTTING
# ============================================================================

if __name__ == "__main__":
    print("\n" + "="*80)
    print("REPLOTTING TOOL FOR ABLATION STUDIES")
    print("="*80)
    print(f"\nYAML File: {YAML_FILE}")
    print(f"Metrics: {PLOT_METRICS}")
    if BASELINE_SOLVERS:
        print(f"Baselines: {list(BASELINE_SOLVERS.keys())}")
    print(f"Output Suffix: {OUTPUT_SUFFIX}")

    try:
        results = load_and_replot(
            yaml_file=YAML_FILE,
            plot_metrics=PLOT_METRICS,
            baseline_solvers=BASELINE_SOLVERS,
            output_dir=OUTPUT_DIR,
            output_suffix=OUTPUT_SUFFIX
        )

        print("\n✓ Replotting completed successfully!")

    except FileNotFoundError:
        print(f"\n✗ ERROR: Could not find YAML file: {YAML_FILE}")
        print("Please update the YAML_FILE path in this script.")
        sys.exit(1)

    except Exception as e:
        print(f"\n✗ ERROR: {e}")
        import traceback
        traceback.print_exc()
        sys.exit(1)
