import json
import numpy as np


filename = "M0/AK1_temp_0.8_t_5.out"
# filename = "M0/EK1_temp_0.8_t_30.out"

num = 5
offset = 1


with open(filename, "r") as f:
   datas = json.load(f)


def pad(lst: list, pad_size: int, padding: int = 0) -> list:
    if len(lst) < pad_size:
        return lst + [padding] * (pad_size - len(lst))
    else:
        return lst[:pad_size]

to_pad = 6
lst1 = [pad(datas["traces"][i * num + offset], to_pad) for i in range(50)]
lst2 = [pad(datas["traces"][i * num + offset + 1], to_pad) for i in range(50)]


def pairwise_cosine_similarity(list1, list2=None):
    # Convert lists of lists to NumPy arrays for efficiency
    array1 = np.array(list1)
    if list2 is None:
        array2 = array1  # If list2 is not provided, compare within list1
    else:
        array2 = np.array(list2)
    
    # Normalize the vectors
    array1 = array1 / np.linalg.norm(array1, axis=1, keepdims=True)
    array2 = array2 / np.linalg.norm(array2, axis=1, keepdims=True)
    
    # Compute the pairwise cosine similarity matrix
    similarity_matrix = np.dot(array1, array2.T)
    
    # if upper_triangular:
    #     # Mask lower triangular part (including diagonal if list1 == list2)
    #     if list2 is None:  # Only applies when comparing the same list
    #         similarity_matrix = np.triu(similarity_matrix, k=1)
    #     else:
    #         raise ValueError("Upper triangular matrix is only valid for self-similarity.")
    
    return similarity_matrix


# Full similarity matrix
full_matrix = pairwise_cosine_similarity(lst2, lst1)
# print("Full Similarity Matrix:\n", full_matrix)
np.savetxt("21matrix_0.8.txt", np.triu(full_matrix), fmt="%.3f", delimiter=",")
# print("Full Similarity Matrix:\n", np.tril(full_matrix, k=0))

# Upper triangular similarity matrix for self-similarity
# upper_triangular_matrix = pairwise_cosine_similarity(lst1, lst2, upper_triangular=True)
# print("Upper Triangular Matrix:\n", upper_triangular_matrix)
