{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Active Pruning Analysis of `Contrast` in VGG-16"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "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": 2,
   "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 = 7\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",
    "Exp_Idxs = [sample(range(tot_size), num_imgs)] * 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": 3,
   "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": 4,
   "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][1::2] + ['all']\n",
    "assert len(transfer) == num_exps, (len(transfer), num_exps)\n",
    "\n",
    "nets = [getnet(tls, seed = 1)  for tls in transfer]\n",
    "\n",
    "# * Prepare the experiments\n",
    "Exps = [InfoNet(net) for net in nets]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(HTML(value='Experiments'), FloatProgress(value=0.0, max=7.0), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "                                                                                                                                                                              \r"
     ]
    }
   ],
   "source": [
    "from utils.measures import contrast\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 += [contrast(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": 6,
   "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": 12,
   "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 = np.linspace(shade('orchid', 1), shade('cornflowerblue', 1), num = num_exps - 1)\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)]\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])\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.08)\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 Contrast')\n",
    "\n",
    "fig.tight_layout()\n",
    "fig.savefig('results/Contrast_Moving_Random.png', dpi = 300)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "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 Contrast 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
}
