{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "0b119b7e",
   "metadata": {},
   "source": [
    "### Random Forest Model Training with Betti Vectorization"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "47d6ddeb",
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import pandas as pd\n",
    "import numpy as np\n",
    "from tqdm import tqdm\n",
    "import random\n",
    "from sklearn.model_selection import RandomizedSearchCV\n",
    "from sklearn.ensemble import RandomForestClassifier\n",
    "from sklearn.metrics import plot_confusion_matrix, roc_auc_score\n",
    "import pickle\n",
    "import seaborn as sns\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "from src.utils import enrichment_factor"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "bc50db6c",
   "metadata": {},
   "source": [
    "## Target GCR"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "94acb9fc",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|████████████████████████████████████████████████| 15749/15749 [00:01<00:00, 9305.16it/s]\n"
     ]
    }
   ],
   "source": [
    "X, y = [], []\n",
    "path = \"../data/DUDE-Diverse_TopologyFeatures/atom_weight_superlevel_betti_partial_charge_superlevel_betti_bond_strength_superlevel_betti/target_gcr/\"\n",
    "\n",
    "for file in tqdm(os.listdir(path)):\n",
    "    if file.endswith('pkl'):\n",
    "        with open(os.path.join(path, file), 'rb') as f:\n",
    "            X.append(pickle.load(f))\n",
    "        target_label = 0 if \"active\" in file else 1\n",
    "        y.append(target_label)\n",
    "\n",
    "active_ind = [i for i, label in enumerate(y) if label == 0]\n",
    "decoy_ind = [i for i, label in enumerate(y) if label == 1]\n",
    "\n",
    "# shuffle the lists\n",
    "random.shuffle(active_ind)\n",
    "random.shuffle(decoy_ind)\n",
    "\n",
    "# Use 90% of the actives for training \n",
    "num_actives = len(active_ind)\n",
    "num_training = int(0.9 * num_actives)\n",
    "active_training_ind = active_ind[:num_training] \n",
    "active_test_ind = active_ind[num_training:] \n",
    "\n",
    "# Use same number of decoys as actives in training (avoid imbalance)\n",
    "decoy_training_ind = decoy_ind[:num_training] \n",
    "decoy_test_ind = decoy_ind[num_training:] \n",
    "\n",
    "# training and test index lists\n",
    "training_ind = active_training_ind + decoy_training_ind\n",
    "test_ind = active_test_ind + decoy_test_ind\n",
    "\n",
    "train_x, train_y = [X[i] for i in training_ind], [y[i] for i in training_ind]\n",
    "test_x, test_y = [X[i] for i in test_ind], [y[i] for i in test_ind]\n",
    "\n",
    "# flatten\n",
    "train_x = [x.flatten() for x in train_x]\n",
    "test_x = [x.flatten() for x in test_x]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5230175d",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Fitting 3 folds for each of 100 candidates, totalling 300 fits\n"
     ]
    }
   ],
   "source": [
    "n_estimators = [int(x) for x in np.linspace(start=100, stop=1000, num=10)]\n",
    "max_depth = [int(x) for x in np.linspace(start=1, stop=15, num=15)]\n",
    "min_samples_split = [int(x) for x in np.linspace(start=2, stop=50, num=10)]\n",
    "min_samples_leaf = [int(x) for x in np.linspace(start=2, stop=50, num=10)]\n",
    "bootstrap = [True, False]\n",
    "criterion = [\"gini\", \"entropy\"]\n",
    "param_dist = {'n_estimators': n_estimators,\n",
    "              'max_depth': max_depth,\n",
    "              'min_samples_split': min_samples_split,\n",
    "              'min_samples_leaf': min_samples_leaf,\n",
    "              'bootstrap': bootstrap,\n",
    "              'criterion': criterion}\n",
    "\n",
    "rfc = RandomForestClassifier()\n",
    "rs = RandomizedSearchCV(rfc, \n",
    "                        param_dist, \n",
    "                        n_iter=100, \n",
    "                        cv=3, \n",
    "                        n_jobs=1,\n",
    "                        verbose=1, \n",
    "                        random_state=0)\n",
    "rs.fit(train_x, train_y)\n",
    "rs.best_params_"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "94d64005",
   "metadata": {},
   "source": [
    "With n_iter = 100 and cv = 3, we create 300 Random Forest models, randomly sampling combinations of the hyperparameters input above. We call “best_params_” to get the best performing model’s parameters (shown at the bottom of the code box above)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5792a9be",
   "metadata": {},
   "outputs": [],
   "source": [
    "rs_df = pd.DataFrame(rs.cv_results_).sort_values('rank_test_score').reset_index(drop=True)\n",
    "rs_df = rs_df.drop([\n",
    "            'mean_fit_time', \n",
    "            'std_fit_time', \n",
    "            'mean_score_time',\n",
    "            'std_score_time', \n",
    "            'params', \n",
    "            'split0_test_score', \n",
    "            'split1_test_score', \n",
    "            'split2_test_score', \n",
    "            'std_test_score'],\n",
    "            axis=1)\n",
    "rs_df.head(10)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0274702c",
   "metadata": {},
   "outputs": [],
   "source": [
    "fig, axs = plt.subplots(ncols=3, nrows=2)\n",
    "sns.set(style=\"whitegrid\", color_codes=True, font_scale=8)\n",
    "fig.set_size_inches(30,25)\n",
    "\n",
    "sns.barplot(x='param_n_estimators', y='mean_test_score', data=rs_df, ax=axs[0,0], color='lightgrey')\n",
    "axs[0,0].set_ylim([.4,.8])\n",
    "axs[0,0].set_title(label='n_estimators', size=20, weight='bold')\n",
    "\n",
    "sns.barplot(x='param_min_samples_split', y='mean_test_score', data=rs_df, ax=axs[0,1], color='coral')\n",
    "axs[0,1].set_ylim([.4,.8])\n",
    "axs[0,1].set_title(label='min_samples_split', size=20, weight='bold')\n",
    "\n",
    "sns.barplot(x='param_min_samples_leaf', y='mean_test_score', data=rs_df, ax=axs[0,2], color='lightgreen')\n",
    "axs[0,2].set_ylim([.4,.8])\n",
    "axs[0,2].set_title(label='min_samples_leaf', size=20, weight='bold')\n",
    "\n",
    "sns.barplot(x='param_max_depth', y='mean_test_score', data=rs_df, ax=axs[1,0], color='lightpink')\n",
    "axs[1,0].set_ylim([.4,.8])\n",
    "axs[1,0].set_title(label='max_depth', size=20, weight='bold')\n",
    "\n",
    "sns.barplot(x='param_bootstrap', y='mean_test_score', data=rs_df, ax=axs[1,1], color='skyblue')\n",
    "axs[1,1].set_ylim([.4,.8])\n",
    "axs[1,1].set_title(label='bootstrap', size=20, weight='bold')\n",
    "\n",
    "sns.barplot(x='param_criterion', y='mean_test_score', data=rs_df, ax=axs[1,2], color='wheat')\n",
    "axs[1,2].set_ylim([.4,.8])\n",
    "axs[1,2].set_title(label='bootstrap', size=20, weight='bold')\n",
    "\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "87fcb8a3",
   "metadata": {},
   "source": [
    "#### Model Training"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "f08b5f2f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.9792490118577075"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# clf = RandomForestClassifier(n_estimators=rs.best_params_[\"n_estimators\"], \n",
    "#                              min_samples_split=rs.best_params_[\"min_samples_split\"],\n",
    "#                              min_samples_leaf=rs.best_params_[\"min_samples_leaf\"],\n",
    "#                              max_depth=rs.best_params_[\"max_depth\"], \n",
    "#                              bootstrap=rs.best_params_[\"bootstrap\"],\n",
    "#                              criterion=rs.best_params_[\"criterion\"],\n",
    "#                              random_state=0,\n",
    "#                              n_jobs=1)\n",
    "\n",
    "# clf = RandomForestClassifier(n_estimators=100, max_depth=9, random_state=0, criterion=\"gini\")\n",
    "\n",
    "# Very large numbers of base estimators may take a long time to prepare, but will not overfit the training data.\n",
    "clf = RandomForestClassifier(n_estimators=1000, \n",
    "                             min_samples_split=2,\n",
    "                             min_samples_leaf=2,\n",
    "                             max_depth=8, \n",
    "                             bootstrap=True,\n",
    "                             criterion=\"gini\",\n",
    "                             random_state=0,\n",
    "                             n_jobs=1)\n",
    "clf.fit(train_x, train_y)\n",
    "clf.score(train_x, train_y)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "1315b8d8",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/demiran1/anaconda3/envs/tda/lib/python3.9/site-packages/sklearn/utils/deprecation.py:87: FutureWarning: Function plot_confusion_matrix is deprecated; Function `plot_confusion_matrix` is deprecated in 1.0 and will be removed in 1.2. Use one of the class methods: ConfusionMatrixDisplay.from_predictions or ConfusionMatrixDisplay.from_estimator.\n",
      "  warnings.warn(msg, category=FutureWarning)\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 360x360 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "sns.set(style=\"whitegrid\", color_codes=True, font_scale=2)\n",
    "\n",
    "fig, ax = plt.subplots(figsize=(5, 5))\n",
    "plot_confusion_matrix(clf, train_x, train_y, ax=ax)  \n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "26957a38",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/demiran1/anaconda3/envs/tda/lib/python3.9/site-packages/sklearn/utils/deprecation.py:87: FutureWarning: Function plot_confusion_matrix is deprecated; Function `plot_confusion_matrix` is deprecated in 1.0 and will be removed in 1.2. Use one of the class methods: ConfusionMatrixDisplay.from_predictions or ConfusionMatrixDisplay.from_estimator.\n",
      "  warnings.warn(msg, category=FutureWarning)\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 360x360 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots(figsize=(5, 5))\n",
    "plot_confusion_matrix(clf, train_x, train_y, normalize='true', ax=ax)  \n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "141c31e8",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/demiran1/anaconda3/envs/tda/lib/python3.9/site-packages/sklearn/utils/deprecation.py:87: FutureWarning: Function plot_confusion_matrix is deprecated; Function `plot_confusion_matrix` is deprecated in 1.0 and will be removed in 1.2. Use one of the class methods: ConfusionMatrixDisplay.from_predictions or ConfusionMatrixDisplay.from_estimator.\n",
      "  warnings.warn(msg, category=FutureWarning)\n"
     ]
    },
    {
     "data": {
      "image/png": "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MD179mTlypWsWLGCtm3b0rBhQwBOnjzJypUrcXR0pF+/fuVcSiHuj7u3q6qune7e0uW5OCQBPGCqV6/OpEmTmDVrFi+//DJt2rQB4OjRo+Tm5jJ//nw8PT3LuZRCFI+NjQ02NjaMXDmg2MeKopME8ADq378/fn5+rFy5krCwMOzt7WnevDkjR47k0UcfLe/iCVFstra2NGzYEL1er/pYGxubfB0jROE0inQYF0KICkkagYUQooKSBCCEEBWUJAAhhKigJAEIIUQFJQlACCEqKEkAQghRQUkCEEKICkoSQBm4fPkyderUsfipW7cujRs35oknnmDkyJEW5/gpD+fOnTOV8W6TJ0+mTp06zJ8//76/48aNG6SkpNz3ee5l7dq11KlTh1deeaVI8Vu3bqVOnTr07Nnzvr978eLF1KlTh7Fjx973ue6lY8eO1KlTh71795b6d4mHgwybK2MNGzY0W85RURSys7O5fPkye/bsYc+ePfTr14/p06eXYylL35dffsnixYtZv369TF0tRDmRBFDGFi5cSPXq1fNtz8nJYcmSJSxfvpx169bRrl07OnbsWA4lLNybb77JsGHDqFKlyn2dZ968eSVUIiFEcUkVkJWws7Nj/PjxNGvWDIB169aVc4ks8/HxoVatWnh4eJR3UYQQ90kSgJXp0KEDkDe9sxBClCapArIyrq5585qnpaWZti1evJglS5YwceJEnJyc+PTTT0lOTiYwMJClS5dSo0YNAGJjY1mxYgW//vor169fx8XFhaZNmzJo0KACZwlNSEhgxYoV7N69m4SEBPz9/enbty+tW7e2GD958mS+++47hgwZwqRJk8z2xcbG8vXXX7N//37i4uJwdHSkUaNGDB48mLZt25pdi9Hzzz8PwNdff22a2hogNDSUL7/8kvDwcFJSUvD09OTxxx9nxIgRpuv9p4iICD799FPCwsJITU2lXr16jBw5stCft1o3btxgzZo1HDx4kNjYWDIyMnBzc6N+/fr07t2brl27FnhsVFQUH3/8sWnq7rp169K3b1+6d+9uMT41NZUvv/yS7du3c+nSJWxsbNDpdPTs2ZN//etfMvWxuG+SAKzMpUuXAPD19c23b8eOHfzxxx/4+/vj7+9Peno6AQEBABw8eJCxY8eSnp6Ok5MTtWvXJikpiX379rFv3z7eeOMNxowZY3a+6OhoBg8e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\n",
      "text/plain": [
       "<Figure size 360x360 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots(figsize=(5, 5))\n",
    "plot_confusion_matrix(clf, test_x, test_y, ax=ax)  \n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "985a8881",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/demiran1/anaconda3/envs/tda/lib/python3.9/site-packages/sklearn/utils/deprecation.py:87: FutureWarning: Function plot_confusion_matrix is deprecated; Function `plot_confusion_matrix` is deprecated in 1.0 and will be removed in 1.2. Use one of the class methods: ConfusionMatrixDisplay.from_predictions or ConfusionMatrixDisplay.from_estimator.\n",
      "  warnings.warn(msg, category=FutureWarning)\n"
     ]
    },
    {
     "data": {
      "image/png": "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vObnn38mNja22o1BS6puoB07dgydTmexTG5uLrt27ap286vqtRw8eNDiNbX9XNRYtWoVZ86coWPHjixfvpyHHnqIa665xjx929LNuAtVpUz+KSsri+LiYrRaLREREcD5n0Nd7U5OTubQoUON8gUjbEuC8GWgaszsl19+afH8t99+S1xcHHfddZe5RzZgwADAdIPLUgD5+uuvrX7+qokYa9asqfX5d+3aRWFhoflY1Q28C3vbkZGRtG3blrKyslrrevPNN4mNjeXJJ580H6t6LatWraqRjzUajbXWpUZ2djYAERER1W7CVVm5cqX5vy3tFJyUlGTO3V9o2bJlAFxzzTXmERf9+vUDYPXq1VRUVNS4JisriwcffJA777yT5ORk9S9G2BUJwpeBxx57DDc3N7799lvmzp1b7YO7bds2ZsyYAcC9995rzo9269aNmJgYysrKGD9+vPlGD8CKFStUrV0RGxuLr68vO3fuZNasWebnVxSFzz//nLVr1+Li4kJsbKz5mqrUw/Hjx83HNBoNjz/+OACzZs1i7dq15nN6vZ5FixaRmJgIUO3G3X333UdgYCB///0306ZNM/cOKyoqePnll2vt7atR1dv/9ddf2bNnj/l4WVkZH330EQsXLjQfsxQ4dTod48ePr/aFt2LFCpYsWYJGo2HcuHHm43fccQfh4eFkZGQwYcIE84gWMPWoH3/8cfR6PV27dq11JqRwHJITvgxERkYyZ84cnn32WRYsWMDnn39Ohw4dKCgoMPfgbrjhBvNY1iqvvPIKo0aNYs+ePQwcOJCoqCjy8/M5ceIEMTExVq9L26ZNG9566y0mTJjAp59+SmJiIu3bt+fEiRPk5eXh5OTEjBkzzIEMTKMvdu/ezVNPPUVERARPPvkkN910E8OGDePw4cMsWbKEp556itmzZxMYGMixY8fMNwDHjRvHwIEDzXV5e3szd+5cxowZw8qVK1m/fj3t27cnIyODs2fPqnottbn33ntZunQp2dnZ3HfffYSHh+Pu7k5GRgalpaW0bdsWrVZLVlYWp06dqnF9nz592LlzJwMGDKBTp04UFBSYe8bPPvss119/vbmsq6sr7733Ho8++ihbtmyhX79+REZGUllZSXp6OgaDgaCgIN5///2Lek3CPkhP+DIxePBgVq9ezbBhw2jZsiUpKSkUFBRw1VVX8fzzz/PRRx/VmOIaEBBAQkIC48aNo23btqSmpqLVahk/fjxvvPGGqufv06cPa9asYdiwYXh7e5OSkoLBYGDgwIEsW7asxgLps2bNIjo6GkVRSE9PJyMjw3xu6tSpLF68mP79+2M0Gs253ptuuon333/f4gLpV199NYmJiQwdOhRPT08OHTpE27ZteeONNxgxYoSq12KJr68vK1eu5KGHHiI8PJzs7GwyMjJo374948ePZ82aNQwePBjAYsC/8sorWbZsGdHR0aSnp3P27FluuOEGPvnkE4sTcyIjI1mzZg1jx44lIiKC9PR0MjMzCQsLY9SoUXz99deEhIRc9OsStqdRrL0FLoQQotFJT1gIIWxIgrAQQtiQBGEhhLAhCcJCCGFDEoSFEMKGJAgLIYQNSRAWQggbkiAshBA2JEFYCCFsSIKwEELYkARhIYSwof8HZD+SMW3WbtYAAAAASUVORK5CYII=\n",
      "text/plain": [
       "<Figure size 360x360 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots(figsize=(5, 5))\n",
    "plot_confusion_matrix(clf, test_x, test_y, normalize='true', ax=ax)  \n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "eaeb5421",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "AUC score: 0.974759190209857\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>EF 1%</th>\n",
       "      <th>EF 2%</th>\n",
       "      <th>EF 5%</th>\n",
       "      <th>EF 10%</th>\n",
       "      <th>EF 15%</th>\n",
       "      <th>EF 20%</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>78.947368</td>\n",
       "      <td>42.982456</td>\n",
       "      <td>18.245614</td>\n",
       "      <td>9.649123</td>\n",
       "      <td>6.432749</td>\n",
       "      <td>4.824561</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>mean</th>\n",
       "      <td>78.947368</td>\n",
       "      <td>42.982456</td>\n",
       "      <td>18.245614</td>\n",
       "      <td>9.649123</td>\n",
       "      <td>6.432749</td>\n",
       "      <td>4.824561</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "          EF 1%      EF 2%      EF 5%    EF 10%    EF 15%    EF 20%\n",
       "0     78.947368  42.982456  18.245614  9.649123  6.432749  4.824561\n",
       "1           NaN        NaN        NaN       NaN       NaN       NaN\n",
       "mean  78.947368  42.982456  18.245614  9.649123  6.432749  4.824561"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "factors = [0.01, 0.02, 0.05, 0.1, 0.15, 0.2]\n",
    "pred_labels = clf.predict_proba(test_x)\n",
    "\n",
    "print(\"AUC score:\", roc_auc_score(test_y, pred_labels[:, 1]))\n",
    "\n",
    "list = []\n",
    "for factor in factors:\n",
    "    list.append(enrichment_factor(test_y, pred_labels, ratio=factor))\n",
    "\n",
    "df = pd.concat(list, axis=1)\n",
    "df = pd.concat([df, df.agg(['mean'])]) \n",
    "display(df)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "548daef6",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "tda",
   "language": "python",
   "name": "tda"
  },
  "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.13"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
