import numpy as np
import os

def saveResult(dataName='', algName='', result=[], time1=0, time2=0, time3=0, filename='result.txt'):
    f = open(filename, 'a')
    print(dataName, end='\t', file=f)
    print(algName, end='\t', file=f)
    for i in range(len(result)):
        print(result[i], end='\t', file=f)
    if(time1>0):
        print(time1, end='\t', file=f)
    if(time2>0):
        print(time2, end='\t', file=f)
    if(time3>0):
        print(time3, end='\t', file=f)
    print('', file=f)
    f.close()

def saveMat(mat,dim=2,filename='rst'):
    f = open(filename,'a')
    if(dim==1):
        for i in range(len(mat)):
            print(mat[i],end='\t',file=f)
        print('',file=f)
        print('==============================',file=f)
    elif(dim==2):
        for i in range(len(mat)):
            for j in range(len(mat[i])):
                print(mat[i][j],end='\t',file=f)
            print('',file=f)
        print('==============================',file=f)
    elif(dim==3):
        for i in range(len(mat)):
            print('----------'+str(i+1)+'----------',file=f)
            for j in range(len(mat[i])):
                for k in range(len(mat[i][j])):
                    print(mat[i][j][k],end='\t',file=f)
                print('',file=f)
        print('==============================',file=f)
    else:
        return None
    f.close()

def savearray(mat,filename='rst'):
    dir_path = os.path.dirname(filename)
    if dir_path and not os.path.exists(dir_path):
        os.makedirs(dir_path)

    dims = np.shape(mat)
    dim = len(dims)
    f = open(filename,'a')
    if(dim==1):
        for i in range(len(mat)):
            print(mat[i],end='\t',file=f)
        print('',file=f)
    elif(dim==2):
        for i in range(dims[0]):
            for j in range(dims[1]):
                print(mat[i][j],end='\t',file=f)
            print('',file=f)
    f.close()

def readMat(filename,matdim):
    mat = np.zeros(matdim)
    i = 0
    for line in open(filename, 'r'):
        lines = line.split('\t')
        for j in range(len(mat[0])):
            mat[i][j] = float(lines[j])
        i += 1
    return mat

def readarray(filename,num=0,type=int):
    array = []
    i = 0
    for line in open(filename, 'r'):
        line = line.strip()
        lines = line.split('\t')
        tmp = []
        for j in range(len(lines)):
            tmp.append(type(lines[j]))
        array.append(tmp)
        i += 1
        if i==num:
            return array
    return array

if __name__ == '__main__':
    numdata = 14
    datasnames = ["Birds","CHD_49","Corel5k","Emotions","GpositiveGO","Image","Langlog","Scene","Chemistry","Philosophy","Tmc2007_500","Water_quality","Yeast","Yelp"]
    savearray(datasnames,'log/names')