import numpy as np
import matplotlib.pyplot as plt
from matplotlib.pyplot import ylabel
from numpy.ma.extras import average

from plotting_function import cumulative_regret_plotting, cumulative_regret_plotting_multiple



def plot_cosine_avg():
    cosine_rand_data = np.load("data/plots/cosine_add_5_5_2_500_1.0_0.0_1_random_2_10.npz")
    cosine_LinCDB_data = np.load("data/plots/cosine_add_5_5_2_500_1.0_0.0_1_linear_ucb_2_1.0_1.0_1_10.npz")
    cosine_neural_ucb_data = np.load("data/plots/cosine_add_5_5_2_500_1.0_0.0_1_neural_ucb_2_False_1.0_1.0_1_10_10.npz")
    # cosine_neural_ts_data = np.load("data/plots/cosine_add_5_5_2_500_1.0_0.0_1_neural_ts_2_False_1.0_1.0_1_10_10.npz")

    # print(np.sum(cosine_rand_data['average_regret']))
    # print(np.sum(cosine_LinCDB_data['average_regret']))
    # print(np.sum(cosine_neural_ucb_data['average_regret']))
    # print(np.sum(cosine_neural_ts_data['average_regret']))

    ylabel = "Cumulative Regret(average)"
    plot_location = 'cosine'
    plot_to_save = plot_location + "_average.png"
    # cases = ['Random Search','LinCDB','NCDB-UCB','NCDB-TS']
    cases = ['Uniform Sampling', 'LinCDB', 'NCDB']

    data = np.stack([
        cosine_rand_data['average_regret'],
        cosine_LinCDB_data['average_regret'],
        cosine_neural_ucb_data['average_regret']
        # cosine_neural_ts_data['average_regret']
    ], axis=1)  # -> shape = (10, 4, 500)

    # Average regret plotting
    cumulative_regret_plotting_multiple(data, cases, plot_to_save, 'upper left',ylabel)


    ylabel = "Cumulative Regret(weak)"
    plot_location = 'cosine'
    plot_to_save = plot_location + "_weak.png"
    # cases = ['Random Search', 'LinCDB', 'NCDB-UCB', 'NCDB-TS']

    data = np.stack([
        cosine_rand_data['weak_regret'],
        cosine_LinCDB_data['weak_regret'],
        cosine_neural_ucb_data['weak_regret']
        # cosine_neural_ts_data['weak_regret']
    ], axis=1)  # -> shape = (10, 4, 500)

    # Weak regret plotting
    cumulative_regret_plotting_multiple(data, cases, plot_to_save, 'upper left', ylabel)



def plot_square_avg():
    rand_data = np.load("data/plots/square_add_5_5_2_500_1.0_0.0_1_random_2_10.npz")
    LinCDB_data = np.load("data/plots/square_add_5_5_2_500_1.0_0.0_1_linear_ucb_2_1.0_1.0_1_10.npz")
    neural_ucb_data = np.load("data/plots/square_add_5_5_2_500_1.0_0.0_1_neural_ucb_2_False_1.0_1.0_1_10_10.npz")
    # neural_ts_data = np.load("data/plots/square_add_5_5_2_500_1.0_0.0_1_neural_ts_2_False_1.0_1.0_1_10_10.npz")

    # print(np.sum(cosine_rand_data['average_regret']))
    # print(np.sum(cosine_LinCDB_data['average_regret']))
    # print(np.sum(cosine_neural_ucb_data['average_regret']))
    # print(np.sum(cosine_neural_ts_data['average_regret']))

    ylabel = "Cumulative Regret(average)"
    plot_location = 'square'
    plot_to_save = plot_location + "_average.png"
    # cases = ['Random Search','LinCDB','NCDB-UCB','NCDB-TS']
    cases = ['Uniform Sampling','LinCDB','NCDB']


    data = np.stack([
        rand_data['average_regret'],
        LinCDB_data['average_regret'],
        neural_ucb_data['average_regret']
        # neural_ts_data['average_regret']
    ], axis=1)  # -> shape = (10, 4, 500)

    # Average regret plotting
    cumulative_regret_plotting_multiple(data, cases, plot_to_save, 'upper left',ylabel)


    ylabel = "Cumulative Regret(weak)"
    plot_location = 'square'
    plot_to_save = plot_location + "_weak.png"
    # cases = ['Random Search', 'LinCDB', 'NCDB-UCB', 'NCDB-TS']

    data = np.stack([
        rand_data['weak_regret'],
        LinCDB_data['weak_regret'],
        neural_ucb_data['weak_regret']
        # neural_ts_data['weak_regret']
    ], axis=1)  # -> shape = (10, 4, 500)

    # Weak regret plotting
    cumulative_regret_plotting_multiple(data, cases, plot_to_save, 'upper left', ylabel)


def plot_linear_avg():
    rand_data = np.load("data/plots/linear_add_5_5_2_500_1.0_0.0_1_random_2_10.npz")
    LinCDB_data = np.load("data/plots/linear_add_5_5_2_500_1.0_0.0_1_linear_ucb_2_1.0_1.0_1_10.npz")
    neural_ucb_data = np.load("data/plots/linear_add_5_5_2_500_1.0_0.0_1_neural_ucb_2_False_1.0_1.0_1_10_10.npz")
    # neural_ts_data = np.load("data/plots/linear_add_5_5_2_500_1.0_0.0_1_linear_ucb_2_1.0_1.0_1_10.npz")

    # print(np.sum(cosine_rand_data['average_regret']))
    # print(np.sum(cosine_LinCDB_data['average_regret']))
    # print(np.sum(cosine_neural_ucb_data['average_regret']))
    # print(np.sum(cosine_neural_ts_data['average_regret']))

    ylabel = "Cumulative Regret(average)"
    plot_location = 'linear'
    plot_to_save = plot_location + "_average.png"
    # cases = ['Random Search','LinCDB','NCDB-UCB','NCDB-TS']
    cases = ['Uniform Sampling','LinCDB','NCDB']


    data = np.stack([
        rand_data['average_regret'],
        LinCDB_data['average_regret'],
        neural_ucb_data['average_regret']
        # neural_ts_data['average_regret']
    ], axis=1)  # -> shape = (10, 4, 500)

    # Average regret plotting
    cumulative_regret_plotting_multiple(data, cases, plot_to_save, 'upper left',ylabel)


    ylabel = "Cumulative Regret(weak)"
    plot_to_save = plot_location + "_weak.png"
    # cases = ['Random Search', 'LinCDB', 'NCDB-UCB', 'NCDB-TS']

    data = np.stack([
        rand_data['weak_regret'],
        LinCDB_data['weak_regret'],
        neural_ucb_data['weak_regret']
        # neural_ts_data['weak_regret']
    ], axis=1)  # -> shape = (10, 4, 500)

    # Weak regret plotting
    cumulative_regret_plotting_multiple(data, cases, plot_to_save, 'upper left', ylabel)


def plot_var_dimension():

    data_dim5 = np.load("data/plots/square_add_5_5_2_500_1.0_0.0_1_neural_ucb_2_False_1.0_1.0_1_10_10.npz")
    data_dim10 = np.load("data/plots/square_add_10_5_2_500_1.0_0.0_1_neural_ucb_2_False_1.0_1.0_1_10_10.npz")
    data_dim15 = np.load("data/plots/square_add_15_5_2_500_1.0_0.0_1_neural_ucb_2_False_1.0_1.0_1_10_10.npz")
    data_dim20 = np.load("data/plots/square_add_20_5_2_500_1.0_0.0_1_neural_ucb_2_False_1.0_1.0_1_10_10.npz")
    data_dim25 = np.load("data/plots/square_add_25_5_2_500_1.0_0.0_1_neural_ucb_2_False_1.0_1.0_1_10_10.npz")

    # neural_ts_data = np.load("data/plots/linear_add_5_5_2_500_1.0_0.0_1_linear_ucb_2_1.0_1.0_1_10.npz")

    # print(np.sum(cosine_rand_data['average_regret']))
    # print(np.sum(cosine_LinCDB_data['average_regret']))
    # print(np.sum(cosine_neural_ucb_data['average_regret']))
    # print(np.sum(cosine_neural_ts_data['average_regret']))

    ylabel = "Cumulative Regret(average)"
    plot_location = 'square_var_dim'
    plot_to_save = plot_location + "_average.png"
    # cases = ['Random Search','LinCDB','NCDB-UCB','NCDB-TS']
    cases = ['NCDB(d=5)','NCDB(d=10)','NCDB(d=15)','NCDB(d=20)','NCDB(d=25)']


    data = np.stack([
        data_dim5['average_regret'],
        data_dim10['average_regret'],
        data_dim15['average_regret'],
        data_dim20['average_regret'],
        data_dim25['average_regret']
        # neural_ts_data['average_regret']
    ], axis=1)  # -> shape = (10, 4, 500)

    # Average regret plotting
    cumulative_regret_plotting_multiple(data, cases, plot_to_save, 'upper left',ylabel)


    ylabel = "Cumulative Regret(weak)"
    plot_to_save = plot_location + "_weak.png"
    # cases = ['Random Search', 'LinCDB', 'NCDB-UCB', 'NCDB-TS']

    data = np.stack([
        data_dim5['weak_regret'],
        data_dim10['weak_regret'],
        data_dim15['weak_regret'],
        data_dim20['weak_regret'],
        data_dim25['weak_regret']
        # neural_ts_data['weak_regret']
    ], axis=1)  # -> shape = (10, 4, 500)

    # Weak regret plotting
    cumulative_regret_plotting_multiple(data, cases, plot_to_save, 'upper left', ylabel)



def plot_var_k():

    data_supersize_2 = np.load("data/plots/square_add_5_10_2_500_1.0_0.0_1_neural_ucb_2_False_1.0_1.0_1_10_10.npz")
    data_supersize_3 = np.load("data/plots/square_add_5_10_3_500_1.0_0.0_1_neural_ucb_3_False_1.0_1.0_1_10_10.npz")
    data_supersize_4 = np.load("data/plots/square_add_5_10_4_500_1.0_0.0_1_neural_ucb_4_False_1.0_1.0_1_10_10.npz")
    data_supersize_5 = np.load("data/plots/square_add_5_10_5_500_1.0_0.0_1_neural_ucb_5_False_1.0_1.0_1_10_10.npz")

    ylabel = "Cumulative Regret(average)"
    plot_location = 'square_var_k'
    plot_to_save = plot_location + "_average.png"
    # cases = ['Random Search','LinCDB','NCDB-UCB','NCDB-TS']
    cases = ['NCDB(k=2)','NCDB(k=3)','NCDB(k=4)','NCDB(k=5)']


    data = np.stack([
        data_supersize_2['average_regret'],
        data_supersize_3['average_regret'],
        data_supersize_4['average_regret'],
        data_supersize_5['average_regret']
        # neural_ts_data['average_regret']
    ], axis=1)  # -> shape = (10, 4, 500)

    # Average regret plotting
    cumulative_regret_plotting_multiple(data, cases, plot_to_save, 'upper left',ylabel)


    ylabel = "Cumulative Regret(weak)"
    plot_to_save = plot_location + "_weak.png"
    # cases = ['Random Search', 'LinCDB', 'NCDB-UCB', 'NCDB-TS']

    data = np.stack([
        data_supersize_2['weak_regret'],
        data_supersize_3['weak_regret'],
        data_supersize_4['weak_regret'],
        data_supersize_5['weak_regret']
        # neural_ts_data['weak_regret']
    ], axis=1)  # -> shape = (10, 4, 500)

    # Weak regret plotting
    cumulative_regret_plotting_multiple(data, cases, plot_to_save, 'upper left', ylabel)






#
#
plot_cosine_avg()
plot_square_avg()
plot_linear_avg()
plot_var_dimension()
plot_var_k()
