{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pickle\n",
    "import json\n",
    "import numpy as np"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Directory with your experiments:"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "dir_with_experiments = '<insert your dir>'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "num_classes = 45  \n",
    "num_targets = 950028"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Codelength"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "For example, let's look at the experiment with linguistic task, layer 1. "
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Uniform codelength"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "uniform_codelength = num_targets * np.log2(num_classes)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Variational codelength"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "In the experiment folder you will find a file with the information for each validation step. You have to use the last step."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "report = json.load(open(dir_with_experiments + 'bayes_l1/train_report.json'))\n",
    "total_code = report[-1]['kl'] + report[-1]['train_xent']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Variational codelength: 85 kbits\n",
      "Compression: 59.76 \n"
     ]
    }
   ],
   "source": [
    "print(\"Variational codelength: {} kbits\".format(round(total_code / 1024)))\n",
    "print(\"Compression: {} \".format(round(uniform_codelength / total_code, 2)))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Induced probe architecture"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "The report we used before contains also information about probe (report[-1]['bayes_masks_test'])\n",
    "#### But it is not correct and do not use it!"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Look at the distributions"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "To decide which weights can be pruned, we follow the original paper [Bayesian compression](https://arxiv.org/abs/1705.08665). Namely, we determining the threshold for pruning with manual inspection as usually there are two well separated clusters (signal and noise)."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Populating the interactive namespace from numpy and matplotlib\n"
     ]
    }
   ],
   "source": [
    "import torch\n",
    "import sys\n",
    "sys.path.append('<insert path to the repo>/control_tasks') # insert path to the repo\n",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "%pylab inline"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "probe = torch.load(dir_with_experiments + 'bayes_l1/checkpoint/probe_199.pth') # last checkpoint"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "masks, alphas = probe.get_masks([0, 0, 0], # thresholds for pruning - do not know for now\n",
    "                                return_log_alpha=True)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Look at distributions for each probe layer and find a threshold."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array([  3.,   9.,  30., 133., 279., 140.,  57.,  12.,   8.,   3.,   1.,\n",
       "          3.,   8.,  32.,  66.,  71.,  53.,  34.,  35.,  47.]),\n",
       " array([-8.844007  , -8.030653  , -7.2173    , -6.403947  , -5.590594  ,\n",
       "        -4.7772408 , -3.9638872 , -3.1505342 , -2.3371809 , -1.5238277 ,\n",
       "        -0.7104745 ,  0.10287871,  0.91623193,  1.7295852 ,  2.5429382 ,\n",
       "         3.3562915 ,  4.169645  ,  4.982998  ,  5.796351  ,  6.6097045 ,\n",
       "         7.4230576 ], dtype=float32),\n",
       " <a list of 20 Patch objects>)"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<matplotlib.figure.Figure at 0x7f5eb524bef0>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.hist(alphas[0], bins=20)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Here it looks like the clusters are separated by zero."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array([  5.,  14.,  11.,  13.,   8.,   2.,   0.,   0.,   0.,   1.,   5.,\n",
       "         34.,  88., 149., 174., 146., 126.,  82.,  76.,  66.]),\n",
       " array([-10.31048   ,  -9.453717  ,  -8.596953  ,  -7.7401905 ,\n",
       "         -6.8834276 ,  -6.0266643 ,  -5.169901  ,  -4.313138  ,\n",
       "         -3.4563746 ,  -2.5996115 ,  -1.7428484 ,  -0.8860852 ,\n",
       "         -0.02932205,   0.8274411 ,   1.6842043 ,   2.5409675 ,\n",
       "          3.3977306 ,   4.2544937 ,   5.111257  ,   5.96802   ,\n",
       "          6.8247833 ], dtype=float32),\n",
       " <a list of 20 Patch objects>)"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<matplotlib.figure.Figure at 0x7f5eb2ec10f0>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.hist(alphas[1], bins=20)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Here, by -3 (or -4, -5)."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array([  6.,  21.,   6.,   4.,   0.,   0.,   0.,   1.,  30.,  98., 131.,\n",
       "        154., 149., 117.,  83.,  72.,  49.,  37.,  22.,  20.]),\n",
       " array([-9.721072  , -8.672385  , -7.623699  , -6.5750127 , -5.526326  ,\n",
       "        -4.477639  , -3.428953  , -2.3802664 , -1.3315798 , -0.28289324,\n",
       "         0.7657933 ,  1.8144798 ,  2.8631663 ,  3.911853  ,  4.9605393 ,\n",
       "         6.009226  ,  7.057913  ,  8.106599  ,  9.155286  , 10.203972  ,\n",
       "        11.252659  ], dtype=float32),\n",
       " <a list of 20 Patch objects>)"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAXoAAAD8CAYAAAB5Pm/hAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADl0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uIDIuMS4yLCBodHRwOi8vbWF0cGxvdGxpYi5vcmcvNQv5yAAAEDFJREFUeJzt3X+sX3V9x/HnazDYdC6AvSC2dLcu1QWNU3JlbmYLihMQY3GRpGTZOiXpfqBzc4uW+QdLjEl1P3DuB0mVjpo4sGE6GmHOynRkicBaRKAgo4EOrq30GtT9MMGh7/1xT5drvb3fe7/n++Xefvp8JDff7/mcz/meNyeXVz/99Hw/J1WFJKldP7LcBUiSxsugl6TGGfSS1DiDXpIaZ9BLUuMMeklqnEEvSY0z6CWpcQODPsn2JIeTPHBU+zuTPJxkX5IPzWm/Osn+bt9F4yhakrR4Jy+izw3AXwEfP9KQ5LXABuDlVfV0kjO79nOBjcBLgRcCn0/y4qr63kInWLVqVU1OTg71HyBJJ6q9e/d+o6omBvUbGPRVdUeSyaOafxvYWlVPd30Od+0bgJu69seS7AfOB7600DkmJyfZs2fPoFIkSXMk+Y/F9Bt2jv7FwC8muSvJvyR5Vde+GnhiTr/prk2StEwWM3VzrONOB14NvArYmeRFQObpO++qaUk2A5sB1q5dO2QZkqRBhh3RTwOfqll3A98HVnXt58zptwY4ON8HVNW2qpqqqqmJiYFTTJKkIQ0b9P8AvA4gyYuBU4BvALuAjUlOTbIOWA/cPYpCJUnDGTh1k+RG4AJgVZJp4BpgO7C9u+Xyu8Cmml3Yfl+SncCDwDPAVYPuuJEkjVdWwoNHpqamyrtuJGlpkuytqqlB/fxmrCQ1zqCXpMYZ9JLUuGHvo5e0CJNbbh362ANbLx1hJTqROaKXpMYZ9JLUOINekhpn0EtS4wx6SWqcd91IK5R37GhUHNFLUuMMeklqnEEvSY0z6CWpcQa9JDXOoJekxhn0ktQ4g16SGjcw6JNsT3K4ez7s0fv+MEklWdVtJ8lHkuxPcl+S88ZRtCRp8RYzor8BuPjoxiTnAL8MPD6n+RJgffezGbiuf4mSpD4GBn1V3QE8Nc+ua4H3AHOfLr4B+HjNuhM4LcnZI6lUkjSUoebok7wZ+FpVfeWoXauBJ+ZsT3dtkqRlsuRFzZI8B3gf8Ib5ds/TVvO0kWQzs9M7rF27dqllSJIWaZgR/U8D64CvJDkArAHuSfICZkfw58zpuwY4ON+HVNW2qpqqqqmJiYkhypAkLcaSg76q7q+qM6tqsqommQ3386rq68Au4Ne7u29eDXy7qg6NtmRJ0lIs5vbKG4EvAS9JMp3kygW63wY8CuwHPgr8zkiqlCQNbeAcfVVdMWD/5Jz3BVzVvyxJ0qj4zVhJapxBL0mNM+glqXEGvSQ1zqCXpMYZ9JLUOINekhq35LVupBPN5JZbl7sEqRdH9JLUOINekhpn0EtS4wx6SWqcQS9JjTPoJalxBr0kNc6gl6TGGfSS1DiDXpIat5hnxm5PcjjJA3Pa/iTJV5Pcl+TTSU6bs+/qJPuTPJzkonEVLklanMWM6G8ALj6qbTfwsqp6OfDvwNUASc4FNgIv7Y75myQnjaxaSdKSDQz6qroDeOqots9V1TPd5p3Amu79BuCmqnq6qh4D9gPnj7BeSdISjWKO/u3AP3bvVwNPzNk33bX9kCSbk+xJsmdmZmYEZUiS5tMr6JO8D3gG+MSRpnm61XzHVtW2qpqqqqmJiYk+ZUiSFjD0evRJNgFvAi6sqiNhPg2cM6fbGuDg8OVJkvoaakSf5GLgvcCbq+o7c3btAjYmOTXJOmA9cHf/MiVJwxo4ok9yI3ABsCrJNHANs3fZnArsTgJwZ1X9VlXtS7ITeJDZKZ2rqup74ype0vz6PBXrwNZLR1iJVoKBQV9VV8zTfP0C/T8AfKBPUZKk0fGbsZLUOINekhpn0EtS4wx6SWqcQS9JjTPoJalxBr0kNc6gl6TGGfSS1DiDXpIaZ9BLUuMMeklqnEEvSY0z6CWpcQa9JDXOoJekxhn0ktQ4g16SGjcw6JNsT3I4yQNz2s5IsjvJI93r6V17knwkyf4k9yU5b5zFS5IGW8yI/gbg4qPatgC3V9V64PZuG+ASYH33sxm4bjRlSpKGNTDoq+oO4KmjmjcAO7r3O4DL5rR/vGbdCZyW5OxRFStJWrph5+jPqqpDAN3rmV37auCJOf2mu7YfkmRzkj1J9szMzAxZhiRpkFH/Y2zmaav5OlbVtqqaqqqpiYmJEZchSTpi2KB/8siUTPd6uGufBs6Z028NcHD48iRJfZ085HG7gE3A1u71ljnt70hyE/BzwLePTPFIy2Vyy63LXYK0rAYGfZIbgQuAVUmmgWuYDfidSa4EHgcu77rfBrwR2A98B3jbGGqWJC3BwKCvqiuOsevCefoWcFXfoiRJo+M3YyWpcQa9JDXOoJekxhn0ktQ4g16SGmfQS1LjDHpJapxBL0mNM+glqXEGvSQ1zqCXpMYZ9JLUOINekhpn0EtS4wx6SWqcQS9JjTPoJalxwz4zVlKj+j5j98DWS0dUiUal14g+ye8n2ZfkgSQ3JvmxJOuS3JXkkSSfTHLKqIqVJC3d0EGfZDXwu8BUVb0MOAnYCHwQuLaq1gPfBK4cRaGSpOH0naM/GfjxJCcDzwEOAa8Dbu727wAu63kOSVIPQwd9VX0N+FPgcWYD/tvAXuBbVfVM120aWD3f8Uk2J9mTZM/MzMywZUiSBugzdXM6sAFYB7wQeC5wyTxda77jq2pbVU1V1dTExMSwZUiSBugzdfN64LGqmqmq/wU+BfwCcFo3lQOwBjjYs0ZJUg99gv5x4NVJnpMkwIXAg8AXgLd2fTYBt/QrUZLUR585+ruY/UfXe4D7u8/aBrwXeHeS/cDzgetHUKckaUi9vjBVVdcA1xzV/Chwfp/PlSSNjksgSFLjDHpJapxBL0mNM+glqXEGvSQ1zmWKJY1Un2WOXeJ4PBzRS1LjDHpJapxBL0mNM+glqXEGvSQ1zqCXpMYZ9JLUOINekhpn0EtS4wx6SWqcQS9JjesV9ElOS3Jzkq8meSjJzyc5I8nuJI90r6ePqlhJ0tL1HdH/BfDZqvoZ4GeBh4AtwO1VtR64vduWJC2ToYM+yU8Cv0T38O+q+m5VfQvYAOzouu0ALutbpCRpeH1G9C8CZoC/TfLlJB9L8lzgrKo6BNC9njmCOiVJQ+oT9CcD5wHXVdUrgf9hCdM0STYn2ZNkz8zMTI8yJEkL6RP008B0Vd3Vbd/MbPA/meRsgO718HwHV9W2qpqqqqmJiYkeZUiSFjJ00FfV14Enkryka7oQeBDYBWzq2jYBt/SqUJLUS99HCb4T+ESSU4BHgbcx+4fHziRXAo8Dl/c8hySph15BX1X3AlPz7Lqwz+dKkkbHb8ZKUuMMeklqnEEvSY0z6CWpcQa9JDXOoJekxhn0ktQ4g16SGmfQS1LjDHpJalzftW4kaWQmt9w69LEHtl46wkra4ohekhpn0EtS4wx6SWqcQS9JjTPoJalxBr0kNc6gl6TG9Q76JCcl+XKSz3Tb65LcleSRJJ/snicrSVomoxjRvwt4aM72B4Frq2o98E3gyhGcQ5I0pF5Bn2QNcCnwsW47wOuAm7suO4DL+pxDktRP3xH9h4H3AN/vtp8PfKuqnum2p4HVPc8hSeph6KBP8ibgcFXtnds8T9c6xvGbk+xJsmdmZmbYMiRJA/QZ0b8GeHOSA8BNzE7ZfBg4LcmRxdLWAAfnO7iqtlXVVFVNTUxM9ChDkrSQoYO+qq6uqjVVNQlsBP65qn4V+ALw1q7bJuCW3lVKkoY2jvvo3wu8O8l+Zufsrx/DOSRJizSS9eir6ovAF7v3jwLnj+JzJWmxXMv+2PxmrCQ1zqCXpMYZ9JLUOINekhpn0EtS4wx6SWqcQS9JjTPoJalxI/nClDRufb4MI53oHNFLUuMMeklqnEEvSY0z6CWpcQa9JDXOoJekxhn0ktQ4g16SGmfQS1Ljhg76JOck+UKSh5LsS/Kurv2MJLuTPNK9nj66ciVJS9VnCYRngD+oqnuSPA/Ym2Q38BvA7VW1NckWYAuzDwyXpBWp7xIbK/2Zs0OP6KvqUFXd073/L+AhYDWwAdjRddsBXNa3SEnS8EayqFmSSeCVwF3AWVV1CGb/MEhy5ijOMS4+OV5S63oHfZKfAP4e+L2q+s8kiz1uM7AZYO3atX3LkKRls9IHjL3uuknyo8yG/Ceq6lNd85NJzu72nw0cnu/YqtpWVVNVNTUxMdGnDEnSAvrcdRPgeuChqvrzObt2AZu695uAW4YvT5LUV5+pm9cAvwbcn+Teru2PgK3AziRXAo8Dl/crUZLUx9BBX1X/ChxrQv7CYT9XkjRafjNWkhpn0EtS4wx6SWqcQS9JjTPoJalxBr0kNc6gl6TGGfSS1DiDXpIaZ9BLUuMMeklqnEEvSY0z6CWpcQa9JDVuJM+MXU59n96+XOf2ebOSni2O6CWpccf9iP545d8GJD1bHNFLUuPGFvRJLk7ycJL9SbaM6zySpIWNJeiTnAT8NXAJcC5wRZJzx3EuSdLCxjVHfz6wv6oeBUhyE7ABeHBM59NxYDnvkJJOZOOaulkNPDFne7prkyQ9y8Y1os88bfUDHZLNwOZu87+TPLzIz14FfKNHbce9fHBglxP+Gg3g9RnMazTYSK7RIv5/XshPLabTuIJ+GjhnzvYa4ODcDlW1Ddi21A9OsqeqpvqV1zav0cK8PoN5jQY7nq7RuKZu/g1Yn2RdklOAjcCuMZ1LkrSAsYzoq+qZJO8A/gk4CdheVfvGcS5J0sLG9s3YqroNuG0MH73k6Z4TkNdoYV6fwbxGgx031yhVNbiXJOm45RIIktS44ybok1yeZF+S7yeZOmrf1d1SCw8nuWi5alxJkvxxkq8lubf7eeNy17QSuDTHYEkOJLm/+73Zs9z1LLck25McTvLAnLYzkuxO8kj3evpy1jjIcRP0wAPArwB3zG3sllbYCLwUuBj4m24JBsG1VfWK7mcc/15yXHFpjiV5bfd7c1zcPjhmNzCbLXNtAW6vqvXA7d32inXcBH1VPVRV832pagNwU1U9XVWPAfuZXYJBOtr/L81RVd8FjizNIR1TVd0BPHVU8wZgR/d+B3DZs1rUEh03Qb8Al1s4tnckua/7q+eK/qvls8TflcUp4HNJ9nbfYNcPO6uqDgF0r2cucz0LWlEPHknyeeAF8+x6X1XdcqzD5mk7IW4lWuh6AdcB72f2Wrwf+DPg7c9edSvSCfu7skSvqaqDSc4Edif5ajeq1XFqRQV9Vb1+iMMGLrfQqsVeryQfBT4z5nKOByfs78pSVNXB7vVwkk8zO+Vl0P+gJ5OcXVWHkpwNHF7ughbSwtTNLmBjklOTrAPWA3cvc03LrvvlO+ItzP5j9onOpTkGSPLcJM878h54A/7uzGcXsKl7vwk41ozDirCiRvQLSfIW4C+BCeDWJPdW1UVVtS/JTmbXun8GuKqqvrecta4QH0ryCmanJg4Av7m85Sw/l+ZYlLOATyeB2Xz4u6r67PKWtLyS3AhcAKxKMg1cA2wFdia5EngcuHz5KhzMb8ZKUuNamLqRJC3AoJekxhn0ktQ4g16SGmfQS1LjDHpJapxBL0mNM+glqXH/BzmFBvpzHkyvAAAAAElFTkSuQmCC\n",
      "text/plain": [
       "<matplotlib.figure.Figure at 0x7f5eb2de57f0>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.hist(alphas[2], bins=20)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Set thresholds and eval number of neurons at each layer."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [],
   "source": [
    "thesholds = [0, -3, -5]\n",
    "\n",
    "masks, alphas = probe.get_masks(thesholds, # now we know them\n",
    "                                return_log_alpha=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Pruned architecture: 664-55-35\n"
     ]
    }
   ],
   "source": [
    "print(\"Pruned architecture: {}-{}-{}\".format(sum(masks[0]), sum(masks[1]), sum(masks[2])))"
   ]
  },
  {
   "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.6.6"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
