{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "48aec4d9",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "ERROR! Session/line number was not unique in database. History logging moved to new session 392\n",
      "Iteration 1/30\n",
      "Next evaluation point: [0.2949465] with acquisition value: 1.6844937801361084\n",
      "Objective value at new point: [[-6.87677]]\n",
      "Iteration 0: 5.5152 seconds\n",
      "Iteration 2/30\n",
      "Next evaluation point: [0.5] with acquisition value: -1.9555559158325195\n",
      "Objective value at new point: [[1.]]\n",
      "Iteration 1: 3.9201 seconds\n",
      "Iteration 3/30\n",
      "Next evaluation point: [-0.40715587] with acquisition value: 1.6262749433517456\n",
      "Objective value at new point: [[-0.7900331]]\n",
      "Iteration 2: 4.0462 seconds\n",
      "Iteration 4/30\n",
      "Next evaluation point: [0.46263167] with acquisition value: 1.6721534729003906\n",
      "Objective value at new point: [[0.9999998]]\n",
      "Iteration 3: 5.7447 seconds\n",
      "Iteration 5/30\n",
      "Next evaluation point: [0.1141811] with acquisition value: 1.1401348114013672\n",
      "Objective value at new point: [[0.9425667]]\n",
      "Iteration 4: 5.3172 seconds\n",
      "Iteration 6/30\n",
      "Next evaluation point: [-0.31722984] with acquisition value: 1.082353949546814\n",
      "Objective value at new point: [[-4.527223]]\n",
      "Iteration 5: 6.0195 seconds\n",
      "Iteration 7/30\n",
      "Next evaluation point: [0.48119497] with acquisition value: 1.1064914464950562\n",
      "Objective value at new point: [[1.]]\n",
      "Iteration 6: 5.4591 seconds\n",
      "Iteration 8/30\n",
      "Next evaluation point: [0.12562795] with acquisition value: 1.1389667987823486\n",
      "Objective value at new point: [[0.9652847]]\n",
      "Iteration 7: 7.5779 seconds\n",
      "Iteration 9/30\n",
      "Next evaluation point: [-0.26534495] with acquisition value: 1.029177188873291\n",
      "Objective value at new point: [[-4.3699555]]\n",
      "Iteration 8: 4.6544 seconds\n",
      "Iteration 10/30\n",
      "Next evaluation point: [-0.5] with acquisition value: 1.0698941946029663\n",
      "Objective value at new point: [[0.8966644]]\n",
      "Iteration 9: 5.4284 seconds\n",
      "Iteration 11/30\n",
      "Next evaluation point: [0.40397134] with acquisition value: 1.1338748931884766\n",
      "Objective value at new point: [[0.99405825]]\n",
      "Iteration 10: 6.5357 seconds\n",
      "Iteration 12/30\n",
      "Next evaluation point: [-0.46952784] with acquisition value: 1.0143307447433472\n",
      "Objective value at new point: [[0.681371]]\n",
      "Iteration 11: 9.6157 seconds\n",
      "Iteration 13/30\n",
      "Next evaluation point: [0.43932307] with acquisition value: 1.025133728981018\n",
      "Objective value at new point: [[0.9999808]]\n",
      "Iteration 12: 2.7683 seconds\n",
      "Iteration 14/30\n",
      "Next evaluation point: [-0.14568768] with acquisition value: 0.9709340333938599\n",
      "Objective value at new point: [[-4.1005335]]\n",
      "Iteration 13: 4.3259 seconds\n",
      "Iteration 15/30\n",
      "Next evaluation point: [0.5] with acquisition value: 1.0049982070922852\n",
      "Objective value at new point: [[1.]]\n",
      "Iteration 14: 5.1498 seconds\n",
      "Iteration 16/30\n",
      "Next evaluation point: [0.353938] with acquisition value: 1.0014138221740723\n",
      "Objective value at new point: [[-0.1518904]]\n",
      "Iteration 15: 2.9608 seconds\n",
      "Iteration 17/30\n",
      "Next evaluation point: [0.08137605] with acquisition value: 1.0022778511047363\n",
      "Objective value at new point: [[0.7897575]]\n",
      "Iteration 16: 7.5797 seconds\n",
      "Iteration 18/30\n",
      "Next evaluation point: [0.49036914] with acquisition value: 1.0121456384658813\n",
      "Objective value at new point: [[1.]]\n",
      "Iteration 17: 5.5462 seconds\n",
      "Iteration 19/30\n",
      "Next evaluation point: [-0.07089268] with acquisition value: 0.9988818168640137\n",
      "Objective value at new point: [[-4.2132177]]\n",
      "Iteration 18: 5.1304 seconds\n",
      "Iteration 20/30\n",
      "Next evaluation point: [0.47107458] with acquisition value: 0.9983285665512085\n",
      "Objective value at new point: [[1.]]\n",
      "Iteration 19: 9.4642 seconds\n",
      "Iteration 21/30\n",
      "Next evaluation point: [-0.18476015] with acquisition value: 0.9992054104804993\n",
      "Objective value at new point: [[-3.2456317]]\n",
      "Iteration 20: 24.7437 seconds\n",
      "Iteration 22/30\n",
      "Next evaluation point: [0.45062256] with acquisition value: 0.9983724355697632\n",
      "Objective value at new point: [[0.99999785]]\n",
      "Iteration 21: 4.4783 seconds\n",
      "Iteration 23/30\n",
      "Next evaluation point: [-0.03854347] with acquisition value: 0.9997268319129944\n",
      "Objective value at new point: [[-2.8732576]]\n",
      "Iteration 22: 3.9026 seconds\n",
      "Iteration 24/30\n",
      "Next evaluation point: [0.09431244] with acquisition value: 0.9987107515335083\n",
      "Objective value at new point: [[0.87068504]]\n",
      "Iteration 23: 4.3362 seconds\n",
      "Iteration 25/30\n",
      "Next evaluation point: [0.1566373] with acquisition value: 0.9990310668945312\n",
      "Objective value at new point: [[0.99220985]]\n",
      "Iteration 24: 9.6530 seconds\n",
      "Iteration 26/30\n",
      "Next evaluation point: [-0.28015184] with acquisition value: 1.0273663997650146\n",
      "Objective value at new point: [[-4.643708]]\n",
      "Iteration 25: 7.0984 seconds\n",
      "Iteration 27/30\n",
      "Next evaluation point: [0.2524431] with acquisition value: 1.0022296905517578\n",
      "Objective value at new point: [[-0.77390456]]\n",
      "Iteration 26: 19.3950 seconds\n",
      "Iteration 28/30\n",
      "Next evaluation point: [-0.19411902] with acquisition value: 1.0582131147384644\n",
      "Objective value at new point: [[-3.1653895]]\n",
      "Iteration 27: 11.6526 seconds\n",
      "Iteration 29/30\n",
      "Next evaluation point: [-0.3846126] with acquisition value: 1.6864750385284424\n",
      "Objective value at new point: [[-1.7591202]]\n",
      "Iteration 28: 37.0513 seconds\n",
      "Iteration 30/30\n",
      "Next evaluation point: [0.25545084] with acquisition value: 2.0994937419891357\n",
      "Objective value at new point: [[-1.1337185]]\n",
      "Iteration 29: 22.1698 seconds\n",
      "Iteration 1/30\n",
      "Next evaluation point: [0.4057536] with acquisition value: 0.18968862295150757\n",
      "Objective value at new point: [[0.9953688]]\n",
      "Iteration 0: 3.8879 seconds\n",
      "Iteration 2/30\n",
      "Next evaluation point: [0.24791765] with acquisition value: 1.190082311630249\n",
      "Objective value at new point: [[-0.31335568]]\n",
      "Iteration 1: 3.1123 seconds\n",
      "Iteration 3/30\n",
      "Next evaluation point: [0.5] with acquisition value: 0.9919981360435486\n",
      "Objective value at new point: [[1.]]\n",
      "Iteration 2: 4.6734 seconds\n",
      "Iteration 4/30\n",
      "Next evaluation point: [0.34930354] with acquisition value: 1.0161664485931396\n",
      "Objective value at new point: [[-0.5846827]]\n",
      "Iteration 3: 3.6254 seconds\n",
      "Iteration 5/30\n",
      "Next evaluation point: [0.5] with acquisition value: 0.8946910500526428\n",
      "Objective value at new point: [[1.]]\n",
      "Iteration 4: 4.2167 seconds\n",
      "Iteration 6/30\n",
      "Next evaluation point: [0.4032821] with acquisition value: 0.9727474451065063\n",
      "Objective value at new point: [[0.9934646]]\n",
      "Iteration 5: 6.4297 seconds\n",
      "Iteration 7/30\n",
      "Next evaluation point: [0.46445984] with acquisition value: 1.1042351722717285\n",
      "Objective value at new point: [[0.9999999]]\n",
      "Iteration 6: 3.1723 seconds\n",
      "Iteration 8/30\n",
      "Next evaluation point: [0.4200947] with acquisition value: 1.0517665147781372\n",
      "Objective value at new point: [[0.9994655]]\n",
      "Iteration 7: 4.4277 seconds\n",
      "Iteration 9/30\n",
      "Next evaluation point: [-0.45657033] with acquisition value: 1.0619480609893799\n",
      "Objective value at new point: [[0.51381767]]\n",
      "Iteration 8: 3.9306 seconds\n",
      "Iteration 10/30\n",
      "Next evaluation point: [0.11735335] with acquisition value: 1.039197564125061\n",
      "Objective value at new point: [[0.9499146]]\n",
      "Iteration 9: 13.9589 seconds\n",
      "Iteration 11/30\n",
      "Next evaluation point: [0.11223385] with acquisition value: 1.0419104099273682\n",
      "Objective value at new point: [[0.93759423]]\n",
      "Iteration 10: 5.4631 seconds\n",
      "Iteration 12/30\n",
      "Next evaluation point: [0.17649022] with acquisition value: 1.0229482650756836\n",
      "Objective value at new point: [[0.99699295]]\n",
      "Iteration 11: 3.8464 seconds\n",
      "Iteration 13/30\n",
      "Next evaluation point: [0.47856477] with acquisition value: 1.0347201824188232\n",
      "Objective value at new point: [[1.]]\n",
      "Iteration 12: 3.0848 seconds\n",
      "Iteration 14/30\n",
      "Next evaluation point: [0.44853723] with acquisition value: 1.0179190635681152\n",
      "Objective value at new point: [[0.9999967]]\n",
      "Iteration 13: 7.0266 seconds\n",
      "Iteration 15/30\n",
      "Next evaluation point: [-0.44976428] with acquisition value: 1.0143003463745117\n",
      "Objective value at new point: [[0.40110427]]\n",
      "Iteration 14: 5.3343 seconds\n",
      "Iteration 16/30\n",
      "Next evaluation point: [0.15454939] with acquisition value: 1.017387866973877\n",
      "Objective value at new point: [[0.9913364]]\n",
      "Iteration 15: 6.6061 seconds\n",
      "Iteration 17/30\n",
      "Next evaluation point: [-0.49944723] with acquisition value: 1.0026562213897705\n",
      "Objective value at new point: [[0.8943573]]\n",
      "Iteration 16: 3.5517 seconds\n",
      "Iteration 18/30\n",
      "Next evaluation point: [-0.24045269] with acquisition value: 1.002644658088684\n",
      "Objective value at new point: [[-3.742259]]\n",
      "Iteration 17: 6.6013 seconds\n",
      "Iteration 19/30\n",
      "Next evaluation point: [0.5] with acquisition value: 1.0007907152175903\n",
      "Objective value at new point: [[1.]]\n",
      "Iteration 18: 8.1575 seconds\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration 20/30\n",
      "Next evaluation point: [-0.2631554] with acquisition value: 1.0024645328521729\n",
      "Objective value at new point: [[-4.31957]]\n",
      "Iteration 19: 4.2564 seconds\n",
      "Iteration 21/30\n",
      "Next evaluation point: [-0.1543212] with acquisition value: 1.001421332359314\n",
      "Objective value at new point: [[-3.8759332]]\n",
      "Iteration 20: 3.4738 seconds\n",
      "Iteration 22/30\n",
      "Next evaluation point: [-0.1504663] with acquisition value: 1.0028648376464844\n",
      "Objective value at new point: [[-3.9763918]]\n",
      "Iteration 21: 3.5193 seconds\n",
      "Iteration 23/30\n",
      "Next evaluation point: [0.3054538] with acquisition value: 0.9899977445602417\n",
      "Objective value at new point: [[-6.854715]]\n",
      "Iteration 22: 4.2403 seconds\n",
      "Iteration 24/30\n",
      "Next evaluation point: [0.03007608] with acquisition value: 1.5129634141921997\n",
      "Objective value at new point: [[-0.0390867]]\n",
      "Iteration 23: 8.1440 seconds\n",
      "Iteration 25/30\n",
      "Next evaluation point: [0.38670012] with acquisition value: 1.115626573562622\n",
      "Objective value at new point: [[0.9466206]]\n",
      "Iteration 24: 17.2644 seconds\n",
      "Iteration 26/30\n",
      "Next evaluation point: [0.49144682] with acquisition value: 1.0244632959365845\n",
      "Objective value at new point: [[1.]]\n",
      "Iteration 25: 8.7325 seconds\n",
      "Iteration 27/30\n",
      "Next evaluation point: [-0.05027003] with acquisition value: 1.0338011980056763\n",
      "Objective value at new point: [[-3.4168005]]\n",
      "Iteration 26: 16.5673 seconds\n",
      "Iteration 28/30\n",
      "Next evaluation point: [0.07587662] with acquisition value: 1.027074933052063\n",
      "Objective value at new point: [[0.7441138]]\n",
      "Iteration 27: 12.7027 seconds\n",
      "Iteration 29/30\n",
      "Next evaluation point: [0.39659736] with acquisition value: 1.3528130054473877\n",
      "Objective value at new point: [[0.9840732]]\n",
      "Iteration 28: 18.7816 seconds\n",
      "Iteration 30/30\n",
      "Next evaluation point: [0.30866158] with acquisition value: 1.0289466381072998\n",
      "Objective value at new point: [[-6.6211557]]\n",
      "Iteration 29: 14.3035 seconds\n",
      "Iteration 1/30\n",
      "Next evaluation point: [-0.09489844] with acquisition value: 1.087890625\n",
      "Objective value at new point: [[-4.711273]]\n",
      "Iteration 0: 1.6283 seconds\n",
      "Iteration 2/30\n",
      "Next evaluation point: [0.30846697] with acquisition value: 1.190177321434021\n",
      "Objective value at new point: [[-6.6381116]]\n",
      "Iteration 1: 4.3348 seconds\n",
      "Iteration 3/30\n",
      "Next evaluation point: [-0.24271424] with acquisition value: -0.40417468547821045\n",
      "Objective value at new point: [[-3.7995458]]\n",
      "Iteration 2: 1.5892 seconds\n",
      "Iteration 4/30\n",
      "Next evaluation point: [0.5] with acquisition value: -0.7403111457824707\n",
      "Objective value at new point: [[1.]]\n",
      "Iteration 3: 1.9043 seconds\n",
      "Iteration 5/30\n",
      "Next evaluation point: [0.5] with acquisition value: -0.5692837238311768\n",
      "Objective value at new point: [[1.]]\n",
      "Iteration 4: 2.1387 seconds\n",
      "Iteration 6/30\n",
      "Next evaluation point: [-0.5] with acquisition value: -0.2386263608932495\n",
      "Objective value at new point: [[0.8966644]]\n",
      "Iteration 5: 2.5459 seconds\n",
      "Iteration 7/30\n",
      "Next evaluation point: [0.5] with acquisition value: 0.030796822160482407\n",
      "Objective value at new point: [[1.]]\n",
      "Iteration 6: 3.2080 seconds\n",
      "Iteration 8/30\n",
      "Next evaluation point: [0.43549478] with acquisition value: 2.2216763496398926\n",
      "Objective value at new point: [[0.99996126]]\n",
      "Iteration 7: 14.6868 seconds\n",
      "Iteration 9/30\n",
      "Next evaluation point: [0.4870434] with acquisition value: 1.168565273284912\n",
      "Objective value at new point: [[1.]]\n",
      "Iteration 8: 3.9802 seconds\n",
      "Iteration 10/30\n",
      "Next evaluation point: [0.09109501] with acquisition value: 1.5397884845733643\n",
      "Objective value at new point: [[0.853613]]\n",
      "Iteration 9: 7.6736 seconds\n",
      "Iteration 11/30\n",
      "Next evaluation point: [-0.3928216] with acquisition value: 1.4869707822799683\n",
      "Objective value at new point: [[-1.384721]]\n",
      "Iteration 10: 9.8896 seconds\n",
      "Iteration 12/30\n",
      "Next evaluation point: [0.1811686] with acquisition value: 1.8448171615600586\n",
      "Objective value at new point: [[0.99726635]]\n",
      "Iteration 11: 15.2805 seconds\n",
      "Iteration 13/30\n",
      "Next evaluation point: [0.45761517] with acquisition value: 1.1191600561141968\n",
      "Objective value at new point: [[0.99999946]]\n",
      "Iteration 12: 4.0702 seconds\n",
      "Iteration 14/30\n",
      "Next evaluation point: [0.49224213] with acquisition value: 1.1165918111801147\n",
      "Objective value at new point: [[1.]]\n",
      "Iteration 13: 10.3853 seconds\n",
      "Iteration 15/30\n",
      "Next evaluation point: [0.08891896] with acquisition value: 1.0477930307388306\n",
      "Objective value at new point: [[0.8409931]]\n",
      "Iteration 14: 8.8885 seconds\n",
      "Iteration 16/30\n",
      "Next evaluation point: [0.0105047] with acquisition value: 1.4051005840301514\n",
      "Objective value at new point: [[-0.66414475]]\n",
      "Iteration 15: 12.6984 seconds\n",
      "Iteration 17/30\n",
      "Next evaluation point: [0.4100606] with acquisition value: 1.0366504192352295\n",
      "Objective value at new point: [[0.99750787]]\n",
      "Iteration 16: 5.4969 seconds\n",
      "Iteration 18/30\n",
      "Next evaluation point: [0.18619096] with acquisition value: 1.3240472078323364\n",
      "Objective value at new point: [[0.99701136]]\n",
      "Iteration 17: 20.0232 seconds\n",
      "Iteration 19/30\n",
      "Next evaluation point: [0.47021392] with acquisition value: 1.0079456567764282\n",
      "Objective value at new point: [[0.99999994]]\n",
      "Iteration 18: 5.9523 seconds\n",
      "Iteration 20/30\n",
      "Next evaluation point: [-0.24534985] with acquisition value: 1.0779354572296143\n",
      "Objective value at new point: [[-3.867403]]\n",
      "Iteration 19: 8.7032 seconds\n",
      "Iteration 21/30\n",
      "Next evaluation point: [0.13210289] with acquisition value: 1.016392707824707\n",
      "Objective value at new point: [[0.9741889]]\n",
      "Iteration 20: 7.7774 seconds\n",
      "Iteration 22/30\n",
      "Next evaluation point: [0.05201936] with acquisition value: 1.0024458169937134\n",
      "Objective value at new point: [[0.44050854]]\n",
      "Iteration 21: 3.6029 seconds\n",
      "Iteration 23/30\n",
      "Next evaluation point: [0.15463096] with acquisition value: 1.0147271156311035\n",
      "Objective value at new point: [[0.99137217]]\n",
      "Iteration 22: 9.2640 seconds\n",
      "Iteration 24/30\n",
      "Next evaluation point: [-0.3228405] with acquisition value: 1.0016080141067505\n",
      "Objective value at new point: [[-4.3944483]]\n",
      "Iteration 23: 6.5267 seconds\n",
      "Iteration 25/30\n",
      "Next evaluation point: [-0.07287464] with acquisition value: 1.1079421043395996\n",
      "Objective value at new point: [[-4.274117]]\n",
      "Iteration 24: 7.5714 seconds\n",
      "Iteration 26/30\n",
      "Next evaluation point: [0.21075477] with acquisition value: 0.9666702747344971\n",
      "Objective value at new point: [[0.9600366]]\n",
      "Iteration 25: 13.0120 seconds\n",
      "Iteration 27/30\n",
      "Next evaluation point: [0.03924392] with acquisition value: 1.0002638101577759\n",
      "Objective value at new point: [[0.18827748]]\n",
      "Iteration 26: 6.5499 seconds\n",
      "Iteration 28/30\n",
      "Next evaluation point: [-0.15786871] with acquisition value: 0.9999271631240845\n",
      "Objective value at new point: [[-3.7846828]]\n",
      "Iteration 27: 6.4614 seconds\n",
      "Iteration 29/30\n",
      "Next evaluation point: [-0.2734898] with acquisition value: 1.0007662773132324\n",
      "Objective value at new point: [[-4.5371356]]\n",
      "Iteration 28: 7.2798 seconds\n",
      "Iteration 30/30\n",
      "Next evaluation point: [0.16532522] with acquisition value: 1.0062594413757324\n",
      "Objective value at new point: [[0.9950108]]\n",
      "Iteration 29: 8.0133 seconds\n"
     ]
    }
   ],
   "source": [
    "# Botorch Knowledge Gradient testing\n",
    "import torch\n",
    "import time\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import warnings\n",
    "from botorch.models import SingleTaskGP\n",
    "from botorch.fit import fit_gpytorch_mll\n",
    "from botorch.acquisition import qKnowledgeGradient\n",
    "from botorch.optim import optimize_acqf\n",
    "from gpytorch.mlls import ExactMarginalLogLikelihood\n",
    "\n",
    "# Suppress all warnings\n",
    "warnings.filterwarnings('ignore')\n",
    "\n",
    "# Gaussian function\n",
    "def gaussian(x, mean, variance):\n",
    "    return (1.0 / np.sqrt(2 * np.pi * variance)) * np.exp(-0.5 * ((x - mean) ** 2) / variance)\n",
    "\n",
    "# Objective function to minimize\n",
    "def objective_function(x, a=0.3, b=0.05):\n",
    "    return -1 * gaussian(x, -0.3, 2*b**2) - 1 * gaussian(x, -0.1, 2*b**2) - 0.55 * gaussian(x, 0.3, 0.3*b**2) + 1\n",
    "\n",
    "# Convert data to PyTorch tensors\n",
    "def to_tensor(X):\n",
    "    return torch.tensor(X, dtype=torch.float).view(-1, 1)\n",
    "\n",
    "# Number of optimization iterations\n",
    "num_iterations = 30\n",
    "num_trials = 20\n",
    "all_min_KG = []\n",
    "\n",
    "for trial in range(num_trials):\n",
    "    np.random.seed(trial)\n",
    "    X_test_np = np.linspace(-0.5, 0.5, 500).reshape(-1, 1)\n",
    "    X_test = to_tensor(X_test_np)\n",
    "    train_indices = np.random.choice(X_test_np.shape[0], size=5, replace=False)\n",
    "    X_train_np = X_test_np[train_indices]\n",
    "    Y_train_np = objective_function(X_train_np)\n",
    "    X_train = to_tensor(X_train_np)\n",
    "    Y_train = to_tensor(Y_train_np)\n",
    "    min_KG = min(Y_train)\n",
    "\n",
    "    gp_model = SingleTaskGP(X_train, Y_train)\n",
    "    mll = ExactMarginalLogLikelihood(gp_model.likelihood, gp_model)\n",
    "    fit_gpytorch_mll(mll)\n",
    "\n",
    "\n",
    "    for iteration in range(num_iterations):\n",
    "        start = time.perf_counter()\n",
    "\n",
    "        # Use Knowledge Gradient (KG)\n",
    "        acquisition_func = qKnowledgeGradient(model=gp_model)\n",
    "\n",
    "        candidate, acq_value = optimize_acqf(\n",
    "            acq_function=acquisition_func,\n",
    "            bounds=torch.tensor([[-0.5], [0.5]]),\n",
    "            q=1,\n",
    "            num_restarts=100,\n",
    "            raw_samples=100,\n",
    "        )\n",
    "\n",
    "        next_point = candidate.detach().numpy()\n",
    "        next_value = objective_function(next_point)\n",
    "\n",
    "        print(f\"Iteration {iteration + 1}/{num_iterations}\")\n",
    "        print(f\"Next evaluation point: {next_point.ravel()} with acquisition value: {acq_value.item()}\")\n",
    "        print(f\"Objective value at new point: {next_value}\")\n",
    "\n",
    "        X_train = torch.cat([X_train, to_tensor(next_point)], dim=0)\n",
    "        Y_train = torch.cat([Y_train, to_tensor(next_value)], dim=0)\n",
    "        min_KG = np.concatenate((min_KG, min(Y_train)))\n",
    "\n",
    "        gp_model = SingleTaskGP(X_train, Y_train)\n",
    "        mll = ExactMarginalLogLikelihood(gp_model.likelihood, gp_model)\n",
    "        fit_gpytorch_mll(mll)\n",
    "\n",
    "        end = time.perf_counter()\n",
    "        print(f\"Iteration {iteration}: {end - start:.4f} seconds\")\n",
    "\n",
    "    all_min_KG.append(min_KG)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "fbbed0d3",
   "metadata": {},
   "outputs": [],
   "source": [
    "torch.save(all_min_KG, 'all_min_KG')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a53b7f47",
   "metadata": {},
   "outputs": [],
   "source": [
    "KG_mean = np.array(all_min_KG).mean(axis=0)\n",
    "KG_std = np.array(all_min_KG).std(axis=0)\n",
    "KG_lower_bound = KG_mean - KG_std/np.sqrt(20)\n",
    "KG_upper_bound = KG_mean + KG_std/np.sqrt(20)\n",
    "x_vals = list(range(len(KG_mean)))\n",
    "plt.plot(x_vals, KG_mean, label=\"KG\", color='green', linewidth=5)\n",
    "plt.plot(x_vals, KG_mean, label=\"KG\", color='green', linewidth=5)\n",
    "plt.plot(x_vals, KG_lower_bound, color='green', linewidth=1, linestyle=':')\n",
    "plt.plot(x_vals, KG_upper_bound, color='green', linewidth=1, linestyle=':')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "51c5c7e6",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "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
}
