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.20', '0.30', '0.40', '0.50', '0.60', '0.70', '0.80']:
     for jj in ['2.20', '2.30', '2.40', '2.50', '2.60', '2.70', '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'/home/XXX/fast_plt_2/fitnd'
 
all_sub=os.listdir(target_folder)
# print(all_sub)
for s in all_sub:
    print(s)
    print(s[0:4])
    if s[0:4] != 'gam2':
            continue
    f = target_folder + '/' + s
    print('f',f)
    all_sub_s = os.listdir(f)
    print(all_sub_s)
    for i in all_sub_s:
        if i[0:4] != 'gam3':
            continue
        fd = f + '/' + i
        print(fd)
        all_sub_i = os.listdir(fd)
        print(all_sub_i)
        for j in all_sub_i:
            if j[0:2] != 'm_':
                continue
            print()
            fdd = fd +'/' + j
            all_sub_j = os.listdir(fdd)
            for p in all_sub_j:
                fddd = fdd + '/' + p
                if p[-4:] != '.pkl':
                    continue
                print(fddd)
                with open(fddd, 'rb') as h:
                    try:
                        R = pickle.load(h)
                    except:
                        print('an error')
                    print(R['RD_w_0_last'])
                    print(R['RD_w_1_last'])
                    print(s[5:])
                    print(i[5:9])
                    RR["gam2_"+s[5:]+"_"+"gam3_"+i[5:9]+"_"+str(R['hidden_layer'][0])+"_"+'RD_w_0'].append(R['RD_w_0_last'])
                    RR["gam2_"+s[5:]+"_"+"gam3_"+i[5:9]+"_"+str(R['hidden_layer'][0])+"_"+'RD_w_1'].append(R['RD_w_1_last'])
                    h.close()
print(errorr)

FolderName  = r"/home/XXX/result_plt2"


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]))

for ii in ['0.20', '0.30', '0.40', '0.50', '0.60', '0.70', '0.80']:
    for jj in ['2.20', '2.30', '2.40', '2.50', '2.60', '2.70', '2.80']:
        for kk in ['100','1000','2500','5000','10000']:
            if RR["gam2_"+ii+"_"+"gam3_"+jj+"_"+kk+"_"+'RD_w_0'] == []:
                RR["gam2_"+ii+"_"+"gam3_"+jj+"_"+kk+"_"+'RD_w_0'] = 0
            if RR["gam2_"+ii+"_"+"gam3_"+jj+"_"+kk+"_"+'RD_w_1'] == []:
                RR["gam2_"+ii+"_"+"gam3_"+jj+"_"+kk+"_"+'RD_w_1'] = 0


for ii in ['0.20', '0.30', '0.40', '0.50', '0.60', '0.70', '0.80']:
     for jj in ['2.25', '2.35', '2.45', '2.55', '2.65', '2.75']:
        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'/home/XXX/fast_plt_2_refined/fitnd'
 
all_sub=os.listdir(target_folder)
# print(all_sub)
for s in all_sub:
    print(s)
    print(s[0:4])
    if s[0:4] != 'gam2':
            continue
    f = target_folder + '/' + s
    print('f',f)
    all_sub_s = os.listdir(f)
    print(all_sub_s)
    for i in all_sub_s:
        if i[0:4] != 'gam3':
            continue
        fd = f + '/' + i
        print(fd)
        all_sub_i = os.listdir(fd)
        print(all_sub_i)
        for j in all_sub_i:
            if j[0:2] != 'm_':
                continue
            print()
            fdd = fd +'/' + j
            all_sub_j = os.listdir(fdd)
            for p in all_sub_j:
                fddd = fdd + '/' + p
                if p[-4:] != '.pkl':
                    continue
                print(fddd)
                with open(fddd, 'rb') as h:
                    try:
                        R = pickle.load(h)
                    except:
                        print('an error')
                    print(R['RD_w_0_last'])
                    print(R['RD_w_1_last'])
                    print(s[5:])
                    print(i[5:9])
                    RR["gam2_"+s[5:]+"_"+"gam3_"+i[5:9]+"_"+str(R['hidden_layer'][0])+"_"+'RD_w_0'].append(R['RD_w_0_last'])
                    RR["gam2_"+s[5:]+"_"+"gam3_"+i[5:9]+"_"+str(R['hidden_layer'][0])+"_"+'RD_w_1'].append(R['RD_w_1_last'])
                    h.close()
print(errorr)

FolderName  = r"/home/XXX/result_plt2"


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]))

for ii in ['0.20', '0.30', '0.40', '0.50', '0.60', '0.70', '0.80']:
    for jj in ['2.25', '2.35', '2.45', '2.55', '2.65', '2.75']:
        for kk in ['100','1000','2500','5000','10000']:
            if RR["gam2_"+ii+"_"+"gam3_"+jj+"_"+kk+"_"+'RD_w_0'] == []:
                RR["gam2_"+ii+"_"+"gam3_"+jj+"_"+kk+"_"+'RD_w_0'] = 0
            if RR["gam2_"+ii+"_"+"gam3_"+jj+"_"+kk+"_"+'RD_w_1'] == []:
                RR["gam2_"+ii+"_"+"gam3_"+jj+"_"+kk+"_"+'RD_w_1'] = 0




savefile()