{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 36,
   "id": "87e9682b",
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "from pathlib import Path\n",
    "from IPython.display import display\n",
    "\n",
    "sns.set()\n",
    "plt.rcParams['svg.fonttype'] = 'none'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "id": "742b95f5",
   "metadata": {},
   "outputs": [],
   "source": [
    "DATA_PATH = Path(\"../data/amex/\")\n",
    "FIGS_PATH = Path(\"figures/eda-amex//\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "id": "48771d2f",
   "metadata": {},
   "outputs": [],
   "source": [
    "# https://www.kaggle.com/competitions/amex-default-prediction/data\n",
    "CAT_FEATURES = ['B_30', 'B_38', 'D_114', 'D_116', 'D_117', 'D_120', 'D_126', 'D_63', 'D_64', 'D_66', 'D_68']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "32cfc99c",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "CPU times: user 3min 32s, sys: 4min 8s, total: 7min 40s\n",
      "Wall time: 7min 44s\n"
     ]
    },
    {
     "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>customer_ID</th>\n",
       "      <th>S_2</th>\n",
       "      <th>P_2</th>\n",
       "      <th>D_39</th>\n",
       "      <th>B_1</th>\n",
       "      <th>B_2</th>\n",
       "      <th>R_1</th>\n",
       "      <th>S_3</th>\n",
       "      <th>D_41</th>\n",
       "      <th>B_3</th>\n",
       "      <th>...</th>\n",
       "      <th>D_136</th>\n",
       "      <th>D_137</th>\n",
       "      <th>D_138</th>\n",
       "      <th>D_139</th>\n",
       "      <th>D_140</th>\n",
       "      <th>D_141</th>\n",
       "      <th>D_142</th>\n",
       "      <th>D_143</th>\n",
       "      <th>D_144</th>\n",
       "      <th>D_145</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0000099d6bd597052cdcda90ffabf56573fe9d7c79be5f...</td>\n",
       "      <td>2017-03-09</td>\n",
       "      <td>0.938469</td>\n",
       "      <td>0.001733</td>\n",
       "      <td>0.008724</td>\n",
       "      <td>1.006838</td>\n",
       "      <td>0.009228</td>\n",
       "      <td>0.124035</td>\n",
       "      <td>0.008771</td>\n",
       "      <td>0.004709</td>\n",
       "      <td>...</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.002427</td>\n",
       "      <td>0.003706</td>\n",
       "      <td>0.003818</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.000569</td>\n",
       "      <td>0.000610</td>\n",
       "      <td>0.002674</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>0000099d6bd597052cdcda90ffabf56573fe9d7c79be5f...</td>\n",
       "      <td>2017-04-07</td>\n",
       "      <td>0.936665</td>\n",
       "      <td>0.005775</td>\n",
       "      <td>0.004923</td>\n",
       "      <td>1.000653</td>\n",
       "      <td>0.006151</td>\n",
       "      <td>0.126750</td>\n",
       "      <td>0.000798</td>\n",
       "      <td>0.002714</td>\n",
       "      <td>...</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.003954</td>\n",
       "      <td>0.003167</td>\n",
       "      <td>0.005032</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.009576</td>\n",
       "      <td>0.005492</td>\n",
       "      <td>0.009217</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>0000099d6bd597052cdcda90ffabf56573fe9d7c79be5f...</td>\n",
       "      <td>2017-05-28</td>\n",
       "      <td>0.954180</td>\n",
       "      <td>0.091505</td>\n",
       "      <td>0.021655</td>\n",
       "      <td>1.009672</td>\n",
       "      <td>0.006815</td>\n",
       "      <td>0.123977</td>\n",
       "      <td>0.007598</td>\n",
       "      <td>0.009423</td>\n",
       "      <td>...</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.003269</td>\n",
       "      <td>0.007329</td>\n",
       "      <td>0.000427</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.003429</td>\n",
       "      <td>0.006986</td>\n",
       "      <td>0.002603</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>0000099d6bd597052cdcda90ffabf56573fe9d7c79be5f...</td>\n",
       "      <td>2017-06-13</td>\n",
       "      <td>0.960384</td>\n",
       "      <td>0.002455</td>\n",
       "      <td>0.013683</td>\n",
       "      <td>1.002700</td>\n",
       "      <td>0.001373</td>\n",
       "      <td>0.117169</td>\n",
       "      <td>0.000685</td>\n",
       "      <td>0.005531</td>\n",
       "      <td>...</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.006117</td>\n",
       "      <td>0.004516</td>\n",
       "      <td>0.003200</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.008419</td>\n",
       "      <td>0.006527</td>\n",
       "      <td>0.009600</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>0000099d6bd597052cdcda90ffabf56573fe9d7c79be5f...</td>\n",
       "      <td>2017-07-16</td>\n",
       "      <td>0.947248</td>\n",
       "      <td>0.002483</td>\n",
       "      <td>0.015193</td>\n",
       "      <td>1.000727</td>\n",
       "      <td>0.007605</td>\n",
       "      <td>0.117325</td>\n",
       "      <td>0.004653</td>\n",
       "      <td>0.009312</td>\n",
       "      <td>...</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.003671</td>\n",
       "      <td>0.004946</td>\n",
       "      <td>0.008889</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.001670</td>\n",
       "      <td>0.008126</td>\n",
       "      <td>0.009827</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5531446</th>\n",
       "      <td>fffff1d38b785cef84adeace64f8f83db3a0c31e8d92ea...</td>\n",
       "      <td>2017-11-05</td>\n",
       "      <td>0.979332</td>\n",
       "      <td>0.416013</td>\n",
       "      <td>0.020818</td>\n",
       "      <td>0.828199</td>\n",
       "      <td>0.003487</td>\n",
       "      <td>0.090743</td>\n",
       "      <td>0.005340</td>\n",
       "      <td>0.025139</td>\n",
       "      <td>...</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.006838</td>\n",
       "      <td>0.003680</td>\n",
       "      <td>0.000457</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.000905</td>\n",
       "      <td>0.001498</td>\n",
       "      <td>0.002774</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5531447</th>\n",
       "      <td>fffff1d38b785cef84adeace64f8f83db3a0c31e8d92ea...</td>\n",
       "      <td>2017-12-23</td>\n",
       "      <td>0.984907</td>\n",
       "      <td>0.296536</td>\n",
       "      <td>0.007209</td>\n",
       "      <td>0.812610</td>\n",
       "      <td>0.005904</td>\n",
       "      <td>0.079886</td>\n",
       "      <td>0.002243</td>\n",
       "      <td>0.023691</td>\n",
       "      <td>...</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.003310</td>\n",
       "      <td>0.007097</td>\n",
       "      <td>0.007857</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.002777</td>\n",
       "      <td>0.008225</td>\n",
       "      <td>0.008856</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5531448</th>\n",
       "      <td>fffff1d38b785cef84adeace64f8f83db3a0c31e8d92ea...</td>\n",
       "      <td>2018-01-06</td>\n",
       "      <td>0.983019</td>\n",
       "      <td>0.443984</td>\n",
       "      <td>0.013151</td>\n",
       "      <td>0.815422</td>\n",
       "      <td>0.003457</td>\n",
       "      <td>0.100503</td>\n",
       "      <td>0.002111</td>\n",
       "      <td>0.012343</td>\n",
       "      <td>...</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.009955</td>\n",
       "      <td>0.009994</td>\n",
       "      <td>0.001088</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.005693</td>\n",
       "      <td>0.006773</td>\n",
       "      <td>0.005566</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5531449</th>\n",
       "      <td>fffff1d38b785cef84adeace64f8f83db3a0c31e8d92ea...</td>\n",
       "      <td>2018-02-06</td>\n",
       "      <td>0.969861</td>\n",
       "      <td>0.442553</td>\n",
       "      <td>0.009855</td>\n",
       "      <td>1.003541</td>\n",
       "      <td>0.005117</td>\n",
       "      <td>0.101802</td>\n",
       "      <td>0.009930</td>\n",
       "      <td>0.008578</td>\n",
       "      <td>...</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.005541</td>\n",
       "      <td>0.006564</td>\n",
       "      <td>0.009883</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.008123</td>\n",
       "      <td>0.001168</td>\n",
       "      <td>0.003983</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5531450</th>\n",
       "      <td>fffff1d38b785cef84adeace64f8f83db3a0c31e8d92ea...</td>\n",
       "      <td>2018-03-14</td>\n",
       "      <td>0.982175</td>\n",
       "      <td>0.002474</td>\n",
       "      <td>0.000077</td>\n",
       "      <td>0.992880</td>\n",
       "      <td>0.000809</td>\n",
       "      <td>0.119165</td>\n",
       "      <td>0.003287</td>\n",
       "      <td>0.014092</td>\n",
       "      <td>...</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.007316</td>\n",
       "      <td>0.002888</td>\n",
       "      <td>0.006207</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.005110</td>\n",
       "      <td>0.003184</td>\n",
       "      <td>0.001914</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>5531451 rows × 190 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "                                               customer_ID        S_2  \\\n",
       "0        0000099d6bd597052cdcda90ffabf56573fe9d7c79be5f... 2017-03-09   \n",
       "1        0000099d6bd597052cdcda90ffabf56573fe9d7c79be5f... 2017-04-07   \n",
       "2        0000099d6bd597052cdcda90ffabf56573fe9d7c79be5f... 2017-05-28   \n",
       "3        0000099d6bd597052cdcda90ffabf56573fe9d7c79be5f... 2017-06-13   \n",
       "4        0000099d6bd597052cdcda90ffabf56573fe9d7c79be5f... 2017-07-16   \n",
       "...                                                    ...        ...   \n",
       "5531446  fffff1d38b785cef84adeace64f8f83db3a0c31e8d92ea... 2017-11-05   \n",
       "5531447  fffff1d38b785cef84adeace64f8f83db3a0c31e8d92ea... 2017-12-23   \n",
       "5531448  fffff1d38b785cef84adeace64f8f83db3a0c31e8d92ea... 2018-01-06   \n",
       "5531449  fffff1d38b785cef84adeace64f8f83db3a0c31e8d92ea... 2018-02-06   \n",
       "5531450  fffff1d38b785cef84adeace64f8f83db3a0c31e8d92ea... 2018-03-14   \n",
       "\n",
       "              P_2      D_39       B_1       B_2       R_1       S_3      D_41  \\\n",
       "0        0.938469  0.001733  0.008724  1.006838  0.009228  0.124035  0.008771   \n",
       "1        0.936665  0.005775  0.004923  1.000653  0.006151  0.126750  0.000798   \n",
       "2        0.954180  0.091505  0.021655  1.009672  0.006815  0.123977  0.007598   \n",
       "3        0.960384  0.002455  0.013683  1.002700  0.001373  0.117169  0.000685   \n",
       "4        0.947248  0.002483  0.015193  1.000727  0.007605  0.117325  0.004653   \n",
       "...           ...       ...       ...       ...       ...       ...       ...   \n",
       "5531446  0.979332  0.416013  0.020818  0.828199  0.003487  0.090743  0.005340   \n",
       "5531447  0.984907  0.296536  0.007209  0.812610  0.005904  0.079886  0.002243   \n",
       "5531448  0.983019  0.443984  0.013151  0.815422  0.003457  0.100503  0.002111   \n",
       "5531449  0.969861  0.442553  0.009855  1.003541  0.005117  0.101802  0.009930   \n",
       "5531450  0.982175  0.002474  0.000077  0.992880  0.000809  0.119165  0.003287   \n",
       "\n",
       "              B_3  ...  D_136  D_137  D_138     D_139     D_140     D_141  \\\n",
       "0        0.004709  ...    NaN    NaN    NaN  0.002427  0.003706  0.003818   \n",
       "1        0.002714  ...    NaN    NaN    NaN  0.003954  0.003167  0.005032   \n",
       "2        0.009423  ...    NaN    NaN    NaN  0.003269  0.007329  0.000427   \n",
       "3        0.005531  ...    NaN    NaN    NaN  0.006117  0.004516  0.003200   \n",
       "4        0.009312  ...    NaN    NaN    NaN  0.003671  0.004946  0.008889   \n",
       "...           ...  ...    ...    ...    ...       ...       ...       ...   \n",
       "5531446  0.025139  ...    NaN    NaN    NaN  0.006838  0.003680  0.000457   \n",
       "5531447  0.023691  ...    NaN    NaN    NaN  0.003310  0.007097  0.007857   \n",
       "5531448  0.012343  ...    NaN    NaN    NaN  0.009955  0.009994  0.001088   \n",
       "5531449  0.008578  ...    NaN    NaN    NaN  0.005541  0.006564  0.009883   \n",
       "5531450  0.014092  ...    NaN    NaN    NaN  0.007316  0.002888  0.006207   \n",
       "\n",
       "         D_142     D_143     D_144     D_145  \n",
       "0          NaN  0.000569  0.000610  0.002674  \n",
       "1          NaN  0.009576  0.005492  0.009217  \n",
       "2          NaN  0.003429  0.006986  0.002603  \n",
       "3          NaN  0.008419  0.006527  0.009600  \n",
       "4          NaN  0.001670  0.008126  0.009827  \n",
       "...        ...       ...       ...       ...  \n",
       "5531446    NaN  0.000905  0.001498  0.002774  \n",
       "5531447    NaN  0.002777  0.008225  0.008856  \n",
       "5531448    NaN  0.005693  0.006773  0.005566  \n",
       "5531449    NaN  0.008123  0.001168  0.003983  \n",
       "5531450    NaN  0.005110  0.003184  0.001914  \n",
       "\n",
       "[5531451 rows x 190 columns]"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "%%time\n",
    "\n",
    "df_train = pd.read_csv(DATA_PATH / \"train_data.csv\", header=0, parse_dates=[\"S_2\"])\n",
    "df_train"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "138c5668",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "D_87           0.000699\n",
       "D_88           0.001085\n",
       "D_108          0.005232\n",
       "D_111          0.005665\n",
       "D_110          0.005665\n",
       "B_39           0.006080\n",
       "D_73           0.010098\n",
       "B_42           0.012922\n",
       "D_138          0.035199\n",
       "D_136          0.035199\n",
       "D_134          0.035199\n",
       "D_137          0.035199\n",
       "D_135          0.035199\n",
       "R_9            0.056501\n",
       "B_29           0.068954\n",
       "D_106          0.097867\n",
       "D_132          0.098089\n",
       "D_49           0.098624\n",
       "R_26           0.110153\n",
       "D_76           0.112538\n",
       "D_66           0.112693\n",
       "D_42           0.143057\n",
       "D_142          0.170734\n",
       "D_53           0.261571\n",
       "D_82           0.266266\n",
       "D_50           0.431903\n",
       "B_17           0.432771\n",
       "D_105          0.453772\n",
       "D_56           0.459284\n",
       "S_9            0.469643\n",
       "D_77           0.545524\n",
       "D_43           0.700188\n",
       "S_27           0.746733\n",
       "D_46           0.780944\n",
       "S_3            0.815502\n",
       "S_7            0.815502\n",
       "D_62           0.862936\n",
       "D_48           0.870066\n",
       "D_61           0.891882\n",
       "P_3            0.945495\n",
       "D_78           0.950407\n",
       "D_44           0.950407\n",
       "D_64           0.960690\n",
       "D_68           0.960860\n",
       "D_69           0.964842\n",
       "D_83           0.964842\n",
       "D_55           0.966591\n",
       "D_125          0.968053\n",
       "D_119          0.968053\n",
       "D_124          0.968053\n",
       "D_123          0.968053\n",
       "D_122          0.968053\n",
       "D_121          0.968053\n",
       "D_120          0.968053\n",
       "D_118          0.968053\n",
       "D_117          0.968053\n",
       "D_116          0.968053\n",
       "D_115          0.968053\n",
       "D_113          0.968053\n",
       "D_114          0.968053\n",
       "D_91           0.971578\n",
       "R_27           0.976733\n",
       "D_126          0.978881\n",
       "D_59           0.980706\n",
       "D_107          0.981642\n",
       "D_130          0.981642\n",
       "D_143          0.981642\n",
       "D_139          0.981642\n",
       "D_128          0.981642\n",
       "D_131          0.981642\n",
       "D_103          0.981642\n",
       "D_104          0.981642\n",
       "D_141          0.981642\n",
       "D_129          0.981642\n",
       "D_145          0.981642\n",
       "D_70           0.982840\n",
       "D_79           0.986271\n",
       "B_13           0.991048\n",
       "P_2            0.991687\n",
       "D_133          0.992278\n",
       "D_144          0.992637\n",
       "D_102          0.992650\n",
       "D_140          0.992654\n",
       "D_84           0.994655\n",
       "D_52           0.994655\n",
       "D_89           0.994655\n",
       "D_81           0.995356\n",
       "D_72           0.995714\n",
       "B_8            0.995974\n",
       "D_80           0.996064\n",
       "D_74           0.996064\n",
       "S_22           0.996561\n",
       "S_24           0.996639\n",
       "S_25           0.997677\n",
       "B_15           0.998748\n",
       "B_25           0.998748\n",
       "D_112          0.999521\n",
       "D_45           0.999635\n",
       "B_3            0.999636\n",
       "B_16           0.999636\n",
       "B_19           0.999636\n",
       "B_20           0.999636\n",
       "D_54           0.999636\n",
       "B_27           0.999636\n",
       "B_33           0.999636\n",
       "B_2            0.999636\n",
       "B_38           0.999636\n",
       "B_26           0.999636\n",
       "B_30           0.999636\n",
       "D_41           0.999636\n",
       "B_22           0.999636\n",
       "D_109          0.999711\n",
       "B_41           0.999875\n",
       "S_26           0.999885\n",
       "S_23           0.999920\n",
       "B_6            0.999958\n",
       "R_20           0.999986\n",
       "B_37           0.999990\n",
       "R_12           0.999990\n",
       "B_40           0.999990\n",
       "R_14           1.000000\n",
       "R_7            1.000000\n",
       "S_2            1.000000\n",
       "D_39           1.000000\n",
       "D_58           1.000000\n",
       "B_14           1.000000\n",
       "D_60           1.000000\n",
       "R_28           1.000000\n",
       "B_4            1.000000\n",
       "S_8            1.000000\n",
       "D_47           1.000000\n",
       "R_2            1.000000\n",
       "D_127          1.000000\n",
       "D_51           1.000000\n",
       "B_9            1.000000\n",
       "R_3            1.000000\n",
       "B_1            1.000000\n",
       "R_5            1.000000\n",
       "B_10           1.000000\n",
       "R_1            1.000000\n",
       "S_5            1.000000\n",
       "B_11           1.000000\n",
       "S_6            1.000000\n",
       "R_4            1.000000\n",
       "B_12           1.000000\n",
       "B_5            1.000000\n",
       "B_7            1.000000\n",
       "P_4            1.000000\n",
       "D_63           1.000000\n",
       "S_13           1.000000\n",
       "D_86           1.000000\n",
       "S_18           1.000000\n",
       "B_21           1.000000\n",
       "R_16           1.000000\n",
       "R_15           1.000000\n",
       "R_13           1.000000\n",
       "B_28           1.000000\n",
       "S_17           1.000000\n",
       "R_11           1.000000\n",
       "R_10           1.000000\n",
       "S_16           1.000000\n",
       "R_8            1.000000\n",
       "D_71           1.000000\n",
       "B_24           1.000000\n",
       "S_15           1.000000\n",
       "D_75           1.000000\n",
       "R_17           1.000000\n",
       "R_18           1.000000\n",
       "R_6            1.000000\n",
       "B_31           1.000000\n",
       "B_36           1.000000\n",
       "D_65           1.000000\n",
       "B_18           1.000000\n",
       "B_23           1.000000\n",
       "D_96           1.000000\n",
       "R_25           1.000000\n",
       "R_24           1.000000\n",
       "D_94           1.000000\n",
       "S_11           1.000000\n",
       "D_93           1.000000\n",
       "S_12           1.000000\n",
       "R_23           1.000000\n",
       "R_22           1.000000\n",
       "R_21           1.000000\n",
       "S_20           1.000000\n",
       "B_32           1.000000\n",
       "R_19           1.000000\n",
       "S_19           1.000000\n",
       "D_92           1.000000\n",
       "customer_ID    1.000000\n",
       "dtype: float64"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "with pd.option_context(\"display.max_rows\", None):\n",
    "    display(df_train.count().div(len(df_train)).sort_values())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "id": "bbd4ad7c",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "customer_ID            object\n",
       "S_2            datetime64[ns]\n",
       "P_2                   float64\n",
       "D_39                  float64\n",
       "B_1                   float64\n",
       "B_2                   float64\n",
       "R_1                   float64\n",
       "S_3                   float64\n",
       "D_41                  float64\n",
       "B_3                   float64\n",
       "D_42                  float64\n",
       "D_43                  float64\n",
       "D_44                  float64\n",
       "B_4                   float64\n",
       "D_45                  float64\n",
       "B_5                   float64\n",
       "R_2                   float64\n",
       "D_46                  float64\n",
       "D_47                  float64\n",
       "D_48                  float64\n",
       "D_49                  float64\n",
       "B_6                   float64\n",
       "B_7                   float64\n",
       "B_8                   float64\n",
       "D_50                  float64\n",
       "D_51                  float64\n",
       "B_9                   float64\n",
       "R_3                   float64\n",
       "D_52                  float64\n",
       "P_3                   float64\n",
       "B_10                  float64\n",
       "D_53                  float64\n",
       "S_5                   float64\n",
       "B_11                  float64\n",
       "S_6                   float64\n",
       "D_54                  float64\n",
       "R_4                   float64\n",
       "S_7                   float64\n",
       "B_12                  float64\n",
       "S_8                   float64\n",
       "D_55                  float64\n",
       "D_56                  float64\n",
       "B_13                  float64\n",
       "R_5                   float64\n",
       "D_58                  float64\n",
       "S_9                   float64\n",
       "B_14                  float64\n",
       "D_59                  float64\n",
       "D_60                  float64\n",
       "D_61                  float64\n",
       "B_15                  float64\n",
       "S_11                  float64\n",
       "D_62                  float64\n",
       "D_63                   object\n",
       "D_64                   object\n",
       "D_65                  float64\n",
       "B_16                  float64\n",
       "B_17                  float64\n",
       "B_18                  float64\n",
       "B_19                  float64\n",
       "D_66                  float64\n",
       "B_20                  float64\n",
       "D_68                  float64\n",
       "S_12                  float64\n",
       "R_6                   float64\n",
       "S_13                  float64\n",
       "B_21                  float64\n",
       "D_69                  float64\n",
       "B_22                  float64\n",
       "D_70                  float64\n",
       "D_71                  float64\n",
       "D_72                  float64\n",
       "S_15                  float64\n",
       "B_23                  float64\n",
       "D_73                  float64\n",
       "P_4                   float64\n",
       "D_74                  float64\n",
       "D_75                  float64\n",
       "D_76                  float64\n",
       "B_24                  float64\n",
       "R_7                   float64\n",
       "D_77                  float64\n",
       "B_25                  float64\n",
       "B_26                  float64\n",
       "D_78                  float64\n",
       "D_79                  float64\n",
       "R_8                   float64\n",
       "R_9                   float64\n",
       "S_16                  float64\n",
       "D_80                  float64\n",
       "R_10                  float64\n",
       "R_11                  float64\n",
       "B_27                  float64\n",
       "D_81                  float64\n",
       "D_82                  float64\n",
       "S_17                  float64\n",
       "R_12                  float64\n",
       "B_28                  float64\n",
       "R_13                  float64\n",
       "D_83                  float64\n",
       "R_14                  float64\n",
       "R_15                  float64\n",
       "D_84                  float64\n",
       "R_16                  float64\n",
       "B_29                  float64\n",
       "B_30                  float64\n",
       "S_18                  float64\n",
       "D_86                  float64\n",
       "D_87                  float64\n",
       "R_17                  float64\n",
       "R_18                  float64\n",
       "D_88                  float64\n",
       "B_31                    int64\n",
       "S_19                  float64\n",
       "R_19                  float64\n",
       "B_32                  float64\n",
       "S_20                  float64\n",
       "R_20                  float64\n",
       "R_21                  float64\n",
       "B_33                  float64\n",
       "D_89                  float64\n",
       "R_22                  float64\n",
       "R_23                  float64\n",
       "D_91                  float64\n",
       "D_92                  float64\n",
       "D_93                  float64\n",
       "D_94                  float64\n",
       "R_24                  float64\n",
       "R_25                  float64\n",
       "D_96                  float64\n",
       "S_22                  float64\n",
       "S_23                  float64\n",
       "S_24                  float64\n",
       "S_25                  float64\n",
       "S_26                  float64\n",
       "D_102                 float64\n",
       "D_103                 float64\n",
       "D_104                 float64\n",
       "D_105                 float64\n",
       "D_106                 float64\n",
       "D_107                 float64\n",
       "B_36                  float64\n",
       "B_37                  float64\n",
       "R_26                  float64\n",
       "R_27                  float64\n",
       "B_38                  float64\n",
       "D_108                 float64\n",
       "D_109                 float64\n",
       "D_110                 float64\n",
       "D_111                 float64\n",
       "B_39                  float64\n",
       "D_112                 float64\n",
       "B_40                  float64\n",
       "S_27                  float64\n",
       "D_113                 float64\n",
       "D_114                 float64\n",
       "D_115                 float64\n",
       "D_116                 float64\n",
       "D_117                 float64\n",
       "D_118                 float64\n",
       "D_119                 float64\n",
       "D_120                 float64\n",
       "D_121                 float64\n",
       "D_122                 float64\n",
       "D_123                 float64\n",
       "D_124                 float64\n",
       "D_125                 float64\n",
       "D_126                 float64\n",
       "D_127                 float64\n",
       "D_128                 float64\n",
       "D_129                 float64\n",
       "B_41                  float64\n",
       "B_42                  float64\n",
       "D_130                 float64\n",
       "D_131                 float64\n",
       "D_132                 float64\n",
       "D_133                 float64\n",
       "R_28                  float64\n",
       "D_134                 float64\n",
       "D_135                 float64\n",
       "D_136                 float64\n",
       "D_137                 float64\n",
       "D_138                 float64\n",
       "D_139                 float64\n",
       "D_140                 float64\n",
       "D_141                 float64\n",
       "D_142                 float64\n",
       "D_143                 float64\n",
       "D_144                 float64\n",
       "D_145                 float64\n",
       "dtype: object"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "with pd.option_context(\"display.max_rows\", None):\n",
    "    display(df_train.dtypes)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "bbf06e0f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "customer_ID\n",
       "0000099d6bd597052cdcda90ffabf56573fe9d7c79be5fbac11a8ed792feb62a    13\n",
       "00000fd6641609c6ece5454664794f0340ad84dddce9a267a310b5ae68e9d8e5    13\n",
       "00001b22f846c82c51f6e3958ccd81970162bae8b007e80662ef27519fcc18c1    13\n",
       "000041bdba6ecadd89a52d11886e8eaaec9325906c9723355abb5ca523658edc    13\n",
       "00007889e4fcd2614b6cbe7f8f3d2e5c728eca32d9eb8ad51ca8b8c4a24cefed    13\n",
       "                                                                    ..\n",
       "ffff41c8a52833b56430603969b9ca48d208e7c192c6a4081a6acc28cf4f8af7    13\n",
       "ffff518bb2075e4816ee3fe9f3b152c57fc0e6f01bf7fdd3e5b57cfcbee30286    13\n",
       "ffff9984b999fccb2b6127635ed0736dda94e544e67e026eee4d20f680639ff6    13\n",
       "ffffa5c46bc8de74f5a4554e74e239c8dee6b9baf388145b2c3d01967fcce461    13\n",
       "fffff1d38b785cef84adeace64f8f83db3a0c31e8d92eaba8b115f71cab04681    13\n",
       "Length: 458913, dtype: int64"
      ]
     },
     "execution_count": 15,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "lens = df_train.groupby(\"customer_ID\").size()\n",
    "lens"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "4105a1fe",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "1       5120\n",
       "2       6098\n",
       "3       5778\n",
       "4       4673\n",
       "5       4671\n",
       "6       5515\n",
       "7       5198\n",
       "8       6110\n",
       "9       6411\n",
       "10      6721\n",
       "11      5961\n",
       "12     10623\n",
       "13    386034\n",
       "Name: count, dtype: int64"
      ]
     },
     "execution_count": 17,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "lens.value_counts().sort_index()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "a19c1996",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "B_30     3\n",
       "B_38     7\n",
       "D_114    2\n",
       "D_116    2\n",
       "D_117    7\n",
       "D_120    2\n",
       "D_126    3\n",
       "D_63     6\n",
       "D_64     4\n",
       "D_66     2\n",
       "D_68     7\n",
       "dtype: int64"
      ]
     },
     "execution_count": 18,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_train[CAT_FEATURES].nunique()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "7ba2b001",
   "metadata": {},
   "outputs": [],
   "source": [
    "last_dt = (\n",
    "    df_train\n",
    "    .groupby(\"customer_ID\")\n",
    "    [\"S_2\"]\n",
    "    .max()\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "id": "569e4341",
   "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>S_2</th>\n",
       "      <th>weights</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>customer_ID</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0000099d6bd597052cdcda90ffabf56573fe9d7c79be5fbac11a8ed792feb62a</th>\n",
       "      <td>2017-03-09</td>\n",
       "      <td>1.676202e-07</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0000099d6bd597052cdcda90ffabf56573fe9d7c79be5fbac11a8ed792feb62a</th>\n",
       "      <td>2017-04-07</td>\n",
       "      <td>1.676202e-07</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0000099d6bd597052cdcda90ffabf56573fe9d7c79be5fbac11a8ed792feb62a</th>\n",
       "      <td>2017-05-28</td>\n",
       "      <td>1.676202e-07</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0000099d6bd597052cdcda90ffabf56573fe9d7c79be5fbac11a8ed792feb62a</th>\n",
       "      <td>2017-06-13</td>\n",
       "      <td>1.676202e-07</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0000099d6bd597052cdcda90ffabf56573fe9d7c79be5fbac11a8ed792feb62a</th>\n",
       "      <td>2017-07-16</td>\n",
       "      <td>1.676202e-07</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>fffff1d38b785cef84adeace64f8f83db3a0c31e8d92eaba8b115f71cab04681</th>\n",
       "      <td>2017-11-05</td>\n",
       "      <td>1.676202e-07</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>fffff1d38b785cef84adeace64f8f83db3a0c31e8d92eaba8b115f71cab04681</th>\n",
       "      <td>2017-12-23</td>\n",
       "      <td>1.676202e-07</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>fffff1d38b785cef84adeace64f8f83db3a0c31e8d92eaba8b115f71cab04681</th>\n",
       "      <td>2018-01-06</td>\n",
       "      <td>1.676202e-07</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>fffff1d38b785cef84adeace64f8f83db3a0c31e8d92eaba8b115f71cab04681</th>\n",
       "      <td>2018-02-06</td>\n",
       "      <td>1.676202e-07</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>fffff1d38b785cef84adeace64f8f83db3a0c31e8d92eaba8b115f71cab04681</th>\n",
       "      <td>2018-03-14</td>\n",
       "      <td>1.676202e-07</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>5531451 rows × 2 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "                                                          S_2       weights\n",
       "customer_ID                                                                \n",
       "0000099d6bd597052cdcda90ffabf56573fe9d7c79be5fb... 2017-03-09  1.676202e-07\n",
       "0000099d6bd597052cdcda90ffabf56573fe9d7c79be5fb... 2017-04-07  1.676202e-07\n",
       "0000099d6bd597052cdcda90ffabf56573fe9d7c79be5fb... 2017-05-28  1.676202e-07\n",
       "0000099d6bd597052cdcda90ffabf56573fe9d7c79be5fb... 2017-06-13  1.676202e-07\n",
       "0000099d6bd597052cdcda90ffabf56573fe9d7c79be5fb... 2017-07-16  1.676202e-07\n",
       "...                                                       ...           ...\n",
       "fffff1d38b785cef84adeace64f8f83db3a0c31e8d92eab... 2017-11-05  1.676202e-07\n",
       "fffff1d38b785cef84adeace64f8f83db3a0c31e8d92eab... 2017-12-23  1.676202e-07\n",
       "fffff1d38b785cef84adeace64f8f83db3a0c31e8d92eab... 2018-01-06  1.676202e-07\n",
       "fffff1d38b785cef84adeace64f8f83db3a0c31e8d92eab... 2018-02-06  1.676202e-07\n",
       "fffff1d38b785cef84adeace64f8f83db3a0c31e8d92eab... 2018-03-14  1.676202e-07\n",
       "\n",
       "[5531451 rows x 2 columns]"
      ]
     },
     "execution_count": 27,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "dts = (\n",
    "    df_train\n",
    "    [[\"customer_ID\", \"S_2\"]]\n",
    "    .set_index(\"customer_ID\")\n",
    "    .pipe(lambda df: df.join(df.groupby(level=0).size().rename(\"weights\")))\n",
    "    .assign(weights=lambda df: 1 / df.weights / df.index.nunique())\n",
    ")\n",
    "dts"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "id": "88f55a6c",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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rApw+fn5CAgIqHB+8eFUIiIiIrI9qwJccHAwfv755wrnf/311+jYsaPVRRERERFRxawKcJGRkdi7dy/Wr1+P7OxsAIAQApcuXcLcuXNx8uRJTJ061ZZ1EhEREdEdVl3EMGrUKFy/fh0rV67E+++/DwB4+umnIYSASqVCTEwMhgwZYss6iYiIiOgOqwIcAPzzn//EqFGjsH//fly6dAmyLKNVq1YYNmwYWrZsacsaiYiIiKgEqwMcADRr1oyHSomIiIhqWLUCHADIsoysrCwIIcrM8/f3r+7miYiIiKgUqwJcYWEhNmzYgM8//xw3b96ELMvlLvf7779XqzgiIiIiKsuqALdgwQLs2rULXbt2xZAhQ1C/fn1b10VEREREFbAqwCUlJWHUqFFYunSpreshIiIiqpJarSrxc9mnQtV2VgU4b29vdO3a1da1EBEREVVJrVbBcGIXDNo0AIBns+ByH+1pMUm6EwZVd97HeYOhVQHu4YcfxrfffosJEybYuh4iIiKiKhm0aSjM/AsA4KZpaJNtutUPgP7YThTaOhjagVUBbu7cuZg/fz6io6MxduxYNGnSBGq1usxynTp1qnaBRERERDXFoEu3eTC0B6sCnF6vhxACycnJSE5OLjNfCAFJkngVKhEREZEdWBXg5s+fj6+//hoPPfQQunbtyqtQiYiIiGqQVQHuyJEjmDRpEubPn2/reoiIiIioCqqqFynL19cXd999t61rISIiIiIFrApwTzzxBPbs2QOj0WjreoiIiIioClYdQg0ODsbBgwcxZswYjBkzpsKrUIcNG1btAomIiIjInFUBLiYmxvTz22+/Xe4yvAqViIiIyD6sCnCbN2+2dR1EREREpJBVAS4sLMzWdRARERGRQlYFuJLOnTuHa9euAQCaN2+Otm3bVrsoIiIiIqqY1QHu66+/xtKlS03hrViLFi0wb948DB48uNrFEREREVFZVgW4w4cPY9asWWjWrBliYmIQHBwMADh//jy2bduGmTNnYu3atQgPD7dpsURERERkZYD78MMPERISgi1btqBevXqm6YMHD8akSZMwceJEfPDBBwxwRERERHZg1Y18//jjD4wePdosvBWrV68exowZgz/++KPaxRERERFRWVYFOE9PT2i12grna7VaeHp6WlXQ+fPn8dRTT6Fbt27o27cvli1bBr1eX+V6QgisX78e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tm3bahdFRERERBWzOsB9/fXXWLp0qSm8FWvRogXmzZuHwYMHV7s4IiIiIirLqgB3+PBhzJo1C82aNUNMTAyCg4MBAOfPn8e2bdswc+ZMrF27FuHh4TYtloiIiIisDHAffvghQkJCsGXLFtSrV880ffDgwZg0aRImTpyIDz74gAGOiIiIyA6supHvH3/8gdGjR5uFt2L16tXDmDFj8Mcff1S7OCIiIiIqy6oA5+npCa1WW+F8rVYLT09Pq4siIiIioopZFeB69eqFzZs348SJE2XmnTp1CgkJCejdu3e1iyMiIiKisqw6B27u3LmIiIjAxIkTERoaijZt2gAALly4gNOnT6Nhw4Z48cUXbVooERERERWxagSuZcuW+OKLLzB58mRotVrs3bsXe/fuhVarxZQpU7B79260aNHC1rUSEREREapxH7iGDRti/vz5mD9/vi3rISIiIqIqWDUCR0RERESOo2gE7pVXXoEkSVi8eDHUajVeeeWVKteRJAn/+te/ql0gEREREZlTFOB+/PFHSJIEWZahVqvx448/VrmOJEnVLo6IiIiIylIU4A4dOlTpayIiIiKqOVadA3f9+nXk5+dXOD8/Px/Xr1+3uigiIiIiqphVAW7w4ME4cOBAhfMPHTqEwYMHW10UEREREVXMqgAnhKh0fmFhIVQqXuBKREREZA+K7wOXnZ0NnU5nep2ZmVnuYVKdToe9e/ciMDDQNhUSERERkRnFAW7jxo344IMPAPx9i5CKbhMihMDzzz9vkwKJiIiIyJziANe3b1/Uq1cPQgi88847ePjhh9GpUyezZSRJgre3Nzp16oQuXbrYvFgiIiIisiDAde/eHd27dwcA5OXlYejQoQgJCbFbYURERERUPquehTpjxgxb10FERERECll1qeiKFSswatSoCuePHj0aq1evtrooIiIiIqqYVQHuq6++Qnh4eIXzBwwYgL1791pdFBERERFVzKoAd+PGDbRq1arC+S1atOCTGIiIiIjsxKoAV69ePVy7dq3C+VevXoWnp6fVRRERERFRxawKcGFhYdi6dStSU1PLzLtx4wa2bt2KXr16Vbs4IiIiIirLqqtQZ8+ejccffxwPP/wwxo0bh7Zt2wIA/vzzT3z++ecQQmD27Nk2LZSIiIiIilgV4IKCgrBlyxYsWbIEGzduNJt333334dVXX0VwcLAt6iMi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rVu3IiwsDOfOncOHH36IDz74AA0aNHB0WU5n/fr1uP/++/Hbb7/h008/xdtvv43U1FQUPx2PT8kzd/36dURGRuL06dMYM2YM2rVrh8TERMycORO3bt1ieCvh9OnTmDJlCuLj4/H//t//w6+//goADCTlYK+qxu8/++AIXA34888/sWnTJowYMQJTpkxBkyZNoFKp0KZNG2zYsAEXL15E586dHV2mU/jhhx/wf//3f+jcuTPi4uLg6+vr6JKc0vr167F8+XK8/vrreOSRR6DRaPDrr79CrVbjp59+Qtu2bR1dotP57bffkJKSgjVr1qB79+6QJAm9e/fGm2++iXnz5mHVqlXw8fFxdJkOl5GRgU8++QS3b9/G66+/jnfffRe7du1Cu3btEBAQwJGlEtirqvH7z34Y4OyoeFj4nnvuweDBgzF06FA0a9YMhYWFUKlUCAwMRH5+Ppo1a2Zap67+whcfvrr//vvxyCOP4MyZMzhz5gx69eqFK1euIDk5GY0aNUK7du3QqlUrqNXqOtmr4s/UxIkTMWrUKDRu3Ng0r379+vDx8cHly5d5OPCOkp+RX375BXfddRfatWtnmta/f3+MHDkSGzduxBdffIHHH38cbm5165/F0r9HAQEBaNasGR588EEMGjQIsizj7bffRnh4OB566KE69ztXnuLfQ/aqYvz+sz9J8DiLzZ04cQJBQUGoV68e3N3dy10mNzcXc+bMgdFoRO/evREaGop77723hit1vPJ6derUKbz22msICgpCYGAgEhMTERAQgL/++gsBAQF4/PHHERMT4+DKa1Zxn7y9veHh4VHmnJHif/giIiLg7++PtWvX1ukQV97nasuWLVi2bBn279+Pxo0bm3q2Z88evPjii7jnnnvw0UcfmYXiukQIASFEuYezir98Fy9ejFatWtXZL1ol/7bX9V7x+6/m8MCzDe3atQv9+vXDSy+9hDFjxmDhwoUwGAym+cW3dvjxxx/Ro0cPnD9/Hv7+/khISMAzzzyDzZs3A6gb5y6V16vCwkIAQNeuXREeHo4jR47g+PHjePfddxEfH4+vv/4a9913HzZv3ow9e/YAQK2/uKF0nxYtWgSDwWD6ki3+rEiSBFmWERoailOnTiE3N7dOhrfKfgf79OkDHx8fxMfHA/j7HKX8/HyEhITgypUr+PLLLwHUjduwfPnllxg4cCA2btwIAGXCmxDC9Dv5+uuv48cff8Thw4dhMBggSVKd+HeqWFX/tsuyXOd7xe8/BxBkEydOnBD9+vUTa9asEceOHRNr1qwR9957r5g+fbo4f/68EEIIWZaFEEKcPn1abN26VaSlpQkhhEhPTxdvvPGG6N69u8jJyXHYPtSUynr1559/CiGEuH79upg3b544evSoqW9CCHHu3Dkxbdo0MXr0aEeVX2Ms+UwVW7NmjQgLCxMnTpxwQMWOVVG/nnvuOXH58mUhhBDr1q0TISEhYvny5eLXX38Vhw8fFn369BHvvvuueOONN8TEiRMdvBf2l5WVJVasWCHCwsJEt27dxKhRo0R6eroQQgij0Vjhek899ZQYPny4OH36dE2V6hSs+T2sa73i959jMMDZyJtvvilGjhwpMjMzTdN++OEH0a1bN7FkyRKh0+kqXf/o0aOia9eu4sCBA/Yu1eGq6tXt27eFEELcvHnTbL3ifwCWLl0qHnjgAXHlypUaq9kRlH6mZFk2ffGeOXNGhISEiKNHjwohKv9Crm0q69fixYtFVlaWEEKIJUuWiL59+4ouXbqITp06icWLFwshhIiNjRXPPvusMBgMtbpvZ8+eFQMHDhRz5swR69atE4MHDxZvvfWWEKJsEBFCCIPBIIQQ4vLlyyIkJEQsW7ZM5OfnCyGEqae1uV+W/B7W1V7x+88xeAi1msSd4d68vDx4enrCz88PAGAwGNCrVy9MmDAB3377Lb766qty1yt2+fJlGAwGNGnSpGYKdwClvfr6668BwHQuUvHQe/Ehr7y8POTm5qJ+/fo1vQs1wtLPlCRJpkNfXl5eaNy4MZKTkwGgTlyer7Rf+/btAwC8+uqr+Pzzz/Hee+/hm2++wWuvvQYAuHnzpunQc23uW4MGDTB37ly89957ePbZZ3Hfffdh//79OHPmDCRJKnP4WK1Ww2AwoGXLlpgyZQq2b9+O5ORkHD58GPPnz0daWlqt7Jc1v4d1rVf8/nOs2vNJcpDiUBEQEID8/HycPXsWwN8f0H/+85+oX78+Dh48iBs3bgAoOl+ieD1ZlvH777/j4MGDGDt2LDp16uSAvagZlvTq5s2bAGB2Ir4syzh58iS+//57TJgwwfSPRW1j7WcKABo1agSNRoO//voLBQUFDqi+5inpl0ajwaFDh3D9+nUARf9xMHToUAQGBsJoNOLYsWM4fvw4JkyY4JidqEF33XUXHnroIdPrhx9+GL6+vli3bh2A8p/iUXxl7qxZsyCEwIIFCxAdHW0KJKW/kGsDa34PhRB1qlf8/nMsBjiFKjpZvviDGhoairS0NPzyyy8AAHd3dxgMBtSvXx/jxo3DiRMn8PvvvwMoGhW5efMmvvzyS2zcuBHPPfccdDodJk6cWCuuVrJFr3777TcARV8mqampSEpKwqZNmzBz5kw0aNAAo0aNqpmdsSNbf6ZkWYZGo0GLFi1w4sQJeHp61syO1BBb9Kv4CwYAsrOz8d133yE+Ph4vvPACmjVrVmuuhFNycU/xMv369cOAAQNw8uRJ7N+/H0D5F3FcuHABn376KbKzsxEYGIgNGzbg008/RUBAQK34d6s0a34Pi/tQV3rF7z/HYoCrQk5ODt5++22cOHECQNmh3+IP3ODBg9GsWTPs2bMH58+fN5s3ceJEqFQq0x269Xo9fvjhB6xatQrbtm3DpEmTkJiYiJCQkJraLbuwR69yc3Nx8OBBvP3220hISEBkZCQSExPRunXrGtor27NHn4pvKyKEQN++fREVFVVTu2N39ugXAGRlZeHAgQPYsWMHJk+ejI8++gh33XVXTeyS3VTVq5KKQz9QNArXsmVLfPzxxygsLCwzCpefn48vvvgCsbGxiImJwRdffIH+/fvbb0dqQOmQaovPlRACBQUFtaZX9uhRbf3+cwh7n2TnylavXi26d+9uumpNiPJP8i0oKBBCFJ20GRISIj788EORl5dnNu+FF14QTz31lNk6x44dM53g6urs2avbt2+L5ORk03KuzJ59Klbe9lyVvft16dIl03xXp7RXFX0+Pv74YzFgwAARHx8vhBBCq9WaTrwXQojff/+9VvwOCiHE5s2bxcyZM8WiRYvE7t27K1zO2s9VbeiVPXtU277/HIUjcOX4+uuvER4ejm3btuEf//gHQkJCcPHiReTn55sN8QohIMsyPDw8AAC9evXCo48+ih07dpjuU+bh4YG8vDykpKSgVatWAGBap2fPni5/mKsmeuXv74/+/fvDy8ur5nfQRmqiT8Vqw2EIe/ereGShVatWpnVdlaW9Kv35KO7FI488gtDQUGzfvh2HDx/GW2+9hXfffRfZ2dkAgPbt27v07yAA/O9//8OoUaOwadMm+Pj44IcffsC8efPwn//8B8DfI0zV/Vy5cq/s3aPa9P3naHXrmTGVEEIgNzcXzzzzDH799VdMmjQJkydPRtOmTXH69GlcvXoVbm5uprtqFx+ykiQJZ8+eRWJiIl588UXMmzcPL730EpYvXw4hBEJCQpCSkgKtVos+ffoAcP0rA9krZdgny9Rkv1z9JsfV7dW///1vPP3002jSpImpFw0bNkRYWBj+85//IDo6GhqNBosXL65VzyPetm0bAgICsHz5crRu3RparRYvv/wy1qxZg/79+9f5zxVg/x7Vhn+rnEaNjfW5iA8//FCcOXNGyLJsOtQQHx8vQkNDTfclK56el5cn5s2bJ0JCQkR0dLTpZpjnzp0TS5YsEd26dRMDBw4UPXr0EB9++KFjdsiO2Ctl2CfLsF/KVadXxfdbFEKI3NxcsWvXLjFy5EjRuXNnsWHDhhrfF3u7ffu2GDx4sHj99deFEMLUs8WLF4tJkyYJvV5f5z9X7JFrYYC7o/gGjOXZsWOH6N69u9i/f7/Z9IULF4px48aJw4cPi8LCwjLr3bhxQ/z4449Cq9XavF5HYq+UYZ8sw34pZ+te5efnizFjxohp06aJjIwMu9TsaLdu3RLjx48Xc+bMMTv36umnnxarV68WN27cME1btGiReOyxx+rc54o9ci11NsAdPXpUrFmzRghR8Um9xXfMvnnzpggJCRE7duwQQgih1+uFEEJkZGTUiUd/sFfKsE+WYb+Uq4le1ZYv2sp69f7774vBgweLiIgIER8fLwYNGiR69uwpHnjgAXHfffeJ1157TeTm5ors7GyRnZ3tiPJrBHtUO9S5c+BycnKwfv16000rw8LC0KNHD9O5IiWVvLv9PffcgyNHjmDMmDFwd3cHUHRH89qMvVKGfbIM+6VcTfZKo9HYYQ9qTmW9EkJApVIhOjoa3bp1w5kzZ/DJJ5+ge/fumDlzJoxGI37//Xe88MILaN26NaZMmWLqW23CHtUude5swk8//RSJiYl49NFH0aFDB7z55psAKr9yz9vbGwEBAbh58yZu375dU6U6HHulDPtkGfZLOfZKucp6VTLcDhgwAN27d0deXh5mz56Nu+++G0FBQXj44YcxfPhwJCUlmS4AqW3Yo9qlzgS44g9aYGAg+vTpg/nz52PWrFn4/fffsX37drNlSiq+5LlTp064dOmSy14abgn2Shn2yTLsl3LslXLW9Oq///0vWrVqZRp1LL4NT/PmzXHlyhXodLpacTueYuxRLVVjB2sdID09vdJzPv766y8xZ84c0bdv3yrPo/nyyy9Fx44dxfHjx4UQtetmqUKwV0qxT5Zhv5Rjr5SztlfFfdi2bZvo3Lmz+Pbbb03zLl++LB5//HGxaNEi+xVeg9ij2q9WjsBlZmYiJiYGTz75JCZNmoQNGzbgypUrAACDwQCg6L8mAgMDMX78eOj1esTGxgKo+NEzDRo0gLu7e5ln3rk69koZ9sky7Jdy7JVy1e1VcR/Gjh2L1q1bY/HixViwYAE2btyI2bNnIy8vD48++qhjds5G2KO6o9YFuPT0dMycORM3b95EVFQUOnfujM8++wyzZ89GQUEB3NyKrtso/pB26tQJERERSEhIwMWLFyFJktk/isU/d+zYEWq1GgEBATW/U3bCXinDPlmG/VKOvVLOVr0Sd07WX7lyJbp27YqTJ09i165d6NGjB3bs2IFu3bo5cC+rhz2qY2p0vK8GHD58WPTs2VOcOnXKNO3QoUNiwIABYvbs2eU+9/Ds2bPiwQcfFNHR0aZpBoPBNJRc/GdmZqadq69Z7JUy7JNl2C/l2CvlbNmr4vvoGY1Gcfv27VrTK/aobql1I3CpqamoX78+7rrrLtO0fv36Ye7cufjqq6+QlJRkmi7u/NdqmzZtMHXqVHz77bc4fPgwUlNT8e9//xs//fQTgL//a8XPz68G98T+2Ctl2CfLsF/KsVfK2bJXx44dA1B06xV/f/9a0yv2qG5x2fvA5ebm4rPPPoNarUbjxo3RrVs3NG3aFJIkITMzE+np6WjcuDEkSYK7uzuGDh2K4cOHY+3atejfvz8aNGhg+ofOw8MD/fr1Q69evfDqq6/Cx8cHN27cwIcffujgvbQN9koZ9sky7Jdy7JVy7FXV2CMCXPQcuG3btuGBBx7A//t//w87d+7EK6+8gunTpwMAHnzwQbi5ueGbb74xPXQXKPqQRkVF4erVqzh8+DCAv0/ozM3NRUpKCtLS0pCWloawsDAcPXoU/fr1c8wO2hB7pQz7ZBn2Szn2Sjn2qmrsEZk48PCtxQwGg9i2bZsYOXKk2LBhg0hNTRXZ2dniiy++EF27dhWxsbFCiKJn/oWFhZke1lx8TkhWVpaYMWOGGDdunNl2d+3aJUJCQsTjjz8uzp49W6P7ZC/slTLsk2XYL+XYK+XYq6qxR1SaS43AqVQqHDx4EKGhoRg7dizuuusu+Pj4IDw8HAMGDMChQ4dgNBoxZswYuLm5YcWKFQD+PifE19cXQUFBkGUZGRkZpu3ef//9iI2NxbZt2xASEuKQfbM19koZ9sky7Jdy7JVy7FXV2CMqzaXOgZMkCQsXLoSfnx+8vb0BFJ2I6efnBw8PD7i5uUGtViM4OBhRUVF455130L9/fwwcONB0+XR+fj4yMzPh4+NjWr9x48YYOnSow/bLHtgrZdgny7BfyrFXyrFXVWOPqDSXCnAA0KRJEwBFNyJUqVSmGw8KIUwP1vXx8cETTzyBkydPYtGiRbh16xaGDRuG9PR0nDp1CiNHjoSnpyeA2nODy/KwV8qwT5Zhv5Rjr5Rjr6rGHlFJkhC142m0jzzyCPr374+XXnrJ9OHW6/V4+eWX8e2336JZs2ZIT09Hs2bNsGLFCtx9992OLtlh2Ctl2CfLsF/KsVfKsVdVY4/qJpcbgSvPX3/9hatXr6JHjx4Ais4VMBqN8PDwwL/+9S+cO3cOKSkp8PHxwZAhQxxcrWOxV8qwT5Zhv5Rjr5Rjr6rGHtVdtSLAnT9/HoWFhWjTpg2AouHl//3vf2jcuDECAgLQpUsXdOnSxcFVOgf2Shn2yTLsl3LslXLsVdXYo7rLpa5CLa34HjenTp1Co0aNEBQUhOvXr+Ott97CmDFjzO46XdexV8qwT5Zhv5Rjr5Rjr6rGHpFLj8CpVEX589SpU+jUqRO2bNmCDz74AL6+vli3bh0GDBjg4AqdB3ulDPtkGfZLOfZKOfaqauwRufxFDPn5+Rg5ciSuXr0KLy8vzJw5E1FRUY4uyymxV8qwT5Zhv5Rjr5Rjr6rGHtVtLj0CBwBeXl7o3r07Bg8ejBdeeAEeHh6OLslpsVfKsE+WYb+UY6+UY6+qxh7VbS4/Agf8fU8cqhp7pQz7ZBn2Szn2Sjn2qmrsUd1VKwIcERERUV3C2E5ERETkYhjgiIiIiFwMAxwRERGRi2GAIyIiInIxDHBERERELoYBjoiIiMjFMMARESkUGxuLkJAQq9efPHkyJk+ebMOKbMNZ6yKiijHAEZFd7NixAyEhIab/dezYEf3798e8efOQmprq6PJcSl5eHmJjY/Hjjz9avY1z584hNjYWV69etWFlROQoLv8oLSJybrNmzUKLFi2g1+tx8uRJ7Ny5E7/88gv27NkDT09PR5fnEvLy8rB69WrMmDEDvXr1smob586dw+rVqxEWFoYWLVqYzYuLi7NFmURUgxjgiMiuwsPD0aVLFwDA448/jgYNGmDDhg04ePAgHnroIQdXZ85gMECW5Tr3TMm6tr9EtQEPoRJRjbr33nsBAFeuXDGbfv78ecyaNQthYWHo0qULHnvsMRw8eLDM+jqdDv/6178waNAgdO7cGeHh4XjppZeQkZFhWiY9PR3z589Hnz590KVLFzz66KPYuXOn2XauXr2KkJAQxMXFYePGjRgyZAi6dOmC8+fPAwCOHTuGsWPHokuXLhgyZAgSExMt2s+tW7diyJAhCA0Nxbhx43Ds2LEyy+j1eqxcuRKPPfYYevbsiW7dumHixIn44YcfzOrs3bs3AGD16tWmQ9KxsbGKe7djxw7Mnj0bADBlyhTTNooPyZY+B+7HH39ESEgI9u7di9WrV6N///7o3r07Zs2ahaysLOj1erz55pvo3bs3unfvjldeeQV6vb7M/u3evRuPPfYYQkNDERYWhpiYGNy4ccOiPhJR+TgCR0Q16tq1awAAjUZjmvbnn39iwoQJaNy4MZ555hnUq1cP+/btw/Tp0xEbG4uhQ4cCAHJycvDkk0/i/PnzGDt2LDp27Ijbt2/j0KFDSE1NRUBAAPLz8zF58mRcvnwZTz75JFq0aIGkpCTMmzcPOp0OkZGRZvXs2LEDBQUFeOKJJ+Dh4QE/Pz/88ccfiIqKQkBAAGbOnAmDwYDY2Fg0bNhQ0T5u374dCxYsQPfu3REZGYkrV67gn//8J/z8/NC0aVPTctnZ2di+fTtGjhyJxx9/HDk5Ofj3v/+Np59+Gtu3b0eHDh0QEBCAhQsXYuHChRg6dKipF8UXUyjp3X333YfJkycjISEB//jHPxAUFAQACA4OrnQ/1q9fDy8vLzz77LO4dOkSPvnkE7i5uUGSJOh0OsyYMQOnTp3Cjh070Lx5c8yYMcO07po1a7By5UqMGDEC48aNQ0ZGBj755BM8+eST2LVrl9nfPxFZQRAR2cHnn38u2rVrJ44ePSrS09PFjRs3RFJSkrj//vtF586dxY0bN0zLRkZGipEjR4qCggLTNFmWxfjx48WwYcNM01auXCnatWsn9u/fX+b9ZFkWQgixceNG0a5dO7F7927TPL1eL8aPHy+6desmsrKyhBBCXLlyRbRr10706NFDpKenm23rueeeE126dBHXrl0zTTt37pzo0KGDaNeuXaX7rdfrRe/evcWoUaPM9mfr1q2iXbt2YtKkSaZpBoPBbBkhhNBqtaJPnz7ilVdeMU1LT08X7dq1E6tWrSrzfkp7t2/fPtGuXTvxww8/lNnGpEmTzOr64YcfRLt27cTIkSOFXq83TZ8zZ44ICQkRTz/9tNn648ePFw888IDp9dWrV0WHDh3EmjVrzJb7448/RMeOHctMJyLL8RAqEdnV1KlT0bt3bwwYMACzZs2Ct7c31qxZgyZNmgAAMjMz8cMPP2DEiBHIzs5GRkYGMjIycPv2bfTr1w8XL140XbW6f/9+tG/f3jQKVZIkSQCA5ORkBAYGYuTIkaZ57u7umDx5MnJzc/Hzzz+brTds2DAEBASYXhuNRhw5cgRDhgxBs2bNTNODg4PRr1+/Kvf3119/RXp6OiIiIszOLRszZgzq169vtqxarTYtI8syMjMzYTAY0LlzZ/z2229VvpclvbPGqFGj4O7ubnodGhoKIQTGjh1rtlxoaChu3LgBg8EAADhw4ABkWcaIESNMNWVkZKBRo0a4++67q3U1LREV4SFUIrKrBQsWoE2bNsjKysLnn3+On3/+2SzYXL58GUIIrFy5EitXrix3G+np6WjcuDEuX76MYcOGVfp+165dw9133w2Vyvy/T4sPF16/ft1seukrMjMyMpCfn4+77767zLbbtGmDw4cPV/r+xdsvvb67uztatmxZZvmdO3ciPj4eFy5cQGFhYYV1lceS3lmjZIAFYAqgJQ8DF0+XZRlZWVlo0KABLl68CCFEhX9Xbm786iGqLv4WEZFdhYaGmq5CHTJkCCZOnIgXXngBSUlJ8PHxgSzLAIBp06ahf//+5W6jVatWdqvPy8vLbtuuyu7duzFv3jwMGTIEUVFRaNiwIdRqNdatW1fmIo/y2Lt3pUNwVdOFEKa6JEnChg0boFaryyxXr149q2sioiIMcERUY9RqNebMmYMpU6Zgy5YtePbZZ02jUu7u7ujTp0+l67dq1Qp//vlnpcs0b94cf/zxB2RZNgsaKSkpAMqOKpUWEBAALy8vXLp0qcy8CxcuVLpuye1funTJdPUoABQWFuLq1ato3769adpXX32Fli1bYvXq1aZDwACwatUqs22WnFeSJb2raBv20KpVKwgh0KJFC7Rp06bG3peoLuE5cERUo3r16oXQ0FBs2rQJBQUFaNiwIcLCwrB161b89ddfZZYveXuQYcOG4ezZszhw4ECZ5YpHf8LDw3Hr1i3s3bvXNM9gMCAhIQH16tXDfffdV2l9arUa/fr1w9dff212uPX8+fM4cuRIlfvXuXNnBAQEIDEx0ezWGjt37oROpyvzXiVrB4BTp07h5MmTZst5e3sDQJn1Leld8TaysrKq3IfqGjZsGNRqNVavXm22b0DRvt6+fdvuNRDVdhyBI6IaFxUVhdmzZ2PHjh2YMGEC3njjDUycOBGPPPIInnjiCbRs2RJpaWk4efIkbt68iS+++MK03ldffYXZs2dj7Nix6NSpE7RaLQ4dOoRFixahffv2GD9+PLZu3Yp58+bhzJkzaN68Ob766iscP34c8+fPh6+vb5X1zZw5E//5z3/w5JNPYsKECTAajfjkk0/Qtm1b/PHHH5Wu6+7ujueffx4LFixAZGQkHnroIVy9ehU7duwocw7cwIEDsX//fkyfPh0DBw7E1atXkZiYiLZt2yI3N9e0nJeXF9q2bYt9+/ahdevW8Pf3xz333IN27dop7l2HDh2gVquxYcMGZGVlwcPDA/fff7/iW6NYolWrVnj++efx3nvv4dq1axgyZAh8fHxw9epVfP3113jiiScQFRVl8/clqksY4Iioxg0bNgytWrVCfHw8nnjiCbRt2xaff/45Vq9ejZ07dyIzMxMBAQHo2LEjpk+fblrPx8cHW7ZsQWxsLA4cOICdO3eiYcOG6N27t+lEfS8vLyQkJODdd9/Fzp07kZ2djTZt2uCtt97CY489pqi+9u3bIy4uDm+99RZWrVqFJk2aYObMmbh161aVAQ4Axo8fD6PRiLi4OCxbtgzt2rUz3RetpMceewxpaWnYunUrjhw5grZt2+Kdd95BUlISfvrpJ7NllyxZgsWLF+Ott95CYWEhZsyYgXbt2inuXWBgIBYtWoR169bh1VdfhdFoxObNm+0S4ADg2WefRevWrbFx40Z88MEHAIAmTZqgb9++GDRokF3ek6gukUTp8W0iIiIicmo8B46IiIjIxTDAEREREbkYBjgiIiIiF8MAR0RERORiGOCIiIiIXAwDHBEREZGLYYAjIiIicjEMcEREREQuhgGOiIiIyMUwwBERERG5GAY4IiIiIhfDAEdERETkYv4/fQl5dgO2W1IAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots(layout=\"tight\")\n",
    "\n",
    "sns.histplot(\n",
    "    dts,\n",
    "    x=\"S_2\",\n",
    "    weights=\"weights\",\n",
    "    bins=100,\n",
    "    ax=ax,\n",
    "    label=\"all\",\n",
    ")\n",
    "\n",
    "sns.histplot(\n",
    "    x=last_dt,\n",
    "    weights=np.ones(len(last_dt)) / len(last_dt),\n",
    "    bins=10,\n",
    "    ax=ax,\n",
    "    label=\"last\",\n",
    ")\n",
    "\n",
    "ax.set_xlabel(\"Record datetime\")\n",
    "ax.set_ylabel(\"fraction of customers\")\n",
    "ax.legend()\n",
    "fig.autofmt_xdate()\n",
    "\n",
    "fig.savefig(FIGS_PATH / \"rec_time_hist.svg\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "2908385c",
   "metadata": {},
   "source": [
    "# Labels"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "id": "10069f76",
   "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>customer_ID</th>\n",
       "      <th>target</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0000099d6bd597052cdcda90ffabf56573fe9d7c79be5f...</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>00000fd6641609c6ece5454664794f0340ad84dddce9a2...</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>00001b22f846c82c51f6e3958ccd81970162bae8b007e8...</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>000041bdba6ecadd89a52d11886e8eaaec9325906c9723...</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>00007889e4fcd2614b6cbe7f8f3d2e5c728eca32d9eb8a...</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>458908</th>\n",
       "      <td>ffff41c8a52833b56430603969b9ca48d208e7c192c6a4...</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>458909</th>\n",
       "      <td>ffff518bb2075e4816ee3fe9f3b152c57fc0e6f01bf7fd...</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>458910</th>\n",
       "      <td>ffff9984b999fccb2b6127635ed0736dda94e544e67e02...</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>458911</th>\n",
       "      <td>ffffa5c46bc8de74f5a4554e74e239c8dee6b9baf38814...</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>458912</th>\n",
       "      <td>fffff1d38b785cef84adeace64f8f83db3a0c31e8d92ea...</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>458913 rows × 2 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "                                              customer_ID  target\n",
       "0       0000099d6bd597052cdcda90ffabf56573fe9d7c79be5f...       0\n",
       "1       00000fd6641609c6ece5454664794f0340ad84dddce9a2...       0\n",
       "2       00001b22f846c82c51f6e3958ccd81970162bae8b007e8...       0\n",
       "3       000041bdba6ecadd89a52d11886e8eaaec9325906c9723...       0\n",
       "4       00007889e4fcd2614b6cbe7f8f3d2e5c728eca32d9eb8a...       0\n",
       "...                                                   ...     ...\n",
       "458908  ffff41c8a52833b56430603969b9ca48d208e7c192c6a4...       0\n",
       "458909  ffff518bb2075e4816ee3fe9f3b152c57fc0e6f01bf7fd...       0\n",
       "458910  ffff9984b999fccb2b6127635ed0736dda94e544e67e02...       0\n",
       "458911  ffffa5c46bc8de74f5a4554e74e239c8dee6b9baf38814...       1\n",
       "458912  fffff1d38b785cef84adeace64f8f83db3a0c31e8d92ea...       0\n",
       "\n",
       "[458913 rows x 2 columns]"
      ]
     },
     "execution_count": 32,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_label = pd.read_csv(DATA_PATH / \"train_labels.csv\")\n",
    "df_label"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "id": "472ec3a1",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "customer_ID    object\n",
       "target          int64\n",
       "dtype: object"
      ]
     },
     "execution_count": 35,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_label.dtypes"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "ff3bf5eb",
   "metadata": {},
   "source": [
    "# Numerical features"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 62,
   "id": "80028c1b",
   "metadata": {},
   "outputs": [],
   "source": [
    "from pyspark.sql import SparkSession\n",
    "from pyspark.sql.types import FloatType, ArrayType"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 40,
   "id": "aaf561ee",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Picked up _JAVA_OPTIONS: -Xmx20g\n",
      "Picked up _JAVA_OPTIONS: -Xmx20g\n",
      "Setting default log level to \"WARN\".\n",
      "To adjust logging level use sc.setLogLevel(newLevel). For SparkR, use setLogLevel(newLevel).\n",
      "24/03/05 12:39:56 WARN NativeCodeLoader: Unable to load native-hadoop library for your platform... using builtin-java classes where applicable\n",
      "24/03/05 12:39:57 WARN Utils: Service 'SparkUI' could not bind on port 4040. Attempting port 4041.\n"
     ]
    }
   ],
   "source": [
    "spark = SparkSession.builder.master(\"local[32]\").getOrCreate()  # pyright: ignore"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 41,
   "id": "3bac0488",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "                                                                                \r"
     ]
    }
   ],
   "source": [
    "df = spark.read.parquet(\"../data/amex/preprocessed/train\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 64,
   "id": "19f1b4d4",
   "metadata": {},
   "outputs": [],
   "source": [
    "num_features = []\n",
    "for field in df.schema:\n",
    "    if field.dataType == ArrayType(FloatType()):\n",
    "        num_features.append(field.name)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 70,
   "id": "634cee92",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'[\"B_1\", \"B_10\", \"B_11\", \"B_12\", \"B_13\", \"B_14\", \"B_15\", \"B_16\", \"B_17\", \"B_18\", \"B_19\", \"B_2\", \"B_20\", \"B_21\", \"B_22\", \"B_23\", \"B_24\", \"B_25\", \"B_26\", \"B_27\", \"B_28\", \"B_29\", \"B_3\", \"B_31\", \"B_32\", \"B_33\", \"B_36\", \"B_37\", \"B_39\", \"B_4\", \"B_40\", \"B_41\", \"B_42\", \"B_5\", \"B_6\", \"B_7\", \"B_8\", \"B_9\", \"D_102\", \"D_103\", \"D_104\", \"D_105\", \"D_106\", \"D_107\", \"D_108\", \"D_109\", \"D_110\", \"D_111\", \"D_112\", \"D_113\", \"D_115\", \"D_118\", \"D_119\", \"D_121\", \"D_122\", \"D_123\", \"D_124\", \"D_125\", \"D_127\", \"D_128\", \"D_129\", \"D_130\", \"D_131\", \"D_132\", \"D_133\", \"D_134\", \"D_135\", \"D_136\", \"D_137\", \"D_138\", \"D_139\", \"D_140\", \"D_141\", \"D_142\", \"D_143\", \"D_144\", \"D_145\", \"D_39\", \"D_41\", \"D_42\", \"D_43\", \"D_44\", \"D_45\", \"D_46\", \"D_47\", \"D_48\", \"D_49\", \"D_50\", \"D_51\", \"D_52\", \"D_53\", \"D_54\", \"D_55\", \"D_56\", \"D_58\", \"D_59\", \"D_60\", \"D_61\", \"D_62\", \"D_65\", \"D_69\", \"D_70\", \"D_71\", \"D_72\", \"D_73\", \"D_74\", \"D_75\", \"D_76\", \"D_77\", \"D_78\", \"D_79\", \"D_80\", \"D_81\", \"D_82\", \"D_83\", \"D_84\", \"D_86\", \"D_87\", \"D_88\", \"D_89\", \"D_91\", \"D_92\", \"D_93\", \"D_94\", \"D_96\", \"P_2\", \"P_3\", \"P_4\", \"R_1\", \"R_10\", \"R_11\", \"R_12\", \"R_13\", \"R_14\", \"R_15\", \"R_16\", \"R_17\", \"R_18\", \"R_19\", \"R_2\", \"R_20\", \"R_21\", \"R_22\", \"R_23\", \"R_24\", \"R_25\", \"R_26\", \"R_27\", \"R_28\", \"R_3\", \"R_4\", \"R_5\", \"R_6\", \"R_7\", \"R_8\", \"R_9\", \"S_11\", \"S_12\", \"S_13\", \"S_15\", \"S_16\", \"S_17\", \"S_18\", \"S_19\", \"S_20\", \"S_22\", \"S_23\", \"S_24\", \"S_25\", \"S_26\", \"S_27\", \"S_3\", \"S_5\", \"S_6\", \"S_7\", \"S_8\", \"S_9\"]'"
      ]
     },
     "execution_count": 70,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "str(list(sorted(num_features))).replace(\"'\", '\"')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "680568f8",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.10.12"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
