{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "%matplotlib inline\n",
    "import matplotlib.pyplot as plt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "from sklearn.model_selection import train_test_split"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import pandas as pd"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 482,
   "metadata": {},
   "outputs": [],
   "source": [
    "from IPython.display import display"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "customer_test.csv   stories_description.csv\ttransactions.csv\r\n",
      "customer_train.csv  stories_reaction_test.csv\r\n",
      "sample_submit.csv   stories_reaction_train.csv\r\n"
     ]
    }
   ],
   "source": [
    "!ls *.csv"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "def pd_intersection(a, b):\n",
    "    a = set(a)\n",
    "    b = set(b)\n",
    "    c = a.intersection(b)\n",
    "    print(f'a: {len(a)}, b: {len(b)}, c: {len(c)}')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# customer"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "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>product_0</th>\n",
       "      <th>product_1</th>\n",
       "      <th>product_2</th>\n",
       "      <th>product_3</th>\n",
       "      <th>product_4</th>\n",
       "      <th>product_5</th>\n",
       "      <th>product_6</th>\n",
       "      <th>gender_cd</th>\n",
       "      <th>age</th>\n",
       "      <th>marital_status_cd</th>\n",
       "      <th>children_cnt</th>\n",
       "      <th>first_session_dttm</th>\n",
       "      <th>job_position_cd</th>\n",
       "      <th>job_title</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>894436</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>UTL</td>\n",
       "      <td>NaN</td>\n",
       "      <td>M</td>\n",
       "      <td>30.0</td>\n",
       "      <td>MAR</td>\n",
       "      <td>0.0</td>\n",
       "      <td>2018-03-20 09:10:16</td>\n",
       "      <td>1</td>\n",
       "      <td>Неруководящий сотрудник - обсл. Персонал</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>524526</td>\n",
       "      <td>NaN</td>\n",
       "      <td>UTL</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>UTL</td>\n",
       "      <td>NaN</td>\n",
       "      <td>F</td>\n",
       "      <td>20.0</td>\n",
       "      <td>UNM</td>\n",
       "      <td>0.0</td>\n",
       "      <td>2017-03-29 20:38:45</td>\n",
       "      <td>16</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>498134</td>\n",
       "      <td>NaN</td>\n",
       "      <td>UTL</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>F</td>\n",
       "      <td>25.0</td>\n",
       "      <td>UNM</td>\n",
       "      <td>0.0</td>\n",
       "      <td>2018-03-12 11:25:06</td>\n",
       "      <td>22</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>278941</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>UTL</td>\n",
       "      <td>CLS</td>\n",
       "      <td>NaN</td>\n",
       "      <td>UTL</td>\n",
       "      <td>UTL</td>\n",
       "      <td>M</td>\n",
       "      <td>25.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>2016-02-21 18:47:51</td>\n",
       "      <td>16</td>\n",
       "      <td>Неруководящий сотрудник - специалист</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>877312</td>\n",
       "      <td>NaN</td>\n",
       "      <td>UTL</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>F</td>\n",
       "      <td>40.0</td>\n",
       "      <td>MAR</td>\n",
       "      <td>0.0</td>\n",
       "      <td>2018-03-07 11:17:02</td>\n",
       "      <td>22</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "   customer_id product_0 product_1 product_2 product_3 product_4 product_5  \\\n",
       "0       894436       NaN       NaN       NaN       NaN       NaN       UTL   \n",
       "1       524526       NaN       UTL       NaN       NaN       NaN       UTL   \n",
       "2       498134       NaN       UTL       NaN       NaN       NaN       NaN   \n",
       "3       278941       NaN       NaN       UTL       CLS       NaN       UTL   \n",
       "4       877312       NaN       UTL       NaN       NaN       NaN       NaN   \n",
       "\n",
       "  product_6 gender_cd   age marital_status_cd  children_cnt  \\\n",
       "0       NaN         M  30.0               MAR           0.0   \n",
       "1       NaN         F  20.0               UNM           0.0   \n",
       "2       NaN         F  25.0               UNM           0.0   \n",
       "3       UTL         M  25.0               NaN           NaN   \n",
       "4       NaN         F  40.0               MAR           0.0   \n",
       "\n",
       "    first_session_dttm  job_position_cd  \\\n",
       "0  2018-03-20 09:10:16                1   \n",
       "1  2017-03-29 20:38:45               16   \n",
       "2  2018-03-12 11:25:06               22   \n",
       "3  2016-02-21 18:47:51               16   \n",
       "4  2018-03-07 11:17:02               22   \n",
       "\n",
       "                                  job_title  \n",
       "0  Неруководящий сотрудник - обсл. Персонал  \n",
       "1                                       NaN  \n",
       "2                                       NaN  \n",
       "3      Неруководящий сотрудник - специалист  \n",
       "4                                       NaN  "
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_cust_train = pd.read_csv('customer_train.csv')\n",
    "df_cust_train.head()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "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>product_0</th>\n",
       "      <th>product_1</th>\n",
       "      <th>product_2</th>\n",
       "      <th>product_3</th>\n",
       "      <th>product_4</th>\n",
       "      <th>product_5</th>\n",
       "      <th>product_6</th>\n",
       "      <th>gender_cd</th>\n",
       "      <th>age</th>\n",
       "      <th>marital_status_cd</th>\n",
       "      <th>children_cnt</th>\n",
       "      <th>first_session_dttm</th>\n",
       "      <th>job_position_cd</th>\n",
       "      <th>job_title</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>234305</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>UTL</td>\n",
       "      <td>NaN</td>\n",
       "      <td>F</td>\n",
       "      <td>25.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.0</td>\n",
       "      <td>2015-10-29 09:59:10</td>\n",
       "      <td>22</td>\n",
       "      <td>Менеджер проектов</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>914339</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>UTL</td>\n",
       "      <td>NaN</td>\n",
       "      <td>M</td>\n",
       "      <td>15.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.0</td>\n",
       "      <td>2018-04-09 08:51:54</td>\n",
       "      <td>22</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>895631</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>UTL</td>\n",
       "      <td>NaN</td>\n",
       "      <td>M</td>\n",
       "      <td>20.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.0</td>\n",
       "      <td>2018-03-22 10:38:33</td>\n",
       "      <td>16</td>\n",
       "      <td>Менеджер по продажам</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>954837</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>UTL</td>\n",
       "      <td>NaN</td>\n",
       "      <td>F</td>\n",
       "      <td>25.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.0</td>\n",
       "      <td>2018-05-09 18:24:32</td>\n",
       "      <td>16</td>\n",
       "      <td>Инженер</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>391590</td>\n",
       "      <td>NaN</td>\n",
       "      <td>UTL</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>M</td>\n",
       "      <td>30.0</td>\n",
       "      <td>UNM</td>\n",
       "      <td>0.0</td>\n",
       "      <td>2016-10-08 05:29:20</td>\n",
       "      <td>20</td>\n",
       "      <td>сборщик мебели</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "   customer_id product_0 product_1 product_2 product_3 product_4 product_5  \\\n",
       "0       234305       NaN       NaN       NaN       NaN       NaN       UTL   \n",
       "1       914339       NaN       NaN       NaN       NaN       NaN       UTL   \n",
       "2       895631       NaN       NaN       NaN       NaN       NaN       UTL   \n",
       "3       954837       NaN       NaN       NaN       NaN       NaN       UTL   \n",
       "4       391590       NaN       UTL       NaN       NaN       NaN       NaN   \n",
       "\n",
       "  product_6 gender_cd   age marital_status_cd  children_cnt  \\\n",
       "0       NaN         F  25.0               NaN           0.0   \n",
       "1       NaN         M  15.0               NaN           0.0   \n",
       "2       NaN         M  20.0               NaN           0.0   \n",
       "3       NaN         F  25.0               NaN           0.0   \n",
       "4       NaN         M  30.0               UNM           0.0   \n",
       "\n",
       "    first_session_dttm  job_position_cd             job_title  \n",
       "0  2015-10-29 09:59:10               22     Менеджер проектов  \n",
       "1  2018-04-09 08:51:54               22                   NaN  \n",
       "2  2018-03-22 10:38:33               16  Менеджер по продажам  \n",
       "3  2018-05-09 18:24:32               16               Инженер  \n",
       "4  2016-10-08 05:29:20               20        сборщик мебели  "
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_cust_valid = pd.read_csv('customer_test.csv')\n",
    "df_cust_valid.head()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "a: 50000, b: 54245, c: 50000\n"
     ]
    }
   ],
   "source": [
    "pd_intersection(\n",
    "    df_cust_train['customer_id'].unique().tolist(),\n",
    "    df_cust_valid['customer_id'].unique().tolist(),\n",
    ")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# stories_reaction"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "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>story_id</th>\n",
       "      <th>event_dttm</th>\n",
       "      <th>event</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>15</td>\n",
       "      <td>138</td>\n",
       "      <td>2018-07-24 15:33:22</td>\n",
       "      <td>view</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>15</td>\n",
       "      <td>202</td>\n",
       "      <td>2018-06-04 08:08:08</td>\n",
       "      <td>skip</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>15</td>\n",
       "      <td>222</td>\n",
       "      <td>2018-06-17 13:44:45</td>\n",
       "      <td>skip</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>15</td>\n",
       "      <td>379</td>\n",
       "      <td>2018-05-23 05:41:43</td>\n",
       "      <td>skip</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>15</td>\n",
       "      <td>544</td>\n",
       "      <td>2018-07-25 02:16:29</td>\n",
       "      <td>view</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "   customer_id  story_id           event_dttm event\n",
       "0           15       138  2018-07-24 15:33:22  view\n",
       "1           15       202  2018-06-04 08:08:08  skip\n",
       "2           15       222  2018-06-17 13:44:45  skip\n",
       "3           15       379  2018-05-23 05:41:43  skip\n",
       "4           15       544  2018-07-25 02:16:29  view"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_user_item_train = pd.read_csv('stories_reaction_train.csv')\n",
    "df_user_item_train.head()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "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>story_id</th>\n",
       "      <th>event_dttm</th>\n",
       "      <th>answer_id</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>466906</td>\n",
       "      <td>1152</td>\n",
       "      <td>2018-08-01 00:00:46</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>466906</td>\n",
       "      <td>1355</td>\n",
       "      <td>2018-08-01 00:00:46</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>146395</td>\n",
       "      <td>537</td>\n",
       "      <td>2018-08-01 00:02:08</td>\n",
       "      <td>2</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>897303</td>\n",
       "      <td>915</td>\n",
       "      <td>2018-08-01 00:02:30</td>\n",
       "      <td>3</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>50094</td>\n",
       "      <td>1415</td>\n",
       "      <td>2018-08-01 00:03:13</td>\n",
       "      <td>4</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "   customer_id  story_id           event_dttm  answer_id\n",
       "0       466906      1152  2018-08-01 00:00:46          0\n",
       "1       466906      1355  2018-08-01 00:00:46          1\n",
       "2       146395       537  2018-08-01 00:02:08          2\n",
       "3       897303       915  2018-08-01 00:02:30          3\n",
       "4        50094      1415  2018-08-01 00:03:13          4"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_user_item_valid = pd.read_csv('stories_reaction_test.csv')\n",
    "df_user_item_valid.head()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [],
   "source": [
    "df_user_item_train['event_dttm'] = pd.to_datetime(df_user_item_train['event_dttm'])\n",
    "df_user_item_valid['event_dttm'] = pd.to_datetime(df_user_item_valid['event_dttm'])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "a: 41001, b: 22646, c: 14260\n"
     ]
    }
   ],
   "source": [
    "pd_intersection(\n",
    "    df_user_item_train['customer_id'].unique().tolist(),\n",
    "    df_user_item_valid['customer_id'].unique().tolist(),\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "min   2018-03-29 11:30:44\n",
       "max   2018-07-31 23:58:14\n",
       "Name: event_dttm, dtype: datetime64[ns]"
      ]
     },
     "execution_count": 14,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_user_item_train['event_dttm'].agg(['min', 'max'])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "min   2018-08-01 00:00:46\n",
       "max   2018-08-22 20:49:33\n",
       "Name: event_dttm, dtype: datetime64[ns]"
      ]
     },
     "execution_count": 15,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_user_item_valid['event_dttm'].agg(['min', 'max'])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [],
   "source": [
    "def plot_dates(s_dt):\n",
    "    s = s_dt.dt.floor('D')\n",
    "    s = s - pd.to_timedelta(s.dt.day - 1, 'D')\n",
    "    s = s.value_counts()\n",
    "    return s"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.axes._subplots.AxesSubplot at 0x7fa3b492d6a0>"
      ]
     },
     "execution_count": 17,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAZAAAAEGCAYAAABLgMOSAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADl0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uIDMuMC4yLCBodHRwOi8vbWF0cGxvdGxpYi5vcmcvOIA7rQAAIABJREFUeJzt3Xl8VNX9//HXh7AEEsKWsC8JiyCgAYngXlyqaFtxRe3iWpef1WrrWrW11S5qXarV+i1W61JFQbDiSilq1VoXFsMuICCENRAIkASyfX5/zEUDIglDkjvL+/l4zGMmZ+6988kw5D3n3DNnzN0RERHZV03CLkBEROKTAkRERKKiABERkagoQEREJCoKEBERiYoCREREoqIAERGRqChAREQkKgoQERGJStOwC6hvmZmZnp2dHXYZIiJxZcaMGRvcPWtf9km4AMnOzmb69OlhlyEiElfM7It93UdDWCIiEhUFiIiIREUBIiIiUVGAiIhIVBQgIiISFQWIiIhERQEiIiJRSbjPgYiISO3KyqtYvrGEZRsil2goQEREElRlVTWrNpexdEMJSwtLWLZhWyQwCktYXbx9v4+vABERiWPuTuG2HSwrjPQkaobFiqJSKqr8y20zUpvSOyudw3p3ICczjZysNHIy08jukEb63fv+2AoQEZE4sHV7Bcs3lLJ0w7YgIL66bNtR+eV2zZs2IadDGv06tubEQZ3JyUyjd2YkKNqnNcfM6q0mBYiISIwor6xmRVFppCdRuO3LHsWyDSUUbt3x5XZm0L1dS3Iy0xnWq12kNxFcurZtSUqT+guJvVGAiIg0oupqZ+2W7TWGm7Z92ZNYWVRK9VcjTmSmNycnM41j+2eRk5ke6U1kpdGzfStSm6WE90sEFCAiIg1gc2l5pPdQWMLS4OT10sISlm8sYXtF9ZfbtWqeQk5mGgd1a8Po3K7BeYl0cjqk0aZVsxB/g9rVGiBm1gN4GugEODDW3R80s/bAC0A2sBwY4+6bLDLA9iBwClAKXOjuM4NjXQDcFhz6t+7+VNA+DHgSaAm8Dlzj7v5Nj7Hfv7WISD3YXhFMhS0s+dpMp02lFV9u17SJ0bN9K3Iy0ziqb+aXJ697Z6bTKaNFvZ6XaEx16YFUAte5+0wzaw3MMLOpwIXANHe/y8xuBm4GbgJOBvoFlxHAo8CIIAxuB/KIBNEMM5scBMKjwKXAR0QCZBTwRnDMPT2GiEijqKp2Vm0q26UXsXPIadXmsl227ZyRSk5mGicf1OXLE9c5mWn0aN+KZimJ97ntWgPE3dcAa4LbW81sAdANGA2MDDZ7CniHyB/30cDT7u7Ah2bW1sy6BNtOdfcigCCERpnZO0CGu38YtD8NnEYkQL7pMURE6o27s2FbeRAMkVlOO09er9hYSnnVV0NOrYOpsMNz2u9y8jonM420Fsl1VmCfflszywaGEukpdArCBWAtkSEuiITLyhq7FQRte2sv2EM7e3kMEZF9tm1HJct3zmyqcW5iWWEJW2tOhU1pQnZmK/pkpXHCgZ0ivYlg2KlDPU+FjWd1DhAzSwcmAte6+5aaT2BwvsK/ced6sLfHMLPLgMsAevbs2ZBliEiMK6+sZuWm0hofrPvqcxPrd5sK261tS3Iy0zjjkG7BB+vS6d3IU2HjWZ0CxMyaEQmPZ919UtC8zsy6uPuaYIhqfdC+CuhRY/fuQdsqvhqO2tn+TtDefQ/b7+0xduHuY4GxAHl5eQ0aZCISPvdgKuweTl6v3FRGVY25sB3SIlNhv3VAFjlZOz9Ul06vDrExFTae1WUWlgGPAwvc/f4ad00GLgDuCq5frtF+lZk9T+QkenEQAFOA35tZu2C7E4FfuHuRmW0xs8OIDI2dD/y5lscQkSTl7vzkuZm8Pmftl20tm0Wmwg7q1obv5Xbd5bxE21bNQ6w2sdWlB3Ik8CNgjpl9GrTdQuSP+ngzuwT4AhgT3Pc6kSm8S4hM470IIAiKO4FPgu3u2HlCHbiSr6bxvhFc2MtjiEiSGj99Ja/PWcvFR+ZwwoEdyclKo3NGqs5LhMAik6USR15enk+fPj3sMkSkARRsKmXUn97joG5tePbHI2ii8xT1xsxmuHvevuyTeBOTRSQhVVc7N744G4B7zjpY4REDFCAiEhee+fALPvh8I7d950B6tG8VdjmCAkRE4sCyDSXc9cZCRvbP4pxDe9S+gzQKBYiIxLSqauf6Cfk0SzHuPvNgnSyPIcn1uXsRiTuPv7+UGV9s4k/nDKFTRmrY5UgN6oGISMxavG4r9/5rEScN6sToIV3DLkd2owARkZhUUVXNdRPySW/RlN+dfpCGrmKQhrBEJCY9+s7nzC4o5i8/OITM9BZhlyN7oB6IiMSceauLeWjaYk7N7copB3UJuxz5BgoQEYkpOyqruG58Pu3SmnPH6EFhlyN7oSEsEYkpD01bzMK1W3niwjwthBjj1AMRkZgxa8UmHn3nc8bkdee4Afr+uFinABGRmLC9oorrJuTTOSOV2747MOxypA40hCUiMeHeKZ+xtLCEf1wygozUZmGXI3WgHoiIhO7jZUU8/t9l/OiwXhzVLzPscqSOFCAiEqqSHZVcPyGfnu1bcfPJA8IuR/aBhrBEJFR/eGMBKzeVMv7yw0lroT9J8UQ9EBEJzXuLC/nHhyv48VE5HJrdPuxyZB8pQEQkFFu2V3Dji7Ppk5XGdSf2D7sciYL6iyISijtfmc+6LduZdOWRpDZLCbsciYJ6ICLS6KYtWMeEGQVcObIvQ3q0DbsciZICREQa1aaScm6eNIcBnVvz0+P7hV2O7AcNYYlIo/rV5HlsLi3nqYuG07yp3sPGM/3riUijeW32Gl7JX81Pj+vHwK4ZYZcj+0kBIiKNonDrDm775xxyu7fh/43sE3Y5Ug8UICLS4NydW1+aQ0l5FfeNyaVpiv70JAL9K4pIg3tp1ir+NX8dN5zYn74dW4ddjtQTBYiINKi1xdu5ffI88nq14+KjcsIuR+qRAkREGoy7c9PE2VRWOfeenUtKEwu7JKlHChARaTDPf7KS/ywq5BenDCA7My3scqSeKUBEpEGsLCrlt6/O58i+HfjhiF5hlyMNQAEiIvWuutq54cV8zIx7zsqliYauEpICRETq3dP/W86HS4v45XcPpFvblmGXIw1EASIi9Wpp4TbuenMhx/bPYkxej7DLkQakABGRelNV7Vw/IZ8WTVO468yDMdPQVSLTYooiUm8ee28pM1ds5sFzh9ApIzXscqSBqQciIvVi0bqt3P+vRYwa1JlTc7uGXY40AgWIiOy3iqpqfj7+U1qnNuW3pw/W0FWSqDVAzOwJM1tvZnNrtP3azFaZ2afB5ZQa9/3CzJaY2WdmdlKN9lFB2xIzu7lGe46ZfRS0v2BmzYP2FsHPS4L7s+vrlxaR+vWXtz9n7qot/O70wWSmtwi7HGkkdemBPAmM2kP7A+4+JLi8DmBmA4FzgUHBPn8xsxQzSwEeAU4GBgLnBdsC3B0cqy+wCbgkaL8E2BS0PxBsJyIxZu6qYv781mJOG9KVUYO7hF2ONKJaA8Td3wWK6ni80cDz7r7D3ZcBS4DhwWWJuy9193LgeWC0Rfq5xwEvBvs/BZxW41hPBbdfBI439YtFYsqOyiquG59P+7Tm/ObUwWGXI41sf86BXGVms4MhrnZBWzdgZY1tCoK2b2rvAGx298rd2nc5VnB/cbC9iMSIP/17MZ+t28rdZx5Mm1bNwi5HGlm0AfIo0AcYAqwB7qu3iqJgZpeZ2XQzm15YWBhmKSJJY+aKTfz1P59zTl4Pjh3QMexyJARRBYi7r3P3KnevBh4jMkQFsAqo+dHT7kHbN7VvBNqaWdPd2nc5VnB/m2D7PdUz1t3z3D0vKysrml9JRPZBWXkV14/Pp0ubltz23QPDLkdCElWAmFnNM2WnAztnaE0Gzg1mUOUA/YCPgU+AfsGMq+ZETrRPdncH3gbOCva/AHi5xrEuCG6fBbwVbC8iIfvjlM9YuqGEP551MK1TNXSVrGr9JLqZjQNGAplmVgDcDow0syGAA8uBywHcfZ6ZjQfmA5XAT9y9KjjOVcAUIAV4wt3nBQ9xE/C8mf0WmAU8HrQ/DjxjZkuInMQ/d79/WxHZbx8u3cjfP1jG+Yf34oi+mWGXIyGyRHtTn5eX59OnTw+7DJGEVLKjklEPvksTM9645mhaNddqSInCzGa4e96+7KN/fRGps9+/voCCTWVMuPxwhYdoKRMRqZt3FxXy7EcruPTo3uRltw+7HIkBChARqVVxWQU3TZxN347p/PzbB4RdjsQI9UFFpFZ3vDKf9Vt3MOmHw0htlhJ2ORIj1AMRkb2aOn8dE2cWcOXIPuT2aBt2ORJDFCAi8o02lZTzi0lzOLBLBlcf1y/sciTGaAhLRL7RL1+eS3FZOc9cMpzmTfV+U3alV4SI7NGrs1fz6uw1XHvCARzYJSPsciQGKUBE5GvWb93OL/85l9webbn8mN5hlyMxSgEiIrtwd26ZNJfS8iruOzuXpin6MyF7pleGiOxi0sxV/HvBOm44qT99O6aHXY7EMAWIiHxpTXEZv35lHodmt+OiI3PCLkdinAJERIDI0NWNL86mssq59+xcUproG6Rl7xQgIgLAuI9X8t7iDdxyygB6dUgLuxyJAwoQEWFlUSm/fW0+R/XN5AcjeoVdjsQJBYhIkquudq6fkE+KGXefdTBNNHQldaQAEUlyT36wnI+WFfHL7w2kW9uWYZcjcUQBIpLEPi/cxt1vLuT4AR05e1j3sMuROKMAEUlSVcHQVWqzFP5wxkGYaehK9o0WUxRJUmPfXcqsFZt58NwhdMxIDbsciUPqgYgkoc/WbuWBqYs45aDOnJrbNexyJE4pQESSTEVVNT8f/ymtU5ty5+jBGrqSqGkISyTJPPzWEuat3sJffzSMDuktwi5H4ph6ICJJZE5BMY+8vYTTh3bjpEGdwy5H4pwCRCRJ7Kis4roJn9IhvTm//t6gsMuRBKAhLJEk8cDUxSxat42/X3QobVo1C7scSQDqgYgkgRlfbGLsu59z7qE9OLZ/x7DLkQShABFJcGXlVVw/IZ8ubVpy63cODLscSSAawhJJcPdMWciyDSU8d+kIWqdq6Erqj3ogIgnsf59v5O//Xc6FR2RzRJ/MsMuRBKMAEUlQ23ZUcsOL+WR3aMWNo/qHXY4kIA1hiSSo3722gNWby5hwxeG0aq7/6lL/1AMRSUD/WVTIuI9XcOnRvRnWq33Y5UiCUoCIJJjisgpuenE2/Tqm87NvHxB2OZLA1K8VSTC/eWUehdt28Nj5eaQ2Swm7HElg6oGIJJB/zVvLpJmr+MnIPhzUvU3Y5UiCU4CIJIiiknJueWkOA7tkcNVx/cIuR5KAhrBEEsQv/zmX4rIK/vHjETRvqveG0vBqfZWZ2RNmtt7M5tZoa29mU81scXDdLmg3M3vIzJaY2WwzO6TGPhcE2y82swtqtA8zsznBPg9Z8O023/QYIvJ1r+Sv5rU5a7j2hAMY0Dkj7HIkSdTlbcqTwKjd2m4Gprl7P2Ba8DPAyUC/4HIZ8ChEwgC4HRgBDAdurxEIjwKX1thvVC2PISI1rN+6nV++PJfcHm25/JjeYZcjSaTWAHH3d4Gi3ZpHA08Ft58CTqvR/rRHfAi0NbMuwEnAVHcvcvdNwFRgVHBfhrt/6O4OPL3bsfb0GCIScHd+MXEOZeVV3Hd2Lk1TNHQljSfaV1snd18T3F4LdApudwNW1tiuIGjbW3vBHtr39hgiEnhxRgHTFq7nhpP607djetjlSJLZ77crQc/B66GWqB/DzC4zs+lmNr2wsLAhSxGJGas3l3HHK/MZntOei4/MCbscSULRBsi6YPiJ4Hp90L4K6FFju+5B297au++hfW+P8TXuPtbd89w9LysrK8pfSSR+uDs3TZxNlTv3npVLkyYWdkmShKINkMnAzplUFwAv12g/P5iNdRhQHAxDTQFONLN2wcnzE4EpwX1bzOywYPbV+bsda0+PIZL0nv1oBe8t3sAtpxxIzw6twi5HklStnwMxs3HASCDTzAqIzKa6CxhvZpcAXwBjgs1fB04BlgClwEUA7l5kZncCnwTb3eHuO0/MX0lkpldL4I3gwl4eQySprdhYyu9fX8DR/TL5wYieYZcjScwipxcSR15enk+fPj3sMkQaRHW1c+5jH7Jg9Ram/OwYurZtGXZJkiDMbIa75+3LPprzJxJH/v7Bcj5eVsSvvjdQ4SGhU4CIxInPC7dxz5sLOX5AR84a1r32HUQamAJEJA5UVlVz3fh8WjZP4Q9nHESw4o9IqLSYokgc+Ou7S/l05WYeOm8oHTNSwy5HBFAPRCTmLVy7hT/9exHfOagL3zu4S9jliHxJASISw8orq/n5C/m0admMO08brKEriSkawhKJYQ+/vYT5a7bw1x8No31a87DLEdmFeiAiMWp2wWYeeXsJZwztxkmDOoddjsjXKEBEYtD2iiquG59PVnoLbv/eoLDLEdkjDWGJxKAHpi5i8fptPHnRobRp1SzsckT2SD0QkRgz44sixr63lPOG92Rk/45hlyPyjRQgIjGktLyS68bn061tS279zoFhlyOyVxrCEokh97z5Gcs3ljLu0sNIb6H/nhLb1AMRiREffL6BJz9YzoVHZHN4nw5hlyNSKwWISAzYur2CGybMJiczjZtGDQi7HJE6UR9ZJAb8/vUFrCkuY8IVh9OyeUrY5YjUiXogIiF7+7P1jPt4JZce05thvdqHXY5InSlAREJUXFrBzRNnc0CndH52wgFhlyOyTzSEJRKiX78yjw3byvnb+YeS2kxDVxJf1AMRCcmbc9fy0qxVXHVsXw7q3ibsckT2mQJEJAQbt+3g1pfmMKhrBlcd1zfsckSioiEskUbm7tz2z7ls3V7Js5fm0ixF7+MkPumVK9LIJuev5o25a7n22/0Y0Dkj7HJEoqYAEWlE67ds51cvz2Noz7ZcdnTvsMsR2S8KEJFG4u7cPGkO2yuquPfsXJpq6ErinF7BIo1kwowC3lq4nptGDaBPVnrY5YjsNwWISCNYtqGEO1+Zz4ic9lx4RHbY5YjUCwWISAN7bfYaTv3z+zRpYvzxrFyaNLGwSxKpF5rGK9JAtldUccer83nuoxUM7dmWh84dSo/2rcIuS6TeKEBEGsDidVu56rlZfLZuK1d8qw/XnXiAPu8hCUcBIlKP3J0J0wv41eS5pLdoytMXD+eYA7LCLkukQShAROrJ1u0V3PrSXCbnr+bIvh144JwhdGydGnZZIg1GASJSD2YXbObqcbMo2FTGDSf154pv9SFFJ8slwSlARPaDu/PEf5dz1xsLyEpvwQuXHUZetr4USpKDAkQkSkUl5dwwIZ9pC9dz4sBO3HPWwbRt1TzsskQajQJEJAofLd3INc9/SlFJOb85dRDnH94LMw1ZSXJRgIjsg6pq5+G3lvDgtEX06pDGpAuOYHA3fRmUJCcFiEgdrduynWuen8WHS4s4Y2g37jhtMOkt9F9Iktd+fbLJzJab2Rwz+9TMpgdt7c1sqpktDq7bBe1mZg+Z2RIzm21mh9Q4zgXB9ovN7IIa7cOC4y8J9tUYgYTi7YXrOfnB95hdUMx9Z+dy/zlDFB6S9Orjo7HHuvsQd88Lfr4ZmObu/YBpwc8AJwP9gstlwKMQCRzgdmAEMBy4fWfoBNtcWmO/UfVQr0idlVdW87vX5nPRk5/QKSOVV64+ijOHdQ+7LJGY0BBvoUYDI4PbTwHvADcF7U+7uwMfmllbM+sSbDvV3YsAzGwqMMrM3gEy3P3DoP1p4DTgjQaoWeRrVmws5epxM8kvKOb8w3txyykHktosJeyyRGLG/gaIA/8yMwf+6u5jgU7uvia4fy3QKbjdDVhZY9+CoG1v7QV7aBdpcK/kr+aWSXMwg//74SGMGtwl7JJEYs7+BshR7r7KzDoCU81sYc073d2DcGlQZnYZkWExevbs2dAPJwmsrLyKO16dx7iPV3JIz7Y8dN5QurfTCroie7Jf50DcfVVwvR54icg5jHXB0BTB9fpg81VAjxq7dw/a9tbefQ/te6pjrLvnuXteVpYWrpPoLFq3ldGPvM/zn6zkypF9eOHywxUeInsRdYCYWZqZtd55GzgRmAtMBnbOpLoAeDm4PRk4P5iNdRhQHAx1TQFONLN2wcnzE4EpwX1bzOywYPbV+TWOJVJv3J1xH6/g1Iffp6iknKcvHs6NowZo+XWRWuzPEFYn4KVgZm1T4Dl3f9PMPgHGm9klwBfAmGD714FTgCVAKXARgLsXmdmdwCfBdnfsPKEOXAk8CbQkcvJcJ9ClXm3ZXsEtk+bw6uw1HN0vk/vG5GoFXZE6ssikqMSRl5fn06dPD7sMiQP5KyMr6K7aXMZ1Jx7AFcf00dfNStIysxk1Po5RJ/oklCSd6mrn8feXcfebC+mUkcr4yw9jWC+toCuyrxQgklQ2btvB9RPyefuzQk4a1Il7zsylTatmYZclEpcUIJI0/vf5Rq59YRabSiu4c/QgfniYVtAV2R8KEEl4VdXOg9MW8+e3FpPTIY0nLjyUQV21gq7I/lKASEJbU1zGNc9/ysfLijjzkO7cMXoQaVoEUaRe6H+SJKxpC9Zx/YR8dlRWc/+YXM44RIsgitQnBYgknPLKau56YyFP/HcZA7tk8PD3h9I7Kz3sskQSjgJEEsryDSVcPW4Wc1YVc+ER2dx88gCtoCvSQBQgkjBe/nQVt740l5Qmxl9/NIyTBnUOuySRhKYAkbhXWl7JryfPY/z0AvJ6tePB84bSrW3LsMsSSXgKEIlrC9du4arnZvF54TZ+cmwffnbCATTVIogijUIBInHJ3Xnu4xXc8cp8Wqc245mLR3BUv8ywyxJJKgoQiTvFZZEVdF+bE1lB9/4xQ8hq3SLsskSSjgJE4sqsFZu4etws1hRv56ZRA7j8mN5aQVckJAoQiQvV1c5j7y3lj1M+C1bQPZxhvdqFXZZIUlOASMzbsG0H143P5z+LChk1qDN3n3mwVtAViQEKEIlpHyzZwLUvfMrmsgruPG0wPxzRUyvoisQIBYjEpMqqah6atpg/v72E3plpPHXxcA7skhF2WSJSgwJEYs7qzWVc+/ynfLy8iLOGRVbQbdVcL1WRWKP/lRJTps5fxw0v5lNRWc0D5+Ry+lCtoCsSqxQgEhN2VFZx1xsL+ft/lzOoawYPf/8QcjLTwi5LRPZCASKhW7ahhKvHzWTuqi1ceEQ2vzhlAC2aagVdkVinAJFQ/XPWKm59aQ7NmjbhsfPz+PbATmGXJCJ1pACRUJSWV3L7y/OYMKOAQ7Pb8eC5Q+mqFXRF4ooCRBrdgjVbuOq5mSzdUMLVx/XlmuP7aQVdkTikAJFG4+48+9EK7nh1Pm1aNuPZS0ZwRF+toCsSrxQg0iiKyyq4eeJs3pi7lmMOyOL+MblkpmsFXZF4pgCRBjdzxSaufm4W67Zs5xcnD+DSo7WCrkgiUIBIg6mudsa+t5R7p3xG5zapTLjicIb21Aq6IolCASINonDrDn4+/lPeW7yBUw7qzB/OOJg2LbWCrkgiUYBIvftvsILulrIKfnf6YL4/XCvoiiQiBYjUm8qqav7078U88s4S+mSl88wlwxnQWSvoiiQqBYjUi1Wby7hm3Cymf7GJMXnd+fWpWkFXJNHpf7jstynz1nLji7OprKrmwXOHMHpIt7BLEpFGoACRqG2viKyg++QHyxncLYOHzzuEbK2gK5I0FCASlaWF27jquVnMX7OFi4/M4aaT+2sFXZEkowCRfTZpZgG3/XMuzZs24W/n53GCVtAVSUoKEKmzkh2V/OrleUycWcDw7PY8eN4QurTRCroiySrmA8TMRgEPAinA39z9rpBLSkrzV2/hqnEzWbahhJ8e34+fHtdXK+iKJLmYDhAzSwEeAb4NFACfmNlkd58fbmXJw9155sMv+O1rC2jbshnP/ngER/TRCroiEuMBAgwHlrj7UgAzex4YDShAGkFxaQU3Tsxnyrx1jOyfxX1n59JBK+iKSCDWA6QbsLLGzwXAiL3tsGjdVk64/z97Pai71/rAtW9R143qtll91VSHwwTHqn3DzaUVlJVXcespB3LJUTlaQVdEdhHrAVInZnYZcBlARtfe9O/Uug471csmdV7jqW7Hqp/jRI5V+5a1bdE0xfj+iF4M6dG2jo8qIskk1gNkFdCjxs/dg7ZduPtYYCxAXl6eP/KDQxqnOhGRJBbr02g+AfqZWY6ZNQfOBSaHXJOIiBDjPRB3rzSzq4ApRKbxPuHu80IuS0REiPEAAXD314HXw65DRER2FetDWCIiEqMUICIiEhUFiIiIREUBIiIiUVGAiIhIVKwuS2jEEzMrBhaHXUcCaQMUh11EgtBzWb/0fNavfu7eZl92iPlpvFF4wd0vC7uIRGFmY/V81g89l/VLz2f9MrOx+7pPIg5hvRJ2AQlGz2f90XNZv/R81q99fj4TbghLREQaRyL2QEREpBEoQEREJCpxFyBm5mb2jxo/NzWzQjN7Ncy64pmZnRY8rwPCriVe6XXZcMxsW9g1JJranlMze8fM8mo7TtwFCFACDDazlsHP32YP3xGyN2aWiLPP9sd5wPvBdZ0F31kvEfv9uhSJN/EYIBBZnfc7we3zgHE77zCz4Wb2PzObZWYfmFn/oP1CM5tsZm8B0xq/5NhkZunAUcAlRL5vBTMbaWbvmtlrZvaZmf2fmTUJ7ttmZveZWT5weHiVx6RoXpfvmtmQGtu9b2a5jVp1HAhek6/W+PlhM7swuL3czH5jZjPNbI560nWzt+e0ruI1QJ4HzjWzVOBg4KMa9y0Ejnb3ocCvgN/XuO8Q4Cx3/1ajVRr7RgNvuvsiYKOZDQvahwNXAwOBPsAZQXsa8JG757r7+41ebWyL5nX5OHAhgJkdAKS6e36jVZw4Nrj7IcCjwPVhF5Ms4jJA3H02kE3kXd7u3xXSBphgZnOBB4BBNe6b6u5FjVJk/DiPyB8+guudw1gfu/tSd68i8k76qKC9CpjYuCXGhyhflxOA75pZM+Bi4MlGKTbxTAquZxD5N5BGEM/nAiYD9wIjgQ412u8E3nb3080sG3inxn0ljVRbXDBkr2bRAAAC8klEQVSz9sBxwEFm5kS+9dGB14Lrmnb+vD0IFdmzfXpdunupmU0l0hMcAwxD9qSSXd/wpu52/47guor4/rvWmGp7TmsVlz2QwBPAb9x9zm7tbfjq5OWFjVpR/DkLeMbde7l7trv3AJYBRwPDg++ibwKcQ+Qku9Qumtfl34CHgE/cfVPDlhe3vgAGmlkLM2sLHB92QQlgv5/TuA0Qdy9w94f2cNc9wB/MbBZ6J1Kb84CXdmubGLR/AjwMLCASKrtvJ3sQzevS3WcAW4C/N0KJcSWYMbnD3VcC44G5wfWsUAuLY/X5nGopE/kaMxsJXO/u3w27lmRgZl2JDGkNcPfqkMuJKcGMtMfcfXjYtSSK+nxO47YHIpIIzOx8IrO1blV47MrMriAygeO2sGtJFPX9nKoHIiIiUVEPJMmYWQ8ze9vM5pvZPDO7Jmhvb2ZTzWxxcN0uaB8QfABuh5ldv9uxfhYcY66ZjQs+/yAiSUIBknwqgevcfSBwGPATMxsI3AxMc/d+RD6pf3OwfRHwUyJTU79kZt2C9jx3H0xkCvC5jfMriEgsUIAkGXdf4+4zg9tbicyy6kbkcwhPBZs9BZwWbLPe3T8BKvZwuKZAy2BWRytgdQOXLyIxRAGSxIIPtA0lchK3k7uvCe5aC3Ta277uvopIr2QFsAYodvd/NVixIhJzFCBJKlhEcSJwrbtvqXmfR2ZW7HV2RXCOZDSQA3QF0szshw1UrojEIAVIEgrWXZoIPOvuO9cQWmdmXYL7uwDraznMCcAydy909woiaxEd0VA1i0jsUYAkGTMzIivALnD3+2vcNRm4ILh9AfByLYdaARxmZq2CYx5P5HyKiCQJfQ4kyZjZUcB7wBxg5wfXbiFyHmQ80JPIGjlj3L3IzDoD04GMYPttwEB332JmvyGyTlYlkWUQfuzuOxCRpKAAERGRqGgIS0REoqIAERGRqChAREQkKgoQERGJigJERESiogAREZGoKEBERCQqChAREYnK/wcwy1NMaXXJfwAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_dates(df_user_item_train['event_dttm']).plot()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "2018-08-01    172049\n",
       "Name: event_dttm, dtype: int64"
      ]
     },
     "execution_count": 18,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "plot_dates(df_user_item_valid['event_dttm'])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.7333359165517135"
      ]
     },
     "execution_count": 19,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(df_user_item_train) / (len(df_user_item_train) + len(df_user_item_valid))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [],
   "source": [
    "df_user_item_train = df_user_item_train.sort_values('event_dttm')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [],
   "source": [
    "split_pos = int(len(df_user_item_train) * 0.75)\n",
    "df_user_item_train, df_user_item_test = df_user_item_train.iloc[:split_pos], df_user_item_train.iloc[split_pos:]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.axes._subplots.AxesSubplot at 0x7fa3b5d869b0>"
      ]
     },
     "execution_count": 22,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_dates(df_user_item_train['event_dttm']).plot()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "2018-07-01    118286\n",
       "Name: event_dttm, dtype: int64"
      ]
     },
     "execution_count": 23,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "plot_dates(df_user_item_test['event_dttm'])"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Пересечение train и test по просмотренным items"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "337245"
      ]
     },
     "execution_count": 24,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(df_user_item_train.groupby(['customer_id', 'story_id']).count())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "113391"
      ]
     },
     "execution_count": 25,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(df_user_item_test.groupby(['customer_id', 'story_id']).count())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "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></th>\n",
       "      <th>event_dttm_x</th>\n",
       "      <th>event_x</th>\n",
       "      <th>event_dttm_y</th>\n",
       "      <th>event_y</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>customer_id</th>\n",
       "      <th>story_id</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>521</th>\n",
       "      <th>1211</th>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1939</th>\n",
       "      <th>509</th>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2679</th>\n",
       "      <th>509</th>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2846</th>\n",
       "      <th>956</th>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3431</th>\n",
       "      <th>1312</th>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>974220</th>\n",
       "      <th>1245</th>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>975675</th>\n",
       "      <th>1286</th>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>979046</th>\n",
       "      <th>1224</th>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>980003</th>\n",
       "      <th>449</th>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>987293</th>\n",
       "      <th>509</th>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>3</td>\n",
       "      <td>3</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>834 rows × 4 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "                      event_dttm_x  event_x  event_dttm_y  event_y\n",
       "customer_id story_id                                              \n",
       "521         1211                 2        2             2        2\n",
       "1939        509                  1        1             1        1\n",
       "2679        509                  1        1             1        1\n",
       "2846        956                  1        1             1        1\n",
       "3431        1312                 1        1             1        1\n",
       "...                            ...      ...           ...      ...\n",
       "974220      1245                 1        1             1        1\n",
       "975675      1286                 1        1             1        1\n",
       "979046      1224                 1        1             1        1\n",
       "980003      449                  1        1             1        1\n",
       "987293      509                  1        1             3        3\n",
       "\n",
       "[834 rows x 4 columns]"
      ]
     },
     "execution_count": 26,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "pd.merge(\n",
    "    df_user_item_train.groupby(['customer_id', 'story_id']).count(),\n",
    "    df_user_item_test.groupby(['customer_id', 'story_id']).count(),\n",
    "    how='inner', left_index=True, right_index=True)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# transactions"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "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>transaction_month</th>\n",
       "      <th>transaction_day</th>\n",
       "      <th>transaction_amt</th>\n",
       "      <th>merchant_id</th>\n",
       "      <th>merchant_mcc</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>855115</td>\n",
       "      <td>7</td>\n",
       "      <td>3</td>\n",
       "      <td>1500</td>\n",
       "      <td>4554547</td>\n",
       "      <td>5411</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>997036</td>\n",
       "      <td>6</td>\n",
       "      <td>6</td>\n",
       "      <td>0</td>\n",
       "      <td>1657528</td>\n",
       "      <td>5411</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>398237</td>\n",
       "      <td>5</td>\n",
       "      <td>24</td>\n",
       "      <td>2500</td>\n",
       "      <td>26375569</td>\n",
       "      <td>5813</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>997036</td>\n",
       "      <td>6</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>16304402</td>\n",
       "      <td>5411</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>291636</td>\n",
       "      <td>7</td>\n",
       "      <td>25</td>\n",
       "      <td>0</td>\n",
       "      <td>1259505</td>\n",
       "      <td>5411</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "   customer_id  transaction_month  transaction_day  transaction_amt  \\\n",
       "0       855115                  7                3             1500   \n",
       "1       997036                  6                6                0   \n",
       "2       398237                  5               24             2500   \n",
       "3       997036                  6                2                0   \n",
       "4       291636                  7               25                0   \n",
       "\n",
       "   merchant_id  merchant_mcc  \n",
       "0      4554547          5411  \n",
       "1      1657528          5411  \n",
       "2     26375569          5813  \n",
       "3     16304402          5411  \n",
       "4      1259505          5411  "
      ]
     },
     "execution_count": 27,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_trans = pd.read_csv('transactions.csv')\n",
    "df_trans.head()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "46948"
      ]
     },
     "execution_count": 28,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_trans['customer_id'].nunique()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "a: 34379, b: 46948, c: 30795\n"
     ]
    }
   ],
   "source": [
    "pd_intersection(\n",
    "    df_user_item_train['customer_id'].unique().tolist(),\n",
    "    df_trans['customer_id'].unique().tolist(),\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "a: 17218, b: 46948, c: 15757\n"
     ]
    }
   ],
   "source": [
    "pd_intersection(\n",
    "    df_user_item_test['customer_id'].unique().tolist(),\n",
    "    df_trans['customer_id'].unique().tolist(),\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "a: 22646, b: 46948, c: 20053\n"
     ]
    }
   ],
   "source": [
    "pd_intersection(\n",
    "    df_user_item_valid['customer_id'].unique().tolist(),\n",
    "    df_trans['customer_id'].unique().tolist(),\n",
    ")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# stories_description"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "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>story_id</th>\n",
       "      <th>story_json</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>127</td>\n",
       "      <td>{\"guid\":\"770a5bae-0e3f-4a6b-b924-bd87bd51a038\"...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>254</td>\n",
       "      <td>{\"guid\":\"64f4c9ef-647b-4e04-b4d4-02297e939388\"...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>865</td>\n",
       "      <td>{\"guid\":\"3482206b-d223-4aec-92ba-0150055cd68a\"...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>1491</td>\n",
       "      <td>{\"guid\":\"5f4a9215-01de-4777-b70f-a18899db8f1c\"...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>598</td>\n",
       "      <td>{\"guid\":\"ed8754bd-67be-4fa1-9289-5508d96f1fa4\"...</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "   story_id                                         story_json\n",
       "0       127  {\"guid\":\"770a5bae-0e3f-4a6b-b924-bd87bd51a038\"...\n",
       "1       254  {\"guid\":\"64f4c9ef-647b-4e04-b4d4-02297e939388\"...\n",
       "2       865  {\"guid\":\"3482206b-d223-4aec-92ba-0150055cd68a\"...\n",
       "3      1491  {\"guid\":\"5f4a9215-01de-4777-b70f-a18899db8f1c\"...\n",
       "4       598  {\"guid\":\"ed8754bd-67be-4fa1-9289-5508d96f1fa4\"..."
      ]
     },
     "execution_count": 32,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_stories = pd.read_csv('stories_description.csv')\n",
    "df_stories.head()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Baseline"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 64,
   "metadata": {},
   "outputs": [],
   "source": [
    "from sklearn.metrics import roc_auc_score"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "df_event_weights = pd.Series({\n",
    "    'dislike': -10,\n",
    "    'skip': -0.1,\n",
    "    'view': 0.1,\n",
    "    'like': 0.5,\n",
    "})\n",
    "df_event_weights"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "def tinkoff_metric(df):\n",
    "    s_event_weights = df['event'].map(df_event_weights)\n",
    "    res = s_event_weights * df['score']\n",
    "    return res.mean().round(6), len(res)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "def tinkoff_metric_split(df):\n",
    "    df = df.copy()\n",
    "    df['cust_kind'] = df['customer_id'].isin(df_user_item_train['customer_id'].unique()) \\\n",
    "        .map({True: 'warm', False: 'cold'})\n",
    "    \n",
    "    return {\n",
    "        'all': tinkoff_metric(df),\n",
    "        'cold': tinkoff_metric(df[df['cust_kind'].eq('cold')]),\n",
    "        'warm': tinkoff_metric(df[df['cust_kind'].eq('warm')]),\n",
    "    }"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "def label_ranking_average_precision_score(df_scores):\n",
    "    df = pd.merge(df_scores, df_true.assign(hit=1), how='left', on=['user_id', 'item_id'])\n",
    "    df['hit'] = df['hit'].fillna(0)\n",
    "    df = df.sort_values(['user_id', 'relevance'], ascending=[True, False])\n",
    "\n",
    "    df['rank'] = df.groupby('user_id').cumcount() + 1\n",
    "    df['hit_count'] = df.groupby('user_id')['hit'].cumsum()\n",
    "    df['score'] = df['hit_count'] / df['rank']\n",
    "    df = df[df['hit'].eq(1)]\n",
    "\n",
    "    rank_hist = df.groupby('rank')['user_id'].count().sort_index()\n",
    "    total_rank_hist = rank_hist.sum()\n",
    "    show_pos = 5\n",
    "    info = ', '.join(\n",
    "        f'{x:.2f}' for x in [v / total_rank_hist for _, v in sorted(rank_hist.iloc[:show_pos].to_dict().items())] +\n",
    "        [rank_hist.iloc[show_pos:].sum() / total_rank_hist]\n",
    "    )\n",
    "    logger.info(f'rank_hist: [{info} ...] from {total_rank_hist}')\n",
    "\n",
    "    df = df.groupby('user_id')['score'].mean()\n",
    "\n",
    "    if not reduce:\n",
    "        return df\n",
    "    score = df.mean()\n",
    "    return float(score)\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Const"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "df_test_predict = df_user_item_test.copy()\n",
    "df_test_predict['score'] = -1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "tinkoff_metric_split(df_test_predict)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Polular prediction"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 429,
   "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",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>event</th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>dislike</th>\n",
       "      <td>0.014606</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>like</th>\n",
       "      <td>0.132426</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>skip</th>\n",
       "      <td>0.353203</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>view</th>\n",
       "      <td>0.499765</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "         customer_id\n",
       "event               \n",
       "dislike     0.014606\n",
       "like        0.132426\n",
       "skip        0.353203\n",
       "view        0.499765"
      ]
     },
     "execution_count": 429,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_user_item_train.groupby('event')[['customer_id']].count() / len(df_user_item_train)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 430,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "event\n",
       "dislike    0.068501\n",
       "like       0.252072\n",
       "skip       0.734780\n",
       "view       0.823032\n",
       "dtype: float64"
      ]
     },
     "execution_count": 430,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_user_item_train.pivot_table(\n",
    "    index='customer_id', columns='event',\n",
    "    values='story_id', aggfunc='count', fill_value=0).gt(0).mean()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 431,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "event\n",
       "dislike    0.533825\n",
       "like       0.674047\n",
       "skip       0.932349\n",
       "view       0.971710\n",
       "dtype: float64"
      ]
     },
     "execution_count": 431,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_user_item_train.pivot_table(\n",
    "    index='story_id', columns='event',\n",
    "    values='customer_id', aggfunc='count', fill_value=0).gt(0).mean()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 432,
   "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>event</th>\n",
       "      <th>dislike</th>\n",
       "      <th>like</th>\n",
       "      <th>skip</th>\n",
       "      <th>view</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>customer_id</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>15</th>\n",
       "      <td>0.0</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.411765</td>\n",
       "      <td>0.588235</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>73</th>\n",
       "      <td>0.0</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.846154</td>\n",
       "      <td>0.153846</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>129</th>\n",
       "      <td>0.0</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.562500</td>\n",
       "      <td>0.437500</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>144</th>\n",
       "      <td>0.0</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>1.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>150</th>\n",
       "      <td>0.0</td>\n",
       "      <td>0.333333</td>\n",
       "      <td>0.666667</td>\n",
       "      <td>0.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1095251</th>\n",
       "      <td>0.0</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>1.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1098683</th>\n",
       "      <td>0.0</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1099266</th>\n",
       "      <td>0.0</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.500000</td>\n",
       "      <td>0.500000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1099955</th>\n",
       "      <td>0.0</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>1.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1103495</th>\n",
       "      <td>0.0</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>1.000000</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>34379 rows × 4 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "event        dislike      like      skip      view\n",
       "customer_id                                       \n",
       "15               0.0  0.000000  0.411765  0.588235\n",
       "73               0.0  0.000000  0.846154  0.153846\n",
       "129              0.0  0.000000  0.562500  0.437500\n",
       "144              0.0  0.000000  0.000000  1.000000\n",
       "150              0.0  0.333333  0.666667  0.000000\n",
       "...              ...       ...       ...       ...\n",
       "1095251          0.0  0.000000  0.000000  1.000000\n",
       "1098683          0.0  0.000000  1.000000  0.000000\n",
       "1099266          0.0  0.000000  0.500000  0.500000\n",
       "1099955          0.0  0.000000  0.000000  1.000000\n",
       "1103495          0.0  0.000000  0.000000  1.000000\n",
       "\n",
       "[34379 rows x 4 columns]"
      ]
     },
     "execution_count": 432,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# fit users\n",
    "df_train_user_popularity = df_user_item_train.pivot_table(\n",
    "    index='customer_id', columns='event',\n",
    "    values='story_id', aggfunc='count', fill_value=0)\n",
    "\n",
    "df_train_user_popularity = df_train_user_popularity.div(df_train_user_popularity.sum(axis=1), axis=0)\n",
    "\n",
    "df_train_user_popularity"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 433,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 1152x216 with 4 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "_, axs = plt.subplots(1, 4, figsize=(16, 3), sharey=True)\n",
    "for col, ax in zip(['dislike', 'like', 'skip', 'view'], axs):\n",
    "    df_train_user_popularity[col].sort_values().reset_index(drop=True).plot(ax=ax, title=col)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 434,
   "metadata": {},
   "outputs": [],
   "source": [
    "df_event_scores = {\n",
    "    'dislike': -10,\n",
    "    'skip': -0.0,\n",
    "    'view': 0.0,\n",
    "    'like': 1.0,\n",
    "}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 435,
   "metadata": {},
   "outputs": [],
   "source": [
    "df_train_user_popularity_score += 0.01\n",
    "df_train_user_popularity_score = df_train_user_popularity.mul(df_event_scores)\n",
    "df_train_user_popularity = df_train_user_popularity.div(df_train_user_popularity.sum(axis=1), axis=0)\n",
    "df_train_user_popularity_score = df_train_user_popularity_score.sum(axis=1).rename('user_score')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 436,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.axes._subplots.AxesSubplot at 0x7fa3b4c6fa90>"
      ]
     },
     "execution_count": 436,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "df_train_user_popularity_score.sort_values().reset_index(drop=True).plot()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 437,
   "metadata": {},
   "outputs": [],
   "source": [
    "# fit items\n",
    "df_train_item_popularity = pd.merge(\n",
    "    df_user_item_train[lambda x: x['event'].isin(['dislike', 'like'])].assign(score=df_user_item_train['event'].map(df_event_scores)),\n",
    "    df_train_user_popularity_score,\n",
    "    left_on='customer_id', right_index=True,\n",
    ").assign(item_score=lambda x: x.score - x.user_score * 0.2) \\\n",
    "    .groupby('story_id')['item_score'].mean().sort_values()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 438,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.axes._subplots.AxesSubplot at 0x7fa28c505978>"
      ]
     },
     "execution_count": 438,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "df_train_item_popularity.reset_index(drop=True).plot()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 439,
   "metadata": {},
   "outputs": [],
   "source": [
    "# predict\n",
    "df_train_predict = pd.merge(\n",
    "    pd.merge(df_user_item_train, df_train_item_popularity,\n",
    "                           how='left', left_on='story_id', right_index=True).fillna(0.0),\n",
    "    df_train_user_popularity_score,\n",
    "    how='left', left_on='customer_id', right_index=True\n",
    ").fillna(0.0).assign(score=lambda x: x.item_score + x.user_score * 0.2)\n",
    "\n",
    "\n",
    "df_test_predict = pd.merge(\n",
    "    pd.merge(df_user_item_test, df_train_item_popularity,\n",
    "                           how='left', left_on='story_id', right_index=True).fillna(0.0),\n",
    "    df_train_user_popularity_score,\n",
    "    how='left', left_on='customer_id', right_index=True\n",
    ").fillna(0.0).assign(score=lambda x: x.item_score + x.user_score * 0.2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 440,
   "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>story_id</th>\n",
       "      <th>event_dttm</th>\n",
       "      <th>event</th>\n",
       "      <th>item_score</th>\n",
       "      <th>user_score</th>\n",
       "      <th>score</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>415192</th>\n",
       "      <td>843538</td>\n",
       "      <td>522</td>\n",
       "      <td>2018-03-29 11:30:44</td>\n",
       "      <td>skip</td>\n",
       "      <td>0.654819</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.654819</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>415188</th>\n",
       "      <td>843538</td>\n",
       "      <td>247</td>\n",
       "      <td>2018-03-29 11:30:44</td>\n",
       "      <td>view</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>376367</th>\n",
       "      <td>749436</td>\n",
       "      <td>498</td>\n",
       "      <td>2018-03-31 04:47:12</td>\n",
       "      <td>skip</td>\n",
       "      <td>0.404299</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.404299</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>415190</th>\n",
       "      <td>843538</td>\n",
       "      <td>428</td>\n",
       "      <td>2018-04-03 05:13:38</td>\n",
       "      <td>skip</td>\n",
       "      <td>0.213752</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.213752</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>415189</th>\n",
       "      <td>843538</td>\n",
       "      <td>419</td>\n",
       "      <td>2018-04-03 05:13:38</td>\n",
       "      <td>view</td>\n",
       "      <td>0.048392</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.048392</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",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>64049</th>\n",
       "      <td>132061</td>\n",
       "      <td>314</td>\n",
       "      <td>2018-07-15 11:49:52</td>\n",
       "      <td>dislike</td>\n",
       "      <td>-3.259131</td>\n",
       "      <td>-2.0</td>\n",
       "      <td>-3.659131</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>205344</th>\n",
       "      <td>387489</td>\n",
       "      <td>745</td>\n",
       "      <td>2018-07-15 11:52:38</td>\n",
       "      <td>view</td>\n",
       "      <td>-0.030452</td>\n",
       "      <td>0.0</td>\n",
       "      <td>-0.030452</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>205345</th>\n",
       "      <td>387489</td>\n",
       "      <td>997</td>\n",
       "      <td>2018-07-15 11:52:38</td>\n",
       "      <td>view</td>\n",
       "      <td>-0.957005</td>\n",
       "      <td>0.0</td>\n",
       "      <td>-0.957005</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>219993</th>\n",
       "      <td>414840</td>\n",
       "      <td>1000083</td>\n",
       "      <td>2018-07-15 11:53:04</td>\n",
       "      <td>view</td>\n",
       "      <td>1.045135</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.045135</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>219955</th>\n",
       "      <td>414840</td>\n",
       "      <td>1295</td>\n",
       "      <td>2018-07-15 11:53:04</td>\n",
       "      <td>skip</td>\n",
       "      <td>-0.846657</td>\n",
       "      <td>0.0</td>\n",
       "      <td>-0.846657</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>354855 rows × 7 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "        customer_id  story_id          event_dttm    event  item_score  \\\n",
       "415192       843538       522 2018-03-29 11:30:44     skip    0.654819   \n",
       "415188       843538       247 2018-03-29 11:30:44     view    0.000000   \n",
       "376367       749436       498 2018-03-31 04:47:12     skip    0.404299   \n",
       "415190       843538       428 2018-04-03 05:13:38     skip    0.213752   \n",
       "415189       843538       419 2018-04-03 05:13:38     view    0.048392   \n",
       "...             ...       ...                 ...      ...         ...   \n",
       "64049        132061       314 2018-07-15 11:49:52  dislike   -3.259131   \n",
       "205344       387489       745 2018-07-15 11:52:38     view   -0.030452   \n",
       "205345       387489       997 2018-07-15 11:52:38     view   -0.957005   \n",
       "219993       414840   1000083 2018-07-15 11:53:04     view    1.045135   \n",
       "219955       414840      1295 2018-07-15 11:53:04     skip   -0.846657   \n",
       "\n",
       "        user_score     score  \n",
       "415192         0.0  0.654819  \n",
       "415188         0.0  0.000000  \n",
       "376367         0.0  0.404299  \n",
       "415190         0.0  0.213752  \n",
       "415189         0.0  0.048392  \n",
       "...            ...       ...  \n",
       "64049         -2.0 -3.659131  \n",
       "205344         0.0 -0.030452  \n",
       "205345         0.0 -0.957005  \n",
       "219993         0.0  1.045135  \n",
       "219955         0.0 -0.846657  \n",
       "\n",
       "[354855 rows x 7 columns]"
      ]
     },
     "execution_count": 440,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_train_predict"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 441,
   "metadata": {},
   "outputs": [],
   "source": [
    "def rocauc_by_cust(df):\n",
    "    df = df.copy()\n",
    "    df = df[df['event'].isin(['dislike', 'like'])]\n",
    "    df['event'] = df['event'].map({'dislike': 0, 'like': 1})\n",
    "\n",
    "    res = df.groupby('customer_id').apply(lambda x: roc_auc_score(x['event'], x['score'])\n",
    "                                          if x['event'].nunique() > 1 else np.NaN)\n",
    "    return res    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 442,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.7139289310613818"
      ]
     },
     "execution_count": 442,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "rocauc_by_cust(df_train_predict).mean()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 443,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.7204284251205677"
      ]
     },
     "execution_count": 443,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "rocauc_by_cust(df_test_predict).mean()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "0.7204284251205677"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 444,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.7192049210481039"
      ]
     },
     "execution_count": 444,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "rocauc_by_cust(df_test_predict[lambda x: x.customer_id.isin(df_train_predict.customer_id)]).mean()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "0.7192049210481039"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 445,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.7312056737588652"
      ]
     },
     "execution_count": 445,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "rocauc_by_cust(df_test_predict[lambda x: ~x.customer_id.isin(df_train_predict.customer_id)]).mean()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "0.7312056737588652"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# ALS"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 395,
   "metadata": {},
   "outputs": [],
   "source": [
    "import implicit\n",
    "import scipy.sparse\n",
    "from tqdm.autonotebook import tqdm"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 396,
   "metadata": {},
   "outputs": [],
   "source": [
    "from functools import reduce"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 397,
   "metadata": {},
   "outputs": [],
   "source": [
    "class ALSModel:\n",
    "    def __init__(self, factors, weights):\n",
    "        if 'OPENBLAS_NUM_THREADS' not in os.environ:\n",
    "            os.environ['OPENBLAS_NUM_THREADS'] = '1'\n",
    "        \n",
    "        self.model = implicit.als.AlternatingLeastSquares(factors=factors)\n",
    "        self.weights = weights\n",
    "\n",
    "        self.df_item_freq = None\n",
    "        self.item_index = None\n",
    "        self.user_index = None\n",
    "        \n",
    "        self.item_map = None\n",
    "        self.user_map = None\n",
    "\n",
    "    def get_item_user_matrix(self, df_log):\n",
    "        df = df_log.copy()\n",
    "\n",
    "        df = df.assign(score=df_user_item_train['event'].map(self.weights))\n",
    "        df = pd.merge(\n",
    "            df,\n",
    "            df_train_user_popularity_score,\n",
    "            left_on='customer_id', right_index=True,\n",
    "        )\n",
    "        df = pd.merge(\n",
    "            df,\n",
    "            df_train_item_popularity,\n",
    "            left_on='story_id', right_index=True,\n",
    "        )\n",
    "        df = df.assign(relevance=lambda x: x.score - x.user_score * 0.2 - x.item_score * 1.0)\n",
    "        \n",
    "        df = df.groupby(['customer_id', 'story_id'])[['relevance']].mean().reset_index()\n",
    "        df['customer_id'] = df['customer_id'].map(self.user_map)\n",
    "        df['story_id'] = df['story_id'].map(self.item_map)\n",
    "        \n",
    "        df = df[~df.isna().any(axis=1)]\n",
    "        \n",
    "        return scipy.sparse.csr_matrix((df['relevance'],\n",
    "                                        (df['story_id'],\n",
    "                                         df['customer_id']),\n",
    "                                        ),\n",
    "                                       shape=(len(self.item_index), len(self.user_index)))\n",
    "\n",
    "    def model_train(self, df_log):\n",
    "        self.item_index = df_log['story_id'].unique()\n",
    "        self.user_index = df_log['customer_id'].unique()\n",
    "        self.item_map = {k: v for v, k in enumerate(self.item_index)}\n",
    "        self.user_map = {k: v for v, k in enumerate(self.user_index)}\n",
    "\n",
    "        item_user_data = self.get_item_user_matrix(df_log)\n",
    "        print(f'item_user_data matrix of type {type(item_user_data)} with shape: {item_user_data.shape}')\n",
    "        self.model.fit(item_user_data)\n",
    "\n",
    "    def model_predict(self, df_log_exclude, df_log_predict):\n",
    "        user_item_data = self.get_item_user_matrix(df_log_exclude).T.tocsr()\n",
    "\n",
    "        predicted_rows = []\n",
    "\n",
    "        for_predict = df_log_predict.groupby('customer_id')['story_id'].apply(np.array)\n",
    "        for user_id, item_list in tqdm(for_predict.items(), total=len(for_predict), desc='Predict'):\n",
    "            user_ix = self.user_map.get(user_id, -1)\n",
    "            if user_ix == -1:\n",
    "                for item_id in item_list:\n",
    "                    predicted_rows.append((user_id, item_id, 0.0))\n",
    "            else:\n",
    "                item_ix = [self.item_map.get(item_id) for item_id in item_list if item_id in self.item_map]\n",
    "                if len(item_ix) > 0:\n",
    "                    als_predict = self.model.rank_items(user_ix, user_item_data, item_ix)\n",
    "                    for item_id, score in als_predict:\n",
    "                        predicted_rows.append((user_id, self.item_index[item_id], score))\n",
    "                for item_id in [item_id for item_id in item_list if item_id not in self.item_map]:\n",
    "                    predicted_rows.append((user_id, item_id, 0.0))\n",
    "\n",
    "        predicted_rows = pd.DataFrame(predicted_rows, columns=['customer_id', 'story_id', 'relevance'])\n",
    "        predicted_rows = predicted_rows.groupby(['customer_id', 'story_id'])['relevance'].max().reset_index()\n",
    "        predicted = pd.merge(\n",
    "            df_log_predict,\n",
    "            predicted_rows,\n",
    "            how='inner', on=['customer_id', 'story_id'],\n",
    "        )\n",
    "        predicted = pd.merge(\n",
    "            predicted,\n",
    "            df_train_user_popularity_score,\n",
    "            how='left', left_on='customer_id', right_index=True,\n",
    "        )\n",
    "        predicted['user_score'] = predicted['user_score'].fillna(0)\n",
    "        predicted = pd.merge(\n",
    "            predicted,\n",
    "            df_train_item_popularity,\n",
    "            how='left', left_on='story_id', right_index=True,\n",
    "        )\n",
    "        predicted['item_score'] = predicted['item_score'].fillna(0)\n",
    "                \n",
    "        predicted['score'] = predicted['relevance'] + predicted['user_score'] * 0.2 + predicted['item_score'] * 1.0\n",
    "\n",
    "        return predicted\n",
    "\n",
    "    def model_predict_top_k(\n",
    "            self,\n",
    "            df_log_exclude,\n",
    "            id_users, id_items,\n",
    "            k,\n",
    "    ):\n",
    "        raise NotImplementedError()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 471,
   "metadata": {},
   "outputs": [],
   "source": [
    "model_dl = ALSModel(factors=32, weights={\n",
    "            'dislike': -10,\n",
    "            'skip': 0,\n",
    "            'view': 0,\n",
    "            'like': 1,\n",
    "        })"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 472,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "item_user_data matrix of type <class 'scipy.sparse.csr.csr_matrix'> with shape: (550, 9345)\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "72e60a7e400041e0a67c4804c03f7256",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=15), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "model_dl.model_train(df_user_item_train[lambda x: x['event'].isin(['dislike', 'like'])])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 473,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "9b0ff8e5537b4dda8412caf41ffba013",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, description='Predict', max=34379, style=ProgressStyle(description_width='i…"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "df_train_predict = model_dl.model_predict(df_user_item_train, df_user_item_train)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 474,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "48cf419d1daa4d198dee7850d5880c22",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, description='Predict', max=17218, style=ProgressStyle(description_width='i…"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "df_test_predict = model_dl.model_predict(df_user_item_train, df_user_item_test)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 475,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.8972992691893553"
      ]
     },
     "execution_count": 475,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "rocauc_by_cust(df_train_predict).mean()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 476,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.7247960248276645"
      ]
     },
     "execution_count": 476,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "rocauc_by_cust(df_test_predict).mean()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "0.7277967254716805"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 477,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.7240683593692914"
      ]
     },
     "execution_count": 477,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "rocauc_by_cust(df_test_predict[lambda x: x.customer_id.isin(df_train_predict.customer_id)]).mean()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "0.7274097192651643\n",
    "\n",
    "0.7192049210481039 - popularity only (warm)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 478,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.7312056737588652"
      ]
     },
     "execution_count": 478,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "rocauc_by_cust(df_test_predict[lambda x: ~x.customer_id.isin(df_train_predict.customer_id)]).mean()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "0.7312056737588652"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 483,
   "metadata": {
    "scrolled": true
   },
   "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>story_id</th>\n",
       "      <th>event_dttm</th>\n",
       "      <th>event</th>\n",
       "      <th>relevance</th>\n",
       "      <th>user_score</th>\n",
       "      <th>item_score</th>\n",
       "      <th>score</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>19653</th>\n",
       "      <td>847035</td>\n",
       "      <td>314</td>\n",
       "      <td>2018-07-21 04:02:41</td>\n",
       "      <td>like</td>\n",
       "      <td>-0.078</td>\n",
       "      <td>0.479</td>\n",
       "      <td>-3.259</td>\n",
       "      <td>-3.241</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>23636</th>\n",
       "      <td>349825</td>\n",
       "      <td>420</td>\n",
       "      <td>2018-07-18 15:38:08</td>\n",
       "      <td>dislike</td>\n",
       "      <td>-0.001</td>\n",
       "      <td>0.200</td>\n",
       "      <td>-2.931</td>\n",
       "      <td>-2.892</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>17090</th>\n",
       "      <td>777930</td>\n",
       "      <td>1311</td>\n",
       "      <td>2018-07-17 17:12:56</td>\n",
       "      <td>dislike</td>\n",
       "      <td>0.015</td>\n",
       "      <td>-1.048</td>\n",
       "      <td>-2.295</td>\n",
       "      <td>-2.489</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8644</th>\n",
       "      <td>504884</td>\n",
       "      <td>1311</td>\n",
       "      <td>2018-07-16 15:07:36</td>\n",
       "      <td>like</td>\n",
       "      <td>0.031</td>\n",
       "      <td>-0.154</td>\n",
       "      <td>-2.295</td>\n",
       "      <td>-2.295</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>10765</th>\n",
       "      <td>374677</td>\n",
       "      <td>1311</td>\n",
       "      <td>2018-07-17 01:18:21</td>\n",
       "      <td>like</td>\n",
       "      <td>0.000</td>\n",
       "      <td>0.000</td>\n",
       "      <td>-2.295</td>\n",
       "      <td>-2.295</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7217</th>\n",
       "      <td>788612</td>\n",
       "      <td>1311</td>\n",
       "      <td>2018-07-16 11:34:08</td>\n",
       "      <td>like</td>\n",
       "      <td>0.000</td>\n",
       "      <td>0.000</td>\n",
       "      <td>-2.295</td>\n",
       "      <td>-2.295</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>50234</th>\n",
       "      <td>293291</td>\n",
       "      <td>1311</td>\n",
       "      <td>2018-07-22 13:05:14</td>\n",
       "      <td>like</td>\n",
       "      <td>0.008</td>\n",
       "      <td>0.120</td>\n",
       "      <td>-2.295</td>\n",
       "      <td>-2.263</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>33491</th>\n",
       "      <td>270383</td>\n",
       "      <td>602</td>\n",
       "      <td>2018-07-20 09:49:20</td>\n",
       "      <td>like</td>\n",
       "      <td>0.134</td>\n",
       "      <td>0.464</td>\n",
       "      <td>-1.073</td>\n",
       "      <td>-0.846</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>79326</th>\n",
       "      <td>197917</td>\n",
       "      <td>409</td>\n",
       "      <td>2018-07-26 12:46:20</td>\n",
       "      <td>like</td>\n",
       "      <td>-0.004</td>\n",
       "      <td>0.200</td>\n",
       "      <td>-0.758</td>\n",
       "      <td>-0.721</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4014</th>\n",
       "      <td>410839</td>\n",
       "      <td>1314</td>\n",
       "      <td>2018-07-16 04:18:40</td>\n",
       "      <td>like</td>\n",
       "      <td>-0.342</td>\n",
       "      <td>-0.184</td>\n",
       "      <td>-0.146</td>\n",
       "      <td>-0.525</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>44979</th>\n",
       "      <td>215184</td>\n",
       "      <td>540</td>\n",
       "      <td>2018-07-22 04:31:55</td>\n",
       "      <td>like</td>\n",
       "      <td>0.000</td>\n",
       "      <td>0.000</td>\n",
       "      <td>-0.486</td>\n",
       "      <td>-0.486</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>29376</th>\n",
       "      <td>483135</td>\n",
       "      <td>1004</td>\n",
       "      <td>2018-07-19 14:47:42</td>\n",
       "      <td>like</td>\n",
       "      <td>-0.030</td>\n",
       "      <td>0.550</td>\n",
       "      <td>-0.506</td>\n",
       "      <td>-0.426</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>25147</th>\n",
       "      <td>13614</td>\n",
       "      <td>1339</td>\n",
       "      <td>2018-07-19 01:30:56</td>\n",
       "      <td>dislike</td>\n",
       "      <td>0.000</td>\n",
       "      <td>-1.993</td>\n",
       "      <td>0.000</td>\n",
       "      <td>-0.399</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>27370</th>\n",
       "      <td>38460</td>\n",
       "      <td>1318</td>\n",
       "      <td>2018-07-19 07:51:17</td>\n",
       "      <td>like</td>\n",
       "      <td>0.000</td>\n",
       "      <td>-0.607</td>\n",
       "      <td>0.000</td>\n",
       "      <td>-0.121</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>39107</th>\n",
       "      <td>521264</td>\n",
       "      <td>1296</td>\n",
       "      <td>2018-07-21 07:03:07</td>\n",
       "      <td>like</td>\n",
       "      <td>0.000</td>\n",
       "      <td>-0.462</td>\n",
       "      <td>0.000</td>\n",
       "      <td>-0.092</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>22300</th>\n",
       "      <td>117167</td>\n",
       "      <td>1318</td>\n",
       "      <td>2018-07-18 11:16:56</td>\n",
       "      <td>like</td>\n",
       "      <td>0.000</td>\n",
       "      <td>0.000</td>\n",
       "      <td>0.000</td>\n",
       "      <td>0.000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>49957</th>\n",
       "      <td>927968</td>\n",
       "      <td>1359</td>\n",
       "      <td>2018-07-22 15:46:21</td>\n",
       "      <td>like</td>\n",
       "      <td>0.000</td>\n",
       "      <td>0.038</td>\n",
       "      <td>0.000</td>\n",
       "      <td>0.008</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>44438</th>\n",
       "      <td>119639</td>\n",
       "      <td>1320</td>\n",
       "      <td>2018-07-22 03:08:56</td>\n",
       "      <td>like</td>\n",
       "      <td>0.000</td>\n",
       "      <td>0.131</td>\n",
       "      <td>0.000</td>\n",
       "      <td>0.026</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>25396</th>\n",
       "      <td>781720</td>\n",
       "      <td>1339</td>\n",
       "      <td>2018-07-19 02:32:17</td>\n",
       "      <td>like</td>\n",
       "      <td>0.000</td>\n",
       "      <td>0.251</td>\n",
       "      <td>0.000</td>\n",
       "      <td>0.050</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>68625</th>\n",
       "      <td>277843</td>\n",
       "      <td>1344</td>\n",
       "      <td>2018-07-25 03:04:49</td>\n",
       "      <td>like</td>\n",
       "      <td>0.000</td>\n",
       "      <td>0.286</td>\n",
       "      <td>0.000</td>\n",
       "      <td>0.057</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>53315</th>\n",
       "      <td>859027</td>\n",
       "      <td>912</td>\n",
       "      <td>2018-07-23 02:32:12</td>\n",
       "      <td>like</td>\n",
       "      <td>-0.022</td>\n",
       "      <td>0.400</td>\n",
       "      <td>0.009</td>\n",
       "      <td>0.067</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>38507</th>\n",
       "      <td>455779</td>\n",
       "      <td>1336</td>\n",
       "      <td>2018-07-21 05:42:02</td>\n",
       "      <td>like</td>\n",
       "      <td>0.000</td>\n",
       "      <td>0.419</td>\n",
       "      <td>0.000</td>\n",
       "      <td>0.084</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>19689</th>\n",
       "      <td>597700</td>\n",
       "      <td>1296</td>\n",
       "      <td>2018-07-18 05:08:22</td>\n",
       "      <td>like</td>\n",
       "      <td>0.000</td>\n",
       "      <td>0.482</td>\n",
       "      <td>0.000</td>\n",
       "      <td>0.096</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>21075</th>\n",
       "      <td>832007</td>\n",
       "      <td>1316</td>\n",
       "      <td>2018-07-18 08:18:35</td>\n",
       "      <td>like</td>\n",
       "      <td>0.000</td>\n",
       "      <td>0.500</td>\n",
       "      <td>0.000</td>\n",
       "      <td>0.100</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>105408</th>\n",
       "      <td>800954</td>\n",
       "      <td>1271</td>\n",
       "      <td>2018-07-30 06:11:27</td>\n",
       "      <td>like</td>\n",
       "      <td>0.000</td>\n",
       "      <td>0.627</td>\n",
       "      <td>0.000</td>\n",
       "      <td>0.125</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9804</th>\n",
       "      <td>257212</td>\n",
       "      <td>1316</td>\n",
       "      <td>2018-07-16 17:52:20</td>\n",
       "      <td>like</td>\n",
       "      <td>0.000</td>\n",
       "      <td>0.661</td>\n",
       "      <td>0.000</td>\n",
       "      <td>0.132</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>45125</th>\n",
       "      <td>118351</td>\n",
       "      <td>1321</td>\n",
       "      <td>2018-07-22 04:49:30</td>\n",
       "      <td>like</td>\n",
       "      <td>0.000</td>\n",
       "      <td>0.746</td>\n",
       "      <td>0.000</td>\n",
       "      <td>0.149</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>18915</th>\n",
       "      <td>35263</td>\n",
       "      <td>1293</td>\n",
       "      <td>2018-07-18 03:23:55</td>\n",
       "      <td>like</td>\n",
       "      <td>0.005</td>\n",
       "      <td>0.116</td>\n",
       "      <td>0.281</td>\n",
       "      <td>0.309</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>14790</th>\n",
       "      <td>29579</td>\n",
       "      <td>1057</td>\n",
       "      <td>2018-07-17 10:48:40</td>\n",
       "      <td>like</td>\n",
       "      <td>0.023</td>\n",
       "      <td>0.364</td>\n",
       "      <td>0.336</td>\n",
       "      <td>0.431</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7544</th>\n",
       "      <td>202622</td>\n",
       "      <td>379</td>\n",
       "      <td>2018-07-16 12:25:57</td>\n",
       "      <td>like</td>\n",
       "      <td>-0.000</td>\n",
       "      <td>0.182</td>\n",
       "      <td>0.399</td>\n",
       "      <td>0.435</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6676</th>\n",
       "      <td>396654</td>\n",
       "      <td>1272</td>\n",
       "      <td>2018-07-16 10:08:52</td>\n",
       "      <td>like</td>\n",
       "      <td>-0.012</td>\n",
       "      <td>0.125</td>\n",
       "      <td>0.513</td>\n",
       "      <td>0.525</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>39254</th>\n",
       "      <td>751999</td>\n",
       "      <td>1264</td>\n",
       "      <td>2018-07-21 07:37:39</td>\n",
       "      <td>like</td>\n",
       "      <td>-0.001</td>\n",
       "      <td>0.167</td>\n",
       "      <td>0.507</td>\n",
       "      <td>0.540</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>27031</th>\n",
       "      <td>751376</td>\n",
       "      <td>1151</td>\n",
       "      <td>2018-07-19 07:00:59</td>\n",
       "      <td>like</td>\n",
       "      <td>0.011</td>\n",
       "      <td>0.667</td>\n",
       "      <td>0.398</td>\n",
       "      <td>0.542</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>10487</th>\n",
       "      <td>20737</td>\n",
       "      <td>1247</td>\n",
       "      <td>2018-07-17 00:10:36</td>\n",
       "      <td>like</td>\n",
       "      <td>0.005</td>\n",
       "      <td>0.143</td>\n",
       "      <td>0.537</td>\n",
       "      <td>0.571</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>50566</th>\n",
       "      <td>718676</td>\n",
       "      <td>1293</td>\n",
       "      <td>2018-07-22 13:53:39</td>\n",
       "      <td>like</td>\n",
       "      <td>0.129</td>\n",
       "      <td>1.000</td>\n",
       "      <td>0.281</td>\n",
       "      <td>0.609</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>25095</th>\n",
       "      <td>574756</td>\n",
       "      <td>1298</td>\n",
       "      <td>2018-07-19 01:04:25</td>\n",
       "      <td>like</td>\n",
       "      <td>0.054</td>\n",
       "      <td>0.477</td>\n",
       "      <td>0.464</td>\n",
       "      <td>0.614</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>37008</th>\n",
       "      <td>589058</td>\n",
       "      <td>1261</td>\n",
       "      <td>2018-07-21 02:04:42</td>\n",
       "      <td>like</td>\n",
       "      <td>-0.091</td>\n",
       "      <td>0.606</td>\n",
       "      <td>0.598</td>\n",
       "      <td>0.628</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>94977</th>\n",
       "      <td>533005</td>\n",
       "      <td>1247</td>\n",
       "      <td>2018-07-28 16:37:48</td>\n",
       "      <td>like</td>\n",
       "      <td>0.111</td>\n",
       "      <td>0.425</td>\n",
       "      <td>0.537</td>\n",
       "      <td>0.733</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>42184</th>\n",
       "      <td>412465</td>\n",
       "      <td>1236</td>\n",
       "      <td>2018-07-22 08:38:33</td>\n",
       "      <td>like</td>\n",
       "      <td>0.030</td>\n",
       "      <td>-0.227</td>\n",
       "      <td>1.052</td>\n",
       "      <td>1.036</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9641</th>\n",
       "      <td>567554</td>\n",
       "      <td>419</td>\n",
       "      <td>2018-07-16 17:32:01</td>\n",
       "      <td>like</td>\n",
       "      <td>0.989</td>\n",
       "      <td>0.400</td>\n",
       "      <td>0.048</td>\n",
       "      <td>1.117</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "        customer_id  story_id          event_dttm    event  relevance  \\\n",
       "19653        847035       314 2018-07-21 04:02:41     like     -0.078   \n",
       "23636        349825       420 2018-07-18 15:38:08  dislike     -0.001   \n",
       "17090        777930      1311 2018-07-17 17:12:56  dislike      0.015   \n",
       "8644         504884      1311 2018-07-16 15:07:36     like      0.031   \n",
       "10765        374677      1311 2018-07-17 01:18:21     like      0.000   \n",
       "7217         788612      1311 2018-07-16 11:34:08     like      0.000   \n",
       "50234        293291      1311 2018-07-22 13:05:14     like      0.008   \n",
       "33491        270383       602 2018-07-20 09:49:20     like      0.134   \n",
       "79326        197917       409 2018-07-26 12:46:20     like     -0.004   \n",
       "4014         410839      1314 2018-07-16 04:18:40     like     -0.342   \n",
       "44979        215184       540 2018-07-22 04:31:55     like      0.000   \n",
       "29376        483135      1004 2018-07-19 14:47:42     like     -0.030   \n",
       "25147         13614      1339 2018-07-19 01:30:56  dislike      0.000   \n",
       "27370         38460      1318 2018-07-19 07:51:17     like      0.000   \n",
       "39107        521264      1296 2018-07-21 07:03:07     like      0.000   \n",
       "22300        117167      1318 2018-07-18 11:16:56     like      0.000   \n",
       "49957        927968      1359 2018-07-22 15:46:21     like      0.000   \n",
       "44438        119639      1320 2018-07-22 03:08:56     like      0.000   \n",
       "25396        781720      1339 2018-07-19 02:32:17     like      0.000   \n",
       "68625        277843      1344 2018-07-25 03:04:49     like      0.000   \n",
       "53315        859027       912 2018-07-23 02:32:12     like     -0.022   \n",
       "38507        455779      1336 2018-07-21 05:42:02     like      0.000   \n",
       "19689        597700      1296 2018-07-18 05:08:22     like      0.000   \n",
       "21075        832007      1316 2018-07-18 08:18:35     like      0.000   \n",
       "105408       800954      1271 2018-07-30 06:11:27     like      0.000   \n",
       "9804         257212      1316 2018-07-16 17:52:20     like      0.000   \n",
       "45125        118351      1321 2018-07-22 04:49:30     like      0.000   \n",
       "18915         35263      1293 2018-07-18 03:23:55     like      0.005   \n",
       "14790         29579      1057 2018-07-17 10:48:40     like      0.023   \n",
       "7544         202622       379 2018-07-16 12:25:57     like     -0.000   \n",
       "6676         396654      1272 2018-07-16 10:08:52     like     -0.012   \n",
       "39254        751999      1264 2018-07-21 07:37:39     like     -0.001   \n",
       "27031        751376      1151 2018-07-19 07:00:59     like      0.011   \n",
       "10487         20737      1247 2018-07-17 00:10:36     like      0.005   \n",
       "50566        718676      1293 2018-07-22 13:53:39     like      0.129   \n",
       "25095        574756      1298 2018-07-19 01:04:25     like      0.054   \n",
       "37008        589058      1261 2018-07-21 02:04:42     like     -0.091   \n",
       "94977        533005      1247 2018-07-28 16:37:48     like      0.111   \n",
       "42184        412465      1236 2018-07-22 08:38:33     like      0.030   \n",
       "9641         567554       419 2018-07-16 17:32:01     like      0.989   \n",
       "\n",
       "        user_score  item_score  score  \n",
       "19653        0.479      -3.259 -3.241  \n",
       "23636        0.200      -2.931 -2.892  \n",
       "17090       -1.048      -2.295 -2.489  \n",
       "8644        -0.154      -2.295 -2.295  \n",
       "10765        0.000      -2.295 -2.295  \n",
       "7217         0.000      -2.295 -2.295  \n",
       "50234        0.120      -2.295 -2.263  \n",
       "33491        0.464      -1.073 -0.846  \n",
       "79326        0.200      -0.758 -0.721  \n",
       "4014        -0.184      -0.146 -0.525  \n",
       "44979        0.000      -0.486 -0.486  \n",
       "29376        0.550      -0.506 -0.426  \n",
       "25147       -1.993       0.000 -0.399  \n",
       "27370       -0.607       0.000 -0.121  \n",
       "39107       -0.462       0.000 -0.092  \n",
       "22300        0.000       0.000  0.000  \n",
       "49957        0.038       0.000  0.008  \n",
       "44438        0.131       0.000  0.026  \n",
       "25396        0.251       0.000  0.050  \n",
       "68625        0.286       0.000  0.057  \n",
       "53315        0.400       0.009  0.067  \n",
       "38507        0.419       0.000  0.084  \n",
       "19689        0.482       0.000  0.096  \n",
       "21075        0.500       0.000  0.100  \n",
       "105408       0.627       0.000  0.125  \n",
       "9804         0.661       0.000  0.132  \n",
       "45125        0.746       0.000  0.149  \n",
       "18915        0.116       0.281  0.309  \n",
       "14790        0.364       0.336  0.431  \n",
       "7544         0.182       0.399  0.435  \n",
       "6676         0.125       0.513  0.525  \n",
       "39254        0.167       0.507  0.540  \n",
       "27031        0.667       0.398  0.542  \n",
       "10487        0.143       0.537  0.571  \n",
       "50566        1.000       0.281  0.609  \n",
       "25095        0.477       0.464  0.614  \n",
       "37008        0.606       0.598  0.628  \n",
       "94977        0.425       0.537  0.733  \n",
       "42184       -0.227       1.052  1.036  \n",
       "9641         0.400       0.048  1.117  "
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "with pd.option_context('display.float_format', '{:.3f}'.format):\n",
    "    display(df_test_predict\n",
    "            [lambda x: x.customer_id.isin(df_train_predict.customer_id)]\n",
    "            [lambda x: x['event'].isin(['dislike', 'like'])]\n",
    "            .sample(n=40).sort_values('score')\n",
    "           )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 492,
   "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>story_id</th>\n",
       "      <th>event_dttm</th>\n",
       "      <th>event</th>\n",
       "      <th>relevance</th>\n",
       "      <th>user_score</th>\n",
       "      <th>item_score</th>\n",
       "      <th>score</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>345347</th>\n",
       "      <td>12513</td>\n",
       "      <td>1311</td>\n",
       "      <td>2018-07-14 10:36:53</td>\n",
       "      <td>dislike</td>\n",
       "      <td>-0.013</td>\n",
       "      <td>-0.926</td>\n",
       "      <td>-2.295</td>\n",
       "      <td>-2.493</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>345742</th>\n",
       "      <td>644459</td>\n",
       "      <td>1311</td>\n",
       "      <td>2018-07-15 04:36:56</td>\n",
       "      <td>dislike</td>\n",
       "      <td>-0.011</td>\n",
       "      <td>-0.871</td>\n",
       "      <td>-2.295</td>\n",
       "      <td>-2.480</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>347971</th>\n",
       "      <td>814964</td>\n",
       "      <td>1311</td>\n",
       "      <td>2018-07-14 10:27:18</td>\n",
       "      <td>dislike</td>\n",
       "      <td>-0.003</td>\n",
       "      <td>-0.686</td>\n",
       "      <td>-2.295</td>\n",
       "      <td>-2.435</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>346132</th>\n",
       "      <td>334332</td>\n",
       "      <td>1311</td>\n",
       "      <td>2018-07-14 06:04:08</td>\n",
       "      <td>dislike</td>\n",
       "      <td>-0.006</td>\n",
       "      <td>-0.438</td>\n",
       "      <td>-2.295</td>\n",
       "      <td>-2.388</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>345839</th>\n",
       "      <td>254463</td>\n",
       "      <td>1311</td>\n",
       "      <td>2018-07-14 05:27:28</td>\n",
       "      <td>dislike</td>\n",
       "      <td>-0.000</td>\n",
       "      <td>-0.211</td>\n",
       "      <td>-2.295</td>\n",
       "      <td>-2.337</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>349989</th>\n",
       "      <td>579260</td>\n",
       "      <td>1311</td>\n",
       "      <td>2018-07-14 15:46:54</td>\n",
       "      <td>dislike</td>\n",
       "      <td>0.001</td>\n",
       "      <td>-0.129</td>\n",
       "      <td>-2.295</td>\n",
       "      <td>-2.319</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>348945</th>\n",
       "      <td>774872</td>\n",
       "      <td>1311</td>\n",
       "      <td>2018-07-14 13:01:01</td>\n",
       "      <td>dislike</td>\n",
       "      <td>-0.001</td>\n",
       "      <td>-0.099</td>\n",
       "      <td>-2.295</td>\n",
       "      <td>-2.315</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>345469</th>\n",
       "      <td>514188</td>\n",
       "      <td>1311</td>\n",
       "      <td>2018-07-14 04:49:24</td>\n",
       "      <td>dislike</td>\n",
       "      <td>0.000</td>\n",
       "      <td>-0.088</td>\n",
       "      <td>-2.295</td>\n",
       "      <td>-2.312</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>348502</th>\n",
       "      <td>693911</td>\n",
       "      <td>1311</td>\n",
       "      <td>2018-07-14 11:52:11</td>\n",
       "      <td>dislike</td>\n",
       "      <td>-0.000</td>\n",
       "      <td>-0.053</td>\n",
       "      <td>-2.295</td>\n",
       "      <td>-2.305</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>345305</th>\n",
       "      <td>133700</td>\n",
       "      <td>1311</td>\n",
       "      <td>2018-07-14 04:30:33</td>\n",
       "      <td>dislike</td>\n",
       "      <td>0.000</td>\n",
       "      <td>-0.050</td>\n",
       "      <td>-2.295</td>\n",
       "      <td>-2.304</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>345952</th>\n",
       "      <td>17467</td>\n",
       "      <td>1311</td>\n",
       "      <td>2018-07-14 05:38:48</td>\n",
       "      <td>dislike</td>\n",
       "      <td>0.001</td>\n",
       "      <td>-0.053</td>\n",
       "      <td>-2.295</td>\n",
       "      <td>-2.304</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>345394</th>\n",
       "      <td>818717</td>\n",
       "      <td>1311</td>\n",
       "      <td>2018-07-14 04:39:24</td>\n",
       "      <td>dislike</td>\n",
       "      <td>-0.007</td>\n",
       "      <td>0.231</td>\n",
       "      <td>-2.295</td>\n",
       "      <td>-2.255</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>345475</th>\n",
       "      <td>715225</td>\n",
       "      <td>1311</td>\n",
       "      <td>2018-07-14 04:50:55</td>\n",
       "      <td>dislike</td>\n",
       "      <td>-0.010</td>\n",
       "      <td>0.462</td>\n",
       "      <td>-2.295</td>\n",
       "      <td>-2.212</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>345868</th>\n",
       "      <td>548770</td>\n",
       "      <td>1311</td>\n",
       "      <td>2018-07-14 05:28:22</td>\n",
       "      <td>like</td>\n",
       "      <td>0.988</td>\n",
       "      <td>-1.310</td>\n",
       "      <td>-2.295</td>\n",
       "      <td>-1.569</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>346506</th>\n",
       "      <td>589347</td>\n",
       "      <td>1311</td>\n",
       "      <td>2018-07-14 07:01:32</td>\n",
       "      <td>like</td>\n",
       "      <td>0.964</td>\n",
       "      <td>0.005</td>\n",
       "      <td>-2.295</td>\n",
       "      <td>-1.330</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>345361</th>\n",
       "      <td>627424</td>\n",
       "      <td>1311</td>\n",
       "      <td>2018-07-14 04:36:13</td>\n",
       "      <td>like</td>\n",
       "      <td>0.964</td>\n",
       "      <td>0.011</td>\n",
       "      <td>-2.295</td>\n",
       "      <td>-1.329</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>345662</th>\n",
       "      <td>714602</td>\n",
       "      <td>1311</td>\n",
       "      <td>2018-07-14 15:28:50</td>\n",
       "      <td>like</td>\n",
       "      <td>0.964</td>\n",
       "      <td>0.011</td>\n",
       "      <td>-2.295</td>\n",
       "      <td>-1.329</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>346630</th>\n",
       "      <td>199186</td>\n",
       "      <td>1311</td>\n",
       "      <td>2018-07-14 07:17:31</td>\n",
       "      <td>like</td>\n",
       "      <td>0.959</td>\n",
       "      <td>0.050</td>\n",
       "      <td>-2.295</td>\n",
       "      <td>-1.326</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>350937</th>\n",
       "      <td>855933</td>\n",
       "      <td>1311</td>\n",
       "      <td>2018-07-14 20:28:35</td>\n",
       "      <td>like</td>\n",
       "      <td>0.964</td>\n",
       "      <td>0.032</td>\n",
       "      <td>-2.295</td>\n",
       "      <td>-1.325</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>350950</th>\n",
       "      <td>357077</td>\n",
       "      <td>1311</td>\n",
       "      <td>2018-07-14 20:54:23</td>\n",
       "      <td>like</td>\n",
       "      <td>0.963</td>\n",
       "      <td>0.042</td>\n",
       "      <td>-2.295</td>\n",
       "      <td>-1.323</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>346012</th>\n",
       "      <td>708877</td>\n",
       "      <td>1311</td>\n",
       "      <td>2018-07-14 05:49:19</td>\n",
       "      <td>like</td>\n",
       "      <td>0.999</td>\n",
       "      <td>-0.138</td>\n",
       "      <td>-2.295</td>\n",
       "      <td>-1.323</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>345467</th>\n",
       "      <td>69807</td>\n",
       "      <td>1311</td>\n",
       "      <td>2018-07-14 04:49:01</td>\n",
       "      <td>like</td>\n",
       "      <td>1.014</td>\n",
       "      <td>-0.194</td>\n",
       "      <td>-2.295</td>\n",
       "      <td>-1.319</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>345468</th>\n",
       "      <td>69807</td>\n",
       "      <td>1311</td>\n",
       "      <td>2018-07-14 07:25:04</td>\n",
       "      <td>like</td>\n",
       "      <td>1.014</td>\n",
       "      <td>-0.194</td>\n",
       "      <td>-2.295</td>\n",
       "      <td>-1.319</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>346893</th>\n",
       "      <td>689209</td>\n",
       "      <td>1311</td>\n",
       "      <td>2018-07-14 07:56:48</td>\n",
       "      <td>like</td>\n",
       "      <td>0.965</td>\n",
       "      <td>0.071</td>\n",
       "      <td>-2.295</td>\n",
       "      <td>-1.315</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>349521</th>\n",
       "      <td>177662</td>\n",
       "      <td>1311</td>\n",
       "      <td>2018-07-14 14:42:29</td>\n",
       "      <td>like</td>\n",
       "      <td>0.971</td>\n",
       "      <td>0.048</td>\n",
       "      <td>-2.295</td>\n",
       "      <td>-1.314</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>345639</th>\n",
       "      <td>103838</td>\n",
       "      <td>1311</td>\n",
       "      <td>2018-07-14 05:08:57</td>\n",
       "      <td>like</td>\n",
       "      <td>0.963</td>\n",
       "      <td>0.143</td>\n",
       "      <td>-2.295</td>\n",
       "      <td>-1.303</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>345810</th>\n",
       "      <td>98376</td>\n",
       "      <td>1311</td>\n",
       "      <td>2018-07-14 05:23:25</td>\n",
       "      <td>like</td>\n",
       "      <td>0.963</td>\n",
       "      <td>0.143</td>\n",
       "      <td>-2.295</td>\n",
       "      <td>-1.303</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>348606</th>\n",
       "      <td>472070</td>\n",
       "      <td>1311</td>\n",
       "      <td>2018-07-14 12:09:26</td>\n",
       "      <td>like</td>\n",
       "      <td>0.962</td>\n",
       "      <td>0.250</td>\n",
       "      <td>-2.295</td>\n",
       "      <td>-1.282</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>345856</th>\n",
       "      <td>179376</td>\n",
       "      <td>1311</td>\n",
       "      <td>2018-07-14 05:27:52</td>\n",
       "      <td>like</td>\n",
       "      <td>0.998</td>\n",
       "      <td>0.100</td>\n",
       "      <td>-2.295</td>\n",
       "      <td>-1.277</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>347847</th>\n",
       "      <td>425586</td>\n",
       "      <td>1311</td>\n",
       "      <td>2018-07-14 10:03:55</td>\n",
       "      <td>like</td>\n",
       "      <td>0.989</td>\n",
       "      <td>0.152</td>\n",
       "      <td>-2.295</td>\n",
       "      <td>-1.275</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>345591</th>\n",
       "      <td>204337</td>\n",
       "      <td>1311</td>\n",
       "      <td>2018-07-14 05:04:18</td>\n",
       "      <td>like</td>\n",
       "      <td>0.986</td>\n",
       "      <td>0.170</td>\n",
       "      <td>-2.295</td>\n",
       "      <td>-1.275</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>350117</th>\n",
       "      <td>873648</td>\n",
       "      <td>1311</td>\n",
       "      <td>2018-07-14 16:09:39</td>\n",
       "      <td>like</td>\n",
       "      <td>0.983</td>\n",
       "      <td>0.265</td>\n",
       "      <td>-2.295</td>\n",
       "      <td>-1.259</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>345955</th>\n",
       "      <td>163438</td>\n",
       "      <td>1311</td>\n",
       "      <td>2018-07-14 05:40:21</td>\n",
       "      <td>like</td>\n",
       "      <td>0.982</td>\n",
       "      <td>0.341</td>\n",
       "      <td>-2.295</td>\n",
       "      <td>-1.244</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>350250</th>\n",
       "      <td>899216</td>\n",
       "      <td>1311</td>\n",
       "      <td>2018-07-14 16:32:34</td>\n",
       "      <td>like</td>\n",
       "      <td>0.963</td>\n",
       "      <td>0.556</td>\n",
       "      <td>-2.295</td>\n",
       "      <td>-1.221</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>353812</th>\n",
       "      <td>640430</td>\n",
       "      <td>1311</td>\n",
       "      <td>2018-07-15 08:29:48</td>\n",
       "      <td>like</td>\n",
       "      <td>0.987</td>\n",
       "      <td>0.436</td>\n",
       "      <td>-2.295</td>\n",
       "      <td>-1.221</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>345969</th>\n",
       "      <td>793518</td>\n",
       "      <td>1311</td>\n",
       "      <td>2018-07-14 05:42:31</td>\n",
       "      <td>like</td>\n",
       "      <td>0.957</td>\n",
       "      <td>0.600</td>\n",
       "      <td>-2.295</td>\n",
       "      <td>-1.217</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>345727</th>\n",
       "      <td>949019</td>\n",
       "      <td>1311</td>\n",
       "      <td>2018-07-14 05:16:56</td>\n",
       "      <td>like</td>\n",
       "      <td>1.039</td>\n",
       "      <td>0.555</td>\n",
       "      <td>-2.295</td>\n",
       "      <td>-1.145</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>345746</th>\n",
       "      <td>409913</td>\n",
       "      <td>1311</td>\n",
       "      <td>2018-07-14 05:18:53</td>\n",
       "      <td>like</td>\n",
       "      <td>1.023</td>\n",
       "      <td>0.640</td>\n",
       "      <td>-2.295</td>\n",
       "      <td>-1.143</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>347097</th>\n",
       "      <td>95578</td>\n",
       "      <td>1311</td>\n",
       "      <td>2018-07-14 08:29:57</td>\n",
       "      <td>like</td>\n",
       "      <td>1.055</td>\n",
       "      <td>0.631</td>\n",
       "      <td>-2.295</td>\n",
       "      <td>-1.113</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>345255</th>\n",
       "      <td>181705</td>\n",
       "      <td>1311</td>\n",
       "      <td>2018-07-14 04:26:37</td>\n",
       "      <td>like</td>\n",
       "      <td>0.982</td>\n",
       "      <td>1.000</td>\n",
       "      <td>-2.295</td>\n",
       "      <td>-1.112</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "        customer_id  story_id          event_dttm    event  relevance  \\\n",
       "345347        12513      1311 2018-07-14 10:36:53  dislike     -0.013   \n",
       "345742       644459      1311 2018-07-15 04:36:56  dislike     -0.011   \n",
       "347971       814964      1311 2018-07-14 10:27:18  dislike     -0.003   \n",
       "346132       334332      1311 2018-07-14 06:04:08  dislike     -0.006   \n",
       "345839       254463      1311 2018-07-14 05:27:28  dislike     -0.000   \n",
       "349989       579260      1311 2018-07-14 15:46:54  dislike      0.001   \n",
       "348945       774872      1311 2018-07-14 13:01:01  dislike     -0.001   \n",
       "345469       514188      1311 2018-07-14 04:49:24  dislike      0.000   \n",
       "348502       693911      1311 2018-07-14 11:52:11  dislike     -0.000   \n",
       "345305       133700      1311 2018-07-14 04:30:33  dislike      0.000   \n",
       "345952        17467      1311 2018-07-14 05:38:48  dislike      0.001   \n",
       "345394       818717      1311 2018-07-14 04:39:24  dislike     -0.007   \n",
       "345475       715225      1311 2018-07-14 04:50:55  dislike     -0.010   \n",
       "345868       548770      1311 2018-07-14 05:28:22     like      0.988   \n",
       "346506       589347      1311 2018-07-14 07:01:32     like      0.964   \n",
       "345361       627424      1311 2018-07-14 04:36:13     like      0.964   \n",
       "345662       714602      1311 2018-07-14 15:28:50     like      0.964   \n",
       "346630       199186      1311 2018-07-14 07:17:31     like      0.959   \n",
       "350937       855933      1311 2018-07-14 20:28:35     like      0.964   \n",
       "350950       357077      1311 2018-07-14 20:54:23     like      0.963   \n",
       "346012       708877      1311 2018-07-14 05:49:19     like      0.999   \n",
       "345467        69807      1311 2018-07-14 04:49:01     like      1.014   \n",
       "345468        69807      1311 2018-07-14 07:25:04     like      1.014   \n",
       "346893       689209      1311 2018-07-14 07:56:48     like      0.965   \n",
       "349521       177662      1311 2018-07-14 14:42:29     like      0.971   \n",
       "345639       103838      1311 2018-07-14 05:08:57     like      0.963   \n",
       "345810        98376      1311 2018-07-14 05:23:25     like      0.963   \n",
       "348606       472070      1311 2018-07-14 12:09:26     like      0.962   \n",
       "345856       179376      1311 2018-07-14 05:27:52     like      0.998   \n",
       "347847       425586      1311 2018-07-14 10:03:55     like      0.989   \n",
       "345591       204337      1311 2018-07-14 05:04:18     like      0.986   \n",
       "350117       873648      1311 2018-07-14 16:09:39     like      0.983   \n",
       "345955       163438      1311 2018-07-14 05:40:21     like      0.982   \n",
       "350250       899216      1311 2018-07-14 16:32:34     like      0.963   \n",
       "353812       640430      1311 2018-07-15 08:29:48     like      0.987   \n",
       "345969       793518      1311 2018-07-14 05:42:31     like      0.957   \n",
       "345727       949019      1311 2018-07-14 05:16:56     like      1.039   \n",
       "345746       409913      1311 2018-07-14 05:18:53     like      1.023   \n",
       "347097        95578      1311 2018-07-14 08:29:57     like      1.055   \n",
       "345255       181705      1311 2018-07-14 04:26:37     like      0.982   \n",
       "\n",
       "        user_score  item_score  score  \n",
       "345347      -0.926      -2.295 -2.493  \n",
       "345742      -0.871      -2.295 -2.480  \n",
       "347971      -0.686      -2.295 -2.435  \n",
       "346132      -0.438      -2.295 -2.388  \n",
       "345839      -0.211      -2.295 -2.337  \n",
       "349989      -0.129      -2.295 -2.319  \n",
       "348945      -0.099      -2.295 -2.315  \n",
       "345469      -0.088      -2.295 -2.312  \n",
       "348502      -0.053      -2.295 -2.305  \n",
       "345305      -0.050      -2.295 -2.304  \n",
       "345952      -0.053      -2.295 -2.304  \n",
       "345394       0.231      -2.295 -2.255  \n",
       "345475       0.462      -2.295 -2.212  \n",
       "345868      -1.310      -2.295 -1.569  \n",
       "346506       0.005      -2.295 -1.330  \n",
       "345361       0.011      -2.295 -1.329  \n",
       "345662       0.011      -2.295 -1.329  \n",
       "346630       0.050      -2.295 -1.326  \n",
       "350937       0.032      -2.295 -1.325  \n",
       "350950       0.042      -2.295 -1.323  \n",
       "346012      -0.138      -2.295 -1.323  \n",
       "345467      -0.194      -2.295 -1.319  \n",
       "345468      -0.194      -2.295 -1.319  \n",
       "346893       0.071      -2.295 -1.315  \n",
       "349521       0.048      -2.295 -1.314  \n",
       "345639       0.143      -2.295 -1.303  \n",
       "345810       0.143      -2.295 -1.303  \n",
       "348606       0.250      -2.295 -1.282  \n",
       "345856       0.100      -2.295 -1.277  \n",
       "347847       0.152      -2.295 -1.275  \n",
       "345591       0.170      -2.295 -1.275  \n",
       "350117       0.265      -2.295 -1.259  \n",
       "345955       0.341      -2.295 -1.244  \n",
       "350250       0.556      -2.295 -1.221  \n",
       "353812       0.436      -2.295 -1.221  \n",
       "345969       0.600      -2.295 -1.217  \n",
       "345727       0.555      -2.295 -1.145  \n",
       "345746       0.640      -2.295 -1.143  \n",
       "347097       0.631      -2.295 -1.113  \n",
       "345255       1.000      -2.295 -1.112  "
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "with pd.option_context('display.float_format', '{:.3f}'.format):\n",
    "    display(df_train_predict\n",
    "            [lambda x: x.story_id == 1311]\n",
    "            [lambda x: x.customer_id.isin(df_train_predict.customer_id)]\n",
    "            [lambda x: x['event'].isin(['dislike', 'like'])]\n",
    "            .sample(n=40).sort_values('score')\n",
    "           )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 491,
   "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>story_id</th>\n",
       "      <th>event_dttm</th>\n",
       "      <th>event</th>\n",
       "      <th>relevance</th>\n",
       "      <th>user_score</th>\n",
       "      <th>item_score</th>\n",
       "      <th>score</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>85325</th>\n",
       "      <td>552033</td>\n",
       "      <td>1311</td>\n",
       "      <td>2018-07-27 11:30:14</td>\n",
       "      <td>like</td>\n",
       "      <td>-0.000</td>\n",
       "      <td>-2.500</td>\n",
       "      <td>-2.295</td>\n",
       "      <td>-2.795</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>39071</th>\n",
       "      <td>624918</td>\n",
       "      <td>1311</td>\n",
       "      <td>2018-07-21 06:55:38</td>\n",
       "      <td>like</td>\n",
       "      <td>-0.000</td>\n",
       "      <td>-1.667</td>\n",
       "      <td>-2.295</td>\n",
       "      <td>-2.628</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9392</th>\n",
       "      <td>869363</td>\n",
       "      <td>1311</td>\n",
       "      <td>2018-07-16 17:01:23</td>\n",
       "      <td>like</td>\n",
       "      <td>-0.014</td>\n",
       "      <td>-1.000</td>\n",
       "      <td>-2.295</td>\n",
       "      <td>-2.508</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>10967</th>\n",
       "      <td>412450</td>\n",
       "      <td>1311</td>\n",
       "      <td>2018-07-17 02:04:06</td>\n",
       "      <td>like</td>\n",
       "      <td>-0.002</td>\n",
       "      <td>-0.500</td>\n",
       "      <td>-2.295</td>\n",
       "      <td>-2.396</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8561</th>\n",
       "      <td>153195</td>\n",
       "      <td>1311</td>\n",
       "      <td>2018-07-16 14:49:53</td>\n",
       "      <td>like</td>\n",
       "      <td>-0.019</td>\n",
       "      <td>-0.146</td>\n",
       "      <td>-2.295</td>\n",
       "      <td>-2.343</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>13384</th>\n",
       "      <td>717701</td>\n",
       "      <td>1311</td>\n",
       "      <td>2018-07-17 07:17:27</td>\n",
       "      <td>like</td>\n",
       "      <td>0.000</td>\n",
       "      <td>-0.179</td>\n",
       "      <td>-2.295</td>\n",
       "      <td>-2.330</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>22323</th>\n",
       "      <td>182324</td>\n",
       "      <td>1311</td>\n",
       "      <td>2018-07-18 11:20:21</td>\n",
       "      <td>like</td>\n",
       "      <td>-0.078</td>\n",
       "      <td>0.256</td>\n",
       "      <td>-2.295</td>\n",
       "      <td>-2.321</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>12276</th>\n",
       "      <td>383292</td>\n",
       "      <td>1311</td>\n",
       "      <td>2018-07-17 04:51:57</td>\n",
       "      <td>dislike</td>\n",
       "      <td>-0.002</td>\n",
       "      <td>-0.114</td>\n",
       "      <td>-2.295</td>\n",
       "      <td>-2.320</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9064</th>\n",
       "      <td>307620</td>\n",
       "      <td>1311</td>\n",
       "      <td>2018-07-16 16:14:28</td>\n",
       "      <td>like</td>\n",
       "      <td>-0.014</td>\n",
       "      <td>-0.049</td>\n",
       "      <td>-2.295</td>\n",
       "      <td>-2.318</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>91329</th>\n",
       "      <td>555387</td>\n",
       "      <td>1311</td>\n",
       "      <td>2018-07-28 08:09:08</td>\n",
       "      <td>like</td>\n",
       "      <td>-0.068</td>\n",
       "      <td>0.229</td>\n",
       "      <td>-2.295</td>\n",
       "      <td>-2.317</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>19321</th>\n",
       "      <td>210943</td>\n",
       "      <td>1311</td>\n",
       "      <td>2018-07-18 03:59:19</td>\n",
       "      <td>like</td>\n",
       "      <td>0.008</td>\n",
       "      <td>-0.152</td>\n",
       "      <td>-2.295</td>\n",
       "      <td>-2.317</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9638</th>\n",
       "      <td>951418</td>\n",
       "      <td>1311</td>\n",
       "      <td>2018-07-16 17:31:57</td>\n",
       "      <td>dislike</td>\n",
       "      <td>-0.034</td>\n",
       "      <td>0.118</td>\n",
       "      <td>-2.295</td>\n",
       "      <td>-2.305</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>39350</th>\n",
       "      <td>536919</td>\n",
       "      <td>1311</td>\n",
       "      <td>2018-07-21 07:49:35</td>\n",
       "      <td>like</td>\n",
       "      <td>0.000</td>\n",
       "      <td>0.000</td>\n",
       "      <td>-2.295</td>\n",
       "      <td>-2.295</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9453</th>\n",
       "      <td>166125</td>\n",
       "      <td>1311</td>\n",
       "      <td>2018-07-16 17:09:50</td>\n",
       "      <td>like</td>\n",
       "      <td>0.000</td>\n",
       "      <td>0.000</td>\n",
       "      <td>-2.295</td>\n",
       "      <td>-2.295</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>18824</th>\n",
       "      <td>861946</td>\n",
       "      <td>1311</td>\n",
       "      <td>2018-07-18 03:00:55</td>\n",
       "      <td>like</td>\n",
       "      <td>0.000</td>\n",
       "      <td>0.000</td>\n",
       "      <td>-2.295</td>\n",
       "      <td>-2.295</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>47259</th>\n",
       "      <td>648394</td>\n",
       "      <td>1311</td>\n",
       "      <td>2018-07-22 10:14:58</td>\n",
       "      <td>like</td>\n",
       "      <td>0.000</td>\n",
       "      <td>0.000</td>\n",
       "      <td>-2.295</td>\n",
       "      <td>-2.295</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>41862</th>\n",
       "      <td>111678</td>\n",
       "      <td>1311</td>\n",
       "      <td>2018-07-21 14:30:33</td>\n",
       "      <td>like</td>\n",
       "      <td>0.000</td>\n",
       "      <td>0.000</td>\n",
       "      <td>-2.295</td>\n",
       "      <td>-2.295</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>60917</th>\n",
       "      <td>195024</td>\n",
       "      <td>1311</td>\n",
       "      <td>2018-07-24 02:06:03</td>\n",
       "      <td>dislike</td>\n",
       "      <td>0.000</td>\n",
       "      <td>0.000</td>\n",
       "      <td>-2.295</td>\n",
       "      <td>-2.295</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7015</th>\n",
       "      <td>50094</td>\n",
       "      <td>1311</td>\n",
       "      <td>2018-07-16 11:12:33</td>\n",
       "      <td>like</td>\n",
       "      <td>0.000</td>\n",
       "      <td>0.000</td>\n",
       "      <td>-2.295</td>\n",
       "      <td>-2.295</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>13639</th>\n",
       "      <td>613672</td>\n",
       "      <td>1311</td>\n",
       "      <td>2018-07-17 07:56:02</td>\n",
       "      <td>like</td>\n",
       "      <td>0.000</td>\n",
       "      <td>0.000</td>\n",
       "      <td>-2.295</td>\n",
       "      <td>-2.295</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9843</th>\n",
       "      <td>83290</td>\n",
       "      <td>1311</td>\n",
       "      <td>2018-07-16 18:04:40</td>\n",
       "      <td>like</td>\n",
       "      <td>0.000</td>\n",
       "      <td>0.000</td>\n",
       "      <td>-2.295</td>\n",
       "      <td>-2.295</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>25964</th>\n",
       "      <td>77703</td>\n",
       "      <td>1311</td>\n",
       "      <td>2018-07-19 04:10:03</td>\n",
       "      <td>dislike</td>\n",
       "      <td>0.000</td>\n",
       "      <td>0.000</td>\n",
       "      <td>-2.295</td>\n",
       "      <td>-2.295</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>34043</th>\n",
       "      <td>103725</td>\n",
       "      <td>1311</td>\n",
       "      <td>2018-07-20 11:26:55</td>\n",
       "      <td>dislike</td>\n",
       "      <td>0.000</td>\n",
       "      <td>0.000</td>\n",
       "      <td>-2.295</td>\n",
       "      <td>-2.295</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>15466</th>\n",
       "      <td>872437</td>\n",
       "      <td>1311</td>\n",
       "      <td>2018-07-17 12:34:40</td>\n",
       "      <td>dislike</td>\n",
       "      <td>0.000</td>\n",
       "      <td>0.000</td>\n",
       "      <td>-2.295</td>\n",
       "      <td>-2.295</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>16737</th>\n",
       "      <td>349906</td>\n",
       "      <td>1311</td>\n",
       "      <td>2018-07-17 16:09:14</td>\n",
       "      <td>like</td>\n",
       "      <td>0.000</td>\n",
       "      <td>0.000</td>\n",
       "      <td>-2.295</td>\n",
       "      <td>-2.295</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>26279</th>\n",
       "      <td>263941</td>\n",
       "      <td>1311</td>\n",
       "      <td>2018-07-19 04:49:19</td>\n",
       "      <td>dislike</td>\n",
       "      <td>0.000</td>\n",
       "      <td>0.000</td>\n",
       "      <td>-2.295</td>\n",
       "      <td>-2.295</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8600</th>\n",
       "      <td>175366</td>\n",
       "      <td>1311</td>\n",
       "      <td>2018-07-16 14:55:09</td>\n",
       "      <td>like</td>\n",
       "      <td>0.000</td>\n",
       "      <td>0.000</td>\n",
       "      <td>-2.295</td>\n",
       "      <td>-2.295</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>11648</th>\n",
       "      <td>166681</td>\n",
       "      <td>1311</td>\n",
       "      <td>2018-07-17 03:43:54</td>\n",
       "      <td>like</td>\n",
       "      <td>-0.000</td>\n",
       "      <td>0.018</td>\n",
       "      <td>-2.295</td>\n",
       "      <td>-2.291</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>64200</th>\n",
       "      <td>78687</td>\n",
       "      <td>1311</td>\n",
       "      <td>2018-07-24 10:07:13</td>\n",
       "      <td>like</td>\n",
       "      <td>0.001</td>\n",
       "      <td>0.036</td>\n",
       "      <td>-2.295</td>\n",
       "      <td>-2.286</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5484</th>\n",
       "      <td>756616</td>\n",
       "      <td>1311</td>\n",
       "      <td>2018-07-16 07:37:40</td>\n",
       "      <td>like</td>\n",
       "      <td>0.032</td>\n",
       "      <td>-0.086</td>\n",
       "      <td>-2.295</td>\n",
       "      <td>-2.280</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>37478</th>\n",
       "      <td>74071</td>\n",
       "      <td>1311</td>\n",
       "      <td>2018-07-21 03:25:02</td>\n",
       "      <td>like</td>\n",
       "      <td>0.004</td>\n",
       "      <td>0.111</td>\n",
       "      <td>-2.295</td>\n",
       "      <td>-2.268</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7302</th>\n",
       "      <td>730679</td>\n",
       "      <td>1311</td>\n",
       "      <td>2018-07-16 11:48:34</td>\n",
       "      <td>dislike</td>\n",
       "      <td>0.004</td>\n",
       "      <td>0.125</td>\n",
       "      <td>-2.295</td>\n",
       "      <td>-2.265</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>57242</th>\n",
       "      <td>970318</td>\n",
       "      <td>1311</td>\n",
       "      <td>2018-07-23 11:35:37</td>\n",
       "      <td>dislike</td>\n",
       "      <td>0.010</td>\n",
       "      <td>0.200</td>\n",
       "      <td>-2.295</td>\n",
       "      <td>-2.245</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>13498</th>\n",
       "      <td>47106</td>\n",
       "      <td>1311</td>\n",
       "      <td>2018-07-17 07:31:38</td>\n",
       "      <td>like</td>\n",
       "      <td>0.034</td>\n",
       "      <td>0.121</td>\n",
       "      <td>-2.295</td>\n",
       "      <td>-2.237</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7561</th>\n",
       "      <td>90244</td>\n",
       "      <td>1311</td>\n",
       "      <td>2018-07-16 12:28:21</td>\n",
       "      <td>like</td>\n",
       "      <td>0.049</td>\n",
       "      <td>0.048</td>\n",
       "      <td>-2.295</td>\n",
       "      <td>-2.236</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>29573</th>\n",
       "      <td>256295</td>\n",
       "      <td>1311</td>\n",
       "      <td>2018-07-19 15:29:14</td>\n",
       "      <td>like</td>\n",
       "      <td>0.094</td>\n",
       "      <td>-0.087</td>\n",
       "      <td>-2.295</td>\n",
       "      <td>-2.218</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>13557</th>\n",
       "      <td>132153</td>\n",
       "      <td>1311</td>\n",
       "      <td>2018-07-17 07:45:24</td>\n",
       "      <td>dislike</td>\n",
       "      <td>-0.015</td>\n",
       "      <td>0.658</td>\n",
       "      <td>-2.295</td>\n",
       "      <td>-2.178</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>10867</th>\n",
       "      <td>579813</td>\n",
       "      <td>1311</td>\n",
       "      <td>2018-07-17 01:41:34</td>\n",
       "      <td>like</td>\n",
       "      <td>0.024</td>\n",
       "      <td>0.487</td>\n",
       "      <td>-2.295</td>\n",
       "      <td>-2.173</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8119</th>\n",
       "      <td>307344</td>\n",
       "      <td>1311</td>\n",
       "      <td>2018-07-16 13:45:25</td>\n",
       "      <td>like</td>\n",
       "      <td>0.090</td>\n",
       "      <td>0.319</td>\n",
       "      <td>-2.295</td>\n",
       "      <td>-2.141</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>13903</th>\n",
       "      <td>273125</td>\n",
       "      <td>1311</td>\n",
       "      <td>2018-07-17 08:36:57</td>\n",
       "      <td>dislike</td>\n",
       "      <td>0.020</td>\n",
       "      <td>0.828</td>\n",
       "      <td>-2.295</td>\n",
       "      <td>-2.109</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "       customer_id  story_id          event_dttm    event  relevance  \\\n",
       "85325       552033      1311 2018-07-27 11:30:14     like     -0.000   \n",
       "39071       624918      1311 2018-07-21 06:55:38     like     -0.000   \n",
       "9392        869363      1311 2018-07-16 17:01:23     like     -0.014   \n",
       "10967       412450      1311 2018-07-17 02:04:06     like     -0.002   \n",
       "8561        153195      1311 2018-07-16 14:49:53     like     -0.019   \n",
       "13384       717701      1311 2018-07-17 07:17:27     like      0.000   \n",
       "22323       182324      1311 2018-07-18 11:20:21     like     -0.078   \n",
       "12276       383292      1311 2018-07-17 04:51:57  dislike     -0.002   \n",
       "9064        307620      1311 2018-07-16 16:14:28     like     -0.014   \n",
       "91329       555387      1311 2018-07-28 08:09:08     like     -0.068   \n",
       "19321       210943      1311 2018-07-18 03:59:19     like      0.008   \n",
       "9638        951418      1311 2018-07-16 17:31:57  dislike     -0.034   \n",
       "39350       536919      1311 2018-07-21 07:49:35     like      0.000   \n",
       "9453        166125      1311 2018-07-16 17:09:50     like      0.000   \n",
       "18824       861946      1311 2018-07-18 03:00:55     like      0.000   \n",
       "47259       648394      1311 2018-07-22 10:14:58     like      0.000   \n",
       "41862       111678      1311 2018-07-21 14:30:33     like      0.000   \n",
       "60917       195024      1311 2018-07-24 02:06:03  dislike      0.000   \n",
       "7015         50094      1311 2018-07-16 11:12:33     like      0.000   \n",
       "13639       613672      1311 2018-07-17 07:56:02     like      0.000   \n",
       "9843         83290      1311 2018-07-16 18:04:40     like      0.000   \n",
       "25964        77703      1311 2018-07-19 04:10:03  dislike      0.000   \n",
       "34043       103725      1311 2018-07-20 11:26:55  dislike      0.000   \n",
       "15466       872437      1311 2018-07-17 12:34:40  dislike      0.000   \n",
       "16737       349906      1311 2018-07-17 16:09:14     like      0.000   \n",
       "26279       263941      1311 2018-07-19 04:49:19  dislike      0.000   \n",
       "8600        175366      1311 2018-07-16 14:55:09     like      0.000   \n",
       "11648       166681      1311 2018-07-17 03:43:54     like     -0.000   \n",
       "64200        78687      1311 2018-07-24 10:07:13     like      0.001   \n",
       "5484        756616      1311 2018-07-16 07:37:40     like      0.032   \n",
       "37478        74071      1311 2018-07-21 03:25:02     like      0.004   \n",
       "7302        730679      1311 2018-07-16 11:48:34  dislike      0.004   \n",
       "57242       970318      1311 2018-07-23 11:35:37  dislike      0.010   \n",
       "13498        47106      1311 2018-07-17 07:31:38     like      0.034   \n",
       "7561         90244      1311 2018-07-16 12:28:21     like      0.049   \n",
       "29573       256295      1311 2018-07-19 15:29:14     like      0.094   \n",
       "13557       132153      1311 2018-07-17 07:45:24  dislike     -0.015   \n",
       "10867       579813      1311 2018-07-17 01:41:34     like      0.024   \n",
       "8119        307344      1311 2018-07-16 13:45:25     like      0.090   \n",
       "13903       273125      1311 2018-07-17 08:36:57  dislike      0.020   \n",
       "\n",
       "       user_score  item_score  score  \n",
       "85325      -2.500      -2.295 -2.795  \n",
       "39071      -1.667      -2.295 -2.628  \n",
       "9392       -1.000      -2.295 -2.508  \n",
       "10967      -0.500      -2.295 -2.396  \n",
       "8561       -0.146      -2.295 -2.343  \n",
       "13384      -0.179      -2.295 -2.330  \n",
       "22323       0.256      -2.295 -2.321  \n",
       "12276      -0.114      -2.295 -2.320  \n",
       "9064       -0.049      -2.295 -2.318  \n",
       "91329       0.229      -2.295 -2.317  \n",
       "19321      -0.152      -2.295 -2.317  \n",
       "9638        0.118      -2.295 -2.305  \n",
       "39350       0.000      -2.295 -2.295  \n",
       "9453        0.000      -2.295 -2.295  \n",
       "18824       0.000      -2.295 -2.295  \n",
       "47259       0.000      -2.295 -2.295  \n",
       "41862       0.000      -2.295 -2.295  \n",
       "60917       0.000      -2.295 -2.295  \n",
       "7015        0.000      -2.295 -2.295  \n",
       "13639       0.000      -2.295 -2.295  \n",
       "9843        0.000      -2.295 -2.295  \n",
       "25964       0.000      -2.295 -2.295  \n",
       "34043       0.000      -2.295 -2.295  \n",
       "15466       0.000      -2.295 -2.295  \n",
       "16737       0.000      -2.295 -2.295  \n",
       "26279       0.000      -2.295 -2.295  \n",
       "8600        0.000      -2.295 -2.295  \n",
       "11648       0.018      -2.295 -2.291  \n",
       "64200       0.036      -2.295 -2.286  \n",
       "5484       -0.086      -2.295 -2.280  \n",
       "37478       0.111      -2.295 -2.268  \n",
       "7302        0.125      -2.295 -2.265  \n",
       "57242       0.200      -2.295 -2.245  \n",
       "13498       0.121      -2.295 -2.237  \n",
       "7561        0.048      -2.295 -2.236  \n",
       "29573      -0.087      -2.295 -2.218  \n",
       "13557       0.658      -2.295 -2.178  \n",
       "10867       0.487      -2.295 -2.173  \n",
       "8119        0.319      -2.295 -2.141  \n",
       "13903       0.828      -2.295 -2.109  "
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "with pd.option_context('display.float_format', '{:.3f}'.format):\n",
    "    display(df_test_predict\n",
    "            [lambda x: x.story_id == 1311]\n",
    "            [lambda x: x.customer_id.isin(df_train_predict.customer_id)]\n",
    "            [lambda x: x['event'].isin(['dislike', 'like'])]\n",
    "            .sample(n=40).sort_values('score')\n",
    "           )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 485,
   "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>story_id</th>\n",
       "      <th>event_dttm</th>\n",
       "      <th>event</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>391895</th>\n",
       "      <td>788612</td>\n",
       "      <td>382</td>\n",
       "      <td>2018-07-08 05:55:51</td>\n",
       "      <td>view</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>391897</th>\n",
       "      <td>788612</td>\n",
       "      <td>885</td>\n",
       "      <td>2018-07-08 05:55:51</td>\n",
       "      <td>view</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>391899</th>\n",
       "      <td>788612</td>\n",
       "      <td>1272</td>\n",
       "      <td>2018-07-08 05:55:51</td>\n",
       "      <td>skip</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>391898</th>\n",
       "      <td>788612</td>\n",
       "      <td>892</td>\n",
       "      <td>2018-07-08 05:55:51</td>\n",
       "      <td>view</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "        customer_id  story_id          event_dttm event\n",
       "391895       788612       382 2018-07-08 05:55:51  view\n",
       "391897       788612       885 2018-07-08 05:55:51  view\n",
       "391899       788612      1272 2018-07-08 05:55:51  skip\n",
       "391898       788612       892 2018-07-08 05:55:51  view"
      ]
     },
     "execution_count": 485,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_user_item_train[lambda x: x.customer_id == 788612]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 488,
   "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>event_dttm</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>event</th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>dislike</th>\n",
       "      <td>52</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>like</th>\n",
       "      <td>121</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>skip</th>\n",
       "      <td>57</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>view</th>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "         event_dttm\n",
       "event              \n",
       "dislike          52\n",
       "like            121\n",
       "skip             57\n",
       "view              1"
      ]
     },
     "execution_count": 488,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_user_item_train[lambda x: x.story_id == 1311].groupby('event')[['event_dttm']].count()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "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.6.4"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
