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'F:\deep_study\20210601_threelayers_limit_width/'
 
all_sub=os.listdir(target_folder)
print(all_sub)

for i in all_sub:
    # print(i[-10:-4])
    if i[-10:-4] != 'gam2':
        continue
    fd = target_folder+'/'+ i
    # print(fd)
    all_sub_i = os.listdir(fd)
    # print(all_sub_i)
    for k in all_sub_i:
        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:
            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)
                all_sub_p = os.listdir(fdddd)
                for p in all_sub_p:
                    fddddd = fdddd + '/' + p
                    if p[-4:] != '.pkl':
                        continue
                    print(fddddd)



                    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:56]+"_"+fdddd[63:72]+"_"+str(R['hidden_layer'][0])+"_"+'RD_w_0')
                    RR[fdddd[48:56]+"_"+fdddd[63:72]+"_"+str(R['hidden_layer'][0])+"_"+'RD_w_0'].append(R['RD_w_0_last'])
                    RR[fdddd[48:56]+"_"+fdddd[63:72]+"_"+str(R['hidden_layer'][0])+"_"+'RD_w_1'].append(R['RD_w_1_last'])
                    print(fdddd[48:56]+"_"+fdddd[63:72]+"_"+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()
                   
        
print(errorr)

FolderName  = r"F:\deep_study\20210812_threelayers_limit_witdth_zqx\result/"



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()