{
  "nbformat": 4,
  "nbformat_minor": 0,
  "metadata": {
    "colab": {
      "name": "Experiments_many_opt.ipynb",
      "provenance": [],
      "collapsed_sections": []
    },
    "kernelspec": {
      "display_name": "Python 3",
      "name": "python3"
    },
    "language_info": {
      "name": "python"
    }
  },
  "cells": [
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "FUnY5bH0tFaD"
      },
      "source": [
        "# Infinite Bandits"
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "id": "HyT846fjDF9K"
      },
      "source": [
        "import numpy as np \n",
        "\n",
        "class InfBandits:\n",
        "  #infinite armed bandits, takes in argument a function to sample\n",
        "  #the mean and the proportion of best arm and the best mean\n",
        "  def __init__(self, sample_mean, p_best, mu_best):\n",
        "    self._sample_mean = sample_mean\n",
        "    self._p_best = p_best\n",
        "    self._mu_best = mu_best\n",
        "    self.reset()\n",
        "  #reset the problem\n",
        "  def reset(self):\n",
        "    self.means = []\n",
        "    self.nb_sampled_arms = 0\n",
        "\n",
        "\n",
        "  #sample a mean for a new arm\n",
        "  def sample_mean(self):\n",
        "    return self._sample_mean()\n",
        "  \n",
        "  # opt arms proportion\n",
        "  @property\n",
        "  def p_best(self):\n",
        "    return self._p_best\n",
        "\n",
        "  # opt mean\n",
        "  @property\n",
        "  def mu_best(self):\n",
        "    return self._mu_best\n",
        "\n",
        "  # sample n arms from the reservoir and return the idxs range of the new arms\n",
        "  def sample_arms(self, n = 1):\n",
        "    idxs = [self.nb_sampled_arms,self.nb_sampled_arms+n-1]\n",
        "    self.nb_sampled_arms += n\n",
        "    for i in range(n):\n",
        "      self.means.append(self.sample_mean())\n",
        "    return idxs\n",
        "  \n",
        "  # sample arm k from the sampled arm\n",
        "  def sample(self, k):\n",
        "    assert k >= 0 and  k < self.nb_sampled_arms\n",
        "    return np.random.binomial(1, self.means[k])\n",
        "  \n",
        "  # get simple regret of arm k\n",
        "  def regret(self,k):\n",
        "    return self.mu_best-self.means[k]"
      ],
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "metadata": {
        "id": "zQ3ftAKZnbBA"
      },
      "source": [
        "# test\n",
        "means = np.array([ 0.2, 0.6, 0.8])\n",
        "probs = np.array([ 0.5, 0.4, 0.1])\n",
        "p_best = probs[-1]\n",
        "mu_best = means[-1] \n",
        "def sample_mean():\n",
        "  return np.random.choice(means, 1, p=probs)[0]\n",
        "bandits = InfBandits(sample_mean,p_best,mu_best)\n",
        "\n",
        "# bandits.sample_arms(3)\n",
        "# bandits.sample(2)\n",
        "\n"
      ],
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "m0A2Z-yTyM7w"
      },
      "source": [
        "# Regret\n"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "EJ7l257htLol"
      },
      "source": [
        "## Algos"
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "id": "PGSal1Y7d8A6"
      },
      "source": [
        "class SamplingUCB:\n",
        "  #same algorithm as the paper\n",
        "  #sample a fixed amount of arm then run ucb\n",
        "  # with bonuses sqrt((C_1 log(n) + C_2)/n)\n",
        "  def __init__(self, bandits):\n",
        "    self.bandits = bandits\n",
        "    \n",
        "  def reset_arms(self,L):\n",
        "    self.C_1 = 1\n",
        "    self.C_2 = 0.5**2/(8*(1-0.5))+np.log(np.pi**2/6)/2\n",
        "    self.pulls = np.zeros(L)\n",
        "    self.sample_means  = np.zeros(L)\n",
        "    self.UCBs =  np.ones(L)\n",
        "\n",
        "  def update(self,k,reward):\n",
        "    self.pulls[k] += 1\n",
        "    self.sample_means[k] += reward\n",
        "    self.UCBs[k] = self.sample_means[k]/self.pulls[k]+\\\n",
        "    ((self.C_1*np.log(self.pulls[k]) + self.C_2)/self.pulls[k])**0.5\n",
        "    \n",
        "\n",
        "  def run(self,T):\n",
        "    regrets =[]\n",
        "    L = int(min(np.ceil(np.log(T)/self.bandits.p_best),T))\n",
        "    bandits.sample_arms(L)\n",
        "    self.reset_arms(L)\n",
        "    for t in range(T):\n",
        "      if t < L:\n",
        "        k = t\n",
        "      else:\n",
        "        k = np.argmax(self.UCBs)\n",
        "      self.update(k,self.bandits.sample(k))\n",
        "      regrets += [self.bandits.regret(k)]\n",
        "\n",
        "    return np.array(regrets).cumsum()\n",
        "\n",
        "class QRM1:\n",
        "  #same as QRM1 algorithm in Quantile-Regret Minimisation in Infinitely Many-Armed Bandits\n",
        "  # by Chaudhuri and Kalyanakrishnan\n",
        "  def __init__(self, bandits):\n",
        "    self.bandits = bandits\n",
        "    self.reset_arms(1)\n",
        "  \n",
        "  def reset_arms(self,L):\n",
        "    self.pulls = np.zeros(L)\n",
        "    self.sample_means  = np.zeros(L)\n",
        "    self.UCBs =  np.ones(L)\n",
        "\n",
        "  def update(self,k,reward,T,L):\n",
        "    self.pulls[k] += 1\n",
        "    self.sample_means[k] += reward\n",
        "    self.UCBs[k] = self.sample_means[k]/self.pulls[k]+\\\n",
        "    (max(np.log(T/(1.0*L*self.pulls[k])),0)/self.pulls[k])**0.5\n",
        "\n",
        "  def run(self,T):\n",
        "    regrets =[]\n",
        "    r_max = int(np.log2(T)+1)\n",
        "    t = 0\n",
        "    for r in range(1,r_max):\n",
        "      TT = 2**r\n",
        "      L = int(np.floor(np.maximum(1,0.5*np.log(self.bandits.p_best*TT))/self.bandits.p_best))\n",
        "      L = min(TT,L)\n",
        "      self.reset_arms(L)\n",
        "      bandits.sample_arms(L-self.bandits.nb_sampled_arms)\n",
        "      for tt in range(TT):\n",
        "        if tt < L:\n",
        "          k = tt\n",
        "        else:\n",
        "          k = np.argmax(self.UCBs)\n",
        "        self.update(k,self.bandits.sample(k),TT,L)\n",
        "        regrets.append(self.bandits.regret(k))\n",
        "        t += 1\n",
        "        if t >= T: \n",
        "          return np.array(regrets).cumsum()\n",
        "    return \n",
        "\n",
        "\n",
        "class SR:\n",
        "  #same as Algorithm 2 in On Regret with Multiple Best Arms\n",
        "  # by Zhu and Nowak\n",
        "  def __init__(self, bandits):\n",
        "    self.bandits = bandits\n",
        "    self.reset_arms(1)\n",
        "\n",
        "\n",
        "  def reset_arms(self,L):\n",
        "    self.pulls = np.zeros(L)\n",
        "    self.sample_means  = np.zeros(L)\n",
        "    self.UCBs =  np.ones(L)    \n",
        "\n",
        "  def update(self,k,reward,T,L):\n",
        "    self.pulls[k] += 1\n",
        "    self.sample_means[k] += reward\n",
        "    self.UCBs[k] = self.sample_means[k]/self.pulls[k]+\\\n",
        "    (max(np.log(T/(1.0*L*self.pulls[k])),0)/self.pulls[k])**0.5\n",
        "    \n",
        "\n",
        "  def run(self,T):\n",
        "    regrets =[]\n",
        "    L = int(min(np.ceil(0.5*np.log(T)/self.bandits.p_best),T))\n",
        "    bandits.sample_arms(L)\n",
        "    self.reset_arms(L)\n",
        "    for t in range(T):\n",
        "      if t < L:\n",
        "        k = t\n",
        "      else:\n",
        "        k = np.argmax(self.UCBs)\n",
        "      self.update(k,self.bandits.sample(k),T,L)\n",
        "      regrets += [self.bandits.regret(k)]\n",
        "\n",
        "    return np.array(regrets).cumsum()\n",
        "  "
      ],
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "xy2kB_q1pYB0"
      },
      "source": [
        "## Plots"
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "0B5JDSh4JlML",
        "outputId": "6d9630d3-abf4-4fdf-f7e6-a851b0a4fe54"
      },
      "source": [
        "# fixed reservoir and T\n",
        "means = np.array([ 0.5, 0.8])\n",
        "probs = np.array([ 0.8, 0.2])\n",
        "p_best = probs[-1]\n",
        "mu_best = means[-1] \n",
        "def sample_mean():\n",
        "  return np.random.choice(means, 1, p=probs)[0]\n",
        "bandits = InfBandits(sample_mean,p_best,mu_best)\n",
        "\n",
        "T = 20000\n",
        "nb_mc = 500\n",
        "\n",
        "#algs\n",
        "algs = [SamplingUCB(bandits), QRM1(bandits), SR(bandits)]\n",
        "alg_names = ['SamplingUCB', 'QRM1', 'SR'] \n",
        "nb_alg = len(algs)\n",
        "regrets_avg = np.zeros((nb_alg,T))\n",
        "for idx, alg in enumerate(algs):\n",
        "  print(alg_names[idx])\n",
        "  for m in range(nb_mc):\n",
        "    bandits.reset()\n",
        "    regrets_avg[idx,:] += alg.run(T)\n",
        "  regrets_avg[idx,:] /= nb_mc"
      ],
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "SamplingUCB\n"
          ]
        },
        {
          "output_type": "error",
          "ename": "KeyboardInterrupt",
          "evalue": "ignored",
          "traceback": [
            "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
            "\u001b[0;31mKeyboardInterrupt\u001b[0m                         Traceback (most recent call last)",
            "\u001b[0;32m<ipython-input-4-46d01912b669>\u001b[0m in \u001b[0;36m<module>\u001b[0;34m()\u001b[0m\n\u001b[1;32m     20\u001b[0m   \u001b[0;32mfor\u001b[0m \u001b[0mm\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mrange\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mnb_mc\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     21\u001b[0m     \u001b[0mbandits\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mreset\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 22\u001b[0;31m     \u001b[0mregrets_avg\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0midx\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m]\u001b[0m \u001b[0;34m+=\u001b[0m \u001b[0malg\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mrun\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mT\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     23\u001b[0m   \u001b[0mregrets_avg\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0midx\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m]\u001b[0m \u001b[0;34m/=\u001b[0m \u001b[0mnb_mc\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;32m<ipython-input-3-252ec185da9b>\u001b[0m in \u001b[0;36mrun\u001b[0;34m(self, T)\u001b[0m\n\u001b[1;32m     25\u001b[0m     \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mreset_arms\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mL\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     26\u001b[0m     \u001b[0;32mfor\u001b[0m \u001b[0mt\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mrange\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mT\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 27\u001b[0;31m       \u001b[0;32mif\u001b[0m \u001b[0mt\u001b[0m \u001b[0;34m<\u001b[0m \u001b[0mL\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     28\u001b[0m         \u001b[0mk\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mt\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     29\u001b[0m       \u001b[0;32melse\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;31mKeyboardInterrupt\u001b[0m: "
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "id": "gGZgWowkpILw"
      },
      "source": [
        "import matplotlib.pyplot as plt\n",
        "plt.figure(figsize=(12, 8))\n",
        "times= np.array([t for t in range(T)])\n",
        "\n",
        "for regret, name in zip(regrets_avg, alg_names):\n",
        "  plt.plot(times, regret, label=name)\n",
        "plt.legend()\n",
        "plt.ylabel('regret')\n",
        "plt.xlabel('time')\n",
        "plt.grid()\n",
        "plt.show()"
      ],
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "metadata": {
        "colab": {
          "background_save": true
        },
        "id": "VYB3fInDX6j4"
      },
      "source": [
        "means = np.array([ 0.5, 0.8])\n",
        "probs = np.array([ 0.8, 0.2])\n",
        "p_best = probs[-1]\n",
        "mu_best = means[-1] \n",
        "def sample_mean():\n",
        "  return np.random.choice(means, 1, p=probs)[0]\n",
        "bandits = InfBandits(sample_mean,p_best,mu_best)\n",
        "\n",
        "nb_mc = 100\n",
        "Ts = list(range(100,10000,100))\n",
        "\n",
        "#algs\n",
        "algs = [SamplingUCB(bandits), QRM1(bandits), SR(bandits)]\n",
        "alg_names = ['SamplingUCB', 'QRM1', 'SR'] \n",
        "\n",
        "\n",
        "nb_alg = len(algs)\n",
        "regrets_avg = np.zeros((nb_alg,len(Ts)))\n",
        "for idx_T,T in enumerate(Ts):\n",
        "  print(T)\n",
        "  for idx, alg in enumerate(algs):\n",
        "    for m in range(nb_mc):\n",
        "      bandits.reset()\n",
        "      regrets_avg[idx,idx_T] += alg.run(T)[-1]\n",
        "    regrets_avg[idx,idx_T] /= nb_mc\n"
      ],
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 501
        },
        "id": "FrZJ8i_kaXd5",
        "outputId": "c5cbdf82-3e20-4bc2-a1ef-7dee1e3906d8"
      },
      "source": [
        "import matplotlib.pyplot as plt\n",
        "plt.figure(figsize=(12, 8))\n",
        "times= np.array([T for T in Ts])\n",
        "\n",
        "for regret, name in zip(regrets_avg, alg_names):\n",
        "  plt.plot(times, regret, label=name)\n",
        "#plt.plot(times, np.log(times)/(0.2*0.3), label=r'$\\log(T)/(p^\\star \\Delta)$')\n",
        "plt.legend()\n",
        "plt.ylabel('regret')\n",
        "plt.xlabel('horizon T')\n",
        "plt.xscale('log')\n",
        "plt.grid()\n",
        "plt.show()"
      ],
      "execution_count": null,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "image/png": "iVBORw0KGgoAAAANSUhEUgAAAtMAAAHkCAYAAAD8Y6O5AAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4yLjIsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy+WH4yJAAAgAElEQVR4nOzdeXxcdb3/8dc3k7VJ2rRJ95RudG9poS1QEAmgKIuAXPzhchUQRERwQ6/L1euCeuF61QsXr4qi4AJeb1mEoqAIUWQpXei+0L1N2zRbs28zk/P743tO5kzWSTKTSdL38/Ho45w5c+bMN0rzePPhcz7HOI6DiIiIiIj0XUqyFyAiIiIiMlwpTIuIiIiI9JPCtIiIiIhIPylMi4iIiIj0k8K0iIiIiEg/KUyLiIiIiPRTarIXMBAFBQXOjBkzkvLdDQ0NZGdnJ+W7RUQGSr/DRGQ4S8bvsA0bNlQ4jjO+4/FhHaZnzJjB+vXrk/LdxcXFFBUVJeW7RUQGSr/DRGQ4S8bvMGPMoa6Oq81DRERERKSfFKZFRERERPpJYVpEREREpJ+Gdc90V4LBICUlJTQ3Nyf0e8aMGcPOnTsT+h0jTWZmJoWFhaSlpSV7KSIiIiJxMeLCdElJCbm5ucyYMQNjTMK+p66ujtzc3IRdf6RxHIfKykpKSkqYOXNmspcjIiIiEhcjrs2jubmZ/Pz8hAZp6TtjDPn5+Qn/LwYiIiIig2nEhWlAQXqI0v8vIiIiMtKMyDA9FHznO99h0aJFnHHGGSxbtoy1a9cm7LuKiora521ffvnlVFdX9+s6Dz/8MHfccUe3166vr+fjH/84s2fPZvny5RQVFbX/XIFAgGXLlrF06VLOOussXn311QH8RCIiIiLDw4jrmR4KXnvtNdasWcPGjRvJyMigoqKC1tbWQfnuP/7xjwm79i233MLMmTPZs2cPKSkpHDhwgB07dgCQlZXFpk2bAHj++ef58pe/zN/+9reErUVERERkKFBlOgGOHz9OQUEBGRkZABQUFDBlyhS+9a1vsXLlShYvXsytt96K4ziArf5+9rOfZcWKFSxYsIB169Zx7bXXMmfOHL761a8CcPDgQebPn8+HPvQhFixYwHXXXUdjY2On754xYwYVFRUcPHiQBQsW8LGPfYxFixZx6aWX0tTUBMC6devaK+Zf+MIXWLx4ca8/0759+1i7di3f/va3SUmx/9jMnDmTK664otO5tbW1jB07tn//44mIiIgMIwrTCXDppZdy5MgR5s6dy+23395eob3jjjtYt24d27Zto6mpiTVr1rR/Jj09nfXr13Pbbbdx9dVX86Mf/Yht27bx8MMPU1lZCcDu3bu5/fbb2blzJ6NHj+Z//ud/elzHnj17+OQnP8n27dvJy8vj8ccfB+Cmm27ipz/9KZs2bSIQCMT0M23fvp1ly5Z1e35TUxPLli1j/vz53HLLLXzta1+L6boiIiIiw9mIbvP45jPb2XGsNq7XXDhlNF9/z6Iez8nJyWHDhg28/PLLvPTSS1x//fXcc8895Obm8h//8R80NjZSVVXFokWLeM973gPAVVddBcCSJUtYtGgRkydPBmDWrFkcOXKEvLw8pk2bxvnnnw/AP//zP3P//ffz+c9/vtt1zJw5k2XLlgGwfPlyDh48SHV1NXV1daxatQqAD37wg+2hvrsbBGO5cdDf5vHaa6/xkY98hG3btummQxERERnRRnSYTqZAIEBRURFFRUUsWbKEn/70p2zZsoX169czbdo0vvGNb0SNifNaQlJSUtr3vdehUAjoHGp7C6r+6wQCgfY2j+7k5+dz8uTJqGNVVVUUFBSQl5fH5s2bCYfDvVazV61aRUVFBeXl5UyYMKHHc0VERESGsxEdpnurICfK7t27SUlJYc6cOQBs2rSJefPmsWXLFgoKCqivr2f16tVcd911fbru4cOHee2111i1ahWPPvoob3vb2/q8try8PHJzc1m7di3nnHMOv/vd79rfW7lyJXfccQelpaVMmjSJ9evX09LSwrRp00hJSWHFihV8/etf5+6778YYw8GDB9m+fXunvuldu3YRDofJz8/v8/pEREREhpMRHaaTpb6+njvvvJPq6mpSU1M5/fTTefDBB8nLy2Px4sVMmjSJlStX9vm68+bN40c/+hEf/ehHWbhwIZ/4xCf6tb6HHnqIj33sY6SkpHDhhRcyZswYACZOnMh9993H5ZdfTltbGzk5OTz22GPtNxz+/Oc/56677uL0008nKyuLgoICvve97wGRnmmwTzt85JFHYu7HFhERERmujDdRYjhasWKF481A9uzcuZMFCxYk/LsH+3HiBw8e5Morr2Tbtm0DvlZ9fT05OTkA3HPPPRw/fpz77rtvwNeNxWD9/yMiPSsuLqaoqCjZyxAR6Zdk/A4zxmxwHGdFx+OqTJ+Cnn32Wf793/+dUCjE9OnTefjhh5O9JBEREZFhSWF6mJgxY0ZcqtIA119/Pddff31criUiIiKnsFAr/P7DcNFXYPLSZK8mKTRnWkRERET6p6Ec3noOjryR7JUkjcK0iIiIiPRPuNVu20LJXUcSKUyLiIiISP94ITocTO46kkhhWkRERET6p70yrTAtcVZSUsLVV1/NnDlzmDVrFnfccQctLS0UFxczZswYli1bxvz586MeB/7www9jjOGFF15oP/bUU09hjGH16tUAPPDAA5x++ukYY6ioqBj0n0tERESknVeRbgsndx1JpDCdAI7jcO2113LNNdewZ88e9uzZQ1NTE//yL/8CwAUXXMCmTZt48803WbNmDa+88kr7Z5csWRL1VMLHHnuMpUsjd8eef/75vPDCC0yfPn3wfiARERGRrqjNQ6PxEuHFF18kMzOTm266CYBAIMAPf/hDpk+fzjvf+c7287Kysli2bBlHjx5tP3bBBRfw8ssvEwwGaWlpYe/eve1PFgQ488wzB+8HEREREemJ2jwUphNh+/btLF++POrY6NGjmTFjBnv37m0/dvLkSfbs2cPb3/729mPGGN7xjnfw/PPPU1NTw1VXXcWBAwcGbe0iIiIiMWtv8zh1p3mM7DD9py9B6db4XnPSErjsngFd4uWXX2bp0qXs2bOHz3zmM0yaNCnq/fe///3cf//91NTU8P3vf5/vfve7A/o+ERERkYTwwnT41A3T6plOgIULF7Jhw4aoY7W1tZSWljJv3jwuuOACNm/ezPbt23nooYfYtGlT1Llnn302W7dupaKigrlz5w7m0kVERERi57V3qM1jhBpgBbm/LrnkEr70pS/xq1/9io985COEw2Huuusu7rjjDrKystrPmzlzJl/60pe49957eeyxx6Kucc8995CZmTnYSxcRERGJnR7aosp0IhhjePLJJ1m9ejVz5swhPz+flJQU/vVf/7XTubfddht///vfOXjwYNTxyy67jIsuuqjT+ffffz+FhYWUlJRwxhlncMsttyTqxxARERHpmdo8RnhlOommTZvG008/DcCrr77KBz7wATZu3EhRURFFRUXt52VlZbVP87jxxhu58cYbO13r4Ycfbt//1Kc+xac+9alELl1EREQkNmG1eShMD4LzzjuPQ4cOJXsZIiIiIvHVNojTPI69CRV7YOE1if+uPlCbh4iIiIj0T3ubxyBUpreuhqfvhJRA4r+rDxSmRURERKR/BnPOdPkuKJijMC0iIiIiI8RgtnmU7YLxCxL/PX2kMC0iIiIi/eONxotHm8fW1bD7ua7fa66F2hKYMH/g3xNnugFRRERERPrHG4kXj8r0yz+AnPEw792d3yvfbbeqTJ86vvOd77Bo0SLOOOMMli1bxtq1aykqKmLevHksXbqUlStXdnryoYiIiMiw0teHthzd2H0Vu7UOWhu6fq98p90Owcq0wnQCvPbaa6xZs4aNGzeyZcsWXnjhBaZNmwbAb3/7WzZv3sztt9/OF77whSSvVERERGQA2vowzaO+DH52MWx/quv3W+q7D9NluyA1C/Jm9GuZiaQwnQDHjx+noKCAjIwMAAoKCpgyZUrUOatWrWp/WIuIiIjIsNSXh7Y01wIONFZ2/X5rvf3TlfKdMH4upAy96Dr0VjQCXHrppRw5coS5c+dy++2387e//a3TOc899xzXXDO0ho6LiIiI9ElfHicebrHbYBfV51CrbRlp6SZMV+yBgnn9W2OCjegbEO994152Ve2K6zXnj5vPF8/+Yo/n5OTksGHDBl5++WVeeuklrr/+eu655x4APvShD9Ha2kp9fb16pkVERGR468tovJAXppugqRp+8ja47pcwbWWkIt1Vm0c4CLVHYeyMuCw53lSZTpBAIEBRURHf/OY3eeCBB3j88ccB2zO9f/9+brjhBu68884kr1JERERkAPrS5uHdrBhssuG45giUbrHHWurcc1o691/XHgWnDfJOi8+a42xEV6Z7qyAnyu7du0lJSWHOnDkAbNq0ienTp7Nt2zYAjDHcfffdzJ49m127djF//tC7M1VERESkV31p8/Aq060N0Npo95tr3GO+9o7WesgaG3l98pDdDtEwrcp0AtTX13PDDTewcOFCzjjjDHbs2ME3vvGNqHOysrK46667+N73vpecRYqIiIgMVF9G4/kr017fdEutu/WH6Q6tHtWH7Xbs9P6vM4FGdGU6WZYvX86rr77a6XhxcXHU67vuumuQViQiIiKSAF6IjqXNo71nujESmNsr03WR87oK0yYFRk8d2FoTRJVpEREREemfvjxOPOwP016bRxeV6Y4TPaoP2yAdSBvYWhNEYVpERERE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\n",
            "text/plain": [
              "<Figure size 864x576 with 1 Axes>"
            ]
          },
          "metadata": {
            "tags": []
          }
        }
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "6Y1gO6MuyfAb"
      },
      "source": [
        "#BAI"
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "id": "hAghJXGOKLqz"
      },
      "source": [
        "\n",
        "# class Elimination:\n",
        "#   def __init__(self, bandits, T, epsilon):\n",
        "#     self.epsilon = epsilon\n",
        "#   def run(self):\n",
        "#     bandits.sample_arms(T//4)\n",
        "#     means = np.array(bandits.means)\n",
        "#     i = 1\n",
        "#     l=0\n",
        "#     while l < T:\n",
        "#       if len(means) <= 1:\n",
        "#         break\n",
        "#       t = max(int(T*epsilon/(8*len(means)*i**(1+epsilon))),1)\n",
        "#       sample_means  = np.random.binomial(t,means).astype(np.float)/t\n",
        "#       l = l + len(means)*t\n",
        "#       i = i + 1\n",
        "#       sort = np.argsort(sample_means)\n",
        "#       sample_means = np.sort(sample_means)\n",
        "#       means = means[sort]\n",
        "#       means = means[len(means)//2+1:]\n",
        "#       bandits.means = []\n",
        "#       bandits.sample_arms(len(means)//2)\n",
        "#       means = np.concatenate((means,np.array(bandits.means)))\n",
        "#     S = means[0]\n",
        "#     if S == mu_best:\n",
        "#       return 1\n",
        "#     else:\n",
        "#       return 0\n",
        "\n",
        "class Elimination:\n",
        "  def __init__(self, bandits, T, epsilon):\n",
        "    self.epsilon = epsilon\n",
        "  def run(self):\n",
        "    bandits.sample_arms(T//4)\n",
        "    means = np.array(bandits.means)\n",
        "    l=0\n",
        "    while l < T:\n",
        "      if len(means) <= 1:\n",
        "        break\n",
        "      t = max(int(np.log(4/3)*T/(len(means)*np.log(T))),1)\n",
        "      sample_means  = np.random.binomial(t,means).astype(np.float)/t\n",
        "      l = l + len(means)*t\n",
        "      sort = np.argsort(sample_means)\n",
        "      sample_means = np.sort(sample_means)\n",
        "      means = means[sort]\n",
        "      means = means[len(means)//2+1:]\n",
        "      bandits.means = []\n",
        "      bandits.sample_arms(len(means)//2)\n",
        "      means = np.concatenate((means,np.array(bandits.means)))\n",
        "    S = means[0]\n",
        "    if S == mu_best:\n",
        "      return 1\n",
        "    else:\n",
        "      return 0\n",
        "  \n",
        "\n"
      ],
      "execution_count": 31,
      "outputs": []
    },
    {
      "cell_type": "code",
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "tOjndwVxXP4X",
        "outputId": "4922aa55-2b6a-4005-b1f8-5264fe89ba0c"
      },
      "source": [
        "T=1000\n",
        "epsilon = 0.2\n",
        "means = np.array([0.2,0.8])\n",
        "probs = np.array([0.999,0.001])\n",
        "mu_best = means[-1]\n",
        "p_best = probs[-1]\n",
        "def sample_mean():\n",
        "  return np.random.choice(means, 1, p=probs)[0]\n",
        "bandits = InfBandits(sample_mean,p_best,mu_best)\n",
        "Alg = Elimination(bandits,T,epsilon)\n",
        "Alg.run()\n"
      ],
      "execution_count": null,
      "outputs": [
        {
          "output_type": "error",
          "ename": "TypeError",
          "evalue": "ignored",
          "traceback": [
            "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
            "\u001b[0;31mTypeError\u001b[0m                                 Traceback (most recent call last)",
            "\u001b[0;32m<ipython-input-7-89972325eec5>\u001b[0m in \u001b[0;36m<module>\u001b[0;34m()\u001b[0m\n\u001b[1;32m      8\u001b[0m   \u001b[0;32mreturn\u001b[0m \u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mrandom\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mchoice\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mmeans\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;36m1\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mp\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mprobs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;36m0\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      9\u001b[0m \u001b[0mbandits\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mInfBandits\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0msample_mean\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0mp_best\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0mmu_best\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 10\u001b[0;31m \u001b[0mAlg\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mElimination\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mbandits\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0mT\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0mepsilon\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     11\u001b[0m \u001b[0mAlg\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mrun\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;31mTypeError\u001b[0m: Elimination() takes no arguments"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "id": "CF-z7Ax7al8B"
      },
      "source": [
        "#jamieson\n",
        "class InfUCB:\n",
        "  def __init__(self, bandits, T, delta):\n",
        "    self.pulls = []\n",
        "    self.brackets = []\n",
        "    self.sample_means = []\n",
        "    self.UCBs = [1]\n",
        "    self.LCBs =  [1]\n",
        "    self.delta  = delta\n",
        "    self.t = 0\n",
        "  def newbrac(self,l):\n",
        "    bandits.sample_arms(2**l)\n",
        "    self.brackets.append(np.array(bandits.means))\n",
        "    self.pulls.append(np.zeros(2**l)) \n",
        "    self.sample_means.append(np.zeros(2**l)) \n",
        "    bandits.means = []\n",
        "    self.UCBs.append(np.zeros(2**l)) \n",
        "    self.LCBs.append(np.zeros(2**l))  \n",
        "\n",
        "  def ucb(self,r):\n",
        "    if np.any(self.pulls[r] == 0):\n",
        "      k = int(np.where(self.pulls[r] == 0)[0][0])\n",
        "      self.sample_means[r][k] = np.random.binomial(2, self.brackets[r][k])\n",
        "      self.pulls[r][k] = 2\n",
        "      # self.t = self.t + 1\n",
        "      \n",
        "      self.UCBs[r][k] = self.sample_means[r][k]/self.pulls[r][k]+\\\n",
        "      (0.5*np.log(np.log(self.pulls[r][k])/self.delta)/self.pulls[r][k])**0.5\n",
        "      self.LCBs[r][k] = self.sample_means[r][k]/self.pulls[r][k]-\\\n",
        "      (0.5*(np.log(max(1,2**r * r**2) * np.log(self.pulls[r][k])/self.delta))/self.pulls[r][k])**0.5\n",
        "\n",
        "    else:\n",
        "      k = np.argmax(self.UCBs[r])\n",
        "      self.sample_means[r][k] += np.random.binomial(1,self.brackets[r][k])\n",
        "      self.pulls[r][k] += 1\n",
        "      # self.t = self.t +1\n",
        "      \n",
        "      self.UCBs[r][k] = self.sample_means[r][k]/self.pulls[r][k]+\\\n",
        "      (0.5*np.log(np.log(self.pulls[r][k])/self.delta)/self.pulls[r][k])**0.5\n",
        "      self.LCBs[r][k] = self.sample_means[r][k]/self.pulls[r][k]-\\\n",
        "      (0.5*np.log(max(1,2**r * r**2) * np.log(self.pulls[r][k])/self.delta)/self.pulls[r][k])**0.5\n",
        "\n",
        "  def run(self):\n",
        "    bandits.sample_arms(1)\n",
        "    self.brackets = [np.array([0]),np.array(bandits.means)]\n",
        "    self.sample_means = [np.array([0]),[np.random.binomial(1, self.brackets[1][0])]]\n",
        "    self.pulls = [[np.array([0])],[np.array([0])]]\n",
        "    self.UCBs = [[np.array([0])],[np.array([0])]]\n",
        "    self.LCBs = [[np.array([0])],[np.array([0])]]\n",
        "    l=1\n",
        "    r = 0\n",
        "    t=0\n",
        "    while t < T:\n",
        "      if t >= l*2**l:\n",
        "        self.newbrac(l)\n",
        "        l= l+1\n",
        "      if r == l:\n",
        "        r = 0\n",
        "      r = r + 1\n",
        "      \n",
        "      self.ucb(r)\n",
        "\n",
        "      t = t+1\n",
        "    maxes = [max(i) for i in self.LCBs]\n",
        "    S =  self.brackets[np.argmax(maxes)][np.argmax(self.LCBs[np.argmax(maxes)])]\n",
        "    if S == mu_best:\n",
        "      return 1\n",
        "    else:\n",
        "      return 0\n",
        "\n",
        "    # return self.pulls\n",
        "    "
      ],
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "metadata": {
        "id": "-Ta-vu2mmeUG",
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "outputId": "6d91a107-3233-48e3-9a94-7a572442fe04"
      },
      "source": [
        "T=1000\n",
        "gap = 0.2\n",
        "delta = np.exp(-T*p_best*gap**2 / (np.log(1/(p_best*gap**2) * np.log(T*p_best*gap**2)) ))\n",
        "print(delta)\n",
        "means = np.array([0.73,0.73,0.8])\n",
        "probs = np.array([0.4,0.4,0.2])\n",
        "mu_best = means[-1]\n",
        "p_best = probs[-1]\n",
        "def sample_mean():\n",
        "  return np.random.choice(means, 1, p=probs)[0]\n",
        "bandits = InfBandits(sample_mean,p_best,mu_best)\n",
        "InfUCB(bandits,T,delta).run()\n"
      ],
      "execution_count": 32,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "nan\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "/usr/local/lib/python3.7/dist-packages/ipykernel_launcher.py:3: RuntimeWarning: invalid value encountered in log\n",
            "  This is separate from the ipykernel package so we can avoid doing imports until\n",
            "/usr/local/lib/python3.7/dist-packages/numpy/core/_asarray.py:83: VisibleDeprecationWarning: Creating an ndarray from ragged nested sequences (which is a list-or-tuple of lists-or-tuples-or ndarrays with different lengths or shapes) is deprecated. If you meant to do this, you must specify 'dtype=object' when creating the ndarray\n",
            "  return array(a, dtype, copy=False, order=order)\n"
          ]
        },
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "0"
            ]
          },
          "metadata": {},
          "execution_count": 32
        }
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "id": "HKWzF52thjn4",
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "outputId": "12cdd489-d2ae-4346-cec6-89cf825ab545"
      },
      "source": [
        "#Comparison algos means slope\n",
        "\n",
        "# setting\n",
        "\n",
        "T = 1000\n",
        "nb_mc = 500\n",
        "epsilon = 0.5\n",
        "gaps = [0.01*i +0.02  for i in range(1,80)]\n",
        "regrets_avg = np.zeros((len(gaps),2))\n",
        "for i in range(len(gaps)):\n",
        "  means = np.array([ 0.2, gaps[i], 1])\n",
        "  probs = np.array([ 0.29, 0.69, 0.02])\n",
        "  p_best = probs[-1]\n",
        "  mu_best = means[-1] \n",
        "  gap = mu_best - gaps[i]\n",
        "  delta = np.exp(-T*p_best*gap**2 / (np.log(1/(p_best*gap**2) * np.log(T*p_best*gap**2)) ))\n",
        "  delta = 0.01\n",
        "  def sample_mean():\n",
        "    return np.random.choice(means, 1, p=probs)[0]\n",
        "\n",
        "  bandits = InfBandits(sample_mean,p_best,mu_best)\n",
        "\n",
        "  for m in range(nb_mc):\n",
        "    bandits.reset()\n",
        "    regrets_avg[i,0] += InfUCB(bandits,T,delta).run()\n",
        "  regrets_avg[i,0] /= nb_mc\n",
        "\n",
        "  for m in range(nb_mc):\n",
        "    bandits.reset()\n",
        "    regrets_avg[i,1] += Elimination(bandits,T,epsilon).run()\n",
        "  regrets_avg[i,1] /= nb_mc\n",
        "\n",
        "regrets_avg"
      ],
      "execution_count": 34,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "/usr/local/lib/python3.7/dist-packages/ipykernel_launcher.py:36: RuntimeWarning: divide by zero encountered in log\n",
            "/usr/local/lib/python3.7/dist-packages/ipykernel_launcher.py:36: RuntimeWarning: invalid value encountered in sqrt\n",
            "/usr/local/lib/python3.7/dist-packages/ipykernel_launcher.py:37: RuntimeWarning: divide by zero encountered in log\n",
            "/usr/local/lib/python3.7/dist-packages/ipykernel_launcher.py:37: RuntimeWarning: invalid value encountered in sqrt\n",
            "/usr/local/lib/python3.7/dist-packages/numpy/core/_asarray.py:83: VisibleDeprecationWarning: Creating an ndarray from ragged nested sequences (which is a list-or-tuple of lists-or-tuples-or ndarrays with different lengths or shapes) is deprecated. If you meant to do this, you must specify 'dtype=object' when creating the ndarray\n",
            "  return array(a, dtype, copy=False, order=order)\n",
            "/usr/local/lib/python3.7/dist-packages/ipykernel_launcher.py:16: RuntimeWarning: invalid value encountered in log\n",
            "  app.launch_new_instance()\n"
          ]
        },
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "array([[0.896, 0.996],\n",
              "       [0.916, 0.998],\n",
              "       [0.922, 1.   ],\n",
              "       [0.926, 1.   ],\n",
              "       [0.898, 0.998],\n",
              "       [0.926, 0.996],\n",
              "       [0.92 , 0.998],\n",
              "       [0.908, 1.   ],\n",
              "       [0.898, 0.998],\n",
              "       [0.92 , 1.   ],\n",
              "       [0.928, 1.   ],\n",
              "       [0.9  , 1.   ],\n",
              "       [0.918, 0.998],\n",
              "       [0.88 , 1.   ],\n",
              "       [0.936, 1.   ],\n",
              "       [0.916, 0.998],\n",
              "       [0.918, 1.   ],\n",
              "       [0.872, 1.   ],\n",
              "       [0.91 , 1.   ],\n",
              "       [0.908, 0.998],\n",
              "       [0.854, 0.998],\n",
              "       [0.886, 1.   ],\n",
              "       [0.884, 0.998],\n",
              "       [0.874, 0.998],\n",
              "       [0.826, 0.998],\n",
              "       [0.82 , 0.998],\n",
              "       [0.812, 1.   ],\n",
              "       [0.806, 1.   ],\n",
              "       [0.762, 1.   ],\n",
              "       [0.772, 1.   ],\n",
              "       [0.758, 0.998],\n",
              "       [0.724, 0.998],\n",
              "       [0.726, 0.998],\n",
              "       [0.716, 1.   ],\n",
              "       [0.7  , 1.   ],\n",
              "       [0.726, 0.996],\n",
              "       [0.712, 1.   ],\n",
              "       [0.686, 0.994],\n",
              "       [0.732, 1.   ],\n",
              "       [0.72 , 0.998],\n",
              "       [0.722, 1.   ],\n",
              "       [0.722, 1.   ],\n",
              "       [0.732, 1.   ],\n",
              "       [0.696, 0.998],\n",
              "       [0.726, 0.998],\n",
              "       [0.718, 0.998],\n",
              "       [0.644, 0.998],\n",
              "       [0.692, 0.992],\n",
              "       [0.66 , 0.998],\n",
              "       [0.708, 0.996],\n",
              "       [0.672, 0.99 ],\n",
              "       [0.686, 0.992],\n",
              "       [0.648, 0.992],\n",
              "       [0.652, 0.988],\n",
              "       [0.63 , 0.982],\n",
              "       [0.606, 0.98 ],\n",
              "       [0.568, 0.97 ],\n",
              "       [0.58 , 0.97 ],\n",
              "       [0.502, 0.962],\n",
              "       [0.49 , 0.954],\n",
              "       [0.54 , 0.942],\n",
              "       [0.464, 0.904],\n",
              "       [0.524, 0.89 ],\n",
              "       [0.472, 0.876],\n",
              "       [0.436, 0.822],\n",
              "       [0.416, 0.83 ],\n",
              "       [0.468, 0.78 ],\n",
              "       [0.458, 0.708],\n",
              "       [0.412, 0.674],\n",
              "       [0.386, 0.692],\n",
              "       [0.41 , 0.624],\n",
              "       [0.328, 0.6  ],\n",
              "       [0.328, 0.536],\n",
              "       [0.292, 0.536],\n",
              "       [0.242, 0.476],\n",
              "       [0.268, 0.47 ],\n",
              "       [0.264, 0.398],\n",
              "       [0.264, 0.382],\n",
              "       [0.212, 0.318]])"
            ]
          },
          "metadata": {},
          "execution_count": 34
        }
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 497
        },
        "id": "ZX4dPEw_Meoz",
        "outputId": "552c2965-20e3-49e5-a751-dc3e03b172b6"
      },
      "source": [
        "import matplotlib.pyplot as plt\n",
        "\n",
        "def bound(T,Delta,epsilon,p_best):\n",
        "    return min(1,8 * np.exp(-(T * epsilon * 0.125 * Delta**2 * p_best)/(48 * np.exp(4)) + np.log(np.log(T))))\n",
        "plt.figure(figsize=(12, 8))\n",
        "a = [1 - i for i in gaps]\n",
        "plt.plot(a, 1-regrets_avg[:,0], label=\"BUCB\")\n",
        "plt.plot(a, 1-regrets_avg[:,1], label=\"Elimination\")\n",
        "# plt.plot(gaps,[bound(T,k,epsilon,p_best) for k in gaps],label='Theoretical Bound')\n",
        "plt.legend()\n",
        "plt.ylabel('Probability of error')\n",
        "plt.xlabel('Delta')\n",
        "plt.grid()\n",
        "plt.show()"
      ],
      "execution_count": 35,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "image/png": "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Kio6e/zpp58++3NOTs7Z7+bNm8e8efM+1QY8q3K0XGvFihVt3vv5558/53PLdaOiovjzn//8qfat7wfwxhtvtHndrtKTaB9cPjINQE+jRURERHopFdE+yEmJZVC/2ICMiz52qo5LH1nCK+tK/H4vEREREfGOimgfXT4yjZV7Kqg+c+GzOzvyyKJt7D92mpfXHvDrfURERETEeyqifTRrRCr1jZaPdpT77R7rD1Ty4toDJMdGsGbfMY6dqvPbvURERCT4tCz5Jv7lSz+riPZRQXYfEqLC/Dako7HJ8uDrRfSLi+T3t06gycL7WlZPRESk14iKiqKiokKFtJ9Za6moqCAqKqpL52l1Dh+FuV3MGJ7Kkm2e3Qu724trDrCx5AS/u3kcUwb1ZUBiFO9uPsINEzO7/V4iIiISfDIzMykpKaG83Lt/9a6tre1yISiefktKSiIzs2s1loroCzB7ZCoLNxxi/YHKbr3u8VN1PPLONibn9mXu2HSMMVyRl8ZLaw9QU9dIdIS7W+8nIiIiwSc8PJzc3Fyv2xcWFjJ+/Hg/JuqZfO03Dee4ADOGpeJ2Gd7f1r1L3T3yznaqahv46bWjMcYAcGVef2rrm1i662i33ktEREREuk5F9AVIjAmnILsPi7d231jljSWVLFizn3nTchjeP/7s8cmD+hIfFca7m490271ERERExDcqoi/Q5SPT2HakiqM1TRd8raYmy49e30xKXCTfunzoOd+Fu13MGpHKYj+NwRYRERER76mIvkCzRqYCsL6s7W0xu+KltQfYcKCSH1w9gvio8E99f2Vef46dqmNd8fELvpeIiIiI+E5F9AUa3C+O3JRYNpRfWBFdebqOXy3axqScvnxuXEabbS4b3o8It0tDOkREREQcptU5usHsEak8tXQvw374drtt+sSGM2VQMtMGJzNtcApZfWPO+f4/3tnOydoGfnLtqLOTCc8XFxnGtCHJvLullB9+ZmS77URERETEv1REd4OvXTKI0sMlZGYNbLdNyfEalu2q4PX1hwDI7BPN1EHJTBuSTFJMBM+v9kwmHDkgocN7XZnXnx+8uokdpdXnTDwUERERkcBREd0N+idGcf3QCGbMGNFhO2stu8urWb67guW7Knh3SykvrysBICUukm9fMazTe10+MpUfvArvbj6iIlpERETEISqiA8gYw5DUeIakxvOlqTk0NVm2HjnJyj3HGJeVSEIbkwnPl5oQxfiBSby7pZS7Zw/ttL2IiIiIdD8V0Q5yuQyj0hMZlZ7YpfOuyEvjkUXbOVRZQ3pStJ/SiYiIiEh7tDpHCLoyrz8A723t3p0SRURERMQ7KqJD0JDUOAb1i+XvW1REi4iIiDhBRXSIuiIvjRW7KzhRU+90FBEREZFeR0V0iLoyrz8NTZbC7WVORxERERHpdVREh6jxWUmkxEXyroZ0iIiIiASciugQ5XIZrshLpXBbGWcaLmzLcRERERHpGhXRIezKvP6cqmtk+e4Kp6OIiIiI9CoqokPY1MHJxEa4tUqHiIiISICpiA5hUeFuLhvej79vKaWpyTodR0RERKTXUBEd4q7M60951Rk+3n/c6SgiIiIivYZfi2hjzBxjzHZjzC5jzH1tfP8bY8z65tcOY0ylP/P0RJfnpREXGcazK4udjiIiIiLSa/itiDbGuIHHgauAPOAWY0xe6zbW2m9ba8dZa8cBjwF/81eeniouMowbCzJ5c9Nhyk7WOh1HREREpFfw55PoScAua+0ea20dsAC4toP2twAv+DFPj/XlqTk0NFk9jRYREREJEH8W0RnAgVafS5qPfYoxJhvIBd73Y54eKyclllnDU3lu1X6tGS0iIiISAMZa/6zqYIy5AZhjrf1a8+fbgcnW2rvaaPt9INNae3c717oTuBMgLS1t4oIFC/yS+UJUV1cTFxfn2P03H23kP9bW8rX8CC7OCHcsR1c53W+hSv3mG/Wbb9RvvlPf+Ub95hv1m2866reZM2eus9YWtPVdmB8zHQSyWn3ObD7WlpuBf23vQtba+cB8gIKCAjtjxoxuith9CgsLcTLXZdby2v4PWVHh4oe3XowxxrEsXeF0v4Uq9Ztv1G++Ub/5Tn3nG/Wbb9RvvvG13/w5nGMNMNQYk2uMicBTKC88v5ExZgTQB1jhxyw9njGGedNz2HzoJGuLtdydiIiIiD/5rYi21jYAdwHvAFuBl6y1m40xPzXGzG3V9GZggfXXuJJe5PPjM0iICuPpZfucjiIiIiLSo/lzOAfW2reAt8479uB5nx/yZ4beJCYijFsmDeSppXs5VFlDelK005FEREREeiTtWNjD3D41G2stz2i5OxERERG/URHdw2T2ieHKvP68sHo/NXVa7k5ERETEH1REe8tazysE3DE9h8rT9by2vr3FUERERETkQqiI9kbxCvj1cDiy0ekkXpmU25eRAxJ4etk+NF9TREREpPupiPZGUhZUl0LxcqeTeMUYwx3Tc9heWsWK3RVOxxERERHpcVREeyMxE5KyYd9Sp5N4be7YdPrGRvDn5fucjiIiIiLS46iI9lb2dM+T6BAZHhEV7ubWSQN5b2sp+ytOOx1HREREpEdREe2tnOlQcwzKtzudxGu3T83GbQx/XbHP6SgiIiIiPYpfN1vpUbKned6Ll0HqCGezeCktIYqr8wfw1xXFvLultN12F+X05ddfGBvAZCIiIiKhTUW0t/rkQvwAz5COi77qdBqvffuKYUSEuWhsansYys6yKl79pIRffH40UeHuAKcTERERCU0qor1ljOdpdPEyz7hoY5xO5JXclFj+88b2nzIvKjrM15/9mG1HqhiXlRTAZCIiIiKhS2OiuyJ7OlQdhuN7nU7SbUalJwKw5dBJh5OIiIiIhA4V0V2RPd3zHiLrRXsjs0808VFhbD50wukoIiIiIiFDRXRX9BsOMck9qog2xpA3IIHNehItIiIi4jUV0V1hDAycGlKbrngjLz2BbUdOtjv5UERERETOpSK6q7KnQ2UxnChxOkm3GZWeSG19E3uPVjsdRURERCQkqIjuqpyWcdErnM3RjfIGJABoSIeIiIiIl1REd1XaaIhM8Cx110MMTYsjwu3SCh0iIiIiXlIR3VUuNwyc0qMmF4a7XQzrH8eWwyqiRURERLyhItoX2dPg6HaoLnc6SbdpWaHDWk0uFBEREemMimhftKwXvb/nPI0elZ7IsVN1lJ4843QUERERkaCnItoXA8ZBeEyPGtKRl94yuVCbroiIiIh0RkW0L8IiIPOiHjW5cKRW6BARERHxmopoX2VPhyNFUHPc6STdIi4yjJzkGK3QISIiIuIFFdG+yp4GWNi/yukk3WZUeiKbD2s4h4iIiEhnVET7KrMA3BE9akhHXnoCB47VcKKm3ukoIiIiIkFNRbSvwqMhY2KPnFy4VetFi4iIiHRIRfSFyJ4Ghz6BM9VOJ+kWo5qLaI2LFhEREemYiugLkT0NbCOUrHY6SbdIjY8iJS5SK3SIiIiIdEJF9IXImgzG3aOGdIxKT9D23yIiIiKdUBF9ISLjYcDYHlVE56UnsLO0ijMNjU5HEREREQlaKqIvVPY0KFmLq7HO6STdYlR6Ag1Nlp2lPWOct4iIiIg/qIi+UNnTofEM8VU7nU7SLfIGaHKhiIiISGdURF+ogVMASKrc7HCQ7pGTHEtshJvNh7TpioiIiEh7VERfqJi+kDqKxBM9o4h2uQwjB2hyoYiIiEhHVER3h5zpJJ7YBqcqnE7SLfLSE9hy6CRNTdbpKCIiIiJBSUV0dxh7C9AEz1wLNcedTnPBRqUncKqukf3HTjsdRURERCQoqYjuDhkT2DzqfijfDs9cB7WhPRQib0AiQKebrtQ3NvHDVzexfPfRQMQSERERCRoqorvJseQJ8IW/wpGN8NwNIb0V+NC0OMJchi2HO55c+IcPdvPcqv1858UNnDrTEKB0IiIiIs5TEd2dhl8FN/wJStbCCzdDXWgOh4gKdzMkNa7DJ9G7yqp4dPEuxmYlceRkLY+9vyuACUVEREScpSK6u+VdC9fNh+JlsOBWqK91OpFPWiYXtqWxyfK9VzYSE+nmj18u4PoJmfxx6R52l4fu03cRERGRrvBrEW2MmWOM2W6M2WWMua+dNl8wxmwxxmw2xjzvzzwBk38DXPs47FkCL90ODWecTtRleQMSKKs6Q3nVp7M/s2IfH++v5MFr8kiJi+S+q0YQFe7moYWbsVYreoiIiEjP57ci2hjjBh4HrgLygFuMMXnntRkK3A9Mt9aOAr7lrzwBN+5WuOa3sPNdePkOaKx3OlGXjEr3TC48f73oA8dO88g727lsWD8+Pz4DgH7xkXz3imF8tPMoi4qOBDyriIiISKD580n0JGCXtXaPtbYOWABce16bfwYet9YeB7DWlvkxT+AV3AFX/QdsfxPeCK2/H+Sle7b/br1zobWWH7y6CQP84vOjMcac/e6LU7IZ0T+en72xhdN1mmQoIiIiPZs/i+gM4ECrzyXNx1obBgwzxiwzxqw0xszxYx5nTL4TJt4BG1+Ghjqn03gtMTqczD7R50wu/N+PD/LRzqN8/6oRZPaJOad9mNvFzz43mkMnanl8iSYZioiISM9m/DWG1RhzAzDHWvu15s+3A5OttXe1avMGUA98AcgEPgTyrbWV513rTuBOgLS0tIkLFizwS+YLUV1dTVxcXJvf9Stbxqgtj7Buwn9SlTA0wMl899gntRysauLhS2OoPNPED5fWkB7r4v7JUbhaPYVubf7GM6w63MAvLo6mf2znf0frqN+kfeo336jffKN+8536zjfqN9+o33zTUb/NnDlznbW2oK3vwvyY6SCQ1epzZvOx1kqAVdbaemCvMWYHMBRY07qRtXY+MB+goKDAzpgxw1+ZfVZYWEi7uU4MhS2PMDGtCSa30yYIbWjYyW8X7+CiqRdz7ysbqLdn+J+vXsLgfu3/B5o3sZbZ//kBb5XG8Zc7LjpnyEdbOuw3aZf6zTfqN9+o33ynvvON+s036jff+Npv/hzOsQYYaozJNcZEADcDC89r8xowA8AYk4JneMceP2ZyRmIGxA/wrB8dQkalJ2At/Pa9Hby16Qj/NntohwU0QGp8FN+6Yhgf7ijnnc2lAUoqIiIiElh+K6KttQ3AXcA7wFbgJWvtZmPMT40xc5ubvQNUGGO2AEuAe621Ff7K5KiMiXAwtIrolsmFT360l7wBCdx56SCvzvvy1H9MMqypa/RnRBERERFH+HWdaGvtW9baYdbawdbaXzQfe9Bau7D5Z2ut/Y61Ns9am2+tDb7Bzt0l8yI4tgdOH3M6idcGJEbRJyYct8vwyA1jCHd798clzO3iJ3NHcbCyhicKNclQREREeh7tWBgomc1j0kNoSIcxhjsvHcyD1+QxOiOxS+dOHpTM58al84cP9nDgWGhufy4iIiLSHhXRgTJgHBhXyA3p+MaMwXx5Wo5P537/qhHUNzXx8rqS7g0lIiIi4jAV0YESGQepo0LqSfSFGpAYzeTcvryx8ZBftgN/ZmUxz60q7vbrioiIiHRGRXQgZTZPLmxqcjpJwFwzJp095afYdqSqW69b19DEI29v44HXiliyvWdtdCkiIiLBT0V0IGUUQO0JOLbb6SQBc9Xo/rgMvLHxULded+2+Y1SdaSA+MoxvLVivcdciIiISUCqiAykEJxdeqOS4SKYNTuGNjYe7dUjHe1vLiAhz8eK/TKXJWr7x3Dpq67WcnoiIiASGiuhAShkOkQlQsqbztj3INWMGUFxxms2HTnbL9ay1LN5WyrTByYwckMBvbxpH0cGTPPh6UbdcX0RERKQzKqIDyeWC9PEht0LHhfqnUf0Jcxn+r5uGdOwuP0VxxWlmj0wDYPbINO6aOYSX1pawYPX+brmHiIiISEdURAdaZgGUboa63jOGt09sBNOHpPBmNw3pWLzVs534rBGpZ499+4phXDI0hQcXbmZTyYkLvoeIiIhIR1REB1rmRdDUAIc3OJ0koD4zZgAlx2vY0A0F7uJtZYwckEBGUvTZY26X4Xc3j6dfXCRff3Ydx0/VXfB9RERERNqjIjrQMponF/a2IR15/Ql3G968wCEdlafrWFd8nMtHpn7qu76xETxx2wTKq87wrRfX09jU/WtTi4iIiICK6MCL6wdJA3vVCh0AiTHhXDq0H29uPEzTBRS3H+wop7HJnjOUo7WxWUn8eG4eH+wo59HFO32+j4iIiEhHVEQ7IfMiOLjO6RQB95kxAzh0opZPDlT6fI33tpaREhfB2MykdtvcOmkg10/I5NH3d/LRznKf7yUiIiLSHhXRTsgogBMHoOqI00kC6oq8NCLCXD5vvFLf2MQH28uYOTwVl8u0284Ywy8+P5qsPjH89j09jRYREZHupyLaCb1w0xWA+KhwLhvWj7c2+TakY+2+45ysbTi7tF1HosLd3DE9h3XFx9lY4vuTbxEREZG2qIh2Qv8x4ArvdZMLwbPxSunJM6wtPt7lc9/fVkqE28UlQ1O8an/DxEziIsN4etm+Lt9LREREpCMqop0QHgX983vdk2iAy0emEenjkI7FW8uYMjiZ2Mgwr9rHR4Vzw8RM/m/jIcqqart8PxEREZH2qIh2SmYBHPoEmhqdThJQsZFhzBqRylubjnRpCbo95dXsOXqqzaXtOjJvWg4NTZbnVmonQxEREek+KqKdklEAddVQvs3pJAF3zZh0jlafYdXeCq/PeX9bGUC7S9u1JycllpnDU3lu1X7ONPSuv7CIiIiI/6iIdsrZyYVrnM3hgJkj+hEd7ubNjYe9Pue9raWM6B9PZp+YLt/vjuk5HK0+06X7iYiIiHRERbRT+g6C6L69clx0TEQYs0emsqjIuyEdJ2rqWbPveJefQre4eEgKQ1Lj+POyfVirXQxFRETkwqmIdooxkDGxV266Ap4hHRWn6th6rKnTti27FHqztF1bjDHMm5bDpoMn+Hh/11cFERERETmfimgnZV4EZVuh9qTTSQJuxvB+xEa4WX2kodO2728tpW9sBOOy2t+lsDPXTcggISqMP2m5OxEREekGKqKdlDkRsJ5VOnqZqHA3V+Slsa60gcMnatpt19DYxJLt5cwcnoq7g10KOxMTEcbNkwayqOgIhyrbv5+IiIiIN1REOyljoue9F266AnD71BzqG+GK//qQZ1YWt7mL4cf7KzlRU9/lpe3avN+UbKy1PLuy+IKvJSIiIr2bimgnRfeB5KG9cnIhwMTsPvz84mjGZSXxo9eKuGn+CnaVVZ/TZvHWUsLdhou93KWwI1l9Y7giL40XVu+ntl7L3YmIiIjvVEQ7LbPAU0T30lUjUmNcPPPVSfzHDWPYUVrN1b/7iMcW76SuwTPh8L2tpUwZlEx8VHi33O+O6bkcP13Pa58cvKDrbDhQyTN6oi0iItJrqYh2WsZEOFUGJw44ncQxxhhuLMji79+5lCtGpfHrv+9g7u+XsnDDIXaXn/J5abu2TM7ty4j+8Ty9/MKWu3vs/Z38+PUiTtd1PjFSREREeh4V0U47u+lK75LdJF4AACAASURBVBzS0VpqfBSP3zqBJ79UwPHTddzzgmfC5ewRvi1t1xZjDF+Znsu2I1Ws2OP9jomtNTQ2sWrPMZosbDnU+1ZWERERERXRzksbDWFRUPS/UF3mdJqgcEVeGn//zmV8eWo210/IZGBy13cp7Mjccen0jY3gaR+Xuys6dJKqM54n0BtLTnRjMhEREQkVYU4H6PXc4TD+dljzJOxYBMPmwPgvwpArwN17/8+TEBXOT64d7ZdrR4W7uWVSFk8U7ubAsdNk9e1akb5s11EAEqLC2FhS6Y+IIiIiEuT0JDoYfOY/4V9Xw5RvwIFV8MLN8JtR8N5DcHSX0+l6pFsnZ2MtvLHxcJfPXbG7ghH945k8KJmNB/UkWkREpDdSER0s+g2HK38O39kKNz0H6eNg2e/g9xPhT1dBxW6nE/YoGUnRjEpPYPHW0i6dd6ahkTX7jjF1cDJjMhLZU36Kk7X1fkopIiIiwUpFdLBxh8PIa+DWF+HbW2D2jz07Gi5/zOlkPc7skWl8vP84x07VeX3Ox8WVnGloYvrgFMY0b0NepKfRIiIivY6K6GCWMAAu+Q4Mugz2fuB0mh7n8pGpNFko3O79hM4Vu4/iMjBpUF/yMxIB2KTJhSIiIr2OiuhQkHsZHNsDlb13LWl/GJ2eSL/4SBZv9b6IXr67gvzMJBKiwukbG0FW32it0CEiItILqYgOBbmXet73feRsjh7G5TLMHpHKhzvKz+6Q2JFTZxpYf6CS6YOTzx4bk5HExoNaoUNERKS3UREdClLzICYF9mhIR3ebNSKVqjMNrNl3rNO2q/cdo6HJMm1wytlj+ZmJHDhWw/EujKsWERGR0KciOhS4XJB7Cez9EC5gq2r5tIuHphAR5uI9L1bpWL7rKBFuFxOz+5w9NibTMy5aS92JiIj0LiqiQ0XupVB1CCq0bnR3iokIY/rgZBZvLcN28heU5bsrmJCdRHSE++yx0WcnF3ZtSMdLaw+wem/nT79FREQkOKmIDhW5l3netUpHt5s1Mo39x06zu7y63TbHT9Wx5fDJc4ZygGdnxUH9YtnQhcmFh0/U8L1XNnLz/BU8UbiLpib964KIiEio8WsRbYyZY4zZbozZZYy5r43v5xljyo0x65tfX/NnnpDWdxAkZHqGdEi3mj0iFaDDVTpW7qnAWpjWalJhizEZiV1a5u69LZ6hI9OHpPDIou3c+cxaTpzWhi0iIiKhxG9FtDHGDTwOXAXkAbcYY/LaaPqitXZc8+spf+UJecZ4hnTs/QiaOl9JQryXnhTNyAEJHRbRy3dXEBPhZmzzBiut5WcmceRkLWUna72637tbShmUEstfvzKJhz6bR+H2cj77+6VsPqRx1SIiIqHCn0+iJwG7rLV7rLV1wALgWj/er+cbdBnUHIPSIqeT9DiXj0xlbfGxdlfZWL77KJNy+xLu/vR/MmNbJhd68TT6RE09K3ZXcEVeGsYY5k3P5cV/mUpdQxPXPbGcl9ZoLXAREZFQ4M8iOgNoXRGUNB873/XGmI3GmFeMMVl+zBP6ci7xvGtIR7ebPTKNJgsf7Cj/1HdHTtSyu/wU088bD90iLz0Bl/FuhY7C7WU0NFmuHJV29tjE7D68cc/FFOT04Xv/u5HvvbKB2vpG338ZERER8TvT2YoEPl/YmBuAOdbarzV/vh2YbK29q1WbZKDaWnvGGPMvwE3W2lltXOtO4E6AtLS0iQsWLPBL5gtRXV1NXFyc3+8zadU3qIkewKYxD/r9XoEQqH7rTJO1fGtJDSP6uvjmuKhzvlt+qIH5G8/wk2lRZCe42zz/gaWn6Rvl4jsFUW1+3+KJ9bVsO9bEb2dG4zLmUxle3VnP/+2pZ2C8i3sviiI+wrR5nWDpt1CjfvON+s136jvfqN98o37zTUf9NnPmzHXW2oK2vgvzY6aDQOsny5nNx86y1la0+vgU8EhbF7LWzgfmAxQUFNgZM2Z0a9DuUFhYSEByVV9FzMYXmXHJdHCH+/9+fhawfvPCnIoNvF10hOmXXHrOsI03X95AUkwpt18zC5er7aJ2avkG3t9WxmWXXYYxbbc509DIXUve45qxmcyaOabNNrNmwmc3H+HOZ9ZREZvDZ6fnttkumPotlKjffKN+8536zjfqN9+o33zja7/5czjHGmCoMSbXGBMB3AwsbN3AGDOg1ce5wFY/5ukZci+Fumo4+LHTSXqcWSPSqKo9d/dCay3Ld1cwdVByuwU0eDZdqThVx6ET7U8uXLG7guozDecM5WjLFXlppMRFsOngya7/EiIiIhIQfiuirbUNwF3AO3iK45estZuNMT81xsxtbnaPMWazMWYDcA8wz195eozcSz3vGhfd7S4ZmkKE23XOKh37j53mYGVNm0vbtTYm07Nqx8YD7W+68u6WUmIi3J9aa/p8xhhGZyRSpF0QRUREgpZf14m21r5lrR1mrR1srf1F87EHrbULm3++31o7ylo71lo701q7zZ95eoSYvtA/X5uu+EFsZBhTByfz/rZ/FNHLdnlGHE3tpPAdMSCecLdpd3JhU5PlvS2lXDasH1HhbY+rbi0/I5GdZVXU1GmCoYiISDDSjoWhKPcyOLAa6mucTtLjzB6Zyt6jp87uXrh891HSEiIZ3C+2w/Miw9yM6J/Axna2/95QUklZ1ZlOh3K0GJ2RSJOFLYc1pENERCQYqYgORbmXQeMZOLDK6SQ9zqzm3Qvf31qGtZYVuyuYNjil3cmCreVnJrKx5ARtrXjz7pZS3C7DrOHeFdH5GZ61pzWkQ0REJDipiA5F2VPBuDUu2g8y+8Qwon88720tZXtpFRWn6pjayXjoFmMyEqmqbaC44vSnvvv7llIm5/YlMca7FVUGJEaRHBvBJhXRIiIiQanDItoY4zbGPBeoMOKlyHjImAh7NC7aH2aPTGVt8XHe3nQEoNNJhS1aJhduOG9Ix57yanaVVXNlnndPoUGTC0VERIJdh0W0tbYRyG5eok6CyaDL4NDHUKsiq7vNHplGY5PlqY/2kJ0cQ2afGK/OG5oWR2SYi03nbf/99y2lAFwxqn+XcngmF1Zr90IREZEg5M1wjj3AMmPMj4wx32l5+TuYdCL3UrBNULzc6SQ9ztjMJJJjIzhV19jpcnSthbtdjEpPYON5RfS7W0oZlZ5ARlJ0l3KMzkiksclqcqGIiEgQ8qaI3g280dw2vtVLnJQ5CcKiNC7aD9wuw8zmCYbeDuVoMSYziaJDJ2hs8kwuLK86w8f7j3NlXteeQoNnoiJocqGIiEgw6nTbb2vtTwCMMXHNn6v9HUq8EB4FWZNVRPvJjRMz+Xj/cS4e4v2TaPAMwXh6+T72lFczNC2exVtLsRavl7ZrLT0xir6xEZ8aHiIiIiLO6/RJtDFmtDHmE2AzsNkYs84YM8r/0aRTuZdCaRFUlzudpMeZPCiZ9787gz6xXZsOMDbL8/R4Q3Ph++6WUjL7RDOif9f/8aZlcqFW6BAREQk+3gznmA98x1qbba3NBr4LPOnfWOKVQTM87/s+cjKFtJKbEkdshJtNJZWcOtPA0l1HuTKvv1frTLclPyNBkwtFRESCkDdFdKy1dknLB2ttIdDx9m0SGAPGQUS8hnQEEbfL8/R4Q8kJPtxRTl1Dk09DOVrkN08u3KrJhSIiIkHFq9U5mlfmyGl+PYBnxQ5xmjsMcqbDXq0XHUzGZCay5fBJ3tx0mKSYcAqy+/h8rfzmtac1uVBERCS4dDqxEPgK8BPgb4AFPmo+JsEg9zLYsQj+/iC4I9tuE58GBV8FH4cUSNfkZyZR17CXtzYd5vPjMwlz+74x6NnJhSqiRUREgkqHRbQxxg38zVo7M0B5pKuGz4HCf4dlj7bTwLPUGgOnQVpewGL1ZmObl6Zr8nFVjtb+MblQwzlERESCSYdFtLW20RjTZIxJtNbqUVgw6jsI7j/Q/vfH9sKj46B4mYroABnYN4bE6HBq6xu5ZGjXlshrS35GAn/4YA+19Y1Ehbu7IaGIiIhcKG+Gc1QDm4wxfwdOtRy01t7jt1TSffrkQHy6Z2fDSf/sdJpewRjD1fmeFTliIrz5T6xj+RmJNDRPLhw/0Pfx1SIiItJ9vPn/8H9rfkkoMgayp8G+pWCtxkUHyL9fN6bbrjU64x87F6qIFhERCQ7ejImepzHRIS5nOhS9Asf2QPJgp9NIF2UkRdMnJlyTC0VERIJIh8sGWGsbgSZjTGKA8og/ZE/3vBcvczaH+ESTC0VERIKPN2tvtYyJ/qMx5tGWl7+DSTdKGQYxyZ5x0RKS8jMS2VlapZ0LRUREgoTGRPcGLeOi9SQ6ZLVMLtx2pIpxWUlOxxEREen1Oi2irbV/McZEAwOttdsDkEn8Ifti2Pp/UHkAkrKcTiNd1DK5cNPBEyqiRUREgkCnwzmMMZ8F1gOLmj+PM8Ys9Hcw6WbZ0zzvGtIRkjL7RJMUE05RiSYXioiIBANvxkQ/BEwCKgGsteuBQX7MJP6QNgoiEzWkI0QZY8jPSNQKHSIiIkHCmyK6vo3dCpv8EUb8yOWGgVP0JDqEjc5IZIcmF4qIiAQFb4rozcaYWwG3MWaoMeYxQJVYKMqeBhU7obrM6STig5bJhduPVDkdRUREpNfzpoi+GxgFnAGeB04A3/JnKPGTnIs97xrSEZLyW00uFBEREWd1WkRba09ba39orb2o+fWAtbY2EOGkmw0YC+ExGtIRos5OLlQRLSIi4jhvnkRLT+EOh6xJKqJDlLeTC/cdPcWyXUcDlEpERKR3UhHd22RPh9LNcPqY00nEBy2TC+ubbJvfL9xwiKsf/Yjb/7iKQ5U1AU4nIiLSe7RbRBtjftX8fmPg4ojfZU8DLOxf6XQS8UF+RiL1jZaSqnMXyKlraOKhhZu554VPGJoahwUWrN7vTEgREZFeoKMn0VcbYwxwf6DCSABkFIA7QpMLQ1TL5MJ9J/5RRB8+UcNN81fw9PJ9fPXiXF75xjRmDOvHgjUHqG/UapQiIiL+0FERvQg4Dowxxpw0xlS1fg9QPulu4VGeQlrjokNSZp9oEqPD2XfSUxwv3XmUzzy6lB1Hqnjitgn86Jo8wt0uvjglm7KqM7y3pdThxCIiIj1Tu0W0tfZea20S8Ka1NsFaG9/6PYAZpbtlT4PDG+CM1hsONS2TC/eeaOKxxTu5/U+rSImLYOHdF3N1/oCz7WYMTyUjKZpnVxU7mFZERKTn8maJu2uNMWnGmGuaX/0CEUz8KHsa2EY4sNrpJOKD0RmJ7K9q4td/38G1Y9N57V+nM7hf3Dlt3C7DLZOyWLargj3l1Q4lFRER6bk6LaKbJxauBm4EvgCsNsbc4O9g4kdZk8G4NS46RM0Y3o8oN/zs2lH85qZxxESEtdnuCxdlEeYyPLdKEwxFRES6mzdL3D0AXGSt/bK19kvAJOBH/o0lfhUZB+njNC46RE0ZlMx/Xx7D7VNz8Mz9bVtqfBT/NLo/r6wroba+MYAJRUREej5vimiXtbas1ecKL8+TYJY9DQ6ug3qtJRyKOiqeW/vi5GxO1NTzxsbDfk4kIiLSu3hTDC8yxrxjjJlnjJkHvAm85d9Y4nfZ06GxzlNIS481ZVBfBveL5dmVmmAoIiLSnbyZWHgv8AdgTPNrvrX2+/4OJn42cApgNKSjhzPGcNvkbNYfqKSok+3CRURExHteDcuw1v7NWvud5ter/g4lARDdB9JGw76lTicRP7t+YiZR4S6e03J3IiIi3UZjm3uz7GmeZe4a6pxOIn6UGB3O3LHpvPbJIU7W1jsdR0REpEfwaxFtjJljjNlujNlljLmvg3bXG2OsMabAn3nkPNnToKHGs/GK9Gi3Tc6mpr6R1z456HQUERGRHsGbdaI/a4zpcrFtjHEDjwNXAXnALcaYvDbaxQP/Bqzq6j3kAmVP87xrvegeb2xWEvkZiTy7shhrrdNxREREQp43xfFNwE5jzCPGmBFduPYkYJe1do+1tg5YAFzbRrufAb8CartwbekOcamQPFRFdC/xxSkD2VFazZp9x52OIiIiEvKMN0+ljDEJwC3AHYAF/gy8YK2t6uCcG4A51tqvNX++HZhsrb2rVZsJwA+ttdcbYwqB/2etXdvGte4E7gRIS0ubuGDBAu9/wwCprq4mLi6u84ZBZsjO+aQfeoe1Bb/hdOzAgN8/VPvNab7025kGy7cKTzO2n5uvj43yU7Lgpj9vvlG/+U595xv1m2/Ub77pqN9mzpy5zlrb5nDjtvcLPo+19qQx5hUgGvgW8HngXmPMo9bax3wJ3DxE5L+AeV7cfz4wH6CgoMDOmDHDl1v6VWFhIcGYq1MFo+Dxi5h0+Bn4yiJwuQN6+5DtN4f52m83nd7Mc6uKGV0wlZS4yO4PFuT058036jffqe98o37zjfrNN772mzdjoq81xrwKFALhwCRr7VXAWOC7HZx6EMhq9Tmz+ViLeGA0UGiM2QdMARZqcmGAxfWDOQ9DyWpY85TTacTPbps8kPpGy8trS5yOIiIiEtK8GRN9HfAba22+tfY/WrYAt9aeBr7awXlrgKHGmFxjTARwM7Cw5Utr7QlrbYq1NsdamwOsBOa2NZxD/GzMTTDkcnjvJ3Bcawn3ZEPT4pk2OJknP9rDsVNa2lBERMRX3hTRR6y1H7Y+YIz5FYC1dnF7J1lrG4C7gHeArcBL1trNxpifGmPmXkBm6W7GwDW/8by/8S3Q6g092o8/O4qq2np+9sYWp6OIiIiELG+K6CvaOHaVNxe31r5lrR1mrR1srf1F87EHrbUL22g7Q0+hHZQ0EC5/CHa/DxtecDqN+NHw/vF8c8YQXv3kIEu2lTkdR0REJCS1W0QbY75hjNkEjDDGbGz12gtsDFxECZiCr0LWFFh0P1SVOp1G/OibMwczLC2OH766iSrtYigiItJlHT2Jfh74LPB683vLa6K19osByCaB5nLBtb+H+hp4+16n04gfRYa5+dX1Yzh8spZHFm13Oo6IiEjI6aiIttbafcC/AlWtXhhj+vo/mjgiZSjM+D5seR22fGrUjfQg4wf24SvTc3lmZTGr9x5zOo6IiEhI6exJNMA6YG3z+7pWn6WnmnYP9M+Ht/4f1Gh3u57su1cOI6tvNN//343U1jc6HUdERCRktFtEW2uvaX7PtdYOan5veQ0KXEQJOHc4zP09nDoK7/7I6TTiRzERYTx83Rj2Hj3F7xbvdDqOiIhIyGh3x8LmLbnbZa39uPvjSNBIHwfT7oZlv4XR18PgmU4nEj+ZPiSFLxRkMv/DPXwmfwCjMxKdjiQiIhL0Otr2+9cdfGeBWd2cRYLNjPtg899g6W9URPdwP7w6jyXby/neKxt5/a7phLu9Wf1SRESk92q3iLbWqmrq7cKjYdgc+OQ5aGwAd0d/55JQlhgTzs+uHc3Xn13H/A/38K8zhzgdSUREJKh1tE70rOb369p6BS6iOCprMtSfgtIip5OIn80Z3Z+r8/vzu8U72VVW7XQcERGRoNbRv9le1vz+2TZe1/g5lwSLrMme9wOrnM0hAfHQ3FFEh7v57ssbqG9scjqOiIhI0OpodY4fN7/f0cbrK4GLKI5KyoKEDBXRvURqfBS//Hw+Gw5U8phW6xAREWlXp7OHjDHJxphHjTEfG2PWGWN+Z4xJDkQ4CRJZk2C/iuje4jNjBnD9hEx+v2QXa/dpExYREZG2eDMFfwFQDlwP3ND884v+DCVBJmsKnCyBEyVOJ5EAeWhuHhl9ovnWi+upqq13Oo6IiEjQ8aaIHmCt/Zm1dm/z6+dAmr+DSRDJmuR515COXiM+Kpzf3jSOQ5U1/HjhZqfjiIiIBB1viuh3jTE3G2Ncza8vAO/4O5gEkf75EB4DB1Y7nUQCaGJ2X+6aNZS/fXyQNzYecjqOiIhIUOloibsqY8xJ4J+B54G65tcC4M7AxJOg4A6HjImwf6XTSSTA7pk1hHFZSfzgb5s4VFnjdBy/OnWmgW1HTjodQ0REQkRHq3PEW2sTmt9d1tqw5pfLWpsQyJASBLImw5FNcEbrB/cmYW4Xv71pHA1Nlu++tIGmJut0JL/59bs7mPv7ZZyua3A6ioiIhACv9vY1xvQxxkwyxlza8vJ3MAkyA6eAbYRDHzudRAIsJyWWhz47ihV7Knjyoz0dtj18oiYkV/RoarK8tekwdQ1NFB3U02gREelcp/s4G2O+BvwbkAmsB6YAK4BZ/o0mQSWzwPO+fxXk6u9Qvc2NBZm8v62M/3x3O9OHpDA6IxGAo9VnWLmnguW7K1ixu4K9R08B8Pw/T2ba4BQnI3fJ+pJKjpysBWDDgUom5fZ1OJGIiAS7TotoPAX0RcBKa+1MY8wI4Jf+jSVBJ7oP9BupFTp6KWMM/35dPnN+d5x/W/AJlwztx4rdFWwvrQIgPjKMyYP6ctvkgfx+yS6eXVkcUkX0oqIjhLsNidHhbCipdDqOiIiEAG+K6Fprba0xBmNMpLV2mzFmuN+TSfDJmgRbXoOmJnB5NRJIepA+sRH8+sZx3P6nVRysrOGinL5cOz6daYNTGJ2eQJjb82ei9GQtf162j7KTtaQmRDmcunPWWt4uOsz0ISnERLhVRIuIiFe8KaJLjDFJwGvA340xx4Fi/8aSoDRwCnz8Fzi6HVJHOp1GHHDx0BSWfX8WyXERRIa522xz6+RsnvxoLy+uOcDds4cGOGHXbT50kgPHarhr5hAqT9fz1qYjVFSfITku0uloIiISxDp9nGit/by1ttJa+xDwI+CPwOf8HUyCUNZkz7uWuuvV0pOi2y2gAXJTYrl4SAovrN5PYwis5rGo6AguA5ePTGNsVhIAG0tOOJxKRESCnberc0wwxtwDjAFKrLV1/o0lQanvIIhJ0aYr0qkvThnIoRO1vL+tLKD33XLoJA2NTV065+2iw0zOTSY5LpL8jERcBtYf0JAOERHpWKdFtDHmQeAvQDKQAvzZGPOAv4NJEDLGM6TjgJ5ES8cuH5lGWkIkz64M3MivnaVVXP3oRzxRuLtL5+wuP8VV+f0BiI0MY0hqHBs1LlpERDrhzZPo24CLrLU/ttb+GM8Sd7f7N5YEraxJcGwPVAf2CaOEljC3i5svGsiHO8vZX3E6IPd8c9NhAP64dC9VtfVenfN20REA/mlU/7PHxmYmsaHkBNYG/1AUERFxjjdF9CGg9RT7SOCgf+JI0Mua4nnXkA7pxC2TBuIyhudX7w/I/RYVHSE9MYoTNfU8u9K7e75ddISJ2X1Ia7WKyNisJI6dqqPkeM/e5lxERC5Mu0W0MeYxY8yjwAlgszHmaWPMn4EiQP/W2VsNGAvuCA3pkE71T4xi9ohUXlp7gDMNjX69196jp9h2pIqvXjKIy4b146mP9nS6fXdxxSm2Hj7JVaP7n3N8XPPkQo2LFhGRjnT0JHotsA54FfgBsAQoBH4IvO73ZBKcwqMgfbyeRItXvjglm2On6ljUPGzCX94u8gzlmDO6P3fPGkLFqTpeWH2gk3M+PZQDYHj/eCLCXGxQES0iIh1od51oa+1fWn42xkQAw5o/brfWejfgUHqmrMmw6n+gvtZTVIu04+IhKWQnx/DsymKuHZfRaftjp+pobLL0i+/aGs2Lio4wNjORjKRoMpKimTKoL/M/3M1tkwcSFd72cnxvFx0hPyORrL4x5xwPd7sYlZ6gTVdERKRD3qzOMQPYCTwOPAHsMMZc6udcEsyyJkNjHRze0HE7a6Fit+ddeiWXy3Db5IGs2XecbUdOdth2/YFKLv+vD7hp/gqaurC+dMnx02wsOcGc0QPOHrtn1lBKT57h5XUlbZ5zqLKGDQcqmXPeUI4WYzOTKDrY9eXyRESk9/BmYuGvgSuttZdZay8F/gn4jX9jSVBr2XSls3HRy34Lj02A9c/7P5MErRsnZhER5uL5Ve1P9luyvYxb5q+krqGJPeWn+GBHudfXf2dzKcA5Y5unDk5mwsAk/qdwN/VtFMItw0vOHw/dYlxWEjX1jewsq/Y6h4iI9C7eFNHh1trtLR+stTuAcP9FkqAX18+z8UpH46KL/gbvPQTG5Smmm/REr7fqExvBNfkD+NvHBzl15tOT/V5ZV8LX/rKWQf1ieffbl5IaH8mflu31+vqLig4zon88OSmxZ48ZY7h71lAOVtbw6sefXkxoUdERhqfFM6hfXJvXbNm5UOOiRUSkPd4U0euMMU8ZY2Y0v57EM+lQerOsKZ7tv9saqrF/Fbz6dU+buY/B0R2wY1HgM0rQuG3KQKrPNPD6+kNnj1lr+e/C3fy/lzcwZVBfFtw5hfSkaG6fks1HO4+yq6yq0+uWVdWytvg4V7UaytFixvB+jM5I4InCXecMyyirqmVN8bF2h3IA5CTHkBAVpnHRIiLSLm+K6K8DW4B7ml9bgG/4M5SEgKxJcPqoZ+OV1ip2wws3Q2IG3Pw8jLkJErNg+aPO5JSgMGFgH0b0j+fZlcVYa2lqsvz0jS38atE25o5N58/zJhEf5fkHrlsnDyQizMXTy/d1et13NpdiLWd3HGzNGMNdM4eyr+I0b2w8fPb4ux2c0/rcsVlJrD9wouu/rIiI9AodFtHGGDewwVr7X9ba65pfv7HWnglQPglWA1s2XVn1j2Onj8FzN3p+vu0ViE0GdzhM+SbsXwEH1gQ+pwQFYwxfnJLNlsMnWb33GHcv+IQ/L9vHV6bn8tubxhER9o//KUqOi2Tu2HT+d91BTpzueCGgRUWHGdQvlqGpbQ/LuDIvjeFp8fx+ya6zkxUXFR0hNyWW4WnxHV57bGYSO0qrqKnz7xrXIiISmjosoq21jcB2Y8zAAOWRUJEyHKISPUM6ABrOwILb4MQBzxPo5MH/aDvhS562y3/nTFYJCp8bn0FshJsv/Wk1b248zP1XjeBH14zE5TKfajtvWg419Y28tLb9tZ6Pn6pj5Z5jzBnVH2M+fQ3wrA7yr7OGsKusmnc2H6G6zrJiTwVzRrd/TouxWf+fvfuOj6rKYenddwAAIABJREFU/z/+OpPeCymENEoCobdQBQQRBbH33tfdte3+3PWrW9T9uruu67quu67uV9desStSRESQIkjvvSfUhBZCenJ+f0yAAEmYlMlMkvfz8ZjHlHvn3s+c3Jl85sznnhNJeYVlze7W3RttrWV3vs5pEBE5nSvlHFE4ZyycYYyZePzi7sDEyzkckDTQeXJhRQV8cS/s/AEu/w+kDjl13YBQGHA3rJvkLPeQVik0wJdrMpMpr7A8d21vfnpupxoT2R6JEQxsH81b87dTXsNwd9PX7qO8wlZbD13V+J4JdIwJ4YXvNrN0fxnlFZax3Wsu5Tiud1IEoJkLv1u/n9/OLeSLZWeeoCki0pq5kkQ/BlwMPIlzuLvjF2ntUgZBzjr4+hFY/QmMfhx6Xl39ugN/6iztmP/vpo1RvMrvxndlziOjuLJf0lnXveOc9mQfKmT62n3VLp+6eg9JUUH0SAyvdTs+DsO9o9JYuyePzzaVkhgZRK/KBLk2ceGBtIsIZEV26+6JPn4y6J+nrCOvSPNsiYgcV2MSbYwJNMb8ErgGyADmWWu/P35psgjFex0fL3rhK9D3Fhj2UM3rhsVD7+udY0bnuz4GsLQsfj4OEiKCXFp3TLd4EiODePOHM4e7yysqZe7m3FpLOaq6rE87kqKCOFxsudDF54CzpKM1D3NXWFLOt+v2kR7pIDe/mOenb/J0SCIiXqO2nui3gExgFTAO9T7L6RL7g28QdBwFF/8DzpaYDHkAyopg0X+bJj5p1nx9HNwyJJUFWw+ybs+psx1+t24/peW21hE2qvLzcXD/qDQALu5de/lHVb2TI9l5sIBDx0pcD7wFmblhPwUl5VyR7s/1A1J4a/72s848KSLSWtSWRHez1t5srX0ZuBoYXteNG2PGGmM2GGM2G2MerWb5z4wxq4wxy40xc40x3eq6D/Eg/xC49we48UNnqcbZxHaGLhc5e65Ljrk/Pmn2rh+QTKCfgzdOm3xl6uo9xIcH0Dc5yuVtXTcgmaeGBdEvxfXnHC/7aIzxonceKKixvttbTV65h5hQfzKiHfzPhV0IC/Tl8S/XYKsbH15EpJWpLYk+UfxmrT1zmrGzqBwe70WcvdjdgBuqSZLft9b2tNb2AZ4BnqvrfsTDojuCb4Dr6w99EAoPwbL33BeTtBiRwf5c2S+JL5bv5mBlb3BBSRnfb8zhwu5tqx3ZoybGGNqFunIayEk9EyMwBlY0cLzoNbuPMPLZmbw6Z+vZV/YSx4rLmLF+H+N6JOAwhqgQfx6+sAsLtx1k4ordZ9+AiEgLV9t/lN7GmLzKy1Gg1/HbxhhXfs8bCGy21m611pYAE4DLqq5gra26nRBA3RstXcpgSBrgPMGwvM7fzaQVun1oe0rKKvhg4U4AZm3Ioai0otYZBxtLWKAfabGhDe6J/vs3G6mw8OYP2yktbx7DxX23fj9FpRVc3Otk+cv1A1LolRTBnyev42gjnWR48FgJRaUai1tEmp8ak2hrrY+1NrzyEmat9a1yu/bT4Z0SgaqDvGZXPnYKY8x9xpgtOHuiH6zrC5Bmxhg45xdweAes00iJcnad48MYlhbDO/N3UFpewdTVe4kO8Wdg++gm2f/xkwvrW8KwZMchvlu/nyEd27DnSBHT1uxt5AjdY9LK3cSFBZBZpZ19HIYnL+tBTn4x/5rR8JMMjxSWMvb52Vz8wlxy8zWHl4g0L8ZdtW3GmKuBsdbauyvv3wIMstbeX8P6NwIXWmtvq2bZPcA9APHx8f0nTJjglpgbIj8/n9DQ6mdNk9PYcgYuvJ8y32Bmd/4DoWG1zxwnZ2ptx9vy/WU8v7SYn/T05521JQxM8OXOHnUoI6pUn3b7bmcpb68t4dlzg4gJqls5CMBfFxayK7+Cv44I5vF5hUQGGH432LURSjylsMzywHcFjEr25aauAWe02+uri5m7q4w/Dg0iMazubXLce+uK+XZHGX4OiAs2PDowiFB/10t0moPW9l5tLGq3+lG71U9t7TZq1Kgl1trM6pb5ujGmXUBylftJlY/VZALwn+oWWGtfAV4ByMzMtCNHjmykEBvPrFmz8Ma4vFbYwzDp/5FUtp0+Ix/wdDTNTms73kZUWD7fMYsJm0ooKoc7x/RlZJe4Om+nPu0WnX2Yt9fOIyixKyN7uT6yB8APm3NZ9/WPPHZxN8YN68DuwG38cdJa2qT1pacLY1V7yhfLdlFWsZyfXTSA/qnRZ7RbrwEljHp2Fl/tCeKDiwe7PGRgVev25DFj2hxuGpzCuB4J3PnmIv6z3pf37x5MRLALJyo3E63tvdpY1G71o3arn/q2W/27EM5uEZBujOlgjPEHrgdO+f3eGJNe5e54QIOQtha9b4DgGJKzPvd0JNIMOByG24a052hRGWGBvgztFNNk+85oG46/j6POddHWWv72zQYSIgK5aVAKANdkJhHi78Mb1Yx97U0mrdxNQkRgjaOfRIf48+sLu7Bg60G+Wrmnztu31vL4l6uJCPLj1xd04Zy0GF6+pT+b9uVz6xsLG63eWkTEndyWRFeO6HE/MA1YB3xkrV1jjHnSGHNp5Wr3G2PWGGOWAw8BZ5RySAvlFwQD76HNwSVwRNMJy9ldk5lEWKAvY7u3xd/Xnd//T+Xv66Bbu/A6T//93fr9LNt5mAfOSyfQzweA8EA/ru6fxKQVe8g56p01wEcKS5m9MZfxPRNqHf3kxoEp9EgM58+T15JfXLeThL9YvotF2w/x6LgMIoP9ARjZJY4Xb+rHml1HuP2NRRyr4zZFRJqaW/8TWWunWGs7W2s7WWv/XPnY49baiZW3f2Gt7W6t7WOtHWWtXePOeMTLpJ/vvM5e6Nk4pFkIC/RjyoPDefySph9Ovk9yJKuyj1Dm4sgaFRWWv3+zkZToYK7JPHWK89uGtqekvIL3ftzhjlAbbPrafZSUVzD+LKUrx08y3JdXzAt1OMkwr6iUp6asp09yJNf0Tz5l2Zhu8fzrhr4szzrMXW8torBEo3aIiPdquu4ckdPF96TC+EH2Yk9HIs1EcnQwYYFNXy/bOzmCwtJyNufku7T+1NV7Wbsnj1+en46fz6kfsx1jQxnZJZZ3F+ykpMz7hrubvHI3iZFB9EmOPOu6/VKiuDYzif/O2cpHi7LOuj7A89M3kZtfzJOXda+2p/uingk8d21vftx2kHveWazh70TEaymJFs/x9edoWEcl0eL1eic5E8qVLky6Ul5heW76BtLjQrmszxmjegJwxzkdyM0vZvIq75q05HBBCXM25XJxrwSXTxZ84pLunJMWw/98upJ/f7ep1qEA1+/N463527lhYAq9kmpO0i/rk8gzV/VizqZcfv7uEorLlEiLiPdREi0elRfeGfYsh3KdSCTeq32bEMICfVnuwsmFny/bxZacYzw0pjM+NdQUD0+LoWNsCG/M2+5VU2hPW7OXsgrLxb3aufyckABfXrttAJf3acez32zkiYlrqp3e3Hky4RrCAn15+IIuZ93uNZnJPHVFT2ZuyOHyF39gZSNMvS4i0piURItH5YV3gbIi2KdyePFeDochMzWKT5dk86dJa2ucGKSkrIJ/zthI93bhtc6o6HAY7hjanpXZR1i6073JYVFpOdtyj7lUFjFp5R5SooPpkejKfFon+fs6eO7aPtwzoiNvz9/BAx8sPWN/E1fsZuG2gzwyNoOoEH+XtnvjoBReuaU/B/KLufzFefx58lrVSYuI13DnONEiZ3U0rLPzRvYiaNfHs8GI1OIvV/bib9M28Pq8bby/cCd3nNOenwzveGJ0CYCPFmeRdbCQN27vcdZyiCv7JfHMtA28MW8b/VOrH0ruuNLyCjbty6eill7rvMJSsg8VknWogKyDBWQdKiTrYAH7K0cBad8mmP/c3J+uCdUnyAfyi/lhywF+OqJjvcZ9djgMv72oK3FhAfxp8joO5C/klVsziQjy42hRKX+evI7eSRFcl5l89o1VcUH3tgzq2Ianp67nv3O2MW3NPv5yZU/OSWu6YQ5FRKqjJFo8qigwDkJiYdcS4CeeDkekRm0jAvn7tb35+chO/HPGJl6cuYW3f9jB3cM7cuew9vj5OHjhu030T41iZJfYs24vJMCX6zKTeeOH7ew5UkhCRPWzGC7beYhHP13Fhn1HXYrTx2FIiAgkKSqIczvHkhwdTFSwHy98t5krXprHny/vyVX9k8543rQ1+yivsGcdleNs7h7ekdiwAH798Qque3k+b905kFfnbCUnv5j/3ppZ67B5NYkI8uMvV/bksj7t+M1nq7jp1R+5pn8Svxvf9ZQvMVVZa8nJL6aiwvm3ExFpbEqixbOMgaQBOrlQmo20uFBeuKEv943qxD+mb+Qf327kjR+20T8lin15xTx/XV+Xe3JvG9qe1+Zt490FO3j4woxTlh0rLuPZbzbw5g/biQ8L5K9X9SSqhoQRIDTAl+ToYNpGBJ4xIgjA2B4JPPjBMn718QoW7zjEE5d0OzF+NTgnWOkYE0K3Gnqq6+KyPom0CQngp+8s5vIX55FztJjrByTT24URP2ozuGMbpv5iOP+csYlXZm9l5oYcHh2XQYi/T2UP/Mme+OxDhRSXVeDv62DGQ+eSHB3c4NclIlKVkmjxvMT+sGEKFB6CoNp/1hbxFhltw3n5lkxWZh/muekbmbF+P8PSYhjSqY3L20iODub8rvG8/+POUyZl+X5jDr/9bBW7Dhdy8+AUHhmb0eCh/WLDAnjnroH8ffpG/jNrC6t3HeGlm/qRHB1MztFiFmw9wH2j0upVylGdYekxfPjTIdz+xkJCA33P+JJQX4F+PjwyNoOLeyXwyKcr+fXHK04sCw90fpFIiwtlVJc42kYE8vTU9bw+bxtPXNK9UfYvInKckmjxvKRM5/WuJZB2vmdjEamjXkmRvHnHQNbvzaNteN3LBu44pz3T1+5j4vLdjOkWzx8nreWzZbvoGBvCxz8bwoD20Y0Wq6+Pg0fGZtAvJYqHPlrOxS/M5fnr+pB9qIAKS51G5XBFj8QIvv7lCApLyol28WRCV3VvF8EX957Dwm0HCQ/yIzk6mIigM79orN2dx4eLsvjF6PQaSz9EROpDo3OI57XrBxjIXuLpSETqLaNteL2StCEd25DRNox/ztjE+c99z8QVu3ngvDSmPDi8URPoqsZ0i2fSA8NIjAzijjcX8fy3m0iLC6VzfGij7ysmNMBtpRS+Pg6GpsXQIzGi2gQa4CcjOlJQUs67C7xzhkgRab6URIvnBYZDbAbsUl20tD7GGO48pwO7DheSFBXEVw8M41cXdDmlXtkdUtuE8Nm9Q7kuM5kDx0q4tHe7Rivl8CZdE8IZ0TmWN3/YodkPRaRRqZxDvENSf1g/Bax1nmwo0opck5lEp7hQ+iRH1jhBizsE+vnw16t7cfPgVDISwppsv03tpyM6ctOrP/L5sl3cMDDF0+GISAuhnmjxDkkDoPAgHNzq6UhEmpwxhv6pUU2aQFfVMymi2hE9WoqhndrQvV04/52zlYpqZlMUEamPlvupKc1LYpWTC0VEGpExhntGdGRrzjG+XbfP0+GISAuhJFq8Q1xX8AtxzlwoItLIxvdMIDEyiFdm69cuEWkcSqLFOzh8ILGfJl0REbfw9XFw9/AOLN5xiCU7Dnk6HBFpAZREi/dI7A97V0FpkacjEZEW6NrMZCKC/Hhl9hZPhyIiLYCSaPEeSZlQUQp7V3o6EhFpgUICfLllcCrfrN3H1px8T4cjIs2ckmjxHsdPLlRJh4i4yW1D2+Pn4+DVuds8HYqINHNKosV7hCdAeJImXRERt4kNC+Cqfol8siSbnKPFng5HRJoxJdHiXZL6a4QOEXGru4d3pLS8grfnb/d0KCLSjCmJFu+SmAmHd0J+jqcjEZEWqlNsKOd3jeedBTsoKCnzdDgi0kwpiRbvkjTAea2SDhFxo5+d25HDBaV8tCjL06GISDOlJFq8S0JvMD46uVBE3Kp/ajT9U6P413ebWb3riKfDEZFmSEm0eBf/YIjvrrpoEXG7Z67uRZCfD9e9PJ+5m3Lr/Pyi0nKstW6ITESaAyXR4n2SBsDuZVBR4elIRKQF6xQbymf3DiU5Opg73lzIl8t3ufS8krIKXpixiV5/+IY3f9ju3iBFxGspiRbvk5QJxXmQu9HTkYhICxcfHsiHPx1Cv5QofjFhOa/O2Vrr+suzDnPpv+fy9+kb8fUxfLBwp3qjRVopJdHifU5MuqKSDhFxv4ggP966cyDjerTlT5PX8dSUdVRUnJoYF5SU8cdJa7nypXkcLijlv7dm8ui4DDbuy2f93qMeilxEPElJtHifNmkQGKEROkSkyQT6+fDvG/tx65BUXpm9lV99vILScmdJ2eyNOVzwj9m8NncbNw5K4ZuHRjCmWzzjeybg4zB84WIZiIi0LL6eDkDkDA4HJPaH7CWejkREWhEfh+F/L+1OfHggf5u2gQPHSogNDeDTpdl0jA3ho58OYWCH6BPrtwkNYHh6DF8t380jF2bgcBgPRi8iTU090eKdEjNh/xoozvd0JCLSihhjuG9UGs9c1Yt5m3P5cvku7h+VxpQHh5+SQB93eZ9Edh8pYvGOQx6IVkQ8ST3R4p2SBoCtgD3Lof0wT0cjIq3MtQOS6dI2jJAAH9Liwmpcb0y3eIL8fPhi+a5qk2wRabnUEy3eKbG/81qTroiIh/ROjqw1gQYICfBlTLd4pqzaQ0mZhuUUaU2URIt3CmkDUR10cqGIeL3L+rTjcEEpszfmeDoUEWlCSqLFeyUNgJ0/atIVEfFqIzrHEhXsx5crdns6FBFpQkqixXuljYZj+2HPMk9HIiJSIz8fBxf1TGD62r3kF5d5OhwRaSJKosV7pV8AxgfWT/Z0JCIitbq8byJFpRVMX7vX06GISBNREi3eKzgaUofC+imejkREpFb9U6JIjAzii2Uq6RBpLZREi3fLuBhy1sGBLZ6ORESkRg6H4dI+7Zi7OZfc/GJPhyMiTUBJtHi3jIuc1yrpEBEvd1mfdpRXWCav3OPpUESkCSiJFu8WmQJte8IGlXSIiHfLaBtORtswvly+y9OhiEgTcGsSbYwZa4zZYIzZbIx5tJrlDxlj1hpjVhpjZhhjUt0ZjzRTGRfDzgWQrzFYRcS7XdqnHUt3HmbngQJPhyIibua2JNoY4wO8CIwDugE3GGO6nbbaMiDTWtsL+AR4xl3xSDPW5SLAwsapno5ERKRWl/ZuB8DEFeqNFmnp3NkTPRDYbK3daq0tASYAl1VdwVo701p7/Ov6AiDJjfFIc9W2J0SkaJQOEfF6SVHBDGgfxRfLd2Ot9XQ4IuJG7kyiE4GsKvezKx+ryV2AuhrlTMZAxnjY8h0U53s6GhGRWl3WJ5HN+/NZuyfP06GIiBsZd31TNsZcDYy11t5def8WYJC19v5q1r0ZuB8411p7xthAxph7gHsA4uPj+0+YMMEtMTdEfn4+oaGhng6j2XG13SIPraTPisdY3f1RcmOHNEFk3k3HW/2o3epH7VY3R0ssv5xZwJhUPy5OKlHb1YOOufpRu9VPbe02atSoJdbazOqW+boxpl1AcpX7SZWPncIYcz7wO2pIoAGsta8ArwBkZmbakSNHNnqwDTVr1iy8MS5v53K7lQ+DDX+nh+8OGPkbt8fl7XS81Y/arX7UbnX3xe5FLN+dx7VdQtR29aBjrn7UbvVT33ZzZznHIiDdGNPBGOMPXA9MrLqCMaYv8DJwqbV2vxtjkebOxxe6jIMNU6G8zNPRiIjU6tI+7dibV8TfFhUxccVuikrLPR2SiDQytyXR1toynCUa04B1wEfW2jXGmCeNMZdWrvY3IBT42Biz3BgzsYbNiThH6Sg6DDt/8HQkIiK1urhXOx6+sAv7CywPfrCMQU/N4A8T17Bm9xFPhyYijcSd5RxYa6cAU0577PEqt8935/6lhUkbDb6BzlE6OozwdDQiIjXycRjuG5VGV7LwS+rBh4uyeP/Hnbz5w3Z6JIZzXWYyl/ZJJCLIz9Ohikg9acZCaT78Q6DjSOcU4Bo6SkSaAYcxDE+P5d839mPh70bzh0u6UV4Bj325hsFPzeDpqes5dKzE02GKSD0oiZbmJWM8HNkJe1d5OhIRkTqJDPbn9nM6MOXBYUx6YBgXdI/n5dlbGP7MTJ6bvpEjhaWeDlFE6kBJtDQvnccBBjZo4hURaZ6MMfRIjOCf1/dl2i9HMDw9hn/N2MSIZ2by4szNHCvWydMizYGSaGleQmMheRCsn+TpSEREGqxzfBj/ubk/kx4YRmZqFH+btoERz8zk1TlbNaKHiJdTEi3NT8Z4ZznHoR2ejkREpFH0SIzgtdsH8Nm9Q+nWLpw/TV7H0Ke/44+T1rJx31FPhyci1VASLc1Pxnjn9YYaZokvOQZz/wHPdoFFrzVdXCIiDdQvJYp37hrEh/cMZlCHaN6ev50L/jGby16cx/s/7uRokeqmRbyFW4e4E3GLNp0gNsNZ0jH4ZycfLy2Cxa/D3OfgWI5zOLwVE2DAXZ6LVUSkHgZ1bMOgjm04kF/M58t28dHiLH77+Sr+OGktF/VM4NrMJAZ2iMYY4+lQRVotJdHSPGWMh7nPQ8FB8A+FZe/A7Gfh6G7nGNKj3oMtM+D7Z5zrBEd7OmIRkTprExrA3cM7ctewDizPOsxHi7P4asUePl2azW1DUvnfy3p4OkSRVkvlHNI8ZYwHWw7Tfgv/7g+TH4LIFLjtK+clZRCkXwBY2PKdp6MVEWkQYwx9U6L4y5W9WPi70Yzr0ZZPlmTr5EMRD1ISLc1TQl8IawcrPoCgaLjpU7jz61NnMmzXF4LbwKZvPBeniEgjC/b35boByRwrKWfe5lxPhyPSaqmcQ5onhwOueROKjkD6GKiuLtDhA51Gw+ZvoaLceV9EpAUY2imGsEBfpq7ey+iu8Z4OR6RVUk+0NF8pg6DzBdUn0MelXwAFB2D3sqaLS0TEzfx9HYzpGs/0tfsoLa/wdDgirZKSaGnZ0kYDBjZN93QkIiKNamyPthwpLGXB1gOeDkWkVVISLS1bcDQkDVBdtIi0OCM6xxLs78PU1Xs9HYpIq6QkWlq+9Atg91LIz/F0JCIijSbQz4dRGXF8s2Yv5RXW0+GItDpKoqXlSz/feb1lhmfjEBFpZON6tCU3v4TF2w96OhSRVkdJtLR8bXtDSJxKOkSkxRnZJQ5/X4dKOkQ8QEm0tHwOh3MYvM0zoLzM09GIiDSa0ABfRqTHMm3NXipU0iHSpJRES+uQPgaKDsOuxZ6ORESkUY3r0ZY9R4pYkX3Y06GItCpKoqV16DgKjI+GuhORFuf8rvH4Ogxfq6RDpEkpiZbWISgSkgepLlpEWpyIYD+GpsUwdfVerFVJh0hTURItrUf6GNi7Eo6qt0ZEWpZxPdqy82ABa/fkuX1fL87czC2v/ej2/Yh4OyXR0nqkX+C83vytZ+MQEWlkF3SLx2Fwe0nHwWMlvDhzM3M25bIt95hb9yXi7ZRES+sR3x3C2qmkQ0RanDahAQzsEO32JPr1udsoKCkHYNaG/W7dl4i3UxItrYcxzolXtsyE8lJPRyMi0qjG9Uhg0/58Nu/Pd8v2jxSW8tYP27moZ1s6xoYwa4NmgZXWTUm0tC7pF0BxHmSpnk9EWpYLu7cF4OvVe9yy/bd+2M7R4jLuH5XOqC5xzN96gMLKXmmR1khJtLQuHc4Fh5+GuhORFqdtRCD9UiLdMnthfnEZr8/bxvld4+jWLpyRXWIpKatg/tbcRt+XSHOhJFpal8BwSB2iJFpEWqRxPRJYszuPnQcKGnW77y7YweGCUu4/Lx2AgR2iCfLzYeZ6lXRI66UkWlqftDGwfw0cyfZ0JCIijWpsj8qSjjWNV9JRWFLOq3O2Mjw9hj7JkQAE+PpwTloMMzfs19jU0mopiZbWR0PdiUgLlRwdTI/E8EYt6fhg4U5y80t4cHT6KY+Pyogl+1AhW3I01J20TkqipfWJ7QIRKSrpEJEWaVyPBJbtPMyeI4UN3lZxWTkvz97CoA7RDGgffcqykV3igMYd6m734UIu+Mf37MjTCYvi/ZRES+tjjHP2wq2zoKzY09GIiDSq4yUdf5mynqNFDRvO8+PF2ezLKz6jFxogMTKIzvGhzGzEJPrdBTvYuC+fWVlljbZNEXdREi2tU/oYKMmHZe96OhIRkUbVKTaU+0Z1YtLK3Yx5bjbfrt1Xr+2Ullfwn1lb6JsSydBObapdZ1SXOBZuO8ix4oYnvSVlFXy0OAuAxfvKKCuvaPA2RdxJSbS0Tp1GQ4cRMPkhmPcv0IkxItKCPHxhBp/dew4RQX7c/fZi7nt/KTlH6/bL2+fLdrHrcCEPnpeOMabadUZ2iaO03DJvc8OHuvt6zV5y80u4cVAKR0tgwdaDDd6miDspiZbWydcfbvoEul8B0x+Dab+DCvV6iEjL0Sc5kq8eGMavL+jM9DX7OP+57/lkSbZLo2mUV1hemrmZHonOMaFrktk+itAAX2Y2wuyF7y7YQWqbYB4b341AH5i0cneDt1kX1lpuee1HPlmikZvENUqipfXyDYCrXodBP4MFL8JnP4GyEk9HJSLSaPx9Hdx/XjpTfjGczvGh/PrjFdz6+kKyDtY+jvSklbvZfqCA+0fV3AsN4OfjYFhaDN83cKi7jfuOsnDbQW4cmEKQvw994nz4es1eSpuwpGPdnqPM2ZTLC99toqJCv07K2fl6OgARj3I4YOzTENYWvv0DFOTCte84J2UREWkh0uJC+fCeIby3cCd/nbqe0c99T+f4UJKjgkmODiY5Koik6GCSo4JJjAzi399tpkt8GBd0iz/rtkdlxPL1mr1s3JdPl7Zh9Yrv/R934u/j4Or+SQAMSvBlwZ5i5m3OPTEKiLvN3uTsTd9xoIA5m3M5t3PNPfAioCRaxDlax7D/B6Hx8OX98OZ4uPlTCG2aD24RkabgcBhuGZzK+V3j+O/sbWxTkR+9AAAgAElEQVTJyWfDvqPMWL+fkrIze3z/dUNfHI6ae6GPO7ez87Ny5ob99UqiC0rK+HRJNhf1bEub0AAAesT4EBbgy6SVe5ouid6YQ6fYEI4UlvLugh1KouWslESLHNfnRgiJhY9uhdfGwM2fQZtOno5KRKRRJUQE8fgl3U7cr6iw5OYXk3WogKyDhWQdLMAC43smuLS9thGBdE0IZ+b6/fzs3Lp/Zk5cvpujxWXcPDj1xGN+DsOY7vFMW7OXp67oib+ve6tPC0rKWLz9ELef0x5fh+H/vt/C7sOFtIsMcut+pXlTTbRIVelj4LZJUHwUXrsAdi31dEQiIm7lcBjiwgPpnxrN5X0TeWB0Og+OTsfHhV7o40Z1iWXJjkPk1XFcamst7/64g4y2YfRPjTpl2SW92nG0qIw5mxp+0uLZLNh6gJLyCkakx3LDwBQsMGHhTrfvV5o3JdEip0vqD3d+A/7B8ObFsHmGpyMSEfFqozLiKKuwzNtUt6HuVmQfYfWuPG4alHLGCYznpMUQEeTH5JV7GjPUan2/IYdAPweZ7aNIjg5mZOdYJizKatITG6X5cWsSbYwZa4zZYIzZbIx5tJrlI4wxS40xZcaYq90Zi0idxKTBXdMhuiO8fy2s+NDTEYmIeK2+yZGEB/rWefbC9xbsINjfh8v7Jp6xzN/XwYXd4/lm7T6KSt07DfjsTbkM7tiGQD8fAG4enMr+o8X1nqhGGo+1loIS75zB0m1JtDHGB3gRGAd0A24wxnQ7bbWdwO3A++6KQ6TewtrCHZMhdSh8fo9zUhYRETmDr4+D4Z1jmbUhx+Wh7o4UlPLVyt1c3jeRsEC/atcZ36sd+cVlzN7ovpKOrIMFbMs9xoj0kycSjuwSR2JkEO/+uMNt+xXXvDZ3Gxe/MJfc/LpNFtQU3NkTPRDYbK3daq0tASYAl1VdwVq73Vq7EtDvJeKdAiNOnZTl699qUhYRkWqM6hLH/qPFrN2T59L6nyzNpqi0gpsHpda4ztBObYgK9mOSG0s6vq9M0EdUGY3Dx2G4YWAy8zYfYGtOvtv27aqi0nJue30hj3+5mqN1rDtvDH//ZgN/nry2yfe7cNtB/jJ1PWmxobQJ8W/y/Z+NO5PoRCCryv3sysdEmhdNyiIiclbHh4Sb5cLshdZa3vtxB/1SIunWruZx+f18HIzt0ZZv1+2jsMQ9JR2zN+aQGBlEp9iQUx6/dkAyvg7Dez+6doLhzPX7ue7l+ezPK2r0GJ+eup7vN+bw7oIdjHluNtObsMxkVfYRXvhuM/+ds41F25tuKvb9eUXc9/5SUqKDefba3rVO+uMppiEzDNW6YWeN81hr7d2V928BBllr769m3TeBSdbaT2rY1j3APQDx8fH9J0yY4JaYGyI/P5/Q0FBPh9HsNKt2s5bkrM/otPVtDkb1Zk33Ryn3DfZIKM2q3byI2q1+1G7119ra7g8/FOLngN8Nrn1ouLUHynlmURE/6enPOYlnlnJUbbfj697XJ4ABbRt3ZN6yCsv9MwoYnODL7T0Czlj+0vIi1hwo5x8jg/H3qTmJ236knKcWFlFSDucm+XJHNduqr5U5ZTy3pJgxqb4MSfDl9dXFZOdbBrb14aauAUQEnIyrsY83ay1PLyxi97EKfI0hKtDw+8GBONyc0JZVWJ5ZVMT2IxU8NiSI5DD3joNRW7uNGjVqibU2s7pl7hwneheQXOV+UuVjdWatfQV4BSAzM9OOHDmywcE1tlmzZuGNcXm75tduo2D5EKK/vJ/hO56HO6c5J2tpYs2v3byD2q1+1G7119ra7tKSDfx75mb6DBxKZHDNP79//N5SIoNz+dW15504ma+qqu02rLyC19fNYHt5NA+P7Neo8S7cdpCi8vlcP7IXI3ucOS52QPIBbvjvAvIi00/Mpni67EMFPPzSD8SGBTGoQzRfLN/Fb68eWu/ZG6s6kF/Mr5+fQ5f4MF64+xwC/Xy4+eIKXv5+Cy98t5kNR0r5/fiuXN0/CWNMox9v09fuY8Ohxfzxsu4E+/vyq49XkB/dhUt7t2u0fVTnT5PWsvHQNp6/rk+1J502tvq2mztT+0VAujGmgzHGH7gemOjG/Yk0jT43wkV/g6wfYftcT0cjIuI1RmbEUWFhTi1D3e3PK2Lamr1c0z+p2gT6dL6VJR0z1u9r9FEaZm/MwcdhGJoWU+3ywR2j6RQbwrsLqj/BMK+olDvfXERRaTlv3DGAxy/pRmiAL09NWdfg2Ky1PPLpKvIKS3n++j4n2srf18EDo9OZ8ovhdI4P5eFPVnLLawvZeaCgwfusqrS8gr9MXUen2BCuH5jCFX0T6ZYQzl+nrnfraCmTV+7h1bnbuHVIapMk0A3htiTaWlsG3A9MA9YBH1lr1xhjnjTGXApgjBlgjMkGrgFeNsascVc8Io2qz40QGAmLX/N0JCIiXqN3UiRRwX78afJa7nl7MU9+tZY35m3j27X72LD3KAUlZXy4KIuyCsuNtZxQeLqLe7WjqLSCGevqNoTe2Xy/MadyeL7qRwcxxnDToFSWZx1m9a4jpywrLa/g3neXsjXnGP93c386x4cRGezPg6PT+X5jToNHFPlgYRbfrtvH/4ztQteEM+vG0+JC+fCeIfzx8h4szzrMBc9/z/fZjXfS4YSFO9mac4zfjOuKn48Dh8Pw+/Fd2XW4kLfnb2+0/VS1ef9R/ueTFfRNieT3408f0M37uHXab2vtFGDKaY89XuX2IpxlHiLNi18Q9LkJFr4M+fshNM7TEYmIeJyPw/D4Jd34asUetuUeY86mXApP67V0GBieHkOHmJAatnKmAe2jiQ0LYNLK3VzSSKUEB/KLWb37CP/v/M61rndV/ySembae937cwV+u7AU4e4l///lq5m7O5W9X9+KcKj3ZtwxJ5a3523lqyjrOSYup08yPx23NyeePk9YyLC2GO8/pUON6DofhlsGpjM6I4+FPVvDG6gMc+2QFT17Ww6Ve/prkFZXyj283MbhjNKO7nvz/NjQthvMy4njhu81c3T+Z6EYcMSO/uIyfvbuUQD8fXrqpn9unem8M3h+hiLfKvBMqymDp256ORETEa1zRN4nXbx/A9IfOZe2TF7L49+fz+b1D+dcNfXn4wi7cNCiVR8Zm1GmbPg7D+J4JzNyQQ35x45R0zN2ci7WnDm1XnYggPy7t3Y4vlu0+Ma35S7O28OHiLB44L41rMpNPWT/A14dHxmawfu9RPl2SXee4Sssr+OWHywnwc/D3a3vjcCEJbxcZxNt3DuKSTn58tDibK1/6gR0HjtV538f9Z9YWDh4r4XcXdTtjVIzfjMugoKScf83YVO/tn85ayyOfrGRrTj4v3NCXhIjaT0z1FkqiReorJg06nAtL3oQK986mJSLSHBljiAkNoG9KFJf2bsd9o9L44+U96JEYUedtje+VQElZRaPNIvj9xhwig/3o6UIsNw9OpbC0nM+X7uLL5bv427QNXNanHQ+Nqb4Xe3zPBPqmRPLsNxvqXMf9/LcbWZl9hKev7El8eKDLz/NxGK5K9+f12zPZdbiQi1+Yyzdr9tZp3wC7Dhfy2txtXNk3kZ5JZ7ZNenwY1w9I5t0FO9iWW/9EvarX5m5j8qo9/PrCLjXWp3sjJdEiDTHgLjiSBZumezoSEZEWrX9KFG3DA5m0cg8lZRVszz3GnE05vP/jTv769Xruf38pl704j/veX3rWE9+stczZlMswF8steiVF0ispgv/M2sLDH69kYPtonrm6V41jFxvjrB/ef7SY/87e5vJrXLjtIC/N2sK1mUmMrWa0EFeclxHPpAeG0b5NCPe8s4Snp66nrNz1ScKenbYBA/zqwi41rvPL8zsT4Ovgr1PX1yvG4zbsPcqTX63lL1PXc0G3eH5+bqcGba+pubUmWqTF63IRhLZ1nmDYZaynoxERabEcDsNFPRN444dtZDw2lYoq01z4OgyJUUG0DQ9k8so9hAf6nqhfrs66PUfJOVp8YoIYV9w0KIVHPl1Fx5gQXrm1PwG+tdcc90+N5qKebXl59hZuGJhM3Fl6lfOKSvl/Hy4nJTqYJy7p7nJc1UmODubjnw3hyUlr+b/vt7A86xAv3NCP2LDax69emX2Yz5ft4t6RnUiMrLmkIjYsgJ+P7MSz32xk4baDDOwQ7XJseUWlfLViNx8tzmZF1mH8fJx/1z9f0cMrJ1SpjZJokYbw8YN+t8Lsv8Gh7RDV3tMRiYi0WHcOa09RWTkxoQEkRwWRHB1McnQwbcMDT/QoP/P1el6atYW+KVFce1q98nGzN5051ffZXNYnkT1HiriqX1KtY2BX9cjYDKav3cdz0zfy9FU1J/Vrd+fxv1+tYW9eEZ/8bAghAQ1PzwL9fHjqip70T4nid1+sYtw/53DL4FSuzkyqNkG21vLnyetoE+LPz0eevUf4rmEdeXfBTv48eS2f33tOrbXb1lp+3HaQjxZnMWXVHopKK+gSH8ZjF3fjir6JjXqCYlNSEi3SUP1vgznPwpK34PwnPB2NiEiLlRQVzFNX9Kx1nV9d0IUV2Yd57IvVdEsIr7b+evbGHDLahtWp5jjQz4dfnmUkj9Oltgnh1iHteWPeNm4/pz0ZbU8dqm7TvqM8/+0mJq+q7D2/oid9U6LqtI+zuap/Et3ahfOnyWv5x7cbeX7GRoanx3JdZjLnd4s70aP+7br9/LjtIH+8rDthNQz5V1WQvw8PX9iFX328gkmr9pwxAcuB/GIWbD3I/K25zN6Yy86DBYQF+HJlvySuy0ymV1JEs+t5Pp2SaJGGikiCzuNg2Tsw8jfg2zy/UYuItAQ+DsO/ru/LxS/M5efvLWHS/cOJCD6ZFB4rLmPR9oPcUcvQcY3pgfPS+HhxFn+Zsp637hwIwPbcY/xzxia+WL6LYD8fHjwvjbuGdyQi6OzJa310TQjnvbsHk3WwgI+XZPPJ4izue38pUcF+XN43kav6JZ0ysYqrruibyGtzt/HXqesZ2qkNy3ce5octB/hhSy7r9x4FIMTfh4Edovnl+emM65FAkH/9h97zNkqiRRrDgDthw2RYNxF6Xu3paEREWrU2oQG8dFM/rn15Pr/8cBmv3TbgRLnBgq0HKC23jEh3vZSjIY5PwPKnyev4aHEWS3cc4uMl2fj5GO4Z3pGfntupycoZkqODeWhMZ34xOp25m3P5aHEW7y3YyRvztgPw6q2Z+Pm4PubE8QlYbnz1RzL/9C0AAb4OMttH8fCFXRjSqQ09EyPqtM3mREm0SGPoeJ6zHnrx60qiRUS8QN+UKB6/uBuPfbmGf8/czIOj0wFnKUegnzPRayq3DEnl7fk7+J9PVuLv4+CWwancO6oTcWGul5M0Jh+H4dzOsZzbOZaDx0r4Ytku8ovLTplYxVVD02J4ZGwGhSVlDE2LoU9yZIMmemlOlESLNAaHA/rfAd8+AfvXQVxXT0ckItLq3Tw4laU7D/OPbzfSKymCkV3imL0pl8Ed2zRpohfg68Nz1/Zm+tp93Da0Pe1qGfmiqUWH+HPnsIaVtrhyImJL1DL710U8oe/N4OMPi9/wdCQiIoJzvOanruhJl/gwfvnhcuZvOcC23GNNVspRVWb7aH5zUVevSqClYZREizSWkBjodjms+ABKGmcWJxERaZggfx/+c3N/ysstd7y5EKjb0HYiNVESLdKYMu+E4jxY9YmnIxERkUodYkL4+7W9KSqtIDEyiE6xIZ4OSVoA1USLNKaUwRDXzTmDYb9boZmPgSki0lJc0L0tT13Rk7BA32Y/PrF4B/VEizQmY5y90XtWwK6lno5GRESquHFQCpecNimISH0piRZpbL2uA78QmPUUlBZ6OhoRERFxAyXRIo0tMBxGPwabv4VXx8CBLZ6OSERERBqZkmgRdxj8c7jxYziSBa+MgvWTPR2RiIiINCIl0SLu0vkC+OlsiO4AE26E6Y9DeZmnoxIREZFGoCRaxJ2iUuHOac7ZDOf9E965HI7u83RUIiIi0kBKokXczS8QLnkeLv8/yF4ML4+AHfM9HZWIiIg0gJJokabS5wb4yQzwD4E3x8P0J6DgoKejEhERkXpQEi3SlOK7wz0zode1zvKOf/aGWU9D0RFPRyYiIiJ1oCRapKkFRsAV/wc//wE6nguz/gLP94I5z0HJMU9HJyIiIi5QEi3iKfHd4Lp34Z7vIXkQzPhfZ8/0/Bc1SYuIiIiXUxIt4mnt+sBNH8Fd0yGuG0z7LfyrLyz8L5SVeDo6ERERqYaSaBFvkTwQbpsIt02CyFSY8mt4oT8sfUfjS4uIiHgZJdEi3qbDcLjza7j5UwhpAxPvhxcHwMqPoKLc09GJiIgISqJFvJMxkHY+/GQmXP8B+AXDZz+B/wyFNV+ArfB0hCIiIq2ar6cDEJFaGAMZF0HnsbD2C+dIHh/fxsCgBNiaUvPzIpJg9BPOGRNFRESk0aknWqQ5cDigx5Vw7wK44mUKgxLAL6j6i28gbJwGLw2BBf9RCYiIiIgbqCdapDlx+EDv61l1qC0jR46seb3DWTD5Ifj6UVj1CVz6gnNIPREREWkU6okWaYkik+HGj+Cq1+DQNnh5BMx8CsqKPR2ZiIhIi6AkWqSlMgZ6Xg33LXKWgnz/V/i/4bDzR09HJiIi0uypnEOkpQtpA1e+Aj2vhUm/hNcvhLTR0CYNIlOcY1JHpTqvA8M9Ha2IiEizoCRapLVIP995YuL3T8OWmc4e6ZKjp64TFOVMpjuMgL63QGxnz8QqIiLi5ZREi7QmAaFwwZ+ct62FwkNwaDsc3gGHdjivD2yG+S/CD/+C5EHOZLr7Fc7nioiICKAkWqT1MgaCo52XxH6nLju6D1ZOcE45PvF+5ygf3a9wJtTJA53PFRERacWURIvImcLi4ZxfwNAHIWshLHsbVn8Gy96BmM7QZRy0HwEpg9VDLSIirZKSaBGpmTGQMsh5Gfu0c8rxlR/C/Jdg3j/B4QuJmc4a6g4jIGkA+AW6tu3SQji882QZyaHtzvvB0dDnJue21OMtIiJeSkm0iLgmIAz63eK8lBRA1gLYNtt5mfMszH7GOVtiQp/aE+mSY87E+dj+Ux/3DYSIZMjbDUvehJgu0Pdm6H0DhMY2LPaCg7DqY7qt+RIisqHb5epBFxGRBnFrEm2MGQv8E/ABXrXWPn3a8gDgbaA/cAC4zlq73Z0xiUgj8A+GTuc5LwBFR2DHfGdCvXuZs5e5Jn7B0PnCk8PqHR9iLyTOOb158VFY87mzHnv6YzDjf6HzWGc9dtr54OPix1ZFBWybBcvehXWToLyYKN8w+HIeTH3EOXZ231vU412boiOw+lO6rfkUwnY42ywgzNNRiYh4Bbcl0cYYH+BFYAyQDSwyxky01q6tstpdwCFrbZox5nrgr8B17opJRNwkMAK6jHVeGiogDPrd6rzsX++sw14xAdZPgrAESD3nZAJ+/DoiCXz8nM8/vBOWvw/L3oMjOyEwEvrfDn1vZt76A4zsGOhMrFd9AkvfhtgMZ493r+sb3uPdElgLO+Y5v8Ss/RLKCp1fPr6ae+oJpimDa//ykb8fts9xfrEqLYT2w5wlP1Htm+yliEg1yssgL7tKKV3ldckx56+Bp3++NuX8AeVlkLerSlw7nbcLDsDNnzZdHC5yZ0/0QGCztXYrgDFmAnAZUDWJvgz4Q+XtT4B/G2OMtda6MS4RaS7iMuDCP8PoJ2DTNFj+AWQvcvZU2/KT6xkHhCdBcBTsWel8rONIOP8JyLj4ZHnJhlmQOsR5Gfd05cmS78I3v4dv/wDJg8E3wD2vxRgIjT9zgpuwBGcPfGMpOXZarXnltW+gc99V/0FGJJ/88pG3u/LLx7vOqeIDwqH39dDvFuZtzGNkWujJE0yXvwdt0k+W24TFO4dL3D7vZIlPzjrndgPCnfte+aHzfkTKyRr6DsMhvJ1rr8taOJZT+dq2n3xtR/dARflZn14j/+DKX0Sq/l1SwD+k/tusq/JSOJJ18m91/O9XeMh9+zQOCGtb+XrbnzwuQuNO/XJUXgpHsk89llyJLTD8ZLse30dkcuO+v8pLnQnX6cd6aWHl3/O091pdSrisdZaBHd5+ajKXt8c5gVXVNotMcb63G/N9XHz01P0e2uE8RvyCz0xywxNP/YXOWsjfd1q7bD95/8iu6j8/A0Jh25ya5w+o+nqj2p+87ep5MNXFdvpxlbcLKspOiy3Rua+yEvD1r09ruo07k+hEIKvK/WxgUE3rWGvLjDFHgDZArhvjEpHmxtcful7ivEA1vRVVEqpzH4E+Nzo/8GsTEAb9b3Nejvd4Z/0IZUXueQ22HPatccZYlY+/M5mNSASHX/23X3TY2QYFp318+gY5/9GVFdXw5SMRQmJgzwqwFZA6DEY+Cl0vdSaYAJtmQfIA5+XCv8DaL5zJ9rdPwIwnnbNf5m4ErPOffMpg6H2dM1Fu2xscPs7l22bDtu+dvyosf9e57TZpzn+QtbXb0b3OZKK04NRlwTENb7cjWbBp+pl/95DYyl64iPpvG+h18CBkRVe/sKzI+brydjnb/jjj4/x1JSQGcFOpUUUZ7Fnu/GJS1fHjJTjamWzlnZ5w+TjbPCS2ltis84vYuklQUVrlceP80hiV6jxOalF7uxVXabdqYvMLhi3fVXO8tHH+TYMia47dVjh/RTm8A0ryT10WFAVh7WD3UmciWNXxczrC2zlPuK6X42P374DCg6cu8gtxfgkpKYDVn1R/vIQnMiB3J8zNPfN4Do13vvbkQdAz9dREPDzx5JfpmuYPOLTD+fm1YSqUl5y27covY/61fEmx5c4v6od3VvNei3M+P2kARF196pfZql/0vZBxV6evMeZqYKy19u7K+7cAg6y191dZZ3XlOtmV97dUrpN72rbuAe4BiI+P7z9hwgS3xNwQ+fn5hIbqRKW6UrvVj9qtfryh3RzlJQQU7yeocD+BRfsqL/sJKM7FNODzuNwnkMKgeIoCT14Kg+Ip9Ys40bNoKsoJKM4lsOjMfeeFZ7C37fkUBiecse2a2i2oIJuEPTMIzd/GkYgMDkf2Ii88HXu2pNZWEJq/ncjDq4g8vAr/kiO1rl7iH0VhUNwpr60oMI5y3yDXG6jWeCz+JYertMk+ggqdbeNT3rAvVeUV5fg4fKpdVuHwpTggtsrfzfkaiwNisDU8p7E5yosILNp/4vUef/1+pUcpDohpWGy2nIDigye269zHPgKLcnBUlNT61LO3W8yJY/z4MVEc0AZ7PIG1Fr/SI6f8LY/H4VtWUO12jyvxjzjxeqvuo9z3ZOLvKC8+pb2Ov5/9Sw426H1c5ht8or2rvrZSv/Aq7+Oyyvdx1TZ1vo8LTQhloYmnvV/iqPBppF8AbAX+JYeq7PfkceNzenJd9WnGUOIffaJdna/NebvRYmuA2v43jBo1aom1NrO6Ze7sid4FJFe5n1T5WHXrZBtjfIEInCcYnsJa+wrwCkBmZqYdOXKkO+JtkFmzZuGNcXk7tVv9qN3qp6W3W1QDn1tTf3Dt7XYzADX0GbZ6Lf2Ycxe1W/0sV7vVS32Pt0Ys4DnDIiDdGNPBGOMPXA9MPG2dicBtlbevBr5TPbSIiIiIeDu39URX1jjfD0zDOcTd69baNcaYJ4HF1tqJwGvAO8aYzcBBnIm2iIiIiIhXc+s40dbaKcCU0x57vMrtIuAad8YgIiIiItLY3FnOISIiIiLSIimJFhERERGpIyXRIiIiIiJ1pCRaRERERKSOlESLiIiIiNSRkmgRERERkTpSEi0iIiIiUkdKokVERERE6khJtIiIiIhIHSmJFhERERGpIyXRIiIiIiJ1pCRaRERERKSOlESLiIiIiNSRkmgRERERkTpSEi0iIiIiUkfGWuvpGOrEGJMD7PB0HNWIAXI9HUQzpHarH7Vb/ajd6kftVn9qu/pRu9WP2q1+amu3VGttbHULml0S7a2MMYuttZmejqO5UbvVj9qtftRu9aN2qz+1Xf2o3epH7VY/9W03lXOIiIiIiNSRkmgRERERkTpSEt14XvF0AM2U2q1+1G71o3arH7Vb/ant6kftVj9qt/qpV7upJlpEREREpI7UEy0iIiIiUkdKouvIGDPWGLPBGLPZGPNoNcsfMsasNcasNMbMMMakeiJOb+NCu/3MGLPKGLPcGDPXGNPNE3F6m7O1W5X1rjLGWGOMzsrGpePtdmNMTuXxttwYc7cn4vQ2rhxvxphrKz/j1hhj3m/qGL2RC8fbP6ocaxuNMYc9Eae3caHdUowxM40xyyr/p17kiTi9jQvtllqZf6w0xswyxiR5Ik5vY4x53Riz3xizuoblxhjzr8p2XWmM6XfWjVprdXHxAvgAW4COgD+wAuh22jqjgODK2z8HPvR03J6+uNhu4VVuXwp87em4PX1xpd0q1wsDZgMLgExPx+3pi4vH2+3Avz0dqzddXGy3dGAZEFV5P87TcXv64ur7tMr6DwCvezpuT19cPN5eAX5eebsbsN3TcXv64mK7fQzcVnn7POAdT8ftDRdgBNAPWF3D8ouAqYABBgM/nm2b6omum4HAZmvtVmttCTABuKzqCtbamdbagsq7CwB9A3St3fKq3A0BVKzvQrtV+iPwV6CoKYPzYq62m5zKlXb7CfCitfYQgLV2fxPH6I3qerzdAHzQJJF5N1fazQLhlbcjgN1NGJ+3cqXdugHfVd6eWc3yVslaOxs4WMsqlwFvW6cFQKQxJqG2bSqJrptEIKvK/ezKx2pyF85vNa2dS+1mjLnPGLMFeAZ4sIli82ZnbbfKn5uSrbWTmzIwL+fq+/Sqyp/sPjHGJDdNaF7NlXbrDHQ2xswzxiwwxoxtsui8l8v/FyrL+zpwMsFpzVxptz8ANxtjsoEpOHvxWztX2m0FcGXl7SuAMGNMmyaIrbmra46nJNpdjDE3A5nA3zwdS3NhrX3RWtsJeAT4vafj8XbGGAfwHPArT8fSDH0FtLfW9gKmA295ODv+WloAAARHSURBVJ7mwhdnScdInD2q/zXGRHo0oubleuATa225pwNpJm4A3rTWJuH8qf2dys89qd2vgXONMcuAc4FdgI45N9DBWDe7gKo9VkmVj53CGHM+8DvgUmttcRPF5s1carcqJgCXuzWi5uFs7RYG9ABmGWO246zhmqiTC89+vFlrD1R5b74K9G+i2LyZK+/TbGCitbbUWrsN2IgzqW7N6vL5dj0q5TjOlXa7C/gIwFo7HwgEYpokOu/lyufbbmvtldbavjhzEay1Opn17OqaqyiJrqNFQLoxpoMxxh/nB+LEqisYY/oCL+NMoFUv6ORKu1X9Rzwe2NSE8XmrWtvNWnvEWhtjrW1vrW2Pswb/UmvtYs+E6zVcOd6q1rldCqxrwvi81VnbDfgCZy80xpgYnOUdW5sySC/kSrthjMkAooD5TRyft3Kl3XYCowGMMV1xJtE5TRql93Hl8y2mSo/9b4DXmzjG5moicGvlKB2DgSPW2j21PcG3aeJqGay1ZcaY+4FpOM+Qfd1au8YY8ySw2Fo7EWf5xv9v745BrDijMAy/H7KIaNxGt14ELVKERbQUUoiFhSIK2rmWEg2I2BpEyIqdkIALadKokDbNLoI2tomCCoagkDIgKZQIUTkp/hFkFb0jrHdn932qO8zc4czhXjjM/HPOJuCXJAB/VdWBsQW9AoyYt1PdHfyXwD/A8fFFvDKMmDctMWLevk1yAHhFe9FkdmwBrxAj5m0B2JfkIe3x8Lmqejq+qMevx//0GHCjujYAa92IeTtLWzJ0hvaS4exaz9+IefsamEtStM5N34wt4BUkyXVabrZ06+y/AyYAquoqbd39fuBP4F/gxEfPucZ/j5IkSVJvLueQJEmSerKIliRJknqyiJYkSZJ6soiWJEmSerKIliRJknqyiJakgUnyOsndJA+S3Ety9mOT3JJMJ7nffZ5Jsv/zRCtJq5N9oiVpeF5U1QxAkingGrCZ1vd0FDPALlpfVEnSJ7BPtCQNTJLnVbXpre1ttElmW2hPGC/RhgqsB36sqvkk08CvwE7aMIENtJG2c8AT4AptItwL4ERVPfpMlyNJg+SdaEkauKp6nGQdMAUcpI2r3Z1kPXAnySJt4htV9V+S88CuqjoFkGQzsKebhrYX+B44PJaLkaSBsIiWpNVlH/BVkiPd9iSwHfjjA9+ZBH5Osp1WbE8sb4iSNHwW0ZI0cN1yjtfA30CA01W1sOSY6Q+c4iJwq6oOdcfdXo44JWk1sTuHJA1Ykq3AVeCHai+5LAAnk0x0+3ck2bjka8+AL97anqStjwaYXd6IJWl1sIiWpOHZ8KbFHXATWAQudPt+Ah4Cv3Ut7eZ596njLeDL7hxHgcvAXJLf33OsJOk97M4hSZIk9eSdaEmSJKkni2hJkiSpJ4toSZIkqSeLaEmSJKkni2hJkiSpJ4toSZIkqSeLaEmSJKkni2hJkiSpp/8BttMdJCSyE2wAAAAASUVORK5CYII=\n",
            "text/plain": [
              "<Figure size 864x576 with 1 Axes>"
            ]
          },
          "metadata": {
            "needs_background": "light"
          }
        }
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "eLutyNZwl2D_",
        "outputId": "766ad8d5-fae1-409e-8996-e59f80f20372"
      },
      "source": [
        "plt.grid()"
      ],
      "execution_count": null,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "image/png": "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\n",
            "text/plain": [
              "<Figure size 432x288 with 1 Axes>"
            ]
          },
          "metadata": {
            "needs_background": "light"
          }
        }
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "id": "pQMdutsma9LG",
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "outputId": "bf6474db-af42-4b7d-a9bd-90600deaae6a"
      },
      "source": [
        "T=1000\n",
        "gap = 0.001\n",
        "delta = np.exp(-T*p_best*gap**2 / (np.log(1/(p_best*gap**2) * np.log(T*p_best*gap**2)) ))\n",
        "delta = 0.01\n",
        "epsilon = 0.2\n",
        "means = np.array([0.2,0.79,0.8])\n",
        "probs = np.array([0.4,0.4,0.2])\n",
        "mu_best = means[-1]\n",
        "p_best = probs[-1]\n",
        "def sample_mean():\n",
        "  return np.random.choice(means, 1, p=probs)[0]\n",
        "bandits = InfBandits(sample_mean,p_best,mu_best)\n",
        "nb_mc = 100\n",
        "regrets_avg = np.array(np.zeros(2))\n",
        "for m in range(nb_mc):\n",
        "  bandits.reset()\n",
        "  regrets_avg[0] +=  InfUCB(bandits,T,delta).run()\n",
        "regrets_avg[0] /= nb_mc\n",
        "for m in range(nb_mc):\n",
        "  bandits.reset()\n",
        "  regrets_avg[1] += Elimination(bandits,T,epsilon).run()\n",
        "regrets_avg[1] /= nb_mc\n",
        "\n",
        "regrets_avg\n"
      ],
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "/usr/local/lib/python3.7/dist-packages/ipykernel_launcher.py:3: RuntimeWarning: invalid value encountered in log\n",
            "  This is separate from the ipykernel package so we can avoid doing imports until\n",
            "/usr/local/lib/python3.7/dist-packages/ipykernel_launcher.py:36: RuntimeWarning: divide by zero encountered in log\n",
            "/usr/local/lib/python3.7/dist-packages/ipykernel_launcher.py:36: RuntimeWarning: invalid value encountered in sqrt\n",
            "/usr/local/lib/python3.7/dist-packages/ipykernel_launcher.py:37: RuntimeWarning: divide by zero encountered in log\n",
            "/usr/local/lib/python3.7/dist-packages/ipykernel_launcher.py:37: RuntimeWarning: invalid value encountered in sqrt\n",
            "/usr/local/lib/python3.7/dist-packages/numpy/core/_asarray.py:83: VisibleDeprecationWarning: Creating an ndarray from ragged nested sequences (which is a list-or-tuple of lists-or-tuples-or ndarrays with different lengths or shapes) is deprecated. If you meant to do this, you must specify 'dtype=object' when creating the ndarray\n",
            "  return array(a, dtype, copy=False, order=order)\n"
          ]
        },
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "array([0.34, 0.3 ])"
            ]
          },
          "metadata": {},
          "execution_count": 13
        }
      ]
    }
  ]
}