from SCOPE.utils.agent_utile import *
from SCOPE.utils.dataAnalysis import DataAnalysis
from SCOPE.utils.symbolic_utils import format_output
import pprint
from collections import defaultdict

def run_task(config):
    agent = config["agent"]
    api_key=config["apikey"]
    start_taskid = config["start_taskid"]
    end_taskid = config["end_taskid"]
    use_memory = config["use_memory"]
    envid = config["envid"]
    partial_obs = config["partial_obs"]
    save_dir = config["save_dir"]

    print(f"Using agent: {agent} \nEnv id: {envid}")
    print(f"Tasks from {start_taskid} to {end_taskid}")
    print(f"Memory enabled: {use_memory}")
    print(f"Partial observability: {partial_obs} \nSaving to {save_dir}")

    prepareExp(envid, agent,api_key, partial_obs,save_dir)
    rooms = getEnvRooms(envid)
    random.seed(time.time())
    room = random.choice(rooms)
    if partial_obs==1:
        output_path = f"{save_dir}/result_all_{agent}.json"
    else:
        output_path = f"{save_dir}/result_all_{agent}_{partial_obs}.json"

    resultAll=[]
    with open(f"evaluation/tasksPreprocess{envid}.json", "r") as f:
        task = json.load(f)
    for i in range(start_taskid,end_taskid):
        log_information.clear()
        print(f"TASK ID: {i}")
        run(task[i], envid, room, agent, partial_obs,save_dir,use_memory,api_key)
        DA = DataAnalysis(0, agent, partial_obs,save_dir)
        logsInfo = DA.initOneLog(i)
        for logInfo in logsInfo:
            result = DA.eval(logInfo)
            resultAll.append(result)
            with open(output_path, "w") as f:
                json.dump(resultAll, f, indent=2)
            print(f"result:{result}")
        else:
            continue

def run_task_classical(config):
    agent = config["agent"]
    save_dir = config["save_dir"]
    output_path = f"{save_dir}/classical_result_all_{agent}.json"
    resultAll=[]
    DA = DataAnalysis(0, agent, 1, save_dir)
    for i in range(DA.getTaskNum()):
        logsInfo=DA.initOneLog(i)
        print(logsInfo)
        print(f"TASK ID: {i}")
        for logInfo in logsInfo:
            result=DA.evalClassicalUnderPartialObs(logInfo)
            resultAll.append(result)
            # 每次追加后立即写入文件
            with open(output_path, "w") as f:
                json.dump(resultAll, f, indent=2)
            print(f"result:{result}")

def processResult(config):
    agent=config["agent"]
    save_dir = config["save_dir"]
    partial_obs = config["partial_obs"]
    if partial_obs==1:
        path = f"{save_dir}/result_all_{agent}.json"
    else:
        path = f"{save_dir}/result_all_{agent}_{partial_obs}.json"
    with open(path, "r") as f:
        results = json.load(f)

    final_output = format_output(results)
    # # === 打印结果 ===
    pprint.pprint(final_output, width=150)

def processResultFromClassical(config):
    agent = config["agent"]
    save_dir = config["save_dir"]
    path=f"{save_dir}/classical_result_all_{agent}.json"
    with open(path, "r") as f:
        results = json.load(f)
    room_stats = defaultdict(lambda: defaultdict(list))
    # 遍历数据，按房间分类收集数据
    for entry in results:
        room_key = "single-room" if entry["room"] == 1 else "multi-room"
        for level, value in entry["planning"].items():
            room_stats[room_key][level].append(value)
    # 计算每个房型每个等级的平均值（作为比例）
    result = {}
    for room_type, levels in room_stats.items():
        result[room_type] = {
            level: round(sum(vals) / len(vals), 3)
            for level, vals in levels.items()
        }
    pprint.pprint(results, width=150)

