{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {
    "hideCode": true,
    "hidePrompt": true
   },
   "source": [
    "#  Hierarchical nucleation of deep networks"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Import libraries and data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "hideCode": true,
    "hidePrompt": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "running build_ext\r\n"
     ]
    }
   ],
   "source": [
    "# Compile the cython extension locally\n",
    "\n",
    "!python setup_cython.py build_ext -b src/ ;\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {
    "hideCode": true,
    "hidePrompt": true
   },
   "outputs": [],
   "source": [
    "# Import libraries and source code to run the analysis\n",
    "import sys\n",
    "sys.path.insert(0,'src/')\n",
    "\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import matplotlib.cm as cm\n",
    "import os\n",
    "import pathlib\n",
    "from matplotlib.gridspec import GridSpec\n",
    "from sklearn.metrics.cluster import adjusted_rand_score\n",
    "from utils import Data_sets, kernel_PCA\n",
    "%load_ext autoreload\n",
    "%autoreload 2\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {
    "hideCode": true,
    "hidePrompt": true
   },
   "outputs": [],
   "source": [
    "# Download and unzip the data from figshare\n",
    "\n",
    "if not os.path.isdir(\"maxk_30\"):\n",
    "    !curl -o dist_imagenet90k_r152.tar.gz https://ndownloader.figshare.com/files/22903688?private_link=6c875e9f4a31bfd79794\n",
    "    !tar -xzf dist_imagenet90k_r152.tar.gz\n",
    "    \n",
    "# If the above does not work, please download the data manually at the link https://figshare.com/s/6c875e9f4a31bfd79794\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {
    "hideCode": true,
    "hidePrompt": true
   },
   "outputs": [],
   "source": [
    "# Ids of the 90000 images used, class label assignements and macro label assignments\n",
    "folder = 'samples_ids_and_macrolabels/'\n",
    "\n",
    "sampled_images_id = np.loadtxt(folder + 'sampled_images_id.txt', dtype='str')\n",
    "macro_labels = np.genfromtxt(folder + 'macro_labels.txt')\n",
    "class_labels = np.repeat(np.arange(300), 300)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {
    "hideCode": true,
    "hidePrompt": true
   },
   "outputs": [],
   "source": [
    "# Initialise a \"Data_sets\" class containing the distance matrices for the selected layers \n",
    "\n",
    "data_folder = 'maxk_30'\n",
    "\n",
    "checkpoints = np.array([0, 1, 10, 34, 97, 142, 145, 148, 151, 152, 153])\n",
    "\n",
    "ds = Data_sets()\n",
    "\n",
    "for cp in checkpoints:\n",
    "    distances = np.load(data_folder + '/layer_{}.npz'.format(cp))\n",
    "    ds.add_one_dataset(distances=(distances['dist'], distances['index']), labels = class_labels, maxk = 30)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Evolution of the neighborhood composition in ResNet152 (section 3.1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {
    "hideCode": true,
    "hidePrompt": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "computing overlap for dataset 0/11\n",
      "computing overlap for dataset 1/11\n",
      "computing overlap for dataset 2/11\n",
      "computing overlap for dataset 3/11\n",
      "computing overlap for dataset 4/11\n",
      "computing overlap for dataset 5/11\n",
      "computing overlap for dataset 6/11\n",
      "computing overlap for dataset 7/11\n",
      "computing overlap for dataset 8/11\n",
      "computing overlap for dataset 9/11\n",
      "computing overlap for dataset 10/11\n",
      "Computing overlap with output layer\n"
     ]
    }
   ],
   "source": [
    "# overlap with ground truth labels\n",
    "overlap_gt = np.array(ds.return_label_overlap_mean())\n",
    "\n",
    "# overlap with output layer\n",
    "print('Computing overlap with output layer')\n",
    "overlap_output = np.array([ds.return_overlap_mean_btw_layers(i, -1, k=30) for i in range(len(checkpoints))])"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "\n",
    "* Here we plot the overlap with the ground truth labels for the checkpoints discussed in section 2.3, i.e. the layers [0,1,10,34,142,151,152,153]. The plot on the left is part of Fig. 2-a. On the right we show the overlaps as a function of the layer depths\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/usr/local/miniconda3/envs/pynn/lib/python3.7/site-packages/ipykernel_launcher.py:24: UserWarning: This figure includes Axes that are not compatible with tight_layout, so results might be incorrect.\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 576x252 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "\n",
    "layer_label = ['input', 'maxpool', 'conv2', 'conv3', 'conv4', 'conv5', 'avgpool', 'output']\n",
    "cpt = np.array([0,1,2,3,5,8,9,10])\n",
    "fig = plt.figure(figsize= (8, 3.5))\n",
    "\n",
    "gs0 = GridSpec(1, 1)\n",
    "ax0 = fig.add_subplot(gs0[0])\n",
    "ax0.plot(np.arange(8), overlap_gt[cpt], label = r'$\\chi^{gt}$', marker = 'o')\n",
    "ax0.plot(np.arange(8), overlap_output[cpt], label = r'$\\chi^{out}$', marker = 'o')\n",
    "ax0.set_xticks(np.arange(8))\n",
    "ax0.set_xticklabels(layer_label, rotation = 45)\n",
    "ax0.set_title('ResNet152', fontsize = 13)\n",
    "ax0.legend()\n",
    "ax0.set_ylabel(r'$\\chi$')\n",
    "gs0.tight_layout(fig, rect = [0, 0, 0.5,1])\n",
    "\n",
    "gs1 = GridSpec(1, 1)\n",
    "ax1 = fig.add_subplot(gs1[0])\n",
    "ax1.plot(checkpoints[cpt], overlap_gt[cpt], label = r'$\\chi^{gt}$', marker = 'o')\n",
    "ax1.plot(checkpoints[cpt], overlap_output[cpt], label = r'$\\chi^{out}$', marker = 'o')\n",
    "ax1.set_title('ResNet152', fontsize = 13)\n",
    "ax1.legend()\n",
    "ax1.set_ylabel(r'$\\chi$')\n",
    "ax1.set_xlabel('layer')\n",
    "gs1.tight_layout(fig, rect = [0.5, 0, 1,1])\n",
    "\n",
    "bottom = max(gs1.bottom, gs0.bottom)\n",
    "top = min(gs1.top, gs0.top)\n",
    "gs0.update(top = top, bottom = bottom)\n",
    "gs1.update(top = top, bottom = bottom)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Evolution of the intrinsic dimension (Appendix A.5)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {
    "hideCode": true,
    "hidePrompt": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "computing id of layer  0\n",
      "computing id of layer  1\n",
      "computing id of layer  2\n",
      "computing id of layer  3\n",
      "computing id of layer  4\n",
      "computing id of layer  5\n",
      "computing id of layer  6\n",
      "computing id of layer  7\n",
      "computing id of layer  8\n",
      "computing id of layer  9\n",
      "computing id of layer  10\n"
     ]
    }
   ],
   "source": [
    "### Compute intrisic dimension across all layers \n",
    "ds.compute_id(fraction = 0.95, decimation = 1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "metadata": {
    "hideCode": true,
    "hidePrompt": true
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/usr/local/miniconda3/envs/pynn/lib/python3.7/site-packages/ipykernel_launcher.py:17: MatplotlibDeprecationWarning: Adding an axes using the same arguments as a previous axes currently reuses the earlier instance.  In a future version, a new instance will always be created and returned.  Meanwhile, this warning can be suppressed, and the future behavior ensured, by passing a unique label to each axes instance.\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x129225160>"
      ]
     },
     "execution_count": 37,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 288x216 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "### Here we plot the intrisic dimesion profile of ResNet152 shown in figure A.4; also in this case \n",
    "### we only the layers analysed in the paper : l = [0, 1, 10, 34, 142, 151, 152, 153]\n",
    "\n",
    "layer_label = ['input', 'maxpool', 'conv2', 'conv3', 'conv4', 'conv5', 'avgpool', 'output']\n",
    "cpt = np.array([0,1,2,3,5,8,9,10])\n",
    "fig = plt.figure(figsize= (4, 3))\n",
    "\n",
    "gs0 = GridSpec(1, 1)\n",
    "\n",
    "ax1 = fig.add_subplot(gs0[0])\n",
    "ax1.plot(np.arange(8), np.array(ds.ids)[cpt], label = 'ID', marker = 'o', color = 'C0')\n",
    "ax1.set_ylabel('ID')\n",
    "ax1.set_xticks(np.arange(8))\n",
    "ax1.set_xticklabels(layer_label, rotation = 45)\n",
    "gs0.tight_layout(fig, rect = [0, 0, 1,1])\n",
    "\n",
    "ax2 = fig.add_subplot(gs0[0])\n",
    "ax2 = ax1.twinx()\n",
    "ax2.plot(np.arange(8), overlap_gt[cpt], label = r'$\\chi^{gt}$', marker = 'o', color = 'C1', alpha = 0.5)\n",
    "ax2.set_title('ResNet152', fontsize = 13)\n",
    "#ax2.legend()\n",
    "ax2.set_ylabel(r'$\\chi^{gt}$')\n",
    "\n",
    "ax1.legend(loc = (.03, .84), frameon = False)\n",
    "ax2.legend(loc = (.03, .72), frameon = False)\n",
    "\n",
    "#plt.plot(np.arange(8), np.array(ds.ids)[cpt], '-o')\n",
    "#plt.xlabel('layer')\n",
    "#plt.ylabel('ID')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Evolution of the data probability distribution across the hidden layers (Section 3.3)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "* Density estimation"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {
    "hideCode": true,
    "hidePrompt": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "computing kNN density for dataset  0\n",
      "computing kNN density for dataset  1\n",
      "computing kNN density for dataset  2\n",
      "computing kNN density for dataset  3\n",
      "computing kNN density for dataset  4\n",
      "computing kNN density for dataset  5\n",
      "computing kNN density for dataset  6\n",
      "computing kNN density for dataset  7\n",
      "computing kNN density for dataset  8\n",
      "computing kNN density for dataset  9\n",
      "computing kNN density for dataset  10\n"
     ]
    }
   ],
   "source": [
    "### Compute density of each point across all layers ###\n",
    "ds.compute_density_kNN(k= 30)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "* Topography of the density landscape (peaks and saddle points)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {
    "hideCode": true,
    "hidePrompt": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Z = 1.65, halo = False\n",
      "computing clustering for dataset  0\n",
      "computing clustering for dataset  1\n",
      "computing clustering for dataset  2\n",
      "computing clustering for dataset  3\n",
      "computing clustering for dataset  4\n",
      "computing clustering for dataset  5\n",
      "computing clustering for dataset  6\n",
      "computing clustering for dataset  7\n",
      "computing clustering for dataset  8\n",
      "computing clustering for dataset  9\n",
      "computing clustering for dataset  10\n",
      "Z = 1.65, halo = False\n"
     ]
    }
   ],
   "source": [
    "### Find density peaks and saddle points between them for all layers ###\n",
    "ds.compute_clustering(Z = 1.65, halo = False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {
    "hideCode": true,
    "hidePrompt": true
   },
   "outputs": [],
   "source": [
    "### Save density peaks and saddle points ###\n",
    "\n",
    "folder = '../peaks_and_saddle_points'\n",
    "\n",
    "if not os.path.isdir(f'{folder}'):\n",
    "                pathlib.Path(f'{folder}').mkdir(parents=True, exist_ok=True)\n",
    "\n",
    "for layer, cp in zip(ds.data_sets, checkpoints):\n",
    "    \n",
    "    #peaks = [layer.Rho[j] for j in layer.centers_m]\n",
    "    topography_matrix = layer.out_bord\n",
    "    with open(f'{folder}/layer_{cp}_topography.txt', 'w') as f:\n",
    "        for i in range(len(topography_matrix)):\n",
    "            for j in range(len(topography_matrix[i])):\n",
    "                f.write(f'{topography_matrix[i, j]} ')\n",
    "            f.write('\\n')\n",
    "    with open(f'{folder}/layer_{cp}_densities.txt', 'w') as f:\n",
    "        for i in range(len(layer.Rho)):\n",
    "            f.write(f'{layer.Rho[i]} \\n')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "* Adjusted Rand index (figure 4-b) (the profiles don't match exactly those of fig 4-b since we use a subset of the layers analysed in the paper)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {
    "hideCode": true,
    "hidePrompt": true
   },
   "outputs": [],
   "source": [
    "### Compute Adjusted Rand Index between density peaks and classes or macro-classes (animals, artifacts, ...)\n",
    "\n",
    "ARIs_classes = []\n",
    "ARIs_macro = []\n",
    "\n",
    "for layer in ds.data_sets:\n",
    "    ARI = adjusted_rand_score(layer.labels, class_labels)\n",
    "    ARIs_classes.append(ARI)\n",
    "    \n",
    "    ARI = adjusted_rand_score(layer.labels, macro_labels)\n",
    "    ARIs_macro.append(ARI)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {
    "hideCode": true,
    "hidePrompt": true
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0, 0.5, 'ARI')"
      ]
     },
     "execution_count": 18,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(checkpoints, ARIs_classes, '-o', label = 'ARI_classes')\n",
    "plt.plot(checkpoints, ARIs_macro, '-o', label = 'ARI macro classes')\n",
    "plt.legend()\n",
    "plt.xlabel('layers')\n",
    "plt.ylabel('ARI')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "* Two dimensional visualization of the peaks (panels in figure 4-a)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {
    "hideCode": true,
    "hidePrompt": true
   },
   "outputs": [],
   "source": [
    "### Plot 2D representation of the density peaks of a given layer\n",
    "\n",
    "# select a specific layer\n",
    "layer = ds.data_sets[-1]\n",
    "\n",
    "# compute 2D embedding\n",
    "embedding = kernel_PCA(layer)\n",
    "\n",
    "# Size of density peaks\n",
    "s = []\n",
    "for i in range(layer.Nclus_m):\n",
    "    s.append(3. * np.sqrt(len(layer.clstruct_m[i])))\n",
    "\n",
    "# Color of density peaks (proportion of animals or artifacts)\n",
    "col = []\n",
    "for i in range(layer.Nclus_m):\n",
    "    idx = layer.clstruct_m[i]\n",
    "    ancs = macro_labels[idx]\n",
    "    n_animals = sum(ancs == 13)\n",
    "    n_artifacts = sum(ancs == 2)\n",
    "\n",
    "    an_frac = n_animals/(n_animals + n_artifacts) \n",
    "    \n",
    "    # subtract baseline ratio between the two (unbalanced) macro classes\n",
    "    an_frac = an_frac - (38400/(47100 + 38400)) + 0.5 \n",
    "    \n",
    "    col.append(cm.coolwarm(an_frac))\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {
    "hideCode": true,
    "hidePrompt": true
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.collections.PathCollection at 0x115d5ce48>"
      ]
     },
     "execution_count": 20,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.scatter(embedding[:, 0], embedding[:, 1], s = s, c = col, edgecolor = 'k')"
   ]
  }
 ],
 "metadata": {
  "hide_code_all_hidden": true,
  "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.3"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
