import pandas as pd
from matplotlib import pyplot as plt
import numpy as np


def np_move_avg(a, n, mode="same"):
    return (np.convolve(a, np.ones((n,)) / n, mode=mode))

plt.figure()
plt.title('Result Analysis')

for index, mytime in enumerate([173746,174707,175706,180748,181904,183102,184337,185655,191054,192533]):
    # 读取日志中的关键信息
    title = pd.read_table('D:/Users/MI/Desktop/实验结果/IJMAI/Logs/CSEv1_aver_3_1_ResNet18_{}_distance_entropy_select.log'.format(mytime), nrows=8, header=0, sep=" ")
    # 读取日志中的数据
    df = pd.read_table( 'D:/Users/MI/Desktop/实验结果/IJMAI/Logs/CSEv1_aver_3_1_ResNet18_{}_distance_entropy_select.log'.format(mytime), header=7, sep=" ")
    # 提取数据中的有用部分
    df_train_loss = df[df['Type'] == "train_loss"]
    df_test_loss = df[df['Type'] == "test_loss"]
    df_train_acc = df[df['Type'] == "train_acc"]
    df_test_acc = df[df['Type'] == "test_acc"]


    # plt.subplot(221)
    # plt.plot(df_train_loss['num1'].values, alpha=0.3)
    # plt.plot(np_move_avg(df_train_loss['num1'].values, int(len(df_train_loss['num1'].values) / 50), mode='valid'))
    # plt.title('train_loss')
    # plt.subplot(222)
    # plt.plot(df_test_loss['num1'].values, alpha=0.3)
    # plt.plot(np_move_avg(df_test_loss['num1'].values, int(len(df_test_loss['num1'].values) / 50), mode='valid'))
    # plt.title('test_loss')
    # plt.subplot(223)
    # plt.plot(df_train_acc['num1'].values, alpha=0.3)
    # plt.plot(np_move_avg(df_train_acc['num1'].values, int(len(df_train_loss['num1'].values) / 50), mode='valid'))
    # plt.title('train_acc')
    # plt.subplot(224)
    # plt.plot(df_test_acc['num1'].values, alpha=0.3)
    plt.plot(np_move_avg(df_test_acc['num1'].values, int(len(df_test_loss['num1'].values) / 50), mode='valid'))
    # plt.title('test_acc')
    # plt.legend()

    # plt.suptitle(
    #     ' ' +
    #     title[title['info'] == 'dataset_name']['content'].values + ' ' +
    #     title[title['info'] == 'classifier_name']['content'].values + ' ' +
    #     title[title['info'] == 'method_name']['content'].values + ' ' +
    #     title[title['info'] == 'proportion']['content'].values
    # )

plt.show()