{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "import math\n",
    "import numpy as np\n",
    "import random\n",
    "from sklearn.gaussian_process.kernels import RBF, Matern\n",
    "from scipy.interpolate import interp1d\n",
    "import pickle\n",
    "from yahpo_gym import local_config\n",
    "from yahpo_gym import *\n",
    "import ConfigSpace as CS\n",
    "import sobol_seq\n",
    "noise_level = 0.1\n",
    "local_config.init_config()\n",
    "local_config.set_data_path(\"../yahpo_data-1.0\") # this directory is needed, you can get from https://github.com/slds-lmu/yahpo_data/releases/tag/v1.0\n",
    "\n",
    "def set_noise_level(x):\n",
    "\tglobal noise_level\n",
    "\tnoise_level = x\n",
    "\n",
    "def norm_add_noise(y, max_f, min_f):\n",
    "\tglobal noise_level\n",
    "\tif y == np.inf or y > max_f:\n",
    "\t\treturn (max_f - min_f) / (max_f - min_f)\n",
    "\telif np.isnan(y) or y < min_f:\n",
    "\t\treturn (min_f - min_f) / (max_f - min_f)\n",
    "\telse:\n",
    "\t\treturn (y - min_f) / (max_f - min_f)\n",
    "\n",
    "HPO_index = -1\n",
    "\n",
    "def get_HPO_index():\n",
    "\tglobal HPO_index\n",
    "\treturn HPO_index\n",
    "\n",
    "def set_HPO_index(x):\n",
    "\tglobal HPO_index\n",
    "\tHPO_index = x\n",
    "\t\n",
    "YAHPO_instance = '3945'\n",
    "YAHPO_benchmarkset = BenchmarkSet(scenario=\"lcbench\")\n",
    "\n",
    "def get_YAHPO_index():\n",
    "\tglobal YAHPO_instance\n",
    "\treturn YAHPO_benchmarkset, YAHPO_instance\n",
    "\n",
    "def set_YAHPO_index(x):\n",
    "\tglobal YAHPO_instance, YAHPO_benchmarkset\n",
    "\tYAHPO_instance = x\n",
    "\tYAHPO_benchmarkset = BenchmarkSet(scenario=\"lcbench\", instance=YAHPO_instance)\n",
    "\n",
    "def scale_value(v, min_val, max_val, log_scale=False):\n",
    "    if log_scale:\n",
    "        return 10 ** (v * (np.log10(max_val) - np.log10(min_val)) + np.log10(min_val))\n",
    "    else:\n",
    "        return v * (max_val - min_val) + min_val\n",
    "\n",
    "def YAHPO_1(x):\n",
    "\t'''\n",
    "\t\t# list all scenarios\n",
    "\t\tlist_scenarios()\n",
    "\t\t\n",
    "\t\t# list all instances in this scenario\n",
    "\t\tb = BenchmarkSet(scenario=scenario) \n",
    "\t\tb.instances \n",
    "\t\t\n",
    "\t\t# or you can check every scenario and instance in the bottom of this page\n",
    "\t\thttps://slds-lmu.github.io/yahpo_gym/scenarios.html\n",
    "\t'''\n",
    "\t# scale\n",
    "\tlearning_rate = scale_value(x[0], 0.0002, 0.1, True) # Learning rate, log scale\n",
    "\tmax_dropout = scale_value(x[1], 0.0, 1.0) # Max dropout, linear scale\n",
    "\tmomentum = scale_value(x[2], 0.1, 0.99) # Momentum, linear scale\n",
    "\tweight_decay = scale_value(x[3], 1e-5, 0.1, True) # Weight decay, log scale\n",
    "\n",
    "\tconfig = {\n",
    "\t\t'OpenML_task_id': YAHPO_instance,\n",
    "\t\t'batch_size': 91, # discrete, Range: [16, 512]\n",
    "\t\t'epoch': 26, # discrete, Range: [1, 52]\n",
    "\t\t'learning_rate': learning_rate, # continuous, [0.00010000000000000009, 0.10000000000000002]\n",
    "\t\t'max_dropout': max_dropout, # continuous, Range: [0.0, 1.0]\n",
    "\t\t'max_units': 256, # discrete, Range: [64, 1024]\n",
    "\t\t'momentum': momentum, # continuous, Range: [0.1, 0.99]\n",
    "\t\t'num_layers': 3, # discrete, Range: [1, 5]\n",
    "\t\t'weight_decay': weight_decay # continuous, Range: [1e-05, 0.1]\n",
    "\t}\n",
    "\n",
    "\tresult = YAHPO_benchmarkset.objective_function(CS.Configuration(YAHPO_benchmarkset._get_config_space(), values=config))\n",
    "\tobj1 = result[0]['test_balanced_accuracy']\n",
    "\tmax_obj1 = 1 # Max test_balanced_accuracy\n",
    "\tmin_obj1 = 0 # Min test_balanced_accuracy\n",
    "\n",
    "\n",
    "\treturn norm_add_noise(obj1, max_obj1, min_obj1)\n",
    "\n",
    "def YAHPO_2(x):\n",
    "\t'''\n",
    "\t\t# list all scenarios\n",
    "\t\tlist_scenarios()\n",
    "\t\t\n",
    "\t\t# list all instances in this scenario\n",
    "\t\tb = BenchmarkSet(scenario=scenario) \n",
    "\t\tb.instances \n",
    "\t\t\n",
    "\t\t# or you can check every scenario and instance in the bottom of this page\n",
    "\t\thttps://slds-lmu.github.io/yahpo_gym/scenarios.html\n",
    "\t'''\n",
    "\t# scale\n",
    "\tlearning_rate = scale_value(x[0], 0.0002, 0.1, True) # Learning rate, log scale\n",
    "\tmax_dropout = scale_value(x[1], 0.0, 1.0) # Max dropout, linear scale\n",
    "\tmomentum = scale_value(x[2], 0.1, 0.99) # Momentum, linear scale\n",
    "\tweight_decay = scale_value(x[3], 1e-5, 0.1, True) # Weight decay, log scale\n",
    "\n",
    "\tconfig = {\n",
    "\t\t'OpenML_task_id': YAHPO_instance,\n",
    "\t\t'batch_size': 91, # discrete, Range: [16, 512]\n",
    "\t\t'epoch': 26, # discrete, Range: [1, 52]\n",
    "\t\t'learning_rate': learning_rate, # continuous, [0.00010000000000000009, 0.10000000000000002]\n",
    "\t\t'max_dropout': max_dropout, # continuous, Range: [0.0, 1.0]\n",
    "\t\t'max_units': 256, # discrete, Range: [64, 1024]\n",
    "\t\t'momentum': momentum, # continuous, Range: [0.1, 0.99]\n",
    "\t\t'num_layers': 3, # discrete, Range: [1, 5]\n",
    "\t\t'weight_decay': weight_decay # continuous, Range: [1e-05, 0.1]\n",
    "\t}\n",
    "\n",
    "\tresult = YAHPO_benchmarkset.objective_function(CS.Configuration(YAHPO_benchmarkset._get_config_space(), values=config))\n",
    "\tobj2 = -result[0]['test_cross_entropy']\n",
    "\n",
    "\tmin_obj2 = -1 # Min test_cross_entropy\n",
    "\tmax_obj2 = -0 # Max test_cross_entropy\n",
    "\n",
    "\treturn norm_add_noise(obj2, max_obj2, min_obj2)\n",
    "\n",
    "def HPO(x):\n",
    "\tglobal HPO_index\n",
    "\tfile = open(\"../Environment/HPObench/hpobenchXGB_\" + str(HPO_index) + \".pkl\",'rb')\n",
    "\tdata = pickle.load(file)\n",
    "\tmax_f = max(data['accs'])\n",
    "\tmin_f = min(data['accs'])\n",
    "\tif list(x) in data['domain']:\n",
    "\t\tobj = data['accs'][data['domain'].index(list(x))]\n",
    "\telse:\n",
    "\t\tobj = np.argmin(np.sum(abs(np.array(x)-np.array(data['domain'])), axis=1), axis=0)\n",
    "\treturn norm_add_noise(obj, max_f, min_f)\n",
    "\n",
    "def GPF(X, kernel, kernel_ls):\n",
    "\tdef countKernel(x, y, kernel, kernel_ls):  # x and y must be a 2-dimensional array\n",
    "\t\tkernel_var = 1.0\n",
    "\t\tif (kernel == \"RBF\"):\n",
    "\t\t\tkernelF = kernel_var * RBF(kernel_ls)\n",
    "\t\telif (kernel == \"matern52\"):\n",
    "\t\t\tkernelF = kernel_var * Matern(length_scale=kernel_ls, nu=2.5)\n",
    "\t\tcov = kernelF.__call__(x, y)\n",
    "\t\treturn cov\n",
    "\tmu = np.zeros(len(X))       # mu = 0\n",
    "\tcov = countKernel(X, X, kernel, kernel_ls)\n",
    "\tY = np.random.multivariate_normal(mu, cov).reshape(len(X), 1)\n",
    "\tY = (Y - min(Y)) / (max(Y) - min(Y)) # normalize\n",
    "\tf = interp1d(X.reshape(-1), Y.reshape(-1), kind='cubic', fill_value='extrapolate')  # f(x) = y\n",
    "\treturn f\n",
    "\n",
    "def SE(X, kernel_ls):\n",
    "\tmu = np.zeros(len(X))       # mu = 0\n",
    "\tcov = RBF(kernel_ls).__call__(X, X)     # x and y must be a 2-dimensional array\n",
    "\tY = np.random.multivariate_normal(mu, cov).reshape(len(X), 1)\n",
    "\tY = (Y - min(Y)) / (max(Y) - min(Y)) # normalize\n",
    "\tf = interp1d(X.reshape(-1), Y.reshape(-1), kind='cubic', fill_value='extrapolate')  # f(x) = y\n",
    "\treturn f\n",
    "\n",
    "def Matern52(X, kernel_ls):\n",
    "\tmu = np.zeros(len(X))       # mu = 0\n",
    "\tcov = Matern(length_scale=kernel_ls, nu=2.5).__call__(X, X)     # x and y must be a 2-dimensional array\n",
    "\tY = np.random.multivariate_normal(mu, cov).reshape(len(X), 1)\n",
    "\tY = (Y - min(Y)) / (max(Y) - min(Y)) # normalize\n",
    "\tf = interp1d(X.reshape(-1), Y.reshape(-1), kind='cubic', fill_value='extrapolate')  # f(x) = y\n",
    "\treturn f\n",
    "\n",
    "\n",
    "def Branin(x):\n",
    "\t# scale x from [0, 1] to truth domain\n",
    "\txmin = 0\n",
    "\txmax = 10\n",
    "\tx = list(xmin + np.asarray(x) * (xmax - xmin))\n",
    "\n",
    "\t# f\n",
    "\tb = 5.1 / (4 * pow(math.pi, 2))\n",
    "\tc = 5. / math.pi\n",
    "\tr = 6\n",
    "\ts = 10\n",
    "\tt = 1. / (8 * math.pi)\n",
    "\n",
    "\ty = float(pow((x[1] - b * pow(x[0], 2) + c * x[0]- r), 2) + s * (1-t) * np.cos(x[0]) + s)\n",
    "\tmax_f = 100.\n",
    "\tmin_f = 0.\n",
    "\treturn norm_add_noise(y, max_f, min_f)\n",
    "\n",
    "def Currin(x):\n",
    "\t# scale x from [0, 1] to truth domain\n",
    "\txmin = 0\n",
    "\txmax = 1\n",
    "\tx = list(xmin + np.asarray(x) * (xmax - xmin))\n",
    "\n",
    "\t# f\n",
    "\ty = float(((1 - math.exp(-0.5*(1/x[1]))) * ((2300*pow(x[0], 3) + 1900*pow(x[0], 2) + 2092*x[0] + 60) / (100*pow(x[0], 3) + 500*pow(x[0], 2) + 4*x[0] + 20))))\n",
    "\tmax_f = 14.\n",
    "\tmin_f = 0.\n",
    "\n",
    "\treturn norm_add_noise(y, max_f, min_f)\n",
    "\n",
    "def Ackley(x):\n",
    "\t# scale x from [0, 1] to truth domain\n",
    "\txmin = -30\n",
    "\txmax = 30\n",
    "\tx = list(xmin + np.asarray(x) * (xmax - xmin))\n",
    "\n",
    "\t# f\n",
    "\tsquare_sum = pow(x[0], 2) + pow(x[1], 2)\n",
    "\tcos_sum = math.cos(2 * math.pi * x[0]) + math.cos(2 * math.pi * x[1])\n",
    "\ty = -20.0 * math.exp(-0.2 * math.sqrt(0.5*square_sum)) - math.exp(0.5 * cos_sum) + 20 + math.exp(1)\n",
    "\n",
    "\tmax_f = 0.\n",
    "\tmin_f = -28.\n",
    "\n",
    "\treturn norm_add_noise(-y, max_f, min_f)\n",
    "\n",
    "def Rosen(x):\n",
    "\t# scale x from [0, 1] to truth domain\n",
    "\txmin = -2\n",
    "\txmax = 2\n",
    "\tx = list(xmin + np.asarray(x) * (xmax - xmin))\n",
    "\n",
    "\t# f\n",
    "\ty = pow((x[0] - 1), 2) + 100 * pow((x[1] - pow(x[0], 2)), 2)\n",
    "\n",
    "\tmax_f = 0.\n",
    "\tmin_f = -4400.\n",
    "\n",
    "\treturn norm_add_noise(-y, max_f, min_f)\n",
    "\n",
    "def Sphere(x):\n",
    "\t# scale x from [0, 1] to truth domain\n",
    "\txmin = -5\n",
    "\txmax = 5\n",
    "\tx = list(xmin + np.asarray(x) * (xmax - xmin))\n",
    "\n",
    "\t# f\n",
    "\ty = pow(x[0], 2) + pow(x[1], 2)\n",
    "\t\n",
    "\t# perturb\n",
    "\tmax_f = 0.\n",
    "\tmin_f = -50.\n",
    "\n",
    "\treturn norm_add_noise(-y, max_f, min_f)\n",
    "\n",
    "def Schwefel(x):\n",
    "\td = 2\n",
    "\n",
    "\t# scale x from [0, 1] to truth domain\n",
    "\txmin = -500\n",
    "\txmax = 500\n",
    "\tx = list(xmin + np.asarray(x) * (xmax - xmin))\n",
    "\n",
    "\t# f\n",
    "\tsum_ = 0\n",
    "\tfor i in range(0, d):\n",
    "\t\tsum_ = sum_ + x[i] * math.sin(math.sqrt(abs(x[i])))\n",
    "\ty = 418.9829 * d - sum_\n",
    " \n",
    "\tmax_f = 0\n",
    "\tmin_f = -1676.\n",
    "\n",
    "\treturn norm_add_noise(-y, max_f, min_f)\n",
    "\n",
    "def Dixon(x):\n",
    "\td = 2\n",
    "\n",
    "\t# scale x from [0, 1] to truth domain\n",
    "\txmin = -10\n",
    "\txmax = 10\n",
    "\tx = list(xmin + np.asarray(x) * (xmax - xmin))\n",
    "\n",
    "\t# f\n",
    "\tsum_ = 0\n",
    "\tfor i in range(1, d):    \n",
    "\t\tsum_ = sum_ + (i+1) * pow((2 * pow(x[i], 2) - x[i-1]), 2)\n",
    "\ty = pow(x[0] - 1, 2) + sum_\n",
    "\t\n",
    "\tmax_f = 0.\n",
    "\tmin_f = -88311.\n",
    "\n",
    "\treturn norm_add_noise(-y, max_f, min_f)\n",
    "\n",
    "def Rastrigin(x):\n",
    "\td = 2\n",
    "\n",
    "\t# scale x from [0, 1] to truth domain\n",
    "\txmin = -5\n",
    "\txmax = 5\n",
    "\tx = list(xmin + np.asarray(x) * (xmax - xmin))\n",
    "\n",
    "\t# f\n",
    "\tsum_ = 0\n",
    "\tfor i in range(0, d):\n",
    "\t\tsum_ = sum_ + (pow(x[i], 2) - 10 * math.cos(2 * math.pi * x[i]))\n",
    "\ty = 10 * d + sum_\n",
    "\n",
    "\tmax_f = 0.\n",
    "\tmin_f = -81.\n",
    "\n",
    "\treturn norm_add_noise(-y, max_f, min_f)\n",
    "\n",
    "def Zakharov(x):\n",
    "\td = 2\n",
    "\n",
    "\t# scale x from [0, 1] to truth domain\n",
    "\txmin = -5\n",
    "\txmax = 10\n",
    "\tx = list(xmin + np.asarray(x) * (xmax - xmin))\n",
    "\n",
    "\t# f\n",
    "\tsum1 = 0\n",
    "\tsum2 = 0\n",
    "\tfor i in range(0, d):\n",
    "\t\tsum1 = sum1 + pow(x[i], 2)\n",
    "\t\tsum2 = sum2 + 0.5 * (i+1) * x[i]\n",
    "\ty = sum1 + pow(sum2, 2) + pow(sum2, 4)\n",
    "\t\n",
    "\tmax_f = 0.\n",
    "\tmin_f = -51041.\n",
    "\n",
    "\treturn norm_add_noise(-y, max_f, min_f)\n",
    "\n",
    "def GP_function(domain, function_type):\n",
    "\n",
    "\t# select ls\n",
    "\tif (function_type == \"train\"):\n",
    "\t\tkernel_ls = random.uniform(0.1, 0.4)\n",
    "\telif (function_type == \"train_large\"):\n",
    "\t\tkernel_ls = random.uniform(-2, -0.5)\n",
    "\t\tkernel_ls = 10**kernel_ls\n",
    "\telif (function_type == \"RBF_0.05\" or function_type == \"matern52_0.05\"):\n",
    "\t\tkernel_ls = random.uniform(0.05, 0.1)\n",
    "\telif (function_type == \"RBF_0.2\" or function_type == \"matern52_0.2\"):\n",
    "\t\tkernel_ls = random.uniform(0.2, 0.3)\n",
    "\n",
    "\t# select kernel\n",
    "\tif (function_type == \"train\" or function_type == \"train_large\"):\n",
    "\t\tGP_kernel = random.choices([\"RBF\", \"matern52\"])[0]\n",
    "\t\tF = GPF(domain, GP_kernel, kernel_ls)\n",
    "\telif (function_type == \"RBF_0.05\" or function_type == \"RBF_0.2\" or function_type == \"RBF_0.3\"):\n",
    "\t\tGP_kernel = \"RBF\"\n",
    "\t\tF = SE(domain, kernel_ls)\n",
    "\telif (function_type == \"matern52_0.05\" or function_type == \"matern52_0.2\" or function_type == \"matern52_0.3\"):\n",
    "\t\tGP_kernel = \"RBF\"\n",
    "\t\tF = Matern52(domain, kernel_ls)\n",
    "\treturn F, GP_kernel, kernel_ls\n",
    "\n",
    "\n",
    "def RE31_1(x):\n",
    "\tproblem_name = 'RE31'\n",
    "\tn_objectives = 3\n",
    "\tn_variables = 3\n",
    "\tn_constraints = 0\n",
    "\tn_original_constraints = 3\n",
    "\tubound = np.zeros(n_variables)\n",
    "\tlbound = np.zeros(n_variables)\n",
    "\tlbound[0] = 0.00001\n",
    "\tlbound[1] = 0.00001\n",
    "\tlbound[2] = 1.0\n",
    "\tubound[0] = 100.0\n",
    "\tubound[1] = 100.0\n",
    "\tubound[2] = 3.0\n",
    "\tx = x*(ubound - lbound) + lbound\n",
    "\n",
    "\tf = np.zeros(n_objectives)\n",
    "\tg = np.zeros(n_original_constraints)\n",
    "\n",
    "\tx1 = x[0]\n",
    "\tx2 = x[1]\n",
    "\tx3 = x[2]\n",
    "\n",
    "\t# First original objective function\n",
    "\tf[0] = x1 * np.sqrt(16.0 + (x3 * x3)) + x2 * np.sqrt(1.0 + x3 * x3)\n",
    "\t# Second original objective function\n",
    "\tf[1] = (20.0 * np.sqrt(16.0 + (x3 * x3))) / (x1 * x3)\n",
    "\n",
    "\t# Constraint functions \n",
    "\tg[0] = 0.1 - f[0]\n",
    "\tg[1] = 100000.0 - f[1]\n",
    "\tg[2] = 100000 - ((80.0 * np.sqrt(1.0 + x3 * x3)) / (x3 * x2))\n",
    "\tg = np.where(g < 0, -g, 0)                \n",
    "\tf[2] = g[0] + g[1] + g[2]\n",
    "\t\n",
    "\tobj = f[0]\n",
    "\tmax_f = 813.7646219455767\n",
    "\tmin_f = 0.23316847407085803\n",
    "\treturn norm_add_noise(obj, max_f, min_f)\n",
    "\n",
    "def RE31_2(x):\n",
    "\tproblem_name = 'RE31'\n",
    "\tn_objectives = 3\n",
    "\tn_variables = 3\n",
    "\tn_constraints = 0\n",
    "\tn_original_constraints = 3\n",
    "\tubound = np.zeros(n_variables)\n",
    "\tlbound = np.zeros(n_variables)\n",
    "\tlbound[0] = 0.00001\n",
    "\tlbound[1] = 0.00001\n",
    "\tlbound[2] = 1.0\n",
    "\tubound[0] = 100.0\n",
    "\tubound[1] = 100.0\n",
    "\tubound[2] = 3.0\n",
    "\tx = x*(ubound - lbound) + lbound\n",
    "\n",
    "\tf = np.zeros(n_objectives)\n",
    "\tg = np.zeros(n_original_constraints)\n",
    "\n",
    "\tx1 = x[0]\n",
    "\tx2 = x[1]\n",
    "\tx3 = x[2]\n",
    "\n",
    "\t# First original objective function\n",
    "\tf[0] = x1 * np.sqrt(16.0 + (x3 * x3)) + x2 * np.sqrt(1.0 + x3 * x3)\n",
    "\t# Second original objective function\n",
    "\tf[1] = (20.0 * np.sqrt(16.0 + (x3 * x3))) / (x1 * x3)\n",
    "\n",
    "\t# Constraint functions \n",
    "\tg[0] = 0.1 - f[0]\n",
    "\tg[1] = 100000.0 - f[1]\n",
    "\tg[2] = 100000 - ((80.0 * np.sqrt(1.0 + x3 * x3)) / (x3 * x2))\n",
    "\tg = np.where(g < 0, -g, 0)                \n",
    "\tf[2] = g[0] + g[1] + g[2]\n",
    "\t\n",
    "\tobj = f[1]\n",
    "\tmax_f = 2223311.6192850918\n",
    "\tmin_f = 0.3333343733738119\n",
    "\treturn norm_add_noise(obj, max_f, min_f)\n",
    "\n",
    "def RE31_3(x):\n",
    "\tproblem_name = 'RE31'\n",
    "\tn_objectives = 3\n",
    "\tn_variables = 3\n",
    "\tn_constraints = 0\n",
    "\tn_original_constraints = 3\n",
    "\tubound = np.zeros(n_variables)\n",
    "\tlbound = np.zeros(n_variables)\n",
    "\tlbound[0] = 0.00001\n",
    "\tlbound[1] = 0.00001\n",
    "\tlbound[2] = 1.0\n",
    "\tubound[0] = 100.0\n",
    "\tubound[1] = 100.0\n",
    "\tubound[2] = 3.0\n",
    "\tx = x*(ubound - lbound) + lbound\n",
    "\n",
    "\tf = np.zeros(n_objectives)\n",
    "\tg = np.zeros(n_original_constraints)\n",
    "\n",
    "\tx1 = x[0]\n",
    "\tx2 = x[1]\n",
    "\tx3 = x[2]\n",
    "\n",
    "\t# First original objective function\n",
    "\tf[0] = x1 * np.sqrt(16.0 + (x3 * x3)) + x2 * np.sqrt(1.0 + x3 * x3)\n",
    "\t# Second original objective function\n",
    "\tf[1] = (20.0 * np.sqrt(16.0 + (x3 * x3))) / (x1 * x3)\n",
    "\n",
    "\t# Constraint functions \n",
    "\tg[0] = 0.1 - f[0]\n",
    "\tg[1] = 100000.0 - f[1]\n",
    "\tg[2] = 100000 - ((80.0 * np.sqrt(1.0 + x3 * x3)) / (x3 * x2))\n",
    "\tg = np.where(g < 0, -g, 0)                \n",
    "\tf[2] = g[0] + g[1] + g[2]\n",
    "\t\n",
    "\tobj = f[2]\n",
    "\tmax_f = 3765483.941211022\n",
    "\tmin_f = 0.13316847407085802\n",
    "\treturn norm_add_noise(obj, max_f, min_f)\n",
    "\n",
    "def RE32_1(x):\n",
    "\tproblem_name = 'RE32'\n",
    "\tn_objectives = 3\n",
    "\tn_variables = 4\n",
    "\tn_constraints = 0\n",
    "\tn_original_constraints = 4\n",
    "\tubound = np.zeros(n_variables)\n",
    "\tlbound = np.zeros(n_variables)\n",
    "\tlbound[0] = 0.125\n",
    "\tlbound[1] = 0.1\n",
    "\tlbound[2] = 0.1\n",
    "\tlbound[3] = 0.125\n",
    "\tubound[0] = 5.0\n",
    "\tubound[1] = 10.0\n",
    "\tubound[2] = 10.0\n",
    "\tubound[3] = 5.0\n",
    "\tx = x*(ubound - lbound) + lbound\n",
    "\tf = np.zeros(n_objectives)\n",
    "\tg = np.zeros(n_original_constraints)\n",
    "\n",
    "\tx1 = x[0]\n",
    "\tx2 = x[1]\n",
    "\tx3 = x[2]\n",
    "\tx4 = x[3]\n",
    "\n",
    "\tP = 6000\n",
    "\tL = 14\n",
    "\tE = 30 * 1e6\n",
    "\n",
    "\t# // deltaMax = 0.25\n",
    "\tG = 12 * 1e6\n",
    "\ttauMax = 13600\n",
    "\tsigmaMax = 30000\n",
    "\n",
    "\t# First original objective function\n",
    "\tf[0] = (1.10471 * x1 * x1 * x2) + (0.04811 * x3 * x4) * (14.0 + x2)\n",
    "\t# Second original objective function\n",
    "\tf[1] = (4 * P * L * L * L) / (E * x4 * x3 * x3 * x3)\n",
    "\n",
    "\t# Constraint functions\n",
    "\tM = P * (L + (x2 / 2))\n",
    "\ttmpVar = ((x2 * x2) / 4.0) + np.power((x1 + x3) / 2.0, 2)\n",
    "\tR = np.sqrt(tmpVar)\n",
    "\ttmpVar = ((x2 * x2) / 12.0) + np.power((x1 + x3) / 2.0, 2)\n",
    "\tJ = 2 * np.sqrt(2) * x1 * x2 * tmpVar\n",
    "\n",
    "\ttauDashDash = (M * R) / J    \n",
    "\ttauDash = P / (np.sqrt(2) * x1 * x2)\n",
    "\ttmpVar = tauDash * tauDash + ((2 * tauDash * tauDashDash * x2) / (2 * R)) + (tauDashDash * tauDashDash)\n",
    "\ttau = np.sqrt(tmpVar)\n",
    "\tsigma = (6 * P * L) / (x4 * x3 * x3)\n",
    "\ttmpVar = 4.013 * E * np.sqrt((x3 * x3 * x4 * x4 * x4 * x4 * x4 * x4) / 36.0) / (L * L)\n",
    "\ttmpVar2 = (x3 / (2 * L)) * np.sqrt(E / (4 * G))\n",
    "\tPC = tmpVar * (1 - tmpVar2)\n",
    "\n",
    "\tg[0] = tauMax - tau\n",
    "\tg[1] = sigmaMax - sigma\n",
    "\tg[2] = x4 - x1\n",
    "\tg[3] = PC - P\n",
    "\tg = np.where(g < 0, -g, 0)                \n",
    "\tf[2] = g[0] + g[1] + g[2] + g[3]\n",
    "\n",
    "\tobj = f[0]\n",
    "\tmax_f = 326.7815857813289\n",
    "\tmin_f = 0.033217020294840964\n",
    "\treturn norm_add_noise(obj, max_f, min_f)\n",
    "\n",
    "def RE32_2(x):\n",
    "\tproblem_name = 'RE32'\n",
    "\tn_objectives = 3\n",
    "\tn_variables = 4\n",
    "\tn_constraints = 0\n",
    "\tn_original_constraints = 4\n",
    "\tubound = np.zeros(n_variables)\n",
    "\tlbound = np.zeros(n_variables)\n",
    "\tlbound[0] = 0.125\n",
    "\tlbound[1] = 0.1\n",
    "\tlbound[2] = 0.1\n",
    "\tlbound[3] = 0.125\n",
    "\tubound[0] = 5.0\n",
    "\tubound[1] = 10.0\n",
    "\tubound[2] = 10.0\n",
    "\tubound[3] = 5.0\n",
    "\tx = x*(ubound - lbound) + lbound\n",
    "\tf = np.zeros(n_objectives)\n",
    "\tg = np.zeros(n_original_constraints)\n",
    "\n",
    "\tx1 = x[0]\n",
    "\tx2 = x[1]\n",
    "\tx3 = x[2]\n",
    "\tx4 = x[3]\n",
    "\n",
    "\tP = 6000\n",
    "\tL = 14\n",
    "\tE = 30 * 1e6\n",
    "\n",
    "\t# // deltaMax = 0.25\n",
    "\tG = 12 * 1e6\n",
    "\ttauMax = 13600\n",
    "\tsigmaMax = 30000\n",
    "\n",
    "\t# First original objective function\n",
    "\tf[0] = (1.10471 * x1 * x1 * x2) + (0.04811 * x3 * x4) * (14.0 + x2)\n",
    "\t# Second original objective function\n",
    "\tf[1] = (4 * P * L * L * L) / (E * x4 * x3 * x3 * x3)\n",
    "\n",
    "\t# Constraint functions\n",
    "\tM = P * (L + (x2 / 2))\n",
    "\ttmpVar = ((x2 * x2) / 4.0) + np.power((x1 + x3) / 2.0, 2)\n",
    "\tR = np.sqrt(tmpVar)\n",
    "\ttmpVar = ((x2 * x2) / 12.0) + np.power((x1 + x3) / 2.0, 2)\n",
    "\tJ = 2 * np.sqrt(2) * x1 * x2 * tmpVar\n",
    "\n",
    "\ttauDashDash = (M * R) / J    \n",
    "\ttauDash = P / (np.sqrt(2) * x1 * x2)\n",
    "\ttmpVar = tauDash * tauDash + ((2 * tauDash * tauDashDash * x2) / (2 * R)) + (tauDashDash * tauDashDash)\n",
    "\ttau = np.sqrt(tmpVar)\n",
    "\tsigma = (6 * P * L) / (x4 * x3 * x3)\n",
    "\ttmpVar = 4.013 * E * np.sqrt((x3 * x3 * x4 * x4 * x4 * x4 * x4 * x4) / 36.0) / (L * L)\n",
    "\ttmpVar2 = (x3 / (2 * L)) * np.sqrt(E / (4 * G))\n",
    "\tPC = tmpVar * (1 - tmpVar2)\n",
    "\n",
    "\tg[0] = tauMax - tau\n",
    "\tg[1] = sigmaMax - sigma\n",
    "\tg[2] = x4 - x1\n",
    "\tg[3] = PC - P\n",
    "\tg = np.where(g < 0, -g, 0)                \n",
    "\tf[2] = g[0] + g[1] + g[2] + g[3]\n",
    "\n",
    "\tmax_f = 16722.394750186457\n",
    "\tmin_f = 0.0004393632694982018\n",
    "\tobj = f[1]\n",
    "\treturn norm_add_noise(obj, max_f, min_f)\n",
    "\n",
    "def RE32_3(x):\n",
    "\tproblem_name = 'RE32'\n",
    "\tn_objectives = 3\n",
    "\tn_variables = 4\n",
    "\tn_constraints = 0\n",
    "\tn_original_constraints = 4\n",
    "\tubound = np.zeros(n_variables)\n",
    "\tlbound = np.zeros(n_variables)\n",
    "\tlbound[0] = 0.125\n",
    "\tlbound[1] = 0.1\n",
    "\tlbound[2] = 0.1\n",
    "\tlbound[3] = 0.125\n",
    "\tubound[0] = 5.0\n",
    "\tubound[1] = 10.0\n",
    "\tubound[2] = 10.0\n",
    "\tubound[3] = 5.0\n",
    "\tx = x*(ubound - lbound) + lbound\n",
    "\tf = np.zeros(n_objectives)\n",
    "\tg = np.zeros(n_original_constraints)\n",
    "\n",
    "\tx1 = x[0]\n",
    "\tx2 = x[1]\n",
    "\tx3 = x[2]\n",
    "\tx4 = x[3]\n",
    "\n",
    "\tP = 6000\n",
    "\tL = 14\n",
    "\tE = 30 * 1e6\n",
    "\n",
    "\t# // deltaMax = 0.25\n",
    "\tG = 12 * 1e6\n",
    "\ttauMax = 13600\n",
    "\tsigmaMax = 30000\n",
    "\n",
    "\t# First original objective function\n",
    "\tf[0] = (1.10471 * x1 * x1 * x2) + (0.04811 * x3 * x4) * (14.0 + x2)\n",
    "\t# Second original objective function\n",
    "\tf[1] = (4 * P * L * L * L) / (E * x4 * x3 * x3 * x3)\n",
    "\n",
    "\t# Constraint functions\n",
    "\tM = P * (L + (x2 / 2))\n",
    "\ttmpVar = ((x2 * x2) / 4.0) + np.power((x1 + x3) / 2.0, 2)\n",
    "\tR = np.sqrt(tmpVar)\n",
    "\ttmpVar = ((x2 * x2) / 12.0) + np.power((x1 + x3) / 2.0, 2)\n",
    "\tJ = 2 * np.sqrt(2) * x1 * x2 * tmpVar\n",
    "\n",
    "\ttauDashDash = (M * R) / J    \n",
    "\ttauDash = P / (np.sqrt(2) * x1 * x2)\n",
    "\ttmpVar = tauDash * tauDash + ((2 * tauDash * tauDashDash * x2) / (2 * R)) + (tauDashDash * tauDashDash)\n",
    "\ttau = np.sqrt(tmpVar)\n",
    "\tsigma = (6 * P * L) / (x4 * x3 * x3)\n",
    "\ttmpVar = 4.013 * E * np.sqrt((x3 * x3 * x4 * x4 * x4 * x4 * x4 * x4) / 36.0) / (L * L)\n",
    "\ttmpVar2 = (x3 / (2 * L)) * np.sqrt(E / (4 * G))\n",
    "\tPC = tmpVar * (1 - tmpVar2)\n",
    "\n",
    "\tg[0] = tauMax - tau\n",
    "\tg[1] = sigmaMax - sigma\n",
    "\tg[2] = x4 - x1\n",
    "\tg[3] = PC - P\n",
    "\tg = np.where(g < 0, -g, 0)                \n",
    "\tf[2] = g[0] + g[1] + g[2] + g[3]\n",
    "\n",
    "\tmax_f = 387075726.8289943\n",
    "\tmin_f = 0.0\n",
    "\tobj = f[2]\n",
    "\treturn norm_add_noise(obj, max_f, min_f)\n",
    "\n",
    "def RE33_1(x):\n",
    "\tn_variables = 4\n",
    "\t\n",
    "\tubound = np.zeros(n_variables)\n",
    "\tlbound = np.zeros(n_variables)\n",
    "\tlbound[0] = 55\n",
    "\tlbound[1] = 75\n",
    "\tlbound[2] = 1000\n",
    "\tlbound[3] = 11\n",
    "\tubound[0] = 80\n",
    "\tubound[1] = 110\n",
    "\tubound[2] = 3000\n",
    "\tubound[3] = 20\n",
    "\tx = x*(ubound - lbound) + lbound\n",
    "\n",
    "\tx1 = x[0]\n",
    "\tx2 = x[1]\n",
    "\tx4 = x[3]\n",
    "\t\n",
    "\t# First original objective function\n",
    "\tobj = 4.9 * 1e-5 * (x2 * x2 - x1 * x1) * (x4 - 1.0)\n",
    "\tmax_f = 8.41203796456161\n",
    "\tmin_f = -0.7148953804344631\n",
    "\treturn norm_add_noise(obj, max_f, min_f)\n",
    "\n",
    "def RE33_2(x):\n",
    "\tn_variables = 4\n",
    "\t\n",
    "\tubound = np.zeros(n_variables)\n",
    "\tlbound = np.zeros(n_variables)\n",
    "\tlbound[0] = 55\n",
    "\tlbound[1] = 75\n",
    "\tlbound[2] = 1000\n",
    "\tlbound[3] = 11\n",
    "\tubound[0] = 80\n",
    "\tubound[1] = 110\n",
    "\tubound[2] = 3000\n",
    "\tubound[3] = 20\n",
    "\tx = x*(ubound - lbound) + lbound\n",
    "\n",
    "\tx1 = x[0]\n",
    "\tx2 = x[1]\n",
    "\tx3 = x[2]\n",
    "\tx4 = x[3]\n",
    "\t\n",
    "\t# Second original objective function\n",
    "\tobj = ((9.82 * 1e6) * (x2 * x2 - x1 * x1)) / (x3 * x4 * (x2 * x2 * x2 - x1 * x1 * x1))\n",
    "\tmax_f = 8.908419030653976\n",
    "\tmin_f = 1.1511506608115614\n",
    "\treturn norm_add_noise(obj, max_f, min_f)\n",
    "\n",
    "def RE33_3(x):\n",
    "\tn_variables = 4\n",
    "\tn_original_constraints = 4\n",
    "\t\n",
    "\tubound = np.zeros(n_variables)\n",
    "\tlbound = np.zeros(n_variables)\n",
    "\tlbound[0] = 55\n",
    "\tlbound[1] = 75\n",
    "\tlbound[2] = 1000\n",
    "\tlbound[3] = 11\n",
    "\tubound[0] = 80\n",
    "\tubound[1] = 110\n",
    "\tubound[2] = 3000\n",
    "\tubound[3] = 20\n",
    "\tx = x*(ubound - lbound) + lbound\n",
    "\tg = np.zeros(n_original_constraints)\n",
    "\n",
    "\tx1 = x[0]\n",
    "\tx2 = x[1]\n",
    "\tx3 = x[2]\n",
    "\tx4 = x[3]\n",
    "\n",
    "\t# Reformulated objective functions\n",
    "\tg[0] = (x2 - x1) - 20.0\n",
    "\tg[1] = 0.4 - (x3 / (3.14 * (x2 * x2 - x1 * x1)))\n",
    "\tg[2] = 1.0 - (2.22 * 1e-3 * x3 * (x2 * x2 * x2 - x1 * x1 * x1)) / np.power((x2 * x2 - x1 * x1), 2)\n",
    "\tg[3] = (2.66 * 1e-2 * x3 * x4 * (x2 * x2 * x2 - x1 * x1 * x1)) / (x2 * x2 - x1 * x1) - 900.0\n",
    "\tg = np.where(g < 0, -g, 0)\n",
    "\tobj = g[0] + g[1] + g[2] + g[3]\n",
    "\tmax_f = 789717.9711891257\n",
    "\tmin_f = 0.0\n",
    "\treturn norm_add_noise(obj, max_f, min_f)\n",
    "\n",
    "def RE34_1(x):\n",
    "\tproblem_name = 'RE34'\n",
    "\tn_objectives = 3\n",
    "\tn_variables = 5\n",
    "\tn_constraints = 0\n",
    "\tn_original_constraints = 0\n",
    "\tlbound = np.full(n_variables, 1)\n",
    "\tubound = np.full(n_variables, 3)\n",
    "\tf = np.zeros(n_objectives)\n",
    "\tg = np.zeros(n_original_constraints)\n",
    "\tx = x*(ubound - lbound) + lbound\n",
    "\n",
    "\tx1 = x[0]\n",
    "\tx2 = x[1]\n",
    "\tx3 = x[2]\n",
    "\tx4 = x[3]\n",
    "\tx5 = x[4]\n",
    "\n",
    "\tf[0] = 1640.2823 + (2.3573285 * x1) + (2.3220035 * x2) + (4.5688768 * x3) + (7.7213633 * x4) + (4.4559504 * x5)\n",
    "\tf[1] = 6.5856 + (1.15 * x1) - (1.0427 * x2) + (0.9738 * x3) + (0.8364 * x4) - (0.3695 * x1 * x4) + (0.0861 * x1 * x5) + (0.3628 * x2 * x4)  - (0.1106 * x1 * x1)  - (0.3437 * x3 * x3) + (0.1764 * x4 * x4)\n",
    "\tf[2] = -0.0551 + (0.0181 * x1) + (0.1024 * x2) + (0.0421 * x3) - (0.0073 * x1 * x2) + (0.024 * x2 * x3) - (0.0118 * x2 * x4) - (0.0204 * x3 * x4) - (0.008 * x3 * x5) - (0.0241 * x2 * x2) + (0.0109 * x4 * x4)\n",
    "\n",
    "\tmax_f = 1703.90664838227\n",
    "\tmin_f = 1662.6440306117302\n",
    "\tobj = f[0]\n",
    "\treturn norm_add_noise(obj, max_f, min_f)\n",
    "\n",
    "def RE34_2(x):\n",
    "\tproblem_name = 'RE34'\n",
    "\tn_objectives = 3\n",
    "\tn_variables = 5\n",
    "\tn_constraints = 0\n",
    "\tn_original_constraints = 0\n",
    "\tlbound = np.full(n_variables, 1)\n",
    "\tubound = np.full(n_variables, 3)\n",
    "\tf = np.zeros(n_objectives)\n",
    "\tg = np.zeros(n_original_constraints)\n",
    "\tx = x*(ubound - lbound) + lbound\n",
    "\n",
    "\tx1 = x[0]\n",
    "\tx2 = x[1]\n",
    "\tx3 = x[2]\n",
    "\tx4 = x[3]\n",
    "\tx5 = x[4]\n",
    "\n",
    "\tf[0] = 1640.2823 + (2.3573285 * x1) + (2.3220035 * x2) + (4.5688768 * x3) + (7.7213633 * x4) + (4.4559504 * x5)\n",
    "\tf[1] = 6.5856 + (1.15 * x1) - (1.0427 * x2) + (0.9738 * x3) + (0.8364 * x4) - (0.3695 * x1 * x4) + (0.0861 * x1 * x5) + (0.3628 * x2 * x4)  - (0.1106 * x1 * x1)  - (0.3437 * x3 * x3) + (0.1764 * x4 * x4)\n",
    "\tf[2] = -0.0551 + (0.0181 * x1) + (0.1024 * x2) + (0.0421 * x3) - (0.0073 * x1 * x2) + (0.024 * x2 * x3) - (0.0118 * x2 * x4) - (0.0204 * x3 * x4) - (0.008 * x3 * x5) - (0.0241 * x2 * x2) + (0.0109 * x4 * x4)\n",
    "\n",
    "\tmax_f = 11.696010139266333\n",
    "\tmin_f = 6.1900438549263015\n",
    "\tobj = f[1]\n",
    "\treturn norm_add_noise(obj, max_f, min_f)\n",
    "\t\n",
    "def RE34_3(x):\n",
    "\tproblem_name = 'RE34'\n",
    "\tn_objectives = 3\n",
    "\tn_variables = 5\n",
    "\tn_constraints = 0\n",
    "\tn_original_constraints = 0\n",
    "\tlbound = np.full(n_variables, 1)\n",
    "\tubound = np.full(n_variables, 3)\n",
    "\tf = np.zeros(n_objectives)\n",
    "\tg = np.zeros(n_original_constraints)\n",
    "\tx = x*(ubound - lbound) + lbound\n",
    "\tx1 = x[0]\n",
    "\tx2 = x[1]\n",
    "\tx3 = x[2]\n",
    "\tx4 = x[3]\n",
    "\tx5 = x[4]\n",
    "\n",
    "\tf[0] = 1640.2823 + (2.3573285 * x1) + (2.3220035 * x2) + (4.5688768 * x3) + (7.7213633 * x4) + (4.4559504 * x5)\n",
    "\tf[1] = 6.5856 + (1.15 * x1) - (1.0427 * x2) + (0.9738 * x3) + (0.8364 * x4) - (0.3695 * x1 * x4) + (0.0861 * x1 * x5) + (0.3628 * x2 * x4)  - (0.1106 * x1 * x1)  - (0.3437 * x3 * x3) + (0.1764 * x4 * x4)\n",
    "\tf[2] = -0.0551 + (0.0181 * x1) + (0.1024 * x2) + (0.0421 * x3) - (0.0073 * x1 * x2) + (0.024 * x2 * x3) - (0.0118 * x2 * x4) - (0.0204 * x3 * x4) - (0.008 * x3 * x5) - (0.0241 * x2 * x2) + (0.0109 * x4 * x4)\n",
    "\n",
    "\tmax_f = 0.2604266470749954\n",
    "\tmin_f = 0.04087807037352572\n",
    "\tobj = f[2]\n",
    "\treturn norm_add_noise(obj, max_f, min_f)\n",
    "\n",
    "def RE35_1(x):\n",
    "\tproblem_name = 'RE35'\n",
    "\tn_objectives = 3\n",
    "\tn_variables = 7\n",
    "\tn_constraints = 0\n",
    "\tn_original_constraints = 11\n",
    "\tlbound = np.zeros(n_variables)\n",
    "\tubound = np.zeros(n_variables)\n",
    "\tlbound[0] = 2.6\n",
    "\tlbound[1] = 0.7\n",
    "\tlbound[2] = 17\n",
    "\tlbound[3] = 7.3\n",
    "\tlbound[4] = 7.3\n",
    "\tlbound[5] = 2.9\n",
    "\tlbound[6] = 5.0    \n",
    "\tubound[0] = 3.6\n",
    "\tubound[1] = 0.8\n",
    "\tubound[2] = 28\n",
    "\tubound[3] = 8.3\n",
    "\tubound[4] = 8.3\n",
    "\tubound[5] = 3.9\n",
    "\tubound[6] = 5.5\n",
    "\tx = x*(ubound - lbound) + lbound\n",
    "\tf = np.zeros(n_objectives)\n",
    "\tg = np.zeros(n_original_constraints)\n",
    "\n",
    "\tx1 = x[0]\n",
    "\tx2 = x[1]\n",
    "\tx3 = np.round(x[2])\n",
    "\tx4 = x[3]\n",
    "\tx5 = x[4]\n",
    "\tx6 = x[5]\n",
    "\tx7 = x[6]\n",
    "\n",
    "\t# First original objective function (weight)\n",
    "\tf[0] = 0.7854 * x1 * (x2 * x2) * (((10.0 * x3 * x3) / 3.0) + (14.933 * x3) - 43.0934) - 1.508 * x1 * (x6 * x6 + x7 * x7) + 7.477 * (x6 * x6 * x6 + x7 * x7 * x7) + 0.7854 * (x4 * x6 * x6 + x5 * x7 * x7)\n",
    "\n",
    "\t# Second original objective function (stress)\n",
    "\ttmpVar = np.power((745.0 * x4) / (x2 * x3), 2.0)  + 1.69 * 1e7\n",
    "\tf[1] =  np.sqrt(tmpVar) / (0.1 * x6 * x6 * x6)\n",
    "\n",
    "\t# Constraint functions \t\n",
    "\tg[0] = -(1.0 / (x1 * x2 * x2 * x3)) + 1.0 / 27.0\n",
    "\tg[1] = -(1.0 / (x1 * x2 * x2 * x3 * x3)) + 1.0 / 397.5\n",
    "\tg[2] = -(x4 * x4 * x4) / (x2 * x3 * x6 * x6 * x6 * x6) + 1.0 / 1.93\n",
    "\tg[3] = -(x5 * x5 * x5) / (x2 * x3 * x7 * x7 * x7 * x7) + 1.0 / 1.93\n",
    "\tg[4] = -(x2 * x3) + 40.0\n",
    "\tg[5] = -(x1 / x2) + 12.0\n",
    "\tg[6] = -5.0 + (x1 / x2)\n",
    "\tg[7] = -1.9 + x4 - 1.5 * x6\n",
    "\tg[8] = -1.9 + x5 - 1.1 * x7\n",
    "\tg[9] =  -f[1] + 1300.0\n",
    "\ttmpVar = np.power((745.0 * x5) / (x2 * x3), 2.0) + 1.575 * 1e8\n",
    "\tg[10] = -np.sqrt(tmpVar) / (0.1 * x7 * x7 * x7) + 1100.0\t\n",
    "\tg = np.where(g < 0, -g, 0)                \n",
    "\tf[2] = g[0] + g[1] + g[2] + g[3] + g[4] + g[5] + g[6] + g[7] + g[8] + g[9] + g[10]\n",
    "\n",
    "\tmax_f = 7085.019631840887\n",
    "\tmin_f = 2390.015417718049\n",
    "\tobj = f[0]\n",
    "\treturn norm_add_noise(obj, max_f, min_f)\n",
    "\n",
    "def RE35_2(x):\n",
    "\tproblem_name = 'RE35'\n",
    "\tn_objectives = 3\n",
    "\tn_variables = 7\n",
    "\tn_constraints = 0\n",
    "\tn_original_constraints = 11\n",
    "\tlbound = np.zeros(n_variables)\n",
    "\tubound = np.zeros(n_variables)\n",
    "\tlbound[0] = 2.6\n",
    "\tlbound[1] = 0.7\n",
    "\tlbound[2] = 17\n",
    "\tlbound[3] = 7.3\n",
    "\tlbound[4] = 7.3\n",
    "\tlbound[5] = 2.9\n",
    "\tlbound[6] = 5.0    \n",
    "\tubound[0] = 3.6\n",
    "\tubound[1] = 0.8\n",
    "\tubound[2] = 28\n",
    "\tubound[3] = 8.3\n",
    "\tubound[4] = 8.3\n",
    "\tubound[5] = 3.9\n",
    "\tubound[6] = 5.5\n",
    "\tx = x*(ubound - lbound) + lbound\n",
    "\tf = np.zeros(n_objectives)\n",
    "\tg = np.zeros(n_original_constraints)\n",
    "\n",
    "\tx1 = x[0]\n",
    "\tx2 = x[1]\n",
    "\tx3 = np.round(x[2])\n",
    "\tx4 = x[3]\n",
    "\tx5 = x[4]\n",
    "\tx6 = x[5]\n",
    "\tx7 = x[6]\n",
    "\n",
    "\t# First original objective function (weight)\n",
    "\tf[0] = 0.7854 * x1 * (x2 * x2) * (((10.0 * x3 * x3) / 3.0) + (14.933 * x3) - 43.0934) - 1.508 * x1 * (x6 * x6 + x7 * x7) + 7.477 * (x6 * x6 * x6 + x7 * x7 * x7) + 0.7854 * (x4 * x6 * x6 + x5 * x7 * x7)\n",
    "\n",
    "\t# Second original objective function (stress)\n",
    "\ttmpVar = np.power((745.0 * x4) / (x2 * x3), 2.0)  + 1.69 * 1e7\n",
    "\tf[1] =  np.sqrt(tmpVar) / (0.1 * x6 * x6 * x6)\n",
    "\n",
    "\t# Constraint functions \t\n",
    "\tg[0] = -(1.0 / (x1 * x2 * x2 * x3)) + 1.0 / 27.0\n",
    "\tg[1] = -(1.0 / (x1 * x2 * x2 * x3 * x3)) + 1.0 / 397.5\n",
    "\tg[2] = -(x4 * x4 * x4) / (x2 * x3 * x6 * x6 * x6 * x6) + 1.0 / 1.93\n",
    "\tg[3] = -(x5 * x5 * x5) / (x2 * x3 * x7 * x7 * x7 * x7) + 1.0 / 1.93\n",
    "\tg[4] = -(x2 * x3) + 40.0\n",
    "\tg[5] = -(x1 / x2) + 12.0\n",
    "\tg[6] = -5.0 + (x1 / x2)\n",
    "\tg[7] = -1.9 + x4 - 1.5 * x6\n",
    "\tg[8] = -1.9 + x5 - 1.1 * x7\n",
    "\tg[9] =  -f[1] + 1300.0\n",
    "\ttmpVar = np.power((745.0 * x5) / (x2 * x3), 2.0) + 1.575 * 1e8\n",
    "\tg[10] = -np.sqrt(tmpVar) / (0.1 * x7 * x7 * x7) + 1100.0\t\n",
    "\tg = np.where(g < 0, -g, 0)                \n",
    "\tf[2] = g[0] + g[1] + g[2] + g[3] + g[4] + g[5] + g[6] + g[7] + g[8] + g[9] + g[10]\n",
    "\n",
    "\tmax_f = 1698.401419092365\n",
    "\tmin_f = 694.3152735996322\n",
    "\tobj = f[1]\n",
    "\treturn norm_add_noise(obj, max_f, min_f)\n",
    "\n",
    "def RE35_3(x):\n",
    "\tproblem_name = 'RE35'\n",
    "\tn_objectives = 3\n",
    "\tn_variables = 7\n",
    "\tn_constraints = 0\n",
    "\tn_original_constraints = 11\n",
    "\tlbound = np.zeros(n_variables)\n",
    "\tubound = np.zeros(n_variables)\n",
    "\tlbound[0] = 2.6\n",
    "\tlbound[1] = 0.7\n",
    "\tlbound[2] = 17\n",
    "\tlbound[3] = 7.3\n",
    "\tlbound[4] = 7.3\n",
    "\tlbound[5] = 2.9\n",
    "\tlbound[6] = 5.0    \n",
    "\tubound[0] = 3.6\n",
    "\tubound[1] = 0.8\n",
    "\tubound[2] = 28\n",
    "\tubound[3] = 8.3\n",
    "\tubound[4] = 8.3\n",
    "\tubound[5] = 3.9\n",
    "\tubound[6] = 5.5\n",
    "\tx = x*(ubound - lbound) + lbound\n",
    "\tf = np.zeros(n_objectives)\n",
    "\tg = np.zeros(n_original_constraints)\n",
    "\n",
    "\tx1 = x[0]\n",
    "\tx2 = x[1]\n",
    "\tx3 = np.round(x[2])\n",
    "\tx4 = x[3]\n",
    "\tx5 = x[4]\n",
    "\tx6 = x[5]\n",
    "\tx7 = x[6]\n",
    "\n",
    "\t# First original objective function (weight)\n",
    "\tf[0] = 0.7854 * x1 * (x2 * x2) * (((10.0 * x3 * x3) / 3.0) + (14.933 * x3) - 43.0934) - 1.508 * x1 * (x6 * x6 + x7 * x7) + 7.477 * (x6 * x6 * x6 + x7 * x7 * x7) + 0.7854 * (x4 * x6 * x6 + x5 * x7 * x7)\n",
    "\n",
    "\t# Second original objective function (stress)\n",
    "\ttmpVar = np.power((745.0 * x4) / (x2 * x3), 2.0)  + 1.69 * 1e7\n",
    "\tf[1] =  np.sqrt(tmpVar) / (0.1 * x6 * x6 * x6)\n",
    "\n",
    "\t# Constraint functions \t\n",
    "\tg[0] = -(1.0 / (x1 * x2 * x2 * x3)) + 1.0 / 27.0\n",
    "\tg[1] = -(1.0 / (x1 * x2 * x2 * x3 * x3)) + 1.0 / 397.5\n",
    "\tg[2] = -(x4 * x4 * x4) / (x2 * x3 * x6 * x6 * x6 * x6) + 1.0 / 1.93\n",
    "\tg[3] = -(x5 * x5 * x5) / (x2 * x3 * x7 * x7 * x7 * x7) + 1.0 / 1.93\n",
    "\tg[4] = -(x2 * x3) + 40.0\n",
    "\tg[5] = -(x1 / x2) + 12.0\n",
    "\tg[6] = -5.0 + (x1 / x2)\n",
    "\tg[7] = -1.9 + x4 - 1.5 * x6\n",
    "\tg[8] = -1.9 + x5 - 1.1 * x7\n",
    "\tg[9] =  -f[1] + 1300.0\n",
    "\ttmpVar = np.power((745.0 * x5) / (x2 * x3), 2.0) + 1.575 * 1e8\n",
    "\tg[10] = -np.sqrt(tmpVar) / (0.1 * x7 * x7 * x7) + 1100.0\t\n",
    "\tg = np.where(g < 0, -g, 0)                \n",
    "\tf[2] = g[0] + g[1] + g[2] + g[3] + g[4] + g[5] + g[6] + g[7] + g[8] + g[9] + g[10]\n",
    "\n",
    "\tmax_f = 400\n",
    "\tmin_f = 0.0\n",
    "\tobj = f[2]\n",
    "\treturn norm_add_noise(obj, max_f, min_f)\n",
    "\n",
    "def RE36_1(x):\n",
    "\tproblem_name = 'RE36'\n",
    "\tn_objectives = 3\n",
    "\tn_variables = 4\n",
    "\tn_constraints = 0\n",
    "\tn_original_constraints = 1\n",
    "\n",
    "\tlbound = np.full(n_variables, 12)\n",
    "\tubound = np.full(n_variables, 60)\n",
    "\n",
    "\tf = np.zeros(n_objectives)\n",
    "\tg = np.zeros(n_original_constraints)\n",
    "\tx = x*(ubound - lbound) + lbound\n",
    "\n",
    "\t# all the four variables must be inverger values\n",
    "\tx1 = np.round(x[0])\n",
    "\tx2 = np.round(x[1])\n",
    "\tx3 = np.round(x[2])\n",
    "\tx4 = np.round(x[3])\n",
    "\n",
    "\t# First original objective function\n",
    "\tf[0] = np.abs(6.931 - ((x3 / x1) * (x4 / x2)))\n",
    "\t# Second original objective function (the maximum value among the four variables)\n",
    "\tl = [x1, x2, x3, x4]\n",
    "\tf[1] = max(l)\n",
    "\n",
    "\tg[0] = 0.5 - (f[0] / 6.931)    \n",
    "\tg = np.where(g < 0, -g, 0)                \n",
    "\tf[2] = g[0]\n",
    "\n",
    "\tmax_f = 17.242611111111113\n",
    "\tmin_f = 0.0\n",
    "\tobj = f[0]\n",
    "\treturn norm_add_noise(obj, max_f, min_f)\n",
    "\n",
    "def RE36_2(x):\n",
    "\tproblem_name = 'RE36'\n",
    "\tn_objectives = 3\n",
    "\tn_variables = 4\n",
    "\tn_constraints = 0\n",
    "\tn_original_constraints = 1\n",
    "\n",
    "\tlbound = np.full(n_variables, 12)\n",
    "\tubound = np.full(n_variables, 60)\n",
    "\n",
    "\tf = np.zeros(n_objectives)\n",
    "\tg = np.zeros(n_original_constraints)\n",
    "\tx = x*(ubound - lbound) + lbound\n",
    "\n",
    "\t# all the four variables must be inverger values\n",
    "\tx1 = np.round(x[0])\n",
    "\tx2 = np.round(x[1])\n",
    "\tx3 = np.round(x[2])\n",
    "\tx4 = np.round(x[3])\n",
    "\n",
    "\t# First original objective function\n",
    "\tf[0] = np.abs(6.931 - ((x3 / x1) * (x4 / x2)))\n",
    "\t# Second original objective function (the maximum value among the four variables)\n",
    "\tl = [x1, x2, x3, x4]\n",
    "\tf[1] = max(l)\n",
    "\n",
    "\tg[0] = 0.5 - (f[0] / 6.931)    \n",
    "\tg = np.where(g < 0, -g, 0)                \n",
    "\tf[2] = g[0]\n",
    "\n",
    "\tmax_f = 60.0\n",
    "\tmin_f = 13.0\n",
    "\tobj = f[1]\n",
    "\treturn norm_add_noise(obj, max_f, min_f)\n",
    "\n",
    "def RE36_3(x):\n",
    "\tproblem_name = 'RE36'\n",
    "\tn_objectives = 3\n",
    "\tn_variables = 4\n",
    "\tn_constraints = 0\n",
    "\tn_original_constraints = 1\n",
    "\n",
    "\tlbound = np.full(n_variables, 12)\n",
    "\tubound = np.full(n_variables, 60)\n",
    "\tx = x*(ubound - lbound) + lbound\n",
    "\tf = np.zeros(n_objectives)\n",
    "\tg = np.zeros(n_original_constraints)\n",
    "\n",
    "\t# all the four variables must be inverger values\n",
    "\tx1 = np.round(x[0])\n",
    "\tx2 = np.round(x[1])\n",
    "\tx3 = np.round(x[2])\n",
    "\tx4 = np.round(x[3])\n",
    "\n",
    "\t# First original objective function\n",
    "\tf[0] = np.abs(6.931 - ((x3 / x1) * (x4 / x2)))\n",
    "\t# Second original objective function (the maximum value among the four variables)\n",
    "\tl = [x1, x2, x3, x4]\n",
    "\tf[1] = max(l)\n",
    "\n",
    "\tg[0] = 0.5 - (f[0] / 6.931)    \n",
    "\tg = np.where(g < 0, -g, 0)                \n",
    "\tf[2] = g[0]\n",
    "\n",
    "\tmax_f = 2\n",
    "\tmin_f = 0.0\n",
    "\tobj = f[2]\n",
    "\treturn norm_add_noise(obj, max_f, min_f)\n",
    "\n",
    "def RE37_1(x):\n",
    "\tproblem_name = 'RE37'\n",
    "\tn_objectives = 3\n",
    "\tn_variables = 4\n",
    "\tn_constraints = 0\n",
    "\tn_original_constraints = 0\n",
    "\n",
    "\tlbound = np.full(n_variables, 0)\n",
    "\tubound = np.full(n_variables, 1)\n",
    "\n",
    "\tx = x*(ubound - lbound) + lbound\n",
    "\n",
    "\tf = np.zeros(n_objectives)\n",
    "\n",
    "\txAlpha = x[0]\n",
    "\txHA = x[1]\n",
    "\txOA = x[2]\n",
    "\txOPTT = x[3]\n",
    "\n",
    "\t# f1 (TF_max)\n",
    "\tf[0] = 0.692 + (0.477 * xAlpha) - (0.687 * xHA) - (0.080 * xOA) - (0.0650 * xOPTT) - (0.167 * xAlpha * xAlpha) - (0.0129 * xHA * xAlpha) + (0.0796 * xHA * xHA) - (0.0634 * xOA * xAlpha) - (0.0257 * xOA * xHA) + (0.0877 * xOA * xOA) - (0.0521 * xOPTT * xAlpha) + (0.00156 * xOPTT * xHA) + (0.00198 * xOPTT * xOA) + (0.0184 * xOPTT * xOPTT)\n",
    "\t# f2 (X_cc)\n",
    "\tf[1] = 0.153 - (0.322 * xAlpha) + (0.396 * xHA) + (0.424 * xOA) + (0.0226 * xOPTT) + (0.175 * xAlpha * xAlpha) + (0.0185 * xHA * xAlpha) - (0.0701 * xHA * xHA) - (0.251 * xOA * xAlpha) + (0.179 * xOA * xHA) + (0.0150 * xOA * xOA) + (0.0134 * xOPTT * xAlpha) + (0.0296 * xOPTT * xHA) + (0.0752 * xOPTT * xOA) + (0.0192 * xOPTT * xOPTT)\n",
    "\t# f3 (TT_max)\n",
    "\tf[2] = 0.370 - (0.205 * xAlpha) + (0.0307 * xHA) + (0.108 * xOA) + (1.019 * xOPTT) - (0.135 * xAlpha * xAlpha) + (0.0141 * xHA * xAlpha) + (0.0998 * xHA * xHA) + (0.208 * xOA * xAlpha) - (0.0301 * xOA * xHA) - (0.226 * xOA * xOA) + (0.353 * xOPTT * xAlpha) - (0.0497 * xOPTT * xOA) - (0.423 * xOPTT * xOPTT) + (0.202 * xHA * xAlpha * xAlpha) - (0.281 * xOA * xAlpha * xAlpha) - (0.342 * xHA * xHA * xAlpha) - (0.245 * xHA * xHA * xOA) + (0.281 * xOA * xOA * xHA) - (0.184 * xOPTT * xOPTT * xAlpha) - (0.281 * xHA * xAlpha * xOA)\n",
    "\n",
    "\tmax_f = 1.0\n",
    "\tmin_f = 0.0\n",
    "\tobj = f[0]\n",
    "\treturn norm_add_noise(obj, max_f, min_f)\n",
    "\t\n",
    "def RE37_2(x):\n",
    "\tproblem_name = 'RE37'\n",
    "\tn_objectives = 3\n",
    "\tn_variables = 4\n",
    "\tn_constraints = 0\n",
    "\tn_original_constraints = 0\n",
    "\n",
    "\tlbound = np.full(n_variables, 0)\n",
    "\tubound = np.full(n_variables, 1)\n",
    "\n",
    "\tx = x*(ubound - lbound) + lbound\n",
    "\n",
    "\tf = np.zeros(n_objectives)\n",
    "\n",
    "\txAlpha = x[0]\n",
    "\txHA = x[1]\n",
    "\txOA = x[2]\n",
    "\txOPTT = x[3]\n",
    "\n",
    "\t# f1 (TF_max)\n",
    "\tf[0] = 0.692 + (0.477 * xAlpha) - (0.687 * xHA) - (0.080 * xOA) - (0.0650 * xOPTT) - (0.167 * xAlpha * xAlpha) - (0.0129 * xHA * xAlpha) + (0.0796 * xHA * xHA) - (0.0634 * xOA * xAlpha) - (0.0257 * xOA * xHA) + (0.0877 * xOA * xOA) - (0.0521 * xOPTT * xAlpha) + (0.00156 * xOPTT * xHA) + (0.00198 * xOPTT * xOA) + (0.0184 * xOPTT * xOPTT)\n",
    "\t# f2 (X_cc)\n",
    "\tf[1] = 0.153 - (0.322 * xAlpha) + (0.396 * xHA) + (0.424 * xOA) + (0.0226 * xOPTT) + (0.175 * xAlpha * xAlpha) + (0.0185 * xHA * xAlpha) - (0.0701 * xHA * xHA) - (0.251 * xOA * xAlpha) + (0.179 * xOA * xHA) + (0.0150 * xOA * xOA) + (0.0134 * xOPTT * xAlpha) + (0.0296 * xOPTT * xHA) + (0.0752 * xOPTT * xOA) + (0.0192 * xOPTT * xOPTT)\n",
    "\t# f3 (TT_max)\n",
    "\tf[2] = 0.370 - (0.205 * xAlpha) + (0.0307 * xHA) + (0.108 * xOA) + (1.019 * xOPTT) - (0.135 * xAlpha * xAlpha) + (0.0141 * xHA * xAlpha) + (0.0998 * xHA * xHA) + (0.208 * xOA * xAlpha) - (0.0301 * xOA * xHA) - (0.226 * xOA * xOA) + (0.353 * xOPTT * xAlpha) - (0.0497 * xOPTT * xOA) - (0.423 * xOPTT * xOPTT) + (0.202 * xHA * xAlpha * xAlpha) - (0.281 * xOA * xAlpha * xAlpha) - (0.342 * xHA * xHA * xAlpha) - (0.245 * xHA * xHA * xOA) + (0.281 * xOA * xOA * xHA) - (0.184 * xOPTT * xOPTT * xAlpha) - (0.281 * xHA * xAlpha * xOA)\n",
    "\n",
    "\tmax_f = 1.2258253067704867\n",
    "\tmin_f = 0.0\n",
    "\tobj = f[1]\n",
    "\treturn norm_add_noise(obj, max_f, min_f)\n",
    "\t\n",
    "def RE37_3(x):\n",
    "\tproblem_name = 'RE37'\n",
    "\tn_objectives = 3\n",
    "\tn_variables = 4\n",
    "\tn_constraints = 0\n",
    "\tn_original_constraints = 0\n",
    "\n",
    "\tlbound = np.full(n_variables, 0)\n",
    "\tubound = np.full(n_variables, 1)\n",
    "\n",
    "\tx = x*(ubound - lbound) + lbound\n",
    "\n",
    "\tf = np.zeros(n_objectives)\n",
    "\n",
    "\txAlpha = x[0]\n",
    "\txHA = x[1]\n",
    "\txOA = x[2]\n",
    "\txOPTT = x[3]\n",
    "\n",
    "\t# f1 (TF_max)\n",
    "\tf[0] = 0.692 + (0.477 * xAlpha) - (0.687 * xHA) - (0.080 * xOA) - (0.0650 * xOPTT) - (0.167 * xAlpha * xAlpha) - (0.0129 * xHA * xAlpha) + (0.0796 * xHA * xHA) - (0.0634 * xOA * xAlpha) - (0.0257 * xOA * xHA) + (0.0877 * xOA * xOA) - (0.0521 * xOPTT * xAlpha) + (0.00156 * xOPTT * xHA) + (0.00198 * xOPTT * xOA) + (0.0184 * xOPTT * xOPTT)\n",
    "\t# f2 (X_cc)\n",
    "\tf[1] = 0.153 - (0.322 * xAlpha) + (0.396 * xHA) + (0.424 * xOA) + (0.0226 * xOPTT) + (0.175 * xAlpha * xAlpha) + (0.0185 * xHA * xAlpha) - (0.0701 * xHA * xHA) - (0.251 * xOA * xAlpha) + (0.179 * xOA * xHA) + (0.0150 * xOA * xOA) + (0.0134 * xOPTT * xAlpha) + (0.0296 * xOPTT * xHA) + (0.0752 * xOPTT * xOA) + (0.0192 * xOPTT * xOPTT)\n",
    "\t# f3 (TT_max)\n",
    "\tf[2] = 0.370 - (0.205 * xAlpha) + (0.0307 * xHA) + (0.108 * xOA) + (1.019 * xOPTT) - (0.135 * xAlpha * xAlpha) + (0.0141 * xHA * xAlpha) + (0.0998 * xHA * xHA) + (0.208 * xOA * xAlpha) - (0.0301 * xOA * xHA) - (0.226 * xOA * xOA) + (0.353 * xOPTT * xAlpha) - (0.0497 * xOPTT * xOA) - (0.423 * xOPTT * xOPTT) + (0.202 * xHA * xAlpha * xAlpha) - (0.281 * xOA * xAlpha * xAlpha) - (0.342 * xHA * xHA * xAlpha) - (0.245 * xHA * xHA * xOA) + (0.281 * xOA * xOA * xHA) - (0.184 * xOPTT * xOPTT * xAlpha) - (0.281 * xHA * xAlpha * xOA)\n",
    "\n",
    "\tmax_f = 1.0850670780811584\n",
    "\tmin_f = -0.4081426955480145\n",
    "\tobj = f[2]\n",
    "\treturn norm_add_noise(obj, max_f, min_f)\n",
    "\n",
    "def RE21_1(x):\n",
    "\tproblem_name = 'RE21'\n",
    "\tn_objectives = 2\n",
    "\tn_variables = 4\n",
    "\tn_constraints = 0        \n",
    "\tn_original_constraints = 0\n",
    "\t\n",
    "\tF = 10.0\n",
    "\tsigma = 10.0\n",
    "\ttmp_val = F / sigma\n",
    "\n",
    "\tubound = np.full(n_variables, 3 * tmp_val)\n",
    "\tlbound = np.zeros(n_variables)\n",
    "\tlbound[0] = tmp_val\n",
    "\tlbound[1] = np.sqrt(2.0) * tmp_val\n",
    "\tlbound[2] = np.sqrt(2.0) * tmp_val\n",
    "\tlbound[3] = tmp_val\n",
    "\tx = x*(ubound - lbound) + lbound\n",
    "\tf = np.zeros(n_objectives)\n",
    "\tx1 = x[0]\n",
    "\tx2 = x[1]\n",
    "\tx3 = x[2]\n",
    "\tx4 = x[3]\n",
    "\n",
    "\tF = 10.0\n",
    "\tsigma = 10.0\n",
    "\tE = 2.0 * 1e5\n",
    "\tL = 200.0\n",
    "\n",
    "\tf[0] = L * ((2 * x1) + np.sqrt(2.0) * x2 + np.sqrt(x3) + x4)\n",
    "\tf[1] = ((F * L) / E) * ((2.0 / x1) + (2.0 * np.sqrt(2.0) / x2) - (2.0 * np.sqrt(2.0) / x3) + (2.0 / x4))\n",
    "\n",
    "\tmax_f = 2977.35881731081 \n",
    "\tmin_f = 1257.2744755078438\n",
    "\tobj = f[0]\n",
    "\treturn norm_add_noise(obj, max_f, min_f)\n",
    "\n",
    "def RE21_2(x):\n",
    "\tproblem_name = 'RE21'\n",
    "\tn_objectives = 2\n",
    "\tn_variables = 4\n",
    "\tn_constraints = 0        \n",
    "\tn_original_constraints = 0\n",
    "\t\n",
    "\tF = 10.0\n",
    "\tsigma = 10.0\n",
    "\ttmp_val = F / sigma\n",
    "\n",
    "\tubound = np.full(n_variables, 3 * tmp_val)\n",
    "\tlbound = np.zeros(n_variables)\n",
    "\tlbound[0] = tmp_val\n",
    "\tlbound[1] = np.sqrt(2.0) * tmp_val\n",
    "\tlbound[2] = np.sqrt(2.0) * tmp_val\n",
    "\tlbound[3] = tmp_val\n",
    "\tx = x*(ubound - lbound) + lbound\n",
    "\tf = np.zeros(n_objectives)\n",
    "\tx1 = x[0]\n",
    "\tx2 = x[1]\n",
    "\tx3 = x[2]\n",
    "\tx4 = x[3]\n",
    "\n",
    "\tF = 10.0\n",
    "\tsigma = 10.0\n",
    "\tE = 2.0 * 1e5\n",
    "\tL = 200.0\n",
    "\n",
    "\tf[0] = L * ((2 * x1) + np.sqrt(2.0) * x2 + np.sqrt(x3) + x4)\n",
    "\tf[1] = ((F * L) / E) * ((2.0 / x1) + (2.0 * np.sqrt(2.0) / x2) - (2.0 * np.sqrt(2.0) / x3) + (2.0 / x4))\n",
    "\t\n",
    "\tmax_f = 0.04997689402824656\n",
    "\tmin_f = 0.0029771351751672216\n",
    "\tobj = f[1]\n",
    "\treturn norm_add_noise(obj, max_f, min_f)\n",
    "\n",
    "def RE22_1(x):\n",
    "\tproblem_name = 'RE22'\n",
    "\tn_objectives = 2\n",
    "\tn_variables = 3\n",
    "\tn_constraints = 0\n",
    "\tn_original_constraints = 2\n",
    "\tubound = np.zeros(n_variables)\n",
    "\tlbound = np.zeros(n_variables)\n",
    "\tlbound[0] = 0.2\n",
    "\tlbound[1] = 0.0\n",
    "\tlbound[2] = 0.0\n",
    "\tubound[0] = 15\n",
    "\tubound[1] = 20\n",
    "\tubound[2] = 40\n",
    "\tx = x*(ubound - lbound) + lbound\n",
    "\tfeasible_vals = np.array([0.20, 0.31, 0.40, 0.44, 0.60, 0.62, 0.79, 0.80, 0.88, 0.93, 1.0, 1.20, 1.24, 1.32, 1.40, 1.55, 1.58, 1.60, 1.76, 1.80, 1.86, 2.0, 2.17, 2.20, 2.37, 2.40, 2.48, 2.60, 2.64, 2.79, 2.80, 3.0, 3.08, 3,10, 3.16, 3.41, 3.52, 3.60, 3.72, 3.95, 3.96, 4.0, 4.03, 4.20, 4.34, 4.40, 4.65, 4.74, 4.80, 4.84, 5.0, 5.28, 5.40, 5.53, 5.72, 6.0, 6.16, 6.32, 6.60, 7.11, 7.20, 7.80, 7.90, 8.0, 8.40, 8.69, 9.0, 9.48, 10.27, 11.0, 11.06, 11.85, 12.0, 13.0, 14.0, 15.0])\n",
    "\n",
    "\tf = np.zeros(n_objectives)\n",
    "\tg = np.zeros(n_original_constraints)\n",
    "\t#Reference: getNearestValue_sample2.py (https://gist.github.com/icchi-h/1d0bb1c52ebfdd31f14b3e811328390a)\n",
    "\tidx = np.abs(np.asarray(feasible_vals) - x[0]).argmin()\n",
    "\tx1 = feasible_vals[idx]\n",
    "\tx2 = x[1]\n",
    "\tx3 = x[2]\n",
    "\n",
    "\t#First original objective function\n",
    "\tf[0] = (29.4 * x1) + (0.6 * x2 * x3)\n",
    "\n",
    "\t# Original constraint functions \t\n",
    "\tg[0] = (x1 * x3) - 7.735 * ((x1 * x1) / x2) - 180.0\n",
    "\tg[1] = 4.0 - (x3 / x2)\n",
    "\tg = np.where(g < 0, -g, 0)          \n",
    "\tf[1] = g[0] + g[1]\n",
    "\t\n",
    "\tmax_f = 920.0528195769679\n",
    "\tmin_f = 5.885428538601677\n",
    "\tobj = f[0]\n",
    "\treturn norm_add_noise(obj, max_f, min_f)\n",
    "\n",
    "def RE22_2(x):\n",
    "\tproblem_name = 'RE22'\n",
    "\tn_objectives = 2\n",
    "\tn_variables = 3\n",
    "\tn_constraints = 0\n",
    "\tn_original_constraints = 2\n",
    "\tubound = np.zeros(n_variables)\n",
    "\tlbound = np.zeros(n_variables)\n",
    "\tlbound[0] = 0.2\n",
    "\tlbound[1] = 0.0\n",
    "\tlbound[2] = 0.0\n",
    "\tubound[0] = 15\n",
    "\tubound[1] = 20\n",
    "\tubound[2] = 40\n",
    "\tx = x*(ubound - lbound) + lbound\n",
    "\tfeasible_vals = np.array([0.20, 0.31, 0.40, 0.44, 0.60, 0.62, 0.79, 0.80, 0.88, 0.93, 1.0, 1.20, 1.24, 1.32, 1.40, 1.55, 1.58, 1.60, 1.76, 1.80, 1.86, 2.0, 2.17, 2.20, 2.37, 2.40, 2.48, 2.60, 2.64, 2.79, 2.80, 3.0, 3.08, 3,10, 3.16, 3.41, 3.52, 3.60, 3.72, 3.95, 3.96, 4.0, 4.03, 4.20, 4.34, 4.40, 4.65, 4.74, 4.80, 4.84, 5.0, 5.28, 5.40, 5.53, 5.72, 6.0, 6.16, 6.32, 6.60, 7.11, 7.20, 7.80, 7.90, 8.0, 8.40, 8.69, 9.0, 9.48, 10.27, 11.0, 11.06, 11.85, 12.0, 13.0, 14.0, 15.0])\n",
    "\n",
    "\tf = np.zeros(n_objectives)\n",
    "\tg = np.zeros(n_original_constraints)\n",
    "\t#Reference: getNearestValue_sample2.py (https://gist.github.com/icchi-h/1d0bb1c52ebfdd31f14b3e811328390a)\n",
    "\tidx = np.abs(np.asarray(feasible_vals) - x[0]).argmin()\n",
    "\tx1 = feasible_vals[idx]\n",
    "\tx2 = x[1]\n",
    "\tx3 = x[2]\n",
    "\n",
    "\t#First original objective function\n",
    "\tf[0] = (29.4 * x1) + (0.6 * x2 * x3)\n",
    "\n",
    "\t# Original constraint functions \t\n",
    "\tg[0] = (x1 * x3) - 7.735 * ((x1 * x1) / x2) - 180.0\n",
    "\tg[1] = 4.0 - (x3 / x2)\n",
    "\tg = np.where(g < 0, -g, 0)          \n",
    "\tf[1] = g[0] + g[1]\n",
    "\n",
    "\tmax_f = 340087855.0689778\n",
    "\tmin_f = 0\n",
    "\tobj = f[1]\n",
    "\treturn norm_add_noise(obj, max_f, min_f)\n",
    "\n",
    "def RE23_1(x):\n",
    "\tproblem_name = 'RE23'\n",
    "\tn_objectives = 2\n",
    "\tn_variables = 4\n",
    "\tn_constraints = 0\n",
    "\tn_original_constraints = 3\n",
    "\tubound = np.zeros(n_variables)\n",
    "\tlbound = np.zeros(n_variables)\n",
    "\tlbound[0] = 1\n",
    "\tlbound[1] = 1\n",
    "\tlbound[2] = 10\n",
    "\tlbound[3] = 10\n",
    "\tubound[0] = 100\n",
    "\tubound[1] = 100\n",
    "\tubound[2] = 200\n",
    "\tubound[3] = 240\n",
    "\tx = x*(ubound - lbound) + lbound\n",
    "\tf = np.zeros(n_objectives)\n",
    "\tg = np.zeros(n_original_constraints)\n",
    "\n",
    "\tx1 = 0.0625 * int(np.round(x[0]))\n",
    "\tx2 = 0.0625 * int(np.round(x[1]))        \n",
    "\tx3 = x[2]\n",
    "\tx4 = x[3]\n",
    "\n",
    "\t#First original objective function\n",
    "\tf[0] = (0.6224 * x1 * x3* x4) + (1.7781 * x2 * x3 * x3) + (3.1661 * x1 * x1 * x4) + (19.84 * x1 * x1 * x3)\n",
    "\n",
    "\t# Original constraint functions \t\n",
    "\tg[0] = x1 - (0.0193 * x3)\n",
    "\tg[1] = x2 - (0.00954 * x3)\n",
    "\tg[2] = (np.pi * x3 * x3 * x4) + ((4.0/3.0) * (np.pi * x3 * x3 * x3)) - 1296000\n",
    "\tg = np.where(g < 0, -g, 0)            \n",
    "\tf[1] = g[0] + g[1] + g[2]\n",
    "\n",
    "\tmax_f = 803948.4670560489\n",
    "\tmin_f = 46.10361249611967\n",
    "\tobj = f[0]\n",
    "\treturn norm_add_noise(obj, max_f, min_f)\n",
    "\n",
    "def RE23_2(x):\n",
    "\tproblem_name = 'RE23'\n",
    "\tn_objectives = 2\n",
    "\tn_variables = 4\n",
    "\tn_constraints = 0\n",
    "\tn_original_constraints = 3\n",
    "\tubound = np.zeros(n_variables)\n",
    "\tlbound = np.zeros(n_variables)\n",
    "\tlbound[0] = 1\n",
    "\tlbound[1] = 1\n",
    "\tlbound[2] = 10\n",
    "\tlbound[3] = 10\n",
    "\tubound[0] = 100\n",
    "\tubound[1] = 100\n",
    "\tubound[2] = 200\n",
    "\tubound[3] = 240\n",
    "\tx = x*(ubound - lbound) + lbound\n",
    "\tf = np.zeros(n_objectives)\n",
    "\tg = np.zeros(n_original_constraints)\n",
    "\n",
    "\tx1 = 0.0625 * int(np.round(x[0]))\n",
    "\tx2 = 0.0625 * int(np.round(x[1]))        \n",
    "\tx3 = x[2]\n",
    "\tx4 = x[3]\n",
    "\n",
    "\t#First original objective function\n",
    "\tf[0] = (0.6224 * x1 * x3* x4) + (1.7781 * x2 * x3 * x3) + (3.1661 * x1 * x1 * x4) + (19.84 * x1 * x1 * x3)\n",
    "\n",
    "\t# Original constraint functions \t\n",
    "\tg[0] = x1 - (0.0193 * x3)\n",
    "\tg[1] = x2 - (0.00954 * x3)\n",
    "\tg[2] = (np.pi * x3 * x3 * x4) + ((4.0/3.0) * (np.pi * x3 * x3 * x3)) - 1296000\n",
    "\tg = np.where(g < 0, -g, 0)            \n",
    "\tf[1] = g[0] + g[1] + g[2]\n",
    "\n",
    "\tmax_f = 1288593.9809127934\n",
    "\tmin_f = 0.0\n",
    "\tobj = f[1]\n",
    "\treturn norm_add_noise(obj, max_f, min_f)\n",
    "\n",
    "def RE24_1(x):\n",
    "\tproblem_name = 'RE24'\n",
    "\tn_objectives = 2\n",
    "\tn_variables = 2\n",
    "\tn_constraints = 0\n",
    "\tn_original_constraints = 4\n",
    "\tubound = np.zeros(n_variables)\n",
    "\tlbound = np.zeros(n_variables)\n",
    "\tlbound[0] = 0.5\n",
    "\tlbound[1] = 0.5\n",
    "\tubound[0] = 4\n",
    "\tubound[1] = 50\n",
    "\tx = x*(ubound - lbound) + lbound\n",
    "\tf = np.zeros(n_objectives)\n",
    "\tg = np.zeros(n_original_constraints)\n",
    "\n",
    "\tx1 = x[0]\n",
    "\tx2 = x[1]\n",
    "\n",
    "\t#First original objective function\n",
    "\tf[0] = x1 + (120 * x2)\n",
    "\n",
    "\tE = 700000\n",
    "\tsigma_b_max = 700\n",
    "\ttau_max = 450\n",
    "\tdelta_max = 1.5\n",
    "\tsigma_k = (E * x1 * x1) / 100\n",
    "\tsigma_b = 4500 / (x1 * x2)\n",
    "\ttau = 1800 / x2\n",
    "\tdelta = (56.2 * 10000) / (E * x1 * x2 * x2)\n",
    "\n",
    "\tg[0] = 1 - (sigma_b / sigma_b_max)\n",
    "\tg[1] = 1 - (tau / tau_max)\n",
    "\tg[2] = 1 - (delta / delta_max)\n",
    "\tg[3] = 1 - (sigma_b / sigma_k)\n",
    "\tg = np.where(g < 0, -g, 0)            \n",
    "\tf[1] = g[0] + g[1] + g[2] + g[3]\n",
    "\n",
    "\tmax_f = 6003.972054541111\n",
    "\tmin_f = 60.57111063599586\n",
    "\tobj = f[0]\n",
    "\treturn norm_add_noise(obj, max_f, min_f)\n",
    "\n",
    "def RE24_2(x):\n",
    "\tproblem_name = 'RE24'\n",
    "\tn_objectives = 2\n",
    "\tn_variables = 2\n",
    "\tn_constraints = 0\n",
    "\tn_original_constraints = 4\n",
    "\tubound = np.zeros(n_variables)\n",
    "\tlbound = np.zeros(n_variables)\n",
    "\tlbound[0] = 0.5\n",
    "\tlbound[1] = 0.5\n",
    "\tubound[0] = 4\n",
    "\tubound[1] = 50\n",
    "\tf = np.zeros(n_objectives)\n",
    "\tg = np.zeros(n_original_constraints)\n",
    "\n",
    "\tx1 = x[0]\n",
    "\tx2 = x[1]\n",
    "\n",
    "\t#First original objective function\n",
    "\tf[0] = x1 + (120 * x2)\n",
    "\n",
    "\tE = 700000\n",
    "\tsigma_b_max = 700\n",
    "\ttau_max = 450\n",
    "\tdelta_max = 1.5\n",
    "\tsigma_k = (E * x1 * x1) / 100\n",
    "\tsigma_b = 4500 / (x1 * x2)\n",
    "\ttau = 1800 / x2\n",
    "\tdelta = (56.2 * 10000) / (E * x1 * x2 * x2)\n",
    "\n",
    "\tg[0] = 1 - (sigma_b / sigma_b_max)\n",
    "\tg[1] = 1 - (tau / tau_max)\n",
    "\tg[2] = 1 - (delta / delta_max)\n",
    "\tg[3] = 1 - (sigma_b / sigma_k)\n",
    "\tg = np.where(g < 0, -g, 0)            \n",
    "\tf[1] = g[0] + g[1] + g[2] + g[3]\n",
    "\n",
    "\tmax_f = 5.7143730873791886e+20\n",
    "\tmin_f = 8.429085889432892\n",
    "\tobj = f[1]\n",
    "\treturn norm_add_noise(obj, max_f, min_f)\n",
    "\n",
    "def RE25_1(x):\n",
    "\t\n",
    "\tn_variables = 3\n",
    "\t\n",
    "\tubound = np.zeros(n_variables)\n",
    "\tlbound = np.zeros(n_variables)\n",
    "\tlbound[0] = 1\n",
    "\tlbound[1] = 0.6\n",
    "\tlbound[2] = 0.09\n",
    "\tubound[0] = 70\n",
    "\tubound[1] = 3\n",
    "\tubound[2] = 0.5\n",
    "\t\n",
    "\tfeasible_vals = np.array([0.009, 0.0095, 0.0104, 0.0118, 0.0128, 0.0132, 0.014, 0.015, 0.0162, 0.0173, 0.018, 0.02, 0.023, 0.025, 0.028, 0.032, 0.035, 0.041, 0.047, 0.054, 0.063, 0.072, 0.08, 0.092, 0.105, 0.12, 0.135, 0.148, 0.162, 0.177, 0.192, 0.207, 0.225, 0.244, 0.263, 0.283, 0.307, 0.331, 0.362, 0.394, 0.4375, 0.5])\n",
    "\n",
    "\tx = x*(ubound - lbound) + lbound\n",
    "\n",
    "\tx1 = np.round(x[0])\n",
    "\tx2 = x[1]\n",
    "\t#Reference: getNearestValue_sample2.py (https://gist.github.com/icchi-h/1d0bb1c52ebfdd31f14b3e811328390a)\n",
    "\tidx = np.abs(np.asarray(feasible_vals) - x[2]).argmin()\n",
    "\tx3 = feasible_vals[idx]\n",
    "\n",
    "\t# first original objective function\n",
    "\tobj = (np.pi * np.pi * x2 * x3 * x3 * (x1 + 2)) / 4.0\n",
    " \n",
    "\tmax_f = 133.22668584938896\n",
    "\tmin_f = 0.03776961289196103\n",
    "\treturn norm_add_noise(obj, max_f, min_f)\n",
    "\t\n",
    "def RE25_2(x):\n",
    "\tn_objectives = 2\n",
    "\tn_variables = 3\n",
    "\tn_original_constraints = 6\n",
    "\t\n",
    "\tubound = np.zeros(n_variables)\n",
    "\tlbound = np.zeros(n_variables)\n",
    "\tlbound[0] = 1\n",
    "\tlbound[1] = 0.6\n",
    "\tlbound[2] = 0.09\n",
    "\tubound[0] = 70\n",
    "\tubound[1] = 3\n",
    "\tubound[2] = 0.5\n",
    "\tx = x*(ubound - lbound) + lbound\n",
    "\tfeasible_vals = np.array([0.009, 0.0095, 0.0104, 0.0118, 0.0128, 0.0132, 0.014, 0.015, 0.0162, 0.0173, 0.018, 0.02, 0.023, 0.025, 0.028, 0.032, 0.035, 0.041, 0.047, 0.054, 0.063, 0.072, 0.08, 0.092, 0.105, 0.12, 0.135, 0.148, 0.162, 0.177, 0.192, 0.207, 0.225, 0.244, 0.263, 0.283, 0.307, 0.331, 0.362, 0.394, 0.4375, 0.5])\n",
    "\tg = np.zeros(n_original_constraints)\n",
    "\n",
    "\tx1 = np.round(x[0])\n",
    "\tx2 = x[1]\n",
    "\t#Reference: getNearestValue_sample2.py (https://gist.github.com/icchi-h/1d0bb1c52ebfdd31f14b3e811328390a)\n",
    "\tidx = np.abs(np.asarray(feasible_vals) - x[2]).argmin()\n",
    "\tx3 = feasible_vals[idx]\n",
    "\t\n",
    "\t# constraint functions\n",
    "\tCf = ((4.0 * (x2 / x3) - 1) / (4.0 * (x2 / x3) - 4)) + (0.615 * x3 / x2)\n",
    "\tFmax = 1000.0\n",
    "\tS = 189000.0\n",
    "\tG = 11.5 * 1e+6\n",
    "\tK  = (G * x3 * x3 * x3 * x3) / (8 * x1 * x2 * x2 * x2)\n",
    "\tlmax = 14.0\n",
    "\tlf = (Fmax / K) + 1.05 *  (x1 + 2) * x3\n",
    "\tFp = 300.0\n",
    "\tsigmaP = Fp / K\n",
    "\tsigmaPM = 6\n",
    "\tsigmaW = 1.25\n",
    "\n",
    "\tg[0] = -((8 * Cf * Fmax * x2) / (np.pi * x3 * x3 * x3)) + S\n",
    "\tg[1] = -lf + lmax\n",
    "\tg[2] = -3 + (x2 / x3)\n",
    "\tg[3] = -sigmaP + sigmaPM\n",
    "\tg[4] = -sigmaP - ((Fmax - Fp) / K) - 1.05 * (x1 + 2) * x3 + lf\n",
    "\tg[5] = sigmaW- ((Fmax - Fp) / K)\n",
    "\n",
    "\tg = np.where(g < 0, -g, 0)            \n",
    "\tobj = g[0] + g[1] + g[2] + g[3] + g[4] + g[5]  \n",
    " \n",
    "\tmax_f = 10074688.939724587\n",
    "\tmin_f = 0.0\n",
    "\treturn norm_add_noise(obj, max_f, min_f)\n",
    "\n",
    "def domain(function_type, domain_num, seed):\n",
    "\tif (function_type == \"train\" or function_type == \"train_large\" or function_type == \"RBF_0.05\" or function_type == \"RBF_0.2\"  or function_type == \"RBF_0.3\" or function_type == \"matern52_0.05\" or function_type == \"matern52_0.2\" or function_type == \"matern52_0.3\"):\n",
    "\t\tX = sobol_seq.i4_sobol_generate(1, domain_num, seed)\n",
    "\telif (function_type == \"RE24\" or function_type == \"DR\" or function_type == \"BC\" or function_type == \"ARS\" or function_type == \"DRZ\" or function_type == \"Branin\" or function_type == \"Currin\" or function_type == \"AR\" or function_type == \"DR\" or function_type == \"ARa\" or function_type == \"BCD\" or function_type == \"ASR\"):\n",
    "\t\tX = sobol_seq.i4_sobol_generate(2, domain_num, seed)\n",
    "\telif (function_type == \"RE25\" or function_type == \"RE22\" or function_type == \"RE31\"):\n",
    "\t\tX = sobol_seq.i4_sobol_generate(3, domain_num, seed)\n",
    "\telif (function_type == \"RE33\" or function_type == \"RE21\" or function_type == \"RE23\" or function_type == \"RE32\" or function_type == \"RE36\" or function_type == \"RE37\" or function_type == \"YAHPO\"):\n",
    "\t\tX = sobol_seq.i4_sobol_generate(4, domain_num, seed)\n",
    "\telif (function_type == \"RE34\"):\n",
    "\t\tX = sobol_seq.i4_sobol_generate(5, domain_num, seed)\n",
    "\telif (function_type == \"RE35\"):\n",
    "\t\tX = sobol_seq.i4_sobol_generate(7, domain_num, seed)\n",
    "\treturn X\n",
    "\n",
    "\n",
    "import torch\n",
    "import random\n",
    "import numpy as np\n",
    "import sys, os\n",
    "import torch\n",
    "from botorch import fit_gpytorch_mll\n",
    "from botorch.models import SingleTaskGP, ModelListGP\n",
    "from gpytorch.constraints import GreaterThan\n",
    "from gpytorch.kernels import RBFKernel, ScaleKernel, MaternKernel\n",
    "from gpytorch.mlls import ExactMarginalLogLikelihood\n",
    "from botorch.models.transforms.outcome import Standardize\n",
    "from yahpo_gym import *\n",
    "from gpytorch.mlls import SumMarginalLogLikelihood\n",
    "    \n",
    "def optimization_function(f, x):\n",
    "    dim = np.shape(x)[1]\n",
    "    y = np.array([f(xx) for xx in x])\n",
    "    train_X = torch.tensor(x, dtype=float)\n",
    "    train_Y = torch.tensor(y, dtype=float)\n",
    "    gp = SingleTaskGP(train_X=train_X, train_Y=train_Y.unsqueeze(1), \n",
    "                                outcome_transform=Standardize(1))\n",
    "    torch.tensor([[0.001]*dim])\n",
    "    gp.covar_module.base_kernel.lengthscale = torch.tensor([[0.001]*dim]) # important step that make the learned ls be correct\n",
    "    # model.likelihood.noise_covar.register_constraint(\"raw_noise\", GreaterThan(1e-5))\n",
    "    mll = ExactMarginalLogLikelihood(likelihood=gp.likelihood, model=gp)\n",
    "    try:\n",
    "        fit_gpytorch_mll(mll)\n",
    "    except RuntimeError:\n",
    "        print(\"Something wrong\")\n",
    "    return list(gp.covar_module.base_kernel.lengthscale.detach().numpy().squeeze())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "RE21_1 [3.803722258485652, 5.374228213666235, 6.025312754743776, 5.528794804317436]\n",
      "RE21_2 [3.3095155184187006, 4.918713083497343, 5.067419704425443, 3.34007851301534]\n",
      "RE22_1 [3.608664369871488, 2.6126497127464767, 2.4039663374248716]\n",
      "RE22_2 [0.5785804144220766, 0.015867825479766763, 10.55302741416124]\n",
      "RE23_1 [4.122225232973132, 4.817929466403503, 2.118850175864754, 6.977704684655366]\n",
      "RE23_2 [10.425123483917059, 10.869433601061608, 0.09074410062298432, 0.5881600281686659]\n",
      "RE24_1 [3.5654943048587073, 3.5653157332215546]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/real/anaconda3/envs/bo/lib/python3.9/site-packages/botorch/models/utils/assorted.py:202: InputDataWarning: Input data is not standardized (mean = tensor([1.2622e-32], dtype=torch.float64), std = tensor([1.1145e-14], dtype=torch.float64)). Please consider scaling the input to zero mean and unit variance.\n",
      "  warnings.warn(msg, InputDataWarning)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "RE24_2 [0.0010919092771883466, 0.00109190927707247]\n",
      "RE25_1 [4.470804455448665, 3.961010168812714, 0.12048732474341543]\n",
      "RE25_2 [5.224378109973743, 2.502961393590481, 0.2984352779739605]\n",
      "RE31_1 [4.2089474135408365, 4.201065221954299, 4.200656582106832]\n",
      "RE31_2 [0.02195962318566807, 19.780389409121224, 5.504329936667641]\n",
      "RE31_3 [4.208947418704599, 4.201065227061116, 4.20065658717857]\n",
      "RE32_1 [3.1247732503449233, 5.015199705183447, 8.349677430066079, 8.36452511770429]\n",
      "RE32_2 [18.591385240214237, 10.957533852609469, 0.04095842656505128, 1.6587118917369543]\n",
      "RE32_3 [19.239260677128303, 15.077850615899044, 0.07076275625074903, 1.109776752360057]\n",
      "RE33_1 [5.20475761317857, 4.694354140980532, 5.404591328251455, 4.903970767934206]\n",
      "RE33_2 [7.086579091961371, 7.004084804020621, 2.472594443982033, 6.212144213752191]\n",
      "RE33_3 [0.32777215192249776, 0.09090844463579181, 1.2394885530125332, 2.6927242892120846]\n",
      "RE34_1 [7.235940329948041, 7.262771512942976, 6.641527441327613, 5.174757305271093, 6.720647843780357]\n",
      "RE34_2 [5.764238688285515, 6.106212115083782, 3.704405513576522, 2.7199605891461363, 7.005837182633211]\n",
      "RE34_3 [7.931191447563538, 2.994072816658113, 4.3307416184259475, 4.565356636651643, 7.851665661345994]\n",
      "RE35_1 [2.392152212944576, 2.6125407681563257, 0.9107941100560183, 2.4691777917093543, 3.8258736573211656, 2.2215775482399027, 3.5778035683484437]\n",
      "RE35_2 [6.615963919787311, 6.60388773244275, 6.612403386176171, 6.62149564301235, 6.6118735778871125, 0.7458584451507319, 6.616391053573797]\n",
      "RE35_3 [8.094552332284318, 8.036434156103445, 7.8252575412267875, 8.01850655967469, 8.027031665413904, 0.14805068007318284, 8.052223895604318]\n",
      "RE36_1 [0.5948346466424413, 0.6024491240860617, 1.3671467792285528, 0.961451786504103]\n",
      "RE36_2 [0.6357172256643281, 0.660310643626246, 0.6231943912047118, 0.6183437833044475]\n",
      "RE36_3 [0.951523555102253, 0.7852109616805245, 1.2274158894957186, 0.8547764845214822]\n",
      "RE37_1 [4.799539862895141, 4.832471686630555, 5.1104207720335095, 5.20329524330567]\n",
      "RE37_2 [4.801657799846086, 5.027262909053975, 4.898586784538537, 5.285738391435452]\n",
      "RE37_3 [4.185088621143237, 4.028837107371882, 4.669157143722919, 4.529845076599971]\n"
     ]
    },
    {
     "ename": "UnboundLocalError",
     "evalue": "local variable 'X' referenced before assignment",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mUnboundLocalError\u001b[0m                         Traceback (most recent call last)",
      "Cell \u001b[0;32mIn[11], line 16\u001b[0m\n\u001b[1;32m      2\u001b[0m \tdatasets \u001b[38;5;241m=\u001b[39m [RE21_1, RE21_2, \n\u001b[1;32m      3\u001b[0m \t\t\t \tRE22_1, RE22_2, \n\u001b[1;32m      4\u001b[0m \t\t\t\tRE23_1, RE23_2,\n\u001b[0;32m   (...)\u001b[0m\n\u001b[1;32m     13\u001b[0m \t\t\t\tRE37_1, RE37_2, RE37_3,\n\u001b[1;32m     14\u001b[0m     \t\t\tAckley, Branin, Currin, Dixon, Rosen, Rastrigin, Sphere, Schwefel, Zakharov]\n\u001b[1;32m     15\u001b[0m \t\u001b[38;5;28;01mfor\u001b[39;00m d \u001b[38;5;129;01min\u001b[39;00m datasets:\n\u001b[0;32m---> 16\u001b[0m \t\tls \u001b[38;5;241m=\u001b[39m optimization_function(d, \u001b[43mdomain\u001b[49m\u001b[43m(\u001b[49m\u001b[43md\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[38;5;18;43m__name__\u001b[39;49m\u001b[43m[\u001b[49m\u001b[43m:\u001b[49m\u001b[38;5;241;43m-\u001b[39;49m\u001b[38;5;241;43m2\u001b[39;49m\u001b[43m]\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m1000\u001b[39;49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mseed\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43m \u001b[49m\u001b[38;5;241;43m0\u001b[39;49m\u001b[43m)\u001b[49m)\n\u001b[1;32m     17\u001b[0m \t\t\u001b[38;5;28mprint\u001b[39m(d\u001b[38;5;241m.\u001b[39m\u001b[38;5;18m__name__\u001b[39m, ls)\n",
      "Cell \u001b[0;32mIn[10], line 1635\u001b[0m, in \u001b[0;36mdomain\u001b[0;34m(function_type, domain_num, seed)\u001b[0m\n\u001b[1;32m   1633\u001b[0m \u001b[38;5;28;01melif\u001b[39;00m (function_type \u001b[38;5;241m==\u001b[39m \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mRE35\u001b[39m\u001b[38;5;124m\"\u001b[39m):\n\u001b[1;32m   1634\u001b[0m \tX \u001b[38;5;241m=\u001b[39m sobol_seq\u001b[38;5;241m.\u001b[39mi4_sobol_generate(\u001b[38;5;241m7\u001b[39m, domain_num, seed)\n\u001b[0;32m-> 1635\u001b[0m \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[43mX\u001b[49m\n",
      "\u001b[0;31mUnboundLocalError\u001b[0m: local variable 'X' referenced before assignment"
     ]
    }
   ],
   "source": [
    "if __name__ == '__main__':\n",
    "\tdatasets = [RE21_1, RE21_2, \n",
    "\t\t\t \tRE22_1, RE22_2, \n",
    "\t\t\t\tRE23_1, RE23_2,\n",
    "\t\t\t\tRE24_1, RE24_2,\t\n",
    "\t\t\t\tRE25_1, RE25_2,\n",
    "\t\t\t\tRE31_1, RE31_2, RE31_3, \n",
    "\t\t\t\tRE32_1, RE32_2, RE32_3,\n",
    "\t\t\t\tRE33_1, RE33_2, RE33_3,\n",
    "\t\t\t\tRE34_1, RE34_2, RE34_3,\n",
    "\t\t\t\tRE35_1, RE35_2, RE35_3,\n",
    "\t\t\t\tRE36_1, RE36_2, RE36_3,\n",
    "\t\t\t\tRE37_1, RE37_2, RE37_3,\n",
    "    \t\t\tAckley, Branin, Currin, Dixon, Rosen, Rastrigin, Sphere, Schwefel, Zakharov]\n",
    "\tfor d in datasets:\n",
    "\t\tls = optimization_function(d, domain(d.__name__[:-2], 1000, seed = 0))\n",
    "\t\tprint(d.__name__, ls)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Ackley [0.1067406142139499, 0.10490022738119344]\n",
      "Branin [1.2322024741645445, 3.473200049038078]\n",
      "Currin [0.9409959672834756, 1.6117729643698377]\n",
      "Dixon [8.127061999241256, 0.6611835034260138]\n",
      "Rosen [1.1737748968055879, 4.516103731528372]\n",
      "Rastrigin [0.06388384531435684, 0.06386143410111994]\n",
      "Sphere [2.949756542381238, 2.948504879565341]\n",
      "Schwefel [0.20099197734756447, 0.2008937879613179]\n",
      "Zakharov [2.9270276255879915, 1.6228369089285533]\n"
     ]
    }
   ],
   "source": [
    "datasets = [Ackley, Branin, Currin, Dixon, Rosen, Rastrigin, Sphere, Schwefel, Zakharov]\n",
    "for d in datasets:\n",
    "    ls = optimization_function(d, sobol_seq.i4_sobol_generate(2, 1000, 0))\n",
    "    print(d.__name__, ls)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "YAHPO_1 [0.6534693965138891, 1.7359597545943706, 1.31481387339792, 1.607972248667732]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/yhlin/anaconda3/envs/mobo/lib/python3.9/site-packages/botorch/models/utils/assorted.py:202: InputDataWarning: Input data is not standardized (mean = tensor([0.], dtype=torch.float64), std = tensor([0.], dtype=torch.float64)). Please consider scaling the input to zero mean and unit variance.\n",
      "  warnings.warn(msg, InputDataWarning)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "YAHPO_2 [0.001091649554797402, 0.001091649554797402, 0.001091649554797402, 0.001091649554797402]\n"
     ]
    }
   ],
   "source": [
    "datasets = [YAHPO_1, YAHPO_2]\n",
    "for d in datasets:\n",
    "    ls = optimization_function(d, domain(d.__name__[:-2], 1000, seed = 0))\n",
    "    print(d.__name__, ls)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([[0.5       , 0.5       , 0.5       , 0.5       ],\n",
       "       [0.75      , 0.25      , 0.75      , 0.25      ],\n",
       "       [0.25      , 0.75      , 0.25      , 0.75      ],\n",
       "       ...,\n",
       "       [0.65722656, 0.40917969, 0.73535156, 0.64550781],\n",
       "       [0.15722656, 0.90917969, 0.23535156, 0.14550781],\n",
       "       [0.21972656, 0.09667969, 0.54785156, 0.45800781]])"
      ]
     },
     "execution_count": 15,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "domain(d.__name__[:-2], 1000, seed = 0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "bo",
   "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.19"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
