{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "oriental-clerk",
   "metadata": {},
   "source": [
    "# Experiments with Data Shapley\n",
    "https://blog.acolyer.org/2019/07/15/data-shapley/\n",
    "\n",
    "This notebook contains six experiments:\n",
    "- On the train data using both the accuracy and the decision_boundary change as metric\n",
    "- On train and mesh data using both the accuracy and the decision_boundary change as metric\n",
    "- On mesh data only using both the accuracy and the decision_boundary change as metric\n",
    "\n",
    "**MESH_SIZE for db difference is smaller than in LOO experiments (100 vs 500)**"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "supposed-beast",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\tensorflow\\python\\framework\\dtypes.py:526: FutureWarning: Passing (type, 1) or '1type' as a synonym of type is deprecated; in a future version of numpy, it will be understood as (type, (1,)) / '(1,)type'.\n",
      "  _np_qint8 = np.dtype([(\"qint8\", np.int8, 1)])\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\tensorflow\\python\\framework\\dtypes.py:527: FutureWarning: Passing (type, 1) or '1type' as a synonym of type is deprecated; in a future version of numpy, it will be understood as (type, (1,)) / '(1,)type'.\n",
      "  _np_quint8 = np.dtype([(\"quint8\", np.uint8, 1)])\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\tensorflow\\python\\framework\\dtypes.py:528: FutureWarning: Passing (type, 1) or '1type' as a synonym of type is deprecated; in a future version of numpy, it will be understood as (type, (1,)) / '(1,)type'.\n",
      "  _np_qint16 = np.dtype([(\"qint16\", np.int16, 1)])\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\tensorflow\\python\\framework\\dtypes.py:529: FutureWarning: Passing (type, 1) or '1type' as a synonym of type is deprecated; in a future version of numpy, it will be understood as (type, (1,)) / '(1,)type'.\n",
      "  _np_quint16 = np.dtype([(\"quint16\", np.uint16, 1)])\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\tensorflow\\python\\framework\\dtypes.py:530: FutureWarning: Passing (type, 1) or '1type' as a synonym of type is deprecated; in a future version of numpy, it will be understood as (type, (1,)) / '(1,)type'.\n",
      "  _np_qint32 = np.dtype([(\"qint32\", np.int32, 1)])\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\tensorflow\\python\\framework\\dtypes.py:535: FutureWarning: Passing (type, 1) or '1type' as a synonym of type is deprecated; in a future version of numpy, it will be understood as (type, (1,)) / '(1,)type'.\n",
      "  np_resource = np.dtype([(\"resource\", np.ubyte, 1)])\n"
     ]
    }
   ],
   "source": [
    "import sys\n",
    "sys.path.append(\"./../\")\n",
    "\n",
    "import numpy as np\n",
    "from sklearn.model_selection import train_test_split\n",
    "from sklearn.neural_network import MLPClassifier as MLP\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "from utils import decision_boundary\n",
    "from utils.synthetic_data import SyntheticData\n",
    "from utils.metrics import DecisionBoundaryDifference\n",
    "from utils.data_shap import DShap"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "adaptive-paintball",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAXAAAAD4CAYAAAD1jb0+AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjQuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/Z1A+gAAAACXBIWXMAAAsTAAALEwEAmpwYAAAx+klEQVR4nO3deXhU5fXA8e87SzbWJOwJkEAgQNgJiLJIBRRQca3ibhW0rpVaK2pba1dr+7OVqlXqAlYFF0SwRcANRNlkCQJhDQRJCJCEkATIMsv7++OGLJCQmclM7kxyPs+Th0zmLuem9szNe9/3HKW1RgghROixmB2AEEII30gCF0KIECUJXAghQpQkcCGECFGSwIUQIkTZAnHQdu3a6YSEhEAcWgjRFLmd4HaBLdy8GLQLjmyDMzPzlIJOA0E1zn3upk2b8rTW7b3ZJyAJPCEhgY0bNwbi0EKIpmbHx7DoXkBB4li4aQFYqiXNI9vgo3ugrBgm/Rn6XhmYOLSGuZfD4S3G6y5D4CdLA3OuWiilDnq7T0ASuBBCeGzZLHCWGt9nfgM5WyBuWNX7794IRdnG9wunw893QlSM/+NQCm5bBDsWGa9TrvH/OfxMErgQwlxhLau+1+6arwFO51d7oaCkIDAJHIwhnEHTAnPsAJCHmEIIc133GrTqArZIGPsotE+u+f6oR8AeCWEtoPtFENPDlDCDkQrEUvrU1FR99hi4w+EgKyuL0tJSv59P1C4iIoL4+HjsdrvZoQjRMEe2Q/lJiB8OFqvZ0QSEUmqT1jrVm30abQglKyuLVq1akZCQgFKqsU7bbGmtyc/PJysri8TERLPDEaJhOvU3O4Kg1GhDKKWlpcTGxkrybiRKKWJjY+UvHiGasEYdA5fk3bjk9y1E0yYPMYUQIkQ1mwR+4sQJXn75ZZ/2nTJlCidOnPB4+7KyMm688UaSkpK44IILyMzMrHW7ZcuWkZycTFJSEs8++2yt2/z2t78lLi6OwYMHM3jwYJYurVpY8Oc//5mkpCSSk5NZvny5N5ckhGgCJIEDTqfzvPsuXbqUtm3benyu119/nejoaPbt28fMmTN5/PHHz9nG5XLxwAMP8Omnn5Kens78+fNJT0+v9XgzZ84kLS2NtLQ0pkyZAkB6ejoLFixgx44dLFu2jPvvvx+Xy+VxjEKI0NdsEvisWbPIyMhg8ODBPPbYY6xcuZIxY8YwdepU+vXrB8DVV1/NsGHDSElJYc6cOZX7JiQkkJeXR2ZmJn379mXGjBmkpKRw6aWXUlJScs65Fi9ezB133AHA9ddfzxdffMHZ0zU3bNhAUlISPXr0ICwsjGnTprF48WKPr2fx4sVMmzaN8PBwEhMTSUpKYsOGDb78aoQQdTmVD6+Ohd/Fwn+uBUdwTQoI6gT+WfpRfrN4O5+lH23wsZ599ll69uxJWloaf/3rXwHYvHkzL7zwAnv27AHgjTfeYNOmTWzcuJHZs2eTn59/znH27t3LAw88wI4dO2jbti0LFy48Z5vs7Gy6du0KgM1mo02bNuccq/o2APHx8WRnZ9ca+4svvsjAgQO56667KCgo8Hp/IYSPVj0LR9ONYlsHv4Ut/zE7ohqCNoF/ln6Uh+dv4a21B3l4/ha/JPGzjRgxosYc6dmzZzNo0CBGjhzJoUOH2Lt37zn7JCYmMnjwYACGDRtW5/i2v9x3331kZGSQlpZG586defTRRwN6PiGaHEcJlBb5tm/ZSSN5g1Et0XHaf3H5gUcJXCk1Uym1Qym1XSk1XykVEejAVu/NpcRhjOmWOFys3pvr93O0aNGi8vuVK1fy+eefs3btWrZu3cqQIUNqnUMdHl5V7tJqtdY6fh4XF8ehQ4cAY3y9sLCQ2NjYOrcBY6FTXFzcOcfq2LEjVqsVi8XCjBkzKodJPN1fiGYtfTE82x2eS4RlT3q//9hfQGQ02KOgdRcYfKv/Y2yAehO4UioOeBhI1Vr3B6xAwKu9jOnVnki7sWQ20m5lTC+vyuSeo1WrVhQXF9f5fmFhIdHR0URFRbFr1y7WrVvn87mmTp3KvHnzAPjwww+55JJLzpmTPXz4cPbu3cuBAwcoLy9nwYIFTJ069Zxj5eTkVH6/aNEi+vfvX3mOBQsWUFZWxoEDB9i7dy8jRozwOWYhmqQlD4OrzLiL3vg6FGR6t39sT6P64X3fwkOboEVs/fs0Ik+X0tuASKWUA4gCDgcuJMPEfh2ZfdMQVu/NZUyv9kzs17FBx4uNjWXUqFH079+fyZMnc/nll9d4f9KkSbzyyiv07duX5ORkRo4c6fO57r77bm677TaSkpKIiYlhwYIFABw+fJjp06ezdOlSbDYbL774Ipdddhkul4u77rqLlJSUc471y1/+krS0NJRSJCQk8OqrrwKQkpLCDTfcQL9+/bDZbLz00ktYrU2zRoQIQkWH4b8z4WQujP8V9LzE7IhqV6MZg/atOYM9wvMCWqePw6Z5xj5D74CwKO/P5wWPilkppX4G/BEoAVZorW+pZZt7gHsAunXrNuzgwZq1yXfu3Enfvn39EbPwgvzeRUDMGQc53xtdbOyR8HAatOpkdlTn2rMC3r8d3OUw+udwya8Cdy63C/6ZCkVZxgdF3FD4yace7x6QYlZKqWjgKiAROAF8oJS6VWv9dvXttNZzgDlgVCP0JgghRIg5fsBI3gDKajRcCIYEnvM9rP4/iIqF8b+G3pfCk9kV7drCAnvu4iNQfBhc5cbrg2vB7a7ZXcjPPDnyBOCA1jpXa+0APgIuClhEQojgN+wOsLcwanS36gwdg6BaYEkBvDkF0j+GzW/B/JuNn1usgU/eAC3aQ3gr4+7bYocOfQOavMGzMfAfgJFKqSiMIZTxgDS8FKI5m/CMMe59+jj0utTcZsRnFFQbtnU74Mj3jXt+WxhM/8L4C8AeAWN/afz82E6jz2bXC4yHov48ZX0baK3XK6U+BDYDTmALFUMlQohmSinoMc7sKGpq19u4A3aVG3fdyZMbP4bo7jB1dtXrzG/hneuMu3Kt4e4V0GmA307n0SwUrfXTwNN+O6sQQvhbWBTc+zVse9+Yuz3gBrMjgi1vGwuJztixuPETuBBChISW7eHCB8yOokrHFKPXp7PEWAx0dr/PBgrapfT+1pjlZL/++muGDh2KzWbjww8/rHO7TZs2MWDAAJKSknj44YfPKXgFMHfuXNq3b19ZTva1116rfG/evHn06tWLXr16VS4cEqLJ0hq2vgeL7oMdH5sdjWdG3gcX3AOdh8CYR2HA9f49vtba71/Dhg3TZ0tPTz/nZ43pwIEDOiUlpdb3HA6H38+1detWfdttt+kPPvigzu2GDx+u165dq91ut540aZJeunTpOdu8+eab+oEHHjjn5/n5+ToxMVHn5+fr48eP68TERH38+PFztjP79y6E32x9T+s/dNL66dZa/6Gj1rs+NTsivwI2ai9zbbO5A2/McrIJCQkMHDgQy3mmEOXk5FBUVMTIkSNRSnH77bfz8ccfe3w9y5cvZ+LEicTExBAdHc3EiRNZtmyZ578QIULNga+rikk5SuDgGnPjCQLBncB3LYX//cL4t4Eas5ysJ7Kzs4mPj698fb5ysAsXLmTgwIFcf/31lQWspJysCGkuB2RvNpbkeyp5srHqE4xx5aTxgYnN39xuOLKt5jRHPwneBL5rKSy8C777t/GvH5L42UKhnOyVV15JZmYm33//PRMnTqxsFCFEg7mcsPxJePki+Px3RqJpDI5S+PclMO8KmD0Udv635vvOMti/Co7tqvnzPpfDDW/D6Efhlvehx8WNEy9A7m5Y80/I+NK7/dxumH8jvH4pvDQC1vt3BnbwJvCML6um3zhKvP/FeSBQ5WQ9ERcXR1ZWVuXrusrBxsbGVp5z+vTpbNq0qXJ/KScrGmTDHNj4BhzbAev/BVvfbZzzZq6G4/uh/JQxO+OLZ6rec5bBnB/BgpuNeisb59bct9cEmPAbSBx7/nO4nLDuX/Dfn0P2pobFm7fXiOnzZ2DBLcbUQI/33Q2Z3xhDP85S+PIPDYvlLMGbwHteUvXnkj2ywdXOGrOcrCc6d+5M69atWbduHVpr3nrrLa666qpztqteTnbJkiWVhakuu+wyVqxYQUFBAQUFBaxYsYLLLrssoDGLJuBUPmRtNJJn3u5qN0mnjUTVGCJjQFfc7SsLRLWreu/QBjhxEMpPGsn96+d8O8dnvzYS7sbXYe4VkJ/he7z7Vxp1X9wO4/f0/Xue7xveuupaASJa+x5HLYI3gfeZAte9AcNnGP/2mdKgw1UvJ/vYY4+d8/6kSZNwOp307duXWbNmNaic7HfffUd8fDwffPAB9957b40ysWeGXwBefvllpk+fTlJSEj179mTy5HNXjs2ePZuUlBQGDRrE7NmzmTt3LgAxMTH8+te/Zvjw4QwfPpzf/OY3xMTE+ByzaOK0hnUvw/N94a2rjKGL5CnG3OSwlsa//p7iVpf4YTB6JkS0hQ794Jp/Vb3XsqNReAoAC7T28a/KjK+MDwAwPiRy0nyPt9OAqjK0tkhjSbyn2sTB5OeMD63oBLjRi7t3D3hUTtZbqampeuPGmuVSpKypOeT3LgD49HHY8O+qCoIWO0x8BnpdZiS3uGEQk3jeQzSazW/BquegdWe47nVo2837Y3z2G2OIyFFiFN26f42RQH2142NIe9coETvmF2D1/xrIgJSTFUI0AWnvViVvMGqFRMVCuyTjK5gMvd34aojxv4WYnpC/Dwbe0LDkDZBytfEVZCSBC9EctOwIZcVAxV/cyVfAgB+bGlK9tDYeeJYWQdIEo8KfpywWo+Stv+LYOt94GNnnigYP5/pToyZwrfU5vSFF4ARieEyEoO/fh8KKGU/KAlP/CUM8bM6rNXz+tPHgrmN/Y0gjsm3AQq1h+ZOwaa5R+TA2CaZ/GZChi3pteQc+fcx4gLnjI7jxnaCZg95oDzEjIiLIz8+XpNJItNbk5+cTEeHFXYtomrZ9UPFAT4OyQckJz/fd/akxdl58xFgJuSKALcnOtmmukTTLTxlzwnd+0njnru7AymorQEvh0Hpz4qhFo32cxcfHk5WVRW5ubmOdstmLiIiosdpTNFNdL6iai2y1QeeBnu978ohxFw5Gne3CrNq3c7uNqXvpS6DrCLjqxappwL5q0xXy9gDa6Cz/8X3G1Mdxsxp2XG8lT4Fd/zUeiNoiINGHBUQlBUa7t3a9oHUXv4XWaAncbrfXWPUohGgko2cawxCHNhg1sutbBFNd36mw8llw2IzpfWN+Xvt22z80FgU5TsOpY8bMkQkNbCFw83uw8G6jm412G39FrH2x8RN4/2uND6Nd/4OWnbx/IFqYDa+OMcoHuJ1w+xLoOtwvoclDTCGaOovVKGXqixbt4MGNRhKN6QFtu9a+XWFWVTNfZykUZPp2vupiEuFHT8H8aRXHVkYCNYOyGh9SygIbXoF7V3s+7XL7QigtBnfF72ftP6HrW34JK3gX8gghgkNEa6PuSF3JG6D/dUaD4/BWxqKgC37a8PMufxLeu9WYOGOPMuZg37Sg4cf1xXf/NoZQyk8Zy/13e1GbqVWnqoev1nBo479hTbkDF0I0XHR3eGizUWGwQx/fFt9UpzWse6Vq7rpSxipGP44fe6V9X+MhrrMULDZjVoyn+l8PWd9B+mKIS4VxT/otLEngQgj/aNEOel/qn2MpZUxXPH2mpLOGvAzfEviR7bDqLxDRBib81ojTWz960phHn7UBBk2D3l7UHbJYYMpfjS8/a7Sl9EII4ZXszbDop8Z4ulLG+PPI+2H8rz0/RlkxPN8PyoqMO+dOA+GerwIWckP4spRexsCFEMEpbijcMM94COssNWa4rPtX/ftVV5hdNQzjdsKxdP/HaSIZQhFCBK+odlXz0FHGA0FvxPQwjuF2GXfwvfw0xBMkJIELIepWdBh+WGsso2+f3Pjnb9kefjzXWAEa0QauedW7/W1hcM9KYzVqeCtjHnwTIglcCFG7/AyYc7FxB6xdxhS+HuMaP47kScaXr6Ji4IJ7/RdPEJExcCFE7XZ+YtT+KD9pzIHe8O/Anu/AaqOJ+db3qg2bVHMq3/hQ8cfEi7KTRpGqHYuqNZDwwJFtsHAGLH/KqJJoMrkDF0LULiYRrHajlZgtAtr3Cdy5sjbBuz82PijS3oGyQhhxT9X7Oz6GRfcCChJGw83vG9PzfOFywusTK1aLKqOp8vWv17/f6ePwxmQoLwZrGBzdAbd/7FsMfiJ34EKI2vWdatQ+ad8XBt0EF/8ycOf6YU3VnbDjNOxZUfP95U8YM1GcJca2hzfXfN/lhO9eM/pg5u07/7l2fwrHdhrncZwyFth44vgBOFMN21V+bgwmkDtwIUTtlIKxjxlfgdbtImO6oAtj2fyZBUGOEmMxj71l1bZut7Fsv7qljxpDL85SI5E/tNl4AFqbTx+jsrEFeL5qtH2y0RPTUWosje/dgHH5s7kcPu0mCVwIYb74YXDzB8a4e9wwow1a9iajAbPLAdE9jFWYJQUw+ufQ4aw+r3s/q2piDHDk+7qbLpRVG7tWVpg627MYw1vCT1cb3XmiYmHQzd5dY11y98Cbvn0YSAIXQgSHxDHG1xkrflXRBg4oPGh0Eup/Xe37Jow2hkKcpUbp2Y4pdZ9n3JPw5e+NeeEJY42mx4XZRgf5+rTqZJTn9acvfmuMr/tAErgQIvi43XAqr+q1xniQWpep/zSGOE4cguF3n3/Bz0UPGn0tS04Ys17mXW6Mv1/1Mgyo4wMikKxhxnCVDySBCyGCz9fPwYkfql53uxB6T657e1u4dzXPY3oY1QXzdhslYgG+eMacBD7xd8ZwESe83lVmoQghgk/Gl8ZwCBgPDvte4fu0wbpExlTVSUEZ49pmaNsNHtnm066SwIUQ5nK7YfGD8Kc4+Pd4Y+ikz+XGbJQzul3o//N26g8Xz4LIaGP45brX/H+OAPMogSul2iqlPlRK7VJK7VRKBeC3KYRoltI/hu0fGSs+c9KMh5cXPmQ0hlBWo4rgEd/uUOs1+hF4PBMeWA+xPQNzjgDy9A78BWCZ1roPMAjYGbiQhBBBxVECm/8DafPBWe7/45eeMGaOgJGsT+UZZV+P7TKGONwOWNbIjYxDRL0PMZVSbYCxwJ0AWutyIAD/Kwohgo7WMPdyY+UiwPcL4HYPVy56KuUa+OYfVd13xj1hdIE/k9QBwqJq3bW582QWSiKQC7yplBoEbAJ+prU+VX0jpdQ9wD0A3bo1sB+eECI4nD5uDF+c6Th/4Gujqa8t3H/niIyGBzZA3h6j4W9UjPHzix83WqGFt4Lr3vDf+ZqQeluqKaVSgXXAKK31eqXUC0CR1rrOvkbSUk2IJsLlhP9Lrrg7VtC6M8zc4fO85Ua38U1Y+6IxbfDqf/nWD7ORBKqlWhaQpbVeX/H6Q2Cot8EJIUKQ1QZ3LYPkydD3SvjJ0tBJ3oe3GEWw8vdBxlew5EGzI/K7eodQtNZHlFKHlFLJWuvdwHigaTWWE0LUrV0vuGn+uT8vPgrbPzRalg34sf/naTfUiUPGLBYwHoQeP2BuPAHg6UrMh4B3lFJhwH7gJ4ELSQgR9MqK4ZXRxgwSi80o8XrlC2ZHVVOPi402bGAk8O6joSjHGAZqIjz6yNRap2mtU7XWA7XWV2utCwIdmBAiiB1NN6r/ucqNutrpS8yO6FwRbeD+dXDhg4AyZtC8NAIKDpodmd8E2d88QoiQENOjapqfNQw6DzI3nrpEtDYaLzgrWsM5S2HX/8yOym8kgQshvNeyPdzxifFgc9idcMM8syOqW/vkqkqGFpvx4dNESDVCIYRv4obBjW+bHUX9fvQUlBRC9ncwcBr0vszsiPxGErgQoulwlsNHM4xqhvGpcMN/jE46V/3T7MgCQoZQhBBNx+Z5sGe50TYt8xtY/TezIwooSeBCiKajpMCYMghGL81TuebGE2CSwIUQjcftNhbUlBbVv60vBt8CkW0hrJVRQ+XChwJzniAhY+BCiMbhLId5V0LOVmM5/s3v12xi7A9t4uDhrUZhrJgeRjJvwuQOXAjRODK+gKPbjQVAjtOw4qnAnCe8JcQNbfLJGySBCyEaiz3KqC8OgAJ7C1PDaQokgQshGkfiWBg0DSx2o5Hv1NlmRxTyZAxcCNE4lIIrnje+hF/IHbgQQoQoSeBCCPNs+xD+2Bn+FAfbF5kdTciRBC6EMIezDD6+z5iRUn4SFt1rtHATHpMELoQwh9tZs/O8dhlfwmOSwIUQ5ghrAWN+AdZwo6b4xbP82+2+GZBZKEII8/zoCUi9y5ih0rKD2dGEHEngQghztepodgQhS4ZQhBAiREkCF0KIECUJXAghQpQkcCGECFGSwIUQIkRJAhdCiBAlCVwIIUKUJHAhhAhRksCFECJESQIXQogQJQlcCCFClCRwIYQIUZLAhRAiREkCF0KIECUJXAghQpQkcCGECFEeJ3CllFUptUUp9d9ABiSEEKbbsQg+eQR2LTU7kvPy5g78Z8DOQAUihBBBYftH8PH9sOlNWHgX7FlhdkR18iiBK6XigcuB1wIbjhBCmCzjS3CcNr53lEDmN+bGcx6e3oH/A/gl4K5rA6XUPUqpjUqpjbm5uf6ITQghGl+vS8EeaXxvj4QeF5sbz3nU29RYKXUFcExrvUkpNa6u7bTWc4A5AKmpqdpfAQohRKPqNxUsNuPOO+kSSBpvdkR18qQr/ShgqlJqChABtFZKva21vjWwoQkhhEn6TDG+gly9Qyha6ye01vFa6wRgGvClJG8hhDCfzAMXQogQ5ckQSiWt9UpgZUAiEUII4RW5AxdCiBAlCVwIIUKUJHAhhAhRksCFECJESQIXQogQJQlcCCFClCRwIYQIUZLAhRAiREkCF0KIECUJXAghQpQkcCGECFGSwIUQIkQ1uwR+sszJQ/M3M/H5VbzxzYFz3j9d7mTVnlz2Hi02ITohhPCcV9UIm4LffZLO8u1HKXe5+evy3fTt3JoLe8YCRnKf/I+vKTjtwOl28+drBnDN0HiTIxZCiNo1uzvw/bknKXdVtfY8dPx05fdr9uVx/HQ5J8uclDrcvLQyw4wQhRDCI80ugd89OpEIu4UW4VYi7BZ+1KdD5Xud20TirsjtVouia3SkSVEKIUT9mt0QyuQBnUls34IDuae4oEcsMS3CKt8bEN+GWZP78Nrq/XSLjeK56weZGKkQQpyf0tr/DeRTU1P1xo0b/X5cIYRoqpRSm7TWqd7s0+yGUIQQoqmQBC6EECFKErgQQoQoSeBCCBGiJIELIUSIClgCP1XmZH/uSZzVFs0IIYTwn4DMAy9xuBj5py9wujVd2kaw+MHRtAxvdlPOhRAioAJyB360qJTiMiclDhfZJ0r4ZOvhQJxGCCGatYAkcKtSWCuObFGKqDBrIE4jhBDNWkASeKc2kSR1aIXdqhjfpwNXDOwSiNMIIUSzFpCBabtVsfyRsYE4tBBCiApBN42wpNzF6r25ZOSeNDsUIYQIakE1NeRUmZPJL6zm+KlynG43z147kKuHxJkdFgAut+bJRdtYui2Hfp1b8+ptw2gbFVb/jkIIESBBdQf+7b488k+VVTZUePGrfWaHVOm/3x9mSdphikudbP6hgL8s22V2SEKIZi6oEninNhHVGipAXNvgaahQcKocd0XpXYdLk1dcbnJEQojmLqgS+MD4tjw+KZkubSMYkRDLX3880OyQKk0dHEd0VBgtw220CLPy4CVJZockhGjmpKFDhTKni9dWHyCroIRbR3YjpUubc7YpKXex52gxXWOianTyEUKIhvKloUO9DzGVUl2Bt4COgAbmaK1f8C3E4PXEwm38b1sOZU43S9Ky+fIX4+jYOqLGNpFhVgZ1bWtOgEIIcRZPhlCcwKNa637ASOABpVS/wIbV+Nbtz6fMaQzAWyyKXUeKTY5ICCHOr94ErrXO0Vpvrvi+GNgJBMfcPj8al9yBCLsFBWgN/Tq3NjsktNZk5J4k+0SJ2aEIIYKQV/PAlVIJwBBgfS3v3QPcA9CtW7ca75U73dz7n42s2pNLrw6teHv6BbRvFV5jmx2HC1m//ziDu7VlaLdo767CD353VQr9urQm+0QJPx4Wf058jU1rzcz3trJsRw5awy8u682MMT1NjUkIEVw8foiplGoJrAL+qLX+6Hzbnv0Qc8GGH3jmkx2UONxYLYrrh8bzl+urZpikHTrBtDlrcWujENa/bh3KuOQOPl1QU5FVcJrx/7eqclgnwmZh1x8mmxyVECJQAtaVXillBxYC79SXvGtT6nDhrviccGvNqXJnjfc/Sz9KqcNNudNNicPFEik/S1SYjeofrVFST10IcZZ6E7hSSgGvAzu11s/7cpJrhsbTpW0kkXYrbSLsPDKhV433+3dpTaTdKDkbabcyRGZ6ENMijD9dM4DWETY6tgrnlVuHmR2SECLIeHJbNwq4DdimlEqr+NmTWuulnp6kTaSdz2aOJaewlPatwomw16wPPql/J/JPlfNJ2mFaRFhpEWbD5dZYLcrTUzRJ1w+L5/ph8WaHIYQIUvUmcK31N0CDM6nNaqFrTFSt7ymluGZIHC98sZfC0+WszTjO+szj/OW64FmJGWzKnW7eXX+QvJNl3Di8W52/WyFE0xU0S+l3Hy2mpNxFuUtT4nCxbPsRs0MKao++n8azn+7i5ZUZXPniNxSVOswOSQjRyIImgXePieLMjBi7VdE/LvDzsI8UljLx+VUkPbmUB97djMvt/7ICgbJ6bx6lTjduDS6XZu9RqZ8uRHMTNAk8tmU4784YyaSUTtw0ohsv39Kwh3bHikq5/fX1THh+FR9vya51mz/8L539uSdxujVf7TrG0m05DTpnY0pNiCbMZkFVDG71bN/C3ICEEI0uqOamDeralldu889si4cXbOG7A8dxaZj10fcMiG9Dz/Yta2xzqsyJq+KmW2vN6bOmNwazf940lFdXZXDsZBl3jUqQ5hJCNENBlcD96YfjpyuTs9WiyDlRek4Cf/TSZDZmFuB0a+KjI7k8hJovR4ZZeWRib7PDEEKYqMkm8BljevDcst1YLNCuZTjDup+7PL9/XBvWPTme3OIy4qMjsVmDZkRJCCHqFdQJfNWeXHblFDG+bweSOrTyat+fjEoktXsMR4pKGZUUS2SYtdbtWoTbaOHlKke3W1Nc5qR1hA2lmvdcdSGEeYI2gb/33Q/8dkk6TrebF77YyycPjT5nCOR8Tpc7WbYjh2NFxt113/NUF9xztJhv9uYxIL4NwxNi6tzO4XLz56U7eXfDDzicmsT2LVj404toE2X36tqEEMIfGiWBO1xu5q3JJLughGkjupHcqf676UWbsylxuACwKM2afXleJfCH52/h6715lDvdfLr9CKseG0dsy3MrDO46UsQ1L63BpTVWBX+/cTCT+neu9Zh/W76beWsyK8fWM/NO8da6TB66pFet2wPknSzjvrc3se/YSX6c2pUnJveRu3YhhF80yqDvU4u28bcVu3lzTSbXvvwtx4pL690nNSGaCLsRnkUp+tXS4ux8Nv9wgvKKSn4K2J93qtbtvtx1jHKXq6KQlpsXv9xHXRUaNx0sqEzeYLQnqi8VP71kB1t+OEHBaQdvrzvIyj25Xl2HEELUpVES+Df78ih1VHS7UYr0w0X17vPIhN7cPy6JCX078PcbB9X6EPJ8xiW3J8JuwarAZlX07lj7XX+/zq2xqqpfw+6jxSzaXPu88WuHxhFhq9o2ITaK2y9KOG8cx4rKcFZbIJR/UrrZCyH8o1GGUMb0as/itGxKHW400K9L/assbVYLD4+vOTShteYvy3axdNsRUrtH86drB5xTGOuM564byLDu0eQVl3F9alfaRNY+Tj0uuQOje7Xjy13HAHC4NKv35XFtLUWkbr6gO3HRUew5UsRFSe3o17l1vcMhj0zoxfR5G7FaFG2j7Ezs17HeaxdCCE80Sld6h8vN22sPknWihOgoOx9uyiI+OornbxhEh7MaB5/P4rRsZi3cRonDRbjNwvTRiTw2qU+D412bkc9P5m6g1OEm0m7luesHcuUg/80JP1pUSlZBCSldWtf5geNPy3cc4ZlPdhAVZuMfNw6mf5x3w09CiMYXkK70/mC3WvjJ6ET2HC1m6ovfUOpwc+j4aR55L413Z4z0+DjZJ0oodxlDMWVON5n5tY9re+vCnrG8fsdwVu4+xvCEGC5N6eSX457RsXVEZYf7HYcL+dP/dhJms/L0lf1IaOffJfCFpx08PH9LZSefu+Z+x4anJvj1HEKI4NCo0wgz805VFoxyaTh0/LRX+18xoAv/WpmB1uBya+4clei32EYltWNUUju/Ha82ZU4XN81ZR1GpE4uCm/9dxJonxvv1HEWljhoPVk+cliqFQjRVjZrA567JxFFtGsdPRiV4tX+32Ci+fHQcWw+dILlTK7/VwF66LYf1+/P5UZ8OAe3FWXjaQWnFnbFbQ05Rqd8bV8RHR3JRUjvW7c/HrTXTR/fw27GFEMGlURN42qETld9H2q2M7OH9HW/7VuFM8OODwMVbspn1kTGu/t7GQ7x+x/CA3Ym3bxVOSpfW7D5SDMCYXu383nVIKcVrt6ey5dAJosKs513AJIQIbY2awC/sEcs3+/JwuNxEhllJaGd+F5mVe45VLhgqdbiZ/fle+ndpE5DVlUop5s8YyfIdR7BbLVzm57H2MywW5fW0SyFE6GnUBP7SLUP5z9pMCk47uGVkd6LCzF3J73S5ySsuQ0FlB/iNB49z3Str+Gzm2HOmCJZWzH5pyErKCLuVqwbH+R60EEJUaNQMGmG3MmNsT4+2Xb7jCDuyC7mkb0cGB6hL/RvfHuC7gwVUn0jp0sbD1qJSZ+XccafLzYy3NrJqTy6xLcJZcO9Ir5b1BxO3W1PmdNdZ3EsIETqCsn7q/PUHeWRBGrO/3Me0OWvZcbgwIOc5kHe6coUoGMvibRZFl7aRtI6o+mxbkX6U9QeO49aQd6qMZ5bsCEg8gbYtq5Ahv/+M/k8v58F3N+MOoRZyQohzBWUCX7I1p3Jc2uXWrM3ID8h5pg3vSqTdSstwG1FhVq4dGscdFyWw8L6LagyTVO+VqbUxgyQUPfXxNgpLHLi05stdx1gToN+rEKJxBF052f99f5gNB6oSi9WiGNKtbUDONahrW5Y/MpbthwsZ1LUtcW0ja93uspROvL3uIJt/KKBFmI1fXdE3IPEEmvusVbdnvxZChJagS+C//+/OqlZoCn5xaTLDutddo7uhusVG0S32/LNhwmwWFtwzksISBy3DbSHbuef3V/Xnttc3UOpwMTqpHaMDvHBJCBFYQZfAW0bYoKJYod1m4eLe7c0NqIJSqrJxcFGpg798uoucwlLuH9eT1PM0gQgmQ7pFk/abiZx2uGgdIU0ohAh1QXcr+cK0wXRpG0Gk3cqDP0qiVx1lYM300LubeX/jIb7cdYzb39jA0aL665sHC5vVIslbiCYi6O7AU7q0Yc0s/9YH8bft2UWVJQEsSpGZd6qyWJUQQjSWoLsDDwVXDupCVJiVcJuFSLuVFCnXKoQwQdDdgYeC31zRj+EJMeQWl3L5wC609LKrvRBC+EOzzjyny52E26xeF5SyWBSXD6y98bEQQjSWZpnAtdb8bEEa/9uWQ6Tdylt3j2BoNyn+JIQILc1yDHzDgeN8vvMoLrfmZJmTJz7aZnZIQgjhtZC/Ay8scTDn6wzKnW7uHt2DTm18mA0iCxKFECEo5BP4ra+tZ9eRItxa88nWw6x+/BLs9ayUHJ4Qw/i+HVi67QiRdit/unZAI0UrhBD+41ECV0pNAl4ArMBrWutnz7f9riPFHCks9e1uGKN4lEVRb91tt1uzPbuw8gb6RImD3OIyutRR0wSM8e+sghJ+N7U/z147kAi79w8xhRAiGNQ7Bq6UsgIvAZOBfsBNSql+59vH4XLz98/3+BTQ35bvpvevPqX/b5ezZl/eebe1WBSDurYlzGrBZlHEtAijQ6vwOrd3uzUz3trIpX9fxcg/f8GqPcdMTd77c0/y1a5jFJZI42EhhPc8uQMfAezTWu8HUEotAK4C0s+3ky+1pjPzTvHv1ftxuTWnylzMfD+N9U9OOO8+b0+/gDe/PUCZw80dFyWct9DU9sOFrMnIr2ws/MySdKYM6OJ1nP7wxc6jPPDuZmwWYzHQ8pljiWkRZkosQojQ5EkCjwMOVXudBVxwvh3sFguPTOztdTBOt5vqoybOah3s80+W8cqqDFxuzU8v7kmHiqXrLcNtPHRJL4+OHxVmrVFCNcrLBThFpQ7ufGMD32cVkpoQzRt3Dve5LdzLKzMqmkm4cbndfL7zKDekdvXpWEKI5slv0wiVUvcopTYqpTbG2krrrK19Pj3bt+TqwXHYrYpwm4U/XtO/8r0bX13Lm99mMm/tQa55eY1Pd/hJHVpx/8VJhNssdGgVzgvTBnu1/6urMtiWXYjTrdn8wwnmrcn0OoYzusdGYbee+bRSPv2+hBDNmye3j9lA9VvD+Iqf1aC1ngPMAUhNTfVpYp5SimevG8jjk/oQbrdU3t2WOlzszztV2QnnWHEphSUOon0Ycnh4Qi8enlD3Hfufl+5k7ppMWobbmHfXCPpXq3NyqsxV2Z3nzDCPr56+MoWiEge7jhRz04hujJLa3EIIL3mSwL8DeimlEjES9zTg5kAGdXZijrBb6du5NXuPnkRrTXx0VGXDYX9afyCfV7/eD0CZs5wfv7KGnb+fXPn+9DGJfLL1MCUOF60ibNx+YXefz9Um0s5rdwxvcMxCiOar3gSutXYqpR4ElmNMI3xDa93oXX3n3zOSt9Zk4nLDHRd1xxKA2SMH8k7VeF3icON268pzxUdH8e2sS8gpLKVL2wjCbdLZXQhhHo+ewGmtlwJLAxzLebWOsPOghw8rfXXFgM78+uPtlbW+kzu1pKjUwVOLtnMw/xT3XtyTKwd1IbFdi4DGIYQQngjoSkyny83LKzNIO3SCa4fGccVAc6bseaplhJ21s8bz0lf7iG0Zzoyxidz/9ma+3pOLw6157MOtJHdqRe8g7BIkhGh+AprAX/xqH6+uyqDE4WZtRj7tW4ZzQY/YQJ6ywdq1CufpqSmVrzNyT+KoeHBpsyh+yD8tCVwIERQCWo1wU2YBJQ5j0YxLa9JzigJ5uoC486IEIu1WWoRZaRFuY0SP0GhgLIRo+gJ6B37NkDg2HizA6XJjtSjG9Aq9qXJ3jkpkQHwbsgpKGNe7gzQEFkIEjYAm8GuHxdOhdQTpOYWMS+5AUgf/DT3kFJawbn8+vTu2IqVLYHtSDusewzDfZwwKIURABLyc7Ohe7Rjt5zvvQ8dPM/mF1WitcWnN7GlDuDSlk1/PIYQQwS4kO/J8sfMoDpebU+UuSh1u/rPuoNkhCSFEowvJBJ7YviWWiqpXETYLfTq1rncfrTVHi0opdfi+/F0IIYJJSHbkubh3ex6flMwHm7IY3LUtj156/sqHDpeb215fz5YfTmCzKN66+wKGdZcmxkKI0BaSCRyM2SF3jkr0aNtVu3PZllVImdNNGfDgu5uIaRHO8IQYnpzSlzBbSP4hIoRo5kI2gXsjzGap0bf4aFEZOYVlZOSepE2knZk+1C4XQgizNYtbz9FJ7bgspRMWBS3CrJwpg1XqcLMzBBcXCSEENJMEbrEo/n7jYPb9cQqfPDSaCLuVqDArkXYLt4yUCd5CiNDULIZQzrBYFD3at2T5zLFsOHCcvp1b07dz/TNYhBAiGDWrBH5GfHQU8dFRZochhBAN0iyGUIQQoilq8gn88IkS1mTkcbLMaXYoQgjhV016CGVtRj53zf0OqwWiwmx8+rMxxLYMNzssIYTwiyZ9B/7SV/socbg4WeaiqNTBp9uPmB2SEEL4jdJa17+VtwdVKhcItgpT7YA8s4NooKZwDdA0rqMpXAM0jetoCtcAkKy19qrmdkCGULTW7QNx3IZQSm3UWqeaHUdDNIVrgKZxHU3hGqBpXEdTuAYwrsPbfZr0EIoQQjRlksCFECJENacEPsfsAPygKVwDNI3raArXAE3jOprCNYAP1xGQh5hCCCECrzndgQshRJMiCVwIIUJUs0jgSqlJSqndSql9SqlZZsfjLaVUV6XUV0qpdKXUDqXUz8yOyVdKKatSaotS6r9mx+IrpVRbpdSHSqldSqmdSqkLzY7JW0qpmRX/LW1XSs1XSkWYHZMnlFJvKKWOKaW2V/tZjFLqM6XU3op/g7pfYh3X8NeK/56+V0otUkq19eRYTT6BK6WswEvAZKAfcJNSqp+5UXnNCTyqte4HjAQeCMFrOONnwE6zg2igF4BlWus+wCBC7HqUUnHAw0Cq1ro/YAWmmRuVx+YCk8762SzgC611L+CLitfBbC7nXsNnQH+t9UBgD/CEJwdq8gkcGAHs01rv11qXAwuAq0yOySta6xyt9eaK74sxEkacuVF5TykVD1wOvGZ2LL5SSrUBxgKvA2ity7XWJ0wNyjc2IFIpZQOigMMmx+MRrfXXwPGzfnwVMK/i+3nA1Y0Zk7dquwat9Qqt9ZmKe+uAeE+O1RwSeBxwqNrrLEIw+Z2hlEoAhgDrTQ7FF/8Afgm4TY6jIRKBXODNiqGg15RSLcwOyhta62zgb8APQA5QqLVeYW5UDdJRa51T8f0RoKOZwfjBXcCnnmzYHBJ4k6GUagksBB7RWodUM0+l1BXAMa31JrNjaSAbMBT4l9Z6CHCK4P+TvYaKMeKrMD6MugAtlFK3mhuVf2hjXnTIzo1WSj2FMWT6jifbN4cEng10rfY6vuJnIUUpZcdI3u9orT8yOx4fjAKmKqUyMYaxLlFKvW1uSD7JArK01mf+AvoQI6GHkgnAAa11rtbaAXwEXGRyTA1xVCnVGaDi32Mmx+MTpdSdwBXALdrDBTrNIYF/B/RSSiUqpcIwHtYsMTkmryilFMaY606t9fNmx+MLrfUTWut4rXUCxv8GX2qtQ+6uT2t9BDiklEqu+NF4IN3EkHzxAzBSKRVV8d/WeELsQexZlgB3VHx/B7DYxFh8opSahDG8OFVrfdrT/Zp8Aq94MPAgsBzjP9L3tdY7zI3Ka6OA2zDuWtMqvqaYHVQz9hDwjlLqe2Aw8Cdzw/FOxV8PHwKbgW0YeSAklqMrpeYDa4FkpVSWUupu4FlgolJqL8ZfF8+aGWN96riGF4FWwGcV//9+xaNjyVJ6IYQITU3+DlwIIZoqSeBCCBGiJIELIUSIkgQuhBAhShK4EEKEKEngQggRoiSBCyFEiPp/+ErZiu+VzlwAAAAASUVORK5CYII=\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "np.random.seed(42)\n",
    "syn = SyntheticData()\n",
    "data, labels = syn.sample_initial_data()\n",
    "\n",
    "sct = decision_boundary.Scatter2D(data, labels)\n",
    "sct.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "organizational-western",
   "metadata": {},
   "outputs": [],
   "source": [
    "X_train, X_test, y_train, y_test = train_test_split(data, labels, \n",
    "                                                    test_size=0.33, \n",
    "                                                    random_state=42)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "other-thinking",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "sct = decision_boundary.Scatter2D(X_train, y_train, \n",
    "                                  X_test, y_test, \n",
    "                                  x_lim=(-10, 20), y_lim=(-10, 20),)\n",
    "sct.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "periodic-transsexual",
   "metadata": {},
   "source": [
    "# Meshgrid"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "rising-commissioner",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(144, 2)\n"
     ]
    }
   ],
   "source": [
    "step = 3\n",
    "xx, yy = np.meshgrid(np.arange(-10, 25, step),\n",
    "                     np.arange(-10, 25, step))\n",
    "\n",
    "X_mesh = np.c_[xx.ravel(), yy.ravel()]\n",
    "y_mesh = syn.get_labels(X_mesh)\n",
    "print(X_mesh.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "47cf06b4-8702-4b51-b3fe-b05a44f1ed8d",
   "metadata": {},
   "outputs": [],
   "source": [
    "y_train = y_train.astype(int)\n",
    "y_test = y_test.astype(int)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "4241fee5-080d-45e5-bb2b-cef562266a94",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "MLPClassifier(hidden_layer_sizes=1000, max_iter=1000)"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "baseline_model = MLP(hidden_layer_sizes=1000, activation='relu', max_iter=1000)\n",
    "baseline_model.fit(X_train, y_train)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "f4aac0d2-2a77-4100-a33a-0a9074862c68",
   "metadata": {},
   "outputs": [],
   "source": [
    "db_difference = DecisionBoundaryDifference(x_lim=(-10, 25), \n",
    "                                           y_lim=(-10, 25),\n",
    "                                           baseline_model=syn.get_labels, \n",
    "                                           mesh_size=70)\n",
    "\n",
    "metric = lambda model, X, y: db_difference.compute_difference(model.predict)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "261151a1-de46-458d-b58a-264af56c7a5d",
   "metadata": {},
   "outputs": [],
   "source": [
    "model = 'NN'\n",
    "problem = 'classification'\n",
    "num_test = 10\n",
    "directory = './temp'"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "cac9f226-345b-4547-8fc3-a28e9ead2233",
   "metadata": {},
   "source": [
    "# 1. Data Shapley on training data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "ecd4f1a0-6b68-40d0-abf9-e71d5f359f69",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Starting LOO score calculations!\n",
      "LOO values calculated!\n",
      "Running iteration  1 error 1.0\n",
      "Running iteration  2 error 298507464.0348258\n",
      "Running iteration  3 error 0.5549238975590579\n",
      "Running iteration  4 error 0.2943831963974418\n",
      "Running iteration  5 error 0.18425818594085802\n",
      "Running iteration  6 error 0.17388473235036986\n",
      "Running iteration  7 error 0.11399141102691049\n",
      "Running iteration  8 error 0.10571922540481841\n",
      "Running iteration  9 error 0.09159017843352751\n"
     ]
    }
   ],
   "source": [
    "dshap = DShap(X_train, y_train, X_test, y_test, num_test, \n",
    "              sources=None, \n",
    "              sample_weight=None,\n",
    "              model_family=model, \n",
    "              metric='accuracy',\n",
    "              overwrite=True,\n",
    "              directory=directory, \n",
    "              seed=0,\n",
    "              hidden_layer_sizes=1000, \n",
    "              activation='relu', \n",
    "              max_iter=1000\n",
    "             )\n",
    "\n",
    "dshap.run(100, 0.1, g_run=False, loo_run=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "trying-paintball",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "dv = dshap.vals_tmc\n",
    "\n",
    "sct.scatter(X_train, y_train, scatter_size=dv*5000+1)\n",
    "sct.show(scatter=False, title=\"TMC on train data only\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "9cbdb108-b0b1-490e-b859-ced8b2728423",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.005970149253731343\n",
      "0.002239620498594199\n"
     ]
    }
   ],
   "source": [
    "print(dv.mean())\n",
    "print(dv.std())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "8bbe08d3-3f42-41b7-8922-419018705471",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "dv_loo = dshap.vals_loo\n",
    "\n",
    "sct.scatter(X_train, y_train, scatter_size=dv_loo*5000+1)\n",
    "sct.show(scatter=False, title=\"LOO on train data\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "66d838bc-d742-4998-9c1f-ec09711c31c4",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.0\n",
      "0.0\n"
     ]
    }
   ],
   "source": [
    "print(dv_loo.mean())\n",
    "print(dv_loo.std())"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "cd3ba606-9973-45e2-ac50-9b7faf119b87",
   "metadata": {},
   "source": [
    "## 1.1 Using the decision boundary change as metric"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "8b8994f1-8770-4d34-be12-f8ecd63be419",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "LOO values calculated!\n",
      "Running iteration  1 error 1.0\n",
      "Running iteration  2 error 14.934854193375765\n",
      "Running iteration  3 error 12.058594152303236\n",
      "Running iteration  4 error 0.4162461498909927\n",
      "Running iteration  5 error 0.3358503012171089\n",
      "Running iteration  6 error 0.17711657782927054\n",
      "Running iteration  7 error 0.2732887694806117\n",
      "Running iteration  8 error 0.13941673028141408\n"
     ]
    }
   ],
   "source": [
    "dshap = DShap(X_train, y_train, X_test, y_test, num_test, \n",
    "              sources=None, \n",
    "              sample_weight=None,\n",
    "              model_family=model, \n",
    "              metric=metric,\n",
    "              overwrite=True,\n",
    "              directory=directory, \n",
    "              seed=0,\n",
    "              hidden_layer_sizes=1000, \n",
    "              activation='relu', \n",
    "              max_iter=2000\n",
    "             )\n",
    "\n",
    "dshap.run(100, 0.15, g_run=False, loo_run=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "b2b30327-cb57-423f-9a05-5ce6935d77ea",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(67,)\n"
     ]
    }
   ],
   "source": [
    "dv = dshap.vals_tmc\n",
    "dv[dv < 0] = 0\n",
    "print(dv.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "3bc244ae-3d19-49db-adc4-0097955dd3c6",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAX8AAAEICAYAAAC3Y/QeAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjQuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/Z1A+gAAAACXBIWXMAAAsTAAALEwEAmpwYAAAk8ElEQVR4nO3deXxU9b3/8dcnGwk7BISQsIuyai4GBRfqzqJe1KpF64KtF9vi0mtvvVrrlV+vbdW2anvdrdQNt2pBq9QFrFBUQFZBUFkUSGQNO4SQ5fv745zgkMwkmcxMtvN+Ph55zMxZvt/vyZnznnO+58wZc84hIiLBktTQDRARkfqn8BcRCSCFv4hIACn8RUQCSOEvIhJACn8RkQBS+EuNzGyfmfWJU1lfm9nZ8SgrXmpavljabGa9zMyZWYr/+gMzu66ubQ0pNy7lSHhm9gsz+3NDtyORFP4R+IFQ8VduZkUhr79vZpP9jfrmSvPd7A+fHDKsrZk9aGYb/PnX+q87JXgZTjez/FjLcc61ds6ti0ebouH/H49OdD2hy2dmT5vZ3YmuUxpGbbcJ59xvnHPN+sNV4R+BHwitnXOtgQ3ABSHDpvqTfQlcXWnWa/zhAJhZGjALGASMBtoCI4BC4MQEL0aNKvZIRcQTlG1C4R+bT4CWZjYIwH9M94dXuBroAVzknFvpnCt3zm11zv2vc25GuELN7GQz+8TMdvuPJ4eM+8DM/tfMPjSzvWb2brgjCDNrBfwD6BZyxNLNP2J51cyeN7M9wAQzO9HMPjazXWa2ycwe8j+0Kso6vAfu7xk/bGZv+fXPN7O+kf5BZnaVma03s0Izu6PSuIj1mtkcf7Jlftu/Z2YdzOxNM9tmZjv95zkR6r3WzP4e8nq1mf015PVGM8sNXT4zmwh8H7jVr/PvIUXmmtmn/jp52czSI9SbbGa/N7PtZrYOOC/MZH3NbIGZ7TGz182sYzX/v3FmttSfdq2ZjQ4Z3TPS+8DM/mpmm/32zql4j/rjql2HZnaumX3hz/uImc22kC4mM/uBma3y18E7ZtazmvZX146xZrbSb0OBmf1XhDIm+Mv5gP9eWWfeNjLBX49bzeyakOlb+Otgg5ltMbPHzCzDotsmJpvZ8yFlnmpmH/n1bzSzCZGWuclwzumvhj/ga+DsSsMmA88DvwDu9YfdB9zuD5/sD3sJeCaKujoCO4GrgBTgcv91pj/+A2AtcAyQ4b++J0JZpwP5YdpdAlyI9+GfAZwADPfr6wWsAn4aMo8DjvafP823Ry0pwFTgpQj1DwT2ASOBFsD9QGnF/zKaev3XmcB3gZZAG+CvwPQIdfcBdvnL2A1YX/G/8MftBJIiLN/dYdb/Ar+cjn47fxSh3h8BnwPd/Wn/6ZefErL+CoDBQCvgNeD5CGWdCOwGzvGXIxvoX5v3AfAD/3/UAngQWBoyLuI6BDoBe4CL/XE3471frvPHjwPWAAP88b8EPqrm/VxdOzYBp/nPOwBDI5QxwX/fXAskA3fjHY0/7Jd7LrAXaO1P/wDwhv//bwP8HfhtlNvE5Ir1AvT0y78cSMV7H+Y2dC7F+tfgDWgKf1Qf/j38N2Kq/9idI8P/PSKEc4S6rgIWVBr2MTDBf/4B8MuQcT8B3o5QVqQ3+pwa2vBTYFrI68rh+OeQcWOBzyOU8z+EfDDghd2hyv/L2tQbYfpcYGc14zcCQ4HxwBN4Ad7fD5E3qlm+cOF/Zcjr+4DHItT5PiEfDHjBVDn8Q0N6oP8/SQ5T1uPAAxHqieZ90N5vQ7ua1iHekerHIePM/z9WhP8/gB+GjE8CDgA9a/HertyODcD1QNsa5psArA55PcQvp0vIsEL//WDAfqBvyLgRwFfRbBMcGf63h74vm8ufun1i5JzbgLcn9Bu8N+jGSpMUAllRFFmxlxpqPd5eX4XNIc8PAK2jKB+8jfkwMzvG70LZ7B/2/gZvDzCS2tbfLbQu59x+vP9Hneo1s5Zm9rh53Uh7gDlAezNLjjDLbLyNfaT//APgO/7f7GqWL5w6LTNV1yVhxqcSfrm74+3dR9Umv+vpHr+baA/ehxeV6oi0PJXXmQNCT5D2BP7od3/sAnbgBW7o+5NatuO7eB886/2upRHVLOuWkOdFftsqD2sNdMY7MlwU0sa3/eHVqbzdhqppPTRJCv/4eBb4mf9Y2UxglN/fWBvf4G1goXrgdRVEK9ItWysPfxSvq6Kfc64tXleW1aG+yjbhbTiAF954h8x1rfdnwLHASf70IyuKjjB9Rfif5j+fTc3hH+ttbo9YZrx1V1nl8SXA9jDTbQQink+pxhV43TNnA+3wutSgdut0E3D4PIqZWehrv03XO+fah/xlOOc+irYdzrlPnHPjgKOA6cArtVm4GmzH+yAYFNK+ds67cANqv02Equt6aNQU/vHxMt7hfbg373N4b57XzKy/mSWZWaZ51xGPDTP9DOAYM7vCzFLM7Ht4XQNv1qFdW4BMM2tXw3Rt8Pp595lZf+DHdagrnFeB8/2TZWnArzjyPVdTvVvw+udDpy8CdvknSe+qof7ZwBlAhnMuH/gX3hVXmcCSCPNUrjNarwA3mVmOmXUAbgszzZVmNtD/MPwV8KpzrizMdE8B15rZWf77Jtv/P9WkDVCMd5TVEu+IqrbeAoaY2YXmXfUyCegaMv4x4Hb79iKHdmZ2abTtMLM08y6ZbuecK8F7H5RH0c6wnHPlwJPAA2Z2lF9XtpmN8iep7TYRaipwtpld5m+TmeZfLNCUKfzjwDlX5Jyb6ZwrCjOuGG/P53O8/v89eH3PnYD5YaYvBM7H28stBG4FznfOhdszrKldnwMvAuv8Q+BuESb9L7y9tL14G87L0dYVof7P8MLjBbw9yp0c2YVQU72TgWf8tl+Gd8IwA2/vbh7e4Xx19X+Jd8L5X/7rPcA64MMIYQte4A7065xem+Ws5EngHWAZsBj4W5hpnsPrd9+Md3XYTRHavwDv/MQDeCd+Z1P1qDCcZ/G6kwqAlXj/q1rx32eX4p3XKMTb8ViIF+I456YB9wIv+V05K4AxdWzHVcDXfjk/wrvSKh7+G68rdp5f9ky8I8ZotonD/K7dsXjb5A5gKXB8nNraYMw/oSEiUoWZJeF9YH/fOffPhm6PxI/2/EXkCGY2yszam1kLvj0PU+ujB2kaYg5/M+tuZv/0v6zxmfm3OzCzjmb2nnlfrnnP7/8UkcZvBN7VLduBC4ALw3VpStMWc7ePmWUBWc65xWbWBliE92WJCcAO59w9ZnYb0ME5998xtldEROIg5j1/59wm59xi//levG8/ZuNd4vWMP9kzeB8IIiLSCMT1hK+Z9cL74s1gYINzrr0/3PC+idk+zDwTgYkArVq1OqF//9pcySYiIhUWLVq03TlX0xfZjhC38Dez1niXov3aOfc3M9sVGvZmttM5V22/f15enlu4cGFc2iMiEhRmtsg5lxfNPHG52sfMUvFuUDXVOVdxXfMW/3xAxXmBrfGoS0REYhePq30M74sxq5xz94eMegPv3vb4j6/HWpeIiMRHPH604BS8b+otN7Ol/rBfAPcAr5jZD/G+5XdZHOoSEZE4iDn8nXNziXzDqLNiLV9EJJKSkhLy8/M5ePBgQzelXqSnp5OTk0NqamrMZQXi58pEpHnKz8+nTZs29OrVC68HuvlyzlFYWEh+fj69e/eOuTzd3kFEmqyDBw+SmZnZ7IMfwMzIzMyM21GOwl9EmrQgBH+FeC6rwl9EJIAU/iIicbJo0SKGDBnC0UcfzU033US4L9E+9thjDBkyhNzcXE499VRWrlx5eNynn37KiBEjGDRoEEOGDEnoiWyFv4gESsGuIj5au52CXfG/UemPf/xjnnzySVavXs3q1at5++2qvzd0xRVXsHz5cpYuXcqtt97KLbfcAkBpaSlXXnkljz32GJ999hkffPBBXK7qiURX+4hIIOwrLuXGFxbz0dpC0lKSOFRazsl9M/m/K4bSukXsUbhp0yb27NnD8OHDAbj66quZPn06Y8Yc+UNnbdu2Pfx8//79h/vx3333XY477jiOP977kbDMzEwSSXv+IhIIN76wmA/XbKe4tJy9B0spLi3nw7WF3PjC4riUX1BQQE7Ot791n5OTQ0FBQdhpH374Yfr27cutt97Kn/70JwC+/PJLzIxRo0YxdOhQ7rvvvri0KxKFv4g0e15XTyGHyo7sgz9UWs5HawsT0gVUnUmTJrF27Vruvfde7r77bsDr9pk7dy5Tp05l7ty5TJs2jVmzZiWsDQp/EWn21hfuJy0lfNylpSSxvnB/zHVkZ2eTn59/+HV+fj7Z2dnVzjN+/HimT58OeEcKI0eOpFOnTrRs2ZKxY8eyeHF8jkrCUfiLSLPXM7MVh0rLw447VFpOr8xWMdeRlZVF27ZtmTdvHs45nn32WcaNG1dlutWrVx9+/tZbb9GvXz8ARo0axfLlyzlw4AClpaXMnj2bgQMHxtyuSHTCV0Savez2GZzcN5MP1xYe8SGQlpLEyX0z6dY+Iy71PPLII0yYMIGioiLGjBlT5WQvwEMPPcTMmTNJTU2lQ4cOPPOM94OHHTp04JZbbmHYsGGYGWPHjuW8886LS7vCiesvecVKP+YiItFYtWoVAwYMqNW0ib7ap76EW+a6/JhL01liEZEYtG6Rwl+uPZGCXUWsL9xPz8xWZMdpj78pUviLSKBkt88IdOhX0AlfEZEAUviLiASQwl9EJIAU/iIiAaTwFxGJkzvuuIPu3bvTunXriNO8/vrrHHfcceTm5pKXl8fcuXMPjxs9ejTt27fn/PPPT3hbFf4iInFywQUXsGDBgmqnOeuss1i2bBlLly5lypQpXHfddYfH/fznP+e5555LdDMBhb+ISNwMHz6crKysaqdp3br14ds4h97SGbwPhjZt2iS0jRUU/iIi9WzatGn079+f8847jylTpjRIGxT+IhIs+wvhwz96jw3koosu4vPPP2f69OnceeedDdIGhb+IBMvS5+G9//EeG9jIkSNZt24d27dvr/e6dXsHEQmW3CuPfKxna9asoW/fvpgZixcvpri4OOE/2RiO9vxFJFhaZcIpN3uPcXbrrbeSk5PDgQMHyMnJYfLkyVWmee211xg8eDC5ublMmjSJl19++fBJ39NOO41LL72UWbNmkZOTwzvvvBP3NlaIyy2dzWwKcD6w1Tk32B82GfgPYJs/2S+cczOqK0e3dBaRaERzS+fmIl63dI7Xnv/TwOgwwx9wzuX6f9UGv4iI1J+4hL9zbg6wIx5liYhI4iW6z/8GM/vUzKaYWYcE1yUiAdSYfo0w0eK5rIkM/0eBvkAusAn4Q7iJzGyimS00s4Xbtm0LN4mISFjp6ekUFhYG4gPAOUdhYSHp6elxKS9hl3o657ZUPDezJ4E3I0z3BPAEeCd8E9UeEWl+cnJyyM/PJyg7junp6eTk5MSlrISFv5llOec2+S8vAlYkqi4RCabU1FR69+7d0M1okuIS/mb2InA60MnM8oG7gNPNLBdwwNfA9fGoS0REYheX8HfOXR5m8FPxKFtEROJP3/AVEQkghb+ISAAp/EVEAkjhLyISQAp/EZEAUviLiASQwl9EJIAU/iIiAaTwFxEJIIW/iEgAKfxFRAJI4S8iEkAKfxGRAFL4i4gEkMJfRCSAFP4iIgGk8BcRCSCFv4hIACn8RUQCSOEvIhJACn8RkQBS+IuIBJDCX0QkgBT+IiIBpPAXEQkghb+ISAAp/EVEAkjhLyISQHEJfzObYmZbzWxFyLCOZvaema32HzvEoy4REYldvPb8nwZGVxp2GzDLOdcPmOW/FhGRRiAu4e+cmwPsqDR4HPCM//wZ4MJ41CUiIrFLZJ9/F+fcJv/5ZqBLuInMbKKZLTSzhdu2bUtgc0REpEK9nPB1zjnARRj3hHMuzzmX17lz5/pojohI4CUy/LeYWRaA/7g1gXWJiEgUEhn+bwDX+M+vAV5PYF0iIhKFeF3q+SLwMXCsmeWb2Q+Be4BzzGw1cLb/WkREGoGUeBTinLs8wqiz4lG+iIjEl77hKyISQAp/EamZc7BkKmxeUfO00iQo/EWCYtHTMOd3dZt360p4/Sfw95vi2iRpOHHp8xeRJmDm/4OiHTDiRkhNj27ezv3h3F9D9xMT0zapdwp/kaCY8CYc2h998AMkJcPJN8S/TdJgFP4iQdFlUEO3QBoR9fmLSO3tL4T7B8Lbtzd0SyRGCn+R5qC8HLas9K7KidWSqXB3V9gwr+q4smLYuxn2bjpyePE+r0tJmgyFv0hzMP8xeHQELHm+7mXs2wpzfg8HCqH0IJSXVp2mbTe4YxNc8pdvhzkHDwyE/zuh7nVLvVP4izQHOcOg21DIOr7uZSx9Ad7/X+/5XTuh16nhp0tpAWZHDsvOg+wT4K2fw+s31r0NUm/MxeMwMU7y8vLcwoULG7oZIsF0YAcsewmOHw8tO9atjHt6QmkR3LGl6geEJIyZLXLO5UUzj/b8RZqSbV96J12jcWi/F+rFe73XxXvDnxto2RFG/KTm4C8v8/r9w7niZRh7v4K/CVD4izQFG+bB52/Bw8Pg2Quim3fRMzDtevjkz7B5Ofw2B/5xa/hpt3wGfzweVr0ZubwZP4c/HAv5YY7S374N3pgE21dH10apd7rOX6QpeOYC7wTsgHHQ46To5h04DnZ9DYO/6+3xt8uBVl2grBSSK0XAnm9g59ewbRUMOD98edknwPoPoXWYX2Y9805vXIfe0bVR6p36/EWagsXPed0teROqn660GDZ8DD1PrRrsFbavhofyvJPDV02v2s2zbyu06lz3rpv9hV6Z6vqpN+rzF2muhl5Vc/ADfPwIPDsOljwbeZq0NtCiLWxaBguerDq+9VF1D+4Vr8Hv+nhdTdKoqdtHpDk55lzIXwC9vxN5mp3roHgPZHSEY8fEt/62OV63Uoce8S1X4k57/iLNSZdBcPmLkNk38jTZeXDMGO8On5/PiG/9PU6C//wM+p4Z33Il7hT+IkFRUgTv3QWbP4ULH/FOzp5wTd3Kyl/oXTFUcfmoNDkKf5GgKFgEHz4Is++Ddf+EfudA26y6lfXxQzD/cdi4IK5NlPqjPn+RoOhxMnz3KSg9BK/+ADr2hZsW162s0ffCwAuhzxlxbaLUH+35iwRFUhIMueTbvfWjz6p7WW26wKALvTKlSdKaEwmanKHeY0lR+PHOQVlJ/bVHGoS6fUSCZtDFsH+7t+cezus3wLIX4eal0F6XbDZX2vMXCZoWreG0W6Bjn/DjMzqCJcHfrq/fdkm9UviLiMc57xu6x4+HjPaw86uGbpEkkLp9RMRTuNa7CqjLEPjpCt2bp5lLePib2dfAXqAMKI325kMiUk869oGzJkPOCZCa3tCtkQSrrz3/M5xz2+upLhGpzDnYne/ddyfSHn1SEpz2n/XbLmkw6vMXCYJPX4EHB3s/6CJC/YS/A941s0VmNrHySDObaGYLzWzhtm3b6qE5IgGUeTRk9oOjBjR0S6SRSPiPuZhZtnOuwMyOAt4DbnTOzQk3rX7MRUQkeo3yx1yccwX+41ZgGnBiousUEZHqJTT8zayVmbWpeA6cC6xIZJ0iIlKzRF/t0wWYZt7VBSnAC865txNcp4iI1CCh4e+cWwccn8g6REQkerrUU0RqZ8N8eOpc2PZFQ7dE4kDhLyK18/Vc2DgfvlnS0C2RONC9fUSkdk652fvpx65DGrolEgcKfxGpneQUyDquoVshcaJuHxGRAFL4i4gEkMJfEuar7ftZUbC7oZshImEo/CUhFq3fyZg/zuGSxz7i5U82NHRzRKQShb8kxBeb9+IcHCotZ8mGXQ3dHBGpRFf7SEKMy+3GB19uZdeBEm48q19DN0dEKlH4CwDl5Y6S8nJapCTHpbxWLVJ44ir9YqdIY6VuHwHgmr8sYMhd77L7QElDN0VE6oHCXwDo2i6drPbppCRX/X3XHfsPUV4e/Y/+lPnz5O88wOgH5zD0V+/y6qL8mNsqIrFTt48A8LtLwt98dcFXO7js8Y+5fmQfbh9bu58AXFGwmx88/Qnb9hYzIKstnduk8eWWvZQ7uP1vnzJmcFdatdBbT6QhaQuUanVqnUaPji05tmubWs9zrR/8AF9s2cOWPWmJap6I1JHCX6rlgJm3fIe0lNr1EB4qLWf7vuLDr8vKIcmM/l3bsmXPQX4xdoD2+kUaAW2FEtFHa7dzxZPzuXJ4T+6+cHCt5klLSaJPp1Z8tX0/5Q5apCRxytGZPDj+3xLcWhGJhk74SkS9MluR2709px3dKeI0Bw6V8ugHa3h89lqKDpUB8MvzBnJMlzZ0btOCUYO68puLY78F8Px1hdz39uccKi2PuSwR0Z6/VKNb+wymTzql2mlueGEJc9dsB2Dpxl3cdcEgfvT8IpLMeHB8LqMGdY1LW+5/70vmf7WDMYOzGJLTLi5ligSZwl9isvKbPYf3xlcU7CYtJYmUJKO03NEq7cgvjBUdKqPcuTr1+d93yXF89s0eBme3jUu7RYJO3T4Sk5+c3gcAA24482g6tkrjrn8fRHFpOVdPWcDfl35zeNqz7v+A4b+dVafvDPTMbMXYIVmYed9D2LLnIPe9/Tln/P4DTr33fSZNXcySDTvjskwiQaA9f6lief5uDpaWMaxXxyrjXpy/gY/WbecPl+aSlpLElcN78dA/19ImPYXvDesBwJvLvMAvd/C7d7/ggtxuAAzJbsf+4jKs6vfIojJtST7//eqnOKCkzPsg+WZXEe9/vpXLT+zOnecPPPwhISLhKfzlCAdLyrj40Q8pKXOs+fUYUpKPPDh8YcEGlhfs5rYxA8hun0FSkjHv9rOOCPTTj+3Mx2sLSTLHcSH984/H4V4/m3YX8bNXllH54KHcQVFJGS8u2MiArLZcmtc95rpEmjN1+8gR1m3bT0mZo2fHjCrBD/CXa4cx46bTyG6fcXhYUpIdsaftHJSUO9q1bMGv/n0QANv2FsflSp1nP1pPUjV79UUlZfxx1mqci75rSSRIFP5yhIHd2jL1upN45UcnHx720Pur6f/LGSzbuItOrVswsFv1J12fn7cegK17i/liyz7WF+5n2K9n8uOpi2Ju34wVmyit4ZzB9r3FfLP7YMx1iTRn6vaRKk4Jua5/+75ifv/ulwA1hm6FO84bwPyvdjCiTybD+3RkT1EpA7PaMiirLTOWb2LUoK4kJx25975z/yHmrSuktNyR27093Tu2DFt2bY4ekpNM3wcQqYHCX6rVJj2Fkf06kderAyf07FCrec4e2JWzB357fX+7lqnMuPk0fv7XZfzp/TU8eXUe5wzsAnhhfufrK5i+pIDU5CQcjtIyR16vDvxp/L+R2brFEWUPzm7H5t0Hqe5jyAFZ7dKjXVSRQEl4+JvZaOCPQDLwZ+fcPYmuU+KnRUoyz/7wpDrPX17uWLttHyVljsvyutMiNYkTe397FdGPpy7iw9XbKS4tpzhkb33Buh1c/OhHvH3zSDJCvi/wH6f1Ye7q7RSVlIWtLzXZuOSEHNJT4/OjNCLNVULD38ySgYeBc4B84BMze8M5tzKR9Up0Nu8+SEZaMu0yUms9z6uLNjL7y2387pLjqwRtSWk5N7ywmPdWbaHced8ByEhLxjm4bFgOLfybxH2av4uP1hRyMEwXTUm5Y+veYl5fWsD4E3scHj6sVwcuHprN3xYXVPkASE02urXP4GfnHhvF0osEU6JP+J4IrHHOrXPOHQJeAsYluE6Jwr7iUkb8dhYXP/JhraY/6Afui/M38vdlm9gccmL147WF5N39Hqfd9z7vrNxy+HJMBxw4VEZRSRkvLdjI5U/Oo6SsnL8uzKe4NPwePHjfCH7OP3lcwcy4+8LB/PK8AXRtm05GajKtWiSTkZrM94Z1540bTo3qQ0wkqBLd7ZMNbAx5nQ8c0YdgZhOBiQA9evRA6ldGajJn9j+KY7rUfL/+6UsK+OnLS3nsyqE8cfUJfLPrIL06tTo8fv2O/Wzfd6jaMopLy/li815mLN/Etn3FVa7Xr2xXmJ+VNDO+P7wnV5zUg407ijhUVkZOh5bq6hGJQoOf8HXOPQE8AZCXl6eLs+tZcpLx1IRhtZq2bUYK7TJSaZueSmbrFodPxm7YsZ8bXljCZ9/sOXxfn+ocOFTGn//1FWf078z7q5I4VBb5ypxencJf9QPeh0CPzMjjRSSyRId/ARD6Vcscf5g0QWf278Kyu849Ytj8dYWMf2JetVffhLN5z0EuP7EHj89eF3GalmnJXHdqnzq0VERqkug+/0+AfmbW28zSgPHAGwmuUxLsLx9+xZ3Tl1NeXs61T38SdfADdG6dRla7DG455xgyUqu+DTNSkzn92M6cfmzn2BssIlUkdM/fOVdqZjcA7+Bd6jnFOfdZIuuUxHtq7lfk7yzi5L6dOHAo8gnbSDJSk5lwSm8Arv9OX3pmtuIP737B14X7MTPaZaTyo+/05dqTe+kGbSIJkvA+f+fcDGBGouuR+vPSxOHsLiphzhfbop43LdnomdmSfz++2+Fhowd3ZfTgruw+UEJJeTkdW6aRlKTQF0mkBj/hK01PToeW5HSAgp1FtZ6nTXoKh0rLGT24K7++aEjYK3PatdQlmiL1ReEvdXZm/6NqvLonyWBE30xuOrMfx3ZtQ/uWafXYQhGJRHf1lDpLSU7iJ2f0pboemrSUJG4fM4CT+mQq+EUaEYW/xOTms45h1KCupFe6YifZjPTUJCZfMIjB2frBdZHGRt0+EpPkJOOR7w9l5qqtPD57LV9s3ktyknFG/6OYOLIPA7L0g+sijZHCX2JmZpwzsMvh2zSLSOOnbh8RkQBS+IuIBJDCX0QkgBT+IiIBpPAXEQkghb+ISAAp/EVEAkjhLyISQAp/EZEAUviLiASQwl9EJIAU/iIiAaTwFxEJIIW/iEgAKfxFRAJI4S8iEkAKfxGRAFL4i4gEkMJfRCSAFP4iIgGk8BcRCaCEhb+ZTTazAjNb6v+NTVRdIiISnZQEl/+Ac+73Ca5DRESipG4fEZEASnT432Bmn5rZFDPrkOC6RESklmIKfzObaWYrwvyNAx4F+gK5wCbgDxHKmGhmC81s4bZt22JpjoiI1JI55xJfiVkv4E3n3ODqpsvLy3MLFy5MeHtERJoTM1vknMuLZp5EXu2TFfLyImBFouoSEZHoJPJqn/vMLBdwwNfA9QmsS0REopCw8HfOXZWoskVEJDa61FNEJIAU/iIiAaTwFxEJIIW/iEgAKfxFRAJI4S8iEkAKfxGRAFL4i4gEkMJfRCSAFP4iIgGk8BcRCSCFv4hIACn8RUQCSOEvIhJACn8RkQBS+IuIBJDCX0QkgBT+IiIBpPAXEQkghb+ISAAp/EVEAkjhLyISQAp/EZEAUviLiASQwl9EJIAU/iIiAaTwFxEJIIW/iEgAxRT+ZnapmX1mZuVmlldp3O1mtsbMvjCzUbE1U0RE4iklxvlXABcDj4cONLOBwHhgENANmGlmxzjnymKsT0RE4iCmPX/n3Crn3BdhRo0DXnLOFTvnvgLWACfGUpeIiMRPrHv+kWQD80Je5/vDqjCzicBE/2Wxma1IUJsag07A9oZuRAJp+Zqu5rxs0PyX79hoZ6gx/M1sJtA1zKg7nHOvR1thZc65J4An/LoWOufyapilydLyNW3Nefma87JBMJYv2nlqDH/n3Nl1aEsB0D3kdY4/TEREGoFEXer5BjDezFqYWW+gH7AgQXWJiEiUYr3U8yIzywdGAG+Z2TsAzrnPgFeAlcDbwKRaXunzRCztaQK0fE1bc16+5rxsoOWrwpxziWiIiIg0YvqGr4hIACn8RUQCqFGEf5BuE2Fmk82swMyW+n9jG7pNsTKz0f76WWNmtzV0e+LNzL42s+X++or6krrGxsymmNnW0O/UmFlHM3vPzFb7jx0aso2xiLB8zWK7M7PuZvZPM1vpZ+bN/vCo11+jCH++vU3EnNCBlW4TMRp4xMyS6795cfeAcy7X/5vR0I2Jhb8+HgbGAAOBy/311tyc4a+v5nCt+NN421Oo24BZzrl+wCz/dVP1NFWXD5rHdlcK/Mw5NxAYDkzyt7eo11+jCH/dJqJJOxFY45xb55w7BLyEt96kkXLOzQF2VBo8DnjGf/4McGF9timeIixfs+Cc2+ScW+w/3wuswrt7QtTrr1GEfzWygY0hryPeJqKJucHMPvUPT5vs4bWvua6jUA5418wW+bcjaY66OOc2+c83A10asjEJ0py2O8ysF/BvwHzqsP7qLfzNbKaZrQjz1+z2EmtY1keBvkAusAn4Q0O2VWrlVOfcULyurUlmNrKhG5RIzrv+u7ldA96stjszaw28BvzUObcndFxt11+ibuxWRZBuE1HbZTWzJ4E3E9ycRGuS6ygazrkC/3GrmU3D6+qaU/1cTc4WM8tyzm0ysyxga0M3KJ6cc1sqnjf17c7MUvGCf6pz7m/+4KjXX2Pv9ml2t4nwV0yFi/BOdjdlnwD9zKy3maXhnaB/o4HbFDdm1srM2lQ8B86l6a+zcN4ArvGfXwPEfNPGxqS5bHdmZsBTwCrn3P0ho6Jef43iG75mdhHwf0BnYBew1Dk3yh93B/ADvLPcP3XO/aOh2hkPZvYc3qGnA74Grg/pq2uS/MvmHgSSgSnOuV83bIvix8z6ANP8lynAC019+czsReB0vNscbwHuAqbj3ZKlB7AeuMw51yRPmkZYvtNpBtudmZ0K/AtYDpT7g3+B1+8f1fprFOEvIiL1q7F3+4iISAIo/EVEAkjhLyISQAp/EZEAUviLiASQwl9EJIAU/iIiAfT/AaWo3lvmJ8hzAAAAAElFTkSuQmCC\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "sct.scatter(X_train, y_train, scatter_size=dv*5000+1)\n",
    "sct.show(scatter=False, title=\"TMC on train data with db change as metric\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "b0eca893-8d07-470e-85c6-f5b68500f31d",
   "metadata": {},
   "source": [
    "# 2. Data Shapley on Mesh Data AND Training Data"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "3bad2bfc-0155-463e-bf1a-2947aab19d64",
   "metadata": {},
   "source": [
    "## 2.1 Using the decision boundary change as metric"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "a1b546e6-2b7c-4d7e-9b0e-86ef81ed23ff",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "LOO values calculated!\n",
      "Running iteration  1 error 1.0\n",
      "Running iteration  2 error 5.47636725720267\n",
      "Running iteration  3 error 1.2951929318042337\n",
      "Running iteration  4 error 0.7273185138697292\n",
      "Running iteration  5 error 0.5314844590943094\n",
      "Running iteration  6 error 0.45645740921283184\n",
      "Running iteration  7 error 2.1525452373361835\n",
      "Running iteration  8 error 0.204554677937991\n",
      "Running iteration  9 error 2.5728706338447074\n",
      "Running iteration  10 error 0.1760653067246015\n",
      "Running iteration  11 error 0.3216752221449805\n",
      "Running iteration  12 error 0.16442262781057426\n",
      "Running iteration  13 error 0.10972367930904384\n"
     ]
    }
   ],
   "source": [
    "dshap = DShap(X_mesh, y_mesh, X_test, y_test, num_test,\n",
    "              X_base=X_train, y_base=y_train,\n",
    "              sources=None, \n",
    "              sample_weight=None,\n",
    "              model_family=model, \n",
    "              metric=metric,\n",
    "              overwrite=True,\n",
    "              directory=directory, \n",
    "              seed=0,\n",
    "              hidden_layer_sizes=1000, \n",
    "              activation='relu', \n",
    "              max_iter=1000\n",
    "             )\n",
    "\n",
    "dshap.run(100, 0.15, g_run=False, loo_run=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "e49135a2-d4e6-4d6f-ba10-d03a61ab1f21",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "dv = dshap.vals_tmc\n",
    "\n",
    "# invert the value\n",
    "dv = max(dv) - dv\n",
    "\n",
    "dv = np.asarray(dv).reshape(xx.shape)\n",
    "im = plt.contourf(xx, yy, dv, cmap=\"RdBu\", alpha=.5)\n",
    "\n",
    "sct.scatter(X_train, y_train)\n",
    "plt.colorbar(im)\n",
    "sct.add_boundary(syn.get_labels)\n",
    "sct.add_boundary(baseline_model.predict)\n",
    "sct.show(scatter=False, title=\"Shapely on mesh and train data with db difference\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "d872c002-fe61-4260-892b-155463b39ecc",
   "metadata": {},
   "source": [
    "# 3. Data Shapley on Mesh Data only"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "855a4437-c937-438a-98ba-53f7f5dceb50",
   "metadata": {},
   "source": [
    "## 3.1 Using the decision boundary change as metric"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "12610f57-b3be-4351-a084-f42302d25575",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n",
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\sklearn\\neural_network\\_multilayer_perceptron.py:617: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (1000) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "LOO values calculated!\n",
      "Running iteration  1 error 1.0\n",
      "Running iteration  2 error 3.0834936535064443\n",
      "Running iteration  3 error 1.903360931350476\n",
      "Running iteration  4 error 0.3101831928386331\n",
      "Running iteration  5 error 0.21945402458935684\n",
      "Running iteration  6 error 0.20358784106479078\n",
      "Running iteration  7 error 0.1329547787195992\n"
     ]
    }
   ],
   "source": [
    "dshap = DShap(X_mesh, y_mesh, X_test, y_test, num_test,\n",
    "              sources=None, \n",
    "              sample_weight=None,\n",
    "              model_family=model, \n",
    "              metric=metric,\n",
    "              overwrite=True,\n",
    "              directory=directory, \n",
    "              seed=0,\n",
    "              hidden_layer_sizes=1000, \n",
    "              activation='relu', \n",
    "              max_iter=1000\n",
    "             )\n",
    "\n",
    "dshap.run(100, 0.15, g_run=False, loo_run=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "7c38f3db-a811-4044-a5f1-c4558bb1db46",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "No handles with labels found to put in legend.\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "dv = dshap.vals_tmc\n",
    "\n",
    "# invert the value\n",
    "dv = max(dv) - dv\n",
    "\n",
    "dv = np.asarray(dv).reshape(xx.shape)\n",
    "im = plt.contourf(xx, yy, dv, cmap=\"RdBu\", alpha=.5)\n",
    "\n",
    "plt.colorbar(im)\n",
    "sct.add_boundary(syn.get_labels)\n",
    "sct.show(scatter=False, title=\"Shapely on mesh data only with db difference\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "21063023-1a3c-4172-8ce7-1140f042c12d",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "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.7.10"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
