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.3','-0.2','-0.1','+0.0','+0.1','+0.2','+0.3']:
    for jj in ['0.90','1.10','1.30','1.50','1.70','1.90','2.10']:
        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)


                        
                    # print(fdddd[72:82])
                    # print(fdddd[83:93])
                    R['RD_w_0_last']
                    R['RD_w_1_last']
                    print(fdddd[48:57]+"_"+fdddd[64:73]+"_"+str(R['hidden_layer'][0])+"_"+'RD_w_0')
                    RR[fdddd[48:57]+"_"+fdddd[64:73]+"_"+str(R['hidden_layer'][0])+"_"+'RD_w_0'].append(R['RD_w_0_last'])
                    RR[fdddd[48:57]+"_"+fdddd[64:73]+"_"+str(R['hidden_layer'][0])+"_"+'RD_w_1'].append(R['RD_w_1_last'])
                    print(fdddd[48:57]+"_"+fdddd[64:73]+"_"+str(R['hidden_layer'][0])+"_"+'RD_w_0')
                    # print(RR[fdddd[72:82]+"_"+fdddd[83:93]+"_"+str(R['hidden_layer'][0])+"_"+'RD_w_1'])
                    f.close()
                    # quit()
# quit()

print(errorr)

FolderName  = r"F:\deep_study\20210824_threelayers_limit_width_zqx\result/"


for ii in ['-0.3','-0.2','-0.1','+0.0','+0.1','+0.2','+0.3']:
    for jj in ['0.90','1.10','1.30','1.50','1.70','1.90','2.10']:
        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()