{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "cellView": "form",
    "executionInfo": {
     "elapsed": 5,
     "status": "ok",
     "timestamp": 1622693515966,
     "user": {
      "displayName": "Branislav Kveton",
      "photoUrl": "https://lh3.googleusercontent.com/a-/AOh14GhjPg1PJKD4ixGqLaZ4X3dpkI6w6dO_eTj8z63Y=s64",
      "userId": "09350298559467540088"
     },
     "user_tz": 0
    },
    "id": "dUrLMhAcZYDY",
    "jupyter": {
     "source_hidden": true
    },
    "outputId": "31bb0c27-489c-4d61-85e8-6002f5252ed5",
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "python 3.9.15\n",
      "matplotlib 3.5.1\n",
      "8 joblib CPUs\n"
     ]
    }
   ],
   "source": [
    "# Imports and defaults\n",
    "import joblib\n",
    "from joblib import Parallel, delayed\n",
    "import matplotlib as mpl\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "import scipy.stats\n",
    "import time\n",
    "\n",
    "mpl.style.use(\"classic\")\n",
    "mpl.rcParams[\"figure.figsize\"] = [5, 3]\n",
    "\n",
    "mpl.rcParams[\"axes.linewidth\"] = 0.75\n",
    "mpl.rcParams[\"errorbar.capsize\"] = 3\n",
    "mpl.rcParams[\"figure.facecolor\"] = \"w\"\n",
    "mpl.rcParams[\"grid.linewidth\"] = 0.75\n",
    "mpl.rcParams[\"lines.linewidth\"] = 0.75\n",
    "mpl.rcParams[\"patch.linewidth\"] = 0.75\n",
    "mpl.rcParams[\"xtick.major.size\"] = 3\n",
    "mpl.rcParams[\"ytick.major.size\"] = 3\n",
    "\n",
    "mpl.rcParams[\"pdf.fonttype\"] = 42\n",
    "mpl.rcParams[\"ps.fonttype\"] = 42\n",
    "mpl.rcParams[\"font.size\"] = 10\n",
    "mpl.rcParams[\"axes.titlesize\"] = \"medium\"\n",
    "mpl.rcParams[\"legend.fontsize\"] = \"medium\"\n",
    "\n",
    "import platform\n",
    "print(\"python %s\" % platform.python_version())\n",
    "print(\"matplotlib %s\" % mpl.__version__)\n",
    "print(\"%d joblib CPUs\" % joblib.cpu_count())\n",
    "\n",
    "def linestyle2dashes(style):\n",
    "  if style == \"--\":\n",
    "    return (3, 3)\n",
    "  elif style == \":\":\n",
    "    return (0.5, 2.5)\n",
    "  else:\n",
    "    return (None, None)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "'created' timestamp seems very low; regarding as unix timestamp\n",
      "'modified' timestamp seems very low; regarding as unix timestamp\n",
      "'created' timestamp seems very low; regarding as unix timestamp\n",
      "'modified' timestamp seems very low; regarding as unix timestamp\n",
      "'created' timestamp seems very low; regarding as unix timestamp\n",
      "'modified' timestamp seems very low; regarding as unix timestamp\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 560x180 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "num_runs = 10000\n",
    "mu0_max_list = [1.0, 1.5, 2.0, 2.5, 3.0, 3.5, 4.0, 4.5, 5.0]\n",
    "sigma0_list = [1.0, 0.9, 0.8, 0.7, 0.6, 0.5, 0.4, 0.3, 0.2, 0.1, 0.05]\n",
    "\n",
    "algs = [\n",
    "  [\"BayesUCB\", {}, \"red\", \"-\", \"BayesUCB\"],\n",
    "  [\"UCB1\", {}, \"orange\", \"-\", \"UCB1\"],\n",
    "  [\"BayesUCB_log_bound\", {}, \"blue\", \"-\", \"BayesUCB log bound\"],\n",
    "  [\"UCB1_log_bound\", {}, \"cyan\", \"-\", \"UCB1 log bound\"],\n",
    "  [\"Sqrt_bound\", {}, \"gray\", \"-\", r\"$O(\\sqrt{n})$ bound\"]]\n",
    "\n",
    "mpl.rcParams[\"font.size\"] = 7\n",
    "plt.figure(figsize=(7, 2.25))\n",
    "plt.subplot(1, 2, 1)\n",
    "\n",
    "mu0_max = 1.0\n",
    "for alg in algs:\n",
    "  Y = np.zeros((len(sigma0_list), num_runs))\n",
    "  for ndx, sigma0 in enumerate(sigma0_list):\n",
    "    fname = \"Results/mab_mu0_max=%.3f_sigma0=%.3f.npy\" % (mu0_max, sigma0)\n",
    "    results = np.load(fname, allow_pickle=True)\n",
    "    Y[ndx, :] = results.item().get(alg[0])\n",
    "  plt.fill_between(sigma0_list,\n",
    "    Y.mean(axis=-1) - Y.std(axis=-1) / np.sqrt(num_runs),\n",
    "    Y.mean(axis=-1) + Y.std(axis=-1) / np.sqrt(num_runs),\n",
    "    color=alg[2], alpha=0.1)\n",
    "  plt.plot(sigma0_list, Y.mean(axis=-1),\n",
    "    alg[2], dashes=linestyle2dashes(alg[3]), label=alg[4])\n",
    "\n",
    "  plt.title(\"(a) Decreasing prior width\")\n",
    "  plt.xlabel(r\"Prior width $\\sigma_0$\")\n",
    "  plt.ylabel(\"Regret\")\n",
    "  plt.yscale(\"log\")\n",
    "  plt.ylim(ymin=10, ymax=3e3)\n",
    "\n",
    "plt.subplot(1, 2, 2)\n",
    "\n",
    "sigma0 = 1.0\n",
    "for alg in algs:\n",
    "  Y = np.zeros((len(mu0_max_list), num_runs))\n",
    "  for ndx, mu0_max in enumerate(mu0_max_list):\n",
    "    fname = \"Results/mab_mu0_max=%.3f_sigma0=%.3f.npy\" % (mu0_max, sigma0)\n",
    "    results = np.load(fname, allow_pickle=True)\n",
    "    Y[ndx, :] = results.item().get(alg[0])\n",
    "  plt.fill_between(mu0_max_list,\n",
    "    Y.mean(axis=-1) - Y.std(axis=-1) / np.sqrt(num_runs),\n",
    "    Y.mean(axis=-1) + Y.std(axis=-1) / np.sqrt(num_runs),\n",
    "    color=alg[2], alpha=0.1)\n",
    "  plt.plot(mu0_max_list, Y.mean(axis=-1),\n",
    "    alg[2], dashes=linestyle2dashes(alg[3]), label=alg[4])\n",
    "\n",
    "  plt.title(\"(b) Increasing prior gap\")\n",
    "  plt.xlabel(r\"Prior gap $\\Delta_0$\")\n",
    "  plt.yscale(\"log\")\n",
    "  plt.ylim(ymin=10, ymax=3e3)\n",
    "  plt.legend(loc=\"upper right\", frameon=False)\n",
    "\n",
    "plt.tight_layout()\n",
    "plt.savefig(\"MAB.pdf\", format=\"pdf\", dpi=1200, bbox_inches=0)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "'created' timestamp seems very low; regarding as unix timestamp\n",
      "'modified' timestamp seems very low; regarding as unix timestamp\n",
      "'created' timestamp seems very low; regarding as unix timestamp\n",
      "'modified' timestamp seems very low; regarding as unix timestamp\n",
      "'created' timestamp seems very low; regarding as unix timestamp\n",
      "'modified' timestamp seems very low; regarding as unix timestamp\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 560x180 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "num_runs = 10000\n",
    "theta0_max_list = [1.0, 2.0, 3.0, 4.0, 5.0, 6.0, 7.0, 8.0, 9.0, 10.0]\n",
    "sigma0_list = [1.0, 0.9, 0.8, 0.7, 0.6, 0.5, 0.4, 0.3, 0.2, 0.1, 0.05]\n",
    "\n",
    "algs = [\n",
    "  [\"LinBayesUCB\", {}, \"red\", \"-\", \"BayesUCB\"],\n",
    "  [\"LinBayesUCB_log_bound\", {}, \"blue\", \"-\", \"BayesUCB log bound\"],\n",
    "  [\"Sqrt_bound\", {}, \"gray\", \"-\", r\"$O(\\sqrt{n})$ bound\"]]\n",
    "\n",
    "mpl.rcParams[\"font.size\"] = 7\n",
    "plt.figure(figsize=(7, 2.25))\n",
    "plt.subplot(1, 2, 1)\n",
    "\n",
    "theta0_max = 1.0\n",
    "for alg in algs:\n",
    "  Y = np.zeros((len(sigma0_list), num_runs))\n",
    "  for ndx, sigma0 in enumerate(sigma0_list):\n",
    "    fname = \"Results/linear_theta0_max=%.3f_sigma0=%.3f.npy\" % (theta0_max, sigma0)\n",
    "    results = np.load(fname, allow_pickle=True)\n",
    "    Y[ndx, :] = results.item().get(alg[0])\n",
    "  plt.fill_between(sigma0_list,\n",
    "    Y.mean(axis=-1) - Y.std(axis=-1) / np.sqrt(num_runs),\n",
    "    Y.mean(axis=-1) + Y.std(axis=-1) / np.sqrt(num_runs),\n",
    "    color=alg[2], alpha=0.1)\n",
    "  plt.plot(sigma0_list, Y.mean(axis=-1),\n",
    "    alg[2], dashes=linestyle2dashes(alg[3]), label=alg[4])\n",
    "\n",
    "  plt.title(\"(a) Decreasing prior width\")\n",
    "  plt.xlabel(r\"Prior width $\\sigma_0$\")\n",
    "  plt.ylabel(\"Regret\")\n",
    "  plt.yscale(\"log\")\n",
    "  plt.ylim(ymin=10, ymax=3e4)\n",
    "\n",
    "plt.subplot(1, 2, 2)\n",
    "\n",
    "sigma0 = 1.0\n",
    "for alg in algs:\n",
    "  Y = np.zeros((len(theta0_max_list), num_runs))\n",
    "  for ndx, theta0_max in enumerate(theta0_max_list):\n",
    "    fname = \"Results/linear_theta0_max=%.3f_sigma0=%.3f.npy\" % (theta0_max, sigma0)\n",
    "    results = np.load(fname, allow_pickle=True)\n",
    "    Y[ndx, :] = results.item().get(alg[0])\n",
    "  plt.fill_between(theta0_max_list,\n",
    "    Y.mean(axis=-1) - Y.std(axis=-1) / np.sqrt(num_runs),\n",
    "    Y.mean(axis=-1) + Y.std(axis=-1) / np.sqrt(num_runs),\n",
    "    color=alg[2], alpha=0.1)\n",
    "  plt.plot(theta0_max_list, Y.mean(axis=-1),\n",
    "    alg[2], dashes=linestyle2dashes(alg[3]), label=alg[4])\n",
    "\n",
    "  plt.title(\"(b) Increasing prior gap\")\n",
    "  plt.xlabel(r\"Prior gap $\\Delta_0$\")\n",
    "  plt.yscale(\"log\")\n",
    "  plt.ylim(ymin=10, ymax=3e4)\n",
    "  plt.legend(loc=\"upper right\", frameon=False)\n",
    "\n",
    "plt.tight_layout()\n",
    "plt.savefig(\"Linear.pdf\", format=\"pdf\", dpi=1200, bbox_inches=0)\n",
    "plt.show()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.9.15"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
