{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fe5a643b",
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "import nibabel.freesurfer.io as fsio\n",
    "import pandas as pd\n",
    "import seaborn as sns\n",
    "from tqdm import tqdm\n",
    "from scipy.stats import zscore\n",
    "\n",
    "from src.dimensionality import Dimensionality"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "298bf7de",
   "metadata": {},
   "outputs": [],
   "source": [
    "def zscore_betas(betas, df_stimuli):\n",
    "    assert np.isnan(betas).sum() == 0, 'Betas contain NaN values'\n",
    "    indices_session = df_stimuli['Session'].values\n",
    "    betas_zscore = np.zeros_like(betas)\n",
    "    sessions = np.unique(indices_session)\n",
    "    num_sessions = len(sessions)\n",
    "    for i_session in tqdm(sessions, total=num_sessions):\n",
    "        indices = np.where(indices_session == i_session)[0]\n",
    "        betas_zscore[indices] = zscore(betas[indices], axis=0)\n",
    "    betas_zscore = np.nan_to_num(betas_zscore)\n",
    "    return betas_zscore"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "0c1391bc",
   "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": 4,
   "id": "51757aa8",
   "metadata": {},
   "outputs": [],
   "source": [
    "path_datasets = os.path.join(..., 'datasets')\n",
    "assert os.path.exists(path_datasets)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "3f19a720",
   "metadata": {},
   "outputs": [],
   "source": [
    "dataset = 'THINGS-fMRI'\n",
    "subject_id = 'S1'\n",
    "num_neighbors = 50\n",
    "split = 'train'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "541847a2",
   "metadata": {},
   "outputs": [],
   "source": [
    "path_dataset = os.path.join(path_datasets, dataset)\n",
    "assert os.path.exists(path_dataset)\n",
    "\n",
    "path_processed = os.path.join(path_dataset, 'processed', subject_id)\n",
    "assert os.path.exists(path_processed)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "b81bc883",
   "metadata": {},
   "outputs": [],
   "source": [
    "path_stimuli = os.path.join(path_processed, 'stimuli',  f'{subject_id}_stimuli.csv')\n",
    "assert os.path.exists(path_stimuli)\n",
    "\n",
    "df_stimuli = pd.read_csv(path_stimuli)\n",
    "indices_split = df_stimuli[df_stimuli['Split'] == split]['Trial'].values"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "2c3b068b",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 12/12 [00:10<00:00,  1.13it/s]\n"
     ]
    }
   ],
   "source": [
    "path_betas_left = os.path.join(path_processed, 'betas', 'surf', f'{subject_id}_betas_surf_lh.npy')\n",
    "assert os.path.exists(path_betas_left), path_betas_left\n",
    "\n",
    "betas_left = np.load(path_betas_left)\n",
    "betas_left = zscore_betas(betas_left, df_stimuli)\n",
    "betas_left = betas_left[indices_split]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "b743728f",
   "metadata": {},
   "outputs": [],
   "source": [
    "path_annot_left = os.path.join(path_dataset, 'freesurfer', subject_id, 'label', f'lh.visual.annot')\n",
    "assert os.path.exists(path_annot_left)\n",
    "\n",
    "labels_vertices_left, _, names_vertices_left = fsio.read_annot(path_annot_left)\n",
    "\n",
    "names_vertices_left = np.array([name.decode('utf-8').split('_')[1] for name in names_vertices_left])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "1a01d967",
   "metadata": {},
   "outputs": [],
   "source": [
    "unique_labels_left = np.unique(labels_vertices_left)[1:]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "21764c19",
   "metadata": {},
   "outputs": [],
   "source": [
    "num_subsample = 100\n",
    "total_subsample = 100"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "a3f705ca",
   "metadata": {},
   "outputs": [],
   "source": [
    "primary_rois = ['V1']\n",
    "early_rois   = ['V2','V3','V4']\n",
    "ventral_rois = ['V8','FFC','PIT','VMV1','VMV3','VMV2','VVC']\n",
    "dorsal_rois  = ['V6','V3A','V7','IPS1','V3B','V6A']\n",
    "lateral_rois = ['MST','LO1','LO2','MT','PH','V4t','FST','V3CD','LO3']\n",
    "\n",
    "indices_primary = np.array([i for i, area in enumerate(names_vertices_left) if area in primary_rois])\n",
    "indices_early = np.array([i for i, area in enumerate(names_vertices_left) if area in early_rois])\n",
    "indices_ventral = np.array([i for i, area in enumerate(names_vertices_left) if area in ventral_rois])\n",
    "indices_dorsal = np.array([i for i, area in enumerate(names_vertices_left) if area in dorsal_rois])\n",
    "indices_lateral = np.array([i for i, area in enumerate(names_vertices_left) if area in lateral_rois])\n",
    "\n",
    "dict_indices = {'Primary': indices_primary,\n",
    "                'Early': indices_early,\n",
    "                'Ventral': indices_ventral,\n",
    "                'Dorsal': indices_dorsal,\n",
    "                'Lateral': indices_lateral}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "87148803",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "4847: 100%|██████████| 100/100 [00:00<00:00, 102.69it/s]\n",
      "8315: 100%|██████████| 100/100 [00:00<00:00, 135.18it/s]\n",
      "3225: 100%|██████████| 100/100 [00:00<00:00, 145.19it/s]\n",
      "2527: 100%|██████████| 100/100 [00:00<00:00, 145.02it/s]\n",
      "3805: 100%|██████████| 100/100 [00:00<00:00, 141.25it/s]\n"
     ]
    }
   ],
   "source": [
    "np.random.seed(5576)\n",
    "name_estimator = 'lpca'\n",
    "\n",
    "dims_areas_linear_left = []\n",
    "\n",
    "for i_area, (name, indices) in enumerate(dict_indices.items()):\n",
    "    indices_area = np.argwhere(np.isin(labels_vertices_left, indices))\n",
    "\n",
    "    for i_sample in tqdm(range(num_subsample), desc=f'{len(indices_area)}'):\n",
    "        sampled_indices = np.random.choice(indices_area.shape[0], size=num_subsample, replace=False)\n",
    "        \n",
    "        dims_areas_linear_left.append({'Area': name,\n",
    "                                       'Effective Dimensionality': Dimensionality.effective_dimensionality(betas_left[:, indices_area[sampled_indices]])})\n",
    "\n",
    "df_dims_areas_linear_left = pd.DataFrame(dims_areas_linear_left)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "id": "68b9baf2",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAh4AAAEdCAYAAABDv255AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8g+/7EAAAACXBIWXMAAA9hAAAPYQGoP6dpAABPYUlEQVR4nO3dd3hUZfr4//dJmySTRgohtEAITXqTUIOANIGIsCIuUl1XdFWqP5cVld2vHf0suqAooDQFV6QIioB06QgKSBEIEEICBEggk548vz+yGTNkQiYnk8kk3C+vXDLnPOecO1NO7nmqppRSCCGEEEI4gEtFByCEEEKIe4ckHkIIIYRwGEk8hBBCCOEwkngIIYQQwmEk8RBCCCGEw0jiIYQQQgiHkcRDCCGEEA4jiYcQQgghHEYSDyGEEEI4TKVIPHJzc+nWrRuaphXZd/HiRUaNGkXNmjUxGo1ERUWxdu3aCohSCCGEECWpFInHG2+8wa5du4psT0xMpHv37qxevZpx48Yxa9YscnJyiImJ4YsvvqiASIUQQghxN5qzr9Wyf/9+unTpgqurK5mZmRQOd8KECcybN49du3bRuXNnADIyMoiKiiI+Pp7z589jNBorKnQhhBBC3MGpazxSU1P585//TL9+/YiKirLYl5uby9KlS+nUqZM56QDw9PTkhRdeICkpiXXr1jk6ZCGEEELchVMnHi+88AIpKSnMnz+/yL7jx4+TmppaJCEB6NixIwD79u0r9twmk8n8k5qaytWrVzGZTDh5BZAQQghRqbnpOSgzMxODwWDvWCx88803LFy4kNWrVxMaGlpk/6VLlwCoW7dukX21a9cGIDY2ttjz+/j4WN2empoqzTNCCCFEOdFV41GjRg2eeeYZ9u/fb+94AIiPj+cvf/kL48ePJyYmxmqZlJQUwHoC4e3tDeTXagghhBDCeehuavn444/p1KkTzZs357333uPKlSt2CUgpxejRowkICODf//73XcsV/r+1fa6ursUen5qaav6xV+xCCCGEuDtdiUdiYiJffPEFffr04dSpU0ybNo06deoQExPD6tWrycnJ0R3Q+++/z5YtW/i///s/MjIySEpKIikpiezsbACSkpK4efMmvr6+AKSlpRU5R8E2f3//Yq9jNBotfoQQQghR/nQlHgaDgccee4zvv/+eixcv8uabbxIZGcm3337L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+HHS09Pp0KED7du359VXX+XWrVuMHj2a1atX88MPP9C7d2+73XcqixUrVrB+/XpeeumlIkmGLTPgFnxOMjIyrH55XbNmDYGBgSV+wZk4cSLJyckcO3bMokktOzubpKQkqlevbsNvU/6kj0cVlp6ejslkol69ehYf/pycHGbNmmX+t63GjRvH7du3mTJlCllZWZWumcVWSUlJADRv3twi6UhKSmLBggVA6Z63O40fPx6lFP/4xz+4fPlypX4eC2o3Dh06xOLFi7l27ZrF3B3t27enXr16fP755+bq/gKffPIJjz76KAsXLtR17YL+N7ZU2xe8pnfOCrxy5UrzUEenGWpoB9u3b2fu3Lncd999DBs2jDZt2hAREcHSpUs5ceKERdnPPvuMs2fPMnTo0LueU9M0hg4dyqBBg0hJSTFv9/PzMz+vbm5udr/vVAbFvb/OnDnD119/DVj+zne+d0NDQ+natSvff/99keRsw4YNPPzww7z11ls2xWE0Gosk8x988AHp6elO87xLjUcVVq1aNbp3787GjRsZO3YsXbp04caNGyxbtoyTJ0/i4uJCcnKyzecbNGgQISEhLF68mKZNm3L//feXX/DlZM+ePXf91uDj40PXrl0JCgri9ddfJzU1lYiICM6dO8fChQvNN9zSPG93atOmDa1bt2bx4sVUq1aNmJgY3edyBmPGjOHVV19l6tSpBAYGWnR4dnV15dNPP2XgwIG0a9eOp59+mgYNGnDgwAEWLlxIgwYNmDFjhq7rFvRFePXVV4mOjr5rM2dMTAxr1qyhX79+PPnkk3h4eLB9+3ZWrFiBl5cX6enpJCcnExwcrCuWilL4/ZyXl8fNmzfZs2cPK1eupHr16nzzzTfm/fPnz2fAgAF07NiRCRMmUL9+ffbt28eiRYuoV6+eTX/YXnvtNR5//HE6derE2LFjqVatGr/88guffPIJrVu3pnfv3ri5udn1vuMs3n//fZYvX2513wsvvIDBYOCFF17g7NmzhIWFcezYMRYuXGieV6nw72ztvTt37ly6d+9Or169eOqpp2jevDknT57k448/JigoyJy03U1MTAz//Oc/6dOnD4899hh5eXl8//33rF+/Hi8vL4uEsUI5fBxNFWTr0LYCxQ0fK244bXh4eJGytm5PTExUY8eOVTVr1lQGg0GFh4eroUOHqiNHjqjOnTsrPz8/ZTKZ7hpXYZMnT1aAeuedd2z6XZ2FrcNpC567Q4cOqT59+qjAwEBlNBpV48aN1d/+9jcVGxurPDw8VK9evcznBlR0dHSx17Q2XO2DDz5QgHrmmWfK6Td2rAEDBihAPf/881b3Hz58WA0bNkyFhIQoDw8PFRERoZ577jmVkJBgUa40z+WRI0dU8+bNlbu7u+rdu7dS6u7v4Tlz5qimTZsqT09PFRISoqKiotT8+fPVvHnzzHMqKFW5htMW/tE0Tfn6+qq2bduql19+WSUlJRU57pdfflHDhg1TwcHBysPDQ0VGRqpp06YVmYuluPuLUvlDk6Ojo82vZYMGDdTUqVMtzmHv+05FKhhOe7efmzdvqs2bN6suXbooPz8/5efnp5o1a6b+8Y9/qMOHDytAjR8/3nxOa+9dpZQ6e/asGjNmjAoLC1Pu7u6qbt26atSoUer333+3iKm41yc7O1v985//VA0aNFAGg0GFhYWpHj16qFWrVqnp06crQO3cuVMpVbHDaTWlqmB3blFupk6dygcffMDFixdtHskhivrPf/7Dc889x8GDB2nXrl1FhyOEEA4jiYew2c2bN2ncuDE9evSostMeO0JmZibt2rXD29ub/fv3V3Q4QgjhUNLHQ5Ro1apVfPXVV+zZs4ebN2+a174QpbN7924+/PBDjhw5wsmTJ1m3bl1FhySEEA4niYcokZeXF99//z3+/v4sW7aM1q1bV3RIlZKvry+bN2/GxcWF2bNn89BDD1V0SEII4XDS1CKEEEIIh5F5PIQQQgjhMJJ4CCGEEMJhJPEQQgghhMNI4iGEEEIIh5HEQwghhBAOI4mHEEIIIRxGEg8hhBBCOIwkHkIIIYRwmP8fuERnlL2heGYAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 600x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "group_colors = {\n",
    "    'Primary': palette[0],\n",
    "    'Early':   palette[1],\n",
    "    'Ventral': palette[2],\n",
    "    'Dorsal': palette[3],\n",
    "    'Lateral':   palette[4]\n",
    "}\n",
    "\n",
    "os.makedirs('svg', exist_ok=True)\n",
    "path_figure = os.path.join('svg', f'figureS10_effective_lh_{subject_id}_{split}_{num_neighbors}.svg')\n",
    "\n",
    "fig = plt.figure(figsize=(6, 3))\n",
    "ax = plt.gca()\n",
    "\n",
    "sns.boxplot(x='Area', y='Effective Dimensionality', data=df_dims_areas_linear_left, palette=group_colors, showfliers=False, **seaborn_props, ax=ax)\n",
    "sns.stripplot(x='Area', y='Effective Dimensionality', data=df_dims_areas_linear_left , palette=group_colors, zorder=-1, ax=ax)\n",
    "ax.set_xlabel('')\n",
    "ax.set_ylim(5, 40)\n",
    "fig.savefig(path_figure, transparent=True)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "adf019c9",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 12/12 [00:09<00:00,  1.21it/s]\n"
     ]
    }
   ],
   "source": [
    "path_betas_right = os.path.join(path_processed, 'betas', 'surf', f'{subject_id}_betas_surf_rh.npy')\n",
    "assert os.path.exists(path_betas_right), path_betas_left\n",
    "\n",
    "betas_right = np.load(path_betas_right)\n",
    "betas_right = zscore_betas(betas_right, df_stimuli)\n",
    "betas_right = betas_right[indices_split]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "b801a524",
   "metadata": {},
   "outputs": [],
   "source": [
    "path_annot_right = os.path.join(path_dataset, 'freesurfer', subject_id, 'label', f'rh.visual.annot')\n",
    "assert os.path.exists(path_annot_right)\n",
    "\n",
    "labels_vertices_right, _, names_vertices_right = fsio.read_annot(path_annot_right)\n",
    "\n",
    "names_vertices_right = np.array([name.decode('utf-8').split('_')[1] for name in names_vertices_right])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "37ba2755",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "4946: 100%|██████████| 100/100 [00:00<00:00, 125.80it/s]\n",
      "8239: 100%|██████████| 100/100 [00:00<00:00, 144.14it/s]\n",
      "4027: 100%|██████████| 100/100 [00:00<00:00, 139.22it/s]\n",
      "2976: 100%|██████████| 100/100 [00:00<00:00, 151.00it/s]\n",
      "4580: 100%|██████████| 100/100 [00:00<00:00, 147.50it/s]\n"
     ]
    }
   ],
   "source": [
    "np.random.seed(4321)\n",
    "\n",
    "dims_areas_linear_right = []\n",
    "\n",
    "for i_area, (name, indices) in enumerate(dict_indices.items()):\n",
    "    indices_area = np.argwhere(np.isin(labels_vertices_right, indices))\n",
    "\n",
    "    for i_sample in tqdm(range(num_subsample), desc=f'{len(indices_area)}'):\n",
    "        sampled_indices = np.random.choice(indices_area.shape[0], size=num_subsample, replace=False)\n",
    "        \n",
    "        dims_areas_linear_right.append({'Area': name,\n",
    "                                  'Effective Dimensionality': Dimensionality.effective_dimensionality(betas_right[:, indices_area[sampled_indices]])})\n",
    "\n",
    "df_dims_areas_linear_right = pd.DataFrame(dims_areas_linear_right)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "id": "e62ff724",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 600x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig = plt.figure(figsize=(6, 3))\n",
    "ax = plt.gca()\n",
    "\n",
    "path_figure = os.path.join('svg', f'figureS10_effective_rh_{subject_id}_{split}_{num_neighbors}.svg')\n",
    "\n",
    "sns.boxplot(x='Area', y='Effective Dimensionality', data=df_dims_areas_linear_right, palette=group_colors, showfliers=False, **seaborn_props, ax=ax)\n",
    "sns.stripplot(x='Area', y='Effective Dimensionality', data=df_dims_areas_linear_right , palette=group_colors, zorder=-1, ax=ax)\n",
    "ax.set_xlabel('')\n",
    "ax.set_ylim(5, 40)\n",
    "fig.savefig(path_figure, transparent=True)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "f62227e3",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(8640, 279601)\n"
     ]
    }
   ],
   "source": [
    "betas = np.hstack((betas_left, betas_right))\n",
    "print(betas.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "35adf1ae",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "9793: 100%|██████████| 100/100 [00:29<00:00,  3.35it/s]\n",
      "16554: 100%|██████████| 100/100 [00:06<00:00, 15.89it/s]\n",
      "7252: 100%|██████████| 100/100 [00:17<00:00,  5.61it/s]\n",
      "5503: 100%|██████████| 100/100 [00:01<00:00, 89.20it/s]\n",
      "8385: 100%|██████████| 100/100 [00:01<00:00, 70.98it/s]\n"
     ]
    }
   ],
   "source": [
    "np.random.seed(9876)\n",
    "name_estimator = 'lpca'\n",
    "\n",
    "dims_areas_linear = []\n",
    "\n",
    "for i_area, (name, indices) in enumerate(dict_indices.items()):\n",
    "    indices_area_left = np.argwhere(np.isin(labels_vertices_left, indices))\n",
    "    indices_area_right = betas_left.shape[1] + np.argwhere(np.isin(labels_vertices_right, indices))\n",
    "    indices_area = np.concatenate((indices_area_left, indices_area_right), axis=0)\n",
    "\n",
    "    for i_sample in tqdm(range(num_subsample), desc=f'{len(indices_area)}'):\n",
    "        sampled_indices = np.random.choice(indices_area.shape[0], size=num_subsample, replace=False)\n",
    "        \n",
    "        dims_areas_linear_left.append({'Area': name,\n",
    "                                  'Effective Dimensionality': Dimensionality.effective_dimensionality(betas[:, indices_area[sampled_indices]])})\n",
    "\n",
    "df_dims_areas_linear = pd.DataFrame(dims_areas_linear_left)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "id": "2b25e773",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 600x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig = plt.figure(figsize=(6, 3))\n",
    "ax = plt.gca()\n",
    "\n",
    "path_figure = os.path.join('svg', f'figureS10_effective_both_{subject_id}_{split}_{num_neighbors}.svg')\n",
    "\n",
    "sns.boxplot(x='Area', y='Effective Dimensionality', data=df_dims_areas_linear, palette=group_colors, showfliers=False, **seaborn_props, ax=ax)\n",
    "sns.stripplot(x='Area', y='Effective Dimensionality', data=df_dims_areas_linear , palette=group_colors, zorder=-1, ax=ax)\n",
    "ax.set_xlabel('')\n",
    "ax.set_ylim(5, 40)\n",
    "fig.savefig(path_figure, transparent=True)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f1eb80a4",
   "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
}
