{
  "cells": [
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "4atkekcAvu-l"
      },
      "outputs": [],
      "source": [
        "import sys\n",
        "sys.path.append('/content/drive/MyDrive')\n",
        "from safe_Discrete_linearbandit_Starconvex import SafeBanditUCB_StarConvex\n",
        "from environment import Env\n",
        "from feature_map import Feature\n",
        "from utils import plot_results\n",
        "import numpy as np\n",
        "from utils import plot_results_variance\n",
        "import matplotlib.pyplot as plt\n",
        "from collections import Counter"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "BwtX-RdwwAwE"
      },
      "outputs": [],
      "source": [
        "NUM_EPISODES = 900000"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "EcaDNqPvwB3F"
      },
      "outputs": [],
      "source": [
        "FEATUREDIM = 2; NUMSTATES = 1; THETA = np.array([1,1]); GAMMA = np.array([1.000000,0.000000]); VARIANCE = 0.0001"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "-eiOejBTwC4k"
      },
      "outputs": [],
      "source": [
        "ACTIONSET = np.array([[1,0], [0,1]]); MAXREWARD = 1; EPSILON = 0.1; OMEGA = 0.1; L = 1;  _LAMBDA  = 1; TIMESTEP = 1; DELTA = 0.01\n",
        "BETA1 = np.sqrt(VARIANCE)*np.sqrt(FEATUREDIM*np.log((1+NUM_EPISODES/_LAMBDA)/DELTA))+np.sqrt(FEATUREDIM)\n",
        "BETA2 = BETA1;\n",
        "TAU = 0.9"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "cEs8qe_QwEI7"
      },
      "outputs": [],
      "source": [
        "# Define your environment and initialize LinearBanditUCB agent\n",
        "feature = Feature(FEATUREDIM)\n",
        "env = Env(feature, NUMSTATES, THETA, GAMMA, VARIANCE, VARIANCE)\n",
        "agent = SafeBanditUCB_StarConvex(feature, ACTIONSET, MAXREWARD, EPSILON, OMEGA, L,TAU, BETA1, BETA2, _LAMBDA, TIMESTEP)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "ZLpgafyGwIDO"
      },
      "outputs": [],
      "source": [
        "cost_record = []; reward_record = []; action_record = []; bonus_rec = [];\n",
        "noisy_reward_record = []; noisy_cost_record = [];\n",
        "estimated_reward_record = []\n",
        "param_uncertainty_rec =[];\n",
        "\n",
        "\n",
        "num_actions = 5\n",
        "total_action_counts = np.zeros(num_actions)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "background_save": true
        },
        "id": "LGHvdjWP6x3k"
      },
      "outputs": [],
      "source": [
        "# Initialize variables\n",
        "T = 10  # Number of runs\n",
        "reward_records = [[] for _ in range(T)]\n",
        "action_records = [[] for _ in range(T)]\n",
        "\n",
        "\n",
        "# Training loop for T runs\n",
        "for t in range(T):\n",
        "    agent = SafeBanditUCB_StarConvex(feature, ACTIONSET, MAXREWARD, EPSILON, OMEGA, L,TAU, BETA1, BETA2, _LAMBDA, TIMESTEP)\n",
        "    cost_record = []\n",
        "    reward_record = []\n",
        "    action_record = []\n",
        "    bonus_rec = []\n",
        "    param_uncertainty_rec = []\n",
        "\n",
        "    for episode in range(1, NUM_EPISODES):\n",
        "        state = env.get_state()  # Get features for current state\n",
        "        action, bonus, est_reward, param_uncertainty, act_ind = agent.select_action(state, episode)\n",
        "        reward, cost, reward_noiseless, cost_noiseless = env.take_action(action)\n",
        "        agent.update(state, action, reward, cost, state, False)\n",
        "        cost_record.append(cost_noiseless)\n",
        "        reward_record.append(reward_noiseless)\n",
        "        action_record.append(act_ind)\n",
        "        bonus_rec.append(bonus)\n",
        "        param_uncertainty_rec.append(param_uncertainty)\n",
        "\n",
        "    reward_records[t] = reward_record\n",
        "    action_counts = Counter(action_record)\n",
        "\n",
        "    # Accumulate the counts\n",
        "    for action, count in action_counts.items():\n",
        "        total_action_counts[action] += count\n",
        "\n",
        "# Calculate the average reward for each episode\n",
        "reward_record_avg = [sum(rewards) / T for rewards in zip(*reward_records)]\n",
        "average_action_counts = total_action_counts / T\n"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "background_save": true
        },
        "id": "7RkRL83H4CnM"
      },
      "outputs": [],
      "source": [
        "action_labels = ['a1', 'a2', 'a3', 'a4', 'a5']\n",
        "\n",
        "\n",
        "bars = plt.bar(range(num_actions), [average_action_counts[0], average_action_counts[3], average_action_counts[1], average_action_counts[4], average_action_counts[2]])\n",
        "plt.xlabel('Actions')\n",
        "plt.ylabel('Average Count')\n",
        "plt.title(f'Average Action Selection Frequency (LC-LUCB)')\n",
        "plt.xticks(range(num_actions), action_labels)\n",
        "\n",
        "# Add counts on top of each column\n",
        "for bar in bars:\n",
        "    yval = bar.get_height()\n",
        "    plt.text(bar.get_x() + bar.get_width() / 2, yval, round(yval, 2),\n",
        "             ha='center', va='bottom')  # Display the count value\n",
        "\n",
        "plt.show()\n",
        "\n",
        "\n",
        "# Add counts on top of each column\n",
        "for bar in bars:\n",
        "    yval = bar.get_height()\n",
        "    plt.text(bar.get_x() + bar.get_width() / 2, yval, round(yval, 2),\n",
        "             ha='center', va='bottom')\n",
        "plt.show()"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "background_save": true
        },
        "id": "Pxli_aAEwNGM",
        "outputId": "06433de5-8df6-4f63-f0c5-252dc055c9ba"
      },
      "outputs": [
        {
          "data": {
            "image/png": "iVBORw0KGgoAAAANSUhEUgAAAk0AAAHHCAYAAACiOWx7AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAABVq0lEQVR4nO3deVhU9eIG8HdmYAYQZkCQAWQRBUUUWTSR1OomSWqLZS5gXjNvtwV307RSy0rNtFzTtpvdm3uZlus1zXJFBURAxF1xAURkhn2Z+f7+6Dq/SNMBgTMD7+d5eJ7mnC/nvDPHnNfzPXNGJoQQICIiIqK7kksdgIiIiMgasDQRERERmYGliYiIiMgMLE1EREREZmBpIiIiIjIDSxMRERGRGViaiIiIiMzA0kRERERkBpYmIiIiIjOwNBERERGZgaWJiIiIyAwsTURERERmYGkiIiIiMgNLExEREZEZWJqIiIiIzMDSRERERGQGliYiIiIiM7A0EREREZmBpYmIiIjIDCxNRERERGZgaSIiIiIyA0sTERERkRlYmoiIiIjMwNJEREREZAaWJiIiIiIzsDQRERERmYGliYiIiMgMLE1EREREZmBpIiIiIjIDSxMRERGRGWykDtBYGI1GXL16FU5OTpDJZFLHISIiIjMIIVBYWAgvLy/I5Xc/l8TSVEeuXr0KHx8fqWMQERFRLWRlZcHb2/uuY1ia6oiTkxOA3190tVotcRoiIiIyh16vh4+Pj+l9/G5YmurIrSk5tVrN0kRERGRlzLm0hheCExEREZmBpYmIiIjIDCxNRERERGbgNU0NzGAwoLKyUuoYdBe2trZQKBRSxyAiIgvD0tRAhBDIzs5GQUGB1FHIDM7OzvDw8OA9t4iIyISlqYHcKkzu7u5wcHDgm7GFEkKgpKQEubm5AABPT0+JExERkaVgaWoABoPBVJhcXV2ljkP3YG9vDwDIzc2Fu7s7p+qIiAgALwRvELeuYXJwcJA4CZnr1rHi9WdERHQLS1MD4pSc9eCxIiKiP2NpIiIiIjIDSxMRERGRGVia6K5eeOEF9O/f/y/XJycnY+DAgdBqtbCzs0NgYCBeeuklnDp16i9/Z8+ePZDJZHe8/cKKFSvg7Ox8x9+TyWTYuHFjtWXff/89HnnkEWg0Gjg6OqJTp06YOXMm8vPzTduTyWSmH0dHR3Tu3BkbNmy411MnIiKqhqWJam3z5s3o1q0bysvLsXLlSmRkZODbb7+FRqPBtGnT6n3/b731FgYPHowHHngA27ZtQ1paGubPn4+UlBT85z//MY1Tq9W4du0arl27huTkZMTExGDQoEHIzMys94xERFQ39p6+jrJKg6QZeMsBqpWSkhKMGDECffv2xQ8//GBa7u/vj8jIyHq/iefhw4cxa9YsLFiwAGPHjjUtb9WqFR577LFq+5fJZPDw8AAAeHh44P3338e8efNw/PhxtGvXrl5zEhHR/amoMuLD7Sfx1b7zGBrpiw+eCZEsC0uTRIQQKJWgMdvbKurkk2E7duxAXl4eJk+efMf1fzXFVldWrlwJR0dHvPbaazXav8FgwL///W8AQERERH3FIyKiOpCVX4JRq5KQclkHAFDZKGA0Csjl0nzCmaVJIqWVBgRP39Hg+z0xMwYOyvs/7KdPnwYABAUF3fe2arv/1q1bw9bW9p5jdTodHB0dAQClpaWwtbXF559/jjZt2tR3TCIiqqXtadcw6bvjKCyrgsbeFvMGhuKxYK2kmViaqFaEEGaN69ChAy5evAgA6NmzJ7Zt29ag+wcAJycnJCUlAfh9WvHnn3/GK6+8AldXVzz55JN1koeIiOpGWaUBs7dm4JuDv793hPs6Y3FsOLxdpL9BNEuTROxtFTgxM0aS/daFtm3bAgBOnjyJqKiovxy3detW0121b309yd2o1WoUFxfDaDRCLv//zyncukZJo9GY9r9v3z5UVlbe82yTXC5HQECA6XGnTp3w3//+Fx9++CFLExGRBbmQV4z4VUlIv6oHALz8cGu83rsdbBWW8bk1y0jRBMlkMjgobRr8p67udN27d2+4ublh7ty5d1x/q+T4+fkhICAAAQEBaNmy5T23265dO1RVVeHYsWPVlt86U3SrrMXFxaGoqAiffvrpXff/VxQKBUpLS++Zh4iIGsZPKVfxxOJ9SL+qh4uDLb5+4QFM7dPeYgoTwDNNZAadTndbiXF1dcWXX36JgQMH4qmnnsKYMWMQEBCAvLw8rFu3DpcuXcKaNWvuut3U1FQ4OTmZHstkMoSGhqJ379548cUXMX/+fLRu3RqZmZkYN24cBg8ebCpekZGRmDx5MiZOnIgrV67gmWeegZeXF86cOYPly5ejR48epk/VCSGQnZ0N4Pdrmnbu3IkdO3Zg+vTpdfgqERFRbZRVGjBz8wmsSrgEAHiglQsWxYbDU3Pv2YmGxtJE97Rnzx6Eh4dXWzZy5Eh8+eWXOHDgAGbPno24uDjo9Xr4+Pjg0Ucfxfvvv3/P7T700EPVHisUClRVVWHt2rWYMWMGXn75ZVy9ehXe3t545plnbrv304cffojOnTtj6dKlWL58OYxGI9q0aYPnnnsOw4cPN43T6/Xw9PQEAKhUKvj5+WHmzJl44403avuSEBFRHTh7vQjxK5NwMrsQMhnw2iNtMD66LWws6OzSH8lETa6opb+k1+uh0Wig0+mgVqurrSsrK8P58+fh7+8POzs7iRJSTfCYERHVrx+SL+OtH9JQUmGAazMlPhkchofatmjwHHd7//4znmkiIiKiBlNaYcCMH9Ow7uhlAEBUa1csHBIGd7Xl/wOVpYmIiIgaxOmcQry2Mgmnc4sgkwFjHg3EmF6BUEh0s8qaYmkiIiKieiWEwPrEy5i+KQ1llUa0cFJh4eAwPBjgJnW0GmFpIiIionpTXF6FaRvTsCH5CgCgZ6AbPh4UhhZOKomT1RxLUwPiNffWg8eKiOj+ZVzTI35VEs5dL4ZcBkx4rC1eeyRAsu+Ou18sTQ3g1h2rS0pKzLorNkmvpKQEAMz6bjsiIqpOCIHVh7Pw7k/pKK8yQqtWYdGQcES2dpU62n1haWoACoUCzs7OyM3NBQA4ODjU2Z25qW4JIVBSUoLc3Fw4OztDoaibr50hImoqCssq8eYPafgp5SoA4JF2LTB/YChcHa1vOu7PWJoaiIeHBwCYihNZNmdnZ9MxIyIi86Rd0WHUqiRcuFEChVyGSTHt8M+era12Ou7PWJoaiEwmg6enJ9zd3U1fYEuWydbWlmeYiIhqQAiB/xy6iPc3Z6DCYISXxg6L48LR2a+51NHqFEtTA1MoFHxDJiKiRkNXWompG45ja+rv3/EZ3V6LeQM7wdlBKXGyusfSRERERLWSklWAUauTkJVfCluFDG88HoSRPfwb7XW7LE1ERERUI0II/Gv/BczZloFKg4C3iz2WxEUgzMdZ6mj1iqWJiIiIzFZQUoHX1x/Hzxk5AIDHO3jgw+c6QWPf+G/RwtJEREREZkm8eBNjVifjSkEplAo53urXHn+P8mu003F/xtJEREREd2U0Cnyx9xw+2pGJKqOAn6sDlsZFoGNLjdTRGhRLExEREf2l/OIKTFx3DL9kXgcAPNHJE7OfDYGTXeOfjvszliYiIiK6o8Pn8zFmdTKy9WVQ2sgx48lgxHX1bTLTcX/G0kRERETVGI0Cy349i493noLBKNDarRmWxEUg2EstdTRJsTQRERGRSV5ROcavPYa9p/MAAM+Et8T7/TuimYqVga8AERERAQAOnr2BsWuSkVtYDjtbOWY+1REDu3g32em4P2NpIiIiauIMRoHFu09j0a7TMAog0N0RS4dGoK3WSepoFoWliYiIqAnL1Zdh3NpjOHD2BgBgYGdvvPt0BzgoWRH+jK8IERFRE7X39HWMX3sMeUUVcFAq8H7/jng2wlvqWBaLpYmIiKiJqTIYseDn01i65wyEAII8nLAkLgIB7o5SR7NoLE1ERERNSLauDGNWJ+PwhXwAQGxXX8x4Mhh2tgqJk1k+uZQ7NxgMmDZtGvz9/WFvb482bdrgvffegxDCNEYIgenTp8PT0xP29vaIjo7G6dOnq20nPz8fQ4cOhVqthrOzM0aOHImioqJqY44fP46ePXvCzs4OPj4+mDt37m151q9fj6CgINjZ2SEkJARbt26tnydOREQkgV8yc9F30V4cvpCPZkoFFsWGY/azISxMZpK0NH344YdYtmwZlixZgoyMDHz44YeYO3cuFi9ebBozd+5cLFq0CMuXL0dCQgKaNWuGmJgYlJWVmcYMHToU6enp2LlzJzZv3ozffvsN//znP03r9Xo9evfuDT8/PyQmJuKjjz7CO++8g88//9w05sCBA4iNjcXIkSORnJyM/v37o3///khLS2uYF4OIiKieVBqMmL0tAyO+PoL84goEe6qxeUxPPBXqJXU0qyITfzyt08CeeOIJaLVafPXVV6ZlAwYMgL29Pb799lsIIeDl5YWJEyfi9ddfBwDodDpotVqsWLECQ4YMQUZGBoKDg3HkyBF06dIFALB9+3b07dsXly9fhpeXF5YtW4a33noL2dnZUCqVAIApU6Zg48aNOHnyJABg8ODBKC4uxubNm01ZunXrhrCwMCxfvvyez0Wv10Oj0UCn00Gtbtp3TCUiIstxpaAUY1YnI/HiTQDA36P88Gbf9jy79D81ef+W9EzTgw8+iF27duHUqVMAgJSUFOzbtw99+vQBAJw/fx7Z2dmIjo42/Y5Go0FkZCQOHjwIADh48CCcnZ1NhQkAoqOjIZfLkZCQYBrz0EMPmQoTAMTExCAzMxM3b940jfnjfm6NubWfPysvL4der6/2Q0REZEl+PpGDvgv3IvHiTTipbPDp0AjMfLojC1MtSXoh+JQpU6DX6xEUFASFQgGDwYAPPvgAQ4cOBQBkZ2cDALRabbXf02q1pnXZ2dlwd3evtt7GxgbNmzevNsbf3/+2bdxa5+Liguzs7Lvu589mz56Nd999tzZPm4iIqF5VVBkxd/tJfLnvPACgk7cGS2Ij4OvqIHEy6yZpaVq3bh1WrlyJVatWoUOHDjh27BjGjRsHLy8vDB8+XMpo9zR16lRMmDDB9Fiv18PHx0fCREREREBWfglGrU5GSlYBAODF7v6Y0icIShtJJ5caBUlL06RJkzBlyhQMGTIEABASEoKLFy9i9uzZGD58ODw8PAAAOTk58PT0NP1eTk4OwsLCAAAeHh7Izc2ttt2qqirk5+ebft/DwwM5OTnVxtx6fK8xt9b/mUqlgkqlqs3TJiIiqhfb065h0nfHUVhWBbWdDeYNDEXvDnd+H6Oak7R2lpSUQC6vHkGhUMBoNAIA/P394eHhgV27dpnW6/V6JCQkICoqCgAQFRWFgoICJCYmmsbs3r0bRqMRkZGRpjG//fYbKisrTWN27tyJdu3awcXFxTTmj/u5NebWfoiIiCxVeZUBMzal4ZVvk1BYVoVwX2dsHduThamuCQkNHz5ctGzZUmzevFmcP39ebNiwQbi5uYnJkyebxsyZM0c4OzuLTZs2iePHj4unn35a+Pv7i9LSUtOYxx9/XISHh4uEhASxb98+ERgYKGJjY03rCwoKhFarFcOGDRNpaWlizZo1wsHBQXz22WemMfv37xc2NjZi3rx5IiMjQ8yYMUPY2tqK1NRUs56LTqcTAIROp6uDV4aIiMg8568XiX6LfhN+b2wWfm9sFrO2nBAVVQapY1mNmrx/S1qa9Hq9GDt2rPD19RV2dnaidevW4q233hLl5eWmMUajUUybNk1otVqhUqlEr169RGZmZrXt3LhxQ8TGxgpHR0ehVqvFiBEjRGFhYbUxKSkpokePHkKlUomWLVuKOXPm3JZn3bp1om3btkKpVIoOHTqILVu2mP1cWJqIiKih/ZRyRXSYvl34vbFZhL27Q+zKyJY6ktWpyfu3pPdpakx4nyYiImooZZUGzNx8AqsSLgEAHmjlgkWx4fDU2EuczPrU5P2b3z1HRERkRc5eL0L8yiSczC4EALz2SBtMeKwtbBT8dFx9Y2kiIiKyEhuTr+DNH1JRUmGAazMlPh4chofbtpA6VpPB0kRERGThSisMeOfHdKw9mgUA6Na6ORYOCYdWbSdxsqaFpYmIiMiCnc4pRPyqJJzKKYJMBox5NBBjegVCIZdJHa3JYWkiIiKyUOuPZmH6pnSUVhrQwkmFhYPD8GCAm9SxmiyWJiIiIgtTXF6FaZvSsCHpCgCgR4AbPhkchhZO/CYKKbE0ERERWZCT2XrEr0zC2evFkMuACY+1xauPBHA6zgKwNBEREVkAIQTWHMnCOz+mo7zKCK1ahUVDwhHZ2lXqaPQ/LE1EREQSKyyrxJs/pOGnlKsAgIfbtsDHg0Lh6sjpOEvC0kRERCShtCs6jFqVhAs3SqCQy/B673Z4+aHWkHM6zuKwNBEREUlACIFvD13Ee5szUGEwwktjh8Vx4ejs11zqaPQXWJqIiIgamL6sElO+P46tqdkAgOj27vjouVC4NFNKnIzuhqWJiIioAR2/XID4VUnIyi+FjVyGKX2CMLKHP2QyTsdZOpYmIiKiBiCEwNf7L2D2tgxUGgS8XeyxJC4CYT7OUkcjM7E0ERER1bOCkgpM+u44dp7IAQDEdNBi7nOh0NjbSpyMaoKliYiIqB4lXbqJ0auScaWgFEqFHG/1a4+/R/lxOs4KsTQRERHVA6NR4Mt95zB3eyaqjAJ+rg5YEhuBEG+N1NGolliaiIiI6lh+cQVeX5+C3SdzAQD9Onli9rMhUNtxOs6asTQRERHVoSMX8jFmdTKu6cqgtJFj+hPBGBrpy+m4RoCliYiIqA4YjQLLfj2Lj3eegsEo0NqtGZbERSDYSy11NKojLE1ERET3Ka+oHOPXHsPe03kAgP5hXnj/mRA4qvg225jwaBIREd2Hg2dvYOyaZOQWlsPOVo6ZT3XEwC7enI5rhFiaiIiIasFgFFiy+wwW7joFowAC3B2xNC4C7TycpI5G9YSliYiIqIZyC8swbs0xHDh7AwDwXGdvzHy6AxyUfFttzHh0iYiIamDf6TyMW5uMvKIK2Nsq8H7/jhjQ2VvqWNQAWJqIiIjMUGUwYuGu01jyyxkIAbTTOmHp0AgEuDtKHY0aCEsTERHRPWTryjBmTTIOn88HAMR29cGMJzvAzlYhcTJqSCxNREREd7EnMxcT1qUgv7gCzZQKzHo2BE+HtZQ6FkmApYmIiOgOKg1GzP/vKSz/9SwAINhTjSVx4WjdgtNxTRVLExER0Z9cLSjF6NXJSLx4EwAwrJsf3urXntNxTRxLExER0R/8fCIHr3+XgoKSSjipbPDhc53QN8RT6lhkAViaiIiIAFRUGTF3+0l8ue88AKCTtwZLYiPg6+ogcTKyFCxNRETU5GXll2DU6mSkZBUAAEZ0b4UpfYKgsuF0HP0/liYiImrStqdlY9J3KSgsq4LazgYfDQxFTAcPqWORBWJpIiKiJqm8yoDZW09ixYELAIAwH2csiQuHtwun4+jOWJqIiKjJuXijGKNWJSP1ig4A8M+HWmNSTDvYKuQSJyNLxtJERERNyubjVzHl+1QUlVfB2cEWHw8KxaNBWqljkRVgaSIioiahrNKA9zafwMqESwCALn4uWBQbDi9ne4mTkbVgaSIiokbv3PUixK9KRsY1PQDgtUfaYMJjbWHD6TiqAZYmIiJq1DYmX8GbP6SipMIA12ZKfDw4DA+3bSF1LLJCLE1ERNQolVYY8M6P6Vh7NAsA0K11cywcEg6t2k7iZGStWJqIiKjROZNbiPiVycjMKYRMBox+NBBjewVCIZdJHY2sGEsTERE1Kt8lXsa0jWkorTTAzVGFhUPC0D3ATepY1AiwNBERUaNQXF6FaZvSsCHpCgCge4ArPhkcBncnTsdR3WBpIiIiq3cyW4/4lUk4e70YchkwProtXvtbAKfjqE6xNBERkdUSQmDtkSzM+DEd5VVGaNUqLBwSjm6tXaWORo0QSxMREVmlovIqvLkhFT+mXAUAPNy2BT4eFApXR5XEyaixYmkiIiKrk35Vh1GrknE+rxgKuQyv926Hlx9qDTmn46gesTQREZHVEELg24RLeG/zCVRUGeGpscPi2HB0adVc6mjUBLA0ERGRVdCXVWLq96nYknoNANAryB3zBobCpZlS4mTUVLA0ERGRxTt+uQCjViXjUn4JbOQyTOkThJE9/CGTcTqOGg5LExERWSwhBFYcuIBZWzNQaRBo6WyPJXHhCPd1kToaNUEsTUREZJF0JZWY9F0K/nsiBwDQO1iLj54LhcbBVuJk1FSxNBERkcVJvnQTo1Yl40pBKZQKOd7sG4ThD7bidBxJiqWJiIgshtEo8NW+8/hw+0lUGQV8mztgaVwEQrw1UkcjYmkiIiLLcLO4AhPXp2D3yVwAQL8QT8weEAK1HafjyDKwNBERkeSOXsjH6NXJuKYrg9JGjulPBGNopC+n48iisDQREZFkjEaB5b+dxfz/noLBKODv1gxL4sLRwYvTcWR5WJqIiEgSeUXlmLAuBb+dug4AeDrMCx88EwJHFd+ayDLxTyYRETW4Q+duYMzqZOQWlkNlI8fMpztgUBcfTseRRWNpIiKiBmMwCiz95QwW/HwKRgEEuDtiaVwE2nk4SR2N6J5YmoiIqEHkFpZh/Npj2H/mBgBgQIQ33uvfAQ5KvhWRdeCfVCIiqnf7z+Rh7JpjyCsqh72tAu/174jnOntLHYuoRliaiIio3lQZjFi06zQW/3IGQgDttE5YOjQcAe6cjiPrI5c6wJUrV/D888/D1dUV9vb2CAkJwdGjR03rhRCYPn06PD09YW9vj+joaJw+fbraNvLz8zF06FCo1Wo4Oztj5MiRKCoqqjbm+PHj6NmzJ+zs7ODj44O5c+felmX9+vUICgqCnZ0dQkJCsHXr1vp50kRETUCOvgxxXyZg0e7fC9OQB3ywMb47CxNZLUlL082bN9G9e3fY2tpi27ZtOHHiBObPnw8Xl///9uq5c+di0aJFWL58ORISEtCsWTPExMSgrKzMNGbo0KFIT0/Hzp07sXnzZvz222/45z//aVqv1+vRu3dv+Pn5ITExER999BHeeecdfP7556YxBw4cQGxsLEaOHInk5GT0798f/fv3R1paWsO8GEREjciezFz0WbgXh8/no5lSgYVDwjBnQCfYKxVSRyOqNZkQQki18ylTpmD//v3Yu3fvHdcLIeDl5YWJEyfi9ddfBwDodDpotVqsWLECQ4YMQUZGBoKDg3HkyBF06dIFALB9+3b07dsXly9fhpeXF5YtW4a33noL2dnZUCqVpn1v3LgRJ0+eBAAMHjwYxcXF2Lx5s2n/3bp1Q1hYGJYvX37P56LX66HRaKDT6aBWq+/rdSEislZVBiPm7zyFZXvOAgDae6qxNC4crVs4SpyM6M5q8v4t6ZmmH3/8EV26dMHAgQPh7u6O8PBwfPHFF6b158+fR3Z2NqKjo03LNBoNIiMjcfDgQQDAwYMH4ezsbCpMABAdHQ25XI6EhATTmIceeshUmAAgJiYGmZmZuHnzpmnMH/dza8yt/fxZeXk59Hp9tR8ioqbsakEphnx+yFSYhnXzww+vPcjCRI2GpKXp3LlzWLZsGQIDA7Fjxw68+uqrGDNmDL755hsAQHZ2NgBAq9VW+z2tVmtal52dDXd392rrbWxs0Lx582pj7rSNP+7jr8bcWv9ns2fPhkajMf34+PjU+PkTETUWuzJy0HfRXhy9eBNOKhssjYvAe/07ws6W03HUeEj66Tmj0YguXbpg1qxZAIDw8HCkpaVh+fLlGD58uJTR7mnq1KmYMGGC6bFer2dxIqImp6LKiI92nMQXe88DAEJaarAkLhx+rs0kTkZU9yQ90+Tp6Yng4OBqy9q3b49Lly4BADw8PAAAOTk51cbk5OSY1nl4eCA3N7fa+qqqKuTn51cbc6dt/HEffzXm1vo/U6lUUKvV1X6IiJqSrPwSDPrsoKkwvfBgK3z3ahQLEzVakpam7t27IzMzs9qyU6dOwc/PDwDg7+8PDw8P7Nq1y7Rer9cjISEBUVFRAICoqCgUFBQgMTHRNGb37t0wGo2IjIw0jfntt99QWVlpGrNz5060a9fO9Em9qKioavu5NebWfoiI6P/tSM9Gv0V7cSyrAGo7G3w2rDPeeaoDVDacjqNGTEjo8OHDwsbGRnzwwQfi9OnTYuXKlcLBwUF8++23pjFz5swRzs7OYtOmTeL48ePi6aefFv7+/qK0tNQ05vHHHxfh4eEiISFB7Nu3TwQGBorY2FjT+oKCAqHVasWwYcNEWlqaWLNmjXBwcBCfffaZacz+/fuFjY2NmDdvnsjIyBAzZswQtra2IjU11aznotPpBACh0+nq4JUhIrJMZZVVYsamNOH3xmbh98Zm8fSSfeLSjWKpYxHVWk3evyUtTUII8dNPP4mOHTsKlUolgoKCxOeff15tvdFoFNOmTRNarVaoVCrRq1cvkZmZWW3MjRs3RGxsrHB0dBRqtVqMGDFCFBYWVhuTkpIievToIVQqlWjZsqWYM2fObVnWrVsn2rZtK5RKpejQoYPYsmWL2c+DpYmIGrsLeUXiiUV7TYXp/c3porzSIHUsovtSk/dvSe/T1JjwPk1E1JhtOX4NU74/jsLyKjg72GL+wFD0aq+99y8SWbiavH/zu+eIiOgvlVUa8P6WE/j20O8f0Oni54JFseHwcraXOBlRw2NpIiKiOzp3vQjxq5KRce33m/e+9kgbjH+sLWwVkn9tKZEkWJqIiOg2m45dwZsbUlFcYUDzZkp8MjgMD7dtIXUsIkmxNBERkUlphQHv/pSONUeyAACR/s2xKDYcWrWdxMmIpMfSREREAIAzuYWIX5mMzJxCyGTA6L8FYEyvQNhwOo4IAEsTEREB+C7xMqZtTENppQFujiosGByGHoFuUscisigsTURETVhJRRWmbUzH90mXAQDdA1zxyeAwuDtxOo7oz1iaiIiaqMzsQry2MhFnrxdDLgPGRbdF/N8CoJDLpI5GZJFYmoiImhghBNYeycKMH9NRXmWEu5MKi2LD0a21q9TRiCwaSxMRURNSVF6Ft35IxaZjVwEAD7VtgY8HhcLNUSVxMiLLx9JERNREpF/VYfSqZJzLK4ZCLsPE3m3xykNtIOd0HJFZWJqIiBo5IQS+TbiE9zafQEWVEZ4aOyyODUeXVs2ljkZkVViaiIgaMX1ZJaZuSMWW49cAAL2C3DFvYChcmiklTkZkfViaiIgaqdTLOsSvSsKl/BLYyGV44/Eg/KOnP2QyTscR1QZLExFRIyOEwDcHLmDW1pOoMBjR0tkei+PCEeHrInU0IqvG0kRE1IjoSiox+fsU7EjPAQD0Dtbio+dCoXGwlTgZkfVjaSIiaiSSL93EqFXJuFJQCluFDG/2bY8XHmzF6TiiOsLSRERk5YQQ+HLveXy4/SSqjAK+zR2wJC4cnbydpY5G1KiwNBERWbGbxRV4fX0Kdp3MBQD0DfHAnAGdoLbjdBxRXWNpIiKyUkcv5GPM6mRc1ZVBaSPHtCeC8XykL6fjiOoJSxMRkZUxGgWW/3YW8/97CgajgL9bMyyJC0cHL43U0YgaNZYmIiIrcqOoHBPWpeDXU9cBAE+HeeGDZ0LgqOJf50T1jf+XERFZiYRzNzBmTTJy9OVQ2cjx7lMdMPgBH07HETUQliYiIgtnMAp8+ssZfPLzKRgF0KZFMywdGoEgD7XU0YiaFJYmIiILlltYhvFrj2H/mRsAgAER3nivfwc4KPnXN1FD4/91REQWav+ZPIxdcwx5ReWwt1Xgvf4d8Vxnb6ljETVZLE1ERBbGYBRYuOs0Fu8+DSGAtlpHLI2LQKDWSepoRE0aSxMRkQXJ0ZdhzOpkJJzPBwAMecAHM57sAHulQuJkRMTSRERkIX49dR0T1h7DjeIKNFMqMOvZEDwd1lLqWET0P/La/NLMmTNRUlJy2/LS0lLMnDnzvkMRETUlVQYjPtx+EsP/dRg3iivQ3lONn0b3YGEisjAyIYSo6S8pFApcu3YN7u7u1ZbfuHED7u7uMBgMdRbQWuj1emg0Guh0OqjV/BgwEZnnakEpxqxOxtGLNwEAz3fzxdv9gmFny+k4ooZQk/fvWk3PCSHueDO1lJQUNG/evDabJCJqcnafzMGEdSkoKKmEo8oGcwaE4IlOXlLHIqK/UKPS5OLiAplMBplMhrZt21YrTgaDAUVFRXjllVfqPCQRUWNSaTDiox2Z+Py3cwCAkJYaLIkLh59rM4mTEdHd1Kg0LViwAEIIvPjii3j33Xeh0fz/l0MqlUq0atUKUVFRdR6SiKixyMovwejVyTiWVQAAeOHBVpjaNwgqG07HEVm6GpWm4cOHAwD8/f3RvXt32Njww3dERObakZ6NSetToC+rgtrOBnOfC8XjHT2kjkVEZqrVp+cefvhhXLx4EW+//TZiY2ORm5sLANi2bRvS09PrNCARkbUrrzLg3Z/S8fJ/EqEvq0KojzO2jOnJwkRkZWpVmn799VeEhIQgISEBGzZsQFFREYDfLwSfMWNGnQYkIrJml26U4LllB/H1/gsAgJd6+mP9y1Hwae4gbTAiqrFalaYpU6bg/fffx86dO6FUKk3LH330URw6dKjOwhERWbOtqdfQb9FepF7RwdnBFl/+vQve6hcMpU2t/uolIonV6qKk1NRUrFq16rbl7u7uyMvLu+9QRETWrKzSgA+2ZOA/hy4CADr7uWBxbDi8nO0lTkZE96NWpcnZ2RnXrl2Dv79/teXJyclo2ZJ3sCWiput8XjHiVybhxDU9AODVR9pgwmNtYavg2SUia1er/4uHDBmCN954A9nZ2ZDJZDAajdi/fz9ef/11/P3vf6/rjEREVmHTsSt4YtFenLimR/NmSqwY8QDeeDyIhYmokajVmaZZs2YhPj4ePj4+MBgMCA4OhsFgQFxcHN5+++26zkhEZNHKKn//dNzqw1kAgK7+zbFoSDg8NHYSJyOiulTj754TQiArKwstWrRAXl4eUlNTUVRUhPDwcAQGBtZXTovH754japrO5BYifmUyMnMKIZMBo/4WgLG9AmHDs0tEVqFev3tOCIGAgACkp6cjMDAQPj4+tQ5KRGTNvk+8jLc3pqG00gA3RxUWDA5Dj0A3qWMRUT2pcWmSy+UIDAzEjRs3mvSZJSJqukoqqjB9Uzq+S7wMAHiwjSsWDAmDuxOn44gas1qdP54zZw4mTZqEtLS0us5DRGTRMrML8dSS/fgu8TLkMmB8dFv8Z2QkCxNRE1Dja5oAwMXFBSUlJaiqqoJSqYS9ffV7j+Tn59dZQGvBa5qIGjchBNYdzcKMH9NRVmmEu5MKC4eEI6qNq9TRiOg+1Os1TQCwYMGC2vwaEZFVKiqvwts/pGLjsasAgJ6BbvhkcBjcHFUSJyOihlSr0jR8+PC6zkFEZJFOXNVj1KoknMsrhkIuw8TebfHKQ20gl8ukjkZEDaxWpUmv199xuUwmg0qlqvZ9dERE1kgIgZUJlzBz8wlUVBnhqbHDothwPNCqudTRiEgitf4aFZnsr/+V5e3tjRdeeAEzZsyAXM57lRCRdSksq8SUDanYcvwaAODRIHfMGxiK5s34D0KipqxWpWnFihV466238MILL6Br164AgMOHD+Obb77B22+/jevXr2PevHlQqVR488036zQwEVF9Sr2sw6jVSbh4owQ2chkmP94O/+jRmtNxRFS70vTNN99g/vz5GDRokGnZk08+iZCQEHz22WfYtWsXfH198cEHH7A0EZFVEELgmwMXMGvrSVQYjGjpbI/FceGI8HWROhoRWYhalaYDBw5g+fLlty0PDw/HwYMHAQA9evTApUuX7i8dEVED0JVUYvL3KdiRngMAeCxYi3nPhULjYCtxMiKyJLW64MjHxwdfffXVbcu/+uor09eq3LhxAy4u/BcaEVm2Y1kF6Ld4L3ak58BWIcP0J4Lx+bDOLExEdJtanWmaN28eBg4ciG3btuGBBx4AABw9ehQnT57Ed999BwA4cuQIBg8eXHdJiYjqkBACX+07jznbTqLKKODb3AFL4sLRydtZ6mhEZKFqdUdwADh//jw+++wznDp1CgDQrl07vPzyy2jVqlVd5rMavCM4kfUoKKnA6+tT8HNGLgCgb4gH5gzoBLUdzy4RNTU1ef+udWmi6liaiKxD4sV8jF6VjKu6Miht5Jj2RDCej/S9621UiKjxqsn7d61vorR37148//zzePDBB3HlyhUAwH/+8x/s27evtpskIqo3RqPAsj1nMeizQ7iqK4O/WzP88NqDGNbNj4WJiMxSq9L0/fffIyYmBvb29khKSkJ5eTkAQKfTYdasWXUakIjoft0oKseL3xzBh9tPwmAUeCrUCz+N7oEOXhqpoxGRFalVaXr//fexfPlyfPHFF7C1/f9rALp3746kpKQ6C0dEdL8Szt1A30V7sSfzOlQ2csx+NgQLh4TBUVWrz8EQURNWq781MjMz8dBDD922XKPRoKCg4H4zERHdN4NR4NNfzuCTn0/BKIA2LZph6dAIBHnwmkMiqp1alSYPDw+cOXPmtk/K7du3D61bt66LXEREtXa9sBzj1x7DvjN5AIBnI1rivac7ohnPLhHRfajV9NxLL72EsWPHIiEhATKZDFevXsXKlSsxceJEvPrqq7UKMmfOHMhkMowbN860rKysDPHx8XB1dYWjoyMGDBiAnJycar936dIl9OvXDw4ODnB3d8ekSZNQVVVVbcyePXsQEREBlUqFgIAArFix4rb9L126FK1atYKdnR0iIyNx+PDhWj0PIpLWgTN56LNwL/adyYO9rQIfPdcJHw8KY2EiovtWq79FpkyZAqPRiF69eqGkpAQPPfQQVCoVJk2ahH/84x813t6RI0fw2WefoVOnTtWWjx8/Hlu2bMH69euh0WgwatQoPPvss9i/fz8AwGAwoF+/fvDw8MCBAwdw7do1/P3vf4etra3pgvTz58+jX79+eOWVV7By5Urs2rUL//jHP+Dp6YmYmBgAwNq1azFhwgQsX74ckZGRWLBgAWJiYpCZmQl3d/favERE1MAMRoGFu05j8e7TEAJoq3XE0rgIBGqdpI5GRI2FuA/l5eUiPT1dJCQkiMLCQjFv3jyh1WprtI3CwkIRGBgodu7cKR5++GExduxYIYQQBQUFwtbWVqxfv940NiMjQwAQBw8eFEIIsXXrViGXy0V2drZpzLJly4RarRbl5eVCCCEmT54sOnToUG2fgwcPFjExMabHXbt2FfHx8abHBoNBeHl5idmzZ5v9PHQ6nQAgdDqd+U+eiOpEtq5UDP7sgPB7Y7Pwe2OzmLw+RZSUV0kdi4isQE3ev2s0PVdeXo6pU6eiS5cu6N69O7Zu3Yrg4GCkp6ejXbt2WLhwIcaPH1+j0hYfH49+/fohOjq62vLExERUVlZWWx4UFARfX1/TlwIfPHgQISEh0Gq1pjExMTHQ6/VIT083jfnztmNiYkzbqKioQGJiYrUxcrkc0dHRpjFEZLl+O3UdfRfuxaFz+XBQKrBgcBg+fK4T7JUKqaMRUSNTo+m56dOn47PPPkN0dDQOHDiAgQMHYsSIETh06BDmz5+PgQMHQqEw/y+qNWvWICkpCUeOHLltXXZ2NpRKJZydnast12q1yM7ONo35Y2G6tf7WuruN0ev1KC0txc2bN2EwGO445uTJk3+Zvby83HR/KuD3O4oSUcOpMhjx8c5T+HTPWQBAe081lsaFo3ULR4mTEVFjVaPStH79evz73//GU089hbS0NHTq1AlVVVVISUmp8R11s7KyMHbsWOzcuRN2dnY1+l1LMHv2bLz77rtSxyBqkq7pSjFmdTKOXLgJABga6YtpTwTDzpZnl4io/tRoeu7y5cvo3LkzAKBjx45QqVQYP358rb6CIDExEbm5uYiIiICNjQ1sbGzw66+/YtGiRbCxsYFWq0VFRcVt933KycmBh4cHgN9vffDnT9PdenyvMWq1Gvb29nBzc4NCobjjmFvbuJOpU6dCp9OZfrKysmr8GhBRzf1yMhd9F+7FkQs34aiywZK4cHzwTAgLExHVuxqVJoPBAKVSaXpsY2MDR8fanQrv1asXUlNTcezYMdNPly5dMHToUNN/29raYteuXabfyczMxKVLlxAVFQUAiIqKQmpqKnJzc01jdu7cCbVajeDgYNOYP27j1phb21AqlejcuXO1MUajEbt27TKNuROVSgW1Wl3th4jqT6XBiNlbMzBixRHcLKlEx5ZqbB7dA0908pI6GhE1ETWanhNC4IUXXoBKpQLw+32UXnnlFTRr1qzauA0bNtxzW05OTujYsWO1Zc2aNYOrq6tp+ciRIzFhwgQ0b94carUao0ePRlRUFLp16wYA6N27N4KDgzFs2DDMnTsX2dnZePvttxEfH2/K+Morr2DJkiWYPHkyXnzxRezevRvr1q3Dli1bTPudMGEChg8fji5duqBr165YsGABiouLMWLEiJq8PERUTy7fLMHo1clIvlQAAHjhwVaY2jcIKhueXSKihlOj0jR8+PBqj59//vk6DfNnn3zyCeRyOQYMGIDy8nLExMTg008/Na1XKBTYvHkzXn31VURFRaFZs2YYPnw4Zs6caRrj7++PLVu2YPz48Vi4cCG8vb3x5Zdfmu7RBACDBw/G9evXMX36dGRnZyMsLAzbt2+/7eJwImp4/03PxuvrU6Avq4KTnQ0+eq4THu/oKXUsImqCZEIIIXWIxkCv10Oj0UCn03GqjqgOVFQZMXtbBr7efwEAEOqtwZK4CPg0d5A2GBE1KjV5/+b3ChCRxbl0owSjVifh+GUdAOAfPfwx+fEgKG1q9c1PRER1gqWJiCzK1tRreOO74ygsr4LG3hbzB4YiOphT5UQkPZYmIrIIZZUGfLAlA/85dBEA0NnPBYtiw9HS2V7iZEREv2NpIiLJnc8rxqhVSUi/+vud9V95uA0m9m4LWwWn44jIcrA0EZGkfky5iqnfH0dxhQHNmykxf1Ao/tbOXepYRES3YWkiIkmUVRrw7k8nsPrwJQBA11bNsSg2HB4a6/taJSJqGliaiKjBncktwqhVSTiZXQiZDBj1twCM7RUIG07HEZEFY2kiogb1feJlvL0xDaWVBrg5KvHJ4DD0DGwhdSwiontiaSKiBlFSUYXpm9LxXeJlAEBUa1csHBIGdzWn44jIOrA0EVG9O5VTiPiVSTidWwS5DBjbqy1GPRoAhVwmdTQiIrOxNBFRvRFCYP3Ry5j+YxrKKo1wd1Jh4ZBwRLVxlToaEVGNsTQRUb0oLq/CWz+kYuOxqwCAnoFu+GRwGNwcVRInIyKqHZYmIqpzJ67qMWpVEs7lFUMhl2HCY23x6sNtIOd0HBFZMZYmIqozQgisOnwJ7/50AhVVRnio7bA4LhwPtGoudTQiovvG0kREdaKwrBJTN6Ri8/FrAIC/tWuB+YPC0LyZUuJkRER1g6WJiO5b2hUd4lcl4eKNEtjIZZj8eDv8o0drTscRUaPC0kREtSaEwL8PXsQHWzJQYTCipbM9FsWGo7Ofi9TRiIjqHEsTEdWKrrQSb3x3HNvTswEA0e21mDewE5wdOB1HRI0TSxMR1dixrAKMWpWEyzdLYauQYWqf9hjRvRVkMk7HEVHjxdJERGYTQuCrfefx4faTqDQI+DS3x5LYCIT6OEsdjYio3rE0EZFZCkoq8Pr6FPyckQsA6NPRA3MGdILG3lbiZEREDYOliYjuKfFiPkavSsZVXRmUCjmmPdEez3fz43QcETUpLE1E9JeMRoHP957DRzsyYTAKtHJ1wJK4CHRsqZE6GhFRg2NpIqI7ulFUjonrU7An8zoA4MlQL8x6piOc7DgdR0RNE0sTEd0m4dwNjFmTjBx9OVQ2crzzVAcMecCH03FE1KSxNBGRidEo8OmeM/h45ykYBdC6RTMsjYtAe0+11NGIiCTH0kREAIDrheWYsO4Y9p7OAwA8G94S7/XviGYq/jVBRASwNBERgANn8jB27TFcLyyHna0cM5/uiIGdvTkdR0T0ByxNRE2YwSiwaNdpLNp9GkIAbbWOWBoXgUCtk9TRiIgsDksTUROVqy/DmDXJOHQuHwAwqIs33n2qI+yVComTERFZJpYmoibot1PXMX7tMdworoCDUoEPnumIZ8K9pY5FRGTRWJqImpAqgxGf/HwKn+45CyGAIA8nLB0agTYtHKWORkRk8ViaiJqIa7pSjF19DIcv/D4dFxfpi+lPBMPOltNxRETmYGkiagJ+OZmLCeuO4WZJJRxVNpj9bAieDPWSOhYRkVVhaSJqxCoNRszbkYnPfjsHAOjYUo0lsRFo5dZM4mRERNaHpYmokbp8swSjVycj+VIBAGB4lB/e7NceKhtOxxER1QZLE1Ej9N/0bEz67jh0pZVwsrPB3AGd0CfEU+pYRERWjaWJqBGpqDJizraT+Nf+8wCAUG8NlsRFwKe5g8TJiIisH0sTUSORlV+CUauSkHJZBwAY2cMfbzweBKWNXOJkRESNA0sTUSOwLfUaJn9/HIVlVdDY22LewFA8FqyVOhYRUaPC0kRkxcoqDZi1NQP/PngRABDh64zFcRFo6WwvcTIiosaHpYnISl3IK0b8qiSkX9UDAF5+uDVe790OtgpOxxER1QeWJiIr9GPKVby5IRVF5VVwcbDFx4PC8Lcgd6ljERE1aixNRFakrNKAd386gdWHLwEAurZqjoWxYfDUcDqOiKi+sTQRWYkzuUUYtSoJJ7MLIZMB8Y8EYFx0IGw4HUdE1CBYmoiswIaky3h7YxpKKgxwc1Tik8Fh6BnYQupYRERNCksTkQUrqajCjE3pWJ94GQAQ1doVC4eEwV1tJ3EyIqKmh6WJyEKdyilE/MoknM4tgkwGjO0ViNGPBkIhl0kdjYioSWJpIrIwQgisT7yM6ZvSUFZpRAsnFRYOCcODbdykjkZE1KSxNBFZkOLyKry9MQ0/JF8BAPQMdMMng8Pg5qiSOBkREbE0EVmIjGt6xK9KwrnrxZDLgIm92+HVh9tAzuk4IiKLwNJEJDEhBFYfzsI7P6WjosoID7UdFsWGo6t/c6mjERHRH7A0EUmosKwSb/6Qhp9SrgIAHmnXAh8PCkPzZkqJkxER0Z+xNBFJJO2KDqNWJeHCjRIo5DJMjmmHl3q25nQcEZGFYmkiamBCCPz74EV8sCUDFQYjWjrbY1FsODr7uUgdjYiI7oKliagB6UorMeX749iWlg0AiG6vxbyBneDswOk4IiJLx9JE1EBSsgowanUSsvJLYauQYUqf9nixeyvIZJyOIyKyBixNRPVMCIF/7b+AOdsyUGkQ8GlujyWxEQj1cZY6GhER1QBLE1E9KiipwOvrj+PnjBwAQJ+OHpgzoBM09rYSJyMioppiaSKqJ4kXb2LM6mRcKSiFUiHH20+0x7BufpyOIyKyUixNRHXMaBT4Yu85fLQjE1VGAT9XByyNi0DHlhqpoxER0X1gaSKqQ/nFFZi47hh+ybwOAHiikydmPxsCJztOxxERWTuWJqI6cvh8PsasTka2vgxKGzneebIDYrv6cDqOiKiRYGkiuk9Go8Cne87g452nYBRA6xbNsDQuAu091VJHIyKiOiSXcuezZ8/GAw88ACcnJ7i7u6N///7IzMysNqasrAzx8fFwdXWFo6MjBgwYgJycnGpjLl26hH79+sHBwQHu7u6YNGkSqqqqqo3Zs2cPIiIioFKpEBAQgBUrVtyWZ+nSpWjVqhXs7OwQGRmJw4cP1/lzpsblemE5hn99GPP++3theja8JX4a1YOFiYioEZK0NP3666+Ij4/HoUOHsHPnTlRWVqJ3794oLi42jRk/fjx++uknrF+/Hr/++iuuXr2KZ5991rTeYDCgX79+qKiowIEDB/DNN99gxYoVmD59umnM+fPn0a9fP/ztb3/DsWPHMG7cOPzjH//Ajh07TGPWrl2LCRMmYMaMGUhKSkJoaChiYmKQm5vbMC8GWZ0DZ/PQd9Fe7D2dBztbOeY+1wnzB4WimYoncImIGiVhQXJzcwUA8euvvwohhCgoKBC2trZi/fr1pjEZGRkCgDh48KAQQoitW7cKuVwusrOzTWOWLVsm1Gq1KC8vF0IIMXnyZNGhQ4dq+xo8eLCIiYkxPe7atauIj483PTYYDMLLy0vMnj3brOw6nU4AEDqdrobPmqxNlcEoPtmZKfynbBZ+b2wW0fP3iMxsvdSxiIioFmry/i3pmaY/0+l0AIDmzZsDABITE1FZWYno6GjTmKCgIPj6+uLgwYMAgIMHDyIkJARardY0JiYmBnq9Hunp6aYxf9zGrTG3tlFRUYHExMRqY+RyOaKjo01j/qy8vBx6vb7aDzV+ufoyPP9lAhb8fBpGAQzq4o0fR/VAW62T1NGIiKieWUxpMhqNGDduHLp3746OHTsCALKzs6FUKuHs7FxtrFarRXZ2tmnMHwvTrfW31t1tjF6vR2lpKfLy8mAwGO445tY2/mz27NnQaDSmHx8fn9o9cbIae09fR99Fe3Hw3A04KBX4eFAo5j4XCnulQupoRETUACzm4ov4+HikpaVh3759Ukcxy9SpUzFhwgTTY71ez+LUSFUZjFjw82ks3XMGQgBBHk5YEheBAHdHqaMREVEDsojSNGrUKGzevBm//fYbvL29Tcs9PDxQUVGBgoKCamebcnJy4OHhYRrz50+53fp03R/H/PkTdzk5OVCr1bC3t4dCoYBCobjjmFvb+DOVSgWVSlW7J0xW45quFGNXH8PhC/kAgLhIX0x/Ihh2tjy7RETU1Eg6PSeEwKhRo/DDDz9g9+7d8Pf3r7a+c+fOsLW1xa5du0zLMjMzcenSJURFRQEAoqKikJqaWu1Tbjt37oRarUZwcLBpzB+3cWvMrW0olUp07ty52hij0Yhdu3aZxlDT88vJXPRduBeHL+TDUWWDRbHhmPVMCAsTEVETJemZpvj4eKxatQqbNm2Ck5OT6fohjUYDe3t7aDQajBw5EhMmTEDz5s2hVqsxevRoREVFoVu3bgCA3r17Izg4GMOGDcPcuXORnZ2Nt99+G/Hx8aYzQa+88gqWLFmCyZMn48UXX8Tu3buxbt06bNmyxZRlwoQJGD58OLp06YKuXbtiwYIFKC4uxogRIxr+hSFJVRqMmLcjE5/9dg4A0MFLjSVxEfB3ayZxMiIiklT9f5jvrwG448/XX39tGlNaWipee+014eLiIhwcHMQzzzwjrl27Vm07Fy5cEH369BH29vbCzc1NTJw4UVRWVlYb88svv4iwsDChVCpF69atq+3jlsWLFwtfX1+hVCpF165dxaFDh8x+LrzlQONw+WaJeGbpPuH3xu+3E5i+MVWUVlRJHYuIiOpJTd6/ZUIIIV1lazz0ej00Gg10Oh3Uat4N2hrtPJGD19enQFdaCSc7G8wd0Al9QjyljkVERPWoJu/fFnEhOJGUKqqM+HD7SXy17zwAINRbg8WxEfB1dZA4GRERWRKWJmrSsvJLMGpVElIu/35j1Re7+2NKnyAobSzmFmZERGQhWJqoydqedg2TvjuOwrIqaOxtMW9gKB4L1t77F4mIqEliaaImp7zKgFlbMvDNwYsAgHBfZyyODYe3C6fjiIjor7E0UZNyIa8Yo1YnIe3K798V+PLDrfF673awVXA6joiI7o6liZqMn1KuYuqGVBSVV8HFwRYfDwrD34LcpY5FRERWgqWJGr2ySgNmbj6BVQmXAAAPtHLBothweGrsJU5GRETWhKWJGrWz14sQvzIJJ7MLIZMBrz3SBuOj28KG03FERFRDLE3UaP2QfBlv/ZCGkgoDXJsp8cngMDzUtoXUsYiIyEqxNFGjU1phwIwf07Du6GUAQFRrVywcEgZ3tZ3EyYiIyJqxNFGjcjqnEK+tTMLp3CLIZMCYRwMxplcgFHKZ1NGIiMjKsTRRoyCEwPrEy5i+KQ1llUa0cFJh4eAwPBjgJnU0IiJqJFiayOoVl1dh2sY0bEi+AgDoGeiGjweFoYWTSuJkRETUmLA0kVXLuKbHqFVJOHu9GHIZMOGxtnjtkQDIOR1HRER1jKWJrJIQAqsPZ+Hdn9JRXmWEVq3CoiHhiGztKnU0IiJqpFiayOoUllXizR/S8FPKVQDAI+1aYP7AULg6cjqOiIjqD0sTWZW0KzqMWpWECzdKoJDLMCmmHf7ZszWn44iIqN6xNJFVEELgP4cu4v3NGagwGOGlscPiuHB09msudTQiImoiWJrI4ulKKzF1w3FsTc0GAES312LewE5wdlBKnIyIiJoSliayaClZBRi1OglZ+aWwVcjwxuNBGNnDHzIZp+OIiKhhsTSRRRJC4F/7L2DOtgxUGgS8XeyxJC4CYT7OUkcjIqImiqWJLE5BSQUmfXccO0/kAAAe7+CBD5/rBI29rcTJiIioKWNpIouSdOkmRq9KxpWCUigVcrzVrz3+HuXH6TgiIpIcSxNZBKNR4Iu95/DRjkxUGQX8XB2wNC4CHVtqpI5GREQEgKWJLEB+cQVeX5+C3SdzAQBPdPLE7GdD4GTH6TgiIrIcLE0kqcPn8zFmdTKy9WVQ2sgx48lgxHX15XQcERFZHJYmkoTRKLDs17P4eOcpGIwCrd2aYUlcBIK91FJHIyIiuiOWJmpweUXlGL/2GPaezgMAPBPeEu/374hmKv5xJCIiy8V3KWpQB8/ewNg1ycgtLIedrRwzn+qIgV28OR1HREQWj6WJGoTBKLB492ks2nUaRgEEujti6dAItNU6SR2NiIjILCxNVO9yC8swbs0xHDh7AwAwsLM33n26AxyU/ONHRETWg+9aVK/2nc7DuLXJyCuqgINSgff7d8SzEd5SxyIiIqoxliaqF1UGIxb8fBpL95yBEECQhxOWxEUgwN1R6mhERES1wtJEdS5bV4Yxa5Jx+Hw+ACC2qy9mPBkMO1uFxMmIiIhqj6WJ6tQvmbmYuC4F+cUVaKZUYPaATngq1EvqWERERPeNpYnqRKXBiHn/zcRnv54DAAR7qrF0aAT83ZpJnIyIiKhusDTRfbtSUIoxq5ORePEmAODvUX54s297TscREVGjwtJE9+XnEzmYuD4FutJKOKls8OFzndA3xFPqWERERHWOpYlqpaLKiLnbT+LLfecBAJ28NVgSGwFfVweJkxEREdUPliaqsaz8EoxanYyUrAIAwIvd/TGlTxCUNnJpgxEREdUjliaqke1p1zDpu+MoLKuC2s4G8waGoncHD6ljERER1TuWJjJLeZUBs7Zk4JuDFwEA4b7OWBwbDm8XTscREVHTwNJE93QhrxijVich7YoeAPDyQ63xekw72Co4HUdERE0HSxPd1ebjVzHl+1QUlVfBxcEW8weF4tEgrdSxiIiIGhxLE91RWaUBMzefwKqESwCAB1q5YFFsODw19hInIyIikgZLE93m7PUixK9MwsnsQshkwGuPtMH46Law4XQcERE1YSxNVM3G5Ct484dUlFQY4NpMiU8Gh+Ghti2kjkVERCQ5liYCAJRWGPDOj+lYezQLANCtdXMsHBIOrdpO4mRERESWgaWJcDqnEPGrknAqpwgyGTDm0UCM6RUIhVwmdTQiIiKLwdLUxK0/moXpm9JRWmlACycVFg4Ow4MBblLHIiIisjgsTU1UcXkVpm1Kw4akKwCAHgFu+GRwGFo4qSRORkREZJlYmpqgk9l6xK9MwtnrxZDLgAmPtcWrjwRwOo6IiOguWJqaECEE1hzJwjs/pqO8ygitWoVFQ8IR2dpV6mhEREQWj6WpiSgqr8KbG1LxY8pVAMDDbVvg40GhcHXkdBwREZE5WJqagLQrOoxalYQLN0qgkMswKaYd/tmzNeScjiMiIjIbS1MjJoTAt4cu4r3NGagwGOGlscPiuHB09msudTQiIiKrw9LUSOnLKjHl++PYmpoNAIhu746PnguFSzOlxMmIiIisE0tTI3T8cgHiVyUhK78UNnIZpvQJwsge/pDJOB1HRERUWyxNjYgQAl/vv4DZ2zJQaRDwdrHHkrgIhPk4Sx2NiIjI6rE0NRK6kkpM+i4F/z2RAwCI6aDF3OdCobG3lTgZERFR48DS1AgkXbqJ0auScaWgFEqFHG/1a4+/R/lxOo6IiKgOsTRZMaNR4Mt95zB3eyaqjAJ+rg5YEhuBEG+N1NGIiIgaHZYmK3WzuAIT16dg98lcAEC/Tp6Y/WwI1HacjiMiIqoPLE1W6MiFfIxZnYxrujIobeSY8WQw4rr6cjqOiIioHsmlDmBpli5dilatWsHOzg6RkZE4fPiw1JFMjEaBpb+cwZDPD+Gargyt3Zph42vdMTSS1y8RERHVN5amP1i7di0mTJiAGTNmICkpCaGhoYiJiUFubq7U0ZBXVI7hXx/GRzsyYTAK9A/zwo+jeyDYSy11NCIioiZBJoQQUoewFJGRkXjggQewZMkSAIDRaISPjw9Gjx6NKVOm3PV39Xo9NBoNdDod1Oq6LTIHz97A2DXJyC0sh52tHDOf6oiBXbx5domIiOg+1eT9m9c0/U9FRQUSExMxdepU0zK5XI7o6GgcPHjwtvHl5eUoLy83Pdbr9fWS69tDFzF9UxqMAghwd8TSuAi083Cql30RERHRX+P03P/k5eXBYDBAq9VWW67VapGdnX3b+NmzZ0Oj0Zh+fHx86iVXJ28NbORyDIjwxo+jurMwERERSYSlqZamTp0KnU5n+snKyqqX/XTydsa2cT0xf1AoHJQ8MUhERCQVvgv/j5ubGxQKBXJycqotz8nJgYeHx23jVSoVVCpVg2Rr08KxQfZDREREf41nmv5HqVSic+fO2LVrl2mZ0WjErl27EBUVJWEyIiIisgQ80/QHEyZMwPDhw9GlSxd07doVCxYsQHFxMUaMGCF1NCIiIpIYS9MfDB48GNevX8f06dORnZ2NsLAwbN++/baLw4mIiKjp4X2a6kh93qeJiIiI6kdN3r95TRMRERGRGViaiIiIiMzA0kRERERkBpYmIiIiIjOwNBERERGZgaWJiIiIyAwsTURERERmYGkiIiIiMgNLExEREZEZ+DUqdeTWjdX1er3ESYiIiMhct963zfmCFJamOlJYWAgA8PHxkTgJERER1VRhYSE0Gs1dx/C75+qI0WjE1atX4eTkBJlMVqfb1uv18PHxQVZWFr/XzgLweFgWHg/LwuNheXhM7k4IgcLCQnh5eUEuv/tVSzzTVEfkcjm8vb3rdR9qtZp/4C0Ij4dl4fGwLDwelofH5K/d6wzTLbwQnIiIiMgMLE1EREREZmBpsgIqlQozZsyASqWSOgqBx8PS8HhYFh4Py8NjUnd4ITgRERGRGXimiYiIiMgMLE1EREREZmBpIiIiIjIDSxMRERGRGViaLNzSpUvRqlUr2NnZITIyEocPH5Y6ksWbPXs2HnjgATg5OcHd3R39+/dHZmZmtTFlZWWIj4+Hq6srHB0dMWDAAOTk5FQbc+nSJfTr1w8ODg5wd3fHpEmTUFVVVW3Mnj17EBERAZVKhYCAAKxYseK2PPc6huZkaUzmzJkDmUyGcePGmZbxeDSsK1eu4Pnnn4erqyvs7e0REhKCo0ePmtYLITB9+nR4enrC3t4e0dHROH36dLVt5OfnY+jQoVCr1XB2dsbIkSNRVFRUbczx48fRs2dP2NnZwcfHB3Pnzr0ty/r16xEUFAQ7OzuEhIRg69at1dabk8WaGQwGTJs2Df7+/rC3t0ebNm3w3nvvVfseNB4PCyLIYq1Zs0YolUrxr3/9S6Snp4uXXnpJODs7i5ycHKmjWbSYmBjx9ddfi7S0NHHs2DHRt29f4evrK4qKikxjXnnlFeHj4yN27doljh49Krp16yYefPBB0/qqqirRsWNHER0dLZKTk8XWrVuFm5ubmDp1qmnMuXPnhIODg5gwYYI4ceKEWLx4sVAoFGL79u2mMeYcw3tlaUwOHz4sWrVqJTp16iTGjh1rWs7j0XDy8/OFn5+feOGFF0RCQoI4d+6c2LFjhzhz5oxpzJw5c4RGoxEbN24UKSkp4qmnnhL+/v6itLTUNObxxx8XoaGh4tChQ2Lv3r0iICBAxMbGmtbrdDqh1WrF0KFDRVpamli9erWwt7cXn332mWnM/v37hUKhEHPnzhUnTpwQb7/9trC1tRWpqak1ymLNPvjgA+Hq6io2b94szp8/L9avXy8cHR3FwoULTWN4PCwHS5MF69q1q4iPjzc9NhgMwsvLS8yePVvCVNYnNzdXABC//vqrEEKIgoICYWtrK9avX28ak5GRIQCIgwcPCiGE2Lp1q5DL5SI7O9s0ZtmyZUKtVovy8nIhhBCTJ08WHTp0qLavwYMHi5iYGNPjex1Dc7I0FoWFhSIwMFDs3LlTPPzww6bSxOPRsN544w3Ro0ePv1xvNBqFh4eH+Oijj0zLCgoKhEqlEqtXrxZCCHHixAkBQBw5csQ0Ztu2bUImk4krV64IIYT49NNPhYuLi+n43Np3u3btTI8HDRok+vXrV23/kZGR4uWXXzY7i7Xr16+fePHFF6ste/bZZ8XQoUOFEDwelobTcxaqoqICiYmJiI6ONi2Ty+WIjo7GwYMHJUxmfXQ6HQCgefPmAIDExERUVlZWe22DgoLg6+trem0PHjyIkJAQaLVa05iYmBjo9Xqkp6ebxvxxG7fG3NqGOcfQnCyNRXx8PPr163fba8bj0bB+/PFHdOnSBQMHDoS7uzvCw8PxxRdfmNafP38e2dnZ1V4DjUaDyMjIasfD2dkZXbp0MY2Jjo6GXC5HQkKCacxDDz0EpVJpGhMTE4PMzEzcvHnTNOZux8ycLNbuwQcfxK5du3Dq1CkAQEpKCvbt24c+ffoA4PGwNPzCXguVl5cHg8FQ7U0CALRaLU6ePClRKutjNBoxbtw4dO/eHR07dgQAZGdnQ6lUwtnZudpYrVaL7Oxs05g7vfa31t1tjF6vR2lpKW7evHnPY2hOlsZgzZo1SEpKwpEjR25bx+PRsM6dO4dly5ZhwoQJePPNN3HkyBGMGTMGSqUSw4cPNz3PO71Of3yt3d3dq623sbFB8+bNq43x9/e/bRu31rm4uPzlMfvjNu6VxdpNmTIFer0eQUFBUCgUMBgM+OCDDzB06FAA5r0GPB4Nh6WJGrX4+HikpaVh3759UkdpsrKysjB27Fjs3LkTdnZ2Usdp8oxGI7p06YJZs2YBAMLDw5GWlobly5dj+PDhEqdretatW4eVK1di1apV6NChA44dO4Zx48bBy8uLx8MCcXrOQrm5uUGhUNz2qZ2cnBx4eHhIlMq6jBo1Cps3b8Yvv/wCb29v03IPDw9UVFSgoKCg2vg/vrYeHh53fO1vrbvbGLVaDXt7e7OOoTlZrF1iYiJyc3MREREBGxsb2NjY4Ndff8WiRYtgY2MDrVbL49GAPD09ERwcXG1Z+/btcenSJQD//3re63XKzc2ttr6qqgr5+fl1csz+uP5eWazdpEmTMGXKFAwZMgQhISEYNmwYxo8fj9mzZwPg8bA0LE0WSqlUonPnzti1a5dpmdFoxK5duxAVFSVhMssnhMCoUaPwww8/YPfu3bedku7cuTNsbW2rvbaZmZm4dOmS6bWNiopCampqtb+Idu7cCbVabXrDiYqKqraNW2NubcOcY2hOFmvXq1cvpKam4tixY6afLl26YOjQoab/5vFoON27d7/tFhynTp2Cn58fAMDf3x8eHh7VXgO9Xo+EhIRqx6OgoACJiYmmMbt374bRaERkZKRpzG+//YbKykrTmJ07d6Jdu3ZwcXExjbnbMTMni7UrKSmBXF79rVihUMBoNALg8bA4Ul+JTn9tzZo1QqVSiRUrVogTJ06If/7zn8LZ2bnaJ4jodq+++qrQaDRiz5494tq1a6afkpIS05hXXnlF+Pr6it27d4ujR4+KqKgoERUVZVp/6yPuvXv3FseOHRPbt28XLVq0uONH3CdNmiQyMjLE0qVL7/gR93sdw3tlaYz++Ok5IXg8GtLhw4eFjY2N+OCDD8Tp06fFypUrhYODg/j2229NY+bMmSOcnZ3Fpk2bxPHjx8XTTz99x4+4h4eHi4SEBLFv3z4RGBhY7SPuBQUFQqvVimHDhom0tDSxZs0a4eDgcNtH3G1sbMS8efNERkaGmDFjxh0/4n6vLNZs+PDhomXLlqZbDmzYsEG4ubmJyZMnm8bweFgOliYLt3jxYuHr6yuUSqXo2rWrOHTokNSRLB6AO/58/fXXpjGlpaXitddeEy4uLsLBwUE888wz4tq1a9W2c+HCBdGnTx9hb28v3NzcxMSJE0VlZWW1Mb/88osICwsTSqVStG7duto+brnXMTQnS2Pz59LE49GwfvrpJ9GxY0ehUqlEUFCQ+Pzzz6utNxqNYtq0aUKr1QqVSiV69eolMjMzq425ceOGiI2NFY6OjkKtVosRI0aIwsLCamNSUlJEjx49hEqlEi1bthRz5sy5Lcu6detE27ZthVKpFB06dBBbtmypcRZrptfrxdixY4Wvr6+ws7MTrVu3Fm+99Va1WwPweFgOmRB/uO0oEREREd0Rr2kiIiIiMgNLExEREZEZWJqIiIiIzMDSRERERGQGliYiIiIiM7A0EREREZmBpYmIiIjIDCxNREQAXnjhBfTv31/qGERkwWykDkBEVN9kMtld18+YMQMLFy4E7/VLRHfD0kREjd61a9dM/7127VpMnz692pfWOjo6wtHRUYpoRGRFOD1HRI2eh4eH6Uej0UAmk1Vb5ujoeNv03COPPILRo0dj3LhxcHFxgVarxRdffIHi4mKMGDECTk5OCAgIwLZt26rtKy0tDX369IGjoyO0Wi2GDRuGvLy8Bn7GRFQfWJqIiP7CN998Azc3Nxw+fBijR4/Gq6++ioEDB+LBBx9EUlISevfujWHDhqGkpAQAUFBQgEcffRTh4eE4evQotm/fjpycHAwaNEjiZ0JEdYGliYjoL4SGhuLtt99GYGAgpk6dCjs7O7i5ueGll15CYGAgpk+fjhs3buD48eMAgCVLliA8PByzZs1CUFAQwsPD8a9//Qu//PILTp06JfGzIaL7xWuaiIj+QqdOnUz/rVAo4OrqipCQENMyrVYLAMjNzQUApKSk4Jdffrnj9VFnz55F27Zt6zkxEdUnliYior9ga2tb7bFMJqu27Nan8oxGIwCgqKgITz75JD788MPbtuXp6VmPSYmoIbA0ERHVkYiICHz//fdo1aoVbGz41ytRY8NrmoiI6kh8fDzy8/MRGxuLI0eO4OzZs9ixYwdGjBgBg8EgdTwiuk8sTUREdcTLywv79++HwWBA7969ERISgnHjxsHZ2RlyOf+6JbJ2MsFb4BIRERHdE//pQ0RERGQGliYiIiIiM7A0EREREZmBpYmIiIjIDCxNRERERGZgaSIiIiIyA0sTERERkRlYmoiIiIjMwNJEREREZAaWJiIiIiIzsDQRERERmYGliYiIiMgM/wcBdi++9nhAjgAAAABJRU5ErkJggg==\n",
            "text/plain": [
              "<Figure size 640x480 with 1 Axes>"
            ]
          },
          "metadata": {},
          "output_type": "display_data"
        }
      ],
      "source": [
        "plot_results(np.cumsum(0.8-np.array(reward_record_avg)), ' ', 'LC-LUCB', 'Time', 'Regret')"
      ]
    }
  ],
  "metadata": {
    "colab": {
      "provenance": []
    },
    "kernelspec": {
      "display_name": "Python 3",
      "name": "python3"
    },
    "language_info": {
      "name": "python"
    }
  },
  "nbformat": 4,
  "nbformat_minor": 0
}