{
  "nbformat": 4,
  "nbformat_minor": 0,
  "metadata": {
    "colab": {
      "name": "Safety Changepoint Global (No threshold).ipynb",
      "provenance": [],
      "collapsed_sections": [],
      "toc_visible": true
    },
    "kernelspec": {
      "display_name": "Python 3",
      "name": "python3"
    }
  },
  "cells": [
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "iZ4Dxrq8ts9z"
      },
      "source": [
        "# Build Environment"
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "id": "LQw-yZPs1S51"
      },
      "source": [
        "import numpy as np\n",
        "\n",
        "class build_environment(object):\n",
        "\n",
        "  def __init__(self, K, threshold, T, trials):\n",
        "    self.K = K + 1\n",
        "    self.mu = None\n",
        "    self.mu_t = None\n",
        "    self.threshold = threshold\n",
        "    self.true_epsilon_arms = []\n",
        "    self.T = T\n",
        "    self.trials = trials\n",
        "    self.G = None\n",
        "    self.sig = .1\n",
        "    self.safe_arm = None\n",
        "\n",
        "    self.baseline = self.K - 1\n",
        "\n",
        "\n",
        "    \n",
        "    \n",
        "    self.best_arm = None\n",
        "\n",
        "  def find_safe_arms(self, mu):\n",
        "\n",
        "    safe_set = []\n",
        "    for k in range(0,self.K-1):\n",
        "      if mu[k] >= self.threshold:\n",
        "        safe_set.append(k)\n",
        "    \n",
        "    return safe_set\n",
        "\n",
        "  \n",
        "  def build_env1(self,):\n",
        "\n",
        "    self.changepoint_time = [int(self.T/4.0), int((2/4.0)*self.T), int((3/4.0)*self.T), self.T]\n",
        "    self.G = len(self.changepoint_time)\n",
        "    print( self.changepoint_time, self.G)\n",
        "\n",
        "    #self.safe_arm = 2\n",
        "\n",
        "    self.best_arm = np.zeros(self.G)\n",
        "    self.mu = np.zeros((self.G, self.K))\n",
        "    #self.time_change = np.zeros((self.G, self.K))\n",
        "    self.mu_t = np.zeros((self.T,self.K))\n",
        "    self.safe_arm_t = np.zeros((self.T,3))\n",
        "    \n",
        "    self.baseline = self.K - 1\n",
        "    self.mu_baseline = 0.35\n",
        "    \n",
        "    self.mu[0, :] = [0.2, 0.3, 0.5, 0.6, 0.65, self.mu_baseline]\n",
        "    self.best_arm[0] = np.argmax(self.mu[0])\n",
        "    self.mu_t[0:self.changepoint_time[0],:] = self.mu[0,:]\n",
        "    self.safe_arm_t[0:self.changepoint_time[0],:] = tuple(self.find_safe_arms(self.mu[0, :]))\n",
        "\n",
        "    self.mu[1, :] = [0.7, 0.65, 0.55, 0.3, 0.25, self.mu_baseline - 0.2] \n",
        "    self.best_arm[1] = np.argmax(self.mu[1])\n",
        "    self.mu_t[self.changepoint_time[0]:self.changepoint_time[1],:] = self.mu[1,:]\n",
        "    self.safe_arm_t[self.changepoint_time[0]:self.changepoint_time[1],:] = (self.find_safe_arms(self.mu[1, :]))\n",
        "\n",
        "    self.mu[2, :] = [0.2, 0.75, 0.52, 0.8, 0.3, self.mu_baseline] \n",
        "    self.best_arm[2] = np.argmax(self.mu[2])\n",
        "    self.mu_t[self.changepoint_time[1]:self.changepoint_time[2],:] = self.mu[2,:]\n",
        "    self.safe_arm_t[self.changepoint_time[1]:self.changepoint_time[2],:] = (self.find_safe_arms(self.mu[2, :]))\n",
        "\n",
        "    self.mu[3, :] = [0.65, 0.2, 0.55, 0.3, 0.7, self.mu_baseline - 0.2] \n",
        "    self.best_arm[3] = np.argmax(self.mu[3])\n",
        "    self.mu_t[self.changepoint_time[2]:self.changepoint_time[3],:] = self.mu[3,:]\n",
        "    self.safe_arm_t[self.changepoint_time[2]:self.changepoint_time[3],:] = (self.find_safe_arms(self.mu[3, :]))\n",
        "\n",
        "  def pull_arm(self, arm, t):\n",
        "\n",
        "    return self.mu_t[t][arm] + self.sig*np.random.randn()\n",
        "    \n",
        "# obj = build_environment(10, 0.1, 1000, 10)\n",
        "# obj.build_env3()\n",
        "# print(obj.mu)\n",
        "# print(obj.mu_t)\n",
        "# print(obj.pull_arm(1, 1))"
      ],
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "9tqOmBZmL8GZ"
      },
      "source": [
        "# Plot Environment"
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 758
        },
        "id": "5PEcHRG-uKsp",
        "outputId": "677df9bc-7016-4711-caf7-b71761e23ad8"
      },
      "source": [
        "import matplotlib\n",
        "import matplotlib.pyplot as plt\n",
        "\n",
        "\n",
        "env = build_environment(5, 0.4, 8000, 10)\n",
        "env.build_env1()\n",
        "print(env.true_epsilon_arms)\n",
        "\n",
        "plt.style.use('ggplot')\n",
        "plt.figure(dpi=200)\n",
        "# plt.plot([i for i in range(0,8000)], [env.threshold for i in range(0,8000)], '--', color='b', label = \"Threshold\")\n",
        "#plt.plot([i for i in range(0,8000)], [1.5*env.threshold for i in range(0,8000)], '--', color='b')\n",
        "#plt.plot(env.mu, 'ro')\n",
        "plt.plot([i for i in range(0,8000)], env.mu_t[0:8000, 0:env.K-1])\n",
        "plt.plot([i for i in range(0,8000)], env.mu_t[0:8000, env.K-1], label = \"Baseline\")\n",
        "\n",
        "\n",
        "plt.title('Global Changepoint Environment', size = 15, fontweight='bold')\n",
        "plt.ylabel('Means', size = 15, fontweight='bold')\n",
        "plt.xlabel('Rounds', size = 15, fontweight='bold')\n",
        "    \n",
        "plt.yticks(size = 15, fontweight='bold')\n",
        "plt.xticks(size = 15, fontweight='bold')\n",
        "\n",
        "#plt.ticklabel_format(axis='y', style='sci', scilimits=(0,0))\n",
        "plt.ticklabel_format(axis='x', style='sci', scilimits=(0,0))\n",
        "\n",
        "plt.legend()\n",
        "plt.grid()\n",
        "plt.show()"
      ],
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "[2000, 4000, 6000, 8000] 4\n",
            "[]\n"
          ]
        },
        {
          "output_type": "display_data",
          "data": {
            "image/png": "iVBORw0KGgoAAAANSUhEUgAABFwAAAMoCAYAAADybfSQAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAAewgAAHsIBbtB1PgAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4yLjIsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy+WH4yJAAAgAElEQVR4nOzdd3xTZf8//lfSJmkLnbQU6KBAGQUZBYSC1AICN8NCQRBFGYqIfh03CirKLSK34kJkKAoiIqAoCEK5oexVNrJbRpHRyWrT0p2mzfn9wa/9UJpzMpo0afp6Ph55PKDXua7zTk7OSc4715AJgiCAiIiIiIiIiIgsRm7rAIiIiIiIiIiIHA0TLkREREREREREFsaECxERERERERGRhTHhQkRERERERERkYUy4EBERERERERFZGBMuREREREREREQWxoQLEREREREREZGFMeFCRERERERERGRhTLgQEREREREREVkYEy5ERERERERERBbGhAsRERERERERkYUx4UJEREREREREZGFMuBARERERERERWRgTLkREREREREREFsaECxERERERERGRhTHhQkRERERERERkYUy4EBERERERERFZGBMuREREREREREQWxoQLEREREREREZGFMeFCRFa1b98+yGQy0Yc9mTVrlmicvXv3tnV4FjNhwgTR5zlhwgRbh2dRten9R2RrdeUaSLWD1LV73759tg6PiMgozrYOgIhsLzMzEwkJCUhNTUVmZiYKCwshl8tRr1491K9fH40aNUJoaCiaNWsGhUJh63DJgWk0GiQkJODatWu4efMmCgoKIAgC3N3d4enpidDQULRt2xZeXl62DpWIiIiISBITLkR11MGDB7FmzRps27YN165dM6qOs7MzwsPDERUVhSeeeAL9+vWDszMvI1Q9mZmZWLVqFTZu3IgjR45Aq9UarNOmTRsMHjwYw4cPR69evWogSiIicSEhIUhOTrZom3v37mXPIiKiWo5DiojqmNjYWHTs2BGRkZFYvHix0ckWACgtLcWJEycwd+5cDBo0CAEBAZgyZQoEQbBixOSoMjMz8eabbyIoKAhvv/02Dhw4YFSyBQAuXbqEefPmITIyEh07dsSOHTusHC0R2SMOOyEiR8ah0bUfEy5EdcTdu3cRExODYcOG4dy5cxZp886dO1iwYAHK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NTUVc+bMQYcOHYxa9t7FxQV9+vTBp59+irNnz+Ls2bP4f//v/9VAxObp2LEjEhMTsWrVKjz99NNo2bIlPD09jXquZFsyQRAEWwdBRLZ17do1XLx4EWlpabh37x40Gg1cXV3h7u4ODw8PBAcHIywszC667wP3V6s5f/48Ll68CLVajezsbKhUKvj4+MDf3x/du3c3KZFkrszMTBw+fBhpaWnIzc2Fv78/wsLC0L17d6PnKHlYYWEhDh48iKSkJOTk5MDV1RXNmzdHr169rJ7YsgcajQbnz5/HtWvXcPPmTRQUFEAQBLi7u8PT0xOhoaFo164dvLy8bB2q0er6MdUnMzMTwcHBKCoq0lv+xhtvYOHChWa1fe3aNZw9exZqtRpqtRolJSUV75+QkBCEhYUZndApFxISguTkZL1lP//8c5WVV86dO4fExESkp6dDLpcjICAAjz32mMFVrIxlL9dAorpOo9HgxIkTSE5OhlqtRm5ubsXCA8HBwXj00UeNGnJFlpWbm4vjx4/j5s2byM7ORm5ubsX32saNG6NNmzZo3rx5re91RbUDEy5ERERktszMTJPnGJk0aZLk6hJbtmyxq/keTE24EBEREQEcUkRERETV0K9fP4wcORLbtm0zuBKQWq3GSy+9JJls8fLyqrXz2RARERE9qHpTbRMREVGdVlpaivXr12P9+vXw9PREjx490KlTJzRp0gQeHh4oKirC7du3cfLkSezYsQMajUayvQ8//JBd8ImIiMghMOFCREREFnHv3j1s27YN27ZtM6t+eHg4Xn/9dQtHRURERGQbHFJERERENte6dWts27bNYZcuJiIiorqHCRciIiKyqZEjRyI+Pt7k1YOIiIiI7BkTLkRERGS2f/3rX/D09DS5nkwmQ9++fbFp0yasW7euzi6RTURERI6Lc7gQERGR2b7++mt89tlnOHToEA4dOoRTp07h6tWryMjIQH5+PrRaLdzd3eHp6Qk/Pz906tQJXbt2xYABA9CsWTNbh09ERERkNTJBEARbB0FERERERERE5Eg4pIiIiIiIiIiIyMKYcCEiIiIiIiIisjAmXIiIiIiIiIiILIwJFyIiIiIiIiIiC2PChYiIiIiIiIjIwphwISIiIiIiIiKyMCZciIiIiIiIiIgszNnWARCJEQQBOp3O1mEQERERERGRg5PL5ZDJZBZtkwkXsls6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0cLk+t9//73Bbby8vMwJjYiIiB4il3NBSiJTCYIAQRBsHQZZwbhx4zB+/PiK/wuCgJycHJw8eRI//vgjMjMz8eeff6JJkyZ47733bBipbaSnp9s6BIfDhIsJXF1dRRMuUomUB0lNYufm5mZWXIYkJSXhm2++EU0KhYWFISYmBi1btoSLiwtycnJw6tQprFu3Dvfu3auyfVFREb788kvMmzcP9erVMykWDhUiIiKqGaGhoRg8eLCtwyCqda5evYotW7bYOgyyAl9fX7Rp06bK33v06IEBAwZg0KBBKC4uxvLly/HWW29BqVTaIEpyJPzZwwRSCRFjhwNJ9TCxVsJl2bJlosmWrl274qOPPkJ4eDjq168PZ2dn+Pr6YsCAAfjkk09EEyrZ2dmIjY21SrxEREREREQ1qVWrVujbty+A+8PI/vnnHxtHRI6ACRcTSPXO0Gq1BlcZKigokOwJY43eH//88w9u3Liht0wmk2HChAmi3Y39/f0xZMgQ0bb3799viRCJiIiIiIhsLjg4uOLfJSUlVcqTk5Pxww8/YPz48ejevTtatGiBFi1aoFu3bnjllVewd+9eg/u4d+8eFixYgOjoaLRt2xZNmzZF+/bt0bt3b0ycOBG//PIL7t69K1q/uLgYP//8M55++ml06tQJISEh6NChA0aPHo01a9YYPfJCn4CAAAQEBODrr7+uUvbHH39UlKempkKn02H16tUYOnQo2rZti9DQUPTr1w8LFiwwajGYsrIyrF27FuPGjUPnzp3RrFkztGvXDjExMViyZInVF5SpKRxSZIKQkBCcPXtWtDw7O1uyl0p2drbB9i3twoULomWNGjVCw4YNJet36NABa9eu1VumVquRlZXFYUJERERERFTrpaWlVfy7fInkcikpKejZs6feeunp6UhPT8fmzZsxYsQIfPPNN3pXsb1y5QqeeeYZ3Lp1q9Lf1Wo11Go1rly5gm3btkGn0+GFF16oUj8xMREvvvhipTgBICsrCwcPHsTBgwexevVqrFixAn5+fkY/b1MVFRXh2WefxcGDByv9/eLFi7h48SJ27tyJtWvXit4bp6enY8KECVXuVUtKSnDixAmcOHECK1euxMqVK82aN9SeMOFigmbNmkmWp6amVjkxH5SSklKt9s0hlR318PAwWN/QNtnZ2Uy4EBERERFRrfbPP/9g165dAIDOnTtXSViUlZVBqVQiKioKjz/+OFq2bAlvb29kZ2fj2rVr+OWXX3D58mVs2LABTZs2xbRp06rs480338StW7egUCgwZswY9OnTBw0bNoROp8PNmzdx6tQpxMXF6Y3v+vXrGDlyJHJzc+Hu7o7x48cjPDwcTZo0QXZ2Nnbs2IHVq1fjzJkzeOGFF/DXX39BoVBY/oUC8M477+DUqVMYNWoUoqOj0bBhQ6Snp2Px4sU4efIkTp8+jQULFuD999+vUletViMmJgYZGRlQqVQYM2YMIiIiEBQUhIKCAuzfvx8//fQTbty4gbFjx2Lbtm1G3bfaKyZcTNC6dWvIZDLRWcv/+ecfREREiNa/cuWKaJlMJkPr1q2rHePDpFZPMjQECrg/DIqIiIiIqK6yxYpFgqCDpqzuLEetcqoPmcz6s11kZmbi0qVLFf8XBAG5ubkVqxQVFxfDw8MDs2bNqlLX398fR48ehb+/f5WyyMhIjBs3Dm+//TbWrl2LJUuW4OWXX66UKEhOTsa5c+cAAB999FGVHizh4eEYPHgwZsyYoXfhkilTpiA3NxePPPII1qxZAx8fn0rlUVFR6NevH8aNG4fTp09j7dq1eO6550x6fYz1999/Y+HChXjqqacq/ta+fXv06dMHgwcPxqVLl/Drr7/inXfeqdLTZ+bMmcjIyEBgYCDWrVtXaRgXAPTs2RPR0dEYPnw4kpOTsXjxYkyfPt0qz6MmMOFiggYNGqBt27ZITEzUW37s2DE899xzkMlkVcp0Oh2OHz8u2vYjjzxS5aR50KxZs0SHB0VFReG1117TWyaVDUxPT0dubq7kNg9ekExtn4iIiIiITKcpy8emy/q/3zuiYa2/g4uz9e8ryoep6COXyzF27FhMmjRJ7zAWNzc3yekjZDIZZs6cifXr16OwsBDx8fGV5sO8c+dOxb+7d+8u2Y6Xl1elvx07dgx///03AGD+/Pmi9419+vTBkCFDsHnzZqsmXAYPHlwp2VJOpVJhwoQJmD59OrKzs5GUlIS2bdtWlKemplYsvPLJJ59USbaUe+SRRzBhwgQsXrwY69atq9UJF06aa6KoqCjRstu3b2P37t16y3bu3Ck5vEeq3eqQmqNFp9OJzs8C3O/dIrUknkqlkkwSERERERER1QY6nQ6xsbFYuXKl5Mqy5bRaLTIyMnDlyhVcunQJly5dwu3bt+Ht7Q2g6lyaD/aMkboH02fHjh0AgBYtWiAsLExy2/IRF2fPnq3WBLpShg8fLlrWoUOHin8/PKXG7t27UVZWBldX14oVocSUJ6Vu3bqF9PT0akRrW+zhYqLHHnsMGzZsqDLRUbmffvoJJSUl6N+/PxQKBbRaLXbu3IlVq1aJttmkSRPRCZiqq1OnTpLDoHbs2AGtVovhw4ejUaNGAO5fbBITE7FixQpkZmaKtt2+fXu9k0ERERERERHZm7fffhtTp06t9LeioiLcuHED69evx48//ohly5bh3Llz+O233+Dq6lppW61Wi19//RV//vknEhMT9a5kVE6tVlf6f3BwMLp3745jx47hxx9/xP79+zF48GD06NEDXbp0qbKvB5Uv3HL16lXJOUMfjjUnJwe+vr5GbW+K0NBQ0bIHe+fk51ceFlf+PIqKikR7t+hz584do5+3veHdsokUCgUmTpyITz/9VG95WVkZVqxYgVWrVsHT0xP37t2TnEcFAF566SWrJS58fHzQsWNHnDlzRnSbvXv3Yu/evXB3d4eLiwtyc3ONyuo+8cQTlgyViIiIiIioRrm6uiIsLAz/+c9/0KxZM7z77rs4fvw4Fi5ciPfee69iu+zsbIwZM6ZiHhZDiouLq/ztu+++w+TJk3Hy5EkkJSUhKSkJ8+fPh0KhQOfOnRETE4Onn34aLi4uleplZWWZ9dystbSyVHJILv+/QTQP3wdL/ZgvpTYvEc2Eixk6duyIfv36VcxirU9ZWVmVrKY+//rXv/DII49YMrwqJkyYgGnTphnsUpaXl4e8vDyj2uzYsSO6dOliifCIiIiIiOgBKqf6GNb6O1uHUWNUTvVtHQIA4Nlnn8WcOXOQk5ODP/74o1LCZebMmRXJloEDB2L06NFo27YtGjRoABcXl4p5PB999FFkZGToHWHQuHFjxMbGIj4+HnFxcTh69CiSkpKg1Wpx7NgxHDt2DEuWLKmyHHJ54qJt27ZYtGiR0c+nfASDvdDpdADudwpYt26d0fVM6Q1jb5hwMdPEiRORn5+Po0ePmt3GY489pnd9dUtr0qQJpk6diq+//toi4/iaN2+OKVOmWCAyIiIiIiJ6mEwmr5FJZKkyuVyOZs2a4fTp07h9+zbUajV8fHyQl5eHzZs3AwBGjBghmfTQt8LQwyIjIxEZGQng/tCj+Ph4/Prrrzh06BBu3LiBV199tWLeFgAV88IUFhaiTZs21XmKNlX+PAoKCtCyZUs4OTnZOCLr46S5ZnJycsKUKVPwzDPPmDwcqHzd9TfffLNSlytr6tKlC2bNmoWmTZua3YZMJkP//v0xc+ZM1KtXz4LRERERERER2d6Dw2DK/339+nVotVoAQHR0tGjdf/75BwUFBSbtz8fHB8OGDcPatWsxYMAAAEBiYiKuXbtWsU35iIjk5ORKqx3VNuXPQ6PRVMzn4uiYcKkGuVyOESNGYMGCBRg4cCDc3d0lt3d3d8fAgQMxf/58xMTE6F0+2ppatWqFL774Am+//Ta6du0KpVJpVL0GDRrgySefxFdffYVJkyZJLodGRERERERUGxUVFSEpKQkA4OLiUrEi64OjBKTmExFbctpYvXr1qvj3g9NTlCdiBEHATz/9VK192FK/fv0q7oGXLVtm42hqBocUWYCfnx9efPFFTJgwASkpKUhJSUFOTg5KSkqgVCrh5eWFoKAgNG3a1OweLbNmzbJIrHK5HBEREYiIiIBOp0NGRgZSU1ORl5eH4uJiaLVauLi4wNXVFT4+PmjatGlF1y8iIiIiIiJH9fXXX1dMdtu7d++KIS8hISEVK7+uW7cOQ4cOrfLj+Y4dO7BixQrRthMSEgBAdP5OQRAQHx8P4P7IgqCgoIqyqKgohIeH4/Tp0/j+++/Rrl07DB06VHRfFy9eRGpqakWixl6EhobiySefxObNm7Fp0yZ07NgRkydPFt0+JSUFp06dQkxMTA1GaVlMuFiQXC5HSEgIQkJCbB2KUeRyOQIDAxEYGGjrUIiIiIiIiKwqMzMTly5dqvQ3jUaD69ev488//8TevXsB3O/dMm3atIptfHx80LdvX+zevRt79+7Fs88+i3HjxiEwMBCZmZnYunUr1q5di+DgYOTm5updVSgxMRFvv/02OnXqhH79+qF9+/Zo2LAhtFotUlNT8ccff+DAgQMA7vdo8ff3r1T/22+/xZAhQ5CTk4NXX30VGzZswNChQ9GsWTM4OTkhMzMTCQkJ2LlzJ06dOoXJkyfbXcIFAD777DOcO3cOycnJmD17Nnbs2IGRI0eiVatWUKlUUKvVuHDhAvbt24dDhw5h4MCBTLgQERERkX2p6aHLRET2buXKlQaH/TRo0ACLFi1CWFhYpb9/9tlnGD58ONLT0xEfH1/RG6VcQEAAli9fjrFjx0q2f+bMGZw5c0a0vGvXrpg7d26Vv4eEhCA2NhYvv/wyLl26hJ07d2Lnzp2i7Ria7sJWvL29sXHjRrzyyis4duwYjh49KrkQjb0+D2Mx4UJERERERER1UvkUEK1atULfvn0xevRoeHl5VdkuICAA27Ztw+LFi7F9+3akp6dDpVIhMDAQAwcOxMSJE/XWKxcTEwM/Pz8cOHAAZ8+exa1bt3D37l2UlZWhQYMGaN++PYYOHYphw4aJTkPRokUL7NixA5s3b8aWLVtw9uxZZGVlQafTwdvbG82bN0e3bt0waNAgtG/f3mKvkaU1bNgQGzZswK5du7Bp0yacPHkSd+7cQWlpKTw8PNCsWTN06dIFAwYMQEREhK3DrRaZoG+BcCI7UFZWhtu3b9s6DCIiolrh6NGjOH78eMX/W7ZsiUGDBtkwIqLa6erVq9iyZUvF/z09PTF+/HiLtV9a1dlQsQAAIABJREFUWoqcnBx4eXmZvNopERnHnPPM39/f4ktVc5UiIiIiIiIiIiILY8KFiIiIiIiIiMjCmHAhIiIicgAcJU5kHTy3iMhcTLgQEREREREREVkYEy5ERERERERERBbGhAsREREREdH/TyaT2ToEInIQTLgQEREREREREVkYEy5ERERERERERBbGhAsRERERERERkYUx4UJEREREREREZGFMuBAREREREdUwQRBsHQKRw7KX84sJFyIiIiIiohpSvgqSvdwQEjmi8vPL1quOMeFCRERERERUQ+Ty+7dgpaWlNo6EyHFptVrIZLKK881WmHAhIiIickC2/lWPiPSTyWRQKBQoKSmxdShEDkkQBGg0GiiVSpt/FjLhQkREREREVINUKhVKS0tRXFxs61CIHIogCMjLy4NOp4OLi4utw4GzrQMgIiIiIiKqS1xcXFBaWor8/HyUlJRApVJBLpfb/Nd4otpIEAQIggCtVguNRgOdTgd3d3coFApbh8aECxERERERUU2rV68enJycUFxcjLy8PFuHQ1TryWQyKJVKuLi42EWyBWDChYiIiIiIqMbJZDK4urrCxcUFOp2OqxYRVUP5BLn21kuMCRciIiIiB8CbNaLaSSaTwcnJydZhEJEVMOFCRERE5AAeTrccSs7Fij+SbBILUW3mrbmDsAf+X6ZjMpOIzMOECxEREZEDSM+tvMRsmQAUlepsFA1R7eVWVjnBkldSZqNIiKi247LQRERERA4gt5g3hUTWUMoeLkRkJiZciIiIiByAUGVQEREREdkShxQREREROSAvF2d8+a+mtg6DqNY5kaiB+qytoyAiR8CECxEREZEDUjjJ0NrX1dZhENU611wVUNs6CCJyCBxSREREREREJIaj9YjITEy4EBERETkC3hQSERHZFSZciIiIiBwA8y1ERET2hQkXIiIiIiKicjJbB0BEjoIJFyIiIiIiIiIiC2PChYiIiMgB8Ud6IiIi22LChYiIiMgRMeNCRERkU0y4EBERETkAgdPmElkEc5VEZClMuBARERERERERWRgTLkRERESOgB1ciIiI7AoTLkREREREREREFsaECxEREZEDqNrBhTNREBER2RITLkREREREREREFsaECxEREZEDYv8WIiIi22LChYiIiIiIiIjIwphwISIiIiIiIiKyMCZciIiIiByAwGWhiSyi6nA8nlxEZB4mXIiIiIgcQuWbQs7hQkREZFtMuBARERERERERWRgTLkREREQOoMqgB3ZxITITTx4isgwmXIiIiIiIiIiILIwJFyIiIiIiIiIiC2PChYiIiIiIiIjIwpxtHYAj0el0SElJQVpaGtRqNUpKSqBUKuHt7Y2goCAEBwdDLmeOi4iIiIiotuCMLkRkLiZcLCAzMxObN2/GwYMHkZeXJ7qdu7s7evXqhejoaPj6+tZIbPv27cPixYut0vbIkSPx9NNPW6VtIiIiMs3Dk+byJpHITDx5iMhCmHCpBkEQEBsbi7Vr10Kr1RrcPi8vD3Fxcdi1axdGjx6N6OhoyGS8ohMREZEFcJkiIiIiu8KEi5l0Oh0WLVqEQ4cOmVxXq9Vi9erVSE5OxmuvvcZhRkRERGQBVTIuREREZEO80zfT8uXLzUq2PCg+Ph6//PKLhSIiIiIiegA7uBAREdkUEy5mOH/+PHbs2CG5jZOTE3x8fODk5CS5XVxcHC5cuGDJ8GpMcHCwrUMgIiIiIiIiskscUmQirVaLZcuWiZY7OTlh7Nix6NevH5RKJbRaLXbv3o2VK1eitLRUb50ff/wRX331FZydLX84wsLC8Prrr5tVd8WKFcjPz9db5ufnh27dulUnNCIiIrIggSOKiIiI7AoTLiY6fPgwbt68KVo+ceJE9OvXr+L/CoUCAwcOhEKhwJIlS/TWSU9Px5EjRxAZGWnxeP39/eHv729yvcTERNFkCwAMGjSIc88QERHZMY4oIiIisi3eMZto//79omWNGjXCE088obesb9++aNSokWjdffv2VTc0i9qyZYtomaurK/r27VuD0RARERERERHVLky4mCArKwuJiYmi5REREaLLPMtkMnTv3l20bkJCAtRqdbVjtITbt2/j5MmTouW9e/eGm5tbDUZEREREREREVLsw4WKCy5cvQ5AYIB0aGipZX6pcEARcvnzZ7NgsKS4uTvR5ymQyDBo0qIYjIiIiIiKqGRyOR0SWwoSLCa5fvy5ZHhgYKFkeFBRUrfZrQlFREfbu3Sta3qVLF8mhUURERGQbVX4q4V0jkXlEeqwTEZmKCRcT3LhxQ7Lcx8dHstzb27ta7deEvXv3oqioSLT8ySefrMFoiIiIiIiIiGonrlJkgqysLNEypVIJFxcXyfqurq5QKBTQarUmt18TdDod4uLiRMubNWuGtm3bVmsfxjxHLy8vODk5VWs/RFR7CBoNhK3rIKRes3UoRLWaoAh56C/8lZ7IXF4upejVogDermXQyeTwzFhh65CIHEJ+g4EoU9WdERNMuJigsLBQtEylUhnVhkqlEk24SLVfE06ePInbt2+Llg8ePLja+3j11VcNbvP999+jQYMG1d4XEdUOwpolEA7tsnUYRLVfWMPK3+y0JTYLhah2EzD20Wz4u5f+358K7WOuRaLartA7CmW2DqIGcUiRCaSG2jg7G5e7UigUZrVfE7Zu3Spa5uXlhccee6wGoyGiukK4fN7WIRA5phKNrSMgqpVcZMWVky1ERGZiDxcTaDTiX1yMHQIjtV1xcbHJMVnKjRs3JJe8HjBggNFJJSnff/+9wW28vLyqvR8iqkXK6tLvHEQ1RyaxsiIRiZNDZ+sQiMhBMOFiApVKJdoLpczIG4bSUvFsubHDkqxBqneLQqHAgAEDLLIfDhUiIkNkvf4/9u4+PKr6zv//a2YyuSOB3EJAEgKiIERFpEAJGJUotEq7tVas1laFrVpa126vtt9evdzSumy3S9e9vGmpoi4C66+lrbagotwoKIGC6KKYSAA1hHuBJBASwkxm5veHlSVk5mTm5MycM8PzcV17Xc75nPOZN2UPM/M6n5vrpJIL7C4DSD47W6QQ04iAeDhZUC25Io9UBxCdQJrxRjKphsAlBllZWREDF6Mg5WyR1m+RpOzsbFN19dbx48dVU1MTsX3KlCnq27dvAisCcD5zXVkpV8VYu8sAks9Hi6XIXzMA9MKpfpUKeYw3yACAc7GGSwyMApFopwMZTUuyK3BZvXq1YRB0ww03JLAaAABgCTYpAkzi5gFgDQKXGBhNh/H7/T3uMtTW1mY4EsaO6TadnZ1atWpVxPbLLrtMpaWlCawIAACYwYotAAA4C4FLDMrLyw3bm5ube9XeU//xUFNTo5aWlojtVmwFDQAAEo9n9IA53DsArELgEoOhQ4catu/du9ewvbGxsVf9x4PRYrmDBg3SFVdckcBqAAAAAABIDQQuMRgxYoRcrsiZ9+7duw2v37VrV8Q2l8ulESNGmK7NjLq6On388ccR27/4xS8a/nkBwBJsXQsAAIAUxC5FMSgsLNSoUaNUW1sbtn3z5s26/fbbw4YUwWBQW7Zsidh3RUWFCgoKIrbPnTtXdXV1Yduqqqo0Z86cHqrvzmh0S05OjqqqqmLuEwAAAEg5PIMEYAIjXGJkFEIcPnxYa9euDdu2evVqHTlyxFS/8fDJJ59o69atEdurq6uVkZGRwIoAAEBvhPhFCACAoxC4xKiyslIlJSUR259++mm9/PLLZ7ZZ9vv9evnll7Vo0aKI1wwaNEiTJk2yulRDr7zyioLBYNg2j8ej6dOnJ7QeADiDqYwAAABIAUwpipHX69WsWbM0b968sO2BQECLFi3SkiVL1K9fPx0/flyBQMCwz9mzZystLXF/FR0dHXrttdcitk+cONFwehMAAHA+okvAHHJ/AFZhhIsJl19+uaqrqw3PCQQCampq6jFsmTZtmioqKqwsr0evv/662tvbI7bfcMMNCawGAAAAcBIWcwdgDQIXk2bNmqWJEyf2qo/KykrdddddFlUUnVAopJUrV0ZsHzFihIYPH57AigAAAAAASD0ELiZ5PB498MADuvXWW2OeDuT1enXbbbfp/vvvl9ud2L+Ct99+W4cOHYrYzugWAInHk0TACtxJQDwxzwhA7FjDpRfcbrduuukmTZkyRStWrFBNTY1aW1sjnp+bm6vKykrNmDFDxcXFCaz0/xiNbikuLtb48eMTWA0AAAAAAKmJwMUCxcXFuvvuu3XnnXeqsbFRjY2Namlpkc/nU3p6uvLy8lRaWqohQ4aYHtEyd+5cS2p98MEHLekHAAA4G8/jAQCwF4GLhdxut8rLy1VeXm53KQAAAAAAwEas4QIAcBYeywOmsIYLAADOQuACAAAAAABgMQIXAACAlMDwMAAAnITABQAAAAAAwGIELgAAe7HwBGCJ7rcSNxcAAHYicAEAAEhBTDACAMBeBC4AAAAA8HcuRocBsAiBCwDAYXguDwAAgORH4AIAAJCSCC8BU1zcOwCsQeACAACQgvjJCFgnxB0FwAQCFwAAAAD4O6IVAFYhcAEAAAAAALAYgQsAwGbsBgFYofuUB+4tAADsROACAAAAAABgMQIXAAAAAAAAixG4AACche04AZOYQgQAgJMQuAAAAKSA0DlhJdElAAD2InABAAAAAACwGIELAAAAAACAxQhcAAAAAODvWEoMgFUIXAAA9gqx0CcAAABST5rdBQDJyHP6oDLa6u0uA0gJwStydNBdogZfnj7cn6nQIY9cgWN2lwUknTZXujLOes1DesA6wVdfkEI8qwZ6yzXharkKi+0uI2EIXAATvKf3K6fpVbvLAFLDxH7qK2mEWrX6WKH+ZXeadOCI3VUBSecil1cFdhcBpKjQ8uekTkZkAr3lGn6JdB4FLsS0AADHuKZgjzLcnXaXAaQERrgA5oT8PrtLAJAiCFwAAI6R5gopwxWwuwwgJeS7/XaXACSnTj6HAFiDKUWACYG0PJ3OvsTuMoCk5wr5lX5qd5djF2YHldY3x6aKgOSVsaOty+u+hJeAKWF3KRo1RnJ5E14LkHL65NpdQUIRuAAm+LOH63j2cLvLAJKeu7NVRQ3/1uXYV0s6den4wTZVBCSvddsP6j2l210GkJLcd39frj55dpcBIMkwpQgAAAAA/i78+kesigQgdgQuAAAAAAAAFiNwAQAAAAAAsBiBCwAAAACcEbK7AAApgsAFAOAwzJMHAABA8iNwAQDYJuwzRPIWAAAApAACFwAAAAAw4uJpAIDYEbgAAAAAAABYjMAFAAAgJbHwJwAAdiJwAQA4DD8SAQAAkPwIXAAAjsIseQAAAKQCAhcAgMMQuQAAbMTHEACLELgAAGzEt1rAKiF2UQEAwFEIXAAAAFIQ8QtgTth7h0ATgAkELgAAAAAAABYjcAEAAAAAALAYgQsAwFEYtQ0AAIBUQOACAAAAAABgMQIXAIB9GM0CAACAFEXgAgBwGFIYAAAAJD8CFwAAAAD4u/CxPw8DAMSOwAUA4Ch8pQUAAEAqIHABAAAAAACwWJrdBaSSYDCoxsZG7du3T01NTfL5fEpPT1d+fr5KS0tVVlYmt9uZGVcgEFBDQ4MOHjyolpYWnT59WmlpacrIyFBhYaH69++vCy64QGlp/L8MAAAAAAA94dezBY4ePaoVK1Zow4YNam1tjXhebm6uJk+erBkzZqioqCiBFUb23nvvae3atXrnnXd0+vRpw3O9Xq+GDRumMWPGaNKkSRo4cGCCqgSQuphABMRNyO4CgOTk4uYBYBECl14IhUJavny5li1bJr/f3+P5ra2tWrlypdasWaOZM2dqxowZcrns+bGxb98+LVy4UB988EHU1/j9ftXX16u+vl6HDh3SnDlz4lghAAAAYIOweQsPCADEjsDFpGAwqMcee0w1NTUxX+v3+7V06VLt2bNHc+bMSfg0o40bN+q3v/2tfD5fQt8XAAAAcDyyFQAWceaCIkngmWeeMRW2nO3NN9/Us88+a1FF0XnjjTf0yCOPELYAcCyXi6HcAACHsWlUOoDkRuBiwvbt27Vq1SrDczwejwoKCuTxeAzPW7lyperq6qwsL6I9e/bod7/7nUKhnn/MZGVlqaioSP369evxzwAAAJyH34eASdw7ACzClKIY+f1+PfXUUxHbPR6P7rjjDlVXVys9PV1+v19r167V4sWL1dnZGfaahQsXav78+XHdAaizs1OPP/54xBokadiwYfriF7+oSy+9VPn5+V2uPXDggHbs2KFt27bp3XffjVudAAAAAACkAgKXGG3cuFEHDx6M2D5r1ixVV1efee31ejV9+nR5vV498cQTYa/Zv3+/Nm3apClTplhe72defPFF7dmzJ2L7Lbfcoq9+9athF/FNS0tTWVmZysrKdP311+vkyZM6cOBA3GoFAAAA7MIAFwBWYUpRjNavXx+xraSkRFOnTg3bdu2116qkpCTitevWrettaREFg0G9+uqrEdtnzJihm2++Oeodk3JycnTxxRdbVR4AAAAAACmHwCUGx44dU21tbcT2iRMnRgwtXC6XJkyYEPHa999/X01NTb2uMZy33npLx44dC9uWn5+vmTNnxuV9AcAMniwCAGwVxXqHABANApcY1NfXGy44O3z4cMPrjdpDoZDq6+tN12Zk06ZNEduuueYapaenx+V9AQAAAAA4X7GGSww+/vhjw/bBgwcbtpeWlvbY/+c///mY6+rJrl27IrZdccUVCgaDevvtt/XWW29p586damlpkc/nU25urgoKCnTJJZdo3LhxGjVqlOW1AQAAAM7H+EsAsSNwiUFDQ4Nhe0FBgWH72Tv/mOnfjJaWFh05ciRie2trq77//e+HXQi4ublZzc3N+vDDD/Xiiy9qxIgRuuuuuzRs2DDL6wQAAAAAIJUQuMQg0jookpSenq7MzEzD67OysuT1euX3+2Pu3yyjnYkkaf78+YbTpM5WX1+vBx98UPfcc4+uuuoqK8pLWu3t7WppabG7DCDpeUKnVGx3EUDK4Ak8AABOQuASg/b29ohtGRkZUfWRkZERMXAx6t+skydPGrZHG7Z8xu/36ze/+Y2ys7M1bty4mOuJJlTKy8uTx+OJue9Eamho0Jo1a+wuA0h6Wd6gLr3O7ioAAAAA6xG4xODUqVMR29LSovuf0uv1murfrLa2Nsv7DIVCeuyxx/Rf//VfPU6jOtd9993X4zkLFixQYWGh2fIAJLlgMGh3CQAAAECvEbjE4PTp0xHboh2RYXReR0dHzDX1JNrAxev1qqqqSsOGDVMwGNTOnTtVU1OjQCAQ9vxTp07p+eef1+zZs60sFwAi/rsDIEbsbAsAgK0IXGKQkZERcRRKtD8QOjs7Dfu3msvV83zuPn366Oc//7nKysrOHLv++utVXV2thx56KOIUqNdff13f/OY3Y9pWesGCBT2ek5eXF3V/dnG73XH5+wLON15P938To/hnCwAAAHA8ApcYZGVlRQxcjIKUs0UKLyQpOzvbVF1GounzK1/5Spew5TMjR47UtGnT9OKLL4a9zu/3q66uTmPGjIm6nlSZKjRy5EiNHDnS7jKApHeq9ah0+D/tLgMAAGM8DABggtvuApKJUXgR7XQgo2lJ8QhcsrKyejxn0qRJEdsqKysNr/3oo49irgkAAAAAgFRH4BIDo9EZfr+/x12G2traDEfCxGP0R9++fQ3bMzMzVVRUFLG9tLTU8PoTJ06YqgsAIuEhIgDATi4WQAJgEQKXGJSXlxu2Nzc396q9p/7NGDJkiGF7nz59DNvT09MNd1by+Xym6gIAANY69yci4SVgVri7hzsKQOwIXGIwdOhQw/a9e/catjc2NvaqfzPy8vIMt26OZu0Zo3Nyc3NN1QUAAAAAQCojcInBiBEjDHf92b17t+H1u3btitjmcrk0YsQI07UZueiiiyK2tba2Go5SaWpqUigUeVhlv379elUbgPNb2H9TeYgIAACAFMAuRTEoLCzUqFGjVFtbG7Z98+bNuv3228P+gAgGg9qyZUvEvisqKgxHosydO1d1dXVh26qqqjRnzpyI106ePFmbN28O2xYMBlVfX69LL700bHuk9/xMvEIiAADQW6xDAQCAnRjhEqOqqqqIbYcPH9batWvDtq1evVpHjhwx1W9vXXnllYZTf5YvXx72eCAQiLgltPTpdKJ4TIMCAAAAHMVglDsARELgEqPKykqVlJREbH/66af18ssvy+/3S/p096KXX35ZixYtinjNoEGDDLdm7q20tDTdcMMNEdvfffddPf7442pqajpz7JNPPtGvf/1rw22fp0+fLreb/xcC0Bt8gQUAOAufTACswpSiGHm9Xs2aNUvz5s0L2x4IBLRo0SItWbJE/fr10/HjxxUIBAz7nD17ttLS4vtX8aUvfUkbNmzQvn37wra/8cYbevPNN5WXl6dgMKjjx48b9te3b1/DEAcAAABIGYxwAWACwxNMuPzyy1VdXW14TiAQUFNTU49hy7Rp01RRUWFleWGlpaXpvvvuM9ziORQKqbm5ucewxePx6J//+Z+VnZ1tdZkAAMAq/D4EzOHeAWARAheTZs2apYkTJ/aqj8rKSt11110WVdSziy66SN///vcNQ5eeeL1effe739WoUaMsrAwAzuJioU/AFJ7AAwDgKAQuJnk8Hj3wwAO69dZbY54O5PV6ddttt+n+++9P+Boo48aN0y9+8QsNGjQo5msHDhyohx56SJWVlXGoDAAAAHACgn8A1mANl15wu9266aabNGXKFK1YsUI1NTVqbW2NeH5ubq4qKys1Y8YMFRcXJ7DSri688EL9+te/1rp167R69Wp9/PHHEc91u9268MILNX36dFVWVrJILgAAAAAAUSBwsUBxcbHuvvtu3XnnnWpsbFRjY6NaWlrk8/mUnp6uvLw8lZaWasiQIaYDi7lz51pac1pamqqrq1VdXa3m5mZ9+OGH+uSTT9TR0aG0tDTl5uaqoKBAF110EWu1AIgbniECccQNBpgSfnIeU/YAxI7AxUJut1vl5eUqLy+3u5SY5Ofna9y4cXaXAQAAAABAymB+CADAWXgqDwAAgBRA4AIAcBiGbQMAACD5EbgAAByFnW0BAACQCghcAAC2cZGuAJZhNh5gEW4mABYhcAEA2IjABQAAAKmJwAUA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OdJ0+2FYIzc3V4sWLdLatWtrPErsu+++03fffaekpCTdc889PneFbWwIXIAqwsLCDEehuFwuv/qorKw07R/AhYqLi/X4449r7969hscMGjRIt9xyS/0VhYDk5eXp2Wef1dGjR3XDDTcEu5wmxeVy6cUXX6z2u6hPnz668sorg1QV/NGxY0d16dJFSUlJio6Ols1mU15ennbv3q3t27ebfjnxeDxatGiR+vXrx2LhFvFnVyGHw6GHH35Yffv2veD1q666So8++qiKioq8nvftt98qKyuryT6pb4g+//xz03Xf2Aq67u3evVvz5883vC78deTIET366KN68MEHz+8W1hQQuABVREREGAYuZkFKVWY/9CMjIwOqC2iqcnNzNW/ePB0+fNjwmH79+umBBx7gy0Y9u/fee88vmut2u1VSUqLs7Gx99913pjsUSdL777+v5ORkDRs2rD5KbRaWLFlSbae7sLAw3XXXXWxL28DYbDZ169ZNY8eO1eDBg9WyZUvDY48cOaLnnnvO9JrKzMzUtm3bmtQ2qcHkz73Y+PHjq4UtktShQwdNmTJFr7zyiuG527ZtYwpLPamsrNTy5csN2y+99FJ16tSpHitqfrKzs/XHP/7R8PtTcnKyfvKTn6h3796KiopSUVGRtm/frnfffdfrrlKVlZV6+umn9eSTTyoxMbGuy68XBC5AFZGRkcrNzfXa5u90ILNpSQQuwP85fvy45s6dq5MnTxoeM2DAAP3qV78yXRsJdcNsWtD+/fv117/+1XSr+4ULF2rIkCEEZRbIzc3V+++/X+31n/3sZzxJb4BuvvlmRUdH+3VsUlKSZs2apZkzZ+r48eOGx23dupXAxSIRERE+jzGbvjp8+HDTwMVXIA3rrF27Vvn5+YbtjG6pe6+99pph2NKtWzfNmTPngrXd4uPjNXr0aA0cOFAzZ870GrqUlZXp7bff1n333Vdnddcn7oKAKsyeQlVUVPjcZej06dOmI2HM+geakwMHDujRRx81DVt+8IMf6KGHHmIR1gaoa9eumj17tlq3bm14zMmTJ5Wenl6PVTVdhYWF1X63xMTEKCoqSl999ZXh/woKCgz7zM7OrnY8rOFv2HJOZGSkpk6danrM999/X5uSUIU/63mYLfoZGxuruLg4w/bCwsKA6kLNmS2W265dO0LKOpaXl6fNmzcbtt90002G93DR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C1skyW63a/Lkyef//N1339VZLUwpAgAAQedrJIM3TqdT4eHhioyMVJs2bdShQwddcskl6t+/v8LDw+uoUgAAUNfKy8v15ZdfatOmTTp8+LCKi4sVFRWl5ORkjRgxQmPGjPEZrJiJiIg4/98VFRVWlOwVgQsAAGiUKioqVFFRoaKiImVlZWn79u1atmyZnE6nxo8fr+uvv75OF8IDAADWO3jwoJ544gmdPHnygtcLCwu1Y8cO7dixQ8uXL9dvfvObgEfTrF279vx/t2/fvlb1miFwAQAATUpFRYWWLVumDRs26JFHHlFSUlKwSwIAAH44ceKEZs+erZKSEkVERGjixInq3r27WrVqpaKiIm3evFlffPGF9u3bpyeeeEJz5sxRSIh/sUZhYaFOnDihFStWaNWqVZKkmJgYjRo1qs7+PgQuAACgScrLy9OcOXP0zDPPKCoqKtjlAAAAH55//nmVlJSoS5cuevjhhxUbG3tBe2pqqgYNGqTHH39ce/fu1apVqzR+/HjD/mbPnq309HSvbTExMXrooYfq9B6BRXMBAECTVVBQoHfffTfYZQAAAB++++477d69W5I0Y8aMamHLOf3799ewYcMkSatXrw7ova666io9/fTTSklJCaxYPzHCBQAANHgdOnTQj370o/N/rqioUG5urrZv337+5szImjVrdPPNN8tu5zkTAAAN1ebNmyWdXVOlU6dOpsdecsklWr9+vTIyMky3gb7nnntUWloqSTp9+rT27dun5cuX69NPP1VWVpbuuuuuOt1VicAFAAA0eHFxcRo9enS116dMmaJly5bpH//4h+G5hYWFyszMVOfOneuwQgAAUBv79++XJB07dkw//elP/TrH5XKpuLhYcXFxXtsTExMv+PMll1yiCRMm6KmnntI333yjmTNnau7cuWrZsmXtijdA4AIAABq1q666Sl9++aUOHTpkeExubm5AgUtpaakyMjKUm5ur4uJilZaWKjIyUtHR0WrTpo26dOni92J9jY3L5dLu3buVlZWl/Px8RUREqGXLlurdu3et57uXlZUpPT1dJ0+eVElJieLj45WYmKiUlJQ6G4lUXFyso0eP6vjx4yopKVFpaalsNpvCwsIUGxurVq1aqW3btnX6pBMAYKygoCCg88rKymp0fGhoqO655x7NmDFDOTk5WrRokf7f//t/Ab23L03zDgEA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/fv3V1pamuExvhbfBQDAGwIXAADQ6E2ePNl0jZF169Z53QJ64MCBpv2+/PLLhlN8srOzvW49fE5oaKjXXW5CQ0NNp9sYhQwFBQVauHChab0NTb9+/QzbKioq9Prrrxu2f/zxx4br7/jy5ptvauPGjaqsrPT7nNOnTxu2mU05AgDACIELAABo9Nq3b6/LLrvMsN3tdutf//pXtddTU1NNR2Hs3btXjz32mPbs2XN+JEtlZaU2btyoWbNmmX5JnzBhgqKiory2mb3njh079PLLL5/v2+12a9u2bXr00UcNt59uqMaNGyeHw2HY/tVXX+l//ud/LhhBUlhYqLfeekuLFi0K+H137dqlJ598UrfffrueeuopffHFF8rIyPA6XauwsFAfffSRPvroI8P+4uLiAq4FANB8sYYLAABoEq699lpt2rTJsH316tWaMmWKWrRoccHrU6dO1bx58wynBu3Zs0e///3vFRERoaioKBUUFBgutHtOVFSUJk+ebNjev39/bd++3bD9s88+0xdffKH4+HgVFxc32hEWCQkJGj16tFauXGl4zNq1a7V27VrFxsbK4XAoPz/fsq2vT58+rQ0bNlywqHJ4ePj5BZPPnDmjoqIin/307NnTknoAAM0LI1wAAECT0KNHD/Xu3duwvbKyUh9++GG11/v166cpU6b47P/MmTM6deqUz7DF4XDogQceUHx8vOExY8aMUVhYmGk/LpdLOTk51cIWp9Pps9aG5KabbjL9tzinsLBQeXl5F4QtRiOEaqO0tFR5eXnKzs72O2xJSkqyvA4AQNNH4AIAAJqMa6+91rR9xYoVXhdqvf76600XTfVXaGioZsyYoUsvvdT0uJiYGN1444017n/AgAG65pprAi0vKKKjo/XAAw/4DJguFhkZqRkzZtRRVf6JiIjQXXfdFdQaAACNF4ELAABoMgYMGKDk5GTD9rKyMn3yySde22666SY9+OCDfo3G8CY5OVnz5s3TyJEj/Tr+6quv1oQJE/zu//LLL9eDDz6okJDGNyM8JSVFv/3tbxUTE+PX8S1atNCjjz7qdStvf9jttb/Fbdu2rR577DFGtwAAAtb4fmMDAACYmDx5sp577jnD9s8++0yTJ0/2uj3zkCFDNGDAAK1evVorV67U/v375XK5DPsKCwtTSkqKJk6cqEGDBpnulHQxm82m6dOnq1evXlq8eLHh1sM9evTQlClT1L9/f7/7boj69Omjp59+Wm+++abWrl3rdV2amJgYjRo1Stdff72io6OVnZ0d0Hs98sgjSk9P1/bt27V7924dOnTIcLepqhwOh1JSUjRq1CiNGTPGdMFfAAB8sXmsWpUMAACgiSktLVVGRoZyc3NVVFSksrIyRUZGKjo6WomJieratatlI04OHjyoAwcOqLCwUA6HQy1atFD37t2VmJhoSf8NSVlZmXbt2qVTp07p9OnTiouLU2JiolJSUupkBI/b7daJEyeUnZ2tnJwcnTlzRmVlZbLb7QoPD1d0dLTatWunpKQkhYeHW/7+AIDmicAFAAAAAADAYqzhAgAAAAAAYDECFwAAAAAAAIsRuAAAAAAAAFiMwAUAAAAAAMBiBC4AAAAAAAAWI3ABAAAAAACwGIELAAAAAACAxQhcAAAAAAAALEbgAgAAAAAAYDECFwAAAAAAAIsRuAAAAAAAAFiMwAUAAAAAAMBiBC4AAAAAAAAWI3ABAAAAAACwGIELAAAAAACAxQhcAAAAAAAALEbgAgAAAAAAYDECFwAAAAAAAIsRuAAAAAAAAFiMwAUAAAAAAMBiBC4AAAAAAAAWI3ABAAAAAACwGIELAAAAAACAxQhcAAAAAAAALEbgAgAAAAAAYDECFwAAAAAAAIv9f2w7IeuDgtdZAAAAAElFTkSuQmCC\n",
            "text/plain": [
              "<Figure size 1200x800 with 1 Axes>"
            ]
          },
          "metadata": {}
        }
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "Cix0BEdb41ca"
      },
      "source": [
        "# Set Parameters"
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "fIu8OJV440wn",
        "outputId": "af14263e-0b9f-47cf-d821-d821394b22d7"
      },
      "source": [
        "T = 8000\n",
        "trials = 10\n",
        "env = build_environment(5, 0.4, T, trials)\n",
        "env.build_env1()"
      ],
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "[2000, 4000, 6000, 8000] 4\n"
          ]
        }
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "uoVNrWm2ZSCn"
      },
      "source": [
        "# Unbalanced MOSS"
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 1000
        },
        "id": "RIGNPI2qZUsq",
        "outputId": "84f7c566-208c-46ce-822d-c850f716b22a"
      },
      "source": [
        "import numpy as np\n",
        "\n",
        "class UMOSS_Sampling(object):\n",
        "\n",
        "  def __init__(self, env, confidence, type_):\n",
        "    \n",
        "    \n",
        "    self.env = env\n",
        "    self.confidence = confidence\n",
        "    \n",
        "    self.K = env.K\n",
        "    self.T = env.T\n",
        "    self.trials = env.trials\n",
        "\n",
        "\n",
        "    self.mu_hat = np.zeros((self.T, self.K))\n",
        "    self.sumreward = np.zeros((self.T, self.K))\n",
        "    self.reward_arm = np.zeros((self.T, self.K))\n",
        "    self.numplays = np.zeros((self.T, self.K))\n",
        "    \n",
        "    self.tol = 0.01\n",
        "    self.gamma = 0.01\n",
        "    \n",
        "    self.budget = 0\n",
        "    self.budget_error = 0\n",
        "    self.alpha = 0.7\n",
        "\n",
        "    self.estimated_G = np.zeros(self.K)\n",
        "    self.type_ = type_\n",
        "    \n",
        "    \n",
        "    \n",
        "    self.error = np.zeros((self.trials, self.T))\n",
        "\n",
        "\n",
        "\n",
        "\n",
        "  def run_algorithm(self, tr):\n",
        "\n",
        "    self.seed = tr\n",
        "    np.random.seed(self.seed)\n",
        "    self.t = 0\n",
        "    self.ts = np.zeros(self.K)\n",
        "    self.tp = np.zeros(self.K)\n",
        "\n",
        "    self.mu_hat = np.zeros((self.T, self.K))\n",
        "    self.sumreward = np.zeros((self.T, self.K))\n",
        "    self.reward_arm = np.zeros((self.T, self.K))\n",
        "    self.numplays = np.zeros((self.T, self.K))\n",
        "\n",
        "    #Sample each arm once\n",
        "    \n",
        "\n",
        "    for i in range(0,self.K):\n",
        "      \n",
        "      arm = i\n",
        "      reward = self.env.pull_arm(arm, self.t)\n",
        "      #self.sumreward[self.t][arm] += reward\n",
        "      self.reward_arm[self.t][arm] = reward\n",
        "      self.numplays[self.t][arm] = 1\n",
        "      #self.mu_hat[self.t][arm] = self.sumreward[self.t][arm]/self.numplays[self.t][arm]\n",
        "\n",
        "      self.tp[arm] += 1\n",
        "\n",
        "      self.t += 1\n",
        "\n",
        "\n",
        "\n",
        "    sum1 = 0.0\n",
        "    self.ucb = np.zeros(self.K)\n",
        "    self.lcb = np.zeros(self.K)\n",
        "    self.B = np.zeros(self.K)\n",
        "    while self.t < self.T:\n",
        "      \n",
        "      for k in range(self.K):\n",
        "\n",
        "        if k == self.env.baseline:\n",
        "          self.B[k] = (self.T*self.K)/(np.sqrt(self.T*self.K) + (self.K/(self.alpha*self.env.mu_t[self.t][self.env.baseline])))\n",
        "        else:\n",
        "          self.B[k] = np.sqrt(self.T*self.K) + (self.K/(self.alpha*self.env.mu_t[self.t][self.env.baseline]))\n",
        "        \n",
        "        n_k = (self.B[k]*self.B[k])/(self.T*self.T)\n",
        "        beta_ucb = np.sqrt(4.0*np.log(max(0, (n_k/ (np.sum(self.numplays[int(self.ts[k]):self.t, k]) + 1) ) ))/(np.sum(self.numplays[int(self.ts[k]):self.t, k]) + 1)) - np.sqrt(1.0/n_k)\n",
        "        self.ucb[k] = np.sum(self.reward_arm[int(self.ts[k]):self.t, k])/(np.sum(self.numplays[int(self.ts[k]):self.t, k]) + 1) + beta_ucb\n",
        "        self.lcb[k] = max(0.0,np.sum(self.reward_arm[int(self.ts[k]):self.t, k])/(np.sum(self.numplays[int(self.ts[k]):self.t, k]) + 1) - beta_ucb)\n",
        "\n",
        "      arm = np.argmax(self.ucb)\n",
        "\n",
        "      reward = self.env.pull_arm(arm, self.t)\n",
        "      #self.sumreward[self.t][arm] += reward\n",
        "      self.reward_arm[self.t][arm] = reward\n",
        "      self.numplays[self.t][arm] = 1\n",
        "      #self.mu_hat[self.t][arm] = self.sumreward[self.t][arm]/self.numplays[self.t][arm]\n",
        "      self.mu_hat[self.t, :] = [np.sum(self.reward_arm[int(self.ts[i]):self.t,i])/(np.sum(self.numplays[int(self.ts[i]):self.t,i]) + 1 ) for i in range(self.K)]\n",
        "      \n",
        "      self.tp[arm] += 1\n",
        "      #print(\"t:\"+str(self.numplays[self.t]))\n",
        "      # if self.t > 1.0*self.K:\n",
        "      #   #print(t)\n",
        "\n",
        "      # self.budget +=  self.lcb[arm] + self.ucb[np.argmax(self.ucb)] - (1.0-self.alpha)*self.ucb[self.env.baseline] - self.alpha*self.env.threshold\n",
        "      self.budget +=  self.lcb[arm] + self.ucb[np.argmax(self.ucb)] - (1.0-self.alpha)*self.ucb[self.env.baseline]\n",
        "      \n",
        "\n",
        "      error1 = 0\n",
        "      \n",
        "      #max(-1.0*self.budget_error,0.0)\n",
        "      error1 = self.env.mu_t[self.t][np.argmax(self.env.mu_t[self.t])] - self.env.mu_t[self.t][arm] + max(self.budget_error, 0.0)\n",
        "      #print(self.env.mu_t[self.t][np.argmax(self.env.mu_t[self.t])], self.env.mu_t[self.t][arm])\n",
        "      sum1 += error1\n",
        "      self.error[tr][self.t] =  sum1\n",
        "      #print(self.t,sum1)   \n",
        "      \n",
        "      if self.t%100 == 0 and self.t > 2.0*self.K:\n",
        "        print(\"t \" +str(self.t))\n",
        "        print(\"t reward-arm: \" + str([np.sum(self.reward_arm[int(self.ts[i]):self.t,i]) for i in range(self.K)]   ))\n",
        "        \n",
        "        print(\"t numplay: \" + str([np.sum(self.numplays[int(self.ts[i]):self.t,i]) for i in range(self.K)]   ), str(np.sum(self.numplays[int(self.ts[i]):self.t,:])))\n",
        "        print(\"t mu-hat: \" + str([np.sum(self.reward_arm[int(self.ts[i]):self.t,i])/(np.sum(self.numplays[int(self.ts[i]):self.t,i]) + 1 ) for i in range(self.K)]   ))\n",
        "        print(\"T true mu: \" + str(self.env.mu_t[self.t]) + \" Err: \" + str(self.error[tr][self.t]))\n",
        "        print(np.argmax(self.mu_hat[self.t]), np.argmax(self.env.mu_t[self.t]))\n",
        "        print()\n",
        "      \n",
        "      self.t += 1\n",
        "\n",
        "  def run_UMOSS_sampling(self, ):\n",
        "\n",
        "    for tr in range(0,self.trials):\n",
        "      \n",
        "      print(tr, end=\", \")\n",
        "      self.run_algorithm(tr)\n",
        "\n",
        "\n",
        "# T = 8000\n",
        "# trials = 10\n",
        "# env = build_environment(5, 0.4, T, trials)\n",
        "# env.build_env1()\n",
        "umoss = UMOSS_Sampling(env, 0.10, \"global\")\n",
        "umoss.run_UMOSS_sampling()\n",
        "\n",
        "\n"
      ],
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "0, t 100\n",
            "t reward-arm: [19.14707330515005, 0.3400157208367223, 0.597873798410574, 0.8240893199201458, 0.8367557990149967, 0.2522722120123589]\n",
            "t numplay: [95.0, 1.0, 1.0, 1.0, 1.0, 1.0] 100.0\n",
            "t mu-hat: [0.1994486802619797, 0.17000786041836116, 0.298936899205287, 0.4120446599600729, 0.4183778995074984, 0.12613610600617944]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 42.75000000000003\n",
            "4 4\n",
            "\n",
            "t 200\n",
            "t reward-arm: [39.96720301262843, 0.3400157208367223, 0.597873798410574, 0.8240893199201458, 0.8367557990149967, 0.2522722120123589]\n",
            "t numplay: [195.0, 1.0, 1.0, 1.0, 1.0, 1.0] 200.0\n",
            "t mu-hat: [0.20391430108483893, 0.17000786041836116, 0.298936899205287, 0.4120446599600729, 0.4183778995074984, 0.12613610600617944]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 87.75000000000031\n",
            "4 4\n",
            "\n",
            "t 300\n",
            "t reward-arm: [59.374880407031796, 0.3400157208367223, 0.597873798410574, 0.8240893199201458, 0.8367557990149967, 0.2522722120123589]\n",
            "t numplay: [295.0, 1.0, 1.0, 1.0, 1.0, 1.0] 300.0\n",
            "t mu-hat: [0.20059081218591823, 0.17000786041836116, 0.298936899205287, 0.4120446599600729, 0.4183778995074984, 0.12613610600617944]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 132.75000000000045\n",
            "4 4\n",
            "\n",
            "t 400\n",
            "t reward-arm: [77.4069133415727, 0.3400157208367223, 0.597873798410574, 0.8240893199201458, 0.8367557990149967, 0.2522722120123589]\n",
            "t numplay: [395.0, 1.0, 1.0, 1.0, 1.0, 1.0] 400.0\n",
            "t mu-hat: [0.19547200338780985, 0.17000786041836116, 0.298936899205287, 0.4120446599600729, 0.4183778995074984, 0.12613610600617944]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 177.74999999999932\n",
            "4 4\n",
            "\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "/usr/local/lib/python3.7/dist-packages/ipykernel_launcher.py:83: RuntimeWarning: invalid value encountered in sqrt\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "t 500\n",
            "t reward-arm: [97.28127118318352, 0.3400157208367223, 0.597873798410574, 0.8240893199201458, 0.8367557990149967, 0.2522722120123589]\n",
            "t numplay: [495.0, 1.0, 1.0, 1.0, 1.0, 1.0] 500.0\n",
            "t mu-hat: [0.19613159512738612, 0.17000786041836116, 0.298936899205287, 0.4120446599600729, 0.4183778995074984, 0.12613610600617944]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 222.74999999999818\n",
            "4 4\n",
            "\n",
            "t 600\n",
            "t reward-arm: [115.25196138428424, 0.3400157208367223, 0.597873798410574, 0.8240893199201458, 0.8367557990149967, 0.2522722120123589]\n",
            "t numplay: [595.0, 1.0, 1.0, 1.0, 1.0, 1.0] 600.0\n",
            "t mu-hat: [0.1933757741347051, 0.17000786041836116, 0.298936899205287, 0.4120446599600729, 0.4183778995074984, 0.12613610600617944]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 267.74999999999704\n",
            "4 4\n",
            "\n",
            "t 700\n",
            "t reward-arm: [133.90246508264943, 0.3400157208367223, 0.597873798410574, 0.8240893199201458, 0.8367557990149967, 0.2522722120123589]\n",
            "t numplay: [695.0, 1.0, 1.0, 1.0, 1.0, 1.0] 700.0\n",
            "t mu-hat: [0.19238859925668023, 0.17000786041836116, 0.298936899205287, 0.4120446599600729, 0.4183778995074984, 0.12613610600617944]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 312.7499999999959\n",
            "4 4\n",
            "\n",
            "t 800\n",
            "t reward-arm: [152.66647224742132, 0.3400157208367223, 0.597873798410574, 0.8240893199201458, 0.8367557990149967, 0.2522722120123589]\n",
            "t numplay: [795.0, 1.0, 1.0, 1.0, 1.0, 1.0] 800.0\n",
            "t mu-hat: [0.1917920505620871, 0.17000786041836116, 0.298936899205287, 0.4120446599600729, 0.4183778995074984, 0.12613610600617944]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 357.74999999999477\n",
            "4 4\n",
            "\n",
            "t 900\n",
            "t reward-arm: [172.3844809298675, 0.3400157208367223, 0.597873798410574, 0.8240893199201458, 0.8367557990149967, 0.2522722120123589]\n",
            "t numplay: [895.0, 1.0, 1.0, 1.0, 1.0, 1.0] 900.0\n",
            "t mu-hat: [0.1923933938949414, 0.17000786041836116, 0.298936899205287, 0.4120446599600729, 0.4183778995074984, 0.12613610600617944]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 402.74999999999363\n",
            "4 4\n",
            "\n",
            "t 1000\n",
            "t reward-arm: [194.02332240078567, 0.3400157208367223, 0.597873798410574, 0.8240893199201458, 0.8367557990149967, 0.2522722120123589]\n",
            "t numplay: [995.0, 1.0, 1.0, 1.0, 1.0, 1.0] 1000.0\n",
            "t mu-hat: [0.19480253253090932, 0.17000786041836116, 0.298936899205287, 0.4120446599600729, 0.4183778995074984, 0.12613610600617944]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 447.7499999999925\n",
            "4 4\n",
            "\n",
            "t 1100\n",
            "t reward-arm: [213.99463177599642, 0.3400157208367223, 0.597873798410574, 0.8240893199201458, 0.8367557990149967, 0.2522722120123589]\n",
            "t numplay: [1095.0, 1.0, 1.0, 1.0, 1.0, 1.0] 1100.0\n",
            "t mu-hat: [0.19525057643795293, 0.17000786041836116, 0.298936899205287, 0.4120446599600729, 0.4183778995074984, 0.12613610600617944]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 492.74999999999136\n",
            "4 4\n",
            "\n",
            "t 1200\n",
            "t reward-arm: [235.94487715817323, 0.3400157208367223, 0.597873798410574, 0.8240893199201458, 0.8367557990149967, 0.2522722120123589]\n",
            "t numplay: [1195.0, 1.0, 1.0, 1.0, 1.0, 1.0] 1200.0\n",
            "t mu-hat: [0.19727832538308798, 0.17000786041836116, 0.298936899205287, 0.4120446599600729, 0.4183778995074984, 0.12613610600617944]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 537.7499999999935\n",
            "4 4\n",
            "\n",
            "t 1300\n",
            "t reward-arm: [255.92260845300927, 0.3400157208367223, 0.597873798410574, 0.8240893199201458, 0.8367557990149967, 0.2522722120123589]\n",
            "t numplay: [1295.0, 1.0, 1.0, 1.0, 1.0, 1.0] 1300.0\n",
            "t mu-hat: [0.19747114849769234, 0.17000786041836116, 0.298936899205287, 0.4120446599600729, 0.4183778995074984, 0.12613610600617944]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 582.7499999999981\n",
            "4 4\n",
            "\n",
            "t 1400\n",
            "t reward-arm: [275.9545503759, 0.3400157208367223, 0.597873798410574, 0.8240893199201458, 0.8367557990149967, 0.2522722120123589]\n",
            "t numplay: [1395.0, 1.0, 1.0, 1.0, 1.0, 1.0] 1400.0\n",
            "t mu-hat: [0.1976751793523639, 0.17000786041836116, 0.298936899205287, 0.4120446599600729, 0.4183778995074984, 0.12613610600617944]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 627.7500000000026\n",
            "4 4\n",
            "\n",
            "t 1500\n",
            "t reward-arm: [295.4831729188777, 0.3400157208367223, 0.597873798410574, 0.8240893199201458, 0.8367557990149967, 0.2522722120123589]\n",
            "t numplay: [1495.0, 1.0, 1.0, 1.0, 1.0, 1.0] 1500.0\n",
            "t mu-hat: [0.1975154899190359, 0.17000786041836116, 0.298936899205287, 0.4120446599600729, 0.4183778995074984, 0.12613610600617944]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 672.7500000000072\n",
            "4 4\n",
            "\n",
            "t 1600\n",
            "t reward-arm: [316.06328069211895, 0.3400157208367223, 0.597873798410574, 0.8240893199201458, 0.8367557990149967, 0.2522722120123589]\n",
            "t numplay: [1595.0, 1.0, 1.0, 1.0, 1.0, 1.0] 1600.0\n",
            "t mu-hat: [0.19803463702513718, 0.17000786041836116, 0.298936899205287, 0.4120446599600729, 0.4183778995074984, 0.12613610600617944]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 717.7500000000117\n",
            "4 4\n",
            "\n",
            "t 1700\n",
            "t reward-arm: [336.71441278084257, 0.3400157208367223, 0.597873798410574, 0.8240893199201458, 0.8367557990149967, 0.2522722120123589]\n",
            "t numplay: [1695.0, 1.0, 1.0, 1.0, 1.0, 1.0] 1700.0\n",
            "t mu-hat: [0.19853444149813831, 0.17000786041836116, 0.298936899205287, 0.4120446599600729, 0.4183778995074984, 0.12613610600617944]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 762.7500000000163\n",
            "4 4\n",
            "\n",
            "t 1800\n",
            "t reward-arm: [356.0525357581693, 0.3400157208367223, 0.597873798410574, 0.8240893199201458, 0.8367557990149967, 0.2522722120123589]\n",
            "t numplay: [1795.0, 1.0, 1.0, 1.0, 1.0, 1.0] 1800.0\n",
            "t mu-hat: [0.1982475143419651, 0.17000786041836116, 0.298936899205287, 0.4120446599600729, 0.4183778995074984, 0.12613610600617944]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 807.7500000000208\n",
            "4 4\n",
            "\n",
            "t 1900\n",
            "t reward-arm: [375.0655921703793, 0.3400157208367223, 0.597873798410574, 0.8240893199201458, 0.8367557990149967, 0.2522722120123589]\n",
            "t numplay: [1895.0, 1.0, 1.0, 1.0, 1.0, 1.0] 1900.0\n",
            "t mu-hat: [0.19781940515315366, 0.17000786041836116, 0.298936899205287, 0.4120446599600729, 0.4183778995074984, 0.12613610600617944]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 852.7500000000254\n",
            "4 4\n",
            "\n",
            "t 2000\n",
            "t reward-arm: [395.38501643240204, 0.3400157208367223, 0.597873798410574, 0.8240893199201458, 0.8367557990149967, 0.2522722120123589]\n",
            "t numplay: [1995.0, 1.0, 1.0, 1.0, 1.0, 1.0] 2000.0\n",
            "t mu-hat: [0.19808868558737577, 0.17000786041836116, 0.298936899205287, 0.4120446599600729, 0.4183778995074984, 0.12613610600617944]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 897.3000000000299\n",
            "4 0\n",
            "\n",
            "t 2100\n",
            "t reward-arm: [466.019485552384, 0.3400157208367223, 0.597873798410574, 0.8240893199201458, 0.8367557990149967, 0.2522722120123589]\n",
            "t numplay: [2095.0, 1.0, 1.0, 1.0, 1.0, 1.0] 2100.0\n",
            "t mu-hat: [0.22233754081697713, 0.17000786041836116, 0.298936899205287, 0.4120446599600729, 0.4183778995074984, 0.12613610600617944]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 897.3000000000299\n",
            "4 0\n",
            "\n",
            "t 2200\n",
            "t reward-arm: [534.6539313328573, 0.3400157208367223, 0.597873798410574, 0.8240893199201458, 0.8367557990149967, 0.2522722120123589]\n",
            "t numplay: [2195.0, 1.0, 1.0, 1.0, 1.0, 1.0] 2200.0\n",
            "t mu-hat: [0.24346718184556343, 0.17000786041836116, 0.298936899205287, 0.4120446599600729, 0.4183778995074984, 0.12613610600617944]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 897.3000000000299\n",
            "4 0\n",
            "\n",
            "t 2300\n",
            "t reward-arm: [603.9316066497186, 0.3400157208367223, 0.597873798410574, 0.8240893199201458, 0.8367557990149967, 0.2522722120123589]\n",
            "t numplay: [2295.0, 1.0, 1.0, 1.0, 1.0, 1.0] 2300.0\n",
            "t mu-hat: [0.26303641404604466, 0.17000786041836116, 0.298936899205287, 0.4120446599600729, 0.4183778995074984, 0.12613610600617944]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 897.3000000000299\n",
            "4 0\n",
            "\n",
            "t 2400\n",
            "t reward-arm: [673.4797794048876, 0.3400157208367223, 0.597873798410574, 0.8240893199201458, 0.8367557990149967, 0.2522722120123589]\n",
            "t numplay: [2395.0, 1.0, 1.0, 1.0, 1.0, 1.0] 2400.0\n",
            "t mu-hat: [0.28108504983509497, 0.17000786041836116, 0.298936899205287, 0.4120446599600729, 0.4183778995074984, 0.12613610600617944]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 897.3000000000299\n",
            "4 0\n",
            "\n",
            "t 2500\n",
            "t reward-arm: [743.9153328938817, 0.3400157208367223, 0.597873798410574, 0.8240893199201458, 0.8367557990149967, 0.2522722120123589]\n",
            "t numplay: [2495.0, 1.0, 1.0, 1.0, 1.0, 1.0] 2500.0\n",
            "t mu-hat: [0.2980430019606898, 0.17000786041836116, 0.298936899205287, 0.4120446599600729, 0.4183778995074984, 0.12613610600617944]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 897.3000000000299\n",
            "4 0\n",
            "\n",
            "t 2600\n",
            "t reward-arm: [813.1125664795723, 0.3400157208367223, 0.597873798410574, 0.8240893199201458, 0.8367557990149967, 0.2522722120123589]\n",
            "t numplay: [2595.0, 1.0, 1.0, 1.0, 1.0, 1.0] 2600.0\n",
            "t mu-hat: [0.31321747553142226, 0.17000786041836116, 0.298936899205287, 0.4120446599600729, 0.4183778995074984, 0.12613610600617944]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 897.3000000000299\n",
            "4 0\n",
            "\n",
            "t 2700\n",
            "t reward-arm: [883.1170001113686, 0.3400157208367223, 0.597873798410574, 0.8240893199201458, 0.8367557990149967, 0.2522722120123589]\n",
            "t numplay: [2695.0, 1.0, 1.0, 1.0, 1.0, 1.0] 2700.0\n",
            "t mu-hat: [0.3275656528602999, 0.17000786041836116, 0.298936899205287, 0.4120446599600729, 0.4183778995074984, 0.12613610600617944]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 897.3000000000299\n",
            "4 0\n",
            "\n",
            "t 2800\n",
            "t reward-arm: [951.9570682799548, 0.3400157208367223, 0.597873798410574, 0.8240893199201458, 0.8367557990149967, 0.2522722120123589]\n",
            "t numplay: [2795.0, 1.0, 1.0, 1.0, 1.0, 1.0] 2800.0\n",
            "t mu-hat: [0.3404710544635031, 0.17000786041836116, 0.298936899205287, 0.4120446599600729, 0.4183778995074984, 0.12613610600617944]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 897.3000000000299\n",
            "4 0\n",
            "\n",
            "t 2900\n",
            "t reward-arm: [1022.1451830450168, 0.3400157208367223, 0.597873798410574, 0.8240893199201458, 0.8367557990149967, 0.2522722120123589]\n",
            "t numplay: [2895.0, 1.0, 1.0, 1.0, 1.0, 1.0] 2900.0\n",
            "t mu-hat: [0.35295068475311353, 0.17000786041836116, 0.298936899205287, 0.4120446599600729, 0.4183778995074984, 0.12613610600617944]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 897.3000000000299\n",
            "4 0\n",
            "\n",
            "t 3000\n",
            "t reward-arm: [1090.2621600658347, 0.3400157208367223, 0.597873798410574, 0.8240893199201458, 0.8367557990149967, 0.2522722120123589]\n",
            "t numplay: [2995.0, 1.0, 1.0, 1.0, 1.0, 1.0] 3000.0\n",
            "t mu-hat: [0.36390592792584603, 0.17000786041836116, 0.298936899205287, 0.4120446599600729, 0.4183778995074984, 0.12613610600617944]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 897.3000000000299\n",
            "4 0\n",
            "\n",
            "t 3100\n",
            "t reward-arm: [1159.2814090554646, 0.3400157208367223, 0.597873798410574, 0.8240893199201458, 0.8367557990149967, 0.2522722120123589]\n",
            "t numplay: [3095.0, 1.0, 1.0, 1.0, 1.0, 1.0] 3100.0\n",
            "t mu-hat: [0.3744448995657185, 0.17000786041836116, 0.298936899205287, 0.4120446599600729, 0.4183778995074984, 0.12613610600617944]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 897.3000000000299\n",
            "4 0\n",
            "\n",
            "t 3200\n",
            "t reward-arm: [1228.975016303439, 0.3400157208367223, 0.597873798410574, 0.8240893199201458, 0.8367557990149967, 0.2522722120123589]\n",
            "t numplay: [3195.0, 1.0, 1.0, 1.0, 1.0, 1.0] 3200.0\n",
            "t mu-hat: [0.384535361797071, 0.17000786041836116, 0.298936899205287, 0.4120446599600729, 0.4183778995074984, 0.12613610600617944]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 897.3000000000299\n",
            "4 0\n",
            "\n",
            "t 3300\n",
            "t reward-arm: [1298.7535249451703, 0.3400157208367223, 0.597873798410574, 0.8240893199201458, 0.8367557990149967, 0.2522722120123589]\n",
            "t numplay: [3295.0, 1.0, 1.0, 1.0, 1.0, 1.0] 3300.0\n",
            "t mu-hat: [0.3940392976168599, 0.17000786041836116, 0.298936899205287, 0.4120446599600729, 0.4183778995074984, 0.12613610600617944]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 897.3000000000299\n",
            "4 0\n",
            "\n"
          ]
        },
        {
          "output_type": "error",
          "ename": "KeyboardInterrupt",
          "evalue": "ignored",
          "traceback": [
            "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
            "\u001b[0;31mKeyboardInterrupt\u001b[0m                         Traceback (most recent call last)",
            "\u001b[0;32m<ipython-input-6-a758f98e5867>\u001b[0m in \u001b[0;36m<module>\u001b[0;34m()\u001b[0m\n\u001b[1;32m    137\u001b[0m \u001b[0;31m# env.build_env1()\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    138\u001b[0m \u001b[0mumoss\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mUMOSS_Sampling\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0menv\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;36m0.10\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m\"global\"\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 139\u001b[0;31m \u001b[0mumoss\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mrun_UMOSS_sampling\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    140\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    141\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;32m<ipython-input-6-a758f98e5867>\u001b[0m in \u001b[0;36mrun_UMOSS_sampling\u001b[0;34m(self)\u001b[0m\n\u001b[1;32m    129\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    130\u001b[0m       \u001b[0mprint\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mtr\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mend\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;34m\", \"\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 131\u001b[0;31m       \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mrun_algorithm\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mtr\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    132\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    133\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;32m<ipython-input-6-a758f98e5867>\u001b[0m in \u001b[0;36mrun_algorithm\u001b[0;34m(self, tr)\u001b[0m\n\u001b[1;32m     81\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     82\u001b[0m         \u001b[0mn_k\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mB\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mk\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mB\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mk\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m/\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mT\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mT\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 83\u001b[0;31m         \u001b[0mbeta_ucb\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msqrt\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;36m4.0\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mlog\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mmax\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;36m0\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m(\u001b[0m\u001b[0mn_k\u001b[0m\u001b[0;34m/\u001b[0m \u001b[0;34m(\u001b[0m\u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msum\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mnumplays\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mint\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mts\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mk\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mt\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mk\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;34m+\u001b[0m \u001b[0;36m1\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;34m)\u001b[0m \u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m/\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msum\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mnumplays\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mint\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mts\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mk\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mt\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mk\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;34m+\u001b[0m \u001b[0;36m1\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;34m-\u001b[0m \u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msqrt\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;36m1.0\u001b[0m\u001b[0;34m/\u001b[0m\u001b[0mn_k\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     84\u001b[0m         \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mucb\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mk\u001b[0m\u001b[0;34m]\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msum\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mreward_arm\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mint\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mts\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mk\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mt\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mk\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m/\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msum\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mnumplays\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mint\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mts\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mk\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mt\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mk\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;34m+\u001b[0m \u001b[0;36m1\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;34m+\u001b[0m \u001b[0mbeta_ucb\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     85\u001b[0m         \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mlcb\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mk\u001b[0m\u001b[0;34m]\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mmax\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;36m0.0\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msum\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mreward_arm\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mint\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mts\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mk\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mt\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mk\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m/\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msum\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mnumplays\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mint\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mts\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mk\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mt\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mk\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;34m+\u001b[0m \u001b[0;36m1\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;34m-\u001b[0m \u001b[0mbeta_ucb\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;31mKeyboardInterrupt\u001b[0m: "
          ]
        }
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "nrUBfmGpk2Kl"
      },
      "source": [
        "# DUCB"
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 1000
        },
        "id": "MSMCOCg2k5s8",
        "outputId": "79302c02-d4eb-49af-ff5f-d3f28d5bd289"
      },
      "source": [
        "import numpy as np\n",
        "\n",
        "class DUCB_Sampling(object):\n",
        "\n",
        "  def __init__(self, env, confidence, type_):\n",
        "    \n",
        "    \n",
        "    self.env = env\n",
        "    self.confidence = confidence\n",
        "    \n",
        "    self.K = env.K\n",
        "    self.T = env.T\n",
        "    self.trials = env.trials\n",
        "\n",
        "\n",
        "    self.mu_hat = np.zeros((self.T, self.K))\n",
        "    self.sumreward = np.zeros((self.T, self.K))\n",
        "    self.reward_arm = np.zeros((self.T, self.K))\n",
        "    self.numplays = np.zeros((self.T, self.K))\n",
        "    \n",
        "    self.tol = 0.01\n",
        "    self.gamma = 0.01\n",
        "    \n",
        "    self.budget = 0\n",
        "    self.budget_error = 0\n",
        "    self.alpha = 0.7\n",
        "\n",
        "    self.estimated_G = np.zeros(self.K)\n",
        "    self.type_ = type_\n",
        "    \n",
        "    \n",
        "    \n",
        "    self.error = np.zeros((self.trials, self.T))\n",
        "\n",
        "\n",
        "\n",
        "\n",
        "  def run_algorithm(self, tr):\n",
        "\n",
        "    self.seed = tr\n",
        "    np.random.seed(self.seed)\n",
        "    self.t = 0\n",
        "    self.ts = np.zeros(self.K)\n",
        "    self.tp = np.zeros(self.K)\n",
        "\n",
        "    self.mu_hat = np.zeros((self.T, self.K))\n",
        "    self.sumreward = np.zeros((self.T, self.K))\n",
        "    self.reward_arm = np.zeros((self.T, self.K))\n",
        "    self.numplays = np.zeros((self.T, self.K))\n",
        "    \n",
        "    #Sample each arm once\n",
        "    \n",
        "\n",
        "    for i in range(0,self.K):\n",
        "      \n",
        "      arm = i\n",
        "      reward = self.env.pull_arm(arm, self.t)\n",
        "      #self.sumreward[self.t][arm] += reward\n",
        "      self.reward_arm[self.t][arm] = reward\n",
        "      self.numplays[self.t][arm] = 1\n",
        "      #self.mu_hat[self.t][arm] = self.sumreward[self.t][arm]/self.numplays[self.t][arm]\n",
        "\n",
        "      self.tp[arm] += 1\n",
        "\n",
        "      self.t += 1\n",
        "\n",
        "\n",
        "\n",
        "    sum1 = 0.0\n",
        "    self.ucb = np.zeros(self.K)\n",
        "    self.lcb = np.zeros(self.K)\n",
        "    self.B = np.zeros(self.K)\n",
        "\n",
        "    self.gamma = 1 - (1/(4.0*np.sqrt(self.T)))\n",
        "    while self.t < self.T:\n",
        "      \n",
        "      for k in range(self.K):\n",
        "\n",
        "        \n",
        "        beta_ucb = 2.0*np.sqrt(2.0*np.log(self.t+1.0)/(np.sum(self.numplays[int(self.ts[k]):self.t, k]) + 1))\n",
        "        #print(beta_ucb)\n",
        "        self.ucb[k] = np.sum(self.reward_arm[int(self.ts[k]):self.t, k])/(np.sum(self.numplays[int(self.ts[k]):self.t, k]) + 1) + beta_ucb\n",
        "        self.lcb[k] = max(0.0,np.sum(self.reward_arm[int(self.ts[k]):self.t, k])/(np.sum(self.numplays[int(self.ts[k]):self.t, k]) + 1) - beta_ucb)\n",
        "\n",
        "      arm = np.argmax(self.ucb)\n",
        "\n",
        "      reward = self.gamma*self.env.pull_arm(arm, self.t)\n",
        "      #self.sumreward[self.t][arm] += reward\n",
        "      self.reward_arm[self.t][arm] = reward\n",
        "      self.numplays[self.t][arm] = self.gamma*1\n",
        "      #self.mu_hat[self.t][arm] = self.sumreward[self.t][arm]/self.numplays[self.t][arm]\n",
        "      self.mu_hat[self.t, :] = [np.sum(self.reward_arm[int(self.ts[i]):self.t,i])/(np.sum(self.numplays[int(self.ts[i]):self.t,i]) + 1 ) for i in range(self.K)]\n",
        "      \n",
        "      self.tp[arm] += 1\n",
        "      \n",
        "\n",
        "      self.budget +=  self.lcb[arm] + self.lcb[np.argmax(self.ucb)] - (1.0 - self.alpha)*self.ucb[np.argmin(self.env.safe_arm_t[self.t])]\n",
        "      \n",
        "\n",
        "      error1 = 0\n",
        "      \n",
        "      #max(-1.0*self.budget_error,0.0)\n",
        "      error1 = self.env.mu_t[self.t][np.argmax(self.env.mu_t[self.t])] - self.env.mu_t[self.t][arm] + max(self.budget_error, 0.0)\n",
        "      #print(self.env.mu_t[self.t][np.argmax(self.env.mu_t[self.t])], self.env.mu_t[self.t][arm])\n",
        "      sum1 += error1\n",
        "      self.error[tr][self.t] =  sum1\n",
        "      #print(self.t,sum1)   \n",
        "      \n",
        "      if self.t%100 == 0 and self.t > 2.0*self.K:\n",
        "        print(\"t \" +str(self.t))\n",
        "        print(\"t reward-arm: \" + str([np.sum(self.reward_arm[int(self.ts[i]):self.t,i]) for i in range(self.K)]   ))\n",
        "        \n",
        "        print(\"t numplay: \" + str([np.sum(self.numplays[int(self.ts[i]):self.t,i]) for i in range(self.K)]   ), str(np.sum(self.numplays[int(self.ts[i]):self.t,:])))\n",
        "        print(\"t mu-hat: \" + str([np.sum(self.reward_arm[int(self.ts[i]):self.t,i])/(np.sum(self.numplays[int(self.ts[i]):self.t,i]) + 1 ) for i in range(self.K)]   ))\n",
        "        print(\"T true mu: \" + str(self.env.mu_t[self.t]) + \" Err: \" + str(self.error[tr][self.t]))\n",
        "        print(np.argmax(self.mu_hat[self.t]), np.argmax(self.env.mu_t[self.t]))\n",
        "        print()\n",
        "      \n",
        "      self.t += 1\n",
        "\n",
        "  def run_DUCB_sampling(self, ):\n",
        "\n",
        "    for tr in range(0,self.trials):\n",
        "      \n",
        "      print(tr, end=\", \")\n",
        "      self.run_algorithm(tr)\n",
        "\n",
        "\n",
        "# T = 8000\n",
        "# trials = 10\n",
        "# env = build_environment(5, 0.4, T, trials)\n",
        "# env.build_env1()\n",
        "ducb = DUCB_Sampling(env, 0.10, \"global\")\n",
        "ducb.run_DUCB_sampling()\n",
        "\n",
        "\n"
      ],
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "0, t 100\n",
            "t reward-arm: [2.670095126930818, 4.297895776719011, 7.112485339572588, 12.846838399159639, 15.58452588267022, 5.012080088527932]\n",
            "t numplay: [11.969254065309377, 13.963663895365627, 15.95807372542188, 20.944098300562505, 22.938508130618754, 13.963663895365627] 99.73726201264377\n",
            "t mu-hat: [0.20587885112628673, 0.2872221540641598, 0.419415875572604, 0.5854347817440432, 0.6510232716940576, 0.33495005792533306]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 16.95000000000001\n",
            "4 4\n",
            "\n",
            "t 200\n",
            "t reward-arm: [4.958154649779715, 7.525360768063347, 16.527949839493477, 24.911063844176013, 33.86758201178212, 9.414687711921696]\n",
            "t numplay: [21.94130321559063, 24.932917960675006, 33.907762195928136, 41.88540151615314, 49.86304083637813, 26.927327790731255] 199.4577535154563\n",
            "t mu-hat: [0.21612349582695953, 0.29018565436696697, 0.4734749178915113, 0.580875145468629, 0.6658583807588522, 0.3371138041730694]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 32.65000000000001\n",
            "4 4\n",
            "\n",
            "t 300\n",
            "t reward-arm: [6.636424392416165, 10.939276000278337, 25.682966905146614, 38.708460874092424, 51.64803483512269, 12.809354310231763]\n",
            "t numplay: [30.91614745084376, 35.902172025984385, 51.85745066643439, 64.82111456180002, 77.78477845716564, 37.89658185604063] 299.17824501826885\n",
            "t mu-hat: [0.20793312860323684, 0.2964398949897997, 0.4858911389280423, 0.5880857705280683, 0.6555585462895364, 0.3293182510905511]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 47.74999999999993\n",
            "4 4\n",
            "\n",
            "t 400\n",
            "t reward-arm: [8.310410560482108, 13.873813445372894, 33.73163733096518, 53.14539799214175, 68.67192582921275, 17.087713937744343]\n",
            "t numplay: [38.89378677106876, 45.874221176265635, 68.80993422191253, 89.75123743750315, 105.70651607795315, 49.86304083637813] 398.89873652108133\n",
            "t mu-hat: [0.20831340499641093, 0.2959796045080272, 0.4831925098760114, 0.5856162350264471, 0.643558878625981, 0.3359554139264696]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 62.19999999999984\n",
            "4 4\n",
            "\n",
            "t 500\n",
            "t reward-arm: [10.05701311458959, 15.929758536351573, 42.847112810398755, 68.74854110137079, 89.42825027232007, 19.88860958473017]\n",
            "t numplay: [45.874221176265635, 53.85186049649064, 86.75962269241877, 115.67856522823439, 137.61707335885313, 58.83788507163126] 498.61922802389387\n",
            "t mu-hat: [0.21455317789219874, 0.2904141881818346, 0.48823264612896017, 0.5892131169670461, 0.6451459990127436, 0.3323748752303284]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 75.29999999999981\n",
            "4 4\n",
            "\n",
            "t 600\n",
            "t reward-arm: [11.50699139964998, 19.14565825970081, 49.326293901233356, 83.06368582104525, 109.38794248199564, 23.850989220258676]\n",
            "t numplay: [52.85465558146251, 63.82390964677189, 101.71769641784066, 140.60868810393754, 169.52763063975317, 69.80713913694063] 598.3397195267064\n",
            "t mu-hat: [0.2136675330184609, 0.29534871259734685, 0.480212228480876, 0.5865719606135918, 0.6414675561468528, 0.33684441302071233]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 88.29999999999976\n",
            "4 4\n",
            "\n",
            "t 700\n",
            "t reward-arm: [12.808724747070201, 20.85763683390089, 58.007823202096844, 96.559675960672, 131.87464503269106, 27.330169738880997]\n",
            "t numplay: [59.83508998665938, 70.80434405196877, 118.67017997331878, 164.54160606461255, 204.42980266573755, 79.7791882872219] 698.060211029519\n",
            "t mu-hat: [0.21054829950739032, 0.2904787601541916, 0.4847308094216124, 0.5832955125672985, 0.6419450504329656, 0.33833181935060663]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 100.64999999999974\n",
            "4 4\n",
            "\n",
            "t 800\n",
            "t reward-arm: [13.485146412484882, 22.651286114605544, 67.11013220052007, 111.1854026740395, 155.05544559664065, 30.21876807805126]\n",
            "t numplay: [64.82111456180002, 77.78477845716564, 136.61986844382506, 189.47172894031567, 240.32917960675007, 88.75403252247501] 797.7807025323315\n",
            "t mu-hat: [0.20487569227992275, 0.2875084065498868, 0.4876485710921436, 0.5837370369482993, 0.6425059988572708, 0.33668423834309924]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 112.04999999999971\n",
            "4 4\n",
            "\n",
            "t 900\n",
            "t reward-arm: [14.357036478259047, 25.450522447054755, 74.23696822196345, 127.05970132407026, 178.98393087464905, 33.136023768252755]\n",
            "t numplay: [69.80713913694065, 85.76241777739064, 151.5779421692469, 216.39626164607506, 277.2257614627907, 96.73167184270002] 897.501194035144\n",
            "t mu-hat: [0.20276255548882735, 0.29333579099137197, 0.48655111719632566, 0.5844612982854586, 0.6433046671653587, 0.33905102760940664]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 123.04999999999967\n",
            "4 4\n",
            "\n",
            "t 1000\n",
            "t reward-arm: [15.466159490076631, 28.243611384768023, 83.4651973030792, 141.30387910894837, 204.08411230349955, 35.945108722142244]\n",
            "t numplay: [74.79316371208127, 93.74005709761565, 168.53042572472503, 240.32917960675005, 315.1195482338594, 104.70931116292502] 997.2216855379565\n",
            "t mu-hat: [0.20405744703874076, 0.298116892157529, 0.4923316681726841, 0.5855233890042033, 0.6455915600401969, 0.3400372997109182]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 134.2999999999999\n",
            "4 4\n",
            "\n",
            "t 1100\n",
            "t reward-arm: [16.337088793044295, 30.409524196430485, 90.01633129354701, 156.56162899200314, 231.2686566383124, 38.68263804791705]\n",
            "t numplay: [78.78198337219376, 100.72049150281254, 182.49129453511878, 266.2565073974813, 356.0049497500126, 112.68695048315003] 1096.942177040769\n",
            "t mu-hat: [0.20477165523486127, 0.298951801619929, 0.49057548763611014, 0.5858103531943358, 0.6478023814522875, 0.34025574512749684]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 144.30000000000027\n",
            "4 4\n",
            "\n",
            "t 1200\n",
            "t reward-arm: [17.094888845386997, 31.839331304215488, 99.23370832550691, 174.60492737124088, 255.56979361032728, 41.77414335749278]\n",
            "t numplay: [82.77080303230628, 105.70651607795315, 199.44377809059694, 295.17544993329693, 392.90153160605325, 120.66458980337502] 1196.6626685435815\n",
            "t mu-hat: [0.2040673865665862, 0.29838225887682107, 0.49507003545231065, 0.5895320743517549, 0.6488164505689874, 0.34335498459333935]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 154.2500000000007\n",
            "4 4\n",
            "\n",
            "t 1300\n",
            "t reward-arm: [17.629567441435775, 34.06933630326489, 105.37018916872174, 189.4945498835688, 284.92726810126567, 43.898687991982186]\n",
            "t numplay: [86.75962269241876, 112.68695048315001, 212.40744198596255, 320.105572809, 436.77854786729074, 127.6450242085719] 1296.383160046394\n",
            "t mu-hat: [0.20088472238792715, 0.2996767540907383, 0.49375124029485695, 0.5901316138050458, 0.650847944672792, 0.3412389111980681]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 163.80000000000106\n",
            "4 4\n",
            "\n",
            "t 1400\n",
            "t reward-arm: [18.362301852234488, 35.46075451330016, 114.15694072995043, 207.13560281397943, 308.85079416894297, 46.65034950114038]\n",
            "t numplay: [90.74844235253127, 117.67297505829066, 229.3599255414407, 349.0245153448157, 474.67233463835953, 134.62545861376879] 1396.1036515492067\n",
            "t mu-hat: [0.2001374778841451, 0.2988106980201877, 0.4955590277329471, 0.5917745578761141, 0.6492931618647817, 0.3439645474968695]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 173.5000000000015\n",
            "4 4\n",
            "\n",
            "t 1500\n",
            "t reward-arm: [18.86072694518605, 37.151707823106975, 119.61080001546307, 225.4946075497336, 336.8564337966386, 48.4646249857812]\n",
            "t numplay: [93.74005709761565, 123.65620454845941, 241.32638452177815, 378.9406627956595, 517.5521459845688, 140.60868810393754] 1495.8241430520193\n",
            "t mu-hat: [0.199078695147427, 0.2980333627008871, 0.4935937960346762, 0.5934995372448713, 0.649609564640897, 0.3422433018390035]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 182.05000000000192\n",
            "4 4\n",
            "\n",
            "t 1600\n",
            "t reward-arm: [19.811862314154737, 38.683881986456115, 128.00604373332723, 240.5716929028147, 364.3354677289117, 51.10289229428241]\n",
            "t numplay: [97.72887675772814, 128.64222912360003, 257.2816631622282, 404.86799058639076, 559.4347524157502, 147.5891225091344] 1595.5446345548316\n",
            "t mu-hat: [0.2006693782485876, 0.29838951588509915, 0.49560639406648815, 0.5927338407624633, 0.6500943529259136, 0.34392081621681897]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 191.3500000000023\n",
            "4 4\n",
            "\n",
            "t 1700\n",
            "t reward-arm: [20.85255458852695, 40.85372611556222, 135.11304662894605, 255.99735708740957, 392.2540351132811, 53.535026820992435]\n",
            "t numplay: [101.71769641784064, 134.62545861376879, 271.2425319726219, 430.79531837712193, 602.3145637619596, 154.5695569143313] 1695.2651260576442\n",
            "t mu-hat: [0.20300839403272627, 0.30122461175895127, 0.4962966133540578, 0.5928673753332042, 0.6501650360756858, 0.34412276979404777]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 200.75000000000267\n",
            "4 4\n",
            "\n",
            "t 1800\n",
            "t reward-arm: [21.20311490061114, 42.13684530217462, 139.88893200495707, 271.90821367658737, 423.1324561114417, 56.31739651238994]\n",
            "t numplay: [104.70931116292503, 139.6114831889094, 282.21178603793135, 457.71985108288135, 649.1831947682813, 161.54999131952815] 1794.9856175604568\n",
            "t mu-hat: [0.20057944439664097, 0.2996685928244168, 0.4939375368587992, 0.5927544078040327, 0.6507895920967963, 0.3464620087348118]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 208.95000000000306\n",
            "4 4\n",
            "\n",
            "t 1900\n",
            "t reward-arm: [21.596655163115813, 44.18320889566885, 145.4739307682711, 292.1105141140295, 447.2428240723275, 58.83911573972439]\n",
            "t numplay: [107.7009259080094, 145.59471267907816, 294.17824501826885, 490.6276132788095, 688.0741864543783, 168.53042572472503] 1894.7061090632692\n",
            "t mu-hat: [0.19867958789414975, 0.3013970155417115, 0.49283418823520536, 0.5941702748669025, 0.6490488729139736, 0.3470711259539004]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 218.10000000000352\n",
            "4 4\n",
            "\n",
            "t 2000\n",
            "t reward-arm: [22.06959352220758, 45.952834040599825, 152.9714091707343, 307.59751560439065, 476.45417068832353, 61.111195115790075]\n",
            "t numplay: [110.69254065309377, 150.58073725421877, 309.1363187436907, 516.5549410695407, 732.9484076306438, 174.5136552148938] 1994.4266005660818\n",
            "t mu-hat: [0.19759236734307623, 0.3031574781400588, 0.4932392626261747, 0.5943282368606749, 0.6491657529804151, 0.3481848465919493]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 226.8000000000039\n",
            "4 0\n",
            "\n",
            "t 2100\n",
            "t reward-arm: [22.06959352220758, 108.48861589678208, 153.44300888469064, 307.743813438016, 476.85221653695936, 61.26537646379886]\n",
            "t numplay: [110.69254065309379, 245.31520418189066, 310.1335236587188, 517.5521459845689, 734.9428174607002, 175.51086012992192] 2094.1470920688944\n",
            "t mu-hat: [0.1975923673430762, 0.4404462820600754, 0.4931741429862817, 0.5934674377900923, 0.6479473747461685, 0.34709125783367717]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 233.200000000005\n",
            "4 0\n",
            "\n",
            "t 2200\n",
            "t reward-arm: [79.88816489527207, 118.36474750996575, 153.44300888469064, 307.743813438016, 476.85221653695936, 61.26537646379886]\n",
            "t numplay: [195.45495843048442, 260.2732779073126, 310.1335236587188, 517.5521459845689, 734.9428174607001, 175.51086012992192] 2193.8675835717067\n",
            "t mu-hat: [0.4066487582370719, 0.45303043793080117, 0.4931741429862817, 0.5934674377900923, 0.6479473747461686, 0.34709125783367717]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 233.90000000000515\n",
            "4 0\n",
            "\n",
            "t 2300\n",
            "t reward-arm: [148.9722032229688, 118.36474750996578, 153.44300888469064, 307.743813438016, 476.8522165369593, 61.26537646379886]\n",
            "t numplay: [295.17544993329693, 260.2732779073126, 310.1335236587188, 517.5521459845688, 734.9428174607001, 175.51086012992192] 2293.5880750745196\n",
            "t mu-hat: [0.502986332109969, 0.4530304379308013, 0.4931741429862817, 0.5934674377900924, 0.6479473747461685, 0.34709125783367717]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 233.90000000000515\n",
            "4 0\n",
            "\n",
            "t 2400\n",
            "t reward-arm: [218.3259829256485, 118.36474750996577, 153.44300888469064, 307.743813438016, 476.8522165369593, 61.26537646379886]\n",
            "t numplay: [394.89594143610947, 260.27327790731255, 310.13352365871884, 517.5521459845688, 734.9428174607002, 175.51086012992192] 2393.308566577332\n",
            "t mu-hat: [0.5514731526008392, 0.45303043793080133, 0.4931741429862816, 0.5934674377900924, 0.6479473747461684, 0.34709125783367717]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 233.90000000000515\n",
            "4 0\n",
            "\n",
            "t 2500\n",
            "t reward-arm: [281.422245918778, 120.38694528339887, 154.9622124955797, 308.3175878937644, 476.8522165369593, 61.74974522922842]\n",
            "t numplay: [483.6471788736126, 264.26209756742503, 313.1251384038032, 519.5465558146251, 734.9428174607001, 177.50526995997816] 2493.0290580801443\n",
            "t mu-hat: [0.5806744745174055, 0.453841488804478, 0.49331363062187683, 0.59229589447819, 0.6479473747461685, 0.3459267350654299]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 236.45000000000525\n",
            "4 0\n",
            "\n",
            "t 2600\n",
            "t reward-arm: [314.8180801947344, 136.9382653296571, 160.0300235161037, 310.04663162809743, 478.9783498348864, 62.01109563345118]\n",
            "t numplay: [531.5130147949626, 290.1894253581563, 323.0971875540844, 525.5297853047939, 742.9204567809252, 179.4996797900344] 2592.749549582957\n",
            "t mu-hat: [0.5911932130258847, 0.4702721095081876, 0.4937717131204613, 0.5888491786815437, 0.6438569412481411, 0.3435523858301874]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 246.40000000000558\n",
            "4 0\n",
            "\n",
            "t 2700\n",
            "t reward-arm: [349.510215338001, 154.80801846230233, 164.1712085368102, 312.0279752969216, 480.08408980440186, 62.70583803436769]\n",
            "t numplay: [580.3760556313407, 318.11116297894387, 331.07482687430945, 531.5130147949626, 748.903686271094, 182.4912945351188] 2692.4700410857695\n",
            "t mu-hat: [0.6011775200450131, 0.4851225416784217, 0.49438016751251407, 0.5859537074733545, 0.6401943324103744, 0.34173740063927815]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 255.70000000000593\n",
            "4 0\n",
            "\n",
            "t 2800\n",
            "t reward-arm: [379.644856415804, 173.37593076615104, 169.9331521612774, 313.65848591262824, 482.10482617111614, 63.066258241126334]\n",
            "t numplay: [624.2530718925781, 347.0301055147595, 342.0440809396189, 537.4962442851314, 756.881325591319, 184.48570436517505] 2792.1905325885823\n",
            "t mu-hat: [0.607185911564828, 0.498163601420965, 0.49536826782091686, 0.5824710742950836, 0.6361217909610918, 0.34000603149968156]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 265.90000000000583\n",
            "4 0\n",
            "\n",
            "t 2900\n",
            "t reward-arm: [421.750523660508, 181.73735513005448, 177.40719706930636, 314.77716600426675, 483.96300146846556, 63.26507561202955]\n",
            "t numplay: [683.0881618792378, 360.99097432515316, 355.00774483498446, 542.4822688602719, 763.861759996516, 186.4801141952313] 2891.9110240913947\n",
            "t mu-hat: [0.6165148692266944, 0.5020494101237218, 0.4983239821131913, 0.5791857141252851, 0.6327457153442605, 0.33744952569288944]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 274.8000000000055\n",
            "4 0\n",
            "\n",
            "t 3000\n",
            "t reward-arm: [443.708241940865, 202.9514576203228, 186.5432363691799, 316.73759095430734, 485.9210781685244, 63.44758140487417]\n",
            "t numplay: [716.9931289901938, 393.8987365210814, 370.9630234754344, 549.4627032654689, 771.8393993167408, 188.47452402528756] 2991.631515594207\n",
            "t mu-hat: [0.6179839667336497, 0.5139329120377887, 0.5015101625592088, 0.5754024551987782, 0.6287478078862466, 0.33486075097043844]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 286.4000000000053\n",
            "4 0\n",
            "\n",
            "t 3100\n",
            "t reward-arm: [466.33435318356, 231.75092406303517, 190.4387123679701, 318.3928878905135, 487.619387529323, 63.627206597399415]\n",
            "t numplay: [750.8980961011499, 436.77854786729074, 378.9406627956595, 555.4459327556376, 778.8198337219377, 190.4689338553438] 3091.35200709702\n",
            "t mu-hat: [0.6202095145627631, 0.5293793521680024, 0.5012327739986923, 0.572190161070573, 0.625297493655688, 0.3323108627401155]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 296.3500000000054\n",
            "4 0\n",
            "\n",
            "t 3200\n",
            "t reward-arm: [498.0209183160798, 251.28522553155102, 195.717229890307, 319.9073553887962, 489.6932561724211, 63.81414856235553]\n",
            "t numplay: [796.7695221924438, 466.69469531813445, 388.9127119459407, 560.4319573307782, 785.8002681271346, 192.46334368540005] 3191.072498599832\n",
            "t mu-hat: [0.6242666640703574, 0.5372847458973684, 0.5019513955150099, 0.5698061024344518, 0.622385726098017, 0.3298513679476498]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 306.00000000000534\n",
            "0 0\n",
            "\n",
            "t 3300\n",
            "t reward-arm: [524.6802000099686, 273.1174941184772, 203.81376286237887, 321.0750682835489, 491.5069427032211, 63.856088514501806]\n",
            "t numplay: [835.6605138785408, 499.6024575140626, 402.87358075633443, 565.4179819059189, 792.7807025323314, 194.4577535154563] 3290.7929901026446\n",
            "t mu-hat: [0.627112420517717, 0.5455776135713536, 0.5046474257630238, 0.5668518276965278, 0.6191973943624582, 0.3267002069040573]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 315.60000000000525\n",
            "0 0\n",
            "\n",
            "t 3400\n",
            "t reward-arm: [564.6729794606202, 284.679150737889, 209.71364976047192, 322.48556722626955, 492.942560313126, 64.20581086815336]\n",
            "t numplay: [892.5011940351438, 518.5493508995969, 413.8428348216438, 570.4040064810595, 798.7639320225003, 196.45216334551256] 3390.513481605457\n",
            "t mu-hat: [0.6319778677748584, 0.5479347635503126, 0.5055255440307546, 0.5643740043271102, 0.6163600789879804, 0.325171473334544]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 324.00000000000506\n",
            "0 0\n",
            "\n"
          ]
        },
        {
          "output_type": "error",
          "ename": "KeyboardInterrupt",
          "evalue": "ignored",
          "traceback": [
            "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
            "\u001b[0;31mKeyboardInterrupt\u001b[0m                         Traceback (most recent call last)",
            "\u001b[0;32m<ipython-input-7-eebcfad30a2d>\u001b[0m in \u001b[0;36m<module>\u001b[0;34m()\u001b[0m\n\u001b[1;32m    132\u001b[0m \u001b[0;31m# env.build_env1()\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    133\u001b[0m \u001b[0mducb\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mDUCB_Sampling\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0menv\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;36m0.10\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m\"global\"\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 134\u001b[0;31m \u001b[0mducb\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mrun_DUCB_sampling\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    135\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    136\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;32m<ipython-input-7-eebcfad30a2d>\u001b[0m in \u001b[0;36mrun_DUCB_sampling\u001b[0;34m(self)\u001b[0m\n\u001b[1;32m    124\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    125\u001b[0m       \u001b[0mprint\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mtr\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mend\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;34m\", \"\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 126\u001b[0;31m       \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mrun_algorithm\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mtr\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    127\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    128\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;32m<ipython-input-7-eebcfad30a2d>\u001b[0m in \u001b[0;36mrun_algorithm\u001b[0;34m(self, tr)\u001b[0m\n\u001b[1;32m     80\u001b[0m         \u001b[0mbeta_ucb\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;36m2.0\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msqrt\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;36m2.0\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mlog\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mt\u001b[0m\u001b[0;34m+\u001b[0m\u001b[0;36m1.0\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m/\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msum\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mnumplays\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mint\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mts\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mk\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mt\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mk\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;34m+\u001b[0m \u001b[0;36m1\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     81\u001b[0m         \u001b[0;31m#print(beta_ucb)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 82\u001b[0;31m         \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mucb\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mk\u001b[0m\u001b[0;34m]\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msum\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mreward_arm\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mint\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mts\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mk\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mt\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mk\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m/\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msum\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mnumplays\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mint\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mts\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mk\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mt\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mk\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;34m+\u001b[0m \u001b[0;36m1\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;34m+\u001b[0m \u001b[0mbeta_ucb\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     83\u001b[0m         \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mlcb\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mk\u001b[0m\u001b[0;34m]\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mmax\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;36m0.0\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msum\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mreward_arm\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mint\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mts\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mk\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mt\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mk\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m/\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msum\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mnumplays\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mint\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mts\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mk\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mt\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mk\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;34m+\u001b[0m \u001b[0;36m1\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;34m-\u001b[0m \u001b[0mbeta_ucb\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     84\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;31mKeyboardInterrupt\u001b[0m: "
          ]
        }
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "kocSSz4M5AI5"
      },
      "source": [
        "# UCB-CPD"
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 837
        },
        "id": "T-Php5-r5GWK",
        "outputId": "2a8d96db-f025-493a-d50d-6496d5775844"
      },
      "source": [
        "import numpy as np\n",
        "\n",
        "class UCB_Sampling(object):\n",
        "\n",
        "  def __init__(self, env, confidence, type_):\n",
        "    \n",
        "    \n",
        "    self.env = env\n",
        "    self.confidence = confidence\n",
        "    \n",
        "    self.K = env.K\n",
        "    self.T = env.T\n",
        "    self.trials = env.trials\n",
        "\n",
        "\n",
        "    self.mu_hat = np.zeros((self.T, self.K))\n",
        "    self.sumreward = np.zeros((self.T, self.K))\n",
        "    self.reward_arm = np.zeros((self.T, self.K))\n",
        "    self.numplays = np.zeros((self.T, self.K))\n",
        "    \n",
        "    self.tol = 0.01\n",
        "    self.gamma = 0.01\n",
        "    \n",
        "    self.budget = 0\n",
        "    self.budget_error = 0\n",
        "    self.alpha = 0.7\n",
        "\n",
        "    self.estimated_G = np.zeros(self.K)\n",
        "    self.type_ = type_\n",
        "    \n",
        "    \n",
        "    \n",
        "    self.error = np.zeros((self.trials, self.T))\n",
        "  \n",
        "\n",
        "  def detect_changepoint(self, ts, tp):\n",
        "\n",
        "   \n",
        "\n",
        "    for k in range(self.K):\n",
        "      \n",
        "      #print(tp)\n",
        "      for t_ in range(int(ts[k])+1,self.t):\n",
        "\n",
        "        self.confidence = 1.0/self.t\n",
        "        beta_ts = np.sqrt(0.5*np.log(np.log(self.t+1)/self.confidence)/(np.sum(self.numplays[int(ts[k]):t_, k]) + 1))\n",
        "        beta_tp = np.sqrt(0.5*np.log(np.log(self.t+1)/self.confidence)/(np.sum(self.numplays[t_:self.t, k]) + 1))\n",
        "\n",
        "        if (np.sum(self.reward_arm[int(ts[k]):t_, k])/(np.sum(self.numplays[int(ts[k]):t_, k])+1) - beta_ts > np.sum(self.reward_arm[t_:self.t, k])/(np.sum(self.numplays[t_:self.t, k]) + 1) + beta_tp) \\\n",
        "          or (np.sum(self.reward_arm[int(ts[k]):t_, k])/(np.sum(self.numplays[int(ts[k]):t_, k]) + 1) + beta_ts < np.sum(self.reward_arm[t_:self.t, k])/(np.sum(self.numplays[t_:self.t, k]) + 1) - beta_tp): \n",
        "            \n",
        "         \n",
        "\n",
        "          if self.type_ == \"global\":\n",
        "            for k1 in range(self.K):\n",
        "\n",
        "              self.estimated_G[k1] += 1\n",
        "\n",
        "              #print(self.mu_hat[int(ts[k1]): int(tp[k1]), k1])\n",
        "              self.mu_hat[int(ts[k1]): self.t, k1] = 0.0\n",
        "              #print(self.mu_hat[int(ts[k1]): int(tp[k1]), k1])\n",
        "              self.numplays[int(ts[k1]): self.t, k1] = 0\n",
        "              self.sumreward[int(ts[k1]): self.t, k1] = 0.0\n",
        "              self.reward_arm[int(ts[k1]): self.t, k1] = 0.0\n",
        "              self.ts[k1] = self.t\n",
        "\n",
        "              #print(self.reward_arm[0: self.t, k])\n",
        "            print(\"Global Changepoint Detected at time \" + str(self.t))\n",
        "            \n",
        "            break\n",
        "          \n",
        "          else:\n",
        "            \n",
        "            self.estimated_G[k] += 1\n",
        "            self.mu_hat[int(ts[k]): self.t, k] = 0.0\n",
        "            self.numplays[int(ts[k]): self.t, k] = 0\n",
        "            self.sumreward[int(ts[k]): self.t, k] = 0.0\n",
        "            self.reward_arm[int(ts[k]): self.t, k] = 0.0\n",
        "            self.ts[k] = self.t\n",
        "\n",
        "            \n",
        "\n",
        "            print(\"Arm \"+ str(k) +\" Changepoint Detected at time \" + str(self.t))\n",
        "            continue\n",
        "\n",
        "\n",
        "\n",
        "  def run_algorithm(self, tr):\n",
        "\n",
        "    self.seed = tr\n",
        "    np.random.seed(self.seed)\n",
        "    self.t = 0\n",
        "    self.ts = np.zeros(self.K)\n",
        "    self.tp = np.zeros(self.K)\n",
        "\n",
        "    self.mu_hat = np.zeros((self.T, self.K))\n",
        "    self.sumreward = np.zeros((self.T, self.K))\n",
        "    self.reward_arm = np.zeros((self.T, self.K))\n",
        "    self.numplays = np.zeros((self.T, self.K))\n",
        "\n",
        "    #Sample each arm once\n",
        "    \n",
        "\n",
        "    for i in range(0,self.K):\n",
        "      \n",
        "      arm = i\n",
        "      reward = self.env.pull_arm(arm, self.t)\n",
        "      #self.sumreward[self.t][arm] += reward\n",
        "      self.reward_arm[self.t][arm] = reward\n",
        "      self.numplays[self.t][arm] = 1\n",
        "      #self.mu_hat[self.t][arm] = self.sumreward[self.t][arm]/self.numplays[self.t][arm]\n",
        "\n",
        "      self.tp[arm] += 1\n",
        "\n",
        "      self.t += 1\n",
        "\n",
        "\n",
        "\n",
        "    sum1 = 0.0\n",
        "    self.ucb = np.zeros(self.K)\n",
        "    self.lcb = np.zeros(self.K)\n",
        "\n",
        "    while self.t < self.T:\n",
        "      \n",
        "      for k in range(self.K):\n",
        "\n",
        "        beta_ucb = np.sqrt(1.0*np.log(np.log(self.t+1)/self.confidence)/(np.sum(self.numplays[int(self.ts[k]):self.t, k]) + 1))\n",
        "        self.ucb[k] = np.sum(self.reward_arm[int(self.ts[k]):self.t, k])/(np.sum(self.numplays[int(self.ts[k]):self.t, k]) + 1) + beta_ucb\n",
        "        self.lcb[k] = max(0.0,np.sum(self.reward_arm[int(self.ts[k]):self.t, k])/(np.sum(self.numplays[int(self.ts[k]):self.t, k]) + 1) - beta_ucb)\n",
        "\n",
        "      arm = np.argmax(self.ucb)\n",
        "\n",
        "      reward = self.env.pull_arm(arm, self.t)\n",
        "      #self.sumreward[self.t][arm] += reward\n",
        "      self.reward_arm[self.t][arm] = reward\n",
        "      self.numplays[self.t][arm] = 1\n",
        "      #self.mu_hat[self.t][arm] = self.sumreward[self.t][arm]/self.numplays[self.t][arm]\n",
        "      self.mu_hat[self.t, :] = [np.sum(self.reward_arm[int(self.ts[i]):self.t,i])/(np.sum(self.numplays[int(self.ts[i]):self.t,i]) + 1 ) for i in range(self.K)]\n",
        "      \n",
        "      self.tp[arm] += 1\n",
        "      #print(\"t:\"+str(self.numplays[self.t]))\n",
        "      # if self.t > 1.0*self.K:\n",
        "      #   #print(t)\n",
        "\n",
        "      self.budget +=  self.lcb[arm] + self.lcb[np.argmax(self.ucb)] - (1.0 - self.alpha)*self.ucb[np.argmin(self.env.safe_arm_t[self.t])]\n",
        "      \n",
        "\n",
        "      if self.t%20 == 0:\n",
        "        self.detect_changepoint(self.ts, self.tp)\n",
        "      \n",
        "      \n",
        "\n",
        "      error1 = 0\n",
        "      \n",
        "      #max(-1.0*self.budget_error,0.0)\n",
        "      error1 = self.env.mu_t[self.t][np.argmax(self.env.mu_t[self.t])] - self.env.mu_t[self.t][arm] + max(self.budget_error, 0.0)\n",
        "      #print(self.env.mu_t[self.t][np.argmax(self.env.mu_t[self.t])], self.env.mu_t[self.t][arm])\n",
        "      sum1 += error1\n",
        "      self.error[tr][self.t] =  sum1\n",
        "      #print(self.t,sum1)   \n",
        "      \n",
        "      if self.t%100 == 0 and self.t > 2.0*self.K:\n",
        "        print(\"t \" +str(self.t))\n",
        "        print(\"t reward-arm: \" + str([np.sum(self.reward_arm[int(self.ts[i]):self.t,i]) for i in range(self.K)]   ))\n",
        "        \n",
        "        print(\"t numplay: \" + str([np.sum(self.numplays[int(self.ts[i]):self.t,i]) for i in range(self.K)]   ), str(np.sum(self.numplays[int(self.ts[i]):self.t,:])))\n",
        "        print(\"t mu-hat: \" + str([np.sum(self.reward_arm[int(self.ts[i]):self.t,i])/(np.sum(self.numplays[int(self.ts[i]):self.t,i]) + 1 ) for i in range(self.K)]   ))\n",
        "        print(\"T true mu: \" + str(self.env.mu_t[self.t]) + \" Err: \" + str(self.error[tr][self.t]))\n",
        "        print(np.argmax(self.mu_hat[self.t]), np.argmax(self.env.mu_t[self.t]))\n",
        "        print(self.budget, self.budget_error)\n",
        "        print()\n",
        "      \n",
        "      self.t += 1\n",
        "\n",
        "  def run_UCB_sampling(self, ):\n",
        "\n",
        "    for tr in range(0,self.trials):\n",
        "      \n",
        "      print(tr, end=\", \")\n",
        "      self.run_algorithm(tr)\n",
        "\n",
        "\n",
        "# T = 8000\n",
        "# trials = 10\n",
        "# env = build_environment(5, 0.4, T, trials)\n",
        "# env.build_env1()\n",
        "ucb = UCB_Sampling(env, 0.10, \"global\")\n",
        "ucb.run_UCB_sampling()\n",
        "\n",
        "\n"
      ],
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "0, t 100\n",
            "t reward-arm: [1.3268474399887056, 2.6465121526003457, 7.292238350434541, 16.811360030770615, 21.96979064998937, 2.9513315315612765]\n",
            "t numplay: [7.0, 9.0, 15.0, 27.0, 33.0, 9.0] 100.0\n",
            "t mu-hat: [0.1658559299985882, 0.26465121526003454, 0.4557648969021588, 0.6004057153846648, 0.6461703132349815, 0.29513315315612765]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 11.600000000000009\n",
            "4 4\n",
            "-26.12014957180177 0\n",
            "\n",
            "t 200\n",
            "t reward-arm: [2.31738496949273, 4.0651663372403375, 13.383023415274259, 37.866976983399205, 45.81152371626938, 5.824134441147317]\n",
            "t numplay: [11.0, 14.0, 28.0, 60.0, 70.0, 17.0] 200.0\n",
            "t mu-hat: [0.19311541412439417, 0.27101108914935584, 0.46148356604394, 0.6207701144819542, 0.6452327283981603, 0.32356302450818425]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 20.90000000000003\n",
            "4 4\n",
            "-19.20153943141332 0\n",
            "\n",
            "t 300\n",
            "t reward-arm: [2.5617327555615717, 5.1637790600611675, 20.77251768147387, 54.35930861217775, 76.56385709565556, 6.804692052296667]\n",
            "t numplay: [14.0, 18.0, 42.0, 88.0, 117.0, 21.0] 300.0\n",
            "t mu-hat: [0.17078218370410478, 0.2717778452663772, 0.483081806545904, 0.6107787484514354, 0.6488462465733522, 0.30930418419530303]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 28.300000000000036\n",
            "4 4\n",
            "6.123832810871331 0\n",
            "\n"
          ]
        },
        {
          "output_type": "error",
          "ename": "KeyboardInterrupt",
          "evalue": "ignored",
          "traceback": [
            "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
            "\u001b[0;31mKeyboardInterrupt\u001b[0m                         Traceback (most recent call last)",
            "\u001b[0;32m<ipython-input-8-d93eaccebf36>\u001b[0m in \u001b[0;36m<module>\u001b[0;34m()\u001b[0m\n\u001b[1;32m    185\u001b[0m \u001b[0;31m# env.build_env1()\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    186\u001b[0m \u001b[0mucb\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mUCB_Sampling\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0menv\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;36m0.10\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m\"global\"\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 187\u001b[0;31m \u001b[0mucb\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mrun_UCB_sampling\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    188\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    189\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;32m<ipython-input-8-d93eaccebf36>\u001b[0m in \u001b[0;36mrun_UCB_sampling\u001b[0;34m(self)\u001b[0m\n\u001b[1;32m    177\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    178\u001b[0m       \u001b[0mprint\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mtr\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mend\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;34m\", \"\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 179\u001b[0;31m       \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mrun_algorithm\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mtr\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    180\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    181\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;32m<ipython-input-8-d93eaccebf36>\u001b[0m in \u001b[0;36mrun_algorithm\u001b[0;34m(self, tr)\u001b[0m\n\u001b[1;32m    135\u001b[0m       \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mnumplays\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mt\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0marm\u001b[0m\u001b[0;34m]\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;36m1\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    136\u001b[0m       \u001b[0;31m#self.mu_hat[self.t][arm] = self.sumreward[self.t][arm]/self.numplays[self.t][arm]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 137\u001b[0;31m       \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mmu_hat\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mt\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m:\u001b[0m\u001b[0;34m]\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;34m[\u001b[0m\u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msum\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mreward_arm\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mint\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mts\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mi\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mt\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0mi\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m/\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msum\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mnumplays\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mint\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mts\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mi\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mt\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0mi\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;34m+\u001b[0m \u001b[0;36m1\u001b[0m \u001b[0;34m)\u001b[0m \u001b[0;32mfor\u001b[0m \u001b[0mi\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mrange\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mK\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    138\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    139\u001b[0m       \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mtp\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0marm\u001b[0m\u001b[0;34m]\u001b[0m \u001b[0;34m+=\u001b[0m \u001b[0;36m1\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;31mKeyboardInterrupt\u001b[0m: "
          ]
        }
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "D5J2QUUZYDOk"
      },
      "source": [
        "# GLR-UCB"
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 854
        },
        "id": "agNiv1OkYIFm",
        "outputId": "b151fe73-ca1f-4a6b-c352-2e34f2fe84fc"
      },
      "source": [
        "import numpy as np\n",
        "import math\n",
        "\n",
        "class GLR_UCB_Sampling(object):\n",
        "\n",
        "  def __init__(self, env, confidence, type_):\n",
        "    \n",
        "    \n",
        "    self.env = env\n",
        "    self.confidence = confidence\n",
        "    \n",
        "    self.K = env.K\n",
        "    self.T = env.T\n",
        "    self.trials = env.trials\n",
        "\n",
        "\n",
        "    self.mu_hat = np.zeros((self.T, self.K))\n",
        "    self.sumreward = np.zeros((self.T, self.K))\n",
        "    self.reward_arm = np.zeros((self.T, self.K))\n",
        "    self.numplays = np.zeros((self.T, self.K))\n",
        "    \n",
        "    self.tol = 0.01\n",
        "    self.gamma = 0.01\n",
        "    \n",
        "    self.budget = 0\n",
        "    self.budget_error = 0\n",
        "    self.alpha = 0.7\n",
        "\n",
        "    self.estimated_G = np.zeros(self.K)\n",
        "    self.type_ = type_\n",
        "    \n",
        "    \n",
        "    \n",
        "    self.error = np.zeros((self.trials, self.T))\n",
        "  \n",
        "  def klGauss(self, x, y, sig2 = 0.1):\n",
        "        \"\"\"caution modified\"\"\"\n",
        "        \"\"\"Kullback-Leibler divergence for Gaussian distributions.\"\"\"\n",
        "        return ((x-y)*(x-y))/(2*sig2)\n",
        "\n",
        "  def klucbGauss(self, x, d, sig2=1., precision=0.):\n",
        "      \"\"\"klUCB index computation for Gaussian distributions.\n",
        "    \n",
        "      Note that it does not require any search.\n",
        "      \"\"\"\n",
        "      #print 2.0*sig2*d, x\n",
        "      return x + math.sqrt(2.0*sig2*d)\n",
        "\n",
        "  def klucb(self, x, d, upperbound, lowerbound=-float('inf'), precision=1e-6):\n",
        "    \n",
        "        \"\"\"The generic klUCB index computation.\n",
        "    \n",
        "        Input args.: x, d, div, upperbound, lowerbound=-float('inf'), precision=1e-6,\n",
        "        where div is the KL divergence to be used.\n",
        "        \"\"\"\n",
        "        l = max(x, lowerbound)\n",
        "        u = upperbound\n",
        "        while u-l > precision:\n",
        "            m = (l+u)/2\n",
        "            if self.klGauss(x, m) > d:\n",
        "                u = m\n",
        "            else:\n",
        "                l = m\n",
        "        return (l+u)/2\n",
        "\n",
        "  def detect_changepoint(self, ts, tp):\n",
        "\n",
        "   \n",
        "\n",
        "    for k in range(self.K):\n",
        "      \n",
        "      #print(tp)\n",
        "      kl_list = []\n",
        "      for t_ in range(int(ts[k])+1,self.t):\n",
        "\n",
        "        \n",
        "        emp_mean_ts = np.sum(self.reward_arm[int(ts[k]):t_, k])/(np.sum(self.numplays[int(ts[k]):t_, k])+1)\n",
        "        emp_mean_tp = np.sum(self.reward_arm[t_:self.t, k])/(np.sum(self.numplays[t_:self.t, k]) + 1)\n",
        "        emp_mean_tot = np.sum(self.reward_arm[int(ts[k]):self.t, k])/(np.sum(self.numplays[int(ts[k]):self.t, k]) + 1)\n",
        "\n",
        "        s = np.sum(self.numplays[int(ts[k]):t_, k])+1\n",
        "        n = (np.sum(self.numplays[t_:self.t, k]) + 1)\n",
        "        n_s = n - s\n",
        "\n",
        "        #kl_list.append(s*self.klucb(emp_mean_ts, emp_mean_tot, 1e-4) + n_s*self.klucb(emp_mean_tp, emp_mean_tot, 1e-4))\n",
        "        kl_list.append(s*self.klGauss(emp_mean_ts, emp_mean_tot) + n_s*self.klGauss(emp_mean_tp, emp_mean_tot))\n",
        "      \n",
        "      self.confidence = 1.0/self.t\n",
        "      self.conf_inf = 1.0*np.log(3.0*math.pow(self.t,3.0/2.0)/self.confidence)\n",
        "      #self.conf_inf = 8.0*np.log(3.0*self.t)\n",
        "\n",
        "\n",
        "      if max(kl_list) > self.conf_inf:\n",
        "        \n",
        "        #if s*self.klGauss(emp_mean_ts, emp_mean_tot) + n_s*self.klGauss(emp_mean_tp, emp_mean_tot) > self.conf_inf:\n",
        "          if self.type_ == \"global\":\n",
        "            for k1 in range(self.K):\n",
        "\n",
        "              self.estimated_G[k1] += 1\n",
        "\n",
        "              #print(self.mu_hat[int(ts[k1]): int(tp[k1]), k1])\n",
        "              self.mu_hat[int(ts[k1]): self.t, k1] = 0.0\n",
        "              #print(self.mu_hat[int(ts[k1]): int(tp[k1]), k1])\n",
        "              self.numplays[int(ts[k1]): self.t, k1] = 0\n",
        "              self.sumreward[int(ts[k1]): self.t, k1] = 0.0\n",
        "              self.reward_arm[int(ts[k1]): self.t, k1] = 0.0\n",
        "              self.ts[k1] = self.t\n",
        "\n",
        "              #print(self.reward_arm[0: self.t, k])\n",
        "            print(\"Global Changepoint Detected at time \" + str(self.t))\n",
        "            \n",
        "            break\n",
        "          \n",
        "          else:\n",
        "            \n",
        "            self.estimated_G[k] += 1\n",
        "            self.mu_hat[int(ts[k]): self.t, k] = 0.0\n",
        "            self.numplays[int(ts[k]): self.t, k] = 0\n",
        "            self.sumreward[int(ts[k]): self.t, k] = 0.0\n",
        "            self.reward_arm[int(ts[k]): self.t, k] = 0.0\n",
        "            self.ts[k] = self.t\n",
        "\n",
        "            \n",
        "\n",
        "            print(\"Arm \"+ str(k) +\" Changepoint Detected at time \" + str(self.t))\n",
        "            continue\n",
        "\n",
        "\n",
        "\n",
        "  def run_algorithm(self, tr):\n",
        "\n",
        "    self.seed = tr\n",
        "    np.random.seed(self.seed)\n",
        "    self.t = 0\n",
        "    self.ts = np.zeros(self.K)\n",
        "    self.tp = np.zeros(self.K)\n",
        "\n",
        "    self.mu_hat = np.zeros((self.T, self.K))\n",
        "    self.sumreward = np.zeros((self.T, self.K))\n",
        "    self.reward_arm = np.zeros((self.T, self.K))\n",
        "    self.numplays = np.zeros((self.T, self.K))\n",
        "    \n",
        "    #Sample each arm once\n",
        "    \n",
        "\n",
        "    for i in range(0,self.K):\n",
        "      \n",
        "      arm = i\n",
        "      reward = self.env.pull_arm(arm, self.t)\n",
        "      #self.sumreward[self.t][arm] += reward\n",
        "      self.reward_arm[self.t][arm] = reward\n",
        "      self.numplays[self.t][arm] = 1\n",
        "      #self.mu_hat[self.t][arm] = self.sumreward[self.t][arm]/self.numplays[self.t][arm]\n",
        "\n",
        "      self.tp[arm] += 1\n",
        "\n",
        "      self.t += 1\n",
        "\n",
        "\n",
        "\n",
        "    sum1 = 0.0\n",
        "    self.ucb = np.zeros(self.K)\n",
        "    self.lcb = np.zeros(self.K)\n",
        "    self.gamma = np.sqrt(np.log(self.T)/self.T)\n",
        "\n",
        "    while self.t < self.T:\n",
        "      \n",
        "      for k in range(self.K):\n",
        "\n",
        "        beta_ucb = np.sqrt(1.0*np.log(np.log(self.t+1)/self.confidence)/(np.sum(self.numplays[int(self.ts[k]):self.t, k]) + 1))\n",
        "        self.ucb[k] = np.sum(self.reward_arm[int(self.ts[k]):self.t, k])/(np.sum(self.numplays[int(self.ts[k]):self.t, k]) + 1) + beta_ucb\n",
        "        self.lcb[k] = max(0.0,np.sum(self.reward_arm[int(self.ts[k]):self.t, k])/(np.sum(self.numplays[int(self.ts[k]):self.t, k]) + 1) - beta_ucb)\n",
        "\n",
        "      \n",
        "      if self.t% (self.K/self.gamma) <= self.K:\n",
        "        arm = np.random.randint(0, self.K-1)\n",
        "        #print(\"fe\", arm, self.t% (self.K/self.gamma))\n",
        "      else:\n",
        "        arm = np.argmax(self.ucb)\n",
        "\n",
        "      reward = self.env.pull_arm(arm, self.t)\n",
        "      #self.sumreward[self.t][arm] += reward\n",
        "      self.reward_arm[self.t][arm] = reward\n",
        "      self.numplays[self.t][arm] = 1\n",
        "      #self.mu_hat[self.t][arm] = self.sumreward[self.t][arm]/self.numplays[self.t][arm]\n",
        "      self.mu_hat[self.t, :] = [np.sum(self.reward_arm[int(self.ts[i]):self.t,i])/(np.sum(self.numplays[int(self.ts[i]):self.t,i]) + 1 ) for i in range(self.K)]\n",
        "      \n",
        "      self.tp[arm] += 1\n",
        "      #print(\"t:\"+str(self.numplays[self.t]))\n",
        "      # if self.t > 1.0*self.K:\n",
        "      #   #print(t)\n",
        "\n",
        "      self.budget +=  self.lcb[arm] + self.lcb[np.argmax(self.ucb)] - (1.0 - self.alpha)*self.ucb[np.argmin(self.env.safe_arm_t[self.t])]\n",
        "      \n",
        "      if self.t%20 == 0:\n",
        "        self.detect_changepoint(self.ts, self.tp)\n",
        "      \n",
        "      \n",
        "\n",
        "      error1 = 0\n",
        "      \n",
        "      #max(-1.0*self.budget_error,0.0)\n",
        "      error1 = self.env.mu_t[self.t][np.argmax(self.env.mu_t[self.t])] - self.env.mu_t[self.t][arm] + max(self.budget_error, 0.0)\n",
        "      #print(self.env.mu_t[self.t][np.argmax(self.env.mu_t[self.t])], self.env.mu_t[self.t][arm])\n",
        "      sum1 += error1\n",
        "      self.error[tr][self.t] =  sum1\n",
        "      #print(self.t,sum1)   \n",
        "      \n",
        "      if self.t%100 == 0 and self.t > 2.0*self.K:\n",
        "        print(\"t \" +str(self.t))\n",
        "        print(\"t reward-arm: \" + str([np.sum(self.reward_arm[int(self.ts[i]):self.t,i]) for i in range(self.K)]   ))\n",
        "        \n",
        "        print(\"t numplay: \" + str([np.sum(self.numplays[int(self.ts[i]):self.t,i]) for i in range(self.K)]   ), str(np.sum(self.numplays[int(self.ts[i]):self.t,:])))\n",
        "        print(\"t mu-hat: \" + str([np.sum(self.reward_arm[int(self.ts[i]):self.t,i])/(np.sum(self.numplays[int(self.ts[i]):self.t,i]) + 1 ) for i in range(self.K)]   ))\n",
        "        print(\"T true mu: \" + str(self.env.mu_t[self.t]) + \" Err: \" + str(self.error[tr][self.t]))\n",
        "        print(np.argmax(self.mu_hat[self.t]), np.argmax(self.env.mu_t[self.t]))\n",
        "        print(self.budget, self.budget_error)\n",
        "        print()\n",
        "      \n",
        "      self.t += 1\n",
        "\n",
        "  def run_GLR_UCB_sampling(self, ):\n",
        "\n",
        "    for tr in range(0,self.trials):\n",
        "      \n",
        "      print(tr, end=\", \")\n",
        "      self.run_algorithm(tr)\n",
        "\n",
        "\n",
        "# T = 8000\n",
        "# trials = 10\n",
        "# env = build_environment(5, 0.4, T, trials)\n",
        "# env.build_env1()\n",
        "glrucb = GLR_UCB_Sampling(env, 0.10, \"global\")\n",
        "glrucb.run_GLR_UCB_sampling()\n",
        "\n",
        "\n"
      ],
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "0, t 100\n",
            "t reward-arm: [1.6559794307212679, 3.5050850592008693, 11.147188622943112, 14.397734565866132, 18.44224205369738, 3.4812115907461063]\n",
            "t numplay: [7.0, 10.0, 20.0, 24.0, 29.0, 10.0] 100.0\n",
            "t mu-hat: [0.20699742884015848, 0.3186440962909881, 0.5308185058544339, 0.5759093826346453, 0.6147414017899127, 0.31647378097691875]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 13.00000000000001\n",
            "4 4\n",
            "-30.178892501003208 0\n",
            "\n",
            "t 200\n",
            "t reward-arm: [2.284775198646644, 4.609945146412395, 18.32512119446198, 28.792261188373942, 44.200723677700054, 7.665438258579374]\n",
            "t numplay: [12.0, 15.0, 35.0, 49.0, 69.0, 20.0] 200.0\n",
            "t mu-hat: [0.17575193835743413, 0.2881215716507747, 0.5090311442906105, 0.5758452237674788, 0.6314389096814294, 0.36502086945616063]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 23.100000000000023\n",
            "4 4\n",
            "-29.65140890001535 0\n",
            "\n",
            "t 300\n",
            "t reward-arm: [2.5991343301352163, 5.666492291317583, 25.79224911981879, 48.287983697985084, 70.23769575420275, 9.749074313016939]\n",
            "t numplay: [14.0, 19.0, 50.0, 81.0, 110.0, 26.0] 300.0\n",
            "t mu-hat: [0.17327562200901442, 0.28332461456587915, 0.5057303748984077, 0.5888778499754278, 0.6327720338216464, 0.3610768264080348]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 31.350000000000033\n",
            "4 4\n",
            "-9.588100894019394 0\n",
            "\n"
          ]
        },
        {
          "output_type": "error",
          "ename": "KeyboardInterrupt",
          "evalue": "ignored",
          "traceback": [
            "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
            "\u001b[0;31mKeyboardInterrupt\u001b[0m                         Traceback (most recent call last)",
            "\u001b[0;32m<ipython-input-9-71598c3d0190>\u001b[0m in \u001b[0;36m<module>\u001b[0;34m()\u001b[0m\n\u001b[1;32m    233\u001b[0m \u001b[0;31m# env.build_env1()\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    234\u001b[0m \u001b[0mglrucb\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mGLR_UCB_Sampling\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0menv\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;36m0.10\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m\"global\"\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 235\u001b[0;31m \u001b[0mglrucb\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mrun_GLR_UCB_sampling\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    236\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    237\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;32m<ipython-input-9-71598c3d0190>\u001b[0m in \u001b[0;36mrun_GLR_UCB_sampling\u001b[0;34m(self)\u001b[0m\n\u001b[1;32m    225\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    226\u001b[0m       \u001b[0mprint\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mtr\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mend\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;34m\", \"\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 227\u001b[0;31m       \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mrun_algorithm\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mtr\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    228\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    229\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;32m<ipython-input-9-71598c3d0190>\u001b[0m in \u001b[0;36mrun_algorithm\u001b[0;34m(self, tr)\u001b[0m\n\u001b[1;32m    194\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    195\u001b[0m       \u001b[0;32mif\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mt\u001b[0m\u001b[0;34m%\u001b[0m\u001b[0;36m20\u001b[0m \u001b[0;34m==\u001b[0m \u001b[0;36m0\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 196\u001b[0;31m         \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mdetect_changepoint\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mts\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mtp\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    197\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    198\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;32m<ipython-input-9-71598c3d0190>\u001b[0m in \u001b[0;36mdetect_changepoint\u001b[0;34m(self, ts, tp)\u001b[0m\n\u001b[1;32m     76\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     77\u001b[0m         \u001b[0memp_mean_ts\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msum\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mreward_arm\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mint\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mts\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mk\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0mt_\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mk\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m/\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msum\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mnumplays\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mint\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mts\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mk\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0mt_\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mk\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m+\u001b[0m\u001b[0;36m1\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 78\u001b[0;31m         \u001b[0memp_mean_tp\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msum\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mreward_arm\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mt_\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mt\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mk\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m/\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msum\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mnumplays\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mt_\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mt\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mk\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;34m+\u001b[0m \u001b[0;36m1\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     79\u001b[0m         \u001b[0memp_mean_tot\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msum\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mreward_arm\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mint\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mts\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mk\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mt\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mk\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m/\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msum\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mnumplays\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mint\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mts\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mk\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mt\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mk\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;34m+\u001b[0m \u001b[0;36m1\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     80\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;32m<__array_function__ internals>\u001b[0m in \u001b[0;36msum\u001b[0;34m(*args, **kwargs)\u001b[0m\n",
            "\u001b[0;32m/usr/local/lib/python3.7/dist-packages/numpy/core/fromnumeric.py\u001b[0m in \u001b[0;36msum\u001b[0;34m(a, axis, dtype, out, keepdims, initial, where)\u001b[0m\n\u001b[1;32m   2240\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   2241\u001b[0m     return _wrapreduction(a, np.add, 'sum', axis, dtype, out, keepdims=keepdims,\n\u001b[0;32m-> 2242\u001b[0;31m                           initial=initial, where=where)\n\u001b[0m\u001b[1;32m   2243\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   2244\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;32m/usr/local/lib/python3.7/dist-packages/numpy/core/fromnumeric.py\u001b[0m in \u001b[0;36m_wrapreduction\u001b[0;34m(obj, ufunc, method, axis, dtype, out, **kwargs)\u001b[0m\n\u001b[1;32m     85\u001b[0m                 \u001b[0;32mreturn\u001b[0m \u001b[0mreduction\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0maxis\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0maxis\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mout\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mout\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mpasskwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     86\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 87\u001b[0;31m     \u001b[0;32mreturn\u001b[0m \u001b[0mufunc\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mreduce\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mobj\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0maxis\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mdtype\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mout\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mpasskwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     88\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     89\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;31mKeyboardInterrupt\u001b[0m: "
          ]
        }
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "W5_QHVZSDHzt"
      },
      "source": [
        "# Conservative-UCB"
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 1000
        },
        "id": "bhwqvotODMnV",
        "outputId": "977778fc-0cc0-4116-8f33-47de92f84196"
      },
      "source": [
        "import numpy as np\n",
        "\n",
        "class CUCB_Sampling(object):\n",
        "\n",
        "  def __init__(self, env, confidence, alpha, type_):\n",
        "    \n",
        "    \n",
        "    self.env = env\n",
        "    self.confidence = confidence\n",
        "    \n",
        "    self.K = env.K\n",
        "    self.T = env.T\n",
        "    self.trials = env.trials\n",
        "\n",
        "\n",
        "    self.mu_hat = np.zeros((self.T, self.K))\n",
        "    self.sumreward = np.zeros((self.T, self.K))\n",
        "    self.reward_arm = np.zeros((self.T, self.K))\n",
        "    self.numplays = np.zeros((self.T, self.K))\n",
        "    \n",
        "    self.tol = 0.01\n",
        "    self.gamma = 0.01\n",
        "    \n",
        "    self.budget = 0\n",
        "    self.budget_error = 0\n",
        "    self.alpha = 0.7\n",
        "\n",
        "    self.estimated_G = np.zeros(self.K)\n",
        "    self.type_ = type_\n",
        "    \n",
        "    \n",
        "    \n",
        "    self.error = np.zeros((self.trials, self.T))\n",
        "  \n",
        "\n",
        "  def detect_changepoint(self, ts, tp):\n",
        "\n",
        "   \n",
        "\n",
        "    for k in range(self.K):\n",
        "      \n",
        "      #print(tp)\n",
        "      for t_ in range(int(ts[k])+1,self.t):\n",
        "\n",
        "        \n",
        "        beta_ts = np.sqrt(0.5*np.log((self.t+1)/self.confidence)/(np.sum(self.numplays[int(ts[k]):t_, k]) + 1))\n",
        "        beta_tp = np.sqrt(0.5*np.log((self.t+1)/self.confidence)/(np.sum(self.numplays[t_:self.t, k]) + 1))\n",
        "\n",
        "        if (np.sum(self.reward_arm[int(ts[k]):t_, k])/(np.sum(self.numplays[int(ts[k]):t_, k])+1) - beta_ts > np.sum(self.reward_arm[t_:self.t, k])/(np.sum(self.numplays[t_:self.t, k]) + 1) + beta_tp) \\\n",
        "          or (np.sum(self.reward_arm[int(ts[k]):t_, k])/(np.sum(self.numplays[int(ts[k]):t_, k]) + 1) + beta_ts < np.sum(self.reward_arm[t_:self.t, k])/(np.sum(self.numplays[t_:self.t, k]) + 1) - beta_tp): \n",
        "            \n",
        "         \n",
        "\n",
        "          if self.type_ == \"global\":\n",
        "            for k1 in range(self.K):\n",
        "\n",
        "              self.estimated_G[k1] += 1\n",
        "\n",
        "              #print(self.mu_hat[int(ts[k1]): int(tp[k1]), k1])\n",
        "              self.mu_hat[int(ts[k1]): self.t, k1] = 0.0\n",
        "              #print(self.mu_hat[int(ts[k1]): int(tp[k1]), k1])\n",
        "              self.numplays[int(ts[k1]): self.t, k1] = 0\n",
        "              self.sumreward[int(ts[k1]): self.t, k1] = 0.0\n",
        "              self.reward_arm[int(ts[k1]): self.t, k1] = 0.0\n",
        "              self.ts[k1] = self.t\n",
        "\n",
        "              #print(self.reward_arm[0: self.t, k])\n",
        "            print(\"Global Changepoint Detected at time \" + str(self.t))\n",
        "            \n",
        "            return True\n",
        "          \n",
        "          else:\n",
        "            \n",
        "            self.estimated_G[k] += 1\n",
        "            self.mu_hat[int(ts[k]): self.t, k] = 0.0\n",
        "            self.numplays[int(ts[k]): self.t, k] = 0\n",
        "            self.sumreward[int(ts[k]): self.t, k] = 0.0\n",
        "            self.reward_arm[int(ts[k]): self.t, k] = 0.0\n",
        "            self.ts[k] = self.t\n",
        "\n",
        "            \n",
        "\n",
        "            print(\"Arm \"+ str(k) +\" Changepoint Detected at time \" + str(self.t))\n",
        "            continue\n",
        "\n",
        "\n",
        "\n",
        "  def run_algorithm(self, tr):\n",
        "\n",
        "    self.seed = tr\n",
        "    np.random.seed(self.seed)\n",
        "    self.t = 0\n",
        "    self.ts = np.zeros(self.K)\n",
        "    self.tp = np.zeros(self.K)\n",
        "\n",
        "    self.budget = 0\n",
        "\n",
        "    #Sample each arm once\n",
        "    \n",
        "    self.mu_hat = np.zeros((self.T, self.K))\n",
        "    self.sumreward = np.zeros((self.T, self.K))\n",
        "    self.reward_arm = np.zeros((self.T, self.K))\n",
        "    self.numplays = np.zeros((self.T, self.K))\n",
        "\n",
        "    for i in range(0,self.K):\n",
        "      \n",
        "      arm = i\n",
        "      reward = self.env.pull_arm(arm, self.t)\n",
        "      #self.sumreward[self.t][arm] += reward\n",
        "      self.reward_arm[self.t][arm] = reward\n",
        "      self.numplays[self.t][arm] = 1\n",
        "      #self.mu_hat[self.t][arm] = self.sumreward[self.t][arm]/self.numplays[self.t][arm]\n",
        "\n",
        "      self.tp[arm] += 1\n",
        "\n",
        "      self.t += 1\n",
        "\n",
        "\n",
        "\n",
        "    sum1 = 0.0\n",
        "    self.ucb = np.zeros(self.K)\n",
        "    self.lcb = np.zeros(self.K)\n",
        "\n",
        "    while self.t < self.T:\n",
        "      \n",
        "      for k in range(self.K):\n",
        "        self.confidence = 1.0/self.confidence\n",
        "        beta_ucb = np.sqrt(1.5*np.log((self.t+1)/self.confidence)/(np.sum(self.numplays[int(self.ts[k]):self.t, k]) + 1))\n",
        "        self.ucb[k] = np.sum(self.reward_arm[int(self.ts[k]):self.t, k])/(np.sum(self.numplays[int(self.ts[k]):self.t, k]) + 1) + beta_ucb\n",
        "        self.lcb[k] = max(0.0,np.sum(self.reward_arm[int(self.ts[k]):self.t, k])/(np.sum(self.numplays[int(self.ts[k]):self.t, k]) + 1) - beta_ucb)\n",
        "\n",
        "      if self.budget >= 0:\n",
        "        arm = np.argmax(self.ucb)\n",
        "      else:\n",
        "        #arm = self.env.safe_arm\n",
        "        arm = self.env.baseline\n",
        "\n",
        "      reward = self.env.pull_arm(arm, self.t)\n",
        "      #self.sumreward[self.t][arm] += reward\n",
        "      self.reward_arm[self.t][arm] = reward\n",
        "      self.numplays[self.t][arm] = 1\n",
        "      #self.mu_hat[self.t][arm] = self.sumreward[self.t][arm]/self.numplays[self.t][arm]\n",
        "      self.mu_hat[self.t, :] = [np.sum(self.reward_arm[int(self.ts[i]):self.t,i])/(np.sum(self.numplays[int(self.ts[i]):self.t,i]) + 1 ) for i in range(self.K)]\n",
        "      \n",
        "      self.tp[arm] += 1\n",
        "      \n",
        "\n",
        "      \n",
        "      self.budget +=  self.lcb[arm] + self.lcb[np.argmax(self.ucb)] - (1.0-self.alpha)*self.ucb[self.env.baseline] \n",
        "      \n",
        "      \n",
        "      error1 = 0\n",
        "      \n",
        "      \n",
        "      error1 = self.env.mu_t[self.t][np.argmax(self.env.mu_t[self.t])] - self.env.mu_t[self.t][arm] + max(self.budget_error, 0.0)\n",
        "      #print(self.env.mu_t[self.t][np.argmax(self.env.mu_t[self.t])], self.env.mu_t[self.t][arm])\n",
        "      sum1 += error1\n",
        "      self.error[tr][self.t] =  sum1\n",
        "      #print(self.t,sum1)   \n",
        "      \n",
        "      if self.t%100 == 0 and self.t > 2.0*self.K:\n",
        "        print(\"t \" +str(self.t))\n",
        "        print(\"t reward-arm: \" + str([np.sum(self.reward_arm[int(self.ts[i]):self.t,i]) for i in range(self.K)]   ))\n",
        "        \n",
        "        print(\"t numplay: \" + str([np.sum(self.numplays[int(self.ts[i]):self.t,i]) for i in range(self.K)]   ), str(np.sum(self.numplays[int(self.ts[i]):self.t,:])))\n",
        "        print(\"t mu-hat: \" + str([np.sum(self.reward_arm[int(self.ts[i]):self.t,i])/(np.sum(self.numplays[int(self.ts[i]):self.t,i]) + 1 ) for i in range(self.K)]   ))\n",
        "        print(\"T true mu: \" + str(self.env.mu_t[self.t]) + \" Err: \" + str(self.error[tr][self.t]))\n",
        "        print(np.argmax(self.mu_hat[self.t]), np.argmax(self.env.mu_t[self.t]))\n",
        "        print(self.budget, self.budget_error)\n",
        "        print()\n",
        "      \n",
        "      self.t += 1\n",
        "\n",
        "  def run_CUCB_sampling(self, ):\n",
        "\n",
        "    for tr in range(0,self.trials):\n",
        "      \n",
        "      print(tr, end=\", \")\n",
        "      self.run_algorithm(tr)\n",
        "\n",
        "\n",
        "# T = 8000\n",
        "# trials = 10\n",
        "# env = build_environment(5, 0.4, T, trials)\n",
        "# env.build_env1()\n",
        "cucb = CUCB_Sampling(env, 0.10, 0.1, \"global\")\n",
        "cucb.run_CUCB_sampling()\n",
        "\n",
        "\n"
      ],
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "0, t 100\n",
            "t reward-arm: [0.6714140763493254, 0.3400157208367223, 0.597873798410574, 0.8240893199201458, 0.8367557990149967, 32.67793144081308]\n",
            "t numplay: [2.0, 1.0, 1.0, 1.0, 1.0, 94.0] 100.0\n",
            "t mu-hat: [0.2238046921164418, 0.17000786041836116, 0.298936899205287, 0.4120446599600729, 0.4183778995074984, 0.3439782256927693]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 28.650000000000045\n",
            "4 4\n",
            "-24.98985219185741 0\n",
            "\n",
            "t 200\n",
            "t reward-arm: [0.6714140763493254, 0.3400157208367223, 0.597873798410574, 0.8240893199201458, 0.8367557990149967, 68.49806114829146]\n",
            "t numplay: [2.0, 1.0, 1.0, 1.0, 1.0, 194.0] 200.0\n",
            "t mu-hat: [0.2238046921164418, 0.17000786041836116, 0.298936899205287, 0.4120446599600729, 0.4183778995074984, 0.3512721084527767]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 58.6499999999998\n",
            "4 4\n",
            "-36.51462287849012 0\n",
            "\n",
            "t 300\n",
            "t reward-arm: [0.6714140763493254, 0.3400157208367223, 0.597873798410574, 0.8240893199201458, 0.8367557990149967, 102.90573854269482]\n",
            "t numplay: [2.0, 1.0, 1.0, 1.0, 1.0, 294.0] 300.0\n",
            "t mu-hat: [0.2238046921164418, 0.17000786041836116, 0.298936899205287, 0.4120446599600729, 0.4183778995074984, 0.34883301200913497]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 88.64999999999952\n",
            "4 4\n",
            "-40.64505225453415 0\n",
            "\n",
            "t 400\n",
            "t reward-arm: [0.6714140763493254, 0.3400157208367223, 0.597873798410574, 0.8240893199201458, 0.8367557990149967, 135.93777147723574]\n",
            "t numplay: [2.0, 1.0, 1.0, 1.0, 1.0, 394.0] 400.0\n",
            "t mu-hat: [0.2238046921164418, 0.17000786041836116, 0.298936899205287, 0.4120446599600729, 0.4183778995074984, 0.34414625690439427]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 118.64999999999924\n",
            "4 4\n",
            "-40.95946454291935 0\n",
            "\n",
            "t 500\n",
            "t reward-arm: [0.6714140763493254, 0.3400157208367223, 0.597873798410574, 0.8240893199201458, 0.8367557990149967, 170.81212931884653]\n",
            "t numplay: [2.0, 1.0, 1.0, 1.0, 1.0, 494.0] 500.0\n",
            "t mu-hat: [0.2238046921164418, 0.17000786041836116, 0.298936899205287, 0.4120446599600729, 0.4183778995074984, 0.3450750087249425]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 148.64999999999992\n",
            "4 4\n",
            "-38.759223871377706 0\n",
            "\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "/usr/local/lib/python3.7/dist-packages/ipykernel_launcher.py:127: RuntimeWarning: invalid value encountered in sqrt\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "t 600\n",
            "t reward-arm: [0.6714140763493254, 0.3400157208367223, 0.597873798410574, 0.8240893199201458, 0.8367557990149967, 203.78281951994728]\n",
            "t numplay: [2.0, 1.0, 1.0, 1.0, 1.0, 594.0] 600.0\n",
            "t mu-hat: [0.2238046921164418, 0.17000786041836116, 0.298936899205287, 0.4120446599600729, 0.4183778995074984, 0.34249213364697023]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 178.65000000000106\n",
            "4 4\n",
            "-34.708380748796586 0\n",
            "\n",
            "t 700\n",
            "t reward-arm: [0.6714140763493254, 0.3400157208367223, 0.597873798410574, 0.8240893199201458, 0.8367557990149967, 237.43332321831244]\n",
            "t numplay: [2.0, 1.0, 1.0, 1.0, 1.0, 694.0] 700.0\n",
            "t mu-hat: [0.2238046921164418, 0.17000786041836116, 0.298936899205287, 0.4120446599600729, 0.4183778995074984, 0.3416306808896582]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 208.6500000000022\n",
            "4 4\n",
            "-29.370625001737828 0\n",
            "\n",
            "t 800\n",
            "t reward-arm: [0.6714140763493254, 0.3400157208367223, 0.597873798410574, 0.8240893199201458, 0.8367557990149967, 271.19733038308436]\n",
            "t numplay: [2.0, 1.0, 1.0, 1.0, 1.0, 794.0] 800.0\n",
            "t mu-hat: [0.2238046921164418, 0.17000786041836116, 0.298936899205287, 0.4120446599600729, 0.4183778995074984, 0.3411287174629992]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 238.65000000000333\n",
            "4 4\n",
            "-22.884023911581075 0\n",
            "\n",
            "t 900\n",
            "t reward-arm: [0.6714140763493254, 0.3400157208367223, 0.597873798410574, 0.8240893199201458, 0.8367557990149967, 305.9153390655305]\n",
            "t numplay: [2.0, 1.0, 1.0, 1.0, 1.0, 894.0] 900.0\n",
            "t mu-hat: [0.2238046921164418, 0.17000786041836116, 0.298936899205287, 0.4120446599600729, 0.4183778995074984, 0.3418048481179111]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 268.65000000000447\n",
            "4 4\n",
            "-15.421952958727923 0\n",
            "\n",
            "t 1000\n",
            "t reward-arm: [0.6714140763493254, 0.3400157208367223, 0.597873798410574, 0.8240893199201458, 0.8367557990149967, 342.5541805364487]\n",
            "t numplay: [2.0, 1.0, 1.0, 1.0, 1.0, 994.0] 1000.0\n",
            "t mu-hat: [0.2238046921164418, 0.17000786041836116, 0.298936899205287, 0.4120446599600729, 0.4183778995074984, 0.34427555832808915]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 298.6500000000056\n",
            "4 4\n",
            "-7.092981526712766 0\n",
            "\n",
            "t 1100\n",
            "t reward-arm: [0.6714140763493254, 1.2803243590623186, 1.3128312518973027, 3.0094863914003787, 1.322875068302779, 374.4987074791791]\n",
            "t numplay: [2.0, 4.0, 2.0, 5.0, 2.0, 1085.0] 1100.0\n",
            "t mu-hat: [0.2238046921164418, 0.25606487181246373, 0.4376104172991009, 0.5015810652333964, 0.4409583561009263, 0.3448422720802754]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 327.35000000000673\n",
            "3 4\n",
            "-0.034405061249122126 0\n",
            "\n",
            "t 1200\n",
            "t reward-arm: [0.8908365243460268, 3.3367304106086393, 4.301190054800697, 13.904782287322234, 7.5335830518608375, 396.27876167942964]\n",
            "t numplay: [4.0, 11.0, 8.0, 22.0, 11.0, 1144.0] 1200.0\n",
            "t mu-hat: [0.17816730486920535, 0.27806086755071996, 0.4779100060889664, 0.6045557516227058, 0.6277985876550698, 0.3460949883663141]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 350.1500000000076\n",
            "4 4\n",
            "0.00700998527638208 0\n",
            "\n",
            "t 1300\n",
            "t reward-arm: [1.4864410585740728, 5.046293656060103, 7.366609652784851, 23.439136331030298, 14.298352440036316, 417.2867821647184]\n",
            "t numplay: [7.0, 17.0, 14.0, 39.0, 22.0, 1201.0] 1300.0\n",
            "t mu-hat: [0.1858051323217591, 0.2803496475588946, 0.49110731018565673, 0.5859784082757574, 0.6216674973928833, 0.34716038449643793]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 372.4500000000084\n",
            "4 4\n",
            "0.0874192062293461 0\n",
            "\n",
            "t 1400\n",
            "t reward-arm: [1.6234468412172254, 7.308407921085818, 12.483081105106798, 46.840496457879226, 32.835128666019344, 421.7149962347864]\n",
            "t numplay: [9.0, 25.0, 25.0, 77.0, 50.0, 1214.0] 1400.0\n",
            "t mu-hat: [0.16234468412172254, 0.28109261234945454, 0.48011850404256917, 0.600519185357426, 0.6438260522748891, 0.3470905318804826]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 383.3500000000089\n",
            "4 4\n",
            "6.728555780085468 0\n",
            "\n",
            "t 1500\n",
            "t reward-arm: [2.2425197186256542, 9.214294879936567, 18.139047698918187, 72.17553853307524, 56.247782703730465, 421.7149962347863]\n",
            "t numplay: [12.0, 32.0, 36.0, 120.0, 86.0, 1214.0] 1500.0\n",
            "t mu-hat: [0.172501516817358, 0.27922105696777477, 0.49024453240319427, 0.5964920539923574, 0.6465262379739134, 0.34709053188048256]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 390.95000000000925\n",
            "4 4\n",
            "34.31423323942162 0\n",
            "\n",
            "t 1600\n",
            "t reward-arm: [2.9424356283144086, 11.679358779798504, 25.815594296535657, 96.58477427440803, 78.6271283284708, 421.7149962347864]\n",
            "t numplay: [15.0, 39.0, 50.0, 161.0, 121.0, 1214.0] 1600.0\n",
            "t mu-hat: [0.18390222676965054, 0.2919839694949626, 0.5061881234614835, 0.596202310335852, 0.6444846584300885, 0.3470905318804826]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 398.9000000000095\n",
            "4 4\n",
            "71.6769222551382 0\n",
            "\n",
            "t 1700\n",
            "t reward-arm: [3.2572706863835212, 13.08107530553076, 30.19483037001755, 128.4120420279574, 100.25520500636176, 421.7149962347863]\n",
            "t numplay: [16.0, 44.0, 59.0, 212.0, 155.0, 1214.0] 1700.0\n",
            "t mu-hat: [0.19160415802256006, 0.290690562345128, 0.5032471728336259, 0.6028734367509737, 0.6426615705536011, 0.34709053188048256]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 404.95000000001\n",
            "4 4\n",
            "120.8532627227227 0\n",
            "\n",
            "t 1800\n",
            "t reward-arm: [3.620112675725986, 13.515603514607403, 35.388197901348576, 154.04345983457, 127.37117244732572, 421.7149962347863]\n",
            "t numplay: [18.0, 47.0, 69.0, 255.0, 197.0, 1214.0] 1800.0\n",
            "t mu-hat: [0.19053224609084138, 0.28157507322098757, 0.5055456843049797, 0.6017322649787891, 0.6432887497339683, 0.34709053188048256]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 410.5500000000103\n",
            "4 4\n",
            "176.97187131105596 0\n",
            "\n",
            "t 1900\n",
            "t reward-arm: [3.8688142083240233, 14.870593499161156, 40.625908183310045, 179.24345215815944, 153.84283473683303, 421.7149962347864]\n",
            "t numplay: [19.0, 51.0, 79.0, 298.0, 239.0, 1214.0] 1900.0\n",
            "t mu-hat: [0.19344071041620117, 0.2859729519069453, 0.5078238522913756, 0.5994764286226069, 0.641011811403471, 0.3470905318804826]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 416.05000000001064\n",
            "4 4\n",
            "236.69609097720075 0\n",
            "\n",
            "t 2000\n",
            "t reward-arm: [4.019841706086721, 15.871535681506325, 45.38592064294709, 198.4047036350738, 189.5890253821965, 421.7149962347864]\n",
            "t numplay: [20.0, 54.0, 88.0, 331.0, 293.0, 1214.0] 2000.0\n",
            "t mu-hat: [0.1914210336231772, 0.28857337602738775, 0.5099541645274954, 0.5976045290213066, 0.6448606305516887, 0.3470905318804826]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 421.00000000001086\n",
            "4 0\n",
            "302.72285338039904 0\n",
            "\n",
            "t 2100\n",
            "t reward-arm: [4.01984170608672, 79.8758804173452, 45.94053414884265, 198.53350661866438, 189.6857332768535, 421.7149962347863]\n",
            "t numplay: [20.0, 151.0, 89.0, 332.0, 294.0, 1214.0] 2100.0\n",
            "t mu-hat: [0.19142103362317714, 0.5254992132720079, 0.510450379431585, 0.5961967165725657, 0.6430024856842492, 0.34709053188048256]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 426.4500000000119\n",
            "4 0\n",
            "306.8680938947181 0\n",
            "\n",
            "t 2200\n",
            "t reward-arm: [4.019841706086721, 143.51032619781842, 45.94053414884265, 198.53350661866438, 189.68573327685345, 421.7149962347864]\n",
            "t numplay: [20.0, 251.0, 89.0, 332.0, 294.0, 1214.0] 2200.0\n",
            "t mu-hat: [0.1914210336231772, 0.5694854214199143, 0.510450379431585, 0.5961967165725657, 0.643002485684249, 0.3470905318804826]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 431.45000000001306\n",
            "4 0\n",
            "348.8117472766073 0\n",
            "\n",
            "t 2300\n",
            "t reward-arm: [66.94436205161308, 149.41348116915336, 45.94053414884265, 198.53350661866438, 189.68573327685348, 421.7149962347863]\n",
            "t numplay: [111.0, 260.0, 89.0, 332.0, 294.0, 1214.0] 2300.0\n",
            "t mu-hat: [0.5977175183179739, 0.5724654450925416, 0.510450379431585, 0.5961967165725657, 0.6430024856842491, 0.34709053188048256]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 431.85000000001315\n",
            "4 0\n",
            "369.82045628739877 0\n",
            "\n",
            "t 2400\n",
            "t reward-arm: [136.49253480678212, 149.41348116915336, 45.94053414884266, 198.53350661866438, 189.68573327685348, 421.71499623478644]\n",
            "t numplay: [211.0, 260.0, 89.0, 332.0, 294.0, 1214.0] 2400.0\n",
            "t mu-hat: [0.6438327113527459, 0.5724654450925416, 0.5104503794315851, 0.5961967165725657, 0.6430024856842491, 0.34709053188048267]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 431.85000000001315\n",
            "0 0\n",
            "435.982930729186 0\n",
            "\n"
          ]
        },
        {
          "output_type": "error",
          "ename": "KeyboardInterrupt",
          "evalue": "ignored",
          "traceback": [
            "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
            "\u001b[0;31mKeyboardInterrupt\u001b[0m                         Traceback (most recent call last)",
            "\u001b[0;32m<ipython-input-10-523c164e4c2e>\u001b[0m in \u001b[0;36m<module>\u001b[0;34m()\u001b[0m\n\u001b[1;32m    184\u001b[0m \u001b[0;31m# env.build_env1()\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    185\u001b[0m \u001b[0mcucb\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mCUCB_Sampling\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0menv\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;36m0.10\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;36m0.1\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m\"global\"\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 186\u001b[0;31m \u001b[0mcucb\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mrun_CUCB_sampling\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    187\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    188\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;32m<ipython-input-10-523c164e4c2e>\u001b[0m in \u001b[0;36mrun_CUCB_sampling\u001b[0;34m(self)\u001b[0m\n\u001b[1;32m    176\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    177\u001b[0m       \u001b[0mprint\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mtr\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mend\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;34m\", \"\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 178\u001b[0;31m       \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mrun_algorithm\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mtr\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    179\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    180\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;32m<ipython-input-10-523c164e4c2e>\u001b[0m in \u001b[0;36mrun_algorithm\u001b[0;34m(self, tr)\u001b[0m\n\u001b[1;32m    140\u001b[0m       \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mnumplays\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mt\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0marm\u001b[0m\u001b[0;34m]\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;36m1\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    141\u001b[0m       \u001b[0;31m#self.mu_hat[self.t][arm] = self.sumreward[self.t][arm]/self.numplays[self.t][arm]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 142\u001b[0;31m       \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mmu_hat\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mt\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m:\u001b[0m\u001b[0;34m]\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;34m[\u001b[0m\u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msum\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mreward_arm\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mint\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mts\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mi\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mt\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0mi\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m/\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msum\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mnumplays\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mint\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mts\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mi\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mt\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0mi\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;34m+\u001b[0m \u001b[0;36m1\u001b[0m \u001b[0;34m)\u001b[0m \u001b[0;32mfor\u001b[0m \u001b[0mi\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mrange\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mK\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    143\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    144\u001b[0m       \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mtp\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0marm\u001b[0m\u001b[0;34m]\u001b[0m \u001b[0;34m+=\u001b[0m \u001b[0;36m1\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;32m<ipython-input-10-523c164e4c2e>\u001b[0m in \u001b[0;36m<listcomp>\u001b[0;34m(.0)\u001b[0m\n\u001b[1;32m    140\u001b[0m       \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mnumplays\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mt\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0marm\u001b[0m\u001b[0;34m]\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;36m1\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    141\u001b[0m       \u001b[0;31m#self.mu_hat[self.t][arm] = self.sumreward[self.t][arm]/self.numplays[self.t][arm]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 142\u001b[0;31m       \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mmu_hat\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mt\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m:\u001b[0m\u001b[0;34m]\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;34m[\u001b[0m\u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msum\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mreward_arm\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mint\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mts\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mi\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mt\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0mi\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m/\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msum\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mnumplays\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mint\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mts\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mi\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mt\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0mi\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;34m+\u001b[0m \u001b[0;36m1\u001b[0m \u001b[0;34m)\u001b[0m \u001b[0;32mfor\u001b[0m \u001b[0mi\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mrange\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mK\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    143\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    144\u001b[0m       \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mtp\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0marm\u001b[0m\u001b[0;34m]\u001b[0m \u001b[0;34m+=\u001b[0m \u001b[0;36m1\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;32m<__array_function__ internals>\u001b[0m in \u001b[0;36msum\u001b[0;34m(*args, **kwargs)\u001b[0m\n",
            "\u001b[0;32m/usr/local/lib/python3.7/dist-packages/numpy/core/fromnumeric.py\u001b[0m in \u001b[0;36msum\u001b[0;34m(a, axis, dtype, out, keepdims, initial, where)\u001b[0m\n\u001b[1;32m   2103\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   2104\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m-> 2105\u001b[0;31m \u001b[0;34m@\u001b[0m\u001b[0marray_function_dispatch\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0m_sum_dispatcher\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m   2106\u001b[0m def sum(a, axis=None, dtype=None, out=None, keepdims=np._NoValue,\n\u001b[1;32m   2107\u001b[0m         initial=np._NoValue, where=np._NoValue):\n",
            "\u001b[0;31mKeyboardInterrupt\u001b[0m: "
          ]
        }
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "GGhdjPKdxxOh"
      },
      "source": [
        "# Adversarial CUCB"
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 1000
        },
        "id": "w0DqQu5Kx0qV",
        "outputId": "32c3ae2c-5789-4843-d19e-cf62c4ffa2aa"
      },
      "source": [
        "import numpy as np\n",
        "\n",
        "class Adv_CUCB_Sampling(object):\n",
        "\n",
        "  def __init__(self, env, confidence, alpha, type_):\n",
        "    \n",
        "    \n",
        "    self.env = env\n",
        "    self.confidence = confidence\n",
        "    \n",
        "    self.K = env.K\n",
        "    self.T = env.T\n",
        "    self.trials = env.trials\n",
        "\n",
        "\n",
        "    self.mu_hat = np.zeros((self.T, self.K))\n",
        "    self.sumreward = np.zeros((self.T, self.K))\n",
        "    self.reward_arm = np.zeros((self.T, self.K))\n",
        "    self.numplays = np.zeros((self.T, self.K))\n",
        "    \n",
        "    self.tol = 0.01\n",
        "    self.gamma = 0.01\n",
        "    \n",
        "    self.budget = 0\n",
        "    self.budget_error = 0\n",
        "    self.alpha = 0.7\n",
        "\n",
        "    self.estimated_G = np.zeros(self.K)\n",
        "    self.type_ = type_\n",
        "    \n",
        "    \n",
        "    \n",
        "    self.error = np.zeros((self.trials, self.T))\n",
        "  \n",
        "\n",
        "  def detect_changepoint(self, ts, tp):\n",
        "\n",
        "   \n",
        "\n",
        "    for k in range(self.K):\n",
        "      \n",
        "      #print(tp)\n",
        "      for t_ in range(int(ts[k])+1,self.t):\n",
        "\n",
        "        \n",
        "        beta_ts = np.sqrt(0.5*np.log((self.t+1)/self.confidence)/(np.sum(self.numplays[int(ts[k]):t_, k]) + 1))\n",
        "        beta_tp = np.sqrt(0.5*np.log((self.t+1)/self.confidence)/(np.sum(self.numplays[t_:self.t, k]) + 1))\n",
        "\n",
        "        # beta_ts = np.sqrt(2.0*np.log(4.0*(1.0/np.log(2))*np.log(self.t+1)/self.confidence)/(np.sum(self.numplays[int(ts[k]):t_, k]) + 1))\n",
        "        # beta_tp = np.sqrt(2.0*np.log(4.0*(1.0/np.log(2))*np.log(self.t+1)/self.confidence)/(np.sum(self.numplays[t_:self.t, k]) + 1))\n",
        "\n",
        "        # beta_ucb = np.sqrt(2.0*np.log(4.0*(1.0/np.log(2))*np.log(self.t+1)/self.confidence)/(np.sum(self.numplays[int(self.ts[k]):self.t, k]) + 1))\n",
        "\n",
        "        if (np.sum(self.reward_arm[int(ts[k]):t_, k])/(np.sum(self.numplays[int(ts[k]):t_, k])+1) - beta_ts > np.sum(self.reward_arm[t_:self.t, k])/(np.sum(self.numplays[t_:self.t, k]) + 1) + beta_tp) \\\n",
        "          or (np.sum(self.reward_arm[int(ts[k]):t_, k])/(np.sum(self.numplays[int(ts[k]):t_, k]) + 1) + beta_ts < np.sum(self.reward_arm[t_:self.t, k])/(np.sum(self.numplays[t_:self.t, k]) + 1) - beta_tp): \n",
        "            \n",
        "         \n",
        "\n",
        "          if self.type_ == \"global\":\n",
        "            for k1 in range(self.K):\n",
        "\n",
        "              self.estimated_G[k1] += 1\n",
        "\n",
        "              #print(self.mu_hat[int(ts[k1]): int(tp[k1]), k1])\n",
        "              self.mu_hat[int(ts[k1]): self.t, k1] = 0.0\n",
        "              #print(self.mu_hat[int(ts[k1]): int(tp[k1]), k1])\n",
        "              self.numplays[int(ts[k1]): self.t, k1] = 0\n",
        "              self.sumreward[int(ts[k1]): self.t, k1] = 0.0\n",
        "              self.reward_arm[int(ts[k1]): self.t, k1] = 0.0\n",
        "              self.ts[k1] = self.t\n",
        "\n",
        "              #print(self.reward_arm[0: self.t, k])\n",
        "            print(\"Global Changepoint Detected at time \" + str(self.t))\n",
        "            \n",
        "            return True\n",
        "          \n",
        "          else:\n",
        "            \n",
        "            self.estimated_G[k] += 1\n",
        "            self.mu_hat[int(ts[k]): self.t, k] = 0.0\n",
        "            self.numplays[int(ts[k]): self.t, k] = 0\n",
        "            self.sumreward[int(ts[k]): self.t, k] = 0.0\n",
        "            self.reward_arm[int(ts[k]): self.t, k] = 0.0\n",
        "            self.ts[k] = self.t\n",
        "\n",
        "            \n",
        "\n",
        "            print(\"Arm \"+ str(k) +\" Changepoint Detected at time \" + str(self.t))\n",
        "            continue\n",
        "\n",
        "\n",
        "\n",
        "  def run_algorithm(self, tr):\n",
        "\n",
        "    self.seed = tr\n",
        "    np.random.seed(self.seed)\n",
        "    self.t = 0\n",
        "    self.ts = np.zeros(self.K)\n",
        "    self.tp = np.zeros(self.K)\n",
        "\n",
        "    self.budget = 0\n",
        "\n",
        "    #Sample each arm once\n",
        "    \n",
        "    self.mu_hat = np.zeros((self.T, self.K))\n",
        "    self.sumreward = np.zeros((self.T, self.K))\n",
        "    self.reward_arm = np.zeros((self.T, self.K))\n",
        "    self.numplays = np.zeros((self.T, self.K))\n",
        "\n",
        "    for i in range(0,self.K):\n",
        "      \n",
        "      arm = i\n",
        "      reward = self.env.pull_arm(arm, self.t)\n",
        "      #self.sumreward[self.t][arm] += reward\n",
        "      self.reward_arm[self.t][arm] = reward\n",
        "      self.numplays[self.t][arm] = 1\n",
        "      #self.mu_hat[self.t][arm] = self.sumreward[self.t][arm]/self.numplays[self.t][arm]\n",
        "\n",
        "      self.tp[arm] += 1\n",
        "\n",
        "      self.t += 1\n",
        "\n",
        "\n",
        "    self.ucb = np.zeros(self.K)\n",
        "    self.lcb = np.zeros(self.K)\n",
        "\n",
        "    self.gamma = np.sqrt((self.K*np.log(self.K)*np.log(self.T))/(self.T))\n",
        "    sum1 = 0.0\n",
        "    self.prob = np.ones(self.K)\n",
        "    \n",
        "    sum_prob = np.sum(self.prob)\n",
        "    for k in range(0,self.K):\n",
        "      self.prob[k] = self.prob[k]/sum_prob\n",
        "\n",
        "    \n",
        "    self.weights = np.ones(self.K)\n",
        "\n",
        "    while self.t < self.T:\n",
        "      \n",
        "      for k in range(self.K):\n",
        "        self.confidence = 1.0/self.confidence\n",
        "        beta_ucb = np.sqrt(1.5*np.log((self.t+1)/self.confidence)/(np.sum(self.numplays[int(self.ts[k]):self.t, k]) + 1))\n",
        "        self.ucb[k] = np.sum(self.reward_arm[int(self.ts[k]):self.t, k])/(np.sum(self.numplays[int(self.ts[k]):self.t, k]) + 1) + beta_ucb\n",
        "        self.lcb[k] = max(0.0,np.sum(self.reward_arm[int(self.ts[k]):self.t, k])/(np.sum(self.numplays[int(self.ts[k]):self.t, k]) + 1) - beta_ucb)\n",
        "        self.prob[k] = (1-self.gamma)*(self.weights[k]/sum(self.weights))+(self.gamma/self.K)\n",
        "\n",
        "\n",
        "      \n",
        "\n",
        "      sum_prob = np.sum(self.prob)\n",
        "      for k in range(0,self.K):\n",
        "        self.prob[k] = self.prob[k]/sum_prob\n",
        "\n",
        "      #print(self.prob)\n",
        "      if self.budget >= 0:\n",
        "        arm = np.random.choice(self.K, p = self.prob)\n",
        "      else:\n",
        "        #arm = self.env.safe_arm\n",
        "        arm = self.env.baseline\n",
        "\n",
        "      reward = self.env.pull_arm(arm, self.t)\n",
        "\n",
        "      xj=[0.0]*self.K\n",
        "\n",
        "      for k in range(self.K):\n",
        "\n",
        "        if k == arm:\n",
        "          xj[k] = reward/self.prob[k]\n",
        "\n",
        "        self.weights[k]=self.weights[k]*np.exp(self.gamma*xj[k]/self.K)\n",
        "      \n",
        "      #print(arm, self.budget)\n",
        "\n",
        "\n",
        "      #self.sumreward[self.t][arm] += reward\n",
        "      self.reward_arm[self.t][arm] = reward\n",
        "      self.numplays[self.t][arm] = 1\n",
        "      #self.mu_hat[self.t][arm] = self.sumreward[self.t][arm]/self.numplays[self.t][arm]\n",
        "      self.mu_hat[self.t, :] = [np.sum(self.reward_arm[int(self.ts[i]):self.t,i])/(np.sum(self.numplays[int(self.ts[i]):self.t,i]) + 1 ) for i in range(self.K)]\n",
        "      \n",
        "      self.tp[arm] += 1\n",
        "      \n",
        "      self.budget +=  self.lcb[arm] + self.ucb[np.argmax(self.ucb)] - (1.0-self.alpha)*self.ucb[self.env.baseline]\n",
        "      \n",
        "\n",
        "      error1 = 0\n",
        "      \n",
        "      \n",
        "      error1 = self.env.mu_t[self.t][np.argmax(self.env.mu_t[self.t])] - self.env.mu_t[self.t][arm] + max(self.budget_error, 0.0)\n",
        "      #print(self.env.mu_t[self.t][np.argmax(self.env.mu_t[self.t])], self.env.mu_t[self.t][arm])\n",
        "      sum1 += error1\n",
        "      self.error[tr][self.t] =  sum1\n",
        "      #print(self.t,sum1)   \n",
        "      \n",
        "      if self.t%100 == 0 and self.t > 2.0*self.K:\n",
        "        print(\"t \" +str(self.t))\n",
        "        print(\"t reward-arm: \" + str([np.sum(self.reward_arm[int(self.ts[i]):self.t,i]) for i in range(self.K)]   ))\n",
        "        \n",
        "        print(\"t numplay: \" + str([np.sum(self.numplays[int(self.ts[i]):self.t,i]) for i in range(self.K)]   ), str(np.sum(self.numplays[int(self.ts[i]):self.t,:])))\n",
        "        print(\"t mu-hat: \" + str([np.sum(self.reward_arm[int(self.ts[i]):self.t,i])/(np.sum(self.numplays[int(self.ts[i]):self.t,i]) + 1 ) for i in range(self.K)]   ))\n",
        "        print(\"T true mu: \" + str(self.env.mu_t[self.t]) + \" Err: \" + str(self.error[tr][self.t]))\n",
        "        print(np.argmax(self.mu_hat[self.t]), np.argmax(self.env.mu_t[self.t]))\n",
        "        print(self.budget, self.budget_error)\n",
        "        print(self.prob)\n",
        "        print()\n",
        "      \n",
        "      self.t += 1\n",
        "\n",
        "  def run_Adv_CUCB_sampling(self, ):\n",
        "\n",
        "    for tr in range(0,self.trials):\n",
        "      \n",
        "      print(tr, end=\", \")\n",
        "      self.run_algorithm(tr)\n",
        "\n",
        "\n",
        "# T = 8000\n",
        "# trials = 10\n",
        "# env = build_environment(5, 0.4, T, trials)\n",
        "# env.build_env1()\n",
        "adv_cucb = Adv_CUCB_Sampling(env, 0.10, 0.1, \"global\")\n",
        "adv_cucb.run_Adv_CUCB_sampling()\n",
        "\n",
        "\n"
      ],
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "0, t 100\n",
            "t reward-arm: [0.37640523459676645, 0.3400157208367223, 1.2244856513963518, 0.8240893199201458, 0.8367557990149967, 33.765289230032636]\n",
            "t numplay: [1.0, 1.0, 2.0, 1.0, 1.0, 94.0] 100.0\n",
            "t mu-hat: [0.18820261729838322, 0.17000786041836116, 0.40816188379878393, 0.4120446599600729, 0.4183778995074984, 0.35542409715823825]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 28.350000000000044\n",
            "4 4\n",
            "nan 0\n",
            "[0.09444366 0.09444366 0.09987069 0.09444366 0.09444366 0.52235469]\n",
            "\n",
            "t 200\n",
            "t reward-arm: [0.37640523459676645, 0.3400157208367223, 1.2244856513963518, 0.8240893199201458, 0.8367557990149967, 68.29092847416781]\n",
            "t numplay: [1.0, 1.0, 2.0, 1.0, 1.0, 194.0] 200.0\n",
            "t mu-hat: [0.18820261729838322, 0.17000786041836116, 0.40816188379878393, 0.4120446599600729, 0.4183778995074984, 0.350209889611117]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 58.3499999999998\n",
            "4 4\n",
            "nan 0\n",
            "[0.05646889 0.05646889 0.05918876 0.05646889 0.05646889 0.71493568]\n",
            "\n",
            "t 300\n",
            "t reward-arm: [0.37640523459676645, 0.3400157208367223, 1.2244856513963518, 0.8240893199201458, 0.8367557990149967, 102.80964230990067]\n",
            "t numplay: [1.0, 1.0, 2.0, 1.0, 1.0, 294.0] 300.0\n",
            "t mu-hat: [0.18820261729838322, 0.17000786041836116, 0.40816188379878393, 0.4120446599600729, 0.4183778995074984, 0.3485072620674599]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 88.34999999999953\n",
            "4 4\n",
            "nan 0\n",
            "[0.03737936 0.03737936 0.03873836 0.03737936 0.03737936 0.8117442 ]\n",
            "\n",
            "t 400\n",
            "t reward-arm: [0.37640523459676645, 0.3400157208367223, 1.2244856513963518, 0.8240893199201458, 0.8367557990149967, 135.4155886216122]\n",
            "t numplay: [1.0, 1.0, 2.0, 1.0, 1.0, 394.0] 400.0\n",
            "t mu-hat: [0.18820261729838322, 0.17000786041836116, 0.40816188379878393, 0.4120446599600729, 0.4183778995074984, 0.34282427499142326]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 118.34999999999924\n",
            "4 4\n",
            "nan 0\n",
            "[0.0282038  0.0282038  0.02890869 0.0282038  0.0282038  0.85827611]\n",
            "\n",
            "t 500\n",
            "t reward-arm: [0.37640523459676645, 0.3400157208367223, 1.2244856513963518, 0.8240893199201458, 0.8367557990149967, 170.26111520470886]\n",
            "t numplay: [1.0, 1.0, 2.0, 1.0, 1.0, 494.0] 500.0\n",
            "t mu-hat: [0.18820261729838322, 0.17000786041836116, 0.40816188379878393, 0.4120446599600729, 0.4183778995074984, 0.34396184889840176]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 148.3499999999999\n",
            "4 4\n",
            "nan 0\n",
            "[0.02321592 0.02321592 0.02356522 0.02321592 0.02321592 0.88357111]\n",
            "\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "/usr/local/lib/python3.7/dist-packages/ipykernel_launcher.py:141: RuntimeWarning: invalid value encountered in sqrt\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "t 600\n",
            "t reward-arm: [0.37640523459676645, 0.3400157208367223, 1.2244856513963518, 0.8240893199201458, 0.8367557990149967, 203.32054075339943]\n",
            "t numplay: [1.0, 1.0, 2.0, 1.0, 1.0, 594.0] 600.0\n",
            "t mu-hat: [0.18820261729838322, 0.17000786041836116, 0.40816188379878393, 0.4120446599600729, 0.4183778995074984, 0.34171519454352844]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 178.35000000000105\n",
            "4 4\n",
            "nan 0\n",
            "[0.02083256 0.02083256 0.02101196 0.02083256 0.02083256 0.8956578 ]\n",
            "\n",
            "t 700\n",
            "t reward-arm: [0.37640523459676645, 0.3400157208367223, 1.2244856513963518, 0.8240893199201458, 0.8367557990149967, 238.05445900596453]\n",
            "t numplay: [1.0, 1.0, 2.0, 1.0, 1.0, 694.0] 700.0\n",
            "t mu-hat: [0.18820261729838322, 0.17000786041836116, 0.40816188379878393, 0.4120446599600729, 0.4183778995074984, 0.34252440144743096]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 208.35000000000218\n",
            "4 4\n",
            "nan 0\n",
            "[0.01956545 0.01956545 0.01965452 0.01956545 0.01956545 0.90208369]\n",
            "\n",
            "t 800\n",
            "t reward-arm: [0.37640523459676645, 0.3400157208367223, 1.2244856513963518, 0.8240893199201458, 0.8367557990149967, 272.33412370243207]\n",
            "t numplay: [1.0, 1.0, 2.0, 1.0, 1.0, 794.0] 800.0\n",
            "t mu-hat: [0.18820261729838322, 0.17000786041836116, 0.40816188379878393, 0.4120446599600729, 0.4183778995074984, 0.3425586461665812]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 238.35000000000332\n",
            "4 4\n",
            "nan 0\n",
            "[0.01894202 0.01894202 0.01898664 0.01894202 0.01894202 0.90524529]\n",
            "\n",
            "t 900\n",
            "t reward-arm: [0.37640523459676645, 0.3400157208367223, 1.2244856513963518, 0.8240893199201458, 0.8367557990149967, 305.6347288157283]\n",
            "t numplay: [1.0, 1.0, 2.0, 1.0, 1.0, 894.0] 900.0\n",
            "t mu-hat: [0.18820261729838322, 0.17000786041836116, 0.40816188379878393, 0.4120446599600729, 0.4183778995074984, 0.3414913171125456]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 268.35000000000446\n",
            "4 4\n",
            "nan 0\n",
            "[0.01863591 0.01863591 0.01865871 0.01863591 0.01863591 0.90679766]\n",
            "\n",
            "t 1000\n",
            "t reward-arm: [0.37640523459676645, 0.3400157208367223, 1.2244856513963518, 0.8240893199201458, 0.8367557990149967, 341.3277797402293]\n",
            "t numplay: [1.0, 1.0, 2.0, 1.0, 1.0, 994.0] 1000.0\n",
            "t mu-hat: [0.18820261729838322, 0.17000786041836116, 0.40816188379878393, 0.4120446599600729, 0.4183778995074984, 0.3430429947137983]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 298.3500000000056\n",
            "4 4\n",
            "nan 0\n",
            "[0.01847179 0.01847179 0.01848289 0.01847179 0.01847179 0.90762997]\n",
            "\n",
            "t 1100\n",
            "t reward-arm: [0.37640523459676645, 0.3400157208367223, 1.2244856513963518, 0.8240893199201458, 0.8367557990149967, 376.48758074669433]\n",
            "t numplay: [1.0, 1.0, 2.0, 1.0, 1.0, 1094.0] 1100.0\n",
            "t mu-hat: [0.18820261729838322, 0.17000786041836116, 0.40816188379878393, 0.4120446599600729, 0.4183778995074984, 0.34382427465451537]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 328.35000000000673\n",
            "4 4\n",
            "nan 0\n",
            "[0.01839269 0.01839269 0.01839816 0.01839269 0.01839269 0.90803108]\n",
            "\n",
            "t 1200\n",
            "t reward-arm: [0.37640523459676645, 0.3400157208367223, 1.2244856513963518, 0.8240893199201458, 0.8367557990149967, 412.9631527631737]\n",
            "t numplay: [1.0, 1.0, 2.0, 1.0, 1.0, 1194.0] 1200.0\n",
            "t mu-hat: [0.18820261729838322, 0.17000786041836116, 0.40816188379878393, 0.4120446599600729, 0.4183778995074984, 0.345575860052865]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 358.35000000000787\n",
            "4 4\n",
            "nan 0\n",
            "[0.01835277 0.01835277 0.01835539 0.01835277 0.01835277 0.90823351]\n",
            "\n",
            "t 1300\n",
            "t reward-arm: [0.37640523459676645, 0.3400157208367223, 1.2244856513963518, 0.8240893199201458, 0.8367557990149967, 448.4936835633694]\n",
            "t numplay: [1.0, 1.0, 2.0, 1.0, 1.0, 1294.0] 1300.0\n",
            "t mu-hat: [0.18820261729838322, 0.17000786041836116, 0.40816188379878393, 0.4120446599600729, 0.4183778995074984, 0.34632716877480263]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 388.350000000009\n",
            "4 4\n",
            "nan 0\n",
            "[0.01833398 0.01833398 0.01833526 0.01833398 0.01833398 0.90832882]\n",
            "\n",
            "t 1400\n",
            "t reward-arm: [0.37640523459676645, 0.3400157208367223, 1.2244856513963518, 0.8240893199201458, 0.8367557990149967, 482.7574733985519]\n",
            "t numplay: [1.0, 1.0, 2.0, 1.0, 1.0, 1394.0] 1400.0\n",
            "t mu-hat: [0.18820261729838322, 0.17000786041836116, 0.40816188379878393, 0.4120446599600729, 0.4183778995074984, 0.3460627049451985]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 418.35000000001014\n",
            "4 4\n",
            "nan 0\n",
            "[0.01832503 0.01832503 0.01832567 0.01832503 0.01832503 0.90837423]\n",
            "\n",
            "t 1500\n",
            "t reward-arm: [0.37640523459676645, 0.3400157208367223, 1.2244856513963518, 0.8240893199201458, 0.8367557990149967, 516.8517390118561]\n",
            "t numplay: [1.0, 1.0, 2.0, 1.0, 1.0, 1494.0] 1500.0\n",
            "t mu-hat: [0.18820261729838322, 0.17000786041836116, 0.40816188379878393, 0.4120446599600729, 0.4183778995074984, 0.34572022676378333]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 448.3500000000113\n",
            "4 4\n",
            "nan 0\n",
            "[0.01832055 0.01832055 0.01832088 0.01832055 0.01832055 0.90839691]\n",
            "\n",
            "t 1600\n",
            "t reward-arm: [0.37640523459676645, 0.3400157208367223, 1.2244856513963518, 0.8240893199201458, 0.8367557990149967, 551.2971533938514]\n",
            "t numplay: [1.0, 1.0, 2.0, 1.0, 1.0, 1594.0] 1600.0\n",
            "t mu-hat: [0.18820261729838322, 0.17000786041836116, 0.40816188379878393, 0.4120446599600729, 0.4183778995074984, 0.34564084852279087]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 478.3500000000124\n",
            "4 4\n",
            "nan 0\n",
            "[0.01831829 0.01831829 0.01831845 0.01831829 0.01831829 0.90840839]\n",
            "\n",
            "t 1700\n",
            "t reward-arm: [0.37640523459676645, 0.3400157208367223, 1.2244856513963518, 0.8240893199201458, 0.8367557990149967, 587.982904911536]\n",
            "t numplay: [1.0, 1.0, 2.0, 1.0, 1.0, 1694.0] 1700.0\n",
            "t mu-hat: [0.18820261729838322, 0.17000786041836116, 0.40816188379878393, 0.4120446599600729, 0.4183778995074984, 0.3468925692693428]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 508.35000000001355\n",
            "4 4\n",
            "nan 0\n",
            "[0.01831711 0.01831711 0.01831719 0.01831711 0.01831711 0.90841438]\n",
            "\n",
            "t 1800\n",
            "t reward-arm: [0.37640523459676645, 0.3400157208367223, 1.2244856513963518, 0.8240893199201458, 0.8367557990149967, 624.1977245873153]\n",
            "t numplay: [1.0, 1.0, 2.0, 1.0, 1.0, 1794.0] 1800.0\n",
            "t mu-hat: [0.18820261729838322, 0.17000786041836116, 0.40816188379878393, 0.4120446599600729, 0.4183778995074984, 0.3477424649511506]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 538.3500000000097\n",
            "4 4\n",
            "nan 0\n",
            "[0.01831655 0.01831655 0.01831659 0.01831655 0.01831655 0.90841721]\n",
            "\n",
            "t 1900\n",
            "t reward-arm: [0.37640523459676645, 0.3400157208367223, 1.2244856513963518, 0.8240893199201458, 0.8367557990149967, 658.596436893624]\n",
            "t numplay: [1.0, 1.0, 2.0, 1.0, 1.0, 1894.0] 1900.0\n",
            "t mu-hat: [0.18820261729838322, 0.17000786041836116, 0.40816188379878393, 0.4120446599600729, 0.4183778995074984, 0.3475442938752633]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 568.3500000000051\n",
            "4 4\n",
            "nan 0\n",
            "[0.01831629 0.01831629 0.01831631 0.01831629 0.01831629 0.90841853]\n",
            "\n",
            "t 2000\n",
            "t reward-arm: [0.37640523459676645, 0.3400157208367223, 1.2244856513963518, 0.8240893199201458, 0.8367557990149967, 694.2554276906176]\n",
            "t numplay: [1.0, 1.0, 2.0, 1.0, 1.0, 1994.0] 2000.0\n",
            "t mu-hat: [0.18820261729838322, 0.17000786041836116, 0.40816188379878393, 0.4120446599600729, 0.4183778995074984, 0.34799770811559777]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 598.6000000000006\n",
            "4 0\n",
            "nan 0\n",
            "[0.01831616 0.01831616 0.01831617 0.01831616 0.01831616 0.90841921]\n",
            "\n",
            "t 2100\n",
            "t reward-arm: [0.37640523459676645, 0.3400157208367223, 1.2244856513963518, 0.8240893199201458, 0.8367557990149967, 710.4870797775052]\n",
            "t numplay: [1.0, 1.0, 2.0, 1.0, 1.0, 2094.0] 2100.0\n",
            "t mu-hat: [0.18820261729838322, 0.17000786041836116, 0.40816188379878393, 0.4120446599600729, 0.4183778995074984, 0.33913464428520534]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 653.599999999996\n",
            "4 0\n",
            "nan 0\n",
            "[0.01831612 0.01831612 0.01831613 0.01831612 0.01831612 0.90841938]\n",
            "\n"
          ]
        },
        {
          "output_type": "error",
          "ename": "KeyboardInterrupt",
          "evalue": "ignored",
          "traceback": [
            "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
            "\u001b[0;31mKeyboardInterrupt\u001b[0m                         Traceback (most recent call last)",
            "\u001b[0;32m<ipython-input-11-eda798b8c4cb>\u001b[0m in \u001b[0;36m<module>\u001b[0;34m()\u001b[0m\n\u001b[1;32m    219\u001b[0m \u001b[0;31m# env.build_env1()\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    220\u001b[0m \u001b[0madv_cucb\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mAdv_CUCB_Sampling\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0menv\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;36m0.10\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;36m0.1\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m\"global\"\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 221\u001b[0;31m \u001b[0madv_cucb\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mrun_Adv_CUCB_sampling\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    222\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    223\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;32m<ipython-input-11-eda798b8c4cb>\u001b[0m in \u001b[0;36mrun_Adv_CUCB_sampling\u001b[0;34m(self)\u001b[0m\n\u001b[1;32m    211\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    212\u001b[0m       \u001b[0mprint\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mtr\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mend\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;34m\", \"\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 213\u001b[0;31m       \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mrun_algorithm\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mtr\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    214\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    215\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;32m<ipython-input-11-eda798b8c4cb>\u001b[0m in \u001b[0;36mrun_algorithm\u001b[0;34m(self, tr)\u001b[0m\n\u001b[1;32m    142\u001b[0m         \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mucb\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mk\u001b[0m\u001b[0;34m]\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msum\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mreward_arm\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mint\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mts\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mk\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mt\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mk\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m/\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msum\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mnumplays\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mint\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mts\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mk\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mt\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mk\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;34m+\u001b[0m \u001b[0;36m1\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;34m+\u001b[0m \u001b[0mbeta_ucb\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    143\u001b[0m         \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mlcb\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mk\u001b[0m\u001b[0;34m]\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mmax\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;36m0.0\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msum\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mreward_arm\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mint\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mts\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mk\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mt\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mk\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m/\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msum\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mnumplays\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mint\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mts\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mk\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mt\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mk\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;34m+\u001b[0m \u001b[0;36m1\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;34m-\u001b[0m \u001b[0mbeta_ucb\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 144\u001b[0;31m         \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mprob\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mk\u001b[0m\u001b[0;34m]\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;34m(\u001b[0m\u001b[0;36m1\u001b[0m\u001b[0;34m-\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mgamma\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mweights\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mk\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m/\u001b[0m\u001b[0msum\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mweights\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m+\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mgamma\u001b[0m\u001b[0;34m/\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mK\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    145\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    146\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;31mKeyboardInterrupt\u001b[0m: "
          ]
        }
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "2Cv86Zg4_-7R"
      },
      "source": [
        "# SGR \n",
        "\n"
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "id": "GsV8wCldAod4",
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 735
        },
        "outputId": "fde7eb53-7f90-48d8-a5cf-1e403ff7e711"
      },
      "source": [
        "import numpy as np\n",
        "\n",
        "class SGR_Sampling(object):\n",
        "\n",
        "  def __init__(self, env, confidence, alpha, type_):\n",
        "    \n",
        "    \n",
        "    self.env = env\n",
        "    self.confidence = confidence\n",
        "    \n",
        "    self.K = env.K\n",
        "    self.T = env.T\n",
        "    self.trials = env.trials\n",
        "\n",
        "\n",
        "    self.mu_hat = np.zeros((self.T, self.K))\n",
        "    self.sumreward = np.zeros((self.T, self.K))\n",
        "    self.reward_arm = np.zeros((self.T, self.K))\n",
        "    self.numplays = np.zeros((self.T, self.K))\n",
        "    \n",
        "    self.tol = 0.01\n",
        "    self.gamma = 0.01\n",
        "    \n",
        "    self.budget = 0\n",
        "    self.budget_error = 0\n",
        "    self.alpha = 0.7\n",
        "\n",
        "    self.estimated_G = np.zeros(self.K)\n",
        "    self.type_ = type_\n",
        "    \n",
        "    \n",
        "    \n",
        "    self.error = np.zeros((self.trials, self.T))\n",
        "  \n",
        "\n",
        "  def detect_changepoint(self, ts, tp):\n",
        "\n",
        "   \n",
        "\n",
        "    for k in range(self.K):\n",
        "      \n",
        "      #print(tp)\n",
        "      #print(k)\n",
        "      for t_ in range(int(ts[k])+1,self.t):\n",
        "\n",
        "        self.confidence = 1.0/self.t\n",
        "        # beta_ts = np.sqrt(0.5*np.log(np.log(self.t+1)/self.confidence)/(np.sum(self.numplays[int(ts[k]):t_, k]) + 1))\n",
        "        # beta_tp = np.sqrt(0.5*np.log(np.log(self.t+1)/self.confidence)/(np.sum(self.numplays[t_:self.t, k]) + 1))\n",
        "\n",
        "        beta_ts = np.sqrt(0.5*np.log(1.0*(1.0/np.log(2))*np.log(self.t+1)/self.confidence)/(np.sum(self.numplays[int(ts[k]):t_, k]) + 1))\n",
        "        beta_tp = np.sqrt(0.5*np.log(1.0*(1.0/np.log(2))*np.log(self.t+1)/self.confidence)/(np.sum(self.numplays[t_:self.t, k]) + 1))\n",
        "\n",
        "        if (np.sum(self.reward_arm[int(ts[k]):t_, k])/(np.sum(self.numplays[int(ts[k]):t_, k])+1) - beta_ts > np.sum(self.reward_arm[t_:self.t, k])/(np.sum(self.numplays[t_:self.t, k]) + 1) + beta_tp) \\\n",
        "          or (np.sum(self.reward_arm[int(ts[k]):t_, k])/(np.sum(self.numplays[int(ts[k]):t_, k]) + 1) + beta_ts < np.sum(self.reward_arm[t_:self.t, k])/(np.sum(self.numplays[t_:self.t, k]) + 1) - beta_tp): \n",
        "            \n",
        "         \n",
        "\n",
        "          if self.type_ == \"global\":\n",
        "            for k1 in range(self.K):\n",
        "\n",
        "              self.estimated_G[k1] += 1\n",
        "\n",
        "              #print(self.mu_hat[int(ts[k1]): int(tp[k1]), k1])\n",
        "              self.mu_hat[int(ts[k1]): self.t, k1] = 0.0\n",
        "              #print(self.mu_hat[int(ts[k1]): int(tp[k1]), k1])\n",
        "              self.numplays[int(ts[k1]): self.t, k1] = 0\n",
        "              self.sumreward[int(ts[k1]): self.t, k1] = 0.0\n",
        "              self.reward_arm[int(ts[k1]): self.t, k1] = 0.0\n",
        "              self.ts[k1] = self.t\n",
        "              self.safe_set = set()\n",
        "              self.budget = 0.0\n",
        "\n",
        "              #print(self.reward_arm[0: self.t, k])\n",
        "            print(\"Global Changepoint Detected at time \" + str(self.t))\n",
        "            \n",
        "            return True\n",
        "          \n",
        "          else:\n",
        "            \n",
        "            self.estimated_G[k] += 1\n",
        "            self.mu_hat[int(ts[k]): self.t, k] = 0.0\n",
        "            self.numplays[int(ts[k]): self.t, k] = 0\n",
        "            self.sumreward[int(ts[k]): self.t, k] = 0.0\n",
        "            self.reward_arm[int(ts[k]): self.t, k] = 0.0\n",
        "            self.ts[k] = self.t\n",
        "            self.safe_set = set()\n",
        "            self.budget = 0.0\n",
        "            \n",
        "\n",
        "            print(\"Arm \"+ str(k) +\" Changepoint Detected at time \" + str(self.t))\n",
        "            continue\n",
        "\n",
        "  def safe_set_function(self, ):\n",
        "    \n",
        "    self.safe_set = set()\n",
        "    for k in range(0, self.K-1):\n",
        "\n",
        "      \n",
        "      if self.mu_hat[self.t-1][k] >= self.alpha*self.env.threshold:\n",
        "        \n",
        "        self.safe_set.add((k, self.mu_hat[self.t-1][k]))\n",
        "    \n",
        "    return self.safe_set\n",
        "\n",
        "  def run_algorithm(self, tr):\n",
        "\n",
        "    self.seed = tr\n",
        "    #self.seed = 8\n",
        "    np.random.seed(self.seed)\n",
        "    self.t = 0\n",
        "    self.ts = np.zeros(self.K)\n",
        "    self.tp = np.zeros(self.K)\n",
        "\n",
        "    self.budget = 0\n",
        "\n",
        "    self.mu_hat = np.zeros((self.T, self.K))\n",
        "    self.sumreward = np.zeros((self.T, self.K))\n",
        "    self.reward_arm = np.zeros((self.T, self.K))\n",
        "    self.numplays = np.zeros((self.T, self.K))\n",
        "\n",
        "    #Sample each arm once\n",
        "    \n",
        "\n",
        "    for i in range(0,self.K):\n",
        "      \n",
        "      arm = i\n",
        "      reward = self.env.pull_arm(arm, self.t)\n",
        "      #self.sumreward[self.t][arm] += reward\n",
        "      self.reward_arm[self.t][arm] = reward\n",
        "      self.numplays[self.t][arm] = 1\n",
        "      #self.mu_hat[self.t][arm] = self.sumreward[self.t][arm]/self.numplays[self.t][arm]\n",
        "\n",
        "      self.tp[arm] += 1\n",
        "\n",
        "      self.t += 1\n",
        "\n",
        "\n",
        "\n",
        "    sum1 = 0.0\n",
        "    self.ucb = np.zeros(self.K)\n",
        "    self.lcb = np.zeros(self.K)\n",
        "    self.B = np.zeros(self.K)\n",
        "    self.safe_set = set()\n",
        "\n",
        "    while self.t < self.T:\n",
        "      \n",
        "      for k in range(self.K):\n",
        "\n",
        "        beta_ucb = np.sqrt(2.0*np.log(4.0*(1.0/np.log(2))*np.log(self.t+1)/self.confidence)/(np.sum(self.numplays[int(self.ts[k]):self.t, k]) + 1))\n",
        "        self.ucb[k] = np.sum(self.reward_arm[int(self.ts[k]):self.t, k])/(np.sum(self.numplays[int(self.ts[k]):self.t, k]) + 1) + beta_ucb\n",
        "        self.lcb[k] = max(0.0,np.sum(self.reward_arm[int(self.ts[k]):self.t, k])/(np.sum(self.numplays[int(self.ts[k]):self.t, k]) + 1) - beta_ucb)\n",
        "        self.B[k] = abs(np.sum(self.reward_arm[int(self.ts[k]):self.t, k])/(np.sum(self.numplays[int(self.ts[k]):self.t, k]) + 1) - self.alpha*self.env.threshold)*np.sqrt((np.sum(self.numplays[int(self.ts[k]):self.t, k]) + 1))\n",
        "\n",
        "      \n",
        "      # self.safe_set = self.safe_set_function()\n",
        "\n",
        "      if self.budget >= 0:\n",
        "        arm = np.argmax(self.ucb)\n",
        "      elif self.budget < 0:\n",
        "        arm = self.env.baseline\n",
        "      \n",
        "      \n",
        "      reward = self.env.pull_arm(arm, self.t)\n",
        "      #self.sumreward[self.t][arm] += reward\n",
        "      self.reward_arm[self.t][arm] = reward\n",
        "      self.numplays[self.t][arm] = 1\n",
        "      #self.mu_hat[self.t][arm] = self.sumreward[self.t][arm]/self.numplays[self.t][arm]\n",
        "      self.mu_hat[self.t, :] = [np.sum(self.reward_arm[int(self.ts[i]):self.t,i])/(np.sum(self.numplays[int(self.ts[i]):self.t,i]) + 1 ) for i in range(self.K)]\n",
        "      \n",
        "      self.tp[arm] += 1\n",
        "      \n",
        "      self.budget +=  self.lcb[arm] + self.ucb[np.argmax(self.mu_hat[self.t, :])] - (1.0 - self.alpha)*self.ucb[self.env.baseline] \n",
        "\n",
        "      if self.t%20 == 0:\n",
        "        self.detect_changepoint(self.ts, self.tp)\n",
        "        \n",
        "          \n",
        "\n",
        "      error1 = 0\n",
        "      \n",
        "      \n",
        "      error1 = self.env.mu_t[self.t][np.argmax(self.env.mu_t[self.t])] - self.env.mu_t[self.t][arm] + max(self.budget_error, 0.0)\n",
        "      #print(self.env.mu_t[self.t][np.argmax(self.env.mu_t[self.t])], self.env.mu_t[self.t][arm])\n",
        "      sum1 += error1\n",
        "      self.error[tr][self.t] =  sum1\n",
        "      #print(self.t,sum1)   \n",
        "      \n",
        "      if self.t%100 == 0 and self.t > 2.0*self.K:\n",
        "        print(\"t \" +str(self.t))\n",
        "        print(\"t reward-arm: \" + str([np.sum(self.reward_arm[int(self.ts[i]):self.t,i]) for i in range(self.K)]   ))\n",
        "        \n",
        "        print(\"t numplay: \" + str([np.sum(self.numplays[int(self.ts[i]):self.t,i]) for i in range(self.K)]   ), str(np.sum(self.numplays[int(self.ts[i]):self.t,:])))\n",
        "        print(\"t mu-hat: \" + str([np.sum(self.reward_arm[int(self.ts[i]):self.t,i])/(np.sum(self.numplays[int(self.ts[i]):self.t,i]) + 1 ) for i in range(self.K)]   ))\n",
        "        print(\"T true mu: \" + str(self.env.mu_t[self.t]) + \" Err: \" + str(self.error[tr][self.t]))\n",
        "        print(np.argmax(self.mu_hat[self.t]), np.argmax(self.env.mu_t[self.t]))\n",
        "        print(self.budget, self.budget_error)\n",
        "        print()\n",
        "      \n",
        "      self.t += 1\n",
        "\n",
        "  def run_SGR_sampling(self, ):\n",
        "\n",
        "    for tr in range(0,self.trials):\n",
        "      \n",
        "      print(tr, end=\", \")\n",
        "      self.run_algorithm(tr)\n",
        "\n",
        "\n",
        "# T = 8000\n",
        "# trials = 10\n",
        "# env = build_environment(5, 0.4, T, trials)\n",
        "# env.build_env1()\n",
        "sgr = SGR_Sampling(env, 0.10, 0.1, \"global\")\n",
        "sgr.run_SGR_sampling()\n",
        "\n",
        "\n"
      ],
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "0, t 100\n",
            "t reward-arm: [2.330791083888016, 3.0318220610822992, 8.306361574638444, 15.989459646263663, 15.179510254804038, 4.710135534668389]\n",
            "t numplay: [10.0, 11.0, 17.0, 25.0, 24.0, 13.0] 100.0\n",
            "t mu-hat: [0.21189009853527419, 0.25265183842352495, 0.461464531924358, 0.6149792171639871, 0.6071804101921615, 0.3364382524763135]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 15.20000000000001\n",
            "3 4\n",
            "114.24497178127446 0\n",
            "\n",
            "t 200\n",
            "t reward-arm: [4.326172712165748, 5.787220093830003, 15.320779905910602, 31.921596215568684, 36.50727372759356, 8.205167207754634]\n",
            "t numplay: [18.0, 20.0, 32.0, 51.0, 56.0, 23.0] 200.0\n",
            "t mu-hat: [0.22769330064030255, 0.27558190923000014, 0.46426605775486673, 0.6138768502993978, 0.6404784864490097, 0.3418819669897764]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 28.050000000000022\n",
            "4 4\n",
            "204.99096501872376 0\n",
            "\n"
          ]
        },
        {
          "output_type": "error",
          "ename": "KeyboardInterrupt",
          "evalue": "ignored",
          "traceback": [
            "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
            "\u001b[0;31mKeyboardInterrupt\u001b[0m                         Traceback (most recent call last)",
            "\u001b[0;32m<ipython-input-12-f6e92396e2e5>\u001b[0m in \u001b[0;36m<module>\u001b[0;34m()\u001b[0m\n\u001b[1;32m    211\u001b[0m \u001b[0;31m# env.build_env1()\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    212\u001b[0m \u001b[0msgr\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mSGR_Sampling\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0menv\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;36m0.10\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;36m0.1\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m\"global\"\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 213\u001b[0;31m \u001b[0msgr\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mrun_SGR_sampling\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    214\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    215\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;32m<ipython-input-12-f6e92396e2e5>\u001b[0m in \u001b[0;36mrun_SGR_sampling\u001b[0;34m(self)\u001b[0m\n\u001b[1;32m    203\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    204\u001b[0m       \u001b[0mprint\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mtr\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mend\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;34m\", \"\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 205\u001b[0;31m       \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mrun_algorithm\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mtr\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    206\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    207\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;32m<ipython-input-12-f6e92396e2e5>\u001b[0m in \u001b[0;36mrun_algorithm\u001b[0;34m(self, tr)\u001b[0m\n\u001b[1;32m    172\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    173\u001b[0m       \u001b[0;32mif\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mt\u001b[0m\u001b[0;34m%\u001b[0m\u001b[0;36m20\u001b[0m \u001b[0;34m==\u001b[0m \u001b[0;36m0\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 174\u001b[0;31m         \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mdetect_changepoint\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mts\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mtp\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    175\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    176\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;32m<ipython-input-12-f6e92396e2e5>\u001b[0m in \u001b[0;36mdetect_changepoint\u001b[0;34m(self, ts, tp)\u001b[0m\n\u001b[1;32m     49\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     50\u001b[0m         \u001b[0mbeta_ts\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msqrt\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;36m0.5\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mlog\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;36m1.0\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;36m1.0\u001b[0m\u001b[0;34m/\u001b[0m\u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mlog\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;36m2\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mlog\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mt\u001b[0m\u001b[0;34m+\u001b[0m\u001b[0;36m1\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m/\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mconfidence\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m/\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msum\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mnumplays\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mint\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mts\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mk\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0mt_\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mk\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;34m+\u001b[0m \u001b[0;36m1\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 51\u001b[0;31m         \u001b[0mbeta_tp\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msqrt\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;36m0.5\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mlog\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;36m1.0\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;36m1.0\u001b[0m\u001b[0;34m/\u001b[0m\u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mlog\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;36m2\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mlog\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mt\u001b[0m\u001b[0;34m+\u001b[0m\u001b[0;36m1\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m/\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mconfidence\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m/\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msum\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mnumplays\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mt_\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mt\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mk\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;34m+\u001b[0m \u001b[0;36m1\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     52\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     53\u001b[0m         \u001b[0;32mif\u001b[0m \u001b[0;34m(\u001b[0m\u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msum\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mreward_arm\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mint\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mts\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mk\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0mt_\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mk\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m/\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msum\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mnumplays\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mint\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mts\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mk\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0mt_\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mk\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m+\u001b[0m\u001b[0;36m1\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;34m-\u001b[0m \u001b[0mbeta_ts\u001b[0m \u001b[0;34m>\u001b[0m \u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msum\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mreward_arm\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mt_\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mt\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mk\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m/\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msum\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mnumplays\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mt_\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mt\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mk\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;34m+\u001b[0m \u001b[0;36m1\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;34m+\u001b[0m \u001b[0mbeta_tp\u001b[0m\u001b[0;34m)\u001b[0m           \u001b[0;32mor\u001b[0m \u001b[0;34m(\u001b[0m\u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msum\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mreward_arm\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mint\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mts\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mk\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0mt_\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mk\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m/\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msum\u001b[0m\u001b[0;34m(\u001b[0m\u001b...\n",
            "\u001b[0;31mKeyboardInterrupt\u001b[0m: "
          ]
        }
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "b_DksKTt2J5C"
      },
      "source": [
        "# SGR-Explore\n",
        "\n",
        "Global Restart with Explore"
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 871
        },
        "id": "HJlJn9jD2KqC",
        "outputId": "69593fb6-c4e5-4461-cbe8-68dca79f3e38"
      },
      "source": [
        "import numpy as np\n",
        "\n",
        "class SGR_Sampling(object):\n",
        "\n",
        "  def __init__(self, env, confidence, alpha, type_):\n",
        "    \n",
        "    \n",
        "    self.env = env\n",
        "    self.confidence = confidence\n",
        "    \n",
        "    self.K = env.K\n",
        "    self.T = env.T\n",
        "    self.trials = env.trials\n",
        "\n",
        "\n",
        "    self.mu_hat = np.zeros((self.T, self.K))\n",
        "    self.sumreward = np.zeros((self.T, self.K))\n",
        "    self.reward_arm = np.zeros((self.T, self.K))\n",
        "    self.numplays = np.zeros((self.T, self.K))\n",
        "    \n",
        "    self.tol = 0.01\n",
        "    self.gamma = 0.01\n",
        "    \n",
        "    self.budget = 0\n",
        "    self.budget_error = 0\n",
        "    self.alpha = 0.7\n",
        "\n",
        "    self.estimated_G = np.zeros(self.K)\n",
        "    self.type_ = type_\n",
        "    \n",
        "    \n",
        "    \n",
        "    self.error = np.zeros((self.trials, self.T))\n",
        "  \n",
        "\n",
        "  def detect_changepoint(self, ts, tp):\n",
        "\n",
        "   \n",
        "\n",
        "    for k in range(self.K):\n",
        "      \n",
        "      #print(tp)\n",
        "      for t_ in range(int(ts[k])+1,self.t):\n",
        "\n",
        "        self.confidence = 1.0/self.t\n",
        "        beta_ts = np.sqrt(0.5*np.log(np.log(self.t+1)/self.confidence)/(np.sum(self.numplays[int(ts[k]):t_, k]) + 1))\n",
        "        beta_tp = np.sqrt(0.5*np.log(np.log(self.t+1)/self.confidence)/(np.sum(self.numplays[t_:self.t, k]) + 1))\n",
        "\n",
        "        if (np.sum(self.reward_arm[int(ts[k]):t_, k])/(np.sum(self.numplays[int(ts[k]):t_, k])+1) - beta_ts > np.sum(self.reward_arm[t_:self.t, k])/(np.sum(self.numplays[t_:self.t, k]) + 1) + beta_tp) \\\n",
        "          or (np.sum(self.reward_arm[int(ts[k]):t_, k])/(np.sum(self.numplays[int(ts[k]):t_, k]) + 1) + beta_ts < np.sum(self.reward_arm[t_:self.t, k])/(np.sum(self.numplays[t_:self.t, k]) + 1) - beta_tp): \n",
        "            \n",
        "         \n",
        "\n",
        "          if self.type_ == \"global\":\n",
        "            for k1 in range(self.K):\n",
        "\n",
        "              self.estimated_G[k1] += 1\n",
        "\n",
        "              #print(self.mu_hat[int(ts[k1]): int(tp[k1]), k1])\n",
        "              self.mu_hat[int(ts[k1]): self.t, k1] = 0.0\n",
        "              #print(self.mu_hat[int(ts[k1]): int(tp[k1]), k1])\n",
        "              self.numplays[int(ts[k1]): self.t, k1] = 0\n",
        "              self.sumreward[int(ts[k1]): self.t, k1] = 0.0\n",
        "              self.reward_arm[int(ts[k1]): self.t, k1] = 0.0\n",
        "              self.ts[k1] = self.t\n",
        "              #self.safe_set = set()\n",
        "              #self.budget = 0.0\n",
        "\n",
        "              #print(self.reward_arm[0: self.t, k])\n",
        "            print(\"Global Changepoint Detected at time \" + str(self.t))\n",
        "            \n",
        "            return True\n",
        "          \n",
        "          else:\n",
        "            \n",
        "            self.estimated_G[k] += 1\n",
        "            self.mu_hat[int(ts[k]): self.t, k] = 0.0\n",
        "            self.numplays[int(ts[k]): self.t, k] = 0\n",
        "            self.sumreward[int(ts[k]): self.t, k] = 0.0\n",
        "            self.reward_arm[int(ts[k]): self.t, k] = 0.0\n",
        "            self.ts[k] = self.t\n",
        "\n",
        "            \n",
        "\n",
        "            print(\"Arm \"+ str(k) +\" Changepoint Detected at time \" + str(self.t))\n",
        "            continue\n",
        "\n",
        "  def safe_set_function(self, ):\n",
        "    \n",
        "    self.safe_set = set()\n",
        "    for k in range(0, self.K-1):\n",
        "\n",
        "      \n",
        "      if self.mu_hat[self.t-1][k] >= self.alpha*self.env.threshold:\n",
        "        \n",
        "        self.safe_set.add((k, self.mu_hat[self.t-1][k]))\n",
        "    \n",
        "    return self.safe_set\n",
        "\n",
        "  def run_algorithm(self, tr):\n",
        "\n",
        "    self.seed = tr\n",
        "    np.random.seed(self.seed)\n",
        "    self.t = 0\n",
        "    self.ts = np.zeros(self.K)\n",
        "    self.tp = np.zeros(self.K)\n",
        "\n",
        "    self.budget = 0\n",
        "\n",
        "    self.mu_hat = np.zeros((self.T, self.K))\n",
        "    self.sumreward = np.zeros((self.T, self.K))\n",
        "    self.reward_arm = np.zeros((self.T, self.K))\n",
        "    self.numplays = np.zeros((self.T, self.K))\n",
        "\n",
        "    #Sample each arm once\n",
        "    \n",
        "\n",
        "    for i in range(0,self.K):\n",
        "      \n",
        "      arm = i\n",
        "      reward = self.env.pull_arm(arm, self.t)\n",
        "      #self.sumreward[self.t][arm] += reward\n",
        "      self.reward_arm[self.t][arm] = reward\n",
        "      self.numplays[self.t][arm] = 1\n",
        "      #self.mu_hat[self.t][arm] = self.sumreward[self.t][arm]/self.numplays[self.t][arm]\n",
        "\n",
        "      self.tp[arm] += 1\n",
        "\n",
        "      self.t += 1\n",
        "\n",
        "\n",
        "\n",
        "    sum1 = 0.0\n",
        "    self.ucb = np.zeros(self.K)\n",
        "    self.lcb = np.zeros(self.K)\n",
        "    self.B = np.zeros(self.K)\n",
        "    self.safe_set = set()\n",
        "\n",
        "    self.gamma = np.sqrt(np.log(self.T)/self.T)\n",
        "    \n",
        "    while self.t < self.T:\n",
        "      \n",
        "      for k in range(self.K):\n",
        "\n",
        "        # beta_ucb = np.sqrt(1.0*np.log(np.log(self.t+1)/self.confidence)/(np.sum(self.numplays[int(self.ts[k]):self.t, k]) + 1))\n",
        "        beta_ucb = np.sqrt(2.0*np.log(4.0*(1.0/np.log(2))*np.log(self.t+1)/self.confidence)/(np.sum(self.numplays[int(self.ts[k]):self.t, k]) + 1))\n",
        "        self.ucb[k] = np.sum(self.reward_arm[int(self.ts[k]):self.t, k])/(np.sum(self.numplays[int(self.ts[k]):self.t, k]) + 1) + beta_ucb\n",
        "        self.lcb[k] = max(0.0,np.sum(self.reward_arm[int(self.ts[k]):self.t, k])/(np.sum(self.numplays[int(self.ts[k]):self.t, k]) + 1) - beta_ucb)\n",
        "        self.B[k] = abs(np.sum(self.reward_arm[int(self.ts[k]):self.t, k])/(np.sum(self.numplays[int(self.ts[k]):self.t, k]) + 1) - self.alpha*self.env.threshold)*np.sqrt((np.sum(self.numplays[int(self.ts[k]):self.t, k]) + 1))\n",
        "\n",
        "      \n",
        "      self.safe_set = self.safe_set_function()\n",
        "\n",
        "      if self.t% (self.K/self.gamma) <= self.K:\n",
        "        arm = np.random.randint(0, self.K-1)\n",
        "        #print(\"fe\", arm, self.t% (self.K/self.gamma))\n",
        "      else:\n",
        "\n",
        "        if self.budget >= 0:\n",
        "          arm = np.argmax(self.ucb)\n",
        "        elif self.budget < 0:\n",
        "          arm = self.env.baseline\n",
        "      \n",
        "      reward = self.env.pull_arm(arm, self.t)\n",
        "      #self.sumreward[self.t][arm] += reward\n",
        "      self.reward_arm[self.t][arm] = reward\n",
        "      self.numplays[self.t][arm] = 1\n",
        "      #self.mu_hat[self.t][arm] = self.sumreward[self.t][arm]/self.numplays[self.t][arm]\n",
        "      self.mu_hat[self.t, :] = [np.sum(self.reward_arm[int(self.ts[i]):self.t,i])/(np.sum(self.numplays[int(self.ts[i]):self.t,i]) + 1 ) for i in range(self.K)]\n",
        "      \n",
        "      self.tp[arm] += 1\n",
        "      \n",
        "      self.budget +=  self.lcb[arm] + self.lcb[np.argmax(self.ucb)] - (1.0 - self.alpha)*self.lcb[self.env.baseline]\n",
        "      \n",
        "      if self.t%20 == 0:\n",
        "        self.detect_changepoint(self.ts, self.tp)\n",
        "        \n",
        "          \n",
        "\n",
        "      error1 = 0\n",
        "      \n",
        "      \n",
        "      error1 = self.env.mu_t[self.t][np.argmax(self.env.mu_t[self.t])] - self.env.mu_t[self.t][arm] + max(self.budget_error, 0.0)\n",
        "      #print(self.env.mu_t[self.t][np.argmax(self.env.mu_t[self.t])], self.env.mu_t[self.t][arm])\n",
        "      sum1 += error1\n",
        "      self.error[tr][self.t] =  sum1\n",
        "      #print(self.t,sum1)   \n",
        "      \n",
        "      if self.t%100 == 0 and self.t > 2.0*self.K:\n",
        "        print(\"t \" +str(self.t))\n",
        "        print(\"t reward-arm: \" + str([np.sum(self.reward_arm[int(self.ts[i]):self.t,i]) for i in range(self.K)]   ))\n",
        "        \n",
        "        print(\"t numplay: \" + str([np.sum(self.numplays[int(self.ts[i]):self.t,i]) for i in range(self.K)]   ), str(np.sum(self.numplays[int(self.ts[i]):self.t,:])))\n",
        "        print(\"t mu-hat: \" + str([np.sum(self.reward_arm[int(self.ts[i]):self.t,i])/(np.sum(self.numplays[int(self.ts[i]):self.t,i]) + 1 ) for i in range(self.K)]   ))\n",
        "        print(\"T true mu: \" + str(self.env.mu_t[self.t]) + \" Err: \" + str(self.error[tr][self.t]))\n",
        "        print(np.argmax(self.mu_hat[self.t]), np.argmax(self.env.mu_t[self.t]))\n",
        "        print(self.budget, self.budget_error)\n",
        "        print()\n",
        "      \n",
        "      self.t += 1\n",
        "\n",
        "  def run_SGR_sampling(self, ):\n",
        "\n",
        "    for tr in range(0,self.trials):\n",
        "      \n",
        "      print(tr, end=\", \")\n",
        "      self.run_algorithm(tr)\n",
        "\n",
        "\n",
        "# T = 8000\n",
        "# trials = 10\n",
        "# env = build_environment(5, 0.4, T, trials)\n",
        "# env.build_env1()\n",
        "sgr = SGR_Sampling(env, 0.10, 0.1, \"global\")\n",
        "sgr.run_SGR_sampling()\n",
        "\n",
        "\n"
      ],
      "execution_count": null,
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "[2000, 4000, 6000, 8000] 4\n",
            "0, t 100\n",
            "t reward-arm: [2.478315494470621, 3.6811591813083933, 8.53299884949385, 15.376821304165416, 15.136836490926823, 4.923310002809764]\n",
            "t numplay: [10.0, 12.0, 17.0, 24.0, 24.0, 13.0] 100.0\n",
            "t mu-hat: [0.2253014085882383, 0.28316609086987643, 0.47405549163854727, 0.6150728521666167, 0.6054734596370729, 0.3516650002006974]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 15.50000000000001\n",
            "3 4\n",
            "0.0 0\n",
            "\n",
            "t 200\n",
            "t reward-arm: [3.74672630278254, 6.2643194562137925, 15.99297501143312, 29.967168431247124, 37.83534533090399, 7.421730131593808]\n",
            "t numplay: [17.0, 21.0, 33.0, 49.0, 58.0, 22.0] 200.0\n",
            "t mu-hat: [0.20815146126569667, 0.2847417934642633, 0.47038161798332706, 0.5993433686249425, 0.6412770395068473, 0.3226839187649482]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 28.00000000000002\n",
            "4 4\n",
            "2.2255102101428976 0\n",
            "\n",
            "t 300\n",
            "t reward-arm: [4.938616154168306, 8.421582541729972, 23.898242463371965, 45.75402643709907, 59.67166461863536, 11.048497291471673]\n",
            "t numplay: [23.0, 28.0, 49.0, 76.0, 92.0, 32.0] 300.0\n",
            "t mu-hat: [0.20577567309034608, 0.2903993979906887, 0.4779648492674393, 0.5942081355467412, 0.6416308023509179, 0.3348029482264143]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 39.59999999999995\n",
            "4 4\n",
            "16.035146714126316 0\n",
            "\n"
          ]
        },
        {
          "ename": "KeyboardInterrupt",
          "evalue": "ignored",
          "output_type": "error",
          "traceback": [
            "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
            "\u001b[0;31mKeyboardInterrupt\u001b[0m                         Traceback (most recent call last)",
            "\u001b[0;32m<ipython-input-15-7941490f1aad>\u001b[0m in \u001b[0;36m<module>\u001b[0;34m()\u001b[0m\n\u001b[1;32m    212\u001b[0m \u001b[0menv\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mbuild_env1\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    213\u001b[0m \u001b[0msgr\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mSGR_Sampling\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0menv\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;36m0.10\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;36m0.1\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m\"global\"\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 214\u001b[0;31m \u001b[0msgr\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mrun_SGR_sampling\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    215\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    216\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;32m<ipython-input-15-7941490f1aad>\u001b[0m in \u001b[0;36mrun_SGR_sampling\u001b[0;34m(self)\u001b[0m\n\u001b[1;32m    204\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    205\u001b[0m       \u001b[0mprint\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mtr\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mend\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;34m\", \"\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 206\u001b[0;31m       \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mrun_algorithm\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mtr\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    207\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    208\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;32m<ipython-input-15-7941490f1aad>\u001b[0m in \u001b[0;36mrun_algorithm\u001b[0;34m(self, tr)\u001b[0m\n\u001b[1;32m    173\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    174\u001b[0m       \u001b[0;32mif\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mt\u001b[0m\u001b[0;34m%\u001b[0m\u001b[0;36m20\u001b[0m \u001b[0;34m==\u001b[0m \u001b[0;36m0\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 175\u001b[0;31m         \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mdetect_changepoint\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mts\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mtp\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    176\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    177\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;32m<ipython-input-15-7941490f1aad>\u001b[0m in \u001b[0;36mdetect_changepoint\u001b[0;34m(self, ts, tp)\u001b[0m\n\u001b[1;32m     47\u001b[0m         \u001b[0mbeta_tp\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msqrt\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;36m0.5\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mlog\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mlog\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mt\u001b[0m\u001b[0;34m+\u001b[0m\u001b[0;36m1\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m/\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mconfidence\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m/\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msum\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mnumplays\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mt_\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mt\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mk\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;34m+\u001b[0m \u001b[0;36m1\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     48\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 49\u001b[0;31m         \u001b[0;32mif\u001b[0m \u001b[0;34m(\u001b[0m\u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msum\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mreward_arm\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mint\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mts\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mk\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0mt_\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mk\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m/\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msum\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mnumplays\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mint\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mts\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mk\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0mt_\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mk\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m+\u001b[0m\u001b[0;36m1\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;34m-\u001b[0m \u001b[0mbeta_ts\u001b[0m \u001b[0;34m>\u001b[0m \u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msum\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mreward_arm\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mt_\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mt\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mk\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m/\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msum\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mnumplays\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mt_\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mt\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mk\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;34m+\u001b[0m \u001b[0;36m1\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;34m+\u001b[0m \u001b[0mbeta_tp\u001b[0m\u001b[0;34m)\u001b[0m           \u001b[0;32mor\u001b[0m \u001b[0;34m(\u001b[0m\u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msum\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mreward_arm\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mint\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mts\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mk\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0mt_\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mk\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m/\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msum\u001b[0m\u001b[0;34m(\u001b[...\n\u001b[0m\u001b[1;32m     50\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     51\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;32m<__array_function__ internals>\u001b[0m in \u001b[0;36msum\u001b[0;34m(*args, **kwargs)\u001b[0m\n",
            "\u001b[0;32m/usr/local/lib/python3.7/dist-packages/numpy/core/fromnumeric.py\u001b[0m in \u001b[0;36msum\u001b[0;34m(a, axis, dtype, out, keepdims, initial, where)\u001b[0m\n\u001b[1;32m   2240\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   2241\u001b[0m     return _wrapreduction(a, np.add, 'sum', axis, dtype, out, keepdims=keepdims,\n\u001b[0;32m-> 2242\u001b[0;31m                           initial=initial, where=where)\n\u001b[0m\u001b[1;32m   2243\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   2244\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;32m/usr/local/lib/python3.7/dist-packages/numpy/core/fromnumeric.py\u001b[0m in \u001b[0;36m_wrapreduction\u001b[0;34m(obj, ufunc, method, axis, dtype, out, **kwargs)\u001b[0m\n\u001b[1;32m     85\u001b[0m                 \u001b[0;32mreturn\u001b[0m \u001b[0mreduction\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0maxis\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0maxis\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mout\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mout\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mpasskwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     86\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 87\u001b[0;31m     \u001b[0;32mreturn\u001b[0m \u001b[0mufunc\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mreduce\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mobj\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0maxis\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mdtype\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mout\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mpasskwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     88\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     89\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;31mKeyboardInterrupt\u001b[0m: "
          ]
        }
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "Mwwrc-AhMzSQ"
      },
      "source": [
        "# SLR"
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "ayu09zg8M5o-",
        "outputId": "132eca93-48f9-47ed-f7d2-780095ce18ff"
      },
      "source": [
        "import numpy as np\n",
        "\n",
        "class SLR_Sampling(object):\n",
        "\n",
        "  def __init__(self, env, confidence, alpha, type_):\n",
        "    \n",
        "    \n",
        "    self.env = env\n",
        "    self.confidence = confidence\n",
        "    \n",
        "    self.K = env.K\n",
        "    self.T = env.T\n",
        "    self.trials = env.trials\n",
        "\n",
        "\n",
        "    self.mu_hat = np.zeros((self.T, self.K))\n",
        "    self.sumreward = np.zeros((self.T, self.K))\n",
        "    self.reward_arm = np.zeros((self.T, self.K))\n",
        "    self.numplays = np.zeros((self.T, self.K))\n",
        "    \n",
        "    self.tol = 0.01\n",
        "    self.gamma = 0.01\n",
        "    \n",
        "    self.budget = 0\n",
        "    self.budget_error = 0\n",
        "    self.alpha = 0.7\n",
        "\n",
        "    self.estimated_G = np.zeros(self.K)\n",
        "    self.type_ = type_\n",
        "    \n",
        "    \n",
        "    \n",
        "    self.error = np.zeros((self.trials, self.T))\n",
        "  \n",
        "\n",
        "  def detect_changepoint(self, ts, tp):\n",
        "\n",
        "   \n",
        "\n",
        "    for k in range(self.K):\n",
        "      \n",
        "      #print(tp)\n",
        "      for t_ in range(int(ts[k])+1,self.t):\n",
        "\n",
        "        \n",
        "        # beta_ts = np.sqrt(0.5*np.log(np.log(self.t+1)/self.confidence)/(np.sum(self.numplays[int(ts[k]):t_, k]) + 1))\n",
        "        # beta_tp = np.sqrt(0.5*np.log(np.log(self.t+1)/self.confidence)/(np.sum(self.numplays[t_:self.t, k]) + 1))\n",
        "\n",
        "        beta_ts = np.sqrt(0.5*np.log(1.0*(1.0/np.log(2))*np.log(self.t+1)/self.confidence)/(np.sum(self.numplays[int(ts[k]):t_, k]) + 1))\n",
        "        beta_tp = np.sqrt(0.5*np.log(1.0*(1.0/np.log(2))*np.log(self.t+1)/self.confidence)/(np.sum(self.numplays[t_:self.t, k]) + 1))\n",
        "\n",
        "        if (np.sum(self.reward_arm[int(ts[k]):t_, k])/(np.sum(self.numplays[int(ts[k]):t_, k])+1) - beta_ts > np.sum(self.reward_arm[t_:self.t, k])/(np.sum(self.numplays[t_:self.t, k]) + 1) + beta_tp) \\\n",
        "          or (np.sum(self.reward_arm[int(ts[k]):t_, k])/(np.sum(self.numplays[int(ts[k]):t_, k]) + 1) + beta_ts < np.sum(self.reward_arm[t_:self.t, k])/(np.sum(self.numplays[t_:self.t, k]) + 1) - beta_tp): \n",
        "            \n",
        "         \n",
        "\n",
        "          if self.type_ == \"global\":\n",
        "            for k1 in range(self.K):\n",
        "\n",
        "              self.estimated_G[k1] += 1\n",
        "\n",
        "              #print(self.mu_hat[int(ts[k1]): int(tp[k1]), k1])\n",
        "              self.mu_hat[int(ts[k1]): self.t, k1] = 0.0\n",
        "              #print(self.mu_hat[int(ts[k1]): int(tp[k1]), k1])\n",
        "              self.numplays[int(ts[k1]): self.t, k1] = 0\n",
        "              self.sumreward[int(ts[k1]): self.t, k1] = 0.0\n",
        "              self.reward_arm[int(ts[k1]): self.t, k1] = 0.0\n",
        "              self.ts[k1] = self.t\n",
        "              self.safe_set = set()\n",
        "              self.budget = 0.0\n",
        "              #print(self.reward_arm[0: self.t, k])\n",
        "            print(\"Global Changepoint Detected at time \" + str(self.t))\n",
        "            \n",
        "            return True\n",
        "          \n",
        "          else:\n",
        "            \n",
        "            self.estimated_G[k] += 1\n",
        "            self.mu_hat[int(ts[k]): self.t, k] = 0.0\n",
        "            self.numplays[int(ts[k]): self.t, k] = 0\n",
        "            self.sumreward[int(ts[k]): self.t, k] = 0.0\n",
        "            self.reward_arm[int(ts[k]): self.t, k] = 0.0\n",
        "            self.ts[k] = self.t\n",
        "            self.safe_set = set()\n",
        "            self.budget = 0.0\n",
        "\n",
        "            print(\"Arm \"+ str(k) +\" Changepoint Detected at time \" + str(self.t))\n",
        "            continue\n",
        "\n",
        "  def safe_set_function(self, ):\n",
        "    \n",
        "    self.safe_set = set()\n",
        "    for k in range(0, self.K-1):\n",
        "\n",
        "      #mu_hat = np.sum(self.reward_arm[int(self.ts[k]):self.t, k])/(np.sum(self.numplays[int(self.ts[k]):self.t, k]) + 1)\n",
        "      #if self.lcb[k] > self.env.threshold and self.ucb[k] < 1.5*self.env.threshold:\n",
        "      #if self.lcb[k] > self.env.threshold:\n",
        "      #if self.mu_hat[self.t-1][k] > self.env.threshold and self.mu_hat[self.t-1][k]  < 1.5*self.env.threshold:\n",
        "      if self.mu_hat[self.t-1][k] >= self.alpha*self.env.threshold:\n",
        "        \n",
        "        self.safe_set.add((k, self.mu_hat[self.t-1][k]))\n",
        "    \n",
        "    return self.safe_set\n",
        "\n",
        "  def run_algorithm(self, tr):\n",
        "\n",
        "    self.seed = tr\n",
        "    np.random.seed(self.seed)\n",
        "    self.t = 0\n",
        "    self.ts = np.zeros(self.K)\n",
        "    self.tp = np.zeros(self.K)\n",
        "\n",
        "    self.budget = 0\n",
        "\n",
        "    self.mu_hat = np.zeros((self.T, self.K))\n",
        "    self.sumreward = np.zeros((self.T, self.K))\n",
        "    self.reward_arm = np.zeros((self.T, self.K))\n",
        "    self.numplays = np.zeros((self.T, self.K))\n",
        "\n",
        "    #Sample each arm once\n",
        "    \n",
        "\n",
        "    for i in range(0,self.K):\n",
        "      \n",
        "      arm = i\n",
        "      reward = self.env.pull_arm(arm, self.t)\n",
        "      #self.sumreward[self.t][arm] += reward\n",
        "      self.reward_arm[self.t][arm] = reward\n",
        "      self.numplays[self.t][arm] = 1\n",
        "      #self.mu_hat[self.t][arm] = self.sumreward[self.t][arm]/self.numplays[self.t][arm]\n",
        "\n",
        "      self.tp[arm] += 1\n",
        "\n",
        "      self.t += 1\n",
        "\n",
        "\n",
        "\n",
        "    sum1 = 0.0\n",
        "    self.ucb = np.zeros(self.K)\n",
        "    self.lcb = np.zeros(self.K)\n",
        "    self.B = np.zeros(self.K)\n",
        "    self.safe_set = set()\n",
        "    self.gamma = np.sqrt(np.log(self.T)/self.T)\n",
        "\n",
        "    while self.t < self.T:\n",
        "      \n",
        "      for k in range(self.K):\n",
        "\n",
        "        beta_ucb = np.sqrt(1.0*np.log(np.log(self.t+1)/self.confidence)/(np.sum(self.numplays[int(self.ts[k]):self.t, k]) + 1))\n",
        "        self.ucb[k] = np.sum(self.reward_arm[int(self.ts[k]):self.t, k])/(np.sum(self.numplays[int(self.ts[k]):self.t, k]) + 1) + beta_ucb\n",
        "        self.lcb[k] = max(0.0,np.sum(self.reward_arm[int(self.ts[k]):self.t, k])/(np.sum(self.numplays[int(self.ts[k]):self.t, k]) + 1) - beta_ucb)\n",
        "        self.B[k] = abs(np.sum(self.reward_arm[int(self.ts[k]):self.t, k])/(np.sum(self.numplays[int(self.ts[k]):self.t, k]) + 1) - self.alpha*self.env.threshold)*np.sqrt((np.sum(self.numplays[int(self.ts[k]):self.t, k]) + 1))\n",
        "\n",
        "      \n",
        "      self.safe_set = self.safe_set_function()\n",
        "\n",
        "      # if self.t% (self.K/self.gamma) <= self.K:\n",
        "      #   arm = np.random.randint(0, self.K-1)\n",
        "      #   #print(\"fe\", arm, self.t% (self.K/self.gamma))\n",
        "      # else:\n",
        "\n",
        "      #   if self.budget >= 0 and len(self.safe_set) >= 1:\n",
        "      #     arm = np.argmax(self.ucb)\n",
        "      #   elif self.budget >= 0 and len(self.safe_set) == 0:\n",
        "      #     arm = np.argmin(self.B)\n",
        "      #   elif self.budget < 0 and len(self.safe_set) >= 1:\n",
        "      #     #print(len(self.safe_set))\n",
        "      #     #arm = np.random.choice(list(self.safe_set), 1)\n",
        "      #     arm = min(self.safe_set, key = lambda x: x[1])[0]\n",
        "      #   elif self.budget < 0 and len(self.safe_set) == 0:\n",
        "      #     #arm = np.argmax(self.ucb)\n",
        "\n",
        "      #     arm = self.env.baseline\n",
        "      \n",
        "      if self.budget >= 0:\n",
        "        if self.t% (self.K/self.gamma) <= self.K:\n",
        "          arm = np.random.randint(0, self.K-1)\n",
        "          #print(\"fe\", arm, self.t% (self.K/self.gamma))\n",
        "        else:\n",
        "          arm = np.argmax(self.ucb)\n",
        "      elif self.budget < 0:\n",
        "        arm = self.env.baseline\n",
        "\n",
        "      \n",
        "      reward = self.env.pull_arm(arm, self.t)\n",
        "      #self.sumreward[self.t][arm] += reward\n",
        "      self.reward_arm[self.t][arm] = reward\n",
        "      self.numplays[self.t][arm] = 1\n",
        "      #self.mu_hat[self.t][arm] = self.sumreward[self.t][arm]/self.numplays[self.t][arm]\n",
        "      self.mu_hat[self.t, :] = [np.sum(self.reward_arm[int(self.ts[i]):self.t,i])/(np.sum(self.numplays[int(self.ts[i]):self.t,i]) + 1 ) for i in range(self.K)]\n",
        "      \n",
        "      self.tp[arm] += 1\n",
        "      #print(\"t:\"+str(self.numplays[self.t]))\n",
        "      # if self.t > 1.0*self.K:\n",
        "      #   #print(t)\n",
        "\n",
        "      # self.budget +=  self.lcb[arm] + self.lcb[np.argmax(self.ucb)] - (1.0 - self.alpha)*self.ucb[self.env.safe_arm]\n",
        "      # self.budget_error += (1.0 - self.alpha)*self.env.mu_t[self.t][self.env.safe_arm] - self.env.mu_t[self.t][arm] - self.env.mu_t[self.t][np.argmax(self.env.mu_t[self.t])]\n",
        "\n",
        "      # self.budget +=  self.lcb[arm] + self.lcb[np.argmax(self.ucb)] - (1.0 - self.alpha)*self.ucb[np.argmin(self.safe_set)]\n",
        "      # self.budget_error += (1.0 - self.alpha)*self.env.mu_t[self.t][self.env.safe_arm] - self.env.mu_t[self.t][arm] - self.env.mu_t[self.t][np.argmin(self.env.mu_t[self.t])]\n",
        "\n",
        "      # if len(self.safe_set) > 0:\n",
        "      #   self.budget +=  self.lcb[arm] + self.lcb[np.argmax(self.ucb)] - (1.0 - self.alpha)*self.ucb[min(self.safe_set, key = lambda x: x[1])[0]]\n",
        "      self.budget +=  self.lcb[arm] + self.ucb[np.argmax(self.mu_hat[self.t, :])] - (1.0 - self.alpha)*self.ucb[self.env.baseline] - self.alpha*self.env.threshold\n",
        "      #self.budget_error += self.env.mu_t[self.t][arm] + self.env.mu_t[self.t][np.argmax(self.env.mu_t[self.t])] - (1.0 - self.alpha)*self.env.mu_t[self.t][self.env.safe_arm]\n",
        "      #self.budget_error += (1.0 - self.alpha)*self.env.mu_t[self.t][np.argmin(self.env.safe_arm_t[self.t])] - self.env.mu_t[self.t][arm] - self.env.mu_t[self.t][np.argmin(self.env.mu_t[self.t])]\n",
        "\n",
        "\n",
        "      if self.t%10 == 0:\n",
        "        self.detect_changepoint(self.ts, self.tp)\n",
        "        \n",
        "      error1 = 0\n",
        "      \n",
        "      \n",
        "      error1 = self.env.mu_t[self.t][np.argmax(self.env.mu_t[self.t])] - self.env.mu_t[self.t][arm] + max(self.budget_error, 0.0)\n",
        "      #print(self.env.mu_t[self.t][np.argmax(self.env.mu_t[self.t])], self.env.mu_t[self.t][arm])\n",
        "      sum1 += error1\n",
        "      self.error[tr][self.t] =  sum1\n",
        "      #print(self.t,sum1)   \n",
        "      \n",
        "      if self.t%100 == 0 and self.t > 2.0*self.K:\n",
        "        print(\"t \" +str(self.t))\n",
        "        print(\"t reward-arm: \" + str([np.sum(self.reward_arm[int(self.ts[i]):self.t,i]) for i in range(self.K)]   ))\n",
        "        #print(np.sum(self.tp), [int(self.tp[i]) for i in range(self.K)])\n",
        "        #print(np.sum(self.numplays[int(np.min(self.ts)):int(np.max(self.tp)),:], axis = 1))\n",
        "        #print(self.numplays[int(self.ts[2]):int(self.tp[2]),2], np.shape(self.numplays[int(self.ts[2]):int(self.tp[2]),2]))\n",
        "        #print(self.numplays[int(self.ts[2]):self.t,2], np.sum(self.numplays[int(self.ts[2]):self.t,2]))\n",
        "        print(\"t numplay: \" + str([np.sum(self.numplays[int(self.ts[i]):self.t,i]) for i in range(self.K)]   ), str(np.sum(self.numplays[int(self.ts[i]):self.t,:])))\n",
        "        print(\"t mu-hat: \" + str([np.sum(self.reward_arm[int(self.ts[i]):self.t,i])/(np.sum(self.numplays[int(self.ts[i]):self.t,i]) + 1 ) for i in range(self.K)]   ))\n",
        "        print(\"T true mu: \" + str(self.env.mu_t[self.t]) + \" Err: \" + str(self.error[tr][self.t]))\n",
        "        print(np.argmax(self.mu_hat[self.t]), np.argmax(self.env.mu_t[self.t]))\n",
        "        print(self.budget, self.budget_error, self.safe_set)\n",
        "        print()\n",
        "      \n",
        "      self.t += 1\n",
        "\n",
        "  def run_SLR_sampling(self, ):\n",
        "\n",
        "    for tr in range(0,self.trials):\n",
        "      \n",
        "      print(tr, end=\", \")\n",
        "      self.run_algorithm(tr)\n",
        "\n",
        "\n",
        "# T = 8000\n",
        "# trials = 10\n",
        "# env = build_environment(5, 0.4, T, trials)\n",
        "# env.build_env1()\n",
        "slr = SLR_Sampling(env, 0.10, 0.1, \"local\")\n",
        "slr.run_SLR_sampling()\n",
        "\n",
        "\n"
      ],
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "\u001b[1;30;43mStreaming output truncated to the last 5000 lines.\u001b[0m\n",
            "t mu-hat: [0.20935404775088165, 0.2564725848131447, 0.49272273288774704, 0.6009740965552726, 0.643945635747898, 0.26958986305060273]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 50.5499999999995\n",
            "4 4\n",
            "992.2884481341566 0 {(3, 0.6009740965552726), (2, 0.49272273288774704), (4, 0.6439282982030732)}\n",
            "\n",
            "t 1500\n",
            "t reward-arm: [3.7683728595158694, 6.068402921255549, 44.701758686386135, 216.83651494334092, 637.13098522908, 6.294602678310746]\n",
            "t numplay: [17.0, 23.0, 90.0, 360.0, 988.0, 22.0] 1500.0\n",
            "t mu-hat: [0.20935404775088162, 0.2528501217189812, 0.4912281174328147, 0.6006551660480358, 0.6442173763691406, 0.2736783773178585]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 52.49999999999945\n",
            "4 4\n",
            "1068.4385841986016 0 {(3, 0.6006551660480358), (2, 0.4912281174328147), (4, 0.6441199741720236)}\n",
            "\n",
            "t 1600\n",
            "t reward-arm: [3.7683728595158694, 6.068402921255549, 45.22341924194714, 225.25421753438258, 692.2393022595277, 6.294602678310746]\n",
            "t numplay: [17.0, 23.0, 91.0, 374.0, 1073.0, 22.0] 1600.0\n",
            "t mu-hat: [0.20935404775088162, 0.2528501217189812, 0.4915589048037733, 0.6006779134250202, 0.6445431119734895, 0.2736783773178585]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 53.34999999999941\n",
            "4 4\n",
            "1146.6274729471093 0 {(3, 0.6006779134250202), (2, 0.49155890480377334), (4, 0.6445793829303346)}\n",
            "\n",
            "t 1700\n",
            "t reward-arm: [3.7683728595158694, 7.06568609022416, 47.74523739986819, 236.34335773886562, 739.8878181724908, 6.75764060979801]\n",
            "t numplay: [17.0, 26.0, 96.0, 392.0, 1146.0, 23.0] 1700.0\n",
            "t mu-hat: [0.20935404775088162, 0.26169207741570966, 0.49221894226668234, 0.6013825896663247, 0.6450634857650313, 0.28156835874158376]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 56.349999999999355\n",
            "4 4\n",
            "1221.0157596768065 0 {(3, 0.6013825896663247), (2, 0.49221894226668234), (4, 0.6451012093167516)}\n",
            "\n",
            "t 1800\n",
            "t reward-arm: [3.9508301865936257, 7.316183524729518, 47.74523739986819, 245.2699730146684, 793.0123589090174, 7.035682963761866]\n",
            "t numplay: [18.0, 27.0, 96.0, 407.0, 1228.0, 24.0] 1800.0\n",
            "t mu-hat: [0.20793843087334873, 0.26129226874033995, 0.49221894226668234, 0.6011518946437951, 0.6452500886159621, 0.28142731855047465]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 58.199999999999314\n",
            "4 4\n",
            "1297.978738926193 0 {(3, 0.6011518946437951), (2, 0.49221894226668234), (4, 0.6452397325245104)}\n",
            "\n",
            "t 1900\n",
            "t reward-arm: [3.950830186593626, 7.316183524729519, 49.43516484239055, 250.02441270261687, 850.8824575202385, 7.035682963761866]\n",
            "t numplay: [18.0, 27.0, 99.0, 415.0, 1317.0, 24.0] 1900.0\n",
            "t mu-hat: [0.20793843087334873, 0.26129226874033995, 0.4943516484239055, 0.601020222842829, 0.6455860830957804, 0.28142731855047465]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 59.099999999999284\n",
            "4 4\n",
            "1376.445116946964 0 {(3, 0.6007974259049619), (2, 0.4943516484239055), (4, 0.6455860830957804)}\n",
            "\n",
            "t 2000\n",
            "t reward-arm: [4.74099431724105, 8.11713623264763, 50.53636787270683, 261.85628257808156, 899.0919932356169, 7.035682963761866]\n",
            "t numplay: [21.0, 29.0, 101.0, 434.0, 1391.0, 24.0] 2000.0\n",
            "t mu-hat: [0.215499741692775, 0.270571207754921, 0.4954545869873219, 0.6019684656967392, 0.6458994204278857, 0.28142731855047465]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 62.74999999999924\n",
            "4 0\n",
            "1451.4350152292238 0 {(3, 0.6018046347536994), (2, 0.4954545869873219), (4, 0.6458994204278857)}\n",
            "\n",
            "Arm 4 Changepoint Detected at time 2050\n",
            "t 2100\n",
            "t reward-arm: [4.74099431724105, 8.11713623264763, 74.31218039610988, 268.1069509949752, 5.2895252527262695, 7.040245802879607]\n",
            "t numplay: [21.0, 29.0, 143.0, 453.0, 21.0, 25.0] 692.0\n",
            "t mu-hat: [0.215499741692775, 0.270571207754921, 0.5160568083063186, 0.5905439449228529, 0.24043296603301226, 0.27077868472613875]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 94.04999999999968\n",
            "3 0\n",
            "21.797659373476908 0 {(3, 0.5905439449228529), (2, 0.5145835694252935)}\n",
            "\n",
            "t 2200\n",
            "t reward-arm: [4.74099431724105, 13.183322566995676, 112.27731813102076, 274.0729839201064, 5.800333228435685, 7.140724779587069]\n",
            "t numplay: [21.0, 37.0, 211.0, 474.0, 23.0, 26.0] 792.0\n",
            "t mu-hat: [0.215499741692775, 0.3469295412367283, 0.5296099911840602, 0.5769957556212767, 0.2416805511848202, 0.2644712881328544]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 114.40000000000016\n",
            "3 0\n",
            "76.44350673192696 0 {(3, 0.5769957556212766), (2, 0.5296099911840604), (1, 0.33732507703495707)}\n",
            "\n",
            "t 2300\n",
            "t reward-arm: [4.74099431724105, 77.14512339936643, 112.27731813102079, 274.0729839201064, 5.800333228435685, 7.140724779587069]\n",
            "t numplay: [21.0, 137.0, 211.0, 474.0, 23.0, 26.0] 892.0\n",
            "t mu-hat: [0.215499741692775, 0.5590226333287422, 0.5296099911840604, 0.5769957556212767, 0.2416805511848202, 0.2644712881328544]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 119.39999999999988\n",
            "3 0\n",
            "121.99681084375673 0 {(3, 0.5769957556212767), (2, 0.5296099911840604), (1, 0.5580540751364224)}\n",
            "\n",
            "t 2400\n",
            "t reward-arm: [6.2166967591346705, 139.1189595838842, 113.26091015705495, 274.0729839201064, 6.4313970218983805, 7.140724779587069]\n",
            "t numplay: [23.0, 231.0, 213.0, 474.0, 25.0, 26.0] 992.0\n",
            "t mu-hat: [0.25902903163061125, 0.5996506878615698, 0.5292565895189484, 0.5769957556212767, 0.2473614239191685, 0.2644712881328544]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 125.29999999999963\n",
            "1 0\n",
            "187.5914240230346 0 {(3, 0.5769957556212767), (2, 0.5292565895189484), (1, 0.5994295481679294)}\n",
            "\n",
            "Arm 1 Changepoint Detected at time 2460\n",
            "t 2500\n",
            "t reward-arm: [6.2166967591346705, 25.19259285375282, 113.26091015705495, 274.0729839201064, 6.4313970218983805, 7.140724779587069]\n",
            "t numplay: [23.0, 40.0, 213.0, 474.0, 25.0, 26.0] 801.0\n",
            "t mu-hat: [0.25902903163061125, 0.6144534842378737, 0.5292565895189484, 0.5769957556212767, 0.2473614239191685, 0.2644712881328544]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 130.29999999999998\n",
            "1 0\n",
            "27.145005688739804 0 {(3, 0.5769957556212767), (2, 0.5292565895189484), (1, 0.6117243340296121)}\n",
            "\n",
            "t 2600\n",
            "t reward-arm: [6.2166967591346705, 87.68625322113824, 113.26091015705495, 275.1923936408788, 7.160619976303924, 7.140724779587069]\n",
            "t numplay: [23.0, 134.0, 213.0, 477.0, 28.0, 26.0] 901.0\n",
            "t mu-hat: [0.25902903163061125, 0.6495278016380611, 0.5292565895189484, 0.5757163046880309, 0.2469179302173767, 0.2644712881328544]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 137.55000000000103\n",
            "1 0\n",
            "106.84268552616892 0 {(3, 0.5757163046880309), (2, 0.5292565895189484), (1, 0.6497561446825267)}\n",
            "\n",
            "t 2700\n",
            "t reward-arm: [6.816670161438414, 150.35322732512702, 113.26091015705492, 275.1923936408787, 8.343496657028794, 7.140724779587069]\n",
            "t numplay: [24.0, 229.0, 213.0, 477.0, 32.0, 26.0] 1001.0\n",
            "t mu-hat: [0.27266680645753655, 0.6537096840222913, 0.5292565895189483, 0.5757163046880308, 0.2528332320311756, 0.2644712881328544]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 144.10000000000207\n",
            "1 0\n",
            "186.3430335964475 0 {(3, 0.5757163046880308), (2, 0.5292565895189483), (1, 0.6528094722764666)}\n",
            "\n",
            "t 2800\n",
            "t reward-arm: [6.816670161438415, 214.77281819707298, 113.26091015705494, 275.1923936408787, 8.343496657028794, 7.140724779587069]\n",
            "t numplay: [24.0, 329.0, 213.0, 477.0, 32.0, 26.0] 1101.0\n",
            "t mu-hat: [0.2726668064575366, 0.650826721809312, 0.5292565895189483, 0.5757163046880308, 0.2528332320311756, 0.2644712881328544]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 149.1000000000032\n",
            "1 0\n",
            "268.7446015907389 0 {(3, 0.5757163046880308), (2, 0.5292565895189484), (1, 0.6507470586166474)}\n",
            "\n",
            "t 2900\n",
            "t reward-arm: [8.26928499615989, 277.0423578104811, 114.09237517555725, 275.4972909206109, 8.343496657028794, 7.14072477958707]\n",
            "t numplay: [26.0, 424.0, 215.0, 478.0, 32.0, 26.0] 1201.0\n",
            "t mu-hat: [0.3062698146725885, 0.6518643713187791, 0.5282054406275799, 0.5751509205023192, 0.2528332320311756, 0.2644712881328544]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 154.5500000000043\n",
            "1 0\n",
            "349.7323146109049 0 {(3, 0.5751509205023192), (2, 0.5282054406275799), (1, 0.6512986931101021), (0, 0.3062698146725885)}\n",
            "\n",
            "t 3000\n",
            "t reward-arm: [8.26928499615989, 341.6471667853449, 114.09237517555727, 275.49729092061085, 8.343496657028794, 7.140724779587069]\n",
            "t numplay: [26.0, 524.0, 215.0, 478.0, 32.0, 26.0] 1301.0\n",
            "t mu-hat: [0.3062698146725885, 0.6507565081625617, 0.5282054406275799, 0.5751509205023191, 0.2528332320311756, 0.2644712881328544]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 159.55000000000544\n",
            "1 0\n",
            "431.7991601845285 0 {(3, 0.5751509205023191), (2, 0.5282054406275799), (1, 0.6507893655642886), (0, 0.3062698146725885)}\n",
            "\n",
            "t 3100\n",
            "t reward-arm: [8.26928499615989, 401.6220486987672, 114.61019151829294, 275.49729092061085, 9.996455479914115, 7.140724779587069]\n",
            "t numplay: [26.0, 618.0, 216.0, 478.0, 37.0, 26.0] 1401.0\n",
            "t mu-hat: [0.3062698146725885, 0.6488239882047935, 0.5281575646004283, 0.5751509205023191, 0.2630646178924767, 0.2644712881328544]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 166.65000000000646\n",
            "1 0\n",
            "510.4916485778508 0 {(3, 0.5751509205023191), (2, 0.5281575646004283), (1, 0.6487180457343574), (0, 0.3062698146725885)}\n",
            "\n",
            "t 3200\n",
            "t reward-arm: [8.26928499615989, 466.3615999543529, 114.61019151829292, 275.4972909206109, 9.996455479914115, 7.140724779587069]\n",
            "t numplay: [26.0, 718.0, 216.0, 478.0, 37.0, 26.0] 1501.0\n",
            "t mu-hat: [0.3062698146725885, 0.6486253128711446, 0.5281575646004282, 0.5751509205023192, 0.2630646178924767, 0.2644712881328544]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 171.6500000000076\n",
            "1 0\n",
            "592.0917423542458 0 {(3, 0.5751509205023191), (2, 0.5281575646004283), (1, 0.648466969021793), (0, 0.3062698146725885)}\n",
            "\n",
            "Arm 3 Changepoint Detected at time 3230\n",
            "t 3300\n",
            "t reward-arm: [8.984991558615253, 514.2633641502847, 114.61019151829294, 5.428959104415336, 10.701708030569907, 7.140724779587069]\n",
            "t numplay: [27.0, 792.0, 216.0, 20.0, 39.0, 26.0] 1120.0\n",
            "t mu-hat: [0.32089255566483044, 0.6485036117910273, 0.5281575646004283, 0.258521862115016, 0.2675427007642477, 0.2644712881328544]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 185.45000000000854\n",
            "1 0\n",
            "45.825071152373326 0 {(2, 0.5281575646004283), (1, 0.6484454700293043), (0, 0.32089255566483044)}\n",
            "\n",
            "t 3400\n",
            "t reward-arm: [8.984991558615253, 578.5057795414796, 114.61019151829294, 5.428959104415336, 10.70170803056991, 7.14072477958707]\n",
            "t numplay: [27.0, 892.0, 216.0, 20.0, 39.0, 26.0] 1220.0\n",
            "t mu-hat: [0.32089255566483044, 0.6478228214350276, 0.5281575646004283, 0.258521862115016, 0.26754270076424774, 0.2644712881328544]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 190.45000000000968\n",
            "1 0\n",
            "127.46303946060254 0 {(2, 0.5281575646004283), (1, 0.647881211041127), (0, 0.32089255566483044)}\n",
            "\n",
            "t 3500\n",
            "t reward-arm: [67.00430375838957, 585.1844526199511, 115.57275103586298, 5.742313588362772, 11.385956304340937, 7.14072477958707]\n",
            "t numplay: [111.0, 903.0, 218.0, 21.0, 41.0, 26.0] 1320.0\n",
            "t mu-hat: [0.5982527121284783, 0.6473279343141052, 0.5277294567847625, 0.26101425401648964, 0.27109419772240323, 0.2644712881328544]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 192.5500000000098\n",
            "1 0\n",
            "179.6466387245004 0 {(2, 0.5277294567847625), (1, 0.6473279343141052), (0, 0.5955839696222188)}\n",
            "\n",
            "Arm 0 Changepoint Detected at time 3530\n",
            "t 3600\n",
            "t reward-arm: [44.92447170047643, 586.5157605873883, 116.00830906629464, 5.742313588362772, 11.840100213139618, 7.140724779587069]\n",
            "t numplay: [65.0, 905.0, 219.0, 21.0, 43.0, 26.0] 1279.0\n",
            "t mu-hat: [0.6806738136435823, 0.6473683891693027, 0.5273104957558847, 0.26101425401648964, 0.26909318666226406, 0.2644712881328544]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 193.7000000000098\n",
            "0 0\n",
            "49.04422762870052 0 {(2, 0.5273104957558847), (1, 0.6473683891693027), (0, 0.680751347281754)}\n",
            "\n",
            "t 3700\n",
            "t reward-arm: [112.87855609032307, 586.5157605873883, 116.00830906629464, 5.742313588362772, 11.840100213139618, 7.140724779587069]\n",
            "t numplay: [165.0, 905.0, 219.0, 21.0, 43.0, 26.0] 1379.0\n",
            "t mu-hat: [0.6799913017489342, 0.6473683891693027, 0.5273104957558847, 0.26101425401648964, 0.26909318666226406, 0.2644712881328544]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 193.7000000000098\n",
            "0 0\n",
            "137.48939778263832 0 {(2, 0.5273104957558847), (1, 0.6473683891693027), (0, 0.6808932494699648)}\n",
            "\n",
            "t 3800\n",
            "t reward-arm: [177.0077521684375, 586.5157605873883, 116.47508063030185, 6.5178236607367435, 12.88423281960698, 7.140724779587069]\n",
            "t numplay: [259.0, 905.0, 220.0, 23.0, 46.0, 26.0] 1479.0\n",
            "t mu-hat: [0.6807990468016827, 0.6473683891693027, 0.5270365639380175, 0.271575985864031, 0.27413261318312726, 0.2644712881328544]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 196.00000000000978\n",
            "0 0\n",
            "222.88408166840242 0 {(2, 0.5270365639380175), (1, 0.6473683891693027), (0, 0.6804362391738785)}\n",
            "\n",
            "t 3900\n",
            "t reward-arm: [248.03731571989925, 586.5157605873883, 116.47508063030185, 6.5178236607367435, 12.88423281960698, 7.140724779587069]\n",
            "t numplay: [359.0, 905.0, 220.0, 23.0, 46.0, 26.0] 1579.0\n",
            "t mu-hat: [0.6889925436663868, 0.6473683891693027, 0.5270365639380175, 0.271575985864031, 0.27413261318312726, 0.2644712881328544]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 196.00000000000978\n",
            "0 0\n",
            "312.08674210179396 0 {(2, 0.5270365639380175), (1, 0.6473683891693027), (0, 0.6886487954212565)}\n",
            "\n",
            "t 4000\n",
            "t reward-arm: [313.79056988014605, 587.2939572955607, 117.07760400131077, 6.959521294390745, 13.182766709715297, 7.140724779587069]\n",
            "t numplay: [454.0, 906.0, 221.0, 25.0, 47.0, 26.0] 1679.0\n",
            "t mu-hat: [0.6896496041321891, 0.6475126320788983, 0.527376594600499, 0.2676738959381056, 0.2746409731190687, 0.2644712881328544]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 198.0500000000098\n",
            "0 3\n",
            "399.9621313862233 0 {(2, 0.5273765946004989), (1, 0.6475126320788983), (0, 0.6901278106355947)}\n",
            "\n",
            "Arm 0 Changepoint Detected at time 4020\n",
            "t 4100\n",
            "t reward-arm: [2.2369158747760123, 636.0742731005764, 117.07760400131077, 6.959521294390745, 13.182766709715297, 7.140724779587069]\n",
            "t numplay: [14.0, 972.0, 221.0, 25.0, 47.0, 26.0] 1305.0\n",
            "t mu-hat: [0.1491277249850675, 0.6537248438854845, 0.527376594600499, 0.2676738959381056, 0.2746409731190687, 0.2644712881328544]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 221.20000000001036\n",
            "1 3\n",
            "58.06904243968456 0 {(2, 0.527376594600499), (1, 0.6536035144177363)}\n",
            "\n",
            "t 4200\n",
            "t reward-arm: [2.350128364035773, 707.6613179978783, 118.1612345105653, 7.867432776641291, 13.769027759179599, 7.140724779587069]\n",
            "t numplay: [15.0, 1066.0, 223.0, 26.0, 49.0, 26.0] 1405.0\n",
            "t mu-hat: [0.1468830227522358, 0.6632252277393423, 0.5275055112078808, 0.29138639913486264, 0.27538055518359195, 0.2644712881328544]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 228.06000000001143\n",
            "1 3\n",
            "138.8383585173944 0 {(3, 0.29138639913486264), (2, 0.5275055112078808), (1, 0.6631917666495779)}\n",
            "\n",
            "t 4300\n",
            "t reward-arm: [2.6620310866515324, 779.2533170129849, 118.1612345105653, 8.56779799823045, 14.233728833035489, 7.140724779587068]\n",
            "t numplay: [16.0, 1163.0, 223.0, 27.0, 50.0, 26.0] 1505.0\n",
            "t mu-hat: [0.15659006392067837, 0.6694616125541107, 0.5275055112078808, 0.3059927856510875, 0.27909272221638215, 0.26447128813285437]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 234.01000000001252\n",
            "1 3\n",
            "222.27778481459913 0 {(3, 0.3059927856510875), (2, 0.5275055112078808), (1, 0.6694616125541109)}\n",
            "\n",
            "t 4400\n",
            "t reward-arm: [2.6620310866515324, 853.9421466665954, 118.77798387556506, 9.391677339478939, 14.233728833035489, 7.140724779587069]\n",
            "t numplay: [16.0, 1261.0, 224.0, 28.0, 50.0, 26.0] 1605.0\n",
            "t mu-hat: [0.15659006392067837, 0.6766578024299488, 0.5279021505580669, 0.32385094274065307, 0.27909272221638215, 0.2644712881328544]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 239.19000000001364\n",
            "1 3\n",
            "307.9764687562126 0 {(3, 0.32385094274065307), (2, 0.527902150558067), (1, 0.6765295312906978)}\n",
            "\n",
            "t 4500\n",
            "t reward-arm: [3.017715489763152, 926.7639882240205, 119.43598875524364, 10.132423679655712, 14.41600492472126, 7.140724779587069]\n",
            "t numplay: [18.0, 1356.0, 225.0, 29.0, 51.0, 26.0] 1705.0\n",
            "t mu-hat: [0.1588271310401659, 0.6829506177037734, 0.5284778263506356, 0.33774745598852374, 0.2772308639369473, 0.2644712881328544]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 245.9200000000147\n",
            "1 3\n",
            "393.18796951463185 0 {(3, 0.33774745598852374), (2, 0.5284778263506356), (1, 0.6828360913562169)}\n",
            "\n",
            "t 4600\n",
            "t reward-arm: [3.0177154897631517, 1000.333475137332, 119.43598875524366, 10.132423679655712, 14.41600492472126, 7.140724779587069]\n",
            "t numplay: [18.0, 1456.0, 225.0, 29.0, 51.0, 26.0] 1805.0\n",
            "t mu-hat: [0.15882713104016588, 0.6865706761409279, 0.5284778263506357, 0.33774745598852374, 0.2772308639369473, 0.2644712881328544]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 250.92000000001585\n",
            "1 3\n",
            "481.9626684810096 0 {(3, 0.33774745598852374), (2, 0.5284778263506357), (1, 0.6864542217025414)}\n",
            "\n",
            "t 4700\n",
            "t reward-arm: [3.144918920190106, 1071.2201579822968, 119.43598875524366, 10.132423679655712, 16.151021133448513, 7.140724779587069]\n",
            "t numplay: [19.0, 1550.0, 225.0, 29.0, 56.0, 26.0] 1905.0\n",
            "t mu-hat: [0.1572459460095053, 0.6906641895437117, 0.5284778263506357, 0.33774745598852374, 0.2833512479552371, 0.2644712881328544]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 258.7200000000169\n",
            "1 3\n",
            "567.7915778896007 0 {(3, 0.33774745598852374), (2, 0.5284778263506357), (1, 0.6905897483293495), (4, 0.2833512479552371)}\n",
            "\n",
            "t 4800\n",
            "t reward-arm: [3.144918920190106, 1144.8502959792545, 119.43598875524366, 10.132423679655712, 16.151021133448516, 7.140724779587069]\n",
            "t numplay: [19.0, 1650.0, 225.0, 29.0, 56.0, 26.0] 2005.0\n",
            "t mu-hat: [0.1572459460095053, 0.6934284045907053, 0.5284778263506357, 0.33774745598852374, 0.28335124795523714, 0.2644712881328544]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 263.72000000001805\n",
            "1 3\n",
            "658.0574655500268 0 {(3, 0.33774745598852374), (2, 0.5284778263506357), (1, 0.6934379145290315), (4, 0.28335124795523714)}\n",
            "\n",
            "t 4900\n",
            "t reward-arm: [3.346105541484071, 1215.158724191634, 120.49915996202117, 10.865213112673045, 16.587725536629193, 7.140724779587069]\n",
            "t numplay: [20.0, 1745.0, 227.0, 30.0, 57.0, 26.0] 2105.0\n",
            "t mu-hat: [0.15933835911828909, 0.6959671959860447, 0.5285050875527244, 0.35049074557009824, 0.2859952678729171, 0.2644712881328544]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 270.1300000000191\n",
            "1 3\n",
            "746.438532276389 0 {(3, 0.35049074557009824), (2, 0.5285050875527244), (1, 0.6958880167329641), (4, 0.2859952678729171)}\n",
            "\n",
            "Arm 1 Changepoint Detected at time 5000\n",
            "t 5000\n",
            "t reward-arm: [3.3461055414840715, 0.0, 120.49915996202117, 10.865213112673045, 16.587725536629193, 7.140724779587069]\n",
            "t numplay: [20.0, 0.0, 227.0, 30.0, 57.0, 26.0] 360.0\n",
            "t mu-hat: [0.1593383591182891, 0.0, 0.5285050875527244, 0.35049074557009824, 0.2859952678729171, 0.2644712881328544]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 275.13000000002023\n",
            "1 3\n",
            "0.0 0 set()\n",
            "\n",
            "t 5100\n",
            "t reward-arm: [3.890605474812612, 72.97142379396419, 121.09987004249702, 11.523031027263018, 16.587725536629193, 7.140724779587069]\n",
            "t numplay: [23.0, 95.0, 228.0, 31.0, 57.0, 26.0] 460.0\n",
            "t mu-hat: [0.16210856145052552, 0.7601189978537937, 0.5288203931986769, 0.3600947196019693, 0.2859952678729171, 0.2644712881328544]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 281.96000000002135\n",
            "1 3\n",
            "97.76623757053574 0 {(3, 0.3600947196019693), (2, 0.5288203931986769), (1, 0.7602323842107437), (4, 0.2859952678729171)}\n",
            "\n",
            "t 5200\n",
            "t reward-arm: [4.132356004231274, 143.460672516501, 121.09987004249705, 13.039732188728289, 17.235818305657432, 7.140724779587069]\n",
            "t numplay: [24.0, 190.0, 228.0, 33.0, 59.0, 26.0] 560.0\n",
            "t mu-hat: [0.16529424016925096, 0.7511029974685917, 0.528820393198677, 0.3835215349625967, 0.28726363842762387, 0.2644712881328544]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 288.31000000002246\n",
            "1 3\n",
            "197.26000758054738 0 {(3, 0.3835215349625967), (2, 0.528820393198677), (1, 0.7502692501285041), (4, 0.28726363842762387)}\n",
            "\n",
            "t 5300\n",
            "t reward-arm: [4.132356004231274, 218.80033161502112, 121.09987004249703, 13.039732188728289, 17.23581830565743, 7.140724779587069]\n",
            "t numplay: [24.0, 290.0, 228.0, 33.0, 59.0, 26.0] 660.0\n",
            "t mu-hat: [0.16529424016925096, 0.7518911739347804, 0.528820393198677, 0.3835215349625967, 0.2872636384276238, 0.2644712881328544]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 293.3100000000236\n",
            "1 3\n",
            "299.3101258135081 0 {(3, 0.3835215349625967), (2, 0.528820393198677), (1, 0.7517219012958496), (4, 0.2872636384276238)}\n",
            "\n",
            "t 5400\n",
            "t reward-arm: [4.132356004231274, 289.02066482259306, 121.09987004249702, 13.799267216294886, 17.774670382820005, 7.140724779587069]\n",
            "t numplay: [24.0, 387.0, 228.0, 34.0, 61.0, 26.0] 760.0\n",
            "t mu-hat: [0.16529424016925096, 0.7448986206767862, 0.5288203931986769, 0.3942647776084253, 0.2866882319809678, 0.2644712881328544]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 299.1600000000247\n",
            "1 3\n",
            "399.1385944003038 0 {(3, 0.3942647776084253), (2, 0.5288203931986769), (1, 0.7447391637042797), (4, 0.2866882319809678)}\n",
            "\n",
            "t 5500\n",
            "t reward-arm: [4.132356004231274, 364.0223720143809, 121.09987004249703, 13.799267216294886, 17.774670382820002, 7.140724779587069]\n",
            "t numplay: [24.0, 487.0, 228.0, 34.0, 61.0, 26.0] 860.0\n",
            "t mu-hat: [0.16529424016925096, 0.7459474836360264, 0.528820393198677, 0.3942647776084253, 0.28668823198096777, 0.2644712881328544]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 304.16000000002583\n",
            "1 3\n",
            "499.91961609929825 0 {(3, 0.3942647776084253), (2, 0.528820393198677), (1, 0.7456961270247099), (4, 0.28668823198096777)}\n",
            "\n",
            "t 5600\n",
            "t reward-arm: [4.619134913230835, 435.4086387967569, 121.45330894202428, 14.50924097243211, 18.118575312574755, 7.140724779587069]\n",
            "t numplay: [26.0, 582.0, 229.0, 35.0, 62.0, 26.0] 960.0\n",
            "t mu-hat: [0.17107907086040128, 0.7468415759807151, 0.5280578649653229, 0.4030344714564475, 0.2875964335329326, 0.2644712881328544]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 310.89000000002693\n",
            "1 3\n",
            "598.3611412388203 0 {(3, 0.4030344714564475), (2, 0.528057864965323), (1, 0.747104194530922), (4, 0.2875964335329326)}\n",
            "\n",
            "t 5700\n",
            "t reward-arm: [4.619134913230835, 510.9860341694515, 121.4533089420243, 14.50924097243211, 18.118575312574755, 7.14072477958707]\n",
            "t numplay: [26.0, 682.0, 229.0, 35.0, 62.0, 26.0] 1060.0\n",
            "t mu-hat: [0.17107907086040128, 0.7481493911705, 0.528057864965323, 0.4030344714564475, 0.2875964335329326, 0.2644712881328544]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 315.89000000002807\n",
            "1 3\n",
            "699.69472185883 0 {(3, 0.4030344714564475), (2, 0.528057864965323), (1, 0.748112241941979), (4, 0.2875964335329326)}\n",
            "\n",
            "t 5800\n",
            "t reward-arm: [4.619134913230835, 583.9208003360602, 122.06020291257059, 16.189968348597652, 18.42216879026365, 7.14072477958707]\n",
            "t numplay: [26.0, 778.0, 230.0, 37.0, 63.0, 26.0] 1160.0\n",
            "t mu-hat: [0.17107907086040128, 0.7495774073633635, 0.5283991468076649, 0.42605179864730663, 0.28784638734786955, 0.2644712881328544]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 321.47000000002913\n",
            "1 3\n",
            "799.1248779023514 0 {(3, 0.42605179864730663), (2, 0.5283991468076649), (1, 0.7494807767998971), (4, 0.28784638734786955)}\n",
            "\n",
            "t 5900\n",
            "t reward-arm: [4.619134913230836, 658.7715812523064, 122.0602029125706, 16.189968348597652, 18.42216879026365, 7.140724779587069]\n",
            "t numplay: [26.0, 878.0, 230.0, 37.0, 63.0, 26.0] 1260.0\n",
            "t mu-hat: [0.17107907086040133, 0.749455723836526, 0.528399146807665, 0.42605179864730663, 0.28784638734786955, 0.2644712881328544]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 326.47000000003027\n",
            "1 3\n",
            "900.8421124701906 0 {(3, 0.42605179864730663), (2, 0.528399146807665), (1, 0.7493569832331505), (4, 0.28784638734786955)}\n",
            "\n",
            "t 6000\n",
            "t reward-arm: [5.032675285849644, 728.6651915068879, 122.0602029125706, 19.011439505983258, 18.90093717454159, 7.140724779587069]\n",
            "t numplay: [27.0, 972.0, 230.0, 41.0, 64.0, 26.0] 1360.0\n",
            "t mu-hat: [0.1797384030660587, 0.7488850889073874, 0.528399146807665, 0.45265332157102994, 0.29078364883910135, 0.2644712881328544]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 332.72000000003135\n",
            "1 4\n",
            "998.9480866411562 0 {(3, 0.45265332157102994), (2, 0.528399146807665), (1, 0.7490069432918453), (4, 0.29078364883910135)}\n",
            "\n",
            "Arm 1 Changepoint Detected at time 6010\n",
            "t 6100\n",
            "t reward-arm: [5.70013324982624, 4.081162595303418, 145.79853007018642, 25.697048143291074, 19.647421491475775, 7.196369614794567]\n",
            "t numplay: [28.0, 21.0, 273.0, 64.0, 65.0, 27.0] 478.0\n",
            "t mu-hat: [0.19655631895952552, 0.18550739069560993, 0.532111423613819, 0.39533920220447805, 0.2976882044162996, 0.2570132005283774]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 364.12000000002985\n",
            "2 4\n",
            "37.25041629833123 0 {(3, 0.39533920220447805), (2, 0.5326236281653108), (4, 0.2976882044162996)}\n",
            "\n",
            "t 6200\n",
            "t reward-arm: [5.70013324982624, 4.081162595303418, 196.65413935336326, 26.678770167122533, 19.64742149147578, 7.222279896976059]\n",
            "t numplay: [28.0, 21.0, 368.0, 68.0, 65.0, 28.0] 578.0\n",
            "t mu-hat: [0.19655631895952552, 0.18550739069560993, 0.5329380470280847, 0.3866488430017758, 0.2976882044162997, 0.2490441343784848]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 380.5200000000276\n",
            "2 4\n",
            "94.92407188955958 0 {(3, 0.3866488430017758), (2, 0.5324384258853282), (4, 0.2976882044162997)}\n",
            "\n",
            "t 6300\n",
            "t reward-arm: [6.188464312564234, 4.970649156652119, 242.93184954403898, 28.379021307707145, 20.204146193037783, 7.5203143318209404]\n",
            "t numplay: [29.0, 25.0, 455.0, 73.0, 66.0, 30.0] 678.0\n",
            "t mu-hat: [0.20628214375214113, 0.19117881371738918, 0.5327452840878047, 0.3835002879419884, 0.3015544207916087, 0.2425907848974497]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 398.72000000002555\n",
            "2 4\n",
            "149.50463998322746 0 {(3, 0.3835002879419884), (2, 0.5328016113854451), (4, 0.3015544207916087)}\n",
            "\n",
            "t 6400\n",
            "t reward-arm: [6.188464312564234, 4.970649156652119, 297.2453125360315, 28.950653661831872, 20.204146193037783, 7.5203143318209404]\n",
            "t numplay: [29.0, 25.0, 553.0, 75.0, 66.0, 30.0] 778.0\n",
            "t mu-hat: [0.20628214375214113, 0.19117881371738918, 0.5365438854441003, 0.3809296534451562, 0.3015544207916087, 0.2425907848974497]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 414.2200000000233\n",
            "2 4\n",
            "209.1145967771273 0 {(3, 0.3809296534451562), (2, 0.5366939703045466), (4, 0.3015544207916087)}\n",
            "\n",
            "t 6500\n",
            "t reward-arm: [8.251808178723543, 5.312818053850882, 349.5307351487793, 29.30411207107303, 21.753293933537396, 7.5203143318209404]\n",
            "t numplay: [32.0, 26.0, 646.0, 76.0, 68.0, 30.0] 878.0\n",
            "t mu-hat: [0.2500547932946528, 0.19677103903151416, 0.5402329755004317, 0.38057288403990946, 0.31526512947155644, 0.2425907848974497]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 429.2200000000212\n",
            "2 4\n",
            "267.3720771683946 0 {(3, 0.38057288403990946), (2, 0.540127612963433), (4, 0.31526512947155644)}\n",
            "\n",
            "t 6600\n",
            "t reward-arm: [8.251808178723543, 5.312818053850882, 402.3193118665395, 29.860157525115426, 21.753293933537392, 7.635320633009679]\n",
            "t numplay: [32.0, 26.0, 743.0, 78.0, 68.0, 31.0] 978.0\n",
            "t mu-hat: [0.2500547932946528, 0.19677103903151416, 0.5407517632614779, 0.37797667753310665, 0.31526512947155644, 0.23860376978155245]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 445.02000000001897\n",
            "2 4\n",
            "327.7178825991412 0 {(3, 0.37797667753310665), (2, 0.5411314070099321), (4, 0.31526512947155644)}\n",
            "\n",
            "Arm 0 Changepoint Detected at time 6680\n",
            "t 6700\n",
            "t reward-arm: [12.57489147749569, 5.510824456371428, 402.3193118665395, 30.644798026796366, 22.557730732978044, 7.635320633009679]\n",
            "t numplay: [20.0, 27.0, 743.0, 80.0, 69.0, 31.0] 970.0\n",
            "t mu-hat: [0.5988043560712233, 0.19681515915612244, 0.5407517632614779, 0.37833083983699217, 0.3222532961854006, 0.23860376978155245]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 451.12000000002\n",
            "0 4\n",
            "11.21804841164778 0 {(3, 0.37833083983699217), (2, 0.5407517632614779), (0, 0.5972237919776285), (4, 0.3222532961854006)}\n",
            "\n",
            "t 6800\n",
            "t reward-arm: [76.29171523386023, 5.510824456371428, 402.3193118665395, 30.64479802679636, 22.557730732978044, 7.6353206330096794]\n",
            "t numplay: [120.0, 27.0, 743.0, 80.0, 69.0, 31.0] 1070.0\n",
            "t mu-hat: [0.6305100432550432, 0.19681515915612244, 0.5407517632614779, 0.37833083983699206, 0.3222532961854006, 0.23860376978155248]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 456.12000000002115\n",
            "0 4\n",
            "89.96914439873369 0 {(3, 0.37833083983699206), (2, 0.5407517632614779), (0, 0.6313008381919862), (4, 0.3222532961854006)}\n",
            "\n",
            "t 6900\n",
            "t reward-arm: [137.86119597712656, 5.739331687427614, 403.0423027653703, 31.332115119347343, 23.995558371255072, 7.6353206330096794]\n",
            "t numplay: [214.0, 28.0, 744.0, 82.0, 71.0, 31.0] 1170.0\n",
            "t mu-hat: [0.641214865009891, 0.19790798922164188, 0.5409963795508327, 0.37749536288370295, 0.3332716440452093, 0.23860376978155248]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 462.27000000002215\n",
            "0 4\n",
            "169.4699964228762 0 {(3, 0.37749536288370295), (2, 0.5409963795508327), (0, 0.6415706449358145), (4, 0.3332716440452093)}\n",
            "\n",
            "t 7000\n",
            "t reward-arm: [198.8480246286515, 5.823056472479009, 404.0294718876273, 31.332115119347343, 24.821923040040215, 7.6353206330096794]\n",
            "t numplay: [310.0, 29.0, 746.0, 82.0, 72.0, 31.0] 1270.0\n",
            "t mu-hat: [0.639382715847754, 0.19410188241596696, 0.5408694402779483, 0.37749536288370295, 0.3400263430142495, 0.23860376978155248]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 467.8700000000232\n",
            "0 4\n",
            "250.3293745297294 0 {(3, 0.37749536288370295), (2, 0.5408694402779483), (0, 0.6392433808889847), (4, 0.3400263430142495)}\n",
            "\n",
            "t 7100\n",
            "t reward-arm: [262.6086211431851, 5.823056472479009, 404.0294718876274, 31.332115119347343, 24.821923040040218, 7.635320633009679]\n",
            "t numplay: [410.0, 29.0, 746.0, 82.0, 72.0, 31.0] 1370.0\n",
            "t mu-hat: [0.6389504164067763, 0.19410188241596696, 0.5408694402779483, 0.37749536288370295, 0.34002634301424955, 0.23860376978155245]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 472.87000000002433\n",
            "0 4\n",
            "331.93447077758225 0 {(3, 0.37749536288370295), (2, 0.5408694402779483), (0, 0.6387279480867348), (4, 0.34002634301424955)}\n",
            "\n",
            "t 7200\n",
            "t reward-arm: [325.1023603192562, 5.917875776102813, 404.55378999593813, 31.928222106442554, 24.821923040040215, 7.635320633009679]\n",
            "t numplay: [506.0, 30.0, 747.0, 84.0, 72.0, 31.0] 1470.0\n",
            "t mu-hat: [0.6412275351464619, 0.1908992185839617, 0.5408473128287943, 0.37562614242873593, 0.3400263430142495, 0.23860376978155245]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 479.12000000002536\n",
            "0 4\n",
            "412.2086702531145 0 {(3, 0.37562614242873593), (2, 0.5408473128287943), (0, 0.6411336090962455), (4, 0.3400263430142495)}\n",
            "\n",
            "t 7300\n",
            "t reward-arm: [390.32254415161157, 5.917875776102813, 404.5537899959381, 31.928222106442554, 24.821923040040218, 7.635320633009679]\n",
            "t numplay: [606.0, 30.0, 747.0, 84.0, 72.0, 31.0] 1570.0\n",
            "t mu-hat: [0.6430354928362628, 0.1908992185839617, 0.5408473128287942, 0.37562614242873593, 0.34002634301424955, 0.23860376978155245]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 484.1200000000265\n",
            "0 4\n",
            "494.24043962499275 0 {(3, 0.37562614242873593), (2, 0.5408473128287942), (0, 0.6429698131699729), (4, 0.34002634301424955)}\n",
            "\n",
            "t 7400\n",
            "t reward-arm: [450.21480302582063, 6.29267838172171, 404.55378999593813, 32.49247336187184, 25.56015872393906, 7.635320633009679]\n",
            "t numplay: [701.0, 33.0, 747.0, 85.0, 73.0, 31.0] 1670.0\n",
            "t mu-hat: [0.6413316282419097, 0.18507877593299146, 0.5408473128287943, 0.37781945769618414, 0.34540755032350084, 0.23860376978155245]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 490.77000000002755\n",
            "0 4\n",
            "573.6996212326471 0 {(3, 0.37781945769618414), (2, 0.5408473128287942), (0, 0.6411833070331333), (4, 0.34540755032350084)}\n",
            "\n",
            "t 7500\n",
            "t reward-arm: [514.0131655219939, 6.29267838172171, 404.55378999593813, 32.49247336187184, 25.56015872393906, 7.635320633009679]\n",
            "t numplay: [801.0, 33.0, 747.0, 85.0, 73.0, 31.0] 1770.0\n",
            "t mu-hat: [0.6409141714738078, 0.18507877593299146, 0.5408473128287943, 0.37781945769618414, 0.34540755032350084, 0.23860376978155245]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 495.7700000000287\n",
            "0 4\n",
            "655.5533434667462 0 {(3, 0.37781945769618414), (2, 0.5408473128287943), (0, 0.6409095112143227), (4, 0.34540755032350084)}\n",
            "\n",
            "t 7600\n",
            "t reward-arm: [577.2996256458839, 6.29267838172171, 404.553789995938, 33.53173938877901, 27.07649803663729, 7.635320633009679]\n",
            "t numplay: [896.0, 33.0, 747.0, 88.0, 75.0, 31.0] 1870.0\n",
            "t mu-hat: [0.6435893262495919, 0.18507877593299146, 0.5408473128287942, 0.376761116727854, 0.3562697110083854, 0.23860376978155245]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 501.7200000000297\n",
            "0 4\n",
            "735.45087111756 0 {(3, 0.376761116727854), (2, 0.5408473128287942), (0, 0.643476016275937), (4, 0.3562697110083854)}\n",
            "\n",
            "t 7700\n",
            "t reward-arm: [640.9934910814968, 6.29267838172171, 404.553789995938, 34.056835554477324, 27.07649803663729, 7.635320633009679]\n",
            "t numplay: [994.0, 33.0, 747.0, 90.0, 75.0, 31.0] 1970.0\n",
            "t mu-hat: [0.6442145639010018, 0.18507877593299146, 0.5408473128287942, 0.3742509401590915, 0.3562697110083854, 0.23860376978155245]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 507.37000000003076\n",
            "0 4\n",
            "816.5655131942466 0 {(3, 0.3745939171898302), (2, 0.5408473128287942), (0, 0.6442145639010018), (4, 0.3562697110083854)}\n",
            "\n",
            "t 7800\n",
            "t reward-arm: [705.0785726908578, 6.4281029923033275, 404.553789995938, 34.056835554477324, 27.958533197301815, 7.635320633009679]\n",
            "t numplay: [1092.0, 34.0, 747.0, 90.0, 76.0, 31.0] 2070.0\n",
            "t mu-hat: [0.6450856108791013, 0.1836600854943808, 0.5408473128287942, 0.3742509401590915, 0.3630978337311924, 0.23860376978155245]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 512.820000000031\n",
            "0 4\n",
            "898.5070878924433 0 {(3, 0.3742509401590915), (2, 0.5408473128287942), (0, 0.6449958320448552), (4, 0.3630978337311924)}\n",
            "\n",
            "t 7900\n",
            "t reward-arm: [766.6267050933059, 7.006768225099515, 405.15294477366103, 34.36617352601006, 27.95853319730181, 7.635320633009679]\n",
            "t numplay: [1187.0, 37.0, 748.0, 91.0, 76.0, 31.0] 2170.0\n",
            "t mu-hat: [0.6453086743209645, 0.18438863750261883, 0.54092515991143, 0.37354536441315284, 0.36309783373119237, 0.23860376978155245]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 519.6200000000266\n",
            "0 4\n",
            "978.7818612425028 0 {(3, 0.37354536441315284), (2, 0.54092515991143), (0, 0.6452518013919181), (4, 0.36309783373119237)}\n",
            "\n",
            "3, t 100\n",
            "t reward-arm: [1.3227328015449364, 1.921470494231007, 9.340741145937972, 16.23672290191972, 21.00906077321599, 3.3173623203587983]\n",
            "t numplay: [6.0, 7.0, 18.0, 27.0, 33.0, 9.0] 100.0\n",
            "t mu-hat: [0.18896182879213377, 0.24018381177887588, 0.49161795504936695, 0.5798829607828472, 0.6179135521534115, 0.3317362320358798]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 10.600000000000009\n",
            "4 4\n",
            "54.411161472870965 0 {(3, 0.5798829607828472), (2, 0.49642516679106524), (4, 0.6179135521534115)}\n",
            "\n",
            "t 200\n",
            "t reward-arm: [1.9391146760096136, 3.3293392921431266, 16.119066288770938, 34.105830521466586, 51.14376510424464, 4.604648307025163]\n",
            "t numplay: [9.0, 11.0, 32.0, 56.0, 79.0, 13.0] 200.0\n",
            "t mu-hat: [0.19391146760096137, 0.27744494101192724, 0.4884565542051799, 0.5983479038853787, 0.6392970638030581, 0.3289034505017973]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 18.150000000000027\n",
            "4 4\n",
            "116.21663694859578 0 {(3, 0.5958786828055481), (2, 0.4884565542051799), (4, 0.6392970638030581)}\n",
            "\n",
            "t 300\n",
            "t reward-arm: [2.0232110295074928, 4.303677800986194, 18.19199763315626, 50.162966298304, 93.96628684301571, 5.5587511489059525]\n",
            "t numplay: [10.0, 14.0, 36.0, 82.0, 142.0, 16.0] 300.0\n",
            "t mu-hat: [0.18392827540977208, 0.2869118533990796, 0.4916756117069259, 0.6043730879313735, 0.6571069010001098, 0.32698536170035014]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 22.400000000000045\n",
            "4 4\n",
            "186.58917706718253 0 {(3, 0.6043730879313735), (2, 0.4916756117069259), (1, 0.2869118533990796), (4, 0.6582087451393988)}\n",
            "\n",
            "t 400\n",
            "t reward-arm: [2.540081561072108, 4.949419603858173, 20.830647956610438, 67.61172393092193, 131.0705940073291, 6.662816622586977]\n",
            "t numplay: [12.0, 16.0, 42.0, 111.0, 200.0, 19.0] 400.0\n",
            "t mu-hat: [0.19539088931323909, 0.29114232963871606, 0.4844336734095451, 0.6036761065260886, 0.6520925074991498, 0.33314083112934884]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 27.30000000000006\n",
            "4 4\n",
            "256.7464440108665 0 {(3, 0.6036761065260886), (2, 0.4844336734095451), (1, 0.29114232963871606), (4, 0.6524761800580207)}\n",
            "\n",
            "t 500\n",
            "t reward-arm: [2.540081561072108, 5.7533415436996185, 24.889774486819963, 84.46276642991428, 169.5816712878762, 7.389509014798081]\n",
            "t numplay: [12.0, 18.0, 50.0, 139.0, 260.0, 21.0] 500.0\n",
            "t mu-hat: [0.19539088931323909, 0.30280744966840095, 0.48803479385921494, 0.6033054744993878, 0.649738204168108, 0.3358867733999128]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 31.150000000000073\n",
            "4 4\n",
            "328.17838776994 0 {(3, 0.6032290512053711), (2, 0.48803479385921494), (1, 0.30280744966840095), (4, 0.649738204168108)}\n",
            "\n",
            "t 600\n",
            "t reward-arm: [2.7322538862164407, 6.959772036740688, 27.34644531087715, 96.55954029232643, 213.41216428353638, 7.633003289573267]\n",
            "t numplay: [13.0, 22.0, 55.0, 160.0, 328.0, 22.0] 600.0\n",
            "t mu-hat: [0.1951609918726029, 0.30259878420611686, 0.4883293805513777, 0.5997486974678661, 0.6486691923511744, 0.331869708242316]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 35.10000000000004\n",
            "4 4\n",
            "400.21263596901065 0 {(3, 0.5997486974678661), (2, 0.4883293805513777), (1, 0.30259878420611686), (4, 0.6489110796797407)}\n",
            "\n",
            "t 700\n",
            "t reward-arm: [2.7322538862164407, 6.959772036740689, 29.889822968493945, 104.77761796492493, 266.65083972950026, 7.965424473363978]\n",
            "t numplay: [13.0, 22.0, 60.0, 174.0, 408.0, 23.0] 700.0\n",
            "t mu-hat: [0.1951609918726029, 0.3025987842061169, 0.489997097844163, 0.5987292455138568, 0.6519580433484115, 0.3318926863901657]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 36.899999999999984\n",
            "4 4\n",
            "476.161394879361 0 {(3, 0.598330629616048), (2, 0.489997097844163), (1, 0.3025987842061169), (4, 0.6519580433484115)}\n",
            "\n",
            "t 800\n",
            "t reward-arm: [2.950285551307938, 7.890566017290565, 31.8427695846625, 118.54861543244868, 310.2327912054403, 8.20910169616075]\n",
            "t numplay: [14.0, 25.0, 64.0, 197.0, 476.0, 24.0] 800.0\n",
            "t mu-hat: [0.1966857034205292, 0.30348330835732945, 0.4898887628409615, 0.5987303809719631, 0.6503832100742983, 0.32836406784643]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 40.44999999999992\n",
            "4 4\n",
            "549.7585099789492 0 {(3, 0.5983358275428811), (2, 0.48988876284096144), (1, 0.30348330835732945), (4, 0.6503832100742983)}\n",
            "\n",
            "t 900\n",
            "t reward-arm: [3.209287727076341, 7.890566017290565, 35.587263573667876, 133.4626947488677, 353.5940579073316, 8.666414679525783]\n",
            "t numplay: [15.0, 25.0, 71.0, 221.0, 543.0, 25.0] 900.0\n",
            "t mu-hat: [0.20058048294227132, 0.30348330835732945, 0.49426754963427605, 0.6011833096795842, 0.649989077035536, 0.3333236415202224]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 43.849999999999845\n",
            "4 4\n",
            "623.351244895445 0 {(3, 0.6011833096795842), (2, 0.49426754963427605), (1, 0.30348330835732945), (4, 0.6500046792879225)}\n",
            "\n",
            "t 1000\n",
            "t reward-arm: [3.2666607005728796, 7.890566017290566, 38.18270467449506, 148.6242856303556, 397.58918309366453, 9.076149670679087]\n",
            "t numplay: [16.0, 25.0, 76.0, 246.0, 611.0, 26.0] 1000.0\n",
            "t mu-hat: [0.19215651179840468, 0.30348330835732945, 0.49587928148694876, 0.6017177555884842, 0.6496555279308244, 0.3361536915066328]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 46.149999999999764\n",
            "4 4\n",
            "698.8303028061521 0 {(3, 0.6017177555884842), (2, 0.49587928148694876), (1, 0.30348330835732945), (4, 0.6499068974024791)}\n",
            "\n",
            "t 1100\n",
            "t reward-arm: [3.4827805201695528, 7.890566017290565, 39.856093703170735, 161.0414614995022, 447.54949565710956, 9.492362826418326]\n",
            "t numplay: [17.0, 25.0, 79.0, 266.0, 686.0, 27.0] 1100.0\n",
            "t mu-hat: [0.19348780667608625, 0.30348330835732945, 0.4982011712896342, 0.6031515411966374, 0.6514548699521245, 0.3390129580863688]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 48.3499999999997\n",
            "4 4\n",
            "774.9951136624153 0 {(3, 0.6031515411966374), (2, 0.4982011712896342), (1, 0.30348330835732945), (4, 0.6516028792080423)}\n",
            "\n",
            "t 1200\n",
            "t reward-arm: [3.4827805201695523, 7.890566017290565, 42.49365064697652, 169.10329542904478, 498.72618797555197, 9.829117834764777]\n",
            "t numplay: [17.0, 25.0, 84.0, 280.0, 766.0, 28.0] 1200.0\n",
            "t mu-hat: [0.19348780667608623, 0.30348330835732945, 0.4999253017291355, 0.6017910869361024, 0.6502297105287509, 0.33893509775050956]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 50.14999999999965\n",
            "4 4\n",
            "851.8813592639406 0 {(3, 0.6016445331175401), (2, 0.4999253017291355), (1, 0.30348330835732945), (4, 0.6502297105287509)}\n",
            "\n",
            "t 1300\n",
            "t reward-arm: [3.753463325197341, 8.458962928605951, 44.29733544154818, 179.34687291312878, 544.7804340883129, 10.204545568729277]\n",
            "t numplay: [19.0, 27.0, 88.0, 298.0, 839.0, 29.0] 1300.0\n",
            "t mu-hat: [0.18767316625986705, 0.30210581887878396, 0.4977228701297548, 0.5998223174352133, 0.6485481358194201, 0.34015151895764256]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 53.4999999999996\n",
            "4 4\n",
            "926.445257896378 0 {(3, 0.5998223174352133), (2, 0.4977228701297548), (1, 0.30210581887878396), (4, 0.6485799412934866)}\n",
            "\n",
            "t 1400\n",
            "t reward-arm: [3.753463325197341, 8.458962928605951, 44.76858158776252, 192.79157937933005, 593.1130601612588, 11.060598415804531]\n",
            "t numplay: [19.0, 27.0, 89.0, 320.0, 914.0, 31.0] 1400.0\n",
            "t mu-hat: [0.18767316625986705, 0.30210581887878396, 0.4974286843084724, 0.6005968204963553, 0.6482109947117582, 0.3456437004938916]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 55.34999999999953\n",
            "4 4\n",
            "1003.0464376907527 0 {(3, 0.6005968204963553), (2, 0.4974286843084724), (1, 0.30210581887878396), (4, 0.6482354461919709)}\n",
            "\n",
            "t 1500\n",
            "t reward-arm: [3.753463325197341, 8.458962928605951, 45.253026933436246, 195.45283516336826, 655.3118425815392, 11.06059841580453]\n",
            "t numplay: [19.0, 27.0, 90.0, 325.0, 1008.0, 31.0] 1500.0\n",
            "t mu-hat: [0.18767316625986705, 0.30210581887878396, 0.49728601025754116, 0.5995485741207616, 0.6494666427963718, 0.34564370049389154]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 55.74999999999952\n",
            "4 4\n",
            "1082.7237710258364 0 {(3, 0.5995485741207616), (2, 0.49728601025754116), (1, 0.30210581887878396), (4, 0.6494147568734799)}\n",
            "\n",
            "t 1600\n",
            "t reward-arm: [3.753463325197341, 8.45896292860595, 49.116810396302284, 201.9767285142026, 709.3457933060467, 11.060598415804531]\n",
            "t numplay: [19.0, 27.0, 97.0, 336.0, 1090.0, 31.0] 1600.0\n",
            "t mu-hat: [0.18767316625986705, 0.3021058188787839, 0.501191942819411, 0.5993374733359127, 0.6501794622420227, 0.3456437004938916]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 57.349999999999476\n",
            "4 4\n",
            "1160.1390364547779 0 {(3, 0.5993374733359127), (2, 0.501191942819411), (1, 0.3021058188787839), (4, 0.6499917926743233)}\n",
            "\n",
            "t 1700\n",
            "t reward-arm: [3.998239939033969, 8.908805510874657, 49.52946623945693, 211.44011457197684, 758.5425428890843, 11.420209486932915]\n",
            "t numplay: [21.0, 29.0, 98.0, 352.0, 1168.0, 32.0] 1700.0\n",
            "t mu-hat: [0.1817381790469986, 0.2969601836958219, 0.5002976387823932, 0.598980494538178, 0.6488815593576427, 0.3460669541494823]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 60.199999999999434\n",
            "4 4\n",
            "1235.9809547808918 0 {(3, 0.598980494538178), (2, 0.5002976387823932), (1, 0.2969601836958219), (4, 0.6489858308647541)}\n",
            "\n",
            "t 1800\n",
            "t reward-arm: [4.4871524627203545, 9.2104825998358, 50.51658577601862, 224.00768260794237, 804.858999711655, 11.874123293681052]\n",
            "t numplay: [23.0, 30.0, 100.0, 373.0, 1241.0, 33.0] 1800.0\n",
            "t mu-hat: [0.18696468594668145, 0.2971123419301871, 0.5001642156041448, 0.5989510230158887, 0.648034621345938, 0.34923892040238386]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 63.099999999999376\n",
            "4 4\n",
            "1311.4551230091372 0 {(3, 0.5989510230158887), (2, 0.5001642156041448), (1, 0.2971123419301871), (4, 0.6479903656133223)}\n",
            "\n",
            "t 1900\n",
            "t reward-arm: [4.487152462720355, 9.2104825998358, 53.002559700029586, 234.19817686832602, 853.5243034931473, 12.725887178227055]\n",
            "t numplay: [23.0, 30.0, 105.0, 390.0, 1317.0, 35.0] 1900.0\n",
            "t mu-hat: [0.18696468594668147, 0.2971123419301871, 0.5000241481134866, 0.5989723193563325, 0.6475905185835715, 0.35349686606186265]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 65.29999999999933\n",
            "4 4\n",
            "1387.5852820599625 0 {(3, 0.5989723193563325), (2, 0.5000241481134866), (1, 0.2971123419301871), (4, 0.6475929930455216)}\n",
            "\n",
            "t 2000\n",
            "t reward-arm: [4.701355781972812, 9.415456606448858, 53.95183104187538, 238.90643485711792, 909.8591214026067, 12.725887178227055]\n",
            "t numplay: [25.0, 31.0, 107.0, 398.0, 1404.0, 35.0] 2000.0\n",
            "t mu-hat: [0.18082137622972355, 0.2942330189515268, 0.49955399112847576, 0.5987629946293682, 0.6475865632758766, 0.35349686606186265]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 67.69999999999932\n",
            "4 0\n",
            "1464.9379424802703 0 {(3, 0.5988301215689102), (2, 0.49955399112847576), (1, 0.2942330189515268), (4, 0.6475865632758766)}\n",
            "\n",
            "Arm 4 Changepoint Detected at time 2040\n",
            "t 2100\n",
            "t reward-arm: [4.701355781972812, 9.415456606448858, 72.96821381252633, 245.03046159148644, 4.733253508217323, 12.741540402763242]\n",
            "t numplay: [25.0, 31.0, 141.0, 418.0, 20.0, 36.0] 671.0\n",
            "t mu-hat: [0.18082137622972355, 0.2942330189515268, 0.5138606606515939, 0.5847982376885118, 0.2253930242008249, 0.34436595683143895]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 101.29999999999976\n",
            "3 0\n",
            "27.219700729531684 0 {(3, 0.5847982376885118), (2, 0.5135590371741062), (1, 0.2942330189515268)}\n",
            "\n",
            "t 2200\n",
            "t reward-arm: [6.112476239885725, 9.415456606448856, 115.47494552916064, 250.4043523372005, 4.929593479435235, 13.373631519437858]\n",
            "t numplay: [27.0, 31.0, 216.0, 437.0, 21.0, 39.0] 771.0\n",
            "t mu-hat: [0.2183027228530616, 0.29423301895152676, 0.5321426061251642, 0.5716994345598185, 0.22407243088341977, 0.33434078798594646]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 122.25000000000028\n",
            "3 0\n",
            "83.557214751412 0 {(3, 0.5716994345598185), (2, 0.5319267541178042), (1, 0.29423301895152676)}\n",
            "\n",
            "Arm 3 Changepoint Detected at time 2240\n",
            "t 2300\n",
            "t reward-arm: [6.112476239885725, 9.415456606448856, 153.12091526348965, 8.859416339144943, 5.115595293372992, 13.373631519437858]\n",
            "t numplay: [27.0, 31.0, 282.0, 30.0, 22.0, 39.0] 431.0\n",
            "t mu-hat: [0.2183027228530616, 0.29423301895152676, 0.5410633048179846, 0.28578762384338524, 0.22241718666839094, 0.33434078798594646]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 145.80000000000084\n",
            "2 0\n",
            "23.338156272626055 0 {(3, 0.28578762384338524), (2, 0.5417706321634227), (1, 0.29423301895152676)}\n",
            "\n",
            "t 2400\n",
            "t reward-arm: [7.31902254205237, 65.1739119989822, 158.4121230798305, 9.102727190927874, 5.372653139111886, 13.524027413840162]\n",
            "t numplay: [29.0, 116.0, 292.0, 31.0, 23.0, 40.0] 531.0\n",
            "t mu-hat: [0.24396741806841232, 0.5570419828972838, 0.54065571017007, 0.28446022471649607, 0.22386054746299525, 0.3298543271668332]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 152.85000000000187\n",
            "1 0\n",
            "67.04124696190372 0 {(3, 0.28446022471649607), (2, 0.54065571017007), (1, 0.5567910641872801)}\n",
            "\n",
            "t 2500\n",
            "t reward-arm: [7.31902254205237, 132.34061980075063, 158.4121230798305, 9.102727190927876, 5.372653139111886, 13.52402741384016]\n",
            "t numplay: [29.0, 216.0, 292.0, 31.0, 23.0, 40.0] 631.0\n",
            "t mu-hat: [0.24396741806841232, 0.609864607376731, 0.54065571017007, 0.2844602247164961, 0.22386054746299525, 0.32985432716683316]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 157.850000000003\n",
            "1 0\n",
            "137.24438188108076 0 {(3, 0.2844602247164961), (2, 0.54065571017007), (1, 0.6092656485415014)}\n",
            "\n",
            "Arm 1 Changepoint Detected at time 2600\n",
            "t 2600\n",
            "t reward-arm: [8.01974333316085, 0.0, 159.55463232711227, 9.290611797250422, 5.763686051432039, 13.524027413840162]\n",
            "t numplay: [30.0, 0.0, 294.0, 32.0, 24.0, 40.0] 420.0\n",
            "t mu-hat: [0.2587013978438984, 0.0, 0.5408631604308891, 0.2815336908257704, 0.23054744205728156, 0.3298543271668332]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 163.7500000000041\n",
            "1 0\n",
            "0.0 0 set()\n",
            "\n",
            "t 2700\n",
            "t reward-arm: [8.01974333316085, 64.0567285825437, 160.5765604836009, 9.650425510821993, 6.061659542209753, 13.524027413840162]\n",
            "t numplay: [30.0, 96.0, 296.0, 33.0, 25.0, 40.0] 520.0\n",
            "t mu-hat: [0.2587013978438984, 0.6603786451808629, 0.5406618198101041, 0.28383604443594096, 0.23314075162345205, 0.3298543271668332]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 169.7000000000052\n",
            "1 0\n",
            "78.86972516581777 0 {(3, 0.28383604443594096), (2, 0.5406618198101041), (1, 0.6608230251096784)}\n",
            "\n",
            "t 2800\n",
            "t reward-arm: [8.01974333316085, 127.00763261998955, 160.5765604836009, 9.650425510821991, 6.061659542209753, 13.524027413840162]\n",
            "t numplay: [30.0, 196.0, 296.0, 33.0, 25.0, 40.0] 620.0\n",
            "t mu-hat: [0.2587013978438984, 0.6447087950253276, 0.5406618198101041, 0.2838360444359409, 0.23314075162345205, 0.3298543271668332]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 174.70000000000633\n",
            "1 0\n",
            "161.25315427733736 0 {(3, 0.2838360444359409), (2, 0.5406618198101041), (1, 0.6455930698369702)}\n",
            "\n",
            "t 2900\n",
            "t reward-arm: [9.305569782010208, 188.55269080357075, 161.19270055690657, 10.369842277462364, 6.061659542209753, 13.524027413840162]\n",
            "t numplay: [32.0, 291.0, 297.0, 35.0, 25.0, 40.0] 720.0\n",
            "t mu-hat: [0.2819869630912184, 0.6457283931629135, 0.5409151025399549, 0.28805117437395455, 0.23314075162345205, 0.3298543271668332]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 180.40000000000742\n",
            "1 0\n",
            "240.47883572837998 0 {(3, 0.28805117437395455), (2, 0.5409151025399549), (1, 0.6453613490088275), (0, 0.2819869630912184)}\n",
            "\n",
            "t 3000\n",
            "t reward-arm: [9.305569782010208, 254.3190694878527, 161.19270055690657, 10.369842277462364, 6.061659542209753, 13.524027413840162]\n",
            "t numplay: [32.0, 391.0, 297.0, 35.0, 25.0, 40.0] 820.0\n",
            "t mu-hat: [0.2819869630912184, 0.6487731364486038, 0.5409151025399549, 0.28805117437395455, 0.23314075162345205, 0.3298543271668332]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 185.40000000000856\n",
            "1 0\n",
            "322.57937624611253 0 {(3, 0.28805117437395455), (2, 0.5409151025399549), (1, 0.648400634338768), (0, 0.2819869630912184)}\n",
            "\n",
            "t 3100\n",
            "t reward-arm: [10.75449614521859, 316.46870911061984, 161.19270055690657, 10.369842277462366, 6.548488051319867, 13.524027413840164]\n",
            "t numplay: [34.0, 487.0, 297.0, 35.0, 27.0, 40.0] 920.0\n",
            "t mu-hat: [0.30727131843481686, 0.6485014530955324, 0.5409151025399549, 0.2880511743739546, 0.23387457326142383, 0.32985432716683327]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 191.10000000000963\n",
            "1 0\n",
            "402.3774531798547 0 {(3, 0.2880511743739546), (2, 0.5409151025399549), (1, 0.6482016349894557), (0, 0.30727131843481686)}\n",
            "\n",
            "t 3200\n",
            "t reward-arm: [10.75449614521859, 379.97355528561843, 161.1927005569066, 10.369842277462368, 6.548488051319867, 13.524027413840162]\n",
            "t numplay: [34.0, 587.0, 297.0, 35.0, 27.0, 40.0] 1020.0\n",
            "t mu-hat: [0.30727131843481686, 0.6462135293973102, 0.540915102539955, 0.28805117437395467, 0.23387457326142383, 0.3298543271668332]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 196.10000000001077\n",
            "1 0\n",
            "484.15282452263006 0 {(3, 0.28805117437395467), (2, 0.540915102539955), (1, 0.6460182901269663), (0, 0.30727131843481686)}\n",
            "\n",
            "t 3300\n",
            "t reward-arm: [12.130457118458466, 442.16970570491355, 161.75888097177904, 10.833508061767938, 6.769904147077175, 13.524027413840162]\n",
            "t numplay: [36.0, 682.0, 298.0, 36.0, 28.0, 40.0] 1120.0\n",
            "t mu-hat: [0.32785019239076935, 0.6473934197729334, 0.5409996019123045, 0.29279751518291725, 0.2334449705888681, 0.3298543271668332]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 201.85000000001185\n",
            "1 0\n",
            "563.3758398609316 0 {(3, 0.29279751518291725), (2, 0.5409996019123045), (1, 0.6472668896987694), (0, 0.32785019239076935)}\n",
            "\n",
            "t 3400\n",
            "t reward-arm: [12.130457118458466, 507.34788329302245, 161.75888097177904, 10.833508061767937, 6.769904147077175, 13.524027413840162]\n",
            "t numplay: [36.0, 782.0, 298.0, 36.0, 28.0, 40.0] 1220.0\n",
            "t mu-hat: [0.32785019239076935, 0.6479538739374489, 0.5409996019123045, 0.2927975151829172, 0.2334449705888681, 0.3298543271668332]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 206.85000000001298\n",
            "1 0\n",
            "645.2282506450924 0 {(3, 0.2927975151829172), (2, 0.5409996019123045), (1, 0.6480186320486949), (0, 0.32785019239076935)}\n",
            "\n",
            "t 3500\n",
            "t reward-arm: [12.130457118458468, 568.4456688546677, 163.2004853427813, 11.409994591680276, 6.984785039552408, 13.524027413840162]\n",
            "t numplay: [36.0, 876.0, 301.0, 38.0, 29.0, 40.0] 1320.0\n",
            "t mu-hat: [0.3278501923907694, 0.6481706600395298, 0.5403989580886798, 0.29256396388923783, 0.23282616798508027, 0.3298543271668332]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 213.25000000001407\n",
            "1 0\n",
            "724.8736682616885 0 {(3, 0.29256396388923783), (2, 0.5403989580886798), (1, 0.6481755617692753), (0, 0.3278501923907694)}\n",
            "\n",
            "t 3600\n",
            "t reward-arm: [13.640774705435584, 630.7698062054294, 163.69294725100414, 11.627995353528364, 7.375820882269729, 13.524027413840164]\n",
            "t numplay: [38.0, 971.0, 302.0, 39.0, 30.0, 40.0] 1420.0\n",
            "t mu-hat: [0.3497634539855278, 0.6489401298409767, 0.540240750003314, 0.2906998838382091, 0.2379297058796687, 0.32985432716683327]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 219.00000000001515\n",
            "1 0\n",
            "804.42929449855 0 {(3, 0.2906998838382091), (2, 0.5402407500033141), (1, 0.6489334852060391), (0, 0.34976345398552783)}\n",
            "\n",
            "t 3700\n",
            "t reward-arm: [13.640774705435586, 694.8728028246225, 163.69294725100417, 11.627995353528364, 7.375820882269728, 13.524027413840162]\n",
            "t numplay: [38.0, 1071.0, 302.0, 39.0, 30.0, 40.0] 1520.0\n",
            "t mu-hat: [0.34976345398552783, 0.6482022414408791, 0.5402407500033141, 0.2906998838382091, 0.23792970587966866, 0.3298543271668332]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 224.00000000001629\n",
            "1 0\n",
            "886.4193645489255 0 {(3, 0.2906998838382091), (2, 0.5402407500033141), (1, 0.648299409339723), (0, 0.34976345398552783)}\n",
            "\n",
            "t 3800\n",
            "t reward-arm: [14.552612342483894, 756.1593700968019, 165.04667824553547, 11.627995353528366, 7.624783432531181, 13.524027413840164]\n",
            "t numplay: [39.0, 1166.0, 305.0, 39.0, 31.0, 40.0] 1620.0\n",
            "t mu-hat: [0.3638153085620973, 0.6479514739475595, 0.5393682295605734, 0.29069988383820916, 0.23827448226659942, 0.32985432716683327]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 229.65000000001737\n",
            "1 0\n",
            "966.6449818372072 0 {(3, 0.29069988383820916), (2, 0.5393682295605734), (1, 0.64787811798644), (0, 0.3638153085620973)}\n",
            "\n",
            "t 3900\n",
            "t reward-arm: [14.552612342483892, 821.4756047399466, 165.04667824553547, 11.627995353528366, 7.624783432531181, 13.524027413840164]\n",
            "t numplay: [39.0, 1266.0, 305.0, 39.0, 31.0, 40.0] 1720.0\n",
            "t mu-hat: [0.3638153085620973, 0.6483627503866981, 0.5393682295605734, 0.29069988383820916, 0.23827448226659942, 0.32985432716683327]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 234.6500000000185\n",
            "1 0\n",
            "1048.527606564599 0 {(3, 0.29069988383820916), (2, 0.5393682295605734), (1, 0.6482668043609257), (0, 0.3638153085620973)}\n",
            "\n",
            "t 4000\n",
            "t reward-arm: [15.181533772035468, 882.0464428181776, 165.5640071911766, 11.627995353528366, 8.415236630061461, 13.524027413840164]\n",
            "t numplay: [40.0, 1361.0, 306.0, 39.0, 34.0, 40.0] 1820.0\n",
            "t mu-hat: [0.3702813115130602, 0.6476111914964594, 0.5392964403621388, 0.29069988383820916, 0.2404353322874703, 0.32985432716683327]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 240.90000000001956\n",
            "1 3\n",
            "1127.8905401244465 0 {(3, 0.29069988383820916), (2, 0.5392964403621388), (1, 0.6476400338924727), (0, 0.3702813115130602)}\n",
            "\n",
            "t 4100\n",
            "t reward-arm: [15.181533772035468, 956.9674945876505, 165.56400719117656, 11.627995353528368, 8.415236630061463, 13.524027413840162]\n",
            "t numplay: [40.0, 1461.0, 306.0, 39.0, 34.0, 40.0] 1920.0\n",
            "t mu-hat: [0.3702813115130602, 0.6545605298137145, 0.5392964403621386, 0.2906998838382092, 0.24043533228747035, 0.3298543271668332]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 245.9000000000207\n",
            "1 3\n",
            "1210.3202934202227 0 {(3, 0.2906998838382092), (2, 0.5392964403621386), (1, 0.6542974959080199), (0, 0.3702813115130602)}\n",
            "\n",
            "t 4200\n",
            "t reward-arm: [15.65875042169074, 1027.250797930204, 165.5640071911766, 13.326866253982622, 8.927765678039663, 13.524027413840162]\n",
            "t numplay: [42.0, 1555.0, 306.0, 41.0, 36.0, 40.0] 2020.0\n",
            "t mu-hat: [0.36415698655094747, 0.6601868881299512, 0.5392964403621388, 0.31730633938053865, 0.24129096427134222, 0.3298543271668332]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 252.80000000002175\n",
            "1 3\n",
            "1290.5492583609775 0 {(3, 0.31730633938053865), (2, 0.5392964403621388), (1, 0.6600867765667788), (0, 0.36415698655094747)}\n",
            "\n",
            "t 4300\n",
            "t reward-arm: [15.65875042169074, 1100.3601881202328, 167.23977664324877, 13.326866253982622, 8.927765678039663, 13.52402741384016]\n",
            "t numplay: [42.0, 1652.0, 309.0, 41.0, 36.0, 40.0] 2120.0\n",
            "t mu-hat: [0.36415698655094747, 0.6656746449608184, 0.5394831504620928, 0.31730633938053865, 0.24129096427134222, 0.32985432716683316]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 258.49000000002275\n",
            "1 3\n",
            "1374.8220747245766 0 {(3, 0.31730633938053865), (2, 0.5397633265190241), (1, 0.6656746449608184), (0, 0.36415698655094747)}\n",
            "\n",
            "t 4400\n",
            "t reward-arm: [15.91439730121861, 1174.8429737593247, 167.23977664324877, 14.208446734694409, 8.927765678039663, 13.524027413840162]\n",
            "t numplay: [43.0, 1750.0, 309.0, 42.0, 36.0, 40.0] 2220.0\n",
            "t mu-hat: [0.3616908477549684, 0.6709554390401625, 0.5394831504620928, 0.33042899383010255, 0.24129096427134222, 0.3298543271668332]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 263.9900000000239\n",
            "1 3\n",
            "1459.540929667105 0 {(3, 0.33042899383010255), (2, 0.5394831504620928), (1, 0.6709384332300246), (0, 0.3616908477549684)}\n",
            "\n",
            "t 4500\n",
            "t reward-arm: [16.15425003583912, 1245.5201060621343, 167.23977664324877, 14.954364896130581, 9.035745312111825, 13.524027413840162]\n",
            "t numplay: [45.0, 1846.0, 309.0, 43.0, 37.0, 40.0] 2320.0\n",
            "t mu-hat: [0.3511793486051982, 0.674347648111605, 0.5394831504620928, 0.3398719294575132, 0.2377827713713638, 0.3298543271668332]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 270.490000000025\n",
            "1 3\n",
            "1543.9697943149183 0 {(3, 0.3398719294575132), (2, 0.5394831504620928), (1, 0.6744812628493209), (0, 0.3511793486051982)}\n",
            "\n",
            "t 4600\n",
            "t reward-arm: [16.15425003583912, 1318.874156340003, 167.23977664324877, 14.954364896130581, 9.035745312111823, 13.524027413840162]\n",
            "t numplay: [45.0, 1946.0, 309.0, 43.0, 37.0, 40.0] 2420.0\n",
            "t mu-hat: [0.3511793486051982, 0.677387856363638, 0.5394831504620928, 0.3398719294575132, 0.23778277137136375, 0.3298543271668332]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 275.49000000002616\n",
            "1 3\n",
            "1631.4231391935095 0 {(3, 0.3398719294575132), (2, 0.5394831504620928), (1, 0.6773345285466219), (0, 0.3511793486051982)}\n",
            "\n",
            "t 4700\n",
            "t reward-arm: [16.38627213271079, 1389.1584261105304, 167.64068937793033, 16.538042015452813, 9.29631416059809, 13.524027413840162]\n",
            "t numplay: [46.0, 2041.0, 310.0, 45.0, 38.0, 40.0] 2520.0\n",
            "t mu-hat: [0.34864408793001683, 0.6802930588200443, 0.5390375864242133, 0.3595226525098438, 0.23836702975892538, 0.3298543271668332]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 281.62000000002723\n",
            "1 3\n",
            "1716.8219211630962 0 {(3, 0.3595226525098438), (2, 0.5390375864242133), (1, 0.6802233937359444), (0, 0.34864408793001683)}\n",
            "\n",
            "t 4800\n",
            "t reward-arm: [16.38627213271079, 1463.7076150766623, 167.6406893779303, 16.53804201545281, 9.29631416059809, 13.524027413840162]\n",
            "t numplay: [46.0, 2141.0, 310.0, 45.0, 38.0, 40.0] 2620.0\n",
            "t mu-hat: [0.34864408793001683, 0.6833368884578255, 0.5390375864242132, 0.35952265250984367, 0.23836702975892538, 0.3298543271668332]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 286.62000000002837\n",
            "1 3\n",
            "1805.4177455232998 0 {(3, 0.35952265250984367), (2, 0.5390375864242133), (1, 0.6831819901819174), (0, 0.34864408793001683)}\n",
            "\n",
            "Arm 1 Changepoint Detected at time 4810\n",
            "t 4900\n",
            "t reward-arm: [16.914762359381882, 66.35191655119053, 167.6406893779303, 18.14173689654654, 9.29631416059809, 13.524027413840162]\n",
            "t numplay: [48.0, 86.0, 310.0, 47.0, 38.0, 40.0] 569.0\n",
            "t mu-hat: [0.34519923182412005, 0.7626657074849486, 0.5390375864242132, 0.37795285201138623, 0.23836702975892538, 0.3298543271668332]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 292.6200000000295\n",
            "1 3\n",
            "89.07258265922994 0 {(3, 0.37795285201138623), (2, 0.5390375864242132), (1, 0.7634509400674588), (0, 0.34519923182412005)}\n",
            "\n",
            "t 5000\n",
            "t reward-arm: [16.914762359381882, 139.27633997719892, 167.64068937793033, 18.14173689654654, 9.29631416059809, 13.52402741384016]\n",
            "t numplay: [48.0, 186.0, 310.0, 47.0, 38.0, 40.0] 669.0\n",
            "t mu-hat: [0.34519923182412005, 0.7447932619101546, 0.5390375864242133, 0.37795285201138623, 0.23836702975892538, 0.32985432716683316]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 297.62000000003064\n",
            "1 3\n",
            "191.845635732422 0 {(3, 0.37795285201138623), (2, 0.5390375864242133), (1, 0.7456264631705279), (0, 0.34519923182412005)}\n",
            "\n",
            "t 5100\n",
            "t reward-arm: [17.522077960157638, 210.34038755960478, 168.6680038950152, 18.14173689654654, 9.646065294872898, 13.52402741384016]\n",
            "t numplay: [50.0, 280.0, 312.0, 47.0, 40.0, 40.0] 769.0\n",
            "t mu-hat: [0.3435701560815223, 0.7485423044825793, 0.5388754118051604, 0.37795285201138623, 0.2352698852408024, 0.32985432716683316]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 305.0800000000317\n",
            "1 3\n",
            "290.9527342694888 0 {(3, 0.37795285201138623), (2, 0.5388754118051604), (1, 0.7489952571190728), (0, 0.3435701560815223)}\n",
            "\n",
            "t 5200\n",
            "t reward-arm: [18.257253252248887, 283.35952032882085, 168.6680038950152, 18.14173689654654, 9.646065294872898, 13.524027413840162]\n",
            "t numplay: [53.0, 377.0, 312.0, 47.0, 40.0, 40.0] 869.0\n",
            "t mu-hat: [0.33809728244905346, 0.7496283606582562, 0.5388754118051604, 0.37795285201138623, 0.2352698852408024, 0.3298543271668332]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 311.7300000000329\n",
            "1 3\n",
            "391.233395000475 0 {(3, 0.37795285201138623), (2, 0.5388754118051604), (1, 0.7499170426346997), (0, 0.33809728244905346)}\n",
            "\n",
            "t 5300\n",
            "t reward-arm: [18.257253252248887, 357.07303375637855, 168.66800389501523, 18.14173689654654, 9.646065294872896, 13.524027413840162]\n",
            "t numplay: [53.0, 477.0, 312.0, 47.0, 40.0, 40.0] 969.0\n",
            "t mu-hat: [0.33809728244905346, 0.7470147149715033, 0.5388754118051605, 0.37795285201138623, 0.23526988524080233, 0.3298543271668332]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 316.730000000034\n",
            "1 3\n",
            "493.1240496838102 0 {(3, 0.37795285201138623), (2, 0.5388754118051605), (1, 0.747324294149648), (0, 0.33809728244905346)}\n",
            "\n",
            "t 5400\n",
            "t reward-arm: [18.640438134751776, 428.3604297157141, 169.65893233569486, 18.955893628790534, 9.646065294872896, 13.524027413840162]\n",
            "t numplay: [55.0, 572.0, 314.0, 48.0, 40.0, 40.0] 1069.0\n",
            "t mu-hat: [0.332864966691996, 0.7475749209698326, 0.538599785192682, 0.38685497201613334, 0.23526988524080233, 0.3298543271668332]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 323.2400000000351\n",
            "1 3\n",
            "592.5718831250528 0 {(3, 0.38685497201613334), (2, 0.538599785192682), (1, 0.7475412447753356), (0, 0.332864966691996)}\n",
            "\n",
            "t 5500\n",
            "t reward-arm: [18.640438134751776, 502.87703815412476, 169.65893233569486, 18.955893628790534, 9.646065294872898, 13.524027413840162]\n",
            "t numplay: [55.0, 672.0, 314.0, 48.0, 40.0, 40.0] 1169.0\n",
            "t mu-hat: [0.332864966691996, 0.7472169957713592, 0.538599785192682, 0.38685497201613334, 0.2352698852408024, 0.3298543271668332]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 328.2400000000362\n",
            "1 3\n",
            "694.4165353083957 0 {(3, 0.38685497201613334), (2, 0.538599785192682), (1, 0.7474103369104443), (0, 0.332864966691996)}\n",
            "\n",
            "t 5600\n",
            "t reward-arm: [19.401678126835076, 572.6463485213287, 169.65893233569486, 19.76728227640544, 10.0103905310552, 13.524027413840162]\n",
            "t numplay: [59.0, 766.0, 314.0, 49.0, 41.0, 40.0] 1269.0\n",
            "t mu-hat: [0.32336130211391795, 0.7466054087631404, 0.538599785192682, 0.3953456455281088, 0.23834263169179049, 0.3298543271668332]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 335.8400000000374\n",
            "1 3\n",
            "792.2320112258342 0 {(3, 0.3953456455281088), (2, 0.538599785192682), (1, 0.7467228061279084), (0, 0.32336130211391795)}\n",
            "\n",
            "t 5700\n",
            "t reward-arm: [19.401678126835076, 647.7523424808686, 169.65893233569486, 19.76728227640544, 10.0103905310552, 13.524027413840162]\n",
            "t numplay: [59.0, 866.0, 314.0, 49.0, 41.0, 40.0] 1369.0\n",
            "t mu-hat: [0.32336130211391795, 0.7471191954796639, 0.538599785192682, 0.3953456455281088, 0.23834263169179049, 0.3298543271668332]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 340.8400000000385\n",
            "1 3\n",
            "893.8033100727146 0 {(3, 0.3953456455281088), (2, 0.538599785192682), (1, 0.7470815928640834), (0, 0.32336130211391795)}\n",
            "\n",
            "t 5800\n",
            "t reward-arm: [19.401678126835076, 719.6449742156199, 170.0213026882051, 20.604636036365516, 11.08931709267355, 13.524027413840162]\n",
            "t numplay: [59.0, 961.0, 315.0, 50.0, 44.0, 40.0] 1469.0\n",
            "t mu-hat: [0.32336130211391795, 0.7480716987688356, 0.5380420971145732, 0.40401247130128465, 0.2464292687260789, 0.3298543271668332]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 347.37000000003957\n",
            "1 3\n",
            "992.6789761305008 0 {(3, 0.40401247130128465), (2, 0.5380420971145732), (1, 0.7480213825956135), (0, 0.32336130211391795)}\n",
            "\n",
            "t 5900\n",
            "t reward-arm: [19.401678126835076, 794.4944104816441, 170.0213026882051, 20.60463603636552, 11.089317092673548, 13.524027413840162]\n",
            "t numplay: [59.0, 1061.0, 315.0, 50.0, 44.0, 40.0] 1569.0\n",
            "t mu-hat: [0.32336130211391795, 0.7481114976286667, 0.5380420971145732, 0.4040124713012847, 0.24642926872607884, 0.3298543271668332]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 352.3700000000407\n",
            "1 3\n",
            "1094.4554664026048 0 {(3, 0.4040124713012847), (2, 0.5380420971145732), (1, 0.7481988086646876), (0, 0.32336130211391795)}\n",
            "\n",
            "t 6000\n",
            "t reward-arm: [19.621000667589584, 866.2209434808082, 170.63165096111783, 21.418169826291994, 11.847733294317887, 13.524027413840162]\n",
            "t numplay: [60.0, 1156.0, 316.0, 51.0, 46.0, 40.0] 1669.0\n",
            "t mu-hat: [0.3216557486490096, 0.7486784299747694, 0.5382701923063654, 0.41188788127484605, 0.2520794317939976, 0.3298543271668332]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 359.45000000004177\n",
            "1 4\n",
            "1193.5113786699237 0 {(3, 0.41188788127484605), (2, 0.5382701923063654), (1, 0.7487871405659033), (0, 0.3216557486490096)}\n",
            "\n",
            "Arm 1 Changepoint Detected at time 6010\n",
            "t 6100\n",
            "t reward-arm: [19.621000667589584, 4.511045610679255, 196.74228943130936, 26.52826051694668, 11.847733294317887, 13.924523305358832]\n",
            "t numplay: [60.0, 22.0, 364.0, 69.0, 46.0, 42.0] 603.0\n",
            "t mu-hat: [0.3216557486490096, 0.19613241785561977, 0.5390199710446831, 0.37897515024209544, 0.2520794317939976, 0.323826123380438]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 390.60000000004027\n",
            "2 4\n",
            "39.1356273327266 0 {(3, 0.37897515024209544), (2, 0.5390492177159253), (0, 0.3216557486490096)}\n",
            "\n",
            "t 6200\n",
            "t reward-arm: [19.621000667589584, 4.511045610679255, 251.43761114599212, 26.52826051694668, 11.847733294317887, 14.132084489864555]\n",
            "t numplay: [60.0, 22.0, 463.0, 69.0, 46.0, 43.0] 703.0\n",
            "t mu-hat: [0.3216557486490096, 0.19613241785561977, 0.5418914033318796, 0.37897515024209544, 0.2520794317939976, 0.3211837384060126]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 406.000000000038\n",
            "2 4\n",
            "99.46693346701339 0 {(3, 0.37897515024209544), (2, 0.5420877768813033), (0, 0.3216557486490096)}\n",
            "\n",
            "t 6300\n",
            "t reward-arm: [19.621000667589584, 5.469339214060051, 302.0149626574377, 26.915883182999462, 13.450038678200794, 14.223787972107242]\n",
            "t numplay: [60.0, 26.0, 555.0, 70.0, 48.0, 44.0] 803.0\n",
            "t mu-hat: [0.3216557486490096, 0.20256811903926117, 0.5431923788802836, 0.379096946239429, 0.27449058526940395, 0.31608417715793874]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 422.7500000000359\n",
            "2 4\n",
            "157.57693313210504 0 {(3, 0.379096946239429), (2, 0.5431792391369562), (0, 0.3216557486490096)}\n",
            "\n",
            "t 6400\n",
            "t reward-arm: [19.621000667589584, 5.469339214060052, 356.3578183085574, 27.003299359132047, 13.450038678200794, 14.456270034728401]\n",
            "t numplay: [60.0, 26.0, 653.0, 71.0, 48.0, 45.0] 903.0\n",
            "t mu-hat: [0.3216557486490096, 0.2025681190392612, 0.5448896304412193, 0.37504582443238954, 0.27449058526940395, 0.31426673988540005]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 438.4000000000337\n",
            "2 4\n",
            "218.7028460425954 0 {(3, 0.37504582443238954), (2, 0.5449290416131574), (0, 0.3216557486490096)}\n",
            "\n",
            "t 6500\n",
            "t reward-arm: [20.374424065274333, 5.469339214060052, 405.19183534651575, 28.481980940973546, 14.060715356331517, 14.585667198745105]\n",
            "t numplay: [61.0, 26.0, 746.0, 75.0, 49.0, 46.0] 1003.0\n",
            "t mu-hat: [0.3286197429882957, 0.2025681190392612, 0.5424254823915874, 0.374762907118073, 0.28121430712663037, 0.3103333446541512]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 454.5500000000315\n",
            "2 4\n",
            "278.140442208553 0 {(3, 0.374762907118073), (2, 0.5423536117692782), (0, 0.3286197429882957), (4, 0.28121430712663037)}\n",
            "\n",
            "t 6600\n",
            "t reward-arm: [20.374424065274333, 5.469339214060051, 458.5466586749147, 29.212070162027842, 14.060715356331517, 14.709555072688897]\n",
            "t numplay: [61.0, 26.0, 843.0, 77.0, 49.0, 47.0] 1103.0\n",
            "t mu-hat: [0.3286197429882957, 0.20256811903926117, 0.5433017282878136, 0.374513720025998, 0.28121430712663037, 0.306449064014352]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 470.45000000002926\n",
            "2 4\n",
            "339.14590679754286 0 {(3, 0.374513720025998), (2, 0.5433231819472438), (0, 0.3286197429882957), (4, 0.28121430712663037)}\n",
            "\n",
            "t 6700\n",
            "t reward-arm: [22.504102755972394, 5.469339214060052, 511.21898609626453, 29.363850630324983, 14.829124750323846, 14.709555072688897]\n",
            "t numplay: [64.0, 26.0, 938.0, 78.0, 50.0, 47.0] 1203.0\n",
            "t mu-hat: [0.3462169654764984, 0.2025681190392612, 0.5444291651717407, 0.3716943117762656, 0.2907671519671342, 0.306449064014352]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 485.2500000000271\n",
            "2 4\n",
            "399.6780304565262 0 {(3, 0.3716943117762656), (2, 0.5445393573431634), (0, 0.3462169654764984), (4, 0.2907671519671342)}\n",
            "\n",
            "t 6800\n",
            "t reward-arm: [22.504102755972394, 5.469339214060052, 565.2947747939318, 29.363850630324983, 14.829124750323846, 14.819900989899143]\n",
            "t numplay: [64.0, 26.0, 1037.0, 78.0, 50.0, 48.0] 1303.0\n",
            "t mu-hat: [0.3462169654764984, 0.2025681190392612, 0.5445999757166973, 0.3716943117762656, 0.2907671519671342, 0.30244695897753354]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 500.6500000000249\n",
            "2 4\n",
            "461.8371518063672 0 {(3, 0.3716943117762656), (2, 0.5445767547530995), (0, 0.3462169654764984), (4, 0.2907671519671342)}\n",
            "\n",
            "t 6900\n",
            "t reward-arm: [82.82563142961224, 6.055832634226254, 566.7216526985403, 29.773588543729304, 16.352348633549575, 14.819900989899143]\n",
            "t numplay: [156.0, 28.0, 1040.0, 79.0, 52.0, 48.0] 1403.0\n",
            "t mu-hat: [0.5275517925453009, 0.20882181497331911, 0.5444012033607496, 0.3721698567966163, 0.30853487987829387, 0.30244695897753354]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 507.00000000002586\n",
            "2 4\n",
            "501.18144526801854 0 {(3, 0.3721698567966163), (2, 0.5444012033607496), (0, 0.5255389837235142), (4, 0.30853487987829387)}\n",
            "\n",
            "Arm 0 Changepoint Detected at time 6940\n",
            "t 7000\n",
            "t reward-arm: [34.83245992087109, 6.751924495535014, 566.7216526985403, 30.230544973181274, 17.725481940821002, 14.819900989899143]\n",
            "t numplay: [54.0, 31.0, 1040.0, 80.0, 54.0, 48.0] 1307.0\n",
            "t mu-hat: [0.633317453106747, 0.21099764048546918, 0.5444012033607496, 0.3732166046071762, 0.3222814898331091, 0.30244695897753354]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 513.6000000000262\n",
            "0 4\n",
            "40.19643333858286 0 {(3, 0.3732166046071762), (2, 0.5444012033607496), (0, 0.6292833332420414), (4, 0.3222814898331091)}\n",
            "\n",
            "t 7100\n",
            "t reward-arm: [99.26478039864976, 6.751924495535013, 566.7216526985403, 30.230544973181274, 17.725481940821002, 14.819900989899143]\n",
            "t numplay: [154.0, 31.0, 1040.0, 80.0, 54.0, 48.0] 1407.0\n",
            "t mu-hat: [0.6404179380558049, 0.21099764048546915, 0.5444012033607496, 0.3732166046071762, 0.3222814898331091, 0.30244695897753354]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 518.6000000000216\n",
            "0 4\n",
            "122.00371569710586 0 {(3, 0.3732166046071762), (2, 0.5444012033607496), (0, 0.640746425804723), (4, 0.3222814898331091)}\n",
            "\n",
            "t 7200\n",
            "t reward-arm: [160.6550106993748, 7.3990619331859975, 566.7216526985403, 30.230544973181274, 19.83102272598365, 14.819900989899145]\n",
            "t numplay: [248.0, 34.0, 1040.0, 80.0, 57.0, 48.0] 1507.0\n",
            "t mu-hat: [0.6452008461822281, 0.21140176951959994, 0.5444012033607496, 0.3732166046071762, 0.3419141849307526, 0.30244695897753354]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 524.8000000000173\n",
            "0 4\n",
            "201.9527087873971 0 {(3, 0.3732166046071762), (2, 0.5444012033607496), (0, 0.6451101872728565), (4, 0.3419141849307526)}\n",
            "\n",
            "t 7300\n",
            "t reward-arm: [228.39193264806775, 7.399061933185999, 566.7216526985403, 30.230544973181267, 19.83102272598365, 14.819900989899145]\n",
            "t numplay: [348.0, 34.0, 1040.0, 80.0, 57.0, 48.0] 1607.0\n",
            "t mu-hat: [0.6544181451234033, 0.2114017695196, 0.5444012033607496, 0.37321660460717615, 0.3419141849307526, 0.30244695897753354]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 529.8000000000128\n",
            "0 4\n",
            "285.8942928255479 0 {(3, 0.37321660460717615), (2, 0.5444012033607496), (0, 0.6540771863859417), (4, 0.3419141849307526)}\n",
            "\n",
            "t 7400\n",
            "t reward-arm: [288.29251796249287, 7.696808091056192, 567.8578859687248, 30.230544973181267, 21.841706455447458, 14.819900989899143]\n",
            "t numplay: [442.0, 35.0, 1042.0, 80.0, 60.0, 48.0] 1707.0\n",
            "t mu-hat: [0.6507731782449049, 0.21380022475156088, 0.544446678781136, 0.37321660460717615, 0.35806076156471245, 0.30244695897753354]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 535.3000000000085\n",
            "0 4\n",
            "368.08881055940986 0 {(3, 0.37321660460717615), (2, 0.544446678781136), (0, 0.6511292831594612), (4, 0.35806076156471245)}\n",
            "\n",
            "t 7500\n",
            "t reward-arm: [353.7064882001389, 7.696808091056192, 567.8578859687248, 30.230544973181274, 21.841706455447458, 14.819900989899143]\n",
            "t numplay: [542.0, 35.0, 1042.0, 80.0, 60.0, 48.0] 1807.0\n",
            "t mu-hat: [0.6513931642728157, 0.21380022475156088, 0.544446678781136, 0.3732166046071762, 0.35806076156471245, 0.30244695897753354]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 540.3000000000039\n",
            "0 4\n",
            "452.1503864677816 0 {(3, 0.3732166046071762), (2, 0.544446678781136), (0, 0.6515897367329767), (4, 0.35806076156471245)}\n",
            "\n",
            "t 7600\n",
            "t reward-arm: [414.87650352535434, 7.860251986168331, 568.5015965230734, 30.956914212511577, 23.20096990590516, 14.819900989899145]\n",
            "t numplay: [636.0, 36.0, 1043.0, 82.0, 62.0, 48.0] 1907.0\n",
            "t mu-hat: [0.6512974937603678, 0.21243924286941435, 0.5445417591217179, 0.37297487003026, 0.3682693635857962, 0.30244695897753354]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 546.4499999999996\n",
            "0 4\n",
            "533.7248734437031 0 {(3, 0.37297487003026), (2, 0.5445417591217179), (0, 0.6511919763314015), (4, 0.3682693635857962)}\n",
            "\n",
            "t 7700\n",
            "t reward-arm: [477.1059810985756, 8.004295379520258, 568.5015965230734, 31.163104244787625, 23.200969905905165, 14.819900989899145]\n",
            "t numplay: [734.0, 37.0, 1043.0, 83.0, 62.0, 48.0] 2007.0\n",
            "t mu-hat: [0.6491237838075858, 0.21063935209263837, 0.5445417591217179, 0.3709893362474717, 0.36826936358579626, 0.30244695897753354]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 552.1999999999952\n",
            "0 4\n",
            "616.1575678783915 0 {(3, 0.3709893362474717), (2, 0.5445417591217179), (0, 0.6491237838075858), (4, 0.36826936358579626)}\n",
            "\n",
            "t 7800\n",
            "t reward-arm: [539.2031461605607, 8.004295379520258, 568.5015965230734, 31.552794687797128, 24.469826232219834, 14.819900989899145]\n",
            "t numplay: [831.0, 37.0, 1043.0, 84.0, 64.0, 48.0] 2107.0\n",
            "t mu-hat: [0.6480807045199046, 0.21063935209263837, 0.5445417591217179, 0.3712093492682015, 0.37645886511107435, 0.30244695897753354]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 557.4999999999907\n",
            "0 4\n",
            "698.9728833916122 0 {(3, 0.3712093492682015), (2, 0.5445417591217179), (0, 0.6481247767377252), (4, 0.37645886511107435)}\n",
            "\n",
            "t 7900\n",
            "t reward-arm: [599.4857786452228, 8.515899535935716, 569.1852830249077, 31.897860890401606, 25.19878227269638, 14.819900989899145]\n",
            "t numplay: [926.0, 39.0, 1044.0, 85.0, 65.0, 48.0] 2207.0\n",
            "t mu-hat: [0.6466944753454399, 0.2128974883983929, 0.5446749119855576, 0.3709053591907164, 0.38179973140449064, 0.30244695897753354]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 563.7999999999863\n",
            "0 4\n",
            "780.1046959643937 0 {(3, 0.3709053591907164), (2, 0.5446749119855576), (0, 0.6467323092632096), (4, 0.38179973140449064)}\n",
            "\n",
            "4, t 100\n",
            "t reward-arm: [0.7945203739376144, 2.0221756182780646, 8.149221526593912, 15.649497638734843, 24.939644325014182, 2.677953869611562]\n",
            "t numplay: [5.0, 7.0, 16.0, 26.0, 38.0, 8.0] 100.0\n",
            "t mu-hat: [0.13242006232293574, 0.2527719522847581, 0.4793659721525831, 0.579611023656846, 0.6394780596157482, 0.2975504299568402]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 9.550000000000008\n",
            "4 4\n",
            "55.18298962973843 0 {(3, 0.579611023656846), (2, 0.4793659721525831), (4, 0.6401699462065946)}\n",
            "\n",
            "t 200\n",
            "t reward-arm: [1.835839532153027, 3.4225543120750803, 17.358354145815426, 31.282443251451078, 49.48742409031735, 4.281924444543715]\n",
            "t numplay: [11.0, 12.0, 33.0, 53.0, 78.0, 13.0] 200.0\n",
            "t mu-hat: [0.15298662767941892, 0.26327340862116, 0.5105398278181008, 0.5793045046565014, 0.6264230897508525, 0.30585174603883675]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 19.500000000000025\n",
            "4 4\n",
            "113.55162127873409 0 {(3, 0.5793045046565014), (2, 0.5056782873576783), (4, 0.6264230897508525)}\n",
            "\n",
            "t 300\n",
            "t reward-arm: [1.835839532153027, 3.6332463639746466, 23.3262874022255, 51.1520342670939, 81.50145292394619, 5.214648162725819]\n",
            "t numplay: [11.0, 13.0, 45.0, 86.0, 129.0, 16.0] 300.0\n",
            "t mu-hat: [0.15298662767941892, 0.25951759742676045, 0.5070932043962065, 0.5879544168631483, 0.6269342532611245, 0.306744009572107]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 24.200000000000035\n",
            "4 4\n",
            "179.005283275262 0 {(3, 0.5879544168631483), (2, 0.5070932043962065), (4, 0.6266455182771863)}\n",
            "\n",
            "t 400\n",
            "t reward-arm: [2.068235529717357, 4.355380379373138, 27.061538185747153, 67.90747596555133, 122.04853942518496, 5.412489909426771]\n",
            "t numplay: [12.0, 15.0, 53.0, 113.0, 190.0, 17.0] 400.0\n",
            "t mu-hat: [0.159095040747489, 0.2722112737108211, 0.5011395960323547, 0.5956796137329063, 0.6389975886135338, 0.3006938838570428]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 28.050000000000047\n",
            "4 4\n",
            "248.0891570241445 0 {(3, 0.5956796137329063), (2, 0.5011395960323547), (4, 0.6392486119799384)}\n",
            "\n",
            "t 500\n",
            "t reward-arm: [2.068235529717357, 4.602110542339423, 29.45904015754181, 79.28571427454216, 169.45397464597556, 5.720200189240062]\n",
            "t numplay: [12.0, 16.0, 58.0, 133.0, 263.0, 18.0] 500.0\n",
            "t mu-hat: [0.159095040747489, 0.27071238484349547, 0.49930576538206456, 0.591684434884643, 0.6418711160832408, 0.30106316785474013]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 30.750000000000057\n",
            "4 4\n",
            "320.23964325629794 0 {(3, 0.591684434884643), (2, 0.49930576538206456), (4, 0.642149392263377)}\n",
            "\n",
            "t 600\n",
            "t reward-arm: [2.2146510797354915, 4.922092115362441, 31.431832080004423, 94.04207698503764, 214.58174918999177, 6.563023340763253]\n",
            "t numplay: [13.0, 17.0, 62.0, 157.0, 331.0, 20.0] 600.0\n",
            "t mu-hat: [0.1581893628382494, 0.27344956196458003, 0.49891796952387973, 0.5952030188926433, 0.6463305698493728, 0.31252492098872636]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 33.65000000000002\n",
            "4 4\n",
            "393.2770287388802 0 {(3, 0.5952030188926432), (2, 0.49891796952387973), (4, 0.6461206290324762)}\n",
            "\n",
            "t 700\n",
            "t reward-arm: [2.2146510797354915, 5.254718140467307, 33.397662421406565, 107.28191802427482, 261.3988973399902, 6.660457606671988]\n",
            "t numplay: [13.0, 18.0, 66.0, 179.0, 403.0, 21.0] 700.0\n",
            "t mu-hat: [0.1581893628382494, 0.27656411265617403, 0.49847257345382934, 0.5960106556904157, 0.6470269736138371, 0.3027480730305449]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 35.99999999999995\n",
            "4 4\n",
            "467.9681398255344 0 {(3, 0.5960106556904157), (2, 0.49847257345382934), (4, 0.6468863453130537)}\n",
            "\n",
            "t 800\n",
            "t reward-arm: [2.2146510797354915, 5.523636927158748, 35.331999114560944, 118.58708934920602, 311.3880042779619, 6.660457606671989]\n",
            "t numplay: [13.0, 19.0, 70.0, 198.0, 479.0, 21.0] 800.0\n",
            "t mu-hat: [0.1581893628382494, 0.2761818463579374, 0.4976337903459288, 0.5959150218553066, 0.6487250089124206, 0.30274807303054496]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 37.89999999999989\n",
            "4 4\n",
            "543.7086731056295 0 {(3, 0.5959150218553068), (2, 0.4976337903459288), (4, 0.6484400514882325)}\n",
            "\n",
            "t 900\n",
            "t reward-arm: [2.5737187545302547, 5.889909056663129, 36.82339323981787, 125.34899759900989, 366.33080458154825, 6.919500961533748]\n",
            "t numplay: [15.0, 20.0, 73.0, 209.0, 561.0, 22.0] 900.0\n",
            "t mu-hat: [0.16085742215814092, 0.28047185984110135, 0.49761342215970095, 0.5968999885667138, 0.6518341718532887, 0.3008478678927716]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 40.899999999999864\n",
            "4 4\n",
            "618.8323688152635 0 {(3, 0.5968999885667138), (2, 0.49761342215970095), (1, 0.28047185984110135), (4, 0.6518341718532887)}\n",
            "\n",
            "t 1000\n",
            "t reward-arm: [2.8098413241342843, 5.889909056663129, 37.546759299357326, 134.57692658106376, 418.69087960290653, 6.919500961533748]\n",
            "t numplay: [16.0, 20.0, 75.0, 225.0, 642.0, 22.0] 1000.0\n",
            "t mu-hat: [0.16528478377260497, 0.28047185984110135, 0.49403630657049113, 0.5954731264648839, 0.6511522233326695, 0.3008478678927716]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 42.04999999999981\n",
            "4 4\n",
            "696.706449119858 0 {(3, 0.5953911795973386), (2, 0.49403630657049113), (1, 0.28047185984110135), (4, 0.6511522233326695)}\n",
            "\n",
            "t 1100\n",
            "t reward-arm: [2.8098413241342843, 6.934503686878178, 39.3679172042409, 140.8578797901322, 471.49301591965406, 7.361582993026426]\n",
            "t numplay: [16.0, 24.0, 79.0, 236.0, 722.0, 23.0] 1100.0\n",
            "t mu-hat: [0.16528478377260497, 0.2773801474751271, 0.4920989650530112, 0.5943370455279839, 0.6521341852277373, 0.3067326247094344]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 44.84999999999978\n",
            "4 4\n",
            "771.8403290663726 0 {(3, 0.5943370455279839), (2, 0.4920989650530112), (4, 0.6520802024297236)}\n",
            "\n",
            "t 1200\n",
            "t reward-arm: [2.8098413241342843, 6.934503686878178, 39.3679172042409, 170.8705355853702, 504.05337120665763, 7.6416830090521835]\n",
            "t numplay: [16.0, 24.0, 79.0, 283.0, 774.0, 24.0] 1200.0\n",
            "t mu-hat: [0.16528478377260497, 0.2773801474751271, 0.4920989650530112, 0.6016568154414443, 0.6503914467182679, 0.3056673203620873]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 47.499999999999645\n",
            "4 4\n",
            "846.9673517479059 0 {(3, 0.6021160788828505), (2, 0.4920989650530112), (4, 0.6503914467182679)}\n",
            "\n",
            "t 1300\n",
            "t reward-arm: [2.8098413241342843, 6.934503686878179, 40.627102429967294, 183.41758777062924, 552.2420855404746, 7.641683009052183]\n",
            "t numplay: [16.0, 24.0, 82.0, 304.0, 850.0, 24.0] 1300.0\n",
            "t mu-hat: [0.16528478377260497, 0.2773801474751271, 0.4894831618068349, 0.6013691402315713, 0.6489331204940947, 0.3056673203620873]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 48.99999999999958\n",
            "4 4\n",
            "924.4555017128273 0 {(3, 0.6014387669570351), (2, 0.4894831618068349), (4, 0.6489331204940947)}\n",
            "\n",
            "t 1400\n",
            "t reward-arm: [2.8098413241342843, 6.934503686878177, 40.627102429967294, 191.72740422203046, 607.9301302476316, 8.030458476666167]\n",
            "t numplay: [16.0, 24.0, 82.0, 318.0, 935.0, 25.0] 1400.0\n",
            "t mu-hat: [0.16528478377260497, 0.27738014747512707, 0.4894831618068349, 0.6010263455236065, 0.6494980024013158, 0.30886378756408334]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 49.99999999999954\n",
            "4 4\n",
            "1002.903416567464 0 {(3, 0.6010263455236066), (2, 0.4894831618068349), (4, 0.6494947345885156)}\n",
            "\n",
            "t 1500\n",
            "t reward-arm: [2.800634482465842, 6.934503686878179, 42.80126255538521, 198.72076599027167, 661.4910644422253, 8.391854656733459]\n",
            "t numplay: [17.0, 24.0, 86.0, 330.0, 1017.0, 26.0] 1500.0\n",
            "t mu-hat: [0.15559080458143568, 0.2773801474751271, 0.4919685351193702, 0.6003648519343555, 0.6497947587841113, 0.31080943173086883]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 51.9499999999995\n",
            "4 4\n",
            "1079.7440825445274 0 {(3, 0.6003648519343555), (2, 0.4919685351193702), (4, 0.6496832733952984)}\n",
            "\n",
            "t 1600\n",
            "t reward-arm: [2.8006344824658425, 6.934503686878179, 44.31834900073349, 204.84783124905834, 718.9062575381772, 8.39185465673346]\n",
            "t numplay: [17.0, 24.0, 89.0, 340.0, 1104.0, 26.0] 1600.0\n",
            "t mu-hat: [0.1555908045814357, 0.2773801474751271, 0.4924261000081499, 0.6007267778564761, 0.6505938982245948, 0.31080943173086895]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 52.94999999999946\n",
            "4 4\n",
            "1158.5381293731537 0 {(3, 0.6006043200646002), (2, 0.4924261000081499), (4, 0.6505938982245948)}\n",
            "\n",
            "t 1700\n",
            "t reward-arm: [2.976557351047969, 7.124518114583724, 45.893924407102844, 217.41044169737995, 764.2576280409819, 9.31508243452916]\n",
            "t numplay: [18.0, 25.0, 92.0, 361.0, 1176.0, 28.0] 1700.0\n",
            "t mu-hat: [0.156660913213051, 0.2740199274839894, 0.4934830581408908, 0.6005813306557457, 0.6493267867807833, 0.32120973912169515]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 55.7999999999994\n",
            "4 4\n",
            "1233.9632317753303 0 {(3, 0.6005813306557457), (2, 0.4934830581408908), (4, 0.6493434575348892)}\n",
            "\n",
            "t 1800\n",
            "t reward-arm: [3.683233225779434, 7.332766592970806, 47.48437875010126, 228.50023165533418, 812.7756556884854, 9.315082434529161]\n",
            "t numplay: [21.0, 26.0, 95.0, 379.0, 1251.0, 28.0] 1800.0\n",
            "t mu-hat: [0.16741969208088336, 0.27158394788780765, 0.4946289453135548, 0.6013163990929846, 0.6491818336170011, 0.3212097391216952]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 58.849999999999355\n",
            "4 4\n",
            "1309.5783148840922 0 {(3, 0.6013163990929846), (2, 0.4946289453135548), (4, 0.6492035505290719)}\n",
            "\n",
            "t 1900\n",
            "t reward-arm: [3.683233225779434, 7.332766592970806, 47.93438685717124, 240.4482670812655, 862.8054504872392, 9.66453648813554]\n",
            "t numplay: [21.0, 26.0, 96.0, 399.0, 1329.0, 29.0] 1900.0\n",
            "t mu-hat: [0.16741969208088336, 0.27158394788780765, 0.49416893667186845, 0.6011206677031637, 0.6487259026219844, 0.32215121627118465]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 60.299999999999294\n",
            "4 4\n",
            "1387.4544686821696 0 {(3, 0.6011206677031637), (2, 0.49416893667186845), (4, 0.648670711514557)}\n",
            "\n",
            "t 2000\n",
            "t reward-arm: [4.308940361910789, 7.332766592970806, 48.56013545576625, 254.41242352285317, 907.3051530424938, 9.664536488135541]\n",
            "t numplay: [24.0, 26.0, 98.0, 422.0, 1401.0, 29.0] 2000.0\n",
            "t mu-hat: [0.17235761447643155, 0.27158394788780765, 0.49050641874511364, 0.6014478097466978, 0.6471506084468572, 0.3221512162711847]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 63.54999999999924\n",
            "4 0\n",
            "1463.4393324257703 0 {(3, 0.6014478097466978), (2, 0.49050641874511364), (4, 0.6472084189339714)}\n",
            "\n",
            "Arm 4 Changepoint Detected at time 2040\n",
            "t 2100\n",
            "t reward-arm: [4.308940361910789, 7.332766592970806, 64.85879182015918, 261.16433797966647, 6.2287464884845205, 9.91034587826022]\n",
            "t numplay: [24.0, 26.0, 128.0, 444.0, 23.0, 31.0] 676.0\n",
            "t mu-hat: [0.17235761447643155, 0.27158394788780765, 0.5027813319392185, 0.5868861527632955, 0.259531103686855, 0.30969830869563186]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 98.34999999999965\n",
            "3 0\n",
            "26.070249153103866 0 {(3, 0.5868861527632955), (2, 0.5019373175492335)}\n",
            "\n",
            "t 2200\n",
            "t reward-arm: [5.6063095391928, 11.663617619606672, 103.25207582642355, 267.1835648088546, 6.607405467960201, 10.407774479592312]\n",
            "t numplay: [26.0, 33.0, 196.0, 463.0, 25.0, 33.0] 776.0\n",
            "t mu-hat: [0.20764109404417777, 0.3430475770472551, 0.5241222123168708, 0.5758266482949452, 0.2541309795369308, 0.3061110141056562]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 118.40000000000012\n",
            "3 0\n",
            "78.49941412380085 0 {(3, 0.5758266482949452), (2, 0.5241222123168708), (1, 0.33622258708477604)}\n",
            "\n",
            "t 2300\n",
            "t reward-arm: [5.6063095391928, 76.35206693767195, 103.25207582642354, 267.1835648088546, 6.6074054679602, 10.407774479592312]\n",
            "t numplay: [26.0, 133.0, 196.0, 463.0, 25.0, 33.0] 876.0\n",
            "t mu-hat: [0.20764109404417777, 0.5697915443109847, 0.5241222123168707, 0.5758266482949452, 0.25413097953693076, 0.3061110141056562]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 123.39999999999984\n",
            "3 0\n",
            "124.22379591182631 0 {(3, 0.5758266482949452), (2, 0.5241222123168707), (1, 0.5685290685303599)}\n",
            "\n",
            "t 2400\n",
            "t reward-arm: [6.4564644106792395, 137.48417359310156, 104.29609611691441, 267.5437117501787, 6.894713342554226, 10.407774479592312]\n",
            "t numplay: [27.0, 228.0, 198.0, 464.0, 26.0, 33.0] 976.0\n",
            "t mu-hat: [0.2305880146671157, 0.6003675702755527, 0.5241009855121327, 0.5753628209681263, 0.2553597534279343, 0.3061110141056562]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 129.29999999999995\n",
            "1 0\n",
            "192.5339852767906 0 {(3, 0.5753628209681263), (2, 0.5241009855121327), (1, 0.600275560116192)}\n",
            "\n",
            "t 2500\n",
            "t reward-arm: [6.4564644106792395, 202.066558340321, 104.29609611691441, 267.54371175017866, 6.894713342554226, 10.407774479592312]\n",
            "t numplay: [27.0, 328.0, 198.0, 464.0, 26.0, 33.0] 1076.0\n",
            "t mu-hat: [0.2305880146671157, 0.6141840679037113, 0.5241009855121327, 0.5753628209681262, 0.2553597534279343, 0.3061110141056562]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 134.3000000000011\n",
            "1 0\n",
            "266.6416191921785 0 {(3, 0.5753628209681262), (2, 0.5241009855121327), (1, 0.6143833532210986)}\n",
            "\n",
            "t 2600\n",
            "t reward-arm: [6.4564644106792395, 263.7547625977995, 105.49640136712655, 267.86156985316745, 6.894713342554225, 10.407774479592312]\n",
            "t numplay: [27.0, 425.0, 200.0, 465.0, 26.0, 33.0] 1176.0\n",
            "t mu-hat: [0.2305880146671157, 0.6191426352061021, 0.5248577182444107, 0.5748102357364109, 0.25535975342793427, 0.3061110141056562]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 139.8500000000022\n",
            "1 0\n",
            "341.8396060132498 0 {(3, 0.5748102357364109), (2, 0.5248577182444107), (1, 0.6189897164581618)}\n",
            "\n",
            "Arm 1 Changepoint Detected at time 2630\n",
            "Arm 3 Changepoint Detected at time 2690\n",
            "t 2700\n",
            "t reward-arm: [7.119891847979159, 37.42002866670193, 105.49640136712655, 2.131234104112802, 7.5450591659374036, 10.407774479592312]\n",
            "t numplay: [28.0, 56.0, 200.0, 8.0, 28.0, 33.0] 353.0\n",
            "t mu-hat: [0.24551351199928134, 0.6564917309947708, 0.5248577182444107, 0.23680378934586688, 0.2601744539978415, 0.3061110141056562]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 149.80000000000322\n",
            "1 0\n",
            "4.539814812654097 0 {(2, 0.5248577182444107), (1, 0.6564917309947708)}\n",
            "\n",
            "t 2800\n",
            "t reward-arm: [7.119891847979159, 99.33606762879045, 105.49640136712655, 3.4475353910081594, 7.5450591659374036, 10.407774479592312]\n",
            "t numplay: [28.0, 151.0, 200.0, 13.0, 28.0, 33.0] 453.0\n",
            "t mu-hat: [0.24551351199928134, 0.6535267607157266, 0.5248577182444107, 0.24625252792915425, 0.2601744539978415, 0.3061110141056562]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 156.20000000000434\n",
            "1 0\n",
            "85.90292455004924 0 {(2, 0.5248577182444107), (1, 0.6536733378830502)}\n",
            "\n",
            "t 2900\n",
            "t reward-arm: [7.6647761952765485, 158.58716783893803, 106.06403041617503, 5.123485046922481, 7.5450591659374036, 10.407774479592312]\n",
            "t numplay: [29.0, 244.0, 201.0, 18.0, 28.0, 33.0] 553.0\n",
            "t mu-hat: [0.2554925398425516, 0.6472945626079103, 0.525069457505817, 0.26965710773276214, 0.2601744539978415, 0.3061110141056562]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 163.00000000000543\n",
            "1 0\n",
            "165.36495068352926 0 {(2, 0.525069457505817), (1, 0.6476290996724143)}\n",
            "\n",
            "t 3000\n",
            "t reward-arm: [7.6647761952765485, 223.14524593904883, 106.06403041617503, 5.123485046922481, 7.545059165937403, 10.407774479592312]\n",
            "t numplay: [29.0, 344.0, 201.0, 18.0, 28.0, 33.0] 653.0\n",
            "t mu-hat: [0.2554925398425516, 0.6467978143160836, 0.525069457505817, 0.26965710773276214, 0.26017445399784145, 0.3061110141056562]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 168.00000000000657\n",
            "1 0\n",
            "246.60308716101449 0 {(2, 0.525069457505817), (1, 0.6463436470575342)}\n",
            "\n",
            "t 3100\n",
            "t reward-arm: [10.083510450340006, 283.8793733749749, 106.45958829866291, 5.872415379059639, 7.545059165937403, 10.407774479592314]\n",
            "t numplay: [32.0, 438.0, 202.0, 20.0, 28.0, 33.0] 753.0\n",
            "t mu-hat: [0.30556092273757596, 0.6466500532459565, 0.5244314694515414, 0.2796388275742685, 0.26017445399784145, 0.3061110141056563]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 173.65000000000765\n",
            "1 0\n",
            "325.1146544754157 0 {(2, 0.5244314694515414), (1, 0.6466513420027197), (0, 0.30556092273757596)}\n",
            "\n",
            "t 3200\n",
            "t reward-arm: [10.083510450340006, 346.82084183125585, 106.45958829866291, 6.120341267931257, 7.5450591659374036, 10.407774479592314]\n",
            "t numplay: [32.0, 537.0, 202.0, 21.0, 28.0, 33.0] 853.0\n",
            "t mu-hat: [0.30556092273757596, 0.6446484048908101, 0.5244314694515414, 0.2781973303605117, 0.2601744539978415, 0.3061110141056563]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 179.00000000000878\n",
            "1 0\n",
            "405.9146988825973 0 {(2, 0.5244314694515414), (1, 0.6447715531606835), (0, 0.30556092273757596)}\n",
            "\n",
            "t 3300\n",
            "t reward-arm: [10.083510450340007, 407.6438443105135, 107.31086405760212, 6.452029474034459, 8.474865645337912, 10.407774479592314]\n",
            "t numplay: [32.0, 631.0, 204.0, 22.0, 31.0, 33.0] 953.0\n",
            "t mu-hat: [0.30556092273757596, 0.6450060827697999, 0.5234676295492786, 0.2805230206101939, 0.26483955141680976, 0.3061110141056563]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 185.75000000000983\n",
            "1 0\n",
            "484.4253858452992 0 {(3, 0.2805230206101939), (2, 0.5234676295492786), (1, 0.6450171919180365), (0, 0.30556092273757596)}\n",
            "\n",
            "t 3400\n",
            "t reward-arm: [10.083510450340007, 472.501161769828, 107.31086405760212, 6.452029474034459, 8.47486564533791, 10.407774479592312]\n",
            "t numplay: [32.0, 731.0, 204.0, 22.0, 31.0, 33.0] 1053.0\n",
            "t mu-hat: [0.30556092273757596, 0.6454933903959399, 0.5234676295492786, 0.2805230206101939, 0.2648395514168097, 0.3061110141056562]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 190.75000000001097\n",
            "1 0\n",
            "565.5862548056434 0 {(3, 0.2805230206101939), (2, 0.5234676295492786), (1, 0.6454998298392303), (0, 0.30556092273757596)}\n",
            "\n",
            "t 3500\n",
            "t reward-arm: [10.753731442769674, 533.9767536710231, 108.48863387098592, 6.60060958336605, 8.47486564533791, 10.407774479592314]\n",
            "t numplay: [33.0, 827.0, 206.0, 23.0, 31.0, 33.0] 1153.0\n",
            "t mu-hat: [0.3162862189049904, 0.6448994609553419, 0.5240996805361638, 0.27502539930691877, 0.2648395514168097, 0.3061110141056563]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 196.25000000001208\n",
            "1 0\n",
            "645.1387407593197 0 {(2, 0.5240996805361638), (1, 0.6447506890479443), (0, 0.3162862189049904)}\n",
            "\n",
            "t 3600\n",
            "t reward-arm: [10.753731442769674, 598.7767274197229, 109.0469057479272, 6.84644439484612, 8.47486564533791, 10.407774479592314]\n",
            "t numplay: [33.0, 925.0, 207.0, 24.0, 31.0, 33.0] 1253.0\n",
            "t mu-hat: [0.3162862189049904, 0.6466271354424653, 0.5242639699419577, 0.2738577757938448, 0.2648395514168097, 0.3061110141056563]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 201.7000000000132\n",
            "1 0\n",
            "725.5002971993503 0 {(2, 0.5242639699419576), (1, 0.6465845766842558), (0, 0.3162862189049904)}\n",
            "\n",
            "t 3700\n",
            "t reward-arm: [10.753731442769674, 663.092967647706, 109.0469057479272, 6.846444394846119, 8.47486564533791, 10.407774479592312]\n",
            "t numplay: [33.0, 1025.0, 207.0, 24.0, 31.0, 33.0] 1353.0\n",
            "t mu-hat: [0.3162862189049904, 0.6462894421517602, 0.5242639699419577, 0.2738577757938448, 0.2648395514168097, 0.3061110141056562]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 206.70000000001434\n",
            "1 0\n",
            "806.7469062550531 0 {(2, 0.5242639699419577), (1, 0.6462740813880763), (0, 0.3162862189049904)}\n",
            "\n",
            "t 3800\n",
            "t reward-arm: [11.511009891616828, 727.140105527104, 109.0469057479272, 7.250343655658868, 9.096276045917408, 10.407774479592312]\n",
            "t numplay: [34.0, 1121.0, 207.0, 25.0, 33.0, 33.0] 1453.0\n",
            "t mu-hat: [0.3288859969033379, 0.6480749603628377, 0.5242639699419577, 0.2788593713714949, 0.2675375307622767, 0.3061110141056562]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 212.80000000001542\n",
            "1 0\n",
            "885.9450485898426 0 {(2, 0.5242639699419577), (1, 0.6479875434497071), (0, 0.3288859969033379)}\n",
            "\n",
            "t 3900\n",
            "t reward-arm: [11.511009891616828, 791.0824779007518, 109.04690574792721, 7.2503436556588685, 9.096276045917408, 10.407774479592312]\n",
            "t numplay: [34.0, 1221.0, 207.0, 25.0, 33.0, 33.0] 1553.0\n",
            "t mu-hat: [0.3288859969033379, 0.6473670031921046, 0.5242639699419578, 0.27885937137149497, 0.2675375307622767, 0.3061110141056562]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 217.80000000001655\n",
            "1 0\n",
            "967.4823638905051 0 {(2, 0.5242639699419578), (1, 0.6474250005433942), (0, 0.3288859969033379)}\n",
            "\n",
            "t 4000\n",
            "t reward-arm: [13.3199761538405, 853.3573463647659, 109.60723747750133, 7.783277888706176, 9.096276045917406, 10.407774479592314]\n",
            "t numplay: [37.0, 1315.0, 208.0, 27.0, 33.0, 33.0] 1653.0\n",
            "t mu-hat: [0.3505256882589605, 0.6484478315841686, 0.5244365429545518, 0.2779742103109349, 0.26753753076227665, 0.3061110141056563]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 223.45000000001764\n",
            "1 3\n",
            "1045.942630200287 0 {(2, 0.5244365429545518), (1, 0.6484752283598931), (0, 0.3505256882589605)}\n",
            "\n",
            "t 4100\n",
            "t reward-arm: [13.3199761538405, 930.1888565291815, 109.60723747750133, 7.783277888706176, 9.096276045917406, 10.407774479592314]\n",
            "t numplay: [37.0, 1415.0, 208.0, 27.0, 33.0, 33.0] 1753.0\n",
            "t mu-hat: [0.3505256882589605, 0.6569130342720209, 0.5244365429545518, 0.2779742103109349, 0.26753753076227665, 0.3061110141056563]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 228.45000000001878\n",
            "1 3\n",
            "1128.516994375074 0 {(2, 0.5244365429545518), (1, 0.6568201767226699), (0, 0.3505256882589605)}\n",
            "\n",
            "t 4200\n",
            "t reward-arm: [13.3199761538405, 1001.9377343317602, 110.08691401291787, 7.783277888706176, 10.003260566686912, 10.407774479592314]\n",
            "t numplay: [37.0, 1511.0, 209.0, 27.0, 36.0, 33.0] 1853.0\n",
            "t mu-hat: [0.3505256882589605, 0.6626572317008996, 0.5242234000615137, 0.2779742103109349, 0.27035839369424086, 0.3061110141056563]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 235.03000000001987\n",
            "1 3\n",
            "1210.42107381417 0 {(2, 0.5242234000615137), (1, 0.6625774339088606), (0, 0.3505256882589605)}\n",
            "\n",
            "t 4300\n",
            "t reward-arm: [13.3199761538405, 1074.325101938054, 110.08691401291786, 8.671210853299414, 10.67939147492304, 10.407774479592312]\n",
            "t numplay: [37.0, 1608.0, 209.0, 28.0, 38.0, 33.0] 1953.0\n",
            "t mu-hat: [0.3505256882589605, 0.6676973908875414, 0.5242234000615136, 0.29900727080342804, 0.2738305506390523, 0.3061110141056562]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 241.11000000002096\n",
            "1 3\n",
            "1293.4088266501572 0 {(3, 0.29900727080342804), (2, 0.5242234000615136), (1, 0.6676973908875414), (0, 0.3505256882589605)}\n",
            "\n",
            "t 4400\n",
            "t reward-arm: [13.3199761538405, 1147.0464643920361, 110.84060819580569, 9.33518826058955, 10.865185201026176, 10.407774479592312]\n",
            "t numplay: [37.0, 1705.0, 210.0, 29.0, 39.0, 33.0] 2053.0\n",
            "t mu-hat: [0.3505256882589605, 0.6723601784244057, 0.5253109393166147, 0.3111729420196517, 0.2716296300256544, 0.3061110141056562]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 246.51000000002207\n",
            "1 3\n",
            "1378.2050828709998 0 {(3, 0.3111729420196517), (2, 0.5253109393166147), (1, 0.6723759413046784), (0, 0.3505256882589605)}\n",
            "\n",
            "t 4500\n",
            "t reward-arm: [13.549227733882594, 1216.3398824633719, 111.7172723202539, 10.19077931338811, 11.052819790030002, 10.407774479592312]\n",
            "t numplay: [38.0, 1800.0, 212.0, 30.0, 40.0, 33.0] 2153.0\n",
            "t mu-hat: [0.34741609574057936, 0.6753691740496235, 0.5244942362453234, 0.32873481656090675, 0.26958097048853663, 0.3061110141056562]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 252.92000000002315\n",
            "1 3\n",
            "1462.6453680367708 0 {(3, 0.32873481656090675), (2, 0.5244942362453234), (1, 0.6753729116855824), (0, 0.34741609574057936)}\n",
            "\n",
            "t 4600\n",
            "t reward-arm: [13.549227733882594, 1291.0473028661763, 111.7172723202539, 10.19077931338811, 11.052819790030002, 10.407774479592312]\n",
            "t numplay: [38.0, 1900.0, 212.0, 30.0, 40.0, 33.0] 2253.0\n",
            "t mu-hat: [0.34741609574057936, 0.6791411377518024, 0.5244942362453234, 0.32873481656090675, 0.26958097048853663, 0.3061110141056562]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 257.9200000000243\n",
            "1 3\n",
            "1550.1513326887678 0 {(3, 0.32873481656090675), (2, 0.5244942362453234), (1, 0.6790697254344842), (0, 0.34741609574057936)}\n",
            "\n",
            "t 4700\n",
            "t reward-arm: [13.549227733882594, 1363.582083902847, 113.00793157281697, 11.855069598271324, 11.457170867899436, 10.407774479592312]\n",
            "t numplay: [38.0, 1995.0, 214.0, 32.0, 41.0, 33.0] 2353.0\n",
            "t mu-hat: [0.34741609574057936, 0.683157356664753, 0.5256182863851953, 0.35924453328094924, 0.2727897825690342, 0.3061110141056562]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 263.7300000000253\n",
            "1 3\n",
            "1635.9720439690166 0 {(3, 0.35924453328094924), (2, 0.5256182863851953), (1, 0.6831190143555145), (0, 0.34741609574057936)}\n",
            "\n",
            "Arm 1 Changepoint Detected at time 4750\n",
            "t 4800\n",
            "t reward-arm: [13.549227733882594, 36.85778254360884, 113.00793157281694, 11.855069598271324, 11.457170867899436, 10.407774479592312]\n",
            "t numplay: [38.0, 50.0, 214.0, 32.0, 41.0, 33.0] 408.0\n",
            "t mu-hat: [0.34741609574057936, 0.7227016185021341, 0.525618286385195, 0.35924453328094924, 0.2727897825690342, 0.3061110141056562]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 268.73000000002645\n",
            "1 3\n",
            "44.92810395473519 0 {(3, 0.35924453328094924), (2, 0.525618286385195), (1, 0.7240496129701256), (0, 0.34741609574057936)}\n",
            "\n",
            "t 4900\n",
            "t reward-arm: [13.966596223161002, 107.65094430769867, 113.53010295096581, 12.692105270924841, 11.457170867899436, 10.407774479592312]\n",
            "t numplay: [40.0, 146.0, 215.0, 33.0, 41.0, 33.0] 508.0\n",
            "t mu-hat: [0.3406486883697805, 0.7323193490319637, 0.5256023284766935, 0.3732972138507306, 0.2727897825690342, 0.3061110141056562]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 275.01000000002756\n",
            "1 3\n",
            "141.4165208663655 0 {(3, 0.3732972138507306), (2, 0.5256023284766935), (1, 0.7316460186544271), (0, 0.3406486883697805)}\n",
            "\n",
            "t 5000\n",
            "t reward-arm: [13.966596223161002, 184.82517586273582, 113.53010295096581, 12.692105270924841, 11.457170867899436, 10.407774479592312]\n",
            "t numplay: [40.0, 246.0, 215.0, 33.0, 41.0, 33.0] 608.0\n",
            "t mu-hat: [0.3406486883697805, 0.7482800642216025, 0.5256023284766935, 0.3732972138507306, 0.2727897825690342, 0.3061110141056562]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 280.0100000000287\n",
            "1 3\n",
            "241.39007886935988 0 {(3, 0.3732972138507306), (2, 0.5256023284766935), (1, 0.7473373641950364), (0, 0.3406486883697805)}\n",
            "\n",
            "t 5100\n",
            "t reward-arm: [13.966596223161002, 258.3468920823184, 114.07738611090299, 13.510958261530364, 11.65592660279563, 10.407774479592312]\n",
            "t numplay: [40.0, 343.0, 216.0, 34.0, 42.0, 33.0] 708.0\n",
            "t mu-hat: [0.3406486883697805, 0.7510084072160418, 0.5257022401424101, 0.3860273789008675, 0.27106806053013094, 0.3061110141056562]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 285.6400000000298\n",
            "1 3\n",
            "341.71431928163065 0 {(3, 0.3860273789008675), (2, 0.5257022401424101), (1, 0.7508405131520415), (0, 0.3406486883697805)}\n",
            "\n",
            "t 5200\n",
            "t reward-arm: [14.15157287756039, 329.5681201743554, 114.57407030695184, 15.194476616061126, 12.091074955439524, 10.407774479592312]\n",
            "t numplay: [41.0, 438.0, 217.0, 36.0, 43.0, 33.0] 808.0\n",
            "t mu-hat: [0.33694221137048547, 0.7507246473219941, 0.525569129848403, 0.4106615301638142, 0.274797158078171, 0.3061110141056562]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 291.77000000003085\n",
            "1 3\n",
            "440.97644528293205 0 {(3, 0.4106615301638142), (2, 0.525569129848403), (1, 0.7511295107356238), (0, 0.33694221137048547)}\n",
            "\n",
            "t 5300\n",
            "t reward-arm: [14.15157287756039, 403.97511976246255, 114.57407030695182, 15.194476616061124, 12.091074955439524, 10.407774479592312]\n",
            "t numplay: [41.0, 538.0, 217.0, 36.0, 43.0, 33.0] 908.0\n",
            "t mu-hat: [0.33694221137048547, 0.7494900181121754, 0.5255691298484029, 0.4106615301638142, 0.274797158078171, 0.3061110141056562]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 296.770000000032\n",
            "1 3\n",
            "542.9776520121416 0 {(3, 0.4106615301638142), (2, 0.5255691298484029), (1, 0.7494402391244596), (0, 0.33694221137048547)}\n",
            "\n",
            "t 5400\n",
            "t reward-arm: [14.15157287756039, 473.21327895130605, 115.60376372811126, 17.569014183141608, 12.37934534748245, 10.407774479592312]\n",
            "t numplay: [41.0, 632.0, 219.0, 39.0, 44.0, 33.0] 1008.0\n",
            "t mu-hat: [0.33694221137048547, 0.747572320618177, 0.5254716533095967, 0.4392253545785402, 0.2750965632773878, 0.3061110141056562]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 302.530000000033\n",
            "1 3\n",
            "641.6513317038539 0 {(3, 0.4392253545785402), (2, 0.5254716533095967), (1, 0.7476257693179771), (0, 0.33694221137048547)}\n",
            "\n",
            "t 5500\n",
            "t reward-arm: [14.15157287756039, 549.2521760213465, 115.60376372811126, 17.569014183141608, 12.379345347482452, 10.407774479592312]\n",
            "t numplay: [41.0, 732.0, 219.0, 39.0, 44.0, 33.0] 1108.0\n",
            "t mu-hat: [0.33694221137048547, 0.7493208404111139, 0.5254716533095967, 0.4392253545785402, 0.27509656327738785, 0.3061110141056562]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 307.53000000003414\n",
            "1 3\n",
            "743.2159017293371 0 {(3, 0.4392253545785402), (2, 0.5254716533095967), (1, 0.7493243758841049), (0, 0.33694221137048547)}\n",
            "\n",
            "t 5600\n",
            "t reward-arm: [14.15157287756039, 618.7557428590262, 117.57306301082289, 18.266384479143788, 12.703509101601188, 10.407774479592312]\n",
            "t numplay: [41.0, 826.0, 223.0, 40.0, 45.0, 33.0] 1208.0\n",
            "t mu-hat: [0.33694221137048547, 0.7481931594425952, 0.5248797455840307, 0.4455215726620436, 0.27616324133915626, 0.3061110141056562]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 313.8500000000351\n",
            "1 3\n",
            "842.4091072888228 0 {(3, 0.4455215726620436), (2, 0.5248797455840307), (1, 0.7480785952713037), (0, 0.33694221137048547)}\n",
            "\n",
            "t 5700\n",
            "t reward-arm: [14.15157287756039, 694.1160815463088, 117.57306301082289, 18.266384479143788, 12.703509101601188, 10.407774479592312]\n",
            "t numplay: [41.0, 926.0, 223.0, 40.0, 45.0, 33.0] 1308.0\n",
            "t mu-hat: [0.33694221137048547, 0.7487767869970969, 0.5248797455840307, 0.4455215726620436, 0.27616324133915626, 0.3061110141056562]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 318.85000000003623\n",
            "1 3\n",
            "944.092120337534 0 {(3, 0.4455215726620436), (2, 0.5248797455840307), (1, 0.748736917813367), (0, 0.33694221137048547)}\n",
            "\n",
            "t 5800\n",
            "t reward-arm: [14.15157287756039, 764.5872475774304, 117.57306301082286, 22.610539891692493, 12.703509101601188, 10.407774479592312]\n",
            "t numplay: [41.0, 1021.0, 223.0, 45.0, 45.0, 33.0] 1408.0\n",
            "t mu-hat: [0.33694221137048547, 0.7481284222871138, 0.5248797455840306, 0.49153347590635854, 0.27616324133915626, 0.3061110141056562]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 323.6000000000373\n",
            "1 3\n",
            "1042.9449851404422 0 {(3, 0.49153347590635854), (2, 0.5248797455840306), (1, 0.748275871582679), (0, 0.33694221137048547)}\n",
            "\n",
            "t 5900\n",
            "t reward-arm: [14.15157287756039, 839.865043269818, 117.57306301082286, 22.610539891692493, 12.703509101601187, 10.407774479592312]\n",
            "t numplay: [41.0, 1121.0, 223.0, 45.0, 45.0, 33.0] 1508.0\n",
            "t mu-hat: [0.33694221137048547, 0.7485428193135633, 0.5248797455840306, 0.49153347590635854, 0.2761632413391562, 0.3061110141056562]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 328.60000000003845\n",
            "1 3\n",
            "1144.6267986048258 0 {(3, 0.49153347590635854), (2, 0.5248797455840306), (1, 0.748560221919843), (0, 0.33694221137048547)}\n",
            "\n",
            "t 6000\n",
            "t reward-arm: [14.383831879463774, 909.5530794613899, 118.83977912405854, 23.497222711265763, 12.958169408051367, 10.407774479592312]\n",
            "t numplay: [42.0, 1215.0, 226.0, 46.0, 46.0, 33.0] 1608.0\n",
            "t mu-hat: [0.3345077181270645, 0.7479877298202219, 0.5235232560531213, 0.49994090875033537, 0.2757057320861993, 0.3061110141056562]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 335.69000000003945\n",
            "1 4\n",
            "1243.4256675162217 0 {(3, 0.49994090875033537), (2, 0.5235232560531213), (1, 0.747938954394902), (0, 0.3345077181270645)}\n",
            "\n",
            "Arm 1 Changepoint Detected at time 6020\n",
            "t 6100\n",
            "t reward-arm: [16.866412020300082, 5.178536286198474, 126.17263522827648, 34.044273922866296, 15.535578216676043, 10.497998216249716]\n",
            "t numplay: [46.0, 23.0, 241.0, 80.0, 50.0, 34.0] 474.0\n",
            "t mu-hat: [0.3588598302191507, 0.21577234525826974, 0.5213745257366796, 0.42029967806007773, 0.3046191807191381, 0.29994280617856334]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 372.8400000000384\n",
            "2 4\n",
            "26.69418069773076 0 {(3, 0.42029967806007773), (2, 0.5213745257366796), (0, 0.3492739203941547), (4, 0.3046191807191381)}\n",
            "\n",
            "t 6200\n",
            "t reward-arm: [80.53580332737873, 5.178536286198474, 126.17263522827648, 34.044273922866296, 15.535578216676045, 10.497998216249718]\n",
            "t numplay: [146.0, 23.0, 241.0, 80.0, 50.0, 34.0] 574.0\n",
            "t mu-hat: [0.5478626076692431, 0.21577234525826974, 0.5213745257366796, 0.42029967806007773, 0.3046191807191381, 0.29994280617856334]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 377.84000000003954\n",
            "0 4\n",
            "73.5521465864813 0 {(3, 0.42029967806007773), (2, 0.5213745257366796), (0, 0.5475126002412656), (4, 0.3046191807191381)}\n",
            "\n",
            "Arm 0 Changepoint Detected at time 6210\n",
            "t 6300\n",
            "t reward-arm: [55.302295305245984, 5.178536286198474, 127.04433639732741, 34.37903962777955, 17.882676543810213, 10.497998216249718]\n",
            "t numplay: [84.0, 23.0, 243.0, 81.0, 53.0, 34.0] 518.0\n",
            "t mu-hat: [0.6506152388852469, 0.21577234525826974, 0.5206735098251124, 0.41925658082657985, 0.33116067673722616, 0.29994280617856334]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 383.24000000004054\n",
            "0 4\n",
            "68.3909219079345 0 {(3, 0.41925658082657985), (2, 0.5206735098251124), (0, 0.6502381998963855), (4, 0.33116067673722616)}\n",
            "\n",
            "t 6400\n",
            "t reward-arm: [120.43096573991292, 5.178536286198474, 127.04433639732744, 34.37903962777955, 17.882676543810213, 10.497998216249718]\n",
            "t numplay: [184.0, 23.0, 243.0, 81.0, 53.0, 34.0] 618.0\n",
            "t mu-hat: [0.6509781931887185, 0.21577234525826974, 0.5206735098251125, 0.41925658082657985, 0.33116067673722616, 0.29994280617856334]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 388.2400000000417\n",
            "0 4\n",
            "151.44418491312686 0 {(3, 0.41925658082657985), (2, 0.5206735098251125), (0, 0.6501377842033562), (4, 0.33116067673722616)}\n",
            "\n",
            "t 6500\n",
            "t reward-arm: [180.7153744333541, 5.379447642864204, 127.64630205204696, 34.90874759663062, 19.580717969843306, 10.497998216249718]\n",
            "t numplay: [278.0, 24.0, 244.0, 83.0, 55.0, 34.0] 718.0\n",
            "t mu-hat: [0.6477253563919502, 0.21517790571456819, 0.5210053144981509, 0.4155803285313169, 0.3496556780329162, 0.29994280617856334]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 394.3900000000427\n",
            "0 4\n",
            "231.35631815820489 0 {(3, 0.4155803285313169), (2, 0.5210053144981509), (0, 0.648000093445861), (4, 0.3496556780329162)}\n",
            "\n",
            "t 6600\n",
            "t reward-arm: [245.2715628162158, 5.379447642864204, 127.64630205204696, 34.90874759663062, 19.58071796984331, 10.497998216249718]\n",
            "t numplay: [378.0, 24.0, 244.0, 83.0, 55.0, 34.0] 818.0\n",
            "t mu-hat: [0.6471545193039995, 0.21517790571456819, 0.5210053144981509, 0.4155803285313169, 0.34965567803291625, 0.29994280617856334]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 399.3900000000438\n",
            "0 4\n",
            "313.0868201358754 0 {(3, 0.4155803285313169), (2, 0.5210053144981509), (0, 0.6471102107391641), (4, 0.34965567803291625)}\n",
            "\n",
            "t 6700\n",
            "t reward-arm: [307.683701566942, 5.589828251304114, 128.55467803427427, 34.90874759663062, 20.14883548249412, 10.497998216249718]\n",
            "t numplay: [474.0, 25.0, 246.0, 83.0, 56.0, 34.0] 918.0\n",
            "t mu-hat: [0.647755161193562, 0.21499339428092748, 0.520464283539572, 0.4155803285313169, 0.3534883417981425, 0.29994280617856334]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 404.99000000004486\n",
            "0 4\n",
            "393.62894792235477 0 {(3, 0.4155803285313169), (2, 0.520464283539572), (0, 0.6474823780066324), (4, 0.3534883417981425)}\n",
            "\n",
            "t 6800\n",
            "t reward-arm: [373.7122410733759, 5.589828251304114, 128.55467803427427, 34.90874759663062, 20.14883548249412, 10.497998216249716]\n",
            "t numplay: [574.0, 25.0, 246.0, 83.0, 56.0, 34.0] 1018.0\n",
            "t mu-hat: [0.6499343323015233, 0.21499339428092748, 0.520464283539572, 0.4155803285313169, 0.3534883417981425, 0.29994280617856334]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 409.990000000046\n",
            "0 4\n",
            "475.73715005042 0 {(3, 0.4155803285313169), (2, 0.520464283539572), (0, 0.6497295468045833), (4, 0.3534883417981425)}\n",
            "\n",
            "t 6900\n",
            "t reward-arm: [434.90927073838634, 5.834534538513633, 128.55467803427427, 35.75486241878798, 20.801035814731826, 10.497998216249718]\n",
            "t numplay: [669.0, 26.0, 246.0, 86.0, 57.0, 34.0] 1118.0\n",
            "t mu-hat: [0.649118314534905, 0.21609387179680123, 0.520464283539572, 0.4109754301010113, 0.35863854852985905, 0.29994280617856334]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 416.440000000047\n",
            "0 4\n",
            "555.7935206958414 0 {(3, 0.4109754301010113), (2, 0.520464283539572), (0, 0.6490635685847391), (4, 0.35863854852985905)}\n",
            "\n",
            "t 7000\n",
            "t reward-arm: [496.71674673374525, 6.508536419733425, 129.03410716332598, 36.12152703656966, 21.54607406950747, 10.497998216249718]\n",
            "t numplay: [763.0, 29.0, 247.0, 87.0, 58.0, 34.0] 1218.0\n",
            "t mu-hat: [0.650152809860923, 0.21695121399111417, 0.5202988192069596, 0.410471898142837, 0.36518769609334695, 0.29994280617856334]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 423.19000000004803\n",
            "0 4\n",
            "635.3003241503225 0 {(3, 0.410471898142837), (2, 0.5202988192069596), (0, 0.6499199033083813), (4, 0.36518769609334695)}\n",
            "\n",
            "t 7100\n",
            "t reward-arm: [562.4085498099746, 6.508536419733426, 129.03410716332598, 36.12152703656966, 21.54607406950747, 10.497998216249718]\n",
            "t numplay: [863.0, 29.0, 247.0, 87.0, 58.0, 34.0] 1318.0\n",
            "t mu-hat: [0.6509358215393225, 0.2169512139911142, 0.5202988192069596, 0.410471898142837, 0.36518769609334695, 0.29994280617856334]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 428.19000000004917\n",
            "0 4\n",
            "717.6746047283094 0 {(3, 0.410471898142837), (2, 0.5202988192069596), (0, 0.6510232413085769), (4, 0.36518769609334695)}\n",
            "\n",
            "t 7200\n",
            "t reward-arm: [624.275594234299, 6.863502922653133, 129.03410716332598, 36.728337966542995, 22.23979605978055, 10.497998216249718]\n",
            "t numplay: [959.0, 30.0, 247.0, 89.0, 59.0, 34.0] 1418.0\n",
            "t mu-hat: [0.6502870773273948, 0.22140332008558494, 0.5202988192069596, 0.40809264407269996, 0.37066326766300917, 0.29994280617856334]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 434.2900000000502\n",
            "0 4\n",
            "798.1502987315214 0 {(3, 0.40809264407269996), (2, 0.5202988192069595), (0, 0.6502583091458534), (4, 0.37066326766300917)}\n",
            "\n",
            "t 7300\n",
            "t reward-arm: [689.2277649338364, 6.863502922653133, 129.03410716332598, 36.728337966542995, 22.23979605978055, 10.497998216249716]\n",
            "t numplay: [1059.0, 30.0, 247.0, 89.0, 59.0, 34.0] 1518.0\n",
            "t mu-hat: [0.6502148725790909, 0.22140332008558494, 0.5202988192069596, 0.40809264407269996, 0.37066326766300917, 0.29994280617856334]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 439.29000000005135\n",
            "0 4\n",
            "880.3776714464877 0 {(3, 0.40809264407269996), (2, 0.5202988192069596), (0, 0.6500670246611256), (4, 0.37066326766300917)}\n",
            "\n",
            "t 7400\n",
            "t reward-arm: [751.1063021450416, 7.037540068432023, 130.88458571465117, 36.728337966542995, 22.23979605978055, 10.497998216249716]\n",
            "t numplay: [1155.0, 31.0, 250.0, 89.0, 59.0, 34.0] 1618.0\n",
            "t mu-hat: [0.6497459361116277, 0.2199231271385007, 0.5214525327276939, 0.40809264407269996, 0.37066326766300917, 0.29994280617856334]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 445.0400000000524\n",
            "0 4\n",
            "961.4710010742701 0 {(3, 0.40809264407269996), (2, 0.5214525327276939), (0, 0.6497945869739365), (4, 0.37066326766300917)}\n",
            "\n",
            "t 7500\n",
            "t reward-arm: [815.9689748411422, 7.037540068432023, 130.88458571465117, 36.728337966542995, 22.23979605978055, 10.497998216249716]\n",
            "t numplay: [1255.0, 31.0, 250.0, 89.0, 59.0, 34.0] 1718.0\n",
            "t mu-hat: [0.6496568271028202, 0.2199231271385007, 0.5214525327276939, 0.40809264407269996, 0.37066326766300917, 0.29994280617856334]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 450.0400000000535\n",
            "0 4\n",
            "1043.684676840061 0 {(3, 0.40809264407269996), (2, 0.5214525327276939), (0, 0.6497107068400928), (4, 0.37066326766300917)}\n",
            "\n",
            "t 7600\n",
            "t reward-arm: [877.7847988122053, 7.033219259922569, 131.34705518002832, 36.9462945824215, 24.469478615984464, 10.497998216249716]\n",
            "t numplay: [1349.0, 32.0, 251.0, 90.0, 62.0, 34.0] 1818.0\n",
            "t mu-hat: [0.650210962083115, 0.21312785636128995, 0.5212184729366203, 0.40600323716946707, 0.38840442247594387, 0.29994280617856334]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 455.79000000005453\n",
            "0 4\n",
            "1123.3001691296813 0 {(3, 0.40600323716946707), (2, 0.5212184729366203), (0, 0.6502352170247092), (4, 0.38840442247594387)}\n",
            "\n",
            "t 7700\n",
            "t reward-arm: [942.5094521361442, 7.033219259922569, 131.34705518002832, 37.24850042812288, 25.333174308186578, 10.497998216249716]\n",
            "t numplay: [1447.0, 32.0, 251.0, 91.0, 63.0, 34.0] 1918.0\n",
            "t mu-hat: [0.6509043177735803, 0.21312785636128995, 0.5212184729366203, 0.40487500465350956, 0.3958308485654153, 0.29994280617856334]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 461.5400000000556\n",
            "0 4\n",
            "1204.1167041313931 0 {(3, 0.40600323716946707), (2, 0.5212184729366203), (0, 0.6509043177735803), (4, 0.3958308485654153)}\n",
            "\n",
            "t 7800\n",
            "t reward-arm: [1004.8306506226091, 7.31217491986418, 131.7208035254682, 37.65933463935714, 25.333174308186578, 10.497998216249716]\n",
            "t numplay: [1544.0, 33.0, 252.0, 92.0, 63.0, 34.0] 2018.0\n",
            "t mu-hat: [0.6503758256457017, 0.21506396823129942, 0.5206355870571866, 0.4049390821436252, 0.3958308485654153, 0.29994280617856334]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 466.9900000000567\n",
            "0 4\n",
            "1285.850580065625 0 {(3, 0.4049390821436252), (2, 0.5206355870571866), (0, 0.6503762212529638), (4, 0.3958308485654153)}\n",
            "\n",
            "t 7900\n",
            "t reward-arm: [1066.8630548551776, 7.702107829885184, 131.72080352546817, 38.189140084837504, 25.921036622520365, 10.497998216249716]\n",
            "t numplay: [1639.0, 35.0, 252.0, 94.0, 64.0, 34.0] 2118.0\n",
            "t mu-hat: [0.6505262529604742, 0.2139474397190329, 0.5206355870571865, 0.40199094826144743, 0.3987851788080056, 0.29994280617856334]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 473.5400000000577\n",
            "0 4\n",
            "1365.6422947647159 0 {(3, 0.40199094826144743), (2, 0.5206355870571865), (0, 0.650565110223744), (4, 0.3987851788080056)}\n",
            "\n",
            "5, t 100\n",
            "t reward-arm: [0.45631704388048505, 2.6949352984580663, 8.955576474487309, 15.73344024736336, 24.70443775305392, 2.712561685780293]\n",
            "t numplay: [4.0, 8.0, 17.0, 26.0, 37.0, 8.0] 100.0\n",
            "t mu-hat: [0.09126340877609701, 0.2994372553842296, 0.49753202636040605, 0.5827200091616059, 0.6501167829751031, 0.301395742864477]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 9.550000000000006\n",
            "4 4\n",
            "57.429138153770126 0 {(3, 0.5840028927366969), (2, 0.49753202636040605), (1, 0.2994372553842296), (4, 0.6501167829751031)}\n",
            "\n",
            "t 200\n",
            "t reward-arm: [0.9194991486207627, 4.539466067946639, 13.890683607126489, 34.70763157513906, 57.217789940862716, 3.3164523943443975]\n",
            "t numplay: [7.0, 13.0, 27.0, 56.0, 86.0, 11.0] 200.0\n",
            "t mu-hat: [0.11493739357759533, 0.3242475762819028, 0.49609584311166033, 0.6089058171077029, 0.6576757464466979, 0.27637103286203313]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 16.60000000000003\n",
            "4 4\n",
            "122.84759216228134 0 {(3, 0.6089058171077029), (2, 0.49609584311166033), (1, 0.3242475762819028), (4, 0.6580913901070278)}\n",
            "\n",
            "t 300\n",
            "t reward-arm: [0.9194991486207625, 5.112939787279551, 18.945884548006376, 49.671875306383185, 97.18821945915546, 4.385661550024569]\n",
            "t numplay: [7.0, 15.0, 37.0, 81.0, 146.0, 14.0] 300.0\n",
            "t mu-hat: [0.11493739357759532, 0.3195587367049719, 0.49857590915806255, 0.605754576907112, 0.661144350062282, 0.29237743666830457]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 20.95000000000004\n",
            "4 4\n",
            "193.01939089863856 0 {(3, 0.6047196468766288), (2, 0.49857590915806255), (1, 0.3195587367049719), (4, 0.661144350062282)}\n",
            "\n",
            "t 400\n",
            "t reward-arm: [1.6257366764904517, 5.76460696610768, 21.663527463080904, 68.20992984970998, 133.43341422651002, 5.693961644214376]\n",
            "t numplay: [10.0, 17.0, 43.0, 111.0, 202.0, 17.0] 400.0\n",
            "t mu-hat: [0.1477942433173138, 0.3202559425615378, 0.49235289688820233, 0.6090172308009819, 0.6573074592438918, 0.3163312024563542]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 26.300000000000054\n",
            "4 4\n",
            "263.5101776524886 0 {(3, 0.6084858971007585), (2, 0.49235289688820233), (1, 0.3202559425615378), (4, 0.6573074592438918)}\n",
            "\n",
            "t 500\n",
            "t reward-arm: [1.6257366764904517, 6.34655343345133, 24.23756899140152, 83.46134484755638, 173.8984919916864, 7.00477307314098]\n",
            "t numplay: [10.0, 19.0, 49.0, 137.0, 265.0, 20.0] 500.0\n",
            "t mu-hat: [0.1477942433173138, 0.3173276716725665, 0.4847513798280304, 0.6047923539677998, 0.6537537292920541, 0.3335606225305228]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 30.050000000000068\n",
            "4 4\n",
            "336.15866149860096 0 {(3, 0.6047923539677998), (2, 0.48818256945552274), (1, 0.3173276716725665), (4, 0.6537537292920541)}\n",
            "\n",
            "t 600\n",
            "t reward-arm: [1.8553777496717552, 6.88952640423433, 25.02225031120779, 96.68019807100477, 219.0846871264602, 8.37780566818208]\n",
            "t numplay: [12.0, 21.0, 51.0, 159.0, 334.0, 23.0] 600.0\n",
            "t mu-hat: [0.14272136535936578, 0.31316029110156046, 0.4811971213693806, 0.6042512379437798, 0.6539841406760006, 0.34907523617425334]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 34.00000000000003\n",
            "4 4\n",
            "409.2716006231551 0 {(3, 0.6042512379437797), (2, 0.4811971213693806), (1, 0.31316029110156046), (4, 0.6542117399678619)}\n",
            "\n",
            "t 700\n",
            "t reward-arm: [1.8553777496717552, 6.8895264042343305, 31.187321538556475, 105.2717453445993, 266.78149384362274, 9.095041921949717]\n",
            "t numplay: [12.0, 21.0, 62.0, 174.0, 406.0, 25.0] 700.0\n",
            "t mu-hat: [0.14272136535936578, 0.31316029110156046, 0.4950368498183567, 0.6015528305405674, 0.6554827858565669, 0.34980930469037375]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 36.94999999999997\n",
            "4 4\n",
            "483.35573317615376 0 {(3, 0.6015528305405674), (2, 0.4950368498183567), (1, 0.31316029110156046), (4, 0.6552518036583792)}\n",
            "\n",
            "t 800\n",
            "t reward-arm: [2.1963847769887783, 7.140872716430181, 31.601122427782837, 109.74459052128192, 326.268955516357, 9.603351215997426]\n",
            "t numplay: [13.0, 22.0, 63.0, 182.0, 494.0, 26.0] 800.0\n",
            "t mu-hat: [0.1568846269277699, 0.3104727268013122, 0.4937675379341068, 0.5996972159632892, 0.6591292030633474, 0.35567967466657135]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 38.599999999999945\n",
            "4 4\n",
            "561.4866618189939 0 {(3, 0.5996972159632892), (2, 0.49376753793410677), (1, 0.3104727268013122), (4, 0.6593136120607285)}\n",
            "\n",
            "t 900\n",
            "t reward-arm: [2.1963847769887783, 7.424350127172529, 33.59798116735602, 121.20580968794164, 375.45198198683954, 9.926510891646856]\n",
            "t numplay: [13.0, 23.0, 67.0, 201.0, 569.0, 27.0] 900.0\n",
            "t mu-hat: [0.1568846269277699, 0.309347921965522, 0.49408795834347086, 0.6000287608313942, 0.6586876876962097, 0.35451824613024485]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 40.94999999999988\n",
            "4 4\n",
            "637.934004472217 0 {(3, 0.5998819078701472), (2, 0.49408795834347086), (1, 0.309347921965522), (4, 0.6586876876962097)}\n",
            "\n",
            "t 1000\n",
            "t reward-arm: [2.1963847769887783, 7.424350127172529, 35.15703337971419, 139.60911404685032, 419.335014903989, 10.163822038085897]\n",
            "t numplay: [13.0, 23.0, 70.0, 230.0, 636.0, 28.0] 1000.0\n",
            "t mu-hat: [0.1568846269277699, 0.309347921965522, 0.4951694842213267, 0.6043684590772741, 0.6582967266938603, 0.350476622002962]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 42.999999999999794\n",
            "4 4\n",
            "715.1117586920785 0 {(3, 0.604368459077274), (2, 0.4951694842213267), (1, 0.309347921965522), (4, 0.6582624767891784)}\n",
            "\n",
            "t 1100\n",
            "t reward-arm: [2.507243678068344, 7.6780005560495646, 38.35732347793998, 150.86748599683563, 466.2055026561914, 10.163822038085897]\n",
            "t numplay: [14.0, 24.0, 76.0, 249.0, 709.0, 28.0] 1100.0\n",
            "t mu-hat: [0.16714957853788961, 0.3071200222419826, 0.49814705815506466, 0.6034699439873425, 0.6566274685298471, 0.350476622002962]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 45.649999999999736\n",
            "4 4\n",
            "791.6170220743879 0 {(3, 0.6034699439873425), (2, 0.49814705815506466), (1, 0.3071200222419826), (4, 0.656908003142969)}\n",
            "\n",
            "t 1200\n",
            "t reward-arm: [2.507243678068344, 7.6780005560495646, 38.76728262988243, 160.10384272968568, 522.0472602312725, 10.547266894518042]\n",
            "t numplay: [14.0, 24.0, 77.0, 264.0, 792.0, 29.0] 1200.0\n",
            "t mu-hat: [0.16714957853788961, 0.3071200222419826, 0.49701644397285166, 0.6041654442629648, 0.6583193697746186, 0.3515755631506014]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 46.84999999999969\n",
            "4 4\n",
            "870.7024577040997 0 {(3, 0.6041654442629648), (2, 0.49701644397285166), (1, 0.3071200222419826), (4, 0.6583016927664739)}\n",
            "\n",
            "t 1300\n",
            "t reward-arm: [2.969983717231532, 7.944063733361044, 39.57978735741392, 167.7326067212612, 575.6745207820506, 10.922977078731211]\n",
            "t numplay: [16.0, 25.0, 79.0, 277.0, 873.0, 30.0] 1300.0\n",
            "t mu-hat: [0.1747049245430313, 0.3055409128215786, 0.494747341967674, 0.6033547004361913, 0.6586664997506301, 0.35235409931391004]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 49.34999999999965\n",
            "4 4\n",
            "948.1825639396653 0 {(3, 0.6033547004361913), (2, 0.494747341967674), (1, 0.3055409128215786), (4, 0.6584752848725317)}\n",
            "\n",
            "t 1400\n",
            "t reward-arm: [2.969983717231532, 7.944063733361044, 41.1799334140383, 173.550907895587, 632.2159781597552, 10.922977078731211]\n",
            "t numplay: [16.0, 25.0, 82.0, 287.0, 960.0, 30.0] 1400.0\n",
            "t mu-hat: [0.1747049245430313, 0.3055409128215786, 0.4961437760727506, 0.6026073190818992, 0.6578730261808067, 0.35235409931391004]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 50.29999999999962\n",
            "4 4\n",
            "1028.0409871348554 0 {(3, 0.6026073190818992), (2, 0.4961437760727506), (1, 0.3055409128215786), (4, 0.6579179464677319)}\n",
            "\n",
            "t 1500\n",
            "t reward-arm: [3.163214983039194, 7.944063733361045, 42.75517991077347, 190.6152504295808, 676.4617935018719, 11.206562169652923]\n",
            "t numplay: [17.0, 25.0, 85.0, 314.0, 1028.0, 31.0] 1500.0\n",
            "t mu-hat: [0.17573416572439968, 0.30554091282157864, 0.4971532547764357, 0.6051277791415264, 0.6573972725965713, 0.35020506780165384]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 52.84999999999954\n",
            "4 4\n",
            "1104.9943543331076 0 {(3, 0.6051277791415264), (2, 0.4971532547764357), (1, 0.30554091282157864), (4, 0.6573777008285739)}\n",
            "\n",
            "t 1600\n",
            "t reward-arm: [3.163214983039195, 7.944063733361045, 43.62692328889053, 202.17509802100136, 726.8742093166727, 11.206562169652923]\n",
            "t numplay: [17.0, 25.0, 87.0, 333.0, 1107.0, 31.0] 1600.0\n",
            "t mu-hat: [0.1757341657243997, 0.30554091282157864, 0.49576049191921057, 0.605314664733537, 0.6560236546179357, 0.35020506780165384]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 54.14999999999948\n",
            "4 4\n",
            "1184.0904009795452 0 {(3, 0.6053350804874336), (2, 0.4957604919192105), (1, 0.30554091282157864), (4, 0.6560236546179357)}\n",
            "\n",
            "t 1700\n",
            "t reward-arm: [3.300432926633989, 8.225555101545208, 45.86855336466447, 214.12485383059922, 773.2692372416427, 11.549679742083432]\n",
            "t numplay: [18.0, 26.0, 91.0, 353.0, 1180.0, 32.0] 1700.0\n",
            "t mu-hat: [0.173706996138631, 0.3046501889461188, 0.4985712322246138, 0.6048724684480205, 0.6547580332274705, 0.34999029521464947]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 56.84999999999942\n",
            "4 4\n",
            "1260.7346169404107 0 {(3, 0.6048724684480205), (2, 0.4985712322246138), (1, 0.3046501889461188), (4, 0.6547962006501754)}\n",
            "\n",
            "t 1800\n",
            "t reward-arm: [3.783663559890059, 8.550242092952107, 48.63190564119006, 221.52542816093995, 823.4552229806886, 11.549679742083434]\n",
            "t numplay: [21.0, 27.0, 96.0, 366.0, 1258.0, 32.0] 1800.0\n",
            "t mu-hat: [0.17198470726772996, 0.30536578903400385, 0.5013598519710315, 0.6036115208744958, 0.6540549825104754, 0.3499902952146495]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 59.89999999999939\n",
            "4 4\n",
            "1337.1075945266166 0 {(3, 0.6036115208744958), (2, 0.5013598519710315), (1, 0.30536578903400385), (4, 0.6539105954844856)}\n",
            "\n",
            "t 1900\n",
            "t reward-arm: [3.783663559890059, 8.550242092952107, 50.13920674904969, 227.8162505450952, 877.6633879323117, 11.93687977602686]\n",
            "t numplay: [21.0, 27.0, 99.0, 377.0, 1343.0, 33.0] 1900.0\n",
            "t mu-hat: [0.17198470726772996, 0.30536578903400385, 0.5013920674904969, 0.6026884935055429, 0.6530233541163033, 0.35108469929490765]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 61.19999999999935\n",
            "4 4\n",
            "1415.8827013150428 0 {(3, 0.6026884935055429), (2, 0.5013920674904969), (1, 0.30536578903400385), (4, 0.653029779257932)}\n",
            "\n",
            "t 2000\n",
            "t reward-arm: [4.0840324372610874, 9.60435067806548, 51.76506144289016, 232.4009059113647, 933.30298841791, 11.93687977602686]\n",
            "t numplay: [22.0, 30.0, 102.0, 385.0, 1428.0, 33.0] 2000.0\n",
            "t mu-hat: [0.1775666277070038, 0.30981776380856385, 0.5025734120668948, 0.6020748857807375, 0.6531161570454234, 0.35108469929490765]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 63.99999999999933\n",
            "4 0\n",
            "1493.1887504842318 0 {(3, 0.6020748857807375), (2, 0.5025734120668948), (1, 0.30981776380856385), (4, 0.6530746603966944)}\n",
            "\n",
            "Arm 4 Changepoint Detected at time 2040\n",
            "t 2100\n",
            "t reward-arm: [4.0840324372610874, 9.60435067806548, 76.7330307384653, 238.0035526120821, 3.5381840834947234, 12.285160756985633]\n",
            "t numplay: [22.0, 30.0, 147.0, 405.0, 17.0, 35.0] 656.0\n",
            "t mu-hat: [0.1775666277070038, 0.30981776380856385, 0.5184664239085494, 0.5862156468277885, 0.1965657824163735, 0.34125446547182314]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 94.39999999999979\n",
            "3 0\n",
            "28.723160407942114 0 {(3, 0.5862156468277885), (2, 0.518086583284881), (1, 0.30981776380856385)}\n",
            "\n",
            "t 2200\n",
            "t reward-arm: [4.0840324372610874, 58.08429418995095, 83.81698859490264, 240.17286660204996, 4.484620179750789, 12.356928741248504]\n",
            "t numplay: [22.0, 105.0, 160.0, 413.0, 20.0, 36.0] 756.0\n",
            "t mu-hat: [0.1775666277070038, 0.5479650395278391, 0.5206024136329357, 0.5801276971064009, 0.2135533418928947, 0.3339710470607704]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 105.0999999999997\n",
            "3 0\n",
            "73.5527715816823 0 {(3, 0.5801276971064009), (2, 0.5206024136329357), (1, 0.5481065073110484)}\n",
            "\n",
            "t 2300\n",
            "t reward-arm: [4.0840324372610874, 121.05643134215859, 83.81698859490265, 240.17286660205, 4.484620179750789, 12.356928741248502]\n",
            "t numplay: [22.0, 205.0, 160.0, 413.0, 20.0, 36.0] 856.0\n",
            "t mu-hat: [0.1775666277070038, 0.5876525793308669, 0.5206024136329357, 0.580127697106401, 0.2135533418928947, 0.33397104706077035]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 110.09999999999941\n",
            "1 0\n",
            "135.9790406969455 0 {(3, 0.580127697106401), (2, 0.5206024136329357), (1, 0.5872553192804459)}\n",
            "\n",
            "t 2400\n",
            "t reward-arm: [5.717820521792639, 181.97959860334828, 85.6926586702255, 240.17286660204996, 4.77236850367662, 12.356928741248502]\n",
            "t numplay: [24.0, 299.0, 163.0, 413.0, 21.0, 36.0] 956.0\n",
            "t mu-hat: [0.22871282087170555, 0.606598662011161, 0.522516211403814, 0.5801276971064009, 0.21692584107621, 0.33397104706077035]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 115.69999999999916\n",
            "1 0\n",
            "205.4921467091694 0 {(3, 0.5801276971064009), (2, 0.522516211403814), (1, 0.6068921103662159)}\n",
            "\n",
            "t 2500\n",
            "t reward-arm: [5.717820521792639, 249.19384732092936, 85.69265867022551, 240.17286660204996, 4.77236850367662, 12.356928741248506]\n",
            "t numplay: [24.0, 399.0, 163.0, 413.0, 21.0, 36.0] 1056.0\n",
            "t mu-hat: [0.22871282087170555, 0.6229846183023234, 0.5225162114038141, 0.5801276971064009, 0.21692584107621, 0.3339710470607704]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 120.69999999999888\n",
            "1 0\n",
            "280.2900908676073 0 {(3, 0.5801276971064009), (2, 0.5225162114038141), (1, 0.6233718901564399)}\n",
            "\n",
            "t 2600\n",
            "t reward-arm: [7.174799214942109, 311.97281583739164, 86.21026204451415, 240.41449998646036, 4.77236850367662, 12.356928741248506]\n",
            "t numplay: [26.0, 495.0, 164.0, 414.0, 21.0, 36.0] 1156.0\n",
            "t mu-hat: [0.2657333042571151, 0.6289774512850638, 0.5224864366334191, 0.5793120481601455, 0.21692584107621, 0.3339710470607704]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 126.04999999999862\n",
            "1 0\n",
            "355.73020262042166 0 {(3, 0.5793120481601455), (2, 0.5224864366334191), (1, 0.6289395453275836)}\n",
            "\n",
            "t 2700\n",
            "t reward-arm: [8.502281941357605, 373.41701147466006, 86.7578587217409, 241.18418368816447, 4.77236850367662, 12.356928741248506]\n",
            "t numplay: [28.0, 589.0, 165.0, 417.0, 21.0, 36.0] 1256.0\n",
            "t mu-hat: [0.2931821359088829, 0.6329101889401018, 0.5226377031430175, 0.5769956547563744, 0.21692584107621, 0.3339710470607704]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 132.09999999999914\n",
            "1 0\n",
            "432.2956100765427 0 {(3, 0.5769956547563744), (2, 0.5226377031430175), (1, 0.6330167561273826), (0, 0.2931821359088829)}\n",
            "\n",
            "Arm 1 Changepoint Detected at time 2710\n",
            "t 2800\n",
            "t reward-arm: [8.502281941357605, 56.50639776489932, 86.75785872174092, 241.18418368816452, 4.77236850367662, 12.356928741248506]\n",
            "t numplay: [28.0, 90.0, 165.0, 417.0, 21.0, 36.0] 757.0\n",
            "t mu-hat: [0.2931821359088829, 0.6209494259879046, 0.5226377031430176, 0.5769956547563745, 0.21692584107621, 0.3339710470607704]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 137.10000000000028\n",
            "1 0\n",
            "62.94657858606262 0 {(3, 0.5769956547563745), (2, 0.5226377031430176), (1, 0.6216460359852227), (0, 0.2931821359088829)}\n",
            "\n",
            "t 2900\n",
            "t reward-arm: [8.502281941357605, 117.2752708288256, 89.66943348159293, 241.18418368816447, 4.958809841254858, 12.356928741248504]\n",
            "t numplay: [28.0, 184.0, 170.0, 417.0, 22.0, 36.0] 857.0\n",
            "t mu-hat: [0.2931821359088829, 0.6339203828585167, 0.5243826519391399, 0.5769956547563744, 0.215600427880646, 0.3339710470607704]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 143.00000000000136\n",
            "1 0\n",
            "139.64380380328433 0 {(3, 0.5769956547563744), (2, 0.5243826519391399), (1, 0.6336075564146827), (0, 0.2931821359088829)}\n",
            "\n",
            "t 3000\n",
            "t reward-arm: [8.502281941357605, 180.9037456288681, 89.66943348159293, 241.18418368816447, 4.958809841254858, 12.356928741248504]\n",
            "t numplay: [28.0, 284.0, 170.0, 417.0, 22.0, 36.0] 957.0\n",
            "t mu-hat: [0.2931821359088829, 0.6347499846626952, 0.5243826519391399, 0.5769956547563744, 0.215600427880646, 0.3339710470607704]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 148.0000000000025\n",
            "1 0\n",
            "218.51760183834463 0 {(3, 0.5769956547563744), (2, 0.5243826519391399), (1, 0.634446286909334), (0, 0.2931821359088829)}\n",
            "\n",
            "t 3100\n",
            "t reward-arm: [8.502281941357605, 241.45712034576167, 91.3261425793222, 241.18418368816447, 5.5205462094059286, 12.356928741248504]\n",
            "t numplay: [28.0, 379.0, 173.0, 417.0, 24.0, 36.0] 1057.0\n",
            "t mu-hat: [0.2931821359088829, 0.6354134745941097, 0.5248628883869092, 0.5769956547563744, 0.22082184837623714, 0.3339710470607704]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 154.10000000000358\n",
            "1 0\n",
            "295.5143063344583 0 {(3, 0.5769956547563744), (2, 0.5248628883869092), (1, 0.6351321223520436), (0, 0.2931821359088829)}\n",
            "\n",
            "t 3200\n",
            "t reward-arm: [8.502281941357605, 306.75053026592076, 91.32614257932221, 241.18418368816447, 5.5205462094059286, 12.356928741248504]\n",
            "t numplay: [28.0, 479.0, 173.0, 417.0, 24.0, 36.0] 1157.0\n",
            "t mu-hat: [0.2931821359088829, 0.6390636047206683, 0.5248628883869092, 0.5769956547563744, 0.22082184837623714, 0.3339710470607704]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 159.1000000000047\n",
            "1 0\n",
            "374.8054506199299 0 {(3, 0.5769956547563744), (2, 0.5248628883869092), (1, 0.6390897193231229), (0, 0.2931821359088829)}\n",
            "\n",
            "t 3300\n",
            "t reward-arm: [9.084532840442439, 370.36089164178776, 91.80048713752299, 241.1841836881645, 5.731623904105258, 12.356928741248504]\n",
            "t numplay: [29.0, 576.0, 174.0, 417.0, 25.0, 36.0] 1257.0\n",
            "t mu-hat: [0.3028177613480813, 0.6418732957396668, 0.5245742122144171, 0.5769956547563744, 0.22044707323481763, 0.3339710470607704]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 164.5500000000058\n",
            "1 0\n",
            "453.1650657474479 0 {(3, 0.5769956547563744), (2, 0.5245742122144171), (1, 0.6418578051622339), (0, 0.3028177613480813)}\n",
            "\n",
            "t 3400\n",
            "t reward-arm: [9.084532840442439, 435.54966198477456, 91.80048713752298, 241.1841836881645, 5.731623904105258, 12.356928741248504]\n",
            "t numplay: [29.0, 676.0, 174.0, 417.0, 25.0, 36.0] 1357.0\n",
            "t mu-hat: [0.3028177613480813, 0.6433525287810555, 0.524574212214417, 0.5769956547563744, 0.22044707323481763, 0.3339710470607704]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 169.55000000000695\n",
            "1 0\n",
            "533.3304177402559 0 {(3, 0.5769956547563744), (2, 0.524574212214417), (1, 0.6435669928089081), (0, 0.3028177613480813)}\n",
            "\n",
            "t 3500\n",
            "t reward-arm: [9.084532840442439, 497.53943452395265, 93.47743446971509, 241.1841836881645, 6.212186394204103, 12.356928741248506]\n",
            "t numplay: [29.0, 771.0, 177.0, 417.0, 27.0, 36.0] 1457.0\n",
            "t mu-hat: [0.3028177613480813, 0.6444811328030475, 0.5251541262343544, 0.5769956547563744, 0.2218637997930037, 0.3339710470607704]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 175.65000000000802\n",
            "1 0\n",
            "612.0328037897598 0 {(3, 0.5769956547563744), (2, 0.5251541262343544), (1, 0.64467885241686), (0, 0.3028177613480813)}\n",
            "\n",
            "t 3600\n",
            "t reward-arm: [9.084532840442439, 560.435588642543, 94.66122249615006, 241.4055131950023, 6.706238809462651, 12.356928741248506]\n",
            "t numplay: [29.0, 866.0, 179.0, 418.0, 29.0, 36.0] 1557.0\n",
            "t mu-hat: [0.3028177613480813, 0.6464078300375352, 0.525895680534167, 0.5761468095346117, 0.22354129364875502, 0.3339710470607704]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 182.0000000000091\n",
            "1 0\n",
            "691.1689929892312 0 {(3, 0.5761468095346117), (2, 0.525895680534167), (1, 0.6464511590630666), (0, 0.3028177613480813)}\n",
            "\n",
            "t 3700\n",
            "t reward-arm: [9.084532840442439, 627.7547070043189, 94.66122249615006, 241.40551319500233, 6.706238809462651, 12.356928741248504]\n",
            "t numplay: [29.0, 966.0, 179.0, 418.0, 29.0, 36.0] 1657.0\n",
            "t mu-hat: [0.3028177613480813, 0.6491775667056038, 0.525895680534167, 0.5761468095346117, 0.22354129364875502, 0.3339710470607704]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 187.00000000001023\n",
            "1 0\n",
            "772.3506996216171 0 {(3, 0.5761468095346117), (2, 0.525895680534167), (1, 0.6492272803080449), (0, 0.3028177613480813)}\n",
            "\n",
            "t 3800\n",
            "t reward-arm: [10.558999219673735, 689.402999180731, 94.98217617291911, 241.87371504774364, 6.915490204389354, 12.356928741248504]\n",
            "t numplay: [31.0, 1061.0, 180.0, 419.0, 30.0, 36.0] 1757.0\n",
            "t mu-hat: [0.3299687256148042, 0.6491553664601987, 0.5247634042702713, 0.575889797732723, 0.22308032917385012, 0.3339710470607704]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 192.7500000000113\n",
            "1 0\n",
            "851.7563845038044 0 {(3, 0.575889797732723), (2, 0.5247634042702713), (1, 0.6492757669871901), (0, 0.3299687256148042)}\n",
            "\n",
            "t 3900\n",
            "t reward-arm: [10.558999219673735, 755.3297410567934, 94.98217617291911, 241.87371504774362, 6.915490204389354, 12.356928741248504]\n",
            "t numplay: [31.0, 1161.0, 180.0, 419.0, 30.0, 36.0] 1857.0\n",
            "t mu-hat: [0.3299687256148042, 0.6500255947132474, 0.5247634042702713, 0.5758897977327229, 0.22308032917385012, 0.3339710470607704]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 197.75000000001245\n",
            "1 0\n",
            "933.3257789994847 0 {(3, 0.5758897977327229), (2, 0.5247634042702713), (1, 0.6501292368361962), (0, 0.3299687256148042)}\n",
            "\n",
            "t 4000\n",
            "t reward-arm: [10.558999219673735, 817.4298093840284, 96.00096831318521, 242.6756686806107, 7.520470647045335, 12.356928741248504]\n",
            "t numplay: [31.0, 1255.0, 182.0, 421.0, 32.0, 36.0] 1957.0\n",
            "t mu-hat: [0.3299687256148042, 0.6508199119299589, 0.5245954552633072, 0.5750608262573713, 0.2278930499104647, 0.3339710470607704]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 204.45000000001352\n",
            "1 3\n",
            "1013.1598173073177 0 {(3, 0.5750608262573712), (2, 0.5245954552633072), (1, 0.650808410221479), (0, 0.3299687256148042)}\n",
            "\n",
            "t 4100\n",
            "t reward-arm: [10.558999219673735, 892.7340186651579, 96.00096831318521, 242.67566868061067, 7.520470647045336, 12.356928741248504]\n",
            "t numplay: [31.0, 1355.0, 182.0, 421.0, 32.0, 36.0] 2057.0\n",
            "t mu-hat: [0.3299687256148042, 0.6583584208445118, 0.5245954552633072, 0.5750608262573712, 0.22789304991046472, 0.3339710470607704]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 209.45000000001465\n",
            "1 3\n",
            "1095.728253019368 0 {(3, 0.5750608262573712), (2, 0.5245954552633072), (1, 0.658186205852811), (0, 0.3299687256148042)}\n",
            "\n",
            "t 4200\n",
            "t reward-arm: [11.048387959289158, 964.5835894318556, 96.33248317785727, 243.3905617785427, 7.90210102975155, 12.356928741248504]\n",
            "t numplay: [33.0, 1450.0, 183.0, 422.0, 33.0, 36.0] 2157.0\n",
            "t mu-hat: [0.3249525870379164, 0.6647715985057585, 0.5235461042274852, 0.575391399003647, 0.23241473616916322, 0.3339710470607704]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 216.18000000001572\n",
            "1 3\n",
            "1177.5421292130015 0 {(3, 0.575391399003647), (2, 0.5235461042274852), (1, 0.6648379980501187), (0, 0.3249525870379164)}\n",
            "\n",
            "t 4300\n",
            "t reward-arm: [11.048387959289158, 1038.2244440179488, 96.33248317785727, 243.39056177854266, 8.79687553943472, 12.356928741248504]\n",
            "t numplay: [33.0, 1547.0, 183.0, 422.0, 36.0, 36.0] 2257.0\n",
            "t mu-hat: [0.3249525870379164, 0.6706876253345923, 0.5235461042274852, 0.575391399003647, 0.2377533929576951, 0.3339710470607704]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 222.48000000001682\n",
            "1 3\n",
            "1260.6578501268148 0 {(3, 0.575391399003647), (2, 0.5235461042274852), (1, 0.6706876253345923), (0, 0.3249525870379164)}\n",
            "\n",
            "t 4400\n",
            "t reward-arm: [11.309502291818838, 1110.9620438017528, 96.33248317785727, 244.72429876467436, 8.79687553943472, 12.356928741248504]\n",
            "t numplay: [34.0, 1644.0, 183.0, 424.0, 36.0, 36.0] 2357.0\n",
            "t mu-hat: [0.32312863690910965, 0.6753568655329804, 0.5235461042274852, 0.5758218794462926, 0.2377533929576951, 0.3339710470607704]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 227.98000000001792\n",
            "1 3\n",
            "1346.0793954116286 0 {(3, 0.5758218794462926), (2, 0.5235461042274853), (1, 0.6753543577593618), (0, 0.32312863690910965)}\n",
            "\n",
            "t 4500\n",
            "t reward-arm: [11.50363469455326, 1180.7633622255976, 97.37571165042156, 246.49700932827943, 9.066458284463277, 12.356928741248504]\n",
            "t numplay: [35.0, 1738.0, 185.0, 426.0, 37.0, 36.0] 2457.0\n",
            "t mu-hat: [0.319545408182035, 0.6789898575190325, 0.5235253314538794, 0.5772763684503032, 0.2385910074858757, 0.3339710470607704]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 234.340000000019\n",
            "1 3\n",
            "1431.0337448886328 0 {(3, 0.5772763684503032), (2, 0.5235253314538794), (1, 0.6789360579293244), (0, 0.319545408182035)}\n",
            "\n",
            "t 4600\n",
            "t reward-arm: [11.50363469455326, 1255.1135406761734, 97.37571165042158, 246.49700932827943, 9.066458284463277, 12.356928741248502]\n",
            "t numplay: [35.0, 1838.0, 185.0, 426.0, 37.0, 36.0] 2557.0\n",
            "t mu-hat: [0.319545408182035, 0.6824978470234766, 0.5235253314538795, 0.5772763684503032, 0.2385910074858757, 0.33397104706077035]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 239.34000000002013\n",
            "1 3\n",
            "1518.7947015661975 0 {(3, 0.5772763684503032), (2, 0.5235253314538795), (1, 0.6824594398837297), (0, 0.319545408182035)}\n",
            "\n",
            "t 4700\n",
            "t reward-arm: [11.822457691594124, 1324.3445082965623, 97.94512801154676, 246.4970093282794, 9.62393117703718, 12.356928741248502]\n",
            "t numplay: [37.0, 1933.0, 186.0, 426.0, 39.0, 36.0] 2657.0\n",
            "t mu-hat: [0.3111173076735296, 0.6847696526869504, 0.5237707380296618, 0.5772763684503031, 0.2405982794259295, 0.33397104706077035]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 246.5700000000212\n",
            "1 3\n",
            "1604.3116341767134 0 {(3, 0.5772763684503031), (2, 0.5237707380296618), (1, 0.6847590180435758), (0, 0.3111173076735296)}\n",
            "\n",
            "t 4800\n",
            "t reward-arm: [11.822457691594124, 1399.6157699619027, 97.94512801154676, 246.4970093282794, 9.62393117703718, 12.356928741248502]\n",
            "t numplay: [37.0, 2033.0, 186.0, 426.0, 39.0, 36.0] 2757.0\n",
            "t mu-hat: [0.3111173076735296, 0.6881100147305323, 0.5237707380296618, 0.5772763684503031, 0.2405982794259295, 0.33397104706077035]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 251.57000000002233\n",
            "1 3\n",
            "1693.1786595756207 0 {(3, 0.5772763684503031), (2, 0.5237707380296618), (1, 0.6880591051832846), (0, 0.3111173076735296)}\n",
            "\n",
            "Arm 1 Changepoint Detected at time 4870\n",
            "t 4900\n",
            "t reward-arm: [11.822457691594124, 22.045650452670344, 98.49975235070491, 248.60947547928006, 10.192707061669042, 12.356928741248504]\n",
            "t numplay: [37.0, 30.0, 187.0, 429.0, 41.0, 36.0] 760.0\n",
            "t mu-hat: [0.3111173076735296, 0.7111500146022691, 0.5239348529292814, 0.5781615708820467, 0.24268350146831053, 0.3339710470607704]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 257.5500000000234\n",
            "1 3\n",
            "22.627555073180734 0 {(3, 0.5781615708820467), (2, 0.5239348529292814), (1, 0.7055005405558694), (0, 0.3111173076735296)}\n",
            "\n",
            "t 5000\n",
            "t reward-arm: [11.822457691594124, 97.09686421197348, 98.49975235070494, 248.60947547928, 10.192707061669042, 12.356928741248506]\n",
            "t numplay: [37.0, 130.0, 187.0, 429.0, 41.0, 36.0] 860.0\n",
            "t mu-hat: [0.3111173076735296, 0.741197436732622, 0.5239348529292815, 0.5781615708820466, 0.24268350146831053, 0.3339710470607704]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 262.5500000000245\n",
            "1 3\n",
            "119.99409480341961 0 {(3, 0.5781615708820466), (2, 0.5239348529292815), (1, 0.7413976489740184), (0, 0.3111173076735296)}\n",
            "\n",
            "t 5100\n",
            "t reward-arm: [11.873816568454256, 167.4711203229924, 99.04622271206674, 250.18484831406943, 10.44186261871303, 12.356928741248506]\n",
            "t numplay: [38.0, 225.0, 188.0, 431.0, 42.0, 36.0] 960.0\n",
            "t mu-hat: [0.3044568350885707, 0.7410226562964265, 0.5240540884236335, 0.5791315933196052, 0.2428340143886751, 0.3339710470607704]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 268.6800000000256\n",
            "1 3\n",
            "218.17720794838525 0 {(3, 0.5791315933196052), (2, 0.5240540884236335), (1, 0.7415897524223184), (0, 0.3044568350885707)}\n",
            "\n",
            "t 5200\n",
            "t reward-arm: [11.873816568454256, 238.50573198214602, 99.62105605019713, 250.87911745232935, 11.161245817925566, 12.356928741248506]\n",
            "t numplay: [38.0, 321.0, 189.0, 432.0, 44.0, 36.0] 1060.0\n",
            "t mu-hat: [0.3044568350885707, 0.7407010310004535, 0.5243213476326164, 0.5793974998899061, 0.24802768484279036, 0.3339710470607704]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 274.76000000002665\n",
            "1 3\n",
            "316.34999301565614 0 {(3, 0.5793974998899061), (2, 0.5243213476326164), (1, 0.7406498547485496), (0, 0.3044568350885707)}\n",
            "\n",
            "t 5300\n",
            "t reward-arm: [11.873816568454256, 314.0811503857585, 99.62105605019713, 250.87911745232935, 11.161245817925566, 12.356928741248506]\n",
            "t numplay: [38.0, 421.0, 189.0, 432.0, 44.0, 36.0] 1160.0\n",
            "t mu-hat: [0.3044568350885707, 0.744268128876205, 0.5243213476326164, 0.5793974998899061, 0.24802768484279036, 0.3339710470607704]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 279.7600000000278\n",
            "1 3\n",
            "416.4818973662407 0 {(3, 0.5793974998899061), (2, 0.5243213476326164), (1, 0.7442637894622848), (0, 0.3044568350885707)}\n",
            "\n",
            "t 5400\n",
            "t reward-arm: [12.24502121373889, 386.0788245581485, 99.62105605019711, 252.5418987186682, 11.511189539035797, 12.356928741248506]\n",
            "t numplay: [41.0, 515.0, 189.0, 434.0, 45.0, 36.0] 1260.0\n",
            "t mu-hat: [0.2915481241366402, 0.7482147762754816, 0.5243213476326164, 0.5805560890084326, 0.25024325084860427, 0.3339710470607704]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 286.7600000000289\n",
            "1 3\n",
            "514.2600719316289 0 {(3, 0.5805560890084326), (2, 0.5243213476326164), (1, 0.7479241522837019), (0, 0.2915481241366402)}\n",
            "\n",
            "t 5500\n",
            "t reward-arm: [12.24502121373889, 459.7420136612667, 99.62105605019713, 252.5418987186682, 11.511189539035797, 12.356928741248506]\n",
            "t numplay: [41.0, 615.0, 189.0, 434.0, 45.0, 36.0] 1360.0\n",
            "t mu-hat: [0.2915481241366402, 0.7463344377617965, 0.5243213476326164, 0.5805560890084326, 0.25024325084860427, 0.3339710470607704]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 291.76000000003006\n",
            "1 3\n",
            "615.2489699990455 0 {(3, 0.5805560890084326), (2, 0.5243213476326164), (1, 0.7465906281614699), (0, 0.2915481241366402)}\n",
            "\n",
            "t 5600\n",
            "t reward-arm: [12.657575265970399, 530.600948636431, 99.62105605019713, 253.6859005388778, 11.815575921811138, 12.356928741248506]\n",
            "t numplay: [43.0, 710.0, 189.0, 436.0, 46.0, 36.0] 1460.0\n",
            "t mu-hat: [0.2876721651356909, 0.7462741893620689, 0.5243213476326164, 0.580516934871574, 0.2513952323789604, 0.3339710470607704]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 298.2100000000312\n",
            "1 3\n",
            "713.8074858459663 0 {(3, 0.580516934871574), (2, 0.5243213476326164), (1, 0.7461418300637908), (0, 0.2876721651356909)}\n",
            "\n",
            "t 5700\n",
            "t reward-arm: [12.657575265970399, 604.1102374795646, 99.62105605019713, 253.68590053887777, 11.815575921811138, 12.356928741248506]\n",
            "t numplay: [43.0, 810.0, 189.0, 436.0, 46.0, 36.0] 1560.0\n",
            "t mu-hat: [0.2876721651356909, 0.7448954839452091, 0.5243213476326164, 0.5805169348715739, 0.2513952323789604, 0.3339710470607704]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 303.2100000000323\n",
            "1 3\n",
            "814.4885402965185 0 {(3, 0.5805169348715739), (2, 0.5243213476326164), (1, 0.7448543698726373), (0, 0.2876721651356909)}\n",
            "\n",
            "t 5800\n",
            "t reward-arm: [13.388290371661217, 675.2032834259733, 99.62105605019713, 254.327630487647, 11.815575921811138, 12.356928741248504]\n",
            "t numplay: [47.0, 905.0, 189.0, 437.0, 46.0, 36.0] 1660.0\n",
            "t mu-hat: [0.27892271607627533, 0.7452574872251361, 0.5243213476326164, 0.5806566906110663, 0.2513952323789604, 0.3339710470607704]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 310.3600000000335\n",
            "1 3\n",
            "912.2391970840814 0 {(3, 0.5806566906110663), (2, 0.5243213476326164), (1, 0.7454134166365208)}\n",
            "\n",
            "t 5900\n",
            "t reward-arm: [13.388290371661217, 750.7542001189934, 99.62105605019713, 254.327630487647, 11.815575921811138, 12.356928741248504]\n",
            "t numplay: [47.0, 1005.0, 189.0, 437.0, 46.0, 36.0] 1760.0\n",
            "t mu-hat: [0.27892271607627533, 0.7462765408737508, 0.5243213476326164, 0.5806566906110663, 0.2513952323789604, 0.3339710470607704]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 315.36000000003463\n",
            "1 3\n",
            "1012.9640380449664 0 {(3, 0.5806566906110663), (2, 0.5243213476326164), (1, 0.7461001653801388)}\n",
            "\n",
            "t 6000\n",
            "t reward-arm: [13.576009384311167, 822.338595608471, 100.11554624421655, 255.22117699235866, 12.36587157249703, 12.356928741248504]\n",
            "t numplay: [49.0, 1099.0, 190.0, 438.0, 48.0, 36.0] 1860.0\n",
            "t mu-hat: [0.2715201876862233, 0.7475805414622464, 0.5241651635822856, 0.5813694236727988, 0.25236472596932713, 0.3339710470607704]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 322.9900000000357\n",
            "1 4\n",
            "1110.643853558852 0 {(3, 0.5813694236727988), (2, 0.5241651635822856), (1, 0.747604326054114)}\n",
            "\n",
            "Arm 1 Changepoint Detected at time 6010\n",
            "t 6100\n",
            "t reward-arm: [14.131155111406223, 3.0355424642937785, 124.64932372110869, 262.3142953174513, 12.365871572497031, 12.776647947460232]\n",
            "t numplay: [50.0, 19.0, 235.0, 461.0, 48.0, 38.0] 851.0\n",
            "t mu-hat: [0.27708147277267103, 0.15177712321468892, 0.5281751005131724, 0.5677798599944833, 0.2523647259693272, 0.32760635762718543]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 354.4900000000342\n",
            "3 4\n",
            "45.8637439822011 0 {(3, 0.5677798599944833), (2, 0.5288221440151929)}\n",
            "\n",
            "t 6200\n",
            "t reward-arm: [14.131155111406223, 3.0355424642937785, 168.52123813444177, 267.98108582091083, 12.365871572497031, 13.117920464814338]\n",
            "t numplay: [50.0, 19.0, 314.0, 480.0, 48.0, 40.0] 951.0\n",
            "t mu-hat: [0.27708147277267103, 0.15177712321468892, 0.5349880575696564, 0.5571332345549082, 0.2523647259693272, 0.319949279629618]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 374.79000000003197\n",
            "3 4\n",
            "104.76441389196282 0 {(3, 0.5571332345549082), (2, 0.5358672771437024)}\n",
            "\n",
            "Arm 3 Changepoint Detected at time 6230\n",
            "t 6300\n",
            "t reward-arm: [14.724627671596874, 3.199321060875712, 196.15501662292752, 12.308555618571988, 13.946373723372638, 13.228423110039076]\n",
            "t numplay: [51.0, 20.0, 365.0, 39.0, 50.0, 41.0] 566.0\n",
            "t mu-hat: [0.28316591676147834, 0.15234862194646248, 0.5359426683686545, 0.3077138904642997, 0.27345830830142426, 0.3149624550009304]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 401.14000000002983\n",
            "2 4\n",
            "23.287409229267062 0 {(3, 0.3077138904642997), (2, 0.5359944958753232), (0, 0.28316591676147834)}\n",
            "\n",
            "t 6400\n",
            "t reward-arm: [14.724627671596874, 3.199321060875712, 249.7205961772463, 12.991744690941907, 13.946373723372638, 13.409966338647543]\n",
            "t numplay: [51.0, 20.0, 462.0, 41.0, 50.0, 42.0] 666.0\n",
            "t mu-hat: [0.28316591676147834, 0.15234862194646248, 0.539353339475694, 0.3093272545462359, 0.27345830830142426, 0.3118596822941289]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 417.0400000000276\n",
            "2 4\n",
            "82.34023484718517 0 {(3, 0.3093272545462359), (2, 0.5391267831529408), (0, 0.28316591676147834)}\n",
            "\n",
            "t 6500\n",
            "t reward-arm: [15.31000773228794, 3.439081385040965, 299.0302566891026, 13.477514386084065, 15.438258568180885, 13.801860176670711]\n",
            "t numplay: [52.0, 21.0, 554.0, 43.0, 52.0, 44.0] 766.0\n",
            "t mu-hat: [0.28886807042052715, 0.15632188113822568, 0.5387932552956803, 0.30630714513827423, 0.2912878975128469, 0.3067080039260158]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 433.2900000000255\n",
            "2 4\n",
            "139.75546853251348 0 {(3, 0.30630714513827423), (2, 0.5390579019725107), (0, 0.28886807042052715), (4, 0.2912878975128469)}\n",
            "\n",
            "t 6600\n",
            "t reward-arm: [15.31000773228794, 3.439081385040965, 354.00042885200935, 13.769045330815167, 15.438258568180885, 13.801860176670711]\n",
            "t numplay: [52.0, 21.0, 653.0, 44.0, 52.0, 44.0] 866.0\n",
            "t mu-hat: [0.28886807042052715, 0.15632188113822568, 0.5412850594067421, 0.30597878512922594, 0.2912878975128469, 0.3067080039260158]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 448.5400000000232\n",
            "2 4\n",
            "200.63811368495908 0 {(3, 0.30597878512922594), (2, 0.541241790511305), (0, 0.28886807042052715), (4, 0.2912878975128469)}\n",
            "\n",
            "t 6700\n",
            "t reward-arm: [15.31000773228794, 3.5523130170846446, 405.06066819583714, 14.905335243799945, 16.06845753440591, 14.039521249080392]\n",
            "t numplay: [52.0, 22.0, 747.0, 47.0, 53.0, 45.0] 966.0\n",
            "t mu-hat: [0.28886807042052715, 0.15444839204715846, 0.5415249574810657, 0.31052781757916553, 0.29756402841492424, 0.3052069836756607]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 464.890000000021\n",
            "2 4\n",
            "259.5352800444348 0 {(3, 0.31052781757916553), (2, 0.5412951258524324), (0, 0.28886807042052715), (4, 0.29756402841492424)}\n",
            "\n",
            "t 6800\n",
            "t reward-arm: [15.31000773228794, 3.5523130170846446, 458.8309671831882, 15.162849042620985, 16.06845753440591, 14.116234358855024]\n",
            "t numplay: [52.0, 22.0, 845.0, 48.0, 53.0, 46.0] 1066.0\n",
            "t mu-hat: [0.28886807042052715, 0.15444839204715846, 0.5423533891054234, 0.3094458988289997, 0.29756402841492424, 0.30034541189053243]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 480.5400000000188\n",
            "2 4\n",
            "320.5589540865844 0 {(3, 0.3094458988289997), (2, 0.5424604841436178), (0, 0.28886807042052715), (4, 0.29756402841492424)}\n",
            "\n",
            "t 6900\n",
            "t reward-arm: [15.31000773228794, 3.872369850747951, 511.2541147142235, 15.162849042620984, 18.13278050099555, 14.116234358855024]\n",
            "t numplay: [52.0, 24.0, 940.0, 48.0, 56.0, 46.0] 1166.0\n",
            "t mu-hat: [0.28886807042052715, 0.15489479402991804, 0.5433093673902482, 0.30944589882899964, 0.3181189561578167, 0.30034541189053243]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 495.7900000000166\n",
            "2 4\n",
            "380.45697061397226 0 {(3, 0.30944589882899964), (2, 0.5432626485543448), (0, 0.28886807042052715), (4, 0.3181189561578167)}\n",
            "\n",
            "t 7000\n",
            "t reward-arm: [15.91308560669156, 3.872369850747951, 562.833496433796, 15.91760644348454, 19.54685342115549, 14.116234358855024]\n",
            "t numplay: [53.0, 24.0, 1034.0, 51.0, 58.0, 46.0] 1266.0\n",
            "t mu-hat: [0.29468677049428815, 0.15489479402991804, 0.5438004796461797, 0.30610781622085653, 0.3313026003585676, 0.30034541189053243]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 511.1400000000144\n",
            "2 4\n",
            "440.1601300430249 0 {(3, 0.30610781622085653), (2, 0.5438756525509679), (0, 0.29468677049428815), (4, 0.3313026003585676)}\n",
            "\n",
            "t 7100\n",
            "t reward-arm: [15.91308560669156, 3.872369850747951, 618.4230392717229, 15.917606443484543, 19.54685342115549, 14.226616559838662]\n",
            "t numplay: [53.0, 24.0, 1133.0, 51.0, 58.0, 47.0] 1366.0\n",
            "t mu-hat: [0.29468677049428815, 0.15489479402991804, 0.5453465954777098, 0.3061078162208566, 0.3313026003585676, 0.2963878449966388]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 526.5400000000121\n",
            "2 4\n",
            "502.4706385738385 0 {(3, 0.3061078162208566), (2, 0.5453319677713062), (0, 0.29468677049428815), (4, 0.3313026003585676)}\n",
            "\n",
            "t 7200\n",
            "t reward-arm: [17.25267816953155, 4.132966344393351, 653.6173577423401, 16.404302630560487, 43.55653562641319, 14.226616559838662]\n",
            "t numplay: [55.0, 25.0, 1194.0, 53.0, 92.0, 47.0] 1466.0\n",
            "t mu-hat: [0.3080835387416348, 0.15896024401512887, 0.5469601320019583, 0.30378338204741645, 0.46834984544530317, 0.2963878449966388]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 536.9400000000106\n",
            "2 4\n",
            "552.1819524947985 0 {(3, 0.30378338204741645), (2, 0.5469601320019583), (0, 0.3080835387416348), (4, 0.46419966125105894)}\n",
            "\n",
            "Arm 4 Changepoint Detected at time 7210\n",
            "t 7300\n",
            "t reward-arm: [17.25267816953155, 4.132966344393351, 653.6173577423401, 16.404302630560487, 63.085117158777294, 14.22661655983866]\n",
            "t numplay: [55.0, 25.0, 1194.0, 53.0, 90.0, 47.0] 1464.0\n",
            "t mu-hat: [0.3080835387416348, 0.15896024401512887, 0.5469601320019583, 0.30378338204741645, 0.6932430457008494, 0.2963878449966388]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 536.9400000000106\n",
            "4 4\n",
            "73.87940122959552 0 {(3, 0.30378338204741645), (2, 0.5469601320019583), (0, 0.3080835387416348), (4, 0.6925544030076383)}\n",
            "\n",
            "t 7400\n",
            "t reward-arm: [18.56327648471926, 4.659607335629811, 653.6173577423401, 16.404302630560487, 129.83595545798255, 14.22661655983866]\n",
            "t numplay: [57.0, 27.0, 1194.0, 53.0, 186.0, 47.0] 1564.0\n",
            "t mu-hat: [0.32005649111584933, 0.1664145477010647, 0.5469601320019583, 0.30378338204741645, 0.6943099222352008, 0.2963878449966388]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 538.0400000000105\n",
            "4 4\n",
            "165.06032065734215 0 {(3, 0.30378338204741645), (2, 0.5469601320019583), (0, 0.32005649111584933), (4, 0.6943862884479983)}\n",
            "\n",
            "t 7500\n",
            "t reward-arm: [18.56327648471926, 4.659607335629811, 653.6173577423401, 16.404302630560487, 199.54993677408635, 14.22661655983866]\n",
            "t numplay: [57.0, 27.0, 1194.0, 53.0, 286.0, 47.0] 1664.0\n",
            "t mu-hat: [0.32005649111584933, 0.1664145477010647, 0.5469601320019583, 0.30378338204741645, 0.6952959469480361, 0.2963878449966388]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 538.0400000000105\n",
            "4 4\n",
            "257.7744459873009 0 {(3, 0.30378338204741645), (2, 0.5469601320019583), (0, 0.32005649111584933), (4, 0.6955962656342232)}\n",
            "\n",
            "t 7600\n",
            "t reward-arm: [19.11682066875195, 5.112268098091096, 653.6173577423401, 17.125018380804697, 267.52075308205883, 14.22661655983866]\n",
            "t numplay: [58.0, 29.0, 1194.0, 55.0, 381.0, 47.0] 1764.0\n",
            "t mu-hat: [0.32401390963986354, 0.17040893660303655, 0.5469601320019583, 0.3058038996572267, 0.7003161075446567, 0.2963878449966388]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 539.8900000000104\n",
            "4 4\n",
            "348.4640059860918 0 {(3, 0.3058038996572267), (2, 0.5469601320019583), (0, 0.32401390963986354), (4, 0.6998807623102795)}\n",
            "\n",
            "t 7700\n",
            "t reward-arm: [19.11682066875195, 5.112268098091096, 653.6173577423401, 17.23376949148199, 338.54750061262166, 14.22661655983866]\n",
            "t numplay: [58.0, 29.0, 1194.0, 56.0, 480.0, 47.0] 1864.0\n",
            "t mu-hat: [0.32401390963986354, 0.17040893660303655, 0.5469601320019583, 0.30234683318389455, 0.7038409576145981, 0.2963878449966388]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 540.7900000000104\n",
            "4 4\n",
            "441.7601909384279 0 {(3, 0.30234683318389455), (2, 0.5469601320019583), (0, 0.32401390963986354), (4, 0.703862050416613)}\n",
            "\n",
            "t 7800\n",
            "t reward-arm: [19.11682066875195, 5.371647551683309, 653.6173577423402, 17.89156521448264, 406.9977825922795, 14.22661655983866]\n",
            "t numplay: [58.0, 31.0, 1194.0, 58.0, 576.0, 47.0] 1964.0\n",
            "t mu-hat: [0.32401390963986354, 0.1678639859901034, 0.5469601320019584, 0.3032468680420786, 0.7053687739900858, 0.2963878449966388]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 542.0900000000104\n",
            "4 4\n",
            "534.8945408340213 0 {(3, 0.3032468680420786), (2, 0.5469601320019583), (0, 0.32401390963986354), (4, 0.7052140533313547)}\n",
            "\n",
            "t 7900\n",
            "t reward-arm: [19.75571610822533, 5.7357162190025175, 655.526649144658, 17.891565214482643, 474.162778799068, 14.22661655983866]\n",
            "t numplay: [59.0, 32.0, 1197.0, 58.0, 671.0, 47.0] 2064.0\n",
            "t mu-hat: [0.3292619351370888, 0.17380958239401567, 0.5471841812559749, 0.3032468680420787, 0.7055993732128988, 0.2963878449966388]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 543.0900000000103\n",
            "4 4\n",
            "628.2869415410045 0 {(3, 0.3032468680420787), (2, 0.5471841812559749), (0, 0.3292619351370888), (4, 0.7055235026391145)}\n",
            "\n",
            "6, t 100\n",
            "t reward-arm: [1.1588088953753601, 2.6626257909065347, 7.489780734192464, 12.719692117117503, 26.13793961024809, 3.863961363073869]\n",
            "t numplay: [6.0, 8.0, 15.0, 22.0, 39.0, 10.0] 100.0\n",
            "t mu-hat: [0.16554412791076573, 0.29584731010072607, 0.468111295887029, 0.5530300920485871, 0.6534484902562022, 0.3512692148248972]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 10.550000000000006\n",
            "4 4\n",
            "56.68777207479779 0 {(3, 0.5530300920485871), (2, 0.468111295887029), (1, 0.29584731010072607), (4, 0.6515171945378655)}\n",
            "\n",
            "t 200\n",
            "t reward-arm: [1.5181811082664425, 3.761803322634878, 14.904118346955805, 28.09990522057701, 58.50915851927486, 5.174630005538523]\n",
            "t numplay: [8.0, 12.0, 29.0, 48.0, 89.0, 14.0] 200.0\n",
            "t mu-hat: [0.1686867898073825, 0.2893694863565291, 0.4968039448985268, 0.5734674534811635, 0.6501017613252762, 0.3449753337025682]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 17.600000000000026\n",
            "4 4\n",
            "118.65136292615928 0 {(3, 0.5734674534811635), (2, 0.4968039448985268), (1, 0.2893694863565291), (4, 0.6497255459044747)}\n",
            "\n",
            "t 300\n",
            "t reward-arm: [1.686159094663523, 4.227610923018021, 20.3514216113214, 43.603573583854576, 94.5299946823857, 6.566454153790397]\n",
            "t numplay: [9.0, 14.0, 40.0, 74.0, 145.0, 18.0] 300.0\n",
            "t mu-hat: [0.1686159094663523, 0.28184072820120143, 0.49637613686149756, 0.581380981118061, 0.6474657170026418, 0.34560285019949455]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 22.750000000000036\n",
            "4 4\n",
            "185.4253855314244 0 {(3, 0.581380981118061), (2, 0.4964753671859833), (1, 0.28184072820120143), (4, 0.6474657170026418)}\n",
            "\n",
            "t 400\n",
            "t reward-arm: [2.4390593036456063, 4.777800412310443, 23.277001886065648, 58.77444129647846, 135.2094942251402, 7.2898302878836]\n",
            "t numplay: [12.0, 16.0, 46.0, 99.0, 207.0, 20.0] 400.0\n",
            "t mu-hat: [0.1876199464342774, 0.28104708307708487, 0.4952553592779925, 0.5877444129647845, 0.650045645313174, 0.34713477561350475]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 27.700000000000045\n",
            "4 4\n",
            "254.665347173435 0 {(3, 0.5877444129647845), (2, 0.4952553592779925), (1, 0.28104708307708487), (4, 0.6507041232743067)}\n",
            "\n",
            "t 500\n",
            "t reward-arm: [2.4390593036456063, 5.234156375315334, 25.447724878420452, 68.3814984372936, 184.6049582088789, 7.8346512477480825]\n",
            "t numplay: [12.0, 17.0, 51.0, 116.0, 282.0, 22.0] 500.0\n",
            "t mu-hat: [0.1876199464342774, 0.29078646529529634, 0.4893793245850087, 0.5844572516008, 0.6523143399607029, 0.34063701077165576]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 30.100000000000055\n",
            "4 4\n",
            "328.45273268631007 0 {(3, 0.5844572516008), (2, 0.4893793245850087), (1, 0.29078646529529634), (4, 0.652225797958339)}\n",
            "\n",
            "t 600\n",
            "t reward-arm: [2.4390593036456063, 5.993267430462035, 29.064745735151277, 80.31843141956219, 229.71207734689855, 8.196499897175043]\n",
            "t numplay: [12.0, 19.0, 58.0, 136.0, 352.0, 23.0] 600.0\n",
            "t mu-hat: [0.1876199464342774, 0.29966337152310174, 0.4926228090703606, 0.5862659227705269, 0.6507424287447551, 0.34152082904896014]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 33.20000000000002\n",
            "4 4\n",
            "401.28973560352307 0 {(3, 0.5851210699266953), (2, 0.4926228090703606), (1, 0.29966337152310174), (4, 0.6507424287447551)}\n",
            "\n",
            "t 700\n",
            "t reward-arm: [2.7248553397428212, 6.3367641345777, 30.815245007913724, 94.00965101815137, 274.5353034944112, 8.767354170124985]\n",
            "t numplay: [13.0, 20.0, 62.0, 159.0, 421.0, 25.0] 700.0\n",
            "t mu-hat: [0.19463252426734437, 0.30175067307512854, 0.4891308731414877, 0.5875603188634461, 0.6505575912189839, 0.33720592962019175]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 36.29999999999995\n",
            "4 4\n",
            "474.6609551292372 0 {(3, 0.5879372315314606), (2, 0.4891308731414877), (1, 0.30175067307512854), (4, 0.6505575912189839)}\n",
            "\n",
            "t 800\n",
            "t reward-arm: [2.9382314722710476, 6.4901465641062925, 32.27710143810724, 109.71951820316107, 318.05435944596184, 8.767354170124985]\n",
            "t numplay: [15.0, 21.0, 65.0, 185.0, 489.0, 25.0] 800.0\n",
            "t mu-hat: [0.18363946701694048, 0.2950066620048315, 0.4890469914864733, 0.5898898828126939, 0.6490905294815548, 0.33720592962019175]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 39.299999999999876\n",
            "4 4\n",
            "548.7375945912594 0 {(3, 0.5913432337242868), (2, 0.4890469914864733), (1, 0.2950066620048315), (4, 0.6490905294815548)}\n",
            "\n",
            "t 900\n",
            "t reward-arm: [3.4859085542328696, 6.4901465641062925, 35.80457697935975, 125.95033948482892, 359.49320823720154, 9.072138083023527]\n",
            "t numplay: [17.0, 21.0, 72.0, 211.0, 553.0, 26.0] 900.0\n",
            "t mu-hat: [0.19366158634627054, 0.2950066620048315, 0.49047365725150344, 0.5941053749284383, 0.648904708009389, 0.33600511418605655]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 43.1999999999998\n",
            "4 4\n",
            "621.040047417699 0 {(3, 0.5941053749284383), (2, 0.49169020225330723), (1, 0.2950066620048315), (4, 0.648904708009389)}\n",
            "\n",
            "t 1000\n",
            "t reward-arm: [3.4859085542328696, 6.8858976922984905, 35.80457697935975, 137.06358048891042, 412.06539495787626, 9.530069316512659]\n",
            "t numplay: [17.0, 22.0, 72.0, 229.0, 633.0, 27.0] 1000.0\n",
            "t mu-hat: [0.19366158634627054, 0.29938685618689087, 0.49047365725150344, 0.5959286108213496, 0.6499454179146313, 0.3403596184468807]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 44.39999999999974\n",
            "4 4\n",
            "698.5251441423064 0 {(3, 0.5958591705057807), (2, 0.49047365725150344), (1, 0.29938685618689087), (4, 0.6499454179146313)}\n",
            "\n",
            "t 1100\n",
            "t reward-arm: [3.611322018337969, 7.539686282169122, 38.53685705781065, 146.87492953763413, 460.8371238432827, 9.728188043677445]\n",
            "t numplay: [18.0, 25.0, 77.0, 245.0, 707.0, 28.0] 1100.0\n",
            "t mu-hat: [0.19006957991252468, 0.2899879339295816, 0.4940622699719314, 0.5970525590960737, 0.6508998924340151, 0.33545476012680847]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 47.79999999999969\n",
            "4 4\n",
            "772.653377144125 0 {(3, 0.5970525590960737), (2, 0.4940622699719314), (1, 0.2899879339295816), (4, 0.6509597760716617)}\n",
            "\n",
            "t 1200\n",
            "t reward-arm: [3.6113220183379693, 7.539686282169122, 40.40460173047137, 157.3408100121389, 510.7858386242374, 9.728188043677445]\n",
            "t numplay: [18.0, 25.0, 81.0, 263.0, 785.0, 28.0] 1200.0\n",
            "t mu-hat: [0.1900695799125247, 0.2899879339295816, 0.4927390454935533, 0.5959879167126473, 0.649854756519386, 0.33545476012680847]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 49.24999999999964\n",
            "4 4\n",
            "850.1243112025394 0 {(3, 0.5963593017514868), (2, 0.4927390454935533), (1, 0.2899879339295816), (4, 0.649854756519386)}\n",
            "\n",
            "t 1300\n",
            "t reward-arm: [3.6113220183379693, 7.765336821570168, 42.75237422452407, 163.21623160098818, 566.5620030124119, 9.728188043677445]\n",
            "t numplay: [18.0, 26.0, 85.0, 273.0, 870.0, 28.0] 1300.0\n",
            "t mu-hat: [0.1900695799125247, 0.28760506746556175, 0.4971206305177217, 0.5956796773758692, 0.6504730229763627, 0.33545476012680847]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 50.7499999999996\n",
            "4 4\n",
            "927.6167818410628 0 {(3, 0.5957169799591534), (2, 0.4971206305177217), (1, 0.28760506746556175), (4, 0.6504730229763627)}\n",
            "\n",
            "t 1400\n",
            "t reward-arm: [3.6113220183379693, 7.765336821570169, 43.06993357177411, 166.58038836236983, 628.0189119484098, 10.017245464558654]\n",
            "t numplay: [18.0, 26.0, 86.0, 279.0, 962.0, 29.0] 1400.0\n",
            "t mu-hat: [0.1900695799125247, 0.2876050674655618, 0.4950567077215415, 0.5949299584370351, 0.6521484028540081, 0.3339081821519551]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 51.449999999999584\n",
            "4 4\n",
            "1007.0013326434193 0 {(3, 0.594929958437035), (2, 0.4950567077215415), (1, 0.2876050674655618), (4, 0.6522353495104902)}\n",
            "\n",
            "t 1500\n",
            "t reward-arm: [3.756274167979557, 8.50983646865272, 43.62596893895605, 177.8387431019479, 679.5876548209293, 10.017245464558654]\n",
            "t numplay: [19.0, 28.0, 87.0, 297.0, 1040.0, 29.0] 1500.0\n",
            "t mu-hat: [0.18781370839897785, 0.2934426368500938, 0.4957496470335915, 0.5967743057112346, 0.6528219546790868, 0.3339081821519551]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 53.64999999999954\n",
            "4 4\n",
            "1084.0248064757766 0 {(3, 0.5967743057112346), (2, 0.4957496470335915), (1, 0.2934426368500938), (4, 0.6528524042704311)}\n",
            "\n",
            "t 1600\n",
            "t reward-arm: [3.756274167979557, 8.50983646865272, 44.530346578179135, 194.7645178875444, 725.2509505055842, 10.017245464558654]\n",
            "t numplay: [19.0, 28.0, 89.0, 324.0, 1111.0, 29.0] 1600.0\n",
            "t mu-hat: [0.18781370839897785, 0.2934426368500938, 0.4947816286464348, 0.5992754396539828, 0.6522040921812807, 0.3339081821519551]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 55.29999999999946\n",
            "4 4\n",
            "1161.5956749359223 0 {(3, 0.5992754396539828), (2, 0.4947816286464348), (1, 0.2934426368500938), (4, 0.6522589463423459)}\n",
            "\n",
            "t 1700\n",
            "t reward-arm: [4.168377010531515, 8.50983646865272, 45.559105557443864, 198.64549211339903, 782.7883853480895, 10.270935784197903]\n",
            "t numplay: [21.0, 28.0, 91.0, 331.0, 1199.0, 30.0] 1700.0\n",
            "t mu-hat: [0.18947168229688705, 0.2934426368500938, 0.4952076691026507, 0.5983297955222863, 0.6523236544567412, 0.3313205091676743]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 57.199999999999434\n",
            "4 4\n",
            "1239.5192021251946 0 {(3, 0.5983297955222863), (2, 0.4952076691026507), (1, 0.2934426368500938), (4, 0.6523305096275589)}\n",
            "\n",
            "t 1800\n",
            "t reward-arm: [4.568246137875996, 8.78246119051313, 46.54400652761976, 203.7571496295226, 838.2238155235702, 10.270935784197903]\n",
            "t numplay: [24.0, 29.0, 93.0, 340.0, 1284.0, 30.0] 1800.0\n",
            "t mu-hat: [0.18272984551503985, 0.29274870635043765, 0.49514900561297615, 0.5975282980337906, 0.6523142533257356, 0.3313205091676743]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 59.59999999999942\n",
            "4 4\n",
            "1316.9783507508619 0 {(3, 0.5975282980337906), (2, 0.49514900561297615), (1, 0.29274870635043765), (4, 0.6523915271775588)}\n",
            "\n",
            "t 1900\n",
            "t reward-arm: [4.568246137875996, 8.78246119051313, 46.95700854436527, 205.11678106718546, 901.784654056519, 10.270935784197903]\n",
            "t numplay: [24.0, 29.0, 94.0, 343.0, 1380.0, 30.0] 1900.0\n",
            "t mu-hat: [0.18272984551503985, 0.29274870635043765, 0.4942843004670029, 0.5962697124046089, 0.6529939565941485, 0.3313205091676743]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 59.89999999999941\n",
            "4 4\n",
            "1397.7231479181112 0 {(3, 0.5962697124046089), (2, 0.4942843004670029), (1, 0.29274870635043765), (4, 0.6528485419978719)}\n",
            "\n",
            "t 2000\n",
            "t reward-arm: [5.02158852392098, 8.78246119051313, 48.04412536165373, 212.32102254739496, 955.5529969257251, 10.270935784197903]\n",
            "t numplay: [26.0, 29.0, 96.0, 355.0, 1464.0, 30.0] 2000.0\n",
            "t mu-hat: [0.18598476014522147, 0.29274870635043765, 0.4953002614603477, 0.5964073667061656, 0.6522546054100513, 0.3313205091676743]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 62.099999999999376\n",
            "4 0\n",
            "1475.8209931944573 0 {(3, 0.5964073667061656), (2, 0.4953002614603477), (1, 0.29274870635043765), (4, 0.6523143393625848)}\n",
            "\n",
            "Arm 4 Changepoint Detected at time 2050\n",
            "t 2100\n",
            "t reward-arm: [5.02158852392098, 8.78246119051313, 70.42367815817812, 216.38567146935756, 6.213410504982425, 10.3742077896888]\n",
            "t numplay: [26.0, 29.0, 136.0, 369.0, 23.0, 31.0] 614.0\n",
            "t mu-hat: [0.18598476014522147, 0.29274870635043765, 0.5140414464100592, 0.5848261391063718, 0.25889210437426774, 0.324193993427775]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 94.49999999999979\n",
            "3 0\n",
            "20.417140977990645 0 {(3, 0.5848261391063718), (2, 0.5152235577446946), (1, 0.29274870635043765)}\n",
            "\n",
            "t 2200\n",
            "t reward-arm: [5.673602482481445, 33.91814996683293, 88.33079954699227, 221.96869152122457, 6.6831656859884765, 10.699726749545976]\n",
            "t numplay: [27.0, 68.0, 171.0, 390.0, 25.0, 33.0] 714.0\n",
            "t mu-hat: [0.20262866008862304, 0.49156739082366563, 0.5135511601569318, 0.5676948632256383, 0.2570448340764799, 0.3146978455748816]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 111.74999999999999\n",
            "3 0\n",
            "66.23063529211414 0 {(3, 0.5676948632256383), (2, 0.5135511601569318), (1, 0.49066776889358)}\n",
            "\n",
            "t 2300\n",
            "t reward-arm: [5.673602482481445, 98.08580942147718, 88.33079954699224, 221.96869152122457, 6.683165685988476, 10.699726749545976]\n",
            "t numplay: [27.0, 168.0, 171.0, 390.0, 25.0, 33.0] 814.0\n",
            "t mu-hat: [0.20262866008862304, 0.5803894048608117, 0.5135511601569316, 0.5676948632256383, 0.2570448340764798, 0.3146978455748816]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 116.7499999999997\n",
            "1 0\n",
            "123.5077994766543 0 {(3, 0.5676948632256383), (2, 0.5135511601569316), (1, 0.5801683864540297)}\n",
            "\n",
            "t 2400\n",
            "t reward-arm: [6.227518851350734, 159.99566392296282, 89.52850734785316, 221.96869152122457, 7.067027495555131, 10.699726749545976]\n",
            "t numplay: [28.0, 263.0, 173.0, 390.0, 27.0, 33.0] 914.0\n",
            "t mu-hat: [0.21474202935692185, 0.6060441815263743, 0.5145316514244435, 0.5676948632256383, 0.25239383912696894, 0.3146978455748816]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 122.69999999999945\n",
            "1 0\n",
            "193.07998547582378 0 {(3, 0.5676948632256383), (2, 0.5145316514244436), (1, 0.6065597739471988)}\n",
            "\n",
            "t 2500\n",
            "t reward-arm: [6.227518851350734, 225.4780980795343, 89.52850734785318, 221.96869152122457, 7.067027495555131, 10.699726749545976]\n",
            "t numplay: [28.0, 363.0, 173.0, 390.0, 27.0, 33.0] 1014.0\n",
            "t mu-hat: [0.21474202935692185, 0.619445324394325, 0.5145316514244436, 0.5676948632256383, 0.25239383912696894, 0.3146978455748816]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 127.69999999999916\n",
            "1 0\n",
            "267.695474141578 0 {(3, 0.5676948632256383), (2, 0.5145316514244436), (1, 0.6193163622435303)}\n",
            "\n",
            "Arm 1 Changepoint Detected at time 2570\n",
            "t 2600\n",
            "t reward-arm: [7.592734957640987, 19.919918596271142, 90.0702711238331, 221.96869152122457, 7.52794216597716, 10.699726749545976]\n",
            "t numplay: [30.0, 30.0, 174.0, 390.0, 30.0, 33.0] 687.0\n",
            "t mu-hat: [0.2449269341174512, 0.6425780192345529, 0.5146872635647606, 0.5676948632256383, 0.24283684406377937, 0.3146978455748816]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 133.90000000000012\n",
            "1 0\n",
            "19.527801382288185 0 {(3, 0.5676948632256383), (2, 0.5146872635647606), (1, 0.6397652948922377)}\n",
            "\n",
            "t 2700\n",
            "t reward-arm: [8.94187962038138, 81.92820523928918, 90.0702711238331, 222.57913725566516, 7.695892647683448, 10.699726749545976]\n",
            "t numplay: [32.0, 125.0, 174.0, 392.0, 31.0, 33.0] 787.0\n",
            "t mu-hat: [0.2709660491024661, 0.6502238511054698, 0.5146872635647606, 0.5663591278770106, 0.24049664524010775, 0.3146978455748816]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 139.9000000000012\n",
            "1 0\n",
            "98.84354257978696 0 {(3, 0.5663591278770106), (2, 0.5146872635647606), (1, 0.6493428246852623)}\n",
            "\n",
            "t 2800\n",
            "t reward-arm: [8.94187962038138, 146.84812103602218, 90.0702711238331, 222.57913725566522, 7.695892647683448, 10.699726749545976]\n",
            "t numplay: [32.0, 225.0, 174.0, 392.0, 31.0, 33.0] 887.0\n",
            "t mu-hat: [0.2709660491024661, 0.649770447062045, 0.5146872635647606, 0.5663591278770107, 0.24049664524010775, 0.3146978455748816]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 144.90000000000234\n",
            "1 0\n",
            "180.47119162090226 0 {(3, 0.5663591278770107), (2, 0.5146872635647606), (1, 0.6502905785228791)}\n",
            "\n",
            "Arm 3 Changepoint Detected at time 2870\n",
            "t 2900\n",
            "t reward-arm: [8.94187962038138, 198.0232002707809, 91.11144384495711, 4.3291311744961245, 7.840337927284898, 10.699726749545976]\n",
            "t numplay: [32.0, 305.0, 176.0, 16.0, 32.0, 33.0] 594.0\n",
            "t mu-hat: [0.2709660491024661, 0.6471346414077808, 0.5147539200280062, 0.25465477497036026, 0.23758599779651204, 0.3146978455748816]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 156.45000000000334\n",
            "1 0\n",
            "15.967367363948366 0 {(2, 0.5147539200280062), (1, 0.6471976338686604)}\n",
            "\n",
            "t 3000\n",
            "t reward-arm: [8.94187962038138, 262.83634980467116, 91.11144384495711, 4.668072135975972, 7.840337927284897, 10.699726749545976]\n",
            "t numplay: [32.0, 404.0, 176.0, 17.0, 32.0, 33.0] 694.0\n",
            "t mu-hat: [0.2709660491024661, 0.6489786414930152, 0.5147539200280062, 0.259337340887554, 0.23758599779651202, 0.3146978455748816]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 161.80000000000447\n",
            "1 0\n",
            "96.86520921005769 0 {(2, 0.5147539200280062), (1, 0.6488760007655601)}\n",
            "\n",
            "t 3100\n",
            "t reward-arm: [9.638810532956565, 325.4488248380136, 91.11144384495711, 5.466267263015189, 8.27020478986686, 10.699726749545976]\n",
            "t numplay: [33.0, 498.0, 176.0, 20.0, 34.0, 33.0] 794.0\n",
            "t mu-hat: [0.283494427439899, 0.6522020537835944, 0.5147539200280062, 0.2602984410959614, 0.23629156542476742, 0.3146978455748816]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 168.60000000000554\n",
            "1 0\n",
            "175.60411613155503 0 {(2, 0.5147539200280062), (1, 0.6521014171108905), (0, 0.283494427439899)}\n",
            "\n",
            "t 3200\n",
            "t reward-arm: [9.638810532956565, 389.2958636915662, 91.11144384495711, 5.466267263015189, 8.270204789866861, 10.699726749545976]\n",
            "t numplay: [33.0, 598.0, 176.0, 20.0, 34.0, 33.0] 894.0\n",
            "t mu-hat: [0.283494427439899, 0.6499096221895929, 0.5147539200280062, 0.2602984410959614, 0.23629156542476748, 0.3146978455748816]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 173.60000000000667\n",
            "1 0\n",
            "257.60200210803475 0 {(2, 0.5147539200280062), (1, 0.6499482981998655), (0, 0.283494427439899)}\n",
            "\n",
            "t 3300\n",
            "t reward-arm: [10.226721786667806, 451.84362191492477, 91.73726484165775, 5.703015610550521, 8.720714038427538, 10.699726749545976]\n",
            "t numplay: [34.0, 693.0, 177.0, 21.0, 36.0, 33.0] 994.0\n",
            "t mu-hat: [0.2921920510476516, 0.6510715013183354, 0.5153778923688638, 0.25922798229775096, 0.23569497401155506, 0.3146978455748816]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 179.80000000000774\n",
            "1 0\n",
            "336.9876775885337 0 {(2, 0.5153778923688638), (1, 0.6509366051162845), (0, 0.2921920510476516)}\n",
            "\n",
            "t 3400\n",
            "t reward-arm: [10.226721786667806, 515.1621474423995, 91.73726484165775, 5.703015610550521, 8.720714038427538, 10.699726749545976]\n",
            "t numplay: [34.0, 793.0, 177.0, 21.0, 36.0, 33.0] 1094.0\n",
            "t mu-hat: [0.2921920510476516, 0.6488188254942059, 0.5153778923688638, 0.25922798229775096, 0.23569497401155506, 0.3146978455748816]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 184.80000000000888\n",
            "1 0\n",
            "418.803489158219 0 {(2, 0.5153778923688638), (1, 0.6488855804324744), (0, 0.2921920510476516)}\n",
            "\n",
            "t 3500\n",
            "t reward-arm: [10.878827800458623, 578.3242678284946, 91.73726484165775, 5.703015610550521, 9.206476506678726, 10.699726749545976]\n",
            "t numplay: [35.0, 890.0, 177.0, 21.0, 38.0, 33.0] 1194.0\n",
            "t mu-hat: [0.30218966112385065, 0.6490732523327661, 0.5153778923688638, 0.25922798229775096, 0.23606350017124939, 0.3146978455748816]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 190.55000000000996\n",
            "1 0\n",
            "498.7785672186688 0 {(2, 0.5153778923688638), (1, 0.6489961953934873), (0, 0.30218966112385065)}\n",
            "\n",
            "t 3600\n",
            "t reward-arm: [10.878827800458623, 641.5324409947943, 92.774332698933, 6.098607532605403, 9.206476506678726, 10.699726749545976]\n",
            "t numplay: [35.0, 987.0, 179.0, 22.0, 38.0, 33.0] 1294.0\n",
            "t mu-hat: [0.30218966112385065, 0.6493243329906825, 0.5154129594385166, 0.2651568492437132, 0.23606350017124939, 0.3146978455748816]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 196.10000000001108\n",
            "1 0\n",
            "579.3228760076216 0 {(2, 0.5154129594385166), (1, 0.6494263633221766), (0, 0.30218966112385065)}\n",
            "\n",
            "t 3700\n",
            "t reward-arm: [10.878827800458623, 705.4859164055149, 92.774332698933, 6.098607532605402, 9.206476506678726, 10.699726749545976]\n",
            "t numplay: [35.0, 1087.0, 179.0, 22.0, 38.0, 33.0] 1394.0\n",
            "t mu-hat: [0.30218966112385065, 0.6484245555197747, 0.5154129594385166, 0.26515684924371313, 0.23606350017124939, 0.3146978455748816]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 201.10000000001222\n",
            "1 0\n",
            "660.8765596772865 0 {(2, 0.5154129594385166), (1, 0.6484532093815986), (0, 0.30218966112385065)}\n",
            "\n",
            "t 3800\n",
            "t reward-arm: [13.221701758933815, 767.7871730023035, 93.31044712548756, 6.098607532605402, 9.349873282169234, 10.699726749545976]\n",
            "t numplay: [38.0, 1182.0, 180.0, 22.0, 39.0, 33.0] 1494.0\n",
            "t mu-hat: [0.33901799381881575, 0.6490170524110764, 0.5155273321850141, 0.26515684924371313, 0.23374683205423086, 0.3146978455748816]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 206.4500000000133\n",
            "1 0\n",
            "739.8029943093647 0 {(2, 0.5155273321850141), (1, 0.6488591582586846), (0, 0.33901799381881575)}\n",
            "\n",
            "t 3900\n",
            "t reward-arm: [13.221701758933815, 833.992086330454, 93.31044712548756, 6.098607532605402, 9.349873282169234, 10.699726749545976]\n",
            "t numplay: [38.0, 1282.0, 180.0, 22.0, 39.0, 33.0] 1594.0\n",
            "t mu-hat: [0.33901799381881575, 0.6500328030634871, 0.5155273321850141, 0.26515684924371313, 0.23374683205423086, 0.3146978455748816]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 211.45000000001443\n",
            "1 0\n",
            "821.4769597237935 0 {(2, 0.5155273321850141), (1, 0.6500066276843003), (0, 0.33901799381881575)}\n",
            "\n",
            "t 4000\n",
            "t reward-arm: [13.95895125501415, 897.1937211433668, 93.87248128677203, 6.512855425254833, 9.606861609531428, 10.699726749545976]\n",
            "t numplay: [39.0, 1378.0, 181.0, 23.0, 40.0, 33.0] 1694.0\n",
            "t mu-hat: [0.34897378137535373, 0.6506118354919266, 0.5157828642130331, 0.2713689760522847, 0.23431369779344946, 0.3146978455748816]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 217.25000000001552\n",
            "1 3\n",
            "901.3016724324967 0 {(2, 0.5157828642130331), (1, 0.6505009418759096), (0, 0.34897378137535373)}\n",
            "\n",
            "t 4100\n",
            "t reward-arm: [13.95895125501415, 970.9811938279777, 93.87248128677203, 6.512855425254833, 9.606861609531428, 10.699726749545976]\n",
            "t numplay: [39.0, 1478.0, 181.0, 23.0, 40.0, 33.0] 1794.0\n",
            "t mu-hat: [0.34897378137535373, 0.6565119633725339, 0.5157828642130331, 0.2713689760522847, 0.23431369779344946, 0.3146978455748816]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 222.25000000001666\n",
            "1 3\n",
            "983.7859551824934 0 {(2, 0.5157828642130331), (1, 0.6564587198973987), (0, 0.34897378137535373)}\n",
            "\n",
            "Arm 3 Changepoint Detected at time 4190\n",
            "t 4200\n",
            "t reward-arm: [14.597737381904366, 984.4973472020713, 93.87248128677201, 7.800330723272796, 10.302718989649222, 10.699726749545976]\n",
            "t numplay: [41.0, 1497.0, 181.0, 10.0, 42.0, 33.0] 1804.0\n",
            "t mu-hat: [0.34756517575962775, 0.6572078419239461, 0.5157828642130331, 0.7091209748429814, 0.239598116038354, 0.3146978455748816]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 225.35000000001685\n",
            "3 3\n",
            "5.888782828463811 0 {(3, 0.7080170701267682), (2, 0.5157828642130331), (1, 0.6572078419239461), (0, 0.34756517575962775)}\n",
            "\n",
            "t 4300\n",
            "t reward-arm: [15.088317814115793, 984.4973472020713, 93.87248128677201, 84.79587906583598, 10.302718989649224, 10.699726749545976]\n",
            "t numplay: [43.0, 1497.0, 181.0, 108.0, 42.0, 33.0] 1904.0\n",
            "t mu-hat: [0.34291631395717714, 0.6572078419239461, 0.5157828642130331, 0.777943844640697, 0.23959811603835404, 0.3146978455748816]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 226.55000000001684\n",
            "3 3\n",
            "110.89298086557399 0 {(3, 0.777943844640697), (2, 0.5157828642130331), (1, 0.6572078419239461), (0, 0.34638679501922287)}\n",
            "\n",
            "t 4400\n",
            "t reward-arm: [15.088317814115793, 985.21486080677, 93.87248128677203, 162.18815477598838, 10.605257166552352, 10.699726749545976]\n",
            "t numplay: [43.0, 1498.0, 181.0, 206.0, 43.0, 33.0] 2004.0\n",
            "t mu-hat: [0.34291631395717714, 0.6572480725862375, 0.5157828642130331, 0.7835176559226492, 0.24102857196709893, 0.3146978455748816]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 227.10000000001685\n",
            "3 3\n",
            "218.03689016386124 0 {(3, 0.7834586196373687), (2, 0.5157828642130331), (1, 0.6572480725862375), (0, 0.34291631395717714)}\n",
            "\n",
            "t 4500\n",
            "t reward-arm: [15.368824617021698, 986.7419070207052, 93.87248128677203, 239.02180360248235, 11.030433611816749, 10.699726749545976]\n",
            "t numplay: [44.0, 1500.0, 181.0, 302.0, 44.0, 33.0] 2104.0\n",
            "t mu-hat: [0.3415294359338155, 0.657389678228318, 0.5157828642130331, 0.788850836971889, 0.24512074692926109, 0.3146978455748816]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 228.30000000001687\n",
            "3 3\n",
            "325.549004881622 0 {(3, 0.7888303831946611), (2, 0.5157828642130331), (1, 0.657389678228318), (0, 0.3415294359338155)}\n",
            "\n",
            "t 4600\n",
            "t reward-arm: [15.368824617021698, 986.7419070207052, 93.872481286772, 319.8396210150513, 11.030433611816749, 10.699726749545976]\n",
            "t numplay: [44.0, 1500.0, 181.0, 402.0, 44.0, 33.0] 2204.0\n",
            "t mu-hat: [0.3415294359338155, 0.657389678228318, 0.515782864213033, 0.7936467022705987, 0.24512074692926109, 0.3146978455748816]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 228.30000000001687\n",
            "3 3\n",
            "435.54547438243895 0 {(3, 0.7935079309318329), (2, 0.515782864213033), (1, 0.657389678228318), (0, 0.3415294359338155)}\n",
            "\n",
            "t 4700\n",
            "t reward-arm: [15.3688246170217, 987.4356363626468, 94.4199507250077, 396.9210529008658, 11.35812120399923, 10.699726749545976]\n",
            "t numplay: [44.0, 1501.0, 182.0, 499.0, 45.0, 33.0] 2304.0\n",
            "t mu-hat: [0.3415294359338156, 0.6574138724118821, 0.5159560148907524, 0.7938421058017315, 0.24691567834780936, 0.3146978455748816]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 229.13000000001688\n",
            "3 3\n",
            "544.792340761751 0 {(3, 0.7938835317689379), (2, 0.5159560148907524), (1, 0.6574138724118821), (0, 0.3415294359338156)}\n",
            "\n",
            "t 4800\n",
            "t reward-arm: [15.3688246170217, 987.4356363626471, 94.4199507250077, 476.41877289098375, 11.358121203999232, 10.699726749545976]\n",
            "t numplay: [44.0, 1501.0, 182.0, 599.0, 45.0, 33.0] 2404.0\n",
            "t mu-hat: [0.3415294359338156, 0.6574138724118822, 0.5159560148907524, 0.7940312881516396, 0.2469156783478094, 0.3146978455748816]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 229.13000000001688\n",
            "3 3\n",
            "655.2687463468892 0 {(3, 0.7938880108308036), (2, 0.5159560148907525), (1, 0.6574138724118822), (0, 0.3415294359338155)}\n",
            "\n",
            "t 4900\n",
            "t reward-arm: [15.368824617021698, 989.0631044192318, 94.41995072500771, 553.5337451446584, 12.147323883376682, 10.699726749545976]\n",
            "t numplay: [44.0, 1503.0, 182.0, 695.0, 47.0, 33.0] 2504.0\n",
            "t mu-hat: [0.3415294359338155, 0.6576217449595956, 0.5159560148907525, 0.7953071050928999, 0.25306924757034754, 0.3146978455748816]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 230.2300000000169\n",
            "3 3\n",
            "764.2284225158897 0 {(3, 0.7954032436794121), (2, 0.5159560148907525), (1, 0.6576217449595956), (0, 0.3415294359338155)}\n",
            "\n",
            "t 5000\n",
            "t reward-arm: [15.3688246170217, 989.063104419232, 94.41995072500771, 633.3520699766717, 12.147323883376682, 10.699726749545976]\n",
            "t numplay: [44.0, 1503.0, 182.0, 795.0, 47.0, 33.0] 2604.0\n",
            "t mu-hat: [0.3415294359338156, 0.6576217449595957, 0.5159560148907525, 0.7956684296189344, 0.25306924757034754, 0.3146978455748816]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 230.2300000000169\n",
            "3 3\n",
            "874.97954227233 0 {(3, 0.7953592833510299), (2, 0.5159560148907525), (1, 0.6576217449595957), (0, 0.3415294359338156)}\n",
            "\n",
            "t 5100\n",
            "t reward-arm: [15.368824617021698, 990.5810181146078, 94.86621252794883, 710.3987498893207, 12.263070880036185, 10.699726749545976]\n",
            "t numplay: [44.0, 1505.0, 183.0, 891.0, 48.0, 33.0] 2704.0\n",
            "t mu-hat: [0.3415294359338155, 0.6577563201292216, 0.5155772419997219, 0.7964111545844402, 0.2502667526537997, 0.3146978455748816]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 231.11000000001692\n",
            "3 3\n",
            "984.5836373405765 0 {(3, 0.7964420734678381), (2, 0.5155772419997219), (1, 0.6577563201292216), (0, 0.3415294359338155)}\n",
            "\n",
            "t 5200\n",
            "t reward-arm: [15.368824617021698, 993.6286757533348, 95.2232434176745, 786.7162715009974, 12.263070880036185, 10.699726749545976]\n",
            "t numplay: [44.0, 1509.0, 184.0, 986.0, 48.0, 33.0] 2804.0\n",
            "t mu-hat: [0.3415294359338155, 0.658032235598235, 0.5147202346901324, 0.7970782892613956, 0.2502667526537997, 0.3146978455748816]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 231.59000000001697\n",
            "3 3\n",
            "1094.7407517081474 0 {(3, 0.7969067843712984), (2, 0.5147202346901324), (1, 0.658032235598235), (0, 0.3415294359338155)}\n",
            "\n",
            "t 5300\n",
            "t reward-arm: [15.368824617021698, 993.628675753335, 95.2232434176745, 866.919251761626, 12.263070880036185, 10.699726749545976]\n",
            "t numplay: [44.0, 1509.0, 184.0, 1086.0, 48.0, 33.0] 2904.0\n",
            "t mu-hat: [0.3415294359338155, 0.6580322355982351, 0.5147202346901324, 0.7975338102682852, 0.2502667526537997, 0.3146978455748816]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 231.59000000001697\n",
            "3 3\n",
            "1205.880128953971 0 {(3, 0.7975423809763351), (2, 0.5147202346901324), (1, 0.6580322355982351), (0, 0.3415294359338155)}\n",
            "\n",
            "t 5400\n",
            "t reward-arm: [15.368824617021698, 995.3966007940883, 95.57033522459227, 942.6489499862646, 12.808465509902964, 10.699726749545976]\n",
            "t numplay: [44.0, 1511.0, 185.0, 1181.0, 50.0, 33.0] 3004.0\n",
            "t mu-hat: [0.3415294359338155, 0.6583310851812754, 0.5138190065838294, 0.7975033417819497, 0.25114638254711696, 0.3146978455748816]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 232.970000000017\n",
            "3 3\n",
            "1315.043741455647 0 {(3, 0.7973974652077057), (2, 0.5138190065838294), (1, 0.6583310851812754), (0, 0.3415294359338155)}\n",
            "\n",
            "t 5500\n",
            "t reward-arm: [15.368824617021698, 995.3966007940883, 95.57033522459227, 1023.018866629634, 12.808465509902966, 10.699726749545976]\n",
            "t numplay: [44.0, 1511.0, 185.0, 1281.0, 50.0, 33.0] 3104.0\n",
            "t mu-hat: [0.3415294359338155, 0.6583310851812754, 0.5138190065838294, 0.7979866354365319, 0.25114638254711696, 0.3146978455748816]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 232.970000000017\n",
            "3 3\n",
            "1426.311883667709 0 {(3, 0.7978931446476963), (2, 0.5138190065838294), (1, 0.6583310851812754), (0, 0.3415294359338155)}\n",
            "\n",
            "t 5600\n",
            "t reward-arm: [15.368824617021698, 996.2181372795495, 96.31448328808015, 1100.5700933332112, 13.36452651945074, 10.699726749545976]\n",
            "t numplay: [44.0, 1512.0, 186.0, 1377.0, 52.0, 33.0] 3204.0\n",
            "t mu-hat: [0.3415294359338155, 0.6584389539190678, 0.5150507127704821, 0.798672056119892, 0.2521608777254857, 0.3146978455748816]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 234.300000000017\n",
            "3 3\n",
            "1535.6930243181953 0 {(3, 0.7986803588555021), (2, 0.5150507127704821), (1, 0.6584389539190678), (0, 0.3415294359338155)}\n",
            "\n",
            "t 5700\n",
            "t reward-arm: [15.368824617021698, 996.2181372795495, 96.31448328808015, 1181.5924053273461, 13.36452651945074, 10.699726749545976]\n",
            "t numplay: [44.0, 1512.0, 186.0, 1477.0, 52.0, 33.0] 3304.0\n",
            "t mu-hat: [0.3415294359338155, 0.6584389539190678, 0.5150507127704821, 0.7994535895313574, 0.2521608777254857, 0.3146978455748816]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 234.300000000017\n",
            "3 3\n",
            "1647.2486856750925 0 {(3, 0.7994164888909799), (2, 0.5150507127704821), (1, 0.6584389539190678), (0, 0.3415294359338155)}\n",
            "\n",
            "t 5800\n",
            "t reward-arm: [15.505748145025478, 997.0979536999793, 97.47394399943256, 1255.7831963107012, 14.294367054324008, 10.699726749545976]\n",
            "t numplay: [45.0, 1513.0, 188.0, 1571.0, 54.0, 33.0] 3404.0\n",
            "t mu-hat: [0.33708148141359734, 0.6585851741743588, 0.5157351534361512, 0.7988442724622781, 0.25989758280589104, 0.3146978455748816]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 236.51000000001702\n",
            "3 3\n",
            "1755.689861345144 0 {(3, 0.7989365421622587), (2, 0.5157351534361512), (1, 0.6585851741743588), (0, 0.33708148141359734)}\n",
            "\n",
            "t 5900\n",
            "t reward-arm: [15.505748145025478, 997.0979536999793, 97.47394399943256, 1335.1957796640158, 14.29436705432401, 10.699726749545976]\n",
            "t numplay: [45.0, 1513.0, 188.0, 1671.0, 54.0, 33.0] 3504.0\n",
            "t mu-hat: [0.33708148141359734, 0.6585851741743588, 0.5157351534361512, 0.798562069177043, 0.2598975828058911, 0.3146978455748816]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 236.51000000001702\n",
            "3 3\n",
            "1867.1384851646535 0 {(3, 0.7986353054512421), (2, 0.5157351534361512), (1, 0.6585851741743588), (0, 0.33708148141359734)}\n",
            "\n",
            "t 6000\n",
            "t reward-arm: [15.746950308390183, 997.7866459728599, 98.66056942743532, 1411.1319630060339, 14.29436705432401, 10.699726749545976]\n",
            "t numplay: [46.0, 1514.0, 190.0, 1767.0, 54.0, 33.0] 3604.0\n",
            "t mu-hat: [0.3350414959231954, 0.6586050468467722, 0.5165474839132739, 0.7981515627862182, 0.2598975828058911, 0.3146978455748816]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 238.12000000001703\n",
            "3 4\n",
            "1976.8544275062693 0 {(3, 0.7980195866579908), (2, 0.5165474839132739), (1, 0.6586050468467722), (0, 0.3350414959231954)}\n",
            "\n",
            "Arm 3 Changepoint Detected at time 6010\n",
            "Arm 1 Changepoint Detected at time 6060\n",
            "t 6100\n",
            "t reward-arm: [16.94722888424122, 3.2345006982491418, 103.07804594988835, 12.402574342452368, 15.075898153538606, 10.684908328499775]\n",
            "t numplay: [48.0, 18.0, 198.0, 38.0, 55.0, 34.0] 391.0\n",
            "t mu-hat: [0.34586181396410653, 0.170236878855218, 0.517980130401449, 0.3180147267295479, 0.2692124670274751, 0.3052830950999936]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 278.9200000000168\n",
            "2 4\n",
            "10.859761771125301 0 {(3, 0.3180147267295479), (2, 0.5175261807669885), (0, 0.34586181396410653)}\n",
            "\n",
            "t 6200\n",
            "t reward-arm: [16.94722888424122, 3.294710860194175, 154.0842320194386, 13.46781612955011, 15.075898153538606, 10.805232057752857]\n",
            "t numplay: [48.0, 19.0, 292.0, 41.0, 55.0, 36.0] 491.0\n",
            "t mu-hat: [0.34586181396410653, 0.16473554300970875, 0.5258847509195856, 0.32066228879881215, 0.2692124670274751, 0.2920332988581853]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 295.8200000000146\n",
            "2 4\n",
            "65.3445161437452 0 {(3, 0.32066228879881215), (2, 0.525807309488522), (0, 0.34586181396410653)}\n",
            "\n",
            "t 6300\n",
            "t reward-arm: [72.66020482975419, 3.4843992526445584, 160.04130896602447, 14.045514350325908, 15.075898153538606, 10.805232057752857]\n",
            "t numplay: [134.0, 20.0, 303.0, 43.0, 55.0, 36.0] 591.0\n",
            "t mu-hat: [0.5382237394796607, 0.16592377393545515, 0.5264516742303437, 0.31921623523467973, 0.2692124670274751, 0.2920332988581853]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 302.9700000000153\n",
            "0 4\n",
            "109.30193388758539 0 {(3, 0.31921623523467973), (2, 0.5264516742303437), (0, 0.5372040423210749)}\n",
            "\n",
            "Arm 0 Changepoint Detected at time 6320\n",
            "t 6400\n",
            "t reward-arm: [50.76953951642555, 3.484399252644559, 160.04130896602447, 14.045514350325908, 15.075898153538606, 10.805232057752857]\n",
            "t numplay: [80.0, 20.0, 303.0, 43.0, 55.0, 36.0] 537.0\n",
            "t mu-hat: [0.6267844384743896, 0.16592377393545518, 0.5264516742303437, 0.31921623523467973, 0.2692124670274751, 0.2920332988581853]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 307.97000000001646\n",
            "0 4\n",
            "60.36553105077852 0 {(3, 0.31921623523467973), (2, 0.5264516742303437), (0, 0.6275078189570524)}\n",
            "\n",
            "t 6500\n",
            "t reward-arm: [114.46778619064385, 3.614236628565684, 160.6168719439554, 14.045514350325908, 16.20054256597055, 10.805232057752857]\n",
            "t numplay: [176.0, 21.0, 304.0, 43.0, 57.0, 36.0] 637.0\n",
            "t mu-hat: [0.6467106564443156, 0.164283483116622, 0.5266126948982144, 0.31921623523467973, 0.2793196994132854, 0.2920332988581853]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 313.4200000000175\n",
            "0 4\n",
            "139.7460191166005 0 {(3, 0.31921623523467973), (2, 0.5266126948982144), (0, 0.6460340620717836)}\n",
            "\n",
            "t 6600\n",
            "t reward-arm: [179.426132680028, 3.614236628565684, 160.6168719439554, 14.045514350325908, 16.200542565970547, 10.805232057752857]\n",
            "t numplay: [276.0, 21.0, 304.0, 43.0, 57.0, 36.0] 737.0\n",
            "t mu-hat: [0.6477477714080433, 0.164283483116622, 0.5266126948982144, 0.31921623523467973, 0.27931969941328527, 0.2920332988581853]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 318.42000000001866\n",
            "0 4\n",
            "222.12483214641105 0 {(3, 0.31921623523467973), (2, 0.5266126948982144), (0, 0.6483130516992769)}\n",
            "\n",
            "t 6700\n",
            "t reward-arm: [242.0256785204329, 3.7921608622372, 161.71097982900292, 14.375503363401343, 16.90984691907512, 10.805232057752859]\n",
            "t numplay: [371.0, 22.0, 306.0, 44.0, 58.0, 36.0] 837.0\n",
            "t mu-hat: [0.6506066626893358, 0.16487655922770433, 0.5267458626351886, 0.3194556302978076, 0.28660757489957833, 0.29203329885818535]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 324.3700000000197\n",
            "0 4\n",
            "302.5806011675102 0 {(3, 0.3194556302978076), (2, 0.5267458626351886), (0, 0.6505205334057894), (4, 0.28660757489957833)}\n",
            "\n",
            "t 6800\n",
            "t reward-arm: [308.20300744110534, 3.7921608622372, 161.71097982900292, 14.375503363401343, 16.90984691907512, 10.805232057752857]\n",
            "t numplay: [471.0, 22.0, 306.0, 44.0, 58.0, 36.0] 937.0\n",
            "t mu-hat: [0.6529724733921723, 0.16487655922770433, 0.5267458626351886, 0.3194556302978076, 0.28660757489957833, 0.2920332988581853]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 329.3700000000208\n",
            "0 4\n",
            "385.78476777703605 0 {(3, 0.3194556302978076), (2, 0.5267458626351886), (0, 0.6527008586861268), (4, 0.28660757489957833)}\n",
            "\n",
            "t 6900\n",
            "t reward-arm: [370.13504148281993, 4.5872669050190265, 162.4039942957103, 14.608812766759057, 16.90984691907512, 10.805232057752857]\n",
            "t numplay: [566.0, 25.0, 307.0, 45.0, 58.0, 36.0] 1037.0\n",
            "t mu-hat: [0.6527954876240211, 0.17643334250073178, 0.5272856957652932, 0.3175828862338925, 0.28660757489957833, 0.2920332988581853]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 336.17000000002184\n",
            "0 4\n",
            "466.71679119967655 0 {(3, 0.3175828862338925), (2, 0.5272856957652932), (0, 0.6527431675532048), (4, 0.28660757489957833)}\n",
            "\n",
            "t 7000\n",
            "t reward-arm: [430.8351257494183, 4.5872669050190265, 162.4039942957103, 14.877982176221098, 19.730612404313163, 10.805232057752857]\n",
            "t numplay: [661.0, 25.0, 307.0, 46.0, 62.0, 36.0] 1137.0\n",
            "t mu-hat: [0.650808347053502, 0.17643334250073178, 0.5272856957652932, 0.31655281226002335, 0.3131843238779867, 0.2920332988581853]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 341.3200000000229\n",
            "0 4\n",
            "547.135900879401 0 {(3, 0.31655281226002335), (2, 0.5272856957652932), (0, 0.6506942469435975), (4, 0.3131843238779867)}\n",
            "\n",
            "t 7100\n",
            "t reward-arm: [496.11672597669445, 4.5872669050190265, 162.40399429571033, 14.877982176221096, 19.730612404313163, 10.805232057752857]\n",
            "t numplay: [761.0, 25.0, 307.0, 46.0, 62.0, 36.0] 1237.0\n",
            "t mu-hat: [0.6510718188670531, 0.17643334250073178, 0.5272856957652933, 0.3165528122600233, 0.3131843238779867, 0.2920332988581853]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 346.32000000002404\n",
            "0 4\n",
            "630.0839642327062 0 {(3, 0.3165528122600233), (2, 0.5272856957652933), (0, 0.651071744411971), (4, 0.3131843238779867)}\n",
            "\n",
            "t 7200\n",
            "t reward-arm: [560.6115189929185, 4.5872669050190265, 162.83406539423714, 14.877982176221098, 21.679370509687054, 10.805232057752857]\n",
            "t numplay: [857.0, 25.0, 308.0, 46.0, 65.0, 36.0] 1337.0\n",
            "t mu-hat: [0.6533933787796253, 0.17643334250073178, 0.5269710854182432, 0.31655281226002335, 0.32847531075283415, 0.2920332988581853]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 351.2700000000251\n",
            "0 4\n",
            "711.6091069150988 0 {(3, 0.31655281226002335), (2, 0.5269710854182432), (0, 0.6532381691015395), (4, 0.32847531075283415)}\n",
            "\n",
            "t 7300\n",
            "t reward-arm: [625.6548139667768, 4.5872669050190265, 162.83406539423714, 14.8779821762211, 21.679370509687054, 10.805232057752857]\n",
            "t numplay: [957.0, 25.0, 308.0, 46.0, 65.0, 36.0] 1437.0\n",
            "t mu-hat: [0.6530843569590572, 0.17643334250073178, 0.5269710854182432, 0.3165528122600234, 0.32847531075283415, 0.2920332988581853]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 356.27000000002624\n",
            "0 4\n",
            "795.0852327083172 0 {(3, 0.3165528122600234), (2, 0.5269710854182432), (0, 0.653189060072017), (4, 0.32847531075283415)}\n",
            "\n",
            "t 7400\n",
            "t reward-arm: [686.720795452096, 4.788162896133634, 163.69912955477423, 15.260882514925667, 22.301959993706536, 10.805232057752857]\n",
            "t numplay: [1052.0, 26.0, 310.0, 47.0, 66.0, 36.0] 1537.0\n",
            "t mu-hat: [0.6521565009041748, 0.1773393665234679, 0.5263637606262836, 0.3179350523942847, 0.33286507453293335, 0.2920332988581853]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 362.22000000002726\n",
            "0 4\n",
            "876.23856169478 0 {(3, 0.3179350523942847), (2, 0.5263637606262836), (0, 0.6520495320033993), (4, 0.33286507453293335)}\n",
            "\n",
            "t 7500\n",
            "t reward-arm: [751.5350076431657, 4.788162896133634, 163.69912955477423, 15.260882514925667, 22.301959993706532, 10.805232057752857]\n",
            "t numplay: [1152.0, 26.0, 310.0, 47.0, 66.0, 36.0] 1637.0\n",
            "t mu-hat: [0.6518083327347491, 0.1773393665234679, 0.5263637606262836, 0.3179350523942847, 0.3328650745329333, 0.2920332988581853]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 367.2200000000284\n",
            "0 4\n",
            "959.3774084898969 0 {(3, 0.3179350523942847), (2, 0.5263637606262836), (0, 0.651768533344484), (4, 0.3328650745329333)}\n",
            "\n",
            "t 7600\n",
            "t reward-arm: [814.9602109462088, 4.85009040336658, 163.69912955477423, 15.46880258924221, 22.99332793875093, 10.805232057752857]\n",
            "t numplay: [1248.0, 28.0, 310.0, 48.0, 67.0, 36.0] 1737.0\n",
            "t mu-hat: [0.6524901608856756, 0.1672444966678131, 0.5263637606262836, 0.31568984876004513, 0.3381371755698666, 0.2920332988581853]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 373.42000000002946\n",
            "0 4\n",
            "1040.3508015593868 0 {(3, 0.31568984876004513), (2, 0.5263637606262836), (0, 0.6525130430485889), (4, 0.3381371755698666)}\n",
            "\n",
            "t 7700\n",
            "t reward-arm: [878.0761184942503, 5.057502688971802, 163.6991295547742, 15.46880258924221, 23.837135385448725, 10.805232057752857]\n",
            "t numplay: [1346.0, 29.0, 310.0, 48.0, 68.0, 36.0] 1837.0\n",
            "t mu-hat: [0.651875366365442, 0.16858342296572673, 0.5263637606262836, 0.31568984876004513, 0.3454657302238946, 0.2920332988581853]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 379.17000000003054\n",
            "0 4\n",
            "1121.81897207692 0 {(3, 0.31568984876004513), (2, 0.5263637606262836), (0, 0.651875366365442), (4, 0.33813717556986655)}\n",
            "\n",
            "t 7800\n",
            "t reward-arm: [940.5765479324155, 5.2659646029506275, 163.69912955477423, 15.903140836187115, 24.626390883014132, 10.805232057752857]\n",
            "t numplay: [1442.0, 30.0, 310.0, 50.0, 69.0, 36.0] 1937.0\n",
            "t mu-hat: [0.6518201995373635, 0.16986982590163316, 0.5263637606262836, 0.3118262909056297, 0.351805584043059, 0.2920332988581853]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 384.9200000000316\n",
            "0 4\n",
            "1203.2937532714207 0 {(3, 0.3118262909056297), (2, 0.5263637606262836), (0, 0.651824135466288), (4, 0.351805584043059)}\n",
            "\n",
            "t 7900\n",
            "t reward-arm: [1003.7142401946417, 5.593794910152725, 163.69912955477423, 16.672227957350252, 25.971381873371364, 10.805232057752857]\n",
            "t numplay: [1537.0, 31.0, 310.0, 52.0, 71.0, 36.0] 2037.0\n",
            "t mu-hat: [0.6526100391382585, 0.17480609094227265, 0.5263637606262836, 0.3145703388179293, 0.3607136371301578, 0.2920332988581853]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 390.97000000003266\n",
            "0 4\n",
            "1283.7370209934404 0 {(3, 0.3145703388179293), (2, 0.5263637606262836), (0, 0.6526283079504382), (4, 0.3607136371301578)}\n",
            "\n",
            "7, t 100\n",
            "t reward-arm: [1.5149586695586632, 1.5025654526683203, 8.863054320945768, 17.175100602152817, 21.876989019195253, 3.1891872934741547]\n",
            "t numplay: [6.0, 6.0, 17.0, 28.0, 34.0, 9.0] 100.0\n",
            "t mu-hat: [0.21642266707980903, 0.21465220752404576, 0.4923919067192093, 0.5922448483500972, 0.6250568291198644, 0.3189187293474155]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 10.600000000000009\n",
            "4 4\n",
            "55.10278083399957 0 {(3, 0.5873907207838497), (2, 0.4923919067192093), (4, 0.6250568291198644)}\n",
            "\n",
            "t 200\n",
            "t reward-arm: [2.802006817176226, 3.1706560615134505, 14.254640327889419, 35.54873130466533, 50.99329086414559, 4.526188214606087]\n",
            "t numplay: [11.0, 11.0, 28.0, 58.0, 79.0, 13.0] 200.0\n",
            "t mu-hat: [0.2335005680980188, 0.2642213384594542, 0.4915393216513593, 0.6025208695705988, 0.6374161358018199, 0.32329915818614907]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 18.55000000000003\n",
            "4 4\n",
            "116.75656172920769 0 {(3, 0.6008143070882629), (2, 0.4915393216513593), (4, 0.6374161358018198)}\n",
            "\n",
            "t 300\n",
            "t reward-arm: [2.802006817176226, 3.2806699295852155, 19.92079991752993, 49.42353225033037, 91.24223689185412, 5.5438679797262]\n",
            "t numplay: [11.0, 12.0, 39.0, 82.0, 140.0, 16.0] 300.0\n",
            "t mu-hat: [0.2335005680980188, 0.2523592253527089, 0.49801999793824825, 0.595464243979884, 0.6471080630627952, 0.3261098811603647]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 22.600000000000033\n",
            "4 4\n",
            "185.48923878135327 0 {(3, 0.595464243979884), (2, 0.49801999793824825), (4, 0.6472115660725415)}\n",
            "\n",
            "t 400\n",
            "t reward-arm: [2.877035460156184, 3.7406503876296906, 25.16665964350013, 64.19228437224555, 129.8531124802053, 6.158764135437466]\n",
            "t numplay: [12.0, 14.0, 49.0, 107.0, 200.0, 18.0] 400.0\n",
            "t mu-hat: [0.22131042001201415, 0.24937669250864605, 0.5033331928700026, 0.5943730034467181, 0.6460353854736582, 0.3241454808124982]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 27.25000000000004\n",
            "4 4\n",
            "254.71830094380334 0 {(3, 0.5943730034467181), (2, 0.5033331928700026), (4, 0.6472527069367894)}\n",
            "\n",
            "t 500\n",
            "t reward-arm: [3.1490134846661424, 3.966466131564081, 28.491830346802317, 81.874976107459, 168.68207555324676, 6.868693647544604]\n",
            "t numplay: [13.0, 15.0, 56.0, 136.0, 260.0, 20.0] 500.0\n",
            "t mu-hat: [0.22492953461901016, 0.24790413322275506, 0.49985667275091783, 0.5976275628281679, 0.6462914772155048, 0.3270806498830764]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 31.000000000000053\n",
            "4 4\n",
            "325.9503053782381 0 {(3, 0.5976275628281679), (2, 0.49985667275091783), (4, 0.6457292878442453)}\n",
            "\n",
            "t 600\n",
            "t reward-arm: [3.8794907353150587, 3.966466131564081, 30.224871850284288, 102.65732252265647, 204.61042915126495, 8.153646557141855]\n",
            "t numplay: [17.0, 15.0, 60.0, 169.0, 316.0, 23.0] 600.0\n",
            "t mu-hat: [0.2155272630730588, 0.24790413322275506, 0.49548970246367685, 0.6038666030744498, 0.6454587670386907, 0.33973527321424396]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 36.0\n",
            "4 4\n",
            "396.53147647758755 0 {(3, 0.6038666030744498), (2, 0.49548970246367685), (4, 0.6455596652789017)}\n",
            "\n",
            "t 700\n",
            "t reward-arm: [3.879490735315059, 4.270856631183784, 30.999071498434613, 114.4422354453836, 255.06573793740714, 8.544584168283855]\n",
            "t numplay: [17.0, 16.0, 62.0, 189.0, 392.0, 24.0] 700.0\n",
            "t mu-hat: [0.21552726307305883, 0.25122686065786964, 0.4920487539434066, 0.6023275549757031, 0.6490222339374228, 0.3417833667313542]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 37.89999999999994\n",
            "4 4\n",
            "471.90023657767046 0 {(3, 0.6023275549757031), (2, 0.4920487539434066), (4, 0.6487797435119228)}\n",
            "\n",
            "t 800\n",
            "t reward-arm: [4.080415698199811, 4.627703087698353, 33.58024616655934, 129.24150816572433, 296.96528788678893, 9.289180779862743]\n",
            "t numplay: [19.0, 18.0, 67.0, 213.0, 457.0, 26.0] 800.0\n",
            "t mu-hat: [0.20402078490999057, 0.24356332040517648, 0.4938271495082256, 0.6039322811482445, 0.6483958250803251, 0.34404373258750903]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 42.04999999999987\n",
            "4 4\n",
            "544.2418640096395 0 {(3, 0.6046176275962556), (2, 0.4938271495082256), (4, 0.6483958250803251)}\n",
            "\n",
            "t 900\n",
            "t reward-arm: [4.080415698199811, 5.334612405029411, 34.36500004216076, 134.69950805103707, 353.1709154775508, 9.690831196446599]\n",
            "t numplay: [19.0, 20.0, 69.0, 223.0, 542.0, 27.0] 900.0\n",
            "t mu-hat: [0.20402078490999057, 0.25402916214425764, 0.490928572030868, 0.6013370895135584, 0.6504068425000936, 0.3461011141588071]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 43.899999999999835\n",
            "4 4\n",
            "620.6483769536646 0 {(3, 0.6013370895135584), (2, 0.490928572030868), (4, 0.6504068425000936)}\n",
            "\n",
            "t 1000\n",
            "t reward-arm: [4.080415698199811, 5.334612405029411, 35.387740626328366, 141.71008457796592, 410.98330313377323, 9.690831196446599]\n",
            "t numplay: [19.0, 20.0, 71.0, 235.0, 628.0, 27.0] 1000.0\n",
            "t mu-hat: [0.20402078490999057, 0.25402916214425764, 0.491496397587894, 0.6004664600761268, 0.6533915789090194, 0.3461011141588071]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 44.7499999999998\n",
            "4 4\n",
            "699.2253790364234 0 {(3, 0.6004664600761268), (2, 0.491496397587894), (4, 0.6532568618920768)}\n",
            "\n",
            "t 1100\n",
            "t reward-arm: [4.04605980505463, 6.147359558350292, 37.972402554974, 151.21148357084832, 457.90441443308316, 10.52974560021378]\n",
            "t numplay: [20.0, 23.0, 76.0, 251.0, 701.0, 29.0] 1100.0\n",
            "t mu-hat: [0.19266951452641093, 0.25613998159792883, 0.4931480851295325, 0.6000455697255885, 0.6522854906454176, 0.35099152000712597]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 48.39999999999975\n",
            "4 4\n",
            "773.1395031965027 0 {(3, 0.6000455697255885), (2, 0.4931480851295325), (4, 0.6521212883622824)}\n",
            "\n",
            "t 1200\n",
            "t reward-arm: [4.04605980505463, 6.147359558350292, 39.580940677505986, 159.40209696238486, 510.8112062080463, 11.403740319275997]\n",
            "t numplay: [20.0, 23.0, 79.0, 265.0, 782.0, 31.0] 1200.0\n",
            "t mu-hat: [0.19266951452641093, 0.25613998159792883, 0.4947617584688248, 0.5992560036179881, 0.6523770194227922, 0.3563668849773749]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 50.1499999999997\n",
            "4 4\n",
            "850.283517682711 0 {(3, 0.5992560036179883), (2, 0.4947617584688248), (4, 0.6523353577991992)}\n",
            "\n",
            "t 1300\n",
            "t reward-arm: [4.550281635339086, 7.015943817863767, 41.11221819184311, 167.10090804426852, 562.5407228213242, 11.403740319275997]\n",
            "t numplay: [22.0, 26.0, 82.0, 278.0, 861.0, 31.0] 1300.0\n",
            "t mu-hat: [0.19783833197126463, 0.25984977103199136, 0.49532793002220615, 0.598927985821751, 0.6525994464284502, 0.3563668849773749]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 53.19999999999967\n",
            "4 4\n",
            "925.995877224201 0 {(3, 0.598927985821751), (2, 0.49532793002220615), (4, 0.6527268774875499)}\n",
            "\n",
            "t 1400\n",
            "t reward-arm: [4.550281635339086, 7.015943817863766, 42.67101338410215, 173.96084853027068, 616.880096934459, 11.633838727726449]\n",
            "t numplay: [22.0, 26.0, 85.0, 290.0, 945.0, 32.0] 1400.0\n",
            "t mu-hat: [0.19783833197126463, 0.25984977103199136, 0.49617457423374595, 0.5978036031968065, 0.6520931257235295, 0.3525405675068621]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 54.54999999999963\n",
            "4 4\n",
            "1004.1969321077466 0 {(3, 0.5978036031968065), (2, 0.49617457423374595), (4, 0.6520798415818372)}\n",
            "\n",
            "t 1500\n",
            "t reward-arm: [5.079114744682918, 7.015943817863766, 44.13000108257816, 183.78147560208788, 668.5372528740783, 11.633838727726449]\n",
            "t numplay: [24.0, 26.0, 88.0, 306.0, 1024.0, 32.0] 1500.0\n",
            "t mu-hat: [0.20316458978731672, 0.25984977103199136, 0.49584270879301307, 0.5986367283455631, 0.6522314662186129, 0.3525405675068621]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 56.699999999999584\n",
            "4 4\n",
            "1081.5227442638893 0 {(3, 0.5986367283455631), (2, 0.49584270879301307), (4, 0.6521719682761629)}\n",
            "\n",
            "t 1600\n",
            "t reward-arm: [5.079114744682918, 7.015943817863766, 45.706163522412666, 195.3886663377573, 719.2628305293595, 11.633838727726449]\n",
            "t numplay: [24.0, 26.0, 91.0, 325.0, 1102.0, 32.0] 1600.0\n",
            "t mu-hat: [0.20316458978731672, 0.25984977103199136, 0.49680612524361595, 0.5993517372323843, 0.6520968545143785, 0.3525405675068621]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 58.099999999999525\n",
            "4 4\n",
            "1159.5598104490323 0 {(3, 0.5993517372323843), (2, 0.49680612524361595), (4, 0.6520201572236888)}\n",
            "\n",
            "t 1700\n",
            "t reward-arm: [5.079114744682918, 7.672658878388033, 46.82839199501, 198.93482209258855, 778.3594810291823, 12.090578324103443]\n",
            "t numplay: [24.0, 28.0, 93.0, 331.0, 1191.0, 33.0] 1700.0\n",
            "t mu-hat: [0.20316458978731672, 0.264574444082346, 0.4981743829256383, 0.5992012713632185, 0.6529861418030053, 0.35560524482657185]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 59.7499999999995\n",
            "4 4\n",
            "1237.595217491526 0 {(3, 0.5992012713632185), (2, 0.4981743829256383), (4, 0.6531167367979853)}\n",
            "\n",
            "t 1800\n",
            "t reward-arm: [5.389876614496478, 8.48461735797271, 49.874014201515706, 204.55969049764454, 829.8574463798889, 12.42349671690934]\n",
            "t numplay: [25.0, 30.0, 99.0, 341.0, 1271.0, 34.0] 1800.0\n",
            "t mu-hat: [0.20730294671140298, 0.2736973341281519, 0.49874014201515704, 0.5981277499931127, 0.6524036528143781, 0.3549570490545526]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 62.54999999999947\n",
            "4 4\n",
            "1313.6613365133185 0 {(3, 0.5981277499931127), (2, 0.49874014201515704), (4, 0.65237319344536)}\n",
            "\n",
            "t 1900\n",
            "t reward-arm: [5.389876614496478, 8.48461735797271, 49.874014201515706, 205.43507871117967, 895.5938366546786, 12.42349671690934]\n",
            "t numplay: [25.0, 30.0, 99.0, 343.0, 1369.0, 34.0] 1900.0\n",
            "t mu-hat: [0.20730294671140298, 0.2736973341281519, 0.49874014201515704, 0.5971949962534293, 0.6537181289450209, 0.3549570490545526]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 62.649999999999466\n",
            "4 4\n",
            "1394.8898664774033 0 {(3, 0.5971949962534293), (2, 0.49874014201515704), (4, 0.653727598379574)}\n",
            "\n",
            "t 2000\n",
            "t reward-arm: [5.499361017576844, 8.48461735797271, 50.76180109552884, 214.9248494353704, 950.1688317359678, 12.42349671690934]\n",
            "t numplay: [26.0, 30.0, 101.0, 358.0, 1451.0, 34.0] 2000.0\n",
            "t mu-hat: [0.20368003768803128, 0.2736973341281519, 0.49766471662283174, 0.5986764608227587, 0.654386247752044, 0.3549570490545526]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 64.59999999999943\n",
            "4 0\n",
            "1473.6151546507863 0 {(3, 0.5986764608227587), (2, 0.49766471662283174), (4, 0.6543022688631082)}\n",
            "\n",
            "Arm 4 Changepoint Detected at time 2030\n",
            "t 2100\n",
            "t reward-arm: [5.4993610175768435, 8.48461735797271, 63.78475152747431, 222.00622169566773, 8.894082864648214, 13.287330786917684]\n",
            "t numplay: [26.0, 30.0, 126.0, 381.0, 29.0, 37.0] 629.0\n",
            "t mu-hat: [0.20368003768803125, 0.2736973341281519, 0.5022421380116088, 0.5811681196221669, 0.2964694288216071, 0.3496665996557285]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 101.19999999999983\n",
            "3 0\n",
            "29.800611672968678 0 {(3, 0.5811681196221669), (2, 0.5022421380116088), (4, 0.3011742294286773)}\n",
            "\n",
            "Arm 3 Changepoint Detected at time 2200\n",
            "t 2200\n",
            "t reward-arm: [5.499361017576844, 9.206857630069278, 105.49640069050099, 0.0, 9.062769412041497, 13.498024300418749]\n",
            "t numplay: [26.0, 31.0, 201.0, 0.0, 30.0, 39.0] 327.0\n",
            "t mu-hat: [0.20368003768803128, 0.28771430093966494, 0.5222594093589158, 0.0, 0.2923474003884354, 0.33745060751046874]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 122.45000000000037\n",
            "3 0\n",
            "0.0 0 set()\n",
            "\n",
            "t 2300\n",
            "t reward-arm: [5.499361017576844, 9.206857630069278, 142.10007326214813, 10.32471374181874, 9.756592790286494, 13.757914197915436]\n",
            "t numplay: [26.0, 31.0, 265.0, 33.0, 32.0, 40.0] 427.0\n",
            "t mu-hat: [0.20368003768803128, 0.28771430093966494, 0.534210801737399, 0.303668051229963, 0.29565432697837857, 0.33555888287598623]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 146.4500000000009\n",
            "2 0\n",
            "44.419913035322956 0 {(3, 0.303668051229963), (2, 0.5349165674661019), (1, 0.28771430093966494), (4, 0.29565432697837857)}\n",
            "\n",
            "t 2400\n",
            "t reward-arm: [7.058200050888922, 51.8410665521165, 156.53177380795316, 10.51567067402198, 10.390388163845302, 13.778764824848434]\n",
            "t numplay: [28.0, 98.0, 292.0, 34.0, 34.0, 41.0] 527.0\n",
            "t mu-hat: [0.24338620865134214, 0.5236471368900657, 0.5342381358633214, 0.30044773354348514, 0.2968682332527229, 0.32806582916305793]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 155.6000000000018\n",
            "2 0\n",
            "85.6554474346095 0 {(3, 0.30044773354348514), (2, 0.5342381358633214), (1, 0.5216964172813413), (4, 0.2968682332527229)}\n",
            "\n",
            "t 2500\n",
            "t reward-arm: [7.058200050888922, 117.94407897043487, 156.53177380795316, 10.51567067402198, 10.390388163845302, 13.778764824848434]\n",
            "t numplay: [28.0, 198.0, 292.0, 34.0, 34.0, 41.0] 627.0\n",
            "t mu-hat: [0.24338620865134214, 0.5926838139217833, 0.5342381358633214, 0.30044773354348514, 0.2968682332527229, 0.32806582916305793]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 160.60000000000295\n",
            "1 0\n",
            "150.1327621010528 0 {(3, 0.30044773354348514), (2, 0.5342381358633214), (1, 0.5919089354933093), (4, 0.2968682332527229)}\n",
            "\n",
            "Arm 1 Changepoint Detected at time 2580\n",
            "t 2600\n",
            "t reward-arm: [7.058200050888922, 13.249535073578572, 157.58477343239332, 10.51567067402198, 10.78016104617469, 13.778764824848434]\n",
            "t numplay: [28.0, 20.0, 294.0, 34.0, 35.0, 41.0] 452.0\n",
            "t mu-hat: [0.24338620865134214, 0.6309302415989796, 0.5341856726521808, 0.30044773354348514, 0.29944891794929696, 0.32806582916305793]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 166.20000000000405\n",
            "1 0\n",
            "13.665943203244154 0 {(3, 0.30044773354348514), (2, 0.5341856726521808), (1, 0.6301201482232914), (4, 0.29944891794929696)}\n",
            "\n",
            "t 2700\n",
            "t reward-arm: [7.674953710208857, 76.55160456243, 158.09124981545156, 10.936259995644562, 10.780161046174692, 13.778764824848436]\n",
            "t numplay: [29.0, 116.0, 295.0, 36.0, 35.0, 41.0] 552.0\n",
            "t mu-hat: [0.25583179034029524, 0.6542872184823076, 0.5340920601873363, 0.29557459447688006, 0.299448917949297, 0.328065829163058]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 171.95000000000516\n",
            "1 0\n",
            "93.74535556341861 0 {(3, 0.29557459447688006), (2, 0.5340920601873363), (1, 0.6533772276124217), (4, 0.299448917949297)}\n",
            "\n",
            "t 2800\n",
            "t reward-arm: [7.674953710208857, 141.06646417543072, 158.09124981545156, 10.936259995644562, 10.780161046174692, 13.778764824848434]\n",
            "t numplay: [29.0, 216.0, 295.0, 36.0, 35.0, 41.0] 652.0\n",
            "t mu-hat: [0.25583179034029524, 0.6500758717761784, 0.5340920601873363, 0.29557459447688006, 0.299448917949297, 0.32806582916305793]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 176.9500000000063\n",
            "1 0\n",
            "176.60754164824158 0 {(3, 0.29557459447688006), (2, 0.5340920601873365), (1, 0.6503183004868779), (4, 0.299448917949297)}\n",
            "\n",
            "t 2900\n",
            "t reward-arm: [8.950784986407033, 202.77786973388675, 158.09124981545156, 11.320894119063125, 11.17749804489967, 13.778764824848436]\n",
            "t numplay: [31.0, 310.0, 295.0, 38.0, 37.0, 41.0] 752.0\n",
            "t mu-hat: [0.2797120308252198, 0.6520188737424011, 0.5340920601873363, 0.290279336386234, 0.2941446853920966, 0.328065829163058]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 183.35000000000736\n",
            "1 0\n",
            "255.82074932938144 0 {(3, 0.290279336386234), (2, 0.5340920601873363), (1, 0.6518479476001727), (4, 0.2941446853920966)}\n",
            "\n",
            "t 3000\n",
            "t reward-arm: [8.950784986407033, 267.03882049981615, 158.09124981545156, 11.320894119063125, 11.17749804489967, 13.778764824848436]\n",
            "t numplay: [31.0, 410.0, 295.0, 38.0, 37.0, 41.0] 852.0\n",
            "t mu-hat: [0.2797120308252198, 0.6497294902671926, 0.5340920601873363, 0.290279336386234, 0.2941446853920966, 0.328065829163058]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 188.3500000000085\n",
            "1 0\n",
            "338.40717384346823 0 {(3, 0.290279336386234), (2, 0.5340920601873363), (1, 0.6496101908162953), (4, 0.2941446853920966)}\n",
            "\n",
            "t 3100\n",
            "t reward-arm: [9.57499093264753, 330.19645791777407, 158.60981006881178, 11.320894119063125, 11.177498044899668, 13.778764824848436]\n",
            "t numplay: [32.0, 508.0, 296.0, 38.0, 37.0, 41.0] 952.0\n",
            "t mu-hat: [0.2901512403832585, 0.6487160273433675, 0.5340397645414539, 0.290279336386234, 0.29414468539209654, 0.328065829163058]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 193.4000000000096\n",
            "1 0\n",
            "419.9423037243682 0 {(0, 0.2901512403832585), (3, 0.290279336386234), (2, 0.5340397645414539), (1, 0.648675348532163), (4, 0.29414468539209654)}\n",
            "\n",
            "t 3200\n",
            "t reward-arm: [9.57499093264753, 394.29138388331455, 158.60981006881178, 11.320894119063125, 11.177498044899668, 13.778764824848434]\n",
            "t numplay: [32.0, 608.0, 296.0, 38.0, 37.0, 41.0] 1052.0\n",
            "t mu-hat: [0.2901512403832585, 0.6474406960317152, 0.5340397645414539, 0.290279336386234, 0.29414468539209654, 0.32806582916305793]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 198.40000000001075\n",
            "1 0\n",
            "502.01929796337345 0 {(0, 0.2901512403832585), (3, 0.290279336386234), (2, 0.5340397645414539), (1, 0.6479756802664068), (4, 0.29414468539209654)}\n",
            "\n",
            "t 3300\n",
            "t reward-arm: [12.814037696269288, 454.2977985699773, 158.6098100688118, 11.506581891460446, 11.177498044899671, 13.778764824848436]\n",
            "t numplay: [37.0, 702.0, 296.0, 39.0, 37.0, 41.0] 1152.0\n",
            "t mu-hat: [0.337211518322876, 0.6462273094878767, 0.5340397645414539, 0.28766454728651114, 0.2941446853920966, 0.328065829163058]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 203.50000000001182\n",
            "1 0\n",
            "580.4192670091514 0 {(0, 0.337211518322876), (3, 0.28766454728651114), (2, 0.5340397645414539), (1, 0.6461655304741394), (4, 0.2941446853920966)}\n",
            "\n",
            "t 3400\n",
            "t reward-arm: [12.814037696269288, 518.7271613397521, 158.60981006881178, 11.506581891460446, 11.177498044899671, 13.778764824848436]\n",
            "t numplay: [37.0, 802.0, 296.0, 39.0, 37.0, 41.0] 1252.0\n",
            "t mu-hat: [0.337211518322876, 0.6459865022910986, 0.5340397645414539, 0.28766454728651114, 0.2941446853920966, 0.328065829163058]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 208.50000000001296\n",
            "1 0\n",
            "662.0396914028252 0 {(0, 0.337211518322876), (3, 0.28766454728651114), (2, 0.5340397645414539), (1, 0.6460233462015168), (4, 0.2941446853920966)}\n",
            "\n",
            "t 3500\n",
            "t reward-arm: [13.55443035532188, 581.1589831278638, 158.6098100688118, 11.84321390346983, 11.703830832371693, 13.778764824848436]\n",
            "t numplay: [38.0, 898.0, 296.0, 40.0, 39.0, 41.0] 1352.0\n",
            "t mu-hat: [0.3475494962903046, 0.6464504817885026, 0.5340397645414539, 0.28885887569438606, 0.29259577080929233, 0.328065829163058]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 214.60000000001403\n",
            "1 0\n",
            "741.5477956650043 0 {(0, 0.3475494962903046), (3, 0.28885887569438606), (2, 0.5340397645414539), (1, 0.6463922113139692), (4, 0.29259577080929233)}\n",
            "\n",
            "t 3600\n",
            "t reward-arm: [13.55443035532188, 644.286188231866, 159.6918445063184, 11.84321390346983, 12.232565214372874, 13.778764824848434]\n",
            "t numplay: [38.0, 994.0, 298.0, 40.0, 41.0, 41.0] 1452.0\n",
            "t mu-hat: [0.3475494962903046, 0.6475238072682071, 0.5340864364759813, 0.28885887569438606, 0.29125155272316366, 0.32806582916305793]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 220.60000000001511\n",
            "1 0\n",
            "821.8238190726652 0 {(0, 0.3475494962903046), (3, 0.28885887569438606), (2, 0.5340864364759812), (1, 0.6473086715766008), (4, 0.29125155272316366)}\n",
            "\n",
            "t 3700\n",
            "t reward-arm: [13.55443035532188, 709.9500538681552, 159.69184450631838, 11.84321390346983, 12.232565214372874, 13.778764824848434]\n",
            "t numplay: [38.0, 1094.0, 298.0, 40.0, 41.0, 41.0] 1552.0\n",
            "t mu-hat: [0.3475494962903046, 0.6483562135782239, 0.5340864364759812, 0.28885887569438606, 0.29125155272316366, 0.32806582916305793]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 225.60000000001625\n",
            "1 0\n",
            "903.8730500877809 0 {(0, 0.3475494962903046), (3, 0.28885887569438606), (2, 0.5340864364759812), (1, 0.6485058065407836), (4, 0.29125155272316366)}\n",
            "\n",
            "t 3800\n",
            "t reward-arm: [14.047056899510828, 772.1031649508591, 160.17551836875253, 12.045079039274524, 12.763913182315083, 13.778764824848434]\n",
            "t numplay: [39.0, 1189.0, 299.0, 41.0, 43.0, 41.0] 1652.0\n",
            "t mu-hat: [0.3511764224877707, 0.6488261890343353, 0.5339183945625084, 0.286787596173203, 0.29008893596170643, 0.32806582916305793]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 231.80000000001732\n",
            "1 0\n",
            "983.5182276864048 0 {(0, 0.3511764224877707), (3, 0.286787596173203), (2, 0.5339183945625084), (1, 0.6487416140319306), (4, 0.29008893596170643)}\n",
            "\n",
            "t 3900\n",
            "t reward-arm: [14.047056899510828, 837.7978418455588, 160.17551836875253, 12.045079039274524, 12.763913182315083, 13.778764824848434]\n",
            "t numplay: [39.0, 1289.0, 299.0, 41.0, 43.0, 41.0] 1752.0\n",
            "t mu-hat: [0.3511764224877707, 0.6494556913531463, 0.5339183945625084, 0.286787596173203, 0.29008893596170643, 0.32806582916305793]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 236.80000000001846\n",
            "1 0\n",
            "1065.7372782374687 0 {(0, 0.3511764224877707), (3, 0.286787596173203), (2, 0.5339183945625084), (1, 0.649312834292725), (4, 0.29008893596170643)}\n",
            "\n",
            "t 4000\n",
            "t reward-arm: [14.735523723945661, 900.7649455473137, 161.91976801665345, 12.208550025356658, 13.101681666262369, 13.778764824848434]\n",
            "t numplay: [40.0, 1383.0, 302.0, 42.0, 44.0, 41.0] 1852.0\n",
            "t mu-hat: [0.3594030176572113, 0.6508417236613538, 0.5343886733222886, 0.28391976803155017, 0.2911484814724971, 0.32806582916305793]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 242.80000000001954\n",
            "1 3\n",
            "1145.901160736848 0 {(0, 0.3594030176572113), (3, 0.28391976803155017), (2, 0.5343886733222886), (1, 0.6507798342433396), (4, 0.2911484814724971)}\n",
            "\n",
            "t 4100\n",
            "t reward-arm: [14.73552372394566, 976.0670823964108, 161.91976801665342, 12.208550025356658, 13.101681666262369, 13.778764824848434]\n",
            "t numplay: [40.0, 1483.0, 302.0, 42.0, 44.0, 41.0] 1952.0\n",
            "t mu-hat: [0.3594030176572112, 0.6577271444719749, 0.5343886733222886, 0.28391976803155017, 0.2911484814724971, 0.32806582916305793]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 247.80000000002067\n",
            "1 3\n",
            "1229.229522271121 0 {(0, 0.3594030176572112), (3, 0.28391976803155017), (2, 0.5343886733222886), (1, 0.6577327210346032), (4, 0.2911484814724971)}\n",
            "\n",
            "t 4200\n",
            "t reward-arm: [14.949539089079899, 1046.4044878224126, 162.54707582356116, 13.975506008643853, 13.473636894168592, 13.778764824848434]\n",
            "t numplay: [41.0, 1578.0, 303.0, 44.0, 45.0, 41.0] 2052.0\n",
            "t mu-hat: [0.35594140688285475, 0.6627007522624526, 0.5346943283669775, 0.3105668001920856, 0.2929051498732303, 0.32806582916305793]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 253.93000000002175\n",
            "1 3\n",
            "1311.1551237856595 0 {(0, 0.35594140688285475), (3, 0.3105668001920856), (2, 0.5346943283669775), (1, 0.6627452271373285), (4, 0.2929051498732303)}\n",
            "\n",
            "t 4300\n",
            "t reward-arm: [14.949539089079899, 1121.6260665478612, 163.11097176213843, 13.975506008643853, 13.473636894168592, 13.778764824848436]\n",
            "t numplay: [41.0, 1677.0, 304.0, 44.0, 45.0, 41.0] 2152.0\n",
            "t mu-hat: [0.35594140688285475, 0.6684303137949114, 0.5347900713512735, 0.3105668001920856, 0.2929051498732303, 0.328065829163058]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 259.6100000000228\n",
            "1 3\n",
            "1395.890551305002 0 {(0, 0.35594140688285475), (3, 0.3105668001920856), (2, 0.5347900713512735), (1, 0.6683506663209258), (4, 0.2929051498732303)}\n",
            "\n",
            "t 4400\n",
            "t reward-arm: [14.897564494784557, 1193.3741057317416, 163.1109717621384, 13.975506008643853, 14.175158965147943, 13.778764824848436]\n",
            "t numplay: [42.0, 1774.0, 304.0, 44.0, 47.0, 41.0] 2252.0\n",
            "t mu-hat: [0.3464549882508037, 0.6723234398488684, 0.5347900713512734, 0.3105668001920856, 0.29531581177391547, 0.328065829163058]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 265.61000000002394\n",
            "1 3\n",
            "1481.2185504457966 0 {(0, 0.3464549882508037), (3, 0.3105668001920856), (2, 0.5347900713512734), (1, 0.6723477204503755), (4, 0.29531581177391547)}\n",
            "\n",
            "t 4500\n",
            "t reward-arm: [15.499407131274754, 1263.357195996342, 163.97737573683185, 14.6439428982768, 14.175158965147943, 13.778764824848436]\n",
            "t numplay: [45.0, 1868.0, 306.0, 45.0, 47.0, 41.0] 2352.0\n",
            "t mu-hat: [0.3369436332885816, 0.6759535559102953, 0.534128259729094, 0.3183465847451478, 0.29531581177391547, 0.328065829163058]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 272.670000000025\n",
            "1 3\n",
            "1565.6414267330902 0 {(0, 0.3369436332885816), (3, 0.3183465847451478), (2, 0.534128259729094), (1, 0.6759586687523594), (4, 0.29531581177391547)}\n",
            "\n",
            "t 4600\n",
            "t reward-arm: [15.499407131274754, 1336.920493657688, 163.97737573683185, 14.6439428982768, 14.175158965147943, 13.778764824848436]\n",
            "t numplay: [45.0, 1968.0, 306.0, 45.0, 47.0, 41.0] 2452.0\n",
            "t mu-hat: [0.3369436332885816, 0.6789845066824215, 0.534128259729094, 0.3183465847451478, 0.29531581177391547, 0.328065829163058]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 277.67000000002616\n",
            "1 3\n",
            "1653.5052089399837 0 {(0, 0.3369436332885816), (3, 0.3183465847451478), (2, 0.534128259729094), (1, 0.6789325135363729), (4, 0.29531581177391547)}\n",
            "\n",
            "t 4700\n",
            "t reward-arm: [15.704435953726307, 1407.1065358622775, 163.97737573683185, 16.236347857925452, 14.41794578653452, 13.778764824848436]\n",
            "t numplay: [46.0, 2064.0, 306.0, 47.0, 48.0, 41.0] 2552.0\n",
            "t mu-hat: [0.3341369351856661, 0.6814075234199891, 0.534128259729094, 0.33825724704011356, 0.294243791561929, 0.328065829163058]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 283.5700000000273\n",
            "1 3\n",
            "1739.475257598109 0 {(0, 0.3341369351856661), (3, 0.33825724704011356), (2, 0.534128259729094), (1, 0.6813838135459035), (4, 0.294243791561929)}\n",
            "\n",
            "t 4800\n",
            "t reward-arm: [15.704435953726307, 1481.4639374216788, 163.97737573683187, 16.236347857925452, 14.41794578653452, 13.778764824848434]\n",
            "t numplay: [46.0, 2164.0, 306.0, 47.0, 48.0, 41.0] 2652.0\n",
            "t mu-hat: [0.3341369351856661, 0.6842789549291819, 0.5341282597290941, 0.33825724704011356, 0.294243791561929, 0.32806582916305793]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 288.5700000000284\n",
            "1 3\n",
            "1828.4550891119077 0 {(0, 0.3341369351856661), (3, 0.33825724704011356), (2, 0.5341282597290941), (1, 0.6841668818802333), (4, 0.294243791561929)}\n",
            "\n",
            "Arm 1 Changepoint Detected at time 4900\n",
            "t 4900\n",
            "t reward-arm: [16.416339045636736, 0.0, 164.9853543804979, 16.870237544270815, 14.41794578653452, 13.778764824848434]\n",
            "t numplay: [48.0, 0.0, 308.0, 48.0, 48.0, 41.0] 493.0\n",
            "t mu-hat: [0.3350273274619742, 0.0, 0.5339331856974042, 0.3442905621279758, 0.294243791561929, 0.32806582916305793]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 295.0800000000295\n",
            "1 3\n",
            "0.0 0 set()\n",
            "\n",
            "t 5000\n",
            "t reward-arm: [16.416339045636736, 76.57902894718968, 164.9853543804979, 16.870237544270815, 14.41794578653452, 13.778764824848434]\n",
            "t numplay: [48.0, 100.0, 308.0, 48.0, 48.0, 41.0] 593.0\n",
            "t mu-hat: [0.3350273274619742, 0.7582082073979176, 0.5339331856974042, 0.3442905621279758, 0.294243791561929, 0.32806582916305793]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 300.0800000000306\n",
            "1 3\n",
            "100.42466056524353 0 {(0, 0.3350273274619742), (3, 0.3442905621279758), (2, 0.5339331856974042), (1, 0.7583144133019671), (4, 0.294243791561929)}\n",
            "\n",
            "t 5100\n",
            "t reward-arm: [16.783807339073338, 147.48450419990667, 165.58567761380402, 17.864250228359065, 14.638981472091363, 13.778764824848434]\n",
            "t numplay: [50.0, 195.0, 309.0, 49.0, 49.0, 41.0] 693.0\n",
            "t mu-hat: [0.3290942615504576, 0.7524719602036054, 0.5341473471413033, 0.3572850045671813, 0.2927796294418272, 0.32806582916305793]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 306.8100000000317\n",
            "1 3\n",
            "201.83886770987698 0 {(0, 0.3290942615504576), (3, 0.3572850045671813), (2, 0.5341473471413033), (1, 0.7518370966736284), (4, 0.2927796294418272)}\n",
            "\n",
            "t 5200\n",
            "t reward-arm: [17.152924552166443, 220.87089332954488, 166.87377319527715, 17.864250228359065, 14.916031955579962, 13.778764824848434]\n",
            "t numplay: [51.0, 291.0, 311.0, 49.0, 50.0, 41.0] 793.0\n",
            "t mu-hat: [0.32986393369550854, 0.7564071689367976, 0.5348518371643498, 0.3572850045671813, 0.29247121481529337, 0.32806582916305793]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 313.2700000000328\n",
            "1 3\n",
            "303.7385234340941 0 {(0, 0.32986393369550854), (3, 0.3572850045671813), (2, 0.5348518371643498), (1, 0.7561909434305151), (4, 0.29247121481529337)}\n",
            "\n",
            "t 5300\n",
            "t reward-arm: [17.152924552166443, 295.1927022514593, 166.87377319527715, 17.864250228359065, 14.916031955579962, 13.778764824848434]\n",
            "t numplay: [51.0, 391.0, 311.0, 49.0, 50.0, 41.0] 893.0\n",
            "t mu-hat: [0.32986393369550854, 0.753042607784335, 0.5348518371643498, 0.3572850045671813, 0.29247121481529337, 0.32806582916305793]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 318.2700000000339\n",
            "1 3\n",
            "407.0247094706033 0 {(0, 0.32986393369550854), (3, 0.3572850045671813), (2, 0.5348518371643498), (1, 0.7526200362387658), (4, 0.29247121481529337)}\n",
            "\n",
            "t 5400\n",
            "t reward-arm: [17.391218988174444, 366.0436004518674, 167.7827555838996, 19.401137946146505, 15.255438118625461, 13.778764824848436]\n",
            "t numplay: [52.0, 485.0, 313.0, 51.0, 51.0, 41.0] 993.0\n",
            "t mu-hat: [0.32813620732404614, 0.7531761326170111, 0.534339985935986, 0.37309880665666356, 0.29337380997356655, 0.328065829163058]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 324.63000000003495\n",
            "1 3\n",
            "507.2605195987773 0 {(0, 0.32813620732404614), (3, 0.37309880665666356), (2, 0.534339985935986), (1, 0.7531321649138883), (4, 0.29337380997356655)}\n",
            "\n",
            "t 5500\n",
            "t reward-arm: [17.391218988174444, 444.186989537343, 167.7827555838996, 19.401137946146505, 15.255438118625461, 13.778764824848436]\n",
            "t numplay: [52.0, 585.0, 313.0, 51.0, 51.0, 41.0] 1093.0\n",
            "t mu-hat: [0.32813620732404614, 0.7579982756609949, 0.534339985935986, 0.37309880665666356, 0.29337380997356655, 0.328065829163058]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 329.6300000000361\n",
            "1 3\n",
            "610.8504922759948 0 {(0, 0.32813620732404614), (3, 0.37309880665666356), (2, 0.534339985935986), (1, 0.7576055957597991), (4, 0.29337380997356655)}\n",
            "\n",
            "t 5600\n",
            "t reward-arm: [17.84763014753548, 516.8944844200608, 167.7827555838996, 19.401137946146505, 15.841109900696534, 13.778764824848434]\n",
            "t numplay: [53.0, 682.0, 313.0, 51.0, 53.0, 41.0] 1193.0\n",
            "t mu-hat: [0.33051166939880516, 0.756800123601846, 0.534339985935986, 0.37309880665666356, 0.2933538870499358, 0.32806582916305793]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 336.0800000000372\n",
            "1 3\n",
            "712.7938092192674 0 {(0, 0.33051166939880516), (3, 0.37309880665666356), (2, 0.5343399859359861), (1, 0.7565990769163528), (4, 0.2933538870499358)}\n",
            "\n",
            "t 5700\n",
            "t reward-arm: [17.84763014753548, 594.9935877637186, 167.78275558389961, 19.401137946146505, 15.841109900696534, 13.778764824848436]\n",
            "t numplay: [53.0, 782.0, 313.0, 51.0, 53.0, 41.0] 1293.0\n",
            "t mu-hat: [0.33051166939880516, 0.759889639544979, 0.5343399859359861, 0.37309880665666356, 0.2933538870499358, 0.328065829163058]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 341.08000000003835\n",
            "1 3\n",
            "816.7374162631795 0 {(0, 0.33051166939880516), (3, 0.37309880665666356), (2, 0.5343399859359861), (1, 0.7596076372594248), (4, 0.2933538870499358)}\n",
            "\n",
            "t 5800\n",
            "t reward-arm: [17.98034877572152, 662.953540331271, 169.2715941906191, 21.170924966541396, 15.841109900696534, 13.778764824848436]\n",
            "t numplay: [54.0, 876.0, 316.0, 53.0, 53.0, 41.0] 1393.0\n",
            "t mu-hat: [0.3269154322858458, 0.7559333413127378, 0.5339797923994294, 0.3920541660470629, 0.2933538870499358, 0.328065829163058]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 347.22000000003936\n",
            "1 3\n",
            "918.0759110520304 0 {(0, 0.3269154322858458), (3, 0.3920541660470629), (2, 0.5339797923994294), (1, 0.7559894153793344), (4, 0.2933538870499358)}\n",
            "\n",
            "t 5900\n",
            "t reward-arm: [17.98034877572152, 737.3560453765032, 169.2715941906191, 21.170924966541396, 15.841109900696534, 13.778764824848436]\n",
            "t numplay: [54.0, 976.0, 316.0, 53.0, 53.0, 41.0] 1493.0\n",
            "t mu-hat: [0.3269154322858458, 0.7547144783792253, 0.5339797923994294, 0.3920541660470629, 0.2933538870499358, 0.328065829163058]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 352.2200000000405\n",
            "1 3\n",
            "1021.4834267096004 0 {(0, 0.3269154322858458), (3, 0.3920541660470629), (2, 0.5339797923994294), (1, 0.7546217367550598), (4, 0.2933538870499358)}\n",
            "\n",
            "t 6000\n",
            "t reward-arm: [18.153945565481894, 808.6765184327605, 170.26923734051175, 22.092970476522716, 16.394935886970615, 13.778764824848436]\n",
            "t numplay: [55.0, 1070.0, 318.0, 54.0, 55.0, 41.0] 1593.0\n",
            "t mu-hat: [0.32417759938360524, 0.7550667772481424, 0.5337593647037986, 0.401690372300413, 0.2927667122673324, 0.328065829163058]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 359.5300000000415\n",
            "1 4\n",
            "1121.673734117398 0 {(0, 0.32417759938360524), (3, 0.401690372300413), (2, 0.5337593647037986), (1, 0.7550106800824385), (4, 0.2927667122673324)}\n",
            "\n",
            "Arm 1 Changepoint Detected at time 6010\n",
            "t 6100\n",
            "t reward-arm: [18.8257473119263, 4.496619846119744, 197.28275357591755, 25.418846615265686, 17.498634686888508, 14.097533868714883]\n",
            "t numplay: [56.0, 22.0, 369.0, 66.0, 57.0, 43.0] 613.0\n",
            "t mu-hat: [0.330276268630286, 0.19550521070085844, 0.5331966312862637, 0.3793857703770998, 0.30170059804980187, 0.32039849701624734]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 388.7800000000401\n",
            "2 4\n",
            "39.109517812376076 0 {(3, 0.3793857703770998), (2, 0.5332114383713087), (0, 0.330276268630286), (4, 0.30170059804980187)}\n",
            "\n",
            "t 6200\n",
            "t reward-arm: [18.8257473119263, 4.730928120320224, 249.90718035603356, 25.542860208827907, 17.498634686888508, 14.194093828096978]\n",
            "t numplay: [56.0, 23.0, 466.0, 67.0, 57.0, 44.0] 713.0\n",
            "t mu-hat: [0.330276268630286, 0.19712200501334265, 0.5351331485139905, 0.3756302971886457, 0.30170059804980187, 0.315424307291044]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 404.7800000000379\n",
            "2 4\n",
            "97.82485446799086 0 {(3, 0.3756302971886457), (2, 0.5353884987690121), (0, 0.330276268630286), (4, 0.30170059804980187)}\n",
            "\n",
            "t 6300\n",
            "t reward-arm: [18.8257473119263, 5.200674101761308, 298.93406793139803, 26.39268432537979, 18.156208978364017, 14.260281089056894]\n",
            "t numplay: [56.0, 26.0, 557.0, 71.0, 58.0, 45.0] 813.0\n",
            "t mu-hat: [0.330276268630286, 0.1926175593244929, 0.5357241360777742, 0.3665650600747193, 0.30773235556549183, 0.3100061106316716]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 422.08000000003574\n",
            "2 4\n",
            "154.66657423079178 0 {(3, 0.3665650600747193), (2, 0.535470555261148), (0, 0.330276268630286), (4, 0.30773235556549183)}\n",
            "\n",
            "t 6400\n",
            "t reward-arm: [18.8257473119263, 5.200674101761308, 353.98221279776106, 26.39268432537979, 18.156208978364017, 14.559609322439256]\n",
            "t numplay: [56.0, 26.0, 656.0, 71.0, 58.0, 46.0] 913.0\n",
            "t mu-hat: [0.330276268630286, 0.1926175593244929, 0.5387857120209453, 0.3665650600747193, 0.30773235556549183, 0.3097789217540267]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 437.4800000000335\n",
            "2 4\n",
            "215.11056790715594 0 {(3, 0.3665650600747193), (2, 0.5386623339712262), (0, 0.330276268630286), (4, 0.30773235556549183)}\n",
            "\n",
            "t 6500\n",
            "t reward-arm: [19.55847540330932, 5.503470707158839, 404.96442505781545, 26.96352213918368, 18.887405587211866, 14.773464668179223]\n",
            "t numplay: [57.0, 27.0, 750.0, 73.0, 59.0, 47.0] 1013.0\n",
            "t mu-hat: [0.3372150931605055, 0.19655252525567282, 0.5392335886255865, 0.3643719207997795, 0.3147900931201978, 0.30778051392040046]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 453.48000000003134\n",
            "2 4\n",
            "273.97461156730157 0 {(3, 0.3643719207997795), (2, 0.5391427243144137), (0, 0.3372150931605055), (4, 0.3147900931201978)}\n",
            "\n",
            "t 6600\n",
            "t reward-arm: [19.94478221900517, 5.503470707158839, 460.4072702751878, 26.96352213918368, 18.887405587211866, 14.773464668179223]\n",
            "t numplay: [58.0, 27.0, 849.0, 73.0, 59.0, 47.0] 1113.0\n",
            "t mu-hat: [0.3380471562543249, 0.19655252525567282, 0.5416556120884563, 0.3643719207997795, 0.3147900931201978, 0.30778051392040046]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 468.3800000000291\n",
            "2 4\n",
            "335.1643966153292 0 {(3, 0.3643719207997795), (2, 0.5417368689130205), (0, 0.3380471562543249), (4, 0.3147900931201978)}\n",
            "\n",
            "t 6700\n",
            "t reward-arm: [72.05691075195259, 5.794760694983822, 469.34694049948826, 28.331841145735346, 18.887405587211866, 14.773464668179223]\n",
            "t numplay: [137.0, 28.0, 866.0, 76.0, 59.0, 47.0] 1213.0\n",
            "t mu-hat: [0.5221515271880622, 0.19981933430978696, 0.5413459521332045, 0.36794598890565383, 0.3147900931201978, 0.30778051392040046]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 476.4800000000296\n",
            "2 4\n",
            "376.8592781762706 0 {(3, 0.36794598890565383), (2, 0.5413459521332045), (0, 0.5210852162447334), (4, 0.3147900931201978)}\n",
            "\n",
            "Arm 0 Changepoint Detected at time 6780\n",
            "t 6800\n",
            "t reward-arm: [12.56303913580754, 5.794760694983822, 469.34694049948814, 28.331841145735346, 18.88740558721187, 14.773464668179223]\n",
            "t numplay: [20.0, 28.0, 866.0, 76.0, 59.0, 47.0] 1096.0\n",
            "t mu-hat: [0.5982399588479781, 0.19981933430978696, 0.5413459521332044, 0.36794598890565383, 0.31479009312019784, 0.30778051392040046]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 481.4800000000307\n",
            "0 4\n",
            "11.255967772641236 0 {(3, 0.36794598890565383), (2, 0.5413459521332044), (0, 0.5956049306493908), (4, 0.31479009312019784)}\n",
            "\n",
            "t 6900\n",
            "t reward-arm: [73.56102562297644, 5.980242768383632, 469.34694049948814, 28.638227273333346, 20.817781578433056, 14.773464668179223]\n",
            "t numplay: [115.0, 29.0, 866.0, 77.0, 62.0, 47.0] 1196.0\n",
            "t mu-hat: [0.6341467726118659, 0.19934142561278773, 0.5413459521332044, 0.36715675991453006, 0.3304409774354453, 0.30778051392040046]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 487.13000000003177\n",
            "0 4\n",
            "90.04500051211987 0 {(3, 0.36715675991453006), (2, 0.5413459521332044), (0, 0.6331818873760999), (4, 0.3304409774354453)}\n",
            "\n",
            "t 7000\n",
            "t reward-arm: [136.11564214026333, 6.110481658448701, 471.0063070799707, 29.53132368158738, 20.817781578433056, 14.773464668179223]\n",
            "t numplay: [209.0, 30.0, 869.0, 79.0, 62.0, 47.0] 1296.0\n",
            "t mu-hat: [0.6481697244774445, 0.19711231156286133, 0.5413865598620353, 0.3691415460198423, 0.3304409774354453, 0.30778051392040046]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 493.5800000000327\n",
            "0 4\n",
            "170.29077145163416 0 {(3, 0.3691415460198423), (2, 0.5413865598620353), (0, 0.6477990420409859), (4, 0.3304409774354453)}\n",
            "\n",
            "t 7100\n",
            "t reward-arm: [200.86175686346144, 6.110481658448701, 471.0063070799707, 29.531323681587384, 20.817781578433056, 14.773464668179221]\n",
            "t numplay: [309.0, 30.0, 869.0, 79.0, 62.0, 47.0] 1396.0\n",
            "t mu-hat: [0.6479411511724562, 0.19711231156286133, 0.5413865598620353, 0.3691415460198423, 0.3304409774354453, 0.30778051392040046]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 498.58000000003386\n",
            "0 4\n",
            "253.68197048000778 0 {(3, 0.3691415460198423), (2, 0.5413865598620353), (0, 0.6479662759016206), (4, 0.3304409774354453)}\n",
            "\n",
            "t 7200\n",
            "t reward-arm: [263.29943300924083, 6.389808932021492, 471.575297035562, 29.679424889011322, 22.343735139539433, 14.773464668179221]\n",
            "t numplay: [403.0, 32.0, 870.0, 80.0, 64.0, 47.0] 1496.0\n",
            "t mu-hat: [0.6517312698248535, 0.193630573697621, 0.541418251475961, 0.3664126529507571, 0.3437497713775297, 0.30778051392040046]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 504.8300000000349\n",
            "0 4\n",
            "334.6606915110008 0 {(3, 0.3664126529507571), (2, 0.541418251475961), (0, 0.6517231891800048), (4, 0.3437497713775297)}\n",
            "\n",
            "t 7300\n",
            "t reward-arm: [329.0939783775764, 6.389808932021492, 471.575297035562, 29.679424889011322, 22.343735139539433, 14.773464668179221]\n",
            "t numplay: [503.0, 32.0, 870.0, 80.0, 64.0, 47.0] 1596.0\n",
            "t mu-hat: [0.6529642428126515, 0.193630573697621, 0.541418251475961, 0.3664126529507571, 0.3437497713775297, 0.30778051392040046]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 509.830000000036\n",
            "0 4\n",
            "418.8497617590342 0 {(3, 0.3664126529507571), (2, 0.541418251475961), (0, 0.6527049973111277), (4, 0.3437497713775297)}\n",
            "\n",
            "t 7400\n",
            "t reward-arm: [391.53929628448475, 6.389808932021492, 471.575297035562, 30.084788933313497, 24.31224436584424, 14.773464668179221]\n",
            "t numplay: [599.0, 32.0, 870.0, 81.0, 67.0, 47.0] 1696.0\n",
            "t mu-hat: [0.6525654938074745, 0.193630573697621, 0.541418251475961, 0.3668876699184573, 0.35753300538006233, 0.30778051392040046]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 515.030000000034\n",
            "0 4\n",
            "501.31078106789676 0 {(3, 0.3668876699184573), (2, 0.541418251475961), (0, 0.6524980955665729), (4, 0.35753300538006233)}\n",
            "\n",
            "t 7500\n",
            "t reward-arm: [457.75894952414114, 6.389808932021492, 471.5752970355621, 30.084788933313497, 24.31224436584424, 14.773464668179221]\n",
            "t numplay: [699.0, 32.0, 870.0, 81.0, 67.0, 47.0] 1796.0\n",
            "t mu-hat: [0.6539413564630587, 0.193630573697621, 0.541418251475961, 0.3668876699184573, 0.35753300538006233, 0.30778051392040046]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 520.0300000000294\n",
            "0 4\n",
            "585.495698174781 0 {(3, 0.3668876699184573), (2, 0.541418251475961), (0, 0.6538279312980676), (4, 0.35753300538006233)}\n",
            "\n",
            "t 7600\n",
            "t reward-arm: [519.0975463726018, 6.629693970369421, 472.6868538260082, 30.375700731516574, 24.31224436584424, 14.773464668179221]\n",
            "t numplay: [795.0, 33.0, 872.0, 82.0, 67.0, 47.0] 1896.0\n",
            "t mu-hat: [0.6521325959454796, 0.19499099912851237, 0.5414511498579704, 0.3659722979700792, 0.35753300538006233, 0.30778051392040046]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 526.030000000025\n",
            "0 4\n",
            "668.4419329963573 0 {(3, 0.3659722979700792), (2, 0.5414511498579704), (0, 0.6520173286759552), (4, 0.35753300538006233)}\n",
            "\n",
            "t 7700\n",
            "t reward-arm: [583.0765760382906, 6.606880664994324, 473.03889301118767, 30.375700731516574, 24.31224436584424, 14.773464668179221]\n",
            "t numplay: [893.0, 34.0, 873.0, 82.0, 67.0, 47.0] 1996.0\n",
            "t mu-hat: [0.6522109351658731, 0.18876801899983783, 0.5412344313629149, 0.3659722979700792, 0.35753300538006233, 0.30778051392040046]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 531.5800000000205\n",
            "0 4\n",
            "751.6597886509802 0 {(3, 0.3659722979700792), (2, 0.5414511498579704), (0, 0.6522109351658731), (4, 0.35753300538006233)}\n",
            "\n",
            "t 7800\n",
            "t reward-arm: [646.8599267989898, 7.023143680831332, 474.1685974958189, 30.375700731516574, 24.31224436584424, 14.773464668179221]\n",
            "t numplay: [990.0, 35.0, 875.0, 82.0, 67.0, 47.0] 2096.0\n",
            "t mu-hat: [0.6527345376377294, 0.195087324467537, 0.5412883533057293, 0.3659722979700792, 0.35753300538006233, 0.30778051392040046]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 537.230000000016\n",
            "0 4\n",
            "834.9476578355367 0 {(3, 0.3659722979700792), (2, 0.5412883533057293), (0, 0.6527966893081859), (4, 0.35753300538006233)}\n",
            "\n",
            "t 7900\n",
            "t reward-arm: [707.9863216297952, 7.176399380223883, 474.1685974958189, 30.82911038501389, 24.98911390827372, 14.773464668179221]\n",
            "t numplay: [1086.0, 36.0, 875.0, 84.0, 68.0, 47.0] 2196.0\n",
            "t mu-hat: [0.6513213630448897, 0.19395674000605087, 0.5412883533057293, 0.3626954162942811, 0.3621610711344017, 0.30778051392040046]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 543.3300000000116\n",
            "0 4\n",
            "916.9687279167331 0 {(3, 0.3626954162942811), (2, 0.5412883533057293), (0, 0.651303764628632), (4, 0.3621610711344017)}\n",
            "\n",
            "8, t 100\n",
            "t reward-arm: [1.4114644504978895, 1.8653174036098807, 5.272601861033289, 19.652996879035662, 22.913234902134, 3.148459557933011]\n",
            "t numplay: [6.0, 7.0, 12.0, 31.0, 35.0, 9.0] 100.0\n",
            "t mu-hat: [0.20163777864255564, 0.2331646754512351, 0.4055847585410222, 0.6141561524698644, 0.6364787472815, 0.3148459557933011]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 9.900000000000006\n",
            "4 4\n",
            "56.05153995277122 0 {(3, 0.6119966112009225), (2, 0.4055847585410222), (4, 0.6364787472815)}\n",
            "\n",
            "t 200\n",
            "t reward-arm: [1.7117843418342045, 3.075636477140014, 9.577072958857038, 39.31240806008118, 54.19132795058533, 5.003688543218213]\n",
            "t numplay: [8.0, 11.0, 21.0, 63.0, 83.0, 14.0] 200.0\n",
            "t mu-hat: [0.19019826020380048, 0.25630303976166785, 0.43532149812986537, 0.6142563759387685, 0.6451348565545872, 0.33357923621454755]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 16.70000000000003\n",
            "4 4\n",
            "119.81771831031232 0 {(3, 0.6118824925394856), (2, 0.43532149812986537), (4, 0.6451348565545872)}\n",
            "\n",
            "t 300\n",
            "t reward-arm: [2.1602907106776548, 3.585664800587755, 13.411406651622737, 60.56635069825963, 85.785214659791, 6.032524249171145]\n",
            "t numplay: [10.0, 13.0, 29.0, 98.0, 133.0, 17.0] 300.0\n",
            "t mu-hat: [0.19639006460705952, 0.2561189143276968, 0.44704688838742457, 0.6117813201844408, 0.6401881691029179, 0.3351402360650636]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 22.250000000000046\n",
            "4 4\n",
            "186.56450138823473 0 {(3, 0.6117813201844408), (2, 0.44704688838742457), (4, 0.6401881691029179)}\n",
            "\n",
            "t 400\n",
            "t reward-arm: [2.791251037298491, 3.941039767224195, 18.18248836150297, 80.37147937283214, 119.24618370018626, 6.676756035600456]\n",
            "t numplay: [14.0, 14.0, 38.0, 130.0, 185.0, 19.0] 400.0\n",
            "t mu-hat: [0.18608340248656605, 0.262735984481613, 0.46621765029494794, 0.6135227433040621, 0.6411085145171305, 0.3338378017800228]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 27.85000000000006\n",
            "4 4\n",
            "254.6331982413268 0 {(3, 0.6135227433040622), (2, 0.46621765029494794), (4, 0.6421339286387774)}\n",
            "\n",
            "t 500\n",
            "t reward-arm: [2.791251037298491, 4.140559579034839, 21.169337028419893, 100.11839194615627, 157.6409390516782, 7.265635781150337]\n",
            "t numplay: [14.0, 15.0, 44.0, 162.0, 244.0, 21.0] 500.0\n",
            "t mu-hat: [0.18608340248656605, 0.25878497368967746, 0.4704297117426643, 0.6142232634733513, 0.6434324042925641, 0.33025617187046985]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 31.300000000000075\n",
            "4 4\n",
            "326.37686881270685 0 {(3, 0.6142232634733513), (2, 0.4704297117426643), (4, 0.6436568661828425)}\n",
            "\n",
            "t 600\n",
            "t reward-arm: [3.342706842346071, 4.296872655887343, 22.98482349394834, 123.56346381185983, 192.70538074556356, 7.435685571891182]\n",
            "t numplay: [17.0, 16.0, 48.0, 199.0, 298.0, 22.0] 600.0\n",
            "t mu-hat: [0.18570593568589283, 0.25275721505219667, 0.46907803048874164, 0.6178173190592992, 0.644499601155731, 0.32329067703874703]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 35.7\n",
            "4 4\n",
            "398.2695996643484 0 {(3, 0.6178173190592992), (2, 0.4690780304887416), (4, 0.644284778263508)}\n",
            "\n",
            "t 700\n",
            "t reward-arm: [3.3427068423460704, 4.296872655887343, 26.1343685875625, 136.32101764517682, 239.45955887260027, 7.435685571891183]\n",
            "t numplay: [17.0, 16.0, 54.0, 221.0, 370.0, 22.0] 700.0\n",
            "t mu-hat: [0.1857059356858928, 0.25275721505219667, 0.4751703379556818, 0.6140586380413371, 0.6454435549126691, 0.3232906770387471]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 37.69999999999993\n",
            "4 4\n",
            "473.4892857612475 0 {(3, 0.6143313882178028), (2, 0.4751703379556818), (4, 0.6454435549126691)}\n",
            "\n",
            "t 800\n",
            "t reward-arm: [3.7684029780653674, 4.776514819408737, 28.15083744082742, 152.37578415039684, 282.47509696171437, 7.736330928683506]\n",
            "t numplay: [18.0, 18.0, 58.0, 247.0, 436.0, 23.0] 800.0\n",
            "t mu-hat: [0.19833699884554565, 0.25139551681098615, 0.4771328379801258, 0.6144184844774067, 0.6463961028872183, 0.3223471220284794]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 41.09999999999985\n",
            "4 4\n",
            "547.2116995339273 0 {(3, 0.614023359101704), (2, 0.4771328379801258), (4, 0.6463961028872183)}\n",
            "\n",
            "t 900\n",
            "t reward-arm: [3.7684029780653674, 4.99042502911167, 32.71716959860321, 162.59150993949976, 328.3108154307805, 7.98773102968128]\n",
            "t numplay: [18.0, 19.0, 67.0, 265.0, 507.0, 24.0] 900.0\n",
            "t mu-hat: [0.19833699884554565, 0.2495212514555835, 0.4811348470382826, 0.6112462779680442, 0.6462811327377569, 0.3195092411872512]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 43.94999999999979\n",
            "4 4\n",
            "621.2302852652593 0 {(3, 0.6111232292268503), (2, 0.4811348470382826), (4, 0.6462811327377569)}\n",
            "\n",
            "t 1000\n",
            "t reward-arm: [3.7684029780653674, 4.99042502911167, 32.71716959860321, 176.24830684789708, 377.9312217055886, 7.987731029681281]\n",
            "t numplay: [18.0, 19.0, 67.0, 288.0, 584.0, 24.0] 1000.0\n",
            "t mu-hat: [0.19833699884554565, 0.2495212514555835, 0.4811348470382826, 0.6098557330377061, 0.6460362764198095, 0.3195092411872512]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 45.099999999999724\n",
            "4 4\n",
            "698.8581325223155 0 {(3, 0.6098557330377061), (2, 0.4811348470382826), (4, 0.6460866417864046)}\n",
            "\n",
            "t 1100\n",
            "t reward-arm: [3.9679701459691885, 6.174618189551375, 33.68112831946384, 179.88602401771, 434.8108570630933, 8.386085692357256]\n",
            "t numplay: [19.0, 22.0, 69.0, 295.0, 670.0, 25.0] 1100.0\n",
            "t mu-hat: [0.19839850729845943, 0.2684616604152772, 0.48115897599234053, 0.6077230541138852, 0.6480042579181718, 0.322541757398356]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 47.549999999999706\n",
            "4 4\n",
            "774.495295888703 0 {(3, 0.6077230541138852), (2, 0.48115897599234053), (4, 0.6482891050340163)}\n",
            "\n",
            "t 1200\n",
            "t reward-arm: [3.9679701459691885, 6.174618189551375, 37.604430051375644, 186.73703192591177, 487.4557793791645, 8.612265322436082]\n",
            "t numplay: [19.0, 22.0, 76.0, 307.0, 750.0, 26.0] 1200.0\n",
            "t mu-hat: [0.19839850729845943, 0.2684616604152772, 0.4883692214464369, 0.6062890646945187, 0.6490756050321764, 0.3189727897198549]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 49.49999999999966\n",
            "4 4\n",
            "850.7163011191493 0 {(3, 0.6062890646945187), (2, 0.4883692214464369), (4, 0.6493665012381369)}\n",
            "\n",
            "t 1300\n",
            "t reward-arm: [4.426194255208197, 7.011948165779396, 39.18141579246918, 190.39631693769542, 546.4608592611107, 8.612265322436082]\n",
            "t numplay: [21.0, 24.0, 79.0, 313.0, 837.0, 26.0] 1300.0\n",
            "t mu-hat: [0.20119064796400898, 0.2804779266311758, 0.4897676974058648, 0.6063576972538071, 0.6521012640347383, 0.3189727897198549]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 51.849999999999646\n",
            "4 4\n",
            "927.5250961023862 0 {(3, 0.6063576972538071), (2, 0.4897676974058648), (1, 0.2804779266311758), (4, 0.6522100255540992)}\n",
            "\n",
            "t 1400\n",
            "t reward-arm: [4.4261942552081965, 7.011948165779396, 40.27679967268927, 199.34647102550437, 600.4717050713804, 8.612265322436082]\n",
            "t numplay: [21.0, 24.0, 81.0, 328.0, 920.0, 26.0] 1400.0\n",
            "t mu-hat: [0.20119064796400893, 0.2804779266311758, 0.49118048381328383, 0.6059163253054844, 0.6519779642468843, 0.3189727897198549]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 52.8999999999996\n",
            "4 4\n",
            "1006.4094040255225 0 {(3, 0.6059322476474122), (2, 0.49118048381328383), (1, 0.2804779266311758), (4, 0.6519779642468843)}\n",
            "\n",
            "t 1500\n",
            "t reward-arm: [4.494618176724015, 7.287373443054097, 42.817807287143125, 213.3405004246539, 644.3053609073294, 8.99315336849988]\n",
            "t numplay: [22.0, 25.0, 86.0, 351.0, 989.0, 27.0] 1500.0\n",
            "t mu-hat: [0.1954181815966963, 0.2802835939636191, 0.492158704449921, 0.606080967115494, 0.6508134958659892, 0.32118404887499574]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 55.89999999999953\n",
            "4 4\n",
            "1081.8024647194654 0 {(3, 0.606080967115494), (2, 0.492158704449921), (1, 0.2802835939636191), (4, 0.6507635750652793)}\n",
            "\n",
            "t 1600\n",
            "t reward-arm: [4.494618176724015, 7.287373443054096, 43.15534344251249, 222.95170960560353, 698.3051693766763, 8.99315336849988]\n",
            "t numplay: [22.0, 25.0, 87.0, 367.0, 1072.0, 27.0] 1600.0\n",
            "t mu-hat: [0.1954181815966963, 0.28028359396361907, 0.490401630028551, 0.6058470369717487, 0.6507969891674523, 0.32118404887499574]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 56.84999999999948\n",
            "4 4\n",
            "1160.7563415853872 0 {(3, 0.6058470369717487), (2, 0.490401630028551), (1, 0.28028359396361907), (4, 0.65090703707993)}\n",
            "\n",
            "t 1700\n",
            "t reward-arm: [4.831341412872337, 7.554257773402226, 43.15534344251249, 230.02305228444527, 752.4327964449991, 9.878639259097326]\n",
            "t numplay: [24.0, 26.0, 87.0, 379.0, 1155.0, 29.0] 1700.0\n",
            "t mu-hat: [0.19325365651489348, 0.27978732494082315, 0.490401630028551, 0.6053238218011717, 0.650893422530276, 0.3292879753032442]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 59.29999999999945\n",
            "4 4\n",
            "1237.583320826826 0 {(3, 0.6053238218011717), (2, 0.490401630028551), (4, 0.650928264033992)}\n",
            "\n",
            "t 1800\n",
            "t reward-arm: [5.1339167019209935, 7.554257773402226, 45.061231308583444, 238.69861011134708, 803.0184286767062, 9.878639259097326]\n",
            "t numplay: [26.0, 26.0, 91.0, 394.0, 1234.0, 29.0] 1800.0\n",
            "t mu-hat: [0.19014506303411086, 0.27978732494082315, 0.48979599248460265, 0.604300278762904, 0.6502173511552277, 0.3292879753032442]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 61.54999999999941\n",
            "4 4\n",
            "1314.6181382566165 0 {(3, 0.604300278762904), (2, 0.48979599248460265), (4, 0.6503419502581422)}\n",
            "\n",
            "t 1900\n",
            "t reward-arm: [5.1339167019209935, 7.554257773402226, 45.06123130858344, 249.94571029952527, 855.3850788205625, 10.172853802718967]\n",
            "t numplay: [26.0, 26.0, 91.0, 412.0, 1315.0, 30.0] 1900.0\n",
            "t mu-hat: [0.19014506303411086, 0.27978732494082315, 0.4897959924846026, 0.6051954244540564, 0.6499886617177527, 0.328156574281257]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 62.79999999999935\n",
            "4 4\n",
            "1393.1862835462866 0 {(3, 0.604884617998665), (2, 0.4897959924846026), (4, 0.6499886617177527)}\n",
            "\n",
            "t 2000\n",
            "t reward-arm: [5.302518414005846, 7.554257773402226, 46.9080523182798, 251.96840532157458, 916.6234981745235, 10.172853802718967]\n",
            "t numplay: [27.0, 26.0, 95.0, 416.0, 1406.0, 30.0] 2000.0\n",
            "t mu-hat: [0.1893756576430659, 0.27978732494082315, 0.4886255449820813, 0.6042407801476609, 0.6514737016165768, 0.328156574281257]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 64.44999999999933\n",
            "4 0\n",
            "1472.1107553093755 0 {(3, 0.6042407801476608), (2, 0.4886255449820813), (4, 0.6514476297584461)}\n",
            "\n",
            "Arm 4 Changepoint Detected at time 2030\n",
            "t 2100\n",
            "t reward-arm: [5.302518414005846, 7.554257773402227, 67.93710585995635, 256.15861393441173, 5.648844226522511, 10.548729565918755]\n",
            "t numplay: [27.0, 26.0, 132.0, 434.0, 22.0, 32.0] 673.0\n",
            "t mu-hat: [0.1893756576430659, 0.27978732494082326, 0.5108053072177169, 0.5888703768607166, 0.2456019228922831, 0.31965847169450773]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 97.34999999999977\n",
            "3 0\n",
            "31.512344902904793 0 {(3, 0.5888703768607166), (2, 0.5097713680553947)}\n",
            "\n",
            "t 2200\n",
            "t reward-arm: [5.9907878531843615, 18.023294145367863, 107.17918824691762, 260.4579305743181, 5.969864188011882, 10.699390521880968]\n",
            "t numplay: [28.0, 42.0, 200.0, 447.0, 23.0, 33.0] 773.0\n",
            "t mu-hat: [0.2065788914891159, 0.41914637547367123, 0.533229792273222, 0.5813793093176743, 0.24874434116716174, 0.3146879565259108]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 114.45000000000017\n",
            "3 0\n",
            "82.64984610100977 0 {(3, 0.5813793093176743), (2, 0.533229792273222), (1, 0.4118642245546045)}\n",
            "\n",
            "t 2300\n",
            "t reward-arm: [5.9907878531843615, 81.56197961456051, 107.17918824691762, 260.4579305743181, 5.969864188011882, 10.69939052188097]\n",
            "t numplay: [28.0, 142.0, 200.0, 447.0, 23.0, 33.0] 873.0\n",
            "t mu-hat: [0.2065788914891159, 0.5703634938081155, 0.533229792273222, 0.5813793093176743, 0.24874434116716174, 0.31468795652591086]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 119.44999999999989\n",
            "3 0\n",
            "132.42520093535282 0 {(3, 0.5813793093176743), (2, 0.533229792273222), (1, 0.5690241630562508)}\n",
            "\n",
            "Arm 3 Changepoint Detected at time 2340\n",
            "t 2400\n",
            "t reward-arm: [6.7896453811210975, 130.406869936962, 107.17918824691762, 5.925731874219432, 6.333029212234923, 10.69939052188097]\n",
            "t numplay: [29.0, 217.0, 200.0, 20.0, 24.0, 33.0] 523.0\n",
            "t mu-hat: [0.22632151270403658, 0.5981966510869817, 0.533229792273222, 0.2821777082961634, 0.2533211684893969, 0.31468795652591086]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 132.85000000000036\n",
            "1 0\n",
            "33.16838752931899 0 {(3, 0.2821777082961634), (2, 0.533229792273222), (1, 0.5978880861328475)}\n",
            "\n",
            "t 2500\n",
            "t reward-arm: [6.7896453811210975, 194.470367168296, 107.17918824691762, 6.256375697619367, 6.333029212234923, 10.69939052188097]\n",
            "t numplay: [29.0, 316.0, 200.0, 21.0, 24.0, 33.0] 623.0\n",
            "t mu-hat: [0.22632151270403658, 0.6134711898053502, 0.533229792273222, 0.28438071352815303, 0.2533211684893969, 0.31468795652591086]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 138.2000000000015\n",
            "1 0\n",
            "105.96718406653676 0 {(3, 0.28438071352815303), (2, 0.533229792273222), (1, 0.6131759654895625)}\n",
            "\n",
            "t 2600\n",
            "t reward-arm: [7.544571598804747, 255.98439406414727, 109.01962919984666, 6.53791689753758, 6.333029212234923, 10.69939052188097]\n",
            "t numplay: [30.0, 411.0, 203.0, 22.0, 24.0, 33.0] 723.0\n",
            "t mu-hat: [0.24337327738079828, 0.6213213448158914, 0.5344099470580719, 0.2842572564146774, 0.2533211684893969, 0.31468795652591086]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 143.8000000000026\n",
            "1 0\n",
            "179.91096159474046 0 {(3, 0.2842572564146774), (2, 0.5344099470580719), (1, 0.6211509167373556)}\n",
            "\n",
            "t 2700\n",
            "t reward-arm: [8.115028215092881, 317.067520041898, 109.69969777917895, 7.530030796284014, 6.658785250537401, 10.69939052188097]\n",
            "t numplay: [31.0, 505.0, 204.0, 25.0, 25.0, 33.0] 823.0\n",
            "t mu-hat: [0.25359463172165253, 0.6266156522567153, 0.5351204769716046, 0.28961656908784666, 0.25610712502066924, 0.31468795652591086]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 150.30000000000368\n",
            "1 0\n",
            "253.78761247099035 0 {(3, 0.28961656908784666), (2, 0.5351204769716046), (1, 0.6268948354320646)}\n",
            "\n",
            "Arm 1 Changepoint Detected at time 2730\n",
            "t 2800\n",
            "t reward-arm: [8.115028215092881, 45.23267740938402, 109.69969777917893, 7.530030796284014, 6.658785250537401, 10.69939052188097]\n",
            "t numplay: [31.0, 70.0, 204.0, 25.0, 25.0, 33.0] 388.0\n",
            "t mu-hat: [0.25359463172165253, 0.637079963512451, 0.5351204769716046, 0.28961656908784666, 0.25610712502066924, 0.31468795652591086]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 155.30000000000481\n",
            "1 0\n",
            "52.96554508645769 0 {(3, 0.28961656908784666), (2, 0.5351204769716046), (1, 0.6390610533927223)}\n",
            "\n",
            "t 2900\n",
            "t reward-arm: [8.87507221825413, 108.78697012879513, 110.2566809802126, 8.038594515627693, 7.0924106166108105, 10.69939052188097]\n",
            "t numplay: [32.0, 166.0, 205.0, 26.0, 26.0, 33.0] 488.0\n",
            "t mu-hat: [0.2689415823713373, 0.6514189828071565, 0.5352266067000612, 0.29772572280102566, 0.2626818746892893, 0.31468795652591086]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 161.1000000000059\n",
            "1 0\n",
            "132.9618867348322 0 {(3, 0.29772572280102566), (2, 0.5352266067000612), (1, 0.6510994437793022)}\n",
            "\n",
            "t 3000\n",
            "t reward-arm: [8.875072218254132, 172.18021682972318, 110.2566809802126, 8.038594515627693, 7.0924106166108105, 10.699390521880968]\n",
            "t numplay: [32.0, 266.0, 205.0, 26.0, 26.0, 33.0] 588.0\n",
            "t mu-hat: [0.26894158237133736, 0.6448697259540194, 0.5352266067000612, 0.29772572280102566, 0.2626818746892893, 0.3146879565259108]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 166.10000000000704\n",
            "1 0\n",
            "214.3759019733941 0 {(3, 0.29772572280102566), (2, 0.5352266067000612), (1, 0.6453172609332928)}\n",
            "\n",
            "t 3100\n",
            "t reward-arm: [9.53495603641372, 234.91248335128398, 111.46257256083726, 8.038594515627693, 7.392401079976991, 10.699390521880968]\n",
            "t numplay: [33.0, 362.0, 207.0, 26.0, 27.0, 33.0] 688.0\n",
            "t mu-hat: [0.28043988342393295, 0.6471418274140055, 0.535877752696333, 0.29772572280102566, 0.2640143242848925, 0.3146879565259108]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 171.65000000000813\n",
            "1 0\n",
            "293.81657793289025 0 {(3, 0.29772572280102566), (2, 0.535877752696333), (1, 0.6472436284646639), (0, 0.28043988342393295)}\n",
            "\n",
            "t 3200\n",
            "t reward-arm: [9.53495603641372, 300.29534329502735, 111.46257256083727, 8.038594515627693, 7.392401079976991, 10.699390521880968]\n",
            "t numplay: [33.0, 462.0, 207.0, 26.0, 27.0, 33.0] 788.0\n",
            "t mu-hat: [0.28043988342393295, 0.6485860546328884, 0.5358777526963331, 0.29772572280102566, 0.2640143242848925, 0.3146879565259108]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 176.65000000000927\n",
            "1 0\n",
            "375.2837912527376 0 {(3, 0.29772572280102566), (2, 0.5358777526963331), (1, 0.6487035794567512), (0, 0.2804398834239329)}\n",
            "\n",
            "t 3300\n",
            "t reward-arm: [11.342029954612528, 361.45015941425686, 113.2976563464777, 8.038594515627693, 7.547082767085007, 10.69939052188097]\n",
            "t numplay: [35.0, 556.0, 210.0, 26.0, 28.0, 33.0] 888.0\n",
            "t mu-hat: [0.31505638762812577, 0.6489230869196712, 0.5369557172818848, 0.29772572280102566, 0.26024423334775887, 0.31468795652591086]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 182.25000000001035\n",
            "1 0\n",
            "454.74787679107914 0 {(3, 0.29772572280102566), (2, 0.5369557172818848), (1, 0.6488363327125172), (0, 0.31505638762812577)}\n",
            "\n",
            "t 3400\n",
            "t reward-arm: [11.342029954612528, 427.0434799852661, 113.2976563464777, 8.038594515627693, 7.547082767085007, 10.69939052188097]\n",
            "t numplay: [35.0, 656.0, 210.0, 26.0, 28.0, 33.0] 988.0\n",
            "t mu-hat: [0.31505638762812577, 0.6499900760810747, 0.5369557172818848, 0.29772572280102566, 0.26024423334775887, 0.31468795652591086]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 187.25000000001148\n",
            "1 0\n",
            "536.4523846401737 0 {(3, 0.29772572280102566), (2, 0.5369557172818848), (1, 0.6498530915602921), (0, 0.31505638762812577)}\n",
            "\n",
            "t 3500\n",
            "t reward-arm: [12.294963996759119, 487.5912837999865, 113.84648214419272, 8.582597640364636, 7.760603634354892, 10.69939052188097]\n",
            "t numplay: [36.0, 751.0, 211.0, 27.0, 30.0, 33.0] 1088.0\n",
            "t mu-hat: [0.33229632423673294, 0.6483926646276417, 0.5370117082273241, 0.306521344298737, 0.25034205272112553, 0.31468795652591086]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 193.45000000001255\n",
            "1 0\n",
            "615.638392619925 0 {(3, 0.306521344298737), (2, 0.5370117082273241), (1, 0.6483127968303088), (0, 0.33229632423673294)}\n",
            "\n",
            "t 3600\n",
            "t reward-arm: [12.29496399675912, 548.7172105224761, 114.27369097171193, 9.332293323958556, 8.182959468947448, 10.69939052188097]\n",
            "t numplay: [36.0, 846.0, 212.0, 29.0, 32.0, 33.0] 1188.0\n",
            "t mu-hat: [0.332296324236733, 0.6478361399320851, 0.5364962017451265, 0.31107644413195185, 0.24796846875598327, 0.31468795652591086]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 200.05000000001363\n",
            "1 0\n",
            "694.5986334370867 0 {(3, 0.31107644413195185), (2, 0.5364962017451265), (1, 0.6478658747552065), (0, 0.33229632423673294)}\n",
            "\n",
            "t 3700\n",
            "t reward-arm: [12.29496399675912, 612.0489956651954, 114.27369097171193, 9.332293323958556, 8.182959468947448, 10.69939052188097]\n",
            "t numplay: [36.0, 946.0, 212.0, 29.0, 32.0, 33.0] 1288.0\n",
            "t mu-hat: [0.332296324236733, 0.6463030577245992, 0.5364962017451265, 0.31107644413195185, 0.24796846875598327, 0.31468795652591086]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 205.05000000001476\n",
            "1 0\n",
            "775.8118103514962 0 {(3, 0.31107644413195185), (2, 0.5364962017451265), (1, 0.6464105557062408), (0, 0.332296324236733)}\n",
            "\n",
            "t 3800\n",
            "t reward-arm: [13.920248930550056, 674.5974207675856, 114.27369097171191, 9.474357212230789, 8.342138403457666, 10.69939052188097]\n",
            "t numplay: [38.0, 1042.0, 212.0, 30.0, 33.0, 33.0] 1388.0\n",
            "t mu-hat: [0.35692945975769375, 0.6467856383198328, 0.5364962017451264, 0.30562442620099317, 0.24535701186640194, 0.31468795652591086]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 210.70000000001585\n",
            "1 0\n",
            "854.5182745377894 0 {(3, 0.30562442620099317), (2, 0.5364962017451264), (1, 0.646705140372041), (0, 0.35692945975769375)}\n",
            "\n",
            "t 3900\n",
            "t reward-arm: [13.920248930550056, 740.0367810909147, 114.27369097171193, 9.474357212230789, 8.342138403457666, 10.69939052188097]\n",
            "t numplay: [38.0, 1142.0, 212.0, 30.0, 33.0, 33.0] 1488.0\n",
            "t mu-hat: [0.35692945975769375, 0.6474512520480443, 0.5364962017451265, 0.30562442620099317, 0.24535701186640194, 0.31468795652591086]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 215.70000000001698\n",
            "1 0\n",
            "935.723372926671 0 {(3, 0.30562442620099317), (2, 0.5364962017451265), (1, 0.6475374008758596), (0, 0.35692945975769375)}\n",
            "\n",
            "t 4000\n",
            "t reward-arm: [15.294961057518817, 803.510337225934, 114.27369097171193, 9.680817175430239, 8.766729216900343, 10.69939052188097]\n",
            "t numplay: [40.0, 1237.0, 212.0, 31.0, 35.0, 33.0] 1588.0\n",
            "t mu-hat: [0.3730478306711907, 0.6490390446089935, 0.5364962017451265, 0.30252553673219496, 0.2435202560250095, 0.31468795652591086]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 221.75000000001805\n",
            "1 3\n",
            "1014.2202232031148 0 {(3, 0.30252553673219496), (2, 0.5364962017451265), (1, 0.6491544073271883), (0, 0.3730478306711907)}\n",
            "\n",
            "t 4100\n",
            "t reward-arm: [15.294961057518817, 879.4216268973871, 114.27369097171194, 9.680817175430239, 8.766729216900343, 10.69939052188097]\n",
            "t numplay: [40.0, 1337.0, 212.0, 31.0, 35.0, 33.0] 1688.0\n",
            "t mu-hat: [0.3730478306711907, 0.657265789908361, 0.5364962017451265, 0.30252553673219496, 0.2435202560250095, 0.31468795652591086]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 226.75000000001918\n",
            "1 3\n",
            "1096.587353004943 0 {(3, 0.30252553673219496), (2, 0.5364962017451265), (1, 0.6571968848916594), (0, 0.3730478306711907)}\n",
            "\n",
            "t 4200\n",
            "t reward-arm: [15.698899889967691, 950.3526308349066, 114.60226536936793, 11.399161082547863, 8.766729216900343, 10.69939052188097]\n",
            "t numplay: [42.0, 1432.0, 213.0, 33.0, 35.0, 33.0] 1788.0\n",
            "t mu-hat: [0.3650906951155277, 0.6631909496405489, 0.5355246045297567, 0.3352694436043489, 0.2435202560250095, 0.31468795652591086]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 232.98000000002025\n",
            "1 3\n",
            "1177.864188901113 0 {(3, 0.3352694436043489), (2, 0.5355246045297567), (1, 0.6631652337487854), (0, 0.3650906951155277)}\n",
            "\n",
            "t 4300\n",
            "t reward-arm: [16.086680427921742, 1024.6271920404997, 115.17542967613682, 11.399161082547863, 8.766729216900343, 10.69939052188097]\n",
            "t numplay: [44.0, 1529.0, 214.0, 33.0, 35.0, 33.0] 1888.0\n",
            "t mu-hat: [0.3574817872871498, 0.6696909751898691, 0.5356996729122643, 0.3352694436043489, 0.2435202560250095, 0.31468795652591086]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 239.31000000002135\n",
            "1 3\n",
            "1261.610368665453 0 {(3, 0.3352694436043489), (2, 0.5355246045297567), (1, 0.6696909751898691), (0, 0.3574817872871498)}\n",
            "\n",
            "t 4400\n",
            "t reward-arm: [16.457945120518026, 1096.960002963537, 115.17542967613683, 11.399161082547863, 8.766729216900343, 10.699390521880968]\n",
            "t numplay: [45.0, 1628.0, 214.0, 33.0, 35.0, 33.0] 1988.0\n",
            "t mu-hat: [0.35778141566343535, 0.6733947225067752, 0.5356996729122643, 0.3352694436043489, 0.2435202560250095, 0.3146879565259108]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 244.86000000002247\n",
            "1 3\n",
            "1347.1312523567594 0 {(3, 0.3352694436043489), (2, 0.5356996729122643), (1, 0.6734048197589357), (0, 0.35778141566343535)}\n",
            "\n",
            "t 4500\n",
            "t reward-arm: [16.664997622954402, 1168.9111352046618, 116.649750498006, 11.399161082547863, 9.122690605474542, 10.69939052188097]\n",
            "t numplay: [46.0, 1723.0, 217.0, 33.0, 36.0, 33.0] 2088.0\n",
            "t mu-hat: [0.3545744175096681, 0.6780227002347227, 0.5350905986147064, 0.3352694436043489, 0.246559205553366, 0.31468795652591086]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 251.55000000002354\n",
            "1 3\n",
            "1432.1665024373951 0 {(3, 0.3352694436043489), (2, 0.5350905986147064), (1, 0.6780392792897364), (0, 0.3545744175096681)}\n",
            "\n",
            "t 4600\n",
            "t reward-arm: [16.664997622954402, 1244.229604565901, 116.649750498006, 11.399161082547863, 9.122690605474542, 10.69939052188097]\n",
            "t numplay: [46.0, 1823.0, 217.0, 33.0, 36.0, 33.0] 2188.0\n",
            "t mu-hat: [0.3545744175096681, 0.6821434235558668, 0.5350905986147064, 0.3352694436043489, 0.246559205553366, 0.31468795652591086]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 256.5500000000247\n",
            "1 3\n",
            "1519.8950215611362 0 {(3, 0.3352694436043489), (2, 0.5350905986147064), (1, 0.6821615432308579), (0, 0.3545744175096681)}\n",
            "\n",
            "t 4700\n",
            "t reward-arm: [17.22670375518909, 1314.8671440002718, 116.649750498006, 12.242484925544378, 9.821899686088218, 10.69939052188097]\n",
            "t numplay: [49.0, 1917.0, 217.0, 34.0, 38.0, 33.0] 2288.0\n",
            "t mu-hat: [0.34453407510378176, 0.6855407424401834, 0.5350905986147064, 0.34978528358698224, 0.25184358169456966, 0.31468795652591086]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 264.0500000000258\n",
            "1 3\n",
            "1604.7278991040698 0 {(3, 0.34978528358698224), (2, 0.5350905986147064), (1, 0.685577239852348), (0, 0.34453407510378176)}\n",
            "\n",
            "Arm 1 Changepoint Detected at time 4770\n",
            "t 4800\n",
            "t reward-arm: [17.22670375518909, 21.57777878423925, 116.649750498006, 12.242484925544378, 9.821899686088218, 10.69939052188097]\n",
            "t numplay: [49.0, 30.0, 217.0, 34.0, 38.0, 33.0] 401.0\n",
            "t mu-hat: [0.34453407510378176, 0.69605738013675, 0.5350905986147064, 0.34978528358698224, 0.25184358169456966, 0.31468795652591086]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 269.05000000002696\n",
            "1 3\n",
            "26.114545825261445 0 {(3, 0.34978528358698224), (2, 0.5350905986147064), (1, 0.698354633467335), (0, 0.34453407510378176)}\n",
            "\n",
            "t 4900\n",
            "t reward-arm: [17.22670375518909, 92.63598006377775, 116.649750498006, 15.535254041424956, 9.821899686088218, 10.69939052188097]\n",
            "t numplay: [49.0, 126.0, 217.0, 38.0, 38.0, 33.0] 501.0\n",
            "t mu-hat: [0.34453407510378176, 0.7294171658565177, 0.5350905986147064, 0.3983398472160245, 0.25184358169456966, 0.31468795652591086]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 273.85000000002805\n",
            "1 3\n",
            "119.65059675679775 0 {(3, 0.3983398472160245), (2, 0.5350905986147064), (1, 0.7287153001655585), (0, 0.34453407510378176)}\n",
            "\n",
            "t 5000\n",
            "t reward-arm: [17.22670375518909, 167.7619486799738, 116.649750498006, 15.535254041424956, 9.821899686088218, 10.69939052188097]\n",
            "t numplay: [49.0, 226.0, 217.0, 38.0, 38.0, 33.0] 601.0\n",
            "t mu-hat: [0.34453407510378176, 0.739039421497682, 0.5350905986147064, 0.3983398472160245, 0.25184358169456966, 0.31468795652591086]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 278.8500000000292\n",
            "1 3\n",
            "218.15745137263212 0 {(3, 0.3983398472160245), (2, 0.5350905986147064), (1, 0.7389116601025626), (0, 0.34453407510378176)}\n",
            "\n",
            "t 5100\n",
            "t reward-arm: [17.22670375518909, 239.75828587432397, 118.13309905130485, 16.316536971671574, 10.092110141913388, 10.69939052188097]\n",
            "t numplay: [49.0, 321.0, 220.0, 39.0, 39.0, 33.0] 701.0\n",
            "t mu-hat: [0.34453407510378176, 0.7445909499202608, 0.5345389097344111, 0.40791342429178934, 0.2523027535478347, 0.31468795652591086]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 284.9400000000302\n",
            "1 3\n",
            "316.742423449315 0 {(3, 0.40791342429178934), (2, 0.5345389097344111), (1, 0.7446719492055965), (0, 0.34453407510378176)}\n",
            "\n",
            "t 5200\n",
            "t reward-arm: [17.517640133930307, 310.632589973917, 118.44852727336873, 18.015871391141168, 10.318707497526653, 10.69939052188097]\n",
            "t numplay: [50.0, 416.0, 221.0, 41.0, 40.0, 33.0] 801.0\n",
            "t mu-hat: [0.3434831398809864, 0.7449222781149089, 0.533551924654814, 0.42894931883669446, 0.25167579262260126, 0.31468795652591086]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 291.07000000003126\n",
            "1 3\n",
            "414.7577898481713 0 {(3, 0.42894931883669446), (2, 0.533551924654814), (1, 0.7452157669807983), (0, 0.3434831398809864)}\n",
            "\n",
            "t 5300\n",
            "t reward-arm: [17.517640133930307, 387.08597256802386, 118.44852727336873, 18.015871391141168, 10.318707497526653, 10.69939052188097]\n",
            "t numplay: [50.0, 516.0, 221.0, 41.0, 40.0, 33.0] 901.0\n",
            "t mu-hat: [0.3434831398809864, 0.7487156142514968, 0.533551924654814, 0.42894931883669446, 0.25167579262260126, 0.31468795652591086]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 296.0700000000324\n",
            "1 3\n",
            "515.7804007508698 0 {(3, 0.42894931883669446), (2, 0.533551924654814), (1, 0.7488937589155071), (0, 0.3434831398809864)}\n",
            "\n",
            "t 5400\n",
            "t reward-arm: [17.597933767128495, 459.11035557210823, 118.89374494127756, 18.82034973380123, 10.696256056151373, 10.69939052188097]\n",
            "t numplay: [51.0, 612.0, 222.0, 42.0, 41.0, 33.0] 1001.0\n",
            "t mu-hat: [0.3384218032140095, 0.7489565343753805, 0.5331558069115586, 0.4376825519488658, 0.25467276324169935, 0.31468795652591086]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 302.2500000000335\n",
            "1 3\n",
            "615.1141759387925 0 {(3, 0.4376825519488658), (2, 0.5331558069115586), (1, 0.748989807253474), (0, 0.3384218032140095)}\n",
            "\n",
            "t 5500\n",
            "t reward-arm: [17.597933767128495, 534.9536435150044, 118.89374494127756, 18.820349733801233, 10.696256056151373, 10.69939052188097]\n",
            "t numplay: [51.0, 712.0, 222.0, 42.0, 41.0, 33.0] 1101.0\n",
            "t mu-hat: [0.3384218032140095, 0.7502856150280567, 0.5331558069115586, 0.4376825519488659, 0.25467276324169935, 0.31468795652591086]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 307.2500000000346\n",
            "1 3\n",
            "716.8361552073735 0 {(3, 0.4376825519488659), (2, 0.5331558069115586), (1, 0.750344774964985), (0, 0.3384218032140095)}\n",
            "\n",
            "t 5600\n",
            "t reward-arm: [17.68753658271995, 604.7819508994069, 119.94118168510411, 19.5367246771523, 11.221354676191975, 10.69939052188097]\n",
            "t numplay: [52.0, 806.0, 224.0, 43.0, 43.0, 33.0] 1201.0\n",
            "t mu-hat: [0.3337271053343387, 0.7494200135060803, 0.5330719186004628, 0.44401646993527955, 0.2550307880952722, 0.31468795652591086]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 314.11000000003565\n",
            "1 3\n",
            "815.4736461101704 0 {(3, 0.44401646993527955), (2, 0.5330719186004628), (1, 0.7493825225929762), (0, 0.3337271053343387)}\n",
            "\n",
            "t 5700\n",
            "t reward-arm: [17.68753658271995, 679.8576434288625, 119.94118168510414, 19.5367246771523, 11.221354676191975, 10.69939052188097]\n",
            "t numplay: [52.0, 906.0, 224.0, 43.0, 43.0, 33.0] 1301.0\n",
            "t mu-hat: [0.3337271053343387, 0.7495674128212376, 0.5330719186004629, 0.44401646993527955, 0.2550307880952722, 0.31468795652591086]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 319.1100000000368\n",
            "1 3\n",
            "917.0762484324745 0 {(3, 0.44401646993527955), (2, 0.5330719186004629), (1, 0.7494829770757944), (0, 0.3337271053343387)}\n",
            "\n",
            "t 5800\n",
            "t reward-arm: [17.936251025733796, 752.6746554140267, 119.94118168510413, 21.724020910843883, 11.221354676191975, 10.69939052188097]\n",
            "t numplay: [53.0, 1002.0, 224.0, 46.0, 43.0, 33.0] 1401.0\n",
            "t mu-hat: [0.3321527967728481, 0.7504233852582519, 0.5330719186004628, 0.4622132108690188, 0.2550307880952722, 0.31468795652591086]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 324.5100000000379\n",
            "1 3\n",
            "1016.4665769620813 0 {(3, 0.4622132108690188), (2, 0.5330719186004628), (1, 0.7504712896552963), (0, 0.3321527967728481)}\n",
            "\n",
            "t 5900\n",
            "t reward-arm: [17.936251025733796, 828.2504956020638, 119.94118168510411, 21.724020910843883, 11.221354676191975, 10.69939052188097]\n",
            "t numplay: [53.0, 1102.0, 224.0, 46.0, 43.0, 33.0] 1501.0\n",
            "t mu-hat: [0.3321527967728481, 0.7509070676355972, 0.5330719186004628, 0.4622132108690188, 0.2550307880952722, 0.31468795652591086]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 329.51000000003904\n",
            "1 3\n",
            "1118.3834638298865 0 {(3, 0.4622132108690188), (2, 0.5330719186004628), (1, 0.7509397910700233), (0, 0.3321527967728481)}\n",
            "\n",
            "t 6000\n",
            "t reward-arm: [18.722521101346256, 898.4131181715256, 120.69512529714152, 23.376645502518627, 11.221354676191975, 10.699390521880968]\n",
            "t numplay: [56.0, 1196.0, 225.0, 48.0, 43.0, 33.0] 1601.0\n",
            "t mu-hat: [0.32846528247975887, 0.7505539834348585, 0.5340492269785023, 0.4770743980105842, 0.2550307880952722, 0.3146879565259108]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 336.74000000004014\n",
            "1 4\n",
            "1216.9050887768326 0 {(3, 0.4770743980105842), (2, 0.5340492269785023), (1, 0.7506544596984343), (0, 0.32846528247975887)}\n",
            "\n",
            "Arm 1 Changepoint Detected at time 6010\n",
            "t 6100\n",
            "t reward-arm: [21.149533890549936, 5.737338915812218, 140.03956894427444, 30.939711452354327, 11.221354676191975, 11.059143497828668]\n",
            "t numplay: [60.0, 24.0, 260.0, 73.0, 43.0, 35.0] 495.0\n",
            "t mu-hat: [0.3467136703368842, 0.22949355663248874, 0.5365500725834269, 0.418104208815599, 0.2550307880952722, 0.30719843049524076]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 369.9400000000388\n",
            "2 4\n",
            "36.099926729812 0 {(3, 0.418104208815599), (2, 0.5356889864744332), (0, 0.3467136703368842)}\n",
            "\n",
            "t 6200\n",
            "t reward-arm: [21.149533890549936, 5.737338915812218, 194.6428417807273, 31.275018173375408, 11.221354676191975, 11.021542830660582]\n",
            "t numplay: [60.0, 24.0, 357.0, 75.0, 43.0, 36.0] 595.0\n",
            "t mu-hat: [0.3467136703368842, 0.22949355663248874, 0.5436950887729813, 0.41151339701809747, 0.2550307880952722, 0.2978795359637995]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 385.8400000000366\n",
            "2 4\n",
            "95.51516780692891 0 {(3, 0.41151339701809747), (2, 0.543789253422464), (0, 0.3467136703368842)}\n",
            "\n",
            "t 6300\n",
            "t reward-arm: [22.30488170297066, 6.198345683856368, 243.091723451691, 32.51840412092948, 11.221354676191975, 11.060991477973596]\n",
            "t numplay: [62.0, 26.0, 447.0, 80.0, 43.0, 37.0] 695.0\n",
            "t mu-hat: [0.3540457413169946, 0.22956835866134695, 0.5426154541332389, 0.40146177927073434, 0.2550307880952722, 0.29107872310456834]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 402.99000000003446\n",
            "2 4\n",
            "153.4823723627557 0 {(3, 0.40146177927073434), (2, 0.5429973369255813), (0, 0.3540457413169946)}\n",
            "\n",
            "t 6400\n",
            "t reward-arm: [22.30488170297066, 6.198345683856368, 299.60556257887583, 32.51840412092948, 11.221354676191975, 11.060991477973598]\n",
            "t numplay: [62.0, 26.0, 547.0, 80.0, 43.0, 37.0] 795.0\n",
            "t mu-hat: [0.3540457413169946, 0.22956835866134695, 0.5467254791585325, 0.40146177927073434, 0.2550307880952722, 0.2910787231045684]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 417.9900000000322\n",
            "2 4\n",
            "215.43843676808078 0 {(3, 0.40146177927073434), (2, 0.5468086552675943), (0, 0.3540457413169946)}\n",
            "\n",
            "t 6500\n",
            "t reward-arm: [23.078908640638844, 7.20787622418312, 348.04339932951444, 33.379996676887004, 12.607101038015106, 11.27868297956276]\n",
            "t numplay: [63.0, 30.0, 636.0, 83.0, 45.0, 38.0] 895.0\n",
            "t mu-hat: [0.36060794750998193, 0.2325121362639716, 0.546378962840682, 0.39738091282008337, 0.2740674138698936, 0.2891969994759682]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 435.1400000000301\n",
            "2 4\n",
            "273.3810751602253 0 {(3, 0.39738091282008337), (2, 0.5466145983610744), (0, 0.36060794750998193)}\n",
            "\n",
            "t 6600\n",
            "t reward-arm: [23.07890864063884, 7.20787622418312, 400.7364705002404, 34.370268643541046, 12.607101038015106, 11.567693563231355]\n",
            "t numplay: [63.0, 30.0, 732.0, 86.0, 45.0, 39.0] 995.0\n",
            "t mu-hat: [0.3606079475099819, 0.2325121362639716, 0.546707326739755, 0.39506055912116145, 0.2740674138698936, 0.2891923390807839]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 451.1900000000279\n",
            "2 4\n",
            "334.213021854057 0 {(3, 0.3969999637164522), (2, 0.546707326739755), (0, 0.3606079475099819)}\n",
            "\n",
            "t 6700\n",
            "t reward-arm: [85.74468401650586, 7.683889539059462, 400.7364705002404, 35.05165587705967, 13.301236761308868, 11.567693563231355]\n",
            "t numplay: [158.0, 32.0, 732.0, 88.0, 46.0, 39.0] 1095.0\n",
            "t mu-hat: [0.5392747422421752, 0.23284513754725641, 0.546707326739755, 0.3938388300793222, 0.2830050374746568, 0.2891923390807839]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 457.74000000002894\n",
            "2 4\n",
            "376.09753583984326 0 {(3, 0.3938388300793222), (2, 0.546707326739755), (0, 0.5388541588976623), (4, 0.2830050374746568)}\n",
            "\n",
            "Arm 0 Changepoint Detected at time 6710\n",
            "t 6800\n",
            "t reward-arm: [59.30282616814496, 7.683889539059462, 400.7364705002404, 35.05165587705967, 13.301236761308868, 11.567693563231355]\n",
            "t numplay: [90.0, 32.0, 732.0, 88.0, 46.0, 39.0] 1027.0\n",
            "t mu-hat: [0.6516794084411535, 0.23284513754725641, 0.546707326739755, 0.3938388300793222, 0.2830050374746568, 0.2891923390807839]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 462.7400000000301\n",
            "0 4\n",
            "70.78249295373601 0 {(3, 0.3938388300793222), (2, 0.5467073267397549), (0, 0.6511390094333063), (4, 0.2830050374746568)}\n",
            "\n",
            "t 6900\n",
            "t reward-arm: [121.21012548308606, 7.683889539059462, 402.6623283207616, 35.436549277310405, 13.301236761308868, 11.567693563231355]\n",
            "t numplay: [186.0, 32.0, 735.0, 89.0, 46.0, 39.0] 1127.0\n",
            "t mu-hat: [0.6481824892143639, 0.23284513754725641, 0.5470955547836435, 0.39373943641456005, 0.2830050374746568, 0.2891923390807839]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 468.3900000000311\n",
            "0 4\n",
            "153.9481138755129 0 {(3, 0.39373943641456005), (2, 0.5470955547836435), (0, 0.6481251020319778), (4, 0.2830050374746568)}\n",
            "\n",
            "t 7000\n",
            "t reward-arm: [182.3831695633498, 7.809811132976976, 403.99352725497135, 35.76402679940625, 14.839852727503933, 11.567693563231355]\n",
            "t numplay: [280.0, 33.0, 737.0, 90.0, 48.0, 39.0] 1227.0\n",
            "t mu-hat: [0.649050425492348, 0.22970032744049929, 0.5474167035975221, 0.39301128350995884, 0.30285413729599864, 0.2891923390807839]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 474.2900000000321\n",
            "0 4\n",
            "235.18270452928877 0 {(3, 0.39301128350995884), (2, 0.5474167035975221), (0, 0.6491988413206634), (4, 0.30285413729599864)}\n",
            "\n",
            "t 7100\n",
            "t reward-arm: [246.0783047352928, 7.809811132976976, 403.9935272549714, 35.764026799406246, 14.839852727503933, 11.567693563231355]\n",
            "t numplay: [380.0, 33.0, 737.0, 90.0, 48.0, 39.0] 1327.0\n",
            "t mu-hat: [0.6458748155781963, 0.22970032744049929, 0.5474167035975223, 0.39301128350995873, 0.30285413729599864, 0.2891923390807839]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 479.2900000000332\n",
            "0 4\n",
            "317.93336588959505 0 {(3, 0.39301128350995873), (2, 0.5474167035975223), (0, 0.645695146931029), (4, 0.30285413729599864)}\n",
            "\n",
            "t 7200\n",
            "t reward-arm: [309.3434527963001, 7.809811132976977, 403.99352725497135, 35.99380653186908, 14.839852727503933, 11.567693563231355]\n",
            "t numplay: [479.0, 33.0, 737.0, 91.0, 48.0, 39.0] 1427.0\n",
            "t mu-hat: [0.6444655266589585, 0.2297003274404993, 0.5474167035975221, 0.39123702752031614, 0.30285413729599864, 0.2891923390807839]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 484.6400000000343\n",
            "0 4\n",
            "399.89452361282275 0 {(3, 0.39123702752031614), (2, 0.5474167035975221), (0, 0.6443980899547748), (4, 0.30285413729599864)}\n",
            "\n",
            "t 7300\n",
            "t reward-arm: [373.3093951352545, 7.809811132976976, 403.99352725497135, 35.99380653186908, 14.839852727503935, 11.567693563231355]\n",
            "t numplay: [579.0, 33.0, 737.0, 91.0, 48.0, 39.0] 1527.0\n",
            "t mu-hat: [0.6436368881642318, 0.22970032744049929, 0.5474167035975221, 0.39123702752031614, 0.3028541372959987, 0.2891923390807839]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 489.64000000003546\n",
            "0 4\n",
            "481.9816992527058 0 {(3, 0.39123702752031614), (2, 0.5474167035975221), (0, 0.6434412205718066), (4, 0.3028541372959987)}\n",
            "\n",
            "t 7400\n",
            "t reward-arm: [436.3634632652178, 7.809811132976976, 404.35874149122475, 36.71163517416118, 16.137053586601517, 11.567693563231355]\n",
            "t numplay: [673.0, 33.0, 738.0, 94.0, 50.0, 39.0] 1627.0\n",
            "t mu-hat: [0.6474235360018068, 0.22970032744049929, 0.5471701508676925, 0.38643826499117034, 0.31641281542355915, 0.2891923390807839]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 495.69000000003643\n",
            "0 4\n",
            "562.0727631647128 0 {(3, 0.38643826499117034), (2, 0.5471701508676925), (0, 0.6474923736284801), (4, 0.31641281542355915)}\n",
            "\n",
            "t 7500\n",
            "t reward-arm: [502.10120338464185, 7.809811132976976, 404.35874149122475, 36.71163517416118, 16.137053586601517, 11.567693563231355]\n",
            "t numplay: [773.0, 33.0, 738.0, 94.0, 50.0, 39.0] 1727.0\n",
            "t mu-hat: [0.6487095650964365, 0.22970032744049929, 0.5471701508676925, 0.38643826499117034, 0.31641281542355915, 0.2891923390807839]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 500.69000000003757\n",
            "0 4\n",
            "645.1905894952399 0 {(3, 0.38643826499117034), (2, 0.5471701508676925), (0, 0.6489392513551223), (4, 0.31641281542355915)}\n",
            "\n",
            "t 7600\n",
            "t reward-arm: [562.1804966329164, 8.353299164921582, 404.35874149122475, 36.71163517416118, 16.752132396412787, 11.567693563231355]\n",
            "t numplay: [869.0, 36.0, 738.0, 94.0, 51.0, 39.0] 1827.0\n",
            "t mu-hat: [0.6461844788884097, 0.2257648422951779, 0.5471701508676925, 0.38643826499117034, 0.32215639223870746, 0.2891923390807839]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 506.99000000003866\n",
            "0 4\n",
            "725.6044013597975 0 {(3, 0.38643826499117034), (2, 0.5471701508676925), (0, 0.6460494952462014), (4, 0.32215639223870746)}\n",
            "\n",
            "t 7700\n",
            "t reward-arm: [626.7279454079351, 8.35329916492158, 404.3587414912248, 36.895881435851116, 17.341550910008742, 11.567693563231355]\n",
            "t numplay: [967.0, 36.0, 738.0, 95.0, 52.0, 39.0] 1927.0\n",
            "t mu-hat: [0.6474462245949743, 0.22576484229517785, 0.5471701508676926, 0.3843320982901158, 0.32719907377374985, 0.2891923390807839]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 512.6400000000398\n",
            "0 4\n",
            "806.875484453015 0 {(3, 0.38643826499117034), (2, 0.5471701508676926), (0, 0.6474462245949743), (4, 0.32719907377374985)}\n",
            "\n",
            "t 7800\n",
            "t reward-arm: [689.8144015310661, 8.73330231012904, 404.3587414912248, 37.139786728608, 19.17533872806672, 11.567693563231355]\n",
            "t numplay: [1063.0, 37.0, 738.0, 96.0, 54.0, 39.0] 2027.0\n",
            "t mu-hat: [0.6483218059502501, 0.2298237450033958, 0.5471701508676926, 0.38288439926400003, 0.3486425223284858, 0.2891923390807839]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 517.9900000000354\n",
            "0 4\n",
            "888.0692147569064 0 {(3, 0.38288439926400003), (2, 0.5471701508676925), (0, 0.6483192904540676), (4, 0.3486425223284858)}\n",
            "\n",
            "t 7900\n",
            "t reward-arm: [750.161142627421, 8.73330231012904, 406.6981349610391, 37.139786728608, 19.942188278634035, 11.567693563231355]\n",
            "t numplay: [1158.0, 37.0, 742.0, 96.0, 55.0, 39.0] 2127.0\n",
            "t mu-hat: [0.6472486131384133, 0.2298237450033958, 0.5473729945639827, 0.38288439926400003, 0.35611050497560776, 0.2891923390807839]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 523.340000000031\n",
            "0 4\n",
            "969.9458121153608 0 {(3, 0.38288439926400003), (2, 0.5473729945639827), (0, 0.64719078941775), (4, 0.35611050497560776)}\n",
            "\n",
            "9, t 100\n",
            "t reward-arm: [0.8846034453109956, 2.5852196140049144, 6.8133951564143125, 17.960655537642214, 24.531306272634723, 2.170795987541224]\n",
            "t numplay: [5.0, 8.0, 14.0, 29.0, 37.0, 7.0] 100.0\n",
            "t mu-hat: [0.14743390755183258, 0.28724662377832383, 0.45422634376095417, 0.5986885179214071, 0.6455606913851243, 0.271349498442653]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 9.700000000000005\n",
            "4 4\n",
            "56.12172349143634 0 {(3, 0.6001054382587061), (2, 0.45422634376095417), (1, 0.28724662377832383), (4, 0.6455606913851243)}\n",
            "\n",
            "t 200\n",
            "t reward-arm: [1.4271319296228744, 4.006745378357113, 14.15842353357226, 35.543211452584686, 52.4022050841334, 3.87704896574117]\n",
            "t numplay: [8.0, 13.0, 28.0, 58.0, 81.0, 12.0] 200.0\n",
            "t mu-hat: [0.1585702144025416, 0.2861960984540795, 0.4882215011576641, 0.6024273127556726, 0.639051281513822, 0.2982345358262438]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 17.60000000000003\n",
            "4 4\n",
            "117.57717758720098 0 {(3, 0.599625878881283), (2, 0.4882215011576641), (1, 0.2861960984540795), (4, 0.639051281513822)}\n",
            "\n",
            "t 300\n",
            "t reward-arm: [1.6613272768192202, 4.343273271865734, 19.958406733897977, 53.165766624956376, 88.56249751573728, 4.801388108314571]\n",
            "t numplay: [9.0, 14.0, 39.0, 87.0, 136.0, 15.0] 300.0\n",
            "t mu-hat: [0.16613272768192203, 0.2895515514577156, 0.49896016834744944, 0.6041564389199588, 0.6464415877061115, 0.3000867567696607]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 22.400000000000038\n",
            "4 4\n",
            "185.63316650922 0 {(3, 0.6038628970003641), (2, 0.49896016834744944), (1, 0.2895515514577156), (4, 0.6464415877061115)}\n",
            "\n",
            "t 400\n",
            "t reward-arm: [2.237101950697014, 4.493240126749164, 23.836654828917254, 70.15010540601665, 126.95984424384618, 5.512096010558407]\n",
            "t numplay: [11.0, 15.0, 47.0, 115.0, 195.0, 17.0] 400.0\n",
            "t mu-hat: [0.1864251625580845, 0.28082750792182276, 0.4965969756024428, 0.6047422879829022, 0.6477543073665621, 0.3062275561421337]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 26.850000000000048\n",
            "4 4\n",
            "256.07392516787615 0 {(3, 0.6047422879829022), (2, 0.4965969756024428), (1, 0.28082750792182276), (4, 0.6480156919681337)}\n",
            "\n",
            "t 500\n",
            "t reward-arm: [2.2371019506970136, 4.894206476780875, 26.208186212775235, 88.21540557682366, 168.06265213851322, 6.229672304078054]\n",
            "t numplay: [11.0, 17.0, 52.0, 144.0, 257.0, 19.0] 500.0\n",
            "t mu-hat: [0.18642516255808447, 0.27190035982115973, 0.4944940794863252, 0.60838210742637, 0.6514056284438496, 0.3114836152039027]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 30.300000000000065\n",
            "4 4\n",
            "328.5775615956489 0 {(3, 0.60838210742637), (2, 0.4944940794863252), (4, 0.6512338501973503)}\n",
            "\n",
            "t 600\n",
            "t reward-arm: [2.486281077703284, 5.415272265388732, 27.894868537217565, 105.70077949148583, 208.4923096292478, 6.274182587298233]\n",
            "t numplay: [12.0, 19.0, 56.0, 173.0, 320.0, 20.0] 600.0\n",
            "t mu-hat: [0.19125239059256033, 0.2707636132694366, 0.48938365854767657, 0.6074757442039416, 0.6495087527390898, 0.29877059939515394]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 33.800000000000004\n",
            "4 4\n",
            "401.93600057837824 0 {(3, 0.6074757442039415), (2, 0.48938365854767657), (4, 0.649416340930957)}\n",
            "\n",
            "t 700\n",
            "t reward-arm: [2.4634519879442007, 5.415272265388732, 30.918408968684773, 122.8737956455699, 250.48274297775427, 6.274182587298234]\n",
            "t numplay: [13.0, 19.0, 62.0, 201.0, 385.0, 20.0] 700.0\n",
            "t mu-hat: [0.1759608562817286, 0.2707636132694366, 0.49076839632832975, 0.6082861170572768, 0.6489190232584308, 0.298770599395154]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 36.54999999999992\n",
            "4 4\n",
            "476.65302934071224 0 {(3, 0.6082861170572768), (2, 0.49076839632832975), (4, 0.6486829418999706)}\n",
            "\n",
            "t 800\n",
            "t reward-arm: [2.9403723094073664, 5.636734081096165, 31.851254153276077, 128.7719149822455, 305.6533368197758, 6.342182152898045]\n",
            "t numplay: [15.0, 20.0, 64.0, 212.0, 468.0, 21.0] 800.0\n",
            "t mu-hat: [0.1837732693379604, 0.2684159086236269, 0.4900192946657858, 0.6045629811373029, 0.651712871683957, 0.2882810069499111]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 38.94999999999989\n",
            "4 4\n",
            "552.6201148561365 0 {(3, 0.6045629811373029), (2, 0.49001929466578575), (4, 0.651260155418043)}\n",
            "\n",
            "t 900\n",
            "t reward-arm: [3.03577383350736, 5.928225945628715, 33.89742747728069, 143.95591533106466, 349.81405434040767, 6.342182152898044]\n",
            "t numplay: [16.0, 21.0, 68.0, 237.0, 537.0, 21.0] 900.0\n",
            "t mu-hat: [0.17857493138278588, 0.26946481571039615, 0.4912670648881259, 0.6048567871053137, 0.6502119969152559, 0.2882810069499111]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 42.04999999999982\n",
            "4 4\n",
            "627.7020596133681 0 {(3, 0.6047933670619491), (2, 0.4912670648881259), (4, 0.6502119969152559)}\n",
            "\n",
            "t 1000\n",
            "t reward-arm: [3.269204506541299, 5.928225945628716, 35.76438718840772, 154.71095037993814, 399.77872933033984, 6.342182152898045]\n",
            "t numplay: [17.0, 21.0, 72.0, 255.0, 614.0, 21.0] 1000.0\n",
            "t mu-hat: [0.18162247258562772, 0.2694648157103962, 0.48992311216996876, 0.6043396499216334, 0.6500467143582762, 0.2882810069499111]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 43.54999999999976\n",
            "4 4\n",
            "704.9608058954439 0 {(3, 0.6043396499216334), (2, 0.48992311216996876), (4, 0.6501874088779535)}\n",
            "\n",
            "t 1100\n",
            "t reward-arm: [3.269204506541299, 6.337391371855478, 37.8548563132631, 168.52835997458828, 446.3552769741307, 6.342182152898044]\n",
            "t numplay: [17.0, 22.0, 76.0, 278.0, 686.0, 21.0] 1100.0\n",
            "t mu-hat: [0.18162247258562772, 0.27553875529806426, 0.49162151056185843, 0.6040443009841874, 0.6497165603699137, 0.2882810069499111]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 45.64999999999969\n",
            "4 4\n",
            "781.1015786283875 0 {(3, 0.6040443009841874), (2, 0.49162151056185843), (4, 0.6496154705891074)}\n",
            "\n",
            "t 1200\n",
            "t reward-arm: [3.269204506541299, 6.337391371855478, 38.90545162801222, 176.97367088557218, 500.91675032316914, 6.698405799763372]\n",
            "t numplay: [17.0, 22.0, 78.0, 292.0, 769.0, 22.0] 1200.0\n",
            "t mu-hat: [0.18162247258562772, 0.27553875529806426, 0.49247407124066106, 0.6040057026811337, 0.6505412341859339, 0.29123503477232054]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 46.94999999999965\n",
            "4 4\n",
            "858.9833447084551 0 {(3, 0.6040057026811337), (2, 0.49247407124066106), (4, 0.6506158866427028)}\n",
            "\n",
            "t 1300\n",
            "t reward-arm: [3.6648390093560153, 7.350801054280581, 40.27569612001212, 189.03765315645904, 547.0223978911532, 7.039938964606692]\n",
            "t numplay: [18.0, 25.0, 81.0, 312.0, 841.0, 23.0] 1300.0\n",
            "t mu-hat: [0.19288626365031658, 0.28272311747233003, 0.49116702585380634, 0.6039541634391663, 0.64967030628403, 0.29333079019194547]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 50.19999999999959\n",
            "4 4\n",
            "933.7504859808519 0 {(3, 0.6039541634391663), (2, 0.49116702585380634), (1, 0.28272311747233003), (4, 0.649823424614187)}\n",
            "\n",
            "t 1400\n",
            "t reward-arm: [3.6648390093560153, 7.350801054280581, 41.13295410837689, 197.75618881695354, 600.3791575541261, 7.039938964606692]\n",
            "t numplay: [18.0, 25.0, 83.0, 327.0, 924.0, 23.0] 1400.0\n",
            "t mu-hat: [0.19288626365031658, 0.28272311747233003, 0.4896780250997249, 0.6029152098077852, 0.6490585487071634, 0.29333079019194547]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 51.29999999999954\n",
            "4 4\n",
            "1012.1700995763725 0 {(3, 0.6029152098077852), (2, 0.4896780250997249), (1, 0.28272311747233003), (4, 0.6491605363159423)}\n",
            "\n",
            "t 1500\n",
            "t reward-arm: [3.9256008936902296, 7.937886565412556, 41.69308138175613, 204.31650244248306, 655.3127816830441, 7.251740599119705]\n",
            "t numplay: [20.0, 27.0, 84.0, 338.0, 1007.0, 24.0] 1500.0\n",
            "t mu-hat: [0.18693337589001094, 0.2834959487647341, 0.49050683978536624, 0.6027035470279736, 0.6501118865903216, 0.2900696239647882]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 53.84999999999952\n",
            "4 4\n",
            "1088.5841304615576 0 {(3, 0.6027035470279736), (2, 0.49050683978536624), (1, 0.2834959487647341), (4, 0.649985015462629)}\n",
            "\n",
            "t 1600\n",
            "t reward-arm: [3.9256008936902305, 7.937886565412556, 43.24797119641934, 213.23051730425087, 708.5980744198687, 7.251740599119705]\n",
            "t numplay: [20.0, 27.0, 87.0, 353.0, 1089.0, 24.0] 1600.0\n",
            "t mu-hat: [0.18693337589001097, 0.2834959487647341, 0.4914542181411289, 0.6023460940798047, 0.6500899765319896, 0.2900696239647882]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 55.04999999999947\n",
            "4 4\n",
            "1167.0607180124846 0 {(3, 0.6023460940798047), (2, 0.49145421814112883), (1, 0.2834959487647341), (4, 0.6500888722107097)}\n",
            "\n",
            "t 1700\n",
            "t reward-arm: [4.048481094543746, 8.442346086247582, 44.02189750729095, 226.17266332896293, 756.4601909273392, 7.251740599119705]\n",
            "t numplay: [21.0, 29.0, 89.0, 374.0, 1163.0, 24.0] 1700.0\n",
            "t mu-hat: [0.18402186793380662, 0.2814115362082527, 0.48913219452545503, 0.6031271022105678, 0.6498798891128343, 0.2900696239647882]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 57.549999999999415\n",
            "4 4\n",
            "1243.5065522013822 0 {(3, 0.6031271022105678), (2, 0.48913219452545503), (1, 0.2814115362082527), (4, 0.6499688269646444)}\n",
            "\n",
            "t 1800\n",
            "t reward-arm: [4.4031359518621676, 8.442346086247582, 44.43399395249877, 231.41852868561458, 813.2126303161942, 7.251740599119705]\n",
            "t numplay: [24.0, 29.0, 90.0, 383.0, 1250.0, 24.0] 1800.0\n",
            "t mu-hat: [0.1761254380744867, 0.2814115362082527, 0.4882856478296568, 0.6026524184521213, 0.6500500642015942, 0.2900696239647882]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 59.499999999999396\n",
            "4 4\n",
            "1321.4137621920727 0 {(3, 0.6026524184521213), (2, 0.4882856478296568), (1, 0.2814115362082527), (4, 0.6499803820728915)}\n",
            "\n",
            "t 1900\n",
            "t reward-arm: [4.4031359518621676, 8.442346086247582, 44.43399395249877, 238.4230445683758, 870.6841998128982, 7.251740599119705]\n",
            "t numplay: [24.0, 29.0, 90.0, 395.0, 1338.0, 24.0] 1900.0\n",
            "t mu-hat: [0.1761254380744867, 0.2814115362082527, 0.4882856478296568, 0.6020783953746863, 0.6502495891059733, 0.2900696239647882]\n",
            "T true mu: [0.2  0.3  0.5  0.6  0.65 0.35] Err: 60.09999999999936\n",
            "4 4\n",
            "1401.0868085764735 0 {(3, 0.6020783953746863), (2, 0.4882856478296568), (1, 0.2814115362082527), (4, 0.6503010577958449)}\n",
            "\n",
            "t 2000\n",
            "t reward-arm: [4.631305249543283, 8.719970823731796, 48.485265624368, 249.62257271452336, 917.1170475565219, 7.443842330441393]\n",
            "t numplay: [25.0, 30.0, 97.0, 413.0, 1410.0, 25.0] 2000.0\n",
            "t mu-hat: [0.17812712498243397, 0.2812893814107031, 0.49474760841191834, 0.6029530741896699, 0.6499766460358057, 0.28630162809389975]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 63.599999999999305\n",
            "4 0\n",
            "1476.3780220510132 0 {(3, 0.6029530741896699), (2, 0.49474760841191834), (1, 0.2812893814107031), (4, 0.6499521601441968)}\n",
            "\n",
            "Arm 4 Changepoint Detected at time 2040\n",
            "t 2100\n",
            "t reward-arm: [4.631305249543283, 8.719970823731796, 70.30223297527431, 255.41052561830423, 3.867031415552666, 7.638053954023649]\n",
            "t numplay: [25.0, 30.0, 137.0, 433.0, 18.0, 26.0] 669.0\n",
            "t mu-hat: [0.17812712498243397, 0.2812893814107031, 0.5094364708353211, 0.5885035152495489, 0.203527969239614, 0.2828908871860611]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 95.64999999999975\n",
            "3 0\n",
            "27.779010732785917 0 {(3, 0.5885035152495489), (2, 0.5106010489456817), (1, 0.2812893814107031)}\n",
            "\n",
            "Arm 3 Changepoint Detected at time 2180\n",
            "t 2200\n",
            "t reward-arm: [5.286471636103135, 8.719970823731794, 100.57627479349432, 6.351892287685644, 4.74324730251065, 7.794691166019222]\n",
            "t numplay: [26.0, 30.0, 191.0, 19.0, 22.0, 27.0] 315.0\n",
            "t mu-hat: [0.1957952457815976, 0.28128938141070303, 0.5238347645494495, 0.31759461438428216, 0.20622814358741956, 0.27838182735782935]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 122.10000000000029\n",
            "2 0\n",
            "3.851347063255139 0 {(3, 0.31466016056845403), (2, 0.5238347645494495), (1, 0.28128938141070303)}\n",
            "\n",
            "t 2300\n",
            "t reward-arm: [5.286471636103135, 10.00405247478017, 142.6255660531792, 12.061286689781738, 4.74324730251065, 8.028770214794513]\n",
            "t numplay: [26.0, 32.0, 269.0, 37.0, 22.0, 29.0] 415.0\n",
            "t mu-hat: [0.1957952457815976, 0.3031531052963688, 0.528242837233997, 0.3174022813100457, 0.20622814358741956, 0.2676256738264838]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 141.85000000000088\n",
            "2 0\n",
            "53.11021750521765 0 {(3, 0.3174022813100457), (2, 0.528242837233997), (1, 0.2956358750513167)}\n",
            "\n",
            "t 2400\n",
            "t reward-arm: [5.286471636103135, 73.1379770176914, 144.58350714765788, 12.06128668978174, 4.813865187129426, 8.02877021479451]\n",
            "t numplay: [26.0, 128.0, 272.0, 37.0, 23.0, 29.0] 515.0\n",
            "t mu-hat: [0.1957952457815976, 0.5669610621526465, 0.5296099162917871, 0.3174022813100458, 0.20057771613039274, 0.26762567382648367]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 147.55000000000197\n",
            "1 0\n",
            "99.87830823514213 0 {(3, 0.3174022813100458), (2, 0.5296099162917871), (1, 0.5658139816847532)}\n",
            "\n",
            "t 2500\n",
            "t reward-arm: [5.286471636103135, 138.8895696435681, 144.58350714765788, 12.061286689781738, 4.813865187129426, 8.028770214794513]\n",
            "t numplay: [26.0, 228.0, 272.0, 37.0, 23.0, 29.0] 615.0\n",
            "t mu-hat: [0.1957952457815976, 0.6065046709326118, 0.5296099162917871, 0.3174022813100457, 0.20057771613039274, 0.2676256738264838]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 152.5500000000031\n",
            "1 0\n",
            "170.5442047658241 0 {(3, 0.3174022813100457), (2, 0.5296099162917871), (1, 0.6062459096589096)}\n",
            "\n",
            "Arm 1 Changepoint Detected at time 2580\n",
            "t 2600\n",
            "t reward-arm: [6.610108534641567, 12.995025083353587, 145.69201355797145, 12.06128668978174, 4.813865187129426, 8.028770214794513]\n",
            "t numplay: [28.0, 20.0, 274.0, 37.0, 23.0, 29.0] 411.0\n",
            "t mu-hat: [0.22793477705660575, 0.6188107182549327, 0.5297891402108053, 0.3174022813100458, 0.20057771613039274, 0.2676256738264838]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 157.6500000000042\n",
            "1 0\n",
            "13.153315666128275 0 {(3, 0.3174022813100458), (2, 0.5297891402108053), (1, 0.6133503895208668)}\n",
            "\n",
            "t 2700\n",
            "t reward-arm: [7.311304432025061, 76.31820512509493, 146.25985894919862, 12.329275426745257, 4.967589766924339, 8.028770214794513]\n",
            "t numplay: [29.0, 116.0, 275.0, 38.0, 24.0, 29.0] 511.0\n",
            "t mu-hat: [0.2437101477341687, 0.6522923514965379, 0.5299270251782559, 0.31613526735244246, 0.19870359067697357, 0.2676256738264838]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 163.4500000000053\n",
            "1 0\n",
            "93.90115141225668 0 {(3, 0.31613526735244246), (2, 0.5299270251782559), (1, 0.6533864118359908)}\n",
            "\n",
            "t 2800\n",
            "t reward-arm: [7.311304432025061, 141.64624083876953, 146.25985894919864, 12.329275426745257, 4.967589766924339, 8.028770214794513]\n",
            "t numplay: [29.0, 216.0, 275.0, 38.0, 24.0, 29.0] 611.0\n",
            "t mu-hat: [0.2437101477341687, 0.6527476536348826, 0.529927025178256, 0.31613526735244246, 0.19870359067697357, 0.2676256738264838]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 168.45000000000644\n",
            "1 0\n",
            "177.19901659509856 0 {(3, 0.31613526735244246), (2, 0.5299270251782559), (1, 0.6528670999317314)}\n",
            "\n",
            "t 2900\n",
            "t reward-arm: [8.121065636996455, 204.5164362413259, 146.25985894919864, 12.774632283413094, 5.15774498115383, 8.02877021479451]\n",
            "t numplay: [30.0, 312.0, 275.0, 40.0, 25.0, 29.0] 711.0\n",
            "t mu-hat: [0.2619698592579502, 0.6534071445409773, 0.529927025178256, 0.31157639715641694, 0.19837480696745502, 0.26762567382648367]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 174.50000000000753\n",
            "1 0\n",
            "258.0862909593828 0 {(3, 0.31157639715641694), (2, 0.529927025178256), (1, 0.65339197770432)}\n",
            "\n",
            "t 3000\n",
            "t reward-arm: [8.121065636996455, 270.5569899607598, 146.25985894919862, 12.774632283413096, 5.15774498115383, 8.028770214794513]\n",
            "t numplay: [30.0, 412.0, 275.0, 40.0, 25.0, 29.0] 811.0\n",
            "t mu-hat: [0.2619698592579502, 0.6551016706071665, 0.5299270251782559, 0.311576397156417, 0.19837480696745502, 0.2676256738264838]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 179.50000000000867\n",
            "1 0\n",
            "340.97783733819995 0 {(3, 0.311576397156417), (2, 0.5299270251782559), (1, 0.6551540482590957)}\n",
            "\n",
            "t 3100\n",
            "t reward-arm: [9.377121581713723, 331.77902463485, 146.25985894919862, 13.628646496534024, 5.15774498115383, 8.028770214794513]\n",
            "t numplay: [32.0, 507.0, 275.0, 43.0, 25.0, 29.0] 911.0\n",
            "t mu-hat: [0.2841551994458704, 0.6531083162103346, 0.5299270251782559, 0.3097419658303187, 0.19837480696745502, 0.2676256738264838]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 185.45000000000977\n",
            "1 0\n",
            "421.5319918022706 0 {(3, 0.3097419658303187), (2, 0.5299270251782559), (1, 0.6527253449641935), (0, 0.2841551994458704)}\n",
            "\n",
            "t 3200\n",
            "t reward-arm: [9.377121581713725, 396.73583280731634, 146.25985894919864, 13.628646496534024, 5.15774498115383, 8.028770214794513]\n",
            "t numplay: [32.0, 607.0, 275.0, 43.0, 25.0, 29.0] 1011.0\n",
            "t mu-hat: [0.2841551994458705, 0.6525260408015071, 0.529927025178256, 0.3097419658303187, 0.19837480696745502, 0.2676256738264838]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 190.4500000000109\n",
            "1 0\n",
            "504.62634002310523 0 {(3, 0.3097419658303187), (2, 0.5299270251782559), (1, 0.6524605996691968), (0, 0.2841551994458704)}\n",
            "\n",
            "t 3300\n",
            "t reward-arm: [10.919178927329918, 459.56040607409125, 146.78402403908154, 14.130211226515165, 5.15774498115383, 8.028770214794513]\n",
            "t numplay: [34.0, 702.0, 276.0, 45.0, 25.0, 29.0] 1111.0\n",
            "t mu-hat: [0.3119765407808548, 0.6537132376587358, 0.5299062239678034, 0.3071785049242427, 0.19837480696745502, 0.2676256738264838]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 196.150000000012\n",
            "1 0\n",
            "585.3825567110824 0 {(3, 0.3071785049242427), (2, 0.5299062239678034), (1, 0.6536051935774273), (0, 0.3119765407808548)}\n",
            "\n",
            "t 3400\n",
            "t reward-arm: [10.919178927329918, 523.432645429466, 146.78402403908154, 14.130211226515165, 5.15774498115383, 8.028770214794513]\n",
            "t numplay: [34.0, 802.0, 276.0, 45.0, 25.0, 29.0] 1211.0\n",
            "t mu-hat: [0.3119765407808548, 0.6518463828511407, 0.5299062239678034, 0.3071785049242427, 0.19837480696745502, 0.2676256738264838]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 201.15000000001314\n",
            "1 0\n",
            "668.3628586813895 0 {(3, 0.3071785049242427), (2, 0.5299062239678034), (1, 0.6518316681364649), (0, 0.3119765407808548)}\n",
            "\n",
            "t 3500\n",
            "t reward-arm: [10.919178927329918, 586.0112972877072, 147.8626803744957, 14.130211226515165, 5.817695874075014, 8.028770214794513]\n",
            "t numplay: [34.0, 898.0, 278.0, 45.0, 27.0, 29.0] 1311.0\n",
            "t mu-hat: [0.3119765407808548, 0.6518479391409424, 0.5299737647831387, 0.3071785049242427, 0.20777485264553622, 0.2676256738264838]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 207.15000000001422\n",
            "1 0\n",
            "749.714135302913 0 {(3, 0.3071785049242427), (2, 0.5299737647831387), (1, 0.6519337787919964), (0, 0.3119765407808548)}\n",
            "\n",
            "t 3600\n",
            "t reward-arm: [11.489258700638633, 650.8787868476966, 148.3764110205704, 14.383961227248875, 5.817695874075014, 8.028770214794513]\n",
            "t numplay: [35.0, 995.0, 279.0, 46.0, 27.0, 29.0] 1411.0\n",
            "t mu-hat: [0.3191460750177398, 0.6534927578792135, 0.5299157536448943, 0.3060417282393378, 0.20777485264553622, 0.2676256738264838]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 212.55000000001533\n",
            "1 0\n",
            "831.3850174970303 0 {(3, 0.3060417282393378), (2, 0.5299157536448943), (1, 0.6533307586441289), (0, 0.3191460750177398)}\n",
            "\n",
            "t 3700\n",
            "t reward-arm: [11.489258700638633, 715.4123686191278, 148.3764110205704, 14.383961227248875, 5.817695874075014, 8.028770214794513]\n",
            "t numplay: [35.0, 1095.0, 279.0, 46.0, 27.0, 29.0] 1511.0\n",
            "t mu-hat: [0.3191460750177398, 0.6527485115138028, 0.5299157536448943, 0.3060417282393378, 0.20777485264553622, 0.2676256738264838]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 217.55000000001647\n",
            "1 0\n",
            "914.3509214180821 0 {(3, 0.3060417282393378), (2, 0.5299157536448943), (1, 0.6527656855635597), (0, 0.3191460750177398)}\n",
            "\n",
            "t 3800\n",
            "t reward-arm: [12.159607162815135, 777.7960916701497, 149.41882338306124, 14.383961227248877, 6.070419236854858, 8.028770214794513]\n",
            "t numplay: [36.0, 1191.0, 281.0, 46.0, 28.0, 29.0] 1611.0\n",
            "t mu-hat: [0.3286380314274361, 0.65251349972328, 0.5298539836278767, 0.3060417282393378, 0.20932480127085717, 0.2676256738264838]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 223.10000000001756\n",
            "1 0\n",
            "995.7747776895727 0 {(3, 0.3060417282393378), (2, 0.5298539836278767), (1, 0.6524970314862151), (0, 0.3286380314274361)}\n",
            "\n",
            "t 3900\n",
            "t reward-arm: [12.159607162815135, 841.0945745283684, 149.41882338306124, 14.383961227248877, 6.070419236854858, 8.028770214794513]\n",
            "t numplay: [36.0, 1291.0, 281.0, 46.0, 28.0, 29.0] 1711.0\n",
            "t mu-hat: [0.3286380314274361, 0.6510019926690158, 0.5298539836278767, 0.3060417282393378, 0.20932480127085717, 0.2676256738264838]\n",
            "T true mu: [0.7  0.65 0.55 0.3  0.25 0.15] Err: 228.1000000000187\n",
            "1 0\n",
            "1078.5505378199828 0 {(3, 0.3060417282393378), (2, 0.5298539836278767), (1, 0.6509516187977105), (0, 0.3286380314274361)}\n",
            "\n",
            "t 4000\n",
            "t reward-arm: [13.405501209023749, 902.9401937138298, 149.81633679484716, 14.383961227248875, 6.3075017738003805, 8.028770214794513]\n",
            "t numplay: [38.0, 1387.0, 282.0, 46.0, 29.0, 29.0] 1811.0\n",
            "t mu-hat: [0.3437308002313782, 0.6505332807736526, 0.5293863490983999, 0.3060417282393378, 0.21025005912667935, 0.2676256738264838]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 233.50000000001978\n",
            "1 3\n",
            "1159.1169114700178 0 {(3, 0.3060417282393378), (2, 0.5293863490984), (1, 0.6505860697651751), (0, 0.3437308002313782)}\n",
            "\n",
            "t 4100\n",
            "t reward-arm: [13.405501209023749, 977.6693884428859, 149.81633679484716, 14.383961227248875, 6.3075017738003805, 8.028770214794513]\n",
            "t numplay: [38.0, 1487.0, 282.0, 46.0, 29.0, 29.0] 1911.0\n",
            "t mu-hat: [0.3437308002313782, 0.6570358793298964, 0.5293863490983999, 0.3060417282393378, 0.21025005912667935, 0.2676256738264838]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 238.50000000002092\n",
            "1 3\n",
            "1242.3215850452254 0 {(3, 0.3060417282393378), (2, 0.5293863490983999), (1, 0.6569971729469278), (0, 0.3437308002313782)}\n",
            "\n",
            "t 4200\n",
            "t reward-arm: [13.92104953475438, 1047.6804262711098, 149.81633679484716, 15.17866841107723, 6.913978725497514, 8.028770214794513]\n",
            "t numplay: [40.0, 1582.0, 282.0, 47.0, 31.0, 29.0] 2011.0\n",
            "t mu-hat: [0.3395377935305946, 0.6618322339046808, 0.5293863490983999, 0.31622225856410896, 0.2160618351717973, 0.2676256738264838]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 245.450000000022\n",
            "1 3\n",
            "1323.6459657497437 0 {(3, 0.31622225856410896), (2, 0.5293863490983999), (1, 0.661763487578254), (0, 0.3395377935305946)}\n",
            "\n",
            "t 4300\n",
            "t reward-arm: [13.92104953475438, 1121.2591092803423, 149.81633679484713, 16.937604073424232, 6.913978725497514, 8.028770214794513]\n",
            "t numplay: [40.0, 1680.0, 282.0, 49.0, 31.0, 29.0] 2111.0\n",
            "t mu-hat: [0.3395377935305946, 0.6670191012970508, 0.5293863490983998, 0.3387520814684846, 0.2160618351717973, 0.2676256738264838]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 250.5800000000231\n",
            "1 3\n",
            "1407.6388949549714 0 {(3, 0.3272986548087748), (2, 0.5293863490983998), (1, 0.6670191012970508), (0, 0.3395377935305946)}\n",
            "\n",
            "t 4400\n",
            "t reward-arm: [13.921049534754381, 1194.7908939583235, 150.55796885929652, 16.937604073424232, 6.913978725497514, 8.02877021479451]\n",
            "t numplay: [40.0, 1779.0, 283.0, 49.0, 31.0, 29.0] 2211.0\n",
            "t mu-hat: [0.33953779353059466, 0.671230839302429, 0.530133693166537, 0.3387520814684846, 0.2160618351717973, 0.26762567382648367]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 255.58000000002423\n",
            "1 3\n",
            "1493.8813098693936 0 {(3, 0.3387520814684846), (2, 0.530133693166537), (1, 0.6712072221648439), (0, 0.33953779353059466)}\n",
            "\n",
            "t 4500\n",
            "t reward-arm: [14.2358796181776, 1265.6933291893592, 152.10716559429824, 17.846076204186353, 7.169156816998503, 8.028770214794513]\n",
            "t numplay: [41.0, 1873.0, 286.0, 50.0, 32.0, 29.0] 2311.0\n",
            "t mu-hat: [0.3389495147185143, 0.6753966537830092, 0.5299901240219451, 0.3499230628271834, 0.2172471762726819, 0.2676256738264838]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 262.2200000000252\n",
            "1 3\n",
            "1578.4738659223096 0 {(3, 0.3499230628271834), (2, 0.5299901240219451), (1, 0.6754194511147041), (0, 0.3389495147185143)}\n",
            "\n",
            "t 4600\n",
            "t reward-arm: [14.2358796181776, 1341.0036368776923, 152.10716559429824, 17.846076204186353, 7.169156816998503, 8.028770214794513]\n",
            "t numplay: [41.0, 1973.0, 286.0, 50.0, 32.0, 29.0] 2411.0\n",
            "t mu-hat: [0.3389495147185143, 0.6793331493807965, 0.5299901240219451, 0.3499230628271834, 0.2172471762726819, 0.2676256738264838]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 267.22000000002635\n",
            "1 3\n",
            "1666.4451979603502 0 {(3, 0.3499230628271834), (2, 0.5299901240219451), (1, 0.6793036867789979), (0, 0.3389495147185143)}\n",
            "\n",
            "t 4700\n",
            "t reward-arm: [14.550380032267155, 1410.861582426296, 153.16914843751826, 19.582106997139654, 7.169156816998503, 8.028770214794513]\n",
            "t numplay: [43.0, 2067.0, 288.0, 52.0, 32.0, 29.0] 2511.0\n",
            "t mu-hat: [0.330690455278799, 0.6822348077496596, 0.5299970534170182, 0.3694737169271633, 0.2172471762726819, 0.2676256738264838]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 273.6800000000274\n",
            "1 3\n",
            "1752.2456406387728 0 {(3, 0.3694737169271633), (2, 0.5299970534170182), (1, 0.6821379944236695), (0, 0.330690455278799)}\n",
            "\n",
            "t 4800\n",
            "t reward-arm: [14.550380032267155, 1485.05088828534, 153.16914843751826, 19.582106997139654, 7.169156816998502, 8.02877021479451]\n",
            "t numplay: [43.0, 2167.0, 288.0, 52.0, 32.0, 29.0] 2611.0\n",
            "t mu-hat: [0.330690455278799, 0.6849865720873339, 0.5299970534170182, 0.3694737169271633, 0.21724717627268186, 0.26762567382648367]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 278.68000000002854\n",
            "1 3\n",
            "1841.415187557535 0 {(3, 0.3694737169271633), (2, 0.5299970534170182), (1, 0.6849855742587878), (0, 0.330690455278799)}\n",
            "\n",
            "Arm 1 Changepoint Detected at time 4870\n",
            "t 4900\n",
            "t reward-arm: [14.550380032267155, 22.367616589262138, 154.0371385867795, 20.29904211071549, 7.478816042970022, 8.028770214794513]\n",
            "t numplay: [43.0, 30.0, 290.0, 53.0, 33.0, 29.0] 478.0\n",
            "t mu-hat: [0.330690455278799, 0.7215360190084561, 0.5293372460026786, 0.37590818723547204, 0.21996517773441243, 0.2676256738264838]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 284.5400000000296\n",
            "1 3\n",
            "28.19893618322343 0 {(3, 0.37590818723547204), (2, 0.5293372460026786), (1, 0.7192295619517421), (0, 0.330690455278799)}\n",
            "\n",
            "t 5000\n",
            "t reward-arm: [14.550380032267155, 98.00301201445967, 154.0371385867795, 20.29904211071549, 7.478816042970022, 8.028770214794513]\n",
            "t numplay: [43.0, 130.0, 290.0, 53.0, 33.0, 29.0] 578.0\n",
            "t mu-hat: [0.330690455278799, 0.7481145955302265, 0.5293372460026786, 0.37590818723547204, 0.21996517773441243, 0.2676256738264838]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 289.5400000000307\n",
            "1 3\n",
            "128.39915345618022 0 {(3, 0.37590818723547204), (2, 0.5293372460026786), (1, 0.7488503404839909), (0, 0.330690455278799)}\n",
            "\n",
            "t 5100\n",
            "t reward-arm: [14.550380032267155, 167.52204015675187, 155.14868882079554, 22.020374231965842, 8.098325776631814, 8.028770214794513]\n",
            "t numplay: [43.0, 224.0, 292.0, 55.0, 35.0, 29.0] 678.0\n",
            "t mu-hat: [0.330690455278799, 0.744542400696675, 0.5295177092859916, 0.39322096842796145, 0.22495349379532817, 0.2676256738264838]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 295.80000000003173\n",
            "1 3\n",
            "227.70771546951875 0 {(3, 0.39322096842796145), (2, 0.5295177092859916), (1, 0.7447192506852283), (0, 0.330690455278799)}\n",
            "\n",
            "t 5200\n",
            "t reward-arm: [14.745218124555814, 238.53252032552842, 155.60844631475882, 23.437816247852425, 8.098325776631814, 8.028770214794513]\n",
            "t numplay: [44.0, 320.0, 293.0, 57.0, 35.0, 29.0] 778.0\n",
            "t mu-hat: [0.3276715138790181, 0.7430919636309297, 0.5292804296420368, 0.4041002801353866, 0.22495349379532817, 0.2676256738264838]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 301.4800000000328\n",
            "1 3\n",
            "327.1921621515885 0 {(3, 0.4041002801353866), (2, 0.5292804296420368), (1, 0.7432621199896765), (0, 0.3276715138790181)}\n",
            "\n",
            "t 5300\n",
            "t reward-arm: [14.745218124555814, 313.258677089649, 155.60844631475882, 23.437816247852425, 8.098325776631814, 8.028770214794513]\n",
            "t numplay: [44.0, 420.0, 293.0, 57.0, 35.0, 29.0] 878.0\n",
            "t mu-hat: [0.3276715138790181, 0.7440823683839644, 0.5292804296420368, 0.4041002801353866, 0.22495349379532817, 0.2676256738264838]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 306.48000000003395\n",
            "1 3\n",
            "428.221896299357 0 {(3, 0.4041002801353866), (2, 0.5292804296420368), (1, 0.7443575378072081), (0, 0.3276715138790181)}\n",
            "\n",
            "t 5400\n",
            "t reward-arm: [15.059519344824915, 382.40879042741966, 155.60844631475882, 23.437816247852425, 9.775341108630064, 8.028770214794513]\n",
            "t numplay: [45.0, 515.0, 293.0, 57.0, 39.0, 29.0] 978.0\n",
            "t mu-hat: [0.3273808553222808, 0.7411023070298831, 0.5292804296420368, 0.4041002801353866, 0.24438352771575161, 0.2676256738264838]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 313.83000000003506\n",
            "1 3\n",
            "525.9891327274925 0 {(3, 0.4041002801353866), (2, 0.5292804296420368), (1, 0.7413550228326333), (0, 0.3273808553222808)}\n",
            "\n",
            "t 5500\n",
            "t reward-arm: [15.059519344824915, 456.28004825633667, 155.60844631475882, 23.437816247852425, 9.775341108630064, 8.028770214794513]\n",
            "t numplay: [45.0, 615.0, 293.0, 57.0, 39.0, 29.0] 1078.0\n",
            "t mu-hat: [0.3273808553222808, 0.7407143640524946, 0.5292804296420368, 0.4041002801353866, 0.24438352771575161, 0.2676256738264838]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 318.8300000000362\n",
            "1 3\n",
            "626.6045078405219 0 {(3, 0.4041002801353866), (2, 0.5292804296420368), (1, 0.7406360195681938), (0, 0.3273808553222808)}\n",
            "\n",
            "t 5600\n",
            "t reward-arm: [15.245258369143366, 529.1525993559783, 155.60844631475885, 25.865074701537807, 9.775341108630064, 8.028770214794513]\n",
            "t numplay: [46.0, 711.0, 293.0, 60.0, 39.0, 29.0] 1178.0\n",
            "t mu-hat: [0.32436719934347585, 0.7431918530280593, 0.5292804296420369, 0.4240176180579968, 0.24438352771575161, 0.2676256738264838]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 324.2300000000373\n",
            "1 3\n",
            "725.2245255188294 0 {(3, 0.4240176180579968), (2, 0.5292804296420368), (1, 0.7431265727290787), (0, 0.32436719934347585)}\n",
            "\n",
            "t 5700\n",
            "t reward-arm: [15.245258369143366, 604.7244114871629, 155.60844631475882, 25.865074701537807, 9.775341108630064, 8.02877021479451]\n",
            "t numplay: [46.0, 811.0, 293.0, 60.0, 39.0, 29.0] 1278.0\n",
            "t mu-hat: [0.32436719934347585, 0.7447344969053731, 0.5292804296420368, 0.4240176180579968, 0.24438352771575161, 0.26762567382648367]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 329.23000000003844\n",
            "1 3\n",
            "826.5850297514438 0 {(3, 0.4240176180579968), (2, 0.5292804296420368), (1, 0.7446410235060106), (0, 0.32436719934347585)}\n",
            "\n",
            "t 5800\n",
            "t reward-arm: [15.521653011654598, 679.3019278093486, 156.13656772476378, 25.865074701537807, 9.775341108630064, 8.02877021479451]\n",
            "t numplay: [47.0, 909.0, 294.0, 60.0, 39.0, 29.0] 1378.0\n",
            "t mu-hat: [0.32336777107613746, 0.7464856349553282, 0.5292765007619111, 0.4240176180579968, 0.24438352771575161, 0.26762567382648367]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 335.01000000003955\n",
            "1 3\n",
            "927.1931389199233 0 {(3, 0.4240176180579968), (2, 0.5292765007619111), (1, 0.7465162887236588), (0, 0.32336777107613746)}\n",
            "\n",
            "t 5900\n",
            "t reward-arm: [15.521653011654598, 757.4783989042489, 156.13656772476378, 25.865074701537807, 9.775341108630064, 8.02877021479451]\n",
            "t numplay: [47.0, 1009.0, 294.0, 60.0, 39.0, 29.0] 1478.0\n",
            "t mu-hat: [0.32336777107613746, 0.7499786127764841, 0.5292765007619111, 0.4240176180579968, 0.24438352771575161, 0.26762567382648367]\n",
            "T true mu: [0.2  0.75 0.52 0.8  0.3  0.35] Err: 340.0100000000407\n",
            "1 3\n",
            "1029.2331874875815 0 {(3, 0.4240176180579968), (2, 0.5292765007619111), (1, 0.7499282764926958), (0, 0.32336777107613746)}\n",
            "\n",
            "t 6000\n",
            "t reward-arm: [15.521653011654598, 829.0996457493519, 156.13656772476375, 25.865074701537807, 10.629730804011489, 8.028770214794513]\n",
            "t numplay: [47.0, 1106.0, 294.0, 60.0, 42.0, 29.0] 1578.0\n",
            "t mu-hat: [0.32336777107613746, 0.7489608362686105, 0.529276500761911, 0.4240176180579968, 0.24720304195375556, 0.2676256738264838]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 346.8100000000418\n",
            "1 4\n",
            "1129.4542274729629 0 {(3, 0.4240176180579968), (2, 0.529276500761911), (1, 0.7489932737211116), (0, 0.32336777107613746)}\n",
            "\n",
            "Arm 1 Changepoint Detected at time 6010\n",
            "t 6100\n",
            "t reward-arm: [16.916429573755323, 5.735980291966008, 182.23503571712922, 29.91976700347159, 10.629730804011489, 8.212950106788393]\n",
            "t numplay: [49.0, 25.0, 342.0, 74.0, 42.0, 30.0] 562.0\n",
            "t mu-hat: [0.33832859147510647, 0.22061462661407724, 0.5312974802248666, 0.3989302267129545, 0.24720304195375556, 0.2649338744125288]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 377.4100000000404\n",
            "2 4\n",
            "38.219911343551914 0 {(3, 0.3989302267129545), (2, 0.5307336808362958), (0, 0.33832859147510647)}\n",
            "\n",
            "t 6200\n",
            "t reward-arm: [18.72965164867612, 5.735980291966008, 233.63884642347372, 30.305039703187298, 10.629730804011489, 8.623464034443755]\n",
            "t numplay: [52.0, 25.0, 435.0, 76.0, 42.0, 32.0] 662.0\n",
            "t mu-hat: [0.35338965374860604, 0.22061462661407724, 0.5358689138153067, 0.3935719441972376, 0.24720304195375556, 0.26131709195284103]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 393.3100000000383\n",
            "2 4\n",
            "95.02652582787591 0 {(3, 0.3935719441972376), (2, 0.5358689138153067), (0, 0.3459008238026338)}\n",
            "\n",
            "t 6300\n",
            "t reward-arm: [80.64772100280372, 6.229282694626912, 233.63884642347375, 30.637819971058356, 11.43091907696591, 8.623464034443755]\n",
            "t numplay: [148.0, 27.0, 435.0, 77.0, 43.0, 32.0] 762.0\n",
            "t mu-hat: [0.5412598725020384, 0.22247438195096114, 0.5358689138153068, 0.3927925637315174, 0.25979361538558887, 0.26131709195284103]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 399.5100000000394\n",
            "0 4\n",
            "137.7434930778518 0 {(3, 0.3927925637315174), (2, 0.5358689138153068), (0, 0.5404622336704026)}\n",
            "\n",
            "Arm 0 Changepoint Detected at time 6320\n",
            "t 6400\n",
            "t reward-arm: [52.322397111687835, 6.229282694626913, 233.63884642347375, 30.637819971058356, 11.43091907696591, 8.623464034443755]\n",
            "t numplay: [80.0, 27.0, 435.0, 77.0, 43.0, 32.0] 694.0\n",
            "t mu-hat: [0.6459555198973806, 0.22247438195096117, 0.5358689138153068, 0.3927925637315174, 0.25979361538558887, 0.26131709195284103]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 404.5100000000405\n",
            "0 4\n",
            "61.89819322376111 0 {(3, 0.3927925637315174), (2, 0.5358689138153067), (0, 0.6447491336690108)}\n",
            "\n",
            "t 6500\n",
            "t reward-arm: [112.8659640387546, 6.229282694626913, 234.15565621650882, 31.272934914626155, 12.728952169560397, 8.623464034443755]\n",
            "t numplay: [174.0, 27.0, 436.0, 80.0, 45.0, 32.0] 794.0\n",
            "t mu-hat: [0.6449483659357406, 0.22247438195096117, 0.5358253002666106, 0.3860856162299525, 0.27671635151218255, 0.26131709195284103]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 410.5600000000415\n",
            "0 4\n",
            "141.86194600089445 0 {(3, 0.3860856162299525), (2, 0.5358253002666106), (0, 0.645995378946484)}\n",
            "\n",
            "t 6600\n",
            "t reward-arm: [179.8338881181977, 6.229282694626912, 234.15565621650885, 31.272934914626155, 12.728952169560396, 8.623464034443755]\n",
            "t numplay: [274.0, 27.0, 436.0, 80.0, 45.0, 32.0] 894.0\n",
            "t mu-hat: [0.6539414113389007, 0.22247438195096114, 0.5358253002666107, 0.3860856162299525, 0.2767163515121825, 0.26131709195284103]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 415.56000000004263\n",
            "0 4\n",
            "224.9404833025167 0 {(3, 0.3860856162299525), (2, 0.5358253002666106), (0, 0.653618624709361)}\n",
            "\n",
            "t 6700\n",
            "t reward-arm: [241.3306404282498, 6.229282694626912, 234.15565621650885, 31.272934914626155, 14.959219068660481, 8.623464034443755]\n",
            "t numplay: [371.0, 27.0, 436.0, 80.0, 48.0, 32.0] 994.0\n",
            "t mu-hat: [0.6487382807211016, 0.22247438195096114, 0.5358253002666107, 0.3860856162299525, 0.3052901850747037, 0.26131709195284103]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 420.41000000004374\n",
            "0 4\n",
            "306.7287623931489 0 {(3, 0.3860856162299525), (2, 0.5358253002666107), (0, 0.6485203114982193), (4, 0.3052901850747037)}\n",
            "\n",
            "t 6800\n",
            "t reward-arm: [305.9080874133902, 6.229282694626913, 234.15565621650882, 31.272934914626155, 14.959219068660481, 8.623464034443755]\n",
            "t numplay: [471.0, 27.0, 436.0, 80.0, 48.0, 32.0] 1094.0\n",
            "t mu-hat: [0.648110354689386, 0.22247438195096117, 0.5358253002666106, 0.3860856162299525, 0.3052901850747037, 0.26131709195284103]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 425.4100000000449\n",
            "0 4\n",
            "389.5818354677891 0 {(3, 0.3860856162299525), (2, 0.5358253002666106), (0, 0.647776281230332), (4, 0.3052901850747037)}\n",
            "\n",
            "t 6900\n",
            "t reward-arm: [366.93487812442356, 6.519518543445446, 234.91823528749984, 31.272934914626155, 18.004460786930572, 8.623464034443755]\n",
            "t numplay: [565.0, 28.0, 437.0, 80.0, 52.0, 32.0] 1194.0\n",
            "t mu-hat: [0.64829483767566, 0.2248109842567395, 0.5363430029394973, 0.3860856162299525, 0.33970680730057684, 0.26131709195284103]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 430.7600000000459\n",
            "0 4\n",
            "469.4455572536085 0 {(3, 0.3860856162299525), (2, 0.5363430029394973), (0, 0.6483318448646086), (4, 0.33970680730057684)}\n",
            "\n",
            "t 7000\n",
            "t reward-arm: [428.56752041158114, 6.999688260206582, 234.9182352874998, 31.620164797942387, 20.264743142917784, 8.623464034443755]\n",
            "t numplay: [659.0, 30.0, 437.0, 81.0, 55.0, 32.0] 1294.0\n",
            "t mu-hat: [0.649344727896335, 0.22579639549053493, 0.5363430029394973, 0.3856117658285657, 0.36187041326638897, 0.26131709195284103]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 436.86000000004697\n",
            "0 4\n",
            "549.0931495682428 0 {(3, 0.3856117658285657), (2, 0.5363430029394973), (0, 0.6493710184812195), (4, 0.36187041326638897)}\n",
            "\n",
            "t 7100\n",
            "t reward-arm: [493.75666271485795, 6.9996882602065815, 234.9182352874998, 31.620164797942387, 20.264743142917787, 8.623464034443755]\n",
            "t numplay: [759.0, 30.0, 437.0, 81.0, 55.0, 32.0] 1394.0\n",
            "t mu-hat: [0.6496798193616552, 0.2257963954905349, 0.5363430029394973, 0.3856117658285657, 0.3618704132663891, 0.26131709195284103]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 441.8600000000481\n",
            "0 4\n",
            "632.0530334812087 0 {(3, 0.3856117658285657), (2, 0.5363430029394973), (0, 0.6496393244403923), (4, 0.3618704132663891)}\n",
            "\n",
            "t 7200\n",
            "t reward-arm: [554.6644437781929, 7.513952982564945, 236.27365761722206, 31.983676020254414, 21.108173559182546, 8.623464034443755]\n",
            "t numplay: [853.0, 32.0, 439.0, 82.0, 56.0, 32.0] 1494.0\n",
            "t mu-hat: [0.6494899810049097, 0.22769554492621044, 0.5369855854936865, 0.3853454942199327, 0.3703188343716236, 0.26131709195284103]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 448.2600000000491\n",
            "0 4\n",
            "712.6721037654529 0 {(3, 0.3853454942199327), (2, 0.5369855854936866), (0, 0.649490143732041), (4, 0.3703188343716236)}\n",
            "\n",
            "t 7300\n",
            "t reward-arm: [618.4684424050729, 7.513952982564945, 236.27365761722209, 31.98367602025441, 21.108173559182546, 8.623464034443755]\n",
            "t numplay: [953.0, 32.0, 439.0, 82.0, 56.0, 32.0] 1594.0\n",
            "t mu-hat: [0.6482897719130744, 0.22769554492621044, 0.5369855854936866, 0.38534549421993264, 0.3703188343716236, 0.26131709195284103]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 453.26000000005024\n",
            "0 4\n",
            "795.5327981477205 0 {(3, 0.38534549421993264), (2, 0.5369855854936866), (0, 0.6483768470396979), (4, 0.3703188343716236)}\n",
            "\n",
            "t 7400\n",
            "t reward-arm: [678.6551601503376, 7.716591750388202, 236.8835938317055, 32.294449211700545, 21.81843009871826, 8.623464034443755]\n",
            "t numplay: [1049.0, 33.0, 440.0, 83.0, 57.0, 32.0] 1694.0\n",
            "t mu-hat: [0.6463382477622263, 0.22695858089377066, 0.5371510064211009, 0.38445772871072076, 0.37617982928824584, 0.26131709195284103]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 459.1100000000513\n",
            "0 4\n",
            "876.3915435898666 0 {(3, 0.38445772871072076), (2, 0.5371510064211009), (0, 0.646286739494898), (4, 0.37617982928824584)}\n",
            "\n",
            "t 7500\n",
            "t reward-arm: [743.9211882653384, 7.716591750388203, 236.8835938317055, 32.294449211700545, 21.818430098718263, 8.623464034443755]\n",
            "t numplay: [1149.0, 33.0, 440.0, 83.0, 57.0, 32.0] 1794.0\n",
            "t mu-hat: [0.6468879897959464, 0.2269585808937707, 0.5371510064211009, 0.38445772871072076, 0.3761798292882459, 0.26131709195284103]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 464.1100000000524\n",
            "0 4\n",
            "958.8004403674192 0 {(3, 0.38445772871072076), (2, 0.5371510064211009), (0, 0.6469906026460724), (4, 0.3761798292882459)}\n",
            "\n",
            "t 7600\n",
            "t reward-arm: [807.7479434695595, 7.716591750388203, 237.45044654034734, 32.294449211700545, 22.474449613337583, 8.623464034443755]\n",
            "t numplay: [1247.0, 33.0, 441.0, 83.0, 58.0, 32.0] 1894.0\n",
            "t mu-hat: [0.647233929062147, 0.2269585808937707, 0.5372182048424148, 0.38445772871072076, 0.38092287480233195, 0.26131709195284103]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 469.1600000000535\n",
            "0 4\n",
            "1040.6403704976556 0 {(3, 0.38445772871072076), (2, 0.5372182048424148), (0, 0.6470635710081922), (4, 0.38092287480233195)}\n",
            "\n",
            "t 7700\n",
            "t reward-arm: [871.4167281664974, 7.716591750388202, 237.45044654034731, 32.294449211700545, 23.133595483533234, 8.623464034443755]\n",
            "t numplay: [1346.0, 33.0, 441.0, 83.0, 59.0, 32.0] 1994.0\n",
            "t mu-hat: [0.6469314982676299, 0.22695858089377066, 0.5372182048424148, 0.38445772871072076, 0.3855599247255539, 0.26131709195284103]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 474.4600000000546\n",
            "0 4\n",
            "1122.2307409649807 0 {(3, 0.38445772871072076), (2, 0.5372182048424148), (0, 0.6470326156058832), (4, 0.3855599247255539)}\n",
            "\n",
            "t 7800\n",
            "t reward-arm: [934.3851528326555, 7.899840664342344, 238.12037900585966, 32.74943524382648, 23.133595483533227, 8.623464034443755]\n",
            "t numplay: [1442.0, 34.0, 442.0, 85.0, 59.0, 32.0] 2094.0\n",
            "t mu-hat: [0.6475295584425887, 0.22570973326692412, 0.5375177855662746, 0.3808073865561219, 0.3855599247255538, 0.26131709195284103]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 480.36000000005566\n",
            "0 4\n",
            "1203.5708838078535 0 {(3, 0.3808073865561219), (2, 0.5375177855662746), (0, 0.6474450644937928), (4, 0.3855599247255538)}\n",
            "\n",
            "t 7900\n",
            "t reward-arm: [997.1036194358594, 8.114332213081735, 238.12037900585966, 32.949412167843285, 23.133595483533227, 8.623464034443755]\n",
            "t numplay: [1539.0, 36.0, 442.0, 86.0, 59.0, 32.0] 2194.0\n",
            "t mu-hat: [0.6474698827505581, 0.21930627602923608, 0.5375177855662746, 0.37872887549245154, 0.3855599247255538, 0.26131709195284103]\n",
            "T true mu: [0.65 0.2  0.55 0.3  0.7  0.15] Err: 486.61000000005674\n",
            "0 4\n",
            "1284.5773766305954 0 {(3, 0.37872887549245154), (2, 0.5375177855662746), (0, 0.6474361714102264), (4, 0.3855599247255538)}\n",
            "\n"
          ]
        }
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "Yjldwu750nl9"
      },
      "source": [
        "# File Save"
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "VXvU-S8dKFSS",
        "outputId": "1db310d3-35d0-440b-fa89-2c5243cee850"
      },
      "source": [
        "from google.colab import drive\n",
        "drive.mount('/content/drive')"
      ],
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Mounted at /content/drive\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "id": "2A9XnDT60nUW"
      },
      "source": [
        "import pickle\n",
        "file = open('/content/drive/My Drive/Expts/SafeChangepoint/Global_Data5', 'wb')\n",
        "\n",
        "A = umoss.error\n",
        "B = ucb.error\n",
        "C = cucb.error\n",
        "D = glrucb.error\n",
        "E = sgr.error\n",
        "# F = slr.error\n",
        "F = ducb.error\n",
        "\n",
        "\n",
        "pickle.dump([A, B, C, D, E, F],file) # dump information to that file\n",
        "\n",
        "file.close()"
      ],
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "e6RdslkC1ldM"
      },
      "source": [
        "# Load Data"
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "Wt_Bqh551non",
        "outputId": "78e56de7-ccbd-4b41-d67d-e5db63c0c746"
      },
      "source": [
        "import pickle \n",
        "file = open('/content/drive/My Drive/Expts/SafeChangepoint/Global_Data5', 'rb')\n",
        "data = pickle.load(file)\n",
        "file.close()\n",
        "\n",
        "\n",
        "umoss.error = data[0]\n",
        "ucb.error = data[1]\n",
        "cucb.error = data[2]\n",
        "glrucb.error = data[3]\n",
        "sgr.error = data[4]\n",
        "# slr.error = data[5]\n",
        "ducb.error = data[5]\n",
        "\n",
        "print(data[0])"
      ],
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "[[   0.      0.      0.   ... 2197.2  2197.25 2197.3 ]\n",
            " [   0.      0.      0.   ... 2197.2  2197.25 2197.3 ]\n",
            " [   0.      0.      0.   ... 2197.2  2197.25 2197.3 ]\n",
            " ...\n",
            " [   0.      0.      0.   ... 2197.2  2197.25 2197.3 ]\n",
            " [   0.      0.      0.   ... 2197.2  2197.25 2197.3 ]\n",
            " [   0.      0.      0.   ... 2197.2  2197.25 2197.3 ]]\n"
          ]
        }
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "cp5aVdPc8OdS"
      },
      "source": [
        "# Regret Plot"
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 754
        },
        "id": "PiBTFXOE8TY7",
        "outputId": "917fa19a-ed70-4d04-bb50-06778d69a51e"
      },
      "source": [
        "import matplotlib\n",
        "import matplotlib.pyplot as plt\n",
        "\n",
        "plt.style.use('ggplot')\n",
        "plt.figure(dpi=200)\n",
        "k = 1.0\n",
        "\n",
        "plt.plot(np.mean(umoss.error, axis = 0), label = \"UMOSS\", color = (0.78,0.4,0.4))\n",
        "plt.fill_between(range(env.T), np.average(umoss.error, axis=0) + k*np.std(umoss.error, axis=0), np.average(umoss.error, axis=0) - k*np.std(umoss.error, axis=0), alpha=0.4, edgecolor=(0.78,0.4,0.4), facecolor=(0.78,0.4,0.4), linewidth=2, linestyle='dashdot', antialiased=True)\n",
        "\n",
        "\n",
        "plt.plot(np.mean(ucb.error, axis = 0), label = \"UCB-CPD\", color = (0.2,0.7,0.63))\n",
        "plt.fill_between(range(env.T), np.average(ucb.error, axis=0) + k*np.std(ucb.error, axis=0), np.average(ucb.error, axis=0) - k*np.std(ucb.error, axis=0), alpha=0.4, edgecolor=(0.2,0.7,0.63), facecolor=(0.2,0.7,0.63), linewidth=2, linestyle='dashdot', antialiased=True)\n",
        "\n",
        "plt.plot(np.mean(cucb.error, axis = 0), label = \"CUCB\", color = (0.3,0.2,0.9))\n",
        "plt.fill_between(range(env.T), np.average(cucb.error, axis=0) + k*np.std(cucb.error, axis=0), np.average(cucb.error, axis=0) - k*np.std(cucb.error, axis=0), alpha=0.4, edgecolor=(0.3,0.2,0.9), facecolor=(0.3,0.2,0.9), linewidth=2, linestyle='dashdot', antialiased=True)\n",
        "\n",
        "plt.plot(np.mean(adv_cucb.error, axis = 0), label = \"Adv-CUCB\", color = (0.9,0.2,0.9))\n",
        "plt.fill_between(range(env.T), np.average(adv_cucb.error, axis=0) + k*np.std(adv_cucb.error, axis=0), np.average(adv_cucb.error, axis=0) - k*np.std(adv_cucb.error, axis=0), alpha=0.4, edgecolor=(0.3,0.2,0.9), facecolor=(0.3,0.2,0.9), linewidth=2, linestyle='dashdot', antialiased=True)\n",
        "\n",
        "\n",
        "plt.plot(np.mean(ducb.error, axis = 0), label = \"DUCB\", color = (0.4,0.6,0.21))\n",
        "plt.fill_between(range(env.T), np.average(ducb.error, axis=0) + k*np.std(ducb.error, axis=0), np.average(ducb.error, axis=0) - k*np.std(ducb.error, axis=0), alpha=0.4, edgecolor=(0.4,0.6,0.21), facecolor=(0.4,0.6,0.21), linewidth=2, linestyle='dashdot', antialiased=True)\n",
        "\n",
        "plt.plot(np.mean(glrucb.error, axis = 0), label = \"GLR-UCB\", color = (0.6,0.2,0.96))\n",
        "plt.fill_between(range(env.T), np.average(glrucb.error, axis=0) + k*np.std(glrucb.error, axis=0), np.average(glrucb.error, axis=0) - k*np.std(glrucb.error, axis=0), alpha=0.4, edgecolor=(0.6,0.2,0.96), facecolor=(0.6,0.2,0.96), linewidth=2, linestyle='dashdot', antialiased=True)\n",
        "\n",
        "\n",
        "plt.plot(np.mean(sgr.error, axis = 0), label = \"SGR\", color = \"r\")\n",
        "plt.fill_between(range(env.T), np.average(sgr.error, axis=0) + k*np.std(sgr.error, axis=0), np.average(sgr.error, axis=0) - k*np.std(sgr.error, axis=0), alpha=0.4, edgecolor=\"r\", facecolor=\"r\", linewidth=2, linestyle='dashdot', antialiased=True)\n",
        "\n",
        "plt.plot(np.mean(slr.error, axis = 0), label = \"SLR\", color = (0.9,0.2,0.56))\n",
        "plt.fill_between(range(env.T), np.average(slr.error, axis=0) + k*np.std(slr.error, axis=0), np.average(slr.error, axis=0) - k*np.std(slr.error, axis=0), alpha=0.4, edgecolor=(0.9,0.2,0.56), facecolor=(0.9,0.2,0.56), linewidth=2, linestyle='dashdot', antialiased=True)\n",
        "\n",
        "\n",
        "plt.xlim(env.K)\n",
        "\n",
        "\n",
        "plt.title('Global Changepoint Setting', size = 15, fontweight='bold')\n",
        "plt.ylabel('Cumulative Regret', size = 15, fontweight='bold')\n",
        "plt.xlabel('Rounds', size = 15, fontweight='bold')\n",
        "    \n",
        "plt.yticks(size = 15, fontweight='bold')\n",
        "plt.xticks(size = 15, fontweight='bold')\n",
        "\n",
        "plt.ticklabel_format(axis='y', style='sci', scilimits=(0,0))\n",
        "plt.ticklabel_format(axis='x', style='sci', scilimits=(0,0))\n",
        "\n",
        "plt.grid()\n",
        "plt.legend()\n",
        "plt.ylim(0,500)\n",
        "\n",
        "\n",
        "plt.show()\n"
      ],
      "execution_count": null,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "image/png": "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RlxcnMUjS2NiYjBp0iSkpKTg5MmTKCkpgclkEpzL1dUV4eHhmDt3LqKjo0VPPLmTRCLB888/j7CwMCQnJwsexxkaGor4+HhMnDjR5rkd0fjx47F161bs3r0baWlpFut4KJVKzJgxAwsXLoSHhwc0Gk2PrvXOO+8gPz8fOTk5KCgowLVr1wRPjelIJpMhPDwcM2bMQGxsrGixUSIiImskrX1VxYmIiIhIRGNjI4qKilBTUwO9Xo+mpia4u7vDw8MDvr6+CA4O7rOVEFevXsWVK1eg0+kgk8kwZMgQhISEwNfXt0/mdyRNTU3Iy8vDzz//jFu3bsHLywu+vr4IDw+3y8oSs9mMyspKaDQaVFdXo6GhAU1NTZBKpXBzc4OHhwf8/f0RGBgINze3Pr8+ERENTkxeEBEREREREZFDY80LIiIiIiIiInJoTF4QERERERERkUNj8oKIiIiIiIiIHBqTF0RERERERETk0Ji8ICIiIiIiIiKHxuQFERERERERETk0Ji+IiIiIiIiIyKExeUFEREREREREDo3JCyIiIiIiIiJyaExeEBEREREREZFDY/KCiIiIiIiIiBwakxdERERERERE5NCYvCAiIiIiIiIih8bkBRERERERERE5NCYviIiIiIiIiMihMXlBRERERERERA6NyQsiIiIiIiIicmhMXhARERERERGRQ2PygoiIiIiIiIgcGpMXREREREREROTQmLwgIiIiIiIiIofG5AUREREREREROTQmL4iIiIiIiIjIoTF5QUREREREREQOjckLIiIiIiIiInJoTF4QERERERERkUP7fwyXBGD3KlSFAAAAAElFTkSuQmCC\n",
            "text/plain": [
              "<Figure size 1200x800 with 1 Axes>"
            ]
          },
          "metadata": {}
        }
      ]
    }
  ]
}