import re

def avg(list_):
    return sum(list_) / len(list_)
    
def pretty_print():
    list_raw_res = open("result.csv").readlines()
    i = 1
    explanation_depth_cascading = []
    explanation_depth_classic = []
    explanation_depth_classic_maxdepth = []
    accuracy_cascading = []
    accuracy_classic = []
    accuracy_classic_maxdepth = []
    runtime0 = []
    runtime1 = []
    runtime2 = []
    tp0 = []
    tp1 = []
    tp2 = []
    tn0 = []
    tn1 = []
    tn2 = []
    fp0 = []
    fp1 = []
    fp2 = []
    fn0 = []
    fn1 = []
    fn2 = []
    precision0 = []
    precision1 = []
    precision2 = []
    recall0 = []
    recall1 = []
    recall2 = []
    f10 = []
    f11 = []
    f12 = []
    while i < len(list_raw_res):
        if (i % 3) == 1:
            accuracy_cascading.append(float(re.split(',', list_raw_res[i])[1]))
            explanation_depth_cascading.append(float(re.split(',', list_raw_res[i])[0]))
            runtime0.append(float(re.split(',', list_raw_res[i])[2]))
            tp0.append(float(re.split(',', list_raw_res[i])[3]))
            tn0.append(float(re.split(',', list_raw_res[i])[4]))
            fp0.append(float(re.split(',', list_raw_res[i])[5]))
            fn0.append(float(re.split(',', list_raw_res[i])[6]))
            precision0.append(float(re.split(',', list_raw_res[i])[7]))
            recall0.append(float(re.split(',', list_raw_res[i])[8]))
            f10.append(float(re.split(',', list_raw_res[i])[9]))
        elif (i % 3) == 2:
            accuracy_classic.append(float(re.split(',', list_raw_res[i])[1]))
            explanation_depth_classic.append(float(re.split(',', list_raw_res[i])[0]))
            runtime1.append(float(re.split(',', list_raw_res[i])[2]))
            tp1.append(float(re.split(',', list_raw_res[i])[3]))
            tn1.append(float(re.split(',', list_raw_res[i])[4]))
            fp1.append(float(re.split(',', list_raw_res[i])[5]))
            fn1.append(float(re.split(',', list_raw_res[i])[6]))
            precision1.append(float(re.split(',', list_raw_res[i])[7]))
            recall1.append(float(re.split(',', list_raw_res[i])[8]))
            f11.append(float(re.split(',', list_raw_res[i])[9]))
        elif (i % 3) == 0:
            accuracy_classic_maxdepth.append(float(re.split(',', list_raw_res[i])[1]))
            explanation_depth_classic_maxdepth.append(float(re.split(',', list_raw_res[i])[0]))
            runtime2.append(float(re.split(',', list_raw_res[i])[2]))
            tp2.append(float(re.split(',', list_raw_res[i])[3]))
            tn2.append(float(re.split(',', list_raw_res[i])[4]))
            fp2.append(float(re.split(',', list_raw_res[i])[5]))
            fn2.append(float(re.split(',', list_raw_res[i])[6]))
            precision2.append(float(re.split(',', list_raw_res[i])[7]))
            recall2.append(float(re.split(',', list_raw_res[i])[8]))
            f12.append(float(re.split(',', list_raw_res[i])[9]))
        else:
            pass
        i += 1
    
    print "###Depth###"
    print avg(explanation_depth_cascading)
    print avg(explanation_depth_classic)
    print avg(explanation_depth_classic_maxdepth)
    print "###Accuracy###"
    print avg(accuracy_cascading) 
    print avg(accuracy_classic)
    print avg(accuracy_classic_maxdepth)
    print "###Runtime###"
    print avg(runtime0) 
    print avg(runtime1)
    print avg(runtime2)
    print "###TP###"
    print avg(tp0)
    print avg(tp1)
    print avg(tp2)
    print "###TN###"
    print avg(tn0)
    print avg(tn1)
    print avg(tn2)
    print "###FP###"
    print avg(fp0)
    print avg(fp1)
    print avg(fp2)
    print "###FN###"
    print avg(fn0)
    print avg(fn1)
    print avg(fn2)
    print "###Precision###"
    print avg(precision0)
    print avg(precision1)
    print avg(precision2)
    print "###Recall###"
    print avg(recall0)
    print avg(recall1)
    print avg(recall2)
    print "###F-1###"
    print avg(f10)
    print avg(f11)
    print avg(f12)
