"""
This script reproduce the results of the section "Our algorithm is a better decoder then Greedy." for the greedy part.
"""
import pandas as pd
import matplotlib.pyplot as plt

if __name__ == "__main__":

    # From DIFUSCO paper
    difusco_gap = [0.10, 0.24, 10.85, 13.06]

    n_list = [50, 100, 500, 1000]

    df = pd.read_csv('./output/results_U.csv')

    df_BS = pd.read_csv('./output/results_U_BS_50.csv')

    means_g2 = []
    stds_g2 = []

    means_chrp = []
    stds_chrp = []

    means_g1 = []
    stds_g1 = []

    means_bs = []
    stds_bs = []

    means_ch = []
    stds_ch = []
    for n in n_list:
        # DIFUSCO and G2
        sub_table_g2 = df[(df['n'] == n)]['DIFUSCO+G2']

        mean_value_g2 = sub_table_g2.mean()
        std_value_g2 = sub_table_g2.std()

        # DIFUSCO and CHR+
        sub_table_chrp = df[(df['n'] == n)]['DIFUSCO+ALPS']

        mean_value_chrp = sub_table_chrp.mean()
        std_value_chrp = sub_table_chrp.std()

        # Just Christofides
        sub_table_ch = df[(df['n'] == n)]['christofides']
        mean_value_ch = sub_table_ch.mean()
        std_value_ch = sub_table_ch.std()

        # DIFUSCO and G1
        sub_table_g1 = df[(df['n'] == n)]['DIFUSCO+G1']
        mean_value_g1 = sub_table_g1.mean()
        std_value_g1 = sub_table_g1.std()

        # DIFUSCO and Beam Search
        sub_table_bs = df_BS[(df_BS['n'] == n)]['DIFUSCO+BS']
        mean_value_bs = sub_table_bs.mean()
        std_value_bs = sub_table_bs.std()

        means_g1.append(mean_value_g1)
        stds_g1.append(std_value_g1)
        means_bs.append(mean_value_bs)
        stds_bs.append(std_value_bs)
        means_g2.append(mean_value_g2)
        stds_g2.append(std_value_g2)
        means_chrp.append(mean_value_chrp)
        stds_chrp.append(std_value_chrp)
        means_ch.append(mean_value_ch)
        stds_ch.append(std_value_ch)

    # Plotting
    plt.plot(n_list, means_g2, 'go-', label='G2')
    plt.fill_between(n_list,
                     [means_g2[i] - stds_g2[i] for i in range(len(n_list))],
                     [means_g2[i] + stds_g2[i] for i in range(len(n_list))],
                     alpha=0.2)

    plt.plot(n_list, means_chrp, 'o-', color='orange', label='CHR+')
    plt.fill_between(n_list,
                     [means_chrp[i] - stds_chrp[i] for i in range(len(n_list))],
                     [means_chrp[i] + stds_chrp[i] for i in range(len(n_list))],
                     alpha=0.2)

    plt.plot(n_list, means_g1, 'bs-', label='G1')
    plt.fill_between(n_list,
                     [means_g1[i] - stds_g1[i] for i in range(len(n_list))],
                     [means_g1[i] + stds_g1[i] for i in range(len(n_list))],
                     alpha=0.2)

    plt.plot(n_list, means_bs, 'r^-', label='BS')
    plt.fill_between(n_list,
                     [means_bs[i] - stds_bs[i] for i in range(len(n_list))],
                     [means_bs[i] + stds_bs[i] for i in range(len(n_list))],
                     alpha=0.2)

    plt.plot(n_list, means_ch, 'mD-', label='CHR')
    plt.fill_between(n_list,
                     [means_ch[i] - stds_ch[i] for i in range(len(n_list))],
                     [means_ch[i] + stds_ch[i] for i in range(len(n_list))],
                     alpha=0.2)

    plt.plot(n_list, difusco_gap, 'kx-', label='DIFUSCO paper')

    plt.xticks(n_list)

    plt.ylim(0, 120)

    plt.xlabel('Number of nodes n')
    plt.ylabel('Optimality Gap (%)')
    plt.legend()
    plt.grid()
    plt.savefig('./figures/difusco_focus.png')
    plt.show()