{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "!pip install deepctr_torch"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "import torch\n",
    "from sklearn.metrics import log_loss, roc_auc_score\n",
    "from sklearn.model_selection import train_test_split\n",
    "from sklearn.preprocessing import LabelEncoder, MinMaxScaler\n",
    "\n",
    "from deepctr_torch.inputs import SparseFeat, DenseFeat, get_feature_names\n",
    "from deepctr_torch.models import *\n",
    "\n",
    "import numpy as np\n",
    "\n",
    "training_name = \"criteo_regularization_3e-7_BN\"\n",
    "\n",
    "if __name__ == \"__main__\":\n",
    "    # data = pd.read_csv('./data/criteo_sample.txt')\n",
    "    \n",
    "    col_names = ['label']\n",
    "    col_names += ['I' + str(i) for i in range(1, 14)]\n",
    "    col_names += ['C' + str(i) for i in range(1, 27)]\n",
    "    data = pd.read_csv('./data/train_15M_rand.txt', delimiter='\\t', names=col_names)\n",
    "\n",
    "    sparse_features = ['C' + str(i) for i in range(1, 27)]\n",
    "    dense_features = ['I' + str(i) for i in range(1, 14)]\n",
    "\n",
    "    data[sparse_features] = data[sparse_features].fillna('-1', )\n",
    "    data[dense_features] = data[dense_features].fillna(0, )\n",
    "    target = ['label']\n",
    "\n",
    "    # 1.Label Encoding for sparse features, and do simple Transformation for dense features\n",
    "    for feat in sparse_features:\n",
    "        lbe = LabelEncoder()\n",
    "        data[feat] = lbe.fit_transform(data[feat])\n",
    "    mms = MinMaxScaler(feature_range=(0, 1))\n",
    "    data[dense_features] = mms.fit_transform(data[dense_features])\n",
    "\n",
    "    # 2.count #unique features for each sparse field, and record dense feature field name\n",
    "\n",
    "    fixlen_feature_columns = [SparseFeat(feat, data[feat].nunique())\n",
    "                              for feat in sparse_features] + [DenseFeat(feat, 1, )\n",
    "                                                              for feat in dense_features]\n",
    "\n",
    "    dnn_feature_columns = fixlen_feature_columns\n",
    "    linear_feature_columns = fixlen_feature_columns\n",
    "\n",
    "    feature_names = get_feature_names(\n",
    "        linear_feature_columns + dnn_feature_columns)\n",
    "\n",
    "    # 3.generate input data for model\n",
    "\n",
    "    # train, test = train_test_split(data, test_size=0.2)\n",
    "    \n",
    "    sample_size = len(data)\n",
    "    test_index = np.loadtxt(\"./data/test_index_10M.txt\", dtype ='int')\n",
    "    train_index = np.array(sorted(set(range(sample_size)) -  set(test_index)))\n",
    "\n",
    "    train = data.iloc[train_index.tolist()]\n",
    "    test = data.iloc[test_index.tolist()]\n",
    "    \n",
    "    for weight in [0.0000005, 0.0000007]:\n",
    "        if weight == 0.0000005:\n",
    "            training_name = \"criteo_regularization_5e-7_BN\"\n",
    "        if weight == 0.0000007:\n",
    "            training_name = \"criteo_regularization_7e-7_BN\"\n",
    "        for seed in range(0, 60):\n",
    "            if seed in [0, 1] and weight == 0.0000005:\n",
    "                continue\n",
    "            print(seed, weight)\n",
    "            num_train = len(train)\n",
    "            random_shuffle = np.random.permutation(num_train)\n",
    "            train_model_input = {name: train[name].iloc[random_shuffle] for name in feature_names}\n",
    "            # train_model_input = {name: train[name] for name in feature_names}\n",
    "            test_model_input = {name: test[name] for name in feature_names}\n",
    "\n",
    "            # 4.Define Model, train, predict and evaluate\n",
    "\n",
    "            device = 'cpu'\n",
    "            use_cuda = True\n",
    "            if use_cuda and torch.cuda.is_available():\n",
    "                print('cuda ready...')\n",
    "                device = 'cuda:0'\n",
    "\n",
    "            model = xDeepFM(\n",
    "                linear_feature_columns=linear_feature_columns, \n",
    "                dnn_feature_columns=dnn_feature_columns,\n",
    "                task='binary',\n",
    "                l2_reg_linear=weight,\n",
    "                l2_reg_embedding=weight,\n",
    "                device=device,\n",
    "                seed=seed,\n",
    "                dnn_dropout=0,\n",
    "                dnn_use_bn=True,\n",
    "                dnn_hidden_units=(512, 256, 128),\n",
    "                cin_layer_size=(256, 256),\n",
    "                # dnn_hidden_units=(128, 64, 32),\n",
    "                # cin_layer_size=(64, 64),\n",
    "            )\n",
    "\n",
    "            model.compile(\n",
    "                \"adagrad\", \n",
    "                \"binary_crossentropy\",\n",
    "                metrics=[\"binary_crossentropy\", \"auc\"],\n",
    "            )\n",
    "            model.fit(\n",
    "                train_model_input,\n",
    "                train[target].iloc[random_shuffle].values,\n",
    "                batch_size=1024,\n",
    "                epochs=1,\n",
    "                verbose=1,\n",
    "                validation_split=0.0,\n",
    "            )\n",
    "\n",
    "            pred_ans = model.predict(test_model_input, 1024)\n",
    "            y = test[target].values\n",
    "            np.savetxt(f\"./results/{training_name}/{seed}_{training_name}.txt\", pred_ans)\n",
    "            # np.savetxt(\"./results/y_15M_criteo.txt\", y)\n",
    "            print(\"\")\n",
    "            # print(\"test LogLoss\", round(log_loss(y, pred_ans), 4))\n",
    "            # print(\"test AUC\", round(roc_auc_score(y, pred_ans), 4))\n",
    "            print(\"test Calibration\", np.sum(pred_ans) / np.sum(y))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "col_names = ['label']\n",
    "col_names += ['I' + str(i) for i in range(1, 14)]\n",
    "col_names += ['C' + str(i) for i in range(1, 27)]\n",
    "data = pd.read_csv('./data/train_15M_rand.txt', delimiter='\\t', names=col_names)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "!mkdir ./results/criteo_BN_dropout_001"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [],
   "source": [
    "from sklearn.metrics import log_loss\n",
    "import json\n",
    "import numpy as np\n",
    "\n",
    "def calculate_bias_exp(p, y):\n",
    "    num_round = 4\n",
    "    b = 1\n",
    "    for i in range(num_round):\n",
    "        curr_calibration = np.sum(p) / np.sum(y)\n",
    "        p = p / (p + (1 - p) * curr_calibration)\n",
    "        b *= curr_calibration\n",
    "    return b\n",
    "\n",
    "def apply_bias_exp(p, b):\n",
    "    return p / (p + (1 - p) * b)\n",
    "\n",
    "\n",
    "def calculate_logloss_and_cali_free_loss(ps, y, val_ratio=10, skip_log_loss=False):\n",
    "    num_model, num_examples = ps.shape\n",
    "    num_val = num_examples // val_ratio\n",
    "    log_loss_array = np.zeros(num_model)\n",
    "    cali_free_log_loss_array = np.zeros(num_model)\n",
    "    for i in range(num_model):\n",
    "        bias = calculate_bias_exp(ps[i, :num_val], y[:num_val])\n",
    "        p_corrected = apply_bias_exp(ps[i, num_val:], bias)\n",
    "        if skip_log_loss:\n",
    "            log_loss_array[i] = 0.0\n",
    "        else:\n",
    "            log_loss_array[i] = log_loss(y, ps[i])\n",
    "        cali_free_log_loss_array[i] = log_loss(y[num_val:], p_corrected)\n",
    "    return log_loss_array, cali_free_log_loss_array\n",
    "\n",
    "def get_avazu_result(key, num_model=60):\n",
    "    p_1 = np.loadtxt(f\"./results/{key}/0_{key}.txt\")\n",
    "    num_example = p_1.shape[0]\n",
    "    ps = np.zeros((num_model, num_example))\n",
    "    ps[0] = p_1\n",
    "    for i in range(1, num_model):\n",
    "        ps[i] = np.loadtxt(f\"./results/{key}/{i}_{key}.txt\")\n",
    "    return ps\n",
    "\n",
    "def get_train_labels(key, num_model=60):\n",
    "    p_1 = np.loadtxt(f\"./results/{key}/0_{key}_train_label.txt\")\n",
    "    num_example = p_1.shape[0]\n",
    "    ps = np.zeros((num_model, num_example))\n",
    "    ps[0] = p_1\n",
    "    for i in range(1, num_model):\n",
    "        ps[i] = np.loadtxt(f\"./results/{key}/{i}_{key}_train_label.txt\")\n",
    "    return ps\n",
    "\n",
    "\n",
    "def get_y():\n",
    "    return np.loadtxt(\"./results/y_15M_criteo.txt\")\n",
    "\n",
    "def save_loss_results(\n",
    "    results, \n",
    "    file_name=\"./results/loss_results_criteo.txt\", \n",
    "    append=True, \n",
    "    metrics_to_include=[\"log_loss\", \"cali_free_log_loss\"],\n",
    "):\n",
    "    result_json = {}\n",
    "    for key, item in results.items():\n",
    "        result_json[key] = {}\n",
    "        for metric in metrics_to_include:\n",
    "            if metric in item.keys():\n",
    "                result_json[key][metric] = item[metric].tolist()\n",
    "    if append:\n",
    "        f = open(file_name)\n",
    "        previous_results = json.load(f)\n",
    "        for key, item in previous_results.items():\n",
    "            if key not in result_json.keys():\n",
    "                result_json[key] = {}\n",
    "            for metric in metrics_to_include:\n",
    "                if metric in item.keys():\n",
    "                    result_json[key][metric] = item[metric]\n",
    "    json_object = json.dumps(result_json)\n",
    "    with open(file_name, \"w\") as outfile:\n",
    "        outfile.write(json_object)\n",
    "\n",
    "keys = [\n",
    "    # \"criteo_baseline\",\n",
    "    \"criteo_BN\",\n",
    "    # \"criteo_smaller_arch\",\n",
    "    # \"criteo_dropout_07\",\n",
    "    # \"criteo_regularization_1e-6\",\n",
    "    # \"criteo_regularization_3e-7\",\n",
    "    # \"criteo_regularization_5e-7\",\n",
    "    # \"criteo_regularization_7e-7\",\n",
    "    # \"criteo_regularization_1e-6_BN\",\n",
    "    # \"criteo_regularization_2e-6_BN\",\n",
    "    # \"criteo_regularization_3e-6_BN\",\n",
    "    # \"criteo_regularization_4e-6_BN\",\n",
    "    # \"criteo_regularization_5e-6_BN\",\n",
    "    # \"criteo_regularization_1e-5_BN\",\n",
    "    # \"criteo_regularization_1e-3_BN\",\n",
    "    # \"criteo_regularization_1e-4_BN\",\n",
    "    \"criteo_regularization_1e-1_BN\",\n",
    "    # \"criteo_regularization_1e-2_BN\",\n",
    "    # \"criteo_regularization_3e-2_BN\",\n",
    "    # \"criteo_regularization_5e-2_BN\",\n",
    "    \"criteo_regularization_7e-2_BN\",\n",
    "    \"criteo_regularization_15e-2_BN\",\n",
    "    \"criteo_regularization_2e-1_BN\",\n",
    "    # \"criteo_BN_sparse_feature_minus_26\",\n",
    "    # \"criteo_BN_dense_feature_minus_8_to_13\",\n",
    "    # \"criteo_BN_dense_feature_minus_11_to_13\",\n",
    "    # \"criteo_BN_dense_feature_minus_13\",\n",
    "    # \"criteo_BN_DCN\",\n",
    "    # \"criteo_BN_DCNMix\",\n",
    "    # \"criteo_BN_DeepFM\",\n",
    "    # \"criteo_BN_dropout_001\",\n",
    "    # \"criteo_BN_dropout_01\",\n",
    "]\n",
    "\n",
    "results = {\n",
    "    key: {} for key in keys\n",
    "}\n",
    "y = get_y()\n",
    "for key in keys:\n",
    "    results[key][\"ps\"] = get_avazu_result(key, num_model=60)\n",
    "    # results[key][\"train_labels\"] = get_train_labels(key, num_model=60)\n",
    "    # results[key][\"log_loss\"], results[key][\"cali_free_log_loss\"] = calculate_logloss_and_cali_free_loss(\n",
    "    #     ps=results[key][\"ps\"], \n",
    "    #     y=y,\n",
    "    # )\n",
    "    for val_ratio in [5, 20]:\n",
    "        _, results[key][f\"cali_free_log_loss_{val_ratio}\"] = calculate_logloss_and_cali_free_loss(\n",
    "            ps=results[key][\"ps\"], \n",
    "            y=y,\n",
    "            val_ratio=val_ratio,\n",
    "            skip_log_loss=True,\n",
    "        )\n",
    "    # results[key][\"calibration\"] = np.sum(results[key][\"ps\"], axis=1) / np.sum(y)\n",
    "\n",
    "\n",
    "save_loss_results(\n",
    "    results=results,\n",
    "    file_name=\"./results/loss_results_criteo.txt\", \n",
    "    append=True, \n",
    "    metrics_to_include=[\"log_loss\", \"cali_free_log_loss\", \"cali_free_log_loss_5\", \"cali_free_log_loss_20\"],\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "!pip install mlxtend"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "criteo_BN criteo_regularization_7e-2_BN\n",
      "p-value:  0.003999600039996\n",
      "log_loss variance:  5.792196173718872e-07 3.150425717434217e-06\n",
      "cali_free_log_loss variance:  7.197063406135733e-08 4.2358735577500337e-07\n",
      "log loss:  0.7811111111111111\n",
      "cali-free log loss:  0.8441666666666666\n",
      "\n",
      "criteo_BN criteo_regularization_1e-1_BN\n",
      "p-value:  0.00019998000199980003\n",
      "log_loss variance:  5.792196173718872e-07 2.3876574884544217e-06\n",
      "cali_free_log_loss variance:  7.197063406135733e-08 2.7252936742437383e-07\n",
      "log loss:  0.8233333333333334\n",
      "cali-free log loss:  0.8977777777777778\n",
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_3220/19370021.py:84: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  df = df.append(\n",
      "/tmp/ipykernel_3220/19370021.py:84: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  df = df.append(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "criteo_BN criteo_regularization_15e-2_BN\n",
      "p-value:  9.999000099990002e-05\n",
      "log_loss variance:  5.792196173718872e-07 6.918055495883699e-06\n",
      "cali_free_log_loss variance:  7.197063406135733e-08 8.707556771122026e-07\n",
      "log loss:  0.8997222222222222\n",
      "cali-free log loss:  0.9627777777777777\n",
      "\n",
      "criteo_BN criteo_regularization_2e-1_BN\n",
      "p-value:  9.999000099990002e-05\n",
      "log_loss variance:  5.792196173718872e-07 4.1737207826522126e-06\n",
      "cali_free_log_loss variance:  7.197063406135733e-08 4.004688842901291e-07\n",
      "log loss:  0.9097222222222222\n",
      "cali-free log loss:  0.9808333333333333\n",
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_3220/19370021.py:84: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  df = df.append(\n",
      "/tmp/ipykernel_3220/19370021.py:84: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  df = df.append(\n"
     ]
    }
   ],
   "source": [
    "# criteo experimental results\n",
    "\n",
    "# regularization weight: works\n",
    "    # (\"criteo_BN\", \"criteo_regularization_7e-2_BN\"),\n",
    "    # (\"criteo_BN\", \"criteo_regularization_1e-1_BN\"), \n",
    "    # (\"criteo_BN\", \"criteo_regularization_15e-2_BN\"),\n",
    "    # (\"criteo_BN\", \"criteo_regularization_2e-1_BN\"),\n",
    "# small arch: works\n",
    "    # (\"criteo_BN\", \"criteo_BN_small_arch\")\n",
    "# features: sparse feature works; dense feature works\n",
    "    # (\"criteo_BN\", \"criteo_BN_sparse_feature_minus_26\")\n",
    "    # (\"criteo_BN\", \"criteo_BN_dense_feature_minus_13\"),\n",
    "# different models: works, but the p-value is large (actually not very good....)\n",
    "# dropout works\n",
    "    # (\"criteo_BN\", \"criteo_BN_dropout_01\")\n",
    "\n",
    "\n",
    "\n",
    "from mlxtend.evaluate import permutation_test\n",
    "import json\n",
    "import pandas as pd\n",
    "import numpy as np\n",
    "\n",
    "f = open(\"./results/loss_results_criteo.txt\")\n",
    "results = json.load(f)\n",
    "metrics = [\"log_loss\", \"cali_free_log_loss\", \"cali_free_log_loss_5\", \"cali_free_log_loss_20\"]\n",
    "for key, value in results.items():\n",
    "    for metric in metrics:\n",
    "        if metric in value.keys():\n",
    "            value[metric] = np.array(value[metric])\n",
    "\n",
    "keys = list(results.keys())\n",
    "\n",
    "def interpret_result(results, key1, key2, cali_free_version=\"cali_free_log_loss\"):\n",
    "\n",
    "    def get_better_percetage(loss1, loss2): # get the percetage of loss1 < loss2\n",
    "        num_model = loss1.shape[0]\n",
    "        assert num_model == loss2.shape[0]\n",
    "        num_greater = 0\n",
    "        for i in range(num_model):\n",
    "            for j in range(num_model):\n",
    "                if loss1[i] < loss2[j]:\n",
    "                    num_greater += 1\n",
    "        return num_greater / (num_model ** 2)\n",
    "\n",
    "    p_value = permutation_test(\n",
    "        results[key1][\"log_loss\"], \n",
    "        results[key2][\"log_loss\"],\n",
    "        method='approximate',\n",
    "        num_rounds=10000,\n",
    "        seed=0,\n",
    "    )\n",
    "    \n",
    "    print(key1, key2)\n",
    "    print(\"p-value: \", p_value)\n",
    "    log_loss_result = get_better_percetage(results[key1][\"log_loss\"], results[key2][\"log_loss\"])\n",
    "    print(\"log_loss variance: \", np.var(results[key1][\"log_loss\"]), np.var(results[key2][\"log_loss\"]))\n",
    "    cali_free_log_loss_result = get_better_percetage(results[key1][cali_free_version], results[key2][cali_free_version])\n",
    "    print(\"cali_free_log_loss variance: \", np.var(results[key1][cali_free_version]), np.var(results[key2][cali_free_version]))\n",
    "    print(\"log loss: \", log_loss_result)\n",
    "    print(\"cali-free log loss: \", cali_free_log_loss_result)\n",
    "    print()\n",
    "    return log_loss_result, cali_free_log_loss_result\n",
    "\n",
    "\n",
    "def generate_excel(results, key_pairs, name_dict, name_pairs, file_name):\n",
    "\n",
    "    def get_model_name(key, index, tuple_index, name_dict, name_pairs):\n",
    "        if name_dict is not None:\n",
    "            return name_dict[key]\n",
    "        if name_pairs is not None:\n",
    "            return name_pairs[index][tuple_index]\n",
    "        return key\n",
    "        \n",
    "\n",
    "    df = pd.DataFrame(columns=['Pipeline A', 'Pipeline B', 'Log Loss Accuracy', 'Cali-Free Accuracy'])\n",
    "    for index, key_pair in enumerate(key_pairs):\n",
    "        log_loss_result, cali_free_log_loss_result = interpret_result(\n",
    "            results, \n",
    "            key_pair[0], \n",
    "            key_pair[1], \n",
    "            cali_free_version=\"cali_free_log_loss_20\",\n",
    "        )\n",
    "        df = df.append(\n",
    "            {\n",
    "                'Pipeline A': get_model_name(key_pair[0], index, 0, name_dict, name_pairs), \n",
    "                'Pipeline B': get_model_name(key_pair[1], index, 1, name_dict, name_pairs), \n",
    "                'Log Loss Accuracy': f\"{round(log_loss_result * 100, 1)}%\",\n",
    "                'Cali-Free Accuracy': f\"{round(cali_free_log_loss_result* 100, 1)}%\",\n",
    "            },\n",
    "            ignore_index = True,\n",
    "        )\n",
    "    df.to_excel(f\"./cali_free_paper_results/{file_name}\", index=False)\n",
    "\n",
    "\n",
    "key_pairs = [\n",
    "    (\"criteo_BN\", \"criteo_regularization_7e-2_BN\"),\n",
    "    (\"criteo_BN\", \"criteo_regularization_1e-1_BN\"), \n",
    "    (\"criteo_BN\", \"criteo_regularization_15e-2_BN\"),\n",
    "    (\"criteo_BN\", \"criteo_regularization_2e-1_BN\"),\n",
    "]\n",
    "name_dict = {\n",
    "    \"criteo_BN\": \"Baseline\",\n",
    "    \"criteo_regularization_7e-2_BN\": \"0.07\",\n",
    "    \"criteo_regularization_1e-1_BN\": \"0.1\",\n",
    "    \"criteo_regularization_15e-2_BN\": \"0.15\",\n",
    "    \"criteo_regularization_2e-1_BN\": \"0.2\",\n",
    "}\n",
    "name_pairs = None\n",
    "generate_excel(results, key_pairs, name_dict, name_pairs, \"regularizations_20.xlsx\")\n",
    "\n",
    "\n",
    "# key_pairs = [\n",
    "#     (\"criteo_BN\", \"criteo_BN_small_arch\"), # arch size\n",
    "#     (\"criteo_BN\", \"criteo_BN_dropout_01\"), # Dropout\n",
    "# ]\n",
    "# name_pairs = [\n",
    "#     (\"Baseline Arch\", \"Smaller Arch\"),\n",
    "#     (\"no Dropout\", \"Dropout w/ p = 0.1\"),\n",
    "# ]\n",
    "# name_dict = None\n",
    "# generate_excel(results, key_pairs, name_dict, name_pairs, \"hyper_parameters.xlsx\")\n",
    "\n",
    "# compare model architectures\n",
    "# key_pairs = [\n",
    "#     (\"criteo_BN_DCN\", \"criteo_BN_DCNMix\"), \n",
    "#     (\"criteo_BN_DeepFM\", \"criteo_BN_DCN\"), \n",
    "#     (\"criteo_BN_DeepFM\", \"criteo_BN_DCNMix\"), \n",
    "#     (\"criteo_BN\", \"criteo_BN_DCNMix\"), \n",
    "#     (\"criteo_BN\", \"criteo_BN_DCN\"), \n",
    "#     (\"criteo_BN\", \"criteo_BN_DeepFM\"), \n",
    "# ]\n",
    "# name_dict = None\n",
    "# name_pairs = None\n",
    "# generate_excel(results, key_pairs, name_dict, name_pairs, \"model_architectures.xlsx\")\n",
    "\n",
    "\n",
    "# # for i in range(len(keys)):\n",
    "# #     interpret_result(results, \"criteo_BN\", keys[i])\n",
    "\n",
    "# for key in [\n",
    "#     # \"criteo_BN_DCN\",\n",
    "#     # \"criteo_BN_DCNMix\",\n",
    "#     # \"criteo_BN_DeepFM\",\n",
    "#     \"criteo_BN_dropout_01\",\n",
    "# ]:\n",
    "#     interpret_result(results, \"criteo_BN\", key)\n",
    "\n",
    "# # interpret_result(results, \"criteo_BN\", \"criteo_BN_dense_feature_minus_13\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'criteo_BN_DCN': {'log_loss': array([0.44908102, 0.45116924, 0.44942759, 0.44882326, 0.44905293,\n",
       "         0.44906797, 0.44875564, 0.44921452, 0.45154092, 0.44861598,\n",
       "         0.44959415, 0.44971104, 0.45350426, 0.44917826, 0.44859145,\n",
       "         0.44944734, 0.44878521, 0.448869  , 0.44935993, 0.44907762,\n",
       "         0.44924678, 0.44881511, 0.44889722, 0.44924965, 0.44933834,\n",
       "         0.44923906, 0.4502647 , 0.44926469, 0.44939736, 0.44899961,\n",
       "         0.44981034, 0.45213508, 0.44913449, 0.44885613, 0.4492164 ,\n",
       "         0.44926123, 0.44895938, 0.44885874, 0.44841133, 0.4490447 ,\n",
       "         0.44914107, 0.44928667, 0.44913836, 0.44876308, 0.45066001,\n",
       "         0.44911678, 0.44961438, 0.44932585, 0.44924216, 0.4494983 ,\n",
       "         0.45062635, 0.44918122, 0.4491196 , 0.45062416, 0.44904644,\n",
       "         0.44950122, 0.44887872, 0.44882138, 0.44952087, 0.4493176 ]),\n",
       "  'cali_free_log_loss': array([0.44896609, 0.44995768, 0.44927994, 0.44880353, 0.44905775,\n",
       "         0.4489348 , 0.44870759, 0.44910916, 0.4499465 , 0.44854038,\n",
       "         0.44902044, 0.44953995, 0.45061744, 0.44908689, 0.4485571 ,\n",
       "         0.44904343, 0.44875575, 0.44884167, 0.44937302, 0.4490628 ,\n",
       "         0.44922426, 0.44881466, 0.44891455, 0.44913194, 0.44933032,\n",
       "         0.44918601, 0.4491502 , 0.44896111, 0.44905827, 0.44898292,\n",
       "         0.44952201, 0.45006747, 0.44883092, 0.44886303, 0.44907763,\n",
       "         0.44924624, 0.44895838, 0.44885835, 0.44839908, 0.44903362,\n",
       "         0.44913095, 0.44926612, 0.44912195, 0.44873274, 0.44950173,\n",
       "         0.44910275, 0.44936684, 0.44922058, 0.44914656, 0.44915568,\n",
       "         0.44996245, 0.44912229, 0.44909133, 0.44919307, 0.44895906,\n",
       "         0.44948652, 0.44885923, 0.44864104, 0.44916093, 0.44920194])},\n",
       " 'criteo_BN_DCNMix': {'log_loss': array([0.44902616, 0.44926417, 0.44957588, 0.44922854, 0.44939942,\n",
       "         0.44896785, 0.44938627, 0.44931455, 0.44906687, 0.44917481,\n",
       "         0.44886389, 0.44938805, 0.44923876, 0.44932313, 0.44907577,\n",
       "         0.4490949 , 0.45006015, 0.4494939 , 0.44914168, 0.44911207,\n",
       "         0.4493775 , 0.45270657, 0.4491239 , 0.44915438, 0.44882147,\n",
       "         0.44894945, 0.44893198, 0.44895267, 0.44901435, 0.44929955,\n",
       "         0.44948877, 0.44894875, 0.44892259, 0.45046113, 0.44865361,\n",
       "         0.45974966, 0.44911762, 0.45063306, 0.44943146, 0.44926452,\n",
       "         0.44958976, 0.44919404, 0.44929679, 0.4491492 , 0.44935343,\n",
       "         0.44905677, 0.44918229, 0.44926188, 0.44905614, 0.44914843,\n",
       "         0.44923175, 0.45203139, 0.44876813, 0.44925458, 0.45366539,\n",
       "         0.44927438, 0.44870208, 0.44940049, 0.44924039, 0.4491177 ]),\n",
       "  'cali_free_log_loss': array([0.44897412, 0.44927293, 0.44925478, 0.44923658, 0.44928809,\n",
       "         0.44893972, 0.44931547, 0.44929758, 0.44905864, 0.44907567,\n",
       "         0.4488465 , 0.44921381, 0.4491748 , 0.44904883, 0.44908055,\n",
       "         0.44901816, 0.44911604, 0.44914291, 0.44912929, 0.44909   ,\n",
       "         0.44922493, 0.45012104, 0.44896723, 0.44911228, 0.44880203,\n",
       "         0.44892851, 0.44895277, 0.44890106, 0.44892746, 0.44933648,\n",
       "         0.44908804, 0.44894924, 0.44885334, 0.44947781, 0.4486486 ,\n",
       "         0.45200555, 0.44910945, 0.44962695, 0.44936604, 0.44918931,\n",
       "         0.44921966, 0.44922505, 0.44918578, 0.4491207 , 0.44928404,\n",
       "         0.44895144, 0.44918879, 0.44922306, 0.44903917, 0.44914482,\n",
       "         0.44920118, 0.44957359, 0.44875679, 0.44924172, 0.45040518,\n",
       "         0.44914359, 0.44868874, 0.44927873, 0.44923552, 0.44909172])},\n",
       " 'criteo_BN_DeepFM': {'log_loss': array([0.44934415, 0.44901914, 0.44909463, 0.44911391, 0.44904449,\n",
       "         0.44902331, 0.45067817, 0.44951316, 0.44887879, 0.44872185,\n",
       "         0.4490986 , 0.4490071 , 0.44939825, 0.44908931, 0.44915667,\n",
       "         0.44901002, 0.44879371, 0.4492585 , 0.44929144, 0.44976192,\n",
       "         0.44895917, 0.44914978, 0.44928232, 0.44948261, 0.44909792,\n",
       "         0.44923445, 0.45426901, 0.44911854, 0.44934633, 0.44892153,\n",
       "         0.44884878, 0.44910892, 0.44890119, 0.4489421 , 0.44932836,\n",
       "         0.44906109, 0.44915221, 0.47218444, 0.44896684, 0.45029787,\n",
       "         0.45156047, 0.44960731, 0.44956165, 0.44948021, 0.45625809,\n",
       "         0.44925867, 0.44893821, 0.45487192, 0.44999102, 0.44916928,\n",
       "         0.44919902, 0.4493777 , 0.44881562, 0.4491978 , 0.4490396 ,\n",
       "         0.44890688, 0.44939237, 0.44939798, 0.44875612, 0.44878266]),\n",
       "  'cali_free_log_loss': array([0.44930243, 0.44900514, 0.44907848, 0.44906545, 0.44903958,\n",
       "         0.44899773, 0.45024812, 0.44905254, 0.44884233, 0.44870727,\n",
       "         0.44912265, 0.44899601, 0.44929417, 0.44906816, 0.44914445,\n",
       "         0.44888655, 0.4488147 , 0.44920128, 0.44929818, 0.44931214,\n",
       "         0.44889253, 0.44905644, 0.44925469, 0.44910083, 0.44913067,\n",
       "         0.44918056, 0.45072213, 0.44912763, 0.44922669, 0.44889925,\n",
       "         0.44880916, 0.44897182, 0.44887938, 0.44894731, 0.44927707,\n",
       "         0.44908749, 0.44915683, 0.45680334, 0.44895804, 0.44911836,\n",
       "         0.4495875 , 0.44941239, 0.44930235, 0.44938576, 0.4506608 ,\n",
       "         0.44924251, 0.44891554, 0.45048034, 0.44925805, 0.44913732,\n",
       "         0.44909043, 0.44893168, 0.44871212, 0.44900893, 0.44905934,\n",
       "         0.44891401, 0.44920086, 0.44939763, 0.44874476, 0.44877305])},\n",
       " 'criteo_BN_dense_feature_minus_13': {'log_loss': array([0.45214707, 0.45156498, 0.45178318, 0.45186384, 0.45161085,\n",
       "         0.45199502, 0.45192254, 0.45164767, 0.45163118, 0.45184338,\n",
       "         0.45167505, 0.45172638, 0.4518881 , 0.45190436, 0.45189881,\n",
       "         0.45189497, 0.45166616, 0.45186593, 0.45164415, 0.45179135,\n",
       "         0.45166123, 0.4519706 , 0.45163022, 0.45192478, 0.45191806,\n",
       "         0.45196004, 0.45170069, 0.45207651, 0.45204425, 0.45179904,\n",
       "         0.45152561, 0.45188805, 0.45193475, 0.45173846, 0.45189006,\n",
       "         0.45191599, 0.45191218, 0.45174091, 0.45191197, 0.45195611,\n",
       "         0.45212692, 0.45207976, 0.45155022, 0.45186436, 0.45215445,\n",
       "         0.45185746, 0.45200077, 0.45178866, 0.45185463, 0.45203606,\n",
       "         0.45179236, 0.45211585, 0.45194207, 0.4519512 , 0.45202546,\n",
       "         0.45180892, 0.45186628, 0.45198885, 0.4518137 , 0.45184765]),\n",
       "  'cali_free_log_loss': array([0.4521132 , 0.45154437, 0.45170165, 0.45183285, 0.45155885,\n",
       "         0.45197515, 0.45187117, 0.45162666, 0.45163572, 0.45181443,\n",
       "         0.45163974, 0.45163327, 0.45187553, 0.45186946, 0.45187599,\n",
       "         0.45164215, 0.45159686, 0.45181822, 0.4516235 , 0.45177393,\n",
       "         0.45166074, 0.45191775, 0.45161005, 0.45173276, 0.45184872,\n",
       "         0.45188357, 0.45157471, 0.45206447, 0.45199734, 0.45176012,\n",
       "         0.4515337 , 0.45174801, 0.451766  , 0.45173189, 0.45184196,\n",
       "         0.45186347, 0.45192973, 0.4517446 , 0.45188251, 0.4519201 ,\n",
       "         0.4520922 , 0.45202787, 0.45151955, 0.45185903, 0.45187585,\n",
       "         0.45181915, 0.45195697, 0.45179811, 0.45180653, 0.4520135 ,\n",
       "         0.45176528, 0.4519751 , 0.45185112, 0.45191742, 0.45199224,\n",
       "         0.45177881, 0.45185877, 0.451964  , 0.45180842, 0.45173895])},\n",
       " 'criteo_BN_dense_feature_minus_11_to_13': {'log_loss': array([0.45479159, 0.45450764, 0.45451984, 0.45479821, 0.45453885,\n",
       "         0.45445931, 0.45484925, 0.45446418, 0.45514182, 0.45442253,\n",
       "         0.45466491, 0.45420123, 0.45438279, 0.45450864, 0.45441345,\n",
       "         0.45468159, 0.45472338, 0.45449381, 0.45449847, 0.4548092 ,\n",
       "         0.45497592, 0.45491043, 0.45455153, 0.45488603, 0.45459979,\n",
       "         0.4549152 , 0.45438923, 0.45462852, 0.45458385, 0.45465827,\n",
       "         0.45472296, 0.45467464, 0.45499613, 0.45517721, 0.45475818,\n",
       "         0.45501018, 0.45497551, 0.45484432, 0.45489851, 0.45462888,\n",
       "         0.45469379, 0.45413342, 0.45451832, 0.45459742, 0.45446307,\n",
       "         0.45446365, 0.45479576, 0.45512606, 0.45468773, 0.45446969,\n",
       "         0.45487291, 0.45495833, 0.45470701, 0.45474637, 0.45472406,\n",
       "         0.45464778, 0.45471725, 0.45437582, 0.45507243, 0.45431035]),\n",
       "  'cali_free_log_loss': array([0.45473824, 0.4544988 , 0.45452591, 0.45474372, 0.4545014 ,\n",
       "         0.45444859, 0.45477874, 0.45447449, 0.45484911, 0.45438843,\n",
       "         0.4545505 , 0.45417808, 0.45438943, 0.45450619, 0.45438537,\n",
       "         0.45462641, 0.45468258, 0.45445665, 0.45447773, 0.45451946,\n",
       "         0.4547408 , 0.45482835, 0.45447436, 0.45462456, 0.45456295,\n",
       "         0.45493642, 0.45434985, 0.45456322, 0.45458823, 0.45455913,\n",
       "         0.45469402, 0.45448528, 0.45472668, 0.45508587, 0.45475089,\n",
       "         0.45483927, 0.4548972 , 0.45461433, 0.45463747, 0.4544901 ,\n",
       "         0.45469896, 0.45414   , 0.45441065, 0.45441773, 0.45445839,\n",
       "         0.45444249, 0.45466247, 0.45503341, 0.45463851, 0.45435176,\n",
       "         0.45456978, 0.45466285, 0.45457683, 0.45470468, 0.45466075,\n",
       "         0.45464888, 0.45462479, 0.45427789, 0.45466551, 0.45426776])},\n",
       " 'criteo_BN_dense_feature_minus_8_to_13': {'log_loss': array([0.45589353, 0.45628544, 0.45616309, 0.45626047, 0.45622902,\n",
       "         0.45616713, 0.45605607, 0.45612906, 0.45599874, 0.45619859,\n",
       "         0.45600154, 0.45591437, 0.45660551, 0.45632772, 0.45606636,\n",
       "         0.45588781, 0.45650744, 0.45648431, 0.45605853, 0.45566215,\n",
       "         0.45606071, 0.45590675, 0.45659547, 0.45615244, 0.45633524,\n",
       "         0.45641409, 0.45619659, 0.45611093, 0.45627484, 0.45586506,\n",
       "         0.45645028, 0.45614387, 0.45650343, 0.45624716, 0.45618364,\n",
       "         0.45637963, 0.45571885, 0.45652803, 0.45612122, 0.45650443,\n",
       "         0.45609633, 0.45635962, 0.45629592, 0.45599971, 0.45601146,\n",
       "         0.45655846, 0.45589716, 0.45572699, 0.45584913, 0.45599223,\n",
       "         0.45622613, 0.45604017, 0.45633406, 0.45620542, 0.45630596,\n",
       "         0.45686489, 0.45697196, 0.45608746, 0.45584662, 0.45598879]),\n",
       "  'cali_free_log_loss': array([0.45579447, 0.45627739, 0.45594865, 0.45622806, 0.4562092 ,\n",
       "         0.45618767, 0.45600122, 0.45614445, 0.45601578, 0.4561962 ,\n",
       "         0.45600852, 0.45592219, 0.45661533, 0.45624161, 0.45601362,\n",
       "         0.45586305, 0.45654144, 0.45599715, 0.45603232, 0.45565442,\n",
       "         0.45605923, 0.45590529, 0.45646605, 0.45612874, 0.45634169,\n",
       "         0.45628035, 0.45615553, 0.45581685, 0.45618306, 0.45587086,\n",
       "         0.45642613, 0.45581675, 0.45606189, 0.4561755 , 0.45617621,\n",
       "         0.45608344, 0.45569899, 0.45631304, 0.45613399, 0.45607904,\n",
       "         0.45589917, 0.45617928, 0.4562709 , 0.45600433, 0.45597532,\n",
       "         0.45641885, 0.45590216, 0.45572367, 0.4558453 , 0.45594948,\n",
       "         0.45624568, 0.45602869, 0.45632529, 0.45616664, 0.45624176,\n",
       "         0.45620458, 0.45639861, 0.45594572, 0.45571494, 0.45577271])},\n",
       " 'criteo_BN_sparse_feature_minus_26': {'log_loss': array([0.44945485, 0.449574  , 0.44995963, 0.45096924, 0.44971706,\n",
       "         0.45030647, 0.46987693, 0.44988472, 0.45188143, 0.4497152 ,\n",
       "         0.4495639 , 0.45094285, 0.44959755, 0.44990752, 0.44929631,\n",
       "         0.44958823, 0.45040663, 0.44977172, 0.44994602, 0.45005915,\n",
       "         0.44972146, 0.45020307, 0.44956409, 0.44958536, 0.45013196,\n",
       "         0.45391418, 0.45021782, 0.44924512, 0.44961577, 0.44949283,\n",
       "         0.44955308, 0.44988139, 0.45045897, 0.45018272, 0.44985862,\n",
       "         0.4505572 , 0.44962277, 0.44957203, 0.44944496, 0.44977545,\n",
       "         0.45032212, 0.45000147, 0.44956355, 0.4501682 , 0.44972259,\n",
       "         0.44966008, 0.44950681, 0.45006701, 0.45008347, 0.48090134,\n",
       "         0.4495915 , 0.45073094, 0.44985393, 0.4494079 , 0.44984202,\n",
       "         0.44976468, 0.44947237, 0.45355136, 0.44976915, 0.45007048]),\n",
       "  'cali_free_log_loss': array([0.44940433, 0.44952337, 0.44982047, 0.45001391, 0.44968288,\n",
       "         0.44967099, 0.45680931, 0.44987729, 0.45029186, 0.44958267,\n",
       "         0.44954376, 0.4499107 , 0.4495186 , 0.44979998, 0.4492906 ,\n",
       "         0.44957615, 0.45007537, 0.44968757, 0.44981195, 0.45002233,\n",
       "         0.44963505, 0.4501733 , 0.44941687, 0.4495493 , 0.44999857,\n",
       "         0.45113008, 0.44996015, 0.44922845, 0.44957203, 0.4494936 ,\n",
       "         0.44953702, 0.44980774, 0.44990708, 0.44989615, 0.44970613,\n",
       "         0.45022437, 0.4493731 , 0.4494801 , 0.44940614, 0.44974907,\n",
       "         0.44969991, 0.44988275, 0.44954291, 0.45004849, 0.44966259,\n",
       "         0.44965875, 0.44941612, 0.45005767, 0.44998741, 0.45857696,\n",
       "         0.44955359, 0.45001014, 0.44959932, 0.44937888, 0.44980023,\n",
       "         0.44975775, 0.44946651, 0.45062103, 0.44974518, 0.44993814])},\n",
       " 'criteo_BN_small_arch': {'log_loss': array([0.44962716, 0.44948108, 0.45150169, 0.44950921, 0.44935734,\n",
       "         0.44951263, 0.44971691, 0.45112833, 0.44921999, 0.44916192,\n",
       "         0.4496656 , 0.45242817, 0.44981371, 0.44931541, 0.44906361,\n",
       "         0.45719106, 0.44937556, 0.44967997, 0.44999841, 0.45052658,\n",
       "         0.44914666, 0.44908747, 0.44956581, 0.44929063, 0.44925833,\n",
       "         0.44908326, 0.44938867, 0.44989136, 0.44927459, 0.44966216,\n",
       "         0.44930111, 0.44913328, 0.44989552, 0.44993975, 0.44961449,\n",
       "         0.44920396, 0.44962558, 0.44927402, 0.44959228, 0.4531238 ,\n",
       "         0.45046413, 0.44944558, 0.4498003 , 0.44977045, 0.45059276,\n",
       "         0.44949043, 0.449514  , 0.45024154, 0.4494714 , 0.44913855,\n",
       "         0.44990808, 0.44965106, 0.44951431, 0.45447273, 0.44943561,\n",
       "         0.45001828, 0.45075823, 0.44967578, 0.46180515, 0.44951209]),\n",
       "  'cali_free_log_loss': array([0.44958459, 0.44938213, 0.45009488, 0.44928429, 0.44932991,\n",
       "         0.44920042, 0.44945937, 0.44975236, 0.44921371, 0.44914456,\n",
       "         0.44948178, 0.45044374, 0.44966698, 0.44922181, 0.44899313,\n",
       "         0.45258721, 0.44936428, 0.44964415, 0.44936166, 0.44974049,\n",
       "         0.44914819, 0.44898486, 0.44947204, 0.44920997, 0.44923756,\n",
       "         0.44906276, 0.44924952, 0.44958523, 0.4493024 , 0.44951755,\n",
       "         0.44926672, 0.44908042, 0.4495095 , 0.44994034, 0.44954941,\n",
       "         0.44904153, 0.44949018, 0.44927397, 0.44957471, 0.45032962,\n",
       "         0.44982317, 0.44935563, 0.44972582, 0.44950017, 0.4495493 ,\n",
       "         0.44950873, 0.44937059, 0.44950127, 0.44936353, 0.44910234,\n",
       "         0.44966927, 0.44942951, 0.44953037, 0.45091336, 0.44915583,\n",
       "         0.44951214, 0.44997387, 0.4493289 , 0.45362675, 0.44950271])},\n",
       " 'criteo_regularization_15e-2_BN': {'log_loss': array([0.45152424, 0.44985702, 0.44958957, 0.44968064, 0.44983692,\n",
       "         0.44981819, 0.4497044 , 0.44965433, 0.44961217, 0.46712697,\n",
       "         0.44991947, 0.44997862, 0.45420322, 0.45071679, 0.45008006,\n",
       "         0.45001495, 0.4560399 , 0.44923848, 0.44982466, 0.4496538 ,\n",
       "         0.45117917, 0.45072714, 0.45268936, 0.45501352, 0.45036313,\n",
       "         0.4519077 , 0.44959334, 0.44960245, 0.44977634, 0.44978631,\n",
       "         0.4502365 , 0.45276829, 0.45038585, 0.44975757, 0.45039631,\n",
       "         0.45039748, 0.44957158, 0.44990684, 0.45013022, 0.45274483,\n",
       "         0.44958459, 0.44976753, 0.44975167, 0.45626893, 0.45021095,\n",
       "         0.45029086, 0.44995532, 0.44946771, 0.44976396, 0.4523807 ,\n",
       "         0.45039245, 0.44975273, 0.44945773, 0.44988565, 0.4496139 ,\n",
       "         0.44989324, 0.44987888, 0.45045727, 0.45266679, 0.44956152]),\n",
       "  'cali_free_log_loss': array([0.45035801, 0.44983372, 0.4495871 , 0.44964438, 0.44983086,\n",
       "         0.44967124, 0.44946672, 0.44960083, 0.44959625, 0.45587989,\n",
       "         0.4498964 , 0.44994372, 0.45132647, 0.45016158, 0.44944738,\n",
       "         0.44983783, 0.45160355, 0.4492161 , 0.44973107, 0.44964922,\n",
       "         0.45017908, 0.4501982 , 0.45085548, 0.4515214 , 0.45014761,\n",
       "         0.45020805, 0.44957746, 0.44954244, 0.44977212, 0.44975056,\n",
       "         0.45023938, 0.45068911, 0.45003475, 0.44974384, 0.45034613,\n",
       "         0.44986317, 0.44957473, 0.44972269, 0.44980657, 0.45003066,\n",
       "         0.44950604, 0.44968209, 0.44967917, 0.45167931, 0.45001763,\n",
       "         0.44987092, 0.44959264, 0.44923872, 0.44952074, 0.45013027,\n",
       "         0.44971856, 0.44969207, 0.44944759, 0.44959763, 0.44964589,\n",
       "         0.44972058, 0.44949527, 0.45015303, 0.45043293, 0.44933604])},\n",
       " 'criteo_regularization_2e-1_BN': {'log_loss': array([0.44996712, 0.44997607, 0.44979348, 0.44975222, 0.45240499,\n",
       "         0.4508126 , 0.44967746, 0.44981533, 0.45110641, 0.44999659,\n",
       "         0.45062318, 0.4562021 , 0.45002314, 0.45017814, 0.45214273,\n",
       "         0.45252404, 0.45855029, 0.4497865 , 0.45012394, 0.4501588 ,\n",
       "         0.45053753, 0.44979415, 0.45046526, 0.44976659, 0.45139359,\n",
       "         0.44998095, 0.46143207, 0.44966157, 0.44977403, 0.44965754,\n",
       "         0.44993339, 0.45049902, 0.44995958, 0.4496765 , 0.44965614,\n",
       "         0.45009239, 0.44968699, 0.44984903, 0.44987991, 0.44992934,\n",
       "         0.4516268 , 0.4503737 , 0.44996348, 0.44966957, 0.44981702,\n",
       "         0.44993687, 0.45097669, 0.45060514, 0.45173051, 0.45030029,\n",
       "         0.45286103, 0.44975407, 0.45140196, 0.44956357, 0.44976985,\n",
       "         0.45028398, 0.45001248, 0.45016994, 0.45169408, 0.45061027]),\n",
       "  'cali_free_log_loss': array([0.44979223, 0.44990931, 0.44977803, 0.44969413, 0.45053183,\n",
       "         0.45002623, 0.44966031, 0.4495933 , 0.45015356, 0.44992527,\n",
       "         0.45026944, 0.45155021, 0.4495592 , 0.4501125 , 0.45014356,\n",
       "         0.45068357, 0.4525718 , 0.44979253, 0.44998442, 0.449845  ,\n",
       "         0.44976755, 0.44978255, 0.45021271, 0.44968821, 0.45031933,\n",
       "         0.44993414, 0.45319747, 0.4496206 , 0.44973269, 0.44955173,\n",
       "         0.44987678, 0.45015632, 0.44994133, 0.44953355, 0.44965959,\n",
       "         0.44991831, 0.44969746, 0.44986039, 0.44964601, 0.44985626,\n",
       "         0.44989734, 0.4500367 , 0.44988759, 0.44961423, 0.44971286,\n",
       "         0.44989766, 0.45047468, 0.45030113, 0.45065831, 0.45028401,\n",
       "         0.45071935, 0.44975726, 0.45023795, 0.44951063, 0.44974869,\n",
       "         0.45010068, 0.44998574, 0.44996889, 0.45028368, 0.45005753])},\n",
       " 'criteo_regularization_3e-2_BN': {'log_loss': array([0.44910456, 0.44874081, 0.45114268, 0.44946724, 0.44921769,\n",
       "         0.44884737, 0.44930262, 0.44876835, 0.44925952, 0.44988059,\n",
       "         0.44905528, 0.44899882, 0.4496104 , 0.44982408, 0.44900088,\n",
       "         0.45154683, 0.45646818, 0.44915142, 0.44958954, 0.44866679,\n",
       "         0.44944811, 0.44936966, 0.44891191, 0.45433895, 0.44915799,\n",
       "         0.44885248, 0.45373158, 0.44882837, 0.45156327, 0.44992527,\n",
       "         0.44881248, 0.44938433, 0.44879262, 0.45281281, 0.44881116,\n",
       "         0.44916394, 0.45579669, 0.44931082, 0.44911976, 0.44936327,\n",
       "         0.44924596, 0.44916541, 0.45035472, 0.44901516, 0.44948033,\n",
       "         0.45093256, 0.44923796, 0.44912253, 0.44898101, 0.4578652 ,\n",
       "         0.44920137, 0.44890546, 0.45951148, 0.44902553, 0.45135717,\n",
       "         0.44906843, 0.44894076, 0.44913655, 0.44911006, 0.44903741]),\n",
       "  'cali_free_log_loss': array([0.44880434, 0.44867769, 0.44955617, 0.44942987, 0.44920126,\n",
       "         0.4488452 , 0.44912609, 0.44869624, 0.44915439, 0.44933038,\n",
       "         0.44894182, 0.44897316, 0.4492107 , 0.44926093, 0.44896928,\n",
       "         0.45029826, 0.45081321, 0.4489957 , 0.44916395, 0.4486366 ,\n",
       "         0.44914088, 0.44932836, 0.44874564, 0.45090394, 0.44917852,\n",
       "         0.44882497, 0.45064263, 0.44880136, 0.45010811, 0.4491568 ,\n",
       "         0.44880733, 0.44918627, 0.44869615, 0.45008806, 0.4487116 ,\n",
       "         0.44909964, 0.45070086, 0.44920753, 0.4490393 , 0.44927232,\n",
       "         0.4491083 , 0.44914235, 0.44965337, 0.44892879, 0.44921395,\n",
       "         0.44969568, 0.44898771, 0.44912845, 0.4489282 , 0.45302174,\n",
       "         0.44915507, 0.4488042 , 0.45236349, 0.44898058, 0.44971571,\n",
       "         0.44887037, 0.4489324 , 0.44907095, 0.44907642, 0.4489714 ])},\n",
       " 'criteo_regularization_5e-2_BN': {'log_loss': array([0.44882602, 0.44930847, 0.4492547 , 0.44972532, 0.44998037,\n",
       "         0.45590299, 0.44937452, 0.448976  , 0.44896525, 0.44927875,\n",
       "         0.44931925, 0.45264572, 0.44985477, 0.44909477, 0.44944736,\n",
       "         0.45311707, 0.44942309, 0.44973142, 0.44997039, 0.44918978,\n",
       "         0.45468012, 0.45060253, 0.4502251 , 0.44904522, 0.44944534,\n",
       "         0.44896136, 0.45364081, 0.45129757, 0.44966776, 0.45046261,\n",
       "         0.44951614, 0.44953721, 0.44896104, 0.45157723, 0.44962105,\n",
       "         0.44921036, 0.44907893, 0.44919385, 0.44947459, 0.44964435,\n",
       "         0.44925248, 0.44946953, 0.4579136 , 0.44918871, 0.44941363,\n",
       "         0.44886324, 0.4493287 , 0.4497239 , 0.44971171, 0.44927434,\n",
       "         0.44882019, 0.44927251, 0.44958708, 0.44888193, 0.44935173,\n",
       "         0.44936234, 0.4488968 , 0.4494292 , 0.44913999, 0.45356418]),\n",
       "  'cali_free_log_loss': array([0.4486633 , 0.44896151, 0.44914035, 0.44932375, 0.44939131,\n",
       "         0.45089176, 0.44939011, 0.44897931, 0.44891399, 0.44902613,\n",
       "         0.4491364 , 0.45027193, 0.44940432, 0.44892393, 0.44921424,\n",
       "         0.45039083, 0.4492993 , 0.44937912, 0.44970702, 0.44918115,\n",
       "         0.45113855, 0.4494401 , 0.4495401 , 0.44903902, 0.44926485,\n",
       "         0.44894528, 0.4505408 , 0.44978238, 0.44918759, 0.44917576,\n",
       "         0.44944484, 0.44946998, 0.44895908, 0.44960539, 0.44920371,\n",
       "         0.44918389, 0.44903504, 0.44918226, 0.44936293, 0.4491264 ,\n",
       "         0.44895966, 0.44924277, 0.45180066, 0.44909336, 0.44932698,\n",
       "         0.44883207, 0.44921211, 0.44917296, 0.4493047 , 0.44924468,\n",
       "         0.44883231, 0.4492185 , 0.44955435, 0.448887  , 0.44927107,\n",
       "         0.44932951, 0.44887917, 0.44939983, 0.44907065, 0.45075143])},\n",
       " 'criteo_regularization_7e-2_BN': {'log_loss': array([0.44913435, 0.44973891, 0.44926365, 0.44978001, 0.44954091,\n",
       "         0.44962649, 0.44951617, 0.44946558, 0.44935728, 0.4496641 ,\n",
       "         0.4499029 , 0.44921698, 0.44937235, 0.4496167 , 0.45441684,\n",
       "         0.44922622, 0.45112042, 0.44908968, 0.44943767, 0.44945186,\n",
       "         0.44979813, 0.44906746, 0.44946728, 0.44938866, 0.45000751,\n",
       "         0.44912511, 0.44948408, 0.45490761, 0.4493216 , 0.44931521,\n",
       "         0.45036293, 0.44932478, 0.45028556, 0.44951094, 0.44947239,\n",
       "         0.44919854, 0.44973019, 0.44941406, 0.45217325, 0.44968972,\n",
       "         0.44934654, 0.44991747, 0.44948908, 0.44936565, 0.44951024,\n",
       "         0.44897198, 0.44933027, 0.44965071, 0.45082216, 0.44977186,\n",
       "         0.44939036, 0.44939337, 0.44986498, 0.45152735, 0.44936692,\n",
       "         0.44923481, 0.44968722, 0.44941366, 0.46092124, 0.44970021]),\n",
       "  'cali_free_log_loss': array([0.44912769, 0.44958134, 0.44908162, 0.44958729, 0.44934819,\n",
       "         0.44941331, 0.44938907, 0.44944349, 0.44911883, 0.44962692,\n",
       "         0.44941628, 0.44921947, 0.44926279, 0.4495898 , 0.45078155,\n",
       "         0.44920735, 0.44972415, 0.44907913, 0.44940215, 0.44942951,\n",
       "         0.44980405, 0.4490653 , 0.44930756, 0.44926559, 0.44947365,\n",
       "         0.44894952, 0.44937235, 0.45088959, 0.44914554, 0.44929283,\n",
       "         0.44960597, 0.44921455, 0.44960563, 0.44945825, 0.44945331,\n",
       "         0.44918798, 0.44951949, 0.44936876, 0.44964542, 0.44956888,\n",
       "         0.4491758 , 0.44971313, 0.44912019, 0.44918595, 0.4494443 ,\n",
       "         0.44890575, 0.44920663, 0.4494324 , 0.44966793, 0.44969843,\n",
       "         0.44919436, 0.44936979, 0.44984555, 0.44968894, 0.44929478,\n",
       "         0.44923488, 0.44954188, 0.44939848, 0.45379258, 0.44941135])},\n",
       " 'criteo_regularization_1e-1_BN': {'log_loss': array([0.44903066, 0.4493942 , 0.44984179, 0.44980339, 0.44952378,\n",
       "         0.45093424, 0.45194917, 0.44924846, 0.44964032, 0.44985439,\n",
       "         0.45449788, 0.44944165, 0.44968735, 0.45647266, 0.44981463,\n",
       "         0.45256076, 0.44926835, 0.44908362, 0.44975053, 0.44917864,\n",
       "         0.45491177, 0.44961399, 0.45001855, 0.4493129 , 0.44941494,\n",
       "         0.45388964, 0.44931004, 0.44948392, 0.44984852, 0.44969031,\n",
       "         0.44941071, 0.44944707, 0.44973822, 0.4498627 , 0.44960914,\n",
       "         0.44957027, 0.44912359, 0.4495466 , 0.44935968, 0.44952617,\n",
       "         0.44970677, 0.45015484, 0.44953548, 0.45029082, 0.44944284,\n",
       "         0.44977009, 0.44944431, 0.44979487, 0.44956585, 0.4528277 ,\n",
       "         0.44963005, 0.44952414, 0.44964992, 0.45003355, 0.4496213 ,\n",
       "         0.44920482, 0.44969806, 0.44913748, 0.45340435, 0.45011534]),\n",
       "  'cali_free_log_loss': array([0.44902324, 0.44938862, 0.44968829, 0.44982017, 0.44939116,\n",
       "         0.44975404, 0.45074725, 0.44926074, 0.4495962 , 0.44974052,\n",
       "         0.45103277, 0.44933902, 0.44956309, 0.45186846, 0.44971037,\n",
       "         0.45091781, 0.44924591, 0.44902657, 0.44978649, 0.44909883,\n",
       "         0.45075128, 0.44955522, 0.44950586, 0.44930533, 0.44936242,\n",
       "         0.45063875, 0.44927327, 0.44946542, 0.44952058, 0.44943629,\n",
       "         0.44942216, 0.44939012, 0.44973394, 0.44984567, 0.44962854,\n",
       "         0.44942096, 0.44909246, 0.44948178, 0.44920913, 0.44950999,\n",
       "         0.44947895, 0.44967734, 0.44937806, 0.44981506, 0.44939202,\n",
       "         0.44975779, 0.44942448, 0.44973341, 0.4495252 , 0.45014179,\n",
       "         0.44958085, 0.44940296, 0.4496287 , 0.44936572, 0.44954513,\n",
       "         0.44918322, 0.44960145, 0.44916613, 0.45005222, 0.45009667])},\n",
       " 'criteo_regularization_1e-2_BN': {'log_loss': array([0.44929652, 0.44851485, 0.4492125 , 0.44857157, 0.44895557,\n",
       "         0.44949259, 0.44923854, 0.44872222, 0.44873326, 0.44888312,\n",
       "         0.45399472, 0.44968395, 0.44900254, 0.44900498, 0.44871552,\n",
       "         0.45021509, 0.44887098, 0.44880307, 0.44919962, 0.44854804,\n",
       "         0.44906097, 0.44913331, 0.4490097 , 0.44909963, 0.44918382,\n",
       "         0.44917458, 0.44915194, 0.44881168, 0.44909332, 0.4491591 ,\n",
       "         0.44888234, 0.44896694, 0.4491366 , 0.44926621, 0.45215287,\n",
       "         0.44911658, 0.44914665, 0.44895015, 0.45136707, 0.44902668,\n",
       "         0.44896165, 0.45145407, 0.4490182 , 0.44894105, 0.44920115,\n",
       "         0.44874036, 0.44916719, 0.4487202 , 0.44882358, 0.44882909,\n",
       "         0.44885165, 0.44946694, 0.4489064 , 0.4491272 , 0.44927977,\n",
       "         0.44887406, 0.44949805, 0.44842157, 0.44896299, 0.44959085]),\n",
       "  'cali_free_log_loss': array([0.4492773 , 0.4484034 , 0.44867588, 0.44855361, 0.44877851,\n",
       "         0.44913701, 0.44876106, 0.44870942, 0.44866986, 0.44871751,\n",
       "         0.45037894, 0.44927445, 0.44891663, 0.44877318, 0.44870611,\n",
       "         0.44901701, 0.44876368, 0.44866644, 0.44901239, 0.44851334,\n",
       "         0.44891195, 0.44894073, 0.44888176, 0.4490531 , 0.44862376,\n",
       "         0.44887315, 0.44901452, 0.44875016, 0.44908093, 0.4490236 ,\n",
       "         0.44884679, 0.44892889, 0.44909462, 0.4492111 , 0.45006489,\n",
       "         0.44910346, 0.44895418, 0.44877643, 0.44944687, 0.44894595,\n",
       "         0.44891754, 0.44954757, 0.44897508, 0.44893229, 0.44901092,\n",
       "         0.44865922, 0.44876673, 0.44850116, 0.4486847 , 0.44882158,\n",
       "         0.44881269, 0.44930275, 0.44885575, 0.44900165, 0.44893939,\n",
       "         0.44883769, 0.44891946, 0.44838909, 0.44895137, 0.44885657])},\n",
       " 'criteo_regularization_1e-3_BN': {'log_loss': array([0.44883888, 0.4486166 , 0.45411273, 0.44919847, 0.44896756,\n",
       "         0.44931705, 0.44907334, 0.4488435 , 0.45443166, 0.45056527,\n",
       "         0.44856229, 0.45017851, 0.44912461, 0.44876715, 0.44926974,\n",
       "         0.449022  , 0.44898581, 0.4484669 , 0.4489733 , 0.44905889,\n",
       "         0.44901033, 0.44867579, 0.44890445, 0.44966046, 0.44905143,\n",
       "         0.44904031, 0.44979953, 0.44911401, 0.449033  , 0.44939172,\n",
       "         0.44907268, 0.44907971, 0.44877934, 0.44895702, 0.44906157,\n",
       "         0.44861558, 0.44922055, 0.44860021, 0.44898378, 0.44969657,\n",
       "         0.44888727, 0.44888235, 0.44972558, 0.45194872, 0.44855324,\n",
       "         0.44918108, 0.44871271, 0.45232304, 0.44888987, 0.45069374,\n",
       "         0.44903122, 0.44903505, 0.44905181, 0.44940373, 0.44912916,\n",
       "         0.44890455, 0.44965876, 0.44888669, 0.44897313, 0.44886848]),\n",
       "  'cali_free_log_loss': array([0.44881734, 0.44853882, 0.45072286, 0.44918172, 0.44888513,\n",
       "         0.44885091, 0.44895667, 0.44875097, 0.45092107, 0.44943366,\n",
       "         0.44854134, 0.44941402, 0.44902953, 0.44868818, 0.44909429,\n",
       "         0.4489813 , 0.44896073, 0.44844082, 0.44887987, 0.44897333,\n",
       "         0.4489739 , 0.4486554 , 0.44878202, 0.44926454, 0.4489681 ,\n",
       "         0.44902205, 0.44938414, 0.44883157, 0.44903996, 0.44899917,\n",
       "         0.44887797, 0.44900626, 0.44861449, 0.44884941, 0.44895533,\n",
       "         0.44859223, 0.44918733, 0.44860478, 0.44891568, 0.44926948,\n",
       "         0.44887896, 0.44887774, 0.44948668, 0.44996554, 0.44853632,\n",
       "         0.44917189, 0.4486874 , 0.44968759, 0.44886819, 0.44946039,\n",
       "         0.44902798, 0.44885601, 0.44903781, 0.44901205, 0.44899461,\n",
       "         0.44880441, 0.44910089, 0.4488635 , 0.44878079, 0.44883132])},\n",
       " 'criteo_regularization_1e-4_BN': {'log_loss': array([0.44911481, 0.44889037, 0.44870275, 0.44922527, 0.44920065,\n",
       "         0.44903218, 0.44949115, 0.44881025, 0.45155156, 0.44889565,\n",
       "         0.44886302, 0.44919829, 0.45672738, 0.44866134, 0.44897281,\n",
       "         0.44924364, 0.44905421, 0.44880211, 0.44895696, 0.45029922,\n",
       "         0.44868665, 0.44891645, 0.44909797, 0.44902126, 0.44924287,\n",
       "         0.44879882, 0.44887371, 0.44884358, 0.44878765, 0.4495008 ,\n",
       "         0.44907199, 0.44939748, 0.45293536, 0.44967837, 0.44913255,\n",
       "         0.44906598, 0.4487556 , 0.44889485, 0.44909728, 0.45065012,\n",
       "         0.44869312, 0.44887246, 0.44902578, 0.44901166, 0.44915505,\n",
       "         0.44907904, 0.44910639, 0.44913629, 0.4491398 , 0.44936961,\n",
       "         0.44904603, 0.45096263, 0.44911014, 0.44906919, 0.44901116,\n",
       "         0.44958125, 0.45205359, 0.44920669, 0.44888237, 0.44952052]),\n",
       "  'cali_free_log_loss': array([0.44900534, 0.44884396, 0.44870627, 0.44919158, 0.44915162,\n",
       "         0.44900695, 0.4492753 , 0.44874216, 0.4500484 , 0.44888236,\n",
       "         0.44884905, 0.44918541, 0.45128174, 0.44865937, 0.44897218,\n",
       "         0.44925162, 0.4489532 , 0.44882105, 0.44892107, 0.4493109 ,\n",
       "         0.44868648, 0.44890074, 0.44889888, 0.44897725, 0.44911922,\n",
       "         0.44879015, 0.44886034, 0.44880843, 0.44880301, 0.44898282,\n",
       "         0.4490847 , 0.44915397, 0.45007337, 0.44902792, 0.44910699,\n",
       "         0.44896403, 0.44876341, 0.44886404, 0.44904059, 0.44966595,\n",
       "         0.4486764 , 0.44885212, 0.44891356, 0.44898491, 0.44913191,\n",
       "         0.44909176, 0.4489901 , 0.44911968, 0.4490873 , 0.44938396,\n",
       "         0.44903567, 0.44930973, 0.44907537, 0.44902252, 0.44901024,\n",
       "         0.44904045, 0.44938641, 0.44893041, 0.4488389 , 0.44927323])},\n",
       " 'criteo_regularization_1e-5_BN': {'log_loss': array([0.4488382 , 0.44857083, 0.45398313, 0.44903488, 0.44897713,\n",
       "         0.44886914, 0.44929495, 0.44955241, 0.45020065, 0.4495492 ,\n",
       "         0.44904924, 0.44912464, 0.45050179, 0.44880803, 0.44903178,\n",
       "         0.44893022, 0.44897886, 0.44919895, 0.44912279, 0.44972846,\n",
       "         0.44930717, 0.44897648, 0.44905213, 0.44964335, 0.44978515,\n",
       "         0.45118555, 0.45289741, 0.44924577, 0.44896494, 0.44892027,\n",
       "         0.44926104, 0.44955981, 0.45192382, 0.45006543, 0.44904796,\n",
       "         0.44953412, 0.4489735 , 0.44886486, 0.45221298, 0.44915175,\n",
       "         0.4500643 , 0.4489331 , 0.44890623, 0.44985472, 0.44872407,\n",
       "         0.44951736, 0.44902767, 0.45022878, 0.45128721, 0.44919198,\n",
       "         0.45176972, 0.44909726, 0.44955006, 0.44932647, 0.45273372,\n",
       "         0.44875623, 0.44903152, 0.44888464, 0.44902755, 0.44914316]),\n",
       "  'cali_free_log_loss': array([0.44884609, 0.44853904, 0.45018509, 0.44902987, 0.44888127,\n",
       "         0.44888154, 0.44917154, 0.44921053, 0.44938603, 0.44934122,\n",
       "         0.4489829 , 0.44897544, 0.44908947, 0.44878044, 0.44886008,\n",
       "         0.44883867, 0.44899518, 0.44913644, 0.44910356, 0.44934863,\n",
       "         0.44929218, 0.44897956, 0.44895725, 0.44928043, 0.4492115 ,\n",
       "         0.44941973, 0.45005911, 0.44912761, 0.44886308, 0.44889011,\n",
       "         0.44895974, 0.44902473, 0.449753  , 0.44905839, 0.44902078,\n",
       "         0.44918701, 0.44894969, 0.44886782, 0.44964045, 0.44915352,\n",
       "         0.44941648, 0.44889005, 0.44884965, 0.44898098, 0.44852057,\n",
       "         0.44922467, 0.44901992, 0.44931614, 0.44934785, 0.44907313,\n",
       "         0.45036769, 0.44910803, 0.44941539, 0.44908925, 0.45020505,\n",
       "         0.44871938, 0.4489937 , 0.44885406, 0.44892545, 0.44905961])},\n",
       " 'criteo_regularization_4e-6_BN': {'log_loss': array([0.44903128, 0.44895396, 0.46210147, 0.44887177, 0.44885063,\n",
       "         0.44861392, 0.45052577, 0.44987117, 0.44895122, 0.44953386,\n",
       "         0.44938115, 0.44898038, 0.44870375, 0.44927178, 0.44905407,\n",
       "         0.44979967, 0.45357554, 0.44897516, 0.4491681 , 0.45224474,\n",
       "         0.44854903, 0.44911808, 0.44981225, 0.4507526 , 0.44900857,\n",
       "         0.44928044, 0.44915126, 0.44914789, 0.44907294, 0.44890269,\n",
       "         0.44910218, 0.44907649, 0.44893919, 0.44898851, 0.44930388,\n",
       "         0.44901411, 0.45161212, 0.4490097 , 0.44895151, 0.44891052,\n",
       "         0.44878931, 0.44931736, 0.4488828 , 0.44887238, 0.45011172,\n",
       "         0.44917659, 0.44890775, 0.44858173, 0.44882375, 0.44916702,\n",
       "         0.44887588, 0.44896902, 0.44893212, 0.44872866, 0.44900071,\n",
       "         0.44935513, 0.44931533, 0.44884314, 0.449077  , 0.44879399]),\n",
       "  'cali_free_log_loss': array([0.44901504, 0.44894163, 0.45394809, 0.44888216, 0.44874753,\n",
       "         0.44861023, 0.44953749, 0.44932492, 0.44892784, 0.44919482,\n",
       "         0.44925229, 0.44893205, 0.44866729, 0.44919704, 0.44902082,\n",
       "         0.44937554, 0.45070888, 0.44896956, 0.44917969, 0.45013997,\n",
       "         0.44852451, 0.44903053, 0.44922568, 0.44934439, 0.4489417 ,\n",
       "         0.44908074, 0.44918932, 0.449093  , 0.44906893, 0.44888162,\n",
       "         0.44907783, 0.44906735, 0.44887558, 0.44900035, 0.44886425,\n",
       "         0.44902226, 0.44929185, 0.44900926, 0.44891888, 0.44882652,\n",
       "         0.44877783, 0.44924026, 0.44870755, 0.44883744, 0.44947747,\n",
       "         0.44908027, 0.44887127, 0.4485545 , 0.44880685, 0.44887535,\n",
       "         0.44884695, 0.44889582, 0.44893322, 0.44869745, 0.44897421,\n",
       "         0.44909331, 0.44912479, 0.44878345, 0.44893685, 0.44871859])},\n",
       " 'criteo_regularization_5e-6_BN': {'log_loss': array([0.44891618, 0.44993374, 0.44889718, 0.44920003, 0.44923485,\n",
       "         0.44864499, 0.45002021, 0.44937878, 0.45093101, 0.4490931 ,\n",
       "         0.44954761, 0.44901118, 0.44911928, 0.44920487, 0.44911244,\n",
       "         0.44908396, 0.44864679, 0.4490048 , 0.4494451 , 0.44886549,\n",
       "         0.4492102 , 0.44909087, 0.44884904, 0.44867194, 0.44911625,\n",
       "         0.44942045, 0.44950677, 0.44906907, 0.44896463, 0.44915973,\n",
       "         0.44943237, 0.44906299, 0.44884599, 0.44909235, 0.44893416,\n",
       "         0.44894617, 0.45211008, 0.44884142, 0.45014346, 0.44899765,\n",
       "         0.44978562, 0.4489175 , 0.44885902, 0.44890352, 0.44903581,\n",
       "         0.44993552, 0.44966165, 0.4490012 , 0.44882317, 0.44901785,\n",
       "         0.44917223, 0.44962167, 0.44891798, 0.4491868 , 0.44901364,\n",
       "         0.44904383, 0.4494644 , 0.44894245, 0.45125233, 0.44880511]),\n",
       "  'cali_free_log_loss': array([0.44886794, 0.44936709, 0.44891095, 0.44898785, 0.44905641,\n",
       "         0.44862424, 0.44940915, 0.44910697, 0.44964839, 0.44892974,\n",
       "         0.44933007, 0.44901029, 0.44884785, 0.44888852, 0.4490006 ,\n",
       "         0.44896674, 0.4486473 , 0.44896749, 0.44899668, 0.44886414,\n",
       "         0.44922808, 0.44906671, 0.44875446, 0.44862345, 0.44904653,\n",
       "         0.44910932, 0.44947372, 0.44900763, 0.44894253, 0.44895852,\n",
       "         0.4492535 , 0.44892936, 0.44877831, 0.44897618, 0.44893045,\n",
       "         0.4489124 , 0.44973895, 0.44881558, 0.44892753, 0.44896259,\n",
       "         0.44906905, 0.44891815, 0.44885281, 0.44885008, 0.44905309,\n",
       "         0.44934311, 0.44921393, 0.44894193, 0.44882832, 0.44895317,\n",
       "         0.44913454, 0.44928648, 0.44887758, 0.44909566, 0.44899002,\n",
       "         0.44902881, 0.44947363, 0.44893614, 0.44987706, 0.44880904])},\n",
       " 'criteo_regularization_1e-6_BN': {'log_loss': array([0.44917544, 0.44905548, 0.44863139, 0.44884778, 0.44921308,\n",
       "         0.44943997, 0.44928303, 0.44875385, 0.44926165, 0.4489703 ,\n",
       "         0.44879976, 0.44911878, 0.44885975, 0.44909465, 0.44962934,\n",
       "         0.44878396, 0.44910822, 0.44897123, 0.4491432 , 0.44875918,\n",
       "         0.44901339, 0.44933617, 0.44885241, 0.44945418, 0.44872402,\n",
       "         0.44899892, 0.44918747, 0.44917547, 0.44944376, 0.44899124,\n",
       "         0.4495781 , 0.44887918, 0.44910383, 0.44889446, 0.45270601,\n",
       "         0.44897399, 0.44897991, 0.44945493, 0.44886547, 0.44898488,\n",
       "         0.44937151, 0.44922217, 0.44927265, 0.44891818, 0.44916017,\n",
       "         0.44923099, 0.44871659, 0.44886231, 0.45029494, 0.45031326,\n",
       "         0.44925103, 0.44959271, 0.44889051, 0.4486883 , 0.44899047,\n",
       "         0.44901625, 0.44905858, 0.44867459, 0.44889623, 0.44910924]),\n",
       "  'cali_free_log_loss': array([0.449146  , 0.44900851, 0.44863889, 0.44864604, 0.44903849,\n",
       "         0.44918936, 0.44923976, 0.44872791, 0.44924417, 0.44892066,\n",
       "         0.44879939, 0.44910963, 0.44882539, 0.4488994 , 0.44894849,\n",
       "         0.44873832, 0.44896787, 0.44894557, 0.44915124, 0.44866379,\n",
       "         0.44899763, 0.44916516, 0.44875051, 0.44901761, 0.44871   ,\n",
       "         0.44903076, 0.4490902 , 0.44918327, 0.44909941, 0.44888969,\n",
       "         0.44895764, 0.44868726, 0.44910657, 0.44880791, 0.45015407,\n",
       "         0.44891061, 0.44880705, 0.44939938, 0.44884431, 0.44888798,\n",
       "         0.44895554, 0.44905541, 0.44917315, 0.44887082, 0.44895224,\n",
       "         0.44916931, 0.44873469, 0.44886339, 0.4492783 , 0.4493477 ,\n",
       "         0.4492582 , 0.4492125 , 0.44871889, 0.44870515, 0.4489717 ,\n",
       "         0.44895409, 0.44892547, 0.44863545, 0.44891127, 0.44911354])},\n",
       " 'criteo_regularization_2e-6_BN': {'log_loss': array([0.44902569, 0.44878674, 0.45179664, 0.44910403, 0.44896671,\n",
       "         0.44891544, 0.45046343, 0.44902742, 0.44906847, 0.44921335,\n",
       "         0.44906499, 0.44895376, 0.44960267, 0.45064316, 0.45526943,\n",
       "         0.4488237 , 0.44905363, 0.44951094, 0.44912175, 0.44898973,\n",
       "         0.44889222, 0.44945162, 0.45295555, 0.44905169, 0.44937992,\n",
       "         0.45142809, 0.44901089, 0.45645888, 0.44931245, 0.44877162,\n",
       "         0.44926451, 0.44953963, 0.44925208, 0.44890404, 0.44931915,\n",
       "         0.45280662, 0.45204217, 0.44895319, 0.44923629, 0.44996417,\n",
       "         0.44884151, 0.44903282, 0.44888776, 0.44866649, 0.45138372,\n",
       "         0.44899592, 0.44875316, 0.44898025, 0.44892854, 0.45078464,\n",
       "         0.44894474, 0.45066022, 0.44920306, 0.44942604, 0.45315849,\n",
       "         0.44925427, 0.44914859, 0.45473568, 0.45709647, 0.44898633]),\n",
       "  'cali_free_log_loss': array([0.44883864, 0.44877432, 0.44979278, 0.44911342, 0.44892651,\n",
       "         0.44891767, 0.4493771 , 0.44901402, 0.44883094, 0.44920263,\n",
       "         0.4490534 , 0.44891478, 0.44910945, 0.44963584, 0.45082485,\n",
       "         0.44878893, 0.44905226, 0.44928666, 0.44904276, 0.44888261,\n",
       "         0.44884288, 0.44923188, 0.44983531, 0.44899478, 0.44921625,\n",
       "         0.44949073, 0.44897413, 0.45143633, 0.44913236, 0.44877615,\n",
       "         0.44916438, 0.4494074 , 0.44912658, 0.44890188, 0.44892444,\n",
       "         0.4499825 , 0.44992098, 0.44882068, 0.44922859, 0.44939968,\n",
       "         0.44871761, 0.44904805, 0.44888691, 0.44856075, 0.44969423,\n",
       "         0.44897907, 0.44872492, 0.44897354, 0.44881386, 0.44982824,\n",
       "         0.4489745 , 0.44930539, 0.44903307, 0.44938532, 0.45019657,\n",
       "         0.44914284, 0.44914531, 0.45065193, 0.45175959, 0.44897563])},\n",
       " 'criteo_regularization_3e-6_BN': {'log_loss': array([0.44875577, 0.44894895, 0.44925194, 0.44901664, 0.44907997,\n",
       "         0.44875738, 0.44894792, 0.44899053, 0.44939604, 0.44885527,\n",
       "         0.44903814, 0.44862552, 0.44879088, 0.44952031, 0.44897914,\n",
       "         0.44920274, 0.44904678, 0.45121403, 0.44916529, 0.44885894,\n",
       "         0.44870752, 0.44910828, 0.44907892, 0.44884661, 0.44913899,\n",
       "         0.44977082, 0.44885672, 0.44911529, 0.44938766, 0.44900322,\n",
       "         0.44887201, 0.44882011, 0.44933039, 0.44882914, 0.44904238,\n",
       "         0.44884544, 0.44899232, 0.45208389, 0.45160613, 0.44885958,\n",
       "         0.44913513, 0.44888957, 0.44907989, 0.44875296, 0.4492978 ,\n",
       "         0.44900327, 0.44936096, 0.45769656, 0.44966013, 0.44966913,\n",
       "         0.44941661, 0.44904277, 0.44919593, 0.44923133, 0.44931735,\n",
       "         0.44959073, 0.45334801, 0.44895769, 0.44928772, 0.44893113]),\n",
       "  'cali_free_log_loss': array([0.44877698, 0.44887282, 0.44912723, 0.44901235, 0.44899667,\n",
       "         0.44871985, 0.4489528 , 0.44894249, 0.44938396, 0.44880488,\n",
       "         0.44896037, 0.44859526, 0.44873395, 0.44948796, 0.44898484,\n",
       "         0.44916724, 0.44903966, 0.44984537, 0.44913977, 0.44885841,\n",
       "         0.44863493, 0.44901315, 0.44904221, 0.44885644, 0.44911213,\n",
       "         0.44938842, 0.44885707, 0.44893657, 0.44937219, 0.44897003,\n",
       "         0.44881546, 0.44876309, 0.44906102, 0.44880919, 0.4490077 ,\n",
       "         0.44885369, 0.44880835, 0.44976707, 0.449677  , 0.44886865,\n",
       "         0.44905724, 0.44884852, 0.44907579, 0.44872434, 0.44897405,\n",
       "         0.44897069, 0.44909273, 0.45094383, 0.44934689, 0.44907998,\n",
       "         0.44929177, 0.44903501, 0.44904151, 0.44910498, 0.44901678,\n",
       "         0.44902097, 0.45013623, 0.44899023, 0.44927634, 0.44895493])},\n",
       " 'criteo_regularization_3e-7_BN': {'log_loss': array([0.44916541, 0.44864007, 0.44898113, 0.44983999, 0.44907513,\n",
       "         0.44910456, 0.44928361, 0.44895282, 0.44897474, 0.44927503,\n",
       "         0.45034728, 0.44906884, 0.44875239, 0.4495844 , 0.4486398 ,\n",
       "         0.44921589, 0.45041777, 0.44902727, 0.44892663, 0.44898069,\n",
       "         0.44922391, 0.4491708 , 0.44931228, 0.44890976, 0.44904157,\n",
       "         0.44905663, 0.44964973, 0.44902695, 0.44889645, 0.45055734,\n",
       "         0.45092371, 0.44900922, 0.4495428 , 0.44908611, 0.44930662,\n",
       "         0.45130858, 0.45121427, 0.44884718, 0.44895817, 0.44875906,\n",
       "         0.44869624, 0.44910839, 0.44955071, 0.44928645, 0.44947298,\n",
       "         0.44887357, 0.44898894, 0.44879095, 0.44908898, 0.44980918,\n",
       "         0.44904151, 0.44887973, 0.45018785, 0.44884698, 0.44895657,\n",
       "         0.44893262, 0.44899815, 0.44884895, 0.44852664, 0.44965041]),\n",
       "  'cali_free_log_loss': array([0.44912645, 0.44863629, 0.44899301, 0.44947798, 0.44895289,\n",
       "         0.44907832, 0.44915518, 0.44890373, 0.44892083, 0.44920927,\n",
       "         0.44956763, 0.4488702 , 0.4487508 , 0.44930768, 0.44862562,\n",
       "         0.44923068, 0.4493585 , 0.44902475, 0.44872906, 0.44892355,\n",
       "         0.44920614, 0.44915399, 0.44920432, 0.44889958, 0.44890955,\n",
       "         0.44901925, 0.44906032, 0.44899597, 0.44876685, 0.44935074,\n",
       "         0.44969166, 0.44894117, 0.44903051, 0.44889936, 0.44918361,\n",
       "         0.44937861, 0.44976196, 0.44875591, 0.44872897, 0.44868615,\n",
       "         0.44866283, 0.4490444 , 0.44913289, 0.44923975, 0.44941703,\n",
       "         0.44880893, 0.44891825, 0.44878003, 0.44897989, 0.44934198,\n",
       "         0.44903692, 0.44883329, 0.44934624, 0.44885081, 0.44892682,\n",
       "         0.44889879, 0.44898561, 0.44885042, 0.44853379, 0.44931639])},\n",
       " 'criteo_regularization_5e-7_BN': {'log_loss': array([0.45132194, 0.44923903, 0.4490041 , 0.45061817, 0.44912096,\n",
       "         0.44963439, 0.45001685, 0.45521486, 0.44898008, 0.44992924,\n",
       "         0.44950698, 0.44893053, 0.44899754, 0.44881825, 0.44887575,\n",
       "         0.44914601, 0.44912418, 0.44894149, 0.45021454, 0.44920993,\n",
       "         0.44895222, 0.44910809, 0.4492714 , 0.44908011, 0.44946873,\n",
       "         0.44897421, 0.44903507, 0.44885937, 0.44884506, 0.44879405,\n",
       "         0.45094952, 0.44926207, 0.44907565, 0.45157011, 0.44933073,\n",
       "         0.44958046, 0.44886737, 0.44881716, 0.44932127, 0.44892678,\n",
       "         0.44910533, 0.44904099, 0.44923871, 0.44894183, 0.44900917,\n",
       "         0.4494705 , 0.44899618, 0.44921361, 0.44908703, 0.44902498,\n",
       "         0.44943942, 0.44878772, 0.44902943, 0.4489385 , 0.44893085,\n",
       "         0.44894063, 0.44941274, 0.44866915, 0.4488575 , 0.45006067]),\n",
       "  'cali_free_log_loss': array([0.44988404, 0.44920338, 0.44900476, 0.44950371, 0.44900836,\n",
       "         0.44909324, 0.44918736, 0.45054636, 0.44868038, 0.4490367 ,\n",
       "         0.44921571, 0.4488063 , 0.44885371, 0.44876274, 0.44882219,\n",
       "         0.44912235, 0.44911831, 0.44885739, 0.44928897, 0.44919949,\n",
       "         0.44892476, 0.44903602, 0.44898789, 0.44905751, 0.44901756,\n",
       "         0.44896624, 0.44904386, 0.44883799, 0.44881628, 0.44879747,\n",
       "         0.4496898 , 0.4492444 , 0.44896982, 0.44988736, 0.44907225,\n",
       "         0.44915841, 0.44876846, 0.4487844 , 0.44925218, 0.44873108,\n",
       "         0.44899137, 0.44882023, 0.4489845 , 0.44888725, 0.4489256 ,\n",
       "         0.44929468, 0.44898423, 0.44919461, 0.44907339, 0.44885737,\n",
       "         0.44939146, 0.44873781, 0.44893677, 0.44889392, 0.44892255,\n",
       "         0.44895382, 0.44890047, 0.448671  , 0.44885507, 0.44923966])},\n",
       " 'criteo_regularization_7e-7_BN': {'log_loss': array([0.44957108, 0.44900329, 0.44886391, 0.44885528, 0.44894298,\n",
       "         0.4492927 , 0.44962256, 0.45000662, 0.44918028, 0.44876548,\n",
       "         0.44926928, 0.44967791, 0.44893798, 0.44914335, 0.44926744,\n",
       "         0.44927234, 0.44878973, 0.44899375, 0.44964668, 0.44950383,\n",
       "         0.44960112, 0.44976273, 0.44952213, 0.44933662, 0.44946328,\n",
       "         0.45096695, 0.44896911, 0.44956187, 0.44896162, 0.44874039,\n",
       "         0.44902357, 0.44898243, 0.4494981 , 0.44915387, 0.44882093,\n",
       "         0.44895178, 0.44878464, 0.44913319, 0.45015331, 0.44972349,\n",
       "         0.44895197, 0.44954293, 0.44923624, 0.44878082, 0.4491903 ,\n",
       "         0.44892817, 0.44917489, 0.44876959, 0.44918756, 0.44915617,\n",
       "         0.44922501, 0.44938069, 0.4491105 , 0.44888582, 0.44914832,\n",
       "         0.44883794, 0.44885839, 0.45004089, 0.44898516, 0.44892723]),\n",
       "  'cali_free_log_loss': array([0.44875865, 0.44889248, 0.44885691, 0.44883336, 0.44884776,\n",
       "         0.44900675, 0.44947826, 0.44928834, 0.44907611, 0.4486892 ,\n",
       "         0.44926253, 0.44902958, 0.44893317, 0.44913441, 0.44876624,\n",
       "         0.44919223, 0.44875276, 0.44889461, 0.4493205 , 0.44942926,\n",
       "         0.44928795, 0.44917945, 0.44920113, 0.44891095, 0.44908576,\n",
       "         0.45017146, 0.44896975, 0.44931297, 0.44892487, 0.44864989,\n",
       "         0.44884976, 0.44892347, 0.4489969 , 0.44902204, 0.44874273,\n",
       "         0.4489191 , 0.44878012, 0.44888287, 0.44937193, 0.44898691,\n",
       "         0.44897115, 0.44917401, 0.44916176, 0.44879094, 0.4491628 ,\n",
       "         0.44892531, 0.4491654 , 0.44865969, 0.44902538, 0.44912987,\n",
       "         0.44906173, 0.4493795 , 0.44898645, 0.44878159, 0.44915919,\n",
       "         0.44880433, 0.44871914, 0.44902139, 0.44900185, 0.44889508])},\n",
       " 'criteo_regularization_5e-7': {'log_loss': array([0.4572319 , 0.45700832, 0.45648034, 0.45687456, 0.45558882,\n",
       "         0.45665562, 0.45686476, 0.45688898, 0.45749997, 0.45655644,\n",
       "         0.45622907, 0.45645477, 0.45691113, 0.45595174, 0.45670241,\n",
       "         0.45589807, 0.45745356, 0.45721753, 0.45554811, 0.45710853,\n",
       "         0.45709184, 0.4570856 , 0.45745595, 0.45686038, 0.45729258,\n",
       "         0.45718511, 0.45713187, 0.45790058, 0.45642753, 0.45714761,\n",
       "         0.45620223, 0.45707293, 0.45678686, 0.45623603, 0.45672765,\n",
       "         0.45751525, 0.4570495 , 0.45708947, 0.45653568, 0.45583934,\n",
       "         0.45671342, 0.45674549, 0.45693277, 0.45692982, 0.45684413,\n",
       "         0.45708517, 0.45666925, 0.45671612, 0.45687554, 0.45651707,\n",
       "         0.45642798, 0.45700254, 0.45649675, 0.45724376, 0.45702041,\n",
       "         0.45704131, 0.45665076, 0.45696629, 0.45603111, 0.45695103]),\n",
       "  'cali_free_log_loss': array([0.45709893, 0.45673869, 0.4563053 , 0.45686056, 0.45535435,\n",
       "         0.45656263, 0.45682983, 0.45686755, 0.45745852, 0.45647572,\n",
       "         0.45607578, 0.45638411, 0.45682373, 0.45575841, 0.45667309,\n",
       "         0.45575388, 0.45732101, 0.45670106, 0.45546657, 0.4569814 ,\n",
       "         0.45675268, 0.45682368, 0.4569508 , 0.456818  , 0.45703435,\n",
       "         0.4571179 , 0.45698803, 0.45740014, 0.45631445, 0.45713338,\n",
       "         0.45619414, 0.45687077, 0.45670004, 0.45617392, 0.45653704,\n",
       "         0.45715447, 0.45684361, 0.4565537 , 0.45617307, 0.4557523 ,\n",
       "         0.45659162, 0.45657394, 0.45671694, 0.45680406, 0.45676174,\n",
       "         0.45691962, 0.45660435, 0.45664198, 0.45684935, 0.45637673,\n",
       "         0.45626838, 0.45684388, 0.45643291, 0.45673986, 0.45680879,\n",
       "         0.45672108, 0.4566196 , 0.45694926, 0.45602347, 0.45677685])},\n",
       " 'criteo_regularization_7e-7': {'log_loss': array([0.45668387, 0.45727049, 0.45704997, 0.45656937, 0.45563382,\n",
       "         0.4562301 , 0.45514882, 0.45568508, 0.45772626, 0.45716941,\n",
       "         0.45643094, 0.45654238, 0.45688836, 0.4567622 , 0.45641731,\n",
       "         0.45661014, 0.45738877, 0.45655464, 0.45586953, 0.45616348,\n",
       "         0.45756329, 0.45643539, 0.45677082, 0.45679193, 0.45673183,\n",
       "         0.4564929 , 0.4565276 , 0.45693548, 0.45663538, 0.45699512,\n",
       "         0.45639009, 0.45659466, 0.45720297, 0.45708307, 0.45655847,\n",
       "         0.45711444, 0.45667763, 0.45626678, 0.45656895, 0.45680718,\n",
       "         0.45649766, 0.45705243, 0.45699573, 0.45743175, 0.45653076,\n",
       "         0.456672  , 0.45673413, 0.45652959, 0.45723164, 0.45715857,\n",
       "         0.45701809, 0.45642071, 0.45697477, 0.45587426, 0.45662798,\n",
       "         0.4563595 , 0.45657657, 0.45700194, 0.45711484, 0.45691272]),\n",
       "  'cali_free_log_loss': array([0.4566015 , 0.4571964 , 0.4562785 , 0.45646736, 0.45559483,\n",
       "         0.45621095, 0.45497839, 0.45532399, 0.45737916, 0.45704129,\n",
       "         0.45626476, 0.45652242, 0.45686932, 0.45672221, 0.45635594,\n",
       "         0.45656327, 0.45734142, 0.45651596, 0.45580583, 0.45608997,\n",
       "         0.45704105, 0.45621566, 0.45671512, 0.4566758 , 0.45660501,\n",
       "         0.4564514 , 0.45635938, 0.45684351, 0.45655318, 0.45669073,\n",
       "         0.45636262, 0.45656186, 0.45713886, 0.45686143, 0.45645566,\n",
       "         0.45710332, 0.45658698, 0.45623487, 0.45654677, 0.45666756,\n",
       "         0.45644061, 0.45702527, 0.45687765, 0.45740632, 0.45649531,\n",
       "         0.4566113 , 0.45662132, 0.45651147, 0.45720227, 0.45707671,\n",
       "         0.45694027, 0.45634701, 0.4568861 , 0.45584836, 0.45658833,\n",
       "         0.4563026 , 0.45644837, 0.45690657, 0.45708234, 0.45683768])},\n",
       " 'criteo_regularization_1e-6': {'log_loss': array([0.45708448, 0.45731277, 0.45708105, 0.45610706, 0.45688317,\n",
       "         0.45681677, 0.4567735 , 0.4570416 , 0.45729804, 0.45676532,\n",
       "         0.45684639, 0.45603285, 0.45730932, 0.45690453, 0.45658464,\n",
       "         0.45694896, 0.45728039, 0.45680874, 0.45671462, 0.45695108,\n",
       "         0.45693353, 0.45659548, 0.45689995, 0.4569218 , 0.45647551,\n",
       "         0.45596791, 0.45651019, 0.45704671, 0.4567002 , 0.45685156,\n",
       "         0.45678902, 0.45588119, 0.4566548 , 0.45658999, 0.45712782,\n",
       "         0.45645801, 0.45692432, 0.45701594, 0.45672628, 0.45727999,\n",
       "         0.4569132 , 0.45687847, 0.45680057, 0.45681536, 0.45696623,\n",
       "         0.45674285, 0.45649227, 0.45632092, 0.45693608, 0.45682847,\n",
       "         0.4564442 , 0.45672817, 0.45680899, 0.45612723, 0.45672818,\n",
       "         0.45696758, 0.45630936, 0.45687463, 0.45655898, 0.45654054]),\n",
       "  'cali_free_log_loss': array([0.45700378, 0.45700781, 0.45705089, 0.45608813, 0.45684965,\n",
       "         0.4568058 , 0.45672879, 0.45688875, 0.45718627, 0.45676117,\n",
       "         0.45680405, 0.45597021, 0.45699137, 0.45684228, 0.45655296,\n",
       "         0.45687027, 0.45715529, 0.45649145, 0.45664939, 0.45647037,\n",
       "         0.45686417, 0.45656471, 0.45688522, 0.45673373, 0.45634791,\n",
       "         0.45591397, 0.4564812 , 0.45700333, 0.45657441, 0.45682591,\n",
       "         0.45676446, 0.45566054, 0.4564858 , 0.45654973, 0.45702795,\n",
       "         0.45644897, 0.45665541, 0.45692944, 0.45663354, 0.45710197,\n",
       "         0.45685459, 0.456842  , 0.45673906, 0.45678163, 0.45689313,\n",
       "         0.45669264, 0.45642174, 0.45628995, 0.45690768, 0.45682069,\n",
       "         0.45614944, 0.45653629, 0.45675205, 0.45613339, 0.45665155,\n",
       "         0.4568277 , 0.4562845 , 0.45628727, 0.4564688 , 0.45650195])},\n",
       " 'criteo_regularization_3e-7': {'log_loss': array([0.45704534, 0.45722193, 0.4565693 , 0.45680674, 0.45613224,\n",
       "         0.45712072, 0.45663871, 0.4563629 , 0.4571767 , 0.45709912,\n",
       "         0.45662202, 0.45644474, 0.45715864, 0.45698563, 0.45621722,\n",
       "         0.45687841, 0.45701665, 0.45680147, 0.45621974, 0.45640168,\n",
       "         0.45708539, 0.45647517, 0.45668336, 0.45685241, 0.45681884,\n",
       "         0.45650314, 0.4566387 , 0.45733912, 0.45656936, 0.45674192,\n",
       "         0.45708456, 0.45668132, 0.456718  , 0.45619318, 0.45704197,\n",
       "         0.45668928, 0.45631164, 0.4562444 , 0.45687677, 0.45713436,\n",
       "         0.45625166, 0.45724639, 0.45699927, 0.45740603, 0.45681758,\n",
       "         0.45621319, 0.45652366, 0.45667933, 0.45651593, 0.45688445,\n",
       "         0.45694361, 0.45636917, 0.45696484, 0.45708599, 0.45756435,\n",
       "         0.45686388, 0.45678691, 0.45678574, 0.45662313, 0.45691753]),\n",
       "  'cali_free_log_loss': array([0.45699894, 0.45690679, 0.45648517, 0.45662931, 0.45610772,\n",
       "         0.45706863, 0.45653009, 0.45624863, 0.45715829, 0.45707686,\n",
       "         0.45660273, 0.45639264, 0.45711692, 0.45685668, 0.45617455,\n",
       "         0.4568162 , 0.45699593, 0.45668687, 0.45619196, 0.45604636,\n",
       "         0.45698961, 0.45644026, 0.45665035, 0.45673679, 0.45660299,\n",
       "         0.45645665, 0.45659886, 0.45730583, 0.45649496, 0.4566288 ,\n",
       "         0.45705348, 0.45666055, 0.45667845, 0.45616802, 0.45667237,\n",
       "         0.45640677, 0.45625115, 0.45618595, 0.45673766, 0.45708692,\n",
       "         0.45620994, 0.45688807, 0.4569719 , 0.45728509, 0.45669375,\n",
       "         0.45616308, 0.45647653, 0.45666158, 0.45638503, 0.4568253 ,\n",
       "         0.45669042, 0.45633329, 0.4569112 , 0.45680557, 0.45752208,\n",
       "         0.4568476 , 0.45669707, 0.45674934, 0.4565745 , 0.45684308])},\n",
       " 'criteo_smaller_arch': {'log_loss': array([0.45861212, 0.45940644, 0.45940574, 0.45908436, 0.45897886,\n",
       "         0.4589124 , 0.459344  , 0.45921243, 0.45991291, 0.45909171,\n",
       "         0.45888622, 0.45929189, 0.45903042, 0.45955572, 0.45944443,\n",
       "         0.45926055, 0.45922368, 0.45941957, 0.45927325, 0.45871793,\n",
       "         0.45930229, 0.45928633, 0.45921898, 0.45921643, 0.45934197,\n",
       "         0.45898276, 0.45940308, 0.45954979, 0.4591718 , 0.45937054,\n",
       "         0.45873714, 0.45937399, 0.45938137, 0.45937248, 0.45922059,\n",
       "         0.4592063 , 0.45944347, 0.4590413 , 0.45895842, 0.45904357,\n",
       "         0.45943702, 0.45922879, 0.45950923, 0.45912342, 0.45948011,\n",
       "         0.45929001, 0.4593057 , 0.45918971, 0.4593545 , 0.45899338,\n",
       "         0.45912131, 0.45914954, 0.45905658, 0.45919578, 0.45906658,\n",
       "         0.4593242 , 0.45913922, 0.45861771, 0.45915091, 0.45907116]),\n",
       "  'cali_free_log_loss': array([0.45857358, 0.45917372, 0.45924096, 0.45903083, 0.45885565,\n",
       "         0.45886231, 0.45919971, 0.45917032, 0.459888  , 0.45905789,\n",
       "         0.45878254, 0.45916194, 0.45892191, 0.45948197, 0.45909213,\n",
       "         0.45906983, 0.4591944 , 0.45937542, 0.45923751, 0.45869918,\n",
       "         0.45918124, 0.4591044 , 0.45918077, 0.45912613, 0.4593046 ,\n",
       "         0.45893726, 0.45934711, 0.45949821, 0.45915707, 0.4593434 ,\n",
       "         0.45870102, 0.45929664, 0.45935266, 0.45931045, 0.45912588,\n",
       "         0.45916561, 0.45939166, 0.45901584, 0.4589089 , 0.45893804,\n",
       "         0.45928194, 0.45911898, 0.45933037, 0.4590676 , 0.45943495,\n",
       "         0.45917843, 0.45926257, 0.45913961, 0.459317  , 0.45894323,\n",
       "         0.45898176, 0.4590688 , 0.45900296, 0.459156  , 0.45887781,\n",
       "         0.45927992, 0.45910998, 0.45850997, 0.45910006, 0.45901795])},\n",
       " 'criteo_dropout_07': {'log_loss': array([0.45874146, 0.45893777, 0.45865639, 0.45864502, 0.45849722,\n",
       "         0.45834948, 0.4585057 , 0.45853025, 0.45856228, 0.45854733,\n",
       "         0.45824718, 0.4579111 , 0.45775733, 0.45856308, 0.45841859,\n",
       "         0.458632  , 0.45830234, 0.45845794, 0.45835095, 0.45830165,\n",
       "         0.45845542, 0.45853367, 0.45911075, 0.45906636, 0.45833828,\n",
       "         0.45837384, 0.45926145, 0.45882558, 0.45824335, 0.45911221,\n",
       "         0.45870491, 0.458581  , 0.45873698, 0.4580137 , 0.45869776,\n",
       "         0.45965756, 0.45854299, 0.45825017, 0.45844878, 0.45852152,\n",
       "         0.45866374, 0.45843937, 0.4581116 , 0.45883195, 0.45875979,\n",
       "         0.4583283 , 0.45855813, 0.45871369, 0.45861248, 0.45805245,\n",
       "         0.45843637, 0.45852561, 0.45851555, 0.45822691, 0.45856108,\n",
       "         0.45798363, 0.45815825, 0.45845296, 0.45851473, 0.45908658]),\n",
       "  'cali_free_log_loss': array([0.4587151 , 0.45878419, 0.45860328, 0.45860986, 0.4584509 ,\n",
       "         0.45825667, 0.45845763, 0.45825612, 0.4585134 , 0.45850603,\n",
       "         0.45814432, 0.45787469, 0.45767014, 0.4585031 , 0.45833823,\n",
       "         0.45857563, 0.45828599, 0.45836465, 0.45821547, 0.45826746,\n",
       "         0.45838819, 0.45848181, 0.45902773, 0.45866372, 0.45825866,\n",
       "         0.4583429 , 0.45911407, 0.45877037, 0.45818042, 0.45887104,\n",
       "         0.45865207, 0.45852624, 0.45868597, 0.45798844, 0.45863317,\n",
       "         0.45961835, 0.45849818, 0.45820848, 0.45812729, 0.45845967,\n",
       "         0.45862434, 0.45840514, 0.45809237, 0.45873986, 0.45862518,\n",
       "         0.45826729, 0.45849528, 0.45862447, 0.45841422, 0.45800948,\n",
       "         0.45836838, 0.45833825, 0.45846648, 0.45818226, 0.45852471,\n",
       "         0.45792088, 0.4581214 , 0.45838416, 0.45824715, 0.45903786])},\n",
       " 'criteo_baseline': {'log_loss': array([0.45761528, 0.45709011, 0.45688497, 0.45715396, 0.45592897,\n",
       "         0.45658749, 0.45730266, 0.45704098, 0.45731717, 0.45732655,\n",
       "         0.4558828 , 0.45730561, 0.45693327, 0.45654694, 0.45666823,\n",
       "         0.45704683, 0.45723971, 0.45664198, 0.45657655, 0.456247  ,\n",
       "         0.45724153, 0.45685076, 0.45738691, 0.45683383, 0.45699917,\n",
       "         0.45697952, 0.45680307, 0.45722766, 0.45728696, 0.45682305,\n",
       "         0.45662151, 0.45671248, 0.45700285, 0.45708189, 0.45755461,\n",
       "         0.45781356, 0.45682197, 0.45680626, 0.45719901, 0.45699416,\n",
       "         0.45723588, 0.45695386, 0.45680441, 0.45685722, 0.45649706,\n",
       "         0.45700031, 0.45668869, 0.45631044, 0.45687771, 0.45686204,\n",
       "         0.45719983, 0.45655644, 0.45709974, 0.45694683, 0.45720826,\n",
       "         0.45631459, 0.45627967, 0.45730666, 0.45676027, 0.45700573]),\n",
       "  'cali_free_log_loss': array([0.45743336, 0.45705441, 0.45685247, 0.4571003 , 0.45564999,\n",
       "         0.45645504, 0.45683585, 0.45685688, 0.45728102, 0.45720148,\n",
       "         0.45578673, 0.45719557, 0.45689948, 0.45653313, 0.45662473,\n",
       "         0.45697545, 0.457152  , 0.45647547, 0.45634309, 0.45620543,\n",
       "         0.45705578, 0.45675465, 0.4570624 , 0.45681793, 0.45674566,\n",
       "         0.45692629, 0.45674713, 0.45711073, 0.4568625 , 0.45676998,\n",
       "         0.45660498, 0.45633985, 0.456847  , 0.45665844, 0.45737192,\n",
       "         0.45732198, 0.45677074, 0.45671111, 0.4566859 , 0.45687651,\n",
       "         0.45709441, 0.45687326, 0.45676782, 0.45683001, 0.45632581,\n",
       "         0.4569725 , 0.45647742, 0.45624968, 0.45674682, 0.45683238,\n",
       "         0.45704295, 0.45649824, 0.45701772, 0.45691024, 0.45714031,\n",
       "         0.45626319, 0.45623476, 0.45700476, 0.4566966 , 0.456789  ])},\n",
       " 'criteo_BN': {'log_loss': array([0.44931901, 0.45097267, 0.44910511, 0.44886827, 0.44949152,\n",
       "         0.44899351, 0.4492049 , 0.44907833, 0.44915536, 0.44903767,\n",
       "         0.44984189, 0.44907094, 0.44918324, 0.44906951, 0.44981694,\n",
       "         0.4493403 , 0.44972974, 0.44877873, 0.44901486, 0.44885095,\n",
       "         0.44892701, 0.44942284, 0.44882012, 0.44951149, 0.44913264,\n",
       "         0.4490785 , 0.45027432, 0.44911137, 0.44941463, 0.44886919,\n",
       "         0.4490768 , 0.44952053, 0.4488391 , 0.44910917, 0.44902919,\n",
       "         0.44891795, 0.44901405, 0.44919049, 0.44884973, 0.44911733,\n",
       "         0.45279073, 0.44909553, 0.44943829, 0.44920826, 0.44912486,\n",
       "         0.45057343, 0.45223183, 0.44899498, 0.44876129, 0.44880567,\n",
       "         0.44874529, 0.44906236, 0.45115172, 0.44901373, 0.44943657,\n",
       "         0.44937695, 0.44893358, 0.44938194, 0.44874771, 0.44895771]),\n",
       "  'cali_free_log_loss': array([0.4492049 , 0.44925902, 0.4491013 , 0.44884533, 0.44937347,\n",
       "         0.44887392, 0.44901421, 0.44896048, 0.44897416, 0.44890492,\n",
       "         0.44900521, 0.44903279, 0.44912867, 0.44907322, 0.44945558,\n",
       "         0.44934349, 0.4494522 , 0.44872678, 0.44884782, 0.44884526,\n",
       "         0.44882934, 0.44915887, 0.44877875, 0.44922346, 0.44873959,\n",
       "         0.44902089, 0.44940523, 0.44911093, 0.44905629, 0.44883955,\n",
       "         0.44902466, 0.44955017, 0.44884585, 0.44891748, 0.44899173,\n",
       "         0.44894793, 0.44894134, 0.44904183, 0.44883218, 0.44911507,\n",
       "         0.44981219, 0.44903765, 0.44897679, 0.4492137 , 0.44913942,\n",
       "         0.44927393, 0.45004553, 0.44898015, 0.44870311, 0.44876697,\n",
       "         0.44869281, 0.44891263, 0.44962863, 0.44901528, 0.44936904,\n",
       "         0.44904154, 0.44891577, 0.44922505, 0.44875595, 0.44893885])}}"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "   Pipeline Log Loss (mean) Cali-Free (mean)\n",
      "0  Baseline         0.44935          0.44907\n",
      "1      0.07         0.44999          0.44951\n",
      "2       0.1         0.45017          0.44966\n",
      "3      0.15         0.45087          0.45004\n",
      "4       0.2         0.45077          0.45008\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_3220/930610118.py:11: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  df = df.append(\n",
      "/tmp/ipykernel_3220/930610118.py:11: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  df = df.append(\n",
      "/tmp/ipykernel_3220/930610118.py:11: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  df = df.append(\n",
      "/tmp/ipykernel_3220/930610118.py:11: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  df = df.append(\n",
      "/tmp/ipykernel_3220/930610118.py:11: FutureWarning: The frame.append method is deprecated and will be removed from pandas in a future version. Use pandas.concat instead.\n",
      "  df = df.append(\n"
     ]
    }
   ],
   "source": [
    "name_dict = {\n",
    "    \"criteo_BN\": \"Baseline\",\n",
    "    \"criteo_regularization_7e-2_BN\": \"0.07\",\n",
    "    \"criteo_regularization_1e-1_BN\": \"0.1\",\n",
    "    \"criteo_regularization_15e-2_BN\": \"0.15\",\n",
    "    \"criteo_regularization_2e-1_BN\": \"0.2\",\n",
    "}\n",
    "\n",
    "df = pd.DataFrame(columns=['Pipeline', 'Log Loss (mean)', 'Cali-Free (mean)'])\n",
    "for key, name in name_dict.items():\n",
    "    df = df.append(\n",
    "        {\n",
    "            'Pipeline': name, \n",
    "            'Log Loss (mean)': f\"{round(np.mean(results[key]['log_loss']), 5)}\",\n",
    "            'Cali-Free (mean)': f\"{round(np.mean(results[key]['cali_free_log_loss']), 5)}\",\n",
    "        },\n",
    "        ignore_index = True,\n",
    "    )\n",
    "    df.to_excel(f\"./cali_free_paper_results/regularization_mean_log_loss.xlsx\", index=False)\n",
    "    \n",
    "print(df)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3.8.10 64-bit",
   "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.8.10"
  },
  "orig_nbformat": 4,
  "vscode": {
   "interpreter": {
    "hash": "e7370f93d1d0cde622a1f8e1c04877d8463912d04d973331ad4851f04de6915a"
   }
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
