{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "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": 2,
   "id": "85a49017",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\94799\\AppData\\Local\\Programs\\Python\\Python310\\lib\\site-packages\\tqdm\\auto.py:21: TqdmWarning: IProgress not found. Please update jupyter and ipywidgets. See https://ipywidgets.readthedocs.io/en/stable/user_install.html\n",
      "  from .autonotebook import tqdm as notebook_tqdm\n"
     ]
    }
   ],
   "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": 3,
   "id": "47e97107",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "from botorch.models.model import Model\n",
    "from typing import Any, Callable, Optional\n",
    "from botorch.optim.optimize import optimize_acqf, optimize_acqf_list\n",
    "from botorch.acquisition.objective import GenericMCObjective\n",
    "from botorch.utils.multi_objective.scalarization import get_chebyshev_scalarization\n",
    "from botorch.utils.multi_objective.box_decompositions.non_dominated import (\n",
    "    FastNondominatedPartitioning,\n",
    ")\n",
    "from botorch.utils.multi_objective.box_decompositions.dominated import (\n",
    "    DominatedPartitioning,\n",
    ")\n",
    "from EHVI_batch_entropy import qExpectedHypervolumeImprovementEntropy\n",
    "from botorch.utils.sampling import sample_simplex\n",
    "from botorch.acquisition.multi_objective.utils import (\n",
    "    sample_optimal_points,\n",
    "    random_search_optimizer,\n",
    "    compute_sample_box_decomposition\n",
    ")\n",
    "from botorch.sampling.normal import SobolQMCNormalSampler\n",
    "from torch import Tensor\n",
    "from botorch.utils.multi_objective.pareto import is_non_dominated\n",
    "\n",
    "\n",
    "NUM_RESTARTS = 10 \n",
    "RAW_SAMPLES = 512 \n",
    "\n",
    "\n",
    "def optimize_qehvi_and_get_observation(model, train_x, train_obj, sampler, X_test, q):\n",
    "    \"\"\"Optimizes the qEHVI acquisition function, and returns a new candidate and observation.\"\"\"\n",
    "    # partition non-dominated space into disjoint rectangles\n",
    "    with torch.no_grad():\n",
    "        pred = model.posterior(train_x).mean\n",
    "        \n",
    "    partitioning = FastNondominatedPartitioning(\n",
    "        ref_point=torch.tensor(problem.ref_point).reshape(-1).to(**tkwargs),\n",
    "        Y=pred,\n",
    "    )\n",
    "    \n",
    "    acq_func = qExpectedHypervolumeImprovementEntropy(\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": 4,
   "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": 5,
   "id": "b763fe2b",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration: 1\n",
      "new candidats: tensor([[0.4646, 0.8017],\n",
      "        [0.1998, 0.3392],\n",
      "        [0.4646, 0.8017],\n",
      "        [0.0848, 0.0943],\n",
      "        [0.0364, 0.3202]], dtype=torch.float64)\n",
      "new obj: tensor([[0.3943, 0.5688],\n",
      "        [0.3925, 0.3179],\n",
      "        [0.3943, 0.5688],\n",
      "        [0.3684, 0.4337],\n",
      "        [0.2987, 0.4115]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.06698648]\n",
      "Time: 3.2810000000008586\n",
      "Iteration: 2\n",
      "new candidats: tensor([[0.2221, 0.9102],\n",
      "        [0.1204, 0.2498],\n",
      "        [0.5099, 0.8662],\n",
      "        [0.5223, 0.9341],\n",
      "        [0.1849, 0.1801]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0025, 0.0791],\n",
      "        [0.4479, 0.4696],\n",
      "        [0.1755, 0.3074],\n",
      "        [0.0443, 0.1349],\n",
      "        [0.4961, 0.4218]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07880825]\n",
      "Time: 8.609000000000378\n",
      "Iteration: 3\n",
      "new candidats: tensor([[0.1687, 0.2018],\n",
      "        [0.1721, 0.1550],\n",
      "        [0.4326, 0.7274],\n",
      "        [0.1505, 0.7493],\n",
      "        [0.4464, 0.7770]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4939, 0.4427],\n",
      "        [0.4828, 0.4279],\n",
      "        [0.5452, 0.5130],\n",
      "        [0.0125, 0.0380],\n",
      "        [0.4545, 0.6135]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.11307473]\n",
      "Time: 6.25\n",
      "Iteration: 4\n",
      "new candidats: tensor([[0.0057, 0.0562],\n",
      "        [0.4532, 0.7389],\n",
      "        [0.4451, 0.6913],\n",
      "        [0.3100, 0.7222],\n",
      "        [0.0057, 0.0562]], dtype=torch.float64)\n",
      "new obj: tensor([[0.2409, 0.3667],\n",
      "        [0.5876, 0.5063],\n",
      "        [0.6112, 0.3543],\n",
      "        [0.1266, 0.3533],\n",
      "        [0.2409, 0.3667]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.12831535]\n",
      "Time: 7.40599999999904\n",
      "Iteration: 5\n",
      "new candidats: tensor([[0.8697, 0.2961],\n",
      "        [0.4266, 0.7864],\n",
      "        [0.4703, 0.7328],\n",
      "        [0.1059, 0.3087],\n",
      "        [0.8876, 0.7915]], dtype=torch.float64)\n",
      "new obj: tensor([[3.4772e-01, 4.4703e-04],\n",
      "        [3.7174e-01, 6.7083e-01],\n",
      "        [6.4042e-01, 4.3826e-01],\n",
      "        [3.8621e-01, 4.2445e-01],\n",
      "        [2.6932e-04, 6.2874e-06]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14454705]\n",
      "Time: 6.21900000000096\n",
      "Iteration: 6\n",
      "new candidats: tensor([[0.9725, 0.1082],\n",
      "        [0.4816, 0.7057],\n",
      "        [0.6627, 0.6541],\n",
      "        [0.9725, 0.1082],\n",
      "        [0.4703, 0.7328]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1040, 0.0344],\n",
      "        [0.6948, 0.3240],\n",
      "        [0.1702, 0.0081],\n",
      "        [0.1040, 0.0344],\n",
      "        [0.6404, 0.4383]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15013818]\n",
      "Time: 7.32799999999952\n",
      "Iteration: 7\n",
      "new candidats: tensor([[0.4532, 0.7389],\n",
      "        [0.8159, 0.1901],\n",
      "        [0.8159, 0.1901],\n",
      "        [0.4266, 0.7864],\n",
      "        [0.8164, 0.2081]], dtype=torch.float64)\n",
      "new obj: tensor([[0.5876, 0.5063],\n",
      "        [0.6922, 0.1097],\n",
      "        [0.6922, 0.1097],\n",
      "        [0.3717, 0.6708],\n",
      "        [0.6927, 0.0544]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15013818]\n",
      "Time: 8.186999999999898\n",
      "Iteration: 8\n",
      "new candidats: tensor([[0.7516, 0.3236],\n",
      "        [0.7516, 0.3236],\n",
      "        [0.2254, 0.9537],\n",
      "        [0.2254, 0.9537],\n",
      "        [0.2254, 0.9537]], dtype=torch.float64)\n",
      "new obj: tensor([[0.2994, 0.0012],\n",
      "        [0.2994, 0.0012],\n",
      "        [0.0011, 0.0471],\n",
      "        [0.0011, 0.0471],\n",
      "        [0.0011, 0.0471]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15013818]\n",
      "Time: 8.514999999999418\n",
      "Iteration: 9\n",
      "new candidats: tensor([[0.4197, 0.7906],\n",
      "        [0.9419, 0.0815],\n",
      "        [0.4266, 0.7864],\n",
      "        [0.4019, 0.1043],\n",
      "        [0.9419, 0.0815]], dtype=torch.float64)\n",
      "new obj: tensor([[0.3397, 0.6850],\n",
      "        [0.1271, 0.1207],\n",
      "        [0.3717, 0.6708],\n",
      "        [0.2680, 0.1125],\n",
      "        [0.1271, 0.1207]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15163661]\n",
      "Time: 7.031999999999243\n",
      "Iteration: 10\n",
      "new candidats: tensor([[0.5552, 0.0497],\n",
      "        [0.1053, 0.4181],\n",
      "        [0.5552, 0.0497],\n",
      "        [0.5552, 0.0497],\n",
      "        [0.1053, 0.4181]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0892, 0.0199],\n",
      "        [0.2466, 0.2716],\n",
      "        [0.0892, 0.0199],\n",
      "        [0.0892, 0.0199],\n",
      "        [0.2466, 0.2716]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15163661]\n",
      "Time: 8.375\n",
      "Iteration: 11\n",
      "new candidats: tensor([[0.0220, 0.4416],\n",
      "        [0.4532, 0.7389],\n",
      "        [0.0415, 0.4250],\n",
      "        [0.4703, 0.7328],\n",
      "        [0.0220, 0.4416]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1622, 0.2342],\n",
      "        [0.5876, 0.5063],\n",
      "        [0.1939, 0.2628],\n",
      "        [0.6404, 0.4383],\n",
      "        [0.1622, 0.2342]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15163661]\n",
      "Time: 7.796999999998661\n",
      "Iteration: 12\n",
      "new candidats: tensor([[0.6592, 0.3450],\n",
      "        [0.6592, 0.3450],\n",
      "        [0.2356, 0.7667],\n",
      "        [0.2356, 0.7667],\n",
      "        [0.6592, 0.3450]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1187, 0.0050],\n",
      "        [0.1187, 0.0050],\n",
      "        [0.0259, 0.1779],\n",
      "        [0.0259, 0.1779],\n",
      "        [0.1187, 0.0050]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15163661]\n",
      "Time: 8.625\n",
      "Iteration: 13\n",
      "new candidats: tensor([[0.1721, 0.1550],\n",
      "        [0.1721, 0.1550],\n",
      "        [0.9378, 0.9798],\n",
      "        [0.9217, 0.9544],\n",
      "        [0.9378, 0.9798]], dtype=torch.float64)\n",
      "new obj: tensor([[4.8278e-01, 4.2790e-01],\n",
      "        [4.8278e-01, 4.2790e-01],\n",
      "        [1.2391e-06, 9.3341e-08],\n",
      "        [4.3944e-06, 3.0879e-07],\n",
      "        [1.2391e-06, 9.3341e-08]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15163661]\n",
      "Time: 7.5789999999997235\n",
      "Iteration: 14\n",
      "new candidats: tensor([[0.8120, 0.6087],\n",
      "        [0.8120, 0.6087],\n",
      "        [0.3750, 0.1156],\n",
      "        [0.8120, 0.6087],\n",
      "        [0.3750, 0.1156]], dtype=torch.float64)\n",
      "new obj: tensor([[4.2916e-03, 8.6792e-05],\n",
      "        [4.2916e-03, 8.6792e-05],\n",
      "        [3.1190e-01, 1.4293e-01],\n",
      "        [4.2916e-03, 8.6792e-05],\n",
      "        [3.1190e-01, 1.4293e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15163661]\n",
      "Time: 7.485000000000582\n",
      "Iteration: 15\n",
      "new candidats: tensor([[0.9201, 0.7306],\n",
      "        [0.5013, 0.0368],\n",
      "        [0.5013, 0.0368],\n",
      "        [0.9201, 0.7306],\n",
      "        [0.9201, 0.7306]], dtype=torch.float64)\n",
      "new obj: tensor([[1.2139e-04, 2.5064e-06],\n",
      "        [1.1731e-01, 3.5019e-02],\n",
      "        [1.1731e-01, 3.5019e-02],\n",
      "        [1.2139e-04, 2.5064e-06],\n",
      "        [1.2139e-04, 2.5064e-06]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15163661]\n",
      "Time: 6.7960000000002765\n",
      "Iteration: 16\n",
      "new candidats: tensor([[0.2039, 0.7417],\n",
      "        [0.5864, 0.0964],\n",
      "        [0.2039, 0.7417],\n",
      "        [0.5864, 0.0964],\n",
      "        [0.2039, 0.7417]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0208, 0.0966],\n",
      "        [0.1094, 0.0156],\n",
      "        [0.0208, 0.0966],\n",
      "        [0.1094, 0.0156],\n",
      "        [0.0208, 0.0966]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15163661]\n",
      "Time: 6.235000000000582\n",
      "Iteration: 1\n",
      "new candidats: tensor([[0.2974, 0.6149],\n",
      "        [0.4450, 0.6519],\n",
      "        [0.4185, 0.8147],\n",
      "        [0.0308, 0.9925],\n",
      "        [0.4515, 0.9999]], dtype=torch.float64)\n",
      "new obj: tensor([[1.1425e-01, 1.0508e-01],\n",
      "        [5.5438e-01, 2.1791e-01],\n",
      "        [2.6267e-01, 6.8175e-01],\n",
      "        [1.3632e-04, 3.1138e-04],\n",
      "        [7.0096e-03, 8.3144e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.09652434]\n",
      "Time: 6.531000000000859\n",
      "Iteration: 2\n",
      "new candidats: tensor([[0.4791, 0.7173],\n",
      "        [0.0445, 0.1657],\n",
      "        [0.0445, 0.1657],\n",
      "        [0.4716, 0.3765],\n",
      "        [0.4746, 0.7408]], dtype=torch.float64)\n",
      "new obj: tensor([[0.6814, 0.3658],\n",
      "        [0.3642, 0.4887],\n",
      "        [0.3642, 0.4887],\n",
      "        [0.1390, 0.0452],\n",
      "        [0.6287, 0.4464]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13866776]\n",
      "Time: 6.234999999998763\n",
      "Iteration: 3\n",
      "new candidats: tensor([[0.1156, 0.1304],\n",
      "        [0.1139, 0.2663],\n",
      "        [0.8183, 0.7572],\n",
      "        [0.8183, 0.7572],\n",
      "        [0.2190, 0.1295]], dtype=torch.float64)\n",
      "new obj: tensor([[4.3057e-01, 4.5854e-01],\n",
      "        [4.3145e-01, 4.6200e-01],\n",
      "        [3.8340e-03, 1.1060e-04],\n",
      "        [3.8340e-03, 1.1060e-04],\n",
      "        [4.6778e-01, 3.5601e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13866776]\n",
      "Time: 5.54700000000048\n",
      "Iteration: 4\n",
      "new candidats: tensor([[0.1963, 0.0656],\n",
      "        [0.4746, 0.7408],\n",
      "        [0.1963, 0.0656],\n",
      "        [0.9615, 0.7777],\n",
      "        [0.9615, 0.7777]], dtype=torch.float64)\n",
      "new obj: tensor([[3.9887e-01, 3.2686e-01],\n",
      "        [6.2869e-01, 4.4640e-01],\n",
      "        [3.9887e-01, 3.2686e-01],\n",
      "        [1.7790e-05, 4.7148e-07],\n",
      "        [1.7790e-05, 4.7148e-07]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13866776]\n",
      "Time: 13.093000000000757\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration: 5\n",
      "new candidats: tensor([[0.6366, 0.7310],\n",
      "        [0.4746, 0.7408],\n",
      "        [0.8812, 0.0142],\n",
      "        [0.8812, 0.0142],\n",
      "        [0.4238, 0.7730]], dtype=torch.float64)\n",
      "new obj: tensor([[0.2639, 0.0339],\n",
      "        [0.6287, 0.4464],\n",
      "        [0.0906, 0.1323],\n",
      "        [0.0906, 0.1323],\n",
      "        [0.4056, 0.6578]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14518846]\n",
      "Time: 8.390999999999622\n",
      "Iteration: 6\n",
      "new candidats: tensor([[0.3566, 0.7368],\n",
      "        [0.7981, 0.6248],\n",
      "        [0.7942, 0.3241],\n",
      "        [0.4746, 0.7408],\n",
      "        [0.3415, 0.2431]], dtype=torch.float64)\n",
      "new obj: tensor([[2.4412e-01, 5.2667e-01],\n",
      "        [6.8851e-03, 1.2398e-04],\n",
      "        [3.2845e-01, 6.0281e-04],\n",
      "        [6.2869e-01, 4.4640e-01],\n",
      "        [3.8044e-01, 1.9448e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14518846]\n",
      "Time: 18.0\n",
      "Iteration: 7\n",
      "new candidats: tensor([[0.8278, 0.0339],\n",
      "        [0.4283, 0.3518],\n",
      "        [0.8278, 0.0339],\n",
      "        [0.4746, 0.7408],\n",
      "        [0.4477, 0.7801]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1721, 0.2653],\n",
      "        [0.1969, 0.0754],\n",
      "        [0.1721, 0.2653],\n",
      "        [0.6287, 0.4464],\n",
      "        [0.4465, 0.6136]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14524846]\n",
      "Time: 9.375\n",
      "Iteration: 8\n",
      "new candidats: tensor([[0.0172, 0.8551],\n",
      "        [0.3883, 0.3173],\n",
      "        [0.3883, 0.3173],\n",
      "        [0.3883, 0.3173],\n",
      "        [0.0172, 0.8551]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0015, 0.0027],\n",
      "        [0.2706, 0.1186],\n",
      "        [0.2706, 0.1186],\n",
      "        [0.2706, 0.1186],\n",
      "        [0.0015, 0.0027]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14524846]\n",
      "Time: 7.375\n",
      "Iteration: 9\n",
      "new candidats: tensor([[0.9542, 0.2408],\n",
      "        [0.4477, 0.7801],\n",
      "        [0.4746, 0.7408],\n",
      "        [0.4746, 0.7408],\n",
      "        [0.9542, 0.2408]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1967, 0.0015],\n",
      "        [0.4465, 0.6136],\n",
      "        [0.6287, 0.4464],\n",
      "        [0.6287, 0.4464],\n",
      "        [0.1967, 0.0015]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14524846]\n",
      "Time: 15.764999999999418\n",
      "Iteration: 10\n",
      "new candidats: tensor([[0.5839, 0.1254],\n",
      "        [0.5839, 0.1254],\n",
      "        [0.4746, 0.7408],\n",
      "        [0.0156, 0.8880],\n",
      "        [0.0156, 0.8880]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1252, 0.0172],\n",
      "        [0.1252, 0.0172],\n",
      "        [0.6287, 0.4464],\n",
      "        [0.0009, 0.0016],\n",
      "        [0.0009, 0.0016]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14524846]\n",
      "Time: 9.25\n",
      "Iteration: 11\n",
      "new candidats: tensor([[0.2792, 0.0785],\n",
      "        [0.4746, 0.7408],\n",
      "        [0.2792, 0.0785],\n",
      "        [0.7681, 0.7722],\n",
      "        [0.7681, 0.7722]], dtype=torch.float64)\n",
      "new obj: tensor([[0.3844, 0.2406],\n",
      "        [0.6287, 0.4464],\n",
      "        [0.3844, 0.2406],\n",
      "        [0.0150, 0.0008],\n",
      "        [0.0150, 0.0008]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14524846]\n",
      "Time: 16.360000000000582\n",
      "Iteration: 12\n",
      "new candidats: tensor([[0.8072, 0.1231],\n",
      "        [0.4746, 0.7408],\n",
      "        [0.4477, 0.7801],\n",
      "        [0.8072, 0.1231],\n",
      "        [0.4935, 0.7128]], dtype=torch.float64)\n",
      "new obj: tensor([[0.5239, 0.4367],\n",
      "        [0.6287, 0.4464],\n",
      "        [0.4465, 0.6136],\n",
      "        [0.5239, 0.4367],\n",
      "        [0.6992, 0.3111]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14685206]\n",
      "Time: 5.92200000000048\n",
      "Iteration: 13\n",
      "new candidats: tensor([[0.8690, 0.7536],\n",
      "        [0.4746, 0.7408],\n",
      "        [0.9769, 0.0520],\n",
      "        [0.4103, 0.7866],\n",
      "        [0.9769, 0.0520]], dtype=torch.float64)\n",
      "new obj: tensor([[7.1057e-04, 1.4235e-05],\n",
      "        [6.2869e-01, 4.4640e-01],\n",
      "        [4.9207e-02, 1.7669e-02],\n",
      "        [3.2572e-01, 6.9164e-01],\n",
      "        [4.9207e-02, 1.7669e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.149271]\n",
      "Time: 6.265999999999622\n",
      "Iteration: 14\n",
      "new candidats: tensor([[0.4416, 0.1691],\n",
      "        [0.9340, 0.0584],\n",
      "        [0.4746, 0.7408],\n",
      "        [0.9340, 0.0584],\n",
      "        [0.4791, 0.7173]], dtype=torch.float64)\n",
      "new obj: tensor([[0.2392, 0.0879],\n",
      "        [0.1051, 0.1209],\n",
      "        [0.6287, 0.4464],\n",
      "        [0.1051, 0.1209],\n",
      "        [0.6814, 0.3658]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.149271]\n",
      "Time: 9.390999999999622\n",
      "Iteration: 15\n",
      "new candidats: tensor([[0.7710, 0.7637],\n",
      "        [0.0139, 0.0175],\n",
      "        [0.0139, 0.0175],\n",
      "        [0.7613, 0.7122],\n",
      "        [0.4746, 0.7408]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0147, 0.0007],\n",
      "        [0.2138, 0.3170],\n",
      "        [0.2138, 0.3170],\n",
      "        [0.0232, 0.0007],\n",
      "        [0.6287, 0.4464]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.149271]\n",
      "Time: 9.235000000000582\n",
      "Iteration: 16\n",
      "new candidats: tensor([[0.4746, 0.7408],\n",
      "        [0.4477, 0.7801],\n",
      "        [0.7928, 0.1875],\n",
      "        [0.7928, 0.1875],\n",
      "        [0.7928, 0.1875]], dtype=torch.float64)\n",
      "new obj: tensor([[0.6287, 0.4464],\n",
      "        [0.4465, 0.6136],\n",
      "        [0.6989, 0.0795],\n",
      "        [0.6989, 0.0795],\n",
      "        [0.6989, 0.0795]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.149271]\n",
      "Time: 10.546000000000276\n",
      "Iteration: 1\n",
      "new candidats: tensor([[0.3668, 0.7672],\n",
      "        [0.9076, 0.2569],\n",
      "        [0.4275, 0.7280],\n",
      "        [0.6387, 0.1316],\n",
      "        [0.7631, 0.0417]], dtype=torch.float64)\n",
      "new obj: tensor([[0.2364, 0.6308],\n",
      "        [0.3346, 0.0027],\n",
      "        [0.5258, 0.5230],\n",
      "        [0.1933, 0.0084],\n",
      "        [0.1937, 0.0791]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.10410356]\n",
      "Time: 8.015000000001237\n",
      "Iteration: 2\n",
      "new candidats: tensor([[0.5284, 0.7521],\n",
      "        [0.9161, 0.0317],\n",
      "        [0.9161, 0.0317],\n",
      "        [0.4391, 0.7541],\n",
      "        [0.4743, 0.7245]], dtype=torch.float64)\n",
      "new obj: tensor([[0.5898, 0.2747],\n",
      "        [0.0871, 0.1149],\n",
      "        [0.0871, 0.1149],\n",
      "        [0.5076, 0.5857],\n",
      "        [0.6636, 0.4014]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14011479]\n",
      "Time: 9.218999999999141\n",
      "Iteration: 3\n",
      "new candidats: tensor([[0.0576, 0.2265],\n",
      "        [0.4803, 0.2578],\n",
      "        [0.0581, 0.1490],\n",
      "        [0.4776, 0.7083],\n",
      "        [0.4644, 0.7507]], dtype=torch.float64)\n",
      "new obj: tensor([[0.3846, 0.4947],\n",
      "        [0.1832, 0.0585],\n",
      "        [0.3763, 0.4832],\n",
      "        [0.6879, 0.3427],\n",
      "        [0.5824, 0.5055]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14896003]\n",
      "Time: 8.70299999999952\n",
      "Iteration: 4\n",
      "new candidats: tensor([[0.3158, 0.4107],\n",
      "        [0.7413, 0.7660],\n",
      "        [0.3158, 0.4107],\n",
      "        [0.4391, 0.7541],\n",
      "        [0.7413, 0.7660]], dtype=torch.float64)\n",
      "new obj: tensor([[0.2447, 0.1351],\n",
      "        [0.0309, 0.0020],\n",
      "        [0.2447, 0.1351],\n",
      "        [0.5076, 0.5857],\n",
      "        [0.0309, 0.0020]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14896003]\n",
      "Time: 9.46900000000096\n",
      "Iteration: 5\n",
      "new candidats: tensor([[0.4391, 0.7541],\n",
      "        [0.9872, 0.2961],\n",
      "        [0.1992, 0.7833],\n",
      "        [0.9872, 0.2961],\n",
      "        [0.1992, 0.7833]], dtype=torch.float64)\n",
      "new obj: tensor([[5.0758e-01, 5.8565e-01],\n",
      "        [7.6682e-02, 1.9489e-05],\n",
      "        [1.2475e-02, 9.7641e-02],\n",
      "        [7.6682e-02, 1.9489e-05],\n",
      "        [1.2475e-02, 9.7641e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14896003]\n",
      "Time: 8.45299999999952\n",
      "Iteration: 6\n",
      "new candidats: tensor([[0.8680, 0.2668],\n",
      "        [0.8690, 0.7934],\n",
      "        [0.4391, 0.7541],\n",
      "        [0.8680, 0.2668],\n",
      "        [0.4379, 0.7987]], dtype=torch.float64)\n",
      "new obj: tensor([[4.4626e-01, 2.6847e-03],\n",
      "        [5.2180e-04, 1.3759e-05],\n",
      "        [5.0758e-01, 5.8565e-01],\n",
      "        [4.4626e-01, 2.6847e-03],\n",
      "        [3.5757e-01, 6.5250e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15085685]\n",
      "Time: 8.859000000000378\n",
      "Iteration: 7\n",
      "new candidats: tensor([[0.0463, 0.3431],\n",
      "        [0.0463, 0.3431],\n",
      "        [0.4012, 0.7847],\n",
      "        [0.4391, 0.7541],\n",
      "        [0.4391, 0.7541]], dtype=torch.float64)\n",
      "new obj: tensor([[0.2881, 0.3843],\n",
      "        [0.2881, 0.3843],\n",
      "        [0.3043, 0.6936],\n",
      "        [0.5076, 0.5857],\n",
      "        [0.5076, 0.5857]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15110007]\n",
      "Time: 7.0\n",
      "Iteration: 8\n",
      "new candidats: tensor([[0.4012, 0.7847],\n",
      "        [0.4391, 0.7541],\n",
      "        [0.8423, 0.0445],\n",
      "        [0.7210, 0.0994],\n",
      "        [0.8241, 0.0409]], dtype=torch.float64)\n",
      "new obj: tensor([[0.3043, 0.6936],\n",
      "        [0.5076, 0.5857],\n",
      "        [0.1932, 0.3738],\n",
      "        [0.3236, 0.0273],\n",
      "        [0.1947, 0.3050]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15110007]\n",
      "Time: 8.468999999999141\n",
      "Iteration: 9\n",
      "new candidats: tensor([[0.2298, 0.7615],\n",
      "        [0.7464, 0.1688],\n",
      "        [0.7464, 0.1688],\n",
      "        [0.2298, 0.7615],\n",
      "        [0.4391, 0.7541]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0247, 0.1598],\n",
      "        [0.5895, 0.0334],\n",
      "        [0.5895, 0.0334],\n",
      "        [0.0247, 0.1598],\n",
      "        [0.5076, 0.5857]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15110007]\n",
      "Time: 16.96900000000096\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration: 10\n",
      "new candidats: tensor([[0.1481, 0.1946],\n",
      "        [0.8930, 0.5785],\n",
      "        [0.8930, 0.5785],\n",
      "        [0.8944, 0.3415],\n",
      "        [0.1825, 0.1969]], dtype=torch.float64)\n",
      "new obj: tensor([[4.8328e-01, 4.6310e-01],\n",
      "        [7.0599e-04, 1.7860e-05],\n",
      "        [7.0599e-04, 1.7860e-05],\n",
      "        [1.6568e-01, 8.3573e-05],\n",
      "        [4.9803e-01, 4.2680e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15110007]\n",
      "Time: 7.311999999999898\n",
      "Iteration: 11\n",
      "new candidats: tensor([[0.1769, 0.8079],\n",
      "        [0.9774, 0.2143],\n",
      "        [0.9774, 0.2143],\n",
      "        [0.1883, 0.6689],\n",
      "        [0.1769, 0.8079]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0070, 0.0622],\n",
      "        [0.1439, 0.0020],\n",
      "        [0.1439, 0.0020],\n",
      "        [0.0372, 0.0584],\n",
      "        [0.0070, 0.0622]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15110007]\n",
      "Time: 7.82799999999952\n",
      "Iteration: 12\n",
      "new candidats: tensor([[0.9336, 0.8585],\n",
      "        [0.9336, 0.8585],\n",
      "        [0.1568, 0.0982],\n",
      "        [0.1743, 0.2341],\n",
      "        [0.1460, 0.0632]], dtype=torch.float64)\n",
      "new obj: tensor([[1.9163e-05, 5.8578e-07],\n",
      "        [1.9163e-05, 5.8578e-07],\n",
      "        [4.2907e-01, 3.9977e-01],\n",
      "        [4.8875e-01, 4.3011e-01],\n",
      "        [3.8152e-01, 3.6814e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15110007]\n",
      "Time: 6.235000000000582\n",
      "Iteration: 13\n",
      "new candidats: tensor([[0.4391, 0.7541],\n",
      "        [0.8530, 0.0579],\n",
      "        [0.4729, 0.7365],\n",
      "        [0.4743, 0.7245],\n",
      "        [0.8530, 0.0579]], dtype=torch.float64)\n",
      "new obj: tensor([[0.5076, 0.5857],\n",
      "        [0.2235, 0.4903],\n",
      "        [0.6368, 0.4403],\n",
      "        [0.6636, 0.4014],\n",
      "        [0.2235, 0.4903]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15321672]\n",
      "Time: 8.875\n",
      "Iteration: 14\n",
      "new candidats: tensor([[0.1168, 0.0788],\n",
      "        [0.2863, 0.0706],\n",
      "        [0.7392, 0.8575],\n",
      "        [0.1168, 0.0788],\n",
      "        [0.7392, 0.8575]], dtype=torch.float64)\n",
      "new obj: tensor([[0.3816, 0.4049],\n",
      "        [0.3695, 0.2260],\n",
      "        [0.0116, 0.0019],\n",
      "        [0.3816, 0.4049],\n",
      "        [0.0116, 0.0019]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15321672]\n",
      "Time: 6.889999999999418\n",
      "Iteration: 15\n",
      "new candidats: tensor([[0.7193, 0.1205],\n",
      "        [0.2146, 0.9602],\n",
      "        [0.2146, 0.9602],\n",
      "        [0.7193, 0.1205],\n",
      "        [0.7193, 0.1205]], dtype=torch.float64)\n",
      "new obj: tensor([[0.3843, 0.0235],\n",
      "        [0.0008, 0.0351],\n",
      "        [0.0008, 0.0351],\n",
      "        [0.3843, 0.0235],\n",
      "        [0.3843, 0.0235]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15321672]\n",
      "Time: 6.766000000001441\n",
      "Iteration: 16\n",
      "new candidats: tensor([[0.7246, 0.7160],\n",
      "        [0.4743, 0.7245],\n",
      "        [0.4776, 0.7083],\n",
      "        [0.9420, 0.0930],\n",
      "        [0.9420, 0.0930]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0560, 0.0026],\n",
      "        [0.6636, 0.4014],\n",
      "        [0.6879, 0.3427],\n",
      "        [0.1446, 0.1275],\n",
      "        [0.1446, 0.1275]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15321672]\n",
      "Time: 8.703999999999724\n",
      "Iteration: 1\n",
      "new candidats: tensor([[0.1147, 0.2388],\n",
      "        [0.6182, 0.5939],\n",
      "        [0.6111, 0.7125],\n",
      "        [0.1078, 0.0042],\n",
      "        [0.6111, 0.7125]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4480, 0.4786],\n",
      "        [0.2063, 0.0094],\n",
      "        [0.3771, 0.0519],\n",
      "        [0.2784, 0.3041],\n",
      "        [0.3771, 0.0519]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.0580835]\n",
      "Time: 12.593999999999141\n",
      "Iteration: 2\n",
      "new candidats: tensor([[0.0273, 0.2792],\n",
      "        [0.1922, 0.2261],\n",
      "        [0.9482, 0.8378],\n",
      "        [0.9482, 0.8378],\n",
      "        [0.1340, 0.2911]], dtype=torch.float64)\n",
      "new obj: tensor([[3.1836e-01, 4.5182e-01],\n",
      "        [4.9540e-01, 4.1130e-01],\n",
      "        [1.4586e-05, 3.9520e-07],\n",
      "        [1.4586e-05, 3.9520e-07],\n",
      "        [4.2689e-01, 4.2828e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.06710062]\n",
      "Time: 7.29700000000048\n",
      "Iteration: 3\n",
      "new candidats: tensor([[0.1466, 0.2411],\n",
      "        [0.8206, 0.7573],\n",
      "        [0.2257, 0.2416],\n",
      "        [0.5664, 0.7652],\n",
      "        [0.8206, 0.7573]], dtype=torch.float64)\n",
      "new obj: tensor([[4.7239e-01, 4.5496e-01],\n",
      "        [3.5604e-03, 1.0088e-04],\n",
      "        [4.8528e-01, 3.6135e-01],\n",
      "        [4.5591e-01, 1.6555e-01],\n",
      "        [3.5604e-03, 1.0088e-04]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.06816549]\n",
      "Time: 5.109000000000378\n",
      "Iteration: 4\n",
      "new candidats: tensor([[0.1011, 0.3670],\n",
      "        [0.5519, 0.0109],\n",
      "        [0.5519, 0.0109],\n",
      "        [0.1244, 0.1685],\n",
      "        [0.1011, 0.3670]], dtype=torch.float64)\n",
      "new obj: tensor([[0.3122, 0.3486],\n",
      "        [0.0734, 0.0175],\n",
      "        [0.0734, 0.0175],\n",
      "        [0.4598, 0.4759],\n",
      "        [0.3122, 0.3486]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.06841235]\n",
      "Time: 14.265999999999622\n",
      "Iteration: 5\n",
      "new candidats: tensor([[0.5878, 0.4658],\n",
      "        [0.3744, 0.9070],\n",
      "        [0.3744, 0.9070],\n",
      "        [0.5878, 0.4658],\n",
      "        [0.5878, 0.4658]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0643, 0.0077],\n",
      "        [0.0380, 0.3826],\n",
      "        [0.0380, 0.3826],\n",
      "        [0.0643, 0.0077],\n",
      "        [0.0643, 0.0077]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.06841235]\n",
      "Time: 8.92200000000048\n",
      "Iteration: 6\n",
      "new candidats: tensor([[0.0798, 0.2095],\n",
      "        [0.9432, 0.9090],\n",
      "        [0.1824, 0.1996],\n",
      "        [0.9432, 0.9090],\n",
      "        [0.0972, 0.1944]], dtype=torch.float64)\n",
      "new obj: tensor([[4.1693e-01, 4.9884e-01],\n",
      "        [5.2218e-06, 2.1938e-07],\n",
      "        [4.9806e-01, 4.2700e-01],\n",
      "        [5.2218e-06, 2.1938e-07],\n",
      "        [4.3798e-01, 4.9520e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07044847]\n",
      "Time: 8.65599999999904\n",
      "Iteration: 7\n",
      "new candidats: tensor([[0.5291, 0.0361],\n",
      "        [0.2393, 0.7173],\n",
      "        [0.4518, 0.7267],\n",
      "        [0.5291, 0.0361],\n",
      "        [0.2393, 0.7173]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0970, 0.0257],\n",
      "        [0.0404, 0.1491],\n",
      "        [0.6084, 0.4706],\n",
      "        [0.0970, 0.0257],\n",
      "        [0.0404, 0.1491]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.09928331]\n",
      "Time: 6.375\n",
      "Iteration: 8\n",
      "new candidats: tensor([[0.4216, 0.7382],\n",
      "        [0.8700, 0.1115],\n",
      "        [0.4671, 0.6971],\n",
      "        [0.4058, 0.5963],\n",
      "        [0.8700, 0.1115]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4859, 0.5678],\n",
      "        [0.3720, 0.6293],\n",
      "        [0.6722, 0.3322],\n",
      "        [0.3036, 0.1050],\n",
      "        [0.3720, 0.6293]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13355577]\n",
      "Time: 15.578000000001339\n",
      "Iteration: 9\n",
      "new candidats: tensor([[0.1213, 0.6067],\n",
      "        [0.9927, 0.6013],\n",
      "        [0.9316, 0.0052],\n",
      "        [0.9953, 0.1068],\n",
      "        [0.1213, 0.6067]], dtype=torch.float64)\n",
      "new obj: tensor([[5.8851e-02, 6.3399e-02],\n",
      "        [6.3107e-05, 1.5990e-06],\n",
      "        [4.4519e-02, 3.0620e-02],\n",
      "        [6.7505e-02, 1.0171e-02],\n",
      "        [5.8851e-02, 6.3399e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13355577]\n",
      "Time: 6.281999999999243\n",
      "Iteration: 10\n",
      "new candidats: tensor([[0.1066, 0.1047],\n",
      "        [0.8700, 0.1115],\n",
      "        [0.8324, 0.1880],\n",
      "        [0.1196, 0.9532],\n",
      "        [0.8486, 0.1524]], dtype=torch.float64)\n",
      "new obj: tensor([[4.0020e-01, 4.3891e-01],\n",
      "        [3.7202e-01, 6.2934e-01],\n",
      "        [6.6277e-01, 1.3997e-01],\n",
      "        [4.0385e-04, 4.6439e-03],\n",
      "        [5.5793e-01, 4.0437e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13355577]\n",
      "Time: 15.09400000000096\n",
      "Iteration: 11\n",
      "new candidats: tensor([[0.1772, 0.8274],\n",
      "        [0.8700, 0.1115],\n",
      "        [0.8486, 0.1524],\n",
      "        [0.1772, 0.8274],\n",
      "        [0.8341, 0.0880]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0053, 0.0595],\n",
      "        [0.3720, 0.6293],\n",
      "        [0.5579, 0.4044],\n",
      "        [0.0053, 0.0595],\n",
      "        [0.3556, 0.6471]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13572154]\n",
      "Time: 6.765999999999622\n",
      "Iteration: 12\n",
      "new candidats: tensor([[0.8486, 0.1524],\n",
      "        [0.3833, 0.4421],\n",
      "        [0.1329, 0.4378],\n",
      "        [0.8341, 0.0880],\n",
      "        [0.1329, 0.4378]], dtype=torch.float64)\n",
      "new obj: tensor([[0.5579, 0.4044],\n",
      "        [0.1707, 0.0716],\n",
      "        [0.2332, 0.2348],\n",
      "        [0.3556, 0.6471],\n",
      "        [0.2332, 0.2348]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13572154]\n",
      "Time: 6.4210000000002765\n",
      "Iteration: 13\n",
      "new candidats: tensor([[0.4782, 0.7265],\n",
      "        [0.4285, 0.7487],\n",
      "        [0.0835, 0.7393],\n",
      "        [0.0788, 0.2523],\n",
      "        [0.0788, 0.2523]], dtype=torch.float64)\n",
      "new obj: tensor([[0.6660, 0.3954],\n",
      "        [0.4874, 0.5917],\n",
      "        [0.0112, 0.0170],\n",
      "        [0.4022, 0.4827],\n",
      "        [0.4022, 0.4827]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14227618]\n",
      "Time: 7.04700000000048\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration: 14\n",
      "new candidats: tensor([[0.4096, 0.7704],\n",
      "        [0.0127, 0.1664],\n",
      "        [0.4376, 0.7672],\n",
      "        [0.4959, 0.7236],\n",
      "        [0.0127, 0.1664]], dtype=torch.float64)\n",
      "new obj: tensor([[0.3682, 0.6689],\n",
      "        [0.3180, 0.4732],\n",
      "        [0.4642, 0.6197],\n",
      "        [0.6857, 0.3317],\n",
      "        [0.3180, 0.4732]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14949189]\n",
      "Time: 5.375\n",
      "Iteration: 15\n",
      "new candidats: tensor([[0.2094, 0.0725],\n",
      "        [0.4703, 0.7590],\n",
      "        [0.0454, 0.0562],\n",
      "        [0.5016, 0.7190],\n",
      "        [0.0454, 0.0562]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4076, 0.3200],\n",
      "        [0.5669, 0.5040],\n",
      "        [0.2864, 0.3832],\n",
      "        [0.6929, 0.3026],\n",
      "        [0.2864, 0.3832]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15273199]\n",
      "Time: 9.656000000000859\n",
      "Iteration: 16\n",
      "new candidats: tensor([[0.1752, 0.9167],\n",
      "        [0.1752, 0.9167],\n",
      "        [0.8446, 0.1647],\n",
      "        [0.1752, 0.9167],\n",
      "        [0.8446, 0.1647]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0012, 0.0290],\n",
      "        [0.0012, 0.0290],\n",
      "        [0.5981, 0.3019],\n",
      "        [0.0012, 0.0290],\n",
      "        [0.5981, 0.3019]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15273199]\n",
      "Time: 9.953999999999724\n",
      "Iteration: 1\n",
      "new candidats: tensor([[8.7744e-02, 2.6370e-01],\n",
      "        [1.5026e-01, 3.3654e-01],\n",
      "        [5.1085e-04, 8.7338e-01],\n",
      "        [5.1085e-04, 8.7338e-01],\n",
      "        [1.7367e-01, 2.9222e-01]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4060, 0.4734],\n",
      "        [0.3840, 0.3654],\n",
      "        [0.0011, 0.0018],\n",
      "        [0.0011, 0.0018],\n",
      "        [0.4457, 0.3931]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.05027488]\n",
      "Time: 6.15599999999904\n",
      "Iteration: 2\n",
      "new candidats: tensor([[0.1276, 0.1815],\n",
      "        [0.4702, 0.8958],\n",
      "        [0.4673, 0.8623],\n",
      "        [0.4702, 0.8958],\n",
      "        [0.1487, 0.0304]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4663, 0.4777],\n",
      "        [0.0989, 0.3461],\n",
      "        [0.1787, 0.4599],\n",
      "        [0.0989, 0.3461],\n",
      "        [0.3377, 0.3229]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.05964667]\n",
      "Time: 13.436999999999898\n",
      "Iteration: 3\n",
      "new candidats: tensor([[0.1138, 0.1439],\n",
      "        [0.0132, 0.1641],\n",
      "        [0.0094, 0.9165],\n",
      "        [0.0094, 0.9165],\n",
      "        [0.1591, 0.2135]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4381, 0.4693],\n",
      "        [0.3181, 0.4726],\n",
      "        [0.0005, 0.0010],\n",
      "        [0.0005, 0.0010],\n",
      "        [0.4885, 0.4517]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.06477684]\n",
      "Time: 6.781000000000859\n",
      "Iteration: 4\n",
      "new candidats: tensor([[0.1009, 0.0435],\n",
      "        [0.5107, 0.7672],\n",
      "        [0.5270, 0.7816],\n",
      "        [0.5019, 0.8043],\n",
      "        [0.1009, 0.0435]], dtype=torch.float64)\n",
      "new obj: tensor([[0.3256, 0.3638],\n",
      "        [0.5581, 0.3601],\n",
      "        [0.4858, 0.3077],\n",
      "        [0.4078, 0.4166],\n",
      "        [0.3256, 0.3638]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07444639]\n",
      "Time: 15.21900000000096\n",
      "Iteration: 5\n",
      "new candidats: tensor([[0.8683, 0.0897],\n",
      "        [0.8683, 0.0897],\n",
      "        [0.4329, 0.7877],\n",
      "        [0.4841, 0.7251],\n",
      "        [0.4468, 0.7480]], dtype=torch.float64)\n",
      "new obj: tensor([[0.3033, 0.6409],\n",
      "        [0.3033, 0.6409],\n",
      "        [0.3838, 0.6595],\n",
      "        [0.6756, 0.3731],\n",
      "        [0.5471, 0.5499]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.1389832]\n",
      "Time: 8.70299999999952\n",
      "Iteration: 6\n",
      "new candidats: tensor([[3.4969e-01, 4.6338e-01],\n",
      "        [8.6834e-01, 8.9703e-02],\n",
      "        [3.5875e-01, 8.0873e-04],\n",
      "        [3.4969e-01, 4.6338e-01],\n",
      "        [8.6446e-01, 1.0591e-02]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1725, 0.0812],\n",
      "        [0.3033, 0.6409],\n",
      "        [0.2222, 0.1074],\n",
      "        [0.1725, 0.0812],\n",
      "        [0.0959, 0.1358]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.1389832]\n",
      "Time: 9.03099999999904\n",
      "Iteration: 7\n",
      "new candidats: tensor([[0.0009, 0.1255],\n",
      "        [0.4468, 0.7480],\n",
      "        [0.4622, 0.4165],\n",
      "        [0.4573, 0.7213],\n",
      "        [0.0009, 0.1255]], dtype=torch.float64)\n",
      "new obj: tensor([[0.2841, 0.4394],\n",
      "        [0.5471, 0.5499],\n",
      "        [0.1297, 0.0410],\n",
      "        [0.6320, 0.4384],\n",
      "        [0.2841, 0.4394]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14452587]\n",
      "Time: 7.406000000000859\n",
      "Iteration: 8\n",
      "new candidats: tensor([[0.6571, 0.0518],\n",
      "        [0.6571, 0.0518],\n",
      "        [0.6571, 0.0518],\n",
      "        [0.4468, 0.7480],\n",
      "        [0.4329, 0.7877]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1120, 0.0054],\n",
      "        [0.1120, 0.0054],\n",
      "        [0.1120, 0.0054],\n",
      "        [0.5471, 0.5499],\n",
      "        [0.3838, 0.6595]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14452587]\n",
      "Time: 7.781999999999243\n",
      "Iteration: 9\n",
      "new candidats: tensor([[0.7292, 0.1326],\n",
      "        [0.0036, 0.7273],\n",
      "        [0.0036, 0.7273],\n",
      "        [0.8586, 0.1226],\n",
      "        [0.8504, 0.1368]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4484, 0.0327],\n",
      "        [0.0096, 0.0148],\n",
      "        [0.0096, 0.0148],\n",
      "        [0.4391, 0.6231],\n",
      "        [0.5074, 0.5340]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14857352]\n",
      "Time: 8.67200000000048\n",
      "Iteration: 10\n",
      "new candidats: tensor([[0.8803, 0.1349],\n",
      "        [0.4440, 0.9605],\n",
      "        [0.8803, 0.1349],\n",
      "        [0.8531, 0.1253],\n",
      "        [0.4440, 0.9605]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4117, 0.4571],\n",
      "        [0.0203, 0.1754],\n",
      "        [0.4117, 0.4571],\n",
      "        [0.4621, 0.6152],\n",
      "        [0.0203, 0.1754]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.1500734]\n",
      "Time: 8.82799999999952\n",
      "Iteration: 11\n",
      "new candidats: tensor([[0.0847, 0.8175],\n",
      "        [0.7743, 0.0585],\n",
      "        [0.0847, 0.8175],\n",
      "        [0.4163, 0.7982],\n",
      "        [0.7743, 0.0585]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0037, 0.0090],\n",
      "        [0.2552, 0.1586],\n",
      "        [0.0037, 0.0090],\n",
      "        [0.3077, 0.6919],\n",
      "        [0.2552, 0.1586]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15246811]\n",
      "Time: 7.984000000000378\n",
      "Iteration: 12\n",
      "new candidats: tensor([[0.8425, 0.1108],\n",
      "        [0.8425, 0.1108],\n",
      "        [0.5161, 0.8650],\n",
      "        [0.5161, 0.8650],\n",
      "        [0.5161, 0.8650]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4324, 0.6763],\n",
      "        [0.4324, 0.6763],\n",
      "        [0.1778, 0.2892],\n",
      "        [0.1778, 0.2892],\n",
      "        [0.1778, 0.2892]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15633624]\n",
      "Time: 15.203000000001339\n",
      "Iteration: 13\n",
      "new candidats: tensor([[0.5538, 0.8676],\n",
      "        [0.8977, 0.4233],\n",
      "        [0.5538, 0.8676],\n",
      "        [0.5538, 0.8676],\n",
      "        [0.8977, 0.4233]], dtype=torch.float64)\n",
      "new obj: tensor([[1.4901e-01, 1.7078e-01],\n",
      "        [3.6539e-02, 5.1187e-05],\n",
      "        [1.4901e-01, 1.7078e-01],\n",
      "        [1.4901e-01, 1.7078e-01],\n",
      "        [3.6539e-02, 5.1187e-05]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15633624]\n",
      "Time: 9.531999999999243\n",
      "Iteration: 14\n",
      "new candidats: tensor([[0.4468, 0.7480],\n",
      "        [0.1507, 0.7401],\n",
      "        [0.4768, 0.7153],\n",
      "        [0.1295, 0.2131],\n",
      "        [0.1295, 0.2131]], dtype=torch.float64)\n",
      "new obj: tensor([[0.5471, 0.5499],\n",
      "        [0.0141, 0.0382],\n",
      "        [0.6804, 0.3664],\n",
      "        [0.4688, 0.4774],\n",
      "        [0.4688, 0.4774]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15703722]\n",
      "Time: 5.75\n",
      "Iteration: 15\n",
      "new candidats: tensor([[0.2289, 0.9397],\n",
      "        [0.8210, 0.5499],\n",
      "        [0.2289, 0.9397],\n",
      "        [0.8210, 0.5499],\n",
      "        [0.2289, 0.9397]], dtype=torch.float64)\n",
      "new obj: tensor([[1.5336e-03, 6.1448e-02],\n",
      "        [3.6878e-03, 9.8196e-05],\n",
      "        [1.5336e-03, 6.1448e-02],\n",
      "        [3.6878e-03, 9.8196e-05],\n",
      "        [1.5336e-03, 6.1448e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15703722]\n",
      "Time: 8.75\n",
      "Iteration: 16\n",
      "new candidats: tensor([[0.8872, 0.2807],\n",
      "        [0.4468, 0.7480],\n",
      "        [0.4573, 0.7213],\n",
      "        [0.7034, 0.7301],\n",
      "        [0.8872, 0.2807]], dtype=torch.float64)\n",
      "new obj: tensor([[0.3468, 0.0009],\n",
      "        [0.5471, 0.5499],\n",
      "        [0.6320, 0.4384],\n",
      "        [0.0851, 0.0056],\n",
      "        [0.3468, 0.0009]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15703722]\n",
      "Time: 9.171999999998661\n",
      "Iteration: 1\n",
      "new candidats: tensor([[0.9494, 0.2138],\n",
      "        [0.5502, 0.9005],\n",
      "        [0.5780, 0.7156],\n",
      "        [0.8975, 0.1323],\n",
      "        [0.4428, 0.7992]], dtype=torch.float64)\n",
      "new obj: tensor([[0.2276, 0.0073],\n",
      "        [0.0829, 0.1368],\n",
      "        [0.5132, 0.1012],\n",
      "        [0.3472, 0.3617],\n",
      "        [0.3662, 0.6396]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.09046379]\n",
      "Time: 5.8289999999997235\n",
      "Iteration: 2\n",
      "new candidats: tensor([[0.8216, 0.1800],\n",
      "        [0.2887, 0.7748],\n",
      "        [0.7767, 0.1143],\n",
      "        [0.2945, 0.7923],\n",
      "        [0.5146, 0.8070]], dtype=torch.float64)\n",
      "new obj: tensor([[0.6743, 0.1661],\n",
      "        [0.0640, 0.3694],\n",
      "        [0.4791, 0.2306],\n",
      "        [0.0609, 0.4032],\n",
      "        [0.3921, 0.3623]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.09046379]\n",
      "Time: 16.32799999999952\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration: 3\n",
      "new candidats: tensor([[0.4428, 0.7992],\n",
      "        [0.0958, 0.2125],\n",
      "        [0.4831, 0.7544],\n",
      "        [0.0958, 0.2125],\n",
      "        [0.4328, 0.7345]], dtype=torch.float64)\n",
      "new obj: tensor([[0.3662, 0.6396],\n",
      "        [0.4357, 0.4949],\n",
      "        [0.5989, 0.4482],\n",
      "        [0.4357, 0.4949],\n",
      "        [0.5335, 0.5379]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.12326081]\n",
      "Time: 5.313000000000102\n",
      "Iteration: 4\n",
      "new candidats: tensor([[0.0088, 0.1250],\n",
      "        [0.4915, 0.8296],\n",
      "        [0.4533, 0.7252],\n",
      "        [0.0088, 0.1250],\n",
      "        [0.4915, 0.8296]], dtype=torch.float64)\n",
      "new obj: tensor([[0.2951, 0.4447],\n",
      "        [0.3025, 0.4413],\n",
      "        [0.6151, 0.4617],\n",
      "        [0.2951, 0.4447],\n",
      "        [0.3025, 0.4413]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.12805139]\n",
      "Time: 5.671999999998661\n",
      "Iteration: 5\n",
      "new candidats: tensor([[0.4070, 0.7781],\n",
      "        [0.6715, 0.3755],\n",
      "        [0.9031, 0.3633],\n",
      "        [0.4230, 0.7526],\n",
      "        [0.9031, 0.3633]], dtype=torch.float64)\n",
      "new obj: tensor([[3.3953e-01, 6.8353e-01],\n",
      "        [8.7606e-02, 3.6991e-03],\n",
      "        [1.0917e-01, 6.1524e-05],\n",
      "        [4.5905e-01, 6.1159e-01],\n",
      "        [1.0917e-01, 6.1524e-05]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13953742]\n",
      "Time: 15.015000000001237\n",
      "Iteration: 6\n",
      "new candidats: tensor([[0.0958, 0.2125],\n",
      "        [0.5291, 0.8414],\n",
      "        [0.5291, 0.8414],\n",
      "        [0.4533, 0.7252],\n",
      "        [0.1703, 0.1104]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4357, 0.4949],\n",
      "        [0.2478, 0.2797],\n",
      "        [0.2478, 0.2797],\n",
      "        [0.6151, 0.4617],\n",
      "        [0.4473, 0.3988]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13953742]\n",
      "Time: 7.218999999999141\n",
      "Iteration: 7\n",
      "new candidats: tensor([[0.5090, 0.7127],\n",
      "        [0.9699, 0.3246],\n",
      "        [0.9699, 0.3246],\n",
      "        [0.4533, 0.7252],\n",
      "        [0.4789, 0.3720]], dtype=torch.float64)\n",
      "new obj: tensor([[6.9728e-01, 2.6579e-01],\n",
      "        [7.6261e-02, 1.8160e-05],\n",
      "        [7.6261e-02, 1.8160e-05],\n",
      "        [6.1513e-01, 4.6174e-01],\n",
      "        [1.3474e-01, 4.2788e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14320889]\n",
      "Time: 11.46900000000096\n",
      "Iteration: 8\n",
      "new candidats: tensor([[0.5090, 0.7127],\n",
      "        [0.4533, 0.7252],\n",
      "        [0.4533, 0.7252],\n",
      "        [0.0702, 0.4195],\n",
      "        [0.0702, 0.4195]], dtype=torch.float64)\n",
      "new obj: tensor([[0.6973, 0.2658],\n",
      "        [0.6151, 0.4617],\n",
      "        [0.6151, 0.4617],\n",
      "        [0.2218, 0.2738],\n",
      "        [0.2218, 0.2738]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14320889]\n",
      "Time: 8.375\n",
      "Iteration: 9\n",
      "new candidats: tensor([[0.5090, 0.7127],\n",
      "        [0.8612, 0.1986],\n",
      "        [0.5392, 0.7269],\n",
      "        [0.4533, 0.7252],\n",
      "        [0.8612, 0.1986]], dtype=torch.float64)\n",
      "new obj: tensor([[0.6973, 0.2658],\n",
      "        [0.5826, 0.0980],\n",
      "        [0.6290, 0.2044],\n",
      "        [0.6151, 0.4617],\n",
      "        [0.5826, 0.0980]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14320889]\n",
      "Time: 8.17200000000048\n",
      "Iteration: 10\n",
      "new candidats: tensor([[0.1750, 0.2684],\n",
      "        [0.5090, 0.7127],\n",
      "        [0.1750, 0.2684],\n",
      "        [0.4533, 0.7252],\n",
      "        [0.2735, 0.7263]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4679, 0.4108],\n",
      "        [0.6973, 0.2658],\n",
      "        [0.4679, 0.4108],\n",
      "        [0.6151, 0.4617],\n",
      "        [0.0667, 0.2490]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14320889]\n",
      "Time: 7.109000000000378\n",
      "Iteration: 11\n",
      "new candidats: tensor([[0.4533, 0.7252],\n",
      "        [0.9163, 0.3424],\n",
      "        [0.1940, 0.7111],\n",
      "        [0.1915, 0.3414],\n",
      "        [0.9163, 0.3424]], dtype=torch.float64)\n",
      "new obj: tensor([[6.1513e-01, 4.6174e-01],\n",
      "        [1.2962e-01, 5.2423e-05],\n",
      "        [2.5528e-02, 7.2295e-02],\n",
      "        [3.8908e-01, 3.2381e-01],\n",
      "        [1.2962e-01, 5.2423e-05]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14320889]\n",
      "Time: 9.218999999999141\n",
      "Iteration: 12\n",
      "new candidats: tensor([[0.0702, 0.4195],\n",
      "        [0.0702, 0.4195],\n",
      "        [0.4230, 0.7526],\n",
      "        [0.4230, 0.7526],\n",
      "        [0.0702, 0.4195]], dtype=torch.float64)\n",
      "new obj: tensor([[0.2218, 0.2738],\n",
      "        [0.2218, 0.2738],\n",
      "        [0.4591, 0.6116],\n",
      "        [0.4591, 0.6116],\n",
      "        [0.2218, 0.2738]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14320889]\n",
      "Time: 8.906000000000859\n",
      "Iteration: 13\n",
      "new candidats: tensor([[0.8892, 0.2015],\n",
      "        [0.5780, 0.7156],\n",
      "        [0.4533, 0.7252],\n",
      "        [0.0505, 0.3085],\n",
      "        [0.0958, 0.2125]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4716, 0.0656],\n",
      "        [0.5132, 0.1012],\n",
      "        [0.6151, 0.4617],\n",
      "        [0.3264, 0.4296],\n",
      "        [0.4357, 0.4949]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14320889]\n",
      "Time: 8.093999999999141\n",
      "Iteration: 14\n",
      "new candidats: tensor([[0.1100, 0.2261],\n",
      "        [0.2526, 0.7348],\n",
      "        [0.4533, 0.7252],\n",
      "        [0.4533, 0.7252],\n",
      "        [0.1100, 0.2261]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4480, 0.4860],\n",
      "        [0.0444, 0.2003],\n",
      "        [0.6151, 0.4617],\n",
      "        [0.6151, 0.4617],\n",
      "        [0.4480, 0.4860]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14320889]\n",
      "Time: 8.890999999999622\n",
      "Iteration: 15\n",
      "new candidats: tensor([[0.9646, 0.1196],\n",
      "        [0.6785, 0.7878],\n",
      "        [0.4533, 0.7252],\n",
      "        [0.9646, 0.1196],\n",
      "        [0.4070, 0.7781]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1311, 0.0470],\n",
      "        [0.0971, 0.0144],\n",
      "        [0.6151, 0.4617],\n",
      "        [0.1311, 0.0470],\n",
      "        [0.3395, 0.6835]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14320889]\n",
      "Time: 15.061999999999898\n",
      "Iteration: 16\n",
      "new candidats: tensor([[0.4814, 0.1238],\n",
      "        [0.0916, 0.1077],\n",
      "        [0.4533, 0.7252],\n",
      "        [0.0916, 0.1077],\n",
      "        [0.5090, 0.7127]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1761, 0.0561],\n",
      "        [0.3881, 0.4468],\n",
      "        [0.6151, 0.4617],\n",
      "        [0.3881, 0.4468],\n",
      "        [0.6973, 0.2658]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14320889]\n",
      "Time: 6.390999999999622\n",
      "Iteration: 1\n",
      "new candidats: tensor([[0.5034, 0.8072],\n",
      "        [0.0532, 0.2772],\n",
      "        [0.5134, 0.4694],\n",
      "        [0.4674, 0.9314],\n",
      "        [0.0679, 0.0321]], dtype=torch.float64)\n",
      "new obj: tensor([[0.3954, 0.4095],\n",
      "        [0.3545, 0.4625],\n",
      "        [0.1080, 0.0189],\n",
      "        [0.0459, 0.2354],\n",
      "        [0.2826, 0.3515]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.08457136]\n",
      "Time: 5.311999999999898\n",
      "Iteration: 2\n",
      "new candidats: tensor([[0.4780, 0.7549],\n",
      "        [0.3999, 0.8006],\n",
      "        [0.8864, 0.0427],\n",
      "        [0.8818, 0.0926],\n",
      "        [0.4263, 0.7691]], dtype=torch.float64)\n",
      "new obj: tensor([[0.5916, 0.4679],\n",
      "        [0.2590, 0.7014],\n",
      "        [0.1409, 0.2786],\n",
      "        [0.2828, 0.5659],\n",
      "        [0.4249, 0.6464]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.12826405]\n",
      "Time: 8.25\n",
      "Iteration: 3\n",
      "new candidats: tensor([[0.0564, 0.1992],\n",
      "        [0.4443, 0.7539],\n",
      "        [0.8898, 0.7699],\n",
      "        [0.9248, 0.2012],\n",
      "        [0.4903, 0.7356]], dtype=torch.float64)\n",
      "new obj: tensor([[3.8640e-01, 4.9884e-01],\n",
      "        [5.2339e-01, 5.7257e-01],\n",
      "        [2.9715e-04, 6.0574e-06],\n",
      "        [3.2206e-01, 2.9547e-02],\n",
      "        [6.5865e-01, 3.8004e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.1455579]\n",
      "Time: 7.29700000000048\n",
      "Iteration: 4\n",
      "new candidats: tensor([[0.2389, 0.0156],\n",
      "        [0.2103, 0.1814],\n",
      "        [0.7533, 0.9707],\n",
      "        [0.2355, 0.1222],\n",
      "        [0.7533, 0.9707]], dtype=torch.float64)\n",
      "new obj: tensor([[3.2072e-01, 2.2878e-01],\n",
      "        [4.9718e-01, 3.8932e-01],\n",
      "        [7.3239e-04, 3.1887e-04],\n",
      "        [4.5636e-01, 3.2918e-01],\n",
      "        [7.3239e-04, 3.1887e-04]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.1455579]\n",
      "Time: 12.90599999999904\n",
      "Iteration: 5\n",
      "new candidats: tensor([[0.2956, 0.0962],\n",
      "        [0.8826, 0.5244],\n",
      "        [0.2956, 0.0962],\n",
      "        [0.8826, 0.5244],\n",
      "        [0.8826, 0.5244]], dtype=torch.float64)\n",
      "new obj: tensor([[3.8981e-01, 2.3128e-01],\n",
      "        [3.0750e-03, 3.5047e-05],\n",
      "        [3.8981e-01, 2.3128e-01],\n",
      "        [3.0750e-03, 3.5047e-05],\n",
      "        [3.0750e-03, 3.5047e-05]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.1455579]\n",
      "Time: 7.828000000001339\n",
      "Iteration: 6\n",
      "new candidats: tensor([[0.4903, 0.7356],\n",
      "        [0.8058, 0.2607],\n",
      "        [0.8058, 0.2607],\n",
      "        [0.4907, 0.7266],\n",
      "        [0.8058, 0.2607]], dtype=torch.float64)\n",
      "new obj: tensor([[0.6587, 0.3800],\n",
      "        [0.5862, 0.0033],\n",
      "        [0.5862, 0.0033],\n",
      "        [0.6781, 0.3562],\n",
      "        [0.5862, 0.0033]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14818707]\n",
      "Time: 7.688000000000102\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration: 7\n",
      "new candidats: tensor([[0.3428, 0.8815],\n",
      "        [0.0532, 0.2772],\n",
      "        [0.3201, 0.8602],\n",
      "        [0.0169, 0.7348],\n",
      "        [0.0046, 0.4721]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0403, 0.4269],\n",
      "        [0.3545, 0.4625],\n",
      "        [0.0402, 0.4252],\n",
      "        [0.0092, 0.0139],\n",
      "        [0.1230, 0.1879]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14818707]\n",
      "Time: 7.92200000000048\n",
      "Iteration: 8\n",
      "new candidats: tensor([[0.9865, 0.6512],\n",
      "        [0.1215, 0.1868],\n",
      "        [0.1215, 0.1868],\n",
      "        [0.1215, 0.1868],\n",
      "        [0.9865, 0.6512]], dtype=torch.float64)\n",
      "new obj: tensor([[2.6350e-05, 1.0877e-06],\n",
      "        [4.6191e-01, 4.8265e-01],\n",
      "        [4.6191e-01, 4.8265e-01],\n",
      "        [4.6191e-01, 4.8265e-01],\n",
      "        [2.6350e-05, 1.0877e-06]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14818707]\n",
      "Time: 4.95299999999952\n",
      "Iteration: 9\n",
      "new candidats: tensor([[0.2647, 0.0396],\n",
      "        [0.2647, 0.0396],\n",
      "        [0.8878, 0.4537],\n",
      "        [0.8878, 0.4537],\n",
      "        [0.2647, 0.0396]], dtype=torch.float64)\n",
      "new obj: tensor([[3.4396e-01, 2.2567e-01],\n",
      "        [3.4396e-01, 2.2567e-01],\n",
      "        [1.9698e-02, 5.2363e-05],\n",
      "        [1.9698e-02, 5.2363e-05],\n",
      "        [3.4396e-01, 2.2567e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14818707]\n",
      "Time: 9.359000000000378\n",
      "Iteration: 10\n",
      "new candidats: tensor([[0.1295, 0.7174],\n",
      "        [0.4997, 0.7027],\n",
      "        [0.7523, 0.2242],\n",
      "        [0.7523, 0.2242],\n",
      "        [0.1295, 0.7174]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0173, 0.0297],\n",
      "        [0.7066, 0.2676],\n",
      "        [0.6176, 0.0062],\n",
      "        [0.6176, 0.0062],\n",
      "        [0.0173, 0.0297]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14951382]\n",
      "Time: 5.781000000000859\n",
      "Iteration: 11\n",
      "new candidats: tensor([[0.4903, 0.7356],\n",
      "        [0.7558, 0.2991],\n",
      "        [0.0702, 0.7487],\n",
      "        [0.0702, 0.7487],\n",
      "        [0.7558, 0.2991]], dtype=torch.float64)\n",
      "new obj: tensor([[0.6587, 0.3800],\n",
      "        [0.3979, 0.0013],\n",
      "        [0.0095, 0.0143],\n",
      "        [0.0095, 0.0143],\n",
      "        [0.3979, 0.0013]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14951382]\n",
      "Time: 7.70299999999952\n",
      "Iteration: 12\n",
      "new candidats: tensor([[0.6481, 0.1132],\n",
      "        [0.0625, 0.8494],\n",
      "        [0.0625, 0.8494],\n",
      "        [0.6481, 0.1132],\n",
      "        [0.6481, 0.1132]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1885, 0.0072],\n",
      "        [0.0020, 0.0047],\n",
      "        [0.0020, 0.0047],\n",
      "        [0.1885, 0.0072],\n",
      "        [0.1885, 0.0072]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14951382]\n",
      "Time: 8.84400000000096\n",
      "Iteration: 13\n",
      "new candidats: tensor([[0.6624, 0.7617],\n",
      "        [0.6624, 0.7617],\n",
      "        [0.0642, 0.1760],\n",
      "        [0.6624, 0.7617],\n",
      "        [0.0642, 0.1760]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1555, 0.0209],\n",
      "        [0.1555, 0.0209],\n",
      "        [0.3943, 0.4962],\n",
      "        [0.1555, 0.0209],\n",
      "        [0.3943, 0.4962]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14951382]\n",
      "Time: 8.843999999999141\n",
      "Iteration: 14\n",
      "new candidats: tensor([[0.4126, 0.7783],\n",
      "        [0.9910, 0.2875],\n",
      "        [0.9910, 0.2875],\n",
      "        [0.9910, 0.2875],\n",
      "        [0.4419, 0.7506]], dtype=torch.float64)\n",
      "new obj: tensor([[3.5599e-01, 6.8009e-01],\n",
      "        [7.7248e-02, 2.2902e-05],\n",
      "        [7.7248e-02, 2.2902e-05],\n",
      "        [7.7248e-02, 2.2902e-05],\n",
      "        [5.2578e-01, 5.6945e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15302253]\n",
      "Time: 8.110000000000582\n",
      "Iteration: 15\n",
      "new candidats: tensor([[0.2147, 0.3605],\n",
      "        [0.6377, 0.7986],\n",
      "        [0.2147, 0.3605],\n",
      "        [0.6377, 0.7986],\n",
      "        [0.6377, 0.7986]], dtype=torch.float64)\n",
      "new obj: tensor([[0.3615, 0.2789],\n",
      "        [0.1675, 0.0417],\n",
      "        [0.3615, 0.2789],\n",
      "        [0.1675, 0.0417],\n",
      "        [0.1675, 0.0417]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15302253]\n",
      "Time: 6.734000000000378\n",
      "Iteration: 16\n",
      "new candidats: tensor([[0.7882, 0.3431],\n",
      "        [0.3201, 0.8602],\n",
      "        [0.7882, 0.3431],\n",
      "        [0.3201, 0.8602],\n",
      "        [0.4126, 0.7783]], dtype=torch.float64)\n",
      "new obj: tensor([[2.5471e-01, 6.1556e-04],\n",
      "        [4.0220e-02, 4.2520e-01],\n",
      "        [2.5471e-01, 6.1556e-04],\n",
      "        [4.0220e-02, 4.2520e-01],\n",
      "        [3.5599e-01, 6.8009e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15302253]\n",
      "Time: 6.389999999999418\n",
      "Iteration: 1\n",
      "new candidats: tensor([[0.1831, 0.0022],\n",
      "        [0.3801, 0.7805],\n",
      "        [0.4515, 0.8239],\n",
      "        [0.2220, 0.0079],\n",
      "        [0.0759, 0.0045]], dtype=torch.float64)\n",
      "new obj: tensor([[0.3056, 0.2614],\n",
      "        [0.2516, 0.6756],\n",
      "        [0.2905, 0.5962],\n",
      "        [0.3133, 0.2361],\n",
      "        [0.2558, 0.3099]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.06933792]\n",
      "Time: 8.25\n",
      "Iteration: 2\n",
      "new candidats: tensor([[0.4570, 0.6979],\n",
      "        [0.1850, 0.2262],\n",
      "        [0.4203, 0.7648],\n",
      "        [0.1217, 0.2967],\n",
      "        [0.1146, 0.1989]], dtype=torch.float64)\n",
      "new obj: tensor([[0.6479, 0.3570],\n",
      "        [0.4943, 0.4201],\n",
      "        [0.4181, 0.6465],\n",
      "        [0.4120, 0.4302],\n",
      "        [0.4564, 0.4877]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.11755736]\n",
      "Time: 14.375\n",
      "Iteration: 3\n",
      "new candidats: tensor([[0.0729, 0.1616],\n",
      "        [0.0729, 0.1616],\n",
      "        [0.0986, 0.7594],\n",
      "        [0.4619, 0.7612],\n",
      "        [0.4587, 0.7417]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4011, 0.4908],\n",
      "        [0.4011, 0.4908],\n",
      "        [0.0090, 0.0168],\n",
      "        [0.5439, 0.5375],\n",
      "        [0.5948, 0.4990]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14008446]\n",
      "Time: 8.234000000000378\n",
      "Iteration: 4\n",
      "new candidats: tensor([[0.4587, 0.7417],\n",
      "        [0.8150, 0.1235],\n",
      "        [0.7422, 0.1445],\n",
      "        [0.4755, 0.6986],\n",
      "        [0.8150, 0.1235]], dtype=torch.float64)\n",
      "new obj: tensor([[0.5948, 0.4990],\n",
      "        [0.5207, 0.4914],\n",
      "        [0.5199, 0.0477],\n",
      "        [0.6879, 0.3175],\n",
      "        [0.5207, 0.4914]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14394679]\n",
      "Time: 8.843999999999141\n",
      "Iteration: 5\n",
      "new candidats: tensor([[0.8859, 0.1795],\n",
      "        [0.8574, 0.2179],\n",
      "        [0.2787, 0.0098],\n",
      "        [0.2787, 0.0098],\n",
      "        [0.9619, 0.2062]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4754, 0.1531],\n",
      "        [0.5865, 0.0431],\n",
      "        [0.2944, 0.1845],\n",
      "        [0.2944, 0.1845],\n",
      "        [0.1889, 0.0060]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14394679]\n",
      "Time: 12.360000000000582\n",
      "Iteration: 6\n",
      "new candidats: tensor([[0.6672, 0.9133],\n",
      "        [0.6672, 0.9133],\n",
      "        [0.3240, 0.0123],\n",
      "        [0.3240, 0.0123],\n",
      "        [0.6482, 0.9977]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0178, 0.0104],\n",
      "        [0.0178, 0.0104],\n",
      "        [0.2657, 0.1437],\n",
      "        [0.2657, 0.1437],\n",
      "        [0.0028, 0.0046]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14394679]\n",
      "Time: 5.359000000000378\n",
      "Iteration: 7\n",
      "new candidats: tensor([[0.5028, 0.6938],\n",
      "        [0.1114, 0.0884],\n",
      "        [0.1114, 0.0884],\n",
      "        [0.4839, 0.7400],\n",
      "        [0.4587, 0.7417]], dtype=torch.float64)\n",
      "new obj: tensor([[0.7059, 0.2371],\n",
      "        [0.3880, 0.4189],\n",
      "        [0.3880, 0.4189],\n",
      "        [0.6425, 0.4130],\n",
      "        [0.5948, 0.4990]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14690595]\n",
      "Time: 8.515999999999622\n",
      "Iteration: 8\n",
      "new candidats: tensor([[0.4916, 0.0469],\n",
      "        [0.9600, 0.7231],\n",
      "        [0.9600, 0.7231],\n",
      "        [0.4916, 0.0469],\n",
      "        [0.4839, 0.7400]], dtype=torch.float64)\n",
      "new obj: tensor([[1.3072e-01, 4.0434e-02],\n",
      "        [2.9561e-05, 9.0117e-07],\n",
      "        [2.9561e-05, 9.0117e-07],\n",
      "        [1.3072e-01, 4.0434e-02],\n",
      "        [6.4249e-01, 4.1299e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14690595]\n",
      "Time: 7.25\n",
      "Iteration: 9\n",
      "new candidats: tensor([[0.0159, 0.4199],\n",
      "        [0.7936, 0.8825],\n",
      "        [0.7936, 0.8825],\n",
      "        [0.6257, 0.8783],\n",
      "        [0.0159, 0.4199]], dtype=torch.float64)\n",
      "new obj: tensor([[1.7882e-01, 2.6336e-01],\n",
      "        [1.7984e-03, 2.1777e-04],\n",
      "        [1.7984e-03, 2.1777e-04],\n",
      "        [6.4951e-02, 4.0376e-02],\n",
      "        [1.7882e-01, 2.6336e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14690595]\n",
      "Time: 7.311999999999898\n",
      "Iteration: 10\n",
      "new candidats: tensor([[0.2334, 0.4640],\n",
      "        [0.1991, 0.4747],\n",
      "        [0.1991, 0.4747],\n",
      "        [0.8447, 0.8342],\n",
      "        [0.8447, 0.8342]], dtype=torch.float64)\n",
      "new obj: tensor([[2.0756e-01, 1.5047e-01],\n",
      "        [1.9526e-01, 1.5850e-01],\n",
      "        [1.9526e-01, 1.5850e-01],\n",
      "        [7.6755e-04, 3.5411e-05],\n",
      "        [7.6755e-04, 3.5411e-05]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14690595]\n",
      "Time: 7.234999999998763\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration: 11\n",
      "new candidats: tensor([[0.7049, 0.0606],\n",
      "        [0.0330, 0.3492],\n",
      "        [0.7049, 0.0606],\n",
      "        [0.0330, 0.3492],\n",
      "        [0.7049, 0.0606]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1847, 0.0102],\n",
      "        [0.2672, 0.3721],\n",
      "        [0.1847, 0.0102],\n",
      "        [0.2672, 0.3721],\n",
      "        [0.1847, 0.0102]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14690595]\n",
      "Time: 8.125\n",
      "Iteration: 12\n",
      "new candidats: tensor([[0.4203, 0.7648],\n",
      "        [0.5022, 0.2046],\n",
      "        [0.3977, 0.7775],\n",
      "        [0.8632, 0.2003],\n",
      "        [0.8632, 0.2003]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4181, 0.6465],\n",
      "        [0.1679, 0.0484],\n",
      "        [0.3119, 0.6843],\n",
      "        [0.5753, 0.0907],\n",
      "        [0.5753, 0.0907]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14933666]\n",
      "Time: 7.593999999999141\n",
      "Iteration: 13\n",
      "new candidats: tensor([[0.9119, 0.0085],\n",
      "        [0.9347, 0.0011],\n",
      "        [0.4313, 0.3834],\n",
      "        [0.4203, 0.7648],\n",
      "        [0.3977, 0.7775]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0604, 0.0611],\n",
      "        [0.0395, 0.0236],\n",
      "        [0.1720, 0.0643],\n",
      "        [0.4181, 0.6465],\n",
      "        [0.3119, 0.6843]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14933666]\n",
      "Time: 5.82799999999952\n",
      "Iteration: 14\n",
      "new candidats: tensor([[0.2552, 0.2544],\n",
      "        [0.2552, 0.2544],\n",
      "        [0.6180, 0.7503],\n",
      "        [0.4203, 0.7648],\n",
      "        [0.6180, 0.7503]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4638, 0.3138],\n",
      "        [0.4638, 0.3138],\n",
      "        [0.3086, 0.0577],\n",
      "        [0.4181, 0.6465],\n",
      "        [0.3086, 0.0577]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14933666]\n",
      "Time: 7.4539999999997235\n",
      "Iteration: 15\n",
      "new candidats: tensor([[0.4619, 0.7612],\n",
      "        [0.9390, 0.2768],\n",
      "        [0.4410, 0.3572],\n",
      "        [0.4203, 0.7648],\n",
      "        [0.9390, 0.2768]], dtype=torch.float64)\n",
      "new obj: tensor([[5.4387e-01, 5.3753e-01],\n",
      "        [1.9906e-01, 3.1488e-04],\n",
      "        [1.7961e-01, 6.5748e-02],\n",
      "        [4.1808e-01, 6.4652e-01],\n",
      "        [1.9906e-01, 3.1488e-04]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14933666]\n",
      "Time: 5.7960000000002765\n",
      "Iteration: 16\n",
      "new candidats: tensor([[0.2272, 0.4900],\n",
      "        [0.2062, 0.9443],\n",
      "        [0.2062, 0.9443],\n",
      "        [0.8150, 0.1235],\n",
      "        [0.8150, 0.1235]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1751, 0.1297],\n",
      "        [0.0010, 0.0382],\n",
      "        [0.0010, 0.0382],\n",
      "        [0.5207, 0.4914],\n",
      "        [0.5207, 0.4914]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14933666]\n",
      "Time: 13.54700000000048\n",
      "Iteration: 1\n",
      "new candidats: tensor([[0.0108, 0.1498],\n",
      "        [0.8494, 0.6711],\n",
      "        [0.0302, 0.1143],\n",
      "        [0.6231, 0.6679],\n",
      "        [0.1458, 0.1776]], dtype=torch.float64)\n",
      "new obj: tensor([[3.0965e-01, 4.6369e-01],\n",
      "        [1.6707e-03, 2.8295e-05],\n",
      "        [3.1810e-01, 4.4723e-01],\n",
      "        [3.1519e-01, 2.5003e-02],\n",
      "        [4.7897e-01, 4.6242e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.06506426]\n",
      "Time: 14.921000000000276\n",
      "Iteration: 2\n",
      "new candidats: tensor([[0.8239, 0.9858],\n",
      "        [0.2481, 0.1335],\n",
      "        [0.8239, 0.9858],\n",
      "        [0.1508, 0.2361],\n",
      "        [0.2174, 0.1967]], dtype=torch.float64)\n",
      "new obj: tensor([[6.3882e-05, 1.5816e-05],\n",
      "        [4.5962e-01, 3.1828e-01],\n",
      "        [6.3882e-05, 1.5816e-05],\n",
      "        [4.7728e-01, 4.5336e-01],\n",
      "        [4.9804e-01, 3.8099e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.06811249]\n",
      "Time: 15.265999999999622\n",
      "Iteration: 3\n",
      "new candidats: tensor([[0.9525, 0.9845],\n",
      "        [0.1100, 0.0894],\n",
      "        [0.1100, 0.0894],\n",
      "        [0.9525, 0.9845],\n",
      "        [0.1838, 0.2072]], dtype=torch.float64)\n",
      "new obj: tensor([[6.3102e-07, 4.3561e-08],\n",
      "        [3.8778e-01, 4.2059e-01],\n",
      "        [3.8778e-01, 4.2059e-01],\n",
      "        [6.3102e-07, 4.3561e-08],\n",
      "        [4.9803e-01, 4.2501e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.06895163]\n",
      "Time: 12.109000000000378\n",
      "Iteration: 4\n",
      "new candidats: tensor([[0.6231, 0.6679],\n",
      "        [0.3470, 0.6883],\n",
      "        [0.9976, 0.0294],\n",
      "        [0.2797, 0.5806],\n",
      "        [0.9976, 0.0294]], dtype=torch.float64)\n",
      "new obj: tensor([[0.3152, 0.0250],\n",
      "        [0.2349, 0.3358],\n",
      "        [0.0233, 0.0033],\n",
      "        [0.1058, 0.0778],\n",
      "        [0.0233, 0.0033]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.06895163]\n",
      "Time: 14.781999999999243\n",
      "Iteration: 5\n",
      "new candidats: tensor([[0.7082, 0.3883],\n",
      "        [0.4039, 0.7643],\n",
      "        [0.4535, 0.7485],\n",
      "        [0.4039, 0.7643],\n",
      "        [0.7082, 0.3883]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0913, 0.0020],\n",
      "        [0.3643, 0.6585],\n",
      "        [0.5637, 0.5332],\n",
      "        [0.3643, 0.6585],\n",
      "        [0.0913, 0.0020]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.11933852]\n",
      "Time: 14.906000000000859\n",
      "Iteration: 6\n",
      "new candidats: tensor([[0.9553, 0.0187],\n",
      "        [0.4646, 0.7413],\n",
      "        [0.4886, 0.7308],\n",
      "        [0.4370, 0.7847],\n",
      "        [0.9553, 0.0187]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0408, 0.0203],\n",
      "        [0.6090, 0.4802],\n",
      "        [0.6684, 0.3739],\n",
      "        [0.4044, 0.6473],\n",
      "        [0.0408, 0.0203]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14471436]\n",
      "Time: 16.73400000000038\n",
      "Iteration: 7\n",
      "new candidats: tensor([[0.7214, 0.7424],\n",
      "        [0.7214, 0.7424],\n",
      "        [0.7214, 0.7424],\n",
      "        [0.2641, 0.1477],\n",
      "        [0.2641, 0.1477]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0556, 0.0035],\n",
      "        [0.0556, 0.0035],\n",
      "        [0.0556, 0.0035],\n",
      "        [0.4590, 0.3017],\n",
      "        [0.4590, 0.3017]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14471436]\n",
      "Time: 4.765999999999622\n",
      "Iteration: 8\n",
      "new candidats: tensor([[0.3098, 0.7809],\n",
      "        [0.3098, 0.7809],\n",
      "        [0.4535, 0.7485],\n",
      "        [0.9021, 0.2641],\n",
      "        [0.9021, 0.2641]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0891, 0.4614],\n",
      "        [0.0891, 0.4614],\n",
      "        [0.5637, 0.5332],\n",
      "        [0.3396, 0.0019],\n",
      "        [0.3396, 0.0019]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14471436]\n",
      "Time: 7.32799999999952\n",
      "Iteration: 9\n",
      "new candidats: tensor([[0.7704, 0.5067],\n",
      "        [0.1458, 0.1776],\n",
      "        [0.7704, 0.5067],\n",
      "        [0.1458, 0.1776],\n",
      "        [0.1458, 0.1776]], dtype=torch.float64)\n",
      "new obj: tensor([[1.1512e-02, 3.4490e-04],\n",
      "        [4.7897e-01, 4.6242e-01],\n",
      "        [1.1512e-02, 3.4490e-04],\n",
      "        [4.7897e-01, 4.6242e-01],\n",
      "        [4.7897e-01, 4.6242e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14471436]\n",
      "Time: 8.436999999999898\n",
      "Iteration: 10\n",
      "new candidats: tensor([[0.9976, 0.0294],\n",
      "        [0.3978, 0.7860],\n",
      "        [0.4738, 0.7011],\n",
      "        [0.9976, 0.0294],\n",
      "        [0.4535, 0.7485]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0233, 0.0033],\n",
      "        [0.2911, 0.6948],\n",
      "        [0.6848, 0.3298],\n",
      "        [0.0233, 0.0033],\n",
      "        [0.5637, 0.5332]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14856681]\n",
      "Time: 8.89100000000144\n",
      "Iteration: 11\n",
      "new candidats: tensor([[0.8669, 0.0493],\n",
      "        [0.4370, 0.7847],\n",
      "        [0.4535, 0.7485],\n",
      "        [0.8669, 0.0493],\n",
      "        [0.4535, 0.7485]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1814, 0.3959],\n",
      "        [0.4044, 0.6473],\n",
      "        [0.5637, 0.5332],\n",
      "        [0.1814, 0.3959],\n",
      "        [0.5637, 0.5332]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14856681]\n",
      "Time: 7.796999999998661\n",
      "Iteration: 12\n",
      "new candidats: tensor([[0.4535, 0.7485],\n",
      "        [0.9835, 0.1257],\n",
      "        [0.4403, 0.5393],\n",
      "        [0.9835, 0.1257],\n",
      "        [0.4646, 0.7413]], dtype=torch.float64)\n",
      "new obj: tensor([[0.5637, 0.5332],\n",
      "        [0.0988, 0.0174],\n",
      "        [0.2187, 0.0429],\n",
      "        [0.0988, 0.0174],\n",
      "        [0.6090, 0.4802]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14856681]\n",
      "Time: 14.42200000000048\n",
      "Iteration: 13\n",
      "new candidats: tensor([[0.6697, 0.7608],\n",
      "        [0.4535, 0.7485],\n",
      "        [0.1417, 0.1411],\n",
      "        [0.6697, 0.7608],\n",
      "        [0.1417, 0.1411]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1386, 0.0172],\n",
      "        [0.5637, 0.5332],\n",
      "        [0.4589, 0.4489],\n",
      "        [0.1386, 0.0172],\n",
      "        [0.4589, 0.4489]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14856681]\n",
      "Time: 8.76600000000144\n",
      "Iteration: 14\n",
      "new candidats: tensor([[0.4535, 0.7485],\n",
      "        [0.4354, 0.6326],\n",
      "        [0.4354, 0.6326],\n",
      "        [0.8595, 0.9997],\n",
      "        [0.8657, 0.2555]], dtype=torch.float64)\n",
      "new obj: tensor([[5.6373e-01, 5.3322e-01],\n",
      "        [4.7701e-01, 1.7108e-01],\n",
      "        [4.7701e-01, 1.7108e-01],\n",
      "        [1.3029e-05, 2.5567e-06],\n",
      "        [4.8553e-01, 5.4545e-03]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14856681]\n",
      "Time: 13.5\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration: 15\n",
      "new candidats: tensor([[0.8595, 0.9997],\n",
      "        [0.3575, 0.2694],\n",
      "        [0.3564, 0.3260],\n",
      "        [0.3564, 0.3260],\n",
      "        [0.8595, 0.9997]], dtype=torch.float64)\n",
      "new obj: tensor([[1.3029e-05, 2.5567e-06],\n",
      "        [3.4540e-01, 1.6759e-01],\n",
      "        [3.0222e-01, 1.4705e-01],\n",
      "        [3.0222e-01, 1.4705e-01],\n",
      "        [1.3029e-05, 2.5567e-06]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14856681]\n",
      "Time: 5.235000000000582\n",
      "Iteration: 16\n",
      "new candidats: tensor([[0.4535, 0.7485],\n",
      "        [0.6612, 0.9515],\n",
      "        [0.9190, 0.4022],\n",
      "        [0.9290, 0.9373],\n",
      "        [0.4352, 0.3965]], dtype=torch.float64)\n",
      "new obj: tensor([[5.6373e-01, 5.3322e-01],\n",
      "        [8.1055e-03, 7.3320e-03],\n",
      "        [4.5123e-02, 3.6646e-05],\n",
      "        [4.9446e-06, 2.8317e-07],\n",
      "        [1.6034e-01, 5.8442e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14856681]\n",
      "Time: 8.0\n",
      "Iteration: 1\n",
      "new candidats: tensor([[0.9338, 0.0949],\n",
      "        [0.9098, 0.7098],\n",
      "        [0.1977, 0.0136],\n",
      "        [0.0860, 0.0013],\n",
      "        [0.4473, 0.7220]], dtype=torch.float64)\n",
      "new obj: tensor([[1.6514e-01, 1.7117e-01],\n",
      "        [1.9406e-04, 3.9442e-06],\n",
      "        [3.2388e-01, 2.6414e-01],\n",
      "        [2.5953e-01, 3.0429e-01],\n",
      "        [6.0251e-01, 4.6438e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.10813416]\n",
      "Time: 6.686999999999898\n",
      "Iteration: 2\n",
      "new candidats: tensor([[0.3345, 0.0530],\n",
      "        [0.4280, 0.8189],\n",
      "        [0.4487, 0.7580],\n",
      "        [0.8707, 0.3515],\n",
      "        [0.3456, 0.7008]], dtype=torch.float64)\n",
      "new obj: tensor([[3.0440e-01, 1.5916e-01],\n",
      "        [2.6867e-01, 6.6194e-01],\n",
      "        [5.2341e-01, 5.7088e-01],\n",
      "        [1.7434e-01, 1.2624e-04],\n",
      "        [2.2929e-01, 3.7743e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.12888865]\n",
      "Time: 7.593999999999141\n",
      "Iteration: 3\n",
      "new candidats: tensor([[0.4473, 0.7220],\n",
      "        [0.0057, 0.0854],\n",
      "        [0.7102, 0.6289],\n",
      "        [0.4966, 0.7444],\n",
      "        [0.0057, 0.0854]], dtype=torch.float64)\n",
      "new obj: tensor([[0.6025, 0.4644],\n",
      "        [0.2648, 0.4030],\n",
      "        [0.0616, 0.0016],\n",
      "        [0.6380, 0.3774],\n",
      "        [0.2648, 0.4030]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13444558]\n",
      "Time: 4.468000000000757\n",
      "Iteration: 4\n",
      "new candidats: tensor([[0.0582, 0.8094],\n",
      "        [0.0711, 0.8007],\n",
      "        [0.7004, 0.0242],\n",
      "        [0.7004, 0.0242],\n",
      "        [0.0582, 0.8094]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0038, 0.0068],\n",
      "        [0.0045, 0.0086],\n",
      "        [0.1057, 0.0049],\n",
      "        [0.1057, 0.0049],\n",
      "        [0.0038, 0.0068]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13444558]\n",
      "Time: 9.734999999998763\n",
      "Iteration: 5\n",
      "new candidats: tensor([[0.4487, 0.7580],\n",
      "        [0.9433, 0.0303],\n",
      "        [0.9433, 0.0303],\n",
      "        [0.4487, 0.7580],\n",
      "        [0.4473, 0.7220]], dtype=torch.float64)\n",
      "new obj: tensor([[0.5234, 0.5709],\n",
      "        [0.0598, 0.0465],\n",
      "        [0.0598, 0.0465],\n",
      "        [0.5234, 0.5709],\n",
      "        [0.6025, 0.4644]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13444558]\n",
      "Time: 9.125\n",
      "Iteration: 6\n",
      "new candidats: tensor([[0.0388, 0.0103],\n",
      "        [0.0388, 0.0103],\n",
      "        [0.4487, 0.7580],\n",
      "        [0.4473, 0.7220],\n",
      "        [0.4499, 0.7910]], dtype=torch.float64)\n",
      "new obj: tensor([[0.2304, 0.3150],\n",
      "        [0.2304, 0.3150],\n",
      "        [0.5234, 0.5709],\n",
      "        [0.6025, 0.4644],\n",
      "        [0.4112, 0.6165]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.1380881]\n",
      "Time: 6.781999999999243\n",
      "Iteration: 7\n",
      "new candidats: tensor([[0.3059, 0.4163],\n",
      "        [0.3059, 0.4163],\n",
      "        [0.8443, 0.8955],\n",
      "        [0.8443, 0.8955],\n",
      "        [0.3059, 0.4163]], dtype=torch.float64)\n",
      "new obj: tensor([[2.4408e-01, 1.3926e-01],\n",
      "        [2.4408e-01, 1.3926e-01],\n",
      "        [2.8301e-04, 2.3639e-05],\n",
      "        [2.8301e-04, 2.3639e-05],\n",
      "        [2.4408e-01, 1.3926e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.1380881]\n",
      "Time: 6.57799999999952\n",
      "Iteration: 8\n",
      "new candidats: tensor([[0.9559, 0.9901],\n",
      "        [0.4487, 0.7580],\n",
      "        [0.6848, 0.7343],\n",
      "        [0.4344, 0.7532],\n",
      "        [0.9559, 0.9901]], dtype=torch.float64)\n",
      "new obj: tensor([[4.8168e-07, 3.3645e-08],\n",
      "        [5.2341e-01, 5.7088e-01],\n",
      "        [1.2049e-01, 9.9131e-03],\n",
      "        [4.9536e-01, 5.9354e-01],\n",
      "        [4.8168e-07, 3.3645e-08]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13999422]\n",
      "Time: 9.453000000001339\n",
      "Iteration: 9\n",
      "new candidats: tensor([[0.0775, 0.0346],\n",
      "        [0.5006, 0.8231],\n",
      "        [0.5006, 0.8231],\n",
      "        [0.0775, 0.0346],\n",
      "        [0.4966, 0.7444]], dtype=torch.float64)\n",
      "new obj: tensor([[0.2944, 0.3549],\n",
      "        [0.3296, 0.4112],\n",
      "        [0.3296, 0.4112],\n",
      "        [0.2944, 0.3549],\n",
      "        [0.6380, 0.3774]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13999422]\n",
      "Time: 7.093999999999141\n",
      "Iteration: 10\n",
      "new candidats: tensor([[0.8634, 0.8640],\n",
      "        [0.8634, 0.8640],\n",
      "        [0.8634, 0.8640],\n",
      "        [0.1910, 0.4895],\n",
      "        [0.1910, 0.4895]], dtype=torch.float64)\n",
      "new obj: tensor([[2.5592e-04, 1.3189e-05],\n",
      "        [2.5592e-04, 1.3189e-05],\n",
      "        [2.5592e-04, 1.3189e-05],\n",
      "        [1.7591e-01, 1.4675e-01],\n",
      "        [1.7591e-01, 1.4675e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13999422]\n",
      "Time: 8.42200000000048\n",
      "Iteration: 11\n",
      "new candidats: tensor([[0.9676, 0.0539],\n",
      "        [0.1307, 0.7744],\n",
      "        [0.1304, 0.7879],\n",
      "        [0.9676, 0.0539],\n",
      "        [0.4499, 0.7910]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0593, 0.0287],\n",
      "        [0.0082, 0.0258],\n",
      "        [0.0068, 0.0247],\n",
      "        [0.0593, 0.0287],\n",
      "        [0.4112, 0.6165]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13999422]\n",
      "Time: 8.46900000000096\n",
      "Iteration: 12\n",
      "new candidats: tensor([[0.4966, 0.7444],\n",
      "        [0.4473, 0.7220],\n",
      "        [0.8204, 0.3706],\n",
      "        [0.8204, 0.3706],\n",
      "        [0.8204, 0.3706]], dtype=torch.float64)\n",
      "new obj: tensor([[6.3805e-01, 3.7745e-01],\n",
      "        [6.0251e-01, 4.6438e-01],\n",
      "        [1.6272e-01, 3.0497e-04],\n",
      "        [1.6272e-01, 3.0497e-04],\n",
      "        [1.6272e-01, 3.0497e-04]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13999422]\n",
      "Time: 7.656999999999243\n",
      "Iteration: 13\n",
      "new candidats: tensor([[0.4473, 0.7220],\n",
      "        [0.4966, 0.7444],\n",
      "        [0.9040, 0.3128],\n",
      "        [0.4487, 0.7580],\n",
      "        [0.9040, 0.3128]], dtype=torch.float64)\n",
      "new obj: tensor([[6.0251e-01, 4.6438e-01],\n",
      "        [6.3805e-01, 3.7745e-01],\n",
      "        [2.1658e-01, 1.1694e-04],\n",
      "        [5.2341e-01, 5.7088e-01],\n",
      "        [2.1658e-01, 1.1694e-04]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13999422]\n",
      "Time: 9.468000000000757\n",
      "Iteration: 14\n",
      "new candidats: tensor([[0.1179, 0.1087],\n",
      "        [0.1179, 0.1087],\n",
      "        [0.3176, 0.1185],\n",
      "        [0.4473, 0.7220],\n",
      "        [0.4966, 0.7444]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4141, 0.4378],\n",
      "        [0.4141, 0.4378],\n",
      "        [0.3871, 0.2139],\n",
      "        [0.6025, 0.4644],\n",
      "        [0.6380, 0.3774]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13999422]\n",
      "Time: 6.609000000000378\n",
      "Iteration: 15\n",
      "new candidats: tensor([[0.4966, 0.7444],\n",
      "        [0.0180, 0.1039],\n",
      "        [0.4473, 0.7220],\n",
      "        [0.0180, 0.1039],\n",
      "        [0.4487, 0.7580]], dtype=torch.float64)\n",
      "new obj: tensor([[0.6380, 0.3774],\n",
      "        [0.2944, 0.4307],\n",
      "        [0.6025, 0.4644],\n",
      "        [0.2944, 0.4307],\n",
      "        [0.5234, 0.5709]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13999422]\n",
      "Time: 7.109000000000378\n",
      "Iteration: 16\n",
      "new candidats: tensor([[0.4966, 0.7444],\n",
      "        [0.3849, 0.6929],\n",
      "        [0.0876, 0.0144],\n",
      "        [0.0876, 0.0144],\n",
      "        [0.4473, 0.7220]], dtype=torch.float64)\n",
      "new obj: tensor([[0.6380, 0.3774],\n",
      "        [0.3758, 0.3970],\n",
      "        [0.2776, 0.3238],\n",
      "        [0.2776, 0.3238],\n",
      "        [0.6025, 0.4644]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13999422]\n",
      "Time: 6.45299999999952\n",
      "Iteration: 1\n",
      "new candidats: tensor([[0.1314, 0.0917],\n",
      "        [0.9295, 0.8716],\n",
      "        [0.1913, 0.0973],\n",
      "        [0.0915, 0.1117],\n",
      "        [0.9295, 0.8716]], dtype=torch.float64)\n",
      "new obj: tensor([[4.0719e-01, 4.1197e-01],\n",
      "        [1.8162e-05, 6.1635e-07],\n",
      "        [4.3785e-01, 3.6459e-01],\n",
      "        [3.9148e-01, 4.5092e-01],\n",
      "        [1.8162e-05, 6.1635e-07]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.04363612]\n",
      "Time: 14.860000000000582\n",
      "Iteration: 2\n",
      "new candidats: tensor([[0.1740, 0.1742],\n",
      "        [0.8649, 0.6959],\n",
      "        [0.0605, 0.1832],\n",
      "        [0.1099, 0.1719],\n",
      "        [0.8649, 0.6959]], dtype=torch.float64)\n",
      "new obj: tensor([[4.9167e-01, 4.3316e-01],\n",
      "        [9.9135e-04, 1.6813e-05],\n",
      "        [3.9061e-01, 4.9768e-01],\n",
      "        [4.4736e-01, 4.8532e-01],\n",
      "        [9.9135e-04, 1.6813e-05]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.06776206]\n",
      "Time: 4.561999999999898\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration: 3\n",
      "new candidats: tensor([[0.8201, 0.7170],\n",
      "        [0.1537, 0.2243],\n",
      "        [0.1331, 0.1982],\n",
      "        [0.8201, 0.7170],\n",
      "        [0.8201, 0.7170]], dtype=torch.float64)\n",
      "new obj: tensor([[4.2589e-03, 8.8694e-05],\n",
      "        [4.8318e-01, 4.5473e-01],\n",
      "        [4.7278e-01, 4.7570e-01],\n",
      "        [4.2589e-03, 8.8694e-05],\n",
      "        [4.2589e-03, 8.8694e-05]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.06906783]\n",
      "Time: 15.640999999999622\n",
      "Iteration: 4\n",
      "new candidats: tensor([[0.8879, 0.7286],\n",
      "        [0.0772, 0.1937],\n",
      "        [0.0751, 0.2124],\n",
      "        [0.8955, 0.6849],\n",
      "        [0.8879, 0.7286]], dtype=torch.float64)\n",
      "new obj: tensor([[4.0493e-04, 7.2343e-06],\n",
      "        [4.1393e-01, 4.9943e-01],\n",
      "        [4.1060e-01, 4.9887e-01],\n",
      "        [3.4363e-04, 6.9675e-06],\n",
      "        [4.0493e-04, 7.2343e-06]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.0696712]\n",
      "Time: 8.234000000000378\n",
      "Iteration: 5\n",
      "new candidats: tensor([[0.1631, 0.4782],\n",
      "        [0.8759, 0.9000],\n",
      "        [0.2532, 0.4590],\n",
      "        [0.1631, 0.4782],\n",
      "        [0.8759, 0.9000]], dtype=torch.float64)\n",
      "new obj: tensor([[1.8706e-01, 1.7077e-01],\n",
      "        [8.4599e-05, 5.4570e-06],\n",
      "        [2.1047e-01, 1.4279e-01],\n",
      "        [1.8706e-01, 1.7077e-01],\n",
      "        [8.4599e-05, 5.4570e-06]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.0696712]\n",
      "Time: 7.031999999999243\n",
      "Iteration: 6\n",
      "new candidats: tensor([[0.8626, 0.4531],\n",
      "        [0.2897, 0.8448],\n",
      "        [0.8626, 0.4531],\n",
      "        [0.8626, 0.4531],\n",
      "        [0.2897, 0.8448]], dtype=torch.float64)\n",
      "new obj: tensor([[2.4383e-02, 8.7273e-05],\n",
      "        [2.9402e-02, 3.4626e-01],\n",
      "        [2.4383e-02, 8.7273e-05],\n",
      "        [2.4383e-02, 8.7273e-05],\n",
      "        [2.9402e-02, 3.4626e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.0696712]\n",
      "Time: 6.96900000000096\n",
      "Iteration: 7\n",
      "new candidats: tensor([[0.1134, 0.4706],\n",
      "        [0.8091, 0.9458],\n",
      "        [0.8091, 0.9458],\n",
      "        [0.1134, 0.4706],\n",
      "        [0.1134, 0.4706]], dtype=torch.float64)\n",
      "new obj: tensor([[1.8233e-01, 1.9562e-01],\n",
      "        [2.9202e-04, 5.6654e-05],\n",
      "        [2.9202e-04, 5.6654e-05],\n",
      "        [1.8233e-01, 1.9562e-01],\n",
      "        [1.8233e-01, 1.9562e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.0696712]\n",
      "Time: 7.765999999999622\n",
      "Iteration: 8\n",
      "new candidats: tensor([[0.6856, 0.9946],\n",
      "        [0.1773, 0.1978],\n",
      "        [0.1773, 0.1978],\n",
      "        [0.6856, 0.9946],\n",
      "        [0.1940, 0.2623]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0016, 0.0018],\n",
      "        [0.4968, 0.4330],\n",
      "        [0.4968, 0.4330],\n",
      "        [0.0016, 0.0018],\n",
      "        [0.4761, 0.3930]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07074861]\n",
      "Time: 9.639999999999418\n",
      "Iteration: 9\n",
      "new candidats: tensor([[0.9603, 0.5414],\n",
      "        [0.4135, 0.8630],\n",
      "        [0.4154, 0.8594],\n",
      "        [0.9603, 0.5414],\n",
      "        [0.4135, 0.8630]], dtype=torch.float64)\n",
      "new obj: tensor([[6.5993e-04, 5.8030e-06],\n",
      "        [1.2858e-01, 5.6915e-01],\n",
      "        [1.3859e-01, 5.8037e-01],\n",
      "        [6.5993e-04, 5.8030e-06],\n",
      "        [1.2858e-01, 5.6915e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07074861]\n",
      "Time: 4.42200000000048\n",
      "Iteration: 10\n",
      "new candidats: tensor([[0.4402, 0.6143],\n",
      "        [0.4201, 0.7759],\n",
      "        [0.8753, 0.3396],\n",
      "        [0.8639, 0.0074],\n",
      "        [0.4621, 0.7504]], dtype=torch.float64)\n",
      "new obj: tensor([[4.3418e-01, 1.2575e-01],\n",
      "        [3.8563e-01, 6.6812e-01],\n",
      "        [2.0022e-01, 1.2453e-04],\n",
      "        [9.0580e-02, 1.2132e-01],\n",
      "        [5.7870e-01, 5.1196e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.12402824]\n",
      "Time: 9.17200000000048\n",
      "Iteration: 11\n",
      "new candidats: tensor([[0.4788, 0.7335],\n",
      "        [0.4788, 0.7335],\n",
      "        [0.5816, 0.1787],\n",
      "        [0.5742, 0.1253],\n",
      "        [0.0041, 0.1343]], dtype=torch.float64)\n",
      "new obj: tensor([[0.6524, 0.4133],\n",
      "        [0.6524, 0.4133],\n",
      "        [0.1435, 0.0189],\n",
      "        [0.1224, 0.0194],\n",
      "        [0.2933, 0.4487]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13819154]\n",
      "Time: 8.296000000000276\n",
      "Iteration: 12\n",
      "new candidats: tensor([[0.8562, 0.0791],\n",
      "        [0.4621, 0.7504],\n",
      "        [0.8562, 0.0791],\n",
      "        [0.4245, 0.7398],\n",
      "        [0.4453, 0.1915]], dtype=torch.float64)\n",
      "new obj: tensor([[0.2898, 0.6368],\n",
      "        [0.5787, 0.5120],\n",
      "        [0.2898, 0.6368],\n",
      "        [0.4933, 0.5693],\n",
      "        [0.2367, 0.0859]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14437117]\n",
      "Time: 9.188000000000102\n",
      "Iteration: 13\n",
      "new candidats: tensor([[0.4852, 0.6294],\n",
      "        [0.3292, 0.6654],\n",
      "        [0.3292, 0.6654],\n",
      "        [0.9218, 0.1482],\n",
      "        [0.8466, 0.1320]], dtype=torch.float64)\n",
      "new obj: tensor([[0.5578, 0.1195],\n",
      "        [0.1805, 0.2348],\n",
      "        [0.1805, 0.2348],\n",
      "        [0.2923, 0.1572],\n",
      "        [0.5009, 0.5692]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14480376]\n",
      "Time: 16.78100000000086\n",
      "Iteration: 14\n",
      "new candidats: tensor([[0.7881, 0.0976],\n",
      "        [0.1719, 0.7052],\n",
      "        [0.7860, 0.1205],\n",
      "        [0.1719, 0.7052],\n",
      "        [0.7737, 0.1356]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4175, 0.3255],\n",
      "        [0.0236, 0.0512],\n",
      "        [0.5116, 0.2846],\n",
      "        [0.0236, 0.0512],\n",
      "        [0.5574, 0.1702]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14480376]\n",
      "Time: 6.375\n",
      "Iteration: 15\n",
      "new candidats: tensor([[0.7794, 0.0269],\n",
      "        [0.1411, 0.9298],\n",
      "        [0.1411, 0.9298],\n",
      "        [0.7732, 0.5469],\n",
      "        [0.8076, 0.0188]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1584, 0.0895],\n",
      "        [0.0007, 0.0112],\n",
      "        [0.0007, 0.0112],\n",
      "        [0.0087, 0.0003],\n",
      "        [0.1386, 0.1313]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14480376]\n",
      "Time: 5.890999999999622\n",
      "Iteration: 16\n",
      "new candidats: tensor([[0.8901, 0.1969],\n",
      "        [0.5051, 0.7068],\n",
      "        [0.3770, 0.7291],\n",
      "        [0.8901, 0.1969],\n",
      "        [0.3770, 0.7291]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4677, 0.0776],\n",
      "        [0.7038, 0.2630],\n",
      "        [0.3253, 0.5349],\n",
      "        [0.4677, 0.0776],\n",
      "        [0.3253, 0.5349]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14695933]\n",
      "Time: 5.20299999999952\n",
      "Iteration: 1\n",
      "new candidats: tensor([[0.8062, 0.6713],\n",
      "        [0.1770, 0.0121],\n",
      "        [0.0343, 0.0094],\n",
      "        [0.8062, 0.6713],\n",
      "        [0.8062, 0.6713]], dtype=torch.float64)\n",
      "new obj: tensor([[6.5022e-03, 1.1530e-04],\n",
      "        [3.1943e-01, 2.7867e-01],\n",
      "        [2.2526e-01, 3.1250e-01],\n",
      "        [6.5022e-03, 1.1530e-04],\n",
      "        [6.5022e-03, 1.1530e-04]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.02914363]\n",
      "Time: 14.093999999999141\n",
      "Iteration: 2\n",
      "new candidats: tensor([[0.1865, 0.1875],\n",
      "        [0.9206, 0.5198],\n",
      "        [0.0741, 0.2287],\n",
      "        [0.9206, 0.5198],\n",
      "        [0.9206, 0.5198]], dtype=torch.float64)\n",
      "new obj: tensor([[4.9788e-01, 4.2118e-01],\n",
      "        [2.2634e-03, 1.6448e-05],\n",
      "        [4.0589e-01, 4.9476e-01],\n",
      "        [2.2634e-03, 1.6448e-05],\n",
      "        [2.2634e-03, 1.6448e-05]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.06549914]\n",
      "Time: 9.546999999998661\n",
      "Iteration: 3\n",
      "new candidats: tensor([[0.1169, 0.2320],\n",
      "        [0.1216, 0.3533],\n",
      "        [0.6080, 0.7491],\n",
      "        [0.1555, 0.2305],\n",
      "        [0.6080, 0.7491]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4529, 0.4802],\n",
      "        [0.3452, 0.3606],\n",
      "        [0.3478, 0.0710],\n",
      "        [0.4821, 0.4511],\n",
      "        [0.3478, 0.0710]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.06914851]\n",
      "Time: 11.0\n",
      "Iteration: 4\n",
      "new candidats: tensor([[0.1983, 0.2145],\n",
      "        [0.1635, 0.2208],\n",
      "        [0.1983, 0.2145],\n",
      "        [0.8763, 0.9742],\n",
      "        [0.8763, 0.9742]], dtype=torch.float64)\n",
      "new obj: tensor([[4.9867e-01, 4.0592e-01],\n",
      "        [4.8907e-01, 4.4587e-01],\n",
      "        [4.9867e-01, 4.0592e-01],\n",
      "        [1.4659e-05, 1.9044e-06],\n",
      "        [1.4659e-05, 1.9044e-06]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.0694665]\n",
      "Time: 6.311999999999898\n",
      "Iteration: 5\n",
      "new candidats: tensor([[0.9482, 0.8384],\n",
      "        [0.9482, 0.8384],\n",
      "        [0.2681, 0.3722],\n",
      "        [0.2681, 0.3722],\n",
      "        [0.9482, 0.8384]], dtype=torch.float64)\n",
      "new obj: tensor([[1.4473e-05, 3.9321e-07],\n",
      "        [1.4473e-05, 3.9321e-07],\n",
      "        [3.2591e-01, 2.1134e-01],\n",
      "        [3.2591e-01, 2.1134e-01],\n",
      "        [1.4473e-05, 3.9321e-07]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.0694665]\n",
      "Time: 17.110000000000582\n",
      "Iteration: 6\n",
      "new candidats: tensor([[0.4219, 0.9768],\n",
      "        [0.7985, 0.6898],\n",
      "        [0.4219, 0.9768],\n",
      "        [0.7985, 0.6898],\n",
      "        [0.7985, 0.6898]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0113, 0.1431],\n",
      "        [0.0084, 0.0002],\n",
      "        [0.0113, 0.1431],\n",
      "        [0.0084, 0.0002],\n",
      "        [0.0084, 0.0002]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.0694665]\n",
      "Time: 8.421000000000276\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration: 7\n",
      "new candidats: tensor([[0.9065, 0.8410],\n",
      "        [0.9065, 0.8410],\n",
      "        [0.8466, 0.8613],\n",
      "        [0.0946, 0.1911],\n",
      "        [0.0946, 0.1911]], dtype=torch.float64)\n",
      "new obj: tensor([[7.2433e-05, 2.1919e-06],\n",
      "        [7.2433e-05, 2.1919e-06],\n",
      "        [4.8056e-04, 2.8189e-05],\n",
      "        [4.3473e-01, 4.9574e-01],\n",
      "        [4.3473e-01, 4.9574e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07008264]\n",
      "Time: 9.218999999999141\n",
      "Iteration: 8\n",
      "new candidats: tensor([[0.9547, 0.8146],\n",
      "        [0.0545, 0.2067],\n",
      "        [0.9547, 0.8146],\n",
      "        [0.6985, 0.7952],\n",
      "        [0.0545, 0.2067]], dtype=torch.float64)\n",
      "new obj: tensor([[1.5333e-05, 3.9443e-07],\n",
      "        [3.8351e-01, 4.9822e-01],\n",
      "        [1.5333e-05, 3.9443e-07],\n",
      "        [6.2302e-02, 8.1664e-03],\n",
      "        [3.8351e-01, 4.9822e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07045392]\n",
      "Time: 6.96900000000096\n",
      "Iteration: 9\n",
      "new candidats: tensor([[0.1096, 0.8959],\n",
      "        [0.1096, 0.8959],\n",
      "        [0.1096, 0.8959],\n",
      "        [0.8484, 0.2866],\n",
      "        [0.8484, 0.2866]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0011, 0.0077],\n",
      "        [0.0011, 0.0077],\n",
      "        [0.0011, 0.0077],\n",
      "        [0.4304, 0.0009],\n",
      "        [0.4304, 0.0009]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07045392]\n",
      "Time: 6.484000000000378\n",
      "Iteration: 10\n",
      "new candidats: tensor([[0.1241, 0.2564],\n",
      "        [0.1409, 0.2124],\n",
      "        [0.6595, 0.9109],\n",
      "        [0.1409, 0.2124],\n",
      "        [0.6595, 0.9109]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4471, 0.4632],\n",
      "        [0.4777, 0.4686],\n",
      "        [0.0213, 0.0131],\n",
      "        [0.4777, 0.4686],\n",
      "        [0.0213, 0.0131]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07089028]\n",
      "Time: 16.34399999999914\n",
      "Iteration: 11\n",
      "new candidats: tensor([[0.8922, 0.0525],\n",
      "        [0.8922, 0.0525],\n",
      "        [0.0539, 0.7836],\n",
      "        [0.0508, 0.7974],\n",
      "        [0.0508, 0.7974]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1550, 0.3120],\n",
      "        [0.1550, 0.3120],\n",
      "        [0.0054, 0.0088],\n",
      "        [0.0044, 0.0073],\n",
      "        [0.0044, 0.0073]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07089028]\n",
      "Time: 7.703000000001339\n",
      "Iteration: 12\n",
      "new candidats: tensor([[0.7237, 0.1394],\n",
      "        [0.7237, 0.1394],\n",
      "        [0.7237, 0.1394],\n",
      "        [0.0638, 0.8458],\n",
      "        [0.0638, 0.8458]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4511, 0.0234],\n",
      "        [0.4511, 0.0234],\n",
      "        [0.4511, 0.0234],\n",
      "        [0.0022, 0.0049],\n",
      "        [0.0022, 0.0049]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07089028]\n",
      "Time: 7.483999999998559\n",
      "Iteration: 13\n",
      "new candidats: tensor([[0.3150, 0.6486],\n",
      "        [0.0079, 0.2551],\n",
      "        [0.3150, 0.6486],\n",
      "        [0.3150, 0.6486],\n",
      "        [0.0079, 0.2551]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1451, 0.1742],\n",
      "        [0.3035, 0.4587],\n",
      "        [0.1451, 0.1742],\n",
      "        [0.1451, 0.1742],\n",
      "        [0.3035, 0.4587]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07089028]\n",
      "Time: 6.17200000000048\n",
      "Iteration: 14\n",
      "new candidats: tensor([[0.9981, 0.9766],\n",
      "        [0.9981, 0.9766],\n",
      "        [0.6431, 0.0783],\n",
      "        [0.6431, 0.0783],\n",
      "        [0.9789, 0.9590]], dtype=torch.float64)\n",
      "new obj: tensor([[1.5543e-07, 8.1298e-09],\n",
      "        [1.5543e-07, 8.1298e-09],\n",
      "        [1.3319e-01, 6.9665e-03],\n",
      "        [1.3319e-01, 6.9665e-03],\n",
      "        [4.4618e-07, 2.2685e-08]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07089028]\n",
      "Time: 12.828000000001339\n",
      "Iteration: 15\n",
      "new candidats: tensor([[0.4019, 0.6717],\n",
      "        [0.4019, 0.6717],\n",
      "        [0.0358, 0.1180],\n",
      "        [0.4019, 0.6717],\n",
      "        [0.0358, 0.1180]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4344, 0.3150],\n",
      "        [0.4344, 0.3150],\n",
      "        [0.3282, 0.4530],\n",
      "        [0.4344, 0.3150],\n",
      "        [0.3282, 0.4530]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07089028]\n",
      "Time: 4.890999999999622\n",
      "Iteration: 16\n",
      "new candidats: tensor([[0.8492, 0.9648],\n",
      "        [0.4424, 0.7381],\n",
      "        [0.4713, 0.7373],\n",
      "        [0.4910, 0.7427],\n",
      "        [0.8492, 0.9648]], dtype=torch.float64)\n",
      "new obj: tensor([[4.8951e-05, 7.6368e-06],\n",
      "        [5.5789e-01, 5.3063e-01],\n",
      "        [6.3205e-01, 4.4775e-01],\n",
      "        [6.4077e-01, 3.9397e-01],\n",
      "        [4.8951e-05, 7.6368e-06]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.11863122]\n",
      "Time: 7.96900000000096\n",
      "Iteration: 1\n",
      "new candidats: tensor([[0.7364, 0.6693],\n",
      "        [0.3300, 0.2458],\n",
      "        [0.3370, 0.7962],\n",
      "        [0.3711, 0.7538],\n",
      "        [0.4104, 0.6772]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0417, 0.0012],\n",
      "        [0.3943, 0.2092],\n",
      "        [0.1215, 0.5761],\n",
      "        [0.2715, 0.6068],\n",
      "        [0.4733, 0.3344]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.08848903]\n",
      "Time: 5.359000000000378\n",
      "Iteration: 2\n",
      "new candidats: tensor([[0.4631, 0.7201],\n",
      "        [0.1226, 0.8501],\n",
      "        [0.1337, 0.9900],\n",
      "        [0.1301, 0.1204],\n",
      "        [0.4566, 0.7512]], dtype=torch.float64)\n",
      "new obj: tensor([[6.4808e-01, 4.1918e-01],\n",
      "        [2.5384e-03, 1.5619e-02],\n",
      "        [2.0630e-04, 3.5156e-03],\n",
      "        [4.3451e-01, 4.4155e-01],\n",
      "        [5.6367e-01, 5.3128e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13947459]\n",
      "Time: 5.688000000000102\n",
      "Iteration: 3\n",
      "new candidats: tensor([[0.6270, 0.7975],\n",
      "        [0.9572, 0.0352],\n",
      "        [0.5018, 0.7131],\n",
      "        [0.4294, 0.7921],\n",
      "        [0.9572, 0.0352]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1948, 0.0533],\n",
      "        [0.0527, 0.0304],\n",
      "        [0.6999, 0.2878],\n",
      "        [0.3603, 0.6695],\n",
      "        [0.0527, 0.0304]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14797942]\n",
      "Time: 6.968000000000757\n",
      "Iteration: 4\n",
      "new candidats: tensor([[0.1597, 0.2639],\n",
      "        [0.1597, 0.2639],\n",
      "        [0.6254, 0.7308],\n",
      "        [0.4535, 0.7369],\n",
      "        [0.6254, 0.7308]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4656, 0.4297],\n",
      "        [0.4656, 0.4297],\n",
      "        [0.3054, 0.0437],\n",
      "        [0.5931, 0.4992],\n",
      "        [0.3054, 0.0437]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15033677]\n",
      "Time: 6.843999999999141\n",
      "Iteration: 5\n",
      "new candidats: tensor([[0.2626, 0.0486],\n",
      "        [0.2626, 0.0486],\n",
      "        [0.5801, 0.5921],\n",
      "        [0.2626, 0.0486],\n",
      "        [0.5801, 0.5921]], dtype=torch.float64)\n",
      "new obj: tensor([[0.3575, 0.2361],\n",
      "        [0.3575, 0.2361],\n",
      "        [0.2958, 0.0188],\n",
      "        [0.3575, 0.2361],\n",
      "        [0.2958, 0.0188]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15033677]\n",
      "Time: 7.859000000000378\n",
      "Iteration: 6\n",
      "new candidats: tensor([[0.4431, 0.7546],\n",
      "        [0.0012, 0.3178],\n",
      "        [0.0038, 0.3892],\n",
      "        [0.0012, 0.3178],\n",
      "        [0.4294, 0.7921]], dtype=torch.float64)\n",
      "new obj: tensor([[0.5182, 0.5772],\n",
      "        [0.2565, 0.3962],\n",
      "        [0.1975, 0.3025],\n",
      "        [0.2565, 0.3962],\n",
      "        [0.3603, 0.6695]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15385159]\n",
      "Time: 7.29700000000048\n",
      "Iteration: 7\n",
      "new candidats: tensor([[0.0033, 0.0925],\n",
      "        [0.0033, 0.0925],\n",
      "        [0.4294, 0.7921],\n",
      "        [0.4757, 0.7230],\n",
      "        [0.4757, 0.7230]], dtype=torch.float64)\n",
      "new obj: tensor([[0.2668, 0.4094],\n",
      "        [0.2668, 0.4094],\n",
      "        [0.3603, 0.6695],\n",
      "        [0.6681, 0.3931],\n",
      "        [0.6681, 0.3931]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15596144]\n",
      "Time: 9.156999999999243\n",
      "Iteration: 8\n",
      "new candidats: tensor([[0.2737, 0.8499],\n",
      "        [0.9209, 0.2553],\n",
      "        [0.9209, 0.2553],\n",
      "        [0.2664, 0.8534],\n",
      "        [0.2664, 0.8534]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0199, 0.2797],\n",
      "        [0.2901, 0.0021],\n",
      "        [0.2901, 0.0021],\n",
      "        [0.0164, 0.2503],\n",
      "        [0.0164, 0.2503]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15596144]\n",
      "Time: 6.82799999999952\n",
      "Iteration: 9\n",
      "new candidats: tensor([[0.0385, 0.8288],\n",
      "        [0.0385, 0.8288],\n",
      "        [0.7110, 0.2671],\n",
      "        [0.7110, 0.2671],\n",
      "        [0.7110, 0.2671]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0026, 0.0045],\n",
      "        [0.0026, 0.0045],\n",
      "        [0.3942, 0.0028],\n",
      "        [0.3942, 0.0028],\n",
      "        [0.3942, 0.0028]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15596144]\n",
      "Time: 5.875\n",
      "Iteration: 10\n",
      "new candidats: tensor([[0.7633, 0.0861],\n",
      "        [0.2244, 0.8060],\n",
      "        [0.4294, 0.7921],\n",
      "        [0.2244, 0.8060],\n",
      "        [0.7633, 0.0861]], dtype=torch.float64)\n",
      "new obj: tensor([[0.3501, 0.1507],\n",
      "        [0.0140, 0.1534],\n",
      "        [0.3603, 0.6695],\n",
      "        [0.0140, 0.1534],\n",
      "        [0.3501, 0.1507]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15596144]\n",
      "Time: 6.781000000000859\n",
      "Iteration: 11\n",
      "new candidats: tensor([[0.7687, 0.3324],\n",
      "        [0.4757, 0.7230],\n",
      "        [0.4850, 0.7016],\n",
      "        [0.7467, 0.4308],\n",
      "        [0.7687, 0.3324]], dtype=torch.float64)\n",
      "new obj: tensor([[0.2846, 0.0009],\n",
      "        [0.6681, 0.3931],\n",
      "        [0.6999, 0.3030],\n",
      "        [0.0493, 0.0008],\n",
      "        [0.2846, 0.0009]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15644526]\n",
      "Time: 6.109000000000378\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration: 12\n",
      "new candidats: tensor([[0.9583, 0.2819],\n",
      "        [0.9583, 0.2819],\n",
      "        [0.3486, 0.9524],\n",
      "        [0.9583, 0.2819],\n",
      "        [0.3486, 0.9524]], dtype=torch.float64)\n",
      "new obj: tensor([[1.4336e-01, 1.1346e-04],\n",
      "        [1.4336e-01, 1.1346e-04],\n",
      "        [9.5337e-03, 1.9232e-01],\n",
      "        [1.4336e-01, 1.1346e-04],\n",
      "        [9.5337e-03, 1.9232e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15644526]\n",
      "Time: 9.42200000000048\n",
      "Iteration: 13\n",
      "new candidats: tensor([[0.4730, 0.2094],\n",
      "        [0.4730, 0.2094],\n",
      "        [0.9953, 0.6091],\n",
      "        [0.9953, 0.6091],\n",
      "        [0.4730, 0.2094]], dtype=torch.float64)\n",
      "new obj: tensor([[2.0007e-01, 6.5591e-02],\n",
      "        [2.0007e-01, 6.5591e-02],\n",
      "        [4.9055e-05, 1.3906e-06],\n",
      "        [4.9055e-05, 1.3906e-06],\n",
      "        [2.0007e-01, 6.5591e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15644526]\n",
      "Time: 7.843999999999141\n",
      "Iteration: 14\n",
      "new candidats: tensor([[0.3671, 0.6979],\n",
      "        [0.3671, 0.6979],\n",
      "        [0.3671, 0.6979],\n",
      "        [0.9650, 0.1753],\n",
      "        [0.9650, 0.1753]], dtype=torch.float64)\n",
      "new obj: tensor([[0.3054, 0.4012],\n",
      "        [0.3054, 0.4012],\n",
      "        [0.3054, 0.4012],\n",
      "        [0.1745, 0.0160],\n",
      "        [0.1745, 0.0160]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15644526]\n",
      "Time: 6.375\n",
      "Iteration: 15\n",
      "new candidats: tensor([[0.0160, 0.8769],\n",
      "        [0.4119, 0.3007],\n",
      "        [0.0160, 0.8769],\n",
      "        [0.4119, 0.3007],\n",
      "        [0.4119, 0.3007]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0011, 0.0019],\n",
      "        [0.2516, 0.1022],\n",
      "        [0.0011, 0.0019],\n",
      "        [0.2516, 0.1022],\n",
      "        [0.2516, 0.1022]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15644526]\n",
      "Time: 6.781000000000859\n",
      "Iteration: 16\n",
      "new candidats: tensor([[0.3671, 0.6979],\n",
      "        [0.8682, 0.4024],\n",
      "        [0.8682, 0.4024],\n",
      "        [0.8682, 0.4024],\n",
      "        [0.3671, 0.6979]], dtype=torch.float64)\n",
      "new obj: tensor([[3.0538e-01, 4.0124e-01],\n",
      "        [7.2614e-02, 1.0412e-04],\n",
      "        [7.2614e-02, 1.0412e-04],\n",
      "        [7.2614e-02, 1.0412e-04],\n",
      "        [3.0538e-01, 4.0124e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15644526]\n",
      "Time: 7.734000000000378\n",
      "Iteration: 1\n",
      "new candidats: tensor([[0.0047, 0.4874],\n",
      "        [0.8468, 0.2724],\n",
      "        [0.8468, 0.2724],\n",
      "        [0.0072, 0.2587],\n",
      "        [0.0538, 0.5100]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1106, 0.1689],\n",
      "        [0.4851, 0.0021],\n",
      "        [0.4851, 0.0021],\n",
      "        [0.3010, 0.4559],\n",
      "        [0.1152, 0.1500]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.05176221]\n",
      "Time: 16.90600000000086\n",
      "Iteration: 2\n",
      "new candidats: tensor([[0.8903, 0.0369],\n",
      "        [0.1876, 0.8250],\n",
      "        [0.2137, 0.1985],\n",
      "        [0.8903, 0.0369],\n",
      "        [0.1876, 0.8250]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1240, 0.2281],\n",
      "        [0.0062, 0.0743],\n",
      "        [0.4988, 0.3863],\n",
      "        [0.1240, 0.2281],\n",
      "        [0.0062, 0.0743]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.06464007]\n",
      "Time: 11.5\n",
      "Iteration: 3\n",
      "new candidats: tensor([[0.8722, 0.7481],\n",
      "        [0.8722, 0.7481],\n",
      "        [0.0176, 0.1583],\n",
      "        [0.2595, 0.2226],\n",
      "        [0.1210, 0.2099]], dtype=torch.float64)\n",
      "new obj: tensor([[6.5395e-04, 1.2577e-05],\n",
      "        [6.5395e-04, 1.2577e-05],\n",
      "        [3.2275e-01, 4.7272e-01],\n",
      "        [4.7533e-01, 3.1719e-01],\n",
      "        [4.6195e-01, 4.8339e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.06863172]\n",
      "Time: 16.15599999999904\n",
      "Iteration: 4\n",
      "new candidats: tensor([[0.2595, 0.2226],\n",
      "        [0.9010, 0.7812],\n",
      "        [0.2833, 0.1808],\n",
      "        [0.8762, 0.9172],\n",
      "        [0.9137, 0.9128]], dtype=torch.float64)\n",
      "new obj: tensor([[4.7533e-01, 3.1719e-01],\n",
      "        [1.7793e-04, 3.7429e-06],\n",
      "        [4.5636e-01, 2.8184e-01],\n",
      "        [5.8639e-05, 4.4407e-06],\n",
      "        [1.5457e-05, 8.0820e-07]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.06863172]\n",
      "Time: 7.96900000000096\n",
      "Iteration: 5\n",
      "new candidats: tensor([[0.2518, 0.7692],\n",
      "        [0.7877, 0.1924],\n",
      "        [0.2595, 0.2226],\n",
      "        [0.2518, 0.7692],\n",
      "        [0.7877, 0.1924]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0338, 0.2285],\n",
      "        [0.6994, 0.0592],\n",
      "        [0.4753, 0.3172],\n",
      "        [0.0338, 0.2285],\n",
      "        [0.6994, 0.0592]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.06863172]\n",
      "Time: 6.79700000000048\n",
      "Iteration: 6\n",
      "new candidats: tensor([[0.8540, 0.1618],\n",
      "        [0.0586, 0.2189],\n",
      "        [0.0708, 0.8235],\n",
      "        [0.8540, 0.1618],\n",
      "        [0.0708, 0.8235]], dtype=torch.float64)\n",
      "new obj: tensor([[0.5646, 0.3254],\n",
      "        [0.3877, 0.4970],\n",
      "        [0.0032, 0.0069],\n",
      "        [0.5646, 0.3254],\n",
      "        [0.0032, 0.0069]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07549505]\n",
      "Time: 6.125\n",
      "Iteration: 7\n",
      "new candidats: tensor([[0.3707, 0.8660],\n",
      "        [0.3707, 0.8660],\n",
      "        [0.7749, 0.3743],\n",
      "        [0.7749, 0.3743],\n",
      "        [0.7749, 0.3743]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0778, 0.5399],\n",
      "        [0.0778, 0.5399],\n",
      "        [0.1541, 0.0007],\n",
      "        [0.1541, 0.0007],\n",
      "        [0.1541, 0.0007]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07549505]\n",
      "Time: 6.90599999999904\n",
      "Iteration: 8\n",
      "new candidats: tensor([[0.9613, 0.1401],\n",
      "        [0.2239, 0.6934],\n",
      "        [0.2239, 0.6934],\n",
      "        [0.9636, 0.1531],\n",
      "        [0.2239, 0.6934]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1598, 0.0427],\n",
      "        [0.0391, 0.1019],\n",
      "        [0.0391, 0.1019],\n",
      "        [0.1647, 0.0301],\n",
      "        [0.0391, 0.1019]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07549505]\n",
      "Time: 8.468000000000757\n",
      "Iteration: 9\n",
      "new candidats: tensor([[0.8422, 0.2247],\n",
      "        [0.8290, 0.4402],\n",
      "        [0.8305, 0.1368],\n",
      "        [0.1677, 0.6871],\n",
      "        [0.1609, 0.2013]], dtype=torch.float64)\n",
      "new obj: tensor([[6.2380e-01, 3.1074e-02],\n",
      "        [3.9310e-02, 1.8140e-04],\n",
      "        [5.5036e-01, 4.9551e-01],\n",
      "        [2.8211e-02, 4.7803e-02],\n",
      "        [4.9055e-01, 4.5088e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.08878867]\n",
      "Time: 6.390999999999622\n",
      "Iteration: 10\n",
      "new candidats: tensor([[0.6985, 0.9759],\n",
      "        [0.7990, 0.1577],\n",
      "        [0.8407, 0.1266],\n",
      "        [0.2592, 0.3599],\n",
      "        [0.2544, 0.3338]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0022, 0.0017],\n",
      "        [0.6457, 0.2144],\n",
      "        [0.4950, 0.5975],\n",
      "        [0.3478, 0.2322],\n",
      "        [0.3852, 0.2613]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.11499573]\n",
      "Time: 5.359000000000378\n",
      "Iteration: 11\n",
      "new candidats: tensor([[0.3035, 0.4838],\n",
      "        [0.2804, 0.8109],\n",
      "        [0.2804, 0.8109],\n",
      "        [0.8407, 0.1266],\n",
      "        [0.8944, 0.5495]], dtype=torch.float64)\n",
      "new obj: tensor([[1.6957e-01, 9.5350e-02],\n",
      "        [3.8273e-02, 3.4295e-01],\n",
      "        [3.8273e-02, 3.4295e-01],\n",
      "        [4.9498e-01, 5.9751e-01],\n",
      "        [1.3539e-03, 2.2338e-05]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.11499573]\n",
      "Time: 6.906999999999243\n",
      "Iteration: 12\n",
      "new candidats: tensor([[0.2052, 0.8712],\n",
      "        [0.3531, 0.8679],\n",
      "        [0.8145, 0.8758],\n",
      "        [0.8407, 0.1266],\n",
      "        [0.8407, 0.1266]], dtype=torch.float64)\n",
      "new obj: tensor([[3.8872e-03, 8.2884e-02],\n",
      "        [5.9478e-02, 4.9851e-01],\n",
      "        [1.0787e-03, 9.9428e-05],\n",
      "        [4.9498e-01, 5.9751e-01],\n",
      "        [4.9498e-01, 5.9751e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.11499573]\n",
      "Time: 7.75\n",
      "Iteration: 13\n",
      "new candidats: tensor([[0.8407, 0.1266],\n",
      "        [0.0897, 0.6392],\n",
      "        [0.2952, 0.6271],\n",
      "        [0.0897, 0.6392],\n",
      "        [0.8407, 0.1266]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4950, 0.5975],\n",
      "        [0.0387, 0.0462],\n",
      "        [0.1116, 0.1178],\n",
      "        [0.0387, 0.0462],\n",
      "        [0.4950, 0.5975]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.11499573]\n",
      "Time: 7.234999999998763\n",
      "Iteration: 14\n",
      "new candidats: tensor([[0.0451, 0.6989],\n",
      "        [0.8317, 0.3523],\n",
      "        [0.0451, 0.6989],\n",
      "        [0.8407, 0.1266],\n",
      "        [0.8305, 0.1368]], dtype=torch.float64)\n",
      "new obj: tensor([[1.6515e-02, 2.2864e-02],\n",
      "        [2.1144e-01, 2.6728e-04],\n",
      "        [1.6515e-02, 2.2864e-02],\n",
      "        [4.9498e-01, 5.9751e-01],\n",
      "        [5.5036e-01, 4.9551e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.11499573]\n",
      "Time: 6.765000000001237\n",
      "Iteration: 15\n",
      "new candidats: tensor([[0.8284, 0.5973],\n",
      "        [0.3064, 0.9841],\n",
      "        [0.3064, 0.9841],\n",
      "        [0.8407, 0.1266],\n",
      "        [0.8305, 0.1368]], dtype=torch.float64)\n",
      "new obj: tensor([[2.6322e-03, 6.1744e-05],\n",
      "        [2.0982e-03, 8.3074e-02],\n",
      "        [2.0982e-03, 8.3074e-02],\n",
      "        [4.9498e-01, 5.9751e-01],\n",
      "        [5.5036e-01, 4.9551e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.11499573]\n",
      "Time: 9.921999999998661\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration: 16\n",
      "new candidats: tensor([[0.7297, 0.8881],\n",
      "        [0.1583, 0.0060],\n",
      "        [0.7290, 0.8738],\n",
      "        [0.8407, 0.1266],\n",
      "        [0.1583, 0.0060]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0086, 0.0021],\n",
      "        [0.3056, 0.2833],\n",
      "        [0.0113, 0.0024],\n",
      "        [0.4950, 0.5975],\n",
      "        [0.3056, 0.2833]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.11499573]\n",
      "Time: 6.563000000000102\n",
      "Iteration: 1\n",
      "new candidats: tensor([[0.8447, 0.9413],\n",
      "        [0.0411, 0.1679],\n",
      "        [0.0096, 0.2262],\n",
      "        [0.8447, 0.9413],\n",
      "        [0.8447, 0.9413]], dtype=torch.float64)\n",
      "new obj: tensor([[1.0312e-04, 1.3409e-05],\n",
      "        [3.5995e-01, 4.8845e-01],\n",
      "        [3.1503e-01, 4.7360e-01],\n",
      "        [1.0312e-04, 1.3409e-05],\n",
      "        [1.0312e-04, 1.3409e-05]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.03372628]\n",
      "Time: 6.218999999999141\n",
      "Iteration: 2\n",
      "new candidats: tensor([[0.9692, 0.0408],\n",
      "        [0.9692, 0.0408],\n",
      "        [0.0781, 0.0971],\n",
      "        [0.1298, 0.0963],\n",
      "        [0.0062, 0.0939]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0473, 0.0202],\n",
      "        [0.0473, 0.0202],\n",
      "        [0.3638, 0.4377],\n",
      "        [0.4110, 0.4180],\n",
      "        [0.2716, 0.4128]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.04384586]\n",
      "Time: 5.796999999998661\n",
      "Iteration: 3\n",
      "new candidats: tensor([[0.8766, 0.6493],\n",
      "        [0.5978, 0.1652],\n",
      "        [0.8766, 0.6493],\n",
      "        [0.1662, 0.1745],\n",
      "        [0.0908, 0.1721]], dtype=torch.float64)\n",
      "new obj: tensor([[6.6517e-04, 1.4411e-05],\n",
      "        [1.5340e-01, 1.5151e-02],\n",
      "        [6.6517e-04, 1.4411e-05],\n",
      "        [4.8893e-01, 4.4176e-01],\n",
      "        [4.2658e-01, 4.9250e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.06607922]\n",
      "Time: 4.17200000000048\n",
      "Iteration: 4\n",
      "new candidats: tensor([[0.4366, 0.5024],\n",
      "        [0.9523, 0.9697],\n",
      "        [0.2757, 0.4960],\n",
      "        [0.2757, 0.4960],\n",
      "        [0.9523, 0.9697]], dtype=torch.float64)\n",
      "new obj: tensor([[1.6049e-01, 3.7514e-02],\n",
      "        [9.2180e-07, 5.7447e-08],\n",
      "        [1.6271e-01, 1.0172e-01],\n",
      "        [1.6271e-01, 1.0172e-01],\n",
      "        [9.2180e-07, 5.7447e-08]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.06607922]\n",
      "Time: 6.95299999999952\n",
      "Iteration: 5\n",
      "new candidats: tensor([[0.7606, 0.8485],\n",
      "        [0.7606, 0.8485],\n",
      "        [0.0732, 0.1758],\n",
      "        [0.7606, 0.8485],\n",
      "        [0.1289, 0.1914]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0079, 0.0009],\n",
      "        [0.0079, 0.0009],\n",
      "        [0.4060, 0.4963],\n",
      "        [0.0079, 0.0009],\n",
      "        [0.4689, 0.4784]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.0682838]\n",
      "Time: 7.84400000000096\n",
      "Iteration: 6\n",
      "new candidats: tensor([[0.1902, 0.1938],\n",
      "        [0.1902, 0.1938],\n",
      "        [0.6347, 0.8178],\n",
      "        [0.6347, 0.8178],\n",
      "        [0.6347, 0.8178]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4992, 0.4171],\n",
      "        [0.4992, 0.4171],\n",
      "        [0.1415, 0.0439],\n",
      "        [0.1415, 0.0439],\n",
      "        [0.1415, 0.0439]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07028889]\n",
      "Time: 6.95299999999952\n",
      "Iteration: 7\n",
      "new candidats: tensor([[0.5969, 0.9615],\n",
      "        [0.1184, 0.1859],\n",
      "        [0.5969, 0.9615],\n",
      "        [0.0657, 0.2076],\n",
      "        [0.0657, 0.2076]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0144, 0.0273],\n",
      "        [0.4590, 0.4843],\n",
      "        [0.0144, 0.0273],\n",
      "        [0.3989, 0.4995],\n",
      "        [0.3989, 0.4995]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07101516]\n",
      "Time: 6.813000000000102\n",
      "Iteration: 8\n",
      "new candidats: tensor([[0.8619, 0.0733],\n",
      "        [0.8619, 0.0733],\n",
      "        [0.0704, 0.6436],\n",
      "        [0.8619, 0.0733],\n",
      "        [0.0704, 0.6436]], dtype=torch.float64)\n",
      "new obj: tensor([[0.2606, 0.5900],\n",
      "        [0.2606, 0.5900],\n",
      "        [0.0347, 0.0436],\n",
      "        [0.2606, 0.5900],\n",
      "        [0.0347, 0.0436]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07344222]\n",
      "Time: 4.391000000001441\n",
      "Iteration: 9\n",
      "new candidats: tensor([[0.1435, 0.9020],\n",
      "        [0.8226, 0.1441],\n",
      "        [0.7880, 0.0688],\n",
      "        [0.1435, 0.9020],\n",
      "        [0.1435, 0.9020]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0012, 0.0165],\n",
      "        [0.5875, 0.4085],\n",
      "        [0.2994, 0.2678],\n",
      "        [0.0012, 0.0165],\n",
      "        [0.0012, 0.0165]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.09000254]\n",
      "Time: 7.53099999999904\n",
      "Iteration: 10\n",
      "new candidats: tensor([[0.2380, 0.8349],\n",
      "        [0.8380, 0.1822],\n",
      "        [0.8651, 0.1416],\n",
      "        [0.2427, 0.9232],\n",
      "        [0.2427, 0.9232]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0123, 0.1795],\n",
      "        [0.6441, 0.1762],\n",
      "        [0.4796, 0.4733],\n",
      "        [0.0028, 0.0956],\n",
      "        [0.0028, 0.0956]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.09034011]\n",
      "Time: 9.484000000000378\n",
      "Iteration: 11\n",
      "new candidats: tensor([[0.6502, 0.5772],\n",
      "        [0.8592, 0.1058],\n",
      "        [0.0364, 0.5809],\n",
      "        [0.3406, 0.1087],\n",
      "        [0.8508, 0.1285]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1136, 0.0038],\n",
      "        [0.3789, 0.6839],\n",
      "        [0.0583, 0.0804],\n",
      "        [0.3519, 0.1804],\n",
      "        [0.4789, 0.5949]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.12532926]\n",
      "Time: 6.688000000000102\n",
      "Iteration: 12\n",
      "new candidats: tensor([[0.8133, 0.1514],\n",
      "        [0.9806, 0.4190],\n",
      "        [0.8431, 0.1402],\n",
      "        [0.9806, 0.4190],\n",
      "        [0.9806, 0.4190]], dtype=torch.float64)\n",
      "new obj: tensor([[6.2097e-01, 3.1569e-01],\n",
      "        [1.2612e-02, 8.6645e-06],\n",
      "        [5.3596e-01, 5.0254e-01],\n",
      "        [1.2612e-02, 8.6645e-06],\n",
      "        [1.2612e-02, 8.6645e-06]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13341412]\n",
      "Time: 7.186999999999898\n",
      "Iteration: 13\n",
      "new candidats: tensor([[0.8371, 0.6788],\n",
      "        [0.1298, 0.0963],\n",
      "        [0.1298, 0.0963],\n",
      "        [0.8371, 0.6788],\n",
      "        [0.8371, 0.6788]], dtype=torch.float64)\n",
      "new obj: tensor([[2.5199e-03, 4.2087e-05],\n",
      "        [4.1096e-01, 4.1802e-01],\n",
      "        [4.1096e-01, 4.1802e-01],\n",
      "        [2.5199e-03, 4.2087e-05],\n",
      "        [2.5199e-03, 4.2087e-05]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13341412]\n",
      "Time: 4.813000000000102\n",
      "Iteration: 14\n",
      "new candidats: tensor([[0.9238, 0.7674],\n",
      "        [0.3475, 0.3425],\n",
      "        [0.3554, 0.3083],\n",
      "        [0.3475, 0.3425],\n",
      "        [0.9238, 0.7674]], dtype=torch.float64)\n",
      "new obj: tensor([[8.2938e-05, 1.7157e-06],\n",
      "        [2.9598e-01, 1.4820e-01],\n",
      "        [3.1936e-01, 1.5594e-01],\n",
      "        [2.9598e-01, 1.4820e-01],\n",
      "        [8.2938e-05, 1.7157e-06]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13341412]\n",
      "Time: 8.593000000000757\n",
      "Iteration: 15\n",
      "new candidats: tensor([[0.3254, 0.8261],\n",
      "        [0.6543, 0.1034],\n",
      "        [0.6681, 0.1225],\n",
      "        [0.6543, 0.1034],\n",
      "        [0.3254, 0.8261]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0718, 0.5137],\n",
      "        [0.1856, 0.0066],\n",
      "        [0.2472, 0.0061],\n",
      "        [0.1856, 0.0066],\n",
      "        [0.0718, 0.5137]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13341412]\n",
      "Time: 8.45299999999952\n",
      "Iteration: 16\n",
      "new candidats: tensor([[0.9036, 0.3019],\n",
      "        [0.4387, 0.8204],\n",
      "        [0.4387, 0.8204],\n",
      "        [0.5777, 0.7980],\n",
      "        [0.9036, 0.3019]], dtype=torch.float64)\n",
      "new obj: tensor([[2.4455e-01, 1.8809e-04],\n",
      "        [2.8285e-01, 6.3693e-01],\n",
      "        [2.8285e-01, 6.3693e-01],\n",
      "        [3.2118e-01, 1.4451e-01],\n",
      "        [2.4455e-01, 1.8809e-04]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13341412]\n",
      "Time: 7.140999999999622\n",
      "Iteration: 1\n",
      "new candidats: tensor([[0.0687, 0.1390],\n",
      "        [0.5168, 0.3907],\n",
      "        [0.1756, 0.1252],\n",
      "        [0.5168, 0.3907],\n",
      "        [0.1571, 0.2424]], dtype=torch.float64)\n",
      "new obj: tensor([[0.3847, 0.4772],\n",
      "        [0.0984, 0.0263],\n",
      "        [0.4628, 0.4056],\n",
      "        [0.0984, 0.0263],\n",
      "        [0.4778, 0.4447]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.06089499]\n",
      "Time: 3.82799999999952\n",
      "Iteration: 2\n",
      "new candidats: tensor([[0.0687, 0.1390],\n",
      "        [0.7842, 0.7344],\n",
      "        [0.0506, 0.2136],\n",
      "        [0.7842, 0.7344],\n",
      "        [0.4345, 0.7263]], dtype=torch.float64)\n",
      "new obj: tensor([[3.8473e-01, 4.7725e-01],\n",
      "        [1.1827e-02, 3.7572e-04],\n",
      "        [3.7733e-01, 4.9649e-01],\n",
      "        [1.1827e-02, 3.7572e-04],\n",
      "        [5.5356e-01, 5.0567e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.09099215]\n",
      "Time: 4.375\n",
      "Iteration: 3\n",
      "new candidats: tensor([[0.4441, 0.7712],\n",
      "        [0.8593, 0.1865],\n",
      "        [0.8593, 0.1865],\n",
      "        [0.4499, 0.6761],\n",
      "        [0.3714, 0.7001]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4687, 0.6108],\n",
      "        [0.5841, 0.1544],\n",
      "        [0.5841, 0.1544],\n",
      "        [0.6136, 0.2916],\n",
      "        [0.3212, 0.4150]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.11990754]\n",
      "Time: 5.343999999999141\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration: 4\n",
      "new candidats: tensor([[0.4778, 0.7503],\n",
      "        [0.0083, 0.5962],\n",
      "        [0.4907, 0.7092],\n",
      "        [0.4380, 0.7893],\n",
      "        [0.3535, 0.0013]], dtype=torch.float64)\n",
      "new obj: tensor([[0.6060, 0.4587],\n",
      "        [0.0444, 0.0671],\n",
      "        [0.7008, 0.3094],\n",
      "        [0.3910, 0.6487],\n",
      "        [0.2273, 0.1117]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14246685]\n",
      "Time: 8.64100000000144\n",
      "Iteration: 5\n",
      "new candidats: tensor([[0.9641, 0.8933],\n",
      "        [0.3404, 0.1744],\n",
      "        [0.3404, 0.1744],\n",
      "        [0.9641, 0.8933],\n",
      "        [0.3404, 0.1744]], dtype=torch.float64)\n",
      "new obj: tensor([[3.1112e-06, 1.1216e-07],\n",
      "        [3.8759e-01, 1.9880e-01],\n",
      "        [3.8759e-01, 1.9880e-01],\n",
      "        [3.1112e-06, 1.1216e-07],\n",
      "        [3.8759e-01, 1.9880e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14246685]\n",
      "Time: 7.781999999999243\n",
      "Iteration: 6\n",
      "new candidats: tensor([[0.4513, 0.7179],\n",
      "        [0.4441, 0.7712],\n",
      "        [0.1332, 0.1762],\n",
      "        [0.4425, 0.7355],\n",
      "        [0.1332, 0.1762]], dtype=torch.float64)\n",
      "new obj: tensor([[0.6198, 0.4409],\n",
      "        [0.4687, 0.6108],\n",
      "        [0.4695, 0.4723],\n",
      "        [0.5636, 0.5221],\n",
      "        [0.4695, 0.4723]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14630984]\n",
      "Time: 8.311999999999898\n",
      "Iteration: 7\n",
      "new candidats: tensor([[0.5335, 0.0594],\n",
      "        [0.0271, 0.8068],\n",
      "        [0.5335, 0.0594],\n",
      "        [0.0271, 0.8068],\n",
      "        [0.0271, 0.8068]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1047, 0.0266],\n",
      "        [0.0035, 0.0056],\n",
      "        [0.1047, 0.0266],\n",
      "        [0.0035, 0.0056],\n",
      "        [0.0035, 0.0056]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14630984]\n",
      "Time: 6.578000000001339\n",
      "Iteration: 8\n",
      "new candidats: tensor([[0.0539, 0.0628],\n",
      "        [0.0539, 0.0628],\n",
      "        [0.5016, 0.7018],\n",
      "        [0.4920, 0.7279],\n",
      "        [0.0862, 0.7236]], dtype=torch.float64)\n",
      "new obj: tensor([[0.3026, 0.3939],\n",
      "        [0.3026, 0.3939],\n",
      "        [0.7067, 0.2600],\n",
      "        [0.6764, 0.3552],\n",
      "        [0.0139, 0.0200]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14913176]\n",
      "Time: 8.936999999999898\n",
      "Iteration: 9\n",
      "new candidats: tensor([[0.4920, 0.7279],\n",
      "        [0.5361, 0.0964],\n",
      "        [0.8784, 0.1026],\n",
      "        [0.4513, 0.7179],\n",
      "        [0.8784, 0.1026]], dtype=torch.float64)\n",
      "new obj: tensor([[0.6764, 0.3552],\n",
      "        [0.1191, 0.0289],\n",
      "        [0.3217, 0.5950],\n",
      "        [0.6198, 0.4409],\n",
      "        [0.3217, 0.5950]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14913176]\n",
      "Time: 6.063000000000102\n",
      "Iteration: 10\n",
      "new candidats: tensor([[0.4710, 0.1530],\n",
      "        [0.9819, 0.1336],\n",
      "        [0.4590, 0.1346],\n",
      "        [0.9919, 0.8851],\n",
      "        [0.9919, 0.8851]], dtype=torch.float64)\n",
      "new obj: tensor([[1.9697e-01, 6.5144e-02],\n",
      "        [1.0759e-01, 1.7223e-02],\n",
      "        [2.0661e-01, 7.1497e-02],\n",
      "        [1.2611e-06, 4.6480e-08],\n",
      "        [1.2611e-06, 4.6480e-08]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14913176]\n",
      "Time: 8.406000000000859\n",
      "Iteration: 11\n",
      "new candidats: tensor([[0.8065, 0.1188],\n",
      "        [0.2940, 0.9117],\n",
      "        [0.2940, 0.9117],\n",
      "        [0.7921, 0.1358],\n",
      "        [0.8046, 0.2679]], dtype=torch.float64)\n",
      "new obj: tensor([[0.5068, 0.4474],\n",
      "        [0.0097, 0.2143],\n",
      "        [0.0097, 0.2143],\n",
      "        [0.5737, 0.2781],\n",
      "        [0.5601, 0.0022]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14913176]\n",
      "Time: 7.75\n",
      "Iteration: 12\n",
      "new candidats: tensor([[0.3726, 0.2621],\n",
      "        [0.3726, 0.2621],\n",
      "        [0.8819, 0.7143],\n",
      "        [0.8819, 0.7143],\n",
      "        [0.8819, 0.7143]], dtype=torch.float64)\n",
      "new obj: tensor([[3.2844e-01, 1.5171e-01],\n",
      "        [3.2844e-01, 1.5171e-01],\n",
      "        [5.2689e-04, 9.2233e-06],\n",
      "        [5.2689e-04, 9.2233e-06],\n",
      "        [5.2689e-04, 9.2233e-06]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14913176]\n",
      "Time: 8.92200000000048\n",
      "Iteration: 13\n",
      "new candidats: tensor([[0.4425, 0.7355],\n",
      "        [0.0705, 0.1195],\n",
      "        [0.4008, 0.7931],\n",
      "        [0.0705, 0.1195],\n",
      "        [0.4441, 0.7712]], dtype=torch.float64)\n",
      "new obj: tensor([[0.5636, 0.5221],\n",
      "        [0.3739, 0.4610],\n",
      "        [0.2810, 0.6999],\n",
      "        [0.3739, 0.4610],\n",
      "        [0.4687, 0.6108]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15155093]\n",
      "Time: 8.656000000000859\n",
      "Iteration: 14\n",
      "new candidats: tensor([[0.6609, 0.9656],\n",
      "        [0.0955, 0.3244],\n",
      "        [0.6609, 0.9656],\n",
      "        [0.0950, 0.3446],\n",
      "        [0.0955, 0.3244]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0057, 0.0059],\n",
      "        [0.3595, 0.4087],\n",
      "        [0.0057, 0.0059],\n",
      "        [0.3354, 0.3820],\n",
      "        [0.3595, 0.4087]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15155093]\n",
      "Time: 10.07799999999952\n",
      "Iteration: 15\n",
      "new candidats: tensor([[0.8053, 0.1968],\n",
      "        [0.1447, 0.9817],\n",
      "        [0.8053, 0.1968],\n",
      "        [0.1447, 0.9817],\n",
      "        [0.1447, 0.9817]], dtype=torch.float64)\n",
      "new obj: tensor([[7.0380e-01, 7.2615e-02],\n",
      "        [2.5584e-04, 5.3848e-03],\n",
      "        [7.0380e-01, 7.2615e-02],\n",
      "        [2.5584e-04, 5.3848e-03],\n",
      "        [2.5584e-04, 5.3848e-03]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15155093]\n",
      "Time: 7.7960000000002765\n",
      "Iteration: 16\n",
      "new candidats: tensor([[0.1315, 0.0371],\n",
      "        [0.6185, 0.6612],\n",
      "        [0.6185, 0.6612],\n",
      "        [0.1315, 0.0371],\n",
      "        [0.1315, 0.0371]], dtype=torch.float64)\n",
      "new obj: tensor([[0.3384, 0.3422],\n",
      "        [0.3255, 0.0253],\n",
      "        [0.3255, 0.0253],\n",
      "        [0.3384, 0.3422],\n",
      "        [0.3384, 0.3422]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15155093]\n",
      "Time: 9.140999999999622\n",
      "Iteration: 1\n",
      "new candidats: tensor([[0.6119, 0.8245],\n",
      "        [0.1816, 0.1478],\n",
      "        [0.2068, 0.0471],\n",
      "        [0.6119, 0.8245],\n",
      "        [0.6119, 0.8245]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1729, 0.0720],\n",
      "        [0.4812, 0.4136],\n",
      "        [0.3731, 0.2955],\n",
      "        [0.1729, 0.0720],\n",
      "        [0.1729, 0.0720]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.04933473]\n",
      "Time: 10.546999999998661\n",
      "Iteration: 2\n",
      "new candidats: tensor([[0.6884, 0.7184],\n",
      "        [0.0839, 0.1769],\n",
      "        [0.0877, 0.6768],\n",
      "        [0.6884, 0.7184],\n",
      "        [0.1293, 0.2033]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1176, 0.0080],\n",
      "        [0.4197, 0.4955],\n",
      "        [0.0251, 0.0316],\n",
      "        [0.1176, 0.0080],\n",
      "        [0.4697, 0.4784]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.06780241]\n",
      "Time: 7.17200000000048\n",
      "Iteration: 3\n",
      "new candidats: tensor([[0.8532, 0.7328],\n",
      "        [0.1976, 0.2006],\n",
      "        [0.6488, 0.7349],\n",
      "        [0.8532, 0.7328],\n",
      "        [0.1976, 0.2006]], dtype=torch.float64)\n",
      "new obj: tensor([[1.3684e-03, 2.6138e-05],\n",
      "        [4.9996e-01, 4.0791e-01],\n",
      "        [2.1892e-01, 2.5883e-02],\n",
      "        [1.3684e-03, 2.6138e-05],\n",
      "        [4.9996e-01, 4.0791e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.06958947]\n",
      "Time: 10.953000000001339\n",
      "Iteration: 4\n",
      "new candidats: tensor([[0.8181, 0.0800],\n",
      "        [0.2392, 0.9154],\n",
      "        [0.8181, 0.0800],\n",
      "        [0.2392, 0.9154],\n",
      "        [0.8181, 0.0800]], dtype=torch.float64)\n",
      "new obj: tensor([[0.3386, 0.5272],\n",
      "        [0.0031, 0.0993],\n",
      "        [0.3386, 0.5272],\n",
      "        [0.0031, 0.0993],\n",
      "        [0.3386, 0.5272]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07291466]\n",
      "Time: 5.843999999999141\n",
      "Iteration: 5\n",
      "new candidats: tensor([[0.8950, 0.0881],\n",
      "        [0.2589, 0.8782],\n",
      "        [0.2589, 0.8782],\n",
      "        [0.9766, 0.0073],\n",
      "        [0.9589, 0.8991]], dtype=torch.float64)\n",
      "new obj: tensor([[2.3931e-01, 4.5360e-01],\n",
      "        [9.3362e-03, 1.9143e-01],\n",
      "        [9.3362e-03, 1.9143e-01],\n",
      "        [2.3136e-02, 5.0889e-03],\n",
      "        [3.4108e-06, 1.2773e-07]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07291466]\n",
      "Time: 8.45299999999952\n",
      "Iteration: 6\n",
      "new candidats: tensor([[0.0278, 0.0189],\n",
      "        [0.0278, 0.0189],\n",
      "        [0.3611, 0.5908],\n",
      "        [0.3611, 0.5908],\n",
      "        [0.0611, 0.4506]], dtype=torch.float64)\n",
      "new obj: tensor([[0.2291, 0.3245],\n",
      "        [0.2291, 0.3245],\n",
      "        [0.2006, 0.0984],\n",
      "        [0.2006, 0.0984],\n",
      "        [0.1792, 0.2279]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07291466]\n",
      "Time: 8.811999999999898\n",
      "Iteration: 7\n",
      "new candidats: tensor([[0.5161, 0.6137],\n",
      "        [0.5161, 0.6137],\n",
      "        [0.1557, 0.2503],\n",
      "        [0.0447, 0.2298],\n",
      "        [0.0447, 0.2298]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4932, 0.0678],\n",
      "        [0.4932, 0.0678],\n",
      "        [0.4727, 0.4420],\n",
      "        [0.3657, 0.4905],\n",
      "        [0.3657, 0.4905]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07300015]\n",
      "Time: 7.09400000000096\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration: 8\n",
      "new candidats: tensor([[0.1976, 0.2006],\n",
      "        [0.1976, 0.2006],\n",
      "        [0.9392, 0.6686],\n",
      "        [0.9392, 0.6686],\n",
      "        [0.9002, 0.6224]], dtype=torch.float64)\n",
      "new obj: tensor([[4.9996e-01, 4.0791e-01],\n",
      "        [4.9996e-01, 4.0791e-01],\n",
      "        [8.2392e-05, 2.6867e-06],\n",
      "        [8.2392e-05, 2.6867e-06],\n",
      "        [3.4634e-04, 1.0282e-05]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07300015]\n",
      "Time: 7.811999999999898\n",
      "Iteration: 9\n",
      "new candidats: tensor([[0.5348, 0.7036],\n",
      "        [0.5348, 0.7036],\n",
      "        [0.8474, 0.0711],\n",
      "        [0.8474, 0.0711],\n",
      "        [0.8358, 0.1148]], dtype=torch.float64)\n",
      "new obj: tensor([[0.6636, 0.1787],\n",
      "        [0.6636, 0.1787],\n",
      "        [0.2748, 0.5919],\n",
      "        [0.2748, 0.5919],\n",
      "        [0.4598, 0.6436]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.10382604]\n",
      "Time: 16.781999999999243\n",
      "Iteration: 10\n",
      "new candidats: tensor([[0.4905, 0.6995],\n",
      "        [0.8411, 0.1672],\n",
      "        [0.8517, 0.1368],\n",
      "        [0.4685, 0.7614],\n",
      "        [0.8411, 0.1672]], dtype=torch.float64)\n",
      "new obj: tensor([[0.7045, 0.2828],\n",
      "        [0.6125, 0.2796],\n",
      "        [0.5039, 0.5339],\n",
      "        [0.5555, 0.5154],\n",
      "        [0.6125, 0.2796]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13365148]\n",
      "Time: 8.890000000001237\n",
      "Iteration: 11\n",
      "new candidats: tensor([[0.1110, 0.1011],\n",
      "        [0.4789, 0.7369],\n",
      "        [0.1640, 0.7482],\n",
      "        [0.8486, 0.1052],\n",
      "        [0.4789, 0.7369]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4008, 0.4332],\n",
      "        [0.6448, 0.4218],\n",
      "        [0.0137, 0.0482],\n",
      "        [0.3993, 0.6961],\n",
      "        [0.6448, 0.4218]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15475833]\n",
      "Time: 11.28099999999904\n",
      "Iteration: 12\n",
      "new candidats: tensor([[0.0839, 0.1769],\n",
      "        [0.5749, 0.7289],\n",
      "        [0.0839, 0.1769],\n",
      "        [0.5749, 0.7289],\n",
      "        [0.4789, 0.7369]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4197, 0.4955],\n",
      "        [0.5097, 0.1184],\n",
      "        [0.4197, 0.4955],\n",
      "        [0.5097, 0.1184],\n",
      "        [0.6448, 0.4218]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15475833]\n",
      "Time: 9.39100000000144\n",
      "Iteration: 13\n",
      "new candidats: tensor([[0.4789, 0.7369],\n",
      "        [0.0765, 0.9724],\n",
      "        [0.4905, 0.6995],\n",
      "        [0.1051, 0.4782],\n",
      "        [0.4789, 0.7369]], dtype=torch.float64)\n",
      "new obj: tensor([[6.4479e-01, 4.2176e-01],\n",
      "        [2.4073e-04, 1.1352e-03],\n",
      "        [7.0453e-01, 2.8284e-01],\n",
      "        [1.6986e-01, 1.8722e-01],\n",
      "        [6.4479e-01, 4.2176e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15475833]\n",
      "Time: 7.78099999999904\n",
      "Iteration: 14\n",
      "new candidats: tensor([[0.1989, 0.1173],\n",
      "        [0.8517, 0.1368],\n",
      "        [0.8363, 0.1257],\n",
      "        [0.2000, 0.6196],\n",
      "        [0.2000, 0.6196]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4590, 0.3730],\n",
      "        [0.5039, 0.5339],\n",
      "        [0.5004, 0.5909],\n",
      "        [0.0610, 0.0634],\n",
      "        [0.0610, 0.0634]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15706841]\n",
      "Time: 9.593000000000757\n",
      "Iteration: 15\n",
      "new candidats: tensor([[0.8363, 0.1257],\n",
      "        [0.2163, 0.8734],\n",
      "        [0.2163, 0.8734],\n",
      "        [0.8363, 0.1257],\n",
      "        [0.2025, 0.4724]], dtype=torch.float64)\n",
      "new obj: tensor([[0.5004, 0.5909],\n",
      "        [0.0045, 0.1002],\n",
      "        [0.0045, 0.1002],\n",
      "        [0.5004, 0.5909],\n",
      "        [0.1984, 0.1593]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15706841]\n",
      "Time: 7.688000000000102\n",
      "Iteration: 16\n",
      "new candidats: tensor([[0.0899, 0.2664],\n",
      "        [0.7278, 0.9340],\n",
      "        [0.7278, 0.9340],\n",
      "        [0.7278, 0.9340],\n",
      "        [0.0899, 0.2664]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4067, 0.4709],\n",
      "        [0.0034, 0.0013],\n",
      "        [0.0034, 0.0013],\n",
      "        [0.0034, 0.0013],\n",
      "        [0.4067, 0.4709]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15706841]\n",
      "Time: 9.734000000000378\n",
      "Iteration: 1\n",
      "new candidats: tensor([[0.8621, 0.4246],\n",
      "        [0.0099, 0.1157],\n",
      "        [0.2238, 0.0748],\n",
      "        [0.0084, 0.5283],\n",
      "        [0.0855, 0.0574]], dtype=torch.float64)\n",
      "new obj: tensor([[4.7504e-02, 1.0442e-04],\n",
      "        [2.9119e-01, 4.3727e-01],\n",
      "        [4.0810e-01, 3.0578e-01],\n",
      "        [8.2151e-02, 1.2397e-01],\n",
      "        [3.2917e-01, 3.8659e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.03676074]\n",
      "Time: 15.281000000000859\n",
      "Iteration: 2\n",
      "new candidats: tensor([[0.6580, 0.8971],\n",
      "        [0.5030, 0.8939],\n",
      "        [0.6580, 0.8971],\n",
      "        [0.1129, 0.2028],\n",
      "        [0.2147, 0.2050]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0289, 0.0157],\n",
      "        [0.1071, 0.2651],\n",
      "        [0.0289, 0.0157],\n",
      "        [0.4547, 0.4886],\n",
      "        [0.4985, 0.3848]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.06625596]\n",
      "Time: 11.938000000000102\n",
      "Iteration: 3\n",
      "new candidats: tensor([[0.7728, 0.7596],\n",
      "        [0.1693, 0.2364],\n",
      "        [0.7728, 0.7596],\n",
      "        [0.1541, 0.1854],\n",
      "        [0.7728, 0.7596]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0143, 0.0006],\n",
      "        [0.4860, 0.4347],\n",
      "        [0.0143, 0.0006],\n",
      "        [0.4857, 0.4564],\n",
      "        [0.0143, 0.0006]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.06849157]\n",
      "Time: 7.061999999999898\n",
      "Iteration: 4\n",
      "new candidats: tensor([[0.4717, 0.9547],\n",
      "        [0.1042, 0.1905],\n",
      "        [0.4545, 0.7409],\n",
      "        [0.0777, 0.2226],\n",
      "        [0.4717, 0.9547]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0264, 0.1636],\n",
      "        [0.4453, 0.4922],\n",
      "        [0.5863, 0.5087],\n",
      "        [0.4121, 0.4964],\n",
      "        [0.0264, 0.1636]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.10137922]\n",
      "Time: 7.561999999999898\n",
      "Iteration: 5\n",
      "new candidats: tensor([[0.3690, 0.7527],\n",
      "        [0.9454, 0.4533],\n",
      "        [0.4054, 0.7527],\n",
      "        [0.4709, 0.7349],\n",
      "        [0.9454, 0.4533]], dtype=torch.float64)\n",
      "new obj: tensor([[2.6610e-01, 6.0024e-01],\n",
      "        [1.0051e-02, 1.5519e-05],\n",
      "        [3.9618e-01, 6.2755e-01],\n",
      "        [6.3695e-01, 4.4231e-01],\n",
      "        [1.0051e-02, 1.5519e-05]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13188349]\n",
      "Time: 13.235000000000582\n",
      "Iteration: 6\n",
      "new candidats: tensor([[0.8913, 0.2734],\n",
      "        [0.4520, 0.7396],\n",
      "        [0.4470, 0.5420],\n",
      "        [0.4970, 0.7356],\n",
      "        [0.9021, 0.0568]], dtype=torch.float64)\n",
      "new obj: tensor([[0.3537, 0.0013],\n",
      "        [0.5827, 0.5116],\n",
      "        [0.2287, 0.0421],\n",
      "        [0.6613, 0.3567],\n",
      "        [0.1499, 0.2801]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13572517]\n",
      "Time: 7.436999999999898\n",
      "Iteration: 7\n",
      "new candidats: tensor([[0.9602, 0.0381],\n",
      "        [0.4709, 0.7349],\n",
      "        [0.9602, 0.0381],\n",
      "        [0.4520, 0.7396],\n",
      "        [0.9377, 0.7499]], dtype=torch.float64)\n",
      "new obj: tensor([[5.2613e-02, 2.8721e-02],\n",
      "        [6.3695e-01, 4.4231e-01],\n",
      "        [5.2613e-02, 2.8721e-02],\n",
      "        [5.8273e-01, 5.1160e-01],\n",
      "        [5.5444e-05, 1.2577e-06]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13572517]\n",
      "Time: 4.718000000000757\n",
      "Iteration: 8\n",
      "new candidats: tensor([[0.4520, 0.7396],\n",
      "        [0.8150, 0.2064],\n",
      "        [0.7841, 0.7636],\n",
      "        [0.4114, 0.7795],\n",
      "        [0.7068, 0.0182]], dtype=torch.float64)\n",
      "new obj: tensor([[5.8273e-01, 5.1160e-01],\n",
      "        [6.9523e-01, 5.7466e-02],\n",
      "        [1.0251e-02, 4.2675e-04],\n",
      "        [3.4916e-01, 6.8268e-01],\n",
      "        [1.0017e-01, 5.1161e-03]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14208477]\n",
      "Time: 7.531999999999243\n",
      "Iteration: 9\n",
      "new candidats: tensor([[0.4492, 0.3431],\n",
      "        [0.8311, 0.9834],\n",
      "        [0.4520, 0.7396],\n",
      "        [0.6200, 0.9782],\n",
      "        [0.8215, 0.3498]], dtype=torch.float64)\n",
      "new obj: tensor([[1.7972e-01, 6.4182e-02],\n",
      "        [5.4181e-05, 1.2179e-05],\n",
      "        [5.8273e-01, 5.1160e-01],\n",
      "        [7.1454e-03, 1.2734e-02],\n",
      "        [2.2568e-01, 3.2703e-04]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14208477]\n",
      "Time: 8.656999999999243\n",
      "Iteration: 10\n",
      "new candidats: tensor([[0.7479, 0.1352],\n",
      "        [0.4520, 0.7396],\n",
      "        [0.1829, 0.1598],\n",
      "        [0.7363, 0.7651],\n",
      "        [0.2052, 0.3845]], dtype=torch.float64)\n",
      "new obj: tensor([[0.5066, 0.0695],\n",
      "        [0.5827, 0.5116],\n",
      "        [0.4882, 0.4178],\n",
      "        [0.0350, 0.0023],\n",
      "        [0.3267, 0.2601]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14208477]\n",
      "Time: 6.109000000000378\n",
      "Iteration: 11\n",
      "new candidats: tensor([[0.0566, 0.1074],\n",
      "        [0.0578, 0.0826],\n",
      "        [0.0578, 0.0826],\n",
      "        [0.4520, 0.7396],\n",
      "        [0.4085, 0.7646]], dtype=torch.float64)\n",
      "new obj: tensor([[0.3473, 0.4482],\n",
      "        [0.3269, 0.4201],\n",
      "        [0.3269, 0.4201],\n",
      "        [0.5827, 0.5116],\n",
      "        [0.3791, 0.6573]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14297738]\n",
      "Time: 6.265999999999622\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration: 12\n",
      "new candidats: tensor([[0.1494, 0.1233],\n",
      "        [0.1455, 0.5691],\n",
      "        [0.1494, 0.1233],\n",
      "        [0.4162, 0.7949],\n",
      "        [0.4520, 0.7396]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4499, 0.4293],\n",
      "        [0.0883, 0.0868],\n",
      "        [0.4499, 0.4293],\n",
      "        [0.3176, 0.6913],\n",
      "        [0.5827, 0.5116]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14369564]\n",
      "Time: 6.406000000000859\n",
      "Iteration: 13\n",
      "new candidats: tensor([[0.4229, 0.2419],\n",
      "        [0.9058, 0.2471],\n",
      "        [0.9058, 0.2471],\n",
      "        [0.4520, 0.7396],\n",
      "        [0.4085, 0.7646]], dtype=torch.float64)\n",
      "new obj: tensor([[0.2633, 0.1031],\n",
      "        [0.3590, 0.0050],\n",
      "        [0.3590, 0.0050],\n",
      "        [0.5827, 0.5116],\n",
      "        [0.3791, 0.6573]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14369564]\n",
      "Time: 9.764999999999418\n",
      "Iteration: 14\n",
      "new candidats: tensor([[0.6079, 0.6771],\n",
      "        [0.0566, 0.1074],\n",
      "        [0.6379, 0.1292],\n",
      "        [0.0566, 0.1074],\n",
      "        [0.4520, 0.7396]], dtype=torch.float64)\n",
      "new obj: tensor([[0.3846, 0.0387],\n",
      "        [0.3473, 0.4482],\n",
      "        [0.1893, 0.0084],\n",
      "        [0.3473, 0.4482],\n",
      "        [0.5827, 0.5116]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14369564]\n",
      "Time: 7.360000000000582\n",
      "Iteration: 15\n",
      "new candidats: tensor([[0.1182, 0.3166],\n",
      "        [0.1182, 0.3166],\n",
      "        [0.8918, 0.6777],\n",
      "        [0.1182, 0.3166],\n",
      "        [0.8918, 0.6777]], dtype=torch.float64)\n",
      "new obj: tensor([[3.8804e-01, 4.0980e-01],\n",
      "        [3.8804e-01, 4.0980e-01],\n",
      "        [3.9538e-04, 8.0866e-06],\n",
      "        [3.8804e-01, 4.0980e-01],\n",
      "        [3.9538e-04, 8.0866e-06]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14369564]\n",
      "Time: 7.561999999999898\n",
      "Iteration: 16\n",
      "new candidats: tensor([[0.7887, 0.7751],\n",
      "        [0.3211, 0.1757],\n",
      "        [0.3211, 0.1757],\n",
      "        [0.4520, 0.7396],\n",
      "        [0.7887, 0.7751]], dtype=torch.float64)\n",
      "new obj: tensor([[8.2923e-03, 3.6866e-04],\n",
      "        [4.1319e-01, 2.2566e-01],\n",
      "        [4.1319e-01, 2.2566e-01],\n",
      "        [5.8273e-01, 5.1160e-01],\n",
      "        [8.2923e-03, 3.6866e-04]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14369564]\n",
      "Time: 7.468999999999141\n",
      "Iteration: 1\n",
      "new candidats: tensor([[0.5953, 0.8280],\n",
      "        [0.1663, 0.3157],\n",
      "        [0.5922, 0.9275],\n",
      "        [0.1895, 0.1922],\n",
      "        [0.5922, 0.9275]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1966, 0.1002],\n",
      "        [0.4170, 0.3766],\n",
      "        [0.0345, 0.0490],\n",
      "        [0.4989, 0.4179],\n",
      "        [0.0345, 0.0490]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.05217929]\n",
      "Time: 6.234000000000378\n",
      "Iteration: 2\n",
      "new candidats: tensor([[0.1293, 0.0836],\n",
      "        [0.1434, 0.9266],\n",
      "        [0.7197, 0.9419],\n",
      "        [0.7197, 0.9419],\n",
      "        [0.1150, 0.1999]], dtype=torch.float64)\n",
      "new obj: tensor([[0.3965, 0.4039],\n",
      "        [0.0007, 0.0123],\n",
      "        [0.0034, 0.0015],\n",
      "        [0.0034, 0.0015],\n",
      "        [0.4569, 0.4875]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.06769961]\n",
      "Time: 4.343999999999141\n",
      "Iteration: 3\n",
      "new candidats: tensor([[0.5577, 0.4669],\n",
      "        [0.0655, 0.2092],\n",
      "        [0.0916, 0.2006],\n",
      "        [0.5577, 0.4669],\n",
      "        [0.1501, 0.2205]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0816, 0.0113],\n",
      "        [0.3984, 0.4993],\n",
      "        [0.4317, 0.4971],\n",
      "        [0.0816, 0.0113],\n",
      "        [0.4821, 0.4591]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07101189]\n",
      "Time: 13.71900000000096\n",
      "Iteration: 4\n",
      "new candidats: tensor([[0.9214, 0.8767],\n",
      "        [0.0608, 0.1640],\n",
      "        [0.9214, 0.8767],\n",
      "        [0.0608, 0.1640],\n",
      "        [0.2149, 0.1982]], dtype=torch.float64)\n",
      "new obj: tensor([[2.2889e-05, 8.4016e-07],\n",
      "        [3.8610e-01, 4.9143e-01],\n",
      "        [2.2889e-05, 8.4016e-07],\n",
      "        [3.8610e-01, 4.9143e-01],\n",
      "        [4.9860e-01, 3.8458e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07101189]\n",
      "Time: 7.03099999999904\n",
      "Iteration: 5\n",
      "new candidats: tensor([[0.9374, 0.5229],\n",
      "        [0.9374, 0.5229],\n",
      "        [0.1337, 0.0455],\n",
      "        [0.1337, 0.0455],\n",
      "        [0.9187, 0.4909]], dtype=torch.float64)\n",
      "new obj: tensor([[1.6461e-03, 1.1198e-05],\n",
      "        [1.6461e-03, 1.1198e-05],\n",
      "        [3.5112e-01, 3.5259e-01],\n",
      "        [3.5112e-01, 3.5259e-01],\n",
      "        [5.3219e-03, 2.1380e-05]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07101189]\n",
      "Time: 7.46900000000096\n",
      "Iteration: 6\n",
      "new candidats: tensor([[0.1952, 0.1977],\n",
      "        [0.6785, 0.6759],\n",
      "        [0.2031, 0.1738],\n",
      "        [0.6785, 0.6759],\n",
      "        [0.2031, 0.1738]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4998, 0.4110],\n",
      "        [0.1400, 0.0070],\n",
      "        [0.4957, 0.3973],\n",
      "        [0.1400, 0.0070],\n",
      "        [0.4957, 0.3973]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.0711807]\n",
      "Time: 8.561999999999898\n",
      "Iteration: 7\n",
      "new candidats: tensor([[0.9199, 0.9680],\n",
      "        [0.3237, 0.1613],\n",
      "        [0.3237, 0.1613],\n",
      "        [0.3237, 0.1613],\n",
      "        [0.9199, 0.9680]], dtype=torch.float64)\n",
      "new obj: tensor([[3.3455e-06, 2.6825e-07],\n",
      "        [4.0534e-01, 2.1954e-01],\n",
      "        [4.0534e-01, 2.1954e-01],\n",
      "        [4.0534e-01, 2.1954e-01],\n",
      "        [3.3455e-06, 2.6825e-07]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.0711807]\n",
      "Time: 7.296999999998661\n",
      "Iteration: 8\n",
      "new candidats: tensor([[0.8094, 0.7307],\n",
      "        [0.2620, 0.2438],\n",
      "        [0.8094, 0.7307],\n",
      "        [0.8094, 0.7307],\n",
      "        [0.2620, 0.2438]], dtype=torch.float64)\n",
      "new obj: tensor([[5.7053e-03, 1.4192e-04],\n",
      "        [4.6522e-01, 3.0785e-01],\n",
      "        [5.7053e-03, 1.4192e-04],\n",
      "        [5.7053e-03, 1.4192e-04],\n",
      "        [4.6522e-01, 3.0785e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.0711807]\n",
      "Time: 7.108999999998559\n",
      "Iteration: 9\n",
      "new candidats: tensor([[0.9816, 0.8081],\n",
      "        [0.4830, 0.1096],\n",
      "        [0.4777, 0.1273],\n",
      "        [0.9816, 0.8081],\n",
      "        [0.5469, 0.1498]], dtype=torch.float64)\n",
      "new obj: tensor([[5.9640e-06, 1.8298e-07],\n",
      "        [1.6894e-01, 5.3532e-02],\n",
      "        [1.8145e-01, 5.8586e-02],\n",
      "        [5.9640e-06, 1.8298e-07],\n",
      "        [1.3272e-01, 2.8216e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.0711807]\n",
      "Time: 12.453000000001339\n",
      "Iteration: 10\n",
      "new candidats: tensor([[0.8448, 0.5486],\n",
      "        [0.1337, 0.0455],\n",
      "        [0.1337, 0.0455],\n",
      "        [0.8448, 0.5486],\n",
      "        [0.8448, 0.5486]], dtype=torch.float64)\n",
      "new obj: tensor([[2.6439e-03, 6.1779e-05],\n",
      "        [3.5112e-01, 3.5259e-01],\n",
      "        [3.5112e-01, 3.5259e-01],\n",
      "        [2.6439e-03, 6.1779e-05],\n",
      "        [2.6439e-03, 6.1779e-05]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.0711807]\n",
      "Time: 5.343999999999141\n",
      "Iteration: 11\n",
      "new candidats: tensor([[0.9004, 0.0871],\n",
      "        [0.4689, 0.5659],\n",
      "        [0.9004, 0.0871],\n",
      "        [0.4689, 0.5659],\n",
      "        [0.9004, 0.0871]], dtype=torch.float64)\n",
      "new obj: tensor([[0.2246, 0.4079],\n",
      "        [0.3095, 0.0485],\n",
      "        [0.2246, 0.4079],\n",
      "        [0.3095, 0.0485],\n",
      "        [0.2246, 0.4079]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.0711807]\n",
      "Time: 4.390000000001237\n",
      "Iteration: 12\n",
      "new candidats: tensor([[0.8491, 0.2010],\n",
      "        [0.8491, 0.2010],\n",
      "        [0.8279, 0.2260],\n",
      "        [0.0826, 0.6028],\n",
      "        [0.0826, 0.6028]], dtype=torch.float64)\n",
      "new obj: tensor([[0.6229, 0.0914],\n",
      "        [0.6229, 0.0914],\n",
      "        [0.6545, 0.0269],\n",
      "        [0.0555, 0.0663],\n",
      "        [0.0555, 0.0663]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.0711807]\n",
      "Time: 6.296999999998661\n",
      "Iteration: 13\n",
      "new candidats: tensor([[0.9961, 0.2083],\n",
      "        [0.3101, 0.6420],\n",
      "        [0.9933, 0.1779],\n",
      "        [0.3101, 0.6420],\n",
      "        [0.3101, 0.6420]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1023, 0.0010],\n",
      "        [0.1348, 0.1552],\n",
      "        [0.1058, 0.0034],\n",
      "        [0.1348, 0.1552],\n",
      "        [0.1348, 0.1552]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.0711807]\n",
      "Time: 6.875\n",
      "Iteration: 14\n",
      "new candidats: tensor([[0.8701, 0.1728],\n",
      "        [0.0884, 0.7420],\n",
      "        [0.1333, 0.1517],\n",
      "        [0.8035, 0.1553],\n",
      "        [0.0884, 0.7420]], dtype=torch.float64)\n",
      "new obj: tensor([[0.5295, 0.2239],\n",
      "        [0.0110, 0.0173],\n",
      "        [0.4593, 0.4619],\n",
      "        [0.6381, 0.2471],\n",
      "        [0.0110, 0.0173]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07478156]\n",
      "Time: 6.96900000000096\n",
      "Iteration: 15\n",
      "new candidats: tensor([[0.1257, 0.6966],\n",
      "        [0.8035, 0.1553],\n",
      "        [0.8471, 0.1173],\n",
      "        [0.1257, 0.6966],\n",
      "        [0.1257, 0.6966]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0220, 0.0316],\n",
      "        [0.6381, 0.2471],\n",
      "        [0.4475, 0.6585],\n",
      "        [0.0220, 0.0316],\n",
      "        [0.0220, 0.0316]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.10905082]\n",
      "Time: 8.734000000000378\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration: 16\n",
      "new candidats: tensor([[0.8035, 0.1553],\n",
      "        [0.8152, 0.0976],\n",
      "        [0.3371, 0.4662],\n",
      "        [0.3371, 0.4662],\n",
      "        [0.3371, 0.4662]], dtype=torch.float64)\n",
      "new obj: tensor([[0.6381, 0.2471],\n",
      "        [0.4135, 0.5490],\n",
      "        [0.1751, 0.0867],\n",
      "        [0.1751, 0.0867],\n",
      "        [0.1751, 0.0867]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.10905082]\n",
      "Time: 10.139999999999418\n",
      "Iteration: 1\n",
      "new candidats: tensor([[0.1677, 0.2947],\n",
      "        [0.1554, 0.0782],\n",
      "        [0.9837, 0.0077],\n",
      "        [0.1513, 0.2121],\n",
      "        [0.9690, 0.9059]], dtype=torch.float64)\n",
      "new obj: tensor([[4.4123e-01, 3.9669e-01],\n",
      "        [4.0516e-01, 3.7923e-01],\n",
      "        [2.0519e-02, 3.5742e-03],\n",
      "        [4.8452e-01, 4.5949e-01],\n",
      "        [2.0167e-06, 7.7750e-08]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.05976948]\n",
      "Time: 8.156999999999243\n",
      "Iteration: 2\n",
      "new candidats: tensor([[0.1765, 0.2311],\n",
      "        [0.8852, 0.9085],\n",
      "        [0.4284, 0.2231],\n",
      "        [0.8852, 0.9085],\n",
      "        [0.1233, 0.2103]], dtype=torch.float64)\n",
      "new obj: tensor([[4.9058e-01, 4.2867e-01],\n",
      "        [5.0457e-05, 3.2373e-06],\n",
      "        [2.5939e-01, 9.9686e-02],\n",
      "        [5.0457e-05, 3.2373e-06],\n",
      "        [4.6393e-01, 4.8192e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.0661895]\n",
      "Time: 6.031000000000859\n",
      "Iteration: 3\n",
      "new candidats: tensor([[0.6367, 0.6611],\n",
      "        [0.6367, 0.6611],\n",
      "        [0.0620, 0.2092],\n",
      "        [0.6367, 0.6611],\n",
      "        [0.0793, 0.1886]], dtype=torch.float64)\n",
      "new obj: tensor([[0.2583, 0.0169],\n",
      "        [0.2583, 0.0169],\n",
      "        [0.3937, 0.4991],\n",
      "        [0.2583, 0.0169],\n",
      "        [0.4161, 0.4987]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.06930715]\n",
      "Time: 6.906000000000859\n",
      "Iteration: 4\n",
      "new candidats: tensor([[0.8567, 0.8085],\n",
      "        [0.2163, 0.1779],\n",
      "        [0.8315, 0.1893],\n",
      "        [0.1877, 0.1720],\n",
      "        [0.8567, 0.8085]], dtype=torch.float64)\n",
      "new obj: tensor([[6.9220e-04, 2.2723e-05],\n",
      "        [4.9532e-01, 3.8027e-01],\n",
      "        [6.6573e-01, 1.3323e-01],\n",
      "        [4.9419e-01, 4.1637e-01],\n",
      "        [6.9220e-04, 2.2723e-05]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07019061]\n",
      "Time: 6.5\n",
      "Iteration: 5\n",
      "new candidats: tensor([[0.1458, 0.9947],\n",
      "        [0.6754, 0.4744],\n",
      "        [0.2997, 0.9777],\n",
      "        [0.1774, 0.4869],\n",
      "        [0.6754, 0.4744]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0002, 0.0043],\n",
      "        [0.0308, 0.0021],\n",
      "        [0.0022, 0.0875],\n",
      "        [0.1779, 0.1551],\n",
      "        [0.0308, 0.0021]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07019061]\n",
      "Time: 9.45299999999952\n",
      "Iteration: 6\n",
      "new candidats: tensor([[0.0553, 0.0119],\n",
      "        [0.8017, 0.9185],\n",
      "        [0.0088, 0.0722],\n",
      "        [0.8017, 0.9185],\n",
      "        [0.8017, 0.9185]], dtype=torch.float64)\n",
      "new obj: tensor([[2.4729e-01, 3.2036e-01],\n",
      "        [6.8834e-04, 1.0987e-04],\n",
      "        [2.5818e-01, 3.8907e-01],\n",
      "        [6.8834e-04, 1.0987e-04],\n",
      "        [6.8834e-04, 1.0987e-04]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07019061]\n",
      "Time: 8.639999999999418\n",
      "Iteration: 7\n",
      "new candidats: tensor([[0.7510, 0.8899],\n",
      "        [0.2181, 0.3245],\n",
      "        [0.7510, 0.8899],\n",
      "        [0.7510, 0.8899],\n",
      "        [0.2181, 0.3245]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0050, 0.0010],\n",
      "        [0.4102, 0.3131],\n",
      "        [0.0050, 0.0010],\n",
      "        [0.0050, 0.0010],\n",
      "        [0.4102, 0.3131]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07019061]\n",
      "Time: 4.468999999999141\n",
      "Iteration: 8\n",
      "new candidats: tensor([[0.5300, 0.1111],\n",
      "        [0.7856, 0.5459],\n",
      "        [0.7856, 0.5459],\n",
      "        [0.5300, 0.1111],\n",
      "        [0.7856, 0.5459]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1285, 0.0322],\n",
      "        [0.0069, 0.0002],\n",
      "        [0.0069, 0.0002],\n",
      "        [0.1285, 0.0322],\n",
      "        [0.0069, 0.0002]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07019061]\n",
      "Time: 8.671000000000276\n",
      "Iteration: 9\n",
      "new candidats: tensor([[0.3840, 0.2987],\n",
      "        [0.9329, 0.8650],\n",
      "        [0.3840, 0.2987],\n",
      "        [0.9329, 0.8650],\n",
      "        [0.9329, 0.8650]], dtype=torch.float64)\n",
      "new obj: tensor([[2.9013e-01, 1.2909e-01],\n",
      "        [1.7723e-05, 5.6702e-07],\n",
      "        [2.9013e-01, 1.2909e-01],\n",
      "        [1.7723e-05, 5.6702e-07],\n",
      "        [1.7723e-05, 5.6702e-07]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07019061]\n",
      "Time: 6.813000000000102\n",
      "Iteration: 10\n",
      "new candidats: tensor([[0.8350, 0.8961],\n",
      "        [0.1233, 0.2103],\n",
      "        [0.1233, 0.2103],\n",
      "        [0.8350, 0.8961],\n",
      "        [0.2163, 0.1779]], dtype=torch.float64)\n",
      "new obj: tensor([[3.8150e-04, 3.5057e-05],\n",
      "        [4.6393e-01, 4.8192e-01],\n",
      "        [4.6393e-01, 4.8192e-01],\n",
      "        [3.8150e-04, 3.5057e-05],\n",
      "        [4.9532e-01, 3.8027e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07019061]\n",
      "Time: 8.735000000000582\n",
      "Iteration: 11\n",
      "new candidats: tensor([[0.7712, 0.9870],\n",
      "        [0.7712, 0.9870],\n",
      "        [0.1513, 0.2121],\n",
      "        [0.2163, 0.1779],\n",
      "        [0.1513, 0.2121]], dtype=torch.float64)\n",
      "new obj: tensor([[2.9153e-04, 1.2452e-04],\n",
      "        [2.9153e-04, 1.2452e-04],\n",
      "        [4.8452e-01, 4.5949e-01],\n",
      "        [4.9532e-01, 3.8027e-01],\n",
      "        [4.8452e-01, 4.5949e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07019061]\n",
      "Time: 9.609000000000378\n",
      "Iteration: 12\n",
      "new candidats: tensor([[0.0682, 0.7296],\n",
      "        [0.5282, 0.1838],\n",
      "        [0.5282, 0.1838],\n",
      "        [0.5282, 0.1838],\n",
      "        [0.0682, 0.7296]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0121, 0.0172],\n",
      "        [0.1468, 0.0361],\n",
      "        [0.1468, 0.0361],\n",
      "        [0.1468, 0.0361],\n",
      "        [0.0121, 0.0172]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07019061]\n",
      "Time: 7.218999999999141\n",
      "Iteration: 13\n",
      "new candidats: tensor([[0.1513, 0.2121],\n",
      "        [0.1513, 0.2121],\n",
      "        [0.9008, 0.8356],\n",
      "        [0.1877, 0.1720],\n",
      "        [0.9008, 0.8356]], dtype=torch.float64)\n",
      "new obj: tensor([[4.8452e-01, 4.5949e-01],\n",
      "        [4.8452e-01, 4.5949e-01],\n",
      "        [9.7710e-05, 2.9309e-06],\n",
      "        [4.9419e-01, 4.1637e-01],\n",
      "        [9.7710e-05, 2.9309e-06]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07019061]\n",
      "Time: 9.218999999999141\n",
      "Iteration: 14\n",
      "new candidats: tensor([[0.3959, 0.1547],\n",
      "        [0.8208, 0.7941],\n",
      "        [0.8208, 0.7941],\n",
      "        [0.3959, 0.1547],\n",
      "        [0.8208, 0.7941]], dtype=torch.float64)\n",
      "new obj: tensor([[3.0182e-01, 1.2919e-01],\n",
      "        [2.6680e-03, 1.0513e-04],\n",
      "        [2.6680e-03, 1.0513e-04],\n",
      "        [3.0182e-01, 1.2919e-01],\n",
      "        [2.6680e-03, 1.0513e-04]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07019061]\n",
      "Time: 8.04700000000048\n",
      "Iteration: 15\n",
      "new candidats: tensor([[0.1988, 0.6361],\n",
      "        [0.2113, 0.6172],\n",
      "        [0.9238, 0.1963],\n",
      "        [0.2020, 0.6112],\n",
      "        [0.9238, 0.1963]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0525, 0.0619],\n",
      "        [0.0644, 0.0664],\n",
      "        [0.3257, 0.0368],\n",
      "        [0.0660, 0.0652],\n",
      "        [0.3257, 0.0368]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07019061]\n",
      "Time: 8.359000000000378\n",
      "Iteration: 16\n",
      "new candidats: tensor([[0.1802, 0.1240],\n",
      "        [0.1802, 0.1240],\n",
      "        [0.1802, 0.1240],\n",
      "        [0.8306, 0.7006],\n",
      "        [0.8306, 0.7006]], dtype=torch.float64)\n",
      "new obj: tensor([[4.6292e-01, 3.9971e-01],\n",
      "        [4.6292e-01, 3.9971e-01],\n",
      "        [4.6292e-01, 3.9971e-01],\n",
      "        [3.1184e-03, 5.6003e-05],\n",
      "        [3.1184e-03, 5.6003e-05]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07019061]\n",
      "Time: 9.45299999999952\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.10.4"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
