{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import yaml\n",
    "import pickle\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "plt.rcParams.update({'font.size': 16})\n",
    "import seaborn as sns\n",
    "\n",
    "from utils.plots import subplots"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "experiment = 'markovian'\n",
    "version = 'v0.1.0'\n",
    "n_samples = 1000\n",
    "SEEDS = list(range(30))\n",
    "\n",
    "folder_ = os.path.join(\n",
    "    os.getenv('RESULTS_DIR'), \n",
    "    experiment,\n",
    "    version.replace('.', '_'),\n",
    "    f'n_samples_{n_samples}',\n",
    "    'seed_{seed}'\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "PLOTS_FOLDER = os.path.join('results', 'synthetic', experiment, 'plots')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(30, 720, 100, 6)"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "dgp, mrg, lin, dcn, dcg, cnf = lists = [], [], [], [], [], []\n",
    "\n",
    "for seed in SEEDS:\n",
    "    folder = folder_.format(seed=seed)\n",
    "\n",
    "    with open(os.path.join(folder, 'metrics', 'dgp_shap.pkl'), 'rb') as f:\n",
    "        dgp.append(pickle.load(f)['mean'])\n",
    "\n",
    "    with open(os.path.join(folder, 'metrics', 'marginal_shap.pkl'), 'rb') as f:\n",
    "        mrg.append(pickle.load(f)['mean'])\n",
    "\n",
    "    with open(os.path.join(folder, 'metrics', 'dcg_linear_shap.pkl'), 'rb') as f:\n",
    "        lin.append(pickle.load(f)['mean'])\n",
    "\n",
    "    with open(os.path.join(folder, 'metrics', 'dcn_shap.pkl'), 'rb') as f:\n",
    "        dcn.append(pickle.load(f)['mean'])\n",
    "\n",
    "    with open(os.path.join(folder, 'metrics', 'dcg_shap.pkl'), 'rb') as f:\n",
    "        dcg.append(pickle.load(f)['mean'])\n",
    "\n",
    "    try:\n",
    "        with open(os.path.join(folder, 'metrics', 'cnf_shap.pkl'), 'rb') as f:\n",
    "            cnf.append(pickle.load(f)['mean'])\n",
    "    except:\n",
    "        pass\n",
    "\n",
    "dgp, mrg, lin, dcn, dcg, cnf = map(\n",
    "    lambda x: np.stack(x) if x else None, lists\n",
    ")\n",
    "dgp.shape  # (replications, iterations, samples, dimensions)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "preds = [mrg, lin, dcn, dcg, cnf]\n",
    "labels = ['marginal', 'linear', 'DCN', 'DCG', 'CNF']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "I, N, _, K = dgp.shape\n",
    "\n",
    "\n",
    "def plot_ci(mean, std, alpha=1., ax=None, label=None, **kwargs):\n",
    "    if ax is None:\n",
    "        ax = plt.gca()\n",
    "\n",
    "    ax.plot(mean, label=label, **kwargs)\n",
    "    ax.fill_between(\n",
    "        np.arange(len(mean)),\n",
    "        mean - alpha * std,\n",
    "        mean + alpha * std,\n",
    "        alpha=.25,\n",
    "        **kwargs\n",
    "    )\n",
    "\n",
    "\n",
    "def shap_loss(real, pred, agg: bool = True, last: bool = True):\n",
    "    losses = ((pred - real) ** 2).mean(-1)  # per sample\n",
    "    if agg:\n",
    "        losses = losses.mean(-1)\n",
    "    if last:\n",
    "        losses = losses[:, -1]\n",
    "\n",
    "    return losses"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Distribution adjustment"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "loglk = []\n",
    "for seed in SEEDS:\n",
    "    folder = folder_.format(seed=seed)\n",
    "\n",
    "    with open(os.path.join(folder, 'metrics', 'dcg_linear_losses.yaml'), 'r') as f:\n",
    "        loglk.append(yaml.safe_load(f) | {'estimator': 'linear'})\n",
    "\n",
    "    with open(os.path.join(folder, 'metrics', 'dcn_losses.yaml'), 'r') as f:\n",
    "        loglk.append(yaml.safe_load(f) | {'estimator': 'DCN'})\n",
    "\n",
    "    with open(os.path.join(folder, 'metrics', 'dcg_losses.yaml'), 'r') as f:\n",
    "        loglk.append(yaml.safe_load(f) | {'estimator': 'DCG'})\n",
    "\n",
    "    try:\n",
    "        with open(os.path.join(folder, 'metrics', 'cnf_losses.yaml'), 'r') as f:\n",
    "            loglk.append(yaml.safe_load(f) | {'estimator': 'CNF'})\n",
    "    except:\n",
    "        pass\n",
    "    \n",
    "loglk = pd.DataFrame(loglk)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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1BiyP/L09NStt95a2ssAAABUWaUOZNKVNSvT0tIkSbVr15aLi6nZNAAAAKqkUiWnDRs2qG/fvqpRo4bq1aunevXqycfHR/369dOGDRucVSMAAEClZjqQTZkyRb1799a6deuUmZkpwzBkGIYyMzO1du1a9e7dW1OnTnVmrQAAAJWSqUC2fv16TZo0SdWqVdNjjz2m3bt3Kz09Xenp6dqzZ4/+9re/yd3dXS+//LK++eYbZ9cMAABQqZh6ynLgwIFavXq11qxZoz59+hR6zLp169SvXz/1799fK1asKHWh1xKesgSAgnJycrR582YdO3ZMDRo0UNeuXeXq6mp1WYBlynzai3r16ql58+bavHlzkcd17dpV+/fv18mTJ0vaxDWNQAYA+S1btkxPPfWUUlNT7dsCAgL0xhtvaNCgQdYVBlioJHnB1C3Ls2fPqkmTJsUe16RJE507d85MEwCACmLZsmUaPHiwWrVqpW3btikjI0Pbtm1Tq1atNHjwYC1btszqEoFrnqkeskaNGqlBgwbatWtXkce1b99ex44d05EjR0wX6CwpKSmaNWuW1q5dq8OHD8vNzU0NGzZUp06d9OKLL6pp06YOX4seMgC4IicnR0FBQWrVqpWWL1+eb9qj3NxcRUZGat++fUpKSuL2JaqcMu8h69y5s3bv3q1PP/30qsd88sknio+PV5cuXcw04VSfffaZbrrpJr3zzjvy9PTUgAED1KNHD7m6uio6Olo///yz1SUCQIW0efNmpaam6oUXXigwB6WLi4smTJiglJSUYoe4AFWdqYlhn3nmGS1btkwjR47U8uXLNWrUKAUGBkqSkpOTFR0dreXLl8vV1VVPP/20UwsuqQ0bNigqKkp169bVokWL1LVr13z7U1NT5eHhYVF1AFCxHTt2TJLUsmXLQvfnbc87DkDhTAWyDh066F//+pfGjRunJUuWaOnSpfn2G4YhNzc3vfvuu+rQoYNTCjUjJydHY8aMUW5urpYuXVroEk8BAQHlXxgAVBINGjSQJO3bt0+33HJLgf379u3LdxyAwpVqcfF9+/bprbfe0rfffmsfJ9aoUSP16NFDf//736/6L6bysnz5ct19993q0qWLU7vLGUMGAFcwhgy4unJbXLxly5aaO3duaS5RptauXStJ6tatm7Kzs7VixQpt3bpVmZmZCggI0F133aWQkBCLqwSA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AABUdZV6UP/VbN68WUlJSapWrZpl49sAAADyOC2QnTlzRgcPHnTW5crUvHnzJEn9+/dX3bp1La4GAABUdU4LZE899VSFmD4iIyNDixcvluT47cqLFy8qPT093xcAAICzODSGzFHOnPT/2Wef1cqVK0t83ty5c9WlS5er7l+4cKF+//13NWzYUH379nXomtOnT9fkyZNLXAsAAIAjnBrInOno0aPav39/ic87f/58kfvzbleOGjVKrq6uDl1zwoQJevLJJ+2v09PT5e/vX+LaAAAACnPNBrKYmBjFxMQ49ZqJiYnatm2bJOnBBx90+DwPDw95eHg4tRYAAIA8Veopy7zese7duysoKMjiagAAAK5wWiALCQlRt27dnHU5p8vOzrYvAcXcYwAA4Fri0NJJlcGKFSsUGRmpmjVr6tixY/Ly8jJ9LZZOAgAAxSlJXqgytyzzblcOHz68VGEMAADA2UwN6nd0Alh3d3fVrl1b7u7uZppxmhMnTmjNmjWSSjaYHwAAoDyYCmQBAQEOLzbu4uKiFi1a6MEHH9Rjjz0mF5fy75SrV6+eLl++XO7tAgAAOMJUOmrcuLEaN24swzDsX76+vqpZs2a+bf7+/nJ1ddWPP/6o8ePH684771Rubq6z3wMAAECFZiqQpaSk6JZbblG9evX0zjvv6LffftNvv/2mM2fO6OzZs3r33XdVv3593XLLLcrIyNDGjRsVFBSkdevWae7cuc5+DwAAABWaqacsZ8+ereeff167d+9WSEhIocckJiaqbdu2mj59usaPH699+/apbdu26ty5s7799ttSF24lnrIEAADFKUleMBXIWrdurYYNG+qrr74q8ri+ffvqyJEj2rt3rySpY8eOSk5O1unTp0va5DWFQAYAAIpT5tNe/PLLL6pTp06xx9WuXVvJycn214GBgcrIyDDTJAAAQKVlKpB5e3tr586dRR5jGIZ27dolb29v+7bMzEz5+PiYaRIAAKDSMhXIunXrpl9++UXPPfeccnJyCuzPzc3VhAkT9N///lfdu3e3b09OTlajRo3MVwsAAFAJmRpD9tNPP6ljx47KyspSkyZNNGTIEPvcZKmpqVq8eLFSU1Pl6empHTt2qGXLlkpNTVXTpk312GOP6e233y6L91JuGEMGAACKU+aD+iXp22+/1X333aejR48WmCTWMAw1aNBAMTExioiI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eLE8PDzsxyxatEiXL18u0GsGAACA/Ez1kEnSSy+9pOeff17p6eny8/MrsL9Xr17avXu3mjVrVqoC4ZikpCRlZGSUa5t5g6rLe3A1t6kAAJWN6UAmSe7u7oWGMUlq3LhxgakxUDaSkpLUvHlzy9qPiooq9zYPHDhAKAMAVBqlCmSS9PPPP+u7777TqVOn1KJFCw0cOFCSlJubq+zsbLm7u5e6SBQtr2esvAdUWzXVQVRUVLn3BgIAUJZMB7JDhw5p9OjRio2NtW8bNWqUPZD9+9//1qOPPqp169bptttuK32lKJYVA6o7d+5cru0BAFAZmRrUf+bMGXXv3l3ffPONWrRooUceeUSGYeQ75t5775WLi4tWrlzplEIBAAAqK1OBbMaMGUpNTdXTTz+tH374Qe+8806BY6677jq1atVKW7ZsKXWRpbVmzRoNGDBA9evXV7Vq1eTj46Pw8HBNnTqVW18AAMBypgLZihUrFBAQoNdee63ImfibNm2qo0ePmi7OGZ577jndeeedWrVqlfz9/XXPPfeoU6dOSkxM1Isvvqjw8HCdOHHC0hoBAEDVZiqQ/frrrwoLC5OLS9Gnu7u768yZM6YKc4bdu3dr5syZqlatmtatW6edO3fq888/17p165Samqo2bdooKSlJL7/8smU1AgAAmApknp6eDt3qO3jwYIFFyMvTN998I+nKnGi9evXKt+/666/Xs88+K0natm1budcGAACQx1QgCwkJUXx8vH7//ferHnP69Gn98MMPat26teniSsvT09Oh4642lxoAAEB5MBXIBg8erLS0ND355JPKzc0t9JhnnnlGFy5c0NChQ0tVYGncfvvtcnNz09dff63169fn23fq1CnNnDlT0pW1OQEAAKziUCDr2bOnPbxI0rhx49SyZUvNnTtXHTt21KuvvipJ+uWXXzRr1ix16tRJCxYsUNu2bfXAAw+USeGOuPHGGzVnzhwZhqFevXqpY8eOGjZsmPr06aOAgACdPHlS//73v3XvvfdaViMAAIBDE8Nu3LhRAQEB9teenp5au3athgwZou+++067d++WJG3ZskVbtmyRYRjq0KGDli9frmrVqpVJ4Y56+OGH1bRpU91///3auXOndu7cad/Xv39/tW/fvthrXLx4URcvXrS/Tk9PL5NaAQBA1WR6pv4GDRpoy5YtWrt2rVavXq3k5GTl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6an27dvr7bffVnBwMIHMAlu3brX3PFSvXl01a9ZUq1at1L59ew0dOrTICTtr1KihhQsXavz48Zo/f742b96sTZs26cKFC6pVq5ZatmypPn36aNSoUfYnbR01Y8YM3XzzzaV6bygZKz8Lffv2VUpKiqKjo7VmzRr98MMP+umnn2QYhurUqaOWLVtq3LhxGjFihJo2bVpm3wP8T926dRUbG6uvvvpKn332mb777jtt2LBBFy9eVJ06ddSpUyfdeeeduv/++4tdXimPm5ubpk2bpnvvvbeMq6/YbMbVHm8DAABAuWAMGQAAgMUIZAAAABYjkAEAAFiMQAYAAGAxAhkAAIDFCGQAAAAWI5ABAABYjEAGAABgMQIZAACAxQhkACwVEBAgm81W7Fd0dHSZ1TBp0iTZbDZNmjSpzNoAgKKwliWAa0Lnzp0VFBR01f1F7SvKxo0bFRERoe7du1f4hcttNpskiRXvgMqHQAbgmjBmzBg98MADlrT92GOPadiwYfLz87OkfQAgkAGo8vz8/AhjACzFGDIAFU5SUpIefPBBBQYGysPDQzVq1FCTJk105513av78+fbjevTooYiICEnSt99+m29MWkBAgP24q40hi46Ols1m0wMPPKBz587pySefVEBAgDw9PRUcHKwZM2YoNzdXknTkyBE99NBD8vf3l4eHh2688UbNmTOn0Pp//fVXzZgxQz179lTjxo3l4eGhWrVqqUuXLnr//fft1/xzfXn+PL4uNTU13/Fr165V//79VbduXbm7u6thw4YaOnSodu3aVWg9PXr0kM1m08aNG7V582YNGDBA119/vVxcXMp07B6A/6GHDECFsm/fPnXu3Fnp6em68cYb1b9/f7m6uurw4cPatGmTjhw5otGjR0uS+vbtK09PT61du1b16tVT37597dcpSY/Y2bNn1alTJ6Wlpalr167KyMjQ5s2b9fzzz+vw4cN64okn1KVLF1WrVk233nqrTp06pU2bNunxxx/XhQsX9Nxzz+W73scff6wXX3xRgYGBat68uTp37qxjx45p27Zt2rp1q9atW6clS5bYQ1jbtm01atQoffTRR5KkUaNG5btejRo17P/94osvaurUqbLZbLr11lvVuHFjJSQkaNGiRVq6dKk++OADPfjgg4W+z8WLF+u9995TSEiIbr/9dp05c0YeHh4Of58AlIIBABZq0qSJIcmYP3++Q8ePHj3akGRMnTq1wL4LFy4Y3377bb5tsbGxhiSje/fuV73myy+/bEgyXn755Xzb58+fb0gyJBkDBgwwfv/9d/u+uLg4w83NzXBxcTFuuukm4+GHHzYuX75s3798+XJDkuHr65vvPMMwjO+//97Yu3dvgTqOHDlitGnTxpBkLFq0qMD+vFqu5ssvvzQkGZ6ensa6devy7Zs7d64hyahWrZqxb9++fPu6d+9uv/a777571esDKDvcsgRwTRg9enSR016cPXtWknTixAlJ0h133FHgGl5eXurWrZvTa6tRo4bmzp0rb29v+7awsDDdcccdys3N1fnz5/Xmm2/Kze1/Nx3uuusutWrVSunp6QVuFXbo0EEtW7Ys0E7Dhg01c+ZMSVd6q0rq9ddflyQ9+uij6tWrV759f/nLX9S/f39dvnxZs2fPLvT8nj176tFHHy1xuwBKj1uWAK4JxU174e7uLknq2LGj1qxZo0ceeUSTJ09W9+7d5enpWaa1hYeHq27dugW2BwcHS5IiIiIKrSE4OFh79+7V0aNHC+y7ePGi1q1bp507d+rkyZO6ePGiDMNQRkaGJGn//v0lqjE7O1tbt26VpKs+rfqXv/xFq1atUmxsbKH7Bw8eXKI2ATgPgQzANcHRaS+eeeYZbdmyRevXr1ffvn1VrVo1tWnTRt26ddOwYcPUoUMHp9fWuHHjQrfnjd262n4fHx9JUlZWVr7t27dv19ChQ3Xw4MGrtpmenl6iGtPS0uztBAYGFnpMs2bNJF15AKEwf3zQAUD54pYlgArF29tbX3/9tb7//ntNmTJFt912mw4cOKBZs2apY8eOGjdunNPbdHEp+ldlcfv/6MKFC4qMjNTBgwc1evRoff/99zpz5oyys7NlGIa9Z8ywYPJXLy+vcm8TwBX0kAGokDp06GDvDcvOztby5cs1cuRI/fOf/9TgwYPt011cazZt2qQTJ04oLCxM8+bNK7A/KSnJ1HXr1KkjDw8PXbx4UcnJyWrdunWBY5KTkyVJjRo1MtUGgLJDDxmACs/NzU2DBw9Wnz59JEl79uyx78sbe5adnW1FaQWcOXNG0tVvc8bExFz13GrVqkkq/L24ubmpS5cuknTVucPyAuC1GlaBqoxABqBC+ec//1nogPfjx4/bn2Zs0qSJffsNN9wg6UrP0+XLl8unyCKEhoZKkjZs2KCff/45374PPvhACxcuvOq5ee/lp59+KnT/U089JUn617/+pQ0bNuTbFx0drZUrV6patWr6+9//brp+AGWDW5YArglz584tcvHv3r17a8SIEfrggw80btw4BQYGqmXLlvL19dWpU6e0efNmZWZmqmfPnho4cKD9vMaNG6t9+/batWuXWrVqpfbt28vT01N+fn567bXXyuGd5deuXTvdddddWrFihdq1a6cePXqodu3a2rNnj/bv368XXnhB06ZNK/Tce+65R6+//rpuv/129ezZ0/7QwIwZM1SnTh3169dPEydO1NSpU9WrVy917txZjRs3VmJiouLj4+Xq6qr33ntPLVq0KM+3DMABBDIA14StW7fap20oTK1atTRixAhNmzZNq1ev1vbt27V9+3adO3dOdevW1c0336zRo0dr+PDh+eYDk6SlS5dqwoQJio2N1cKFC5Wdna0mTZpYEsikK3OMzZ49WwsWLNCWLVvk6emp9u3b6+2331ZwcPBVA9krr7wiFxcXLVu2TMuXL9elS5ckSRMnTlSdOnXsx3Tu3Flz5szRjh07tH37dvn5+WnIkCF6+umn1bFjx3J7nwAcZzOseJQHAAAAdowhAwAAsBiBDAAAwGIEMgAAAIsRyAAAACxGIAMAALAYgQwAAMBiBDIAAACLEcgAAAAsRiADAACwGIEMAADAYgQyAAAAixHIAAAALEYgAwAAsNj/A7SplmgF/fbvAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "loglk = []\n",
    "for seed in SEEDS:\n",
    "    folder = folder_.format(seed=seed)\n",
    "\n",
    "    with open(os.path.join(folder, 'metrics', 'dcg_linear_losses.yaml'), 'r') as f:\n",
    "        loglk.append(yaml.safe_load(f) | {'estimator': 'linear'})\n",
    "\n",
    "    with open(os.path.join(folder, 'metrics', 'dcn_losses.yaml'), 'r') as f:\n",
    "        loglk.append(yaml.safe_load(f) | {'estimator': 'DCN'})\n",
    "\n",
    "    with open(os.path.join(folder, 'metrics', 'dcg_losses.yaml'), 'r') as f:\n",
    "        loglk.append(yaml.safe_load(f) | {'estimator': 'DCG'})\n",
    "\n",
    "    try:\n",
    "        with open(os.path.join(folder, 'metrics', 'cnf_losses.yaml'), 'r') as f:\n",
    "            loglk.append(yaml.safe_load(f) | {'estimator': 'CNF'})\n",
    "    except:\n",
    "        pass\n",
    "    \n",
    "loglk = pd.DataFrame(loglk)\n",
    "\n",
    "\n",
    "models = ['linear', 'DCN', 'DCG']\n",
    "if 'CNF' in loglk.estimator.values:\n",
    "    models.append('CNF')\n",
    "\n",
    "plt.boxplot(\n",
    "    [loglk[loglk.estimator == e].test_loglk for e in models],\n",
    "    labels=models\n",
    ")\n",
    "plt.xlabel('Estimator')\n",
    "plt.ylabel('Test log-likelihood (↑)')\n",
    "\n",
    "plt.tight_layout()\n",
    "plt.savefig(os.path.join(PLOTS_FOLDER, 'loglk.png'), bbox_inches='tight', dpi=300);\n",
    "plt.savefig(os.path.join(PLOTS_FOLDER, 'loglk.pdf'), bbox_inches='tight', dpi=300);"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Compute $L_2$"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "marginal loss: 0.09088033191361648 +- 0.0021437709231418283\n",
      "linear loss: 0.11823642910434295 +- 0.003973685586152516\n",
      "DCN loss: 0.007343579144226358 +- 0.0003659879343134597\n",
      "DCG loss: 0.007797817562159976 +- 0.0027594628981618013\n",
      "CNF loss: 0.005279329602057003 +- 0.0005786339156852109\n"
     ]
    },
    {
     "data": {
      "image/png": "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EFu3btVETFQJXRwhIyIiorI0MkL2stOnT6Np06YqBUdERERE8lRKyHr06KHuOIiIiIhqLZWWvUhNTcXvv/+Oe/fuyR2/ceMGevbsifr168PDwwMnTpxQS5BERERE+kylhGz16tV46623kJ+fLzuWn5+P3r174+zZs5BIJLh69SoGDRqEpKQktQVLREREpI9USsjOnTsHJycntG3bVnZs586dyMjIwJAhQ5CQkICvvvoKhYWFWLdundqCJSIiItJHKs0he/DgQZl1p44ePQqRSITvvvsOLVq0QIcOHfDLL7/g1KlTagmUiIiISF+pNEL277//okGDBnLHLl26hHbt2qFFixayY66urmXmmRERERGRPJUSMnNzczx+/Fj2PiUlBQ8ePICPj49cPSMjIxQXF1cvQiIiIiI9p1JC1q5dO0RFRcmSsp07d0IkEqFbt25y9dLS0tCkSZNqBbhnzx74+fmhfv36MDc3h5ubG1atWoWioiKV+ouNjcWIESPQpEkT1K1bFw4ODpgxYwYePXpUbv2UlBSIRKJKX/Pnz6/wfM+fP8fKlSvh5uYGc3Nz1K9fH35+fti7d69K8RMREZH+UWkO2YQJE3Dx4kV4eXnB09MThw8fhoWFBQYNGiSr8+zZM8TFxcHf31/l4GbNmoWQkBAYGRnB398fYrEYp06dwrx583Dw4EEcP35cqW139u7di9GjR6O4uBje3t5wcHBATEwM1q1bhz179iAqKgqOjo7ltjU3N8fw4cPLLatoH8eCggL06dMHFy5cQL169dC/f3/k5eXh1KlTOHv2LObOnYvVq1crHD8RERHpKUEFpaWlwsSJEwWRSCSIRCLB0tJS2Ldvn1ydXbt2CSKRSFi1apUqpxD2798vABDEYrEQGxsrO/748WPB1dVVACDMnTtX4f7S09MFMzMzAYCwceNG2fHi4mJh7NixAgDB29tbKC0tlWuXnJwsABBatmyp9DV89NFHAgDB1dVVePz4sex4TEyMIBaLBQDCwYMHlepTIpEIAASJRKJ0PERERPTqKPObrVJCJpWamipER0cLubm5Zcri4+OF8PBw4eHDhyr17e3tLQAQlixZUqYsMjJSACCYmJgI2dnZCvX3ySefCACE3r17lynLzc0VrKysBADC0aNH5cpUTciePHkiGBsbCwCEqKioMuWLFy8WAAidO3dWql8mZERE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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "errors = {\n",
    "    label: shap_loss(dgp, pred, agg=True, last=True)\n",
    "    for label, pred in zip(labels, preds)\n",
    "    if pred is not None\n",
    "}\n",
    "\n",
    "plt.boxplot(errors.values(), labels=errors.keys())\n",
    "plt.xlabel('Estimator')\n",
    "plt.ylabel('SHAP Estimation Loss (↓)')\n",
    "plt.tight_layout()\n",
    "plt.savefig(os.path.join(PLOTS_FOLDER, 'shap_loss.png'), bbox_inches='tight', dpi=300);\n",
    "plt.savefig(os.path.join(PLOTS_FOLDER, 'shap_loss.pdf'), bbox_inches='tight', dpi=300);\n",
    "\n",
    "for label, error in errors.items():\n",
    "    mean = error.mean(0)\n",
    "    std = error.std(0) / np.sqrt(I)\n",
    "\n",
    "    print(f'{label} loss: {mean} +- {std}')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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bX5ERERypscNngFOO+00rrzySn7zm99w+OGHM2vWLAoLC3nxxReprq5m+vTp7QZZqqmpYdWqVTQ3N6ct37JlC2eccQaxWIyKigpef/11Xn/99YzH/eUvf5k2X0lBQQEPP/wwJ5xwAjfffDNPPPEEBx54ICtXrmTlypUUFhayYMEC8vPze3OafU7Bj4iISO71KvgBmDdvHtOnT+fOO+/k9ddfJx6Ps9dee3HttddyzTXXdHtG2cbGRn+QwU8//ZT77ruvw21//OMft5usbfr06bzzzjvMnTuXF154gUcffZShQ4dy4YUXcsMNN7DXXnv19hT7nIIfERGR3LOMMZppKkVtbS2lpaXU1NT0uqt+R45+8Gi2R7fzy6N/yYnjT+zTtEVEUjU3N7N69WrGjx9PXl5errMj0is9eR335Pm90w5yuDvyu7qj3l4iIiK5ouAni1TtJSKycxk3bhyWZbFmzRp/2ezZs7Esi/nz5+csX9K/FPxkkYIfERGR3FPwk0V+8OMq+BER2VndcsstfPDBB/5YcrL76XVvL+k5b4RnlfyIiOy8Ro4cyciRI3OdDelHKvnJIo3wLCKy8+uozc+Pf/xjLMvixz/+MVu3buXb3/42o0ePJhwOM3r0aK644gqqq6s7TPfDDz/ksssuY6+99iIvL4/S0lKOPvpo7r///ozbr127lp///Occe+yxjBkzhkgkQllZGTNmzOD3v/99xlqENWvWYFkW48aNw3Ecfv3rXzNp0iSKioqwLGtHLstuRSU/WeT39tLcXiIiu6z169czefJk4vE406dPp7m5mcWLF3PHHXewZMkSFi9eTCgUSttnwYIFXHjhhTQ3NzNx4kROOeUUampqWLJkCRdccAEvvfQS9957b9o+//d//8f111/P+PHjmTBhAtOnT2fTpk288cYbLF68mOeee45HHnkkY1BjjOGMM87g73//O0cddRT77bcf7733Xr9el12Jgp8sUoNnEdlZGGNoSjTlOhu9kh/Mz2kpxr333svs2bO5++67iUQiQDIgOuKII1i6dCmPPPII5513nr/9u+++ywUXXIBlWTz66KNp802uXbuWL33pS/zpT39i5syZadMxnXjiiZx22mkceOCBacffuHEjp5xyCo899hiPPPIIZ511Vrs8rlu3Dtd1effdd5kwYUJfX4JdnoKfLFLwIyI7i6ZEE597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Zs0yQMYP0oaGBjNq1CgDmDlz5qStmzNnjgHM6NGjFSxnUUNDg9lnn33MHnvsYU477bQOgx/d811bY2OjmThxogHMj3/8YxOLxdLWNzQ0mBUrVqQt0z3f9Sn46UdTp041gLnpppvarXvttdcMYCKRiKmurs5B7mRHfP3rXzeAmTVrVtrys846ywDmkksuabfPmjVrjG3bBjAffPBB2ro777zTAGbChAnGcZy0dY7jmAkTJhjA3H333X1/MpLRlVdeaQDz1FNPmYsuuqjD4Ef3fNd2/fXX+yW53aV7vutTm59+smHDBpYuXQrA+eef3279jBkzGD16NNFolKeffjrb2ZMdNGnSJADWr1/vL4vFYn5boEz3fOzYsUyfPh2AhQsXpq3z/j733HPbTchn2zbnnHMOAI899lgfnYF05uWXX+a3v/0tF154IaecckqH2+me79ri8Ti/+93vAPj+97/frX10z3cPCn76yYoVKwAYPHgw48ePz7jNlClT0raVXcdHH30EwMiRI/1lH374IY2NjUDrvW2ro3vu/d3T/aTv1dfX81//9V8MHz6c22+/vdNtdc93bcuXL6eyspJRo0ax99578+677/KTn/yEyy67jGuvvZannnoK13XT9tE93z1oVvd+snr1agDGjBnT4TajR49O21Z2DZ999hnz588H4Mwzz/SXe/exrKyM4uLijPtmuud1dXVUVVUBHb9evP22bt1KQ0MDhYWFO3YS0qH//u//ZvXq1SxcuJBBgwZ1uq3u+a7tX//6FwAVFRVce+213HbbbZiUSQ9+/vOfM2nSJB5//HH/Pume7x5U8tNP6urqADp98RYVFQFQW1ublTzJjkskEnzta1+jpqaGgw46iMsuu8xf19t77u3X2b7efm33lb713HPP8fvf/55zzz2X0047rcvtdc93bV4wsmLFCn7+859z+eWXs2rVKmpqanj++eeZMGECK1as4Atf+II/NInu+e5BwY9ID3zzm9/kxRdfZMiQITzyyCOEw+FcZ0n6SE1NDV//+tcZOnQov/3tb3OdHckCr5QnHo9z3nnncccddzBhwgRKSko47rjjeP7558nLy2PlypU8+OCDOc6t9CUFP/3EKw5taGjocBtvIKySkpKs5El2zFVXXcUf//hHBg0a5H8rTNXbe55adN7RvqmDpun10j+uvvpqPv30U+644w7Ky8u7tY/u+a4t9T6kluJ6xowZwxe+8AUgOaBh6j6657s2BT/9ZNy4cUB6b6C2vHXetrLz+t73vsdvfvMbysrKeO655/zeXqm8+1hdXZ1WxJ0q0z0vLi5m8ODBAKxbt67T/crLy9UOoJ8sXLiQYDDIXXfdxcyZM9N+/v73vwPwxz/+kZkzZ3LuuecCuue7uj333DPj75m22bRpE6B7vrtQ8NNPvIdjVVVVhw2aly1bBsDkyZOzli/puf/3//4fv/71ryktLeW5557rsKfGvvvuS0FBAdB6b9vq6J57f/d0P+lbiUSCV155pd3P5s2bAVizZg2vvPIKb775JqB7vqubPHkylmUBUFlZmXEbb7nXHkf3fPeg4KefVFRUMHXqVAAeeOCBdusXLVrE+vXriUQinY4jIrl17bXX8otf/ILS0lKef/55/55mEg6H/SLyTPd87dq1vP766wCcfvrpaeu8vx988MF2XWtd1/XnFjrjjDN6fzLSqerqakxy4Nd2PxdddBEAc+fOxRjDmjVrAN3zXd2IESOYMWMG0FqtlSoej/PKK68AMG3aNED3fLeRs+EVB4COpreorKzU9Ba7gB/+8IcGMGVlZeatt97q1j5vv/22P+z9M8884y/vybD31113Xdq66667zgCmoqJCw97nSGcjPOue79peeOEFA5hBgwalzasVj8fNFVdcYQBTXFxsPvvsM3+d7vmuT8FPP/OGyA+FQuakk04yZ555pj+x6fTp0/Ui30n99a9/9ScwnTJlirnooosy/mQKXlMnPJw5c6Y5++yzzciRI3s04eGBBx5ozj33XH8iVU14mFudBT/G6J7v6ubOnetPQH3kkUeaM844w4wbN84AJj8/3/ztb39rt4/u+a5NwU8WPPTQQ+boo482JSUlJj8/3xx44IHm1ltvNdFoNNdZkw786U9/8oOfzn7Gjh2bcf/nn3/enHTSSWbw4MEmEomYffbZx8yZM8fU1tZ2etyPPvrIXHjhhWbUqFEmFAqZUaNGmQsvvNB8/PHH/XCW0l1dBT/G6J7v6p599llz8sknm8GDB5tQKGRGjx5tZs+e3W5+rlS657suy5iU4SxFREREdnNq8CwiIiIDioIfERERGVAU/IiIiMiAouBHREREBhQFPyIiIjKgKPgRERGRAUXBj4iIiAwoCn5ERERkQFHwIyIiIgOKgh8REREZUBT8iIiIyICi4EdEREQGFAU/IiIiMqD8/y9kM/hBTUMBAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Plot error evolution for each estimator\n",
    "for i, (label, pred) in enumerate(zip(labels, preds)):\n",
    "    if pred is None: continue\n",
    "\n",
    "    error = shap_loss(dgp[:, [-1]], pred, agg=True, last=False)\n",
    "    mean, std = error.mean(0), error.std(0) / np.sqrt(I)\n",
    "    \n",
    "    plot_ci(mean, std, color=f'C{i+1}', label=label)\n",
    "\n",
    "plt.legend();"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Plot SHAP values"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Average normalized absolute SHAP value for each variable:"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "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>u</th>\n",
       "      <th>z</th>\n",
       "      <th>x</th>\n",
       "      <th>a</th>\n",
       "      <th>b</th>\n",
       "      <th>c</th>\n",
       "      <th>y</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>347</th>\n",
       "      <td>11.297735</td>\n",
       "      <td>0.565693</td>\n",
       "      <td>3.501924</td>\n",
       "      <td>2.358705</td>\n",
       "      <td>3.014701</td>\n",
       "      <td>2.196934</td>\n",
       "      <td>2.087988</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>543</th>\n",
       "      <td>14.109654</td>\n",
       "      <td>0.205260</td>\n",
       "      <td>1.953730</td>\n",
       "      <td>2.724411</td>\n",
       "      <td>1.775909</td>\n",
       "      <td>1.975899</td>\n",
       "      <td>0.358776</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>293</th>\n",
       "      <td>7.584979</td>\n",
       "      <td>0.085960</td>\n",
       "      <td>0.292178</td>\n",
       "      <td>1.222547</td>\n",
       "      <td>5.299134</td>\n",
       "      <td>3.098251</td>\n",
       "      <td>0.976478</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>523</th>\n",
       "      <td>9.473665</td>\n",
       "      <td>0.486819</td>\n",
       "      <td>2.237908</td>\n",
       "      <td>1.553010</td>\n",
       "      <td>4.539130</td>\n",
       "      <td>2.634199</td>\n",
       "      <td>2.667763</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>24</th>\n",
       "      <td>1.782750</td>\n",
       "      <td>0.187737</td>\n",
       "      <td>0.653788</td>\n",
       "      <td>2.054074</td>\n",
       "      <td>5.115911</td>\n",
       "      <td>3.621924</td>\n",
       "      <td>2.886644</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "             u         z         x         a         b         c         y\n",
       "347  11.297735  0.565693  3.501924  2.358705  3.014701  2.196934  2.087988\n",
       "543  14.109654  0.205260  1.953730  2.724411  1.775909  1.975899  0.358776\n",
       "293   7.584979  0.085960  0.292178  1.222547  5.299134  3.098251  0.976478\n",
       "523   9.473665  0.486819  2.237908  1.553010  4.539130  2.634199  2.667763\n",
       "24    1.782750  0.187737  0.653788  2.054074  5.115911  3.621924  2.886644"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "seed = SEEDS[0]\n",
    "folder = folder_.format(seed=seed)\n",
    "\n",
    "df = pd.read_csv(os.path.join(folder, 'data', 'df.csv'))\n",
    "df_pred = df.pred\n",
    "df = df.drop('pred', axis=1)\n",
    "\n",
    "with open(os.path.join(folder, 'data', 'idxs.pkl'), 'rb') as f:\n",
    "    idxs = pickle.load(f)\n",
    "    idx_train, idx_val, idx_test = \\\n",
    "        idxs['idx_train'], idxs['idx_val'], idxs['idx_test']\n",
    "\n",
    "df_test = df.iloc[idx_test]\n",
    "\n",
    "df_test.head()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABDgAAAGkCAYAAADUjJUQAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8g+/7EAAAACXBIWXMAAA9hAAAPYQGoP6dpAACS/ElEQVR4nOzdeVxUVf8H8M8MMIOyChigIItrkai4RWKYZlaWWS6lYGJPtKCZ1qMpKqYRWpmFhlbkluBTqWmZluWGC/4UE0WtSAOJVEhHh03Zhvn9wcM8jszADNw7C3zerxev5N4z536HDsPc75zzPRK1Wq0GEREREREREZEVk5o7ACIiIiIiIiKi5mKCg4iIiIiIiIisHhMcRERERERERGT1mOAgIiIiIiIiIqvHBAcRERERERERWT0mOIiIiIiIiIjI6jHBQURERERERERWjwkOIiIiIiIiIrJ6tk15UFVVFVQqldCxEBERERERERFBKpXCzs4OEonE4McYleAoLi7GtWvXUFFRYXRwRERERERERESGsrGxQdu2bXHXXXdBJpM12l6iVqvVhnRcXFyMS5cuwdHRES4uLkZnUoiIiIiIiIiIGqNWq6FSqXDr1i0UFRWhpqYGPj4+aNu2bYOPMzjBkZOTAzs7O/j4+DCxQURERERERESiU6lUyMvLg62tLTp16tRgW4OKjFZVVaGiogIuLi5MbhARERERERGRSdjY2MDNzQ1lZWWorq5usK1BCY66gqJ2dnbNj46IiIiIiIiIyEByuRwAhElw1OHsDSIiIiIiIiIyJUNzEUYlOIiIiIiIiIiILBETHERERERERERk9WyF7KywsBBKpVLILkXl6uoKT09Pc4dBrZi1/c4A/L1pjaxtnHKMWjeONzIlaxtvAMecNbG28cWxRS2BYAmOwsJCREREorKyQqguRSeTyZGamsJfZCNFRUVhw4YNWLduHaKiolp9HE1VWFiIyIgIVFRWmjsUo8hlMqSkpgrye+Pv74+8vDzk5ubC398fgPX/f21pCgsLEREZgcoK6xmnMrkMqSnCjFHgf+O0jkQigYODA1xcXNC1a1f07dsX48ePx4ABAxrt69ixY1i/fj0OHjyIS5cu4ebNm3B1dcXdd9+N4cOH47nnntPa/uzAgQN48MEHAQCenp74888/4eDgUK/fv//+G76+vgBq9423Vtb4uijk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ZSUuXrwIW1tbuLm5QS6XN9o5EREREREREZEx1Go1VCoVSkpKUFxcDLlcDl9fX9jY2DT4OIMTHABw8+ZNXLt2DWVlZc0OmIiIiIiIiIhIHzs7Ozg5OcHDw6PR5AZgZIKjTnV1Naqrq5sUIBERERERERFRQ6RSKezs7IxaOdKkBAcRERERERERkSUxqMgoEREREREREZElY4KDiIiIiIiIiKweExxEREREREREZPWY4CAiIiIiIiIiq8cEBxERERERERFZPSY4iIiIiIiIiMjqMcFBRERERERERFbP1twBtAY1NTW4fPkynJycIJFIzB0OERERERERtXBqtRolJSXo0KEDpNLWMbeBCQ4TuHz5Mnx9fc0dBhEREREREbUy+fn58PHxMXcYJsEEhwk4OTkBqB1Yzs7OZo6GWrrr16/Dzc3N3GFQK8CxRqbCsUamwrFGpsKxRqZQXFwMX19fzf1oa8AEhwnULUtxdnZmgoNEV11dzXFGJsGxRqbCsUamwrFGpsKxRqbUmsoktI6FOERERERERETUojHBQURERERERERWjwkOIiIiIiIiIrJ6THAQERERERERkdVjgoOIiIiIiIiIrB4THERERERERERk9ZjgICIiIiIiIiKrxwQHEREREREREVk9JjiIiIiIiIiIyOrZmjsAIiIiIiIiarry8nLk5eUZ3N7Pzw/29vYiRkRkHkxwEBERERERWbG8vDxER0cb3D45ORndu3cXMSIi82CCg4iIiIiIyIr5+fkhOTlZ61heXh7i4+Mxf/58+Pn51WtP1BIxwUFERERERGTF7O3t9c7I8PPz42wNajVYZJSIiIiIiIiIrB4THERERERERERk9ZjgICIiIiIiIiKrxwQHEREREREREVk9JjiIiIiIiIiIyOq1mATH5s2bMWTIELRr1w4ODg7o1asX3nvvPVRVVRnVz/r16yGRSBr8+vHHH0V6FkRERERERETUFC1im9gZM2YgMTERtra2GDp0KBwdHbFv3z68+eab2LFjB3766Se0adPGqD47d+6MsLAwnec6duwoRNhEREREREREJBCrT3Bs374diYmJcHR0RFpaGkJCQgAA165dw9ChQ3H48GEsWLAAy5YtM6rfsLAwrF+/XoSIiYiIiIiIiEhoVr9EJSEhAQAwZ84cTXIDADw8PLBq1SoAwMcff4yioiKzxEdERERE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OOhsc+3aNZw+fRoDBw4UMxQiIiIiIqIWwdPT0+BkhJ+fH7p37y5yRESWQdRdVMaOHQuFQoHXX3+93pY9dWbNmoWbN2/imWeeETMUIiIiIiIiImrBRJ3BMXXqVGzYsAGff/45fvnlFzz99NMAgD///BPLly/H5s2bcfz4cfTu3RtRUVFihkJERERERERELZjoNTh2796NcePGIT09HZmZmQCAw4cP4/Dhw1Cr1ejfvz+2b98OOzs7MUMhIiIiIiIiohZM1AQHULv38OHDh7F7927s3LkTOTk5qKmpga+vLx599FE8+eSTDW4hS0RERERERPqVl5cjLy9P61jd93ceB2rrctjb25skNiJTEj3BUWfEiBEYMWKEqS5HRERERETUKuTl5SE6Olrnufj4+HrHkpOTWXiUWiSTJTiIiIiIiIhIeH5+fkhOTjaqPVFLJGqC4+jRo0hOTsYLL7yA+++/X2ebI0eOYM2aNXj55ZcxYMAAMcMhIiIiIiJqcezt7TkjgwgibxP72WefYdOmTejWrZveNt26dUNqaio+//xzMUMhIiIiIiIiohZM1ARHeno6evfuDQ8PD71t2rdvjz59+uDQoUNihkJERERERERELZioS1QuXbqEPn36NNrOz88PP/74o5ihEJGBCgsLoVQqG2zTUFVuXVxdXeHp6dnc0IiIiIiIiPQSNcEhlUpRWVnZaLuqqipUV1eLGQoRGaCwsBAREZGorKwwqL2uqty6yGRypKamMMlBRERERESiETXB4e/vj6NHj6K6uhq2trovVV1djaNHj7KSL5EFUCqVqKysQIVPX6jlToL0KakoAf7+BUqlkgkOIiIiIiISjagJjhEjRmD58uV466239H7Su2jRIvzzzz+YMGGCmKEQkRHkf/9i7hCIiIiIiIiMImqCY+bMmVizZg2WLFmCc+fOITo6Gj169AAA/P7770hOTsZ3330HJycnvP7662KGQkRGKO88BOo2roL0JbmlhP2fBwTpi4iIiIiISB9RExwdOnTA5s2bMWbMGHz77bf47rvvtM6r1Wo4OTlh8+bN8PHxETMUIjKCuo0rahz0735kDFG3aiIiIiIiIvov0e89hg0bhrNnz+K1115D9+7dYW9vD3t7e3Tr1g2vvfYazp49i+HDh4sdBhERERERERG1YKLO4Kjj4+ODDz/80BSXIiISRHl5ucHb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",
      "text/plain": [
       "<Figure size 1200x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "FI = []\n",
    "\n",
    "for label, data in zip(labels + ['ground-truth'], preds + [dgp]):\n",
    "    if data is None: continue\n",
    "    normalized_shap = np.abs(data[:, -1])\n",
    "    normalized_shap = normalized_shap / normalized_shap.sum(axis=-1, keepdims=True)\n",
    "    avg_normalized_shap = normalized_shap.mean(1)\n",
    "\n",
    "    FI.append((\n",
    "        [label] * np.prod(avg_normalized_shap.shape),\n",
    "        list(map(lambda x: x.upper(), df.columns[:-1])) * len(avg_normalized_shap),\n",
    "        avg_normalized_shap.flatten(),\n",
    "    ))\n",
    "\n",
    "FI = pd.concat([\n",
    "    pd.DataFrame(FI_label, index=['Estimator', 'Feature', 'Feature Importance']).T\n",
    "    for FI_label in FI\n",
    "], axis=0).reset_index(drop=True)\n",
    "\n",
    "fig, ax = plt.subplots(1, 1, figsize=(12, 4))\n",
    "\n",
    "sns.boxplot(x='Feature', y='Feature Importance', hue='Estimator', data=FI, ax=ax)\n",
    "ax.axhline(1 / avg_normalized_shap.shape[-1], ls='--', c='k', alpha=.5)\n",
    "for i in range(len(df.columns) - 1):\n",
    "    ax.axvline(i + .5, c='k', lw=.5, alpha=.1)\n",
    "\n",
    "\n",
    "fig.subplots_adjust(top=.85)\n",
    "ax.get_legend().remove()\n",
    "plt.figlegend(loc='upper center', bbox_to_anchor=(.5, 1.), alignment='center', ncol=6)\n",
    "plt.savefig(os.path.join(PLOTS_FOLDER, 'FI.png'), bbox_inches='tight', dpi=300);\n",
    "plt.savefig(os.path.join(PLOTS_FOLDER, 'FI.pdf'), bbox_inches='tight', dpi=300);"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "dcg_shap",
   "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.11.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
