{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Bayesian Optimization on a Sphere Manifold $\\mathbb{S}^2$\n",
    "\n",
    "This notebooks illustrates the application of Bayesian optimization (BO) on a sphere manifold. \n",
    "To run it, you need to have [BoTorch](https://botorch.org/) installed.\n",
    "\n",
    "References:\n",
    "\n",
    "[1] N. Jaquier, V. Borovitskiy, A. Smolensky, A. Terenin, T. Asfour, and L. Rozo. Geometry-aware Bayesian Optimization in Robotics using Riemannian Matérn Kernels. In Conference on Robot Learning (CoRL), 2021. https://arxiv.org/pdf/2111.01460.pdf\n",
    "\n",
    "[2] N. Jaquier, L. Rozo, S. Calinon, and M. Bürger. Bayesian Optimization Meets Riemannian Manifolds in Robot Learning. In Conference on Robot Learning (CoRL), 2019. https://arxiv.org/pdf/1910.04998.pdf"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import random\n",
    "import torch\n",
    "import gpytorch\n",
    "import botorch\n",
    "import warnings"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO: Using numpy backend\n"
     ]
    }
   ],
   "source": [
    "import geometric_kernels.torch\n",
    "from geometric_kernels.spaces.hypersphere import Hypersphere\n",
    "from geometric_kernels.kernels.geometric_kernels import MaternKarhunenLoeveKernel\n",
    "from geometric_kernels.frontends.pytorch.gpytorch import GPytorchGeometricKernel"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "We first set the numpy and pytorch seeds for reproducibility."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "outputs": [],
   "source": [
    "seed = 1234\n",
    "random.seed(seed)\n",
    "np.random.seed(seed)\n",
    "torch.manual_seed(seed)\n",
    "torch.backends.cudnn.deterministic = True\n",
    "torch.backends.cudnn.benchmark = False"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "We initialize a sphere manifold $\\mathbb{S}^2$."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "dimension = 3\n",
    "hypersphere = Hypersphere(dim=dimension-1)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Define the function to optimize. \n",
    "\n",
    "Here we use the Ackley function (see, e.g., https://www.sfu.ca/~ssurjano/ackley.html).\n",
    "The function is defined on the tangent space of the base point $(1, 0, 0, ...)$ and projected to the manifold via the exponential map. The value of the function is therefore computed by projecting the point on the manifold to the tangent space of the base point and by computing the value of the Ackley function in this Euclidean space.\n",
    "This requires the logarithmic map on the sphere, also defined below."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "def logmap(x, x0):\n",
    "    \"\"\"\n",
    "    This function maps a point lying on the sphere manifold into the tangent space of a second point on the manifold.\n",
    "\n",
    "    Parameters\n",
    "    ----------\n",
    "    :param x: point on the sphere manifold\n",
    "    :param x0: basis point of the tangent space where x will be mapped\n",
    "\n",
    "    Returns\n",
    "    -------\n",
    "    :return: u: vector in the tangent space of x0\n",
    "    \"\"\"\n",
    "    if x0.ndim < 2:\n",
    "        x0 = x0[None]\n",
    "\n",
    "    if x.ndim < 2:\n",
    "        x = x[None]\n",
    "\n",
    "    theta = torch.arccos(torch.maximum(torch.minimum(torch.inner(x0, x), torch.ones(1)), -torch.ones(1)))\n",
    "    u = (x - x0 * torch.cos(theta)) * theta / torch.sin(theta)\n",
    "\n",
    "    u[:, torch.where(theta[0] < 1e-16)[0]] = 0.\n",
    "\n",
    "    return u\n",
    "\n",
    "def ackley_function_sphere(x):\n",
    "    # Data to numpy\n",
    "    if x.ndim < 2:\n",
    "        x = x[None]\n",
    "\n",
    "    # Dimension of the manifold\n",
    "    dimension = x.shape[-1]\n",
    "\n",
    "    # Projection in tangent space of the mean.\n",
    "    # The base is fixed at (1, 0, 0, ...) for simplicity. Therefore, the tangent plane is aligned with the axis x.\n",
    "    # The first coordinate of x_proj is always 0, so that vectors in the tangent space can be expressed in a dimension-1\n",
    "    # dimensional space by simply ignoring the first coordinate.\n",
    "    base = torch.zeros((1, dimension), dtype=x.dtype)\n",
    "    base[0, 0] = 1.\n",
    "    x_proj = logmap(x, base)[0]\n",
    "\n",
    "    # Remove first dim\n",
    "    x_proj_red = x_proj[1:]\n",
    "    reduced_dimension = dimension - 1\n",
    "\n",
    "    # Ackley function parameters\n",
    "    a = 20\n",
    "    b = 0.2\n",
    "    c = 2 * np.pi\n",
    "\n",
    "    # Ackley function\n",
    "    aexp_term = -a * torch.exp(-b * torch.sqrt(torch.sum(x_proj_red ** 2) / reduced_dimension))\n",
    "    expcos_term = - torch.exp(torch.sum(torch.cos(c * x_proj_red) / reduced_dimension))\n",
    "    y = aexp_term + expcos_term + a + np.exp(1.)\n",
    "\n",
    "    return y[None, None]\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Initialization"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Generate 5 random data locations on the sphere to be used as initial design for BO."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Inputs: tensor([[ 0.2453, -0.6197,  0.7455],\n",
      "        [-0.2639, -0.6081,  0.7487],\n",
      "        [ 0.8036, -0.5950,  0.0147],\n",
      "        [-0.8280,  0.4246,  0.3662],\n",
      "        [ 0.4219, -0.8945, -0.1478]], dtype=torch.float64)\n",
      "Outputs:  tensor([3.9497, 6.4574, 3.2544, 7.5566, 3.9296], dtype=torch.float64)\n"
     ]
    }
   ],
   "source": [
    "nb_data_init = 5\n",
    "\n",
    "x_data = torch.tensor(hypersphere.random_point(nb_data_init))\n",
    "y_data = torch.zeros(nb_data_init, dtype=torch.float64)\n",
    "for n in range(nb_data_init):\n",
    "    y_data[n] = ackley_function_sphere(x_data[n])\n",
    "\n",
    "print('Inputs:', x_data)\n",
    "print('Outputs: ', y_data)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Definition of the BO surrogate model\n",
    "Here we use a Gaussian process with a Matérn kernel on $\\mathbb{S}^2$, as by [1].\n",
    "\n",
    "The kernel has three positive real hyperparameters: variance $\\sigma^2$, length scale $\\kappa$ and smoothness $\\nu$.\n",
    "Defining a Gaussian process model also requires a likelihood noise hyperparameter $\\sigma_n^2$.\n",
    "\n",
    "We use the $\\operatorname{Gamma}(2.0, 0.15)$ prior for $\\sigma$, the square root of $\\sigma^2$, and $\\operatorname{Gamma}(1.1, 0.05)$ prior for $\\sigma_n^2$."
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "pycharm": {
     "name": "#%% md\n"
    }
   },
   "source": [
    "We first define the kernel."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "The number of eigenfunctions requested does not lead to complete levels of spherical harmonics. We have thus increased the number to 16, which includes all spherical harmonics up to degree 4 (excl.)\n",
      "The number of eigenfunctions requested does not lead to complete levels of spherical harmonics. We have thus increased the number to 16, which includes all spherical harmonics up to degree 4 (excl.)\n"
     ]
    }
   ],
   "source": [
    "_TRUNCATION_LEVEL = 10\n",
    "base_kernel = GPytorchGeometricKernel(MaternKarhunenLoeveKernel(hypersphere, _TRUNCATION_LEVEL))\n",
    "kernel = gpytorch.kernels.ScaleKernel(base_kernel,\n",
    "                                      outputscale_prior=gpytorch.priors.torch_priors.GammaPrior(2.0, 0.15))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "pycharm": {
     "name": "#%% md\n"
    }
   },
   "source": [
    "We then define the likelihood of the Gaussian process."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "outputs": [],
   "source": [
    "noise_prior = gpytorch.priors.torch_priors.GammaPrior(1.1, 0.05)\n",
    "noise_prior_mode = (noise_prior.concentration - 1) / noise_prior.rate\n",
    "lik_fct = gpytorch.likelihoods.gaussian_likelihood.GaussianLikelihood(noise_prior=noise_prior,\n",
    "                                                                      noise_constraint=\n",
    "                                                                      gpytorch.constraints.GreaterThan(1e-8),\n",
    "                                                                      initial_value=noise_prior_mode)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "pycharm": {
     "name": "#%% md\n"
    }
   },
   "source": [
    "We finally initialize the GP model, as well as the marginal likelihood function that will be used to optimize its parameters."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "outputs": [],
   "source": [
    "model = botorch.models.SingleTaskGP(x_data, y_data[:, None], covar_module=kernel, likelihood=lik_fct)\n",
    "mll_fct = gpytorch.mlls.ExactMarginalLogLikelihood(model.likelihood, model)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "pycharm": {
     "name": "#%% md\n"
    }
   },
   "source": [
    "## Bayesian optimization loop"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "outputs": [],
   "source": [
    "new_best_f, index = y_data.min(0)\n",
    "best_x = [x_data[index]]\n",
    "best_f = [new_best_f]"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "pycharm": {
     "name": "#%% md\n"
    }
   },
   "source": [
    "We define the bounds for the optimization of the acquisition function, as well as the constraints that must be satisfied by candidate points on the sphere."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "outputs": [],
   "source": [
    "bounds = torch.stack([-torch.ones(dimension, dtype=torch.float64), torch.ones(dimension, dtype=torch.float64)])\n",
    "\n",
    "def upper_constraint(x):\n",
    "    return 1.0 - torch.linalg.norm(x, dim=-1)\n",
    "\n",
    "def lower_constraint(x):\n",
    "    return torch.linalg.norm(x, dim=-1) - 1.0"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "pycharm": {
     "name": "#%% md\n"
    }
   },
   "source": [
    "We can now run our BO loop. At each iteration, we first optimize our GP model, then we define the acquisition function, and select the new candidate point as the point maximizing the acquisition function. \n",
    "\n",
    "Notice that, for the sake of simplicity, we here use a constrained optimization on the sphere to guarantee that our new candidate point belongs to the sphere manifold. However, for a fully geometry-aware BO loop, Riemannian optimization should be used to optimize the acquisition function on the manifold, see [1], [2] for details, and https://github.com/NoemieJaquier/MaternGaBO for an implementation."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration 0\t Best f 3.2543758676565138\n",
      "Iteration 1\t Best f 3.2543758676565138\n",
      "Iteration 2\t Best f 1.199826977720083\n",
      "Iteration 3\t Best f 1.199826977720083\n",
      "Iteration 4\t Best f 1.199826977720083\n",
      "Iteration 5\t Best f 1.199826977720083\n",
      "Iteration 6\t Best f 1.199826977720083\n",
      "Iteration 7\t Best f 0.5187739891185896\n",
      "Iteration 8\t Best f 0.5187739891185896\n",
      "Iteration 9\t Best f 0.5187739891185896\n",
      "Iteration 10\t Best f 0.5187739891185896\n",
      "Iteration 11\t Best f 0.5187739891185896\n",
      "Iteration 12\t Best f 0.5187739891185896\n",
      "Iteration 13\t Best f 0.39601370512681955\n",
      "Iteration 14\t Best f 0.39601370512681955\n",
      "Iteration 15\t Best f 0.39601370512681955\n",
      "Iteration 16\t Best f 0.39601370512681955\n",
      "Iteration 17\t Best f 0.39601370512681955\n",
      "Iteration 18\t Best f 0.3095212015135691\n",
      "Iteration 19\t Best f 0.3095212015135691\n",
      "Iteration 20\t Best f 0.3095212015135691\n",
      "Iteration 21\t Best f 0.3095212015135691\n",
      "Iteration 22\t Best f 0.3095212015135691\n",
      "Iteration 23\t Best f 0.3095212015135691\n",
      "Iteration 24\t Best f 0.3095212015135691\n"
     ]
    }
   ],
   "source": [
    "n_iters = 25\n",
    "for iteration in range(n_iters):\n",
    "    # Fit GP model\n",
    "    botorch.fit_gpytorch_model(mll=mll_fct)\n",
    "\n",
    "    # Define the acquisition function\n",
    "    acq_fct = botorch.acquisition.ExpectedImprovement(model=model, best_f=best_f[-1], maximize=False)\n",
    "    \n",
    "    # Initial conditions to optimize the acquisition function\n",
    "    batch_initial_conditions = torch.tensor(hypersphere.random_point(100))\n",
    "    batch_initial_conditions /= torch.linalg.norm(batch_initial_conditions, dim=-1)[:, None]\n",
    "\n",
    "\n",
    "    # Get new candidate\n",
    "    with warnings.catch_warnings():\n",
    "        warnings.simplefilter(\"ignore\")\n",
    "        new_x, acq_new_x = botorch.optim.optimize_acqf(acq_fct, bounds=bounds, q=1,\n",
    "                                                       num_restarts=5, raw_samples=100,\n",
    "                                                       nonlinear_inequality_constraints=[upper_constraint,\n",
    "                                                                                         lower_constraint],\n",
    "                                                       batch_initial_conditions=batch_initial_conditions[:, None])\n",
    "    # Get new observation\n",
    "    new_y = ackley_function_sphere(new_x)[0]\n",
    "\n",
    "    # Update training points\n",
    "    x_data = torch.cat((x_data, new_x))\n",
    "    y_data = torch.cat((y_data, new_y))\n",
    "\n",
    "    # Update best observation\n",
    "    new_best_f, index = y_data.min(0)\n",
    "    best_x.append(x_data[index])\n",
    "    best_f.append(new_best_f)\n",
    "\n",
    "    # Update the model\n",
    "    model.set_train_data(x_data, y_data, strict=False)  # strict False necessary to add datapoints\n",
    "\n",
    "    print(\"Iteration \" + str(iteration) + \"\\t Best f \" + str(new_best_f.item()))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "outputs": [],
   "source": [
    "x_eval = x_data.cpu().numpy()\n",
    "y_eval = y_data.cpu().numpy()[:, None]\n",
    "best_x_np = np.array([x.cpu().detach().numpy() for x in best_x])\n",
    "best_f_np = np.array([f.cpu().detach().numpy() for f in best_f])[:, None]"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "pycharm": {
     "name": "#%% md\n"
    }
   },
   "source": [
    "# Results\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import matplotlib.pylab as pl\n",
    "from mpl_toolkits.mplot3d import Axes3D"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "pycharm": {
     "name": "#%% md\n"
    }
   },
   "source": [
    "We set the true minimum value of the objective function to evaluate the performance of the BO."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "outputs": [],
   "source": [
    "true_min_x = np.zeros((1, dimension))\n",
    "true_min_x[0, 0] = 1.\n",
    "true_min_value = 0.0"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "pycharm": {
     "name": "#%% md\n"
    }
   },
   "source": [
    "We display the candidate points on the sphere evaluated in the BO loop. Their color indicate the value of the function (yellow is low, purple is high). The best candidate is displayed as a red diamond, and the true minimum as a blue cross."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": "<Figure size 720x720 with 1 Axes>",
      "image/png": "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AUULIYQQQhoBRQshhBBCGgFFCyGEEEIaAUULIYQQQhoBRQshhBBCGgFFCyGEEEIaAUULIYQQQhoBRQshhBBCGgFFCyGEEEIaAUULIYQQQhoBRQshhBBCGgFFCyGEEEIaAUULIYQQQhoBRQshhBBCGgFFCyGEEEIaAUULIYQQQhoBRQshhBBCGgFFCyGEEEIaAUULIYQQQhoBRQshhBBCGgFFCyGEEEIaAUULIYQQQhoBRQshhBBCGgFFCyGEEEIaAUULIYQQQhoBRQshhBBCGgFFCyGEEEIaAUULIYQQQhoBRQshhBBCGgFFCyGEEEIaAUULIYQQQhoBRQshhBBCGgFFCyGEEEIaAUULIYQQQhoBRQshhBBCGgFFCyGEEEIaAUULIYQQQhoBRQshhBBCGgFFCyGEEEIaAUULIYQQQhoBRQshhBBCGgFFCyGEEEIaAUULIYQQQhoBRQshhBBCGgFFCyGEEEIaAUULIYQQQhoBRQshhBBCGgFFCyGEEEIaAUULIYQQQhoBRQshhBBCGgFFCyGEEEIaAUULIYQQQhoBRQshhBBCGgFFCyGEEEIaAUULIYQQQhoBRQshhBBCGgFFCyGEEEIaAUULIYQQQhoBRQshhBBCGgFFCyGEEEIaAUULIYQQQhoBRQshhBBCGgFFCyGEEEIaAUULIYQQQhoBRQshhBBCGgFFCyGEEEIaAUULIYQQQhoBRQshhBBCGgFFCyGEEEIaAUULIYQQQhoBRQshhBBCGgFFCyGEEEIaAUULIYQQQhoBRQshhBBCGoGf8b4zll4QQgghhGRASwshhBBCGgFFCyGEEEIaAUULIYQQQhoBRQshhBBCGgFFCyGEEEIaAUULIYQQQhrB/x8tvXnbImLA5QAAAABJRU5ErkJggg==\n"
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig = plt.figure(figsize=(10, 10))\n",
    "ax = fig.add_subplot(111, projection=\"3d\")\n",
    "\n",
    "# Make the panes transparent\n",
    "ax.xaxis.set_pane_color((1.0, 1.0, 1.0, 0.0))\n",
    "ax.yaxis.set_pane_color((1.0, 1.0, 1.0, 0.0))\n",
    "ax.zaxis.set_pane_color((1.0, 1.0, 1.0, 0.0))\n",
    "\n",
    "# Make the grid lines transparent\n",
    "ax.xaxis._axinfo[\"grid\"]['color'] = (1, 1, 1, 0)\n",
    "ax.yaxis._axinfo[\"grid\"]['color'] = (1, 1, 1, 0)\n",
    "ax.zaxis._axinfo[\"grid\"]['color'] = (1, 1, 1, 0)\n",
    "\n",
    "# Remove axis\n",
    "ax._axis3don = False\n",
    "\n",
    "# Initial view\n",
    "# ax.view_init(elev=10, azim=-20.)  # (default: elev=30, azim=-60)\n",
    "ax.view_init(elev=10, azim=30.)  # (default: elev=30, azim=-60)\n",
    "\n",
    "# Plot sphere\n",
    "n_elems = 100\n",
    "r = 0.99\n",
    "u = np.linspace(0, 2 * np.pi, n_elems)\n",
    "v = np.linspace(0, np.pi, n_elems)\n",
    "\n",
    "x = r * np.outer(np.cos(u), np.sin(v))\n",
    "y = r * np.outer(np.sin(u), np.sin(v))\n",
    "z = r * np.outer(np.ones(np.size(u)), np.cos(v))\n",
    "\n",
    "ax.plot_surface(x, y, z, rstride=4, cstride=4, color=[0.8, 0.8, 0.8], linewidth=0, alpha=0.4)\n",
    "\n",
    "lim = 1.1\n",
    "ax.set_xlim3d([-lim, lim])\n",
    "ax.set_ylim3d([-lim, lim])\n",
    "ax.set_zlim3d([-0.75*lim, 0.75*lim])\n",
    "\n",
    "# Plot evaluated points\n",
    "max_colors = np.max(y_eval - true_min_value)\n",
    "for n in range(x_eval.shape[0]):\n",
    "    ax.scatter(x_eval[n, 0], x_eval[n, 1], x_eval[n, 2], s=50,\n",
    "               c=pl.cm.inferno(1. - (y_eval[n] - true_min_value) / max_colors))\n",
    "\n",
    "# Plot true minimum\n",
    "ax.scatter(true_min_x[0, 0], true_min_x[0, 1], true_min_x[0, 2], s=200, c='b', marker='P')\n",
    "\n",
    "# Plot BO minimum\n",
    "ax.scatter(best_x_np[-1][0], best_x_np[-1][1], best_x_np[-1][2], s=100, c='r', marker='D')\n",
    "\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "pycharm": {
     "name": "#%% md\n"
    }
   },
   "source": [
    "We finally display the distance between consecutive candidate points on the sphere, and the convergence plot of our BO algorithm."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "outputs": [
    {
     "data": {
      "text/plain": "<Figure size 720x360 with 2 Axes>",
      "image/png": "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\n"
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "def sphere_distance(x, y):\n",
    "    if np.ndim(x) < 2:\n",
    "        x = x[:, None]\n",
    "    if np.ndim(y) < 2:\n",
    "        y = y[:, None]\n",
    "\n",
    "    # Compute the inner product (should be [-1,1])\n",
    "    inner_product = np.dot(x.T, y)\n",
    "    inner_product = np.max(np.min(inner_product, 1), -1)\n",
    "    return np.arccos(inner_product)\n",
    "\n",
    "# Compute distances between consecutive x's and best evaluation for each iteration\n",
    "neval = x_eval.shape[0]\n",
    "distances = np.zeros(neval-1)\n",
    "for n in range(neval-1):\n",
    "    distances[n] = sphere_distance(x_eval[n + 1, :], x_eval[n, :])\n",
    "\n",
    "Y_best = np.ones(neval)\n",
    "for i in range(neval):\n",
    "    Y_best[i] = y_eval[:(i + 1)].min()\n",
    "\n",
    "# Plot distances between consecutive x's\n",
    "plt.figure(figsize=(10, 5))\n",
    "plt.subplot(1, 2, 1)\n",
    "plt.plot(np.array(range(neval - 1)), distances, '-ro')\n",
    "plt.xlabel('Iteration')\n",
    "plt.ylabel('d(x[n], x[n-1])')\n",
    "plt.title('Distance between consecutive x\\'s')\n",
    "plt.grid(True)\n",
    "\n",
    "# Plot value of the best candidate\n",
    "plt.subplot(1, 2, 2)\n",
    "plt.plot(np.array(range(neval)), Y_best, '-o')\n",
    "plt.hlines(true_min_value, 0, neval, 'k', '--')\n",
    "plt.title('Value of the best candidate')\n",
    "plt.xlabel('Iteration')\n",
    "plt.ylabel('Best y')\n",
    "plt.grid(True)\n",
    "\n",
    "plt.show()"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%%\n"
    }
   }
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "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.8.10"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 1
}