{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "688f9fbe",
   "metadata": {},
   "source": [
    "# `Corner` Feature Analysis in VGG-16"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "choice-saturn",
   "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": 1,
   "id": "occupied-spotlight",
   "metadata": {},
   "outputs": [],
   "source": [
    "from random import sample\n",
    "\n",
    "# Prepare the Experiment hyperparameters\n",
    "img_size = 224\n",
    "pop_size = 250\n",
    "num_imgs = 1500\n",
    "num_exps = 2\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)] * num_exps# 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": null,
   "id": "comprehensive-lecture",
   "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": null,
   "id": "abandoned-elevation",
   "metadata": {},
   "outputs": [],
   "source": [
    "from random import randint\n",
    "from utils.miscellaneous import getnet\n",
    "\n",
    "# We prepare the network we want to use for the analysis\n",
    "transfer = [[]] + ['all']\n",
    "assert len(transfer) == num_exps\n",
    "\n",
    "seed = randint(0, 10000)\n",
    "nets = (getnet(tls, seed = seed)  for tls in transfer)\n",
    "\n",
    "# * Prepare the experiments\n",
    "Exps = (InfoNet(net) for net in nets)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "capable-driver",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "                                                                        \r"
     ]
    }
   ],
   "source": [
    "from utils.measures import corner\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",
    "# Collect the experiment images for feature extraction \n",
    "imgs = torch.cat([tmp[0] for tmp in Data[0]]).unsqueeze(0).numpy()\n",
    "\n",
    "# Compute image luminosity, the feature in our experiment\n",
    "Peak1, Peak2, Bsi = corner(imgs, Exp_uRFs[0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "criminal-nirvana",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "c54cc6668af24e3181b55fd17084289d",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(HTML(value='Experiments'), FloatProgress(value=0.0, max=2.0), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": []
    }
   ],
   "source": [
    "Acts = []\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",
    "    # 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)}]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "olive-cookbook",
   "metadata": {},
   "outputs": [],
   "source": [
    "from scipy.stats import binned_statistic_2d\n",
    "\n",
    "def joinbin(p1 : np.ndarray, p2 : np.ndarray, bins : int = 5, flip : bool = True) -> np.ndarray:\n",
    "    p1 = p1.astype(np.float)\n",
    "    p2 = p2.astype(np.float)\n",
    "    ans = binned_statistic_2d(p1, p2, None, 'count', bins = bins, expand_binnumbers = False)\n",
    "\n",
    "    # If flip is requested, we map the lower triangle of the histogram back into\n",
    "    # the top one by diagonal symmetry\n",
    "    if flip:\n",
    "        size = bins + 2\n",
    "        M = np.arange(size * size).reshape(size, size)\n",
    "        M = {a : b for a, b in zip(M.flat, M.T.flat)}\n",
    "\n",
    "        out = [min(idx, M[idx]) for idx in ans.binnumber]\n",
    "    else:\n",
    "        out = ans.binnumber\n",
    "\n",
    "    return out\n",
    "\n",
    "R = {l : np.vstack([joinbin(p1, p2) for p1, p2 in zip(P1[..., 0], P2[..., 0])]) for (l, P1), (l, P2) in zip(Peak1.items(), Peak2.items())}\n",
    "G = {l : np.vstack([joinbin(p1, p2) for p1, p2 in zip(P1[..., 1], P2[..., 1])]) for (l, P1), (l, P2) in zip(Peak1.items(), Peak2.items())}\n",
    "B = {l : np.vstack([joinbin(p1, p2) for p1, p2 in zip(P1[..., 2], P2[..., 2])]) for (l, P1), (l, P2) in zip(Peak1.items(), Peak2.items())}\n",
    "\n",
    "Feat = {l : np.stack([R[l], G[l], B[l]], axis = -1) for l in R}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "infrared-cotton",
   "metadata": {},
   "outputs": [],
   "source": [
    "from utils.algorithms import filtbest\n",
    "\n",
    "pop_num = 200\n",
    "img_num = 400\n",
    "\n",
    "f_Feat = []\n",
    "f_Acts = []\n",
    "\n",
    "for acts in Acts:\n",
    "    f_feat, f_acts = filtbest(Feat, acts, Bsi, pop_num, img_num)\n",
    "    f_Feat += [f_feat]\n",
    "    f_Acts += [f_acts]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "strange-marijuana",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "                                                      \r"
     ]
    }
   ],
   "source": [
    "f_Inet = [iprofile(f_feat, f_acts, nbins = (None, 20), bias = 'pt') for f_feat, f_acts in zip(f_Feat, f_Acts)]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "forty-interview",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Here we extract the individual entropy measures from all the experiments\n",
    "layers = [l for l in info.names]\n",
    "\n",
    "Hx  = [np.array([[I[l]['Hx']   if I[l] is not None else [np.nan] * pop_num for I in P] for l in layers]) for P in f_Inet]\n",
    "Hy  = [np.array([[I[l]['Hy']   if I[l] is not None else [np.nan] * pop_num for I in P] for l in layers]) for P in f_Inet]\n",
    "Hxy = [np.array([[I[l]['Hx|y'] if I[l] is not None else [np.nan] * pop_num for I in P] for l in layers]) for P in f_Inet]\n",
    "MI  = [np.array([[I[l]['Ix,y'] if I[l] is not None else [np.nan] * pop_num for I in P] for l in layers]) for P in f_Inet]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "brown-siemens",
   "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 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'] + ['cornflowerblue']\n",
    "\n",
    "# Plot the lines of the information profiles\n",
    "with np.testing.suppress_warnings() as sup:\n",
    "    sup.filter(RuntimeWarning)\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, Hx, 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",
    "\n",
    "masks   = (convs, fulls)\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",
    "    with np.testing.suppress_warnings() as sup:\n",
    "        sup.filter(RuntimeWarning)\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), (Hx), (colors))]\n",
    "    \n",
    "sizes = (9, 13)\n",
    "\n",
    "ax.set_xlabel('layers')\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.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 Corner')\n",
    "\n",
    "fig.tight_layout()\n",
    "fig.savefig('results/Corner_Experiment.png', dpi = 300)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "global-thinking",
   "metadata": {},
   "outputs": [],
   "source": [
    "storepath = f'path_where_to_store/Experiment.pkl'\n",
    "\n",
    "bundle = {\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",
    "    \n",
    "    'Peak1' : Peak1,\n",
    "    'Peak2' : Peak2,\n",
    "    'Bsi' : Bsi,\n",
    "    \n",
    "    'f_nimg' : img_num,\n",
    "    'f_nunt' : pop_num,\n",
    "    'f_Feat' : f_Feat,\n",
    "    'f_Acts' : f_Acts,\n",
    "    \n",
    "    'f_Inet' : f_Inet    \n",
    "}\n",
    "\n",
    "with open(storepath, 'wb') as f:\n",
    "    pickle.dump(bundle, f)"
   ]
  }
 ],
 "metadata": {
  "interpreter": {
   "hash": "d463e5fc653bab9d8e4f24359b8c55f1b66bd68a84a58e4a6e27c30ef7709220"
  },
  "kernelspec": {
   "display_name": "Python 3.8.10 64-bit ('SISSA': venv)",
   "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": 5
}
