import os
import subprocess
import re
import numpy as np
import itertools
import pickle

directory= os.getcwd()


models=[100,250,10000,15000,30000]

d={}
d_test_e={}
d_train_e={}
d_test_r={}
d_train_r={}
for model in models:
    d_test_e[model]=[]
    d_train_e[model]=[]
    d_test_r[model]=[]
    d_train_r[model]=[]

files_under=[]

for filename in os.listdir(directory):
     if filename.startswith("slurm"):  
         line = subprocess.check_output(['tail', '-14', filename])
         line=line.decode("utf-8")
         line=str(line)
         #print(line)
         flts=re.findall(r"[-+]?\d*\.\d+|\d+", line)
         
         #print(flts)
         #['0.503086519241333', '78.2', '0', '0.0', '0.1', '100', '0.0', '1', '300', '2', '600', '0.0007']
         #print("flts")
         #print(flts)
         #print(line)
         
         train_acc=float(flts[1])
         test_acc=float(float(flts[0]))
         
         print(filename)
         print(train_acc)
         print(test_acc)

         seed = int(flts[3])#int(re.search(r'Seed: (\d+)', line).group(1))

         neurons = int(flts[8])


         #print(neurons)
         #print(seed)

         line = subprocess.check_output(['tail', '-1', filename])
         line=line.decode("utf-8")
         line=str(line)
         #print(filename)
         #print(line)
         #LR = re.search(r'LR: (\d+)', line).group(1)
         LR = float(flts[8])
         flts=re.findall(r"[-+]?\d*\.\d+|\d+", line)
         
         temp=[]
         try:
            for i in range(10):
                temp.append(int(flts[i]))
            if neurons==10 or neurons==50:
                if sum(temp)!=0:
                    files_under.append(filename)     
         except:
             continue
         if not neurons in d.keys():
             d[neurons]=np.array([0 for i in range(10)])

         d[neurons]=d[neurons]+np.array(temp)
         print(temp)
         print(sum(temp))
         print("")
         if sum(temp)!=0:
             #print(neurons)
             #print(filename)
             d_test_r[neurons].append(test_acc)
             d_train_r[neurons].append(train_acc)
         else:
             d_test_e[neurons].append(test_acc)
             d_train_e[neurons].append(train_acc)
#print(d)
#print(files_under)

print("No feature")

print("")
for model in models:
    print(model)
    print(d_test_e[model])
    print(d_train_e[model])
    print("test")
    print("avg")
    print(np.mean(d_test_e[model]))
    print("std")
    print(np.std(d_test_e[model]))
    print("train")
    print("avg")
    print(np.mean(d_train_e[model]))
    print("std")
    print(np.std(d_train_e[model]))
    print("")


print("feature")

print("")
for model in models:
    print(model)
    print(d_test_r[model])
    print(d_train_r[model])
    print("test")
    print("avg")
    print(np.mean(d_test_r[model]))
    print("std")
    print(np.std(d_test_r[model]))
    print("train")
    print("avg")
    print(np.mean(d_train_r[model]))
    print("std")
    print(np.std(d_train_r[model]))
    print("")
