import os
cwd = os.getcwd()
import re
import numpy as np


training={}
test={}
fnames={}
params_array={}



for filename in os.listdir(cwd):
    #print(filename)
    path=cwd+"/"+filename
    if not "slurm" in filename:
        continue
    path=True
    #print(filename)
	

    #if os.path.exists(path):
    if path:
        i=0
        j=0
        params=0
        with open(cwd+"/"+filename) as file:
            count=0
            for line in file:
                if count:
                    if not i or not j:
                        break
                    params_array[(i,j)]=line
                    count=0

                if "Parameters" in line:
                    count=1

                match1 = re.search('Final Training Accuracy: (\d+\.\d+)', line)
                match2 = re.search('Final Test Accuracy: (\d+\.\d+)', line)
                match3 = re.search('d_model  :  (\d+)', line)
                match5 = re.search('d_model=(\d+)', line)
                match4 = re.search('n_head  :  (\d+)', line)
                match6 = re.search('n_head=(\d+)', line) 
                if match4 or match6:
                    if match4:
                        j=int(match4.group(1))
                    if match6:
                        j=int(match6.group(1))                    
                if match3 or match5:
                    if match3:
                        i=int(match3.group(1))
                    if match5:
                        i=int(match5.group(1))
                    #print("d_model")
                    #print(i)
                if match1:
                    if not i or not j:
                        break

                    if not (i,j) in training.keys():
                        training[(i,j)]=[]
                        test[(i,j)]=[]   
                        fnames[(i,j)]=[] 
                            
                    training[(i,j)].append(float(match1.group(1)))

                if match2:
                    test[(i,j)].append(float(match2.group(1)))
                    #print(filename)
                    #print(match2.group(1))
                    #print("")
                    fnames[(i,j)].append(filename)
                


for i in training.keys():
    print(i)
    if not test[i]:
        continue
    index=np.argmax(np.array(test[i]))
    print(test[i][index])
    print("n_head d_model training_acc test_acc params file_name")
    print("{n_head} {d_model} {tra} {test} {par} {fname}".format(n_head=i[1],d_model=i[0],tra=training[i][index],test=test[i][index],par=params_array[i] ,fname=fnames[i][index]))
    #print(training[i][index])
    #print(test[i][index])
    #print(fnames[i][index])
    print("")

for i in params_array.keys():
    print(i)
    print(params_array[i])
    print("")
