{
 "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": "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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",
    "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": 8,
   "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": 9,
   "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
}
