{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "oriental-clerk",
   "metadata": {},
   "source": [
    "# Experiments with decision boundary plots and data importance\n",
    "\n",
    "TODO\n",
    "- Substract initial difference between decision boundaries"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "supposed-beast",
   "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.memorizing import MemorizationDV\n",
    "from utils.synthetic_data import SyntheticData\n",
    "from utils.metrics import DecisionBoundaryDifference, AccuracyDifference"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6fa4ed06-9066-42c0-bef6-b31ef48f4e3b",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "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": [
    "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": "1982cadb-984a-4d2f-9255-c95ce2885fe8",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "MLPClassifier(hidden_layer_sizes=1000, max_iter=1000)"
      ]
     },
     "execution_count": 4,
     "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": 5,
   "id": "other-thinking",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "sct = decision_boundary.Scatter2D(X_train, y_train, \n",
    "                                  X_test, y_test, \n",
    "                                  x_lim=(-10, 20), y_lim=(-10, 20),)\n",
    "sct.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "periodic-transsexual",
   "metadata": {},
   "source": [
    "# Meshgrid"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "rising-commissioner",
   "metadata": {},
   "outputs": [],
   "source": [
    "step = 1\n",
    "\n",
    "x, y = np.meshgrid(np.arange(-10, 25, step),\n",
    "                   np.arange(-10, 25, step),\n",
    "                   sparse=True)\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": 7,
   "id": "a9f03b2d-1235-4bcc-a024-8afc3d50b0d6",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "MLPClassifier(hidden_layer_sizes=1000, max_iter=1000)"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "baseline_mesh = MLP(hidden_layer_sizes=1000, activation='relu', max_iter=1000)\n",
    "baseline_mesh.fit(X_mesh, y_mesh)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "egyptian-dream",
   "metadata": {},
   "source": [
    "## Data Value with Memorization"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "8384fe08-fe7e-464e-ace0-ad0fd3523fbc",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 1225/1225 [23:18<00:00,  1.14s/it]\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": [
    "loo = MemorizationDV(1000, X_train, y_train)\n",
    "dv = loo.predict_dv(X_mesh, y_mesh)\n",
    "\n",
    "dv = dv.reshape(xx.shape)\n",
    "im = plt.contourf(xx, yy, dv, 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=\"Memorization wrt baseline\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "63f443c1-d85b-4ddd-9e58-c70099f2c896",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 1225/1225 [9:00:02<00:00, 26.45s/it]\n",
      "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": [
    "loo = MemorizationDV(1000)\n",
    "dv = loo.predict_dv(X_mesh, y_mesh)\n",
    "\n",
    "dv = dv.reshape(xx.shape)\n",
    "im = plt.contourf(xx, yy, dv, cmap=\"RdBu\", alpha=.5)\n",
    "\n",
    "sct.add_boundary(syn.get_labels)\n",
    "sct.add_boundary(baseline_mesh.predict)\n",
    "plt.colorbar(im)\n",
    "sct.show(scatter=False, title=\"Memorization on mesh grid only\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ace20b4f-ea04-4198-8a6b-539b14ad30fc",
   "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
}
