{
 "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": null,
   "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"
     ]
    }
   ],
   "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
}
