{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/scratch/users/zachrewolinski/conda/envs/mdi/lib/python3.10/site-packages/glmnet/__init__.py:1: UserWarning: pkg_resources is deprecated as an API. See https://setuptools.pypa.io/en/latest/pkg_resources.html. The pkg_resources package is slated for removal as early as 2025-11-30. Refrain from using this package or pin to Setuptools<81.\n",
      "  import pkg_resources\n",
      "/scratch/users/zachrewolinski/conda/envs/mdi/lib/python3.10/site-packages/pkg_resources/__init__.py:3146: DeprecationWarning: Deprecated call to `pkg_resources.declare_namespace('mpl_toolkits')`.\n",
      "Implementing implicit namespace packages (as specified in PEP 420) is preferred to `pkg_resources.declare_namespace`. See https://setuptools.pypa.io/en/latest/references/keywords.html#keyword-namespace-packages\n",
      "  declare_namespace(pkg)\n",
      "/scratch/users/zachrewolinski/conda/envs/mdi/lib/python3.10/site-packages/pkg_resources/__init__.py:3146: DeprecationWarning: Deprecated call to `pkg_resources.declare_namespace('mpl_toolkits.basemap_data')`.\n",
      "Implementing implicit namespace packages (as specified in PEP 420) is preferred to `pkg_resources.declare_namespace`. See https://setuptools.pypa.io/en/latest/references/keywords.html#keyword-namespace-packages\n",
      "  declare_namespace(pkg)\n",
      "/scratch/users/zachrewolinski/conda/envs/mdi/lib/python3.10/site-packages/pkg_resources/__init__.py:2558: DeprecationWarning: Deprecated call to `pkg_resources.declare_namespace('mpl_toolkits')`.\n",
      "Implementing implicit namespace packages (as specified in PEP 420) is preferred to `pkg_resources.declare_namespace`. See https://setuptools.pypa.io/en/latest/references/keywords.html#keyword-namespace-packages\n",
      "  declare_namespace(parent)\n",
      "/scratch/users/zachrewolinski/conda/envs/mdi/lib/python3.10/site-packages/pkg_resources/__init__.py:3146: DeprecationWarning: Deprecated call to `pkg_resources.declare_namespace('mpl_toolkits.basemap_data')`.\n",
      "Implementing implicit namespace packages (as specified in PEP 420) is preferred to `pkg_resources.declare_namespace`. See https://setuptools.pypa.io/en/latest/references/keywords.html#keyword-namespace-packages\n",
      "  declare_namespace(pkg)\n",
      "/scratch/users/zachrewolinski/conda/envs/mdi/lib/python3.10/site-packages/pkg_resources/__init__.py:3146: DeprecationWarning: Deprecated call to `pkg_resources.declare_namespace('mpl_toolkits')`.\n",
      "Implementing implicit namespace packages (as specified in PEP 420) is preferred to `pkg_resources.declare_namespace`. See https://setuptools.pypa.io/en/latest/references/keywords.html#keyword-namespace-packages\n",
      "  declare_namespace(pkg)\n"
     ]
    }
   ],
   "source": [
    "# so kernel doesn't have to be restarted\n",
    "%load_ext autoreload\n",
    "%autoreload 2\n",
    "\n",
    "# helper scripts\n",
    "from knn_helper import *\n",
    "import pandas as pd"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Random Forest Results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "### RANDOM FOREST RESULTS\n",
    "over_shap = []\n",
    "over_lime = []\n",
    "over_lmdi_sutera = []\n",
    "means_lst = []\n",
    "medians_lst = []\n",
    "labels = \"preds\"\n",
    "k = 1\n",
    "nbr_dist = \"l1\"\n",
    "cfact_dist = \"l1\"\n",
    "names = ['Spam', 'Ozone', 'Pol', 'House 16H', 'Higgs', 'Jannis']\n",
    "counter = 0\n",
    "for data_id in [43, 9978, 361062, 361063, 361069, 361071]:\n",
    "    shap_distances = np.loadtxt(f\"results/rf/openml_{data_id}/shap/{labels}/k{k}/nbr-dist-{nbr_dist}_cfact-dist-{cfact_dist}.csv\", delimiter=\",\")\n",
    "    lime_distances = np.loadtxt(f\"results/rf/openml_{data_id}/lime/{labels}/k{k}/nbr-dist-{nbr_dist}_cfact-dist-{cfact_dist}.csv\", delimiter=\",\")\n",
    "    lmdi_sutera_distances = np.loadtxt(f\"results/rf/openml_{data_id}/lmdi/{labels}/k{k}/nbr-dist-{nbr_dist}_cfact-dist-{cfact_dist}.csv\", delimiter=\",\")\n",
    "    lmdi_plus_distances = np.loadtxt(f\"results/rf/openml_{data_id}/lmdi_plus/{labels}/k{k}/nbr-dist-{nbr_dist}_cfact-dist-{cfact_dist}.csv\", delimiter=\",\")\n",
    "    # get means and medians of each:\n",
    "    means = {\n",
    "        \"shap\": np.mean(shap_distances),\n",
    "        \"lime\": np.mean(lime_distances),\n",
    "        \"lmdi_sutera\": np.mean(lmdi_sutera_distances),\n",
    "        \"lmdi+\": np.mean(lmdi_plus_distances),\n",
    "    }\n",
    "    medians = {\n",
    "        \"shap\": np.median(shap_distances),\n",
    "        \"lime\": np.median(lime_distances),\n",
    "        \"lmdi_sutera\": np.median(lmdi_sutera_distances),\n",
    "        \"lmdi+\": np.median(lmdi_plus_distances),\n",
    "    }\n",
    "    \n",
    "    means_lst.append({names[counter]: means})\n",
    "    medians_lst.append({names[counter]: medians})\n",
    "    counter += 1\n",
    "    \n",
    "    over_shap.append(means[\"shap\"]-means[\"lmdi+\"])\n",
    "    over_lime.append(means[\"lime\"]-means[\"lmdi+\"])\n",
    "    over_lmdi_sutera.append(means[\"lmdi_sutera\"]-means[\"lmdi+\"])\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "# of Losses: 0\n"
     ]
    }
   ],
   "source": [
    "print(\"# of Losses:\", sum(np.array([sum(np.array(over_shap) < 0),\n",
    "                                    sum(np.array(over_lime) < 0),\n",
    "                                    sum(np.array(over_lmdi_sutera) < 0)])))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "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>House 16H</th>\n",
       "      <th>Higgs</th>\n",
       "      <th>Pol</th>\n",
       "      <th>Ozone</th>\n",
       "      <th>Jannis</th>\n",
       "      <th>Spam</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>LMDI+</th>\n",
       "      <td>6.530280</td>\n",
       "      <td>17.694568</td>\n",
       "      <td>7.657638</td>\n",
       "      <td>31.974321</td>\n",
       "      <td>39.964031</td>\n",
       "      <td>12.780391</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>LIME</th>\n",
       "      <td>8.027789</td>\n",
       "      <td>19.178099</td>\n",
       "      <td>9.370878</td>\n",
       "      <td>34.205151</td>\n",
       "      <td>44.421518</td>\n",
       "      <td>16.410204</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>TreeSHAP</th>\n",
       "      <td>8.045210</td>\n",
       "      <td>19.960932</td>\n",
       "      <td>9.481639</td>\n",
       "      <td>43.749718</td>\n",
       "      <td>43.501792</td>\n",
       "      <td>16.484652</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Local MDI</th>\n",
       "      <td>11.473445</td>\n",
       "      <td>21.967686</td>\n",
       "      <td>10.750003</td>\n",
       "      <td>36.958241</td>\n",
       "      <td>47.251987</td>\n",
       "      <td>17.843236</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "           House 16H      Higgs        Pol      Ozone     Jannis       Spam\n",
       "LMDI+       6.530280  17.694568   7.657638  31.974321  39.964031  12.780391\n",
       "LIME        8.027789  19.178099   9.370878  34.205151  44.421518  16.410204\n",
       "TreeSHAP    8.045210  19.960932   9.481639  43.749718  43.501792  16.484652\n",
       "Local MDI  11.473445  21.967686  10.750003  36.958241  47.251987  17.843236"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# make medians_lst a dataframe with columns being datasets and rows being methods\n",
    "medians_df = pd.DataFrame({list(d.keys())[0]: list(d.values())[0] for d in medians_lst})\n",
    "# reorder df rows\n",
    "medians_df = medians_df.reindex(['lmdi+', 'lime', 'shap', 'lmdi_sutera'])\n",
    "# rename df row names\n",
    "medians_df.index = ['LMDI+', 'LIME', 'TreeSHAP', 'Local MDI']\n",
    "# reorder df columns\n",
    "medians_df = medians_df[['House 16H', 'Higgs', 'Pol', 'Ozone', 'Jannis', 'Spam']]\n",
    "medians_df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "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>House 16H</th>\n",
       "      <th>Higgs</th>\n",
       "      <th>Pol</th>\n",
       "      <th>Ozone</th>\n",
       "      <th>Jannis</th>\n",
       "      <th>Spam</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>LMDI+</th>\n",
       "      <td>7.649203</td>\n",
       "      <td>18.247936</td>\n",
       "      <td>9.086941</td>\n",
       "      <td>34.694681</td>\n",
       "      <td>40.395984</td>\n",
       "      <td>15.194992</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>LIME</th>\n",
       "      <td>9.503305</td>\n",
       "      <td>19.901391</td>\n",
       "      <td>11.357722</td>\n",
       "      <td>36.343563</td>\n",
       "      <td>44.681014</td>\n",
       "      <td>18.661235</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>TreeSHAP</th>\n",
       "      <td>9.496799</td>\n",
       "      <td>20.618358</td>\n",
       "      <td>10.868890</td>\n",
       "      <td>44.343489</td>\n",
       "      <td>44.287463</td>\n",
       "      <td>19.796848</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Local MDI</th>\n",
       "      <td>12.748603</td>\n",
       "      <td>22.795109</td>\n",
       "      <td>11.150972</td>\n",
       "      <td>39.016900</td>\n",
       "      <td>48.058515</td>\n",
       "      <td>21.118984</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "           House 16H      Higgs        Pol      Ozone     Jannis       Spam\n",
       "LMDI+       7.649203  18.247936   9.086941  34.694681  40.395984  15.194992\n",
       "LIME        9.503305  19.901391  11.357722  36.343563  44.681014  18.661235\n",
       "TreeSHAP    9.496799  20.618358  10.868890  44.343489  44.287463  19.796848\n",
       "Local MDI  12.748603  22.795109  11.150972  39.016900  48.058515  21.118984"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# make means_lst a dataframe with columns being datasets and rows being methods\n",
    "means_df = pd.DataFrame({list(d.keys())[0]: list(d.values())[0] for d in means_lst})\n",
    "# reorder df rows\n",
    "means_df = means_df.reindex(['lmdi+', 'lime', 'shap', 'lmdi_sutera'])\n",
    "# rename df row names\n",
    "means_df.index = ['LMDI+', 'LIME', 'TreeSHAP', 'Local MDI']\n",
    "# reorder df columns\n",
    "means_df = means_df[['House 16H', 'Higgs', 'Pol', 'Ozone', 'Jannis', 'Spam']]\n",
    "means_df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\\begin{tabular}{lrrrrrr}\n",
      "\\toprule\n",
      " & House 16H & Higgs & Pol & Ozone & Jannis & Spam \\\\\n",
      "\\midrule\n",
      "LMDI+ & 7.6 & 18.2 & 9.1 & 34.7 & 40.4 & 15.2 \\\\\n",
      "LIME & 9.5 & 19.9 & 11.4 & 36.3 & 44.7 & 18.7 \\\\\n",
      "TreeSHAP & 9.5 & 20.6 & 10.9 & 44.3 & 44.3 & 19.8 \\\\\n",
      "Local MDI & 12.7 & 22.8 & 11.2 & 39.0 & 48.1 & 21.1 \\\\\n",
      "\\bottomrule\n",
      "\\end{tabular}\n",
      "\n"
     ]
    }
   ],
   "source": [
    "# turn means_df into a latex table\n",
    "print(means_df.to_latex(float_format=\"%.1f\"))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Gradient Boosting Results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [],
   "source": [
    "### GRADIENT BOOSTING RESULTS\n",
    "over_shap = []\n",
    "over_lime = []\n",
    "means_lst = []\n",
    "medians_lst = []\n",
    "labels = \"preds\"\n",
    "k = 1\n",
    "nbr_dist = \"l1\"\n",
    "cfact_dist = \"l1\"\n",
    "names = ['Spam', 'Ozone', 'Pol', 'House 16H', 'Higgs', 'Jannis']\n",
    "counter = 0\n",
    "for data_id in [43, 9978, 361062, 361063, 361069, 361071]:\n",
    "    shap_distances = np.loadtxt(f\"results/gb/openml_{data_id}/shap/{labels}/k{k}/nbr-dist-{nbr_dist}_cfact-dist-{cfact_dist}.csv\", delimiter=\",\")\n",
    "    lime_distances = np.loadtxt(f\"results/gb/openml_{data_id}/lime/{labels}/k{k}/nbr-dist-{nbr_dist}_cfact-dist-{cfact_dist}.csv\", delimiter=\",\")\n",
    "    lmdi_plus_distances = np.loadtxt(f\"results/gb/openml_{data_id}/lmdi_plus/{labels}/k{k}/nbr-dist-{nbr_dist}_cfact-dist-{cfact_dist}.csv\", delimiter=\",\")\n",
    "    # get means and medians of each:\n",
    "    means = {\n",
    "        \"shap\": np.mean(shap_distances),\n",
    "        \"lime\": np.mean(lime_distances),\n",
    "        \"lmdi+\": np.mean(lmdi_plus_distances),\n",
    "    }\n",
    "    medians = {\n",
    "        \"shap\": np.median(shap_distances),\n",
    "        \"lime\": np.median(lime_distances),\n",
    "        \"lmdi+\": np.median(lmdi_plus_distances),\n",
    "    }\n",
    "    \n",
    "    means_lst.append({names[counter]: means})\n",
    "    medians_lst.append({names[counter]: medians})\n",
    "    counter += 1\n",
    "    \n",
    "    over_shap.append(means[\"shap\"]-means[\"lmdi+\"])\n",
    "    over_lime.append(means[\"lime\"]-means[\"lmdi+\"])\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "# of Losses: 0\n"
     ]
    }
   ],
   "source": [
    "print(\"# of Losses:\", sum(np.array([sum(np.array(over_shap) < 0),\n",
    "                                    sum(np.array(over_lime) < 0)])))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "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>House 16H</th>\n",
       "      <th>Higgs</th>\n",
       "      <th>Pol</th>\n",
       "      <th>Ozone</th>\n",
       "      <th>Jannis</th>\n",
       "      <th>Spam</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>LMDI+</th>\n",
       "      <td>5.737791</td>\n",
       "      <td>17.838713</td>\n",
       "      <td>6.034750</td>\n",
       "      <td>31.861186</td>\n",
       "      <td>41.334131</td>\n",
       "      <td>11.467630</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>LIME</th>\n",
       "      <td>8.123942</td>\n",
       "      <td>19.055273</td>\n",
       "      <td>10.038613</td>\n",
       "      <td>36.865215</td>\n",
       "      <td>45.176987</td>\n",
       "      <td>21.916890</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>TreeSHAP</th>\n",
       "      <td>7.099951</td>\n",
       "      <td>18.482246</td>\n",
       "      <td>8.522499</td>\n",
       "      <td>34.352284</td>\n",
       "      <td>43.865658</td>\n",
       "      <td>14.098376</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "          House 16H      Higgs        Pol      Ozone     Jannis       Spam\n",
       "LMDI+      5.737791  17.838713   6.034750  31.861186  41.334131  11.467630\n",
       "LIME       8.123942  19.055273  10.038613  36.865215  45.176987  21.916890\n",
       "TreeSHAP   7.099951  18.482246   8.522499  34.352284  43.865658  14.098376"
      ]
     },
     "execution_count": 19,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# make medians_lst a dataframe with columns being datasets and rows being methods\n",
    "medians_df = pd.DataFrame({list(d.keys())[0]: list(d.values())[0] for d in medians_lst})\n",
    "# reorder df rows\n",
    "medians_df = medians_df.reindex(['lmdi+', 'lime', 'shap'])\n",
    "# rename df row names\n",
    "medians_df.index = ['LMDI+', 'LIME', 'TreeSHAP']\n",
    "# reorder df columns\n",
    "medians_df = medians_df[['House 16H', 'Higgs', 'Pol', 'Ozone', 'Jannis', 'Spam']]\n",
    "medians_df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "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>House 16H</th>\n",
       "      <th>Higgs</th>\n",
       "      <th>Pol</th>\n",
       "      <th>Ozone</th>\n",
       "      <th>Jannis</th>\n",
       "      <th>Spam</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>LMDI+</th>\n",
       "      <td>6.800225</td>\n",
       "      <td>18.470154</td>\n",
       "      <td>7.698557</td>\n",
       "      <td>34.321992</td>\n",
       "      <td>41.848724</td>\n",
       "      <td>13.384658</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>LIME</th>\n",
       "      <td>9.605768</td>\n",
       "      <td>20.027935</td>\n",
       "      <td>12.005236</td>\n",
       "      <td>40.992963</td>\n",
       "      <td>45.639559</td>\n",
       "      <td>24.332827</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>TreeSHAP</th>\n",
       "      <td>8.468283</td>\n",
       "      <td>19.170825</td>\n",
       "      <td>10.173399</td>\n",
       "      <td>37.364389</td>\n",
       "      <td>43.812058</td>\n",
       "      <td>16.352601</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "          House 16H      Higgs        Pol      Ozone     Jannis       Spam\n",
       "LMDI+      6.800225  18.470154   7.698557  34.321992  41.848724  13.384658\n",
       "LIME       9.605768  20.027935  12.005236  40.992963  45.639559  24.332827\n",
       "TreeSHAP   8.468283  19.170825  10.173399  37.364389  43.812058  16.352601"
      ]
     },
     "execution_count": 20,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# make means_lst a dataframe with columns being datasets and rows being methods\n",
    "means_df = pd.DataFrame({list(d.keys())[0]: list(d.values())[0] for d in means_lst})\n",
    "# reorder df rows\n",
    "means_df = means_df.reindex(['lmdi+', 'lime', 'shap'])\n",
    "# rename df row names\n",
    "means_df.index = ['LMDI+', 'LIME', 'TreeSHAP']\n",
    "# reorder df columns\n",
    "means_df = means_df[['House 16H', 'Higgs', 'Pol', 'Ozone', 'Jannis', 'Spam']]\n",
    "means_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": 4
}
