import os
import numpy as np

import utils.const as C

import utils.helpers as UH

import utils.plot as UP


def main():

    encoders = [
        "sentence-transformers/all-MiniLM-L6-v2",
        "sentence-transformers/all-mpnet-base-v2",
        "sentence-transformers/all-roberta-large-v1",
    ]
    for K_path in ["K1", "K2", "K3"]:
        for encoder in encoders:
            G = {}
            emb_name = encoder.split("/")[1]
            base_path = f"cache/{emb_name}"
            for file in os.listdir(f"{base_path}/{K_path}"):
                K = UH.load_from_cache(f"{emb_name}/{K_path}", file)
                for k, v in K.items():
                    if k not in G:
                        G[k] = []
                    v = [a for a in v if not np.isnan(a)]
                    G[k].extend(v)
            D = UH.bin_tuple_dict_log_to_tuple(G)
            D = UH.get_median_Ks(D)
            D = UH.get_mean_deltas_diagonal(D)
            path = f"by_encoders/{emb_name}"
            os.makedirs(f"plots/{path}", exist_ok=True)
            UP.plot_individ_median_logplot_with_fit_exponential(D, f"{path}/{K_path}_all")


if __name__ == "__main__":

    main()
