import matplotlib.pyplot as plt
import numpy as np
from matplotlib.pyplot import MultipleLocator
import os

if __name__ == '__main__':
    with open('list_data_Dis_mean.txt', 'r') as f:
        # 读取每一行，并将其转换为整数，然后创建一个列表
        Dis_mean = [float(line.strip()) for line in f]
    with open('list_data_Dis_std_1.txt', 'r') as f:
        # 读取每一行，并将其转换为整数，然后创建一个列表
        Dis_std_1 = [float(line.strip()) for line in f]
    with open('list_data_Dis_std_2.txt', 'r') as f:
        # 读取每一行，并将其转换为整数，然后创建一个列表
        Dis_std_2 = [float(line.strip()) for line in f]

    with open('list_data_Gos_mean.txt', 'r') as f:
        # 读取每一行，并将其转换为整数，然后创建一个列表
        Gos_mean = [float(line.strip()) for line in f]
    with open('list_data_Gos_std_1.txt', 'r') as f:
        # 读取每一行，并将其转换为整数，然后创建一个列表
        Gos_std_1 = [float(line.strip()) for line in f]
    with open('list_data_Gos_std_2.txt', 'r') as f:
        # 读取每一行，并将其转换为整数，然后创建一个列表
        Gos_std_2 = [float(line.strip()) for line in f]

    with open('list_data_DSE_mean.txt', 'r') as f:
        # 读取每一行，并将其转换为整数，然后创建一个列表
        DES_mean = [float(line.strip()) for line in f]
    with open('list_data_DSE_std_1.txt', 'r') as f:
        # 读取每一行，并将其转换为整数，然后创建一个列表
        DES_std_1 = [float(line.strip()) for line in f]
    with open('list_data_DSE_std_2.txt', 'r') as f:
        # 读取每一行，并将其转换为整数，然后创建一个列表
        DSE_std_2 = [float(line.strip()) for line in f]

    plt.plot([5, 8, 11, 14, 17, 20], DES_mean, linestyle='--', color='blue', marker='^', markerfacecolor='none',
             markersize=10, label='DRRB-bandit')
    plt.plot([5,8, 11, 14, 17,20], Dis_mean, linestyle=':', color='red', marker='*', markerfacecolor='none',
             markersize=10, label = 'Dis-UCB')
    plt.plot([5,8, 11, 14, 17,20], Gos_mean, linestyle='-', color='green', marker='o', markerfacecolor='none',
             markersize=10, label = 'Gossip-UCB')

    plt.fill_between([5,8, 11, 14, 17,20], DES_std_1, DSE_std_2, color='lightblue', alpha=0.2)
    plt.fill_between([5,8, 11, 14, 17,20], Dis_std_1, Dis_std_2, color='lightcoral', alpha=0.2)
    plt.fill_between([5,8, 11, 14, 17,20], Gos_std_1, Gos_std_2, color='lightgreen', alpha=0.2)


    # plt.subplots_adjust(left=0.2, right=0.9, top=0.9, bottom=0.2)

    # plt.grid(True, linestyle='--')
    # plt.title('regret')
    my_x_ticks =np.arange(5, 23, 3)
    plt.xlabel(r'Number of Agents $N$', fontsize=20)
    plt.ylabel(r'Regret', fontsize=20)
    plt.xticks(my_x_ticks, fontsize=20)
    plt.yticks(fontsize=20)
    from matplotlib.font_manager import FontProperties
    font_prop = FontProperties(family = "Times New Roman", size=20)
    # plt.tight_layout()
    # plt.legend(prop=font_prop)
    plt.grid(False)
    plt.tight_layout()
    # plt.legend(['DistributedUCB', 'GossipUCB', 'DSE'])
    # plt.savefig('multi_armed.png', dpi=1200)~/zhr/3K/graph
    plt.savefig(os.path.join('multi_agents_3method3.png'), dpi=400)



    # plt.xticks(fontsize=15)
    # plt.yticks(fontsize=15)
    # from matplotlib.font_manager import FontProperties
    # font_prop = FontProperties(family="Times New Roman", size=16)
    # plt.legend(prop=font_prop)
    # plt.legend()
    # plt.show()
    # plt.savefig('different_gamma.png', dpi=400)
    # plt.savefig(os.path.join('/home/amax/zhr/7k/graph', 'different_sigma3.png'))