{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 40,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "%matplotlib inline\n",
    "import matplotlib.pyplot as plt\n",
    "import matplotlib\n",
    "from pylab import rcParams\n",
    "import pandas as pd"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAiMAAAGSCAYAAAAxVMH8AAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADl0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uIDMuMC4wLCBodHRwOi8vbWF0cGxvdGxpYi5vcmcvqOYd8AAAIABJREFUeJzt3XmYHmWZ6P/vHSAskgSyQNjDQUAlXjgQj4wLwzIyZuCgBNkvDkHGqGcUHQf5DccfQlwYBFwQRyUSDbK4ssgiuIRF1J+OCQJhE1SCQgyEAEmQJCy5f39UdVJpOt39vnnfrrc738911dVVTz1Vdb9Vvdz91FNPRWYiSZJUl2F1ByBJkjZsJiOSJKlWJiOSJKlWJiOSJKlWJiOSJKlWG9cdgNSXuXPnvmbYsGFnZuZhmTmy7ngkdaaIWBoRN6xatepT++6774N1x6P+Cx/tVScrE5Ffjx8/fuTo0aNj+PDhRETdYUnqMJnJCy+8wOLFi3PhwoVLM3M/E5LBw9s06mjDhg07c/z48SO322672HTTTU1EJPUoIth0003ZfvvtY/z48SOXLFnylcMPP9y/cYOEF0odLTMPGz16tBmIpH4bM2ZMbLnllm8F3l13LOofkxF1tMwcOXz48LrDkDSIDB8+nI022mgT4J8OP/zwLeuOR30zGVHH89aMpEZ0+50xoaYw1ACTEUnSULZ53QGobyYjkiSpViYjkiSpVg56pkFtwn/cWHcIvZp/7qF1h9Cjs88+m+nTp69e7u94Q7fddhsHHnjg6uVbb72VAw44oNXh1ePsUXVH0Luzl9QdQY9mzZrFySefvHr5kUceYcKECX1uN3/+fHbdddfVy9/85jeZOnVqGyLUYGDLiDQIfeADHyAiVk/9+eXfbvPnz18rplmzZtUdkrp55plnuPTSSznllFPYZ5992H777Rk+fDgjR45k33335ROf+ARPP/103WECrPW9dPbZZ9cdjtrMlhFpkPnxj3/M1772tVqOvdtuu3H++eevtazBY/bs2T22Prz44ovceeed3HnnnVxyySXccsstvOY1r2lrLKNHj17re+mNb3xjW4+nzmYyIg0izz77LKecckptx99pp5047bTTaju+WmPUqFG84x3vYK+99mLJkiVceeWV/PWvfwXgr3/9K+973/u4/fbb2xrDyJEj/V7Sat6mkQaRD37wgzz++OOMGjWKgw46qGX7ffHFFzn33HPZc8892Wyzzdhxxx35yEc+wpIla/dTuO2229ZqPr/tttsAmDBhwlr3/wFOPvnkteqqfqNHj+aLX/wiCxYs4Dvf+Q5nnnkmF1xwAXfffTfbbLPN6np33HEHy5Yta+oYmcnFF1/M3nvvzeabb84222zDySefzIIFC9aqt67begcccMArvl+mT5++Vt358+c3FZs6l8mINEhcffXVXHHFFQBcdNFF7LTTTi3b95QpUzjjjDN46KGHWLlyJY8//jgXXngh+++/P88991zLjqN6HXTQQXz4wx9miy22WKt83LhxvO1tb1u93PXSuWaceuqpvP/97+eee+5hxYoVLFq0iFmzZrHffvvx+OOPr1f8Grq8TSMNAk8++STvf//7ATjyyCM58cQTmT17dsv2f+ONN3L88cez2267cf3113PXXXcBcM899/CJT3yCz3/+871u//GPf5z58+dzzjnnrC475phjmDRpUstiVPtkJg8+uOYFt7vtthtjxoxpal833HADhx12GPvssw+33nord9xxBwB/+ctf+NCHPsTVV1/d6/Yf+MAHOOyww/jYxz62uuztb387hxxyyOrl0aNHNxWbOpfJiDQITJs2jUWLFrHtttu2pfPq9OnTOfPMM4EisXj961/Pww8/DMAll1zCeeedx8Ybr/vXxXvf+95XJCPveMc7fFRzkPjkJz/Jfffdt9Zys97znvcwc+ZMAM466ywOPvjg1bfzrr32WhYuXMj48ePXuf0xxxwDsFYy8uY3v9n+JUOct2mkDnfppZfywx/+ECgSg7Fjx7b8GCeddNLq+U033ZRjjz129fKyZct46KGHWn5M1W/VqlV89KMfXevR2bPOOovjjz++6X1Wv5eGDRvGiSeeuHo5M7nzzjub3reGLltGpA62YsUKPvzhDwNwyimncNhhh7XlONtuu22vy88880xbjqv6LFu2jOOOO44bbywGDowIzjvvvPVugfB7Sc2wZUTqYCtWrFj9RMvMmTPXeqLg0ksvXV3v0UcfXa+nVp544olel7faaqum9qvO9Oijj/KWt7xldSKyxRZb8IMf/KAlt0L8XlIzTEYkrZXYrFy5ku985zurl0eMGMGee+7Z5z422WSTtZaff/751gWolvn1r3/Nm970JubNmwfAjjvu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\n",
      "text/plain": [
       "<Figure size 576x432 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "p = [2, 2.5, 3, 3.5, 4]\n",
    "acc2bit = [17.1, 34.35, 43.3, 45.57, 42.8]\n",
    "acc4bit = [74., 74.64, 74.87, 74.37, 73.84]\n",
    "\n",
    "rcParams['figure.figsize'] = 8, 6\n",
    "font = {'weight' : 'normal', 'size': 20, 'weight': 'bold'}\n",
    "matplotlib.rc('font', **font)\n",
    "\n",
    "N = len(p)\n",
    "ind = np.arange(N)    # the x locations for the groups\n",
    "width = 0.35       # the width of the bars: can also be len(x) sequence\n",
    "\n",
    "p1 = plt.bar(ind, acc4bit, width)\n",
    "p2 = plt.bar(ind, acc2bit, width)\n",
    "\n",
    "plt.ylabel('Accuracy', fontsize=25)\n",
    "plt.xticks(ind, ('p=2', 'p=2.5', 'p=3', 'p=3.5', 'p=4'))\n",
    "plt.legend(['4 bit', '2 bit'], loc='upper center', bbox_to_anchor=(0.5, 1.15),\n",
    "          ncol=2, fancybox=True, shadow=True)\n",
    "plt.tight_layout()\n",
    "plt.savefig('../fig/res50_p_vs_acc.png')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 156,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 576x432 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "df_2bit = pd.DataFrame()\n",
    "temp = df_res18[df_res18['p'].isin([2., 2.5, 3., 3.5, 4., 4.5])].reset_index()\n",
    "df_2bit['p'] = temp.p\n",
    "df_2bit['res18'] = temp.acc\n",
    "temp = df_res50[df_res50['p'].isin([2., 2.5, 3., 3.5, 4., 4.5])].reset_index()\n",
    "df_2bit['res50'] = temp.acc\n",
    "\n",
    "rcParams['figure.figsize'] = 8, 6\n",
    "font = {'weight' : 'normal', 'size': 20, 'weight': 'bold'}\n",
    "matplotlib.rc('font', **font)\n",
    "\n",
    "N = len(df_2bit)\n",
    "ind = np.arange(N)    # the x locations for the groups\n",
    "width = 0.35       # the width of the bars: can also be len(x) sequence\n",
    "p1 = plt.bar(ind, df_2bit.res18, width)\n",
    "p2 = plt.bar(ind+width, df_2bit.res50, width)\n",
    "plt.ylabel('Accuracy', fontsize=25)\n",
    "plt.legend(['Resnet18', 'Resnet50'], loc='upper center', bbox_to_anchor=(0.5, 1.15),\n",
    "          ncol=2, fancybox=True, shadow=True)\n",
    "\n",
    "plt.xticks(ind, ('p=2', 'p=2.5', 'p=3', 'p=3.5', 'p=4', 'p=4.5'));\n",
    "\n",
    "min_ = 2\n",
    "max_ = 4.5\n",
    "\n",
    "xp = np.linspace(min_, max_, 50)\n",
    "xp_tag = (xp - min_) * 5 / (max_ - min_)\n",
    "z = np.polyfit(df_2bit['p'], df_2bit['res18'], 2)\n",
    "y = np.poly1d(z)\n",
    "plt.plot(xp_tag, y(xp), '-', c='blue', linewidth=3)\n",
    "\n",
    "\n",
    "xp = np.linspace(min_, max_, 50)\n",
    "xp_tag = (xp - min_) * 5 / (max_ - min_) + width\n",
    "z = np.polyfit(df_2bit['p'], df_2bit['res50'], 2)\n",
    "y = np.poly1d(z)\n",
    "plt.plot(xp_tag, y(xp), '-', c='orange', linewidth=3)\n",
    "\n",
    "plt.tight_layout()\n",
    "plt.savefig('../fig/res50_res18_pnorms.png')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 139,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([0.        , 0.06122449, 0.12244898, 0.18367347, 0.24489796,\n",
       "       0.30612245, 0.36734694, 0.42857143, 0.48979592, 0.55102041,\n",
       "       0.6122449 , 0.67346939, 0.73469388, 0.79591837, 0.85714286,\n",
       "       0.91836735, 0.97959184, 1.04081633, 1.10204082, 1.16326531,\n",
       "       1.2244898 , 1.28571429, 1.34693878, 1.40816327, 1.46938776,\n",
       "       1.53061224, 1.59183673, 1.65306122, 1.71428571, 1.7755102 ,\n",
       "       1.83673469, 1.89795918, 1.95918367, 2.02040816, 2.08163265,\n",
       "       2.14285714, 2.20408163, 2.26530612, 2.32653061, 2.3877551 ,\n",
       "       2.44897959, 2.51020408, 2.57142857, 2.63265306, 2.69387755,\n",
       "       2.75510204, 2.81632653, 2.87755102, 2.93877551, 3.        ])"
      ]
     },
     "execution_count": 139,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "min_ = 2\n",
    "max_ = 4.5\n",
    "(xp - min_) "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 47,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Optimal predicted p = 3.20\n",
      "Maximum predicted acc = 48.33\n"
     ]
    },
    {
     "data": {
      "image/png": "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bcPDw82sWbN83o/ExESTlpa2T5tTTz11/740DvL998PMwoWY9eunOK2KAZaYFjxjHX/It/XWFkZl1661ZuHCMLNoUaSpqSlu9espLWfkyJGeh8ywYcPMvHnzzBtvvGH69evnKX/nnXeMMdaDKiEhwQAmLS3N3H///R6Zc845x3POb775xkyYMMFTd9ZZZ5nFixebxYsXmx9++MEYs7dRAczhhx9uXn/9dTN//nwzZ84cY4wxL774opkxY4aZN2+eWbRokfnwww/NAw884Glz5plneq5pf4gC5rDDDjNz5swxzz//vOnataun/PbbbzfGGLNz506Tnp7uKR85cqSZP3++eeihh0x0dLSn/K233vJcw59RefLJJ83s2bPNu+++axYtWmT+85//mJtuuskjO378eGOMMQUFBWbx4sV76em+L4sXLzY1NTXGGN9GZcmSJZ4yETG33nqree+998zYsWM95TExMaa4uNjn/ejXr5958803zVNPPWUiIyM95StXrgzad6kt2LLlI7NwIeazz9JNQ0ONo7q01KjoQH8rUFT0JFZKlkuIjs5yWp0DZtGi0PJaO+UUs1/ttm3bxjvvvANATEwMt9xyi2cIaMyYMdx1112ANVR1zjnnkJeXxxNPPMEVV1zB5s2buf322wHo3r07M2fO9Jx3yJAhrFixwnPcvXv3JucH4uPj+fjjj+nWrdte5WeccQZTp05l2rRpFBYWUl1dvVf9119/7fecb775Jv379wegvr6e8ePHAzBnzhymTp3KRx99xMaNGwHIzMzkjTfeICoqiuHDh1NWVsajj1peii+//DKjR49u4i7CsGHDmDp1Kp988gklJSXU1u6dp8qtZ25uLrm5uXvVtXTe5JVX9qQpGT16NA88YC23e9ZZZ7F06VK+/fZbampq+Oc//8n111+/T/vXX3+dI488EoD58+fzwQcfALBmzRoOPvjgFukQCqSknEZc3CB27lzOpk2vk5FxqdMqNYsalSBTV1dBWdnzAPTocZPD2ih21qxZQ2OjlfqipqaG0047zafcypUrPfuXX345c+fO9RgjgOnTp9O9e/f91uP444/fx6BUVVVxwgknsH79er/tKioqfJZ37drVY1AAjj32WM/+unXWErWrVq3ylA0ZMoSoqD0rjp5wwgkeo2KX80VRURHHHHMM27ZtC1jPQLDrcfzxx+9V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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "p = np.linspace(2, 4.5, 26)\n",
    "acc = [32.7, 35.5, 38, 40, 41.8, 43.7, 45.1, 46.25, 46.9, 47.6, 47.74, 48, 48.4, 48.17, 47.57, 47, 46.6, 45.7, 44.74, 43.6, 42.1, 40, 38.2, 36.2, 34.2, 31.9]\n",
    "df_res18 = pd.DataFrame()\n",
    "df_res18['p'] = p\n",
    "df_res18['acc'] = acc\n",
    "\n",
    "_=plt.scatter(p, acc, linewidth=4, c='r')\n",
    "plt.ylabel('Accuracy', size='xx-large')\n",
    "plt.xlabel('p', size='xx-large')\n",
    "plt.tick_params(axis='both', which='major', labelsize='xx-large')\n",
    "plt.tick_params(axis='both', which='minor', labelsize='xx-large')\n",
    "plt.title(\"Resnet18 2 bit\", size=20)\n",
    "\n",
    "z = np.polyfit(p, acc, 2)\n",
    "y = np.poly1d(z)\n",
    "\n",
    "xp = np.linspace(1.5, 5, 100)\n",
    "plt.plot(xp, y(xp), '-', c='y', linewidth=2)\n",
    "print(\"Optimal predicted p = {:.2f}\".format(xp[y(xp).argmax()]))\n",
    "print(\"Maximum predicted acc = {:.2f}\".format(y(xp).max()))\n",
    "\n",
    "_=plt.legend(['extrapolation', 'measured'], fontsize='xx-large', framealpha=0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 48,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Optimal predicted p = 3.52\n",
      "Maximum predicted acc = 46.27\n"
     ]
    },
    {
     "data": {
      "image/png": "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r87TTz/tO/b4448HYPbs2b6ycePG8dprr3H44YcTHh7O1VdfDcAzzzzDmDFj6NOnD7GxsYSGhpKWlsZZZ53FV199tcfvsH79et/5MjMzWbt2LWeeeSZxcXHExcVx3nnnkZOTs9fvvnz5ci6++GIyMjIIDQ0lPj6e4447jueff77Zn98DDzzAiSeeSEZGBlFRUYSFhdG7d2/Gjh3LihUrfPWmTJmyVzuJf/tJbTtNY20qb7/9Nr/97W9JTk4mNDSUlJQUzjrrLL788stGP49169Zx7rnnEhcXR3R0NKeffjq5ubnN/h3bo5CQRFJSnH9ntfMFtkuq2qVehx9+uLqhpqZav/pqoM6fj27e/KIrMRjV3Nxc7du3r+KsBbTXa/z48aqqWl1drcccc4yv/MUXnf9mv/71r31l//73v1VVtXfv3g2e77jjjlNV1VmzZvnK+vTpox6Px/f+4osvVlXV0047rcHzBAcH66effur7PdatW+fbFx8frykpKXsd07dvXy0qKvId8+6772pERESD17jsssv2+Kz8f69169b5yocNG9bgOWJiYvTnn39WVdXJkyc3WM//nP5l/u68884Gjw0KCtJZs2bV+3nExsZqcnLyXsf88pe/3Ld/NO1ISclKnT9f9OOPQ7W8fHObXhtYqM34jnX9S76tX24llfz8N3T+fPSLLzK0urrSlRiM6umnn+77khk9erTOmzdPX375ZR0wYICv/PXXX1dV54sqJiZGAU1OTtZ77rnHV+eUU07xnfPbb7/ViRMn+vadfPLJumDBAl2wYIEuWbJEVfdMKoAecsgh+tJLL+kbb7yhc+bMUVXVp59+Wp944gmdN2+efvzxx/ree+/pvffe6zvmpJNO8l3T/0sU0GHDhumcOXP0ySef1MTERF/5LbfcoqqqJSUl2qNHD1/56aefrm+88Ybed999GhYW5it/9dVXfddoKKk8/PDDOnv2bH3zzTf1448/1rfffltvuOEGX90rrrhCVVU3bNigCxYs2CPO2s9lwYIFWlZWpqr1J5WFCxf6ykREb775Zn3rrbf08ssv95WHh4drTk5OvZ/HgAED9JVXXtFHHnlEQ0JCfOXLly9vsX9Lblmy5DSdPx9du/a2Nr1uc5OKtam0kaws53Y1Pf1aPJ6O9bF//HH76up5/PH71qWysLCQ119/HYDw8HBuuukm3yOgsWPHcvvttwPOo6pTTjmFzMxMHnroIS699FLy8vK45RZnaYLu3bszc+ZM33mHDx/Ojz/+6HvfvXv3RtsJoqOj+eCDD0hKStqj/MQTT2TatGlMnz6drKwsSktL99j/zTffNHjOV155hQMOOACAqqoqrrjCWY9jzpw5TJs2jffff58tW7YAkJqayssvv0xoaChjxoxh8+bNPPCA08392Wef5cwzz2zkU4TRo0czbdo0PvnkE3JzcykvL683zoyMDDIyMvbY19z2k+eee863feaZZ3Lvvc4qiCeffDKLFi3iu+++o6ysjP/85z9cd911ex3/0ksvcdhhhwHwxhtv8O677wKwatUqBg8e3KwY2qtevW5g27bXyMl5nIyMWwgKinA7pD10rG+3Dqq4eAlFRR/i8UTZlCwuWrVqFTU1NQCUlZVxwgkn1Ftv+fLlvu1LLrmEuXPn+pIRwIwZM+jefd/HF40cOXKvhFJcXMyoUaNYt25dg8cVFRXVW56YmOhLKAAjRozwba9duxaAn3/+2Vc2fPhwQkNDfe9HjRrlSyr+9eqTnZ3NkUceSWFhYcBxBsI/jpEjR+6xb9SoUXz33Xd71asVGxvrSygA3bp18203FndHERd3DDExw9m5cyFbtjzjW9CrvbCk0gaysx8EIDX1UkJC4l2OJnD7emfQURUXF/u2y8vLWbNmzR77lyxZwmmnnbbP509JSdmrbO7cub6EkpKSwrRp0+jXrx+q6mvsd55AuGv27Nm+L+aBAwcyZcoUevbsSU5ODhdccAGAL3G7JSEhYY/3wcG7v+baw2e4v0SE9PQbWLHi92RnP0Rq6vh2NXDUen+1soqKrWzZ8jwg9Ox5rdvhdGn9+/fH43H+ycfGxlJcXFzvM2H/v35vueUWli1bBuz+crrrrrtYtGjRHueuPS80/aVa3xdAdvbulbgvvPBCLrnkEo499tg9vhAbUlBQwKpVu1cH/Prrr33bffv2BZwEUGvRokVUVu6eQ+qLL77wbfvXq49/nBMmTOD888/nmGOOobq6usFj/H/f5iYc/zjq9vTyf99UvJ1VcvLZhIamsWvXCgoL33c7nD1YUmllubn/RLXCO9ixv9vhdGmJiYmMGTMGgB07dvCb3/yGF198kQ8//JBnn32WiRMnMmTIEF555RUA5s+fz4MPOneZQ4YMYe7cuYgIlZWVjB07do82D/+/jhcsWMBbb73FZ599RlZWVrNiy8zM9G3/97//Zc6cObzwwgtceOGFzTr+vPPOY+7cucyaNYuJEyf6ys844wzAaa/p0aMHALm5uZx//vm89dZb3H///Tz66KO++mPHjm12nE8++SRvvvkmTzzxRL3tGrX8P5sHH3yQBQsW7JWU67rooot823PmzOHWW2/lnXfe4corr2ThwoUAhIWFcc455zR6ns7K4wmhZ88JwO4nIe1Gc1rzO9OrLXt/VVWV6mefddf589GCgvltdl3TsKysLM3MzGy0q+usWbO0qKhIe/Xq5eu++s0336iq6p/+9CdfvWuvvdZ33vz8fA0PD9/rXHfddZeq7tn7q7YLsb+dO3f6ruf/OvbYY+vtHeXf2ykxMbHeYzMzM7WwsNB3zDvvvFNvjLWvSy+9dI+Y6uv9lZWVpdHR0Y3G2bt37z3Oc8455+xVv1+/fr799f1+qqp33HFHg7F6PJ4GuxTXvf7FF1+8x3/bzqKiIl8/+SRc589Hi4tXtPr1aGbvL7tTaUV5eS9TWbmVqKhhxMcf53Y4BkhPT+f777/ntttu4+CDDyYyMpLIyEj69evHqaeeylNPPcUZZ5zBhAkTfHcZN954I0cccQQA06dPp0+fPgA88sgjfPDBBwAkJSXxyiuvMGzYMEJCAl9wLTo6mg8//JDRo0cTGxtLt27dGD9+PPPmzWvy2JiYGD777DPOPvtsYmNjiYmJ4eyzz+bTTz8lPn53G95JJ53EwoULGTt2LD179iQ4OJjY2FiOPfZYnn32WZ588slmfX4fffQRRx99NFFRUaSmpnLzzTfzxBMNr/Xx8MMPc8YZZxAXF9e8D8Pr9ttv580332T06NEkJSURHBxM9+7dOeOMM1iwYAHjxo0L6HydTUhIEj16OHeWOTmPuBzNbqKdoOEqEMOHD9fa2+fWpKosWnQ4xcXfM3DgLFJTx7X6NU3XsX79el9y6927d6vOImzar5KSZXz77UF4PJEcdVQ2ISEJTR+0j0RkkaoOb6qe3am0ku3bP6e4+HtCQrrRvfv5bodjjOmEoqKGkJDwa2pqdrFp08ymD2gDllRaSU7OwwCkpl5BUFC4y9EYYzqr9PQ/A5CT8xiqDffCayuWVFpBWVkWeXlzgCB69rzS7XCMMZ1YYuLJhIf3o7x8A/n5TbfBtTZLKq0gN/efQDXJyWcTFtbT7XBMJ5SZmenrbWPtKV2biMfXvbg9NNhbUmlhzpopMwBIT2+4774xxrSU1NRL8HiiKCr6iOLiH5s+oBVZUmlhW7e+SFXVNmJihhMbO6LpA4wxZj8FB8eRkvIHAHJyHm2iduuypNKCVNV3+9mz54R2NR+PMaZzq30E5iwG6N7EmZZUWtCOHV9SXLyYkJBuJCef53Y4xpguJCrqQF/34s2bn3ItDksqLaj2tjM19XLrRmyMaXM9e14DuNu92JJKCykv30Re3n8AD2lpf3I7HGNMF5SUNIawsN6Ula2joOAdV2JwNamIyKEiMk1EFojIRhEpF5EiEflERH7fwDEXicjnIrJDREpE5DsRmSAiQW0dv79Nm55AtYpu3U4jPDyj6QOMMaaFieweG5eT87grMbh9p3IFcAtwNNALCAXigGOB50Vkun9lEXkYeBYYCcQAkcChwCPAK+JSy3hNTSW5uf8CdjeWGWOMG1JSLkMkjIKCtyktXdvm13c7qQBsBe4FfgucDXzrt+8vItIHQEROAq7xlpcA44ELgS3esjOBS9si4Lry8/9HRcUmIiMHEx//SzdCMKbdOP744xERRISPP/7Y7XC6nNDQbnTvfh6g3oHYbcvtpPI80EdVb1HVt1X1VZzkUtvCJMAR3u2r/Y6bqqpPqOoLwF/8yq/BBbW3mWlpV1k3YmOM63r2dL4uN216iurq0iZqtyxXk4qqLlDVXXXK8oECv6IS789j/Mq+8Nv+3G97qIgEtmjDfiopWc727Z/g8UT5Bh8ZY4ybYmN/QUzMcKqqCti69aU2vbbbdyp7EZFjgGTv253ApyKSAMT7Vdvit73Z/3CgTz3nHC8iC0VkYV5eXovGW3t72aPHRQQHx7bouY1pCyUlJU1XMh1OWppzt5KT81ibXrddJRUR6Q+84Fd0varuBKLqVK1oYBsguu55VXWGqg5X1eHJycl1d++zqqpiNm9+GsBmI25Mfj7MnAl33eX8zM93JYxx48b5nvU/9dRT3HPPPWRkZBAVFcWJJ57IypUrqamp8ZWHh4dz5JFH8sUXX+xxnqKiIiZNmsRBBx1EZGQk0dHRHHnkkcyePXuvaz7zzDOMGTOGPn36EBsbS2hoKGlpaZx11ll89dVXe9WfOXMmI0aMIDY2lpCQEFJSUhg5ciQ33HADxcXFvnq1v0fdx61TpkzxlU+ZMqXB8pkzZzJkyBBCQ0OZPn13f5iFCxdy/vnnk5aWRmhoKD169ODcc89l6dKle8W6fft2rrzySpKTk4mOjuakk07ixx/dnXfK7Na9+/kEBydSXLyIHTu+bfqAltKcNYfb4gUMw7nrqF1PepLfvgT2XKN6kN++iDr7DmnsOi25Rn1Ozr91/nx00aJRLXbOTqWmRnXqVNWwMFXY/QoLc8prato0HP+1yvv377/Xuue9evXS8ePH71WekJCgRUVFqqqam5urffv2bXDt9PHjx+9xzdNOO63BusHBwfrpp5/66s6YMaPBuoBmZWX56vqX+5s8ebKvfPLkyfWW9+vXb4/ja+s999xzGhwcXO+1IyIi9MMPP/Sdr6qqSkeOHLlXvbi4OM3MzPS9nz9/fgv91zP7YtWqv+j8+eiKFZfu97noSGvUex95fQL0wPnHeL2qTvWrUgRs93vfw287pZxTlEYAAA3qSURBVM7p1rdGjHWpqq+B3u5SGjBtGkyaBOXle5aXlzvl06a5Exewdu1apk6dyty5c0lNTQUgKyuLGTNmcP311/PGG28wYMAAAAoLC3nhBecG+qqrrmLtWqeb5ujRo5k3bx4vv/yyr+6MGTP2WFf+zDPP5IknnmDevHl8/PHHvPfee9x7770AVFVVcffdd/vqzp07F4Dg4GAef/xxPvroI1566SVuv/12hg0b1mKdQNasWcMJJ5zAnDlz+N///sfRRx/Npk2buPzyy6mqqiI4OJg777yT999/n2nTphEUFERpaSljx46lrKwMgKefftp3BxceHs7999/PvHnzGD58uE3F346kpV0BOBPdttl8YM3JPK35AsYAu3CSSQVwYQP1Xmf3X0QT/crH+pUvbup6LXWnUlT0hc6fj372WTetri5rkXN2Knl5e9+h1H2FhTn12oj/ncr555/vK7/qqqt85SNGjPCVT58+3Vd+/fXXa0FBgXo8HgU0PDxcP/zwQ12wYIEuWLBA77zzTl/dM88803eO3NxcnTBhgh5wwAEaERFR711QrQsuuMB3V/Dee+9pQUFBg7+L/zn8NedOJSMjQysqKvY47qGHHvLtHzNmjO/3WrBggY4YMcK37/XXX1dV1TFjxvjKbrrpJt95CgoKNDIy0u5U2pHFi3+t8+ejWVkP7td5aOadSnBrJKrmEpGzgJfAF8d0YIOIHO1XbaOqbgQeA07xlk0UkTycnmF/96vbZivU1DbQp6RchscT1laX7Tjmzt37DqWu8nJ47TW47LK2icnPiBG7lyVISkqqt7xbt26+7cLCQlatWkVNTQ0AZWVlnHDCCfWee/ny5QAUFxczatQo1q1b12AcRUVFvu3LLruMl156idLS/2/v7mOrqu84jr+/hQKtlIeCPLSw4YA0mgGBgQMzEUOsbDyHgSCb5UEgIGsCCwNrOh9gzmT7g/AHYYZV3NziiEAbQxhjwMANi6KoLAgZbhSlIDZKoJYq1N/+OLeXS2l7e+m599xyP6/khtPfPff+vpfT2+/5PZzfuUJ+fj4AvXv3ZvTo0SxYsIApU6bE8hGbNGHCBNLT028oO3HiRHh7586d7Ny5s9HXHj9+nMmTJ/PRRx+Fy8aMGRPe7t69O3l5eRw9etSXWKX1cnKW8sUXf6eychO5uYVxv+wh6O6vyXBDYisC3mjwWADgnNvN9aRxB/Ai3nUuvUJl24GELM159ernXLiwFTBychYnosq259y5lu1XWRnfOJrQtev1medpaWmNlkfyTtRapn5AvbS0NJxQ+vTpQ0lJCQcOHLjhgsDI9x0/fjzl5eUsXbqUUaNGkZWVxaeffkpZWRlTp05l27ZtjdZ37dq18HZVCyZB9OnTsMe45SInC0jb0KPHZDp0yKGm5gQXL/4j7vUFnVRi4pwrxOvuehOoBq4AR4FCYJaL5ZvfCufPv4xzX9G9ez4ZGd9JRJVtT2icIqqcnPjG4aNBgwaFE1CXLl2orq5utPl/8uRJAD755JPwa+fOncv8+fMZO3Ys7ds33kHgnOPee+9l48aNvPXWW1y6dImtW7eGn4/c7tbt+gz7s2fPAlBXV8fu3bujfo7GzlTz8vLC2wsXLmz0c1VXV7N27VoABg4cGN4/chbbxYsXw59fkkNaWjp9+z4OEF5OKp4C7f5yzs0D5sX4mleAV+IRTwvrp7LydwBajbg506bB8uXNd4F17AhTpyYuplbKzs5m4sSJvP7661y6dIn8/HyWL19Or169qKys5MMPP6SsrIxVq1Yxb948BgwYEH7ta6+9xn333UdtbS1FRUWNvn9hYSFnz57loYceon///nTq1Ik9e/aEn68fJAcYPHgwb7/tTRN97LHHmD17Ntu3b+fUqVO39NlmzpzJmjVrqK2tpaSkhKysLPLz83HOUVFRweHDhyktLQ13102fPj3cRbZhwwb69OnD4MGD2bBhAzU1Nc1VJQHo23cRFRW/oqqqlKtXvyA9vXvc6go0qbRFFy8e4MqVk3TokEOPHpOCDid59ewJxcXeLK+mFBd7+7UhGzdu5NixY5w+fZpDhw7ddA1LpEmTJtG/f38+/vhjKioqmDFjBgBjx46loqLipv2vXLnCjh072LFjR6PvN3fu3PD2smXLmD9/PgAHDx7k4MGDANxzzz3hMZ1Y5OTksGnTJhYuXEhdXR3r169n/fr1Te5fUFDA5s2bKS8vp7a2lpUrVwKQmZlJbm5uuPUkyaFTp37k5W2mW7f745pQoI11fyWDc+e8Vkrfvo+Tlqac3KyiIli3zmuRROrY0Stv4ow9mfXr14+jR49SXFzMkCFDyMzMJDMzk4EDBzJlyhRKSkqYPn06AJ07d2bv3r1MmDCBLl260LNnTxYvXnzDlONI9V1kd999N926daNdu3ZkZ2fz4IMPsn37dmbNmhXet6CggOeee46cnBw6duzIiBEjKCsrY+bMmbf82QoKCigvL2fOnDnk5uaSnp5OdnY2Q4cO5YknnmDfvn3hfdu3b8+uXbtYtGgR2dnZZGRk8MADD7B//34GDRp0yzFI/PTtO4+MjIHRd2wlS9AwRNIYOXKkO3LkyC299uuvL/Dmm/1wro7Ro0/TqVN/n6O7TVVVebO8Kiu9MZSpU9tcC0Uk1ZnZO865kdH206l2DM6f34JzV+nRY7ISSix69gxk2rCIJJ66v2JQV/claWkZGqAXEWmCWioxuOuuZ+nXbwXt22cFHYqISFJSUmmpqiooLSX93DnvGoxp0zQuICLSgJJKNM55Cx+uXXvjNRfLl3tTYouKQHd7FBEBlFSiq19pt6H6lXYBnnoqsTGJiCQpDdQ3p6rKa6E0Z+3awG46JSKSbJRUmhPLSrsiIqKk0qwkX2lXRCTZKKk05zZcaVdEJJ6UVJozbdrN61Y11MZW2hURiScllebUr7TbnDa40q6ISLwoqURzG660KyISL7pOJRoz7zqUJUu00q6ISBRKKi2llXZFRKJS95eIiPhGSUVERHyjpCIiIr5JudsJm9lnQEUr3qInoMW+ko+OS/LRMUk+rTkm33bO3Rltp5RLKq1lZkdacp9mSSwdl+SjY5J8EnFM1P0lIiK+UVIRERHfKKnE7sWgA5BG6bgkHx2T5BP3Y6IxFRER8Y1aKiIi4hslFRER8Y2SioiI+EZJJQozG25mz5vZG2Z2xsy+MrOLZnbAzB4NOr5UZGYDzOz3ZvaBmVWZ2TUzu2Rm75rZM2bWJegYBcys2MxcxOOZoGNKJaHviWvmURuPerVKcXRLQo9IHYCxwFgzG+6cW5X4sFLaIGBBg7IsYHjoMcXMvu+cu5rwyAQAMxsCRLnDndyOlFRa5gJQAhwEMoHVwKjQcz83s43Ouf8FFVwKugz8EdgPnAXSgdnAT0LPDwfGAXuCCC7VmVl7YAvecakFOgUakAC8hPc3LNI38ahISSW6PwErnXM19QVmdgA4D7QDDC/BKKkkiHPuMHC4QfFOM5sMdA39rC6w4KwBRgDvAccBdRMH74xz7p+JqEhjKlE4596ITCihsirg84iiLxMblUQys+5mtoTrCaUWOBRgSCkrotvrKjAv9K8Eb5mZXTazGjM7Zma/NLOMeFSklsotMLP7gfrVOi/jdYtJgpnZq8AjDYpPAoXOuXMBhJTSQt1eL+GNOT7tnHvfzAKOSkIiVxf+bugxyczGNTxpbi21VGJkZoOAP0cUrXDOXQ4qHrnJV+j3Oiirge8BR4HnA45FwAHvAE8C04BJ3LhMyyig0O9KtUxLDMxsGLAb6B0qKnbOrQswpJRmZnlAL7yzsJl4g/UAdcBw59yxoGJLNWaWC/wXb4xxpHPug1D5FqAgtNuzzrlnAglQwszsFWBu6Md/Oed+4Of764yuhUJdXgfwEorDa6EooQTIOXcyNOa13Tk3B6gfiGwHzAkwtFR0J163Vzrwfv21EFxPKABPh8rHBRGghJVHbPfy+82VVFrAzCbitVC64g08/tQ5tz7YqFJXMwOMkc3ubomIRSRZmdmI0DhXQ2Mits/7Xa8G6qMwsxnAq1z/v/oNUGFmkU3GM865MwkPLnXtN7PTwD68qdx3AD8G7o/Y50gAcaWys8CKRsof5fo1XbuBvwKnEhVUiisExpnZH/BaJwZM4cYp3tv8rlRjKlE06BNuivqKE8jM3gOGNbPLPuBh59y1BIUkTdCYSnBa8Lfrb8Akv1eeUEtF2qINeLNZhuL15afjXTf0AfAX4GUlFBFeAE4DDwPfwvuu1AD/xluRYrNzrs7vStVSERER32igXkREfKOkIiIivlFSERER3yipiIiIb5RURETEN0oqIiLiGyUVERHxjZKKiIj4RklFRER8o6QiIiK+UVIRERHfKKmIBMjM5oVuXPVDM3vBzCrN7IqZHTSzEUHHJxIrrVIskhx+jXe/i98CXYDlePeNGemc+0+gkYnEQElFJDlkAcOcc9UAZrYDeBdYBzwSZGAisVD3l0hy2FyfUACcc+8De4EfmZm+p9Jm6JdVJDmcbKKsM97NlUTaBCUVERHxjZKKSHLIa6KsGvgswbGI3DIlFZHk8LiZ3VH/g5kNA8YDu5xz3wQXlkhsNPtLJDlcBg6Z2Ra8KcU/A2qA4iCDEomVkopIcngSGAf8AugOvA2scM41NoAvkrSUVESSw1Xn3GpgddCBiLSGxlRERMQ3SioiIuIbJRUREfGNOeeCjkFERG4TaqmIiIhvlFRERMQ3SioiIuIbJRUREfGNkoqIiPjm/923KGJdBtVFAAAAAElFTkSuQmCC\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "p = np.concatenate([[2], np.linspace(2.5, 3.5, 11), [4, 4.5]])\n",
    "acc = np.array([17.1] + [34.35, 36.6, 38.8, 40.3, 42, 43.3, 44.1, 45, 45.4, 45.57, 45.57] + [42.8, 34.8])\n",
    "df_res50 = pd.DataFrame()\n",
    "df_res50['p'] = p\n",
    "df_res50['acc'] = acc\n",
    "\n",
    "_=plt.scatter(p, acc, linewidth=4, c='r')\n",
    "plt.ylabel('Accuracy', size='xx-large')\n",
    "plt.xlabel('p', size='xx-large')\n",
    "plt.tick_params(axis='both', which='major', labelsize='xx-large')\n",
    "plt.tick_params(axis='both', which='minor', labelsize='xx-large')\n",
    "plt.title(\"Resnet50 2 bit\", size=20)\n",
    "\n",
    "z = np.polyfit(p, acc, 2)\n",
    "y = np.poly1d(z)\n",
    "\n",
    "xp = np.linspace(2, 5, 100)\n",
    "plt.plot(xp, y(xp), '-', c='y', linewidth=2)\n",
    "print(\"Optimal predicted p = {:.2f}\".format(xp[y(xp).argmax()]))\n",
    "print(\"Maximum predicted acc = {:.2f}\".format(y(xp).max()))\n",
    "\n",
    "_=plt.legend(['extrapolation', 'measured'], fontsize='xx-large', framealpha=0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Optimal measured p = 3.00\n",
      "Maximum measured acc = 74.87\n"
     ]
    },
    {
     "data": {
      "image/png": "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Hb2NrdUXGFSbSWm7GTiDYJTzRjP7csr5J909XTVHu+Pua0nzA29mB4b/fMrdFxY3qvh4CxeW60D+DzgBeNLMbgfeImiAv4BgrMntMcbWqsxsPEF1b6LK90gzuzr892PuPseLsMCg1jMpYWb2NNnreo/piO0nyczseuA6YHhHSiYJZnYeQa+tfQimVfkrwcJyqYP32j0zO4BgapExwECCLq9TgWvac4cVM1sCDMlw+nx3nxyW6wxcRTAl00CCBQYnAbcVopu9komIiESmNhMREYlMyURERCJTMhERkciUTEREJDIlExERiUzJREREIlMyERGRyJRMREQkMiUTERGJTMlEREQiUzIREZHIlExEYmBm55mZm9kJZvYjM3vPzDaa2bNmdnDc8YnkSlPQi8Trh4ARTCXfExhPMKV8jbsviDUykRwomYjEqwfwEXevAzCzR4CXgZsI1rIRaRNUzSUSr18nEgmAu/8XmAZ8OlxpU6RN0A+rSLzmZzjWHdilyLGI5E3JREREIlMyEYnXPhmO1QGrihyLSN6UTETi9TUzq0p8YWYfAY4FnnD3pvjCEsmNenOJxGs98LyZTSboGvwtYANwTZxBieRKyUQkXlcCRwPfBfoALwGXunu6hnmRkqVkIhKvLe5+OXB53IGIRKE2ExERiUzJREREIlMyERGRyMzd445BRETaOL2ZiIhIZEomIiISmZKJiIhEpmQiIiKRKZmIiEhk/x+9x0VOhnrr/gAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<matplotlib.figure.Figure at 0x7fda1cdebba8>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "p = np.concatenate([[1, 1.5, 2], np.linspace(2.5, 4, 4), [4.5, 5, 5.5, 6, 6.5, 7, 10]])\n",
    "acc = np.array([60.54, 71.3, 74.1]+ [74.64, 74.87, 74.37, 73.84] + [73, 72.3, 70.7, 70.4, 69.5, 68.7, 66.7])\n",
    "\n",
    "_=plt.scatter(p, acc, linewidth=4)\n",
    "plt.ylabel('Accuracy', size='xx-large')\n",
    "plt.xlabel('p', size='xx-large')\n",
    "plt.tick_params(axis='both', which='major', labelsize='xx-large')\n",
    "plt.tick_params(axis='both', which='minor', labelsize='xx-large')\n",
    "plt.title(\"Resnet50 4 bit\", size=20)\n",
    "\n",
    "opt_p = p[acc.argmax()]\n",
    "opt_p_idx = acc.argmax()\n",
    "\n",
    "z = np.polyfit(p[opt_p_idx-3:opt_p_idx+2], acc[opt_p_idx-3:opt_p_idx+2], 2)\n",
    "y = np.poly1d(z)\n",
    "\n",
    "xp = np.linspace(1.5, 4, 100)\n",
    "plt.plot(xp, y(xp), '-', c='y', linewidth=2)\n",
    "print(\"Optimal measured p = {:.2f}\".format(opt_p))\n",
    "print(\"Maximum measured acc = {:.2f}\".format(acc.max()))\n",
    "\n",
    "# _=plt.legend(['extrapolation', 'measured'], fontsize='xx-large', framealpha=0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Optimal predicted p = 3.16\n",
      "Maximum predicted acc = 71.03\n"
     ]
    },
    {
     "data": {
      "image/png": "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+axcuZIvv/ySyy67jPj4eNLT03nzzTe55JJL+OKLLzj//PMBeOqpp7jnnns4fPgwTz75ZJ0/9zVr1jBx4kROOukkvv76a2bNmsWaNWtYuHBhlX0uueQSunfvzsMPP8ymTZt49tln8fPz44033qjmDI1EVdvE45RTTtHmorg4X5cv765Ll6IpKa94OhxjqvXII4+or6+vrly5skL5woULFdA5c+aUlRUWFuqpp56qUVFRunfvXn3wwQcV0HfeeafCvvfff78CumPHjirnO/vssxXQ2bNnV9l25MiRKmUHDx7U6Ohovf766yuUx8XFKaDPP/98hfLf//73Cuj69evLYo6JidHY2FhNS0srq7dr1y4NCQnR8t8ZO3bsUEDnzp1ba0y5ubnat29fHTFiRIXyYcOGaVxcXJX6qqqAzpgxo+z1c889p4A+/vjjFerdcccdCujChQvLysaPH6+A3n777RXq3n777ert7a0ZGRnVntMdwCqtw3esXZl4wN69r7iWTelLx47jPR2OaUDLljW/OULnnHN8LcHz589nyJAhxMfHk5qaWlZ++umnExwczOLFi5k0aRIAPj4+vPnmm5x00klceuml/O9//2PcuHFcccUVbp/3pptuqlIWFBRU9uecnBxyc515yqeddhorV66sUj80NLRKs9vkyZN5//33+eijj+jfvz+rVq1i7969zJo1q8JggNjYWMaOHctLL71ESkoKnTtXmeJWJaa8vDyOHDmCqnLOOefw7rvvuvemy/nwww8JDg7m5ptvrlB+991389RTT/Hhhx8ycuTICtsqf2Znn302//jHP0hOTmbQoEE0BUsmTay4+AhJSc7tVxISHrJlU0yztWnTJnJzc6lpKaIDBw5UeN27d28SExOZPHkyXbp04dlnn3X7nJGRkdWO8srMzGTq1Kn861//Yt++fRW2JSQkVKkfHx+Pn59fhbI+ffoAsGPHDsCZOwIVm9lKlTab7dixo8ZkUlBQQGJiIq+//jrJyckVttVn4nFSUhIJCQlVOuZjYmIIDw8vi7+8uLiKt6qIiHDmezdlv4l9kzWx3bv/QWHhfkJDTyMqqtWsnG9cjvcqoDlSVc444wwefLD6e89V/tJX1bLO50OHDrFnzx7CwsLcOmdgYLXL7DFmzBiWLFnCX/7yF04++WTCwsLw8vLi4YcfZtu2bW6do6Hccccd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\n",
      "text/plain": [
       "<matplotlib.figure.Figure at 0x7fda1ce73320>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "p = np.concatenate([np.linspace(1.5, 4, 11)])\n",
    "acc = [56.2, 62.5, 66.4, 68.57, 69.9, 70.7, 70.8, 70.67, 70.6, 69.9, 68.8]\n",
    "\n",
    "_=plt.scatter(p, acc, linewidth=4, c='r')\n",
    "plt.ylabel('Accuracy', size='xx-large')\n",
    "plt.xlabel('p', size='xx-large')\n",
    "plt.tick_params(axis='both', which='major', labelsize='xx-large')\n",
    "plt.tick_params(axis='both', which='minor', labelsize='xx-large')\n",
    "plt.title(\"Resnet50 3 bit\", size=20)\n",
    "\n",
    "z = np.polyfit(p[2:], acc[2:], 2)\n",
    "y = np.poly1d(z)\n",
    "\n",
    "xp = np.linspace(1, 4.5, 100)\n",
    "plt.plot(xp, y(xp), '-', c='y', linewidth=2)\n",
    "print(\"Optimal predicted p = {:.2f}\".format(xp[y(xp).argmax()]))\n",
    "print(\"Maximum predicted acc = {:.2f}\".format(y(xp).max()))\n",
    "\n",
    "_=plt.legend(['extrapolation', 'measured'], fontsize='xx-large', framealpha=0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([1.  , 1.25, 1.5 , 1.75, 2.  , 2.25, 2.5 , 2.75, 3.  , 3.25, 3.5 ,\n",
       "       3.75, 4.  ])"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.linspace(1, 4, 13)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Optimal predicted p = 1.83\n",
      "Maximum predicted acc = 63.62\n"
     ]
    },
    {
     "data": {
      "image/png": "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hQsXcv/995ORkeF1KFXq1Vdf5amnnvI6jEplycQYU2UWLlzIAw88YMmkkMzMTMaNG1fFEYWeJRNjTLV15MgRr0OodNHR0URE1Ij7x0tlycQYU6IjR44wduxYOnbsSGRkJAkJCYwaNYp9+/YV1FmyZAkRERGMGDGiyHM3bdpEo0aN6NevH6rK8OHDmTJlCgDt27dHRBARFi9eDECfPn1ITEwkNTWVSy65hMaNGzNgwAAAfvrpJ0aMGEHnzp1p0KABsbGxXHTRRSxduhRfSUlJnHvuuSxdupTevXvToEEDWrduzfjx48nJKb5A7Pz58+nduzcNGzakcePGJR7X19atW7n55pvp3r07MTExxMTE8Nvf/pb58+cXi+err75i69atBX9z4UUA/fWZZGRkcMstt5CYmEhUVBQdO3ZkwoQJZGcXXdZp+PDhiAi7du3iz3/+M7GxsTRq1IirrrqqyHtUFWp+OjTGVIrs7GwuuOACVq1axciRI+natSvr1q1j2rRpLFmyhKVLlxIdHc3ZZ5/NmDFjmDx5MpdeeimDBg0iNzeXoUOHUq9ePWbOnImIcP3115ORkcHcuXN58skniYuLA6Br164F5zx69Cj9+vWjf//+PPbYY4SFOd93P/74Y3766SeGDBlCYmIiu3bt4pVXXqFPnz6sWLGCbt26FYk9LS2Niy++mCFDhjBkyBDmz5/P5MmTSU9PZ/r06QX13nnnHQYPHkyXLl24//77OXbsGM8//zznnXceCxYsoHfv3iW+PsuWLeOzzz5j0KBBJCUlkZGRweuvv86AAQP49NNPueCCCwB46qmnuOeee9i3bx9PPvlkuV/3lStXMmLECHr27Mnnn3/OpEmTWLlyJfPmzSv2nAEDBtChQwcefvhhUlNTmTp1KpGRkcyaNavM84WMqtaJR69evdQYU36PPPKI1qtXT5ctW1akfN68eQro9OnTC8qOHz+uZ5xxhsbFxemOHTv0wQcfVEDfeuutIs+97777FNDNmzcXO995552ngE6ZMqXYviNHjhQr27Nnj8bHx+t1111XpLxdu3YK6HPPPVek/I9//KMCumrVqoKYExISNDExUffv319Q7+eff9aYmBgt/JmxefNmBXTGjBmlxpSZmaknnXSS9u/fv0h57969tV27dsXqq6oCOnHixILfp02bpoA+9thjRerddtttCui8efMK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\n",
      "text/plain": [
       "<matplotlib.figure.Figure at 0x7fda1ce2ccc0>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "p = np.linspace(1, 4, 13)\n",
    "acc = np.array([29, 57.1, 62, 63.5, 62.66, 60.7, 61, 60.5, 56.95, 49.77, 46.8, 45, 44])\n",
    "\n",
    "_=plt.scatter(p, acc, linewidth=4, c='r')\n",
    "plt.ylabel('Accuracy', size='xx-large')\n",
    "plt.xlabel('p', size='xx-large')\n",
    "plt.tick_params(axis='both', which='major', labelsize='xx-large')\n",
    "plt.tick_params(axis='both', which='minor', labelsize='xx-large')\n",
    "plt.title(\"mobilenetV2 4 bit\", size=20)\n",
    "\n",
    "z = np.polyfit(p[1:6], acc[1:6], 2)\n",
    "y = np.poly1d(z)\n",
    "\n",
    "xp = np.linspace(1, 2.5, 100)\n",
    "plt.plot(xp, y(xp), '-', c='y', linewidth=2)\n",
    "print(\"Optimal predicted p = {:.2f}\".format(xp[y(xp).argmax()]))\n",
    "print(\"Maximum predicted acc = {:.2f}\".format(y(xp).max()))\n",
    "\n",
    "_=plt.legend(['extrapolation', 'measured'], fontsize='xx-large', framealpha=0)"
   ]
  }
 ],
 "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.0"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 1
}
