{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import sys\n",
    "sys.path.append('../')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "%aimport log_plotter\n",
    "from log_plotter import get_accuracies\n",
    "import matplotlib.ticker as mtick"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib\n",
    "matplotlib.rcParams['pdf.fonttype'] = 3\n",
    "matplotlib.rcParams['ps.fonttype'] = 3\n",
    "import matplotlib.pyplot as plt\n",
    "plt.rcParams.update({'font.size': 16})\n",
    "import numpy as np"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "def format_accuracies(unf_accuracies, tag='Tacc'):\n",
    "    reformed_accuracies = {}\n",
    "    for accuracy in unf_accuracies:\n",
    "        for method in accuracy[tag][0]:\n",
    "            # sample data ((0.0, 76.3499984741211), 'NUQ')\n",
    "            acc = method[0][1]\n",
    "            err = method[0][0]\n",
    "            method_name = method[1]\n",
    "\n",
    "            if method_name not in list(reformed_accuracies):\n",
    "                reformed_accuracies[method_name] = [acc]\n",
    "            else:\n",
    "                reformed_accuracies[method_name].append(acc)\n",
    "    return reformed_accuracies"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAXsAAAD9CAYAAABdoNd6AAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4xLjIsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy8li6FKAAAgAElEQVR4nO3dd3hUZf7+8fcnEELvvYMgVYpEqSpYaF/brrq2XQsdAUFsq9hFWRWX0KW5uooN1LWsomI3oYXee++9J6Q8vz9m2F82GyCRkxxm5n5d11yBc87k3M/A3Dk5c+YZc84hIiLhLcrvACIikvtU9iIiEUBlLyISAVT2IiIRQGUvIhIB8vsdIKOyZcu6mjVr+h1DRCRkzJ8/f59zrty5trugyr5mzZokJib6HUNEJGSY2ebsbKfTOCIiESBbZW9mVc1stJnNMrMTZubMrGYW2xU0s9fMbKeZnQxuf6XXoUVEJGeye2RfB/gTcBD49SzbTQF6As8A1wM7gW/MrNn5hBQRkfOT3XP2vzjnKgCYWQ+gY+YNzKwpcBfQzTn3j+Cyn4HlwAvAjZ4kFhGRHMvWkb1zLj0bm90IpAAfZrhfKvAB0MnMYn5XQhEROW9evkDbCNjonDuRaflyoACBU0EiIuIDL8u+NIFz+pkdyLD+f5hZLzNLNLPEvXv3ehhHRERO8/3SS+fcROdcrHMutly5c74vQEQkrOxe9htLp72a6/vxsuwPAqWyWH76iP5AFutERCJSyomjzB7Xn68fvYI1X00gJel4ru7Py3fQLgf+YGaFM523bwicAtZ5uC8RkZC1ff43JIzqxfG9W2lw04Nceu9LRBcskqv79PLI/gsgGrjt9AIzyw/cDnzrnEv2cF8iIiEn6ch+fh1+L9891Zn8MYXpOvw3WvYZSXShorm+72wf2ZvZrcE/tgh+7WJme4G9zrmfnXMLzexDIM7MooGNQF+gFnC3l6FFREKJc47Nv33M7HH9SD56gCZ3PkWTO4aQv0DBPMuQk9M40zL9fVzw689A++Cf7wdeAoYCJYHFQGfn3ILzyCgiErJOHNjJ7LH92JLwKWXqXErHl76ldO2meZ4j22XvnLNsbHMSGBy8iYhELOcc6779B3MnDSY9JZkW9/+NRrc8TFQ+fyYbvqCmOBYRCQdHd20kYVQvdi6cSYXGV9Jm4CRKVL3Y10wqexERj6SnpbHqizEseOtJLCofrfqNo17X3liU729pUtmLiHjh0OYVxI/swd6Vs6gS24U2D06gSLlqfsf6D5W9iMh5SEs5xbLpr7L4vReJLlyMKx59l9od7sLsnC9z5imVvYjI77RvTSLxcd05uHEJNa/8Ey37jqZQyfJ+x8qSyl5EJIdSk06waOpzLP/kdQqVqsjVz35G9VYX9kd2qOxFRHJg15KfiR/Zg6M71lG3cw9iu79GTNGSfsc6J5W9iEg2nDp+hPlvPs7qr96gWMXadBr2PZWaXe13rGxT2YuInMO2uV+RMLo3Jw/soNEfB9P8Ly+Sv2Bhv2PliMpeROQMkg7vY+6EQWz4cSolazSiw5DplKvf0u9Yv4vKXkQkE+ccm375iDnjB5B87CBN736WJrc/Sb7oAn5H+91U9iIiGRzft53ZYx9g6+zPKXvxZXQa9j2lal3id6zzprIXESFwNL92xmTmTX6E9LQUYnsMp+HNg4jKl8/vaJ5Q2YtIxDuyYz2zRvVi5+IfqNikPW0GTqJ45Tp+x/KUyl5EIlZ6WhorPxvJgn8+RVS+aFoPmMDFnXtcEBOXeU1lLyIR6eCmZcTHdWff6rlUa3kDrfqPp0jZKn7HyjUqexGJKGkpp1j60TCWfPAS0YVLcOXj71PrqtsvuInLvKayF5GIsXf1XOLjunNo0zJqt7+Ly/uMpGCJsn7HyhMqexEJe6lJJ1j4ztOs+FcchUpV4prnvqBay+v9jpWnVPYiEtZ2Lv6RhLgeHN21gXpd+9Ci2ysUKFLc71h5TmUvImHp1PHDJE5+lDUzJlGsch06vfIjlZq09zuWb1T2IhJ2ts75klmj+3Dy4E4a3/ooze5+LuQmLvOayl5EwkbSob3MmTCQjT+9T8majbn66U8pW+8yv2NdEFT2IhLynHNs/Ol95rzxICknjtD8Ly/Q+LbHQ3riMq+p7EUkpB3fu41ZY/qybe6XlK3XkrYPTaFUjUZ+x7rgqOxFJCS59HTWzJhE4uRHcelpXNZrBA1uHBA2E5d5TWUvIiHnyPa1xI/sye6lP1Op6dW0GTiJYpVq+x3rguZp2ZtZW+BZoBlQCFgLjHHOvenlfkQkMqWnpbLi0xEsfOcZoqJjaDNoMnU7dgv7qQ684FnZm1kTYCYwG+gJnABuBaaYWYxzbrxX+xKRyHNg4xLiR3Rn/9pEqrW+idb9xlG4TGW/Y4UML4/s7wDyATc4544Fl30X/CFwD6CyF5EcSzuVzJIPXmLJR8OIKVaa9k9+RI12t+poPoe8LPsCQApwMtPyw0ApD/cjIhFiz8rZJMR159CWFVx0zT1c1uvvFCxexu9YIcnLGfrfCn4dZWaVzaykmfUErgFGeLgfEQlzKUnHmTvhIb56uA0pJ49y7QtfccUjb6voz4NnR/bOuWVm1h74FHgguDgF6OOc++BM9zOzXkAvgOrVq3sVR0RC1I6FM0kY2ZNjuzdR//oHaHH/34guXMzvWCHPyxdo6wIfA8uBPgRO59wEvGFmSc65qVndzzk3EZgIEBsb67zKIyKhJfnYIRInPczab9+keJW6dHntFyo0vsLvWGHDy3P2LxM4kr/eOZcSXPa9mZUBRprZ+865dA/3JyJhYnPCv5g99gGSDu2h8W2P0+zuZ8kfU8jvWGHFy7K/BFicoehPmwvcBZQHdnm4PxEJcScP7WHO+AFs+uUjStVuyjXPfUHZui38jhWWvCz7XUAzMyvgnDuVYXlLIAk44OG+RCSEOefY8ONU5r4xkJSTx2h+z1Auue0xovJH+x0tbHlZ9mOAacAXZjaOwDn7G4E7gRGZfgCISIQ6tmcLs0b3YXvi15Rr0Jq2g6ZQsnoDv2OFPS+vxpluZl2Bx4HJQEFgPdAPmODVfkQkNLn0dFZ/9QaJbz4O6elc3mck9a/vp4nL8oinc+M4574Gvvbye4pI6Du8bQ0JI3uwe9mvVG5+Ha0HTqRYhZp+x4oomvVSRHJNeloqyz9+nYXvBq6uaTv4H9S59l5NdeADlb2I5Ir96xeRENed/esWUKPtH2n5wFgKl67od6yIpbIXEU+lnkpiyXsvsnTaK8SUKEv7IdOp2e4Wv2NFPJW9iHhmz4oE4uO6c3jrKi669l4u7/V3YoqV9juWoLIXEQ+knDzGgreeZOUXYyhSrhrXDZ1BlRad/I4lGajsReS8bJ//LQmjenF87xYa3NCfS+97mehCRf2OJZmo7EXkd0k+eoB5kx5m3XdvUbxqPbq89isVGrX1O5acgcpeRHJsc/wnzBr7AMmH99Hk9idpctfT5C9Q0O9YchYqexHJthMHdjFnXH82x39M6drNuO6FrylTp7nfsSQbVPYick7OOdbP/CdzJz5EavIJLr3vZRrf8ogmLgshKnsROaujuzcxa1Rvdiz4lvIN29Jm0GRKVqvvdyzJIZW9iGTJpaez6ouxzH/rCTCj5QNjqP9/fbEoLz+6WvKKyl5E/sehLStJGNmDPSsSqNyiE20GTKBohRp+x5LzoLIXkf9IT01h2fTXWDT1eaILFaXdw29z0TV/0cRlYUBlLyIA7F+3gN9GdOPghsXUvOI2WvYdTaFSFfyOJR5R2YtEuNTkkyya+jzLPx5OwRLl6PD0p9Roc7PfscRjKnuRCLZ72a/Ex/XgyPY11O3Yjdgew4kpVsrvWJILVPYiEejU8SMseOsJVn05jqIVa9Hx5e+o3Pxav2NJLlLZi0SYbfO+Ztbo3hzft42GNw+i+b1DiS5YxO9YkstU9iIRIunIfuZNfIj1379DyeoN6fp6AuUbtPI7luQRlb1ImHPOsenXacwZ15/kYwdpeufTNLljCPkKxPgdTfKQyl4kjJ04sJPZY/uxJeFTytRtQcdhMyldq4nfscQHKnuRMOScY923/2DupMGkpyQT2/1VGv7hIaLy6SkfqfQvLxJmju7cQMLo3uxcOJMKja+k7aDJFK9S1+9Y4jOVvUiYSE9LY+Xno1n49hAsKh+t+o+nXpdemrhMAJW9SFg4tHkF8XHd2btqNlUv60rrAW9QpFw1v2PJBURlLxLC0lJOsWzaKyx+fyjRhYtxxaPvUrvDXZq4TP5HrpS9mXUF/gpcCqQDa4DHnHM/5Mb+RCLRvjWJxMd15+DGJdS66g5a9hlFwZLl/I4lFyjPy97MegNjgrcXgSigGVDY632JRKLUpBMsmvocyz95nUKlKnL1s59RvdWNfseSC5ynZW9mNYE44FHnXFyGVd94uR+RSLVryc/Ej+zB0R3ruLhzT2J7vEaBIiX8jiUhwOsj+24ETtu84fH3FYlop44fJvHNx1nz1QSKVaxNp2HfU6nZ1X7HkhDi9TVZ7YBVwB1mtt7MUs1snZn183g/IhFj69x/86/ejVg7YxKN/vgwN41fqqKXHPP6yL5y8PYa8CSwHrgNGGNm+Z1zIzPfwcx6Ab0Aqlev7nEckdCVdGgvcycMYsNP71GyRiM6PP0J5epd7ncsCVHmnPPum5mtAeoCtzjnPsmw/GugOVDJnWWHsbGxLjEx0bM8IqHIOcfGnz9kzvgBpJw4zCW3P0mT258kX3QBv6PJBcjM5jvnYs+1nddH9vsJlP13mZZ/C3QGKgE7PN6nSNg4vm87s8f0ZeucLyh78WW0HTSFUrUu8TuWhAGvy345cLYJstM93p9IWHDOsXbGZOZNfoT0tBRiewyn4c2DiMqXz+9oEia8LvtPge5AJ2B6huWdgW3OuV0e708k5B3ZsZ6EUT3ZtfhHKjZpT5uBkyheuY7fsSTMeF32XwE/AhPMrCywgcALtB2B+z3el0hIS09LY+VnI1nwz6eIyhdNmwcnUrdzD011ILnC07J3zjkzuxkYBjwPlCJwKebdzrn3vNyXSCg7uGkZ8XHd2bd6LtVa3kCr/uMpUraK37EkjHk+XYJz7gjQL3gTkQzSUk6x9KNhLPngJaILl+DKx9+n1lW362hecp1mvRTJI3tXzyU+rjuHNi2jdvu7uLzPSAqWKOt3LIkQKnuRXJaadIKF7zzNin/FUah0Za55/kuqXf5/fseSCKOyF8lFOxf/SEJcD47u2sDFXXsT2+1VChQp7ncsiUAqe5FccOr4YRInP8qaGZMoVrkOnV/5iYpNrvI7lkQwlb2Ix7bM/pzZY/py8uAuGt/6KM3+/Dz5Ywr5HUsinMpexCMnD+1hzvgH2fTLh5SqeQlXP/MZZS8+55QlInlCZS9ynpxzbPjxPeZOGEjKiSM0/8sLNL7tcU1cJhcUlb3IeTi+dxuzxvRl29wvKVe/FW0HTaFkjYZ+xxL5Hyp7kd/BpaezZsYkEic/iktP47JeI2hw4wBNXCYXLJW9SA4d2b6W+JE92b30Zyo1u4Y2D06kWKXafscSOSuVvUg2paelsuLTESx85xmiomNoM2gydTt201QHEhJU9iLZcGDjEuJHdGf/2kSqtb6J1v3GUbhMZb9jiWSbyl7kLNJOJbPkg5dY8tEwYoqW4qonPqTmFbfpaF5Cjspe5Az2rJxNQlx3Dm1ZwUXX/IXLeo2gYPEyfscS+V1U9iKZpJw8xoK3n2Ll56MoUrYq177wFVUv6+J3LJHzorIXyWDHwpkkjOzJsd2bqH9DP1rcN4zowsX8jiVy3lT2IkDy0YMkTn6Etd++SfEqF9PltV+o0PgKv2OJeEZlLxFvc/ynzB77AEmH93LJn/5K07ufJX+Bgn7HEvGUyl4i1okDu5gzfgCbf5tOqdpNufaFf1OmzqV+xxLJFSp7iTjOOdZ//w5zJwwiNek4l977Eo1vfZSo/NF+RxPJNSp7iSjH9mxh1ujebE+cQbkGrQMTl1Vv4HcskVynspeI4NLTWf3VGyS++Tg4R8s+o6h3/QOauEwihspewt7hbauJj+vBnuW/Ubn5dbQeOJFiFWr6HUskT6nsJWylp6aw7JPXWfTuc+SPKUy7wW9x0bX3aKoDiUgqewlL+9ctJD6uOwfWL6RG2z/S8oGxFC5d0e9YIr5R2UtYST2VxJL3XmTptFeIKVGW9kOmU7PdLX7HEvGdyl7Cxu7l8SSM7MHhrauoc919XNbzdWKKlfY7lsgFISo3v7mZzTAzZ2ZDc3M/EtlSTh5jzvgH+frRK0hNPsl1Q7+h3eB/qOhFMsi1I3szuxNomlvfXwRg+/xvSBjVi+N7t9Lghv5cet/LRBcq6ncskQtOrpS9mZUCRgAPAe/lxj4ksiUfPcDciYNZP/NtSlSrT9fhv1G+YRu/Y4lcsHLryP4VYJlz7n0zU9mLpzb99jGzx/Uj+ch+mtwxhCZ3PqWJy0TOwfOyN7N2wD3oFI547MSBncwZ15/N8Z9Qps6lXPfiDMpc1MzvWCIhwdOyN7MCwARguHNudTbv0wvoBVC9enUv40iYcM6xbubbzJv4EKnJJ2lx/99odMvDROXTxWQi2eX1s+UxoBDwUnbv4JybCEwEiI2NdR7nkRB3dPcmZo3sxY6F31Gh8RW0GTiZElUv9juWSMjxrOzNrDowBOgBxJhZTIbVMWZWEjjqnEvzap8Svlx6Oqu+GMv8t54AM1r1G0u9rn2wqFy9WlgkbHl5ZF8bKAi8m8W6R4K35sAiD/cpYejQlpUkjOzBnhUJVIntTOsBEyhaXqf4RM6Hl2W/COiQxfIfCfwAmAKs83B/EmbSU1NYOu1VFr/3AtGFinLFI/+k9tV/1sRlIh7wrOydc4eAnzIvDz5RNzvn/medyGn71y3gtxHdOLhhMTWv/BMt+4yiUKkKfscSCRu6nEF8lZp8kkVTn2f5x8MpWLI8HZ7+lBptbvY7lkjYyfWyd87pd3DJ0u5lvxIf14Mj29dQt1N3YnsMJ6ZoSb9jiYQlHdlLnjt1/AgL3nqCVV+Oo2jFWnR8eSaVm1/jdyyRsKaylzy1bd7XzBrdm+P7ttHw5kE0v3co0QWL+B1LJOyp7CVPJB3Zz7yJD7H++3coUa0BXV9PoHyDVn7HEokYKnvJVc45Nv06jTnj+pN87CBN73yaJncMIV+BmHPfWUQ8o7KXXHNi/w5mj+3Hlln/okzdFnQcNpPStZr4HUskIqnsxXPOOdZ++ybzJj1Mekoysd1fpeEfHtLEZSI+0rNPPHV05wYSRvVi56LvqdD4StoOmkzxKnX9jiUS8VT24on0tDRWfj6ahW8PwaLy0ar/eOp16aWJy0QuECp7OW+HNq8gPq47e1fNpuplXWk94A2KlKvmdywRyUBlL79bWsoplk17hcXvDyW6cDGufGwqtdrfqYnLRC5AKnv5Xfatnkd8XHcOblpKravuoGWfURQsWc7vWCJyBip7yZHUpBMsmvocyz95nUKlKnL1s59RvdWNfscSkXNQ2Uu27VzyEwkje3J0xzou7tyT2B6vUaBICb9jiUg2qOzlnE4dP0Lim4+x5qsJFKt0EZ3+9gOVmmb1OTUicqFS2ctZbZ37b2aN6s3Jgztp9MfBNP/Li+QvWNjvWCKSQyp7yVLSob3MnTCIDT+9R8kajejw1MeUq9/S71gi8jup7OW/OOfY+PMHzBn/ICknDtP07mdpcvuT5Isu4Hc0ETkPKnv5j+P7tjN7TF+2zvmCsvUup+2gKZSq2djvWCLiAZW9BCYumzGZeZMfIT0thct6vk6DmwYSlS+f39FExCMq+wh3ZMd6Ekb1ZNfiH6nYtANtHpxE8coX+R1LRDymso9Q6WlprPxsJAv++RRR+aJpPWACF3fpqakORMKUyj4CHdy0jPi47uxbPZdqLW+gVf/xFClbxe9YIpKLVPYRJO1UMks+GsbSD1+mQJGSXPXXD6h55Z90NC8SAVT2EWLv6rnEj+jGoc3Lqd3hbi7vHUfBEmX9jiUieURlH+ZSko6z6J1nWPGvOAqVqsQ1z39Jtcv/z+9YIpLHVPZhbOeiHwITl+3aQL2ufWjR7RUKFCnudywR8YHKPgwlHztE4pRHWTtjMsUq16HzKz9RsclVfscSER95WvZmditwJxALlAe2AJ8ALzvnjnq5L8naltmfM3tMX04e3EXjWx+j2Z+fI39MIb9jiYjPvD6yf4RAwT8JbAOaA88BHcysjXMu3eP9SdDJQ3uYM/5BNv3yIaVqXsLVz3xG2Ytj/Y4lIhcIr8v+Bufc3gx//9nMDgBvA+2BHzzeX8RzzrHhx/eY+8aDpJw8RvN7XqTxrY9p4jIR+S+eln2moj9tXvCr3rXjseN7tzJrdB+2zfuKcvVb0XbQFErWaOh3LBG5AOXFC7SnXxlcmQf7igguPZ3VX01g/puP49LTuLx3HPVv6K+Jy0TkjHK17M2sCvACMNM5l3iGbXoBvQCqV6+em3HCwpHta4mP68HuZb9Qqdk1tBk4iWIVa/kdS0QucLlW9mZWFPgMSAXuP9N2zrmJwESA2NhYl1t5Ql16WiorPh3BwneeISo6hraDplCn4/2a6kBEsiVXyt7MCgFfALWBq5xz23JjP5HiwIbFxMd1Z//a+VRvfTOt+o2lcJnKfscSkRDiedmbWTQwncC19tc555Z6vY9IkXYqmcUfDGXpR38jplhp2j85jRrtbtHRvIjkmNdvqooCpgJXA9c752Z7+f0jyZ6Vs4gf0Z3DW1dy0TX3cFmvv1OweBm/Y4lIiPL6yH4scBvwEnDczFplWLdNp3POLeXkMRa8/RQrPx9FkXLVuPbFr6ka29nvWCIS4rwu+y7Br0OCt4yeJ/BuWjmDHQu+I2FUL47t3kT9G/rR4r5hRBcu5ncsEQkDXr+pqqaX3y9SJB89SOLkR1j77ZsUr1qPLq/9SoXG7fyOJSJhRLNe+mxz/KfMHvsASYf3csmf/krTu58lf4GCfscSkTCjsvfJyYO7mT2uP5t/m07p2s249oV/U6bOpX7HEpEwpbLPY8451n//DnMnDCI1+QSX3vcyjW95hKj80X5HE5EwprLPQ8d2byZhdG92zP+G8g3b0GbQFEpWq+93LBGJACr7PODS01n17/HM/8dfwTla9hlF/Rv6YVFRfkcTkQihss9lh7etJj6uB3uW/0blFp1oM2ACRSvU8DuWiEQYlX0uSU9NYdnHw1k09XnyxxSm3eC3uOjaezTVgYj4QmWfC/avW0h8XHcOrF9IjXa30rLvaAqXruh3LBGJYCp7D6WeSmLxey+wbNqrxJQoS/sh06nZ7ha/Y4mIqOy9snt5PPFx3TmybTV1rrufy3q+TkyxUn7HEhEBVPbnLeXEUea/9SSrvhxLkXLVuW7oN1Rp0dHvWCIi/0Vlfx62z/+GhFG9Ob53Cw1uHMCl975EdKGifscSEfkfKvvfIfnoAeZOHMz6mW9Tolp9ug7/jfIN2/gdS0TkjFT2ObTp1+nMHteP5KMHaHLHEJrc+ZQmLhORC57KPptOHNjJnHH92Rz/CWXqXMp1Q7+hzEXN/I4lIpItKvtzcM6x7ru3mDdpMGmnkmjR7RUa/XEwUfn00IlI6FBjncXRXRtJGNWLnQtnUqHxFbQZOJkSVS/2O5aISI6p7LOQnpbGqi/HsuAfT0BUFK36jaNe196auExEQpbKPpNDW1YSH9edvStnUSW2C60HvEHR8tX9jiUicl5U9kHpqSksnfYqi997gehCRbni0Xeo3eFuTVwmImFBZQ/sX7eA30Z04+CGxdS84jZa9h1NoVIV/I4lIuKZiC771OSTLJr6PMs/Hk7BkuXp8PSn1Ghzs9+xREQ8F7Flv2vpLySM7MGR7Wup26k7sT2GE1O0pN+xRERyRcSV/anjR1jw1hOs+nIcRSvWouPLM6nc/Bq/Y4mI5KqIKvttc79i1pg+HN+3jYY3D6L5vUOJLljE71giIrkuIso+6fA+5k58iA0/vEvJ6g3p+noC5Ru08juWiEieCeuyd86x6ZePmDN+AMnHDtL0zqdpcscQ8hWI8TuaiEie8rTszawaMAK4DjBgJjDIObfFy/1kx4n9O5g19gG2zvqMMnVj6ThsJqVrNcnrGCIiFwTPyt7MCgM/AMnAvYADhgI/mlkT59xxr/Z1Ns451n4zhXmTHyE9JZnY7q/R8A+DNHGZiEQ0LxuwJ1AbqOecWwdgZkuAtUBv4O8e7itLR3duIGFkT3Yu/oEKl1xF20GTKV65Tm7vVkTkgudl2d8IzD5d9ADOuY1mFg/cRC6WfXpaGis/H8WCt4cQFZWf1gPe4OLOPTVxmYhIkJdl3wj4LIvly4HbPNzPf0k+epDvnu7CvtVzqHr59bTuP54i5arm1u5EREKSl2VfGjiYxfIDQKkz3cnMegG9AKpXz/nskgWKlqR4pYtoeNOD1Gp/pyYuExHJgu+vWjrnJgITAWJjY11O729mXPn4VM9ziYiEEy9Pah8k6yP4Mx3xi4hIHvGy7JcTOG+fWUNghYf7ERGRHPKy7D8HWplZ7dMLzKwm0Da4TkREfOJl2U8CNgGfmdlNZnYjgatztgITPNyPiIjkkGdlH3yH7NXAGuAdYCqwEbjaOXfMq/2IiEjOeXo1TnAOnFu8/J4iInL+9BZTEZEIoLIXEYkA5lyO38eUa8xsL7D5d969LLDPwzihIBLHDJE57kgcM0TmuHM65hrOuXLn2uiCKvvzYWaJzrlYv3PkpUgcM0TmuCNxzBCZ486tMes0johIBFDZi4hEgHAq+4l+B/BBJI4ZInPckThmiMxx58qYw+acvYiInFk4HdmLiMgZqOxFRCJASJe9mVUzs+lmdtjMjpjZJ2aW84+7ugCZ2a1m9rGZbTazk2a22syGmVmxTNuVMrPJZrbPzI6b2Uwzu8Sv3F4zsxlm5sxsaKblYTduM+tqZr+Y2bHg/+dEM7s6w/pwHHNbM/vWzPaY2VEzW2Bm3TJtU9DMXjOzncHnwiwzu9KvzDlhZlXNbHQw84ng/+WaWWyXrTGaWZSZPWFmm8wsycwWm1m2pqgJ2bI3s8LAD0B94F7gL0Bd4EczK+JnNo88AqQBTwKdgZfUw78AAAV0SURBVPFAX+A7M4sCsMBnMH4RXD+AwLxE0QQeg5D/IF4zuxNomsXysBu3mfUmMEvsfOAPBD63eRpQOLg+HMfcBJhJYBw9gT8C84ApZtY3w6ZTguufAa4HdgLfmFmzvE38u9QB/kTgA5x+Pct22R3ji8BzwBigCzAbmGZmXc+ZxDkXkjdgIIEyrJNhWS0gFRjsdz4Pxlcui2X3AI7ATKIANwX/3iHDNiUIfO7vKL/HcJ7jLwXsAu4MjnFohnVhNW6gJnASGHSWbcJqzMH8LwOngKKZls8CZgX/3DQ47vszrM8PrAY+93sM2RhjVIY/9wiOpWambbI1RqA8kAw8n+n+3wNLzpUlZI/sgRuB2c65dacXOOc2AvEEnhghzTm3N4vF84JfqwS/3gjscM79mOF+hwkcAYb6Y/AKsMw5934W68Jt3N2AdOCNs2wTbmMGKACkEPhBl9Fh/v9ZhxuD23x4eqVzLhX4AOhkZjF5kPN3c86lZ2Oz7I6xE4HH7N1M938XuMTMap1tJ6Fc9o2AZVksX07goxDD0VXBryuDX8/2GFQ3s6J5kspjZtaOwG8x/c6wSbiNux2wCrjDzNabWaqZrTOzjOMPtzEDvBX8OsrMKptZSTPrCVwDjAiuawRsdM6dyHTf5QSKr06eJM1d2R1jIwJH9uuy2A7O0XuhXPZn+iDzA2T9wechzcyqAC8AM51zicHFZ3sMIAQfBzMrQOCTzYY751afYbNwG3dlAq83vQb8DegIfAeMMbOBwW3Cbcw455YB7Qn8ZrKdwPjGAn2ccx8ENzvXuEvncsy8kN0xlgYOueC5m7NslyVPP7xEckfwqO0zAq9H3O9znNz2GFAIeMnvIHkoCigG3Oec+yS47IfgVRtPmNkov4LlJjOrC3xM4Mi0D4HTOTcBb5hZknNuqp/5wk0ol/1Bsj6aOdNPyZBkZoUInJetDVzlnNuWYfXZHoPT60NG8LLZIQReyIrJdD42xsxKAkcJs3ED+wkc2X+Xafm3BK6+qUT4jRkCL9CmANc751KCy743szLASDN7n8C4amRx39PjPpDFulCT3TEeBEqamWU6us/WYxHKp3GWEziHlVlDYEUeZ8kVZhYNTAdiga7OuaWZNjnbY7DFhd5n/9YGChJ4welghhsELkU9CFxC+I17+TnWpxN+Y4bAv+XiDEV/2lygDIGrT5YDtYKXWmfUkMCVPJnPX4ei7I5xORADXJTFdnCO3gvlsv8caGVmtU8vCP7a2za4LqQFr6WfSuBD3G92zs3OYrPPgSpmdlWG+xUHbiA0H4NFQIcsbhD4AdCBwH/8cBv3p8GvnTIt7wxsc87tIvzGDIFLa5sFX6fJqCWQROBI9QsC1+HfdnqlmeUHbge+dc4l51HW3JTdMc4g8JvQ3Znu/2cCV65tPOte/L4O9TyuXy1C4Im/lMB5vhuBxcAGMl23G4o3Am+icsBQoFWmW9XgNlFAArAVuINAWfxE4ElSze8xePhYZL7OPqzGDRiBNwjuJ3DuuiMwKTju+8JxzMEx3Roc4zfB53BHAm8WcsDfM2z3AYHf6noQuFJnOoEfBpf6PYYcjPPWDM/pvsG/X5XTMRJ4AT8JGEzgxe3xBH7zu/6cOfx+IM7zQaxO4AWeIwTO5f6LTG9YCNUbsCn4HyOr23MZtisNvBl80p8g8AaLpn7n9/ix+K+yD8dxA8UJXImym8Cv7kuAu8J5zMExdQn+0NobfA4vAh4A8mXYphDwdwK/CSQBc4D2fmfPwRjP9Dz+KadjBPIBTxH4+Nbk4P+TW7OTQ1Mci4hEgFA+Zy8iItmkshcRiQAqexGRCKCyFxGJACp7EZEIoLIXEYkAKnsRkQigshcRiQD/DzqlL80ESU9yAAAAAElFTkSuQmCC\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "x = np.arange(0, 10, 0.1)\n",
    "colors = [\n",
    "        (0.00784313725490196, 0.24313725490196078, 1.0),\n",
    "        (1.0, 0.48627450980392156, 0.0),\n",
    "        (0.9098039215686274, 0.0, 0.043137254901960784),\n",
    "        (0.5450980392156862, 0.16862745098039217, 0.8862745098039215),\n",
    "        (0.6235294117647059, 0.2823529411764706, 0.0)]\n",
    "for color in colors:\n",
    "    plt.plot(x, color=color)\n",
    "    plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 104,
   "metadata": {},
   "outputs": [],
   "source": [
    "def plot_accuracies(accuracies, xaxis, filename, xtitle, ytitle, xscale=True):\n",
    "    colors = [\n",
    "        (0.00784313725490196, 0.24313725490196078, 1.0),\n",
    "        (1.0, 0.48627450980392156, 0.0),\n",
    "        (0.9098039215686274, 0.0, 0.043137254901960784),\n",
    "        (0.5450980392156862, 0.16862745098039217, 0.8862745098039215),\n",
    "        (0.6235294117647059, 0.2823529411764706, 0.0)]\n",
    "    colors2 = [(0.00392156862745098, 0.45098039215686275, 0.6980392156862745),\n",
    " (0.8705882352941177, 0.5607843137254902, 0.0196078431372549),\n",
    " (0.00784313725490196, 0.6196078431372549, 0.45098039215686275),\n",
    " (0.8352941176470589, 0.3686274509803922, 0.0),\n",
    " (0.8, 0.47058823529411764, 0.7372549019607844),\n",
    " (0.792156862745098, 0.5686274509803921, 0.3803921568627451)]\n",
    "    colors3 = [(0.7561707035755478, 0.21038062283737025, 0.22352941176470587),\n",
    " (0.940715109573241, 0.6099192618223759, 0.4812764321414839),\n",
    " (0.9856978085351787, 0.8889657823913879, 0.8320645905420992),\n",
    " (0.8605151864667436, 0.9174163783160324, 0.9487120338331411),\n",
    " (0.530026912725875, 0.7456362937331797, 0.8560553633217994),\n",
    " (0.1843137254901961, 0.47266435986159167, 0.7116493656286044)]\n",
    "    dark =[(0.0, 0.10980392156862745, 0.4980392156862745),\n",
    " (0.6941176470588235, 0.25098039215686274, 0.050980392156862744),\n",
    " (0.07058823529411765, 0.44313725490196076, 0.10980392156862745),\n",
    " (0.5490196078431373, 0.03137254901960784, 0.0),\n",
    " (0.34901960784313724, 0.11764705882352941, 0.44313725490196076),\n",
    " (0.34901960784313724, 0.1843137254901961, 0.050980392156862744)]\n",
    "    color = [[0.00784314, 0.24313725, 1.],\n",
    "             [1., 0.48627451, 0.],\n",
    "             [0.10196078, 0.78823529, 0.21960784],\n",
    "             [0.90980392, 0., 0.04313725],\n",
    "             [0.54509804, 0.16862745, 0.88627451]]\n",
    "    #style = ['-', '--', ':', '-.']\n",
    "    styles = ['-']\n",
    "    orders = [ 'ALQ', 'AMQ', 'ALQ-N', 'AMQ-N','Qinf', 'TRN', 'NUQ,p=0.5', 'SignSGD', 'SignSGDInf']\n",
    "    import collections\n",
    "#     markers = \n",
    "    colors = color\n",
    "#     styles = ['-', '--', ':', '-.']\n",
    "    markers = ['o', 'X', 'p', '*', 'd', 'v']\n",
    "    index = 0\n",
    "    accuracies = collections.OrderedDict(sorted(accuracies.items()))\n",
    "    print(accuracies)\n",
    "    for method, vals in accuracies.items():\n",
    "        style = styles[0]\n",
    "        index_2 = orders.index(method)\n",
    "        color = colors[(index_2) % len(colors)]\n",
    "        marker = markers[(index_2) % len(markers)]\n",
    "        vals = np.array(vals)\n",
    "        indexes = vals != 0\n",
    "        plt.plot(np.array(xaxis)[indexes], vals[indexes], label=method, color=color, linestyle=style, marker=marker, markersize=10+index_2, markevery=2+index_2%3)\n",
    "        index += 1\n",
    "    ax = plt.gca()\n",
    "    if xscale:\n",
    "        ax.set_xscale('log')\n",
    "        ax.xaxis.set_major_formatter(mtick.ScalarFormatter())\n",
    "        ax.ticklabel_format(axis=\"x\", style=\"sci\", scilimits=(0,0))\n",
    "    ax.set_xlabel(xtitle)\n",
    "    plt.grid(linewidth=1)\n",
    "    ax.set_ylabel(ytitle + ' (%)')\n",
    "    handles, labels = plt.gca().get_legend_handles_labels()\n",
    "\n",
    "#     plt.title(ytitle + ' vs ' + xtitle)\n",
    "    norders = []\n",
    "    for order in orders:\n",
    "        if order in labels:\n",
    "            norders.append(order)\n",
    "\n",
    "    order = []\n",
    "    \n",
    "    for label in labels:\n",
    "        order.append(norders.index(label))\n",
    "    \n",
    "    nlabels = np.arange(len(labels)).tolist()\n",
    "    nhandles = np.arange(len(handles)).tolist()\n",
    "    for idx, label, handle in zip(order, labels, handles):\n",
    "        nlabels[idx] = label\n",
    "        nhandles[idx] = handle\n",
    "    print(nlabels)\n",
    "    dirn = 'figs_acc/'\n",
    "    plt.savefig(dirn + filename, dpi=100, bbox_inches='tight')\n",
    "    plt.legend(nhandles, nlabels, bbox_to_anchor=(1.01, 1.0))\n",
    "    plt.savefig(dirn+'lo-'+filename, dpi=100, bbox_inches='tight')\n",
    "    plt.legend(nhandles, nlabels)\n",
    "    plt.savefig(dirn+'li-'+filename, dpi=100, bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 80,
   "metadata": {},
   "outputs": [],
   "source": [
    "def trim_name(name, accuracies, pad=None):\n",
    "    new_accuracies = [0]*pad\n",
    "    for method, vals in accuracies.items():\n",
    "        new_accuracies += vals\n",
    "    return {\n",
    "        name: new_accuracies\n",
    "    }"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 130,
   "metadata": {},
   "outputs": [],
   "source": [
    "lg_tags = ['estim_sgd', 'nuq_method', 'nuq_mul']\n",
    "logdir = '/h/iman/Code/nuqsgd/runs'\n",
    "tag = 'Vacc'\n",
    "ytitle = 'Validation Accuracy'\n",
    "lg_replace = [('p2_', 'P='), ('estim_sgd', 'SGD'), ('nuq_mul_', 'p='), ('ngpu_', 'GPU='), ('nuq_method', ''), ('_q', 'Q'), ('nuq_inv_', 'Inv'), ('nuq_sym_', 'Sym'), ('_amq_nb', 'AMQ'), ('_amq', 'AMQ-N'), ('_alq_nb', 'ALQ'), ('_trn', 'TRN'), ('_alq', 'ALQ-N'), ('_qinf', 'Qinf'), ('kfac', 'K-FAC'), ('SGD,K-FAC', 'K-FAC'), ('estim_ntk', 'NTK'), ('adamw', 'AdamW'), ('adam', 'Adam'), ('lr_', 'LR='), ('LR=0.001', 'LR=1e-3'), ('LR=0.0001', 'LR=1e-4'), ('LR=0.0005', 'LR=5e-4'), ('LR=0.0002', 'LR=2e-4'), ('batch_size_', 'bs='), ('optim_start_', 'Start='), ('damping_', '$\\epsilon=$'), ('_l2q', 'L2Q'), ('_none', 'SuperSGD'), ('nuq_layer_1', 'w/o layers'), ('nuq_layer_0', 'w/ layers'),('_nuq', 'NUQ')]\n",
    "bucket_sizes = ['32', '64', '128', '256', '512', '1024', '2048', '4096', '8192', '16384', '32768']\n",
    "accuracies_bs = []\n",
    "for bucket_size in bucket_sizes:\n",
    "    patterns = ['.*runs_cifar10_full/bs_.*nuq_bucket_size_' + bucket_size + '.*,(?!(.*nuq_sym.*|.*nuq_inv))']\n",
    "    accuracies_bs.append(get_accuracies(patterns, lg_replace, lg_tags, logdir, tag))\n",
    "\n",
    "accuracies_sgi = []\n",
    "lg_tags = ['sa2']\n",
    "lg_replace = [('sa2_', 'SignSGDInf')]\n",
    "bucket_sizes = ['2048', '4096', '8192', '16384', '32768']\n",
    "\n",
    "for bucket_size in bucket_sizes:\n",
    "    patterns = ['.*runs_cifar10_full/sa2_.*nuq_bucket_size_' + bucket_size + '.*,(?!(.*nuq_sym.*|.*nuq_inv))']\n",
    "    accuracies_sgi.append(get_accuracies(patterns, lg_replace, lg_tags, logdir, tag))\n",
    "\n",
    "accuracies_sg = []\n",
    "\n",
    "lg_tags = ['sa3']\n",
    "lg_replace = [('sa3_', 'SignSGD')]\n",
    "for bucket_size in bucket_sizes:\n",
    "    patterns = ['.*runs_cifar10_full/sa3_.*nuq_bucket_size_' + bucket_size + '.*,(?!(.*nuq_sym.*|.*nuq_inv))']\n",
    "    accuracies_sg.append(get_accuracies(patterns, lg_replace, lg_tags, logdir, tag))\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 113,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[{'Vacc': [[((0.06118858728755413, 86.56599884033203), 'AMQ'),\n",
       "    ((0.07138485048278534, 86.54200134277343), 'AMQ-N'),\n",
       "    ((0.09899513434545146, 88.06999969482422), 'ALQ'),\n",
       "    ((0.12607974482436077, 73.32799987792968), 'NUQ,p=0.5'),\n",
       "    ((0.07059692648369724, 88.19400024414062), 'ALQ-N'),\n",
       "    ((0.12142331767731569, 83.84400024414063), 'Qinf'),\n",
       "    ((0.06343537560644226, 84.8760009765625), 'TRN')]],\n",
       "  'Tacc': [[((0.06014057600040922, 91.29719848632813), 'AMQ'),\n",
       "    ((0.05995460777391494, 91.36920013427735), 'AMQ-N'),\n",
       "    ((0.07512437016038431, 95.02960052490235), 'ALQ'),\n",
       "    ((0.07191725601811555, 74.64519958496093), 'NUQ,p=0.5'),\n",
       "    ((0.06468632922316665, 94.9875991821289), 'ALQ-N'),\n",
       "    ((0.06369989877651171, 86.36999969482422), 'Qinf'),\n",
       "    ((0.11212507255989353, 88.7947982788086), 'TRN')]]},\n",
       " {'Vacc': [[((0.0884078724428425, 88.1779998779297), 'ALQ'),\n",
       "    ((0.07889119753575055, 87.31399841308594), 'TRN'),\n",
       "    ((0.03611121737326853, 88.1240020751953), 'ALQ-N'),\n",
       "    ((0.07848532531527669, 88.07999877929687), 'NUQ,p=0.5'),\n",
       "    ((0.08183023588238766, 88.12799987792968), 'AMQ-N'),\n",
       "    ((0.058444683357310276, 88.21199951171874), 'Qinf'),\n",
       "    ((0.0348730398860167, 88.27799987792969), 'AMQ')]],\n",
       "  'Tacc': [[((0.05730576352153899, 95.63639984130859), 'ALQ'),\n",
       "    ((0.0846722821739573, 94.61399993896484), 'TRN'),\n",
       "    ((0.05200753629737746, 95.6343994140625), 'ALQ-N'),\n",
       "    ((0.09916915252308234, 95.31119995117187), 'NUQ,p=0.5'),\n",
       "    ((0.07059119797232409, 95.68440093994141), 'AMQ-N'),\n",
       "    ((0.039827956372233686, 95.68240051269531), 'Qinf'),\n",
       "    ((0.04754255046720031, 95.79919891357422), 'AMQ')]]},\n",
       " {'Vacc': [[((0.08376240873219387, 88.41200103759766), 'ALQ-N'),\n",
       "    ((0.04049802880416699, 88.36999969482422), 'AMQ'),\n",
       "    ((0.025768135900539082, 88.11600036621094), 'NUQ,p=0.5'),\n",
       "    ((0.0354400834484499, 88.62200012207032), 'ALQ'),\n",
       "    ((0.05980039637691752, 87.96200103759766), 'AMQ-N'),\n",
       "    ((0.06177205770630969, 88.52200012207031), 'Qinf'),\n",
       "    ((0.07456496552875001, 87.65999908447266), 'TRN')]],\n",
       "  'Tacc': [[((0.07868296869375588, 95.53559875488281), 'ALQ-N'),\n",
       "    ((0.03460955164188317, 95.58679962158203), 'AMQ'),\n",
       "    ((0.05702046090618855, 94.37999877929687), 'NUQ,p=0.5'),\n",
       "    ((0.09015882911600336, 95.75920104980469), 'ALQ'),\n",
       "    ((0.06389221836852077, 95.60760040283203), 'AMQ-N'),\n",
       "    ((0.0798939317377115, 95.70839996337891), 'Qinf'),\n",
       "    ((0.0767223786874461, 94.39200134277344), 'TRN')]]},\n",
       " {'Vacc': [[((0.0873145649643346, 88.44599914550781), 'ALQ-N'),\n",
       "    ((0.12383955389824632, 88.5780014038086), 'Qinf'),\n",
       "    ((0.045868533518044236, 88.14400024414063), 'ALQ'),\n",
       "    ((0.04707337973917455, 88.32799987792968), 'AMQ'),\n",
       "    ((0.07494042884923992, 88.20200042724609), 'TRN'),\n",
       "    ((0.07364949624245554, 88.7040008544922), 'AMQ-N'),\n",
       "    ((0.07694091751483552, 86.86999969482422), 'NUQ,p=0.5')]],\n",
       "  'Tacc': [[((0.017598100147512577, 95.52279968261719), 'ALQ-N'),\n",
       "    ((0.036890118265852354, 95.69320068359374), 'Qinf'),\n",
       "    ((0.03297553791150307, 95.65279998779297), 'ALQ'),\n",
       "    ((0.04971372993913838, 95.62720031738282), 'AMQ'),\n",
       "    ((0.10263406945664885, 94.11520080566406), 'TRN'),\n",
       "    ((0.0591489906217782, 95.57519989013672), 'AMQ-N'),\n",
       "    ((0.03511428348141315, 92.60079956054688), 'NUQ,p=0.5')]]},\n",
       " {'Vacc': [[((0.07694210742731264, 87.13999938964844), 'TRN'),\n",
       "    ((0.07781861646126395, 88.01800079345703), 'AMQ-N'),\n",
       "    ((0.10268573708818189, 88.33600006103515), 'Qinf'),\n",
       "    ((0.06615057214741711, 88.48800048828124), 'ALQ'),\n",
       "    ((0.09911706897475639, 85.6259994506836), 'NUQ,p=0.5'),\n",
       "    ((0.12448167341160961, 88.1020004272461), 'ALQ-N'),\n",
       "    ((0.08236640760396623, 88.68399963378906), 'AMQ')]],\n",
       "  'Tacc': [[((0.04653303070276585, 93.4363998413086), 'TRN'),\n",
       "    ((0.08591547453460453, 95.24920043945312), 'AMQ-N'),\n",
       "    ((0.037599425645783294, 95.50319976806641), 'Qinf'),\n",
       "    ((0.07390284919576004, 95.5707992553711), 'ALQ'),\n",
       "    ((0.10981459297452836, 90.16000061035156), 'NUQ,p=0.5'),\n",
       "    ((0.08637078326796042, 95.48159942626953), 'ALQ-N'),\n",
       "    ((0.04192157441627552, 95.54639892578125), 'AMQ')]]},\n",
       " {'Vacc': [[((0.059463942450024225, 88.0979995727539), 'Qinf'),\n",
       "    ((0.05268708302836572, 84.46200103759766), 'NUQ,p=0.5'),\n",
       "    ((0.08772603897986038, 87.48199920654297), 'TRN'),\n",
       "    ((0.03919257720949622, 88.51799926757812), 'ALQ'),\n",
       "    ((0.041182722188737884, 88.53200073242188), 'ALQ-N'),\n",
       "    ((0.07709718592303572, 88.75400085449219), 'AMQ'),\n",
       "    ((0.07222180094478896, 88.38200073242187), 'AMQ-N')]],\n",
       "  'Tacc': [[((0.07411738104939232, 95.15359954833984), 'Qinf'),\n",
       "    ((0.09868275284553267, 87.26519927978515), 'NUQ,p=0.5'),\n",
       "    ((0.052717408877162066, 93.33400115966796), 'TRN'),\n",
       "    ((0.06497595907556955, 95.35480041503907), 'ALQ'),\n",
       "    ((0.05397162218318757, 95.45920104980469), 'ALQ-N'),\n",
       "    ((0.08328765783095136, 95.40519866943359), 'AMQ'),\n",
       "    ((0.06614700398322845, 95.4948013305664), 'AMQ-N')]]},\n",
       " {'Vacc': [[((0.07536790464034748, 88.39000091552734), 'ALQ-N'),\n",
       "    ((0.04427066027499949, 88.31999969482422), 'ALQ'),\n",
       "    ((0.08772576067412238, 87.06799926757813), 'TRN'),\n",
       "    ((0.055352168448354555, 82.13399963378906), 'NUQ,p=0.5'),\n",
       "    ((0.07964923409703924, 87.91399993896485), 'AMQ-N'),\n",
       "    ((0.06554395853028801, 87.97200012207031), 'AMQ'),\n",
       "    ((0.07547256560902868, 88.06199951171875), 'Qinf')]],\n",
       "  'Tacc': [[((0.06301577186242216, 95.41199951171875), 'ALQ-N'),\n",
       "    ((0.036953844414758845, 95.32960052490235), 'ALQ'),\n",
       "    ((0.0865186275540214, 92.93519897460938), 'TRN'),\n",
       "    ((0.13667323926870245, 84.88879852294922), 'NUQ,p=0.5'),\n",
       "    ((0.03768028073216587, 95.3396011352539), 'AMQ-N'),\n",
       "    ((0.08974246880637575, 95.22480010986328), 'AMQ'),\n",
       "    ((0.0938975175164923, 94.83359985351562), 'Qinf')]]},\n",
       " {'Vacc': [[((0.12092949648551905, 79.68399963378906), 'NUQ,p=0.5'),\n",
       "    ((0.0781291264695918, 87.44599914550781), 'AMQ'),\n",
       "    ((0.07110525148884851, 88.40800170898437), 'ALQ-N'),\n",
       "    ((0.07386292007879888, 88.07799987792968), 'ALQ'),\n",
       "    ((0.062288254630585224, 87.6), 'AMQ-N'),\n",
       "    ((0.07445759432358459, 87.52400054931641), 'Qinf'),\n",
       "    ((0.05035929019807214, 86.37200012207032), 'TRN')]],\n",
       "  'Tacc': [[((0.08210875216256011, 81.46519927978515), 'NUQ,p=0.5'),\n",
       "    ((0.04962868272527615, 94.81759948730469), 'AMQ'),\n",
       "    ((0.0441908753413853, 95.1552017211914), 'ALQ-N'),\n",
       "    ((0.05614779466363481, 95.29159851074219), 'ALQ'),\n",
       "    ((0.061063771139582904, 94.68519897460938), 'AMQ-N'),\n",
       "    ((0.04781755645238964, 93.61800079345703), 'Qinf'),\n",
       "    ((0.08348688699479678, 91.510400390625), 'TRN')]]},\n",
       " {'Vacc': [[((0.05238309158411574, 87.90599975585937), 'AMQ'),\n",
       "    ((0.06279996574152584, 87.99600067138672), 'AMQ-N'),\n",
       "    ((0.08461556418818886, 88.47000122070312), 'ALQ'),\n",
       "    ((0.0372029610157204, 86.88399963378906), 'Qinf'),\n",
       "    ((0.03310733982582585, 75.71799926757812), 'NUQ,p=0.5'),\n",
       "    ((0.07787370684793421, 88.39399871826171), 'ALQ-N'),\n",
       "    ((0.05885562522611922, 86.2739974975586), 'TRN')]],\n",
       "  'Tacc': [[((0.05576393457910465, 94.5884002685547), 'AMQ'),\n",
       "    ((0.08011601083929262, 94.0696014404297), 'AMQ-N'),\n",
       "    ((0.03549800784910384, 95.37080078125), 'ALQ'),\n",
       "    ((0.0788273570084282, 92.74320068359376), 'Qinf'),\n",
       "    ((0.11376268501311491, 76.68320007324219), 'NUQ,p=0.5'),\n",
       "    ((0.0987389519364556, 95.25719909667968), 'ALQ-N'),\n",
       "    ((0.091485400297982, 91.24600219726562), 'TRN')]]},\n",
       " {'Vacc': [[((0.07797535670145704, 76.36999969482422), 'NUQ,p=0.5'),\n",
       "    ((0.061642209333043804, 85.81999969482422), 'TRN'),\n",
       "    ((0.044543408471977713, 88.61600189208984), 'ALQ'),\n",
       "    ((0.03610994975308558, 87.80599822998047), 'AMQ'),\n",
       "    ((0.06956873992093576, 87.71999969482422), 'AMQ-N'),\n",
       "    ((0.07445845503181509, 85.65400085449218), 'Qinf'),\n",
       "    ((0.06939582847249176, 87.98200073242188), 'ALQ-N')]],\n",
       "  'Tacc': [[((0.09888057577302092, 77.8760009765625), 'NUQ,p=0.5'),\n",
       "    ((0.05181280210925169, 90.18800048828125), 'TRN'),\n",
       "    ((0.0778780375540452, 95.23280029296875), 'ALQ'),\n",
       "    ((0.03770611020335278, 93.59920043945313), 'AMQ'),\n",
       "    ((0.05032960510993854, 93.63200073242187), 'AMQ-N'),\n",
       "    ((0.07924063040274328, 90.58479919433594), 'Qinf'),\n",
       "    ((0.056746376809310765, 95.45120086669922), 'ALQ-N')]]},\n",
       " {'Vacc': [[((0.06118858728755413, 86.56599884033203), 'AMQ'),\n",
       "    ((0.07138485048278534, 86.54200134277343), 'AMQ-N'),\n",
       "    ((0.09899513434545146, 88.06999969482422), 'ALQ'),\n",
       "    ((0.12607974482436077, 73.32799987792968), 'NUQ,p=0.5'),\n",
       "    ((0.07059692648369724, 88.19400024414062), 'ALQ-N'),\n",
       "    ((0.12142331767731569, 83.84400024414063), 'Qinf'),\n",
       "    ((0.06343537560644226, 84.8760009765625), 'TRN')]],\n",
       "  'Tacc': [[((0.06014057600040922, 91.29719848632813), 'AMQ'),\n",
       "    ((0.05995460777391494, 91.36920013427735), 'AMQ-N'),\n",
       "    ((0.07512437016038431, 95.02960052490235), 'ALQ'),\n",
       "    ((0.07191725601811555, 74.64519958496093), 'NUQ,p=0.5'),\n",
       "    ((0.06468632922316665, 94.9875991821289), 'ALQ-N'),\n",
       "    ((0.06369989877651171, 86.36999969482422), 'Qinf'),\n",
       "    ((0.11212507255989353, 88.7947982788086), 'TRN')]]}]"
      ]
     },
     "execution_count": 113,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "accuracies_bs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 117,
   "metadata": {},
   "outputs": [],
   "source": [
    "reformed_accuracies_sgi = format_accuracies(accuracies_sgi, tag)\n",
    "reformed_accuracies_sg = format_accuracies(accuracies_sg, tag)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 118,
   "metadata": {},
   "outputs": [],
   "source": [
    "trimmed_accuracies_sgi = trim_name('SignSGDInf', reformed_accuracies_sgi, pad=6)\n",
    "trimmed_accuracies_sg = trim_name('SignSGD', reformed_accuracies_sg, pad=6)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 119,
   "metadata": {},
   "outputs": [],
   "source": [
    "reformed_accuracies_bs = format_accuracies(accuracies_bs, tag)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 120,
   "metadata": {},
   "outputs": [],
   "source": [
    "reformed_accuracies_bs['SignSGD'] = trimmed_accuracies_sg['SignSGD']\n",
    "reformed_accuracies_bs['SignSGDInf'] = trimmed_accuracies_sgi['SignSGDInf']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 121,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "OrderedDict([('ALQ', [88.06999969482422, 88.1779998779297, 88.62200012207032, 88.14400024414063, 88.48800048828124, 88.51799926757812, 88.31999969482422, 88.07799987792968, 88.47000122070312, 88.61600189208984, 88.06999969482422]), ('ALQ-N', [88.19400024414062, 88.1240020751953, 88.41200103759766, 88.44599914550781, 88.1020004272461, 88.53200073242188, 88.39000091552734, 88.40800170898437, 88.39399871826171, 87.98200073242188, 88.19400024414062]), ('AMQ', [86.56599884033203, 88.27799987792969, 88.36999969482422, 88.32799987792968, 88.68399963378906, 88.75400085449219, 87.97200012207031, 87.44599914550781, 87.90599975585937, 87.80599822998047, 86.56599884033203]), ('AMQ-N', [86.54200134277343, 88.12799987792968, 87.96200103759766, 88.7040008544922, 88.01800079345703, 88.38200073242187, 87.91399993896485, 87.6, 87.99600067138672, 87.71999969482422, 86.54200134277343]), ('NUQ,p=0.5', [73.32799987792968, 88.07999877929687, 88.11600036621094, 86.86999969482422, 85.6259994506836, 84.46200103759766, 82.13399963378906, 79.68399963378906, 75.71799926757812, 76.36999969482422, 73.32799987792968]), ('Qinf', [83.84400024414063, 88.21199951171874, 88.52200012207031, 88.5780014038086, 88.33600006103515, 88.0979995727539, 88.06199951171875, 87.52400054931641, 86.88399963378906, 85.65400085449218, 83.84400024414063]), ('SignSGD', [0, 0, 0, 0, 0, 0, 62.69200057983399, 56.885999298095705, 56.87799987792969, 62.470000457763675, 60.344000244140624]), ('SignSGDInf', [0, 0, 0, 0, 0, 0, 77.00599975585938, 76.21600036621093, 70.62799987792968, 69.32999877929687, 67.83000030517579]), ('TRN', [84.8760009765625, 87.31399841308594, 87.65999908447266, 88.20200042724609, 87.13999938964844, 87.48199920654297, 87.06799926757813, 86.37200012207032, 86.2739974975586, 85.81999969482422, 84.8760009765625])])\n",
      "['ALQ', 'AMQ', 'ALQ-N', 'AMQ-N', 'Qinf', 'TRN', 'NUQ,p=0.5', 'SignSGD', 'SignSGDInf']\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "bucket_sizes = ['32', '64', '128', '256', '512', '1024', '2048', '4096', '8192', '16384', '32768']\n",
    "bucket_sizes = list(map(int, bucket_sizes))\n",
    "plot_accuracies(reformed_accuracies_bs, bucket_sizes, 'bucket-size-t.pdf', xtitle='Bucket Size', ytitle=ytitle)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 131,
   "metadata": {},
   "outputs": [],
   "source": [
    "accuracies_bits = []\n",
    "\n",
    "bits = ['2']\n",
    "for bit in bits:\n",
    "    patterns = ['.*runs_cifar10_full/bi3_.*nuq_bits_' + bit + ',.*,(?!(.*nuq_sym.*|.*nuq_inv))']\n",
    "    accuracies_bits.append(get_accuracies(patterns, lg_replace, lg_tags, logdir))\n",
    "bits = [ '3', '4', '5']\n",
    "for bit in bits:\n",
    "    patterns = ['.*runs_cifar10_full/bi2_.*nuq_bits_' + bit + ',.*,(?!(.*nuq_sym.*|.*nuq_inv))']\n",
    "    accuracies_bits.append(get_accuracies(patterns, lg_replace, lg_tags, logdir))\n",
    "bits = ['6']\n",
    "for bit in bits:\n",
    "    patterns = ['.*runs_cifar10_full/bi4_.*nuq_bits_' + bit + ',.*,(?!(.*nuq_sym.*|.*nuq_inv))']\n",
    "    accuracies_bits.append(get_accuracies(patterns, lg_replace, lg_tags, logdir))\n",
    "bits = [ '7']\n",
    "for bit in bits:\n",
    "    patterns = ['.*runs_cifar10_full/bi2_.*nuq_bits_' + bit + ',.*,(?!(.*nuq_sym.*|.*nuq_inv))']\n",
    "    accuracies_bits.append(get_accuracies(patterns, lg_replace, lg_tags, logdir))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 132,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[{'Vacc': [[((0.10632088169144839, 85.79600219726562), ''),\n",
       "    ((0.08138866023678999, 66.96600036621093), ''),\n",
       "    ((0.08034862697354686, 84.48200073242188), ''),\n",
       "    ((0.13600120545236083, 76.11800079345703), ''),\n",
       "    ((0.10722044638959762, 77.9479995727539), ''),\n",
       "    ((0.053065083441254685, 85.47799835205078), ''),\n",
       "    ((0.05692055828613218, 80.52999877929688), '')]],\n",
       "  'Tacc': [[((0.07596954669406164, 90.3759994506836), ''),\n",
       "    ((0.15653832350482355, 67.07360076904297), ''),\n",
       "    ((0.10287506105733597, 88.3051986694336), ''),\n",
       "    ((0.08030335029686868, 77.07639770507812), ''),\n",
       "    ((0.13313531011085197, 79.61399841308594), ''),\n",
       "    ((0.090798501297686, 89.59879913330079), ''),\n",
       "    ((0.17358733407341706, 82.3740005493164), '')]]},\n",
       " {'Vacc': [[((0.03498411336119893, 87.22599945068359), ''),\n",
       "    ((0.041181091884333956, 87.37799987792968), ''),\n",
       "    ((0.06112470047422461, 87.98799896240234), ''),\n",
       "    ((0.04223647624745057, 85.25399932861328), ''),\n",
       "    ((0.06462100111635297, 87.94199981689454), ''),\n",
       "    ((0.025768135900539082, 85.68600006103516), ''),\n",
       "    ((0.061774379634692296, 77.18200073242187), '')]],\n",
       "  'Tacc': [[((0.07182751857887654, 93.34160003662109), ''),\n",
       "    ((0.05182102041553179, 93.09360046386719), ''),\n",
       "    ((0.054043357271797605, 95.22439880371094), ''),\n",
       "    ((0.06077750239641775, 89.85919952392578), ''),\n",
       "    ((0.09956310303078729, 95.0532012939453), ''),\n",
       "    ((0.0825318058748819, 89.88399963378906), ''),\n",
       "    ((0.11643560580634683, 77.61799926757813), '')]]},\n",
       " {'Vacc': [[((0.09264895236219425, 87.2959991455078), ''),\n",
       "    ((0.06079562613993292, 87.47800140380859), ''),\n",
       "    ((0.11429933781701761, 87.8540023803711), ''),\n",
       "    ((0.11620577432077768, 88.05599975585938), ''),\n",
       "    ((0.08187781931713173, 85.35399780273437), ''),\n",
       "    ((0.05161468951449811, 88.24400177001954), ''),\n",
       "    ((0.1292144365459936, 87.51199951171876), '')]],\n",
       "  'Tacc': [[((0.08683108625640408, 93.65040130615235), ''),\n",
       "    ((0.07775503347121644, 93.5448013305664), ''),\n",
       "    ((0.08442317555331438, 94.231201171875), ''),\n",
       "    ((0.04572061969037827, 94.94280090332032), ''),\n",
       "    ((0.06663808534373518, 89.22959899902344), ''),\n",
       "    ((0.030983000085775415, 95.1979995727539), ''),\n",
       "    ((0.12220996255774727, 94.12559814453125), '')]]},\n",
       " {'Vacc': [[((0.032248822890398765, 88.46000061035156), ''),\n",
       "    ((0.10256664661229374, 88.2), ''),\n",
       "    ((0.061774923053739945, 88.36199951171875), ''),\n",
       "    ((0.05036007801758256, 85.39800109863282), ''),\n",
       "    ((0.04915320293066975, 88.54199829101563), ''),\n",
       "    ((0.057758143806191, 88.26799926757812), ''),\n",
       "    ((0.05153508744581827, 88.37200012207032), '')]],\n",
       "  'Tacc': [[((0.054162884982922224, 95.59760131835938), ''),\n",
       "    ((0.05725173571475738, 95.54920043945313), ''),\n",
       "    ((0.047448599402754775, 95.0520004272461), ''),\n",
       "    ((0.05857674638077793, 89.64679870605468), ''),\n",
       "    ((0.028040589465714284, 95.739599609375), ''),\n",
       "    ((0.05382582739866478, 95.66719970703124), ''),\n",
       "    ((0.07248901725383472, 95.13799896240235), '')]]},\n",
       " {'Vacc': [[((0.03225118859370818, 88.18000030517578), ''),\n",
       "    ((0.05635499968353038, 88.53799896240234), ''),\n",
       "    ((0.05268829933344425, 88.1719985961914), ''),\n",
       "    ((0.05114786894460286, 88.1020004272461), ''),\n",
       "    ((0.1059437463711921, 85.99600067138672), ''),\n",
       "    ((0.05161486692936901, 88.23400115966797), ''),\n",
       "    ((0.03826189251159734, 88.14599914550782), '')]],\n",
       "  'Tacc': [[((0.06364105270633276, 95.86439971923828), ''),\n",
       "    ((0.05231631008125968, 95.60919952392578), ''),\n",
       "    ((0.06261769749801992, 95.80279998779297), ''),\n",
       "    ((0.05085621934797292, 95.6531997680664), ''),\n",
       "    ((0.11796341131616388, 90.29400024414062), ''),\n",
       "    ((0.0992350361488099, 95.46920013427734), ''),\n",
       "    ((0.03699536956386046, 95.70960083007813), '')]]},\n",
       " {'Vacc': [[((0.21404775212816393, 88.24799957275391), ''),\n",
       "    ((0.10457706865370339, 85.18800048828125), ''),\n",
       "    ((0.09308210135005857, 88.05599975585938), ''),\n",
       "    ((0.08863442079998118, 87.96199951171874), ''),\n",
       "    ((0.17783050011431822, 88.10399932861328), ''),\n",
       "    ((0.08868038369308691, 87.84400177001953), ''),\n",
       "    ((0.15019842834117855, 88.0000015258789), '')]],\n",
       "  'Tacc': [[((0.07652051693594358, 95.31679840087891), ''),\n",
       "    ((0.12723163907253404, 89.27560119628906), ''),\n",
       "    ((0.052200057478734116, 95.16199951171875), ''),\n",
       "    ((0.06119547529203798, 95.23480072021485), ''),\n",
       "    ((0.05441139805494258, 94.86759948730469), ''),\n",
       "    ((0.059693600031761995, 94.63400115966797), ''),\n",
       "    ((0.07454189065259462, 95.0260009765625), '')]]}]"
      ]
     },
     "execution_count": 132,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "accuracies_bits"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 124,
   "metadata": {},
   "outputs": [],
   "source": [
    "bits = ['2', '3', '4', '5', '6', '7']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 125,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "OrderedDict([('', [85.79600219726562, 66.96600036621093, 84.48200073242188, 76.11800079345703, 77.9479995727539, 85.47799835205078, 80.52999877929688, 87.22599945068359, 87.37799987792968, 87.98799896240234, 85.25399932861328, 87.94199981689454, 85.68600006103516, 77.18200073242187, 87.2959991455078, 87.47800140380859, 87.8540023803711, 88.05599975585938, 85.35399780273437, 88.24400177001954, 87.51199951171876, 88.46000061035156, 88.2, 88.36199951171875, 85.39800109863282, 88.54199829101563, 88.26799926757812, 88.37200012207032, 88.18000030517578, 88.53799896240234, 88.1719985961914, 88.1020004272461, 85.99600067138672, 88.23400115966797, 88.14599914550782, 88.24799957275391, 85.18800048828125, 88.05599975585938, 87.96199951171874, 88.10399932861328, 87.84400177001953, 88.0000015258789])])\n"
     ]
    },
    {
     "ename": "ValueError",
     "evalue": "'' is not in list",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mValueError\u001b[0m                                Traceback (most recent call last)",
      "\u001b[0;32m<ipython-input-125-9bfb27065854>\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m      1\u001b[0m \u001b[0mreformed_accuracies_bits\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mformat_accuracies\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0maccuracies_bits\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mtag\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      2\u001b[0m \u001b[0mbits\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mlist\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mmap\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mint\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mbits\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----> 3\u001b[0;31m \u001b[0mplot_accuracies\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mreformed_accuracies_bits\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mbits\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m'bits-t.pdf'\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m'# bits'\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mxscale\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;32mFalse\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mytitle\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mytitle\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m",
      "\u001b[0;32m<ipython-input-104-ed2910292338>\u001b[0m in \u001b[0;36mplot_accuracies\u001b[0;34m(accuracies, xaxis, filename, xtitle, ytitle, xscale)\u001b[0m\n\u001b[1;32m     42\u001b[0m     \u001b[0;32mfor\u001b[0m \u001b[0mmethod\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mvals\u001b[0m \u001b[0;32min\u001b[0m \u001b[0maccuracies\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mitems\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[1;32m     43\u001b[0m         \u001b[0mstyle\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mstyles\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---> 44\u001b[0;31m         \u001b[0mindex_2\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0morders\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mindex\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mmethod\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     45\u001b[0m         \u001b[0mcolor\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mcolors\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mindex_2\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;34m%\u001b[0m \u001b[0mlen\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mcolors\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     46\u001b[0m         \u001b[0mmarker\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mmarkers\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mindex_2\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;34m%\u001b[0m \u001b[0mlen\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mmarkers\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;31mValueError\u001b[0m: '' is not in list"
     ]
    }
   ],
   "source": [
    "reformed_accuracies_bits = format_accuracies(accuracies_bits, tag)\n",
    "bits = list(map(int, bits))\n",
    "plot_accuracies(reformed_accuracies_bits, bits, 'bits-t.pdf', '# bits', xscale=False, ytitle=ytitle)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "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.7.6"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
