import numpy as np
import matplotlib.pyplot as plt
import json
gi = ["oppopair_swap_com_incontext_special"]#,"oppoverb_com_incontext_special","verbsingle_upper_com_incontext_special","verbpair_swap_com_incontext_special","verbsingle_plusOne_com_incontext_special"]
for i in gi:
    matrix = np.load("output_meta2/10/meta-llama_Llama-2-13b-hf/" + str(i) + "_shuffle_metatoken.npy")
    #print(matrix)
    a = json.load(open("output_meta2/10/meta-llama_Llama-2-13b-hf/" + str(i) + "_shuffle.json"))
    lencomp = a[1]["lencomp"]
    len1 = a[2]["lent1"]
    len2 = a[3]["lent2"]
    lenq = a[4]["lenq"]
    lencompav = 0
    len1av = 0
    len2av = 0
    lenqav = 0
    for jii in range(12):
        len1av += len1[jii]
        len2av += len2[jii]
        lenqav += lenq[jii]
        lencompav += lencomp[jii]
    lencompav /= 12
    len1av /= 12
    len2av /= 12
    lenqav /= 12
    x = [1,2,3]
    for ijjjj in range(0, 40):
       matrix[ijjjj][3][0] /= lencompav
       matrix[ijjjj][3][1] /= len1av
       matrix[ijjjj][3][2] /= len2av
       matrix[ijjjj][3][3] /= lenqav
    xlb = ["composite_task", "simple_task1", "simple_task2"]
    for j in [15,19,23]:
        cc = [0.0,0.0,0.0]
        cc[0] = matrix[j][3][0]
        cc[1] = matrix[j][3][1]
        cc[2] = matrix[j][3][2]
        #print(cc)
        plt.bar(x, cc, tick_label=xlb, width=0.3)
        #plt.ylim(0, 0.01)
        plt.savefig("piks2/" + str(j) + "_metatoken_" + str(i) + ".jpg")
        plt.close()