# !/usr/bin/env python
# coding: utf-8

# Importing python packages
import matplotlib
import matplotlib.pyplot as plt
import numpy as np


labels  = ['Square', 'Cosine', 'Sine']

# Cumulative regret
ofd_ucb     = [3915.64, 124.13, 177.54]
ofd_ts      = [1144.41, 121.07, 557.65]
ofd_gp_ucb  = [228.66, 474.79, 788.35]
ofd_gp_ts   = [228.86, 461.70, 862.32]

x = np.arange(len(labels))  # the label locations
width = 0.4  # the width of the bars

fig, ax = plt.subplots()
rects1 = ax.bar(x - 3*width/4, ofd_ucb, width/2, label='OFD-UCB', yerr=(19.13, 3.42, 3.40), capsize=7)
rects2 = ax.bar(x - width/4, ofd_ts, width/2, label='OFD-TS', yerr=(41.54, 3.13, 65.20), capsize=7)
rects3 = ax.bar(x + width/4, ofd_gp_ucb, width/2, label='OFD-GP-UCB', yerr=(15.72, 32.63, 11.82), capsize=7)
rects4 = ax.bar(x + 3*width/4, ofd_gp_ts, width/2, label='OFD-GP-TS', yerr=(14.10, 12.08, 6.32), capsize=7)


# Add some text for labels, title and custom x-axis tick labels, etc.
# ax.set_ylabel('Total Cost = ' + r'$\sum_{t=1}^T(\gamma_{I_t}(x_t) + C_{I_t})$', fontsize=15)
ax.set_ylabel('Total Cost', fontsize=15)
# ax.set_title('Total cost for different cases')
ax.set_xticks(x)
ax.set_xticklabels(labels, fontsize=15)
ax.legend(loc='best', bbox_to_anchor=(0.37, 0.73))


def autolabel(rects):
    """Attach a text label above each bar in *rects*, displaying its height."""
    for rect in rects:
        height = rect.get_height()
        ax.annotate('',
            xy=(rect.get_x() + rect.get_width() / 2, height),
            xytext=(0, 3),  # 3 points vertical offset
            textcoords="offset points",
            ha='center', va='bottom')

autolabel(rects1)
autolabel(rects4)
autolabel(rects2)
autolabel(rects3)

fig.tight_layout()
plt.savefig('diabetes.png')