# -*- coding: utf-8 -*-

"""
Created on 

@file: log_ana.py
@author: ZhangZ

"""
import matplotlib.pyplot as plt
import pandas as pd
import numpy as np
import os

path = '/root/projects/msk/fewshot/Logs/20211101/'
name = '110053.log'
def log_ana(parent, filename):
    # print(parent + '/' + filename)
    # 读取日志中的关键信息
    title = pd.read_table(parent + '/' + filename, engine='python', nrows=8, header=0, sep=" ")
    # 读取日志中的数据
    df = pd.read_table(parent + '/' + filename, engine='python', header=9, sep=" ")
    # 提取数据中的有用部分
    df_tp = df[df['Type'] == "truth/predict"]
    # 规定所用数据时长
    # print(df_tp)


    print('分类任务')
    cls_num = 8
    conf_mat = np.zeros([cls_num, cls_num])
    for i in range(len(df_tp['num1'].values)):
        true_i = int(np.array(df_tp['num1'].values[i]))
        pre_i = int(np.array(df_tp['num2'].values[i]))
        conf_mat[7 - true_i, pre_i] += 1

    # TPs = [0] * cls_num
    # FPs = [0] * cls_num
    # FNs = [0] * cls_num
    # print(TPs)

    precision = [0] * cls_num
    recall = [0] * cls_num
    f1 = [0] * cls_num

    # for i in range(len(conf_mat)):
    #     for j in range(len(conf_mat[0])):
    #         if i == j:
    #             TPs[i] += conf_mat[i][j]
    #         else:
    #             FPs[j] += conf_mat[i][j]
    #             FNs[i] += conf_mat[i][j]

    # for i in range(len(conf_mat)):
    #     precision[i] = TPs[i] / (TPs[i] + FPs[i]) + 0.0000001
    #     recall[i] = TPs[i] / (TPs[i] + FNs[i])
    #     f1[i] = 2 * precision[i] * recall[i] / (precision[i] + recall[i])
    # plt.rcParams['font.sans-serif'] = ['Microsoft YaHei']  # 可显示中文字符
    # plt.rcParams['axes.unicode_minus'] = False

    classes = list(range(cls_num))
    confusion_matrix = conf_mat

    plt.imshow(confusion_matrix, interpolation='nearest', cmap=plt.cm.Oranges, vmin=0, vmax=100)  # 按照像素显示出矩阵
    plt.title('log_name:' + filename + " mission:" + title[title['info'] == 'mission']['content'].values + " SNR:" +
              title[title['info'] == 'snr']['content'].values)
    # plt.pcolor(X, Y, f(data), cmap=cm, )
    plt.colorbar()
    tick_marks = np.arange(len(classes))
    plt.xticks(tick_marks, classes, rotation=-45)
    classes.reverse()
    plt.yticks(tick_marks, classes)

    thresh = confusion_matrix.max() / 2.
    # iters = [[i,j] for i in range(len(classes)) for j in range((classes))]
    # ij配对，遍历矩阵迭代器
    iters = np.reshape([[[i, j] for j in range(cls_num)] for i in range(cls_num)], (confusion_matrix.size, 2))
    for i, j in iters:
        plt.text(j, i, format(confusion_matrix[i, j]), fontsize=7)  # 显示对应的数字

    plt.ylabel('Truth')
    plt.xlabel('Pred')
    plt.title(filename)
    plt.tight_layout()

    print('某验证1结果：')
    # result = [sum(precision) / 7, sum(recall) / 7]

    dirs = parent[0:27] + 'images'
    print(dirs)
    if not os.path.exists(dirs + '/' + filename[:-10]):
        os.makedirs(dirs + '/' + filename[:-10])
    plt.savefig(dirs + '/' + filename[:-4] + '.png')
    plt.show()


log_ana(path, name)
