{
 "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": "d2405424a5e04c0fb2dce5642eb6ba3e",
       "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": "7ed249c7c32b4f29b9e3070baba0b145",
       "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": "6b83c80c4c5149138d67c6bda456f5dd",
       "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.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": "a1de825e5b4d451fb475f9d436993169",
       "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": "60dae452afcf4ada88ef6c829fe6a39d",
       "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": "673dbb17d6c44613b3253a4ff4f8aba8",
       "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.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": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "23.78x^1.60 + 5.33\n",
      "16.85x^1.83 + 4.35\n",
      "17.15x^1.80 + 4.76\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA3oAAAEiCAYAAACvEaDLAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8g+/7EAAAACXBIWXMAAA9hAAAPYQGoP6dpAAB6sElEQVR4nO3dd3hUVcIG8Pem94QQSCCQBgkBQm+hKL2DUVFQunU/110L6i6yKmJX7NgQQRYLWJAiq0hHegkgvSf0HggkIXXO98dlJjOZfjPlzuT9Pc88ZG6ZOUOYl3vOPUUSQggQERERERGR1/BxdwGIiIiIiIjIsVjRIyIiIiIi8jKs6BEREREREXkZVvSIiIiIiIi8DCt6REREREREXoYVPSIiIiIiIi/Dih4REREREZGXYUWPiIiIiIjIy7CiR0RERERE5GVY0fNSkiRZfPj7+yM6Ohrt27fHCy+8gGvXrrm1vOPHj4ckSQgODsaBAwesHt+jRw9IkoSXX37ZoeXYt2+fye0vv/yy1b/TDz/80OS5c+bMQefOnREWFobw8HC0b98en376KSoqKhxadiJvs3v3bjzxxBNo3rw5oqKiEBQUhIYNG2LgwIH45JNPcPPmTaNztFkyevRol5a1oqIC8+fPx4gRI5CcnIygoCAEBwejUaNGGDNmDNasWWP2XG2ejR8/3q731H5Wcw8fHx+EhoYiNTUVI0eOxLZt26r3IYlc5Pr16/jkk0/Qr18/xMXFwd/fH+Hh4WjVqhUmTJiAw4cPmzxP+29/9uzZdr2f9v/4pKQks69p6hEQEKC7lpo0aRIuXLig4NPymk0pXrNZ5+fuApBzpaamom7dukbbS0pKcOzYMWRnZyM7Oxtff/01Nm/ejIYNG7qhlJWKi4sxfvx4bNy4Eb6+vi5738OHD+OJJ55AQUEB1q9fb7T/r7/+AgCkp6ejdu3aJl8jPj7eaNs///lPfPLJJ7pzfX19dX/nixcvxpIlS+Dv7+/AT0LkHSZPnozXXnsNGo0GERERaNSoEQICAnDu3DksXboUS5cuxTvvvIOFCxeibdu2bi3roUOHMGLECF1OaCtX5eXlyMnJwbfffotvv/0W9957L77++muEhoY69P0jIiLQokULo+0ajQYXLlzA0aNHcfToUfzwww+YPn06Hn74YYe+P5EjLVmyBA888AAuX74MAIiOjkaLFi2Ql5eHffv2Yffu3fjkk08wefJk/Oc//3FZuUxdT5WVleHKlSvYsWMHsrOz8cUXX+D3339Hp06dHPYeAK/ZquI1mx0EeSUAAoD4+uuvzR5TUVEhvvnmG+Hv7y8AiN69e7uugFWMGzdOV2YA4q233rJ4fPfu3QUAMXnyZIe8/+TJkwUA0bVrV5P7k5OTBQCxefNmm1/z66+/FgBEZGSkWLdunW779u3bRb169QQA8cILL1S77ETeZtasWQKACA0NFT/99JMoLy832L9//36RmZkpAIiYmBhx8eJF3b6zZ8+KAwcOiLNnz7qkrGvXrhWhoaECgGjfvr347bffDPYXFRWJDz74QHdMz549RVlZmcEx2jwbN26cXe+tzc3u3btbPO7AgQOiVatWAoDw9/cXx48ft+t9iFzl3Xff1V0HDB8+XOzdu9dg/9mzZ8Xf//533TFV/w+15drHFO01QGJiotE+W17zr7/+Eg0aNBAAREpKiiguLrbr/XnNZh9es9mOXTdrMB8fH4wePRoTJ04EAKxcudJsdwhXkSQJgNyav3//freWRev69evIzc2FJElo3ry5TedUVFTgtddeAwC8/fbb6Natm25fu3btMGfOHADABx98gPz8fMcXmsiDvf766wCAd999F/fcc49RS3HTpk2xePFi1K1bF5cvX8bHH3+s21evXj2kp6ejXr16Ti/nlStXMHLkSBQWFqJfv35Yt24dBg4caHBMcHAwnnrqKSxcuBCSJGH16tWYNm2a08umLz09HT/99BN8fX1RVlaGr776yqXvT2SLDRs24N///jcA4MUXX8QPP/xg9H9uvXr18Omnn+LFF18EALzxxhvIzs52eVmratmyJaZPnw4AOH78OJYsWeLw9+A1m214zWZIUUWvpKTE0eUgNxo6dKjuZ3P9nV1l6NChSEhIQElJCcaPH6+KPtG7d++GEAJJSUkICwuz6Zx169bh2LFjCAgIwJgxY4z29+nTB40bN0ZhYSEWL17s6CLXWMwmz3ft2jUcO3YMACx2f6pTpw7uvPNOAMCWLVtcUTQjL7zwAs6cOYOwsDB89913CAoKMntsnz59MHz4cADA+++/D41G46piApC7hDVp0gQAsHfvXpe+NzGbrBFC4JFHHkFFRQU6deqEV155xeLxL7zwAho2bAiNRoP333/fRaW0bODAgboM2Lx5s9Pe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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_{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",
    "    p0 = [1.0, 2.0, 1.0]\n",
    "    popt, pcov = curve_fit(model, depth, mean_dimensionality_linear, 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_linear, yerr=std_dimensionality_linear, fmt='o', color=palette[1], markersize=5, capsize=5, capthick=1.5)\n",
    "    ax[i].plot(x_fit, y_fit, color=palette[1], linewidth=2)\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, 40)\n",
    "    # ax[i].set_yticks([9, 11, 13, 15, 17], [9, 11, 13, 15, 17])\n",
    "\n",
    "fig.tight_layout()\n",
    "fig.savefig(path_figure, transparent=True)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "cab33154",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA3oAAAEiCAYAAACvEaDLAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8g+/7EAAAACXBIWXMAAA9hAAAPYQGoP6dpAACCt0lEQVR4nO3dd3xT5eIG8Od07wW0tEApo8wyBZnKVoaiLOEKCs6f93od13GvG0UFBVy4JzjudV0H4FUcCCJo2RvK3tDBKKW7Sd7fHy9JkzbzJGlOkuf7+eTTNuec5E3bPDnve96hCCEEiIiIiIiIKGCE+LoARERERERE5Fms6BEREREREQUYVvSIiIiIiIgCDCt6REREREREAYYVPSIiIiIiogDDih4REREREVGAYUWPiIiIiIgowLCiR0REREREFGBY0SMiIiIiIgowrOgFKEVR7N7Cw8ORkpKCXr164bHHHkNxcbFPyztjxgwoioLo6Gjs3r3b4f6DBw+Goih48sknPVqOnTt3Wr3/ySefdPg7ffnll60e+9FHH6Ffv36Ii4tDfHw8evXqhddffx16vd6jZScKNNu2bcPdd9+Nzp07IykpCVFRUWjRogVGjRqF1157DRUVFfWOMWbJtGnTGrSser0eX331FSZPnoxWrVohKioK0dHRaNOmDW644QasXLnS5rHGPJsxY4ZLz2l8rbZuISEhiI2NRXZ2Nq6//nqsX7/evRdJ1EBKSkrw2muv4YorrkDTpk0RHh6O+Ph4dOvWDffddx/27t1r9Tjj//6iRYtcej7jZ3xWVpbNx7R2i4iIMJ1LPfLIIygoKFDxannOphbP2RwL83UByLuys7ORmppa7/6qqiocOHAAGzduxMaNG7Fw4ULk5uaiRYsWPihlrcrKSsyYMQN//PEHQkNDG+x59+7di7vvvhulpaVYvXp1ve1bt24FAHTo0AGNGjWy+hjNmjWrd99dd92F1157zXRsaGio6Xe+ZMkSfPfddwgPD/fgKyEKDDNnzsQzzzwDg8GAhIQEtGnTBhERETh16hSWLVuGZcuWYe7cufj222/Rs2dPn5Z1z549mDx5siknjJUrnU6HQ4cO4ZNPPsEnn3yCSZMmYeHChYiNjfXo8yckJKBLly717jcYDCgoKMD+/fuxf/9+fP7553j77bdx6623evT5iTzpu+++w0033YTTp08DAFJSUtClSxecPXsWO3fuxLZt2/Daa69h5syZePTRRxusXNbOp2pqanDmzBls2rQJGzduxFtvvYUffvgBffr08dhzADxnq4vnbC4QFJAACABi4cKFNvfR6/Xi448/FuHh4QKAGDZsWMMVsI7p06ebygxAPPfcc3b3HzRokAAgZs6c6ZHnnzlzpgAgBgwYYHV7q1atBACRm5vr9GMuXLhQABCJiYni999/N92/YcMGkZ6eLgCIxx57zO2yEwWaDz74QAAQsbGx4ssvvxQ6nc5i+65du0Tfvn0FANG4cWNRWFho2nby5Emxe/ducfLkyQYp62+//SZiY2MFANGrVy/x/fffW2wvLy8XL730kmmfIUOGiJqaGot9jHk2ffp0l57bmJuDBg2yu9/u3btFt27dBAARHh4uDh486NLzEDWU+fPnm84DrrvuOrFjxw6L7SdPnhR/+9vfTPvU/Qx15tzHGuM5QMuWLettc+Yxt27dKpo3by4AiNatW4vKykqXnp/nbK7hOZvz2HUziIWEhGDatGl46KGHAADLly+32R2ioSiKAkC25u/atcunZTEqKSnB4cOHoSgKOnfu7NQxer0ezzzzDADg+eefx8CBA03bLrnkEnz00UcAgJdeegnnz5/3fKGJ/Nizzz4LAJg/fz4mTpxYr6W4Y8eOWLJkCVJTU3H69GksWLDAtC09PR0dOnRAenq618t55swZXH/99SgrK8MVV1yB33//HaNGjbLYJzo6Gvfeey++/fZbKIqCFStW4NVXX/V62cx16NABX375JUJDQ1FTU4P33nuvQZ+fyBlr1qzBv/71LwDA448/js8//7zeZ256ejpef/11PP744wCA2bNnY+PGjQ1e1rq6du2Kt99+GwBw8OBBfPfddx5/Dp6zOYfnbJZY0SNcffXVpu9t9XduKFdffTUyMzNRVVWFGTNmaKJP9LZt2yCEQFZWFuLi4pw65vfff8eBAwcQERGBG264od724cOHo23btigrK8OSJUs8XWQiv1VcXIwDBw4AgN3uT02aNMG1114LAFi7dm1DFK2exx57DCdOnEBcXBz+/e9/Iyoqyua+w4cPx3XXXQcAePHFF2EwGBqqmABkl7D27dsDAHbs2NGgz03kiBACt912G/R6Pfr06YNZs2bZ3f+xxx5DixYtYDAY8OKLLzZQKe0bNWqUKQNyc3O99jw8Z7OP52yWWNEjhITU/hsIIeptLykpwdNPP40ePXogPj4esbGx6NKlC2bOnGlzQPCJEydw9913o1u3bkhISEB8fDw6deqEe+65B4cPH7ZZlvj4eFNr8/r16zF37lxVr2nx4sUYM2YMUlNTERERgWbNmuH666/Hpk2bLPYztvo89dRTAGSLYt0B2ca+3tbGwNjy559/AgB69OiBmJgYq/sMGDAAAOxO0kAUbMzHPzhqFX/qqaewc+dOfPrpp6b7bE3GYhyAr9Pp8Nlnn6F///6Ij49HcnIyrrjiCtN7tqysDI8++ijatm2LyMhIpKWl4cYbb8TJkyctHq+yshIff/wxAOCWW25B48aNHb62J554Av/973+xYcMGi9xtKMbntJbzRL60evVq06QexitW9kREROCDDz7Azz//jHfeecfbxXOKoiiIj48HAFy4cMFrz8NzNp6zuYIVPcLnn38OQIbHpZdearEtLy8P3bp1wxNPPIHt27cjPT0d2dnZyMvLw6xZs9C9e3fk5eVZHHPgwAH07NkTr776Kg4cOICsrCy0atUKBw8exIIFC9CtWzds3rzZZnlGjBiB22+/HYCcOcmV1medTodp06bh2muvxffffw9FUdCtWzdUVlbi008/xaWXXmoaaAsAUVFRGDBggGlAc0JCAgYMGIDevXub9jGGRufOnbFkyRLccsstGDZsGK655hrMnj0bhYWF9cqxf/9+AECbNm1sltUYTL7uekGkJbGxsaYP1JkzZ2L69OlYtWqV1Zbipk2bolOnTjYH21vzj3/8A3/5y1+wf/9+tG3bFlVVVfj5558xZMgQrFixAn369MGcOXNgMBiQnZ2NwsJCfPzxx7j88stRXl5uepw///wTZWVlAGRmOaNTp06YMGEC0tLSnC6vp+zcudPU+t+vX78Gf34ie3755RcAQGhoKIYOHerUMcOHD8fw4cM9PrmRWufPn0dRUREAeHWSFJ6z8ZzNJb4cIEjeAycG9lZWVopXXnlFhIaGCgDi1ltvtdheWloq2rZtKwCIa665Rpw4ccK07dSpU2LMmDECgMjOzhbl5eWmbZMnTxYAxMSJE8WFCxdM9+fn54v+/fsLAOLKK6+0eC7jwN6pU6cKIYQoKSkRmZmZAoC45JJLbE5eUHdg70MPPSQAiObNm4tly5aZ7tfpdGLBggUiLCxMKIoifvrpJ4vj7A3svfTSSwUAER8fbzH42HiLj48X3377rcUxV111lQAg7rnnnnqPZ7RgwQIBQHTo0MHmPkTBaNOmTSIuLs7ifZaQkCBGjx4t5syZI3Jzc4Ver7d6bN0sMTJ/rOeee86UKceOHRMZGRkCgAgJCRGtWrUS69atMx33008/mTJy0aJFpvvfeOMN0+MdO3bMrdfr7clY/vjjD5GdnS0AiLS0NHH69Gn1hSXyguuuu04AEG3atHHrcZw597HG3clYhBDiiSeeMO27efNml56f52w8Z/MWXtELcLNnz8bAgQMtbv3790dOTg4SExNxzz33QK/XY/LkyRYTGgDAe++9h/3796Nnz5746quvkJGRYdrWtGlTfPnll2jZsiX27dtnsWaNsTVl6tSpFv2j09LS8Morr2DkyJHo1KmT3XLHx8fj/fffBwBs3LgRzz//vMPXWlhYiJdeegmA7AZw5ZVXmraFhobirrvuwn333QchBB577DGHjwfI6cmNrVNRUVF49913UVhYiMrKSuTm5mLkyJG4cOECJk2ahDVr1piOM7b82xuzEx0dbbEvEUk9evTA2rVrLQbEl5SU4Pvvv8fDDz+Mvn37Ij09HY899pjL75+RI0fiX//6F8LC5OpCzZs3x/Tp0wHI9/v7779v0To8YsQIXHbZZQBg0Y3o7Nmzpu+bNGni+ov0oM2bN9fL+YEDB6Jnz55IS0tD//79sW/fPmRlZeGHH35w6QooUUMwvp98/V5yVVVVFXbv3o1HH30Us2fPBgBMnjwZ3bt3V/V4PGeTeM7mOaoqeiNHjsQXX3yB6upqT5eHPGzfvn1Ys2aNxe3PP//Ezp07kZmZibvvvht//PEHPvvsM9M/sdE333wDAJgyZYrV9VGio6MxceJEAMDSpUtN92dnZwOQ/ewXL15ssahxr1698MMPPzg1eHr48OH4v//7PwDArFmzsH37drv7f//996iqqkKnTp1srqtlHGS7bt06q5fv66qoqMC9996L66+/HqtWrcKtt96KJk2aIDIyEn369MH//vc/XHnllaipqcF9991nOs74+zLOSGWNuNi33hdjdQIVsylwdOrUCb///js2b96MmTNnon///hbj9woLC/Hss8+ia9euOH78uNOPO2bMmHr3GbvkxMTEYNCgQfW2G0+YSkpKTPeZdxerqalx+vm9oaSkpF7Or1mzBps3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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_intrinsic_{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_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",
    "    ax[i].plot(depth, mean_dimensionality_nonlinear, color=palette[0])\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(8, 17)\n",
    "    ax[i].set_yticks([9, 11, 13, 15, 17], [9, 11, 13, 15, 17])\n",
    "    ax[i].set_title(dict_titles[model_name])\n",
    "\n",
    "fig.tight_layout()\n",
    "fig.savefig(path_figure, transparent=True)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a9beaeae",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "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
}
