{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from zoopt_v1 import Dimension, Opt, Parameter, Objective"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Hyperparameters:\n",
    "\n",
    "`shrinking_rate`: rate of region shrinking\n",
    "\n",
    "`shrinking_freq`: frequency of region shrinking\n",
    "\n",
    "`max_shrinking_times`: limits of region shrinking times (Optional)"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Default algorithm is SRACOS, RACE-CARS will be implemented once args ``shrinking_rate`` and ``shrinking_freq`` are provided."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[zoopt] x: [0.19929994043217847, 0.07226868110677892, 0.18401107294657504, 0.20964577184528604, 0.11317501908570904, 0.2260595890953354, 0.20363743089379024, 0.2209992114170347, 0.18457401285461916, 0.2072774352235336, 0.23619160257009686, 0.1810473571462155, 0.17785574474175264, 0.1799890580314159, 0.2430230938642466, 0.16762890878726477, 0.2367575701731289, 0.15706770796322855, 0.20554039221526899, 0.2266699337542556, 0.21596451424278762, 0.1694040644730742, 0.12150029493171222, 0.19443622761931945, 0.185786786808189, 0.19025489814736718, 0.21811505176019375, 0.18870002374755018, 0.21759650609426406, 0.22988984056439893, 0.2558184950731419, 0.21548021887278307, 0.19425698973539385, 0.1742834430076441, 0.17289558886173018, 0.21782800717447082, 0.26016506782535065, 0.18594956994368195, 0.17327406177134286, 0.16231336937627727, 0.21337736913867644, 0.23421694720356334, 0.20551890897324548, 0.20128792864767064, 0.17877177435076144, 0.1968042030221256, 0.16364719230832003, 0.22902371681824346, 0.17413608203233477, 0.23959431753009192]\n",
      "[zoopt] value: 0.2039558909861623\n",
      "[zoopt] x: [-0.04245576948435925, 0.3779525973705731, 0.3913536090721266, 0.23975719644398552, 0.1027889302776952, 1.0140515732690663, 0.021188860388562603, 0.1502463415059374, 0.5583226599919584, -0.5634454326057696, 1.1727089149660568, 0.4652286266656098, 0.3574334000402164, 0.3738651504222812, -0.6128433333831111, 1.0192457052588555, -0.506625477715497, 0.12774145298348927, 1.0366497643884074, 0.5226940441992944, -0.6773227419380827, 0.14487826556954353, 1.2430658584552194, 0.20438297206490041, -0.07718336014432658, -0.0020347107120599617, 0.16259144381320567, 1.1746034268490941, 0.41583526410953553, 0.09655230517139124, 0.15009380964433916, -0.027634053055344054, -0.6952722962781621, 0.007777236123798659, 0.40151899311745076, 1.2444664802375713, 0.36901350024218615, 1.113158916425995, 0.45935349512084755, 0.25926698677301196, 0.8941220657937521, 1.0914666676949363, 0.020037274924842308, 1.09650537652659, 1.221135768979316, 0.09484642432165558, 0.2476098239658331, 0.26656197418902394, 1.03503293556847, -0.8577638634077722]\n",
      "[zoopt] value: 3.172406337279494\n"
     ]
    }
   ],
   "source": [
    "ackley = lambda x: -20.0*np.exp(-0.2*np.sqrt(np.sum(np.power(np.array(x)-0.2, 2))/np.size(x)))-np.exp(np.sum(np.cos(2.0*np.pi*(np.array(x)-0.2))/np.size(x)))+20.0+np.e\n",
    "f = lambda x: ackley(x.get_x())\n",
    "dim_1 = Dimension(size=50, regs=[[-10, 10]]*50, tys=[True]*50)\n",
    "dim_2 = Dimension(size=50, regs=[[-10, 10]]*50, tys=[True]*50)\n",
    "obj_1 = Objective(f, dim_1)\n",
    "obj_2 = Objective(f, dim_2)\n",
    "# RACE-CARS\n",
    "param_1 = Parameter(budget=3000, shrinking_rate=0.9, shrinking_freq=0.01)\n",
    "sol_1 = Opt.min(obj_1, param_1)\n",
    "# SRACOS\n",
    "param_2 = Parameter(budget=3000)\n",
    "sol_2 = Opt.min(obj_2, param_2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7f5a1fe1cfd0>"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAh8AAAGdCAYAAACyzRGfAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8pXeV/AAAACXBIWXMAAA9hAAAPYQGoP6dpAABZjUlEQVR4nO3dd3wUdf7H8dfsZlNJAqGFQIDQe1ekqKDSbNh+B4qKnufZG1ZsiA311PM8TjkVUc96CmIvoAJ6oIAQpNfQE0JNT3azO78/JtmwKZDAZjfl/Xw85rGz8/3uzCfj6n78zrcYpmmaiIiIiASILdgBiIiISP2i5ENEREQCSsmHiIiIBJSSDxEREQkoJR8iIiISUEo+REREJKCUfIiIiEhAKfkQERGRgAoJdgCleTwe9u7dS3R0NIZhBDscERERqQTTNMnKyiIhIQGb7dhtGzUu+di7dy+JiYnBDkNEREROwK5du2jVqtUx69S45CM6Ohqwgo+JiQlyNCIiIlIZmZmZJCYmen/Hj6XGJR/Fj1piYmKUfIiIiNQylekyoQ6nIiIiElBKPkRERCSglHyIiIhIQFW5z8eiRYv429/+xu+//05qaiqffvopF110kU+d9evXc//997Nw4UI8Hg/du3fnv//9L61bt/ZX3CIiEiSmaVJYWIjb7Q52KBJgdrudkJCQk54Ko8rJR05ODr179+baa6/l0ksvLVO+detWhg4dynXXXcfUqVOJjY1l/fr1hIeHn1SgIiISfE6nk9TUVHJzc4MdigRJZGQkLVq0IDQ09ITPYZimaZ7whw2jTMvH+PHjcTgc/Oc//zmhc2ZmZhIbG0tGRoZGu4iI1CAej4fNmzdjt9tp2rQpoaGhmgyyHjFNE6fTyf79+3G73XTs2NFnMrGq/H77daitx+Phq6++4r777mPUqFGsXLmSpKQkJk+eXObRTLGCggIKCgp8ghcRkZrH6XTi8XhITEwkMjIy2OFIEEREROBwONixYwdOp/OEn2r4tcNpeno62dnZPPPMM4wePZrvv/+eiy++mEsuuYSFCxeW+5lp06YRGxvr3TS7qYhIzXa8qbOlbvPHP3+/foM8Hg8AY8eO5a677qJPnz488MADnH/++cyYMaPcz0yePJmMjAzvtmvXLn+GJCIiIjWMXx+7NGnShJCQELp16+ZzvGvXrvzyyy/lfiYsLIywsDB/hiEiIiI1mF9bPkJDQznllFPYuHGjz/FNmzbRpk0bf15KREREaqkqJx/Z2dkkJyeTnJwMQEpKCsnJyezcuROAe++9l48++ojXX3+dLVu2MH36dL744gtuvvlmvwYuIiJSWddccw2GYWAYBiEhIbRu3ZqbbrqJw4cP+9TLy8ujUaNGxMXFkZeXV+65Zs+ezbBhw4iNjaVBgwb06tWLxx9/nEOHDgHw1ltvea919FaZzplbtmzh2muvpVWrVoSFhZGUlMTll1/O8uXLy9T961//it1u58MPPyxT9thjj3mva7PZSEhIYMKECWW6Nmzbto3LL7+chIQEwsPDadWqFWPHjmXTpk3HjfVkVDn5WL58OX379qVv374ATJo0ib59+/Loo48CcPHFFzNjxgyee+45evbsyRtvvMHs2bMZOnSofyOvKlcefP8wfHEnuAuDG4uIiATc6NGjSU1NZfv27bzxxhvl/o/x7Nmz6dGjB926dWPOnDllzvHQQw8xbtw4TjnlFL755hvWrFnDCy+8wKpVq3ymmIiJiSE1NdVn27FjxzHjW758Of3792fTpk38+9//Zt26dXz66ad06dKFu+++26dubm4uH330Effeey8zZ84s93zdu3cnNTWV3bt389FHH7F69Wr+9Kc/ecudTicjRowgMzOTOXPmsHHjRj766CN69OhBRkbGce/nSTFrmIyMDBMwMzIy/HtiV75pTomxttzD/j23iEg9kJeXZ65bt87My8szTdM0PR6PmVPgCsrm8XiqFPvEiRPNsWPH+hybNGmSGRcX53Ns2LBh5owZM8xXX33VHD58uE/Zb7/9ZgLmSy+9VO41Dh8+bJqmac6aNcuMjY2tUnwej8fs3r272b9/f9Ptdld47mJvvfWWedppp5lHjhwxIyIizJSUFJ/yKVOmmL179/Y59vLLL/v8vq5cudIEzO3bt1cp1tLfg2JV+f32a4fTGi0kDGwO8LjAmQ0RDYMdkYhIrZbnctPt0e+Ccu11j48iMvTEf8K2bdvGt99+i8Ph8B7bunUrS5YsYc6cOZimyZ133sm2bdto164dAO+99x4NGjSosBtBw4YNTzie5ORk1q5dy/vvv1/uUNbS5545cyZXXnklsbGxnHvuucyaNYupU6dWeP60tDTmzJmD3W7HbrcD0LRpU2w2G5988gl33nmn93gg1K/B2mENrNeCrODGISIiAffll1/SoEEDIiIiaN++PevWreP+++/3lr/55puMGTPG2+dj9OjRvPnmm97yzZs3065dO5+EpSIZGRk0aNDAZxs5cmSF9Tdv3gxAly5djnvuzZs38+uvvzJu3DgArrzySmbNmuWd7qLY6tWradCggXc69AULFnDLLbcQFRUFQMuWLXn55Zd59NFHadSoEWeddRZPPPEE27ZtO24MJ6v+tHwAhDaAvMPgzAl2JCIitV6Ew866x0cF7dpVNXz4cF599VVyc3N544032LRpE7fddhsAbrebt99+m3/84x/e+ldeeSV33XUXU6dOxW63Y5pmpaeTj46OZsWKFb4xR0QAVgvKDTfc4D3+zTffYBatdFKZ88+cOZNRo0bRpEkTAM4991yuu+465s+f75PgdO7cmc8//5yCggI+++wzPv74Y5566imfc91yyy1cffXV/PTTT/z22298/PHHPP3003z++eeMGDGiUn/riahfyYet6M/1qMOpiMjJMgzjpB59BFpUVBQdOnQA4OWXX2b48OFMnTqVJ554gu+++449e/Z4WxOKud1uvv/+e8aMGUOnTp345ZdfcLlcx239sNls3muVduGFFzJw4EDv+5YtW7JhwwbAWhW+T58+FZ7X7XbzzjvvkJaWRkhIiM/xmTNn+iQfoaGh3hi6d+/O5s2buemmm8qsvRYdHc2FF17IhRdeyJNPPsmoUaN48sknqzX5qF+PXexFXxa3K7hxiIhI0E2ZMoXnn3+evXv3MnPmTMaPH++dSqJ4mzBhgnc0yRVXXEF2djavvPJKuec7cuRIpa4bHR1Nhw4dvFtERAR9+vShW7duvPDCC2Uenxx97q+//pqsrCxWrlzpE+fHH3/M3LlzOXjwYIXXfeSRR/jggw/KtMgczTAMunTpQk5O9T4hqD0pqz/YipIPj5IPEZH6btiwYXTv3p2nnnqKL774gs8//5wePXr41Jk4cSLnnXce+/fvZ+DAgdx3333cfffd7Nmzh4svvpiEhAS2bNnCjBkzGDp0KHfccQdgrQCblpZW5prNmjUrt0OpYRjMmjWLc845hzPOOIMHH3yQLl26kJ2dzRdffMH333/PwoULmTlzJueddx69e/f2+Xz37t258847effdd70xlNauXTvGjh3Lo48+ypdffklycjJTpkzhqquuolu3boSGhrJw4ULe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7NgKP3fLLbewceNGZs+ezZdffsnhw4e57rrr6NGjh8922WWXMXPmTADuvPNOhgwZwtlnn82//vUvVq1axbZt2/jvf//LwIED2bx5MwDTp0+noKCAUaNGsWjRInbt2sW3337LiBEjaNmyJU899RQAycnJjB07lk8++YR169axZcsWZs6cyZtvvnnM2Gu6evXYBSDcYQfgSK6LbYVxeLvrfHEHdL84aHGJiEj1aNCgAQMHDuTvf/87W7duxeVykZiYyPXXX8+DDz5Y4eeaNm3KVVddxWOPPUZSUhLnnHMOsbGxZepdeumlPP3006xYsYJ+/foxb948/v73v/Pvf/+be+65h8jISLp27crtt99Ojx49AOjYsSPLly/nscceY9y4cRw8eJD4+HguuugipkyZQlxcHACtWrWibdu2TJ06le3bt2MYhvf9XXfdVT03LAAM06zCeKUAyMzMJDY2loyMDGJiYvx+/oxcF70f/x6AEApZcv5hms6/wyq8YRG06O33a4qI1AX5+fmkpKSQlJREeHh4sMORIKnoe1CV3+969dgFIDbSwcPnWcObCglhY7PzSgr3/B6kqEREROqPepd8APzl9HYMaNMIgEVbDkAva9gU678IYlQiIiL1Q71MPgBCQ6w/PXnXEYi0nq2x9UfYW7aHsoiIiPhPvU0+bjizPQBLUw6xusUlJQW/vRakiEREROqHKicfixYt4oILLiAhIQHDMJg7d26FdW+44QYMw+Cll146iRCrx+D2jb2tH9d/lVky0mXV+1CQFcTIRERE6rYqJx85OTn07t2b6dOnH7Pe3Llz+e2330hICNK8/8fhsNuYdnFPADymCWc9UlKY/H6QohIRqflq2CBJCTB//POvcvIxZswYnnzySS655JIK6+zZs4dbb72V9957r8yKgDXJqUlWX4+MPBc0bg+dRlsF39ynWU9FREop/u95bq7++1ifFf/zP5nfd79PMubxeLjqqqu499576d69+3HrFxQU+CxxnJmZ6e+QKhQTYd24gkIPBYVuwvpNhE3fWoV/fAQDrg1YLCIiNZ3dbqdhw4akp6cDEBkZedKLqEntYZomubm5pKen07BhQ+x2+wmfy+/Jx7PPPktISEiZZYgrMm3aNKZOnervMCol3FHS8JPv8hDW5VzoeyWsfBcObA5KTCIiNVl8fDyANwGR+qdhw4be78GJ8mvy8fvvv/OPf/yDFStWVDobnjx5MpMmTfK+z8zMJDEx0Z9hVSjUbsMwwDShwOWGCAc0bGMVumrvgj0iItXFMAxatGhBs2bNcLlcwQ5HAszhcJxUi0cxvyYfP//8M+np6bRu3dp7zO12c/fdd/PSSy+xffv2Mp8JCwsjLCzMn2FUmmEYhIfYyXO5yS4opBlYqyUC/P4WDH8IGjQLSmwiIjWZ3W73y4+Q1E9+nefjqquu4o8//vBZbjghIYF7772X7777zp+X8puoMOtfns+S91oHYo9qdZk5MggRiYiI1G1VbvnIzs5my5Yt3vcpKSkkJycTFxdH69atady4sU99h8NBfHw8nTt3Pvloq0H7pg04kH2IX7cdtA50OQ+SzoCUReDKC25wIiIidVCVWz6WL19O37596du3LwCTJk2ib9++PProo34PLhDuOKcjAL+lHGJfZj7Y7HDuC1ZhYX4QIxMREambqtzyMWzYsCpNMFJeP4+aZECbOO/+zkO5NI8Jh5BQ64DbGaSoRERE6q56u7ZLsdAQG52aNwDAVeixDoaEW69q+RAREfG7ep98AITYrNvg8hS16NiLWj5MD2TsCVJUIiIidZOSD8Bht+YkKXQXtXyEx5YUvnVuECISERGpu5R8YC0yB+ByF7V82OxwyvXWfs6BIEUlIiJSNyn5AEKKWj5cxS0fAGcXjd5xZkP6hiBEJSIiUjcp+aCk5WNjWlbJwbBoaNTW2v/fSwGPSUREpK5S8gEcyLaG1GYXFJYcNAxrenWAg1vK+ZSIiIicCCUfwIhuzYFSyQdAoyTrdfeyAEckIiJSdyn5AFrEWvN6HM4pNalYbMuS/X3rAhiRiIhI3aXkA2gU6QDghw3pvgUxCSXDbg9tDXBUIiIidZOSD6BpdBgANqOcwgRrDRucuYELSEREpA5T8gG0aRwFgMek7Lo1DquMVe8HOCoREZG6SckHJUNt4aiJxoo1aGq9blug+T5ERET8QMkHEOqTfHh8C8+8v2R//mOBCUhERKQOU/JByQynAIWlWz5iEuCMe639Td8EMCoREZG6SckHEHJUT1Nn6ZYPgH5Xl+znHan+gEREROowJR+AYRjelW3//Naysp1OG7Yu2XdmBzAyERGRukfJR5HWcZEArN6TwdKUQ2UrFI96cTvLlomIiEilKfko8tXtp3v392bkla1gD7Fe3YVly0RERKTSlHwUCXfYOadrMwDyXeX0+7BZs6DicQUwKhERkbpHycdRwhx2ANIy8ssW2kOtV7eSDxERkZOh5OMo4SFW8vGPHzbz1R+pvoXFj108euwiIiJyMpR8HGVEt+be/RU7D/sWFj92SVsdwIhERETqHiUfRxndI567zukEQK7T7VuYsct6VcuHiIjISVHyUUpkqPXoJd9VKvnocan16tLqtiIiIidDyUcp4UXJR66zVAuHI8J6zU4PcEQiIiJ1i5KPUiKLRrzklR5u67AmIWPrjwGOSEREpG5R8lFKRPFjl9J9PmJbWa+5B8GpRy8iIiInSslHKRFFLR+5rlKPXdqfZb1m74O/tYf09QGOTEREpG5Q8lFKcctHXumWj7j20OpUa9+VC6mrAhyZiIhI3aDko5Tilo8yyYc9BP4yDzqfa70vLGcWVBERETkuJR+lFA+1zXG6yw63BQgJs14LCwIYlYiISN2h5KOU8KKWj4w8F72mfs+iTft9K4SEW69KPkRERE5IlZOPRYsWccEFF5CQkIBhGMydO9db5nK5uP/+++nZsydRUVEkJCRw9dVXs3fvXn/GXK0SGkbQr3VDAJyFHv639YBvBbV8iIiInJQqJx85OTn07t2b6dOnlynLzc1lxYoVPPLII6xYsYI5c+awadMmLrzwQr8EGwh2m8Gcm4dw76jOABzIcpaqUJx8qM+HiIjIiQip6gfGjBnDmDFjyi2LjY1l3rx5Psf++c9/cuqpp7Jz505at259YlEGQdMGVpJxILtUC0eIkg8REZGTUeXko6oyMjIwDIOGDRuWW15QUEBBQckPfGZmZnWHVClNokOB8pIP9fkQERE5GdXa4TQ/P58HHniAK664gpiYmHLrTJs2jdjYWO+WmJhYnSFVWpPjtXwc2RHgiEREROqGaks+XC4X48ePx+Px8Morr1RYb/LkyWRkZHi3Xbt2VVdIVRIb4QAgK7/UTKfFLR+bv4d9awMclYiISO1XLcmHy+XiT3/6EykpKcybN6/CVg+AsLAwYmJifLaaIDTEujXOwlILzHUaXbL/6mAwzQBGJSIiUvv5PfkoTjw2b97M/Pnzady4sb8vERBhIdZ8H4UeE4/nqASjSQe48J8l711aZE5ERKQqqpx8ZGdnk5ycTHJyMgApKSkkJyezc+dOCgsLueyyy1i+fDnvvfcebrebtLQ00tLScDqdxz5xDVPc8gHgdJdq/eh7FdiK+uoe2BTAqERERGq/Kicfy5cvp2/fvvTt2xeASZMm0bdvXx599FF2797N559/zu7du+nTpw8tWrTwbosXL/Z78NUp1F5ya3IKSvX7MAywWX1C+PbBAEYlIiJS+1V5qO2wYcMwj9HP4VhltYnDbnj31+7N5IxOTX0rdL8YVr0P7trVoiMiIhJsWtulAoZh0LZxJABXv7mUnzeXWuOl15+sV/X5EBERqRIlH8fwfwNK5hx585cU38LQKOs1Kw3+97K1rf8igNGJiIjUTtU+w2ltdsvwDoSF2Hjyq/X8tHE/a/dm0D0h1ioMb2i95h2CeY+UfOhP70C3sQGPVUREpLZQy8dxnN8rwbu/eV92SUGTjnDOY9BrvLUV+2la4IITERGphdTycRzxseEM79yUnzbu9x1yaxgw9K6S9407wE9PBj5AERGRWkYtH5UQUjTsttB9jJE8bYdYrxr9IiIickxKPiqheNhtocdTcaXieT88rgBEJCIiUnsp+aiEEJt1m1zHavmwFyUf7sKK64iIiIiSj8pw2IuTj2O0fNjV8iEiIlIZSj4qofixy0fLdlVcqfixi1vJh4iIyLEo+aiE4paPo9d7KaO45SP/COzXYnMiIiIVUfJRCZf1bwXAxn1ZpGbklV8pOr5kf+NXAYhKRESkdlLyUQmNG4R695/5ZkP5lRwRcMpfrP2sfQGISkREpHZS8lEJrRpFcmpSHACpR/IrrhhTNBuqMysAUYmIiNROSj4q6dbhHQBYuv0Qj362hh0Hc8pWCm1gva5811pwTkRERMpQ8lFJ3RNivPvvLNnBi/PK6VQa0ahk/4XO4Kqgf4iIiEg9puSjkho3COPn+4Z7H79sSc8uW6nTaOhzZcn7VR8GKDoREZHaQ8lHFSTGRfL0xT0BWLs3k5yCUrOZhsfARf+CGGt0DBs06kVERKQ0JR9VlBgXgc2ac4zuU75j9+HcspX6T7Ret8yDX2eAs5w6IiIi9ZSSjyoKC7FzQe8E7/uvV6eWrdT53JL9b++Hhc8GIDIREZHaQcnHCXhpXB86N48GIKfAXbZCfA8Y+0rJ+4zdAYpMRESk5lPycQIMw+CMTk0AyHeVk3wA9J0A571g7bsLAhSZiIhIzafk4wSFO+wAfLpyDxe/8j/mrCindSMk3HotVPIhIiJSLCTYAdRWiXGRAKRnFZCeVcDKnUdIahJF39ZHzfVhD7NeCzTjqYiISDG1fJygS/u14v2/DOTeUZ29x7aXnvU0pCj52LkEZpwOb50P678IYJQiIiI1j2GaphnsII6WmZlJbGwsGRkZxMTEHP8DNcAt763gq6JRL8M6N8VuGHRsHs1F7Q26vH9q2Q/clwKRcQGOUkREpPpU5fdbLR9+MKBtyaOWBRv388OGdGYs3MroN7fww0XLYdx7MOa5kg88lwQr3glCpCIiIsGnlg8/+W3bQXYdzsNZ6GHW/1LYfNT061ueGkOI3QYfXwNrP7UOxrSESeuCE6yIiIifVeX3W8lHNZn9+27u/ngVAE0ahPH9XWcQFwb8Pgu+uQ/CYmDyruAGKSIi4id67FIDXNS3JX0SGwJwILuAtXszICQUul5gVSjIhOz9wQtQREQkSJR8VBO7zeDTmwfTv43VH+TtxdutgtAGJZWe7wA/Phn44ERERIJIyUc1MgyD2AgHANv2Fw3DDY+B024pqbTob/DhBNjyQxAiFBERCbwqJx+LFi3iggsuICEhAcMwmDt3rk+5aZo89thjJCQkEBERwbBhw1i7dq2/4q11rjqtDQAuj6fk4Oin4Z4tJe83fAk/PB7gyERERIKjyslHTk4OvXv3Zvr06eWWP/fcc7z44otMnz6dZcuWER8fz4gRI8jKqp+zfCY0jABg16E8DmQfNc16g6Zw/U9wxr3W+9RkTcMuIiL1QpWTjzFjxvDkk09yySWXlCkzTZOXXnqJhx56iEsuuYQePXrw9ttvk5uby/vvv++XgGubyFC7d3/g0z+wbm9mSWHLftD/2pL36z4LYGQiIiLB4dc+HykpKaSlpTFy5EjvsbCwMM4880wWL15c7mcKCgrIzMz02eqSlg0jOLtLMwDcHpN1qaX+vtiWEB5r7c+5HvZvCnCEIiIigeXX5CMtLQ2A5s2b+xxv3ry5t6y0adOmERsb690SExP9GVLQ2WwGM685hfN6tgBg075yHj8Nvatk/1+nQM2aekVERMSvqmW0i2EYPu9N0yxzrNjkyZPJyMjwbrt21c2JtxpGWqNeXlu0jYfnrsZnbreBN/k+fvlhaoCjExERCRy/Jh/x8fEAZVo50tPTy7SGFAsLCyMmJsZnq4vO75Xg3X/3150s2HjUBGOOcLjgpZL32xYELC4REZFA82vykZSURHx8PPPmzfMeczqdLFy4kMGDB/vzUrXOoPaN+XXy2d737/22E4+n1OOVyz+0Xl35AYxMREQksKqcfGRnZ5OcnExycjJgdTJNTk5m586dGIbBnXfeydNPP82nn37KmjVruOaaa4iMjOSKK67wd+y1TnxsODcPaw/A/PX7+Peibb4Vwhtar25nYAMTEREJoJCqfmD58uUMHz7c+37SpEkATJw4kbfeeov77ruPvLw8br75Zg4fPszAgQP5/vvviY6O9l/UtdjFfVvyyoKtADz77QZCbAbXDGmLw24Du9UvBI8riBGKiIhUL61qGwQb07IY9dIi7/vn/683l/VvBamr4N9nQHQLuHtDECMUERGpGq1qW8N1jo9m9k0lfWDmrSvqoGsravnQYxcREanDlHwESf82jbhmcFsA9mUWTatuD7Vecw/C2rlBiUtERKS6KfkIoh4trZlN7baiOVCiGpcU/vhEECISERGpfko+gqhR0cRjhe6iFW8jGsGFRQv2FWQHKSoREZHqpeQjiELs1u13uY/q85s40HotzAtCRCIiItVPyUcQOezW4xZXccsHWLOdAuRnQObeIEQlIiJSvZR8BJGjqOWj8OiZTkMblOy/938BjkhERKT6KfkIopCijqbOwqNaPiLjoPvF1n7mniBEJSIiUr2UfARRaIh1+wsK3b4FZz9qvbo106mIiNQ9Sj6CqGl0GAAHc5y+/T68k40p+RARkbpHyUcQNYkKI8RmYJqwP6ugpEBrvIiISB2m5COIbDaD5jHW6JYPl+0i11loFRTPdGp6wOOu4NMiIiK1k5KPIGsRayUfL/+wmWtnLcM0TbAdtdiwHr2IiEgdo+QjyG4a1t67/1vKIW59f2VJywfAziVBiEpERKT6KPkIsrO7Nmfd46O8779anUqueVTLR8buIEQlIiJSfZR81ACRoSGsmVqSgBS4PND1QutNYX6QohIREakeSj5qiKhQu3ff5fFASNE064UFFXxCRESkdlLyUUMYhuFd66XQbUKINQcI/3tJa7yIiEidouSjBgmxFa314jYhPNY6mLMfpp8SxKhERET8S8lHDRJS3PLh8cCpf4X4nlaBMxs+vhYyUyE7PYgRioiInDwlHzWIzyq3jdrADT+XFK6dAy92gec7wtf3BSlCERGRk6fkowYpXuX27v+u4rHP12ICPLgXYlqBUdIhlaX/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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(obj_1.get_history_bestsofar(), label='RACE-CARS')\n",
    "plt.plot(obj_2.get_history_bestsofar(), label='SRACOS')\n",
    "plt.legend()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "`tys` is a list object, representing the continuity of each dimension. `True` means continuous dimension and `False` means discrete"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "continuous_size = 50\n",
    "discrete_size = 50\n",
    "dim_size = continuous_size + discrete_size\n",
    "tys = [True]*continuous_size+[False]*discrete_size\n",
    "L = np.random.uniform(1, 2, discrete_size)\n",
    "def obj(xx):\n",
    "    x = np.array(xx.get_x())\n",
    "    return ackley(x[:continuous_size])+np.dot(L, np.abs(x[continuous_size:]))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[zoopt] x: [0.19222271613412964, 0.2066756559698969, 0.1759256842445558, 0.19811684138761887, 0.1868102240697186, 0.21505726053163104, 0.19340840665835135, 0.2276510281176326, 0.21925891477693227, 0.18838901154060805, 0.1802434167627447, 0.1815538364518026, 0.20881171221774786, 0.20712058996854638, 0.2856427193839438, 0.21315158518170624, 0.24513078237799196, 0.1990301566396181, 0.15358549638888536, 0.17040788919510902, 0.22501993273756493, 0.2557933927391251, 0.19713594053782585, 0.23236146314045256, 0.1881870035689516, 0.20109053053952608, 0.23061689885075254, 0.19539418026676, 0.19860288548968352, 0.19733784616281297, 0.1469578888102363, 0.2146577513746209, 0.14943069269086595, 0.24779233459206673, 0.1512880462162472, 0.20962783350368913, 0.19552837720239047, 0.14221724065252017, 0.2091947692603269, 0.23996927335107798, 0.16006523828929195, 0.28006853497072803, 0.19616418945960723, 0.21794981246290204, 0.19829466838287343, 0.19763864589855326, 0.13068307653340397, 0.20197432296012494, 0.1921044219293347, 0.2015534444044203, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0]\n",
      "[zoopt] value: 2.6808834917876676\n",
      "[zoopt] x: [0.2210421692646085, 0.21687207883947401, 0.2166662246657871, 0.22260027486246137, 0.3314945810049583, 0.1268018480596913, 0.16959789730955355, 0.0991947815616323, 0.11654559944297493, 0.21061311878595568, 0.18376574114913558, 0.17347990569026517, 0.17433888187604074, 0.14633969673586877, 0.2069176251415903, 0.25536787001657757, 0.0788493003655204, 0.3292649277577946, 0.24441794605712164, 0.28927331581870885, 0.1851944727889796, 0.20952588209277234, 0.029259306373693228, 0.1422639662655656, 0.23607113008332847, 0.1394653834902213, 0.22932978508705748, 0.2550442759681868, 0.12118742732806842, 0.2109178209017628, 0.048463603104285324, 0.38259838546878466, 0.27158489034347433, 0.1832422656072361, 0.0924475283406454, 0.28034718717091645, 0.2626726192224771, 0.3498579683635641, 0.22916313686507617, 0.2279152222936014, 0.2047937104844313, 0.23106661727154898, 0.24382200683402688, 0.1971266747793663, 0.16854229303263701, 0.15773257407245667, 0.21201545906860053, 0.24967956642102718, 0.12687950528832181, 0.2615264823974579, 0, -1, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 1, -1, 1, 0, 0, 0, 0, -1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, -1, 1, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 1, 1]\n",
      "[zoopt] value: 26.329047426838656\n"
     ]
    }
   ],
   "source": [
    "dim_3 = Dimension(dim_size, [[-1, 1]]*continuous_size+[[-10, 10]]*discrete_size, tys)\n",
    "dim_4 = Dimension(dim_size, [[-1, 1]]*continuous_size+[[-10, 10]]*discrete_size, tys)\n",
    "obj_3 = Objective(obj, dim_3)\n",
    "obj_4 = Objective(obj, dim_4)\n",
    "# RACE-CARS\n",
    "param_3 = Parameter(budget=3000, shrinking_rate=0.95, shrinking_freq=0.01)\n",
    "sol_3 = Opt.min(obj_3, param_3)\n",
    "# SRACOS\n",
    "param_4 = Parameter(budget=3000)\n",
    "sol_4 = Opt.min(obj_4, param_4)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7f597ed56d40>"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(obj_3.get_history_bestsofar(), label='RACE-CARS')\n",
    "plt.plot(obj_4.get_history_bestsofar(), label='SRACOS')\n",
    "plt.legend()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "sci_compu",
   "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.10.12"
  },
  "orig_nbformat": 4
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
