{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "0bcc30f5-8177-4caf-9894-76de754c393a",
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "\n",
    "# use a GPU if available\n",
    "device = torch.device(\"cuda\" if torch.cuda.is_available() else \"cpu\")\n",
    "\n",
    "# Set default tensor type to float64\n",
    "torch.set_default_dtype(torch.float64)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "9b7b4f18-d992-4286-a5d0-fa18d5da7d0d",
   "metadata": {},
   "outputs": [],
   "source": [
    "from botorch.utils.sampling import draw_sobol_samples\n",
    "from botorch.optim import optimize_acqf\n",
    "import matplotlib.pyplot as plt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "b158fa1e-65e4-424f-aaf1-6b05df410072",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<torch._C.Generator at 0x10a88a030>"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "seed = 123\n",
    "# Set the seed for reproducibility\n",
    "torch.manual_seed(seed)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "f362fb7c-b9ec-4dfe-9c9a-7f9bcf91643e",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/qianxie/Desktop/Curriculum/Graduate/Research/PandoraBayesOpt/pandorabayesopt_env/lib/python3.9/site-packages/botorch/models/utils/assorted.py:174: InputDataWarning: Input data is not contained to the unit cube. Please consider min-max scaling the input data.\n",
      "  warnings.warn(msg, InputDataWarning)\n",
      "/Users/qianxie/Desktop/Curriculum/Graduate/Research/PandoraBayesOpt/pandorabayesopt_env/lib/python3.9/site-packages/botorch/models/utils/assorted.py:194: UserWarning: std(): degrees of freedom is <= 0. Correction should be strictly less than the reduction factor (input numel divided by output numel). (Triggered internally at /Users/runner/work/pytorch/pytorch/pytorch/aten/src/ATen/native/ReduceOps.cpp:1760.)\n",
      "  Ymean, Ystd = torch.mean(Y, dim=-2), torch.std(Y, dim=-2)\n",
      "/Users/qianxie/Desktop/Curriculum/Graduate/Research/PandoraBayesOpt/pandorabayesopt_env/lib/python3.9/site-packages/botorch/models/utils/assorted.py:202: InputDataWarning: Input data is not standardized (mean = tensor([0.5413]), std = tensor([nan])). Please consider scaling the input to zero mean and unit variance.\n",
      "  warnings.warn(msg, InputDataWarning)\n"
     ]
    }
   ],
   "source": [
    "import torch\n",
    "import gpytorch\n",
    "from botorch.models import SingleTaskGP\n",
    "from gpytorch.likelihoods import FixedNoiseGaussianLikelihood\n",
    "from gpytorch.means import ConstantMean\n",
    "from gpytorch.kernels import MaternKernel, ScaleKernel\n",
    "\n",
    "# Example Usage for 1D\n",
    "dim = 1\n",
    "\n",
    "# Define your kernel\n",
    "nu = 2.5\n",
    "lengthscale = 0.1\n",
    "outputscale = 1.0\n",
    "base_kernel = MaternKernel(nu=nu).double()\n",
    "base_kernel.lengthscale = torch.tensor([[lengthscale]])\n",
    "scale_kernel = ScaleKernel(base_kernel).double()\n",
    "scale_kernel.outputscale = torch.tensor([[outputscale]])\n",
    "\n",
    "# Define Noise Level\n",
    "noise_level = 1e-4\n",
    "\n",
    "# Initialize Placeholder Data with Correct Dimensions\n",
    "num_samples = 1  # Replace with actual number of samples\n",
    "num_features = 1  # Replace with actual number of features\n",
    "train_X = torch.empty(num_samples, num_features)  # Placeholder data\n",
    "train_Y = torch.empty(num_samples, 1)             # Placeholder data\n",
    "Yvar = torch.ones(num_samples) * noise_level\n",
    "\n",
    "# Initialize Model\n",
    "model = SingleTaskGP(train_X, train_Y, likelihood = FixedNoiseGaussianLikelihood(noise=Yvar), covar_module=scale_kernel)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "bfac52a5-b57b-408a-9e0e-0d171c7ab72c",
   "metadata": {},
   "outputs": [],
   "source": [
    "from botorch.sampling.pathwise import draw_kernel_feature_paths\n",
    "matern_sample = draw_kernel_feature_paths(model, sample_shape=torch.Size([1]))\n",
    "def objective_function(x):\n",
    "    return matern_sample(x).squeeze(0).detach()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "aa29f0b6",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 1000x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "import torch\n",
    "\n",
    "# Set global font properties\n",
    "plt.rcParams['font.family'] = 'serif'\n",
    "plt.rcParams['font.serif'] = 'Times New Roman'\n",
    "plt.rcParams['xtick.labelsize'] = 40\n",
    "plt.rcParams['ytick.labelsize'] = 40\n",
    "\n",
    "# Generate test data\n",
    "test_x = torch.linspace(0, 1, 1001)\n",
    "y_values = objective_function(test_x.view(-1, 1)).detach().cpu().numpy()\n",
    "\n",
    "# Plot setup\n",
    "plt.figure(figsize=(10, 6))\n",
    "plt.plot(test_x.cpu().numpy(), y_values, color='tab:grey', label=\"Objective function\", alpha=0.6)\n",
    "\n",
    "# Grid setup\n",
    "grid_density = 40\n",
    "x_grid = np.linspace(0, 1, grid_density)\n",
    "y_grid = np.linspace(min(y_values), max(y_values), grid_density)\n",
    "\n",
    "# Analyze each grid cell\n",
    "for i in range(len(x_grid) - 1):\n",
    "    for j in range(len(y_grid) - 1):\n",
    "        # Define cell corners\n",
    "        x0, x1 = x_grid[i], x_grid[i + 1]\n",
    "        y0, y1 = y_grid[j], y_grid[j + 1]\n",
    "\n",
    "        # Sample the function within the cell\n",
    "        x_sample = np.linspace(x0, x1, 10)\n",
    "        y_sample = objective_function(torch.tensor(x_sample).view(-1, 1)).detach().cpu().numpy()\n",
    "\n",
    "        # Check if any part of the function is within this cell's y range\n",
    "        if np.any((y_sample >= y0) & (y_sample <= y1)):\n",
    "            plt.fill_between([x0, x1], y0, y1, color='grey', alpha=0.2, edgecolor='none')\n",
    "\n",
    "# Draw vertical grid lines only\n",
    "for x_line in x_grid:\n",
    "    plt.axvline(x=x_line, color='black', linestyle='-', linewidth=0.5, alpha=0.5)\n",
    "\n",
    "# Adjust margins on the x-axis\n",
    "plt.margins(x=0.025)  # Adjust the margin to be narrower\n",
    "\n",
    "plt.xticks([])\n",
    "plt.yticks([])\n",
    "\n",
    "# Get the current Axes object\n",
    "ax = plt.gca()\n",
    "\n",
    "# Customize spines to make them less obvious\n",
    "ax.spines['top'].set_color('lightgrey')\n",
    "ax.spines['top'].set_linewidth(0.5)\n",
    "ax.spines['right'].set_color('lightgrey')\n",
    "ax.spines['right'].set_linewidth(0.5)\n",
    "ax.spines['left'].set_color('lightgrey')\n",
    "ax.spines['left'].set_linewidth(0.5)\n",
    "ax.spines['bottom'].set_color('lightgrey')\n",
    "ax.spines['bottom'].set_linewidth(0.5)\n",
    "\n",
    "plt.savefig('plot/objective_discrete.pdf', format='pdf')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "84d53710",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 1000x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Plot setup\n",
    "plt.figure(figsize=(10, 6))\n",
    "plt.plot(test_x.cpu().numpy(), y_values, color='tab:grey', label=\"Objective function\", alpha=0.6)\n",
    "plt.xticks([])\n",
    "plt.yticks([])\n",
    "\n",
    "# Get the current Axes object\n",
    "ax = plt.gca()\n",
    "\n",
    "# Customize spines to make them less obvious\n",
    "ax.spines['top'].set_color('lightgrey')\n",
    "ax.spines['top'].set_linewidth(0.5)\n",
    "ax.spines['right'].set_color('lightgrey')\n",
    "ax.spines['right'].set_linewidth(0.5)\n",
    "ax.spines['left'].set_color('lightgrey')\n",
    "ax.spines['left'].set_linewidth(0.5)\n",
    "ax.spines['bottom'].set_color('lightgrey')\n",
    "ax.spines['bottom'].set_linewidth(0.5)\n",
    "\n",
    "plt.savefig('plot/objective_continuous.pdf', format='pdf')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "8c73424a",
   "metadata": {},
   "outputs": [],
   "source": [
    "def plot_posterior(objective_function,model,test_x,train_x,train_y):\n",
    "    \n",
    "    with torch.no_grad():\n",
    "        \n",
    "        # # Plot the objective function at the test points\n",
    "        plt.plot(test_x.cpu().numpy(), objective_function(test_x.view(-1,1)).detach().numpy(), 'tab:grey', alpha=0.6)\n",
    "    \n",
    "        # Calculate the posterior at the test points\n",
    "        posterior = model.posterior(test_x.unsqueeze(1).unsqueeze(1))\n",
    "\n",
    "        # Get upper and lower confidence bounds (2 standard deviations from the mean)\n",
    "        lower, upper = posterior.mvn.confidence_region()\n",
    "        lower = lower.squeeze(-1).squeeze(-1)\n",
    "        upper = upper.squeeze(-1).squeeze(-1)\n",
    "        # Plot training points as black stars\n",
    "        plt.plot(train_x.cpu().numpy(), train_y.cpu().numpy(), 'k*', alpha=0.8, markersize=10)\n",
    "        # Plot posterior means as blue line\n",
    "        plt.plot(test_x.cpu().numpy(), posterior.mean.squeeze(-1).squeeze(-1).cpu().numpy(), alpha=0.8)\n",
    "        # Shade between the lower and upper confidence bounds\n",
    "        plt.fill_between(test_x.cpu().numpy(), lower.cpu().numpy(), upper.cpu().numpy(), alpha=0.2)\n",
    "        plt.axis(\"off\")\n",
    "        \n",
    "    \n",
    "    # Define legend labels\n",
    "    legend_labels = ['Objective Function', 'Observed Data', 'Prediction', 'Confidence']\n",
    "    # Add legend to the axis\n",
    "    # plt.legend(legend_labels, fontsize=24, loc='lower right')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "b92ca78f",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/qianxie/Desktop/Curriculum/Graduate/Research/PandoraBayesOpt/pandorabayesopt_env/lib/python3.9/site-packages/botorch/models/utils/assorted.py:202: InputDataWarning: Input data is not standardized (mean = tensor([0.0413]), std = tensor([0.7097])). Please consider scaling the input to zero mean and unit variance.\n",
      "  warnings.warn(msg, InputDataWarning)\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 1000x800 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "from botorch.utils.sampling import draw_sobol_samples\n",
    "from pandora_bayesopt.utils import fit_gp_model\n",
    "\n",
    "plt.rcParams['xtick.labelsize'] = 24\n",
    "plt.rcParams['ytick.labelsize'] = 24\n",
    "\n",
    "bounds = torch.stack([torch.zeros(dim), torch.ones(dim)])\n",
    "init_x = draw_sobol_samples(bounds=bounds, n=1, q=2*(dim+1)).squeeze(0)\n",
    "x = init_x\n",
    "y = objective_function(x)\n",
    "model = fit_gp_model(x, y, scale_kernel)\n",
    "# Plot the posterior\n",
    "plt.figure(figsize=(10, 8))\n",
    "plot_posterior(objective_function,model,test_x,x,y)\n",
    "plt.axis(\"off\")\n",
    "plt.savefig('plot/bayesopt.pdf', format='pdf')\n",
    "plt.show()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "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.9.18"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
