{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Welcome to the LSBoosting Notebook for Folktables!"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "In this notebook, you'll be able to import US Census data from Folktables easily via the helper function and then train a LSBoostRegressor using your choice of hyperparameters!"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Install/Imports"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "# pip install scikit-learn\n",
    "# pip install tqdm\n",
    "# pip install pandas\n",
    "# pip install seaborn\n",
    "# pip install folktables"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {
    "metadata": {}
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/ralur/miniconda3/envs/heap/lib/python3.12/site-packages/tqdm/auto.py:21: TqdmWarning: IProgress not found. Please update jupyter and ipywidgets. See https://ipywidgets.readthedocs.io/en/stable/user_install.html\n",
      "  from .autonotebook import tqdm as notebook_tqdm\n"
     ]
    }
   ],
   "source": [
    "\n",
    "import LSBoost\n",
    "# from LSBoost import LSBoostingRegressor\n",
    "import helper_functions as hf\n",
    "\n",
    "import pandas as pd\n",
    "\n",
    "import numpy as np\n",
    "\n",
    "import sklearn as sk\n",
    "from sklearn.model_selection import train_test_split\n",
    "from helper_functions import MSCE as MSCE\n",
    "from sklearn.metrics import mean_squared_error as MSE\n",
    "\n",
    "from sklearn.linear_model import LinearRegression\n",
    "from sklearn.tree import DecisionTreeRegressor\n",
    "from sklearn.tree import DecisionTreeClassifier\n",
    "from sklearn.ensemble import GradientBoostingRegressor\n",
    "from sklearn.linear_model import LogisticRegression\n",
    "\n",
    "import gc\n",
    "import time\n",
    "import warnings\n",
    "\n",
    "warnings.filterwarnings(\"ignore\", category=FutureWarning)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {
    "metadata": {}
   },
   "outputs": [],
   "source": [
    "X = pd.read_csv('./visual-prediction-data/features_labels_wide.csv')\n",
    "h = pd.read_csv('./visual-prediction-data/study_2/responses.csv')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {
    "metadata": {}
   },
   "outputs": [],
   "source": [
    "data = X.drop(['escaped', 'location', 'room'], axis=1)\n",
    "escaped = X['escaped'].map({'Y': 1, 'N': 0})\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {
    "metadata": {}
   },
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>file_id</th>\n",
       "      <th>location_boston</th>\n",
       "      <th>location_arizona</th>\n",
       "      <th>location_texas</th>\n",
       "      <th>location_nyc</th>\n",
       "      <th>room_theater</th>\n",
       "      <th>room_dig</th>\n",
       "      <th>room_office</th>\n",
       "      <th>room_home</th>\n",
       "      <th>room_apartment</th>\n",
       "      <th>...</th>\n",
       "      <th>p_glass</th>\n",
       "      <th>race_NA</th>\n",
       "      <th>race_asian</th>\n",
       "      <th>race_black</th>\n",
       "      <th>race_white</th>\n",
       "      <th>race_entropy</th>\n",
       "      <th>smile_coef_mean</th>\n",
       "      <th>smile_coef_median</th>\n",
       "      <th>smile_coef_std</th>\n",
       "      <th>confidence</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>1010227249025169</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>...</td>\n",
       "      <td>0.0</td>\n",
       "      <td>3</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>7</td>\n",
       "      <td>0.0</td>\n",
       "      <td>54.961</td>\n",
       "      <td>70.882</td>\n",
       "      <td>33.650</td>\n",
       "      <td>2</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>969078203140074</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>...</td>\n",
       "      <td>0.0</td>\n",
       "      <td>4</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>8</td>\n",
       "      <td>0.0</td>\n",
       "      <td>87.983</td>\n",
       "      <td>95.030</td>\n",
       "      <td>17.712</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>906142969433598</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>...</td>\n",
       "      <td>0.4</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>5</td>\n",
       "      <td>0.0</td>\n",
       "      <td>58.330</td>\n",
       "      <td>74.165</td>\n",
       "      <td>24.595</td>\n",
       "      <td>5</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>880673725313856</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>...</td>\n",
       "      <td>0.0</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>5</td>\n",
       "      <td>0.0</td>\n",
       "      <td>52.075</td>\n",
       "      <td>43.388</td>\n",
       "      <td>20.601</td>\n",
       "      <td>5</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>965696076811620</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>...</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>10</td>\n",
       "      <td>0.0</td>\n",
       "      <td>88.929</td>\n",
       "      <td>93.034</td>\n",
       "      <td>10.039</td>\n",
       "      <td>3</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>5 rows × 35 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "            file_id  location_boston  location_arizona  location_texas  \\\n",
       "0  1010227249025169                1                 0               0   \n",
       "1   969078203140074                1                 0               0   \n",
       "2   906142969433598                1                 0               0   \n",
       "3   880673725313856                1                 0               0   \n",
       "4   965696076811620                1                 0               0   \n",
       "\n",
       "   location_nyc  room_theater  room_dig  room_office  room_home  \\\n",
       "0             0             0         0            1          0   \n",
       "1             0             0         0            1          0   \n",
       "2             0             0         0            0          0   \n",
       "3             0             0         0            0          0   \n",
       "4             0             0         0            1          0   \n",
       "\n",
       "   room_apartment  ...  p_glass  race_NA  race_asian  race_black  race_white  \\\n",
       "0               0  ...      0.0        3           0           0           7   \n",
       "1               0  ...      0.0        4           0           0           8   \n",
       "2               0  ...      0.4        0           0           0           5   \n",
       "3               0  ...      0.0        2           0           0           5   \n",
       "4               0  ...      0.0        0           0           0          10   \n",
       "\n",
       "   race_entropy  smile_coef_mean  smile_coef_median  smile_coef_std  \\\n",
       "0           0.0           54.961             70.882          33.650   \n",
       "1           0.0           87.983             95.030          17.712   \n",
       "2           0.0           58.330             74.165          24.595   \n",
       "3           0.0           52.075             43.388          20.601   \n",
       "4           0.0           88.929             93.034          10.039   \n",
       "\n",
       "   confidence  \n",
       "0           2  \n",
       "1           1  \n",
       "2           5  \n",
       "3           5  \n",
       "4           3  \n",
       "\n",
       "[5 rows x 35 columns]"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "data.head()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {
    "metadata": {}
   },
   "outputs": [],
   "source": [
    "random_state = 0\n",
    "np.random.seed(random_state)\n",
    "\n",
    "\n",
    "x_train = data[~data['file_id'].isin(h['Img'])]\n",
    "y_train = escaped[~data['file_id'].isin(h['Img'])]\n",
    "\n",
    "x_test = data[data['file_id'].isin(h['Img'])]\n",
    "y_test = escaped[data['file_id'].isin(h['Img'])]\n",
    "\n",
    "\n",
    "x_train_id = x_train['file_id']\n",
    "x_train = x_train.drop(['file_id'], axis = 1)\n",
    "x_test_id = x_test['file_id']\n",
    "x_test = x_test.drop('file_id', axis = 1)\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAk0AAAHHCAYAAACiOWx7AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjkuMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy80BEi2AAAACXBIWXMAAA9hAAAPYQGoP6dpAAA9sUlEQVR4nO3deVgW9f7/8Reg3KAJqIjIkRT3NT1pIqWWRaKSZXpOmaagmMeCSlFTs+OSnTBN09LytChW7h21cifcTi6ZC7ml5hZ2FLUUEFRAmN8ffZlft7gMyHJjz8d1zZX3Z973zHs+UvermbkHJ8MwDAEAAOCmnEu6AQAAgNKA0AQAAGABoQkAAMACQhMAAIAFhCYAAAALCE0AAAAWEJoAAAAsIDQBAABYQGgCAACwgNAEwFSzZk2Fh4eXdBt3vEmTJqlWrVpycXFR8+bNS7qd28bPDf4sCE3AHSo2NlZOTk7asWPHddc/9NBDatKkyW3vZ+XKlRo7duxtb+fPYu3atXrllVf0wAMPaPbs2XrzzTeLfJ9btmzR2LFjlZycXOT7Au5kZUq6AQCO49ChQ3J2zt//S61cuVIzZswgOFm0bt06OTs765NPPpGrq2ux7HPLli0aN26cwsPD5eXlVejbL8jPDVAa8VMOwGSz2VS2bNmSbiNf0tPTS7qFfDl79qzc3d2LLTDlV05Ojq5cuZKv95TGnxugIAhNAEzX3puSlZWlcePGqW7dunJzc1PlypXVpk0bxcXFSZLCw8M1Y8YMSZKTk5O55EpPT9eQIUPk7+8vm82m+vXr6+2335ZhGHb7vXz5sl566SV5e3urQoUKevzxx/W///1PTk5Odmewxo4dKycnJx04cEA9e/ZUxYoV1aZNG0nSnj17FB4erlq1asnNzU2+vr7q16+ffvvtN7t95W7j8OHDevbZZ+Xp6akqVaron//8pwzD0MmTJ/XEE0/Iw8NDvr6+mjx5sqW5u3r1qsaPH6/atWvLZrOpZs2aevXVV5WRkWHWODk5afbs2UpPTzfnKjY29rrbGzNmjMqWLatz587lWTdgwAB5eXlZCjdjx47VsGHDJEkBAQHmfk+cOGH2FBUVpblz56px48ay2WxavXq1JOntt9/W/fffr8qVK8vd3V0tWrTQF198kWcf1/7c5F4a3rx5s6Kjo1WlShWVL19eTz755HWPBygtuDwH3OFSUlL066+/5hnPysq65XvHjh2rmJgY9e/fX61atVJqaqp27NihXbt26dFHH9U//vEPnTp1SnFxcfrss8/s3msYhh5//HGtX79eERERat68udasWaNhw4bpf//7n9555x2zNjw8XIsWLVLv3r3VunVrbdy4UaGhoTfs6+9//7vq1q2rN9980wxgcXFxOnbsmPr27StfX1/t379fH374ofbv369t27bZhTlJevrpp9WwYUNNmDBBK1as0BtvvKFKlSrp3//+tx5++GG99dZbmjt3roYOHar77rtP7dq1u+lc9e/fX3PmzNHf/vY3DRkyRN99951iYmL0448/aunSpZKkzz77TB9++KG2b9+ujz/+WJJ0//33X3d7vXv31uuvv66FCxcqKirKHM/MzNQXX3yh7t27y83N7aY9SVK3bt10+PBhzZ8/X++88468vb0lSVWqVDFr1q1bp0WLFikqKkre3t6qWbOmJGnatGl6/PHH1atXL2VmZmrBggX6+9//ruXLl9/07yfXiy++qIoVK2rMmDE6ceKEpk6dqqioKC1cuPCW7wUckgHgjjR79mxD0k2Xxo0b272nRo0aRlhYmPm6WbNmRmho6E33ExkZaVzvPyXLli0zJBlvvPGG3fjf/vY3w8nJyThy5IhhGIaxc+dOQ5IxaNAgu7rw8HBDkjFmzBhzbMyYMYYk45lnnsmzv0uXLuUZmz9/viHJ2LRpU55tDBgwwBy7evWqUb16dcPJycmYMGGCOX7hwgXD3d3dbk6uJyEhwZBk9O/f32586NChhiRj3bp15lhYWJhRvnz5m24vV1BQkBEYGGg3tmTJEkOSsX79ekvbMAzDmDRpkiHJOH78eJ51kgxnZ2dj//79edZdO6eZmZlGkyZNjIcffthu/Nqfm9yfveDgYCMnJ8ccHzx4sOHi4mIkJydb7h1wJFyeA+5wM2bMUFxcXJ7lnnvuueV7vby8tH//fv3000/53u/KlSvl4uKil156yW58yJAhMgxDq1atkiTzUtALL7xgV/fiiy/ecNsDBw7MM+bu7m7++cqVK/r111/VunVrSdKuXbvy1Pfv39/8s4uLi1q2bCnDMBQREWGOe3l5qX79+jp27NgNe5F+P1ZJio6OthsfMmSIJGnFihU3ff+N9OnTR999952OHj1qjs2dO1f+/v568MEHC7TN63nwwQfVqFGj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AMBREZoAAAAscJjnNOHmao5YcesiB3NiQmhJtwAAQKHhTBMAAIAFhCYAAAALCE0AAAAWEJoAAAAsIDQBAABYQGgCAACwgNAEAABgAaEJAADAAkITAACABYQmAAAACwhNAAAAFhCaAAAALCA0AQAAWEBoAgAAsIDQBAAAYAGhCQAAwAJCEwAAgAWEJgAAAAsITQAAABYQmgAAACwgNAEAAFhAaAIAALCA0AQAAGABoQkAAMACQhMAAIAFhCYAAAALCE0AAAAWEJoAAAAsIDQBAABYQGgCAACwgNAEAABgAaEJAADAAkITAACABYQmAAAACwhNAAAAFhCaAAAALCA0AQAAWEBoAgAAsIDQBAAAYAGhCQAAwAJCEwAAgAWEJgAAAAsITQAAABYQmgAAACwgNAEAAFhAaAIAALCA0AQAAGABoQkAAMACQhMAAIAFhCYAAAALCE0AAAAWEJoAAAAsIDQBAABYQGgCAACwgNAEAABgAaEJAADAAkITAACABYQmAAAAC0o0NMXExOi+++5ThQoV5OPjo65du+rQoUN2NVeuXFFkZKQqV66su+66S927d9eZM2fsahITExUaGqpy5crJx8dHw4YN09WrV+1qNmzYoHvvvVc2m0116tRRbGxsnn5mzJihmjVrys3NTYGBgdq+fXuhHzMAACidSjQ0bdy4UZGRkdq2bZvi4uKUlZWlDh06KD093awZPHiwvv76ay1evFgbN27UqVOn1K1bN3N9dna2QkNDlZmZqS1btmjOnDmKjY3V6NGjzZrjx48rNDRU7du3V0JCggYNGqT+/ftrzZo1Zs3ChQsVHR2tMWPGaNeuXWrWrJlCQkJ09uzZ4pkMAADg0JwMwzBKuolc586dk4+PjzZu3Kh27dopJSVFVapU0bx58/S3v/1NknTw4EE1bNhQW7duVevWrbVq1So99thjOnXqlKpWrSpJmjlzpoYPH65z587J1dVVw4cP14oVK7Rv3z5zXz169FBycrJWr14tSQoMDNR9992n6dOnS5JycnLk7++vF198USNGjLhl76mpqfL09FRKSoo8PDwKe2pUc8SKQt9mUTsxIbSkWwAA4Kby8/ntUPc0paSkSJIqVaokSdq5c6eysrIUHBxs1jRo0EB33323tm7dKknaunWrmjZtagYmSQoJCVFqaqr2799v1vxxG7k1udvIzMzUzp07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oHua1q5dqzVr1qh69ep243Xr1tXPP/9cKI0BAAA4kgKdaUpPT7c7w5Tr/Pnzstlst90UAACAoylQaGrbtq0+/fRT87WTk5NycnI0ceJEtW/fvtCaAwAAcBQFujw3ceJEPfLII9qxY4cyMzP1yiuvaP/+/Tp//rw2b95c2D0CAACUuAKdaWrSpIkOHz6sNm3a6IknnlB6erq6deum3bt3q3bt2oXdIwAAQInL95mmrKwsdezYUTNnztSoUaOKoicAAACHk+8zTWXLltWePXuKohcAAACHVaDLc88++6w++eSTwu4FAADAYRXoRvCrV69q1qxZ+uabb9SiRYs8v3NuypQphdIcAACAo8hXaDp27Jhq1qypffv26d5775UkHT582K7Gycmp8LoDAABwEPkKTXXr1tXp06e1fv16Sb//2pR3331XVatWLZLmAAAAHEW+7mkyDMPu9apVq5Senl6oDQEAADiiAt0InuvaEAUAAHCnyldocnJyynPPEvcwAQCAP4N83dNkGIbCw8PNX8p75coVDRw4MM+355YsWVJ4HQIAADiAfJ1pCgsLk4+Pjzw9PeXp6alnn31Wfn5+5uvcxapNmzapS5cu8vPzk5OTk5YtW2a33jAMjR49WtWqVZO7u7uCg4P1008/2dWcP39evXr1koeHh7y8vBQREaG0tDS7mj179qht27Zyc3OTv7+/Jk6cmKeXxYsXq0GDBnJzc1PTpk21cuVK6xMDAADuePk60zR79uxC3Xl6erqaNWumfv36qVu3bnnWT5w4Ue+++67mzJmjgIAA/fOf/1RISIgOHDggNzc3SVKvXr10+vRpxcXFKSsrS3379tWAAQM0b948SVJqaqo6dOig4OBgzZw5U3v37lW/fv3k5eWlAQMGSJK2bNmiZ555RjExMXrsscc0b948de3aVbt27VKTJk0K9ZgBAEDp5GQ4yN3cTk5OWrp0qbp27Srp97NMfn5+GjJkiIYOHSpJSklJUdWqVRUbG6sePXroxx9/VKNGjfT999+rZcuWkqTVq1erc+fO+uWXX+Tn56cPPvhAo0aNUlJSklxdXSVJI0aM0LJly3Tw4EFJvz86IT09XcuXLzf7ad26tZo3b66ZM2da6j81NVWenp5KSUmRh4dHYU2LqeaIFYW+zaJ2YkJoSbcAALgBPld+l5/P79v69lxROn78uJKSkhQc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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# plot histogram of y_train\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "plt.hist(y_train)\n",
    "plt.xlabel('Escaped')\n",
    "plt.ylabel('Frequency')\n",
    "plt.title('Histogram of y_train')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {
    "metadata": {}
   },
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>location_boston</th>\n",
       "      <th>location_arizona</th>\n",
       "      <th>location_texas</th>\n",
       "      <th>location_nyc</th>\n",
       "      <th>room_theater</th>\n",
       "      <th>room_dig</th>\n",
       "      <th>room_office</th>\n",
       "      <th>room_home</th>\n",
       "      <th>room_apartment</th>\n",
       "      <th>room_agency</th>\n",
       "      <th>...</th>\n",
       "      <th>p_glass</th>\n",
       "      <th>race_NA</th>\n",
       "      <th>race_asian</th>\n",
       "      <th>race_black</th>\n",
       "      <th>race_white</th>\n",
       "      <th>race_entropy</th>\n",
       "      <th>smile_coef_mean</th>\n",
       "      <th>smile_coef_median</th>\n",
       "      <th>smile_coef_std</th>\n",
       "      <th>confidence</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>...</td>\n",
       "      <td>0.0</td>\n",
       "      <td>3</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>7</td>\n",
       "      <td>0.0</td>\n",
       "      <td>54.961</td>\n",
       "      <td>70.882</td>\n",
       "      <td>33.650</td>\n",
       "      <td>2</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>...</td>\n",
       "      <td>0.0</td>\n",
       "      <td>4</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>8</td>\n",
       "      <td>0.0</td>\n",
       "      <td>87.983</td>\n",
       "      <td>95.030</td>\n",
       "      <td>17.712</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>...</td>\n",
       "      <td>0.4</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>5</td>\n",
       "      <td>0.0</td>\n",
       "      <td>58.330</td>\n",
       "      <td>74.165</td>\n",
       "      <td>24.595</td>\n",
       "      <td>5</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>...</td>\n",
       "      <td>0.0</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>5</td>\n",
       "      <td>0.0</td>\n",
       "      <td>52.075</td>\n",
       "      <td>43.388</td>\n",
       "      <td>20.601</td>\n",
       "      <td>5</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>...</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>10</td>\n",
       "      <td>0.0</td>\n",
       "      <td>88.929</td>\n",
       "      <td>93.034</td>\n",
       "      <td>10.039</td>\n",
       "      <td>3</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>5 rows × 34 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "   location_boston  location_arizona  location_texas  location_nyc  \\\n",
       "0                1                 0               0             0   \n",
       "1                1                 0               0             0   \n",
       "2                1                 0               0             0   \n",
       "3                1                 0               0             0   \n",
       "4                1                 0               0             0   \n",
       "\n",
       "   room_theater  room_dig  room_office  room_home  room_apartment  \\\n",
       "0             0         0            1          0               0   \n",
       "1             0         0            1          0               0   \n",
       "2             0         0            0          0               0   \n",
       "3             0         0            0          0               0   \n",
       "4             0         0            1          0               0   \n",
       "\n",
       "   room_agency  ...  p_glass  race_NA  race_asian  race_black  race_white  \\\n",
       "0            0  ...      0.0        3           0           0           7   \n",
       "1            0  ...      0.0        4           0           0           8   \n",
       "2            0  ...      0.4        0           0           0           5   \n",
       "3            0  ...      0.0        2           0           0           5   \n",
       "4            0  ...      0.0        0           0           0          10   \n",
       "\n",
       "   race_entropy  smile_coef_mean  smile_coef_median  smile_coef_std  \\\n",
       "0           0.0           54.961             70.882          33.650   \n",
       "1           0.0           87.983             95.030          17.712   \n",
       "2           0.0           58.330             74.165          24.595   \n",
       "3           0.0           52.075             43.388          20.601   \n",
       "4           0.0           88.929             93.034          10.039   \n",
       "\n",
       "   confidence  \n",
       "0           2  \n",
       "1           1  \n",
       "2           5  \n",
       "3           5  \n",
       "4           3  \n",
       "\n",
       "[5 rows x 34 columns]"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "x_train.head()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Data Control Panel"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Hyperparameter Tuning"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "# number of rounds - (integer)\n",
    "T = 100\n",
    "\n",
    "# level sets - (integer)\n",
    "num_bins = 10\n",
    "\n",
    "# minimum number of points in level set for update to occur - (integer)\n",
    "min_group_size = 5\n",
    "\n",
    "# amount (multiplicative) level set must improve by to accept update if validation data or leniency factor for update requirements - (float)\n",
    "global_gamma = .01\n",
    "\n",
    "# weak learner class for UDT - (ML class with .predict method)\n",
    "weak_learner = DecisionTreeRegressor(max_depth=5)\n",
    "\n",
    "# determines width of level sets, either 'default' for equal width or 'distribution' for equal number of expected points - (string)\n",
    "bin_type = 'default'\n",
    "\n",
    "# multiplicative weight for new update - (float)\n",
    "learning_rate = 1\n",
    "\n",
    "# starting model to boost. Set to None for weak learner to be use as initial model - (fit ML class with .predict method or None)\n",
    "initial_model = None\n",
    "\n",
    "# round final predictions to level set center or use output of weak learner - (bool)\n",
    "final_round = False\n",
    "\n",
    "# center level sets using historical mean - (bool)\n",
    "center_mean = False"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Train LSBoost Regressor"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {
    "metadata": {}
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "LS:  35%|\u001b[32m███▌      \u001b[0m 35/100 00:24, Training Error=0.0091150"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Early Termination at round: 36\n",
      "Memory released!\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "LSBoostReg = LSBoost.LSBoostingRegressor(\n",
    "                                T = T, \n",
    "                                num_bins = num_bins, \n",
    "                                min_group_size = min_group_size, \n",
    "                                global_gamma = global_gamma, \n",
    "                                weak_learner= weak_learner, \n",
    "                                bin_type = bin_type, \n",
    "                                learning_rate = learning_rate, \n",
    "                                initial_model = initial_model,  \n",
    "                                final_round = final_round, \n",
    "                                center_mean=center_mean)\n",
    "LSBoostReg.fit(x_train.values, y_train.values)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Predict on train/test data and print MSE/MSCE on train/test"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {
    "metadata": {}
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Number of weak learner updates made: 378 \n",
      "\n",
      "Test Accuracy: 0.722115\n",
      "\n",
      "Test Correlation: 0.389033\n",
      "\n"
     ]
    }
   ],
   "source": [
    "print(f'Number of weak learner updates made: {LSBoostReg.updates} \\n')\n",
    "\n",
    "\n",
    "test_predictions = LSBoostReg.predict(x_test.values)\n",
    "print(f'Test Accuracy: {np.mean((y_test == (test_predictions >= .5))):.6f}\\n')\n",
    "test_cor = np.corrcoef(test_predictions, y_test)\n",
    "print(f'Test Correlation: {test_cor[0][1]:.6f}\\n')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {
    "metadata": {}
   },
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAkIAAAHHCAYAAABTMjf2AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjkuMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy80BEi2AAAACXBIWXMAAA9hAAAPYQGoP6dpAACKzElEQVR4nOzdd1xV9R/H8dflsgQBUURQUdx74t4rNc1cOXKbmiO11CxHOcqRmrPMVYqa/tymOUtzR1ruiSmSC1QcIMgQ7vf3x82LN0BBgQPcz/Px4NE533vOue97r3Q/fM/3nK9OKaUQQgghhLBAVloHEEIIIYTQihRCQgghhLBYUggJIYQQwmJJISSEEEIIiyWFkBBCCCEslhRCQgghhLBYUggJIYQQwmJJISSEEEIIiyWFkBBCCCEslhRCQqQSb29vevXqpXUMi9OgQQMaNGigdYyXmjBhAjqdjpCQEK2jZDg6nY4JEyakyrECAwPR6XT4+vqmyvFE1ieFkMgUfH190el0ph9ra2vy5ctHr169uHXrltbxMrSIiAi+/PJLypcvj4ODAy4uLtStW5cVK1aQWWbYuXDhAhMmTCAwMFDrKAnExcWxbNkyGjRoQM6cObGzs8Pb25vevXvz119/aR0vVaxevZo5c+ZoHcNMRswkMidrrQMIkRJffPEFhQoVIioqij/++ANfX18OHz7MuXPnsLe31zSbv78/VlYZ62+LO3fu0LhxYy5evEjnzp0ZPHgwUVFRbNy4kZ49e7Jjxw5WrVqFXq/XOuoLXbhwgYkTJ9KgQQO8vb3NHvvll1+0CQVERkbSrl07du3aRb169RgzZgw5c+YkMDCQdevWsXz5cq5fv07+/Pk1y5gaVq9ezblz5/joo4/S5PiRkZFYW6fs6yipTAULFiQyMhIbG5tUTCiyMimERKby5ptvUqVKFQD69u2Lm5sb06ZNY+vWrXTs2FHTbHZ2dun+nFFRUdja2iZZgPXs2ZOLFy+yefNm3n77bVP70KFDGTlyJF9//TWVKlXi008/Ta/IgLGXytHRMVWOZWtrmyrHeRUjR45k165dzJ49O8EX8vjx45k9e3a65lFKERUVRbZs2dL1eV+FwWAgJiYGe3v7VP0jRqfTaf5HkchklBCZwLJlyxSg/vzzT7P2bdu2KUBNmTLFrP3ixYuqffv2ytXVVdnZ2SkfHx+1ZcuWBMd9+PCh+uijj1TBggWVra2typcvn+revbu6d++eaZuoqCg1btw4VaRIEWVra6vy58+vRo4cqaKiosyOVbBgQdWzZ0+llFJ//vmnApSvr2+C59y1a5cC1M8//2xqu3nzpurdu7dyd3dXtra2qnTp0uqHH34w22/fvn0KUP/73//U2LFjVd68eZVOp1MPHz5M9D3z8/NTgHrvvfcSffzp06eqWLFiytXVVT158kQppdS1a9cUoGbMmKFmzZqlChQooOzt7VW9evXU2bNnExwjOe/zs89u//79auDAgSp37twqR44cSimlAgMD1cCBA1Xx4sWVvb29ypkzp3rnnXfUtWvXEuz/3599+/YppZSqX7++ql+/foL3ae3atWrSpEkqX758ys7OTjVq1Ej9/fffCV7Dt99+qwoVKqTs7e1V1apV1cGDBxMcMzE3btxQ1tbW6o033njhds+MHz9eAervv/9WPXv2VC4uLsrZ2Vn16tVLRUREmG27dOlS1bBhQ5U7d25la2urSpUqpb777rsExyxYsKBq2bKl2rVrl/Lx8VF2dnZq9uzZKTqGUkrt2LFD1atXT2XPnl05OTmpKlWqqFWrVimljO/vf9/7ggULmvZN7u8HoD744AP1448/qtKlSytra2u1efNm02Pjx483bRsWFqY+/PBD0+9l7ty5VZMmTdTx48dfmunZv+Fly5aZPf/FixdVhw4dlJubm7K3t1fFixdXY8aMedFHJiyE9AiJTO3ZmBFXV1dT2/nz56lduzb58uVj1KhRODo6sm7dOtq0acPGjRtp27YtAOHh4dStW5eLFy/y3nvvUblyZUJCQti6dSs3b97Ezc0Ng8HA22+/zeHDh3n//fcpVaoUZ8+eZfbs2Vy+fJmffvop0VxVqlShcOHCrFu3jp49e5o9tnbtWlxdXWnWrBlgPH1Vo0YNdDodgwcPJnfu3OzcuZM+ffoQFhaWoKfhyy+/xNbWlo8//pjo6Ogke0R+/vlnAHr06JHo49bW1nTp0oWJEydy5MgRmjRpYnpsxYoVPH78mA8++ICoqCjmzp1Lo0aNOHv2LHny5EnR+/zMoEGDyJ07N+PGjSMiIgKAP//8k99//53OnTuTP39+AgMDWbBgAQ0aNODChQs4ODhQr149hg4dyrx58xgzZgylSpUCMP03KV999RVWVlZ8/PHHhIaGMn36dLp2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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "from sklearn.metrics import roc_curve, auc\n",
    "\n",
    "fpr, tpr, thresholds = roc_curve(y_test, test_predictions)\n",
    "roc_auc = auc(fpr, tpr)\n",
    "\n",
    "plt.figure()\n",
    "plt.plot(fpr, tpr, color='darkorange', lw=2, label='ROC curve (area = %0.2f)' % roc_auc)\n",
    "plt.plot([0, 1], [0, 1], color='navy', lw=2, linestyle='--')\n",
    "plt.xlim([0.0, 1.0])\n",
    "plt.ylim([0.0, 1.05])\n",
    "plt.xlabel('False Positive Rate')\n",
    "plt.ylabel('True Positive Rate')\n",
    "plt.title('Receiver Operating Characteristic')\n",
    "plt.legend(loc=\"lower right\")\n",
    "plt.show()\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {
    "metadata": {}
   },
   "outputs": [],
   "source": [
    "bins = np.ceil(test_predictions * num_bins).astype(int)\n",
    "df = pd.DataFrame({'file_id': x_test_id, 'mc_pred': test_predictions, 'bin': bins})\n",
    "df.to_csv('./mc_predictions.csv', index=False)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {
    "metadata": {}
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([10,  0,  1])"
      ]
     },
     "execution_count": 14,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df['bin'].unique()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.12.3"
  },
  "vscode": {
   "interpreter": {
    "hash": "916dbcbb3f70747c44a77c7bcd40155683ae19c65e1c03b4aa3499c5328201f1"
   }
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
