{
 "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": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 560x180 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "num_runs = 1000\n",
    "num_exp = 81\n",
    "\n",
    "fname = \"Results/ucb1_vs_bayesucb.npy\"\n",
    "results = np.load(fname, allow_pickle=True)\n",
    "\n",
    "mpl.rcParams[\"font.size\"] = 7\n",
    "plt.figure(figsize=(7, 2.25))\n",
    "plt.subplot(1, 2, 1)\n",
    "\n",
    "Y = results[0 :: 4, :] - results[1 :: 4, :]\n",
    "ndx = np.argsort(Y.mean(axis=-1))\n",
    "Y = Y[ndx, :]\n",
    "\n",
    "plt.fill_between(np.arange(num_exp),\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=\"blue\", alpha=0.1)\n",
    "plt.semilogy(np.arange(num_exp), Y.mean(axis=-1), \"blue\")\n",
    "plt.title(\"(a) Gaussian noise\")\n",
    "plt.xlabel(\"Instance\")\n",
    "plt.ylabel(\"Regret difference\")\n",
    "plt.ylim(ymin=0.1, ymax=1000)\n",
    "\n",
    "plt.subplot(1, 2, 2)\n",
    "\n",
    "Y = results[2 :: 4, :] - results[3 :: 4, :]\n",
    "ndx = np.argsort(Y.mean(axis=-1))\n",
    "Y = Y[ndx, :]\n",
    "\n",
    "plt.fill_between(np.arange(num_exp),\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=\"blue\", alpha=0.1)\n",
    "plt.semilogy(np.arange(num_exp), Y.mean(axis=-1), \"blue\")\n",
    "plt.title(\"(b) Box noise\")\n",
    "plt.xlabel(\"Instance\")\n",
    "plt.ylabel(\"Regret difference\")\n",
    "plt.ylim(ymin=0.1, ymax=1000)\n",
    "\n",
    "plt.tight_layout()\n",
    "plt.savefig(\"Bakeoff.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
}
