import yaml
import argparse
import os
from data import MaterialDataset
from evals.comp import CompositionEvaluator
from evals.charge import ChargeEvaluator
from evals.structure import StructureEvaluator


def comp_eval_main(config):
    """
    Main function for the composition evaluator.
    Loads configuration from YAML file and executes the evaluation pipeline.
    """
    # Create evaluator
    evaluator = CompositionEvaluator(save_dir=config['evaluator']['save_dir'])

    # Training phase
    if config['training']['enabled']:
        training_config = config['training']

        train_dataset = MaterialDataset(**training_config['dataset'])
        property_name = training_config['property_name']
        evaluator.train_model(train_dataset, property_name, training_config.get('model_params', None))

    # Evaluation phase
    if config['evaluation']['enabled']:
        evaluation_config = config['evaluation']
        property_name = evaluation_config['property_name']
        
        # Get list of extxyz files to evaluate
        extxyz_files = evaluation_config['files']
        
        # Evaluate all files
        evaluator.evaluate_files(extxyz_files, property_name)
        
        print(f"Evaluation complete. Predictions saved alongside input files.")


def structure_eval_main(config):
    """
    Main function for the structure evaluator.
    Loads configuration from YAML file and executes the structure evaluation pipeline.
    """
    # Create evaluator
    evaluator = StructureEvaluator()
    
    # Get list of extxyz files to evaluate
    extxyz_files = config['files']
    adf_config = config['adf']
    rdf_config = config['rdf']
    
    # Evaluate all files
    evaluator.evaluate_files(extxyz_files, adf_config, rdf_config)
    
    print("Structure evaluation complete. ADF and RDF data saved alongside input files.")


def charge_eval_main(config):
    """
    Main function for the charge evaluator.
    Loads configuration from YAML file and executes the charge evaluation pipeline.
    """
    # Create evaluator
    evaluator = ChargeEvaluator(**config['evaluator'])

    # Load datasets
    datasets_data = {}
    for run_name, run_config in config['runs'].items():
        dataset = MaterialDataset(**run_config['dataset'])
        datasets_data[run_name] = dataset.samples

    # Evaluate charge distributions
    evaluator.evaluate_datasets(
        datasets_data,
        **config.get('visualization', {})
    )

    print(f"Charge evaluation complete. Results saved to: {evaluator.save_dir}")


if __name__ == "__main__":
    parser = argparse.ArgumentParser()
    parser.add_argument('-s', '--setting', type=str, required=True,
                        help='Path to the configuration YAML file')
    args = parser.parse_args()

    with open(args.setting, 'r') as f:
        config = yaml.safe_load(f)

    for eval_name, eval_config in config.items():
        if eval_name == 'composition':
            comp_eval_main(eval_config)
        elif eval_name == 'structure':
            structure_eval_main(eval_config)
        elif eval_name == 'charge':
            charge_eval_main(eval_config)
        else:
            raise ValueError(f"Unknown evaluation type: {eval_name}")
