{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "38f46bbc",
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "from sklearn.linear_model import Ridge\n",
    "from tqdm.auto import tqdm\n",
    "\n",
    "from src.utils import load_pickle"
   ]
  },
  {
   "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', 'silver']\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": "3e839d96",
   "metadata": {},
   "outputs": [],
   "source": [
    "model_name = 'resnet50'\n",
    "split = 'train'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "e9e5196b",
   "metadata": {},
   "outputs": [],
   "source": [
    "path_models = os.path.join('..', '..', 'models')\n",
    "assert os.path.exists(path_models)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "6eadd784",
   "metadata": {},
   "outputs": [],
   "source": [
    "path_model = os.path.join(path_models, f'{model_name}_activations.pickle')\n",
    "assert os.path.exists(path_model)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "d5f110e2",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Num. Labels: 8640\n"
     ]
    }
   ],
   "source": [
    "dict_activations = load_pickle(path_model)\n",
    "labels = np.array(['_'.join(x.split('.jpg')[0].split('_')[:-1]) for x in dict_activations['filenames']])\n",
    "num_labels = len(labels)\n",
    "print(f'Num. Labels: {num_labels}')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "b60b3cd0",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Number of layers: 126\n"
     ]
    }
   ],
   "source": [
    "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}')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "f46f3190",
   "metadata": {},
   "outputs": [],
   "source": [
    "depth = np.where(np.isin(dict_activations['layers'], layers))[0] / num_total_layers"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "5c9c1637",
   "metadata": {},
   "source": [
    "## Categories"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "b9def6fb",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "\"\\nfrom sklearn.model_selection import train_test_split  # <- added\\n\\nnp.random.seed(5656)\\nnum_subsample = 100\\ntotal_subsample = 10\\nnum_layers = len(activations.keys())\\n\\npipeline = Pipeline([\\n    ('scaler', StandardScaler()),\\n    ('lr', LogisticRegression(\\n        solver='lbfgs',\\n        max_iter=1000,\\n        random_state=2345\\n    ))\\n])\\n\\nscores = np.zeros((num_layers, total_subsample))\\n\\nfor i, layer in tqdm(enumerate(layers), total=num_layers):\\n    X_layer = activations[layer]\\n    for j in range(total_subsample):\\n        indices_subset = np.random.choice(\\n            X_layer.shape[1],\\n            num_subsample,\\n            replace=False\\n        )\\n        X_subset = X_layer[:, indices_subset]\\n\\n        X_train, X_test, y_train, y_test = train_test_split(\\n            X_subset, labels,\\n            test_size=0.2,\\n            stratify=labels,\\n            random_state=None\\n        )\\n\\n        pipeline.fit(X_train, y_train)\\n        scores[i, j] = pipeline.score(X_test, y_test)\\n\""
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "\"\"\"\n",
    "from sklearn.model_selection import train_test_split  # <- added\n",
    "\n",
    "np.random.seed(5656)\n",
    "num_subsample = 100\n",
    "total_subsample = 10\n",
    "num_layers = len(activations.keys())\n",
    "\n",
    "pipeline = Pipeline([\n",
    "    ('scaler', StandardScaler()),\n",
    "    ('lr', LogisticRegression(\n",
    "        solver='lbfgs',\n",
    "        max_iter=1000,\n",
    "        random_state=2345\n",
    "    ))\n",
    "])\n",
    "\n",
    "scores = np.zeros((num_layers, total_subsample))\n",
    "\n",
    "for i, layer in tqdm(enumerate(layers), total=num_layers):\n",
    "    X_layer = activations[layer]\n",
    "    for j in range(total_subsample):\n",
    "        indices_subset = np.random.choice(\n",
    "            X_layer.shape[1],\n",
    "            num_subsample,\n",
    "            replace=False\n",
    "        )\n",
    "        X_subset = X_layer[:, indices_subset]\n",
    "\n",
    "        X_train, X_test, y_train, y_test = train_test_split(\n",
    "            X_subset, labels,\n",
    "            test_size=0.2,\n",
    "            stratify=labels,\n",
    "            random_state=None\n",
    "        )\n",
    "\n",
    "        pipeline.fit(X_train, y_train)\n",
    "        scores[i, j] = pipeline.score(X_test, y_test)\n",
    "\"\"\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "b6a3640f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "1a80bade8a914d9bb50adfc698819c01",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/16 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import numpy as np\n",
    "from joblib import Parallel, delayed\n",
    "from sklearn.pipeline import Pipeline\n",
    "from sklearn.preprocessing import StandardScaler\n",
    "from sklearn.linear_model import LogisticRegression\n",
    "from sklearn.model_selection import train_test_split\n",
    "\n",
    "# ── CONFIG ────────────────────────────────────────────────────────────────\n",
    "RANDOM_SEED     = 5656\n",
    "NUM_SUBSAMPLE   = 50\n",
    "TOTAL_SUBSAMPLE = 10\n",
    "\n",
    "np.random.seed(RANDOM_SEED)\n",
    "layers    = list(activations.keys())\n",
    "n_layers  = len(layers)\n",
    "\n",
    "pipeline_classification = Pipeline([\n",
    "    ('scaler', StandardScaler()),\n",
    "    ('lr',     LogisticRegression(\n",
    "        solver='lbfgs',\n",
    "        max_iter=1000,\n",
    "        random_state=2345\n",
    "    ))\n",
    "])\n",
    "\n",
    "# ── WORKER ───────────────────────────────────────────────────────────────\n",
    "def process_layer(layer_name, labels, pipeline):\n",
    "    X_layer      = activations[layer_name]\n",
    "    layer_scores = np.empty(TOTAL_SUBSAMPLE, dtype=float)\n",
    "    \n",
    "    for j in range(TOTAL_SUBSAMPLE):\n",
    "        # 1) feature‐subsample\n",
    "        feat_idx = np.random.choice(\n",
    "            X_layer.shape[1],\n",
    "            NUM_SUBSAMPLE,\n",
    "            replace=False\n",
    "        )\n",
    "        X_sub = X_layer[:, feat_idx]\n",
    "\n",
    "        # 2) stratified 80/20 split\n",
    "        X_tr, X_te, y_tr, y_te = train_test_split(\n",
    "            X_sub, labels,\n",
    "            test_size=0.2,\n",
    "            stratify=labels\n",
    "        )\n",
    "\n",
    "        # 3) fit & eval\n",
    "        pipeline.fit(X_tr, y_tr)\n",
    "        layer_scores[j] = pipeline.score(X_te, y_te)\n",
    "\n",
    "    return layer_scores\n",
    "\n",
    "# ── PARALLEL RUN ────────────────────────────────────────────────────────\n",
    "# verbose=10 will print progress info to stdout\n",
    "results = Parallel(n_jobs=-1)(\n",
    "    delayed(process_layer)(layer, labels, pipeline_classification)\n",
    "    for layer in tqdm(layers)\n",
    ")\n",
    "\n",
    "# assemble into (n_layers, TOTAL_SUBSAMPLE)\n",
    "scores = np.vstack(results)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "343482a7",
   "metadata": {},
   "outputs": [],
   "source": [
    "mean_dimensionality = np.mean(scores, axis=1)\n",
    "std_dimensionality = np.std(scores, axis=1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "15306905",
   "metadata": {},
   "outputs": [],
   "source": [
    "dict_names = {\n",
    "    'resnet50': 'ResNet50',\n",
    "    'simclr': 'SimCLR',\n",
    "    'clip_resnet50': 'CLIP ResNet50'\n",
    "}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "a4dd6704",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 300x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "path_figure = os.path.join('svg', f'{model_name}_{split}_categories.svg')\n",
    "\n",
    "fig = plt.figure(figsize=(3, 3))\n",
    "ax = plt.gca()\n",
    "plt.plot(depth, mean_dimensionality, color=palette[-1], markersize=5)\n",
    "plt.errorbar(x=depth, y=mean_dimensionality, yerr=std_dimensionality, fmt='o', color=palette[-1], markersize=5, capsize=5, capthick=1.5)\n",
    "\n",
    "plt.xlabel('Relative Depth')\n",
    "plt.ylabel('Accuracy')\n",
    "\n",
    "plt.xlim(0, 1)\n",
    "\n",
    "plt.ylim(0, 1)\n",
    "plt.title('Categories')\n",
    "fig.tight_layout()\n",
    "fig.savefig(path_figure, transparent=True)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "3d4b5434",
   "metadata": {},
   "source": [
    "## Properties"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "cbd94bb4",
   "metadata": {},
   "outputs": [],
   "source": [
    "import src.utils as utils\n",
    "\n",
    "path_properties = os.path.join('..', '..', 'images', 'properties_THINGS.pickle')\n",
    "assert os.path.exists(path_properties)\n",
    "\n",
    "dict_properties = utils.load_pickle(path_properties)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "fb2df57c",
   "metadata": {},
   "outputs": [],
   "source": [
    "list_properties = ['arousal', 'manmade', 'precious', 'hold']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "7bb8b511",
   "metadata": {},
   "outputs": [],
   "source": [
    "path_results = os.path.join('..', '..', 'models', model_name)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "0d6b46c8",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "29241193eef7414d90050414156cf82a",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "arousal:   0%|          | 0/16 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "493472a6b79d42cc811ae970cf85b20c",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "manmade:   0%|          | 0/16 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "de60b0a9d22c4c23b953cbb090754d6c",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "precious:   0%|          | 0/16 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "5651c7c7492a4a0a8fb48f48175c068b",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "hold:   0%|          | 0/16 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "from scipy.stats import zscore\n",
    "\n",
    "results_properties = {}\n",
    "for name_property in list_properties:\n",
    "    path_output = os.path.join(path_results, f'{model_name}_{name_property}.pickle')\n",
    "\n",
    "    if os.path.exists(path_output):\n",
    "        print(f'Skipping for {name_property} {model_name}')\n",
    "        continue\n",
    "    \n",
    "    properties = dict_properties['properties'][name_property]\n",
    "    concepts = dict_properties['concepts']\n",
    "    \n",
    "    array_properties = np.zeros((len(labels),))\n",
    "    unique_concepts = np.unique(labels)\n",
    "    \n",
    "    for i, concept in enumerate(unique_concepts):\n",
    "        mask = labels == concept\n",
    "        array_properties[mask] = dict_properties['properties'][name_property]['mean'][np.where(concepts == concept)[0]]\n",
    "    \n",
    "    array_properties = zscore(array_properties)\n",
    "\n",
    "    pipeline_regression = Pipeline([\n",
    "    ('scaler', StandardScaler()),\n",
    "    ('lr',     Ridge(\n",
    "        max_iter=1000,\n",
    "        random_state=2345\n",
    "    ))\n",
    "    ])\n",
    "\n",
    "    results_properties[name_property] = Parallel(n_jobs=-1)(\n",
    "        delayed(process_layer)(layer, array_properties, pipeline_regression)\n",
    "        for layer in tqdm(layers, desc=name_property)\n",
    "    )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "42f31a37",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABLAAAAEiCAYAAADptysgAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8g+/7EAAAACXBIWXMAAA9hAAAPYQGoP6dpAABs2ElEQVR4nO3dd3hUVf4/8PdkkkkmmfSQ3giEkBAMvbuAIAoogiKyG1ywF+zL1wK7P6wUWddVV1FwBdQVy9rWgqsuZZfeJAEjEAKE9ISQhEwmPef3R565ZjJ9UubO5P16njzCvffcOZM4b04+99xzFUIIASIiIiIiIiIiIpnycHYHiIiIiIiIiIiILGEBi4iIiIiIiIiIZI0FLCIiIiIiIiIikjUWsIiIiIiIiIiISNZYwCIiIiIiIiIiIlljAYuIiIiIiIiIiGSNBSwiIiIiIiIiIpI1FrCIiIiIiIiIiEjWWMAiIiIiIiIiIiJZYwGLetzWrVuhUCigUChw3333Obs7srRz507pe9TS0uLs7hDJ3vnz56XPjEKhwEMPPWRTuz//+c9Sm9jY2B7upXtITEyEQqHA22+/7eyuELm8ztnV+cvb2xv9+vXDxIkTsWrVKly+fNnZXTZL3+cff/zR2V0hIhegz4zNmzdbPXbz5s3S8d3h6aefhkKhwKRJk+xqt2TJEigUCixatKhb+kFdxwIW9bh33nlH+vP777+P2tpaJ/aGiNzRp59+CiGE1eM++uijXugNEZF16enpmDhxosFXRkYG/Pz8sHfvXqxYsQJDhw7FmTNnnN1VIiIiWfB0dgfIvV24cAHbt29HSEgIBg0ahP379+Mf//gH7r33Xmd3jYjchKenJ4qLi7Fnzx6LV9bOnj2Lw4cP92LPiIjMe+211zBlyhST+3bu3IkbbrgBFy5cwOLFi7Fnz57e7ZwNfvnlFwBAfHy8k3tCRER9BWdgUY/atGkT2traMGHCBMyZMwcA8Oabbzq5V0TkTq666ioAwCeffGLxOP3sq+HDh/d4n4iIumLKlClYvXo1AGDv3r04cuSIk3tkbPDgwRg8eDB8fX2d3RUiIuojWMCiHiOEwJYtWwAAs2bNwoIFCwAAWVlZ2L9/vzO7RkRuRJ8t1m4j/Oijj+Dh4SEdT0QkZ/PmzZP+zHETERERC1jUg3bs2IFz587Bw8MDN9xwAwYMGIAxY8YAANavX2+yzZQpU6BQKLBt2zY899xziIiIgK+vL9LT03Hy5EnpuKKiIvzf//0f0tLS4OvrC41Gg2HDhuGZZ55BdXW10XmtLdzXcRH1zg4cOICFCxciJSUFarUawcHBGDduHNasWWN2Pa8zZ87gkUceQUZGBoKCguDl5YWwsDBcddVV2LhxI1pbW619+4jIRldeeSWioqJQVFSEvXv3mjzm1KlTyMrKwpQpUxAZGWnymJaWFrz33nu4/vrrERMTAx8fH2g0GgwaNAj33nsvTp8+bdRGn1nfffcdsrKysGDBAkRERMDb2xtJSUl49NFHUVFRYdROvzD6mTNn8P3332P69OkICgpCQEAAJk6ciG+++Ubq07p165Ceng61Wo3Q0FDceOONBnnYUUlJCVasWIExY8YgJCQEXl5eCAkJwYQJE/DSSy+hvr7ebLtly5Zh0KBBUKvViI+Px7Jly6wuIN3Y2IhXXnkF48ePR2BgINRqNVJSUvDYY4+hpKTEYlsisiwwMFD6s368Yes4qaysDI8//rg0TvL398fo0aPx0ksvoaGhwexr5uXl4bHHHpNmVgUEBGDChAnYuHEj2traDI61tIi73MdpROTa7M0YSxoaGvDKK69gxIgR8Pf3R1hYGBYuXIjc3Nye6Tx1jSDqIZmZmQKAuOqqq6Rtf/3rXwUA4ePjIy5dumTUZvLkyQKAmDhxogAgBgwYIAYNGiTi4uJES0uLEEKIH3/8UQQGBgoAwsvLSwwbNkwMGTJEeHh4CAAiLi5OZGdnG5x35cqV0nlN2bFjhwAgOn8kPv30U+Hp6SkAiLCwMDFy5EiRnJwsFAqFACCGDBkiLl++bNDmiy++EN7e3gKA0Gg04oorrhDp6enCz89Peo3f/e53Zl+/ubnZ9m8yUR917tw56TOTm5srHnjgAQFAPPzwwyaPf+aZZwQAsWHDBrFp0yYBQMTExEj7dTqdmDp1qnTOxMREMWrUKBEXFydt8/PzE0ePHjU4rz6zHnroIeHl5SU8PT1FWlqaGDBggNRu4MCBRjmRkJAgAIilS5cKACIoKEgMHz5c+Pv7CwBCoVCIzz77TOpTTEyMyMjIkHIuJCREFBUVGZxz3759IigoSMrYIUOGiGHDhkl5CUBceeWVUpbqHTt2TERFRQkAQqVSiREjRoj+/ftLGdevXz8BQGzcuNGgXXFxsRg2bJjU38TERDFixAjh4+Mj9XH37t32/miJ3FrH7NqxY4fFY48dOyYd+/777wshbBsn7d69W4SGhkrjpCFDhoi0tDRp7JKRkSFKSkqMXu+zzz4TGo1GypARI0aIpKQkqQ+ZmZmira1NOl6//YcffjA4j9zHaUTkHPrP8KZNm6weqx+rmSpXdGfGVFVViQkTJkivlZaWJoYOHSo8PDyEv7+/GDlypJR/JA8sYFGPqK6uFmq1WgAQ77zzjrS9rKxMGmj85S9/MWqnH5gBEGvXrpW2l5eXCyGEOH/+vDS4mjNnjigtLZWOycvLE+PHjxcARHx8vKiurpb2OTIwam1tlX6pe/HFFw1+6Tty5Ij0S93q1aul7ZcuXRLBwcECgLjvvvtEXV2dtE+r1YqHHnpIep0TJ06YfH0WsIis61zA+u9//ysAiNjYWINfsPTS0tKEl5eXqKysNFnA0mdEWFiYOHjwoEHbgwcPSlkwf/58g30dM2v27NmiuLhY2vfll18KpVIpAIiXX37ZoJ2+gAVAPPjgg0Kn0wkh2gdSV1xxhQAgPDw8RGhoqPjuu++kdseOHZOKXE8//bS0vaWlRSqazZ071+ACQVNTk1izZo30el9//bW0r7m5WaSlpUkXG8rKyqR93377rQgICJDadSxgtbW1SQO+SZMmiZMnT0r7qqurxe233y59P039okzUV9lTwPr9738vFZb14x1r46TCwkKpeHXXXXeJqqoq6ZgzZ86IsWPHSsXsjs6cOSNdaFu8eLHBGGrbtm3SmG7Dhg3SdlMFLLmP04jIebqjgNXdGXPnnXdK48eOFylPnTolhgwZYlDAJ3lgAYt6xPr166UreDU1NQb7rr32WgFApKSkGLXTD8wSEhJM/hJ6zz33CAAiPT1dNDY2Gu2/dOmSiIyMFADEc889J213ZGBUWloqbes4ANTbsGGDmDt3rsFg7ssvvxQajUZERkaaLEQ1NzcLlUolAIitW7eafH0WsIis61zAamtrEzExMQKA2LNnj8Gx2dnZAoCYNWuWEEKYLGBNnDhReHh4iNdee83k6z377LMmc0ufWeHh4aK+vt6o3fXXX2+y8KUvYKWlpYnW1laDfW+99Zb03jpeANBbsmSJNHDTO3LkiAgKChLe3t7i4sWLJt+DfiZFx1/mPvzwQwFABAcHm5wVu2XLFpMFrC+++EIAENHR0UKr1Rq1a2trk35Rfvzxx032h6gvslbA0ul04ujRo+Lee++VjnviiSek/dbGSY888ohRPnRUWloqFaa//fZbabv+9caNG2eUSUII8cILL0j79UwVsOQ+TiMi59F/Xu396qg7M6a4uFiatbVz506jc505c0Z4eXmxgCUzXAOLesSmTZsAAHPmzEFAQIDBvkWLFgFoX5Nmx44dJttPmDDB5DoHX3/9NQDg/vvvh0qlMtofHByM22+/HQDwxRdfONx/AAgLC0NwcDAAIDMzE/v27TNY/+Guu+7C559/jrvuukvaNmfOHNTW1uLs2bPw9PQ0OmdDQwNCQkIAADqdrkv9I6JfKRQKzJ8/H4Dx0wj1Tx9cuHCh2fa7d+9GQ0MD7r33XpP79U/ZMve5nT59Onx8fIy2p6amAoDZ9RhmzpwJDw/Df4oTExOlP8+aNcuoTXR0NAAYrE81YsQIVFVVoaqqCqGhoUZtGhsbTWaPfq2tG264Qcq7jn77298arMOj9/nnnwMA5s6dCz8/P6P9CoVCyvqvvvrKaD8RAVOnTpXWddJ/+fr6YsSIEdITm++8804899xzRm3NjZP0n03956+ziIgIXH311QAMP5v6P991111GmQQADzzwAE6cOIGdO3dafE9yH6cRkfMlJydj4sSJFr+Sk5NNtu3OjNm2bRva2tqQmJiIyZMnG+0fMGCAlJckH8a/YRN1UU5ODg4ePAjA9ABq3rx50Gg00Gq1WL9+PaZOnWp0TFRUlNG22tpaFBUVAQBGjhxp9vX1+06dOuVQ//WUSiXWrl2Lu+++G99++y2+/fZbBAcHY+rUqZgxYwZmz56N2NhYk23VajWys7Nx7NgxnD17Fnl5efj5559x4sQJNDc3A4DRYqhE1DULFizAK6+8gn/+85/4y1/+Iv1y9/HHH8PHxwdz58612N7Lyws1NTXYu3cvTp8+jbNnz+L06dP46aefUFZWBsD85zYmJsbkdrVaDaB9MXZT4uLijLZ1HJD169fPZD8BmHziolqtRm5uLg4fPoy8vDycPXsWP//8M7Kzs6WFmzu+B31Opqenm+yfl5cXhgwZYrQ4/okTJwC0/9KblZVlsm1VVRUA4PTp0xBCmPxlm6gvS09PNygQKxQK+Pj4IDQ0FFdccQXmzp2LtLQ0k21NjZO0Wi3y8/MBAM8++yxeeeUVk23Pnz8PANKi7w0NDdL4KiMjw2SbgIAADBkyxOL7caVxGhE5z/Lly7FkyRKLx2zevBm33XabwbbuzhhrYyAAGDZsGL799luL56HexQIWdbu///3v0p/nzJlj8dgvvvgCZWVliIiIMNiu/6Wvo46zDUzNCNDTz/jSarVd/qXprrvuQnJyMv7yl7/ghx9+QFVVFT777DN89tlnUCgUmD17NtavX28wQNq2bRtWrFiBn376yeBc0dHRWLBgAb799lvpFzsi6j7jx49HXFwcCgoKsH//fowfPx5Hjx5Fbm4ubrrpJvj7+5ttW1tbi6eeegqbN29GXV2dtF2lUmHEiBEYPnw4vvvuO7PtTV0F7MhUsQmAydlLHZmaCWHOgQMH8MQTT2DXrl0G28PCwjBr1iz89NNPOHfunME+fRZpNBqz5zU1M6umpgYAUFBQgIKCAov9am1tRW1trdFsXKK+7rXXXsOUKVMcamtqnKT/XAK/Fpkt0c8MrayslLZZygJrXGWcRkSuqbszxtExEDkXC1jUrZqbm/H+++8DAIKCgsz+ciaEQHFxMZqbm/H3v/8dy5cvt3rujr98dhykddYxjDoHlrlfIjv+wtrZlClTMGXKFNTX1+N///sfdu3ahX//+984cuQIvv76axQUFOCnn36CQqHAjh07cN1116GtrQ3jxo1DZmYmhg4ditTUVISHhwNon6nBAhZR99PfRvjyyy/jk08+wfjx4226fRBov4Vux44dUKvVeOyxxzBu3DgMGTIEycnJ8PLywsaNGy0WsJztl19+wdSpU1FfX4+0tDTcfvvtyMjIQGpqqjQ7bOLEiUYFrNDQUOTm5hoMCjurr6832qbP9tdeew0PPPBAN74TInJUxzHX8ePHLc4qMNeutrbW4dd3hXEaEbmu7siYjvRLLtg7BiLn4hpY1K2++eYblJeXAwB++OEHFBYWmvwqKiqSBlYbN2606Xa6gIAAae2XI0eOmD3u8OHDAGBw77R+ParGxkaTbYqLi422NTU14ZdffsGBAwcAtF/tnDFjBl544QUcPnwYW7duBQBkZWUhOzsbALB27Vq0tbXhqquuwu7du/HAAw9g8uTJUvGqsbERFy9etPpeicgxCxYsAAD885//hBACH3/8MTQaDWbPnm22zf79+6X1+L755hu89NJLuPnmm5GWlibdrldYWNjzne+CV155BfX19Rg8eDAOHTqEP/zh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0b66ujpUV1cjLi7OYvuqqiqT0+QKCwvh4eGBmJiYbu2zO+vqz8OSiIgIAEBtbW2X+ki24Wej65hP8sJ8ch/8bHQd80lemE/ug5+NrmM+yQvzyb109+eDBSw7aTQapKam4uDBg0b79E9DmDBhgtn2+icnmGp/8OBBpKenm1zgjEzr6s9j6dKlSExMRH5+vtG+nJwcAO3TUKnn8bPRdcwneWE+uQ9+NrqO+SQvzCf3wc9G1zGf5IX55F66+/PBApYDFi1ahPz8fHz44YfSNiEE1q1bB29vbyxcuNBs2wULFsDLywsvvviiwb2gW7duxYULF7BkyZKe7Lpb6srPIz4+Hvn5+fjrX/9qsP3kyZPYtGkThgwZglGjRvVU16kDfja6B/NJXphP7oGfje7BfJIX5pN74GejezCf5IX55D66/fMhyG46nU6kpaUJlUolli1bJjZs2CCmT58uAIh169ZJx+Xl5Yn33ntP7N2716D9008/LQCI6dOniw0bNohly5YJlUolRo8eLXQ6XW+/HZfXlZ9HXV2dGDZsmAAg5s+fL9avXy+efPJJERAQIAICAsThw4ed8ZbcxsqVKwUAsWPHDoPt/Gz0HOaTvDCf5Iv51PuYT/LCfJIv5lPvYz7JC/NJ3pyZUSxgOai8vFzceeedIjw8XKjVajFs2DDx7rvvGhyzadMmAUAsXrzYqP369eulD2VcXJx44IEHxKVLl3qp9+6nKz+Py5cvi8cff1wkJiYKT09P0a9fP7Fw4UJx6tSpXnwH7slcuPGz0bOYT/LCfJIn5pNzMJ/khfkkT8wn52A+yQvzSb6cmVEKIcw805CIiIiIiIiIiEgGuAYWERERERERERHJGgtYREREREREREQkayxgERERERERERGRrLGARUREREREREREssYCFhERERERERERyRoLWEREREREREREJGssYBERERERERERkayxgEVERERERERERLLGAhbJihDC2V1wC/w+EvUMfra6B7+PRN2Pn6vuwe8jUffj56p78PvIApbb2blzJxQKhdkvlUqFyMhIXH311fjss8+6/Hrnz5+HQqFAbGxsl87T2tqK119/HQ8//LDB9s2bN0OhUGDRokVdOn93ePrpp81+T4ODgzFixAj86U9/QmlpqdP6WFxcjEWLFmH79u0G26dMmQKFQoEff/zRST0jaseM6jnMKKKu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",
      "text/plain": [
       "<Figure size 1200x300 with 4 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "path_figure = os.path.join('svg', f'{model_name}_{split}_concepts.svg')\n",
    "\n",
    "fig, ax = plt.subplots(1, len(list_properties), figsize=(12, 3))\n",
    "\n",
    "for i, name_property in enumerate(list_properties):\n",
    "    accuray_property = np.vstack(results_properties[name_property])\n",
    "    mean_accuracy = np.mean(accuray_property, axis=1)\n",
    "    std_accuracy = np.std(accuray_property, axis=1)\n",
    "\n",
    "    ax[i].plot(depth, mean_accuracy, color=palette[-1], markersize=5)\n",
    "    ax[i].errorbar(x=depth, y=mean_accuracy, yerr=std_accuracy, fmt='o', color=palette[-1], markersize=5, capsize=5, capthick=1.5)\n",
    "\n",
    "    ax[i].set_xlabel('Relative Depth')\n",
    "    ax[i].set_xlim(0, 1)\n",
    "    ax[i].set_ylim(0, 1)\n",
    "    ax[i].set_ylabel(r'$R^2$')\n",
    "    ax[i].set_title(name_property.capitalize())\n",
    "\n",
    "# fig.suptitle('Concepts', fontsize=18)\n",
    "fig.tight_layout()\n",
    "fig.savefig(path_figure, transparent=True)\n",
    "\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "f0efe074",
   "metadata": {},
   "source": [
    "## Components"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "0a08b230",
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "\n",
    "path_images_pca = os.path.join('..', '..', 'images', 'subjects', f'images_train_pca_S1.pickle')\n",
    "assert os.path.exists(path_images_pca)\n",
    "\n",
    "dict_images_pca = pd.read_pickle(path_images_pca)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "99401d89",
   "metadata": {},
   "outputs": [],
   "source": [
    "list_components = [0, 1, 2, 3]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "d380801f",
   "metadata": {},
   "outputs": [],
   "source": [
    "def process_layer(layer_name, labels, pipeline):\n",
    "    X_layer      = activations[layer_name]\n",
    "    layer_scores = np.empty(TOTAL_SUBSAMPLE, dtype=float)\n",
    "    \n",
    "    for j in range(TOTAL_SUBSAMPLE):\n",
    "        # 1) feature‐subsample\n",
    "        feat_idx = np.random.choice(\n",
    "            X_layer.shape[1],\n",
    "            NUM_SUBSAMPLE,\n",
    "            replace=False\n",
    "        )\n",
    "        X_sub = X_layer[:, feat_idx]\n",
    "\n",
    "        # 2) stratified 80/20 split\n",
    "        X_tr, X_te, y_tr, y_te = train_test_split(\n",
    "            X_sub, labels,\n",
    "            test_size=0.2,\n",
    "        )\n",
    "\n",
    "        # 3) fit & eval\n",
    "        pipeline.fit(X_tr, y_tr)\n",
    "        layer_scores[j] = pipeline.score(X_te, y_te)\n",
    "\n",
    "    return layer_scores"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "d27da7ff",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array(['dog_12s.jpg', 'mango_12s.jpg', 'spatula_12s.jpg', ...,\n",
       "       'sword_09s.jpg', 'toilet_09s.jpg', 'cockroach_09s.jpg'],\n",
       "      dtype=object)"
      ]
     },
     "execution_count": 22,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "dict_images_pca['stimuli_info']['stimulus'].values"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "8d394cb7",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array(['acorn_01b.jpg', 'acorn_02n.jpg', 'acorn_03s.jpg', ...,\n",
       "       'zucchini_10s.jpg', 'zucchini_11s.jpg', 'zucchini_12s.jpg'],\n",
       "      dtype=object)"
      ]
     },
     "execution_count": 23,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "dict_activations['filenames']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "bd8cede4",
   "metadata": {},
   "outputs": [],
   "source": [
    "stimuli   = dict_images_pca['stimuli_info']['stimulus'].values\n",
    "filenames = dict_activations['filenames']\n",
    "\n",
    "# 1) build a lookup from stimulus → its index in your original stimuli array\n",
    "pos = { s:i for i,s in enumerate(stimuli) }\n",
    "\n",
    "# 2) turn your desired order (filenames) into an array of indices\n",
    "order = np.array([ pos[f] for f in filenames ])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "9fcf6250",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "a49fcf8ef1d84193b067f6aa1055ce02",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Component 0:   0%|          | 0/16 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "4933f7a0c1c649228ef661cbdb621db0",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Component 1:   0%|          | 0/16 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "9ed7a1a6a8dc462a9f062a385a3cc6b9",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Component 2:   0%|          | 0/16 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "65a054b350ca46a3a2755f7ca1ca15ba",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Component 3:   0%|          | 0/16 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "results_components = {}\n",
    "for component in list_components:\n",
    "    path_output = os.path.join(path_results, f'{model_name}_{component}.pickle')\n",
    "\n",
    "    if os.path.exists(path_output):\n",
    "        print(f'Skipping for {component} {model_name}')\n",
    "        continue\n",
    "    \n",
    "    label_component = dict_images_pca['images_transformed'][order, component]\n",
    "   \n",
    "    pipeline_regression = Pipeline([\n",
    "    ('scaler', StandardScaler()),\n",
    "    ('lr',     Ridge(\n",
    "        max_iter=1000,\n",
    "        random_state=2345\n",
    "    ))\n",
    "    ])\n",
    "\n",
    "    results_components[component] = Parallel(n_jobs=-1)(\n",
    "        delayed(process_layer)(layer, label_component, pipeline_regression)\n",
    "        for layer in tqdm(layers, desc=f'Component {component}')\n",
    "    )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "6804070a",
   "metadata": {},
   "outputs": [],
   "source": [
    "dict_title = {\n",
    "    0: 'First Component',\n",
    "    1: 'Second Component',\n",
    "    2: 'Third Component',\n",
    "    3: 'Fourth Component'\n",
    "}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "id": "2a54b63f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABLAAAAEiCAYAAADptysgAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8g+/7EAAAACXBIWXMAAA9hAAAPYQGoP6dpAACfgElEQVR4nOzdd3hUZfo38O+kTDKTSSW9kISQhBJIIBQpCq6CgusqKwouKGDv66prQxdcu9hXxbIiqAvWtez+1rqCitJLAoQ00kkPpM2kkMnz/pF3zs5kekkyk3w/1zUX4TynPJPMuc859zxFJoQQICIiIiIiIiIiclNeQ10BIiIiIiIiIiIiS5jAIiIiIiIiIiIit8YEFhERERERERERuTUmsIiIiIiIiIiIyK0xgUVERERERERERG6NCSwiIiIiIiIiInJrTGAREREREREREZFbYwKLiIiIiIiIiIjcGhNYRERERERERETk1pjAchMymcyuV3NzMwCgrKxMWlZcXDwoda2qqkJra6vD25eXl+Phhx/GWWedhdDQUPj6+iIsLAxnn302nn76aZw+fdqFtaXBptFoUFZWNtTVID25ubm44447MHHiRISEhMDf3x8JCQlYtGgRXnnlFXR0dAx1Fd3Kjh07pLja09Pj0D4aGhrw1FNPYd68eQgPD4evry9CQkIwY8YMPPzwwzh58qSLa02DqaenB4WFhUNdjRFl8+bNdt8ryWQyzJ8/H4Dj90sDeZ+VlJQEmUyGv//97w5tr9Vq8emnn2LZsmVITk6Gv78/FAoFUlJScNVVV2HHjh0urS8NvmPHjg11FagfR5/Z3Jmpz5mu/t9///2AHffbb7/F6tWrkZaWBqVSCT8/P4wePRpLly7FF198MWDHpcFx/PhxCCFcvl8fl++RnJKamorIyEir6/n4DP6frru7G4899hieffZZ5ObmIigoyK7te3t78dRTT2HdunXo6emBTCZDTEwMUlJSUFVVhZ07d2Lnzp149tlnsWXLFixevHiA3gkNlK1bt+Lee+/F+vXrcd111w11dQjAunXr8Nhjj6G3txdBQUFISUmBXC5HTU0Nvv76a3z99dd45pln8Pnnn2Pq1KlDXd1hYdOmTbjjjjugVqsBAJGRkcjMzERtbS3279+Pffv24YUXXsDLL7+Ma665ZohrS/b69ttvcccdd2Dp0qV47LHHhro6I0ZUVBTmzJljtLyiogKVlZXw8/PDtGnTjMonTZo0GNUbdAUFBVi2bBlycnIAAAEBAUhNTUVPTw9KS0vx/vvv4/3338fll1+Od955BwEBAUNcY7JHTU0N7r77bvz888+orKwc6uqQCe78zGarwsJC3HHHHWhvb8fOnTsH7bg1NTVYuXIlfvjhBwCAv78/EhMTIZfLUVJSgk8//RSffvop5s+fjw8//NCm3zO5j9bWVjz44IN444030NHR4fpzQJBbACAAiHfeeceu7bq7u8Xx48fF8ePHRXd398BU7v8rLS2V6llUVGTXtr29veJ3v/udACD8/PzEAw88IOrr6w3WOXjwoDjvvPMEAOHt7S2++eYbV1afBkFiYqIAIN56662hrgoJITZt2iQAiICAAPHxxx+Lnp4eg/K8vDxx1llnCQAiPDzc6JwcqbZv3y7FujNnzti17W233SYACJlMJm666SZRWlpqUF5UVCQuv/xyaf9///vfXVhzGgzz5s0TAMTatWuHuiokhFi3bp0AIBITEy2u5+g9zEDeZzl6zfzxxx9FQECAACCmTZsm/vOf/xiUazQa8cILL0jrnHvuuXbHMhpa77zzjgAg4uLihroq1I+jz2zuSBc/58yZY1Sme5/fffedS495/PhxERERIQCItLQ0sW3bNoP70zNnzohNmzaJyMhIAUBMnDhRtLS0uLQONLCcuY+2BbsQejhfX1+MGzcO48aNg6+v71BXx6ynn34aX375Jfz8/PDZZ5/hiSeeQEREhME6U6ZMwddff41zzz0XWq0Wa9askVowEJH9Hn/8cQDAs88+i6VLl8Lb29ugfPz48fjyyy8RGRmJxsZGvPzyy0NRzWHjgw8+wCuvvAKZTIa33noLGzduRFJSksE6Y8eOxUcffYSrrroKAHDHHXegqqpqCGpLRLZwt/uspqYm/OEPf4BarcbChQvx888/Y9GiRQbrKBQK3Hnnnfj8888hk8mwfft2/O1vfxuiGhMR9enq6sLy5cvR0NCAKVOmYNeuXVi+fLnB/amPjw/WrFmD//73v1AoFDh27BgefvjhIaw1uRsmsGjAVVVV4S9/+QsA4M477zS60dLn4+MjPQBWV1dj69atg1VNomGlubkZJ06cAADMnDnT7HoRERG49NJLAQB79uwZjKoNSxqNBrfeeisA4IorrsC1115rcf3nn38eAQEB0Gg02Lhx42BUkYiGgYceeggnT56ESqXCP/7xD/j7+5td9/zzz8cVV1wBoC/m9Pb2DlY1iYiMvPjii8jJyYGXlxfef/99hIWFmV03IyMDd9xxBwDgrbfecmr8ZRpmXN6mixwCB5ujmmsSr2sSet9994nPPvtMpKWlCblcLhITE8W2bduEEH1NzJ966ikxa9YsERERIfz8/MTo0aPFlVdeKXbu3GlwHF2Xif6v7du3W63jX//6V6lbYENDg03v6/333xd79+412eywoKBA3HTTTSIlJUXI5XIRFBQkZs6cKZ5//nmh0WiM1l+1apXURL+wsFD84Q9/EFFRUcLf31+MHz9ePPfcc6K3t1cIIcSnn34qzj77bBEYGCiUSqWYPXu2+L//+z+jfep+H5999pn49ddfxYIFC0RwcLAIDg4WZ511lti0aZPQarVm398nn3wiLrzwQhEeHi58fX1FdHS0+P3vfy/++9//mlxf9/vu6OgQ//znP8X8+fNFcHCwUCgUIisrSzz//PNmuzZ0dnaKF198UZx11lkiKChI+Pv7i7S0NPGnP/1JVFdXG62va/Y5c+ZM0d3dLZ599lkxefJkoVAoRHBwsPjNb34jPv/8c4NtdJ+3/q9169aZ/R3QwGpvb5f+Dn/9618trltTUyOOHTsmGhsbTZYfPnxYXH311SIhIUHI5XIRFhYmFi5cKD755BOL+/3pp5/ElVdeKUaPHi3kcrkIDw8Xv/3tb8X3339vcv1Tp06J9evXi6ysLBEQECAUCoUYN26cuPvuu01+VnVdLJYtWyba29vFQw89JNLS0oSfn58ICwsTv/3tb8VPP/1ktn7bt28XF198sYiOjhYKhUJMnz5dbN261aGmz++++660zaFDh2za5rPPPhM//fST6OzsNCqrqqoS99xzjxg/frxQKBQiICBAZGZmivXr14vTp08bra87B9euXStqamrETTfdJOLi4oSfn58YM2aMWLt2rejq6pLe9wUXXCBCQkKEv7+/mDJlitiyZYvRPnWx84UXXhDHjx8XS5YsEWFhYUKlUomsrCzx4osvio6ODrPv7/vvvxe///3vRXR0tPD19RXh4eHiwgsvFJ9++qnJ9XXdqY4fPy527NghFi9eLMLCwoSfn58YN26c+Mtf/iLa2tpMbtvT0yM2b94szj33XBEaGirkcrlISkoS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nHMONm/ebFSmUqlw1llnAYDBgLf6TSrteQgYNWoUHn74YQDAiy++aHJwS52Ojg6sWbMGvb29iI6Oxg033ACgL3t87rnnSvswpaSkBF9++SUAmBzYbiBs27YNGo3GaPmmTZvQ3d2NmJgYaYDURYsWwcfHB7W1tfjwww9N7u+VV15BT0+P2QEE7aEbmPiDDz4we5N7zTXXYNasWdINsbN0nxE+JA493UCN+/fvN3me6/v2229x6tQphIWFSef++PHjMXbsWAB9rfhM+eWXX3D22WdjwoQJ2L17t7SdrlvLpk2bTG63efNm/Pjjj9LnUvdZ3bJli8E3Tjrd3d147bXXADh/bisUCmkfGzduNLnOW2+9Zfd+vb298dxzzwEAPvzwQ4vJ/97eXtxwww1oa2uDQqHAn//8Z6lMN07Da6+9Jo37p+/06dPYsmULgMGLc//5z39MPrT9+9//RmVlJfz8/KS/4dy5cxEaGoqenh7pwbm/Dz74ADU1NZDJZLjwwgudqpvuuN9//73Zm8f7778fc+fOxfz5883e7NqDcY5soRv4+Msvv5TGa9L373//22IyxJwHHngA0dHRaG1txbXXXiuNu2TKF198ga1bt0rb6Vra6s6bvXv3mh2D64UXXgAAxMfH2z2BkCO0Wq3Ja5VGo8G7774LALj88sul5YMZKx29HjqDcWb40Z13X375JUpLS02uo3vGmTVrFkJCQgAA4eHhUrmp8Yl0k5k4YrA/Z9dddx0mTZoErVaLa665BqdOnTK77t69e/Hss88C6JsUKCoqCsDgP0/Z6u233zZa1tvbizfeeAOAYfwazPvewMBAqaX/yy+/bHKd0tJSzJ07F5MnT8bHH3/s1PEAx3MGNu/f5Xskj6CblemRRx7B119/bVC2c+dO6eFLf8Yq/T68uoHebHXXXXdh3rx56OrqwqJFi7Bu3TqjpMquXbtwzjnn4Ndff4Wvry/ef/99g2aP69evh4+PD7799lvp4U8nJycHixcvRmdnJzIzM6WuhwOtqqoKy5YtM+ga+fHHH0stS5544gnpJE5ISJAScjfccAM++eQTaZve3l5s3LgR69atAwA8/PDDds9O1N+yZcswadIkNDc344ILLjDIure1teGWW27B999/D5lMhgceeMCpY+noPiP2fj7I9RYsWCA9QF133XW48847jVpEdXZ24p133sEV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iTvuuAOHDx822Y1xsO9716xZg5ycHNxwww2IiYnB0aNHUVFRgfHjx+Pee+9Fbm6u063idVQqFT755BNkZmZCrVajpKTEbLdZR8iEYOdqInvNnz8fP/74I9auXYvHHntsqKtDRORyq1evxpYtW7BixQq8//77Q10dIhqGduzYIXW5O3PmjMMP4kREg62srExqOFFUVCSNlUcDy2NbYO3Zswfe3t4G/fat2bJlC6ZMmYKAgADExMTg1ltvNTlwmlarxQsvvIDx48dDoVAgKSkJa9eu5awiRGQTxicicleMT0TkzhijiMgSj0xgFRUVYcmSJXbNJvTkk09i9erVGDVqFJ555hmsWLECf//733HuuecaBa1bbrkFd911FyZOnIgXXngBCxcuxJNPPoklS5ZwNhAisojxiYjcFeMTEbkzxigissplo2kNkn/+858iNDRUGqDM1MDb/VVWVgq5XC4WLVoktFqttHzr1q0CgHj66aelZXv27BEAxI033miwjyeeeEIAEB9++KHL3gt5LmuDctLIxPhEw4kzA7SS+2F8Indky8QxNDIwRpGnsWVyEHI9j2qBddFFF+H3v/89YmJicOWVV9q83datW9Hd3Y0//elP8PL631u+8sorkZiYiHfeeUdatnnzZgAwmOoSAO688074+/sbrEtEpMP4RETuivGJiNwZYxQR2cqjElj5+fl44okncPDgQbtGyd+9ezcA4KyzzjIqmzFjBvLz89HS0iKtGxYWhtTUVIP1FAoFJk2ahD179jjxDmi42LFjB4QQHMCdJIxPNNxs3rwZQggO4D4MMD6Ru5o/fz6EEBBCcAD3EYwxijxRUlKSFL84gPvg8agrRV5eHvz8/OzerqqqCiEhIQgMDDQqi4+PB9A3i0BmZiaqqqowevRok/uJj4/Hvn370NLSguDgYJPrqNVq6WchBDQaDQICAqBUKgd1Kk8iGlyMT0TkrhifiMiduXuMYnwich8elcByJLABQEtLC1QqlckypVIJ4H+BqaWlBenp6VbXNXcDZu447e3tCAgIsKveROQ5GJ+IyF0xPhGRO3P3GMX4ROQ+PKoLoaN0TfvMlQGAt7e33esSETmL8YmI3BXjExG5M8YoopHHo1pgOSowMBCNjY0myzQaDQBI2fbAwEBpmbV1TWlvb5d+VqvViIqKcqjORDQyMD4RkbtifCIidzZY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yK5duzTbLl++LImJiTJs2DAxmUwyZswYSUpKkhs3bmjqeQo3EZGSkhL57LPPZMSIETJo0CAJCgqSpKQkKSkpkby8PAEgcXFxmn327Nkj/v7+YjKZZN68eSLS/gcvOztbAEhoaOgbx1peXi7Jycni7+8v/fv3l9GjR0tsbKwUFRW1e55cXOHW+s9gMIjFYpGwsDDZtWuX/P3332220djYKIcOHZLQ0FAxm83i5eUlwcHBsmPHDqmrq9PUbTn2/Px8mTZtmgwYMEACAwNl/fr18vTpU7f2a2pqJD4+Xm3b9QXSF8ON9IkZ5RkzihlF7x7zyTPmE/OJ3j3mk2fMp76XT4pIF9e5JKIedeLECaxcuRJ2u73TDwUkIuppzCgi0ivmExHpFfOpe/gMLCIiIiIiIiIi0jVOYBERERERERERka5xAouIiIiIiIiIiHSNz8AiIiIiIiIiIiJd4xVYRERERERERESka5zAIiIiIiIiIiIiXeMEFhERERERERER6RonsIiIiIiIiIiISNc4gUVERERERERERLrGCSwiIiIiIiIiItI1TmAREREREREREZGucQKLiIiIiIiIiIh0jRNYRERERERERESka/8BhLA9iLwmC8cAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 1200x300 with 4 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "path_figure = os.path.join('svg', f'{model_name}_{split}_components.svg')\n",
    "\n",
    "fig, ax = plt.subplots(1, len(list_components), figsize=(12, 3))\n",
    "\n",
    "for i, component in enumerate(list_components):\n",
    "    accuracy_components = np.vstack(results_components[component])\n",
    "    mean_accuracy = np.mean(accuracy_components, axis=1)\n",
    "    std_accuracy = np.std(accuracy_components, axis=1)\n",
    "\n",
    "    ax[i].plot(depth, mean_accuracy, color=palette[-1], markersize=5)\n",
    "    ax[i].errorbar(x=depth, y=mean_accuracy, yerr=std_accuracy, 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(r'$R^2$')\n",
    "    ax[i].set_xlim(0, 1)\n",
    "    ax[i].set_ylim(0, 1)\n",
    "    ax[i].set_title(dict_title[component])\n",
    "\n",
    "# fig.suptitle(dict_names[model_name], fontsize=18)\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
}
