{
 "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": "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\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": "iVBORw0KGgoAAAANSUhEUgAAAX8AAAD8CAYAAACfF6SlAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjQuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/Z1A+gAAAACXBIWXMAAAsTAAALEwEAmpwYAAA3pklEQVR4nO3dd3hUVfrA8e+Zkl5IqCEhEAi9hQ5SpIigrBQLYkVFUdTVn7qWVdeCuuq6uqKoiMJaVrGhgIp0kCI9gtJDCyShhoT0ZMr5/XFDSEghZSaFeT/Pk4e57ZxzM+SdO+ee+x6ltUYIIYRnMdV0A4QQQlQ/Cf5CCOGBJPgLIYQHkuAvhBAeSIK/EEJ4IAn+Qgjhgaoc/JVSzZRSK5VSu5RSO5VSD+evD1VKLVVKxeX/G1L15gohhHAFVdVx/kqpMCBMax2rlAoEtgJjgTuAM1rr15RSTwEhWusnq9heIYQQLlDlK3+t9TGtdWz+63RgNxAOjAE+zd/tU4wPBCGEELVAla/8ixSmVAtgNdAJOKK1rpe/XgEp55YvOGYyMBnA39+/R7t27VzWHiGE8ARbt249rbVuWJFjXBb8lVIBwK/AK1rr75VSqYWDvVIqRWtdZr9/z5499ZYtW1zSHiGE8BRKqa1a654VOcYlo32UUlZgLvCF1vr7/NUn8u8HnLsvcNIVdQkhhKg6V4z2UcAsYLfW+q1CmxYAE/NfTwTmV7UuIYQQrmFxQRn9gduAP5VS2/LXPQ28BnyjlJoExAPjXVCXEEIIF6hy8NdarwVUKZuHVbV8IUTtZLPZSEhIICcnp6ab4jF8fHyIiIjAarVWuSxXXPkLITxQQkICgYGBtGjRAqP3V7iT1prk5GQSEhKIioqqcnmS3kEIUSk5OTnUr19fAn81UUpRv359l33TkuAvhKg0CfzVy5W/bwn+QgjhgST4CyHqpNTUVN5///1KHXv11VeTmppa7v1zc3O58cYbiY6Opk+fPhw+fLjE/RYtWkTbtm2Jjo7mtddeK3Gff/zjH3Tp0oWYmBiuvPJKkpKSCratWrWKmJgYOnbsyOWXX16RU6o4rXWt+enRo4cWQtQNu3btqtH6Dx06pDt27FjiNpvN5tK63nvvPX3vvfdqrbWeM2eOHj9+fLF97Ha7btmypT5w4IDOzc3VXbp00Tt37iy239mzZwteT5s2raDclJQU3b59ex0fH6+11vrEiRMltqWk3zuwRVcw3sqVvxCiTnrqqac4cOAAMTExPP7446xatYqBAwcyevRoOnToAMDYsWPp0aMHHTt2ZObMmQXHtmjRgtOnT3P48GHat2/PPffcQ8eOHbnyyivJzs4uVtf8+fOZONF4ZvX6669n+fLl6AtS42zatIno6GhatmyJl5cXEyZMYP784s+2BgUFFbzOzMws6Mf/8ssvufbaa4mMjASgUaNGVfwNlU2CvxCi2izddYLn5u9g6a4TVS7rtddeo1WrVmzbto033ngDgNjYWKZNm8a+ffsAmD17Nlu3bmXLli288847JCcnFysnLi6OBx54gJ07d1KvXj3mzp1bbJ/ExESaNWsGgMViITg4uFhZhfcBiIiIIDExscS2P/PMMzRr1owvvviCqVOnArBv3z5SUlIYPHgwPXr04LPPPqvEb6X8JPgLIarF0l0neGjO73y2Pp6H5vzukg+AC/Xu3bvIGPh33nmHrl270rdvX44ePUpcXFyxY6KiooiJiQGgR48epfbnu9Irr7zC0aNHueWWW5g+fToAdrudrVu38vPPP7N48WJeeumlgg8xd5DgL4SoFmviTpFtcwCQbXOwJu6Uy+vw9/cveL1q1SqWLVvG+vXr2b59O926dStxjLy3t3fBa7PZjN1uL7ZPeHg4R48eBYwgffbsWerXr1/qPmA8BBceHl5me2+55ZaCbxoRERGMGDECf39/GjRowKBBg9i+fXs5zrpyJPgLIarFwNYN8bWaAfC1mhnYukLp54sJDAwkPT291O1nz54lJCQEPz8/9uzZw4YNGypd1+jRo/n0U2Nuqu+++46hQ4cWG3Pfq1cv4uLiOHToEHl5eXz11VeMHj26WFmFv33Mnz+fc3OYjBkzhrVr12K328nKymLjxo20b9++0m2+GEnvIISoFsM7NOadm7qxJu4UA1s3ZHiHxlUqr379+vTv359OnTpx1VVXMWrUqCLbR44cyYwZM2jfvj1t27alb9++la5r0qRJ3HbbbURHRxMaGspXX30FQFJSEnfffTcLFy7EYrEwffp0RowYgcPh4K677qJjx47FynrqqafYu3cvJpOJ5s2bM2PGDADat2/PyJEj6dKlCyaTibvvvptOnTpVus0X49KZvKpKJnMRou7YvXu3W69MRclK+r3X2GQuQggh6hYJ/kII4YEk+AshhAeS4C+EEB5Igr8QQnggCf5CCOGBJPgLIeqk6kzpvHr1arp3747FYuG7774rdb+tW7fSuXNnoqOjeeihh4olfwOYMWMGnTt3JiYmhgEDBrBr1y4AkpOTGTJkCAEBATz44IMVPqeKkuAvhKiTygr+JaVoKGzhwoXUq1ev3HVFRkbyySefcPPNN5e535QpU/joo4+Ii4sjLi6ORYsWFdvn5ptv5s8//2Tbtm088cQTPProo4AxOftLL73Ev//973K3qyok+Ash6qTqTOncokWLgidvS3Ps2DHS0tLo27cvSiluv/125s2bV2y/0lI6+/v7M2DAAHx8fCr7K6kQSe8ghKg+exbCgRXQaii0u7pKRb322mvs2LGDbdu2AUYit9jYWHbs2FGQ2XP27NmEhoaSnZ1Nr169uO6664olZIuLi2POnDl89NFHjB8/nrlz53LrrbdWuD2JiYlEREQULJeV0vm9997jrbfeIi8vjxUrVlS4LleQK38hRPXYsxDm3gWbPzL+3bPQ5VXUlZTODzzwAAcOHOD111/n5Zdfdnt9JZHgL4SoHgdWgC2/S8WWbSy7mLtSOpdHeHg4CQkJBcvlSek8YcKEEruGqoMEfyFE9Wg1FKy+xmurr7FcBdWZ0rk8wsLCCAoKYsOGDWit+eyzzxgzZkyx/Qp/+/j5559p3bq1W9tVGunzF0JUj3ZXw3WzXdbnX50pnTdv3sy4ceNISUnhxx9/5Pnnn2fnzp0AxMTEFNx3eP/997njjjvIzs7mqquu4qqrripW1vTp01m2bBlWq5WQkJCCeQLAuLGclpZGXl4e8+bNY8mSJQU3r13NJSmdlVKzgb8AJ7XWnfLXvQDcA5ybrudprXWZnXyS0lmIukNSOteM2pbS+RNgZAnr/6O1jsn/cf3dHSGEEJXikuCvtV4NnHFFWUIIIdzP3Td8H1RK/aGUmq2UCnFzXUIIIcrJncH/A6AVEAMcA94saSel1GSl1Bal1JZTp06VtIsQQggXc1vw11qf0Fo7tNZO4COgdyn7zdRa99Ra92zYsKG7miOEEKIQtwV/pVRYocVxwA531SWEEKJiXBL8lVJzgPVAW6VUglJqEvAvpdSfSqk/gCHAI66oSwghoGopnQHefvttsrKyStx26NAh+vTpQ3R0NDfeeCN5eXkl7vfqq68SHR1N27ZtWbx4cYn7PPPMMzRr1oyAgIASt8+dOxelFNU9zN1Vo31u0lqHaa2tWusIrfUsrfVtWuvOWusuWuvRWutjrqhLCCHAvcH/ySef5JFHHmH//v2EhIQwa9asYvvs2rWLr776ip07d7Jo0SLuv/9+HA5Hsf2uueYaNm3aVGI96enpTJs2jT59+lT6PCpL0jsIIeqkC1M6A7zxxhv06tWLLl268PzzzwNG2uRRo0bRtWtXOnXqxNdff80777xDUlISQ4YMYciQIUXK1VqzYsUKrr/+egAmTpxYYv6d+fPnM2HCBLy9vYmKiiI6OrrEIN+3b1/CwsKKrQf4xz/+wZNPPlltaZwLk/QOQohqs/LIStYnradf034MiRxy8QPKcGFK5yVLlhAXF8emTZvQWjN69GhWr17NqVOnaNq0KT///DNg5PwJDg7mrbfeYuXKlTRo0KBIucnJydSrVw+LxQiPpaVmTkxMLJIyoqwUziWJjY3l6NGjjBo1ijfeeKOip19lcuUvhKgWK4+s5InVTzBn7xyeWP0EK4+sdGn5S5YsYcmSJXTr1o3u3buzZ88e4uLi6Ny5M0uXLuXJJ59kzZo1BAcHu7TeynA6nTz66KO8+WaJI+CrhQR/IUS1WJ+0nhyHkVI5x5HD+qT1Li1fa83f//53tm3bxrZt29i/fz+TJk2iTZs2xMbG0rlzZ5599lmmTp1aZjn169cnNTW1ILVzaamZw8PDOXr0aMFyeVI4n5Oens6OHTsYPHgwLVq0YMOGDYwePbpab/pK8BdCVIt+TfvhYzb6tn3MPvRr2q9K5V2Y0nnEiBHMnj2bjIwMwOiWOXnyJElJSfj5+XHrrbfy+OOPExsbW+Lx5yilGDJkSMFE7Z9++mmJqZlHjx7NV199RW5uLocOHSIuLo7evUt8nKmY4ODggmkkDx8+TN++fVmwYAE9e1YoN1uVSJ+/EKJaDIkcwr8G/ctlff4XpnR+44032L17N/36GR8qAQEB/O9//2P//v08/vjjmEwmrFYrH3zwAQCTJ09m5MiRNG3alJUri3ZBvf7660yYMIFnn32Wbt26MWnSJAAWLFjAli1bmDp1Kh07dmT8+PF06NABi8XCe++9h9lsLtbOJ554gi+//JKsrCwiIiK4++67eeGFF6p07q7gkpTOriIpnYWoOySlc82obSmdhRBC1CES/IUQwgNJ8BdCCA8kwV8IITyQBH8hhPBAEvyFEMIDSfAXQtRJ7szqOX36dKKjo1FKcfr06VLL+PTTT2ndujWtW7fm008/rVBZKSkpjBs3ji5dutC7d2927KjeKU8k+Ash6iR3Bv/+/fuzbNkymjdvXurxZ86c4cUXX2Tjxo1s2rSJF198kZSUlHKX9c9//pOYmBj++OMPPvvsMx5++OFKn0tlSPAXQtRJ7krpDNCtWzdatGhRZv2LFy9m+PDhhIaGEhISwvDhw1m0aFG5y9q1axdDhw4FoF27dhw+fJgTJ05U8LdQeZLeQQhRbdJXrCBz3Tr8+/cnMD/wVZa7UjqXV2JiIs2aNStYrmhK565du/L9998zcOBANm3aRHx8PAkJCTRu3LhS7akoufIXQlSL9BUrSHz0MVK++JLERx8jfcUKl5Zfl1I6g/HNJTU1lZiYGN599126detWYm4gd5ErfyFEtchctw6dY6R01jk5ZK5bV+Wr/8LOpXS+9957i22LjY1l4cKFPPvsswwbNoznnnuuyvWFh4ezatWqguWEhAQGDx5c7uODgoL473//Cxhtj4qKomXLllVuV3nJlb8Qolr49++Pyp+uUPn44N+/f5XKc1dK5/IaMWIES5YsISUlhZSUFJYsWcKIESPKfXxqamrBxPAff/wxgwYNIigoqNLtqTCtda356dGjhxZC1A27du2q8DFpy5frY1On6rTly13Shptuukl37NhR/+1vf9Naa/3222/rTp066U6dOum+ffvq/fv360WLFunOnTvrrl276p49e+rNmzdrrbV+5513dJs2bfTgwYOLlTtt2jQdHh6uzWazDgsL05MmTdJaa7158+aC11prPWvWLN2qVSvdqlUrPXv27BLbWFpZv/32m27durVu06aNHjdunD5z5ky5zrmk3zuwRVcw3kpKZyFEpUhK55ohKZ2FEEJUmgR/IYTwQBL8hRCVVpu6jT2BK3/fEvyFEJXi4+NDcnKyfABUE601ycnJ+OSPmKoqGecvhKiUiIgIEhISOHXqVE03xWP4+PgQERHhkrIk+AshKsVqtRIVFVXTzRCV5JJuH6XUbKXUSaXUjkLrQpVSS5VScfn/hriiLiGEEFXnqj7/T4CRF6x7CliutW4NLM9fFkIIUQu4JPhrrVcDZy5YPQY4N7vBp8BYV9QlREXYHE4SUrLIsztruilC1Cru7PNvrLU+lv/6OFBinlKl1GRgMkBkZKQbmyM8zemMXMZMX8eZzFwCvK3Me7A/4fV8a7pZQtQK1TLUMz/3RInjwbTWM7XWPbXWPRs2bFgdzREe4osN8ZxIyyHb5iQ5M5cPfz1Q000SotZwZ/A/oZQKA8j/96Qb6xKiGB+rGZNJAWA2KXyt1ZcrXYjazp3BfwEwMf/1RGC+G+sSopjb+jWna0QwJgVtGwdy/+DoIts/XH2Ari8uYfhbv3LwVEYNtVKImuGSrJ5KqTnAYKABcAJ4HpgHfANEAvHAeK31hTeFi5CsnsIdtNYopYqs230sjXHvryPH5kQBnSOCWfDggJppoBBVVJmsni654au1vqmUTcNcUb4QVXFh4AdIzbJhzl+vgTOZedXcKiFqluT2ER6pZ4sQ2jQJxM/LjI/FxBMj2l70mN+PpPDeyv2sP5BcDS0Uwr0kvYPwSFaziW/v7cfuY+nUD/Ci6UWGgG45fIZbZ23EZnfiZTEx/ebuDGtf4uhlIeoEufIXHstiNtE5IviigR9gxZ6T5NicODRk25ws/PPYRY8RojaT4C9EOcQ0q1cwVNTXaqZXi9AabpEQVSPdPkKUw5Udm/DK2E4s3nWc/q0acGOvZgAsOrSIGdtn0MS/CS/1f4mGfvKgoqgbZAJ3ISopPi2e6xdcT44jB7My061RN/478r813SzhgWQCdyGq0fHM45hNRleQQzs4mn60hlskRPlJt48QldSlYRfq+9RHa41TO5nYYeLFDxKilpDgL2q9jFw7C7Yl4WM1MbprUyzm2vGF1dfiy7fXfMuGYxto6NuQzg0713SThCg3Cf6iVrM7nIx9bx0JKVkopVi88zgf3lahrs0S2Rw2dp/ZTSO/RjTxb1LpcvysfgyNHFrl9ghR3ST4i1otMTWbxJRscmzGZCzLdlc9OWyOPYcJP0/gWMYxnNrJvwb9iyGRQ6pcrhB1Se34/ixEKRoF+mA1n0vLDC0b+Fe5zPVJ6zmWcYwsexY5jhze+f0dAA6ePcgPcT+wP2V/lesQoraTK39Rq/l6mfnmvn68uXgfft5mnr66fZXLDPEJQefPLWTCRAPfBuw4vYM7F9+JQqG1ZuaVM+nWqFuV6xKitpLgL2q9dk2C+Ghi1fv5z4lpFMOdHe/kyz1f0jSgKVMvm8oXe74gx55TsM+PB36U4C8uaRL8hUeaEjOFKTFTCpaj60XjY/Ehx56Dj9mHNiFtarB1QrifBH8hgDGtxnAi8wS/JvzKZU0vY3zb8TXdJCHcStI7CCFEHSfpHYRHczg1by7Zy9j31vHeyv1U5sLm2Nlsfvg9gV1JaW5ooRC1h3T7iFpLa80H2z/g233fEhUUxb8H/5tQn9JTKX++/jAfrzlEts3B3uNphAX7cG33iHLX98exo9z8w6NgPYPzzBDeHX1PlSZsyc5z8NMfSXhZTFzdOQxrLXkyWQiQK39Rizidmh2JZzmSnAXAxuMb+WTnJ5zOPk3syVhe3vBymcfvOZ5Ots0BGBOu7DuRTlqOjfEzfqPts78w6ZPN5NodpR7/9zVPg98+lNdJTI2+58P1v1XpXG6Y8RvPzd/JU3P/5N7Pt1a6LCHcQa78Ra3gdGpun72J2CMpOJ2ap0e1J7TxaRTGA14O7eB45vEyy7i2ewTztiUWHPOXLk2Zvnw/vx9NxebQrN1/mjkbj3BH/6gSj89ynkAp40litIlGIdmVPp+T6bnEncwg126Ut3LvSZxOjclUfDJ5IWqCXPmLWmH38TRij6SQlecgx+7kraX76Nt4AMHewfhb/fEx+3Bf1/vKLKN3VCjzHxjAi6M78tNDA+gUHszZHBt2h9H373Bq0nPtpR5/X8wkLMob5fTG3xLE1BHXVPp8Qvyt+FjNKMCkIKKerwR+UavIaB9RKySkZDHszV8LrpRNCpwarBYbU28I5vJWbWka0LTC5R48lcG493/D7nDi721h/gP9CStjzt5dybs4nnmcPmF98LdWPJVEQkoWXmYTjYJ82Hs8ndcX7cHLYuKZq9vTLNSvQmVtOnSGB7+MJdfu5PlrOlTo/oXwLJUZ7SPBX9QaczbG88aSfeTZHWTknu+bbxLkw4anh1W63MxcO0//8Cc/bk/Cy2zi0SvbMLJjGJH1jWCckpnHY99uJ+5EOgPbNOTKDo0Z2Loh5gpeqT8/fwdfbT6K1vC3EW2YPKhVpdsM0G3qElKybAB4WUxsenoY9fy8qlSmuDTJUE9Rp93Upzmx/xjO8AtG2OTaSr9JWx7bjqby4/YknBpy7E5eXbiHK9/+lV/+PAbAs/N2sGbfKY6mZPPlxiPc97+tTPp0c8FQ0aTUbKb8byu3z9rInwlnS6zjdEYuczYdJdfuJM/h5F+L9uJ0Vu3CKjPv/HkrICuvar8HIQqT4C+qxemMXFbsOUFi6sVvoj51dXu8LOf/az43ukOxfZIykhj/43gGzBnAjO0zyizvH/N2UDgOayDH5mTa8jgAjpzJxFZohxybk3X7Txdcdd8+exOLdx5nddxpbvpoA1l5xe8beFlMUOiLgrfFhKpiF/9jw9vgbXXg43eKEZ1CaFpGd5UQFSWjfYTbxSdn8pd316I1OLTmi7v70D0ypNT9Gwf5sOP5K4k9mkrLhv40DPDmtV/28MXGeCJD/fjo9p48u/FZ9pzZg0Yze8ds+jXtR9eGXUss72RaTrF1ZhOEBRvBdMrgVjzy9TZy7ec/ALwtZgK8jT+Pw6czCz48HE7NybRcWjQo+qcT5GPln+M68/z8HVgtJqZN6IaqYvS/tlcQXx77D1n2LGK1lSNpXxIZFFmlMoU4x+3BXyl1GEgHHIC9ov1Sou5bsC2JrFw7+YNuuOuTzcy7vz8tysjN72U107dlfQDWH0jms/WHycpzsPtYGk/N/YO0+mcK0jIrFKk5qaWWdUvf5ny+IR60xtfLjNlkokUDf16/zph28erOTWnTOIh1+08zNzYBreHFMR0Lvn1c1bkJy3efRGuIDPUr9cbt9T0iuL6H627Kfhf3HWfzUnBoB7kOxSc7P+G5fs+5rHzh2arryn+I1vp0NdUlasiSw0v46eBPdG3YlTs63oHZZAYgrJ4vVrMJR/5IntQsG1O+2MovDw8qV7lns/MKelScGpIz83hs+EM8ufpJTMpERGAEfcL6lHr8U1e14/I2DUnNtjGkbSN8vczF9oluFEB0owBu7dscm8OJj/X8Pq9d24Wlu05gczgZ1SWswjeCKyvQGojFZMHhcGAxWQj0CqyWeoVnkG4f4RJbjm/hmbXPkOPIYX3SehzaweQukwG4tls4v+47yU/bj3GuY+VEWm65y768TSPCQ3xJTMnGqeGJke24PLIhP477kVNZp2gX2g6r2Vrq8UopLotucNF6NhxM5q5PNpNjc3BLn0imjunE5+vjeennXQA8O6oDfl7V9ydzQ9sbWJe0jk3HN9Gpfifu6XxPtdUtLn3V8T9ZA0uUUhr4UGs9s/BGpdRkYDJAZKT0Z9ZVu5J34dDGaJQcRw6xJ2ILtplMirfGxxB/OosDpzJwaM39g8s/DNLXy8xPfx3I3uPpNA72plGgDwBN/JtUafL1Cz3x3R8FI2q+25rItd0jmPrTLuz5Hf4v/7yLG3s1K/KtwJ28zd58cMUH1VKX8DzVEfwHaK0TlVKNgKVKqT1a69XnNuZ/GMwEY5x/NbRHuEG/pv2Yvm06Tu3EarJyVdRVRbZbzSa+m3IZW+LPEOrvRbsmQcaGQ6vhz++gaTfoPhFMJQ9A87KY6BwR7NZzcF7wzItT6yqP2BGitnJ78NdaJ+b/e1Ip9QPQG1hd9lGirmkd0prPr/qctYlraRfajv7h/Yvt42UxcVmrQt0vSb/Dl+PBlg1/fgvZqTDwkTLr+Wl7Es/M24HFpHh7QgwDWzd02Tm8dm0X7vlsCzaHk790CaN7ZAgvXNORF37cCcBzf+lYbVf9QribW5/wVUr5AyatdXr+66XAVK31opL2lyd8a5mVr8Jv70JAQ7jpa2jUDm23c/LNt8jatInAq0ZSf9KkSg1p3Bp/hh0/vMlNZ2fipfOMlS0Gwh0/lXpMZq6d7i8tLUgB4edlZueLI6o8pLKwPLuTXLuDQB9rkXUajbdFAr+onSrzhK+7r/wbAz/k/3FagC9LC/yiljm2HX6bZlyVp2TC9/fAfWs4/fEsUubMQefkkHvwIF4RzQgaOaJCRSdn5HLbrE1E2iIY74XxcJTVD9peXeZxeXZnka6ZXLsTpwZzFWL/sl0nmLPpCB2aBvHQsNZ4WUxFHjADii0LcSlwa/DXWh8ESn7yRtRuuemgCl3p5hozW+Xu24fOMR6a0rm55B06WOGiE1OzUUqxR0dyc94zXOO9lbtGj4FO1xXZLzkjl/u/iOXAqQzG92zG4yPaclOvSL7ZchQNPDAkukrDLv9ISOWvc34n2+Zg3YHT5NgcPDOq+NPEQlyKZKinKFmzvhAWA0mxoJ1wpTGRSsgN15OxYoVxY1ZrAq+4osJFt2kcSIifFYfTyV7Vjg5dh0HnzsX2e37BTrbGp2B3aj757TB9WtZn6thOTBoYhdmkiAipWJbMCxWeqjHH5mRrfAoATn0us6hc8YtLlwR/UTKzBSb+CMlx4Btq9PsD/v360eLrr8nZtQu/nj3wataswkX7WM38/NeBLNxxjBA/K1d2KHm45vGzOQXDLAFOpxvPBjSvX/5Uy6lZeXyxMR6LycStfZvj733+v/xlrRpgUmA1KSxmE2O7hfN93Pe8vOFlFIqpl01lVKtRFT4/IeoCSeksaq01caeY/NlWzCbwqb+OqBb76NWkB4/0fASrqfSHugA+XH2A91ceICvPjtYakzLRoWkQ8x4oOgrpwKkMVuw+SXSjAPpFB3HZnMuwOY2EblaTlU23bMJiOv+BkZKTQkJ6Aq3qtcLPWvY3jxybgzeX7GPviXQm9mtepfmAhShLbbzhK0SlDWzdkOWPXc6PcUuZtXcxe1KyOZx2kEDvQKZ0nVLqcXuOp/GfpfvIsTkLrXWy/WgqNoezyETqrRoG0KphAABZtqyCfEFgdP8UvjjambyTuxbdhVIKP4sfn4z4ih82p5KRa+fO/lHFsm6++ONOvo9NJNfuZPOhM3x//2W0Dwuq4m9FCNeQTk1RexxaA5+NhXkPQLbR/960ni8Wn1PkOY3hoDmOHPac2VNmMWezbJgvGP5pMSmiGwUUCfwX8rP6MaXrFKwmK1aTlcd6PlYkbcSsP2eRZc8i05bJ2dyz3PXth7y38gCz1h5i9PS15Fww78C2o6lFZibbdyK93L8KIdxNrvxF7XA2Eb68wRhaarZCehLc9gMAQyOHMvOPmWg0WmtuaHNDmUV1bx5Cu7Agdh9Lw+HU9GoRQpvGgTwwJPqizZjcZTI3tr0RpRRBXkWv0kN9QrGarNicNswmM0dPK/IcRnDPynOQlJpNy/xvEQDXdY/gzSX7cDidmEyKPlH1K/pbEcJtJPgL90k+AD/cB1nJMOw56Di29H3PHIRzfesOG5zYWbApKjiKuaPnsuXEFtqFtqNdaLsyq7WaTXxzbz92H0ujfoBXQd7+c85m2dgSf4b0HDvLdp8gqoE/DwyJLnh6N9i75DQSD3V/iENnD7H7zG6GRQ5jb8YQtqWfxeHU+HtZinX73D2wJa0aBXD4dCZXtG9Mk2CfMtstRHWS4O8pErdCxkmIuhy8qjZEsty+ugVO7QG08SHQrDcElTIJe9MYsPqDww7KBF0mFNkcERhBRGAEpB2DtKTSy8lnNik6hRcP4skZuYx4ezVZeY6CJG7eFhPHz+Zw62A4mXWSy5peVuLk7UFeQcwaMatgObOnnVdX/EJcxiau69i3xNQPQ9o2grZlNlWIGiHB3xP8Nh1WvmIE1cAwuG8tWKvhKjT9GJy7gWoyGR8+pQTtNKVZftWzhJ7cy6Am/VDtSnjad9VrsOYt43W/++GKFyrcpOV7TpKZ5yC70Hy4uXYnq09+x6rFizApE6E+ocwdPfeio3kOp+9lcfJUchw5HIxdhNmSw3VtrivzGCFqC7nh6wnWvwu2LMjLMAJyohuH08b/Bm9EwythENnXSNvgFQAN2kDjTiUekmPP4YYFN/Dqtnd5PGkJb6TvpFg6TXsurH4DHLnGz2/vQm5GhZsXUc8XLhjd7OtlhqA15DhyyLJnkZKbwvZT2y9a1qbjm7A7jfl8cxw5rDi6olxtOJOZx9ytCWw4mFzh9gvhKnLl7wnqNYeMU6Ad4HRctMukSr6ZCJmnjNcHV8KEOUYgbz7AeHCsBHvO7OFs3lmy7cbk7gsOLuCJ3k8U3UmZjXsCznOTp5tg1zzj20SnayGkRbmad1l0A/7vitZ8uekIkaF+dGtWj1aNAlhwohVbT6Ti0A4cTgdNAy7+O4ppFIPFZMHusONj8aFf034XPeZsto0Rb68mM9eO1vDYlW24e2DLcrVdCFeS4O8JbvgE5k0x+soH/x1C3RhsbFmFFhSERl20vvCAcBxOoxvGoiy0Ci4+0UuOU/FB8JNMOv0vLCawRA3Ca+Hj4MiDdW/Dg1sLnkK+mHsvb8W9lxeto3/267zw2wskZSRxb9d7aR7U/KLldGvUjf8M+Q+LDy2ma6OuXNf64l0+mw+dITvPXnC/4fMN8RL8RY2Q4O8JgprC7fNdXqx2OMDhQHl5nV955cvwy5PG1X6HMRASddFyGvo15P0r3ueD7R/Q0LchT/Z+stg+/9sQz4wT7Zlmn4XVrNic8Che5z5otNPIQdSmYtlFC2vg24Dpw6ZX+LgB4QMYED6g3Pu3aOBXkLLCala0bSzz8oqaIcFfVErGmjUk/PUhtM1G/XvuodH/PWxs6HkntBsFeZlGV0w5c+33atKLXk16lbo9M9eOIz9oOpyaw76diHGkgD3H6MpqWPbwz9oiulEgb9/YjRm/HqBFfT9eHFPyfRAh3E1y+4hK2dfvMhwpxlO4ytublj//hFdEhNvqO5mew+h315GWY8PbYmLBvT1o9ud7kHII+twHkX3cVrcQtZ3k9vE0x7bDtjlQP9q44ja5YKaprDPw3V3G+PzuE2HwU8bVe9oxSDkMYV3Ayx8uvGhwOkssrsIyThrz+jZoDWHnp4JoFOjDr08MJiElm/B6vviYNGSdhiPrjRvBTWPA4u2aNgjhAST411Uph2H2SOMGq9UXUg7CiH9WvdyFj8PhteC0wW/vGFfUZi/44gbjw8U7CO5bS5OXppL0t8fRDgf1brwRr8jIouXsWwzLXgT/BjBmOtSLLLm+wtKOwQf9jJu42gljZxR5KtjbYi5Iwsbmj+GPb8CeDbsXGN0+gx6r+vkL4SEk+NchztxcMj58CrVvPgHNrahzF9+2bNi/zDXB/+xRI/Cfk34ctn99fhSPww67FxA0/A4CNm1E22yYAwKKlpF2zBjyac8GTDDnZpiy9uJ1xy0BW07+ccDGGaWnhDibZPT3g/Hv2SMVOUshPJ485FVHaKeT+Ak3kDRzIYmrrCQtLxQkrb7QaphrKhr0uFGedyD41oM2IyEoDM7lz1cK/BsBYPL2Lh74ATKOG0/0AuA0PlDKI7Tl+RvEZm9o2L70fbvdYrTRO8h4iKzX3eWrQwgByJV/nWFLSiJ3/yG03QiqafG+hA81Q+frITQaek0qsr+22XBmZWEOLjlJWalaD4f7Nxo3UsN7GAF2xD/hbAKc2GWsy8s0nrgtrY+9cSdjpE9KvNF90/ue8tUdNZD0hneSuWwhfl1aEzTi5dL3rd8KHvodjv8BjTpCoEyUIkRFSPCvIzLWrEHbzj3dqrH45s+rG3NzsX2zfv+do3ffgzM3l4BBA4l4912UuQI3g0OaGz/n+IXCHT/B59dC/DqIXwubZ8JdS0oeymm2wt3L4cBK49jIvuU+x8T3f0Hn5JK6bz/0XEvQyDLG7vs3gFZDy39eQogC0u1TR2QsXXZ+QSmCb7y9xMAPcPyll3BmZoLdTuaGjWRu2HB+Y14m/DAF3u8HGz4ofwNsOUa6Blum0f9/dJORf9/pKHl/qy+0u7rcgR8gc/16dI7Rj69zcshYu6bsAxx22DEXtn9ltE8IUW4S/OsI3549UD5GJk7l40PAFVeVuq9SRd9WZSq0vPQ5I2Ce3AXLp8LBVeVrgMUb/C9In3B4XfmPLwf/fv3A+3xXkvLxLWNv4OtbYP5f4adH4ZOriw8/FUKUSoJ/HdHg3ntp8MD9BFwxjKav/wu/Hj1K3bfJ1BcxBQeDyUTgsKH49Sn0ANSpPUZWTDCC5ZmD5WuAUtBxXPF15XyCtzwCBg7Eq+n5hGpnv/uOvPj4knd22I3hpLZM4+f4DuMZASFEuUiffx2hzGYa3FO+G6e+HTvSZsN6tM2GqXDeHYA+U4yJXc5lyWwzsnwNyM2AzbOKrms1DKIGl3mYLSmJ9FWr8GrenID+/S9ajTPjfJpmZTZjP3kSr+YlJFkzWyA43EhWp51GN5NvSDlORAgBEvwvWUqpognXzmn/F5i0FE7vM9Isl3eUjDIVv8pPOWw8kGUqeWIY28mTHBw7Fp2bByYTjR75P0Jvv73Maurfczcn3/oPmM1Ymobh07Vr6TtP/AkWP220YfhUsJRwvkKIEknw90RNOhs/FeHlB6PeggV/pWA2lDMH4cAK48ZuCbI2bUbbHehco5spde73Fw3+obffjl+vXthPn8avd+/i31yK7BwFN82p2HkIIYBq6PNXSo1USu1VSu1XSj3l7vqEEWQTHn6YlG+/xaWJ+7rfBi0GGN8CwOhu8Sn9OQLv6FYFOX+Utzc+ncv3gePTvj0BAwdi8pZcPUK4i1uv/JVSZuA9YDiQAGxWSi3QWu9yZ72eLG3RIo6//DI6O5uM1Wsw+fgSfM1fKl/g2UTY8R0ENIHONxh5er68EVtiIvZmY/EJ701pt3x92rUj/M1/c+bz/+HdpjWNHn2UrNhY8o4cIWDgQCz165d8oNMBv38OqUeh603QILry7RdClMjd3T69gf1a64MASqmvgDGABH83yYr9HZ1tpH3Q2dlkxW6tfPDPToUPB0JOmvHgVsJmGPVvzkY+y7GZ/wDzenyW3Ebz/32OshrpH/ISElFWK9bGRgqIwGHDCBxmpJ44PfMjTr37LspkwuTnR8uff8ISGlq83kVPGcHflgObZsJft0JAo8qdgxCiRO7u9gkHCid2SchfV0ApNVkptUUpteXUqVNubs6lL3DoEON5AJMJ5eND4NAq5Pw5/gc4bEaiN1uWkT3z1D5OvvE6OjcXnZVFblwcWb//buw+9SUOjhrFgeHDOf3xx0WKsp85w6m33wabDZ2biyMzk6yNG0uud+8vRrK6c/cWjl18MvXCnJmZZMXGYj99uoInLITnqPEbvlrrmcBMMCZzqeHm1Hn+ffsSOetjsjZvxq9HD/x6lT471kXVb33+CV6zN/jVhw8HYbEHYs//r6OdTsz16mFPTib122/RNiMj6Km3p1H/rrsKHjDL2rS56GihvLySh3ACtBgIO78/P0tXow7lbrL99GkOjh2HzslBO500/+9sfMsaMSSEh3L3lX8i0KzQckT+OuFGfj160OC++6oW+MHI5jlxAXQYa2TNTIkHezZN+ybjXc+BOSiAhg8/hE+bNsaw0kLB3eTtXWTZKyoKLEWvNRIeehhbYgn/Ha55Gwb+DbrdBnf+bIznL6e0hQtxpqXhzMhAZ2VxeuZHFT1rITyCu4P/ZqC1UipKKeUFTAAWuLlO4UoRPWH8p9CkU0FOf+8gBy1HnaHNkrnUv/NOAMyBgTR5aSomf3/M9YIJnzYNVSj4+7RtQ/gbb2Bt0QLyk8zZkpI48eabxeu0eMPljxs3l5t2q1BzzSGhBeVjtWJpJPcKhCiJW7t9tNZ2pdSDwGLADMzWWu90Z53CdbL/3EHi3/6GMyuLxlc0JJhCvXJRQ4rNzlVvzBjqjRlTanlBVw7HcTaVE6/8E+1wGOkl8myl7l8ZQaOuJmvrFtIXLcanYwcaPfJ/Li1fiEuFTOB+ibInJ5O7dy/ebduWPqTyIuIGXY79pJEvR1ktRP8lAYt3/ly9na6D62dXuExnVhaHb72VvP0HMPn70/x/n+PdqlWl2ieEMMgE7gKA3AMHODz+RqPPXWtafPN1pQKs4+zZ8wsmE06nL5BpLFcym6fJz4+o777DkZyMuV69giGiQojqJVk9L0Ep33yLMzMTZ0YGzsxMUr75plLlNJgyBeXtjfL1xb93D6yB+Vf9Jgs0aHPxAs4cgl+ehFWvGfMI5FMmE5aGDSXwC1GD5Mr/EmQNa4Ly8UHn5KC8vbGGhQHG+Hfl61s0v38ZGtx3L4FXDseZmYVPxw6oQ7/CqlchMAyu/nfZB+dmwEdDjQfFzFY4sgFun1e1ExNCuIwE/0tQ6M03k7tnL5m//Yb/ZZcRMn48R+6+m8z1GzAHBdH8s0/xbt26XGV5t2x5fqHVEOOnPM5l/MRpzB8Q/5vxwJhZrvaFqA2k2+cSpLy8aPraq7Re/StNX3uVjNVryIr9HRwOHKmpHP/nq+5vRGgUWAqlenba4POxMtuWELWEBH/hHl7+MHnl+WXtNHIDpSXVXJuEEAUk+HuAwGFD8evWDcxmzMHBNHn67+6t8MROWDfNyPcfGAbn8n6aLDLblhC1hPT5ewBltRI562McGZmY/Mp/w7dSTuyCj684379/+ZNGojZ7Nox83ZgURghR4yT4exBzgP9F99F2u5ERtLIfEAeWG5OrO/Ozgcavg0mLK1eWEMJtpNtHFDj1/gfs6RrD3h49yVi9unKFhHU1JlcHsPpBsz6ua6AQwmUk+AvASLKWPGMGOBzo7GySnniycgVFDYLR06HNSBj0OAx4xLUNFUK4hHT7CMDIy184BbN2OCpfWOfrjB8hRK0lV/4CAK+ICOrdeCNYLSgvL5q8+GL+LF5V+BAQQtRaEvxFgSZP/502a9fSZuMGgoPj4JUm8M8w2Dm/ppsmhHAxCf6iCHNwMCZnFqx4CZx2sOfCvPvkyVwhLjES/EVx2ln2shCizpPgL4oLaAj9HwaTFcxeMOqtopOvCyHqPBntI0o29Fm47CEjJYM8lSvEJUeCvyidT1BNt0AI4SbS7SOEEB5Igr8QQnggCf5CCOGBJPgLIYQHkuAvhBAeSIK/EEJ4IAn+QgjhgST4CyGEB3Jb8FdKvaCUSlRKbcv/udpddYk67tgfsPQF2DZHEsgJUU3c/YTvf7TW/3ZzHaIuSz4As0eALcuY9jE1HgY/VdOtEuKSJ90+omYd3QTkJ42zZcHehTXaHCE8hbuD/4NKqT+UUrOVUiFurkvUReHdgfyU0VZfaDm4JlsjhMdQugp9rEqpZUCTEjY9A2wATgMaeAkI01rfVUIZk4HJAJGRkT3i4+Mr3R5RR8Wvh21fQOOO0HsymMw13SIh6hSl1Fatdc8KHVOV4F/uSpRqAfykte5U1n49e/bUW7ZscXt7hBDiUlKZ4O/O0T5hhRbHATvcVZcQQoiKcedon38ppWIwun0OA/e6sS4hhBAV4Lbgr7W+zV1lCyGEqBoZ6imEEB5Igr8QQnggCf5CCOGBJPgLIYQHkuAvhBAeSIK/EEJ4IAn+QgjhgST4CyGEB5LgL4QQHkiCvxBCeCAJ/kII4YEk+AshhAeS4C+EEB5Igr8QQnggCf5CCOGBJPgLIYQHkuAvhBAeSIK/EEJ4IAn+QgjhgST4CyGEB5LgL4QQHkiCvxBCeCAJ/kII4YEk+AshhAeS4C+EEB5Igr8QQnggCf5CCOGBJPgLIYQHqlLwV0rdoJTaqZRyKqV6XrDt70qp/UqpvUqpEVVrphBCCFeyVPH4HcC1wIeFVyqlOgATgI5AU2CZUqqN1tpRxfqEEEK4QJWu/LXWu7XWe0vYNAb4Smudq7U+BOwHelelLiGEEK5T1Sv/0oQDGwotJ+SvK0YpNRmYnL+Yq5Ta4aY21QYNgNM13Qg3kvOruy7lc4NL//zaVvSAiwZ/pdQyoEkJm57RWs+vaIUX0lrPBGbm17VFa93zIofUWXJ+ddulfH6X8rmBZ5xfRY+5aPDXWl9RibYkAs0KLUfkrxNCCFELuGuo5wJgglLKWykVBbQGNrmpLiGEEBVU1aGe45RSCUA/4Gel1GIArfVO4BtgF7AIeKCcI31mVqU9dYCcX912KZ/fpXxuIOdXjNJau6MhQgghajF5wlcIITyQBH8hhPBAtSL4e1KaCKXUC0qpRKXUtvyfq2u6TVWllBqZ//7sV0o9VdPtcTWl1GGl1J/571eFh9TVNkqp2Uqpk4WfqVFKhSqlliql4vL/DanJNlZFKed3SfzdKaWaKaVWKqV25cfMh/PXV/j9qxXBn/NpIlYXXnlBmoiRwPtKKXP1N8/l/qO1jsn/WVjTjamK/PfjPeAqoANwU/77dqkZkv9+XQpjxT/B+Hsq7Clguda6NbA8f7mu+oTi5weXxt+dHXhMa90B6As8kP/3VuH3r1YEf0kTUaf1BvZrrQ9qrfOArzDeN1FLaa1XA2cuWD0G+DT/9afA2OpskyuVcn6XBK31Ma11bP7rdGA3RvaECr9/tSL4lyEcOFpoudQ0EXXMg0qpP/K/ntbZr9f5LtX3qDANLFFKbc1PR3Ipaqy1Ppb/+jjQuCYb4yaX0t8dSqkWQDdgI5V4/6ot+CullimldpTwc8ldJV7kXD8AWgExwDHgzZpsqyiXAVrr7hhdWw8opQbVdIPcSRvjvy+1MeCX1N+dUioAmAv8n9Y6rfC28r5/7krsVownpYko77kqpT4CfnJzc9ytTr5HFaG1Tsz/96RS6geMrq7VZR9V55xQSoVprY8ppcKAkzXdIFfSWp8497qu/90ppawYgf8LrfX3+asr/P7V9m6fSy5NRP4bc844jJvdddlmoLVSKkop5YVxg35BDbfJZZRS/kqpwHOvgSup++9ZSRYAE/NfTwSqnLSxNrlU/u6UUgqYBezWWr9VaFOF379a8YSvUmoc8C7QEEgFtmmtR+Rvewa4C+Mu9/9prX+pqXa6glLqc4yvnho4DNxbqK+uTsofNvc2YAZma61fqdkWuY5SqiXwQ/6iBfiyrp+fUmoOMBgjzfEJ4HlgHkZKlkggHhivta6TN01LOb/BXAJ/d0qpAcAa4E/Amb/6aYx+/wq9f7Ui+AshhKhetb3bRwghhBtI8BdCCA8kwV8IITyQBH8hhPBAEvyFEMIDSfAXQggPJMFfCCE80P8Dl8wVa4Hm1P8AAAAASUVORK5CYII=\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=baseline_model.predict, \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 746268658.6881605\n",
      "Running iteration  3 error 29555194.97317477\n",
      "Running iteration  4 error 0.4018317506782987\n",
      "Running iteration  5 error 0.26782485254703053\n",
      "Running iteration  6 error 46641754.99713346\n",
      "Running iteration  7 error 0.23746619802553712\n",
      "Running iteration  8 error 0.2798781293552826\n",
      "Running iteration  9 error 3822118.6489112857\n",
      "Running iteration  10 error 0.12988879625856947\n",
      "Running iteration  11 error 0.09810455927025667\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=100, \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": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "c:\\users\\dob\\miniconda3\\envs\\qc-195-2021-visuelle-xai\\lib\\site-packages\\matplotlib\\collections.py:1003: RuntimeWarning: invalid value encountered in sqrt\n",
      "  scale = np.sqrt(self._sizes) * dpi / 72.0 * self._factor\n"
     ]
    },
    {
     "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.00597014925373134\n",
      "0.004957521495738406\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": "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 (2000) 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 (2000) 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 (2000) 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 (2000) 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 (2000) 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 (2000) 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 (2000) 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 (2000) 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 (2000) 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 (2000) 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 (2000) 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 (2000) 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 (2000) 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 (2000) 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 (2000) 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 (2000) 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 11.645309486111657\n",
      "Running iteration  3 error 2.8159010124673283\n",
      "Running iteration  4 error 0.4181084521652141\n",
      "Running iteration  5 error 0.18403974267945275\n",
      "Running iteration  6 error 0.21503130085077085\n",
      "Running iteration  7 error 0.20466331789139872\n",
      "Running iteration  8 error 0.12315097270584685\n",
      "Running iteration  9 error 0.07902185901390103\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=100, \n",
    "              activation='relu', \n",
    "              max_iter=2000\n",
    "             )\n",
    "\n",
    "dshap.run(100, 0.1, 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": "290c1d51-1436-47a0-ab82-0347f6c7e0d1",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[0.         0.         0.         0.         0.         0.\n",
      " 0.         0.         0.         0.         0.         0.\n",
      " 0.         0.         0.         0.         0.         0.\n",
      " 0.01015874 0.         0.         0.         0.         0.\n",
      " 0.         0.         0.         0.         0.         0.\n",
      " 0.         0.         0.         0.         0.         0.\n",
      " 0.         0.         0.         0.         0.         0.\n",
      " 0.         0.         0.         0.00253428 0.         0.\n",
      " 0.         0.         0.         0.         0.         0.\n",
      " 0.         0.         0.         0.         0.         0.\n",
      " 0.         0.         0.         0.         0.         0.\n",
      " 0.        ]\n"
     ]
    }
   ],
   "source": [
    "print(dv)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "3bc244ae-3d19-49db-adc4-0097955dd3c6",
   "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.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": "code",
   "execution_count": 19,
   "id": "70458d0f-c490-46f9-af6a-30c4f4189b91",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "LOO values calculated!\n",
      "Running iteration  1 error 1.0\n",
      "Running iteration  2 error 1.2499999997025464\n",
      "Running iteration  3 error 0.548974219096112\n",
      "Running iteration  4 error 0.35658512972166645\n",
      "Running iteration  5 error 0.3186776000714468\n",
      "Running iteration  6 error 0.2215192012208388\n",
      "Running iteration  7 error 0.18221624076748402\n",
      "Running iteration  8 error 0.15389398460078246\n",
      "Running iteration  9 error 0.15063029096720804\n",
      "Running iteration  10 error 0.12306063371420452\n",
      "Running iteration  11 error 0.11272544556763751\n",
      "Running iteration  12 error 0.09945798960658335\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='accuracy',\n",
    "              overwrite=True,\n",
    "              directory=directory, \n",
    "              seed=0,\n",
    "              hidden_layer_sizes=100, \n",
    "              activation='relu', \n",
    "              max_iter=1000\n",
    "             )\n",
    "\n",
    "dshap.run(100, 0.1, g_run=False, loo_run=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "cf47072d-1277-4d69-ba34-f4c80d0ff898",
   "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",
    "dv = np.asarray(dv).reshape(xx.shape)\n",
    "im = plt.contourf(yy, xx, 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.show(scatter=False, title=\"TMC Shapely on mesh and train 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": 21,
   "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"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "LOO values calculated!\n",
      "Running iteration  1 error 1.0\n",
      "Running iteration  2 error 5.963886912973673\n",
      "Running iteration  3 error 1.1858581205638539\n",
      "Running iteration  4 error 0.5638331529692407\n",
      "Running iteration  5 error 0.48386528675948715\n",
      "Running iteration  6 error 0.4571211385717738\n",
      "Running iteration  7 error 0.2590859974264303\n",
      "Running iteration  8 error 0.18142812774037395\n",
      "Running iteration  9 error 0.19449857544583235\n",
      "Running iteration  10 error 0.17207440934064414\n",
      "Running iteration  11 error 0.1446343188164858\n",
      "Running iteration  12 error 0.1127117068218345\n",
      "Running iteration  13 error 0.14267258021263587\n",
      "Running iteration  14 error 0.2579137796665216\n",
      "Running iteration  15 error 0.09728709939031543\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=100, \n",
    "              activation='relu', \n",
    "              max_iter=1000\n",
    "             )\n",
    "\n",
    "dshap.run(100, 0.1, g_run=False, loo_run=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "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",
    "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=\"TMC Shapely on mesh and train data with db difference as metric\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "d872c002-fe61-4260-892b-155463b39ecc",
   "metadata": {},
   "source": [
    "# 3. Data Shapley on Mesh Data only"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "12cb0740-682d-4beb-8250-74ae6e8f659c",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "LOO values calculated!\n",
      "Running iteration  1 error 1.0\n",
      "Running iteration  2 error 2083331802.5221224\n",
      "Running iteration  3 error 34378427.948735155\n",
      "Running iteration  4 error 31140994.67368216\n",
      "Running iteration  5 error 26455014.398224168\n",
      "Running iteration  6 error 10040157.538352115\n",
      "Running iteration  7 error 18019507.152678177\n",
      "Running iteration  8 error 7930033.330266865\n",
      "Running iteration  9 error 16841012.63243039\n",
      "Running iteration  10 error 7275899.712499455\n",
      "Running iteration  11 error 8321227.0445184875\n",
      "Running iteration  12 error 9000771.40482796\n",
      "Running iteration  13 error 3564298.682279932\n",
      "Running iteration  14 error 1111110.9363360978\n",
      "Running iteration  15 error 3197747.6702751643\n",
      "Running iteration  16 error 4956774.401331652\n",
      "Running iteration  17 error 1387963.627090008\n",
      "Running iteration  18 error 867513.4498983211\n",
      "Running iteration  19 error 0.3555359077618668\n",
      "Running iteration  20 error 1134713.2646409646\n",
      "Running iteration  21 error 0.25701607454920444\n",
      "Running iteration  22 error 3429354.188914923\n",
      "Running iteration  23 error 1322121.9766569391\n",
      "Running iteration  24 error 2524105.3000710653\n",
      "Running iteration  25 error 3319811.9447322865\n",
      "Running iteration  26 error 2603081.2627945947\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='accuracy',\n",
    "              overwrite=True,\n",
    "              directory=directory, \n",
    "              seed=0,\n",
    "              hidden_layer_sizes=100, \n",
    "              activation='relu', \n",
    "              max_iter=1000\n",
    "             )\n",
    "\n",
    "dshap.run(100, 0.1, g_run=False, loo_run=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b161d78c-710b-4213-873a-1bdbcb868763",
   "metadata": {},
   "outputs": [],
   "source": [
    "dv = dshap.vals_tmc\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.show(scatter=False, title=\"TMC Shapely 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": null,
   "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"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "LOO values calculated!\n",
      "Running iteration  1 error 1.0\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=100, \n",
    "              activation='relu', \n",
    "              max_iter=1000\n",
    "             )\n",
    "\n",
    "dshap.run(100, 0.1, g_run=False, loo_run=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7c38f3db-a811-4044-a5f1-c4558bb1db46",
   "metadata": {},
   "outputs": [],
   "source": [
    "dv = dshap.vals_tmc\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=\"TMC Shapely on mesh data only with db difference as metric\")"
   ]
  },
  {
   "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
}
