{
 "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 AMPC"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "94acb9fc",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████| 2965/2965 [00:00<00:00, 9049.43it/s]\n"
     ]
    }
   ],
   "source": [
    "X, y = [], []\n",
    "path = '../data/DUDE-Diverse_TopologyFeatures/atom_weight_superlevel_betti_partial_charge_superlevel_betti/target_ampc/'\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": {
    "scrolled": false
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.9636363636363636"
      ]
     },
     "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=4,\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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Wi1JSUlcv369xPEhISEcPnyYXr16ERgYSHp6ummkGx4eTteuXU197e3tWb58OS+++CL79++ne/fuBAQEkJ+fT0JCAgaDAR8fH1asWHFPn0lYloxsa4h+/fqxbds2Bg8ezIMPPsi5c+dIT0+nTZs2zJkzhw8//LDEo51eXl5ERkYyadIkGjVqRFxcHFqtlrCwMN555x1V1w8JCWH79u0MHjwYV1dXzp07h8FgoHfv3qxfv77EQtwLFiygS5cuKIpCQkICiYmJprbZs2ezevVqevbsidFoNNViH330UVasWGF2Ie4OHTqwZcsWBg0ahLOzM7/++iuNGjXinXfeYdiwYao+izlubm5s2rSJESNG4Ofnx+XLl0lMTMTX15ewsDC2b99Ov379AMwm9oceeoj169fTpUsXEhISuH37Nn/605/4+OOPzT7AEhAQwPbt25kwYQL+/v4kJCRw8eJFmjZtypgxY9i6dSsNGza8588lLEejVPSWsxBCiEqTka0QQliAJFshhLAASbZCCGEBkmyFEMICJNkKIYQFSLIVQggLkGQrhBAWIMlWCCEsQJKtEEJYgCRbIYSwAEm2QghhAf8P7Aph9sr4LY0AAAAASUVORK5CYII=\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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s2fzwgsv4OLigslk4vXXX+fUqVPceuutVvsiX6nSIBwbG6vuqoQQopbU9dwRLVq0YOrUqcycOZOHH36Ynj17AhAfH4/BYGDevHnl0ghjx44lIyODOXPmMHz4cABcXFx4++23+de//sWqVav46aefaN++PceOHSMtLY2QkBBmzpxZbV0kCAsh6qVRo0bRrFkzli1bxv79+3F3d6dbt26MHz+eXr162VRGmzZt2LhxI0uWLGHHjh3s3LmToKAgRo0axfjx4wkKCqq2jBrNHSGEEHWqjtMRZfr370///v2rPa6qleMbN27Miy++yIsvvlijOtQoCBuNRjIzMykuLq7QmdlgMKDX6zl37hw7duxg9uzZNaqYEKI+01x6qDneOakOwkuXLmXp0qWWIXvVkSAshFDtGrWEHYGqILx161beeustm45t2bIld955Z40qJYSo5+pREFY1WOOLL74A4N5772Xnzp389ttvuLi48OCDD3Lw4EG2bdvGk08+aemm8cQTT9RJpYUQ17myZezVPJyUqiB8+PBhvLy8eOWVVwgODqZhw4ZERETwyy+/4ObmRmhoKM888wxPP/00GRkZFWYvEkIIW9TlsGVHoyoIX7x4kdDQUHx8fCzb2rZty+nTp8nLy7NsGzNmDJ6envzwww+1V1MhRP1SV2sbORhVQdjb27vCTPGhoaEAnDhxwrLN09OTsLAwUlNTa6GKQoh6R9IR1oWGhpKenk5RUZFlW6tWrVAUhSNHjpQ7tqSkxOoMRUIIUR2Nov7hrFQF4dtuu42ioiJeeuklCgoKAPP6SgDr16+3THJ84MABUlJSKp3iTQghqlTXyy07EFVBeMyYMQQEBPDtt9/Sp08f9Ho9bdq0oWfPnhw5coThw4czadIkoqOjAXPQFkII1SQdYV2jRo346KOPaN++Pe7u7pZF8l544QX8/f1JSkpi69atFBYW0qxZM5566qk6qbQQ4jpXj1rCqkfMtW/fng0bNnDmzBnLtsjISL755hvWr19PRkYGYWFhPPDAA5Yp34QQQpV6NFijxhP4hISElPu7cePGPPnkk1ddISGEkCAshBB2pTbP67w54UqD8IgRI666cI1Gw9q1a6+6HCFE/aK225kzd1GrNAgfOnToqgv/+8AOIYQQ5VUahOfMmXMt6yGEEJdJThjuu+++a1kPIYSol+rFjblne3cn90xe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U3/laskLFy7kvffeY8qUKXh5efH++++Tl5dHy5YtWbRoEa1atQIgPT2dpUuX8vPPP3Pu3Dl8fHzo0qULY8eOrXR2tfPnz7N06VJ++OEHzp8/T/PmzXnkkUe4+eabrR4/bdo0vvzyS8aNG8fUqVPL7UtPT2flypXs3LmTs2fP4unpSadOnYiOjua2224rdy1l7r33XgBWrlxpmZYTYO/evaxYsYKEhAQuXrxIo0aNuPXWW3nyySct1/t3R44c4f3332f//v0UFBTQvn17xo8fX+XrrVZWVhaffvopu3fvJj09neLiYvz8/Ljhhht48MEHGTx4cKXnnjx5krffftsy7Wi7du145JFHGDp0qNXjCwoKWLFiBVu2bCEtLQ0XFxciIyMZPnw4999/v1POGCYqkiDsYNLS0gAICQmpsG/r1q38+eefNG/enObNm1NUVERoaCgAu3fvZtKkSRQVFeHl5UXbtm3Jycnhp59+4qeffmLixInExsaWKy85OZno6GjOnDmDp6cnbdu2JTMzk1mzZtG9e3dV9f7ll194+umnyc/Px9vbm4iICM6fP8/PP//Mzz//zKxZsxgxYgQhISF069aN/fv3A3DDDTfg6emJn5+fpazFixezYMECAAICAoiMjCQ9PZ3169fz7bffsmDBggqrh2zbto1nn30WvV5PQEAAbdq04ejRo8TExHDTTTepupbKHDlyhOjoaHJzc/H29rbk9tPT0y3XOXnyZJ544okK5yYnJ/Pggw9SWFhI27ZtKSoqYv/+/ezfv5/ffvuN2bNnlzv+1KlTjBs3jtTUVFxdXQkLC8NkMpGQkEBCQgJbt25l8eLF5W7yCieliDqXnp6uREZGKpGRkUp6enqlx124cEG55ZZblMjISOW1116zbH/33Xct58+aNUsxmUyKoihKdna2pfxu3bopkZGRyjvvvKPodDrLudu3b7fs27Ztm2W7yWRSHnroISUyMlIZN26ckpubqyiKohiNRmX58uVKVFSU5TmvNHXqVCUyMlKZO3euZVt2drbSs2dPJTIyUnnxxReVgoICy3N8/PHHSmRkpNKhQ4dy115WdmJiYrnyt2zZokRGRirdunVTvvnmG8t2vV6vLFq0yLIvIyPDsi8rK8tyjW+88YZSWlqqKIqiFBQUKM8884zluUaPHl3pa3+l9evXK5GRkcp9991Xbvt9992n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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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\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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\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.8365770465489567\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>42.857143</td>\n",
       "      <td>21.428571</td>\n",
       "      <td>8.571429</td>\n",
       "      <td>5.714286</td>\n",
       "      <td>3.809524</td>\n",
       "      <td>2.857143</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>42.857143</td>\n",
       "      <td>21.428571</td>\n",
       "      <td>8.571429</td>\n",
       "      <td>5.714286</td>\n",
       "      <td>3.809524</td>\n",
       "      <td>2.857143</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     42.857143  21.428571  8.571429  5.714286  3.809524  2.857143\n",
       "1           NaN        NaN       NaN       NaN       NaN       NaN\n",
       "mean  42.857143  21.428571  8.571429  5.714286  3.809524  2.857143"
      ]
     },
     "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": "7574893e",
   "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.9.10"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
