import os
import pickle
import matplotlib
import matplotlib.pyplot as plt
matplotlib.use('Agg')
import numpy as np
import shutil 

RR={}

# for ii in ['0.2','0.3','0.4','0.5','0.6','0.7','0.8']:
#     for jj in ['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']:
#         for kk in ['100','1000','2500','5000','10000']:
#             RR["gam2_"+ii+"_"+"gam3_"+jj+"_"+kk+"_"+'RD_w_0'] = []
#             RR["gam2_"+ii+"_"+"gam3_"+jj+"_"+kk+"_"+'RD_w_1'] = []
# print(RR)

errorr = []
Seq=[]
target_folder=r'E:\deep_study\20210824_threelayers_limit_width/'
 
all_sub=os.listdir(target_folder)
print(all_sub)

for i in all_sub:
    # print(i[-10:-5])
    if i[-10:-5] != 'gam2':
        continue
    fd = target_folder+'/'+ i
    # print(fd)
    all_sub_i = os.listdir(fd)
    # print(all_sub_i)
    for k in all_sub_i:
        # print(k[0:5])
        if k[0:5] != 'fitnd':
             continue
        fdd = fd + '/' + k
        # print(fdd)
        all_sub_k = os.listdir(fdd)
        # print(all_sub_k)
        for m in all_sub_k:
            # print(m[0:3])
            if m[0:3] != 'gam':
                continue
            fddd = fdd + '/' + m
            # print(fddd)
            all_sub_m = os.listdir(fddd)
            #print(all_sub_m)
            for o in all_sub_m:
                fdddd = fddd + '/' + o
                # print(fdddd)
                if o[0:2] != 'm_':
                    continue
                # print(fdddd)
                # quit()
                all_sub_p = os.listdir(fdddd)
                for p in all_sub_p:
                    fddddd = fdddd + '/' + p
                    if p[-4:] != '.pkl':
                        continue
                    print(fddddd)
                    # quit()


                    with open(fddddd,'rb') as f:
                        try:
                            R = pickle.load(f)
                        except:
                            print('an error')
                            errorr.append(fdddd)


                    RR[fdddd[48:57]+"_"+fdddd[64:73]+"_"+str(R['hidden_layer'][0])+"_"+'w_dot_plot_layer1']=R['w_dot_plot_layer1']
                    RR[fdddd[48:57]+"_"+fdddd[64:73]+"_"+str(R['hidden_layer'][0])+"_"+'b_dot_plot_layer1']=R['b_dot_plot_layer1']

                    f.close()
                    # quit()
        
print(errorr)

FolderName  = r"F:\deep_study\20210824_threelayers_limit_width_zqx\result_1to2/"



# for ii in ['0.2','0.3','0.4','0.5','0.6','0.7','0.8']:
#     for jj in ['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']:
#         for kk in ['100','1000','2500','5000','10000']:
#             if len(RR["gam2_"+ii+"_"+"gam3_"+jj+"_"+kk+"_"+'RD_w_0']) != 8:
#                 print("error "+"gam2_"+ii+"_"+"gam3_"+jj+"_"+kk+"_"+'RD_w_0')
#             if len(RR["gam2_"+ii+"_"+"gam3_"+jj+"_"+kk+"_"+'RD_w_1']) != 8:
#                 print("error "+"gam2_"+ii+"_"+"gam3_"+jj+"_"+kk+"_"+'RD_w_1')
# quit()

def savefile(): #保存模型参数的函数
    with open('%s/objk.pkl'%(FolderName), 'wb') as f:  # Python 3: open(..., 'wb')
        pickle.dump(RR, f, protocol=4)
    #序列化对象，将对象obj保存到文件file中去
    text_file = open("%s/objk.txt"%(FolderName), "w")
    for para in RR:
        if np.size(RR[para])>200:
            continue
        text_file.write('%s: %s\n'%(para,RR[para]))

savefile()