{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "ff153539",
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import torch\n",
    "import multiprocessing\n",
    "from joblib import Parallel, delayed\n",
    "\n",
    "tkwargs = {\n",
    "    \"dtype\": torch.double,\n",
    "    \"device\": torch.device(\"cpu\"),\n",
    "}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "85a49017",
   "metadata": {},
   "outputs": [],
   "source": [
    "from botorch.models.gp_regression import FixedNoiseGP\n",
    "from botorch.models.model_list_gp_regression import ModelListGP\n",
    "from botorch.models.transforms.outcome import Standardize\n",
    "from gpytorch.mlls.sum_marginal_log_likelihood import SumMarginalLogLikelihood\n",
    "from botorch.utils.transforms import unnormalize, normalize\n",
    "from botorch.utils.sampling import draw_sobol_samples\n",
    "from botorch.acquisition import AcquisitionFunction\n",
    "from botorch.models import SingleTaskGP\n",
    "from gpytorch.mlls import ExactMarginalLogLikelihood\n",
    "from botorch import fit_gpytorch_mll\n",
    "from botorch.test_functions.multi_objective import DTLZ2, GMM, ZDT2, VehicleSafety\n",
    "#NOISE_SE = torch.tensor([0.00, 0.00, 0.00], **tkwargs)\n",
    "NOISE_SE = torch.tensor([0.00, 0.00], **tkwargs)\n",
    "#problem = DTLZ2(num_objectives=3, dim=4, negate=True).to(**tkwargs)\n",
    "problem = GMM(negate=True).to(**tkwargs)\n",
    "#problem = ZDT2(dim=6, negate=True).to(**tkwargs)\n",
    "#problem = VehicleSafety(negate=True).to(**tkwargs)\n",
    "def initialize_model(train_x, train_obj):\n",
    "    # define models for objective and constraint\n",
    "    #train_x = normalize(train_x, problem.bounds)\n",
    "    models = []\n",
    "    for i in range(train_obj.shape[-1]):\n",
    "        train_y = train_obj[..., i : i + 1]\n",
    "        train_yvar = torch.full_like(train_y, NOISE_SE[i] ** 2)\n",
    "        models.append(\n",
    "            FixedNoiseGP(\n",
    "                train_x, train_y, train_yvar, outcome_transform=Standardize(m=1)\n",
    "            )\n",
    "        )\n",
    "    model = ModelListGP(*models)\n",
    "    mll = SumMarginalLogLikelihood(model.likelihood, model)\n",
    "    return mll, model\n",
    "\n",
    "def generate_initial_data(n=10, seed=42):\n",
    "    # generate training data\n",
    "    train_x = draw_sobol_samples(bounds=problem.bounds, n=n, q=1, seed=seed).squeeze(1)\n",
    "    train_obj_true = problem(train_x)\n",
    "    train_obj = train_obj_true + torch.randn_like(train_obj_true) * NOISE_SE\n",
    "    return train_x, train_obj, train_obj_true"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "47e97107",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "from botorch.models.model import Model\n",
    "from typing import Any, Callable, Optional\n",
    "from botorch.optim.optimize import optimize_acqf, optimize_acqf_list\n",
    "from botorch.acquisition.objective import GenericMCObjective\n",
    "from botorch.utils.multi_objective.scalarization import get_chebyshev_scalarization\n",
    "from botorch.utils.multi_objective.box_decompositions.non_dominated import (\n",
    "    FastNondominatedPartitioning,\n",
    ")\n",
    "from botorch.utils.multi_objective.box_decompositions.dominated import (\n",
    "    DominatedPartitioning,\n",
    ")\n",
    "from EHVI_batch_filling import qExpectedHypervolumeImprovementFilling\n",
    "from botorch.utils.sampling import sample_simplex\n",
    "from botorch.acquisition.multi_objective.utils import (\n",
    "    sample_optimal_points,\n",
    "    random_search_optimizer,\n",
    "    compute_sample_box_decomposition\n",
    ")\n",
    "from botorch.sampling.normal import SobolQMCNormalSampler\n",
    "from torch import Tensor\n",
    "from botorch.utils.multi_objective.pareto import is_non_dominated\n",
    "\n",
    "\n",
    "NUM_RESTARTS = 10 \n",
    "RAW_SAMPLES = 512 \n",
    "\n",
    "\n",
    "def optimize_qehvi_and_get_observation(model, train_x, train_obj, sampler, X_test, q):\n",
    "    \"\"\"Optimizes the qEHVI acquisition function, and returns a new candidate and observation.\"\"\"\n",
    "    # partition non-dominated space into disjoint rectangles\n",
    "    with torch.no_grad():\n",
    "        pred = model.posterior(train_x).mean\n",
    "        \n",
    "    partitioning = FastNondominatedPartitioning(\n",
    "        ref_point=torch.tensor(problem.ref_point).reshape(-1).to(**tkwargs),\n",
    "        Y=pred,\n",
    "    )\n",
    "    \n",
    "    acq_func = qExpectedHypervolumeImprovementFilling(\n",
    "        model=model,\n",
    "        previous_X = train_x,\n",
    "        ref_point=torch.tensor(problem.ref_point).reshape(-1).to(**tkwargs),\n",
    "        partitioning=partitioning,\n",
    "        sampler=sampler,\n",
    "    )\n",
    "    # optimize\n",
    "    candidates, _ = optimize_acqf(\n",
    "        acq_function=acq_func,\n",
    "        bounds=problem.bounds,\n",
    "        q=q,\n",
    "        num_restarts=NUM_RESTARTS,\n",
    "        raw_samples=RAW_SAMPLES, \n",
    "        options={\"batch_limit\": 5, \"maxiter\": 200},\n",
    "        sequential=False,\n",
    "        # set equality constraints to make sure sum of composition is 1\n",
    "        #equality_constraints=[(indices, coefficients, rhs)]\n",
    "        #inequality_constraints=... if needed\n",
    "    )\n",
    "    \n",
    "    # Compute pairwise distances: result shape (M, N)\n",
    "    distances = np.linalg.norm(X_test[None, :, :] - candidates[:, None, :], axis=2)\n",
    "\n",
    "    # For each candidate, find the nearest X_test index\n",
    "    nearest_indices = np.argmin(distances, axis=1)\n",
    "    \n",
    "    new_x = X_test[nearest_indices].reshape(q, N_dim)\n",
    "    new_obj_true = problem(new_x)    \n",
    "    new_obj = new_obj_true\n",
    "    \n",
    "    return new_x, new_obj, new_obj_true"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "4bfb272c",
   "metadata": {},
   "outputs": [],
   "source": [
    "def distance_XX(X, X_star):\n",
    "    d_sum = 0\n",
    "    for x_star in X_star:\n",
    "        d_list = torch.norm(X - x_star, dim=1)\n",
    "        d_sum += torch.min(d_list)\n",
    "    return d_sum / len(X_star)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "b763fe2b",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration: 1\n",
      "new candidats: tensor([[2.6796e-02, 2.2705e-01],\n",
      "        [4.6956e-01, 6.0016e-01],\n",
      "        [1.9809e-01, 3.2427e-01],\n",
      "        [3.2274e-02, 7.2031e-02],\n",
      "        [4.8001e-02, 4.6881e-04]], dtype=torch.float64)\n",
      "new obj: tensor([[0.3405, 0.4840],\n",
      "        [0.4332, 0.0838],\n",
      "        [0.4122, 0.3358],\n",
      "        [0.2866, 0.4003],\n",
      "        [0.2277, 0.3021]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.05219038]\n",
      "Time: 7.0188187239691615\n",
      "Iteration: 2\n",
      "new candidats: tensor([[0.3989, 0.7484],\n",
      "        [0.1646, 0.1984],\n",
      "        [0.0862, 0.4687],\n",
      "        [0.0791, 0.2182],\n",
      "        [0.4811, 0.7109]], dtype=torch.float64)\n",
      "new obj: tensor([[0.3806, 0.6158],\n",
      "        [0.4922, 0.4470],\n",
      "        [0.1725, 0.2022],\n",
      "        [0.4147, 0.4974],\n",
      "        [0.6907, 0.3410]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.10907994]\n",
      "Time: 8.840229735942557\n",
      "Iteration: 3\n",
      "new candidats: tensor([[0.4875, 0.6688],\n",
      "        [0.0588, 0.5403],\n",
      "        [0.4543, 0.8078],\n",
      "        [0.1571, 0.6149],\n",
      "        [0.4840, 0.8000]], dtype=torch.float64)\n",
      "new obj: tensor([[0.6730, 0.2055],\n",
      "        [0.0917, 0.1175],\n",
      "        [0.3549, 0.6031],\n",
      "        [0.0582, 0.0595],\n",
      "        [0.4210, 0.4925]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.1092723]\n",
      "Time: 6.535311441868544\n",
      "Iteration: 4\n",
      "new candidats: tensor([[0.4424, 0.7422],\n",
      "        [0.8172, 0.2067],\n",
      "        [0.2324, 0.5059],\n",
      "        [0.8645, 0.7770],\n",
      "        [0.4424, 0.7422]], dtype=torch.float64)\n",
      "new obj: tensor([[5.4838e-01, 5.4383e-01],\n",
      "        [6.9246e-01, 5.8457e-02],\n",
      "        [1.5621e-01, 1.1395e-01],\n",
      "        [7.0948e-04, 1.6996e-05],\n",
      "        [5.4838e-01, 5.4383e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.12916157]\n",
      "Time: 7.982243694132194\n",
      "Iteration: 5\n",
      "new candidats: tensor([[0.9583, 0.1325],\n",
      "        [0.1562, 0.4775],\n",
      "        [0.4424, 0.7422],\n",
      "        [0.5367, 0.8188],\n",
      "        [0.5564, 0.6185]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1596, 0.0543],\n",
      "        [0.1866, 0.1743],\n",
      "        [0.5484, 0.5438],\n",
      "        [0.3242, 0.2705],\n",
      "        [0.4397, 0.0426]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.12916157]\n",
      "Time: 6.012533828150481\n",
      "Iteration: 6\n",
      "new candidats: tensor([[0.0959, 0.0587],\n",
      "        [0.4681, 0.8477],\n",
      "        [0.4424, 0.7422],\n",
      "        [0.6073, 0.0625],\n",
      "        [0.0155, 0.4835]], dtype=torch.float64)\n",
      "new obj: tensor([[0.3402, 0.3863],\n",
      "        [0.2246, 0.4959],\n",
      "        [0.5484, 0.5438],\n",
      "        [0.0921, 0.0107],\n",
      "        [0.1197, 0.1764]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.12916157]\n",
      "Time: 6.182825156953186\n",
      "Iteration: 7\n",
      "new candidats: tensor([[0.4424, 0.7422],\n",
      "        [0.5866, 0.0297],\n",
      "        [0.4072, 0.7911],\n",
      "        [0.6011, 0.6097],\n",
      "        [0.6517, 0.7824]], dtype=torch.float64)\n",
      "new obj: tensor([[0.5484, 0.5438],\n",
      "        [0.0706, 0.0124],\n",
      "        [0.3043, 0.6969],\n",
      "        [0.2873, 0.0169],\n",
      "        [0.1583, 0.0291]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13488095]\n",
      "Time: 5.336319040041417\n",
      "Iteration: 8\n",
      "new candidats: tensor([[0.4424, 0.7422],\n",
      "        [0.3146, 0.8127],\n",
      "        [0.2101, 0.7946],\n",
      "        [0.6311, 0.6729],\n",
      "        [0.1626, 0.7797]], dtype=torch.float64)\n",
      "new obj: tensor([[0.5484, 0.5438],\n",
      "        [0.0704, 0.4845],\n",
      "        [0.0127, 0.1198],\n",
      "        [0.2886, 0.0222],\n",
      "        [0.0091, 0.0476]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13488095]\n",
      "Time: 4.181420861044899\n",
      "Iteration: 9\n",
      "new candidats: tensor([[0.7982, 0.5823],\n",
      "        [0.5064, 0.9517],\n",
      "        [0.3632, 0.2031],\n",
      "        [0.4424, 0.7422],\n",
      "        [0.3486, 0.3297]], dtype=torch.float64)\n",
      "new obj: tensor([[5.4961e-03, 1.3001e-04],\n",
      "        [2.9550e-02, 1.2585e-01],\n",
      "        [3.5842e-01, 1.7070e-01],\n",
      "        [5.4838e-01, 5.4383e-01],\n",
      "        [3.0773e-01, 1.5359e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13488095]\n",
      "Time: 3.4420298889745027\n",
      "Iteration: 10\n",
      "new candidats: tensor([[0.4424, 0.7422],\n",
      "        [0.5825, 0.8629],\n",
      "        [0.6995, 0.5534],\n",
      "        [0.0680, 0.4152],\n",
      "        [0.3081, 0.2740]], dtype=torch.float64)\n",
      "new obj: tensor([[0.5484, 0.5438],\n",
      "        [0.1326, 0.1088],\n",
      "        [0.0381, 0.0011],\n",
      "        [0.2254, 0.2803],\n",
      "        [0.4034, 0.2298]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13488095]\n",
      "Time: 6.822501098038629\n",
      "Iteration: 11\n",
      "new candidats: tensor([[0.0378, 0.4597],\n",
      "        [0.4424, 0.7422],\n",
      "        [0.5762, 0.4477],\n",
      "        [0.4424, 0.7422],\n",
      "        [0.9667, 0.7124]], dtype=torch.float64)\n",
      "new obj: tensor([[1.5487e-01, 2.1242e-01],\n",
      "        [5.4838e-01, 5.4383e-01],\n",
      "        [6.3977e-02, 9.7399e-03],\n",
      "        [5.4838e-01, 5.4383e-01],\n",
      "        [2.5424e-05, 8.6215e-07]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13488095]\n",
      "Time: 4.525263519957662\n",
      "Iteration: 12\n",
      "new candidats: tensor([[0.5895, 0.3639],\n",
      "        [0.4626, 0.9869],\n",
      "        [0.4424, 0.7422],\n",
      "        [0.1058, 0.2338],\n",
      "        [0.9962, 0.4104]], dtype=torch.float64)\n",
      "new obj: tensor([[7.5224e-02, 1.2262e-02],\n",
      "        [1.0738e-02, 1.0034e-01],\n",
      "        [5.4838e-01, 5.4383e-01],\n",
      "        [4.4114e-01, 4.8509e-01],\n",
      "        [1.1267e-02, 6.3316e-06]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13488095]\n",
      "Time: 15.873099128017202\n",
      "Iteration: 13\n",
      "new candidats: tensor([[0.4072, 0.7911],\n",
      "        [0.7877, 0.1209],\n",
      "        [0.2808, 0.9214],\n",
      "        [0.4424, 0.7422],\n",
      "        [0.8535, 0.2219]], dtype=torch.float64)\n",
      "new obj: tensor([[0.3043, 0.6969],\n",
      "        [0.5142, 0.2961],\n",
      "        [0.0061, 0.1651],\n",
      "        [0.5484, 0.5438],\n",
      "        [0.5948, 0.0361]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13488095]\n",
      "Time: 4.073474816046655\n",
      "Iteration: 14\n",
      "new candidats: tensor([[0.1027, 0.5413],\n",
      "        [0.9659, 0.7199],\n",
      "        [0.6615, 0.9143],\n",
      "        [0.9984, 0.9024],\n",
      "        [0.4424, 0.7422]], dtype=torch.float64)\n",
      "new obj: tensor([[1.0366e-01, 1.1536e-01],\n",
      "        [2.4670e-05, 8.0551e-07],\n",
      "        [1.9189e-02, 1.1934e-02],\n",
      "        [7.2741e-07, 2.8893e-08],\n",
      "        [5.4838e-01, 5.4383e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13488095]\n",
      "Time: 4.779727531131357\n",
      "Iteration: 15\n",
      "new candidats: tensor([[0.0073, 0.3359],\n",
      "        [0.8201, 0.0283],\n",
      "        [0.9380, 0.0665],\n",
      "        [0.7645, 0.1707],\n",
      "        [0.4424, 0.7422]], dtype=torch.float64)\n",
      "new obj: tensor([[0.2496, 0.3779],\n",
      "        [0.1598, 0.2096],\n",
      "        [0.1113, 0.1189],\n",
      "        [0.6388, 0.0608],\n",
      "        [0.5484, 0.5438]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13488095]\n",
      "Time: 5.127809762023389\n",
      "Iteration: 16\n",
      "new candidats: tensor([[0.1760, 0.1757],\n",
      "        [0.8003, 0.6989],\n",
      "        [0.4424, 0.7422],\n",
      "        [0.4925, 0.1450],\n",
      "        [0.2472, 0.6337]], dtype=torch.float64)\n",
      "new obj: tensor([[4.9278e-01, 4.3126e-01],\n",
      "        [7.9481e-03, 1.6737e-04],\n",
      "        [5.4838e-01, 5.4383e-01],\n",
      "        [1.7061e-01, 5.1726e-02],\n",
      "        [6.9325e-02, 8.6782e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13488095]\n",
      "Time: 5.657076179049909\n",
      "Iteration: 1\n",
      "new candidats: tensor([[0.4433, 0.7164],\n",
      "        [0.4988, 0.6640],\n",
      "        [0.4566, 0.9830],\n",
      "        [0.4820, 0.8849],\n",
      "        [0.3555, 0.9954]], dtype=torch.float64)\n",
      "new obj: tensor([[0.5966, 0.4524],\n",
      "        [0.6672, 0.1739],\n",
      "        [0.0117, 0.1118],\n",
      "        [0.1252, 0.3489],\n",
      "        [0.0033, 0.0940]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.1225353]\n",
      "Time: 9.621368517167866\n",
      "Iteration: 2\n",
      "new candidats: tensor([[0.8296, 0.6075],\n",
      "        [0.4455, 0.7249],\n",
      "        [0.3860, 0.7651],\n",
      "        [0.2758, 0.9931],\n",
      "        [0.6502, 0.4908]], dtype=torch.float64)\n",
      "new obj: tensor([[2.6058e-03, 5.7055e-05],\n",
      "        [5.9261e-01, 4.7863e-01],\n",
      "        [3.0155e-01, 6.5483e-01],\n",
      "        [9.5205e-04, 5.0284e-02],\n",
      "        [4.2502e-02, 2.8421e-03]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.12849417]\n",
      "Time: 5.858206333825365\n",
      "Iteration: 3\n",
      "new candidats: tensor([[0.4962, 0.7150],\n",
      "        [0.4248, 0.0197],\n",
      "        [0.0017, 0.1993],\n",
      "        [0.7460, 0.1725],\n",
      "        [0.4197, 0.3964]], dtype=torch.float64)\n",
      "new obj: tensor([[0.6977, 0.3090],\n",
      "        [0.1772, 0.0691],\n",
      "        [0.3058, 0.4717],\n",
      "        [0.5946, 0.0298],\n",
      "        [0.1740, 0.0671]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13738202]\n",
      "Time: 5.861928592901677\n",
      "Iteration: 4\n",
      "new candidats: tensor([[0.0036, 0.0102],\n",
      "        [0.7076, 0.6125],\n",
      "        [0.4912, 0.7406],\n",
      "        [0.4811, 0.5113],\n",
      "        [0.1356, 0.2283]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1968, 0.3017],\n",
      "        [0.0577, 0.0014],\n",
      "        [0.6467, 0.3886],\n",
      "        [0.1715, 0.0258],\n",
      "        [0.4700, 0.4691]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.1413703]\n",
      "Time: 7.454198008170351\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration: 5\n",
      "new candidats: tensor([[0.4405, 0.7620],\n",
      "        [0.1672, 0.7920],\n",
      "        [0.1950, 0.5215],\n",
      "        [0.0476, 0.7026],\n",
      "        [0.4212, 0.7755]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4886, 0.6017],\n",
      "        [0.0080, 0.0520],\n",
      "        [0.1387, 0.1148],\n",
      "        [0.0159, 0.0220],\n",
      "        [0.3900, 0.6660]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.1484994]\n",
      "Time: 4.404617232969031\n",
      "Iteration: 6\n",
      "new candidats: tensor([[0.4974, 0.3810],\n",
      "        [0.4455, 0.7249],\n",
      "        [0.2860, 0.9659],\n",
      "        [0.5246, 0.4084],\n",
      "        [0.4962, 0.7150]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1156, 0.0339],\n",
      "        [0.5926, 0.4786],\n",
      "        [0.0024, 0.0925],\n",
      "        [0.0893, 0.0221],\n",
      "        [0.6977, 0.3090]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.1484994]\n",
      "Time: 6.565137424040586\n",
      "Iteration: 7\n",
      "new candidats: tensor([[0.9975, 0.3169],\n",
      "        [0.4212, 0.7755],\n",
      "        [0.4405, 0.7620],\n",
      "        [0.3641, 0.0251],\n",
      "        [0.2431, 0.9327]], dtype=torch.float64)\n",
      "new obj: tensor([[5.0390e-02, 9.7423e-06],\n",
      "        [3.9005e-01, 6.6600e-01],\n",
      "        [4.8855e-01, 6.0171e-01],\n",
      "        [2.4367e-01, 1.1572e-01],\n",
      "        [2.3140e-03, 8.5078e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.1484994]\n",
      "Time: 10.972735825926065\n",
      "Iteration: 8\n",
      "new candidats: tensor([[0.4833, 0.8495],\n",
      "        [0.2144, 0.4986],\n",
      "        [0.5064, 0.6171],\n",
      "        [0.4405, 0.7620],\n",
      "        [0.7782, 0.9646]], dtype=torch.float64)\n",
      "new obj: tensor([[2.2676e-01, 4.3806e-01],\n",
      "        [1.6521e-01, 1.2774e-01],\n",
      "        [5.1292e-01, 7.9821e-02],\n",
      "        [4.8855e-01, 6.0171e-01],\n",
      "        [4.4600e-04, 1.4231e-04]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.1484994]\n",
      "Time: 4.154488258995116\n",
      "Iteration: 9\n",
      "new candidats: tensor([[0.9060, 0.4960],\n",
      "        [0.1020, 0.4403],\n",
      "        [0.3200, 0.3716],\n",
      "        [0.0359, 0.4994],\n",
      "        [0.4405, 0.7620]], dtype=torch.float64)\n",
      "new obj: tensor([[5.3555e-03, 2.6915e-05],\n",
      "        [2.1547e-01, 2.3988e-01],\n",
      "        [2.8965e-01, 1.5845e-01],\n",
      "        [1.1646e-01, 1.6074e-01],\n",
      "        [4.8855e-01, 6.0171e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.1484994]\n",
      "Time: 6.572271161945537\n",
      "Iteration: 10\n",
      "new candidats: tensor([[0.4700, 0.9049],\n",
      "        [0.8158, 0.6432],\n",
      "        [0.2979, 0.4630],\n",
      "        [0.4912, 0.7406],\n",
      "        [0.9337, 0.6001]], dtype=torch.float64)\n",
      "new obj: tensor([[8.2356e-02, 3.1611e-01],\n",
      "        [4.4770e-03, 7.7019e-05],\n",
      "        [1.9226e-01, 1.1141e-01],\n",
      "        [6.4671e-01, 3.8862e-01],\n",
      "        [2.1134e-04, 6.0860e-06]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.1484994]\n",
      "Time: 5.910075163003057\n",
      "Iteration: 11\n",
      "new candidats: tensor([[0.2481, 0.6490],\n",
      "        [0.3630, 0.0415],\n",
      "        [0.9873, 0.9858],\n",
      "        [0.4948, 0.7959],\n",
      "        [0.4405, 0.7620]], dtype=torch.float64)\n",
      "new obj: tensor([[6.4843e-02, 9.7694e-02],\n",
      "        [2.6202e-01, 1.2489e-01],\n",
      "        [1.7842e-07, 1.0059e-08],\n",
      "        [4.4342e-01, 4.4666e-01],\n",
      "        [4.8855e-01, 6.0171e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.1484994]\n",
      "Time: 7.393218940123916\n",
      "Iteration: 12\n",
      "new candidats: tensor([[0.5746, 0.8340],\n",
      "        [0.6814, 0.4887],\n",
      "        [0.1405, 0.5426],\n",
      "        [0.4405, 0.7620],\n",
      "        [0.0476, 0.7026]], dtype=torch.float64)\n",
      "new obj: tensor([[0.2164, 0.1439],\n",
      "        [0.0296, 0.0018],\n",
      "        [0.1106, 0.1092],\n",
      "        [0.4886, 0.6017],\n",
      "        [0.0159, 0.0220]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.1484994]\n",
      "Time: 5.625517359934747\n",
      "Iteration: 13\n",
      "new candidats: tensor([[0.7936, 0.8608],\n",
      "        [0.9729, 0.4373],\n",
      "        [0.4405, 0.7620],\n",
      "        [0.5485, 0.1010],\n",
      "        [0.1844, 0.4248]], dtype=torch.float64)\n",
      "new obj: tensor([[2.6094e-03, 2.5483e-04],\n",
      "        [9.5412e-03, 9.2835e-06],\n",
      "        [4.8855e-01, 6.0171e-01],\n",
      "        [1.1508e-01, 2.5287e-02],\n",
      "        [2.6514e-01, 2.2576e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.1484994]\n",
      "Time: 8.169335299171507\n",
      "Iteration: 14\n",
      "new candidats: tensor([[0.5863, 0.6182],\n",
      "        [0.4550, 0.4514],\n",
      "        [0.2832, 0.1736],\n",
      "        [0.4405, 0.7620],\n",
      "        [0.5298, 0.4346]], dtype=torch.float64)\n",
      "new obj: tensor([[0.3539, 0.0257],\n",
      "        [0.1295, 0.0370],\n",
      "        [0.4546, 0.2808],\n",
      "        [0.4886, 0.6017],\n",
      "        [0.0855, 0.0183]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.1484994]\n",
      "Time: 8.791340027935803\n",
      "Iteration: 15\n",
      "new candidats: tensor([[0.4405, 0.7620],\n",
      "        [0.5524, 0.6665],\n",
      "        [0.7085, 0.8945],\n",
      "        [0.2530, 0.1357],\n",
      "        [0.0512, 0.6478]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4886, 0.6017],\n",
      "        [0.5839, 0.0917],\n",
      "        [0.0121, 0.0039],\n",
      "        [0.4584, 0.3124],\n",
      "        [0.0309, 0.0411]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.1484994]\n",
      "Time: 6.978015372995287\n",
      "Iteration: 16\n",
      "new candidats: tensor([[0.9190, 0.0023],\n",
      "        [0.4405, 0.7620],\n",
      "        [0.5479, 0.5908],\n",
      "        [0.1982, 0.4969],\n",
      "        [0.9279, 0.7929]], dtype=torch.float64)\n",
      "new obj: tensor([[4.9300e-02, 4.0029e-02],\n",
      "        [4.8855e-01, 6.0171e-01],\n",
      "        [3.6033e-01, 3.0578e-02],\n",
      "        [1.6700e-01, 1.3613e-01],\n",
      "        [5.6213e-05, 1.2431e-06]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.1484994]\n",
      "Time: 6.727831912925467\n",
      "Iteration: 1\n",
      "new candidats: tensor([[0.8028, 0.1853],\n",
      "        [0.0572, 0.1279],\n",
      "        [0.9998, 0.0178],\n",
      "        [0.7418, 0.0894],\n",
      "        [0.0265, 0.2083]], dtype=torch.float64)\n",
      "new obj: tensor([[0.6975, 0.1052],\n",
      "        [0.3632, 0.4676],\n",
      "        [0.0182, 0.0020],\n",
      "        [0.3317, 0.0674],\n",
      "        [0.3429, 0.4879]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.06342642]\n",
      "Time: 14.601181250996888\n",
      "Iteration: 2\n",
      "new candidats: tensor([[0.4172, 0.5523],\n",
      "        [0.6226, 0.1968],\n",
      "        [0.4140, 0.8843],\n",
      "        [0.3595, 0.7059],\n",
      "        [0.7653, 0.3965]], dtype=torch.float64)\n",
      "new obj: tensor([[0.2258, 0.0556],\n",
      "        [0.1987, 0.0110],\n",
      "        [0.0893, 0.4863],\n",
      "        [0.2752, 0.4213],\n",
      "        [0.1016, 0.0007]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.06342642]\n",
      "Time: 6.992443897994235\n",
      "Iteration: 3\n",
      "new candidats: tensor([[0.9516, 0.9582],\n",
      "        [0.9741, 0.0843],\n",
      "        [0.0909, 0.0571],\n",
      "        [0.1351, 0.1950],\n",
      "        [0.4431, 0.7388]], dtype=torch.float64)\n",
      "new obj: tensor([[1.2563e-06, 7.2380e-08],\n",
      "        [7.9065e-02, 3.0712e-02],\n",
      "        [3.3383e-01, 3.8525e-01],\n",
      "        [4.7417e-01, 4.7409e-01],\n",
      "        [5.5864e-01, 5.3121e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.11589741]\n",
      "Time: 7.479302003979683\n",
      "Iteration: 4\n",
      "new candidats: tensor([[0.4314, 0.7725],\n",
      "        [0.1932, 0.2029],\n",
      "        [0.6932, 0.9459],\n",
      "        [0.7247, 0.3819],\n",
      "        [0.3662, 0.9857]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4295, 0.6433],\n",
      "        [0.4997, 0.4136],\n",
      "        [0.0053, 0.0033],\n",
      "        [0.1117, 0.0016],\n",
      "        [0.0050, 0.1179]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.12714005]\n",
      "Time: 6.359485721914098\n",
      "Iteration: 5\n",
      "new candidats: tensor([[0.7315, 0.6642],\n",
      "        [0.4712, 0.7379],\n",
      "        [0.4434, 0.7700],\n",
      "        [0.2015, 0.1719],\n",
      "        [0.2782, 0.2957]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0461, 0.0013],\n",
      "        [0.6303, 0.4499],\n",
      "        [0.4708, 0.6106],\n",
      "        [0.4951, 0.3989],\n",
      "        [0.4132, 0.2594]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14681788]\n",
      "Time: 4.127873759018257\n",
      "Iteration: 6\n",
      "new candidats: tensor([[0.6909, 0.4477],\n",
      "        [0.4712, 0.7379],\n",
      "        [0.0610, 0.9417],\n",
      "        [0.0586, 0.6772],\n",
      "        [0.2474, 0.4824]], dtype=torch.float64)\n",
      "new obj: tensor([[3.4093e-02, 1.8972e-03],\n",
      "        [6.3028e-01, 4.4994e-01],\n",
      "        [4.0788e-04, 1.3363e-03],\n",
      "        [2.2637e-02, 2.9938e-02],\n",
      "        [1.8205e-01, 1.2586e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14681788]\n",
      "Time: 8.506414951989427\n",
      "Iteration: 7\n",
      "new candidats: tensor([[0.3766, 0.5481],\n",
      "        [0.0968, 0.8131],\n",
      "        [0.0982, 0.7431],\n",
      "        [0.4712, 0.7379],\n",
      "        [0.4224, 0.7685]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1776, 0.0625],\n",
      "        [0.0041, 0.0115],\n",
      "        [0.0112, 0.0187],\n",
      "        [0.6303, 0.4499],\n",
      "        [0.4144, 0.6515]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14751441]\n",
      "Time: 3.833571946946904\n",
      "Iteration: 8\n",
      "new candidats: tensor([[0.5690, 0.6491],\n",
      "        [0.0135, 0.9360],\n",
      "        [0.4431, 0.7388],\n",
      "        [0.6795, 0.0456],\n",
      "        [0.4712, 0.7379]], dtype=torch.float64)\n",
      "new obj: tensor([[4.9204e-01, 5.5550e-02],\n",
      "        [3.7134e-04, 7.0918e-04],\n",
      "        [5.5864e-01, 5.3121e-01],\n",
      "        [1.2379e-01, 4.7277e-03],\n",
      "        [6.3028e-01, 4.4994e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14751441]\n",
      "Time: 5.323667791904882\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration: 9\n",
      "new candidats: tensor([[0.4712, 0.7379],\n",
      "        [0.3551, 0.3608],\n",
      "        [0.9319, 0.7330],\n",
      "        [0.5438, 0.0559],\n",
      "        [0.8402, 0.5217]], dtype=torch.float64)\n",
      "new obj: tensor([[6.3028e-01, 4.4994e-01],\n",
      "        [2.6866e-01, 1.3102e-01],\n",
      "        [7.6966e-05, 1.7330e-06],\n",
      "        [9.7375e-02, 2.3329e-02],\n",
      "        [4.9033e-03, 8.3440e-05]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14751441]\n",
      "Time: 7.871689651859924\n",
      "Iteration: 10\n",
      "new candidats: tensor([[0.4961, 0.6932],\n",
      "        [0.2574, 0.8087],\n",
      "        [0.9891, 0.4576],\n",
      "        [0.4712, 0.7379],\n",
      "        [0.6704, 0.8618]], dtype=torch.float64)\n",
      "new obj: tensor([[7.0584e-01, 2.5175e-01],\n",
      "        [2.5091e-02, 2.5534e-01],\n",
      "        [4.3320e-03, 5.6613e-06],\n",
      "        [6.3028e-01, 4.4994e-01],\n",
      "        [4.4348e-02, 1.4947e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14983032]\n",
      "Time: 3.9166039042174816\n",
      "Iteration: 11\n",
      "new candidats: tensor([[0.7975, 0.8766],\n",
      "        [0.3393, 0.5061],\n",
      "        [0.4771, 0.5408],\n",
      "        [0.7302, 0.1746],\n",
      "        [0.4712, 0.7379]], dtype=torch.float64)\n",
      "new obj: tensor([[1.7802e-03, 1.9558e-04],\n",
      "        [1.5099e-01, 7.0365e-02],\n",
      "        [2.3686e-01, 3.2823e-02],\n",
      "        [5.4594e-01, 1.5137e-02],\n",
      "        [6.3028e-01, 4.4994e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14983032]\n",
      "Time: 10.302207303000614\n",
      "Iteration: 12\n",
      "new candidats: tensor([[0.4431, 0.7388],\n",
      "        [0.6449, 0.0173],\n",
      "        [0.6080, 0.1734],\n",
      "        [0.4712, 0.7379],\n",
      "        [0.6270, 0.5551]], dtype=torch.float64)\n",
      "new obj: tensor([[0.5586, 0.5312],\n",
      "        [0.0674, 0.0053],\n",
      "        [0.1688, 0.0133],\n",
      "        [0.6303, 0.4499],\n",
      "        [0.1203, 0.0048]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14983032]\n",
      "Time: 6.645378567976877\n",
      "Iteration: 13\n",
      "new candidats: tensor([[0.3618, 0.8770],\n",
      "        [0.4712, 0.7379],\n",
      "        [0.2339, 0.0553],\n",
      "        [0.4314, 0.7725],\n",
      "        [0.3281, 0.2860]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0574, 0.4843],\n",
      "        [0.6303, 0.4499],\n",
      "        [0.3793, 0.2750],\n",
      "        [0.4295, 0.6433],\n",
      "        [0.3713, 0.1982]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14983032]\n",
      "Time: 6.715116902953014\n",
      "Iteration: 14\n",
      "new candidats: tensor([[0.4562, 0.4056],\n",
      "        [0.0417, 0.3490],\n",
      "        [0.4712, 0.7379],\n",
      "        [0.5982, 0.0301],\n",
      "        [0.2842, 0.0868]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1383, 0.0459],\n",
      "        [0.2770, 0.3751],\n",
      "        [0.6303, 0.4499],\n",
      "        [0.0696, 0.0107],\n",
      "        [0.3898, 0.2400]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14983032]\n",
      "Time: 6.903541432926431\n",
      "Iteration: 15\n",
      "new candidats: tensor([[0.7836, 0.2895],\n",
      "        [0.4712, 0.7379],\n",
      "        [0.9590, 0.1841],\n",
      "        [0.4235, 0.8223],\n",
      "        [0.3547, 0.2162]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4691, 0.0010],\n",
      "        [0.6303, 0.4499],\n",
      "        [0.1956, 0.0158],\n",
      "        [0.2493, 0.6650],\n",
      "        [0.3696, 0.1810]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14983032]\n",
      "Time: 3.118664624169469\n",
      "Iteration: 16\n",
      "new candidats: tensor([[0.3214, 0.3979],\n",
      "        [0.3984, 0.8250],\n",
      "        [0.2106, 0.8098],\n",
      "        [0.4712, 0.7379],\n",
      "        [0.4925, 0.9159]], dtype=torch.float64)\n",
      "new obj: tensor([[0.2564, 0.1393],\n",
      "        [0.1935, 0.6793],\n",
      "        [0.0106, 0.1196],\n",
      "        [0.6303, 0.4499],\n",
      "        [0.0681, 0.2331]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14983032]\n",
      "Time: 5.119243496097624\n",
      "Iteration: 1\n",
      "new candidats: tensor([[0.0176, 0.2813],\n",
      "        [0.9924, 0.9330],\n",
      "        [0.0119, 0.1017],\n",
      "        [0.0479, 0.0125],\n",
      "        [0.9409, 0.7784]], dtype=torch.float64)\n",
      "new obj: tensor([[3.0365e-01, 4.4477e-01],\n",
      "        [4.8756e-07, 2.1462e-08],\n",
      "        [2.8479e-01, 4.2487e-01],\n",
      "        [2.4129e-01, 3.2027e-01],\n",
      "        [3.8937e-05, 8.8575e-07]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.04565737]\n",
      "Time: 7.282190768048167\n",
      "Iteration: 2\n",
      "new candidats: tensor([[0.0098, 0.3363],\n",
      "        [0.6701, 0.3065],\n",
      "        [0.2108, 0.1918],\n",
      "        [0.1350, 0.2004],\n",
      "        [0.5812, 0.5277]], dtype=torch.float64)\n",
      "new obj: tensor([[0.2522, 0.3788],\n",
      "        [0.1984, 0.0048],\n",
      "        [0.4989, 0.3899],\n",
      "        [0.4743, 0.4743],\n",
      "        [0.1356, 0.0083]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.0686762]\n",
      "Time: 7.1225609860848635\n",
      "Iteration: 3\n",
      "new candidats: tensor([[0.8838, 0.1187],\n",
      "        [0.4098, 0.1239],\n",
      "        [0.3554, 0.8023],\n",
      "        [0.3724, 0.5515],\n",
      "        [0.5441, 0.7345]], dtype=torch.float64)\n",
      "new obj: tensor([[0.3554, 0.5190],\n",
      "        [0.2685, 0.1098],\n",
      "        [0.1497, 0.6354],\n",
      "        [0.1766, 0.0648],\n",
      "        [0.6018, 0.2008]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07144829]\n",
      "Time: 4.206325845094398\n",
      "Iteration: 4\n",
      "new candidats: tensor([[0.9593, 0.0936],\n",
      "        [0.4740, 0.7707],\n",
      "        [0.4957, 0.7454],\n",
      "        [0.7305, 0.2719],\n",
      "        [0.6647, 0.5954]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1121, 0.0638],\n",
      "        [0.5305, 0.5109],\n",
      "        [0.6348, 0.3830],\n",
      "        [0.4385, 0.0021],\n",
      "        [0.1092, 0.0035]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.10386768]\n",
      "Time: 5.087935004150495\n",
      "Iteration: 5\n",
      "new candidats: tensor([[0.0053, 0.7545],\n",
      "        [0.0266, 0.9888],\n",
      "        [0.4540, 0.7573],\n",
      "        [0.4334, 0.7688],\n",
      "        [0.9783, 0.9802]], dtype=torch.float64)\n",
      "new obj: tensor([[6.6708e-03, 1.0426e-02],\n",
      "        [1.4407e-04, 3.1531e-04],\n",
      "        [5.3894e-01, 5.5400e-01],\n",
      "        [4.4690e-01, 6.3234e-01],\n",
      "        [2.7645e-07, 1.5784e-08]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13380039]\n",
      "Time: 8.622256677830592\n",
      "Iteration: 6\n",
      "new candidats: tensor([[0.4425, 0.7214],\n",
      "        [0.9763, 0.7490],\n",
      "        [0.8552, 0.1741],\n",
      "        [0.3657, 0.5928],\n",
      "        [0.4148, 0.7839]], dtype=torch.float64)\n",
      "new obj: tensor([[5.8806e-01, 4.7244e-01],\n",
      "        [1.3562e-05, 4.3873e-07],\n",
      "        [5.8343e-01, 2.3231e-01],\n",
      "        [2.1135e-01, 1.0144e-01],\n",
      "        [3.4651e-01, 6.8502e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14413201]\n",
      "Time: 18.85604665079154\n",
      "Iteration: 7\n",
      "new candidats: tensor([[0.9686, 0.3786],\n",
      "        [0.7346, 0.1203],\n",
      "        [0.5055, 0.1275],\n",
      "        [0.5075, 0.7111],\n",
      "        [0.0193, 0.3992]], dtype=torch.float64)\n",
      "new obj: tensor([[3.4533e-02, 1.3891e-05],\n",
      "        [4.2462e-01, 4.6865e-02],\n",
      "        [1.5284e-01, 4.3729e-02],\n",
      "        [6.9963e-01, 2.6623e-01],\n",
      "        [2.0243e-01, 2.9484e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14705603]\n",
      "Time: 8.725812139222398\n",
      "Iteration: 8\n",
      "new candidats: tensor([[0.5107, 0.4652],\n",
      "        [0.3769, 0.8942],\n",
      "        [0.4516, 0.7041],\n",
      "        [0.3682, 0.2073],\n",
      "        [0.0570, 0.7855]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1066, 0.0197],\n",
      "        [0.0506, 0.4376],\n",
      "        [0.6316, 0.3902],\n",
      "        [0.3509, 0.1644],\n",
      "        [0.0054, 0.0088]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14737002]\n",
      "Time: 4.5786636560224\n",
      "Iteration: 9\n",
      "new candidats: tensor([[0.8370, 0.8916],\n",
      "        [0.7772, 0.1633],\n",
      "        [0.5075, 0.7111],\n",
      "        [0.8637, 0.5905],\n",
      "        [0.1422, 0.2764]], dtype=torch.float64)\n",
      "new obj: tensor([[3.8947e-04, 3.3621e-05],\n",
      "        [6.4518e-01, 1.0966e-01],\n",
      "        [6.9963e-01, 2.6623e-01],\n",
      "        [1.0966e-03, 2.9940e-05],\n",
      "        [4.4582e-01, 4.3552e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14737002]\n",
      "Time: 8.263920853147283\n",
      "Iteration: 10\n",
      "new candidats: tensor([[0.4891, 0.5503],\n",
      "        [0.2751, 0.2663],\n",
      "        [0.5223, 0.8710],\n",
      "        [0.8346, 0.2989],\n",
      "        [0.2219, 0.0055]], dtype=torch.float64)\n",
      "new obj: tensor([[0.2648, 0.0328],\n",
      "        [0.4411, 0.2797],\n",
      "        [0.1588, 0.2578],\n",
      "        [0.4072, 0.0005],\n",
      "        [0.3098, 0.2335]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14737002]\n",
      "Time: 4.809930646093562\n",
      "Iteration: 11\n",
      "new candidats: tensor([[0.4612, 0.1255],\n",
      "        [0.7823, 0.3656],\n",
      "        [0.5075, 0.7111],\n",
      "        [0.7810, 0.0155],\n",
      "        [0.1575, 0.3248]], dtype=torch.float64)\n",
      "new obj: tensor([[2.0059e-01, 6.8903e-02],\n",
      "        [1.8006e-01, 6.2480e-04],\n",
      "        [6.9963e-01, 2.6623e-01],\n",
      "        [1.3004e-01, 6.5318e-02],\n",
      "        [4.0242e-01, 3.7401e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14737002]\n",
      "Time: 4.831926940008998\n",
      "Iteration: 12\n",
      "new candidats: tensor([[0.8963, 0.9639],\n",
      "        [0.3371, 0.7762],\n",
      "        [0.5176, 0.3353],\n",
      "        [0.5075, 0.7111],\n",
      "        [0.8624, 0.5498]], dtype=torch.float64)\n",
      "new obj: tensor([[9.1598e-06, 8.8595e-07],\n",
      "        [1.4519e-01, 5.6149e-01],\n",
      "        [1.1884e-01, 3.2531e-02],\n",
      "        [6.9963e-01, 2.6623e-01],\n",
      "        [2.0393e-03, 4.3010e-05]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14737002]\n",
      "Time: 10.622119080973789\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration: 13\n",
      "new candidats: tensor([[0.3174, 0.9393],\n",
      "        [0.8766, 0.6826],\n",
      "        [0.4005, 0.7872],\n",
      "        [0.0780, 0.8135],\n",
      "        [0.5075, 0.7111]], dtype=torch.float64)\n",
      "new obj: tensor([[7.9955e-03, 1.8883e-01],\n",
      "        [6.6672e-04, 1.2089e-05],\n",
      "        [2.9587e-01, 6.9597e-01],\n",
      "        [3.8087e-03, 8.4139e-03],\n",
      "        [6.9963e-01, 2.6623e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14804969]\n",
      "Time: 9.820634013973176\n",
      "Iteration: 14\n",
      "new candidats: tensor([[0.0595, 0.1640],\n",
      "        [0.5001, 0.7700],\n",
      "        [0.4025, 0.7010],\n",
      "        [0.5075, 0.7111],\n",
      "        [0.9312, 0.5033]], dtype=torch.float64)\n",
      "new obj: tensor([[3.8437e-01, 4.9129e-01],\n",
      "        [5.5088e-01, 4.0638e-01],\n",
      "        [4.4833e-01, 4.3404e-01],\n",
      "        [6.9963e-01, 2.6623e-01],\n",
      "        [3.1864e-03, 1.4926e-05]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14804969]\n",
      "Time: 8.096899094060063\n",
      "Iteration: 15\n",
      "new candidats: tensor([[0.5075, 0.7111],\n",
      "        [0.7789, 0.1264],\n",
      "        [0.7092, 0.3470],\n",
      "        [0.1633, 0.4169],\n",
      "        [0.3433, 0.2427]], dtype=torch.float64)\n",
      "new obj: tensor([[0.6996, 0.2662],\n",
      "        [0.5293, 0.2223],\n",
      "        [0.1726, 0.0023],\n",
      "        [0.2731, 0.2491],\n",
      "        [0.3781, 0.1921]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14804969]\n",
      "Time: 6.24626205698587\n",
      "Iteration: 16\n",
      "new candidats: tensor([[0.5075, 0.7111],\n",
      "        [0.1465, 0.2302],\n",
      "        [0.7295, 0.7937],\n",
      "        [0.0997, 0.6904],\n",
      "        [0.9859, 0.1362]], dtype=torch.float64)\n",
      "new obj: tensor([[0.6996, 0.2662],\n",
      "        [0.4770, 0.4595],\n",
      "        [0.0326, 0.0031],\n",
      "        [0.0221, 0.0287],\n",
      "        [0.1017, 0.0134]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14804969]\n",
      "Time: 7.96500414214097\n",
      "Iteration: 1\n",
      "new candidats: tensor([[0.2178, 0.1989],\n",
      "        [0.1650, 0.3187],\n",
      "        [0.1888, 0.2727],\n",
      "        [0.8652, 0.4196],\n",
      "        [0.0514, 0.2313]], dtype=torch.float64)\n",
      "new obj: tensor([[4.9802e-01, 3.8055e-01],\n",
      "        [4.1290e-01, 3.7450e-01],\n",
      "        [4.6726e-01, 3.9228e-01],\n",
      "        [5.1895e-02, 1.0099e-04],\n",
      "        [3.7482e-01, 4.9179e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.05890259]\n",
      "Time: 8.989769186126068\n",
      "Iteration: 2\n",
      "new candidats: tensor([[0.1610, 0.1293],\n",
      "        [0.6232, 0.0366],\n",
      "        [0.1087, 0.7466],\n",
      "        [0.0720, 0.1625],\n",
      "        [0.3981, 0.9993]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4608, 0.4235],\n",
      "        [0.0768, 0.0078],\n",
      "        [0.0111, 0.0204],\n",
      "        [0.4002, 0.4913],\n",
      "        [0.0048, 0.0961]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.06331225]\n",
      "Time: 5.981582016916946\n",
      "Iteration: 3\n",
      "new candidats: tensor([[0.2082, 0.0675],\n",
      "        [0.6486, 0.6226],\n",
      "        [0.0286, 0.0160],\n",
      "        [0.2328, 0.8103],\n",
      "        [0.1228, 0.1974]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4012, 0.3163],\n",
      "        [0.1763, 0.0074],\n",
      "        [0.2268, 0.3205],\n",
      "        [0.0154, 0.1755],\n",
      "        [0.4640, 0.4829]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.06719673]\n",
      "Time: 4.816330380970612\n",
      "Iteration: 4\n",
      "new candidats: tensor([[0.0852, 0.2083],\n",
      "        [0.8681, 0.7516],\n",
      "        [0.5996, 0.5318],\n",
      "        [0.1785, 0.2127],\n",
      "        [0.8655, 0.8967]], dtype=torch.float64)\n",
      "new obj: tensor([[4.2366e-01, 4.9814e-01],\n",
      "        [7.4214e-04, 1.4755e-05],\n",
      "        [1.2122e-01, 6.4133e-03],\n",
      "        [4.9612e-01, 4.3070e-01],\n",
      "        [1.3156e-04, 9.0634e-06]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07019495]\n",
      "Time: 3.606813477817923\n",
      "Iteration: 5\n",
      "new candidats: tensor([[0.6589, 0.3013],\n",
      "        [0.0189, 0.8958],\n",
      "        [0.2790, 0.4810],\n",
      "        [0.4361, 0.0220],\n",
      "        [0.4536, 0.3891]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1865, 0.0058],\n",
      "        [0.0008, 0.0014],\n",
      "        [0.1779, 0.1100],\n",
      "        [0.1678, 0.0630],\n",
      "        [0.1484, 0.0509]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07019495]\n",
      "Time: 6.367641621967778\n",
      "Iteration: 6\n",
      "new candidats: tensor([[0.5724, 0.7119],\n",
      "        [0.4302, 0.8986],\n",
      "        [0.5031, 0.8331],\n",
      "        [0.9922, 0.4426],\n",
      "        [0.0074, 0.4038]], dtype=torch.float64)\n",
      "new obj: tensor([[5.3796e-01, 1.0815e-01],\n",
      "        [7.6941e-02, 4.1165e-01],\n",
      "        [2.8942e-01, 3.8977e-01],\n",
      "        [5.9189e-03, 5.7921e-06],\n",
      "        [1.8711e-01, 2.8324e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07019495]\n",
      "Time: 8.044255038024858\n",
      "Iteration: 7\n",
      "new candidats: tensor([[0.2638, 0.3485],\n",
      "        [0.3064, 0.2510],\n",
      "        [0.6429, 0.1682],\n",
      "        [0.4814, 0.7368],\n",
      "        [0.2968, 0.8862]], dtype=torch.float64)\n",
      "new obj: tensor([[0.3608, 0.2373],\n",
      "        [0.4202, 0.2407],\n",
      "        [0.2362, 0.0082],\n",
      "        [0.6480, 0.4131],\n",
      "        [0.0169, 0.2840]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.0990679]\n",
      "Time: 9.612630478804931\n",
      "Iteration: 8\n",
      "new candidats: tensor([[0.4257, 0.7628],\n",
      "        [0.1156, 0.6104],\n",
      "        [0.2325, 0.4289],\n",
      "        [0.7669, 0.7499],\n",
      "        [0.4376, 0.7587]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4411, 0.6340],\n",
      "        [0.0560, 0.0614],\n",
      "        [0.2568, 0.1869],\n",
      "        [0.0178, 0.0008],\n",
      "        [0.4898, 0.6009]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13459253]\n",
      "Time: 5.265257358085364\n",
      "Iteration: 9\n",
      "new candidats: tensor([[0.6694, 0.8944],\n",
      "        [0.0694, 0.6350],\n",
      "        [0.4651, 0.7293],\n",
      "        [0.5771, 0.8935],\n",
      "        [0.7101, 0.3035]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0253, 0.0119],\n",
      "        [0.0380, 0.0477],\n",
      "        [0.6372, 0.4432],\n",
      "        [0.0802, 0.0943],\n",
      "        [0.2903, 0.0026]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13891613]\n",
      "Time: 8.24675619113259\n",
      "Iteration: 10\n",
      "new candidats: tensor([[0.5228, 0.9073],\n",
      "        [0.7069, 0.7681],\n",
      "        [0.8093, 0.7662],\n",
      "        [0.4675, 0.7330],\n",
      "        [0.2700, 0.2809]], dtype=torch.float64)\n",
      "new obj: tensor([[7.9826e-02, 1.8538e-01],\n",
      "        [6.5626e-02, 6.0452e-03],\n",
      "        [4.7966e-03, 1.6220e-04],\n",
      "        [6.3481e-01, 4.4711e-01],\n",
      "        [4.3340e-01, 2.7950e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13948024]\n",
      "Time: 5.699991818051785\n",
      "Iteration: 11\n",
      "new candidats: tensor([[0.9073, 0.3538],\n",
      "        [0.7592, 0.3747],\n",
      "        [0.9591, 0.5414],\n",
      "        [0.4376, 0.7587],\n",
      "        [0.1237, 0.3199]], dtype=torch.float64)\n",
      "new obj: tensor([[1.2126e-01, 5.9049e-05],\n",
      "        [1.4693e-01, 9.0172e-04],\n",
      "        [6.7258e-04, 5.9563e-06],\n",
      "        [4.8978e-01, 6.0093e-01],\n",
      "        [3.8844e-01, 4.0303e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13948024]\n",
      "Time: 6.734762559179217\n",
      "Iteration: 12\n",
      "new candidats: tensor([[0.7815, 0.6549],\n",
      "        [0.4376, 0.7587],\n",
      "        [0.2472, 0.1888],\n",
      "        [0.4675, 0.7330],\n",
      "        [0.3252, 0.5057]], dtype=torch.float64)\n",
      "new obj: tensor([[1.2609e-02, 2.3628e-04],\n",
      "        [4.8978e-01, 6.0093e-01],\n",
      "        [4.8550e-01, 3.3714e-01],\n",
      "        [6.3481e-01, 4.4711e-01],\n",
      "        [1.5081e-01, 7.5828e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13948024]\n",
      "Time: 2.635059430031106\n",
      "Iteration: 13\n",
      "new candidats: tensor([[0.4086, 0.4546],\n",
      "        [0.4376, 0.7587],\n",
      "        [0.4772, 0.8805],\n",
      "        [0.4291, 0.7917],\n",
      "        [0.0568, 0.7713]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1518, 0.0549],\n",
      "        [0.4898, 0.6009],\n",
      "        [0.1344, 0.3761],\n",
      "        [0.3607, 0.6700],\n",
      "        [0.0066, 0.0103]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14404511]\n",
      "Time: 4.017854259815067\n",
      "Iteration: 14\n",
      "new candidats: tensor([[0.0152, 0.8789],\n",
      "        [0.1136, 0.3126],\n",
      "        [0.1401, 0.1031],\n",
      "        [0.4376, 0.7587],\n",
      "        [0.2564, 0.2922]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0010, 0.0018],\n",
      "        [0.3887, 0.4167],\n",
      "        [0.4252, 0.4181],\n",
      "        [0.4898, 0.6009],\n",
      "        [0.4321, 0.2912]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14404511]\n",
      "Time: 3.4959882800467312\n",
      "Iteration: 15\n",
      "new candidats: tensor([[0.8969, 0.0163],\n",
      "        [0.5605, 0.4107],\n",
      "        [0.7949, 0.8241],\n",
      "        [0.2934, 0.4177],\n",
      "        [0.4376, 0.7587]], dtype=torch.float64)\n",
      "new obj: tensor([[8.1712e-02, 1.1103e-01],\n",
      "        [6.9762e-02, 1.4291e-02],\n",
      "        [4.2338e-03, 2.8452e-04],\n",
      "        [2.4943e-01, 1.4839e-01],\n",
      "        [4.8978e-01, 6.0093e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14404511]\n",
      "Time: 5.561639195075259\n",
      "Iteration: 16\n",
      "new candidats: tensor([[0.6439, 0.9527],\n",
      "        [0.3274, 0.9413],\n",
      "        [0.4376, 0.7587],\n",
      "        [0.5480, 0.8682],\n",
      "        [0.6542, 0.0637]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0102, 0.0111],\n",
      "        [0.0090, 0.1984],\n",
      "        [0.4898, 0.6009],\n",
      "        [0.1521, 0.1856],\n",
      "        [0.1257, 0.0058]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14404511]\n",
      "Time: 9.207238093949854\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration: 1\n",
      "new candidats: tensor([[0.6396, 0.8211],\n",
      "        [0.4668, 0.8351],\n",
      "        [0.5291, 0.8472],\n",
      "        [0.1976, 0.4387],\n",
      "        [0.5463, 0.7475]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1274, 0.0389],\n",
      "        [0.2674, 0.5272],\n",
      "        [0.2276, 0.2723],\n",
      "        [0.2455, 0.2002],\n",
      "        [0.5644, 0.2100]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.0624635]\n",
      "Time: 6.192110595991835\n",
      "Iteration: 2\n",
      "new candidats: tensor([[0.4057, 0.5323],\n",
      "        [0.4493, 0.7704],\n",
      "        [0.4718, 0.7356],\n",
      "        [0.4417, 0.8033],\n",
      "        [0.4609, 0.5599]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1841, 0.0502],\n",
      "        [0.4845, 0.5947],\n",
      "        [0.6368, 0.4417],\n",
      "        [0.3489, 0.6424],\n",
      "        [0.2852, 0.0472]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13274649]\n",
      "Time: 9.917848018929362\n",
      "Iteration: 3\n",
      "new candidats: tensor([[0.7693, 0.1780],\n",
      "        [0.9941, 0.2105],\n",
      "        [0.4139, 0.7616],\n",
      "        [0.9433, 0.7821],\n",
      "        [0.9856, 0.0588]], dtype=torch.float64)\n",
      "new obj: tensor([[6.6049e-01, 5.7491e-02],\n",
      "        [1.0608e-01, 9.6979e-04],\n",
      "        [4.0538e-01, 6.4609e-01],\n",
      "        [3.4199e-05, 7.9091e-07],\n",
      "        [4.6253e-02, 1.2578e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13607239]\n",
      "Time: 8.562201699940488\n",
      "Iteration: 4\n",
      "new candidats: tensor([[0.0834, 0.4619],\n",
      "        [0.7765, 0.0463],\n",
      "        [0.2338, 0.9549],\n",
      "        [0.2914, 0.2773],\n",
      "        [0.4601, 0.7492]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1790, 0.2117],\n",
      "        [0.2147, 0.1342],\n",
      "        [0.0012, 0.0533],\n",
      "        [0.4181, 0.2515],\n",
      "        [0.5778, 0.5152]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.1429272]\n",
      "Time: 5.020976140163839\n",
      "Iteration: 5\n",
      "new candidats: tensor([[0.6872, 0.7001],\n",
      "        [0.4852, 0.7221],\n",
      "        [0.8302, 0.8796],\n",
      "        [0.1441, 0.6612],\n",
      "        [0.6526, 0.5977]], dtype=torch.float64)\n",
      "new obj: tensor([[1.2259e-01, 7.0692e-03],\n",
      "        [6.8169e-01, 3.6134e-01],\n",
      "        [6.0951e-04, 4.9948e-05],\n",
      "        [3.4822e-02, 4.2794e-02],\n",
      "        [1.3501e-01, 4.7228e-03]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.149228]\n",
      "Time: 7.100751565070823\n",
      "Iteration: 6\n",
      "new candidats: tensor([[0.4283, 0.7929],\n",
      "        [0.6841, 0.6332],\n",
      "        [0.1364, 0.7754],\n",
      "        [0.6115, 0.4549],\n",
      "        [0.4263, 0.2398]], dtype=torch.float64)\n",
      "new obj: tensor([[0.3548, 0.6721],\n",
      "        [0.1055, 0.0035],\n",
      "        [0.0083, 0.0286],\n",
      "        [0.0500, 0.0059],\n",
      "        [0.2591, 0.1003]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.1523721]\n",
      "Time: 5.506828170036897\n",
      "Iteration: 7\n",
      "new candidats: tensor([[0.3069, 0.7057],\n",
      "        [0.3028, 0.5443],\n",
      "        [0.3622, 0.6682],\n",
      "        [0.1754, 0.1364],\n",
      "        [0.4370, 0.7389]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1261, 0.3011],\n",
      "        [0.1293, 0.0743],\n",
      "        [0.2808, 0.2846],\n",
      "        [0.4718, 0.4137],\n",
      "        [0.5387, 0.5448]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15397273]\n",
      "Time: 5.863095601089299\n",
      "Iteration: 8\n",
      "new candidats: tensor([[0.9500, 0.5523],\n",
      "        [0.0769, 0.0632],\n",
      "        [0.0127, 0.0044],\n",
      "        [0.5485, 0.6360],\n",
      "        [0.9257, 0.6617]], dtype=torch.float64)\n",
      "new obj: tensor([[5.6238e-04, 6.6359e-06],\n",
      "        [3.2742e-01, 3.9546e-01],\n",
      "        [1.9989e-01, 2.9748e-01],\n",
      "        [5.1718e-01, 6.3188e-02],\n",
      "        [1.3127e-04, 3.9575e-06]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15397273]\n",
      "Time: 10.016176101053134\n",
      "Iteration: 9\n",
      "new candidats: tensor([[0.3982, 0.7866],\n",
      "        [0.3643, 0.2036],\n",
      "        [0.2385, 0.2636],\n",
      "        [0.3731, 0.4855],\n",
      "        [0.1581, 0.0837]], dtype=torch.float64)\n",
      "new obj: tensor([[0.2905, 0.6954],\n",
      "        [0.3568, 0.1693],\n",
      "        [0.4666, 0.3333],\n",
      "        [0.1555, 0.0621],\n",
      "        [0.4130, 0.3832]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15529647]\n",
      "Time: 6.482068123994395\n",
      "Iteration: 10\n",
      "new candidats: tensor([[0.5092, 0.3434],\n",
      "        [0.1124, 0.1218],\n",
      "        [0.2935, 0.8411],\n",
      "        [0.4852, 0.7221],\n",
      "        [0.8390, 0.6345]], dtype=torch.float64)\n",
      "new obj: tensor([[1.2192e-01, 3.4709e-02],\n",
      "        [4.2089e-01, 4.5294e-01],\n",
      "        [3.3304e-02, 3.6637e-01],\n",
      "        [6.8169e-01, 3.6134e-01],\n",
      "        [2.1436e-03, 4.0730e-05]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15529647]\n",
      "Time: 5.973870201967657\n",
      "Iteration: 11\n",
      "new candidats: tensor([[0.3982, 0.7866],\n",
      "        [0.5436, 0.1772],\n",
      "        [0.4852, 0.7221],\n",
      "        [0.3250, 0.4083],\n",
      "        [0.2859, 0.3529]], dtype=torch.float64)\n",
      "new obj: tensor([[0.2905, 0.6954],\n",
      "        [0.1390, 0.0301],\n",
      "        [0.6817, 0.3613],\n",
      "        [0.2413, 0.1292],\n",
      "        [0.3406, 0.2085]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15529647]\n",
      "Time: 7.916292778914794\n",
      "Iteration: 12\n",
      "new candidats: tensor([[0.2023, 0.7430],\n",
      "        [0.5231, 0.5251],\n",
      "        [0.1300, 0.3335],\n",
      "        [0.8096, 0.2437],\n",
      "        [0.4852, 0.7221]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0201, 0.0943],\n",
      "        [0.1840, 0.0177],\n",
      "        [0.3764, 0.3826],\n",
      "        [0.6380, 0.0086],\n",
      "        [0.6817, 0.3613]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15529647]\n",
      "Time: 7.81422556610778\n",
      "Iteration: 13\n",
      "new candidats: tensor([[0.5794, 0.4287],\n",
      "        [0.8917, 0.3587],\n",
      "        [0.4852, 0.7221],\n",
      "        [0.7825, 0.5984],\n",
      "        [0.4964, 0.1936]], dtype=torch.float64)\n",
      "new obj: tensor([[6.0396e-02, 1.0293e-02],\n",
      "        [1.3144e-01, 7.9693e-05],\n",
      "        [6.8169e-01, 3.6134e-01],\n",
      "        [8.9649e-03, 1.8169e-04],\n",
      "        [1.7366e-01, 5.1512e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15529647]\n",
      "Time: 6.704928761115298\n",
      "Iteration: 14\n",
      "new candidats: tensor([[0.7141, 0.5941],\n",
      "        [0.8549, 0.1950],\n",
      "        [0.3021, 0.6469],\n",
      "        [0.4852, 0.7221],\n",
      "        [0.0475, 0.7898]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0433, 0.0010],\n",
      "        [0.6037, 0.1147],\n",
      "        [0.1219, 0.1552],\n",
      "        [0.6817, 0.3613],\n",
      "        [0.0049, 0.0078]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15529647]\n",
      "Time: 7.736272868001834\n",
      "Iteration: 15\n",
      "new candidats: tensor([[0.3273, 0.0743],\n",
      "        [0.0389, 0.4595],\n",
      "        [0.0123, 0.3559],\n",
      "        [0.2130, 0.2584],\n",
      "        [0.4852, 0.7221]], dtype=torch.float64)\n",
      "new obj: tensor([[0.3351, 0.1794],\n",
      "        [0.1558, 0.2129],\n",
      "        [0.2376, 0.3539],\n",
      "        [0.4781, 0.3710],\n",
      "        [0.6817, 0.3613]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15529647]\n",
      "Time: 7.812308813910931\n",
      "Iteration: 16\n",
      "new candidats: tensor([[0.4718, 0.7356],\n",
      "        [0.4325, 0.5159],\n",
      "        [0.4355, 0.7640],\n",
      "        [0.0326, 0.0939],\n",
      "        [0.6761, 0.0887]], dtype=torch.float64)\n",
      "new obj: tensor([[0.6368, 0.4417],\n",
      "        [0.1754, 0.0395],\n",
      "        [0.4678, 0.6179],\n",
      "        [0.3059, 0.4268],\n",
      "        [0.2001, 0.0060]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15674303]\n",
      "Time: 4.274602479068562\n",
      "Iteration: 1\n",
      "new candidats: tensor([[0.4700, 0.8798],\n",
      "        [0.5230, 0.8334],\n",
      "        [0.0626, 0.0062],\n",
      "        [0.0186, 0.1208],\n",
      "        [0.3995, 0.2763]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1334, 0.3986],\n",
      "        [0.2811, 0.3112],\n",
      "        [0.2469, 0.3124],\n",
      "        [0.3064, 0.4473],\n",
      "        [0.2829, 0.1196]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.08457136]\n",
      "Time: 8.95078860083595\n",
      "Iteration: 2\n",
      "new candidats: tensor([[0.9983, 0.3041],\n",
      "        [0.9913, 0.1734],\n",
      "        [0.0087, 0.2620],\n",
      "        [0.3182, 0.0270],\n",
      "        [0.1625, 0.1645]], dtype=torch.float64)\n",
      "new obj: tensor([[5.7110e-02, 1.1222e-05],\n",
      "        [1.0857e-01, 4.4062e-03],\n",
      "        [3.0168e-01, 4.5474e-01],\n",
      "        [2.8887e-01, 1.5927e-01],\n",
      "        [4.8362e-01, 4.4228e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.08980236]\n",
      "Time: 7.750664476072416\n",
      "Iteration: 3\n",
      "new candidats: tensor([[0.4239, 0.2506],\n",
      "        [0.7669, 0.3654],\n",
      "        [0.2056, 0.2320],\n",
      "        [0.4658, 0.7478],\n",
      "        [0.9049, 0.3319]], dtype=torch.float64)\n",
      "new obj: tensor([[2.5939e-01, 1.0124e-01],\n",
      "        [1.7520e-01, 8.2009e-04],\n",
      "        [4.9345e-01, 3.9228e-01],\n",
      "        [5.9369e-01, 4.9373e-01],\n",
      "        [1.7007e-01, 7.4320e-05]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.12102843]\n",
      "Time: 9.725194823928177\n",
      "Iteration: 4\n",
      "new candidats: tensor([[0.4999, 0.1580],\n",
      "        [0.4951, 0.7269],\n",
      "        [0.8487, 0.9438],\n",
      "        [0.4262, 0.7804],\n",
      "        [0.4273, 0.7428]], dtype=torch.float64)\n",
      "new obj: tensor([[1.6597e-01, 4.8521e-02],\n",
      "        [6.7949e-01, 3.4256e-01],\n",
      "        [8.4500e-05, 1.0808e-05],\n",
      "        [3.8969e-01, 6.6508e-01],\n",
      "        [4.9704e-01, 5.7522e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14538924]\n",
      "Time: 7.974613731959835\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration: 5\n",
      "new candidats: tensor([[0.8569, 0.3938],\n",
      "        [0.2039, 0.6514],\n",
      "        [0.7485, 0.3884],\n",
      "        [0.7693, 0.5818],\n",
      "        [0.4811, 0.7178]], dtype=torch.float64)\n",
      "new obj: tensor([[9.2376e-02, 1.3594e-04],\n",
      "        [4.6911e-02, 6.5229e-02],\n",
      "        [1.1170e-01, 1.0176e-03],\n",
      "        [1.1125e-02, 2.4973e-04],\n",
      "        [6.8324e-01, 3.6170e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14755866]\n",
      "Time: 5.191000469960272\n",
      "Iteration: 6\n",
      "new candidats: tensor([[0.4685, 0.7180],\n",
      "        [0.8773, 0.8314],\n",
      "        [0.3616, 0.5582],\n",
      "        [0.2832, 0.9568],\n",
      "        [0.6049, 0.2341]], dtype=torch.float64)\n",
      "new obj: tensor([[6.6253e-01, 3.9792e-01],\n",
      "        [2.5021e-04, 8.5157e-06],\n",
      "        [1.7086e-01, 6.9708e-02],\n",
      "        [2.8254e-03, 1.0373e-01],\n",
      "        [1.6199e-01, 1.3781e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15005206]\n",
      "Time: 5.601570978062227\n",
      "Iteration: 7\n",
      "new candidats: tensor([[0.0695, 0.6393],\n",
      "        [0.1662, 0.3430],\n",
      "        [0.4529, 0.7569],\n",
      "        [0.7477, 0.5535],\n",
      "        [0.6625, 0.0948]], dtype=torch.float64)\n",
      "new obj: tensor([[3.6277e-02, 4.5627e-02],\n",
      "        [3.8173e-01, 3.4486e-01],\n",
      "        [5.3777e-01, 5.5603e-01],\n",
      "        [1.4798e-02, 4.1656e-04],\n",
      "        [1.8638e-01, 6.0253e-03]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15258985]\n",
      "Time: 7.574513453990221\n",
      "Iteration: 8\n",
      "new candidats: tensor([[0.6848, 0.9561],\n",
      "        [0.4685, 0.7180],\n",
      "        [0.7921, 0.3988],\n",
      "        [0.4182, 0.7941],\n",
      "        [0.8779, 0.9143]], dtype=torch.float64)\n",
      "new obj: tensor([[4.7985e-03, 3.5896e-03],\n",
      "        [6.6253e-01, 3.9792e-01],\n",
      "        [1.0062e-01, 4.5037e-04],\n",
      "        [3.2528e-01, 6.8858e-01],\n",
      "        [5.8617e-05, 4.2473e-06]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15473994]\n",
      "Time: 8.90528277005069\n",
      "Iteration: 9\n",
      "new candidats: tensor([[0.4262, 0.7804],\n",
      "        [0.4025, 0.6301],\n",
      "        [0.1072, 0.1490],\n",
      "        [0.4590, 0.8221],\n",
      "        [0.0480, 0.9280]], dtype=torch.float64)\n",
      "new obj: tensor([[3.8969e-01, 6.6508e-01],\n",
      "        [3.7054e-01, 1.7770e-01],\n",
      "        [4.3455e-01, 4.7569e-01],\n",
      "        [3.0706e-01, 5.7455e-01],\n",
      "        [4.9892e-04, 1.2892e-03]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15473994]\n",
      "Time: 7.857248644111678\n",
      "Iteration: 10\n",
      "new candidats: tensor([[0.6641, 0.2068],\n",
      "        [0.0750, 0.8769],\n",
      "        [0.4658, 0.7478],\n",
      "        [0.1633, 0.5627],\n",
      "        [0.9593, 0.7586]], dtype=torch.float64)\n",
      "new obj: tensor([[3.1115e-01, 6.1346e-03],\n",
      "        [1.3551e-03, 4.2700e-03],\n",
      "        [5.9369e-01, 4.9373e-01],\n",
      "        [9.5884e-02, 8.9152e-02],\n",
      "        [2.3037e-05, 6.1910e-07]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15473994]\n",
      "Time: 9.302142676897347\n",
      "Iteration: 11\n",
      "new candidats: tensor([[0.4057, 0.7136],\n",
      "        [0.7521, 0.6805],\n",
      "        [0.8020, 0.6421],\n",
      "        [0.4262, 0.7804],\n",
      "        [0.9472, 0.9555]], dtype=torch.float64)\n",
      "new obj: tensor([[4.5565e-01, 4.8552e-01],\n",
      "        [2.9233e-02, 7.7908e-04],\n",
      "        [6.6997e-03, 1.1589e-04],\n",
      "        [3.8969e-01, 6.6508e-01],\n",
      "        [1.5864e-06, 9.2216e-08]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15473994]\n",
      "Time: 5.716854479862377\n",
      "Iteration: 12\n",
      "new candidats: tensor([[0.3333, 0.7768],\n",
      "        [0.6066, 0.4043],\n",
      "        [0.0629, 0.2427],\n",
      "        [0.4262, 0.7804],\n",
      "        [0.5710, 0.8577]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1362, 0.5490],\n",
      "        [0.0560, 0.0081],\n",
      "        [0.3864, 0.4885],\n",
      "        [0.3897, 0.6651],\n",
      "        [0.1572, 0.1375]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15473994]\n",
      "Time: 8.45554795092903\n",
      "Iteration: 13\n",
      "new candidats: tensor([[0.1596, 0.4862],\n",
      "        [0.4262, 0.7804],\n",
      "        [0.2214, 0.8699],\n",
      "        [0.8327, 0.5702],\n",
      "        [0.5178, 0.3688]], dtype=torch.float64)\n",
      "new obj: tensor([[1.7614e-01, 1.6268e-01],\n",
      "        [3.8969e-01, 6.6508e-01],\n",
      "        [5.2323e-03, 1.1270e-01],\n",
      "        [2.4994e-03, 6.7036e-05],\n",
      "        [1.0507e-01, 2.8578e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15473994]\n",
      "Time: 9.479737780056894\n",
      "Iteration: 14\n",
      "new candidats: tensor([[0.9009, 0.0203],\n",
      "        [0.1625, 0.1645],\n",
      "        [0.4262, 0.7804],\n",
      "        [0.2399, 0.4612],\n",
      "        [0.5109, 0.4193]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0844, 0.1169],\n",
      "        [0.4836, 0.4423],\n",
      "        [0.3897, 0.6651],\n",
      "        [0.2103, 0.1492],\n",
      "        [0.0964, 0.0244]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15473994]\n",
      "Time: 8.499465994071215\n",
      "Iteration: 15\n",
      "new candidats: tensor([[0.4262, 0.7804],\n",
      "        [0.2621, 0.5483],\n",
      "        [0.1986, 0.5296],\n",
      "        [0.6595, 0.3308],\n",
      "        [0.1262, 0.8132]], dtype=torch.float64)\n",
      "new obj: tensor([[0.3897, 0.6651],\n",
      "        [0.1177, 0.0806],\n",
      "        [0.1304, 0.1070],\n",
      "        [0.1400, 0.0052],\n",
      "        [0.0046, 0.0207]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15473994]\n",
      "Time: 5.56134361308068\n",
      "Iteration: 16\n",
      "new candidats: tensor([[0.8843, 0.3668],\n",
      "        [0.6123, 0.8471],\n",
      "        [0.5215, 0.5737],\n",
      "        [0.4262, 0.7804],\n",
      "        [0.0740, 0.2166]], dtype=torch.float64)\n",
      "new obj: tensor([[1.2311e-01, 8.9190e-05],\n",
      "        [1.2660e-01, 6.5894e-02],\n",
      "        [3.3213e-01, 3.2686e-02],\n",
      "        [3.8969e-01, 6.6508e-01],\n",
      "        [4.0865e-01, 4.9817e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15473994]\n",
      "Time: 6.985130466986448\n",
      "Iteration: 1\n",
      "new candidats: tensor([[0.2186, 0.4433],\n",
      "        [0.5457, 0.0818],\n",
      "        [0.3380, 0.0119],\n",
      "        [0.1964, 0.0107],\n",
      "        [0.0883, 0.0169]], dtype=torch.float64)\n",
      "new obj: tensor([[0.2381, 0.1813],\n",
      "        [0.1080, 0.0248],\n",
      "        [0.2532, 0.1309],\n",
      "        [0.3195, 0.2617],\n",
      "        [0.2814, 0.3274]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.06036194]\n",
      "Time: 7.491549727972597\n",
      "Iteration: 2\n",
      "new candidats: tensor([[0.4161, 0.8359],\n",
      "        [0.1363, 0.2063],\n",
      "        [0.5051, 0.2791],\n",
      "        [0.0256, 0.6211],\n",
      "        [0.3713, 0.7308]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1974, 0.6487],\n",
      "        [0.4751, 0.4730],\n",
      "        [0.1511, 0.0434],\n",
      "        [0.0373, 0.0533],\n",
      "        [0.3017, 0.5334]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.06842541]\n",
      "Time: 9.347407429013401\n",
      "Iteration: 3\n",
      "new candidats: tensor([[0.9989, 0.1990],\n",
      "        [0.4250, 0.7714],\n",
      "        [0.9839, 0.0369],\n",
      "        [0.1836, 0.2016],\n",
      "        [0.6313, 0.5006]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0970, 0.0012],\n",
      "        [0.4140, 0.6530],\n",
      "        [0.0343, 0.0087],\n",
      "        [0.4983, 0.4255],\n",
      "        [0.0581, 0.0037]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.0979636]\n",
      "Time: 6.343316546175629\n",
      "Iteration: 4\n",
      "new candidats: tensor([[0.0110, 0.4525],\n",
      "        [0.7929, 0.6304],\n",
      "        [0.4432, 0.7399],\n",
      "        [0.4570, 0.7339],\n",
      "        [0.6710, 0.7304]], dtype=torch.float64)\n",
      "new obj: tensor([[1.4414e-01, 2.1571e-01],\n",
      "        [8.2122e-03, 1.4575e-04],\n",
      "        [5.5626e-01, 5.3473e-01],\n",
      "        [6.0886e-01, 4.8029e-01],\n",
      "        [1.5587e-01, 1.4136e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13608201]\n",
      "Time: 10.919551138067618\n",
      "Iteration: 5\n",
      "new candidats: tensor([[0.4246, 0.7983],\n",
      "        [0.5885, 0.7438],\n",
      "        [0.6358, 0.7875],\n",
      "        [0.1780, 0.9051],\n",
      "        [0.4947, 0.7234]], dtype=torch.float64)\n",
      "new obj: tensor([[0.3280, 0.6802],\n",
      "        [0.4318, 0.1016],\n",
      "        [0.1906, 0.0432],\n",
      "        [0.0015, 0.0351],\n",
      "        [0.6856, 0.3351]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14739054]\n",
      "Time: 6.223056948045269\n",
      "Iteration: 6\n",
      "new candidats: tensor([[0.7950, 0.8281],\n",
      "        [0.6109, 0.5961],\n",
      "        [0.4381, 0.7836],\n",
      "        [0.0210, 0.4175],\n",
      "        [0.2635, 0.8571]], dtype=torch.float64)\n",
      "new obj: tensor([[4.0178e-03, 2.8068e-04],\n",
      "        [2.2925e-01, 1.1294e-02],\n",
      "        [4.1108e-01, 6.4362e-01],\n",
      "        [1.8542e-01, 2.6857e-01],\n",
      "        [1.4592e-02, 2.3578e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14739054]\n",
      "Time: 10.191991685889661\n",
      "Iteration: 7\n",
      "new candidats: tensor([[0.4974, 0.0406],\n",
      "        [0.2956, 0.0683],\n",
      "        [0.9886, 0.8404],\n",
      "        [0.4250, 0.7714],\n",
      "        [0.2399, 0.5519]], dtype=torch.float64)\n",
      "new obj: tensor([[1.2251e-01, 3.7111e-02],\n",
      "        [3.5909e-01, 2.1304e-01],\n",
      "        [2.9572e-06, 9.7214e-08],\n",
      "        [4.1402e-01, 6.5300e-01],\n",
      "        [1.1220e-01, 8.3084e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14739054]\n",
      "Time: 5.592355101136491\n",
      "Iteration: 8\n",
      "new candidats: tensor([[0.2857, 0.1768],\n",
      "        [0.4250, 0.7714],\n",
      "        [0.5658, 0.1355],\n",
      "        [0.5178, 0.5279],\n",
      "        [0.7376, 0.6977]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4531, 0.2777],\n",
      "        [0.4140, 0.6530],\n",
      "        [0.1257, 0.0220],\n",
      "        [0.1936, 0.0193],\n",
      "        [0.0422, 0.0015]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14739054]\n",
      "Time: 7.705654626013711\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration: 9\n",
      "new candidats: tensor([[0.0586, 0.5708],\n",
      "        [0.7253, 0.4471],\n",
      "        [0.5978, 0.1637],\n",
      "        [0.4555, 0.3532],\n",
      "        [0.4250, 0.7714]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0698, 0.0896],\n",
      "        [0.0347, 0.0011],\n",
      "        [0.1529, 0.0151],\n",
      "        [0.1671, 0.0582],\n",
      "        [0.4140, 0.6530]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14739054]\n",
      "Time: 6.955867483979091\n",
      "Iteration: 10\n",
      "new candidats: tensor([[0.5669, 0.3254],\n",
      "        [0.9366, 0.2179],\n",
      "        [0.4297, 0.7066],\n",
      "        [0.8799, 0.5859],\n",
      "        [0.4250, 0.7714]], dtype=torch.float64)\n",
      "new obj: tensor([[9.7921e-02, 1.8752e-02],\n",
      "        [2.7155e-01, 9.7273e-03],\n",
      "        [5.5611e-01, 4.3707e-01],\n",
      "        [8.0492e-04, 2.2052e-05],\n",
      "        [4.1402e-01, 6.5300e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14739054]\n",
      "Time: 6.555253505939618\n",
      "Iteration: 11\n",
      "new candidats: tensor([[0.6239, 0.4251],\n",
      "        [0.6722, 0.8067],\n",
      "        [0.0983, 0.0697],\n",
      "        [0.4229, 0.1839],\n",
      "        [0.4250, 0.7714]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0473, 0.0058],\n",
      "        [0.0903, 0.0173],\n",
      "        [0.3553, 0.4003],\n",
      "        [0.2684, 0.1051],\n",
      "        [0.4140, 0.6530]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14739054]\n",
      "Time: 4.305905899964273\n",
      "Iteration: 12\n",
      "new candidats: tensor([[0.9598, 0.9147],\n",
      "        [0.4250, 0.7714],\n",
      "        [0.6549, 0.2356],\n",
      "        [0.3260, 0.0521],\n",
      "        [0.6156, 0.3855]], dtype=torch.float64)\n",
      "new obj: tensor([[2.4062e-06, 9.9075e-08],\n",
      "        [4.1402e-01, 6.5300e-01],\n",
      "        [2.6637e-01, 6.8454e-03],\n",
      "        [3.1189e-01, 1.6766e-01],\n",
      "        [6.2968e-02, 7.8868e-03]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14739054]\n",
      "Time: 6.231150028994307\n",
      "Iteration: 13\n",
      "new candidats: tensor([[0.8716, 0.4885],\n",
      "        [0.3380, 0.0119],\n",
      "        [0.6517, 0.6751],\n",
      "        [0.4250, 0.7714],\n",
      "        [0.1178, 0.4056]], dtype=torch.float64)\n",
      "new obj: tensor([[9.1535e-03, 5.7524e-05],\n",
      "        [2.5319e-01, 1.3088e-01],\n",
      "        [2.1702e-01, 1.3943e-02],\n",
      "        [4.1402e-01, 6.5300e-01],\n",
      "        [2.7082e-01, 2.8642e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14739054]\n",
      "Time: 5.387582873925567\n",
      "Iteration: 14\n",
      "new candidats: tensor([[0.4250, 0.7714],\n",
      "        [0.7104, 0.7933],\n",
      "        [0.2774, 0.2742],\n",
      "        [0.7706, 0.5788],\n",
      "        [0.4706, 0.1608]], dtype=torch.float64)\n",
      "new obj: tensor([[4.1402e-01, 6.5300e-01],\n",
      "        [4.9815e-02, 5.6928e-03],\n",
      "        [4.3315e-01, 2.7271e-01],\n",
      "        [1.0566e-02, 2.4317e-04],\n",
      "        [1.9930e-01, 6.6013e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14739054]\n",
      "Time: 6.432514701038599\n",
      "Iteration: 15\n",
      "new candidats: tensor([[0.6795, 0.3293],\n",
      "        [0.4250, 0.7714],\n",
      "        [0.3724, 0.6475],\n",
      "        [0.8548, 0.2756],\n",
      "        [0.3056, 0.7966]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1699, 0.0039],\n",
      "        [0.4140, 0.6530],\n",
      "        [0.2986, 0.2238],\n",
      "        [0.4549, 0.0017],\n",
      "        [0.0714, 0.4508]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14739054]\n",
      "Time: 11.38401826703921\n",
      "Iteration: 16\n",
      "new candidats: tensor([[0.2810, 0.7972],\n",
      "        [0.2409, 0.2332],\n",
      "        [0.0555, 0.6933],\n",
      "        [0.0287, 0.0151],\n",
      "        [0.4250, 0.7714]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0450, 0.3478],\n",
      "        [0.4830, 0.3423],\n",
      "        [0.0184, 0.0249],\n",
      "        [0.2260, 0.3192],\n",
      "        [0.4140, 0.6530]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14739054]\n",
      "Time: 4.42155741690658\n",
      "Iteration: 1\n",
      "new candidats: tensor([[0.0015, 0.1965],\n",
      "        [0.9906, 0.9990],\n",
      "        [0.0348, 0.2646],\n",
      "        [0.1285, 0.1560],\n",
      "        [0.9062, 0.0978]], dtype=torch.float64)\n",
      "new obj: tensor([[3.0545e-01, 4.7142e-01],\n",
      "        [1.1696e-07, 6.8763e-09],\n",
      "        [3.3746e-01, 4.6732e-01],\n",
      "        [4.5785e-01, 4.6759e-01],\n",
      "        [2.3695e-01, 3.7172e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.06027453]\n",
      "Time: 6.948181065963581\n",
      "Iteration: 2\n",
      "new candidats: tensor([[0.1593, 0.2122],\n",
      "        [0.2310, 0.1540],\n",
      "        [0.2871, 0.6083],\n",
      "        [0.7285, 0.3679],\n",
      "        [0.0730, 0.0461]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4888, 0.4518],\n",
      "        [0.4811, 0.3522],\n",
      "        [0.1042, 0.0934],\n",
      "        [0.1433, 0.0016],\n",
      "        [0.3040, 0.3718]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.06741918]\n",
      "Time: 5.2235487008001655\n",
      "Iteration: 3\n",
      "new candidats: tensor([[0.9235, 0.2702],\n",
      "        [0.4371, 0.7594],\n",
      "        [0.4554, 0.7258],\n",
      "        [0.1784, 0.1969],\n",
      "        [0.1112, 0.1683]], dtype=torch.float64)\n",
      "new obj: tensor([[0.2560, 0.0008],\n",
      "        [0.4864, 0.6036],\n",
      "        [0.6199, 0.4584],\n",
      "        [0.4970, 0.4316],\n",
      "        [0.4474, 0.4834]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.12830952]\n",
      "Time: 5.613167784875259\n",
      "Iteration: 4\n",
      "new candidats: tensor([[4.8503e-01, 7.2880e-01],\n",
      "        [5.7564e-01, 2.6235e-01],\n",
      "        [9.0739e-01, 4.1766e-04],\n",
      "        [4.4915e-01, 7.7211e-01],\n",
      "        [4.9527e-01, 7.5775e-01]], dtype=torch.float64)\n",
      "new obj: tensor([[0.6696, 0.3802],\n",
      "        [0.1282, 0.0195],\n",
      "        [0.0542, 0.0499],\n",
      "        [0.4781, 0.5981],\n",
      "        [0.5953, 0.4077]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13621077]\n",
      "Time: 9.794532679952681\n",
      "Iteration: 5\n",
      "new candidats: tensor([[0.1996, 0.8955],\n",
      "        [0.0406, 0.2889],\n",
      "        [0.4172, 0.7936],\n",
      "        [0.6304, 0.0120],\n",
      "        [0.1510, 0.8968]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0023, 0.0605],\n",
      "        [0.3297, 0.4481],\n",
      "        [0.3238, 0.6897],\n",
      "        [0.0601, 0.0063],\n",
      "        [0.0014, 0.0208]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14395623]\n",
      "Time: 4.461572625907138\n",
      "Iteration: 6\n",
      "new candidats: tensor([[0.0853, 0.3501],\n",
      "        [0.4677, 0.7423],\n",
      "        [0.1949, 0.4206],\n",
      "        [0.4772, 0.7071],\n",
      "        [0.8402, 0.2111]], dtype=torch.float64)\n",
      "new obj: tensor([[0.3201, 0.3762],\n",
      "        [0.6127, 0.4731],\n",
      "        [0.2721, 0.2240],\n",
      "        [0.6880, 0.3402],\n",
      "        [0.6446, 0.0586]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14800238]\n",
      "Time: 8.26197884697467\n",
      "Iteration: 7\n",
      "new candidats: tensor([[0.0582, 0.9457],\n",
      "        [0.8218, 0.7512],\n",
      "        [0.4371, 0.7594],\n",
      "        [0.4772, 0.7071],\n",
      "        [0.9137, 0.8736]], dtype=torch.float64)\n",
      "new obj: tensor([[3.7442e-04, 1.1811e-03],\n",
      "        [3.5546e-03, 9.4753e-05],\n",
      "        [4.8641e-01, 6.0363e-01],\n",
      "        [6.8796e-01, 3.4022e-01],\n",
      "        [3.2784e-05, 1.2293e-06]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14800238]\n",
      "Time: 3.745487437117845\n",
      "Iteration: 8\n",
      "new candidats: tensor([[0.1651, 0.5500],\n",
      "        [0.8021, 0.2145],\n",
      "        [0.7147, 0.6378],\n",
      "        [0.4371, 0.7594],\n",
      "        [0.6996, 0.5465]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1073, 0.0985],\n",
      "        [0.6979, 0.0328],\n",
      "        [0.0593, 0.0016],\n",
      "        [0.4864, 0.6036],\n",
      "        [0.0353, 0.0011]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14800238]\n",
      "Time: 4.978579316986725\n",
      "Iteration: 9\n",
      "new candidats: tensor([[0.8187, 0.0772],\n",
      "        [0.4371, 0.7594],\n",
      "        [0.3271, 0.0400],\n",
      "        [0.6319, 0.4883],\n",
      "        [0.8174, 0.4380]], dtype=torch.float64)\n",
      "new obj: tensor([[3.2729e-01, 5.1905e-01],\n",
      "        [4.8641e-01, 6.0363e-01],\n",
      "        [2.9669e-01, 1.5893e-01],\n",
      "        [5.1063e-02, 3.7861e-03],\n",
      "        [4.2880e-02, 2.2869e-04]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14800238]\n",
      "Time: 5.370936185820028\n",
      "Iteration: 10\n",
      "new candidats: tensor([[0.0201, 0.0657],\n",
      "        [0.7455, 0.8221],\n",
      "        [0.2073, 0.0111],\n",
      "        [0.4371, 0.7594],\n",
      "        [0.5779, 0.1887]], dtype=torch.float64)\n",
      "new obj: tensor([[0.2663, 0.3868],\n",
      "        [0.0164, 0.0018],\n",
      "        [0.3199, 0.2529],\n",
      "        [0.4864, 0.6036],\n",
      "        [0.1428, 0.0199]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14800238]\n",
      "Time: 8.324953206814826\n",
      "Iteration: 11\n",
      "new candidats: tensor([[0.9629, 0.5617],\n",
      "        [0.5976, 0.8007],\n",
      "        [0.8449, 0.8141],\n",
      "        [0.4371, 0.7594],\n",
      "        [0.2120, 0.0746]], dtype=torch.float64)\n",
      "new obj: tensor([[3.4164e-04, 4.5814e-06],\n",
      "        [2.6267e-01, 9.9594e-02],\n",
      "        [9.7992e-04, 3.7429e-05],\n",
      "        [4.8641e-01, 6.0363e-01],\n",
      "        [4.1009e-01, 3.1933e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14800238]\n",
      "Time: 6.6556382440030575\n",
      "Iteration: 12\n",
      "new candidats: tensor([[0.7156, 0.2760],\n",
      "        [0.1048, 0.3342],\n",
      "        [0.8770, 0.1188],\n",
      "        [0.4371, 0.7594],\n",
      "        [0.6120, 0.3338]], dtype=torch.float64)\n",
      "new obj: tensor([[0.3840, 0.0026],\n",
      "        [0.3565, 0.3933],\n",
      "        [0.3758, 0.5641],\n",
      "        [0.4864, 0.6036],\n",
      "        [0.0972, 0.0102]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14800238]\n",
      "Time: 13.322866905946285\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration: 13\n",
      "new candidats: tensor([[0.6291, 0.1445],\n",
      "        [0.8369, 0.1403],\n",
      "        [0.0051, 0.4578],\n",
      "        [0.6388, 0.2846],\n",
      "        [0.8673, 0.3967]], dtype=torch.float64)\n",
      "new obj: tensor([[1.8759e-01, 9.6889e-03],\n",
      "        [5.5023e-01, 4.8912e-01],\n",
      "        [1.3547e-01, 2.0665e-01],\n",
      "        [1.7473e-01, 8.0087e-03],\n",
      "        [8.1824e-02, 1.0916e-04]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14902661]\n",
      "Time: 5.643569065956399\n",
      "Iteration: 14\n",
      "new candidats: tensor([[0.3379, 0.2881],\n",
      "        [0.0525, 0.8653],\n",
      "        [0.8872, 0.0256],\n",
      "        [0.4371, 0.7594],\n",
      "        [0.4561, 0.3452]], dtype=torch.float64)\n",
      "new obj: tensor([[0.3578, 0.1850],\n",
      "        [0.0015, 0.0033],\n",
      "        [0.1056, 0.1757],\n",
      "        [0.4864, 0.6036],\n",
      "        [0.1711, 0.0596]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14902661]\n",
      "Time: 8.633617796003819\n",
      "Iteration: 15\n",
      "new candidats: tensor([[0.1683, 0.6723],\n",
      "        [0.4371, 0.7594],\n",
      "        [0.3281, 0.6572],\n",
      "        [0.4118, 0.4872],\n",
      "        [0.4997, 0.5523]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0331, 0.0484],\n",
      "        [0.4864, 0.6036],\n",
      "        [0.1757, 0.2109],\n",
      "        [0.1511, 0.0466],\n",
      "        [0.2697, 0.0304]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14902661]\n",
      "Time: 17.01487644901499\n",
      "Iteration: 16\n",
      "new candidats: tensor([[0.2040, 0.7454],\n",
      "        [0.1227, 0.5951],\n",
      "        [0.4957, 0.2251],\n",
      "        [0.6106, 0.3752],\n",
      "        [0.4371, 0.7594]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0200, 0.0980],\n",
      "        [0.0662, 0.0704],\n",
      "        [0.1729, 0.0515],\n",
      "        [0.0684, 0.0088],\n",
      "        [0.4864, 0.6036]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14902661]\n",
      "Time: 13.012468982953578\n",
      "Iteration: 1\n",
      "new candidats: tensor([[0.0450, 0.0137],\n",
      "        [0.0114, 0.0382],\n",
      "        [0.4970, 0.7723],\n",
      "        [0.4198, 0.6170],\n",
      "        [0.9268, 0.5097]], dtype=torch.float64)\n",
      "new obj: tensor([[2.3999e-01, 3.2151e-01],\n",
      "        [2.3102e-01, 3.4526e-01],\n",
      "        [5.4155e-01, 4.2181e-01],\n",
      "        [3.9059e-01, 1.4092e-01],\n",
      "        [2.8075e-03, 1.5605e-05]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.08522545]\n",
      "Time: 9.570599725935608\n",
      "Iteration: 2\n",
      "new candidats: tensor([[0.5091, 0.7334],\n",
      "        [0.9770, 0.2942],\n",
      "        [0.4737, 0.7928],\n",
      "        [0.2378, 0.0940],\n",
      "        [0.5038, 0.8738]], dtype=torch.float64)\n",
      "new obj: tensor([[6.6365e-01, 3.1052e-01],\n",
      "        [9.4035e-02, 3.0053e-05],\n",
      "        [4.4215e-01, 5.3280e-01],\n",
      "        [4.2684e-01, 3.0563e-01],\n",
      "        [1.5496e-01, 3.1115e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.10757365]\n",
      "Time: 21.962500205961987\n",
      "Iteration: 3\n",
      "new candidats: tensor([[0.6787, 0.5648],\n",
      "        [0.4442, 0.7213],\n",
      "        [0.0740, 0.7649],\n",
      "        [0.4224, 0.7664],\n",
      "        [0.8277, 0.3659]], dtype=torch.float64)\n",
      "new obj: tensor([[6.2671e-02, 1.8290e-03],\n",
      "        [5.9371e-01, 4.6860e-01],\n",
      "        [7.6548e-03, 1.2495e-02],\n",
      "        [4.2050e-01, 6.4705e-01],\n",
      "        [1.7279e-01, 2.7151e-04]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13065471]\n",
      "Time: 12.561476277885959\n",
      "Iteration: 4\n",
      "new candidats: tensor([[0.1146, 0.2411],\n",
      "        [0.4102, 0.7668],\n",
      "        [0.4705, 0.2718],\n",
      "        [0.7450, 0.0129],\n",
      "        [0.4279, 0.7544]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4469, 0.4776],\n",
      "        [0.3793, 0.6611],\n",
      "        [0.1902, 0.0631],\n",
      "        [0.1125, 0.0181],\n",
      "        [0.4712, 0.6089]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.1378021]\n",
      "Time: 14.775265123927966\n",
      "Iteration: 5\n",
      "new candidats: tensor([[0.4279, 0.7544],\n",
      "        [0.7233, 0.5132],\n",
      "        [0.3068, 0.8113],\n",
      "        [0.2202, 0.2110],\n",
      "        [0.2167, 0.8233]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4712, 0.6089],\n",
      "        [0.0187, 0.0008],\n",
      "        [0.0623, 0.4527],\n",
      "        [0.4967, 0.3766],\n",
      "        [0.0098, 0.1299]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.1378021]\n",
      "Time: 17.860363296000287\n",
      "Iteration: 6\n",
      "new candidats: tensor([[0.6447, 0.4474],\n",
      "        [0.1524, 0.2712],\n",
      "        [0.4882, 0.7029],\n",
      "        [0.6132, 0.3322],\n",
      "        [0.1265, 0.5942]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0396, 0.0038],\n",
      "        [0.4562, 0.4311],\n",
      "        [0.7023, 0.2986],\n",
      "        [0.0990, 0.0101],\n",
      "        [0.0674, 0.0709]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14079953]\n",
      "Time: 12.25942788994871\n",
      "Iteration: 7\n",
      "new candidats: tensor([[0.4882, 0.7029],\n",
      "        [0.3677, 0.5420],\n",
      "        [0.4960, 0.6115],\n",
      "        [0.4080, 0.4584],\n",
      "        [0.2309, 0.2380]], dtype=torch.float64)\n",
      "new obj: tensor([[0.7023, 0.2986],\n",
      "        [0.1652, 0.0621],\n",
      "        [0.4928, 0.0809],\n",
      "        [0.1511, 0.0541],\n",
      "        [0.4852, 0.3552]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14079953]\n",
      "Time: 15.577790728071705\n",
      "Iteration: 8\n",
      "new candidats: tensor([[0.0548, 0.3687],\n",
      "        [0.4882, 0.7029],\n",
      "        [0.4742, 0.3878],\n",
      "        [0.0601, 0.3087],\n",
      "        [0.7569, 0.0110]], dtype=torch.float64)\n",
      "new obj: tensor([[0.2692, 0.3494],\n",
      "        [0.7023, 0.2986],\n",
      "        [0.1314, 0.0418],\n",
      "        [0.3378, 0.4309],\n",
      "        [0.1135, 0.0262]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14079953]\n",
      "Time: 17.76155248307623\n",
      "Iteration: 9\n",
      "new candidats: tensor([[0.1954, 0.0283],\n",
      "        [0.9332, 0.2485],\n",
      "        [0.9704, 0.1608],\n",
      "        [0.4442, 0.7213],\n",
      "        [0.6840, 0.1020]], dtype=torch.float64)\n",
      "new obj: tensor([[0.3458, 0.2842],\n",
      "        [0.2568, 0.0022],\n",
      "        [0.1520, 0.0184],\n",
      "        [0.5937, 0.4686],\n",
      "        [0.2447, 0.0068]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14079953]\n",
      "Time: 22.905200690962374\n",
      "Iteration: 10\n",
      "new candidats: tensor([[0.4080, 0.4584],\n",
      "        [0.6284, 0.8803],\n",
      "        [0.4442, 0.7213],\n",
      "        [0.1473, 0.6728],\n",
      "        [0.4279, 0.7544]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1511, 0.0541],\n",
      "        [0.0606, 0.0374],\n",
      "        [0.5937, 0.4686],\n",
      "        [0.0309, 0.0412],\n",
      "        [0.4712, 0.6089]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14079953]\n",
      "Time: 15.728890352882445\n",
      "Iteration: 11\n",
      "new candidats: tensor([[0.6206, 0.4017],\n",
      "        [0.0247, 0.0719],\n",
      "        [0.4279, 0.7544],\n",
      "        [0.4442, 0.7213],\n",
      "        [0.0083, 0.2859]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0552, 0.0068],\n",
      "        [0.2773, 0.3969],\n",
      "        [0.4712, 0.6089],\n",
      "        [0.5937, 0.4686],\n",
      "        [0.2880, 0.4348]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14079953]\n",
      "Time: 11.04817946604453\n",
      "Iteration: 12\n",
      "new candidats: tensor([[0.3873, 0.6859],\n",
      "        [0.8872, 0.8036],\n",
      "        [0.4442, 0.7213],\n",
      "        [0.2166, 0.5266],\n",
      "        [0.9288, 0.1180]], dtype=torch.float64)\n",
      "new obj: tensor([[3.8407e-01, 3.6956e-01],\n",
      "        [2.4147e-04, 6.1458e-06],\n",
      "        [5.9371e-01, 4.6860e-01],\n",
      "        [1.3411e-01, 1.0381e-01],\n",
      "        [2.1888e-01, 1.8981e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14079953]\n",
      "Time: 16.776877759955823\n",
      "Iteration: 13\n",
      "new candidats: tensor([[0.4442, 0.7213],\n",
      "        [0.3434, 0.1114],\n",
      "        [0.4279, 0.7544],\n",
      "        [0.9512, 0.7938],\n",
      "        [0.4095, 0.2285]], dtype=torch.float64)\n",
      "new obj: tensor([[5.9371e-01, 4.6860e-01],\n",
      "        [3.5057e-01, 1.7809e-01],\n",
      "        [4.7117e-01, 6.0888e-01],\n",
      "        [2.2415e-05, 5.4819e-07],\n",
      "        [2.8623e-01, 1.1714e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14079953]\n",
      "Time: 11.679705239832401\n",
      "Iteration: 14\n",
      "new candidats: tensor([[0.8294, 0.2133],\n",
      "        [0.6519, 0.8048],\n",
      "        [0.4882, 0.7029],\n",
      "        [0.6361, 0.3512],\n",
      "        [0.2384, 0.1402]], dtype=torch.float64)\n",
      "new obj: tensor([[0.6681, 0.0497],\n",
      "        [0.1279, 0.0294],\n",
      "        [0.7023, 0.2986],\n",
      "        [0.0937, 0.0068],\n",
      "        [0.4694, 0.3354]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14079953]\n",
      "Time: 13.95855624997057\n",
      "Iteration: 15\n",
      "new candidats: tensor([[0.4279, 0.7544],\n",
      "        [0.4442, 0.7213],\n",
      "        [0.1509, 0.9013],\n",
      "        [0.2813, 0.0929],\n",
      "        [0.5342, 0.3823]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4712, 0.6089],\n",
      "        [0.5937, 0.4686],\n",
      "        [0.0012, 0.0198],\n",
      "        [0.3988, 0.2479],\n",
      "        [0.0899, 0.0224]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14079953]\n",
      "Time: 26.990477948915213\n",
      "Iteration: 16\n",
      "new candidats: tensor([[0.4442, 0.7213],\n",
      "        [0.0725, 0.8787],\n",
      "        [0.4224, 0.7664],\n",
      "        [0.6040, 0.8342],\n",
      "        [0.6630, 0.1506]], dtype=torch.float64)\n",
      "new obj: tensor([[0.5937, 0.4686],\n",
      "        [0.0013, 0.0040],\n",
      "        [0.4205, 0.6470],\n",
      "        [0.1661, 0.0826],\n",
      "        [0.2758, 0.0064]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14079953]\n",
      "Time: 11.498084899969399\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration: 1\n",
      "new candidats: tensor([[0.0039, 0.2265],\n",
      "        [0.1640, 0.1885],\n",
      "        [0.4424, 0.3305],\n",
      "        [0.1232, 0.7621],\n",
      "        [0.1244, 0.0090]], dtype=torch.float64)\n",
      "new obj: tensor([[0.3064, 0.4693],\n",
      "        [0.4911, 0.4470],\n",
      "        [0.1950, 0.0714],\n",
      "        [0.0094, 0.0234],\n",
      "        [0.2950, 0.3054]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.0597511]\n",
      "Time: 13.405122632859275\n",
      "Iteration: 2\n",
      "new candidats: tensor([[0.1989, 0.2143],\n",
      "        [0.3588, 0.5117],\n",
      "        [0.2076, 0.1606],\n",
      "        [0.2681, 0.2115],\n",
      "        [0.1003, 0.2025]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4987, 0.4052],\n",
      "        [0.1522, 0.0624],\n",
      "        [0.4900, 0.3870],\n",
      "        [0.4711, 0.3057],\n",
      "        [0.4416, 0.4942]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.06934507]\n",
      "Time: 12.681140396045521\n",
      "Iteration: 3\n",
      "new candidats: tensor([[0.7680, 0.0077],\n",
      "        [0.4150, 0.7687],\n",
      "        [0.8432, 0.6318],\n",
      "        [0.0135, 0.4866],\n",
      "        [0.6576, 0.1951]], dtype=torch.float64)\n",
      "new obj: tensor([[1.1034e-01, 3.3932e-02],\n",
      "        [3.9044e-01, 6.6092e-01],\n",
      "        [1.8686e-03, 3.6863e-05],\n",
      "        [1.1591e-01, 1.7203e-01],\n",
      "        [2.9020e-01, 6.7435e-03]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.09545273]\n",
      "Time: 22.81520095001906\n",
      "Iteration: 4\n",
      "new candidats: tensor([[0.5932, 0.8604],\n",
      "        [0.2039, 0.5597],\n",
      "        [0.1186, 0.5324],\n",
      "        [0.1215, 0.2160],\n",
      "        [0.4318, 0.8075]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1257, 0.0904],\n",
      "        [0.1025, 0.0850],\n",
      "        [0.1158, 0.1224],\n",
      "        [0.4614, 0.4822],\n",
      "        [0.3140, 0.6646]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.09644391]\n",
      "Time: 11.055390593828633\n",
      "Iteration: 5\n",
      "new candidats: tensor([[0.9041, 0.9067],\n",
      "        [0.4161, 0.7897],\n",
      "        [0.2049, 0.2765],\n",
      "        [0.6968, 0.3221],\n",
      "        [0.4420, 0.7428]], dtype=torch.float64)\n",
      "new obj: tensor([[2.5467e-05, 1.3629e-06],\n",
      "        [3.3290e-01, 6.8875e-01],\n",
      "        [4.6458e-01, 3.7018e-01],\n",
      "        [2.1409e-01, 3.0571e-03],\n",
      "        [5.4576e-01, 5.4652e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.12219456]\n",
      "Time: 19.873361392179504\n",
      "Iteration: 6\n",
      "new candidats: tensor([[0.8854, 0.3561],\n",
      "        [0.1064, 0.3727],\n",
      "        [0.4420, 0.7428],\n",
      "        [0.0153, 0.9793],\n",
      "        [0.4598, 0.7102]], dtype=torch.float64)\n",
      "new obj: tensor([[1.4471e-01, 9.1683e-05],\n",
      "        [3.0867e-01, 3.3876e-01],\n",
      "        [5.4576e-01, 5.4652e-01],\n",
      "        [1.6501e-04, 3.2909e-04],\n",
      "        [6.5059e-01, 3.9393e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14031299]\n",
      "Time: 35.968899878906086\n",
      "Iteration: 7\n",
      "new candidats: tensor([[0.4420, 0.7428],\n",
      "        [0.7400, 0.7884],\n",
      "        [0.1940, 0.8622],\n",
      "        [0.8302, 0.4222],\n",
      "        [0.3243, 0.3916]], dtype=torch.float64)\n",
      "new obj: tensor([[5.4576e-01, 5.4652e-01],\n",
      "        [2.6783e-02, 2.1741e-03],\n",
      "        [3.8193e-03, 7.0846e-02],\n",
      "        [5.8622e-02, 1.9666e-04],\n",
      "        [2.6176e-01, 1.4090e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14031299]\n",
      "Time: 8.16274787997827\n",
      "Iteration: 8\n",
      "new candidats: tensor([[0.4420, 0.7428],\n",
      "        [0.9492, 0.9032],\n",
      "        [0.3074, 0.8730],\n",
      "        [0.2615, 0.3039],\n",
      "        [0.0270, 0.1185]], dtype=torch.float64)\n",
      "new obj: tensor([[5.4576e-01, 5.4652e-01],\n",
      "        [4.6165e-06, 1.8175e-07],\n",
      "        [2.6042e-02, 3.5020e-01],\n",
      "        [4.1675e-01, 2.7629e-01],\n",
      "        [3.1658e-01, 4.4968e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14031299]\n",
      "Time: 9.697172323009\n",
      "Iteration: 9\n",
      "new candidats: tensor([[0.7293, 0.2730],\n",
      "        [0.2540, 0.4733],\n",
      "        [0.9750, 0.4510],\n",
      "        [0.4420, 0.7428],\n",
      "        [0.2967, 0.1557]], dtype=torch.float64)\n",
      "new obj: tensor([[4.3171e-01, 2.1396e-03],\n",
      "        [1.9210e-01, 1.2989e-01],\n",
      "        [6.6110e-03, 8.1370e-06],\n",
      "        [5.4576e-01, 5.4652e-01],\n",
      "        [4.3401e-01, 2.5657e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14031299]\n",
      "Time: 14.720574559178203\n",
      "Iteration: 10\n",
      "new candidats: tensor([[0.2126, 0.0782],\n",
      "        [0.2666, 0.4493],\n",
      "        [0.4420, 0.7428],\n",
      "        [0.4420, 0.7428],\n",
      "        [0.4887, 0.3240]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4146, 0.3222],\n",
      "        [0.2195, 0.1425],\n",
      "        [0.5458, 0.5465],\n",
      "        [0.5458, 0.5465],\n",
      "        [0.1487, 0.0461]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14031299]\n",
      "Time: 20.257833842886612\n",
      "Iteration: 11\n",
      "new candidats: tensor([[0.6273, 0.7006],\n",
      "        [0.3053, 0.5892],\n",
      "        [0.2332, 0.6257],\n",
      "        [0.4420, 0.7428],\n",
      "        [0.3952, 0.7825]], dtype=torch.float64)\n",
      "new obj: tensor([[0.3136, 0.0327],\n",
      "        [0.1224, 0.0861],\n",
      "        [0.0663, 0.0753],\n",
      "        [0.5458, 0.5465],\n",
      "        [0.2919, 0.6905]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.140417]\n",
      "Time: 22.26989384694025\n",
      "Iteration: 12\n",
      "new candidats: tensor([[0.6168, 0.8083],\n",
      "        [0.2106, 0.9727],\n",
      "        [0.4420, 0.7428],\n",
      "        [0.1627, 0.9226],\n",
      "        [0.8404, 0.0181]], dtype=torch.float64)\n",
      "new obj: tensor([[1.9740e-01, 6.6597e-02],\n",
      "        [5.4399e-04, 2.6413e-02],\n",
      "        [5.4576e-01, 5.4652e-01],\n",
      "        [9.1818e-04, 2.0432e-02],\n",
      "        [1.2528e-01, 1.7974e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.140417]\n",
      "Time: 18.10877432511188\n",
      "Iteration: 13\n",
      "new candidats: tensor([[0.8121, 0.1345],\n",
      "        [0.0492, 0.8937],\n",
      "        [0.4420, 0.7428],\n",
      "        [0.6238, 0.3392],\n",
      "        [0.6920, 0.6862]], dtype=torch.float64)\n",
      "new obj: tensor([[0.5652, 0.4145],\n",
      "        [0.0009, 0.0022],\n",
      "        [0.5458, 0.5465],\n",
      "        [0.0983, 0.0085],\n",
      "        [0.1111, 0.0054]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14081729]\n",
      "Time: 16.76853768201545\n",
      "Iteration: 14\n",
      "new candidats: tensor([[0.3995, 0.1296],\n",
      "        [0.3474, 0.9882],\n",
      "        [0.4420, 0.7428],\n",
      "        [0.8435, 0.7196],\n",
      "        [0.9299, 0.4013]], dtype=torch.float64)\n",
      "new obj: tensor([[2.8589e-01, 1.2094e-01],\n",
      "        [3.5921e-03, 1.0375e-01],\n",
      "        [5.4576e-01, 5.4652e-01],\n",
      "        [1.9823e-03, 3.6868e-05],\n",
      "        [4.0102e-02, 2.9184e-05]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14081729]\n",
      "Time: 13.43966320110485\n",
      "Iteration: 15\n",
      "new candidats: tensor([[0.4420, 0.7428],\n",
      "        [0.0788, 0.5736],\n",
      "        [0.4730, 0.6061],\n",
      "        [0.2654, 0.0939],\n",
      "        [0.0720, 0.4424]], dtype=torch.float64)\n",
      "new obj: tensor([[0.5458, 0.5465],\n",
      "        [0.0728, 0.0876],\n",
      "        [0.4595, 0.0902],\n",
      "        [0.4118, 0.2695],\n",
      "        [0.1955, 0.2399]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14081729]\n",
      "Time: 10.234746818896383\n",
      "Iteration: 16\n",
      "new candidats: tensor([[0.4038, 0.2918],\n",
      "        [0.3182, 0.7915],\n",
      "        [0.4420, 0.7428],\n",
      "        [0.4658, 0.6999],\n",
      "        [0.5350, 0.9442]], dtype=torch.float64)\n",
      "new obj: tensor([[0.2681, 0.1118],\n",
      "        [0.0936, 0.5022],\n",
      "        [0.5458, 0.5465],\n",
      "        [0.6694, 0.3446],\n",
      "        [0.0335, 0.0995]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14314111]\n",
      "Time: 18.043183790985495\n",
      "Iteration: 1\n",
      "new candidats: tensor([[0.0171, 0.9752],\n",
      "        [0.1961, 0.0267],\n",
      "        [0.0132, 0.0195],\n",
      "        [0.0950, 0.0679],\n",
      "        [0.1329, 0.1877]], dtype=torch.float64)\n",
      "new obj: tensor([[1.8025e-04, 3.6325e-04],\n",
      "        [3.4344e-01, 2.8160e-01],\n",
      "        [2.1504e-01, 3.1951e-01],\n",
      "        [3.5033e-01, 3.9894e-01],\n",
      "        [4.7172e-01, 4.7498e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.06054412]\n",
      "Time: 18.63161773700267\n",
      "Iteration: 2\n",
      "new candidats: tensor([[0.2000, 0.1896],\n",
      "        [0.8265, 0.9868],\n",
      "        [0.0735, 0.3341],\n",
      "        [0.0469, 0.2123],\n",
      "        [0.7008, 0.7779]], dtype=torch.float64)\n",
      "new obj: tensor([[4.9932e-01, 4.0418e-01],\n",
      "        [5.7076e-05, 1.3884e-05],\n",
      "        [3.2688e-01, 3.9924e-01],\n",
      "        [3.7235e-01, 4.9574e-01],\n",
      "        [6.9110e-02, 7.4536e-03]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.06833343]\n",
      "Time: 17.424896768061444\n",
      "Iteration: 3\n",
      "new candidats: tensor([[0.5693, 0.9947],\n",
      "        [0.8512, 0.1840],\n",
      "        [0.5681, 0.1210],\n",
      "        [0.3251, 0.9010],\n",
      "        [0.9937, 0.7025]], dtype=torch.float64)\n",
      "new obj: tensor([[7.1986e-03, 2.5113e-02],\n",
      "        [6.0866e-01, 1.7070e-01],\n",
      "        [1.1982e-01, 2.0807e-02],\n",
      "        [2.1010e-02, 3.1807e-01],\n",
      "        [1.2019e-05, 5.0674e-07]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.06833343]\n",
      "Time: 19.28299653180875\n",
      "Iteration: 4\n",
      "new candidats: tensor([[0.7308, 0.1680],\n",
      "        [0.8153, 0.0231],\n",
      "        [0.7843, 0.2732],\n",
      "        [0.9606, 0.0758],\n",
      "        [0.4248, 0.0050]], dtype=torch.float64)\n",
      "new obj: tensor([[0.5379, 0.0183],\n",
      "        [0.1476, 0.1687],\n",
      "        [0.5355, 0.0015],\n",
      "        [0.0895, 0.0540],\n",
      "        [0.1654, 0.0644]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.06833343]\n",
      "Time: 12.17080122884363\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration: 5\n",
      "new candidats: tensor([[0.3283, 0.7450],\n",
      "        [0.0980, 0.1947],\n",
      "        [0.9544, 0.1984],\n",
      "        [0.1748, 0.2187],\n",
      "        [0.1120, 0.6192]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1547, 0.4706],\n",
      "        [0.4388, 0.4950],\n",
      "        [0.2129, 0.0115],\n",
      "        [0.4939, 0.4339],\n",
      "        [0.0507, 0.0565]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07032063]\n",
      "Time: 9.680741503834724\n",
      "Iteration: 6\n",
      "new candidats: tensor([[0.9175, 0.4863],\n",
      "        [0.2633, 0.4194],\n",
      "        [0.2430, 0.6279],\n",
      "        [0.3119, 0.5380],\n",
      "        [0.4894, 0.4998]], dtype=torch.float64)\n",
      "new obj: tensor([[6.1258e-03, 2.2646e-05],\n",
      "        [2.6142e-01, 1.7192e-01],\n",
      "        [6.9374e-02, 8.1275e-02],\n",
      "        [1.3464e-01, 7.3028e-02],\n",
      "        [1.5099e-01, 2.3225e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07032063]\n",
      "Time: 12.986242395127192\n",
      "Iteration: 7\n",
      "new candidats: tensor([[0.0686, 0.2208],\n",
      "        [0.7541, 0.7753],\n",
      "        [0.0655, 0.1629],\n",
      "        [0.9320, 0.4231],\n",
      "        [0.0123, 0.2815]], dtype=torch.float64)\n",
      "new obj: tensor([[4.0079e-01, 4.9730e-01],\n",
      "        [2.1090e-02, 1.3106e-03],\n",
      "        [3.9207e-01, 4.9137e-01],\n",
      "        [2.4652e-02, 2.4845e-05],\n",
      "        [2.9630e-01, 4.4144e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07060216]\n",
      "Time: 13.12809938006103\n",
      "Iteration: 8\n",
      "new candidats: tensor([[0.6080, 0.5132],\n",
      "        [0.4425, 0.7282],\n",
      "        [0.3841, 0.2236],\n",
      "        [0.1364, 0.8717],\n",
      "        [0.9957, 0.9544]], dtype=torch.float64)\n",
      "new obj: tensor([[8.7379e-02, 5.2530e-03],\n",
      "        [5.7747e-01, 4.9706e-01],\n",
      "        [3.2512e-01, 1.4462e-01],\n",
      "        [1.9042e-03, 1.8446e-02],\n",
      "        [2.7618e-07, 1.3271e-08]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.0948792]\n",
      "Time: 14.810732034035027\n",
      "Iteration: 9\n",
      "new candidats: tensor([[0.7263, 0.8491],\n",
      "        [0.2962, 0.3878],\n",
      "        [0.0100, 0.7500],\n",
      "        [0.4295, 0.7806],\n",
      "        [0.4975, 0.7506]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0179, 0.0030],\n",
      "        [0.2872, 0.1698],\n",
      "        [0.0073, 0.0112],\n",
      "        [0.3983, 0.6592],\n",
      "        [0.6194, 0.3864]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.1284453]\n",
      "Time: 27.299929057015106\n",
      "Iteration: 10\n",
      "new candidats: tensor([[0.4455, 0.7439],\n",
      "        [0.6128, 0.0579],\n",
      "        [0.5679, 0.2165],\n",
      "        [0.0231, 0.6281],\n",
      "        [0.6639, 0.6576]], dtype=torch.float64)\n",
      "new obj: tensor([[0.5539, 0.5413],\n",
      "        [0.0904, 0.0098],\n",
      "        [0.1385, 0.0225],\n",
      "        [0.0342, 0.0494],\n",
      "        [0.1696, 0.0083]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13532736]\n",
      "Time: 12.557762457989156\n",
      "Iteration: 11\n",
      "new candidats: tensor([[0.0969, 0.5186],\n",
      "        [0.1816, 0.3626],\n",
      "        [0.4879, 0.6975],\n",
      "        [0.3072, 0.2539],\n",
      "        [0.9581, 0.4656]], dtype=torch.float64)\n",
      "new obj: tensor([[1.2316e-01, 1.3948e-01],\n",
      "        [3.5784e-01, 3.0752e-01],\n",
      "        [7.0270e-01, 2.8395e-01],\n",
      "        [4.1763e-01, 2.3863e-01],\n",
      "        [6.0514e-03, 1.0813e-05]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14056287]\n",
      "Time: 14.916550275869668\n",
      "Iteration: 12\n",
      "new candidats: tensor([[0.9325, 0.6987],\n",
      "        [0.4455, 0.7439],\n",
      "        [0.8112, 0.3723],\n",
      "        [0.4425, 0.7282],\n",
      "        [0.5139, 0.9479]], dtype=torch.float64)\n",
      "new obj: tensor([[8.9297e-05, 2.3384e-06],\n",
      "        [5.5387e-01, 5.4130e-01],\n",
      "        [1.6106e-01, 3.5966e-04],\n",
      "        [5.7747e-01, 4.9706e-01],\n",
      "        [3.2222e-02, 1.2263e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14056287]\n",
      "Time: 20.36751254997216\n",
      "Iteration: 13\n",
      "new candidats: tensor([[0.4890, 0.2624],\n",
      "        [0.0813, 0.3536],\n",
      "        [0.2223, 0.0212],\n",
      "        [0.4425, 0.7282],\n",
      "        [0.9797, 0.1224]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1722, 0.0530],\n",
      "        [0.3122, 0.3717],\n",
      "        [0.3333, 0.2510],\n",
      "        [0.5775, 0.4971],\n",
      "        [0.1033, 0.0219]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14056287]\n",
      "Time: 12.154096852988005\n",
      "Iteration: 14\n",
      "new candidats: tensor([[0.8802, 0.2257],\n",
      "        [0.0980, 0.1947],\n",
      "        [0.4425, 0.7282],\n",
      "        [0.6401, 0.5555],\n",
      "        [0.4455, 0.7439]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4927, 0.0249],\n",
      "        [0.4388, 0.4950],\n",
      "        [0.5775, 0.4971],\n",
      "        [0.1019, 0.0037],\n",
      "        [0.5539, 0.5413]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14056287]\n",
      "Time: 11.564559443853796\n",
      "Iteration: 15\n",
      "new candidats: tensor([[0.9728, 0.0367],\n",
      "        [0.2049, 0.4485],\n",
      "        [0.4425, 0.7282],\n",
      "        [0.9615, 0.2320],\n",
      "        [0.0016, 0.3598]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0417, 0.0154],\n",
      "        [0.2314, 0.1842],\n",
      "        [0.5775, 0.4971],\n",
      "        [0.1808, 0.0018],\n",
      "        [0.2222, 0.3428]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14056287]\n",
      "Time: 37.57251065084711\n",
      "Iteration: 16\n",
      "new candidats: tensor([[0.4425, 0.7282],\n",
      "        [0.8670, 0.9903],\n",
      "        [0.3946, 0.0465],\n",
      "        [0.9419, 0.2570],\n",
      "        [0.4043, 0.1827]], dtype=torch.float64)\n",
      "new obj: tensor([[5.7747e-01, 4.9706e-01],\n",
      "        [1.3101e-05, 2.1764e-06],\n",
      "        [2.3206e-01, 9.9799e-02],\n",
      "        [2.1802e-01, 9.7221e-04],\n",
      "        [2.9596e-01, 1.2324e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14056287]\n",
      "Time: 14.891559071140364\n",
      "Iteration: 1\n",
      "new candidats: tensor([[0.8039, 0.8784],\n",
      "        [0.3613, 0.7929],\n",
      "        [0.5039, 0.7070],\n",
      "        [0.5039, 0.7070],\n",
      "        [0.4152, 0.6849]], dtype=torch.float64)\n",
      "new obj: tensor([[1.4257e-03, 1.4962e-04],\n",
      "        [1.7818e-01, 6.4986e-01],\n",
      "        [7.0412e-01, 2.6679e-01],\n",
      "        [7.0412e-01, 2.6679e-01],\n",
      "        [4.9783e-01, 3.6264e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.10228062]\n",
      "Time: 16.363113862928003\n",
      "Iteration: 2\n",
      "new candidats: tensor([[0.4817, 0.7716],\n",
      "        [0.4906, 0.7559],\n",
      "        [0.4915, 0.4748],\n",
      "        [0.4717, 0.3173],\n",
      "        [0.7242, 0.8590]], dtype=torch.float64)\n",
      "new obj: tensor([[0.5358, 0.4826],\n",
      "        [0.5998, 0.4225],\n",
      "        [0.1226, 0.0234],\n",
      "        [0.1693, 0.0560],\n",
      "        [0.0161, 0.0031]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.12718295]\n",
      "Time: 19.195304608903825\n",
      "Iteration: 3\n",
      "new candidats: tensor([[0.5559, 0.1352],\n",
      "        [0.9451, 0.0573],\n",
      "        [0.5082, 0.7308],\n",
      "        [0.2501, 0.6889],\n",
      "        [0.0499, 0.0126]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1262, 0.0248],\n",
      "        [0.0886, 0.0797],\n",
      "        [0.6698, 0.3081],\n",
      "        [0.0550, 0.1396],\n",
      "        [0.2432, 0.3207]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13007306]\n",
      "Time: 22.189267122885212\n",
      "Iteration: 4\n",
      "new candidats: tensor([[0.9205, 0.4080],\n",
      "        [0.4467, 0.7407],\n",
      "        [0.2510, 0.8610],\n",
      "        [0.7043, 0.1017],\n",
      "        [0.0314, 0.1404]], dtype=torch.float64)\n",
      "new obj: tensor([[3.9374e-02, 3.4474e-05],\n",
      "        [5.6493e-01, 5.2880e-01],\n",
      "        [1.0669e-02, 1.9277e-01],\n",
      "        [2.9158e-01, 1.2922e-02],\n",
      "        [3.3530e-01, 4.6948e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13752514]\n",
      "Time: 10.488745216047391\n",
      "Iteration: 5\n",
      "new candidats: tensor([[0.0327, 0.5193],\n",
      "        [0.9865, 0.4768],\n",
      "        [0.4395, 0.7639],\n",
      "        [0.4139, 0.7658],\n",
      "        [0.4707, 0.0995]], dtype=torch.float64)\n",
      "new obj: tensor([[9.8535e-02, 1.3743e-01],\n",
      "        [2.7490e-03, 5.2853e-06],\n",
      "        [4.7972e-01, 6.0844e-01],\n",
      "        [3.9444e-01, 6.5594e-01],\n",
      "        [1.7820e-01, 5.9223e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14478933]\n",
      "Time: 13.265327944187447\n",
      "Iteration: 6\n",
      "new candidats: tensor([[0.0247, 0.3279],\n",
      "        [0.5091, 0.9869],\n",
      "        [0.1580, 0.3723],\n",
      "        [0.1267, 0.2187],\n",
      "        [0.1835, 0.1900]], dtype=torch.float64)\n",
      "new obj: tensor([[0.2776, 0.3973],\n",
      "        [0.0114, 0.0674],\n",
      "        [0.3375, 0.3132],\n",
      "        [0.4655, 0.4782],\n",
      "        [0.4977, 0.4252]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14478933]\n",
      "Time: 18.609243283048272\n",
      "Iteration: 7\n",
      "new candidats: tensor([[0.2568, 0.3612],\n",
      "        [0.0018, 0.2945],\n",
      "        [0.3987, 0.7875],\n",
      "        [0.4550, 0.7127],\n",
      "        [0.7123, 0.9500]], dtype=torch.float64)\n",
      "new obj: tensor([[0.3472, 0.2336],\n",
      "        [0.2737, 0.4219],\n",
      "        [0.2898, 0.6962],\n",
      "        [0.6358, 0.4139],\n",
      "        [0.0032, 0.0017]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15084453]\n",
      "Time: 15.209264948032796\n",
      "Iteration: 8\n",
      "new candidats: tensor([[0.8548, 0.8680],\n",
      "        [0.6209, 0.7040],\n",
      "        [0.4723, 0.6386],\n",
      "        [0.6929, 0.1672],\n",
      "        [0.4550, 0.7127]], dtype=torch.float64)\n",
      "new obj: tensor([[3.2378e-04, 1.8751e-05],\n",
      "        [3.3896e-01, 3.8933e-02],\n",
      "        [5.7585e-01, 1.5260e-01],\n",
      "        [3.9741e-01, 5.9005e-03],\n",
      "        [6.3577e-01, 4.1391e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15084453]\n",
      "Time: 33.01189560908824\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration: 9\n",
      "new candidats: tensor([[0.2971, 0.0095],\n",
      "        [0.4550, 0.7127],\n",
      "        [0.1379, 0.9585],\n",
      "        [0.9502, 0.3820],\n",
      "        [0.0772, 0.6844]], dtype=torch.float64)\n",
      "new obj: tensor([[2.8241e-01, 1.6676e-01],\n",
      "        [6.3577e-01, 4.1391e-01],\n",
      "        [3.9424e-04, 6.7870e-03],\n",
      "        [4.3566e-02, 2.0595e-05],\n",
      "        [2.2130e-02, 2.8556e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15084453]\n",
      "Time: 16.01349759893492\n",
      "Iteration: 10\n",
      "new candidats: tensor([[0.7072, 0.8107],\n",
      "        [0.4700, 0.2809],\n",
      "        [0.2771, 0.4539],\n",
      "        [0.4550, 0.7127],\n",
      "        [0.0959, 0.9486]], dtype=torch.float64)\n",
      "new obj: tensor([[4.4520e-02, 6.2470e-03],\n",
      "        [1.8751e-01, 6.2362e-02],\n",
      "        [2.1026e-01, 1.3156e-01],\n",
      "        [6.3577e-01, 4.1391e-01],\n",
      "        [4.0534e-04, 2.7270e-03]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15084453]\n",
      "Time: 11.779909707140177\n",
      "Iteration: 11\n",
      "new candidats: tensor([[0.4550, 0.7127],\n",
      "        [0.9425, 0.8293],\n",
      "        [0.7725, 0.6333],\n",
      "        [0.5139, 0.4287],\n",
      "        [0.2653, 0.5416]], dtype=torch.float64)\n",
      "new obj: tensor([[6.3577e-01, 4.1391e-01],\n",
      "        [2.0595e-05, 5.3367e-07],\n",
      "        [1.4521e-02, 2.6925e-04],\n",
      "        [9.4198e-02, 2.2508e-02],\n",
      "        [1.2295e-01, 8.2213e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15084453]\n",
      "Time: 34.686793396947905\n",
      "Iteration: 12\n",
      "new candidats: tensor([[0.8839, 0.5394],\n",
      "        [0.8536, 0.5654],\n",
      "        [0.5845, 0.6925],\n",
      "        [0.4550, 0.7127],\n",
      "        [0.4452, 0.8203]], dtype=torch.float64)\n",
      "new obj: tensor([[2.0153e-03, 3.0213e-05],\n",
      "        [1.7621e-03, 4.5263e-05],\n",
      "        [4.9244e-01, 7.2521e-02],\n",
      "        [6.3577e-01, 4.1391e-01],\n",
      "        [2.9416e-01, 6.1969e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15084453]\n",
      "Time: 18.18690724717453\n",
      "Iteration: 13\n",
      "new candidats: tensor([[0.4550, 0.7127],\n",
      "        [0.0816, 0.7306],\n",
      "        [0.0934, 0.9718],\n",
      "        [0.4467, 0.7407],\n",
      "        [0.0313, 0.4808]], dtype=torch.float64)\n",
      "new obj: tensor([[6.3577e-01, 4.1391e-01],\n",
      "        [1.2529e-02, 1.8240e-02],\n",
      "        [2.5789e-04, 1.7450e-03],\n",
      "        [5.6493e-01, 5.2880e-01],\n",
      "        [1.3075e-01, 1.8317e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15084453]\n",
      "Time: 35.21777303703129\n",
      "Iteration: 14\n",
      "new candidats: tensor([[0.5039, 0.7070],\n",
      "        [0.5296, 0.5550],\n",
      "        [0.3286, 0.1126],\n",
      "        [0.7400, 0.5953],\n",
      "        [0.0780, 0.1838]], dtype=torch.float64)\n",
      "new obj: tensor([[7.0412e-01, 2.6679e-01],\n",
      "        [2.6081e-01, 2.2402e-02],\n",
      "        [3.6962e-01, 1.9701e-01],\n",
      "        [2.4807e-02, 5.2552e-04],\n",
      "        [4.1372e-01, 4.9796e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15084453]\n",
      "Time: 19.951063690939918\n",
      "Iteration: 15\n",
      "new candidats: tensor([[0.6092, 0.0341],\n",
      "        [0.7612, 0.7320],\n",
      "        [0.7651, 0.2932],\n",
      "        [0.4467, 0.7407],\n",
      "        [0.4550, 0.7127]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0723, 0.0094],\n",
      "        [0.0222, 0.0009],\n",
      "        [0.4348, 0.0012],\n",
      "        [0.5649, 0.5288],\n",
      "        [0.6358, 0.4139]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15084453]\n",
      "Time: 13.966190190985799\n",
      "Iteration: 16\n",
      "new candidats: tensor([[0.1318, 0.3285],\n",
      "        [0.4550, 0.7127],\n",
      "        [0.5544, 0.0644],\n",
      "        [0.1278, 0.8978],\n",
      "        [0.2365, 0.3455]], dtype=torch.float64)\n",
      "new obj: tensor([[0.3837, 0.3877],\n",
      "        [0.6358, 0.4139],\n",
      "        [0.0964, 0.0212],\n",
      "        [0.0012, 0.0118],\n",
      "        [0.3775, 0.2714]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15084453]\n",
      "Time: 24.82199752284214\n",
      "Iteration: 1\n",
      "new candidats: tensor([[0.3764, 0.0459],\n",
      "        [0.8656, 0.4582],\n",
      "        [0.0184, 0.9149],\n",
      "        [0.0028, 0.0190],\n",
      "        [0.1040, 0.2324]], dtype=torch.float64)\n",
      "new obj: tensor([[2.5188e-01, 1.1494e-01],\n",
      "        [2.1060e-02, 7.9601e-05],\n",
      "        [5.5701e-04, 1.0617e-03],\n",
      "        [2.0412e-01, 3.1370e-01],\n",
      "        [4.3985e-01, 4.8640e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.05680348]\n",
      "Time: 11.684506228892133\n",
      "Iteration: 2\n",
      "new candidats: tensor([[0.5748, 0.9997],\n",
      "        [0.0985, 0.3317],\n",
      "        [0.1572, 0.1955],\n",
      "        [0.5002, 0.3720],\n",
      "        [0.0058, 0.2351]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0060, 0.0207],\n",
      "        [0.3539, 0.3985],\n",
      "        [0.4885, 0.4546],\n",
      "        [0.1170, 0.0342],\n",
      "        [0.3073, 0.4676]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.06817292]\n",
      "Time: 12.11534834606573\n",
      "Iteration: 3\n",
      "new candidats: tensor([[0.1765, 0.0928],\n",
      "        [0.1827, 0.1600],\n",
      "        [0.2406, 0.1965],\n",
      "        [0.5593, 0.7644],\n",
      "        [0.4788, 0.0290]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4301, 0.3759],\n",
      "        [0.4883, 0.4182],\n",
      "        [0.4897, 0.3475],\n",
      "        [0.4789, 0.1852],\n",
      "        [0.1322, 0.0430]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.0683247]\n",
      "Time: 12.74922254611738\n",
      "Iteration: 4\n",
      "new candidats: tensor([[0.3807, 0.7647],\n",
      "        [0.8326, 0.4796],\n",
      "        [0.4485, 0.3901],\n",
      "        [0.9936, 0.0064],\n",
      "        [0.3580, 0.2653]], dtype=torch.float64)\n",
      "new obj: tensor([[2.8484e-01, 6.4839e-01],\n",
      "        [1.4836e-02, 1.3140e-04],\n",
      "        [1.5234e-01, 5.3226e-02],\n",
      "        [1.6602e-02, 1.9666e-03],\n",
      "        [3.4706e-01, 1.6811e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07600931]\n",
      "Time: 16.4911878190469\n",
      "Iteration: 5\n",
      "new candidats: tensor([[0.4373, 0.6927],\n",
      "        [0.1575, 0.6952],\n",
      "        [0.7848, 0.1348],\n",
      "        [0.4242, 0.7489],\n",
      "        [0.7859, 0.6315]], dtype=torch.float64)\n",
      "new obj: tensor([[5.8534e-01, 3.7183e-01],\n",
      "        [2.4773e-02, 4.2539e-02],\n",
      "        [5.6596e-01, 2.3534e-01],\n",
      "        [4.7233e-01, 5.9895e-01],\n",
      "        [1.0028e-02, 1.7936e-04]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.11102862]\n",
      "Time: 21.33372676698491\n",
      "Iteration: 6\n",
      "new candidats: tensor([[0.4405, 0.7327],\n",
      "        [0.4199, 0.7744],\n",
      "        [0.1744, 0.3268],\n",
      "        [0.0763, 0.3450],\n",
      "        [0.4199, 0.7744]], dtype=torch.float64)\n",
      "new obj: tensor([[0.5628, 0.5169],\n",
      "        [0.3895, 0.6659],\n",
      "        [0.4056, 0.3569],\n",
      "        [0.3175, 0.3843],\n",
      "        [0.3895, 0.6659]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13071015]\n",
      "Time: 29.141359206987545\n",
      "Iteration: 7\n",
      "new candidats: tensor([[0.1972, 0.4964],\n",
      "        [0.9002, 0.2944],\n",
      "        [0.4717, 0.7253],\n",
      "        [0.6371, 0.0243],\n",
      "        [0.4717, 0.7253]], dtype=torch.float64)\n",
      "new obj: tensor([[1.6765e-01, 1.3710e-01],\n",
      "        [2.7227e-01, 3.0178e-04],\n",
      "        [6.5767e-01, 4.1161e-01],\n",
      "        [7.0844e-02, 6.1318e-03],\n",
      "        [6.5767e-01, 4.1161e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14538894]\n",
      "Time: 14.744036107091233\n",
      "Iteration: 8\n",
      "new candidats: tensor([[0.4717, 0.7253],\n",
      "        [0.7556, 0.7628],\n",
      "        [0.2830, 0.2745],\n",
      "        [0.4872, 0.2181],\n",
      "        [0.9018, 0.1401]], dtype=torch.float64)\n",
      "new obj: tensor([[0.6577, 0.4116],\n",
      "        [0.0221, 0.0012],\n",
      "        [0.4281, 0.2646],\n",
      "        [0.1827, 0.0565],\n",
      "        [0.3493, 0.2965]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14538894]\n",
      "Time: 10.905805302085355\n",
      "Iteration: 9\n",
      "new candidats: tensor([[0.9860, 0.8667],\n",
      "        [0.5197, 0.9502],\n",
      "        [0.3884, 0.9745],\n",
      "        [0.4717, 0.7253],\n",
      "        [0.2526, 0.2045]], dtype=torch.float64)\n",
      "new obj: tensor([[2.1491e-06, 7.3324e-08],\n",
      "        [3.0145e-02, 1.1072e-01],\n",
      "        [8.8612e-03, 1.5184e-01],\n",
      "        [6.5767e-01, 4.1161e-01],\n",
      "        [4.8289e-01, 3.2952e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14538894]\n",
      "Time: 11.591394481947646\n",
      "Iteration: 10\n",
      "new candidats: tensor([[0.2357, 0.3551],\n",
      "        [0.4717, 0.7253],\n",
      "        [0.4913, 0.7731],\n",
      "        [0.0955, 0.8821],\n",
      "        [0.2444, 0.3015]], dtype=torch.float64)\n",
      "new obj: tensor([[0.3643, 0.2626],\n",
      "        [0.6577, 0.4116],\n",
      "        [0.5367, 0.4458],\n",
      "        [0.0013, 0.0063],\n",
      "        [0.4289, 0.3006]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14538894]\n",
      "Time: 19.946984505979344\n",
      "Iteration: 11\n",
      "new candidats: tensor([[0.6438, 0.1566],\n",
      "        [0.7162, 0.3871],\n",
      "        [0.6750, 0.3503],\n",
      "        [0.4951, 0.7173],\n",
      "        [0.5858, 0.4199]], dtype=torch.float64)\n",
      "new obj: tensor([[0.2297, 0.0080],\n",
      "        [0.0976, 0.0017],\n",
      "        [0.1263, 0.0039],\n",
      "        [0.6947, 0.3181],\n",
      "        [0.0584, 0.0099]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.148985]\n",
      "Time: 24.941202929010615\n",
      "Iteration: 12\n",
      "new candidats: tensor([[0.3698, 0.5457],\n",
      "        [0.4717, 0.7253],\n",
      "        [0.2554, 0.9532],\n",
      "        [0.9163, 0.7495],\n",
      "        [0.6538, 0.8417]], dtype=torch.float64)\n",
      "new obj: tensor([[1.6949e-01, 6.2857e-02],\n",
      "        [6.5767e-01, 4.1161e-01],\n",
      "        [1.8224e-03, 7.6288e-02],\n",
      "        [1.2555e-04, 2.4849e-06],\n",
      "        [7.8930e-02, 2.5696e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.148985]\n",
      "Time: 20.56877908599563\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration: 13\n",
      "new candidats: tensor([[0.4717, 0.7253],\n",
      "        [0.6914, 0.0072],\n",
      "        [0.1304, 0.8757],\n",
      "        [0.9567, 0.6548],\n",
      "        [0.3034, 0.1621]], dtype=torch.float64)\n",
      "new obj: tensor([[6.5767e-01, 4.1161e-01],\n",
      "        [7.5832e-02, 3.3334e-03],\n",
      "        [1.7247e-03, 1.5461e-02],\n",
      "        [5.4688e-05, 2.0784e-06],\n",
      "        [4.2970e-01, 2.4861e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.148985]\n",
      "Time: 28.203609248856083\n",
      "Iteration: 14\n",
      "new candidats: tensor([[0.4717, 0.7253],\n",
      "        [0.4199, 0.7744],\n",
      "        [0.1402, 0.3956],\n",
      "        [0.3947, 0.7197],\n",
      "        [0.0852, 0.1000]], dtype=torch.float64)\n",
      "new obj: tensor([[0.6577, 0.4116],\n",
      "        [0.3895, 0.6659],\n",
      "        [0.2963, 0.2914],\n",
      "        [0.4048, 0.5110],\n",
      "        [0.3743, 0.4400]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.148985]\n",
      "Time: 9.5313988130074\n",
      "Iteration: 15\n",
      "new candidats: tensor([[0.3313, 0.2893],\n",
      "        [0.4717, 0.7253],\n",
      "        [0.4396, 0.8909],\n",
      "        [0.7890, 0.4726],\n",
      "        [0.6934, 0.4063]], dtype=torch.float64)\n",
      "new obj: tensor([[3.6490e-01, 1.9277e-01],\n",
      "        [6.5767e-01, 4.1161e-01],\n",
      "        [9.4850e-02, 4.2834e-01],\n",
      "        [2.0309e-02, 3.1017e-04],\n",
      "        [6.2649e-02, 2.2851e-03]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.148985]\n",
      "Time: 10.079939126968384\n",
      "Iteration: 16\n",
      "new candidats: tensor([[0.0487, 0.0582],\n",
      "        [0.4199, 0.7744],\n",
      "        [0.4717, 0.7253],\n",
      "        [0.9541, 0.0227],\n",
      "        [0.2977, 0.6627]], dtype=torch.float64)\n",
      "new obj: tensor([[0.2921, 0.3867],\n",
      "        [0.3895, 0.6659],\n",
      "        [0.6577, 0.4116],\n",
      "        [0.0446, 0.0243],\n",
      "        [0.1150, 0.1797]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.148985]\n",
      "Time: 9.849900836125016\n",
      "Iteration: 1\n",
      "new candidats: tensor([[0.5104, 0.6697],\n",
      "        [0.0734, 0.0086],\n",
      "        [0.8442, 0.6556],\n",
      "        [0.0172, 0.4561],\n",
      "        [0.0367, 0.2168]], dtype=torch.float64)\n",
      "new obj: tensor([[6.7449e-01, 1.6568e-01],\n",
      "        [2.5885e-01, 3.1623e-01],\n",
      "        [1.9257e-03, 3.3625e-05],\n",
      "        [1.4502e-01, 2.1265e-01],\n",
      "        [3.5697e-01, 4.9137e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.03328989]\n",
      "Time: 14.341948956949636\n",
      "Iteration: 2\n",
      "new candidats: tensor([[0.0815, 0.2248],\n",
      "        [0.9486, 0.6014],\n",
      "        [0.0122, 0.1630],\n",
      "        [0.2340, 0.5563],\n",
      "        [0.5032, 0.7476]], dtype=torch.float64)\n",
      "new obj: tensor([[4.1632e-01, 4.9534e-01],\n",
      "        [1.5273e-04, 4.3348e-06],\n",
      "        [3.1632e-01, 4.7144e-01],\n",
      "        [1.0807e-01, 8.2134e-02],\n",
      "        [6.2837e-01, 3.5937e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07937476]\n",
      "Time: 10.322205242002383\n",
      "Iteration: 3\n",
      "new candidats: tensor([[0.1816, 0.2092],\n",
      "        [0.3129, 0.1583],\n",
      "        [0.4826, 0.7759],\n",
      "        [0.6915, 0.6066],\n",
      "        [0.5214, 0.7425]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4974, 0.4275],\n",
      "        [0.4172, 0.2340],\n",
      "        [0.5199, 0.4845],\n",
      "        [0.0756, 0.0020],\n",
      "        [0.6284, 0.2849]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.09233126]\n",
      "Time: 13.299760163994506\n",
      "Iteration: 4\n",
      "new candidats: tensor([[0.4685, 0.7803],\n",
      "        [0.4458, 0.1717],\n",
      "        [0.5078, 0.1702],\n",
      "        [0.4598, 0.7417],\n",
      "        [0.1108, 0.6417]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4855, 0.5439],\n",
      "        [0.2339, 0.0847],\n",
      "        [0.1606, 0.0450],\n",
      "        [0.5974, 0.4958],\n",
      "        [0.0398, 0.0458]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.11626406]\n",
      "Time: 13.477734185988083\n",
      "Iteration: 5\n",
      "new candidats: tensor([[0.8861, 0.1211],\n",
      "        [0.3529, 0.5795],\n",
      "        [0.9055, 0.5294],\n",
      "        [0.4375, 0.7753],\n",
      "        [0.9514, 0.9130]], dtype=torch.float64)\n",
      "new obj: tensor([[3.5552e-01, 4.9370e-01],\n",
      "        [1.7653e-01, 8.5514e-02],\n",
      "        [2.0672e-03, 2.0979e-05],\n",
      "        [4.3750e-01, 6.3441e-01],\n",
      "        [3.4694e-06, 1.4497e-07]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13470838]\n",
      "Time: 14.600388343911618\n",
      "Iteration: 6\n",
      "new candidats: tensor([[0.6890, 0.7531],\n",
      "        [0.4777, 0.1738],\n",
      "        [0.7993, 0.0259],\n",
      "        [0.7984, 0.0882],\n",
      "        [0.0064, 0.0472]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1025, 0.0097],\n",
      "        [0.1929, 0.0621],\n",
      "        [0.1577, 0.1401],\n",
      "        [0.3793, 0.4005],\n",
      "        [0.2338, 0.3551]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13470838]\n",
      "Time: 25.97226689895615\n",
      "Iteration: 7\n",
      "new candidats: tensor([[0.2758, 0.6669],\n",
      "        [0.7934, 0.3924],\n",
      "        [0.7849, 0.5029],\n",
      "        [0.1589, 0.0897],\n",
      "        [0.8162, 0.1986]], dtype=torch.float64)\n",
      "new obj: tensor([[8.4153e-02, 1.5282e-01],\n",
      "        [1.1374e-01, 4.5425e-04],\n",
      "        [1.0993e-02, 2.7227e-04],\n",
      "        [4.2045e-01, 3.8906e-01],\n",
      "        [6.9519e-01, 8.0195e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13470838]\n",
      "Time: 26.599026208976284\n",
      "Iteration: 8\n",
      "new candidats: tensor([[0.4770, 0.7208],\n",
      "        [0.3012, 0.5001],\n",
      "        [0.2998, 0.4686],\n",
      "        [0.4205, 0.7683],\n",
      "        [0.7999, 0.1435]], dtype=torch.float64)\n",
      "new obj: tensor([[0.6736, 0.3824],\n",
      "        [0.1558, 0.0879],\n",
      "        [0.1857, 0.1066],\n",
      "        [0.4088, 0.6538],\n",
      "        [0.6022, 0.2905]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14610857]\n",
      "Time: 13.36508962418884\n",
      "Iteration: 9\n",
      "new candidats: tensor([[0.9153, 0.0643],\n",
      "        [0.4205, 0.7683],\n",
      "        [0.5523, 0.6691],\n",
      "        [0.4546, 0.7444],\n",
      "        [0.0270, 0.1768]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1442, 0.2316],\n",
      "        [0.4088, 0.6538],\n",
      "        [0.5890, 0.0950],\n",
      "        [0.5777, 0.5186],\n",
      "        [0.3416, 0.4853]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14821614]\n",
      "Time: 12.172136616893113\n",
      "Iteration: 10\n",
      "new candidats: tensor([[0.0289, 0.8917],\n",
      "        [0.5469, 0.8741],\n",
      "        [0.5138, 0.5651],\n",
      "        [0.4471, 0.7711],\n",
      "        [0.8549, 0.5373]], dtype=torch.float64)\n",
      "new obj: tensor([[8.7881e-04, 1.7085e-03],\n",
      "        [1.3810e-01, 1.8085e-01],\n",
      "        [3.0663e-01, 3.1248e-02],\n",
      "        [4.7668e-01, 6.0222e-01],\n",
      "        [2.9460e-03, 5.5264e-05]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15050279]\n",
      "Time: 39.9160533871036\n",
      "Iteration: 11\n",
      "new candidats: tensor([[0.3232, 0.0244],\n",
      "        [0.6774, 0.9527],\n",
      "        [0.4205, 0.7683],\n",
      "        [0.8236, 0.9183],\n",
      "        [0.4546, 0.7444]], dtype=torch.float64)\n",
      "new obj: tensor([[2.8132e-01, 1.5262e-01],\n",
      "        [5.9836e-03, 4.6575e-03],\n",
      "        [4.0885e-01, 6.5380e-01],\n",
      "        [3.5048e-04, 4.4870e-05],\n",
      "        [5.7767e-01, 5.1862e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15050279]\n",
      "Time: 10.266928347060457\n",
      "Iteration: 12\n",
      "new candidats: tensor([[0.4205, 0.7683],\n",
      "        [0.5061, 0.3671],\n",
      "        [0.1233, 0.0798],\n",
      "        [0.8666, 0.6916],\n",
      "        [0.3118, 0.3414]], dtype=torch.float64)\n",
      "new obj: tensor([[4.0885e-01, 6.5380e-01],\n",
      "        [1.1439e-01, 3.2767e-02],\n",
      "        [3.8782e-01, 4.0286e-01],\n",
      "        [9.3910e-04, 1.6032e-05],\n",
      "        [3.3325e-01, 1.8751e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15050279]\n",
      "Time: 18.77666925592348\n",
      "Iteration: 13\n",
      "new candidats: tensor([[0.9592, 0.9826],\n",
      "        [0.4546, 0.7444],\n",
      "        [0.4770, 0.7208],\n",
      "        [0.7236, 0.0970],\n",
      "        [0.0102, 0.0063]], dtype=torch.float64)\n",
      "new obj: tensor([[5.1561e-07, 3.3453e-08],\n",
      "        [5.7767e-01, 5.1862e-01],\n",
      "        [6.7359e-01, 3.8245e-01],\n",
      "        [3.2172e-01, 3.0666e-02],\n",
      "        [1.9935e-01, 2.9907e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15050279]\n",
      "Time: 10.449260069988668\n",
      "Iteration: 14\n",
      "new candidats: tensor([[0.4770, 0.7208],\n",
      "        [0.3766, 0.0667],\n",
      "        [0.4584, 0.7330],\n",
      "        [0.0563, 0.2046],\n",
      "        [0.0622, 0.5539]], dtype=torch.float64)\n",
      "new obj: tensor([[0.6736, 0.3824],\n",
      "        [0.2712, 0.1236],\n",
      "        [0.6142, 0.4737],\n",
      "        [0.3861, 0.4987],\n",
      "        [0.0824, 0.1045]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15203216]\n",
      "Time: 10.904755478026345\n",
      "Iteration: 15\n",
      "new candidats: tensor([[0.4205, 0.7683],\n",
      "        [0.8952, 0.3063],\n",
      "        [0.5015, 0.0137],\n",
      "        [0.1247, 0.5985],\n",
      "        [0.9308, 0.0914]], dtype=torch.float64)\n",
      "new obj: tensor([[4.0885e-01, 6.5380e-01],\n",
      "        [2.5394e-01, 1.8076e-04],\n",
      "        [1.0540e-01, 3.1587e-02],\n",
      "        [6.4376e-02, 6.8263e-02],\n",
      "        [1.6554e-01, 1.8710e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15203216]\n",
      "Time: 19.988365806872025\n",
      "Iteration: 16\n",
      "new candidats: tensor([[0.8655, 0.9893],\n",
      "        [0.8149, 0.0532],\n",
      "        [0.9574, 0.4201],\n",
      "        [0.4205, 0.7683],\n",
      "        [0.6496, 0.7126]], dtype=torch.float64)\n",
      "new obj: tensor([[1.4209e-05, 2.3735e-06],\n",
      "        [2.3909e-01, 3.5367e-01],\n",
      "        [1.8211e-02, 1.4497e-05],\n",
      "        [4.0885e-01, 6.5380e-01],\n",
      "        [2.2845e-01, 2.1508e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15203216]\n",
      "Time: 41.72619955288246\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration: 1\n",
      "new candidats: tensor([[0.1273, 0.6815],\n",
      "        [0.4784, 0.7273],\n",
      "        [0.0339, 0.1179],\n",
      "        [0.1106, 0.2745],\n",
      "        [0.1317, 0.0096]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0265, 0.0349],\n",
      "        [0.6648, 0.3970],\n",
      "        [0.3255, 0.4522],\n",
      "        [0.4222, 0.4570],\n",
      "        [0.2998, 0.3030]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.09088152]\n",
      "Time: 13.03372526797466\n",
      "Iteration: 2\n",
      "new candidats: tensor([[0.1905, 0.8966],\n",
      "        [0.8463, 0.5815],\n",
      "        [0.4726, 0.8575],\n",
      "        [0.4258, 0.7710],\n",
      "        [0.9135, 0.1870]], dtype=torch.float64)\n",
      "new obj: tensor([[2.0007e-03, 4.9859e-02],\n",
      "        [1.7345e-03, 4.6398e-05],\n",
      "        [1.9599e-01, 4.5624e-01],\n",
      "        [4.1736e-01, 6.5110e-01],\n",
      "        [3.6533e-01, 6.8879e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.12466207]\n",
      "Time: 14.0137942309957\n",
      "Iteration: 3\n",
      "new candidats: tensor([[0.8807, 0.8002],\n",
      "        [0.6037, 0.6616],\n",
      "        [0.4400, 0.6849],\n",
      "        [0.4054, 0.7225],\n",
      "        [0.4549, 0.4613]], dtype=torch.float64)\n",
      "new obj: tensor([[3.1884e-04, 8.2178e-06],\n",
      "        [3.8422e-01, 3.4709e-02],\n",
      "        [5.9093e-01, 3.3782e-01],\n",
      "        [4.4615e-01, 5.2181e-01],\n",
      "        [1.3121e-01, 3.5355e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.12623803]\n",
      "Time: 10.67257868917659\n",
      "Iteration: 4\n",
      "new candidats: tensor([[0.2828, 0.4071],\n",
      "        [0.1380, 0.7467],\n",
      "        [0.1332, 0.0775],\n",
      "        [0.4686, 0.7624],\n",
      "        [0.4930, 0.3322]], dtype=torch.float64)\n",
      "new obj: tensor([[0.2694, 0.1662],\n",
      "        [0.0123, 0.0309],\n",
      "        [0.3920, 0.3942],\n",
      "        [0.5521, 0.5171],\n",
      "        [0.1409, 0.0429]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13877212]\n",
      "Time: 11.4923848179169\n",
      "Iteration: 5\n",
      "new candidats: tensor([[0.8965, 0.6988],\n",
      "        [0.5101, 0.5311],\n",
      "        [0.1350, 0.1789],\n",
      "        [0.3857, 0.6132],\n",
      "        [0.4258, 0.7710]], dtype=torch.float64)\n",
      "new obj: tensor([[3.2325e-04, 6.2225e-06],\n",
      "        [2.0557e-01, 2.1569e-02],\n",
      "        [4.7166e-01, 4.7164e-01],\n",
      "        [2.8845e-01, 1.3800e-01],\n",
      "        [4.1736e-01, 6.5110e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13877212]\n",
      "Time: 24.837011298863217\n",
      "Iteration: 6\n",
      "new candidats: tensor([[0.4258, 0.7710],\n",
      "        [0.7867, 0.9283],\n",
      "        [0.9818, 0.5249],\n",
      "        [0.1693, 0.4481],\n",
      "        [0.4884, 0.7199]], dtype=torch.float64)\n",
      "new obj: tensor([[4.1736e-01, 6.5110e-01],\n",
      "        [8.5733e-04, 1.7523e-04],\n",
      "        [7.5032e-04, 4.1019e-06],\n",
      "        [2.2899e-01, 2.0484e-01],\n",
      "        [6.8769e-01, 3.4555e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14162031]\n",
      "Time: 10.14381681685336\n",
      "Iteration: 7\n",
      "new candidats: tensor([[0.6045, 0.4634],\n",
      "        [0.4258, 0.7710],\n",
      "        [0.9059, 0.2353],\n",
      "        [0.0942, 0.0172],\n",
      "        [0.8626, 0.5036]], dtype=torch.float64)\n",
      "new obj: tensor([[5.5090e-02, 6.2116e-03],\n",
      "        [4.1736e-01, 6.5110e-01],\n",
      "        [3.7651e-01, 9.7081e-03],\n",
      "        [2.8635e-01, 3.2693e-01],\n",
      "        [6.5356e-03, 6.1636e-05]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14162031]\n",
      "Time: 18.843794470187277\n",
      "Iteration: 8\n",
      "new candidats: tensor([[0.4258, 0.7710],\n",
      "        [0.1055, 0.7008],\n",
      "        [0.6529, 0.0546],\n",
      "        [0.1823, 0.6537],\n",
      "        [0.4842, 0.5810]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4174, 0.6511],\n",
      "        [0.0198, 0.0270],\n",
      "        [0.1120, 0.0057],\n",
      "        [0.0421, 0.0550],\n",
      "        [0.3704, 0.0542]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14162031]\n",
      "Time: 18.549122793134302\n",
      "Iteration: 9\n",
      "new candidats: tensor([[0.3783, 0.6710],\n",
      "        [0.0858, 0.0482],\n",
      "        [0.4258, 0.7710],\n",
      "        [0.6803, 0.5675],\n",
      "        [0.9009, 0.5385]], dtype=torch.float64)\n",
      "new obj: tensor([[3.4109e-01, 3.0699e-01],\n",
      "        [3.1849e-01, 3.7376e-01],\n",
      "        [4.1736e-01, 6.5110e-01],\n",
      "        [6.2891e-02, 1.8033e-03],\n",
      "        [1.6843e-03, 2.1389e-05]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14162031]\n",
      "Time: 20.65828673215583\n",
      "Iteration: 10\n",
      "new candidats: tensor([[0.7409, 0.0786],\n",
      "        [0.4672, 0.3518],\n",
      "        [0.4258, 0.7710],\n",
      "        [0.4784, 0.7273],\n",
      "        [0.3358, 0.7600]], dtype=torch.float64)\n",
      "new obj: tensor([[0.2920, 0.0607],\n",
      "        [0.1560, 0.0522],\n",
      "        [0.4174, 0.6511],\n",
      "        [0.6648, 0.3970],\n",
      "        [0.1597, 0.5299]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14162031]\n",
      "Time: 15.168390244944021\n",
      "Iteration: 11\n",
      "new candidats: tensor([[0.4784, 0.7273],\n",
      "        [0.4297, 0.7856],\n",
      "        [0.7829, 0.1632],\n",
      "        [0.4258, 0.7710],\n",
      "        [0.0616, 0.0948]], dtype=torch.float64)\n",
      "new obj: tensor([[0.6648, 0.3970],\n",
      "        [0.3825, 0.6643],\n",
      "        [0.6518, 0.1285],\n",
      "        [0.4174, 0.6511],\n",
      "        [0.3427, 0.4350]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.1435851]\n",
      "Time: 11.629617277998477\n",
      "Iteration: 12\n",
      "new candidats: tensor([[0.6171, 0.8538],\n",
      "        [0.3336, 0.8680],\n",
      "        [0.6792, 0.8983],\n",
      "        [0.9890, 0.1859],\n",
      "        [0.4258, 0.7710]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1084, 0.0575],\n",
      "        [0.0442, 0.4463],\n",
      "        [0.0198, 0.0088],\n",
      "        [0.1165, 0.0034],\n",
      "        [0.4174, 0.6511]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.1435851]\n",
      "Time: 11.4605828570202\n",
      "Iteration: 13\n",
      "new candidats: tensor([[0.0275, 0.6467],\n",
      "        [0.2653, 0.8870],\n",
      "        [0.4258, 0.7710],\n",
      "        [0.5195, 0.4138],\n",
      "        [0.9205, 0.2193]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0285, 0.0406],\n",
      "        [0.0091, 0.1945],\n",
      "        [0.4174, 0.6511],\n",
      "        [0.0917, 0.0228],\n",
      "        [0.3333, 0.0151]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.1435851]\n",
      "Time: 14.583982604090124\n",
      "Iteration: 14\n",
      "new candidats: tensor([[0.4258, 0.7710],\n",
      "        [0.6723, 0.2496],\n",
      "        [0.4769, 0.4583],\n",
      "        [0.3934, 0.4858],\n",
      "        [0.8806, 0.6191]], dtype=torch.float64)\n",
      "new obj: tensor([[4.1736e-01, 6.5110e-01],\n",
      "        [3.0373e-01, 5.2159e-03],\n",
      "        [1.2015e-01, 2.8937e-02],\n",
      "        [1.5284e-01, 5.3738e-02],\n",
      "        [6.0938e-04, 1.6406e-05]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.1435851]\n",
      "Time: 14.484887921018526\n",
      "Iteration: 15\n",
      "new candidats: tensor([[0.3492, 0.1577],\n",
      "        [0.4702, 0.8824],\n",
      "        [0.4258, 0.7710],\n",
      "        [0.8478, 0.8953],\n",
      "        [0.5489, 0.0883]], dtype=torch.float64)\n",
      "new obj: tensor([[3.7017e-01, 1.8451e-01],\n",
      "        [1.2751e-01, 3.8995e-01],\n",
      "        [4.1736e-01, 6.5110e-01],\n",
      "        [2.5221e-04, 2.0309e-05],\n",
      "        [1.0948e-01, 2.4347e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.1435851]\n",
      "Time: 28.149805997963995\n",
      "Iteration: 16\n",
      "new candidats: tensor([[0.4423, 0.5538],\n",
      "        [0.2114, 0.3048],\n",
      "        [0.9123, 0.0624],\n",
      "        [0.6317, 0.9121],\n",
      "        [0.4258, 0.7710]], dtype=torch.float64)\n",
      "new obj: tensor([[0.2537, 0.0494],\n",
      "        [0.4351, 0.3395],\n",
      "        [0.1453, 0.2430],\n",
      "        [0.0311, 0.0255],\n",
      "        [0.4174, 0.6511]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.1435851]\n",
      "Time: 14.89856346999295\n",
      "Iteration: 1\n",
      "new candidats: tensor([[0.3542, 0.5173],\n",
      "        [0.2320, 0.1057],\n",
      "        [0.1772, 0.6135],\n",
      "        [0.1007, 0.1197],\n",
      "        [0.8308, 0.2108]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1511, 0.0634],\n",
      "        [0.4417, 0.3223],\n",
      "        [0.0613, 0.0614],\n",
      "        [0.4078, 0.4559],\n",
      "        [0.6671, 0.0561]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.05296107]\n",
      "Time: 10.63716965680942\n",
      "Iteration: 2\n",
      "new candidats: tensor([[0.0552, 0.2847],\n",
      "        [0.1370, 0.2080],\n",
      "        [0.0427, 0.2029],\n",
      "        [0.9838, 0.9172],\n",
      "        [0.5903, 0.4688]], dtype=torch.float64)\n",
      "new obj: tensor([[3.5175e-01, 4.5585e-01],\n",
      "        [4.7540e-01, 4.7236e-01],\n",
      "        [3.6691e-01, 4.9530e-01],\n",
      "        [9.1974e-07, 3.7616e-08],\n",
      "        [6.4437e-02, 7.3478e-03]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.06629731]\n",
      "Time: 11.577818835852668\n",
      "Iteration: 3\n",
      "new candidats: tensor([[0.4929, 0.7397],\n",
      "        [0.7254, 0.4884],\n",
      "        [0.9363, 0.3066],\n",
      "        [0.6645, 0.8822],\n",
      "        [0.0010, 0.0013]], dtype=torch.float64)\n",
      "new obj: tensor([[6.4973e-01, 3.8044e-01],\n",
      "        [1.9774e-02, 8.5078e-04],\n",
      "        [1.5707e-01, 6.7435e-05],\n",
      "        [3.4527e-02, 1.5138e-02],\n",
      "        [1.8614e-01, 2.8769e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.09153611]\n",
      "Time: 13.211594916181639\n",
      "Iteration: 4\n",
      "new candidats: tensor([[0.7848, 0.9102],\n",
      "        [0.6903, 0.7176],\n",
      "        [0.4378, 0.7653],\n",
      "        [0.5495, 0.7008],\n",
      "        [0.6934, 0.5010]], dtype=torch.float64)\n",
      "new obj: tensor([[1.3446e-03, 2.3377e-04],\n",
      "        [1.1363e-01, 7.5170e-03],\n",
      "        [4.7075e-01, 6.1528e-01],\n",
      "        [6.2403e-01, 1.4127e-01],\n",
      "        [2.6852e-02, 1.3598e-03]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.12234752]\n",
      "Time: 18.14684167993255\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration: 5\n",
      "new candidats: tensor([[0.4692, 0.7676],\n",
      "        [0.4378, 0.7653],\n",
      "        [0.3998, 0.8129],\n",
      "        [0.4417, 0.2835],\n",
      "        [0.5959, 0.0237]], dtype=torch.float64)\n",
      "new obj: tensor([[0.5348, 0.5240],\n",
      "        [0.4707, 0.6153],\n",
      "        [0.2270, 0.6954],\n",
      "        [0.2217, 0.0815],\n",
      "        [0.0662, 0.0107]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13111614]\n",
      "Time: 13.374700382817537\n",
      "Iteration: 6\n",
      "new candidats: tensor([[0.7118, 0.2826],\n",
      "        [0.4929, 0.7397],\n",
      "        [0.4186, 0.3545],\n",
      "        [0.4507, 0.7355],\n",
      "        [0.1940, 0.6668]], dtype=torch.float64)\n",
      "new obj: tensor([[0.3548, 0.0027],\n",
      "        [0.6497, 0.3804],\n",
      "        [0.2055, 0.0812],\n",
      "        [0.5882, 0.5024],\n",
      "        [0.0389, 0.0616]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13763247]\n",
      "Time: 16.38421599799767\n",
      "Iteration: 7\n",
      "new candidats: tensor([[0.9559, 0.1835],\n",
      "        [0.2781, 0.7548],\n",
      "        [0.5197, 0.9949],\n",
      "        [0.4120, 0.7607],\n",
      "        [0.7243, 0.7433]], dtype=torch.float64)\n",
      "new obj: tensor([[0.2054, 0.0185],\n",
      "        [0.0613, 0.3071],\n",
      "        [0.0089, 0.0511],\n",
      "        [0.4008, 0.6457],\n",
      "        [0.0520, 0.0032]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14270621]\n",
      "Time: 6.107965896138921\n",
      "Iteration: 8\n",
      "new candidats: tensor([[0.7420, 0.7940],\n",
      "        [0.4929, 0.7397],\n",
      "        [0.3607, 0.6580],\n",
      "        [0.0162, 0.6252],\n",
      "        [0.0353, 0.1256]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0242, 0.0020],\n",
      "        [0.6497, 0.3804],\n",
      "        [0.2694, 0.2491],\n",
      "        [0.0342, 0.0504],\n",
      "        [0.3324, 0.4596]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14270621]\n",
      "Time: 10.617210092954338\n",
      "Iteration: 9\n",
      "new candidats: tensor([[0.4929, 0.7397],\n",
      "        [0.0243, 0.4561],\n",
      "        [0.0764, 0.8835],\n",
      "        [0.7948, 0.5300],\n",
      "        [0.1786, 0.5893]], dtype=torch.float64)\n",
      "new obj: tensor([[6.4973e-01, 3.8044e-01],\n",
      "        [1.4974e-01, 2.1459e-01],\n",
      "        [1.2183e-03, 4.0794e-03],\n",
      "        [6.6979e-03, 1.8776e-04],\n",
      "        [7.6956e-02, 7.1466e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14270621]\n",
      "Time: 14.484426621813327\n",
      "Iteration: 10\n",
      "new candidats: tensor([[0.2591, 0.6579],\n",
      "        [0.4866, 0.9330],\n",
      "        [0.3138, 0.3865],\n",
      "        [0.5705, 0.7252],\n",
      "        [0.4929, 0.7397]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0700, 0.1178],\n",
      "        [0.0462, 0.1987],\n",
      "        [0.2762, 0.1541],\n",
      "        [0.5318, 0.1244],\n",
      "        [0.6497, 0.3804]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14270621]\n",
      "Time: 17.213780543999746\n",
      "Iteration: 11\n",
      "new candidats: tensor([[0.5513, 0.1683],\n",
      "        [0.4929, 0.7397],\n",
      "        [0.0037, 0.8774],\n",
      "        [0.6770, 0.6194],\n",
      "        [0.3241, 0.1892]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1358, 0.0273],\n",
      "        [0.6497, 0.3804],\n",
      "        [0.0010, 0.0017],\n",
      "        [0.1089, 0.0035],\n",
      "        [0.4118, 0.2227]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14270621]\n",
      "Time: 12.346227134112269\n",
      "Iteration: 12\n",
      "new candidats: tensor([[0.1459, 0.5820],\n",
      "        [0.4929, 0.7397],\n",
      "        [0.2435, 0.2496],\n",
      "        [0.4465, 0.5264],\n",
      "        [0.8701, 0.1993]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0785, 0.0777],\n",
      "        [0.6497, 0.3804],\n",
      "        [0.4735, 0.3329],\n",
      "        [0.1963, 0.0373],\n",
      "        [0.5494, 0.0899]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14270621]\n",
      "Time: 22.582230207975954\n",
      "Iteration: 13\n",
      "new candidats: tensor([[0.1355, 0.4917],\n",
      "        [0.5243, 0.7451],\n",
      "        [0.1433, 0.0759],\n",
      "        [0.5265, 0.4433],\n",
      "        [0.4929, 0.7397]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1639, 0.1637],\n",
      "        [0.6172, 0.2791],\n",
      "        [0.3961, 0.3856],\n",
      "        [0.0889, 0.0182],\n",
      "        [0.6497, 0.3804]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14270621]\n",
      "Time: 16.85916731180623\n",
      "Iteration: 14\n",
      "new candidats: tensor([[0.6018, 0.3976],\n",
      "        [0.3678, 0.6989],\n",
      "        [0.4929, 0.7397],\n",
      "        [0.3856, 0.1104],\n",
      "        [0.4507, 0.7355]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0591, 0.0090],\n",
      "        [0.3078, 0.4062],\n",
      "        [0.6497, 0.3804],\n",
      "        [0.2941, 0.1302],\n",
      "        [0.5882, 0.5024]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14270621]\n",
      "Time: 18.546889923047274\n",
      "Iteration: 15\n",
      "new candidats: tensor([[0.0475, 0.3789],\n",
      "        [0.4382, 0.9811],\n",
      "        [0.6884, 0.9108],\n",
      "        [0.4929, 0.7397],\n",
      "        [0.5088, 0.0451]], dtype=torch.float64)\n",
      "new obj: tensor([[0.2506, 0.3330],\n",
      "        [0.0112, 0.1263],\n",
      "        [0.0129, 0.0059],\n",
      "        [0.6497, 0.3804],\n",
      "        [0.1155, 0.0334]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14270621]\n",
      "Time: 10.537239043042064\n",
      "Iteration: 16\n",
      "new candidats: tensor([[0.4929, 0.7397],\n",
      "        [0.1858, 0.3316],\n",
      "        [0.6287, 0.5230],\n",
      "        [0.4150, 0.4048],\n",
      "        [0.6681, 0.3533]], dtype=torch.float64)\n",
      "new obj: tensor([[0.6497, 0.3804],\n",
      "        [0.4016, 0.3405],\n",
      "        [0.0784, 0.0038],\n",
      "        [0.1724, 0.0672],\n",
      "        [0.1151, 0.0043]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14270621]\n",
      "Time: 10.837366743013263\n",
      "Iteration: 1\n",
      "new candidats: tensor([[6.8065e-01, 4.9351e-01],\n",
      "        [6.7155e-01, 4.7504e-02],\n",
      "        [5.2280e-01, 9.5944e-01],\n",
      "        [2.2615e-02, 6.1120e-04],\n",
      "        [1.2268e-01, 1.6185e-01]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0304, 0.0017],\n",
      "        [0.1191, 0.0047],\n",
      "        [0.0237, 0.0924],\n",
      "        [0.2053, 0.2958],\n",
      "        [0.4556, 0.4742]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.0561565]\n",
      "Time: 8.659019469982013\n",
      "Iteration: 2\n",
      "new candidats: tensor([[0.0165, 0.2033],\n",
      "        [0.2365, 0.2043],\n",
      "        [0.8003, 0.9831],\n",
      "        [0.2647, 0.1989],\n",
      "        [0.1557, 0.2357]], dtype=torch.float64)\n",
      "new obj: tensor([[3.2817e-01, 4.8236e-01],\n",
      "        [4.9161e-01, 3.5342e-01],\n",
      "        [1.4270e-04, 4.3726e-05],\n",
      "        [4.7452e-01, 3.1132e-01],\n",
      "        [4.8016e-01, 4.4893e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.06402486]\n",
      "Time: 13.880410213023424\n",
      "Iteration: 3\n",
      "new candidats: tensor([[0.4026, 0.9889],\n",
      "        [0.0813, 0.1893],\n",
      "        [0.1830, 0.1827],\n",
      "        [0.8827, 0.5512],\n",
      "        [0.1983, 0.2643]], dtype=torch.float64)\n",
      "new obj: tensor([[6.8400e-03, 1.1761e-01],\n",
      "        [4.1868e-01, 4.9849e-01],\n",
      "        [4.9634e-01, 4.2465e-01],\n",
      "        [1.5121e-03, 2.8052e-05],\n",
      "        [4.7484e-01, 3.8651e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.06951936]\n",
      "Time: 25.80801962292753\n",
      "Iteration: 4\n",
      "new candidats: tensor([[0.2528, 0.8326],\n",
      "        [0.9923, 0.3305],\n",
      "        [0.2644, 0.6203],\n",
      "        [0.0188, 0.7077],\n",
      "        [0.9856, 0.8988]], dtype=torch.float64)\n",
      "new obj: tensor([[1.6922e-02, 2.2673e-01],\n",
      "        [4.7143e-02, 1.0032e-05],\n",
      "        [8.3939e-02, 8.9790e-02],\n",
      "        [1.3237e-02, 1.9620e-02],\n",
      "        [1.2303e-06, 4.6661e-08]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.06951936]\n",
      "Time: 16.934505725977942\n",
      "Iteration: 5\n",
      "new candidats: tensor([[0.3521, 0.0028],\n",
      "        [0.7701, 0.7802],\n",
      "        [0.4843, 0.0794],\n",
      "        [0.1254, 0.5154],\n",
      "        [0.8446, 0.3920]], dtype=torch.float64)\n",
      "new obj: tensor([[2.3022e-01, 1.1367e-01],\n",
      "        [1.3349e-02, 7.4481e-04],\n",
      "        [1.5407e-01, 4.8766e-02],\n",
      "        [1.3462e-01, 1.3904e-01],\n",
      "        [1.0217e-01, 1.7462e-04]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.06951936]\n",
      "Time: 16.530771157937124\n",
      "Iteration: 6\n",
      "new candidats: tensor([[0.2912, 0.3498],\n",
      "        [0.2271, 0.1689],\n",
      "        [0.1935, 0.9270],\n",
      "        [0.6646, 0.8239],\n",
      "        [0.2032, 0.2184]], dtype=torch.float64)\n",
      "new obj: tensor([[0.3406, 0.2049],\n",
      "        [0.4895, 0.3628],\n",
      "        [0.0012, 0.0376],\n",
      "        [0.0841, 0.0206],\n",
      "        [0.4978, 0.3988]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.06978174]\n",
      "Time: 21.292325923219323\n",
      "Iteration: 7\n",
      "new candidats: tensor([[0.9697, 0.4707],\n",
      "        [0.6749, 0.6423],\n",
      "        [0.2198, 0.0423],\n",
      "        [0.9181, 0.2066],\n",
      "        [0.5009, 0.5408]], dtype=torch.float64)\n",
      "new obj: tensor([[4.3796e-03, 8.0750e-06],\n",
      "        [1.3104e-01, 5.0630e-03],\n",
      "        [3.6462e-01, 2.7675e-01],\n",
      "        [3.4839e-01, 2.8609e-02],\n",
      "        [2.3492e-01, 2.6112e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.06978174]\n",
      "Time: 14.934471562039107\n",
      "Iteration: 8\n",
      "new candidats: tensor([[0.3871, 0.8599],\n",
      "        [0.5744, 0.1630],\n",
      "        [0.9539, 0.6714],\n",
      "        [0.4405, 0.7566],\n",
      "        [0.3747, 0.1395]], dtype=torch.float64)\n",
      "new obj: tensor([[1.0445e-01, 5.8073e-01],\n",
      "        [1.3654e-01, 2.0434e-02],\n",
      "        [5.1290e-05, 1.8496e-06],\n",
      "        [5.0482e-01, 5.8867e-01],\n",
      "        [3.2617e-01, 1.4962e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.09962132]\n",
      "Time: 36.31059304601513\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration: 9\n",
      "new candidats: tensor([[0.6778, 0.6886],\n",
      "        [0.4255, 0.7889],\n",
      "        [0.0244, 0.8213],\n",
      "        [0.4729, 0.7208],\n",
      "        [0.8401, 0.9117]], dtype=torch.float64)\n",
      "new obj: tensor([[1.4450e-01, 8.1814e-03],\n",
      "        [3.6065e-01, 6.7477e-01],\n",
      "        [2.7315e-03, 4.4981e-03],\n",
      "        [6.6700e-01, 3.9432e-01],\n",
      "        [2.3405e-04, 2.3842e-05]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13863404]\n",
      "Time: 28.86138597992249\n",
      "Iteration: 10\n",
      "new candidats: tensor([[0.1088, 0.0566],\n",
      "        [0.4545, 0.7269],\n",
      "        [0.2303, 0.1044],\n",
      "        [0.4405, 0.7566],\n",
      "        [0.1056, 0.9781]], dtype=torch.float64)\n",
      "new obj: tensor([[3.4846e-01, 3.7938e-01],\n",
      "        [6.1571e-01, 4.6430e-01],\n",
      "        [4.4098e-01, 3.2356e-01],\n",
      "        [5.0482e-01, 5.8867e-01],\n",
      "        [2.3732e-04, 2.1364e-03]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14639428]\n",
      "Time: 20.25252479594201\n",
      "Iteration: 11\n",
      "new candidats: tensor([[0.0339, 0.5275],\n",
      "        [0.3973, 0.6555],\n",
      "        [0.8596, 0.0978],\n",
      "        [0.4405, 0.7566],\n",
      "        [0.2977, 0.2847]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0926, 0.1287],\n",
      "        [0.3973, 0.2561],\n",
      "        [0.3494, 0.6866],\n",
      "        [0.5048, 0.5887],\n",
      "        [0.4057, 0.2391]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14776491]\n",
      "Time: 24.89197409292683\n",
      "Iteration: 12\n",
      "new candidats: tensor([[0.6579, 0.2025],\n",
      "        [0.8547, 0.0812],\n",
      "        [0.5148, 0.7780],\n",
      "        [0.2003, 0.9179],\n",
      "        [0.1133, 0.8048]], dtype=torch.float64)\n",
      "new obj: tensor([[0.2914, 0.0067],\n",
      "        [0.2994, 0.6494],\n",
      "        [0.5128, 0.3540],\n",
      "        [0.0015, 0.0482],\n",
      "        [0.0049, 0.0165]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14776491]\n",
      "Time: 20.463934768922627\n",
      "Iteration: 13\n",
      "new candidats: tensor([[0.8577, 0.2290],\n",
      "        [0.2227, 0.1519],\n",
      "        [0.3626, 0.2370],\n",
      "        [0.3732, 0.3697],\n",
      "        [0.8341, 0.1186]], dtype=torch.float64)\n",
      "new obj: tensor([[0.5706, 0.0250],\n",
      "        [0.4826, 0.3629],\n",
      "        [0.3533, 0.1686],\n",
      "        [0.2411, 0.1106],\n",
      "        [0.4774, 0.6211]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15155287]\n",
      "Time: 18.696394689148292\n",
      "Iteration: 14\n",
      "new candidats: tensor([[0.8209, 0.1365],\n",
      "        [0.6169, 0.6968],\n",
      "        [0.1778, 0.0273],\n",
      "        [0.4545, 0.7269],\n",
      "        [0.9478, 0.3370]], dtype=torch.float64)\n",
      "new obj: tensor([[5.6365e-01, 4.5322e-01],\n",
      "        [3.5599e-01, 3.9654e-02],\n",
      "        [3.4232e-01, 2.9791e-01],\n",
      "        [6.1571e-01, 4.6430e-01],\n",
      "        [9.2177e-02, 2.7297e-05]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15155287]\n",
      "Time: 11.5034923881758\n",
      "Iteration: 15\n",
      "new candidats: tensor([[0.8981, 0.9432],\n",
      "        [0.4405, 0.7566],\n",
      "        [0.9304, 0.0980],\n",
      "        [0.0911, 0.4669],\n",
      "        [0.0655, 0.2256]], dtype=torch.float64)\n",
      "new obj: tensor([[1.4302e-05, 1.1238e-06],\n",
      "        [5.0482e-01, 5.8867e-01],\n",
      "        [1.7832e-01, 1.9174e-01],\n",
      "        [1.7698e-01, 2.0416e-01],\n",
      "        [3.9552e-01, 4.9578e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15155287]\n",
      "Time: 12.209236943162978\n",
      "Iteration: 16\n",
      "new candidats: tensor([[0.8341, 0.1186],\n",
      "        [0.7093, 0.1473],\n",
      "        [0.2993, 0.3711],\n",
      "        [0.6091, 0.8141],\n",
      "        [0.8596, 0.0978]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4774, 0.6211],\n",
      "        [0.4227, 0.0115],\n",
      "        [0.3070, 0.1798],\n",
      "        [0.2019, 0.0779],\n",
      "        [0.3494, 0.6866]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15155287]\n",
      "Time: 15.585234340978786\n",
      "Iteration: 1\n",
      "new candidats: tensor([[0.1961, 0.0851],\n",
      "        [0.1992, 0.2600],\n",
      "        [0.7939, 0.2586],\n",
      "        [0.1924, 0.3528],\n",
      "        [0.1131, 0.2013]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4238, 0.3475],\n",
      "        [0.4780, 0.3879],\n",
      "        [0.5945, 0.0031],\n",
      "        [0.3732, 0.3097],\n",
      "        [0.4549, 0.4885]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.06298551]\n",
      "Time: 14.599477008916438\n",
      "Iteration: 2\n",
      "new candidats: tensor([[0.0106, 0.0822],\n",
      "        [0.9815, 0.3863],\n",
      "        [0.0411, 0.2059],\n",
      "        [0.1897, 0.1787],\n",
      "        [0.1158, 0.6390]], dtype=torch.float64)\n",
      "new obj: tensor([[2.6853e-01, 4.0229e-01],\n",
      "        [2.3929e-02, 1.0012e-05],\n",
      "        [3.6446e-01, 4.9458e-01],\n",
      "        [4.9652e-01, 4.1568e-01],\n",
      "        [4.1517e-02, 4.7179e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.06801875]\n",
      "Time: 12.839435092173517\n",
      "Iteration: 3\n",
      "new candidats: tensor([[0.5967, 0.6377],\n",
      "        [0.2483, 0.1955],\n",
      "        [0.6260, 0.7220],\n",
      "        [0.1100, 0.4137],\n",
      "        [0.1409, 0.2200]], dtype=torch.float64)\n",
      "new obj: tensor([[0.3678, 0.0286],\n",
      "        [0.4855, 0.3359],\n",
      "        [0.3106, 0.0405],\n",
      "        [0.2554, 0.2770],\n",
      "        [0.4762, 0.4673]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.06911641]\n",
      "Time: 16.663501273840666\n",
      "Iteration: 4\n",
      "new candidats: tensor([[0.1897, 0.1787],\n",
      "        [0.2157, 0.5529],\n",
      "        [0.0861, 0.2203],\n",
      "        [0.2895, 0.4973],\n",
      "        [0.3409, 0.5092]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4965, 0.4157],\n",
      "        [0.1093, 0.0869],\n",
      "        [0.4229, 0.4958],\n",
      "        [0.1596, 0.0946],\n",
      "        [0.1501, 0.0690]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.06970837]\n",
      "Time: 29.492772937985137\n",
      "Iteration: 5\n",
      "new candidats: tensor([[0.9746, 0.1824],\n",
      "        [0.7524, 0.9539],\n",
      "        [0.9964, 0.9156],\n",
      "        [0.6232, 0.1242],\n",
      "        [0.3935, 0.7203]], dtype=torch.float64)\n",
      "new obj: tensor([[1.5028e-01, 8.0756e-03],\n",
      "        [1.1618e-03, 4.3193e-04],\n",
      "        [6.0595e-07, 2.5028e-08],\n",
      "        [1.5968e-01, 1.0165e-02],\n",
      "        [3.9957e-01, 5.1302e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07255642]\n",
      "Time: 17.131155574927106\n",
      "Iteration: 6\n",
      "new candidats: tensor([[0.7769, 0.4543],\n",
      "        [0.5064, 0.6334],\n",
      "        [0.3950, 0.3141],\n",
      "        [0.5105, 0.4629],\n",
      "        [0.4333, 0.7449]], dtype=torch.float64)\n",
      "new obj: tensor([[3.1057e-02, 4.3324e-04],\n",
      "        [5.7458e-01, 1.0375e-01],\n",
      "        [2.6446e-01, 1.1346e-01],\n",
      "        [1.0535e-01, 1.9932e-02],\n",
      "        [5.1280e-01, 5.7130e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.0977064]\n",
      "Time: 17.542882160982117\n",
      "Iteration: 7\n",
      "new candidats: tensor([[0.4662, 0.7353],\n",
      "        [0.4256, 0.7907],\n",
      "        [0.4634, 0.7198],\n",
      "        [0.8824, 0.5149],\n",
      "        [0.6517, 0.9082]], dtype=torch.float64)\n",
      "new obj: tensor([[6.2708e-01, 4.5784e-01],\n",
      "        [3.5517e-01, 6.7579e-01],\n",
      "        [6.4914e-01, 4.1761e-01],\n",
      "        [4.0144e-03, 3.7898e-05],\n",
      "        [2.5399e-02, 1.6408e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14177717]\n",
      "Time: 19.983640174847096\n",
      "Iteration: 8\n",
      "new candidats: tensor([[0.4256, 0.7907],\n",
      "        [0.5549, 0.0256],\n",
      "        [0.9557, 0.4491],\n",
      "        [0.6924, 0.4185],\n",
      "        [0.4308, 0.1437]], dtype=torch.float64)\n",
      "new obj: tensor([[3.5517e-01, 6.7579e-01],\n",
      "        [7.8412e-02, 1.8092e-02],\n",
      "        [9.5468e-03, 1.2697e-05],\n",
      "        [5.1420e-02, 2.1772e-03],\n",
      "        [2.4759e-01, 9.4422e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14177717]\n",
      "Time: 17.569622511975467\n",
      "Iteration: 9\n",
      "new candidats: tensor([[0.4683, 0.7014],\n",
      "        [0.6918, 0.5084],\n",
      "        [0.0703, 0.8304],\n",
      "        [0.5976, 0.3514],\n",
      "        [0.4256, 0.7907]], dtype=torch.float64)\n",
      "new obj: tensor([[0.6743, 0.3440],\n",
      "        [0.0285, 0.0014],\n",
      "        [0.0029, 0.0064],\n",
      "        [0.0818, 0.0116],\n",
      "        [0.3552, 0.6758]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14487176]\n",
      "Time: 30.76512434380129\n",
      "Iteration: 10\n",
      "new candidats: tensor([[0.4256, 0.7907],\n",
      "        [0.6778, 0.8986],\n",
      "        [0.8780, 0.5473],\n",
      "        [0.5192, 0.3618],\n",
      "        [0.0543, 0.3290]], dtype=torch.float64)\n",
      "new obj: tensor([[3.5517e-01, 6.7579e-01],\n",
      "        [2.0117e-02, 9.0894e-03],\n",
      "        [1.7677e-03, 3.1931e-05],\n",
      "        [1.0681e-01, 2.8968e-02],\n",
      "        [3.1144e-01, 4.0487e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14487176]\n",
      "Time: 13.405553987948224\n",
      "Iteration: 11\n",
      "new candidats: tensor([[0.7691, 0.1146],\n",
      "        [0.0688, 0.8803],\n",
      "        [0.4952, 0.8924],\n",
      "        [0.7485, 0.0277],\n",
      "        [0.4256, 0.7907]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4712, 0.1821],\n",
      "        [0.0013, 0.0036],\n",
      "        [0.1102, 0.2904],\n",
      "        [0.1471, 0.0325],\n",
      "        [0.3552, 0.6758]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14487176]\n",
      "Time: 9.857204960193485\n",
      "Iteration: 12\n",
      "new candidats: tensor([[0.0370, 0.5581],\n",
      "        [0.9235, 0.8796],\n",
      "        [0.4333, 0.7449],\n",
      "        [0.0305, 0.6070],\n",
      "        [0.1097, 0.5434]], dtype=torch.float64)\n",
      "new obj: tensor([[7.2226e-02, 9.9351e-02],\n",
      "        [2.0016e-05, 7.4282e-07],\n",
      "        [5.1280e-01, 5.7130e-01],\n",
      "        [4.4039e-02, 6.1958e-02],\n",
      "        [1.0351e-01, 1.1267e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14487176]\n",
      "Time: 16.056374080944806\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration: 13\n",
      "new candidats: tensor([[0.4333, 0.7449],\n",
      "        [0.4256, 0.7907],\n",
      "        [0.8966, 0.0101],\n",
      "        [0.6599, 0.2590],\n",
      "        [0.7193, 0.6769]], dtype=torch.float64)\n",
      "new obj: tensor([[0.5128, 0.5713],\n",
      "        [0.3552, 0.6758],\n",
      "        [0.0732, 0.0903],\n",
      "        [0.2546, 0.0062],\n",
      "        [0.0626, 0.0022]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14487176]\n",
      "Time: 11.044571697944775\n",
      "Iteration: 14\n",
      "new candidats: tensor([[0.2135, 0.1533],\n",
      "        [0.4256, 0.7907],\n",
      "        [0.3301, 0.7774],\n",
      "        [0.4371, 0.4478],\n",
      "        [0.9615, 0.5189]], dtype=torch.float64)\n",
      "new obj: tensor([[4.8544e-01, 3.7611e-01],\n",
      "        [3.5517e-01, 6.7579e-01],\n",
      "        [1.2877e-01, 5.3766e-01],\n",
      "        [1.3887e-01, 4.4390e-02],\n",
      "        [1.2788e-03, 6.7981e-06]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14487176]\n",
      "Time: 9.694705218076706\n",
      "Iteration: 15\n",
      "new candidats: tensor([[0.3703, 0.0350],\n",
      "        [0.3372, 0.7877],\n",
      "        [0.2985, 0.4108],\n",
      "        [0.4256, 0.7907],\n",
      "        [0.5584, 0.6021]], dtype=torch.float64)\n",
      "new obj: tensor([[0.2476, 0.1152],\n",
      "        [0.1319, 0.5730],\n",
      "        [0.2556, 0.1496],\n",
      "        [0.3552, 0.6758],\n",
      "        [0.3787, 0.0315]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14487176]\n",
      "Time: 37.51065069809556\n",
      "Iteration: 16\n",
      "new candidats: tensor([[0.4333, 0.7449],\n",
      "        [0.4584, 0.1359],\n",
      "        [0.2373, 0.3452],\n",
      "        [0.7203, 0.1546],\n",
      "        [0.8870, 0.5922]], dtype=torch.float64)\n",
      "new obj: tensor([[5.1280e-01, 5.7130e-01],\n",
      "        [2.0779e-01, 7.2053e-02],\n",
      "        [3.7760e-01, 2.7073e-01],\n",
      "        [4.7634e-01, 1.5815e-02],\n",
      "        [6.3802e-04, 1.7954e-05]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14487176]\n",
      "Time: 22.846503080101684\n",
      "Iteration: 1\n",
      "new candidats: tensor([[0.9866, 0.3316],\n",
      "        [0.1308, 0.2225],\n",
      "        [0.4165, 0.4644],\n",
      "        [0.1744, 0.1301],\n",
      "        [0.1476, 0.1865]], dtype=torch.float64)\n",
      "new obj: tensor([[5.1842e-02, 1.1440e-05],\n",
      "        [4.6796e-01, 4.7443e-01],\n",
      "        [1.4693e-01, 4.8984e-02],\n",
      "        [4.6654e-01, 4.1043e-01],\n",
      "        [4.8206e-01, 4.6265e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.06272585]\n",
      "Time: 14.2767411719542\n",
      "Iteration: 2\n",
      "new candidats: tensor([[0.1024, 0.1707],\n",
      "        [0.1861, 0.1939],\n",
      "        [0.0345, 0.0710],\n",
      "        [0.6181, 0.0601],\n",
      "        [0.5935, 0.4675]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4391, 0.4882],\n",
      "        [0.4986, 0.4223],\n",
      "        [0.2883, 0.3997],\n",
      "        [0.0943, 0.0092],\n",
      "        [0.0621, 0.0071]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.06887887]\n",
      "Time: 8.975023092934862\n",
      "Iteration: 3\n",
      "new candidats: tensor([[0.6368, 0.1743],\n",
      "        [0.8543, 0.7258],\n",
      "        [0.0382, 0.6876],\n",
      "        [0.4887, 0.3131],\n",
      "        [0.0435, 0.2139]], dtype=torch.float64)\n",
      "new obj: tensor([[2.2447e-01, 8.9666e-03],\n",
      "        [1.3501e-03, 2.4794e-05],\n",
      "        [1.8476e-02, 2.5820e-02],\n",
      "        [1.5367e-01, 4.7648e-02],\n",
      "        [3.6731e-01, 4.9445e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.06970964]\n",
      "Time: 12.850153545849025\n",
      "Iteration: 4\n",
      "new candidats: tensor([[0.9222, 0.4715],\n",
      "        [0.3085, 0.9981],\n",
      "        [0.3231, 0.1006],\n",
      "        [0.4491, 0.0121],\n",
      "        [0.8201, 0.0223]], dtype=torch.float64)\n",
      "new obj: tensor([[8.6333e-03, 2.2740e-05],\n",
      "        [1.4680e-03, 6.4879e-02],\n",
      "        [3.6563e-01, 1.9840e-01],\n",
      "        [1.4836e-01, 5.3370e-02],\n",
      "        [1.4421e-01, 1.7537e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.06970964]\n",
      "Time: 17.665469109779224\n",
      "Iteration: 5\n",
      "new candidats: tensor([[0.8144, 0.1837],\n",
      "        [0.6932, 0.3340],\n",
      "        [0.6849, 0.8611],\n",
      "        [0.9627, 0.0032],\n",
      "        [0.2995, 0.8073]], dtype=torch.float64)\n",
      "new obj: tensor([[0.6880, 0.1345],\n",
      "        [0.1805, 0.0031],\n",
      "        [0.0347, 0.0100],\n",
      "        [0.0271, 0.0085],\n",
      "        [0.0571, 0.4240]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.06970964]\n",
      "Time: 16.49878485291265\n",
      "Iteration: 6\n",
      "new candidats: tensor([[0.8479, 0.9101],\n",
      "        [0.0269, 0.5910],\n",
      "        [0.2844, 0.4554],\n",
      "        [0.4325, 0.7638],\n",
      "        [0.7919, 0.3676]], dtype=torch.float64)\n",
      "new obj: tensor([[1.8607e-04, 1.7271e-05],\n",
      "        [5.0886e-02, 7.2372e-02],\n",
      "        [2.0581e-01, 1.2548e-01],\n",
      "        [4.5965e-01, 6.2362e-01],\n",
      "        [1.7565e-01, 5.2136e-04]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.09973902]\n",
      "Time: 25.139424949185923\n",
      "Iteration: 7\n",
      "new candidats: tensor([[0.6361, 0.6890],\n",
      "        [0.9765, 0.0752],\n",
      "        [0.4009, 0.7816],\n",
      "        [0.3402, 0.3908],\n",
      "        [0.4622, 0.7104]], dtype=torch.float64)\n",
      "new obj: tensor([[0.2777, 0.0237],\n",
      "        [0.0679, 0.0253],\n",
      "        [0.3113, 0.6901],\n",
      "        [0.2497, 0.1274],\n",
      "        [0.6564, 0.3888]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13136567]\n",
      "Time: 27.04996026097797\n",
      "Iteration: 8\n",
      "new candidats: tensor([[0.4245, 0.7350],\n",
      "        [0.4468, 0.7253],\n",
      "        [0.6976, 0.3748],\n",
      "        [0.4261, 0.5545],\n",
      "        [0.4953, 0.2488]], dtype=torch.float64)\n",
      "new obj: tensor([[0.5027, 0.5527],\n",
      "        [0.5960, 0.4772],\n",
      "        [0.1058, 0.0025],\n",
      "        [0.2397, 0.0545],\n",
      "        [0.1692, 0.0506]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.1443699]\n",
      "Time: 8.943510413868353\n",
      "Iteration: 9\n",
      "new candidats: tensor([[0.6480, 0.5149],\n",
      "        [0.0604, 0.4534],\n",
      "        [0.4718, 0.6388],\n",
      "        [0.4075, 0.7869],\n",
      "        [0.4325, 0.7638]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0555, 0.0028],\n",
      "        [0.1756, 0.2238],\n",
      "        [0.5757, 0.1535],\n",
      "        [0.3166, 0.6937],\n",
      "        [0.4596, 0.6236]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14502108]\n",
      "Time: 22.75325862201862\n",
      "Iteration: 10\n",
      "new candidats: tensor([[0.4585, 0.7615],\n",
      "        [0.5801, 0.9123],\n",
      "        [0.5085, 0.7212],\n",
      "        [0.4622, 0.7104],\n",
      "        [0.2145, 0.3640]], dtype=torch.float64)\n",
      "new obj: tensor([[0.5357, 0.5493],\n",
      "        [0.0535, 0.0737],\n",
      "        [0.6870, 0.2863],\n",
      "        [0.6564, 0.3888],\n",
      "        [0.3564, 0.2752]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14939113]\n",
      "Time: 24.82574201002717\n",
      "Iteration: 11\n",
      "new candidats: tensor([[0.1932, 0.3032],\n",
      "        [0.6807, 0.7820],\n",
      "        [0.4995, 0.8199],\n",
      "        [0.9132, 0.5189],\n",
      "        [0.4325, 0.7638]], dtype=torch.float64)\n",
      "new obj: tensor([[4.3746e-01, 3.6212e-01],\n",
      "        [9.8100e-02, 1.3461e-02],\n",
      "        [3.4255e-01, 4.1861e-01],\n",
      "        [2.5482e-03, 1.9373e-05],\n",
      "        [4.5965e-01, 6.2362e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14939113]\n",
      "Time: 15.673803149024025\n",
      "Iteration: 12\n",
      "new candidats: tensor([[0.7765, 0.8686],\n",
      "        [0.5295, 0.8038],\n",
      "        [0.4325, 0.7638],\n",
      "        [0.9266, 0.4092],\n",
      "        [0.8532, 0.4421]], dtype=torch.float64)\n",
      "new obj: tensor([[3.7232e-03, 4.6543e-04],\n",
      "        [3.9266e-01, 3.0300e-01],\n",
      "        [4.5965e-01, 6.2362e-01],\n",
      "        [3.5606e-02, 3.0062e-05],\n",
      "        [3.3627e-02, 1.1253e-04]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14939113]\n",
      "Time: 15.83860849100165\n",
      "Iteration: 13\n",
      "new candidats: tensor([[0.2217, 0.7481],\n",
      "        [0.4325, 0.7638],\n",
      "        [0.1429, 0.3745],\n",
      "        [0.0757, 0.2008],\n",
      "        [0.5285, 0.5010]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0246, 0.1336],\n",
      "        [0.4596, 0.6236],\n",
      "        [0.3280, 0.3197],\n",
      "        [0.4122, 0.4998],\n",
      "        [0.1348, 0.0152]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14939113]\n",
      "Time: 18.224403897998855\n",
      "Iteration: 14\n",
      "new candidats: tensor([[0.1693, 0.7394],\n",
      "        [0.7077, 0.9972],\n",
      "        [0.4325, 0.7638],\n",
      "        [0.0674, 0.7664],\n",
      "        [0.7112, 0.8825]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0157, 0.0523],\n",
      "        [0.0010, 0.0009],\n",
      "        [0.4596, 0.6236],\n",
      "        [0.0073, 0.0117],\n",
      "        [0.0143, 0.0039]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14939113]\n",
      "Time: 18.377046182053164\n",
      "Iteration: 15\n",
      "new candidats: tensor([[0.4325, 0.7638],\n",
      "        [0.4181, 0.2733],\n",
      "        [0.6669, 0.1726],\n",
      "        [0.0922, 0.4597],\n",
      "        [0.2660, 0.0617]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4596, 0.6236],\n",
      "        [0.2584, 0.1028],\n",
      "        [0.3105, 0.0061],\n",
      "        [0.1861, 0.2139],\n",
      "        [0.3728, 0.2435]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14939113]\n",
      "Time: 23.734413110883906\n",
      "Iteration: 16\n",
      "new candidats: tensor([[0.0200, 0.8591],\n",
      "        [0.4325, 0.7638],\n",
      "        [0.9889, 0.6785],\n",
      "        [0.8511, 0.0656],\n",
      "        [0.5554, 0.4351]], dtype=torch.float64)\n",
      "new obj: tensor([[1.4622e-03, 2.5517e-03],\n",
      "        [4.5965e-01, 6.2362e-01],\n",
      "        [1.7619e-05, 7.5486e-07],\n",
      "        [2.5089e-01, 5.5239e-01],\n",
      "        [7.1870e-02, 1.3455e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14939113]\n",
      "Time: 18.357659386005253\n"
     ]
    }
   ],
   "source": [
    "import torch\n",
    "import time\n",
    "import gpytorch\n",
    "from matplotlib import pyplot as plt\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "from scipy.stats import norm\n",
    "from pyDOE import *\n",
    "from copy import deepcopy\n",
    "import os\n",
    "import shutil\n",
    "from multiprocessing import Pool\n",
    "import multiprocessing\n",
    "from joblib import Parallel, delayed\n",
    "import random\n",
    "import warnings\n",
    "\n",
    "warnings.filterwarnings(\"ignore\")\n",
    "\n",
    "itr=16\n",
    "N_dim=2\n",
    "N_test=1500\n",
    "N_alt=100\n",
    "N_samp=1\n",
    "N_obj=2\n",
    "MC_SAMPLES = 10\n",
    "BATCH_SIZE = 5\n",
    "opt_imp=[]\n",
    "#chosen_acq='EI'\n",
    "chosen_acq='EI_Botorch'\n",
    "#chosen_acq='PES_Botorch'\n",
    "#chosen_acq='MFDS_Botorch'\n",
    "#chosen_acq='TPE_Optuna'\n",
    "#chosen_acq='RS_Botorch'\n",
    "verbose = True\n",
    "rep=20\n",
    "hv_total=[]\n",
    "edmin_total=[]\n",
    "\n",
    "for j in range(rep):\n",
    "    \n",
    "    train_x_qehvi, train_y_qehvi, _ = generate_initial_data(seed=j)\n",
    "    data_x_qehvi=train_x_qehvi.detach().numpy()\n",
    "    data_y_qehvi=train_y_qehvi.detach().numpy()\n",
    "    train_x_qehvi=torch.tensor(train_x_qehvi).to(**tkwargs)\n",
    "    train_y_qehvi=torch.tensor(train_y_qehvi).to(**tkwargs)\n",
    "    mll_qehvi, model_qehvi = initialize_model(train_x_qehvi, train_y_qehvi)\n",
    "    \n",
    "    X_test_all=lhs(N_dim,N_test)\n",
    "    X_test_all=torch.tensor(X_test_all)\n",
    "    #X_test_all=unnormalize(X_test_all, problem.bounds)\n",
    "    Y_test_all = problem(X_test_all)\n",
    "    X_test_all = torch.tensor(X_test_all).to(**tkwargs)\n",
    "    \n",
    "    \n",
    "    # Find PF ground truth and calculate HV\n",
    "    pareto_mask_test_all = is_non_dominated(Y_test_all)\n",
    "    Y_pf = Y_test_all[pareto_mask_test_all]  \n",
    "    bd_test_all = DominatedPartitioning(ref_point=problem.ref_point, Y=Y_pf)\n",
    "    volume_test_all = bd_test_all.compute_hypervolume().item()\n",
    "    \n",
    "    # Initialize edmin\n",
    "    X_pf = torch.tensor(X_test_all[pareto_mask_test_all]).to(**tkwargs) \n",
    "    edmin = distance_XX(train_x_qehvi, X_pf).reshape(1,1)\n",
    "    \n",
    "    # Initialize hv\n",
    "    pareto_mask_train = is_non_dominated(train_y_qehvi)\n",
    "    Y_pf_train = train_y_qehvi[pareto_mask_train] \n",
    "    bd_train = DominatedPartitioning(ref_point=problem.ref_point, Y=Y_pf_train)\n",
    "    hv_truth = np.array(bd_train.compute_hypervolume().item()).reshape(1,1) \n",
    "        \n",
    "    iteration=0\n",
    "    if chosen_acq == 'EI_Botorch':\n",
    "    \n",
    "        while iteration<itr:\n",
    "            iteration += 1\n",
    "            t0 = time.monotonic()\n",
    "            \n",
    "            X_test=lhs(N_dim,N_alt)\n",
    "            X_test=torch.tensor(X_test)\n",
    "            #X_test=unnormalize(X_test, problem.bounds)\n",
    "            \n",
    "            # Fit the models\n",
    "            fit_gpytorch_mll(mll_qehvi)\n",
    "\n",
    "            # Define the qEHVI acquisition module using a QMC sampler\n",
    "            qehvi_sampler = SobolQMCNormalSampler(sample_shape=torch.Size([MC_SAMPLES]))\n",
    "\n",
    "            # Optimize acquisition function and get new observations\n",
    "            new_x_qehvi, new_y_qehvi, new_y_true_qehvi = optimize_qehvi_and_get_observation(\n",
    "                model_qehvi, train_x_qehvi, train_y_qehvi, qehvi_sampler, X_test_all, BATCH_SIZE\n",
    "            )\n",
    "            \n",
    "            # Update training points\n",
    "            train_x_qehvi = torch.cat([train_x_qehvi, new_x_qehvi.reshape(-1, N_dim)])\n",
    "            train_y_qehvi = torch.cat([train_y_qehvi, new_y_qehvi.reshape(-1, N_obj)])\n",
    "            data_x_qehvi=train_x_qehvi.cpu().detach().numpy()\n",
    "            data_y_qehvi=train_y_qehvi.cpu().detach().numpy()\n",
    "            \n",
    "            # Compute hypervolume\n",
    "            pareto_mask_train = is_non_dominated(train_y_qehvi)\n",
    "            Y_pf_train = train_y_qehvi[pareto_mask_train] \n",
    "            bd_train = DominatedPartitioning(ref_point=problem.ref_point, Y=Y_pf_train)\n",
    "            hv_t = np.array(bd_train.compute_hypervolume().item())    \n",
    "            hv_truth=np.concatenate((hv_truth,hv_t.reshape(1,1)))\n",
    "            \n",
    "            # Compute edmin\n",
    "            ed_t = distance_XX(train_x_qehvi, X_pf).reshape(1,1)\n",
    "            edmin = torch.cat((edmin, ed_t.reshape(1,1)))\n",
    "\n",
    "            # Reinitialize the models for next iteration\n",
    "            mll_qehvi, model_qehvi = initialize_model(train_x_qehvi, train_y_qehvi)\n",
    "\n",
    "            t1 = time.monotonic()\n",
    "\n",
    "            if verbose:\n",
    "                print(\"Iteration:\", iteration)\n",
    "                print('new candidats:', new_x_qehvi) \n",
    "                print('new obj:', new_y_qehvi)\n",
    "                print(\"Hypervolume (qEHVI):\", hv_truth[-1])\n",
    "                print(\"Time:\", t1 - t0)\n",
    "     \n",
    "            pd.DataFrame(Y_pf_train).to_csv(\"y_pareto_truth.csv\", header=None, index=None)\n",
    "            pd.DataFrame(data_x_qehvi).to_csv(\"data_x\"+str(j)+\".csv\", header=None, index=None)\n",
    "            pd.DataFrame(data_y_qehvi).to_csv(\"data_y\"+str(j)+\".csv\", header=None, index=None)\n",
    "            pd.DataFrame(hv_truth).to_csv(\"hv_truth.csv\", header=None, index=None)\n",
    "\n",
    "    # Save hv\n",
    "    hv_total.append(np.ravel(hv_truth))\n",
    "    pd.DataFrame(hv_total).to_csv(\"hv_truth_total.csv\", header=None, index=None)\n",
    "    \n",
    "    # Save edmin\n",
    "    edmin_total.append(np.ravel(edmin.cpu().detach().numpy()))\n",
    "    pd.DataFrame(edmin_total).to_csv(\"edmin_total.csv\", header=None, index=None)\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "decf4358",
   "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
}
