{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "import re\n",
    "import xlsxwriter as xlsx\n",
    "from plotsettings import BBOX_INCHES, signature, maximizeWindow, palette, makemarkers, add_percent_formatter, legend, show_and_save, nrows_ncols, violin_or_box_plot, adjust_xticks_subplots, table_to_latex\n",
    "\n",
    "\n",
    "\n",
    "class Plot(object):\n",
    "\n",
    "    def __init__(self):\n",
    "        self.C = 5\n",
    "        pass\n",
    "        \n",
    "        \n",
    "    def plot(self, savefig=None, path=None, experiment = None):\n",
    "        if experiment == None:\n",
    "            self.plotMyRegret(savefig = savefig, path=path)\n",
    "        elif experiment == \"M\":\n",
    "            self.plotLastRegretVersusM(savefig = savefig, path=path)\n",
    "        elif experiment == \"K\":\n",
    "            self.plotLastRegretVersusK(savefig = savefig, path=path)\n",
    "        elif experiment == \"T\":\n",
    "            self.plotLastRegretVersusT(savefig = savefig, path=path)\n",
    "\n",
    "\n",
    "    def plotMyRegret(self, savefig=None, path=None):\n",
    "        formats = ('png', 'pdf', 'eps')\n",
    "        # plt.rcParams['figure.figsize'] = (12,8)\n",
    "        # plt.rcParams['figure.dpi'] = 400\n",
    "        # plt.rcParams['figure.figsize'] = (20,10)\n",
    "        # plt.rcParams['figure.dpi'] = 200\n",
    "        plt.rcParams['font.family'] = \"sans-serif\"\n",
    "        plt.rcParams['font.sans-serif'] = \"DejaVu Sans\"\n",
    "        plt.rcParams['mathtext.fontset'] = \"cm\"\n",
    "        plt.rcParams['mathtext.rm'] = \"serif\"\n",
    "        Regrets_file_name = path+\"/Regrets_file_name.txt\"\n",
    "        std_Regrets_file_name = path+\"/std_Regrets_file_name.txt\"\n",
    "        Regrets_file_name = open(Regrets_file_name).read().split(\"\\n\")\n",
    "        std_Regrets_file_name = open(std_Regrets_file_name).read().split(\"\\n\")\n",
    "        while \"\" in Regrets_file_name:\n",
    "            Regrets_file_name.remove(\"\")\n",
    "        print(Regrets_file_name)\n",
    "        while \"\" in std_Regrets_file_name:\n",
    "            std_Regrets_file_name.remove(\"\")\n",
    "        print(std_Regrets_file_name)\n",
    "        Regret_data = {}\n",
    "        Regret_std = {}\n",
    "        fig = plt.figure()\n",
    "        plotParams = self._plotParameter(Regrets_file_name)\n",
    "        i = 0\n",
    "        lw = 1\n",
    "        for filename in Regrets_file_name:\n",
    "            filename_path = path + \"/\" + filename\n",
    "            std_filename_path = path + \"/std_\" + filename\n",
    "            Regret_data[filename] = np.loadtxt(filename_path)\n",
    "            Regret_std[filename] = np.loadtxt(std_filename_path)\n",
    "            plt.plot(Regret_data[filename], label = filename[8:-4], color = plotParams[filename][\"color\"], marker=plotParams[filename][\"marker\"], markevery=(1 / 40., 0.1), ls = plotParams[filename][\"ls\"] , lw=lw, ms=int(self.C*lw))\n",
    "            x = np.linspace(0, len(Regret_std[filename])-1, len(Regret_std[filename]))\n",
    "            plt.fill_between(x, Regret_data[filename]-Regret_std[filename], Regret_data[filename]+Regret_std[filename], color = plotParams[filename][\"color\"], alpha = 0.2)\n",
    "            i = i+1\n",
    "        print(Regret_data)\n",
    "        # print(type(Regret_data[filename][2]))\n",
    "        plt.grid(True)\n",
    "        plt.legend(loc = 'upper left', fontsize = 'large')\n",
    "        # plt.ylim(-30, 1300)\n",
    "        # self._xlabel(0, r\"Time steps $t = 1...T$, horizon $T = {}${}\".format(self.horizon, self.signature))\n",
    "        # env = self.envs[envId]\n",
    "        # if hasattr(env, 'changePoints'):\n",
    "        #     ymin, ymax = plt.ylim()\n",
    "        #     # ymin, ymax = plt.ylim(0, ymax)\n",
    "        #     taus = self.envs[envId].changePoints\n",
    "        #     # if len(taus) > 25:\n",
    "        #     #     print(\"WARNING: Adding vlines for the change points with more than 25 change points will be ugly on the plots...\")  # DEBUG\n",
    "        #     # if len(taus) > 50:  # Force to NOT add the vlines\n",
    "        #     #     return plt.xlabel(r\"Time steps $t = 1...T$, horizon $T = {}${}\".format(self.horizon, self.signature))\n",
    "        #     for tau in taus:\n",
    "        #         if tau > 0 and tau < self.horizon:\n",
    "        #             plt.vlines(tau, ymin, ymax, linestyles='dotted', alpha=0.2)\n",
    "        # plt.xlim(0, self.horizon)\n",
    "        plt.xlabel(r\"Time steps $t = 1...T$, horizon\", fontsize=16)\n",
    "        # plt.xlabel(r\"Time steps $t = 1...T$\")\n",
    "        plt.ylabel(\"Regret\", fontsize=16)\n",
    "        \n",
    "        # for form in formats:\n",
    "        #     plt.savefig(\"{}.{}\".format(savefig, form),format=form, dpi=400)\n",
    "        # plt.show()\n",
    "        show_and_save(False , savefig=savefig, fig=fig, pickleit=None)\n",
    "        plt.close(fig)\n",
    "        return fig\n",
    "    \n",
    "    def plotLastRegretVersusM(self, savefig=None, path=None):\n",
    "        formats = ('png', 'pdf', 'eps')\n",
    "        # plt.rcParams['figure.figsize'] = (12,8)\n",
    "        # plt.rcParams['figure.dpi'] = 400\n",
    "        # plt.rcParams['figure.figsize'] = (20,10)\n",
    "        # plt.rcParams['figure.dpi'] = 200\n",
    "        plt.rcParams['font.family'] = \"sans-serif\"\n",
    "        plt.rcParams['font.sans-serif'] = \"DejaVu Sans\"\n",
    "        plt.rcParams['mathtext.fontset'] = \"cm\"\n",
    "        plt.rcParams['mathtext.rm'] = \"serif\"\n",
    "        Regrets_file_name = path+\"/Regrets_versus_M_file_name.txt\"\n",
    "        std_Regrets_file_name = path+\"/std_Regrets_versus_M_file_name.txt\"\n",
    "        Regrets_file_name = open(Regrets_file_name).read().split(\"\\n\")\n",
    "        std_Regrets_file_name = open(std_Regrets_file_name).read().split(\"\\n\")\n",
    "        while \"\" in Regrets_file_name:\n",
    "            Regrets_file_name.remove(\"\")\n",
    "        print(Regrets_file_name)\n",
    "        while \"\" in Regrets_file_name:\n",
    "            std_Regrets_file_name.remove(\"\")\n",
    "        print(std_Regrets_file_name)\n",
    "        Regret_data = {}\n",
    "        Regret_std = {}\n",
    "        fig = plt.figure()\n",
    "        plotParams = self._plotParameter(Regrets_file_name)\n",
    "        i = 0\n",
    "        lw = 1\n",
    "        nb_break_points_path = path + \"/nb_break_points.csv\"\n",
    "        nb_break_points = np.loadtxt(nb_break_points_path)\n",
    "        for filename in Regrets_file_name:\n",
    "            filename_path = path + \"/\" + filename\n",
    "            std_filename_path = path + \"/std_\" + filename\n",
    "            Regret_data[filename] = np.loadtxt(filename_path)\n",
    "            Regret_std[filename] = np.loadtxt(std_filename_path)\n",
    "            plt.plot(nb_break_points, Regret_data[filename], label = filename[17:-4], color = plotParams[filename][\"color\"], marker=plotParams[filename][\"marker\"], markevery=(i / 40., 0.1), ls = plotParams[filename][\"ls\"] , linewidth=lw, ms=int(self.C*lw))\n",
    "            x = np.linspace(0, len(Regret_std[filename])-1, len(Regret_std[filename]))\n",
    "            plt.fill_between(nb_break_points, Regret_data[filename]-Regret_std[filename], Regret_data[filename]+Regret_std[filename], color = plotParams[filename][\"color\"], alpha = 0.2)\n",
    "            i = i+1\n",
    "        print(Regret_data)\n",
    "        # print(type(Regret_data[filename][2]))\n",
    "        plt.grid(True)\n",
    "        plt.legend(loc = 'upper left', fontsize = 'medium')\n",
    "        # self._xlabel(0, r\"Time steps $t = 1...T$, horizon $T = {}${}\".format(self.horizon, self.signature))\n",
    "        # env = self.envs[envId]\n",
    "        # if hasattr(env, 'changePoints'):\n",
    "        #     ymin, ymax = plt.ylim()\n",
    "        #     # ymin, ymax = plt.ylim(0, ymax)\n",
    "        #     taus = self.envs[envId].changePoints\n",
    "        #     # if len(taus) > 25:\n",
    "        #     #     print(\"WARNING: Adding vlines for the change points with more than 25 change points will be ugly on the plots...\")  # DEBUG\n",
    "        #     # if len(taus) > 50:  # Force to NOT add the vlines\n",
    "        #     #     return plt.xlabel(r\"Time steps $t = 1...T$, horizon $T = {}${}\".format(self.horizon, self.signature))\n",
    "        #     for tau in taus:\n",
    "        #         if tau > 0 and tau < self.horizon:\n",
    "        #             plt.vlines(tau, ymin, ymax, linestyles='dotted', alpha=0.2)\n",
    "        # plt.xlim(0, self.horizon)\n",
    "        plt.xlabel(r\"$M$\", fontsize = 16)\n",
    "        # plt.xlabel(r\"Time steps $t = 1...T$\")\n",
    "        plt.ylabel(\"Regret\", fontsize = 16)\n",
    "        \n",
    "        # for form in formats:\n",
    "        #     plt.savefig(\"{}.{}\".format(savefig, form),format=form, dpi=400)\n",
    "        # plt.show()\n",
    "        show_and_save(False , savefig=savefig, fig=fig, pickleit=None)\n",
    "        plt.close(fig)\n",
    "        return fig\n",
    "    \n",
    "    def plotLastRegretVersusK(self, savefig=None, path=None):\n",
    "        formats = ('png', 'pdf', 'eps')\n",
    "        # plt.rcParams['figure.figsize'] = (12,8)\n",
    "        # plt.rcParams['figure.dpi'] = 400\n",
    "        # plt.rcParams['figure.figsize'] = (20,10)\n",
    "        # plt.rcParams['figure.dpi'] = 200\n",
    "        plt.rcParams['font.family'] = \"sans-serif\"\n",
    "        plt.rcParams['font.sans-serif'] = \"DejaVu Sans\"\n",
    "        plt.rcParams['mathtext.fontset'] = \"cm\"\n",
    "        plt.rcParams['mathtext.rm'] = \"serif\"\n",
    "        Regrets_file_name = path+\"/Regrets_versus_K_file_name.txt\"\n",
    "        # std_Regrets_file_name = path+\"/std_Regrets_versus_K_file_name.txt\"\n",
    "        Regrets_file_name = open(Regrets_file_name).read().split(\"\\n\")\n",
    "        # std_Regrets_file_name = open(std_Regrets_file_name).read().split(\"\\n\")\n",
    "        while \"\" in Regrets_file_name:\n",
    "            Regrets_file_name.remove(\"\")\n",
    "        print(Regrets_file_name)\n",
    "        # while \"\" in Regrets_file_name:\n",
    "        #     std_Regrets_file_name.remove(\"\")\n",
    "        # print(std_Regrets_file_name)\n",
    "        Regret_data = {}\n",
    "        Regret_std = {}\n",
    "        fig = plt.figure()\n",
    "        plotParams = self._plotParameter(Regrets_file_name)\n",
    "        i = 0\n",
    "        lw = 1\n",
    "        nb_arms_path = path + \"/nb_arms.csv\"\n",
    "        nb_arms = np.loadtxt(nb_arms_path)\n",
    "        for filename in Regrets_file_name:\n",
    "            filename_path = path + \"/\" + filename\n",
    "            std_filename_path = path + \"/std_\" + filename\n",
    "            Regret_data[filename] = np.loadtxt(filename_path)\n",
    "            Regret_std[filename] = np.loadtxt(std_filename_path)\n",
    "            plt.plot(nb_arms, Regret_data[filename], label = filename[17:-4], color = plotParams[filename][\"color\"], marker=plotParams[filename][\"marker\"], markevery=(i / 40., 0.1), ls = plotParams[filename][\"ls\"] , linewidth=lw, ms=int(self.C*lw))\n",
    "            # plt.errorbar(nb_arms, Regret_data[filename], yerr=Regret_std[filename], label = filename[17:-4], color = plotParams[filename][\"color\"], marker=plotParams[filename][\"marker\"], markevery=(i / 50., 0.1), ls = plotParams[filename][\"ls\"] , linewidth=lw, ms=int(7*lw))\n",
    "            # x = np.linspace(0, len(Regret_std[filename])-1, len(Regret_std[filename]))\n",
    "            # plt.fill_between(x, Regret_data[filename]-Regret_std[filename], Regret_data[filename]+Regret_std[filename], color = plotParams[filename][\"color\"], alpha = 0.2)\n",
    "            i = i+1\n",
    "        print(Regret_data)\n",
    "        # print(type(Regret_data[filename][2]))\n",
    "        plt.grid(True)\n",
    "        plt.legend(loc = 'upper left', fontsize = 'medium')\n",
    "        # self._xlabel(0, r\"Time steps $t = 1...T$, horizon $T = {}${}\".format(self.horizon, self.signature))\n",
    "        # env = self.envs[envId]\n",
    "        # if hasattr(env, 'changePoints'):\n",
    "        #     ymin, ymax = plt.ylim()\n",
    "        #     # ymin, ymax = plt.ylim(0, ymax)\n",
    "        #     taus = self.envs[envId].changePoints\n",
    "        #     # if len(taus) > 25:\n",
    "        #     #     print(\"WARNING: Adding vlines for the change points with more than 25 change points will be ugly on the plots...\")  # DEBUG\n",
    "        #     # if len(taus) > 50:  # Force to NOT add the vlines\n",
    "        #     #     return plt.xlabel(r\"Time steps $t = 1...T$, horizon $T = {}${}\".format(self.horizon, self.signature))\n",
    "        #     for tau in taus:\n",
    "        #         if tau > 0 and tau < self.horizon:\n",
    "        #             plt.vlines(tau, ymin, ymax, linestyles='dotted', alpha=0.2)\n",
    "        # plt.xlim(0, self.horizon)\n",
    "        plt.xlabel(r\"$K$\", fontsize = 16)\n",
    "        # plt.xlabel(r\"Time steps $t = 1...T$\")\n",
    "        plt.ylabel(\"Regret\", fontsize = 16)\n",
    "        \n",
    "        # for form in formats:\n",
    "        #     plt.savefig(\"{}.{}\".format(savefig, form),format=form, dpi=400)\n",
    "        # plt.show()\n",
    "        show_and_save(False , savefig=savefig, fig=fig, pickleit=None)\n",
    "        plt.close(fig)\n",
    "        return fig\n",
    "    \n",
    "    def plotLastRegretVersusT(self, savefig=None, path=None):\n",
    "        formats = ('png', 'pdf', 'eps')\n",
    "        # plt.rcParams['figure.figsize'] = (12,8)\n",
    "        # plt.rcParams['figure.dpi'] = 400\n",
    "        # plt.rcParams['figure.figsize'] = (20,10)\n",
    "        # plt.rcParams['figure.dpi'] = 200\n",
    "        plt.rcParams['font.family'] = \"sans-serif\"\n",
    "        plt.rcParams['font.sans-serif'] = \"DejaVu Sans\"\n",
    "        plt.rcParams['mathtext.fontset'] = \"cm\"\n",
    "        plt.rcParams['mathtext.rm'] = \"serif\"\n",
    "        Regrets_file_name = path+\"/Regrets_versus_T_file_name.txt\"\n",
    "        # std_Regrets_file_name = path+\"/std_Regrets_versus_T_file_name.txt\"\n",
    "        Regrets_file_name = open(Regrets_file_name).read().split(\"\\n\")\n",
    "        # std_Regrets_file_name = open(std_Regrets_file_name).read().split(\"\\n\")\n",
    "        while \"\" in Regrets_file_name:\n",
    "            Regrets_file_name.remove(\"\")\n",
    "        print(Regrets_file_name)\n",
    "        # while \"\" in Regrets_file_name:\n",
    "        #     std_Regrets_file_name.remove(\"\")\n",
    "        # print(std_Regrets_file_name)\n",
    "        Regret_data = {}\n",
    "        Regret_std = {}\n",
    "        fig = plt.figure()\n",
    "        plotParams = self._plotParameter(Regrets_file_name)\n",
    "        i = 0\n",
    "        lw = 1\n",
    "        horizon_path = path + \"/T.csv\"\n",
    "        horizon = np.loadtxt(horizon_path)\n",
    "        for filename in Regrets_file_name:\n",
    "            filename_path = path + \"/\" + filename\n",
    "            std_filename_path = path + \"/std_\" + filename\n",
    "            Regret_data[filename] = np.loadtxt(filename_path)\n",
    "            Regret_std[filename] = np.loadtxt(std_filename_path)\n",
    "            plt.plot(horizon, Regret_data[filename], label = filename[17:-4], color = plotParams[filename][\"color\"], marker=plotParams[filename][\"marker\"], markevery=(i / 40., 0.1), ls = plotParams[filename][\"ls\"] , linewidth=lw, ms=int(self.C*lw))\n",
    "            x = np.linspace(0, len(Regret_std[filename])-1, len(Regret_std[filename]))\n",
    "            plt.fill_between(horizon, Regret_data[filename]-Regret_std[filename], Regret_data[filename]+Regret_std[filename], color = plotParams[filename][\"color\"], alpha = 0.2)\n",
    "            i = i+1\n",
    "        print(Regret_data)\n",
    "        # print(type(Regret_data[filename][2]))\n",
    "        plt.grid(True)\n",
    "        plt.legend(loc = 'upper left', fontsize = 'medium')\n",
    "        # self._xlabel(0, r\"Time steps $t = 1...T$, horizon $T = {}${}\".format(self.horizon, self.signature))\n",
    "        # env = self.envs[envId]\n",
    "        # if hasattr(env, 'changePoints'):\n",
    "        #     ymin, ymax = plt.ylim()\n",
    "        #     # ymin, ymax = plt.ylim(0, ymax)\n",
    "        #     taus = self.envs[envId].changePoints\n",
    "        #     # if len(taus) > 25:\n",
    "        #     #     print(\"WARNING: Adding vlines for the change points with more than 25 change points will be ugly on the plots...\")  # DEBUG\n",
    "        #     # if len(taus) > 50:  # Force to NOT add the vlines\n",
    "        #     #     return plt.xlabel(r\"Time steps $t = 1...T$, horizon $T = {}${}\".format(self.horizon, self.signature))\n",
    "        #     for tau in taus:\n",
    "        #         if tau > 0 and tau < self.horizon:\n",
    "        #             plt.vlines(tau, ymin, ymax, linestyles='dotted', alpha=0.2)\n",
    "        # plt.xlim(0, self.horizon)\n",
    "        plt.xlabel(r\"$T$\", fontsize = 16)\n",
    "        # plt.xlabel(r\"Time steps $t = 1...T$\")\n",
    "        plt.ylabel(\"Regret\", fontsize = 16)\n",
    "        \n",
    "        # for form in formats:\n",
    "        #     plt.savefig(\"{}.{}\".format(savefig, form),format=form, dpi=400)\n",
    "        # plt.show()\n",
    "        show_and_save(False , savefig=savefig, fig=fig, pickleit=None)\n",
    "        plt.close(fig)\n",
    "        return fig\n",
    "    \n",
    "    def _plotParameter(self, Regrets_file_name):\n",
    "        plotParams = {}\n",
    "        allmarkers = ['o', 'D', 'v', 'p', 's', '*', 'h', '>']\n",
    "        i = 0\n",
    "        for filename in Regrets_file_name:\n",
    "            plotParams[filename] = {}\n",
    "            plotParams[filename][\"color\"] = None \n",
    "            plotParams[filename][\"marker\"] = None\n",
    "            plotParams[filename][\"ls\"] = None\n",
    "            if filename.find(\"CUSUM-UCB\") != -1:\n",
    "                plotParams[filename][\"color\"] = \"orange\"\n",
    "                plotParams[filename][\"marker\"] =  allmarkers[i]\n",
    "                i = i + 1\n",
    "            elif filename.find(\"M-UCB\") != -1:\n",
    "                # plotParams[filename][\"color\"] = \"cornflowerblue\"\n",
    "                # plotParams[filename][\"color\"] = \"#1f77b4\"\n",
    "                plotParams[filename][\"color\"] = \"gray\"\n",
    "                if filename.find(\"M-UCB(w=80\") != -1:\n",
    "                    plotParams[filename][\"color\"] = \"cyan\"\n",
    "                elif filename.find(\"M-UCB(w=160\") != -1:\n",
    "                    plotParams[filename][\"color\"] = \"deepskyblue\"\n",
    "                elif filename.find(\"M-UCB(w=320\") != -1:\n",
    "                    plotParams[filename][\"color\"] = \"aquamarine\"\n",
    "                elif filename.find(\"M-UCB(w=720\") != -1:\n",
    "                    plotParams[filename][\"color\"] = \"greenyellow\"\n",
    "                plotParams[filename][\"marker\"] =  allmarkers[i]\n",
    "                i = i + 1\n",
    "            elif filename.find(\"GLR-klUCB(with \") != -1:\n",
    "                plotParams[filename][\"color\"] = \"gray\"\n",
    "                # plotParams[filename][\"marker\"] =  allmarkers[i]\n",
    "                i = i + 1\n",
    "            elif filename.find(\"GLR-UCB\") != -1:\n",
    "                plotParams[filename][\"color\"] = \"olive\"\n",
    "                # plotParams[filename][\"color\"] = \"red\"\n",
    "                plotParams[filename][\"marker\"] =  allmarkers[i]\n",
    "                i = i + 1\n",
    "            elif filename.find(\"Oracle kl-UCB\") != -1:\n",
    "                plotParams[filename][\"color\"] = \"#1E76B4\"\n",
    "            elif filename.find(\"kl-UCB\") != -1:\n",
    "                plotParams[filename][\"color\"] = \"#FF7E0D\"\n",
    "                plotParams[filename][\"ls\"] = (0, (2, 3))\n",
    "            elif filename.find(\"CUSUM-klUCB\") != -1:\n",
    "                # plotParams[filename][\"color\"] = \"#E376C2\"\n",
    "                plotParams[filename][\"color\"] = \"orange\"\n",
    "            elif filename.find(\"M-klUCB\") != -1:\n",
    "                plotParams[filename][\"color\"] = \"#8B564A\"\n",
    "            elif filename.find(\"AdSwitch\") != -1:\n",
    "                plotParams[filename][\"color\"] = \"lime\"\n",
    "            elif filename.find(\"AdSwitch\") != -1:\n",
    "                plotParams[filename][\"color\"] = \"lime\"\n",
    "            elif filename.find(\"Discounted-TS\") != -1:\n",
    "                plotParams[filename][\"color\"] = \"royalblue\"\n",
    "                plotParams[filename][\"marker\"] =  allmarkers[i]\n",
    "                i = i + 1\n",
    "            elif filename.find(\"Discounted-klUCB\") != -1:\n",
    "                plotParams[filename][\"color\"] = \"magenta\"\n",
    "                plotParams[filename][\"marker\"] =  allmarkers[i]\n",
    "                i = i + 1\n",
    "            if filename.find(\"diminishing\") != -1:\n",
    "                plotParams[filename][\"ls\"] = \"--\"\n",
    "        return plotParams"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "['Regrets_M-UCB($w=200$, with diminishing).csv', 'Regrets_M-UCB($w=200$).csv', 'Regrets_ArmSwitch.csv', 'Regrets_AdSwitch.csv']\n",
      "['std_Regrets_M-UCB($w=200$, with diminishing).csv', 'std_Regrets_M-UCB($w=200$).csv', 'std_Regrets_ArmSwitch.csv', 'std_Regrets_AdSwitch.csv']\n",
      "{'Regrets_M-UCB($w=200$, with diminishing).csv': array([  0.6,   1.2,   1.6, ..., 249.2, 249.1, 249.1]), 'Regrets_M-UCB($w=200$).csv': array([  0.6,   1. ,   1.3, ..., 418.9, 418.8, 418.8]), 'Regrets_ArmSwitch.csv': array([8.0000e-01, 1.4000e+00, 1.9000e+00, ..., 1.2436e+03, 1.2440e+03,\n",
      "       1.2445e+03]), 'Regrets_AdSwitch.csv': array([6.0000e-01, 1.0000e+00, 1.3000e+00, ..., 1.9071e+03, 1.9074e+03,\n",
      "       1.9078e+03])}\n",
      "Saving figure with format png, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__K3_T5000_N10_M5_envId6/main__Regret.png'...\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__K3_T5000_N10_M5_envId6/main__Regret.png' created of size '370379b', at 'Fri Apr  5 14:54:10 2024' ...\n",
      "Saving figure with format pdf, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__K3_T5000_N10_M5_envId6/main__Regret.pdf'...\n",
      "Error: could not save current figure to C:/Users/USER/Code/SimulatuionByMe/plot/SP__K3_T5000_N10_M5_envId6/main__Regret.pdf because of error [Errno 13] Permission denied: 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__K3_T5000_N10_M5_envId6/main__Regret.pdf'... Skipping!\n",
      "Saving figure with format eps, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__K3_T5000_N10_M5_envId6/main__Regret.eps'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__K3_T5000_N10_M5_envId6/main__Regret.eps' created of size '1042688b', at 'Fri Apr  5 14:54:10 2024' ...\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "from Environment import Environment\n",
    "from MUCB import MUCB\n",
    "from CUSUM_UCB import CusumUCB\n",
    "from GLR_UCB import GLRUCB\n",
    "from klUCB import klUCB\n",
    "from Oracle_klUCB import OracleklUCB\n",
    "from DTS import DTS\n",
    "from DklUCB import DklUCB\n",
    "from AdSwitch import AdSwitch\n",
    "# from plot import Plot\n",
    "import os, os.path\n",
    "import matplotlib.pyplot as mpl\n",
    "from generate_instance import Regret_versus_K\n",
    "\n",
    "plot_dir = \"C:/Users/USER/Code/SimulatuionByMe/plot/SP__K3_T5000_N10_M5_envId6\"\n",
    "mainfig = plot_dir + \"/main\"\n",
    "if mainfig is not None: mainfig = \"{}__Regret\".format(mainfig)\n",
    "mpl.rcParams['figure.figsize'] = (7.5,5)\n",
    "mpl.rcParams['figure.dpi'] = 400\n",
    "fig = Plot()\n",
    "fig.plot(savefig = mainfig, path = plot_dir)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "['Regrets_Discounted-TS.csv', 'Regrets_Discounted-klUCB.csv', 'Regrets_M-UCB ($w=200$, with diminishing).csv', 'Regrets_M-UCB ($w=200$).csv', 'Regrets_GLR-UCB.csv', 'Regrets_CUSUM-UCB.csv', 'Regrets_CUSUM-UCB (with diminishing).csv']\n",
      "['std_Regrets_Discounted-TS.csv', 'std_Regrets_Discounted-klUCB.csv', 'std_Regrets_M-UCB ($w=200$, with diminishing).csv', 'std_Regrets_M-UCB ($w=200$).csv', 'std_Regrets_GLR-UCB.csv', 'std_Regrets_CUSUM-UCB.csv', 'std_Regrets_CUSUM-UCB (with diminishing).csv']\n",
      "{'Regrets_Discounted-TS.csv': array([3.0000e-01, 6.0000e-01, 9.5000e-01, ..., 9.3742e+02, 9.3743e+02,\n",
      "       9.3744e+02]), 'Regrets_Discounted-klUCB.csv': array([3.30000e-01, 6.00000e-01, 9.10000e-01, ..., 1.30507e+03,\n",
      "       1.30515e+03, 1.30517e+03]), 'Regrets_M-UCB ($w=200$, with diminishing).csv': array([  0.57      ,   1.15      ,   1.44      , ..., 452.74999999,\n",
      "       452.76999999, 452.77999999]), 'Regrets_M-UCB ($w=200$).csv': array([5.7000e-01, 8.6000e-01, 8.6000e-01, ..., 8.2771e+02, 8.2773e+02,\n",
      "       8.2776e+02]), 'Regrets_GLR-UCB.csv': array([  0.57      ,   0.86      ,   0.86      , ..., 503.95999999,\n",
      "       503.95999999, 503.94999999]), 'Regrets_CUSUM-UCB.csv': array([5.7000e-01, 8.6000e-01, 8.6000e-01, ..., 9.2546e+02, 9.2552e+02,\n",
      "       9.2550e+02]), 'Regrets_CUSUM-UCB (with diminishing).csv': array([5.7000e-01, 1.1500e+00, 1.4400e+00, ..., 7.2011e+02, 7.2018e+02,\n",
      "       7.2019e+02])}\n",
      "Saving figure with format png, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__K3_T20000_N100_M5_envId6/main__Regret.png'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__K3_T20000_N100_M5_envId6/main__Regret.png' created of size '582915b', at 'Wed Mar 27 16:32:55 2024' ...\n",
      "Saving figure with format pdf, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__K3_T20000_N100_M5_envId6/main__Regret.pdf'...\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__K3_T20000_N100_M5_envId6/main__Regret.pdf' created of size '2505344b', at 'Wed Mar 27 16:32:57 2024' ...\n",
      "Saving figure with format eps, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__K3_T20000_N100_M5_envId6/main__Regret.eps'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__K3_T20000_N100_M5_envId6/main__Regret.eps' created of size '7002380b', at 'Wed Mar 27 16:32:57 2024' ...\n",
      "['Regrets_versus_M_Discounted-TS.csv', 'Regrets_versus_M_Discounted-klUCB.csv', 'Regrets_versus_M_M-UCB ($w=200$, with diminishing).csv', 'Regrets_versus_M_M-UCB ($w=200$).csv', 'Regrets_versus_M_GLR-UCB.csv', 'Regrets_versus_M_CUSUM-UCB.csv', 'Regrets_versus_M_CUSUM-UCB (with diminishing).csv']\n",
      "['std_Regrets_versus_M_Discounted-TS.csv', 'std_Regrets_versus_M_Discounted-klUCB.csv', 'std_Regrets_versus_M_M-UCB ($w=200$, with diminishing).csv', 'std_Regrets_versus_M_M-UCB ($w=200$).csv', 'std_Regrets_versus_M_GLR-UCB.csv', 'std_Regrets_versus_M_CUSUM-UCB.csv', 'std_Regrets_versus_M_CUSUM-UCB (with diminishing).csv', '']\n",
      "{'Regrets_versus_M_Discounted-TS.csv': array([ 681.87999999,  852.50999999,  944.70999999, 1118.00999999,\n",
      "       1185.30999999, 1388.29999999, 1506.86999999, 1622.18999999,\n",
      "       1766.05999999, 1893.17999999, 2027.96999999]), 'Regrets_versus_M_Discounted-klUCB.csv': array([ 463.26999999,  578.61999999,  642.11999999,  763.49999999,\n",
      "        808.07999999,  942.45999999, 1029.56999999, 1103.90999999,\n",
      "       1208.41999999, 1285.97999999, 1372.74999999]), 'Regrets_versus_M_M-UCB ($w=200$, with diminishing).csv': array([ 235.36999999,  386.28999999,  459.05999999,  614.18999999,\n",
      "        680.44999999,  866.01999999,  924.73999999,  980.40999999,\n",
      "        976.87999999,  980.29999999, 1029.03999999]), 'Regrets_versus_M_M-UCB ($w=200$).csv': array([ 437.58999999,  724.83999999,  836.48999999, 1136.13999999,\n",
      "       1284.34999999, 1554.43999999, 1734.25999999, 1955.56999999,\n",
      "       2271.23999999, 2573.57999999, 2863.46999999]), 'Regrets_versus_M_GLR-UCB.csv': array([ 284.71999999,  444.87999999,  509.30999999,  694.14999999,\n",
      "        786.44999999, 1032.68999999, 1178.51999999, 1309.31999999,\n",
      "       1492.92999999, 1640.51999999, 1797.76999999]), 'Regrets_versus_M_CUSUM-UCB.csv': array([ 694.33999999,  860.35999999,  927.21999999, 1102.60999999,\n",
      "       1204.78999999, 1460.10999999, 1600.64999999, 1788.62999999,\n",
      "       2017.74999999, 2189.05999999, 2378.94999999]), 'Regrets_versus_M_CUSUM-UCB (with diminishing).csv': array([ 602.73999999,  680.52999999,  709.23999999,  838.24999999,\n",
      "        904.64999999, 1078.74999999, 1169.61999999, 1284.21999999,\n",
      "       1425.16999999, 1553.21999999, 1701.51999999])}\n",
      "Saving figure with format png, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__K3_T20000_N100_M_scaling_envId6/main__Regret_versus_M.png'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__K3_T20000_N100_M_scaling_envId6/main__Regret_versus_M.png' created of size '557256b', at 'Wed Mar 27 16:32:57 2024' ...\n",
      "Saving figure with format pdf, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__K3_T20000_N100_M_scaling_envId6/main__Regret_versus_M.pdf'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__K3_T20000_N100_M_scaling_envId6/main__Regret_versus_M.pdf' created of size '25652b', at 'Wed Mar 27 16:32:57 2024' ...\n",
      "Saving figure with format eps, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__K3_T20000_N100_M_scaling_envId6/main__Regret_versus_M.eps'...\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__K3_T20000_N100_M_scaling_envId6/main__Regret_versus_M.eps' created of size '48214b', at 'Wed Mar 27 16:32:57 2024' ...\n",
      "['Regrets_versus_T_Discounted-TS.csv', 'Regrets_versus_T_Discounted-klUCB.csv', 'Regrets_versus_T_M-UCB ($w=200$, with diminishing).csv', 'Regrets_versus_T_M-UCB ($w=200$).csv', 'Regrets_versus_T_GLR-UCB.csv', 'Regrets_versus_T_CUSUM-UCB.csv', 'Regrets_versus_T_CUSUM-UCB (with diminishing).csv']\n",
      "{'Regrets_versus_T_Discounted-TS.csv': array([ 200.01      ,  379.61      ,  594.15      ,  943.78999999,\n",
      "       1700.34      , 2191.44000008, 2623.43000015]), 'Regrets_versus_T_Discounted-klUCB.csv': array([ 219.8       ,  459.11      ,  773.04      , 1308.59999999,\n",
      "       2547.87000001, 3383.72000008, 4126.98000015]), 'Regrets_versus_T_M-UCB ($w=200$, with diminishing).csv': array([131.01      , 233.11      , 327.08      , 460.70999999,\n",
      "       646.98      , 734.31000008, 794.88000015]), 'Regrets_versus_T_M-UCB ($w=200$).csv': array([ 250.78      ,  403.77      ,  602.2       ,  830.03999999,\n",
      "       1265.86      , 1551.30000008, 1723.09000015]), 'Regrets_versus_T_GLR-UCB.csv': array([175.66      , 283.1       , 387.92      , 505.83999999,\n",
      "       712.01      , 810.00000008, 904.72000015]), 'Regrets_versus_T_CUSUM-UCB.csv': array([ 224.51      ,  387.21      ,  584.19      ,  927.00999999,\n",
      "       1783.01      , 2431.24000008, 3015.03000015]), 'Regrets_versus_T_CUSUM-UCB (with diminishing).csv': array([ 166.81      ,  289.63      ,  435.18      ,  728.30999999,\n",
      "       1510.86000001, 2160.67000008, 2728.22000015])}\n",
      "Saving figure with format png, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M5_K3_N100_T_scaling_envId6/main__Regret_versus_T.png'...\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M5_K3_N100_T_scaling_envId6/main__Regret_versus_T.png' created of size '514417b', at 'Wed Mar 27 16:32:58 2024' ...\n",
      "Saving figure with format pdf, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M5_K3_N100_T_scaling_envId6/main__Regret_versus_T.pdf'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M5_K3_N100_T_scaling_envId6/main__Regret_versus_T.pdf' created of size '25221b', at 'Wed Mar 27 16:32:58 2024' ...\n",
      "Saving figure with format eps, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M5_K3_N100_T_scaling_envId6/main__Regret_versus_T.eps'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__M5_K3_N100_T_scaling_envId6/main__Regret_versus_T.eps' created of size '46717b', at 'Wed Mar 27 16:32:58 2024' ...\n",
      "['Regrets_Discounted-TS.csv', 'Regrets_Discounted-klUCB.csv', 'Regrets_M-UCB ($w=200$, with diminishing).csv', 'Regrets_M-UCB ($w=200$).csv', 'Regrets_GLR-UCB.csv', 'Regrets_CUSUM-UCB.csv', 'Regrets_CUSUM-UCB (with diminishing).csv']\n",
      "['std_Regrets_Discounted-TS.csv', 'std_Regrets_Discounted-klUCB.csv', 'std_Regrets_M-UCB ($w=200$, with diminishing).csv', 'std_Regrets_M-UCB ($w=200$).csv', 'std_Regrets_GLR-UCB.csv', 'std_Regrets_CUSUM-UCB.csv', 'std_Regrets_CUSUM-UCB (with diminishing).csv']\n",
      "{'Regrets_Discounted-TS.csv': array([4.30000e-01, 7.70000e-01, 1.20000e+00, ..., 2.37036e+03,\n",
      "       2.37058e+03, 2.37083e+03]), 'Regrets_Discounted-klUCB.csv': array([3.10000e-01, 6.30000e-01, 9.70000e-01, ..., 2.68978e+03,\n",
      "       2.68998e+03, 2.69024e+03]), 'Regrets_M-UCB ($w=200$, with diminishing).csv': array([1.0000e-02, 6.0000e-02, 3.8000e-01, ..., 7.6386e+02, 7.6389e+02,\n",
      "       7.6398e+02]), 'Regrets_M-UCB ($w=200$).csv': array([1.00000e-02, 2.80000e-01, 7.00000e-01, ..., 1.48935e+03,\n",
      "       1.48938e+03, 1.48947e+03]), 'Regrets_GLR-UCB.csv': array([1.0000e-02, 2.8000e-01, 7.0000e-01, ..., 7.7740e+02, 7.7746e+02,\n",
      "       7.7758e+02]), 'Regrets_CUSUM-UCB.csv': array([1.00000e-02, 2.80000e-01, 7.00000e-01, ..., 1.97477e+03,\n",
      "       1.97484e+03, 1.97503e+03]), 'Regrets_CUSUM-UCB (with diminishing).csv': array([1.00000e-02, 6.00000e-02, 3.80000e-01, ..., 1.87699e+03,\n",
      "       1.87711e+03, 1.87727e+03])}\n",
      "Saving figure with format png, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__K6_T18000_N100_M9_envId9/main__Regret.png'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__K6_T18000_N100_M9_envId9/main__Regret.png' created of size '640009b', at 'Wed Mar 27 16:32:59 2024' ...\n",
      "Saving figure with format pdf, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__K6_T18000_N100_M9_envId9/main__Regret.pdf'...\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__K6_T18000_N100_M9_envId9/main__Regret.pdf' created of size '2186637b', at 'Wed Mar 27 16:32:59 2024' ...\n",
      "Saving figure with format eps, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__K6_T18000_N100_M9_envId9/main__Regret.eps'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/SP__K6_T18000_N100_M9_envId9/main__Regret.eps' created of size '6259801b', at 'Wed Mar 27 16:33:00 2024' ...\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "from Environment import Environment\n",
    "from MUCB import MUCB\n",
    "from CUSUM_UCB import CusumUCB\n",
    "from GLR_UCB import GLRUCB\n",
    "from klUCB import klUCB\n",
    "from Oracle_klUCB import OracleklUCB\n",
    "from DTS import DTS\n",
    "from DklUCB import DklUCB\n",
    "from AdSwitch import AdSwitch\n",
    "# from plot import Plot\n",
    "import os, os.path\n",
    "import matplotlib.pyplot as mpl\n",
    "from generate_instance import Regret_versus_K\n",
    "\n",
    "plot_dir = \"C:/Users/USER/Code/SimulatuionByMe/plot/SP__K3_T20000_N100_M5_envId6\"\n",
    "mainfig = plot_dir + \"/main\"\n",
    "if mainfig is not None: mainfig = \"{}__Regret\".format(mainfig)\n",
    "mpl.rcParams['figure.figsize'] = (7.5,5)\n",
    "mpl.rcParams['figure.dpi'] = 400\n",
    "fig = Plot()\n",
    "fig.plot(savefig = mainfig, path = plot_dir)\n",
    "\n",
    "plot_dir = \"C:/Users/USER/Code/SimulatuionByMe/plot/SP__K3_T20000_N100_M_scaling_envId6\"\n",
    "mainfig = plot_dir + \"/main\"\n",
    "if mainfig is not None: mainfig = \"{}__Regret_versus_M\".format(mainfig)\n",
    "mpl.rcParams['figure.figsize'] = (7.5,5)\n",
    "mpl.rcParams['figure.dpi'] = 400\n",
    "fig = Plot()\n",
    "fig.plot(savefig = mainfig, path = plot_dir, experiment= \"M\")\n",
    "\n",
    "plot_dir = \"C:/Users/USER/Code/SimulatuionByMe/plot/SP__M5_K3_N100_T_scaling_envId6\"\n",
    "mainfig = plot_dir + \"/main\"\n",
    "if mainfig is not None: mainfig = \"{}__Regret_versus_T\".format(mainfig)\n",
    "mpl.rcParams['figure.figsize'] = (7.5,5)\n",
    "mpl.rcParams['figure.dpi'] = 400\n",
    "fig = Plot()\n",
    "fig.plot(savefig = mainfig, path = plot_dir, experiment= \"T\")\n",
    "\n",
    "plot_dir = \"C:/Users/USER/Code/SimulatuionByMe/plot/SP__K6_T18000_N100_M9_envId9\"\n",
    "mainfig = plot_dir + \"/main\"\n",
    "if mainfig is not None: mainfig = \"{}__Regret\".format(mainfig)\n",
    "mpl.rcParams['figure.figsize'] = (7.5,5)\n",
    "mpl.rcParams['figure.dpi'] = 400\n",
    "fig = Plot()\n",
    "fig.plot(savefig = mainfig, path = plot_dir)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "['Regrets_Discounted-TS.csv', 'Regrets_Discounted-klUCB.csv', 'Regrets_M-UCB($w=200$, with diminishing).csv', 'Regrets_M-UCB($w=200$).csv', 'Regrets_GLR-UCB.csv', 'Regrets_CUSUM-UCB.csv', 'Regrets_CUSUM-UCB(with diminishing).csv']\n",
      "['std_Regrets_Discounted-TS.csv', 'std_Regrets_Discounted-klUCB.csv', 'std_Regrets_M-UCB($w=200$, with diminishing).csv', 'std_Regrets_M-UCB($w=200$).csv', 'std_Regrets_GLR-UCB.csv', 'std_Regrets_CUSUM-UCB.csv', 'std_Regrets_CUSUM-UCB(with diminishing).csv']\n",
      "{'Regrets_Discounted-TS.csv': array([3.3000e-01, 6.0000e-01, 1.0000e+00, ..., 9.4564e+02, 9.4571e+02,\n",
      "       9.4574e+02]), 'Regrets_Discounted-klUCB.csv': array([3.10000e-01, 6.00000e-01, 9.90000e-01, ..., 1.30888e+03,\n",
      "       1.30904e+03, 1.30913e+03]), 'Regrets_M-UCB($w=200$, with diminishing).csv': array([  0.57      ,   1.12      ,   1.5       , ..., 455.92999999,\n",
      "       456.00999999, 455.99999999]), 'Regrets_M-UCB($w=200$).csv': array([5.7000e-01, 8.3000e-01, 8.6000e-01, ..., 8.4044e+02, 8.4054e+02,\n",
      "       8.4057e+02]), 'Regrets_GLR-UCB.csv': array([  0.57      ,   0.83      ,   0.86      , ..., 516.46999999,\n",
      "       516.51999999, 516.51999999]), 'Regrets_CUSUM-UCB.csv': array([5.7000e-01, 8.3000e-01, 8.6000e-01, ..., 9.1718e+02, 9.1723e+02,\n",
      "       9.1728e+02]), 'Regrets_CUSUM-UCB(with diminishing).csv': array([5.7000e-01, 1.1200e+00, 1.5000e+00, ..., 7.2391e+02, 7.2401e+02,\n",
      "       7.2404e+02])}\n",
      "Saving figure with format png, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/Fig2_SP__K3_T20000_N100_M5_envId6/main__Regret.png'...\n",
      "Error: could not save current figure to C:/Users/USER/Code/SimulatuionByMe/plot/Fig2_SP__K3_T20000_N100_M5_envId6/main__Regret.png because of error Maximum allowed size exceeded... Skipping!\n",
      "Saving figure with format pdf, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/Fig2_SP__K3_T20000_N100_M5_envId6/main__Regret.pdf'...\n",
      "Error: could not save current figure to C:/Users/USER/Code/SimulatuionByMe/plot/Fig2_SP__K3_T20000_N100_M5_envId6/main__Regret.pdf because of error Maximum allowed size exceeded... Skipping!\n",
      "Saving figure with format eps, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/Fig2_SP__K3_T20000_N100_M5_envId6/main__Regret.eps'...\n",
      "Error: could not save current figure to C:/Users/USER/Code/SimulatuionByMe/plot/Fig2_SP__K3_T20000_N100_M5_envId6/main__Regret.eps because of error Maximum allowed size exceeded... Skipping!\n",
      "['Regrets_versus_M_Discounted-TS.csv', 'Regrets_versus_M_Discounted-klUCB.csv', 'Regrets_versus_M_M-UCB($w=200$, with diminishing).csv', 'Regrets_versus_M_M-UCB($w=200$).csv', 'Regrets_versus_M_GLR-UCB.csv', 'Regrets_versus_M_CUSUM-UCB.csv', 'Regrets_versus_M_CUSUM-UCB(with diminishing).csv']\n",
      "['std_Regrets_versus_M_Discounted-TS.csv', 'std_Regrets_versus_M_Discounted-klUCB.csv', 'std_Regrets_versus_M_M-UCB($w=200$, with diminishing).csv', 'std_Regrets_versus_M_M-UCB($w=200$).csv', 'std_Regrets_versus_M_GLR-UCB.csv', 'std_Regrets_versus_M_CUSUM-UCB.csv', 'std_Regrets_versus_M_CUSUM-UCB(with diminishing).csv']\n",
      "{'Regrets_versus_M_Discounted-TS.csv': array([ 670.37999999,  850.86999999,  927.11999999, 1110.39999999,\n",
      "       1184.87999999, 1511.84999999, 1600.51999999, 1890.36999999,\n",
      "       2045.38999999]), 'Regrets_versus_M_Discounted-klUCB.csv': array([ 456.09999999,  577.43999999,  632.47999999,  761.39999999,\n",
      "        806.11999999, 1035.90999999, 1086.51999999, 1288.99999999,\n",
      "       1393.74999999]), 'Regrets_versus_M_M-UCB($w=200$, with diminishing).csv': array([ 229.82999999,  381.95999999,  433.09999999,  601.13999999,\n",
      "        675.61999999,  927.20999999,  969.24999999,  979.83999999,\n",
      "       1045.83999999]), 'Regrets_versus_M_M-UCB($w=200$).csv': array([ 445.23999999,  707.42999999,  820.00999999, 1137.69999999,\n",
      "       1284.94999999, 1729.45999999, 1939.78999999, 2557.87999999,\n",
      "       2893.36999999]), 'Regrets_versus_M_GLR-UCB.csv': array([ 276.86999999,  438.36999999,  495.12999999,  682.34999999,\n",
      "        778.80999999, 1180.14999999, 1301.76999999, 1636.90999999,\n",
      "       1824.24999999]), 'Regrets_versus_M_CUSUM-UCB.csv': array([ 693.30999999,  842.27999999,  925.30999999, 1101.28999999,\n",
      "       1212.22999999, 1599.32999999, 1787.70999999, 2195.90999999,\n",
      "       2385.27999999]), 'Regrets_versus_M_CUSUM-UCB(with diminishing).csv': array([ 577.71999999,  634.20999999,  717.89999999,  828.83999999,\n",
      "        900.95999999, 1155.06999999, 1292.02999999, 1569.35999999,\n",
      "       1718.34999999])}\n",
      "Saving figure with format png, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/Fig3_SP__K3_T20000_N100_M_scaling_envId6/main__Regret_versus_M.png'...\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "c:\\Users\\USER\\Code\\SimulatuionByMe\\sim\\lib\\site-packages\\matplotlib\\lines.py:169: RuntimeWarning: divide by zero encountered in double_scalars\n",
      "  marker_delta = np.arange(start * scale, delta[-1], step * scale)\n",
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/Fig3_SP__K3_T20000_N100_M_scaling_envId6/main__Regret_versus_M.png' created of size '314039b', at 'Thu Feb  1 19:07:25 2024' ...\n",
      "Saving figure with format pdf, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/Fig3_SP__K3_T20000_N100_M_scaling_envId6/main__Regret_versus_M.pdf'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/Fig3_SP__K3_T20000_N100_M_scaling_envId6/main__Regret_versus_M.pdf' created of size '24142b', at 'Thu Feb  1 19:07:25 2024' ...\n",
      "Saving figure with format eps, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/Fig3_SP__K3_T20000_N100_M_scaling_envId6/main__Regret_versus_M.eps'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/Fig3_SP__K3_T20000_N100_M_scaling_envId6/main__Regret_versus_M.eps' created of size '41733b', at 'Thu Feb  1 19:07:25 2024' ...\n",
      "['Regrets_versus_T_Discounted-TS.csv', 'Regrets_versus_T_Discounted-klUCB.csv', 'Regrets_versus_T_M-UCB($w=200$, with diminishing).csv', 'Regrets_versus_T_M-UCB($w=200$).csv', 'Regrets_versus_T_GLR-UCB.csv', 'Regrets_versus_T_CUSUM-UCB.csv', 'Regrets_versus_T_CUSUM-UCB(with diminishing).csv']\n",
      "{'Regrets_versus_T_Discounted-TS.csv': array([ 205.98      ,  386.16      ,  586.08      ,  933.47999999,\n",
      "       1694.10000001, 2640.68000015]), 'Regrets_versus_T_Discounted-klUCB.csv': array([ 225.18      ,  458.78      ,  767.26      , 1294.75999999,\n",
      "       2547.94000001, 4145.50000015]), 'Regrets_versus_T_M-UCB($w=200$, with diminishing).csv': array([131.6       , 243.16      , 321.08      , 439.37999999,\n",
      "       653.68000001, 790.52000015]), 'Regrets_versus_T_M-UCB($w=200$).csv': array([ 258.1       ,  415.6       ,  600.32      ,  822.25999999,\n",
      "       1255.24000001, 1688.72000015]), 'Regrets_versus_T_GLR-UCB.csv': array([176.94      , 285.36      , 376.2       , 503.91999999,\n",
      "       714.02000001, 919.72000015]), 'Regrets_versus_T_CUSUM-UCB.csv': array([ 224.62      ,  401.34      ,  585.14      ,  901.71999999,\n",
      "       1760.40000001, 3064.46000015]), 'Regrets_versus_T_CUSUM-UCB(with diminishing).csv': array([ 170.42      ,  295.48      ,  435.76      ,  685.41999999,\n",
      "       1503.10000001, 2766.42000015])}\n",
      "Saving figure with format png, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/Fig4_SP__M5_K3_N50_T_scaling_envId6/main__Regret_versus_T.png'...\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/Fig4_SP__M5_K3_N50_T_scaling_envId6/main__Regret_versus_T.png' created of size '308988b', at 'Thu Feb  1 19:07:26 2024' ...\n",
      "Saving figure with format pdf, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/Fig4_SP__M5_K3_N50_T_scaling_envId6/main__Regret_versus_T.pdf'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/Fig4_SP__M5_K3_N50_T_scaling_envId6/main__Regret_versus_T.pdf' created of size '24668b', at 'Thu Feb  1 19:07:26 2024' ...\n",
      "Saving figure with format eps, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/Fig4_SP__M5_K3_N50_T_scaling_envId6/main__Regret_versus_T.eps'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/Fig4_SP__M5_K3_N50_T_scaling_envId6/main__Regret_versus_T.eps' created of size '43673b', at 'Thu Feb  1 19:07:26 2024' ...\n",
      "['Regrets_versus_K_Discounted-TS.csv', 'Regrets_versus_K_Discounted-klUCB.csv', 'Regrets_versus_K_M-UCB($w=200$, with diminishing).csv', 'Regrets_versus_K_M-UCB($w=200$).csv', 'Regrets_versus_K_GLR-UCB.csv', 'Regrets_versus_K_CUSUM-UCB.csv', 'Regrets_versus_K_CUSUM-UCB(with diminishing).csv']\n",
      "{'Regrets_versus_K_Discounted-TS.csv': array([1.20e+00, 4.37e+02, 7.89e+02, 1.06e+03, 1.32e+03, 1.50e+03,\n",
      "       1.68e+03, 1.86e+03, 1.98e+03, 2.12e+03]), 'Regrets_versus_K_Discounted-klUCB.csv': array([1.20e+00, 5.75e+02, 1.05e+03, 1.42e+03, 1.76e+03, 1.99e+03,\n",
      "       2.21e+03, 2.41e+03, 2.56e+03, 2.73e+03]), 'Regrets_versus_K_M-UCB($w=200$, with diminishing).csv': array([1.20e+00, 5.71e+02, 7.67e+02, 1.02e+03, 1.09e+03, 1.15e+03,\n",
      "       1.19e+03, 1.19e+03, 1.24e+03, 1.29e+03]), 'Regrets_versus_K_M-UCB($w=200$).csv': array([1.20e+00, 6.34e+02, 9.89e+02, 1.26e+03, 1.52e+03, 1.65e+03,\n",
      "       1.78e+03, 1.93e+03, 2.06e+03, 2.21e+03]), 'Regrets_versus_K_GLR-UCB.csv': array([1.20e+00, 3.44e+02, 6.25e+02, 8.70e+02, 1.12e+03, 1.47e+03,\n",
      "       1.94e+03, 2.22e+03, 2.61e+03, 2.86e+03]), 'Regrets_versus_K_CUSUM-UCB.csv': array([1.20e+00, 4.85e+02, 8.72e+02, 1.15e+03, 1.43e+03, 1.62e+03,\n",
      "       1.81e+03, 2.00e+03, 2.14e+03, 2.30e+03]), 'Regrets_versus_K_CUSUM-UCB(with diminishing).csv': array([1.20e+00, 4.21e+02, 7.06e+02, 8.98e+02, 1.09e+03, 1.23e+03,\n",
      "       1.37e+03, 1.50e+03, 1.60e+03, 1.73e+03])}\n",
      "Saving figure with format png, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/Fig5/main__Regret_versus_K.png'...\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/Fig5/main__Regret_versus_K.png' created of size '340302b', at 'Thu Feb  1 19:07:26 2024' ...\n",
      "Saving figure with format pdf, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/Fig5/main__Regret_versus_K.pdf'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/Fig5/main__Regret_versus_K.pdf' created of size '25072b', at 'Thu Feb  1 19:07:26 2024' ...\n",
      "Saving figure with format eps, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/Fig5/main__Regret_versus_K.eps'...\n",
      "       Saved! 'C:/Users/USER/Code/SimulatuionByMe/plot/Fig5/main__Regret_versus_K.eps' created of size '44068b', at 'Thu Feb  1 19:07:26 2024' ...\n",
      "['Regrets_Discounted-TS.csv', 'Regrets_Discounted-klUCB.csv', 'Regrets_M-UCB($w=200$, with diminishing).csv', 'Regrets_M-UCB($w=200$).csv', 'Regrets_GLR-UCB.csv', 'Regrets_CUSUM-UCB.csv', 'Regrets_CUSUM-UCB(with diminishing).csv']\n",
      "['std_Regrets_Discounted-TS.csv', 'std_Regrets_Discounted-klUCB.csv', 'std_Regrets_M-UCB($w=200$, with diminishing).csv', 'std_Regrets_M-UCB($w=200$).csv', 'std_Regrets_GLR-UCB.csv', 'std_Regrets_CUSUM-UCB.csv', 'std_Regrets_CUSUM-UCB(with diminishing).csv']\n",
      "{'Regrets_Discounted-TS.csv': array([3.70000e-01, 6.70000e-01, 1.11000e+00, ..., 2.36469e+03,\n",
      "       2.36480e+03, 2.36494e+03]), 'Regrets_Discounted-klUCB.csv': array([3.90000e-01, 7.80000e-01, 1.08000e+00, ..., 2.69405e+03,\n",
      "       2.69417e+03, 2.69440e+03]), 'Regrets_M-UCB($w=200$, with diminishing).csv': array([ 5.0000e-02, -2.0000e-02,  2.9000e-01, ...,  7.4363e+02,\n",
      "        7.4359e+02,  7.4358e+02]), 'Regrets_M-UCB($w=200$).csv': array([5.00000e-02, 3.80000e-01, 7.40000e-01, ..., 1.49374e+03,\n",
      "       1.49369e+03, 1.49368e+03]), 'Regrets_GLR-UCB.csv': array([5.0000e-02, 3.8000e-01, 7.4000e-01, ..., 7.4432e+02, 7.4428e+02,\n",
      "       7.4430e+02]), 'Regrets_CUSUM-UCB.csv': array([5.00000e-02, 3.80000e-01, 7.40000e-01, ..., 1.95186e+03,\n",
      "       1.95195e+03, 1.95204e+03]), 'Regrets_CUSUM-UCB(with diminishing).csv': array([ 5.00000e-02, -2.00000e-02,  2.90000e-01, ...,  1.88037e+03,\n",
      "        1.88040e+03,  1.88050e+03])}\n",
      "Saving figure with format png, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/Fig6_SP__K6_T18000_N100_M9_envId9/main__Regret_yh.png'...\n",
      "Error: could not save current figure to C:/Users/USER/Code/SimulatuionByMe/plot/Fig6_SP__K6_T18000_N100_M9_envId9/main__Regret_yh.png because of error Maximum allowed size exceeded... Skipping!\n",
      "Saving figure with format pdf, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/Fig6_SP__K6_T18000_N100_M9_envId9/main__Regret_yh.pdf'...\n",
      "Error: could not save current figure to C:/Users/USER/Code/SimulatuionByMe/plot/Fig6_SP__K6_T18000_N100_M9_envId9/main__Regret_yh.pdf because of error Maximum allowed size exceeded... Skipping!\n",
      "Saving figure with format eps, to file 'C:/Users/USER/Code/SimulatuionByMe/plot/Fig6_SP__K6_T18000_N100_M9_envId9/main__Regret_yh.eps'...\n",
      "Error: could not save current figure to C:/Users/USER/Code/SimulatuionByMe/plot/Fig6_SP__K6_T18000_N100_M9_envId9/main__Regret_yh.eps because of error Maximum allowed size exceeded... Skipping!\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "c:\\Users\\USER\\Code\\SimulatuionByMe\\sim\\lib\\site-packages\\matplotlib\\lines.py:169: RuntimeWarning: divide by zero encountered in double_scalars\n",
      "  marker_delta = np.arange(start * scale, delta[-1], step * scale)\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "from Environment import Environment\n",
    "from MUCB import MUCB\n",
    "from CUSUM_UCB import CusumUCB\n",
    "from GLR_UCB import GLRUCB\n",
    "from klUCB import klUCB\n",
    "from Oracle_klUCB import OracleklUCB\n",
    "from DTS import DTS\n",
    "from DklUCB import DklUCB\n",
    "from AdSwitch import AdSwitch\n",
    "# from plot import Plot\n",
    "import os, os.path\n",
    "import matplotlib.pyplot as mpl\n",
    "from generate_instance import Regret_versus_K\n",
    "\n",
    "plot_dir = \"C:/Users/USER/Code/SimulatuionByMe/plot/Fig2_SP__K3_T20000_N100_M5_envId6\"\n",
    "mainfig = plot_dir + \"/main\"\n",
    "if mainfig is not None: mainfig = \"{}__Regret\".format(mainfig)\n",
    "mpl.rcParams['figure.figsize'] = (7.5,5)\n",
    "mpl.rcParams['figure.dpi'] = 400\n",
    "fig = Plot()\n",
    "fig.plot(savefig = mainfig, path = plot_dir)\n",
    "\n",
    "plot_dir = \"C:/Users/USER/Code/SimulatuionByMe/plot/Fig3_SP__K3_T20000_N100_M_scaling_envId6\"\n",
    "mainfig = plot_dir + \"/main\"\n",
    "if mainfig is not None: mainfig = \"{}__Regret_versus_M\".format(mainfig)\n",
    "mpl.rcParams['figure.figsize'] = (7.5,5)\n",
    "mpl.rcParams['figure.dpi'] = 400\n",
    "fig = Plot()\n",
    "fig.plot(savefig = mainfig, path = plot_dir, experiment= \"M\")\n",
    "\n",
    "plot_dir = \"C:/Users/USER/Code/SimulatuionByMe/plot/Fig4_SP__M5_K3_N50_T_scaling_envId6\"\n",
    "mainfig = plot_dir + \"/main\"\n",
    "if mainfig is not None: mainfig = \"{}__Regret_versus_T\".format(mainfig)\n",
    "mpl.rcParams['figure.figsize'] = (7.5,5)\n",
    "mpl.rcParams['figure.dpi'] = 400\n",
    "fig = Plot()\n",
    "fig.plot(savefig = mainfig, path = plot_dir, experiment= \"T\")\n",
    "\n",
    "plot_dir = \"C:/Users/USER/Code/SimulatuionByMe/plot/Fig5\"\n",
    "mainfig = plot_dir + \"/main\"\n",
    "if mainfig is not None: mainfig = \"{}__Regret_versus_K\".format(mainfig)\n",
    "mpl.rcParams['figure.figsize'] = (7.5,5)\n",
    "mpl.rcParams['figure.dpi'] = 400\n",
    "fig = Plot()\n",
    "fig.plot(savefig = mainfig, path = plot_dir, experiment= \"K\")\n",
    "\n",
    "plot_dir = \"C:/Users/USER/Code/SimulatuionByMe/plot/Fig6_SP__K6_T18000_N100_M9_envId9\"\n",
    "mainfig = plot_dir + \"/main\"\n",
    "if mainfig is not None: mainfig = \"{}__Regret_yh\".format(mainfig)\n",
    "mpl.rcParams['figure.figsize'] = (7.5,5)\n",
    "mpl.rcParams['figure.dpi'] = 400\n",
    "fig = Plot()\n",
    "fig.plot(savefig = mainfig, path = plot_dir)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "sim",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.10.11"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
