"""
Example usage:
    python run_multi_fraction_sweep.py --config config/simulations/fraction_sweep.yaml

YAML config should contain:
    runner:
      modes: ["response", "endowment"]
      models: ["lasso", "elasticnet"]
      fractions: "np.linspace(0.1, 1.0, 10)"
      seed: 42
      plot: true
      verbose: true
"""
import argparse
import os
import sys
import yaml
from datetime import datetime
import pandas as pd
import numpy as np

# Ensure project root is in sys.path
project_root = os.path.abspath(os.path.join(os.path.dirname(__file__), ".."))
if project_root not in sys.path:
    sys.path.append(project_root)

from experiments.simulations import run_fraction_sweep
from utils.io import load_experiment_from_config


def run_multi_sweep_from_config(config_path: str):
    # Load config
    with open(config_path, "r") as f:
        config = yaml.safe_load(f)

    # Load experiment
    experiment = load_experiment_from_config(config_path)
    experiment_name = config.get("experiment", {}).get("name", "experiment").lower().replace(" ", "_")

    # Parse runner settings
    runner_cfg = config.get("runner", {})
    modes = runner_cfg.get("modes", ["endowment"])
    models = runner_cfg.get("models", ["lasso"])
    fractions = runner_cfg.get("fractions", [0.2, 0.4, 0.6, 0.8, 1.0])
    if isinstance(fractions, str):
        fractions = eval(fractions, {"np": np})
    seed = runner_cfg.get("seed", 101)
    plot = runner_cfg.get("plot", False)
    verbose = runner_cfg.get("verbose", True)
    output_dir = runner_cfg.get("output_dir", f"outputs/fraction_sweep/{experiment_name}")
    os.makedirs(output_dir, exist_ok=True)

    timestamp = datetime.now().strftime("%Y%m%d_%H%M%S")

    for mode in modes:
        for model_type in models:
            print(f"\n>>> Running {mode} sweep with {model_type} model...")

            # Set paths
            output_csv = os.path.join(output_dir, f"sweep_{mode}_{model_type}_{timestamp}.csv")
            plot_dir = os.path.join(output_dir, f"plots_{mode}_{model_type}_{timestamp}") if plot else None
            config_copy_path = os.path.join(output_dir, f"config_copy_{mode}_{model_type}_{timestamp}.yaml")

            # Save config copy for reproducibility
            with open(config_copy_path, "w") as f_out:
                yaml.dump(config, f_out)

            # Run
            df = run_fraction_sweep(
                base_experiment=experiment,
                config=config,
                fraction_values=fractions,
                mode=mode,
                model_type=model_type,
                seed=seed,
                output_csv=output_csv,
                plot=plot,
                plot_dir=plot_dir,
                verbose=verbose
            )

            print("[✓] Sweep completed. Summary:")
            print(df)


if __name__ == "__main__":
    parser = argparse.ArgumentParser(description="Run multiple response/endowment fraction sweep experiments.")
    parser.add_argument("--config", type=str, required=True, help="Path to YAML config file")
    args = parser.parse_args()
    run_multi_sweep_from_config(args.config)
