{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "7505119d",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import pandas as pd"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "24162692",
   "metadata": {},
   "outputs": [],
   "source": [
    "# data_ids = [361260, 361254, 361259, 361253, 361243, 361242]\n",
    "data_ids = [361254, 361259, 361253, 361242]\n",
    "n_ests = [50, 100, 500, 1000]\n",
    "min_samples_leafs = [1, 5, 10]\n",
    "max_features = [0.1, 0.33, \"1.0\"]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "c58f56a3",
   "metadata": {},
   "outputs": [],
   "source": [
    "# for each data_id, load the result and save as a df\n",
    "dfs = []\n",
    "for data_id in data_ids:\n",
    "    # get number of samples in the data_id by reading X csv\n",
    "    X = np.loadtxt(f\"data/{data_id}/X.csv\", delimiter=\",\")\n",
    "    n_samples = 1000\n",
    "    n_features = X.shape[1]\n",
    "    for n_est in n_ests:\n",
    "        for min_samples_leaf in min_samples_leafs:\n",
    "            for max_feature in max_features:\n",
    "                # create the directory if it doesn't exist\n",
    "                dir_path = f\"results/rf/{data_id}/n_estimators_{n_est}/min_samples_leaf_{min_samples_leaf}/max_features_{max_feature}\"\n",
    "                results_path = f\"{dir_path}/runtime_results.csv\"\n",
    "                results_df = pd.read_csv(results_path)\n",
    "                # divide every col in df except 'data_id' by n_samples\n",
    "                for col in results_df.columns:\n",
    "                    if col != 'data_id':\n",
    "                        results_df[col] = results_df[col] / n_samples\n",
    "                # add columns for n_estimators, min_samples_leaf, max_features\n",
    "                results_df['n_estimators'] = n_est\n",
    "                results_df['min_samples_leaf'] = min_samples_leaf\n",
    "                results_df['max_features'] = max_feature\n",
    "                results_df['num_features'] = n_features\n",
    "                dfs.append(results_df)\n",
    "df = pd.concat(dfs, ignore_index=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "24c37531",
   "metadata": {},
   "outputs": [
    {
     "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>data_id</th>\n",
       "      <th>rf_fitting_time</th>\n",
       "      <th>rf_plus_fitting_time</th>\n",
       "      <th>shap_rf_explainer_time</th>\n",
       "      <th>shap_rf_values_time</th>\n",
       "      <th>lime_rf_time</th>\n",
       "      <th>local_mdi_time</th>\n",
       "      <th>lmdi_plus_rf_explainer_time</th>\n",
       "      <th>lmdi_plus_rf_values_time</th>\n",
       "      <th>n_estimators</th>\n",
       "      <th>min_samples_leaf</th>\n",
       "      <th>max_features</th>\n",
       "      <th>num_features</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>118</th>\n",
       "      <td>361242</td>\n",
       "      <td>0.001498</td>\n",
       "      <td>0.047808</td>\n",
       "      <td>0.000030</td>\n",
       "      <td>0.031717</td>\n",
       "      <td>0.186433</td>\n",
       "      <td>0.001082</td>\n",
       "      <td>0.000006</td>\n",
       "      <td>0.043541</td>\n",
       "      <td>100</td>\n",
       "      <td>1</td>\n",
       "      <td>0.33</td>\n",
       "      <td>81</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>82</th>\n",
       "      <td>361253</td>\n",
       "      <td>0.001102</td>\n",
       "      <td>0.027166</td>\n",
       "      <td>0.000032</td>\n",
       "      <td>0.033963</td>\n",
       "      <td>0.138509</td>\n",
       "      <td>0.001114</td>\n",
       "      <td>0.000006</td>\n",
       "      <td>0.022529</td>\n",
       "      <td>100</td>\n",
       "      <td>1</td>\n",
       "      <td>0.33</td>\n",
       "      <td>48</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>10</th>\n",
       "      <td>361254</td>\n",
       "      <td>0.000665</td>\n",
       "      <td>0.022531</td>\n",
       "      <td>0.000025</td>\n",
       "      <td>0.031032</td>\n",
       "      <td>0.126291</td>\n",
       "      <td>0.001288</td>\n",
       "      <td>0.000009</td>\n",
       "      <td>0.015159</td>\n",
       "      <td>100</td>\n",
       "      <td>1</td>\n",
       "      <td>0.33</td>\n",
       "      <td>21</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>46</th>\n",
       "      <td>361259</td>\n",
       "      <td>0.000813</td>\n",
       "      <td>0.045874</td>\n",
       "      <td>0.000033</td>\n",
       "      <td>0.030291</td>\n",
       "      <td>0.114102</td>\n",
       "      <td>0.001223</td>\n",
       "      <td>0.000006</td>\n",
       "      <td>0.014599</td>\n",
       "      <td>100</td>\n",
       "      <td>1</td>\n",
       "      <td>0.33</td>\n",
       "      <td>32</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>121</th>\n",
       "      <td>361242</td>\n",
       "      <td>0.001003</td>\n",
       "      <td>0.007108</td>\n",
       "      <td>0.000004</td>\n",
       "      <td>0.003114</td>\n",
       "      <td>0.188586</td>\n",
       "      <td>0.000834</td>\n",
       "      <td>0.000006</td>\n",
       "      <td>0.034292</td>\n",
       "      <td>100</td>\n",
       "      <td>5</td>\n",
       "      <td>0.33</td>\n",
       "      <td>81</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>85</th>\n",
       "      <td>361253</td>\n",
       "      <td>0.000853</td>\n",
       "      <td>0.008118</td>\n",
       "      <td>0.000010</td>\n",
       "      <td>0.003883</td>\n",
       "      <td>0.168553</td>\n",
       "      <td>0.000920</td>\n",
       "      <td>0.000006</td>\n",
       "      <td>0.020327</td>\n",
       "      <td>100</td>\n",
       "      <td>5</td>\n",
       "      <td>0.33</td>\n",
       "      <td>48</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>13</th>\n",
       "      <td>361254</td>\n",
       "      <td>0.000395</td>\n",
       "      <td>0.005046</td>\n",
       "      <td>0.000012</td>\n",
       "      <td>0.002404</td>\n",
       "      <td>0.073060</td>\n",
       "      <td>0.000779</td>\n",
       "      <td>0.000005</td>\n",
       "      <td>0.003176</td>\n",
       "      <td>100</td>\n",
       "      <td>5</td>\n",
       "      <td>0.33</td>\n",
       "      <td>21</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>49</th>\n",
       "      <td>361259</td>\n",
       "      <td>0.000571</td>\n",
       "      <td>0.005350</td>\n",
       "      <td>0.000012</td>\n",
       "      <td>0.002810</td>\n",
       "      <td>0.095760</td>\n",
       "      <td>0.000815</td>\n",
       "      <td>0.000004</td>\n",
       "      <td>0.005758</td>\n",
       "      <td>100</td>\n",
       "      <td>5</td>\n",
       "      <td>0.33</td>\n",
       "      <td>32</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>124</th>\n",
       "      <td>361242</td>\n",
       "      <td>0.000844</td>\n",
       "      <td>0.005588</td>\n",
       "      <td>0.000008</td>\n",
       "      <td>0.001079</td>\n",
       "      <td>0.167529</td>\n",
       "      <td>0.000632</td>\n",
       "      <td>0.000005</td>\n",
       "      <td>0.016736</td>\n",
       "      <td>100</td>\n",
       "      <td>10</td>\n",
       "      <td>0.33</td>\n",
       "      <td>81</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>88</th>\n",
       "      <td>361253</td>\n",
       "      <td>0.000723</td>\n",
       "      <td>0.007096</td>\n",
       "      <td>0.000010</td>\n",
       "      <td>0.001369</td>\n",
       "      <td>0.179425</td>\n",
       "      <td>0.000804</td>\n",
       "      <td>0.000006</td>\n",
       "      <td>0.010872</td>\n",
       "      <td>100</td>\n",
       "      <td>10</td>\n",
       "      <td>0.33</td>\n",
       "      <td>48</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>16</th>\n",
       "      <td>361254</td>\n",
       "      <td>0.000396</td>\n",
       "      <td>0.006740</td>\n",
       "      <td>0.000009</td>\n",
       "      <td>0.001211</td>\n",
       "      <td>0.105210</td>\n",
       "      <td>0.000887</td>\n",
       "      <td>0.000008</td>\n",
       "      <td>0.003772</td>\n",
       "      <td>100</td>\n",
       "      <td>10</td>\n",
       "      <td>0.33</td>\n",
       "      <td>21</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>52</th>\n",
       "      <td>361259</td>\n",
       "      <td>0.000484</td>\n",
       "      <td>0.005634</td>\n",
       "      <td>0.000010</td>\n",
       "      <td>0.001178</td>\n",
       "      <td>0.098319</td>\n",
       "      <td>0.000760</td>\n",
       "      <td>0.000005</td>\n",
       "      <td>0.004488</td>\n",
       "      <td>100</td>\n",
       "      <td>10</td>\n",
       "      <td>0.33</td>\n",
       "      <td>32</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "     data_id  rf_fitting_time  rf_plus_fitting_time  shap_rf_explainer_time  \\\n",
       "118   361242         0.001498              0.047808                0.000030   \n",
       "82    361253         0.001102              0.027166                0.000032   \n",
       "10    361254         0.000665              0.022531                0.000025   \n",
       "46    361259         0.000813              0.045874                0.000033   \n",
       "121   361242         0.001003              0.007108                0.000004   \n",
       "85    361253         0.000853              0.008118                0.000010   \n",
       "13    361254         0.000395              0.005046                0.000012   \n",
       "49    361259         0.000571              0.005350                0.000012   \n",
       "124   361242         0.000844              0.005588                0.000008   \n",
       "88    361253         0.000723              0.007096                0.000010   \n",
       "16    361254         0.000396              0.006740                0.000009   \n",
       "52    361259         0.000484              0.005634                0.000010   \n",
       "\n",
       "     shap_rf_values_time  lime_rf_time  local_mdi_time  \\\n",
       "118             0.031717      0.186433        0.001082   \n",
       "82              0.033963      0.138509        0.001114   \n",
       "10              0.031032      0.126291        0.001288   \n",
       "46              0.030291      0.114102        0.001223   \n",
       "121             0.003114      0.188586        0.000834   \n",
       "85              0.003883      0.168553        0.000920   \n",
       "13              0.002404      0.073060        0.000779   \n",
       "49              0.002810      0.095760        0.000815   \n",
       "124             0.001079      0.167529        0.000632   \n",
       "88              0.001369      0.179425        0.000804   \n",
       "16              0.001211      0.105210        0.000887   \n",
       "52              0.001178      0.098319        0.000760   \n",
       "\n",
       "     lmdi_plus_rf_explainer_time  lmdi_plus_rf_values_time  n_estimators  \\\n",
       "118                     0.000006                  0.043541           100   \n",
       "82                      0.000006                  0.022529           100   \n",
       "10                      0.000009                  0.015159           100   \n",
       "46                      0.000006                  0.014599           100   \n",
       "121                     0.000006                  0.034292           100   \n",
       "85                      0.000006                  0.020327           100   \n",
       "13                      0.000005                  0.003176           100   \n",
       "49                      0.000004                  0.005758           100   \n",
       "124                     0.000005                  0.016736           100   \n",
       "88                      0.000006                  0.010872           100   \n",
       "16                      0.000008                  0.003772           100   \n",
       "52                      0.000005                  0.004488           100   \n",
       "\n",
       "     min_samples_leaf max_features  num_features  \n",
       "118                 1         0.33            81  \n",
       "82                  1         0.33            48  \n",
       "10                  1         0.33            21  \n",
       "46                  1         0.33            32  \n",
       "121                 5         0.33            81  \n",
       "85                  5         0.33            48  \n",
       "13                  5         0.33            21  \n",
       "49                  5         0.33            32  \n",
       "124                10         0.33            81  \n",
       "88                 10         0.33            48  \n",
       "16                 10         0.33            21  \n",
       "52                 10         0.33            32  "
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df[(df['max_features'] == 0.33) & (df['n_estimators'] == 100)].sort_values(by=['min_samples_leaf', 'data_id'])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "5189b575",
   "metadata": {},
   "outputs": [],
   "source": [
    "display_df = df[(df['max_features'] == 0.33) & (df['n_estimators'] == 100)].sort_values(by=['min_samples_leaf', 'data_id'])\n",
    "# display_df columns should be data_id, n_features, n_estimators, min_samples_leaf, max_features, rf_plus_fitting_time + lmdi_plus_values_time, lime_time, shap_values_time, local_mdi_time\n",
    "display_df = display_df[['data_id', 'num_features', 'min_samples_leaf', 'rf_plus_fitting_time', 'lmdi_plus_rf_values_time', 'lime_rf_time', 'shap_rf_values_time', 'local_mdi_time']]\n",
    "display_df['lmdi_plus_time'] = display_df['rf_plus_fitting_time'] + display_df['lmdi_plus_rf_values_time']\n",
    "display_df.drop(columns=['rf_plus_fitting_time', 'lmdi_plus_rf_values_time'], inplace=True)\n",
    "display_df = display_df[['data_id', 'num_features', 'min_samples_leaf', 'lmdi_plus_time', 'lime_rf_time', 'shap_rf_values_time', 'local_mdi_time']]\n",
    "display_df = display_df.rename(columns={\n",
    "    'data_id': 'OpenML Data ID',\n",
    "    'num_features': '# of Features',\n",
    "    'n_estimators': '# of Estimators',\n",
    "    'min_samples_leaf': 'Min. Samples per Leaf',\n",
    "    'max_features': 'Max Features per Split',\n",
    "    'lmdi_plus_time': 'LMDI+',\n",
    "    'lime_rf_time': 'LIME',\n",
    "    'shap_rf_values_time': 'TreeSHAP',\n",
    "    'local_mdi_time': 'Local MDI'\n",
    "})\n",
    "\n",
    "# sort display_df by min samples leaf increasing and then number of features increasing\n",
    "display_df = display_df.sort_values(by=['Min. Samples per Leaf', '# of Features'])\n",
    "\n",
    "# round to fourth decimal place\n",
    "display_df = display_df.round(4)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "550be71d",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "|   OpenML Data ID |   # of Features |   Min. Samples per Leaf |   LMDI+ |   LIME |   TreeSHAP |   Local MDI |\n",
      "|-----------------:|----------------:|------------------------:|--------:|-------:|-----------:|------------:|\n",
      "|           361254 |              21 |                       1 |  0.0377 | 0.1263 |     0.031  |      0.0013 |\n",
      "|           361259 |              32 |                       1 |  0.0605 | 0.1141 |     0.0303 |      0.0012 |\n",
      "|           361253 |              48 |                       1 |  0.0497 | 0.1385 |     0.034  |      0.0011 |\n",
      "|           361242 |              81 |                       1 |  0.0913 | 0.1864 |     0.0317 |      0.0011 |\n",
      "|           361254 |              21 |                       5 |  0.0082 | 0.0731 |     0.0024 |      0.0008 |\n",
      "|           361259 |              32 |                       5 |  0.0111 | 0.0958 |     0.0028 |      0.0008 |\n",
      "|           361253 |              48 |                       5 |  0.0284 | 0.1686 |     0.0039 |      0.0009 |\n",
      "|           361242 |              81 |                       5 |  0.0414 | 0.1886 |     0.0031 |      0.0008 |\n",
      "|           361254 |              21 |                      10 |  0.0105 | 0.1052 |     0.0012 |      0.0009 |\n",
      "|           361259 |              32 |                      10 |  0.0101 | 0.0983 |     0.0012 |      0.0008 |\n",
      "|           361253 |              48 |                      10 |  0.018  | 0.1794 |     0.0014 |      0.0008 |\n",
      "|           361242 |              81 |                      10 |  0.0223 | 0.1675 |     0.0011 |      0.0006 |\n"
     ]
    }
   ],
   "source": [
    "# get display_df in markdown format\n",
    "markdown_df = display_df.to_markdown(index=False)\n",
    "print(markdown_df)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "04939105",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\\begin{tabular}{rrrrrrr}\n",
      "\\toprule\n",
      "OpenML Data ID & # of Features & Min. Samples per Leaf & LMDI+ & LIME & TreeSHAP & Local MDI \\\\\n",
      "\\midrule\n",
      "361254 & 21 & 1 & 0.0377 & 0.1263 & 0.0310 & 0.0013 \\\\\n",
      "361259 & 32 & 1 & 0.0605 & 0.1141 & 0.0303 & 0.0012 \\\\\n",
      "361253 & 48 & 1 & 0.0497 & 0.1385 & 0.0340 & 0.0011 \\\\\n",
      "361242 & 81 & 1 & 0.0913 & 0.1864 & 0.0317 & 0.0011 \\\\\n",
      "361254 & 21 & 5 & 0.0082 & 0.0731 & 0.0024 & 0.0008 \\\\\n",
      "361259 & 32 & 5 & 0.0111 & 0.0958 & 0.0028 & 0.0008 \\\\\n",
      "361253 & 48 & 5 & 0.0284 & 0.1686 & 0.0039 & 0.0009 \\\\\n",
      "361242 & 81 & 5 & 0.0414 & 0.1886 & 0.0031 & 0.0008 \\\\\n",
      "361254 & 21 & 10 & 0.0105 & 0.1052 & 0.0012 & 0.0009 \\\\\n",
      "361259 & 32 & 10 & 0.0101 & 0.0983 & 0.0012 & 0.0008 \\\\\n",
      "361253 & 48 & 10 & 0.0180 & 0.1794 & 0.0014 & 0.0008 \\\\\n",
      "361242 & 81 & 10 & 0.0223 & 0.1675 & 0.0011 & 0.0006 \\\\\n",
      "\\bottomrule\n",
      "\\end{tabular}\n",
      "\n"
     ]
    }
   ],
   "source": [
    "# get display_df in latex format, still only use 4 decimal places\n",
    "latex_df = display_df.to_latex(index=False, float_format=\"%.4f\")\n",
    "print(latex_df)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "55cf427d",
   "metadata": {},
   "outputs": [
    {
     "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>data_id</th>\n",
       "      <th>rf_fitting_time</th>\n",
       "      <th>rf_plus_fitting_time</th>\n",
       "      <th>shap_rf_explainer_time</th>\n",
       "      <th>shap_rf_values_time</th>\n",
       "      <th>lime_rf_time</th>\n",
       "      <th>local_mdi_time</th>\n",
       "      <th>lmdi_plus_rf_explainer_time</th>\n",
       "      <th>lmdi_plus_rf_values_time</th>\n",
       "      <th>n_estimators</th>\n",
       "      <th>min_samples_leaf</th>\n",
       "      <th>max_features</th>\n",
       "      <th>num_features</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>112</th>\n",
       "      <td>361242</td>\n",
       "      <td>0.000532</td>\n",
       "      <td>0.006824</td>\n",
       "      <td>0.000005</td>\n",
       "      <td>0.001733</td>\n",
       "      <td>0.215546</td>\n",
       "      <td>0.000483</td>\n",
       "      <td>0.000003</td>\n",
       "      <td>0.015815</td>\n",
       "      <td>50</td>\n",
       "      <td>5</td>\n",
       "      <td>0.33</td>\n",
       "      <td>81</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>76</th>\n",
       "      <td>361253</td>\n",
       "      <td>0.000476</td>\n",
       "      <td>0.005429</td>\n",
       "      <td>0.000007</td>\n",
       "      <td>0.002090</td>\n",
       "      <td>0.156516</td>\n",
       "      <td>0.000562</td>\n",
       "      <td>0.000004</td>\n",
       "      <td>0.008764</td>\n",
       "      <td>50</td>\n",
       "      <td>5</td>\n",
       "      <td>0.33</td>\n",
       "      <td>48</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>361254</td>\n",
       "      <td>0.000180</td>\n",
       "      <td>0.003806</td>\n",
       "      <td>0.000004</td>\n",
       "      <td>0.001255</td>\n",
       "      <td>0.055506</td>\n",
       "      <td>0.000423</td>\n",
       "      <td>0.000002</td>\n",
       "      <td>0.001566</td>\n",
       "      <td>50</td>\n",
       "      <td>5</td>\n",
       "      <td>0.33</td>\n",
       "      <td>21</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>40</th>\n",
       "      <td>361259</td>\n",
       "      <td>0.000366</td>\n",
       "      <td>0.005601</td>\n",
       "      <td>0.000005</td>\n",
       "      <td>0.001970</td>\n",
       "      <td>0.117854</td>\n",
       "      <td>0.000586</td>\n",
       "      <td>0.000004</td>\n",
       "      <td>0.004816</td>\n",
       "      <td>50</td>\n",
       "      <td>5</td>\n",
       "      <td>0.33</td>\n",
       "      <td>32</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>121</th>\n",
       "      <td>361242</td>\n",
       "      <td>0.001003</td>\n",
       "      <td>0.007108</td>\n",
       "      <td>0.000004</td>\n",
       "      <td>0.003114</td>\n",
       "      <td>0.188586</td>\n",
       "      <td>0.000834</td>\n",
       "      <td>0.000006</td>\n",
       "      <td>0.034292</td>\n",
       "      <td>100</td>\n",
       "      <td>5</td>\n",
       "      <td>0.33</td>\n",
       "      <td>81</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>85</th>\n",
       "      <td>361253</td>\n",
       "      <td>0.000853</td>\n",
       "      <td>0.008118</td>\n",
       "      <td>0.000010</td>\n",
       "      <td>0.003883</td>\n",
       "      <td>0.168553</td>\n",
       "      <td>0.000920</td>\n",
       "      <td>0.000006</td>\n",
       "      <td>0.020327</td>\n",
       "      <td>100</td>\n",
       "      <td>5</td>\n",
       "      <td>0.33</td>\n",
       "      <td>48</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>13</th>\n",
       "      <td>361254</td>\n",
       "      <td>0.000395</td>\n",
       "      <td>0.005046</td>\n",
       "      <td>0.000012</td>\n",
       "      <td>0.002404</td>\n",
       "      <td>0.073060</td>\n",
       "      <td>0.000779</td>\n",
       "      <td>0.000005</td>\n",
       "      <td>0.003176</td>\n",
       "      <td>100</td>\n",
       "      <td>5</td>\n",
       "      <td>0.33</td>\n",
       "      <td>21</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>49</th>\n",
       "      <td>361259</td>\n",
       "      <td>0.000571</td>\n",
       "      <td>0.005350</td>\n",
       "      <td>0.000012</td>\n",
       "      <td>0.002810</td>\n",
       "      <td>0.095760</td>\n",
       "      <td>0.000815</td>\n",
       "      <td>0.000004</td>\n",
       "      <td>0.005758</td>\n",
       "      <td>100</td>\n",
       "      <td>5</td>\n",
       "      <td>0.33</td>\n",
       "      <td>32</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>130</th>\n",
       "      <td>361242</td>\n",
       "      <td>0.005007</td>\n",
       "      <td>0.039496</td>\n",
       "      <td>0.000050</td>\n",
       "      <td>0.014647</td>\n",
       "      <td>0.300730</td>\n",
       "      <td>0.003435</td>\n",
       "      <td>0.000029</td>\n",
       "      <td>0.116405</td>\n",
       "      <td>500</td>\n",
       "      <td>5</td>\n",
       "      <td>0.33</td>\n",
       "      <td>81</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>94</th>\n",
       "      <td>361253</td>\n",
       "      <td>0.003813</td>\n",
       "      <td>0.034524</td>\n",
       "      <td>0.000052</td>\n",
       "      <td>0.015624</td>\n",
       "      <td>0.261150</td>\n",
       "      <td>0.003626</td>\n",
       "      <td>0.000028</td>\n",
       "      <td>0.054999</td>\n",
       "      <td>500</td>\n",
       "      <td>5</td>\n",
       "      <td>0.33</td>\n",
       "      <td>48</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>22</th>\n",
       "      <td>361254</td>\n",
       "      <td>0.001744</td>\n",
       "      <td>0.031732</td>\n",
       "      <td>0.000051</td>\n",
       "      <td>0.011815</td>\n",
       "      <td>0.200693</td>\n",
       "      <td>0.003745</td>\n",
       "      <td>0.000028</td>\n",
       "      <td>0.015622</td>\n",
       "      <td>500</td>\n",
       "      <td>5</td>\n",
       "      <td>0.33</td>\n",
       "      <td>21</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>58</th>\n",
       "      <td>361259</td>\n",
       "      <td>0.003084</td>\n",
       "      <td>0.045722</td>\n",
       "      <td>0.000025</td>\n",
       "      <td>0.018138</td>\n",
       "      <td>0.292724</td>\n",
       "      <td>0.004583</td>\n",
       "      <td>0.000032</td>\n",
       "      <td>0.042279</td>\n",
       "      <td>500</td>\n",
       "      <td>5</td>\n",
       "      <td>0.33</td>\n",
       "      <td>32</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>139</th>\n",
       "      <td>361242</td>\n",
       "      <td>0.011716</td>\n",
       "      <td>0.164791</td>\n",
       "      <td>0.000077</td>\n",
       "      <td>0.033192</td>\n",
       "      <td>0.503287</td>\n",
       "      <td>0.007669</td>\n",
       "      <td>0.000063</td>\n",
       "      <td>0.345007</td>\n",
       "      <td>1000</td>\n",
       "      <td>5</td>\n",
       "      <td>0.33</td>\n",
       "      <td>81</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>103</th>\n",
       "      <td>361253</td>\n",
       "      <td>0.007992</td>\n",
       "      <td>0.168185</td>\n",
       "      <td>0.000050</td>\n",
       "      <td>0.041749</td>\n",
       "      <td>0.500899</td>\n",
       "      <td>0.008754</td>\n",
       "      <td>0.000058</td>\n",
       "      <td>0.146259</td>\n",
       "      <td>1000</td>\n",
       "      <td>5</td>\n",
       "      <td>0.33</td>\n",
       "      <td>48</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>31</th>\n",
       "      <td>361254</td>\n",
       "      <td>0.004092</td>\n",
       "      <td>0.177316</td>\n",
       "      <td>0.000054</td>\n",
       "      <td>0.028126</td>\n",
       "      <td>0.373659</td>\n",
       "      <td>0.008423</td>\n",
       "      <td>0.000062</td>\n",
       "      <td>0.045898</td>\n",
       "      <td>1000</td>\n",
       "      <td>5</td>\n",
       "      <td>0.33</td>\n",
       "      <td>21</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>67</th>\n",
       "      <td>361259</td>\n",
       "      <td>0.005769</td>\n",
       "      <td>0.143497</td>\n",
       "      <td>0.000078</td>\n",
       "      <td>0.029650</td>\n",
       "      <td>0.391290</td>\n",
       "      <td>0.008601</td>\n",
       "      <td>0.000061</td>\n",
       "      <td>0.062091</td>\n",
       "      <td>1000</td>\n",
       "      <td>5</td>\n",
       "      <td>0.33</td>\n",
       "      <td>32</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "     data_id  rf_fitting_time  rf_plus_fitting_time  shap_rf_explainer_time  \\\n",
       "112   361242         0.000532              0.006824                0.000005   \n",
       "76    361253         0.000476              0.005429                0.000007   \n",
       "4     361254         0.000180              0.003806                0.000004   \n",
       "40    361259         0.000366              0.005601                0.000005   \n",
       "121   361242         0.001003              0.007108                0.000004   \n",
       "85    361253         0.000853              0.008118                0.000010   \n",
       "13    361254         0.000395              0.005046                0.000012   \n",
       "49    361259         0.000571              0.005350                0.000012   \n",
       "130   361242         0.005007              0.039496                0.000050   \n",
       "94    361253         0.003813              0.034524                0.000052   \n",
       "22    361254         0.001744              0.031732                0.000051   \n",
       "58    361259         0.003084              0.045722                0.000025   \n",
       "139   361242         0.011716              0.164791                0.000077   \n",
       "103   361253         0.007992              0.168185                0.000050   \n",
       "31    361254         0.004092              0.177316                0.000054   \n",
       "67    361259         0.005769              0.143497                0.000078   \n",
       "\n",
       "     shap_rf_values_time  lime_rf_time  local_mdi_time  \\\n",
       "112             0.001733      0.215546        0.000483   \n",
       "76              0.002090      0.156516        0.000562   \n",
       "4               0.001255      0.055506        0.000423   \n",
       "40              0.001970      0.117854        0.000586   \n",
       "121             0.003114      0.188586        0.000834   \n",
       "85              0.003883      0.168553        0.000920   \n",
       "13              0.002404      0.073060        0.000779   \n",
       "49              0.002810      0.095760        0.000815   \n",
       "130             0.014647      0.300730        0.003435   \n",
       "94              0.015624      0.261150        0.003626   \n",
       "22              0.011815      0.200693        0.003745   \n",
       "58              0.018138      0.292724        0.004583   \n",
       "139             0.033192      0.503287        0.007669   \n",
       "103             0.041749      0.500899        0.008754   \n",
       "31              0.028126      0.373659        0.008423   \n",
       "67              0.029650      0.391290        0.008601   \n",
       "\n",
       "     lmdi_plus_rf_explainer_time  lmdi_plus_rf_values_time  n_estimators  \\\n",
       "112                     0.000003                  0.015815            50   \n",
       "76                      0.000004                  0.008764            50   \n",
       "4                       0.000002                  0.001566            50   \n",
       "40                      0.000004                  0.004816            50   \n",
       "121                     0.000006                  0.034292           100   \n",
       "85                      0.000006                  0.020327           100   \n",
       "13                      0.000005                  0.003176           100   \n",
       "49                      0.000004                  0.005758           100   \n",
       "130                     0.000029                  0.116405           500   \n",
       "94                      0.000028                  0.054999           500   \n",
       "22                      0.000028                  0.015622           500   \n",
       "58                      0.000032                  0.042279           500   \n",
       "139                     0.000063                  0.345007          1000   \n",
       "103                     0.000058                  0.146259          1000   \n",
       "31                      0.000062                  0.045898          1000   \n",
       "67                      0.000061                  0.062091          1000   \n",
       "\n",
       "     min_samples_leaf max_features  num_features  \n",
       "112                 5         0.33            81  \n",
       "76                  5         0.33            48  \n",
       "4                   5         0.33            21  \n",
       "40                  5         0.33            32  \n",
       "121                 5         0.33            81  \n",
       "85                  5         0.33            48  \n",
       "13                  5         0.33            21  \n",
       "49                  5         0.33            32  \n",
       "130                 5         0.33            81  \n",
       "94                  5         0.33            48  \n",
       "22                  5         0.33            21  \n",
       "58                  5         0.33            32  \n",
       "139                 5         0.33            81  \n",
       "103                 5         0.33            48  \n",
       "31                  5         0.33            21  \n",
       "67                  5         0.33            32  "
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df[(df['max_features'] == 0.33) & (df['min_samples_leaf'] == 5)].sort_values(by=['n_estimators', 'data_id'])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "9fe04a80",
   "metadata": {},
   "outputs": [
    {
     "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>OpenML Data ID</th>\n",
       "      <th># of Features</th>\n",
       "      <th>Min. Samples per Leaf</th>\n",
       "      <th>LMDI+</th>\n",
       "      <th>LIME</th>\n",
       "      <th>TreeSHAP</th>\n",
       "      <th>Local MDI</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>10</th>\n",
       "      <td>361254</td>\n",
       "      <td>21</td>\n",
       "      <td>1</td>\n",
       "      <td>0.0377</td>\n",
       "      <td>0.1263</td>\n",
       "      <td>0.0310</td>\n",
       "      <td>0.0013</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>46</th>\n",
       "      <td>361259</td>\n",
       "      <td>32</td>\n",
       "      <td>1</td>\n",
       "      <td>0.0605</td>\n",
       "      <td>0.1141</td>\n",
       "      <td>0.0303</td>\n",
       "      <td>0.0012</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>82</th>\n",
       "      <td>361253</td>\n",
       "      <td>48</td>\n",
       "      <td>1</td>\n",
       "      <td>0.0497</td>\n",
       "      <td>0.1385</td>\n",
       "      <td>0.0340</td>\n",
       "      <td>0.0011</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>118</th>\n",
       "      <td>361242</td>\n",
       "      <td>81</td>\n",
       "      <td>1</td>\n",
       "      <td>0.0913</td>\n",
       "      <td>0.1864</td>\n",
       "      <td>0.0317</td>\n",
       "      <td>0.0011</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>13</th>\n",
       "      <td>361254</td>\n",
       "      <td>21</td>\n",
       "      <td>5</td>\n",
       "      <td>0.0082</td>\n",
       "      <td>0.0731</td>\n",
       "      <td>0.0024</td>\n",
       "      <td>0.0008</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>49</th>\n",
       "      <td>361259</td>\n",
       "      <td>32</td>\n",
       "      <td>5</td>\n",
       "      <td>0.0111</td>\n",
       "      <td>0.0958</td>\n",
       "      <td>0.0028</td>\n",
       "      <td>0.0008</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>85</th>\n",
       "      <td>361253</td>\n",
       "      <td>48</td>\n",
       "      <td>5</td>\n",
       "      <td>0.0284</td>\n",
       "      <td>0.1686</td>\n",
       "      <td>0.0039</td>\n",
       "      <td>0.0009</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>121</th>\n",
       "      <td>361242</td>\n",
       "      <td>81</td>\n",
       "      <td>5</td>\n",
       "      <td>0.0414</td>\n",
       "      <td>0.1886</td>\n",
       "      <td>0.0031</td>\n",
       "      <td>0.0008</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>16</th>\n",
       "      <td>361254</td>\n",
       "      <td>21</td>\n",
       "      <td>10</td>\n",
       "      <td>0.0105</td>\n",
       "      <td>0.1052</td>\n",
       "      <td>0.0012</td>\n",
       "      <td>0.0009</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>52</th>\n",
       "      <td>361259</td>\n",
       "      <td>32</td>\n",
       "      <td>10</td>\n",
       "      <td>0.0101</td>\n",
       "      <td>0.0983</td>\n",
       "      <td>0.0012</td>\n",
       "      <td>0.0008</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>88</th>\n",
       "      <td>361253</td>\n",
       "      <td>48</td>\n",
       "      <td>10</td>\n",
       "      <td>0.0180</td>\n",
       "      <td>0.1794</td>\n",
       "      <td>0.0014</td>\n",
       "      <td>0.0008</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>124</th>\n",
       "      <td>361242</td>\n",
       "      <td>81</td>\n",
       "      <td>10</td>\n",
       "      <td>0.0223</td>\n",
       "      <td>0.1675</td>\n",
       "      <td>0.0011</td>\n",
       "      <td>0.0006</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "     OpenML Data ID  # of Features  Min. Samples per Leaf   LMDI+    LIME  \\\n",
       "10           361254             21                      1  0.0377  0.1263   \n",
       "46           361259             32                      1  0.0605  0.1141   \n",
       "82           361253             48                      1  0.0497  0.1385   \n",
       "118          361242             81                      1  0.0913  0.1864   \n",
       "13           361254             21                      5  0.0082  0.0731   \n",
       "49           361259             32                      5  0.0111  0.0958   \n",
       "85           361253             48                      5  0.0284  0.1686   \n",
       "121          361242             81                      5  0.0414  0.1886   \n",
       "16           361254             21                     10  0.0105  0.1052   \n",
       "52           361259             32                     10  0.0101  0.0983   \n",
       "88           361253             48                     10  0.0180  0.1794   \n",
       "124          361242             81                     10  0.0223  0.1675   \n",
       "\n",
       "     TreeSHAP  Local MDI  \n",
       "10     0.0310     0.0013  \n",
       "46     0.0303     0.0012  \n",
       "82     0.0340     0.0011  \n",
       "118    0.0317     0.0011  \n",
       "13     0.0024     0.0008  \n",
       "49     0.0028     0.0008  \n",
       "85     0.0039     0.0009  \n",
       "121    0.0031     0.0008  \n",
       "16     0.0012     0.0009  \n",
       "52     0.0012     0.0008  \n",
       "88     0.0014     0.0008  \n",
       "124    0.0011     0.0006  "
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "display_df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "b8a0b551",
   "metadata": {},
   "outputs": [],
   "source": [
    "display_df = df[(df['max_features'] == 0.33) & (df['min_samples_leaf'] == 5) & (df['n_estimators'] != 50)].sort_values(by=['n_estimators', 'data_id'])\n",
    "# display_df columns should be data_id, n_features, n_estimators, min_samples_leaf, max_features, rf_plus_fitting_time + lmdi_plus_values_time, lime_time, shap_values_time, local_mdi_time\n",
    "display_df = display_df[['data_id', 'num_features', 'n_estimators', 'rf_plus_fitting_time', 'lmdi_plus_rf_values_time', 'lime_rf_time', 'shap_rf_values_time', 'local_mdi_time']]\n",
    "display_df['lmdi_plus_time'] = display_df['rf_plus_fitting_time'] + display_df['lmdi_plus_rf_values_time']\n",
    "display_df.drop(columns=['rf_plus_fitting_time', 'lmdi_plus_rf_values_time'], inplace=True)\n",
    "display_df = display_df[['data_id', 'num_features', 'n_estimators', 'lmdi_plus_time', 'lime_rf_time', 'shap_rf_values_time', 'local_mdi_time']]\n",
    "display_df = display_df.rename(columns={\n",
    "    'data_id': 'OpenML Data ID',\n",
    "    'num_features': '# of Features',\n",
    "    'n_estimators': '# of Estimators',\n",
    "    'min_samples_leaf': 'Min. Samples per Leaf',\n",
    "    'max_features': 'Max Features per Split',\n",
    "    'lmdi_plus_time': 'LMDI+',\n",
    "    'lime_rf_time': 'LIME',\n",
    "    'shap_rf_values_time': 'TreeSHAP',\n",
    "    'local_mdi_time': 'Local MDI'\n",
    "})\n",
    "\n",
    "# sort display_df by min samples leaf increasing and then number of features increasing\n",
    "display_df = display_df.sort_values(by=['# of Estimators', '# of Features'])\n",
    "\n",
    "# round to fourth decimal place\n",
    "display_df = display_df.round(4)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "a5970ab5",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "|   OpenML Data ID |   # of Features |   # of Estimators |   LMDI+ |   LIME |   TreeSHAP |   Local MDI |\n",
      "|-----------------:|----------------:|------------------:|--------:|-------:|-----------:|------------:|\n",
      "|           361254 |              21 |               100 |  0.0082 | 0.0731 |     0.0024 |      0.0008 |\n",
      "|           361259 |              32 |               100 |  0.0111 | 0.0958 |     0.0028 |      0.0008 |\n",
      "|           361253 |              48 |               100 |  0.0284 | 0.1686 |     0.0039 |      0.0009 |\n",
      "|           361242 |              81 |               100 |  0.0414 | 0.1886 |     0.0031 |      0.0008 |\n",
      "|           361254 |              21 |               500 |  0.0474 | 0.2007 |     0.0118 |      0.0037 |\n",
      "|           361259 |              32 |               500 |  0.088  | 0.2927 |     0.0181 |      0.0046 |\n",
      "|           361253 |              48 |               500 |  0.0895 | 0.2611 |     0.0156 |      0.0036 |\n",
      "|           361242 |              81 |               500 |  0.1559 | 0.3007 |     0.0146 |      0.0034 |\n",
      "|           361254 |              21 |              1000 |  0.2232 | 0.3737 |     0.0281 |      0.0084 |\n",
      "|           361259 |              32 |              1000 |  0.2056 | 0.3913 |     0.0296 |      0.0086 |\n",
      "|           361253 |              48 |              1000 |  0.3144 | 0.5009 |     0.0417 |      0.0088 |\n",
      "|           361242 |              81 |              1000 |  0.5098 | 0.5033 |     0.0332 |      0.0077 |\n"
     ]
    }
   ],
   "source": [
    "# get display_df in markdown format\n",
    "markdown_df = display_df.to_markdown(index=False)\n",
    "print(markdown_df)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "9a99041a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\\begin{tabular}{rrrrrrr}\n",
      "\\toprule\n",
      "OpenML Data ID & # of Features & # of Estimators & LMDI+ & LIME & TreeSHAP & Local MDI \\\\\n",
      "\\midrule\n",
      "361254 & 21 & 100 & 0.0082 & 0.0731 & 0.0024 & 0.0008 \\\\\n",
      "361259 & 32 & 100 & 0.0111 & 0.0958 & 0.0028 & 0.0008 \\\\\n",
      "361253 & 48 & 100 & 0.0284 & 0.1686 & 0.0039 & 0.0009 \\\\\n",
      "361242 & 81 & 100 & 0.0414 & 0.1886 & 0.0031 & 0.0008 \\\\\n",
      "361254 & 21 & 500 & 0.0474 & 0.2007 & 0.0118 & 0.0037 \\\\\n",
      "361259 & 32 & 500 & 0.0880 & 0.2927 & 0.0181 & 0.0046 \\\\\n",
      "361253 & 48 & 500 & 0.0895 & 0.2611 & 0.0156 & 0.0036 \\\\\n",
      "361242 & 81 & 500 & 0.1559 & 0.3007 & 0.0146 & 0.0034 \\\\\n",
      "361254 & 21 & 1000 & 0.2232 & 0.3737 & 0.0281 & 0.0084 \\\\\n",
      "361259 & 32 & 1000 & 0.2056 & 0.3913 & 0.0296 & 0.0086 \\\\\n",
      "361253 & 48 & 1000 & 0.3144 & 0.5009 & 0.0417 & 0.0088 \\\\\n",
      "361242 & 81 & 1000 & 0.5098 & 0.5033 & 0.0332 & 0.0077 \\\\\n",
      "\\bottomrule\n",
      "\\end{tabular}\n",
      "\n"
     ]
    }
   ],
   "source": [
    "# get display_df in latex format\n",
    "latex_df = display_df.to_latex(index=False, float_format=\"%.4f\")\n",
    "print(latex_df)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "mdi",
   "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.14"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
