{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "from examples.SMO.turbo import train_turbo, get_initial_points, TurboState\n",
    "from uncertaintylearning.utils.networks import create_optimizer, create_network\n",
    "import torch\n",
    "import os\n",
    "from botorch.test_functions import Ackley\n",
    "from botorch.utils.transforms import unnormalize\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "import warnings\n",
    "warnings.filterwarnings('ignore')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "features = 'xv'\n",
    "dim = 10\n",
    "batch_size = 1\n",
    "n_init = 20\n",
    "use_log_unc = True\n",
    "device = torch.device(\"cuda\" if torch.cuda.is_available() else \"cpu\")\n",
    "dtype = torch.float\n",
    "SMOKE_TEST = os.environ.get(\"SMOKE_TEST\")\n",
    "low, up = -10, 15\n",
    "fun = Ackley(dim=10, negate=True).to(dtype=dtype, device=device)\n",
    "fun.bounds[0, :].fill_(low)\n",
    "fun.bounds[1, :].fill_(up)\n",
    "dim = fun.dim\n",
    "lb, ub = fun.bounds\n",
    "\n",
    "X_test = get_initial_points(dim, 1000)\n",
    "\n",
    "\n",
    "def eval_objective(x):\n",
    "    \"\"\"This is a helper function we use to unnormalize and evalaute a point\"\"\"\n",
    "    return fun(unnormalize(x, fun.bounds))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [],
   "source": [
    "def transform_results(res):\n",
    "    return np.maximum.accumulate(res, 1)\n",
    "\n",
    "def plot_all(seed):\n",
    "    for k, v in {\n",
    "                'gp': gp_results[:1 + seed, :],\n",
    "                'turbo_gp': turbo_gp_results[:1 + seed, :],\n",
    "                'deup_vd': deup_vd_results[:1 + seed, :],\n",
    "                'turbo_deup_vd': turbo_deup_vd_results[:1 + seed, :],\n",
    "                'deup_xv': deup_xv_results[:1 + seed, :],\n",
    "    }.items():\n",
    "        plt.errorbar(range(v.shape[1]), np.mean(v, axis=0), np.std(v, axis=0), label=k)\n",
    "    plt.legend()\n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "seed 0 , gp current max -13.478581428527832\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "seed 1 , gp current max -14.354255676269531\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "seed 2 , gp current max -14.808502197265625\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "n_seeds = 3\n",
    "max_step = 250\n",
    "gp_results = np.zeros((n_seeds, 2 + max_step)) * (-np.float('inf'))\n",
    "turbo_gp_results = np.zeros((n_seeds, 2 + max_step)) * (-np.float('inf'))\n",
    "deup_v_results = np.zeros((n_seeds, 2 + max_step)) * (-np.float('inf'))\n",
    "deup_xv_results = np.zeros((n_seeds, 2 + max_step)) * (-np.float('inf'))\n",
    "turbo_deup_v_results = np.zeros((n_seeds, 2 + max_step)) * (-np.float('inf'))\n",
    "\n",
    "for seed in range(n_seeds):\n",
    "    X_turbo = get_initial_points(dim, n_init)\n",
    "    Y_turbo = torch.tensor(\n",
    "        [eval_objective(x) for x in X_turbo], dtype=dtype, device=device\n",
    "    ).unsqueeze(-1)\n",
    "    \n",
    "    print('seed', seed, ', gp current max', Y_turbo.max().item())\n",
    "    gp_results[seed, 0] = Y_turbo.max().item()\n",
    "    state = TurboState(dim, batch_size=batch_size, max_step=max_step)\n",
    "    best_values, f_losses, e_losses, buffer = train_turbo(X_turbo, Y_turbo, state, deup=False, batch_size=1, turbo=False)\n",
    "    gp_results[seed, 1:len(best_values) + 1] = best_values\n",
    "    plot_all(seed)\n",
    "    \n",
    "    print('seed', seed, ', turbo gp current max', Y_turbo.max().item())\n",
    "    turbo_gp_results[seed, 0] = Y_turbo.max().item()\n",
    "    state = TurboState(dim, batch_size=batch_size, max_step=max_step)\n",
    "    best_values, f_losses, e_losses, buffer = train_turbo(X_turbo, Y_turbo, state, deup=False, batch_size=1, turbo=True)\n",
    "    turbo_gp_results[seed, 1:len(best_values) + 1] = best_values\n",
    "    plot_all(seed)\n",
    "    \n",
    "    print('seed', seed, ', deup-v current max', Y_turbo.max().item())\n",
    "    deup_v_results[seed, 0] = Y_turbo.max().item()\n",
    "    state = TurboState(dim, batch_size=batch_size, max_step=max_step)\n",
    "    best_values, f_losses, e_losses, buffer = train_turbo(X_turbo, Y_turbo, state, deup=True, use_log_unc=True, \n",
    "                                                          batch_size=1, features='v', turbo=False)\n",
    "    deup_v_results[seed, 1:len(best_values) + 1] = best_values\n",
    "    plot_all(seed)\n",
    "        \n",
    "    print('seed', seed, ', deup-xv current max', Y_turbo.max().item())\n",
    "    deup_xv_results[seed, 0] = Y_turbo.max().item()\n",
    "    state = TurboState(dim, batch_size=batch_size, max_step=max_step)\n",
    "    best_values, f_losses, e_losses, buffer = train_turbo(X_turbo, Y_turbo, state, deup=True, use_log_unc=True, \n",
    "                                                          batch_size=1, features='xv', turbo=False)\n",
    "    deup_xv_results[seed, 1:len(best_values) + 1] = best_values\n",
    "    plot_all(seed)\n",
    "    \n",
    "    print('seed', seed, ', turbo-deup-v current max', Y_turbo.max().item())\n",
    "    turbo_deup_v_results[seed, 0] = Y_turbo.max().item()\n",
    "    state = TurboState(dim, batch_size=batch_size, max_step=max_step)\n",
    "    best_values, f_losses, e_losses, buffer = train_turbo(X_turbo, Y_turbo, state, deup=True, use_log_unc=True, \n",
    "                                                          batch_size=1, features='v', turbo=True)\n",
    "    turbo_deup_v_results[seed, 1:len(best_values) + 1] = best_values\n",
    "    plot_all(seed)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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wmN6mFI4hfsuum9wKyqEEAMoY3ryrYEmIibYkZHk50W5sukgc8NRduWPoJUImH6K/TJUI4Q4vmRMT741ECDiBZQ7MDPSsqk3M+Y7TIjjSkNDA3fdddcxH7d48WLefffdfq3LxIkTqa2t7ddzDqSMiYKhlgARD3iIQriZUZbFLr+kLxCir36+4edsr9/e437xfeJj892ZUTKDGxfe2OX2eJA/miyTcbZt97zTcShjevLRYAsRDxjKxtCaMtumzpMx32FCHFduuukmKisrmTt3LqeeeiqXXHJJYtsNN9zAfffdB7i97J/85CecddZZiZw2Dz30EGeccQazZ89mw4YNANTX1/PlL3+ZOXPm8JnPfIZNmzZ1ee26ujouuOAC5s2bx7XXXovWOrHtoYceYuHChcydO5drr7028cWSl5eX2OeJJ57gqquuAuCqq67iuuuu4+yzz+aEE07o9mna0047jS1btiTeL168OJGPpy8yJgpara1EvPDD5maubGgA4AtmCV/Qo9wdvt6/j1wLcbzorsedrD9n19x2221s3ryZDz74gHXr1nW79J/f72f9+vUA3H333bS0tPDGG2/w2muvcfXVV7N582ZuueUW5s2bxzPPPMNf/vIXli9fnjKbJcCtt97KWWedxY9//GOef/55Vq9eDcC2bdtYu3Ytf/vb3/B6vVx//fU8/PDDLF++vNu27N69m1dffZXKyko++9nP8umnn+L3+zvtd/nll/PYY49x6623Ul1dzYEDB5g/f/5R/hfrWsYEeTvUSsQDJToK2k1fgCer3/NpCCGGlo7ZIq+44grAzWTZ1NREQ0MD69ev58knnwTg3HPPpa6ujsbGRgoLCzud77XXXkssHnLxxRdTXOxO2HjllVfYuHEjp556KgCtra2MHNlztpbLLrsMwzCYNm0akydPZvv27cydOzflfp/73Oe49dZbeeyxx9rlze+LjAnyOhwi4oExOuIuEgJgZg1upYQQfZacKx4gFHsmJi454ySkzh+fPOTS1X49bdNa861vfatd8rNU+3es39Hmsx87diylpaVs2rSJtWvXcs8993RZv2ORMWPyhCNEPIoyJwQ6dgPGI0FeiOEoPz+f5uZmACZMmMDWrVsJh8M0NjbyyiuvdHtsPOPk+vXrKSwspLCwkEWLFvHwww8DsG7dOkaMGEFBQUHK45P3feGFFzhy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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "res = {\n",
    "                'gp': gp_results[:1 + seed, :],\n",
    "                'turbo_gp': turbo_gp_results[:1 + seed, :],\n",
    "                'deup_v': deup_v_results[:1 + seed, :],\n",
    "                'turbo_deup_v': turbo_deup_v_results[:1 + seed, :],\n",
    "                'deup_xv': deup_xv_results[:seed, :],            }\n",
    "for k, v in res.items():\n",
    "        plt.errorbar(range(v.shape[1]), np.mean(v, axis=0), .5 * np.std(v, axis=0), label=k)\n",
    "plt.legend()\n",
    "plt.axhline(0, label='true max', color='k')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pickle\n",
    "pickle.dump(res, open('pickles/turbodeup.pkl', 'wb'))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pickle\n",
    "res = pickle.load(open('pickles/turbodeup.pkl', 'rb'))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(3, 252)"
      ]
     },
     "execution_count": 19,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "res['turbo_gp'].shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "dict_keys(['turbo_gp', 'deup_v', 'turbo_deup_v', 'deup_xv', 'gp'])"
      ]
     },
     "execution_count": 25,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "res.keys()"
   ]
  },
  {
   "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.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
