import os
import yaml
from modules.survey_converter import BinaryExtendedSurvey
from modules.endowment_manager import ActiveEndowments
from modules.response_converter import BinaryExtendedResponses
from experiments.experiments import SimulationExperiment

def load_experiment_from_config(config_path: str, seed: int = None) -> SimulationExperiment:
    """
    Load a SimulationExperiment object using paths and metadata from a YAML config file.

    Args:
        config_path (str): Path to YAML configuration file.
        seed (int, optional): Optional random seed to override config file.

    Returns:
        SimulationExperiment: Loaded experiment object with survey, responses, endowments.
    """
    # Load config
    with open(config_path, "r") as f:
        config = yaml.safe_load(f)

    paths = config["paths"]
    config_seed = config.get("experiment", {}).get("seed", 101)
    seed = seed if seed is not None else config_seed

    # Load survey
    survey = BinaryExtendedSurvey(
        csv_path=paths["survey_csv"],
        config_path=paths["survey_yaml"]
    )

    # Load responses
    responses = BinaryExtendedResponses(
        source=paths["responses_csv"],
        survey=survey,
        output_format="code"
    )

    # Load endowments
    endowments = ActiveEndowments.load(path=paths["endowments_csv"])

    # Assign roles and weights
    role_cfg = config["experiment"].get("role_assignment", {})
    method = role_cfg.get("method", "manual")
    proxy_ratio = role_cfg.get("proxy_ratio", 0.7)
    endowments.assign_roles(method=method, proxy_ratio=proxy_ratio, seed=seed)
    endowments.initialize_ground_truth_weights(seed=seed)

    # Build experiment
    experiment = SimulationExperiment(
        responses=responses,
        survey=survey,
        endowments=endowments,
        aggregate_stats=None,
        filter_binary=True,
        drop_na=True
    )

    return experiment