import os
import pickle
import matplotlib
import matplotlib.pyplot as plt
from seaborn.matrix import heatmap
matplotlib.use('Agg')
import numpy as np
import shutil 
import math
import seaborn as sns

Gamma2 = [0.2,0.3,0.4,0.5,0.6,0.7,0.8]
Gamma3 = ['2.20','2.25','2.30','2.35','2.40','2.45','2.50','2.55','2.60','2.65','2.70','2.75','2.80']
num = [100,1000,2500,5000,10000]
mean_100 = np.zeros(shape=(len(Gamma2),len(Gamma3)))
mean_1000 = np.zeros(shape=(len(Gamma2),len(Gamma3)))
mean_2500 = np.zeros(shape=(len(Gamma2),len(Gamma3)))
mean_5000 = np.zeros(shape=(len(Gamma2),len(Gamma3)))
mean_10000 = np.zeros(shape=(len(Gamma2),len(Gamma3)))
QQ={}
RR={}

# for na in name:
#     with open(r"D:\work_xzq_doctor\20210701_threelayers_limit_width\drawing_cos_result/%s"%(na),'rb') as f:
#         Q = pickle.load(f)
ii = 0
jj = 0
with open(r"F:\deep_study\20210812_threelayers_limit_witdth_zqx\result_cos/objk_2.pkl",'rb') as f:
    Q1 = pickle.load(f)
# with open(r"F:\deep_study\20210812_threelayers_limit_witdth_zqx\result_cos/objk_2.pkl",'rb') as f:
#     Q2 = pickle.load(f)

# RR["gam2_"+ii+"_"+"gam3_"+jj+"_"+kk+"_"+'cos']

for i in Gamma2:
    jj = 0
    print(i)
    for j in Gamma3:
        for k in num:
            if i == 0.2 or i == 0.3 or i == 0.4 or i == 0.5:
                continue # cos_distance_matrix = Q1['gam2_'+str(i)+'_gam3_'+j+'_'+str(k)+'_cos']
            if i == 0.6 or i == 0.7 or i == 0.8:
                cos_distance_matrix = Q1['gam2_'+str(i)+'_gam3_'+j+'_'+str(k)+'_cos']
            
            if k == 100:
                print(np.mean(np.abs(cos_distance_matrix)))
                print(np.mean(np.mean(np.abs(cos_distance_matrix))))
                mean_100[ii][jj] = np.mean(np.mean(np.abs(cos_distance_matrix)))
            if k == 1000:
                mean_1000[ii][jj] = np.mean(np.mean(np.abs(cos_distance_matrix)))
            if k == 2500:
                mean_2500[ii][jj] = np.mean(np.mean(np.abs(cos_distance_matrix)))
            if k == 5000:
                mean_5000[ii][jj] = np.mean(np.mean(np.abs(cos_distance_matrix)))
            if k == 10000:
                mean_10000[ii][jj] = np.mean(np.mean(np.abs(cos_distance_matrix)))
        
        jj = jj + 1
    ii = ii + 1

RR['mean_100'] = mean_100
RR['mean_1000'] = mean_1000
RR['mean_2500'] = mean_2500
RR['mean_5000'] = mean_5000
RR['mean_10000'] = mean_10000

print(mean_100)

FolderName  = r"F:\deep_study\20210812_threelayers_limit_witdth_zqx\result_cos/"

def savefile(): #保存模型参数的函数
    with open('%s/objk_2_step_2.pkl'%(FolderName), 'wb') as f:  # Python 3: open(..., 'wb')
        pickle.dump(RR, f, protocol=4)
    #序列化对象，将对象obj保存到文件file中去
    text_file = open("%s/objk_2_step_2.txt"%(FolderName), "w")
    for para in RR:
        if np.size(RR[para])>200:
            continue
        text_file.write('%s: %s\n'%(para,RR[para]))

savefile()