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]
QQ={}

with open(r"D:\work_xzq_doctor\20210701_threelayers_limit_width\linear_regression_average_variation/objk_dis.pkl",'rb') as f:
    Q = pickle.load(f)

# for dic in Q:        
#     print(dic)


for i in Gamma2:
    for j in Gamma3:
        QQ['gamma_'+str(i)+'_gam3_'+j+'_plot'] = []
        for k in num:
            QQ['gamma_'+str(i)+'_gam3_'+j+'_plot'].append(Q['gamma_'+str(i)+'_gam3_'+j+'_'+str(k)+'_dis'])
        print('gamma_'+str(i)+'_gam3_'+j+'_plot'+str(QQ['gamma_'+str(i)+'_gam3_'+j+'_plot']))


heatmap_k_100 = np.zeros(shape=(len(Gamma2),len(Gamma3)))
for i in range(len(Gamma2)):
    for j in range(len(Gamma3)):
        heatmap_k_100[i][j] =  QQ['gamma_'+str(Gamma2[i])+'_gam3_'+Gamma3[j]+'_plot'][-5]

XX,YY = np.meshgrid([2.2,2.25,2.3,2.35,2.4,2.45,2.5,2.55,2.6,2.65,2.7,2.75,2.8],[0.2,0.3,0.4,0.5,0.6,0.7,0.8])

plt.rcParams['savefig.dpi'] = 200 #图片像素
plt.rcParams['figure.dpi'] = 200 #分辨率
fig,ax = plt.subplots()
im = plt.pcolor(XX,YY,heatmap_k_100, cmap='RdBu',shading='auto') #,vmin=-0.16,vmax=0.16) 
# ax = sns.heatmap(heatmap_k,linewidths = 0.05,cmap='RdBu') # vmin=-1,vmax=1,cmap='YlGnBu_r'),xticklabels = np.arange(Q['thredhood']),yticklabels = np.arange(Q['thredhood']))
ax.set_xticks([2.2,2.25,2.3,2.35,2.4,2.45,2.5,2.55,2.6,2.65,2.7,2.75,2.8]) #设置x轴刻度
ax.set_yticks([0.8,0.7,0.6,0.5,0.4,0.3,0.2]) #设置y轴刻度
ax.xaxis.set_ticks_position('top')
# divider = make_axes_locatable(ax)
# cax = divider.append_axes("right", size="5%", pad=0.05)
plt.tick_params(labelsize=8)
plt.colorbar(im) #,ticks = [-0.10,0,0.10])# , cax=cax)
# plt.plot(stars_0,[0.2,0.3,0.4,0.5,0.6,0.7,0.8],'k*',markersize=14)
plt.plot([2.5,2.5],[0.5,0.85],'k--',linewidth=1.5)
x_aux=[2.5,2.825]
y_aux=[0.5,0.175]
plt.plot(x_aux,y_aux,'k--',linewidth=1.5)
# ax.set_yticklabels(([+0.3,0.2,0.1,0.0,-0.1,-0.2,-0.3]),fontsize=12)
# ax.set_xticklabels(([0.9,1.1,1.3,1.5,1.7,1.9,2.1]),fontsize=12)
#ax.set_title("cos distance: relu",fontsize=16)
plt.savefig(r'D:\work_xzq_doctor\20210701_threelayers_limit_width\linear_regression_average_variation/Dis_100_xu.png')
plt.close()
plt.clf()

heatmap_k_1000 = np.zeros(shape=(len(Gamma2),len(Gamma3)))
for i in range(len(Gamma2)):
    for j in range(len(Gamma3)):
        heatmap_k_1000[i][j] =  QQ['gamma_'+str(Gamma2[i])+'_gam3_'+Gamma3[j]+'_plot'][-4]

XX,YY = np.meshgrid([2.2,2.25,2.3,2.35,2.4,2.45,2.5,2.55,2.6,2.65,2.7,2.75,2.8],[0.2,0.3,0.4,0.5,0.6,0.7,0.8])

plt.rcParams['savefig.dpi'] = 200 #图片像素
plt.rcParams['figure.dpi'] = 200 #分辨率
fig,ax = plt.subplots()
im = plt.pcolor(XX,YY,heatmap_k_1000, cmap='RdBu',shading='auto') #,vmin=-0.16,vmax=0.16) 
# ax = sns.heatmap(heatmap_k,linewidths = 0.05,cmap='RdBu') # vmin=-1,vmax=1,cmap='YlGnBu_r'),xticklabels = np.arange(Q['thredhood']),yticklabels = np.arange(Q['thredhood']))
ax.set_xticks([2.2,2.25,2.3,2.35,2.4,2.45,2.5,2.55,2.6,2.65,2.7,2.75,2.8]) #设置x轴刻度
ax.set_yticks([0.8,0.7,0.6,0.5,0.4,0.3,0.2]) #设置y轴刻度
ax.xaxis.set_ticks_position('top')
# divider = make_axes_locatable(ax)
# cax = divider.append_axes("right", size="5%", pad=0.05)
plt.tick_params(labelsize=8)
plt.colorbar(im) #,ticks = [-0.10,0,0.10])# , cax=cax)
# plt.plot(stars_0,[0.2,0.3,0.4,0.5,0.6,0.7,0.8],'k*',markersize=14)
plt.plot([2.5,2.5],[0.5,0.85],'k--',linewidth=1.5)
x_aux=[2.5,2.825]
y_aux=[0.5,0.175]
plt.plot(x_aux,y_aux,'k--',linewidth=1.5)
# ax.set_yticklabels(([+0.3,0.2,0.1,0.0,-0.1,-0.2,-0.3]),fontsize=12)
# ax.set_xticklabels(([0.9,1.1,1.3,1.5,1.7,1.9,2.1]),fontsize=12)
#ax.set_title("cos distance: relu",fontsize=16)
plt.savefig(r'D:\work_xzq_doctor\20210701_threelayers_limit_width\linear_regression_average_variation/Dis_1000_xu.png')
plt.close()
plt.clf()

heatmap_k_2500 = np.zeros(shape=(len(Gamma2),len(Gamma3)))
for i in range(len(Gamma2)):
    for j in range(len(Gamma3)):
        heatmap_k_2500[i][j] =  QQ['gamma_'+str(Gamma2[i])+'_gam3_'+Gamma3[j]+'_plot'][-3]

XX,YY = np.meshgrid([2.2,2.25,2.3,2.35,2.4,2.45,2.5,2.55,2.6,2.65,2.7,2.75,2.8],[0.2,0.3,0.4,0.5,0.6,0.7,0.8])

plt.rcParams['savefig.dpi'] = 200 #图片像素
plt.rcParams['figure.dpi'] = 200 #分辨率
fig,ax = plt.subplots()
im = plt.pcolor(XX,YY,heatmap_k_2500, cmap='RdBu',shading='auto') #,vmin=-0.16,vmax=0.16) 
# ax = sns.heatmap(heatmap_k,linewidths = 0.05,cmap='RdBu') # vmin=-1,vmax=1,cmap='YlGnBu_r'),xticklabels = np.arange(Q['thredhood']),yticklabels = np.arange(Q['thredhood']))
ax.set_xticks([2.2,2.25,2.3,2.35,2.4,2.45,2.5,2.55,2.6,2.65,2.7,2.75,2.8]) #设置x轴刻度
ax.set_yticks([0.8,0.7,0.6,0.5,0.4,0.3,0.2]) #设置y轴刻度
ax.xaxis.set_ticks_position('top')
# divider = make_axes_locatable(ax)
# cax = divider.append_axes("right", size="5%", pad=0.05)
plt.tick_params(labelsize=8)
plt.colorbar(im) #,ticks = [-0.10,0,0.10])# , cax=cax)
# plt.plot(stars_0,[0.2,0.3,0.4,0.5,0.6,0.7,0.8],'k*',markersize=14)
plt.plot([2.5,2.5],[0.5,0.85],'k--',linewidth=1.5)
x_aux=[2.5,2.825]
y_aux=[0.5,0.175]
plt.plot(x_aux,y_aux,'k--',linewidth=1.5)
# ax.set_yticklabels(([+0.3,0.2,0.1,0.0,-0.1,-0.2,-0.3]),fontsize=12)
# ax.set_xticklabels(([0.9,1.1,1.3,1.5,1.7,1.9,2.1]),fontsize=12)
#ax.set_title("cos distance: relu",fontsize=16)
plt.savefig(r'D:\work_xzq_doctor\20210701_threelayers_limit_width\linear_regression_average_variation/Dis_2500_xu.png')
plt.close()
plt.clf()

heatmap_k_5000 = np.zeros(shape=(len(Gamma2),len(Gamma3)))
for i in range(len(Gamma2)):
    for j in range(len(Gamma3)):
        heatmap_k_5000[i][j] =  QQ['gamma_'+str(Gamma2[i])+'_gam3_'+Gamma3[j]+'_plot'][-2]

XX,YY = np.meshgrid([2.2,2.25,2.3,2.35,2.4,2.45,2.5,2.55,2.6,2.65,2.7,2.75,2.8],[0.2,0.3,0.4,0.5,0.6,0.7,0.8])

plt.rcParams['savefig.dpi'] = 200 #图片像素
plt.rcParams['figure.dpi'] = 200 #分辨率
fig,ax = plt.subplots()
im = plt.pcolor(XX,YY,heatmap_k_5000, cmap='RdBu',shading='auto') #,vmin=-0.16,vmax=0.16) 
# ax = sns.heatmap(heatmap_k,linewidths = 0.05,cmap='RdBu') # vmin=-1,vmax=1,cmap='YlGnBu_r'),xticklabels = np.arange(Q['thredhood']),yticklabels = np.arange(Q['thredhood']))
ax.set_xticks([2.2,2.25,2.3,2.35,2.4,2.45,2.5,2.55,2.6,2.65,2.7,2.75,2.8]) #设置x轴刻度
ax.set_yticks([0.8,0.7,0.6,0.5,0.4,0.3,0.2]) #设置y轴刻度
ax.xaxis.set_ticks_position('top')
# divider = make_axes_locatable(ax)
# cax = divider.append_axes("right", size="5%", pad=0.05)
plt.tick_params(labelsize=8)
plt.colorbar(im) #,ticks = [-0.10,0,0.10])# , cax=cax)
# plt.plot(stars_0,[0.2,0.3,0.4,0.5,0.6,0.7,0.8],'k*',markersize=14)
plt.plot([2.5,2.5],[0.5,0.85],'k--',linewidth=1.5)
x_aux=[2.5,2.825]
y_aux=[0.5,0.175]
plt.plot(x_aux,y_aux,'k--',linewidth=1.5)
# ax.set_yticklabels(([+0.3,0.2,0.1,0.0,-0.1,-0.2,-0.3]),fontsize=12)
# ax.set_xticklabels(([0.9,1.1,1.3,1.5,1.7,1.9,2.1]),fontsize=12)
#ax.set_title("cos distance: relu",fontsize=16)
plt.savefig(r'D:\work_xzq_doctor\20210701_threelayers_limit_width\linear_regression_average_variation/Dis_5000_xu.png')
plt.close()
plt.clf()

heatmap_k_10000 = np.zeros(shape=(len(Gamma2),len(Gamma3)))
for i in range(len(Gamma2)):
    for j in range(len(Gamma3)):
        heatmap_k_10000[i][j] =  QQ['gamma_'+str(Gamma2[i])+'_gam3_'+Gamma3[j]+'_plot'][-1]

XX,YY = np.meshgrid([2.2,2.25,2.3,2.35,2.4,2.45,2.5,2.55,2.6,2.65,2.7,2.75,2.8],[0.2,0.3,0.4,0.5,0.6,0.7,0.8])

plt.rcParams['savefig.dpi'] = 200 #图片像素
plt.rcParams['figure.dpi'] = 200 #分辨率
fig,ax = plt.subplots()
im = plt.pcolor(XX,YY,heatmap_k_10000, cmap='RdBu',shading='auto') #,vmin=-0.16,vmax=0.16) 
# ax = sns.heatmap(heatmap_k,linewidths = 0.05,cmap='RdBu') # vmin=-1,vmax=1,cmap='YlGnBu_r'),xticklabels = np.arange(Q['thredhood']),yticklabels = np.arange(Q['thredhood']))
ax.set_xticks([2.2,2.25,2.3,2.35,2.4,2.45,2.5,2.55,2.6,2.65,2.7,2.75,2.8]) #设置x轴刻度
ax.set_yticks([0.8,0.7,0.6,0.5,0.4,0.3,0.2]) #设置y轴刻度
ax.xaxis.set_ticks_position('top')
# divider = make_axes_locatable(ax)
# cax = divider.append_axes("right", size="5%", pad=0.05)
plt.tick_params(labelsize=8)
plt.colorbar(im) #,ticks = [-0.10,0,0.10])# , cax=cax)
# plt.plot(stars_0,[0.2,0.3,0.4,0.5,0.6,0.7,0.8],'k*',markersize=14)
plt.plot([2.5,2.5],[0.5,0.85],'k--',linewidth=1.5)
x_aux=[2.5,2.825]
y_aux=[0.5,0.175]
plt.plot(x_aux,y_aux,'k--',linewidth=1.5)
# ax.set_yticklabels(([+0.3,0.2,0.1,0.0,-0.1,-0.2,-0.3]),fontsize=12)
# ax.set_xticklabels(([0.9,1.1,1.3,1.5,1.7,1.9,2.1]),fontsize=12)
#ax.set_title("cos distance: relu",fontsize=16)
plt.savefig(r'D:\work_xzq_doctor\20210701_threelayers_limit_width\linear_regression_average_variation/Dis_10000_xu.png')
plt.close()
plt.clf()

heatmap_k_xie = np.zeros(shape=(len(Gamma2),len(Gamma3)))

for i in range(len(Gamma2)):
    for j in range(len(Gamma3)):
        z1 = np.polyfit([100,1000,2500,5000,10000],[heatmap_k_100[i][j],heatmap_k_1000[i][j],heatmap_k_2500[i][j],heatmap_k_5000[i][j],heatmap_k_10000[i][j]], 1) # 用1次多项式拟合，可改变多项式阶数；
        heatmap_k_xie[i][j] = z1[0]

plt.rcParams['savefig.dpi'] = 200 #图片像素
plt.rcParams['figure.dpi'] = 200 #分辨率
fig,ax = plt.subplots()
im = plt.pcolor(XX,YY,heatmap_k_xie, cmap='RdBu',shading='auto') #,vmin=-0.16,vmax=0.16) 
# ax = sns.heatmap(heatmap_k,linewidths = 0.05,cmap='RdBu') # vmin=-1,vmax=1,cmap='YlGnBu_r'),xticklabels = np.arange(Q['thredhood']),yticklabels = np.arange(Q['thredhood']))
ax.set_xticks([2.2,2.25,2.3,2.35,2.4,2.45,2.5,2.55,2.6,2.65,2.7,2.75,2.8]) #设置x轴刻度
ax.set_yticks([0.8,0.7,0.6,0.5,0.4,0.3,0.2]) #设置y轴刻度
ax.xaxis.set_ticks_position('top')
# divider = make_axes_locatable(ax)
# cax = divider.append_axes("right", size="5%", pad=0.05)
plt.tick_params(labelsize=8)
plt.colorbar(im) #,ticks = [-0.10,0,0.10])# , cax=cax)
# plt.plot(stars_0,[0.2,0.3,0.4,0.5,0.6,0.7,0.8],'k*',markersize=14)
plt.plot([2.5,2.5],[0.5,0.85],'k--',linewidth=1.5)
x_aux=[2.5,2.825]
y_aux=[0.5,0.175]
plt.plot(x_aux,y_aux,'k--',linewidth=1.5)
# ax.set_yticklabels(([+0.3,0.2,0.1,0.0,-0.1,-0.2,-0.3]),fontsize=12)
# ax.set_xticklabels(([0.9,1.1,1.3,1.5,1.7,1.9,2.1]),fontsize=12)
#ax.set_title("cos distance: relu",fontsize=16)
plt.savefig(r'D:\work_xzq_doctor\20210701_threelayers_limit_width\linear_regression_average_variation/Dis_xie_xu.png')
plt.close()
plt.clf()
