import argparse
import os
from SCOPE.evaluation.eval import run_task_classical,run_task,processResult
from SCOPE.virtualhome.virtualhome.simulation.unity_simulator import UnityCommunication

def parse_args():
    parser = argparse.ArgumentParser(description="Run evaluation for SCOPE framework.")

    parser.add_argument('--agent', type=str, default='gpt-4o', choices=['gpt-4o', 'qwen2.5-vl-72b-instruct'],
                        help='Which vision-language agent to use (default: gpt-4o).')

    parser.add_argument('--apikey', type=str, default=None,
                        help='API key for accessing the agent (optional, can also be set via environment variable).')

    parser.add_argument('--start_taskid', type=int, default=0,
                        help='Index of the first task to run (default: 0)')

    parser.add_argument('--end_taskid', type=int, default=1,
                        help='Index of the last task to run (default: -1)')

    parser.add_argument('--memory', action='store_true',
                        help='Enable symbolic memory module (default: true).')

    parser.add_argument('--envid', type=int, choices=[0, 1, 2], default=0,
                        help='ID of the VirtualHome environment to use (default: 0).')

    parser.add_argument('--partial_obs', type=float, default=1.0, choices=[0.8, 0.9, 1.0],
                        help='Partial observability (default: 1.0).')

    parser.add_argument('--save_dir', type=str, default='result/',
                        help='Directory to save logs/results (default: output/).')

    parser.add_argument('--mode', type=str, default='eval',
                        help='')
    return parser.parse_args()

def main():
    comm = UnityCommunication(file_name=r"./virtualhome/virtualhome/simulation/unity_simulator/windows_exec.v2.3.0/VirtualHome.exe", port="8080", x_display="0")
    args = parse_args()
    openai_api_key = args.apikey or os.getenv("OPENAI_API_KEY")

    if not openai_api_key:
        raise ValueError("OpenAI API key not provided. Use --apikey or set OPENAI_API_KEY in env.")

    config = {
        "agent": args.agent,
        "apikey": openai_api_key,
        'start_taskid': args.start_taskid,
        'end_taskid': args.end_taskid,
        "use_memory": args.memory,
        "envid": args.envid,
        "partial_obs": args.partial_obs,
        "save_dir": args.save_dir,
    }
    if args.mode == 'eval':
        run_task(config)
    else:
        run_task_classical(config)
    processResult(config)


if __name__ == "__main__":
    main()