{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "8012953a",
   "metadata": {},
   "outputs": [],
   "source": [
    "from xgboostlss.model import *\n",
    "from xgboostlss.distributions.Gaussian import *\n",
    "from xgboostlss.datasets.data_loader import load_simulated_gaussian_data\n",
    "from scipy.stats import norm\n",
    "from xgboostlss.distributions.Gamma import *\n",
    "from xgboostlss.distributions.Laplace import *\n",
    "from xgboostlss.distributions.Gumbel import *\n",
    "\n",
    "from xgboostlss.distributions.Mixture import *\n",
    "from xgboostlss.distributions.mixture_distribution_utils import MixtureDistributionClass\n",
    "\n",
    "import multiprocessing\n",
    "import plotnine\n",
    "from plotnine import *\n",
    "plotnine.options.figure_size = (12, 8)\n",
    "\n",
    "import pandas as pd \n",
    "import numpy as np\n",
    "\n",
    "\n",
    "import torch\n",
    "from torch import nn, optim\n",
    "from torch.autograd import Variable\n",
    "import torch.nn.functional as F\n",
    "import pandas as pd\n",
    "import time\n",
    "import math\n",
    "import matplotlib.pyplot as plt\n",
    "from torch.utils.data import Dataset, DataLoader\n",
    "from sklearn.preprocessing import StandardScaler\n",
    "import os\n",
    "from os import listdir\n",
    "from os.path import isfile, join\n",
    "import joblib\n",
    "\n",
    "import datetime"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "867dd867",
   "metadata": {},
   "outputs": [],
   "source": [
    "def read_data_cont(task_type, df):\n",
    "    \n",
    "    if task_type == 'XGBoost':\n",
    "        data_cont = df[['consumption','solar','DNI','DHI','temperature','relativehumidity']]    \n",
    "        \n",
    "    data_cont = data_cont.values\n",
    "    return data_cont\n",
    "\n",
    "def create_datasets_onechunk(configs, df, scaler):\n",
    "    \n",
    "    location = configs.location\n",
    "    gap = configs.gap\n",
    "    look_back = configs.look_back\n",
    "    pred_len = configs.pred_len\n",
    "    total_len = gap+look_back+pred_len\n",
    "    task_type = configs.task_type\n",
    "        \n",
    "    data_cont = read_data_cont(task_type, df)\n",
    "    df.rename(columns = {\"timeofday\": \"hour\"}, inplace = True)\n",
    "    data_time = df[['weekday','dayofyear', 'hour', 'month','year']]\n",
    "     \n",
    "    data_time = data_time.values\n",
    "\n",
    "    data_target = df[['total_grid']]\n",
    "    data_target = data_target.values\n",
    "    \n",
    "    data_cont = scaler.transform(data_cont)\n",
    "    \n",
    "    if location != \"TX\":\n",
    "        cycl_ = lambda x,period : torch.tensor((np.sin(x / period * 2 * np.pi),np.cos(x / period * 2 * np.pi))).type(torch.float32)\n",
    "        W = cycl_(data_time[:,0],7)    # week of day\n",
    "        H = cycl_(data_time[:,2],24)   # timeslot of the day\n",
    "        M = cycl_(data_time[:,3],12)   # month of year\n",
    "        data_time = np.concatenate((W,H,M),0).T\n",
    "        data_context = np.concatenate((data_cont,data_time),1)\n",
    "    else:\n",
    "        cycl_ = lambda x,period : torch.tensor((np.sin(x / period * 2 * np.pi),np.cos(x / period * 2 * np.pi))).type(torch.float32)\n",
    "        W = cycl_(data_time[:,0],7)    # week of day\n",
    "        D = cycl_(data_time[:,1],365)  # day of year\n",
    "        H = cycl_(data_time[:,2],24)   # timeslot of the day\n",
    "        M = cycl_(data_time[:,3],12)   # month of year\n",
    "        Y = torch.tensor(data_time[:,4] - 2022).unsqueeze(0) # year\n",
    "        data_time = np.concatenate((W,D,H,M,Y),0).T\n",
    "        data_context = np.concatenate((data_cont,data_time),1)\n",
    "    \n",
    "    def helper(x_train_hist, x_train_future, target):\n",
    "\n",
    "        x_train = []\n",
    "        y_train = []\n",
    "        \n",
    "        for k in range(24):\n",
    "            x_train_sub = []\n",
    "            y_train_sub= []\n",
    "            y_train_sub.extend(target[k])\n",
    "            x_train_sub.extend(x_train_future[k])\n",
    "            for d in range(14):\n",
    "                x_train_sub.extend(x_train_hist[d*24 + k,:6])\n",
    "\n",
    "            x_train.append(np.array(x_train_sub).reshape(1,-1))\n",
    "            y_train.append(np.array(y_train_sub))\n",
    "\n",
    "        x_train, y_train = np.concatenate(x_train), np.concatenate(y_train)\n",
    "        \n",
    "        return x_train, y_train\n",
    "\n",
    "    def Create_dataset(data_context,data_target):\n",
    "        x_train_total = []\n",
    "        y_train_total = []\n",
    "        \n",
    "        for i in range(1, len(data_context)-total_len, 24): \n",
    "            tempx = data_context[i:i+look_back,:]\n",
    "            tempy = data_context[i+look_back+gap:i+total_len,configs.masked:]\n",
    "            tempy_target = data_target[i+look_back+gap:i+total_len,0]\n",
    "            \n",
    "            tempx = np.array(tempx)\n",
    "            tempy = np.array(tempy)\n",
    "            tempy_target = np.array(tempy_target).reshape(-1,1)\n",
    "\n",
    "            x_train, y_train = helper(tempx, tempy, tempy_target)\n",
    "            x_train_total.append(x_train)\n",
    "            y_train_total.append(y_train)\n",
    "        \n",
    "        return np.concatenate(x_train_total), np.concatenate(y_train_total)\n",
    "\n",
    "    x_train, y_train = Create_dataset(data_context,data_target)\n",
    "    return x_train, y_train\n",
    "\n",
    "\n",
    "def create_datasets_location(df, configs):\n",
    "    location = configs.location\n",
    "    gap = configs.gap\n",
    "    look_back = configs.look_back\n",
    "    pred_len = configs.pred_len\n",
    "    total_len = gap+look_back+pred_len\n",
    "    task_type = configs.task_type\n",
    "    \n",
    "    data_conts = []\n",
    "    dfs = []\n",
    "\n",
    "    df['date'] = pd.to_datetime(df['year'].astype(str) + df['dayofyear'].astype(str), format='%Y%j')\n",
    "    df['weekday'] = df['date'].dt.weekday\n",
    "    \n",
    "    for i in set(df[\"train_group\"]):\n",
    "        df_sub = df[df[\"train_group\"] == i]\n",
    "        dfs.append(df_sub)\n",
    "        data_cont = read_data_cont(task_type, df_sub)\n",
    "        data_conts.append(data_cont)  \n",
    "\n",
    "    data_cont_cat = np.concatenate(data_conts, axis=0)\n",
    "    scaler = StandardScaler()\n",
    "    scaler.fit(data_cont_cat)\n",
    "    \n",
    "    os.makedirs(configs.path, exist_ok=True)\n",
    "    joblib.dump(scaler, configs.path+location+'_L='+str(look_back)+'_gap='+str(gap)+'_'+task_type+'_scaler.gz')\n",
    "\n",
    "    x_train, y_train = [], []\n",
    "\n",
    "    for df in dfs:\n",
    "        if df.shape[0] > total_len:\n",
    "            x_train_sub, y_train_sub= create_datasets_onechunk(configs, df, scaler)\n",
    "            \n",
    "            x_train.append(x_train_sub)\n",
    "            y_train.append(y_train_sub)\n",
    "\n",
    "\n",
    "    input_datas = np.concatenate(x_train, axis=0)\n",
    "    output_datas = np.concatenate(y_train, axis=0)\n",
    "\n",
    "    \n",
    "    return input_datas, output_datas"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "cd57c664",
   "metadata": {},
   "outputs": [],
   "source": [
    "def XGBoost_training(location, data_seed):\n",
    "\n",
    "    class ModelParams:\n",
    "        context_window = 336\n",
    "        target_window = 24\n",
    "        look_back = 336\n",
    "        pred_len = 24\n",
    "        gap = 24\n",
    "        masked = 1\n",
    "        location = location\n",
    "        task_type = \"XGBoost\"\n",
    "        path = f'models_and_scalers/{data_seed}/'\n",
    "    params = ModelParams  \n",
    "    \n",
    "    path = f\"../../../data/preprocess/Final/{data_seed}/\"\n",
    "    \n",
    "    \n",
    "    df = pd.read_csv(path + f\"{location}_{data_seed}.csv\")\n",
    "    df[\"localTime\"] = pd.to_datetime(df[\"localTime\"])\n",
    "    df[\"date\"] = df[\"localTime\"].dt.date\n",
    "    df_sub = df.groupby([\"year\", \"date\"], as_index = False).count()\n",
    "    exclude = list(df_sub[df_sub[\"localTime\"]!=72][\"date\"])\n",
    "    df = df[~df[\"date\"].isin(exclude)].reset_index()\n",
    "    x_train, y_train = create_datasets_location(df, params)\n",
    "    \n",
    "  \n",
    "    if location == \"GA\":\n",
    "        df2 = pd.read_csv(path + f\"{location}_{data_seed}_1.csv\")\n",
    "        df2[\"localTime\"] = pd.to_datetime(df2[\"localTime\"])\n",
    "        df2[\"date\"] = df2[\"localTime\"].dt.date\n",
    "        df_sub2 = df2.groupby([\"year\", \"date\"], as_index = False).count()\n",
    "        exclude = list(df_sub2[df_sub2[\"localTime\"]!=72][\"date\"])\n",
    "        df2 = df2[~df2[\"date\"].isin(exclude)].reset_index()\n",
    "        x_train2, y_train2 = create_datasets_location(df2, params)\n",
    "        \n",
    "        x_train = np.concatenate([x_train, x_train2])\n",
    "        y_train = np.concatenate([y_train, y_train2])\n",
    "        \n",
    "    \n",
    "    n_cpu = multiprocessing.cpu_count()\n",
    "    dtrain = xgb.DMatrix(x_train, label=y_train, nthread=n_cpu)\n",
    "    \n",
    "    if location == \"OR\":\n",
    "        xgblss = XGBoostLSS(\n",
    "        Gamma(stabilization=\"L2\",     # Options are \"None\", \"MAD\", \"L2\".\n",
    "              response_fn=\"exp\",      # Function to transform the concentration and rate parameters, e.g., \"exp\" or \"softplus\".\n",
    "              loss_fn=\"crps\"           # Loss function. Options are \"nll\" (negative log-likelihood) or \"crps\"(continuous ranked probability score).\n",
    "             )\n",
    "        )\n",
    "    elif location == \"GA\":\n",
    "        xgblss = XGBoostLSS(\n",
    "        Laplace(stabilization=\"L2\",     # Options are \"None\", \"MAD\", \"L2\".\n",
    "              response_fn=\"exp\",      # Function to transform the concentration and rate parameters, e.g., \"exp\" or \"softplus\".\n",
    "              loss_fn=\"crps\"           # Loss function. Options are \"nll\" (negative log-likelihood) or \"crps\"(continuous ranked probability score).\n",
    "             )\n",
    "        )\n",
    "    elif location == \"TX\":\n",
    "        xgblss = XGBoostLSS(\n",
    "        Gumbel(stabilization=\"L2\",     # Options are \"None\", \"MAD\", \"L2\".\n",
    "              response_fn=\"exp\",      # Function to transform the concentration and rate parameters, e.g., \"exp\" or \"softplus\".\n",
    "              loss_fn=\"crps\"           # Loss function. Options are \"nll\" (negative log-likelihood) or \"crps\"(continuous ranked probability score).\n",
    "             )\n",
    "        )\n",
    "    elif location == \"HI\":\n",
    "        # Specifies a mixture of Gaussians. See ?Mixture for an overview.\n",
    "        xgblss = XGBoostLSS(\n",
    "            Mixture(\n",
    "                Gaussian(response_fn=\"softplus\"), \n",
    "                M = 2,\n",
    "                tau=1.0,\n",
    "                hessian_mode=\"individual\",\n",
    "            )\n",
    "        )\n",
    "\n",
    "    \n",
    "    filename = f'opt_param_{location}.pkl'\n",
    "\n",
    "    if os.path.exists(filename):\n",
    "        with open(filename, 'rb') as f:\n",
    "            opt_param = pickle.load(f)\n",
    "    else:\n",
    "        param_dict = {\n",
    "        \"eta\":              [\"float\", {\"low\": 1e-5,   \"high\": 1,     \"log\": True}],\n",
    "        \"max_depth\":        [\"int\",   {\"low\": 1,      \"high\": 10,    \"log\": False}],\n",
    "        \"gamma\":            [\"float\", {\"low\": 1e-8,   \"high\": 40,    \"log\": True}],\n",
    "        \"subsample\":        [\"float\", {\"low\": 0.2,    \"high\": 1.0,   \"log\": False}],\n",
    "        \"colsample_bytree\": [\"float\", {\"low\": 0.2,    \"high\": 1.0,   \"log\": False}],\n",
    "        \"min_child_weight\": [\"float\", {\"low\": 1e-8,   \"high\": 500,   \"log\": True}],\n",
    "        \"booster\":          [\"categorical\", [\"gbtree\"]],\n",
    "        # \"tree_method\":    [\"categorical\", [\"auto\", \"approx\", \"hist\", \"gpu_hist\"]],\n",
    "        # \"gpu_id\":         [\"none\", [0]]\n",
    "        }\n",
    "\n",
    "        np.random.seed(42)\n",
    "        opt_param = xgblss.hyper_opt(param_dict,\n",
    "                                     dtrain,\n",
    "                                     num_boost_round=100,        # Number of boosting iterations.\n",
    "                                     nfold=5,                    # Number of cv-folds.\n",
    "                                     early_stopping_rounds=20,   # Number of early-stopping rounds\n",
    "                                     max_minutes=180,              # Time budget in minutes, i.e., stop study after the given number of minutes.\n",
    "                                     n_trials=60,              # The number of trials. If this argument is set to None, there is no limitation on the number of trials.\n",
    "                                     silence=False,              # Controls the verbosity of the trail, i.e., user can silence the outputs of the trail.\n",
    "                                     seed=42,                   # Seed used to generate cv-folds.\n",
    "                                     hp_seed=None                # Seed for random number generator used in the Bayesian hyperparameter search.\n",
    "                                    )\n",
    "            # Save the opt_param object to a file\n",
    "        with open(filename, 'wb') as f:\n",
    "            pickle.dump(opt_param, f)\n",
    "    \n",
    "    np.random.seed(42)\n",
    "\n",
    "    opt_params = opt_param.copy()\n",
    "    n_rounds = opt_params[\"opt_rounds\"]\n",
    "    del opt_params[\"opt_rounds\"]\n",
    "\n",
    "    # Train Model with optimized hyperparameters\n",
    "    xgblss.train(opt_params,\n",
    "                 dtrain,\n",
    "                 num_boost_round=n_rounds\n",
    "                 )\n",
    "    \n",
    "    model_filename = os.path.join(params.path, f'xgboost_{location}.pkl')\n",
    "    os.makedirs(params.path, exist_ok=True)\n",
    "    \n",
    "    # Save the trained model to a file\n",
    "    with open(model_filename, 'wb') as f:\n",
    "        pickle.dump(xgblss, f)\n",
    "        \n",
    "    return\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "debb4732",
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "[I 2024-09-02 12:38:56,963] A new study created in memory with name: XGBoostLSS Hyper-Parameter Optimization\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "2791dce8642e4153a8222e4396e727f4",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/60 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[I 2024-09-02 12:40:15,179] Trial 0 finished with value: 385.59325559999996 and parameters: {'eta': 1.3896563407704693e-05, 'max_depth': 7, 'gamma': 7.837345866699959e-08, 'subsample': 0.6706832045623994, 'colsample_bytree': 0.8842041149238351, 'min_child_weight': 1.183287555930955e-06, 'booster': 'gbtree'}. Best is trial 0 with value: 385.59325559999996.\n",
      "[I 2024-09-02 12:41:27,574] Trial 1 finished with value: 261.21787720000003 and parameters: {'eta': 0.0007961714216256999, 'max_depth': 6, 'gamma': 9.884063471978504e-08, 'subsample': 0.9600379251246738, 'colsample_bytree': 0.851830910126927, 'min_child_weight': 4.365217033097689, 'booster': 'gbtree'}. Best is trial 1 with value: 261.21787720000003.\n",
      "[I 2024-09-02 12:43:05,670] Trial 2 finished with value: 384.7566774 and parameters: {'eta': 1.7263328656290937e-05, 'max_depth': 9, 'gamma': 0.00027967637936485097, 'subsample': 0.7265910375524502, 'colsample_bytree': 0.9421678528467752, 'min_child_weight': 4.793684561108835e-08, 'booster': 'gbtree'}. Best is trial 1 with value: 261.21787720000003.\n",
      "[I 2024-09-02 12:43:49,603] Trial 3 finished with value: 160.4927826 and parameters: {'eta': 0.08174065637901244, 'max_depth': 2, 'gamma': 1.9848150683599374e-08, 'subsample': 0.27814009667090095, 'colsample_bytree': 0.5581157914267487, 'min_child_weight': 226.1613728126516, 'booster': 'gbtree'}. Best is trial 3 with value: 160.4927826.\n",
      "[I 2024-09-02 12:44:13,452] Trial 4 finished with value: 443.8268006 and parameters: {'eta': 0.28467843203598653, 'max_depth': 10, 'gamma': 0.013767083222939463, 'subsample': 0.7504388210010109, 'colsample_bytree': 0.9065658451816099, 'min_child_weight': 0.00030082195547492916, 'booster': 'gbtree'}. Best is trial 3 with value: 160.4927826.\n",
      "[I 2024-09-02 12:44:32,372] Trial 5 finished with value: 922.7161866 and parameters: {'eta': 0.5063442868615918, 'max_depth': 9, 'gamma': 6.106653221329199e-06, 'subsample': 0.21010907207472088, 'colsample_bytree': 0.777697736205069, 'min_child_weight': 0.00036615116225623194, 'booster': 'gbtree'}. Best is trial 3 with value: 160.4927826.\n",
      "[I 2024-09-02 12:45:37,913] Trial 6 finished with value: 362.64288339999996 and parameters: {'eta': 0.00024902674833021297, 'max_depth': 1, 'gamma': 1.6660659532391409, 'subsample': 0.9387929924805123, 'colsample_bytree': 0.3832655059278845, 'min_child_weight': 61.32175160148463, 'booster': 'gbtree'}. Best is trial 3 with value: 160.4927826.\n",
      "[I 2024-09-02 12:45:55,991] Trial 7 finished with value: 570.3746218 and parameters: {'eta': 0.3861140322243263, 'max_depth': 8, 'gamma': 1.1057969307351995e-08, 'subsample': 0.9685653611496043, 'colsample_bytree': 0.5814567350775395, 'min_child_weight': 126.9725659685673, 'booster': 'gbtree'}. Best is trial 3 with value: 160.4927826.\n",
      "[I 2024-09-02 12:47:01,955] Trial 8 finished with value: 246.6407532 and parameters: {'eta': 0.0017939930535297553, 'max_depth': 2, 'gamma': 0.0002241892011166063, 'subsample': 0.6928190304687083, 'colsample_bytree': 0.2574289037476325, 'min_child_weight': 7.5904973290843166e-06, 'booster': 'gbtree'}. Best is trial 3 with value: 160.4927826.\n",
      "[I 2024-09-02 12:47:27,228] Trial 9 finished with value: 165.6135406 and parameters: {'eta': 0.09221913628867029, 'max_depth': 4, 'gamma': 0.8823851077789793, 'subsample': 0.9729336467533278, 'colsample_bytree': 0.607947956757046, 'min_child_weight': 0.9623426850487019, 'booster': 'gbtree'}. Best is trial 3 with value: 160.4927826.\n",
      "[I 2024-09-02 12:48:33,765] Trial 10 finished with value: 121.37867879999999 and parameters: {'eta': 0.017350946213599196, 'max_depth': 4, 'gamma': 3.947832048431053e-06, 'subsample': 0.25287012036765916, 'colsample_bytree': 0.533474969385182, 'min_child_weight': 0.056235356785556904, 'booster': 'gbtree'}. Best is trial 10 with value: 121.37867879999999.\n",
      "[I 2024-09-02 12:49:58,567] Trial 11 finished with value: 128.84402319999998 and parameters: {'eta': 0.021228237533768516, 'max_depth': 4, 'gamma': 2.826048242910106e-06, 'subsample': 0.22767260157767255, 'colsample_bytree': 0.5195194899071366, 'min_child_weight': 0.043834865482233705, 'booster': 'gbtree'}. Best is trial 10 with value: 121.37867879999999.\n",
      "[I 2024-09-02 12:51:32,177] Trial 12 finished with value: 115.5883072 and parameters: {'eta': 0.016007440702566777, 'max_depth': 4, 'gamma': 2.7549549780157445e-06, 'subsample': 0.39367507520568157, 'colsample_bytree': 0.43242870576584, 'min_child_weight': 0.06838839109669571, 'booster': 'gbtree'}. Best is trial 12 with value: 115.5883072.\n",
      "[I 2024-09-02 12:53:06,342] Trial 13 finished with value: 115.7334458 and parameters: {'eta': 0.01648588182798818, 'max_depth': 4, 'gamma': 4.935602935067287e-06, 'subsample': 0.39720360050584214, 'colsample_bytree': 0.4084536963640356, 'min_child_weight': 0.0239442795487165, 'booster': 'gbtree'}. Best is trial 12 with value: 115.5883072.\n",
      "[I 2024-09-02 12:53:29,599] Trial 14 pruned. Trial was pruned at iteration 23.\n",
      "[I 2024-09-02 12:53:49,710] Trial 15 pruned. Trial was pruned at iteration 20.\n",
      "[I 2024-09-02 12:54:12,712] Trial 16 pruned. Trial was pruned at iteration 22.\n",
      "[I 2024-09-02 12:54:59,939] Trial 17 finished with value: 145.68524179999997 and parameters: {'eta': 0.04134854310752359, 'max_depth': 5, 'gamma': 0.011250711915606487, 'subsample': 0.3769355262536904, 'colsample_bytree': 0.7511037425289695, 'min_child_weight': 5.4223553711552364e-05, 'booster': 'gbtree'}. Best is trial 12 with value: 115.5883072.\n",
      "[I 2024-09-02 12:55:21,729] Trial 18 pruned. Trial was pruned at iteration 22.\n",
      "[I 2024-09-02 12:55:41,051] Trial 19 pruned. Trial was pruned at iteration 20.\n",
      "[I 2024-09-02 12:56:03,488] Trial 20 pruned. Trial was pruned at iteration 20.\n",
      "[I 2024-09-02 12:57:38,009] Trial 21 finished with value: 118.10540040000001 and parameters: {'eta': 0.017052505291702085, 'max_depth': 4, 'gamma': 9.632754221940299e-06, 'subsample': 0.3104257724280745, 'colsample_bytree': 0.6945153715581971, 'min_child_weight': 0.07034251002525835, 'booster': 'gbtree'}. Best is trial 12 with value: 115.5883072.\n",
      "[I 2024-09-02 12:57:58,322] Trial 22 pruned. Trial was pruned at iteration 20.\n",
      "[I 2024-09-02 12:59:04,661] Trial 23 finished with value: 119.79463639999999 and parameters: {'eta': 0.024582384385386357, 'max_depth': 5, 'gamma': 7.849429481001643e-07, 'subsample': 0.5163809884500572, 'colsample_bytree': 0.6902212306559987, 'min_child_weight': 0.0036405322927967393, 'booster': 'gbtree'}. Best is trial 12 with value: 115.5883072.\n",
      "[I 2024-09-02 12:59:19,135] Trial 24 pruned. Trial was pruned at iteration 20.\n",
      "[I 2024-09-02 12:59:33,303] Trial 25 pruned. Trial was pruned at iteration 20.\n",
      "[I 2024-09-02 13:00:17,297] Trial 26 pruned. Trial was pruned at iteration 65.\n",
      "[I 2024-09-02 13:00:32,635] Trial 27 finished with value: 254.43408520000003 and parameters: {'eta': 0.17926758169601156, 'max_depth': 6, 'gamma': 2.6010178271988717e-07, 'subsample': 0.29042102035208817, 'colsample_bytree': 0.7465081977831525, 'min_child_weight': 0.0006149313344578939, 'booster': 'gbtree'}. Best is trial 12 with value: 115.5883072.\n",
      "[I 2024-09-02 13:01:08,915] Trial 28 finished with value: 139.6823912 and parameters: {'eta': 0.03891932102788397, 'max_depth': 5, 'gamma': 3.236759452865678e-06, 'subsample': 0.4851072619809769, 'colsample_bytree': 0.4281768186924192, 'min_child_weight': 4.806906778290033e-05, 'booster': 'gbtree'}. Best is trial 12 with value: 115.5883072.\n",
      "[I 2024-09-02 13:02:24,058] Trial 29 finished with value: 109.4550688 and parameters: {'eta': 0.011889271674984684, 'max_depth': 7, 'gamma': 8.785502458625207e-08, 'subsample': 0.6284047886064339, 'colsample_bytree': 0.9921110555747016, 'min_child_weight': 8.151614483801891e-08, 'booster': 'gbtree'}. Best is trial 29 with value: 109.4550688.\n",
      "[I 2024-09-02 13:02:40,572] Trial 30 pruned. Trial was pruned at iteration 20.\n",
      "[I 2024-09-02 13:04:00,697] Trial 31 finished with value: 115.22631220000001 and parameters: {'eta': 0.011096523928444275, 'max_depth': 8, 'gamma': 7.484415513835055e-08, 'subsample': 0.6135333515968755, 'colsample_bytree': 0.9945892511058892, 'min_child_weight': 4.772497669932697e-07, 'booster': 'gbtree'}. Best is trial 29 with value: 109.4550688.\n",
      "[I 2024-09-02 13:04:19,966] Trial 32 pruned. Trial was pruned at iteration 20.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[I 2024-09-02 13:04:40,189] Trial 33 pruned. Trial was pruned at iteration 20.\n",
      "[I 2024-09-02 13:04:57,467] Trial 34 pruned. Trial was pruned at iteration 20.\n",
      "[I 2024-09-02 13:05:18,196] Trial 35 pruned. Trial was pruned at iteration 20.\n",
      "[I 2024-09-02 13:06:31,149] Trial 36 finished with value: 103.398175 and parameters: {'eta': 0.012258120612390613, 'max_depth': 6, 'gamma': 1.9161229760123256e-07, 'subsample': 0.763278912406082, 'colsample_bytree': 0.941101956928563, 'min_child_weight': 3.510301670566549e-06, 'booster': 'gbtree'}. Best is trial 36 with value: 103.398175.\n",
      "[I 2024-09-02 13:06:58,744] Trial 37 pruned. Trial was pruned at iteration 20.\n",
      "[I 2024-09-02 13:07:27,651] Trial 38 pruned. Trial was pruned at iteration 37.\n",
      "[I 2024-09-02 13:07:49,748] Trial 39 pruned. Trial was pruned at iteration 20.\n",
      "[I 2024-09-02 13:08:09,532] Trial 40 pruned. Trial was pruned at iteration 20.\n",
      "[I 2024-09-02 13:09:50,501] Trial 41 finished with value: 111.06723179999999 and parameters: {'eta': 0.012411701441924196, 'max_depth': 7, 'gamma': 1.4362213938896562e-06, 'subsample': 0.5914964568233338, 'colsample_bytree': 0.962936954040761, 'min_child_weight': 5.1212262474658135e-05, 'booster': 'gbtree'}. Best is trial 36 with value: 103.398175.\n",
      "[I 2024-09-02 13:10:14,367] Trial 42 pruned. Trial was pruned at iteration 20.\n",
      "[I 2024-09-02 13:10:38,664] Trial 43 pruned. Trial was pruned at iteration 20.\n",
      "[I 2024-09-02 13:11:40,967] Trial 44 finished with value: 124.228926 and parameters: {'eta': 0.02911954386952888, 'max_depth': 6, 'gamma': 1.6584451973202667e-07, 'subsample': 0.7450182241126941, 'colsample_bytree': 0.9724981767631267, 'min_child_weight': 0.00012791826170739786, 'booster': 'gbtree'}. Best is trial 36 with value: 103.398175.\n",
      "[I 2024-09-02 13:13:34,755] Trial 45 finished with value: 112.1506564 and parameters: {'eta': 0.011361464830800673, 'max_depth': 8, 'gamma': 2.73171007122846e-06, 'subsample': 0.776870622920949, 'colsample_bytree': 0.8654025416803186, 'min_child_weight': 1.1244543979292835e-06, 'booster': 'gbtree'}. Best is trial 36 with value: 103.398175.\n",
      "[I 2024-09-02 13:15:28,337] Trial 46 finished with value: 113.42927399999999 and parameters: {'eta': 0.011277329373735033, 'max_depth': 8, 'gamma': 1.4653193347442595e-06, 'subsample': 0.7137283091249865, 'colsample_bytree': 0.8739469676686337, 'min_child_weight': 1.8028331132759715e-06, 'booster': 'gbtree'}. Best is trial 36 with value: 103.398175.\n",
      "[I 2024-09-02 13:16:06,053] Trial 47 pruned. Trial was pruned at iteration 20.\n",
      "[I 2024-09-02 13:16:32,148] Trial 48 pruned. Trial was pruned at iteration 20.\n",
      "[I 2024-09-02 13:16:56,398] Trial 49 pruned. Trial was pruned at iteration 20.\n",
      "[I 2024-09-02 13:17:21,987] Trial 50 pruned. Trial was pruned at iteration 20.\n",
      "[I 2024-09-02 13:18:57,601] Trial 51 pruned. Trial was pruned at iteration 74.\n",
      "[I 2024-09-02 13:19:39,949] Trial 52 pruned. Trial was pruned at iteration 35.\n",
      "[I 2024-09-02 13:20:12,139] Trial 53 pruned. Trial was pruned at iteration 20.\n",
      "[I 2024-09-02 13:21:57,838] Trial 54 finished with value: 110.9946152 and parameters: {'eta': 0.014255142988245144, 'max_depth': 7, 'gamma': 2.2635092682671276e-08, 'subsample': 0.7087538074420816, 'colsample_bytree': 0.8599215270625566, 'min_child_weight': 1.3344898085297332e-07, 'booster': 'gbtree'}. Best is trial 36 with value: 103.398175.\n",
      "[I 2024-09-02 13:23:43,762] Trial 55 finished with value: 109.4084304 and parameters: {'eta': 0.014453702933540957, 'max_depth': 7, 'gamma': 1.805275453715637e-08, 'subsample': 0.7926671123998645, 'colsample_bytree': 0.8379331615214979, 'min_child_weight': 1.2839563754758034e-07, 'booster': 'gbtree'}. Best is trial 36 with value: 103.398175.\n",
      "[I 2024-09-02 13:25:11,526] Trial 56 finished with value: 114.66837319999999 and parameters: {'eta': 0.019379820459092627, 'max_depth': 7, 'gamma': 2.5402672416349378e-08, 'subsample': 0.9174275001566203, 'colsample_bytree': 0.8461915101953899, 'min_child_weight': 1.306210844674647e-07, 'booster': 'gbtree'}. Best is trial 36 with value: 103.398175.\n",
      "[I 2024-09-02 13:26:09,465] Trial 57 finished with value: 126.49852600000001 and parameters: {'eta': 0.0334079938638114, 'max_depth': 6, 'gamma': 1.073060761670858e-08, 'subsample': 0.7972660560093523, 'colsample_bytree': 0.7420688677037481, 'min_child_weight': 3.086008841032346e-06, 'booster': 'gbtree'}. Best is trial 36 with value: 103.398175.\n",
      "[I 2024-09-02 13:26:31,697] Trial 58 pruned. Trial was pruned at iteration 20.\n",
      "[I 2024-09-02 13:26:55,223] Trial 59 pruned. Trial was pruned at iteration 20.\n",
      "\n",
      "Hyper-Parameter Optimization successfully finished.\n",
      "  Number of finished trials:  60\n",
      "  Best trial:\n",
      "    Value: 103.398175\n",
      "    Params: \n",
      "    eta: 0.012258120612390613\n",
      "    max_depth: 6\n",
      "    gamma: 1.9161229760123256e-07\n",
      "    subsample: 0.763278912406082\n",
      "    colsample_bytree: 0.941101956928563\n",
      "    min_child_weight: 3.510301670566549e-06\n",
      "    booster: gbtree\n",
      "    opt_rounds: 100\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "GA 0:52:54.785742\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "[I 2024-09-02 13:31:52,173] A new study created in memory with name: XGBoostLSS Hyper-Parameter Optimization\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "1ba806611f9c42e99e4d86d736195568",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/60 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[I 2024-09-02 13:34:01,295] Trial 0 finished with value: 5194.0267578 and parameters: {'eta': 0.039985617190864776, 'max_depth': 10, 'gamma': 0.00018708009855093307, 'subsample': 0.44859714822796115, 'colsample_bytree': 0.9030925930692142, 'min_child_weight': 32.32797475533014, 'booster': 'gbtree'}. Best is trial 0 with value: 5194.0267578.\n",
      "[I 2024-09-02 13:34:34,423] Trial 1 finished with value: 48662.4453124 and parameters: {'eta': 0.0075152666157125275, 'max_depth': 7, 'gamma': 5.508903683591508e-06, 'subsample': 0.5205784440006784, 'colsample_bytree': 0.5178504247814528, 'min_child_weight': 0.005044830613941749, 'booster': 'gbtree'}. Best is trial 0 with value: 5194.0267578.\n",
      "[I 2024-09-02 13:35:06,711] Trial 2 finished with value: 6616572.844921799 and parameters: {'eta': 0.7118764350613317, 'max_depth': 5, 'gamma': 4.5387760150733934e-05, 'subsample': 0.962616063190203, 'colsample_bytree': 0.2737659877583343, 'min_child_weight': 0.012778819209134573, 'booster': 'gbtree'}. Best is trial 0 with value: 5194.0267578.\n",
      "[I 2024-09-02 13:35:35,316] Trial 3 finished with value: 9538.8852538 and parameters: {'eta': 0.006423183151005617, 'max_depth': 1, 'gamma': 5.489895875790517, 'subsample': 0.6304967376635231, 'colsample_bytree': 0.7178224231961781, 'min_child_weight': 0.0005555794019680215, 'booster': 'gbtree'}. Best is trial 0 with value: 5194.0267578.\n",
      "[I 2024-09-02 13:36:12,948] Trial 4 finished with value: 759815.084375 and parameters: {'eta': 0.04376775392291806, 'max_depth': 8, 'gamma': 5.5917110933125285, 'subsample': 0.9598068547992227, 'colsample_bytree': 0.3721714646286318, 'min_child_weight': 0.00022216333279827128, 'booster': 'gbtree'}. Best is trial 0 with value: 5194.0267578.\n",
      "[I 2024-09-02 13:36:59,276] Trial 5 finished with value: 5325951.58125 and parameters: {'eta': 0.06722831087422304, 'max_depth': 9, 'gamma': 0.011040354985747082, 'subsample': 0.841284455839638, 'colsample_bytree': 0.9635800856746022, 'min_child_weight': 0.0017401203574734293, 'booster': 'gbtree'}. Best is trial 0 with value: 5194.0267578.\n",
      "[I 2024-09-02 13:37:30,558] Trial 6 finished with value: 2836.7877197999996 and parameters: {'eta': 0.4743306225155992, 'max_depth': 2, 'gamma': 9.114039367981248e-06, 'subsample': 0.37934398025897187, 'colsample_bytree': 0.399325725012612, 'min_child_weight': 102.02859681401162, 'booster': 'gbtree'}. Best is trial 6 with value: 2836.7877197999996.\n",
      "[I 2024-09-02 13:38:05,672] Trial 7 finished with value: 65734.5914064 and parameters: {'eta': 0.01727721029843082, 'max_depth': 6, 'gamma': 27.667640836214414, 'subsample': 0.7594427722530344, 'colsample_bytree': 0.9120725513743142, 'min_child_weight': 1.2598136371182414e-08, 'booster': 'gbtree'}. Best is trial 6 with value: 2836.7877197999996.\n",
      "[I 2024-09-02 13:40:14,520] Trial 8 finished with value: -1658.2878664 and parameters: {'eta': 0.00028522096821878275, 'max_depth': 5, 'gamma': 1.7326381234882076e-05, 'subsample': 0.4577291121665723, 'colsample_bytree': 0.2800785527436562, 'min_child_weight': 8.46447712929691e-05, 'booster': 'gbtree'}. Best is trial 8 with value: -1658.2878664.\n",
      "[I 2024-09-02 13:41:06,553] Trial 9 finished with value: 39912.5195312 and parameters: {'eta': 0.5319852183173293, 'max_depth': 1, 'gamma': 0.4292552948089573, 'subsample': 0.5885113942261, 'colsample_bytree': 0.35005034551000747, 'min_child_weight': 0.010947696068952389, 'booster': 'gbtree'}. Best is trial 8 with value: -1658.2878664.\n",
      "[I 2024-09-02 13:43:09,975] Trial 10 finished with value: -2353.054004 and parameters: {'eta': 0.00010521429102495977, 'max_depth': 4, 'gamma': 1.799666493549737e-08, 'subsample': 0.21717257500359854, 'colsample_bytree': 0.644396657943658, 'min_child_weight': 1.116283620229556e-06, 'booster': 'gbtree'}. Best is trial 10 with value: -2353.054004.\n",
      "[I 2024-09-02 13:45:12,968] Trial 11 finished with value: -2693.2614748 and parameters: {'eta': 0.00011139915200642388, 'max_depth': 4, 'gamma': 1.4055004282061363e-08, 'subsample': 0.20602253745477223, 'colsample_bytree': 0.6695239684124773, 'min_child_weight': 4.969550634960045e-07, 'booster': 'gbtree'}. Best is trial 11 with value: -2693.2614748.\n",
      "[I 2024-09-02 13:45:58,791] Trial 12 pruned. Trial was pruned at iteration 38.\n",
      "[I 2024-09-02 13:47:26,242] Trial 13 pruned. Trial was pruned at iteration 69.\n",
      "[I 2024-09-02 13:48:49,356] Trial 14 pruned. Trial was pruned at iteration 69.\n",
      "[I 2024-09-02 13:49:23,633] Trial 15 pruned. Trial was pruned at iteration 26.\n",
      "[I 2024-09-02 13:50:01,571] Trial 16 pruned. Trial was pruned at iteration 27.\n",
      "[I 2024-09-02 13:51:03,059] Trial 17 pruned. Trial was pruned at iteration 51.\n",
      "[I 2024-09-02 13:51:30,849] Trial 18 pruned. Trial was pruned at iteration 20.\n",
      "[I 2024-09-02 13:54:04,167] Trial 19 finished with value: -2674.7631834 and parameters: {'eta': 8.429078819121533e-05, 'max_depth': 7, 'gamma': 1.3134598893028531e-06, 'subsample': 0.4152138642008991, 'colsample_bytree': 0.47363262200157674, 'min_child_weight': 2.225739772252082e-05, 'booster': 'gbtree'}. Best is trial 11 with value: -2693.2614748.\n",
      "[I 2024-09-02 13:56:36,642] Trial 20 finished with value: -2860.5787108 and parameters: {'eta': 0.0002304581260404273, 'max_depth': 7, 'gamma': 1.4039873631480622e-06, 'subsample': 0.39851696789108176, 'colsample_bytree': 0.4725780907531101, 'min_child_weight': 0.2067332849988301, 'booster': 'gbtree'}. Best is trial 20 with value: -2860.5787108.\n",
      "[I 2024-09-02 13:59:06,353] Trial 21 finished with value: -3106.1538088 and parameters: {'eta': 0.000313708679941657, 'max_depth': 7, 'gamma': 1.5407851367569078e-06, 'subsample': 0.4137823331478154, 'colsample_bytree': 0.469397613111198, 'min_child_weight': 1.219030363634945, 'booster': 'gbtree'}. Best is trial 21 with value: -3106.1538088.\n",
      "[I 2024-09-02 13:59:51,614] Trial 22 pruned. Trial was pruned at iteration 26.\n",
      "[I 2024-09-02 14:00:23,958] Trial 23 pruned. Trial was pruned at iteration 20.\n",
      "[I 2024-09-02 14:01:04,019] Trial 24 pruned. Trial was pruned at iteration 26.\n",
      "[I 2024-09-02 14:01:41,147] Trial 25 pruned. Trial was pruned at iteration 26.\n",
      "[I 2024-09-02 14:02:22,076] Trial 26 pruned. Trial was pruned at iteration 20.\n",
      "[I 2024-09-02 14:02:57,235] Trial 27 pruned. Trial was pruned at iteration 26.\n",
      "[I 2024-09-02 14:03:35,009] Trial 28 pruned. Trial was pruned at iteration 23.\n",
      "[I 2024-09-02 14:04:04,664] Trial 29 pruned. Trial was pruned at iteration 21.\n",
      "[I 2024-09-02 14:06:59,639] Trial 30 finished with value: -6168.577831799999 and parameters: {'eta': 0.004795869817458798, 'max_depth': 10, 'gamma': 8.632899035931487e-08, 'subsample': 0.2913495419775143, 'colsample_bytree': 0.8444496914502289, 'min_child_weight': 47.43657666080897, 'booster': 'gbtree'}. Best is trial 30 with value: -6168.577831799999.\n",
      "[I 2024-09-02 14:10:11,495] Trial 31 finished with value: -6826.1794922 and parameters: {'eta': 0.004461846742364742, 'max_depth': 10, 'gamma': 6.029297697267055e-08, 'subsample': 0.2933065839510934, 'colsample_bytree': 0.8390508919450779, 'min_child_weight': 22.707217109836, 'booster': 'gbtree'}. Best is trial 31 with value: -6826.1794922.\n",
      "[I 2024-09-02 14:13:16,412] Trial 32 finished with value: -6368.5913088 and parameters: {'eta': 0.0040886391687034946, 'max_depth': 10, 'gamma': 6.56253658373395e-08, 'subsample': 0.28869880714416263, 'colsample_bytree': 0.8388918299511268, 'min_child_weight': 29.50665858207928, 'booster': 'gbtree'}. Best is trial 31 with value: -6826.1794922.\n",
      "[I 2024-09-02 14:16:17,919] Trial 33 finished with value: -6462.4985354 and parameters: {'eta': 0.0049250409224106525, 'max_depth': 10, 'gamma': 6.828923649675072e-08, 'subsample': 0.2737769497316659, 'colsample_bytree': 0.8552138730124058, 'min_child_weight': 32.378530603227915, 'booster': 'gbtree'}. Best is trial 31 with value: -6826.1794922.\n",
      "[I 2024-09-02 14:19:21,469] Trial 34 finished with value: -6780.2912108 and parameters: {'eta': 0.0048969421089696255, 'max_depth': 10, 'gamma': 1.0223538184890811e-07, 'subsample': 0.2829999027421975, 'colsample_bytree': 0.8613745304908367, 'min_child_weight': 32.93429675366618, 'booster': 'gbtree'}. Best is trial 31 with value: -6826.1794922.\n",
      "[I 2024-09-02 14:19:56,347] Trial 35 pruned. Trial was pruned at iteration 20.\n",
      "[I 2024-09-02 14:20:25,766] Trial 36 pruned. Trial was pruned at iteration 20.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[I 2024-09-02 14:21:01,920] Trial 37 pruned. Trial was pruned at iteration 20.\n",
      "[I 2024-09-02 14:22:22,264] Trial 38 finished with value: -4436.324768 and parameters: {'eta': 0.1098164917934823, 'max_depth': 10, 'gamma': 4.478943535967823e-08, 'subsample': 0.2627894141776032, 'colsample_bytree': 0.864400509382786, 'min_child_weight': 79.89216943589213, 'booster': 'gbtree'}. Best is trial 31 with value: -6826.1794922.\n",
      "[I 2024-09-02 14:23:00,945] Trial 39 pruned. Trial was pruned at iteration 20.\n",
      "[I 2024-09-02 14:25:45,956] Trial 40 finished with value: -5099.1691406 and parameters: {'eta': 0.0033889942958781555, 'max_depth': 10, 'gamma': 2.7349050080448552e-05, 'subsample': 0.5508536673423419, 'colsample_bytree': 0.7516114302371659, 'min_child_weight': 176.96127630041516, 'booster': 'gbtree'}. Best is trial 31 with value: -6826.1794922.\n",
      "[I 2024-09-02 14:28:33,364] Trial 41 finished with value: -6173.4583984 and parameters: {'eta': 0.00527582887607016, 'max_depth': 10, 'gamma': 6.563990862026283e-08, 'subsample': 0.2615635775718239, 'colsample_bytree': 0.8363316051459949, 'min_child_weight': 61.86457402894896, 'booster': 'gbtree'}. Best is trial 31 with value: -6826.1794922.\n",
      "[I 2024-09-02 14:29:14,612] Trial 42 pruned. Trial was pruned at iteration 20.\n",
      "[I 2024-09-02 14:29:51,530] Trial 43 pruned. Trial was pruned at iteration 20.\n",
      "[I 2024-09-02 14:30:32,037] Trial 44 pruned. Trial was pruned at iteration 27.\n",
      "[I 2024-09-02 14:33:49,634] Trial 45 finished with value: -9304.991796799999 and parameters: {'eta': 0.015666496373714946, 'max_depth': 10, 'gamma': 5.671467833063984e-07, 'subsample': 0.6601677386835949, 'colsample_bytree': 0.920703058713082, 'min_child_weight': 142.1366127615024, 'booster': 'gbtree'}. Best is trial 45 with value: -9304.991796799999.\n",
      "[I 2024-09-02 14:34:30,817] Trial 46 pruned. Trial was pruned at iteration 20.\n",
      "[I 2024-09-02 14:35:10,556] Trial 47 finished with value: 70730.403125 and parameters: {'eta': 0.02202001222444663, 'max_depth': 9, 'gamma': 2.7597762920687323e-08, 'subsample': 0.6834123860727622, 'colsample_bytree': 0.9201271279821749, 'min_child_weight': 2.4040416154693673, 'booster': 'gbtree'}. Best is trial 45 with value: -9304.991796799999.\n",
      "[I 2024-09-02 14:35:44,718] Trial 48 pruned. Trial was pruned at iteration 20.\n",
      "[I 2024-09-02 14:38:18,878] Trial 49 finished with value: -8399.6632814 and parameters: {'eta': 0.011988621106526562, 'max_depth': 9, 'gamma': 1.3116611914172166e-05, 'subsample': 0.7291617752355857, 'colsample_bytree': 0.7154039173358693, 'min_child_weight': 454.60813728830357, 'booster': 'gbtree'}. Best is trial 45 with value: -9304.991796799999.\n",
      "[I 2024-09-02 14:40:55,176] Trial 50 finished with value: -7517.6448242 and parameters: {'eta': 0.009430486810237585, 'max_depth': 9, 'gamma': 1.4318410589058754e-05, 'subsample': 0.7489504545332687, 'colsample_bytree': 0.7102620385016413, 'min_child_weight': 309.819492314493, 'booster': 'gbtree'}. Best is trial 45 with value: -9304.991796799999.\n",
      "[I 2024-09-02 14:43:35,043] Trial 51 finished with value: -7401.649902200001 and parameters: {'eta': 0.009027267020577441, 'max_depth': 9, 'gamma': 1.4383891399057315e-05, 'subsample': 0.7685222847241712, 'colsample_bytree': 0.7167037346562446, 'min_child_weight': 243.99476332596865, 'booster': 'gbtree'}. Best is trial 45 with value: -9304.991796799999.\n",
      "[I 2024-09-02 14:46:16,291] Trial 52 finished with value: -8003.3928712 and parameters: {'eta': 0.0105411166905353, 'max_depth': 9, 'gamma': 1.3628483420457892e-05, 'subsample': 0.7742866618878331, 'colsample_bytree': 0.7342220158712628, 'min_child_weight': 236.38760217842136, 'booster': 'gbtree'}. Best is trial 45 with value: -9304.991796799999.\n",
      "[I 2024-09-02 14:48:41,960] Trial 53 finished with value: -8177.462695199999 and parameters: {'eta': 0.010818236505868864, 'max_depth': 8, 'gamma': 4.8982707302347245e-05, 'subsample': 0.7606082861588255, 'colsample_bytree': 0.7242622738962535, 'min_child_weight': 460.8286821734749, 'booster': 'gbtree'}. Best is trial 45 with value: -9304.991796799999.\n",
      "[I 2024-09-02 14:51:16,290] Trial 54 finished with value: -8347.030664 and parameters: {'eta': 0.011028541679025302, 'max_depth': 9, 'gamma': 1.2175451618176576e-05, 'subsample': 0.7625236368096304, 'colsample_bytree': 0.7159215022573142, 'min_child_weight': 485.04106698534827, 'booster': 'gbtree'}. Best is trial 45 with value: -9304.991796799999.\n",
      "[I 2024-09-02 14:53:41,240] Trial 55 finished with value: -10149.0439452 and parameters: {'eta': 0.038142810181359316, 'max_depth': 8, 'gamma': 5.690673717111187e-05, 'subsample': 0.7313694670092006, 'colsample_bytree': 0.619769013238866, 'min_child_weight': 493.13338102423006, 'booster': 'gbtree'}. Best is trial 55 with value: -10149.0439452.\n",
      "[I 2024-09-02 14:54:14,408] Trial 56 pruned. Trial was pruned at iteration 20.\n",
      "[I 2024-09-02 14:54:43,648] Trial 57 pruned. Trial was pruned at iteration 20.\n",
      "[I 2024-09-02 14:57:05,623] Trial 58 finished with value: -8983.9902344 and parameters: {'eta': 0.0144051077274611, 'max_depth': 8, 'gamma': 4.195751562574787e-05, 'subsample': 0.6674126928130013, 'colsample_bytree': 0.6659366111039089, 'min_child_weight': 497.82960763027035, 'booster': 'gbtree'}. Best is trial 55 with value: -10149.0439452.\n",
      "[I 2024-09-02 14:59:36,089] Trial 59 finished with value: -8676.3378906 and parameters: {'eta': 0.015101012182022611, 'max_depth': 8, 'gamma': 5.513999608592226e-05, 'subsample': 0.6250866519989025, 'colsample_bytree': 0.6864315475611175, 'min_child_weight': 110.52749690547466, 'booster': 'gbtree'}. Best is trial 55 with value: -10149.0439452.\n",
      "\n",
      "Hyper-Parameter Optimization successfully finished.\n",
      "  Number of finished trials:  60\n",
      "  Best trial:\n",
      "    Value: -10149.0439452\n",
      "    Params: \n",
      "    eta: 0.038142810181359316\n",
      "    max_depth: 8\n",
      "    gamma: 5.690673717111187e-05\n",
      "    subsample: 0.7313694670092006\n",
      "    colsample_bytree: 0.619769013238866\n",
      "    min_child_weight: 493.13338102423006\n",
      "    booster: gbtree\n",
      "    opt_rounds: 86\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "HI 1:35:45.277781\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "[I 2024-09-02 15:07:37,404] A new study created in memory with name: XGBoostLSS Hyper-Parameter Optimization\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "11e15433ca4d4862a2a006749f37e1b3",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/60 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[I 2024-09-02 15:10:28,077] Trial 0 finished with value: 596.5084472000001 and parameters: {'eta': 1.222575639175663e-05, 'max_depth': 6, 'gamma': 4.775178210022988, 'subsample': 0.34860555242970837, 'colsample_bytree': 0.4969977993612582, 'min_child_weight': 3.529257121576166e-06, 'booster': 'gbtree'}. Best is trial 0 with value: 596.5084472000001.\n",
      "[I 2024-09-02 15:11:16,142] Trial 1 finished with value: 1634.8762694000002 and parameters: {'eta': 0.941480202251069, 'max_depth': 8, 'gamma': 0.17119392147815818, 'subsample': 0.2338438833789309, 'colsample_bytree': 0.5884408075184085, 'min_child_weight': 2.454342698617208e-05, 'booster': 'gbtree'}. Best is trial 0 with value: 596.5084472000001.\n",
      "[I 2024-09-02 15:14:09,042] Trial 2 finished with value: 576.5783078000001 and parameters: {'eta': 8.428454196548667e-05, 'max_depth': 10, 'gamma': 0.004549927581691847, 'subsample': 0.21159015223740127, 'colsample_bytree': 0.4274719969625327, 'min_child_weight': 64.68222941361465, 'booster': 'gbtree'}. Best is trial 2 with value: 576.5783078000001.\n",
      "[I 2024-09-02 15:16:45,279] Trial 3 finished with value: 548.0517942 and parameters: {'eta': 0.000421131635807038, 'max_depth': 1, 'gamma': 1.073760026873107e-05, 'subsample': 0.8990177599156579, 'colsample_bytree': 0.5786565782804969, 'min_child_weight': 5.318368792682681e-07, 'booster': 'gbtree'}. Best is trial 3 with value: 548.0517942.\n",
      "[I 2024-09-02 15:17:23,034] Trial 4 finished with value: 749.6831543999999 and parameters: {'eta': 0.4599868862722884, 'max_depth': 3, 'gamma': 33.00896669600504, 'subsample': 0.5768990619911325, 'colsample_bytree': 0.9193322108735149, 'min_child_weight': 0.007347022437529205, 'booster': 'gbtree'}. Best is trial 3 with value: 548.0517942.\n",
      "[I 2024-09-02 15:18:12,941] Trial 5 finished with value: 294.52058700000003 and parameters: {'eta': 0.06616335061364208, 'max_depth': 7, 'gamma': 0.13130680411873266, 'subsample': 0.8016813689484235, 'colsample_bytree': 0.9579921402232177, 'min_child_weight': 1.0370992212736396e-08, 'booster': 'gbtree'}. Best is trial 5 with value: 294.52058700000003.\n",
      "[I 2024-09-02 15:20:50,958] Trial 6 finished with value: 534.2222291999999 and parameters: {'eta': 0.0003542768573113706, 'max_depth': 2, 'gamma': 0.007280212123439256, 'subsample': 0.8608310454996821, 'colsample_bytree': 0.5100464914120957, 'min_child_weight': 0.14328606188161144, 'booster': 'gbtree'}. Best is trial 5 with value: 294.52058700000003.\n",
      "[I 2024-09-02 15:23:27,326] Trial 7 finished with value: 365.3686094 and parameters: {'eta': 0.004410304102019005, 'max_depth': 1, 'gamma': 0.1717202782078908, 'subsample': 0.8643325544219473, 'colsample_bytree': 0.4684912471093167, 'min_child_weight': 4.261806771894456e-05, 'booster': 'gbtree'}. Best is trial 5 with value: 294.52058700000003.\n",
      "[I 2024-09-02 15:24:06,974] Trial 8 finished with value: 1137.6482666 and parameters: {'eta': 0.7080427426930682, 'max_depth': 5, 'gamma': 0.03654405815752846, 'subsample': 0.30689039038011834, 'colsample_bytree': 0.7468196533997755, 'min_child_weight': 4.349745266751927, 'booster': 'gbtree'}. Best is trial 5 with value: 294.52058700000003.\n",
      "[I 2024-09-02 15:28:05,637] Trial 9 finished with value: 587.7627076000001 and parameters: {'eta': 3.898541846393673e-05, 'max_depth': 10, 'gamma': 0.011183709309844346, 'subsample': 0.8789465344999676, 'colsample_bytree': 0.5422650721862627, 'min_child_weight': 2.0466156778337146, 'booster': 'gbtree'}. Best is trial 5 with value: 294.52058700000003.\n",
      "[I 2024-09-02 15:29:36,863] Trial 10 finished with value: 282.4564026 and parameters: {'eta': 0.03928742236781244, 'max_depth': 7, 'gamma': 2.96798233034562e-08, 'subsample': 0.6768080742405903, 'colsample_bytree': 0.25994423780681186, 'min_child_weight': 3.80076656820519e-08, 'booster': 'gbtree'}. Best is trial 10 with value: 282.4564026.\n",
      "[I 2024-09-02 15:31:48,043] Trial 11 finished with value: 276.7595702 and parameters: {'eta': 0.032931320490246406, 'max_depth': 7, 'gamma': 1.1427942963172339e-08, 'subsample': 0.7069206253439505, 'colsample_bytree': 0.23235554342080553, 'min_child_weight': 1.5569417248284666e-08, 'booster': 'gbtree'}. Best is trial 11 with value: 276.7595702.\n",
      "[I 2024-09-02 15:34:39,178] Trial 12 finished with value: 272.4425356 and parameters: {'eta': 0.020237488804732334, 'max_depth': 8, 'gamma': 7.816314079674467e-08, 'subsample': 0.6587840558957121, 'colsample_bytree': 0.21367406469914693, 'min_child_weight': 1.010179775871657e-08, 'booster': 'gbtree'}. Best is trial 12 with value: 272.4425356.\n",
      "[I 2024-09-02 15:37:31,609] Trial 13 finished with value: 270.54674059999996 and parameters: {'eta': 0.014500111360383582, 'max_depth': 8, 'gamma': 2.2232697696398776e-08, 'subsample': 0.5618536207576662, 'colsample_bytree': 0.20699064261805256, 'min_child_weight': 2.374335041637576e-07, 'booster': 'gbtree'}. Best is trial 13 with value: 270.54674059999996.\n",
      "[I 2024-09-02 15:40:40,513] Trial 14 finished with value: 271.91429439999996 and parameters: {'eta': 0.007073821454706995, 'max_depth': 9, 'gamma': 1.9971616429255462e-06, 'subsample': 0.5206688688644844, 'colsample_bytree': 0.340922902235996, 'min_child_weight': 0.00033547683352210824, 'booster': 'gbtree'}. Best is trial 13 with value: 270.54674059999996.\n",
      "[I 2024-09-02 15:41:31,719] Trial 15 pruned. Trial was pruned at iteration 24.\n",
      "[I 2024-09-02 15:44:14,136] Trial 16 finished with value: 288.519641 and parameters: {'eta': 0.004304558168639714, 'max_depth': 5, 'gamma': 4.1581932299353414e-05, 'subsample': 0.44936992936051623, 'colsample_bytree': 0.3497975756842051, 'min_child_weight': 0.000808173442610345, 'booster': 'gbtree'}. Best is trial 13 with value: 270.54674059999996.\n",
      "[I 2024-09-02 15:44:58,231] Trial 17 finished with value: 328.2814332 and parameters: {'eta': 0.1704068062769404, 'max_depth': 9, 'gamma': 4.3860098878088895e-07, 'subsample': 0.473394588093317, 'colsample_bytree': 0.7074507697839216, 'min_child_weight': 1.468408349621418e-06, 'booster': 'gbtree'}. Best is trial 13 with value: 270.54674059999996.\n",
      "[I 2024-09-02 15:45:34,220] Trial 18 pruned. Trial was pruned at iteration 21.\n",
      "[I 2024-09-02 15:48:39,994] Trial 19 finished with value: 267.76696159999995 and parameters: {'eta': 0.014132062735921474, 'max_depth': 9, 'gamma': 6.730001826000699e-07, 'subsample': 0.9868990158391258, 'colsample_bytree': 0.3071000532063568, 'min_child_weight': 6.320245798542002e-05, 'booster': 'gbtree'}. Best is trial 19 with value: 267.76696159999995.\n",
      "[I 2024-09-02 15:51:45,949] Trial 20 finished with value: 267.640564 and parameters: {'eta': 0.009522531052262908, 'max_depth': 8, 'gamma': 3.518763774805726e-07, 'subsample': 0.9607859068726929, 'colsample_bytree': 0.6943377361768157, 'min_child_weight': 3.372539106074307e-07, 'booster': 'gbtree'}. Best is trial 20 with value: 267.640564.\n",
      "[I 2024-09-02 15:54:51,344] Trial 21 finished with value: 266.6345764 and parameters: {'eta': 0.012134455464889634, 'max_depth': 8, 'gamma': 2.1814651236838692e-07, 'subsample': 0.9910445881015721, 'colsample_bytree': 0.7181159351198133, 'min_child_weight': 2.2420842317122736e-07, 'booster': 'gbtree'}. Best is trial 21 with value: 266.6345764.\n",
      "[I 2024-09-02 15:55:28,143] Trial 22 finished with value: 345.19791860000004 and parameters: {'eta': 0.18281877897081447, 'max_depth': 6, 'gamma': 2.9912792300644046e-07, 'subsample': 0.996889974055528, 'colsample_bytree': 0.7056215625176395, 'min_child_weight': 1.6493970490175262e-05, 'booster': 'gbtree'}. Best is trial 21 with value: 266.6345764.\n",
      "[I 2024-09-02 15:56:27,442] Trial 23 pruned. Trial was pruned at iteration 20.\n",
      "[I 2024-09-02 15:59:34,371] Trial 24 finished with value: 267.6676208 and parameters: {'eta': 0.009873561154955763, 'max_depth': 8, 'gamma': 0.0006356824269986876, 'subsample': 0.948115749745095, 'colsample_bytree': 0.6439654116213163, 'min_child_weight': 5.768293597202232e-06, 'booster': 'gbtree'}. Best is trial 21 with value: 266.6345764.\n",
      "[I 2024-09-02 16:00:13,174] Trial 25 finished with value: 321.9895386 and parameters: {'eta': 0.1280764436842332, 'max_depth': 7, 'gamma': 0.0007410377499769462, 'subsample': 0.9290618999528885, 'colsample_bytree': 0.6665550010150365, 'min_child_weight': 8.675658541147286e-08, 'booster': 'gbtree'}. Best is trial 21 with value: 266.6345764.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[I 2024-09-02 16:03:24,618] Trial 26 finished with value: 269.68762200000003 and parameters: {'eta': 0.008277784727536664, 'max_depth': 8, 'gamma': 0.00039438146081570283, 'subsample': 0.7876537547153234, 'colsample_bytree': 0.8210334810838402, 'min_child_weight': 3.145217643209902e-06, 'booster': 'gbtree'}. Best is trial 21 with value: 266.6345764.\n",
      "[I 2024-09-02 16:04:01,303] Trial 27 pruned. Trial was pruned at iteration 20.\n",
      "[I 2024-09-02 16:04:51,665] Trial 28 finished with value: 289.8304566 and parameters: {'eta': 0.06130373221719705, 'max_depth': 8, 'gamma': 1.1750243469481295e-05, 'subsample': 0.9618574065282306, 'colsample_bytree': 0.7974329528988292, 'min_child_weight': 1.4152449109759543e-07, 'booster': 'gbtree'}. Best is trial 21 with value: 266.6345764.\n",
      "[I 2024-09-02 16:05:26,924] Trial 29 pruned. Trial was pruned at iteration 20.\n",
      "[I 2024-09-02 16:06:18,949] Trial 30 pruned. Trial was pruned at iteration 28.\n",
      "[I 2024-09-02 16:08:57,840] Trial 31 finished with value: 274.9064696 and parameters: {'eta': 0.0200606301323888, 'max_depth': 9, 'gamma': 1.6693311564298878e-06, 'subsample': 0.8209271426494136, 'colsample_bytree': 0.7500476926270885, 'min_child_weight': 5.299494948757853e-05, 'booster': 'gbtree'}. Best is trial 21 with value: 266.6345764.\n",
      "[I 2024-09-02 16:09:44,049] Trial 32 pruned. Trial was pruned at iteration 20.\n",
      "[I 2024-09-02 16:13:23,395] Trial 33 finished with value: 271.6996156 and parameters: {'eta': 0.013610296620369345, 'max_depth': 10, 'gamma': 1.0392104169646825e-07, 'subsample': 0.9059391512117703, 'colsample_bytree': 0.7013534232317117, 'min_child_weight': 1.1466170780843614e-05, 'booster': 'gbtree'}. Best is trial 21 with value: 266.6345764.\n",
      "[I 2024-09-02 16:14:05,032] Trial 34 pruned. Trial was pruned at iteration 20.\n",
      "[I 2024-09-02 16:14:51,740] Trial 35 pruned. Trial was pruned at iteration 20.\n",
      "[I 2024-09-02 16:17:37,701] Trial 36 finished with value: 266.8840818 and parameters: {'eta': 0.032479868841794476, 'max_depth': 6, 'gamma': 0.001558633883162597, 'subsample': 0.8994270371620002, 'colsample_bytree': 0.869781567126986, 'min_child_weight': 0.004766745794254869, 'booster': 'gbtree'}. Best is trial 21 with value: 266.6345764.\n",
      "[I 2024-09-02 16:18:19,292] Trial 37 pruned. Trial was pruned at iteration 23.\n",
      "[I 2024-09-02 16:20:57,536] Trial 38 finished with value: 261.58418559999996 and parameters: {'eta': 0.03320554561270422, 'max_depth': 4, 'gamma': 1.5402939618079654, 'subsample': 0.8542313274215508, 'colsample_bytree': 0.9454826385237145, 'min_child_weight': 0.5422294982413776, 'booster': 'gbtree'}. Best is trial 38 with value: 261.58418559999996.\n",
      "[I 2024-09-02 16:21:32,113] Trial 39 pruned. Trial was pruned at iteration 20.\n",
      "[I 2024-09-02 16:22:11,168] Trial 40 pruned. Trial was pruned at iteration 23.\n",
      "[I 2024-09-02 16:22:58,474] Trial 41 pruned. Trial was pruned at iteration 28.\n",
      "[I 2024-09-02 16:23:37,410] Trial 42 pruned. Trial was pruned at iteration 23.\n",
      "[I 2024-09-02 16:24:16,723] Trial 43 pruned. Trial was pruned at iteration 23.\n",
      "[I 2024-09-02 16:24:55,442] Trial 44 pruned. Trial was pruned at iteration 20.\n",
      "[I 2024-09-02 16:27:42,375] Trial 45 finished with value: 265.66989739999997 and parameters: {'eta': 0.027098274599115443, 'max_depth': 6, 'gamma': 0.0016933752077482307, 'subsample': 0.8096890175227847, 'colsample_bytree': 0.9009823857044108, 'min_child_weight': 4.372654900276578e-08, 'booster': 'gbtree'}. Best is trial 38 with value: 261.58418559999996.\n",
      "[I 2024-09-02 16:28:19,414] Trial 46 pruned. Trial was pruned at iteration 20.\n",
      "[I 2024-09-02 16:28:53,405] Trial 47 pruned. Trial was pruned at iteration 20.\n",
      "[I 2024-09-02 16:29:28,015] Trial 48 pruned. Trial was pruned at iteration 20.\n",
      "[I 2024-09-02 16:30:07,053] Trial 49 pruned. Trial was pruned at iteration 23.\n",
      "[I 2024-09-02 16:33:02,478] Trial 50 finished with value: 268.6648986 and parameters: {'eta': 0.017214626149279096, 'max_depth': 7, 'gamma': 0.014346857319357462, 'subsample': 0.6125905251276114, 'colsample_bytree': 0.7613819642365888, 'min_child_weight': 0.4959843685426169, 'booster': 'gbtree'}. Best is trial 38 with value: 261.58418559999996.\n",
      "[I 2024-09-02 16:36:07,771] Trial 51 finished with value: 267.5125186 and parameters: {'eta': 0.010090981709879666, 'max_depth': 8, 'gamma': 0.00029230540738216134, 'subsample': 0.8863806886042369, 'colsample_bytree': 0.6287066803146094, 'min_child_weight': 4.4778256157163477e-07, 'booster': 'gbtree'}. Best is trial 38 with value: 261.58418559999996.\n",
      "[I 2024-09-02 16:36:44,114] Trial 52 pruned. Trial was pruned at iteration 20.\n",
      "[I 2024-09-02 16:37:34,413] Trial 53 pruned. Trial was pruned at iteration 28.\n",
      "[I 2024-09-02 16:38:19,698] Trial 54 pruned. Trial was pruned at iteration 23.\n",
      "[I 2024-09-02 16:38:54,694] Trial 55 pruned. Trial was pruned at iteration 20.\n",
      "[I 2024-09-02 16:39:32,147] Trial 56 pruned. Trial was pruned at iteration 20.\n",
      "[I 2024-09-02 16:40:10,150] Trial 57 pruned. Trial was pruned at iteration 20.\n",
      "[I 2024-09-02 16:40:49,205] Trial 58 pruned. Trial was pruned at iteration 20.\n",
      "[I 2024-09-02 16:41:28,913] Trial 59 pruned. Trial was pruned at iteration 23.\n",
      "\n",
      "Hyper-Parameter Optimization successfully finished.\n",
      "  Number of finished trials:  60\n",
      "  Best trial:\n",
      "    Value: 261.58418559999996\n",
      "    Params: \n",
      "    eta: 0.03320554561270422\n",
      "    max_depth: 4\n",
      "    gamma: 1.5402939618079654\n",
      "    subsample: 0.8542313274215508\n",
      "    colsample_bytree: 0.9454826385237145\n",
      "    min_child_weight: 0.5422294982413776\n",
      "    booster: gbtree\n",
      "    opt_rounds: 100\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "OR 1:43:54.441420\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "[I 2024-09-02 16:51:31,886] A new study created in memory with name: XGBoostLSS Hyper-Parameter Optimization\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "aa61cfa18a534710871096e09213bb55",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/60 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[I 2024-09-02 16:53:24,291] Trial 0 finished with value: 652.8791502 and parameters: {'eta': 3.5771271039285884e-05, 'max_depth': 3, 'gamma': 0.002215076259747077, 'subsample': 0.8015647808070403, 'colsample_bytree': 0.22942277187978544, 'min_child_weight': 0.004216031723381791, 'booster': 'gbtree'}. Best is trial 0 with value: 652.8791502.\n",
      "[I 2024-09-02 16:54:08,818] Trial 1 finished with value: 389.4945802 and parameters: {'eta': 0.1787180812242362, 'max_depth': 10, 'gamma': 7.479956944522971e-05, 'subsample': 0.9641140673066197, 'colsample_bytree': 0.6766898694849399, 'min_child_weight': 0.00010288868687284031, 'booster': 'gbtree'}. Best is trial 1 with value: 389.4945802.\n",
      "[I 2024-09-02 16:55:56,124] Trial 2 finished with value: 143.8056062 and parameters: {'eta': 0.023547598386083023, 'max_depth': 10, 'gamma': 0.03555141430177128, 'subsample': 0.846517811956593, 'colsample_bytree': 0.6750467723614764, 'min_child_weight': 100.79742108058666, 'booster': 'gbtree'}. Best is trial 2 with value: 143.8056062.\n",
      "[I 2024-09-02 16:56:35,163] Trial 3 finished with value: 331.349597 and parameters: {'eta': 0.07681768041434263, 'max_depth': 10, 'gamma': 0.014114594878457657, 'subsample': 0.20062064974049393, 'colsample_bytree': 0.9010449530469995, 'min_child_weight': 0.028688655727744497, 'booster': 'gbtree'}. Best is trial 2 with value: 143.8056062.\n",
      "[I 2024-09-02 16:59:01,711] Trial 4 finished with value: 655.2332395999999 and parameters: {'eta': 2.1427699659928064e-05, 'max_depth': 8, 'gamma': 1.4426592290484632e-06, 'subsample': 0.2840785732069887, 'colsample_bytree': 0.8701779028900125, 'min_child_weight': 1.1142334886569045e-05, 'booster': 'gbtree'}. Best is trial 2 with value: 143.8056062.\n",
      "[I 2024-09-02 16:59:41,004] Trial 5 finished with value: 2028.0827148 and parameters: {'eta': 0.8283433751542046, 'max_depth': 10, 'gamma': 3.308493358771743e-05, 'subsample': 0.820161609034076, 'colsample_bytree': 0.8124307618360846, 'min_child_weight': 9.03083689806025, 'booster': 'gbtree'}. Best is trial 2 with value: 143.8056062.\n",
      "[I 2024-09-02 17:01:31,001] Trial 6 finished with value: 556.6391355999999 and parameters: {'eta': 0.0003901760628385971, 'max_depth': 2, 'gamma': 0.36061115102304697, 'subsample': 0.6703815011308611, 'colsample_bytree': 0.9814132841037428, 'min_child_weight': 1.7665048657309546e-08, 'booster': 'gbtree'}. Best is trial 2 with value: 143.8056062.\n",
      "[I 2024-09-02 17:03:23,016] Trial 7 finished with value: 574.8458130000001 and parameters: {'eta': 0.00030806857398383935, 'max_depth': 3, 'gamma': 0.30700311715548007, 'subsample': 0.9104482748736997, 'colsample_bytree': 0.29102750839706926, 'min_child_weight': 8.01356826651435e-06, 'booster': 'gbtree'}. Best is trial 2 with value: 143.8056062.\n",
      "[I 2024-09-02 17:05:22,017] Trial 8 finished with value: 278.6394834 and parameters: {'eta': 0.0020571459621270462, 'max_depth': 6, 'gamma': 0.004135937732681694, 'subsample': 0.702249203518881, 'colsample_bytree': 0.9147721171192809, 'min_child_weight': 146.88343550267348, 'booster': 'gbtree'}. Best is trial 2 with value: 143.8056062.\n",
      "[I 2024-09-02 17:07:19,625] Trial 9 finished with value: 626.8394166 and parameters: {'eta': 0.00010280577630163268, 'max_depth': 5, 'gamma': 4.11851440896142e-08, 'subsample': 0.6865492123821542, 'colsample_bytree': 0.650005586403205, 'min_child_weight': 0.17436499025718566, 'booster': 'gbtree'}. Best is trial 2 with value: 143.8056062.\n",
      "[I 2024-09-02 17:09:08,671] Trial 10 finished with value: 168.0170716 and parameters: {'eta': 0.012736087888252869, 'max_depth': 7, 'gamma': 28.97893147249643, 'subsample': 0.4265840063997307, 'colsample_bytree': 0.4993788208937378, 'min_child_weight': 2.7364706499284526, 'booster': 'gbtree'}. Best is trial 2 with value: 143.8056062.\n",
      "[I 2024-09-02 17:10:56,973] Trial 11 finished with value: 178.33098139999998 and parameters: {'eta': 0.012905168045628405, 'max_depth': 7, 'gamma': 34.00812247288365, 'subsample': 0.4612975665659425, 'colsample_bytree': 0.4647619536641722, 'min_child_weight': 426.23061037441965, 'booster': 'gbtree'}. Best is trial 2 with value: 143.8056062.\n",
      "[I 2024-09-02 17:12:48,813] Trial 12 finished with value: 139.5458466 and parameters: {'eta': 0.014151015803837208, 'max_depth': 8, 'gamma': 11.175401032472807, 'subsample': 0.4793381145997095, 'colsample_bytree': 0.49722632835890934, 'min_child_weight': 6.304612706657637, 'booster': 'gbtree'}. Best is trial 12 with value: 139.5458466.\n",
      "[I 2024-09-02 17:14:56,861] Trial 13 finished with value: 201.44581599999998 and parameters: {'eta': 0.004956597932619567, 'max_depth': 8, 'gamma': 0.39043997648593604, 'subsample': 0.5101689008805834, 'colsample_bytree': 0.4942262235542534, 'min_child_weight': 2.934780317730626, 'booster': 'gbtree'}. Best is trial 12 with value: 139.5458466.\n",
      "[I 2024-09-02 17:15:59,274] Trial 14 finished with value: 203.7747804 and parameters: {'eta': 0.03626092713842842, 'max_depth': 9, 'gamma': 3.3741623253087387, 'subsample': 0.5728851691247638, 'colsample_bytree': 0.7538002493994397, 'min_child_weight': 26.854956145417745, 'booster': 'gbtree'}. Best is trial 12 with value: 139.5458466.\n",
      "[I 2024-09-02 17:16:27,280] Trial 15 pruned. Trial was pruned at iteration 23.\n",
      "[I 2024-09-02 17:16:56,449] Trial 16 finished with value: 636.5181884 and parameters: {'eta': 0.2864906972080723, 'max_depth': 8, 'gamma': 1.6480656230736594, 'subsample': 0.8075503051493653, 'colsample_bytree': 0.5718939333522493, 'min_child_weight': 70.60478348706019, 'booster': 'gbtree'}. Best is trial 12 with value: 139.5458466.\n",
      "[I 2024-09-02 17:18:13,948] Trial 17 finished with value: 201.299414 and parameters: {'eta': 0.025650116773416536, 'max_depth': 9, 'gamma': 0.00021691069375762818, 'subsample': 0.5540168586597841, 'colsample_bytree': 0.39839702496399304, 'min_child_weight': 0.0007577621216467217, 'booster': 'gbtree'}. Best is trial 12 with value: 139.5458466.\n",
      "[I 2024-09-02 17:18:51,341] Trial 18 pruned. Trial was pruned at iteration 20.\n",
      "[I 2024-09-02 17:19:32,505] Trial 19 pruned. Trial was pruned at iteration 33.\n",
      "[I 2024-09-02 17:20:08,090] Trial 20 finished with value: 279.73710919999996 and parameters: {'eta': 0.09714979557332801, 'max_depth': 7, 'gamma': 1.5416449650947029e-06, 'subsample': 0.7454951534357014, 'colsample_bytree': 0.5566997169105784, 'min_child_weight': 0.012419436695578668, 'booster': 'gbtree'}. Best is trial 12 with value: 139.5458466.\n",
      "[I 2024-09-02 17:21:56,061] Trial 21 finished with value: 176.16369020000002 and parameters: {'eta': 0.01183664215354736, 'max_depth': 7, 'gamma': 34.97718293490475, 'subsample': 0.429851113703359, 'colsample_bytree': 0.41983915293492524, 'min_child_weight': 1.7492350220170325, 'booster': 'gbtree'}. Best is trial 12 with value: 139.5458466.\n",
      "[I 2024-09-02 17:23:51,143] Trial 22 finished with value: 156.8859954 and parameters: {'eta': 0.01828129083873632, 'max_depth': 9, 'gamma': 8.27142232519185, 'subsample': 0.3529291761039263, 'colsample_bytree': 0.5424723812926547, 'min_child_weight': 17.21538759213715, 'booster': 'gbtree'}. Best is trial 12 with value: 139.5458466.\n",
      "[I 2024-09-02 17:25:28,691] Trial 23 finished with value: 169.0754394 and parameters: {'eta': 0.03604116216927236, 'max_depth': 9, 'gamma': 3.7649424359151014, 'subsample': 0.3473316582676289, 'colsample_bytree': 0.6589807793740221, 'min_child_weight': 425.592483901082, 'booster': 'gbtree'}. Best is trial 12 with value: 139.5458466.\n",
      "[I 2024-09-02 17:25:59,006] Trial 24 pruned. Trial was pruned at iteration 20.\n",
      "[I 2024-09-02 17:26:29,974] Trial 25 pruned. Trial was pruned at iteration 23.\n",
      "[I 2024-09-02 17:26:58,013] Trial 26 pruned. Trial was pruned at iteration 20.\n",
      "[I 2024-09-02 17:27:42,983] Trial 27 pruned. Trial was pruned at iteration 23.\n",
      "[I 2024-09-02 17:29:04,178] Trial 28 finished with value: 173.56931760000003 and parameters: {'eta': 0.029391242272103164, 'max_depth': 8, 'gamma': 0.0026693920450640528, 'subsample': 0.8736292241654804, 'colsample_bytree': 0.500553839742915, 'min_child_weight': 4.5869224697206485, 'booster': 'gbtree'}. Best is trial 12 with value: 139.5458466.\n",
      "[I 2024-09-02 17:29:28,392] Trial 29 pruned. Trial was pruned at iteration 20.\n",
      "[I 2024-09-02 17:31:20,535] Trial 30 finished with value: 152.44198319999998 and parameters: {'eta': 0.020649092448111642, 'max_depth': 9, 'gamma': 8.630927047552206, 'subsample': 0.2809029742819137, 'colsample_bytree': 0.3435993682384947, 'min_child_weight': 78.93373524160428, 'booster': 'gbtree'}. Best is trial 12 with value: 139.5458466.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[I 2024-09-02 17:33:12,825] Trial 31 finished with value: 148.2745576 and parameters: {'eta': 0.016017621975562384, 'max_depth': 9, 'gamma': 8.267662898107824, 'subsample': 0.28646237980135625, 'colsample_bytree': 0.34126995413888594, 'min_child_weight': 104.52636625136593, 'booster': 'gbtree'}. Best is trial 12 with value: 139.5458466.\n",
      "[I 2024-09-02 17:34:04,398] Trial 32 pruned. Trial was pruned at iteration 42.\n",
      "[I 2024-09-02 17:34:30,901] Trial 33 pruned. Trial was pruned at iteration 20.\n",
      "[I 2024-09-02 17:34:57,167] Trial 34 pruned. Trial was pruned at iteration 20.\n",
      "[I 2024-09-02 17:35:43,749] Trial 35 pruned. Trial was pruned at iteration 42.\n",
      "[I 2024-09-02 17:36:12,133] Trial 36 pruned. Trial was pruned at iteration 20.\n",
      "[I 2024-09-02 17:37:57,953] Trial 37 finished with value: 179.17572339999998 and parameters: {'eta': 0.019456408462114154, 'max_depth': 10, 'gamma': 2.309104086341056e-05, 'subsample': 0.75855395697036, 'colsample_bytree': 0.3762864166651778, 'min_child_weight': 7.4060995525158875, 'booster': 'gbtree'}. Best is trial 12 with value: 139.5458466.\n",
      "[I 2024-09-02 17:38:23,452] Trial 38 pruned. Trial was pruned at iteration 20.\n",
      "[I 2024-09-02 17:38:57,203] Trial 39 pruned. Trial was pruned at iteration 20.\n",
      "[I 2024-09-02 17:39:23,626] Trial 40 pruned. Trial was pruned at iteration 20.\n",
      "[I 2024-09-02 17:41:14,397] Trial 41 finished with value: 146.6874724 and parameters: {'eta': 0.01598449056255154, 'max_depth': 9, 'gamma': 11.05880078332072, 'subsample': 0.31186132638641567, 'colsample_bytree': 0.5310080713519939, 'min_child_weight': 11.707621891593558, 'booster': 'gbtree'}. Best is trial 12 with value: 139.5458466.\n",
      "[I 2024-09-02 17:41:39,917] Trial 42 pruned. Trial was pruned at iteration 20.\n",
      "[I 2024-09-02 17:42:07,216] Trial 43 pruned. Trial was pruned at iteration 20.\n",
      "[I 2024-09-02 17:44:06,320] Trial 44 finished with value: 153.3111298 and parameters: {'eta': 0.017337226761892865, 'max_depth': 7, 'gamma': 0.440707411421922, 'subsample': 0.4549522152151105, 'colsample_bytree': 0.6192381853849586, 'min_child_weight': 9.005153533917229, 'booster': 'gbtree'}. Best is trial 12 with value: 139.5458466.\n",
      "[I 2024-09-02 17:44:30,933] Trial 45 pruned. Trial was pruned at iteration 20.\n",
      "[I 2024-09-02 17:46:20,052] Trial 46 pruned. Trial was pruned at iteration 99.\n",
      "[I 2024-09-02 17:46:46,797] Trial 47 pruned. Trial was pruned at iteration 20.\n",
      "[I 2024-09-02 17:47:15,971] Trial 48 pruned. Trial was pruned at iteration 20.\n",
      "[I 2024-09-02 17:49:06,894] Trial 49 finished with value: 141.5706086 and parameters: {'eta': 0.022671719157096752, 'max_depth': 10, 'gamma': 17.111513413549492, 'subsample': 0.5413039441883395, 'colsample_bytree': 0.44252143694709417, 'min_child_weight': 0.0470325980647457, 'booster': 'gbtree'}. Best is trial 12 with value: 139.5458466.\n",
      "[I 2024-09-02 17:49:33,537] Trial 50 pruned. Trial was pruned at iteration 20.\n",
      "[I 2024-09-02 17:50:43,779] Trial 51 pruned. Trial was pruned at iteration 56.\n",
      "[I 2024-09-02 17:52:50,191] Trial 52 finished with value: 156.8171542 and parameters: {'eta': 0.013876194084351283, 'max_depth': 9, 'gamma': 1.9619387527152656, 'subsample': 0.6564742481387108, 'colsample_bytree': 0.4507501143018977, 'min_child_weight': 0.991295496946735, 'booster': 'gbtree'}. Best is trial 12 with value: 139.5458466.\n",
      "[I 2024-09-02 17:53:31,613] Trial 53 pruned. Trial was pruned at iteration 31.\n",
      "[I 2024-09-02 17:53:57,641] Trial 54 pruned. Trial was pruned at iteration 20.\n",
      "[I 2024-09-02 17:55:46,322] Trial 55 finished with value: 164.9172514 and parameters: {'eta': 0.028237123386293448, 'max_depth': 3, 'gamma': 39.13131602058482, 'subsample': 0.7099026374246103, 'colsample_bytree': 0.4791467262004481, 'min_child_weight': 2.257070258077399, 'booster': 'gbtree'}. Best is trial 12 with value: 139.5458466.\n",
      "[I 2024-09-02 17:56:37,977] Trial 56 pruned. Trial was pruned at iteration 43.\n",
      "[I 2024-09-02 17:57:06,949] Trial 57 pruned. Trial was pruned at iteration 20.\n",
      "[I 2024-09-02 17:57:33,556] Trial 58 pruned. Trial was pruned at iteration 20.\n",
      "[I 2024-09-02 17:58:02,955] Trial 59 pruned. Trial was pruned at iteration 20.\n",
      "\n",
      "Hyper-Parameter Optimization successfully finished.\n",
      "  Number of finished trials:  60\n",
      "  Best trial:\n",
      "    Value: 139.5458466\n",
      "    Params: \n",
      "    eta: 0.014151015803837208\n",
      "    max_depth: 8\n",
      "    gamma: 11.175401032472807\n",
      "    subsample: 0.4793381145997095\n",
      "    colsample_bytree: 0.49722632835890934\n",
      "    min_child_weight: 6.304612706657637\n",
      "    booster: gbtree\n",
      "    opt_rounds: 100\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\scukp\\AppData\\Local\\Temp\\ipykernel_11644\\626884004.py:19: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "TX 1:13:43.041845\n"
     ]
    }
   ],
   "source": [
    "# \"OR\"\n",
    "for location in [\"GA\",\"HI\",\"OR\",\"TX\"]:\n",
    "    start = datetime.datetime.now()\n",
    "    for seed in range(2005, 2025):\n",
    "        XGBoost_training(location, seed)\n",
    "    end = datetime.datetime.now()\n",
    "    print(location, end - start)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "0eaa0b02",
   "metadata": {},
   "outputs": [],
   "source": [
    "#####################################################\n",
    "###                  Evaluation                   ###  \n",
    "#####################################################"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "d6d2098b",
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "from xgboostlss.distributions import *\n",
    "from xgboostlss.distributions.distribution_utils import DistributionClass\n",
    "from sklearn import datasets\n",
    "from sklearn.model_selection import train_test_split"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "d00c9891",
   "metadata": {},
   "outputs": [],
   "source": [
    "data = pd.read_csv(\"D:/Jupyter/Research/Competition/ICLR/data/preprocess/TX.csv\")\n",
    "y_train = np.array(data[\"total_grid\"])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "35400f23",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Fitting of candidate distributions completed: 100%|██████████████████████████████████████| 8/8 [00:04<00:00,  1.64it/s]\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAArMAAAHFCAYAAADhdHFaAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8fJSN1AAAACXBIWXMAAA9hAAAPYQGoP6dpAACN+ElEQVR4nOzdd3hUZdrH8e9Mei+EFCBA6L1Ls1BEKfbeAdfe1r4r++5aV1l3de1lXRVsKGLBFRVFFFBp0ouAlJBQklBCes+c94+TGTKkTcJMJuX3ua655syZ55y5Mxng5pn73I/FMAwDEREREZFmyOrtAEREREREGkrJrIiIiIg0W0pmRURERKTZUjIrIiIiIs2WklkRERERabaUzIqIiIhIs6VkVkRERESaLSWzIiIiItJsKZkVERERkWZLyayIGxw+fBh/f38sFovTbcGCBd4OzSv27t3r9D6MHTvW2yF51NixY6v87i0WC1arldDQUJKSkjjvvPN48803KSkp8Xa4HjF79uxq34PqbpGRkbUe++ijj3okxiVLllSJxcfHh8DAQGJiYujVqxfnnHMOTzzxBHv37vVIDN5y4me0pf180ropmRVxg/fff5/S0tIq+2fPnu321zrxH+Tp06e7/TXEPQzDID8/n71797JgwQJuuukmRowYQXZ2trdDa1b/4fBksmuz2SguLubo0aPs2LGDr7/+mocffpiuXbsybdo08vLy3PZaTZmSXWnOfL0dgEhL8M4771S7/8svvyQzM5Po6OhGjki8adiwYXTq1AnDMNizZw8bNmxwPLdhwwaeeuopnn76ae8F2AhiYmIYM2ZMtc+FhIQ4Pe7cuTOXXHKJ43GfPn08GptdcHAwkydPpry8nMOHD7N+/XoKCgoAM8l99913+fXXX/npp59o06ZNo8TkKWPGjCEmJsbx+MTfgUhzpmRW5CStX7+ejRs3Oh77+fk5ZmlLSkqYM2cOd955p7fCEy+44447nGbM77vvPp577jnH48WLF3shqsbVt29fPvnkE5fGjh071iszw23btnWKsbCwkJdffpn/+7//c/wZ3rZtG1dccQXff/99o8fnTo899pi3QxDxGJUZiJykE0sJTvwK1JVSgyVLljB9+nR69epFeHg4AQEBtG/fnnHjxvHEE084xlgsFsaNG+d07DvvvFNt2YErXyPX9dXiSy+9xLRp0xgyZAgdOnQgJCSEgIAA4uLiGDNmDP/85z/Jzc2t8+dzVVpaGn5+fo54hg8fXu24GTNmOMX94YcfOp5btWoV06ZNo2fPnoSEhODn50fbtm3p06cPl19+Of/6179IT093W8yuOPPMM50eFxYWVjvOMAwWLFjA5ZdfTufOnQkKCiI4OJiePXty2223sX379mqPy8/P55lnnuGMM84gNjYWf39/QkND6dSpE6effjr33nuvo37b/rlISkpyOsfSpUu9VnZQUxmBff/111/vNP6xxx7zSNlBUFAQDz74IG+99ZbT/sWLF7Nw4cIq48vKypgzZw7nn38+HTp0IDAwkLCwMPr378+DDz7I/v37q32dzp07O8UP8OmnnzJu3DgiIiIICgpi6NChvPfee9Uev2/fPh544AEGDx5MZGQkvr6+REVF0a1bNyZPnszDDz/M+vXrnY6p6c+6ff/SpUudxiclJTmNT05OplevXo7HISEhZGVlVYnts88+czruwQcfrPZnEHErQ0QarKSkxIiJiTEAAzBCQkKM/Px8Y8SIEY59gLF58+Zqj8/PzzcuvfRSp7HV3QzDMH788cc6xwHGtGnTDMMwjOTkZKf9Y8aMqfL6Y8aMcRqTnJzs9HxISEidr9epUycjNTXV6ThXXrsmF154odOx27Ztc3reZrMZiYmJjufbtGljFBUVGYZhGHPnzjWsVmudMX/55Zcux+OKE9/HWbNmOT1/7733Vvs7qiwnJ8eYPHlyrXH7+fkZr7/+utNxRUVFxtChQ+v8mYcOHWoYRtXfTU23+vzODMMwZs2a1eDjTzz2kUceqXZ/TTf7+Lqc+GeoU6dONY4dNGiQ09hrr73W6fmDBw8aw4cPrzWusLAw44svvqhy7k6dOjmNmzp1ao3neO6555yO3bFjhxEdHV3ne3L//fc7HVfTn/UT99d0S05ONt544w2nff/+97+r/GwXXXSR43mLxWLs3LnTpd+NyMlQmYHISfjyyy85cuSI4/H5559PcHAwV111FatWrXLsnz17Ns8880yV46+55hrmz5/vtK9Tp0707t2bkpIS1q5d67hYqG3btlxyySUcPnyYZcuWOY0fNmyY4/Epp5zirh8PgLCwMHr06EFUVBQhISHk5uayceNGjh49CkBKSgp33XVXlZ+joW6++Wanc7333ns8+eSTjsdLlixh3759jsfT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sTVOTVydUfT393d6bL9gy+7gwYPs3r27xuMrz7IEBASwfft2fvzxRz799FM++eQTp6/3PaHyrGtOTg5vvPEG3333nWPf1KlTq/3adtiwYbzxxhv8/vvvFBYWsnv3bubNm0e7du0cY1599VWKioo8Gv+JTlzCNS0tzbF94ozdRx99hGEYtd4qz4oGBQVx1113sXjxYrKysjh69CirVq1yeg+PHTvGrFmzHI9d/Rw9+uijNcbQWKvPeXIWvTqzZ8+u8ue78n9GTvx9rVy5ss7fl30W3h3at2/Pk08+yZo1axwXfi1atIjTTz/dMca+2IOr6vMed+7cmcsuu8zx+O2333b6z/2UKVPo2LGjy+cTOVlKZkUaoKHL1FY+7sILL3R67p133qnS37K0tLTKawUFBTk9rlxPV1lMTIxTQrtjxw5+/PFHwKytvPnmm6tdgrfya9tZrVan1/3888893kR+8uTJJCYmOh4/9NBDTrPLJ5YYALz44ossWbLEMc7f358uXbpw8cUX07VrV8e44uJipx6Z06dPd+qN6e6vx9PS0qrMxFZOrs8//3yn5/72t79V+SobzN/1K6+8wl133eXYt2HDBv7zn/9w8OBBx77o6GiGDx9eZea6cn/dEz9HlY9valz9zJ+swsJC/vnPf1b5bE2YMMFRFwpVf1/33ntvteU4u3bt4umnn+bxxx93W4yff/45n376qWOZXavVSrt27ZgwYYJTMgvUq59yfd/jBx54wLGdmZnp1AP5tttuc/l1RdxBBS0i9XTiDCvA5s2bq515KSsrIz4+3jErunbtWrZs2UK/fv0488wzOe+88/jyyy8B86vnG2+8kSeeeILevXtTVlbGunXryMzMdJoBs399br9A5fvvv2fUqFG0b98eMBcUGDp0KP7+/pxxxhmOpNMwDM4880wSExNJS0urNZEFGDlypCP5LSwspHfv3owYMYL09HTWrVvn8dky+4Vg9ob4lWdSTzvtNHr37l3lmLfffpuNGzcSHh5O7969iY2NxTAMtm7d6pQcxsTE0LZtW4/Fbm/NBeY/9KtWrXIskwrm18iVE82zzz6bs846y1F7uXPnTrp3786QIUNISEigoKCAXbt2ORrdV66v3rt3L7feeiu33XYbXbt2JSkpiZCQEMfrVlb5PYuNjSU6OtpR+rJz504GDRpE165dsVgs3HjjjU4JnDf16tXL6fGsWbPYtWuX4+v55557zuk/Pq46fPgwl156KeXl5Rw5coR169Y5/Z7AbFE2d+5cp33Tp0/nxRdfdFyktWLFCjp27MjQoUNp27YtOTk57Nixw/EfhGnTptU7tposXbqUF154AX9/f3r16kX79u3x9/dn3759rFu3zmlsdX9GatKrVy+n0oqLLrqIESNGEBAQQNeuXassvzx06FDGjRvn+DvCrnPnzk3mcyOtSKP0TBBpQebNm+fUfqZv3761jr/pppucxlduZp6Xl1dlkYDqbie67LLLahxbeUGAlStXGv7+/tWOO+2004zBgwfX2I5n1apVRmBgYLXHDh8+vEoMP/74o+NYd7V92rdvn+Hj41Pl9d99991qxw8cOLDO99LHx8d47733nI6bNm1ajT+LK1xtzWV//VdeeaXKObKzs42JEye6dI7KLZk+//xzl44ZMmSIkZeX5/SaDz74YI3jX3rppXq9B55YNKGy2hYoqGlRkhO5uvAIYFitVmP69OlV3jO7ffv2GcOGDXPpXDfccIPTsSe25jrRI4884vR85bZqd999t0uvecsttzids67WWxs2bDB8fX2rPZd9wY0Tff3111XGPvnkky78JkTcS2UGIvV04tf+V155Za3jr7jiCqfHH3zwgeNr8JCQEMdX9tdddx3du3cnJCQEf39/EhISGDt2bLVfUb799tvcf//9dO3atUptbGUjRoxg2bJlTJw4kfDwcAIDA+nfvz/PPPMMP/zwA+Hh4TUeO3z4cFasWMH5559PZGQkAQEBdO/enb/97W8sXbrUqaG6p3To0MGxOIBdVFSUU71eZc8//zx//etfmTBhAl26dCEiIgKr1UpoaCh9+/blpptuYs2aNVx77bUej93Ox8eHyMhIBg8ezN13382mTZu4/fbbq4wLDw9n4cKFfPXVV1x99dV07dqV4OBgfHx8iIqKYvDgwdxwww189NFH/O9//3Mcd9ppp/H6668zbdo0BgwYQEJCAv7+/vj5+ZGQkMCECRN46aWX+OWXXwgJCXF6zSeffJK///3v9OnTx+lCoqboyy+/5KabbiIxMdGtV8lbLBb8/PyIjo6mR48eTJo0iUcffZTdu3cza9asKu+ZXYcOHVi5ciUfffQRF110ER07diQwMBA/Pz9iYmIYPnw4d9xxB//73/947bXX3Bbvrbfeyj//+U8uuugievXqRUxMDL6+vgQFBZGUlMQll1zC/PnznTpauGLgwIEsXLiQM888k8jISJe+eZk8ebLT4hp+fn5ebSUorZfFMBphORwRERFpUYqLi+nataujvvaKK67go48+8nJU0hqpZlZERERcYu8sUlhYyFdffeVIZK1Wq9NCICKNScmsiIiIuCQzM5MHH3ywyv4HHniAIUOGeCEiESWzIiIi0gChoaH06NGD22+/XbWy4lWqmRURERGRZkvdDERERESk2VIyKyIiIiLNVqurmbXZbBw8eJCwsLBGX+9bREREROpmGAa5ubm0a9cOq7X2uddWl8wePHiwQcseioiIiEjj2rdvHx06dKh1TKtLZsPCwgDzzalt9SMRERER8Y6cnBwSExMdeVttWl0yay8tCA8PVzIrIiIi0oS5UhKqC8BEREREpNlSMisiIiIizZaSWRERERFptlpdzayIiEhrV15eTmlpqbfDkFbO39+/zrZbrlAyKyIi0koYhkF6ejpZWVneDkUEq9VKUlIS/v7+J3UeJbMiIiKthD2RjY2NJTg4WIsHidfYF7FKS0ujY8eOJ/VZVDIrIiLSCpSXlzsS2TZt2ng7HBHatm3LwYMHKSsrw8/Pr8Hn0QVgIiIirYC9RjY4ONjLkYiY7OUF5eXlJ3UeJbMiIiKtiEoLpKlw12dRyayIiIiINFtKZkVEREQayGKxMH/+fG+H0aopmRUREZFmYcWKFfj4+HDOOefU67jOnTvz/PPPeyYo8TolsyIiItIsvPXWW9x1110sW7aMgwcPejscaSKUzIqIiEiTl5eXx9y5c7nttts455xzmD17ttPzX375JaeccgqBgYHExMRw0UUXATB27FhSUlK49957sVgsjouOHn30UQYNGuR0jueff57OnTs7Hv/666+cddZZxMTEEBERwZgxY1i3bp0nf0xpACWzIs1Euc1gyY5DfLxmH6v2HCWvuMzbIYlIM2cYBgUlZY1+Mwyj3rF+/PHH9OrVi549e3Lttdfy9ttvO87z1VdfcdFFFzFlyhTWr1/P4sWLGT58OACfffYZHTp04PHHHyctLY20tDSXXzM3N5dp06bx888/s3LlSrp3786UKVPIzc2td/ziOVo0QaSJMwyD91em8OqS3aRlFzn2Rwb78cQF/ThvYDsvRicizVlhaTl9Hv620V/3t8cnEuxfvxTk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Pt3ln/f222/H19eXNWvWcPnll9O7d2+6dOnCBRdcwFdffcV5550HVF/akJWVhcViYcmSJY6f22Kx8O233zJ48GCCgoIYP348hw4d4ptvvqF3796Eh4dz9dVXV5nxLSsr48477yQiIoKYmBj+9re/Oa0wWVxczAMPPED79u0JCQlhxIgRjtdtLF5NZl977TUGDBhAeHg44eHhjBo1im+++abWY+bNm0evXr0IDAykf//+fP31140UrYj7fLh6H6XlBkM6RjIoMbLhJzq2F2afB2kbISACJv0D7t0Cty+HP66n9MwnKDb8GGlbT+6caWCzuetHEJGWwDCgJL/xbye53HZeXh7vv/8+3bp1o02bNgCUlpYyceJEwsLC+Omnn/jll18IDQ1l0qRJlJSUUFZWxoUXXsiYMWPYtGkTK1as4Oabb8ZisXDFFVdw//3307dvX9LS0khLS+OKK644qRgTExP59NNPAdixYwdpaWm88MILgFlHarFYajz26NGjfPfdd9xxxx2EhIRUO6a242vy6KOP8vLLL7N8+XJH4v/8888zZ84cvvrqK7777jteeuklp2PeeecdfH19Wb16NS+88AL//ve/efPNNx3P33nnnaxYsYKPPvqITZs2cdlllzFp0iR27txZ7/gayqtlBh06dOAf//gH3bt3xzAM3nnnHS644ALWr19P3759q4xfvnw5V111FTNnzuTcc89lzpw5XHjhhaxbt85RnyLS1JXbDMdFWVNHdW74ibL2wTvnQc5+iOkB076EsEpfb1l98Dv9jzy7tz2377qViLRf4Nf/wohbTu4HEJGWo7QAnmrX+K/7l4PgX32SVpMFCxYQGhoKQH5+PgkJCSxYsACr1ZyXmzt3LjabjTfffNOR6M2aNYvIyEiWLFnCsGHDyM7O5txzz6Vr164A9O7d23H+0NBQfH19XS4TuOqqq/Dx8XE8fv/9951qbn18fIiOjgYgNjbW6SKoiIgIevbsWeO5d+3ahWEYVcbExMRQVFQEwB133MHTTz/tUqx2f//73zn11FMBuOGGG5gxYwa7d++mS5cuAFx66aX8+OOP/PnPf3Yck5iYyHPPPYfFYqFnz55s3ryZ5557jptuuonU1FRmzZpFamoq7dqZn6MHHniAhQsXMmvWLJ566ql6xddQXp2ZPe+885gyZQrdu3enR48ePPnkk4SGhrJy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",
      "text/plain": [
       "<Figure size 800x500 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>nll</th>\n",
       "      <th>distribution</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>rank</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>-6.828975e+03</td>\n",
       "      <td>Gumbel</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>-5.455586e+03</td>\n",
       "      <td>StudentT</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>-5.355247e+03</td>\n",
       "      <td>Laplace</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>-5.306276e+03</td>\n",
       "      <td>Gaussian</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>-4.215146e+03</td>\n",
       "      <td>Cauchy</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>1.181085e+04</td>\n",
       "      <td>LogNormal</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>1.266531e+04</td>\n",
       "      <td>Weibull</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8</th>\n",
       "      <td>inf</td>\n",
       "      <td>Gamma</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "               nll distribution\n",
       "rank                           \n",
       "1    -6.828975e+03       Gumbel\n",
       "2    -5.455586e+03     StudentT\n",
       "3    -5.355247e+03      Laplace\n",
       "4    -5.306276e+03     Gaussian\n",
       "5    -4.215146e+03       Cauchy\n",
       "6     1.181085e+04    LogNormal\n",
       "7     1.266531e+04      Weibull\n",
       "8              inf        Gamma"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "xgblss_dist_class = DistributionClass()\n",
    "candidate_distributions = [Gaussian, StudentT, Gamma, Cauchy, LogNormal, Weibull, Gumbel, Laplace]\n",
    "\n",
    "dist_nll = xgblss_dist_class.dist_select(target=y_train, candidate_distributions=candidate_distributions, max_iter=50, plot=True, figure_size=(8, 5))\n",
    "dist_nll"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b2518f30",
   "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.11.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
