{
  "cells": [
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "kcNz7Ra3_dQw"
      },
      "outputs": [],
      "source": [
        "import numpy as np\n",
        "import matplotlib.pyplot as plt"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "ZpctqYwsCutI"
      },
      "outputs": [],
      "source": [
        "repeat = 10"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "vGyT6Uz_IXD8"
      },
      "source": [
        "# MCAR"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "-q7df3iz_eRT"
      },
      "outputs": [],
      "source": [
        "class MCAR:\n",
        "    def __init__(self, means, gamma):\n",
        "        self.arm_means = means\n",
        "        self.num_arms = len(means)\n",
        "        self.gamma = gamma\n",
        "        self.best_arm = np.argmax(means)\n",
        "\n",
        "    def pull_arm(self, arm):\n",
        "        reward = np.random.normal(self.arm_means[arm], 1)\n",
        "\n",
        "        observed = np.random.rand() < self.gamma\n",
        "\n",
        "        return (reward, observed) if observed else (None, observed)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "xHzxQxtZAGH2"
      },
      "outputs": [],
      "source": [
        "class MCAR_algo:\n",
        "    def __init__(self, bandit_env, alpha):\n",
        "        self.bandit_env = bandit_env\n",
        "        self.num_arms = bandit_env.num_arms\n",
        "        self.counts = np.zeros(self.num_arms)\n",
        "        self.means = np.zeros(self.num_arms)\n",
        "        self.total_pulls = 0\n",
        "        self.alpha = alpha\n",
        "\n",
        "    def select_arm(self, round_number):\n",
        "        if self.total_pulls < self.num_arms:\n",
        "            return self.total_pulls\n",
        "\n",
        "        ucb_values = np.zeros(self.num_arms)\n",
        "        for arm in range(self.num_arms):\n",
        "            if self.counts[arm] == 0:\n",
        "                ucb_values[arm] = float('inf')\n",
        "            else:\n",
        "                confidence_bound = np.sqrt(self.alpha * np.log(round_number) / self.counts[arm])\n",
        "                ucb_values[arm] = self.means[arm] + confidence_bound\n",
        "\n",
        "        return np.argmax(ucb_values)\n",
        "\n",
        "    def update(self, arm, reward, observed):\n",
        "        if observed:\n",
        "            self.counts[arm] += 1\n",
        "            self.means[arm] += (reward - self.means[arm]) / self.counts[arm]\n",
        "\n",
        "        self.total_pulls += 1\n",
        "\n",
        "    def update_regret(self, arm, cu_regret, regrets):\n",
        "        regret = self.bandit_env.arm_means[self.bandit_env.best_arm] - self.bandit_env.arm_means[arm]\n",
        "        cu_regret += regret\n",
        "        regrets.append(cu_regret)\n",
        "        return cu_regret\n",
        "\n",
        "    def run(self, num_rounds):\n",
        "        results = []\n",
        "        regrets = []\n",
        "        cu_regret = 0\n",
        "        for round_number in range(num_rounds):\n",
        "            arm = self.select_arm(round_number)\n",
        "\n",
        "            reward, observed = self.bandit_env.pull_arm(arm)\n",
        "\n",
        "            cu_regret = self.update_regret(arm, cu_regret, regrets)\n",
        "            self.update(arm, reward, observed)\n",
        "\n",
        "            results.append((arm, reward, observed))\n",
        "\n",
        "        return results, regrets"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "Xg8Wf8ZiAz4J",
        "outputId": "8d1c120f-081b-49c2-86f0-7271d6f5f276"
      },
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "[0.96702984 0.54723225 0.97268436 0.71481599 0.69772882 0.2160895\n",
            " 0.97627445 0.00623026 0.25298236 0.43479153]\n",
            "0.8896914608968762\n"
          ]
        }
      ],
      "source": [
        "np.random.seed(4)\n",
        "\n",
        "n = 10  # Number of arms\n",
        "\n",
        "means = np.random.uniform(0, 1, size=n)  # Means between 0 and 5\n",
        "gamma = np.random.uniform(0.5, 1.0)  # Observation probabilities between 0.5 and 1\n",
        "\n",
        "print(means)\n",
        "print(gamma)\n",
        "\n",
        "alpha = 2\n",
        "\n",
        "mcar_env = MCAR(means, gamma)\n",
        "ucb_alg = MCAR_algo(mcar_env, alpha)\n",
        "\n",
        "T = 10000\n",
        "results, regrets = ucb_alg.run(T)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 307
        },
        "id": "nCU6mRN8Cbau",
        "outputId": "2c84c337-2526-4fcc-a4a8-dd6d01757c00"
      },
      "outputs": [
        {
          "data": {
            "image/png": "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SExMJCwszLLM7Nmzqa+vZ8eOHZZlur9H5zKOmOvSpUu56KKLevw8kpXZp59+SmpqKldccQWhoaFMnTqVV155xfJ6YWEh5eXlVj+jv78/06dPt8opICCA1NRUyzLp6ek4OzuTkZFhWeass87C3d3dsszs2bPZs2cPNTU1/f1j6uK0005j3bp17N27F4Bt27bx/fffM3fuXECy6stA5qLH/0dp0Dqoqqqio6PD6ssTICwsjPLycoOqGjgmk4nly5dz+umnM2nSJADKy8txd3cnICDAatnumZSXl/eaWedrJ1qmvr6epqam/vhx+sX7779PTk4Oq1ev7vGaZGVWUFDAX//6V8aOHcuXX37JTTfdxO9+9zvefPNNoOvnPNH/s/LyckJDQ61ed3V1JSgoyKYs7d3vf/975s+fT3x8PG5ubkydOpXly5ezcOFCQLLqy0Dm0tcytuQmF8sQp2zp0qXk5eXx/fffG12KXSopKeHWW29l7dq1eHp6Gl2O3TKZTKSmpvLII48AMHXqVPLy8njppZe47rrrDK7OvnzwwQe88847vPvuu0ycOJGtW7eyfPlyIiIiJKtBRNagdRAcHIyLi0uPo24rKioIDw83qKqBsWzZMj777DO+/fZbqyuChYeH09raSm1trdXy3TMJDw/vNbPO1060jJ+fH8OGDdP7x+kX2dnZVFZWkpycjKurK66urqxfv55nn30WV1dXwsLCJCtgxIgRTJgwweq5hIQEiouLga6f80T/z8LDw6msrLR6vb29nerqapuytHd33nmnZS06MTGRa665httuu82yhUay6t1A5tLXMrbkJg1aB+7u7qSkpLBu3TrLcyaTiXXr1jFz5kwDK+s/mqaxbNkyPvroI7755htiY2OtXk9JScHNzc0qkz179lBcXGzJZObMmWzfvt3qP8PatWvx8/OzfFHPnDnT6j06l3GkXGfNmsX27dvZunWr5ZaamsrChQst9yUrOP3003ucqrd3715GjRoFQGxsLOHh4VY/Y319PRkZGVY51dbWkp2dbVnmm2++wWQyMX36dMsyGzZsoK2tzbLM2rVrGT9+PIGBgf328+np2LFjPa4p7OLigslkAiSrvgxkLrr8f1Q+nEyc0Pvvv695eHhob7zxhrZz507thhtu0AICAqyOuh1MbrrpJs3f31/77rvvtLKyMsvt2LFjlmVuvPFG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",
            "text/plain": [
              "<Figure size 500x300 with 1 Axes>"
            ]
          },
          "metadata": {},
          "output_type": "display_data"
        }
      ],
      "source": [
        "plt.figure(figsize=(5, 3))\n",
        "plt.plot(regrets, label='Cumulative Regret', color='blue', linewidth=2)\n",
        "plt.xlabel('Iteration')\n",
        "plt.ylabel('Cumulative Regret')\n",
        "# plt.legend(loc='upper left', fontsize=12)\n",
        "plt.grid(True, which='both', linestyle='--', linewidth=0.5)\n",
        "\n",
        "# Adjust the ticks for better readability\n",
        "# plt.xticks(fontsize=12)\n",
        "# plt.yticks(fontsize=12)\n",
        "\n",
        "# Save the figure with high resolution\n",
        "plt.tight_layout()\n",
        "plt.savefig('cumulative_regret_plot_paper.png', dpi=300)\n",
        "\n",
        "# Display the plot\n",
        "plt.show()"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 307
        },
        "id": "kIJ3ebfeHa1l",
        "outputId": "d3b79a81-50dd-451e-8685-3288f421d228"
      },
      "outputs": [
        {
          "data": {
            "image/png": "iVBORw0KGgoAAAANSUhEUgAAAegAAAEiCAYAAAAyI0HeAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAABXrUlEQVR4nO3de1zT1f8H8Ne4bFw35LaBguBdFBUv6dSvXSTRtCyt1EzR/Nk3Q0tRMys1K8X89rWr5reb9u3rpeyepUZ4S8VLeL/fUFQYqAgDhMG28/vj3TamqAw3NuD9fDz2YJcP29lH3HvnnPd5H4kQQoAxxhhjLsXN2Q1gjDHG2M04QDPGGGMuiAM0Y4wx5oI4QDPGGGMuiAM0Y4wx5oI4QDPGGGMuiAM0Y4wx5oI4QDPGGGMuyMPZDXAFRqMR2dnZ8Pf3h0QicXZzGGOM1TNCCBQVFSE8PBxubtXrG3OABpCdnY2IiAhnN4Mxxlg9d+HCBTRp0qRax3KABuDv7w+ATpxcLndyaxhjjNU3Wq0WERER5nhTHRygAfOwtlwu5wDNGGPMYWyZRuUkMcYYY8wFcYBmjDHGXBAHaMYYY8wFcYBmjDHGXJBTA3RUVBQkEslNl6SkJABAWVkZkpKSEBQUBD8/PwwdOhS5ublWz5GVlYWBAwfCx8cHoaGhmD59OvR6vTPeDmOMMWY3Tg3Qe/bsQU5OjvmSmpoKAHjiiScAAFOmTMEvv/yCNWvWYMuWLcjOzsaQIUPMv28wGDBw4ECUl5djx44d+PLLL7F8+XLMnj3bKe+HMcYYsxeJEEI4uxEmkydPxtq1a3Hq1ClotVqEhIRg5cqVePzxxwEAx48fR9u2bZGeno4ePXpg3bp1GDRoELKzs6FUKgEAS5cuxYwZM3D58mVIpdJqva5Wq4VCoUBhYSEvs2KMMWZ3NYkzLjMHXV5ejv/973945plnIJFIkJGRgYqKCsTHx5uPadOmDSIjI5Geng4ASE9PR2xsrDk4A0BCQgK0Wi2OHDlS6++BMcZY/VBSAly4ABw5Ajhr1tRlCpX8+OOPKCgowJgxYwAAGo0GUqkUAQEBVscplUpoNBrzMZWDs+lx02O3otPpoNPpzLe1Wq0d3gFjjLG6xmAArl+3XLRaoLQUKCwEiosBX18gOhrwcEK0dJkA/fnnn2PAgAEIDw93+GulpKRg7ty5Dn8dxhhjrkEIoLycLno9BWGtFsjNpd5yRQUd4+lJwdjLC/DzA4qKnNdmlwjQ58+fxx9//IHvv//efJ9KpUJ5eTkKCgqsetG5ublQqVTmY3bv3m31XKYsb9MxVZk5cyaSk5PNt001UhljjNUP165RENbpqDdcWEjBuaKCArTBQMf5+gIBAYBUCtxYhbOsrNabbcUlAvSyZcsQGhqKgQMHmu/r0qULPD09kZaWhqFDhwIATpw4gaysLKjVagCAWq3GvHnzkJeXh9DQUABAamoq5HI5YmJibvl6MpkMMpnMge+IMcZYbSotpd5uSQlw9SqQl0cBGQDc3QFvbwrCPj7US3ZzuzkguxqnB2ij0Yhly5YhMTERHpUG+RUKBcaNG4fk5GQEBgZCLpdj0qRJUKvV6NGjBwCgX79+iImJwahRo7Bw4UJoNBq89tprSEpK4gDMGGMNgF5PyVxnz1KAFoICsVxOwbguc3qA/uOPP5CVlYVnnnnmpsfeffdduLm5YejQodDpdEhISMCSJUvMj7u7u2Pt2rWYMGEC1Go1fH19kZiYiDfeeKM23wJjjLFaYjQCBQXUUy4qojnkwkKaL27SxPV7xbZwqXXQzsLroBljzPUYDBSIS0osmdVaLQVmvZ6CsZ8fXRyRZV1WRq/Vp8/d98ZrEmec3oNmjDHWcBgMlmQto5GWNpWX09B0aSkF3rIyelyno+umVbFSKV0CA4GGMIvJAZoxxphNTEuWTIlZej3dNhgo+QqgHq3RaLnfFHQrZ1ILQddNw9JubnRxd6eLhwdlWDeEYFwVDtCMMcbuyFTEIz8fuHzZsqZYp6NgClBwFYIuJu7uFIArB10fH/rp5uacAiB1BZ8axhhjZqZerdFIvdzCQiA7mwJzaSkFWx8fGmr296clS8wxOEAzxlgDYzRaLqaAXFpKveTsbErKMj1eVka9XLkcCAqqX1nSro4DNGOM1RNCUEDVamnouaLCMu9bOTnL1EM2DUeb5pCNRprv9fW1zAcHB3NQdhYO0IwxVscYjZYeryn4FhfTMPT16/SYKfiakq4qJ2CZfkok1kPWbi6zvyEDOEAzxlidIAQlZ128aKkrXVZmSchyc6MNHry8gEaNONjWBxygGWPMRel0dCkuBnJygEuX6H5fX+r18pxw/cYBmjHGXIhpG8T8fErYKiuj3rKHB80HN9Q1wQ0RB2jGGKtlFRWUKW0q3qHX089r1yg4l5RQz9jXl6pmeXpyT7kh4gDNGGMOZjTSvHFBAc0jFxVRT7lyFS2JhAKxj0/92/SB1QwHaMYYcwCDgQJybi4F5eJiGqo2JXIFB3ORD3Z7HKAZY8wOTEPUOh0NUWs01FM2GmmoulEjnj9mtuEAzRhjd6GsjIJxZibNHwthmT8ODqb1xYzVBAdoxhirgcpLn/LzaU/isDDLxhGM3S0O0IwxVk1CULJXbi6QlUVD2HI5JXVxYGb2xgGaMcbuoLiY5pdzcoArV2ieWaEAIiM525o5jtOLwV26dAlPP/00goKC4O3tjdjYWPz111/mx4UQmD17NsLCwuDt7Y34+HicOnXK6jny8/MxcuRIyOVyBAQEYNy4cSguLq7tt8IYq0eMRsq+zsgAtm0D9uyh26bArFBwcGaO5dQAfe3aNfTq1Quenp5Yt24djh49in//+99o1KiR+ZiFCxfigw8+wNKlS7Fr1y74+voiISEBZWVl5mNGjhyJI0eOIDU1FWvXrsXWrVvx7LPPOuMtMcbqMCEo0ev8eWD3biA9neaYfX0pKKtUtESKsdogEcJUar32vfzyy9i+fTv+/PPPKh8XQiA8PBxTp07FtGnTAACFhYVQKpVYvnw5hg8fjmPHjiEmJgZ79uxB165dAQDr16/HQw89hIsXLyI8PPyO7dBqtVAoFCgsLIRcLrffG2SM1Qk6HSV65eZSeU2djpZEBQTw0qiGSAjKMUhPpy9qX34JREXd3XPWJM44dQ76559/RkJCAp544gls2bIFjRs3xvPPP4/x48cDADIzM6HRaBAfH2/+HYVCge7duyM9PR3Dhw9Heno6AgICzMEZAOLj4+Hm5oZdu3bhscceq/X3xRhzbabh62vXqKJXYSFdd3OjDSi8vZ3dQlZbCgqAU6eAkyfpkplJoyaFhZZjtm27+wBdE04N0GfPnsXHH3+M5ORkvPLKK9izZw9eeOEFSKVSJCYmQqPRAACUSqXV7ymVSvNjGo0GoaGhVo97eHggMDDQfMyNdDoddDqd+bZWq7Xn22KMuaiKCgrMWVnUWwZoEwqZjDKxeYvG+quggAJwdjatWz9xgm6b/g5uZ8cO4OmnHd7Emzg1QBuNRnTt2hXz588HAMTFxeHw4cNYunQpEhMTHfa6KSkpmDt3rsOenzHmWioq6IP53Dn6oPbwAEJDuYhIfVZSAhw4AOzaRQE2M7N6vyeRAEol0KwZ0KED0Lo18Mwzjm3rrTg1QIeFhSEmJsbqvrZt2+K7774DAKhUKgBAbm4uwsLCzMfk5uaiU6dO5mPy8vKsnkOv1yM/P9/8+zeaOXMmkpOTzbe1Wi0iIiLu+v0wxlxHeTkF47w8WhqVn0/JXioVBWhWf5SVAYcPA6dPA2fPAsePUw/ZYLj97/n5Aa1a0aVlS/rZrJkl76CsjNa6O+vvxal/pr169cKJEyes7jt58iSaNm0KAIiOjoZKpUJaWpo5IGu1WuzatQsTJkwAAKjVahQUFCAjIwNdunQBAGzcuBFGoxHdu3ev8nVlMhlknPnBWL1hNNJa5ZISmlPOzaXr169Two+fH9C4MQfm+qS8HDh6lBK5vvuOvozdirs70KYN9YgjIqjiW2Sk669jd+qf65QpU9CzZ0/Mnz8fTz75JHbv3o1PPvkEn3zyCQBAIpFg8uTJeOutt9CyZUtER0dj1qxZCA8Px6OPPgqAetz9+/fH+PHjsXTpUlRUVGDixIkYPnx4tTK4GWN1jxA0bF1aCly9SsPXWi1lX0sklh2jlEoOyvWFEPTFa/t24I8/aPi6vPzWxzdrBnTpQpeuXSkjv65x6p9ut27d8MMPP2DmzJl44403EB0djffeew8jR440H/PSSy+hpKQEzz77LAoKCtC7d2+sX78eXpUWI65YsQITJ05E37594ebmhqFDh+KDDz5wxltijNmZ0UiBV6ejgFxSQsPW16/TEGZxMfWQFQpeo1zXlZTQFy6tli4XL9Kw9ZkzdLlV/Sl3d+CBB4B77qHA3KwZ4O9fu213BKeug3YVvA6aMddhMNBFr6fSmjk59MFdUUGXyj1kNzfAx8e1hymZNSEoJyAzk5L2MjOpMExmJmXYV1fjxkDnzkDHjkCPHpRbYG+mOeg+fejv7G7UuXXQjLGGraiIekXl5XS5do3uE4J6zkVF1Dv28aGMax6udj1C0GhGfj7NAxcU0Bpi0/Ub78vLoy9ctlKpgObNaS75gQcooau+fzHjP3fGWK0zldPMzqZha4A+bD09qUiImxvdDgjgXaJchRBUwMNU1CMzE7hwgYahaxJwb6RQUDEQlYp2CFMogJAQoEULCsx+fnf/GnWNzQF669at6NmzJzxu+Cqr1+uxY8cO9OnTx26NY4zVH6Y613l5tBTm+nUgMBAIDnZ2y1hlOh1NK5h6xMeOAYcO0bKloqK7e25fX6BRI6BpUwrGUVFAdDT9rItJXI5mc4C+//77kZOTc1P1rsLCQtx///0w3GnhGWOsQTEaKfv24kWaYywrow/jyEhnt6zhMBgsW2WahpyvXbv5umnNeHW5u1OPV6WiEqmBgfRvGxBAPWDTddNtLgxjG5sDtBACkioG/q9evQpfX1+7NIoxVvcJQb2wM2coOLi7U+/phsq9zE6uX6cSphcuWC4XL9Kw9NWrdy7acSfBwVRVq00bS1GP8HDOC3Ckap/aIUOGAKC1yWPGjLEq9GEwGHDw4EH07NnT/i1kjNUpQlBP7PJlmmfW67mspr3odDQHfPaspY70tWtUW/oWWw9Um0RCPeDGjamQR0gILVVq2pQKfNwwaMpqQbUDtEKhAEA9aH9/f3hX2u5FKpWiR48e5l2oGGMNU0UFlVnMzKRA3agRzTuymsvPB7ZuBbZsoa0PK+3zUy2BgRRcw8JoKLpRI7oEBFh+BgRQMOaEPNdS7QC9bNkyAEBUVBSmTZvGw9mMMSum0otnz9IwNhcNqRm9nr7k7NxJmzwcOkRfdm5HoaDduJo3p7n9iAi63aQJf0Gqy2yePZgzZw70ej3++OMPnDlzBk899RT8/f2RnZ0NuVwOv4aYC89YA5efT9m+ubnUU+Ph7NszGGiJ2ZkzVKwjL8+S3X7p0q3ni0NCqChHixY0DxwZSb1g3lqgfrI5QJ8/fx79+/dHVlYWdDodHnzwQfj7++Ptt9+GTqfD0qVLHdFOxpgL0utpnvn0aepBN2nCw6SVmdYOm9YNmypnZWZWf6g6Ohq47z7g3nuBmBjes7ohsTlAv/jii+jatSsOHDiAoKAg8/2PPfYYz0Ez1kDodJQlbMoQVih4PXNFBWVNX7lCowkHD9Lw9NWr1X8OmYySsqKjqYxlz540IsEaJpsD9J9//okdO3ZAesMYVlRUFC5dumS3hjHGXIteT4VGCgqoJ1hQQIlFDXkbx5IS2lnpt99odyW9/s6/4+ZmmS9u3pyCcVgYJXIFBzfcc8luZvOfgtForLIYycWLF+FfH7YPYYyZ6XQUlC9fpotWS0HI379hD2dfuAB88QWQmkqFV27Fz4+WKLVrRzssRUfTvDHP0bPqsDlA9+vXD++9957Vns3FxcWYM2cOHnroIbs3kDFWe65fpyHa4mLqHWq1dF0ICjahoQ2zh1dRQcPVO3cCu3ZRtvqNmdWNG1MgVqnoy0vHjhSQec6Y1ZTN/9Xeeecd9O/fHzExMSgrK8NTTz2FU6dOITg4GKtWrXJEGxljDiQEBeFLl6hnWFxMPWNPT5oTDQtrmD3l8+eB9HQKyBkZ9OXlRn5+QP/+wKBBFJzr++5KrHbZHKAjIiJw4MABfP311zhw4ACKi4sxbtw4jBw50qp4CWPMtZm2CLx0iapRlZZSwYqIiIYZaPLzgX376LJ3L2Ve30rz5sCDDwLDhzfMXZZY7bApQFdUVKBNmzZYu3YtRo4ciZEjRzqqXYwxB8rLA44cocAsk9H2fiEhzm5V7SoooB7y3r10OX/+1scGBQH33AN0706XhnaumHPYFKA9PT1RdruMCMaYSzOtyz10iHaZioxsWL3l7Gwqmbl5M7B//60LgkgktBlEv3601KlFi4Z1nphrsHmIOykpCW+//TY+++yzm/aEZoy5ruJiKihy8SJlETeUzQ80GuD334ENG2hP46q4u9MccqdOtP64Y0fKVGfMmWyOsHv27EFaWhp+//13xMbG3lST+/vvv6/2c73++uuYO3eu1X2tW7fG8ePHAQBlZWWYOnUqVq9eDZ1Oh4SEBCxZsgTKSvvVZWVlYcKECdi0aRP8/PyQmJiIlJQU/vLAGGieOS+PSnAWFFBmdmgoUB/TRQoKLNsr5uTQWu19++h2VSIiqEKXWk1Lobh2OHM1NkexgIAADB061G4NaNeuHf744w9LgyoF1ilTpuDXX3/FmjVroFAoMHHiRAwZMgTbt28HQNtcDhw4ECqVCjt27EBOTg5Gjx4NT09PzJ8/325tZKyuMW31eO0aUFRE88z+/jSXWp+Gak+eBDZupGHrU6fufHxMDAXl++6jJVD16Vyw+sfmAG3a1cpuDfDwgEqluun+wsJCfP7551i5ciUeeOAB82u3bdsWO3fuRI8ePfD777/j6NGj+OOPP6BUKtGpUye8+eabmDFjBl5//fWbqp0xVp8JQb1IjYZqPev1VIKzvs0zZ2YC69dTUD59+vbHenoCsbFAly60HKpp09ppI2P24PRx4FOnTiE8PBxeXl5Qq9VISUlBZGQkMjIyUFFRgfj4ePOxbdq0QWRkJNLT09GjRw+kp6cjNjbWasg7ISEBEyZMwJEjRxAXF1fla+p0OugqVarXarWOe4OMOZjRSPWeL12iS3k57QFc15f/mBLajh+nueOTJ+nnlStVH9+uHdCmDa3bbtyYhrCjonjomlWPEFQ5z2Cg66bSts6cDrI5QMfFxUFSxddxiUQCLy8vtGjRAmPGjMH9999/x+fq3r07li9fjtatWyMnJwdz587FP/7xDxw+fBgajQZSqRQBAQFWv6NUKqHRaAAAGo3GKjibHjc9dispKSk3zX0zVheVlNDQblYWfagEBdW9+WUhLGuyr16l+fI9e6hq123+GwOg3vFDDwH338+bdbDqKS+nynBGIwXhkhL6G5RIKHnSw4Oqv7m50Zc8Z27naXOA7t+/Pz7++GPExsbinnvuAUCJYwcPHsSYMWNw9OhRxMfH4/vvv8fgwYNv+1wDBgwwX+/QoQO6d++Opk2b4ptvvnFo0ZOZM2ciOTnZfFur1SIiIsJhr8eYvZWXU/LX6dM0z6xU1q09gTMzaZOJTZtorry6Wy/K5bT8qXdvGrLmoMyqQ6ezlK/19KRAbKqW16oV/V3JZDTa4ulJwdnd3fllWm0O0FeuXMHUqVMxa9Ysq/vfeustnD9/Hr///jvmzJmDN998844B+kYBAQFo1aoVTp8+jQcffBDl5eUoKCiw6kXn5uaa56xVKhV2795t9Ry5ubnmx25FJpNBVpc+zRj7m8FAa3nPnKH5Zm9vqvvs7A+S6jAF5T/+oPbfiVQKxMVRhnXr1nRRqerXfDpzDCGol3z9OgVmNzfKx2jWjEaZfHzoPg8P1/57sjlAf/PNN8jIyLjp/uHDh6NLly749NNPMWLECCxatMjmxhQXF+PMmTMYNWoUunTpAk9PT6SlpZmzxk+cOIGsrCyo1WoAgFqtxrx585CXl4fQvxd1pqamQi6XIyYmxubXZ8xVlZfT8G92Ni0l8vICwsNdv0b2uXO049PtgnJ0NPWEGzWiD8/AQKBlS6BrV54/Znem11MQLi6m26bhag8P+gLbsiWNMDVqVDe+yFZmc4D28vLCjh070KJFC6v7d+zYAa+//zcZjUbz9duZNm0aHn74YTRt2hTZ2dmYM2cO3N3dMWLECCgUCowbNw7JyckIDAyEXC7HpEmToFar0aNHDwC0s1ZMTAxGjRqFhQsXQqPR4LXXXkNSUhL3kFmdJwQlRGk0NJxdVEQBOSTEtYezCwqAn36iwiC3qmfdoQMQHw/07UsfnoxVlykgFxXRbXd3Sohs2pS+3Hl6Woaxvb3pel1lc4CeNGkSnnvuOWRkZKBbt24AaA76s88+wyuvvAIA2LBhAzp16nTH57p48SJGjBiBq1evIiQkBL1798bOnTsR8neh23fffRdubm4YOnSoVaESE3d3d6xduxYTJkyAWq2Gr68vEhMT8cYbb9j6thhzGUJQ9uj583QxGmkNs6v3mHU6YNUqYNkymuu7kSkoP/AADVUzVhUhrDOpdTr6WVFBPyUS+v/Qpg399PamOeT6WJtKIsSNu5re2YoVK/DRRx/hxN9181q3bo1JkybhqaeeAgCUlpaas7rrAq1WC4VCgcLCQsjlcmc3hzVQBgP1lLOyaDhbp6OqX3Xhv9HWrcC//kUVvCpr1452fYqP56DMqlZaSl/oTEucTBnUpjliqZRGjPz8aO7Yz4+mQupaz7gmcaZGAbq+4QDNnO36dVrjm5VFH0oBAa4fmA0G2gXqm28oG9vEzQ145BEgMZGWqTBmYjRaErcqKug+Ly/qAfv709+9t7dlqZOHBz1e1+aOq1KTOFOjQYGCggJ8++23OHv2LKZNm4bAwEDs3bsXSqUSjRs3rslTMtZg5ecDhw/TfLNK5drzy0LQF4n162mO+fJl68e7dwemTKHdn1jDYRqONhop8JqGoysqrHcMk0goAIeE0MXLi3rEfn6unU3tLDYH6IMHDyI+Ph4KhQLnzp3D//3f/yEwMBDff/89srKy8N///tcR7WSs3ikuBi5coF5zRQX1Nl2xpyAEZWBv3kyB+dy5m48JCgJeeIGKhvAHbf2k11su5eVAWZllrlgioSFn00+plJY1eXvTxc3Nkrwll9e9YjrOYnOATk5OxpgxY7Bw4UL4V9qP7aGHHjLPQTPGbk+jAY4doyIjjRq5ZsGN06eB//2Pqnr9XV7AiocH7ZU8YADwj3+4/pB8Q2dKvjIYLIFWCLqYqmqVl1uOl0joMRNTYQ93dwrAKhUFWomEesBeXpZjpFL+omYPNdpu8j//+c9N9zdu3Pi25TUZa+iEoF7zxYvUI3V3d62NLEpLgT//pHXLBw7Q0HtVOncGEhJoidQNlXiZCxCCerdlZRRwKwdgU5UsU6B1d6e/P3d3CrYKheUx09+l6XGp1FIK0/Q8zLFsDtAymazKzSVOnjxpXh7FGCOmNZv5+dRbvnyZAmFQEHDDVupOUV5ONa83bKBM7NLSm4+RySgoq9VU8zosrPbbySxMVbJMAdhgsARggAKqTEYBt1EjCqju7pSEJZdTcDVlR0skrvMFkd3M5gD9yCOP4I033sA333wDgDbJyMrKwowZM+y6TzRjdZUQQGEhBeULFyhA63T0oSmXU3KMs9u3fz/w88+UfW2qwFSZQkE1irt1A0aM4DlDZyovp2VIZWUUmE3zvKY9vmUyuu3nR9dNBTp8fTn41nU2L7MqLCzE448/jr/++gtFRUUIDw+HRqNBjx49sG7dOvi6QrfARrzMitmD0Ui95AsXaJtEnc6SoeoKmdlGI7BjB7B4Me2AdSO5nIat+/WjHrMrF0Wpj0xFOYxGy23TiIZcTtMJCgWtBZbJLJs7sLqhVpZZKRQKpKamYtu2bTh48CCKi4vRuXNnq32bGWsoTHvIFhRQNnZuLg05mpaQuILsbGD7duC77yjxqzJfX6BPHwrKPXrUveIPdYXRaEnIkkgo8JaV0ZpgNze6392dgq7pi5Ep47lpU0oi5C9MDY/dCpXs3bsXs2fPxtq1a+3xdLWKe9DMVkYjZWJfuEDD2aWl9AEaFERDjM5WXExzyqtWUbb4jdq2paHrBx5wnS8SdZmpt2tadmQwUAA2fbqaEqpMQ85SKY2smDKhTUlYpu0OhXD9nZaYbRzeg96wYQNSU1MhlUrxf//3f2jWrBmOHz+Ol19+Gb/88gsSEhJq1HDG6hKDATh+nHqjHh40D6hQuEYt4OvXgS++oMBc1R7LrVsD48dTr5mzcO+OwUBTGtev07+9j48lqHp60rp2X19LqcrKwVYmo+MZu51qf6R8/vnnGD9+PAIDA3Ht2jV89tlnWLRoESZNmoRhw4bh8OHDaNu2rSPbypjT6fVUSevkSdepk200AhkZwG+/AWlpFDAqa9WKesq9e1OA5l5ZzZjWDut01DvW6Wj3pNat6Quanx/3epl9VTtAv//++3j77bcxffp0fPfdd3jiiSewZMkSHDp0CE2aNHFkGxlzCaWltH7ZVYJzWRnw44/AV1/dXEhEKgUefpjWK8fFcdCoLlOxDqOR/r1NSVtGo6UAh1RKc8IqFS0543l75ijVnoP29fXFkSNHEBUVBSEEZDIZNm3ahF69ejm6jQ7Hc9DsdgwGmms+f95SL9uZwTk3F1i7Fvj665uLifj60s5Ro0dTchGrmqmYh05Hgdi0fMk0F2z62bgxTQW4u9O59fKi4WlXmM5gdYtD56BLS0vh8/ekiUQigUwmQxhXLGD1XHExkJlJ883e3lT5y1lzt7m5wJdfUjZ25Q0IAKBXL2DQIC65eStC0ND/9esUmAH695TJaK5YLrcsXzJVyzJV2mLMWWz6HvjZZ5/Bz88PAKDX67F8+XIE31BE+IUXXrBf6xhzgpISCoZ5ebR86vp1QKl0TuATAvjrL+Dbb2mziht3BurbFxg7luZBG7qSEsvwdOW606ZKW76+NFfcogUl9vn5WTZyYMwVVXuIOyoqCpI7TGRJJBKcPXvWLg2rTTzEzQD6cM/Lo3nmK1csm8M7I9tWCGDjRuCTT6g9lclkwMiRwODBNATbUAlBQdlUqc3Hx5JJ7e5OP03Z0h4elND1d/+CsVrn0CHuc1XtMcdYHVdRQb3kK1eooIdWSz1lZw1lG43A7t3Ap5/ShhWVBQUBjz0GPPEEXW/Iiopo/t3PjxL2lEqqO11pgz3G6jyXGdxZsGABJBIJJk+ebL6vrKwMSUlJCAoKgp+fH4YOHYrcG9JVs7KyMHDgQPj4+CA0NBTTp0+H3lQ1nrEqlJfTphWZmcCuXVT+8sQJeqxxY/rAr+3gbDTSMPYjjwATJ1oH59hYYP58Sgx77rmGFZxNQ9Xl5ZZNRy5epMSudu1o6Vi3bvSFioMzq29cIhfRtIVlhw4drO6fMmUKfv31V6xZswYKhQITJ07EkCFDsH37dgCAwWDAwIEDoVKpsGPHDuTk5GD06NHw9PTE/PnznfFWmIsSgj7U8/IoG7uggIKilxctlXFmMtD+/cC77wJHjljfHxkJvPgiFRVpSMukTDXNS0osFbVMWdUyGZVRjYykIWvG6jO7lfqsKVMt7yVLluCtt95Cp06d8N5776GwsBAhISFYuXIlHn/8cQDA8ePH0bZtW6Snp5s35xg0aBCys7OhVCoBAEuXLsWMGTNw+fJlSKtZc5HnoOuv8nIaur54kZK9SkpoTrJRI+dn6F67Bnz8MfD999b39+xJPen77qufy3nKy2mI+saCKiYSCf0bNWtmyaw2rUF2hU1HGKuJWtksw96SkpIwcOBAxMfH46233jLfn5GRgYqKCqtNONq0aYPIyEhzgE5PT0dsbKw5OANAQkICJkyYgCNHjiAuLq7K19TpdNBVqoNY1f7WrO67do2GrrOzLQlEjRo5P2v34kVg+XIasq48G9O8OTB9OtC1q9OaZldGIwXjsjLLVomAZWvE5s1pBOPG6ltubpZ/L8YaMqcG6NWrV2Pv3r3Ys2fPTY9pNBpIpVIEBARY3a9UKqHRaMzHVA7OpsdNj91KSkoK5s6de5etZ67IaKT55Zwc2sxCp6N5ZWf3RIuKgD17gPXrgS1brJdL+fgAzz9PyV/O7tXfLb2e3qtpeNq0JaJSSUPTprXHfn51/70y5mg1+tg6c+YMli1bhjNnzuD9999HaGgo1q1bh8jISLRr165az3HhwgW8+OKLSE1NhVctLzCdOXMmkpOTzbe1Wi0iIiJqtQ3M/kx1sk3LkhQKCgrOUl5OS6V+/BHYt+/m4iK+vsCQIcCwYVSdrC4zfTGqqKDz3rIl/VQoLL1kxphtbP5vs2XLFgwYMAC9evXC1q1bMW/ePISGhuLAgQP4/PPP8e2331breTIyMpCXl4fOnTub7zMYDNi6dSs++ugjbNiwAeXl5SgoKLDqRefm5kL196eZSqXC7t27rZ7XlOWtus0nnkwmg4wns+oVnQ44ehQ4d87SU3OWCxdoXvmXXygZ7UZBQRSYn3qq7mYem4avdTrKrjYaafqgVSs6/xyQGbt7Nv83evnll/HWW28hOTkZ/pU+XR544AF89NFH1X6evn374tChQ1b3jR07Fm3atMGMGTMQEREBT09PpKWlYejQoQCAEydOICsrC2q1GgCgVqsxb9485OXlITQ0FACQmpoKuVyOmJgYW98aq6OKiigDOjubMrKdsR+zwUBD199+S+uYbxQRQeU41Wqge/e6GcD0etr72pTcJZPRJTKShrADAzmJizF7svlj4tChQ1i5cuVN94eGhuLKlSvVfh5/f3+0b9/e6j5fX18EBQWZ7x83bhySk5MRGBgIuVyOSZMmQa1Wo0ePHgCAfv36ISYmBqNGjcLChQuh0Wjw2muvISkpiXvIDcTly9Rzvnat9ueajUaq0Z2eTj3mS5esH/fwoFKcQ4YAnTvXzaVSxcU0CiAEzRn7+wPR0TR07e1N8+c8l8yYY9j8cRYQEICcnBxER0db3b9v3z40tnPdwXfffRdubm4YOnQodDodEhISsGTJEvPj7u7uWLt2LSZMmAC1Wg1fX18kJibijTfesGs7mOsxGmk98/Hj1Htt0qT2AqBOB6xcSb3lG7d5BKgtQ4bQdo+NGtVOm+xJr6egXFZG57RZM3ofvr6U3MXbKzJWO2xeBz1t2jTs2rULa9asQatWrbB3717k5uZi9OjRGD16NObMmeOotjoMr4OuWwwG4PBhqgSmUNBORLVl507g7bdpnvlGajXNK3fv7vylXLYyLYUqLqbbgYGUuObrS9MGdbH3z5grqUmcsTlAl5eXIykpCcuXL4fBYICHhwcMBgOeeuopLF++HO51cLyLA3TdYTDQfPPp07W7w1RxMbB4MbBmjeU+NzegRw8KzGo1EBVVO225WwYDjQKY9kM2bTTh7U0JXiEhFKDr4jw5Y66qVgK0SVZWFg4fPozi4mLExcWhZcuWNXkal8ABum6oqKAlVMeOUb3s2gjOZWUUlL/80joju1Mn4OWXaevCusBUvaukhL5YeHlRQpdpg4mgIF6bzJgj1UolsW3btqF3796IjIxEZGSkzY1kzFb5+VRDOzcXuHoVCA52bHAuKqLEsz17gJ9/ptc3kcmAF16goiKuPoyt19PuXMXFNG/s7w80bWoJyjKZ678HxhoymwP0Aw88gMaNG2PEiBF4+umneTkTcxijEcjKoh6zTkc9PEdmauflAV99BXzzzc1FRSQSoF8/ICkJCA93zOvbS1kZbZ8J0Px8hw4UlBUK7iEzVpfY/FGXnZ2N1atXY9WqVViwYAE6dOiAkSNHYsSIEWjSpIkj2sgaoOvXgZMnKVPbtOevI+TkUOLXTz9R4tmN3N2BBx4Axo1z3eFso5GCclERDWW7u9Pa5CZNKDDzXDJjddNd7WaVmZmJlStXYtWqVTh+/Dj69OmDjRs32rN9tYLnoF1HRQVtJnH2LBXFcEQiWHExsHkz8OuvNIx9I6kUGDAAiIujJLDgYPu+vj0YDPQlpriYzpmPD/WQw8LoC40rbArCGLOo1SQxE4PBgHXr1mHWrFk4ePAgDDeODdYBHKCdz2ikSmBnztCcr78/EBBg3+U9eXnAZ59RYK60mZlZ8+bA/fcDjz/umkEZoB5yfj7NL/v6UjuDguji7c3LoRhzVbW63eT27duxYsUKfPvttygrK8PgwYORkpJS06djDVh5OS2dysqixKXwcPsNywpBQ9epqVTtq6zM+vGICOChh6in3L696wY4rZayyKVSCsaRkfSTC+YxVn/Z/DE4c+ZMrF69GtnZ2XjwwQfx/vvvY/DgwfDhzVtZDVy/Dhw6RMPaYWH2CzhCAGlpwLJltMNVZb6+FJQHDABiY103KANAaSmVM/XxAdq1o7l4uZyHrxlrCGwO0Fu3bsX06dPx5JNPIthVxwFZnWCqo52fTwlN9ug1GwzArl3A118D27dbP+buTiU4//lPGj53ZTodnR9PT6p93bx53d35ijFWMzZ/JG6/8VOPMRtVVNC2kKdP09xzkyZ33yMUAvjzT+C992iovLKYGGDoUODee10/MFceyg4Pp8xxe8/FM8bqhmoF6J9//hkDBgyAp6cnfv7559se+8gjj9ilYax+KiykXnNODpWTtEev8Nw54J13aLlUZUFBwEsv0TIpVw5wQlCFL62WRhHatqXsdYWCh7IZa8iqlcXt5uYGjUaD0NBQuN3mE0MikXAWN7uloiJg/36qBhYWdvdD2lot8PnnwOrV1oVF4uKAkSNp/2VX3nnJaKTAnJ9P8+KBgVTPOyTE2S1jjNmbw7K4jUZjldcZq67cXMrULiqiamB32zPctAmYN8+6PrZKBUyeTHswu2KPWQjKIi8tpeQ4IWhpVKtWFJj9/JzdQsaYK7G5D/Pf//4Xw4YNg+yGdNvy8nKsXr0ao0ePtlvjWN1XUgJcukTrm41GCs53EzyvXwf+/W+q/GUikwGjRwOJibW3u1V1CUHD+sXFloDs5UXz7gEBlJHt4+OaXygYY85lc6ESd3d35OTkIPSG2otXr15FaGgoD3EzAJbCIydOUIBq1Oju9m3W64GtW4EPP7Tei/m++4Bp06j37EqMRhqCLyykueTGjSkg+/tTkOa5ZcYallopVCKEgKSKr/sXL16EQqGw9elYPSQEBeaTJ6m3GBlZ8x5ifj4VGPnhBxomN/H2psD8yCOu1fssLaWgXFFBwTgujubbXa1nzxhzfdUO0HFxcZBIJJBIJOjbty88KmX4GAwGZGZmon///g5pJKs79HrKqj55kpKealq/xmgE1q0DFi6kYfLKYmOBN9+kYWJXYDDQXHhJCQ23h4RQ2wIDOTAzxmqu2gH60UcfBQDs378fCQkJ8KuU0SKVShEVFYWhQ4fa9OIff/wxPv74Y5w7dw4A0K5dO8yePRsDBgwAAJSVlWHq1KlYvXo1dDodEhISsGTJEiiVSvNzZGVlYcKECdi0aRP8/PyQmJiIlJQUqy8QrHaUlFAi2MWLdxecT58GUlKAAwcs97m5Ab170z7M3bs7f4i4ooLmlYuLqQfv7w906mTZ1tGVevWMsbqp2lFszpw5AICoqCgMGzYMXnboGjRp0gQLFixAy5YtIYTAl19+icGDB2Pfvn1o164dpkyZgl9//RVr1qyBQqHAxIkTMWTIEHOxFIPBgIEDB0KlUmHHjh3IycnB6NGj4enpifnz5991+1j1ZWUBp07RvGt4eM2WN50/D/zvf5QAVnmxQEICMHEiDRU7W0EBZaK7u1PWddu29GVEoaDiIowxZi93vZuVvQUGBuJf//oXHn/8cYSEhGDlypV4/PHHAQDHjx9H27ZtkZ6ejh49emDdunUYNGgQsrOzzb3qpUuXYsaMGbh8+TKk1fzE5CSxu3P5MrB7N61rDgy0vXd77Bjwn/8A27ZZ3x8ZCUyfDqjV9mtrTQhB2ePXrtGoQFQUFUHx93ftddaMMddRkzhj80ChwWDAO++8g3vuuQcqlQqBgYFWl5oyGAxYvXo1SkpKoFarkZGRgYqKCsTHx5uPadOmDSIjI5Geng4ASE9PR2xsrNWQd0JCArRaLY4cOVLjtrDq0+ksm1EEB9sWnIuKaC551Cjr4OzrSz3mVaucE5xNlb2uXaPh+osXKfkrLAy45x6gZUv6IsLBmTHmSDZP1M6dOxefffYZpk6ditdeew2vvvoqzp07hx9//BGzZ8+2uQGHDh2CWq1GWVkZ/Pz88MMPPyAmJgb79++HVCpFwA3Fk5VKJTQaDQBAo9FYBWfT46bHbkWn00FXaUNgrVZrc7sZDUMfO0b7LNuSsFVRQVnZn35KQdBEqQRGjAAGDqS53NpkCsrFxbT9pY8PJXg1a0Y7SPn60oXnlhljtcXmAL1ixQp8+umnGDhwIF5//XWMGDECzZs3R4cOHbBz50688MILNj1f69atsX//fhQWFuLbb79FYmIitmzZYmuzbJKSkoK5c+c69DXqOyGA48eBzExag+zuXr3fO3IEeO0167XMvr7AhAm001RtzuOaioiUlFD2uZ8fjQKEhdFPb28OyIwx57E5QGs0GsTGxgIA/Pz8UFhYCAAYNGgQZs2aZXMDpFIpWrRoAQDo0qUL9uzZg/fffx/Dhg1DeXk5CgoKrHrRubm5UP1dlUKlUmH37t1Wz5f792JZ1W0qV8ycORPJycnm21qtFhERETa3vSG7eJGyrYOCqreHsxDAd99RFbCKCsv9Dz4IvPhi7RYa0esty6IUCtrOUaGg9+LrW3vtYIyx27F5DrpJkybIyckBADRv3hy///47AGDPnj03lf+sCaPRCJ1Ohy5dusDT0xNpaWnmx06cOIGsrCyo/56YVKvVOHToEPLy8szHpKamQi6XIyYm5pavIZPJIJfLrS6seoxG6jUfPEjDwNUJaKWlwOzZwIIFluDcvj3w5Ze0nKq2grMQwJUrVOHMxwfo0oU21IiNpYQ0Ds6MMVdicw/6scceQ1paGrp3745Jkybh6aefxueff46srCxMmTLFpueaOXMmBgwYgMjISBQVFWHlypXYvHkzNmzYAIVCgXHjxiE5ORmBgYGQy+WYNGkS1Go1evToAQDo168fYmJiMGrUKCxcuBAajQavvfYakpKS7PJlgd3szBnaLtLfn3qdd3L4MPDGG8DZs5b7RoygXnNtLVUXguaWr12jcptt29JSMF4qzxhzZTZ/RC1YsMB8fdiwYeas6pYtW+Lhhx+26bny8vIwevRo5OTkQKFQoEOHDtiwYQMefPBBAMC7774LNzc3DB061KpQiYm7uzvWrl2LCRMmQK1Ww9fXF4mJiXjjjTdsfVusGi5dooztgIA777xUUkI95nXrLPf5+FBPulJivkPp9dRjLi+n9jZvTkukeMCEMVYXuNw6aGfgddB3VlQE7NxJQ9zBwbc/NisLeOklmqM2admShrOjohzaTAD05UCrpcAcHk4Z5kFBlPTFGGPO4LDNMn7++edqN+KRRx6p9rGs7jh3joaJIyNvf9z+/cDUqZQdDVDPdeJE4NFHHTekbCokUlRE+y37+tLuUUFBPJTNGKu7qvXRZarDfScSiaRObjfJbq+wkBKrbleHRgjgq6+AxYtp8wgAaNqUsrYd1WsuL6d5ZVNQDgykgHy3W1syxpgrqFaANlYujMwalIoK2pmqrOzWQ9sFBTS3vGOH5b5u3YB//evOc9U1UVYGXL1K10NDLeuWfXx43TJjrP7gwT92SxUVNI988SL1TKtSUAA895z1fPPYscA//2nfoWW9nuaWTRtVRERQm0JCnL+zFWOMOYLNH6F3ypCuSblP5nr0eqr6dfYsBcGqgq1WCyQlWYJzUBDw+uv2rZ+t01EmthDUG4+Ksswvc2+ZMVaf2Rygf/jhB6vbFRUVyMzMhIeHB5o3b84Bup44fdpSxrOqJeXFxZT8VXmjjE8+uXMSWXVVHsaOiKBh7KAg3qCCMdZw2Byg9+3bd9N9Wq0WY8aMwWOPPWaXRjHnysykeedblfHUaqnQyNGjdDswEFi61D7BuaKCeswSCfWUIyJs3yWLMcbqA7utgz506BAefvhhnDt3zh5PV6t4HTQxlfE8epSyoquqFHbuHO3RnJlJtwMCaC/n5s1r/rqlpUB+Pr2+hwe9buvWNLTOw9iMsfrAYeugq6OwsNC8cQare8rLKTBnZlLQrervZ/duCs4lJXQ7MBD46KOaBWejkXriWi3tYBUZSdtNenvTXDOvXWaMNXQ2fwx+8MEHVreFEMjJycFXX32FAQMG2K1hrPaUltJc8tmzt55z/v13Wkql19PtZs2ARYts2wcaoGQvjYaex9+f6mKHhtLaZe4tM8aYhc0B+t1337W67ebmhpCQECQmJmLmzJl2axhzPCEs9bULCykRq6r9mH/+GXjzTToeAPr0AebNs7105vXrwOXLFIzbtKGfXl53/z4YY6w+sjlAZ5omH1mdVl5OPeaTJ6nHHBlZdQ922zba9MIUnAcPBmbOtH0IuqCA1jC3akUVxvz97/otMMZYvcYzfQ2M0Ui95nPnqDcbHHzrfZC//ZaqgZlKdw4ZQsHZlqFonY5ex8sL6NiRgjNnZDPG2J3ZHKDLysrw4YcfYtOmTcjLy7upDOjevXvt1jhmXwYDrW8+fpx6zY0bV90TFgL47DPKzjaJj6cEMVuC8/XrtGQqKop66EFBd/0WGGOswbA5QI8bNw6///47Hn/8cdxzzz2QcGZPnVBcTL3mU6coUN6q12w0Au+8A3zzjeW+p58GXnjBtp7vtWuU7d22LQ1rc6+ZMcZsY3OAXrt2LX777Tf06tXLEe1hDlBaCmRkUGUupfLWiVnl5cCcOUBqquW+yZMpQFeXXg/k5NDGFZ06UaERDs6MMWY7mwN048aN4c8ZPnWGEMCZMxScb5UIBlBQfe014MABuu3uDsyaBQwaVP3Xun4dyMuj12ndmrd8ZIyxu2Fz3+bf//43ZsyYgfPnzzuiPcyOhKA559Onaa3xrYLz5s3AiBGW4OzlRfs4Vzc4G40015yfT0PaHTtycGaMsbtlc4Du2rUrysrK0KxZM/j7+yMwMNDqYouUlBR069YN/v7+CA0NxaOPPooTpt0X/lZWVoakpCQEBQXBz88PQ4cORW5urtUxWVlZGDhwIHx8fBAaGorp06dDb6qo0YBlZwPHjtF646rWLGdlUVb2tGk0Rw3QWuilS4Hevav3Gno9cOECJZ117kwBuqq11Iwxxmxj8xD3iBEjcOnSJcyfPx9KpfKuksS2bNmCpKQkdOvWDXq9Hq+88gr69euHo0ePwvfvLKYpU6bg119/xZo1a6BQKDBx4kQMGTIE27dvBwAYDAYMHDgQKpUKO3bsQE5ODkaPHg1PT0/Mnz+/xm2r60pLLdnafn7WjwkBrFoFfPCBpTIYADz4IPDqqzcffysGAy3ZiogA2re3vXAJY4yxW7N5swwfHx+kp6ejY8eOdm/M5cuXERoaii1btqBPnz4oLCxESEgIVq5ciccffxwAcPz4cbRt2xbp6eno0aMH1q1bh0GDBiE7OxtKpRIAsHTpUsyYMQOXL1+GtBrdufq4WcapU8ChQzfPO5eU0Nzy1q2W+xo1Av75T2Do0OovoyotpfXNKhX1nKsqD8oYY4zUJM7YPMTdpk0blJaW2ty46jBttmEaKs/IyEBFRQXi4+OtXj8yMhLp6ekAgPT0dMTGxpqDMwAkJCRAq9XiyJEjDmmnq8vJoXnnG+tbnz0LjBljHZxHjQJ+/BF4/PHqBWejkWppFxQA0dE038zBmTHG7M/mIe4FCxZg6tSpmDdvHmJjY+Hp6Wn1eE17oEajEZMnT0avXr3Qvn17AIBGo4FUKkVAQIDVsUqlEhqNxnxM5eBsetz0WFV0Oh10Op35tlarrVGbXVF+PnDwIC1tMv1TCAGsXQu8/TZQVkb3yeXAG29Uf64ZoHrd165R9bE2bW6feMYYY+zu2Byg+/fvDwDo27ev1f1CCEgkEhhMdSFtlJSUhMOHD2Pbtm01+n1bpKSkYO7cuQ5/ndpmMADnz1MQNu0ypdcDc+cC69ZZjmvZkoJ1ZOSdn1OvpwQyrZaKm3ToQHPOvMkFY4w5ls0BetOmTXZvxMSJE7F27Vps3boVTSrtX6hSqVBeXo6CggKrXnRubi5UKpX5mN27d1s9nynL23TMjWbOnInk5GTzba1Wi4iICHu9HacwGGgv53PnqBgJQIH15ZeBnTstxz36KGVtVyfAlpUBubmAQkHVwCIjeZMLxhirLTYH6HvvvdduLy6EwKRJk/DDDz9g8+bNiI6Otnq8S5cu8PT0RFpaGoYOHQoAOHHiBLKysqBWqwEAarUa8+bNQ15eHkJDQwEAqampkMvliImJqfJ1ZTIZZPVo4tRopDXM58/TvLNMRtnVU6bQvDNAS5/mzqVM7eooLqbiJq1aUdGRG2YyGGOMOZjNAXpr5QyjKvTp06faz5WUlISVK1fip59+gr+/v3nOWKFQwNvbGwqFAuPGjUNycjICAwMhl8sxadIkqNVq9OjRAwDQr18/xMTEYNSoUVi4cCE0Gg1ee+01JCUl1asgfDtXrgAXL1LPWSaj4Pr88xSkAeoBv/MOEBd35+fS6ykJTCajwNy6te1bSzLGGLt7Ni+zcquisHLltdC2zEHfag31smXLMGbMGABUqGTq1KlYtWoVdDodEhISsGTJEqvh6/Pnz2PChAnYvHkzfH19kZiYiAULFsCjmpGlLi+z0uupzvbly1RkRAgqPvLHH/R4ZCTw/vs0b3wnxcUU7CMiqOd8Q24eY4yxGqpJnLE5QJuWQplUVFRg3759mDVrFubNm3dT8lhdUJcD9OnTtN45PJwyqt96C/jlF3rM3x9YsYIeux3Tns2enrR0qlkzXjrFGGP2VJM4Y/PgpUKhuOm+Bx98EFKpFMnJycjIyLD1KVkNabW0EUZAAC2revNNS3CWSIDXX799cNbpaHMLDw86rnlzwMZqrYwxxhzEbrOLSqXypjrazLGys2kHqYAA656zuzswbx5wu3y+ggIK8NHRQNOmNE/N20IyxpjrsDlAHzx40Oq2EAI5OTlYsGABOnXqZK92sTu4epWWVAUEACkpwM8/0/3u7sD8+cDtZhqKimgJVadONEft7l4LDWaMMWYTmwN0p06dIJFIcOPUdY8ePfDFF1/YrWHs1goKqFqYXg9s2wb89BPd7+FBw9y3Cs4GAyWBVVTQrlM3rGpjjDHmQmwO0JmZmVa33dzcEBISAi8uLVUrDAbapUqrpTnk996zPHa7dc6moiPBwTTXHBZWK81ljDFWQzYH6KZNmzqiHawajEYqPJKTQ0PbY8fS7lQA8PDDQELCzb+j11MN7ZISoEULqqHN+zUzxpjrq3Za0MaNGxETE1PlxhKFhYVo164d/vzzT7s2jlkIARw7Bhw+TJnW775LlcMAWrP80kvWxxsMlESm0dAcc+fOQLt2HJwZY6yuqHaAfu+99zB+/Pgq128pFAr885//xKJFi+zaOGZx+TL1nkNCqDCJKWPbxwdYsADw9rYcKwT1soODgW7dgF69KFObk8EYY6zuqHaAPnDggHknq6r069eP10A7SEUFrXeWSIAjR4BXXrE8Nm2a9a5UWi31rBUKoH17Wt/M6QGMMVb3VHsOOjc396a9n62eyMMDly9ftkujmIUQtJwqJ4d6y6+8QslhAHD//TT3bHLlCs05d+hAgdnX1ylNZowxZgfV7kE3btwYhw8fvuXjBw8eRBinBtuVEFTK8+hRGsKeNg3Iz6fHevSg9c6mcua5uXQ9Lo72e+bgzBhjdVu1A/RDDz2EWbNmoays7KbHSktLMWfOHAwaNMiujWvocnJoSZW/PwXjI0fo/uBgKuNpGtAoLKRg3rHjnetuM8YYqxuqvVlGbm4uOnfuDHd3d0ycOBGtW7cGABw/fhyLFy+GwWDA3r17oVQqHdpgR3DFzTJ0OmDHDqC8HPjvf4GVK+l+f3/g009pyRRARUtKSoDYWC48whhjrsqhm2UolUrs2LEDEyZMwMyZM82VxCQSCRISErB48eI6GZxdVW4uBd9jxyzB2d0d+Ne/LME5P58CeIcOlKXNGGOs/rCpUEnTpk3x22+/4dq1azh9+jSEEGjZsiUaNWrkqPY1SCUlNPecm0ubXphMnw507Wo5RqejetpNmjilmYwxxhyoRrtZNWrUCN26dbN3W9jfzp8HsrJonvn6dbpvwABg6FC6XlpKm2W0bg00buy0ZjLGGHMg3mDQxRQVUXD+z3+oBw0AMTHAq69SlnZFBe3h3KIFBWhTFjdjjLH6hQO0i8nOBr7/Hti5k243agQsWkTFRoxGerxpU6qpzZXBGGOs/qrREDdzjNJS4NAhS1IYQDtUBQdTbe2cHECppJrat6kZwxhjrB5wag9669atePjhhxEeHg6JRIIff/zR6nEhBGbPno2wsDB4e3sjPj4ep06dsjomPz8fI0eOhFwuR0BAAMaNG4fi4uJafBf2c+4c8PHH1jtU9exJwfniRepNx8Rw6U7GGGsInBqgS0pK0LFjRyxevLjKxxcuXIgPPvgAS5cuxa5du+Dr64uEhASrYikjR47EkSNHkJqairVr12Lr1q149tlna+st2I1WC2zYAGzcSLf9/IBJk+i6qefctSsFacYYY/VftQuVOJpEIsEPP/yARx99FAD1nsPDwzF16lRMmzYNAG1rqVQqsXz5cgwfPhzHjh1DTEwM9uzZg65/rz9av349HnroIVy8eBHh1Syr5QqFSvbtAwYPBi5coNtTpwIjRtBaZ6ORSnsqFE5pGmOMsbtUkzjjsklimZmZ0Gg0iI+PN9+nUCjQvXt3pKenAwDS09MREBBgDs4AEB8fDzc3N+zateuWz63T6aDVaq0uzlRQQAHZFJxbtQKeeILuLy+nYW0Ozowx1rC4bIDWaDQAcFN1MqVSaX5Mo9EgNDTU6nEPDw8EBgaaj6lKSkoKFAqF+RIREWHn1ttm+XJg0ya67uMDvPUW7UpVXEwJYU5uHmOMMSdw2QDtSDNnzkRhYaH5csHUdXWCS5eABQsst2fNopraublAs2bWez0zxhhrOFw2QKtUKgC0SUdlubm55sdUKhXy8vKsHtfr9cjPzzcfUxWZTAa5XG51cQa9npZRmd5i9+5AfDwNbSsUQPPmgJvL/gsxxhhzJJf9+I+OjoZKpUJaWpr5Pq1Wi127dkGtVgMA1Go1CgoKkJGRYT5m48aNMBqN6N69e6232VYbNwLLltF1d3cgOZnqaxcVUe/Zx8e57WOMMeY8Ti1UUlxcjNOnT5tvZ2ZmYv/+/QgMDERkZCQmT56Mt956Cy1btkR0dDRmzZqF8PBwc6Z327Zt0b9/f4wfPx5Lly5FRUUFJk6ciOHDh1c7g9tZCgqAF16gXjQAjB5NS6iuXKEynjzvzBhjDZtTA/Rff/2F+++/33w7OTkZAJCYmIjly5fjpZdeQklJCZ599lkUFBSgd+/eWL9+PbwqVepYsWIFJk6ciL59+8LNzQ1Dhw7FBx98UOvvxRZCAG+8AZw4QbejooDHHqPlVHFxtDsVD20zxljD5jLroJ2pttdB79gB3HcfbXwhkQBLlwIqFdClC+9OxRhj9VG9WgddX+n1wIQJFJwB4KmnKDiHhdGFMcYYA3izjFq3aBFw8CBdb9IEGD6cEsSio3lYmzHGmAWHhFpUUADMn2+5PWUKDXG3bUs7VjHGGGMm3IOuRSkpQGEhXe/fn9Y5t29P+zszxhhjlXEPupZoNMBHH9F1Dw/aGKNpU15OxRhjrGocoGvJq68C16/T9YceAlq2pPXOPO/MGGOsKhweasHJk8CXX9J1X19a89yyJe35zBhjjFWFA3QtmDoVMBjo+sMPAx07Ai5e6IwxxpiTcYB2sLQ0YO1auh4YCIwcSb1nD07PY4wxdhscoB1ICOCllyy3n34a6NyZh7YZY4zdGQdoB1q3Dti7l65HRVmqhjHGGGN3wgHaQUwbYpiMHg20acNZ24wxxqqHw4WDpKUBu3bR9chIYOxYQKFwbpsYY4zVHRygHWTBAsv1ceN4lyrGGGO24QDtAMeOUQ8aoDnnZ54BPD2d2ybGGGN1CwdoB/j4Y8v14cO598wYY8x2HKDtrLjYUjVMKqW9nyUS57aJMcZY3cMB2s5Wrwa0Wrr+4INUb5sxxhizVb0J0IsXL0ZUVBS8vLzQvXt37N692ynt+Pxzy/UJE3hZFWOMsZqpF+Hj66+/RnJyMubMmYO9e/eiY8eOSEhIQF5eXq224+hRYOdOut6iBZCQUKsvzxhjrB6pFwF60aJFGD9+PMaOHYuYmBgsXboUPj4++OKLL2q1HcuWWa4/+STX22aMMVZzdT5Al5eXIyMjA/Hx8eb73NzcEB8fj/T09FprR2EhsHgxXffwACZOrLWXZowxVg/V+T7elStXYDAYoFQqre5XKpU4fvx4lb+j0+mg0+nMt7WmrK67sHo1UFpK17t0AcLC7vopGWOMNWB1vgddEykpKVAoFOZLRETEXT/ns89SQZKAACAl5e7byBhjrGGr8wE6ODgY7u7uyM3Ntbo/NzcXqltsHTVz5kwUFhaaLxcuXLjrdkgkwNKlwL59wP333/XTMcYYa+DqfICWSqXo0qUL0ky1NQEYjUakpaVBrVZX+TsymQxyudzqYg+enrStJGOMMXa36vwcNAAkJycjMTERXbt2xT333IP33nsPJSUlGDt2rLObxhhjjNVIvQjQw4YNw+XLlzF79mxoNBp06tQJ69evvylxjDHGGKsrJEII4exGOJtWq4VCoUBhYaHdhrsZY4wxk5rEmTo/B80YY4zVRxygGWOMMRfEAZoxxhhzQfUiSexumabh7VFRjDHGGLuRKb7YkvbFARpAUVERANilohhjjDF2K0VFRVAoFNU6lrO4QYVNsrOz4e/vD4lEUuPn0Wq1iIiIwIULFzgb/A74XFUPn6fq43NVPXyeqs+e50oIgaKiIoSHh8PNrXqzy9yDBu1+1aRJE7s9nz2rk9V3fK6qh89T9fG5qh4+T9Vnr3NV3Z6zCSeJMcYYYy6IAzRjjDHmgjhA25FMJsOcOXMgk8mc3RSXx+eqevg8VR+fq+rh81R9zj5XnCTGGGOMuSDuQTPGGGMuiAM0Y4wx5oI4QDPGGGMuiAO0HS1evBhRUVHw8vJC9+7dsXv3bmc3yWFSUlLQrVs3+Pv7IzQ0FI8++ihOnDhhdUxZWRmSkpIQFBQEPz8/DB06FLm5uVbHZGVlYeDAgfDx8UFoaCimT58OvV5vdczmzZvRuXNnyGQytGjRAsuXL3f023OoBQsWQCKRYPLkyeb7+FyRS5cu4emnn0ZQUBC8vb0RGxuLv/76y/y4EAKzZ89GWFgYvL29ER8fj1OnTlk9R35+PkaOHAm5XI6AgACMGzcOxcXFVsccPHgQ//jHP+Dl5YWIiAgsXLiwVt6fvRgMBsyaNQvR0dHw9vZG8+bN8eabb1qVkWyo52rr1q14+OGHER4eDolEgh9//NHq8do8L2vWrEGbNm3g5eWF2NhY/Pbbb7a9GcHsYvXq1UIqlYovvvhCHDlyRIwfP14EBASI3NxcZzfNIRISEsSyZcvE4cOHxf79+8VDDz0kIiMjRXFxsfmY5557TkRERIi0tDTx119/iR49eoiePXuaH9fr9aJ9+/YiPj5e7Nu3T/z2228iODhYzJw503zM2bNnhY+Pj0hOThZHjx4VH374oXB3dxfr16+v1fdrL7t37xZRUVGiQ4cO4sUXXzTfz+dKiPz8fNG0aVMxZswYsWvXLnH27FmxYcMGcfr0afMxCxYsEAqFQvz444/iwIED4pFHHhHR0dGitLTUfEz//v1Fx44dxc6dO8Wff/4pWrRoIUaMGGF+vLCwUCiVSjFy5Ehx+PBhsWrVKuHt7S3+85//1Or7vRvz5s0TQUFBYu3atSIzM1OsWbNG+Pn5iffff998TEM9V7/99pt49dVXxffffy8AiB9++MHq8do6L9u3bxfu7u5i4cKF4ujRo+K1114Tnp6e4tChQ9V+Lxyg7eSee+4RSUlJ5tsGg0GEh4eLlJQUJ7aq9uTl5QkAYsuWLUIIIQoKCoSnp6dYs2aN+Zhjx44JACI9PV0IQf+R3NzchEajMR/z8ccfC7lcLnQ6nRBCiJdeekm0a9fO6rWGDRsmEhISHP2W7K6oqEi0bNlSpKaminvvvdccoPlckRkzZojevXvf8nGj0ShUKpX417/+Zb6voKBAyGQysWrVKiGEEEePHhUAxJ49e8zHrFu3TkgkEnHp0iUhhBBLliwRjRo1Mp8302u3bt3a3m/JYQYOHCieeeYZq/uGDBkiRo4cKYTgc2VyY4CuzfPy5JNPioEDB1q1p3v37uKf//xntdvPQ9x2UF5ejoyMDMTHx5vvc3NzQ3x8PNLT053YstpTWFgIAAgMDAQAZGRkoKKiwuqctGnTBpGRkeZzkp6ejtjYWCiVSvMxCQkJ0Gq1OHLkiPmYys9hOqYuntekpCQMHDjwpvfD54r8/PPP6Nq1K5544gmEhoYiLi4On376qfnxzMxMaDQaq/eoUCjQvXt3q/MUEBCArl27mo+Jj4+Hm5sbdu3aZT6mT58+kEql5mMSEhJw4sQJXLt2zdFv0y569uyJtLQ0nDx5EgBw4MABbNu2DQMGDADA5+pWavO82OP/IwdoO7hy5QoMBoPVhycAKJVKaDQaJ7Wq9hiNRkyePBm9evVC+/btAQAajQZSqRQBAQFWx1Y+JxqNpspzZnrsdsdotVqUlpY64u04xOrVq7F3716kpKTc9BifK3L27Fl8/PHHaNmyJTZs2IAJEybghRdewJdffgnA8j5v9/9Mo9EgNDTU6nEPDw8EBgbadC5d3csvv4zhw4ejTZs28PT0RFxcHCZPnoyRI0cC4HN1K7V5Xm51jC3njTfLYHctKSkJhw8fxrZt25zdFJd04cIFvPjii0hNTYWXl5ezm+OyjEYjunbtivnz5wMA4uLicPjwYSxduhSJiYlObp1r+eabb7BixQqsXLkS7dq1w/79+zF58mSEh4fzuapHuAdtB8HBwXB3d78p6zY3NxcqlcpJraodEydOxNq1a7Fp0yarHcFUKhXKy8tRUFBgdXzlc6JSqao8Z6bHbneMXC6Ht7e3vd+OQ2RkZCAvLw+dO3eGh4cHPDw8sGXLFnzwwQfw8PCAUqnkcwUgLCwMMTExVve1bdsWWVlZACzv83b/z1QqFfLy8qwe1+v1yM/Pt+lcurrp06ebe9GxsbEYNWoUpkyZYh6h4XNVtdo8L7c6xpbzxgHaDqRSKbp06YK0tDTzfUajEWlpaVCr1U5smeMIITBx4kT88MMP2LhxI6Kjo60e79KlCzw9Pa3OyYkTJ5CVlWU+J2q1GocOHbL6z5Camgq5XG7+oFar1VbPYTqmLp3Xvn374tChQ9i/f7/50rVrV4wcOdJ8nc8V0KtXr5uW6p08eRJNmzYFAERHR0OlUlm9R61Wi127dlmdp4KCAmRkZJiP2bhxI4xGI7p3724+ZuvWraioqDAfk5qaitatW6NRo0YOe3/2dP369Zv2FHZ3d4fRaATA5+pWavO82OX/Y7XTydhtrV69WshkMrF8+XJx9OhR8eyzz4qAgACrrNv6ZMKECUKhUIjNmzeLnJwc8+X69evmY5577jkRGRkpNm7cKP766y+hVquFWq02P25aOtSvXz+xf/9+sX79ehESElLl0qHp06eLY8eOicWLF9eppUO3UjmLWwg+V0LQEjQPDw8xb948cerUKbFixQrh4+Mj/ve//5mPWbBggQgICBA//fSTOHjwoBg8eHCVS2Ti4uLErl27xLZt20TLli2tlsgUFBQIpVIpRo0aJQ4fPixWr14tfHx8XHrp0I0SExNF48aNzcusvv/+exEcHCxeeukl8zEN9VwVFRWJffv2iX379gkAYtGiRWLfvn3i/PnzQojaOy/bt28XHh4e4p133hHHjh0Tc+bM4WVWzvThhx+KyMhIIZVKxT333CN27tzp7CY5DIAqL8uWLTMfU1paKp5//nnRqFEj4ePjIx577DGRk5Nj9Tznzp0TAwYMEN7e3iI4OFhMnTpVVFRUWB2zadMm0alTJyGVSkWzZs2sXqOuujFA87kiv/zyi2jfvr2QyWSiTZs24pNPPrF63Gg0ilmzZgmlUilkMpno27evOHHihNUxV69eFSNGjBB+fn5CLpeLsWPHiqKiIqtjDhw4IHr37i1kMplo3LixWLBggcPfmz1ptVrx4osvisjISOHl5SWaNWsmXn31VatlPw31XG3atKnKz6bExEQhRO2el2+++Ua0atVKSKVS0a5dO/Hrr7/a9F54NyvGGGPMBfEcNGOMMeaCOEAzxhhjLogDNGOMMeaCOEAzxhhjLogDNGOMMeaCOEAzxhhjLogDNGOMMeaCOEAzxhhjLogDNGPMYaKiovDee+85uxmM1UkcoBmrJ8aMGYNHH30UAHDfffdh8uTJtfbay5cvv2k/awDYs2cPnn322VprB2P1Ce8HzRi7pfLyckil0hr/fkhIiB1bw1jDwj1oxuqZMWPGYMuWLXj//fchkUggkUhw7tw5AMDhw4cxYMAA+Pn5QalUYtSoUbhy5Yr5d++77z5MnDgRkydPRnBwMBISEgAAixYtQmxsLHx9fREREYHnn38excXFAIDNmzdj7NixKCwsNL/e66+/DuDmIe6srCwMHjwYfn5+kMvlePLJJ632zH399dfRqVMnfPXVV4iKioJCocDw4cNRVFTk2JPGmAviAM1YPfP+++9DrVZj/PjxyMnJQU5ODiIiIlBQUIAHHngAcXFx+Ouvv7B+/Xrk5ubiySeftPr9L7/8ElKpFNu3b8fSpUsBAG5ubvjggw9w5MgRfPnll9i4cSNeeuklAEDPnj3x3nvvQS6Xm19v2rRpN7XLaDRi8ODByM/Px5YtW5CamoqzZ89i2LBhVsedOXMGP/74I9auXYu1a9diy5YtWLBggYPOFmOui4e4GatnFAoFpFIpfHx8oFKpzPd/9NFHiIuLw/z58833ffHFF4iIiMDJkyfRqlUrAEDLli2xcOFCq+esPJ8dFRWFt956C8899xyWLFkCqVQKhUIBiURi9Xo3SktLw6FDh5CZmYmIiAgAwH//+1+0a9cOe/bsQbdu3QBQIF++fDn8/f0BAKNGjUJaWhrmzZt3dyeGsTqGe9CMNRAHDhzApk2b4OfnZ760adMGAPVaTbp06XLT7/7xxx/o27cvGjduDH9/f4waNQpXr17F9evXq/36x44dQ0REhDk4A0BMTAwCAgJw7Ngx831RUVHm4AwAYWFhyMvLs+m9MlYfcA+asQaiuLgYDz/8MN5+++2bHgsLCzNf9/X1tXrs3LlzGDRoECZMmIB58+YhMDAQ27Ztw7hx41BeXg4fHx+7ttPT09PqtkQigdFotOtrMFYXcIBmrB6SSqUwGAxW93Xu3BnfffcdoqKi4OFR/f/6GRkZMBqN+Pe//w03Nxp0++abb+74ejdq27YtLly4gAsXLph70UePHkVBQQFiYmKq3R7GGgoe4masHoqKisKuXbtw7tw5XLlyBUajEUlJScjPz8eIESOwZ88enDlzBhs2bMDYsWNvG1xbtGiBiooKfPjhhzh79iy++uorc/JY5dcrLi5GWloarly5UuXQd3x8PGJjYzFy5Ejs3bsXu3fvxujRo3Hvvfeia9eudj8HjNV1HKAZq4emTZsGd3d3xMTEICQkBFlZWQgPD8f27dthMBjQr18/xMbGYvLkyQgICDD3jKvSsWNHLFq0CG+//Tbat2+PFStWICUlxeqYnj174rnnnsOwYcMQEhJyU5IZQEPVP/30Exo1aoQ+ffogPj4ezZo1w9dff233989YfSARQghnN4Ixxhhj1rgHzRhjjLkgDtCMMcaYC+IAzRhjjLkgDtCMMcaYC+IAzRhjjLkgDtCMMcaYC+IAzRhjjLkgDtCMMcaYC+IAzRhjjLkgDtCMMcaYC+IAzRhjjLkgDtCMMcaYC/p/Xx30RoiKK0sAAAAASUVORK5CYII=",
            "text/plain": [
              "<Figure size 500x300 with 1 Axes>"
            ]
          },
          "metadata": {},
          "output_type": "display_data"
        }
      ],
      "source": [
        "# Set seed for reproducibility\n",
        "np.random.seed(42)\n",
        "\n",
        "# Parameters\n",
        "n = 10\n",
        "T = 10000\n",
        "alpha = 2\n",
        "repeat = 20  # Number of repetitions\n",
        "\n",
        "# Initialize cumulative regret matrix\n",
        "cu_regret = np.zeros((repeat, T))\n",
        "\n",
        "# Generating random means and gamma values with fixed seed\n",
        "means = np.random.uniform(0, 1, size=n)  # Means between 0 and 1\n",
        "gamma = np.random.uniform(0.5, 1.0)  # Observation probabilities between 0.5 and 1\n",
        "\n",
        "# Initialize the MCAR environment\n",
        "mcar_env = MCAR(means, gamma)\n",
        "\n",
        "# Running the algorithm for 'repeat' number of times\n",
        "for r in range(repeat):\n",
        "    # Setting seed for each repetition for consistent runs\n",
        "    np.random.seed(42 + r)\n",
        "\n",
        "    ucb_alg = MCAR_algo(mcar_env, alpha)\n",
        "    results, regrets = ucb_alg.run(T)\n",
        "    cu_regret[r] = regrets\n",
        "\n",
        "# Calculate mean and standard deviation of cumulative regrets\n",
        "mean_regret = np.mean(cu_regret, axis=0)\n",
        "std_regret = np.std(cu_regret, axis=0)\n",
        "\n",
        "# Plot suitable for a paper\n",
        "plt.figure(figsize=(5, 3))\n",
        "\n",
        "# Plot the mean cumulative regret\n",
        "plt.plot(mean_regret, label='Cumulative Regret', color='blue', linewidth=2)\n",
        "\n",
        "# Add shaded area for error indication (1 standard deviation)\n",
        "plt.fill_between(np.arange(T),\n",
        "                 mean_regret - std_regret,\n",
        "                 mean_regret + std_regret,\n",
        "                 color='blue', alpha=0.2, label='±1 Std Dev')\n",
        "\n",
        "# Labeling and formatting\n",
        "plt.xlabel('Iteration')\n",
        "plt.ylabel('Cumulative Regret')\n",
        "plt.grid(False)  # You can enable the grid by changing this to True\n",
        "\n",
        "# Save the figure with high resolution\n",
        "plt.tight_layout()\n",
        "plt.savefig('cumulative_regret_plot_paper.png', dpi=300)\n",
        "\n",
        "# Display the plot\n",
        "plt.show()"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "psLQwZfe5SER",
        "outputId": "b68d886e-296c-4da4-f293-1c09e09389cd"
      },
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "0.5102922471479012\n"
          ]
        }
      ],
      "source": [
        "print(gamma)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 307
        },
        "id": "jkvBLtc9L-PX",
        "outputId": "8053a240-6305-4758-c7d5-43300bf922f0"
      },
      "outputs": [
        {
          "data": {
            "image/png": "iVBORw0KGgoAAAANSUhEUgAAAegAAAEiCAYAAAAyI0HeAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAACIY0lEQVR4nOzdeXwU9f348dfM7L2b3dwJAcIhN3IJClG0Wqlo1dZ6VC1VtNZWCraItorferUqHm3VVi2tbbX9VetVtS2eiAeKKAiCHHIHArnP3ey9O/P5/bHJwpIEEsgJn6ePPCSzs7OfnUDe+7neb0UIIZAkSZIkqVdRe7oBkiRJkiS1JAO0JEmSJPVCMkBLkiRJUi8kA7QkSZIk9UIyQEuSJElSLyQDtCRJkiT1QjJAS5IkSVIvJAO0JEmSJPVCpp5uQG9gGAZlZWWkpaWhKEpPN0eSJEk6xgghaGxspKCgAFVtX99YBmigrKyMgQMH9nQzJEmSpGPc3r17GTBgQLvOlQEaSEtLAxI3zu1293BrJEmSpGONz+dj4MCByXjTHjJAQ3JY2+12ywAtSZIkdZmOTKPKRWKSJEmS1AvJAC1JkiRJvZAM0JIkSZLUC8k56HYyDINoNNrTzZBaYbFY2r1tQZIkqa+QAbodotEoxcXFGIbR002RWqGqKkOGDMFisfR0UyRJkjqNDNCHIYSgvLwcTdMYOHCg7Kn1Ms1JZsrLyyksLJSJZiRJOmb0aIAePHgwe/bsaXH8Jz/5CU888QThcJibb76Z559/nkgkwsyZM3nyySfJy8tLnltSUsKcOXN4//33cblczJ49m0WLFmEydc5bi8fjBINBCgoKcDgcnXJNqXPl5ORQVlZGPB7HbDb3dHMkSZI6RY92B1evXk15eXnya+nSpQBcdtllANx0003873//46WXXuLDDz+krKyMiy++OPl8Xdc5//zziUajfPLJJ/z973/nmWee4c477+y0Nuq6DiCHT3ux5p9N889KkiTpSAkhiOsG3lCMvXXBHm2LIoQQPdqCA8yfP58lS5awfft2fD4fOTk5PPfcc1x66aUAbNmyhdGjR7Ny5UqmTZvGm2++yQUXXEBZWVmyV7148WJuvfVWqqur2x1UfT4fHo8Hr9fbIlFJOBymuLiYIUOGYLPZOvcNS51C/owkSWovIQSRuEEkZhDRdSIxA184RltLjMYN8HTK6x4qzrSl10yoRqNR/vnPf/KDH/wARVFYs2YNsViMGTNmJM8ZNWoUhYWFrFy5EoCVK1cybty4lCHvmTNn4vP52LRpU5uvFYlE8Pl8KV+SJEnSsScc06kLRCltCLGjqpGNpT62V/opqQtS6Y3QEGw7OPe0XrNI7LXXXqOhoYFrrrkGgIqKCiwWC+np6Snn5eXlUVFRkTznwODc/HjzY21ZtGgR99xzT+c1XpIkSeo1hBDU+KPUBaJE4700+rZDrwnQf/3rXznvvPMoKCjo8tdauHAhCxYsSH7fnMRckiRJ6luicYNQTCcS04kbgnBMJxTTe22vuCN6xRD3nj17ePfdd/nhD3+YPJafn080GqWhoSHl3MrKSvLz85PnVFZWtni8+bG2WK3WZGEMWSDj6D3xxBMMHjwYm83G1KlTWbVq1SHPv/vuu1EUJeVr1KhR3dRaSZKOBYYhqPCG2VbZSEltkEpfhFp/lEDk2AjO0EsC9NNPP01ubi7nn39+8tjkyZMxm80sW7YseWzr1q2UlJRQVFQEQFFRERs2bKCqqip5ztKlS3G73YwZM6b73sBx7IUXXmDBggXcddddrF27lgkTJjBz5syUn0lrxo4dm7KC/+OPP+6mFkuS1FfF9MSCruKaAJvLfVQ3Rug9y5w7X48HaMMwePrpp5k9e3bK3mWPx8N1113HggULeP/991mzZg3XXnstRUVFTJs2DYBzzjmHMWPGcNVVV7F+/XrefvttfvnLXzJ37lysVmtPvaVeY8SIERQVFREKhZLHhBBMmzaNhQsXdspr/O53v+P666/n2muvZcyYMSxevBiHw8Hf/va3Qz7PZDKRn5+f/MrOzu6U9kiSdOwwDEF9IMrOaj+byrxsKW9kT00Qfzh+TAfmZj0eoN99911KSkr4wQ9+0OKxRx55hAsuuIBLLrmEM844g/z8fF555ZXk45qmsWTJEjRNo6ioiO9///tcffXV/OpXv+rOt9BrvfDCC6xdu5YVK1Ykjz377LPs2bOH22+/PXns/vvvx+VyHfKrpKSkxfWj0Shr1qxJWWmvqiozZsxIrrRvy/bt2ykoKGDo0KHMmjWr1etLknR8iOsGwWichmCUCm+Y3TUBtlY0sqnMx776EMFjaNi6I3p8kdg555xDW1uxbTYbTzzxBE888USbzx80aBBvvPFGVzWvVRf+4WOqGyPd+poAOWlW/nfj9HafP2nSJCZOnMiWLVuYMWMGwWCQhQsXcu+995KWlpY874YbbuC73/3uIa/V2uK9mpoadF1vdSX9li1b2rzW1KlTeeaZZxg5ciTl5eXcc889nH766WzcuDGlXZIkHZviukEkblAXiBKIxonFj4Pu8BHo8QDdF1U3RqjwhXu6Ge0yYsQItm7dCsBDDz1EdnY21157bco5mZmZZGZmdlubzjvvvOSfx48fz9SpUxk0aBAvvvgi1113Xbe1Q5KkrtUYjhGK6UTjiYAc1wUx3Tguhqc7gwzQRyAnrWfmt4/kdUeOHMny5cvZt28fDz/8MK+//nqLgh/3338/999//yGvs3nzZgoLC1OOZWdno2laqyvpD7WK/mDp6emMGDGCHTt2tPs5kiT1LpG4ji8UJ6obxOIG4bgue8ZHSQboI9CRYeaeNmLECJ566iluu+02zjnnHM4888wW5xzpELfFYmHy5MksW7aMiy66CEgs+lu2bBnz5s1rdxv9fj87d+7kqquuavdzJEnqWYYhaAjFCMd0glGdUFTmwu9sMkAf40aMGMHevXt5+eWX2bhxY6vnHM0Q94IFC5g9ezZTpkzhlFNO4dFHHyUQCKQMoz/++OO8+uqryS1zt9xyCxdeeCGDBg2irKyMu+66C03TuPLKK4+oDZIkdT1fOEYomshdHY4nhq3lUHXXkgH6GDdixAgA5s2bx7Bhwzr9+pdffjnV1dXceeedVFRUMHHiRN56662UhWM1NTXs3Lkz+f2+ffu48sorqa2tJScnh+nTp/Ppp5+Sk5PT6e2TJKn9mgtJNA9Th2I64ZhBOKbLYNwDelU1q55yLFezqqurIysri/Xr1zN+/Piebk6X6Os/I0nqSkIIYrpAkPhVrxuCaNxAN5q+FwLdEMR1cciqTsernqxmJXvQx7j169djsVgYPXp0TzdFkqROJoQgGNVpDMeJxg3ihoEhEscFIASJYzLo9kkyQB/j1q9fz5gxYzCbzT3dFEmSjkJjOEY4luj5xnSDYFSXW5aOcTJAH+Pmz5/P/Pnze7oZkiS1U/OQdEw3iDcFY28oRjAiV0kfb2SAliRJ6gFCCHzhOIFInEjcQDcMonGRnBuWJBmgJUmSulhzr9gQglBUJxjT8YVixHUZjKW2yQAtSZLUSZrnh5vniMMHpLmUc8VSR8kALUmSdBQMQ9AYjlMbiBCMyv3CUueRAVqSJOkwDEPQGInjC8WIHrBy2hCCSEzuYZK6hgzQkiRJB9ENQTAaJxDR8YVjMq2l1CNkgJYkSWriC8eo9UcJROIyIEs9TgZoSZKOa83ZuJqDswzMUm8hA7QkSccd3RBE4jr+SJyGYEzOI0u9ktrTDSgtLeX73/8+WVlZ2O12xo0bx+eff558XAjBnXfeSb9+/bDb7cyYMYPt27enXKOuro5Zs2bhdrtJT0/nuuuuw+/3d/dbOW498cQTDB48GJvNxtSpU1m1alWb5w4ePBhFUVp8zZ07N3nO3Xff3eLxUaNGdcdbkY5x4ZhOcU2Ar8p97KwKUOmNyOAs9Vo9GqDr6+s57bTTMJvNvPnmm2zevJnf/va3ZGRkJM956KGH+P3vf8/ixYv57LPPcDqdzJw5k3A4nDxn1qxZbNq0iaVLl7JkyRKWL1/Oj370o554S8edF154gQULFnDXXXexdu1aJkyYwMyZM6mqqmr1/NWrV1NeXp78Wrp0KQCXXXZZynljx45NOe/jjz/u8vciHbt0Q1DVGGZntR9/WM4vS31Dj5abvO2221ixYgUfffRRq48LISgoKODmm2/mlltuAcDr9ZKXl8czzzzDFVdcwVdffcWYMWNYvXo1U6ZMAeCtt97im9/8Jvv27aOgoOCw7ThWy02OGDGCrKws3nvvPex2O5C4p0VFRZx11lksWrToqF9j6tSpnHzyyTz++OMAGIbBwIEDufHGG7ntttsO+/z58+ezZMkStm/fjqIoQKIH/dprr7Fu3bp2taEv/4ykzheK6jRGYggBkZhBOK7LVdjSEevJcpM92oP+73//y5QpU7jsssvIzc1l0qRJPPXUU8nHi4uLqaioYMaMGcljHo+HqVOnsnLlSgBWrlxJenp6MjgDzJgxA1VV+eyzz7rvzfRCL7zwAmvXrmXFihXJY88++yx79uzh9ttvTx67//77cblch/wqKSlpcf1oNMqaNWtSfj6qqjJjxozkz+dQotEo//znP/nBD36QDM7Ntm/fTkFBAUOHDmXWrFmtvr4kAUTiOmUNIXZUNbKx1MuOKj+V3ghVvgjeUGJ+WQZnqS/q0UViu3bt4o9//CMLFizg9ttvZ/Xq1fz0pz/FYrEwe/ZsKioqAMjLy0t5Xl5eXvKxiooKcnNzUx43mUxkZmYmzzlYJBIhEokkv/f5fJ35tnqNSZMmMXHiRLZs2cKMGTMIBoMsXLiQe++9l7S0tOR5N9xwA9/97ncPea3WRiJqamrQdb3Vn8+WLVsO277XXnuNhoYGrrnmmpTjU6dO5ZlnnmHkyJGUl5dzzz33cPrpp7Nx48aUdkvHp2jcoNIXJhTTieuyuIR07OrRAG0YBlOmTOH+++8HEgFl48aNLF68mNmzZ3fZ6y5atIh77rnnyC/wp6+Bv/U51i7lyoUff9ihp4wYMYKtW7cCifn87Oxsrr322pRzMjMzyczM7LRmttdf//pXzjvvvBbB/7zzzkv+efz48UydOpVBgwbx4osvct1113V3M6UeJIQgEjdoDMcJRhNVn+SiLul40aMBul+/fowZMybl2OjRo/n3v/8NQH5+PgCVlZX069cveU5lZSUTJ05MnnPwgqR4PE5dXV3y+QdbuHAhCxYsSH7v8/kYOHBg+xvur4LGsvaf34NGjhzJ8uXL2bdvHw8//DCvv/46qpo6s3H//fcnPyS1ZfPmzRQWFqYcy87ORtM0KisrU45XVla2ee+b7dmzh3fffZdXXnnlsO8hPT2dESNGsGPHjsOeK/V9/ki8qcCEjjcUIxaXPWSpa8R0g/pglPpAjIZQlHDMIBrXicQN6gJRyhpC1Aai3PedcUwelHH4C3ayHg3Qp512WrJ312zbtm0MGjQIgCFDhpCfn8+yZcuSAdnn8/HZZ58xZ84cAIqKimhoaGDNmjVMnjwZgPfeew/DMJg6dWqrr2u1WrFarUfecFfu4c/pCkfwuiNGjOCpp57itttu45xzzuHMM89scc6RDnFbLBYmT57MsmXLuOiii4DEqMiyZcuYN2/eIa/39NNPk5uby/nnn3/Y9+D3+9m5cydXXXXVYc+V+i5vKEaFN0w0LnvIUucwhKDWH6XMG6K8IUyZN0RZQ4gKb5i6QJTGSLxd19lZ5T/+AvRNN93Eqaeeyv333893v/tdVq1axZ///Gf+/Oc/A6AoCvPnz+fee+9l+PDhDBkyhDvuuIOCgoJkQBg9ejTnnnsu119/PYsXLyYWizFv3jyuuOKKdq3gPiIdHGbuSSNGjGDv3r28/PLLbNy4sdVzjmaIe8GCBcyePZspU6Zwyimn8OijjxIIBFKG0R9//HFeffVVli1bBiSC+NNPP83s2bMxmVr+Fbzlllu48MILGTRoEGVlZdx1111omsaVV155RG2UerdwTKe0IUQwovd0U6Q+qiEYZU9dkJrGCHXBKBXeMNur/JQ2hI76A59JVagLRjuppR187R551SYnn3wyr776KgsXLuRXv/oVQ4YM4dFHH2XWrFnJc37xi18QCAT40Y9+RENDA9OnT+ett95K2U7z7LPPMm/ePM4++2xUVeWSSy7h97//fU+8pV5nxIgRAMybN49hw4Z1+vUvv/xyqqurufPOO6moqGDixIm89dZbKQvHampq2LlzZ/L7d999l5KSEn7wgx+0es19+/Zx5ZVXUltbS05ODtOnT+fTTz8lJyen09sv9ay4brC7NiCHsaUOicYNPiuu5cNt1WypaMQbinXo+SZVIctlIdNhId1hIdNpIcNhxm4xYdFULCYFj02jf5qJs04ciEnrmQ1PPboPurc4VvdBQyLLWlZWFuvXr2f8+PE93Zwu0dd/RserSFxnb12IUFT2nKW26YagzBtid02A4qavTWU+QrFD/71RFShIt1PgsdPPY0v8Od1OgcdGlsuKpia2dirxMFq0ETXWiBoPgzCA/b3u4RNP75T3cST7oDvcg16+fDmnnnpqi6HJeDzOJ598whlnnNHRS0pdaP369VgsFkaPHt3TTZGOc0Ikaio3huM0BKMYcqpZahLTDaobI1Q1Rqj1R6gLRCn3himuDVBSGySqt/2XxW0zMSTbyaAsJ/luG5lOC9kuK4WZDuwWLfVkYaDoUZSYrykoB1CMSOsX7gU6HKDPOussysvLW+w99nq9nHXWWei6/DTcm6xfv54xY8ZgNpt7uinScSoQidMQitEYliuyjzfNlcIaI4kPZf5InFBUJxBJFCrZUNrAntogdYEoHfmbkWYzccrgTM4alcu4/h7UgxIdHUiN+jGFalDjIRAdGwrvaR0O0EKIFlmfAGpra3E6nZ3SKKnzzJ8/n/nz5/d0M6TjUDim0xCMUd3Ye3so0tGLxHVKaoMU1waoaYzgDcfxBqNUNUbYc5je7+EoJIapB2c5GJLtZHC2kyFZTnLSrC3jkBAoRjTRQ9ajKEYMNRZAjQeO7g32oHYH6IsvvhhIrKy+5pprUrYp6brOl19+yamnntr5LZQkqU9o7i01hGL4w3G5XeoYU+uPsKPaT3VjhEpfhJK6IKUNQap8kQ71fg/mtpnI99jIc9vITbOS6bSS5bSQk5YYpraZtbafLAzUeAg16sMUrgfRvm1TfUW7A7THk0gYLoQgLS0tWXwBEvthp02bxvXXX9/5LZQkqVeLxg0aQlFq/VHiuhzC7quEEPjCcSp9YSp9YXyhGI2RON5QjOKaAJvLfB0KxAqQ70kE3TSbGY898WW3aDgsGk6LiX4eG0Oyna2Oyra4XjyMoodR9ViidxwPosSDR/x++4J2B+inn34aSNTzveWWW+RwtiQd53zhGA2BGL5wTBaj6KV0Q+ALxfCGYtT4I+ytD1LpixCINs8FxwnGdIKRRNa2w62MPpjdrNE/w05hhoOhOU4K0u3JQJzuMGM1HaL32xYhUPQIajyIGg+hxMOo8SAcVT+9b+rwHPRdd91FPB7n3XffZefOnXzve98jLS2NsrIy3G43LperK9opSVIvIROL9B5CCCobIxTXBNhdE2BPbYC6YCwZlP3tzJTVHvluG9OHZdM/w06Oy8qADDuZTku7er8pDB01HkAx4okvPYoimv8caxqmPv6CcWs6HKD37NnDueeeS0lJCZFIhG984xukpaXx4IMPEolEWLx4cVe0U5KkHtY8BFpaH5IVpHpAJK6zszoRhJsXZe2uCRA4yn3kmqrgMGu47WZy0qzku23ke2yk282k2Uy4bWay0xLzwh0Jxko8hBbxNgXiWDIQI+QHu/bqcID+2c9+xpQpU1i/fj1ZWVnJ49/5znfkHLQkHWPiukEwpuMPx2kIxmRg7iaRuE6tP0q1P8LeuiBr9tSzbm8D8Xbef7tZI91hxn3A3G+6w8yAjESyjjSrGYc1MRds0dSO94LbIgy0cD2mcC2KHu6cax7HOhygP/roIz755BMsFkvK8cGDB1NaWtppDZMkqfs195IjcZ1QVKcxHJfzy10kGjfYVtnItspGqhoj1PgjVPsj1DRG8IXbNzSd7bIyJNvBkGxXYhtSloM8tw1zd6amNHTUWCNatBEt6pM95E7U4QBtGEaryUj27dtHWlpapzRKkqTuVReI0hCMEorpMsNXJ2uuqFThDVHmDVPhDbO1spEtFT5iHVj1num0cFJhOsNy0yjMdDA4y0GarWcSEKlRf2J7UyyAGvNzYGpMqfN0OECfc845PProoykVp/x+P3fddRff/OY3O72BkiR1rbKGELX+nqnWc6wIRuPsaKqeVB+I0hCKUeuPUu4NUeELtzsQqwpkOq3kuCxkp1nJdlnJTbMyup+bIdnOQ2bM6lJGDC3iQ4s1ougRFF0mn+kOHQ7Qv/nNbzj33HMZM2YM4XCY733ve2zfvp3s7Gz+9a9/dUUbJUnqZEIIfKE41f4woajs/XSENxSjpDbA3voQu6r97KwOsKvGT0en53PTrIzr72FsgZuBGQ6y06xkOCzJIg7dzog1FYvQUQwdtWmrk6JHj7kEIH1FhwP0wIEDWb9+PS+88ALr16/H7/dz3XXXMWvWrJTkJdLxYfny5Tz88MOsWbOG8vJyXn311WSt7kN54oknePjhh6moqGDChAn84Q9/4JRTTun6Bh/nonGDQCROtT9CJCYD8+HohmBLhY8dVX62V/nZVtlIubf9i58smkqex0aBx0a+20Y/j418j52BGXZy3d1ceU0YieArBIoRS/xZjyYCcbQRxZCjKL1NhwJ0LBZj1KhRLFmyhFmzZqXUbZaOT4FAgAkTJvCDH/wgmQ72cF544QUWLFjA4sWLmTp1Ko8++igzZ85k69atLYqwSEcmHNOJ6gaRmEFUNwhF44RjhlzwdRiRuM6OKj9bKxr5qsLHV+WHrzWsAAMzHYzp5+aEHFeytnCm00KG09Ktw9KKHkGJh1Dj4UQQRuz/s1y81ed0KECbzWbCYbl0vq8YMWIEWVlZvPfee8nRDSEERUVFnHXWWSxatOioX+O8887jvPPO69Bzfve733H99ddz7bXXArB48WJef/11/va3v3HbbbcddZuOVzHdSGaE6mgB++NZOKazZk89H22vZvXu+kMWd7BoKifkuhiW42RAhiNZvKFFWcNuouiRpgVbAbSoXw5FH2M6PMQ9d+5cHnzwQf7yl7+0qAkt9S4vvPAC06ZNY8WKFcyYMQOAZ599lj179nD77bcnz7v//vu5//77D3mtzZs3U1hYeNRtikajrFmzhoULFyaPqarKjBkzWLly5VFf/3gSjRtE4onSfY3hGGE5ZN1uzRm4PtxWzX/WldLYxrYmp0Vj3AAPUwZlckKOi0FZju7dwtQaIdAiDWjhuj5dqUk6vA5H2NWrV7Ns2TLeeecdxo0b1yIn9yuvvNJpjZOOzqRJk5g4cSJbtmxhxowZBINBFi5cyL333puyJe6GG27gu9/97iGvVVBQ0CltqqmpQdd18vLyUo7n5eWxZcuWTnmNY5kQIlHAIBijISh7yR0hhGDNnnre21rFpjIfdYGWc65um4lThmQyup+bUfluBmTYe3TltGLoIIymVJg6WtSLGgvI4erjRIcDdHp6OpdcckmnvPjdd9/NPffck3Js5MiRyV/U4XCYm2++meeff55IJMLMmTN58sknU365l5SUMGfOHN5//31cLhezZ89m0aJFXdq7v3zJ5dSEarrs+m3JtmfzwgUvdOg5I0aMYOvWrQA89NBDZGdnJ4eWm2VmZpKZmdlp7ZQ6X1w3qAtEqQ/GZBnHI9AQjPKn5bv4eEfLf7cKMH14Nt8Yncf4Aek9t4qaxJC1FvGhxhoTgVjmpD6udTiKNVe16ixjx47l3Xff3d+gAwLrTTfdxOuvv85LL72Ex+Nh3rx5XHzxxaxYsQJI1KE+//zzyc/P55NPPqG8vJyrr74as9l82CHbo1ETqqEqWNVl1+9MI0eOZPny5ezbt4+HH36Y119/HVVNHaLrziHu7OxsNE2jsrIy5XhlZSX5+flHff1jTVw3qGqMUB+MygQiHSCEoDEcZ1dNgE931fLB1qqUnNUOi8aIvDRO7O/hzBE55HX3iuoDKLEgpnAtaiyIYsj9xdJ+PT6JbDKZWv3F7PV6+etf/8pzzz3H17/+dSDx4WD06NF8+umnTJs2jXfeeYfNmzfz7rvvkpeXx8SJE/n1r3/Nrbfeyt13390iHWlnybZnd8l1u+J1R4wYwVNPPcVtt93GOeecw5lnntninO4c4rZYLEyePJlly5Ylt2MZhsGyZcuYN29ep7xGX2cYAl84hi8Ul6Uc28EQgl3VAUrqApQ1hNlY5mV7pb/VxV5Oi8YNXzuB04fn9GhPGRLFJEzherRwLbKnLLWmwwF60qRJrSZWVxQFm83GsGHDuOaaazjrrLPadb3t27dTUFCAzWajqKiIRYsWUVhYyJo1a4jFYsnFTQCjRo2isLCQlStXMm3aNFauXMm4ceNShrxnzpzJnDlz2LRpE5MmTero22uXjg4z96QRI0awd+9eXn75ZTZu3NjqOUczxO33+9mxY0fy++LiYtatW0dmZmayx/3444/z6quvsmzZMgAWLFjA7NmzmTJlCqeccgqPPvoogUCgxdD78aQ5cUhjJLECW/aWD63KF2bZlipW766jzBsicJjSl2ZN4cyRuVw1bRAZjq754N4eih5BjQXQIl7UWGOPtUPqGzocoM8991z++Mc/Mm7cuGRiidWrV/Pll19yzTXXsHnzZmbMmMErr7zCt7/97UNea+rUqTzzzDOMHDmS8vJy7rnnHk4//XQ2btxIRUUFFouF9PT0lOfk5eVRUVEBQEVFRauLjZofa0skEiES2T+U5PP52v3++5oRI0YAMG/ePIYNG9bp1//8889TPowtWLAAgNmzZ/PMM88AiYVhO3fuTJ5z+eWXU11dzZ133klFRQUTJ07krbfeavGzPB4YhqAhFKO6MSLnltuhLhDluVUlvLOp4pB9zuaSif08NsYWeDh5cAYOSzcNGBp6U1nFREIQLVKPGg8lMnLJnrLUAR3+G1tTU8PNN9/MHXfckXL83nvvZc+ePbzzzjvcdddd/PrXvz5sgD5w/+z48eOZOnUqgwYN4sUXX+zSrGSLFi1qsTjtWBUOhxFCcPXVV3fJ9c8880zEYcZg7777bu6+++6UY/PmzTuuh7QjcR1fKE6NP0K8AwUTjhdCCLyhGKUNIUrqgmwpb2R7tZ99dcGUEKcAWS4rJ+Q4ObG/h34eG0OynF2TpSuZgctIrKw2ophCtYl6x0I/YGW1/HkeE4SBGm2Eqq8grR/Y07u9CR0O0C+++CJr1qxpcfyKK65g8uTJPPXUU1x55ZX87ne/63Bj0tPTGTFiBDt27OAb3/gG0WiUhoaGlF70gYuJ8vPzWbVqVco1mhcfHWrB0cKFC5M9PUj0oAcOHNjh9vYF69evx2KxMHr06J5uitQkFNXZWe2Xc8sHEEKwpzbIxztqWLe3gX0NwUMOW9vMKhdPGsCM0XnkpFm7tG1KPIQpVI0W8SGrNh0jhECNNWJpLMVetwmzvwxzoAJTqCYxDaFHEqMezR+6vvsPGHPoDmdX6HCAttlsfPLJJy2GSz/55BNstsSnVsMwkn/uCL/fz86dO7nqqquYPHkyZrOZZcuWJbd1bd26lZKSEoqKigAoKirivvvuo6qqKpkicunSpbjdbsaMGdPm61itVqzWrv1H3VusX7+eMWPGYDb3TFk6aT/DEJTUBdtMinG8Kq4J8MT7O9haeeg5WU1VGJLtZOKAdL49sYD0rppLFkZTKcUgWtSLEg92zetIXUqJhzEHqzAFKzEHyjEHyrEEKjAFKzAHq1A7UpHL3zO7djocoG+88UZuuOEG1qxZw8knnwwk5qD/8pe/JLNTvf3220ycOPGw17rlllu48MILGTRoEGVlZdx1111omsaVV16Jx+PhuuuuY8GCBWRmZuJ2u7nxxhspKipi2rRpQKL05ZgxY7jqqqt46KGHqKio4Je//CVz5849bgLw4cyfP5/58+f3dDOOa82rsmv8EVk56gAx3eDlNft48fO9xA8qBZXtsjIgw07/9MTX8FwXQ3NcWExdl8VLC9ejRRqa6hvL4Y0+QRiYgtVYG/dg8ZVg8e3B4t+HKViFKert8OV0kwPDZEdoFgyTHd2agbNgFGQO7YLGH16HA/Qvf/lLhgwZwuOPP87/+3//D0jstX3qqaf43ve+ByS27cyZM+ew19q3bx9XXnkltbW15OTkMH36dD799FNycnIAeOSRR1BVlUsuuSQlUUkzTdNYsmQJc+bMoaioCKfTyezZs/nVr37V0bclSZ0qEtcJRnT8kTiN4Th6R2sRHsMicZ2Pttfwyhel7K3b3zsdmGHnm+P6ceoJ2WQ6u6B3bOiJnnE8lJwvVoQBIo6qR2VPuZdS4mEs/n2Y/aWYwnXJrWkWfxkW/77Ez7MDDNVC3JFLzJ5D3JFDOGMEkfRhxBx5GJa0FucPn3h6Z72VDlPE4Vb4HAd8Ph8ejwev14vb7U55LBwOU1xczJAhQ45o2F7qej39M2pOv+kPx4npBqGYTix+3P+zamFPbYD/fVnOR9urCR6QNERV4NLJA7ni5IGdn+daCLRwHeZgpSwk0ZsJgRrzYw5WJnrCjU1fvhLMwUqUDoxoCBTi9qymIJxHzJFLzNmPmDOfmDMf3ZYJSvv/nnVWgD5UnGnLEe07aGho4OWXX2bXrl3ccsstZGZmsnbtWvLy8ujfv/+RXFKS+hzDENQGolQ1huW+5TZUN0ZYurmCtSUNrc4xj8pP48dnnMCwXFenv7YabcQcKEfRZQW+HtG0EMsUrkeLeNGiPrSoDzXqQ4sk/mxumh9WY35Uo2MfoAQKcUcuEfcgommFRN2DiKQNIpY2AKH13F73ztThAP3ll18yY8YMPB4Pu3fv5oc//CGZmZm88sorlJSU8I9//KMr2ilJPU4IQThmEIzG8UcSXzIwp4rEdbZX+tlc7mNTmY8v9zW0mF+2mzVOPSGLc0/MZ1R++3oShyQM1FgAxYgl9xsrelSmzewmaiyItWEbVu9uzIEyzP5yzKFqTKHqji3EaoVhshNNG5gIwGkDiNuyidsyidsyiNtzEKZje1SzwwF6wYIFXHPNNTz00EMpFZG++c1vJuegj0VyJqD36sqfTVw3qPFH8UfihGO63Bp1EN0QbCj1sm5vPRtLfeys9rcIyM0GZTo4Z2w+M0bndjhpiKJHUOIhFENHMWKJrTBGLJH8Q+jIRV3dQ4kFsfhLsTVsx1a/DWv9ViyN+zo0BH2wmD0bw5xG3JpO3J61PyC7BxG3Z3doOPpYc0TlJv/0pz+1ON6/f/9DZu/qqzQtUYg9Go12afIU6chFo4mygc0/q87ij8TZXROQQfkguiH4dFct722pYkOpl1Cs7f3K6Q4zXxuew0WT+pPtasfOCiOGFvWj6OGmQBxD1cOyvGJ3EwJTqBqrtxhTsApr4x7sVeuwBNv3O97QrMTtOcTsOei2THSrB93iRre60S2epv8n/mxYjm56QyGxBc+kqZhUheYU6wd/TlQVMGsqiqJg0pSmcxUUBYSA5gzWCgoooNKzudrhCAK01WptNTXmtm3bkquvjyUmkwmHw0F1dTVms7lFJSipZxmGQXV1NQ6Ho1NLjEbiOnvrgjI4HyCmG7y/tYrnV++lurH1ocsCj40xBW7G9vMwpsBNP4+t1dz9KYxYcs+xTAbSPdRYILE/OFiFOViJqfn/oZpErvBoI1rMf9jrCEUj4hlCOGMkkfRhRF0DiLn6oVs8+yNeJ1MAl82Ew2zCbtEwaz0fSLtKh3+jfetb3+JXv/oVL774IpAoklFSUsKtt97aaXWiexNFUejXrx/FxcXs2bOnp5sjtUJVVQoLCw8fCNrJG4yxryF43M8v1/gjbKloZEu5jy0Vjeyq8RM7KC1put3M+AEepg3NYlx/T7uThyTrHkd9qPFAVzT/uKbGgskAnPh/858Tgbg9wfdghmpqCsIDiboHE84cQcQzFKEdec4JBdA0BU1RMKkqqpo4pioKmqZgahreVhQSPV5VwaKpXRX7e50Ob7Pyer1ceumlfP755zQ2NlJQUEBFRQXTpk3jzTffxOl0dlVbu0x7lr8bhpEcSpV6F4vF0ikjG0IIyr1hav3H58/ZH4mzodTLyp01bCj1UnOI+3BSYQbfnljAxIHpqB34banGAmihGrQjSCIhtU6Jh7HVb8NeuxF7zUas3l1HFIABBCqGxZVYnOUqIJI+nKizILFFyTMEq9ODSU0EUJtZQ1ETw8Nm9fBBU1UVECAQyZEpc1NQ7tUKOqcqYrdss/J4PCxdupSPP/6YL7/8Er/fz0knnZRSFvJYpKqq3Ad9DKtr2i51vO1f1g3B25sqeHtzBcXVgUMu9Snw2BjVz825Y/MZ3a9jq6/ViBdzsApF71hSCakVwsDsL8NZtQZX6Qps9dsS1bPa81RFJW7PQXfmoTtyiTvzMFz5GK48cOWDMwdVMyVnXxXACjgUBafVROdsUz9Our+d4Ign7aZPn8706dOT369du5Y777yTJUuWdErDJKk76Iagwhem7jjrNcd1g5W7annx873srm2ZQctmVhmRm8bI/DRG5bsZmZ+Gx96BfO7CSOx9jTSgxoNykdcR0EK12Bp2YApWJuaEo16svt1YvcWHzJ4Vt2UScxYQd+YRdzYF37R8rOn9cWXmYVZNyMz8fUOHAvTbb7/N0qVLsVgs/PCHP2To0KFs2bKF2267jf/973/MnDmzq9opSZ3OF46xt+74mWuOxg2+qvCxfm8Dn+yspbQh9Zf8kGwn4/p7mDgwnYkD0zue1cuINQVlbyIoy61P7WPomENVmP2lWBt2YKvflgjM4bp2PT3u6k88bxz0G49SMBHV3Q+7Knupx4J2B+i//vWvXH/99WRmZlJfX89f/vIXfve733HjjTdy+eWXs3HjRlnSUOoTApE45d4woeix3asrqQvyWXEtu2uC7K4NsK8+2GLrCcDQHCdzzjiBUR0ctoamUozhetRYI8pRJqU45gkdLVyPKVSLOVSNOVCBrX4LjqovOpTQQ3fmIbKGo+aMQB16BqaMwUc+FCr1au3+uT722GM8+OCD/PznP+ff//43l112GU8++SQbNmxgwIABXdlGSeo04ZjO7trAMdlrNoRgd02AT3bWsmJnDfvqDz3fO7bAzZUnFzJ+gKdDK+CVWBAt5kcL16EYx9fUwMFMoRq0SANKPIyqR1CMOGo8iBoLoMaDaBEvtvrtmELVmMK1ieIc7aCbnUTThxPPGgEZg9Hs6Vhc6ZjS+6PZPF38rqTeot0BeufOnVx22WUAXHzxxZhMJh5++GEZnKU+IxiNs6f22BnSrvCG2VjmZWeVnx3VfoprAkTirb85VYHBWU6G5jiZMCCdCQPTyehAPWVFj6JF6tHCDcdfCk0h0CL1mAMVTbmjK9AiDU1D0duP+vKGJQ2j3wTU9EKUjMEoeWPQ3P2xHy97iaQ2tTtAh0IhHA4HkNgbbLVa6devX5c1TJI6i2EIqhoj1PgjfT7xSI0/wsfba1i+vZrtVW1vpVGAMQVuTj0hmwkDPBSk2zs0p6zEw4leoB5GjQWbCk708ZvXHoaOOViBxVeC1VeMtWEH9tpNaLGj26ttWD0IZw44c8CZi5KWi5qWB5lDUdMHoaqdmwVPOjZ0aOriL3/5Cy5XIi1bPB7nmWeeITs7O+Wcn/70p53XOkk6Ss1D2n19+9TumgB/XVHMur0NbZ6T77YxKMvBSYUZFA3NIqOjNZWFgRZpwBSsOnaHroVIZixTYwHUmB9TuB5L455EbumGHahGrN2Xi2cMQ+SORrU4UExWVJMFLE4wO8DiALMTMgajOjK78E1Jneng1CA9OY7R7kQlgwcPPuw8laIo7Nq1q1Ma1p2OZAO51PtF4wbFNQGibQz79gXhmM7zq/fy2rpS9INWeA3NcXLqCdmMykvjhBwXLtuRLRVS9Ehi8VK49pjcDmVt2Imz/NPECmnvznavjm4Wt7iJZAxHdxVAWj/M6f3R0nKwpGWDK7eLWi11hmA8TFzoxIWOAIQwiBlx4sLAEEbyMQBDGBitjBKNHXVxp7SlSxOV7N69+0jbJUndKhzTqQ1EaQhG+/R8857aAA+9vZWSuv37lPPcVs4elcfpw7MZkOE4qusrsWCiFu8xmGpT0WO4yj7GU/w69rot7X5e1NmPiGcIUddA9IwTULOG4swdhM1k7qQkHdLRihoxdGEQN3T0AwKsLozEcaETMWLJANyXydX50jEjHNOpbozgDcX69FxzcU2A97ZU8fqGsmTua5Oq8N0pA7l08oCO708+gBILYoo0oEW8INo/lNtbKfEwlsa9WPz7sDTuw+zfi8Vfitlfimq0zK6lm51E0oclsmmZnRhmJ8LiRssYiJIzHIsrC6um4GpH6kqp8xgi0Xc1mnq2iqIQNeJEmwJtc+D1x0N9Puh2RK8J0A888AALFy7kZz/7GY8++igA4XCYm2++meeff55IJMLMmTN58sknycvLSz6vpKSEOXPm8P777+NyuZg9ezaLFi3q1MpGUu8mhKC6MUJVY99dBBbXDT4rruOtTRUt5pkHZTr4xbmjKMxsZ4/Z0BP1kvUIaqwRhEhs/9Ej0M6UkL2OEcfSWIKtYSeWxhIs3t1Y/KWYQjUoh6l+FXEPxjvkmwRyTyLuyEtWWTJrKm67CY/NjEkm9ugycUMnqIeJCR0hRGK4WRhEjThhI4ouDMTxsADxCPSKKNZcY3r8+PEpx2+66SZef/11XnrpJTweD/PmzePiiy9mxYoVAOi6zvnnn09+fj6ffPIJ5eXlXH311ZjNZu6///6eeCtSN0uUhQz12aQjlb4wb2+q4N2vKqkPpvZoVQW+NaGAq6YNxmI6RK9ZCBQjmkirGQugxgL06RXXQmAOlGGr/QpbwzZs9dux+Ha3e/GWUExNhR6G4R08k3DmmGRQdlhMuG2JMoUyKHeO5gAcMWJEjVhy6FkAMRFHb+feb6mlDlez6mzNxTaefPJJ7r33XiZOnMijjz6K1+slJyeH5557jksvvRSALVu2MHr0aFauXJmsnnXBBRdQVlaW7FUvXryYW2+9lerqaiyW9q1ilYvE+p7mylN1gWif7DX7w3Ge/WwPr28obxFK8902vjWhgOnDs1vfqyyMZCBOJMUI0qdrKAuB2b8PZ+Xn2Gs2Yav7ClM7ql3pZicxZz+i7sFE0gqJpQ1I1CN25MFB25YUIMNpIdNhkUPXR8EQBkE9QuiAr2N9yLlPLBLrKnPnzuX8889nxowZ3Hvvvcnja9asIRaLpVTJGjVqFIWFhckAvXLlSsaNG5cy5D1z5kzmzJnDpk2bmDSpc8qESb2LEIKSuiC+UN8brvWGYrz2RSn/WV+aUltZVWDqkCzOPTE/tYSjEUeNh1GMGGqsMbEn2YjRp3vIJBKf2Go346xYRdq+Dw8bkKOu/kTShxH2nEDUM4RIWiG6PevwrwO4bCYyHBashxqFkFolhCCkRwjoYUJ6BH88JIeju9ERBeidO3fy9NNPs3PnTh577DFyc3N58803KSwsZOzYse2+zvPPP8/atWtZvXp1i8cqKiqwWCykp6enHM/Ly6OioiJ5zoHBufnx5sfaEolEiET2Z0Py+XztbrPUs2K6QUldkGCkb3xqb+7pbyrz8vmeelYV1xE/YLuUxaRy6UkDmDk2n8wD9y0LIzGse4R1fXslQ8deswH3vg9wla1osyKTbnYRzhxNKGs04YxRRNKHYZgPPf+ukBjFtmgaNouKzZQYwrZbZAKQjhJCEDaiBPUIdVEf0Q7sCz8mKE0f5BRt/597SIcD9Icffsh5553HaaedxvLly7nvvvvIzc1l/fr1/PWvf+Xll19u13X27t3Lz372M5YuXdrtdZYXLVrEPffc062vKR2dSDyxQrsh2HtXaAshqPZH2F7pZ0eVn101AXZUNeILt+zpm1SFmWPz+daEAgrS7SmPqbEApmDlMRGc1VgQW91mXOWf4ixb2WpP2VBNhHImEcweRzDvJKJphe36xWg3a+SkWVEUMMtV1x2mC4NgPNEzbp4rjhlxIkas7/SSFRUUE2jmxLSGou4PrKoKKGDoicWRiglMlqa/W81/WQSolsS3Auhli4s73JrbbruNe++9lwULFpCWlpY8/vWvf53HH3+83ddZs2YNVVVVnHTSScljuq6zfPlyHn/8cd5++22i0SgNDQ0pvejKykry8/MByM/PZ9WqVSnXraysTD7WloULF7JgwYLk9z6fj4EDB7a77VL3qvKFe+0KbSEEm8t9/Hd9GRtKvTS2EowPlOEwc9bIXM49MZ9+nkRgVvQIaiyYmE+ONvbdLF5CYApWYq/dhK1hB7bazVi9xa2ustZNDgL9igjknUQw9yQMS1orF2xbltOSOuIgtSCEIGLECOphwno0OV/cvKWp1wdhRUsEXpMVNGtTEDY1BWG16c893ciu1eEAvWHDBp577rkWx3Nzc6mpqWn3dc4++2w2bNiQcuzaa69l1KhR3HrrrQwcOBCz2cyyZcu45JJLANi6dSslJSUUFRUBUFRUxH333UdVVRW5uYmMPkuXLsXtdjNmzJg2X9tqtWK1WtvdVqlnxHWD0oZQr5xrNoTgs+I6Xlm7jy0VjW2e57aZOCHHxYn9PYzp52Z0PzeaqiSKTwQq0KKNKPqhq071WsLA4ivBXrspEZTrNmMOtf07wNCsBPKm4O9/OoH8kxFax/4NmjQFm0kjzW7CZeldPZ2eFDd0IkaUaFPvtzkIh/Uosa7eVqdoYLYnAigG6HEwmr9aGRpv7r0qWmJOQtVAs+wPupq5KTBbe11vtid0+A6kp6dTXl7OkCFDUo5/8cUX9O/fv93XSUtL48QTT0w55nQ6ycrKSh6/7rrrWLBgAZmZmbjdbm688UaKioqYNm0aAOeccw5jxozhqquu4qGHHqKiooJf/vKXzJ07VwbgPq4hGKXcGyau945P+ZG4zuYyH1+V+9ha6Wd7ZSONkdRffmk2E8Nz0zghx8nI/DSGZDvJcVn3p8gVAjXWiClUl9if3Nt7MAcz4lgbdmKv3Yi9ZiP2us2HLCIhUIi6BxHKGksoezyBvMkIU9vTWRaTikVTMWvN/2+6bwrYTNpxOYQthCAm4kT0GCE9goFBSI8ms2lBV/eElf29VYsrEUA1c+K4aj50EBWAHms6V0ushJQ6pMMB+oorruDWW2/lpZdeQlEUDMNgxYoV3HLLLVx99dWd2rhHHnkEVVW55JJLUhKVNNM0jSVLljBnzhyKiopwOp3Mnj2bX/3qV53aDql7CCFoCMaoaoz0ivzZoajOh9uqWb69mq/KfSmLuw5UmOngkpP6c/rwnFazfKmxAGq0ES3qRdH7SKlGQ8fi34fZX4YlUIqjah22uq8SyU7aeopmJZw5imD2uP2Luyyuw76UzaSS67Ydl6ushRCEjMTwc0SPEhd6U65ovc3c0J1KbRo2VrWmL0ti7lZRE0PLpqPo6CiAydxpTT0edXgfdDQaZe7cuTzzzDPouo7JZELXdb73ve/xzDPPoGl9b9Wk3Afd82K6wZ7aYK9IOCKahq+f+GAHDcHWV7C6bSZG93Nz7th8Jg/KaFFIRtGjyaDcFxZ7KXoUW91m7NUbmuaQtx8yGEOiiEQ4a0yih5w1lohnaOKXfXtej8S+ZIdZO25WWuvCIGLEiBmxRBYtPUpQD3ftPuLkAirT/qFkzdT0vRX64O/r7jY2q/07kw7lSOLMEScqKSkpYePGjfj9fiZNmsTw4cOP5DK9ggzQPau3VJ0yhODz3fX8Z30pX+5LXW2c77YxboCHCQPSGZmfRl6atdWgrIVr0SI+FKP395TN/lKcFatxVH2BvXbjYQNyzJ7dFIxPJJR9IjHXADo67qwq4LQm0mseq4E5buiJbUpNlZRiRpyQEenajFqaNTEEbbI0zeGa9v9fOio9GaA7/NP7+OOPmT59OoWFhRQWFna4kZJ0IH8kTkltsEUpxe4UjMZ5a2MFb2+qoMwbTnlsyqAMZk0dxAk5zrbLrQoDU7ASU6iGXj+vLAwclWvI2P5vHLUb2zwtZs8lnDGCqLuQWHOFp7RBHQ7IzUyqgtNqIsNpwXwMzUXGjHhiQZYRxRsLENTD3ZDaUtm/qMqWDjaP7AkfozocoL/+9a/Tv39/rrzySr7//e8fcrW0JLUlEtcpawjjP8y2pK725b4GfvvONuqCqVub+nlszJo6iDOGZ7cdmA0dc7ACLeLr3ZWhhMDiLSat9EPS9i3HHKpucUrclkkg9yRCORMJZZ9I3J591C+rKpBmM5PhsOxf8NVHBfUIxgH7hCN6NDFc3Z5V0s17dQEQIIxD191WtMQQtMkGFmfi/80BGdG0v1c6HnQ4QJeVlfH888/zr3/9iwceeIDx48cza9YsrrzySgYMGNAVbZSOMc3zzZFYzw1p+8Nx/vTRTj7Ymhqsxg/w8O0JBUwelInWRk9PiYfRIg2YwrWH/kXbk4wY9rotOCo/x1X+GRb/vhanRF0D8A46h2DeFKJpAzvcO7aZVMwmFYspsfLapCiYTSoqSp+OITEjngzEUSOGNxbYH4gVFThgEZU1uylBRtO2IUVh/+bcpu9bG2Y2ROLvjhE/IHjTNDR9qNb17Q86UsccVbGM4uJinnvuOf71r3+xZcsWzjjjDN57773ObF+3kHPQ3ccwBDuq/T0WnIUQLN9ew99X7qa6cf+c64kFbuaeNYwBGQellBQGasyPFvWjxEOoerR39pabUoM6qtbhqFmPvWYTqh5ueZqiEsyZhHfwTAL9prU7laGqgEVTMWkqdrOGy2bqk9WgjKYyhzqCOII4CnFVQ9fMRGNBwkYcvTnQNu/Jbf7goiiJud6+97alVoTiIbwRL43RRsLxMBE9QlSPEtEjxEUcIQSGMMh35jM1fyrDMoYd1et1e7GMIUOGcNtttzFhwgTuuOMOPvzww6O5nHSMM4xEkYueCs6hqM4TH+zgw237e80uq4nZRYP5xpi8Fj1mNdKApXEvvXVe2RSowFG9Dkf1euzV6zFFW88pL1AIZ42hccDX8Bechm71HPq6qoLLasKsqVjNKiZV7VND1EII/PEQ/niQcNN+YWGyIswO4poZYbW3PmdrPvR9kXqPuBHHH/UTNaLEjThxI07MiBGOhwnFQwTjQYKxIA2RBnxRH4FYgGAscSwQD9AYbSRwiD38B7u76O6jDtBH4ogD9IoVK3j22Wd5+eWXCYfDfPvb32bRokWd2TbpGJIY1g4QivZMcF5VXMefP9pJpW9/r3nCAA8/O3sEOWmpez0VPYIpVIsWbn9mvO6gRbzYq9fjqF6Po3od5mBlm+fGbZkEcyYQzE2k0jxUUFYVsJlNWE0qdouKw2zqE0lBmusOx4VOIB5GF3piftiIEVdNYLaBLTOxurkP9vaPJ0IIQvEQ/pif+nA9deE6vBEvvqgPf9SPL+rDG/HijXrxRrwdCq6dweihcq4dDtALFy7k+eefp6ysjG984xs89thjfPvb38bhOHS1Gen4FY0b7KrxE4t3f080GI3z9IrdvLVpf3Uzu1njp2cPZ/qwgxZCGTFMoRpMoVp6vL6yENia9iNb/KVYG3Zia9je5um6yUEoexzBnIkEcye2awuUy2oizW7C2UsDcliPEtYjhI0YMSOezJiVSORhEFeUxN5eiwss1v0Zr8wOOQzdS0X1KHsb97LHt4cSXwl7fHsoC5Thj/rRu2E9h4KC3WTHZXGRbc8m3ZqO2+LGbrJj0SxYNAtWzYpJNaEqKioqA9MGcmL2iYe/eBfocIBevnw5P//5z/nud79LdvbRr/SUjm2GIdhTG+iR4PzlvgYeXbY9Za55/AAPc88cRkG6HSUeThaoUPVwr8jypUZ9OKrWkbH939i8O9s8z1BNhDNHE8yZSChnAuH04YnFSm1QSKTStJk1LFri/zZzz67kSmxPihE3EpWUDARCCHShE4iHCB1YNETREoHYbGvK02yTveJeKBwPUxOqoTpUTW2olppQDTWhGsr95XijXurCdRhHsQ3NqlnxWD14rB7cFjcWzYJZNWNSTZgUEzaTDYfZgd1kx2FykGZJI92ajtPsxGl2YjPZUDtYQrKz9kEfiQ4H6BUrVnRFO6RjULypdnO4G+ec/eE4nxXX8t6WKr4s3Z9sxGpS+eH0ocwcm4dqJApVmELV9Nj8shCY/aXYGrZj9e7C0liCxbcXc6iqzadE3IMTW6FyJxLKHHPIvNYATouJtKbFXBaTRitZSLtFczrLqJ6oMaw37Rs+ZJ1h1dwUkB1NW41k5arepjHayFe1X7HLu4td3l3sa9xHXbiuw9fJsGbgsXpIs6ThNDtJt6aTacsk3Zbo3aZZ0nCZXXisHmyH+Tt/rGlXgP7vf//Leeedh9ls5r///e8hz/3Wt77VKQ2T+jbdEOypCxKMdM82pF3Vfv66opiNpV4Oznkyrr+bn54+kAH2CKa6LT2zClsIzIFybHVfYa/djKNqbav7kQ8UcQ+hYeiFRN2FRF0FGJZDr/xUoGmVtUq6w9Ijua2NZDrLOFEjTiAeIqCHD1/QQbUkqiKZbWB2yUpGvVBMj7GtfhsbazfyZfWX7GrY1e5CHQoKbqubDGsGhe5CBrkHMdg9mEJ3IWkdLDV6PGnXNitVVamoqCA3Nxf1EBscFUVB13vpvtBDkNusOpduCIprAt2SV7usIcTzq0v4cFt1i8BckGbmO6MdfGuI6JHRUEWP4ahcjWfPUmz1W9HaWGXdTDc5iKYNJJw1JjGXnDOxzWFrVUnMIdvMJmxmFU1V0BSlW+eShRCE9AhhI0pYjxLQw4fuFR9MsyYCsj3j6IoySF1CCEGpv5Q1lWvYWLORbfXbiBxiGshldlHgKiDPkUe2PZssexY59hyy7dlkO7KxdrC8aG/R61N9GobR6p8l6WDNW6m6OjjX+CP889M9vL+1KiUw5zlVTutv4oxCE2OyNBSlG4ewhY6tbguO6i+x12zAVrcF1Yi2eqqhmghljyeUNYZI+nAi7sHotsxDLuxSFXDbzbht5h6t/BQz4tRGfXhj/g4UelASPWTVnJg/trpknuheIqJHqAhUUB2spjpUnfz/roZd1IZr23zewLSBjM8Zz8iMkQxNH0qWLavtrHvSEenwv5B//OMfXH755S3qLUejUZ5//vlOLzkp9R1G07B2V6bvFELw7leV/OXjYoIHfAhIsyhcPtrCxSO6P62kGvXj3vMO6bv+1+awddziIZIxjFDmGMKZowlnjDjsHPKBLCaVAo+9x/Yjxw2dxngQXyxwmCHrppXVqmn/l8kqtzr1AEMYiQVagXIaI434Y/7EV9O2pYZIA5WBykMG4QNlWDMYlzOOE7NP5MSsE8m0Z3bxO5A6nElM0zTKy8vJzc1NOV5bW0tubq4c4j5OhWM6e7t4QViNP8Lj7+9gzZ765LE0C1wy0spFIyw4zd0XABQ9hrtkKa59y7HVb2u1pxyz5xLKGU9j/9MJ5k5qd9aug9lMGv3Sbd2eucsQBo3xEL6Yn8Z4KDUoK1rTtiZtfz1hkx2sbhmIu1k4HqY8UE6Zv4wyfxml/lLK/GWUB8qJdWTK4SAW1cLIzJFMyp3ESXknkefIOy57yL1+iPtAQohWf0j79u3D45GZeI5H3mCMfQ1Bumr2I6YbvLB6L6+uK00pSfmNwWbmnGQjzdINvzSEgaWxBFvdNuw163FUfdEic5dAIZA3hUBBEcHs8cSd+Uf9snazRoHH3uW5rYUQhI1oojSiHiGoRwkJHaEoiQBsz0yspNYsibljGYS7nBCCYDyY3KpUHazGG/FSG66lKlhFMBbEH/Mf0crpZk6zkwJnAf1c/chz5JHjSMwZ59hzyLRloh1i657U9dodoCdNmoSiKCiKwtlnn43pgFWWuq5TXFzMueee2yWNlHovbyhGSV2wy66/ty7Ib9/+ip21oeSxTJvCglNsTC0wd9nrQiKVZlrpR9hrN2Or24zWRvaiuC0Tf8FpeAfPJOoe3Gmv77KayHfbum7hl2ompJkJqAo+PUrIECA0EJbE9iYZhLtUVI9SF65LBuDaUC114brE/uFw4vtQPHT4C7VCUzTynfkUuAoocBaQbkvHZXbhsrhwmV3J/cHH27alvqbdAfqiiy4CYN26dcycOROXy5V8zGKxMHjwYC655JJOb6DUe0XiOvvquyY4h2M6S77Yzb/WlNM81WxS4VvDLMwaa8Vt7brgYQpUkL7rf6Tveh2ljXKCuslOMG8K9cMuJpIxvFNf32kxke4w47B0Te8lbhjUmK00msxEaXp/mgKa/GV9NIQQBGIBfFFf4iviS6am9EV8NMYaaQg3dFq6SrNqxm6yk+fISwRiVwH9Xf0pcBWQ68jFpMpFeH1du3+Cd911FwCDBw/m8ssvx2Y7+n/Mf/zjH/njH//I7t27ARg7dix33nkn5513HgDhcJibb76Z559/nkgkwsyZM3nyySfJy8tLXqOkpIQ5c+bw/vvv43K5mD17NosWLUrp4UudLxpPlIzszGFtIQTbq/y891U5H26rxh/dP+c50K2ycJqd4ZldE7S0cB2OqnW497yDo3Zji8fjFg/hrDGEmhZ4hTNHJYZ+O5HNpJLtsmLv5MAc1CNE9ChhVSNkshK2mBGaAvRsLe6+JBwPUx+uxxf10RhtpCHSQEOkAX80sfCqeQ74SHu8BzOrZrLsWYktSvZssmxZ5DhyyLBl4LF4yHfmy97vcaDDv2Fmz57daS8+YMAAHnjgAYYPH44Qgr///e98+9vf5osvvmDs2LHcdNNNvP7667z00kt4PB7mzZvHxRdfnMxmpus6559/Pvn5+XzyySeUl5dz9dVXYzabuf/++zutnVKq5vSdnVWVSgjBmpJ6/vVZCduq/CmPqUqi13zdBCs2U+f1mhU9hrPiMxzV67DXbGy1XrKhWWk44SJ8A88i5urf4XrJ7WEzJUo3Oixap26dCutRaqNeGuNBdFRw5YJNJoRoTXPP1xvxUh+ppyHcQH2kPpmqcm/jXioPUZiko2yaLZmuMsueRbYtOxmMM22ZZNoz8Vg8x+WCLClVh1dx67rOI488wosvvkhJSQnRaOrq1bq6I1+wAJCZmcnDDz/MpZdeSk5ODs899xyXXnopAFu2bGH06NGsXLmSadOm8eabb3LBBRdQVlaW7FUvXryYW2+9lerqaiyW9qUHlKu4288wBLtrAwQ6IUOYEIIvShp4blUJWysbUx6zanDGQDOXj7YwyNN5PUotXE/avg9J3/nfNtNqRl0D8BWeTePAs4jbuybfvAK4bCby0jpnjjlmxIkYMcJ6FG/MT9iIJvYbW1yJBV7H4XxyVI9SG6pNDjk3V0eqDlanVEvyRrxHXahBQSHbnk2+Mz+ZtrI5X3Tz/+W8b9/Up1Zx33PPPfzlL3/h5ptv5pe//CX/93//x+7du3nttde48847O9zoZrqu89JLLxEIBCgqKmLNmjXEYjFmzJiRPGfUqFEUFhYmA/TKlSsZN25cypD3zJkzmTNnDps2bWLSpElH3B6ppWjcYG/90afvFELwyc5aXlqzl53VqfNwQzwq3xlh4YxCc6dumzIFq8jY8Sru3W+hHrT1RCga4YyRhLLHEcidRDhr7FH3ljVFwaypmE0KJjWR6UtVFFQFVBXsJlOHV2bHDZ2YiCfTaUaNGEE9QrSp5nFyD7LFDtb8xP+PYYYwCMVDyWIMBybZKPeXUxmsbHcqykOxqBYGugeS78jHbU0EWo/FQ7otPZk/Oseeg0WT+cKlztXhAP3ss8/y1FNPcf7553P33Xdz5ZVXcsIJJzB+/Hg+/fRTfvrTn3boehs2bKCoqIhwOIzL5eLVV19lzJgxrFu3DovFQnp6esr5eXl5VFQkSgdWVFSkBOfmx5sfa0skEiES2Z+yzuc7dApGKbHVqbgmkLLN6Uh4QzEeW7aN1bvrU44P9qhcdaKV6QNMqJ00tGcKVOLe+x6O6nXYar9COaiEZCD3JBpO+DahrLEdShrS6mupCh67GbOmYrdoR7Vn2RBGMpd1TCT+n9j6FG55smpJ7D+2uMDmpsv3Y3UTIQSVwUr2+PZQFayiKlhFQ6SBcDycSLIRbsAX9R1VAFYVFY/Fg9vqTvZ0M6wZpNvSybBmkGXPIsueRaYts8MVkCSpM3Q4QFdUVDBu3DgAXC4XXm+iYtAFF1zAHXfc0eEGjBw5knXr1uH1enn55ZeZPXs2H374YYev0xGLFi3innvu6dLXOJYYhmB3JwTntXvqeey97dQF9k+LDM9QuXKMldM6IzALga1uC2n7PsRRtQZLoLzFKYZmxTvkm3gHnUMsbeDRvR6JnnKG00K63dyhTveBFZ4SveFEzzgmEkPVh2SyNRWWcCRSZvZBQgiiRpRALEAoFsIb9dIQaaAuVMc+/z7WVq7Fd5jc5Ydi1az0d/VPDjkfONScbk0nz5mH0+yUgVfq1TocoAcMGEB5eTmFhYWccMIJvPPOO5x00kmsXr26RfrP9rBYLAwbNgyAyZMns3r1ah577DEuv/xyotEoDQ0NKb3oyspK8vMTCSDy8/NZtWpVyvUqKyuTj7Vl4cKFLFiwIPm9z+dj4MCj/2V9LDIMwa6awFFlCAtFdZ76eBdLN+9faJNuVZh/so1T+5uOajGMokdwla0krWQZNu/ONgtSxBx5+Apn4B3yTXTr0SXUURWwaInFXR6buV2d1uaArBs6ESNGTbShaVi6HRRToqiExQVmZ6+v9CSEoCHSQFWwiopABZXBShqjjTRGE+kmG6ONVAQqDll44VA0RSPDlpEsQ5hhy6CfMzXRhsfqkcFX6vM6/C/9O9/5DsuWLWPq1KnceOONfP/73+evf/0rJSUl3HTTTUfdIMMwiEQiTJ48GbPZzLJly5L7q7du3UpJSQlFRUUAFBUVcd9991FVVZVMPbp06VLcbjdjxoxp8zWsVusRfZg4HtX4I0dV+KKkLsh9r2+mzLt/eHZSnsZt0+xk2o/8F6gW8ZK+41U8xa+jtbK1xVBNhDNGEcydSOPArxN35LZylfZRFXBYTLisJhwWU7vrKgshCOhh/PEg3lig9cISipb4UtWm/2v781drlkRvuZeu79INnX3+fZQ2libSSwbKKG0spSJQQbSNIiHtZdWsjMkawwnpJ9DP2Y9cRy4ZtgwcJgc2k00GX6lLKU3/9bQOr+I+2MqVK1m5ciXDhw/nwgsv7NBzFy5cyHnnnUdhYSGNjY0899xzPPjgg7z99tt84xvfYM6cObzxxhs888wzuN1ubrzxRgA++eQTILGwbOLEiRQUFPDQQw9RUVHBVVddxQ9/+MMObbOSq7hbF47p7Kjyc6R/Q7ZVNnLP/zbhayqeYTPBnEk2zhtqPuJesxr1k7H9ZdJ3LUE9aE42bs0gkn4Cjf1PJ9CvCMPsOLLXaOohW80qDquG02zq0PC1LgyqIw3UR32JWW+Lsyk9ZtPnYVVtCsK2PjVnHDfi7GzYyZa6LWyu3cy2+m1HtO9XU7RkOUKnyYndbE+ucM60ZZJpy2Ro+tA+W55Q6nwKCpqiIRAIIQ75Ae3AcwSJ/zcHWwUFVVVxmByYVTMm1YRZNaOpGqqioqJ2WXrTblnFfbCioqJkj7ajqqqquPrqqykvL8fj8TB+/PhkcAZ45JFHUFWVSy65JCVRSTNN01iyZAlz5syhqKgIp9PJ7Nmz+dWvfnW0b+u4pxuCffXBIwrOQgje3lTJn5bvJN5UC/KEdJU7TnPQP+0IA5IQuEo/ImfDnzFFGpKHDdWEf8CZ+ArPJpR14hGtvlaATKcFu1nDZFIxH8ECr0hTPeSAHsVvxDFUFZw5iWFpU9emJO0qET3C9vrtfFX7FVvqtrCtftthiy+oikq+I588Zx65jlxyHbn0c/ZLbj1ymV3YTXa5x1dKUlETwVFRMatm3FY3tqasdoqSCMxm9cg/1Pdl7epB//e//233Bb/1rW8dVYN6guxBpxJCsLv2yMpGRuMGiz/YxtItNclj43I0fn26A+cRFLVQo424yleStvd9HDUbkscN1YRv0LnUjbgU/Sj2KtvNGjlp1nYlCYkZcWJGnLARJaJH0REIRSMidCIYYPOAJa1P7jluTtZRFaxiY81GNtRs4Ku6r4gbbf8d8Fg9jM4czRDPkGSqyTxHnkwxKR2SiorVZMWqWXFb3LjMruMi+HZZD7o5D/fhKIrSJ8tNSqn21YeOKDhXN0Z4ZOkWNpTtTzpy0QgLP55o7fC2I1vtV6Tv+i/O8k9b7Fv250+levyPj2peWQGyXVbSHYfv3Yb0CA3RRupj/sSmHpM18WV1g+XIhtF7UtyIU+ovpdhbzG7vbnb7drPHt+eww9XZ9mzGZI1hVOYoRmeOJt+Zf1z8YpWOjIKCVbNiUS2YtcRwsk2z4TQ75d+bdmpXgDa6qo6g1OtU+cI0BDtWQzamG/xnXSnPry4hEk8MyFg1uOlkO2cP7tjwrrVhJ1lf/T+clZ+3eCzqyKfmxB8QKDi1Q9c8mMtqIt1uPmTO66AewRcL4NPDxCxOsDrBldPnhqsNYbC3cS/b6rclA/Lexr3tqhOcbc9mfPZ4RmeNZlTmKHIcOd3QYqmvsWt2LJoFs2pOBGTNgqZqWFSLDMRHSY5FSUm+cIxKX8e2vmzY18Dj722jzLd/1W66VeGe0+2MyW7/Xy9z416yvvonaWUrUo7HLW4aB56Fv//phDNGwFGs3nXbTKQ7LC2Gs5szc4X1KCE9SlhVCSmA3Q3m/F67irottaFaVles5ouqL9q9kCvLlkWBq4B0azrDMoYxLnsc/Zz95C9YqVV2zY7b6sZj8WDW+taH1r6kwwH6cAuwjibdp9RzDENQ1tD+FbmGEDy3qoQXVu9NHlMVuHCYmWvG2XC1c75Z0aOk7/wPWV/9P5QD9gXH7DnUjbwSX+HXj7pqlALkp9twWRLXiRlx6qI+QnqEmNCJmawIzZrYa+zsW3mrw/Ewpf5S9jbupcRXQrG3mC11W9rMsKWg0M/Zj8GewQzxDGGwezCDPYNJs8hCGlLbNEVLLvBzWVxyhX036fBvvldffTXl+1gsRnFxMSaTiRNOOEEG6D6qtCFELN6+Jdvl3hAPv72F7VX782iPzdaYN9nGsIz2bVFQo348xUvI2PnflOQicWsGdSMuwzf4PMRRfjI3aQppVjMuq0aUMJVhH0E9QkiPIDRLYg7Z5gatdw8kGcKgIdJAdbCaymAl1cFqKgIV7GjYQUWg4pDpLtOt6YzIGMHIzJEMSx/GIPcgWaxBalXzViazZsasJr4smgWn2SkDcg/p8G+mL774osUxn8/HNddcw3e+851OaZTUvWr9kXbPOxfXBLjzPxtoCCUWkakK/GC8lctGWdqVqlONNpK+8z+k7/wfWnx/gBco1A+/hLqRVxxxXmybWcNp1VBRsGgKqsnAG/OzJ+zfnyTE7ATXwF5VSEI3dOrCdfiiPurD9VQGK6kMVCZyUIeqqA5Wt2vOuFmeI4/p/adzSr9TKEwrlMPUxxkVFZfZhaZqKCjJSl3Ne4I1RUNTNEyqKbkPuPnPUu9y1IlKmm3YsIELL7yQ3bt3d8blutXxvM2qIRhlb93hh7YNIXh73S7+8mkFUT3xV2Zgmsr8k22Mzz38P2wlHiZz2wuJBCMHzIkKVPz9p1M/7DtEMoYf0XtwWkzYLIAWozEeICrixI04xoE9S0VNlF10ZPXYnHI4HqY6VE1VsCqxcKtuG2X+MqpD1UdU7tCkmhiUNoiB7oEMTEt8FaYV4rHKWsLHCwUFu8mOTbNhNSVWTDvMDplprRfqkUQlzbxeb7JwhtQ3BCJx9tUfPjgHAn4efvsr1pTtX0A2IlPlgTOdpLVjrtncuJd+qxZhbSxJHhOKhq/wbOpHXEbM2a/dbdaFQcyIESeKxWpgNSs0Eqc+rkNrO8PMzsT+ZLMDtK7JENQaIQT7/PtYX7WezbWbKfYWUx+pP/wTD2JRLeQ6cslx5CQTfxyYAESWODx2WVVrcnW0qqiYVBOaoqGqKibFlEzs0VWZr6Se1+EA/fvf/z7leyEE5eXl/L//9/8477zzOq1hUtcyDMG++tChM4UZOuWlu/n1+5Xs9e1fwHXhMDM/nmjDajpMcDZ03CXvkrPhqWRaTkM14Sv8BvUjLjvkPuaoESNiRIiJOLow0IVOyIgghIHbYcJtNYMCkdbar2iJuWWrO7Hwq5s07y/+rPwzlpUswxs5/AdWm2ZLZt3yWD2kW9PJseeQ78wnz5Ene8O9QHOmq+ZhYSDZQ1VQQCH5uBCi1TUBzecf/PyDz2+e+22eB5aObx0O0I888kjK96qqkpOTw+zZs1m4cGGnNUzqWqUNoUOXjxQGm7dt4Z4P6gk29UzdFoWFRXam9DvMXxtDJ23fB2Ru+ReW4P663JG0QspPuZ1Y2oAWT4kY0aagHCWgB1sUllAAu1XDY7e1nvREa04ekpboLXdRjuu4Eac8UE5loBJ/zE8gFqAx2sgu7y621m1ts0KT0+xkgGtAsveb58xjWPowuZWpGykoqIqa3KtrVs0p87GqoqIoSnKxlKp0XV5mSWqPDgfo4uLirmiH1I1qDrcozIjx4Rdf8cinPpqmmxnsUfnV6Q76uQ4d+CzeXeR//puU4WwA38CzqJowN2UBmCEMQkaY+piPyCGqHylKIuuXzdzKaytqYgjbmdslc8vheJhNtZv4svpLttdvZ49vT7vmizVFY3zOeE7MPpGJORMpcBXIQNxJmgNoc55mVUkM+aLs74E2Dwcf+H95/6W+Ri7bO854QzEqvOG2T4g08tyKbfxr8/656WkFJv7vVDu2Qwxpq7EAGdv/TfqO11APCLbBnInUjryCcPaJyWNRI0Z9zEtADx1yixCARVPIclkxaQe9tmJKBGZHZqf3liN6hE/LPuXj0o/ZUrel3SuoM6wZjMwcyRDPEE7rfxrZR5Ej/HhnUkzYTXasmhW72Y5JSawyVlBksJWOGx0O0OFwmD/84Q+8//77VFVVtUgDunbt2k5rnNS5qhrDVHrbzhQW89fx2LLtfLh3f0D69nAzcybZ0NpI3mH2l5K55Xlc5Z+gHjC8G/acQPW461MCsxACb9xPXayhzcCsqYnayyZNxaKpWA7+UKBZwZENNld73nK76IZOZbCSzbWb2VizkS+rvyQYD7Y4T0GhwFWQXDHttrpxmpw4zU7ynHnkOfJk4GiioCQXNx24orj5595c/k8gQCTmZG0mGxbNgk2zyYpXksQRBOjrrruOd955h0svvZRTTjlF/iPqI8oaQtT62x5G9tZVcsfrOyn2Jj5wqQrcMMnKd0a0nqDAFKwic+vzuEveTckAZqgmvEO/Re3o7yeSgTTxx4PUxupbzC2bNQWLScWkKlhNiRrMrVMS26Sc2Uc8lG0Ig9LGUrY3bE8OV3sjXuoj9Rii9fn4LFsWE3MnMil3EmOyxuA4whrTxwpN0ZLB9cDFTAfW1pULnCSpc3Q4QC9ZsoQ33niD0047rSvaI3WBukD0kMG5srqKO5bsoDyQ6N3YTXB7kZ1p/Vv+kjWFakjf/m88u99EPaAUoW5Ow9//NOqGX0rcmZ8oyxj3E9TDBI1wSgA0aQp2s4bNrGIzaW0HXNWSWIVtdiQWf3VwKFsIQUljCR/t+4h1VeuoCFYcsnxiM6fZyeS8ycwYNIPh6cOP2w+hZtWMTbMls0k5TA65aEqSulGHA3T//v1JS5N5e/uKSFw/ZI7t4r37uPOtPTQ07VfKdyrce4aDQZ7UX8RapIGM7a/g2fW/lPKPuslJ/fDv0DD0Wwizg7AeoTZcSdhoOZSeZjVhtxyql9zE7Ez0lI9gi1RUj7KhZgPb6rexpnIN+xr3tXmugoLb6ibTlkmOPYchniGMzxnPEM+Q4ybRQ/MWIlVRE6ucVRWHyYHdZMdtcR+3H04kqTfocID+7W9/y6233srixYsZNGhQV7RJ6iRCCPbWBVvf6ywE76z5isWr6og1dW4He1QWfc1BtmN/cDL7S8nc9hJpe99HOWB42tCsNAy9kPrhl2BY0ogaMWojVQT1lgvQ7BYNj92M+eCFXgczO8GekSjt2E6GMKgIVLDLu4s1lWv4ovILwq20QVM0ClwFFLgKGJY+jOEZwxniGXLM5xg2KSZsJluy0IGmaqiooJBcAS1JUu/U4QA9ZcoUwuEwQ4cOxeFwYDanDoPW1dV1WuOko1PtjxCKtj63+sqnW3h6zf6f1dhsjV+f4difGUzoZG59kcytz6cGZtVCw9ALaBh+Mbo1nZAepj5SRaiVoAiJXnO68zDzkSZbYuHXYQJzVI9S7C1mj29P8mtv49429x4DjMgYwfT+05lWMA235dhP42pRLbjMLjxWDzaTTQZgSerDOhygr7zySkpLS7n//vvJyzu6VauLFi3ilVdeYcuWLdjtdk499VQefPBBRo4cmTwnHA5z88038/zzzxOJRJg5cyZPPvkkeXl5yXNKSkqYM2cO77//Pi6Xi9mzZ7No0SJMpuN3F1lMN6hqpbazEILnVmzl+XW1yWPfGWHhhxOsWJp6uFq4nry1j+Cs2r8iXzc78Q4+F+/QC4nZsvDrARrC5UTb2IJkNam47SZs5jbmLFVzYpuULb3NFJy+iI+KYAUlvhLWVa3jy+oviR5ivzQk5o+n5E1hct5khqYPPWa3OikoOM1O7CY7dpM9uVBLzhFL0rGjwxHsk08+YeXKlUyYMOGoX/zDDz9k7ty5nHzyycTjcW6//XbOOeccNm/ejNOZ6E3ddNNNvP7667z00kt4PB7mzZvHxRdfzIoVKwDQdZ3zzz+f/Px8PvnkE8rLy7n66qsxm83cf//9R93Gvqq8IdxiaFsIwV+Xb+c/G2qSx64bb+WKMfuHeZ0Vq8hb8wharDHxHEWlfvhliaFss4O40KmIVLaaWEQhsSo73WFpe55ZtYAzK5GG84DPdnEjTrG3mG3129hev51t9duoCx9+NCbPkccg9yAGuQcxInMEozNH9/mqPCoqVpMVk2JKJuNQUNBUDZvJlly4JUnSsa3D1axOOukknnzySaZNm9bpjamuriY3N5cPP/yQM844A6/XS05ODs899xyXXnopAFu2bGH06NGsXLmSadOm8eabb3LBBRdQVlaW7FUvXryYW2+9lerqaiyWw/8iO9aqWQUicXZVB1KOGULwx/e28tZX+4Pz3JNsXDSi6f4Ig8yvniVr2wvJx+PWdCqm/IJQzniEENTGGmjU/RgH/ZWxmlQcFg2HxXTohdb2THDmJAOzEIKNtRt5q/gtvqz+8rAJQTxWDxNzJjI0fSiD3YMZmDawz2x7UlERiGS6SVVRk3V2Dyz5pyma7AVL0jGoW6pZPfDAA9x8883cd999jBs3rsUc9NEEuOZqWJmZmQCsWbOGWCzGjBkzkueMGjWKwsLCZIBeuXIl48aNSxnynjlzJnPmzGHTpk1MmjTpiNvTF4VjOntqU5NsCCFYvGwzb21JVFNSFbjpZBvnDk0EZ0WPkrf2EdJKP0o+x9+viKqJ89CtHnShUxmtIXTAXK/FpGK3qNhMppbJRA6mWiAtDyyJYBo34qwsW8mSXUvY49vT6lNsmo0T0k9ILuwanj6coelD+8ScqoqKx+rBrJqTw9ByNbQkSR3V4QB97rnnAnD22WenHBdCoCgKut7xurYAhmEwf/58TjvtNE48MZF9qqKiAovFQnp6esq5eXl5VFRUJM85MDg3P978WGsikQiRyP5g4/P5jqjNvdG++hC6sb+HKwydv3+wgTe3+IFEcL5tmp2zBiU+WGkRL/mrFuGo3Zg4H5WasbNpGHYxOgJvrAFvvDHZa1YUcNtNuG2HS0ShgMUJVk/i/6pCIBbgvZL3eLP4zRbD1xnWDE7MPpHhGcMZmTmSgWkDe20wNikmLJol0RMm0UabyYbD7EgUvldMshcsSdJR63CAfv/997uiHcydO5eNGzfy8ccfd8n1D7Ro0SLuueeeLn+d7lYXiBKKpn5AeunjTfx7cyI4K8CtBwRna8NO+n12L+ZQNZDYOlUy5WaqsscSjFSl7GVWALfDhMtiPny+EEsauPJAS5Tf21K3hY9KP2JF6YoWK65P8JzABSdcwCn5p/S6oKaiJhdhNaehtGrWXvvBQZKkY0uHA/TXvva1Tm/EvHnzWLJkCcuXL2fAgP2lCPPz84lGozQ0NKT0oisrK8nPz0+es2rVqpTrVVZWJh9rzcKFC1mwYEHye5/Px8CBAzvr7fQIXzhGaX1qQpL/rNrG//ty/+jA/JNtfL0pONtqv6Jg5Z1o8cRz4tYMdp78c4od6RDbX8dYUcBh0XDbza2XeWymmhMZvxwZYLJS6i/lo30f8WnZp1QEU0cyFBQm503m/KHnMypzVK8b/rVpNvo5+8mhaUmSelSHA/Ty5csP+fgZZ5zR7msJIbjxxht59dVX+eCDDxgyZEjK45MnT8ZsNrNs2TIuueQSALZu3UpJSQlFRUUAFBUVcd9991FVVUVubi4AS5cuxe12M2bMmFZf12q1YrUeWwkqDq5Q9fnm7fxlVVXy+zmTrHzzhMScs612M/1X3oXaFJxDGSPZfNI8qg/Y7qSp4LKZcFvNrafiVDSwuRN7mM1O0DR0Q+fzys95e/fbbK7d3OIpNs3GGQPO4Nwh51LgKuiEd310kqujm8oR2kw20ixpOEwOGZglSepxHQ7QZ555ZotjB/4y68gc9Ny5c3nuuef4z3/+Q1paWnLO2OPxYLfb8Xg8XHfddSxYsIDMzEzcbjc33ngjRUVFyVXk55xzDmPGjOGqq67ioYceoqKigl/+8pfMnTv3mAvCbfEGY0Ri+xOS1JTt4uHllcnvrz7RysUjE/fCVrOR/p/ekwzOwZyJrD9pLl6RWEFtM2s4rRoOSxvDzVZPYv+yyZrMje2NeHlv13ss3bO0xdyygsKYrDF8beDXOCX/FGymjqfvPBomxYTD5MBmsiULOVhUiyxZKElSr9fhAF1fX5/yfSwW44svvuCOO+7gvvvu69C1/vjHPwItg/7TTz/NNddcA8AjjzyCqqpccsklKYlKmmmaxpIlS5gzZw5FRUU4nU5mz57Nr371q46+tT7JMASVjU29ZyOG5i3ht8urCDbVhPjaQBPfH5voObtKPyJvzSPJes3e7HGsm3g9YRHDYdVwWU1YTa3MryoqmOyJghU2DyiJ0Y8d9dt5e/fbfFr+aYsiFP2c/ZgxaAan9T+NdGt6V739VmmKht1kx2l2kmHN6HVz25IkSe3R4X3Qbfnwww9ZsGABa9as6YzLdau+ug9aCMGumgDBiA5CoNXv5InPanl9Z6I3nO9U+NO5LpxqlJwNT+HZ/VbyubXZJ7Jx8o+wORzYTCqmtvJk2zzgzE32lg1h8HnF5/x353/Z0bAj5VQFhZPyTmLm4JmcmH1ity+msqgWsuxZeCweGZQlSepVumUfdFvy8vLYunVrZ11OaocafzQRnAGTv5THVtbyVnEiOKsK/GKqHXe0ioLPfo3Vtzv5vLJ+Uyk95Vqy7YeYAtCs4MhMzDMDMT3GR6Uf8b+d/6M8UJ5yqsvs4qzCs/jGoG+Q68jt3Dd5CJqiYVYTQ9YOs4NMW6YctpYk6ZjR4QD95ZdfpnwvhKC8vJwHHniAiRMndla7pMMIRXUqfYmhbVOwiiUbKlKC8/wpNiZb99L/o7swNc0L66qFbWMuJzrqTBytDWU3c+WD3ZN4nXiId/e8yxu73qA+kjq9UZhWyHlDzuO0/qd1S+pJu2bHbXVj1axYNAsW1SIDsiRJx6wOB+iJEyeiKAoHj4xPmzaNv/3tb53WMKltQgj21TeVkTRirNiylyfX7l/Ffds0O990bqHfR/eixRMpPwOOXNaf9GOc/Ya0PZytaOAZAGYbNaEa3ip+i/f3vk8glpo2dEzWGL51wreYkDOhSwNk8wprp9lJpi2zz6T1lCRJ6gwdDtDFxcUp36uqSk5ODjZb967OPZ6VNoQIN63arq+u4DerQjR/XLpilInvRP9H1vp/oDYt3GpwD2btST8hPSur7eCsWTHS+vFRxad8VPoRm2o2IUj9EHZy/sl864RvMTxjeJe8L7tmx2qy4jK7MKkm7Ca7TAoiSdJxq8MBetCgQV3RDqmdqhsj1AcSQ9mRWIyHPygl3LSA+uKBAe4IPIFz97r952eN4ctJ1+NOS2u9wpSigj2TOlXhic8fYlPtppSHTaqJ6f2nc+HQC+mf1r/T34+maGTZssiwZfT5KlSSJEmdqd2/Ed977z3mzZvHp59+2mIFmtfr5dRTT2Xx4sWcfvrpnd5IKaEuEE3OOwsh+MPbG9lQnYjO51g38VDD7zE1lYkEKB50NjtHXUSO29l6z1nRIH0gX9Rt5sl1T9IY3f/cPEcepw84nRmDZnTZNim3xU0/Zz8ZmCVJklrR7t+Mjz76KNdff32ry8M9Hg8//vGP+d3vficDdBcJRuOUNYQS885C8PbqTXy4OwAIrje/zUL1WdRYYkV3xJLG+vE/wJczipw0a+spOhWNsDOHl7a9yOu7Xk8ezrRl8uPxP2Z8zvhOn182q2bSzGnYTDZcZhdm7XAFNyRJko5f7Q7Q69ev58EHH2zz8XPOOYff/OY3ndIoKZUQgr11TcEZ2LN7O3/+vAGAu0z/4FrtbZqni6uyT2Tj2KsQDnebwTkkDP5TvYZ3St4lGN9fmnJy3mRumHADaZa0Tmu7STGRZc8i3Zoue8qSJEkd0O7fmJWVlS1qP6dcyGSiurq6Uxolpar2R4jGE4vCwvUV3PtBNTEDvqWu4FrT28nzdg/6OltGXIzJpJHjaiU4KybWBPfxl63Pp2yZMqkmZo2exbmDz+20XrPT5CTTnonb0ncSv0iSJPUm7Q7Q/fv3Z+PGjQwbNqzVx7/88kv69evXaQ2TEmK6QU1jIjVnINDIvW8XUxEQ9KeaRZb929o2jvke+wZMx2HV8LRSeWpLsIpXy5ezvmZD8pimaJw+4HTOH3o+A9OOrpqXgkKaOQ231Y3b4pb7kyVJko5SuwP0N7/5Te644w7OPffcFluqQqEQd911FxdccEGnN/B4JoRgd00A3RCEozF+vWQTm2p0cqjnH9aHcJIoeFHa7xT2DZiO227CY08d5QgZMf5V9hHvlH6YcnxizkSuOfEa8p2tl+RsL03RyLBmkG3Pluk1JUmSOlG7c3FXVlZy0kknoWka8+bNY+TIkQBs2bKFJ554Al3XWbt2LXl5eV3a4K7QW3NxNwSjTXPPgt8uWcuHe0LkU8sL1vsYpCQqfwVtWXxSdDtOdxrug4LzxsYS/lT8H6pDNclj2fZsLh5+MWcNPOuoerl2zU66LV3mvZYkSWqHLs3FnZeXxyeffMKcOXNYuHBhMpOYoijMnDmTJ554ok8G595KCEGlLwLAG6u38OGeEAOUav5luZeBSmKuP2jLYvWUn2FPSw3O/niIZ/e9x/uVq5LHrJqVK0ZdwczBM48o+YdJMeGyuHCZXThMDrkCW5IkqYt1aFntoEGDeOONN6ivr2fHjh0IIRg+fDgZGRld1b7jVm0gSjRu8OXOfTy1upZBSgXPWe6jv1ILQMCRw+dTfoYjKx+HNdGDFUKwomEb/9i9BF/Ul7zW6MzR3DDhBvKcHf8AlW5NJ8Oagd1kl/PKkiRJ3eiI9r1kZGRw8sknd3ZbpCZCCGr9UUrKK7nv3d1kCC/PWfcHZ78zj9WTf4YnJ68pO5hCRTzI33b/jy8PyARmN9m5ctSVzBg0o0O9ZpNiItOWicfq6ZYiGJIkSVJLcmNqL9QQjFFVW8/db+5AxMIstjySDM6NrgJWT/4pZndGIjibbHwWKOWJLxcTNaLJa0ztN5XZY2eTacts9+sqKGTbs8m2Z8sc2JIkST1MBuheJq4b7KsP8dt3thIMBnnG8jBT1G0AhK3prJ58I7rdTbbdTD0G/9r9OstLlyefn2XL4gfjfsDkvMkdel23xU2+I1/OLUuSJPUSMkD3MtX+CC+t3MKOygb+bnkoGZxjJhtrJ92A5soky2Fhc6yW329+OiV/9un9T+e6cddhM7W/spimaOQ58siwyXUEkiRJvUmPjmMuX76cCy+8kIKCAhRF4bXXXkt5XAjBnXfeSb9+/bDb7cyYMYPt27ennFNXV8esWbNwu92kp6dz3XXX4ff7u/FddJ5IXOfL4kpeW1fKPywPHBCc7aye/DMimYPJcJr5b91a7l/3h2RwdpqdXDP2Gn4y8SftDs6aopFjz2GoZ6gMzpIkSb1QjwboQCDAhAkTeOKJJ1p9/KGHHuL3v/89ixcv5rPPPsPpdDJz5kzC4XDynFmzZrFp0yaWLl3KkiVLWL58OT/60Y+66y10qr0VtTz41hZuV/7OSeoOAKJmJ6umzCecOQS7U+U3u1/lxV3/SdZqnpgzkUfOeoRzh7QvTaeCQpYtixPSTyDXkSsXgUmSJPVS7U5U0tUUReHVV1/loosuAhK954KCAm6++WZuueUWIFHWMi8vj2eeeYYrrriCr776ijFjxrB69WqmTJkCwFtvvcU3v/lN9u3bR0FBQbteuzckKvEGY9zz4scEtn3AnyyPAhDXrHx2ys340wbgs3h5cueL1IQTi8UUFC4beRkXDbuoXQu6TIqJXEcuaZY0WbRCkiSpmx1JnOm1S3WLi4upqKhgxowZyWMej4epU6eycuVKAFauXEl6enoyOAPMmDEDVVX57LPPur3NR0oIwdIvtvP51mIeNv85eXzLyEsJeQawIbqR+zb/ORmc0yxp3D71di4efvFhg7OCQo49h+EZw8mwZcjgLEmS1Ef02t/WFRWJVJYHZyfLy8tLPlZRUUFubm7K4yaTiczMzOQ5rYlEIkQikeT3Pp+vzXO7w94aH39690ueMT+IW0mUfyzPO4nKIVN5ufJNVtSuT547MmMkN550I9n27MNe16SYKHAVdGr5SEmSJKl79NoA3ZUWLVrEPffc09PNABK951+/9gW/ij/GUC3xoaLRmc87o87kmZ1/peaAspDnDz2fK0ddedhesIqK2+om15GLWZXbpiRJkvqiXjvEnZ+fqLJUWVmZcryysjL5WH5+PlVVVSmPx+Nx6urqkue0ZuHChXi93uTX3r17O7n17ffq2n0M2/0virTNAAQsHn43ejq/KXk5GZztJjvzT5rPVWOuOmxwzrRmMiJjBP1d/WVwliRJ6sN6bYAeMmQI+fn5LFu2LHnM5/Px2WefUVRUBEBRURENDQ2sWbMmec57772HYRhMnTq1zWtbrVbcbnfKV09oDMd4841XuMX0AgAChXtHTOHl2v1FLsZmjeXBMx5kWsG0Nq/TPM88ImME/Vz9ZHUpSZKkY0CPDnH7/X527NiR/L64uJh169aRmZlJYWEh8+fP595772X48OEMGTKEO+64g4KCguRK79GjR3Puuedy/fXXs3jxYmKxGPPmzeOKK65o9wrunvTY0q3Mif0DTU0spH/shKksCezf5335yMu5aNhFrW6f0hSNLFsWTrNTFrKQJEk6BvVogP78888566yzkt8vWLAAgNmzZ/PMM8/wi1/8gkAgwI9+9CMaGhqYPn06b731Fjbb/mQczz77LPPmzePss89GVVUuueQSfv/733f7e+moktoA/tX/TO53fjazP381ypKP/3DcD5kxaEaL55kUE1n2LDJtmTJftiRJ0jGs1+yD7kndvQ9aCMF1T77Bw1U/Jktp5BObjZ/0y0NvSj5yyfBLuGzkZSnPsWt2nGYn2fZsOYQtSZLUxxxJnDkuV3H3tP+uL2Nm+Z/JMjWy1Wzmpvz9wfncwedy6YhLk+dqikaGNYNcR64cxpYkSTqOyADdzYLROEvfeJnHTR9QZtK4IT+XoJIIzlPypnD12KtRFAWzaibfmY/b0jML2CRJkqSeJQN0N3v8nY3MDy+m1qTy47xcakyJ4eph6cO48aQbURU1UfrRmS+3SUmSJB3HZIDuRptKvZg+fZwCcznX5Oex25IIwP2c/fjFKb/AY/GQ78zHaXb2cEslSZKkniYDdDcRQrD41Xd4WHuN23Ky+MqaqCKVacvk9qm3Mzx9eLvSd0qSJEnHB7lPp5u891Ull1c+wgseG8ucDgAcJge3T72dE7NPlMFZkiRJSiEDdDeI6waf/mcxNucOHslMTx6/cdKNTOs3TQZnSZIkqQU5xN0N/r1iI1dE/8YNA7LQm7ZKfWfYd/jO8O/I+WZJkiSpVbIH3cUawzG09+7iN7kWKkyJz0NjMscwf/J8GZwlSZKkNskedBf79//+R9TzOR870gFwm13cO/1eMm2ZPdswSZIkqVeTPegutLc2gGn7fTyR4QFAAe6dfj/DM4b3bMMkSZKkXk/2oLvQkpef4LXcIIaSuM0/GvdDzio86zDPkiRJkiTZg+4y63aWUh75K2XmRHCe5BzMTybd2MOtkiRJkvoKGaC7yKrX7+I/7kSmMIuA+855QpaHlCRJktpNRowusGdvCZu0DzGatlT9cMQVDHQX9nCrJEmSpL5EBugu8PHbv+I9lw0AjzAz++SberhFkiRJUl8jA3Qni4UaWaKvSH5/zajZOMyOHmyRJEmS1BfJAN3J/rHkbjbaEgvD8uNmZp/8kx5ukSRJktQXHTMB+oknnmDw4MHYbDamTp3KqlWreqQd79e9m/zz9wbNxqzJms6SJElSxx0TAfqFF15gwYIF3HXXXaxdu5YJEyYwc+ZMqqqqurUdq9a9wXqbAUBeDK4+a263vr4kSZJ07DgmAvTvfvc7rr/+eq699lrGjBnD4sWLcTgc/O1vf+vWdrz0+WPJP59qnYCmyTwwkiRJ0pHp8wE6Go2yZs0aZsyYkTymqiozZsxg5cqV3daOsuo9vK+VAmASgtln/V+3vbYkSZJ07OnzXbyamhp0XScvLy/leF5eHlu2bGn1OZFIhEgkkvze5/MddTv++e59RNTEvufREQsnDBh91NeUJEmSjl99vgd9JBYtWoTH40l+DRw48Kivect3/8j0SDoe3eDaCbd2QislSZKk41mfD9DZ2dlomkZlZWXK8crKSvLz81t9zsKFC/F6vcmvvXv3HnU7VE3jN99/g9+fuphvTLv8qK8nSZIkHd/6fIC2WCxMnjyZZcuWJY8ZhsGyZcsoKipq9TlWqxW3253y1RmcjjROGnV6p1xLkiRJOr71+TlogAULFjB79mymTJnCKaecwqOPPkogEODaa6/t6aZJkiRJ0hE5JgL05ZdfTnV1NXfeeScVFRVMnDiRt956q8XCMUmSJEnqKxQhhOjpRvQ0n8+Hx+PB6/V22nC3JEmSJDU7kjjT5+egJUmSJOlYJAO0JEmSJPVCMkBLkiRJUi90TCwSO1rN0/CdkVFMkiRJkg7WHF86suxLBmigsbERoFMyikmSJElSWxobG/F4PO06V67iJpHYpKysjLS0NBRFOeLr+Hw+Bg4cyN69e+Vq8MOQ96p95H1qP3mv2kfep/brzHslhKCxsZGCggJUtX2zy7IHTaL61YABAzrtep2ZnexYJ+9V+8j71H7yXrWPvE/t11n3qr0952ZykZgkSZIk9UIyQEuSJElSLyQDdCeyWq3cddddWK3Wnm5KryfvVfvI+9R+8l61j7xP7dfT90ouEpMkSZKkXkj2oCVJkiSpF5IBWpIkSZJ6IRmgJUmSJKkXkgG6Ez3xxBMMHjwYm83G1KlTWbVqVU83qcssWrSIk08+mbS0NHJzc7nooovYunVryjnhcJi5c+eSlZWFy+XikksuobKyMuWckpISzj//fBwOB7m5ufz85z8nHo+nnPPBBx9w0kknYbVaGTZsGM8880xXv70u9cADD6AoCvPnz08ek/cqobS0lO9///tkZWVht9sZN24cn3/+efJxIQR33nkn/fr1w263M2PGDLZv355yjbq6OmbNmoXb7SY9PZ3rrrsOv9+fcs6XX37J6aefjs1mY+DAgTz00EPd8v46i67r3HHHHQwZMgS73c4JJ5zAr3/965Q0ksfrvVq+fDkXXnghBQUFKIrCa6+9lvJ4d96Xl156iVGjRmGz2Rg3bhxvvPFGx96MkDrF888/LywWi/jb3/4mNm3aJK6//nqRnp4uKisre7ppXWLmzJni6aefFhs3bhTr1q0T3/zmN0VhYaHw+/3Jc2644QYxcOBAsWzZMvH555+LadOmiVNPPTX5eDweFyeeeKKYMWOG+OKLL8Qbb7whsrOzxcKFC5Pn7Nq1SzgcDrFgwQKxefNm8Yc//EFomibeeuutbn2/nWXVqlVi8ODBYvz48eJnP/tZ8ri8V0LU1dWJQYMGiWuuuUZ89tlnYteuXeLtt98WO3bsSJ7zwAMPCI/HI1577TWxfv168a1vfUsMGTJEhEKh5DnnnnuumDBhgvj000/FRx99JIYNGyauvPLK5ONer1fk5eWJWbNmiY0bN4p//etfwm63iz/96U/d+n6Pxn333SeysrLEkiVLRHFxsXjppZeEy+USjz32WPKc4/VevfHGG+L//u//xCuvvCIA8eqrr6Y83l33ZcWKFULTNPHQQw+JzZs3i1/+8pfCbDaLDRs2tPu9yADdSU455RQxd+7c5Pe6rouCggKxaNGiHmxV96mqqhKA+PDDD4UQQjQ0NAiz2Sxeeuml5DlfffWVAMTKlSuFEIl/SKqqioqKiuQ5f/zjH4Xb7RaRSEQIIcQvfvELMXbs2JTXuvzyy8XMmTO7+i11usbGRjF8+HCxdOlS8bWvfS0ZoOW9Srj11lvF9OnT23zcMAyRn58vHn744eSxhoYGYbVaxb/+9S8hhBCbN28WgFi9enXynDfffFMoiiJKS0uFEEI8+eSTIiMjI3nfml975MiRnf2Wusz5558vfvCDH6Qcu/jii8WsWbOEEPJeNTs4QHfnffnud78rzj///JT2TJ06Vfz4xz9ud/vlEHcniEajrFmzhhkzZiSPqarKjBkzWLlyZQ+2rPt4vV4AMjMzAVizZg2xWCzlnowaNYrCwsLkPVm5ciXjxo0jLy8vec7MmTPx+Xxs2rQpec6B12g+py/e17lz53L++ee3eD/yXiX897//ZcqUKVx22WXk5uYyadIknnrqqeTjxcXFVFRUpLxHj8fD1KlTU+5Teno6U6ZMSZ4zY8YMVFXls88+S55zxhlnYLFYkufMnDmTrVu3Ul9f39Vvs1OceuqpLFu2jG3btgGwfv16Pv74Y8477zxA3qu2dOd96Yx/jzJAd4Kamhp0XU/55QmQl5dHRUVFD7Wq+xiGwfz58znttNM48cQTAaioqMBisZCenp5y7oH3pKKiotV71vzYoc7x+XyEQqGueDtd4vnnn2ft2rUsWrSoxWPyXiXs2rWLP/7xjwwfPpy3336bOXPm8NOf/pS///3vwP73eah/ZxUVFeTm5qY8bjKZyMzM7NC97O1uu+02rrjiCkaNGoXZbGbSpEnMnz+fWbNmAfJetaU770tb53TkvsliGdJRmzt3Lhs3buTjjz/u6ab0Snv37uVnP/sZS5cuxWaz9XRzei3DMJgyZQr3338/AJMmTWLjxo0sXryY2bNn93DrepcXX3yRZ599lueee46xY8eybt065s+fT0FBgbxXxxDZg+4E2dnZaJrWYtVtZWUl+fn5PdSq7jFv3jyWLFnC+++/n1IRLD8/n2g0SkNDQ8r5B96T/Pz8Vu9Z82OHOsftdmO32zv77XSJNWvWUFVVxUknnYTJZMJkMvHhhx/y+9//HpPJRF5enrxXQL9+/RgzZkzKsdGjR1NSUgLsf5+H+neWn59PVVVVyuPxeJy6uroO3cve7uc//3myFz1u3DiuuuoqbrrppuQIjbxXrevO+9LWOR25bzJAdwKLxcLkyZNZtmxZ8phhGCxbtoyioqIebFnXEUIwb948Xn31Vd577z2GDBmS8vjkyZMxm80p92Tr1q2UlJQk70lRUREbNmxI+cewdOlS3G538hd1UVFRyjWaz+lL9/Xss89mw4YNrFu3Lvk1ZcoUZs2alfyzvFdw2mmntdiqt23bNgYNGgTAkCFDyM/PT3mPPp+Pzz77LOU+NTQ0sGbNmuQ57733HoZhMHXq1OQ5y5cvJxaLJc9ZunQpI0eOJCMjo8veX2cKBoMtagprmoZhGIC8V23pzvvSKf8e272cTDqk559/XlitVvHMM8+IzZs3ix/96EciPT09ZdXtsWTOnDnC4/GIDz74QJSXlye/gsFg8pwbbrhBFBYWivfee098/vnnoqioSBQVFSUfb946dM4554h169aJt956S+Tk5LS6dejnP/+5+Oqrr8QTTzzRp7YOteXAVdxCyHslRGILmslkEvfdd5/Yvn27ePbZZ4XD4RD//Oc/k+c88MADIj09XfznP/8RX375pfj2t7/d6haZSZMmic8++0x8/PHHYvjw4SlbZBoaGkReXp646qqrxMaNG8Xzzz8vHA5Hr946dLDZs2eL/v37J7dZvfLKKyI7O1v84he/SJ5zvN6rxsZG8cUXX4gvvvhCAOJ3v/ud+OKLL8SePXuEEN13X1asWCFMJpP4zW9+I7766itx1113yW1WPekPf/iDKCwsFBaLRZxyyini008/7ekmdRmg1a+nn346eU4oFBI/+clPREZGhnA4HOI73/mOKC8vT7nO7t27xXnnnSfsdrvIzs4WN998s4jFYinnvP/++2LixInCYrGIoUOHprxGX3VwgJb3KuF///ufOPHEE4XVahWjRo0Sf/7zn1MeNwxD3HHHHSIvL09YrVZx9tlni61bt6acU1tbK6688krhcrmE2+0W1157rWhsbEw5Z/369WL69OnCarWK/v37iwceeKDL31tn8vl84mc/+5koLCwUNptNDB06VPzf//1fyraf4/Vevf/++63+bpo9e7YQonvvy4svvihGjBghLBaLGDt2rHj99dc79F5kNStJkiRJ6oXkHLQkSZIk9UIyQEuSJElSLyQDtCRJkiT1QjJAS5IkSVIvJAO0JEmSJPVCMkBLkiRJUi8kA7QkSZIk9UIyQEuSJElSLyQDtCQdA6655houuuiinm6GJEmdSJablKReTlGUQz5+11138dhjj9HbkgJ+8MEHnHXWWdTX17eodS1J0uHJAC1JvVx5eXnyzy+88AJ33nlnStUnl8uFy+XqiaZJktSF5BC3JPVy+fn5yS+Px4OiKCnHXC5XiyHuM888kxtvvJH58+eTkZFBXl4eTz31FIFAgGuvvZa0tDSGDRvGm2++mfJaGzdu5LzzzsPlcpGXl8dVV11FTU1Nm23bs2cPF154IRkZGTidTsaOHcsbb7zB7t27OeusswDIyMhAURSuueYaIFGKddGiRQwZMgS73c6ECRN4+eWXk9f84IMPUBSF119/nfHjx2Oz2Zg2bRobN2487OtK0rFEBmhJOkb9/e9/Jzs7m1WrVnHjjTcyZ84cLrvsMk499VTWrl3LOeecw1VXXUUwGASgoaGBr3/960yaNInPP/+ct956i8rKSr773e+2+Rpz584lEomwfPlyNmzYwIMPPojL5WLgwIH8+9//BhK1rcvLy3nssccAWLRoEf/4xz9YvHgxmzZt4qabbuL73/8+H374Ycq1f/7zn/Pb3/6W1atXk5OTw4UXXpisv9vW60rSMaVDta8kSepRTz/9tPB4PC2Oz549W3z7299Ofv+1r31NTJ8+Pfl9PB4XTqdTXHXVVclj5eXlAhArV64UQgjx61//Wpxzzjkp1927d68AWpTjazZu3Dhx9913t/pYc9m/+vr65LFwOCwcDsf/b+9+QmEL4zCOfw8hSQk1RRNKo1Gj/NnYWCEbKysLRSyIGLGwscCC/ZSN1ezY2DCLUZoVKTWRf4VDWYmwOVmoY+5CTve9uLp3de7c51On3nnnvO9vVvP0nvN2TmZ3d9c4d3Bw0Hvf7vu41dVV7/uHh4dMYWFhZm1t7du6ItlC96BFslRDQ4PXzs3NpaysjEgk4vUFAgEA7u7uADg8PCSVSn26ErVtm1Ao9KF/fHyckZERtra2aG9vp6enx6j7q8vLS56fn+no6DD6X15eaGxsNPpaW1u9dmlpKXV1dZydnf1VXZF/kS5xi2SpvLw847NlWUbf++7w19dXABzHobu7m4ODA+O4uLigra3t0xpDQ0NcXV3R19fH0dERLS0txGKxL3+T4zgAJBIJo8bp6alxH/o7f1pX5F+kgBYRAJqamjg5OaG6upra2lrjKCoq+nJcMBhkeHiY9fV1pqamWFlZASA/Px8A13W9c+vr6ykoKODm5uZDjWAwaMy7t7fntZ+enjg/PyccDn9bVyRbKKBFBHjbePX4+Ehvby/7+/vYtk0ymWRgYMAI2Z9Fo1GSySTX19ek02lSqZQXolVVVViWxebmJvf39ziOQ3FxMdPT00xOThKPx7Ftm3Q6TSwWIx6PG3PPz8+zvb3N8fEx/f39lJeXezvVf1dXJFsooEUEgIqKCnZ2dnBdl87OTiKRCNFolJKSEnJyPv+rcF2X0dFRwuEwXV1dhEIhlpeXAaisrGRubo6ZmRkCgQBjY2MALCwsMDs7y+LiojcukUhQU1NjzL20tMTExATNzc3c3t6ysbFhrMq/qiuSLaxMxmePHxKR/5qeQCbyRitoERERH1JAi4iI+JAucYuIiPiQVtAiIiI+pIAWERHxIQW0iIiIDymgRUREfEgBLSIi4kMKaBERER9SQIuIiPiQAlpERMSHFNAiIiI+9ANrYHjRhjnZ3gAAAABJRU5ErkJggg==",
            "text/plain": [
              "<Figure size 500x300 with 1 Axes>"
            ]
          },
          "metadata": {},
          "output_type": "display_data"
        }
      ],
      "source": [
        "# Set seed for reproducibility\n",
        "np.random.seed(42)\n",
        "\n",
        "# Parameters\n",
        "n = 10\n",
        "T = 10000\n",
        "alpha = 2\n",
        "repeat = 20  # Number of repetitions\n",
        "gamma_values = [0.5, 0.75, 1.0]  # Gamma values to use in the experiment\n",
        "\n",
        "# Generate the same means for all experiments\n",
        "means = np.random.uniform(0, 1, size=n)  # Means between 0 and 1\n",
        "\n",
        "# Prepare to store cumulative regret for each gamma value\n",
        "cu_regret_gamma = np.zeros((len(gamma_values), repeat, T))\n",
        "\n",
        "# Loop through each gamma value\n",
        "for idx, gamma in enumerate(gamma_values):\n",
        "    for r in range(repeat):\n",
        "        # Create the MCAR environment with the same means but different gamma\n",
        "        # Set a seed for each repetition to make the experiment reproducible\n",
        "        np.random.seed(42 + r + idx * repeat)  # Unique seed per gamma and repetition\n",
        "\n",
        "        mcar_env = MCAR(means, gamma)\n",
        "\n",
        "        # Run the MCAR algorithm\n",
        "        ucb_alg = MCAR_algo(mcar_env, alpha)\n",
        "        results, regrets = ucb_alg.run(T)\n",
        "\n",
        "        # Store the regrets for this repetition\n",
        "        cu_regret_gamma[idx, r] = regrets\n",
        "\n",
        "# Plot the cumulative regrets for different gamma values with error shading\n",
        "plt.figure(figsize=(5, 3))\n",
        "\n",
        "# Loop over gamma values to plot\n",
        "for idx, gamma in enumerate(gamma_values):\n",
        "    mean_regret = np.mean(cu_regret_gamma[idx], axis=0)  # Mean cumulative regret\n",
        "    std_regret = np.std(cu_regret_gamma[idx], axis=0)  # Standard deviation of cumulative regret\n",
        "\n",
        "    # Plot the mean cumulative regret\n",
        "    plt.plot(mean_regret, label=fr'$\\gamma = {gamma}$', linewidth=2)\n",
        "\n",
        "    # Add shaded area for error indication (1 standard deviation)\n",
        "    plt.fill_between(np.arange(T),\n",
        "                     mean_regret - std_regret,\n",
        "                     mean_regret + std_regret,\n",
        "                     alpha=0.2)\n",
        "\n",
        "# Labeling and formatting\n",
        "plt.xlabel('Time steps')\n",
        "plt.ylabel('Cumulative Regret')\n",
        "\n",
        "# Add LaTeX formatted legend\n",
        "plt.legend(loc='upper left')\n",
        "\n",
        "# Plot settings\n",
        "plt.grid(False)\n",
        "\n",
        "# Tight layout for better spacing\n",
        "plt.tight_layout()\n",
        "\n",
        "# Save the figure with high resolution\n",
        "plt.savefig('cumulative_regret_gamma_values_same_means.png', dpi=300)\n",
        "\n",
        "# Display the plot\n",
        "plt.show()"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "10HvOjA73wnf"
      },
      "source": [
        "#UCB"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "IccDsL2O3y0I"
      },
      "outputs": [],
      "source": [
        "class UCB_algo:\n",
        "    def __init__(self, bandit_env, alpha):\n",
        "        self.bandit_env = bandit_env\n",
        "        self.num_arms = bandit_env.num_arms\n",
        "        self.counts = np.zeros(self.num_arms)\n",
        "        self.means = np.zeros(self.num_arms)\n",
        "        self.total_pulls = 0\n",
        "        self.alpha = alpha\n",
        "\n",
        "    def select_arm(self, round_number):\n",
        "        if self.total_pulls < self.num_arms:\n",
        "            return self.total_pulls\n",
        "\n",
        "        ucb_values = np.zeros(self.num_arms)\n",
        "        for arm in range(self.num_arms):\n",
        "            if self.counts[arm] == 0:\n",
        "                ucb_values[arm] = float('inf')\n",
        "            else:\n",
        "                confidence_bound = np.sqrt(self.alpha / 2 * np.log(self.total_pulls) / self.counts[arm])\n",
        "                ucb_values[arm] = self.means[arm] + confidence_bound\n",
        "\n",
        "        return np.argmax(ucb_values)\n",
        "\n",
        "    def update(self, arm, reward, observed):\n",
        "        if observed:\n",
        "            self.counts[arm] += 1\n",
        "            self.means[arm] += (reward - self.means[arm]) / self.counts[arm]\n",
        "\n",
        "        self.total_pulls += 1\n",
        "\n",
        "    def update_regret(self, arm, cu_regret, regrets):\n",
        "        regret = np.sum(self.bandit_env.p[self.bandit_env.best_arm] * self.bandit_env.means[self.bandit_env.best_arm]) - np.sum(self.bandit_env.p[arm] * self.bandit_env.means[arm])\n",
        "        cu_regret += regret\n",
        "        regrets.append(cu_regret)\n",
        "        return cu_regret\n",
        "\n",
        "    def run(self, num_rounds):\n",
        "        results = []\n",
        "        regrets = []\n",
        "        cu_regret = 0\n",
        "        for round_number in range(num_rounds):\n",
        "            arm = self.select_arm(round_number)\n",
        "\n",
        "            reward, observed, context = self.bandit_env.pull_arm(arm)\n",
        "\n",
        "            cu_regret = self.update_regret(arm, cu_regret, regrets)\n",
        "            self.update(arm, reward, observed)\n",
        "\n",
        "            results.append((arm, reward, observed))\n",
        "\n",
        "        return results, regrets"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "2AEsN9l5SzRx"
      },
      "source": [
        "#MAR"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "bBUwE4CSS0oR"
      },
      "outputs": [],
      "source": [
        "import numpy as np\n",
        "\n",
        "class MAR:\n",
        "    def __init__(self, means, gamma, prob):\n",
        "        self.means = means\n",
        "        self.gamma = gamma\n",
        "        self.p = prob\n",
        "        self.num_arms = means.shape[0]  # Number of arms (n)\n",
        "        self.num_contexts = means.shape[1]  # Number of contexts (k)\n",
        "        self.best_arm = np.argmax(np.sum(self.p * self.means , axis=1))\n",
        "\n",
        "    def pull_arm(self, arm):\n",
        "        if arm >= self.num_arms:\n",
        "            raise ValueError(\"Invalid arm index\")\n",
        "\n",
        "        # Select a context based on the probability distribution p[arm]\n",
        "        context = np.random.choice(self.num_contexts, p=self.p[arm])\n",
        "\n",
        "        # Reward is drawn from a normal distribution centered at the means[arm, context]\n",
        "        reward = np.random.normal(self.means[arm, context], 1)\n",
        "\n",
        "        # Determine if the reward is observed based on the gamma[arm, context]\n",
        "        observed = np.random.rand() < self.gamma[arm, context]\n",
        "        if observed:\n",
        "            return reward, observed, context\n",
        "        else:\n",
        "            return None, observed, context"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "0x3n9taoIo8g"
      },
      "outputs": [],
      "source": [
        "class MAR_algo:\n",
        "    def __init__(self, bandit_env, alpha, p_known):\n",
        "\n",
        "        self.bandit_env = bandit_env\n",
        "        self.num_arms = bandit_env.num_arms\n",
        "        self.num_contexts = bandit_env.num_contexts\n",
        "        # self.p = bandit_env.p\n",
        "        self.alpha = alpha\n",
        "        self.p_known = p_known\n",
        "        self.p = np.zeros((self.num_arms, self.num_contexts))\n",
        "\n",
        "        self.counts = np.zeros((self.num_arms, self.num_contexts))  # Keeps track of how many times each arm-context pair has been pulled\n",
        "        self.means = np.zeros((self.num_arms, self.num_contexts))  # Estimate of the mean reward for each arm-context pair\n",
        "        self.s = np.zeros((self.num_arms, self.num_contexts))\n",
        "\n",
        "    def select_arm(self, round_number):\n",
        "\n",
        "        # Calculate UCB values for each arm based on all contexts\n",
        "        ucb_values = np.zeros(self.num_arms)\n",
        "        for arm in range(self.num_arms):\n",
        "            if self.p_known:\n",
        "              self.p = bandit_env.p\n",
        "            else:\n",
        "              self.p[arm, :] = self.s[arm, :] / np.sum(self.counts[arm])\n",
        "\n",
        "            if np.any(self.counts[arm] == 0):\n",
        "                ucb_values[arm] = float('inf')  # If no context has been explored for this arm, set UCB to infinity\n",
        "            else:\n",
        "                # Calculate the mean reward over all contexts weighted by pulls\n",
        "                mean_reward = np.sum(self.p[arm] * self.means[arm])\n",
        "\n",
        "                # UCB confidence bound using total counts\n",
        "                if self.p_known:\n",
        "                  confidence_bound = np.sqrt(self.alpha / 2 * np.log(round_number) * np.sum((p[arm] ** 2) / self.counts[arm]))\n",
        "                else:\n",
        "                  confidence_bound = 8 * np.sqrt(self.alpha / 2 * np.log(round_number) * np.sum((p[arm] ** 2) / self.counts[arm]))\n",
        "                ucb_values[arm] = mean_reward + confidence_bound\n",
        "\n",
        "        # Select the arm with the highest UCB value\n",
        "        return np.argmax(ucb_values)\n",
        "\n",
        "    def update(self, arm, context, reward, observed):\n",
        "        self.s[arm, context] += 1\n",
        "\n",
        "        if observed:\n",
        "            # Increment the count for the pulled arm-context pair\n",
        "            self.counts[arm, context] += 1\n",
        "\n",
        "            # Update the estimated mean reward for this arm-context pair\n",
        "            self.means[arm, context] = (reward + self.means[arm, context] * (self.counts[arm, context] - 1)) / self.counts[arm, context]\n",
        "\n",
        "    def update_regret(self, arm, context, cu_regret, regrets):\n",
        "\n",
        "        regret = np.sum(self.bandit_env.p[self.bandit_env.best_arm] * self.bandit_env.means[self.bandit_env.best_arm]) - np.sum(self.bandit_env.p[arm] * self.bandit_env.means[arm])\n",
        "\n",
        "        cu_regret += regret  # Add this round's regret to the cumulative regret\n",
        "        regrets.append(cu_regret)  # Store the cumulative regret\n",
        "        return cu_regret\n",
        "\n",
        "    def run(self, num_rounds):\n",
        "\n",
        "        results = []\n",
        "        regrets = []\n",
        "        cu_regret = 0\n",
        "\n",
        "        for arm in range(self.num_arms):\n",
        "          for _ in range(int(np.log(num_rounds)**2)):\n",
        "            reward, observed, context = self.bandit_env.pull_arm(arm)\n",
        "            cu_regret = self.update_regret(arm, context, cu_regret, regrets)\n",
        "            self.update(arm, context, reward, observed)\n",
        "            results.append((arm, reward, observed, context))\n",
        "\n",
        "        for round_number in range(num_rounds - self.num_arms * int(np.log(num_rounds)**2)):\n",
        "            # Select an arm using the UCB strategy\n",
        "            arm = self.select_arm(round_number)\n",
        "\n",
        "            # Pull the arm and observe the reward and context\n",
        "            reward, observed, context = self.bandit_env.pull_arm(arm)\n",
        "\n",
        "            # Update the cumulative regret and store the result\n",
        "            cu_regret = self.update_regret(arm, context, cu_regret, regrets)\n",
        "\n",
        "            # Update the means and counts based on the observed reward\n",
        "            self.update(arm, context, reward, observed)\n",
        "\n",
        "            # Store the results for this round\n",
        "            results.append((arm, reward, observed, context))\n",
        "\n",
        "        return results, regrets"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "xbdGs22f6zpe"
      },
      "source": [
        "##test"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "oREUP6k1Q61d"
      },
      "outputs": [],
      "source": [
        "np.random.seed(5)\n",
        "\n",
        "n = 10  # Number of arms\n",
        "k = 5   # Number of contexts\n",
        "\n",
        "means = np.random.uniform(0, 0.5, size=(n, k))\n",
        "means[0] = means[0] + 0.2\n",
        "gamma = np.random.uniform(0.2, 1.0, size=(n, k))\n",
        "\n",
        "# Randomly generate a probability matrix for the categorical distribution (each row sums to 1)\n",
        "p = np.random.dirichlet(np.ones(k), size=n)\n",
        "\n",
        "bandit_env = MAR(means, gamma, p)\n",
        "\n",
        "alpha = 1\n",
        "p_known = 1\n",
        "algo = MAR_algo(bandit_env, alpha, p_known)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "QVGAYEawazjZ",
        "outputId": "4ecce494-e8bd-4474-e201-b14660b33980"
      },
      "outputs": [
        {
          "name": "stderr",
          "output_type": "stream",
          "text": [
            "<ipython-input-13-1b3319606638>:34: RuntimeWarning: divide by zero encountered in log\n",
            "  confidence_bound = np.sqrt(self.alpha / 2 * np.log(round_number) * np.sum((p[arm] ** 2) / self.counts[arm]))\n",
            "<ipython-input-13-1b3319606638>:34: RuntimeWarning: invalid value encountered in sqrt\n",
            "  confidence_bound = np.sqrt(self.alpha / 2 * np.log(round_number) * np.sum((p[arm] ** 2) / self.counts[arm]))\n"
          ]
        }
      ],
      "source": [
        "np.random.seed(42)\n",
        "T = 50000\n",
        "results, regrets1 = algo.run(T)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 307
        },
        "id": "mBjD3iqjae5N",
        "outputId": "3568218c-ea2f-488c-f057-4fe0a79367a5"
      },
      "outputs": [
        {
          "data": {
            "image/png": "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",
            "text/plain": [
              "<Figure size 500x300 with 1 Axes>"
            ]
          },
          "metadata": {},
          "output_type": "display_data"
        }
      ],
      "source": [
        "plt.figure(figsize=(5, 3))\n",
        "plt.plot(regrets1, label='Cumulative Regret', color='blue', linewidth=2)\n",
        "plt.xlabel('Iteration')\n",
        "plt.ylabel('Cumulative Regret')\n",
        "# plt.legend(loc='upper left', fontsize=12)\n",
        "plt.grid(True, which='both', linestyle='--', linewidth=0.5)\n",
        "\n",
        "# Adjust the ticks for better readability\n",
        "# plt.xticks(fontsize=12)\n",
        "# plt.yticks(fontsize=12)\n",
        "\n",
        "# Save the figure with high resolution\n",
        "plt.tight_layout()\n",
        "plt.savefig('cumulative_regret_plot_paper.png', dpi=300)\n",
        "\n",
        "# Display the plot\n",
        "plt.show()"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "zerKDOMuIL1w"
      },
      "source": [
        "##UCB on MAR env"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "srLjxsC5Dbnq"
      },
      "outputs": [],
      "source": [
        "# bandit_env = MAR(means, gamma, p)\n",
        "np.random.seed(42)\n",
        "algo = UCB_algo(bandit_env, alpha)\n",
        "results, regrets2 = algo.run(50000)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 307
        },
        "id": "FmYqo8o4EPDV",
        "outputId": "2daf1351-a748-4b12-f929-bbabea6de0f6"
      },
      "outputs": [
        {
          "data": {
            "image/png": "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m2++yS233ALA3Llzue+++077WrW1tVxwwQVcdtllfPbZZ0RERLB7925CQ0ONZZ5//nlefvll3nrrLRITE1m0aBEzZ85k+/btxlr6nDlzOHjwICtXrqSjo4M777yTe++9l7/97W/2fryzFhERcc7f01VJVnrOJqfaWuu1iPvaPJ2ZCRERxxtYWBiMHAl+frZNbepUSE4+4zLOmb17Wxk50uwqXIP8/9NjZk5ndLlJR1m4cCHr1q3j66+/7vV5pRQxMTE88MADPPjggwDU19cTFRXFsmXLuOmmmygqKmL8+PHk5OQYa90rVqzg6quvZv/+/cTExJy2Dkfug66trbX5A0P0TbLS051TXh688AJUVh4/cEop2wO3Tvw+L8/2taZNAx8fSEqC++6DYxvBBgwZU/okKz2OyqnfLzfZra6uztik3X0Ien5+Pgfs3Kn18ccfk56ezg9+8AMiIyOZMmUKb775pvF8SUkJlZWVZGVlGY8FBwczffp0Nhw7QXHDhg2EhIQYzRkgKysLd3d3srOzz+TjnZVdu3ad8/d0VZKVnl27dqGU9Uji99+HNWtg7Vr4+mv45htYv956vu6330J2NuTkQG7uyc157Vrr82vXwp/+NPCaM8iYsodkpcfMnOzexF1QUEBWVhbBwcGUlpbywx/+kLCwMD788EPKysp4++23tV9r7969vP7669x///089thj5OTk8NOf/hRvb29uv/12KisrAYiKirL5uaioKOO5yspKIiMjbT+UpydhYWHGMidqa2ujra3N+L6hoUG7ZiHMUFUF+/bpLdtzH7G7u3UT9V13wYUX9m+NQgjHsrtB33///dxxxx08//zzBAYGGo9fffXVxj5oXRaLhfT0dH71q18B1lnKCgsLeeONN7j99tvtLU3bkiVLePLJJ096PDc3F39/f9LS0igqKuLo0aMEBgaSmJhIQUEBACNGjMBisVBeXg5Aamoqe/bsoampCX9/f0aOHGmsucfGxuLh4cG+Y79ZJ02aRGlpKQ0NDfj6+jJhwgTyjq3mxMTE4Ovry969ewFISUlh//791NXV4e3tTWpqqnHh8OjoaAICAtizZw9gnYquqqqKmpoaPD09mTp1Khs3bkQpRUREBKGhocZfgWPHjqWmpoZDhw7h7u5ORkYGubm5dHV1MXToUCIjIykqKgJg9OjRNDQ0UFVVBcD06dPJ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",
            "text/plain": [
              "<Figure size 500x300 with 1 Axes>"
            ]
          },
          "metadata": {},
          "output_type": "display_data"
        }
      ],
      "source": [
        "plt.figure(figsize=(5, 3))\n",
        "plt.plot(regrets2, label='Cumulative Regret', color='blue', linewidth=2)\n",
        "plt.xlabel('Iteration')\n",
        "plt.ylabel('Cumulative Regret')\n",
        "# plt.legend(loc='upper left', fontsize=12)\n",
        "plt.grid(True, which='both', linestyle='--', linewidth=0.5)\n",
        "\n",
        "# Adjust the ticks for better readability\n",
        "# plt.xticks(fontsize=12)\n",
        "# plt.yticks(fontsize=12)\n",
        "\n",
        "# Save the figure with high resolution\n",
        "plt.tight_layout()\n",
        "plt.savefig('cumulative_regret_plot_paper.png', dpi=300)\n",
        "\n",
        "# Display the plot\n",
        "plt.show()"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 507
        },
        "id": "z5MdyGpKSdHy",
        "outputId": "84ddff51-bf50-4cf6-9349-b9a1b3709d3d"
      },
      "outputs": [
        {
          "data": {
            "image/png": "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82aKi4vt600mU52f8+qrr+bzzz9nzZo1DBkyhKSkJDZs2GD/MyfAvn370DSNjh07Vvsczo5ffOWVV+jUqRPZ2dn897//ZdWqVQ5DAfbv34+macyZM4c5c+ZU+xypqam0adOGQ4cOMXjw4Cr3d+jQodrHxcfHV1m3b98+tm7dah8DW91rnY2Pjw9PPfUUd955J5GRkZxzzjlMmDCB6667jqioqLM+9mzi4uJ48803sVqtJCUl8fjjj5OWluYws4OzmRw6dAio+r54enrWOI3Vme9VeSNT05+2wTYOuKbGGGyfs8WLF3PDDTdw3333MWrUKCZOnMiVV17ZoCeSeXp6csUVV7Bs2TKKi4vx8fHh008/pbS01KGRvffee/npp58YOHAgHTp04MILL2TKlCkMHTrUqde58cYbueqqqygqKmLlypW8+OKLWCwWh22c/bwdOnSI1q1b24cIlKvps+3p6VlliMi+ffvIzs4mIiLirK91No8++iiXXnopnTp1onv37lx00UX84x//sA+rcUZ+fj4TJkwgNzeXP/74o8rYWSFqIo2saLaCg4OJjo52+szmmprAM/8nVFl1Z43XdCZ55SOddXmtcr///juXXHIJw4cPZ9GiRbRu3RovLy+WLl1a5xNSAC6++GL8/f358MMPGTJkCB9++CFms5mrrrrKvo3VasVkMvHdd99V+306+z+ngQMH2k8gu+yyyxg2bBhTpkxhz549BAYG2o/U3XXXXVWOnpar6X/mtaluhgKr1coFF1xQ41GiTp061fq8t912GxdffDGff/4533//PXPmzGHBggWsXLmSPn361KnWgIAAhzO7hw4dSt++fXnggQd48cUX7bW7I5PqnPlelefyzDPPOBwBd+X1/Pz8WLVqFb/88gvffPMNK1as4IMPPmDkyJH88MMPDToTw+TJk3n99df57rvvuOyyy/jwww9JTEykV69e9m26dOnCnj17+Prrr1mxYgWffPIJixYt4uGHH7ZPvXY2HTt2tGc2YcIEPDw8uO+++zj//PPtn3l3fN6q4+PjU+WXAavVSkREBO+99161j6mpma5s+PDhJCUl8cUXX/DDDz+wePFinnvuOV577TWHv0rVpKSkhIkTJ7J161a+//57unfv7tw3JATSyIpmbsKECbzxxhusWbOm2qN2lZUfRTpzAvfyI1nuVJ/X+uSTT/D19eX77793OIq5dOnSKtu6coQ2ICCACRMm8NFHH7Fw4UI++OADzj33XIf5OhMSEtA0jfj4+Dr/z/ZMHh4eLFiwgPPPP5+XX36Z++67zz6DgpeXV61T9MTGxrJ///4q66tbV5OEhATy8vJqfa3a3s+EhATuvPNO7rzzTvbt20fv3r35z3/+w7vvvut0LWfTs2dPrr32Wl5//XXuuusu2rVr53QmsbGxgO19Of/88+3ry8rKSE5OduroWvnJgsHBwfV6r8xmM6NGjWLUqFEsXLiQJ554ggcffJBffvmlQadkGj58OK1bt+aDDz5g2LBhrFy50n5iU2UBAQFcffXVXH311fYm7PHHH+f+++93eZ7jBx98kDfffJOHHnqIFStWAM5/3mJjY/nll18oKChwOCrr6mf7p59+YujQobVOM3e2zMpnfZgxYwZ5eXkMHz6cuXPn1trIWq1WrrvuOn7++Wc+/PBDRowY4XTtQoBMvyWauXvuuYeAgABuuOEGTp48WeX+pKQkXnjhBcD2P+dWrVpVGQ/ZEHM/ljcElV/LYrE4dWEGDw8PTCaTw9Hb5OTkaq/gFRAQ4NKVla6++mqOHz/O4sWL2bJli8OfXAEmTpyIh4cH8+bNczjCDLYjznUdPnHeeecxcOBAnn/+eYqKioiIiOC8887j9ddf58SJE1W2T0tLsy+PGTOGNWvWsHnzZvu6jIyMGo9AVWfSpEmsWbOG77//vsp9WVlZlJWVAdibiTPf04KCAoqKihzWJSQkEBQU5DD0o77Tb4HtM11aWsrChQsB5zPp378/LVu25M0337R/PwDvvffeWcf1VtavXz8SEhJ49tlnycvLq3J/5VzK5y89873KyMio8rjyo7uV36uGYDabufLKK/nqq6945513KCsrq/IZP/Mz7O3tTdeuXdE0jdLSUpdfMzQ0lJtuuonvv//e/hl19vM2ZswYSktLefPNN+33W61WXnnlFadff9KkSVgsFh577LEq95WVlTnkU9PPizPfk8DAQDp06OBUXrfccgsffPABixYtss/0IYQr5IisaNYSEhJYtmyZfZqsylf2Wr16NR999JHDiTc33HADTz75JDfccAP9+/dn1apV7N271+11devWjXPOOYf777+fjIwMwsLCeP/99x0ajJqMHz+ehQsXctFFFzFlyhRSU1N55ZVX6NChA1u3bnXYtl+/fvz0008sXLiQ6Oho4uPjGTRoUI3PXT7/5F133YWHhwdXXHGFw/0JCQnMnz+f+++/3z51U1BQEAcPHuSzzz7jxhtvdJiP0xV33303V111FW+99Rb//Oc/eeWVVxg2bBg9evRg5syZtG/fnpMnT7JmzRqOHj3Kli1bAFtj9+6773LBBRdwyy232KffateuHRkZGU4dlb777rv58ssvmTBhAtOnT6dfv37k5+ezbds2Pv74Y5KTk2nVqhV+fn507dqVDz74gE6dOhEWFkb37t0pKytj1KhRTJo0ia5du+Lp6clnn33GyZMn7dM6gXum3+ratSvjxo1j8eLFzJkzx+lMvL29mTt3LrfccgsjR45k0qRJJCcn89Zbb5GQkODU+2Q2m1m8eDFjx46lW7duzJgxgzZt2nDs2DF++eUXgoOD+eqrrwDbZw9sRyQnT56Ml5cXF198MY8++iirVq1i/PjxxMbGkpqayqJFi4iJiWHYsGFnff2tW7fa5xHev38/2dnZzJ8/H4BevXpx8cUX1/o9XH311bz00ks88sgj9OjRgy5dujjcf+GFFxIVFcXQoUOJjIxk165dvPzyy4wfP77OJ47++9//5vnnn+fJJ5/k/fffd/rzdtlllzFw4EDuvPNO9u/fT2JiIl9++aX9lwFnMhsxYgQ33XQTCxYsYPPmzVx44YV4eXmxb98+PvroI1544QX7iWj9+vXj1VdfZf78+XTo0IGIiAhGjhxJ165dOe+88+jXrx9hYWGsX7+ejz/+mNmzZ5/1tZ9//nkWLVrE4MGD8ff3r/KXicsvv1zXCzYIRegxVYIQRrN3715t5syZWlxcnObt7a0FBQVpQ4cO1V566SWH6Z0KCgq066+/XgsJCdGCgoK0SZMmaampqTVOv3XmFELTpk3TAgICqrz+iBEjqkzpk5SUpI0ePVrz8fHRIiMjtQceeED78ccfnZp+a8mSJVrHjh01Hx8fLTExUVu6dKm9psp2796tDR8+XPPz89MA+1RcNU3/pWmaNnXqVA3QRo8eXeP7+cknn2jDhg3TAgICtICAAC0xMVGbNWuWtmfPnhofU/l1161bV+U+i8WiJSQkaAkJCVpZWZn9Pbruuuu0qKgozcvLS2vTpo02YcIE7eOPP3Z47KZNm7Rzzz1X8/Hx0WJiYrQFCxZoL774ogZoKSkp9u1iY2NrnEYoNzdXu//++7UOHTpo3t7eWqtWrbQhQ4Zozz77rFZSUmLfbvXq1Vq/fv00b29v++fi1KlT2qxZs7TExEQtICBACwkJ0QYNGqR9+OGH1X7/zk6/VdM0UL/++muVz6Szmbz44otabGys5uPjow0cOFD7888/tX79+mkXXXSRfZvy6bcqTxlV2aZNm7SJEydqLVu21Hx8fLTY2Fht0qRJ2s8//+yw3WOPPaa1adNGM5vN9s/bzz//rF166aVadHS05u3trUVHR2vXXHNNlamoqlP+/lX3Vd00c9WxWq1a27ZtNUCbP39+lftff/11bfjw4fbvLSEhQbv77ru17Ozssz5v+fRbNU3BNn36dM3Dw0Pbv3+/pmnOf97S0tK0KVOmaEFBQVpISIg2ffp07c8//9QA7f3337dvV9PPnnJvvPGG1q9fP83Pz08LCgrSevTood1zzz3a8ePH7dukpKRo48eP14KCghymZJs/f742cOBALTQ0VPPz89MSExO1xx9/3KHO6pRPCVbTV3U/f4Q4k0nTzvhbkxBCNAO33XYbr7/+Onl5ebpejtforFYr4eHhTJw40eFP2MK4Pv/8cy6//HL++OMPp2dTEEJVMkZWCNHkFRYWOtxOT0/nnXfeYdiwYdLEVlJUVFRlHO3//vc/MjIyHC5RK4zjzM+2xWLhpZdeIjg4mL59++pUlRCNR8bICiGavMGDB3PeeefRpUsXTp48yZIlS8jJyalxDtrm6q+//uL222/nqquuomXLlmzcuJElS5bQvXt3h2nWhHHccsstFBYWMnjwYIqLi/n0009ZvXo1TzzxRK2zEAjRFEgjK4Ro8saNG8fHH3/MG2+8gclkom/fvixZsoThw4frXZqhxMXF0bZtW1588UX7SYbXXXcdTz75JN7e3nqXJ6oxcuRI/vOf//D1119TVFREhw4deOmll2o90UqIpkLGyAohhBBCCCXJGFkhhBBCCKEkaWSFEEIIIYSSZIwstulljh8/TlBQkEuX7BRCCCGEEO6laRq5ublER0djNp/9mKs0ssDx48dp27at3mUIIYQQQojTjhw5QkxMzFm3kUYW7JcVPHLkCMHBwY3ymjk5OY32WsK9JDu1SX5qk/zUJdmprTHzy8nJoW3btk5d9lkaWSquRx0cHNxoIe3atavW3zKEMUl2apP81Cb5qUuyU5se+Tkz3FNO9hJCCCGEEEqSRlYnHTt21LsEUUeSndokP7VJfuqS7NRm1PykkdVJTk6O3iWIOpLs1Cb5qU3yU5dkpzaj5ieNrE5OnjypdwmijiQ7tUl+apP81CXZqc2o+UkjK4QQQgghlGTSNE3Tuwi95eTkEBISQnZ2dq2zFlgsFkpLSxupMqEKLy8vPDw89C5DCCGEUJ4rfZlMv+UkTdNISUkhKyvLLc9XUlKCt7e3W55LNK6asgsNDSUqKkquDmdwGzdupG/fvnqXIepI8lOXZKc2o+YnjayTypvYiIgI/P39692s5OfnExAQ4KbqRGM6MztN0ygoKCA1NRWA1q1b61WacIL8RUVtkp+6JDu1GTU/aWSdYLFY7E1sy5Yt3fa8vr6+bnsu0bjOzM7Pzw+A1NRUIiIiZJiBgbVo0ULvEkQ9SH7qkuzUZtT85GQvJ5T/FuLv7++25/Ty8nLbc4nGVVN25Z8Po/7WKmyio6P1LkHUg+SnLslObUbNTxpZF7hz7GNhYaHbnks0rpqyk7GxatixY4feJYh6kPzUJdmpzaj5SSMrhBBCCCGUJI2sTnx8fPQuocmaPn06cXFxDfb8kp3aEhIS9C5B1IPkpy7JTm1GzU8aWZ1YrVa9SwDgrbfewmQyYTKZ+OOPP6rcr2kabdu2xWQyMWHChGqfIysrC19fX0wmE7t27ap2m+nTp9tfx2Qy4ePjQ6dOnXj44YcpKipy6/fU0IySnaibgoICvUsQ9SD5qUuyU5tR85NZC3RSWlpqqCN7vr6+LFu2jGHDhjms/+233zh69OhZa/3oo48wmUxERUXx3nvvMX/+/Gq38/HxYfHixQBkZ2fzxRdf8Nhjj5GUlMR7773nvm+mgRktO+GaEydO0K5dO73LEHUk+anLqeyyj8Lv/4H8tMYpSjgtMCMTzvsndLlY71IcSCMrABg3bhwfffQRL774Ip6eFR+LZcuW0a9fP06dOlXjY999913GjRtHbGwsy5Ytq7GR9fT05Nprr7Xf/te//sWQIUNYvnw5CxcuJDIy0n3fkBBCCPWsfBy2LNO7ClGNMID00XqXUYUMLdCJ0S6GcM0115Cens6PP/5oX1dSUsLHH3/MlClTanzc4cOH+f3335k8eTKTJ0/m4MGDrF692qnXNJlMDBs2DE3TOHDgQK3bf/HFF4wfP57o6Gh8fHxISEjgsccew2Kx1PrY9PR0/vGPfxAcHExoaCjTpk1jy5YtmEwm3nrrLYdtV65cybnnnktAQAChoaFceumlDkMmjJadcE3//v31LkHUg+SnLqeyO7Gl4QsRTYockdVJYWGhW+elra+4uDgGDx7M8uXLGTt2LADfffcd2dnZTJ48mRdffLHaxy1fvpyAgAAmTJiAn58fCQkJvPfeewwZMsSp101OTgacm2j5rbfeIjAwkDvuuIPAwEBWrlzJww8/TE5ODs8880yNj7NarVx88cX8/fff3HzzzSQmJvLFF18wbdq0Ktv+9NNPjB07lvbt2zN37lwKCwt56aWXGDp0KBs3biQuLs5w2QnXbN++nV69euldhqgjyU9dtWanaZCZbFtuEQczvmuMsoSTduzcSbc+g/QuowppZHVixBOGpkyZwv33309hYSF+fn689957jBgx4qyTIL/33ntceuml9itbXX311bzxxhu88MILDkMUypUPUcjOzubzzz/nk08+oXv37nTu3LnW+pYtW2Z/HYB//vOf/POf/2TRokXMnz+/xnGrn3/+OWvWrOH555/n3//+NwA333wzF1xwQZVt7777bsLCwlizZg1hYWEAXHbZZfTp04dHHnmEt99+25DZCeepdnKhcCT5qavW7PLToDTfttyyAwQbcwL+5irPdAR8gvQuowppZOvp4pf+IC232OXHaZrm9gn0w4N8+OqWYbVvWINJkyZx22238fXXX3PRRRfx9ddf13gkFmDr1q1s27aNBQsW2Nddc801PPHEE3z//feMHz/eYfv8/HzCw8Md1g0bNoy3337bqfeichObm5tLcXEx5557Lq+//jq7d++u8Tf9FStW4OXlxcyZM+3rzGYzs2bNYuXKlfZ1J06cYPPmzdxzzz32JhagZ8+eXHDBBXz77bcAcvlZxYWEhOhdgqgHyU9dtWaXcbBiuUVcg9YiXGfUfU8a2XpKyy0mJadpHCEIDw9n9OjRLFu2jIKCAiwWC1deeWWN27/77rsEBATQvn179u/fD9hmP4iLi+O9996r0sj6+vry1VdfAXD06FGefvppUlNTHRrUs9mxYwcPPfQQK1euJCcnx+G+7OzsGh936NAhWrduXWU4QIcOHapsB1R7dLhLly58//335Ofn4+vr61S9wpjkjHe1SX7qqjW7zMqNbHzDFiNcZtR9TxrZegoPqts0TJpmxWRy77l2da2lsilT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",
            "text/plain": [
              "<Figure size 700x500 with 1 Axes>"
            ]
          },
          "metadata": {},
          "output_type": "display_data"
        }
      ],
      "source": [
        "# Plot the regrets on the same figure\n",
        "plt.figure(figsize=(7, 5))\n",
        "\n",
        "# Plot regrets1\n",
        "plt.plot(regrets1, label='MAR algo', linewidth=2)\n",
        "\n",
        "# Plot regrets2\n",
        "plt.plot(regrets2, label='UCB algo', linewidth=2)\n",
        "\n",
        "# Plot settings\n",
        "plt.xlabel('Iteration')\n",
        "plt.ylabel('Cumulative Regret')\n",
        "plt.title('Cumulative Regrets: Regrets 1 vs Regrets 2')\n",
        "plt.legend(loc='upper left', fontsize=12)\n",
        "plt.grid(True, which='both', linestyle='--', linewidth=0.5)\n",
        "\n",
        "# Save and display the plot\n",
        "plt.tight_layout()\n",
        "plt.savefig('regrets1_vs_regrets2.png', dpi=300)\n",
        "plt.show()\n"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "oeQj5VhOxtGP"
      },
      "source": [
        "##UCB on MAR repeating"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 375
        },
        "id": "854EvBu4xsmO",
        "outputId": "c509651c-aea1-4729-9dcc-e4d09e03466f"
      },
      "outputs": [
        {
          "name": "stderr",
          "output_type": "stream",
          "text": [
            "<ipython-input-13-1b3319606638>:34: RuntimeWarning: divide by zero encountered in log\n",
            "  confidence_bound = np.sqrt(self.alpha / 2 * np.log(round_number) * np.sum((p[arm] ** 2) / self.counts[arm]))\n",
            "<ipython-input-13-1b3319606638>:34: RuntimeWarning: invalid value encountered in sqrt\n",
            "  confidence_bound = np.sqrt(self.alpha / 2 * np.log(round_number) * np.sum((p[arm] ** 2) / self.counts[arm]))\n"
          ]
        },
        {
          "data": {
            "image/png": "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",
            "text/plain": [
              "<Figure size 500x300 with 1 Axes>"
            ]
          },
          "metadata": {},
          "output_type": "display_data"
        }
      ],
      "source": [
        "# Seed for reproducibility\n",
        "np.random.seed(42)\n",
        "\n",
        "# Number of arms and contexts\n",
        "n = 10\n",
        "k = 5\n",
        "\n",
        "# Generate the means and gamma\n",
        "means = np.random.uniform(0, 0.5, size=(n, k))\n",
        "means[0] = means[0] + 0.2\n",
        "gamma = np.random.uniform(0.4, 0.6, size=(n, k))\n",
        "\n",
        "# Randomly generate a probability matrix for the categorical distribution\n",
        "p = np.random.dirichlet(np.ones(k), size=n)\n",
        "\n",
        "# Bandit environment setup\n",
        "bandit_env = MAR(means, gamma, p)\n",
        "\n",
        "# Algorithm parameters\n",
        "alpha = 1\n",
        "p_known = 1\n",
        "T = 50000  # Time horizon\n",
        "num_repeats = 1  # Number of repetitions to average over\n",
        "\n",
        "# Initialize arrays to store the cumulative regrets\n",
        "regrets1_avg = np.zeros(T)\n",
        "regrets2_avg = np.zeros(T)\n",
        "regrets1_all = np.zeros((num_repeats, T))\n",
        "regrets2_all = np.zeros((num_repeats, T))\n",
        "\n",
        "# Loop over the number of repeats\n",
        "for i in range(num_repeats):\n",
        "    # MAR Algorithm\n",
        "    algo1 = MAR_algo(bandit_env, alpha, p_known)\n",
        "    _, regrets1 = algo1.run(T)\n",
        "    regrets1_avg += regrets1\n",
        "    regrets1_all[i] = regrets1\n",
        "\n",
        "    # UCB Algorithm\n",
        "    np.random.seed(42 + i)  # Change the seed for each repeat\n",
        "    algo2 = UCB_algo(bandit_env, alpha)\n",
        "    _, regrets2 = algo2.run(T)\n",
        "    regrets2_avg += regrets2\n",
        "    regrets2_all[i] = regrets2\n",
        "\n",
        "# Average the regrets over the number of repetitions\n",
        "regrets1_avg /= num_repeats\n",
        "regrets2_avg /= num_repeats\n",
        "\n",
        "# Calculate standard deviation for error shading\n",
        "std_regrets1 = np.std(regrets1_all, axis=0)\n",
        "std_regrets2 = np.std(regrets2_all, axis=0)\n",
        "\n",
        "# Plot the averaged regrets with error shading\n",
        "plt.figure(figsize=(5, 3))\n",
        "\n",
        "# Plot MAR Algorithm cumulative regret\n",
        "plt.plot(regrets1_avg, label=r'MAR', color='blue', linewidth=2)\n",
        "plt.fill_between(np.arange(T), regrets1_avg - std_regrets1, regrets1_avg + std_regrets1, color='blue', alpha=0.2)\n",
        "\n",
        "# Plot UCB Algorithm cumulative regret\n",
        "plt.plot(regrets2_avg, label=r'UCB', color='red', linewidth=2)\n",
        "plt.fill_between(np.arange(T), regrets2_avg - std_regrets2, regrets2_avg + std_regrets2, color='red', alpha=0.2)\n",
        "\n",
        "# Labeling and formatting\n",
        "plt.xlabel('Time Steps')\n",
        "plt.ylabel('Cumulative Regret')\n",
        "\n",
        "# LaTeX formatted legend\n",
        "plt.legend(loc='upper left')\n",
        "\n",
        "# Grid and layout\n",
        "plt.grid(False)\n",
        "plt.tight_layout()\n",
        "\n",
        "# Save and display the plot\n",
        "plt.savefig('cumulative_regret_MAR_vs_UCB.png', dpi=300)\n",
        "plt.show()"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "DL3wfpByrqzn"
      },
      "outputs": [],
      "source": [
        "import numpy as np\n",
        "\n",
        "class MAR:\n",
        "    def __init__(self, means, gamma, prob):\n",
        "        self.means = means\n",
        "        self.gamma = gamma\n",
        "        self.p = prob\n",
        "        self.num_arms = means.shape[0]  # Number of arms (n)\n",
        "        self.num_contexts = means.shape[1]  # Number of contexts (k)\n",
        "        self.best_arm = np.argmax(np.sum(self.p * self.means , axis=1))\n",
        "\n",
        "    def pull_arm(self, arm):\n",
        "        if arm >= self.num_arms:\n",
        "            raise ValueError(\"Invalid arm index\")\n",
        "\n",
        "        # Select a context based on the probability distribution p[arm]\n",
        "        context = int(np.random.choice(self.num_contexts, p=self.p[arm]))\n",
        "\n",
        "        # Reward is drawn from a normal distribution centered at the means[arm, context]\n",
        "        reward = float(np.random.normal(self.means[arm, context], 1))\n",
        "\n",
        "        # Determine if the reward is observed based on the gamma[arm, context]\n",
        "        observed = np.random.rand() < self.gamma[arm, context]\n",
        "        if observed:\n",
        "            return reward, observed, context\n",
        "        else:\n",
        "            return None, observed, context"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "rc1XmEby-pdZ",
        "outputId": "66b86528-8799-4581-c062-277c8dccf458"
      },
      "outputs": [
        {
          "name": "stderr",
          "output_type": "stream",
          "text": [
            "<ipython-input-22-075c4455024e>:11: DeprecationWarning: Conversion of an array with ndim > 0 to a scalar is deprecated, and will error in future. Ensure you extract a single element from your array before performing this operation. (Deprecated NumPy 1.25.)\n",
            "  means[i, 0] = np.random.uniform(0.8, 1, size=(1))\n"
          ]
        }
      ],
      "source": [
        "# Seed for reproducibility\n",
        "np.random.seed(42)\n",
        "\n",
        "# Number of arms and contexts\n",
        "n = 10\n",
        "k = 5\n",
        "\n",
        "# Generate the means and gamma\n",
        "means = np.random.uniform(0, 0.5, size=(n, k))\n",
        "for i in range(n):\n",
        "  means[i, 0] = np.random.uniform(0.8, 1, size=(1))\n",
        "\n",
        "# Randomly generate a probability matrix for the categorical distribution\n",
        "p = np.full((n, k), 1 / k)\n",
        "\n",
        "peak_index = 0  # Randomly choose a peak index\n",
        "alpha_values = np.ones(k)\n",
        "alpha_values[peak_index] = 10  # Bias alpha to create a peak at the chosen index\n",
        "p[0, :] = np.random.dirichlet(alpha_values)\n",
        "\n",
        "gamma = np.random.uniform(0.5, 0.8, size=(n, k))\n",
        "for i in range(n):\n",
        "  for j in range(k):\n",
        "    gamma[i, j] = 1 / p[i, j]\n",
        "gamma = gamma / gamma.sum(axis=1, keepdims=True)\n",
        "\n",
        "\n",
        "# Bandit environment setup\n",
        "bandit_env = MAR(means, gamma, p)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 375
        },
        "id": "thyDah2OehOG",
        "outputId": "e149876c-c93a-40da-f273-bed2793a5f1e"
      },
      "outputs": [
        {
          "name": "stderr",
          "output_type": "stream",
          "text": [
            "<ipython-input-13-1b3319606638>:34: RuntimeWarning: divide by zero encountered in log\n",
            "  confidence_bound = np.sqrt(self.alpha / 2 * np.log(round_number) * np.sum((p[arm] ** 2) / self.counts[arm]))\n",
            "<ipython-input-13-1b3319606638>:34: RuntimeWarning: invalid value encountered in sqrt\n",
            "  confidence_bound = np.sqrt(self.alpha / 2 * np.log(round_number) * np.sum((p[arm] ** 2) / self.counts[arm]))\n"
          ]
        },
        {
          "data": {
            "image/png": "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",
            "text/plain": [
              "<Figure size 500x300 with 1 Axes>"
            ]
          },
          "metadata": {},
          "output_type": "display_data"
        }
      ],
      "source": [
        "np.random.seed(42)\n",
        "\n",
        "# Algorithm parameters\n",
        "alpha = 1\n",
        "p_known = 1\n",
        "T = 20000  # Time horizon\n",
        "num_repeats = 20  # Number of repetitions to average over\n",
        "\n",
        "# Initialize arrays to store the cumulative regrets\n",
        "regrets1_avg = np.zeros(T)\n",
        "regrets2_avg = np.zeros(T)\n",
        "regrets1_all = np.zeros((num_repeats, T))\n",
        "regrets2_all = np.zeros((num_repeats, T))\n",
        "\n",
        "# Loop over the number of repeats\n",
        "for i in range(num_repeats):\n",
        "    # MAR Algorithm\n",
        "    algo1 = MAR_algo(bandit_env, alpha, p_known)\n",
        "    _, regrets1 = algo1.run(T)\n",
        "    regrets1_avg += regrets1\n",
        "    regrets1_all[i] = regrets1\n",
        "\n",
        "    # UCB Algorithm\n",
        "    algo2 = UCB_algo(bandit_env, alpha)\n",
        "    _, regrets2 = algo2.run(T)\n",
        "    regrets2_avg += regrets2\n",
        "    regrets2_all[i] = regrets2\n",
        "\n",
        "# Average the regrets over the number of repetitions\n",
        "regrets1_avg /= num_repeats\n",
        "regrets2_avg /= num_repeats\n",
        "\n",
        "# Calculate standard deviation for error shading\n",
        "std_regrets1 = np.std(regrets1_all, axis=0)\n",
        "std_regrets2 = np.std(regrets2_all, axis=0)\n",
        "\n",
        "# Plot the averaged regrets with error shading\n",
        "plt.figure(figsize=(5, 3))\n",
        "\n",
        "# Plot MAR Algorithm cumulative regret\n",
        "plt.plot(regrets1_avg, label=r'MAR', color='blue', linewidth=2)\n",
        "plt.fill_between(np.arange(T), regrets1_avg - std_regrets1, regrets1_avg + std_regrets1, color='blue', alpha=0.2)\n",
        "\n",
        "# Plot UCB Algorithm cumulative regret\n",
        "plt.plot(regrets2_avg, label=r'UCB', color='red', linewidth=2)\n",
        "plt.fill_between(np.arange(T), regrets2_avg - std_regrets2, regrets2_avg + std_regrets2, color='red', alpha=0.2)\n",
        "\n",
        "# Labeling and formatting\n",
        "plt.xlabel('Time Steps')\n",
        "plt.ylabel('Cumulative Regret')\n",
        "\n",
        "# LaTeX formatted legend\n",
        "plt.legend(loc='upper left')\n",
        "\n",
        "# Grid and layout\n",
        "plt.grid(False)\n",
        "plt.tight_layout()\n",
        "\n",
        "# Save and display the plot\n",
        "plt.savefig('cumulative_regret_MAR_vs_UCB.png', dpi=300)\n",
        "plt.show()"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "mcq3AwdsNjnm"
      },
      "source": [
        "##different Ps"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 632
        },
        "id": "4fpx3R1cNnT6",
        "outputId": "89909677-1b40-4d02-95af-af3a4219f2a0"
      },
      "outputs": [
        {
          "name": "stderr",
          "output_type": "stream",
          "text": [
            "<ipython-input-13-1b3319606638>:34: RuntimeWarning: divide by zero encountered in log\n",
            "  confidence_bound = np.sqrt(self.alpha / 2 * np.log(round_number) * np.sum((p[arm] ** 2) / self.counts[arm]))\n",
            "<ipython-input-13-1b3319606638>:34: RuntimeWarning: invalid value encountered in sqrt\n",
            "  confidence_bound = np.sqrt(self.alpha / 2 * np.log(round_number) * np.sum((p[arm] ** 2) / self.counts[arm]))\n"
          ]
        },
        {
          "data": {
            "image/png": "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3VqwYMFpP79//PGHAgMDFRMTU6q+Vqg07/PiPProo3r66af12muvadSoUZKcr9eIESPUq1cvPfvss8rKytKsWbPUtWtXbdy40RXyly5dqoEDB6pNmzaaMmWKDh8+rBtvvPGMA/yJz0Gh5cuXa968eRo3bpxq1KihRo0aefzeGDdunGJiYjRp0iRt375ds2bN0p9//ukK45IzxERERGj8+PGKiIjQ8uXL9fjjjys9Pd3ts02Sjh49qj59+mjQoEEaMmSI5s2bpzFjxig4OPiM/ki/+OKLdeedd+qll17Sww8/rNatW0uSWrdurRtuuEFz587VV199pX79+rnuk5SUpOXLl2vixIml2seAAQN02223acGCBa5a33//fbVq1Urnn39+kfZ//PGHPvnkE1133XVq3LixkpOT9dprr6lbt27aunWr6tSpo9atW+uJJ57Q448/rltvvdX1pdeJ/6cePnxYV1xxha6//nr93//9n+Li4oqtr6CgQP369dOyZct0/fXX66677lJGRoYSExP1888/u/5/Gj16tObMmaMbb7xRd955p3bt2qWXX35ZGzdu1OrVq2W1WsvlfYoqzgBwk5aWZiSZq6++ulTtd+3aZSSZ2bNnF1knyUycONF1e+LEiUaSufXWW13L8vPzTb169YzFYjHPPPOMa/nRo0dNaGioGTFihGvZ7NmzjSSza9cut/2sWLHCSDIrVqxwLRsxYoRp2LChW7usrCy323l5eebss882l156qdvy8PBwt/2WtP+0tDRjs9nMvffe69buueeeMxaLxfz555/GGGN2795tAgMDzb/+9S+3dlu2bDFBQUFFlpe03//973/m4MGDZu/eveajjz4yNWvWNDabzezdu9fV9rLLLjNt27Y1OTk5rmUOh8N07tzZNG/e3LXsjjvuMBaLxWzcuNG17PDhwyY2NrbIc9ywYUMjySxZssStrieffNKEh4eb3377zW35Qw89ZAIDA82ePXuMMcYcPHiwSF84mcI+9fzzz7st79+/vwkODja///67a9n+/ftNZGSkufjii4s8X127djX5+fmn3F9h/5k/f36x68eOHWv++d+FJBMcHGx27tzpWvbTTz8ZSWbGjBlFajnx+RwxYoQJDw93296mTZuMJHPLLbe4Lb/vvvuMJLN8+XLXspJej8LHcfbZZ5u8vDzX8iFDhhiLxWKu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rgsvvFDTpk1TTk6OatWqpe7du+u1117TgQMHirQvnEJZknr16qW1a9dq06ZNrmVHjhwp8RvN4gwaNEhr167VV199VWRdamqq69ybsLAw17LTFRgYqJ49e+rTTz91O9wmOTlZ77//vrp27eo61MpTtWvXVrt27fSf//ynSI0bNmzQunXrdMUVV5x27aVR+AfsiYeEStLUqVMl6aSzzVWEwYMHKzc3V++8846WLFlS5Bv/o0ePFunbheffnWqK9dIobV/z5H1e6JxzztHixYu1bds2XXnlla6RyV69eikqKkpPP/10seeTFL6fCvvPO++843bIW2JiorZu3Xpaj9cTp/PeeP31190e06xZs5Sfn+/q54Wjlye+pnl5eSV+rufn57suiVDY9rXXXlPNmjXVvn37M3p8heGspM+PIUOGyGKx6K677tIff/zhdi0uT1xyySV68skn9fLLLxc7AlkoMDCwSF+fP3++6/zT0tZdWgMHDtShQ4f08ssvF1lXWMegQYNUUFCgJ598skib/Px8Vw3l/T5F1cOIFFCMpk2b6v3333dNUz58+HCdffbZysvL05o1azR//nzXdT4k5+QRzzzzjG655RZ16NBBq1atcn0bWZbOOussderUSRMmTNCRI0cUGxurDz744KQnyxfq27evpk6dqt69e2vo0KFKSUnRzJkz1axZM23evNmtbfv27fW///1PU6dOVZ06ddS4ceMi0wefqPD4+vvuu0+BgYEaOHCg2/qmTZvqqaee0oQJE7R79271799fkZGR2rVrlxYuXKhbb71V991332k9J/fff7+uu+46zZkzR7fddptmzpyprl27qm3btho1apSaNGmi5ORkrV27Vvv27XNd6+SBBx7Qf/7zH11++eW64447XNOfN2jQQEeOHCnVt6n333+/PvvsM/Xr108jR45U+/btdezYMW3ZskUfffSRdu/e7bpWSZs2bfThhx+qRYsWio2N1dlnn62zzz7bo8f61FNPKTExUV27dtXtt9+uoKAgvfbaa8rNzdVzzz13Ws9foalTp6pXr15q166dRo4cqTp16mjbtm16/fXXVbt2bU2YMOGMtn8q5557rkaMGKHXX3/ddVjV999/r3feeUf9+/d3Gz3whvPPP1/NmjXTI488otzc3CJfFrzzzjt65ZVXdM0116hp06bKyMjQG2+8oaioKFdIPBOl7WuevM9P1KlTJ3366afq06ePrr32Wn3yySeKiorSrFmzdMMNN+j888/X9ddfr5o1a2rPnj1atGiRunTp4vrjdsqUKerbt6+6du2qm266SUeOHNGMGTN01llnuU3SUV48fW/k5eXpsssu06BBg7R9+3a98sor6tq1q6666ipJzmm6q1WrphEjRujOO++UxWLRu+++W+JhoHXq1NGzzz6r3bt3q0WLFq5zjV5//fUzvphyu3btFBgYqGeffVZpaWmy2Wy69NJLXecD1axZU71799b8+fMVExNz2l86BAQE6NFHHz1lu379+umJJ57QjTfeqM6dO2vLli167733ilxTsGnTpoqJidGrr76qyMhIhYeHq2PHjh6fuzl8+HDNnTtX48eP1/fff6+LLrpIx44d0//+9z/dfvvtuvrqq9WtWzeNHj1aU6ZM0aZNm9SzZ09ZrVbt2LFD8+fP1/Tp03XttdeW+/sUVVBFTxMI+JPffvvNjBo1yjRq1MgEBwebyMhI06VLFzNjxgy36W+zsrLMzTffbKKjo01kZKQZNGiQSUlJKXH684MHD7rtp7jpoI1xTgN71llnuS37/fffTY8ePYzNZjNxcXHm4YcfNomJiaWa/vytt94yzZs3NzabzbRq1crMnj272Ol3f/31V3PxxReb0NBQI8k1FW9J068bY8ywYcOMJNOjR48Sn8+PP/7YdO3a1YSHh5vw8HDTqlUrM3bsWLN9+/YS73PifoubsragoMA0bdrUNG3a1DXV9++//26GDx9u4uPjjdVqNXXr1jX9+vUzH330kdt9N27caC666CJjs9lMvXr1zJQpU8xLL71kJJmkpCRXu4YNG5q+ffsWW1tGRoaZMGGCadasmQkODjY1atQwnTt3Ni+88ILb9Mpr1qwx7du3N8HBwaecCr2k6c+NMebHH380vXr1MhERESYsLMxccsklZs2aNaV+vk5m3bp1pl+/fqZatWomKCjI1K1b19xyyy1m3759RdrqhKmzT/TPqZtLO/25McbY7XYzefJk07hxY2O1Wk39+vXNhAkT3N5rhfso7vUoaRr3kp6Pkt6PJXnkkUeMJNOsWbMi63788UczZMgQ06BBA2Oz2UytWrVMv379zA8//HDK7Rb3Pi9Oaftaad/nxb2Gn376qQkKCjKDBw92TXG9YsUK06tXLxMdHW1CQkJM06ZN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jgbAOwhSAABUQQeOz9Z25bl1FBVy8nBkMQEKCpCCgwJkDeJgFgCQOLQPAIAq6UCqM0jViQ71ciUA4J8IUgAAVEGFI1Lx0VwrDgBOB0EKAIAqqPAcqToxBCkAOB0EKZy27t276+677y7TbY4cOVL9+/f3uW2daM6cOYqJiXHdnjRpktq1a1fm+yluXwBQVlwjUlEc2gcAp4MgVUmNHDlSFotFFotFwcHBatasmZ544gnl5/vIlRRP08qVK12PKyAgQNHR0TrvvPP0wAMP6MCBA25tp0+frjlz5pRqu56ErsGDB+u3337zsPJTa9SokaZNm1Yh+wJQteXYC3TkWJ4kRqQA4HQxa18l1rt3b82ePVu5ublavHixxo4dK6vVqgkTJni7tDO2fft2RUVFKT09XT/++KOee+45vfXWW1q5cqXatm0rSYqOji7z/drtdoWGhio0tGK+wa3IfQGoOpKOj0aFWAMUHeo705kDgD9hRMpTxkh5x8r3nz2r+OXGeFSqzWZTfHy8GjZsqDFjxqhHjx767LPPJEm5ubm67777VLduXYWHh6tjx45auXKl676HDx/WkCFDVLduXYWFhalt27b673//e9L9LVq0SNHR0XrvvfckSXv37tWgQYMUExOj2NhYXX311dq9e7erfUFBgcaPH6+YmBhVr15dDzzwgEwpH2OtWrUUHx+vFi1a6Prrr9fq1atVs2ZNjRkzxtXmn6NMH330kdq2bavQ0FBVr15dPXr00LFjxzRp0iS98847+vTTT12jXStXrtTu3btlsVj04Ycfqlu3bgoJCdF7771X4uF2r732murXr6+wsDANGjRIaWlprnXFHQbZv39/jRw50rX+zz//1D333OOqQSr+0L5Zs2apadOmCg4OVsuWLfXuu++6rbdYLHrzzTd1zTXXKCwsTM2bN3e97gAg/X1YX53oUNfnDQDAM4xIecqeJT1dp9w2HyAppqSVD++XgsNPe9uhoaE6fPiwJGncuHHaunWrPvjgA9WpU0cLFy5U7969tWXLFjVv3lw5OTlq3769HnzwQUVFRWnRokW64YYb1LRpU1144YVFtv3+++/rtttu0/vvv69+/frJbrerV69eSkhI0DfffKOgoCA99dRT6t27tzZv3qzg4GC9+OKLmjNnjt5++221bt1aL774ohYuXKhLL730tB7bbbfdpnvuuUcp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GW6ioqJ8oiPBf9Bn4Cn6DDxFn4Gn6DPwhC/1l5ONRBVisgkAAAAA8BBBCgAAAAA8RJDyMTabTRMnTpTNZvN2KfAT9Bl4ij4DT9Fn4Cn6DDzhr/2FySYAAAAAwEOMSAEAAACAhwhSAAAAAOAhghQAAAAAeIggBQAAAAAeIkj5kJkzZ6pRo0YKCQlRx44d9f3333u7JJSDVatW6corr1SdOnVksVj0ySefuK03xujxxx9X7dq1FRoaqh49emjHjh1ubY4cOaJhw4YpKipKMTExuvnmm5WZmenWZvPmzbrooosUEhKi+vXr67nnnitSy/z589WqVSuFhISobdu2Wrx4cZk/Xpy5KVOm6IILLlBkZKRq1aql/v37a/v27W5tcnJyNHbsWFWvXl0REREaOHCgkpOT3drs2bNHffv2VVhYmGrVqqX7779f+fn5bm1Wrlyp888/XzabTc2aNdOcOXOK1MNnle+bNWuWzjnnHNfFLRMSEvTll1+61tNfcDLPPPOMLBaL7r77btcy+gz+adKkSbJYLG7/WrVq5VpfJfqMgU/44IMPTHBwsHn77bfNL7/8YkaNGmViYmJMcnKyt0tDGVu8eLF55JFHzIIFC4wks3DhQrf1zzzzjImOjjaffPKJ+emnn8xVV11lGjdubLKzs11tevfubc4991yzbt06880335hmzZqZIUOGuNanpaWZuLg4M2zYMPPzzz+b//73vyY0NNS89tprrjarV682gYGB5rnnnjNbt241jz76qLFarWbLli3l/hzAM7169TKzZ882P//8s9m0aZPp06ePadCggcnMzHS1ue2220z9+vXNsmXLzA8//GA6depkOnfu7Fqfn59vzj77bNOjRw+zceNGs3jxYlOjRg0zYcIEV5s//vjDhIWFmfHjx5utW7eaGTNmmMDAQLNkyRJXGz6r/MNnn31mFi1aZH777Tezfft28/DDDxur1Wp+/vlnYwz9BSX7/vvvTaNGjcw555xj7rrrLtdy+gz+aeLEieass84yBw4ccP07ePCga31V6DMEKR9x4YUXmrFjx7puFxQUmDp16pgpU6Z4sSqUt38GKYfDYeLj483zzz/vWpaammpsNpv573//a4wxZuvWrUaSWb9+vavNl19+aSwWi/nrr7+MMca88sorplq1aiY3N9fV5sEHHzQtW7Z03R40aJDp27evWz0d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",
            "text/plain": [
              "<Figure size 1000x600 with 1 Axes>"
            ]
          },
          "metadata": {},
          "output_type": "display_data"
        }
      ],
      "source": [
        "# Set up common parameters\n",
        "np.random.seed(5)\n",
        "\n",
        "n = 10  # Number of arms\n",
        "k = 5   # Number of contexts\n",
        "\n",
        "# Generate means and gamma values\n",
        "means = np.random.uniform(0, 0.5, size=(n, k))  # Means between 0 and 1\n",
        "means[0] = means[0] + 0.2\n",
        "gamma = np.random.uniform(0.2, 1.0, size=(n, k))  # Observation probabilities\n",
        "\n",
        "alpha = 1\n",
        "p_known = 1\n",
        "T = 50000  # Time steps\n",
        "\n",
        "# Initialize list for probability matrices\n",
        "p_list = []\n",
        "\n",
        "# First p: Uniform distribution for each row\n",
        "p_uniform = np.full((n, k), 1 / k)\n",
        "p_list.append(p_uniform)\n",
        "\n",
        "# Second p: Peaked distributions using Dirichlet\n",
        "p_peaked = np.zeros((n, k))\n",
        "for i in range(n):\n",
        "    peak_index = np.random.randint(0, k)  # Randomly choose a peak index\n",
        "    alpha_values = np.ones(k)\n",
        "    alpha_values[peak_index] = 5  # Bias alpha to create a peak at the chosen index\n",
        "    p_peaked[i, :] = np.random.dirichlet(alpha_values)\n",
        "p_list.append(p_peaked)\n",
        "\n",
        "# Prepare plot\n",
        "plt.figure(figsize=(10, 6))\n",
        "\n",
        "# Labels for the probability matrices\n",
        "p_labels = [\"Uniform Distribution\", \"Peaked Distribution\"]\n",
        "\n",
        "# Run the algorithm for each p and plot results\n",
        "for idx, p in enumerate(p_list):\n",
        "    # Initialize the bandit environment and algorithm\n",
        "    bandit_env = MAR(means, gamma, p)\n",
        "    algo = MAR_algo(bandit_env, alpha, p_known)\n",
        "\n",
        "    # Run the algorithm\n",
        "    np.random.seed(42)  # Ensure same randomness for fair comparison\n",
        "    results, regrets = algo.run(T)\n",
        "\n",
        "    # Plot the cumulative regret for each probability matrix\n",
        "    plt.plot(regrets, label=p_labels[idx])\n",
        "\n",
        "# Finalize the plot\n",
        "plt.title('Cumulative Regret for Uniform vs Peaked Probability Matrices')\n",
        "plt.xlabel('Time Steps')\n",
        "plt.ylabel('Cumulative Regret')\n",
        "plt.legend()\n",
        "plt.grid(True)\n",
        "plt.show()"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "bqh4nqE4CLaf"
      },
      "source": [
        "##different Ps repeated"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 375
        },
        "id": "5wwFRB6hQPS5",
        "outputId": "326a1a6b-4ba2-48ad-b2cc-272cd64fee22"
      },
      "outputs": [
        {
          "name": "stderr",
          "output_type": "stream",
          "text": [
            "<ipython-input-13-1b3319606638>:34: RuntimeWarning: divide by zero encountered in log\n",
            "  confidence_bound = np.sqrt(self.alpha / 2 * np.log(round_number) * np.sum((p[arm] ** 2) / self.counts[arm]))\n",
            "<ipython-input-13-1b3319606638>:34: RuntimeWarning: invalid value encountered in sqrt\n",
            "  confidence_bound = np.sqrt(self.alpha / 2 * np.log(round_number) * np.sum((p[arm] ** 2) / self.counts[arm]))\n"
          ]
        },
        {
          "data": {
            "image/png": "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",
            "text/plain": [
              "<Figure size 500x300 with 1 Axes>"
            ]
          },
          "metadata": {},
          "output_type": "display_data"
        }
      ],
      "source": [
        "np.random.seed(42)\n",
        "# Set up common parameters\n",
        "n = 10  # Number of arms\n",
        "k = 5   # Number of contexts\n",
        "T = 10000  # Time steps\n",
        "num_repeats = 10  # Number of runs to average over\n",
        "\n",
        "# Generate means and gamma values\n",
        "np.random.seed(2)  # Set seed for reproducibility\n",
        "means = np.random.uniform(0, 0.8, size=(n, k))  # Means between 0 and 1\n",
        "means[0] = means[0] + 0.2\n",
        "gamma = np.random.uniform(0.2, 1.0, size=(n, k))  # Observation probabilities\n",
        "\n",
        "alpha = 1\n",
        "p_known = 1\n",
        "\n",
        "# Initialize list for probability matrices\n",
        "p_list = []\n",
        "\n",
        "# First p: Uniform distribution for each row\n",
        "p_uniform = np.full((n, k), 1 / k)\n",
        "p_list.append(p_uniform)\n",
        "\n",
        "# Second p: Peaked distributions using Dirichlet\n",
        "p_peaked = np.zeros((n, k))\n",
        "for i in range(n):\n",
        "    peak_index = np.random.randint(0, k)  # Randomly choose a peak index\n",
        "    alpha_values = np.ones(k)\n",
        "    alpha_values[peak_index] = 5  # Bias alpha to create a peak at the chosen index\n",
        "    p_peaked[i, :] = np.random.dirichlet(alpha_values)\n",
        "p_list.append(p_peaked)\n",
        "\n",
        "# Labels for the probability matrices\n",
        "p_labels = [\"Uniform Distribution\", \"Peaked Distribution\"]\n",
        "\n",
        "# Prepare storage for average regrets and standard deviations\n",
        "avg_regrets_list = []\n",
        "std_regrets_list = []\n",
        "\n",
        "# Run multiple times for both uniform and peaked probability matrices\n",
        "for idx, p in enumerate(p_list):\n",
        "    # Store the cumulative regrets over multiple runs\n",
        "    cumulative_regrets_runs = np.zeros((num_repeats, T))\n",
        "\n",
        "    for run in range(num_repeats):\n",
        "        # Initialize the bandit environment and algorithm\n",
        "        bandit_env = MAR(means, gamma, p)\n",
        "        algo = MAR_algo(bandit_env, alpha, p_known)\n",
        "\n",
        "        # Run the algorithm\n",
        "        results, regrets = algo.run(T)\n",
        "\n",
        "        # Store the cumulative regret for this run\n",
        "        cumulative_regrets_runs[run, :] = regrets\n",
        "\n",
        "    # Calculate the average and standard deviation of cumulative regret over all runs\n",
        "    avg_cumulative_regrets = np.mean(cumulative_regrets_runs, axis=0)\n",
        "    std_cumulative_regrets = np.std(cumulative_regrets_runs, axis=0)\n",
        "\n",
        "    avg_regrets_list.append(avg_cumulative_regrets)\n",
        "    std_regrets_list.append(std_cumulative_regrets)\n",
        "\n",
        "# Plot the average cumulative regrets with error shading for both cases\n",
        "plt.figure(figsize=(5, 3))\n",
        "\n",
        "for idx, avg_cumulative_regrets in enumerate(avg_regrets_list):\n",
        "    # Plot the mean cumulative regret\n",
        "    plt.plot(avg_cumulative_regrets, label=f'{p_labels[idx]}', linewidth=2)\n",
        "\n",
        "    # Add shaded area for error indication (1 standard deviation)\n",
        "    plt.fill_between(np.arange(T),\n",
        "                     avg_cumulative_regrets - std_regrets_list[idx],\n",
        "                     avg_cumulative_regrets + std_regrets_list[idx],\n",
        "                     alpha=0.2)\n",
        "\n",
        "# Finalize the plot\n",
        "# plt.title('Average Cumulative Regret for Uniform vs Peaked Probability Matrices')\n",
        "plt.xlabel('Time Steps')\n",
        "plt.ylabel('Cumulative Regret')\n",
        "plt.legend(loc='upper left')\n",
        "plt.grid(False)\n",
        "\n",
        "# Adjust layout and save the figure with high resolution\n",
        "plt.tight_layout()\n",
        "plt.savefig('average_cumulative_regret_uniform_vs_peaked.png', dpi=300)\n",
        "\n",
        "# Display the plot\n",
        "plt.show()"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "VPVjqKAsRn8O"
      },
      "source": [
        "repeating"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "background_save": true,
          "base_uri": "https://localhost:8080/"
        },
        "id": "IJPDSa-sI2V0",
        "outputId": "cf035af2-4668-40c8-d65a-3a45c6e515bb"
      },
      "outputs": [
        {
          "name": "stderr",
          "output_type": "stream",
          "text": [
            "<ipython-input-13-1b3319606638>:34: RuntimeWarning: divide by zero encountered in log\n",
            "  confidence_bound = np.sqrt(self.alpha / 2 * np.log(round_number) * np.sum((p[arm] ** 2) / self.counts[arm]))\n",
            "<ipython-input-13-1b3319606638>:34: RuntimeWarning: invalid value encountered in sqrt\n",
            "  confidence_bound = np.sqrt(self.alpha / 2 * np.log(round_number) * np.sum((p[arm] ** 2) / self.counts[arm]))\n"
          ]
        },
        {
          "data": {
            "image/png": "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",
            "text/plain": [
              "<Figure size 500x300 with 1 Axes>"
            ]
          },
          "metadata": {},
          "output_type": "display_data"
        }
      ],
      "source": [
        "T = 100000\n",
        "n = 10  # Number of arms\n",
        "k = 10   # Number of contexts\n",
        "alpha = 1\n",
        "p_known = 1\n",
        "repeat = 10\n",
        "\n",
        "cu_regret = np.zeros((repeat,T))\n",
        "for r in range(repeat):\n",
        "\n",
        "  means = np.random.uniform(0, 1, size=(n, k))  # Means between 0 and 5\n",
        "  gamma = np.random.uniform(0.5, 1.0, size=(n, k))  # Observation probabilities between 0.5 and 1\n",
        "  p = np.random.dirichlet(np.ones(k), size=n)  # Each row is a probability distribution over contexts\n",
        "\n",
        "  bandit_env = MAR(means, gamma, p)\n",
        "\n",
        "  algo = MAR_algo(bandit_env, alpha, p_known)\n",
        "  results, regrets = algo.run(T)\n",
        "\n",
        "  cu_regret[r] = regrets\n",
        "\n",
        "plt.figure(figsize=(5, 3))\n",
        "plt.plot(np.mean(cu_regret, axis=0), label='Cumulative Regret', color='blue', linewidth=2)\n",
        "plt.xlabel('Iteration')\n",
        "plt.ylabel('Cumulative Regret')\n",
        "# plt.legend(loc='upper left', fontsize=12)\n",
        "plt.grid(True, which='both', linestyle='--', linewidth=0.5)\n",
        "\n",
        "# Adjust the ticks for better readability\n",
        "# plt.xticks(fontsize=12)\n",
        "# plt.yticks(fontsize=12)\n",
        "\n",
        "# Save the figure with high resolution\n",
        "plt.tight_layout()\n",
        "plt.savefig('cumulative_regret_plot_paper.png', dpi=300)\n",
        "\n",
        "# Display the plot\n",
        "plt.show()"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "-seVW6X6HYHV"
      },
      "outputs": [],
      "source": [
        "# Parameters\n",
        "T = 100000  # Time horizon\n",
        "n = 10  # Number of arms\n",
        "k = 20  # Number of contexts\n",
        "alpha = 1\n",
        "p_known = 1\n",
        "repeat = 20  # Number of repetitions\n",
        "\n",
        "# Initialize cumulative regret storage\n",
        "cu_regret = np.zeros((repeat, T))\n",
        "\n",
        "# Set a seed for reproducibility\n",
        "np.random.seed(2)\n",
        "\n",
        "# Generate random means and gamma values\n",
        "means = np.random.uniform(0, 0.5, size=(n, k))  # Means between 0 and 1\n",
        "means += 0.2*np.eye(n, k)\n",
        "gamma = np.random.uniform(0.5, 1.0, size=(n, k))  # Observation probabilities between 0.5 and 1\n",
        "p = np.random.dirichlet(np.ones(k), size=n)  # Each row is a probability distribution over contexts\n",
        "\n",
        "# Initialize the MAR bandit environment\n",
        "bandit_env = MAR(means, gamma, p)\n",
        "\n",
        "# Run the algorithm for each repetition\n",
        "for r in range(repeat):\n",
        "    # Set a unique seed for each run to ensure variability between runs\n",
        "    np.random.seed(42 + r)\n",
        "\n",
        "    # Initialize the MAR algorithm and run it\n",
        "    algo = MAR_algo(bandit_env, alpha, p_known)\n",
        "    results, regrets = algo.run(T)\n",
        "\n",
        "    # Store the cumulative regrets for this run\n",
        "    cu_regret[r] = regrets\n",
        "\n",
        "# Calculate mean and standard deviation of cumulative regrets\n",
        "mean_regret = np.mean(cu_regret, axis=0)\n",
        "std_regret = np.std(cu_regret, axis=0)\n",
        "\n",
        "# Plot the average cumulative regret with error shading\n",
        "plt.figure(figsize=(5, 3))\n",
        "\n",
        "# Plot the mean cumulative regret\n",
        "plt.plot(mean_regret, label='Cumulative Regret', color='blue', linewidth=2)\n",
        "\n",
        "# Add shaded area for error indication (±1 standard deviation)\n",
        "plt.fill_between(np.arange(T),\n",
        "                 mean_regret - std_regret,\n",
        "                 mean_regret + std_regret,\n",
        "                 color='blue', alpha=0.2, label='±1 Std Dev')\n",
        "\n",
        "# Add labels and grid\n",
        "plt.xlabel('Time Steps')\n",
        "plt.ylabel('Cumulative Regret')\n",
        "# plt.grid(True, which='both', linestyle='--', linewidth=0.5)\n",
        "plt.grid(False)\n",
        "\n",
        "# Adjust the ticks for better readability\n",
        "# plt.xticks(fontsize=12)\n",
        "# plt.yticks(fontsize=12)\n",
        "\n",
        "# Adjust the layout for better spacing\n",
        "plt.tight_layout()\n",
        "\n",
        "# Save the figure with high resolution\n",
        "plt.savefig('cumulative_regret_plot_paper.png', dpi=300)\n",
        "\n",
        "# Display the plot\n",
        "plt.show()"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "9t9ECQqTMPE9"
      },
      "source": [
        "## MAR With unknown p"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "background_save": true
        },
        "id": "B_oqidl053yP"
      },
      "outputs": [],
      "source": [
        "np.random.seed(42)\n",
        "\n",
        "# Number of arms and contexts\n",
        "n = 10\n",
        "k = 5\n",
        "\n",
        "# Generate the means and gamma\n",
        "means = np.random.uniform(0, 0.4, size=(n, k))\n",
        "means[0] = means[0] + 0.6\n",
        "\n",
        "# Randomly generate a probability matrix for the categorical distribution\n",
        "p = np.random.dirichlet(np.ones(k), size=n)\n",
        "\n",
        "gamma = np.random.uniform(0.8, 1.0, size=(n, k))  # Observation probabilities\n",
        "\n",
        "# Bandit environment setup\n",
        "bandit_env = MAR(means, gamma, p)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "Iw3hQXUqNoJf"
      },
      "outputs": [],
      "source": [
        "np.random.seed(42)\n",
        "\n",
        "# Parameters\n",
        "T = 100000  # Time horizon\n",
        "n = 10  # Number of arms\n",
        "k = 5  # Number of contexts\n",
        "alpha = 1\n",
        "p_known = 0\n",
        "repeat = 10  # Number of repetitions\n",
        "\n",
        "# Initialize cumulative regret storage\n",
        "cu_regret1 = np.zeros((repeat, T))\n",
        "\n",
        "# Run the algorithm for each repetition\n",
        "for r in range(repeat):\n",
        "    # Initialize and run the MAR algorithm\n",
        "    algo = MAR_algo(bandit_env, alpha, p_known)\n",
        "    results, regrets = algo.run(T)\n",
        "\n",
        "    # Store the cumulative regrets for this run\n",
        "    cu_regret1[r] = regrets\n",
        "\n",
        "cu_regret2 = np.zeros((repeat, T))\n",
        "for r in range(repeat):\n",
        "    # Initialize and run the MAR algorithm\n",
        "    algo = MAR_algo(bandit_env, alpha, 1)\n",
        "    results, regrets = algo.run(T)\n",
        "\n",
        "    # Store the cumulative regrets for this run\n",
        "    cu_regret2[r] = regrets\n",
        "\n",
        "# Calculate mean and standard deviation of cumulative regrets\n",
        "mean_regret1 = np.mean(cu_regret1, axis=0)\n",
        "std_regret1 = np.std(cu_regret1, axis=0)\n",
        "\n",
        "mean_regret2 = np.mean(cu_regret2, axis=0)\n",
        "std_regret2 = np.std(cu_regret2, axis=0)\n",
        "\n",
        "\n",
        "\n",
        "# Plot the average cumulative regret with error shading\n",
        "plt.figure(figsize=(5, 3))\n",
        "\n",
        "# Plot the mean cumulative regret\n",
        "plt.plot(mean_regret1, label='unknown p', color='red', linewidth=2)\n",
        "\n",
        "plt.plot(mean_regret2, label='known p', color='blue', linewidth=2)\n",
        "\n",
        "\n",
        "# Add shaded area for error indication (±1 standard deviation)\n",
        "plt.fill_between(np.arange(T),\n",
        "                 mean_regret1 - std_regret1,\n",
        "                 mean_regret1 + std_regret1,\n",
        "                 color='red', alpha=0.2, label='±1 Std Dev')\n",
        "\n",
        "plt.fill_between(np.arange(T),\n",
        "                 mean_regret2 - std_regret2,\n",
        "                 mean_regret2 + std_regret2,\n",
        "                 color='blue', alpha=0.2, label='±1 Std Dev')\n",
        "\n",
        "# Add labels and grid\n",
        "plt.xlabel('Time Steps')\n",
        "plt.ylabel('Cumulative Regret')\n",
        "plt.grid(False)\n",
        "\n",
        "# Adjust the ticks for better readability\n",
        "# plt.xticks(fontsize=12)\n",
        "# plt.yticks(fontsize=12)\n",
        "\n",
        "# Adjust the layout for better spacing\n",
        "plt.tight_layout()\n",
        "\n",
        "# Save the figure with high resolution\n",
        "plt.savefig('cumulative_regret_plot_paper.png', dpi=300)\n",
        "\n",
        "# Display the plot\n",
        "plt.show()"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "T3NzHVVQ7LcH"
      },
      "outputs": [],
      "source": [
        "plt.figure(figsize=(5, 3))\n",
        "\n",
        "T = 100000\n",
        "\n",
        "# Plot the mean cumulative regret\n",
        "plt.plot(mean_regret1, label='unknown p')\n",
        "\n",
        "# Add shaded area for error indication (±1 standard deviation)\n",
        "plt.fill_between(np.arange(T),\n",
        "                 mean_regret1 - std_regret1,\n",
        "                 mean_regret1 + std_regret1, alpha=0.2)\n",
        "\n",
        "plt.plot(mean_regret2, label='known p')\n",
        "\n",
        "plt.fill_between(np.arange(T),\n",
        "                 mean_regret2 - std_regret2,\n",
        "                 mean_regret2 + std_regret2, alpha=0.2)\n",
        "\n",
        "# Add labels and grid\n",
        "plt.xlabel('Time Steps')\n",
        "plt.ylabel('Cumulative Regret')\n",
        "plt.grid(False)\n",
        "plt.legend(loc='upper left')\n",
        "\n",
        "# Adjust the ticks for better readability\n",
        "# plt.xticks(fontsize=12)\n",
        "# plt.yticks(fontsize=12)\n",
        "\n",
        "# Adjust the layout for better spacing\n",
        "plt.tight_layout()\n",
        "\n",
        "# Save the figure with high resolution\n",
        "plt.savefig('cumulative_regret_plot_paper.png', dpi=300)\n",
        "\n",
        "# Display the plot\n",
        "plt.show()"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "cSq7UUrq-RGJ"
      },
      "source": [
        "# MNAR"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "gzfZ391B-TOb"
      },
      "outputs": [],
      "source": [
        "import numpy as np\n",
        "import matplotlib.pyplot as plt\n",
        "\n",
        "class MNAR:\n",
        "    def __init__(self, means, gamma, prob, rewards):\n",
        "        self.means = means\n",
        "        self.gamma = gamma\n",
        "        self.p = prob\n",
        "        self.num_arms = means.shape[0]  # Number of arms (n)\n",
        "        self.num_contexts = means.shape[1]  # Number of contexts (k)\n",
        "        self.num_reward = means.shape[1]\n",
        "        self.rewards = rewards\n",
        "        self.mu = np.zeros((self.num_arms))\n",
        "        self.best_arm = -1\n",
        "        self.best_mu = -1\n",
        "\n",
        "        for a in range(self.num_arms):\n",
        "          mu = 0\n",
        "          for m in range(self.num_contexts):\n",
        "            for y in range(self.num_reward):\n",
        "              mu += self.p[a, m] * self.means[a, m, y] * self.rewards[y]\n",
        "\n",
        "          self.mu[a] = mu\n",
        "          if mu > self.best_mu:\n",
        "            self.best_mu = mu\n",
        "            self.best_arm = a\n",
        "\n",
        "        self.A_matrix = np.zeros((self.num_arms, self.num_contexts, self.num_reward))\n",
        "        for a in range(self.num_arms):\n",
        "          for m in range(self.num_contexts):\n",
        "            for y in range(self.num_reward):\n",
        "              self.A_matrix[a, m, y] = prob[a, m] * means[a, m, y] * gamma[a, y]\n",
        "        self.k_A = [np.linalg.cond(self.A_matrix[a]) for a in range(self.num_arms)]\n",
        "\n",
        "    def pull_arm(self, arm):\n",
        "        if arm >= self.num_arms:\n",
        "            raise ValueError(\"Invalid arm index\")\n",
        "\n",
        "        # Select a context based on the probability distribution p[arm]\n",
        "        context = int(np.random.choice(self.num_contexts, p=self.p[arm]))\n",
        "\n",
        "        # Reward is drawn from a normal distribution centered at the means[arm, context]\n",
        "        reward_i = np.random.choice([i for i in range(self.num_reward)], p=list(self.means[arm, context]))\n",
        "        reward = self.rewards[reward_i]\n",
        "\n",
        "        # Determine if the reward is observed based on the gamma[arm, context]\n",
        "        observed = np.random.rand() < self.gamma[arm, reward_i]\n",
        "        if observed:\n",
        "            return reward_i, reward, observed, context\n",
        "        else:\n",
        "            return None, None, observed, context"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "mPMlR8cEOpUJ"
      },
      "outputs": [],
      "source": [
        "class MNAR_algo:\n",
        "    def __init__(self, bandit_env):\n",
        "\n",
        "        self.bandit_env = bandit_env\n",
        "        self.num_arms = bandit_env.num_arms\n",
        "        self.num_contexts = bandit_env.num_contexts\n",
        "        self.num_rewards = bandit_env.num_reward\n",
        "        self.k_A = bandit_env.k_A\n",
        "        self.rewards_value = bandit_env.rewards\n",
        "\n",
        "        self.m0_matrix = np.zeros((bandit_env.num_arms, bandit_env.num_contexts))\n",
        "        self.my1_matrix = np.zeros((bandit_env.num_arms, bandit_env.num_contexts, bandit_env.num_reward))\n",
        "        self.my_given_1_matrix = np.zeros((bandit_env.num_arms, bandit_env.num_contexts, bandit_env.num_reward))\n",
        "\n",
        "        self.T_a = np.zeros(bandit_env.num_arms)\n",
        "        self.n_a = np.zeros(bandit_env.num_arms)\n",
        "\n",
        "\n",
        "    def select_arm(self, round_number):\n",
        "        ucb_values = np.zeros(self.num_arms)\n",
        "        means = np.zeros(self.num_arms)\n",
        "        for arm in range(self.num_arms):\n",
        "          m0_vector = self.m0_matrix[arm]/self.T_a[arm] # K * 1\n",
        "          my1_matrix = self.my1_matrix[arm]/self.T_a[arm] # K * L\n",
        "          my_given_1_matrix = self.my_given_1_matrix[arm]/self.n_a[arm] # K * L\n",
        "          #################\n",
        "          if np.linalg.det(my1_matrix) == 0:\n",
        "            ucb_values[arm] = float('inf')\n",
        "            means[arm] = float('inf')\n",
        "          else:\n",
        "            inverse_mymatrix = np.linalg.inv(my1_matrix)\n",
        "            OR_vector = inverse_mymatrix @ m0_vector\n",
        "            Ov_gamma_vector = OR_vector + 1 # L * 1\n",
        "            my_a_matrx = np.zeros((bandit_env.num_contexts, bandit_env.num_reward))\n",
        "            for i in range(bandit_env.num_contexts):\n",
        "              for j in range(bandit_env.num_reward):\n",
        "                my_a_matrx[i, j] = my_given_1_matrix[i, j] * Ov_gamma_vector[j]\n",
        "\n",
        "            y_a_vector = np.zeros((bandit_env.num_reward))\n",
        "            for j in range(bandit_env.num_reward):\n",
        "              for i in range(bandit_env.num_contexts):\n",
        "                y_a_vector[j] += my_a_matrx[i, j]\n",
        "\n",
        "            mean = sum(y_a_vector * self.rewards_value)\n",
        "\n",
        "            cb1 = (self.k_A[arm] / np.linalg.norm(my1_matrix, ord=np.inf)) * np.sqrt(np.log(round_number) / (2 * self.T_a[arm]))\n",
        "            cb2 = self.num_contexts * np.sqrt(np.log(round_number) / (2 * self.n_a[arm]))\n",
        "\n",
        "            cb = cb1 + cb2\n",
        "            means[arm] = mean\n",
        "            ucb_values[arm] = mean + 100 * cb\n",
        "\n",
        "        arm = np.argmax(ucb_values)\n",
        "\n",
        "        return arm, means[arm], ucb_values[arm]\n",
        "\n",
        "    def update(self, arm, context, reward_i, reward, observed):\n",
        "        int_obs = 1 if observed else 0\n",
        "        self.T_a[arm] += 1\n",
        "        self.n_a[arm] += int_obs\n",
        "        if observed:\n",
        "          self.m0_matrix[arm, context] += 1\n",
        "          self.my1_matrix[arm, context, reward_i] += 1\n",
        "          self.my_given_1_matrix[arm, context, reward_i] += 1\n",
        "\n",
        "    def update_regret(self, arm, context, cu_regret, regrets):\n",
        "        regret = self.bandit_env.mu[self.bandit_env.best_arm] - self.bandit_env.mu[arm]\n",
        "\n",
        "        cu_regret += regret  # Add this round's regret to the cumulative regret\n",
        "        regrets.append(cu_regret)  # Store the cumulative regret\n",
        "        return cu_regret\n",
        "\n",
        "    def run(self, num_rounds):\n",
        "\n",
        "        results = []\n",
        "        regrets = []\n",
        "        cu_regret = 0\n",
        "\n",
        "        for arm in range(self.num_arms):\n",
        "          for _ in range(100):\n",
        "            reward_i, reward, observed, context = self.bandit_env.pull_arm(arm)\n",
        "            cu_regret = self.update_regret(arm, context, cu_regret, regrets)\n",
        "            self.update(arm, context, reward_i, reward, observed)\n",
        "\n",
        "        for round_number in range(num_rounds - (100 * self.num_arms)):\n",
        "            # Select an arm using the UCB strategy\n",
        "            arm, mean, ucb = self.select_arm(round_number)\n",
        "\n",
        "            # Pull the arm and observe the reward and context\n",
        "            reward_i, reward, observed, context = self.bandit_env.pull_arm(arm)\n",
        "\n",
        "            # Update the cumulative regret and store the result\n",
        "            cu_regret = self.update_regret(arm, context, cu_regret, regrets)\n",
        "\n",
        "            # Update the means and counts based on the observed reward\n",
        "            self.update(arm, context, reward_i, reward, observed)\n",
        "\n",
        "            # Store the results for this round\n",
        "            results.append((arm, mean, ucb, reward, observed, context))\n",
        "\n",
        "        return results, regrets"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "r1jW0B5pUWd-"
      },
      "source": [
        "-------\n"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "tk2i1HiEYUWt",
        "outputId": "ed37685d-55ea-45b3-92eb-32460daa3d13"
      },
      "outputs": [
        {
          "data": {
            "text/plain": [
              "110.42303536666729"
            ]
          },
          "execution_count": 149,
          "metadata": {},
          "output_type": "execute_result"
        }
      ],
      "source": [
        "np.random.seed(97)\n",
        "\n",
        "# Number of arms and contexts\n",
        "n = 5\n",
        "k = 5\n",
        "Y = 5\n",
        "\n",
        "# Generate the means and gamma\n",
        "means = np.zeros((n, k, Y))\n",
        "for i in range(n):\n",
        "  for j in range(k):\n",
        "    means[i, j] = np.random.dirichlet(np.ones(k), size=1)\n",
        "\n",
        "for j in range(k):\n",
        "    peak_index = 1 # Randomly choose a peak index\n",
        "    alpha_values = np.ones(k)\n",
        "    alpha_values[peak_index] = 20  # Bias alpha to create a peak at the chosen index\n",
        "    means[2, j] = np.random.dirichlet(alpha_values)\n",
        "\n",
        "# Randomly generate a probability matrix for the categorical distribution\n",
        "p = np.random.dirichlet(np.ones(k), size=n)\n",
        "\n",
        "gamma = np.random.uniform(0.5, 1.0, size=(n, Y))  # Observation probabilities\n",
        "\n",
        "rewards = [0.3, 1, 0.4, 0.3, 0.2]\n",
        "rewards = [x * 1000 for x in rewards]\n",
        "# rewards = [0.1, 0.9]\n",
        "\n",
        "# Bandit environment setup\n",
        "bandit_env = MNAR(means, gamma, p, rewards)\n",
        "max(bandit_env.k_A)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "2BqUSqBzwphP",
        "outputId": "2b8b6c82-59f5-4fa5-cb92-d8c9a0e7de25"
      },
      "outputs": [
        {
          "data": {
            "text/plain": [
              "array([449.34661852, 507.88350511, 849.32306591, 420.86295397,\n",
              "       469.1845302 ])"
            ]
          },
          "execution_count": 150,
          "metadata": {},
          "output_type": "execute_result"
        }
      ],
      "source": [
        "bandit_env.mu"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "j3iuFMwyYWZi",
        "outputId": "f4029e1c-8476-4507-e966-ad4a1a211170"
      },
      "outputs": [
        {
          "name": "stderr",
          "output_type": "stream",
          "text": [
            "<ipython-input-135-41e01be198c2>:46: RuntimeWarning: divide by zero encountered in log\n",
            "  cb1 = (self.k_A[arm] / np.linalg.norm(my1_matrix, ord=np.inf)) * np.sqrt(np.log(round_number) / (2 * self.T_a[arm]))\n",
            "<ipython-input-135-41e01be198c2>:46: RuntimeWarning: invalid value encountered in sqrt\n",
            "  cb1 = (self.k_A[arm] / np.linalg.norm(my1_matrix, ord=np.inf)) * np.sqrt(np.log(round_number) / (2 * self.T_a[arm]))\n",
            "<ipython-input-135-41e01be198c2>:47: RuntimeWarning: divide by zero encountered in log\n",
            "  cb2 = self.num_contexts * np.sqrt(np.log(round_number) / (2 * self.n_a[arm]))\n",
            "<ipython-input-135-41e01be198c2>:47: RuntimeWarning: invalid value encountered in sqrt\n",
            "  cb2 = self.num_contexts * np.sqrt(np.log(round_number) / (2 * self.n_a[arm]))\n"
          ]
        }
      ],
      "source": [
        "np.random.seed(42)\n",
        "\n",
        "# Parameters\n",
        "T = 100000  # Time horizon\n",
        "repeat = 10  # Number of repetitions\n",
        "\n",
        "# Initialize cumulative regret storage\n",
        "cu_regret1 = np.zeros((repeat, T))\n",
        "all_results = []\n",
        "algo = MNAR_algo(bandit_env)\n",
        "# Run the algorithm for each repetition\n",
        "for r in range(repeat):\n",
        "    # Initialize and run the MAR algorithm\n",
        "    algo = MNAR_algo(bandit_env)\n",
        "    results, regrets = algo.run(T)\n",
        "    all_results.append(results)\n",
        "\n",
        "    # Store the cumulative regrets for this run\n",
        "    cu_regret1[r] = regrets"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 307
        },
        "id": "KNZn6Bz5_zp0",
        "outputId": "ee88dea0-8e5f-45c6-de93-96d0c363a402"
      },
      "outputs": [
        {
          "data": {
            "image/png": "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",
            "text/plain": [
              "<Figure size 500x300 with 1 Axes>"
            ]
          },
          "metadata": {},
          "output_type": "display_data"
        }
      ],
      "source": [
        "# cu_regret = cu_regret1/1000\n",
        "cu_regret1 = cu_regret\n",
        "# Calculate mean and standard deviation of cumulative regrets\n",
        "mean_regret1 = np.mean(cu_regret1, axis=0)\n",
        "std_regret1 = np.std(cu_regret1, axis=0)\n",
        "\n",
        "# Plot the average cumulative regret with error shading\n",
        "plt.figure(figsize=(5, 3))\n",
        "\n",
        "# Plot the mean cumulative regret\n",
        "plt.plot(mean_regret1, linewidth=2)\n",
        "\n",
        "# Add shaded area for error indication (±1 standard deviation)\n",
        "plt.fill_between(np.arange(T),\n",
        "                 mean_regret1 + std_regret1\n",
        "                 ,mean_regret1 - std_regret1\n",
        "                 , alpha=0.2)\n",
        "\n",
        "# Add labels and grid\n",
        "plt.xlabel('Time Steps')\n",
        "plt.ylabel('Cumulative Regret')\n",
        "plt.grid(False)\n",
        "\n",
        "# Adjust the ticks for better readability\n",
        "# plt.xticks(fontsize=12)\n",
        "# plt.yticks(fontsize=12)\n",
        "\n",
        "# Adjust the layout for better spacing\n",
        "plt.tight_layout()\n",
        "\n",
        "# Save the figure with high resolution\n",
        "plt.savefig('cumulative_regret_plot_paper.png', dpi=300)\n",
        "\n",
        "# Display the plot\n",
        "plt.show()"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "3OkZZkErLxYg"
      },
      "outputs": [],
      "source": [
        "class UCB_algo:\n",
        "    def __init__(self, bandit_env, alpha):\n",
        "        self.bandit_env = bandit_env\n",
        "        self.num_arms = bandit_env.num_arms\n",
        "        self.counts = np.zeros(self.num_arms)\n",
        "        self.means = np.zeros(self.num_arms)\n",
        "        self.total_pulls = 0\n",
        "        self.alpha = alpha\n",
        "\n",
        "    def select_arm(self, round_number):\n",
        "        if self.total_pulls < self.num_arms:\n",
        "            return self.total_pulls\n",
        "\n",
        "        ucb_values = np.zeros(self.num_arms)\n",
        "        for arm in range(self.num_arms):\n",
        "            if self.counts[arm] == 0:\n",
        "                ucb_values[arm] = float('inf')\n",
        "            else:\n",
        "                confidence_bound = np.sqrt(self.alpha / 2 * np.log(self.total_pulls) / self.counts[arm])\n",
        "                ucb_values[arm] = self.means[arm] + confidence_bound\n",
        "\n",
        "        return np.argmax(ucb_values)\n",
        "\n",
        "    def update(self, arm, reward, observed):\n",
        "        if observed:\n",
        "            self.counts[arm] += 1\n",
        "            self.means[arm] += (reward - self.means[arm]) / self.counts[arm]\n",
        "\n",
        "        self.total_pulls += 1\n",
        "\n",
        "    def update_regret(self, arm, cu_regret, regrets):\n",
        "        regret = self.bandit_env.mu[self.bandit_env.best_arm] - self.bandit_env.mu[arm]\n",
        "\n",
        "        cu_regret += regret  # Add this round's regret to the cumulative regret\n",
        "        regrets.append(cu_regret)  # Store the cumulative regret\n",
        "        return cu_regret\n",
        "\n",
        "    def run(self, num_rounds):\n",
        "        results = []\n",
        "        regrets = []\n",
        "        cu_regret = 0\n",
        "        for round_number in range(num_rounds):\n",
        "            arm = self.select_arm(round_number)\n",
        "\n",
        "            reward_i, reward, observed, context = self.bandit_env.pull_arm(arm)\n",
        "\n",
        "            cu_regret = self.update_regret(arm, cu_regret, regrets)\n",
        "            self.update(arm, reward, observed)\n",
        "\n",
        "            results.append((arm, reward, observed))\n",
        "\n",
        "        return results, regrets"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "-7yOowgnLLdg"
      },
      "outputs": [],
      "source": [
        "np.random.seed(42)\n",
        "\n",
        "# Parameters\n",
        "T = 100000  # Time horizon\n",
        "repeat = 10  # Number of repetitions\n",
        "\n",
        "# Initialize cumulative regret storage\n",
        "cu_regret2 = np.zeros((repeat, T))\n",
        "all_results = []\n",
        "algo = UCB_algo(bandit_env, 1)\n",
        "# Run the algorithm for each repetition\n",
        "for r in range(repeat):\n",
        "    # Initialize and run the MAR algorithm\n",
        "    algo = UCB_algo(bandit_env, 1)\n",
        "    results, regrets = algo.run(T)\n",
        "    all_results.append(results)\n",
        "\n",
        "    # Store the cumulative regrets for this run\n",
        "    cu_regret2[r] = regrets"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "CB61jmnNPphE",
        "outputId": "2798b036-efd5-4c1d-91fa-11778a0d9796"
      },
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "[ 0.39997645  0.74141601  0.74141601 ... 73.7609631  73.7609631\n",
            " 73.7609631 ]\n",
            "[ 0.39997645  0.74141601  0.74141601 ... 65.79977964 65.79977964\n",
            " 65.79977964]\n"
          ]
        }
      ],
      "source": [
        "print(cu_regret2[0])\n",
        "print(cu_regret2[1])"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 307
        },
        "id": "6ZPISRI2MWf5",
        "outputId": "3482ac67-1859-4297-9e98-9b6e81bedd0b"
      },
      "outputs": [
        {
          "data": {
            "image/png": "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",
            "text/plain": [
              "<Figure size 500x300 with 1 Axes>"
            ]
          },
          "metadata": {},
          "output_type": "display_data"
        }
      ],
      "source": [
        "# cu_regret2 /= 1000\n",
        "\n",
        "# Calculate mean and standard deviation of cumulative regrets\n",
        "mean_regret1 = np.mean(cu_regret1, axis=0)\n",
        "std_regret1 = np.std(cu_regret1, axis=0)\n",
        "\n",
        "mean_regret2 = np.mean(cu_regret2, axis=0)\n",
        "std_regret2 = np.std(cu_regret2, axis=0)\n",
        "\n",
        "\n",
        "# Plot the average cumulative regret with error shading\n",
        "plt.figure(figsize=(5, 3))\n",
        "\n",
        "# Plot the mean cumulative regret\n",
        "plt.plot(mean_regret1, linewidth=2, label=\"MNAR\")\n",
        "\n",
        "# Add shaded area for error indication (±1 standard deviation)\n",
        "plt.fill_between(np.arange(T),\n",
        "                 mean_regret1 - std_regret1,\n",
        "                 mean_regret1 + std_regret1\n",
        "                 , alpha=0.2)\n",
        "\n",
        "# Plot the mean cumulative regret\n",
        "# plt.plot(mean_regret2, linewidth=2, label=\"UCB\")\n",
        "\n",
        "# Add shaded area for error indication (±2mean_regret2 standard deviation)\n",
        "# plt.fill_between(np.arange(T),\n",
        "#                  mean_regret2 - std_regret2,\n",
        "#                  mean_regret2 + std_regret2\n",
        "#                  , alpha=0.2)\n",
        "\n",
        "\n",
        "# Add labels and grid\n",
        "plt.xlabel('Time Steps')\n",
        "plt.ylabel('Cumulative Regret')\n",
        "plt.grid(False)\n",
        "plt.legend(loc='upper left')\n",
        "\n",
        "# Adjust the ticks for better readability\n",
        "# plt.xticks(fontsize=12)\n",
        "# plt.yticks(fontsize=12)\n",
        "\n",
        "# Adjust the layout for better spacing\n",
        "plt.tight_layout()\n",
        "\n",
        "# Save the figure with high resolution\n",
        "plt.savefig('cumulative_regret_plot_paper.png', dpi=300)\n",
        "\n",
        "# Display the plot\n",
        "plt.show()"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 307
        },
        "id": "gQcYYLpWNG7A",
        "outputId": "e17e6557-a40c-4fdd-9f2e-c1b3da9613bb"
      },
      "outputs": [
        {
          "data": {
            "image/png": "iVBORw0KGgoAAAANSUhEUgAAAeoAAAEiCAYAAAA21pHjAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAABOqElEQVR4nO3deVxU5eI/8M+ZGWYGZBPZpEApccs1dzPN5Apq5VLmQoXaV1vA8odmmVuWpZZtFjdvVlpdy/KbervdLukXU8wQFcUll9RISlk01mEZZnl+fwxzYASUgQEG+bxfr3nNnHOeOeeZc29+eJ7zPOdIQggBIiIickqK5q4AERER1Y5BTURE5MQY1ERERE6MQU1EROTEGNREREROjEFNRETkxBjUREREToxBTURE5MRUzV2Bm5HZbMbly5fh4eEBSZKauzpERNSEhBAoKipCUFAQFIqGt4cZ1I3g8uXLCA4Obu5qEBFRM/rjjz9w6623Nng/DGoHio+PR3x8PIxGIwDL/0ienp7NXCsiImpKhYWFCA4OhoeHh0P2J/Fe345XWFgILy8vFBQUMKiJiFoZR2cAB5M5UHx8PLp3744BAwY0d1WIiOgmwRZ1I2CLmoio9WKL2omxRU1ERI7GFnUjqOtfUyaTCQaDoQlr1rqo1WqHTI0gIrKHo1vUHPXdDIQQyMrKQn5+fnNX5aamUCgQGhoKtVrd3FUhIqo3BrUDWadnmUym65azhrS/vz/c3Nx4U5RGYL3pTGZmJkJCQniOiajFYtd3I7het4fJZMKvv/4Kf39/tGvXrplq2DoUFBTg8uXL6NSpE1xcXJq7OkTUSrDru4WzXpN2c3Nr5prc/Kxd3iaTiUFNdLMTAhDmWl6ils8VL1RZp1QDnkHN/WtsMKibCbtiGx/PMZGTMNcWoPa86hC2juDSxjH7cSAGtQPV9Ro1EZFTqRp8ZtM1IWiqHozVylQNzxq2UYMwqB0oJiYGMTEx8vUJIiKHqxqS8mdTZVhWW1e1nKh5vaNao9QoOMmU6mzGjBmQJAlPPvlktW0xMTGQJAkzZsywKbt69Wqbcjt27Ki1S7pr167QaDTIysqqtu2ee+6BJEmQJAlarRadO3fGqlWrwLGQ5PTMJsBkAAxlQHkxoC8CSvOBklyg+CpQlA0UZgIFfwL5GUBuOvDXBeDqOeDKWSD7FJB1Esg8Blw+CmQdB7JPAjmngKtngb/OAbm/AXm/A/kXgcI/gaLLgC4bKL4ClPwFlOUD+kKgvAgwlADGMsBUbglthrTTY4ua7BIcHIwtW7bg7bffhqurKwCgrKwMX3zxBUJCQmzKarVarFmzBk888QTatm173f3+9NNPKC0txUMPPYRPP/0Uzz//fLUys2fPxssvvwy9Xo/du3djzpw58Pb2xlNPPeW4H0gEVGmZmq55r9oSNdm2Xs1VWrHW7ez2JQdgi5rscueddyI4OBjbtm2T123btg0hISHo27evTdnw8HAEBgZi1apVN9zvxx9/jOnTp+PRRx/FJ598UmMZNzc3BAYGokOHDpg5cyZ69eqFXbt2NewH0c3HbLZtwZYVAqV5QPFfgC6nsvWad9HSEr16vkrL9QRwOQ3ITAOyT1RptZ4H8tItLdaCPypbrCVXgdJcoKzAtrVqNjCkyWHYonag1jKYbNasWdi4cSOioqIAAJ988glmzpyJPXv22JRTKpV47bXXMH36dDzzzDO1PkC9qKgIW7duRUpKCrp27YqCggLs27cPd999d43lhRD46aefcObMGYSFhTn0t5ETsLZmzcbKVqvZeE1L1ljZmr12Hbty6SbDoHag+g4mu/+9n3ClSN+INauZn4cG/547zO7vPfLII1i0aBEuXrwIANi/fz+2bNlSLagBYOLEiejTpw+WL1+Ojz/+uMb9bdmyBWFhYbjjjjsAAFOnTsXHH39cLaj//ve/46OPPkJ5eTkMBgO0Wi2eeeYZu+tPTcRcJTyvDd1q66qELVui1JyE2dITo3IFnORZAQxqJ3ClSI+swrLmrkad+fn5Ydy4cdi0aROEEBg3bhx8fX1rLb9mzRrce++9WLBgQY3bP/nkEzzyyCPy8iOPPIIRI0bgvffeg4eHh7w+KioKixcvRl5eHpYvX46hQ4di6NChjvthVDMhKsK16qtq6BqrtHiNbNlS4zAbAaPecmmhzu+1bDOVV1lXDpj0FZ/1lssWAPDMUcDntub9zRUY1E7Az0PT4o47a9YsxMbGArB0+V/P8OHDERERgUWLFsmjwq1OnTqFAwcO4ODBgzYDyEwmE7Zs2YLZs2fL67y8vNCpUycAwNdff41OnTph8ODBCA8Pr/fvaJWqBqzJUD1wq7Z4ra1eotoIURF89QzNG76XVgSosWl/l8F5Gk9OE9RJSUl44403kJqaiszMTGzfvh0TJkyQtwshsHz5cmzYsAH5+fm466678MEHH9hco8zNzcXcuXPx73//GwqFAg8++CDeffdduLu7y2WOHz+OmJgYHDp0CH5+fpg7dy4WLlxoU5etW7di6dKl+P333xEWFoY1a9Zg7Nixjfbb69P93NwiIyNRXl4OSZIQERFxw/KrV69Gnz590KVLF5v1H3/8MYYPH14t7Ddu3IiPP/7YJqircnd3x7PPPosFCxbg6NGjrfsuZNYWr8lgG7bXLlvXsaXbOgmzJXyMpYCh1BKE8nJZxbq6brumTIu8XCEBKo3lpdRUfnZxBVzbWm4l6iScJqiLi4vRu3dvzJo1C5MmTaq2/fXXX8e6devw6aefIjQ0FEuXLkVERAROnToFrVYLwNI1mpmZiV27dsFgMGDmzJmYM2cOvvjiCwCWG6WPHj0a4eHhWL9+PU6cOIFZs2bB29sbc+bMAQD8/PPPmDZtGlatWoX77rsPX3zxBSZMmIAjR46gR48eTXdCnJxSqcTp06flzzfSs2dPREVFYd26dfI6g8GAzz//HC+//HK1c/s///M/eOutt/DLL7/I166v9cQTT+CVV17BN998g4ceeqgBv8ZJWeffmg2VoSsvW8PX0PQtDWp8ZiNQXmIZRW4osQSjocRy7dRQWiU4y2oIzyrbqpYxNf04mHqTg1PbsHcXV9vlqoGscAFq+gPfpQ3g17npf/N1OE1QjxkzBmPGjKlxmxAC77zzDpYsWYLx48cDAD777DMEBARgx44dmDp1Kk6fPo2EhAQcOnQI/fv3BwC89957GDt2LNauXYugoCBs3rwZ5eXl+OSTT6BWq3HHHXcgLS0Nb731lhzU7777LiIjI/Hcc88BAF555RXs2rUL77//PtavX98EZ6LlsPepMC+//DK++uorefnbb7/FX3/9hYkTJ1Yr261bN3Tr1g0ff/wx3nrrrRr35+Pjg8ceewwvvfQSJk2aBIWTDPy4IbPZ0lVoDeDawrhFtlJaKWtr1XBNuFYN25qCV15favtdk6G5f1HtFC4VAagFXLSVn1Wu9Q9VlyqflWpAaiH/LTcRpwnq60lPT0dWVpbNtUgvLy8MGjQIycnJmDp1KpKTk+Ht7S2HNGCZx6tQKJCSkoKJEyciOTkZw4cPl5+qBAARERFYs2YN8vLy0LZtWyQnJyMuLs7m+BEREdixY0et9dPr9dDrK/9aLSwsdMCvdj6bNm267vaq56imsh07drQ5Tw8++OB1p7KdOnVK/lzTiHIAzvfHk7UVbCqvfJcDuWIdr/k6DyEsrc7yYktglusqPltfVZYNxbbbbMK1tLl/SXUqbUUIula+u1QEatV11cq4VpSpZbuiRcTGTaVFnHHrLSUDAgJs1gcEBMjbsrKy4O/vb7NdpVLBx8fHpkxoaGi1fVi3tW3bFllZWdc9Tk1WrVqFFStW1OOXUYsjB255xWjRcttQZgg3HSEqWq266wesvFxSEbbXbHOGngulC+DiVuXlCqivWbZ+VrtVhq0cvDWEKlulN40WEdTObtGiRTat8MLCQgQHBzdjjajezKaK6Rt6S/hap3JYX87wj/rNRAhLeOqLAH1F4OqLqrx0ljt+1bisa74/jCSFbXi6uAFq1+phaw3WmsK26rKSz0un2rWIoA4MDAQAZGdno3379vL67Oxs9OnTRy6Tk5Nj8z2j0Yjc3Fz5+4GBgcjOzrYpY12+URnr9ppoNBpoNJpWc2eyFs9ktJ03aaoyl5IDs+rHbKoIzwLLLTvLKt711ldFsOqLbIO2XNf0f/woXAB1myov92uWa9jm4mZbTqWteSASUSNoEUEdGhqKwMBAJCYmysFcWFiIlJQU+YEMQ4YMQX5+PlJTU9GvXz8AwO7du2E2mzFo0CC5zOLFi2EwGODiYvkLdteuXejSpYv80IghQ4YgMTER8+bNk4+/a9cuDBkypIl+LTmEEJUPqy++ApSaK+dmsnv6+kzllSFbVmAbuvLna9brdWiaaV+SJSg1HhUv94oAda9b4KrbONW0G6K6cJqg1ul0OH/+vLycnp6OtLQ0+Pj4ICQkBPPmzcPKlSsRFhYmT88KCgqS51p369YNkZGRmD17NtavXw+DwYDY2FhMnToVQUFBAIDp06djxYoVePzxx/H888/j5MmTePfdd/H222/Lx3322WcxYsQIvPnmmxg3bhy2bNmCw4cP48MPP7zhb+DzqJuB/LB6AaDqA+xF5U0Siq8Aqlbc+jEZLI85LM23PJyiNB8oy6t5WV/Y+AOjJIUlOK0haw1ddUXwyiHsYbtd42Fp2SpuPB2Q6GbiNEF9+PBhjBw5Ul62XvONjo7Gpk2bsHDhQhQXF2POnDnIz8/HsGHDkJCQIM+hBoDNmzcjNjYWo0aNkm94UnXerpeXF3bu3ImYmBj069cPvr6+WLZsmTw1CwCGDh2KL774AkuWLMGLL76IsLAw7Nixo05zqNn13cisjxiUw9ga0K2M9bpuyV+WZxqXFVQGbk1BXK5rvLqo3QGtJ6D1AjReVT572n7WVAlhFzcOdCKygyREa/yXrnFZW9QFBQXV5hqXlZUhPT0doaGhNn9kUBXWFrFNMNt/HbOsTI/0jAyEepqgbQktamG2dCWX/FXllVvzsqNvXiEpqoer1qt66Go9KwLZyxK8nKpDNxsH3PDkehlQH/yvzIHYoq4nYa68nlzPUHZ6xjJAd8XSDV+cU/lZDt+rltavIwezubQBXL0tt0N09Qa0bW2XXdsC2op3jQe7lImcFIPagXiNug5sWsoVzxNu6X06Rr0ldHU5tu/F1uUrlmu/jqDxANzaAW4+gKv1vW0N4evNQVNENwkGtQPd7C3qe+65B3369ME777xjs37Tpk2YN28e8vPzAVi6fdasWYNvvvkGv//+O7y9vdHjju54+ok5mDj+fkiShHv+Fom9Sfvkffj7+2H4sGFYu/o1dOgQ0oS/qg6MekCXBRRmVbxnAkWZls9FWZZrxA0iWYLVzacihH2rfG5XJZh9LLdZJKJWhUHtQGxRA/l5eRh2990oKCjAypeWY0D/vlApVdi77ycsXLQY994zHN7e3gCA2bNm4uXlSyCEwMWMPzBvwUI8MvNx7Nu9q2krLcyWVnDBn5bgLcq0fS/Nrf++FSqgjS/Qxg9o4295d694b+MHtGlnaQXzWi8R1YL/OlDDWa8pG/V48YXn8fvvv+PXk8cQFFR5c5rOncMwbcpkmwF0bm6u8o1k2rdvj9innsATMc80Uh2F5TpwwZ+2r8JLlle9HoIgWcLWI6AyiN2rBrKfJYQ5wpmIGoBB7UA3e9e3DXPFNWbrQygAmI0GbNn6v4iaOsUmpK2qPhf8Wrm5ufj6f7dh0MD+tZapE2GuvN1nWYllilLyGiA71TKgy15u7QCPQMCjfcV7lc9t/HnrRyJqdAxqB2oVXd/CZLkhRg2z+q5evYq8vDx07VK3qQ1//8cGfLTxUwghUFJSgs5hYfjhu3/VsR5VAlm+H7fetmVsFJZwLsioPaQVLoBnEOB1K+B1C+B5S2UYuwfwmjARNTsGtTP4xwjLNdKm5u4PPLH3+mWE2dJqNhurTKOqeZi2vVPyo6ZNweLnFwIAsnNy8NqaNzB63ANIPfATPDw8KguajRVhXAYYrA/MKLfjSErAK7giiG+tCOWKYG7jz2lJROTUGNQOVO+ub10OUHS5cSpVX2ZjxatyTrOnhwcKanjWdn5+Aby8POHn5wdvb2+cOftrnQ7h5emJTp1uBwB06nQ7Pv7H39G+w+346st/4n+iHqrHvbklQKUGlBrLu1EBtBHAQx8Bav5fnYhaJv7r5UD17vp2979xmcZw7XGFqAzoGlrHXTqHYef/JVZbfyQtDZ07dYJCocDUyQ/h8y++xPIlL1a7Tq3T6aDVaqFSWf9vV3ErTEMZYCyFstDyx0ppfs4NRlpXDWSNZb6wUgMoVZZtVmV6y2hqRSsYM0BENy0GtTO4UfdzYxNmy6Mfb3BXrKfmzMb7H/wDz/y/BfifWdHQqDX4z38T8OVXW/HvbVsBAK++vBx7kvZh0N0j8OqK5ejf7064qFywb/9+rHp9LQ79+B94u6kBQylK8rKQdS4NAJB9JRevvLMBWq0Go4cPrjyopLSEsfzSVtzIowXcEpSIyAEY1K2ZMFsGX5nr1uK87bZQJCXuxOJlLyF8zH0oLzega5fO2PrFPxEZMRoA4OPjgwP7fsTqN97EylVrcDHjD7T19kTPrp3wxosx8FKUAPpSAAIbNm/Hhs3bAQBtvT3Rq1sYvv/iH+jSq58lkFWaivnFDGUiar34UI5G4PQP5RCiIqAdeF9pwHItubzE0p1dXnzj/au0lpeLFlC5Vkx1clwot7iHchARAMvAVJMAzBUvo7li2QwYhYDZDJgEYDILSxlYypkqypnMgFkIGCveretMQlS8V5Y1VilrEoBZUgMeARjToz283Oo3/ZIP5aD6s16DrtfNPWrcoWXAV3lFMBuv9xxjCXBxrXi5WQKaNwIhsmEWAgaTJZiMZsBgtgSL9d1YETBGs6WMwVxZttwkYDBVrjML2ISbqWK9yWa5MryMAjCbRcV7ZRlDleNV+07V+lULw5rDVQjLNmsIWwJZVISr5dX8rccc3Nmhbb2D2tEY1A7k1Dc8sd6YpMFPphKWedTlOkCvA8y1hb5UGcrWgGYXNjURk1mgzCigN1UEnxAwmiqm1lcJHjnwTJagK6/4bKoIrMpQrBKW5ir7rQjLcpOAwSxQZgD0JmHZV8U6o6ky7AwV+zdUfM8arAaTZXvzBxQ5Iwa1AznlDU+EsISpqSHd3BU3DikrBPRFtU+XUqotj1ZUu1kCmi3mm5Y1CMtN1wZTZfhUbeEZzAJ6o+U7pUZLWFm/pzcKlJsBY5Xvl1f5nrWMoUrQWoPNJKwtSFTWwWRppVHTU0qAUmF5V0iSvFz1swRAqZCgkCrLKeRylWUVCkABQKWQoFAASkmCqmK9Ut6f5V2SLN9VKSq/q5Ks36s8jkpR+R2ldT8KWNZb66HSQPIMQIBHM12arAGD+mYmzICxvP6taJPB8njGsoLaW84uboDGHVC7W+7yRU1GCEtQWsOvtCII9RUtyRKDQKnBsr7cJCqCsTLQ9FW+V2oA9CYzyoxAmdHybg3a8qrfMwPlRktrk+rOEiKAi0KCi8ISKCoFoFZKUCsBF6VkWScBKqVlu4vCEiJqhTVMrNsrAqfis4t1vxWf1RXbrQFoDSdVlXCS11mDrCK8rN+rGmjWequUleGnqhJwCslyXKXiJukxc2kD+DnXE/zsDuqkpCQMHTq0ylxYC6PRiJ9//hnDhw93WOWoAcwmyx287P4HVVi6tUvzAUNJDdslQN2mMpwl3tXreoQQ0JsAXbkZxeUCxQZLmJYZLZ+L9GYUGwSKDWYU6YX8ubjcErTWsvLLJFBuFCirCGhzKwtMCZZwUFUJu2tDT62UoFFKVd4rA00pWQJNDqAq4eZSJfRUyspAu/Y4Ssl6rMqQtQawRmU5pktFPSwBagkzovqyO6hHjhyJzMxM+Pvb3iyjoKAAI0eObNTrs0lJSXjjjTeQmpqKzMxMbN++HRMmTJC3CyGwfPlybNiwAfn5+bjrrrvwwQcfICwsTC6Tm5uLuXPn4t///jcUCgUefPBBvPvuuzYPjDh+/DhiYmJw6NAh+Pn5Ye7cuVi4cKFDf0ujDrY3Ge28xSYsg8zKCoCy/JpHa7u4AVpPQO3RYrq063uGhRDQlQsUlQsUlZtRUGZGgb4yVHXlZugqQrfIGsDlAiVGM0oNAiXGipaswVKmJXbDSoAlhCqCxkUpQa0A1BVBpK14twaTHIgKCRqVbUi5VAScViXJL2uI1lZWbW1hVnxPrbzJWm1EdrA7qIUQkGr46/Cvv/5CmzZtHFKp2hQXF6N3796YNWsWJk2aVG3766+/jnXr1uHTTz9FaGgoli5dioiICJw6dUqeChUVFYXMzEzs2rULBoMBM2fOxJw5c/DFF18AsAyrHz16NMLDw7F+/XqcOHECs2bNgre3N+bMmdPg3+DiYukeLikpgaura4P3V43JYN+obrMBKMmzBPS10aZwAVy9AI1ni+zW1hvKYTIJpOcZUVhuRl6ZJXTzyszIKzUjr0wgv8yMAr0ZunIzisoFdHrLu6GhY+4czKUisKzhplVJcFNJ0LpIFZ8VlncXa3gCri4KuLlI0FZ8RyO3Ai2h6KqS4Fqx3RqG2opltRI1/ndORE2vzvOorcH4r3/9C5GRkdBoKp8qZDKZcPz4cXTp0gUJCQmNU9NrSJJk06IWQiAoKAjz58/HggULAFha+QEBAdi0aROmTp2K06dPo3v37jh06BD697c8TjEhIQFjx47Fn3/+iaCgIHzwwQdYvHgxsrKyoFarAQAvvPACduzYgTNnztSpbjeaQ5eZmYn8/Hz4+/vDzc3Ncf8gmuwYNCaMlu7tch2qBbSLK6D2ssxvdpKR2gKVcx5NZgETIE/nqDolxCiE5dK8WUCXdwX7LuThg8MFTTaaVqWAJUArQtBdLcFdbQlM94rgdHWR4KqS0EYtwVOtgJtaQhsXCR5qBdpUfG6jtoavpXXJliRRE3FpA/jV7QmAtWm2edTWUcxCCHh4eNi0BtVqNQYPHozZs2c3uEL1lZ6ejqysLISHh8vrvLy8MGjQICQnJ2Pq1KlITk6Gt7e3HNIAEB4eDoVCgZSUFEycOBHJyckYPny4HNIAEBERgTVr1iAvLw9t27atdmy9Xg+9Xi8vF9bw4IqqAgMDAQA5OQ58YpbZbAnfGxHminnPJbANaKlytLaiHMAVx9XtRlUSlTclsAaxdX6lfAMDUetDu2rbK/JKjNhysqhOIa2UgDZqCR4VwdrOVQEvjQLuagleWstnT40lSN1dLGWs5du4WD67qizXOYmIHKnOQb1x40YAQMeOHbFgwYJG7+a2V1ZWFgAgICDAZn1AQIC8LSsrq9q1dZVKBR8fH5syoaGh1fZh3VZTUK9atQorVqyoc10lSUL79u3h7+8Pg8EBNx8pLwbyM3Ddq7JCAL/tBU5sBcqLKter3IBOo4DOEYDWrWKlY8cZlBsFsovNyNQZkV1sRnaxCTkV738WmpBf5th+5jYVLVlJAvq1V6OtqwJeGgneWgW8tQq01SrQ1tXy7q1VwFNjCVl29RKRM7L7GvXy5cthNBrxf//3f7hw4QKmT58ODw8PXL58GZ6enjaDslqLRYsWIS4uTl4uLCxEcHDwDb+nVCqhVDZw1LSxHMi/XPG/ZC1Bk38R2PcWkHmscp3CBegxCej7CKDxqPl7dWQwCVwsMOJ8nhG/5xtxqdCErGIzsnQmZOtMuFJiblDXs7dWQkAbJQLbKOHvroCfmxI+rpaQ9VBbAthHq0A7N0vLl93ERHQzsTuoL168iMjISGRkZECv1+Nvf/sbPDw8sGbNGuj1eqxfv74x6nlD1u7k7OxstG9f+XjF7Oxs9OnTRy5zbXez0WhEbm6u/P3AwEBkZ2fblLEuW8tcS6PRQKPRNM+dyfIzar+ntjADJ/4XOLjBdh707fcCA2cDHu1r/t51FOrNOJ5tQFp2Oc5eNeLsXwb8lm+EsZ6NYl9XBW71VCLAXQl/NwWCPJS41VMFXzcFgtwt63mfbiJqzewO6meffRb9+/fHsWPH0K5dO3n9xIkTm/UadWhoKAIDA5GYmCgHc2FhIVJSUvDUU08BAIYMGYL8/HykpqaiX79+AIDdu3fDbDZj0KBBcpnFixfDYDDII7R37dqFLl261Njt3ax0V2y7sasqzQf2rAb+OFC5ziMIuDsOuLV/zd+5RonBjF+uGHA824Bj2QYczynH7/l1/yNEIVmCuL2HErd6KtHRS4VbPJW4xcPyCvJQws2lZUz1IiJqLnYH9b59+/Dzzz/bDLYCLNeuL1265LCK1USn0+H8+fPycnp6OtLS0uDj44OQkBDMmzcPK1euRFhYmDw9KygoSB4Z3q1bN0RGRmL27NlYv349DAYDYmNjMXXqVAQFBQEApk+fjhUrVuDxxx/H888/j5MnT+Ldd9/F22+/fcP6NektRI3lQNHlmrddPQf88CJQXGVAWM+HgQGzLA/DqIEQAhfyjEj+sxzHs8uRlm3AhTzjDW+ooVIAod4qdG6nQpiPC0K9lQj2VKG9uxJ+bRRQsRuaiKhB7A5qs9lcY9fun3/+CQ+Phl3rvJHDhw9j5MiR8rL1unB0dDQ2bdqEhQsXori4GHPmzEF+fj6GDRuGhIQEm8dJbt68GbGxsRg1apR8w5N169bJ2728vLBz507ExMSgX79+8PX1xbJly+o0h7pJu76LLtd8a9CLPwOJL1vuzQ0AWm9g5ItA8MDqu9CbseeiHnsuliHpoh5XSq7ff61WAt18XdA7wAV3BqrR3c8FHb1VUHOkMxFRo7H7edRTpkyBl5cXPvzwQ3h4eOD48ePw8/PD+PHjERISIo8Ob80cPYeuGkMpcKWGOd2/7gT2rq4McP/uwOhXALfKSxRlRoG9F8vw7a+l+DFdj5JabtqskoAwHxV6BajRO9AFvfzV6NyOoUxEN7mWPI/aau3atYiMjET37t1RVlaG6dOn49y5c/D19cWXX37Z4Aq1ZE3Woi7Kqr7u1x8s16St46tvGwnc8wKg0sBkFkjLNuA/50rx9akS6Mqrh7OrSsKAIDXuCtZgQJCltcxBXEREzc/uFjVgGSn91Vdf4dixY9DpdLjzzjsRFRXVOLfEbIEatUVt1AM5p2zXpe8Ddi2DHNLdJ0AMnYvkS0b862wpdqWXIbe0ere2l0bC2DBXjO2kxcAgDTQMZiJq7Vp6i9pgMKBr16747rvvEBUVhaioqAZX4GbSJC3qkr9sl3POALtXwhrS5u4T8a92/4P3N/+FC3nVp21plMC4MFc80NkVw0I0HOxFROTk7ApqFxcXlJWVNVZdWrxGH/UtBFCSW7lcmmcZ3W2y3L40w38kHjk3BRlHCmy+5qqSMLyDBqM6avG327Ro68opUURELYXd16hjYmKwZs0afPTRR9WeSU2NTF9UeeMSYQb2rAJKLcF9XNEND2XMQDkqu7gHBKnxWK82+NttWl5vJiJqoexO2kOHDiExMRE7d+5Ez549q93ze9u2bQ6rXEvT6F3fZfnyR9OJbVD+cRAAcEV4YWbJMyiH5QYtg25R45mBHrgrWFPTXoiIqAWxO6i9vb3x4IMPNkZdWrxG7/ous3Rp63KzoDn4Eax3CY8zPIW/4IWu7ZR4cZgXhneo+aYmRETU8tgd1Jwn3UzKSwCzEWazQMbO99DdbBkr8IXxXpxz7Y237/LAhC5t+AQoIqKbDC8yO1Cjdn2X6wAAW/YcxvTC/QCAXOGORN9H8O1YP/i7839KIqKbkd3zqPv27Vtjq02SJGi1WnTq1AkzZsywudVna9Mo86j/uoCTf1xFzjfP417lUQDAd36zMeq+qXB1aeCjMomIyMIJ51HbPU8nMjISv/32G9q0aYORI0di5MiRcHd3x4ULFzBgwABkZmYiPDwc//rXvxpcOapk0hfjo11H5ZDOV/ni3sgHGdJERDc5u/tLr169ivnz52Pp0qU261euXImLFy9i586dWL58OV555RWMHz/eYRVt1Yzl+OJ4IYYWfC//LyZ6TYGbKweNERHd7OxuUX/99deYNm1atfVTp07F119/DQCYNm0azp492/DaEQCgrKQIHx7IxP3KZACAQekGz573NXOtiIioKdgd1FqtFj///HO19T///LP8OEmz2WzzaMnWIj4+Ht27d8eAAQMcut/taZcxwrAfrlI5AEDZZTSUGt5XnYioNbC763vu3Ll48sknkZqaKgfSoUOH8NFHH+HFF18EAPzwww/o06ePQyvaEjTGPGqjyYwPfs7EakWKvE7RdZxD9k1ERM6vXk/P2rx5M95//325e7tLly6YO3cupk+fDgAoLS2VR4G3Ro4c8bdg6zEkpp7CIc3TUElmwDMImLIZ4HxpIiLHc8JR3/WafHujJ2fxcZeO8UduCf439U88pDxqCWkACB3BkCYiakXq9Ril/Px8uas7N9fyUIgjR47g0qVLDq1ca5d+tRgAMFTxS+XKDkObqTZERNQc7A7q48ePo3PnzlizZg3eeOMN5OfnA7A8jGPRokWOrp9dkpKScP/99yMoKAiSJGHHjh0224UQWLZsGdq3bw9XV1eEh4fj3LlzNmVyc3MRFRUFT09PeHt74/HHH4dOp2vCX1EpI7cEgMBgxSnLCqUG8OvaLHUhIqLmYXdQx8XFYcaMGTh37pzNNeixY8ciKSnJoZWzV3FxMXr37o34+Pgat7/++utYt24d1q9fj5SUFLRp0wYRERE2z9iOiorCL7/8gl27duG7775DUlIS5syZ01Q/wUZ2YRmCpRwESRXPoA7sAShdmqUuRETUPOr1mMt//OMf1dbfcsstyMrKckil6mvMmDEYM2ZMjduEEHjnnXewZMkS+UYsn332GQICArBjxw5MnToVp0+fRkJCAg4dOoT+/fsDAN577z2MHTsWa9euRVBQUJP9FgAoKDWgn1Slxd++d5Men4iImp/dLWqNRoPCwsJq63/99Vf4+fk5pFKNIT09HVlZWQgPD5fXeXl5YdCgQUhOttxIJDk5Gd7e3nJIA0B4eDgUCgVSUlKq7dNKr9ejsLDQ5uUIBaUGdFNcrFzh28Uh+yUiopbD7qB+4IEH8PLLL8NgMACwPIwjIyMDzz//vFM/p9ra2g8ICLBZHxAQIG/LysqCv7+/zXaVSgUfH5/r9hasWrUKXl5e8is4ONghdS4sNaCblFG5ot3tDtkvERG1HHYH9ZtvvgmdTgd/f3+UlpZixIgR6NSpE9zd3fHqq682Rh2d3qJFi1BQUIC1a9eiS5cu6NSpk0P2a2lRW4JaaL0At3YO2S8REbUcdl+j9vLywq5du/DTTz/h+PHj0Ol0uPPOO226lJ1RYGAgACA7Oxvt27eX12dnZ8t3UQsMDEROTo7N94xGI3Jzc+Xv10Sj0UCj0WD+/PmYP3++w+5Mlp6RAT9tAQBA8rmd86eJiFqhes2jBoBhw4bh6aefxsKFCxEeHo4jR47gvvuc90ERoaGhCAwMRGJioryusLAQKSkpGDJkCABgyJAhyM/PR2pqqlxm9+7dMJvNGDRo0A2P4ch7ff+RW4IQqcofDV63NnifRETU8tgV1D/88AMWLFiAF198Eb/99hsA4MyZM5gwYQIGDBgAs9ncKJWsK51Oh7S0NKSlpQGwDCBLS0tDRkYGJEnCvHnzsHLlSnz77bc4ceIEHnvsMQQFBWHChAkAgG7duiEyMhKzZ8/GwYMHsX//fsTGxmLq1Kl1GvEdExODU6dO4dChQw3+LReu6BAsXalc4VF7i56IiG5ede76/vjjjzF79mz4+PggLy8PH330Ed566y3MnTsXU6ZMwcmTJ9GtW7fGrOsNHT58GCNHjpSX4+LiAADR0dHYtGkTFi5ciOLiYsyZMwf5+fkYNmwYEhISbOaDb968GbGxsRg1ahQUCgUefPBBrFu3rk7Hj4+PR3x8PEwmU4N/S7HedE1Qt6+9MBER3bTq/FCOXr164dFHH8Vzzz2Hb775BpMnT8bgwYPx9ddf49Zb2S1blSNuyP71oT9g/NczmK7abVkxYT3gz7uSERE1Kid8KEedu74vXLiAyZMnAwAmTZoElUqFN954gyFdhSOvUev0RrSX/qpc4RFQe2EiIrpp1TmoS0tL4ebmBsAyd1qj0diMnibHXqMu1hvRTrLcOEVAAWgd83xrIiJqWeyanvXRRx/B3d0dgGXa0qZNm+Dr62tT5plnnnFc7VoYR16j1pUb4SMVAQAMak+opXoP0CciohaszteoO3bsCOkG83glSZJHg7dmjrg+sXT7CSxOGwmtZECpR0e4Ttvk2EoSEVF1TniNus4t6t9//73BB6O6E+U6aCXLbVrNWu/mrQwRETUb9qc6kCMHk2kNefJnBjURUevFoHYgRw4m05YXVC5oGt51QkRELROD2kmpTLrKBZc2zVcRIiJqVgxqB3Jk17fKWCp/ltSuDd4fERG1TAxqB3Jk17eLsVj+LLkwqImIWqt6BfWFCxewZMkSTJs2TX4s5H//+1/88ssvDq1ca+ZiLpE/K9RuzVgTIiJqTnYH9d69e9GzZ0+kpKRg27Zt0Oks11KPHTuG5cuXO7yCrZXaVNn1rWDXNxFRq2V3UL/wwgtYuXIldu3aBbVaLa+/9957ceDAAYdWrjVTm6q0qDUcTEZE1FrZHdQnTpzAxIkTq6339/fH1atXHVKplsqRg8nU5soWtYotaiKiVsvuoPb29kZmZma19UePHsUtt9zikEq1VI4cTKYy6+XPkov2OiWJiOhmZndQT506Fc8//zyysrIgSRLMZjP279+PBQsW4LHHHmuMOrZKSmGoXFDY9ewUIiK6idgd1K+99hq6du2K4OBg6HQ6dO/eHcOHD8fQoUOxZMmSxqhjq8SgJiIiwM7HXAKAWq3Ghg0bsHTpUpw8eRI6nQ59+/ZFWFhYY9Sv1VKKKo/KVLg0X0WIiKhZ2d2i/umnnwAAISEhGDt2LB5++OEWFdJJSUm4//77ERQUBEmSsGPHDpvtQggsW7YM7du3h6urK8LDw3Hu3Lkmr6fKpkWtbPLjExGRc7A7qO+9916EhobixRdfxKlTpxqjTo2quLgYvXv3Rnx8fI3bX3/9daxbtw7r169HSkoK2rRpg4iICJSVlTVpPVUwVi4o2aImImqt7A7qy5cvY/78+di7dy969OiBPn364I033sCff/7ZGPVzuDFjxmDlypU1TjETQuCdd97BkiVLMH78ePTq1QufffYZLl++XK3l3dhUqNr1zWvUREStld1B7evri9jYWOzfvx8XLlzA5MmT8emnn6Jjx4649957G6OOTSY9PR1ZWVkIDw+X13l5eWHQoEFITk6u9Xt6vR6FhYU2r4ZScTAZERGhgQ/lCA0NxQsvvIDVq1ejZ8+e2Lt3r6Pq1SyysrIAAAEBATbrAwIC5G01WbVqFby8vORXcHBwg+vCrm8iIgIaENT79+/H008/jfbt22P69Ono0aMH/vOf/ziybi3GokWLUFBQgLVr16JLly7o1KlTg/dp0/UtcTAZEVFrZXdQL1q0CKGhobj33nuRkZGBd999F1lZWfj8888RGRnZGHVsMoGBgQCA7Oxsm/XZ2dnytppoNBp4enpi/vz5OHPmDFJTUxtcFxdhaVEboAQkqcH7IyKilsnuoE5KSsJzzz2HS5cu4bvvvsO0adPg5nZzPIYxNDQUgYGBSExMlNcVFhYiJSUFQ4YMueH3HXmvbxUs16iN9k91JyKim4jdKbB///7GqEeT0el0OH/+vLycnp6OtLQ0+Pj4ICQkBPPmzcPKlSsRFhaG0NBQLF26FEFBQZgwYUKT1lMJMwDA1LBhBERE1MLVKai//fZbjBkzBi4uLvj222+vW/aBBx5wSMUay+HDhzFy5Eh5OS4uDgAQHR2NTZs2YeHChSguLsacOXOQn5+PYcOGISEhAVrtjR+MERMTg5iYGBQWFsLLy6tB9ZQqgtrMoCYiatUkIYS4USGFQoGsrCz4+/tDoag9OCRJgslkqnX7zS4+Ph7x8fEwmUz49ddfUVBQAE9Pz3rt648VXREsMlGANvCa0zoH6RERNTmXNoBf5wbtwtpYa0gGVFWn5prZbIa/v7/8ubZXaw5pwLGPuZQq/n4S4EAyIqLWzO5+1c8++wx6vb7a+vLycnz22WcOqRQBEoT8iYiIWi+7g3rmzJkoKCiotr6oqAgzZ850SKVaKkeO+hbXvBMRUetkd1ALISDVMK/3zz//bPAAqpbOoV3fFe/s+iYiat3qPD2rb9++kCQJkiRh1KhRUKkqv2oymZCent7ib3jSUFUHkzWUxLY0ERHBjqC2ziNOS0tDREQE3N3d5W1qtRodO3bEgw8+6PAKtiSOnJ4FXqMmIiLYEdTLly8HAHTs2BFTpkyp07xiqj9ri5rtaiKi1s3uO5NFR0c3Rj3oGrxGTUREQD0Gk5lMJqxduxYDBw5EYGAgfHx8bF6tmSNHfXN6FhERAfUI6hUrVuCtt97ClClTUFBQgLi4OEyaNAkKhQIvvfRSI1Sx5XDkqG+w65uIiFCPoN68eTM2bNiA+fPnQ6VSYdq0afjoo4+wbNkyHDhwoDHq2Cqx65uIiIB6BHVWVhZ69uwJAHB3d5dvfnLffffhP//hPakdjUFNRNS62R3Ut956KzIzMwEAt99+O3bu3AkAOHToEDQajWNr14pxHjUREQH1COqJEyciMTERADB37lwsXboUYWFheOyxxzBr1iyHV7AlceRgsspr1GxRExG1ZnV6zOX1JCcnIzk5GWFhYbj//vsdVa8WzRGPOLv6Ugh8UYBM+KH9nK0OriEREdXICR9zafc86msNGTIEQ4YMaXBFyBbb0UREBNQxqL/99ts67/CBBx6od2WoEq9RExERUMegtt7n+0YkSXLIAymaW1JSEt544w2kpqYiMzMT27dvr/M5cJyKa9Q1PKmMiIhajzoNJjObzXV63QwhDQDFxcXo3bs34uPjm60OnEdNRESAA65R34zGjBmDMWPGNHc1iIiI7A/ql19++brbly1bVu/KUCWJ07OIiAj1COrt27fbLBsMBqSnp0OlUuH2229vlUGt1+uh1+vl5cLCwgbvk0FNRERAPYL66NGj1dYVFhZixowZmDhxokMq1dKsWrUKK1ascOg+JQHO0SIiIvvvTFYTT09PrFixAkuXLnXE7lqcRYsWoaCgAGvXrkWXLl3QqVMnB+yVLWoiInJQUANAQUGB/ICO1kaj0cDT0xPz58/HmTNnkJqa2uB98nnUREQE1KPre926dTbLQghkZmbi888/v2lGSut0Opw/f15eTk9PR1paGnx8fBASElLr9+Lj4xEfH++QaWqV07OIiKg1szuo3377bZtlhUIBPz8/REdHY9GiRQ6rWHM6fPgwRo4cKS/HxcUBAKKjo7Fp06YmqQMHkxEREeCAh3JQdY64IXvxcn+0kfS4KN2KDrP/6eAaEhFRjZzwoRwOu0ZNjn7MpQVb1ERErZvdXd9lZWV477338OOPPyInJwdms9lm+5EjRxxWuZYmJiYGMTEx8l9TDcFr1EREBNQjqB9//HHs3LkTDz30EAYOHAiJD41oFPKob55fIqJWze6g/u677/D999/jrrvuaoz6tGiOHfXNwWRERFSPa9S33HILPDw8GqMuLV5MTAxOnTqFQ4cONXhf7PomIiKgHkH95ptv4vnnn8fFixcboz4tmiMHk/GGJ0REBNSj67t///4oKyvDbbfdBjc3N7i4uNhsz83NdVjlWhpHDia7oO4CpTCgUNPeQbUjIqKWyO6gnjZtGi5duoTXXnsNAQEBHEzWSLot/hkoKwByf2vuqhARUTOyO6h//vlnJCcno3fv3o1RHyIiIqrC7mvUXbt2RWlpaWPUpcVrjBueEBFR62b3LUR37tyJFStW4NVXX0XPnj2rXaN2xO3SWjqH3T6OXd9ERE3LCW8hanfXd2RkJABg1KhRNuuFEJAkySFziImIiMjC7qD+8ccfG6MeREREVAO7g3rEiBGNUQ+qEUfUExG1dnYHdVJS0nW3Dx8+vN6VaekceQtRIiIioB6DyRSK6gPFq86lZkg5cjBZIZB7wXEVIyKi63PCwWR2T8/Ky8uzeeXk5CAhIQEDBgzAzp07G1whIiIiqmR313dNt8b829/+BrVajbi4OKSmpjqkYkRERFSPFnVtAgICcPbsWbu+k5SUhPvvvx9BQUGQJAk7duxwVHVqFR8fj44dO0Kr1WLQoEE4ePCgzfYPP/wQ99xzDzw9PSFJEvLz8xu9TkRERLWxO6iPHz9u8zp27BgSEhLw5JNPok+fPnbtq7i4GL1790Z8fLy91aiXr776CnFxcVi+fDmOHDmC3r17IyIiAjk5OXKZkpISREZG4sUXX2ySOhEREV1PvQaTSZKEa782ePBgfPLJJ+jatWv9KiJJ2L59OyZMmCCv0+v1WLx4Mb788kvk5+ejR48eWLNmDe655556HWPQoEEYMGAA3n//fQCA2WxGcHAw5s6dixdeeMGm7J49ezBy5Ejk5eXB29vbruNwMBkRUQvlhIPJ7L5GnZ6ebrOsUCjg5+cHrVbb4MpcKzY2FqdOncKWLVsQFBSE7du3IzIyEidOnEBYWJhd+yovL0dqaioWLVokr1MoFAgPD0dycrKjq05EROQQdgd1hw4dGqMe1WRkZGDjxo3IyMhAUFAQAGDBggVISEjAxo0b8dprr9m1v6tXr8JkMiEgIMBmfUBAAM6cOdOguur1euj1enm5sLCwQfsjIiKyqvM16t27d6N79+41hlBBQQHuuOMO7Nu3z2EVO3HiBEwmEzp37gx3d3f5tXfvXly4YOkOPnPmDCRJuu7r2i7txrBq1Sp4eXnJr+Dg4EY/JhERtQ51blG/8847mD17do397V5eXnjiiSfw1ltv4e6773ZIxXQ6HZRKJVJTU6FUKm22ubu7AwBuu+02nD59+rr7adeuHQDA19cXSqUS2dnZNtuzs7MRGBjYoLouWrQIcXFx2LBhAzZs2ACTyYTz5883aJ9ERESAHUF97NgxrFmzptbto0ePxtq1ax1SKQDo27cvTCYTcnJyag1/tVpd58FrarUa/fr1Q2JiojxgzWw2IzExEbGxsQ2qq0ajgUajwfz58zF//nx5IAEREVFD1Tmos7Ozqz172mZHKhWuXLli18F1Op1NyzM9PR1paWnw8fFB586dERUVhcceewxvvvkm+vbtiytXriAxMRG9evXCuHHj7DoWAMTFxSE6Ohr9+/fHwIED8c4776C4uBgzZ86Uy2RlZSErK0uu14kTJ+Dh4YGQkBD4+Phcd/+81zcRETlanYP6lltuwcmTJ9GpU6catx8/fhzt27e36+CHDx/GyJEj5eW4uDgAQHR0NDZt2oSNGzdi5cqVmD9/Pi5dugRfX18MHjwY9913n13HsZoyZQquXLmCZcuWISsrC3369EFCQoLNALP169djxYoV8rL1ISMbN27EjBkz6nVcIiKi+qrzPOq5c+diz549OHToULWpWKWlpRg4cCBGjhyJdevWNUpFWxLOoyYiaqGccB51nYM6Ozsbd955J5RKJWJjY9GlSxcAlpHX1u7eI0eOVJv+1JpU7fr+9ddfGdRERC1NSw5qALh48SKeeuop/PDDD/KdySRJQkREBOLj4xEaGtrgCt0M2KImImqhnDCo7brhSYcOHfD9998jLy8P58+fhxACYWFhaNu2bYMrcjPgYDIiInI0u+/1TTfGFjURUQvlhC1qhz3mkoiIiByPQe1A8fHx6N69OwYMGNDcVSEiopsEu74bAbu+iYhaKHZ9ExERkT0Y1ERERE6MQe1AvEZNRESOxmvUjYDXqImIWiheoyYiIiJ7MKiJiIicGIOaiIjIiTGoHYiDyYiIyNE4mKwRcDAZEVELxcFkREREZA8GNRERkRNr1qBOSkrC/fffj6CgIEiShB07djT6MePj49GxY0dotVoMGjQIBw8elLfl5uZi7ty56NKlC1xdXRESEoJnnnkGBQUFjV4vIiKimjRrUBcXF6N3796Ij49vkuN99dVXiIuLw/Lly3HkyBH07t0bERERyMnJAQBcvnwZly9fxtq1a3Hy5Els2rQJCQkJePzxx5ukfkRERNdymsFkkiRh+/btmDBhgrxOr9dj8eLF+PLLL5Gfn48ePXpgzZo1uOeee+p1jEGDBmHAgAF4//33AQBmsxnBwcGYO3cuXnjhhRq/s3XrVjzyyCMoLi6GSqWq03E4mIyIqIXiYDL7xMbGIjk5GVu2bMHx48cxefJkREZG4ty5c3bvq7y8HKmpqQgPD5fXKRQKhIeHIzk5udbvWU90XUOaiIjIkZw2fTIyMrBx40ZkZGQgKCgIALBgwQIkJCRg48aNeO211+za39WrV2EymRAQEGCzPiAgAGfOnKn1O6+88grmzJlz3X3r9Xro9Xp5ubCw0K66ERER1cZpW9QnTpyAyWRC586d4e7uLr/27t2LCxcs3cFnzpyBJEnXfdXWpX0jhYWFGDduHLp3746XXnrpumVXrVoFLy8v+RUcHFyvYxIREV3LaVvUOp0OSqUSqampUCqVNtvc3d0BALfddhtOnz593f20a9cOAODr6wulUons7Gyb7dnZ2QgMDLRZV1RUhMjISHh4eGD79u1wcXG57jEWLVqEuLg4bNiwARs2bIDJZML58+fr9DuJiIiux2mDum/fvjCZTMjJycHdd99dYxm1Wo2uXbvWaX9qtRr9+vVDYmKiPGDNbDYjMTERsbGxcrnCwkJERERAo9Hg22+/hVarveG+NRoNNBoNtFotFAoFnGR8HhER3QSaNah1Op1NyzM9PR1paWnw8fFB586dERUVhcceewxvvvkm+vbtiytXriAxMRG9evXCuHHj7D5eXFwcoqOj0b9/fwwcOBDvvPMOiouLMXPmTACWkB49ejRKSkrwz3/+E4WFhfL1Zj8/v2ot+2vFxMQgJiZGHvFHRETUUM0a1IcPH8bIkSPl5bi4OABAdHQ0Nm3ahI0bN2LlypWYP38+Ll26BF9fXwwePBj33XdfvY43ZcoUXLlyBcuWLUNWVhb69OmDhIQEeYDZkSNHkJKSAgDo1KmTzXfT09PRsWPH6+4/Pj4e8fHxMJlM9aofERHRtZxmHvXNhPOoiYhaKM6jvrnxMZdERORobFE3AraoiYhaKLaob25sURMRkaOxRd0I2KImImqh2KImIiIiezCoHYhd30RE5Gjs+m4E7PomImqh2PVNRERE9mBQExEROTEGtQPxGjURETkar1E3Al6jJiJqoXiNmuwiSc1dAyIiamYMaiIiIifGoCYiInJiDGoH4mAyIiJyNA4mawQOG0igLwL+Ou+4ihER0fVxMBkRERHZg0FNRETkxBjUREREToxBTURE5MQY1ERERE5M1dwVuBlZB9IXFhY2bEf6IqBI54AaERFRnbgIQNOwf7ut//Y7alIVg7oRFBUVAQCCg4ObuSZERNRcioqK4OXl1eD9cB51IzCbzbh8+TI8PDwg1fN+3YWFhQgODsYff/zhkHl4Nwuel9rx3NSM56VmPC81c8R5EUKgqKgIQUFBUCgafoWZLepGoFAocOuttzpkX56envyPqAY8L7XjuakZz0vNeF5q1tDz4oiWtBUHkxERETkxBjUREZETY1A7KY1Gg+XLl0Oj0TR3VZwKz0vteG5qxvNSM56XmjnjeeFgMiIiIifGFjUREZETY1ATERE5MQY1ERGRE2NQO6n4+Hh07NgRWq0WgwYNwsGDB5u7SvW2atUqDBgwAB4eHvD398eECRNw9uxZmzJlZWWIiYlBu3bt4O7ujgcffBDZ2dk2ZTIyMjBu3Di4ubnB398fzz33HIxGo02ZPXv24M4774RGo0GnTp2wadOmavVxxnO7evVqSJKEefPmyeta8zm5dOkSHnnkEbRr1w6urq7o2bMnDh8+LG8XQmDZsmVo3749XF1dER4ejnPnztnsIzc3F1FRUfD09IS3tzcef/xx6HS2t+Q9fvw47r77bmi1WgQHB+P111+vVpetW7eia9eu0Gq16NmzJ77//vvG+dE3YDKZsHTpUoSGhsLV1RW33347XnnlFZvbVLaG85KUlIT7778fQUFBkCQJO3bssNnuTOegLnWpE0FOZ8uWLUKtVotPPvlE/PLLL2L27NnC29tbZGdnN3fV6iUiIkJs3LhRnDx5UqSlpYmxY8eKkJAQodPp5DJPPvmkCA4OFomJieLw4cNi8ODBYujQofJ2o9EoevToIcLDw8XRo0fF999/L3x9fcWiRYvkMr/99ptwc3MTcXFx4tSpU+K9994TSqVSJCQkyGWc8dwePHhQdOzYUfTq1Us8++yz8vrWek5yc3NFhw4dxIwZM0RKSor47bffxA8//CDOnz8vl1m9erXw8vISO3bsEMeOHRMPPPCACA0NFaWlpXKZyMhI0bt3b3HgwAGxb98+0alTJzFt2jR5e0FBgQgICBBRUVHi5MmT4ssvvxSurq7iH//4h1xm//79QqlUitdff12cOnVKLFmyRLi4uIgTJ040zcmo4tVXXxXt2rUT3333nUhPTxdbt24V7u7u4t1335XLtIbz8v3334vFixeLbdu2CQBi+/btNtud6RzUpS51waB2QgMHDhQxMTHysslkEkFBQWLVqlXNWCvHycnJEQDE3r17hRBC5OfnCxcXF7F161a5zOnTpwUAkZycLISw/MepUChEVlaWXOaDDz4Qnp6eQq/XCyGEWLhwobjjjjtsjjVlyhQREREhLzvbuS0qKhJhYWFi165dYsSIEXJQt+Zz8vzzz4thw4bVut1sNovAwEDxxhtvyOvy8/OFRqMRX375pRBCiFOnTgkA4tChQ3KZ//73v0KSJHHp0iUhhBB///vfRdu2beVzZT12ly5d5OWHH35YjBs3zub4gwYNEk888UTDfmQ9jBs3TsyaNctm3aRJk0RUVJQQonWel2uD2pnOQV3qUlfs+nYy5eXlSE1NRXh4uLxOoVAgPDwcycnJzVgzxykoKAAA+Pj4AABSU1NhMBhsfnPXrl0REhIi/+bk5GT07NkTAQEBcpmIiAgUFhbil19+kctU3Ye1jHUfznhuY2JiMG7cuGr1bs3n5Ntvv0X//v0xefJk+Pv7o2/fvtiwYYO8PT09HVlZWTZ19vLywqBBg2zOjbe3N/r37y+XCQ8Ph0KhQEpKilxm+PDhUKvVcpmIiAicPXsWeXl5cpnrnb+mNHToUCQmJuLXX38FABw7dgw//fQTxowZA6D1npeqnOkc1KUudcWgdjJXr16FyWSy+ccXAAICApCVldVMtXIcs9mMefPm4a677kKPHj0AAFlZWVCr1fD29rYpW/U3Z2Vl1XhOrNuuV6awsBClpaVOd263bNmCI0eOYNWqVdW2tdZzAgC//fYbPvjgA4SFheGHH37AU089hWeeeQaffvopgMrfdr06Z2Vlwd/f32a7SqWCj4+PQ85fc5ybF154AVOnTkXXrl3h4uKCvn37Yt68eYiKirKpc2s7L1U50zmoS13qig/loCYVExODkydP4qeffmruqjSrP/74A88++yx27doFrVbb3NVxKmazGf3798drr70GAOjbty9OnjyJ9evXIzo6uplr13y+/vprbN68GV988QXuuOMOpKWlYd68eQgKCmrV56U1YIvayfj6+kKpVFYb3ZudnY3AwMBmqpVjxMbG4rvvvsOPP/5o83SxwMBAlJeXIz8/36Z81d8cGBhY4zmxbrteGU9PT7i6ujrVuU1NTUVOTg7uvPNOqFQqqFQq7N27F+vWrYNKpUJAQECrOydW7du3R/fu3W3WdevWDRkZGQAqf9v16hwYGIicnByb7UajEbm5uQ45f81xbp577jm5Vd2zZ088+uij+H//7//JPTKt9bxU5UznoC51qSsGtZNRq9Xo168fEhMT5XVmsxmJiYkYMmRIM9as/oQQiI2Nxfbt27F7926EhobabO/Xrx9cXFxsfvPZs2eRkZEh/+YhQ4bgxIkTNv+B7dq1C56envI/6kOGDLHZh7WMdR/OdG5HjRqFEydOIC0tTX71798fUVFR8ufWdk6s7rrrrmrT93799Vd06NABABAaGorAwECbOhcWFiIlJcXm3OTn5yM1NVUus3v3bpjNZgwaNEguk5SUBIPBIJfZtWsXunTpgrZt28plrnf+mlJJSUm1ZxsrlUqYzWYArfe8VOVM56Audakzu4aeUZPYsmWL0Gg0YtOmTeLUqVNizpw5wtvb22Z0b0vy1FNPCS8vL7Fnzx6RmZkpv0pKSuQyTz75pAgJCRG7d+8Whw8fFkOGDBFDhgyRt1unIo0ePVqkpaWJhIQE4efnV+NUpOeee06cPn1axMfH1zgVyVnPbdVR30K03nNy8OBBoVKpxKuvvirOnTsnNm/eLNzc3MQ///lPuczq1auFt7e3+Ne//iWOHz8uxo8fX+MUnL59+4qUlBTx008/ibCwMJspOPn5+SIgIEA8+uij4uTJk2LLli3Czc2t2hQclUol1q5dK06fPi2WL1/ebNOzoqOjxS233CJPz9q2bZvw9fUVCxculMu0hvNSVFQkjh49Ko4ePSoAiLfeekscPXpUXLx40enOQV3qUhcMaif13nvviZCQEKFWq8XAgQPFgQMHmrtK9QagxtfGjRvlMqWlpeLpp58Wbdu2FW5ubmLixIkiMzPTZj+///67GDNmjHB1dRW+vr5i/vz5wmAw2JT58ccfRZ8+fYRarRa33XabzTGsnPXcXhvUrfmc/Pvf/xY9evQQGo1GdO3aVXz44Yc2281ms1i6dKkICAgQGo1GjBo1Spw9e9amzF9//SWmTZsm3N3dhaenp5g5c6YoKiqyKXPs2DExbNgwodFoxC233CJWr15drS5ff/216Ny5s1Cr1eKOO+4Q//nPfxz/g+ugsLBQPPvssyIkJERotVpx2223icWLF9tMIWoN5+XHH3+s8d+T6OhoIYRznYO61KUu+PQsIiIiJ8Zr1ERERE6MQU1EROTEGNREREROjEFNRETkxBjUREREToxBTURE5MQY1ERERE6MQU1EROTEGNREN7kZM2ZgwoQJzV0NIqonBjVRCyZJ0nVfL730Et59911s2rSpWeq3YcMG9O7dG+7u7vD29kbfvn1tnr/NPyKIbozPoyZqwTIzM+XPX331FZYtW2bz5Cl3d3e4u7s3R9XwySefYN68eVi3bh1GjBgBvV6P48eP4+TJk81SH6IWy+67gxORU9q4caPw8vKqtj46OlqMHz9eXh4xYoSIjY0Vzz77rPD29hb+/v7iww8/FDqdTsyYMUO4u7uL22+/XXz//fc2+zlx4oSIjIwUbdq0Ef7+/uKRRx4RV65cqbU+48ePFzNmzKh1+/Lly6s9WOHHH38UQgiRkZEhJk+eLLy8vETbtm3FAw88INLT06v9ppdeekn4+voKDw8P8cQTT9g8oGLr1q2iR48eQqvVCh8fHzFq1Cih0+mufxKJnBC7volaoU8//RS+vr44ePAg5s6di6eeegqTJ0/G0KFDceTIEYwePRqPPvooSkpKAAD5+fm499570bdvXxw+fBgJCQnIzs7Gww8/XOsxAgMDceDAAVy8eLHG7QsWLMDDDz+MyMhIZGZmIjMzE0OHDoXBYEBERAQ8PDywb98+7N+/H+7u7oiMjER5ebn8/cTERJw+fRp79uzBl19+iW3btmHFihUALD0N06ZNw6xZs+QykyZNguAziKglau6/FIjIMexpUQ8bNkxeNhqNok2bNuLRRx+V12VmZgoAIjk5WQghxCuvvCJGjx5ts98//vhDAKj1sX2XL18WgwcPFgBE586dRXR0tPjqq6+EyWSqtW5CCPH555+LLl26CLPZLK/T6/XC1dVV/PDDD/L3fHx8RHFxsVzmgw8+EO7u7sJkMonU1FQBQPz++++1nC2iloMtaqJWqFevXvJnpVKJdu3aoWfPnvK6gIAAAEBOTg4A4NixY/jxxx/la97u7u7o2rUrAODChQs1HqN9+/ZITk7GiRMn8Oyzz8JoNCI6OhqRkZEwm8211u3YsWM4f/48PDw85GP5+PigrKzM5li9e/eGm5ubvDxkyBDodDr88ccf6N27N0aNGoWePXti8uTJ2LBhA/Ly8upxpoiaHweTEbVCLi4uNsuSJNmskyQJAORA1el0uP/++7FmzZpq+2rfvv11j9WjRw/06NEDTz/9NJ588kncfffd2Lt3L0aOHFljeZ1Oh379+mHz5s3Vtvn5+V3/h1VQKpXYtWsXfv75Z+zcuRPvvfceFi9ejJSUFISGhtZpH0TOgkFNRDd055134ptvvkHHjh2hUtX/n43u3bsDAIqLiwEAarUaJpOp2rG++uor+Pv7w9PTs9Z9HTt2DKWlpXB1dQUAHDhwAO7u7ggODgZg+WPjrrvuwl133YVly5ahQ4cO2L59O+Li4updf6LmwK5vIrqhmJgY5ObmYtq0aTh06BAuXLiAH374ATNnzqwWtFZPPfUUXnnlFezfvx8XL17EgQMH8Nhjj8HPzw9DhgwBAHTs2BHHjx/H2bNncfXqVRgMBkRFRcHX1xfjx4/Hvn37kJ6ejj179uCZZ57Bn3/+Ke+/vLwcjz/+OE6dOoXvv/8ey5cvR2xsLBQKBVJSUvDaa6/h8OHDyMjIwLZt23DlyhV069atSc4XkSMxqInohoKCgrB//36YTCaMHj0aPXv2xLx58+Dt7Q2FouZ/RsLDw3HgwAFMnjwZnTt3xoMPPgitVovExES0a9cOADB79mx06dIF/fv3h5+fH/bv3w83NzckJSUhJCQEkyZNQrdu3fD444+jrKzMpoU9atQohIWFYfjw4ZgyZQoeeOABvPTSSwAAT09PJCUlYezYsejcuTOWLFmCN998E2PGjGn0c0XkaJIQnK9ARC3LjBkzkJ+fjx07djR3VYgaHVvUREREToxBTURE5MTY9U1EROTE2KImIiJyYgxqIiIiJ8agJiIicmIMaiIiIifGoCYiInJiDGoiIiInxqAmIiJyYgxqIiIiJ8agJiIicmL/Hxp0KP2O7MUdAAAAAElFTkSuQmCC",
            "text/plain": [
              "<Figure size 500x300 with 1 Axes>"
            ]
          },
          "metadata": {},
          "output_type": "display_data"
        }
      ],
      "source": [
        "import matplotlib.ticker as ticker\n",
        "\n",
        "# Calculate mean and standard deviation of cumulative regrets\n",
        "mean_regret1 = np.mean(cu_regret1, axis=0)\n",
        "std_regret1 = np.std(cu_regret1, axis=0)\n",
        "\n",
        "mean_regret2 = np.mean(cu_regret2, axis=0)\n",
        "std_regret2 = np.std(cu_regret2, axis=0)\n",
        "\n",
        "# Plot the average cumulative regret with error shading\n",
        "plt.figure(figsize=(5, 3))\n",
        "\n",
        "# Plot the mean cumulative regret\n",
        "plt.plot(mean_regret1, linewidth=2, label=\"MNAR\")\n",
        "\n",
        "# Add shaded area for error indication (±1 standard deviation)\n",
        "plt.fill_between(np.arange(T),\n",
        "                 mean_regret1 - std_regret1,\n",
        "                 mean_regret1 + std_regret1,\n",
        "                 alpha=0.2)\n",
        "\n",
        "# Plot the mean cumulative regret\n",
        "plt.plot(mean_regret2, linewidth=2, label=\"UCB\")\n",
        "\n",
        "# Add shaded area for error indication (±1 standard deviation)\n",
        "plt.fill_between(np.arange(T),\n",
        "                 mean_regret2 - std_regret2,\n",
        "                 mean_regret2 + std_regret2,\n",
        "                 alpha=0.2)\n",
        "\n",
        "# Set the y-axis to log scale\n",
        "plt.yscale('log')\n",
        "\n",
        "# Set the formatter for the y-axis to display in 10^n format\n",
        "plt.gca().yaxis.set_major_formatter(ticker.LogFormatter(base=10))\n",
        "\n",
        "# Add labels and grid\n",
        "plt.xlabel('Time Steps')\n",
        "plt.ylabel('Cumulative Regret')\n",
        "plt.grid(False)\n",
        "plt.legend(loc='upper left')\n",
        "\n",
        "# Adjust the layout for better spacing\n",
        "plt.tight_layout()\n",
        "\n",
        "# Save the figure with high resolution\n",
        "plt.savefig('log_cumulative_regret_plot_paper.png', dpi=300)\n",
        "\n",
        "# Display the plot\n",
        "plt.show()"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 307
        },
        "id": "Rn26d6k8ANFk",
        "outputId": "3636cf5d-6580-4758-fbf0-77f2e2930e56"
      },
      "outputs": [
        {
          "data": {
            "image/png": "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",
            "text/plain": [
              "<Figure size 500x300 with 1 Axes>"
            ]
          },
          "metadata": {},
          "output_type": "display_data"
        }
      ],
      "source": [
        "import matplotlib.ticker as ticker\n",
        "import numpy as np\n",
        "import matplotlib.pyplot as plt\n",
        "\n",
        "# Assuming cu_regret1 and cu_regret2 are already defined arrays\n",
        "T = len(cu_regret1[0])  # Number of time steps, assuming cu_regret1 is a 2D array\n",
        "\n",
        "# Calculate mean and standard deviation of cumulative regrets\n",
        "mean_regret1 = np.mean(cu_regret1, axis=0)\n",
        "std_regret1 = np.std(cu_regret1, axis=0)\n",
        "\n",
        "mean_regret2 = np.mean(cu_regret2, axis=0)\n",
        "std_regret2 = np.std(cu_regret2, axis=0)\n",
        "\n",
        "# Create a mask to filter out points where mean regret is less than 100\n",
        "mask_regret1 = mean_regret1 > 100\n",
        "mask_regret2 = mean_regret2 > 100\n",
        "\n",
        "# Plot the average cumulative regret with error shading\n",
        "plt.figure(figsize=(5, 3))\n",
        "\n",
        "# Plot the mean cumulative regret for MNAR where regret is greater than 100\n",
        "plt.plot(np.arange(T)[mask_regret1], mean_regret1[mask_regret1], linewidth=2, label=\"MNAR\")\n",
        "\n",
        "# Add shaded area for error indication (±1 standard deviation), applying the mask\n",
        "plt.fill_between(np.arange(T)[mask_regret1],\n",
        "                 mean_regret1[mask_regret1],\n",
        "                 mean_regret1[mask_regret1] + 2 * std_regret1[mask_regret1],\n",
        "                 alpha=0.2)\n",
        "\n",
        "# Plot the mean cumulative regret for UCB where regret is greater than 100\n",
        "plt.plot(np.arange(T)[mask_regret2], mean_regret2[mask_regret2], linewidth=2, label=\"UCB\")\n",
        "\n",
        "# Add shaded area for error indication (±1 standard deviation), applying the mask\n",
        "plt.fill_between(np.arange(T)[mask_regret2],\n",
        "                 mean_regret2[mask_regret2],\n",
        "                 mean_regret2[mask_regret2] + 2 * std_regret2[mask_regret2],\n",
        "                #  mean_regret2[mask_regret2] - std_regret2[mask_regret2],\n",
        "                 alpha=0.2)\n",
        "\n",
        "# Set the y-axis to log scale\n",
        "plt.yscale('log')\n",
        "\n",
        "# Set the formatter for the y-axis to display in 10^n format\n",
        "plt.gca().yaxis.set_major_formatter(ticker.LogFormatter(base=10))\n",
        "\n",
        "# Add labels and grid\n",
        "plt.xlabel('Time Steps')\n",
        "plt.ylabel('Cumulative Regret')\n",
        "plt.grid(False)\n",
        "plt.legend(loc='upper left')\n",
        "\n",
        "# Adjust the layout for better spacing\n",
        "plt.tight_layout()\n",
        "\n",
        "# Save the figure with high resolution\n",
        "plt.savefig('log_cumulative_regret_plot_paper_filtered.png', dpi=300)\n",
        "\n",
        "# Display the plot\n",
        "plt.show()\n"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 307
        },
        "id": "TwCIKPEIAmob",
        "outputId": "1c2dad52-6195-40af-cea8-38bb9360d4e5"
      },
      "outputs": [
        {
          "data": {
            "image/png": "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",
            "text/plain": [
              "<Figure size 500x300 with 1 Axes>"
            ]
          },
          "metadata": {},
          "output_type": "display_data"
        }
      ],
      "source": [
        "import matplotlib.ticker as ticker\n",
        "\n",
        "# Calculate mean and standard deviation of cumulative regrets\n",
        "mean_regret1 = np.mean(cu_regret1, axis=0)\n",
        "std_regret1 = np.std(cu_regret1, axis=0)\n",
        "\n",
        "mean_regret2 = np.mean(cu_regret2, axis=0)\n",
        "std_regret2 = np.std(cu_regret2, axis=0)\n",
        "\n",
        "# Plot the average cumulative regret with error shading\n",
        "plt.figure(figsize=(5, 3))\n",
        "\n",
        "# Plot the mean cumulative regret\n",
        "plt.plot(mean_regret1, linewidth=2, label=\"MNAR\")\n",
        "\n",
        "# Add shaded area for error indication (±1 standard deviation)\n",
        "# plt.fill_between(np.arange(T),\n",
        "#                  mean_regret1 ,\n",
        "#                  mean_regret1 + std_regret1,\n",
        "#                  alpha=0.2)\n",
        "\n",
        "# Plot the mean cumulative regret\n",
        "plt.plot(mean_regret2, linewidth=2, label=\"UCB\")\n",
        "\n",
        "# Add shaded area for error indication (±1 standard deviation)\n",
        "# plt.fill_between(np.arange(T),\n",
        "#                  mean_regret2 ,\n",
        "#                  mean_regret2 + std_regret2,\n",
        "#                  alpha=0.2)\n",
        "\n",
        "# Set the y-axis to log scale\n",
        "plt.yscale('log')\n",
        "\n",
        "# Set the formatter for the y-axis to display in 10^n format\n",
        "plt.gca().yaxis.set_major_formatter(ticker.LogFormatter(base=10))\n",
        "\n",
        "# Add labels and grid\n",
        "plt.xlabel('Time Steps')\n",
        "plt.ylabel('Cumulative Regret')\n",
        "plt.grid(False)\n",
        "plt.legend(loc='upper left')\n",
        "\n",
        "# Adjust the layout for better spacing\n",
        "plt.tight_layout()\n",
        "\n",
        "# Save the figure with high resolution\n",
        "plt.savefig('log_cumulative_regret_plot_paper.png', dpi=300)\n",
        "\n",
        "# Display the plot\n",
        "plt.show()"
      ]
    }
  ],
  "metadata": {
    "colab": {
      "collapsed_sections": [
        "vGyT6Uz_IXD8",
        "10HvOjA73wnf"
      ],
      "provenance": []
    },
    "kernelspec": {
      "display_name": "Python 3",
      "name": "python3"
    },
    "language_info": {
      "name": "python"
    }
  },
  "nbformat": 4,
  "nbformat_minor": 0
}
