{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Active Pruning Analysis of `Luminosity` in VGG-16"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "import pickle\n",
    "import numpy as np\n",
    "import torch.nn as nn\n",
    "\n",
    "from torchvision.models import vgg16\n",
    "\n",
    "from torchvision import transforms\n",
    "from torch.utils.data import DataLoader\n",
    "from torch.utils.data import Subset\n",
    "from torchvision.datasets import ImageNet\n",
    "\n",
    "from utils.infonets import InfoNet\n",
    "from utils.miscellaneous import get_info"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "from random import sample\n",
    "\n",
    "# Prepare the Experiment hyperparameters\n",
    "img_size = 224\n",
    "pop_size = 100\n",
    "num_imgs = 1000\n",
    "num_exps = 5\n",
    "\n",
    "batch_size = 100\n",
    "\n",
    "img_mean, img_std = [0.485, 0.456, 0.406], [0.229, 0.224, 0.225]\n",
    "pipeline = transforms.Compose([\n",
    "    transforms.Resize(img_size),\n",
    "    transforms.CenterCrop(img_size),\n",
    "    transforms.ToTensor(),\n",
    "    transforms.Normalize(mean = img_mean, std = img_std)\n",
    "])\n",
    "\n",
    "# * Here we load the ImageNet dataset\n",
    "imagenet = ImageNet('path_to_ImageNet', split = 'val', transform = pipeline)\n",
    "\n",
    "# Define the indices of ImageNet images we want to use for the experiments\n",
    "tot_size = len(imagenet)\n",
    "Exp_Idxs = [sample(range(tot_size), num_imgs) for _ in range(num_exps)]\n",
    "\n",
    "# Take a subset of ImageNet containing only the selected classes\n",
    "datasets = [Subset(imagenet, idxs) for idxs in Exp_Idxs]\n",
    "\n",
    "# Construct the loaders for the ImageNet subsets and sample the images\n",
    "loaders = [DataLoader(dataset, batch_size = batch_size, shuffle = False) for dataset in datasets]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/pmurator/SISSA/lib/python3.8/site-packages/torch/nn/functional.py:718: UserWarning: Named tensors and all their associated APIs are an experimental feature and subject to change. Please do not use them for anything important until they are released as stable. (Triggered internally at  /pytorch/c10/core/TensorImpl.h:1156.)\n",
      "  return torch.max_pool2d(input, kernel_size, stride, padding, dilation, ceil_mode)\n"
     ]
    }
   ],
   "source": [
    "from numpy.random import randint\n",
    "\n",
    "# Generate the unit indices and compute their receptive fields for all experiments \n",
    "vgg = vgg16(pretrained = True)\n",
    "tmp = InfoNet(vgg)\n",
    "\n",
    "# Get network layer shapes for the selected input\n",
    "excluded_layers = (nn.Dropout, nn.BatchNorm2d, nn.AdaptiveAvgPool2d)\n",
    "info = get_info(vgg, (1, 3, img_size, img_size), exclude = excluded_layers)\n",
    "\n",
    "# Use network shapes to select a random population of fixed size\n",
    "Exp_unit = []\n",
    "Exp_uRFs = []\n",
    "\n",
    "# NOTE: In this setup every experiment should measure from the same units\n",
    "units = [randint(0, shape, size = (pop_size, len(shape))) for shape in info.shapes]\n",
    "untrf = tmp.measure_RF(keys = info.names, units = units)\n",
    "\n",
    "for _ in range(num_exps):\n",
    "    Exp_unit += [units]\n",
    "    Exp_uRFs += [untrf]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "from utils.miscellaneous import getnet\n",
    "\n",
    "# We prepare the network we want to use for the analysis\n",
    "transfer = [i for i, name in enumerate(info.names) if 'conv' in name][:4] + ['all']\n",
    "assert len(transfer) == num_exps\n",
    "\n",
    "nets = [getnet(tls, seed = 1)  for tls in transfer]\n",
    "\n",
    "\n",
    "# * Prepare the experiments\n",
    "Exps = [InfoNet(net) for net in nets]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "633d6ed4d9b54b8386a4c2448becea1a",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(HTML(value='Experiments'), FloatProgress(value=0.0, max=5.0), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "                                                                              \r"
     ]
    }
   ],
   "source": [
    "from utils.measures import luminosity\n",
    "from utils.algorithms import iprofile\n",
    "\n",
    "from tqdm.notebook import tqdm\n",
    "\n",
    "# Here we sample the dataset\n",
    "Data = ([batch for batch in loader] for loader in loaders)\n",
    "\n",
    "Feat = []\n",
    "Acts = []\n",
    "\n",
    "Inet = []\n",
    "\n",
    "for exp, data, units, uRFs in tqdm(zip(Exps, Data, Exp_unit, Exp_uRFs), total = num_exps, desc = 'Experiments', leave = False):\n",
    "    # Record the network activations from the images\n",
    "    exp.record(units = units, rec_imgs = data)\n",
    "\n",
    "    # Collect the experiment images for feature extraction \n",
    "    imgs = torch.cat([tmp[0] for tmp in data]).numpy()\n",
    "\n",
    "    # Compute image luminosity, the feature in our experiment\n",
    "    Feat += [luminosity(imgs, uRFs)]\n",
    "\n",
    "    # Extract the unit activations from the experiment\n",
    "    ls, Ls = info.names, exp.recorder.keys\n",
    "\n",
    "    Acts += [{l : exp.features[L].T for l, L in zip(ls, Ls)}]\n",
    "\n",
    "    # Compute the mutual information profile using the latest Features and Activations\n",
    "    Inet += [iprofile(Feat[-1], Acts[-1], nbins = (20, 20), bias = 'pt')]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Here we extract the individual entropy measures from all the experiments\n",
    "layers = [l for l in info.names]# if 'conv' in l or 'fc' in l]\n",
    "\n",
    "Hx  = [np.array([[I[l]['Hx']   if I[l] is not None else [np.nan] * pop_size for I in P] for l in layers]) for P in Inet]\n",
    "Hy  = [np.array([[I[l]['Hy']   if I[l] is not None else [np.nan] * pop_size for I in P] for l in layers]) for P in Inet]\n",
    "Hxy = [np.array([[I[l]['Hx|y'] if I[l] is not None else [np.nan] * pop_size for I in P] for l in layers]) for P in Inet]\n",
    "MI  = [np.array([[I[l]['Ix,y'] if I[l] is not None else [np.nan] * pop_size for I in P] for l in layers]) for P in Inet]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 500x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "from utils.plotting import dark_theme, light_theme, shade\n",
    "\n",
    "plt.rcParams.update ({'font.size' : 14, \"text.usetex\": False})\n",
    "light_theme()\n",
    "\n",
    "# Get the layers from a sample data, all data shares it\n",
    "layers = info.names\n",
    "\n",
    "convs = [True if 'conv'  in l else False for l in info.names]\n",
    "relus = [True if 'relu'  in l else False for l in info.names]\n",
    "pools = [True if 'mpool' in l else False for l in info.names]\n",
    "fulls = [True if 'fc'    in l else False for l in info.names]\n",
    "\n",
    "gmask = np.logical_or(convs, fulls)\n",
    "\n",
    "fig, ax = plt.subplots(figsize = (5, 4))\n",
    "\n",
    "# * Compute the average across channel colors\n",
    "colors = ['darkseagreen'] + [*np.linspace(shade('orchid', 1), shade('cornflowerblue', 1), num = num_exps - 0)]\n",
    "\n",
    "# Plot the lines of the information profiles\n",
    "ls = [ax.plot (np.arange(sum(gmask)), np.nanmean(mi / hx, axis = (1, 2))[gmask], c = c, lw = 2)[0] \n",
    "        for mi, hx, c in zip(MI[1:], Hx[1:], colors[1:])]\n",
    "\n",
    "markers = ('o', '*')\n",
    "sizes   = (40, 120)\n",
    "convs = [True if 'conv'  in l else False for l in layers if 'conv' in l or 'fc' in l]\n",
    "fulls = [True if 'fc'    in l else False for l in layers if 'conv' in l or 'fc' in l]\n",
    "masks   = (convs, fulls)\n",
    "for mask, m, s in zip(masks, markers, sizes):\n",
    "    par = {'marker' : m, 'ec' : 'w', 's' : s, 'zorder' : 10}\n",
    "    rpar = {'alpha' : 0.7, 's' : s, 'zorder' : 10, 'marker' : m, 'ec' : 'w'}\n",
    "\n",
    "    [ax.scatter(np.arange(sum(gmask))[mask], np.nanmean(mi / hx, axis = (1, 2))[gmask][mask], color = c, **par) \n",
    "        for mi, hx, c in zip(MI[1:-1], Hx[1:-1], colors[1:])]\n",
    "\n",
    "sizes   = (70, 160)\n",
    "for mask, m, s in zip(masks, markers, sizes):\n",
    "    par = {'marker' : m, 'ec' : 'k', 's' : s, 'zorder' : 10}\n",
    "    rpar = {'alpha' : 0.7, 's' : s, 'zorder' : 10, 'marker' : m, 'ec' : 'w'}\n",
    "\n",
    "    [ax.scatter(np.arange(sum(gmask))[mask], np.nanmean(mi / hx, axis = (1, 2))[gmask][mask], color = c, **par) \n",
    "        for mi, hx, c in zip((MI[-1],), (Hx[-1],), (colors[-1],))]\n",
    "    \n",
    "sizes = (9, 13)\n",
    "\n",
    "ax.set_xlabel('layers')\n",
    "ax.set_yticks([0.01, 0.02, 0.03, 0.04, 0.05, 0.06, 0.07, 0.08, 0.09])\n",
    "ax.set_xlim(left = -0.5)\n",
    "\n",
    "ax.spines['top'].set_visible(False)\n",
    "ax.spines['right'].set_visible(False)\n",
    "ax.spines['bottom'].set_bounds(0., 15)\n",
    "ax.spines['left'].set_bounds(0.01, 0.09)\n",
    "ax.set_xticks(np.arange(sum(gmask)))\n",
    "ax.set_xticklabels([])\n",
    "\n",
    "ax.xaxis.set_tick_params(width = 2)\n",
    "ax.yaxis.set_tick_params(width = 2)\n",
    "for s in ax.spines.values(): s.set_linewidth(2)\n",
    "\n",
    "ax.set_ylabel('Normalized MI Luminosity')\n",
    "\n",
    "fig.tight_layout()\n",
    "fig.savefig('results/Luminosity_Active_Pruning.png', dpi = 300)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Store the computed experiments in long storage\n",
    "storepath = f'path_where_to_store/Experiment.pkl'\n",
    "\n",
    "desc = \\\n",
    "    '''\n",
    "        This data bundle contains the data from the mutual information experiment\n",
    "        using Luminosity as stimuli feature on VGG-16 and repeating the experiment\n",
    "        for different VGG-16 setups. We scan from a compleately random network\n",
    "        to a fully trained network, with intermediate cases being network with\n",
    "        layers [0, N] fully trained (equal to VGG-16 trained on ImageNet), and\n",
    "        layers [N, L] (with L being VGG-16 total number of layers) being fully\n",
    "        random. Each experiment is performed once for each configuration.\n",
    "    '''\n",
    "\n",
    "bundle = {\n",
    "    'desc' : desc,\n",
    "    'info' : info,\n",
    "\n",
    "    'img_size' : img_size,\n",
    "    'pop_size' : pop_size,\n",
    "    'num_imgs' : num_imgs,\n",
    "    'num_exps' : num_exps,\n",
    "    'transfer' : transfer,\n",
    "\n",
    "    'batch_size' : batch_size,\n",
    "\n",
    "    'Exp_Idxs' : Exp_Idxs,\n",
    "    'Exp_unit' : Exp_unit,\n",
    "    'Exp_uRFs' : Exp_uRFs,\n",
    "    \n",
    "    'Feat' : Feat,\n",
    "    'Acts' : Acts,\n",
    "    'Inet' : Inet\n",
    "}\n",
    "\n",
    "with open(storepath, 'wb') as f:\n",
    "    pickle.dump(bundle, f)"
   ]
  }
 ],
 "metadata": {
  "interpreter": {
   "hash": "d463e5fc653bab9d8e4f24359b8c55f1b66bd68a84a58e4a6e27c30ef7709220"
  },
  "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.8.10"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
