import os
import sys
import pathlib
import numpy as np

datasets =["1_ALOI", "3_backdoor", "4_breastw", "5_campaign", "6_cardio","9_census", "15_Hepatitis", "12_fault", "17_InternetAds", "19_landsat", "20_letter", "24_mnist", "25_musk","32_shuttle", "36_speech"]
methods = ["CLOE", "CLOE_ablation_0", "CLOE_ablation_1", "CLOE_ablation_2", "DRL", "RCA", "MCM", "OC SVM","iForest", "ECOD",  "DeepSVDD" , "kNN", "KDE", "Og", "DAGMM"] 
path = "CLOE/results"
for dataset in datasets:
    print(dataset)
    for method in methods:
        print(method)
        AUCROC = []
        AP = []
        F1 = []
        n = []
        time_train = []
        time_infer = []
        cpu_memory = []
        time_infer_one = []
        for root, dirs, files in os.walk(path):
            for file in files:
                if dataset in root and method == root.split('/')[-1] and ("0" in root or "49" in root):
                    result = np.load(os.path.join(root, file), allow_pickle = True)
                    AUCROC.append(result[()]["AUC ROC"])
                    AP.append(result[()]["AP AUC"])
                    if method == "CLOE":
                        time_train.append(result[()]["Time training"])
                        cpu_memory.append(result[()]["mean_memory"])
                        time_infer.append(result[()]["Time inference"])
                        time_infer_one.append(result[()]["Time inference for one sample"])
                        F1.append(result[()]["F1 Score"])
                        n.append(result[()]["n"])
        print(f'Mean for au-roc : {sum(AUCROC)/len(AUCROC)}')
        print(f'Variance for au-roc : {np.var(AUCROC)}')
        print(f'Mean for ap : {sum(AP)/len(AP)}')
        print(f'Variance for ap : {np.var(AP)}')
        if method == "CLOE":
            print(f'Time for training: {np.mean(time_train)}')
            print(f'CPU memory for training: {np.mean(cpu_memory)}')
            print(f'Time for inference: {np.mean(time_infer)}')
            print(f'Time for inference of one sample: {np.mean(time_infer_one)}')
            print(f'F1 score: {np.mean(F1)}')
            print(f'F1 score: {np.var(F1)}')
            print(f'n: {n}')