{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "last_epoch = []\n",
    "best_epoch = []\n",
    "wid = []\n",
    "widths = [1,1.25,1.5,1.75,2,3,4]\n",
    "offsets = [\"_0\",\"_1\",\"_2\",\"_3\"]\n",
    "for offset in offsets:\n",
    "    for k in widths:\n",
    "        name = \"wdn_{}\".format(k)+offset+\".log\"\n",
    "        print(name)\n",
    "        with open(name) as f:\n",
    "            lines = f.readlines()\n",
    "        name = name.split('/')[0]\n",
    "        accs = [[],[]]\n",
    "        b = 0\n",
    "        for line in lines:\n",
    "            if('Epoch' in line):\n",
    "                b = 0\n",
    "            if('Step' in line):\n",
    "                if('50000' in line):\n",
    "                    accs[0].append(float(line[line.find(\"Acc:\")+5:line.find(\"%\")])*0.01)\n",
    "                    b = 1\n",
    "                if(('10000' in line) and b):\n",
    "                    accs[1].append(float(line[line.find(\"Acc:\")+5:line.find(\"%\")])*0.01)\n",
    "        from matplotlib import pyplot as plt\n",
    "        import numpy as np\n",
    "        accs = np.array(accs)*100\n",
    "        plt.figure(figsize = (7,5))\n",
    "        plt.plot(accs[0],label = 'Train', color = \"Blue\")\n",
    "        plt.plot(accs[1],label = 'Validation', color = \"Orange\")\n",
    "        last_epoch.append(accs[1][-1])\n",
    "        best_epoch.append(max(accs[1]))\n",
    "        wid.append(k)\n",
    "        plt.ylabel('Acc'+\"(%)\",fontsize = 50)\n",
    "        plt.xlabel('Epoch (W={})'.format(k),fontsize = 50)\n",
    "        plt.xticks(range(0,201,50),[str(_) for _  in range(0,201,50)], fontsize = 40, rotation = 45)\n",
    "        plt.yticks(range(20,101,20),[str(_) for _  in range(20,101,20)], fontsize = 40)\n",
    "        plt.legend(fontsize = 20)\n",
    "        plt.tight_layout()\n",
    "        plt.savefig(name+'.pdf',format = \"pdf\")\n",
    "        plt.close()\n",
    "        # plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "plt.figure(figsize = (7,5))\n",
    "plt.plot(accs[0],label = 'Train', color = \"Blue\")\n",
    "plt.plot(accs[1],label = 'Validation', color = \"Orange\")\n",
    "last_epoch.append(accs[1][-1])\n",
    "best_epoch.append(max(accs[1]))\n",
    "wid.append(k)\n",
    "plt.ylabel('Acc'+\"(%)\",fontsize = 50)\n",
    "plt.xlabel('Epoch (W={})'.format(k),fontsize = 50)\n",
    "plt.xticks(range(0,201,50),[str(_) for _  in range(0,201,50)], fontsize = 40, rotation = 45)\n",
    "plt.yticks(range(20,101,20),[str(_) for _  in range(20,101,20)], fontsize = 40)\n",
    "plt.legend(fontsize = 20)\n",
    "plt.tight_layout()\n",
    "plt.savefig(name+'.pdf',format = \"pdf\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "avgs = np.zeros(len(widths))\n",
    "best_avgs  = np.zeros(len(widths))\n",
    "for r in range(len(widths)):\n",
    "    for j in range(len(wid)//len(widths)):\n",
    "        avgs[r] += last_epoch[j*len(widths) + r]\n",
    "        best_avgs[r] += best_epoch[j*len(widths) + r]\n",
    "avgs /= (len(wid)/len(widths))\n",
    "best_avgs /= (len(wid)/len(widths))\n",
    "from scipy import interpolate\n",
    "spline = interpolate.make_interp_spline(widths, avgs)(widths)\n",
    "import sklearn.linear_model\n",
    "# from scipy.interpolate import spline\n",
    "# lr = sklearn.linear_model.LinearRegression()\n",
    "# lr.fit(np.array(wid).reshape(-1, 1),last_epoch)\n",
    "# xrange = np.linspace(1,8)\n",
    "# yrange = lr.intercept_ + lr.coef_*xrange\n",
    "# plt.figure(figsize = (25,12))\n",
    "plt.plot(widths, avgs, color = \"blue\")\n",
    "plt.plot(widths, best_avgs, color = \"orange\")\n",
    "plt.ylabel(\"Validation Acc(%)\",fontsize = 20)\n",
    "plt.xlabel(\"Width Factor\",fontsize = 20)\n",
    "plt.xticks(fontsize = 20)\n",
    "plt.yticks(fontsize = 20)\n",
    "plt.scatter(wid,last_epoch,label = \"Last Epoch\", color = \"blue\")\n",
    "plt.scatter(wid,best_epoch,label = \"Best Epoch\", color = \"orange\")\n",
    "plt.legend(fontsize = 20)\n",
    "plt.tight_layout()\n",
    "plt.savefig(\"widthacc.pdf\",format = \"pdf\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "from re import L\n",
    "\n",
    "\n",
    "for key in pylab.rcParams.keys():\n",
    "    if('fontsize' in key):\n",
    "        print(key)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "from matplotlib.transforms import Bbox\n",
    "\n",
    "def full_extent(ax, pad=0.0):\n",
    "    \"\"\"Get the full extent of an axes, including axes labels, tick labels, and\n",
    "    titles.\"\"\"\n",
    "    # For text objects, we need to draw the figure first, otherwise the extents\n",
    "    # are undefined.\n",
    "    ax.figure.canvas.draw()\n",
    "    items = ax.get_xticklabels() + ax.get_yticklabels() \n",
    "    items += [ax.get_xaxis().get_label(), ax.get_yaxis().get_label()]\n",
    "    items += [ax, ax.title]\n",
    "    bbox = Bbox.union([item.get_window_extent() for item in items])\n",
    "    return bbox.expanded(1.0 + pad, 1.0 + pad)\n",
    "extent = full_extent(ax)\n",
    "fig.savefig('ax_figure.png', bbox_inches=extent)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<Figure size 864x288 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 504x360 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "\n",
    "name = \"resnet0.1\"\n",
    "with open(name) as f:\n",
    "    lines = f.readlines()\n",
    "name = name.split('/')[0]\n",
    "accs = [[],[]]\n",
    "b = 0\n",
    "for line in lines:\n",
    "    if('Epoch' in line):\n",
    "        b = 0\n",
    "    if('Step' in line):\n",
    "        if('50000' in line):\n",
    "            accs[0].append(float(line[line.find(\"Acc:\")+5:line.find(\"%\")])*0.01)\n",
    "            b = 1\n",
    "        if(('10000' in line) and b):\n",
    "            accs[1].append(float(line[line.find(\"Acc:\")+5:line.find(\"%\")])*0.01)\n",
    "from matplotlib import pyplot as plt\n",
    "import numpy as np\n",
    "fig = plt.figure(figsize=(12,4))\n",
    "accs = np.array(accs)*100\n",
    "plt.figure(figsize = (7,5))\n",
    "plt.plot(accs[0],label = 'Train',linewidth = 2)\n",
    "plt.plot(accs[1],label = 'Validation',linewidth = 2)\n",
    "# plt.xticks(fontsize = 25)\n",
    "# plt.yticks(fontsize = 25)\n",
    "plt.xlabel(\"Epoch\",fontsize = 25)\n",
    "plt.ylabel(\"Accuracy(%)\", fontsize = 25)\n",
    "plt.legend(fontsize = 25)\n",
    "plt.xticks(range(0,201,50),[str(_) for _  in range(0,201,50)], fontsize = 25)\n",
    "plt.yticks(range(20,101,20),[str(_) for _  in range(20,101,20)], fontsize = 25)\n",
    "plt.tight_layout()\n",
    "plt.savefig(name+'noise.pdf',format = \"pdf\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "b = 0\n",
    "from matplotlib import pyplot as plt\n",
    "import numpy as np\n",
    "def getaccs(name):\n",
    "    accs = [[],[]]\n",
    "    with open(\"../imagenet/resnet50.log\") as f:\n",
    "        lines = f.readlines()\n",
    "    for line in lines:\n",
    "        if('*' in line):\n",
    "            cut = line[line.find(\"Prec@1\")+6:]\n",
    "            # print(cut)\n",
    "            acc = float(cut[:cut.find('P')])\n",
    "            accs[1].append(acc)\n",
    "        elif('1250/1252' in line):\n",
    "            cut = line[line.find(\"Prec@1\"):]\n",
    "            acc = float(cut[cut.find('(')+1:cut.find(')')])\n",
    "            accs[0].append(acc)\n",
    "    with open(\"../imagenet/\"+name) as f:\n",
    "        lines = f.readlines()\n",
    "    for line in lines:\n",
    "        if('*' in line):\n",
    "            cut = line[line.find(\"Prec@1\")+6:]\n",
    "            # print(cut)\n",
    "            acc = float(cut[:cut.find('P')])\n",
    "            accs[1].append(acc)\n",
    "        elif('1250/1252' in line):\n",
    "            cut = line[line.find(\"Prec@1\"):]\n",
    "            acc = float(cut[cut.find('(')+1:cut.find(')')])\n",
    "            accs[0].append(acc)\n",
    "    return accs\n",
    "origin = getaccs(\"resnet50_90_lr1.log\")\n",
    "from matplotlib import pyplot as pltz\n",
    "plt.figure(figsize=(7,5))\n",
    "plt.plot([0]*27 + origin[0],label = \"Train\",linewidth = 2)\n",
    "plt.plot([0]*27 + origin[1],label = \"Validation\", linewidth = 2)\n",
    "plt.ylim(61,87)\n",
    "plt.yticks(range(65,86,5),[\" {}\".format(k) for k in range(65,86,5)],fontsize = 25)\n",
    "plt.xticks(fontsize = 25)\n",
    "plt.xlabel(\"Epoch\",fontsize = 25)\n",
    "plt.ylabel(\"Accuracy(%)\", fontsize = 25)\n",
    "plt.legend(fontsize = 25)\n",
    "plt.tight_layout()\n",
    "plt.savefig(\"resnet50_90_lr1.log\"+'.pdf',format = \"pdf\")\n",
    "plt.show()\n",
    "# plt.title(\"LR1\")"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3.8.13 ('JiayeTeng')",
   "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.8.13"
  },
  "orig_nbformat": 4,
  "vscode": {
   "interpreter": {
    "hash": "e72f24b787c0d487131ca6ac3f3c79044e81d11bd62401f3bd21201feea542ed"
   }
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
