{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import math\n",
    "import torch\n",
    "import gpytorch\n",
    "from matplotlib import pyplot as plt\n",
    "\n",
    "# Make plots inline\n",
    "%matplotlib inline"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "# We make an nxn grid of training points spaced every 1/(n-1) on [0,1]x[0,1]\n",
    "n = 40\n",
    "train_x = torch.zeros(pow(n, 2), 2)\n",
    "for i in range(n):\n",
    "    for j in range(n):\n",
    "        train_x[i * n + j][0] = float(i) / (n-1)\n",
    "        train_x[i * n + j][1] = float(j) / (n-1)\n",
    "# True function is sin( 2*pi*(x0+x1))\n",
    "train_y = torch.sin((train_x[:, 0] + train_x[:, 1]) * (2 * math.pi)) + torch.randn_like(train_x[:, 0]).mul(0.01)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "class GPRegressionModel(gpytorch.models.ExactGP):\n",
    "    def __init__(self, train_x, train_y, likelihood):\n",
    "        super(GPRegressionModel, self).__init__(train_x, train_y, likelihood)\n",
    "\n",
    "        # SKI requires a grid size hyperparameter. This util can help with that. Here we are using a grid that has the same number of points as the training data (a ratio of 1.0). Performance can be sensitive to this parameter, so you may want to adjust it for your own problem on a validation set.\n",
    "        grid_size = gpytorch.utils.grid.choose_grid_size(train_x,1.0)\n",
    "\n",
    "        self.mean_module = gpytorch.means.ConstantMean()\n",
    "        self.covar_module = gpytorch.kernels.ScaleKernel(\n",
    "            gpytorch.kernels.GridInterpolationKernel(\n",
    "                gpytorch.kernels.RBFKernel(), grid_size=grid_size, num_dims=train_x.shape[-1]\n",
    "            )\n",
    "        )\n",
    "\n",
    "    def forward(self, x):\n",
    "        mean_x = self.mean_module(x)\n",
    "        covar_x = self.covar_module(x)\n",
    "        return gpytorch.distributions.MultivariateNormal(mean_x, covar_x)\n",
    "\n",
    "\n",
    "likelihood = gpytorch.likelihoods.GaussianLikelihood()\n",
    "model = GPRegressionModel(train_x, train_y, likelihood)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "# this is for running the notebook in our testing framework\n",
    "import os\n",
    "smoke_test = ('CI' in os.environ)\n",
    "training_iterations = 2 if smoke_test else 30\n",
    "\n",
    "\n",
    "# Find optimal model hyperparameters\n",
    "model.train()\n",
    "likelihood.train()\n",
    "\n",
    "# Use the adam optimizer\n",
    "optimizer = torch.optim.Adam(model.parameters(), lr=0.1)  # Includes GaussianLikelihood parameters\n",
    "\n",
    "# \"Loss\" for GPs - the marginal log likelihood\n",
    "mll = gpytorch.mlls.ExactMarginalLogLikelihood(likelihood, model)\n",
    "\n",
    "for i in range(training_iterations):\n",
    "    optimizer.zero_grad()\n",
    "    output = model(train_x)\n",
    "    loss = -mll(output, train_y)\n",
    "    loss.backward()\n",
    "    optimizer.step()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x300 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x300 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x300 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Set model and likelihood into evaluation mode\n",
    "model.eval()\n",
    "likelihood.eval()\n",
    "\n",
    "# Generate nxn grid of test points spaced on a grid of size 1/(n-1) in [0,1]x[0,1]\n",
    "n = 10\n",
    "test_x = torch.zeros(int(pow(n, 2)), 2)\n",
    "for i in range(n):\n",
    "    for j in range(n):\n",
    "        test_x[i * n + j][0] = float(i) / (n-1)\n",
    "        test_x[i * n + j][1] = float(j) / (n-1)\n",
    "\n",
    "with torch.no_grad(), gpytorch.settings.fast_pred_var():\n",
    "    observed_pred = likelihood(model(test_x))\n",
    "    pred_labels = observed_pred.mean.view(n, n)\n",
    "\n",
    "# Calc abosolute error\n",
    "test_y_actual = torch.sin(((test_x[:, 0] + test_x[:, 1]) * (2 * math.pi))).view(n, n)\n",
    "delta_y = torch.abs(pred_labels - test_y_actual).detach().numpy()\n",
    "\n",
    "# Define a plotting function\n",
    "def ax_plot(f, ax, y_labels, title):\n",
    "    if smoke_test: return  # this is for running the notebook in our testing framework\n",
    "    im = ax.imshow(y_labels)\n",
    "    ax.set_title(title)\n",
    "    f.colorbar(im)\n",
    "\n",
    "# Plot our predictive means\n",
    "f, observed_ax = plt.subplots(1, 1, figsize=(4, 3))\n",
    "ax_plot(f, observed_ax, pred_labels, 'Predicted Values (Likelihood)')\n",
    "\n",
    "# Plot the true values\n",
    "f, observed_ax2 = plt.subplots(1, 1, figsize=(4, 3))\n",
    "ax_plot(f, observed_ax2, test_y_actual, 'Actual Values (Likelihood)')\n",
    "\n",
    "# Plot the absolute errors\n",
    "f, observed_ax3 = plt.subplots(1, 1, figsize=(4, 3))\n",
    "ax_plot(f, observed_ax3, delta_y, 'Absolute Error Surface')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "softgp",
   "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.12.4"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
