{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Simple example of TuRBO-1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "/mnt/08B82010B81FFAC0/PyCharm Projects/TurBODiscrete\n"
     ]
    }
   ],
   "source": [
    "cd ../../.."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "from baselines.TuRBO.turbo import Turbo1\n",
    "import numpy as np\n",
    "import torch\n",
    "import math\n",
    "import matplotlib\n",
    "import matplotlib.pyplot as plt"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Set up an optimization problem class"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "class Levy:\n",
    "    def __init__(self, dim=50):\n",
    "        self.dim = dim\n",
    "        self.lb = -5 * np.ones(dim)\n",
    "        self.ub = 10 * np.ones(dim)\n",
    "        \n",
    "    def __call__(self, x):\n",
    "        assert len(x) == self.dim\n",
    "        assert x.ndim == 1\n",
    "        assert np.all(x <= self.ub) and np.all(x >= self.lb)\n",
    "        w = 1 + (x - 1.0) / 4.0\n",
    "        val = np.sin(np.pi * w[0]) ** 2 + \\\n",
    "            np.sum((w[1:self.dim - 1] - 1) ** 2 * (1 + 10 * np.sin(np.pi * w[1:self.dim - 1] + 1) ** 2)) + \\\n",
    "            (w[self.dim - 1] - 1) ** 2 * (1 + np.sin(2 * np.pi * w[self.dim - 1])**2)\n",
    "        return val\n",
    "\n",
    "f = Levy(20)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Create a Turbo optimizer instance"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Using dtype = torch.float64 \n",
      "Using device = cpu\n"
     ]
    }
   ],
   "source": [
    "turbo1 = Turbo1(\n",
    "    f=f,  # Handle to objective function\n",
    "    lb=f.lb,  # Numpy array specifying lower bounds\n",
    "    ub=f.ub,  # Numpy array specifying upper bounds\n",
    "    n_init=20,  # Number of initial bounds from an Latin hypercube design\n",
    "    max_evals = 2000,  # Maximum number of evaluations\n",
    "    batch_size=10,  # How large batch size TuRBO uses\n",
    "    verbose=True,  # Print information from each batch\n",
    "    use_ard=True,  # Set to true if you want to use ARD for the GP kernel\n",
    "    max_cholesky_size=2000,  # When we switch from Cholesky to Lanczos\n",
    "    n_training_steps=50,  # Number of steps of ADAM to learn the hypers\n",
    "    min_cuda=1024,  # Run on the CPU for small datasets\n",
    "    device=\"cpu\",  # \"cpu\" or \"cuda\"\n",
    "    dtype=\"float64\",  # float64 or float32\n",
    "    guided_restart=True,\n",
    ")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Run the optimization process"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Starting from fbest = 48.25\n",
      "60) New best: 40.75\n",
      "70) New best: 33.11\n",
      "80) New best: 27.82\n",
      "130) New best: 18.32\n",
      "140) New best: 11.98\n",
      "170) New best: 9.594\n",
      "210) New best: 9.318\n",
      "220) New best: 8.402\n",
      "250) New best: 6.917\n",
      "280) Restarting with fbest = 6.917\n",
      "Starting from fbest = 50.28\n",
      "530) New best: 6.201\n",
      "560) Restarting with fbest = 6.201\n",
      "Starting from fbest = 65.76\n",
      "840) Restarting with fbest = 10.07\n",
      "Starting from fbest = 58.74\n",
      "1160) Restarting with fbest = 12.63\n",
      "Starting from fbest = 60.74\n",
      "1430) Restarting with fbest = 9.953\n",
      "Starting from fbest = 80.15\n",
      "1620) New best: 6.131\n",
      "1650) Restarting with fbest = 6.131\n",
      "Starting from fbest = 42.33\n",
      "1880) Restarting with fbest = 19.24\n",
      "Starting from fbest = 65.15\n"
     ]
    }
   ],
   "source": [
    "turbo1.optimize()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Best value found:\n",
      "\tf(x) = 6.131\n",
      "Observed at:\n",
      "\tx = [-2.247 -0.103  0.777  0.591  1.055  1.364 -0.222  0.255  1.549  2.4\n",
      "  1.121  2.16  -0.11   0.889  4.025  3.458  0.719  1.266 -0.172  5.399]\n"
     ]
    }
   ],
   "source": [
    "X = turbo1.X  # Evaluated points\n",
    "fX = turbo1.fX  # Observed values\n",
    "ind_best = np.argmin(fX)\n",
    "f_best, x_best = fX[ind_best], X[ind_best, :]\n",
    "\n",
    "print(\"Best value found:\\n\\tf(x) = %.3f\\nObserved at:\\n\\tx = %s\" % (f_best, np.around(x_best, 3)))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 504x360 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig = plt.figure(figsize=(7, 5))\n",
    "matplotlib.rcParams.update({'font.size': 16})\n",
    "plt.plot(fX, 'b.', ms=1)  # Plot all evaluated points as blue dots\n",
    "plt.plot(np.minimum.accumulate(fX), 'r', lw=3)  # Plot cumulative minimum as a red line\n",
    "plt.xlim([0, len(fX)])\n",
    "# plt.ylim([0, 30])\n",
    "plt.title(\"10D Levy function\")\n",
    "\n",
    "plt.tight_layout()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Using dtype = torch.float64 \n",
      "Using device = cpu\n",
      "Starting from fbest = 50.29\n",
      "40) New best: 39.52\n",
      "70) New best: 32.63\n",
      "140) New best: 26.81\n",
      "150) New best: 26.67\n",
      "160) New best: 16.25\n",
      "200) New best: 15.85\n",
      "210) New best: 13.53\n",
      "220) New best: 12.38\n",
      "260) New best: 10.12\n",
      "270) New best: 10.06\n",
      "280) New best: 9.315\n",
      "320) New best: 8.567\n",
      "340) New best: 8.017\n",
      "360) New best: 6.63\n",
      "390) Restarting with fbest = 6.63\n",
      "Starting from fbest = 65.54\n",
      "580) Restarting with fbest = 11.88\n",
      "Starting from fbest = 48.53\n",
      "790) Restarting with fbest = 14.53\n",
      "Starting from fbest = 68.37\n",
      "1000) Restarting with fbest = 12.51\n",
      "Starting from fbest = 85.96\n",
      "1150) New best: 5.597\n",
      "1200) New best: 4.833\n",
      "1230) New best: 4.687\n",
      "1260) Restarting with fbest = 4.687\n",
      "Starting from fbest = 86.47\n",
      "1500) New best: 3.096\n",
      "1510) New best: 2.981\n",
      "1540) Restarting with fbest = 2.981\n",
      "Starting from fbest = 67.97\n",
      "1810) Restarting with fbest = 9.221\n",
      "Starting from fbest = 68.44\n"
     ]
    }
   ],
   "source": [
    "turbo1 = Turbo1(\n",
    "    f=f,  # Handle to objective function\n",
    "    lb=f.lb,  # Numpy array specifying lower bounds\n",
    "    ub=f.ub,  # Numpy array specifying upper bounds\n",
    "    n_init=20,  # Number of initial bounds from an Latin hypercube design\n",
    "    max_evals = 2000,  # Maximum number of evaluations\n",
    "    batch_size=10,  # How large batch size TuRBO uses\n",
    "    verbose=True,  # Print information from each batch\n",
    "    use_ard=True,  # Set to true if you want to use ARD for the GP kernel\n",
    "    max_cholesky_size=2000,  # When we switch from Cholesky to Lanczos\n",
    "    n_training_steps=50,  # Number of steps of ADAM to learn the hypers\n",
    "    min_cuda=1024,  # Run on the CPU for small datasets\n",
    "    device=\"cpu\",  # \"cpu\" or \"cuda\"\n",
    "    dtype=\"float64\",  # float64 or float32\n",
    "    guided_restart=False,\n",
    ")\n",
    "turbo1.optimize()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Extract all evaluations from Turbo and print the best"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Best value found:\n",
      "\tf(x) = 2.981\n",
      "Observed at:\n",
      "\tx = [ 5.449  1.101  0.582  1.008  0.257  0.945  0.372  1.904  1.464  1.783\n",
      "  0.156  1.448  1.667  0.962 -0.55   1.91   0.682  0.473  1.193  1.793]\n"
     ]
    }
   ],
   "source": [
    "X = turbo1.X  # Evaluated points\n",
    "fX = turbo1.fX  # Observed values\n",
    "ind_best = np.argmin(fX)\n",
    "f_best, x_best = fX[ind_best], X[ind_best, :]\n",
    "\n",
    "print(\"Best value found:\\n\\tf(x) = %.3f\\nObserved at:\\n\\tx = %s\" % (f_best, np.around(x_best, 3)))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Plot the progress\n",
    "Each trust region is independent and finds different solutions"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 504x360 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig = plt.figure(figsize=(7, 5))\n",
    "matplotlib.rcParams.update({'font.size': 16})\n",
    "plt.plot(fX, 'b.', ms=1)  # Plot all evaluated points as blue dots\n",
    "plt.plot(np.minimum.accumulate(fX), 'r', lw=3)  # Plot cumulative minimum as a red line\n",
    "plt.xlim([0, len(fX)])\n",
    "plt.ylim([0, 300])\n",
    "plt.title(\"10D Levy function\")\n",
    "\n",
    "plt.tight_layout()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 504x360 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig = plt.figure(figsize=(7, 5))\n",
    "matplotlib.rcParams.update({'font.size': 16})\n",
    "plt.plot(fX, 'b.', ms=10)  # Plot all evaluated points as blue dots\n",
    "plt.plot(np.minimum.accumulate(fX), 'r', lw=3)  # Plot cumulative minimum as a red line\n",
    "plt.xlim([0, len(fX)])\n",
    "plt.ylim([0, 30])\n",
    "plt.title(\"10D Levy function\")\n",
    "\n",
    "plt.tight_layout()\n",
    "plt.show()"
   ]
  },
  {
   "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.7.4"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
