{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 2,
   "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": 3,
   "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": 12,
   "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 botorch.acquisition.multi_objective.monte_carlo import (\n",
    "    qExpectedHypervolumeImprovement,\n",
    ")\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",
    "    acq_func = qExpectedHypervolumeImprovement(\n",
    "        model=model,\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": 13,
   "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": 16,
   "id": "b763fe2b",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration: 1\n",
      "new candidats: tensor([[0.4852, 0.6015],\n",
      "        [0.0247, 0.2185],\n",
      "        [0.0835, 0.4257],\n",
      "        [0.1628, 0.1594],\n",
      "        [0.2190, 0.3533]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4503, 0.0756],\n",
      "        [0.3391, 0.4853],\n",
      "        [0.2232, 0.2639],\n",
      "        [0.4814, 0.4398],\n",
      "        [0.3711, 0.2825]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.0611879]\n",
      "Time: 10.533626246033236\n",
      "Iteration: 2\n",
      "new candidats: tensor([[0.5361, 0.2215],\n",
      "        [0.1331, 0.2711],\n",
      "        [0.9098, 0.2501],\n",
      "        [0.7832, 0.5449],\n",
      "        [0.1026, 0.1626]], dtype=torch.float64)\n",
      "new obj: tensor([[1.4217e-01, 3.2908e-02],\n",
      "        [4.4389e-01, 4.4661e-01],\n",
      "        [3.3895e-01, 3.8650e-03],\n",
      "        [7.2196e-03, 2.1318e-04],\n",
      "        [4.3636e-01, 4.8484e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.06342964]\n",
      "Time: 10.251836991868913\n",
      "Iteration: 3\n",
      "new candidats: tensor([[0.1974, 0.1618],\n",
      "        [0.6815, 0.7754],\n",
      "        [0.2247, 0.0410],\n",
      "        [0.5110, 0.8480],\n",
      "        [0.4954, 0.3976]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4909, 0.4008],\n",
      "        [0.1019, 0.0130],\n",
      "        [0.3618, 0.2703],\n",
      "        [0.2334, 0.3370],\n",
      "        [0.1113, 0.0321]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.06514971]\n",
      "Time: 10.958717836998403\n",
      "Iteration: 4\n",
      "new candidats: tensor([[0.0835, 0.4257],\n",
      "        [0.1761, 0.2121],\n",
      "        [0.7859, 0.4525],\n",
      "        [0.7767, 0.0536],\n",
      "        [0.0596, 0.1911]], dtype=torch.float64)\n",
      "new obj: tensor([[2.2321e-01, 2.6392e-01],\n",
      "        [4.9555e-01, 4.3355e-01],\n",
      "        [3.2265e-02, 3.7309e-04],\n",
      "        [2.3911e-01, 1.5605e-01],\n",
      "        [3.9043e-01, 4.9884e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.06858955]\n",
      "Time: 10.761213649995625\n",
      "Iteration: 5\n",
      "new candidats: tensor([[0.2115, 0.2140],\n",
      "        [0.1265, 0.9065],\n",
      "        [0.2247, 0.0410],\n",
      "        [0.0105, 0.0500],\n",
      "        [0.9250, 0.9846]], dtype=torch.float64)\n",
      "new obj: tensor([[4.9795e-01, 3.8834e-01],\n",
      "        [9.8938e-04, 1.0370e-02],\n",
      "        [3.6179e-01, 2.7033e-01],\n",
      "        [2.4090e-01, 3.6104e-01],\n",
      "        [1.7756e-06, 1.5607e-07]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.06899096]\n",
      "Time: 5.771015027072281\n",
      "Iteration: 6\n",
      "new candidats: tensor([[0.9763, 0.0098],\n",
      "        [0.9763, 0.0098],\n",
      "        [0.2568, 0.9110],\n",
      "        [0.9900, 0.0240],\n",
      "        [0.1921, 0.0421]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0244, 0.0057],\n",
      "        [0.0244, 0.0057],\n",
      "        [0.0048, 0.1362],\n",
      "        [0.0246, 0.0044],\n",
      "        [0.3658, 0.3038]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.06899096]\n",
      "Time: 2.980498183052987\n",
      "Iteration: 7\n",
      "new candidats: tensor([[0.1066, 0.1956],\n",
      "        [0.3590, 0.6992],\n",
      "        [0.1203, 0.2077],\n",
      "        [0.2327, 0.0751],\n",
      "        [0.7987, 0.7151]], dtype=torch.float64)\n",
      "new obj: tensor([[4.4829e-01, 4.9156e-01],\n",
      "        [2.7515e-01, 3.9516e-01],\n",
      "        [4.6145e-01, 4.8410e-01],\n",
      "        [4.0593e-01, 2.9553e-01],\n",
      "        [8.1897e-03, 1.9599e-04]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07038168]\n",
      "Time: 2.4149797700811177\n",
      "Iteration: 8\n",
      "new candidats: tensor([[0.5041, 0.8932],\n",
      "        [0.4056, 0.8390],\n",
      "        [0.6126, 0.5426],\n",
      "        [0.4840, 0.7174],\n",
      "        [0.8761, 0.4893]], dtype=torch.float64)\n",
      "new obj: tensor([[1.0854e-01, 2.6377e-01],\n",
      "        [1.7248e-01, 6.4849e-01],\n",
      "        [1.2155e-01, 5.5619e-03],\n",
      "        [6.8716e-01, 3.5174e-01],\n",
      "        [8.6193e-03, 5.2172e-05]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.09509983]\n",
      "Time: 14.369936580071226\n",
      "Iteration: 9\n",
      "new candidats: tensor([[0.4294, 0.7849],\n",
      "        [0.2412, 0.2658],\n",
      "        [0.4706, 0.7429],\n",
      "        [0.0220, 0.3458],\n",
      "        [0.6581, 0.6890]], dtype=torch.float64)\n",
      "new obj: tensor([[0.3842, 0.6641],\n",
      "        [0.4637, 0.3284],\n",
      "        [0.6164, 0.4654],\n",
      "        [0.2581, 0.3725],\n",
      "        [0.2013, 0.0139]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13456592]\n",
      "Time: 8.145543721038848\n",
      "Iteration: 10\n",
      "new candidats: tensor([[0.4840, 0.7174],\n",
      "        [0.9451, 0.3362],\n",
      "        [0.2364, 0.8111],\n",
      "        [0.4430, 0.7552],\n",
      "        [0.6590, 0.4454]], dtype=torch.float64)\n",
      "new obj: tensor([[6.8716e-01, 3.5174e-01],\n",
      "        [9.7010e-02, 2.9245e-05],\n",
      "        [1.6304e-02, 1.8574e-01],\n",
      "        [5.1586e-01, 5.7926e-01],\n",
      "        [3.7398e-02, 3.1256e-03]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14758981]\n",
      "Time: 2.8842102659400553\n",
      "Iteration: 11\n",
      "new candidats: tensor([[0.5138, 0.8159],\n",
      "        [0.5085, 0.1200],\n",
      "        [0.9440, 0.0517],\n",
      "        [0.3862, 0.5069],\n",
      "        [0.4430, 0.7552]], dtype=torch.float64)\n",
      "new obj: tensor([[0.3555, 0.3620],\n",
      "        [0.1477, 0.0417],\n",
      "        [0.0830, 0.0751],\n",
      "        [0.1567, 0.0536],\n",
      "        [0.5159, 0.5793]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14758981]\n",
      "Time: 1.9192497259937227\n",
      "Iteration: 12\n",
      "new candidats: tensor([[0.7832, 0.5449],\n",
      "        [0.5407, 0.5873],\n",
      "        [0.3501, 0.5686],\n",
      "        [0.4430, 0.7552],\n",
      "        [0.7873, 0.9690]], dtype=torch.float64)\n",
      "new obj: tensor([[7.2196e-03, 2.1318e-04],\n",
      "        [3.5926e-01, 3.1874e-02],\n",
      "        [1.6506e-01, 7.6815e-02],\n",
      "        [5.1586e-01, 5.7926e-01],\n",
      "        [3.0688e-04, 9.3267e-05]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14758981]\n",
      "Time: 2.0342002229299396\n",
      "Iteration: 13\n",
      "new candidats: tensor([[0.5190, 0.1601],\n",
      "        [0.4840, 0.7174],\n",
      "        [0.0842, 0.1749],\n",
      "        [0.7224, 0.8170],\n",
      "        [0.4708, 0.7295]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1498, 0.0394],\n",
      "        [0.6872, 0.3517],\n",
      "        [0.4195, 0.4948],\n",
      "        [0.0299, 0.0038],\n",
      "        [0.6481, 0.4271]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14998154]\n",
      "Time: 2.195686243008822\n",
      "Iteration: 14\n",
      "new candidats: tensor([[0.6064, 0.6626],\n",
      "        [0.4430, 0.7552],\n",
      "        [0.9787, 0.1829],\n",
      "        [0.3200, 0.4364],\n",
      "        [0.6293, 0.9642]], dtype=torch.float64)\n",
      "new obj: tensor([[0.3750, 0.0333],\n",
      "        [0.5159, 0.5793],\n",
      "        [0.1399, 0.0064],\n",
      "        [0.2120, 0.1146],\n",
      "        [0.0093, 0.0131]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14998154]\n",
      "Time: 2.2605152330361307\n",
      "Iteration: 15\n",
      "new candidats: tensor([[0.4430, 0.7552],\n",
      "        [0.3964, 0.0938],\n",
      "        [0.9648, 0.4273],\n",
      "        [0.1996, 0.6306],\n",
      "        [0.8339, 0.8698]], dtype=torch.float64)\n",
      "new obj: tensor([[5.1586e-01, 5.7926e-01],\n",
      "        [2.6827e-01, 1.1467e-01],\n",
      "        [1.3777e-02, 1.1801e-05],\n",
      "        [5.5304e-02, 6.2304e-02],\n",
      "        [6.4014e-04, 4.5997e-05]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14998154]\n",
      "Time: 2.4312149831093848\n",
      "Iteration: 16\n",
      "new candidats: tensor([[0.5482, 0.3812],\n",
      "        [0.4430, 0.7552],\n",
      "        [0.1583, 0.8213],\n",
      "        [0.1628, 0.1594],\n",
      "        [0.4430, 0.7552]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0824, 0.0190],\n",
      "        [0.5159, 0.5793],\n",
      "        [0.0049, 0.0405],\n",
      "        [0.4814, 0.4398],\n",
      "        [0.5159, 0.5793]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14998154]\n",
      "Time: 2.2883595780003816\n",
      "Iteration: 1\n",
      "new candidats: tensor([[0.4382, 0.6690],\n",
      "        [0.4407, 0.9011],\n",
      "        [0.4141, 0.6975],\n",
      "        [0.4835, 0.7242],\n",
      "        [0.7796, 0.4702]], dtype=torch.float64)\n",
      "new obj: tensor([[5.6695e-01, 2.8168e-01],\n",
      "        [7.8295e-02, 3.8695e-01],\n",
      "        [4.9657e-01, 4.1498e-01],\n",
      "        [6.7656e-01, 3.7247e-01],\n",
      "        [2.1840e-02, 3.7341e-04]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.12584848]\n",
      "Time: 7.008380889892578\n",
      "Iteration: 2\n",
      "new candidats: tensor([[0.5666, 0.0726],\n",
      "        [0.2343, 0.8767],\n",
      "        [0.4659, 0.7371],\n",
      "        [0.9309, 0.3296],\n",
      "        [0.1023, 0.8875]], dtype=torch.float64)\n",
      "new obj: tensor([[9.6489e-02, 1.8719e-02],\n",
      "        [5.9159e-03, 1.3329e-01],\n",
      "        [6.2230e-01, 4.6397e-01],\n",
      "        [1.2882e-01, 4.3382e-05],\n",
      "        [1.2495e-03, 7.0204e-03]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.1383868]\n",
      "Time: 9.935298511059955\n",
      "Iteration: 3\n",
      "new candidats: tensor([[0.9088, 0.6598],\n",
      "        [0.4279, 0.7715],\n",
      "        [0.1396, 0.2238],\n",
      "        [0.3729, 0.3335],\n",
      "        [0.7847, 0.7962]], dtype=torch.float64)\n",
      "new obj: tensor([[2.2858e-04, 6.0229e-06],\n",
      "        [4.2256e-01, 6.4811e-01],\n",
      "        [4.7436e-01, 4.6730e-01],\n",
      "        [2.7573e-01, 1.2707e-01],\n",
      "        [7.7336e-03, 4.3692e-04]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14517009]\n",
      "Time: 11.768382801907137\n",
      "Iteration: 4\n",
      "new candidats: tensor([[0.4440, 0.7530],\n",
      "        [0.6192, 0.9812],\n",
      "        [0.2589, 0.8453],\n",
      "        [0.9488, 0.1518],\n",
      "        [0.4761, 0.1258]], dtype=torch.float64)\n",
      "new obj: tensor([[0.5253, 0.5708],\n",
      "        [0.0066, 0.0123],\n",
      "        [0.0159, 0.2351],\n",
      "        [0.2063, 0.0580],\n",
      "        [0.1828, 0.0594]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15049029]\n",
      "Time: 7.909658784978092\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration: 5\n",
      "new candidats: tensor([[0.4581, 0.4175],\n",
      "        [0.5619, 0.1726],\n",
      "        [0.3982, 0.7872],\n",
      "        [0.3214, 0.8414],\n",
      "        [0.3185, 0.4659]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1325, 0.0425],\n",
      "        [0.1360, 0.0241],\n",
      "        [0.2892, 0.6959],\n",
      "        [0.0547, 0.4732],\n",
      "        [0.1820, 0.0973]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15313806]\n",
      "Time: 6.907051166053861\n",
      "Iteration: 6\n",
      "new candidats: tensor([[0.9423, 0.3506],\n",
      "        [0.4279, 0.7715],\n",
      "        [0.1358, 0.4828],\n",
      "        [0.4611, 0.7358],\n",
      "        [0.3458, 0.8713]], dtype=torch.float64)\n",
      "new obj: tensor([[8.2176e-02, 2.8288e-05],\n",
      "        [4.2256e-01, 6.4811e-01],\n",
      "        [1.7488e-01, 1.7445e-01],\n",
      "        [6.1477e-01, 4.7447e-01],\n",
      "        [5.0522e-02, 4.6941e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15407726]\n",
      "Time: 8.153911207104102\n",
      "Iteration: 7\n",
      "new candidats: tensor([[0.8658, 0.5479],\n",
      "        [0.5194, 0.3946],\n",
      "        [0.7383, 0.2472],\n",
      "        [0.4440, 0.7530],\n",
      "        [0.5607, 0.6383]], dtype=torch.float64)\n",
      "new obj: tensor([[2.0338e-03, 4.0772e-05],\n",
      "        [9.5532e-02, 2.5032e-02],\n",
      "        [5.3071e-01, 2.5888e-03],\n",
      "        [5.2529e-01, 5.7080e-01],\n",
      "        [4.9006e-01, 5.4254e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15407726]\n",
      "Time: 7.192181905964389\n",
      "Iteration: 8\n",
      "new candidats: tensor([[0.4678, 0.3658],\n",
      "        [0.4440, 0.7530],\n",
      "        [0.9843, 0.2022],\n",
      "        [0.0368, 0.7617],\n",
      "        [0.6415, 0.4847]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1479, 0.0491],\n",
      "        [0.5253, 0.5708],\n",
      "        [0.1283, 0.0024],\n",
      "        [0.0070, 0.0104],\n",
      "        [0.0447, 0.0033]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15407726]\n",
      "Time: 2.884027661057189\n",
      "Iteration: 9\n",
      "new candidats: tensor([[0.8726, 0.3784],\n",
      "        [0.7101, 0.3083],\n",
      "        [0.7252, 0.5010],\n",
      "        [0.1794, 0.9179],\n",
      "        [0.4440, 0.7530]], dtype=torch.float64)\n",
      "new obj: tensor([[1.1067e-01, 1.0702e-04],\n",
      "        [2.7655e-01, 2.5793e-03],\n",
      "        [1.8492e-02, 7.9384e-04],\n",
      "        [1.1754e-03, 3.1367e-02],\n",
      "        [5.2529e-01, 5.7080e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15407726]\n",
      "Time: 2.3600012650713325\n",
      "Iteration: 10\n",
      "new candidats: tensor([[0.2868, 0.0048],\n",
      "        [0.9404, 0.3802],\n",
      "        [0.1681, 0.8185],\n",
      "        [0.2545, 0.3380],\n",
      "        [0.4440, 0.7530]], dtype=torch.float64)\n",
      "new obj: tensor([[2.8265e-01, 1.7258e-01],\n",
      "        [5.1816e-02, 2.5692e-05],\n",
      "        [5.5470e-03, 5.0470e-02],\n",
      "        [3.7971e-01, 2.5748e-01],\n",
      "        [5.2529e-01, 5.7080e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15407726]\n",
      "Time: 4.617760844063014\n",
      "Iteration: 11\n",
      "new candidats: tensor([[0.2255, 0.5212],\n",
      "        [0.7661, 0.9083],\n",
      "        [0.5688, 0.7164],\n",
      "        [0.3214, 0.8414],\n",
      "        [0.4440, 0.7530]], dtype=torch.float64)\n",
      "new obj: tensor([[1.3982e-01, 1.0487e-01],\n",
      "        [2.3389e-03, 4.8142e-04],\n",
      "        [5.4840e-01, 1.1949e-01],\n",
      "        [5.4739e-02, 4.7321e-01],\n",
      "        [5.2529e-01, 5.7080e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15407726]\n",
      "Time: 2.9859377609100193\n",
      "Iteration: 12\n",
      "new candidats: tensor([[0.8029, 0.9612],\n",
      "        [0.3540, 0.4196],\n",
      "        [0.9423, 0.3506],\n",
      "        [0.6197, 0.0509],\n",
      "        [0.4440, 0.7530]], dtype=torch.float64)\n",
      "new obj: tensor([[2.3859e-04, 5.7334e-05],\n",
      "        [2.0812e-01, 1.0026e-01],\n",
      "        [8.2176e-02, 2.8288e-05],\n",
      "        [8.7227e-02, 8.6785e-03],\n",
      "        [5.2529e-01, 5.7080e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15407726]\n",
      "Time: 7.257703124079853\n",
      "Iteration: 13\n",
      "new candidats: tensor([[0.4975, 0.7016],\n",
      "        [0.6753, 0.4332],\n",
      "        [0.5335, 0.8216],\n",
      "        [0.4835, 0.7242],\n",
      "        [0.7101, 0.3083]], dtype=torch.float64)\n",
      "new obj: tensor([[0.7068, 0.2703],\n",
      "        [0.0406, 0.0026],\n",
      "        [0.3169, 0.2808],\n",
      "        [0.6766, 0.3725],\n",
      "        [0.2766, 0.0026]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15556577]\n",
      "Time: 3.132189539959654\n",
      "Iteration: 14\n",
      "new candidats: tensor([[0.1050, 0.3764],\n",
      "        [0.0985, 0.5970],\n",
      "        [0.1342, 0.5925],\n",
      "        [0.4440, 0.7530],\n",
      "        [0.2545, 0.3380]], dtype=torch.float64)\n",
      "new obj: tensor([[0.3027, 0.3337],\n",
      "        [0.0614, 0.0700],\n",
      "        [0.0695, 0.0716],\n",
      "        [0.5253, 0.5708],\n",
      "        [0.3797, 0.2575]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15556577]\n",
      "Time: 3.8744810589123517\n",
      "Iteration: 15\n",
      "new candidats: tensor([[0.4440, 0.7530],\n",
      "        [0.5006, 0.5372],\n",
      "        [0.9438, 0.6517],\n",
      "        [0.5909, 0.8442],\n",
      "        [0.4581, 0.4175]], dtype=torch.float64)\n",
      "new obj: tensor([[5.2529e-01, 5.7080e-01],\n",
      "        [2.2500e-01, 2.5243e-02],\n",
      "        [8.0828e-05, 2.8815e-06],\n",
      "        [1.6413e-01, 1.0270e-01],\n",
      "        [1.3245e-01, 4.2533e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15556577]\n",
      "Time: 1.9747904490213841\n",
      "Iteration: 16\n",
      "new candidats: tensor([[0.9256, 0.8333],\n",
      "        [0.1136, 0.1213],\n",
      "        [0.9233, 0.0736],\n",
      "        [0.1324, 0.9793],\n",
      "        [0.0130, 0.0314]], dtype=torch.float64)\n",
      "new obj: tensor([[3.8126e-05, 1.0155e-06],\n",
      "        [4.2147e-01, 4.5186e-01],\n",
      "        [1.4795e-01, 2.0820e-01],\n",
      "        [2.5462e-04, 4.1411e-03],\n",
      "        [2.2639e-01, 3.3657e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15556577]\n",
      "Time: 10.58769691013731\n",
      "Iteration: 1\n",
      "new candidats: tensor([[0.8393, 0.1733],\n",
      "        [0.9087, 0.6069],\n",
      "        [0.9827, 0.0610],\n",
      "        [0.4105, 0.7351],\n",
      "        [0.7685, 0.0835]], dtype=torch.float64)\n",
      "new obj: tensor([[6.2838e-01, 2.3387e-01],\n",
      "        [3.2373e-04, 9.8364e-06],\n",
      "        [5.0384e-02, 1.5279e-02],\n",
      "        [4.4880e-01, 5.6724e-01],\n",
      "        [3.4544e-01, 1.7649e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.09056548]\n",
      "Time: 9.896331747993827\n",
      "Iteration: 2\n",
      "new candidats: tensor([[0.3603, 0.7551],\n",
      "        [0.1332, 0.1769],\n",
      "        [0.0545, 0.2210],\n",
      "        [0.5908, 0.0139],\n",
      "        [0.5850, 0.1846]], dtype=torch.float64)\n",
      "new obj: tensor([[0.2343, 0.5887],\n",
      "        [0.4697, 0.4725],\n",
      "        [0.3817, 0.4958],\n",
      "        [0.0620, 0.0109],\n",
      "        [0.1467, 0.0181]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.09398371]\n",
      "Time: 10.845960399135947\n",
      "Iteration: 3\n",
      "new candidats: tensor([[0.4323, 0.8290],\n",
      "        [0.8645, 0.2126],\n",
      "        [0.4510, 0.7387],\n",
      "        [0.4235, 0.9542],\n",
      "        [0.3816, 1.0000]], dtype=torch.float64)\n",
      "new obj: tensor([[0.2440, 0.6377],\n",
      "        [0.5661, 0.0534],\n",
      "        [0.5821, 0.5115],\n",
      "        [0.0209, 0.2074],\n",
      "        [0.0040, 0.0932]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.12544524]\n",
      "Time: 11.187199813080952\n",
      "Iteration: 4\n",
      "new candidats: tensor([[0.0290, 0.8347],\n",
      "        [0.4550, 0.7712],\n",
      "        [0.9378, 0.9735],\n",
      "        [0.4743, 0.7291],\n",
      "        [0.3447, 0.4417]], dtype=torch.float64)\n",
      "new obj: tensor([[2.2600e-03, 3.8593e-03],\n",
      "        [4.9478e-01, 5.7863e-01],\n",
      "        [1.4558e-06, 1.0429e-07],\n",
      "        [6.5507e-01, 4.1509e-01],\n",
      "        [1.9288e-01, 9.4782e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14345982]\n",
      "Time: 9.56363622401841\n",
      "Iteration: 5\n",
      "new candidats: tensor([[0.2139, 0.0286],\n",
      "        [0.4826, 0.7109],\n",
      "        [0.8884, 0.2522],\n",
      "        [0.3667, 0.4387],\n",
      "        [0.4398, 0.7580]], dtype=torch.float64)\n",
      "new obj: tensor([[0.3455, 0.2673],\n",
      "        [0.6925, 0.3368],\n",
      "        [0.4146, 0.0052],\n",
      "        [0.1828, 0.0826],\n",
      "        [0.4987, 0.5938]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15062629]\n",
      "Time: 11.454258798854426\n",
      "Iteration: 6\n",
      "new candidats: tensor([[0.4398, 0.7580],\n",
      "        [0.3941, 0.5960],\n",
      "        [0.4248, 0.5046],\n",
      "        [0.6901, 0.6213],\n",
      "        [0.1556, 0.5759]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4987, 0.5938],\n",
      "        [0.2767, 0.1062],\n",
      "        [0.1616, 0.0411],\n",
      "        [0.0870, 0.0026],\n",
      "        [0.0842, 0.0808]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15062629]\n",
      "Time: 9.06999659189023\n",
      "Iteration: 7\n",
      "new candidats: tensor([[0.9240, 0.8270],\n",
      "        [0.4743, 0.7291],\n",
      "        [0.5250, 0.7754],\n",
      "        [0.5081, 0.8391],\n",
      "        [0.4398, 0.7580]], dtype=torch.float64)\n",
      "new obj: tensor([[4.4260e-05, 1.1400e-06],\n",
      "        [6.5507e-01, 4.1509e-01],\n",
      "        [5.1255e-01, 3.1158e-01],\n",
      "        [2.6607e-01, 3.6177e-01],\n",
      "        [4.9868e-01, 5.9384e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15062629]\n",
      "Time: 6.6001135220285505\n",
      "Iteration: 8\n",
      "new candidats: tensor([[0.8627, 0.8675],\n",
      "        [0.7939, 0.3369],\n",
      "        [0.8645, 0.2126],\n",
      "        [0.4398, 0.7580],\n",
      "        [0.4380, 0.2407]], dtype=torch.float64)\n",
      "new obj: tensor([[2.4727e-04, 1.3250e-05],\n",
      "        [2.7851e-01, 5.7095e-04],\n",
      "        [5.6613e-01, 5.3399e-02],\n",
      "        [4.9868e-01, 5.9384e-01],\n",
      "        [2.4220e-01, 9.0124e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15062629]\n",
      "Time: 5.2415235850494355\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration: 9\n",
      "new candidats: tensor([[0.4398, 0.7580],\n",
      "        [0.1704, 0.2440],\n",
      "        [0.7097, 0.0566],\n",
      "        [0.7470, 0.0511],\n",
      "        [0.6699, 0.0174]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4987, 0.5938],\n",
      "        [0.4827, 0.4303],\n",
      "        [0.1815, 0.0117],\n",
      "        [0.2097, 0.0531],\n",
      "        [0.0775, 0.0039]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15062629]\n",
      "Time: 7.468242367031053\n",
      "Iteration: 10\n",
      "new candidats: tensor([[0.4350, 0.0602],\n",
      "        [0.8834, 0.8645],\n",
      "        [0.4398, 0.7580],\n",
      "        [0.1891, 0.5713],\n",
      "        [0.0669, 0.1400]], dtype=torch.float64)\n",
      "new obj: tensor([[1.9675e-01, 7.4091e-02],\n",
      "        [1.2198e-04, 5.2966e-06],\n",
      "        [4.9868e-01, 5.9384e-01],\n",
      "        [9.1541e-02, 8.0271e-02],\n",
      "        [3.8307e-01, 4.7792e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15062629]\n",
      "Time: 2.366157392039895\n",
      "Iteration: 11\n",
      "new candidats: tensor([[0.7460, 0.5203],\n",
      "        [0.4398, 0.7580],\n",
      "        [0.8458, 0.4595],\n",
      "        [0.9087, 0.6069],\n",
      "        [0.5093, 0.2748]], dtype=torch.float64)\n",
      "new obj: tensor([[1.3685e-02, 4.9389e-04],\n",
      "        [4.9868e-01, 5.9384e-01],\n",
      "        [2.2987e-02, 1.1645e-04],\n",
      "        [3.2373e-04, 9.8364e-06],\n",
      "        [1.4885e-01, 4.1784e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15062629]\n",
      "Time: 2.1221238058060408\n",
      "Iteration: 12\n",
      "new candidats: tensor([[0.2823, 0.4364],\n",
      "        [0.5569, 0.3671],\n",
      "        [0.4580, 0.3829],\n",
      "        [0.4398, 0.7580],\n",
      "        [0.2052, 0.1531]], dtype=torch.float64)\n",
      "new obj: tensor([[0.2305, 0.1420],\n",
      "        [0.0831, 0.0182],\n",
      "        [0.1478, 0.0502],\n",
      "        [0.4987, 0.5938],\n",
      "        [0.4863, 0.3871]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15062629]\n",
      "Time: 1.9553276649676263\n",
      "Iteration: 13\n",
      "new candidats: tensor([[0.4398, 0.7580],\n",
      "        [0.5474, 0.1739],\n",
      "        [0.1887, 0.8843],\n",
      "        [0.6901, 0.6213],\n",
      "        [0.7405, 0.1297]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4987, 0.5938],\n",
      "        [0.1375, 0.0287],\n",
      "        [0.0024, 0.0538],\n",
      "        [0.0870, 0.0026],\n",
      "        [0.4703, 0.0550]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15062629]\n",
      "Time: 2.1123178398702294\n",
      "Iteration: 14\n",
      "new candidats: tensor([[0.4912, 0.3789],\n",
      "        [0.3949, 0.0440],\n",
      "        [0.9323, 0.0115],\n",
      "        [0.4398, 0.7580],\n",
      "        [0.8245, 0.4907]], dtype=torch.float64)\n",
      "new obj: tensor([[1.2130e-01, 3.6533e-02],\n",
      "        [2.2945e-01, 9.8568e-02],\n",
      "        [4.9758e-02, 3.7725e-02],\n",
      "        [4.9868e-01, 5.9384e-01],\n",
      "        [1.1659e-02, 1.4185e-04]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15062629]\n",
      "Time: 2.042525780154392\n",
      "Iteration: 15\n",
      "new candidats: tensor([[0.6685, 0.0932],\n",
      "        [0.4398, 0.7580],\n",
      "        [0.8834, 0.8645],\n",
      "        [0.7217, 0.0152],\n",
      "        [0.0314, 0.1039]], dtype=torch.float64)\n",
      "new obj: tensor([[1.9470e-01, 5.8808e-03],\n",
      "        [4.9868e-01, 5.9384e-01],\n",
      "        [1.2198e-04, 5.2966e-06],\n",
      "        [1.0434e-01, 7.7970e-03],\n",
      "        [3.1222e-01, 4.3726e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15062629]\n",
      "Time: 2.3548151950817555\n",
      "Iteration: 16\n",
      "new candidats: tensor([[0.1316, 0.6939],\n",
      "        [0.5578, 0.1808],\n",
      "        [0.4398, 0.7580],\n",
      "        [0.2391, 0.6100],\n",
      "        [0.7939, 0.3369]], dtype=torch.float64)\n",
      "new obj: tensor([[2.3141e-02, 3.3469e-02],\n",
      "        [1.3704e-01, 2.5416e-02],\n",
      "        [4.9868e-01, 5.9384e-01],\n",
      "        [7.5500e-02, 7.4331e-02],\n",
      "        [2.7851e-01, 5.7095e-04]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15062629]\n",
      "Time: 2.7984242271631956\n",
      "Iteration: 1\n",
      "new candidats: tensor([[0.0205, 0.1695],\n",
      "        [0.0324, 0.2752],\n",
      "        [0.1492, 0.1768],\n",
      "        [0.0302, 0.0135],\n",
      "        [0.1864, 0.4233]], dtype=torch.float64)\n",
      "new obj: tensor([[0.3304, 0.4793],\n",
      "        [0.3280, 0.4577],\n",
      "        [0.4809, 0.4592],\n",
      "        [0.2257, 0.3173],\n",
      "        [0.2676, 0.2264]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.06497429]\n",
      "Time: 10.645110233919695\n",
      "Iteration: 2\n",
      "new candidats: tensor([[0.5167, 0.8219],\n",
      "        [0.2046, 0.1989],\n",
      "        [0.6337, 0.8661],\n",
      "        [0.1835, 0.8224],\n",
      "        [0.1280, 0.1940]], dtype=torch.float64)\n",
      "new obj: tensor([[0.3296, 0.3464],\n",
      "        [0.4999, 0.3987],\n",
      "        [0.0723, 0.0367],\n",
      "        [0.0061, 0.0688],\n",
      "        [0.4684, 0.4792]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.06971993]\n",
      "Time: 5.513723663985729\n",
      "Iteration: 3\n",
      "new candidats: tensor([[0.0772, 0.1928],\n",
      "        [0.1824, 0.6183],\n",
      "        [0.4320, 0.7311],\n",
      "        [0.1765, 0.7970],\n",
      "        [0.4751, 0.6524]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4139, 0.4993],\n",
      "        [0.0591, 0.0605],\n",
      "        [0.5367, 0.5275],\n",
      "        [0.0081, 0.0627],\n",
      "        [0.6210, 0.1826]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.09283022]\n",
      "Time: 13.094975357875228\n",
      "Iteration: 4\n",
      "new candidats: tensor([[0.0871, 0.1316],\n",
      "        [0.0676, 0.9227],\n",
      "        [0.4670, 0.6990],\n",
      "        [0.4078, 0.7649],\n",
      "        [0.5485, 0.1163]], dtype=torch.float64)\n",
      "new obj: tensor([[4.0210e-01, 4.6990e-01],\n",
      "        [5.9211e-04, 2.0464e-03],\n",
      "        [6.7207e-01, 3.3894e-01],\n",
      "        [3.7604e-01, 6.5840e-01],\n",
      "        [1.2123e-01, 2.6168e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.12739288]\n",
      "Time: 8.653732397127897\n",
      "Iteration: 5\n",
      "new candidats: tensor([[0.4652, 0.7421],\n",
      "        [0.0412, 0.9057],\n",
      "        [0.1426, 0.8195],\n",
      "        [0.4139, 0.7751],\n",
      "        [0.4239, 0.7444]], dtype=torch.float64)\n",
      "new obj: tensor([[0.6082, 0.4806],\n",
      "        [0.0007, 0.0016],\n",
      "        [0.0045, 0.0289],\n",
      "        [0.3692, 0.6738],\n",
      "        [0.4815, 0.5854]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14570051]\n",
      "Time: 3.803874443983659\n",
      "Iteration: 6\n",
      "new candidats: tensor([[0.8453, 0.2830],\n",
      "        [0.7292, 0.0292],\n",
      "        [0.1109, 0.8431],\n",
      "        [0.4652, 0.7421],\n",
      "        [0.6523, 0.0621]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4502, 0.0011],\n",
      "        [0.1372, 0.0154],\n",
      "        [0.0027, 0.0126],\n",
      "        [0.6082, 0.4806],\n",
      "        [0.1215, 0.0059]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14570051]\n",
      "Time: 2.0338685938622802\n",
      "Iteration: 7\n",
      "new candidats: tensor([[0.9940, 0.2346],\n",
      "        [0.5136, 0.1754],\n",
      "        [0.9954, 0.1026],\n",
      "        [0.1832, 0.7501],\n",
      "        [0.1419, 0.6061]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1005, 0.0003],\n",
      "        [0.1563, 0.0424],\n",
      "        [0.0648, 0.0102],\n",
      "        [0.0154, 0.0686],\n",
      "        [0.0618, 0.0635]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14570051]\n",
      "Time: 8.011706257006153\n",
      "Iteration: 8\n",
      "new candidats: tensor([[0.7533, 0.7132],\n",
      "        [0.5250, 0.2267],\n",
      "        [0.4652, 0.7421],\n",
      "        [0.3323, 0.4833],\n",
      "        [0.8138, 0.8448]], dtype=torch.float64)\n",
      "new obj: tensor([[2.8462e-02, 9.8975e-04],\n",
      "        [1.4775e-01, 3.7256e-02],\n",
      "        [6.0816e-01, 4.8058e-01],\n",
      "        [1.6374e-01, 8.1300e-02],\n",
      "        [1.8120e-03, 1.2409e-04]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14570051]\n",
      "Time: 1.9925449308939278\n",
      "Iteration: 9\n",
      "new candidats: tensor([[0.4670, 0.6990],\n",
      "        [0.3147, 0.9590],\n",
      "        [0.4652, 0.7421],\n",
      "        [0.4174, 0.7784],\n",
      "        [0.6547, 0.4649]], dtype=torch.float64)\n",
      "new obj: tensor([[0.6721, 0.3389],\n",
      "        [0.0047, 0.1376],\n",
      "        [0.6082, 0.4806],\n",
      "        [0.3703, 0.6752],\n",
      "        [0.0363, 0.0030]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14590938]\n",
      "Time: 3.414261753903702\n",
      "Iteration: 10\n",
      "new candidats: tensor([[0.4174, 0.7784],\n",
      "        [0.8416, 0.4677],\n",
      "        [0.4382, 0.7679],\n",
      "        [0.4469, 0.8290],\n",
      "        [0.6107, 0.4972]], dtype=torch.float64)\n",
      "new obj: tensor([[3.7030e-01, 6.7525e-01],\n",
      "        [1.9159e-02, 1.1988e-04],\n",
      "        [4.6349e-01, 6.1981e-01],\n",
      "        [2.6630e-01, 6.0208e-01],\n",
      "        [7.0084e-02, 5.0667e-03]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14892142]\n",
      "Time: 2.811000219080597\n",
      "Iteration: 11\n",
      "new candidats: tensor([[0.5566, 0.5493],\n",
      "        [0.7219, 0.8728],\n",
      "        [0.4652, 0.7421],\n",
      "        [0.7045, 0.0436],\n",
      "        [0.4469, 0.8290]], dtype=torch.float64)\n",
      "new obj: tensor([[0.2139, 0.0145],\n",
      "        [0.0135, 0.0030],\n",
      "        [0.6082, 0.4806],\n",
      "        [0.1459, 0.0078],\n",
      "        [0.2663, 0.6021]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14892142]\n",
      "Time: 1.9422287750057876\n",
      "Iteration: 12\n",
      "new candidats: tensor([[0.4652, 0.7421],\n",
      "        [0.5185, 0.2891],\n",
      "        [0.4163, 0.7221],\n",
      "        [0.4174, 0.7784],\n",
      "        [0.4891, 0.2725]], dtype=torch.float64)\n",
      "new obj: tensor([[0.6082, 0.4806],\n",
      "        [0.1365, 0.0366],\n",
      "        [0.4906, 0.5136],\n",
      "        [0.3703, 0.6752],\n",
      "        [0.1691, 0.0521]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14892142]\n",
      "Time: 2.0951267771888524\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration: 13\n",
      "new candidats: tensor([[0.4652, 0.7421],\n",
      "        [0.5024, 0.4597],\n",
      "        [0.8674, 0.1388],\n",
      "        [0.4795, 0.5122],\n",
      "        [0.7805, 0.5811]], dtype=torch.float64)\n",
      "new obj: tensor([[6.0816e-01, 4.8058e-01],\n",
      "        [1.0787e-01, 2.2055e-02],\n",
      "        [4.6430e-01, 4.8813e-01],\n",
      "        [1.7327e-01, 2.6301e-02],\n",
      "        [8.4508e-03, 1.9394e-04]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14892142]\n",
      "Time: 3.3619741569273174\n",
      "Iteration: 14\n",
      "new candidats: tensor([[0.4894, 0.7230],\n",
      "        [0.2911, 0.1105],\n",
      "        [0.3506, 0.1331],\n",
      "        [0.2679, 0.0027],\n",
      "        [0.7498, 0.0204]], dtype=torch.float64)\n",
      "new obj: tensor([[0.6837, 0.3507],\n",
      "        [0.4077, 0.2454],\n",
      "        [0.3561, 0.1767],\n",
      "        [0.2901, 0.1884],\n",
      "        [0.1305, 0.0274]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15117819]\n",
      "Time: 8.506256360094994\n",
      "Iteration: 15\n",
      "new candidats: tensor([[0.4652, 0.7421],\n",
      "        [0.5808, 0.1324],\n",
      "        [0.2618, 0.9397],\n",
      "        [0.6829, 0.2954],\n",
      "        [0.9394, 0.9221]], dtype=torch.float64)\n",
      "new obj: tensor([[6.0816e-01, 4.8058e-01],\n",
      "        [1.2751e-01, 1.8100e-02],\n",
      "        [2.8261e-03, 1.0178e-01],\n",
      "        [2.4803e-01, 4.0774e-03],\n",
      "        [4.6102e-06, 2.1790e-07]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15117819]\n",
      "Time: 2.3122975109145045\n",
      "Iteration: 16\n",
      "new candidats: tensor([[0.1419, 0.6061],\n",
      "        [0.7870, 0.5501],\n",
      "        [0.4652, 0.7421],\n",
      "        [0.1006, 0.1896],\n",
      "        [0.2226, 0.3899]], dtype=torch.float64)\n",
      "new obj: tensor([[6.1757e-02, 6.3485e-02],\n",
      "        [6.6719e-03, 1.9212e-04],\n",
      "        [6.0816e-01, 4.8058e-01],\n",
      "        [4.4129e-01, 4.9353e-01],\n",
      "        [3.1663e-01, 2.3813e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15117819]\n",
      "Time: 2.206546108936891\n",
      "Iteration: 1\n",
      "new candidats: tensor([[0.9134, 0.9371],\n",
      "        [0.1850, 0.2784],\n",
      "        [0.1297, 0.3102],\n",
      "        [0.0709, 0.1882],\n",
      "        [0.2985, 0.0063]], dtype=torch.float64)\n",
      "new obj: tensor([[9.1746e-06, 5.9534e-07],\n",
      "        [4.6169e-01, 3.9238e-01],\n",
      "        [4.0382e-01, 4.1088e-01],\n",
      "        [4.0524e-01, 4.9912e-01],\n",
      "        [2.7709e-01, 1.6288e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.05733219]\n",
      "Time: 11.953880358021706\n",
      "Iteration: 2\n",
      "new candidats: tensor([[0.2985, 0.0063],\n",
      "        [0.0319, 0.1112],\n",
      "        [0.2736, 0.7748],\n",
      "        [0.2314, 0.2767],\n",
      "        [0.1681, 0.1708]], dtype=torch.float64)\n",
      "new obj: tensor([[0.2771, 0.1629],\n",
      "        [0.3182, 0.4449],\n",
      "        [0.0483, 0.3097],\n",
      "        [0.4589, 0.3355],\n",
      "        [0.4885, 0.4386]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.06576547]\n",
      "Time: 10.628763939021155\n",
      "Iteration: 3\n",
      "new candidats: tensor([[0.0412, 0.2363],\n",
      "        [0.2059, 0.2061],\n",
      "        [0.1086, 0.8415],\n",
      "        [0.1212, 0.1856],\n",
      "        [0.6795, 0.8074]], dtype=torch.float64)\n",
      "new obj: tensor([[0.3589, 0.4868],\n",
      "        [0.4995, 0.3967],\n",
      "        [0.0027, 0.0121],\n",
      "        [0.4615, 0.4826],\n",
      "        [0.0787, 0.0141]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07018687]\n",
      "Time: 5.793813042109832\n",
      "Iteration: 4\n",
      "new candidats: tensor([[0.2985, 0.0063],\n",
      "        [0.2842, 0.9344],\n",
      "        [0.1512, 0.2139],\n",
      "        [0.2059, 0.2061],\n",
      "        [0.4192, 0.4253]], dtype=torch.float64)\n",
      "new obj: tensor([[0.2771, 0.1629],\n",
      "        [0.0049, 0.1454],\n",
      "        [0.4841, 0.4593],\n",
      "        [0.4995, 0.3967],\n",
      "        [0.1571, 0.0584]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07065594]\n",
      "Time: 3.005074138054624\n",
      "Iteration: 5\n",
      "new candidats: tensor([[0.1092, 0.6278],\n",
      "        [0.2063, 0.1860],\n",
      "        [0.1681, 0.1708],\n",
      "        [0.2059, 0.2061],\n",
      "        [0.8828, 0.8360]], dtype=torch.float64)\n",
      "new obj: tensor([[4.6048e-02, 5.2109e-02],\n",
      "        [4.9854e-01, 3.9547e-01],\n",
      "        [4.8845e-01, 4.3864e-01],\n",
      "        [4.9954e-01, 3.9671e-01],\n",
      "        [1.9219e-04, 6.5241e-06]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07065594]\n",
      "Time: 3.382021804107353\n",
      "Iteration: 6\n",
      "new candidats: tensor([[0.7272, 0.5853],\n",
      "        [0.0923, 0.1967],\n",
      "        [0.5015, 0.1218],\n",
      "        [0.3586, 0.5166],\n",
      "        [0.9462, 0.8610]], dtype=torch.float64)\n",
      "new obj: tensor([[3.0178e-02, 6.8364e-04],\n",
      "        [4.3251e-01, 4.9682e-01],\n",
      "        [1.5468e-01, 4.5178e-02],\n",
      "        [1.5223e-01, 6.1999e-02],\n",
      "        [1.1113e-05, 3.3751e-07]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07104368]\n",
      "Time: 3.073475093115121\n",
      "Iteration: 7\n",
      "new candidats: tensor([[0.5705, 0.3244],\n",
      "        [0.4824, 0.6717],\n",
      "        [0.0848, 0.9211],\n",
      "        [0.2314, 0.2767],\n",
      "        [0.2059, 0.2061]], dtype=torch.float64)\n",
      "new obj: tensor([[9.7749e-02, 1.7990e-02],\n",
      "        [6.7367e-01, 2.2252e-01],\n",
      "        [6.4787e-04, 3.0874e-03],\n",
      "        [4.5889e-01, 3.3550e-01],\n",
      "        [4.9954e-01, 3.9671e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07129175]\n",
      "Time: 3.2541278740391135\n",
      "Iteration: 8\n",
      "new candidats: tensor([[0.1678, 0.7584],\n",
      "        [0.4369, 0.7790],\n",
      "        [0.4688, 0.7271],\n",
      "        [0.4670, 0.7780],\n",
      "        [0.7447, 0.1664]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0124, 0.0524],\n",
      "        [0.4236, 0.6411],\n",
      "        [0.6490, 0.4256],\n",
      "        [0.4920, 0.5472],\n",
      "        [0.5798, 0.0332]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13417459]\n",
      "Time: 13.692415565019473\n",
      "Iteration: 9\n",
      "new candidats: tensor([[0.3806, 0.3469],\n",
      "        [0.4399, 0.7384],\n",
      "        [0.7935, 0.2557],\n",
      "        [0.1652, 0.5263],\n",
      "        [0.7161, 0.6192]], dtype=torch.float64)\n",
      "new obj: tensor([[0.2547, 0.1144],\n",
      "        [0.5493, 0.5372],\n",
      "        [0.6041, 0.0036],\n",
      "        [0.1307, 0.1190],\n",
      "        [0.0509, 0.0012]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.1405717]\n",
      "Time: 4.271453971043229\n",
      "Iteration: 10\n",
      "new candidats: tensor([[0.6113, 0.6178],\n",
      "        [0.2059, 0.2061],\n",
      "        [0.0978, 0.2837],\n",
      "        [0.0155, 0.1599],\n",
      "        [0.4272, 0.7910]], dtype=torch.float64)\n",
      "new obj: tensor([[0.2757, 0.0157],\n",
      "        [0.4995, 0.3967],\n",
      "        [0.4020, 0.4537],\n",
      "        [0.3203, 0.4722],\n",
      "        [0.3583, 0.6731]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14455489]\n",
      "Time: 2.096652468200773\n",
      "Iteration: 11\n",
      "new candidats: tensor([[0.1735, 0.2994],\n",
      "        [0.4769, 0.7151],\n",
      "        [0.4777, 0.7194],\n",
      "        [0.7293, 0.8094],\n",
      "        [0.7846, 0.2419]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4380, 0.3865],\n",
      "        [0.6808, 0.3656],\n",
      "        [0.6766, 0.3762],\n",
      "        [0.0279, 0.0031],\n",
      "        [0.6406, 0.0061]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14939795]\n",
      "Time: 3.905478669097647\n",
      "Iteration: 12\n",
      "new candidats: tensor([[0.0251, 0.9356],\n",
      "        [0.3468, 0.4587],\n",
      "        [0.4351, 0.7604],\n",
      "        [0.8641, 0.7772],\n",
      "        [0.4754, 0.0617]], dtype=torch.float64)\n",
      "new obj: tensor([[3.9476e-04, 8.1143e-04],\n",
      "        [1.7728e-01, 8.4957e-02],\n",
      "        [4.7731e-01, 6.1053e-01],\n",
      "        [7.1897e-04, 1.7294e-05],\n",
      "        [1.5390e-01, 5.0445e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15280374]\n",
      "Time: 3.6178369021508843\n",
      "Iteration: 13\n",
      "new candidats: tensor([[0.0187, 1.0000],\n",
      "        [0.6824, 0.1308],\n",
      "        [0.7067, 0.6853],\n",
      "        [0.6277, 0.7293],\n",
      "        [0.4688, 0.7271]], dtype=torch.float64)\n",
      "new obj: tensor([[1.1142e-04, 2.2863e-04],\n",
      "        [3.0167e-01, 6.4384e-03],\n",
      "        [8.2837e-02, 3.4510e-03],\n",
      "        [2.9838e-01, 4.1169e-02],\n",
      "        [6.4902e-01, 4.2565e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15280374]\n",
      "Time: 2.0977071640081704\n",
      "Iteration: 14\n",
      "new candidats: tensor([[0.3759, 0.2806],\n",
      "        [0.4688, 0.7271],\n",
      "        [0.4272, 0.7910],\n",
      "        [0.1318, 0.8777],\n",
      "        [0.3911, 0.7756]], dtype=torch.float64)\n",
      "new obj: tensor([[0.3132, 0.1431],\n",
      "        [0.6490, 0.4256],\n",
      "        [0.3583, 0.6731],\n",
      "        [0.0017, 0.0157],\n",
      "        [0.2957, 0.6790]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.1531671]\n",
      "Time: 3.30414682906121\n",
      "Iteration: 15\n",
      "new candidats: tensor([[0.6239, 0.1601],\n",
      "        [0.9248, 0.4153],\n",
      "        [0.0450, 0.0918],\n",
      "        [0.4192, 0.4253],\n",
      "        [0.4688, 0.7271]], dtype=torch.float64)\n",
      "new obj: tensor([[1.8897e-01, 1.0599e-02],\n",
      "        [3.2029e-02, 3.0265e-05],\n",
      "        [3.1992e-01, 4.2858e-01],\n",
      "        [1.5705e-01, 5.8350e-02],\n",
      "        [6.4902e-01, 4.2565e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.1531671]\n",
      "Time: 2.57707796106115\n",
      "Iteration: 16\n",
      "new candidats: tensor([[0.8102, 0.0948],\n",
      "        [0.2685, 0.9733],\n",
      "        [0.5676, 0.7468],\n",
      "        [0.3767, 0.6626],\n",
      "        [0.4688, 0.7271]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4044, 0.5080],\n",
      "        [0.0014, 0.0659],\n",
      "        [0.5014, 0.1497],\n",
      "        [0.3286, 0.2756],\n",
      "        [0.6490, 0.4256]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.1531671]\n",
      "Time: 2.495299420086667\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration: 1\n",
      "new candidats: tensor([[0.4821, 0.8173],\n",
      "        [0.4480, 0.7684],\n",
      "        [0.5411, 0.7934],\n",
      "        [0.5536, 0.7100],\n",
      "        [0.3791, 0.3697]], dtype=torch.float64)\n",
      "new obj: tensor([[0.3479, 0.4927],\n",
      "        [0.4881, 0.5948],\n",
      "        [0.4174, 0.2587],\n",
      "        [0.6073, 0.1446],\n",
      "        [0.2351, 0.1057]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.1089374]\n",
      "Time: 17.814757102169096\n",
      "Iteration: 2\n",
      "new candidats: tensor([[0.4362, 0.7890],\n",
      "        [0.4584, 0.7110],\n",
      "        [0.0131, 0.9038],\n",
      "        [0.0917, 0.1627],\n",
      "        [0.9599, 0.1548]], dtype=torch.float64)\n",
      "new obj: tensor([[0.3874, 0.6530],\n",
      "        [0.6465, 0.4000],\n",
      "        [0.0007, 0.0012],\n",
      "        [0.4244, 0.4885],\n",
      "        [0.1765, 0.0344]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.1323098]\n",
      "Time: 4.379899309016764\n",
      "Iteration: 3\n",
      "new candidats: tensor([[0.0011, 0.5595],\n",
      "        [0.6612, 0.0891],\n",
      "        [0.4683, 0.1491],\n",
      "        [0.7710, 0.2909],\n",
      "        [0.4425, 0.7304]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0606, 0.0937],\n",
      "        [0.1745, 0.0060],\n",
      "        [0.1993, 0.0666],\n",
      "        [0.4515, 0.0011],\n",
      "        [0.5736, 0.5046]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14125409]\n",
      "Time: 6.5336617971770465\n",
      "Iteration: 4\n",
      "new candidats: tensor([[0.0047, 0.6997],\n",
      "        [0.8729, 0.3629],\n",
      "        [0.3791, 0.3697],\n",
      "        [0.0202, 0.1969],\n",
      "        [0.4693, 0.7060]], dtype=torch.float64)\n",
      "new obj: tensor([[1.3684e-02, 2.1068e-02],\n",
      "        [1.4358e-01, 1.1418e-04],\n",
      "        [2.3505e-01, 1.0571e-01],\n",
      "        [3.3381e-01, 4.8470e-01],\n",
      "        [6.7481e-01, 3.5681e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14509624]\n",
      "Time: 10.978106934111565\n",
      "Iteration: 5\n",
      "new candidats: tensor([[0.8514, 0.9414],\n",
      "        [0.2149, 0.8133],\n",
      "        [0.4693, 0.7060],\n",
      "        [0.0917, 0.1627],\n",
      "        [0.1994, 0.0177]], dtype=torch.float64)\n",
      "new obj: tensor([[8.1547e-05, 9.9204e-06],\n",
      "        [1.0863e-02, 1.2868e-01],\n",
      "        [6.7481e-01, 3.5681e-01],\n",
      "        [4.2438e-01, 4.8849e-01],\n",
      "        [3.3001e-01, 2.6766e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14509624]\n",
      "Time: 9.58404755499214\n",
      "Iteration: 6\n",
      "new candidats: tensor([[0.5068, 0.9324],\n",
      "        [0.4425, 0.7304],\n",
      "        [0.4362, 0.7890],\n",
      "        [0.8163, 0.7688],\n",
      "        [0.1587, 0.6699]], dtype=torch.float64)\n",
      "new obj: tensor([[4.7130e-02, 1.6489e-01],\n",
      "        [5.7358e-01, 5.0464e-01],\n",
      "        [3.8743e-01, 6.5296e-01],\n",
      "        [3.7852e-03, 1.2305e-04],\n",
      "        [3.2961e-02, 4.5024e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14509624]\n",
      "Time: 8.142141306074336\n",
      "Iteration: 7\n",
      "new candidats: tensor([[0.9386, 0.3370],\n",
      "        [0.0582, 0.1410],\n",
      "        [0.4362, 0.7890],\n",
      "        [0.9789, 0.4201],\n",
      "        [0.9865, 0.5330]], dtype=torch.float64)\n",
      "new obj: tensor([[1.0527e-01, 3.3657e-05],\n",
      "        [3.7234e-01, 4.7787e-01],\n",
      "        [3.8743e-01, 6.5296e-01],\n",
      "        [1.2677e-02, 8.9395e-06],\n",
      "        [5.3678e-04, 3.4426e-06]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14509624]\n",
      "Time: 5.153615494025871\n",
      "Iteration: 8\n",
      "new candidats: tensor([[0.4693, 0.7060],\n",
      "        [0.1207, 0.2472],\n",
      "        [0.4277, 0.2428],\n",
      "        [0.9924, 0.3100],\n",
      "        [0.4480, 0.7684]], dtype=torch.float64)\n",
      "new obj: tensor([[6.7481e-01, 3.5681e-01],\n",
      "        [4.4952e-01, 4.7086e-01],\n",
      "        [2.5630e-01, 9.8761e-02],\n",
      "        [6.0255e-02, 1.2141e-05],\n",
      "        [4.8808e-01, 5.9484e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14509624]\n",
      "Time: 7.618629225995392\n",
      "Iteration: 9\n",
      "new candidats: tensor([[0.6987, 0.0395],\n",
      "        [0.4362, 0.7890],\n",
      "        [0.4480, 0.7684],\n",
      "        [0.9679, 0.4609],\n",
      "        [0.7779, 0.1174]], dtype=torch.float64)\n",
      "new obj: tensor([[1.3177e-01, 6.0518e-03],\n",
      "        [3.8743e-01, 6.5296e-01],\n",
      "        [4.8808e-01, 5.9484e-01],\n",
      "        [5.8199e-03, 8.9636e-06],\n",
      "        [4.9262e-01, 2.3385e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14509624]\n",
      "Time: 5.396792310057208\n",
      "Iteration: 10\n",
      "new candidats: tensor([[0.3874, 0.2880],\n",
      "        [0.4425, 0.7304],\n",
      "        [0.4362, 0.7890],\n",
      "        [0.4480, 0.7684],\n",
      "        [0.3989, 0.0358]], dtype=torch.float64)\n",
      "new obj: tensor([[0.2928, 0.1288],\n",
      "        [0.5736, 0.5046],\n",
      "        [0.3874, 0.6530],\n",
      "        [0.4881, 0.5948],\n",
      "        [0.2178, 0.0924]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14509624]\n",
      "Time: 7.367521323962137\n",
      "Iteration: 11\n",
      "new candidats: tensor([[0.7618, 0.7425],\n",
      "        [0.7216, 0.3475],\n",
      "        [0.4693, 0.7060],\n",
      "        [0.4425, 0.7304],\n",
      "        [0.6917, 0.3244]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0210, 0.0009],\n",
      "        [0.1861, 0.0019],\n",
      "        [0.6748, 0.3568],\n",
      "        [0.5736, 0.5046],\n",
      "        [0.1999, 0.0033]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14509624]\n",
      "Time: 8.050736632896587\n",
      "Iteration: 12\n",
      "new candidats: tensor([[0.7874, 0.0350],\n",
      "        [0.4480, 0.7684],\n",
      "        [0.6838, 0.3678],\n",
      "        [0.7167, 0.9404],\n",
      "        [0.4425, 0.7304]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1829, 0.1381],\n",
      "        [0.4881, 0.5948],\n",
      "        [0.1066, 0.0032],\n",
      "        [0.0037, 0.0017],\n",
      "        [0.5736, 0.5046]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14509624]\n",
      "Time: 6.702794859884307\n",
      "Iteration: 13\n",
      "new candidats: tensor([[0.3899, 0.7941],\n",
      "        [0.1350, 0.2975],\n",
      "        [0.3794, 0.8931],\n",
      "        [0.4362, 0.7890],\n",
      "        [0.0156, 0.4475]], dtype=torch.float64)\n",
      "new obj: tensor([[0.2491, 0.6969],\n",
      "        [0.4211, 0.4211],\n",
      "        [0.0532, 0.4446],\n",
      "        [0.3874, 0.6530],\n",
      "        [0.1520, 0.2241]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14576965]\n",
      "Time: 3.7440200401470065\n",
      "Iteration: 14\n",
      "new candidats: tensor([[0.2773, 0.9471],\n",
      "        [0.4693, 0.7060],\n",
      "        [0.4389, 0.7476],\n",
      "        [0.2971, 0.8886],\n",
      "        [0.7592, 0.7035]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0032, 0.1121],\n",
      "        [0.6748, 0.3568],\n",
      "        [0.5246, 0.5677],\n",
      "        [0.0163, 0.2789],\n",
      "        [0.0247, 0.0007]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14807168]\n",
      "Time: 2.1808182259555906\n",
      "Iteration: 15\n",
      "new candidats: tensor([[0.7035, 0.2132],\n",
      "        [0.4362, 0.7890],\n",
      "        [0.3636, 0.6156],\n",
      "        [0.2790, 0.4796],\n",
      "        [0.3685, 0.6892]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4565, 0.0040],\n",
      "        [0.3874, 0.6530],\n",
      "        [0.2347, 0.1393],\n",
      "        [0.1794, 0.1110],\n",
      "        [0.3109, 0.3689]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14807168]\n",
      "Time: 3.616294138133526\n",
      "Iteration: 16\n",
      "new candidats: tensor([[0.8868, 0.4848],\n",
      "        [0.6959, 0.0482],\n",
      "        [0.1167, 0.9851],\n",
      "        [0.6202, 0.1132],\n",
      "        [0.4362, 0.7890]], dtype=torch.float64)\n",
      "new obj: tensor([[8.8622e-03, 4.3407e-05],\n",
      "        [1.4592e-01, 6.3435e-03],\n",
      "        [2.1422e-04, 2.5004e-03],\n",
      "        [1.4548e-01, 1.0359e-02],\n",
      "        [3.8743e-01, 6.5296e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14807168]\n",
      "Time: 2.505856579169631\n",
      "Iteration: 1\n",
      "new candidats: tensor([[0.4653, 0.7482],\n",
      "        [0.4673, 0.8597],\n",
      "        [0.4138, 0.8776],\n",
      "        [0.5449, 0.9128],\n",
      "        [0.1570, 0.9522]], dtype=torch.float64)\n",
      "new obj: tensor([[5.9158e-01, 4.9636e-01],\n",
      "        [1.8631e-01, 4.6740e-01],\n",
      "        [1.0062e-01, 5.1338e-01],\n",
      "        [6.6003e-02, 1.2974e-01],\n",
      "        [4.9579e-04, 1.1872e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.12079829]\n",
      "Time: 9.780712726991624\n",
      "Iteration: 2\n",
      "new candidats: tensor([[1.1273e-01, 2.2705e-01],\n",
      "        [3.8101e-01, 7.7395e-01],\n",
      "        [7.4103e-04, 1.9620e-01],\n",
      "        [7.7279e-02, 2.9734e-01],\n",
      "        [7.1268e-01, 9.2932e-02]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4505, 0.4843],\n",
      "        [0.2678, 0.6670],\n",
      "        [0.3043, 0.4708],\n",
      "        [0.3679, 0.4439],\n",
      "        [0.2857, 0.0184]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.12324225]\n",
      "Time: 9.380220880964771\n",
      "Iteration: 3\n",
      "new candidats: tensor([[0.9365, 0.1123],\n",
      "        [0.0094, 0.9311],\n",
      "        [0.7127, 0.0929],\n",
      "        [0.9338, 0.0361],\n",
      "        [0.4802, 0.7247]], dtype=torch.float64)\n",
      "new obj: tensor([[1.8829e-01, 1.5230e-01],\n",
      "        [3.9834e-04, 7.4277e-04],\n",
      "        [2.8573e-01, 1.8430e-02],\n",
      "        [7.5029e-02, 7.5869e-02],\n",
      "        [6.7188e-01, 3.8397e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13632176]\n",
      "Time: 6.849091473035514\n",
      "Iteration: 4\n",
      "new candidats: tensor([[0.4478, 0.7375],\n",
      "        [0.4186, 0.7747],\n",
      "        [0.4606, 0.1641],\n",
      "        [0.1363, 0.6489],\n",
      "        [0.6207, 0.3514]], dtype=torch.float64)\n",
      "new obj: tensor([[0.5757, 0.5159],\n",
      "        [0.3847, 0.6681],\n",
      "        [0.2126, 0.0731],\n",
      "        [0.0391, 0.0450],\n",
      "        [0.0865, 0.0085]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14715553]\n",
      "Time: 11.695577141130343\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration: 5\n",
      "new candidats: tensor([[0.5341, 0.0248],\n",
      "        [0.5046, 0.7238],\n",
      "        [0.3877, 0.2793],\n",
      "        [0.4186, 0.7747],\n",
      "        [0.2291, 0.2186]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0888, 0.0231],\n",
      "        [0.6848, 0.3046],\n",
      "        [0.2978, 0.1309],\n",
      "        [0.3847, 0.6681],\n",
      "        [0.4926, 0.3628]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14823748]\n",
      "Time: 11.975245720008388\n",
      "Iteration: 6\n",
      "new candidats: tensor([[0.8054, 0.5389],\n",
      "        [0.4450, 0.5868],\n",
      "        [0.4367, 0.7788],\n",
      "        [0.4707, 0.7254],\n",
      "        [0.0476, 0.5863]], dtype=torch.float64)\n",
      "new obj: tensor([[5.2644e-03, 1.4416e-04],\n",
      "        [3.5359e-01, 7.8531e-02],\n",
      "        [4.2371e-01, 6.4137e-01],\n",
      "        [6.5563e-01, 4.1492e-01],\n",
      "        [5.7904e-02, 7.7058e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15202747]\n",
      "Time: 8.598106904886663\n",
      "Iteration: 7\n",
      "new candidats: tensor([[0.4478, 0.7375],\n",
      "        [0.3119, 0.0378],\n",
      "        [0.2525, 0.6845],\n",
      "        [0.0603, 0.5115],\n",
      "        [0.0094, 0.9311]], dtype=torch.float64)\n",
      "new obj: tensor([[5.7567e-01, 5.1587e-01],\n",
      "        [3.0774e-01, 1.7315e-01],\n",
      "        [5.8039e-02, 1.3856e-01],\n",
      "        [1.1646e-01, 1.4848e-01],\n",
      "        [3.9834e-04, 7.4277e-04]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15202747]\n",
      "Time: 5.937485221074894\n",
      "Iteration: 8\n",
      "new candidats: tensor([[0.5863, 0.9589],\n",
      "        [0.4714, 0.3799],\n",
      "        [0.9557, 0.8104],\n",
      "        [0.4478, 0.7375],\n",
      "        [0.8178, 0.8540]], dtype=torch.float64)\n",
      "new obj: tensor([[1.6969e-02, 3.4932e-02],\n",
      "        [1.3754e-01, 4.4628e-02],\n",
      "        [1.5551e-05, 3.9884e-07],\n",
      "        [5.7567e-01, 5.1587e-01],\n",
      "        [1.3919e-03, 1.0024e-04]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15202747]\n",
      "Time: 6.188453259179369\n",
      "Iteration: 9\n",
      "new candidats: tensor([[0.4186, 0.7747],\n",
      "        [0.0751, 0.7612],\n",
      "        [0.0250, 0.0100],\n",
      "        [0.4478, 0.7375],\n",
      "        [0.1646, 0.8736]], dtype=torch.float64)\n",
      "new obj: tensor([[0.3847, 0.6681],\n",
      "        [0.0081, 0.0131],\n",
      "        [0.2171, 0.3104],\n",
      "        [0.5757, 0.5159],\n",
      "        [0.0023, 0.0349]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15202747]\n",
      "Time: 9.414749060990289\n",
      "Iteration: 10\n",
      "new candidats: tensor([[0.4478, 0.7375],\n",
      "        [0.5501, 0.7323],\n",
      "        [0.2388, 0.4778],\n",
      "        [0.0365, 0.0646],\n",
      "        [0.3519, 0.8526]], dtype=torch.float64)\n",
      "new obj: tensor([[0.5757, 0.5159],\n",
      "        [0.5892, 0.1814],\n",
      "        [0.1890, 0.1345],\n",
      "        [0.2847, 0.3921],\n",
      "        [0.0748, 0.5440]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15202747]\n",
      "Time: 9.401778383878991\n",
      "Iteration: 11\n",
      "new candidats: tensor([[0.1575, 0.0961],\n",
      "        [0.4621, 0.9037],\n",
      "        [0.7421, 0.7503],\n",
      "        [0.4478, 0.7375],\n",
      "        [0.5238, 0.7892]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4271, 0.3970],\n",
      "        [0.0822, 0.3371],\n",
      "        [0.0332, 0.0018],\n",
      "        [0.5757, 0.5159],\n",
      "        [0.4587, 0.3240]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15202747]\n",
      "Time: 2.8419186789542437\n",
      "Iteration: 12\n",
      "new candidats: tensor([[0.7301, 0.2102],\n",
      "        [0.4478, 0.7375],\n",
      "        [0.1436, 0.9667],\n",
      "        [0.9475, 0.9244],\n",
      "        [0.1862, 0.1511]], dtype=torch.float64)\n",
      "new obj: tensor([[5.6038e-01, 5.6404e-03],\n",
      "        [5.7567e-01, 5.1587e-01],\n",
      "        [3.4458e-04, 6.8304e-03],\n",
      "        [3.1854e-06, 1.4667e-07],\n",
      "        [4.8411e-01, 4.0994e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15202747]\n",
      "Time: 3.1369758441578597\n",
      "Iteration: 13\n",
      "new candidats: tensor([[0.7476, 0.4912],\n",
      "        [0.3823, 0.6770],\n",
      "        [0.4478, 0.7375],\n",
      "        [0.4660, 0.6538],\n",
      "        [0.3463, 0.6146]], dtype=torch.float64)\n",
      "new obj: tensor([[1.6557e-02, 5.7133e-04],\n",
      "        [3.6017e-01, 3.3192e-01],\n",
      "        [5.7567e-01, 5.1587e-01],\n",
      "        [6.0954e-01, 1.9882e-01],\n",
      "        [1.9382e-01, 1.3111e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15202747]\n",
      "Time: 6.011134666157886\n",
      "Iteration: 14\n",
      "new candidats: tensor([[0.5364, 0.0041],\n",
      "        [0.6965, 0.9889],\n",
      "        [0.9832, 0.6776],\n",
      "        [0.4478, 0.7375],\n",
      "        [0.4763, 0.8485]], dtype=torch.float64)\n",
      "new obj: tensor([[7.8390e-02, 2.0402e-02],\n",
      "        [1.5738e-03, 1.4515e-03],\n",
      "        [2.0790e-05, 8.7209e-07],\n",
      "        [5.7567e-01, 5.1587e-01],\n",
      "        [2.2708e-01, 4.6574e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15202747]\n",
      "Time: 4.240832417970523\n",
      "Iteration: 15\n",
      "new candidats: tensor([[0.7355, 0.2849],\n",
      "        [0.8201, 0.5545],\n",
      "        [0.4174, 0.1682],\n",
      "        [0.5316, 0.8510],\n",
      "        [0.4478, 0.7375]], dtype=torch.float64)\n",
      "new obj: tensor([[4.0902e-01, 1.8552e-03],\n",
      "        [3.5748e-03, 9.6668e-05],\n",
      "        [2.7386e-01, 1.0919e-01],\n",
      "        [2.1356e-01, 2.5865e-01],\n",
      "        [5.7567e-01, 5.1587e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15202747]\n",
      "Time: 3.842882014112547\n",
      "Iteration: 16\n",
      "new candidats: tensor([[0.4450, 0.5868],\n",
      "        [0.0843, 0.2551],\n",
      "        [0.6463, 0.8870],\n",
      "        [0.5085, 0.2626],\n",
      "        [0.4478, 0.7375]], dtype=torch.float64)\n",
      "new obj: tensor([[0.3536, 0.0785],\n",
      "        [0.4072, 0.4802],\n",
      "        [0.0419, 0.0231],\n",
      "        [0.1531, 0.0430],\n",
      "        [0.5757, 0.5159]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15202747]\n",
      "Time: 3.0320331000257283\n",
      "Iteration: 1\n",
      "new candidats: tensor([[0.4197, 0.8439],\n",
      "        [0.2681, 0.0109],\n",
      "        [0.1916, 0.0989],\n",
      "        [0.1206, 0.0121],\n",
      "        [0.5061, 0.5105]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1816, 0.6243],\n",
      "        [0.3018, 0.1958],\n",
      "        [0.4397, 0.3658],\n",
      "        [0.2972, 0.3114],\n",
      "        [0.1625, 0.0199]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.06036194]\n",
      "Time: 15.6542574390769\n",
      "Iteration: 2\n",
      "new candidats: tensor([[0.4083, 0.7644],\n",
      "        [0.2442, 0.2106],\n",
      "        [0.9835, 0.2430],\n",
      "        [0.1393, 0.2036],\n",
      "        [0.9070, 0.9723]], dtype=torch.float64)\n",
      "new obj: tensor([[3.7897e-01, 6.5703e-01],\n",
      "        [4.8726e-01, 3.4170e-01],\n",
      "        [1.1878e-01, 3.4604e-04],\n",
      "        [4.7739e-01, 4.7083e-01],\n",
      "        [4.9091e-06, 4.6145e-07]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.09098712]\n",
      "Time: 11.5244827340357\n",
      "Iteration: 3\n",
      "new candidats: tensor([[0.6543, 0.4737],\n",
      "        [0.1150, 0.2167],\n",
      "        [0.1707, 0.2185],\n",
      "        [0.7426, 0.8506],\n",
      "        [0.0039, 0.1723]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0370, 0.0029],\n",
      "        [0.4552, 0.4858],\n",
      "        [0.4925, 0.4386],\n",
      "        [0.0119, 0.0017],\n",
      "        [0.3062, 0.4689]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.09269591]\n",
      "Time: 16.333866860019043\n",
      "Iteration: 4\n",
      "new candidats: tensor([[0.4436, 0.7504],\n",
      "        [0.1154, 0.1732],\n",
      "        [0.4102, 0.7730],\n",
      "        [0.2031, 0.1982],\n",
      "        [0.4332, 0.7338]], dtype=torch.float64)\n",
      "new obj: tensor([[0.5311, 0.5649],\n",
      "        [0.4531, 0.4829],\n",
      "        [0.3630, 0.6734],\n",
      "        [0.4999, 0.4006],\n",
      "        [0.5360, 0.5350]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.11923404]\n",
      "Time: 11.091164494864643\n",
      "Iteration: 5\n",
      "new candidats: tensor([[0.7714, 0.6479],\n",
      "        [0.4733, 0.7270],\n",
      "        [0.5874, 0.6796],\n",
      "        [0.4733, 0.7270],\n",
      "        [0.9031, 0.5036]], dtype=torch.float64)\n",
      "new obj: tensor([[1.6073e-02, 3.0913e-04],\n",
      "        [6.5734e-01, 4.1208e-01],\n",
      "        [4.7214e-01, 5.9521e-02],\n",
      "        [6.5734e-01, 4.1208e-01],\n",
      "        [4.4624e-03, 2.6989e-05]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14241692]\n",
      "Time: 16.51534395897761\n",
      "Iteration: 6\n",
      "new candidats: tensor([[0.5018, 0.9863],\n",
      "        [0.1356, 0.5565],\n",
      "        [0.4733, 0.7270],\n",
      "        [0.4102, 0.7730],\n",
      "        [0.2309, 0.8270]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0117, 0.0735],\n",
      "        [0.0973, 0.0979],\n",
      "        [0.6573, 0.4121],\n",
      "        [0.3630, 0.6734],\n",
      "        [0.0120, 0.1641]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14241692]\n",
      "Time: 11.898041123058647\n",
      "Iteration: 7\n",
      "new candidats: tensor([[0.4733, 0.7270],\n",
      "        [0.4033, 0.6416],\n",
      "        [0.1113, 0.2300],\n",
      "        [0.9878, 0.1202],\n",
      "        [0.6358, 0.8969]], dtype=torch.float64)\n",
      "new obj: tensor([[0.6573, 0.4121],\n",
      "        [0.3959, 0.2105],\n",
      "        [0.4481, 0.4840],\n",
      "        [0.0875, 0.0145],\n",
      "        [0.0402, 0.0272]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14241692]\n",
      "Time: 6.836797973141074\n",
      "Iteration: 8\n",
      "new candidats: tensor([[0.7269, 0.8024],\n",
      "        [0.8897, 0.3901],\n",
      "        [0.6118, 0.3238],\n",
      "        [0.5083, 0.1160],\n",
      "        [0.4733, 0.7270]], dtype=torch.float64)\n",
      "new obj: tensor([[3.1727e-02, 3.3645e-03],\n",
      "        [7.7700e-02, 7.1625e-05],\n",
      "        [1.0524e-01, 1.0532e-02],\n",
      "        [1.4654e-01, 4.1480e-02],\n",
      "        [6.5734e-01, 4.1208e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14241692]\n",
      "Time: 6.422175734071061\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration: 9\n",
      "new candidats: tensor([[0.9416, 0.8929],\n",
      "        [0.5917, 0.4302],\n",
      "        [0.8448, 0.4156],\n",
      "        [0.4733, 0.7270],\n",
      "        [0.1811, 0.9755]], dtype=torch.float64)\n",
      "new obj: tensor([[7.6270e-06, 2.8735e-07],\n",
      "        [5.5617e-02, 8.7083e-03],\n",
      "        [6.3587e-02, 1.5400e-04],\n",
      "        [6.5734e-01, 4.1208e-01],\n",
      "        [3.6829e-04, 1.3918e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14241692]\n",
      "Time: 2.007634388981387\n",
      "Iteration: 10\n",
      "new candidats: tensor([[0.9370, 0.3107],\n",
      "        [0.3477, 0.0949],\n",
      "        [0.4173, 0.7634],\n",
      "        [0.4102, 0.7730],\n",
      "        [0.3687, 0.4001]], dtype=torch.float64)\n",
      "new obj: tensor([[1.4890e-01, 5.7066e-05],\n",
      "        [3.3161e-01, 1.6611e-01],\n",
      "        [4.1187e-01, 6.4707e-01],\n",
      "        [3.6296e-01, 6.7344e-01],\n",
      "        [2.1570e-01, 9.9617e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14511916]\n",
      "Time: 1.796851608902216\n",
      "Iteration: 11\n",
      "new candidats: tensor([[0.2293, 0.4576],\n",
      "        [0.6677, 0.3352],\n",
      "        [0.4102, 0.7730],\n",
      "        [0.4733, 0.7270],\n",
      "        [0.9684, 0.1178]], dtype=torch.float64)\n",
      "new obj: tensor([[0.2167, 0.1593],\n",
      "        [0.1431, 0.0046],\n",
      "        [0.3630, 0.6734],\n",
      "        [0.6573, 0.4121],\n",
      "        [0.1212, 0.0398]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14511916]\n",
      "Time: 2.2756167768966407\n",
      "Iteration: 12\n",
      "new candidats: tensor([[0.8358, 0.7014],\n",
      "        [0.1602, 0.5232],\n",
      "        [0.7398, 0.4218],\n",
      "        [0.9586, 0.2323],\n",
      "        [0.4733, 0.7270]], dtype=torch.float64)\n",
      "new obj: tensor([[2.6319e-03, 4.6490e-05],\n",
      "        [1.3330e-01, 1.2325e-01],\n",
      "        [5.7860e-02, 9.9421e-04],\n",
      "        [1.8915e-01, 2.0210e-03],\n",
      "        [6.5734e-01, 4.1208e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14511916]\n",
      "Time: 2.53095181286335\n",
      "Iteration: 13\n",
      "new candidats: tensor([[0.4733, 0.7270],\n",
      "        [0.4808, 0.6981],\n",
      "        [0.4846, 0.5893],\n",
      "        [0.7532, 0.8040],\n",
      "        [0.5618, 0.5545]], dtype=torch.float64)\n",
      "new obj: tensor([[0.6573, 0.4121],\n",
      "        [0.6955, 0.3031],\n",
      "        [0.4021, 0.0619],\n",
      "        [0.0166, 0.0014],\n",
      "        [0.2208, 0.0143]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14825179]\n",
      "Time: 2.7648258151020855\n",
      "Iteration: 14\n",
      "new candidats: tensor([[0.8209, 0.1660],\n",
      "        [0.0015, 0.3881],\n",
      "        [0.5146, 0.4460],\n",
      "        [0.4733, 0.7270],\n",
      "        [0.3768, 0.2684]], dtype=torch.float64)\n",
      "new obj: tensor([[0.6505, 0.2475],\n",
      "        [0.1963, 0.3029],\n",
      "        [0.0962, 0.0205],\n",
      "        [0.6573, 0.4121],\n",
      "        [0.3192, 0.1454]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14825179]\n",
      "Time: 2.8243298118468374\n",
      "Iteration: 15\n",
      "new candidats: tensor([[0.7147, 0.7460],\n",
      "        [0.7380, 0.9102],\n",
      "        [0.6483, 0.3498],\n",
      "        [0.4733, 0.7270],\n",
      "        [0.2933, 0.3222]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0633, 0.0043],\n",
      "        [0.0046, 0.0013],\n",
      "        [0.1032, 0.0058],\n",
      "        [0.6573, 0.4121],\n",
      "        [0.3722, 0.2225]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14825179]\n",
      "Time: 8.627073213923723\n",
      "Iteration: 16\n",
      "new candidats: tensor([[0.4904, 0.3447],\n",
      "        [0.4733, 0.7270],\n",
      "        [0.7316, 0.6563],\n",
      "        [0.1475, 0.3054],\n",
      "        [0.1707, 0.2185]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1374, 0.0423],\n",
      "        [0.6573, 0.4121],\n",
      "        [0.0447, 0.0012],\n",
      "        [0.4204, 0.4037],\n",
      "        [0.4925, 0.4386]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14825179]\n",
      "Time: 7.865765079157427\n",
      "Iteration: 1\n",
      "new candidats: tensor([[0.1302, 0.2769],\n",
      "        [0.7076, 0.6076],\n",
      "        [0.3623, 0.7007],\n",
      "        [0.6815, 0.1708],\n",
      "        [0.1432, 0.1560]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4370, 0.4438],\n",
      "        [0.0556, 0.0014],\n",
      "        [0.2868, 0.4058],\n",
      "        [0.3597, 0.0055],\n",
      "        [0.4687, 0.4564]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.06216833]\n",
      "Time: 7.08161598094739\n",
      "Iteration: 2\n",
      "new candidats: tensor([[0.1694, 0.1954],\n",
      "        [0.3175, 0.1026],\n",
      "        [0.7076, 0.6076],\n",
      "        [0.7512, 0.9320],\n",
      "        [0.5000, 0.7783]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4941, 0.4418],\n",
      "        [0.3737, 0.2065],\n",
      "        [0.0556, 0.0014],\n",
      "        [0.0020, 0.0006],\n",
      "        [0.5175, 0.4157]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07231902]\n",
      "Time: 9.64234277419746\n",
      "Iteration: 3\n",
      "new candidats: tensor([[1.0311e-01, 8.6767e-02],\n",
      "        [1.8058e-02, 9.5254e-04],\n",
      "        [5.6324e-03, 1.4320e-01],\n",
      "        [4.2367e-01, 7.5203e-01],\n",
      "        [9.8605e-01, 2.8425e-01]], dtype=torch.float64)\n",
      "new obj: tensor([[3.7880e-01, 4.2016e-01],\n",
      "        [2.0146e-01, 2.9460e-01],\n",
      "        [2.9948e-01, 4.5600e-01],\n",
      "        [4.6279e-01, 6.0902e-01],\n",
      "        [8.7153e-02, 3.2163e-05]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.10037614]\n",
      "Time: 8.904932910809293\n",
      "Iteration: 4\n",
      "new candidats: tensor([[0.7076, 0.6076],\n",
      "        [0.4631, 0.8035],\n",
      "        [0.9349, 0.8158],\n",
      "        [0.3986, 0.7819],\n",
      "        [0.4583, 0.7287]], dtype=torch.float64)\n",
      "new obj: tensor([[5.5604e-02, 1.3602e-03],\n",
      "        [3.8491e-01, 5.7413e-01],\n",
      "        [3.3040e-05, 8.0193e-07],\n",
      "        [3.0354e-01, 6.9049e-01],\n",
      "        [6.2250e-01, 4.6023e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13270363]\n",
      "Time: 11.673532977933064\n",
      "Iteration: 5\n",
      "new candidats: tensor([[0.0537, 0.1466],\n",
      "        [0.4311, 0.3472],\n",
      "        [0.4491, 0.3677],\n",
      "        [0.4843, 0.7135],\n",
      "        [0.4583, 0.7287]], dtype=torch.float64)\n",
      "new obj: tensor([[0.3693, 0.4809],\n",
      "        [0.1969, 0.0747],\n",
      "        [0.1648, 0.0584],\n",
      "        [0.6920, 0.3394],\n",
      "        [0.6225, 0.4602]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14092625]\n",
      "Time: 8.407909317873418\n",
      "Iteration: 6\n",
      "new candidats: tensor([[0.4730, 0.0481],\n",
      "        [0.4583, 0.7287],\n",
      "        [0.4237, 0.7520],\n",
      "        [0.3000, 0.8122],\n",
      "        [0.4936, 0.0452]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1487, 0.0492],\n",
      "        [0.6225, 0.4602],\n",
      "        [0.4628, 0.6090],\n",
      "        [0.0545, 0.4238],\n",
      "        [0.1281, 0.0393]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14092625]\n",
      "Time: 5.407319188816473\n",
      "Iteration: 7\n",
      "new candidats: tensor([[0.5618, 0.5084],\n",
      "        [0.1223, 0.8410],\n",
      "        [0.4663, 0.8914],\n",
      "        [0.0930, 0.9152],\n",
      "        [0.4583, 0.7287]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1223, 0.0101],\n",
      "        [0.0029, 0.0164],\n",
      "        [0.1064, 0.3701],\n",
      "        [0.0007, 0.0041],\n",
      "        [0.6225, 0.4602]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14092625]\n",
      "Time: 3.603752995142713\n",
      "Iteration: 8\n",
      "new candidats: tensor([[0.5347, 0.5194],\n",
      "        [0.4583, 0.7287],\n",
      "        [0.4583, 0.7287],\n",
      "        [0.4152, 0.0634],\n",
      "        [0.2372, 0.7588]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1636, 0.0149],\n",
      "        [0.6225, 0.4602],\n",
      "        [0.6225, 0.4602],\n",
      "        [0.2221, 0.0893],\n",
      "        [0.0285, 0.1780]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14092625]\n",
      "Time: 3.506846849108115\n",
      "Iteration: 9\n",
      "new candidats: tensor([[0.4583, 0.7287],\n",
      "        [0.9552, 0.2621],\n",
      "        [0.6003, 0.5212],\n",
      "        [0.5053, 0.1546],\n",
      "        [0.6271, 0.2618]], dtype=torch.float64)\n",
      "new obj: tensor([[6.2250e-01, 4.6023e-01],\n",
      "        [1.7343e-01, 4.2552e-04],\n",
      "        [1.0473e-01, 6.0273e-03],\n",
      "        [1.6016e-01, 4.5600e-02],\n",
      "        [1.7847e-01, 9.8510e-03]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14092625]\n",
      "Time: 2.301065606996417\n",
      "Iteration: 10\n",
      "new candidats: tensor([[0.0921, 0.6336],\n",
      "        [0.4583, 0.7287],\n",
      "        [0.4237, 0.7520],\n",
      "        [0.1816, 0.8873],\n",
      "        [0.9061, 0.9061]], dtype=torch.float64)\n",
      "new obj: tensor([[4.1353e-02, 4.8914e-02],\n",
      "        [6.2250e-01, 4.6023e-01],\n",
      "        [4.6279e-01, 6.0902e-01],\n",
      "        [2.1165e-03, 4.5147e-02],\n",
      "        [2.3915e-05, 1.2529e-06]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14092625]\n",
      "Time: 4.961170371854678\n",
      "Iteration: 11\n",
      "new candidats: tensor([[0.4583, 0.7287],\n",
      "        [0.4237, 0.7520],\n",
      "        [0.5919, 0.4743],\n",
      "        [0.1139, 0.6442],\n",
      "        [0.5743, 0.5735]], dtype=torch.float64)\n",
      "new obj: tensor([[0.6225, 0.4602],\n",
      "        [0.4628, 0.6090],\n",
      "        [0.0664, 0.0070],\n",
      "        [0.0391, 0.0449],\n",
      "        [0.2538, 0.0154]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14092625]\n",
      "Time: 4.80965664004907\n",
      "Iteration: 12\n",
      "new candidats: tensor([[0.6884, 0.0630],\n",
      "        [0.1461, 0.3905],\n",
      "        [0.4583, 0.7287],\n",
      "        [0.9465, 0.1885],\n",
      "        [0.3719, 0.0393]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1671, 0.0062],\n",
      "        [0.3063, 0.2955],\n",
      "        [0.6225, 0.4602],\n",
      "        [0.2384, 0.0228],\n",
      "        [0.2503, 0.1159]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14092625]\n",
      "Time: 3.061172310030088\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration: 13\n",
      "new candidats: tensor([[0.4583, 0.7287],\n",
      "        [0.6164, 0.3702],\n",
      "        [0.2062, 0.2077],\n",
      "        [0.1941, 0.0774],\n",
      "        [0.7476, 0.0771]], dtype=torch.float64)\n",
      "new obj: tensor([[0.6225, 0.4602],\n",
      "        [0.0719, 0.0083],\n",
      "        [0.4994, 0.3962],\n",
      "        [0.4142, 0.3419],\n",
      "        [0.2965, 0.0788]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14092625]\n",
      "Time: 2.4505148991011083\n",
      "Iteration: 14\n",
      "new candidats: tensor([[0.4583, 0.7287],\n",
      "        [0.4982, 0.7069],\n",
      "        [0.6432, 0.8809],\n",
      "        [0.6353, 0.6098],\n",
      "        [0.4155, 0.3450]], dtype=torch.float64)\n",
      "new obj: tensor([[0.6225, 0.4602],\n",
      "        [0.7049, 0.2821],\n",
      "        [0.0491, 0.0263],\n",
      "        [0.1924, 0.0083],\n",
      "        [0.2162, 0.0865]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14171229]\n",
      "Time: 1.7293641108553857\n",
      "Iteration: 15\n",
      "new candidats: tensor([[0.7637, 0.2446],\n",
      "        [0.5740, 0.8925],\n",
      "        [0.6224, 0.2939],\n",
      "        [0.4583, 0.7287],\n",
      "        [0.4654, 0.3405]], dtype=torch.float64)\n",
      "new obj: tensor([[0.6026, 0.0036],\n",
      "        [0.0837, 0.1005],\n",
      "        [0.1413, 0.0099],\n",
      "        [0.6225, 0.4602],\n",
      "        [0.1640, 0.0554]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14171229]\n",
      "Time: 2.174144848017022\n",
      "Iteration: 16\n",
      "new candidats: tensor([[0.8048, 0.8859],\n",
      "        [0.3805, 0.5275],\n",
      "        [0.4583, 0.7287],\n",
      "        [0.5952, 0.7558],\n",
      "        [0.6590, 0.4089]], dtype=torch.float64)\n",
      "new obj: tensor([[1.2098e-03, 1.3548e-04],\n",
      "        [1.6450e-01, 5.5960e-02],\n",
      "        [6.2250e-01, 4.6023e-01],\n",
      "        [3.8228e-01, 9.4845e-02],\n",
      "        [5.2925e-02, 3.8011e-03]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14171229]\n",
      "Time: 2.5511511301156133\n",
      "Iteration: 1\n",
      "new candidats: tensor([[0.6407, 0.6701],\n",
      "        [0.4629, 0.6837],\n",
      "        [0.4593, 0.8978],\n",
      "        [0.0407, 0.0290],\n",
      "        [0.6611, 0.1847]], dtype=torch.float64)\n",
      "new obj: tensor([[0.2514, 0.0171],\n",
      "        [0.6561, 0.2959],\n",
      "        [0.0915, 0.3640],\n",
      "        [0.2526, 0.3432],\n",
      "        [0.2986, 0.0065]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07890035]\n",
      "Time: 9.016376687213778\n",
      "Iteration: 2\n",
      "new candidats: tensor([[0.0072, 0.3562],\n",
      "        [0.1243, 0.1105],\n",
      "        [0.4454, 0.7239],\n",
      "        [0.4287, 0.7564],\n",
      "        [0.0806, 0.2239]], dtype=torch.float64)\n",
      "new obj: tensor([[0.2316, 0.3508],\n",
      "        [0.4211, 0.4360],\n",
      "        [0.5938, 0.4755],\n",
      "        [0.4684, 0.6130],\n",
      "        [0.4154, 0.4957]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13244531]\n",
      "Time: 9.074454855872318\n",
      "Iteration: 3\n",
      "new candidats: tensor([[0.4160, 0.7764],\n",
      "        [0.1101, 0.3893],\n",
      "        [0.3943, 0.2995],\n",
      "        [0.4529, 0.7476],\n",
      "        [0.1331, 0.8803]], dtype=torch.float64)\n",
      "new obj: tensor([[0.3716, 0.6739],\n",
      "        [0.2887, 0.3131],\n",
      "        [0.2759, 0.1187],\n",
      "        [0.5647, 0.5324],\n",
      "        [0.0016, 0.0159]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14238582]\n",
      "Time: 10.62365771504119\n",
      "Iteration: 4\n",
      "new candidats: tensor([[0.4777, 0.7317],\n",
      "        [0.1145, 0.4089],\n",
      "        [0.7121, 0.9092],\n",
      "        [0.5819, 0.4365],\n",
      "        [0.4160, 0.7764]], dtype=torch.float64)\n",
      "new obj: tensor([[0.6550, 0.4117],\n",
      "        [0.2645, 0.2827],\n",
      "        [0.0083, 0.0030],\n",
      "        [0.0596, 0.0096],\n",
      "        [0.3716, 0.6739]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14946845]\n",
      "Time: 3.1692421829793602\n",
      "Iteration: 5\n",
      "new candidats: tensor([[0.7038, 0.7191],\n",
      "        [0.9240, 0.7378],\n",
      "        [0.4777, 0.7317],\n",
      "        [0.5344, 0.7706],\n",
      "        [0.4822, 0.7221]], dtype=torch.float64)\n",
      "new obj: tensor([[8.6843e-02, 5.1106e-03],\n",
      "        [1.0082e-04, 2.1090e-06],\n",
      "        [6.5499e-01, 4.1168e-01],\n",
      "        [5.1632e-01, 2.7211e-01],\n",
      "        [6.7862e-01, 3.7034e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.1529115]\n",
      "Time: 8.071264841826633\n",
      "Iteration: 6\n",
      "new candidats: tensor([[0.3980, 0.2607],\n",
      "        [0.3231, 0.8456],\n",
      "        [0.1471, 0.8031],\n",
      "        [0.4901, 0.9422],\n",
      "        [0.4529, 0.7476]], dtype=torch.float64)\n",
      "new obj: tensor([[0.2927, 0.1244],\n",
      "        [0.0530, 0.4707],\n",
      "        [0.0059, 0.0335],\n",
      "        [0.0373, 0.1698],\n",
      "        [0.5647, 0.5324]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.1529115]\n",
      "Time: 5.313506347825751\n",
      "Iteration: 7\n",
      "new candidats: tensor([[0.6148, 0.8358],\n",
      "        [0.4529, 0.7476],\n",
      "        [0.0257, 0.4925],\n",
      "        [0.3466, 0.7961],\n",
      "        [0.3689, 0.8509]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1443, 0.0654],\n",
      "        [0.5647, 0.5324],\n",
      "        [0.1173, 0.1674],\n",
      "        [0.1405, 0.6088],\n",
      "        [0.0967, 0.5866]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.1529115]\n",
      "Time: 3.514036306878552\n",
      "Iteration: 8\n",
      "new candidats: tensor([[0.4966, 0.6973],\n",
      "        [0.4254, 0.4416],\n",
      "        [0.3083, 0.2528],\n",
      "        [0.9255, 0.2495],\n",
      "        [0.2238, 0.6067]], dtype=torch.float64)\n",
      "new obj: tensor([[0.7069, 0.2615],\n",
      "        [0.1466, 0.0508],\n",
      "        [0.4171, 0.2375],\n",
      "        [0.2824, 0.0026],\n",
      "        [0.0728, 0.0699]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15405475]\n",
      "Time: 3.6056613898836076\n",
      "Iteration: 9\n",
      "new candidats: tensor([[0.2499, 0.2456],\n",
      "        [0.0900, 0.2956],\n",
      "        [0.8598, 0.3353],\n",
      "        [0.4529, 0.7476],\n",
      "        [0.5519, 0.9066]], dtype=torch.float64)\n",
      "new obj: tensor([[4.7226e-01, 3.2511e-01],\n",
      "        [3.8344e-01, 4.4377e-01],\n",
      "        [2.3612e-01, 1.7406e-04],\n",
      "        [5.6474e-01, 5.3236e-01],\n",
      "        [7.2670e-02, 1.2529e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15405475]\n",
      "Time: 1.8589034941978753\n",
      "Iteration: 10\n",
      "new candidats: tensor([[0.5966, 0.3498],\n",
      "        [0.5653, 0.8758],\n",
      "        [0.7254, 0.4658],\n",
      "        [0.4529, 0.7476],\n",
      "        [0.3663, 0.2255]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0826, 0.0118],\n",
      "        [0.1209, 0.1340],\n",
      "        [0.0256, 0.0010],\n",
      "        [0.5647, 0.5324],\n",
      "        [0.3511, 0.1656]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15405475]\n",
      "Time: 2.0031752579379827\n",
      "Iteration: 11\n",
      "new candidats: tensor([[0.8151, 0.3747],\n",
      "        [0.8425, 0.4637],\n",
      "        [0.2460, 0.1866],\n",
      "        [0.4160, 0.7764],\n",
      "        [0.7436, 0.7425]], dtype=torch.float64)\n",
      "new obj: tensor([[1.5338e-01, 3.3095e-04],\n",
      "        [2.1096e-02, 1.2087e-04],\n",
      "        [4.8586e-01, 3.3871e-01],\n",
      "        [3.7164e-01, 6.7395e-01],\n",
      "        [3.3213e-02, 1.6634e-03]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15405475]\n",
      "Time: 1.9172064680606127\n",
      "Iteration: 12\n",
      "new candidats: tensor([[0.4160, 0.7764],\n",
      "        [0.7061, 0.3569],\n",
      "        [0.4449, 0.0309],\n",
      "        [0.2754, 0.1308],\n",
      "        [0.1419, 0.7728]], dtype=torch.float64)\n",
      "new obj: tensor([[0.3716, 0.6739],\n",
      "        [0.1468, 0.0023],\n",
      "        [0.1656, 0.0604],\n",
      "        [0.4386, 0.2779],\n",
      "        [0.0088, 0.0319]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15405475]\n",
      "Time: 1.7331492649391294\n",
      "Iteration: 13\n",
      "new candidats: tensor([[0.2847, 0.9047],\n",
      "        [0.4160, 0.7764],\n",
      "        [0.9094, 0.8908],\n",
      "        [0.0351, 0.5313],\n",
      "        [0.1905, 0.8890]], dtype=torch.float64)\n",
      "new obj: tensor([[9.4072e-03, 2.0875e-01],\n",
      "        [3.7164e-01, 6.7395e-01],\n",
      "        [2.8382e-05, 1.2668e-06],\n",
      "        [9.0271e-02, 1.2493e-01],\n",
      "        [2.2967e-03, 5.3574e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15405475]\n",
      "Time: 1.623732628999278\n",
      "Iteration: 14\n",
      "new candidats: tensor([[0.4529, 0.7476],\n",
      "        [0.8279, 0.5541],\n",
      "        [0.2599, 0.0511],\n",
      "        [0.9854, 0.2031],\n",
      "        [0.5240, 0.0200]], dtype=torch.float64)\n",
      "new obj: tensor([[5.6474e-01, 5.3236e-01],\n",
      "        [3.1498e-03, 8.3100e-05],\n",
      "        [3.6236e-01, 2.4144e-01],\n",
      "        [1.2577e-01, 2.1536e-03],\n",
      "        [9.2879e-02, 2.5370e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15405475]\n",
      "Time: 1.8453393960371614\n",
      "Iteration: 15\n",
      "new candidats: tensor([[0.4822, 0.7221],\n",
      "        [0.4160, 0.7764],\n",
      "        [0.0619, 0.5283],\n",
      "        [0.0472, 0.4244],\n",
      "        [0.0411, 0.6226]], dtype=torch.float64)\n",
      "new obj: tensor([[0.6786, 0.3703],\n",
      "        [0.3716, 0.6739],\n",
      "        [0.1024, 0.1299],\n",
      "        [0.1990, 0.2647],\n",
      "        [0.0391, 0.0533]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15405475]\n",
      "Time: 1.8189427319448441\n",
      "Iteration: 16\n",
      "new candidats: tensor([[0.1148, 0.9197],\n",
      "        [0.8386, 0.8927],\n",
      "        [0.7134, 0.6906],\n",
      "        [0.4529, 0.7476],\n",
      "        [0.0843, 0.4318]], dtype=torch.float64)\n",
      "new obj: tensor([[7.4196e-04, 6.6058e-03],\n",
      "        [3.6081e-04, 3.0978e-05],\n",
      "        [7.2343e-02, 2.9692e-03],\n",
      "        [5.6474e-01, 5.3236e-01],\n",
      "        [2.1605e-01, 2.5473e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15405475]\n",
      "Time: 2.015364082995802\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration: 1\n",
      "new candidats: tensor([[0.1008, 0.0576],\n",
      "        [0.9832, 0.1277],\n",
      "        [0.0180, 0.1758],\n",
      "        [0.1630, 0.0188],\n",
      "        [0.1108, 0.1875]], dtype=torch.float64)\n",
      "new obj: tensor([[0.3431, 0.3834],\n",
      "        [0.1009, 0.0173],\n",
      "        [0.3281, 0.4799],\n",
      "        [0.3261, 0.2978],\n",
      "        [0.4518, 0.4888]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.05834516]\n",
      "Time: 6.6525850801263005\n",
      "Iteration: 2\n",
      "new candidats: tensor([[0.3448, 0.4550],\n",
      "        [0.3276, 0.4232],\n",
      "        [0.0813, 0.2018],\n",
      "        [0.1598, 0.2107],\n",
      "        [0.0711, 0.8102]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1811, 0.0878],\n",
      "        [0.2223, 0.1175],\n",
      "        [0.4193, 0.4992],\n",
      "        [0.4893, 0.4514],\n",
      "        [0.0039, 0.0079]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.06891717]\n",
      "Time: 5.59215390519239\n",
      "Iteration: 3\n",
      "new candidats: tensor([[0.1134, 0.3322],\n",
      "        [0.1419, 0.1802],\n",
      "        [0.1930, 0.2062],\n",
      "        [0.1889, 0.2246],\n",
      "        [0.0609, 0.2218]], dtype=torch.float64)\n",
      "new obj: tensor([[0.3658, 0.3925],\n",
      "        [0.4770, 0.4664],\n",
      "        [0.4994, 0.4137],\n",
      "        [0.4955, 0.4158],\n",
      "        [0.3902, 0.4965]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07126368]\n",
      "Time: 7.1611073890235275\n",
      "Iteration: 4\n",
      "new candidats: tensor([[0.0996, 0.5384],\n",
      "        [0.0637, 0.3822],\n",
      "        [0.5682, 0.9940],\n",
      "        [0.1212, 0.2176],\n",
      "        [0.4500, 0.8663]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1054, 0.1185],\n",
      "        [0.2618, 0.3301],\n",
      "        [0.0074, 0.0259],\n",
      "        [0.4608, 0.4820],\n",
      "        [0.1558, 0.4960]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07140496]\n",
      "Time: 2.0705028290394694\n",
      "Iteration: 5\n",
      "new candidats: tensor([[0.0813, 0.2018],\n",
      "        [0.8574, 0.7138],\n",
      "        [0.9585, 0.7350],\n",
      "        [0.5425, 0.7218],\n",
      "        [0.5587, 0.0873]], dtype=torch.float64)\n",
      "new obj: tensor([[4.1930e-01, 4.9918e-01],\n",
      "        [1.2535e-03, 2.1801e-05],\n",
      "        [2.8556e-05, 8.1881e-07],\n",
      "        [6.2831e-01, 1.8790e-01],\n",
      "        [1.0562e-01, 2.1565e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07140496]\n",
      "Time: 1.7179403400514275\n",
      "Iteration: 6\n",
      "new candidats: tensor([[0.5045, 0.5284],\n",
      "        [0.4288, 0.7314],\n",
      "        [0.9759, 0.9369],\n",
      "        [0.4558, 0.7063],\n",
      "        [0.7955, 0.1121]], dtype=torch.float64)\n",
      "new obj: tensor([[2.0132e-01, 2.2419e-02],\n",
      "        [5.2475e-01, 5.3374e-01],\n",
      "        [8.1647e-07, 3.7061e-08],\n",
      "        [6.4266e-01, 3.8921e-01],\n",
      "        [4.8072e-01, 3.7574e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.11078571]\n",
      "Time: 9.59380577900447\n",
      "Iteration: 7\n",
      "new candidats: tensor([[0.7772, 0.0053],\n",
      "        [0.4223, 0.7267],\n",
      "        [0.3995, 0.7842],\n",
      "        [0.5813, 0.5889],\n",
      "        [0.5701, 0.6861]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1074, 0.0411],\n",
      "        [0.5079, 0.5252],\n",
      "        [0.3005, 0.6931],\n",
      "        [0.2837, 0.0175],\n",
      "        [0.5468, 0.0872]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.12141434]\n",
      "Time: 6.516326694982126\n",
      "Iteration: 8\n",
      "new candidats: tensor([[0.6022, 0.3954],\n",
      "        [0.4667, 0.7376],\n",
      "        [0.4452, 0.7636],\n",
      "        [0.6380, 0.6098],\n",
      "        [0.4235, 0.2040]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0598, 0.0090],\n",
      "        [0.6226, 0.4632],\n",
      "        [0.4965, 0.5931],\n",
      "        [0.1854, 0.0078],\n",
      "        [0.2683, 0.1048]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.1402908]\n",
      "Time: 5.4275413600262254\n",
      "Iteration: 9\n",
      "new candidats: tensor([[0.3155, 0.2021],\n",
      "        [0.1008, 0.0576],\n",
      "        [0.4778, 0.7209],\n",
      "        [0.2321, 0.0463],\n",
      "        [0.4839, 0.7239]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4232, 0.2354],\n",
      "        [0.3431, 0.3834],\n",
      "        [0.6745, 0.3806],\n",
      "        [0.3674, 0.2680],\n",
      "        [0.6775, 0.3704]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14581093]\n",
      "Time: 2.9014577839989215\n",
      "Iteration: 10\n",
      "new candidats: tensor([[0.3122, 0.3169],\n",
      "        [0.7103, 0.1943],\n",
      "        [0.2047, 0.3919],\n",
      "        [0.4999, 0.6997],\n",
      "        [0.4079, 0.7832]], dtype=torch.float64)\n",
      "new obj: tensor([[0.3602, 0.2025],\n",
      "        [0.4865, 0.0054],\n",
      "        [0.3155, 0.2515],\n",
      "        [0.7072, 0.2591],\n",
      "        [0.3283, 0.6897]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14962795]\n",
      "Time: 1.6519938679412007\n",
      "Iteration: 11\n",
      "new candidats: tensor([[0.2713, 0.0203],\n",
      "        [0.4452, 0.7636],\n",
      "        [0.7648, 0.5854],\n",
      "        [0.1598, 0.2107],\n",
      "        [0.4572, 0.2549]], dtype=torch.float64)\n",
      "new obj: tensor([[3.1345e-01, 2.0128e-01],\n",
      "        [4.9653e-01, 5.9311e-01],\n",
      "        [1.2739e-02, 2.7730e-04],\n",
      "        [4.8929e-01, 4.5143e-01],\n",
      "        [2.1233e-01, 7.3913e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14962795]\n",
      "Time: 1.488248550100252\n",
      "Iteration: 12\n",
      "new candidats: tensor([[0.8493, 0.5354],\n",
      "        [0.5187, 0.6251],\n",
      "        [0.4452, 0.7636],\n",
      "        [0.3615, 0.1136],\n",
      "        [0.0032, 0.8591]], dtype=torch.float64)\n",
      "new obj: tensor([[3.2755e-03, 6.2760e-05],\n",
      "        [5.3421e-01, 7.9183e-02],\n",
      "        [4.9653e-01, 5.9311e-01],\n",
      "        [3.2876e-01, 1.5745e-01],\n",
      "        [1.3503e-03, 2.2949e-03]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14962795]\n",
      "Time: 1.4956530719064176\n",
      "Iteration: 13\n",
      "new candidats: tensor([[0.4452, 0.7636],\n",
      "        [0.1458, 0.6365],\n",
      "        [0.6585, 0.8730],\n",
      "        [0.9116, 0.1145],\n",
      "        [0.7192, 0.3623]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4965, 0.5931],\n",
      "        [0.0456, 0.0503],\n",
      "        [0.0447, 0.0190],\n",
      "        [0.2616, 0.3146],\n",
      "        [0.1479, 0.0019]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14962795]\n",
      "Time: 1.5156697919592261\n",
      "Iteration: 14\n",
      "new candidats: tensor([[0.8561, 0.2055],\n",
      "        [0.3907, 0.3145],\n",
      "        [0.8298, 0.6477],\n",
      "        [0.4452, 0.7636],\n",
      "        [0.4443, 0.7009]], dtype=torch.float64)\n",
      "new obj: tensor([[5.9946e-01, 7.5290e-02],\n",
      "        [2.6972e-01, 1.1736e-01],\n",
      "        [2.9722e-03, 5.1397e-05],\n",
      "        [4.9653e-01, 5.9311e-01],\n",
      "        [6.0956e-01, 3.9218e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14962795]\n",
      "Time: 1.5325739730615169\n",
      "Iteration: 15\n",
      "new candidats: tensor([[0.3353, 0.0104],\n",
      "        [0.2139, 0.0698],\n",
      "        [0.4452, 0.7636],\n",
      "        [0.5292, 0.5875],\n",
      "        [0.5682, 0.9940]], dtype=torch.float64)\n",
      "new obj: tensor([[0.2539, 0.1324],\n",
      "        [0.4036, 0.3122],\n",
      "        [0.4965, 0.5931],\n",
      "        [0.3760, 0.0373],\n",
      "        [0.0074, 0.0259]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14962795]\n",
      "Time: 1.390811914112419\n",
      "Iteration: 16\n",
      "new candidats: tensor([[0.6697, 0.1116],\n",
      "        [0.4429, 0.2730],\n",
      "        [0.2694, 0.3778],\n",
      "        [0.0167, 0.1960],\n",
      "        [0.4452, 0.7636]], dtype=torch.float64)\n",
      "new obj: tensor([[0.2314, 0.0061],\n",
      "        [0.2248, 0.0823],\n",
      "        [0.3173, 0.2049],\n",
      "        [0.3285, 0.4825],\n",
      "        [0.4965, 0.5931]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14962795]\n",
      "Time: 1.5092597261536866\n",
      "Iteration: 1\n",
      "new candidats: tensor([[0.7588, 0.0923],\n",
      "        [0.1613, 0.1770],\n",
      "        [0.5062, 0.4401],\n",
      "        [0.0083, 0.0076],\n",
      "        [0.1369, 0.0065]], dtype=torch.float64)\n",
      "new obj: tensor([[0.3689, 0.1322],\n",
      "        [0.4875, 0.4475],\n",
      "        [0.0997, 0.0231],\n",
      "        [0.1989, 0.3002],\n",
      "        [0.2978, 0.2960]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.0574485]\n",
      "Time: 5.790718639967963\n",
      "Iteration: 2\n",
      "new candidats: tensor([[0.0353, 0.2444],\n",
      "        [0.0263, 0.3177],\n",
      "        [0.1903, 0.2397],\n",
      "        [0.1227, 0.2267],\n",
      "        [0.7012, 0.8792]], dtype=torch.float64)\n",
      "new obj: tensor([[0.3475, 0.4805],\n",
      "        [0.2884, 0.4105],\n",
      "        [0.4897, 0.4092],\n",
      "        [0.4599, 0.4787],\n",
      "        [0.0186, 0.0055]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.06510142]\n",
      "Time: 5.080700809136033\n",
      "Iteration: 3\n",
      "new candidats: tensor([[0.2053, 0.2066],\n",
      "        [0.2357, 0.9677],\n",
      "        [0.0781, 0.1874],\n",
      "        [0.0996, 0.2001],\n",
      "        [0.5306, 0.4410]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4996, 0.3976],\n",
      "        [0.0009, 0.0447],\n",
      "        [0.4144, 0.4986],\n",
      "        [0.4408, 0.4945],\n",
      "        [0.0861, 0.0175]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07065916]\n",
      "Time: 6.444124168949202\n",
      "Iteration: 4\n",
      "new candidats: tensor([[0.9882, 0.1121],\n",
      "        [0.9312, 0.5632],\n",
      "        [0.9839, 0.0129],\n",
      "        [0.8434, 0.8111],\n",
      "        [0.7379, 0.3493]], dtype=torch.float64)\n",
      "new obj: tensor([[8.1106e-02, 1.4914e-02],\n",
      "        [5.4976e-04, 9.0834e-06],\n",
      "        [2.2583e-02, 4.2719e-03],\n",
      "        [1.0641e-03, 4.0040e-05],\n",
      "        [1.9974e-01, 1.4340e-03]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07065916]\n",
      "Time: 7.049254139885306\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration: 5\n",
      "new candidats: tensor([[0.0708, 0.6738],\n",
      "        [0.1555, 0.1834],\n",
      "        [0.1068, 0.1927],\n",
      "        [0.0781, 0.1874],\n",
      "        [0.9059, 0.8363]], dtype=torch.float64)\n",
      "new obj: tensor([[2.4591e-02, 3.1612e-02],\n",
      "        [4.8611e-01, 4.5475e-01],\n",
      "        [4.4828e-01, 4.9126e-01],\n",
      "        [4.1442e-01, 4.9860e-01],\n",
      "        [7.9298e-05, 2.3227e-06]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07094231]\n",
      "Time: 2.8103807540610433\n",
      "Iteration: 6\n",
      "new candidats: tensor([[0.0781, 0.1874],\n",
      "        [0.1555, 0.1834],\n",
      "        [0.4569, 0.4488],\n",
      "        [0.1764, 0.9888],\n",
      "        [0.5394, 0.3922]], dtype=torch.float64)\n",
      "new obj: tensor([[4.1442e-01, 4.9860e-01],\n",
      "        [4.8611e-01, 4.5475e-01],\n",
      "        [1.2838e-01, 3.6760e-02],\n",
      "        [2.6549e-04, 9.8489e-03],\n",
      "        [8.4039e-02, 2.0125e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07094231]\n",
      "Time: 1.2671639539767057\n",
      "Iteration: 7\n",
      "new candidats: tensor([[0.1668, 0.1788],\n",
      "        [0.8737, 0.6854],\n",
      "        [0.7700, 0.4033],\n",
      "        [0.1966, 0.4031],\n",
      "        [0.9555, 0.8356]], dtype=torch.float64)\n",
      "new obj: tensor([[4.9041e-01, 4.4219e-01],\n",
      "        [7.3785e-04, 1.3072e-05],\n",
      "        [9.0026e-02, 6.5210e-04],\n",
      "        [2.9855e-01, 2.4437e-01],\n",
      "        [1.1249e-05, 3.0776e-07]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07104626]\n",
      "Time: 1.579485853901133\n",
      "Iteration: 8\n",
      "new candidats: tensor([[0.4112, 0.4199],\n",
      "        [0.7321, 0.7765],\n",
      "        [0.0781, 0.1874],\n",
      "        [0.9711, 0.6816],\n",
      "        [0.1555, 0.1834]], dtype=torch.float64)\n",
      "new obj: tensor([[1.6575e-01, 6.4223e-02],\n",
      "        [3.5532e-02, 2.7721e-03],\n",
      "        [4.1442e-01, 4.9860e-01],\n",
      "        [2.8251e-05, 1.1059e-06],\n",
      "        [4.8611e-01, 4.5475e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07104626]\n",
      "Time: 3.248148712096736\n",
      "Iteration: 9\n",
      "new candidats: tensor([[0.1555, 0.1834],\n",
      "        [0.6616, 0.1202],\n",
      "        [0.2037, 0.4242],\n",
      "        [0.2331, 0.7002],\n",
      "        [0.5624, 0.1443]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4861, 0.4548],\n",
      "        [0.2275, 0.0063],\n",
      "        [0.2669, 0.2134],\n",
      "        [0.0415, 0.1213],\n",
      "        [0.1288, 0.0232]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07104626]\n",
      "Time: 2.4567184320185333\n",
      "Iteration: 10\n",
      "new candidats: tensor([[0.0781, 0.1874],\n",
      "        [0.5979, 0.3820],\n",
      "        [0.5501, 0.8438],\n",
      "        [0.1085, 0.8966],\n",
      "        [0.1555, 0.1834]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4144, 0.4986],\n",
      "        [0.0657, 0.0102],\n",
      "        [0.2203, 0.2063],\n",
      "        [0.0011, 0.0074],\n",
      "        [0.4861, 0.4548]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07104626]\n",
      "Time: 1.784582540858537\n",
      "Iteration: 11\n",
      "new candidats: tensor([[0.5272, 0.9437],\n",
      "        [0.0781, 0.1874],\n",
      "        [0.6688, 0.3621],\n",
      "        [0.7815, 0.4711],\n",
      "        [0.2709, 0.4057]], dtype=torch.float64)\n",
      "new obj: tensor([[3.4763e-02, 1.1108e-01],\n",
      "        [4.1442e-01, 4.9860e-01],\n",
      "        [1.0321e-01, 4.0747e-03],\n",
      "        [2.1336e-02, 3.5851e-04],\n",
      "        [2.7741e-01, 1.7807e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07104626]\n",
      "Time: 1.489378263009712\n",
      "Iteration: 12\n",
      "new candidats: tensor([[0.8049, 0.2359],\n",
      "        [0.2709, 0.4057],\n",
      "        [0.2053, 0.2066],\n",
      "        [0.0454, 0.9283],\n",
      "        [0.4551, 0.7414]], dtype=torch.float64)\n",
      "new obj: tensor([[6.6066e-01, 1.2181e-02],\n",
      "        [2.7741e-01, 1.7807e-01],\n",
      "        [4.9956e-01, 3.9757e-01],\n",
      "        [4.9115e-04, 1.2273e-03],\n",
      "        [5.8654e-01, 5.0859e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.10140908]\n",
      "Time: 5.531859034206718\n",
      "Iteration: 13\n",
      "new candidats: tensor([[0.4847, 0.7154],\n",
      "        [0.4154, 0.7512],\n",
      "        [0.5835, 0.9965],\n",
      "        [0.2958, 0.7962],\n",
      "        [0.0530, 0.1582]], dtype=torch.float64)\n",
      "new obj: tensor([[0.6903, 0.3439],\n",
      "        [0.4358, 0.6164],\n",
      "        [0.0061, 0.0189],\n",
      "        [0.0600, 0.4094],\n",
      "        [0.3734, 0.4874]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.1359355]\n",
      "Time: 3.736142053967342\n",
      "Iteration: 14\n",
      "new candidats: tensor([[0.9270, 0.2371],\n",
      "        [0.5247, 0.6445],\n",
      "        [0.4551, 0.7414],\n",
      "        [0.1787, 0.5888],\n",
      "        [0.2129, 0.0775]], dtype=torch.float64)\n",
      "new obj: tensor([[0.2925, 0.0050],\n",
      "        [0.5935, 0.0993],\n",
      "        [0.5865, 0.5086],\n",
      "        [0.0773, 0.0717],\n",
      "        [0.4136, 0.3211]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.1359355]\n",
      "Time: 1.837971521075815\n",
      "Iteration: 15\n",
      "new candidats: tensor([[0.5501, 0.8438],\n",
      "        [0.8316, 0.2602],\n",
      "        [0.9492, 0.5782],\n",
      "        [0.4551, 0.7414],\n",
      "        [0.1549, 0.2646]], dtype=torch.float64)\n",
      "new obj: tensor([[2.2025e-01, 2.0627e-01],\n",
      "        [5.5890e-01, 4.2073e-03],\n",
      "        [2.6959e-04, 5.3456e-06],\n",
      "        [5.8654e-01, 5.0859e-01],\n",
      "        [4.6263e-01, 4.3368e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.1359355]\n",
      "Time: 3.586197149939835\n",
      "Iteration: 16\n",
      "new candidats: tensor([[0.4551, 0.7414],\n",
      "        [0.1898, 0.8064],\n",
      "        [0.7987, 0.3520],\n",
      "        [0.9129, 0.2406],\n",
      "        [0.4078, 0.1387]], dtype=torch.float64)\n",
      "new obj: tensor([[5.8654e-01, 5.0859e-01],\n",
      "        [8.2670e-03, 8.0877e-02],\n",
      "        [2.2469e-01, 4.9193e-04],\n",
      "        [3.4155e-01, 6.1594e-03],\n",
      "        [2.7829e-01, 1.1454e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.1359355]\n",
      "Time: 3.8842254478950053\n",
      "Iteration: 1\n",
      "new candidats: tensor([[0.3726, 0.7431],\n",
      "        [0.4087, 0.8020],\n",
      "        [0.1801, 0.8383],\n",
      "        [0.3087, 0.8093],\n",
      "        [0.0376, 0.9155]], dtype=torch.float64)\n",
      "new obj: tensor([[2.9199e-01, 5.7737e-01],\n",
      "        [2.7717e-01, 6.9853e-01],\n",
      "        [4.6698e-03, 6.0636e-02],\n",
      "        [6.5918e-02, 4.6167e-01],\n",
      "        [6.0011e-04, 1.3277e-03]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.08788867]\n",
      "Time: 11.255386160919443\n",
      "Iteration: 2\n",
      "new candidats: tensor([[0.4491, 0.4999],\n",
      "        [0.4751, 0.7399],\n",
      "        [0.4280, 0.7306],\n",
      "        [0.5062, 0.7054],\n",
      "        [0.5011, 0.3376]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1579, 0.0338],\n",
      "        [0.6317, 0.4426],\n",
      "        [0.5231, 0.5321],\n",
      "        [0.7040, 0.2565],\n",
      "        [0.1312, 0.0387]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13983448]\n",
      "Time: 7.373702529119328\n",
      "Iteration: 3\n",
      "new candidats: tensor([[0.3830, 0.0821],\n",
      "        [0.6950, 0.3397],\n",
      "        [0.4771, 0.7357],\n",
      "        [0.0619, 0.0385],\n",
      "        [0.1892, 0.2048]], dtype=torch.float64)\n",
      "new obj: tensor([[0.2765, 0.1235],\n",
      "        [0.1706, 0.0030],\n",
      "        [0.6450, 0.4246],\n",
      "        [0.2844, 0.3606],\n",
      "        [0.4991, 0.4186]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14207919]\n",
      "Time: 7.884162771049887\n",
      "Iteration: 4\n",
      "new candidats: tensor([[0.4751, 0.7399],\n",
      "        [0.6056, 0.6377],\n",
      "        [0.3540, 0.0839],\n",
      "        [0.4340, 0.7706],\n",
      "        [0.4774, 0.4252]], dtype=torch.float64)\n",
      "new obj: tensor([[0.6317, 0.4426],\n",
      "        [0.3360, 0.0239],\n",
      "        [0.3141, 0.1542],\n",
      "        [0.4430, 0.6344],\n",
      "        [0.1173, 0.0338]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14301508]\n",
      "Time: 5.018652559025213\n",
      "Iteration: 5\n",
      "new candidats: tensor([[0.2012, 0.2214],\n",
      "        [0.2382, 0.7983],\n",
      "        [0.4771, 0.7357],\n",
      "        [0.4340, 0.7706],\n",
      "        [0.4321, 0.3388]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4971, 0.4009],\n",
      "        [0.0196, 0.1931],\n",
      "        [0.6450, 0.4246],\n",
      "        [0.4430, 0.6344],\n",
      "        [0.2015, 0.0763]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14301508]\n",
      "Time: 6.326935056131333\n",
      "Iteration: 6\n",
      "new candidats: tensor([[0.2911, 0.9887],\n",
      "        [0.4620, 0.7699],\n",
      "        [0.5578, 0.4073],\n",
      "        [0.9810, 0.4664],\n",
      "        [0.3078, 0.5785]], dtype=torch.float64)\n",
      "new obj: tensor([[1.4156e-03, 6.5417e-02],\n",
      "        [5.1383e-01, 5.5316e-01],\n",
      "        [7.1498e-02, 1.5017e-02],\n",
      "        [4.0155e-03, 6.4298e-06],\n",
      "        [1.2491e-01, 8.0500e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14450717]\n",
      "Time: 2.1570190370548517\n",
      "Iteration: 7\n",
      "new candidats: tensor([[0.7899, 0.3965],\n",
      "        [0.4751, 0.7399],\n",
      "        [0.6196, 0.8626],\n",
      "        [0.8573, 0.0809],\n",
      "        [0.1002, 0.7021]], dtype=torch.float64)\n",
      "new obj: tensor([[1.0518e-01, 4.7461e-04],\n",
      "        [6.3168e-01, 4.4260e-01],\n",
      "        [9.1546e-02, 5.1701e-02],\n",
      "        [2.9410e-01, 6.4394e-01],\n",
      "        [1.9123e-02, 2.5996e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14466846]\n",
      "Time: 2.366644190857187\n",
      "Iteration: 8\n",
      "new candidats: tensor([[0.8114, 0.4729],\n",
      "        [0.4751, 0.7399],\n",
      "        [0.2250, 0.7740],\n",
      "        [0.4771, 0.7357],\n",
      "        [0.5578, 0.4073]], dtype=torch.float64)\n",
      "new obj: tensor([[1.9038e-02, 2.0519e-04],\n",
      "        [6.3168e-01, 4.4260e-01],\n",
      "        [2.0211e-02, 1.5251e-01],\n",
      "        [6.4504e-01, 4.2463e-01],\n",
      "        [7.1498e-02, 1.5017e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14466846]\n",
      "Time: 7.801527015166357\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration: 9\n",
      "new candidats: tensor([[0.4771, 0.7357],\n",
      "        [0.8641, 0.0222],\n",
      "        [0.5333, 0.8334],\n",
      "        [0.1205, 0.4788],\n",
      "        [0.7395, 0.8798]], dtype=torch.float64)\n",
      "new obj: tensor([[0.6450, 0.4246],\n",
      "        [0.1187, 0.2006],\n",
      "        [0.2728, 0.2724],\n",
      "        [0.1749, 0.1834],\n",
      "        [0.0079, 0.0016]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14466846]\n",
      "Time: 4.236121251014993\n",
      "Iteration: 10\n",
      "new candidats: tensor([[0.8573, 0.0809],\n",
      "        [0.5274, 0.1999],\n",
      "        [0.8826, 0.1583],\n",
      "        [0.0455, 0.9496],\n",
      "        [0.8998, 0.1469]], dtype=torch.float64)\n",
      "new obj: tensor([[2.9410e-01, 6.4394e-01],\n",
      "        [1.4799e-01, 3.6586e-02],\n",
      "        [4.5756e-01, 2.8710e-01],\n",
      "        [3.3120e-04, 8.6824e-04],\n",
      "        [3.7052e-01, 2.7473e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14466846]\n",
      "Time: 10.047079134965315\n",
      "Iteration: 11\n",
      "new candidats: tensor([[0.2077, 0.2622],\n",
      "        [0.8095, 0.1080],\n",
      "        [0.0943, 0.2688],\n",
      "        [0.4340, 0.7706],\n",
      "        [0.6932, 0.8985]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4761, 0.3759],\n",
      "        [0.4609, 0.4985],\n",
      "        [0.4098, 0.4679],\n",
      "        [0.4430, 0.6344],\n",
      "        [0.0152, 0.0059]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14466846]\n",
      "Time: 6.855073584010825\n",
      "Iteration: 12\n",
      "new candidats: tensor([[0.3751, 0.9450],\n",
      "        [0.1766, 0.7716],\n",
      "        [0.5116, 0.7038],\n",
      "        [0.4751, 0.7399],\n",
      "        [0.4771, 0.7357]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0163, 0.2373],\n",
      "        [0.0113, 0.0628],\n",
      "        [0.7010, 0.2382],\n",
      "        [0.6317, 0.4426],\n",
      "        [0.6450, 0.4246]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14466846]\n",
      "Time: 6.120416118064895\n",
      "Iteration: 13\n",
      "new candidats: tensor([[0.7742, 0.9061],\n",
      "        [0.9932, 0.2026],\n",
      "        [0.4751, 0.7399],\n",
      "        [0.4771, 0.7357],\n",
      "        [0.8830, 0.5025]], dtype=torch.float64)\n",
      "new obj: tensor([[1.9642e-03, 3.6492e-04],\n",
      "        [1.0854e-01, 1.4281e-03],\n",
      "        [6.3168e-01, 4.4260e-01],\n",
      "        [6.4504e-01, 4.2463e-01],\n",
      "        [5.6379e-03, 4.1199e-05]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14466846]\n",
      "Time: 5.131683585932478\n",
      "Iteration: 14\n",
      "new candidats: tensor([[0.7964, 0.8184],\n",
      "        [0.4340, 0.7706],\n",
      "        [0.3743, 0.6443],\n",
      "        [0.4751, 0.7399],\n",
      "        [0.7395, 0.8798]], dtype=torch.float64)\n",
      "new obj: tensor([[4.3465e-03, 2.7246e-04],\n",
      "        [4.4303e-01, 6.3442e-01],\n",
      "        [3.0112e-01, 2.1493e-01],\n",
      "        [6.3168e-01, 4.4260e-01],\n",
      "        [7.9415e-03, 1.6071e-03]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14466846]\n",
      "Time: 2.490902456920594\n",
      "Iteration: 15\n",
      "new candidats: tensor([[0.2269, 0.0458],\n",
      "        [0.8273, 0.7453],\n",
      "        [0.8900, 0.1078],\n",
      "        [0.8517, 0.0124],\n",
      "        [0.4751, 0.7399]], dtype=torch.float64)\n",
      "new obj: tensor([[3.6804e-01, 2.7304e-01],\n",
      "        [3.0710e-03, 7.4772e-05],\n",
      "        [3.0643e-01, 5.0259e-01],\n",
      "        [1.0706e-01, 1.5108e-01],\n",
      "        [6.3168e-01, 4.4260e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14466846]\n",
      "Time: 2.4250446939840913\n",
      "Iteration: 16\n",
      "new candidats: tensor([[0.4751, 0.7399],\n",
      "        [0.3224, 0.4525],\n",
      "        [0.0455, 0.9496],\n",
      "        [0.2713, 0.0077],\n",
      "        [0.6633, 0.1722]], dtype=torch.float64)\n",
      "new obj: tensor([[6.3168e-01, 4.4260e-01],\n",
      "        [1.9367e-01, 1.0289e-01],\n",
      "        [3.3120e-04, 8.6824e-04],\n",
      "        [2.9558e-01, 1.8978e-01],\n",
      "        [2.9845e-01, 6.3107e-03]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14466846]\n",
      "Time: 1.8677473079878837\n",
      "Iteration: 1\n",
      "new candidats: tensor([[0.4623, 0.2740],\n",
      "        [0.0029, 0.2535],\n",
      "        [0.2252, 0.1979],\n",
      "        [0.7587, 0.3773],\n",
      "        [0.6288, 0.9983]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1994, 0.0682],\n",
      "        [0.2969, 0.4560],\n",
      "        [0.4960, 0.3700],\n",
      "        [0.1405, 0.0009],\n",
      "        [0.0036, 0.0072]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.06295356]\n",
      "Time: 8.498402388999239\n",
      "Iteration: 2\n",
      "new candidats: tensor([[0.1136, 0.2174],\n",
      "        [0.1646, 0.7294],\n",
      "        [0.0298, 0.0045],\n",
      "        [0.4960, 0.1641],\n",
      "        [0.6608, 0.8668]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4538, 0.4864],\n",
      "        [0.0172, 0.0476],\n",
      "        [0.2159, 0.3039],\n",
      "        [0.1711, 0.0509],\n",
      "        [0.0480, 0.0187]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.06678571]\n",
      "Time: 8.04505476495251\n",
      "Iteration: 3\n",
      "new candidats: tensor([[0.2017, 0.1408],\n",
      "        [0.0029, 0.2535],\n",
      "        [0.7711, 0.2069],\n",
      "        [0.1442, 0.1919],\n",
      "        [0.1778, 0.2278]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4786, 0.3852],\n",
      "        [0.2969, 0.4560],\n",
      "        [0.6783, 0.0216],\n",
      "        [0.4805, 0.4663],\n",
      "        [0.4921, 0.4282]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07004153]\n",
      "Time: 9.650653494056314\n",
      "Iteration: 4\n",
      "new candidats: tensor([[0.2062, 0.1935],\n",
      "        [0.5152, 0.5325],\n",
      "        [0.9854, 0.0852],\n",
      "        [0.1352, 0.3234],\n",
      "        [0.2097, 0.3552]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4995, 0.3963],\n",
      "        [0.2065, 0.0206],\n",
      "        [0.0652, 0.0172],\n",
      "        [0.3922, 0.3919],\n",
      "        [0.3696, 0.2900]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07075208]\n",
      "Time: 8.317688022973016\n",
      "Iteration: 5\n",
      "new candidats: tensor([[0.5168, 0.8630],\n",
      "        [0.4145, 0.3723],\n",
      "        [0.2130, 0.0643],\n",
      "        [0.9286, 0.9746],\n",
      "        [0.1615, 0.2141]], dtype=torch.float64)\n",
      "new obj: tensor([[1.8348e-01, 2.9050e-01],\n",
      "        [1.9646e-01, 7.8339e-02],\n",
      "        [3.9639e-01, 3.0761e-01],\n",
      "        [2.0177e-06, 1.5807e-07],\n",
      "        [4.8961e-01, 4.4917e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07094236]\n",
      "Time: 7.588092489168048\n",
      "Iteration: 6\n",
      "new candidats: tensor([[0.1064, 0.2030],\n",
      "        [0.7206, 0.6606],\n",
      "        [0.1199, 0.6290],\n",
      "        [0.0627, 0.2024],\n",
      "        [0.8465, 0.0944]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4481, 0.4917],\n",
      "        [0.0581, 0.0017],\n",
      "        [0.0466, 0.0518],\n",
      "        [0.3950, 0.4996],\n",
      "        [0.3620, 0.6941]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.09631354]\n",
      "Time: 2.6461111011449248\n",
      "Iteration: 7\n",
      "new candidats: tensor([[0.8254, 0.0697],\n",
      "        [0.8791, 0.9635],\n",
      "        [0.8249, 0.1513],\n",
      "        [0.8381, 0.1183],\n",
      "        [0.0279, 0.1805]], dtype=torch.float64)\n",
      "new obj: tensor([[2.9323e-01, 5.1658e-01],\n",
      "        [1.7535e-05, 2.0027e-06],\n",
      "        [6.0647e-01, 3.6488e-01],\n",
      "        [4.6919e-01, 6.3654e-01],\n",
      "        [3.4371e-01, 4.8674e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.1272157]\n",
      "Time: 9.943431732011959\n",
      "Iteration: 8\n",
      "new candidats: tensor([[0.8381, 0.1183],\n",
      "        [0.1922, 0.8821],\n",
      "        [0.5697, 0.3513],\n",
      "        [0.2580, 0.9193],\n",
      "        [0.8249, 0.1513]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4692, 0.6365],\n",
      "        [0.0027, 0.0590],\n",
      "        [0.0850, 0.0166],\n",
      "        [0.0041, 0.1259],\n",
      "        [0.6065, 0.3649]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.1272157]\n",
      "Time: 4.8471022001467645\n",
      "Iteration: 9\n",
      "new candidats: tensor([[0.8381, 0.1183],\n",
      "        [0.1646, 0.7294],\n",
      "        [0.0344, 0.1420],\n",
      "        [0.7573, 0.5707],\n",
      "        [0.4136, 0.5979]], dtype=torch.float64)\n",
      "new obj: tensor([[4.6919e-01, 6.3654e-01],\n",
      "        [1.7234e-02, 4.7624e-02],\n",
      "        [3.4024e-01, 4.7187e-01],\n",
      "        [1.3589e-02, 3.2999e-04],\n",
      "        [3.2521e-01, 1.0575e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.1272157]\n",
      "Time: 7.375571734039113\n",
      "Iteration: 10\n",
      "new candidats: tensor([[0.9908, 0.1246],\n",
      "        [0.8507, 0.1344],\n",
      "        [0.1552, 0.6210],\n",
      "        [0.8249, 0.1513],\n",
      "        [0.4387, 0.0237]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0855, 0.0118],\n",
      "        [0.4990, 0.5524],\n",
      "        [0.0545, 0.0569],\n",
      "        [0.6065, 0.3649],\n",
      "        [0.1665, 0.0620]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13050726]\n",
      "Time: 3.4376188658643514\n",
      "Iteration: 11\n",
      "new candidats: tensor([[0.8249, 0.1513],\n",
      "        [0.0602, 0.3082],\n",
      "        [0.1798, 0.4504],\n",
      "        [0.3261, 0.0436],\n",
      "        [0.0519, 0.2293]], dtype=torch.float64)\n",
      "new obj: tensor([[0.6065, 0.3649],\n",
      "        [0.3383, 0.4314],\n",
      "        [0.2273, 0.1965],\n",
      "        [0.3019, 0.1622],\n",
      "        [0.3760, 0.4926]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13050726]\n",
      "Time: 3.39704702491872\n",
      "Iteration: 12\n",
      "new candidats: tensor([[0.7798, 0.0121],\n",
      "        [0.8249, 0.1513],\n",
      "        [0.5573, 0.1217],\n",
      "        [0.2857, 0.0309],\n",
      "        [0.8582, 0.9307]], dtype=torch.float64)\n",
      "new obj: tensor([[1.2215e-01, 5.6241e-02],\n",
      "        [6.0647e-01, 3.6488e-01],\n",
      "        [1.2099e-01, 2.3808e-02],\n",
      "        [3.1908e-01, 1.9552e-01],\n",
      "        [8.2900e-05, 8.5082e-06]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13050726]\n",
      "Time: 2.5006425480823964\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration: 13\n",
      "new candidats: tensor([[0.3391, 0.0143],\n",
      "        [0.0292, 0.2903],\n",
      "        [0.4753, 0.3144],\n",
      "        [0.5976, 0.7855],\n",
      "        [0.8249, 0.1513]], dtype=torch.float64)\n",
      "new obj: tensor([[0.2550, 0.1314],\n",
      "        [0.3135, 0.4422],\n",
      "        [0.1669, 0.0545],\n",
      "        [0.3026, 0.0985],\n",
      "        [0.6065, 0.3649]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13050726]\n",
      "Time: 1.8891845990438014\n",
      "Iteration: 14\n",
      "new candidats: tensor([[0.1393, 0.0222],\n",
      "        [0.9631, 0.1946],\n",
      "        [0.5488, 0.6862],\n",
      "        [0.8249, 0.1513],\n",
      "        [0.7775, 0.4883]], dtype=torch.float64)\n",
      "new obj: tensor([[3.2165e-01, 3.1717e-01],\n",
      "        [1.8525e-01, 9.0840e-03],\n",
      "        [6.2134e-01, 1.2263e-01],\n",
      "        [6.0647e-01, 3.6488e-01],\n",
      "        [1.5027e-02, 3.4376e-04]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13050726]\n",
      "Time: 2.867632556008175\n",
      "Iteration: 15\n",
      "new candidats: tensor([[0.8436, 0.3442],\n",
      "        [0.8249, 0.1513],\n",
      "        [0.2633, 0.1259],\n",
      "        [0.5883, 0.9518],\n",
      "        [0.1932, 0.5093]], dtype=torch.float64)\n",
      "new obj: tensor([[2.2715e-01, 2.2208e-04],\n",
      "        [6.0647e-01, 3.6488e-01],\n",
      "        [4.4401e-01, 2.9260e-01],\n",
      "        [1.9971e-02, 3.7558e-02],\n",
      "        [1.5218e-01, 1.2633e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13050726]\n",
      "Time: 6.834658181993291\n",
      "Iteration: 16\n",
      "new candidats: tensor([[0.6960, 0.5277],\n",
      "        [0.8829, 0.4782],\n",
      "        [0.8249, 0.1513],\n",
      "        [0.0701, 0.1308],\n",
      "        [0.9069, 0.0069]], dtype=torch.float64)\n",
      "new obj: tensor([[3.1182e-02, 1.1893e-03],\n",
      "        [1.0969e-02, 4.9225e-05],\n",
      "        [6.0647e-01, 3.6488e-01],\n",
      "        [3.8142e-01, 4.7097e-01],\n",
      "        [6.1830e-02, 6.4666e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13050726]\n",
      "Time: 5.575466773938388\n",
      "Iteration: 1\n",
      "new candidats: tensor([[0.3876, 0.0627],\n",
      "        [0.0196, 0.2532],\n",
      "        [0.0245, 0.0837],\n",
      "        [0.9190, 0.7710],\n",
      "        [0.1409, 0.4969]], dtype=torch.float64)\n",
      "new obj: tensor([[2.5458e-01, 1.1201e-01],\n",
      "        [3.2129e-01, 4.6751e-01],\n",
      "        [2.8726e-01, 4.1141e-01],\n",
      "        [9.7070e-05, 1.9866e-06],\n",
      "        [1.5912e-01, 1.5620e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.02155804]\n",
      "Time: 8.457406327826902\n",
      "Iteration: 2\n",
      "new candidats: tensor([[0.3934, 0.6384],\n",
      "        [0.1475, 0.2272],\n",
      "        [0.5562, 0.3910],\n",
      "        [0.0895, 0.2206],\n",
      "        [0.1679, 0.1383]], dtype=torch.float64)\n",
      "new obj: tensor([[0.3563, 0.2014],\n",
      "        [0.4786, 0.4596],\n",
      "        [0.0757, 0.0166],\n",
      "        [0.4270, 0.4950],\n",
      "        [0.4707, 0.4229]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.06521782]\n",
      "Time: 7.595223730895668\n",
      "Iteration: 3\n",
      "new candidats: tensor([[0.5086, 0.1928],\n",
      "        [0.1945, 0.1985],\n",
      "        [0.8020, 0.8790],\n",
      "        [0.8702, 0.9956],\n",
      "        [0.2213, 0.2437]], dtype=torch.float64)\n",
      "new obj: tensor([[1.6193e-01, 4.5108e-02],\n",
      "        [4.9980e-01, 4.1192e-01],\n",
      "        [1.4922e-03, 1.6059e-04],\n",
      "        [1.0032e-05, 1.6940e-06],\n",
      "        [4.8544e-01, 3.6668e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.0692649]\n",
      "Time: 7.311542237875983\n",
      "Iteration: 4\n",
      "new candidats: tensor([[0.4334, 0.7215],\n",
      "        [0.1134, 0.2015],\n",
      "        [0.0969, 0.2145],\n",
      "        [0.3327, 0.2054],\n",
      "        [0.1653, 0.9679]], dtype=torch.float64)\n",
      "new obj: tensor([[5.5623e-01, 4.8984e-01],\n",
      "        [4.5524e-01, 4.8835e-01],\n",
      "        [4.3669e-01, 4.9418e-01],\n",
      "        [4.0109e-01, 2.1096e-01],\n",
      "        [3.8146e-04, 1.1170e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.08768647]\n",
      "Time: 4.385486009996384\n",
      "Iteration: 5\n",
      "new candidats: tensor([[0.4466, 0.7468],\n",
      "        [0.9968, 0.2431],\n",
      "        [0.0054, 0.4420],\n",
      "        [0.7152, 0.7606],\n",
      "        [0.4810, 0.7440]], dtype=torch.float64)\n",
      "new obj: tensor([[5.4961e-01, 5.4710e-01],\n",
      "        [9.2192e-02, 1.6763e-04],\n",
      "        [1.4976e-01, 2.2823e-01],\n",
      "        [5.7819e-02, 4.5576e-03],\n",
      "        [6.2871e-01, 4.3239e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.12004809]\n",
      "Time: 5.508900061016902\n",
      "Iteration: 6\n",
      "new candidats: tensor([[0.4431, 0.7724],\n",
      "        [0.9008, 0.4870],\n",
      "        [0.8669, 0.3016],\n",
      "        [0.4616, 0.7157],\n",
      "        [0.4313, 0.8204]], dtype=torch.float64)\n",
      "new obj: tensor([[4.6231e-01, 6.1539e-01],\n",
      "        [7.2572e-03, 3.1970e-05],\n",
      "        [3.3570e-01, 3.5177e-04],\n",
      "        [6.4992e-01, 4.0849e-01],\n",
      "        [2.7004e-01, 6.5356e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14101071]\n",
      "Time: 10.090094052953646\n",
      "Iteration: 7\n",
      "new candidats: tensor([[0.4377, 0.7687],\n",
      "        [0.7971, 0.2083],\n",
      "        [0.3689, 0.9516],\n",
      "        [0.8743, 0.2116],\n",
      "        [0.4616, 0.7157]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4595, 0.6226],\n",
      "        [0.7031, 0.0390],\n",
      "        [0.0128, 0.2114],\n",
      "        [0.5292, 0.0516],\n",
      "        [0.6499, 0.4085]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14237226]\n",
      "Time: 2.324118081945926\n",
      "Iteration: 8\n",
      "new candidats: tensor([[0.9865, 0.4167],\n",
      "        [0.4466, 0.7468],\n",
      "        [0.6531, 0.6236],\n",
      "        [0.4042, 0.7637],\n",
      "        [0.0085, 0.0104]], dtype=torch.float64)\n",
      "new obj: tensor([[1.1884e-02, 7.6625e-06],\n",
      "        [5.4961e-01, 5.4710e-01],\n",
      "        [1.6616e-01, 6.7671e-03],\n",
      "        [3.6671e-01, 6.5721e-01],\n",
      "        [2.0169e-01, 3.0429e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14585191]\n",
      "Time: 2.6372801198158413\n",
      "Iteration: 9\n",
      "new candidats: tensor([[0.4827, 0.6887],\n",
      "        [0.8435, 0.8237],\n",
      "        [0.6861, 0.8826],\n",
      "        [0.4616, 0.7157],\n",
      "        [0.5216, 0.2937]], dtype=torch.float64)\n",
      "new obj: tensor([[6.9458e-01, 2.7066e-01],\n",
      "        [9.1455e-04, 3.8655e-05],\n",
      "        [2.3451e-02, 8.3187e-03],\n",
      "        [6.4992e-01, 4.0849e-01],\n",
      "        [1.3256e-01, 3.5029e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14806518]\n",
      "Time: 3.3006917689926922\n",
      "Iteration: 10\n",
      "new candidats: tensor([[0.1595, 0.3649],\n",
      "        [0.0256, 0.2210],\n",
      "        [0.5797, 0.6853],\n",
      "        [0.4616, 0.7157],\n",
      "        [0.2900, 0.3404]], dtype=torch.float64)\n",
      "new obj: tensor([[0.3488, 0.3221],\n",
      "        [0.3400, 0.4852],\n",
      "        [0.5083, 0.0731],\n",
      "        [0.6499, 0.4085],\n",
      "        [0.3533, 0.2134]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14806518]\n",
      "Time: 1.958290508016944\n",
      "Iteration: 11\n",
      "new candidats: tensor([[0.4940, 0.0864],\n",
      "        [0.0802, 0.6281],\n",
      "        [0.9803, 0.1725],\n",
      "        [0.9840, 0.5504],\n",
      "        [0.4616, 0.7157]], dtype=torch.float64)\n",
      "new obj: tensor([[1.4784e-01, 4.4971e-02],\n",
      "        [4.2348e-02, 5.1470e-02],\n",
      "        [1.3299e-01, 8.2374e-03],\n",
      "        [3.2909e-04, 3.1454e-06],\n",
      "        [6.4992e-01, 4.0849e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14806518]\n",
      "Time: 2.289683684008196\n",
      "Iteration: 12\n",
      "new candidats: tensor([[0.2418, 0.0258],\n",
      "        [0.4616, 0.7157],\n",
      "        [0.0249, 0.4137],\n",
      "        [0.4042, 0.7637],\n",
      "        [0.5152, 0.1000]], dtype=torch.float64)\n",
      "new obj: tensor([[0.3348, 0.2366],\n",
      "        [0.6499, 0.4085],\n",
      "        [0.1926, 0.2754],\n",
      "        [0.3667, 0.6572],\n",
      "        [0.1348, 0.0370]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14806518]\n",
      "Time: 4.5684553070459515\n",
      "Iteration: 13\n",
      "new candidats: tensor([[0.4313, 0.8204],\n",
      "        [0.4042, 0.7637],\n",
      "        [0.1706, 0.7615],\n",
      "        [0.9055, 0.6937],\n",
      "        [0.3441, 0.4678]], dtype=torch.float64)\n",
      "new obj: tensor([[2.7004e-01, 6.5356e-01],\n",
      "        [3.6671e-01, 6.5721e-01],\n",
      "        [1.2158e-02, 5.5382e-02],\n",
      "        [2.3726e-04, 4.9846e-06],\n",
      "        [1.7135e-01, 8.2141e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14806518]\n",
      "Time: 2.1446879680734128\n",
      "Iteration: 14\n",
      "new candidats: tensor([[0.4313, 0.8204],\n",
      "        [0.6953, 0.7247],\n",
      "        [0.4042, 0.7637],\n",
      "        [0.5360, 0.5983],\n",
      "        [0.9183, 0.6127]], dtype=torch.float64)\n",
      "new obj: tensor([[2.7004e-01, 6.5356e-01],\n",
      "        [1.0156e-01, 6.8546e-03],\n",
      "        [3.6671e-01, 6.5721e-01],\n",
      "        [4.0783e-01, 4.0842e-02],\n",
      "        [2.3921e-04, 7.5440e-06]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14806518]\n",
      "Time: 2.328095277072862\n",
      "Iteration: 15\n",
      "new candidats: tensor([[0.4827, 0.6887],\n",
      "        [0.9094, 0.3689],\n",
      "        [0.3889, 0.7579],\n",
      "        [0.4616, 0.7157],\n",
      "        [0.5316, 0.6466]], dtype=torch.float64)\n",
      "new obj: tensor([[6.9458e-01, 2.7066e-01],\n",
      "        [9.3032e-02, 5.2532e-05],\n",
      "        [3.2602e-01, 6.3964e-01],\n",
      "        [6.4992e-01, 4.0849e-01],\n",
      "        [5.8806e-01, 9.3766e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14806518]\n",
      "Time: 2.0673732480499893\n",
      "Iteration: 16\n",
      "new candidats: tensor([[0.4616, 0.7157],\n",
      "        [0.3628, 0.6571],\n",
      "        [0.3845, 0.3730],\n",
      "        [0.3944, 0.3307],\n",
      "        [0.2642, 0.7573]], dtype=torch.float64)\n",
      "new obj: tensor([[0.6499, 0.4085],\n",
      "        [0.2755, 0.2478],\n",
      "        [0.2265, 0.1000],\n",
      "        [0.2523, 0.1084],\n",
      "        [0.0466, 0.2604]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14806518]\n",
      "Time: 1.6070929849520326\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration: 1\n",
      "new candidats: tensor([[0.6479, 0.0742],\n",
      "        [0.1461, 0.0656],\n",
      "        [0.1822, 0.1435],\n",
      "        [0.0054, 0.2737],\n",
      "        [0.1033, 0.2782]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1333, 0.0065],\n",
      "        [0.3848, 0.3711],\n",
      "        [0.4785, 0.4105],\n",
      "        [0.2910, 0.4434],\n",
      "        [0.4122, 0.4569]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.05850906]\n",
      "Time: 6.893033059081063\n",
      "Iteration: 2\n",
      "new candidats: tensor([[0.0919, 0.1877],\n",
      "        [0.1840, 0.1995],\n",
      "        [0.0592, 0.4260],\n",
      "        [0.3924, 0.7242],\n",
      "        [0.8208, 0.8967]], dtype=torch.float64)\n",
      "new obj: tensor([[4.3118e-01, 4.9609e-01],\n",
      "        [4.9839e-01, 4.2507e-01],\n",
      "        [2.0602e-01, 2.6361e-01],\n",
      "        [3.9101e-01, 5.2808e-01],\n",
      "        [5.9867e-04, 6.3730e-05]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07375571]\n",
      "Time: 7.692547106184065\n",
      "Iteration: 3\n",
      "new candidats: tensor([[0.4432, 0.7734],\n",
      "        [0.3844, 0.7008],\n",
      "        [0.9932, 0.9717],\n",
      "        [0.4592, 0.7350],\n",
      "        [0.4380, 0.7919]], dtype=torch.float64)\n",
      "new obj: tensor([[4.5900e-01, 6.1690e-01],\n",
      "        [3.7299e-01, 4.2922e-01],\n",
      "        [2.0350e-07, 1.0564e-08],\n",
      "        [6.1193e-01, 4.7761e-01],\n",
      "        [3.8196e-01, 6.5014e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13328803]\n",
      "Time: 9.431685603922233\n",
      "Iteration: 4\n",
      "new candidats: tensor([[0.4650, 0.5171],\n",
      "        [0.2182, 0.4492],\n",
      "        [0.4961, 0.7162],\n",
      "        [0.4541, 0.7497],\n",
      "        [0.6268, 0.8680]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1828, 0.0306],\n",
      "        [0.2297, 0.1752],\n",
      "        [0.6963, 0.3125],\n",
      "        [0.5621, 0.5345],\n",
      "        [0.0766, 0.0425]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14686017]\n",
      "Time: 3.896531946025789\n",
      "Iteration: 5\n",
      "new candidats: tensor([[0.4592, 0.7350],\n",
      "        [0.5911, 0.7304],\n",
      "        [0.6907, 0.0388],\n",
      "        [0.5765, 0.5193],\n",
      "        [0.6692, 0.6577]], dtype=torch.float64)\n",
      "new obj: tensor([[0.6119, 0.4776],\n",
      "        [0.4434, 0.0889],\n",
      "        [0.1228, 0.0050],\n",
      "        [0.1263, 0.0085],\n",
      "        [0.1552, 0.0072]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14686017]\n",
      "Time: 1.6897006079088897\n",
      "Iteration: 6\n",
      "new candidats: tensor([[0.8298, 0.2397],\n",
      "        [0.4379, 0.7528],\n",
      "        [0.1556, 0.6087],\n",
      "        [0.4182, 0.7995],\n",
      "        [0.8227, 0.3893]], dtype=torch.float64)\n",
      "new obj: tensor([[6.2242e-01, 1.3391e-02],\n",
      "        [5.0755e-01, 5.8480e-01],\n",
      "        [6.1718e-02, 6.2237e-02],\n",
      "        [3.0845e-01, 6.8975e-01],\n",
      "        [1.1623e-01, 2.6825e-04]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15225971]\n",
      "Time: 2.694216634845361\n",
      "Iteration: 7\n",
      "new candidats: tensor([[0.6697, 0.9429],\n",
      "        [0.5009, 0.1597],\n",
      "        [0.4592, 0.7350],\n",
      "        [0.2795, 0.3323],\n",
      "        [0.3098, 0.3228]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0087, 0.0066],\n",
      "        [0.1654, 0.0481],\n",
      "        [0.6119, 0.4776],\n",
      "        [0.3713, 0.2321],\n",
      "        [0.3563, 0.2018]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15225971]\n",
      "Time: 2.0804971451871097\n",
      "Iteration: 8\n",
      "new candidats: tensor([[0.6692, 0.6577],\n",
      "        [0.5907, 0.2481],\n",
      "        [0.9932, 0.9717],\n",
      "        [0.9816, 0.2310],\n",
      "        [0.4434, 0.6745]], dtype=torch.float64)\n",
      "new obj: tensor([[1.5517e-01, 7.1887e-03],\n",
      "        [1.4183e-01, 1.6398e-02],\n",
      "        [2.0350e-07, 1.0564e-08],\n",
      "        [1.2845e-01, 7.2285e-04],\n",
      "        [5.9175e-01, 2.9513e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15225971]\n",
      "Time: 6.956435177009553\n",
      "Iteration: 9\n",
      "new candidats: tensor([[0.2086, 0.4985],\n",
      "        [0.6888, 0.3539],\n",
      "        [0.4592, 0.7350],\n",
      "        [0.0144, 0.4902],\n",
      "        [0.4182, 0.7995]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1653, 0.1303],\n",
      "        [0.1344, 0.0031],\n",
      "        [0.6119, 0.4776],\n",
      "        [0.1134, 0.1678],\n",
      "        [0.3085, 0.6898]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15225971]\n",
      "Time: 1.7027145421598107\n",
      "Iteration: 10\n",
      "new candidats: tensor([[0.4592, 0.7350],\n",
      "        [0.6213, 0.2357],\n",
      "        [0.5829, 0.4013],\n",
      "        [0.4336, 0.0863],\n",
      "        [0.4923, 0.9653]], dtype=torch.float64)\n",
      "new obj: tensor([[0.6119, 0.4776],\n",
      "        [0.1866, 0.0110],\n",
      "        [0.0627, 0.0113],\n",
      "        [0.2155, 0.0815],\n",
      "        [0.0208, 0.1166]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15225971]\n",
      "Time: 1.7995823598466814\n",
      "Iteration: 11\n",
      "new candidats: tensor([[0.2302, 0.5822],\n",
      "        [0.7201, 0.8006],\n",
      "        [0.4592, 0.7350],\n",
      "        [0.1098, 0.5362],\n",
      "        [0.1215, 0.2228]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0888, 0.0739],\n",
      "        [0.0377, 0.0042],\n",
      "        [0.6119, 0.4776],\n",
      "        [0.1100, 0.1196],\n",
      "        [0.4599, 0.4806]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15225971]\n",
      "Time: 1.4300524550490081\n",
      "Iteration: 12\n",
      "new candidats: tensor([[0.4592, 0.7350],\n",
      "        [0.5186, 0.3544],\n",
      "        [0.4367, 0.2964],\n",
      "        [0.0731, 0.1767],\n",
      "        [0.1773, 0.2637]], dtype=torch.float64)\n",
      "new obj: tensor([[0.6119, 0.4776],\n",
      "        [0.1102, 0.0300],\n",
      "        [0.2218, 0.0829],\n",
      "        [0.4061, 0.4966],\n",
      "        [0.4723, 0.4116]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15225971]\n",
      "Time: 1.4227496238891035\n",
      "Iteration: 13\n",
      "new candidats: tensor([[0.5032, 0.8197],\n",
      "        [0.8523, 0.6166],\n",
      "        [0.4726, 0.6244],\n",
      "        [0.4592, 0.7350],\n",
      "        [0.9336, 0.6789]], dtype=torch.float64)\n",
      "new obj: tensor([[3.4311e-01, 4.0369e-01],\n",
      "        [1.3805e-03, 3.1872e-05],\n",
      "        [5.2719e-01, 1.2198e-01],\n",
      "        [6.1193e-01, 4.7761e-01],\n",
      "        [9.3581e-05, 2.7609e-06]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15225971]\n",
      "Time: 1.9151896419934928\n",
      "Iteration: 14\n",
      "new candidats: tensor([[0.5744, 0.0858],\n",
      "        [0.4592, 0.7350],\n",
      "        [0.6195, 0.6300],\n",
      "        [0.7682, 0.2628],\n",
      "        [0.6953, 0.0692]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1023, 0.0177],\n",
      "        [0.6119, 0.4776],\n",
      "        [0.2737, 0.0160],\n",
      "        [0.5547, 0.0020],\n",
      "        [0.1908, 0.0079]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15225971]\n",
      "Time: 2.0955205052159727\n",
      "Iteration: 15\n",
      "new candidats: tensor([[0.2198, 0.9444],\n",
      "        [0.4526, 0.9969],\n",
      "        [0.4592, 0.7350],\n",
      "        [0.7284, 0.5078],\n",
      "        [0.5505, 0.5755]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0012, 0.0490],\n",
      "        [0.0077, 0.0877],\n",
      "        [0.6119, 0.4776],\n",
      "        [0.0175, 0.0007],\n",
      "        [0.3023, 0.0229]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15225971]\n",
      "Time: 1.8514417400583625\n",
      "Iteration: 16\n",
      "new candidats: tensor([[0.6882, 0.1430],\n",
      "        [0.4592, 0.7350],\n",
      "        [0.7856, 0.0232],\n",
      "        [0.3416, 0.5513],\n",
      "        [0.0571, 0.2505]], dtype=torch.float64)\n",
      "new obj: tensor([[0.3429, 0.0066],\n",
      "        [0.6119, 0.4776],\n",
      "        [0.1498, 0.0943],\n",
      "        [0.1493, 0.0693],\n",
      "        [0.3752, 0.4833]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15225971]\n",
      "Time: 1.9230004220735282\n",
      "Iteration: 1\n",
      "new candidats: tensor([[0.5039, 0.2640],\n",
      "        [0.3789, 0.0020],\n",
      "        [0.1716, 0.1705],\n",
      "        [0.1446, 0.1276],\n",
      "        [0.2447, 0.0338]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1569, 0.0451],\n",
      "        [0.2054, 0.0930],\n",
      "        [0.4896, 0.4347],\n",
      "        [0.4506, 0.4368],\n",
      "        [0.3452, 0.2417]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.05562827]\n",
      "Time: 8.7800190129783\n",
      "Iteration: 2\n",
      "new candidats: tensor([[0.0450, 0.1879],\n",
      "        [0.1971, 0.1798],\n",
      "        [0.1740, 0.2034],\n",
      "        [0.1162, 0.1744],\n",
      "        [0.6636, 0.4923]], dtype=torch.float64)\n",
      "new obj: tensor([[0.3696, 0.4952],\n",
      "        [0.4974, 0.4065],\n",
      "        [0.4957, 0.4367],\n",
      "        [0.4542, 0.4829],\n",
      "        [0.0368, 0.0023]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.06863081]\n",
      "Time: 9.958329786080867\n",
      "Iteration: 3\n",
      "new candidats: tensor([[0.2980, 0.4894],\n",
      "        [0.2587, 0.8747],\n",
      "        [0.8042, 0.5376],\n",
      "        [0.0663, 0.2031],\n",
      "        [0.4089, 0.5572]], dtype=torch.float64)\n",
      "new obj: tensor([[1.6561e-01, 9.5025e-02],\n",
      "        [9.8821e-03, 1.9605e-01],\n",
      "        [5.4268e-03, 1.4876e-04],\n",
      "        [3.9978e-01, 4.9985e-01],\n",
      "        [2.2550e-01, 6.0722e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.06977494]\n",
      "Time: 3.3987984410487115\n",
      "Iteration: 4\n",
      "new candidats: tensor([[0.9919, 0.7785],\n",
      "        [0.1529, 0.1973],\n",
      "        [0.7732, 0.1496],\n",
      "        [0.0200, 0.3562],\n",
      "        [0.3851, 0.0501]], dtype=torch.float64)\n",
      "new obj: tensor([[5.8668e-06, 2.0217e-07],\n",
      "        [4.8625e-01, 4.5884e-01],\n",
      "        [6.0263e-01, 1.3281e-01],\n",
      "        [2.4585e-01, 3.5728e-01],\n",
      "        [2.4612e-01, 1.0917e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07048505]\n",
      "Time: 2.65945261484012\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration: 5\n",
      "new candidats: tensor([[0.1752, 0.7896],\n",
      "        [0.0154, 0.8678],\n",
      "        [0.2404, 0.7022],\n",
      "        [0.7732, 0.1496],\n",
      "        [0.9726, 0.1416]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0088, 0.0613],\n",
      "        [0.0012, 0.0022],\n",
      "        [0.0450, 0.1362],\n",
      "        [0.6026, 0.1328],\n",
      "        [0.1334, 0.0245]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07048505]\n",
      "Time: 11.167313107056543\n",
      "Iteration: 6\n",
      "new candidats: tensor([[0.6245, 0.4038],\n",
      "        [0.3099, 0.6290],\n",
      "        [0.0286, 0.7133],\n",
      "        [0.4700, 0.6574],\n",
      "        [0.5084, 0.7592]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0541, 0.0064],\n",
      "        [0.1323, 0.1325],\n",
      "        [0.0129, 0.0186],\n",
      "        [0.6258, 0.2032],\n",
      "        [0.5886, 0.3587]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.08302847]\n",
      "Time: 11.54960565501824\n",
      "Iteration: 7\n",
      "new candidats: tensor([[0.6636, 0.4923],\n",
      "        [0.9667, 0.4073],\n",
      "        [0.5115, 0.6845],\n",
      "        [0.4684, 0.7520],\n",
      "        [0.4635, 0.7264]], dtype=torch.float64)\n",
      "new obj: tensor([[3.6825e-02, 2.2921e-03],\n",
      "        [2.0528e-02, 1.2607e-05],\n",
      "        [6.9503e-01, 1.9538e-01],\n",
      "        [5.8624e-01, 4.9523e-01],\n",
      "        [6.3886e-01, 4.3895e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.10884503]\n",
      "Time: 7.7623454260174185\n",
      "Iteration: 8\n",
      "new candidats: tensor([[0.1550, 0.3122],\n",
      "        [0.7893, 0.4002],\n",
      "        [0.3576, 0.6458],\n",
      "        [0.4408, 0.7870],\n",
      "        [0.2421, 0.5742]], dtype=torch.float64)\n",
      "new obj: tensor([[4.1655e-01, 3.9027e-01],\n",
      "        [9.7879e-02, 4.7088e-04],\n",
      "        [2.4966e-01, 2.0957e-01],\n",
      "        [4.0590e-01, 6.3974e-01],\n",
      "        [9.6353e-02, 7.5705e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13294855]\n",
      "Time: 6.442148953909054\n",
      "Iteration: 9\n",
      "new candidats: tensor([[0.6247, 0.5463],\n",
      "        [0.2469, 0.0414],\n",
      "        [0.4599, 0.7458],\n",
      "        [0.5497, 0.0540],\n",
      "        [0.8845, 0.4353]], dtype=torch.float64)\n",
      "new obj: tensor([[1.1083e-01, 4.6313e-03],\n",
      "        [3.5518e-01, 2.4686e-01],\n",
      "        [5.8661e-01, 5.0713e-01],\n",
      "        [9.3576e-02, 2.1584e-02],\n",
      "        [3.1445e-02, 6.2627e-05]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13511854]\n",
      "Time: 4.702064587036148\n",
      "Iteration: 10\n",
      "new candidats: tensor([[0.4163, 0.7719],\n",
      "        [0.6464, 0.2356],\n",
      "        [0.4607, 0.9871],\n",
      "        [0.1569, 0.2640],\n",
      "        [0.4599, 0.7458]], dtype=torch.float64)\n",
      "new obj: tensor([[0.3853, 0.6660],\n",
      "        [0.2426, 0.0077],\n",
      "        [0.0106, 0.1011],\n",
      "        [0.4641, 0.4322],\n",
      "        [0.5866, 0.5071]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13909414]\n",
      "Time: 1.7737204020377249\n",
      "Iteration: 11\n",
      "new candidats: tensor([[0.5121, 0.1944],\n",
      "        [0.6114, 0.3330],\n",
      "        [0.4274, 0.1362],\n",
      "        [0.4599, 0.7458],\n",
      "        [0.6549, 0.5660]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1590, 0.0434],\n",
      "        [0.0976, 0.0103],\n",
      "        [0.2496, 0.0963],\n",
      "        [0.5866, 0.5071],\n",
      "        [0.0934, 0.0031]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13909414]\n",
      "Time: 1.7891755001619458\n",
      "Iteration: 12\n",
      "new candidats: tensor([[0.9240, 0.4015],\n",
      "        [0.8323, 0.9312],\n",
      "        [0.4599, 0.7458],\n",
      "        [0.4691, 0.6205],\n",
      "        [0.3673, 0.4704]], dtype=torch.float64)\n",
      "new obj: tensor([[4.3067e-02, 3.3056e-05],\n",
      "        [1.9728e-04, 2.6285e-05],\n",
      "        [5.8661e-01, 5.0713e-01],\n",
      "        [5.0851e-01, 1.1751e-01],\n",
      "        [1.6212e-01, 6.9343e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13909414]\n",
      "Time: 2.6798751910682768\n",
      "Iteration: 13\n",
      "new candidats: tensor([[0.1595, 0.8417],\n",
      "        [0.7742, 0.4305],\n",
      "        [0.4599, 0.7458],\n",
      "        [0.0558, 0.9475],\n",
      "        [0.2025, 0.3203]], dtype=torch.float64)\n",
      "new obj: tensor([[3.6273e-03, 3.8254e-02],\n",
      "        [5.2084e-02, 5.2394e-04],\n",
      "        [5.8661e-01, 5.0713e-01],\n",
      "        [3.5848e-04, 1.0923e-03],\n",
      "        [4.1729e-01, 3.3506e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13909414]\n",
      "Time: 2.002843188121915\n",
      "Iteration: 14\n",
      "new candidats: tensor([[0.4599, 0.7458],\n",
      "        [0.0433, 0.8142],\n",
      "        [0.1431, 0.9804],\n",
      "        [0.8700, 0.1482],\n",
      "        [0.7723, 0.7841]], dtype=torch.float64)\n",
      "new obj: tensor([[5.8661e-01, 5.0713e-01],\n",
      "        [3.3036e-03, 5.6332e-03],\n",
      "        [2.6074e-04, 5.3079e-03],\n",
      "        [4.8074e-01, 4.0622e-01],\n",
      "        [1.2188e-02, 6.9150e-04]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13909414]\n",
      "Time: 2.9483584370464087\n",
      "Iteration: 15\n",
      "new candidats: tensor([[0.4647, 0.7091],\n",
      "        [0.4599, 0.7458],\n",
      "        [0.8794, 0.1825],\n",
      "        [0.4468, 0.4395],\n",
      "        [0.7411, 0.9769]], dtype=torch.float64)\n",
      "new obj: tensor([[6.6310e-01, 3.7847e-01],\n",
      "        [5.8661e-01, 5.0713e-01],\n",
      "        [5.0435e-01, 1.5114e-01],\n",
      "        [1.3452e-01, 4.2339e-02],\n",
      "        [8.3424e-04, 4.3644e-04]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.1429088]\n",
      "Time: 3.8528378950431943\n",
      "Iteration: 16\n",
      "new candidats: tensor([[0.7417, 0.2040],\n",
      "        [0.7648, 0.0110],\n",
      "        [0.3537, 0.0039],\n",
      "        [0.4599, 0.7458],\n",
      "        [0.7366, 0.4408]], dtype=torch.float64)\n",
      "new obj: tensor([[0.6029, 0.0095],\n",
      "        [0.1162, 0.0343],\n",
      "        [0.2301, 0.1130],\n",
      "        [0.5866, 0.5071],\n",
      "        [0.0396, 0.0009]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.1429088]\n",
      "Time: 2.0428735439199954\n",
      "Iteration: 1\n",
      "new candidats: tensor([[0.1998, 0.1160],\n",
      "        [0.2407, 0.1849],\n",
      "        [0.0494, 0.9798],\n",
      "        [0.0847, 0.0117],\n",
      "        [0.0186, 0.1343]], dtype=torch.float64)\n",
      "new obj: tensor([[4.5777e-01, 3.7082e-01],\n",
      "        [4.8836e-01, 3.4638e-01],\n",
      "        [1.8877e-04, 5.4653e-04],\n",
      "        [2.7190e-01, 3.2015e-01],\n",
      "        [3.1389e-01, 4.5829e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.04573839]\n",
      "Time: 8.531635896069929\n",
      "Iteration: 2\n",
      "new candidats: tensor([[0.0331, 0.2106],\n",
      "        [0.1594, 0.2167],\n",
      "        [0.1224, 0.1731],\n",
      "        [0.1007, 0.4757],\n",
      "        [0.7667, 0.8597]], dtype=torch.float64)\n",
      "new obj: tensor([[0.3525, 0.4909],\n",
      "        [0.4881, 0.4509],\n",
      "        [0.4596, 0.4788],\n",
      "        [0.1710, 0.1912],\n",
      "        [0.0056, 0.0007]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.06620227]\n",
      "Time: 10.025916327955201\n",
      "Iteration: 3\n",
      "new candidats: tensor([[0.1905, 0.2155],\n",
      "        [0.0875, 0.1784],\n",
      "        [0.5037, 0.9930],\n",
      "        [0.9989, 0.2044],\n",
      "        [0.9955, 0.0052]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4979, 0.4157],\n",
      "        [0.4243, 0.4952],\n",
      "        [0.0096, 0.0635],\n",
      "        [0.0969, 0.0010],\n",
      "        [0.0156, 0.0017]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.06977456]\n",
      "Time: 8.559921951964498\n",
      "Iteration: 4\n",
      "new candidats: tensor([[0.2959, 0.1111],\n",
      "        [0.7667, 0.8597],\n",
      "        [0.2094, 0.2607],\n",
      "        [0.1757, 0.3765],\n",
      "        [0.5123, 0.4565]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4038, 0.2393],\n",
      "        [0.0056, 0.0007],\n",
      "        [0.4770, 0.3746],\n",
      "        [0.3362, 0.2946],\n",
      "        [0.1012, 0.0201]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.06977456]\n",
      "Time: 8.718482048017904\n",
      "Iteration: 5\n",
      "new candidats: tensor([[0.5597, 0.9169],\n",
      "        [0.4570, 0.9077],\n",
      "        [0.8211, 0.8433],\n",
      "        [0.0080, 0.7178],\n",
      "        [0.0875, 0.1784]], dtype=torch.float64)\n",
      "new obj: tensor([[5.5854e-02, 9.8692e-02],\n",
      "        [7.4223e-02, 3.3338e-01],\n",
      "        [1.4677e-03, 9.2272e-05],\n",
      "        [1.1058e-02, 1.6931e-02],\n",
      "        [4.2433e-01, 4.9520e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.06977456]\n",
      "Time: 3.0273172811139375\n",
      "Iteration: 6\n",
      "new candidats: tensor([[3.5021e-01, 7.0769e-02],\n",
      "        [3.8569e-01, 5.7241e-01],\n",
      "        [7.1710e-01, 1.3162e-04],\n",
      "        [8.2775e-01, 9.7662e-01],\n",
      "        [5.8751e-01, 4.2296e-01]], dtype=torch.float64)\n",
      "new obj: tensor([[3.0608e-01, 1.5208e-01],\n",
      "        [2.1878e-01, 7.7402e-02],\n",
      "        [7.8092e-02, 4.4021e-03],\n",
      "        [7.2868e-05, 1.5853e-05],\n",
      "        [5.7489e-02, 9.5439e-03]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.06977456]\n",
      "Time: 6.875978583004326\n",
      "Iteration: 7\n",
      "new candidats: tensor([[0.5177, 0.6458],\n",
      "        [0.6383, 0.2645],\n",
      "        [0.4570, 0.9077],\n",
      "        [0.4787, 0.7308],\n",
      "        [0.3826, 0.0953]], dtype=torch.float64)\n",
      "new obj: tensor([[0.6069, 0.1101],\n",
      "        [0.1968, 0.0084],\n",
      "        [0.0742, 0.3334],\n",
      "        [0.6583, 0.4059],\n",
      "        [0.2874, 0.1285]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.09940335]\n",
      "Time: 8.236445498187095\n",
      "Iteration: 8\n",
      "new candidats: tensor([[0.3426, 0.8571],\n",
      "        [0.4538, 0.7616],\n",
      "        [0.5900, 0.1020],\n",
      "        [0.4148, 0.7929],\n",
      "        [0.5227, 0.7539]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0609, 0.5054],\n",
      "        [0.5247, 0.5642],\n",
      "        [0.1140, 0.0151],\n",
      "        [0.3196, 0.6921],\n",
      "        [0.5931, 0.2974]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13547005]\n",
      "Time: 6.993512389948592\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration: 9\n",
      "new candidats: tensor([[0.4678, 0.7158],\n",
      "        [0.4075, 0.7511],\n",
      "        [0.0829, 0.1444],\n",
      "        [0.4296, 0.7463],\n",
      "        [0.3040, 0.2857]], dtype=torch.float64)\n",
      "new obj: tensor([[0.6636, 0.3930],\n",
      "        [0.4071, 0.6222],\n",
      "        [0.4052, 0.4800],\n",
      "        [0.4972, 0.5823],\n",
      "        [0.3985, 0.2300]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14308333]\n",
      "Time: 6.420607567066327\n",
      "Iteration: 10\n",
      "new candidats: tensor([[0.4808, 0.5015],\n",
      "        [0.4678, 0.7158],\n",
      "        [0.4465, 0.7712],\n",
      "        [0.7313, 0.1447],\n",
      "        [0.2506, 0.3723]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1558, 0.0253],\n",
      "        [0.6636, 0.3930],\n",
      "        [0.4747, 0.6042],\n",
      "        [0.4886, 0.0300],\n",
      "        [0.3343, 0.2295]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.1445624]\n",
      "Time: 2.08751847082749\n",
      "Iteration: 11\n",
      "new candidats: tensor([[0.1470, 0.9309],\n",
      "        [0.2028, 0.7241],\n",
      "        [0.4787, 0.7308],\n",
      "        [0.3704, 0.2934],\n",
      "        [0.6383, 0.2645]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0007, 0.0127],\n",
      "        [0.0244, 0.0881],\n",
      "        [0.6583, 0.4059],\n",
      "        [0.3120, 0.1451],\n",
      "        [0.1968, 0.0084]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.1445624]\n",
      "Time: 1.6170860168058425\n",
      "Iteration: 12\n",
      "new candidats: tensor([[0.7568, 0.6272],\n",
      "        [0.1447, 0.6739],\n",
      "        [0.7400, 0.3326],\n",
      "        [0.4538, 0.7616],\n",
      "        [0.5934, 0.8324]], dtype=torch.float64)\n",
      "new obj: tensor([[2.0983e-02, 4.1085e-04],\n",
      "        [3.0280e-02, 4.0308e-02],\n",
      "        [2.5340e-01, 1.4692e-03],\n",
      "        [5.2472e-01, 5.6423e-01],\n",
      "        [1.8869e-01, 1.0237e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.1445624]\n",
      "Time: 1.745721965096891\n",
      "Iteration: 13\n",
      "new candidats: tensor([[0.4538, 0.7616],\n",
      "        [0.2861, 0.7733],\n",
      "        [0.0482, 0.8697],\n",
      "        [0.3494, 0.7942],\n",
      "        [0.9331, 0.1073]], dtype=torch.float64)\n",
      "new obj: tensor([[0.5247, 0.5642],\n",
      "        [0.0618, 0.3578],\n",
      "        [0.0014, 0.0030],\n",
      "        [0.1490, 0.6170],\n",
      "        [0.1885, 0.1743]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.1445624]\n",
      "Time: 1.5661368060391396\n",
      "Iteration: 14\n",
      "new candidats: tensor([[0.6612, 0.4769],\n",
      "        [0.4787, 0.7308],\n",
      "        [0.5855, 0.7973],\n",
      "        [0.4700, 0.7060],\n",
      "        [0.5548, 0.8295]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0351, 0.0026],\n",
      "        [0.6583, 0.4059],\n",
      "        [0.3034, 0.1253],\n",
      "        [0.6761, 0.3552],\n",
      "        [0.2613, 0.2026]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14623905]\n",
      "Time: 1.9410345419310033\n",
      "Iteration: 15\n",
      "new candidats: tensor([[0.6720, 0.4259],\n",
      "        [0.1040, 0.7444],\n",
      "        [0.8224, 0.1666],\n",
      "        [0.4787, 0.7308],\n",
      "        [0.4775, 0.9867]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0441, 0.0029],\n",
      "        [0.0112, 0.0196],\n",
      "        [0.6496, 0.2478],\n",
      "        [0.6583, 0.4059],\n",
      "        [0.0113, 0.0908]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14623905]\n",
      "Time: 1.6982238998170942\n",
      "Iteration: 16\n",
      "new candidats: tensor([[0.4538, 0.7616],\n",
      "        [0.6014, 0.2276],\n",
      "        [0.5302, 0.7485],\n",
      "        [0.0810, 0.8534],\n",
      "        [0.8166, 0.8897]], dtype=torch.float64)\n",
      "new obj: tensor([[5.2472e-01, 5.6423e-01],\n",
      "        [1.5990e-01, 1.4513e-02],\n",
      "        [5.9771e-01, 2.6361e-01],\n",
      "        [2.0480e-03, 6.1494e-03],\n",
      "        [7.8238e-04, 8.0935e-05]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14623905]\n",
      "Time: 1.8917312731500715\n",
      "Iteration: 1\n",
      "new candidats: tensor([[0.5271, 0.5380],\n",
      "        [0.9345, 0.0671],\n",
      "        [0.1930, 0.3405],\n",
      "        [0.1714, 0.1747],\n",
      "        [0.6964, 0.7393]], dtype=torch.float64)\n",
      "new obj: tensor([[0.2133, 0.0189],\n",
      "        [0.1177, 0.1353],\n",
      "        [0.3904, 0.3233],\n",
      "        [0.4909, 0.4362],\n",
      "        [0.0947, 0.0073]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.05531648]\n",
      "Time: 7.917912479955703\n",
      "Iteration: 2\n",
      "new candidats: tensor([[0.1714, 0.1747],\n",
      "        [0.0716, 0.0252],\n",
      "        [0.9720, 0.8243],\n",
      "        [0.1616, 0.0420],\n",
      "        [0.5113, 0.0837]], dtype=torch.float64)\n",
      "new obj: tensor([[4.9095e-01, 4.3622e-01],\n",
      "        [2.7768e-01, 3.4125e-01],\n",
      "        [6.9241e-06, 2.0005e-07],\n",
      "        [3.5935e-01, 3.2956e-01],\n",
      "        [1.3129e-01, 3.7028e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.05531648]\n",
      "Time: 8.143053109990433\n",
      "Iteration: 3\n",
      "new candidats: tensor([[0.7513, 0.4045],\n",
      "        [0.0671, 0.1947],\n",
      "        [0.1912, 0.1956],\n",
      "        [0.1414, 0.2004],\n",
      "        [0.1811, 0.9921]], dtype=torch.float64)\n",
      "new obj: tensor([[8.3834e-02, 8.9634e-04],\n",
      "        [4.0087e-01, 4.9978e-01],\n",
      "        [4.9939e-01, 4.1600e-01],\n",
      "        [4.7902e-01, 4.6909e-01],\n",
      "        [2.5616e-04, 1.0245e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07015125]\n",
      "Time: 8.880068581085652\n",
      "Iteration: 4\n",
      "new candidats: tensor([[0.9488, 0.2418],\n",
      "        [0.1107, 0.2047],\n",
      "        [0.9533, 0.1012],\n",
      "        [0.8848, 0.6146],\n",
      "        [0.5670, 0.5680]], dtype=torch.float64)\n",
      "new obj: tensor([[2.1255e-01, 1.8117e-03],\n",
      "        [4.5247e-01, 4.8960e-01],\n",
      "        [1.3317e-01, 8.2974e-02],\n",
      "        [5.5306e-04, 1.5516e-05],\n",
      "        [2.5115e-01, 1.5962e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07120936]\n",
      "Time: 3.9372234540060163\n",
      "Iteration: 5\n",
      "new candidats: tensor([[0.0686, 0.2349],\n",
      "        [0.1811, 0.9921],\n",
      "        [0.1414, 0.2004],\n",
      "        [0.5772, 0.4877],\n",
      "        [0.3653, 0.6747]], dtype=torch.float64)\n",
      "new obj: tensor([[3.9686e-01, 4.9245e-01],\n",
      "        [2.5616e-04, 1.0245e-02],\n",
      "        [4.7902e-01, 4.6909e-01],\n",
      "        [8.5483e-02, 8.2409e-03],\n",
      "        [2.9507e-01, 3.1073e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07120936]\n",
      "Time: 4.598163312068209\n",
      "Iteration: 6\n",
      "new candidats: tensor([[0.5459, 0.4700],\n",
      "        [0.2521, 0.8315],\n",
      "        [0.7067, 0.8184],\n",
      "        [0.0731, 0.1907],\n",
      "        [0.1011, 0.2844]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0905, 0.0129],\n",
      "        [0.0169, 0.2253],\n",
      "        [0.0412, 0.0063],\n",
      "        [0.4084, 0.4994],\n",
      "        [0.4048, 0.4519]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07128279]\n",
      "Time: 2.0749174209777266\n",
      "Iteration: 7\n",
      "new candidats: tensor([[0.1882, 0.2423],\n",
      "        [0.1893, 0.3767],\n",
      "        [0.5670, 0.5680],\n",
      "        [0.2706, 0.8863],\n",
      "        [0.7663, 0.1371]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4881, 0.4106],\n",
      "        [0.3379, 0.2833],\n",
      "        [0.2511, 0.0160],\n",
      "        [0.0102, 0.2096],\n",
      "        [0.5513, 0.1321]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07128279]\n",
      "Time: 2.150234896922484\n",
      "Iteration: 8\n",
      "new candidats: tensor([[0.6487, 0.9545],\n",
      "        [0.5198, 0.3968],\n",
      "        [0.7173, 0.9865],\n",
      "        [0.2133, 0.1786],\n",
      "        [0.4983, 0.8012]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0091, 0.0096],\n",
      "        [0.0947, 0.0247],\n",
      "        [0.0011, 0.0008],\n",
      "        [0.4961, 0.3846],\n",
      "        [0.4213, 0.4323]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07128279]\n",
      "Time: 2.411799377994612\n",
      "Iteration: 9\n",
      "new candidats: tensor([[0.1237, 0.3725],\n",
      "        [0.4858, 0.6530],\n",
      "        [0.4822, 0.7327],\n",
      "        [0.2597, 0.9469],\n",
      "        [0.0931, 0.3183]], dtype=torch.float64)\n",
      "new obj: tensor([[0.3205, 0.3326],\n",
      "        [0.6344, 0.1688],\n",
      "        [0.6584, 0.3998],\n",
      "        [0.0023, 0.0893],\n",
      "        [0.3639, 0.4169]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.09971017]\n",
      "Time: 6.011017767013982\n",
      "Iteration: 10\n",
      "new candidats: tensor([[0.0638, 0.4541],\n",
      "        [0.9616, 0.4189],\n",
      "        [0.4872, 0.6960],\n",
      "        [0.4570, 0.7552],\n",
      "        [0.1078, 0.4308]], dtype=torch.float64)\n",
      "new obj: tensor([[1.7692e-01, 2.2299e-01],\n",
      "        [1.7457e-02, 1.3272e-05],\n",
      "        [7.0198e-01, 2.8118e-01],\n",
      "        [5.5275e-01, 5.3972e-01],\n",
      "        [2.3105e-01, 2.5243e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.1231307]\n",
      "Time: 3.0669035059399903\n",
      "Iteration: 11\n",
      "new candidats: tensor([[0.5117, 0.9334],\n",
      "        [0.4427, 0.7375],\n",
      "        [0.4205, 0.7541],\n",
      "        [0.7409, 0.1701],\n",
      "        [0.0906, 0.7840]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0458, 0.1542],\n",
      "        [0.5602, 0.5280],\n",
      "        [0.4466, 0.6193],\n",
      "        [0.5750, 0.0260],\n",
      "        [0.0062, 0.0128]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14102272]\n",
      "Time: 2.3978217388503253\n",
      "Iteration: 12\n",
      "new candidats: tensor([[0.6247, 0.2213],\n",
      "        [0.7173, 0.9865],\n",
      "        [0.6922, 0.2664],\n",
      "        [0.1379, 0.8739],\n",
      "        [0.4096, 0.7881]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1993, 0.0106],\n",
      "        [0.0011, 0.0008],\n",
      "        [0.3369, 0.0038],\n",
      "        [0.0019, 0.0188],\n",
      "        [0.3194, 0.6934]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14736911]\n",
      "Time: 2.060825345106423\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration: 13\n",
      "new candidats: tensor([[0.4427, 0.7375],\n",
      "        [0.0608, 0.5555],\n",
      "        [0.0608, 0.5555],\n",
      "        [0.5508, 0.4336],\n",
      "        [0.8809, 0.4718]], dtype=torch.float64)\n",
      "new obj: tensor([[5.6017e-01, 5.2800e-01],\n",
      "        [8.0844e-02, 1.0300e-01],\n",
      "        [8.0844e-02, 1.0300e-01],\n",
      "        [7.4057e-02, 1.4330e-02],\n",
      "        [1.3207e-02, 5.3516e-05]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14736911]\n",
      "Time: 1.9696173560805619\n",
      "Iteration: 14\n",
      "new candidats: tensor([[0.6248, 0.1213],\n",
      "        [0.4822, 0.7327],\n",
      "        [0.4427, 0.7375],\n",
      "        [0.0314, 0.1859],\n",
      "        [0.8614, 0.5991]], dtype=torch.float64)\n",
      "new obj: tensor([[1.5916e-01, 9.8935e-03],\n",
      "        [6.5843e-01, 3.9985e-01],\n",
      "        [5.6017e-01, 5.2800e-01],\n",
      "        [3.4965e-01, 4.8957e-01],\n",
      "        [1.1020e-03, 2.9366e-05]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14736911]\n",
      "Time: 1.573520089033991\n",
      "Iteration: 15\n",
      "new candidats: tensor([[0.6177, 0.1899],\n",
      "        [0.3101, 0.0151],\n",
      "        [0.9488, 0.2418],\n",
      "        [0.4427, 0.7375],\n",
      "        [0.8930, 0.9213]], dtype=torch.float64)\n",
      "new obj: tensor([[1.8856e-01, 1.1753e-02],\n",
      "        [2.8029e-01, 1.5865e-01],\n",
      "        [2.1255e-01, 1.8117e-03],\n",
      "        [5.6017e-01, 5.2800e-01],\n",
      "        [2.8619e-05, 1.9270e-06]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14736911]\n",
      "Time: 1.678119524847716\n",
      "Iteration: 16\n",
      "new candidats: tensor([[0.4762, 0.2928],\n",
      "        [0.1122, 0.9091],\n",
      "        [0.8940, 0.3354],\n",
      "        [0.4427, 0.7375],\n",
      "        [0.2565, 0.6985]], dtype=torch.float64)\n",
      "new obj: tensor([[1.7563e-01, 5.7101e-02],\n",
      "        [8.8954e-04, 7.0561e-03],\n",
      "        [1.8083e-01, 8.9238e-05],\n",
      "        [5.6017e-01, 5.2800e-01],\n",
      "        [5.7640e-02, 1.6396e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14736911]\n",
      "Time: 1.6386310108937323\n",
      "Iteration: 1\n",
      "new candidats: tensor([[0.0195, 0.3558],\n",
      "        [0.1341, 0.9281],\n",
      "        [0.1551, 0.2440],\n",
      "        [0.2428, 0.1281],\n",
      "        [0.0648, 0.0999]], dtype=torch.float64)\n",
      "new obj: tensor([[0.2456, 0.3575],\n",
      "        [0.0007, 0.0096],\n",
      "        [0.4759, 0.4458],\n",
      "        [0.4581, 0.3227],\n",
      "        [0.3510, 0.4409]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.05440996]\n",
      "Time: 8.494142199167982\n",
      "Iteration: 2\n",
      "new candidats: tensor([[0.1746, 0.1940],\n",
      "        [0.1304, 0.9290],\n",
      "        [0.1096, 0.1944],\n",
      "        [0.0779, 0.4020],\n",
      "        [0.0204, 0.7136]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4958, 0.4359],\n",
      "        [0.0007, 0.0087],\n",
      "        [0.4512, 0.4901],\n",
      "        [0.2493, 0.3001],\n",
      "        [0.0124, 0.0183]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.06830389]\n",
      "Time: 10.090115525992587\n",
      "Iteration: 3\n",
      "new candidats: tensor([[0.0710, 0.2058],\n",
      "        [0.6702, 0.7698],\n",
      "        [0.1498, 0.1901],\n",
      "        [0.9370, 0.7429],\n",
      "        [0.0867, 0.2120]], dtype=torch.float64)\n",
      "new obj: tensor([[4.0587e-01, 4.9978e-01],\n",
      "        [1.2936e-01, 1.7451e-02],\n",
      "        [4.8388e-01, 4.6121e-01],\n",
      "        [5.9819e-05, 1.3693e-06],\n",
      "        [4.2516e-01, 4.9736e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07068745]\n",
      "Time: 7.356038147117943\n",
      "Iteration: 4\n",
      "new candidats: tensor([[0.4130, 0.6075],\n",
      "        [0.0290, 0.3830],\n",
      "        [0.2474, 0.3875],\n",
      "        [0.2035, 0.1878],\n",
      "        [0.0750, 0.5626]], dtype=torch.float64)\n",
      "new obj: tensor([[0.3483, 0.1232],\n",
      "        [0.2282, 0.3221],\n",
      "        [0.3135, 0.2175],\n",
      "        [0.4990, 0.3994],\n",
      "        [0.0796, 0.0968]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07126381]\n",
      "Time: 3.786755733890459\n",
      "Iteration: 5\n",
      "new candidats: tensor([[0.8662, 0.0700],\n",
      "        [0.1250, 0.1986],\n",
      "        [0.1291, 0.7301],\n",
      "        [0.5624, 0.0133],\n",
      "        [0.3234, 0.8592]], dtype=torch.float64)\n",
      "new obj: tensor([[0.2430, 0.5547],\n",
      "        [0.4660, 0.4814],\n",
      "        [0.0147, 0.0282],\n",
      "        [0.0699, 0.0156],\n",
      "        [0.0433, 0.4391]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07206961]\n",
      "Time: 4.960166132077575\n",
      "Iteration: 6\n",
      "new candidats: tensor([[0.9270, 0.0015],\n",
      "        [0.3673, 0.7561],\n",
      "        [0.9142, 0.0260],\n",
      "        [0.9881, 0.0111],\n",
      "        [0.3515, 0.3848]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0440, 0.0308],\n",
      "        [0.2552, 0.6061],\n",
      "        [0.0809, 0.1029],\n",
      "        [0.0202, 0.0032],\n",
      "        [0.2465, 0.1213]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07383854]\n",
      "Time: 5.547767356038094\n",
      "Iteration: 7\n",
      "new candidats: tensor([[0.7985, 0.4767],\n",
      "        [0.8119, 0.1038],\n",
      "        [0.8045, 0.1503],\n",
      "        [0.9270, 0.0015],\n",
      "        [0.1045, 0.2886]], dtype=torch.float64)\n",
      "new obj: tensor([[1.8083e-02, 2.5369e-04],\n",
      "        [4.4191e-01, 5.2227e-01],\n",
      "        [6.2295e-01, 2.7956e-01],\n",
      "        [4.4000e-02, 3.0764e-02],\n",
      "        [4.0439e-01, 4.4658e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.08549115]\n",
      "Time: 5.905651408014819\n",
      "Iteration: 8\n",
      "new candidats: tensor([[0.9471, 0.6772],\n",
      "        [0.8506, 0.0883],\n",
      "        [0.0050, 0.2000],\n",
      "        [0.5761, 0.3309],\n",
      "        [0.8380, 0.1430]], dtype=torch.float64)\n",
      "new obj: tensor([[6.0995e-05, 2.0409e-06],\n",
      "        [3.3230e-01, 6.8137e-01],\n",
      "        [3.1090e-01, 4.7430e-01],\n",
      "        [9.3695e-02, 1.6436e-02],\n",
      "        [5.5659e-01, 4.7002e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.11112855]\n",
      "Time: 6.406341745983809\n",
      "Iteration: 9\n",
      "new candidats: tensor([[0.6197, 0.9303],\n",
      "        [0.7648, 0.9479],\n",
      "        [0.5144, 0.2604],\n",
      "        [0.8839, 0.1191],\n",
      "        [0.8587, 0.1453]], dtype=torch.float64)\n",
      "new obj: tensor([[2.4161e-02, 2.6806e-02],\n",
      "        [9.8192e-04, 3.0336e-04],\n",
      "        [1.4873e-01, 4.0440e-02],\n",
      "        [3.5624e-01, 5.1735e-01],\n",
      "        [5.0967e-01, 4.5749e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.11112855]\n",
      "Time: 6.838615871965885\n",
      "Iteration: 10\n",
      "new candidats: tensor([[0.8380, 0.1430],\n",
      "        [0.7644, 0.8236],\n",
      "        [0.7478, 0.3258],\n",
      "        [0.1626, 0.1532],\n",
      "        [0.8380, 0.1430]], dtype=torch.float64)\n",
      "new obj: tensor([[0.5566, 0.4700],\n",
      "        [0.0100, 0.0009],\n",
      "        [0.2866, 0.0013],\n",
      "        [0.4780, 0.4371],\n",
      "        [0.5566, 0.4700]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.11112855]\n",
      "Time: 6.899836841970682\n",
      "Iteration: 11\n",
      "new candidats: tensor([[0.0185, 0.1595],\n",
      "        [0.2910, 0.6211],\n",
      "        [0.8960, 0.0865],\n",
      "        [0.7133, 0.4834],\n",
      "        [0.8380, 0.1430]], dtype=torch.float64)\n",
      "new obj: tensor([[0.3245, 0.4739],\n",
      "        [0.1069, 0.1076],\n",
      "        [0.2328, 0.4422],\n",
      "        [0.0224, 0.0011],\n",
      "        [0.5566, 0.4700]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.11112855]\n",
      "Time: 5.895530313020572\n",
      "Iteration: 12\n",
      "new candidats: tensor([[0.7681, 0.6824],\n",
      "        [0.8380, 0.1430],\n",
      "        [0.6973, 0.8227],\n",
      "        [0.0689, 0.2412],\n",
      "        [0.9260, 0.1866]], dtype=torch.float64)\n",
      "new obj: tensor([[1.9433e-02, 4.6197e-04],\n",
      "        [5.5659e-01, 4.7002e-01],\n",
      "        [4.7309e-02, 8.2517e-03],\n",
      "        [3.9479e-01, 4.8948e-01],\n",
      "        [3.1415e-01, 4.9271e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.11112855]\n",
      "Time: 6.196190612856299\n",
      "Iteration: 13\n",
      "new candidats: tensor([[0.0290, 0.3830],\n",
      "        [0.3414, 0.0549],\n",
      "        [0.8380, 0.1430],\n",
      "        [0.2953, 0.2079],\n",
      "        [0.8380, 0.1430]], dtype=torch.float64)\n",
      "new obj: tensor([[0.2282, 0.3221],\n",
      "        [0.2994, 0.1531],\n",
      "        [0.5566, 0.4700],\n",
      "        [0.4460, 0.2649],\n",
      "        [0.5566, 0.4700]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.11112855]\n",
      "Time: 5.70095864799805\n",
      "Iteration: 14\n",
      "new candidats: tensor([[0.0421, 0.2337],\n",
      "        [0.0528, 0.0335],\n",
      "        [0.5325, 0.4309],\n",
      "        [0.8380, 0.1430],\n",
      "        [0.5682, 0.2428]], dtype=torch.float64)\n",
      "new obj: tensor([[0.3609, 0.4881],\n",
      "        [0.2697, 0.3523],\n",
      "        [0.0836, 0.0180],\n",
      "        [0.5566, 0.4700],\n",
      "        [0.1333, 0.0220]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.11112855]\n",
      "Time: 4.383377366000786\n",
      "Iteration: 15\n",
      "new candidats: tensor([[0.5577, 0.4480],\n",
      "        [0.2232, 0.6683],\n",
      "        [0.8380, 0.1430],\n",
      "        [0.6019, 0.3594],\n",
      "        [0.0351, 0.8188]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0733, 0.0123],\n",
      "        [0.0465, 0.0857],\n",
      "        [0.5566, 0.4700],\n",
      "        [0.0772, 0.0106],\n",
      "        [0.0030, 0.0050]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.11112855]\n",
      "Time: 6.849119307007641\n",
      "Iteration: 16\n",
      "new candidats: tensor([[0.3444, 0.9714],\n",
      "        [0.2221, 0.1706],\n",
      "        [0.8380, 0.1430],\n",
      "        [0.8380, 0.1430],\n",
      "        [0.9399, 0.1723]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0055, 0.1382],\n",
      "        [0.4916, 0.3705],\n",
      "        [0.5566, 0.4700],\n",
      "        [0.5566, 0.4700],\n",
      "        [0.2536, 0.0488]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.11112855]\n",
      "Time: 6.346144960960373\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
}
