{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 3,
   "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, Regret_std = 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, Regret_std=Regret_std)\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, Regret_std=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.fill_between(nb_arms, Regret_data[filename]-Regret_std[i], Regret_data[filename]+Regret_std[i], color = plotParams[filename][\"color\"], alpha = 0.2)\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": 61,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\oliver\\AppData\\Local\\Temp\\ipykernel_27024\\2490324316.py:18: TqdmDeprecationWarning: This function will be removed in tqdm==5.0.0\n",
      "Please use `tqdm.notebook.tqdm` instead of `tqdm.tqdm_notebook`\n",
      "  for alg in tqdm(range(nb_of_algorithm)):\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "0c9ea0a9137c48aa838f072e9e2c30ea",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/7 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "loading algorithm roll_dataDiscounted-TS (0.75)\n",
      "loading K1......\n",
      "loading K2......\n",
      "loading K3......\n",
      "loading K4......\n",
      "loading K5......\n",
      "loading K6......\n",
      "loading K7......\n",
      "loading K8......\n",
      "loading K9......\n",
      "loading K10......\n",
      "loading algorithm roll_dataDiscounted-klUCB (0.75)\n",
      "loading K1......\n",
      "loading K2......\n",
      "loading K3......\n",
      "loading K4......\n",
      "loading K5......\n",
      "loading K6......\n",
      "loading K7......\n",
      "loading K8......\n",
      "loading K9......\n",
      "loading K10......\n",
      "loading algorithm roll_dataM-UCB($w=200$, with diminishing)\n",
      "loading K1......\n",
      "loading K2......\n",
      "loading K3......\n",
      "loading K4......\n",
      "loading K5......\n",
      "loading K6......\n",
      "loading K7......\n",
      "loading K8......\n",
      "loading K9......\n",
      "loading K10......\n",
      "loading algorithm roll_dataM-UCB($w=200$)\n",
      "loading K1......\n",
      "loading K2......\n",
      "loading K3......\n",
      "loading K4......\n",
      "loading K5......\n",
      "loading K6......\n",
      "loading K7......\n",
      "loading K8......\n",
      "loading K9......\n",
      "loading K10......\n",
      "loading algorithm roll_dataGLR-UCB(with unknown change point)\n",
      "loading K1......\n",
      "loading K2......\n",
      "loading K3......\n",
      "loading K4......\n",
      "loading K5......\n",
      "loading K6......\n",
      "loading K7......\n",
      "loading K8......\n",
      "loading K9......\n",
      "loading K10......\n",
      "loading algorithm roll_dataCUSUM-UCB\n",
      "loading K1......\n",
      "loading K2......\n",
      "loading K3......\n",
      "loading K4......\n",
      "loading K5......\n",
      "loading K6......\n",
      "loading K7......\n",
      "loading K8......\n",
      "loading K9......\n",
      "loading K10......\n",
      "loading algorithm roll_dataCUSUM-UCB(with diminishing)\n",
      "loading K1......\n",
      "loading K2......\n",
      "loading K3......\n",
      "loading K4......\n",
      "loading K5......\n",
      "loading K6......\n",
      "loading K7......\n",
      "loading K8......\n",
      "loading K9......\n",
      "loading K10......\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "import os\n",
    "from tqdm import tqdm_notebook as tqdm\n",
    "\n",
    "path = \"C:/Users/oliver/Desktop/regret_K\"\n",
    "\n",
    "K = 10\n",
    "nb_of_instance = 50\n",
    "nb_of_algorithm = 7\n",
    "repetitions = 50\n",
    "horizon = 20000\n",
    "\n",
    "file_name = [\"roll_dataDiscounted-TS (0.75)\", \"roll_dataDiscounted-klUCB (0.75)\", \"roll_dataM-UCB($w=200$, with diminishing)\", \"roll_dataM-UCB($w=200$)\", \n",
    "             \"roll_dataGLR-UCB(with unknown change point)\", \"roll_dataCUSUM-UCB\", \"roll_dataCUSUM-UCB(with diminishing)\"]\n",
    "\n",
    "roll_data = np.zeros((nb_of_algorithm, K, nb_of_instance, repetitions, horizon), dtype=float)\n",
    "\n",
    "for alg in tqdm(range(nb_of_algorithm)): \n",
    "    print(\"loading algorithm {}\".format(file_name[alg]))\n",
    "    path = \"C:/Users/USER/Code/SimulatuionByMe/plot/SP__M5_T20000_N50_K_scaling_envId5\"+\"/\"+file_name[alg]\n",
    "    for k in range(K):\n",
    "        print(\"loading K{}......\".format(k+1))\n",
    "        rand_ID = 0\n",
    "        path = \"C:/Users/USER/Code/SimulatuionByMe/plot/SP__M5_T20000_N50_K_scaling_envId5\"+\"/K\"+str(k+1)+\"/\"+file_name[alg]+str(rand_ID)+\".csv\" \n",
    "        for instance in range(nb_of_instance):\n",
    "            while(os.path.exists(path)!= True):\n",
    "                # print(rand_ID)\n",
    "                rand_ID = rand_ID + 1\n",
    "                path = \"C:/Users/USER/Code/SimulatuionByMe/plot/SP__M5_T20000_N50_K_scaling_envId5\"+\"/K\"+str(k+1)+\"/\"+file_name[alg]+str(rand_ID)+\".csv\"\n",
    "            roll_data[alg][k][instance] = np.loadtxt(path, dtype=float, delimiter=\",\")\n",
    "            # print( roll_data[k][alg][instance])\n",
    "\n",
    "\n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 62,
   "metadata": {},
   "outputs": [],
   "source": [
    "## X1 X2 ....\n",
    "mean_of_each_instance = np.zeros((nb_of_algorithm, K, nb_of_instance), dtype=float)\n",
    "\n",
    "## sigma^2_1 sigma^2_2 ....\n",
    "var_of_each_instance = np.zeros((nb_of_algorithm, K, nb_of_instance), dtype=float)\n",
    "\n",
    "## d1 d2 ....\n",
    "mean_difference = np.zeros((nb_of_algorithm, K, nb_of_instance), dtype=float)\n",
    "\n",
    "## sigma^2_c\n",
    "var_for_diff_K = np.zeros((nb_of_algorithm, K), dtype=float)\n",
    "\n",
    "## m_c\n",
    "mean_for_diff_K = np.zeros((nb_of_algorithm, K), dtype=float)\n",
    "\n",
    "for alg in range(nb_of_algorithm):\n",
    "    for k in range(K):\n",
    "        for instance in range(nb_of_instance):\n",
    "            mean_of_each_instance[alg][k][instance] = np.mean(roll_data[alg][k][instance], axis=0)[horizon-1]\n",
    "            var_of_each_instance[alg][k][instance] = np.var(roll_data[alg][k][instance], axis=0)[horizon-1]\n",
    "        mean_for_diff_K = np.mean(mean_of_each_instance, axis=2)\n",
    "        # var_for_diff_K = np.mean(var_of_each_instance, axis=2)\n",
    "# std_for_diff_K = np.sqrt(var_for_diff_K)\n",
    "\n",
    "for alg in range(nb_of_algorithm):\n",
    "    for k in range(K):\n",
    "        mean_difference[alg][k] = mean_of_each_instance[alg][k] - mean_for_diff_K[alg][k]\n",
    "\n",
    "var_for_diff_K = np.mean(np.square(mean_difference)+var_of_each_instance, axis=2)\n",
    "std_for_diff_K = np.sqrt(var_for_diff_K)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 63,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[ 67.66897369  56.89802809  52.04588745  66.8587197   67.63149858\n",
      "   62.09465033  58.27924502  53.78902862  68.43613373  77.02569961]\n",
      " [ 49.08810039  61.51729513  61.31134968  68.0006147   72.37814311\n",
      "   54.55432522  53.8595544   64.53533916  63.92609483  53.51373655]\n",
      " [ 49.08810039 576.68474056 164.91588765 123.79628427  77.68501529\n",
      "   50.91442232 242.15406996 193.39470934  79.24593617 408.2620242 ]\n",
      " [ 49.90376339 271.22615213 152.09516626 109.62806393  91.31924003\n",
      "   67.73063118  45.37515179 166.05890521  64.70211434 174.42935991]\n",
      " [ 63.84369663  59.46316171 118.83316709 105.74346315 184.09384129\n",
      "   95.82066583 189.0087998  148.90540487 665.28102333 461.61611064]\n",
      " [ 57.23250824  66.52543574  70.44654427  82.22189489 116.76140458\n",
      "  106.78188049  86.93938348 105.99419795 102.87220227 124.66396592]\n",
      " [ 57.8379149   60.23076955 102.3560941  113.5467199   84.80766239\n",
      "   94.73424091 115.65895383 102.48219553 157.51055965 178.80337357]]\n"
     ]
    }
   ],
   "source": [
    "print(std_for_diff_K)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "ename": "NameError",
     "evalue": "name 'std_for_diff_K' is not defined",
     "output_type": "error",
     "traceback": [
      "\u001b[1;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[1;31mNameError\u001b[0m                                 Traceback (most recent call last)",
      "Input \u001b[1;32mIn [4]\u001b[0m, in \u001b[0;36m<cell line: 22>\u001b[1;34m()\u001b[0m\n\u001b[0;32m     20\u001b[0m mpl\u001b[38;5;241m.\u001b[39mrcParams[\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mfigure.dpi\u001b[39m\u001b[38;5;124m'\u001b[39m] \u001b[38;5;241m=\u001b[39m \u001b[38;5;241m400\u001b[39m\n\u001b[0;32m     21\u001b[0m fig \u001b[38;5;241m=\u001b[39m Plot()\n\u001b[1;32m---> 22\u001b[0m fig\u001b[38;5;241m.\u001b[39mplot(savefig \u001b[38;5;241m=\u001b[39m mainfig, path \u001b[38;5;241m=\u001b[39m plot_dir, experiment\u001b[38;5;241m=\u001b[39m \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mK\u001b[39m\u001b[38;5;124m\"\u001b[39m, Regret_std \u001b[38;5;241m=\u001b[39m \u001b[43mstd_for_diff_K\u001b[49m)\n",
      "\u001b[1;31mNameError\u001b[0m: name 'std_for_diff_K' is not defined"
     ]
    }
   ],
   "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_N50_M5_envId6\"\n",
    "mainfig = plot_dir + \"/main\"\n",
    "if mainfig is not None: mainfig = \"{}\".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\", Regret_std = std_for_diff_K)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 64,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "['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.63e+00,  4.53e+02,  8.25e+02,  1.11e+03,  1.35e+03,  1.52e+03,\n",
      "        1.69e+03,  1.84e+03,  1.99e+03,  2.13e+03]), 'Regrets_versus_K_Discounted-klUCB.csv': array([-1.63e+00,  5.97e+02,  1.10e+03,  1.48e+03,  1.81e+03,  2.04e+03,\n",
      "        2.25e+03,  2.43e+03,  2.61e+03,  2.76e+03]), 'Regrets_versus_K_M-UCB ($w=200$, with diminishing).csv': array([  -1.63,  746.  ,  787.  ,  990.  , 1070.  , 1130.  , 1170.  ,\n",
      "       1210.  , 1180.  , 1240.  ]), 'Regrets_versus_K_M-UCB ($w=200$).csv': array([-1.63e+00,  6.67e+02,  1.04e+03,  1.26e+03,  1.44e+03,  1.66e+03,\n",
      "        1.85e+03,  2.03e+03,  2.18e+03,  2.29e+03]), 'Regrets_versus_K_GLR-UCB.csv': array([-1.63e+00,  3.28e+02,  5.71e+02,  8.20e+02,  1.05e+03,  1.41e+03,\n",
      "        1.79e+03,  2.12e+03,  2.55e+03,  2.81e+03]), 'Regrets_versus_K_CUSUM-UCB.csv': array([-1.63e+00,  5.04e+02,  8.96e+02,  1.19e+03,  1.44e+03,  1.64e+03,\n",
      "        1.81e+03,  1.99e+03,  2.15e+03,  2.30e+03]), 'Regrets_versus_K_CUSUM-UCB (with diminishing).csv': array([-1.63e+00,  4.35e+02,  7.23e+02,  9.32e+02,  1.10e+03,  1.22e+03,\n",
      "        1.36e+03,  1.48e+03,  1.60e+03,  1.71e+03])}\n",
      "Saving figure with format png, to file 'C:/Users/oliver/Desktop/regret_K/main__Regret_versus_K.png'...\n",
      "       Saved! 'C:/Users/oliver/Desktop/regret_K/main__Regret_versus_K.png' created of size '617395b', at 'Fri Mar 29 19:47:22 2024' ...\n",
      "Saving figure with format pdf, to file 'C:/Users/oliver/Desktop/regret_K/main__Regret_versus_K.pdf'...\n",
      "       Saved! 'C:/Users/oliver/Desktop/regret_K/main__Regret_versus_K.pdf' created of size '26271b', at 'Fri Mar 29 19:47:22 2024' ...\n",
      "Saving figure with format eps, to file 'C:/Users/oliver/Desktop/regret_K/main__Regret_versus_K.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/oliver/Desktop/regret_K/main__Regret_versus_K.eps' created of size '49680b', at 'Fri Mar 29 19:47:22 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/oliver/Desktop/regret_K\"\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\", Regret_std = std_for_diff_K)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "4.743565176348143"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "C = np.sqrt(np.log((2*3*(5000**2)*(np.log(7 - 1 + 1)+2))/0.1))\n",
    "C"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 55,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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0YvW/mwHH3zwSHcPAAAaZYuR7gDQt4svvni99blz52b//fcfod5svD333DMPPPDASHcDAADGBXf6YRRbsWJFvvWtbyVJpk+fniS57LLLsnLlypHs1kapta4tv+AFL8hRRx01gr0BAIBmE/phFPvOd76TJUuWJEm+8IUvJEmeeuqpXHnllSPZrY3yF3/xF/nWt76VBx98MI8++uiY/lkAAGC0E/phFJs7d26SZI899sgpp5ySl7/85et9PxZ97GMfy3HHHZeddtpppLsCAACNJ/TDKPXII4/k+uuvT5KcdNJJ6y2vueaaLFy4sNd9zzrrrLWT4yXJokWLcs4552TPPffMzJkzU0rJRRdd1GPdxYsX56yzzsprXvOaTJ8+Pdttt12OOOKI50wg+Nhjj+XMM8/Mq1/96kybNi2zZs3KMccckzvuuGOT/jkAAABDJ/TDKPXVr341a9asyYQJE/LOd74zSfKud70rpZQ8++yz+frXvz6g48yfPz+vfe1r84lPfCJ33nlnFi1a1Gvdhx56KHvvvXfOPvvs3H333Vm2bFkWLlyYq6++OgceeGC++c1vJknuuuuuvO51r8u5556be+65J8uXL8+TTz6ZK664Ivvtt19++MMfbvwfAAAAsNHM3s9G6+qqeWr5qo3YvytLlj+bJHl2wspMmDC6r0VtM3VSJkwow97OJZdckiQ5+OCDs8MOOyRJdtlll+y///6ZN29e5s6dmw996EP9Huf444/Pww8/nA9+8IN5y1vekm222Sbz58/Pzjvv/Jy6b3/727NgwYKcccYZOfzwwzN16tTcfPPN+eQnP5nFixfn1FNPzV577ZWjjjoqK1asyLnnnpuDDjooW265Za655pqce+65WblyZU4++eTMnz8/kyZN2rR/KAAAwKAI/Wy0p5avypz/ef1Id2Ozuf3MN2fW9K2GtY0777wzd911V5J1Q/q7nXTSSZk3b15uv/323HPPPXnVq17V57HuvvvuXH311TnssMPWfjdnzpxe273xxhuz7777rv1ur732yq677pqjjjoqS5Ysyb777ptaa2699da89KUvXVtvn332yezZs/OBD3wgDz74YK666qoce+yxg/7ZAQCATWd031KFcap7or4pU6bkuOOOW2/bO97xjrV30Acyod/JJ5+8XuDvy0c+8pH1An+3I488cu3IgIULF+acc85ZL/B3O+WUUzJ58uQkyY9+9KMBtQkAAAwfoR9GmdWrV+drX/takuToo4/OjBkz1tu+7bbb5ogjjkjSeu6/q6urz+O9613vGnDbJ554Yq/b9thjjyRJKSUnnHBCj3WmTJmSXXfdNUny61//esDtAgAAw0Poh1Hm2muvze9///skzx3a3637+wULFvQ7aV53WB+I3XbbrddtM2fOTJLMnj0722yzTb/1lixZMuB2AQCA4eGZfjbaNlMn5fYz3zzk/bu6urJk6dIkydbTp4+JifyGU/eQ/VmzZuXwww/vsc5RRx2VmTNn5umnn87cuXNz6KGH9nq8vgL6hqZOndrrtu6/l77qdNZbs2bNgNsFAACGh9DPRpswoWzUxHZdXV3ZsmtlkmTG9K1GfegfTosWLcoVV1yRJHniiScGNPv95ZdfnvPPPz/Tpk3rcfvEiRM3aR8BAICxY/ymKxiFLrvssjzzzDOD2mfp0qW5/PLLh6lHAADAWOZOP4wi3UP7t99++3z+85/vt/7pp5+eBQsWZO7cuXn3u9893N0DAADGGKEfRonf/OY3mTdvXpLkuOOO63Mm/W4/+clPct555+UHP/hBHn744eywww7D3U0AAGAMMbwfRom5c+em1pokOf744we0T3e9rq6uXHrppcPWNwAAYGxypx9GiUsuuSRJst122+WAAw4Y0D77779/tt9++zzyyCO55JJL8vGPf3w4u7hJ3Hnnnbnzzjt73Pboo4/moosuWu+7448/PtOnTx/+jgEAQAMJ/TAKzJs3L/fff3+S5Nhjjx3wGwwmTJiQY489Nueff35+/vOf5/bbb8+cOXOGs6sb7bvf/W7OPvvsHrf98pe/zCmnnLLedwcffLDQDwAAQ2R4P4wC3RP4Ja3n+Qejs37ncQAAAEr3M8Q0VyllxyQPJclDDz2UHXfcccD7zp8/P6tXr84WW2yRXXfddVj619XVlcWLFydJZsyYMeC73NCXzXHudluxYkWuu+66JMlhhx2WKVOmDGt7MBycxzSB85ixzjnMggULstNOO3Wv7lRrXbCxx5SuAAAAoKGEfgAAAGgooR8AAAAaSugHAACAhhL6AQAAoKGEfgAAAGgooR8AAAAaSugHAACAhhL6AQAAoKGEfgAAAGgooR8AAAAaSugHAACAhhL6AQAAoKGEfgAAAGgooR8AAAAaSugHAACAhhL6AQAAoKGEfgAAAGgooR8AAAAaSugHAACAhhL6YZS78cYbU0pZ+/nxj3880l3aKPfcc08++9nP5qijjsqLX/ziTJ48OVOnTs0uu+ySE088Mf/n//yfke4iAAA0xhYj3QGgbxdffPF663Pnzs3+++8/Qr3ZOO9973szd+7cHrc98MADeeCBB/KNb3wjf/zHf5x/+7d/y8yZMzdvBwEAoGHc6YdRbMWKFfnWt76VJJk+fXqS5LLLLsvKlStHsltD9vDDDydJtt1227zvfe/L1772tfz4xz/OrbfemgsuuCAvf/nLkyTXXnttjj766HR1dY1kdwEAYMwT+mEU+853vpMlS5YkSb7whS8kSZ566qlceeWVI9mtIdtpp51ywQUX5He/+10uuOCC/Omf/mn222+/7L333nnf+96X//zP/8wb3/jGJMnNN9+cSy+9dIR7DAAAY5vQD6NY91D4PfbYI6eccsraO+G9DZEf7S688MK8733vy1ZbbdXj9qlTp+ZLX/rS2vXuUQ4AAMDQCP0wSj3yyCO5/vrrkyQnnXTSestrrrkmCxcu7HXfs846a+3Ef0myaNGinHPOOdlzzz0zc+bMlFJy0UUX9Vh38eLFOeuss/Ka17wm06dPz3bbbZcjjjjiORMIPvbYYznzzDPz6le/OtOmTcusWbNyzDHH5I477tion3v33XfP7NmzkyT333//Rh0LAADGO6EfRqmvfvWrWbNmTSZMmJB3vvOdSZJ3vetdKaXk2Wefzde//vUBHWf+/Pl57Wtfm0984hO58847s2jRol7rPvTQQ9l7771z9tln5+67786yZcuycOHCXH311TnwwAPzzW9+M0ly11135XWve13OPffc3HPPPVm+fHmefPLJXHHFFdlvv/3ywx/+cKN+9lWrViVJJk6cuFHHAQCA8c7s/Wy8rq5kxZMbtX9Z3npuPRNXJRNG+bWoKdtulj5ecsklSZKDDz44O+ywQ5Jkl112yf7775958+Zl7ty5+dCHPtTvcY4//vg8/PDD+eAHP5i3vOUt2WabbTJ//vzsvPPOz6n79re/PQsWLMgZZ5yRww8/PFOnTs3NN9+cT37yk1m8eHFOPfXU7LXXXjnqqKOyYsWKnHvuuTnooIOy5ZZb5pprrsm5556blStX5uSTT878+fMzadKkQf/cd9xxRxYvXpwkeeUrXzno/QEAgHWEfjbeiieTz750yLtPSPK8Tdeb4Xf6/cm02cPaxJ133pm77roryboh/d1OOumkzJs3L7fffnvuueeevOpVr+rzWHfffXeuvvrqHHbYYWu/mzNnTq/t3njjjdl3333XfrfXXntl1113zVFHHZUlS5Zk3333Ta01t956a1760nV/7/vss09mz56dD3zgA3nwwQdz1VVX5dhjjx30z/7pT396bfkd73jHoPcHAADWGeW3VGF86p6ob8qUKTnuuOPW2/aOd7xj7R30gUzod/LJJ68X+PvykY98ZL3A3+3II49cOzJg4cKFOeecc9YL/N1OOeWUTJ48OUnyox/9aEBtdvr2t7+9dvK+OXPm5G1ve9ugjwEAAKwj9MMos3r16nzta19Lkhx99NGZMWPGetu33XbbHHHEEUlaz/339y77d73rXQNu+8QTT+x12x577JEkKaXkhBNO6LHOlClTsuuuuyZJfv3rXw+43ST5xS9+kVNOOWXtcS655JK1kwsCAABDI/TDKHPttdfm97//fZLnDu3v1v39ggUL+p00rzusD8Ruu+3W67aZM2cmSWbPnp1tttmm33pLliwZcLu/+93vcsQRR2TJkiUppeRf//VfPc8PAACbgGf62XhTtm095z5EXV1dawPi1ltvnQljYSK/YdQ9ZH/WrFk5/PDDe6xz1FFHZebMmXn66aczd+7cHHroob0er6+AvqGpU6f2uq3776WvOp311qxZM6A2n3zyyRx22GF54IEHkiRf/OIX+xxxAAAADJzQz8abMGHjJrbr6kpd057lfdqM0T97/zBatGhRrrjiiiTJE088MaDZ7y+//PKcf/75mTZtWo/bR/Nr75YsWZLDDz88P//5z5Mk55xzTj7wgQ+McK8AAKA5xm+6glHosssuyzPPPDOofZYuXZrLL798mHo0fFasWJGjjz46t912W5Lk9NNPz5lnnjnCvQIAgGZxpx9Gke6h/dtvv30+//nP91v/9NNPz4IFCzJ37ty8+93vHu7ubTLPPvtsjjvuuNx4441Jkve///35zGc+M8K9AgCA5hH6YZT4zW9+k3nz5iVJjjvuuAE91/6Tn/wk5513Xn7wgx/k4Ycfzg477DDc3dxoa9asyTvf+c5cffXVSZJ3v/vdOf/880e4VwAA0EyG98MoMXfu3NRakyTHH3/8gPbprtfV1ZVLL7102Pq2qdRa8+d//uf51re+laR1cePCCy/0aj4AABgm7vTDKHHJJZckSbbbbrsccMABA9pn//33z/bbb59HHnkkl1xyST7+8Y8PZxc32sc+9rFceOGFSZLdd989f/3Xf51f/OIXfe6z++67b46uAQBAIwn9MArMmzcv99/feu3hscceO+DXFk6YMCHHHntszj///Pz85z/P7bffnjlz5gxnVzfKt7/97bXlu+++e0B97R79AAAADJ7h/TAKdE/gl7SGvA9GZ/3O4wAAAAj9MApccMEFqbWm1po/+qM/GtS+b3rTm9bue9555yVJzjrrrLXf9WegdS+66KLUWvPAAw/0We+GG25IrTU33HDDc7Y98MADa9sa6AcAABg6oR8AAAAaSugHAACAhhL6AQAAoKGEfgAAAGgooR8AAAAaSugHAACAhhL6AQAAoKGEfgAAAGgooR8AAAAaSugHAACAhhL6AQAAoKGEfgAAAGgooR8AAAAaSugHAACAhhL6AQAAoKGEfgAAAGgooR8AAAAaSugHAACAhhL6AQAAoKGEfgAAAGgooR9GuRtvvDGllLWfH//4xyPdpSFbuXJlvvOd7+SMM87Im9/85uy2227Zdttts+WWW2bWrFnZf//984lPfCILFiwY6a4CAEAjbDHSHQD6dvHFF6+3Pnfu3Oy///4j1JuN89BDD+Vtb3tbj9uefPLJ3HLLLbnlllvy+c9/Pv/4j/+Y9773vZu5hwAA0CxCP4xiK1asyLe+9a0kyfTp07N06dJcdtllOe+887LVVluNcO+GZrvttsshhxySvffeOzvvvHO23377bLnllnn44Ydz1VVX5atf/WqWLVuWU045Jc9//vNzxBFHjHSXAQBgzBL6YRT7zne+kyVLliRJvvCFL+TP/uzP8tRTT+XKK6/M8ccfP8K9G7yXvOQlefTRR1NK6XH7sccem/e973154xvfmGeffTZnnnmm0A8AABvBM/0wis2dOzdJsscee+SUU07Jy1/+8vW+H2smTJjQa+Dvts8+++RNb3pTkuSOO+7I0qVLN0fXAACgkYR+GKUeeeSRXH/99UmSk046ab3lNddck4ULF/a671lnnbV24r8kWbRoUc4555zsueeemTlzZkopueiii3qsu3jx4px11ll5zWtek+nTp2e77bbLEUcc8ZwJBB977LGceeaZefWrX51p06Zl1qxZOeaYY3LHHXds9M++9dZbry2vXLlyo48HAADjldAPo9RXv/rVrFmzJhMmTMg73/nOJMm73vWulFLy7LPP5utf//qAjjN//vy89rWvzSc+8YnceeedWbRoUa91H3rooey99945++yzc/fdd2fZsmVZuHBhrr766hx44IH55je/mSS566678rrXvS7nnntu7rnnnixfvjxPPvlkrrjiiuy333754Q9/OOSfe+HChfn+97+fJJk9e3ZmzZo15GMBAMB455l+NlpX7crTK58e+v5dXVmysvXc+upnVmfChNF9LWrmVjMzoQx/Hy+55JIkycEHH5wddtghSbLLLrtk//33z7x58zJ37tx86EMf6vc4xx9/fB5++OF88IMfzFve8pZss802mT9/fnbeeefn1H3729+eBQsW5Iwzzsjhhx+eqVOn5uabb84nP/nJLF68OKeeemr22muvHHXUUVmxYkXOPffcHHTQQdlyyy1zzTXX5Nxzz83KlStz8sknZ/78+Zk0adKAftaVK1fmd7/7Xa6//vr83d/9XZ566qkkyUc+8pEB/mkBAAA9EfrZaE+vfDoHfeOgke7GZnPjCTdm28nbDmsbd955Z+66664k64b0dzvppJMyb9683H777bnnnnvyqle9qs9j3X333bn66qtz2GGHrf1uzpw5vbZ74403Zt9991373V577ZVdd901Rx11VJYsWZJ99903tdbceuuteelLX7q23j777JPZs2fnAx/4QB588MFcddVVOfbYY3vt1w033JBDDjmk1+3vec97cvrpp/f5swEAAH0b3bdUYZzqnqhvypQpOe6449bb9o53vGPtHfSBTOh38sknrxf4+/KRj3xkvcDf7cgjj1w7MmDhwoU555xz1gv83U455ZRMnjw5SfKjH/1oQG1u6MUvfnGuu+66XHzxxQMeKQAAAPRM6IdRZvXq1fna176WJDn66KMzY8aM9bZvu+22a19j99WvfjVdXV19Hu9d73rXgNs+8cQTe922xx57JElKKTnhhBN6rDNlypTsuuuuSZJf//rXfba1995752c/+1l+9rOf5ac//Wkuv/zynHzyyXnooYfy3ve+N1/5ylcG3G8AAKBnQj+MMtdee21+//vfJ3nu0P5u3d8vWLCg30nzusP6QOy22269bps5c2aS1uR622yzTb/1lixZ0mdb06ZNy+67757dd989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",
      "text/plain": [
       "<Figure size 1134x876 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "a = np.ones(90000)*0.6\n",
    "b = np.ones(90000)*0.4\n",
    "c = np.ones(90000)*0.2\n",
    "\n",
    "\n",
    "plt.figure(dpi = 200, figsize = (5.67, 4.38))\n",
    "line1 = plt.plot(a, label = \"Arm1\" )\n",
    "line2 = plt.plot(b, label = \"Arm2\")\n",
    "line3 = plt.plot(c, label = \"Arm3\")\n",
    "plt.grid()\n",
    "plt.ylim(0,1)\n",
    "plt.legend([\"Arm1\", \"Arm2\", \"Arm3\"], loc = 'upper left')\n",
    "plt.ticklabel_format(style='scientific', scilimits=(0,0), axis='x')\n",
    "plt.xlabel(\"Time\")\n",
    "plt.ylabel(\"$\\mu$\")\n",
    "\n",
    "plt.show()\n"
   ]
  }
 ],
 "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
}
