{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 4,
   "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": 5,
   "id": "85a49017",
   "metadata": {},
   "outputs": [],
   "source": [
    "from botorch.models.gp_regression import FixedNoiseGP\n",
    "from botorch.models.model_list_gp_regression import ModelListGP\n",
    "from botorch.models.transforms.outcome import Standardize\n",
    "from gpytorch.mlls.sum_marginal_log_likelihood import SumMarginalLogLikelihood\n",
    "from botorch.utils.transforms import unnormalize, normalize\n",
    "from botorch.utils.sampling import draw_sobol_samples\n",
    "from botorch.acquisition import AcquisitionFunction\n",
    "from botorch.models import SingleTaskGP\n",
    "from gpytorch.mlls import ExactMarginalLogLikelihood\n",
    "from botorch import fit_gpytorch_mll\n",
    "from botorch.test_functions.multi_objective import DTLZ2, GMM, ZDT2, VehicleSafety\n",
    "#NOISE_SE = torch.tensor([0.00, 0.00, 0.00], **tkwargs)\n",
    "NOISE_SE = torch.tensor([0.00, 0.00], **tkwargs)\n",
    "#problem = DTLZ2(num_objectives=3, dim=4, negate=True).to(**tkwargs)\n",
    "problem = GMM(negate=True).to(**tkwargs)\n",
    "#problem = ZDT2(dim=6, negate=True).to(**tkwargs)\n",
    "#problem = VehicleSafety(negate=True).to(**tkwargs)\n",
    "def initialize_model(train_x, train_obj):\n",
    "    # define models for objective and constraint\n",
    "    #train_x = normalize(train_x, problem.bounds)\n",
    "    models = []\n",
    "    for i in range(train_obj.shape[-1]):\n",
    "        train_y = train_obj[..., i : i + 1]\n",
    "        train_yvar = torch.full_like(train_y, NOISE_SE[i] ** 2)\n",
    "        models.append(\n",
    "            FixedNoiseGP(\n",
    "                train_x, train_y, train_yvar, outcome_transform=Standardize(m=1)\n",
    "            )\n",
    "        )\n",
    "    model = ModelListGP(*models)\n",
    "    mll = SumMarginalLogLikelihood(model.likelihood, model)\n",
    "    return mll, model\n",
    "\n",
    "def generate_initial_data(n=10, seed=42):\n",
    "    # generate training data\n",
    "    train_x = draw_sobol_samples(bounds=problem.bounds, n=n, q=1, seed=seed).squeeze(1)\n",
    "    train_obj_true = problem(train_x)\n",
    "    train_obj = train_obj_true + torch.randn_like(train_obj_true) * NOISE_SE\n",
    "    return train_x, train_obj, train_obj_true"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "47e97107",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "from botorch.models.model import Model\n",
    "from typing import Any, Callable, Optional\n",
    "from botorch.optim.optimize import optimize_acqf, optimize_acqf_list\n",
    "from botorch.acquisition.objective import GenericMCObjective\n",
    "from botorch.utils.multi_objective.scalarization import get_chebyshev_scalarization\n",
    "from botorch.utils.multi_objective.box_decompositions.non_dominated import (\n",
    "    FastNondominatedPartitioning,\n",
    ")\n",
    "from botorch.utils.multi_objective.box_decompositions.dominated import (\n",
    "    DominatedPartitioning,\n",
    ")\n",
    "from botorch.acquisition.multi_objective.monte_carlo import (\n",
    "    qExpectedHypervolumeImprovement,\n",
    ")\n",
    "from botorch.utils.sampling import sample_simplex\n",
    "from botorch.acquisition.multi_objective.utils import (\n",
    "    sample_optimal_points,\n",
    "    random_search_optimizer,\n",
    "    compute_sample_box_decomposition\n",
    ")\n",
    "from botorch.sampling.normal import SobolQMCNormalSampler\n",
    "from torch import Tensor\n",
    "from botorch.utils.multi_objective.pareto import is_non_dominated\n",
    "\n",
    "\n",
    "NUM_RESTARTS = 10 \n",
    "RAW_SAMPLES = 512 \n",
    "\n",
    "\n",
    "def optimize_qehvi_and_get_observation(model, train_x, train_obj, sampler, X_test, q):\n",
    "    \"\"\"Optimizes the qEHVI acquisition function, and returns a new candidate and observation.\"\"\"\n",
    "    # partition non-dominated space into disjoint rectangles\n",
    "    with torch.no_grad():\n",
    "        pred = model.posterior(train_x).mean\n",
    "        \n",
    "    partitioning = FastNondominatedPartitioning(\n",
    "        ref_point=torch.tensor(problem.ref_point).reshape(-1).to(**tkwargs),\n",
    "        Y=pred,\n",
    "    )\n",
    "    acq_func = qExpectedHypervolumeImprovement(\n",
    "        model=model,\n",
    "        ref_point=torch.tensor(problem.ref_point).reshape(-1).to(**tkwargs),\n",
    "        partitioning=partitioning,\n",
    "        sampler=sampler,\n",
    "    )\n",
    "    # optimize\n",
    "    candidates, _ = optimize_acqf(\n",
    "        acq_function=acq_func,\n",
    "        bounds=problem.bounds,\n",
    "        q=q,\n",
    "        num_restarts=NUM_RESTARTS,\n",
    "        raw_samples=RAW_SAMPLES, \n",
    "        options={\"batch_limit\": 5, \"maxiter\": 200},\n",
    "        sequential=False,\n",
    "        # set equality constraints to make sure sum of composition is 1\n",
    "        #equality_constraints=[(indices, coefficients, rhs)]\n",
    "        #inequality_constraints=... if needed\n",
    "    )\n",
    "    \n",
    "    # Compute pairwise distances: result shape (M, N)\n",
    "    distances = np.linalg.norm(X_test[None, :, :] - candidates[:, None, :], axis=2)\n",
    "\n",
    "    # For each candidate, find the nearest X_test index\n",
    "    nearest_indices = np.argmin(distances, axis=1)\n",
    "    \n",
    "    new_x = X_test[nearest_indices].reshape(q, N_dim)\n",
    "    new_obj_true = problem(new_x)    \n",
    "    new_obj = new_obj_true\n",
    "    \n",
    "    return new_x, new_obj, new_obj_true"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "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": 8,
   "id": "b763fe2b",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration: 1\n",
      "new candidats: tensor([[0.2183, 0.2842],\n",
      "        [0.3067, 0.8598],\n",
      "        [0.4643, 0.6436],\n",
      "        [0.4742, 0.8254],\n",
      "        [0.1747, 0.3838],\n",
      "        [0.7475, 0.1749],\n",
      "        [0.0048, 0.5564],\n",
      "        [0.0181, 0.4690],\n",
      "        [0.5894, 0.9390],\n",
      "        [0.0402, 0.1254]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4556, 0.3476],\n",
      "        [0.0320, 0.3800],\n",
      "        [0.5781, 0.1738],\n",
      "        [0.3098, 0.5152],\n",
      "        [0.3252, 0.2859],\n",
      "        [0.6028, 0.0295],\n",
      "        [0.0635, 0.0969],\n",
      "        [0.1338, 0.1956],\n",
      "        [0.0271, 0.0444],\n",
      "        [0.3389, 0.4613]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.05577363]\n",
      "Time: 33.65535171702504\n",
      "Iteration: 2\n",
      "new candidats: tensor([[0.1388, 0.0212],\n",
      "        [0.0069, 0.2405],\n",
      "        [0.1364, 0.7610],\n",
      "        [0.1747, 0.3838],\n",
      "        [0.1181, 0.1948],\n",
      "        [0.4582, 0.7027],\n",
      "        [0.9986, 0.0703],\n",
      "        [0.6516, 0.5788],\n",
      "        [0.1461, 0.1682],\n",
      "        [0.6579, 0.7888]], dtype=torch.float64)\n",
      "new obj: tensor([[0.3199, 0.3160],\n",
      "        [0.3073, 0.4660],\n",
      "        [0.0101, 0.0294],\n",
      "        [0.3252, 0.2859],\n",
      "        [0.4596, 0.4856],\n",
      "        [0.6505, 0.3712],\n",
      "        [0.0421, 0.0071],\n",
      "        [0.1131, 0.0038],\n",
      "        [0.4761, 0.4592],\n",
      "        [0.1360, 0.0251]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.09207759]\n",
      "Time: 46.05801241402514\n",
      "Iteration: 3\n",
      "new candidats: tensor([[0.0464, 0.4374],\n",
      "        [0.9616, 0.8408],\n",
      "        [0.4684, 0.7318],\n",
      "        [0.6579, 0.7888],\n",
      "        [0.7612, 0.8212],\n",
      "        [0.0997, 0.4370],\n",
      "        [0.8979, 0.8084],\n",
      "        [0.4278, 0.7734],\n",
      "        [0.4386, 0.7301],\n",
      "        [0.3268, 0.7760]], dtype=torch.float64)\n",
      "new obj: tensor([[1.8401e-01, 2.4543e-01],\n",
      "        [8.2206e-06, 2.3371e-07],\n",
      "        [6.3912e-01, 4.4088e-01],\n",
      "        [1.3604e-01, 2.5075e-02],\n",
      "        [1.1168e-02, 1.0172e-03],\n",
      "        [2.1846e-01, 2.4505e-01],\n",
      "        [1.5321e-04, 3.8229e-06],\n",
      "        [4.1650e-01, 6.5160e-01],\n",
      "        [5.6155e-01, 5.1152e-01],\n",
      "        [1.2347e-01, 5.2379e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13953738]\n",
      "Time: 49.76346432603896\n",
      "Iteration: 4\n",
      "new candidats: tensor([[0.0997, 0.4370],\n",
      "        [0.5676, 0.6958],\n",
      "        [0.4613, 0.9590],\n",
      "        [0.8291, 0.0325],\n",
      "        [0.4294, 0.9739],\n",
      "        [0.7612, 0.8212],\n",
      "        [0.6345, 0.0448],\n",
      "        [0.9072, 0.4334],\n",
      "        [0.2799, 0.6245],\n",
      "        [0.4605, 0.7538]], dtype=torch.float64)\n",
      "new obj: tensor([[2.1846e-01, 2.4505e-01],\n",
      "        [5.6086e-01, 1.0091e-01],\n",
      "        [2.2834e-02, 1.6391e-01],\n",
      "        [1.6750e-01, 2.5820e-01],\n",
      "        [1.2949e-02, 1.4779e-01],\n",
      "        [1.1168e-02, 1.0172e-03],\n",
      "        [8.8255e-02, 6.9298e-03],\n",
      "        [2.6361e-02, 3.9680e-05],\n",
      "        [9.5207e-02, 1.0328e-01],\n",
      "        [5.6505e-01, 5.2535e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14183851]\n",
      "Time: 23.960301659069955\n",
      "Iteration: 5\n",
      "new candidats: tensor([[0.6217, 0.9128],\n",
      "        [0.8571, 0.6694],\n",
      "        [0.4785, 0.3124],\n",
      "        [0.0856, 0.6022],\n",
      "        [0.8961, 0.1046],\n",
      "        [0.9457, 0.3515],\n",
      "        [0.6855, 0.6252],\n",
      "        [0.4862, 0.7142],\n",
      "        [0.9898, 0.3433],\n",
      "        [0.4217, 0.7594]], dtype=torch.float64)\n",
      "new obj: tensor([[3.4779e-02, 3.1744e-02],\n",
      "        [1.2906e-03, 2.2448e-05],\n",
      "        [1.6444e-01, 5.3042e-02],\n",
      "        [5.6305e-02, 6.6722e-02],\n",
      "        [2.8087e-01, 4.5585e-01],\n",
      "        [7.7178e-02, 2.6123e-05],\n",
      "        [9.7592e-02, 3.0429e-03],\n",
      "        [6.9298e-01, 3.3627e-01],\n",
      "        [4.1591e-02, 9.9863e-06],\n",
      "        [4.3724e-01, 6.3176e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14893575]\n",
      "Time: 16.629526345990598\n",
      "Iteration: 6\n",
      "new candidats: tensor([[0.3933, 0.7802],\n",
      "        [0.5721, 0.8616],\n",
      "        [0.1015, 0.1745],\n",
      "        [0.0280, 0.1821],\n",
      "        [0.2724, 0.2596],\n",
      "        [0.5331, 0.6572],\n",
      "        [0.5869, 0.4559],\n",
      "        [0.2640, 0.5341],\n",
      "        [0.4684, 0.7318],\n",
      "        [0.4278, 0.7734]], dtype=torch.float64)\n",
      "new obj: tensor([[0.2920, 0.6869],\n",
      "        [0.1466, 0.1317],\n",
      "        [0.4393, 0.4898],\n",
      "        [0.3440, 0.4871],\n",
      "        [0.4480, 0.2866],\n",
      "        [0.6140, 0.1067],\n",
      "        [0.0611, 0.0081],\n",
      "        [0.1286, 0.0855],\n",
      "        [0.6391, 0.4409],\n",
      "        [0.4165, 0.6516]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15098806]\n",
      "Time: 10.758448987966403\n",
      "Iteration: 7\n",
      "new candidats: tensor([[0.6445, 0.7792],\n",
      "        [0.0069, 0.2405],\n",
      "        [0.8260, 0.2357],\n",
      "        [0.8061, 0.4193],\n",
      "        [0.1679, 0.8812],\n",
      "        [0.7008, 0.2922],\n",
      "        [0.8291, 0.0325],\n",
      "        [0.8039, 0.3593],\n",
      "        [0.4605, 0.7538],\n",
      "        [0.6660, 0.5986]], dtype=torch.float64)\n",
      "new obj: tensor([[1.8077e-01, 3.4601e-02],\n",
      "        [3.0732e-01, 4.6604e-01],\n",
      "        [6.3860e-01, 1.6078e-02],\n",
      "        [6.6024e-02, 3.1381e-04],\n",
      "        [2.0379e-03, 3.5360e-02],\n",
      "        [2.9943e-01, 3.1138e-03],\n",
      "        [1.6750e-01, 2.5820e-01],\n",
      "        [2.0060e-01, 4.3489e-04],\n",
      "        [5.6505e-01, 5.2535e-01],\n",
      "        [1.1016e-01, 3.4858e-03]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15098806]\n",
      "Time: 7.598248695023358\n",
      "Iteration: 8\n",
      "new candidats: tensor([[0.8737, 0.7920],\n",
      "        [0.0907, 0.4986],\n",
      "        [0.0157, 0.7949],\n",
      "        [0.0583, 0.3537],\n",
      "        [0.2762, 0.5027],\n",
      "        [0.4605, 0.7538],\n",
      "        [0.1400, 0.8327],\n",
      "        [0.4132, 0.3709],\n",
      "        [0.2263, 0.1869],\n",
      "        [0.4389, 0.4433]], dtype=torch.float64)\n",
      "new obj: tensor([[4.4716e-04, 1.1309e-05],\n",
      "        [1.4125e-01, 1.6318e-01],\n",
      "        [3.9246e-03, 6.2121e-03],\n",
      "        [2.8961e-01, 3.7155e-01],\n",
      "        [1.5613e-01, 9.7424e-02],\n",
      "        [5.6505e-01, 5.2535e-01],\n",
      "        [3.6546e-03, 2.5749e-02],\n",
      "        [1.9885e-01, 7.9672e-02],\n",
      "        [4.9464e-01, 3.6763e-01],\n",
      "        [1.3849e-01, 4.4664e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15098806]\n",
      "Time: 7.112571154022589\n",
      "Iteration: 1\n",
      "new candidats: tensor([[0.1571, 0.7555],\n",
      "        [0.1595, 0.0031],\n",
      "        [0.4881, 0.5662],\n",
      "        [0.8977, 0.1335],\n",
      "        [0.2616, 0.7882],\n",
      "        [0.0062, 0.5419],\n",
      "        [0.9507, 0.0697],\n",
      "        [0.4598, 0.6727],\n",
      "        [0.4484, 0.9404],\n",
      "        [0.0352, 0.5491]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0120, 0.0428],\n",
      "        [0.3017, 0.2786],\n",
      "        [0.3172, 0.0414],\n",
      "        [0.3491, 0.3550],\n",
      "        [0.0340, 0.2710],\n",
      "        [0.0725, 0.1102],\n",
      "        [0.0967, 0.0768],\n",
      "        [0.6353, 0.2649],\n",
      "        [0.0343, 0.2324],\n",
      "        [0.0777, 0.1074]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.10152351]\n",
      "Time: 97.34809624799527\n",
      "Iteration: 2\n",
      "new candidats: tensor([[0.0027, 0.2046],\n",
      "        [0.4598, 0.6727],\n",
      "        [0.5800, 0.2770],\n",
      "        [0.7331, 0.5802],\n",
      "        [0.7077, 0.4901],\n",
      "        [0.4428, 0.7245],\n",
      "        [0.6750, 0.9820],\n",
      "        [0.8438, 0.3630],\n",
      "        [0.1021, 0.8494],\n",
      "        [0.4201, 0.7269]], dtype=torch.float64)\n",
      "new obj: tensor([[3.0734e-01, 4.7239e-01],\n",
      "        [6.3532e-01, 2.6494e-01],\n",
      "        [1.2270e-01, 1.7976e-02],\n",
      "        [2.5354e-02, 5.8076e-04],\n",
      "        [2.2718e-02, 1.1337e-03],\n",
      "        [5.8438e-01, 4.8332e-01],\n",
      "        [2.8552e-03, 3.0496e-03],\n",
      "        [1.7039e-01, 2.0225e-04],\n",
      "        [2.3604e-03, 9.8642e-03],\n",
      "        [4.9918e-01, 5.2859e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.12637757]\n",
      "Time: 45.636595678981394\n",
      "Iteration: 3\n",
      "new candidats: tensor([[0.3458, 0.1228],\n",
      "        [0.0403, 0.6166],\n",
      "        [0.2521, 0.3444],\n",
      "        [0.4163, 0.7862],\n",
      "        [0.6535, 0.0682],\n",
      "        [0.3412, 0.3381],\n",
      "        [0.5374, 0.0520],\n",
      "        [0.4783, 0.7016],\n",
      "        [0.5158, 0.9429],\n",
      "        [0.4675, 0.7537]], dtype=torch.float64)\n",
      "new obj: tensor([[0.3558, 0.1793],\n",
      "        [0.0415, 0.0567],\n",
      "        [0.3725, 0.2546],\n",
      "        [0.3440, 0.6857],\n",
      "        [0.1312, 0.0060],\n",
      "        [0.3074, 0.1571],\n",
      "        [0.0991, 0.0248],\n",
      "        [0.6918, 0.3201],\n",
      "        [0.0363, 0.1290],\n",
      "        [0.5794, 0.5022]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14440545]\n",
      "Time: 86.21053907112218\n",
      "Iteration: 4\n",
      "new candidats: tensor([[0.8775, 0.8215],\n",
      "        [0.8911, 0.5579],\n",
      "        [0.8527, 0.3196],\n",
      "        [0.0129, 0.9130],\n",
      "        [0.7063, 0.5390],\n",
      "        [0.5512, 0.5004],\n",
      "        [0.6047, 0.5857],\n",
      "        [0.4783, 0.7016],\n",
      "        [0.4675, 0.7537],\n",
      "        [0.4551, 0.8928]], dtype=torch.float64)\n",
      "new obj: tensor([[2.8169e-04, 8.7953e-06],\n",
      "        [1.1432e-03, 2.2265e-05],\n",
      "        [3.0003e-01, 2.4280e-04],\n",
      "        [5.6143e-04, 1.0399e-03],\n",
      "        [2.9051e-02, 9.6605e-04],\n",
      "        [1.1879e-01, 1.1468e-02],\n",
      "        [2.2060e-01, 1.0847e-02],\n",
      "        [6.9182e-01, 3.2014e-01],\n",
      "        [5.7935e-01, 5.0225e-01],\n",
      "        [9.9201e-02, 3.9112e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14440545]\n",
      "Time: 51.783322412054986\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration: 5\n",
      "new candidats: tensor([[0.4728, 0.4097],\n",
      "        [0.7409, 0.4858],\n",
      "        [0.6560, 0.0055],\n",
      "        [0.2043, 0.1595],\n",
      "        [0.6699, 0.7251],\n",
      "        [0.4928, 0.7346],\n",
      "        [0.9340, 0.2201],\n",
      "        [0.2121, 0.8830],\n",
      "        [0.6363, 0.5110],\n",
      "        [0.3412, 0.3381]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1242, 0.0382],\n",
      "        [0.0184, 0.0007],\n",
      "        [0.0606, 0.0043],\n",
      "        [0.4897, 0.3910],\n",
      "        [0.1611, 0.0140],\n",
      "        [0.6625, 0.3689],\n",
      "        [0.2801, 0.0096],\n",
      "        [0.0035, 0.0861],\n",
      "        [0.0616, 0.0034],\n",
      "        [0.3074, 0.1571]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14821697]\n",
      "Time: 62.58458736189641\n",
      "Iteration: 6\n",
      "new candidats: tensor([[0.0621, 0.2842],\n",
      "        [0.1431, 0.1068],\n",
      "        [0.5016, 0.3473],\n",
      "        [0.3154, 0.9575],\n",
      "        [0.3458, 0.1228],\n",
      "        [0.1611, 0.8541],\n",
      "        [0.4414, 0.0219],\n",
      "        [0.8074, 0.5748],\n",
      "        [0.4675, 0.7537],\n",
      "        [0.1002, 0.2481]], dtype=torch.float64)\n",
      "new obj: tensor([[3.6084e-01, 4.5727e-01],\n",
      "        [4.3075e-01, 4.1959e-01],\n",
      "        [1.2641e-01, 3.7150e-02],\n",
      "        [4.9491e-03, 1.4171e-01],\n",
      "        [3.5585e-01, 1.7935e-01],\n",
      "        [3.0211e-03, 3.7026e-02],\n",
      "        [1.6262e-01, 6.0001e-02],\n",
      "        [4.3194e-03, 1.1036e-04],\n",
      "        [5.7935e-01, 5.0225e-01],\n",
      "        [4.2891e-01, 4.8019e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14821697]\n",
      "Time: 54.682713757967576\n",
      "Iteration: 7\n",
      "new candidats: tensor([[0.4675, 0.7537],\n",
      "        [0.0573, 0.9195],\n",
      "        [0.4104, 0.2633],\n",
      "        [0.9068, 0.0382],\n",
      "        [0.2194, 0.0757],\n",
      "        [0.1805, 0.2592],\n",
      "        [0.5383, 0.8243],\n",
      "        [0.9812, 0.1383],\n",
      "        [0.3782, 0.4571],\n",
      "        [0.8083, 0.1567]], dtype=torch.float64)\n",
      "new obj: tensor([[5.7935e-01, 5.0225e-01],\n",
      "        [6.0299e-04, 1.7359e-03],\n",
      "        [2.7375e-01, 1.1171e-01],\n",
      "        [1.0750e-01, 1.7088e-01],\n",
      "        [4.1027e-01, 3.1190e-01],\n",
      "        [4.7630e-01, 4.1080e-01],\n",
      "        [3.0145e-01, 2.6145e-01],\n",
      "        [1.1234e-01, 1.6741e-02],\n",
      "        [1.6458e-01, 6.8647e-02],\n",
      "        [6.3995e-01, 2.6039e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14821697]\n",
      "Time: 8.478255599969998\n",
      "Iteration: 8\n",
      "new candidats: tensor([[0.1173, 0.8186],\n",
      "        [0.5670, 0.0129],\n",
      "        [0.2475, 0.7408],\n",
      "        [0.1113, 0.6121],\n",
      "        [0.8946, 0.0996],\n",
      "        [0.7587, 0.2313],\n",
      "        [0.4163, 0.7862],\n",
      "        [0.4675, 0.7537],\n",
      "        [0.7984, 0.3132],\n",
      "        [0.9701, 0.7810]], dtype=torch.float64)\n",
      "new obj: tensor([[4.0690e-03, 1.6717e-02],\n",
      "        [6.8017e-02, 1.4727e-02],\n",
      "        [3.9148e-02, 1.9238e-01],\n",
      "        [5.4489e-02, 6.0433e-02],\n",
      "        [2.7139e-01, 4.7070e-01],\n",
      "        [6.2211e-01, 5.5232e-03],\n",
      "        [3.4402e-01, 6.8569e-01],\n",
      "        [5.7935e-01, 5.0225e-01],\n",
      "        [3.7375e-01, 6.0787e-04],\n",
      "        [1.2473e-05, 3.5448e-07]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14821697]\n",
      "Time: 7.678627805085853\n",
      "Iteration: 1\n",
      "new candidats: tensor([[9.9632e-01, 1.5630e-01],\n",
      "        [3.7854e-01, 8.1243e-01],\n",
      "        [5.3436e-01, 4.1097e-01],\n",
      "        [8.7581e-01, 1.3785e-01],\n",
      "        [9.0631e-01, 6.9675e-01],\n",
      "        [3.7164e-01, 7.3541e-01],\n",
      "        [6.2808e-03, 6.4138e-01],\n",
      "        [8.8944e-01, 1.1626e-02],\n",
      "        [2.9745e-03, 8.4079e-01],\n",
      "        [7.0794e-01, 2.8165e-04]], dtype=torch.float64)\n",
      "new obj: tensor([[9.2787e-02, 5.1405e-03],\n",
      "        [1.8103e-01, 6.8020e-01],\n",
      "        [8.3211e-02, 1.9500e-02],\n",
      "        [4.3453e-01, 4.6021e-01],\n",
      "        [2.2850e-04, 4.7659e-06],\n",
      "        [2.9809e-01, 5.5028e-01],\n",
      "        [2.7396e-02, 4.1707e-02],\n",
      "        [8.0432e-02, 1.0763e-01],\n",
      "        [1.8173e-03, 3.0326e-03],\n",
      "        [7.4434e-02, 3.5678e-03]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07367504]\n",
      "Time: 39.827164815040305\n",
      "Iteration: 2\n",
      "new candidats: tensor([[0.8370, 0.1354],\n",
      "        [0.6701, 0.0459],\n",
      "        [0.8221, 0.6743],\n",
      "        [0.4682, 0.7541],\n",
      "        [0.1701, 0.2119],\n",
      "        [0.1553, 0.2414],\n",
      "        [0.6393, 0.5574],\n",
      "        [0.3384, 0.5058],\n",
      "        [0.7434, 0.8552],\n",
      "        [0.4734, 0.7995]], dtype=torch.float64)\n",
      "new obj: tensor([[5.3360e-01, 5.2686e-01],\n",
      "        [1.1536e-01, 4.7234e-03],\n",
      "        [4.0252e-03, 6.8390e-05],\n",
      "        [5.7910e-01, 5.0098e-01],\n",
      "        [4.9356e-01, 4.4040e-01],\n",
      "        [4.7736e-01, 4.4687e-01],\n",
      "        [1.0534e-01, 3.8666e-03],\n",
      "        [1.5104e-01, 7.0748e-02],\n",
      "        [1.0911e-02, 1.6593e-03],\n",
      "        [4.1419e-01, 5.3528e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.1206929]\n",
      "Time: 49.809791279025376\n",
      "Iteration: 3\n",
      "new candidats: tensor([[0.6308, 0.7624],\n",
      "        [0.2998, 0.2353],\n",
      "        [0.0692, 0.2157],\n",
      "        [0.3465, 0.9114],\n",
      "        [0.9063, 0.6967],\n",
      "        [0.6393, 0.5574],\n",
      "        [0.7879, 0.1664],\n",
      "        [0.7343, 0.0635],\n",
      "        [0.3008, 0.3021],\n",
      "        [0.5856, 0.0138]], dtype=torch.float64)\n",
      "new obj: tensor([[2.4575e-01, 4.5605e-02],\n",
      "        [4.3469e-01, 2.5445e-01],\n",
      "        [4.0255e-01, 4.9846e-01],\n",
      "        [2.3731e-02, 3.2639e-01],\n",
      "        [2.2850e-04, 4.7659e-06],\n",
      "        [1.0534e-01, 3.8666e-03],\n",
      "        [6.6331e-01, 1.3499e-01],\n",
      "        [2.3351e-01, 3.8501e-02],\n",
      "        [3.8662e-01, 2.2553e-01],\n",
      "        [6.2941e-02, 1.1686e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.1206929]\n",
      "Time: 58.669313380960375\n",
      "Iteration: 4\n",
      "new candidats: tensor([[0.8090, 0.7762],\n",
      "        [0.2049, 0.0053],\n",
      "        [0.4257, 0.7747],\n",
      "        [0.8492, 0.4704],\n",
      "        [0.0055, 0.0310],\n",
      "        [0.9455, 0.5166],\n",
      "        [0.4420, 0.7706],\n",
      "        [0.7937, 0.0981],\n",
      "        [0.4733, 0.7255],\n",
      "        [0.8341, 0.9194]], dtype=torch.float64)\n",
      "new obj: tensor([[4.5020e-03, 1.6735e-04],\n",
      "        [3.1128e-01, 2.4802e-01],\n",
      "        [4.0599e-01, 6.5765e-01],\n",
      "        [1.7150e-02, 1.0141e-04],\n",
      "        [2.1804e-01, 3.3218e-01],\n",
      "        [1.7583e-03, 9.8539e-06],\n",
      "        [4.6519e-01, 6.1535e-01],\n",
      "        [4.2095e-01, 3.7207e-01],\n",
      "        [6.6005e-01, 4.0760e-01],\n",
      "        [2.4279e-04, 2.8319e-05]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15035643]\n",
      "Time: 55.7671875320375\n",
      "Iteration: 5\n",
      "new candidats: tensor([[0.3572, 0.5519],\n",
      "        [0.2178, 0.4260],\n",
      "        [0.1719, 0.9302],\n",
      "        [0.9845, 0.1364],\n",
      "        [0.4360, 0.7512],\n",
      "        [0.4733, 0.7255],\n",
      "        [0.4733, 0.7255],\n",
      "        [0.5303, 0.9643],\n",
      "        [0.5420, 0.2532],\n",
      "        [0.8392, 0.2328]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1624, 0.0673],\n",
      "        [0.2633, 0.2011],\n",
      "        [0.0009, 0.0228],\n",
      "        [0.1046, 0.0145],\n",
      "        [0.5058, 0.5846],\n",
      "        [0.6600, 0.4076],\n",
      "        [0.6600, 0.4076],\n",
      "        [0.0204, 0.0777],\n",
      "        [0.1337, 0.0298],\n",
      "        [0.6171, 0.0204]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15270203]\n",
      "Time: 21.22045937902294\n",
      "Iteration: 6\n",
      "new candidats: tensor([[0.3779, 0.6764],\n",
      "        [0.9987, 0.7129],\n",
      "        [0.1194, 0.2859],\n",
      "        [0.4779, 0.0748],\n",
      "        [0.1590, 0.5641],\n",
      "        [0.4733, 0.7255],\n",
      "        [0.8151, 0.6259],\n",
      "        [0.4733, 0.7255],\n",
      "        [0.8959, 0.3413],\n",
      "        [0.3255, 0.3163]], dtype=torch.float64)\n",
      "new obj: tensor([[3.4273e-01, 3.2707e-01],\n",
      "        [9.3821e-06, 3.9612e-07],\n",
      "        [4.2041e-01, 4.4228e-01],\n",
      "        [1.5836e-01, 5.1377e-02],\n",
      "        [9.4191e-02, 8.8741e-02],\n",
      "        [6.6005e-01, 4.0760e-01],\n",
      "        [4.2552e-03, 7.8120e-05],\n",
      "        [6.6005e-01, 4.0760e-01],\n",
      "        [1.6377e-01, 8.1209e-05],\n",
      "        [3.4688e-01, 1.8670e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15270203]\n",
      "Time: 53.961067490046844\n",
      "Iteration: 7\n",
      "new candidats: tensor([[0.4352, 0.4156],\n",
      "        [0.4733, 0.7255],\n",
      "        [0.6284, 0.4919],\n",
      "        [0.4733, 0.7255],\n",
      "        [0.4297, 0.3891],\n",
      "        [0.2539, 0.1082],\n",
      "        [0.9545, 0.4234],\n",
      "        [0.7122, 0.5946],\n",
      "        [0.0356, 0.8131],\n",
      "        [0.2558, 0.6959]], dtype=torch.float64)\n",
      "new obj: tensor([[1.5010e-01, 5.3202e-02],\n",
      "        [6.6005e-01, 4.0760e-01],\n",
      "        [5.4880e-02, 3.9469e-03],\n",
      "        [6.6005e-01, 4.0760e-01],\n",
      "        [1.6983e-01, 6.3599e-02],\n",
      "        [4.3399e-01, 2.9488e-01],\n",
      "        [1.7708e-02, 1.5160e-05],\n",
      "        [4.5125e-02, 1.0603e-03],\n",
      "        [3.2563e-03, 5.3948e-03],\n",
      "        [5.7673e-02, 1.5898e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15270203]\n",
      "Time: 24.410955494036898\n",
      "Iteration: 8\n",
      "new candidats: tensor([[0.6314, 0.9636],\n",
      "        [0.9035, 0.5813],\n",
      "        [0.4733, 0.7255],\n",
      "        [0.5406, 0.0831],\n",
      "        [0.6931, 0.1645],\n",
      "        [0.9501, 0.3582],\n",
      "        [0.7343, 0.0635],\n",
      "        [0.3234, 0.4122],\n",
      "        [0.4512, 0.7440],\n",
      "        [0.4733, 0.7255]], dtype=torch.float64)\n",
      "new obj: tensor([[9.1795e-03, 1.2627e-02],\n",
      "        [5.5336e-04, 1.3947e-05],\n",
      "        [6.6005e-01, 4.0760e-01],\n",
      "        [1.1108e-01, 2.6458e-02],\n",
      "        [3.9484e-01, 6.0613e-03],\n",
      "        [6.5274e-02, 2.2966e-05],\n",
      "        [2.3351e-01, 3.8501e-02],\n",
      "        [2.3777e-01, 1.2791e-01],\n",
      "        [5.6978e-01, 5.2682e-01],\n",
      "        [6.6005e-01, 4.0760e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15363727]\n",
      "Time: 40.70087848510593\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration: 1\n",
      "new candidats: tensor([[0.6455, 0.1256],\n",
      "        [0.7004, 0.0941],\n",
      "        [0.3864, 0.4304],\n",
      "        [0.2116, 0.0173],\n",
      "        [0.2725, 0.0018],\n",
      "        [0.2106, 0.4507],\n",
      "        [0.2921, 0.8866],\n",
      "        [0.6455, 0.1256],\n",
      "        [0.6518, 0.9809],\n",
      "        [0.0133, 0.0337]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1999, 0.0076],\n",
      "        [0.2625, 0.0110],\n",
      "        [0.1765, 0.0744],\n",
      "        [0.3288, 0.2563],\n",
      "        [0.2866, 0.1833],\n",
      "        [0.2280, 0.1782],\n",
      "        [0.0154, 0.2694],\n",
      "        [0.1999, 0.0076],\n",
      "        [0.0043, 0.0057],\n",
      "        [0.2288, 0.3399]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.04565737]\n",
      "Time: 39.39803689508699\n",
      "Iteration: 2\n",
      "new candidats: tensor([[0.7397, 0.7382],\n",
      "        [0.2106, 0.4507],\n",
      "        [0.1124, 0.2404],\n",
      "        [0.0126, 0.2304],\n",
      "        [0.1267, 0.1730],\n",
      "        [0.0293, 0.7648],\n",
      "        [0.1874, 0.2147],\n",
      "        [0.1398, 0.8770],\n",
      "        [0.9737, 0.7475],\n",
      "        [0.4104, 0.0227]], dtype=torch.float64)\n",
      "new obj: tensor([[3.7109e-02, 1.8521e-03],\n",
      "        [2.2801e-01, 1.7822e-01],\n",
      "        [4.4509e-01, 4.7904e-01],\n",
      "        [3.1859e-01, 4.7429e-01],\n",
      "        [4.6327e-01, 4.7595e-01],\n",
      "        [6.4500e-03, 9.7642e-03],\n",
      "        [4.9766e-01, 4.1975e-01],\n",
      "        [1.7740e-03, 1.9138e-02],\n",
      "        [1.5059e-05, 4.7784e-07],\n",
      "        [1.9413e-01, 7.9277e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.06881973]\n",
      "Time: 39.80942030902952\n",
      "Iteration: 3\n",
      "new candidats: tensor([[0.2416, 0.2124],\n",
      "        [0.6881, 0.9871],\n",
      "        [0.1985, 0.1727],\n",
      "        [0.1469, 0.2070],\n",
      "        [0.3749, 0.0094],\n",
      "        [0.4161, 0.8600],\n",
      "        [0.1035, 0.2111],\n",
      "        [0.8642, 0.1989],\n",
      "        [0.0751, 0.1996],\n",
      "        [0.7388, 0.9371]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4883, 0.3453],\n",
      "        [0.0020, 0.0019],\n",
      "        [0.4953, 0.4030],\n",
      "        [0.4824, 0.4641],\n",
      "        [0.2166, 0.0993],\n",
      "        [0.1380, 0.5774],\n",
      "        [0.4443, 0.4923],\n",
      "        [0.5718, 0.0953],\n",
      "        [0.4114, 0.4998],\n",
      "        [0.0024, 0.0009]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07094364]\n",
      "Time: 41.1807221500203\n",
      "Iteration: 4\n",
      "new candidats: tensor([[0.7004, 0.0941],\n",
      "        [0.8355, 0.2255],\n",
      "        [0.2393, 0.7556],\n",
      "        [0.3525, 0.6812],\n",
      "        [0.4035, 0.9334],\n",
      "        [0.0500, 0.8527],\n",
      "        [0.3399, 0.9360],\n",
      "        [0.3533, 0.8774],\n",
      "        [0.9228, 0.0053],\n",
      "        [0.9746, 0.0153]], dtype=torch.float64)\n",
      "new obj: tensor([[0.2625, 0.0110],\n",
      "        [0.6394, 0.0291],\n",
      "        [0.0304, 0.1817],\n",
      "        [0.2524, 0.3188],\n",
      "        [0.0292, 0.2874],\n",
      "        [0.0018, 0.0038],\n",
      "        [0.0124, 0.2320],\n",
      "        [0.0507, 0.4658],\n",
      "        [0.0499, 0.0403],\n",
      "        [0.0278, 0.0075]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07094364]\n",
      "Time: 61.34873989201151\n",
      "Iteration: 5\n",
      "new candidats: tensor([[0.4541, 0.7793],\n",
      "        [0.9424, 0.7975],\n",
      "        [0.7397, 0.7382],\n",
      "        [0.9412, 0.4861],\n",
      "        [0.1643, 0.5517],\n",
      "        [0.9746, 0.0153],\n",
      "        [0.2956, 0.4564],\n",
      "        [0.3356, 0.3922],\n",
      "        [0.0293, 0.7648],\n",
      "        [0.4173, 0.7832]], dtype=torch.float64)\n",
      "new obj: tensor([[4.6342e-01, 5.9312e-01],\n",
      "        [3.0330e-05, 7.1147e-07],\n",
      "        [3.7109e-02, 1.8521e-03],\n",
      "        [4.4971e-03, 1.3614e-05],\n",
      "        [1.0573e-01, 9.7351e-02],\n",
      "        [2.7844e-02, 7.4640e-03],\n",
      "        [2.0050e-01, 1.1742e-01],\n",
      "        [2.5198e-01, 1.3059e-01],\n",
      "        [6.4500e-03, 9.7642e-03],\n",
      "        [3.5590e-01, 6.8145e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.10385166]\n",
      "Time: 68.93580827303231\n",
      "Iteration: 6\n",
      "new candidats: tensor([[0.4814, 0.7436],\n",
      "        [0.4814, 0.7436],\n",
      "        [0.6040, 0.0739],\n",
      "        [0.1732, 0.6290],\n",
      "        [0.5488, 0.0259],\n",
      "        [0.2176, 0.6890],\n",
      "        [0.1799, 0.8706],\n",
      "        [0.7537, 0.9175],\n",
      "        [0.5547, 0.2182],\n",
      "        [0.4499, 0.1533]], dtype=torch.float64)\n",
      "new obj: tensor([[0.6302, 0.4302],\n",
      "        [0.6302, 0.4302],\n",
      "        [0.0996, 0.0116],\n",
      "        [0.0523, 0.0562],\n",
      "        [0.0814, 0.0195],\n",
      "        [0.0380, 0.0908],\n",
      "        [0.0028, 0.0500],\n",
      "        [0.0026, 0.0007],\n",
      "        [0.1373, 0.0264],\n",
      "        [0.2242, 0.0801]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13172749]\n",
      "Time: 55.94521046592854\n",
      "Iteration: 7\n",
      "new candidats: tensor([[0.6608, 0.0395],\n",
      "        [0.8038, 0.9629],\n",
      "        [0.9719, 0.9626],\n",
      "        [0.4216, 0.7592],\n",
      "        [0.8571, 0.9617],\n",
      "        [0.4173, 0.7832],\n",
      "        [0.2613, 0.2503],\n",
      "        [0.4216, 0.7592],\n",
      "        [0.2444, 0.5898],\n",
      "        [0.4539, 0.7269]], dtype=torch.float64)\n",
      "new obj: tensor([[9.8784e-02, 4.8767e-03],\n",
      "        [2.2225e-04, 5.3845e-05],\n",
      "        [5.2841e-07, 2.8151e-08],\n",
      "        [4.3764e-01, 6.3124e-01],\n",
      "        [4.0375e-05, 5.6472e-06],\n",
      "        [3.5590e-01, 6.8145e-01],\n",
      "        [4.6224e-01, 3.0666e-01],\n",
      "        [4.3764e-01, 6.3124e-01],\n",
      "        [8.7602e-02, 7.4080e-02],\n",
      "        [6.1404e-01, 4.6591e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13957712]\n",
      "Time: 44.13037402788177\n",
      "Iteration: 8\n",
      "new candidats: tensor([[0.7430, 0.4191],\n",
      "        [0.4744, 0.6966],\n",
      "        [0.5453, 0.3780],\n",
      "        [0.1429, 0.6921],\n",
      "        [0.6627, 0.6695],\n",
      "        [0.4539, 0.7269],\n",
      "        [0.4656, 0.7122],\n",
      "        [0.8970, 0.3456],\n",
      "        [0.1998, 0.0424],\n",
      "        [0.4216, 0.7592]], dtype=torch.float64)\n",
      "new obj: tensor([[6.1582e-02, 9.5553e-04],\n",
      "        [6.8592e-01, 3.1405e-01],\n",
      "        [8.4928e-02, 2.0005e-02],\n",
      "        [2.4464e-02, 3.7035e-02],\n",
      "        [1.7993e-01, 9.8639e-03],\n",
      "        [6.1404e-01, 4.6591e-01],\n",
      "        [6.6256e-01, 3.8684e-01],\n",
      "        [1.5234e-01, 7.6884e-05],\n",
      "        [3.6661e-01, 2.9702e-01],\n",
      "        [4.3764e-01, 6.3124e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14711139]\n",
      "Time: 24.649418336106464\n",
      "Iteration: 1\n",
      "new candidats: tensor([[0.2681, 0.6577],\n",
      "        [0.1373, 0.2486],\n",
      "        [0.9472, 0.5594],\n",
      "        [0.1852, 0.3158],\n",
      "        [0.1645, 0.3684],\n",
      "        [0.0058, 0.2078],\n",
      "        [0.8489, 0.9303],\n",
      "        [0.7408, 0.2577],\n",
      "        [0.5761, 0.2357],\n",
      "        [0.1434, 0.8808]], dtype=torch.float64)\n",
      "new obj: tensor([[7.7911e-02, 1.2895e-01],\n",
      "        [4.6219e-01, 4.5874e-01],\n",
      "        [4.7586e-04, 6.6254e-06],\n",
      "        [4.2163e-01, 3.5811e-01],\n",
      "        [3.4530e-01, 3.1373e-01],\n",
      "        [3.1187e-01, 4.7455e-01],\n",
      "        [1.1543e-04, 1.2921e-05],\n",
      "        [5.0968e-01, 2.1748e-03],\n",
      "        [1.3756e-01, 2.0021e-02],\n",
      "        [1.6995e-03, 2.0196e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.05551009]\n",
      "Time: 52.31671026092954\n",
      "Iteration: 2\n",
      "new candidats: tensor([[0.1048, 0.1911],\n",
      "        [0.1107, 0.7187],\n",
      "        [0.9472, 0.5594],\n",
      "        [0.5728, 0.0982],\n",
      "        [0.8069, 0.2633],\n",
      "        [0.1203, 0.0736],\n",
      "        [0.5234, 0.7630],\n",
      "        [0.9330, 0.9784],\n",
      "        [0.1349, 0.4418],\n",
      "        [0.4244, 0.9201]], dtype=torch.float64)\n",
      "new obj: tensor([[4.4595e-01, 4.9202e-01],\n",
      "        [1.6015e-02, 2.4617e-02],\n",
      "        [4.7586e-04, 6.6254e-06],\n",
      "        [1.0885e-01, 1.8630e-02],\n",
      "        [5.7630e-01, 2.8643e-03],\n",
      "        [3.7825e-01, 3.9677e-01],\n",
      "        [5.6112e-01, 3.0588e-01],\n",
      "        [1.5430e-06, 1.1986e-07],\n",
      "        [2.2841e-01, 2.2850e-01],\n",
      "        [4.7078e-02, 3.3048e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.06972199]\n",
      "Time: 60.05703801289201\n",
      "Iteration: 3\n",
      "new candidats: tensor([[0.1636, 0.2210],\n",
      "        [0.6897, 0.9930],\n",
      "        [0.0786, 0.2083],\n",
      "        [0.4859, 0.7512],\n",
      "        [0.9772, 0.5727],\n",
      "        [0.1476, 0.2122],\n",
      "        [0.9226, 0.5073],\n",
      "        [0.1449, 0.5304],\n",
      "        [0.2439, 0.1434],\n",
      "        [0.9204, 0.0621]], dtype=torch.float64)\n",
      "new obj: tensor([[4.8908e-01, 4.4568e-01],\n",
      "        [1.5960e-03, 1.6409e-03],\n",
      "        [4.1555e-01, 4.9910e-01],\n",
      "        [6.1188e-01, 4.3112e-01],\n",
      "        [1.8998e-04, 3.0035e-06],\n",
      "        [4.8223e-01, 4.6288e-01],\n",
      "        [3.1758e-03, 1.7393e-05],\n",
      "        [1.2334e-01, 1.1984e-01],\n",
      "        [4.6892e-01, 3.2911e-01],\n",
      "        [1.3173e-01, 1.9521e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.09486357]\n",
      "Time: 48.349626692943275\n",
      "Iteration: 4\n",
      "new candidats: tensor([[0.4463, 0.7722],\n",
      "        [0.4669, 0.7122],\n",
      "        [0.3517, 0.0119],\n",
      "        [0.4268, 0.7418],\n",
      "        [0.0630, 0.1834],\n",
      "        [0.4626, 0.7342],\n",
      "        [0.8029, 0.6381],\n",
      "        [0.8064, 0.3927],\n",
      "        [0.0322, 0.4829],\n",
      "        [0.4251, 0.7169]], dtype=torch.float64)\n",
      "new obj: tensor([[4.7079e-01, 6.0655e-01],\n",
      "        [6.6546e-01, 3.8324e-01],\n",
      "        [2.4099e-01, 1.1918e-01],\n",
      "        [4.9741e-01, 5.7279e-01],\n",
      "        [3.9410e-01, 4.9799e-01],\n",
      "        [6.2157e-01, 4.6554e-01],\n",
      "        [6.4147e-03, 1.1147e-04],\n",
      "        [1.1228e-01, 3.5776e-04],\n",
      "        [1.2926e-01, 1.8055e-01],\n",
      "        [5.3079e-01, 4.8387e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.1387884]\n",
      "Time: 53.22240505903028\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration: 5\n",
      "new candidats: tensor([[0.8708, 0.3794],\n",
      "        [0.3106, 0.5693],\n",
      "        [0.1236, 0.3365],\n",
      "        [0.7915, 0.1989],\n",
      "        [0.4626, 0.7342],\n",
      "        [0.3959, 0.0231],\n",
      "        [0.1164, 0.8198],\n",
      "        [0.8830, 0.2871],\n",
      "        [0.4357, 0.9828],\n",
      "        [0.4263, 0.7852]], dtype=torch.float64)\n",
      "new obj: tensor([[1.1026e-01, 1.1060e-04],\n",
      "        [1.2757e-01, 7.6895e-02],\n",
      "        [3.6826e-01, 3.8222e-01],\n",
      "        [7.0374e-01, 5.0572e-02],\n",
      "        [6.2157e-01, 4.6554e-01],\n",
      "        [2.0935e-01, 8.9663e-02],\n",
      "        [3.9845e-03, 1.6322e-02],\n",
      "        [3.4063e-01, 6.2828e-04],\n",
      "        [1.0547e-02, 1.2353e-01],\n",
      "        [3.7467e-01, 6.7027e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14776381]\n",
      "Time: 9.688699088990688\n",
      "Iteration: 6\n",
      "new candidats: tensor([[2.2418e-01, 8.7274e-01],\n",
      "        [7.2639e-01, 2.1150e-01],\n",
      "        [8.7188e-01, 8.8967e-01],\n",
      "        [2.8252e-01, 1.3870e-01],\n",
      "        [1.2828e-01, 9.3274e-01],\n",
      "        [7.1385e-01, 1.7741e-04],\n",
      "        [7.0224e-01, 3.7750e-01],\n",
      "        [4.1405e-01, 2.0729e-01],\n",
      "        [4.6263e-01, 7.3425e-01],\n",
      "        [7.9400e-01, 9.7179e-01]], dtype=torch.float64)\n",
      "new obj: tensor([[5.2423e-03, 1.1583e-01],\n",
      "        [5.4599e-01, 5.0293e-03],\n",
      "        [1.1968e-04, 7.2656e-06],\n",
      "        [4.3813e-01, 2.7126e-01],\n",
      "        [6.1719e-04, 7.8145e-03],\n",
      "        [7.6785e-02, 4.0464e-03],\n",
      "        [1.0474e-01, 2.2809e-03],\n",
      "        [2.8221e-01, 1.1378e-01],\n",
      "        [6.2157e-01, 4.6554e-01],\n",
      "        [2.3480e-04, 6.8541e-05]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14776381]\n",
      "Time: 11.590619754977524\n",
      "Iteration: 7\n",
      "new candidats: tensor([[0.7335, 0.3510],\n",
      "        [0.4626, 0.7342],\n",
      "        [0.3041, 0.3655],\n",
      "        [0.4669, 0.7122],\n",
      "        [0.1594, 0.9730],\n",
      "        [0.4183, 0.1594],\n",
      "        [0.1594, 0.9730],\n",
      "        [0.2164, 0.0726],\n",
      "        [0.9414, 0.2911],\n",
      "        [0.9342, 0.8572]], dtype=torch.float64)\n",
      "new obj: tensor([[1.9033e-01, 1.5326e-03],\n",
      "        [6.2157e-01, 4.6554e-01],\n",
      "        [3.1044e-01, 1.7902e-01],\n",
      "        [6.6546e-01, 3.8324e-01],\n",
      "        [3.3073e-04, 8.9385e-03],\n",
      "        [2.7040e-01, 1.0750e-01],\n",
      "        [3.3073e-04, 8.9385e-03],\n",
      "        [4.0683e-01, 3.1231e-01],\n",
      "        [1.7043e-01, 1.2221e-04],\n",
      "        [1.9052e-05, 5.7694e-07]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14776381]\n",
      "Time: 19.30977868102491\n",
      "Iteration: 8\n",
      "new candidats: tensor([[0.8420, 0.4892],\n",
      "        [0.7897, 0.8501],\n",
      "        [0.1164, 0.8198],\n",
      "        [0.3073, 0.0200],\n",
      "        [0.4626, 0.7342],\n",
      "        [0.8758, 0.2011],\n",
      "        [0.5108, 0.3450],\n",
      "        [0.5761, 0.2357],\n",
      "        [0.5674, 0.1590],\n",
      "        [0.7362, 0.5737]], dtype=torch.float64)\n",
      "new obj: tensor([[1.1023e-02, 1.0247e-04],\n",
      "        [3.4502e-03, 3.1536e-04],\n",
      "        [3.9845e-03, 1.6322e-02],\n",
      "        [2.8883e-01, 1.6499e-01],\n",
      "        [6.2157e-01, 4.6554e-01],\n",
      "        [5.2688e-01, 7.9344e-02],\n",
      "        [1.1997e-01, 3.3911e-02],\n",
      "        [1.3756e-01, 2.0021e-02],\n",
      "        [1.3360e-01, 2.2225e-02],\n",
      "        [2.2296e-02, 5.2972e-04]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14776381]\n",
      "Time: 15.929404804948717\n",
      "Iteration: 1\n",
      "new candidats: tensor([[0.8961, 0.0121],\n",
      "        [0.0047, 0.9978],\n",
      "        [0.1482, 0.9465],\n",
      "        [0.5098, 0.8749],\n",
      "        [0.4553, 0.9011],\n",
      "        [0.6185, 0.5890],\n",
      "        [0.6568, 0.3304],\n",
      "        [0.6306, 0.6910],\n",
      "        [0.5389, 0.8070],\n",
      "        [0.5369, 0.7199]], dtype=torch.float64)\n",
      "new obj: tensor([[7.6210e-02, 9.7570e-02],\n",
      "        [1.0878e-04, 2.0606e-04],\n",
      "        [5.2476e-04, 1.0490e-02],\n",
      "        [1.5147e-01, 2.8954e-01],\n",
      "        [8.4417e-02, 3.6061e-01],\n",
      "        [1.9585e-01, 8.6989e-03],\n",
      "        [1.3738e-01, 5.4615e-03],\n",
      "        [2.9949e-01, 2.7530e-02],\n",
      "        [3.6728e-01, 2.6629e-01],\n",
      "        [6.4518e-01, 2.0010e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.0580126]\n",
      "Time: 55.169339321088046\n",
      "Iteration: 2\n",
      "new candidats: tensor([[0.4883, 0.7328],\n",
      "        [0.1874, 0.8018],\n",
      "        [0.8647, 0.9135],\n",
      "        [0.9843, 0.0255],\n",
      "        [0.8237, 0.7918],\n",
      "        [0.9215, 0.2242],\n",
      "        [0.4502, 0.7608],\n",
      "        [0.7301, 0.6240],\n",
      "        [0.0954, 0.8243],\n",
      "        [0.0758, 0.2445]], dtype=torch.float64)\n",
      "new obj: tensor([[6.6393e-01, 3.7974e-01],\n",
      "        [8.5478e-03, 7.7567e-02],\n",
      "        [9.6275e-05, 7.8537e-06],\n",
      "        [2.8089e-02, 6.2589e-03],\n",
      "        [2.4873e-03, 9.3404e-05],\n",
      "        [3.2574e-01, 1.1561e-02],\n",
      "        [5.1842e-01, 5.7317e-01],\n",
      "        [3.8768e-02, 8.6720e-04],\n",
      "        [3.4300e-03, 1.0373e-02],\n",
      "        [4.0220e-01, 4.8755e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.12402856]\n",
      "Time: 51.59064986300655\n",
      "Iteration: 3\n",
      "new candidats: tensor([[0.7298, 0.1569],\n",
      "        [0.1961, 0.1752],\n",
      "        [0.4357, 0.7735],\n",
      "        [0.4212, 0.1541],\n",
      "        [0.3677, 0.9439],\n",
      "        [0.3769, 0.1170],\n",
      "        [0.7020, 0.2568],\n",
      "        [0.8297, 0.8283],\n",
      "        [0.4170, 0.7724],\n",
      "        [0.8476, 0.1325]], dtype=torch.float64)\n",
      "new obj: tensor([[5.1316e-01, 2.2435e-02],\n",
      "        [4.9608e-01, 4.0671e-01],\n",
      "        [4.3876e-01, 6.3556e-01],\n",
      "        [2.6466e-01, 1.0421e-01],\n",
      "        [1.5252e-02, 2.3616e-01],\n",
      "        [3.1032e-01, 1.4135e-01],\n",
      "        [3.8925e-01, 3.3211e-03],\n",
      "        [1.3680e-03, 6.8569e-05],\n",
      "        [3.8633e-01, 6.6600e-01],\n",
      "        [5.0002e-01, 5.6655e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14145918]\n",
      "Time: 51.69774099206552\n",
      "Iteration: 4\n",
      "new candidats: tensor([[0.3273, 0.2911],\n",
      "        [0.3401, 0.6031],\n",
      "        [0.4632, 0.5158],\n",
      "        [0.4723, 0.7418],\n",
      "        [0.3035, 0.0425],\n",
      "        [0.3939, 0.6742],\n",
      "        [0.5050, 0.7792],\n",
      "        [0.4960, 0.7138],\n",
      "        [0.5090, 0.2216],\n",
      "        [0.1656, 0.6823]], dtype=torch.float64)\n",
      "new obj: tensor([[0.3681, 0.1970],\n",
      "        [0.1732, 0.1105],\n",
      "        [0.1805, 0.0309],\n",
      "        [0.6223, 0.4568],\n",
      "        [0.3207, 0.1854],\n",
      "        [0.4043, 0.3249],\n",
      "        [0.5131, 0.3956],\n",
      "        [0.6990, 0.3065],\n",
      "        [0.1606, 0.0447],\n",
      "        [0.0295, 0.0468]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15171528]\n",
      "Time: 50.437032657908276\n",
      "Iteration: 5\n",
      "new candidats: tensor([[1.9612e-01, 1.7522e-01],\n",
      "        [6.8341e-01, 6.9980e-01],\n",
      "        [8.4354e-01, 5.2314e-01],\n",
      "        [8.1491e-01, 5.7029e-01],\n",
      "        [9.5287e-01, 9.0858e-01],\n",
      "        [4.6759e-01, 4.5743e-05],\n",
      "        [5.8388e-01, 7.4605e-01],\n",
      "        [1.8839e-01, 2.4612e-01],\n",
      "        [1.5813e-01, 2.7615e-01],\n",
      "        [2.5237e-01, 2.5884e-01]], dtype=torch.float64)\n",
      "new obj: tensor([[4.9608e-01, 4.0671e-01],\n",
      "        [1.3140e-01, 7.8380e-03],\n",
      "        [4.6055e-03, 7.7335e-05],\n",
      "        [3.6473e-03, 9.6703e-05],\n",
      "        [3.5865e-06, 1.4468e-07],\n",
      "        [1.2432e-01, 4.2050e-02],\n",
      "        [4.4479e-01, 1.1205e-01],\n",
      "        [4.8606e-01, 4.0864e-01],\n",
      "        [4.5496e-01, 4.2202e-01],\n",
      "        [4.6269e-01, 3.1595e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15171528]\n",
      "Time: 59.94558302802034\n",
      "Iteration: 6\n",
      "new candidats: tensor([[0.9270, 0.6651],\n",
      "        [0.6129, 0.6106],\n",
      "        [0.6355, 0.0216],\n",
      "        [0.6919, 0.8306],\n",
      "        [0.4723, 0.7418],\n",
      "        [0.4502, 0.7608],\n",
      "        [0.9518, 0.1271],\n",
      "        [0.8528, 0.9516],\n",
      "        [0.1240, 0.3920],\n",
      "        [0.2541, 0.2025]], dtype=torch.float64)\n",
      "new obj: tensor([[1.2381e-04, 3.7099e-06],\n",
      "        [2.5538e-01, 1.3597e-02],\n",
      "        [6.8214e-02, 6.1911e-03],\n",
      "        [4.7504e-02, 9.4597e-03],\n",
      "        [6.2226e-01, 4.5679e-01],\n",
      "        [5.1842e-01, 5.7317e-01],\n",
      "        [1.6991e-01, 7.6010e-02],\n",
      "        [6.0576e-05, 8.0211e-06],\n",
      "        [2.9348e-01, 3.0418e-01],\n",
      "        [4.8203e-01, 3.2737e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15171528]\n",
      "Time: 39.53353640297428\n",
      "Iteration: 7\n",
      "new candidats: tensor([[0.1467, 0.9627],\n",
      "        [0.4502, 0.7608],\n",
      "        [0.4192, 0.8038],\n",
      "        [0.5577, 0.9668],\n",
      "        [0.8863, 0.7390],\n",
      "        [0.4357, 0.7735],\n",
      "        [0.6382, 0.7425],\n",
      "        [0.4170, 0.7724],\n",
      "        [0.9229, 0.0810],\n",
      "        [0.0642, 0.7730]], dtype=torch.float64)\n",
      "new obj: tensor([[3.7842e-04, 7.8559e-03],\n",
      "        [5.1842e-01, 5.7317e-01],\n",
      "        [2.9753e-01, 6.8783e-01],\n",
      "        [1.6935e-02, 5.0242e-02],\n",
      "        [4.0944e-04, 7.4434e-06],\n",
      "        [4.3876e-01, 6.3556e-01],\n",
      "        [2.4733e-01, 3.5033e-02],\n",
      "        [3.8633e-01, 6.6600e-01],\n",
      "        [1.6264e-01, 2.2521e-01],\n",
      "        [6.5915e-03, 1.0648e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.1531067]\n",
      "Time: 29.86163606797345\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration: 8\n",
      "new candidats: tensor([[0.8032, 0.4323],\n",
      "        [0.4723, 0.7418],\n",
      "        [0.8945, 0.4468],\n",
      "        [0.4634, 0.5320],\n",
      "        [0.1915, 0.7513],\n",
      "        [0.4133, 0.0346],\n",
      "        [0.8096, 0.3649],\n",
      "        [0.7733, 0.2198],\n",
      "        [0.4502, 0.7608],\n",
      "        [0.1032, 0.1319]], dtype=torch.float64)\n",
      "new obj: tensor([[4.9975e-02, 3.0753e-04],\n",
      "        [6.2226e-01, 4.5679e-01],\n",
      "        [2.1906e-02, 4.7668e-05],\n",
      "        [2.1265e-01, 3.4008e-02],\n",
      "        [1.6437e-02, 7.9974e-02],\n",
      "        [2.0115e-01, 8.1364e-02],\n",
      "        [1.8228e-01, 3.8209e-04],\n",
      "        [6.7055e-01, 1.3250e-02],\n",
      "        [5.1842e-01, 5.7317e-01],\n",
      "        [4.1966e-01, 4.6543e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.1531067]\n",
      "Time: 53.604365515057\n",
      "Iteration: 1\n",
      "new candidats: tensor([[0.7666, 0.0979],\n",
      "        [0.5445, 0.8199],\n",
      "        [0.0419, 0.7801],\n",
      "        [0.0848, 0.6089],\n",
      "        [0.1673, 0.9646],\n",
      "        [0.4413, 0.8634],\n",
      "        [0.5190, 0.9914],\n",
      "        [0.9124, 0.0304],\n",
      "        [0.1120, 0.8225],\n",
      "        [0.9383, 0.1064]], dtype=torch.float64)\n",
      "new obj: tensor([[4.0090e-01, 1.7521e-01],\n",
      "        [3.0978e-01, 2.4186e-01],\n",
      "        [5.4631e-03, 8.5010e-03],\n",
      "        [5.2457e-02, 6.2442e-02],\n",
      "        [4.1441e-04, 1.2354e-02],\n",
      "        [1.5610e-01, 5.2607e-01],\n",
      "        [9.8924e-03, 5.5220e-02],\n",
      "        [8.9007e-02, 1.2210e-01],\n",
      "        [3.7556e-03, 1.4645e-02],\n",
      "        [1.7404e-01, 1.4582e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.08457136]\n",
      "Time: 32.07300909003243\n",
      "Iteration: 2\n",
      "new candidats: tensor([[0.1394, 0.1498],\n",
      "        [0.4277, 0.3741],\n",
      "        [0.2015, 0.8789],\n",
      "        [0.4371, 0.7727],\n",
      "        [0.0523, 0.2589],\n",
      "        [0.4584, 0.7222],\n",
      "        [0.8470, 0.7175],\n",
      "        [0.0965, 0.3267],\n",
      "        [0.6570, 0.5158],\n",
      "        [0.5821, 0.9318]], dtype=torch.float64)\n",
      "new obj: tensor([[4.6277e-01, 4.5619e-01],\n",
      "        [1.8185e-01, 6.9225e-02],\n",
      "        [3.2148e-03, 7.2761e-02],\n",
      "        [4.4500e-01, 6.3112e-01],\n",
      "        [3.6446e-01, 4.7691e-01],\n",
      "        [6.3343e-01, 4.3877e-01],\n",
      "        [1.7690e-03, 3.2107e-05],\n",
      "        [3.5779e-01, 4.0550e-01],\n",
      "        [4.9697e-02, 2.3896e-03],\n",
      "        [3.4160e-02, 5.6026e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.12999949]\n",
      "Time: 49.57425368507393\n",
      "Iteration: 3\n",
      "new candidats: tensor([[0.1324, 0.3309],\n",
      "        [0.7847, 0.8100],\n",
      "        [0.9960, 0.8429],\n",
      "        [0.9101, 0.3103],\n",
      "        [0.4423, 0.2880],\n",
      "        [0.4393, 0.7500],\n",
      "        [0.2062, 0.3849],\n",
      "        [0.0583, 0.5696],\n",
      "        [0.5923, 0.1791],\n",
      "        [0.3089, 0.5024]], dtype=torch.float64)\n",
      "new obj: tensor([[3.8119e-01, 3.8441e-01],\n",
      "        [6.7077e-03, 4.3360e-04],\n",
      "        [2.1822e-06, 7.5445e-08],\n",
      "        [2.0871e-01, 1.1240e-04],\n",
      "        [2.1875e-01, 8.0233e-02],\n",
      "        [5.1951e-01, 5.7382e-01],\n",
      "        [3.2596e-01, 2.5855e-01],\n",
      "        [7.0552e-02, 9.0656e-02],\n",
      "        [1.5183e-01, 1.6439e-02],\n",
      "        [1.5349e-01, 8.3642e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13799157]\n",
      "Time: 54.29772396106273\n",
      "Iteration: 4\n",
      "new candidats: tensor([[0.9471, 0.8558],\n",
      "        [0.3649, 0.8618],\n",
      "        [0.9921, 0.9571],\n",
      "        [0.8551, 0.7703],\n",
      "        [0.0523, 0.2589],\n",
      "        [0.4779, 0.7129],\n",
      "        [0.9238, 0.8702],\n",
      "        [0.5898, 0.4452],\n",
      "        [0.7579, 0.1803],\n",
      "        [0.4371, 0.7727]], dtype=torch.float64)\n",
      "new obj: tensor([[1.1646e-05, 3.4365e-07],\n",
      "        [7.7440e-02, 5.4456e-01],\n",
      "        [2.9376e-07, 1.4350e-08],\n",
      "        [1.0375e-03, 2.5123e-05],\n",
      "        [3.6446e-01, 4.7691e-01],\n",
      "        [6.8454e-01, 3.5600e-01],\n",
      "        [2.3305e-05, 8.0386e-07],\n",
      "        [5.7280e-02, 8.2589e-03],\n",
      "        [6.3843e-01, 3.6618e-02],\n",
      "        [4.4500e-01, 6.3112e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14488635]\n",
      "Time: 55.26595978322439\n",
      "Iteration: 5\n",
      "new candidats: tensor([[0.6333, 0.1407],\n",
      "        [0.2328, 0.1868],\n",
      "        [0.4277, 0.3741],\n",
      "        [0.4302, 0.3127],\n",
      "        [0.4292, 0.6773],\n",
      "        [0.1986, 0.4125],\n",
      "        [0.1394, 0.1498],\n",
      "        [0.1023, 0.3504],\n",
      "        [0.2719, 0.0475],\n",
      "        [0.9476, 0.7905]], dtype=torch.float64)\n",
      "new obj: tensor([[1.9220e-01, 9.1023e-03],\n",
      "        [4.9226e-01, 3.5825e-01],\n",
      "        [1.8185e-01, 6.9225e-02],\n",
      "        [2.2065e-01, 8.4268e-02],\n",
      "        [5.4601e-01, 3.2162e-01],\n",
      "        [2.8443e-01, 2.3128e-01],\n",
      "        [4.6277e-01, 4.5619e-01],\n",
      "        [3.3446e-01, 3.7200e-01],\n",
      "        [3.5049e-01, 2.2465e-01],\n",
      "        [2.6625e-05, 6.3555e-07]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14488635]\n",
      "Time: 56.96672413684428\n",
      "Iteration: 6\n",
      "new candidats: tensor([[0.3439, 0.1563],\n",
      "        [0.9645, 0.4264],\n",
      "        [0.8179, 0.8271],\n",
      "        [0.7018, 0.5309],\n",
      "        [0.4371, 0.7727],\n",
      "        [0.6812, 0.6231],\n",
      "        [0.4371, 0.7727],\n",
      "        [0.6284, 0.7086],\n",
      "        [0.7196, 0.6873],\n",
      "        [0.7996, 0.0090]], dtype=torch.float64)\n",
      "new obj: tensor([[3.7684e-01, 1.9108e-01],\n",
      "        [1.4115e-02, 1.1944e-05],\n",
      "        [2.0267e-03, 1.1231e-04],\n",
      "        [2.9147e-02, 1.0636e-03],\n",
      "        [4.4500e-01, 6.3112e-01],\n",
      "        [1.0387e-01, 3.3100e-03],\n",
      "        [4.4500e-01, 6.3112e-01],\n",
      "        [3.0782e-01, 3.4370e-02],\n",
      "        [6.3228e-02, 2.3789e-03],\n",
      "        [1.1642e-01, 8.0641e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14488635]\n",
      "Time: 20.709916145075113\n",
      "Iteration: 7\n",
      "new candidats: tensor([[0.1512, 0.0500],\n",
      "        [0.5034, 0.2555],\n",
      "        [0.4423, 0.2880],\n",
      "        [0.6477, 0.7716],\n",
      "        [0.3818, 0.5251],\n",
      "        [0.4393, 0.7500],\n",
      "        [0.0296, 0.5972],\n",
      "        [0.4584, 0.7222],\n",
      "        [0.9238, 0.8702],\n",
      "        [0.8271, 0.5345]], dtype=torch.float64)\n",
      "new obj: tensor([[3.6643e-01, 3.4760e-01],\n",
      "        [1.5962e-01, 4.5962e-02],\n",
      "        [2.1875e-01, 8.0233e-02],\n",
      "        [1.8256e-01, 3.1372e-02],\n",
      "        [1.6369e-01, 5.5304e-02],\n",
      "        [5.1951e-01, 5.7382e-01],\n",
      "        [4.8415e-02, 6.8284e-02],\n",
      "        [6.3343e-01, 4.3877e-01],\n",
      "        [2.3305e-05, 8.0386e-07],\n",
      "        [4.2564e-03, 9.7660e-05]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14488635]\n",
      "Time: 44.86121624708176\n",
      "Iteration: 8\n",
      "new candidats: tensor([[0.3649, 0.8618],\n",
      "        [0.7167, 0.2919],\n",
      "        [0.0777, 0.2308],\n",
      "        [0.1079, 0.4954],\n",
      "        [0.9210, 0.2211],\n",
      "        [0.4371, 0.7727],\n",
      "        [0.8345, 0.2196],\n",
      "        [0.7894, 0.2034],\n",
      "        [0.9023, 0.7318],\n",
      "        [0.0318, 0.5049]], dtype=torch.float64)\n",
      "new obj: tensor([[7.7440e-02, 5.4456e-01],\n",
      "        [3.4025e-01, 2.4284e-03],\n",
      "        [4.0988e-01, 4.9376e-01],\n",
      "        [1.5117e-01, 1.6513e-01],\n",
      "        [3.2999e-01, 1.3641e-02],\n",
      "        [4.4500e-01, 6.3112e-01],\n",
      "        [6.5016e-01, 3.8507e-02],\n",
      "        [7.0221e-01, 4.0394e-02],\n",
      "        [2.3471e-04, 4.3756e-06],\n",
      "        [1.0982e-01, 1.5362e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14488635]\n",
      "Time: 35.55629434902221\n",
      "Iteration: 1\n",
      "new candidats: tensor([[0.0015, 0.4079],\n",
      "        [0.4496, 0.5200],\n",
      "        [0.0309, 0.1534],\n",
      "        [0.9432, 0.6032],\n",
      "        [0.4531, 0.9659],\n",
      "        [0.9751, 0.9915],\n",
      "        [0.1108, 0.0289],\n",
      "        [0.4409, 0.8685],\n",
      "        [0.4107, 0.8070],\n",
      "        [0.8958, 0.2143]], dtype=torch.float64)\n",
      "new obj: tensor([[1.7795e-01, 2.7466e-01],\n",
      "        [1.8579e-01, 3.5238e-02],\n",
      "        [3.4045e-01, 4.7744e-01],\n",
      "        [1.6348e-04, 4.7917e-06],\n",
      "        [1.8436e-02, 1.5358e-01],\n",
      "        [2.3435e-07, 1.4462e-08],\n",
      "        [3.1398e-01, 3.3963e-01],\n",
      "        [1.4318e-01, 5.0957e-01],\n",
      "        [2.6793e-01, 6.9542e-01],\n",
      "        [4.3918e-01, 3.3804e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.06935172]\n",
      "Time: 46.15229329094291\n",
      "Iteration: 2\n",
      "new candidats: tensor([[0.3768, 0.1105],\n",
      "        [0.9824, 0.2614],\n",
      "        [0.4151, 0.4598],\n",
      "        [0.1108, 0.0289],\n",
      "        [0.1765, 0.2243],\n",
      "        [0.3896, 0.6940],\n",
      "        [0.4926, 0.4093],\n",
      "        [0.3944, 0.7555],\n",
      "        [0.4820, 0.7547],\n",
      "        [0.0158, 0.5758]], dtype=torch.float64)\n",
      "new obj: tensor([[3.0612e-01, 1.3949e-01],\n",
      "        [1.1016e-01, 1.2943e-04],\n",
      "        [1.4790e-01, 5.0659e-02],\n",
      "        [3.1398e-01, 3.3963e-01],\n",
      "        [4.9293e-01, 4.3068e-01],\n",
      "        [3.9488e-01, 4.0359e-01],\n",
      "        [1.1005e-01, 3.1230e-02],\n",
      "        [3.5027e-01, 6.3594e-01],\n",
      "        [5.9713e-01, 4.5250e-01],\n",
      "        [5.5979e-02, 8.2499e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.10851084]\n",
      "Time: 41.15784047287889\n",
      "Iteration: 3\n",
      "new candidats: tensor([[0.6568, 0.7403],\n",
      "        [0.1207, 0.9088],\n",
      "        [0.6631, 0.2550],\n",
      "        [0.4586, 0.0343],\n",
      "        [0.6001, 0.6915],\n",
      "        [0.7895, 0.0350],\n",
      "        [0.5591, 0.3562],\n",
      "        [0.4457, 0.7489],\n",
      "        [0.9328, 0.0666],\n",
      "        [0.4736, 0.7308]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1896, 0.0218],\n",
      "        [0.0009, 0.0088],\n",
      "        [0.2688, 0.0059],\n",
      "        [0.1543, 0.0537],\n",
      "        [0.4260, 0.0533],\n",
      "        [0.1829, 0.1451],\n",
      "        [0.0865, 0.0185],\n",
      "        [0.5413, 0.5555],\n",
      "        [0.1196, 0.1423],\n",
      "        [0.6506, 0.4221]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13788345]\n",
      "Time: 45.85201227199286\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration: 4\n",
      "new candidats: tensor([[0.7707, 0.3929],\n",
      "        [0.7878, 0.2230],\n",
      "        [0.6562, 0.2685],\n",
      "        [0.0187, 0.9612],\n",
      "        [0.9854, 0.5407],\n",
      "        [0.5452, 0.4865],\n",
      "        [0.8363, 0.7867],\n",
      "        [0.2424, 0.1455],\n",
      "        [0.4884, 0.9195],\n",
      "        [0.4257, 0.7569]], dtype=torch.float64)\n",
      "new obj: tensor([[1.0984e-01, 6.7911e-04],\n",
      "        [6.8334e-01, 1.6484e-02],\n",
      "        [2.3186e-01, 6.4310e-03],\n",
      "        [2.3722e-04, 4.7877e-04],\n",
      "        [4.3335e-04, 3.3145e-06],\n",
      "        [1.0554e-01, 1.2450e-02],\n",
      "        [1.7230e-03, 5.5308e-05],\n",
      "        [4.7107e-01, 3.3228e-01],\n",
      "        [6.2851e-02, 2.3208e-01],\n",
      "        [4.5720e-01, 6.1929e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14470342]\n",
      "Time: 44.08241821685806\n",
      "Iteration: 5\n",
      "new candidats: tensor([[0.5196, 0.3556],\n",
      "        [0.3109, 0.0825],\n",
      "        [0.7655, 0.3594],\n",
      "        [0.8777, 0.1674],\n",
      "        [0.7661, 0.1034],\n",
      "        [0.4107, 0.8070],\n",
      "        [0.4257, 0.7569],\n",
      "        [0.6912, 0.6140],\n",
      "        [0.6878, 0.3589],\n",
      "        [0.4747, 0.4263]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1090, 0.0295],\n",
      "        [0.3608, 0.2037],\n",
      "        [0.1919, 0.0009],\n",
      "        [0.4925, 0.2424],\n",
      "        [0.4225, 0.1720],\n",
      "        [0.2679, 0.6954],\n",
      "        [0.4572, 0.6193],\n",
      "        [0.0807, 0.0023],\n",
      "        [0.1245, 0.0031],\n",
      "        [0.1189, 0.0345]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14470342]\n",
      "Time: 65.66446677688509\n",
      "Iteration: 6\n",
      "new candidats: tensor([[0.7013, 0.6939],\n",
      "        [0.3362, 0.5561],\n",
      "        [0.4736, 0.7308],\n",
      "        [0.7317, 0.1417],\n",
      "        [0.2820, 0.4801],\n",
      "        [0.9105, 0.8394],\n",
      "        [0.3395, 0.0357],\n",
      "        [0.4257, 0.7569],\n",
      "        [0.6348, 0.1959],\n",
      "        [0.2981, 0.8415]], dtype=torch.float64)\n",
      "new obj: tensor([[9.3142e-02, 4.4212e-03],\n",
      "        [1.4622e-01, 7.1445e-02],\n",
      "        [6.5055e-01, 4.2206e-01],\n",
      "        [4.8165e-01, 3.2036e-02],\n",
      "        [1.7820e-01, 1.0900e-01],\n",
      "        [6.3535e-05, 1.8605e-06],\n",
      "        [2.7973e-01, 1.4391e-01],\n",
      "        [4.5720e-01, 6.1929e-01],\n",
      "        [2.2567e-01, 9.2858e-03],\n",
      "        [3.6101e-02, 3.8365e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14470342]\n",
      "Time: 50.669102411018685\n",
      "Iteration: 7\n",
      "new candidats: tensor([[0.4403, 0.2000],\n",
      "        [0.4257, 0.7569],\n",
      "        [0.6001, 0.6915],\n",
      "        [0.1189, 0.1634],\n",
      "        [0.6943, 0.0972],\n",
      "        [0.0365, 0.8086],\n",
      "        [0.3575, 0.7040],\n",
      "        [0.2194, 0.9063],\n",
      "        [0.0778, 0.8402],\n",
      "        [0.4736, 0.7308]], dtype=torch.float64)\n",
      "new obj: tensor([[0.2440, 0.0900],\n",
      "        [0.4572, 0.6193],\n",
      "        [0.4260, 0.0533],\n",
      "        [0.4528, 0.4772],\n",
      "        [0.2567, 0.0088],\n",
      "        [0.0035, 0.0058],\n",
      "        [0.2685, 0.4110],\n",
      "        [0.0026, 0.0787],\n",
      "        [0.0025, 0.0066],\n",
      "        [0.6506, 0.4221]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14470342]\n",
      "Time: 25.022259797900915\n",
      "Iteration: 8\n",
      "new candidats: tensor([[0.8651, 0.5389],\n",
      "        [0.4457, 0.7489],\n",
      "        [0.7456, 0.9787],\n",
      "        [0.4257, 0.7569],\n",
      "        [0.2448, 0.2258],\n",
      "        [0.0043, 0.9284],\n",
      "        [0.9680, 0.3969],\n",
      "        [0.5452, 0.4865],\n",
      "        [0.0433, 0.1970],\n",
      "        [0.5443, 0.6657]], dtype=torch.float64)\n",
      "new obj: tensor([[2.5293e-03, 4.4447e-05],\n",
      "        [5.4130e-01, 5.5551e-01],\n",
      "        [7.1244e-04, 3.6270e-04],\n",
      "        [4.5720e-01, 6.1929e-01],\n",
      "        [4.8356e-01, 3.3839e-01],\n",
      "        [4.0856e-04, 7.4666e-04],\n",
      "        [2.4758e-02, 1.2913e-05],\n",
      "        [1.0554e-01, 1.2450e-02],\n",
      "        [3.6782e-01, 4.9551e-01],\n",
      "        [6.0603e-01, 1.0239e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14470342]\n",
      "Time: 25.08096019201912\n",
      "Iteration: 1\n",
      "new candidats: tensor([[0.4378, 0.9305],\n",
      "        [0.0102, 0.3345],\n",
      "        [0.3957, 0.7505],\n",
      "        [0.0274, 0.1625],\n",
      "        [0.3957, 0.7505],\n",
      "        [0.1351, 0.1610],\n",
      "        [0.4103, 0.6691],\n",
      "        [0.4382, 0.6411],\n",
      "        [0.3191, 0.1419],\n",
      "        [0.1802, 0.6431]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0408, 0.2782],\n",
      "        [0.2543, 0.3814],\n",
      "        [0.3647, 0.6217],\n",
      "        [0.3385, 0.4803],\n",
      "        [0.3647, 0.6217],\n",
      "        [0.4654, 0.4653],\n",
      "        [0.4649, 0.3032],\n",
      "        [0.5077, 0.1921],\n",
      "        [0.4015, 0.2207],\n",
      "        [0.0464, 0.0552]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07782696]\n",
      "Time: 39.24611934903078\n",
      "Iteration: 2\n",
      "new candidats: tensor([[0.9436, 0.0153],\n",
      "        [0.9908, 0.0651],\n",
      "        [0.4611, 0.7300],\n",
      "        [0.4629, 0.7689],\n",
      "        [0.8255, 0.3164],\n",
      "        [0.7629, 0.1696],\n",
      "        [0.0543, 0.8551],\n",
      "        [0.4369, 0.7480],\n",
      "        [0.4988, 0.6983],\n",
      "        [0.9216, 0.9793]], dtype=torch.float64)\n",
      "new obj: tensor([[4.5606e-02, 2.8841e-02],\n",
      "        [4.5837e-02, 1.0441e-02],\n",
      "        [6.2664e-01, 4.5704e-01],\n",
      "        [5.1899e-01, 5.4855e-01],\n",
      "        [3.4723e-01, 3.8945e-04],\n",
      "        [6.3326e-01, 5.9407e-02],\n",
      "        [1.8063e-03, 3.8632e-03],\n",
      "        [5.1708e-01, 5.7332e-01],\n",
      "        [7.0720e-01, 2.5850e-01],\n",
      "        [2.3294e-06, 2.0232e-07]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13514336]\n",
      "Time: 33.79497157293372\n",
      "Iteration: 3\n",
      "new candidats: tensor([[0.0767, 0.8761],\n",
      "        [0.2125, 0.1708],\n",
      "        [0.1791, 0.4190],\n",
      "        [0.4328, 0.3209],\n",
      "        [0.1071, 0.3563],\n",
      "        [0.2125, 0.1708],\n",
      "        [0.4286, 0.7580],\n",
      "        [0.2395, 0.2891],\n",
      "        [0.4548, 0.1680],\n",
      "        [0.3724, 0.1133]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0014, 0.0045],\n",
      "        [0.4937, 0.3837],\n",
      "        [0.2731, 0.2366],\n",
      "        [0.2124, 0.0804],\n",
      "        [0.3307, 0.3621],\n",
      "        [0.4937, 0.3837],\n",
      "        [0.4636, 0.6174],\n",
      "        [0.4440, 0.3162],\n",
      "        [0.2210, 0.0776],\n",
      "        [0.3139, 0.1451]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13950388]\n",
      "Time: 49.83336455980316\n",
      "Iteration: 4\n",
      "new candidats: tensor([[0.1351, 0.1610],\n",
      "        [0.7756, 0.7630],\n",
      "        [0.5156, 0.8088],\n",
      "        [0.5764, 0.0278],\n",
      "        [0.4286, 0.7580],\n",
      "        [0.3111, 0.8900],\n",
      "        [0.3201, 0.8164],\n",
      "        [0.3344, 0.1718],\n",
      "        [0.1279, 0.0197],\n",
      "        [0.0496, 0.5812]], dtype=torch.float64)\n",
      "new obj: tensor([[4.6541e-01, 4.6531e-01],\n",
      "        [1.3011e-02, 5.8343e-04],\n",
      "        [3.8401e-01, 3.5777e-01],\n",
      "        [7.1813e-02, 1.4002e-02],\n",
      "        [4.6361e-01, 6.1741e-01],\n",
      "        [2.0430e-02, 3.1495e-01],\n",
      "        [7.4093e-02, 5.0392e-01],\n",
      "        [3.9500e-01, 2.0659e-01],\n",
      "        [3.1204e-01, 3.1937e-01],\n",
      "        [6.1293e-02, 8.1031e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13950388]\n",
      "Time: 42.105329491896555\n",
      "Iteration: 5\n",
      "new candidats: tensor([[0.3980, 0.7982],\n",
      "        [0.5332, 0.2760],\n",
      "        [0.3674, 0.0886],\n",
      "        [0.8621, 0.2930],\n",
      "        [0.7967, 0.5319],\n",
      "        [0.0162, 0.2966],\n",
      "        [0.0669, 0.7491],\n",
      "        [0.4938, 0.1461],\n",
      "        [0.4286, 0.7580],\n",
      "        [0.5616, 0.3868]], dtype=torch.float64)\n",
      "new obj: tensor([[2.6062e-01, 7.0124e-01],\n",
      "        [1.3115e-01, 3.1848e-02],\n",
      "        [3.0165e-01, 1.4171e-01],\n",
      "        [3.7667e-01, 5.7302e-04],\n",
      "        [6.3948e-03, 1.7873e-04],\n",
      "        [2.9164e-01, 4.2911e-01],\n",
      "        [9.3028e-03, 1.3938e-02],\n",
      "        [1.6952e-01, 5.1092e-02],\n",
      "        [4.6361e-01, 6.1741e-01],\n",
      "        [7.4497e-02, 1.5807e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14163792]\n",
      "Time: 22.01636704709381\n",
      "Iteration: 6\n",
      "new candidats: tensor([[0.8335, 0.3491],\n",
      "        [0.4286, 0.7580],\n",
      "        [0.9242, 0.4676],\n",
      "        [0.1636, 0.5046],\n",
      "        [0.2082, 0.8670],\n",
      "        [0.5940, 0.1333],\n",
      "        [0.3683, 0.9635],\n",
      "        [0.6723, 0.8353],\n",
      "        [0.2889, 0.9215],\n",
      "        [0.4008, 0.5793]], dtype=torch.float64)\n",
      "new obj: tensor([[2.2033e-01, 2.6211e-04],\n",
      "        [4.6361e-01, 6.1741e-01],\n",
      "        [9.3005e-03, 2.2321e-05],\n",
      "        [1.5454e-01, 1.4105e-01],\n",
      "        [4.3733e-03, 9.0309e-02],\n",
      "        [1.3509e-01, 1.5279e-02],\n",
      "        [9.3763e-03, 1.7502e-01],\n",
      "        [6.3678e-02, 1.6161e-02],\n",
      "        [7.1653e-03, 1.8095e-01],\n",
      "        [2.5673e-01, 8.2408e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14163792]\n",
      "Time: 10.338871798943728\n",
      "Iteration: 7\n",
      "new candidats: tensor([[0.3683, 0.9635],\n",
      "        [0.4103, 0.6691],\n",
      "        [0.4286, 0.7580],\n",
      "        [0.9242, 0.4676],\n",
      "        [0.0933, 0.9323],\n",
      "        [0.8120, 0.1706],\n",
      "        [0.5320, 0.7833],\n",
      "        [0.6794, 0.0111],\n",
      "        [0.2780, 0.7941],\n",
      "        [0.8098, 0.5038]], dtype=torch.float64)\n",
      "new obj: tensor([[9.3763e-03, 1.7502e-01],\n",
      "        [4.6487e-01, 3.0322e-01],\n",
      "        [4.6361e-01, 6.1741e-01],\n",
      "        [9.3005e-03, 2.2321e-05],\n",
      "        [5.4383e-04, 3.2562e-03],\n",
      "        [6.7024e-01, 1.9381e-01],\n",
      "        [4.7204e-01, 2.8922e-01],\n",
      "        [7.4947e-02, 3.5117e-03],\n",
      "        [4.3821e-02, 3.3537e-01],\n",
      "        [9.2525e-03, 1.7059e-04]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14163792]\n",
      "Time: 7.290694624884054\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration: 8\n",
      "new candidats: tensor([[0.2825, 0.1732],\n",
      "        [0.8720, 0.3732],\n",
      "        [0.4286, 0.7580],\n",
      "        [0.1411, 0.3849],\n",
      "        [0.4747, 0.0610],\n",
      "        [0.6139, 0.3154],\n",
      "        [0.2652, 0.9425],\n",
      "        [0.0933, 0.9323],\n",
      "        [0.9872, 0.2364],\n",
      "        [0.9378, 0.7927]], dtype=torch.float64)\n",
      "new obj: tensor([[4.5513e-01, 2.8181e-01],\n",
      "        [1.2166e-01, 1.1093e-04],\n",
      "        [4.6361e-01, 6.1741e-01],\n",
      "        [3.1229e-01, 3.0615e-01],\n",
      "        [1.5422e-01, 5.0682e-02],\n",
      "        [1.1359e-01, 1.0487e-02],\n",
      "        [2.8341e-03, 1.0261e-01],\n",
      "        [5.4383e-04, 3.2562e-03],\n",
      "        [1.1383e-01, 4.0638e-04],\n",
      "        [3.8248e-05, 8.7158e-07]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14163792]\n",
      "Time: 10.436078995000571\n",
      "Iteration: 1\n",
      "new candidats: tensor([[0.2031, 0.2368],\n",
      "        [0.7930, 0.5083],\n",
      "        [0.2531, 0.4206],\n",
      "        [0.3742, 0.5366],\n",
      "        [0.4228, 0.6897],\n",
      "        [0.8105, 0.7908],\n",
      "        [0.0102, 0.8864],\n",
      "        [0.4695, 0.9961],\n",
      "        [0.4561, 0.9313],\n",
      "        [0.1973, 0.0151]], dtype=torch.float64)\n",
      "new obj: tensor([[4.9155e-01, 3.9402e-01],\n",
      "        [9.4340e-03, 2.2605e-04],\n",
      "        [2.6337e-01, 1.7915e-01],\n",
      "        [1.6649e-01, 5.9239e-02],\n",
      "        [5.3016e-01, 3.7642e-01],\n",
      "        [3.8005e-03, 1.5965e-04],\n",
      "        [8.8366e-04, 1.5667e-03],\n",
      "        [8.4112e-03, 8.0395e-02],\n",
      "        [4.4105e-02, 2.5284e-01],\n",
      "        [3.2609e-01, 2.6629e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07928596]\n",
      "Time: 38.744806519011036\n",
      "Iteration: 2\n",
      "new candidats: tensor([[0.4284, 0.7756],\n",
      "        [0.4326, 0.7354],\n",
      "        [0.7037, 0.5843],\n",
      "        [0.8180, 0.9419],\n",
      "        [0.1874, 0.6287],\n",
      "        [0.0400, 0.8123],\n",
      "        [0.3990, 0.5265],\n",
      "        [0.0486, 0.3099],\n",
      "        [0.0512, 0.2230],\n",
      "        [0.5249, 0.2346]], dtype=torch.float64)\n",
      "new obj: tensor([[4.1114e-01, 6.5424e-01],\n",
      "        [5.3090e-01, 5.4144e-01],\n",
      "        [4.8579e-02, 1.1999e-03],\n",
      "        [2.4353e-04, 4.1613e-05],\n",
      "        [5.4252e-02, 5.9144e-02],\n",
      "        [3.3577e-03, 5.6255e-03],\n",
      "        [1.7373e-01, 5.0711e-02],\n",
      "        [3.2282e-01, 4.2751e-01],\n",
      "        [3.7668e-01, 4.9453e-01],\n",
      "        [1.4663e-01, 3.7060e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.11517843]\n",
      "Time: 56.75197097309865\n",
      "Iteration: 3\n",
      "new candidats: tensor([[0.2158, 0.0379],\n",
      "        [0.1717, 0.1315],\n",
      "        [0.2052, 0.3261],\n",
      "        [0.3960, 0.7891],\n",
      "        [0.4837, 0.7155],\n",
      "        [0.4472, 0.7473],\n",
      "        [0.4494, 0.7274],\n",
      "        [0.1872, 0.6053],\n",
      "        [0.6560, 0.4154],\n",
      "        [0.9659, 0.3238]], dtype=torch.float64)\n",
      "new obj: tensor([[3.5890e-01, 2.7599e-01],\n",
      "        [4.6681e-01, 4.1428e-01],\n",
      "        [4.0978e-01, 3.2616e-01],\n",
      "        [2.7822e-01, 6.9704e-01],\n",
      "        [6.8909e-01, 3.4727e-01],\n",
      "        [5.4987e-01, 5.4713e-01],\n",
      "        [6.0025e-01, 4.7861e-01],\n",
      "        [6.7367e-02, 6.4956e-02],\n",
      "        [4.8842e-02, 3.8439e-03],\n",
      "        [8.2445e-02, 2.0268e-05]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14812632]\n",
      "Time: 59.239133877912536\n",
      "Iteration: 4\n",
      "new candidats: tensor([[0.8365, 0.1509],\n",
      "        [0.9451, 0.5762],\n",
      "        [0.2091, 0.2859],\n",
      "        [0.5299, 0.4071],\n",
      "        [0.5491, 0.7259],\n",
      "        [0.5468, 0.1443],\n",
      "        [0.4472, 0.7473],\n",
      "        [0.1248, 0.7809],\n",
      "        [0.8522, 0.8820],\n",
      "        [0.0566, 0.6475]], dtype=torch.float64)\n",
      "new obj: tensor([[5.8336e-01, 4.0279e-01],\n",
      "        [3.0531e-04, 5.9566e-06],\n",
      "        [4.5552e-01, 3.5807e-01],\n",
      "        [8.6329e-02, 2.0915e-02],\n",
      "        [6.0350e-01, 1.7602e-01],\n",
      "        [1.3125e-01, 2.8053e-02],\n",
      "        [5.4987e-01, 5.4713e-01],\n",
      "        [7.3075e-03, 2.2664e-02],\n",
      "        [2.7797e-04, 1.8863e-05],\n",
      "        [3.1675e-02, 4.1430e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14812632]\n",
      "Time: 30.901066638994962\n",
      "Iteration: 5\n",
      "new candidats: tensor([[0.2947, 0.5187],\n",
      "        [0.9929, 0.0922],\n",
      "        [0.4669, 0.2154],\n",
      "        [0.9287, 0.3053],\n",
      "        [0.2520, 0.8110],\n",
      "        [0.8471, 0.4937],\n",
      "        [0.0356, 0.8227],\n",
      "        [0.8872, 0.0218],\n",
      "        [0.8338, 0.4953],\n",
      "        [0.5146, 0.1323]], dtype=torch.float64)\n",
      "new obj: tensor([[1.4202e-01, 8.2433e-02],\n",
      "        [6.1118e-02, 1.1680e-02],\n",
      "        [2.0729e-01, 6.9560e-02],\n",
      "        [1.7618e-01, 8.7456e-05],\n",
      "        [2.2010e-02, 2.3585e-01],\n",
      "        [9.4938e-03, 8.9881e-05],\n",
      "        [2.8075e-03, 4.7601e-03],\n",
      "        [9.8664e-02, 1.5610e-01],\n",
      "        [9.8797e-03, 1.1502e-04],\n",
      "        [1.4652e-01, 3.9913e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14812632]\n",
      "Time: 27.89083715993911\n",
      "Iteration: 6\n",
      "new candidats: tensor([[0.4472, 0.7473],\n",
      "        [0.8071, 0.8895],\n",
      "        [0.6458, 0.4226],\n",
      "        [0.6201, 0.2355],\n",
      "        [0.1297, 0.6936],\n",
      "        [0.4447, 0.6430],\n",
      "        [0.3330, 0.5818],\n",
      "        [0.7091, 0.2712],\n",
      "        [0.6458, 0.4226],\n",
      "        [0.7818, 0.1742]], dtype=torch.float64)\n",
      "new obj: tensor([[5.4987e-01, 5.4713e-01],\n",
      "        [1.0538e-03, 1.1958e-04],\n",
      "        [4.5499e-02, 4.2974e-03],\n",
      "        [1.8450e-01, 1.1207e-02],\n",
      "        [2.3087e-02, 3.3031e-02],\n",
      "        [5.3094e-01, 1.9218e-01],\n",
      "        [1.5118e-01, 8.5821e-02],\n",
      "        [3.7799e-01, 2.8813e-03],\n",
      "        [4.5499e-02, 4.2974e-03],\n",
      "        [6.7309e-01, 9.2665e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14812632]\n",
      "Time: 23.584600385976955\n",
      "Iteration: 7\n",
      "new candidats: tensor([[0.4984, 0.2113],\n",
      "        [0.5526, 0.5217],\n",
      "        [0.1855, 0.4400],\n",
      "        [0.0766, 0.9128],\n",
      "        [0.6216, 0.1685],\n",
      "        [0.1063, 0.8292],\n",
      "        [0.2003, 0.4703],\n",
      "        [0.4472, 0.7473],\n",
      "        [0.7693, 0.8238],\n",
      "        [0.4284, 0.7756]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1714, 0.0504],\n",
      "        [0.1536, 0.0120],\n",
      "        [0.2429, 0.2061],\n",
      "        [0.0007, 0.0029],\n",
      "        [0.1891, 0.0110],\n",
      "        [0.0033, 0.0125],\n",
      "        [0.2011, 0.1626],\n",
      "        [0.5499, 0.5471],\n",
      "        [0.0087, 0.0008],\n",
      "        [0.4111, 0.6542]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14812632]\n",
      "Time: 27.04414030397311\n",
      "Iteration: 8\n",
      "new candidats: tensor([[0.4472, 0.7473],\n",
      "        [0.8327, 0.4394],\n",
      "        [0.2142, 0.2340],\n",
      "        [0.5421, 0.2068],\n",
      "        [0.6643, 0.2304],\n",
      "        [0.5951, 0.8949],\n",
      "        [0.6686, 0.4634],\n",
      "        [0.3062, 0.3273],\n",
      "        [0.4776, 0.7230],\n",
      "        [0.0256, 0.6090]], dtype=torch.float64)\n",
      "new obj: tensor([[5.4987e-01, 5.4713e-01],\n",
      "        [3.9490e-02, 1.6972e-04],\n",
      "        [4.9161e-01, 3.8009e-01],\n",
      "        [1.4081e-01, 3.0801e-02],\n",
      "        [2.9970e-01, 5.9977e-03],\n",
      "        [6.6821e-02, 6.6538e-02],\n",
      "        [3.2985e-02, 2.4496e-03],\n",
      "        [3.5477e-01, 2.0335e-01],\n",
      "        [6.7107e-01, 3.8720e-01],\n",
      "        [4.2257e-02, 6.0390e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15095438]\n",
      "Time: 14.468181675998494\n",
      "Iteration: 1\n",
      "new candidats: tensor([[0.2160, 0.4570],\n",
      "        [0.8838, 0.3373],\n",
      "        [0.9572, 0.3832],\n",
      "        [0.5117, 0.4425],\n",
      "        [0.1328, 0.7356],\n",
      "        [0.4526, 0.2720],\n",
      "        [0.2160, 0.4570],\n",
      "        [0.1443, 0.0177],\n",
      "        [0.0060, 0.2654],\n",
      "        [0.3096, 0.3870]], dtype=torch.float64)\n",
      "new obj: tensor([[2.1897e-01, 1.6816e-01],\n",
      "        [1.9304e-01, 1.0741e-04],\n",
      "        [3.8272e-02, 1.7550e-05],\n",
      "        [9.7018e-02, 2.1563e-02],\n",
      "        [1.3869e-02, 2.9200e-02],\n",
      "        [2.1239e-01, 7.5168e-02],\n",
      "        [2.1897e-01, 1.6816e-01],\n",
      "        [3.1745e-01, 3.0796e-01],\n",
      "        [2.9609e-01, 4.5031e-01],\n",
      "        [2.7881e-01, 1.5770e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.01613288]\n",
      "Time: 22.994530549971387\n",
      "Iteration: 2\n",
      "new candidats: tensor([[0.9805, 0.8656],\n",
      "        [0.8419, 0.0240],\n",
      "        [0.3905, 0.1242],\n",
      "        [0.2160, 0.4570],\n",
      "        [0.4526, 0.2720],\n",
      "        [0.0965, 0.2055],\n",
      "        [0.7830, 0.7796],\n",
      "        [0.0791, 0.2410],\n",
      "        [0.1770, 0.1854],\n",
      "        [0.0134, 0.3916]], dtype=torch.float64)\n",
      "new obj: tensor([[2.6921e-06, 8.9318e-08],\n",
      "        [1.3817e-01, 2.1779e-01],\n",
      "        [2.9578e-01, 1.2888e-01],\n",
      "        [2.1897e-01, 1.6816e-01],\n",
      "        [2.1239e-01, 7.5168e-02],\n",
      "        [4.3717e-01, 4.9544e-01],\n",
      "        [9.3928e-03, 4.5986e-04],\n",
      "        [4.0787e-01, 4.8911e-01],\n",
      "        [4.9540e-01, 4.3214e-01],\n",
      "        [2.0450e-01, 3.0360e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.06808179]\n",
      "Time: 20.77811278705485\n",
      "Iteration: 3\n",
      "new candidats: tensor([[0.6711, 0.6454],\n",
      "        [0.2853, 0.6451],\n",
      "        [0.0089, 0.7208],\n",
      "        [0.2224, 0.7932],\n",
      "        [0.0805, 0.2042],\n",
      "        [0.9784, 0.0492],\n",
      "        [0.2586, 0.7056],\n",
      "        [0.1363, 0.2016],\n",
      "        [0.1321, 0.6080],\n",
      "        [0.1822, 0.2282]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1421, 0.0058],\n",
      "        [0.0984, 0.1328],\n",
      "        [0.0107, 0.0163],\n",
      "        [0.0157, 0.1489],\n",
      "        [0.4181, 0.4992],\n",
      "        [0.0459, 0.0155],\n",
      "        [0.0575, 0.1779],\n",
      "        [0.4752, 0.4733],\n",
      "        [0.0594, 0.0625],\n",
      "        [0.4931, 0.4230]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07034117]\n",
      "Time: 17.748486717930064\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration: 4\n",
      "new candidats: tensor([[0.5087, 0.9566],\n",
      "        [0.1363, 0.2016],\n",
      "        [0.8177, 0.8322],\n",
      "        [0.2211, 0.2148],\n",
      "        [0.0821, 0.5141],\n",
      "        [0.9687, 0.2618],\n",
      "        [0.3162, 0.0247],\n",
      "        [0.8043, 0.1356],\n",
      "        [0.9894, 0.6490],\n",
      "        [0.2571, 0.1144]], dtype=torch.float64)\n",
      "new obj: tensor([[2.6060e-02, 1.1384e-01],\n",
      "        [4.7523e-01, 4.7328e-01],\n",
      "        [1.9050e-03, 1.1109e-04],\n",
      "        [4.9587e-01, 3.7483e-01],\n",
      "        [1.2246e-01, 1.4548e-01],\n",
      "        [1.3968e-01, 2.4259e-04],\n",
      "        [2.8765e-01, 1.5965e-01],\n",
      "        [5.7329e-01, 3.5813e-01],\n",
      "        [2.5377e-05, 1.0421e-06],\n",
      "        [4.3807e-01, 2.9459e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.08102325]\n",
      "Time: 11.049746179953218\n",
      "Iteration: 5\n",
      "new candidats: tensor([[0.1200, 0.7740],\n",
      "        [0.3096, 0.3870],\n",
      "        [0.7754, 0.8426],\n",
      "        [0.3244, 0.7685],\n",
      "        [0.8419, 0.0240],\n",
      "        [0.6410, 0.8617],\n",
      "        [0.8043, 0.1356],\n",
      "        [0.7775, 0.1268],\n",
      "        [0.7654, 0.0429],\n",
      "        [0.9401, 0.2596]], dtype=torch.float64)\n",
      "new obj: tensor([[7.8995e-03, 2.1302e-02],\n",
      "        [2.7881e-01, 1.5770e-01],\n",
      "        [5.7542e-03, 5.6228e-04],\n",
      "        [1.2564e-01, 5.0430e-01],\n",
      "        [1.3817e-01, 2.1779e-01],\n",
      "        [7.0256e-02, 3.1752e-02],\n",
      "        [5.7329e-01, 3.5813e-01],\n",
      "        [5.2941e-01, 2.1250e-01],\n",
      "        [1.9858e-01, 8.7874e-02],\n",
      "        [2.2037e-01, 8.8716e-04]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.08102325]\n",
      "Time: 23.824049927992746\n",
      "Iteration: 6\n",
      "new candidats: tensor([[0.2603, 0.6818],\n",
      "        [0.0938, 0.6335],\n",
      "        [0.2566, 0.0624],\n",
      "        [0.9982, 0.5889],\n",
      "        [0.4054, 0.4897],\n",
      "        [0.8339, 0.1764],\n",
      "        [0.7775, 0.1268],\n",
      "        [0.6871, 0.8405],\n",
      "        [0.2130, 0.1531],\n",
      "        [0.8339, 0.1764]], dtype=torch.float64)\n",
      "new obj: tensor([[6.5183e-02, 1.4871e-01],\n",
      "        [4.1583e-02, 4.8990e-02],\n",
      "        [3.7913e-01, 2.5536e-01],\n",
      "        [7.8739e-05, 1.5889e-06],\n",
      "        [1.5239e-01, 4.8587e-02],\n",
      "        [6.4599e-01, 2.0707e-01],\n",
      "        [5.2941e-01, 2.1250e-01],\n",
      "        [4.5439e-02, 1.0480e-02],\n",
      "        [4.8544e-01, 3.7676e-01],\n",
      "        [6.4599e-01, 2.0707e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.08102325]\n",
      "Time: 22.226865058997646\n",
      "Iteration: 7\n",
      "new candidats: tensor([[0.3991, 0.8720],\n",
      "        [0.5997, 0.1941],\n",
      "        [0.4526, 0.2720],\n",
      "        [0.3194, 0.3769],\n",
      "        [0.2351, 0.1655],\n",
      "        [0.9894, 0.6490],\n",
      "        [0.7788, 0.1881],\n",
      "        [0.1145, 0.7189],\n",
      "        [0.2312, 0.8106],\n",
      "        [0.1742, 0.2773]], dtype=torch.float64)\n",
      "new obj: tensor([[9.6958e-02, 5.4075e-01],\n",
      "        [1.6182e-01, 1.4987e-02],\n",
      "        [2.1239e-01, 7.5168e-02],\n",
      "        [2.8367e-01, 1.5544e-01],\n",
      "        [4.8509e-01, 3.5039e-01],\n",
      "        [2.5377e-05, 1.0421e-06],\n",
      "        [6.8724e-01, 5.4682e-02],\n",
      "        [1.6176e-02, 2.5405e-02],\n",
      "        [1.4897e-02, 1.7074e-01],\n",
      "        [4.6017e-01, 4.0509e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.08102325]\n",
      "Time: 22.6144440358039\n",
      "Iteration: 8\n",
      "new candidats: tensor([[0.6590, 0.4553],\n",
      "        [0.7788, 0.1881],\n",
      "        [0.1101, 0.9142],\n",
      "        [0.6938, 0.9723],\n",
      "        [0.9904, 0.1369],\n",
      "        [0.8043, 0.1356],\n",
      "        [0.8085, 0.8538],\n",
      "        [0.2802, 0.0118],\n",
      "        [0.7063, 0.7420],\n",
      "        [0.2358, 0.8564]], dtype=torch.float64)\n",
      "new obj: tensor([[3.5756e-02, 2.9593e-03],\n",
      "        [6.8724e-01, 5.4682e-02],\n",
      "        [8.0392e-04, 6.2939e-03],\n",
      "        [2.6422e-03, 2.1225e-03],\n",
      "        [9.3796e-02, 1.0359e-02],\n",
      "        [5.7329e-01, 3.5813e-01],\n",
      "        [1.8637e-03, 1.4678e-04],\n",
      "        [2.9639e-01, 1.8492e-01],\n",
      "        [7.6885e-02, 5.5126e-03],\n",
      "        [8.5378e-03, 1.5674e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.08102325]\n",
      "Time: 24.286417135968804\n",
      "Iteration: 1\n",
      "new candidats: tensor([[0.1969, 0.1827],\n",
      "        [0.4436, 0.6325],\n",
      "        [0.2958, 0.2734],\n",
      "        [0.1910, 0.0272],\n",
      "        [0.7241, 0.1919],\n",
      "        [0.9825, 0.8726],\n",
      "        [0.2926, 0.7668],\n",
      "        [0.2415, 0.3427],\n",
      "        [0.0129, 0.0236],\n",
      "        [0.4021, 0.1861]], dtype=torch.float64)\n",
      "new obj: tensor([[4.9808e-01, 4.0726e-01],\n",
      "        [4.9828e-01, 1.6488e-01],\n",
      "        [4.1676e-01, 2.4708e-01],\n",
      "        [3.4384e-01, 2.8662e-01],\n",
      "        [5.3939e-01, 7.8076e-03],\n",
      "        [2.2201e-06, 7.5899e-08],\n",
      "        [7.3229e-02, 3.7684e-01],\n",
      "        [3.7941e-01, 2.6835e-01],\n",
      "        [2.1881e-01, 3.2534e-01],\n",
      "        [2.9965e-01, 1.2569e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.04919832]\n",
      "Time: 20.292257370892912\n",
      "Iteration: 2\n",
      "new candidats: tensor([[0.4385, 0.6020],\n",
      "        [0.0831, 0.9856],\n",
      "        [0.5686, 0.5508],\n",
      "        [0.2836, 0.5265],\n",
      "        [0.4910, 0.9825],\n",
      "        [0.4272, 0.8594],\n",
      "        [0.1314, 0.2134],\n",
      "        [0.7607, 0.4400],\n",
      "        [0.4313, 0.4906],\n",
      "        [0.5815, 0.2707]], dtype=torch.float64)\n",
      "new obj: tensor([[3.9084e-01, 1.0364e-01],\n",
      "        [1.8994e-04, 1.0470e-03],\n",
      "        [2.0151e-01, 1.2372e-02],\n",
      "        [1.3582e-01, 8.3021e-02],\n",
      "        [1.2984e-02, 8.7540e-02],\n",
      "        [1.5187e-01, 5.6599e-01],\n",
      "        [4.7037e-01, 4.7591e-01],\n",
      "        [4.1970e-02, 6.2722e-04],\n",
      "        [1.5088e-01, 3.9575e-02],\n",
      "        [1.2630e-01, 1.7851e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.06543843]\n",
      "Time: 18.427848846884444\n",
      "Iteration: 3\n",
      "new candidats: tensor([[0.7481, 0.1538],\n",
      "        [0.7950, 0.3581],\n",
      "        [0.9730, 0.6450],\n",
      "        [0.0805, 0.1647],\n",
      "        [0.4695, 0.6972],\n",
      "        [0.4214, 0.7571],\n",
      "        [0.8097, 0.0937],\n",
      "        [0.1910, 0.0272],\n",
      "        [0.0176, 0.2873],\n",
      "        [0.6172, 0.1753]], dtype=torch.float64)\n",
      "new obj: tensor([[5.6129e-01, 5.0849e-02],\n",
      "        [2.0466e-01, 5.1349e-04],\n",
      "        [4.0158e-05, 1.5897e-06],\n",
      "        [4.1184e-01, 4.9157e-01],\n",
      "        [6.7712e-01, 3.2734e-01],\n",
      "        [4.4209e-01, 6.2636e-01],\n",
      "        [4.0017e-01, 5.0270e-01],\n",
      "        [3.4384e-01, 2.8662e-01],\n",
      "        [2.9992e-01, 4.3922e-01],\n",
      "        [1.8407e-01, 1.1756e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.11579813]\n",
      "Time: 25.2085313370917\n",
      "Iteration: 4\n",
      "new candidats: tensor([[0.8905, 0.1566],\n",
      "        [0.7442, 0.4479],\n",
      "        [0.7121, 0.1166],\n",
      "        [0.0695, 0.4520],\n",
      "        [0.0089, 0.4683],\n",
      "        [0.9156, 0.7589],\n",
      "        [0.8414, 0.1553],\n",
      "        [0.8771, 0.1913],\n",
      "        [0.9206, 0.1149],\n",
      "        [0.9268, 0.2664]], dtype=torch.float64)\n",
      "new obj: tensor([[4.2436e-01, 2.6621e-01],\n",
      "        [3.4926e-02, 7.9343e-04],\n",
      "        [3.5297e-01, 1.7387e-02],\n",
      "        [1.8269e-01, 2.2604e-01],\n",
      "        [1.2877e-01, 1.9403e-01],\n",
      "        [1.2113e-04, 2.4058e-06],\n",
      "        [5.8432e-01, 3.7450e-01],\n",
      "        [5.1964e-01, 1.1421e-01],\n",
      "        [2.3630e-01, 2.4725e-01],\n",
      "        [2.5199e-01, 8.9747e-04]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.1198649]\n",
      "Time: 32.36960164899938\n",
      "Iteration: 5\n",
      "new candidats: tensor([[0.8489, 0.9439],\n",
      "        [0.1275, 0.4618],\n",
      "        [0.0141, 0.8479],\n",
      "        [0.7921, 0.3758],\n",
      "        [0.4549, 0.7641],\n",
      "        [0.4658, 0.7356],\n",
      "        [0.4323, 0.2204],\n",
      "        [0.8774, 0.2614],\n",
      "        [0.2623, 0.1497],\n",
      "        [0.5764, 0.9531]], dtype=torch.float64)\n",
      "new obj: tensor([[8.3789e-05, 1.0711e-05],\n",
      "        [1.9877e-01, 2.0366e-01],\n",
      "        [1.7089e-03, 2.8931e-03],\n",
      "        [1.5321e-01, 5.0168e-04],\n",
      "        [5.1893e-01, 5.6607e-01],\n",
      "        [6.2550e-01, 4.6004e-01],\n",
      "        [2.5419e-01, 9.6424e-02],\n",
      "        [4.3102e-01, 3.4211e-03],\n",
      "        [4.6149e-01, 3.0510e-01],\n",
      "        [2.1339e-02, 4.5809e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14186602]\n",
      "Time: 33.67311521107331\n",
      "Iteration: 6\n",
      "new candidats: tensor([[0.2520, 0.6883],\n",
      "        [0.6898, 0.6693],\n",
      "        [0.4272, 0.8594],\n",
      "        [0.6713, 0.8576],\n",
      "        [0.1803, 0.7330],\n",
      "        [0.2403, 0.1145],\n",
      "        [0.4157, 0.8010],\n",
      "        [0.8242, 0.6675],\n",
      "        [0.4945, 0.5974],\n",
      "        [0.3121, 0.7778]], dtype=torch.float64)\n",
      "new obj: tensor([[5.6627e-02, 1.4227e-01],\n",
      "        [1.1179e-01, 4.7311e-03],\n",
      "        [1.5187e-01, 5.6599e-01],\n",
      "        [4.6708e-02, 1.4962e-02],\n",
      "        [1.8278e-02, 6.2403e-02],\n",
      "        [4.4717e-01, 3.1756e-01],\n",
      "        [2.9768e-01, 6.9256e-01],\n",
      "        [3.7329e-03, 6.2678e-05],\n",
      "        [4.3658e-01, 6.4844e-02],\n",
      "        [9.5067e-02, 4.6780e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.146095]\n",
      "Time: 7.843718791147694\n",
      "Iteration: 7\n",
      "new candidats: tensor([[0.0102, 0.3843],\n",
      "        [0.4658, 0.7356],\n",
      "        [0.7073, 0.8970],\n",
      "        [0.5718, 0.3042],\n",
      "        [0.3779, 0.6431],\n",
      "        [0.7189, 0.8289],\n",
      "        [0.6813, 0.2376],\n",
      "        [0.0990, 0.1842],\n",
      "        [0.4658, 0.7356],\n",
      "        [0.0185, 0.5559]], dtype=torch.float64)\n",
      "new obj: tensor([[0.2085, 0.3127],\n",
      "        [0.6255, 0.4600],\n",
      "        [0.0118, 0.0039],\n",
      "        [0.1079, 0.0188],\n",
      "        [0.3115, 0.2125],\n",
      "        [0.0279, 0.0042],\n",
      "        [0.3497, 0.0047],\n",
      "        [0.4388, 0.4932],\n",
      "        [0.6255, 0.4600],\n",
      "        [0.0680, 0.0993]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.146095]\n",
      "Time: 5.474117813864723\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration: 8\n",
      "new candidats: tensor([[0.3214, 0.3256],\n",
      "        [0.4658, 0.7356],\n",
      "        [0.2174, 0.0583],\n",
      "        [0.8632, 0.2455],\n",
      "        [0.1154, 0.6981],\n",
      "        [0.4658, 0.7356],\n",
      "        [0.9658, 0.8521],\n",
      "        [0.0904, 0.0555],\n",
      "        [0.4194, 0.6838],\n",
      "        [0.1625, 0.3657]], dtype=torch.float64)\n",
      "new obj: tensor([[3.4157e-01, 1.8628e-01],\n",
      "        [6.2550e-01, 4.6004e-01],\n",
      "        [3.8750e-01, 2.9643e-01],\n",
      "        [5.1912e-01, 1.0013e-02],\n",
      "        [2.1008e-02, 2.9192e-02],\n",
      "        [6.2550e-01, 4.6004e-01],\n",
      "        [5.8799e-06, 1.7629e-07],\n",
      "        [3.3144e-01, 3.8308e-01],\n",
      "        [5.1396e-01, 3.5574e-01],\n",
      "        [3.4857e-01, 3.1874e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.146095]\n",
      "Time: 7.8263616662006825\n",
      "Iteration: 1\n",
      "new candidats: tensor([[0.3699, 0.7430],\n",
      "        [0.6418, 0.1354],\n",
      "        [0.5158, 0.7832],\n",
      "        [0.8126, 0.7857],\n",
      "        [0.3532, 0.7643],\n",
      "        [0.4494, 0.7003],\n",
      "        [0.8570, 0.2738],\n",
      "        [0.9967, 0.8555],\n",
      "        [0.9802, 0.2283],\n",
      "        [0.2943, 0.8569]], dtype=torch.float64)\n",
      "new obj: tensor([[2.8263e-01, 5.7282e-01],\n",
      "        [2.0393e-01, 8.0590e-03],\n",
      "        [4.9101e-01, 3.5366e-01],\n",
      "        [3.7289e-03, 1.4655e-04],\n",
      "        [2.0072e-01, 5.9213e-01],\n",
      "        [6.2594e-01, 3.8042e-01],\n",
      "        [4.5510e-01, 1.8476e-03],\n",
      "        [1.7507e-06, 6.1756e-08],\n",
      "        [1.3287e-01, 8.9146e-04],\n",
      "        [2.6670e-02, 3.4172e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.11426496]\n",
      "Time: 25.446844776859507\n",
      "Iteration: 2\n",
      "new candidats: tensor([[0.1557, 0.1742],\n",
      "        [0.7170, 0.1786],\n",
      "        [0.2262, 0.7621],\n",
      "        [0.8982, 0.0058],\n",
      "        [0.7301, 0.8990],\n",
      "        [0.4440, 0.7530],\n",
      "        [0.5720, 0.2384],\n",
      "        [0.3679, 0.1239],\n",
      "        [0.6011, 0.4603],\n",
      "        [0.8190, 0.0013]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4838, 0.4524],\n",
      "        [0.5024, 0.0086],\n",
      "        [0.0232, 0.1510],\n",
      "        [0.0663, 0.0747],\n",
      "        [0.0069, 0.0019],\n",
      "        [0.5251, 0.5710],\n",
      "        [0.1354, 0.0210],\n",
      "        [0.3270, 0.1534],\n",
      "        [0.0557, 0.0066],\n",
      "        [0.0980, 0.0826]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13016677]\n",
      "Time: 19.928418019087985\n",
      "Iteration: 3\n",
      "new candidats: tensor([[0.1199, 0.2684],\n",
      "        [0.4726, 0.7293],\n",
      "        [0.4734, 0.0184],\n",
      "        [0.7920, 0.8143],\n",
      "        [0.2387, 0.2198],\n",
      "        [0.8570, 0.2738],\n",
      "        [0.9278, 0.7111],\n",
      "        [0.1121, 0.7578],\n",
      "        [0.4238, 0.2776],\n",
      "        [0.1635, 0.8469]], dtype=torch.float64)\n",
      "new obj: tensor([[4.3530e-01, 4.5717e-01],\n",
      "        [6.5188e-01, 4.2080e-01],\n",
      "        [1.3072e-01, 4.3312e-02],\n",
      "        [5.1781e-03, 3.2544e-04],\n",
      "        [4.8831e-01, 3.4854e-01],\n",
      "        [4.5510e-01, 1.8476e-03],\n",
      "        [9.9890e-05, 2.3535e-06],\n",
      "        [9.6025e-03, 2.0157e-02],\n",
      "        [2.4843e-01, 9.6976e-02],\n",
      "        [3.4553e-03, 4.0653e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13941978]\n",
      "Time: 30.52341503603384\n",
      "Iteration: 4\n",
      "new candidats: tensor([[8.0663e-01, 6.6099e-01],\n",
      "        [9.0928e-01, 8.6548e-01],\n",
      "        [1.7204e-01, 3.8343e-01],\n",
      "        [4.8020e-01, 1.1190e-02],\n",
      "        [9.1019e-01, 2.3271e-01],\n",
      "        [8.1955e-01, 9.4755e-01],\n",
      "        [7.2661e-02, 5.4379e-04],\n",
      "        [4.1826e-01, 2.0763e-01],\n",
      "        [6.6572e-01, 4.2854e-01],\n",
      "        [4.7261e-01, 7.2929e-01]], dtype=torch.float64)\n",
      "new obj: tensor([[6.2627e-03, 1.0815e-04],\n",
      "        [4.4683e-05, 1.6136e-06],\n",
      "        [3.2516e-01, 2.8827e-01],\n",
      "        [1.2072e-01, 3.9085e-02],\n",
      "        [3.6250e-01, 1.0090e-02],\n",
      "        [2.0200e-04, 3.5897e-05],\n",
      "        [2.4830e-01, 3.0406e-01],\n",
      "        [2.7593e-01, 1.0971e-01],\n",
      "        [4.2613e-02, 3.1031e-03],\n",
      "        [6.5188e-01, 4.2080e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13941978]\n",
      "Time: 45.07376658800058\n",
      "Iteration: 5\n",
      "new candidats: tensor([[0.0778, 0.2980],\n",
      "        [0.0165, 0.0315],\n",
      "        [0.0346, 0.7547],\n",
      "        [0.7660, 0.7413],\n",
      "        [0.4348, 0.7698],\n",
      "        [0.7386, 0.8982],\n",
      "        [0.6164, 0.4312],\n",
      "        [0.6354, 0.0344],\n",
      "        [0.7904, 0.1412],\n",
      "        [0.4860, 0.7066]], dtype=torch.float64)\n",
      "new obj: tensor([[0.3680, 0.4431],\n",
      "        [0.2302, 0.3384],\n",
      "        [0.0076, 0.0113],\n",
      "        [0.0189, 0.0008],\n",
      "        [0.4480, 0.6311],\n",
      "        [0.0057, 0.0014],\n",
      "        [0.0479, 0.0062],\n",
      "        [0.0790, 0.0066],\n",
      "        [0.5923, 0.2458],\n",
      "        [0.6989, 0.3151]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14453808]\n",
      "Time: 16.37105289893225\n",
      "Iteration: 6\n",
      "new candidats: tensor([[0.5649, 0.7505],\n",
      "        [0.5065, 0.7021],\n",
      "        [0.5254, 0.0379],\n",
      "        [0.2196, 0.4259],\n",
      "        [0.5529, 0.0785],\n",
      "        [0.4348, 0.7698],\n",
      "        [0.4188, 0.8088],\n",
      "        [0.5098, 0.1449],\n",
      "        [0.4726, 0.7293],\n",
      "        [0.1597, 0.2216]], dtype=torch.float64)\n",
      "new obj: tensor([[0.5013, 0.1596],\n",
      "        [0.7050, 0.2478],\n",
      "        [0.1002, 0.0269],\n",
      "        [0.2633, 0.1999],\n",
      "        [0.1034, 0.0225],\n",
      "        [0.4480, 0.6311],\n",
      "        [0.2813, 0.6861],\n",
      "        [0.1540, 0.0429],\n",
      "        [0.6519, 0.4208],\n",
      "        [0.4871, 0.4495]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14731293]\n",
      "Time: 14.34391984785907\n",
      "Iteration: 7\n",
      "new candidats: tensor([[0.0767, 0.2209],\n",
      "        [0.5335, 0.4076],\n",
      "        [0.0930, 0.9878],\n",
      "        [0.2562, 0.0954],\n",
      "        [0.6164, 0.4312],\n",
      "        [0.9852, 0.8343],\n",
      "        [0.4440, 0.7530],\n",
      "        [0.0102, 0.6185],\n",
      "        [0.0676, 0.5371],\n",
      "        [0.2306, 0.4305]], dtype=torch.float64)\n",
      "new obj: tensor([[4.1120e-01, 4.9699e-01],\n",
      "        [8.4186e-02, 2.0027e-02],\n",
      "        [1.8808e-04, 1.2898e-03],\n",
      "        [4.1921e-01, 2.8268e-01],\n",
      "        [4.7909e-02, 6.2170e-03],\n",
      "        [3.6711e-06, 1.1714e-07],\n",
      "        [5.2508e-01, 5.7098e-01],\n",
      "        [3.5694e-02, 5.3613e-02],\n",
      "        [9.7085e-02, 1.2091e-01],\n",
      "        [2.5479e-01, 1.8656e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14731293]\n",
      "Time: 6.581084955018014\n",
      "Iteration: 8\n",
      "new candidats: tensor([[0.8355, 0.4467],\n",
      "        [0.4440, 0.7530],\n",
      "        [0.9228, 0.3797],\n",
      "        [0.1635, 0.8469],\n",
      "        [0.3879, 0.6292],\n",
      "        [0.8761, 0.9229],\n",
      "        [0.2993, 0.7152],\n",
      "        [0.4726, 0.7293],\n",
      "        [0.6708, 0.2368],\n",
      "        [0.4348, 0.7698]], dtype=torch.float64)\n",
      "new obj: tensor([[3.2913e-02, 1.5412e-04],\n",
      "        [5.2508e-01, 5.7098e-01],\n",
      "        [6.5959e-02, 3.7661e-05],\n",
      "        [3.4553e-03, 4.0653e-02],\n",
      "        [3.2280e-01, 1.7564e-01],\n",
      "        [5.1948e-05, 4.1535e-06],\n",
      "        [1.0838e-01, 3.0372e-01],\n",
      "        [6.5188e-01, 4.2080e-01],\n",
      "        [3.1460e-01, 5.4265e-03],\n",
      "        [4.4796e-01, 6.3112e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14731293]\n",
      "Time: 14.778661452932283\n",
      "Iteration: 1\n",
      "new candidats: tensor([[0.1686, 0.1884],\n",
      "        [0.6421, 0.6195],\n",
      "        [0.7142, 0.6705],\n",
      "        [0.9435, 0.2489],\n",
      "        [0.0269, 0.2389],\n",
      "        [0.5175, 0.5190],\n",
      "        [0.2285, 0.1829],\n",
      "        [0.0091, 0.1237],\n",
      "        [0.5217, 0.7398],\n",
      "        [0.2194, 0.9357]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4930, 0.4420],\n",
      "        [0.1893, 0.0083],\n",
      "        [0.0687, 0.0023],\n",
      "        [0.2223, 0.0015],\n",
      "        [0.3374, 0.4794],\n",
      "        [0.1739, 0.0182],\n",
      "        [0.4931, 0.3639],\n",
      "        [0.2948, 0.4439],\n",
      "        [0.6352, 0.2793],\n",
      "        [0.0014, 0.0550]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07599877]\n",
      "Time: 53.31453914614394\n",
      "Iteration: 2\n",
      "new candidats: tensor([[0.7359, 0.8312],\n",
      "        [0.7884, 0.2835],\n",
      "        [0.4843, 0.0891],\n",
      "        [0.7463, 0.6090],\n",
      "        [0.3198, 0.0098],\n",
      "        [0.4843, 0.0891],\n",
      "        [0.1960, 0.0037],\n",
      "        [0.8084, 0.6915],\n",
      "        [0.1763, 0.7061],\n",
      "        [0.6883, 0.9914]], dtype=torch.float64)\n",
      "new obj: tensor([[1.8419e-02, 2.3792e-03],\n",
      "        [4.9669e-01, 1.1130e-03],\n",
      "        [1.5872e-01, 5.0181e-02],\n",
      "        [2.3898e-02, 4.8406e-04],\n",
      "        [2.6583e-01, 1.4578e-01],\n",
      "        [1.5872e-01, 5.0181e-02],\n",
      "        [3.0883e-01, 2.5331e-01],\n",
      "        [6.2462e-03, 1.1965e-04],\n",
      "        [2.3905e-02, 5.4557e-02],\n",
      "        [1.7132e-03, 1.7572e-03]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07599877]\n",
      "Time: 43.27159943105653\n",
      "Iteration: 3\n",
      "new candidats: tensor([[0.7463, 0.6090],\n",
      "        [0.1609, 0.4025],\n",
      "        [0.1785, 0.5206],\n",
      "        [0.1891, 0.9152],\n",
      "        [0.1404, 0.2200],\n",
      "        [0.5057, 0.4256],\n",
      "        [0.2194, 0.9357],\n",
      "        [0.0689, 0.0357],\n",
      "        [0.6235, 0.0898],\n",
      "        [0.4753, 0.7535]], dtype=torch.float64)\n",
      "new obj: tensor([[2.3898e-02, 4.8406e-04],\n",
      "        [2.9383e-01, 2.7008e-01],\n",
      "        [1.3836e-01, 1.2064e-01],\n",
      "        [1.3852e-03, 3.9732e-02],\n",
      "        [4.7590e-01, 4.6761e-01],\n",
      "        [9.9206e-02, 2.5029e-02],\n",
      "        [1.4232e-03, 5.5004e-02],\n",
      "        [2.8783e-01, 3.5677e-01],\n",
      "        [1.2594e-01, 9.3599e-03],\n",
      "        [5.9272e-01, 4.7457e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.09779895]\n",
      "Time: 48.5786460689269\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration: 4\n",
      "new candidats: tensor([[0.2250, 0.2242],\n",
      "        [0.4285, 0.7933],\n",
      "        [0.1785, 0.5206],\n",
      "        [0.1730, 0.9783],\n",
      "        [0.5031, 0.4008],\n",
      "        [0.4452, 0.7529],\n",
      "        [0.0608, 0.9504],\n",
      "        [0.9718, 0.6000],\n",
      "        [0.3814, 0.1209],\n",
      "        [0.5692, 0.4752]], dtype=torch.float64)\n",
      "new obj: tensor([[4.9248e-01, 3.6754e-01],\n",
      "        [3.5423e-01, 6.7178e-01],\n",
      "        [1.3836e-01, 1.2064e-01],\n",
      "        [3.2441e-04, 1.1088e-02],\n",
      "        [1.0487e-01, 2.9091e-02],\n",
      "        [5.2878e-01, 5.6767e-01],\n",
      "        [3.4631e-04, 1.1563e-03],\n",
      "        [9.9389e-05, 2.6117e-06],\n",
      "        [3.0649e-01, 1.3755e-01],\n",
      "        [8.0465e-02, 9.4653e-03]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13344906]\n",
      "Time: 46.97191632911563\n",
      "Iteration: 5\n",
      "new candidats: tensor([[0.0645, 0.6572],\n",
      "        [0.6123, 0.3531],\n",
      "        [0.4225, 0.7546],\n",
      "        [0.0051, 0.8302],\n",
      "        [0.5300, 0.2743],\n",
      "        [0.1647, 0.2423],\n",
      "        [0.5983, 0.1226],\n",
      "        [0.8687, 0.2918],\n",
      "        [0.9697, 0.3962],\n",
      "        [0.4656, 0.7109]], dtype=torch.float64)\n",
      "new obj: tensor([[2.9197e-02, 3.7560e-02],\n",
      "        [8.2695e-02, 9.4439e-03],\n",
      "        [4.5244e-01, 6.1792e-01],\n",
      "        [2.1720e-03, 3.5855e-03],\n",
      "        [1.3361e-01, 3.3152e-02],\n",
      "        [4.8136e-01, 4.3713e-01],\n",
      "        [1.3172e-01, 1.4162e-02],\n",
      "        [3.6449e-01, 5.7164e-04],\n",
      "        [2.4382e-02, 1.2456e-05],\n",
      "        [6.6378e-01, 3.8227e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14736401]\n",
      "Time: 44.03315753303468\n",
      "Iteration: 6\n",
      "new candidats: tensor([[0.4480, 0.3152],\n",
      "        [0.1129, 0.2761],\n",
      "        [0.5494, 0.0016],\n",
      "        [0.4452, 0.7529],\n",
      "        [0.1921, 0.3685],\n",
      "        [0.4285, 0.7933],\n",
      "        [0.1909, 0.9943],\n",
      "        [0.4909, 0.4792],\n",
      "        [0.6293, 0.4465],\n",
      "        [0.4552, 0.7200]], dtype=torch.float64)\n",
      "new obj: tensor([[1.9747e-01, 7.1009e-02],\n",
      "        [4.2307e-01, 4.5450e-01],\n",
      "        [7.0698e-02, 1.7289e-02],\n",
      "        [5.2878e-01, 5.6767e-01],\n",
      "        [3.5037e-01, 2.9099e-01],\n",
      "        [3.5423e-01, 6.7178e-01],\n",
      "        [2.6508e-04, 1.2055e-02],\n",
      "        [1.2650e-01, 2.3301e-02],\n",
      "        [4.3403e-02, 4.7877e-03],\n",
      "        [6.2800e-01, 4.3937e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14937874]\n",
      "Time: 17.191351521993056\n",
      "Iteration: 7\n",
      "new candidats: tensor([[0.5277, 0.8212],\n",
      "        [0.3715, 0.4159],\n",
      "        [0.8687, 0.2918],\n",
      "        [0.1453, 0.2974],\n",
      "        [0.8144, 0.7973],\n",
      "        [0.0750, 0.7763],\n",
      "        [0.1416, 0.1683],\n",
      "        [0.9268, 0.0045],\n",
      "        [0.0656, 0.8483],\n",
      "        [0.2299, 0.5672]], dtype=torch.float64)\n",
      "new obj: tensor([[3.2416e-01, 3.0321e-01],\n",
      "        [1.9873e-01, 9.0043e-02],\n",
      "        [3.6449e-01, 5.7164e-04],\n",
      "        [4.2781e-01, 4.1371e-01],\n",
      "        [3.1605e-03, 1.3608e-04],\n",
      "        [6.5376e-03, 1.1333e-02],\n",
      "        [4.7315e-01, 4.6310e-01],\n",
      "        [4.6814e-02, 3.4825e-02],\n",
      "        [2.1042e-03, 4.9349e-03],\n",
      "        [9.9208e-02, 7.8286e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14937874]\n",
      "Time: 47.45527414791286\n",
      "Iteration: 8\n",
      "new candidats: tensor([[0.7106, 0.8447],\n",
      "        [0.7268, 0.0816],\n",
      "        [0.6861, 0.7377],\n",
      "        [0.4893, 0.6492],\n",
      "        [0.4693, 0.1512],\n",
      "        [0.7620, 0.3129],\n",
      "        [0.5912, 0.1746],\n",
      "        [0.4656, 0.7109],\n",
      "        [0.9757, 0.1505],\n",
      "        [0.0292, 0.1446]], dtype=torch.float64)\n",
      "new obj: tensor([[0.0268, 0.0051],\n",
      "        [0.2788, 0.0334],\n",
      "        [0.1160, 0.0097],\n",
      "        [0.6258, 0.1552],\n",
      "        [0.1986, 0.0661],\n",
      "        [0.3527, 0.0011],\n",
      "        [0.1498, 0.0166],\n",
      "        [0.6638, 0.3823],\n",
      "        [0.1326, 0.0178],\n",
      "        [0.3341, 0.4713]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14937874]\n",
      "Time: 12.397558817872778\n",
      "Iteration: 1\n",
      "new candidats: tensor([[0.5985, 0.0317],\n",
      "        [0.6867, 0.0209],\n",
      "        [0.6067, 0.3709],\n",
      "        [0.4473, 0.0583],\n",
      "        [0.9668, 0.4800],\n",
      "        [0.0210, 0.9508],\n",
      "        [0.4581, 0.6744],\n",
      "        [0.0041, 0.3143],\n",
      "        [0.0013, 0.4505],\n",
      "        [0.0454, 0.1777]], dtype=torch.float64)\n",
      "new obj: tensor([[7.0531e-02, 1.0689e-02],\n",
      "        [9.1432e-02, 3.8522e-03],\n",
      "        [7.0732e-02, 9.4854e-03],\n",
      "        [1.8165e-01, 6.5647e-02],\n",
      "        [3.5769e-03, 8.0763e-06],\n",
      "        [2.9209e-04, 5.9323e-04],\n",
      "        [6.3365e-01, 2.7331e-01],\n",
      "        [2.6287e-01, 4.0225e-01],\n",
      "        [1.3927e-01, 2.1507e-01],\n",
      "        [3.6854e-01, 4.9315e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.05049839]\n",
      "Time: 23.843375934986398\n",
      "Iteration: 2\n",
      "new candidats: tensor([[0.4743, 0.6666],\n",
      "        [0.0216, 0.1120],\n",
      "        [0.8526, 0.0759],\n",
      "        [0.2973, 0.8367],\n",
      "        [0.4613, 0.7309],\n",
      "        [0.4113, 0.4226],\n",
      "        [0.8928, 0.9398],\n",
      "        [0.1155, 0.4034],\n",
      "        [0.0969, 0.1630],\n",
      "        [0.8290, 0.1214]], dtype=torch.float64)\n",
      "new obj: tensor([[6.5335e-01, 2.2260e-01],\n",
      "        [3.0492e-01, 4.4078e-01],\n",
      "        [2.8415e-01, 6.2249e-01],\n",
      "        [3.8026e-02, 3.8773e-01],\n",
      "        [6.2558e-01, 4.5897e-01],\n",
      "        [1.6416e-01, 6.3327e-02],\n",
      "        [1.8912e-05, 1.5133e-06],\n",
      "        [2.7271e-01, 2.9055e-01],\n",
      "        [4.3033e-01, 4.8707e-01],\n",
      "        [4.9636e-01, 5.8470e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.12855855]\n",
      "Time: 78.78459742688574\n",
      "Iteration: 3\n",
      "new candidats: tensor([[0.9960, 0.8144],\n",
      "        [0.0210, 0.9508],\n",
      "        [0.2702, 0.0674],\n",
      "        [0.1612, 0.0018],\n",
      "        [0.7676, 0.6722],\n",
      "        [0.8329, 0.1505],\n",
      "        [0.6585, 0.9211],\n",
      "        [0.4552, 0.8308],\n",
      "        [0.4475, 0.7611],\n",
      "        [0.4785, 0.7096]], dtype=torch.float64)\n",
      "new obj: tensor([[3.2766e-06, 1.1220e-07],\n",
      "        [2.9209e-04, 5.9323e-04],\n",
      "        [3.7729e-01, 2.4311e-01],\n",
      "        [3.0036e-01, 2.7585e-01],\n",
      "        [1.9333e-02, 4.3029e-04],\n",
      "        [5.8980e-01, 3.9708e-01],\n",
      "        [1.7357e-02, 1.1911e-02],\n",
      "        [2.7072e-01, 5.7379e-01],\n",
      "        [5.1050e-01, 5.8145e-01],\n",
      "        [6.8823e-01, 3.4423e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.1375537]\n",
      "Time: 91.84426871896721\n",
      "Iteration: 4\n",
      "new candidats: tensor([[0.0614, 0.7655],\n",
      "        [0.6368, 0.5309],\n",
      "        [0.6413, 0.4139],\n",
      "        [0.9767, 0.3392],\n",
      "        [0.0102, 0.8891],\n",
      "        [0.4284, 0.7729],\n",
      "        [0.4475, 0.7611],\n",
      "        [0.7097, 0.3665],\n",
      "        [0.1794, 0.5834],\n",
      "        [0.4509, 0.0221]], dtype=torch.float64)\n",
      "new obj: tensor([[7.2615e-03, 1.1314e-02],\n",
      "        [7.8255e-02, 3.4299e-03],\n",
      "        [4.9207e-02, 4.7925e-03],\n",
      "        [5.5914e-02, 1.3803e-05],\n",
      "        [8.4328e-04, 1.5001e-03],\n",
      "        [4.1952e-01, 6.4981e-01],\n",
      "        [5.1050e-01, 5.8145e-01],\n",
      "        [1.3054e-01, 2.1238e-03],\n",
      "        [8.1270e-02, 7.4436e-02],\n",
      "        [1.5360e-01, 5.4904e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14774237]\n",
      "Time: 35.98170088301413\n",
      "Iteration: 5\n",
      "new candidats: tensor([[0.4284, 0.7729],\n",
      "        [0.7664, 0.3038],\n",
      "        [0.9676, 0.0416],\n",
      "        [0.9659, 0.0735],\n",
      "        [0.0176, 0.4888],\n",
      "        [0.4613, 0.7309],\n",
      "        [0.2073, 0.4402],\n",
      "        [0.9474, 0.0970],\n",
      "        [0.8531, 0.7718],\n",
      "        [0.0386, 0.0243]], dtype=torch.float64)\n",
      "new obj: tensor([[4.1952e-01, 6.4981e-01],\n",
      "        [3.9377e-01, 1.0611e-03],\n",
      "        [4.9228e-02, 2.2262e-02],\n",
      "        [7.9734e-02, 4.1474e-02],\n",
      "        [1.1627e-01, 1.7028e-01],\n",
      "        [6.2558e-01, 4.5897e-01],\n",
      "        [2.4324e-01, 1.9223e-01],\n",
      "        [1.3930e-01, 1.0465e-01],\n",
      "        [1.1032e-03, 2.7417e-05],\n",
      "        [2.4546e-01, 3.3574e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14774237]\n",
      "Time: 51.58774877618998\n",
      "Iteration: 6\n",
      "new candidats: tensor([[0.0242, 0.3328],\n",
      "        [0.6467, 0.7008],\n",
      "        [0.4839, 0.7272],\n",
      "        [0.6867, 0.0209],\n",
      "        [0.8290, 0.1214],\n",
      "        [0.2295, 0.2262],\n",
      "        [0.9895, 0.0194],\n",
      "        [0.4403, 0.7334],\n",
      "        [0.1968, 0.9267],\n",
      "        [0.8259, 0.0897]], dtype=torch.float64)\n",
      "new obj: tensor([[0.2725, 0.3907],\n",
      "        [0.2406, 0.0208],\n",
      "        [0.6715, 0.3796],\n",
      "        [0.0914, 0.0039],\n",
      "        [0.4964, 0.5847],\n",
      "        [0.4904, 0.3607],\n",
      "        [0.0229, 0.0039],\n",
      "        [0.5608, 0.5196],\n",
      "        [0.0012, 0.0404],\n",
      "        [0.3718, 0.6108]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15241844]\n",
      "Time: 57.71573729882948\n",
      "Iteration: 7\n",
      "new candidats: tensor([[0.0283, 0.3218],\n",
      "        [0.3864, 0.0917],\n",
      "        [0.4284, 0.7729],\n",
      "        [0.4875, 0.5427],\n",
      "        [0.8031, 0.5122],\n",
      "        [0.5290, 0.3521],\n",
      "        [0.6282, 0.4978],\n",
      "        [0.4284, 0.7729],\n",
      "        [0.1665, 0.2207],\n",
      "        [0.8727, 0.7451]], dtype=torch.float64)\n",
      "new obj: tensor([[2.8728e-01, 4.0639e-01],\n",
      "        [2.7975e-01, 1.2354e-01],\n",
      "        [4.1952e-01, 6.4981e-01],\n",
      "        [2.4243e-01, 3.0445e-02],\n",
      "        [8.1265e-03, 1.8187e-04],\n",
      "        [1.0396e-01, 2.6910e-02],\n",
      "        [5.8430e-02, 3.8978e-03],\n",
      "        [4.1952e-01, 6.4981e-01],\n",
      "        [4.9040e-01, 4.4268e-01],\n",
      "        [6.5231e-04, 1.2348e-05]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15241844]\n",
      "Time: 21.160668171942234\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration: 8\n",
      "new candidats: tensor([[0.8365, 0.5227],\n",
      "        [0.4240, 0.3559],\n",
      "        [0.1014, 0.3211],\n",
      "        [0.8591, 0.5940],\n",
      "        [0.9584, 0.8991],\n",
      "        [0.3459, 0.4228],\n",
      "        [0.4785, 0.7096],\n",
      "        [0.2106, 0.9724],\n",
      "        [0.1504, 0.3235],\n",
      "        [0.4284, 0.7729]], dtype=torch.float64)\n",
      "new obj: tensor([[4.9578e-03, 8.9093e-05],\n",
      "        [1.9871e-01, 7.7104e-02],\n",
      "        [3.6861e-01, 4.1109e-01],\n",
      "        [1.1986e-03, 3.2170e-05],\n",
      "        [3.4761e-06, 1.3025e-07],\n",
      "        [2.1057e-01, 1.0428e-01],\n",
      "        [6.8823e-01, 3.4423e-01],\n",
      "        [5.4833e-04, 2.6572e-02],\n",
      "        [4.0073e-01, 3.8116e-01],\n",
      "        [4.1952e-01, 6.4981e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15241844]\n",
      "Time: 9.301617003045976\n",
      "Iteration: 1\n",
      "new candidats: tensor([[0.1664, 0.1219],\n",
      "        [0.0756, 0.2457],\n",
      "        [0.9213, 0.6879],\n",
      "        [0.6129, 0.4583],\n",
      "        [0.2913, 0.1973],\n",
      "        [0.8365, 0.3419],\n",
      "        [0.8907, 0.7831],\n",
      "        [0.3084, 0.8874],\n",
      "        [0.0866, 0.0293],\n",
      "        [0.1583, 0.2431]], dtype=torch.float64)\n",
      "new obj: tensor([[4.5683e-01, 4.1256e-01],\n",
      "        [4.0144e-01, 4.8695e-01],\n",
      "        [1.3749e-04, 3.4337e-06],\n",
      "        [5.0047e-02, 5.6673e-03],\n",
      "        [4.5048e-01, 2.7106e-01],\n",
      "        [2.4165e-01, 2.5699e-04],\n",
      "        [2.5811e-04, 5.6421e-06],\n",
      "        [2.0492e-02, 3.1494e-01],\n",
      "        [2.9583e-01, 3.4622e-01],\n",
      "        [4.7803e-01, 4.4313e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.06270567]\n",
      "Time: 33.56760631687939\n",
      "Iteration: 2\n",
      "new candidats: tensor([[0.6809, 0.6487],\n",
      "        [0.6809, 0.6487],\n",
      "        [0.4086, 0.7051],\n",
      "        [0.8451, 0.5328],\n",
      "        [0.3931, 0.7157],\n",
      "        [0.4977, 0.4493],\n",
      "        [0.4539, 0.7531],\n",
      "        [0.6500, 0.0657],\n",
      "        [0.8932, 0.5791],\n",
      "        [0.4069, 0.9159]], dtype=torch.float64)\n",
      "new obj: tensor([[1.2185e-01, 4.6980e-03],\n",
      "        [1.2185e-01, 4.6980e-03],\n",
      "        [4.7225e-01, 4.4938e-01],\n",
      "        [3.6302e-03, 6.9603e-05],\n",
      "        [4.0181e-01, 4.9452e-01],\n",
      "        [1.0651e-01, 2.4299e-02],\n",
      "        [5.5159e-01, 5.4400e-01],\n",
      "        [1.2391e-01, 6.1420e-03],\n",
      "        [6.9600e-04, 1.7698e-05],\n",
      "        [4.4647e-02, 3.5706e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.10261506]\n",
      "Time: 36.1253816219978\n",
      "Iteration: 3\n",
      "new candidats: tensor([[0.5416, 0.3131],\n",
      "        [0.4929, 0.7292],\n",
      "        [0.3514, 0.5085],\n",
      "        [0.3479, 0.6042],\n",
      "        [0.1889, 0.9684],\n",
      "        [0.5698, 0.2397],\n",
      "        [0.0166, 0.4802],\n",
      "        [0.9041, 0.0394],\n",
      "        [0.1810, 0.1205],\n",
      "        [0.1400, 0.0339]], dtype=torch.float64)\n",
      "new obj: tensor([[1.1254e-01, 2.6428e-02],\n",
      "        [6.7418e-01, 3.5566e-01],\n",
      "        [1.5135e-01, 6.5444e-02],\n",
      "        [1.8853e-01, 1.1457e-01],\n",
      "        [4.6240e-04, 1.8532e-02],\n",
      "        [1.3446e-01, 2.1589e-02],\n",
      "        [1.2305e-01, 1.8082e-01],\n",
      "        [1.1295e-01, 1.8731e-01],\n",
      "        [4.5998e-01, 3.9605e-01],\n",
      "        [3.3863e-01, 3.3319e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.11911069]\n",
      "Time: 49.705816749017686\n",
      "Iteration: 4\n",
      "new candidats: tensor([[0.4029, 0.1545],\n",
      "        [0.9827, 0.0438],\n",
      "        [0.4699, 0.7486],\n",
      "        [0.2344, 0.2065],\n",
      "        [0.0259, 0.2498],\n",
      "        [0.7093, 0.1883],\n",
      "        [0.4699, 0.7486],\n",
      "        [0.3625, 0.3228],\n",
      "        [0.4271, 0.7720],\n",
      "        [0.9619, 0.2892]], dtype=torch.float64)\n",
      "new obj: tensor([[2.9144e-01, 1.2190e-01],\n",
      "        [3.9145e-02, 1.1017e-02],\n",
      "        [5.9918e-01, 4.8197e-01],\n",
      "        [4.9241e-01, 3.5653e-01],\n",
      "        [3.3185e-01, 4.7309e-01],\n",
      "        [4.8036e-01, 5.8260e-03],\n",
      "        [5.9918e-01, 4.8197e-01],\n",
      "        [2.9792e-01, 1.4212e-01],\n",
      "        [4.1879e-01, 6.5036e-01],\n",
      "        [1.2710e-01, 6.6275e-05]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14479706]\n",
      "Time: 66.96211980399676\n",
      "Iteration: 5\n",
      "new candidats: tensor([[0.4568, 0.1387],\n",
      "        [0.4929, 0.7292],\n",
      "        [0.7559, 0.4735],\n",
      "        [0.0076, 0.8888],\n",
      "        [0.7775, 0.4138],\n",
      "        [0.9295, 0.8007],\n",
      "        [0.0431, 0.7210],\n",
      "        [0.5981, 0.4863],\n",
      "        [0.4131, 0.7823],\n",
      "        [0.0847, 0.4428]], dtype=torch.float64)\n",
      "new obj: tensor([[2.1084e-01, 7.3526e-02],\n",
      "        [6.7418e-01, 3.5566e-01],\n",
      "        [2.1257e-02, 5.5412e-04],\n",
      "        [8.3647e-04, 1.4784e-03],\n",
      "        [7.3978e-02, 5.4178e-04],\n",
      "        [4.8678e-05, 1.1075e-06],\n",
      "        [1.2371e-02, 1.7528e-02],\n",
      "        [7.0364e-02, 6.2100e-03],\n",
      "        [3.4611e-01, 6.8488e-01],\n",
      "        [2.0266e-01, 2.3867e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14867357]\n",
      "Time: 30.861417884007096\n",
      "Iteration: 6\n",
      "new candidats: tensor([[0.7234, 0.8380],\n",
      "        [0.0293, 0.1611],\n",
      "        [0.7822, 0.6598],\n",
      "        [0.3318, 0.2682],\n",
      "        [0.9295, 0.8007],\n",
      "        [0.1133, 0.9521],\n",
      "        [0.9153, 0.1110],\n",
      "        [0.5827, 0.2853],\n",
      "        [0.7563, 0.2589],\n",
      "        [0.4464, 0.7612]], dtype=torch.float64)\n",
      "new obj: tensor([[2.2347e-02, 3.4977e-03],\n",
      "        [3.4081e-01, 4.8057e-01],\n",
      "        [1.2590e-02, 2.3941e-04],\n",
      "        [3.7968e-01, 2.0025e-01],\n",
      "        [4.8678e-05, 1.1075e-06],\n",
      "        [4.0297e-04, 4.0240e-03],\n",
      "        [2.4315e-01, 2.9166e-01],\n",
      "        [1.1918e-01, 1.7079e-02],\n",
      "        [5.4479e-01, 2.1014e-03],\n",
      "        [5.0730e-01, 5.8470e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15227614]\n",
      "Time: 7.365226567955688\n",
      "Iteration: 7\n",
      "new candidats: tensor([[0.2072, 0.4884],\n",
      "        [0.6082, 0.5435],\n",
      "        [0.1568, 0.7959],\n",
      "        [0.4699, 0.7486],\n",
      "        [0.1723, 0.4409],\n",
      "        [0.4505, 0.0474],\n",
      "        [0.2435, 0.4837],\n",
      "        [0.0756, 0.2457],\n",
      "        [0.4568, 0.1387],\n",
      "        [0.2614, 0.9669]], dtype=torch.float64)\n",
      "new obj: tensor([[0.1777, 0.1406],\n",
      "        [0.1292, 0.0061],\n",
      "        [0.0070, 0.0417],\n",
      "        [0.5992, 0.4820],\n",
      "        [0.2399, 0.2125],\n",
      "        [0.1710, 0.0612],\n",
      "        [0.1811, 0.1269],\n",
      "        [0.4014, 0.4870],\n",
      "        [0.2108, 0.0735],\n",
      "        [0.0015, 0.0668]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15227614]\n",
      "Time: 6.619058896088973\n",
      "Iteration: 8\n",
      "new candidats: tensor([[0.6933, 0.4637],\n",
      "        [0.6210, 0.3759],\n",
      "        [0.9162, 0.4287],\n",
      "        [0.4699, 0.7486],\n",
      "        [0.5745, 0.6235],\n",
      "        [0.2824, 0.6089],\n",
      "        [0.7465, 0.9063],\n",
      "        [0.8346, 0.4539],\n",
      "        [0.1489, 0.0283],\n",
      "        [0.8005, 0.7260]], dtype=torch.float64)\n",
      "new obj: tensor([[2.8882e-02, 1.6646e-03],\n",
      "        [6.8860e-02, 7.6463e-03],\n",
      "        [2.6522e-02, 3.3733e-05],\n",
      "        [5.9918e-01, 4.8197e-01],\n",
      "        [4.0500e-01, 3.4368e-02],\n",
      "        [1.0011e-01, 9.1621e-02],\n",
      "        [4.0134e-03, 9.8465e-04],\n",
      "        [2.7873e-02, 1.4996e-04],\n",
      "        [3.3470e-01, 3.1993e-01],\n",
      "        [7.5774e-03, 1.9489e-04]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15227614]\n",
      "Time: 10.96177750499919\n",
      "Iteration: 1\n",
      "new candidats: tensor([[0.6268, 0.1208],\n",
      "        [0.9773, 0.2117],\n",
      "        [0.0983, 0.3062],\n",
      "        [0.3633, 0.3383],\n",
      "        [0.1741, 0.1763],\n",
      "        [0.1139, 0.1814],\n",
      "        [0.7567, 0.1140],\n",
      "        [0.2593, 0.9596],\n",
      "        [0.2305, 0.0550],\n",
      "        [0.9757, 0.2937]], dtype=torch.float64)\n",
      "new obj: tensor([[1.6154e-01, 9.6224e-03],\n",
      "        [1.4474e-01, 2.2773e-03],\n",
      "        [3.8158e-01, 4.2995e-01],\n",
      "        [2.8254e-01, 1.3437e-01],\n",
      "        [4.9235e-01, 4.3356e-01],\n",
      "        [4.5382e-01, 4.8598e-01],\n",
      "        [4.4975e-01, 1.1933e-01],\n",
      "        [1.6810e-03, 7.2994e-02],\n",
      "        [3.8003e-01, 2.7865e-01],\n",
      "        [9.6580e-02, 3.2067e-05]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.06660314]\n",
      "Time: 28.522017054026946\n",
      "Iteration: 2\n",
      "new candidats: tensor([[0.5206, 0.2837],\n",
      "        [0.8287, 0.8426],\n",
      "        [0.6364, 0.4471],\n",
      "        [0.5131, 0.7474],\n",
      "        [0.1594, 0.4947],\n",
      "        [0.0369, 0.0096],\n",
      "        [0.0067, 0.2169],\n",
      "        [0.4788, 0.8713],\n",
      "        [0.7983, 0.5255],\n",
      "        [0.4966, 0.9452]], dtype=torch.float64)\n",
      "new obj: tensor([[1.3681e-01, 3.6199e-02],\n",
      "        [1.1608e-03, 6.7406e-05],\n",
      "        [4.1514e-02, 4.3124e-03],\n",
      "        [6.2386e-01, 3.2247e-01],\n",
      "        [1.6573e-01, 1.5320e-01],\n",
      "        [2.2786e-01, 3.1346e-01],\n",
      "        [3.1237e-01, 4.7391e-01],\n",
      "        [1.5854e-01, 3.9839e-01],\n",
      "        [6.8075e-03, 1.8141e-04],\n",
      "        [3.4789e-02, 1.5310e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07983486]\n",
      "Time: 47.73891082103364\n",
      "Iteration: 3\n",
      "new candidats: tensor([[0.4633, 0.7703],\n",
      "        [0.9100, 0.9285],\n",
      "        [0.9075, 0.2389],\n",
      "        [0.1122, 0.9479],\n",
      "        [0.5131, 0.7474],\n",
      "        [0.3818, 0.2669],\n",
      "        [0.7701, 0.4290],\n",
      "        [0.0998, 0.1757],\n",
      "        [0.0665, 0.1750],\n",
      "        [0.4976, 0.7488]], dtype=torch.float64)\n",
      "new obj: tensor([[5.1472e-01, 5.4948e-01],\n",
      "        [1.2735e-05, 7.8793e-07],\n",
      "        [3.6517e-01, 7.7200e-03],\n",
      "        [4.3503e-04, 4.1771e-03],\n",
      "        [6.2386e-01, 3.2247e-01],\n",
      "        [3.1286e-01, 1.4021e-01],\n",
      "        [5.3549e-02, 5.6755e-04],\n",
      "        [4.3783e-01, 4.9083e-01],\n",
      "        [3.9700e-01, 4.9605e-01],\n",
      "        [6.2514e-01, 3.8243e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.11006461]\n",
      "Time: 47.01263679983094\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration: 4\n",
      "new candidats: tensor([[0.4279, 0.7649],\n",
      "        [0.1069, 0.1397],\n",
      "        [0.1183, 0.0766],\n",
      "        [0.2094, 0.1248],\n",
      "        [0.0459, 0.5338],\n",
      "        [0.1484, 0.2404],\n",
      "        [0.4915, 0.7204],\n",
      "        [0.6112, 0.5498],\n",
      "        [0.0026, 0.6156],\n",
      "        [0.4692, 0.7453]], dtype=torch.float64)\n",
      "new obj: tensor([[0.4419, 0.6351],\n",
      "        [0.4287, 0.4697],\n",
      "        [0.3802, 0.4014],\n",
      "        [0.4653, 0.3654],\n",
      "        [0.0923, 0.1233],\n",
      "        [0.4738, 0.4537],\n",
      "        [0.6889, 0.3373],\n",
      "        [0.1354, 0.0061],\n",
      "        [0.0355, 0.0546],\n",
      "        [0.6075, 0.4760]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14396577]\n",
      "Time: 39.54292612802237\n",
      "Iteration: 5\n",
      "new candidats: tensor([[0.4118, 0.7791],\n",
      "        [0.1484, 0.2404],\n",
      "        [0.1618, 0.6077],\n",
      "        [0.4394, 0.7617],\n",
      "        [0.0331, 0.7737],\n",
      "        [0.3477, 0.3209],\n",
      "        [0.0126, 0.2247],\n",
      "        [0.0113, 0.9566],\n",
      "        [0.7499, 0.5030],\n",
      "        [0.4118, 0.7791]], dtype=torch.float64)\n",
      "new obj: tensor([[3.5155e-01, 6.8179e-01],\n",
      "        [4.7385e-01, 4.5373e-01],\n",
      "        [6.2962e-02, 6.2792e-02],\n",
      "        [4.8647e-01, 6.0357e-01],\n",
      "        [5.7755e-03, 8.8367e-03],\n",
      "        [3.1731e-01, 1.5888e-01],\n",
      "        [3.1995e-01, 4.7620e-01],\n",
      "        [2.5045e-04, 4.8178e-04],\n",
      "        [1.4324e-02, 5.0994e-04],\n",
      "        [3.5155e-01, 6.8179e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15187881]\n",
      "Time: 19.96236329502426\n",
      "Iteration: 6\n",
      "new candidats: tensor([[0.2227, 0.8875],\n",
      "        [0.7030, 0.8600],\n",
      "        [0.0631, 0.6480],\n",
      "        [0.4692, 0.7453],\n",
      "        [0.4870, 0.7367],\n",
      "        [0.8027, 0.2271],\n",
      "        [0.4504, 0.1292],\n",
      "        [0.8120, 0.6276],\n",
      "        [0.3252, 0.7269],\n",
      "        [0.7762, 0.3500]], dtype=torch.float64)\n",
      "new obj: tensor([[3.9286e-03, 1.0009e-01],\n",
      "        [2.4881e-02, 5.9501e-03],\n",
      "        [3.2242e-02, 4.1428e-02],\n",
      "        [6.0750e-01, 4.7596e-01],\n",
      "        [6.5382e-01, 3.9381e-01],\n",
      "        [6.7981e-01, 1.8276e-02],\n",
      "        [2.1573e-01, 7.6972e-02],\n",
      "        [4.6836e-03, 8.4726e-05],\n",
      "        [1.5934e-01, 4.1190e-01],\n",
      "        [2.2702e-01, 7.4080e-04]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15369884]\n",
      "Time: 8.025389541871846\n",
      "Iteration: 7\n",
      "new candidats: tensor([[0.4943, 0.1388],\n",
      "        [0.2883, 0.0845],\n",
      "        [0.9196, 0.6775],\n",
      "        [0.9830, 0.3284],\n",
      "        [0.4203, 0.5551],\n",
      "        [0.6919, 0.9481],\n",
      "        [0.4692, 0.7453],\n",
      "        [0.9075, 0.2389],\n",
      "        [0.5638, 0.1198],\n",
      "        [0.2987, 0.9731]], dtype=torch.float64)\n",
      "new obj: tensor([[1.6696e-01, 5.0241e-02],\n",
      "        [3.8397e-01, 2.3333e-01],\n",
      "        [1.5082e-04, 3.9368e-06],\n",
      "        [5.7701e-02, 1.2731e-05],\n",
      "        [2.3462e-01, 5.6470e-02],\n",
      "        [5.1378e-03, 3.3068e-03],\n",
      "        [6.0750e-01, 4.7596e-01],\n",
      "        [3.6517e-01, 7.7200e-03],\n",
      "        [1.1939e-01, 2.1882e-02],\n",
      "        [2.4694e-03, 9.3844e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15369884]\n",
      "Time: 7.168327922932804\n",
      "Iteration: 8\n",
      "new candidats: tensor([[0.0430, 0.0854],\n",
      "        [0.4692, 0.7453],\n",
      "        [0.2628, 0.7136],\n",
      "        [0.7113, 0.9362],\n",
      "        [0.4242, 0.6634],\n",
      "        [0.8738, 0.3604],\n",
      "        [0.0466, 0.0978],\n",
      "        [0.2398, 0.9940],\n",
      "        [0.7603, 0.1872],\n",
      "        [0.8080, 0.3980]], dtype=torch.float64)\n",
      "new obj: tensor([[3.1173e-01, 4.2040e-01],\n",
      "        [6.0750e-01, 4.7596e-01],\n",
      "        [5.9231e-02, 1.9972e-01],\n",
      "        [4.6371e-03, 2.1804e-03],\n",
      "        [5.0939e-01, 2.7440e-01],\n",
      "        [1.4859e-01, 1.1357e-04],\n",
      "        [3.2699e-01, 4.3579e-01],\n",
      "        [5.0052e-04, 2.9698e-02],\n",
      "        [6.5160e-01, 3.1913e-02],\n",
      "        [1.0131e-01, 3.3832e-04]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15369884]\n",
      "Time: 8.216084870975465\n",
      "Iteration: 1\n",
      "new candidats: tensor([[0.0305, 0.0284],\n",
      "        [0.8664, 0.0161],\n",
      "        [0.2927, 0.9978],\n",
      "        [0.5316, 0.9896],\n",
      "        [0.5239, 0.2136],\n",
      "        [0.0391, 0.1874],\n",
      "        [0.1380, 0.1976],\n",
      "        [0.9335, 0.4935],\n",
      "        [0.1425, 0.0293],\n",
      "        [0.0011, 0.1229]], dtype=torch.float64)\n",
      "new obj: tensor([[2.4162e-01, 3.3937e-01],\n",
      "        [1.0489e-01, 1.6270e-01],\n",
      "        [1.1257e-03, 5.5739e-02],\n",
      "        [1.0108e-02, 4.8806e-02],\n",
      "        [1.4977e-01, 3.7989e-02],\n",
      "        [3.6107e-01, 4.9309e-01],\n",
      "        [4.7649e-01, 4.7191e-01],\n",
      "        [4.0813e-03, 1.5257e-05],\n",
      "        [3.3336e-01, 3.2529e-01],\n",
      "        [2.8303e-01, 4.3739e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.06356437]\n",
      "Time: 33.5071780749131\n",
      "Iteration: 2\n",
      "new candidats: tensor([[0.1855, 0.3262],\n",
      "        [0.5323, 0.0022],\n",
      "        [0.4010, 0.9607],\n",
      "        [0.2280, 0.2797],\n",
      "        [0.7329, 0.0537],\n",
      "        [0.9458, 0.7346],\n",
      "        [0.5349, 0.2651],\n",
      "        [0.1841, 0.2553],\n",
      "        [0.1855, 0.3262],\n",
      "        [0.2305, 0.2090]], dtype=torch.float64)\n",
      "new obj: tensor([[4.0872e-01, 3.4689e-01],\n",
      "        [7.9852e-02, 2.1195e-02],\n",
      "        [1.4540e-02, 1.9244e-01],\n",
      "        [4.5730e-01, 3.3796e-01],\n",
      "        [2.0267e-01, 3.0962e-02],\n",
      "        [4.5436e-05, 1.1546e-06],\n",
      "        [1.3362e-01, 3.1818e-02],\n",
      "        [4.7974e-01, 4.0901e-01],\n",
      "        [4.0872e-01, 3.4689e-01],\n",
      "        [4.9373e-01, 3.6200e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.06614567]\n",
      "Time: 30.2721791327931\n",
      "Iteration: 3\n",
      "new candidats: tensor([[0.8115, 0.7753],\n",
      "        [0.1851, 0.1997],\n",
      "        [0.0821, 0.2000],\n",
      "        [0.2506, 0.8349],\n",
      "        [0.7514, 0.8195],\n",
      "        [0.0679, 0.6256],\n",
      "        [0.2566, 0.1318],\n",
      "        [0.1855, 0.3262],\n",
      "        [0.8668, 0.6495],\n",
      "        [0.2106, 0.1825]], dtype=torch.float64)\n",
      "new obj: tensor([[4.1929e-03, 1.5096e-04],\n",
      "        [4.9862e-01, 4.2367e-01],\n",
      "        [4.2021e-01, 4.9909e-01],\n",
      "        [1.5722e-02, 2.1799e-01],\n",
      "        [1.4639e-02, 1.4435e-03],\n",
      "        [4.1802e-02, 5.2553e-02],\n",
      "        [4.5327e-01, 3.0529e-01],\n",
      "        [4.0872e-01, 3.4689e-01],\n",
      "        [9.1602e-04, 1.8494e-05],\n",
      "        [4.9738e-01, 3.8899e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.07041803]\n",
      "Time: 44.14981316914782\n",
      "Iteration: 4\n",
      "new candidats: tensor([[0.1591, 0.0426],\n",
      "        [0.0075, 0.1448],\n",
      "        [0.5486, 0.6464],\n",
      "        [0.3309, 0.2973],\n",
      "        [0.8190, 0.6822],\n",
      "        [0.1311, 0.2175],\n",
      "        [0.6771, 0.5761],\n",
      "        [0.4490, 0.7478],\n",
      "        [0.4734, 0.7101],\n",
      "        [0.7128, 0.2759]], dtype=torch.float64)\n",
      "new obj: tensor([[3.5931e-01, 3.3224e-01],\n",
      "        [3.0292e-01, 4.5842e-01],\n",
      "        [5.4781e-01, 7.3674e-02],\n",
      "        [3.5853e-01, 1.8963e-01],\n",
      "        [4.4778e-03, 7.8373e-05],\n",
      "        [4.6936e-01, 4.7539e-01],\n",
      "        [7.3051e-02, 2.0827e-03],\n",
      "        [5.5386e-01, 5.4352e-01],\n",
      "        [6.7982e-01, 3.5956e-01],\n",
      "        [3.7621e-01, 2.6934e-03]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.12063619]\n",
      "Time: 26.03763662907295\n",
      "Iteration: 5\n",
      "new candidats: tensor([[0.7809, 0.2288],\n",
      "        [0.8866, 0.7874],\n",
      "        [0.5486, 0.6464],\n",
      "        [0.4319, 0.7208],\n",
      "        [0.4293, 0.7723],\n",
      "        [0.0780, 0.1659],\n",
      "        [0.0311, 0.7262],\n",
      "        [0.0780, 0.1659],\n",
      "        [0.9954, 0.2181],\n",
      "        [0.2690, 0.3449]], dtype=torch.float64)\n",
      "new obj: tensor([[6.6681e-01, 1.0676e-02],\n",
      "        [2.8992e-04, 6.6169e-06],\n",
      "        [5.4781e-01, 7.3674e-02],\n",
      "        [5.5178e-01, 4.8937e-01],\n",
      "        [4.2435e-01, 6.4688e-01],\n",
      "        [4.0909e-01, 4.9240e-01],\n",
      "        [1.0997e-02, 1.5991e-02],\n",
      "        [4.0909e-01, 4.9240e-01],\n",
      "        [1.0232e-01, 6.3918e-04],\n",
      "        [3.6252e-01, 2.3449e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14033]\n",
      "Time: 42.64942621416412\n",
      "Iteration: 6\n",
      "new candidats: tensor([[0.4894, 0.7410],\n",
      "        [0.9332, 0.5982],\n",
      "        [0.8467, 0.0370],\n",
      "        [0.6909, 0.9688],\n",
      "        [0.2010, 0.2706],\n",
      "        [0.7082, 0.6710],\n",
      "        [0.8957, 0.4553],\n",
      "        [0.4568, 0.2423],\n",
      "        [0.4293, 0.7723],\n",
      "        [0.4287, 0.6467]], dtype=torch.float64)\n",
      "new obj: tensor([[6.4460e-01, 3.9567e-01],\n",
      "        [2.2217e-04, 6.2751e-06],\n",
      "        [1.6827e-01, 3.1612e-01],\n",
      "        [3.0709e-03, 2.4517e-03],\n",
      "        [4.6981e-01, 3.7909e-01],\n",
      "        [7.8085e-02, 2.8288e-03],\n",
      "        [1.7567e-02, 4.4043e-05],\n",
      "        [2.1614e-01, 7.5307e-02],\n",
      "        [4.2435e-01, 6.4688e-01],\n",
      "        [4.9236e-01, 2.1575e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14360595]\n",
      "Time: 22.21841929014772\n",
      "Iteration: 7\n",
      "new candidats: tensor([[0.7265, 0.9096],\n",
      "        [0.9462, 0.2018],\n",
      "        [0.3994, 0.7849],\n",
      "        [0.7578, 0.7691],\n",
      "        [0.6202, 0.1193],\n",
      "        [0.4490, 0.7478],\n",
      "        [0.7622, 0.3301],\n",
      "        [0.9050, 0.9452],\n",
      "        [0.4172, 0.2942],\n",
      "        [0.7391, 0.8953]], dtype=torch.float64)\n",
      "new obj: tensor([[6.0178e-03, 1.8640e-03],\n",
      "        [2.4079e-01, 1.3840e-02],\n",
      "        [2.9850e-01, 6.9386e-01],\n",
      "        [2.0066e-02, 1.1330e-03],\n",
      "        [1.5100e-01, 1.0499e-02],\n",
      "        [5.5386e-01, 5.4352e-01],\n",
      "        [2.8742e-01, 1.0174e-03],\n",
      "        [1.0474e-05, 7.8698e-07],\n",
      "        [2.4861e-01, 9.9206e-02],\n",
      "        [5.9969e-03, 1.4213e-03]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14664538]\n",
      "Time: 18.808121817884967\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration: 8\n",
      "new candidats: tensor([[0.6920, 0.9395],\n",
      "        [0.7239, 0.3106],\n",
      "        [0.7871, 0.7705],\n",
      "        [0.4367, 0.7564],\n",
      "        [0.0029, 0.4013],\n",
      "        [0.3124, 0.2874],\n",
      "        [0.1821, 0.0388],\n",
      "        [0.9736, 0.9333],\n",
      "        [0.4293, 0.7723],\n",
      "        [0.2339, 0.3046]], dtype=torch.float64)\n",
      "new obj: tensor([[6.3325e-03, 3.7349e-03],\n",
      "        [2.9831e-01, 2.0519e-03],\n",
      "        [8.9633e-03, 3.8684e-04],\n",
      "        [4.9382e-01, 5.9704e-01],\n",
      "        [1.8532e-01, 2.8473e-01],\n",
      "        [3.8809e-01, 2.1801e-01],\n",
      "        [3.5984e-01, 3.0873e-01],\n",
      "        [9.5942e-07, 4.2877e-08],\n",
      "        [4.2435e-01, 6.4688e-01],\n",
      "        [4.2985e-01, 3.1168e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.15036344]\n",
      "Time: 10.138051971094683\n",
      "Iteration: 1\n",
      "new candidats: tensor([[0.3234, 0.9790],\n",
      "        [0.2531, 0.2951],\n",
      "        [0.9940, 0.0159],\n",
      "        [0.2032, 0.3157],\n",
      "        [0.1723, 0.1055],\n",
      "        [0.8992, 0.6723],\n",
      "        [0.9931, 0.1530],\n",
      "        [0.6488, 0.4409],\n",
      "        [0.1342, 0.2470],\n",
      "        [0.9390, 0.2765]], dtype=torch.float64)\n",
      "new obj: tensor([[3.2101e-03, 1.0524e-01],\n",
      "        [4.3107e-01, 2.9368e-01],\n",
      "        [1.9693e-02, 2.6939e-03],\n",
      "        [4.2285e-01, 3.3878e-01],\n",
      "        [4.4291e-01, 3.9237e-01],\n",
      "        [3.0757e-04, 6.8927e-06],\n",
      "        [9.7309e-02, 6.6449e-03],\n",
      "        [3.9840e-02, 3.7259e-03],\n",
      "        [4.6075e-01, 4.6193e-01],\n",
      "        [1.9928e-01, 3.1910e-04]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.0546586]\n",
      "Time: 31.324669030029327\n",
      "Iteration: 2\n",
      "new candidats: tensor([[0.7622, 0.7853],\n",
      "        [0.1126, 0.1974],\n",
      "        [0.5311, 0.5552],\n",
      "        [0.1853, 0.1843],\n",
      "        [0.4759, 0.2257],\n",
      "        [0.0024, 0.9784],\n",
      "        [0.0216, 0.1244],\n",
      "        [0.6391, 0.0308],\n",
      "        [0.5736, 0.5272],\n",
      "        [0.6023, 0.0240]], dtype=torch.float64)\n",
      "new obj: tensor([[1.5757e-02, 9.9746e-04],\n",
      "        [4.5442e-01, 4.8875e-01],\n",
      "        [2.6012e-01, 2.2056e-02],\n",
      "        [4.9711e-01, 4.2212e-01],\n",
      "        [1.9504e-01, 6.3235e-02],\n",
      "        [1.5777e-04, 2.9531e-04],\n",
      "        [3.1272e-01, 4.5206e-01],\n",
      "        [7.7198e-02, 6.1374e-03],\n",
      "        [1.4309e-01, 9.2575e-03],\n",
      "        [6.5959e-02, 9.8306e-03]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.06788242]\n",
      "Time: 35.04546782793477\n",
      "Iteration: 3\n",
      "new candidats: tensor([[0.7536, 0.7332],\n",
      "        [0.0644, 0.2215],\n",
      "        [0.1395, 0.1798],\n",
      "        [0.0842, 0.1765],\n",
      "        [0.1989, 0.1951],\n",
      "        [0.8932, 0.6460],\n",
      "        [0.1642, 0.3517],\n",
      "        [0.6934, 0.0058],\n",
      "        [0.8340, 0.1369],\n",
      "        [0.0500, 0.4952]], dtype=torch.float64)\n",
      "new obj: tensor([[2.6896e-02, 1.1213e-03],\n",
      "        [3.9510e-01, 4.9694e-01],\n",
      "        [4.7518e-01, 4.6834e-01],\n",
      "        [4.1992e-01, 4.9531e-01],\n",
      "        [4.9984e-01, 4.0613e-01],\n",
      "        [3.8953e-04, 9.8272e-06],\n",
      "        [3.6902e-01, 3.3557e-01],\n",
      "        [7.5129e-02, 3.3061e-03],\n",
      "        [5.4465e-01, 5.0662e-01],\n",
      "        [1.2697e-01, 1.6740e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.0887546]\n",
      "Time: 24.794045815011486\n",
      "Iteration: 4\n",
      "new candidats: tensor([[0.0171, 0.2038],\n",
      "        [0.8219, 0.1705],\n",
      "        [0.7007, 0.6012],\n",
      "        [0.1620, 0.2510],\n",
      "        [0.9234, 0.7902],\n",
      "        [0.9121, 0.1408],\n",
      "        [0.2400, 0.8280],\n",
      "        [0.4578, 0.7750],\n",
      "        [0.3515, 0.1277],\n",
      "        [0.4208, 0.1944]], dtype=torch.float64)\n",
      "new obj: tensor([[3.2906e-01, 4.8272e-01],\n",
      "        [6.5834e-01, 2.2141e-01],\n",
      "        [6.0332e-02, 1.5168e-03],\n",
      "        [4.7535e-01, 4.3546e-01],\n",
      "        [6.9029e-05, 1.5009e-06],\n",
      "        [3.1408e-01, 2.3183e-01],\n",
      "        [1.4031e-02, 1.8954e-01],\n",
      "        [4.8694e-01, 5.7534e-01],\n",
      "        [3.5156e-01, 1.7393e-01],\n",
      "        [2.7228e-01, 1.0735e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.10618546]\n",
      "Time: 40.07301575411111\n",
      "Iteration: 5\n",
      "new candidats: tensor([[0.8059, 0.1169],\n",
      "        [0.8414, 0.6193],\n",
      "        [0.8094, 0.1480],\n",
      "        [0.4309, 0.5543],\n",
      "        [0.0434, 0.7214],\n",
      "        [0.4839, 0.8792],\n",
      "        [0.9733, 0.7346],\n",
      "        [0.1241, 0.5289],\n",
      "        [0.8854, 0.9741],\n",
      "        [0.6650, 0.8091]], dtype=torch.float64)\n",
      "new obj: tensor([[4.9943e-01, 4.4884e-01],\n",
      "        [1.9124e-03, 4.0747e-05],\n",
      "        [6.1352e-01, 3.1791e-01],\n",
      "        [2.4430e-01, 5.3085e-02],\n",
      "        [1.2315e-02, 1.7450e-02],\n",
      "        [1.3919e-01, 3.5993e-01],\n",
      "        [1.7061e-05, 5.6321e-07],\n",
      "        [1.2046e-01, 1.2507e-01],\n",
      "        [1.0507e-05, 1.2431e-06],\n",
      "        [9.9257e-02, 2.0859e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.11283146]\n",
      "Time: 48.564771874807775\n",
      "Iteration: 6\n",
      "new candidats: tensor([[0.4609, 0.7457],\n",
      "        [0.7887, 0.3673],\n",
      "        [0.0171, 0.2038],\n",
      "        [0.9303, 0.5373],\n",
      "        [0.0126, 0.3990],\n",
      "        [0.6363, 0.3741],\n",
      "        [0.7220, 0.5765],\n",
      "        [0.4563, 0.7135],\n",
      "        [0.4141, 0.7701],\n",
      "        [0.9746, 0.5007]], dtype=torch.float64)\n",
      "new obj: tensor([[5.8932e-01, 5.0358e-01],\n",
      "        [1.7632e-01, 5.5384e-04],\n",
      "        [3.2906e-01, 4.8272e-01],\n",
      "        [1.1839e-03, 1.1579e-05],\n",
      "        [1.9641e-01, 2.9240e-01],\n",
      "        [7.3362e-02, 6.2166e-03],\n",
      "        [3.1057e-02, 7.4191e-04],\n",
      "        [6.3852e-01, 4.1397e-01],\n",
      "        [3.8334e-01, 6.6477e-01],\n",
      "        [1.7501e-03, 5.8307e-06]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14163641]\n",
      "Time: 65.66077609895729\n",
      "Iteration: 7\n",
      "new candidats: tensor([[0.1517, 0.6925],\n",
      "        [0.8953, 0.9124],\n",
      "        [0.9481, 0.0916],\n",
      "        [0.0242, 0.5252],\n",
      "        [0.4475, 0.7575],\n",
      "        [0.0947, 0.0892],\n",
      "        [0.4904, 0.7141],\n",
      "        [0.7220, 0.5765],\n",
      "        [0.6812, 0.6300],\n",
      "        [0.0970, 0.6673]], dtype=torch.float64)\n",
      "new obj: tensor([[2.5037e-02, 4.0198e-02],\n",
      "        [3.1751e-05, 1.9286e-06],\n",
      "        [1.3027e-01, 1.0060e-01],\n",
      "        [9.0641e-02, 1.2992e-01],\n",
      "        [5.2179e-01, 5.7298e-01],\n",
      "        [3.7333e-01, 4.2559e-01],\n",
      "        [6.9634e-01, 3.2353e-01],\n",
      "        [3.1057e-02, 7.4191e-04],\n",
      "        [1.0891e-01, 3.6324e-03],\n",
      "        [2.8761e-02, 3.5265e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14986594]\n",
      "Time: 44.92131319409236\n",
      "Iteration: 8\n",
      "new candidats: tensor([[0.4904, 0.7141],\n",
      "        [0.4088, 0.1806],\n",
      "        [0.4475, 0.7575],\n",
      "        [0.0473, 0.3273],\n",
      "        [0.4141, 0.7701],\n",
      "        [0.4904, 0.7141],\n",
      "        [0.4287, 0.0835],\n",
      "        [0.6572, 0.1898],\n",
      "        [0.8389, 0.9939],\n",
      "        [0.9367, 0.0748]], dtype=torch.float64)\n",
      "new obj: tensor([[6.9634e-01, 3.2353e-01],\n",
      "        [2.8889e-01, 1.1852e-01],\n",
      "        [5.2179e-01, 5.7298e-01],\n",
      "        [3.0510e-01, 4.0570e-01],\n",
      "        [3.8334e-01, 6.6477e-01],\n",
      "        [6.9634e-01, 3.2353e-01],\n",
      "        [2.1980e-01, 8.4475e-02],\n",
      "        [2.8782e-01, 6.7906e-03],\n",
      "        [3.1051e-05, 7.1294e-06],\n",
      "        [1.2602e-01, 1.3700e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14986594]\n",
      "Time: 37.57994946092367\n",
      "Iteration: 1\n",
      "new candidats: tensor([[0.9828, 0.9704],\n",
      "        [0.1594, 0.2659],\n",
      "        [0.5921, 0.1476],\n",
      "        [0.0488, 0.1409],\n",
      "        [0.3576, 0.9053],\n",
      "        [0.4105, 0.4351],\n",
      "        [0.3973, 0.4444],\n",
      "        [0.3428, 0.9902],\n",
      "        [0.1670, 0.3173],\n",
      "        [0.1769, 0.1172]], dtype=torch.float64)\n",
      "new obj: tensor([[2.9858e-07, 1.5905e-08],\n",
      "        [4.6395e-01, 4.2857e-01],\n",
      "        [1.4098e-01, 1.6017e-02],\n",
      "        [3.5964e-01, 4.7594e-01],\n",
      "        [3.1580e-02, 3.6779e-01],\n",
      "        [1.5807e-01, 5.9713e-02],\n",
      "        [1.6144e-01, 6.3366e-02],\n",
      "        [3.1775e-03, 9.7499e-02],\n",
      "        [4.1532e-01, 3.7426e-01],\n",
      "        [4.5588e-01, 3.9785e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.05371034]\n",
      "Time: 58.53086526202969\n",
      "Iteration: 2\n",
      "new candidats: tensor([[0.1769, 0.1172],\n",
      "        [0.7902, 0.8677],\n",
      "        [0.6895, 0.0749],\n",
      "        [0.1922, 0.2171],\n",
      "        [0.0922, 0.1848],\n",
      "        [0.1415, 0.1937],\n",
      "        [0.0315, 0.2366],\n",
      "        [0.4673, 0.5373],\n",
      "        [0.2477, 0.8147],\n",
      "        [0.7681, 0.2340]], dtype=torch.float64)\n",
      "new obj: tensor([[4.5588e-01, 3.9785e-01],\n",
      "        [2.5721e-03, 2.7840e-04],\n",
      "        [1.9443e-01, 6.9641e-03],\n",
      "        [4.9779e-01, 4.1336e-01],\n",
      "        [4.3120e-01, 4.9548e-01],\n",
      "        [4.7886e-01, 4.6878e-01],\n",
      "        [3.4478e-01, 4.8267e-01],\n",
      "        [2.2604e-01, 3.4489e-02],\n",
      "        [1.9338e-02, 2.1999e-01],\n",
      "        [6.3656e-01, 6.1495e-03]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.0696058]\n",
      "Time: 49.841718868818134\n",
      "Iteration: 3\n",
      "new candidats: tensor([[0.9241, 0.2584],\n",
      "        [0.2609, 0.2530],\n",
      "        [0.3869, 0.6224],\n",
      "        [0.9937, 0.1121],\n",
      "        [0.7898, 0.0378],\n",
      "        [0.2297, 0.5605],\n",
      "        [0.9241, 0.2584],\n",
      "        [0.2098, 0.4146],\n",
      "        [0.9726, 0.0072],\n",
      "        [0.5981, 0.1789]], dtype=torch.float64)\n",
      "new obj: tensor([[0.2740, 0.0016],\n",
      "        [0.4609, 0.3061],\n",
      "        [0.3079, 0.1588],\n",
      "        [0.0730, 0.0109],\n",
      "        [0.1917, 0.1572],\n",
      "        [0.1043, 0.0810],\n",
      "        [0.2740, 0.0016],\n",
      "        [0.2811, 0.2203],\n",
      "        [0.0248, 0.0062],\n",
      "        [0.1578, 0.0152]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.0696058]\n",
      "Time: 32.73247098992579\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration: 4\n",
      "new candidats: tensor([[0.0657, 0.2036],\n",
      "        [0.4477, 0.8768],\n",
      "        [0.1301, 0.6299],\n",
      "        [0.4631, 0.6259],\n",
      "        [0.1309, 0.6144],\n",
      "        [0.7942, 0.0757],\n",
      "        [0.7806, 0.4333],\n",
      "        [0.4814, 0.7461],\n",
      "        [0.4212, 0.7999],\n",
      "        [0.7285, 0.1166]], dtype=torch.float64)\n",
      "new obj: tensor([[3.9895e-01, 4.9980e-01],\n",
      "        [1.2879e-01, 4.6558e-01],\n",
      "        [4.7270e-02, 5.1751e-02],\n",
      "        [5.1861e-01, 1.3347e-01],\n",
      "        [5.5587e-02, 5.9135e-02],\n",
      "        [3.2758e-01, 3.3433e-01],\n",
      "        [4.9337e-02, 4.5974e-04],\n",
      "        [6.2317e-01, 4.3609e-01],\n",
      "        [3.1470e-01, 6.8560e-01],\n",
      "        [3.9683e-01, 3.6647e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.1127384]\n",
      "Time: 22.67715651798062\n",
      "Iteration: 5\n",
      "new candidats: tensor([[0.0075, 0.9115],\n",
      "        [0.8878, 0.2234],\n",
      "        [0.8391, 0.9674],\n",
      "        [0.4886, 0.7156],\n",
      "        [0.0094, 0.4472],\n",
      "        [0.4573, 0.7532],\n",
      "        [0.5608, 0.1421],\n",
      "        [0.8611, 0.6004],\n",
      "        [0.7796, 0.7250],\n",
      "        [0.4747, 0.0535]], dtype=torch.float64)\n",
      "new obj: tensor([[5.6219e-04, 1.0201e-03],\n",
      "        [4.6474e-01, 2.5208e-02],\n",
      "        [6.4462e-05, 1.1431e-05],\n",
      "        [6.9339e-01, 3.3323e-01],\n",
      "        [1.4796e-01, 2.2254e-01],\n",
      "        [5.5960e-01, 5.3394e-01],\n",
      "        [1.2808e-01, 2.3607e-02],\n",
      "        [1.1052e-03, 2.9281e-05],\n",
      "        [1.3868e-02, 4.2270e-04],\n",
      "        [1.5009e-01, 4.9359e-02]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.13573328]\n",
      "Time: 52.09549902193248\n",
      "Iteration: 6\n",
      "new candidats: tensor([[0.5464, 0.1181],\n",
      "        [0.8441, 0.6976],\n",
      "        [0.0417, 0.4121],\n",
      "        [0.0112, 0.7818],\n",
      "        [0.4233, 0.7679],\n",
      "        [0.4573, 0.7532],\n",
      "        [0.7225, 0.3616],\n",
      "        [0.4233, 0.7679],\n",
      "        [0.6072, 0.7403],\n",
      "        [0.0989, 0.1500]], dtype=torch.float64)\n",
      "new obj: tensor([[1.2266e-01, 2.6935e-02],\n",
      "        [2.0090e-03, 3.4274e-05],\n",
      "        [2.0836e-01, 2.8213e-01],\n",
      "        [4.6575e-03, 7.3185e-03],\n",
      "        [4.1909e-01, 6.4886e-01],\n",
      "        [5.5960e-01, 5.3394e-01],\n",
      "        [1.5263e-01, 1.7614e-03],\n",
      "        [4.1909e-01, 6.4886e-01],\n",
      "        [3.6510e-01, 6.8827e-02],\n",
      "        [4.2647e-01, 4.7960e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14773018]\n",
      "Time: 25.495781874051318\n",
      "Iteration: 7\n",
      "new candidats: tensor([[0.3845, 0.3332],\n",
      "        [0.0154, 0.9535],\n",
      "        [0.5700, 0.3508],\n",
      "        [0.4573, 0.7532],\n",
      "        [0.1093, 0.7060],\n",
      "        [0.1049, 0.4851],\n",
      "        [0.1219, 0.3167],\n",
      "        [0.4886, 0.7156],\n",
      "        [0.4140, 0.8507],\n",
      "        [0.7505, 0.2920]], dtype=torch.float64)\n",
      "new obj: tensor([[2.6224e-01, 1.1636e-01],\n",
      "        [2.7040e-04, 5.3074e-04],\n",
      "        [8.5120e-02, 1.6528e-02],\n",
      "        [5.5960e-01, 5.3394e-01],\n",
      "        [1.8728e-02, 2.6568e-02],\n",
      "        [1.6163e-01, 1.7829e-01],\n",
      "        [3.9082e-01, 4.0782e-01],\n",
      "        [6.9339e-01, 3.3323e-01],\n",
      "        [1.5680e-01, 6.1018e-01],\n",
      "        [4.1578e-01, 1.4375e-03]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14773018]\n",
      "Time: 7.667665184941143\n",
      "Iteration: 8\n",
      "new candidats: tensor([[0.9962, 0.3405],\n",
      "        [0.3544, 0.7245],\n",
      "        [0.3993, 0.3294],\n",
      "        [0.7624, 0.1622],\n",
      "        [0.3782, 0.5227],\n",
      "        [0.4573, 0.7532],\n",
      "        [0.0306, 0.7129],\n",
      "        [0.2365, 0.8754],\n",
      "        [0.8058, 0.6895],\n",
      "        [0.2481, 0.7205]], dtype=torch.float64)\n",
      "new obj: tensor([[3.8227e-02, 8.7054e-06],\n",
      "        [2.4715e-01, 4.8031e-01],\n",
      "        [2.4738e-01, 1.0458e-01],\n",
      "        [6.1679e-01, 7.0894e-02],\n",
      "        [1.6069e-01, 5.6128e-02],\n",
      "        [5.5960e-01, 5.3394e-01],\n",
      "        [1.3045e-02, 1.8819e-02],\n",
      "        [6.3132e-03, 1.3958e-01],\n",
      "        [6.7442e-03, 1.2967e-04],\n",
      "        [4.5179e-02, 1.7250e-01]], dtype=torch.float64)\n",
      "Hypervolume (qEHVI): [0.14773018]\n",
      "Time: 16.63592077908106\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=8\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 = 10\n",
    "opt_imp=[]\n",
    "#chosen_acq='EI'\n",
    "chosen_acq='EI_Botorch'\n",
    "#chosen_acq='PES_Botorch'\n",
    "#chosen_acq='MFDS_Botorch'\n",
    "#chosen_acq='TPE_Optuna'\n",
    "#chosen_acq='RS_Botorch'\n",
    "verbose = True\n",
    "rep=20\n",
    "hv_total=[]\n",
    "edmin_total=[]\n",
    "\n",
    "for j in range(rep):\n",
    "    \n",
    "    train_x_qehvi, train_y_qehvi, _ = generate_initial_data(seed=j)\n",
    "    data_x_qehvi=train_x_qehvi.detach().numpy()\n",
    "    data_y_qehvi=train_y_qehvi.detach().numpy()\n",
    "    train_x_qehvi=torch.tensor(train_x_qehvi).to(**tkwargs)\n",
    "    train_y_qehvi=torch.tensor(train_y_qehvi).to(**tkwargs)\n",
    "    mll_qehvi, model_qehvi = initialize_model(train_x_qehvi, train_y_qehvi)\n",
    "    \n",
    "    X_test_all=lhs(N_dim,N_test)\n",
    "    X_test_all=torch.tensor(X_test_all)\n",
    "    #X_test_all=unnormalize(X_test_all, problem.bounds)\n",
    "    Y_test_all = problem(X_test_all)\n",
    "    X_test_all = torch.tensor(X_test_all).to(**tkwargs)\n",
    "    \n",
    "    \n",
    "    # Find PF ground truth and calculate HV\n",
    "    pareto_mask_test_all = is_non_dominated(Y_test_all)\n",
    "    Y_pf = Y_test_all[pareto_mask_test_all]  \n",
    "    bd_test_all = DominatedPartitioning(ref_point=problem.ref_point, Y=Y_pf)\n",
    "    volume_test_all = bd_test_all.compute_hypervolume().item()\n",
    "    \n",
    "    # Initialize edmin\n",
    "    X_pf = torch.tensor(X_test_all[pareto_mask_test_all]).to(**tkwargs) \n",
    "    edmin = distance_XX(train_x_qehvi, X_pf).reshape(1,1)\n",
    "    \n",
    "    # Initialize hv\n",
    "    pareto_mask_train = is_non_dominated(train_y_qehvi)\n",
    "    Y_pf_train = train_y_qehvi[pareto_mask_train] \n",
    "    bd_train = DominatedPartitioning(ref_point=problem.ref_point, Y=Y_pf_train)\n",
    "    hv_truth = np.array(bd_train.compute_hypervolume().item()).reshape(1,1) \n",
    "        \n",
    "    iteration=0\n",
    "    if chosen_acq == 'EI_Botorch':\n",
    "    \n",
    "        while iteration<itr:\n",
    "            iteration += 1\n",
    "            t0 = time.monotonic()\n",
    "            \n",
    "            X_test=lhs(N_dim,N_alt)\n",
    "            X_test=torch.tensor(X_test)\n",
    "            #X_test=unnormalize(X_test, problem.bounds)\n",
    "            \n",
    "            # Fit the models\n",
    "            fit_gpytorch_mll(mll_qehvi)\n",
    "\n",
    "            # Define the qEHVI acquisition module using a QMC sampler\n",
    "            qehvi_sampler = SobolQMCNormalSampler(sample_shape=torch.Size([MC_SAMPLES]))\n",
    "\n",
    "            # Optimize acquisition function and get new observations\n",
    "            new_x_qehvi, new_y_qehvi, new_y_true_qehvi = optimize_qehvi_and_get_observation(\n",
    "                model_qehvi, train_x_qehvi, train_y_qehvi, qehvi_sampler, X_test_all, BATCH_SIZE\n",
    "            )\n",
    "            \n",
    "            # Update training points\n",
    "            train_x_qehvi = torch.cat([train_x_qehvi, new_x_qehvi.reshape(-1, N_dim)])\n",
    "            train_y_qehvi = torch.cat([train_y_qehvi, new_y_qehvi.reshape(-1, N_obj)])\n",
    "            data_x_qehvi=train_x_qehvi.cpu().detach().numpy()\n",
    "            data_y_qehvi=train_y_qehvi.cpu().detach().numpy()\n",
    "            \n",
    "            # Compute hypervolume\n",
    "            pareto_mask_train = is_non_dominated(train_y_qehvi)\n",
    "            Y_pf_train = train_y_qehvi[pareto_mask_train] \n",
    "            bd_train = DominatedPartitioning(ref_point=problem.ref_point, Y=Y_pf_train)\n",
    "            hv_t = np.array(bd_train.compute_hypervolume().item())    \n",
    "            hv_truth=np.concatenate((hv_truth,hv_t.reshape(1,1)))\n",
    "            \n",
    "            # Compute edmin\n",
    "            ed_t = distance_XX(train_x_qehvi, X_pf).reshape(1,1)\n",
    "            edmin = torch.cat((edmin, ed_t.reshape(1,1)))\n",
    "\n",
    "            # Reinitialize the models for next iteration\n",
    "            mll_qehvi, model_qehvi = initialize_model(train_x_qehvi, train_y_qehvi)\n",
    "\n",
    "            t1 = time.monotonic()\n",
    "\n",
    "            if verbose:\n",
    "                print(\"Iteration:\", iteration)\n",
    "                print('new candidats:', new_x_qehvi) \n",
    "                print('new obj:', new_y_qehvi)\n",
    "                print(\"Hypervolume (qEHVI):\", hv_truth[-1])\n",
    "                print(\"Time:\", t1 - t0)\n",
    "     \n",
    "            pd.DataFrame(Y_pf_train).to_csv(\"y_pareto_truth.csv\", header=None, index=None)\n",
    "            pd.DataFrame(data_x_qehvi).to_csv(\"data_x\"+str(j)+\".csv\", header=None, index=None)\n",
    "            pd.DataFrame(data_y_qehvi).to_csv(\"data_y\"+str(j)+\".csv\", header=None, index=None)\n",
    "            pd.DataFrame(hv_truth).to_csv(\"hv_truth.csv\", header=None, index=None)\n",
    "\n",
    "    # Save hv\n",
    "    hv_total.append(np.ravel(hv_truth))\n",
    "    pd.DataFrame(hv_total).to_csv(\"hv_truth_total.csv\", header=None, index=None)\n",
    "    \n",
    "    # Save edmin\n",
    "    edmin_total.append(np.ravel(edmin.cpu().detach().numpy()))\n",
    "    pd.DataFrame(edmin_total).to_csv(\"edmin_total.csv\", header=None, index=None)\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "decf4358",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.9.18"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
