{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "otherwise-graduation",
   "metadata": {},
   "source": [
    "# Gaussian Process for OOD Estimation\n",
    "TODO: Use GP Classifier not regressor..."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "proud-visitor",
   "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",
    "\n",
    "from sklearn.gaussian_process import GaussianProcessRegressor"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "heated-termination",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(100, 2)\n",
      "(100,)\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAXIAAAD4CAYAAADxeG0DAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjQuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/Z1A+gAAAACXBIWXMAAAsTAAALEwEAmpwYAAAyA0lEQVR4nO3dd3yV1f3A8c+5I5OQRYBAgATCCHsKqDhRGQpWrQtxjyp11brqT2uHrVZtLXW0VBytCnVUUQsIqAgqIAEBJewdCJCEJGTnjvP74wkJmSS5z81zb/J9v1555Y7nOc/3Rvzec88953uU1hohhBDBy2Z1AEIIIXwjiVwIIYKcJHIhhAhyksiFECLISSIXQogg57Diop06ddLJyclWXFoI0VZ53XBkM2hv5QMKug0zfrcR69aty9FaJ9R+3JJEnpycTHp6uhWXFkK0VVrDq+fD0S2Agp7jYOZ/rY7KVEqpffU9bkkiF0II0ykFN/4PNn8INgcM+onVEbUaSeRCiLbDGQ7Dr7U6ilYnX3YKIUSQC5geucvlIjMzk7KyMqtDaTfCwsJISkrC6XRaHYoQwgcBk8gzMzOJiooiOTkZpdrOt8yBSmtNbm4umZmZpKSkWB2OEMIHATO0UlZWRnx8vCTxVqKUIj4+Xj4BCdEGBEwiBySJtzL5ewvRNgRUIhdCCNF8ksgr5efn8/LLL7fo3ClTppCfn9/k48vLy7nqqqtITU1l7Nix7N27t97jFi9eTP/+/UlNTeXpp5+u95gnn3yS7t27M3z4cIYPH87ChQurnvvjH/9Iamoq/fv357PPPmvOSxJCBBFJ5JUaS+Rut7vRcxcuXEhMTEyTrzV37lxiY2PZuXMn999/Pw8//HCdYzweD7NmzWLRokVkZGQwb948MjIy6m3v/vvvZ8OGDWzYsIEpU6YAkJGRwfz589m8eTOLFy/mrrvuwuPxNDlGIUTwkERe6ZFHHmHXrl0MHz6cBx98kOXLlzNhwgSmTZvGwIEDAbj00ksZNWoUgwYNYs6cOVXnJicnk5OTw969e0lLS+O2225j0KBBXHjhhZSWlta51oIFC7jhhhsAuOKKK/j888+pvVPTd999R2pqKr179yYkJISrr76aBQsWNPn1LFiwgKuvvprQ0FBSUlJITU3lu+++a8mfRggR4II6kS/NOMITC35kacYRn9t6+umn6dOnDxs2bODZZ58FYP369fz1r39l+/btALz22musW7eO9PR0Zs+eTW5ubp12duzYwaxZs9i8eTMxMTF88MEHdY45ePAgPXr0AMDhcBAdHV2nrZOPAUhKSuLgwYP1xv7iiy8ydOhQbr75ZvLy8pp9vhAByVUGix6C1ybDpnetjiagBW0iX5pxhHvmfc+/Vu3jnnnfm5LMazvttNNqzLGePXs2w4YNY9y4cRw4cIAdO3bUOSclJYXhw4cDMGrUqAbHv81y5513smvXLjZs2EBiYiIPPPCAX68n2gB3OZQXWR3FqS35P1j3Juz/Fj65Fw7IJ8qGBG0iX7kjm1KXMeZb6vKwcke26deIjIysur18+XKWLVvGqlWr2LhxIyNGjKh3DnZoaGjVbbvdXu/4evfu3Tlw4ABgjL8XFBQQHx/f4DFgLJjq3r17nba6dOmC3W7HZrNx2223VQ2fNPV80c5kfAxP94BnesGSx62OpnFZG8F90v9j2VutiyXABW0in9A3gXCnHYBwp50JfeuU6G2WqKgoCgsLG3y+oKCA2NhYIiIi2Lp1K6tXr27xtaZNm8abb74JwPvvv895551XZ073mDFj2LFjB3v27KGiooL58+czbdq0Om1lZWVV3f7www8ZPHhw1TXmz59PeXk5e/bsYceOHZx22mktjlm0ER/fbfTIvW74bg7k1VsVNTCMuhGcEeAIN6oZ9jmv5vMlx+Cju+Dfl8H+lv//2BYEzBL95rpgYBdmXzOClTuymdA3gQsGdvGpvfj4eM444wwGDx7M5MmTmTp1ao3nJ02axN///nfS0tLo378/48aNa/G1brnlFmbOnElqaipxcXHMnz8fgEOHDnHrrbeycOFCHA4HL774IhdddBEej4ebb76ZQYMG1WnroYceYsOGDSilSE5O5h//+AcAgwYN4sorr2TgwIE4HA5eeukl7HZ7i2MWbUSNDoOudT/AjJgBcSmQvQ1SJ0J0Us3n/zMTDqwBr8tI5PdugA6dLQnVaqr2bInWMHr0aF17Y4ktW7aQlpbW6rG0d/J3b2e2LYL3bgSPC868H84P8OGVxjyTDKXGl/uERMHMD6HHGEtD8jel1Dqt9ejajwdtj1wI0QL9J8OjB42hFWeY1dH4ZvAVsOEdY2u3sI7Qpe4n1vZCErkQ7Y3dYfwEu8l/gpQJUJxj7AYUEmF1RJZpA/81hRCmqCg2vlz017h51kYozoZeZ5rzacBmg4HTfW+nIV4PuEogNMp/1zCJJHIh2jtXGfz7J8YXhx06w82LITbZ3Gusegm++B0oO8T0hNuXgyP0lKdZJmsTvHkJVBQZs2WunhfQn2KCdvqhEMIkP7wHWd+D9kDhEVj2pPnX+OYFcJUaiTF/Pxxcb/41zLTwQSjLN75L2PcN7FzqW3set/FF87ZFRk/fZIH7FiOEaB3aW31bAf6YydYxCYpyAK+RHKO6mn8NM5k9vDT/GuMNQQPJZ8IMc0sOSI+8UmuWsV2xYgUjR47E4XDw/vvvN3jcunXrGDJkCKmpqdxzzz11CmsBvPHGGyQkJFSVsX311VernnvzzTfp27cvffv2rVqAJEQdQ6+EzoOMRTeRneD8J8y/xpVvQs9xENcHpr1ozA8PZFOehfBYsNkh5Szoe2HL2yovhF2fG99BuIph1zLzSyRorVv9Z9SoUbq2jIyMOo+1pj179uhBgwbV+5zL5TL9Whs3btQzZ87U7733XoPHjRkzRq9atUp7vV49adIkvXDhwjrHvP7663rWrFl1Hs/NzdUpKSk6NzdXHzt2TKekpOhjx47VOc7qv7sIEF6v1iV5Wns8vrd1PEvrvd9oXVboe1tW8ni0Li8yoR231n/sqfWvOxo/T/dq8d8ZSNf15FRTeuRKqfuVUpuVUj8qpeYppYJugmprlrFNTk5m6NCh2GwN//mzsrI4fvw448aNQynF9ddfz0cffdTk1/PZZ59xwQUXEBcXR2xsLBdccAGLFy9u+h9EtC9KQXiMMRPEF/u+hdkj4J0r4cXRUFy3QmjQsNkgJPLUx52yHTvc+Cn0HA89T4cbPvH971z7Er42oJTqDtwDjNZaDwbswNW+ttskWxfC/35p/PZRa5axbYqDBw+SlFS9JLmxMrQffPABQ4cO5YorrqgqlCVlbIUlVjxnTNkrL4TSfMj4yOqIfFNRDCueh6VPQkFmy9vpOsSYDXTzIuN2c5Uca7SUr1lvCw4gXCnlACKAQya127CtC+GDm2HtP43fJiTz2oKhjO0ll1zC3r172bRpExdccEHVhhVCWCIqEWxO47ayQaRvxewsN+8a+OoZ+HY2zDnXmKrZ2krz4eXx8Ml9DR7icyLXWh8EngP2A1lAgdZ6Se3jlFK3K6XSlVLp2dkmlJzd9YUxnQmM37u+8L3NWvxVxrYpunfvTmZmdQ+goTK08fHxVde89dZbWbduXdX5UsZWNMrrNT8xXfR76HUGRHSCkTMh7RJz28/aBC+Ogef6tc5mE/tXgafcmJrpKjamTra2/auqvyhtgBlDK7HAdCAF6AZEKqWuq32c1nqO1nq01np0QoIJ79J9zgNnuHHbGV63xGUztWYZ26ZITEykY8eOrF69Gq01//rXv5g+ve4qtpPL2H788cdVBbAuuugilixZQl5eHnl5eSxZsoSLLrrIrzGLIJK5Dv6UDH/oBh/ead6Uw/BYuGEBPLQLJj9jjL0f2WwsCNr3re/tz78WcrZD0RGjJG+h+RvK1JB0GthDjE8XznCI6VHz+X2rYPOHxlCSv8SmgG68Q2jG0MpEYI/WOltr7QL+C5xuQruNGzAFLn8Nxtxm/B4wxafmTi5j++CDD9Z5ftKkSbjdbtLS0njkkUd8KmO7du1akpKSeO+997jjjjtqlKc9MSwD8PLLL3PrrbeSmppKnz59mDx5cp22Zs+ezaBBgxg2bBizZ8/mjTfeACAuLo7HH3+cMWPGMGbMGJ544gni4uJaHLNoYz65B8oKjJ5mxgKj1+cPWZvg1YnGIqO3LoMtn/jW3olqh2Ak17J839prjNcL18w3pk2ijDe7I5urn1/5Z+M1LZgFf58AFSX+iaPzALj079BtRIOH+FzGVik1FngNGAOUAm9gTJH5W0PnSBnbwCF/93bqpXGQvcW4HRIJ175rLFQx24rn4Ms/GG8YAGnT4Kp/t7y9r1+A5U8bSbznOJjxvukzQABY/XdY+n+gHEa9c29ljzimF9y3ybj9fH8oPGzcDukA18wz5pz7kd/K2Gqt1yil3gfWA27ge2BO42cJISx18V/g7SuM3YJSJxrT4vyh61CjpoqrxBiaSPKxXviZ98GAqVB+HBJH+CeJF+fC0seNmu24aj7nOqnXHdcHirKNNymvB6JrDbu0IlOW6Gutfw382oy2hBCtoNd4eHiv8SVaeIz/rtPvQpjyHPz4gfEl6PhZvrfZqa/vbTTGW2s8WtmMmThKwaSnqx+/4nVjiOr4QTj7EUtXqwZUrRWtdZ29K4X/+DqsJoKc3enfJH7CiBnGj6sMsjYYPddA3pItqguMvQPWGNsmMvlPxmSK0CiIiKt53LX/sSbGWgImkYeFhZGbm0t8fLwk81agtSY3N5ewsKBbhCuCUVkB/ONsox65x2XUddEeuOC3RtLM2WHMROnUHz7/LeTthTPvNYZ9rHDh7+GM+4w3u7Boa2JohoBJ5ElJSWRmZmLKHHPRJGFhYTVWjwrhN1sXGon6xBizp9z4veRxo/rist8YS9kBPBXGz8F0uPMbiOttfjxer1G+t+iwsWVcdD1rLCI7mX9dPwmYRO50OmusohRCtCERcRg1cmtRylg16T5Rk0hh1HrFSOy5u/2TyBc9BBveNj4dfP0C3LPemAMfpKSMrRCimtdrzNX2ek99bHP0vRBGXQ9hMcbuQ7YQsIfCsGsqZ3tUpiKbHRxh4Ag3fncdZCTazx6D3F1Nv96eFbDqZcjeXv/zWz42Ph2cmFqYtcm312cxn+eRt0R988iFEBYrzjEW7xRkGisYb1kGkfF+ulYuuMuMIY38/fD+zcbsjzMfgNheRgwDLoaFD8D2z4xpkmEd4d6Np+45b/wPfHqfkaBtTmNbuYR+NY+Zdy3sXGYM8Tgj4e510DHRP6/VRH6bRy6EaCNWvWQkUK8L8g8Y9yf6YZMJqPkGEdMTbl1mrIw8ftBYdOMIMZ7bs9JI+GCsrMzeDj3H1m2vosQ4LiIONs47ab63MjZ1qJ3IL5sDy/9ovN7T7w6KJN4YSeRCCIOqNdLqj8U2DcnZCXMngrsCImLh9q+MLxuTJ8COyh65UnUTMsDW/xk9eu2BoddA99Gwf7Ux7m6z1182NrQDXPSU/19XK5FELoQwjJ8FWz8xkmp8Hxh3V+tde+XzRrlWNBRVwPdvGas4L/8nrH7FmPEy5tb6h1U+va+61/7je3DzMuNNKHMtDLu2/tID2z8zeuRRXeHiFwJ/D9FTkEQuRHt3+Adj3nbyBLhrjVEW2hlu/gbEjQnraMwt97pA2at35nGEGgm9MbaT0pgGnKFw7q8aPj7/ALx7g9FjVw7j9i2f+foKLCWzVoRozzb+B+ZeAB/+DF4aa8xYCYlo3SQOcPbDkDjUKBmbchaMvL7p5/7kH0bRKmU3Fhedagl/QWb1nHXthmPNmA0ToKRHLkR79u3s6g1aAHZ/CYMvb/04IuLgthZuDpNyFjyaaRSu8rqrP1E0pNtwiKwsEaC9MPrmll03gEgiF6I9i0+F7G3GkIb2Qkyy1RG1jFKw7g1Y/Ihx/6Lfw9if1X+sMxx+tgJ2LDESesqEVgvTXySRC9GeXfwXI4nn7ICxd0LSKKsjahl3OSx+uLpy4Wf/ByNvaLhnHhplzScPP5FELkR7FhEHV79jdRS+qSiBd2fWLT9bX0mANkoSuRAiuH37N2Ph0AnKbtQNd4Qa4+Xf/BUKs4yhls5tczcsSeRCiMBWnGNUSSw9Zsxu6T6y5vMlOUa1RACUMd9803xY9CCEdjRWeXpc8MMHxhJ/f5UdsJAkciFE4PK44ZXxUHTUuL/3a7h/c80NMU67Azb9x/iy9sROPlkbjfsnb86sFORsh8jxrfkKWoXMIxdCBK5v/1adxMH4YrYgs+YxnVLhvh/g+o+NjZHtocZURACUMdSibMZP5wH1X8fjhk/ug78MgQV3V+7XGTykRy6ECFxHN9e87wivf8FPWHT1kEt0d6PuChjj5BN+aSzhHzmz4cqJ6XNh43xjtecP7xk1XU6/27zX4WeSyIUQgWvkDbDlE6PyodZw7btGcm7MV3866Y6CAVOgy6DGz8nfX725hbvUuB9EJJELIcyVvc34gjJpTHU5WjCKcRUdqft4Y1ImGJUQszYa5Wtjk099To2547rxVZ4njLjOWFCkbMbY+sgbqp8rK4B9q4xrNzQ0YzFJ5EII86x91ViMY7MbQyC3LDU2MP7+LfjfL43HY1Pgts9P3bM+ofOA5iXQK16H+ddC+XE459GmbRXXOc3YXCJrk1H29kR98pJj8MrpUF5kzFO/9BUY/JOmx9JKJJELIczz1Z+qhyhydsDBddBzHCx/uvrxvD1GvfDeZ/snhh5j4MEdzT8vqmvdcra7voCy4+AqNu5/85eATOQya0UIYZ6orlStqPS6ITKh+vETG1d4PdChsyXhNVt0EtWbQTv9sxG0CaRHLoQwz0/fMHbrKTpqDGvE9zEev3wuvH8THD8EZz0YuCssi3MABQX74b2boKIIBkyFzHRI6A9T/2x1hPWSzZeFEAKM4Z+Vzxu3HWHGGPuJ2/dugqgu1sVWqaHNl00ZWlFKxSil3ldKbVVKbVFKtb2lU0KItquiGFY8Zyz191RUJ3EwVoSefN9Xe7+B5c/AnhWmNWnW0MpfgcVa6yuUUiFAhEntCiGE/yl7zV2RbHZjGzib3di4Ij7VnOvsXg7zrgZXmdHTv+ot6DvR52Z9TuRKqWjgLOBGAK11BVDR2DlCiDbG4zLmj3fsZpTGDTbOMJj2N/jkXiOhT38ZEocZY+Rdhpi39d32xdU7MrlLYdvCwEjkQAqQDbyulBoGrAPu1VoXm9C2ECLQVRTDnHPheKax+nLGe/XvXB/ohl0NQ68ybvtrz9Ke442FR65ScEZAr9NNadaMMXIHMBJ4RWs9AigGHql9kFLqdqVUulIqPTs724TLCiECwrZFRiGrimKjZOznv7U6opZTyr8bTw+cDlP/AoMugynPmbZLkRmJPBPI1Fqvqbz/PkZir0FrPUdrPVprPTohIcGEywohWkXRUXh9KjzfH1Y8X/f5sOjq28oenEMrrWn4NfDT12HEDNPeNHxO5Frrw8ABpVT/yofOBzJ8bVcIESA+uQcOrIbCw7DyOdj3bc3nUyfC8GshJBI6D4Qp9ST79i5vLxz+AbxevzRv1qyVu4G3K2es7AZuMqldIYTVCg5W74epbEZCP5lSMPU540fUtfoVWPak8bdLngDX/sf04RtT5pFrrTdUDpsM1VpfqrXOM6NdIUQAOOcRow54SBREdDJ64KLpvvyDUQ/dVQJ7Vxize0wmS/SFEI0bMBXuWgV5+6HHaGMIRTRdWHT1giKtIayj6ZeQollCiFP7/i14+zL4c5pRm1s03VVvGaV7I+Jh6vPGXHuTSY9cCNG47O2w6iVjnLysAP57G9z/o9VRBY9uw+HeDX69hPTIhRCN81TU/HLOIwu3A40kciFE47oMgrRLwB5i1AeZKtMLA40MrQghGqcUXDYHLvy9sf9laJRv7X3xFHw3B6J7wDXvQExPc+Jsx6RHLoRomg6dfU/i+1fDqhehLB+ObIYFPzcltPZOErkQovWUHKve8g1v5Y48wleSyIUQrafPuRCbbMxFd4TD+U9YHVGbIGPkQojW4wyH25fDkR+hQ1fomGh1RG2CJHIhROuyO6HbCKujaFNkaEUIIYKcJHIhhAhyksiFEO1LeaFRH9xPtcGtIGPkQoj2Y+/X8PZPjSqEicPghk/AEWJ1VD6THrkQov347FdGXXB3qTFzZtcXVkdkCknkQoj2wxkJnCgApo3pkG2AJHIhRPsxbTbE9ACbE4ZcBSlnWR2RKWSMXAjRfnTqC/f9YHUUppMeuRBCBDlJ5EIIEeQkkQshRJCTRC6EEEFOErkQQgQ5SeRCCBHkJJELIazThuqdWEkSuRCi9Xlc8M5V8Ls4mD0SCjKtjiioSSIXQrS+Hz+APSuM4lV5e2HJ41ZHFNRMS+RKKbtS6nul1KdmtSmEaKPc5YA2bmsvuMssDSfYmdkjvxfYYmJ7Qoi2avDlENcbHGEQFg3nSY/cF6bUWlFKJQFTgaeAX5jRphCiDQvtAHd8DYVZENkJHKFWRxTUzOqRvwA8BDT4FbRS6nalVLpSKj07O9ukywohgpbNBtHdJYmbwOdErpS6GDiqtV7X2HFa6zla69Fa69EJCQm+XlYIIUQlM3rkZwDTlFJ7gfnAeUqpt0xoVwghRBP4nMi11o9qrZO01snA1cAXWuvrfI5MCCFEk8g8ciGECHKm7hCktV4OLDezTSGEEI2THrkQQgQ5SeRCCBHkJJELIUSQk0QuhBBBThK5EEIEOUnkQggR5CSRCyFEkJNELoQQQU4SuRBCBDlJ5EIIEeRMXaIfLCrcXhZvPoxNwUWDuuK0y/uZECJ4tbtErrXmhte+Y2NmPgDvrj3Av24Za21QlV5duZu31+ynX5cOPPvTYXQMc1odkhAiCLS7rmhhuZu1e49RUuGhpMLDNztzKa3wWB0Wq3fn8vyS7ezJKeaLrUf59YLNVockhAgSbTKRv/TlToY8+RnnPrecnUeLajwXGeIgKsyBAhQQG+kkzGn9n+FgXilKGbddHs2enGJrAxJCBA3rM5jJtmQd58UvdlJY5mZvTjH3zf++xvN2m+I/d4znzL6dOKtfAvNvH486kUEtdE7/BCJC7HQItRPutHHHWb2tDkkIESTa3Bh5QakLW2Ve1kB+qavOMf26RPFvC8fFjx4v47q5a9h5tIhz+3fm7zNHEd8hlGW/OJvv9hwjuVMk/bpE1XtufkkFn2zKIjrcycVDErHZrH8TEkJYq80l8tG9YhnYrSObDx3H69U8OnmA1SHV8czirezKLsar4dtduXz4/UGuHN2DmIgQLhzUtcHzylweLv7b1+QUlmNTihXbs3nup8NaMXIhRCBqc4ncYbcx//bxbD9SSHxkCJ07hlkdUh2lLi9erwbAqzXHS11sPJBPr/gIYiJCGjxv59Ei8koqKHN7AVj0Q5YkciFE2xsjB2McPC2xY0AmcYD7J/alY7iTcKedrtFh/GPFLma8uoYznv6CHw8WNHheUmy4MV4EOGyK/l3rH34RQrQvbTKRB7q+XaJY86vzWXL/Wcw4rScFJS6Kyt0UV3h4efnOBs+LiQjhndvGcd6Azlw6ojuv3jCmFaMWQgSqNje0EizCnHZ6xEUQ1yEUu80GHg9Ou6JTh9BGzxvWI4bXbpQELoSoJj1yi/1kRHcmD+lKVJiDUb1ieeDC/laHJIQIMtIjt5jdpvjzlcOtDkMIEcSkR94K8ksqKHdbXwZACNE2SY/cj7xezax31rNsyxGcdhtv3HQap6XEWR2WEKKNkR65H63de4yvtmfj8mhKKjw89uEPVockhGiDJJH7kb3W8vna94UQwgw+J3KlVA+l1JdKqQyl1Gal1L1mBBZMtNYcK67A5fHWeHxUr1imDknEpqBjmINnLh9qUYRCiLZMaa19a0CpRCBRa71eKRUFrAMu1VpnNHTO6NGjdXp6uk/XDRQVbi8z565h/f48wkPszLttHIO6Rdc5xmlXAVFlUQgRvJRS67TWo2s/7vOXnVrrLCCr8nahUmoL0B1oMJG3JUszjvDDwQJcHo2r1M0v3t3AuJR4xvfpxKTBRgGsEIeMYAkh/MfUWStKqWRgBLCmnuduB24H6Nmzp5mXtVTtce8dR4rYdriId9MP4NXDmDKkG8u3HWXjgQLO7NuJUb1iLYpUCNFWmdZVVEp1AD4A7tNaH6/9vNZ6jtZ6tNZ6dEJCQtXj248U8l76gVbZEWfn0SLOf345w36zhH+s2GVKmxPTOnNGaidsCsKdNiqLGlLq8vLV9hw+3XSIO99azwvLtjPj1dWs359nynWFEOIEU3rkSiknRhJ/W2v936aet2Z3Lje+vhaljKJ+7/9sfJ3xZTPdM+97dmcXo4G/LN3OOf06+1xB0GG38c/rR1Ph9vLtzhzufHs9pS4P4U4bZ/XtxMIfD1PqMhYDVbi9fL0jh5E9pVcuhDCPGbNWFDAX2KK1/nNzzv1gfSalLmMT5NIKD899tq3RMq6+yi+pOFEFFrtSFNSze1BLhThsnDOgMy/NGMH143vxl6tGMHVoN8alxBHutBvH2G18sC6Tfo8tYtY763HXmuUihBAtYcbQyhnATOA8pdSGyp8pTTmxf5eoqiQH8M3OXH7691UszThiQlh1PTxpAKEOGxEhdtISOzKyZ0yjx/9r1V4m/OkLZs5dQ05ReZOucd6ALvx2+uCqLzqvG9eL/7s4jUuGJjKsRzSZ+aVUeLx8seUon2w65OtLEkIIU2atfI2xIX2z3XhGCrnFFXz4/UGOHC+jwuMFD7yzZh8XDOzia2h1TB/RndN6x3GsuIIBXTs2ukBnU2Y+f1y4lVKXh6z8Mh56f1OLyscqpZgxthczxvbi9n+l46kcRNdaU1Qu9VeEEL6zdF6c3aZ4aNIA/nDZEEIdRs88zGkjLbGj366ZGB3OoG7Rp1xlmVVQhq3yr+P2ag4cK/H52vdN7EdUqIOIEGNnoGnDugFQUuFm6+HjlFS4fb6GEKL9CYiiWef278zDk/vz4fqDjOgZy70T+1odEmekdiI2IgRFBW6v5q5z+vjc5sBuHVn1q/M5XFBGr/gInHYbB46VMO3Fr6nweAl12Pn452eQFBthwisQQrQXPq/sbIlgWdlZXO7mu73HSIoJp28X/+yP+dtPMnjj2z14NdgU3H5Wbx6ZnOaXawkhgpvfVna2ZZGhDs7t39mv14gOd+Cw2yqX8duIDnf69XonbDyQz7bDhZyeGi+fAIQIcu0ikR8uKCO3uJz+XaJw2Jv/tcDRwjJ2HCliQNco4k+xp2ZzHMov5avt2SjAYVOM6x3PjaenmNZ+Qxb/mMX9/9kIGN9TLLxnAj3jJZkLEazafCL/36ZDPPDuRmw2Rf8uUbz7s/E4m5HMtx4+zuUvf4tNKVDw8c/PJKVTpCmx3Tv/ezYcyMerjS95H5uaRniI/dQn+ujt1furFimFOmx8vvUIN53h/zcQIYR/tPlqTs8s3kaZ20tJhYftRwpZu+dYs87/96p9FFd4KCx3U1Tm5t30A6bFllVQVrWk325THD3etLnqvhrYrSNhTuM/vU0pUjt3aJXrCiH8o80n8pgIZ9Ukd6+Gjs0cg06MCSO0snphqNNGt+gw02K7+7xUwpw2IkPsdIsOZ3Ry6yzd/8WF/bh6TE+G94jhsalpTOibcOqThBABq80n8heuGk5q5w50DHPw8/NSGdy9ebVcbpvQm0mDu9KlYyjThnXjmtMar9xY5vJQWNa0pf9XjenJP2aOIiLEzs6jRTz8wSa8Xt9nEZVUuDlcUEZDM5JCHXaenDaIj2adwXXjevl8PSGEtWT6YTO5PV5e+WoXmw8e56oxPTh3QPWsliWbD3P3vO/xeDXXje3Fk9MHVT33z5W7+OeKPSTFhvPSjJEkRocDcP3cNXy9MwevhogQO7OvHsFEH1a1frsrh1veSMerNeN6x/PajWNkizkh2oiGph+2+R75yQpKXFw/dw2nPbWMZxZtbbDH2pjnl2znpS93snjzYe58ex2bMvOrnnvkvz9Q7vbi9mrmp++vKs27KTOfPy/ZwdHCcjYcyOeBdzdWnVPm9nJyJ7zM7duy/V8v2Eypy0O520v63mOs3p3rU3tCiMDXrhL57/6XwarduRwtLOfNVXv5YuvRqueOFVew40hhVS2UE7xezbp9eWw+ZFRl/G7vMcpcRtVCBWw+VF16vcZObpULfAByisqrlvt7NRw+XlZ12K+mpNEh1EGYw0a/Lh2YmOZbjZlQZ/V/Ug1V4/tCiLarzU8/PNmh/FJcHiNRe7XmaKExS+Sr7dnc8e90FIr+XaN4947xhDhsaK352Vvr+HpnDlrDzPG9uGRYIhmHjlPh8aCUMff7hD9fOZw7/p2Oy6O56cwUesUb0xTH9+5EYnQ4WQWleLya+yf2qzpneI8Y1j42kdzicrpFh2PzcRjkT5cP4/rX1nCsuILLRnSXHYmEaAfa1Rj5NztzuPXNdOw2RUSIncX3nUVcZAgX/WUF244UAhAZYufFa0dy7oDOZBWUcs6zyyl3Gz1wu02x86nJfL7lKNuPFnJBWpc6S/c9Xo3b660qAnZCmcvDxgP5dI0Oq0rwZsouLCczr4S0xI6EOe14vdrnNwUhRGCRJfoYhbCWPXA2+3KLGdI9mqgwYypix3CHsUuRBi/QIcz4s3QIddSozxsT7kQpxcSBXRr8QtJuU9htdRf1hDntjD2p926m1btzuen1tdhtitgIJ5/eM6HVlvoLIazX7gZQu8eEc3qfTlVJHOBPVwwjOT6ScKedmeN6MbpyOCIqzMnL140kKTac1ITIFtUjbw0vLNtBqctDUbmbnKIKPtt82OqQhBCtqF31yBuS0imSL395Tr3PnTegC+cNMH+TCzMlRIXgsCncXo1SEBcRYnVIQohWJIm8Dfj1JYM4lFfGzuwiLhvZnfPT/FuxUQgRWCz5sjO6xwC9ctVqhibFtPq1A0W520NesYvOUaHypaQQokkCakFQmdvDDa9916IFOS2xK7uIF5Zu5/11mXWWwH+35xhPL9rS7HHlz7cc4XefZvDlSXPRm2rr4eOc9tTnnP3sl1z60jeUuWTvTiFEy1k2tFJQ6sKrwe7nzujhgjKmv/gNJRVuQh1GTZNHJg8AYN2+PK5/bQ1lLi/hTju/v3Qwl49KOmWbSzOOcPe89ZS5vLyzZh8vzxhVY6n+qTy9aCsFpUY9lh3ZRXy6KYsrmnBdIYSojyU9cptSXDe2V6vUANlwIA8wVlSWujwsOannvXp3LhWVc8RLXR5e/2YP3+7KOWWbX207WrW6s9TlZeWO7GbFFOKwVa36VIDT3+9mQog2zZJEntIpkt+cVFDKnwYmRlctuw9z2BjbO4730g/wwtLtJEaH1VjCvu1IIbe8kc7cr/c02uaZfTsRXrkUPtxp5/Q+nZoV0+NTB9I9Jhyl4PQ+8UwdktjMVyWEENXaxcrOdfvyeGfNPpLjI8krqWDedwcod3uICHHwm+mDeG3lHraeVGelb+cOLP3F2Y22ueiHLFbuzOHsfglcNKhri+KS1ZdCiOZo1ys7R/WKrao5cs6zX1ZtcwawL6eYHdnVSdxhU6Qldjxlm5OHJDLZx560JHEhhBnaRSIvKHGxbMsRukaHMa53PIePl1Hm8uLxavbkllDhrv5U0qdzJH+4bAjLMg7zi3c34tGam8ancG5aAiN7xqKUJF8hRGBp84m8uNzNpL+uqJolcuuZKcw6J5W9ucXMGNeLfTnFLMs4QqnLQ7jTzn3n9yPCaefn876v+kLzxeU7mfvNbi4bmcRTPxnS7BhKKtz89pMMth0p5MbxyUwf0d3U1yiEaN/afCLfcCCfwjI3JRXGcMq76Zms/tX5Vc+P6BFDhcfLV9uzmTigC5OHJOL2eKvK3Z5Q6vIy77v9/Hb64GbPtvn1gs0s2HiICreXrVk/kJIQ2a4XQwkhzGXKrBWl1CSl1Dal1E6l1CNmtGmWnnERuL1Gz9phU/TtUnPHeKUUV43pycszRnFZ5Vxuh93GLyb2I6TWpgzR4U5aMqydkXW8apqjUrA7u7gFr0QIIerncyJXStmBl4DJwEDgGqXUQF/bNUuPuAhemTGKkT1jmTykK7OvHtGk82adl8rKh87lb9cMp09CJGmJUfz7lrEtGiO/bmxPwp12wp12Quw2Tk+tWc72uz3HeGbR1hpz3IUQoql8nn6olBoPPKm1vqjy/qMAWus/NnROMG++3FJr9x5jT04x5/RLoHPHsKrH1+3LY8arq6tWlz71k8FcNlJWeQoh6vJnrZXuwIGT7mdWPlY7gNuVUulKqfTs7OathPSHNbtzueKVb7nljbVkFZT6/XpjkuO4cnSPGkkcYNWunBqrS5dmHPF7LEKItqXVVnZqredorUdrrUcnJCS01mXrlVdcwY2vryV9Xx5fbjvKzW+stSyWkb1iq8biw512zuzbvFWiQghhxqyVg0CPk+4nVT4WsA4fL6va8d6rYV9uiWWxnN6nEy9dO5LFPx5mTHIcPx0twypCiOYxI5GvBfoqpVIwEvjVwLUmtOs3qZ07kBQbTmaeMaQyZXAihWWuGtu/tabz07pwflpg70IkhAhcPg+taK3dwM+Bz4AtwLta682+tutPTruNj2adwR9/MoSB3Try8caDjP79MtnrUggRlExZEKS1XggsNKOt1hIR4qB3QgcyDh2nwqMBzRMLfmxxASwhhLCKJWVsA0Wo04b3pOmXYU57i9rxerXs8iOEsEy7TuT9ukRx65m9cdgUsRFOXrhqeLPb2HyogJG/W8rAJxYz6+31dbaSE0IIf2vztVZO5ZcX9eeBC/u1uKrhYx/+SH5lQa4vtx3l6505nNXP2umVQoj2pV33yE/wpTTtyUMzqtZ9IYRoDZLIffS76YOJCnPgsCnG9YlnQl/pjQshWle7H1rx1bAeMax//AJKKjxEh1szD10I0b5JIjeB024jOlw+3AghrNGuE/menGJe+3o3sREh3HVuaoumHxaVu/khs4Be8RF0iwn3Q5RCCNG4dpvIC0pdTJ29smrnoI82HGLFQ+c2q4284gom/XUFxeUePF4vc28Yw+mpUvRKCNG62u14wO7soqokDrD/WAn7cpu3c89nmw9TUOqiqNxNqcvL377YaXaYQghxSu02kffp3IGTJx3aFCiaNw0xISoUW+XURadN0S0m7BRnCCGE+dptIu8Y5uTpy4dgV8b871sn9KZnfESz2jhvQGeuH59MQlQoY3vH8/jFAbPDnRCiHfF5q7eWCKSt3jxejcvjbXGdFSGEaC0NbfXWbr/sPMFuU9htksSFEMGr3Q6tCCFEWyGJXAghgpwk8nbA69VSXleINkwSeRv39up99H98EWlPLObTjYesDkcI4QeSyNuwonI3T36yGZdHU+728sB7G6VnLkQbJIm8DfN4NbqR+0KItkESeRsWHe7k5+em4rQrnHbF4xcPxG5r+SYaQojA1O7nkbd1903sx02np6BsxmpWIUTbI4m8HYiOkAQuRFsmQytCCBHkJJELIUSQk0QuhBBBThK5EEIEOZ8SuVLqWaXUVqXUJqXUh0qpGJPiEkII0US+9siXAoO11kOB7cCjvockhBCiOXxK5FrrJVprd+Xd1UCS7yEJIYRoDjPHyG8GFjX0pFLqdqVUulIqPTs728TLCiFE+3bKBUFKqWVA13qeekxrvaDymMcAN/B2Q+1orecAc8DY6q1F0QohhKjjlIlcaz2xseeVUjcCFwPnays2ABVCiHbO11krk4CHgGla6xJzQgosR46X8e2uHApKXVaHIoQQ9fK11sqLQCiwVCkFsFpr/TOfowoQ3+/PY8ara7ArhcOuWHjvBBKjw60OSwghavApkWutU80KJBD9c+VuSio8ADjtio83HOKOs/tYHJUQQtSkrBjWVkplA/tOeqgTkNPqgfhGYm4dEnPrkJhbh68x99JaJ9R+0JJEXicIpdK11qOtjqM5JObWITG3Dom5dfgrZqm1IoQQQU4SuRBCBLlASeRzrA6gBSTm1iExtw6JuXX4JeaAGCMXQgjRcoHSIxdCCNFCksiFECLIBUwiD5ZNKpRSk5RS25RSO5VSj1gdz6kopXoopb5USmUopTYrpe61OqamUkrZlVLfK6U+tTqWplBKxSil3q/8d7xFKTXe6phORSl1f+W/ix+VUvOUUmFWx1QfpdRrSqmjSqkfT3osTim1VCm1o/J3rJUx1tZAzH7JcwGTyAmCTSqUUnbgJWAyMBC4Rik10NqoTskNPKC1HgiMA2YFQcwn3AtssTqIZvgrsFhrPQAYRoDHrpTqDtwDjNZaDwbswNXWRtWgN4BJtR57BPhca90X+LzyfiB5g7ox+yXPBUwiD5JNKk4Ddmqtd2utK4D5wHSLY2qU1jpLa72+8nYhRnLpbm1Up6aUSgKmAq9aHUtTKKWigbOAuQBa6wqtdb6lQTWNAwhXSjmACOCQxfHUS2u9AjhW6+HpwJuVt98ELm3NmE6lvpj9lecCJpHX0ugmFRbqDhw46X4mQZAUT1BKJQMjgDUWh9IUL2BU1vRaHEdTpQDZwOuVw0GvKqUirQ6qMVrrg8BzwH4gCyjQWi+xNqpm6aK1zqq8fRjoYmUwLWBanmvVRK6UWlY5Flf7Z/pJx5xykwrRfEqpDsAHwH1a6+NWx9MYpdTFwFGt9TqrY2kGBzASeEVrPQIoJvA+6tdQOaY8HeNNqBsQqZS6ztqoWqZyL4SgmUttdp7ztYxts7SBTSoOAj1Oup9U+VhAU0o5MZL421rr/1odTxOcAUxTSk0BwoCOSqm3tNaBnGQygUyt9YlPO+8T4IkcmAjs0VpnAyil/gucDrxlaVRNd0Qplai1zlJKJQJHrQ6oKfyR5wJmaCVINqlYC/RVSqUopUIwvhj62OKYGqWMQvFzgS1a6z9bHU9TaK0f1Vonaa2TMf7GXwR4EkdrfRg4oJTqX/nQ+UCGhSE1xX5gnFIqovLfyfkE+Be0tXwM3FB5+wZggYWxNIm/8lzArOxUSu3E2KQit/KhgNykorKX+ALGN/yvaa2fsjaiximlzgRWAj9QPd78K631Quuiajql1DnAL7XWF1scyikppYZjfDkbAuwGbtJa51ka1CkopX4DXIXxMf974Fatdbm1UdWllJoHnINRBvYI8GvgI+BdoCdGWewrtda1vxC1TAMxP4of8lzAJHIhhBAtEzBDK0IIIVpGErkQQgQ5SeRCCBHkJJELIUSQk0QuhBBBThK5EEIEOUnkQggR5P4fKzM1GuN24nkAAAAASUVORK5CYII=\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",
    "print(data.shape)\n",
    "print(labels.shape)\n",
    "\n",
    "sct = decision_boundary.Scatter2D(data, labels)\n",
    "sct.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "metric-travel",
   "metadata": {},
   "outputs": [],
   "source": [
    "X_train, X_test, y_train, y_test = train_test_split(data, labels, test_size=0.33, random_state=42)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "enhanced-mistake",
   "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, X_test, y_test, x_lim=(-10, 20), y_lim=(-10, 20),)\n",
    "sct.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "9ceb18af-eb5f-4cb4-8b5b-a502e8097a8c",
   "metadata": {},
   "outputs": [],
   "source": [
    "gp = GaussianProcessRegressor()\n",
    "gp.fit(X_train, y_train)\n",
    "\n",
    "y_hat, y_std = gp.predict(X_test, return_std=True)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "amateur-emerald",
   "metadata": {},
   "source": [
    "# Meshgrid with multiple points"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "variable-costs",
   "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(X_mesh)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "bba59542-6ae0-419a-ba2c-5871b911d248",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(1225,)\n"
     ]
    }
   ],
   "source": [
    "y_hat, ood = gp.predict(X_mesh, return_std=True)\n",
    "print(ood.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "380cb785-c466-4502-ace3-d3a8d3fc74a0",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Wrapper to get binary predictions from gp regressor\n",
    "gp_clf = lambda x: (gp.predict(x)<.5).astype(int)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "engaging-advocacy",
   "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": [
    "sct = decision_boundary.Scatter2D(X_mesh, X_mesh, \n",
    "                                  x_lim=(-10, 20), y_lim=(-10, 20))\n",
    "\n",
    "ood = np.asarray(ood).reshape(xx.shape)\n",
    "im = plt.contourf(xx, yy, ood, cmap=\"RdBu\", alpha=.5)\n",
    "\n",
    "\n",
    "sct.scatter(X_train, y_train)\n",
    "plt.colorbar(im)\n",
    "sct.add_boundary(syn.get_labels)\n",
    "sct.add_boundary(gp_clf)\n",
    "sct.show(scatter=False, title=\"Gaussian Process\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "spanish-throw",
   "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
}
