{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "seven-movie",
   "metadata": {},
   "source": [
    "# Experiments with decision boundary plots and data importance\n",
    " Comparison of data value computed by different methods\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "sustainable-eleven",
   "metadata": {},
   "outputs": [],
   "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.catastrophic_forgetting import ForgettingDV"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "superb-zambia",
   "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": [
    "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": "amber-healing",
   "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": "formal-hazard",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAX8AAAD8CAYAAACfF6SlAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjQuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/Z1A+gAAAACXBIWXMAAAsTAAALEwEAmpwYAAAvsUlEQVR4nO3deXxU1fn48c8zSzJZCGRhCQl7AkJYAgSEoha0AmoLoi3iVhcU15+7YtUW1xZr61ZcKkrFKqBfUaFi2bG4gBAQkU0CsiXsIQSyT2bO7487xEASzDKThXner1demTv33nPOnUmeuXPuuc8RYwxKKaWCi62hG6CUUqr+afBXSqkgpMFfKaWCkAZ/pZQKQhr8lVIqCGnwV0qpIFTn4C8i7URkmYhsEpGNInK37/kYEVkkIhm+39F1b65SSil/kLqO8xeReCDeGLNWRJoBa4BLgeuBI8aYySLyMBBtjJlYx/YqpZTygzqf+Rtj9hlj1voeHwc2AwnAaGC6b7PpWB8ISimlGoE6n/mfVJhIR2A50BPYbYxp4XtegJwTy6fsMwGYABAREdH/rLPO8lt7lFIqGKxZs+awMaZlTfbxW/AXkUjgf8AzxpiPRORo+WAvIjnGmNP2+6elpZn09HS/tEcppYKFiKwxxqTVZB+/jPYREScwG3jPGPOR7+kDvusBJ64LHPRHXUopperOH6N9BHgL2GyMeb7cqrnAdb7H1wFz6lqXUkop/3D4oYwhwLXA9yKyzvfcI8Bk4AMRGQ/sAsb6oS6llFJ+UOfgb4z5EpAqVl9Q1/KVUo2T2+0mMzOToqKihm5K0HC5XCQmJuJ0Outclj/O/JVSQSgzM5NmzZrRsWNHrN5fFUjGGLKzs8nMzKRTp051Lk/TOyilaqWoqIjY2FgN/PVERIiNjfXbNy0N/kqpWtPAX7/8+Xpr8FdKqSCkwV8p1SQdPXqUV199tVb7XnzxxRw9erTa2xcXF3PFFVeQlJTE2Wefzc6dOyvdbv78+XTr1o2kpCQmT55c6TZ//OMf6d27N6mpqQwfPpy9e/eWrfv8889JTU0lJSWFX/7ylzU5pJozxjSan/79+xulVNOwadOmBq1/x44dJiUlpdJ1brfbr3W98sor5pZbbjHGGDNz5kwzduzYCtuUlpaazp07m+3bt5vi4mLTu3dvs3Hjxgrb5ebmlj1+6aWXysrNyckx3bt3N7t27TLGGHPgwIFK21LZ6w6kmxrGWz3zV0o1SQ8//DDbt28nNTWVBx98kM8//5xzzz2XUaNG0aNHDwAuvfRS+vfvT0pKCm+88UbZvh07duTw4cPs3LmT7t27c/PNN5OSksLw4cMpLCysUNecOXO47jrrntXf/va3LFmyBHNKapxVq1aRlJRE586dCQkJYdy4ccyZU/He1qioqLLH+fn5Zf34M2bM4LLLLqN9+/YAtGrVqo6v0Olp8FdK1ZtFmw7wpzkbWLTpQJ3Lmjx5Ml26dGHdunU899xzAKxdu5aXXnqJrVu3AjBt2jTWrFlDeno6L7/8MtnZ2RXKycjI4I477mDjxo20aNGC2bNnV9gmKyuLdu3aAeBwOGjevHmFsspvA5CYmEhWVlalbX/00Udp164d7733Hk8++SQAW7duJScnh6FDh9K/f3/eeeedWrwq1afBXylVLxZtOsBdM7/lnRW7uGvmt375ADjVwIEDTxoD//LLL9OnTx8GDRrEnj17yMjIqLBPp06dSE1NBaB///5V9uf70zPPPMOePXu4+uqrmTJlCgClpaWsWbOGefPmsWDBAp566qmyD7FA0OCvlKoXX2QcotDtAaDQ7eGLjEN+ryMiIqLs8eeff87ixYtZsWIF3333HX379q10jHxoaGjZY7vdTmlpaYVtEhIS2LNnD2AF6dzcXGJjY6vcBqyb4BISEk7b3quvvrrsm0ZiYiIjRowgIiKCuLg4zjvvPL777rtqHHXtaPBXStWLc5NbEua0AxDmtHNuco3Sz1fQrFkzjh8/XuX63NxcoqOjCQ8PZ8uWLaxcubLWdY0aNYrp0625qT788EPOP//8CmPuBwwYQEZGBjt27KCkpIRZs2YxatSoCmWV//YxZ84cTsxhMnr0aL788ktKS0spKCjgm2++oXv37rVu88/R9A5KqXpxYY/WvHxlX77IOMS5yS25sEfrOpUXGxvLkCFD6NmzJxdddBGXXHLJSetHjhzJ66+/Tvfu3enWrRuDBg2qdV3jx4/n2muvJSkpiZiYGGbNmgXA3r17uemmm/jss89wOBxMmTKFESNG4PF4uPHGG0lJSalQ1sMPP8wPP/yAzWajQ4cOvP766wB0796dkSNH0rt3b2w2GzfddBM9e/asdZt/jl9n8qorncxFqaZj8+bNAT0zVZWr7HVvsMlclFJKNS0a/JVSKghp8FdKqSCkwV8ppYKQBn+llApCGvyVUioIafBXSjVJ9ZnSefny5fTr1w+Hw8GHH35Y5XZr1qyhV69eJCUlcdddd1VI/gbw+uuv06tXL1JTUznnnHPYtGkTANnZ2QwbNozIyEjuvPPOGh9TTWnwV0o1SacL/pWlaCjvs88+o0WLFtWuq3379rz99ttcddVVp93utttuY+rUqWRkZJCRkcH8+fMrbHPVVVfx/fffs27dOh566CHuu+8+wJqc/amnnuJvf/tbtdtVFxr8lVJNUn2mdO7YsWPZnbdV2bdvH8eOHWPQoEGICL///e/55JNPKmxXVUrniIgIzjnnHFwuV21fkhrR9A5Kqfqz5TPYvhS6nA9nXVynoiZPnsyGDRtYt24dYCVyW7t2LRs2bCjL7Dlt2jRiYmIoLCxkwIABXH755RUSsmVkZDBz5kymTp3K2LFjmT17Ntdcc02N25OVlUViYmLZ8ulSOr/yyis8//zzlJSUsHTp0hrX5Q965q+Uqh9bPoPZN8LqqdbvLZ/5vYqmktL5jjvuYPv27Tz77LM8/fTTAa+vMhr8lVL1Y/tScPu6VNyF1rKfBSqlc3UkJCSQmZlZtlydlM7jxo2rtGuoPmjwV0rVjy7ngzPMeuwMs5broD5TOldHfHw8UVFRrFy5EmMM77zzDqNHj66wXflvH/PmzSM5OTmg7aqK9vkrperHWRfD5dP81udfnymdV69ezZgxY8jJyeE///kPkyZNYuPGjQCkpqaWXXd49dVXuf766yksLOSiiy7ioosuqlDWlClTWLx4MU6nk+jo6LJ5AsC6sHzs2DFKSkr45JNPWLhwYdnFa3/zS0pnEZkG/Bo4aIzp6XvuceBm4MR0PY8YY07byacpnZVqOjSlc8NobCmd3wZGVvL8C8aYVN+P/6/uKKWUqhW/BH9jzHLgiD/KUkopFXiBvuB7p4isF5FpIhId4LqUUkpVUyCD/2tAFyAV2Af8vbKNRGSCiKSLSPqhQ4cq20QppZSfBSz4G2MOGGM8xhgvMBUYWMV2bxhj0owxaS1btgxUc5RSSpUTsOAvIvHlFscAGwJVl1JKqZrxS/AXkZnACqCbiGSKyHjgryLyvYisB4YB9/qjLqWUgrqldAZ48cUXKSgoqHTdjh07OPvss0lKSuKKK66gpKSk0u3+8pe/kJSURLdu3ViwYEGl2zz66KO0a9eOyMjIStfPnj0bEaG+h7n7a7TPlcaYeGOM0xiTaIx5yxhzrTGmlzGmtzFmlDFmnz/qUkopCGzwnzhxIvfeey/btm0jOjqat956q8I2mzZtYtasWWzcuJH58+dz++234/F4Kmz3m9/8hlWrVlVaz/Hjx3nppZc4++yza30ctaXpHZRSTdKpKZ0BnnvuOQYMGEDv3r2ZNGkSYKVNvuSSS+jTpw89e/bk/fff5+WXX2bv3r0MGzaMYcOGnVSuMYalS5fy29/+FoDrrruu0vw7c+bMYdy4cYSGhtKpUyeSkpIqDfKDBg0iPj6+wvMAf/zjH5k4cWK9pXEuT9M7KKXqzbLdy1ixdwWD2w5mWPthP7/DaZya0nnhwoVkZGSwatUqjDGMGjWK5cuXc+jQIdq2bcu8efMAK+dP8+bNef7551m2bBlxcXEnlZudnU2LFi1wOKzwWFVq5qysrJNSRpwuhXNl1q5dy549e7jkkkt47rnnanr4daZn/kqperFs9zIeWv4QM3+YyUPLH2LZ7mV+LX/hwoUsXLiQvn370q9fP7Zs2UJGRga9evVi0aJFTJw4kS+++ILmzZv7td7a8Hq93Hffffz975WOgK8XGvyVUvVixd4VFHmslMpFniJW7F3h1/KNMfzhD39g3bp1rFu3jm3btjF+/Hi6du3K2rVr6dWrF4899hhPPvnkacuJjY3l6NGjZamdq0rNnJCQwJ49e8qWq5PC+YTjx4+zYcMGhg4dSseOHVm5ciWjRo2q14u+GvyVUvVicNvBuOxW37bL7mJw28F1Ku/UlM4jRoxg2rRp5OXlAVa3zMGDB9m7dy/h4eFcc801PPjgg6xdu7bS/U8QEYYNG1Y2Ufv06dMrTc08atQoZs2aRXFxMTt27CAjI4OBAyu9namC5s2bl00juXPnTgYNGsTcuXNJS6tRbrY60T5/pVS9GNZ+GH89769+6/M/NaXzc889x+bNmxk82PpQiYyM5N1332Xbtm08+OCD2Gw2nE4nr732GgATJkxg5MiRtG3blmXLTu6CevbZZxk3bhyPPfYYffv2Zfz48QDMnTuX9PR0nnzySVJSUhg7diw9evTA4XDwyiuvYLfbK7TzoYceYsaMGRQUFJCYmMhNN93E448/Xqdj9we/pHT2F03prFTToSmdG0ZjS+mslFKqCdHgr5RSQUiDv1JKBSEN/kopFYQ0+CulVBDS4K+UUkFIg79SqkkKZFbPKVOmkJSUhIhw+PDhKsuYPn06ycnJJCcnM3369BqVlZOTw5gxY+jduzcDBw5kw4b6nfJEg79SqkkKZPAfMmQIixcvpkOHDlXuf+TIEZ544gm++eYbVq1axRNPPEFOTk61y/rzn/9Mamoq69ev55133uHuu++u9bHUhgZ/pVSTFKiUzgB9+/alY8eOp61/wYIFXHjhhcTExBAdHc2FF17I/Pnzq13Wpk2bOP/88wE466yz2LlzJwcOHKjhq1B7mt5BKVVvji9dSv5XXxExZAjNfIGvtgKV0rm6srKyaNeuXdlyTVM69+nTh48++ohzzz2XVatWsWvXLjIzM2ndunWt2lNTeuavlKoXx5cuJeu++8l5bwZZ993P8aVL/Vp+U0rpDNY3l6NHj5Kamso//vEP+vbtW2luoEDRM3+lVL3I/+orTJGV0tkUFZH/1Vd1Pvsv70RK51tuuaXCurVr1/LZZ5/x2GOPccEFF/CnP/2pzvUlJCTw+eefly1nZmYydOjQau8fFRXFv/71L8Bqe6dOnejcuXOd21VdeuavlKoXEUOGIL7pCsXlImLIkDqVF6iUztU1YsQIFi5cSE5ODjk5OSxcuJARI0ZUe/+jR4+WTQz/5ptvct555xEVFVXr9tSYMabR/PTv398opZqGTZs21XifY0uWmH1PPmmOLVnilzZceeWVJiUlxTzwwAPGGGNefPFF07NnT9OzZ08zaNAgs23bNjN//nzTq1cv06dPH5OWlmZWr15tjDHm5ZdfNl27djVDhw6tUO5LL71kEhISjN1uN/Hx8Wb8+PHGGGNWr15d9tgYY9566y3TpUsX06VLFzNt2rRK21hVWV9//bVJTk42Xbt2NWPGjDFHjhyp1jFX9roD6aaG8VZTOiulakVTOjcMTemslFKq1jT4K6VUENLgr5SqtcbUbRwM/Pl6a/BXStWKy+UiOztbPwDqiTGG7OxsXL4RU3Wl4/yVUrWSmJhIZmYmhw4dauimBA2Xy0ViYqJfytLgr5SqFafTSadOnRq6GaqW/NLtIyLTROSgiGwo91yMiCwSkQzf72h/1KWUUqru/NXn/zYw8pTnHgaWGGOSgSW+ZaWUUo2AX4K/MWY5cOSUp0cDJ2Y3mA5c6o+6lFJK1V0gR/u0Nsbs8z3eD1Sap1REJohIuoik64UjpZSqH/Uy1NOXe6LS8WDGmDeMMWnGmLSWLVvWR3OUUiroBTL4HxCReADf74MBrEsp5Q8//g9mjoMFj0JJ5VMcqjNDIId6zgWuAyb7fs8JYF1KqbrK3g4zrwB3IThCIe8guaGjOfzKqzjatKbt5Mk4K5llyni9FK77DnHYcfXqhYg0QONVTfkl+IvITGAoECcimcAkrKD/gYiMB3YBY/1Rl1IqQA5tAZsvJJQWU7JxNfs+SscUFVGyaxdZ995HxxnvVdgt6777yVu+HIyh+ejRxD8+qZ4brmrDL8HfGHNlFasu8Ef5Sql6kDgQxA52J9icuGPORewrrIt1Xi/uSuanLc3J4fiSJeB2A3D0gw9o8+gjiNNZv21XNaZ3+CoVzA5thXXvQYv20O86uPVL2DQHWrQnrNOFOOZchhvA4yH2xhsq7G4LD0ccDowv+NsiI8GhYaUp0MlclApWxw/AP/pDSR44XJB6Ffz6+ZM28RYUkP/NNzhatiKsZ0qlxeSvXMn+SY+Dw0HbZ54mzLse9q6DnpdDx7pN1aiqpzaTuWjwVypYZSyCD2+AYt88tjYnRMTBsEeh37W1K/PLF+F/z4K7AJxhcOMCiO/jtyaryulMXkqp6mudAsbrWxDwuuH4PvjsATiyo3ZlbltkBX4AY2DPKr80VfmfBn+lGgFjDMU7duA+cKD+Ko1qCzfMh/43WGfpJ9jsUHBqtpZq6joSnOG+BYH2g+rcTBUYemVGqQZmjGHvAw9wfMlS8HppNXEiMVdfVfsCPaXwzetweCv0+z0knqY3IL43/OZF61vAwseswN8qpfZdNYPvhIiWsG899BgNbXrVrhwVcNrnr1QDK9m1ix9HjcYUFwMg4eGctXZN7Qv870RYMx1KC62z8Nu+gpjOP7/f4QwoyIaENLDreWFTon3+SjVBEhZ20rItPLyKLavpx2VW4AcQmzXypjrikq1uGrsDPG749l1Y+Xrtu4D2fw8fXAf/ubv2ZaiA0Y93pRqYs1UrWj/yCAefew5bWBgJL71YvR2P77dSMrTpBa4ojNfLvrtvInfJMZzhrWg/NJuQaHP6bp+qfHgDbFsCxgMrX4M7V4Mj5ORtVr8F374Hif1h+NNWSogTinLhXxdD8TFrFNGBTXDTopq3QwWMBn+lGoHoK8YSfUUNMqDsWY33X6M5vMGFO89J9KOv4c0v4Niyr8EruPPs7P82jvYzPrZu4CrP6wWb70v/0d2YnV9z8KO1HJ23FGdiIm0mTaJ08TLCWhTjjPBA/iHI2Qktu/5Uxval1jUCdwHsX2/dLHbFO+Bq7it3z08jibxuOLAB1bho8FeqKfrqRfZ/7eTYbifGa+P4bXfT6vbyd+AK3hKvdSH3BGNgwSPWxeCwaOuGrk/uoGCfjZxlEZhSoXjrVnZdcw02R3OMN5KOF2TjamO3RgaVd2greD3WY68bdiyHqefD7+daF41jkyCshdV9ZLNbo4BUo6LBX6mmKKotBYdDMV7rDF7sdhydehAa46A42w0CrVKPw+ppMOBGa5+938Kat60z8oJsmPcAuAvxFDiBcECsDwhj8JYA2Dh6NIU2j7wKoZEn1991BCx9GjzFvie8kLMLXkoFERhyF0xYDt9/AKFR0PuK+nhVVA3oBV+lmqLzH6NZz5aIw4AAjhDC+6fR8fXJdP71MZJHHyA8tgi+esna/vA2mPv/rHTNZQQcoUTGF+OM8CKhDnA4kBCrb19CQwn51U3WtwdPqdXHv/hJq6yYTnD719Y3ArFTdpOYt8T6QPjieXC6YNBt0PdqHT3UCOk7olRT5GpOq7//G9dfbsSdfYyoG+/FERcH3i6ENDNQakAcEN3B2v69y60z8xMT6jlccOmrsH8Dtg0f0vmh3hR3vRV763h2X3c9JTt3YtxuSo/kWNt/9gB8Nwt3bgkFs/5F6O0zcPUbDDd/DosnQdEx2DrfukAM1u+iXAiJqO9XRlWTnvkr1UTJrCtp3uw74jpsJ2T5vZB/GFp1t/ryY5Og83lw2VRr42N7OSnwj18MyRdCl2FwdDeyeTaur+9Cio9bqZuNAa+X7DfewBgDGQspOVrCj/Nbsn9lCDuvvZ7jDw2w+vPHvA5XzsAdmkzuLhfFx+xgDyH/o3+ybfgItl98CYXffddgr5OqnJ75K9VU5WaWy81jg7wDVmK21Kusn/L6XQfrZlhdRK1SfroQvPAxazgmwL51yNRBQJuy3WwREdbMXDFdyEs/htcj4LVm6spZnU2zpc/Ab16gePt2dszIB28LjEcIjfZQnDsbPNY3gd03T6DrNyt1lq9GRIO/Uk1V2nhYPdW6kSumC8R1q3rbi5+DHqOgJB+6XPDTUE+HC+sTwfpWYLeV0PaXXvZ/G4c4nST87TlY8QpkpRPSzCBiMAhi8+Jq4QZ3PgDH/jsf4/aCscotPuIAPGXVe/PyrA8CzfXfaOg7oVRTdeET1qibolzocv7pL6qKQKfzrMdeL5QWWzdfuVoAUFpow1sqOCM9NEsKoajzZRxftJhjn35KWOi7iLuAyHhomRpK7g4XYXFu4gY44LyHAAjp0AFxuTCFhSfX63AgTictxoxBNPA3KvpuKNVUidR8spSdX8GMK6ybszqdB7tXcvRHF/vTW4AYIhO8RF5xDUem/BtTWIg7cw+Os4qI62HtHtv1OLHPzYWw5hDZxhrRA0T9+hJKdu0kd85c3Hv3Wt8sbDZaP/ggYX364KpiIhjVcDT4KxVM5tyBJy8Pd76dEO+X2OyGg+viMF4BhLxDEdgz8zBFRQCYEjfFx8uFifje0LZixk8RoeWdd9Lyzjsp3LiRwjVrCOvbj7BePevpwFRNafBXqonxFhSw59ZbKVizFlfPnrR/cyr2Zs2q3D7/m1Xkr1xBeP807AdK2T23NQD2UEOnUcWIEyg5UbiXZsOHc2zOXBDBeEqJPqsQnBHW8M3z//iz7QtLSSEsRc/0GzsN/ko1MUfee4+Cdd+Bx0Pxpk1kv/kWre69p9Jt81euZM+tt2GKijjiCiU0oQ3e0izAGs15LPFBEv/cnMyn/4knv5CWd99F5ODBdJ73KYXfrcfV/SxC1vwZNsy2rgsf+RG4oN6OVQWOBn+lmhhvQaF10RYwHg/e/Pwqt8374sufunCKivEc3GXdkWsE8GLb8j5h478gecTJc/Y64+Nxxsdbw0k3fWzdvQvW0NCBNwfkuFT90pu8lGpiYq66EkdsLBIWhj06mtgbrq9y2/D+/ZBQX7oGu5fo5DxcMW5sDi9R7YuIiv6ZuXodrrJ7w8qW1RlBz/yVamIcLVuStGgh7v37cbRpgy0kpMptI4cNI/qykRQsmk3zDvlEJxUQ27Xgpw26Xn76yiLirFz9ix4DRxj87m3/HIRqcHrmr1QTJCEhhLRvf9rAD3Do+RfI+WQRxcdcZG9uhvGUu8NW7DD8z6evKD8bVkwBbGAPgdgudW+8ahQ0+Ct1Bjv60UeYwkJMiQevLYqi5LutIG4PhcG3Q1Sb0xeQPs3KC1RaCAWH4csX6qfhKuAC3u0jIjuB41j3epfWdJJhpVTthSYnU5CbC6WlGI8X54jbIOpu8JZCZKufL8AZZt2w5cX6puAM+9ldVNNQX2f+w4wxqRr4lapfCS88T9TIkYQNSKPdK1NwtmkD4THVC/wAaTdCQn/rbuJW3eHcBwLbYFVv9IKvUmcwR3S0lZyttkLC4Yb/WjcFBCAjZ9EPW8m8/TZKj+QQO348Le+8w+91qMrVx5m/ARaKyBoRmXDqShGZICLpIpJ+6NChemiOUqrGApSKee+DD+LO2ospLCT7zTcp+uGHgNSjKqqP4H+OMaYfcBFwh4icV36lMeYNY0yaMSatZcuW9dAcpVRj4cnL+2nBZrNSP6t6EfDgb4zJ8v0+CHwMDAx0nUqppqH1xIlIaCjichHWpw9hqakN3aSgEdA+fxGJAGzGmOO+x8OBJwNZp1Kq6YgaMZzwAWl4juYS0rEDYtPR5/Ul0Bd8WwMf+6ZucwAzjDHzA1ynUqoJccTE4IiJaehmBJ2ABn9jzI9AxeTfSimlGpR+x1JKqSCkwV8ppYKQBn+llApCGvyVUioIafBX9cIYw8HjRRS5PQ3dFKUUmttH1YNSj5fx09NZsT0bp114+8aBDOioQ/uUakh65q8C7qvt2aTvPEKJx0t+iYc/zdnY0E1SKuhp8FdVKnAX4D4xcXcdOO1y0jSwIfbAJAlTSlWfBn9VgTGGp1c+zS9m/oJfzPgFX2d9XafyBneO5ZJe8dgE4iJDmHx57yrrXbPrCF9tO0ypx1unOpVSpyfGmJ/fqp6kpaWZ9PT0hm5G0Nuas5Wr511NkacIgNbhrVn8u8U/u5/Ha9iQlUszl4POLSMrXW8TkCrSA0+as4H/W5OJAH3bR/Pv8QOr3FYp9RMRWVPTybL0gq+qwHbKF0Lh5wOw12v47b9mkeGehfGEclOP+7h32KCTtrHbTl/Ou9/sxuO1TkZW7zxC1tFCEqPDa9h6pVR1aLePqiApOonLki/DLnbCHGE8OeTnE7F+s3sHGfbJSNiPSMRmpm17pMb1xkY4T1puER5S4zKUUtWjZ/6qUn84+w/c2/9enDYndpv9Z7d/c8tfsWb59k365Mw+7fbGGDJzCgkPsZNf7KF5uJOkVpEcOn4EAwhQWOIhMlT/RJUKBP3PCkJer0FO0/d+gsvhqnaZBwoyf5rpz0CP6Mov6oIV+O+a9S0LNuzH7TE47ILdJoTYbWWjgpwOG9sP5dGyWWi126CUqj7t9gkyr36+ja6P/ZeUSQv439bqz5ns9ni5/4N1DHhmMf9v5lqKS0++U/d33X6Hy+7CKU4inBGM63EZS3YvodRbWqGsbQfzWLzpICUegwHcHkOR24sBwpx27Dbrw6B7m6g6Hq1Sqip65h9E9ucW8dLiDEq9htISD/fM+pZv/zS8Wvu+u3IX89bvo6jUy8KNB3irzQ5uH5ZUtv66lOvYkdWcTzdvwDRby1+++QsiwoA2A5hywZSTynI57XgrGWXWMTacawZ14HBeCZf2TaB5uLPCNkop/9DgH0Tcp4ydd3usALw7u4D7PljH4bxiHhjRjV/3blth3/25RRSXWvuXlHrZfaSAeev3ERsZwqDOsazPPMr7X7go9JxFZPP/Q3x1fZH1BUWlRSd1IbWLCef+4V35+4IfEBFKvYZWUaH8fWwqXVs3C9ThK6XK0eAfRNrFhDNuQDtmrNqNiPDUpT0BuPXdNWzZfwyvgQc++I6+7aNJaBF20r7jBrZnxqrdAHiNYfnWQ8z9bi/GwK2/7Ez3+ChsNsAdAt5QsBUiIjQPaU6oPRSv17Bw0wFyC0u4qFc8E87rQq+EFjy/aCtxkSE8MTqFVs2qf41BKVU3GvyDzBOje3L3r7oS4rCVjaTZl1uIb3g9dptw6HhxheDfKS6C/z04jC37j1FY4uGuWd9SUGL1+7+zYhfLHxpGXKR1cbY061a6dl9Cy2YuHh74MAB/nLOBj7/Nwhh4Zdl2Ztx8NtdNW0WJx4tNYG9uAU+NtT4ousV0q6dXQ6ngpcE/CMVEnDx+/tpBHXhl2TZEoG2LMFLaVrzQ6vZ4ycopxOWwU+T2lqVfsAt0jIsgItTB/LvPY82uHOJbuOjS8kY+/jaL3zy/HmMy8JBPaWkoYCc7v5hn5m2mxFeG1xh+5FVuWrgdYwxXdb+Ke/vfG/DXQalgpsFfsXjzQRDBaz/MAdd7DJpxP9GuFrx8/sv0iO1BkdvD5a99zdYDx3F7DKEOGx1iI3DahNbNw5h8WS8AwkLsnJMcB0CR28PED9dT4nET1n4azvCd4A2hYNfNGNOOFT/+dB+AOI4hkVsoLLVGBk3fOJ17+t2jqR2UCiAd6hnkjDFs3n8M4zhAeOcX8YZ/T4m3mAMFB3ho+UMArPgxm52H88suEBeXesnMKeTpMb2Ydv0AWkVV7Kv3GoPXGBzNNmN37UHEA7ZCwtp8yp9+3YNOsRGcyPbgJAxnuRvJokKiEBEaU94ppc40GvyDXG6hm5T4KEKjtoB4KH+yne/OB6BFmLPsmsAJXmOqTL/w9bbD3PbuWnq0jcImtlP2E574zyYe+3V3zkmKo1vrZvzjysG8MOx54iPi6RjVkft7/5W0pxeR9Oh/eXreJr8er1LKot0+QWzj3lyu+OdKjDHYw9vgECceigErudsDaQ8AVobNW3/Zmalf7KCk1IMrxM59F3alU1xEWVkbsnLZmZ1P+5hwxk9Pp9DtwSYQHdGb1uGb2V2UjvFEULx/NOE24cCxYt4Zf3bZ/tmFTl4Y9gLJLZL5zT9WcjivBID3Vu5mVJ+29E5sUX8vjFJBQIN/EHv9f9vJK7b62Z2ebsS0uJRsVlJa1Arb0RGkXDK0bNu7f9WVu3/VtdJyPl6bySMff49NxPdjPe81kJ1Ximy7krF97mbmqr143V5MiKFPuxZl+6/ev5o7ltyBIMSFxVFYekfZOhEocmtuf6X8TYN/EIuNCMFpFyu/js1G/qGzyc/vC0BkqIOtB47TMS7CN/l6MVEuJ2EhFZO8vfXlDgp9ATrUIVbeIHs+xuMC7BzJL+GuC7qT3DqanYfzGdMv4aShpFO+nUJhaSEAhwoPcfmgHP61IAZjYFDnWNI6RAf+xVAqyGjwD2L3XtiNH/bnsSErlwu6tyahhYtpX+/EXWqNve/bPhqP13Dj26tZ+WM2NhGmXT+AwV1iTyonqVUkP+w/htsLxZ4SwttPJcKVhfGGUrjrFkxJa87+82LGprXnydEpFJd62XOkgPjmLhx2GzGuGOxix2Os+wYGd2zHHY/9gmOFbuKbu3TUj1IBEPDgLyIjgZcAO/CmMWZyoOtU1dM8zMnMCT9NuGKMoXOrSDZk5nLFgHa0bBbKpxu3sKbob9gTcyk+NJzH54az4N7zTirnqUt7klvo5vMfDmGPWo/NtQ+xeUAKCGn1GUWZN1Bcapi9NpMebaN49r9bKC710qa5izl3DuHRQY+yv2A/O3N3MqrLKM5NOBcR0XTOSgVQQEf7iIgdeAW4COgBXCkiPQJZp6q9zJxCnv50E/+3JpNxb6xkV3Y+U3+YBOFbsIftJSzxXYrCPmdrztaT9mvmcvKXy3oT4rCBsYNv5i9BCLWfHMD/L30PuYVuCt0e9h4t5KM1mTRzRjOm1V+5vfMs/l/qg3qmr1Q9CPRQz4HANmPMj8aYEmAWMDrAdQY1YwwzV+3m9vfW8Mm3WTXa992Vu8gtdJNXXEpuoZu3v95JTsk+RKxxniKl5EXM4ep5V/NV1lcn7dumuYs//boHYSV9cZR0RhBaR7TiqfMeIcxpJzzETofYCDrGRWDzXRG2iRAWYuemt9OZNHcDz8zbxOWvfo331HGlSim/C/T36gRgT7nlTODs8huIyARgAkD79u0D3Jwz34drMnnyP5sodHtYtuUQ4SF2hqe0qda+LcKdOFuswBHzJaYkjjDXw4xNHMs7m96h1FuK2+umxGsNwXz/h/cZkjDkpP2vHtSBqwd1AC7G7XHjsDkQEX75h+4cPF5Ep7gIjhSUsHHvMbYdyGNQ5xhG90ng4dnfl03isjM7n0N5xbSu5MYxpZT/NHinqjHmDeANgLS0ND3lq6NVO45Q6LYunBa6PXy7+2i1g//uvC04W32G2NwYRw7fF03l333/ydnxZ7M8czmztsyiyFNEqD2U5Ojk05bltP+Ui795uLMsN3+rZi4W3HPyNYMOseHsOVKAFwgPsROtc/cqFXCBDv5ZQLtyy4m+51SAjEhpw6fr91Fc6iHEYWNot5bV3ve7fbusTG2A2Lxk5llv1YA2A0hrnUasK5ZPf/yUvq36ckvvW/zW5lkTBvPsfOsi8P3DrYyjSqnAkkDmTxERB7AVuAAr6K8GrjLGbKxs+7S0NJOenh6w9gSLr7cdJn1XDkOSYunfIaba+73xxSZe/uEWsBWCeLmnzx+4qd/vAthSpZQ/iMgaY0xaTfYJ6Jm/MaZURO4EFmAN9ZxWVeBX/vOLpDh+kRRX4/1uPqc7raLe5ovdq/hV17O4qFvfALROKdUYBPTMv6b0zL9xKSzxUOr10sxV+Vy6+/P3szVnKz1iexAXVvMPG6WUfzS6M3/VdH28NpOJs7/Hi+HmczszceRZJ63feHgjNyy4AbtY6R5mXjKTjs07NkBLlVK1oVfWVKUe/WQDJR4vpR7DW1/s4OCxopPWv//D+xSWFpLnziPfnc9/tv+ngVqqlKoNDf6qUqfeZHvqXbeJkYmE2q05e0PtobSNbFtfTVNK+YEGf1Wp53/Xh1CHDbtNuOfCZFo2Cz1p/fU9r2dkx5EkRCZwWfJlXJp0acM0VClVK3rBV1XJ47WmYnTa9RxBqcZML/gqv7LbBDuaZE2pM5Ge0imlVBDS4K+UUkFIg79SSgUhDf5KKRWENPgrpVQQ0uCvlFJBSIO/UkoFIQ3+SikVhDT4K6VUENLgr5RSQUiDv1JKBSEN/kopFYQ0+CulVBDS4K+UUkFIg79SSgUhDf5KKRWENPgrpVQQ0uCvlFJBSIO/UkoFIQ3+SikVhDT4K6VUEApY8BeRx0UkS0TW+X4uDlRdSimlasYR4PJfMMb8LcB1KKWUqiHt9lFKqSAU6OB/p4isF5FpIhId4LqUUkpVU52Cv4gsFpENlfyMBl4DugCpwD7g71WUMUFE0kUk/dChQ3VpjlJKqWoSY0zgKxHpCHxqjOl5uu3S0tJMenp6wNujlFJnEhFZY4xJq8k+gRztE19ucQywIVB1KaWUqplAjvb5q4ikAgbYCdwSwLqUUkrVQMCCvzHm2kCVrZRSqm50qKdSSgUhDf5KKRWENPgrpVQQ0uCvlFJBSIO/UkoFIQ3+SikVhDT4K6VUENLgr5RSQUiDv1JKBSEN/kopFYQ0+CulVBDS4K+UUkFIg79SSgUhDf5KKRWENPgrpVQQ0uCvlFJBSIO/UkoFIQ3+SikVhDT4K6VUENLgr5RSQUiDv1JKBSEN/kopFYQ0+CulVBDS4K+UUkFIg79SSgUhDf5KKRWENPgrpVQQ0uCvlFJBqE7BX0R+JyIbRcQrImmnrPuDiGwTkR9EZETdmqmUUsqfHHXcfwNwGfDP8k+KSA9gHJACtAUWi0hXY4ynjvUppZTygzqd+RtjNhtjfqhk1WhgljGm2BizA9gGDKxLXUoppfynrmf+VUkAVpZbzvQ9V4GITAAm+BaLRWRDgNrUGMQBhxu6EQGkx9d0ncnHBmf+8XWr6Q4/G/xFZDHQppJVjxpj5tS0wlMZY94A3vDVlW6MSfuZXZosPb6m7Uw+vjP52CA4jq+m+/xs8DfG/KoWbckC2pVbTvQ9p5RSqhEI1FDPucA4EQkVkU5AMrAqQHUppZSqoboO9RwjIpnAYGCeiCwAMMZsBD4ANgHzgTuqOdLnjbq0pwnQ42vazuTjO5OPDfT4KhBjTCAaopRSqhHTO3yVUioIafBXSqkg1CiCfzCliRCRx0UkS0TW+X4ubug21ZWIjPS9P9tE5OGGbo+/ichOEfne937VeEhdYyMi00TkYPl7akQkRkQWiUiG73d0Q7axLqo4vjPi/05E2onIMhHZ5IuZd/uer/H71yiCPz+liVhe/slT0kSMBF4VEXv9N8/vXjDGpPp+PmvoxtSF7/14BbgI6AFc6XvfzjTDfO/XmTBW/G2s/6fyHgaWGGOSgSW+5abqbSoeH5wZ/3elwP3GmB7AIOAO3/9bjd+/RhH8NU1EkzYQ2GaM+dEYUwLMwnrfVCNljFkOHDnl6dHAdN/j6cCl9dkmf6ri+M4Ixph9xpi1vsfHgc1Y2RNq/P41iuB/GgnAnnLLVaaJaGLuFJH1vq+nTfbrtc+Z+h6VZ4CFIrLGl47kTNTaGLPP93g/0LohGxMgZ9L/HSLSEegLfEMt3r96C/4islhENlTyc8adJf7Msb4GdAFSgX3A3xuyrapazjHG9MPq2rpDRM5r6AYFkrHGf59pY8DPqP87EYkEZgP3GGOOlV9X3fcvUIndKgimNBHVPVYRmQp8GuDmBFqTfI9qwhiT5ft9UEQ+xurqWn76vZqcAyISb4zZJyLxwMGGbpA/GWMOnHjc1P/vRMSJFfjfM8Z85Hu6xu9fY+/2OePSRPjemBPGYF3sbspWA8ki0klEQrAu0M9t4Db5jYhEiEizE4+B4TT996wyc4HrfI+vA+qctLExOVP+70REgLeAzcaY58utqvH71yju8BWRMcA/gJbAUWCdMWaEb92jwI1YV7nvMcb8t6Ha6Q8i8m+sr54G2AncUq6vrknyDZt7EbAD04wxzzRsi/xHRDoDH/sWHcCMpn58IjITGIqV5vgAMAn4BCslS3tgFzDWGNMkL5pWcXxDOQP+70TkHOAL4HvA63v6Eax+/xq9f40i+CullKpfjb3bRymlVABo8FdKqSCkwV8ppYKQBn+llApCGvyVUioIafBXSqkgpMFfKaWC0P8Hpc8a8QXIUsQAAAAASUVORK5CYII=\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": "authorized-shore",
   "metadata": {},
   "source": [
    "# Catastrophic Forgetting Wrapper"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "brave-regression",
   "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 (1) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n"
     ]
    }
   ],
   "source": [
    "fg = ForgettingDV(hidden_layer_sizes=(100))\n",
    "dv = fg.predict_dv(X_train, y_train)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "5272fb10-d5eb-444b-968f-958d57b51aeb",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(67, 2)\n"
     ]
    }
   ],
   "source": [
    "print(X_train.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "mature-reading",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAX8AAAD8CAYAAACfF6SlAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjQuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/Z1A+gAAAACXBIWXMAAAsTAAALEwEAmpwYAAAbv0lEQVR4nO3deXhUVZ7/8fc3CwmEENmNCUIkILuoaUTbdmkaAUUWF8TWFltHRO3RmfY3NiMtOjP6qD0uPfajKG6ovaC2KLQKCuqAbYOYMCwB1LApwQhhX0L28/ujihggK1U3ldT9vJ6nnqq6de4930tRn1Sde+uUOecQERF/iYl0ASIi0vQU/iIiPqTwFxHxIYW/iIgPKfxFRHxI4S8i4kMhh7+ZdTOzT8xsnZmtNbO7gss7mNlCM8sLXrcPvVwREQkHC/U8fzNLBVKdcyvMLBnIAcYBNwK7nXOPmNlUoL1z7jch1isiImEQ8jt/51yBc25F8PYBYD2QBowFXgk2e4XAHwQREWkGQn7nf9TGzHoAS4ABwLfOuZOCyw3Yc+T+MetMBiYDJCUlnd2nT5+w1SMi4gc5OTk7nXOdG7NO2MLfzNoCi4GHnHNzzGxv9bA3sz3OuTrH/bOyslx2dnZY6hER8Qszy3HOZTVmnbCc7WNm8cBbwJ+cc3OCi7cHjwccOS6wIxx9iYhI6MJxto8BLwLrnXNPVHtoHjApeHsSMDfUvkREJDziwrCNHwO/ANaY2crgsnuBR4A3zOxm4BtgQhj6EhGRMAg5/J1zfwesloeHhbp9EfGfsrIy8vPzKS4ujnQpzUpiYiLp6enEx8eHvK1wvPMXEQmr/Px8kpOT6dGjB4GRZXHOsWvXLvLz88nIyAh5e5reQUSaneLiYjp27Kjgr8bM6NixY9g+DSn8RaRZUvAfL5z/Jgp/EREfUviLiNQjJyeHgQMHkpmZyZ133klNX451znHnnXeSmZnJoEGDWLFixXFtiouLGTJkCGeccQb9+/fn/vvvP2r9adOm0bt3b/r27ctTTz3l6T4p/EVE6nHbbbfx/PPPk5eXR15eHgsWLDiuzfz586senzlzJrfddttxbRISEvj4449ZtWoVK1euZMGCBSxbtgyAWbNmsXXrVr788kvWr1/PxIkTPd0nhb+ISB0KCgrYv38/Q4cOxcy44YYbeOedd45rN3fuXG644QbMjKFDh7J3714KCgqOamNmtG3bFgiczlpWVlY1jj9jxgymT59OTEwglrt06eLpfin8RUTqsG3bNtLT06vup6ens23bthrbdevWrd52FRUVDB48mC5dujB8+HDOOeccADZu3Mjrr79OVlYWo0aNIi8vz4O9+YHCX0SiwsJ13zPqf5awcN33kS6lTrGxsaxcuZL8/HyWL19Obm4uACUlJSQmJpKdnc0tt9zCTTfd5GkdCn8RiQpPLPya9QUHeGLh12HdblpaGvn5+VX38/PzSUtLq7Hd1q1b6213xEknncTFF19cdfwgPT2dK664AoDx48ezevXqcO1CjRT+IhIVfj28N31Tk/n18N5h3W5qairt2rVj2bJlOOd49dVXGTt27HHtxowZw6uvvopzjmXLlpGSkkJqaupRbQoLC9m7dy8Ahw8fZuHChRz5DZNx48bxySefALB48WJ69w7vfhxL0zuISFQY3u9khvc72ZNtP/PMM9x4440cPnyYUaNGMWrUKACeffZZAKZMmcKll17K+++/T2ZmJm3atOHll18+bjsFBQVMmjSJiooKKisrmTBhAqNHjwZg6tSpXHfddTz55JO0bduWF154wZN9OSKsv+QVKv2Yi4gArF+/nr59+0a6jGappn+biP2Yi4iItCwKfxERH1L4i4j4kMJfRMSHFP4iIj6k8BcR8SGFv4hIPaZNm0a3bt2qJmWrzcMPP0xmZiann346H3zwQY1tRo4cWTWl85QpU6ioqADgzTffpH///sTExNAUp7wr/EVE6nH55ZezfPnyOtusW7eO2bNns3btWhYsWMDtt99eFezVvfHGG6xatYrc3FwKCwt58803ARgwYABz5szhggsu8GQfjqVv+IqI1GPo0KH1tpk7dy4TJ04kISGBjIwMMjMzWb58Oeeee+5R7dq1awdAeXk5paWlVVM6N/WX2vTOX0QkDBo6pTPAiBEj6NKlC8nJyVx11VVNVeJRFP4iEh0O7YLP/idw3cx98MEHFBQUUFJSwscffxyRGhT+IhIdVv4RFk4PXEdAY6d0TkxMZOzYscydO7cpyjuOwl9EosPg62H4fwauI2DMmDHMnj2bkpISNm/eTF5eHkOGDDmqzcGDB6t+2rG8vJz33nuvakrnpqbwF5HokNQRfnxX4DrM7rnnHtLT0ykqKiI9PZ0HHngAgHnz5jF9+nQA+vfv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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",
    "\n",
    "sct.scatter(X_train, y_train, scatter_size=dv*300+1)\n",
    "sct.show(scatter=False)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "catholic-saying",
   "metadata": {},
   "source": [
    "# Meshgrid with multiple points"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "reserved-stopping",
   "metadata": {},
   "outputs": [],
   "source": [
    "step = 1\n",
    "\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(np.array(X_mesh))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "conditional-possible",
   "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 (1) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n"
     ]
    }
   ],
   "source": [
    "X_new = np.vstack([X_train, X_mesh])\n",
    "y_new = np.hstack([y_train, y_mesh])\n",
    "\n",
    "fg = ForgettingDV(hidden_layer_sizes=(1000))\n",
    "dv = fg.predict_dv(X_new, y_new)\n",
    "\n",
    "dv = dv[X_train.shape[0]:]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "protecting-african",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "MLPClassifier(hidden_layer_sizes=1000, max_iter=1000)"
      ]
     },
     "execution_count": 10,
     "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": 11,
   "id": "alternate-progressive",
   "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": [
    "db_diff = np.asarray(dv).reshape(xx.shape)\n",
    "im = plt.contourf(xx, yy, db_diff, cmap=\"RdBu\", alpha=.5)\n",
    "\n",
    "plt.colorbar(im)\n",
    "sct.add_boundary(syn.get_labels)\n",
    "sct.add_boundary(baseline_model.predict)\n",
    "sct.show(title=\"\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "stunning-graphics",
   "metadata": {},
   "source": [
    "# Meshgrid only"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "foster-legislation",
   "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 (1) reached and the optimization hasn't converged yet.\n",
      "  % self.max_iter, ConvergenceWarning)\n"
     ]
    }
   ],
   "source": [
    "fg = ForgettingDV(hidden_layer_sizes=(1000))\n",
    "dv = fg.predict_dv(X_mesh, y_mesh)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "equipped-albany",
   "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": [
    "db_diff = np.asarray(dv).reshape(xx.shape)\n",
    "im = plt.contourf(xx, yy, db_diff, cmap=\"RdBu\", alpha=.5)\n",
    "\n",
    "plt.colorbar(im)\n",
    "sct.add_boundary(syn.get_labels)\n",
    "sct.add_boundary(baseline_model.predict)\n",
    "sct.show(title=\"\", scatter=False)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "specified-efficiency",
   "metadata": {},
   "source": [
    "# Sequentially adding points and evaluating dv"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "efficient-prior",
   "metadata": {},
   "outputs": [],
   "source": [
    "step = 1\n",
    "\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(np.array(X_mesh))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "consolidated-spencer",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 1225/1225 [16:23<00:00,  1.25it/s]\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": [
    "from tqdm import tqdm \n",
    "import warnings\n",
    "warnings.filterwarnings(\"ignore\")\n",
    "arc = 1000\n",
    "\n",
    "dvs = []\n",
    "\n",
    "for i in tqdm(range(X_mesh.shape[0])):\n",
    "\n",
    "        X_train_new = np.vstack([X_train, X_mesh[i]])\n",
    "        y_train_new = np.hstack([y_train, y_mesh[i]])\n",
    "\n",
    "        fg = ForgettingDV(hidden_layer_sizes=(1000))\n",
    "        dv = fg.predict_dv(X_train_new, y_train_new)[-1]\n",
    "        dvs.append(dv)\n",
    "\n",
    "dvs = np.asarray(dvs).reshape(xx.shape)\n",
    "im = plt.contourf(xx, yy, dvs, cmap=\"RdBu\", alpha=.5)\n",
    "\n",
    "sct.add_boundary(syn.get_labels)\n",
    "sct.add_boundary(baseline_model.predict)\n",
    "plt.colorbar(im)\n",
    "sct.show(title=\"Sample Forgetting\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "21270a2d-9568-49dd-bc27-05018da8dc6f",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  6%|███████████▊                                                                                                                                                                                    | 75/1225 [01:02<15:48,  1.21it/s]"
     ]
    }
   ],
   "source": [
    "from tqdm import tqdm \n",
    "import warnings\n",
    "warnings.filterwarnings(\"ignore\")\n",
    "arc = 100\n",
    "\n",
    "dvs = []\n",
    "\n",
    "for i in tqdm(range(X_mesh.shape[0])):\n",
    "\n",
    "        X_train_new = np.vstack([X_train, X_mesh[i]])\n",
    "        y_train_new = np.hstack([y_train, y_mesh[i]])\n",
    "\n",
    "        fg = ForgettingDV(hidden_layer_sizes=(1000))\n",
    "        dv = fg.predict_dv(X_train_new, y_train_new)[-1]\n",
    "        dvs.append(dv)\n",
    "\n",
    "dvs = np.asarray(dvs).reshape(xx.shape)\n",
    "im = plt.contourf(xx, yy, dvs, cmap=\"RdBu\", alpha=.5)\n",
    "\n",
    "sct.add_boundary(syn.get_labels)\n",
    "sct.add_boundary(baseline_model.predict)\n",
    "plt.colorbar(im)\n",
    "sct.show(title=\"Sample Forgetting\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d8c1fc08-b934-4a16-b737-28037c266ad6",
   "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
}
