{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import torch\n",
    "from torchvision.models import resnet18\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from pylab import rcParams\n",
    "from scipy.optimize import minimize_scalar\n",
    "from scipy.misc import derivative\n",
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "import matplotlib\n",
    "from pylab import rcParams\n",
    "\n",
    "import sys\n",
    "sys.path.append('../')\n",
    "from utils.misc import normalize_module_name\n",
    "\n",
    "from pylab import rcParams\n",
    "from pathlib import Path\n",
    "home = str(Path.home())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "st_kurt_2 = torch.load(os.path.join(home, '/data/moran/distiller_master_0/distiller/examples/classifier_compression/logs/resnet18_kurtosis/2019.12.18-191602/best.pth.tar'))['state_dict']\n",
    "convs = [k for k in st_kurt_2.keys() if ('conv' in k or 'downsample.0' in k)]\n",
    "if 'module.' in convs[0]:\n",
    "    st_kurt_2 = {normalize_module_name(k): v for k, v in st_kurt_2.items()}\n",
    "    convs = [k for k in st_kurt_2.keys() if ('conv' in k or 'downsample.0' in k)]\n",
    "# convs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "st_kurt_3 = torch.load(os.path.join(home, '/data/moran/distiller_master_0/distiller/examples/classifier_compression/logs/resnet18_kurtosis/2019.12.11-150717/best.pth.tar'))['state_dict']\n",
    "convs = [k for k in st_kurt_3.keys() if ('conv' in k or 'downsample.0' in k)]\n",
    "if 'module.' in convs[0]:\n",
    "    st_kurt_3 = {normalize_module_name(k): v for k, v in st_kurt_3.items()}\n",
    "    convs = [k for k in st_kurt_3.keys() if ('conv' in k or 'downsample.0' in k)]\n",
    "# convs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "['layer3.0.conv2.weight',\n",
       " 'layer1.1.conv1.weight',\n",
       " 'layer4.1.conv1.weight',\n",
       " 'layer1.1.conv2.weight',\n",
       " 'layer2.1.conv2.weight',\n",
       " 'layer3.1.conv2.weight',\n",
       " 'layer1.0.conv2.weight',\n",
       " 'layer4.1.conv2.weight',\n",
       " 'layer2.0.conv2.weight',\n",
       " 'layer2.0.downsample.0.weight',\n",
       " 'layer3.1.conv1.weight',\n",
       " 'layer1.0.conv1.weight',\n",
       " 'layer4.0.conv2.weight',\n",
       " 'layer4.0.conv1.weight',\n",
       " 'layer2.1.conv1.weight',\n",
       " 'layer4.0.downsample.0.weight',\n",
       " 'conv1.weight',\n",
       " 'layer3.0.conv1.weight',\n",
       " 'layer2.0.conv1.weight',\n",
       " 'layer3.0.downsample.0.weight']"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "st_kurt_6 = torch.load(os.path.join(home, '/data/moran/distiller_master_0/distiller/examples/classifier_compression/logs/resnet18_kurtosis/2019.12.13-154150/best.pth.tar'))['state_dict']\n",
    "convs = [k for k in st_kurt_6.keys() if ('conv' in k or 'downsample.0' in k)]\n",
    "if 'module.' in convs[0]:\n",
    "    st_kurt_6 = {normalize_module_name(k): v for k, v in st_kurt_6.items()}\n",
    "    convs = [k for k in st_kurt_6.keys() if ('conv' in k or 'downsample.0' in k)]\n",
    "convs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "['layer3.0.conv2.weight',\n",
       " 'layer1.1.conv1.weight',\n",
       " 'layer4.1.conv1.weight',\n",
       " 'layer1.1.conv2.weight',\n",
       " 'layer2.1.conv2.weight',\n",
       " 'layer3.1.conv2.weight',\n",
       " 'layer1.0.conv2.weight',\n",
       " 'layer4.1.conv2.weight',\n",
       " 'layer2.0.conv2.weight',\n",
       " 'layer2.0.downsample.0.weight',\n",
       " 'layer3.1.conv1.weight',\n",
       " 'layer1.0.conv1.weight',\n",
       " 'layer4.0.conv2.weight',\n",
       " 'layer4.0.conv1.weight',\n",
       " 'layer2.1.conv1.weight',\n",
       " 'layer4.0.downsample.0.weight',\n",
       " 'conv1.weight',\n",
       " 'layer3.0.conv1.weight',\n",
       " 'layer2.0.conv1.weight',\n",
       " 'layer3.0.downsample.0.weight']"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "st_orig = torch.load(os.path.join(home, '/data/moran/distiller_master_0/distiller/examples/classifier_compression/logs/resnet18_kurtosis/2019.12.16-100325/best.pth.tar'))['state_dict']\n",
    "convs = [k for k in st_orig.keys() if ('conv' in k or 'downsample.0' in k)]\n",
    "if 'module.' in convs[0]:\n",
    "    st_orig = {normalize_module_name(k): v for k, v in st_orig.items()}\n",
    "    convs = [k for k in st_orig.keys() if ('conv' in k or 'downsample.0' in k)]\n",
    "convs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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Tr/55hvuvPNOli9fDsCFF17II488Qtu2bUN5pk+fzqxZszh48CBXX331Eb8v27dvJy0tjeeff54nnniCdevWkZ6eztNPP43H4+Gmm27ik08+oUuXLvzjH/8gLS0ttG5WVhYzZsxgx44dnHHGGdxzzz3ceOONoeWff/45N9xwA2vXrqVVq1YR3+PqHNPR0hqTWrZw4UIGDx7M3LlzK/2n2LFjR5KSkiqcOnYsM/T7mF100UXk5uaydOlSjDHs3buXBQsWcPnll9f4vk5EdXFui4uLmTt3Lo0bN6Zz5841cRgntNo4R47jsHTpUjp06MBll11GcnIy5513Hv/85z+PxyGdsOLj48vUitxzzz1MmTKFrVu30r17d5YvX87w4cMZM2YM2dnZPPXUUyxcuJA//vGPgG3SbtmyJffddx+5ubnk5uaGtlVYWMjkyZPJyspi8+bNtGrVih9++IGMjAzeffdd1q1bR+fOnbn88svJy8urtKyTJk1i0KBBfPLJJ1xzzTVcf/317NixA4D8/Hz69OlDXFwc77zzDmvWrKFFixZceuml5OfnA/DCCy9w7733cv/99/PRRx9x1llnVbm2e+LEidxzzz18/PHHNGnShF/96leMHTuWBx54gHXr1lFYWMjvf//7UP4XX3yRMWPGcNttt7Fp0yZuvfVWbrnlFpYuXQrY7+/gwYNxHIc1a9bw1FNPkZmZSVFRUWgbVTmmY9Gga0wamrlz5zJu3DgWLlxIv379Ks376quvVlpV6ff7a7p49OjRgwULFjB8+HAKCgooLS3l5z//OU8//XSN7+tEU9vn9uWXX+baa68lPz+fFi1a8MYbb5CSklLtcv+Y1NY52r17NwcPHuTBBx9k8uTJTJ06lbfffpvhw4eTlJTEFVdUv5b1x2bdunU899xz9O3bNyI9MzMz4tw98MADjBs3jl//+tcAtGnThmnTpjFixAhmzJjBKaecgtfrpVGjRqHamKBAIMCcOXPo1q1bKO2SSy6JyDN79mz+/e9/89prr5WpqQyXkZERWj558mQeffRRVq1axYgRI1iwYAHGGP7+978Hn91BVlYWzZo14+WXX2bo0KE88sgjjBo1itGjRwO2xm3FihV8/vnnR/ys7rjjjtDN45133smAAQOYPHkyffr0AWDMmDERnb9nzpxJRkZGKK1du3asX7+eadOmMWDAAN58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\n",
      "text/plain": [
       "<Figure size 576x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# for L in convs:\n",
    "L = 'layer4.0.conv2.weight'\n",
    "# rcParams['figure.figsize'] = 5, 5\n",
    "rcParams['figure.figsize'] = 8, 4\n",
    "# print(L)\n",
    "# plt.plot(torch.histc(st_kurt_1_8[L]).cpu().numpy(), linewidth=3)\n",
    "lwidth = 5\n",
    "plt.plot(torch.histc(st_kurt_2[L]).cpu().numpy(), linewidth=lwidth)\n",
    "plt.plot(torch.histc(st_kurt_3[L]).cpu().numpy(), linewidth=lwidth)\n",
    "plt.plot(torch.histc(st_kurt_6[L]).cpu().numpy(), linewidth=lwidth)\n",
    "plt.plot(torch.histc(st_orig[L]).cpu().numpy(), linewidth=lwidth)\n",
    "plt.xlim(20, 70)\n",
    "# plt.legend(['1.8', '2'])\n",
    "# plt.show()\n",
    "# plt.legend(['k = 1.8', 'k = 3', 'k = 6', 'Pretrained model'], fontsize=20);\n",
    "plt.xlabel('Weight tensor\\'s values', fontsize=16, fontweight='normal')\n",
    "plt.ylabel('Value distribution', fontsize=16, fontweight='normal', labelpad=30)\n",
    "plt.legend(['k = 1.8', 'k = 3', 'k = 6', 'Pretrained model'], loc='upper center', bbox_to_anchor=(0.5, -0.10),\n",
    "          fancybox=True, shadow=True, ncol=5, fontsize=14)\n",
    "plt.xticks([])\n",
    "plt.yticks([]);\n",
    "plt.tight_layout()\n",
    "plt.savefig('/data/moran/distiller_master_0/distiller/examples/classifier_compression/logs/resnet18_kurtosis/histogram_uniformization_for_paper_square_with_legend.pdf')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "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.5.2"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
