import os
import subprocess
from dotenv import load_dotenv
import time

def run_experiment(experiment_name):
    """
    Run experiments with multiple LLM models using environment variables.
    
    Args:
        experiment_name: Name of the experiment (used for output files)
    """
    # Load environment variables
    load_dotenv()
    
    # Get API keys and model names
    openrouter_key = os.getenv('OPENROUTER_KEY')
    openai_key = os.getenv('OPENAI_KEY')
    
    llama_model = os.getenv('LLAMA_model')
    gemini_model = os.getenv('GEMINI_model')
    openai_model = os.getenv('OPENAI_model')
    
    # Timestamp for unique experiment identification
    timestamp = time.strftime("%Y%m%d_%H%M%S")
    
    # Common arguments for all runs
    base_args = [
        'python', 'main.py',
        '--batch',
        '--no_plot',
        '--adaptive',
        '--num_runs', '3',  # You can adjust this
    ]
    
    # Define experiments
    experiments = [
        {
            'name': 'openai',
            'api_key': openai_key,
            'provider': 'openai',
            'model': openai_model
        },
        {
            'name': 'llama',
            'api_key': openrouter_key,
            'provider': 'openrouter',
            'model': llama_model
        },
        {
            'name': 'gemini',
            'api_key': openrouter_key,
            'provider': 'openrouter',
            'model': gemini_model
        }
    ]
    
    # Run each experiment
    for exp in experiments:
        print(f"\n{'='*50}")
        print(f"Running experiment with {exp['name']} model")
        print(f"Model: {exp['model']}")
        print(f"{'='*50}\n")
        
        # Create experiment-specific output directory
        output_dir = f"results/{experiment_name}/{timestamp}/{exp['name']}"
        os.makedirs(output_dir, exist_ok=True)
        
        # Build command for this experiment
        cmd = base_args + [
            '--api_key', exp['api_key'],
            '--llm_provider', exp['provider'],
            '--llm_model', exp['model']
        ]
        
        try:
            # Run the experiment
            process = subprocess.run(
                cmd,
                check=True,
                text=True,
                capture_output=True
            )
            
            # Save output to files
            with open(f"{output_dir}/stdout.txt", 'w') as f:
                f.write(process.stdout)
            with open(f"{output_dir}/stderr.txt", 'w') as f:
                f.write(process.stderr)
            
            print(f"Experiment with {exp['name']} completed successfully")
            print(f"Results saved in {output_dir}")
            
        except subprocess.CalledProcessError as e:
            print(f"Error running experiment with {exp['name']}")
            print(f"Exit code: {e.returncode}")
            print(f"Error output: {e.stderr}")
            
            # Save error output
            with open(f"{output_dir}/error.txt", 'w') as f:
                f.write(f"Exit code: {e.returncode}\n")
                f.write(f"Error output:\n{e.stderr}")
            
            continue

if __name__ == "__main__":
    import argparse
    
    parser = argparse.ArgumentParser(description='Run symbolic regression experiments with multiple LLMs')
    parser.add_argument('--experiment_name', type=str, help='Name of the experiment')
    
    args = parser.parse_args()
    run_experiment(args.experiment_name) 