{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "38f46bbc",
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "from tqdm.auto import tqdm\n",
    "\n",
    "from src.utils import load_pickle\n",
    "from src.dimensionality import Dimensionality"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "b4316954",
   "metadata": {},
   "outputs": [],
   "source": [
    "plt.style.use('../style/plots.mplstyle')\n",
    "palette = ['#a4c8ffff', '#ffa5acff', '#afffa6ff', '#d8a6ffff', '#ffd0a5ff', '#d7d7d7ff']\n",
    "\n",
    "seaborn_props = {\n",
    "    'boxprops': {'edgecolor':'black', 'linewidth': 1.5},\n",
    "    'medianprops': {'color':'black', 'linewidth': 1.5},\n",
    "    'whiskerprops': {'color':'black', 'linewidth': 1.5},\n",
    "    'capprops': {'color':'black', 'linewidth': 1.5}\n",
    "}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "e9e5196b",
   "metadata": {},
   "outputs": [],
   "source": [
    "path_models = os.path.join('..', '..', 'models')\n",
    "assert os.path.exists(path_models)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "b9def6fb",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Number of layers: 126\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "6e4e5582a2d34a3aa5a355baec455e3d",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "resnet50:   0%|          | 0/16 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Number of layers: 126\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "6f3dd6d15a8a4026a85924d88c237045",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "simclr:   0%|          | 0/16 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Number of layers: 186\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "a45fc0c58565458c9a56b75eaed63507",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "clip_resnet50:   0%|          | 0/16 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "num_subsample = 50\n",
    "total_subsample = 100\n",
    "\n",
    "dict_dimensionality_linear = {}\n",
    "dict_depth = {}\n",
    "dict_size = {}\n",
    "\n",
    "model_names = ['resnet50', 'simclr', 'clip_resnet50']\n",
    "seeds = [11, 22, 33]\n",
    "\n",
    "for model_name, seed in zip(model_names, seeds):\n",
    "    np.random.seed(seed)\n",
    "    path_model = os.path.join(path_models, f'{model_name}_activations_untrained.pickle')\n",
    "    assert os.path.exists(path_model)\n",
    "\n",
    "    dict_activations = load_pickle(path_model)\n",
    "\n",
    "    activations = dict_activations['activations']\n",
    "    layers = list(dict_activations['activations'].keys())\n",
    "    num_total_layers = len(dict_activations['layers'])\n",
    "\n",
    "    print(f'Number of layers: {num_total_layers}')\n",
    "\n",
    "    dict_depth[model_name] = np.where(np.isin(dict_activations['layers'], layers))[0] / num_total_layers\n",
    "\n",
    "    num_layers = len(activations.keys())\n",
    "    dimensionality = np.zeros((num_layers, total_subsample))\n",
    "    dict_size[model_name] = np.zeros((num_layers, ))\n",
    "\n",
    "    for i, layer in tqdm(enumerate(activations.keys()),\n",
    "                         total=num_layers, desc=model_name):\n",
    "        num_features = activations[layer].shape[1]\n",
    "        dict_size[model_name][i] = num_features\n",
    "        if num_features < num_subsample:\n",
    "            continue\n",
    "        for j in range(total_subsample):\n",
    "            subset_indices = np.random.choice(num_features, num_subsample, replace=False)\n",
    "            dimensionality[i, j] = Dimensionality.effective_dimensionality(activations[layer][:, subset_indices])\n",
    "\n",
    "    dict_dimensionality_linear[model_name] = dimensionality"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "295e7d8b",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Number of layers: 126\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "6da15dfe9ea140ee96761de51eac5fdb",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "resnet50:   0%|          | 0/16 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Number of layers: 126\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "882a7faadbac47a782fc48bb59259c41",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "simclr:   0%|          | 0/16 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Number of layers: 186\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "1a709b3110ae4ce6958d9d862fb7b92d",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "clip_resnet50:   0%|          | 0/16 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "dict_dimensionality_nonlinear = {}\n",
    "\n",
    "for model_name, seed in zip(model_names, seeds):\n",
    "    np.random.seed(seed)\n",
    "    path_model = os.path.join(path_models, f'{model_name}_activations_untrained.pickle')\n",
    "    assert os.path.exists(path_model)\n",
    "\n",
    "    dict_activations = load_pickle(path_model)\n",
    "\n",
    "    activations = dict_activations['activations']\n",
    "    layers = list(dict_activations['activations'].keys())\n",
    "    num_total_layers = len(dict_activations['layers'])\n",
    "\n",
    "    print(f'Number of layers: {num_total_layers}')\n",
    "\n",
    "    num_layers = len(activations.keys())\n",
    "    dimensionality = np.zeros((num_layers, total_subsample))\n",
    "\n",
    "    for i, layer in tqdm(enumerate(activations.keys()),\n",
    "                         total=num_layers, desc=model_name):\n",
    "        num_features = activations[layer].shape[1]\n",
    "        if dict_size[model_name][i] < num_subsample:\n",
    "            continue\n",
    "        for j in range(total_subsample):\n",
    "            subset_indices = np.random.choice(num_features, num_subsample, replace=False)\n",
    "            dimensionality[i, j] = Dimensionality.intrinsic_dimensionality(activations[layer][:, subset_indices])\n",
    "\n",
    "    dict_dimensionality_nonlinear[model_name] = dimensionality"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "348fe24e",
   "metadata": {},
   "outputs": [],
   "source": [
    "from scipy.optimize import curve_fit\n",
    "\n",
    "def model(x, a, b, c):\n",
    "    return a * x**b + c"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "0165a786",
   "metadata": {},
   "outputs": [],
   "source": [
    "dict_titles = {\n",
    "    'resnet50': 'ResNet50',\n",
    "    'simclr': 'SimCLR',\n",
    "    'clip_resnet50': 'CLIP-ResNet50'\n",
    "}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "2d23fe79",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([ True,  True,  True,  True,  True,  True,  True,  True,  True,\n",
       "        True,  True,  True,  True,  True,  True,  True])"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "dict_size['resnet50'] > num_subsample"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "29a35b57",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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2LJlC6KjozFp0iQMGDDAcEGxfpvDhw/jl19+wezZs3Hp0iWkpqbi999/r9AXYA7DirySueGY1igdQqnkeC4crslsIiI1YjYRkbvZVOR99913GD16NNq3b4/ly5ejevXqFre/desW+vXrh23btuG///0vBg92/fAthhWR92M2EZEaMZuIyN00tmz0/fffw9/fH999953VoAKAqlWrYv78+ZAkCd9//73DjSQiMoXZRERqxGwiInezqSevbt26iImJwR9//GHXkycnJ+PWrVs4c+aM0vYpxk+kiLwfs4mI1IjZRETuZlNP3o0bN1C3bl27nzwuLg5ZWVl270dEZAtmExGpEbOJiNzNpiIvPz8fgYGBdj95aGgoCgoK7N6PiMgWzCYiUiNmExG5m01FHhEREREREXkGFnlERERERERexOYFra5cuYJNmzbZ9eRXrlyxu0FERPZgNhGRGjGbiMidbJpdU6PRQJIkxQfRarV273PgwAFMnToVGzduRHZ2NurUqYOBAwdi6tSpqFKlitX9OUsUkfdjNhGRGjGbiMjdbOrJi4mJcSis7HXs2DF06NABvr6+mDBhAmJiYrBt2zbMmjUL69atw7Zt2xg+RMRsIiJVYjYRkbvZ1JPnag888ADWr1+PPXv2ICkpyXD/zJkz8cwzz+C9997Diy++aPE5+IkUETkbs4mI1IjZRERlqW7ilcLCQmzevBn33XefUVABwOjRowEAGzdudEfTiKgSYzYRkRoxm4jIFJsnXnEVX19fHDp0CDqdrtxj+guSfXx8XN0sIqrkmE1EpEbMJiIyRXVFnkajQVxcnMnH3n//fQBA165dTT6em5tr8v9ERI5iNhGRGjGbiMgUVV6TZ8q3336L0aNHo169ejh8+LBh3Hhp5i5y5thyIqoozCYiUiNmE1Hlprpr8kz55ptv8OijjyIkJASLFy82GVRERK7GbCIiNWI2EZHqi7w333wTY8eORWhoKFauXImUlBSz2+bk5BhuXFCUiCoSs4mI1IjZRESACq/J0ysqKsL48eMxf/58REdH49dff0Xz5s0t7sOhBURU0ZhNRKRGzCYiKs3hIq+oqAh79+7F+fPnERUVhU6dOuHcuXOIiYlR/JxarRbDhw/H4sWL0bx5c/z666+Ijo52tKlEVIkwm4hIjZhNROQKiodrFhcXY/LkyYiMjESHDh0wdOhQ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",
      "text/plain": [
       "<Figure size 900x300 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "os.makedirs('svg', exist_ok=True)\n",
    "path_figure = os.path.join('svg', f'figure02_models_effective_untrained_{num_subsample}.svg')\n",
    "\n",
    "fig, ax = plt.subplots(1, 3, figsize=(9, 3))\n",
    "\n",
    "for i, model_name in enumerate(model_names):\n",
    "    depth = dict_depth[model_name][dict_size[model_name] > num_subsample]\n",
    "    mean_dimensionality_linear = np.mean(dict_dimensionality_linear[model_name][dict_size[model_name] > num_subsample, :], axis=1)\n",
    "    std_dimensionality_linear = np.std(dict_dimensionality_linear[model_name][dict_size[model_name] > num_subsample, :], axis=1)\n",
    "\n",
    "    ax[i].plot(depth, mean_dimensionality_linear, color=palette[1])\n",
    "    ax[i].errorbar(x=depth, y=mean_dimensionality_linear, yerr=std_dimensionality_linear, fmt='o', color=palette[1], markersize=5, capsize=5, capthick=1.5)\n",
    "\n",
    "    ax[i].set_xlabel('Relative Depth')\n",
    "    ax[i].set_ylabel('Effective Dimensionality')\n",
    "    ax[i].set_title(dict_titles[model_name])\n",
    "    ax[i].set_xlim(0, 1)\n",
    "    ax[i].set_ylim(1, 4)\n",
    "\n",
    "fig.tight_layout()\n",
    "fig.savefig(path_figure, transparent=True)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "cab33154",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2.33x^2.86 + 6.41\n",
      "2.41x^2.83 + 5.50\n",
      "0.65x^3.64 + 5.95\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 900x300 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "path_figure = os.path.join('svg', f'figure02_models_intrinsic_untrained_{num_subsample}2.svg')\n",
    "\n",
    "fig, ax = plt.subplots(1, 3, figsize=(9, 3))\n",
    "\n",
    "for i, model_name in enumerate(model_names):\n",
    "    depth = dict_depth[model_name][dict_size[model_name] > num_subsample]\n",
    "    mean_dimensionality_nonlinear = np.mean(dict_dimensionality_nonlinear[model_name][dict_size[model_name] > num_subsample], axis=1)\n",
    "    std_dimensionality_nonlinear = np.std(dict_dimensionality_nonlinear[model_name][dict_size[model_name] > num_subsample], axis=1)\n",
    "\n",
    "    p0 = [1.0, 2.0, 1.0]\n",
    "    popt, pcov = curve_fit(model, depth, mean_dimensionality_nonlinear, p0=p0)\n",
    "    x_fit = np.linspace(0, 1, 200)\n",
    "    y_fit = model(x_fit, *popt)\n",
    "    a, b, c = popt\n",
    "    print(f'{a:.2f}x^{b:.2f} + {c:.2f}')\n",
    "\n",
    "    ax[i].errorbar(x=depth, y=mean_dimensionality_nonlinear, yerr=std_dimensionality_nonlinear, fmt='o', color=palette[0], markersize=5, capsize=5, capthick=1.5)\n",
    "    ax[i].plot(x_fit, y_fit, color=palette[0], linewidth=2)\n",
    "\n",
    "    ax[i].set_xlabel('Relative Depth')\n",
    "    ax[i].set_ylabel('Intrinsic Dimensionality')\n",
    "    ax[i].set_xlim(0, 1)\n",
    "    ax[i].set_ylim(6, 9)\n",
    "    ax[i].set_title(dict_titles[model_name])\n",
    "\n",
    "fig.tight_layout()\n",
    "fig.savefig(path_figure, transparent=True)\n",
    "plt.show()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "src",
   "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.10.0"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
