import numpy as np
from numpy.linalg import norm
import scipy.spatial as sp
import matplotlib.pyplot as plt
import copy
q = []
TOTAL_Layers = 32
ppp = 100
for i in range(TOTAL_Layers):
    c = []
    q.append(copy.deepcopy(c))
#q = [[], [], [], [], [], [], [], [], [], [], [], [], [], [], [], [], [], [], [], [], [], [], [], [], [], [], [], [], [], [], [], []]
for ijk in range(ppp + 1):
    if ijk == 0:
        continue
    upc = np.load("/group/yingyul/LLM_Compose/matrices/oppopair_swap_com_incontext_fix/no" + str(ijk) + ".npy")
    #print(upc.shape)
    for j in range(TOTAL_Layers):
        q[j].append(upc[j])
for ijk in range(ppp + 1):
    if ijk == 0:
        continue
    upd = np.load("/group/yingyul/LLM_Compose/matrices/oppopair_swap_com_incontext_fix_re1/no" + str(ijk) + ".npy")
    #print(upd.shape)
    for j in range(TOTAL_Layers):
        q[j].append(upd[j])
for layer in range(32):
    r = np.zeros((ppp * 2,ppp * 2))#78*2
    for op in range(ppp * 2):
        for qr in range(ppp * 2):
            g = 1 - sp.distance.cosine(q[layer][op], q[layer][qr])
            #g = q[layer][op].dot(q[layer][qr]) / (np.linalg.norm(q[layer][op]) * np.linalg.norm(q[layer][qr]))
            print(g)
            r[op][qr] = g
    plt.imshow(r, cmap='summer',vmin=0.8, vmax=1.0)
    plt.colorbar()
    plt.savefig("llama11/layer" + str(int(layer + 1)) + ".jpg")
    plt.close()
            
            