{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "188f2fb6-f341-4284-ab54-aa17d6fff829",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "python 3.6.8\n",
      "matplotlib 3.2.2\n"
     ]
    }
   ],
   "source": [
    "# Imports and defaults\n",
    "import matplotlib as mpl\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "from ast import literal_eval\n",
    "\n",
    "mpl.style.use(\"classic\")\n",
    "mpl.rcParams[\"figure.figsize\"] = [5, 3]\n",
    "\n",
    "mpl.rcParams[\"axes.linewidth\"] = 0.75\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",
    "\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,
   "id": "7341d853-a89d-454b-8941-9e3a59e4dfb5",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 352x176 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# resize to 80% in the paper\n",
    "mpl.rcParams[\"font.size\"] = 8\n",
    "#plt.figure(figsize=(6.8, 1.75))\n",
    "\n",
    "vision_datasets = ['MNIST', 'FashionMNIST']\n",
    "methods = ['ours, gaussian','london, gaussian', 'sakhi1, gaussian', 'sakhi2, gaussian', 'logging_reward']\n",
    "\n",
    "colors_ = {'ours, gaussian':'red', 'ours, mixed-logit':'brown','london, gaussian':'cyan', 'london, mixed-logit':'blue', 'sakhi1, gaussian':'gray', 'sakhi1, mixed-logit':'purple', 'sakhi2, gaussian':'orange', 'sakhi2, mixed-logit':'green', 'logging_reward':'k'}\n",
    "model_names_ = [r'Ours', 'London et al.', 'Sakhi et al. 1', 'Sakhi et al. 2', 'Logging']\n",
    "line_styles = {'ours, gaussian':'-', 'ours, mixed-logit':'-','london, gaussian':'-', 'london, mixed-logit':'-', 'sakhi1, gaussian':'-', 'sakhi1, mixed-logit':'-', 'sakhi2, gaussian':'-', 'sakhi2, mixed-logit':'-', 'logging_reward':'-.'}\n",
    "markers = {'ours, gaussian':'.', 'ours, mixed-logit':'.','london, gaussian':'1', 'london, mixed-logit':'1', 'sakhi1, gaussian':'2', 'sakhi1, mixed-logit':'2', 'sakhi2, gaussian':'3', 'sakhi2, mixed-logit':'3', 'logging_reward':''}\n",
    "\n",
    "\n",
    "fig, axs = plt.subplots(1, 2, sharex='col', figsize=(2.2 * 2, 2.2 * 1),constrained_layout=False)#sharey=Truesharey='row', \n",
    "\n",
    "for i in range(2):\n",
    "    ax = axs[i]\n",
    "    data_name = vision_datasets[i]\n",
    "    df = pd.read_csv('results/bound_optimization/' + data_name + '.csv')\n",
    "    \n",
    "    #for cl in df.columns[2:]:\n",
    "    #    df[cl] = df[cl].apply(lambda x: literal_eval(str(x)))\n",
    "    \n",
    "    for k, name in enumerate(methods):\n",
    "        ax.plot(df['eta'], df[name], linestyle=line_styles[name], marker=markers[name], color=colors_[name], label=model_names_[k])\n",
    "        if i<2:\n",
    "            ax.set_title(data_name + ', K=10, d=784')\n",
    "        elif i==2:\n",
    "            ax.set_title(data_name + ', K=47, d=784')\n",
    "        else:\n",
    "            ax.set_title(data_name + ', K=100, d=2048')\n",
    "        \n",
    "    if i==0:\n",
    "        ax.set_ylabel(r'reward of the learned policy')\n",
    "    #if i==1:\n",
    "    ax.set_xlabel(r'inverse-temperature parameter $\\eta_0$')\n",
    "        \n",
    "fig.tight_layout()\n",
    "fig.subplots_adjust(bottom=0.35)   ##  Need to play with this number.\n",
    "fig.legend(labels=model_names_, loc=\"lower center\", ncol=3)\n",
    "\n",
    "#plt.legend(loc=(1.02, 0))\n",
    "fig.savefig(\"figures/comparison_bound_optimization_sota.pdf\", format=\"pdf\", dpi=1200, bbox_inches=0)\n",
    "fig.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "915536dc-3656-405e-bd2a-87270f6facdf",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python Kernel (MOAB #58857)",
   "language": "python",
   "name": "python-kernel-58857"
  },
  "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.6.8"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
