{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import os \n",
    "import glob "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "def plot_regrets(arrs, labels, data, X): \n",
    "    \"\"\"\n",
    "    in: \n",
    "        arrs: list of regrets [n,T] \n",
    "        labels: list of str \n",
    "    \"\"\"\n",
    "    n = len(arrs)\n",
    "    cmap = plt.cm.get_cmap('jet')\n",
    "    colors = cmap(np.arange(cmap.N))\n",
    "    cinv = cmap.N / (1. * n) \n",
    "    markers=['.','o','v','^','<','>','1','2','3','4','8','s','p','P','*','h','H','+','x','X','D','d','|','_']\n",
    "\n",
    "     #arrs[0].shape[-1]\n",
    "    figsize=(5, 4)\n",
    "    fig, ax = plt.subplots(figsize=figsize, nrows=1, ncols=1)\n",
    "    # t = np.arange(T)\n",
    "    # xs = np.arange(T)\n",
    "    for i, arr, l in zip(range(n), arrs, labels):\n",
    "        # arr = arr[:,:T] # truncate as different algo can have different iteration length \n",
    "        mean = np.mean(arr, axis=0)\n",
    "        std = np.std(arr, axis=0) / np.sqrt(arr.shape[0])\n",
    "        ax.plot(X, mean, label=l, marker=markers[i % len(markers)], markevery=4, color=colors[int((i+0.5)*cinv)]) \n",
    "        ax.fill_between(X, mean + 1.96*std, mean-1.96*std, alpha=0.1, color=colors[int((i+0.5)*cinv)])\n",
    "\n",
    "    ax.set_title('{}'.format(data),fontsize=12)\n",
    "    ax.set_xlim([0,X[-1]])\n",
    "    # ax.set_xlim([0,1000])\n",
    "    # ax.set_ylim([0,500])\n",
    "    ax.set_xlabel('K',fontsize=12)\n",
    "    ax.set_ylabel(r'$\\log$' + '(SubOpt)',fontsize=12)\n",
    "    ax.grid('on')\n",
    "    plt.legend(fontsize=12)\n",
    "    plt.tight_layout()\n",
    "    plt.show()\n",
    "\n",
    "\n",
    "    return fig "
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Quadratic"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "algo: LinLCB, n: 5\n",
      "(5, 50)\n",
      "algo: NeuralGreedy, n: 5\n",
      "(5, 50)\n",
      "algo: NeuraLCB, n: 5\n",
      "(5, 50)\n",
      "algo: NeuralTS, n: 5\n",
      "(5, 50)\n",
      "algo: NeuraLMC, n: 5\n",
      "(5, 50)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_2224791/972051142.py:25: RuntimeWarning: invalid value encountered in log\n",
      "  arr.append( np.log(tmp['arr_0'][:,1]) )\n"
     ]
    },
    {
     "data": {
      "image/png": "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e5x22ml89atf7eZafvfdd3P55ZcX9RyKQYkD7gdEOKz8Mb1eKq/8OZPXfkDiIfUotWaTBXfO50vnHIwQFk1miQsuoTj0JL6Fju8urrrqKm6++WZ27NiRPvboo4/S0NDAhRdeiGEYHHjggZx99tn861//KrreSy+9lOrq6jQBPu+88xgyZAiGYfCDH/yARCJBtngszc3N3bJw7Nq1i8rKSioqKnoR6+985zuMGjWKQCDA3Xffzcknn8zJJ5+Mpmkcd9xxzJkzh8cff5ympiaeeOIJbrzxRkKhEHV1dVxyySX84x//AFTeu+9973uMGjWK6upqLr300vQ9fD4f55xzDnfffTcAS5cuZf369ZxyyilFP4tCKHHA/YAQAq22Dmf9OvRj56AfrGHe7iBXgfUiVDurwIKQsNhhdTLUrixxwR9jFMuZNjytxA49MSYACw6Djo4YZWVlA9au/fffn1NOOYVrrrkmzeFt2LCBhQsXUllZmS5nWRbnn39+0fWOGtXdAuj666/n1ltvpbGxESEE7e3tNDf3zqMwZMgQVq1ald6vrq6mtbWV1atXp8UZ2e6xYcMG/vnPf/Kf//wnfcw0TY466ig2bNiAaZrd8tQ5jpO+vrGxsVtdY8aM6XafCy64gM997nP84he/4K677uIzn/kMPp+v6GdRCCUC3E8IjwdRNxT5+o8RYQlxsJ6lWwxur9kMeg07zBAj9VI65RLy45dTlMw3mhHZLair43sKP//5zznwwAP5wQ9+ACjCduSRR/L0009nLR8KhYhGuxIRbNu2rVeZzCA6L730Er/5zW949tlnmTZtGpqmUVVV1SvSGcAxxxzDzTffzJYtW5g8eXLedmfeY9SoUZx//vnccsstvcpt3boVn89Hc3MzhtGb3A0fPpxNmzal9zdu3Njt/CGHHILX6+Wll17i3nvv5d57783brr6iJILYDYjychJXPo31XCp2YPfzgfbnKHNaaLaipUzKJRTEuSPhrzMUxytQv3+doY7vKUyYMIFzzjmHm266CYBTTjmFlStXctddd2GaJqZp8uabb7Js2TIAZs6cyYMPPkg0GmX16tXcdttteevv6OjAMAxqa2uxLIurrrqK9mzpXoDjjz+eo446is9//vMsXLiQZDKJaZq8/vrrWcuncN555/Gf//yH//73v9i2TTweZ8GCBWzevJnhw4dz/PHH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",
      "text/plain": [
       "<Figure size 360x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "data = 'cosine'\n",
    "func_label = r'$r(s,a) = cos(3s^T \\theta_a)$'\n",
    "result_path = '/results/cosine/unif'\n",
    "algos = [ 'LinLCB','NeuralGreedy', 'NeuraLCB', 'NeuralTS', 'NeuraLMC']\n",
    "algo_labels = [ 'LinLCB','NeuralGreedy', 'NeuraLCB', 'NeuralTS', 'Neural-PEPS']\n",
    "# T = 500\n",
    "arrs = []\n",
    "upd_times = [] \n",
    "act_select_times = []\n",
    "X = None\n",
    "for algo in algos: \n",
    "    arr = []\n",
    "    upd_time = [] \n",
    "    act_select_time = []\n",
    "    data_path = os.path.join(result_path, algo) \n",
    "    n = len(glob.glob1(data_path,\"*.npz\"))\n",
    " \n",
    "    # n = 1\n",
    "    print('algo: {}, n: {}'.format(algo, n))\n",
    "    for i in range(n): \n",
    "        tmp = np.load(os.path.join(result_path, algo, 'trial={}.npz'.format(i)))\n",
    "        arr.append( np.log(tmp['arr_0'][:,1]) ) \n",
    "\n",
    "        if X is None: \n",
    "            X = tmp['arr_0'][:,0]\n",
    "\n",
    "        # Only use the first trial to count elapsed time as running multiple trials does not give a reliable measure of time\n",
    "        # After running for each algo to get reget, run each algo one more time with trial=0 only to get a measure of time\n",
    "        # if i == 0: \n",
    "        try:\n",
    "            upd_time.append(tmp['arr_1'][:,1])\n",
    "            act_select_time.append(tmp['arr_2'][:,1]) \n",
    "        except: \n",
    "            pass \n",
    "    \n",
    "    arr = np.array(arr) # (n,T)\n",
    "    print(arr.shape)\n",
    "    upd_time = np.array(upd_time) \n",
    "    act_select_time = np.array(act_select_time)\n",
    "    # print(act_select_time.shape)\n",
    "    arrs.append(arr)\n",
    "    upd_times.append(upd_time)\n",
    "    act_select_times.append(act_select_time) # (n_algo, T)\n",
    "fig = plot_regrets(arrs, algo_labels, func_label, X)\n",
    "\n",
    "fig.savefig(os.path.join(result_path, '{}_regret_neurips.png'.format(data)), bbox_inches='tight', dpi=400)\n",
    "\n",
    "# act_select_times = np.array(act_select_times)\n"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3.9.12 ('venv')",
   "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.12"
  },
  "orig_nbformat": 4,
  "vscode": {
   "interpreter": {
    "hash": "cf155ea7873fa76cf4d2709f415475ad30d3f8dd7e6ecb302d8ace816f0c7efb"
   }
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
