import argparse
import datetime

from Testers.RobomimicTest import RobomimicVerifier
from analysis_plot_utils import load_file, pick_wrong_responses, calculate_noise, get_F1_score
from config import *
from utils import get_latest_modified_file_with_prefix


def filter_path_list(l):
    new_list = []
    for i in l:
        if os.path.isdir(i):
            new_list.append(i)
    return new_list


if __name__ == '__main__':
    parser = argparse.ArgumentParser(description="Check results")
    parser.add_argument("--domain", type=str, default="")
    parser.add_argument("--type", type=str, default="")
    parser.add_argument("--condition", type=str, default="")
    parser.add_argument("--distribution", type=str, default="")
    parser.add_argument("--model", type=str, default="")
    parser.add_argument("--show_all", type=bool, default=False)
    parser.add_argument("--prompt_config", type=str, default="")
    args = parser.parse_args()



    domain_dict = {
        "C": "CliffWalking",
        "CD": "CliffWalkingDirectionality",
        "D": "MiniGrid-DoorKey-5x5-v0",
        "F": "MiniGrid-FourRooms-v0",
        "A": "ALFWorld",
        "H": "HCraft",
        "R": "robomimic"
    }

    if args.domain != "":
        if args.domain in domain_dict:
            print(f"Domain: {domain_dict[args.domain]}")
            args.domain = domain_dict[args.domain]


    type_dict = {
        "P": "preference",
        "A": "action_advising",
        "B": "binary_feedback",
        "D": "delta_action",
        "G": "goal_advising"
    }

    if args.type != "":
        if args.type in type_dict:
            print(f"Type: {type_dict[args.type]}")
            args.type = type_dict[args.type]

    model_list = ["/meta-llama/Meta-Llama-3.1-8B-Instruct-Turbo/", "/meta-llama/Meta-Llama-3.1-70B-Instruct-Turbo/"
                                                                   "/llama3.1:8b/", "/llama3.1:70b/",
                  "/deepseek-reasoner/",
                  "/meta-llama/Meta-Llama-3.1-8B-Instruct/",
                  "/meta-llama/Meta-Llama-3.1-70B-Instruct/",
                  "/Qwen/QwQ-32B/", "/h/PLACEHOLDER_FOR_ANOYNOMITYli/PLACEHOLDER_FOR_ANOYNOMITYlab_storage/models/QwQ-32B/", "/deepseek-ai/DeepSeek-R1/", "/Qwen3-32B/", "/Qwen2.5-VL-32B-Instruct/", "/Qwen2.5-VL-7B-Instruct/", "/Qwen2.5-VL-72B-Instruct/",
                  "/gpt-4o-mini-2024-07-18/"
                  # "deepseek-chat"
                  ]
    if args.model == "llama3.1-8b":
        model_list = ["/meta-llama/Meta-Llama-3.1-8B-Instruct-Turbo/",
                "/llama3.1:8b/",
                  "/meta-llama/Meta-Llama-3.1-8B-Instruct/",
                  # "deepseek-chat"
                  ]
    if args.model == "llama3.1-70b":
        model_list = ["/meta-llama/Meta-Llama-3.1-70B-Instruct-Turbo/",
                "/llama3.1:70b/",
                  "/meta-llama/Meta-Llama-3.1-70B-Instruct/",
                  # "deepseek-chat"
                  ]
    if args.model == "qwq-32b":
        model_list = ["/Qwen/QwQ-32B/", "/h/PLACEHOLDER_FOR_ANOYNOMITYli/PLACEHOLDER_FOR_ANOYNOMITYlab_storage/models/QwQ-32B/"]
    if args.model == "deepseek-reasoner":
        model_list = ["/deepseek-reasoner/", "/deepseek-ai/DeepSeek-R1/"]

    distribution_list = ["0", "0.5", "1", "traverse"]
    if args.distribution != "":
        if args.distribution == "0":
            distribution_list = ["0"]
        elif args.distribution == "0.5":
            distribution_list = ["0.5"]
        elif args.distribution == "1":
            distribution_list = ["1"]
        elif args.distribution == "traverse":
            distribution_list = ["traverse"]

    domain_path_list = []
    if args.domain != "":
        path = f"{PERSISTENT_DATA_PATH}/results/{args.domain}/"
        domain_path_list = [path]
    else:
        domain_path_list = [os.path.join(PERSISTENT_DATA_PATH + "/results/", file) for file in os.listdir(PERSISTENT_DATA_PATH + "/results/")]

    domain_path_list = filter_path_list(domain_path_list)
    for i in domain_path_list:
        type_path_list = []
        if args.type != "":
            path = f"/{i}/{args.type}/"
            type_path_list = [path]
        else:
            type_path_list = [os.path.join(i, file) for file in os.listdir(i)]

        type_path_list = filter_path_list(type_path_list)
        for j in type_path_list:
            condition_path_list = []
            if args.condition != "":
                path = f"/{j}/{args.condition}/"
                condition_path_list = [path]
            else:
                condition_path_list = [os.path.join(j, file) for file in os.listdir(j)]
            condition_path_list = filter_path_list(condition_path_list)
            for k in condition_path_list:

                model_path_list = []
                if args.model != "" and args.model not in ["llama3.1-8b", "llama3.1-70b", "qwq-32b", "deepseek-reasoner"]:
                    path = f"/{k}/{args.model}/"
                    model_path_list = [path]
                else:
                    for model in model_list:
                        model_path_list.append(k + model)
                model_path_list = filter_path_list(model_path_list)
                for l in model_path_list:
                    current_domain = i.split("/")[-1] if args.domain == "" else args.domain
                    current_type = j.split("/")[-1] if args.type == "" else args.type
                    current_condition = k.split("/")[-1] if args.condition == "" else args.condition
                    current_model = l.split("/")[-2]
                    prefix_dict = {
                        "ALFWorld": "ALF",
                        "HCraft": "HierachyCraft",
                        "CliffWalking": "cliffwalking_",
                        "MiniGrid-DoorKey-5x5-v0": "doorkey_",
                        "MiniGrid-FourRooms-v0": "FourRooms",
                        "robomimic": "robomimic",
                        "CliffWalkingDirectionality": "cliffwalking_directionality_"
                    }
                    for dis in distribution_list:

                        prefix = prefix_dict[current_domain] + current_type + "_" + dis
                        print(l, prefix)
                        if args.show_all:
                            datapaths = get_latest_modified_file_with_prefix(l, prefix, n=-1)
                        else:
                            datapath = get_latest_modified_file_with_prefix(l, prefix, n=1)
                            datapaths = [datapath]
                        # wrong_response_list = []
                        if datapaths is not None and len(datapaths) > 0:
                            for datapath in datapaths:
                                if datapath is not None:
                                    print(datapath)
                                    data = load_file(datapath)
                                    if len(data) > 0:
                                        if args.prompt_config != "" and "PromptConfigPath" in data[0]:
                                            if args.prompt_config not in data[0]["PromptConfigPath"]:
                                                continue
                                        
                                        if "Purpose" in data[0]:
                                            print("Purpose: ", data[0]["Purpose"])
                                        
                                        if "PromptConfigPath" in data[0]:
                                            print("PromptConfigPath: ", data[0]["PromptConfigPath"])
                                        print("Data points: ", len(data))

                                        # wrong_response = pick_wrong_responses(data, exclude_json_error=True)
                                        # wrong_response_list.append(wrong_response)
                                        CLIFFWALKING_IMPOSSIBLE_STATES = [37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47]

                                        excluded_states = CLIFFWALKING_IMPOSSIBLE_STATES if current_domain == "CliffWalking" else None

                                        if excluded_states is not None:
                                            print("Excluded states: ", excluded_states)

                                        if "robomimic" == current_domain and current_type == "action_advising":
                                            tester = RobomimicVerifier(env=current_domain, feedback_type=current_type, data_path="/Users/PLACEHOLDER_FOR_ANOYNOMITYli/Coding/LLM-Feedback-Playaround-Scripts/persistent_data/robomimic/robomimicaction_advising_1.npy", purpose_str="test", condition_list=[], system_prompt="You are a professional robot engineer.")
                                            results = calculate_noise(data, excluding_state=excluded_states, recalculate=True, tester=tester)
                                        else:
                                            results = calculate_noise(data, excluding_state=excluded_states)
                                        print(f"Results for {current_domain} {current_type} {dis} {current_type} {current_condition} in {current_model}")

                                        if current_type == "binary_feedback" or current_type == "preference":
                                            #F1 score
                                            try:    
                                                F1_scores = get_F1_score(data, type=current_type)
                                                print("F1 scores: ", F1_scores)
                                            except Exception as e:
                                                print("Error getting F1 scores: ", e)
                                                F1_scores = None

                                        timestamp = os.path.getmtime(datapath)
                                        modified_time = datetime.datetime.fromtimestamp(timestamp)
                                        print("Last modified time:", modified_time)
                                        print(results)
                                        print("\n\n")





