{
 "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 = 'semi_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, 120, 100, 5)"
      ]
     },
     "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": [
    {
     "data": {
      "image/png": "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78GDBzV48GDVqlVLnp6eKlOmjFq1aqWoqKibtj969KimTp2qdu3aKSAgQB4eHipbtqxatGihL774QtnZ2XmOSUpKksFgkNFoVFZWlqZPn66GDRvKx8eHuTxOpmzZsvrwww8lSZs2bVJMTIykGw8TnjFjhiTpjTfeUGBgYIH9+Pj4qGHDhjfd9/bbb8vNzU2ff/65EhMTbVc8HFpxfTdnzpyptLQ0Va5cWVOmTLllHa6urgoPD7fyUzgPAhnuWMePH1dYWJiWLFmiJk2aqGPHjsrIyNDHH3+sTp066dq1a3mOWbRokerXr68vv/xS7u7ueuihh9SoUSPFxsbq6aef1oABA/Ic89///ldjxoxRUlKS6tSpo8cff1wNGjTQnj179Nxzz6lnz575zs0xmUx6/PHHNXbsWJUvX15du3bVfffdZ/M/C9zZHnzwQZUrV07SjXk1khQdHa309HQZDAb16dOnSP0HBQVp0KBBunr1ql5//fUi1wvnURzfzeXLl0uSnnjiCbm7u9uuWCdHIMMda9asWerQoYOOHj2qJUuWaNWqVfrtt99UrVo17dmzR4sXL87V/rffftPTTz8tSVqyZIni4+O1dOlSbdy4Ufv371doaKhmz56tuXPn5jquc+fO+u2333TkyBFt2LBB3333nTZv3qzExETVr19fS5cuzTNWjmPHjik2Nla//fabNmzYoHnz5umXX34pnj8Q3LEMBoPCwsIkSfv375ck7d27V5IUGBio8uXLF3mMN954Q6VLl9Z3332nuLi4IvcH52Dr7+b169f166+/SpIaN25sw0pBIMMdq3r16vrkk09yPcIj55KlJG3YsCFX+7fffltXrlzRpEmT9Pjjj+faV6NGDX399deSpI8++ijXvsaNG6tevXp5xq9atareffddSTfOvOXnnXfeUZ06dQrxyeCIKlSoIElKSUmRJJ05c0aSVLFiRZv0X7lyZY0cOVImk0ljxoyxSZ9wDrb8bqamppqncdx99903bfPJJ5+oX79+eV4omJu9CwDy0759e3l7e+fZHhISIkk6ceKEeVt2drbWrFkjSerVq9dN+2vUqJF8fHy0b98+Xb58WZ6enuZ9V65c0fr167Vnzx6dPn1aV65ckclkUkZGhiTpwIED+dbZvXv3wn84OJycH6ninEP48ssv6/PPP9e6desUHR2da1kMID+347v5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",
      "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",
    "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": 8,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "marginal loss: 0.10730905664451963 +- 0.002529793012559583\n",
      "linear loss: 0.1376523230465625 +- 0.004561426869149492\n",
      "DCN loss: 0.007114188411609937 +- 0.00034321141121037126\n",
      "DCG loss: 0.005270548142899202 +- 0.000670240578719045\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAmQAAAHECAYAAACX5TbPAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8g+/7EAAAACXBIWXMAAA9hAAAPYQGoP6dpAABVFklEQVR4nO3dd1gU1/4/8PcC0otR7ICooKASAcEGFrB3ghprFE289haTKCZo1GjUr95EoyYaY4sxViQxGhuCYKeIBmNBBUVUFAxFQJRlfn/4Y68b2u6yy8Du+/U8PNedOXPms6y5+/bMmTMSQRAEEBEREZFo9MQugIiIiEjXMZARERERiYyBjIiIiEhkDGREREREImMgIyIiIhIZAxkRERGRyBjIiIiIiETGQEZEREQkMgOxC9BVhYWFePToESwsLCCRSMQuh4iIiNRMEARkZ2ejYcOG0NMrewyMgUwkjx49gq2trdhlEBERkYYlJyfDxsamzDYMZCKxsLAA8OZDsrS0FLkaIiIiUresrCzY2trKvvPLwkAmkqLLlJaWlgxkREREWkyRqUmc1E9EREQkMgYyIiIiIpExkBERERGJjIGMiIiISGQMZEREREQiYyAjIiIiEhkDGREREZHIGMiIiIiIRMZARkRERCQyBjIiIiIikTGQEREREYmMgYyIiIhIZAxkRERERCIzELsAIqp+cnNzcfPmTaWPy8vLQ1JSEuzt7WFiYqL08U5OTjA1NVX6OCKiqo6BjIiUdvPmTbRt27bSzxsTEwN3d/dKPy8RkaYxkBGR0pycnBATE6P0cTdu3MCYMWOwa9cuODs7q3ReIiJtxEBGREozNTWt0EiVs7MzR7qIiN7CSf1EREREImMgIyIiIhIZAxkRERGRyBjIiIiIiETGQEZEREQkMgYyIiIiIpExkBERERGJjIGMiIiISGQMZEREREQiYyAjIiIiEhkDGREREZHIGMiIiIiIRMZARkRERCQyBjIiIiIikTGQEREREYmMgYyIiIhIZAxkRERERCJjICMiIiISGQMZERERkcgYyIiIiIhExkBGREREJDIGMiIiIiKRMZARERERiYyBjIiIiEhkDGREREREImMgIyIiIhIZAxkRERGRyBjIiIiIiERmUNEOXrx4gdTUVPzzzz945513UK9ePZibm6ujNiIiIiKdoFIgO378OEJCQhAaGoq7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HUtcFoOIiIioPFUykNnY2MDT0xMAsHv37mL7z549i+TkZBgZGaFfv34K9Vn0aKOS+nvx4gUOHz4MAPD39y/xuN9//73Ey5ZF/f37OCIiIiJFVclABgALFiwAAKxYsQKxsbGy7enp6Zg6dSoAYPr06bCyspLtO3ToEJycnNC9e/di/c2ePRumpqY4deoUfvzxR9l2qVSKqVOnIiMjA56enujVq5fccX379oWbmxsyMjIwdepUSKVS2b7NmzcjNDQU5ubmmDVrlnreOBEREemcKv1w8VmzZmHdunWoUaMGunfvDjMzM4SGhiIjIwNeXl44efKk3C2027dvx/jx49G4cWO5tceK7N+/HyNHjoRUKkX79u1hb2+PqKioch8ufuvWLXTu3BnPnj1D06ZN4enpicTERFy+fJkPFyciIqISKfNdX2VHyABg7dq12Lt3Lzp27Ijz58/j6NGjsLGxwYoVK3D69Gml1zMZNmwYLl26BH9/f9y7dw+HDh2CVCrFtGnTcPXq1RLDGAC0aNEC165dw7Rp0yCVSnHo0CEkJibC398fly5dUjqMEREREb2tSo+QaTOOkBEREWk3rRkhIyIiItIFDGREREREImMgIyIiIhIZAxkRERGRyBjIiIiIiERmIHYBuqro5tasrCyRKyEiIiJNKPqOV2RBCwYykWRnZwMAbG1tRa6EiIiINCk7O1vuyUIl4TpkIiksLMSjR49gYWEBiUQidjmVKisrC7a2tkhOTuYabDqGn73u4mevu3T5sxcEAdnZ2WjYsCH09MqeJcYRMpHo6enBxsZG7DJEZWlpqXP/cdIb/Ox1Fz973aWrn315I2NFOKmfiIiISGQMZEREREQiYyCjSmdkZIRFixbByMhI7FKokvGz11387HUXP3vFcFI/ERERkcg4QkZEREQkMgYyIiIiIpExkFGVFxAQAIlEgu3bt7MONbO3t4dEIkFSUpJsmza+T1Jc0d+Joh89PT1YWFjAxsYGPj4++OSTT3D58mWF+rp06RKmTJmCVq1aoWbNmjA0NETdunXRtWtXfPXVV3jw4IFc+/DwcNl569evj5ycnBL7ffjwoawdqY+Yn/3b8vLy8P3332PgwIGwtbWFqakpTExMYGNjg969e2PFihW4d++eut52lcF1yIiIqBgvLy84ODgAePMFmZaWhitXriA8PBxr1qxB165dsXXr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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": 9,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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M2nSJC6++GJaW1t7LPeDDz7gW9/6FtOnTycYDFJZWcnxxx/Pn//854Lbf/TRR/zXf/0XJ554IpMnTyYQCFBVVcWCBQu48847sSyr2z6bNm1CURSmTp2KaZr8+te/Zs6cOUQiERRF2ZvLsl8a8BD5ofanP/2Jn//856iqyt13382BBx44JMe58cYb+c///M8hKbuQMl8Z4EyY6K4kr6la0Y4vhBBi7zQ0NDB37lwymQzHHXccyWSSVatWceutt7J69WpWrVqFz+fL22fZsmVccMEFJJNJDjroIE499VTa2tpYvXo1559/Ps899xx333133j7/9//+X6666iqmTZvGzJkzOe6449i2bRsvv/wyq1at4umnn+ahhx4qGNzYts2ZZ57Jk08+ySc+8QkOPvhg3n333SG9LvuifgdB5eXlAMRisR636ehwJgOsqKgYUKWWLVvGf/zHfwBw1113cdZZZ/VYj97q4tajt7pcccUVecPv29vbvWa0oeBmguKZuLeSvIYEQUKI4rJtm4QxPKYP6a+QHippVuPuu+9myZIl3HHHHV43jYaGBo455hjWrFnDQw89xLnnnutt//bbb3P++eejKAoPP/wwZ555pvfcRx99xOc+9zn++Mc/snDhQi644ALvuZNPPpnTTz+dQw89NO/4W7du5dRTT+WRRx7hoYceKniP3Lx5M5Zl8fbbbzNz5szBvgT7jX4HQVOnTgWcX3hP3OfcbfvjkUce4bzzzsOyLO68804vGOqqvLycmpoadu3axebNmzn88MN7rEdtbW2PTWaBQKDb0Pyh5AVBRhwTZ5i8X/MX7fhCCAFOk/zH7/t4qasxIKvPW+1l1Uuhrq6O2267Le/e4TaHXX755axYsSIvCPrFL35BKpXil7/8ZV4ABDBlyhT+8Ic/cNRRR3HLLbfkBUHz588vePwJEyZw8803c/LJJ7Ns2bKCQRA409lIANS7fgdB7pD1lpYW6uvrC44Qe/XVVwHy5hDqi0cffZQvfelLmKbJ7373O775zW/2uv3cuXNZsWIFr776Kp/73OcGrR5DKaxn+wRlEliWRcbq3xIjQgghSmvRokWUlXUPwg4++GDAmUrGZVkWf//73wG8aVu6mjdvHpFIhLVr15JMJgkGg95zqVSKp59+mjVr1rBz505SqRS2bXv9YtetW9djPb/whS/0/+RGmH4HQXV1dcyfP581a9Zw33338dOf/jTv+ZUrV9LQ0EAgEODUU0/tc7mPPfYYZ599NoZh8Lvf/Y5vfetbe9znjDPOYMWKFdx///1cc801eXMFWZbFAw88ANAt8i4l99OLO2Giacv6YUKI4gvpIVaft7rU1RiQkL7nJZmGUk8jkt1uF8lk0nuspaXFG3DTl64WLS0tTJw4EYB//etfnHPOOWzevLnH7XsazDNmzJiCgZrIN6CO0VdeeSVnnHEGN910E6eccoqXaWlpaeGiiy4C4Hvf+x6VlZXePsuXL+eKK65g4sSJPPvss3nlPfHEE3zxi1/EMAzuuOMOLrzwwj7VY8mSJfziF7/ggw8+4KqrruIXv/iF99xVV13FBx98QF1dXV56sdTc5rCOTAeWbcms0UKIklAUpaRNSvuyrpPz9iZ3BNdXv/rVPW7vNrHF43FOP/10duzYwde+9jW+853vMGPGDCoqKtA0jQ8++IBZs2Zh23bBcvqydqcYYBB0+umnc8kll3DLLbdw9NFHs2jRIsLhMM8++yytra0cd9xxXHfddXn7tLW1sW7durwIGWDnzp2ceeaZpNNp6urqeOmll3jppZcKHveXv/wltbW13r/Lysp48MEHWbx4MTfccAN/+9vfOPTQQ3nnnXd45513CIfDLFu2bFi9GHKDIBtbVpIXQoj9WG1tLaFQiEQi0e0e1pt//vOf7Nixg7lz53YbNQadEwmLvTPgIfJLly7luOOO47bbbuOll14ik8kwffp0Lr/8ci677DL8/r519o3H46RSzszJW7Zs4d577+1x22uvvbbbC+i4447jzTff5LrrrmPFihU8/PDDjB49mgsuuICrr76a6dOnD/QUB52qqER8ztxFHWlZSV4IIfZ3mqZx0kkn8be//Y0HH3zQay3Zk127dgE9N731NLeQ6J+9mifo7LPP5uyzz+7TtkuWLGHJkiXdHp86dWqP6by+mjFjRq/B03ChqzoVfqfNOGY4fYIytnSMFkKI/dk111zDk08+yY9//GPC4TDnn39+tya1d955hw8++MDrw+p2sn722Wd57733+NjHPuZt+/vf/97r8yr2zoBWkRcD4wZBCs78FolMQprDhBBiPzd37lwvc7NkyRKmTJnCySefzFe+8hVOPfVUJk2axOzZs3nwwQe9febMmcPnP/95otEoc+bM4eSTT+bcc8/l4IMP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lxehlsX3/PPP89vf/pYLLriAU089tcftRvq1ymQy/O53vwPgxz/+cZ/2GanXrD+T0tXW1gIj91r1Zm+uifvvL33pS90W+1RVlXPOOQeARx55ZNDrPVwVuge43OtV6DpHIhFOO+00oP/XS4KgIbJ27VoAampqmDZtWsFt5s2bl7ftSLd+/XoAxo8f7z32wQcfEI/Hgc7r1dX+fB07Ojr4j//4D8aOHctvfvObXrcd6dfq9ddfp7m5mQkTJjBjxgzefvtt/vM//5NvfetbXH755Tz++ONYlpW3z0i9ZpFIhE984hMA/OxnP8sbpGFZFtdeey2JRIJTTjmFSZMmASP3WvVmb66J+2+5lp0K3QMAotEoGzZsAAb/eskq8kOkvr4egMmTJ/e4jfvm4m47km3fvp177rkHgC984Qve4+61qaqqory8vOC++/N1/NGPfkR9fT3Lly+nurq6121H+rV66623AKirq+Pyyy/n5ptvzhtp8l//9V/MmTOHRx991Pu7HMnX7K677uLUU0/l97//PY8//jjz5s1D0zTWrl1LY2Mj559/Prfeequ3/Ui+Vj0Z6DWJRqO0tLQAPd8j3P2ampqIxWKEw+FBq/dwFI/HueWWW4D8ewDApk2bvJ/3dL36+9qTTNAQiUajAL2+cCORCADt7e1FqdNwZRgGX/nKV2hra2P27Nl861vf8p4bydfx6aef5s477+RLX/oSp59++h63H8nXCvBuKmvXruW//uu/uOiii1i3bh1tbW0888wzzJw5k7Vr1/KZz3zGy3yM5Gs2a9YsXn75ZRYvXkxjYyN//etfeeSRR6ivr2fGjBksXLiQiooKb/uRfK16MtBr4u7X277ufl333V9ddNFF1NfXM2HCBK688sq85/pzvfp7rSQIEiX37W9/m2effZZRo0bx0EMP4ff7S12lkmtra+PrX/86o0eP5re//W2pq7NPcLM+mUyGc889l1tvvZWZM2dSUVHBpz71KZ555hmCwSDvvPMO999/f4lrW3qrVq1i9uzZvPPOO9x3331s376dXbt28dhjj5HJZPj617/O17/+9VJXU4wA1113Hffeey/BYJAHH3yQUaNGFe3YEgQNETc1GovFetzGnUQr99PWSPP973+fP/zhD1RXV3uf1nON1Ot46aWXsmXLFm699VavY+qejNRr5cptjsjNJromT57MZz7zGcCZ2C53n5F2zVpbWznjjDNoamrikUce4dxzz2Xs2LFUV1fz2c9+lieffJKysjLuvvtu/vGPfwAj91r1ZqDXJPe12tO+uZMs7s/X89e//jVXX301gUCA5cuXex3Jc/XnevX3WkkQNESmTp0KFO7l7nKfc7cdaX74wx9yyy23UFVVxdNPP+2NDMjlXpvW1ta8lGiu/fE6Ll++HF3Xuf3221m4cGHe15NPPgnAH/7wBxb+/+3dz0vTYRwH8PekbSzYhkPB3GIykjzsJOmgIjwuEaJFKQhu91WXQGr+A0LgRaLYpUMQGnSIFaELYhCR4qxjoCIR+KNW5I9LbPjpIN+n2X64aabteb/gC9v3+T66vZnbZ9vX59PVhb6+PgD6ZmXw+XxFLxc7Znl5GYC+mb148QJfv36Fz+dDIBAoGM/fbxSMumZVzl4zsdvtcLlcALZX7S43r6GhoWbPBxodHcWtW7dgsVjw9OlTBIPBosd5vV51ebe8qn3ssQg6IMYL+rdv30qeqDUzMwMAaG9v/2e366gYHBzEyMgInE4nJicnS57xf/r0aRw/fhzA77z+VKs55nI5pFKpgm11dRXA9smCqVQK7969A6B3VsD2fTKZTACATCZT9Bhjv3H+gK6ZGS8k5d41O51OAMD3798B6JtVOfvJxLiua5b37t3DzZs3VQFkfEpbjMPhwKlTpwD8/bxYBB0Qj8eDjo4OAMDjx48Lxt+8eYPPnz/DarWWXfulFt2+fRt3796F0+lEMplUORVjsVjUH0exHD99+oS3b98CAC5fvnwwN/gQ/PjxA7K9mGnBFg6HAWx/jy4i6j8ndM3K0NTUhPPnzwP4/elFvmw2i1QqBQDo7OwEoG9mbrcbAPDx40esra0VjGezWczOzgKAWuJD16zK2U8mxvWxsbGCpRu2trZUj7tQKPTXb/dhe/DgAa5fv64KoJ6enl3nGHkVy3lzcxOJRALAHvKqdkVHqlypthmZTEbLthkiIkNDQ2o5/unp6YrmpNNptSz9y5cv1f5aWaq/WuVWZdU9q1evXgkAqa+v39F3KZvNyo0bNwSA2O12WVlZUWM6ZvblyxfVouDq1auysbGhxn7+/CnRaFQAiNlsloWFBTWmW1aVrIC810zy22bEYrEdY7FYTACIx+M50m0z/lRJXvF4XEwmk1gsFkkkEhX/7Py2GfF4XO3P5XKqXQfbZhxBRrsDs9kswWBQrly5ohqonjt37r96gO/Xs2fP1FL9Z86ckXA4XHQrVhjmNyjs6uqSa9euyYkTJ2qiaWO1dnui0T0rY+n9Y8eOydmzZyUUCklLS4sAEJvNJs+fPy+Yo2Nmjx49Us0oGxsbpbu7Wy5duiRut1sASF1dndy/f79gXi1nlU6nJRAIqK2hoUEVI/n7l5aWdszbayb5DVT9fr/09fWphtL/QwPVavN6//69agDd1tZW8jUgHA4X/X1PnjxRPSYDgYD09vayger/YHx8XC5cuCAOh0NsNpv4/X4ZHh4u2Sm3Vj18+FAVQeU2r9dbdH4ymZRgMCgul0usVqu0trbKnTt3ZH19/d/ekUNWybst3bOamJiQixcvisvlErPZLCdPnpRIJFK2p5WOmX348EEikYj4fD6xWq1isVjE6/VKf3+/TE1NlZxXq1m9fv26oueoxcXFgrl7zWRubk4GBgakublZzGazNDc3y8DAgMzPzx/Qvfx7qs2r0uPLfUk1MzMjoVBIGhsb1eM1Go3u+HS3GiaRvCVViYiIiDTBE6OJiIhISyyCiIiISEssgoiIiEhLLIKIiIhISyyCiIiISEssgoiIiEhLLIKIiIhISyyCiIiISEssgoiIiEhLLIKIiIhISyyCiIiISEssgoiIiEhLLIKIiIhIS78A69AM+AbP3xIAAAAASUVORK5CYII=",
      "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": 10,
   "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>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>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>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>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>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>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": [
       "            z         x         a         b         c         y\n",
       "347  0.565693  3.501924  2.358705  3.014701  2.196934  2.087988\n",
       "543  0.205260  1.953730  2.724411  1.775909  1.975899  0.358776\n",
       "293  0.085960  0.292178  1.222547  5.299134  3.098251  0.976478\n",
       "523  0.486819  2.237908  1.553010  4.539130  2.634199  2.667763\n",
       "24   0.187737  0.653788  2.054074  5.115911  3.621924  2.886644"
      ]
     },
     "execution_count": 10,
     "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": 11,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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kZGRmDFjBjp27Ig///zTABES6Y8i4f83sVgMNzc39OrVC++++y5/VyGzcejQIXz77bdISkrCvXv3UFRUBGdnZ3Tq1AkvvfQSxo0bBycnJ2OHWa8x4SciIiIiIiIyQ1zDT0RERERERGSGmPATERERERERmSEm/ERERERERERmiAk/ERERERERkRliwk9ERERERERkhpjwExEREREREZkhJvxEREREREREZogJPxEREREREZEZYsJPRERkxjw9PSESiar98+WXXxo7TCIiIqoFVsYOgIiIiGqfv78/2rRpo/LY008/bdBYbty4gVatWsHDwwM3btww6NhERET1CRN+IiKiemDSpEkIDg42dhhERERkQJzST0RERERERGSGmPATERGR0rlz5zBmzBi0bNkSEokETk5OGDhwIA4ePKiy/Z9//okFCxbA398fzZs3h1gshrOzM/r3749du3ZVaR8cHIxWrVoBANLT06vUE3iynUgkwpYtW1SOu2XLFohEoiqzFp58PTs7GzNmzEDr1q0hkUgQFBRUqW1cXBxef/11uLm5QSwW46mnnsJrr72GU6dOaf4NIyIiMmGc0k9EREQAgMjISHzwwQcoLy9Hly5d0LNnT9y7dw/Hjx/HkSNHsGjRIoSHh1c65/PPP8fGjRvRoUMHdOrUCY6Ojrh58yaOHTuGuLg4/Pbbb/j888+V7QMCAvDo0SPs2bMHtra2GD58eK28l6ysLHTr1g0ymQx9+vRB165dIRaLlcc/+ugjrFy5EhYWFujWrRv69OmDmzdv4ocffsD+/fsRFRWFiRMn1kpsREREhsKEn4iIiHD48GHMnDkTzs7O2LNnD5577jnlsT/++AODBw/GggULEBgYiMDAQOWxcePGITQ0FF5eXpX6S01NRf/+/fHFF1/gzTffRI8ePQBU1BLo378/9uzZgyZNmqh9gq+rAwcOoF+/fvj+++9hb29f6VhUVBRWrlyJNm3aYM+ePfDx8VEeO3HiBF5++WW8++67CAgIQNu2bWslPiIiIkPglH4iIqJ6YOLEiSq35FNMc1+wYAHkcjm++uqrSsk+AHTq1En5lH716tWVjgUGBlZJ9gGgffv2CAsLAwDs3r27Ft5R9Ro0aIBvvvmmSrJfXl6OhQsXAgB27txZKdkHgOeeew5hYWEoLi7G119/bahwiYiIagWf8BMREdUD6rbl69ChA7KysnDmzBnY2NjglVdeUXm+4sZAUlJSlWOPHj3Czz//jJSUFGRlZaG4uBgAcPfuXQAVT/sNzdfXV+WNiJSUFNy5cwetW7dG165dVZ5b3XslIiKqS5jwExER1QPVbcuXnJwMuVyOgoICSCSSavt58OBBpa/379+PiRMnQiqVqj0nNzdX63h15enpqfL169evAwCuXbtWqUigKv9+r0RERHUNE34iIqJ6rry8HABgZ2eHYcOGaXze7du38cYbb6CgoAAff/wxxowZA09PT9jZ2cHCwgJHjhzBwIEDIZfLay1mdWxsbKo9z9XVFQMHDqy2jyZNmggLjoiIyEQw4SciIqrn3N3dAQAikQibNm2ChYVmJX7279+PgoICvPbaa/j000+rHL9y5YrgmBQV9fPy8lQeT09PF9Sv4r06OzvXWsFAIiIiU8GifURERPVcs2bN4OPjg7y8PBw6dEjj87KzswEAHh4eVY7J5XLs2LFD5XmKZL60tFRt382bNwcA/PXXXyr7/vnnnzWO80ndu3dHkyZN8Oeff+Ly5cuC+iAiIqormPATERERIiIiAFRU89+/f3+V43K5HKdPn8aRI0eUr3Xs2BFARRV+RYE+ACgrK0N4eLjaondNmzaFWCzGvXv3lDcN/q1///4AgO3bt+PPP/9Uvl5SUoLZs2cjOTlZy3dYoUGDBsodCV577TUkJCRUaVNWVoajR4/it99+EzQGERGRqeCUfiIiIsIrr7yCyMhIfPjhhxgyZAjatGmD9u3bw8HBAQ8ePMCFCxdw//59zJ49Gy+88ILynK5du+LcuXNo164dAgMDYWtri9OnT+POnTuYPXu2yqn+DRo0wJAhQ7B792506dIFAQEBaNiwIQBgw4YNACp2FXj11Vfxww8/oFu3bggICICNjQ3Onz+P3NxcvP/++4iMjBT0XqdNm4abN2/is88+Q58+feDt7Y02bdrAxsYG9+7dw++//w6ZTIb169ejV69eAr+jRERExscn/ERERAQAmD59OlJSUvD2229DJBIhLi4O+/btw7Vr1+Dr64tVq1Zh+vTpyvZWVlY4fvw4QkND0bx5c8TFxeH48ePw9fXFqVOn8OKLL6od6+uvv8Y777wDkUiE3bt3Y+PGjdi4cWOlNt999x3mz58PNzc3HD9+HL/99hv69OmD8+fPo0uXLjq91+XLlyMxMRFjxozBo0ePcOjQIRw4cAB37txBUFAQNmzYgDfeeEOnMYiIiIxNJK+N0rlEREREREREZFR8wk9ERERERERkhpjwExEREREREZkhJvxEREREREREZogJPxEREREREZEZYsJPREREREREZIaY8BMRERERERGZISb8RERERERERGaICT8RERERERGRGWLCT0RERERERGSGmPATERERERERmSEm/ERERERERERmiAk/ERERERERkRliwk9ERERERERkhv4PWv9IUSv192oAAAAASUVORK5CYII=",
      "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
}
