{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-rw-rw-r-- 1 ivan ivan  21M Dec  2 19:40 ../data/clients.csv\r\n",
      "-rw-rw-r-- 1 ivan ivan 3.8M Dec  2 19:40 ../data/products.csv\r\n",
      "-rw-rw-r-- 1 ivan ivan 4.2G Dec  2 19:49 ../data/purchases.csv\r\n",
      "-rw-rw-r-- 1 ivan ivan 5.8M Dec  2 19:40 ../data/uplift_sample_submission.csv\r\n",
      "-rw-rw-r-- 1 ivan ivan 2.1M Dec  2 19:40 ../data/uplift_test.csv\r\n",
      "-rw-rw-r-- 1 ivan ivan 2.9M Dec  2 19:40 ../data/uplift_train.csv\r\n"
     ]
    }
   ],
   "source": [
    "!ls -lh ../data/*.csv"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "client_id,uplift\r\n",
      "008fb49e3a,0.1149912020897228\r\n",
      "0095340acc,0.8353208872466903\r\n",
      "015c0b4d79,0.3085840952650095\r\n"
     ]
    }
   ],
   "source": [
    "!head -n 4 ../data/uplift_sample_submission.csv"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 154,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import pandas as pd"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Read"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "df_clients = pd.read_csv('../data/clients.csv')\n",
    "df_products = pd.read_csv('../data/products.csv')\n",
    "df_purchases = pd.read_csv('../data/purchases.csv')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "df_train = pd.read_csv('../data/uplift_train.csv')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Transformations"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 85,
   "metadata": {},
   "outputs": [],
   "source": [
    "df_purchases['transaction_datetime'] = pd.to_datetime(df_purchases['transaction_datetime'])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 96,
   "metadata": {},
   "outputs": [],
   "source": [
    "df_purchases['transaction_month'] = \\\n",
    "    df_purchases['transaction_datetime'].dt.floor('D') - \\\n",
    "    pd.to_timedelta(df_purchases['transaction_datetime'].dt.day - 1, 'D')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Train target"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "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 tr th {\n",
       "        text-align: left;\n",
       "    }\n",
       "\n",
       "    .dataframe thead tr:last-of-type th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr>\n",
       "      <th></th>\n",
       "      <th colspan=\"2\" halign=\"left\">cnt</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>target</th>\n",
       "      <th>0</th>\n",
       "      <th>1</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>treatment_flg</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>39695</td>\n",
       "      <td>60363</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>36342</td>\n",
       "      <td>63639</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                 cnt       \n",
       "target             0      1\n",
       "treatment_flg              \n",
       "0              39695  60363\n",
       "1              36342  63639"
      ]
     },
     "execution_count": 14,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_train.assign(cnt=1).pivot_table(index='treatment_flg', columns='target', aggfunc='sum')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Clients"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "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>client_id</th>\n",
       "      <th>first_issue_date</th>\n",
       "      <th>first_redeem_date</th>\n",
       "      <th>age</th>\n",
       "      <th>gender</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>000012768d</td>\n",
       "      <td>2017-08-05 15:40:48</td>\n",
       "      <td>2018-01-04 19:30:07</td>\n",
       "      <td>45</td>\n",
       "      <td>U</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>000036f903</td>\n",
       "      <td>2017-04-10 13:54:23</td>\n",
       "      <td>2017-04-23 12:37:56</td>\n",
       "      <td>72</td>\n",
       "      <td>F</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>000048b7a6</td>\n",
       "      <td>2018-12-15 13:33:11</td>\n",
       "      <td>NaN</td>\n",
       "      <td>68</td>\n",
       "      <td>F</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>000073194a</td>\n",
       "      <td>2017-05-23 12:56:14</td>\n",
       "      <td>2017-11-24 11:18:01</td>\n",
       "      <td>60</td>\n",
       "      <td>F</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>00007c7133</td>\n",
       "      <td>2017-05-22 16:17:08</td>\n",
       "      <td>2018-12-31 17:17:33</td>\n",
       "      <td>67</td>\n",
       "      <td>U</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "    client_id     first_issue_date    first_redeem_date  age gender\n",
       "0  000012768d  2017-08-05 15:40:48  2018-01-04 19:30:07   45      U\n",
       "1  000036f903  2017-04-10 13:54:23  2017-04-23 12:37:56   72      F\n",
       "2  000048b7a6  2018-12-15 13:33:11                  NaN   68      F\n",
       "3  000073194a  2017-05-23 12:56:14  2017-11-24 11:18:01   60      F\n",
       "4  00007c7133  2017-05-22 16:17:08  2018-12-31 17:17:33   67      U"
      ]
     },
     "execution_count": 15,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_clients.head()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 53,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "400162"
      ]
     },
     "execution_count": 53,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_clients['client_id'].nunique()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.axes._subplots.AxesSubplot at 0x7fb56330f1d0>"
      ]
     },
     "execution_count": 20,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 864x216 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "df_clients['age'].hist(bins=20, figsize=(12, 3))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 166,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.axes._subplots.AxesSubplot at 0x7fb49065ff60>"
      ]
     },
     "execution_count": 166,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 864x216 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "df_clients['age'].clip(0, 100).hist(bins=20, figsize=(12, 3))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 167,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.25    34.0\n",
       "0.50    45.0\n",
       "0.75    59.0\n",
       "Name: age, dtype: float64"
      ]
     },
     "execution_count": 167,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_clients['age'].quantile([0.25, 0.50, 0.75])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "U    185706\n",
       "F    147649\n",
       "M     66807\n",
       "Name: gender, dtype: int64"
      ]
     },
     "execution_count": 21,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_clients['gender'].value_counts()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 190,
   "metadata": {},
   "outputs": [],
   "source": [
    "df_clients['age_bin'] = np.where(\n",
    "    (df_clients['age'] < 10) | (df_clients['age'] > 90), -1, np.where(\n",
    "        df_clients['age'] < 35, 0, np.where(\n",
    "            df_clients['age'] < 45, 1, np.where(\n",
    "                df_clients['age'] < 60, 2, 3))))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 191,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "-1      1494\n",
       " 0    108564\n",
       " 1     85019\n",
       " 2    107763\n",
       " 3     97322\n",
       "Name: age_bin, dtype: int64"
      ]
     },
     "execution_count": 191,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_clients['age_bin'].value_counts().sort_index()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 192,
   "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>gender</th>\n",
       "      <th>F</th>\n",
       "      <th>M</th>\n",
       "      <th>U</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>age_bin</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>-1</th>\n",
       "      <td>73</td>\n",
       "      <td>454</td>\n",
       "      <td>967</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>37681</td>\n",
       "      <td>25143</td>\n",
       "      <td>45740</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>28498</td>\n",
       "      <td>14720</td>\n",
       "      <td>41801</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>38966</td>\n",
       "      <td>15256</td>\n",
       "      <td>53541</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>42431</td>\n",
       "      <td>11234</td>\n",
       "      <td>43657</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "gender       F      M      U\n",
       "age_bin                     \n",
       "-1          73    454    967\n",
       " 0       37681  25143  45740\n",
       " 1       28498  14720  41801\n",
       " 2       38966  15256  53541\n",
       " 3       42431  11234  43657"
      ]
     },
     "execution_count": 192,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_clients.groupby(['age_bin', 'gender'])['client_id'].count().unstack()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Products"
   ]
  },
  {
   "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>product_id</th>\n",
       "      <th>level_1</th>\n",
       "      <th>level_2</th>\n",
       "      <th>level_3</th>\n",
       "      <th>level_4</th>\n",
       "      <th>segment_id</th>\n",
       "      <th>brand_id</th>\n",
       "      <th>vendor_id</th>\n",
       "      <th>netto</th>\n",
       "      <th>is_own_trademark</th>\n",
       "      <th>is_alcohol</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0003020d3c</td>\n",
       "      <td>c3d3a8e8c6</td>\n",
       "      <td>c2a3ea8d5e</td>\n",
       "      <td>b7cda0ec0c</td>\n",
       "      <td>6376f2a852</td>\n",
       "      <td>123.0</td>\n",
       "      <td>394a54a7c1</td>\n",
       "      <td>9eaff48661</td>\n",
       "      <td>0.400</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>0003870676</td>\n",
       "      <td>e344ab2e71</td>\n",
       "      <td>52f13dac0c</td>\n",
       "      <td>d3cfe81323</td>\n",
       "      <td>6dc544533f</td>\n",
       "      <td>105.0</td>\n",
       "      <td>acd3dd483f</td>\n",
       "      <td>10486c3cf0</td>\n",
       "      <td>0.680</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>0003ceaf69</td>\n",
       "      <td>c3d3a8e8c6</td>\n",
       "      <td>f2333c90fb</td>\n",
       "      <td>419bc5b424</td>\n",
       "      <td>f6148afbc0</td>\n",
       "      <td>271.0</td>\n",
       "      <td>f597581079</td>\n",
       "      <td>764e660dda</td>\n",
       "      <td>0.500</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>000701e093</td>\n",
       "      <td>ec62ce61e3</td>\n",
       "      <td>4202626fcb</td>\n",
       "      <td>88a515c084</td>\n",
       "      <td>48cf3d488f</td>\n",
       "      <td>172.0</td>\n",
       "      <td>54a90fe769</td>\n",
       "      <td>03c2d70bad</td>\n",
       "      <td>0.112</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>0007149564</td>\n",
       "      <td>e344ab2e71</td>\n",
       "      <td>52f13dac0c</td>\n",
       "      <td>d3cfe81323</td>\n",
       "      <td>6dc544533f</td>\n",
       "      <td>105.0</td>\n",
       "      <td>63417fe1f3</td>\n",
       "      <td>f329130198</td>\n",
       "      <td>0.600</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>43033</th>\n",
       "      <td>fffac3a287</td>\n",
       "      <td>e344ab2e71</td>\n",
       "      <td>52f13dac0c</td>\n",
       "      <td>0f84eb7480</td>\n",
       "      <td>420c3b3f0b</td>\n",
       "      <td>150.0</td>\n",
       "      <td>5aef526287</td>\n",
       "      <td>f546d8aa6f</td>\n",
       "      <td>0.085</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>43034</th>\n",
       "      <td>fffd2946cf</td>\n",
       "      <td>e344ab2e71</td>\n",
       "      <td>52f13dac0c</td>\n",
       "      <td>a1786084ca</td>\n",
       "      <td>b2960bceb8</td>\n",
       "      <td>176.0</td>\n",
       "      <td>7bf16d4aa4</td>\n",
       "      <td>3d8c5ef5f4</td>\n",
       "      <td>0.130</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>43035</th>\n",
       "      <td>fffd7fb409</td>\n",
       "      <td>e344ab2e71</td>\n",
       "      <td>1d2939ba1d</td>\n",
       "      <td>2721c4b3d6</td>\n",
       "      <td>32f03574dd</td>\n",
       "      <td>255.0</td>\n",
       "      <td>1267326e16</td>\n",
       "      <td>0cfa052441</td>\n",
       "      <td>0.450</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>43036</th>\n",
       "      <td>fffd963a2c</td>\n",
       "      <td>c3d3a8e8c6</td>\n",
       "      <td>c2a3ea8d5e</td>\n",
       "      <td>a6b0dd76e0</td>\n",
       "      <td>a7e8f1cc02</td>\n",
       "      <td>220.0</td>\n",
       "      <td>c2eec3be6f</td>\n",
       "      <td>75ea3d1182</td>\n",
       "      <td>0.300</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>43037</th>\n",
       "      <td>fffd992186</td>\n",
       "      <td>e344ab2e71</td>\n",
       "      <td>14d373dff5</td>\n",
       "      <td>3e810ee449</td>\n",
       "      <td>b3abf10724</td>\n",
       "      <td>235.0</td>\n",
       "      <td>880444b642</td>\n",
       "      <td>c2d24cc81f</td>\n",
       "      <td>0.250</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>43038 rows × 11 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "       product_id     level_1     level_2     level_3     level_4  segment_id  \\\n",
       "0      0003020d3c  c3d3a8e8c6  c2a3ea8d5e  b7cda0ec0c  6376f2a852       123.0   \n",
       "1      0003870676  e344ab2e71  52f13dac0c  d3cfe81323  6dc544533f       105.0   \n",
       "2      0003ceaf69  c3d3a8e8c6  f2333c90fb  419bc5b424  f6148afbc0       271.0   \n",
       "3      000701e093  ec62ce61e3  4202626fcb  88a515c084  48cf3d488f       172.0   \n",
       "4      0007149564  e344ab2e71  52f13dac0c  d3cfe81323  6dc544533f       105.0   \n",
       "...           ...         ...         ...         ...         ...         ...   \n",
       "43033  fffac3a287  e344ab2e71  52f13dac0c  0f84eb7480  420c3b3f0b       150.0   \n",
       "43034  fffd2946cf  e344ab2e71  52f13dac0c  a1786084ca  b2960bceb8       176.0   \n",
       "43035  fffd7fb409  e344ab2e71  1d2939ba1d  2721c4b3d6  32f03574dd       255.0   \n",
       "43036  fffd963a2c  c3d3a8e8c6  c2a3ea8d5e  a6b0dd76e0  a7e8f1cc02       220.0   \n",
       "43037  fffd992186  e344ab2e71  14d373dff5  3e810ee449  b3abf10724       235.0   \n",
       "\n",
       "         brand_id   vendor_id  netto  is_own_trademark  is_alcohol  \n",
       "0      394a54a7c1  9eaff48661  0.400                 0           0  \n",
       "1      acd3dd483f  10486c3cf0  0.680                 0           0  \n",
       "2      f597581079  764e660dda  0.500                 0           0  \n",
       "3      54a90fe769  03c2d70bad  0.112                 0           0  \n",
       "4      63417fe1f3  f329130198  0.600                 0           0  \n",
       "...           ...         ...    ...               ...         ...  \n",
       "43033  5aef526287  f546d8aa6f  0.085                 0           0  \n",
       "43034  7bf16d4aa4  3d8c5ef5f4  0.130                 0           0  \n",
       "43035  1267326e16  0cfa052441  0.450                 0           0  \n",
       "43036  c2eec3be6f  75ea3d1182  0.300                 0           0  \n",
       "43037  880444b642  c2d24cc81f  0.250                 0           0  \n",
       "\n",
       "[43038 rows x 11 columns]"
      ]
     },
     "execution_count": 26,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_products"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 195,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "product_id          43038\n",
       "level_1             43035\n",
       "level_2             43035\n",
       "level_3             43035\n",
       "level_4             43035\n",
       "segment_id          41466\n",
       "brand_id            37838\n",
       "vendor_id           43004\n",
       "netto               43035\n",
       "is_own_trademark    43038\n",
       "is_alcohol          43038\n",
       "dtype: int64"
      ]
     },
     "execution_count": 195,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_products.count()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 70,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "e344ab2e71    22183\n",
       "c3d3a8e8c6    16573\n",
       "ec62ce61e3     4279\n",
       "Name: level_1, dtype: int64"
      ]
     },
     "execution_count": 70,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_products['level_1'].value_counts()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 76,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "52f13dac0c    8891\n",
       "ad2b2e17d2    6631\n",
       "f2333c90fb    3310\n",
       "ed2ad1797c    3257\n",
       "703f4b6eb0    2396\n",
       "749c619457    2393\n",
       "14d373dff5    2377\n",
       "c2a3ea8d5e    2209\n",
       "1d2939ba1d    1717\n",
       "f93982269d    1343\n",
       "4202626fcb    1124\n",
       "de6f3b925a     910\n",
       "be86806c6b     757\n",
       "6b4ae3f25d     570\n",
       "a49a930a49     540\n",
       "d283080a93     523\n",
       "70ac384d6a     502\n",
       "825fe699ab     441\n",
       "034aca0659     383\n",
       "f980df59e1     331\n",
       "36bd2cad67     285\n",
       "63852cb2ab     261\n",
       "428e08386e     245\n",
       "91fb12a54a     242\n",
       "fb3d79909e     225\n",
       "6f624f4be0     206\n",
       "e8705574ff     174\n",
       "b0c4967fce     125\n",
       "93073a7304     114\n",
       "79666b6e44     100\n",
       "8a277809e5      87\n",
       "3f9010c11e      74\n",
       "fb84f08028      69\n",
       "c6e84cdac8      56\n",
       "26ae5a7da8      39\n",
       "c3d6b407d9      36\n",
       "a75f1bad01      18\n",
       "35642addd4      17\n",
       "3ef03403a0      17\n",
       "a2963967ff      16\n",
       "2ede06c1ee      14\n",
       "15e7af62dd      10\n",
       "Name: level_2, dtype: int64"
      ]
     },
     "execution_count": 76,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_products['level_2'].value_counts()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 75,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "ca69ed9de2    3737\n",
       "419bc5b424    2729\n",
       "0f84eb7480    2571\n",
       "38816369ce    2324\n",
       "6b55683dad    1862\n",
       "              ... \n",
       "c0a411f3b8       1\n",
       "d26b025821       1\n",
       "57f95167c1       1\n",
       "cf7a66aa8b       1\n",
       "475f86c453       1\n",
       "Name: level_3, Length: 201, dtype: int64"
      ]
     },
     "execution_count": 75,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_products['level_3'].value_counts()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 77,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "420c3b3f0b    2500\n",
       "4d4b7e1f16    2077\n",
       "3a074a6620    1485\n",
       "6dc544533f    1313\n",
       "b4b0e4c470     784\n",
       "              ... \n",
       "9d5c6c6b11       1\n",
       "690cbc6ce7       1\n",
       "0c61588ac2       1\n",
       "53755496eb       1\n",
       "fca87d4254       1\n",
       "Name: level_4, Length: 790, dtype: int64"
      ]
     },
     "execution_count": 77,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_products['level_4'].value_counts()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 78,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "105.0    5360\n",
       "150.0    2745\n",
       "271.0    1690\n",
       "259.0    1523\n",
       "85.0     1291\n",
       "         ... \n",
       "23.0       10\n",
       "211.0       7\n",
       "171.0       6\n",
       "258.0       3\n",
       "144.0       3\n",
       "Name: segment_id, Length: 116, dtype: int64"
      ]
     },
     "execution_count": 78,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_products['segment_id'].value_counts()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 79,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0d6f137fb6    4344\n",
       "4da2dc345f    3071\n",
       "b06ace74de     385\n",
       "ab230258e9     268\n",
       "63ba6b7a61     136\n",
       "              ... \n",
       "7a29f17b84       1\n",
       "80ab83fda5       1\n",
       "41db68d44b       1\n",
       "ef911b1caf       1\n",
       "0d9c8ce7f5       1\n",
       "Name: brand_id, Length: 4296, dtype: int64"
      ]
     },
     "execution_count": 79,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_products['brand_id'].value_counts()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 80,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "43acd80c1a    1514\n",
       "63243765ed     349\n",
       "c4e167b91e     331\n",
       "83f98e6dc3     328\n",
       "4f276b13c1     323\n",
       "              ... \n",
       "c4655e8d7d       1\n",
       "cc452eff56       1\n",
       "62f5423d28       1\n",
       "38284aa3db       1\n",
       "9f241baab6       1\n",
       "Name: vendor_id, Length: 3193, dtype: int64"
      ]
     },
     "execution_count": 80,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_products['vendor_id'].value_counts()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 159,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 1008x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "_, (ax0, ax1) = plt.subplots(1, 2, figsize=(14, 4))\n",
    "df_products['netto'].clip(None, 2).hist(ax=ax0)\n",
    "np.log1p(df_products['netto']).clip(None, 1).hist(ax=ax1)\n",
    "\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Purchases"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 140,
   "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>client_id</th>\n",
       "      <th>transaction_id</th>\n",
       "      <th>transaction_datetime</th>\n",
       "      <th>regular_points_received</th>\n",
       "      <th>express_points_received</th>\n",
       "      <th>regular_points_spent</th>\n",
       "      <th>express_points_spent</th>\n",
       "      <th>purchase_sum</th>\n",
       "      <th>store_id</th>\n",
       "      <th>product_id</th>\n",
       "      <th>product_quantity</th>\n",
       "      <th>trn_sum_from_iss</th>\n",
       "      <th>trn_sum_from_red</th>\n",
       "      <th>transaction_month</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>000012768d</td>\n",
       "      <td>7e3e2e3984</td>\n",
       "      <td>2018-12-01 07:12:45</td>\n",
       "      <td>10.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1007.0</td>\n",
       "      <td>54a4a11a29</td>\n",
       "      <td>9a80204f78</td>\n",
       "      <td>2.0</td>\n",
       "      <td>80.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>2018-12-01</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>000012768d</td>\n",
       "      <td>7e3e2e3984</td>\n",
       "      <td>2018-12-01 07:12:45</td>\n",
       "      <td>10.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1007.0</td>\n",
       "      <td>54a4a11a29</td>\n",
       "      <td>da89ebd374</td>\n",
       "      <td>1.0</td>\n",
       "      <td>65.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>2018-12-01</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>000012768d</td>\n",
       "      <td>7e3e2e3984</td>\n",
       "      <td>2018-12-01 07:12:45</td>\n",
       "      <td>10.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1007.0</td>\n",
       "      <td>54a4a11a29</td>\n",
       "      <td>0a95e1151d</td>\n",
       "      <td>1.0</td>\n",
       "      <td>24.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>2018-12-01</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>000012768d</td>\n",
       "      <td>7e3e2e3984</td>\n",
       "      <td>2018-12-01 07:12:45</td>\n",
       "      <td>10.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1007.0</td>\n",
       "      <td>54a4a11a29</td>\n",
       "      <td>4055b15e4a</td>\n",
       "      <td>2.0</td>\n",
       "      <td>50.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>2018-12-01</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>000012768d</td>\n",
       "      <td>7e3e2e3984</td>\n",
       "      <td>2018-12-01 07:12:45</td>\n",
       "      <td>10.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1007.0</td>\n",
       "      <td>54a4a11a29</td>\n",
       "      <td>a685f1916b</td>\n",
       "      <td>1.0</td>\n",
       "      <td>22.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>2018-12-01</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>45786563</th>\n",
       "      <td>fffff6ce77</td>\n",
       "      <td>48f6d115ce</td>\n",
       "      <td>2019-03-15 17:47:02</td>\n",
       "      <td>6.7</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>676.0</td>\n",
       "      <td>5ec64bdccb</td>\n",
       "      <td>24d5a54f42</td>\n",
       "      <td>1.0</td>\n",
       "      <td>164.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>2019-03-01</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>45786564</th>\n",
       "      <td>fffff6ce77</td>\n",
       "      <td>48f6d115ce</td>\n",
       "      <td>2019-03-15 17:47:02</td>\n",
       "      <td>6.7</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>676.0</td>\n",
       "      <td>5ec64bdccb</td>\n",
       "      <td>7427d0830d</td>\n",
       "      <td>1.0</td>\n",
       "      <td>134.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>2019-03-01</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>45786565</th>\n",
       "      <td>fffff6ce77</td>\n",
       "      <td>48f6d115ce</td>\n",
       "      <td>2019-03-15 17:47:02</td>\n",
       "      <td>6.7</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>676.0</td>\n",
       "      <td>5ec64bdccb</td>\n",
       "      <td>6c547c2ca8</td>\n",
       "      <td>1.0</td>\n",
       "      <td>60.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>2019-03-01</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>45786566</th>\n",
       "      <td>fffff6ce77</td>\n",
       "      <td>48f6d115ce</td>\n",
       "      <td>2019-03-15 17:47:02</td>\n",
       "      <td>6.7</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>676.0</td>\n",
       "      <td>5ec64bdccb</td>\n",
       "      <td>d04e7a8338</td>\n",
       "      <td>1.0</td>\n",
       "      <td>48.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>2019-03-01</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>45786567</th>\n",
       "      <td>fffff6ce77</td>\n",
       "      <td>48f6d115ce</td>\n",
       "      <td>2019-03-15 17:47:02</td>\n",
       "      <td>6.7</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>676.0</td>\n",
       "      <td>5ec64bdccb</td>\n",
       "      <td>f40cd0b2f4</td>\n",
       "      <td>1.0</td>\n",
       "      <td>17.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>2019-03-01</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>45786568 rows × 14 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "           client_id transaction_id transaction_datetime  \\\n",
       "0         000012768d     7e3e2e3984  2018-12-01 07:12:45   \n",
       "1         000012768d     7e3e2e3984  2018-12-01 07:12:45   \n",
       "2         000012768d     7e3e2e3984  2018-12-01 07:12:45   \n",
       "3         000012768d     7e3e2e3984  2018-12-01 07:12:45   \n",
       "4         000012768d     7e3e2e3984  2018-12-01 07:12:45   \n",
       "...              ...            ...                  ...   \n",
       "45786563  fffff6ce77     48f6d115ce  2019-03-15 17:47:02   \n",
       "45786564  fffff6ce77     48f6d115ce  2019-03-15 17:47:02   \n",
       "45786565  fffff6ce77     48f6d115ce  2019-03-15 17:47:02   \n",
       "45786566  fffff6ce77     48f6d115ce  2019-03-15 17:47:02   \n",
       "45786567  fffff6ce77     48f6d115ce  2019-03-15 17:47:02   \n",
       "\n",
       "          regular_points_received  express_points_received  \\\n",
       "0                            10.0                      0.0   \n",
       "1                            10.0                      0.0   \n",
       "2                            10.0                      0.0   \n",
       "3                            10.0                      0.0   \n",
       "4                            10.0                      0.0   \n",
       "...                           ...                      ...   \n",
       "45786563                      6.7                      0.0   \n",
       "45786564                      6.7                      0.0   \n",
       "45786565                      6.7                      0.0   \n",
       "45786566                      6.7                      0.0   \n",
       "45786567                      6.7                      0.0   \n",
       "\n",
       "          regular_points_spent  express_points_spent  purchase_sum  \\\n",
       "0                          0.0                   0.0        1007.0   \n",
       "1                          0.0                   0.0        1007.0   \n",
       "2                          0.0                   0.0        1007.0   \n",
       "3                          0.0                   0.0        1007.0   \n",
       "4                          0.0                   0.0        1007.0   \n",
       "...                        ...                   ...           ...   \n",
       "45786563                   0.0                   0.0         676.0   \n",
       "45786564                   0.0                   0.0         676.0   \n",
       "45786565                   0.0                   0.0         676.0   \n",
       "45786566                   0.0                   0.0         676.0   \n",
       "45786567                   0.0                   0.0         676.0   \n",
       "\n",
       "            store_id  product_id  product_quantity  trn_sum_from_iss  \\\n",
       "0         54a4a11a29  9a80204f78               2.0              80.0   \n",
       "1         54a4a11a29  da89ebd374               1.0              65.0   \n",
       "2         54a4a11a29  0a95e1151d               1.0              24.0   \n",
       "3         54a4a11a29  4055b15e4a               2.0              50.0   \n",
       "4         54a4a11a29  a685f1916b               1.0              22.0   \n",
       "...              ...         ...               ...               ...   \n",
       "45786563  5ec64bdccb  24d5a54f42               1.0             164.0   \n",
       "45786564  5ec64bdccb  7427d0830d               1.0             134.0   \n",
       "45786565  5ec64bdccb  6c547c2ca8               1.0              60.0   \n",
       "45786566  5ec64bdccb  d04e7a8338               1.0              48.0   \n",
       "45786567  5ec64bdccb  f40cd0b2f4               1.0              17.0   \n",
       "\n",
       "          trn_sum_from_red transaction_month  \n",
       "0                      NaN        2018-12-01  \n",
       "1                      NaN        2018-12-01  \n",
       "2                      NaN        2018-12-01  \n",
       "3                      NaN        2018-12-01  \n",
       "4                      NaN        2018-12-01  \n",
       "...                    ...               ...  \n",
       "45786563               NaN        2019-03-01  \n",
       "45786564               NaN        2019-03-01  \n",
       "45786565               NaN        2019-03-01  \n",
       "45786566               NaN        2019-03-01  \n",
       "45786567               NaN        2019-03-01  \n",
       "\n",
       "[45786568 rows x 14 columns]"
      ]
     },
     "execution_count": 140,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_purchases"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "client_id                  45786568\n",
       "transaction_id             45786568\n",
       "transaction_datetime       45786568\n",
       "regular_points_received    45786568\n",
       "express_points_received    45786568\n",
       "regular_points_spent       45786568\n",
       "express_points_spent       45786568\n",
       "purchase_sum               45786568\n",
       "store_id                   45786568\n",
       "product_id                 45786568\n",
       "product_quantity           45786568\n",
       "trn_sum_from_iss           45786568\n",
       "trn_sum_from_red            3043356\n",
       "dtype: int64"
      ]
     },
     "execution_count": 33,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_purchases.count()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 67,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.axes._subplots.AxesSubplot at 0x7fb426a9c550>"
      ]
     },
     "execution_count": 67,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 864x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "df_purchases.groupby(['transaction_id', 'client_id'])['transaction_datetime'].count().hist(bins=20, figsize=(12, 4))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 52,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "400162"
      ]
     },
     "execution_count": 52,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_purchases['client_id'].nunique()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 68,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.15     2.0\n",
       "0.95    15.0\n",
       "Name: transaction_datetime, dtype: float64"
      ]
     },
     "execution_count": 68,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_purchases.groupby(['transaction_id', 'client_id'])['transaction_datetime'].count().quantile([0.15, 0.95])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 164,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 1008x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 1008x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 1008x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "for col in [\n",
    "#     'regular_points_received', 'express_points_received',\n",
    "#     'regular_points_spent', 'express_points_spent',\n",
    "#     'purchase_sum',\n",
    "    'product_quantity', 'trn_sum_from_iss', 'trn_sum_from_red',\n",
    "]:\n",
    "    _, (ax0, ax1) = plt.subplots(1, 2, figsize=(14, 4))\n",
    "    df_purchases[col].hist(ax=ax0)\n",
    "    (np.log1p(abs(df_purchases[col])) * np.sign(df_purchases[col])).hist(ax=ax1)\n",
    "    plt.suptitle(col)\n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Transactions"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 97,
   "metadata": {},
   "outputs": [],
   "source": [
    "df_trx = df_purchases \\\n",
    "    .drop(columns=['product_id', 'product_quantity', 'trn_sum_from_iss', 'trn_sum_from_red']) \\\n",
    "    .drop_duplicates()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 201,
   "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>client_id</th>\n",
       "      <th>transaction_id</th>\n",
       "      <th>transaction_datetime</th>\n",
       "      <th>regular_points_received</th>\n",
       "      <th>express_points_received</th>\n",
       "      <th>regular_points_spent</th>\n",
       "      <th>express_points_spent</th>\n",
       "      <th>purchase_sum</th>\n",
       "      <th>store_id</th>\n",
       "      <th>transaction_month</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>000012768d</td>\n",
       "      <td>7e3e2e3984</td>\n",
       "      <td>2018-12-01 07:12:45</td>\n",
       "      <td>10.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1007.0</td>\n",
       "      <td>54a4a11a29</td>\n",
       "      <td>2018-12-01</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>19</th>\n",
       "      <td>000012768d</td>\n",
       "      <td>c1ca85d462</td>\n",
       "      <td>2018-12-16 08:56:01</td>\n",
       "      <td>5.7</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>574.0</td>\n",
       "      <td>ed8d2683fd</td>\n",
       "      <td>2018-12-01</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>30</th>\n",
       "      <td>000012768d</td>\n",
       "      <td>6a0e96d0bc</td>\n",
       "      <td>2019-03-08 10:12:03</td>\n",
       "      <td>8.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>803.0</td>\n",
       "      <td>017c89b915</td>\n",
       "      <td>2019-03-01</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>46</th>\n",
       "      <td>000012768d</td>\n",
       "      <td>b34f23306e</td>\n",
       "      <td>2019-03-14 15:01:47</td>\n",
       "      <td>2.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>419.0</td>\n",
       "      <td>017c89b915</td>\n",
       "      <td>2019-03-01</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>52</th>\n",
       "      <td>000036f903</td>\n",
       "      <td>12b218b054</td>\n",
       "      <td>2018-11-28 10:48:36</td>\n",
       "      <td>1.2</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>241.0</td>\n",
       "      <td>6381a55c22</td>\n",
       "      <td>2018-11-01</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>45786546</th>\n",
       "      <td>fffff6ce77</td>\n",
       "      <td>eba2694c0c</td>\n",
       "      <td>2019-02-28 12:56:31</td>\n",
       "      <td>1.8</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>446.0</td>\n",
       "      <td>5ec64bdccb</td>\n",
       "      <td>2019-02-01</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>45786555</th>\n",
       "      <td>fffff6ce77</td>\n",
       "      <td>bdd578a115</td>\n",
       "      <td>2019-03-05 15:07:03</td>\n",
       "      <td>0.3</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>247.0</td>\n",
       "      <td>5ec64bdccb</td>\n",
       "      <td>2019-03-01</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>45786556</th>\n",
       "      <td>fffff6ce77</td>\n",
       "      <td>6d9fc7ad6b</td>\n",
       "      <td>2019-03-06 16:26:35</td>\n",
       "      <td>0.1</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>109.0</td>\n",
       "      <td>5ec64bdccb</td>\n",
       "      <td>2019-03-01</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>45786558</th>\n",
       "      <td>fffff6ce77</td>\n",
       "      <td>b8b6e5e851</td>\n",
       "      <td>2019-03-06 16:53:10</td>\n",
       "      <td>0.2</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>245.0</td>\n",
       "      <td>6e4faad02e</td>\n",
       "      <td>2019-03-01</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>45786559</th>\n",
       "      <td>fffff6ce77</td>\n",
       "      <td>48f6d115ce</td>\n",
       "      <td>2019-03-15 17:47:02</td>\n",
       "      <td>6.7</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>676.0</td>\n",
       "      <td>5ec64bdccb</td>\n",
       "      <td>2019-03-01</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>8045229 rows × 10 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "           client_id transaction_id transaction_datetime  \\\n",
       "0         000012768d     7e3e2e3984  2018-12-01 07:12:45   \n",
       "19        000012768d     c1ca85d462  2018-12-16 08:56:01   \n",
       "30        000012768d     6a0e96d0bc  2019-03-08 10:12:03   \n",
       "46        000012768d     b34f23306e  2019-03-14 15:01:47   \n",
       "52        000036f903     12b218b054  2018-11-28 10:48:36   \n",
       "...              ...            ...                  ...   \n",
       "45786546  fffff6ce77     eba2694c0c  2019-02-28 12:56:31   \n",
       "45786555  fffff6ce77     bdd578a115  2019-03-05 15:07:03   \n",
       "45786556  fffff6ce77     6d9fc7ad6b  2019-03-06 16:26:35   \n",
       "45786558  fffff6ce77     b8b6e5e851  2019-03-06 16:53:10   \n",
       "45786559  fffff6ce77     48f6d115ce  2019-03-15 17:47:02   \n",
       "\n",
       "          regular_points_received  express_points_received  \\\n",
       "0                            10.0                      0.0   \n",
       "19                            5.7                      0.0   \n",
       "30                            8.0                      0.0   \n",
       "46                            2.0                      0.0   \n",
       "52                            1.2                      0.0   \n",
       "...                           ...                      ...   \n",
       "45786546                      1.8                      0.0   \n",
       "45786555                      0.3                      0.0   \n",
       "45786556                      0.1                      0.0   \n",
       "45786558                      0.2                      0.0   \n",
       "45786559                      6.7                      0.0   \n",
       "\n",
       "          regular_points_spent  express_points_spent  purchase_sum  \\\n",
       "0                          0.0                   0.0        1007.0   \n",
       "19                         0.0                   0.0         574.0   \n",
       "30                         0.0                   0.0         803.0   \n",
       "46                         0.0                   0.0         419.0   \n",
       "52                         0.0                   0.0         241.0   \n",
       "...                        ...                   ...           ...   \n",
       "45786546                   0.0                   0.0         446.0   \n",
       "45786555                   0.0                   0.0         247.0   \n",
       "45786556                   0.0                   0.0         109.0   \n",
       "45786558                   0.0                   0.0         245.0   \n",
       "45786559                   0.0                   0.0         676.0   \n",
       "\n",
       "            store_id transaction_month  \n",
       "0         54a4a11a29        2018-12-01  \n",
       "19        ed8d2683fd        2018-12-01  \n",
       "30        017c89b915        2019-03-01  \n",
       "46        017c89b915        2019-03-01  \n",
       "52        6381a55c22        2018-11-01  \n",
       "...              ...               ...  \n",
       "45786546  5ec64bdccb        2019-02-01  \n",
       "45786555  5ec64bdccb        2019-03-01  \n",
       "45786556  5ec64bdccb        2019-03-01  \n",
       "45786558  6e4faad02e        2019-03-01  \n",
       "45786559  5ec64bdccb        2019-03-01  \n",
       "\n",
       "[8045229 rows x 10 columns]"
      ]
     },
     "execution_count": 201,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_trx"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 98,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "095561a391-19d2967ec2    1\n",
       "a97cf352bd-2f40d4a068    1\n",
       "f70d6ad369-1d1a480d5e    1\n",
       "a1e5bd111e-0ae9c3fccd    1\n",
       "328a01845c-bf288ed310    1\n",
       "                        ..\n",
       "acd0cc7a81-493be7d242    1\n",
       "f7dbf457e8-0c1e2edf4c    1\n",
       "d385e79375-3a83c34d7f    1\n",
       "127958183b-2f4113fe87    1\n",
       "567a182495-dcf878fc9c    1\n",
       "Length: 8045229, dtype: int64"
      ]
     },
     "execution_count": 98,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "(df_trx['transaction_id'] + '-' + df_trx['client_id']).value_counts()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 54,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "client_id                  8045229\n",
       "transaction_id             8045229\n",
       "transaction_datetime       8045229\n",
       "regular_points_received    8045229\n",
       "express_points_received    8045229\n",
       "regular_points_spent       8045229\n",
       "express_points_spent       8045229\n",
       "purchase_sum               8045229\n",
       "store_id                   8045229\n",
       "dtype: int64"
      ]
     },
     "execution_count": 54,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_trx.count()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 100,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.axes._subplots.AxesSubplot at 0x7fb424d06f28>"
      ]
     },
     "execution_count": 100,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAt8AAAFmCAYAAAC1J/bkAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4xLjIsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy8li6FKAAAgAElEQVR4nO3dfbBldX3n+/dHWoyPPEhfgjRME2016MQWWmAm1wxKhEZTgikf4M5Ia4itV0j0JjexndwKKQ1TmFTGXKsiDgkdmpQBiUZhxlZk8OlOphpoEOVJ6BYhdA8CQ6PEIT4A3/vH+R3ZfVinT/c5zVr7nPN+Ve3qvb9r7bW+Rz4cv7347bVTVUiSJEl66j1t6AYkSZKkxcLhW5IkSeqJw7ckSZLUE4dvSZIkqScO35IkSVJPlgzdQF8OOuigWr58+dBtSJIkaYG7/vrr/2dVLe3atmiG7+XLl7N58+ah25AkSdICl+Tu6ba57ESSJEnqicO3JEmS1BOHb0mSJKknDt+SJElSTxy+JUmSpJ44fEuSJEk9cfiWJEmSeuLwLUmSJPXE4VuSJEnqyaL5hktJkhaC5es+P3QLY+Ou894wdAvSHvPKtyRJktQTh29JkiSpJw7fkiRJUk8cviVJkqSeOHxLkiRJPXH4liRJknoy4/Cd5LAkX0lya5Jbkryv1Q9MclWSLe3PA1o9ST6WZGuSbyU5auRYa9r+W5KsGakfneSm9p6PJclszyFJkiSNq9258v0o8LtVdSRwHHBWkiOBdcDVVbUCuLq9BjgZWNEea4HzYWKQBs4BjgWOAc6ZHKbbPu8aed/qVt+jc0iSJEnjbMbhu6ruraob2vN/Am4DDgVOATa03TYAp7bnpwAX14RNwP5JDgFOAq6qqh1V9RBwFbC6bXteVW2qqgIunnKsPTmHJEmSNLb2aM13kuXAK4FrgIOr6t626XvAwe35ocA9I2/b1mq7qm/rqDOLc0ztd22SzUk2P/DAA7v3Q0qSJElPkd0evpM8B/gM8P6qenh0W7tiXXu5t53M5hxVdUFVraqqVUuXLn2KOpMkSZJ2z5Ld2SnJ05kYvD9ZVX/fyvclOaSq7m1LPu5v9e3AYSNvX9Zq24Hjp9S/2urLOvafzTmkeWn5us8P3cLYuOu8NwzdgiRJT5ndudtJgAuB26rqP45sugKYvGPJGuDykfoZ7Y4kxwE/aEtHrgROTHJA+6DlicCVbdvDSY5r5zpjyrH25BySJEnS2NqdK9+/DLwduCnJja3274HzgMuSnAncDby1bdsIvB7YCjwCvBOgqnYk+TBwXdvvQ1W1oz1/L3AR8EzgC+3Bnp5DkiRJGmczDt9V9d+ATLP5hI79CzhrmmOtB9Z31DcDL++oP7in55AkSZLGld9wKUmSJPXE4VuSJEnqicO3JEmS1JPdutWgJKl/3oLyCd6CUtJC4ZVvSZIkqScO35IkSVJPHL4lSZKknjh8S5IkST1x+JYkSZJ64vAtSZIk9cThW5IkSeqJw7ckSZLUE4dvSZIkqScO35IkSVJPHL4lSZKknsw4fCdZn+T+JDeP1D6V5Mb2uCvJja2+PMk/j2z7xMh7jk5yU5KtST6WJK1+YJKrkmxpfx7Q6mn7bU3yrSRHjRxrTdt/S5I1e/N/EEmSJOmpsjtXvi8CVo8WquptVbWyqlYCnwH+fmTzdya3VdV7RurnA+8CVrTH5DHXAVdX1Qrg6vYa4OSRfde295PkQOAc4FjgGOCcyYFdkiRJGmczDt9V9XVgR9e2dvX6rcAluzpGkkOA51XVpqoq4GLg1Lb5FGBDe75hSv3imrAJ2L8d5yTgqqraUVUPAVcx5S8HkiRJ0jia65rvVwP3VdWWkdoRSb6R5GtJXt1qhwLbRvbZ1moAB1fVve3594CDR95zT8d7pqtLkiRJY23JHN9/Ojtf9b4XOLyqHkxyNPC5JC/b3YNVVSWpOfb0M0nWMrFkhcMPP3xvHVaSJEmalVlf+U6yBPh14FOTtar6cVU92J5fD3wHeDGwHVg28vZlrQZwX1tOMrk85f5W3w4c1vGe6epPUlUXVNWqqlq1dOnS2fyYkiRJ0l4zl2Unvwp8u6p+tpwkydIk+7Tnv8DEhyXvbMtKHk5yXFsnfgZweXvbFcDkHUvWTKmf0e56chzwg3acK4ETkxzQPmh5YqtJkiRJY23GZSdJLgGOBw5Ksg04p6ouBE7jyR+0/BXgQ0l+CjwOvKeqJj+s+V4m7pzyTOAL7QFwHnBZkjOBu5n4ACfARuD1wFbgEeCdAFW1I8mHgevafh8aOYckSZI0tmYcvqvq9Gnq7+iofYaJWw927b8ZeHlH/UHghI56AWdNc6z1wPpd9S1JkiSNG7/hUpIkSeqJw7ckSZLUE4dvSZIkqScO35IkSVJPHL4lSZKknjh8S5IkST1x+JYkSZJ64vAtSZIk9cThW5IkSeqJw7ckSZLUE4dvSZIkqScO35IkSVJPHL4lSZKknjh8S5IkST1x+JYkSZJ64vAtSZIk9WTG4TvJ+iT3J7l5pPZHSbYnubE9Xj+y7YNJtia5PclJI/XVrbY1ybqR+hFJrmn1TyXZt9Wf0V5vbduXz3QOSZIkaZztzpXvi4DVHfWPVtXK9tgIkORI4DTgZe09H0+yT5J9gL8ATgaOBE5v+wJ8pB3rRcBDwJmtfibwUKt/tO037Tn27MeWJEmS+jfj8F1VXwd27ObxTgEuraofV9V3ga3AMe2xtarurKqfAJcCpyQJ8Frg0+39G4BTR461oT3/NHBC23+6c0iSJEljbckc3nt2kjOAzcDvVtVDwKHAppF9trUawD1T6scCzwe+X1WPdux/6OR7qurRJD9o++/qHDtJshZYC3D44YfP4keUJEkab8vXfX7oFsbGXee9YegWZjTbD1yeD7wQWAncC/zZXutoL6qqC6pqVVWtWrp06dDtSJIkaZGb1fBdVfdV1WNV9Tjwlzyx7GM7cNjIrstabbr6g8D+SZZMqe90rLZ9v7b/dMeSJEmSxtqshu8kh4y8fBMweSeUK4DT2p1KjgBWANcC1wEr2p1N9mXiA5NXVFUBXwHe3N6/Brh85Fhr2vM3A19u+093DkmSJGmszbjmO8klwPHAQUm2AecAxydZCRRwF/BugKq6JcllwK3Ao8BZVfVYO87ZwJXAPsD6qrqlneIDwKVJ/hj4BnBhq18I/E2SrUx84PO0mc4hSZIkjbMZh++qOr2jfGFHbXL/c4FzO+obgY0d9TvpuFtJVf0IeMuenEOSJEkaZ37DpSRJktQTh29JkiSpJw7fkiRJUk8cviVJkqSeOHxLkiRJPXH4liRJknri8C1JkiT1xOFbkiRJ6onDtyRJktQTh29JkiSpJw7fkiRJUk8cviVJkqSeOHxLkiRJPXH4liRJknri8C1JkiT1xOFbkiRJ6smMw3eS9UnuT3LzSO1Pk3w7ybeSfDbJ/q2+PMk/J7mxPT4x8p6jk9yUZGuSjyVJqx+Y5KokW9qfB7R62n5b23mOGjnWmrb/liRr9ub/IJIkSdJTZXeufF8ErJ5Suwp4eVX9EnAH8MGRbd+pqpXt8Z6R+vnAu4AV7TF5zHXA1VW1Ari6vQY4eWTfte39JDkQOAc4FjgGOGdyYJckSZLG2YzDd1V9Hdgxpfalqnq0vdwELNvVMZIcAjyvqjZVVQEXA6e2zacAG9rzDVPqF9eETcD+7TgnAVdV1Y6qeoiJvwhM/cuBJEmSNHb2xprv3wC+MPL6iCTfSPK1JK9utUOBbSP7bGs1gIOr6t72/HvAwSPvuafjPdPVnyTJ2iSbk2x+4IEH9vDHkiRJkvauOQ3fSf4AeBT4ZCvdCxxeVa8Efgf42yTP293jtaviNZeephzvgqpaVVWrli5durcOK0mSJM3KrIfvJO8Afg34t21opqp+XFUPtufXA98BXgxsZ+elKctaDeC+tpxkcnnK/a2+HTis4z3T1SVJkqSxNqvhO8lq4PeBN1bVIyP1pUn2ac9/gYkPS97ZlpU8nOS4dpeTM4DL29uuACbvWLJmSv2MdteT44AftONcCZyY5ID2QcsTW02SJEkaa0tm2iHJJcDxwEFJtjFxp5EPAs8Armp3DNzU7mzyK8CHkvwUeBx4T1VNfljzvUzcOeWZTKwRn1wnfh5wWZIzgbuBt7b6RuD1wFbgEeCdAFW1I8mHgevafh8aOYckSZI0tmYcvqvq9I7yhdPs+xngM9Ns2wy8vKP+IHBCR72As6Y51npg/fRdS5IkSePHb7iUJEmSeuLwLUmSJPXE4VuSJEnqicO3JEmS1BOHb0mSJKknDt+SJElSTxy+JUmSpJ44fEuSJEk9cfiWJEmSeuLwLUmSJPXE4VuSJEnqicO3JEmS1BOHb0mSJKknDt+SJElSTxy+JUmSpJ7s1vCdZH2S+5PcPFI7MMlVSba0Pw9o9ST5WJKtSb6V5KiR96xp+29JsmakfnSSm9p7PpYksz2HJEmSNK5298r3RcDqKbV1wNVVtQK4ur0GOBlY0R5rgfNhYpAGzgGOBY4Bzpkcpts+7xp53+rZnEOSJEkaZ7s1fFfV14EdU8qnABva8w3AqSP1i2vCJmD/JIcAJwFXVdWOqnoIuApY3bY9r6o2VVUBF0851p6cQ5IkSRpbc1nzfXBV3duefw84uD0/FLhnZL9trbar+raO+mzOIUmSJI2tvfKBy3bFuvbGsfbmOZKsTbI5yeYHHnjgKepMkiRJ2j1zGb7vm1zq0f68v9W3A4eN7Les1XZVX9ZRn805dlJVF1TVqqpatXTp0j3+ASVJkqS9aS7D9xXA5B1L1gCXj9TPaHckOQ74QVs6ciVwYpID2gctTwSubNseTnJcu8vJGVOOtSfnkCRJksbWkt3ZKcklwPHAQUm2MXHXkvOAy5KcCdwNvLXtvhF4PbAVeAR4J0BV7UjyYeC6tt+HqmryQ5zvZeKOKs8EvtAe7Ok5JEmSpHG2W8N3VZ0+zaYTOvYt4KxpjrMeWN9R3wy8vKP+4J6eQ5IkSRpXfsOlJEmS1BOHb0mSJKknDt+SJElSTxy+JUmSpJ44fEuSJEk9cfiWJEmSeuLwLUmSJPXE4VuSJEnqicO3JEmS1BOHb0mSJKknDt+SJElSTxy+JUmSpJ44fEuSJEk9cfiWJEmSeuLwLUmSJPXE4VuSJEnqyayH7yQvSXLjyOPhJO9P8kdJto/UXz/yng8m2Zrk9iQnjdRXt9rWJOtG6kckuabVP5Vk31Z/Rnu9tW1fPtufQ5IkSerLrIfvqrq9qlZW1UrgaOAR4LNt80cnt1XVRoAkRwKnAS8DVgMfT7JPkn2AvwBOBo4ETm/7AnykHetFwEPAma1+JvBQq3+07SdJkiSNtb217OQE4DtVdfcu9jkFuLSqflxV3wW2Ase0x9aqurOqfgJcCpySJMBrgU+3928ATh051ob2/NPACW1/SZIkaWztreH7NOCSkddnJ/lWkvVJDmi1Q4F7RvbZ1mrT1Z8PfL+qHp1S3+lYbfsP2v47SbI2yeYkmx944IG5/HySJEnSnM15+G7rsN8I/F0rnQ+8EFgJ3Av82VzPMVtVdUFVraqqVUuXLh2qDUmSJAnYO1e+TwZuqKr7AKrqvqp6rKoeB/6SiWUlANuBw0bet6zVpqs/COyfZMmU+k7Hatv3a/tLkiRJY2tvDN+nM7LkJMkhI9veBNzcnl8BnNbuVHIEsAK4FrgOWNHubLIvE0tYrqiqAr4CvLm9fw1w+cix1rTnbwa+3PaXJEmSxtaSmXeZXpJnA68D3j1S/pMkK4EC7prcVlW3JLkMuBV4FDirqh5rxzkbuBLYB1hfVbe0Y30AuDTJHwPfAC5s9QuBv0myFdjBxMAuSZIkjbU5Dd9V9b+Y8kHHqnr7LvY/Fzi3o74R2NhRv5Mnlq2M1n8EvGUWLUuSJEmD8RsuJUmSpJ44fEuSJEk9cfiWJEmSeuLwLUmSJPXE4VuSJEnqicO3JEmS1BOHb0mSJKknDt+SJElSTxy+JUmSpJ44fEuSJEk9cfiWJEmSeuLwLUmSJPXE4VuSJEnqyZKhG1hslq/7/NAtjI27znvD0C1IkiT1yivfkiRJUk/mPHwnuSvJTUluTLK51Q5MclWSLe3PA1o9ST6WZGuSbyU5auQ4a9r+W5KsGakf3Y6/tb03uzqHJEmSNK721pXv11TVyqpa1V6vA66uqhXA1e01wMnAivZYC5wPE4M0cA5wLHAMcM7IMH0+8K6R962e4RySJEnSWHqqlp2cAmxozzcAp47UL64Jm4D9kxwCnARcVVU7quoh4Cpgddv2vKraVFUFXDzlWF3nkCRJksbS3hi+C/hSkuuTrG21g6vq3vb8e8DB7fmhwD0j793Waruqb+uo7+ockiRJ0ljaG3c7+d+ranuS/w24Ksm3RzdWVSWpvXCeaU13jvaXgbUAhx9++FPZgiRJkjSjOV/5rqrt7c/7gc8ysWb7vrZkhPbn/W337cBhI29f1mq7qi/rqLOLc4z2dkFVraqqVUuXLp3LjylJkiTN2ZyG7yTPTvLcyefAicDNwBXA5B1L1gCXt+dXAGe0u54cB/ygLR25EjgxyQHtg5YnAle2bQ8nOa7d5eSMKcfqOockSZI0lua67ORg4LPt7n9LgL+tqi8muQ64LMmZwN3AW9v+G4HXA1uBR4B3AlTVjiQfBq5r+32oqna05+8FLgKeCXyhPQDOm+YckiRJ0lia0/BdVXcCr+ioPwic0FEv4KxpjrUeWN9R3wy8fHfPIUmSJI0rv+FSkiRJ6onDtyRJktQTh29JkiSpJw7fkiRJUk8cviVJkqSeOHxLkiRJPXH4liRJknri8C1JkiT1xOFbkiRJ6onDtyRJktQTh29JkiSpJw7fkiRJUk8cviVJkqSeOHxLkiRJPXH4liRJknri8C1JkiT1ZNbDd5LDknwlya1Jbknyvlb/oyTbk9zYHq8fec8Hk2xNcnuSk0bqq1tta5J1I/UjklzT6p9Ksm+rP6O93tq2L5/tzyFJkiT1ZS5Xvh8FfreqjgSOA85KcmTb9tGqWtkeGwHattOAlwGrgY8n2SfJPsBfACcDRwKnjxznI+1YLwIeAs5s9TOBh1r9o20/SZIkaazNeviuqnur6ob2/J+A24BDd/GWU4BLq+rHVfVdYCtwTHtsrao7q+onwKXAKUkCvBb4dHv/BuDUkWNtaM8/DZzQ9pckSZLG1l5Z892WfbwSuKaVzk7yrSTrkxzQaocC94y8bVurTVd/PvD9qnp0Sn2nY7XtP2j7T+1rbZLNSTY/8MADc/oZJUmSpLma8/Cd5DnAZ4D3V9XDwPnAC4GVwL3An831HLNVVRdU1aqqWrV06dKh2pAkSZKAOQ7fSZ7OxOD9yar6e4Cquq+qHquqx4G/ZGJZCcB24LCRty9rtenqDwL7J1kypb7Tsdr2/dr+kiRJ0tiay91OAlwI3FZV/3GkfsjIbm8Cbm7PrwBOa3cqOQJYAVwLXAesaHc22ZeJD2VeUVUFfAV4c3v/GuDykWOtac/fDHy57S9JkiSNrSUz7zKtXwbeDtyU5MZW+/dM3K1kJVDAXcC7AarqliSXAbcycaeUs6rqMYAkZwNXAvsA66vqlna8DwCXJvlj4BtMDPu0P/8myVZgBxMDuyRJkjTWZj18V9V/A7ruMLJxF+85Fzi3o76x631VdSdPLFsZrf8IeMue9CtJkiQNzW+4lCRJknri8C1JkiT1xOFbkiRJ6onDtyRJktQTh29JkiSpJw7fkiRJUk8cviVJkqSeOHxLkiRJPXH4liRJknri8C1JkiT1xOFbkiRJ6onDtyRJktQTh29JkiSpJw7fkiRJUk8cviVJkqSeOHxLkiRJPZnXw3eS1UluT7I1ybqh+5EkSZJ2Zd4O30n2Af4COBk4Ejg9yZHDdiVJkiRNb94O38AxwNaqurOqfgJcCpwycE+SJEnStFJVQ/cwK0neDKyuqt9sr98OHFtVZ4/ssxZY216+BLi990bH00HA/xy6CY0dc6Eu5kJdzIW6mIsn/IuqWtq1YUnfnfSpqi4ALhi6j3GTZHNVrRq6D40Xc6Eu5kJdzIW6mIvdM5+XnWwHDht5vazVJEmSpLE0n4fv64AVSY5Isi9wGnDFwD1JkiRJ05q3y06q6tEkZwNXAvsA66vqloHbmi9ciqMu5kJdzIW6mAt1MRe7Yd5+4FKSJEmab+bzshNJkiRpXnH4liRJknri8C1JkiT1ZN5+4FK7J0mY+DbQQ1tpO3Btudh/UTMX6mIu1MVcaDpJDmYkF1V135D9zBd+4HIBS3Ii8HFgC0/cA30Z8CLgvVX1paF603DMhbqYC3UxF+qSZCXwCWA/ds7F95nIxQ1D9TYfOHwvYEluA06uqrum1I8ANlbVLw7SmAZlLtTFXKiLuVCXJDcC766qa6bUjwP+U1W9YpjO5gfXfC9sS4BtHfXtwNN77kXjw1yoi7lQF3OhLs+eOngDVNUm4NkD9DOvuOZ7YVsPXJfkUuCeVjuMiW8DvXCwrjQ0c6Eu5kJdzIW6fCHJ54GL2TkXZwBfHKyrecJlJwtckiOBN7LzB2WuqKpbh+tKQzMX6mIu1MVcqEuSk4FTeHIuNg7X1fzg8L1IJDkQoKp2DN2Lxoe5UBdzoS7mQto7XPO9gCU5PMmlSe4HrgGuTXJ/qy0ftjsNxVyoi7lQF3OhLkn2S3JektuS7EjyYHt+XpL9h+5v3Dl8L2yfAj4LHFJVK6rqRcAhwOeASwftTEMyF+piLtTFXKjLZcBDwGuq6sCqej7wGiZuNXjZoJ3NAy47WcCSbKmqFXu6TQubuVAXc6Eu5kJdktxeVS/Z022a4N1OFrbrk3wc2MDOn0ZeA3xjsK40NHOhLuZCXcyFutyd5PeBDZPfatm+7fIdPJETTcMr3wtYkn2BM9n508jbgP8MXFhVPx6qNw3HXKiLuVAXc6EuSQ4A1jGRi4OBAu4DrgA+4odyd83hW5IkSeqJH7hcJJL82q5ea3EyF+piLtTFXKhLkqN29VpP5vC9eLxqhtdanMyFupgLdTEX6vJ/zvBaU7jsRJIkSeqJdztZ4JK8lO6vf71tuK40NHOhLuZCXcyFuiTZD1jNzrm4sqq+P1xX84PLThawJB9g4ksQAlzbHgEuSbJuyN40HHOhLuZCXcyFuiQ5A7gBOB54Vnu8holbU54xYGvzgstOFrAkdwAvq6qfTqnvC9zilyMsTuZCXcyFupgLdUlyO3Ds1Kvc7RaE11TVi4fpbH7wyvfC9jjwgo76IW2bFidzoS7mQl3MhbqEiXt7T/V426ZdcM33wvZ+4OokW3jiG6cOB14EnD1YVxqauVAXc6Eu5kJdzgVuSPIlds7F64APD9bVPOGykwUuydOAY9j5AxHXVdVjw3WloZkLdTEX6mIu1KUtMTmJJ3/g8qHhupofvPK98NXIY/K1/6lQ5kJdzIW6mAs9SVU9lOQrjAzfDt67xyvfC1iSE4GPA1uY+BspwDIm/nPhe6vqS0P1puGYC3UxF+piLtQlyUrgE8B+wDYm1nkvA77PRC5uGLC9sefwvYAluQ04uarumlI/AthYVb84SGMalLlQF3OhLuZCXZLcCLy7qq6ZUj8O+E9V9YphOpsfvNvJwraEib+RTrUdeHrPvWh8mAt1MRfqYi7U5dlTB2+AqtoEPHuAfuYV13wvbOuB65JcyhOfRj4MOA24cLCuNDRzoS7mQl3Mhbp8IcnngYvZORdnAF8crKt5wmUnC1ySX6T7a4FvHa4rDc1cqIu5UBdzoS5JTqY7FxuH62p+cPiWJEmSeuKa70UiyR/t6rUWJ3OhLuZCXcyFuiRZu6vXejKH78Xj+hlea3EyF+piLtTFXKjL1K+T9+vlZ+CyE0mSJKkn3u1kAUuyBDgTeBPwglbeDlwOXFhVPx2qNw3HXKiLuVAXc6HpJDkJOJWdP3B5eVV5t5MZeOV7AUtyCRPfNrWBJ+7TugxYAxxYVW8bqjcNx1yoi7lQF3OhLkn+HHgxE7caHM3FGcCWqnrfUL3NBw7fC1iSO6rqxXu6TQubuVAXc6Eu5kJdpvtnnyTAHVW1YoC25g0/cLmw7UjyliQ/++ec5GlJ3gY8NGBfGpa5UBdzoS7mQl1+lORVHfVXAT/qu5n5xivfC1iS5cBHgNcy8UsywP7Al4F1VfXdwZrTYMyFupgLdTEX6pLkKOB84Lk8sezkMOAHwFlV5Z1wdsHhe5FI8nyAqnpw6F40PsyFupgLdTEXmirJzzPygcuq+t6Q/cwXDt8LXJKX8uSvf728qr49XFcamrlQF3OhLuZCXZLsB6xm51xcWVXfH66r+cE13wtYkg8AlzLxnwmvbY8AlyZZN2RvGo65UBdzoS7mQl2SnAHcABwPPKs9XgNc37ZpF7zyvYAluQN42dT7sCbZF7jFTyMvTuZCXcyFupgLdUlyO3Ds1KvcSQ4ArvEuOLvmle+F7XGe+FKEUYe0bVqczIW6mAt1MRfqEqDr6u3j+PXyM/IbLhe29wNXJ9kC3NNqhwMvAs4erCsNzVyoi7lQF3OhLucCNyT5Ejvn4nXAhwfrap5w2ckC1+7Negw7fyDiuqp6bLiuNDRzoS7mQl3Mhbq0JSYn8eQPXHr/9xk4fEuSJEk9cc23JEmS1BOHb0mSJKknDt+SJElSTxy+F6kkNw3dg8aPuVAXc6Eu5kJdknxh6B7GnbcaXMCS/Pp0m4Cf77MXjQ9zoS7mQl3MhbokOWq6TcDKPnuZjxy+F7ZPAZ+k+0b4P9dzLxof5kJdzIW6mAt1uQ74Gt1fqLN/z73MO95qcAFLcj2wpqpu7th2T1UdNkBbGpi5UBdzoS7mQl2S3Ay8qaq2dGwzFzNwzffC9n7g4Wm2vanPRjRWzIW6mAt1MRfq8kdMP0P+Vo99zEte+ZYkSZJ64prvBSzJEuBMJq5OvKCVtwOXAxdW1U+H6k3DMRfqYi7UxVxoOklOAk5l56+Xv7yqvjhcV/ODV74XsCSXAN8HNgDbWnkZsAY4sKreNlRvGo65UBdzoS7mQl2S/DnwYuBids7FGcCWqnrfUL3NBw7fC1iSO6rqxXu6TQubuVAXc6Eu5kJdpvtnnyTAHVW1YoC25g0/cLmw7UjylpTgFmgAAAqlSURBVCQ/++ec5GlJ3gY8NGBfGpa5UBdzoS7mQl1+lORVHfVXAT/qu5n5xivfC1iS5cBHgNfyxC/JA4AvA+uq6rvDdKYhmQt1MRfqYi7UpX3JzvnAc3li2clhwA+As6rq+qF6mw8cvheJJM8HqKoHh+5F48NcqIu5UBdzoamS/DwjH7isqu8N2c984bKTRaKqHqyqB5NcMHQvGh/mQl3MhbqYC01VVd+rquvble73DN3PfOHwvfisGroBjSVzoS7mQl3Mhbq8cegG5guH78Xn/qEb0FgyF+piLtTFXKhLhm5gvnDNtyRJkuYkydOq6vGh+5gPvPK9SLlmb/FKsk+Sdyf5cJJfnrLt/xmqL40vf18sXv6+UJckz0ry+0l+L8nPJXkH8Lkkf5LkOUP3N+688r2AJTlwuk3AN6tqWZ/9aDwk+SvgWcC1wNuBr1XV77RtN1TVUUP2p2H4+0Jd/H2hLkkuA+4Bngm8BLgN+BQT675/vqrePmB7Y8/hewFL8hhwNzuvw6r2+tCq2neQxjSoJN+qql9qz5cAHwcOAk4HNlXVK4fsT8Pw94W6+PtCXZLcWFUr2zda3gscUlXVXn9zMjPqtmToBvSUuhM4oar+ceqGJPcM0I/Gw8+GqKp6FFib5A+Z+NIM/3Ph4uXvC3Xx94Wm1QbujdWu5LbXXtWdgWu+F7Y/Z+KbyLr8SZ+NaKxsTrJ6tFBVHwL+Glg+SEcaB/6+UBd/X6jL5sm13VX1G5PFJC8E/mmwruYJl51IkiRpr0iScrjcJZedLFJJXldVVw3dh8aLuVjckrwUOIWRr4sGrqiq24brSkMzF+piLmbPZSeL14VDN6CxZC4WqSQfAC5l4gOW17ZHgEuSrBuyNw3HXKiLuZgbl50sYEmumG4T8Nqqenaf/Wg8mAt1SXIH8LKq+umU+r7ALVW1YpjONCRzoS7mYm5cdrKwvRr4d8APp9QDHNN/OxoT5kJdHgdewMTtBkcd0rZpcTIX6mIu5sDhe2HbBDxSVV+buiHJ7QP0o/FgLtTl/cDVSbYw8eUZAIcDLwLOHqwrDc1cqIu5mAOXnUiSAEjyNCb+68foB6iuq6rHhutKQzMX6mIuZs/he5FJ8mtV9V+G7kPjxVyoS5K1VXXB0H1ovJgLdTEXu8/he5FJckNVHTV0Hxov5kJdzIW6mAt1MRe7z1sNLj4ZugGNJXOhLuZCXcyFupiL3eSV70UmyTFVde3QfWi8mAt1SbKsqrYN3YfGi7lQF3Ox+xy+F7B2v83TgP9RVf81yf8B/GvgNuCCqffn1OJgLjSdJL8A/DpwGPAYcAfwt1X18KCNaVDmQl3Mxey57GRh+2vgDcD7kvwN8BbgGuBVwF8N2ZgGZS70JEl+G/gE8HNMZOEZTPyf6qYkxw/YmgZkLtTFXMyNV74XsCTfqqpfSrKEiVsAvaCqHksS4JtV9UsDt6gBmAt1SXITsLJl4VnAxqo6PsnhwOVV9cqBW9QAzIW6mIu58cr3wva0tsTgucCzgP1a/RnA0wfrSkMzF5rO5BevPQN4DkBV/SPmYrEzF+piLmbJb7hc2C4Evg3sA/wB8HdJ7gSOAy4dsjENylyoy18B1yW5Bng18BGAJEuBHUM2pkGZC3UxF3PgspMFLskLAKrqfyTZH/hV4B+9s8XiZi7UJcnLgF8Ebq6qbw/dj8aDuVAXczF7Dt+LVJLnVNUPh+5D48VcqIu5UBdzoS7mYmau+V68bh26AY0lc6Eu5kJdzIW6mIsZuOZ7AUvyO9Nton04QouPuVAXc6Eu5kJdzMXceOV7YfsPwAFM3NVi9PEc/Ge/mJkLdTEX6mIu1MVczIFXvhe2G4DPVdX1Uzck+c0B+tF4MBfqYi7UxVyoi7mYAz9wuYAleQmwo6oe6Nh2cFXdN0BbGpi5UBdzoS7mQl3Mxdw4fEuSJEk9cV3OApZkvyTnJfl2kh1JHkxyW6vtP3R/Goa5UBdzoS7mQl3Mxdw4fC9slwEPAcdX1YFV9XzgNa122aCdaUjmQl3MhbqYC3UxF3PgspMFLMntVfWSPd2mhc1cqIu5UBdzoS7mYm688r2w3Z3k95McPFlIcnCSDwD3DNiXhmUu1MVcqIu5UBdzMQcO3wvb24DnA19ra7J2AF8FDgTeOmRjGpS5UBdzoS7mQl3MxRy47ESSJEnqiVe+F7gkL01yQpJnT6mvHqonDc9cqIu5UBdzoS7mYvYcvhewJL8NXA78FnBLklNGNv+HYbrS0MyFupgLdTEX6mIu5savl1/Y3gUcXVU/TLIc+HSS5VX1/wIZtDMNyVyoi7lQF3OhLuZiDhy+F7anVdUPAarqriTHM/EvyL/AfzkWM3OhLuZCXcyFupiLOXDZycJ2X5KVky/avyi/BhwE/MvButLQzIW6mAt1MRfqYi7mwLudLGBJlgGPVtX3Orb9clX9wwBtaWDmQl3MhbqYC3UxF3Pj8C1JkiT1xGUnkiRJUk8cviVJkqSeOHxLkiRJPXH4lqSnWJL9k7x36D5GJXlHkheMvP6rJEcO2dPuSHLqaJ9Jvppk1ZA9SdKecPiWpKfe/sCThu8kQ37XwjuAnw3fVfWbVXXrcO3stlOBsf9LgiRNx+Fbkp565wEvTHJjkuuS/H9JrgBuBUjyuSTXJ7klydrJNyX5YZJzk3wzyaYkB7f6W5Lc3Opfb7Xl7bg3tMe/HjnOB5Lc1PY/L8mbgVXAJ1tPzxy9gpzk9Lb/zUk+MlM/XZJclOT8tt+dSY5Psj7JbUkuGtlvt8/VfqY3An/a+n5h2/0tSa5NckeSV8/+H5MkPfUcviXpqbcO+E5VrQR+DzgKeF9Vvbht/42qOpqJgfi3kzy/1Z8NbKqqVwBfZ+IrnQH+EDip1d/YavcDr6uqo4C3AR8DSHIycApwbNv/T6rq08Bm4N9W1cqq+ufJRttSlI8ArwVWAq9KcuoM/UznAOBfAf8XcAXwUeBlwL9MsnJPz1VV/70d5/da399p+y6pqmOA9wPnzNCTJA3K4VuS+ndtVX135PVvJ/kmsAk4DFjR6j8B/kt7fj2wvD3/B+CiJO8C9mm1pwN/meQm4O94YmnGrwJ/XVWPAFTVjhl6exXw1ap6oKoeBT4J/MoM/UznP9fEl0ncBNxXVTdV1ePALe29e+tcf78HPUnSoIZcbyhJi9X/mnyS5HgmBuR/VVWPJPkq8HNt80/riW9Ce4z2O7uq3pPkWOANwPVJjgZ+C7gPeAUTF1Z+9BT03dnPLvy4/fn4yPPJ10uAn+6lc/14N/eTpMF55VuSnnr/BDx3mm37AQ+1wfulwHEzHSzJC6vqmqr6Q+ABJq6W7wfc264sv50nrohfBbwzybPaew+coadrgX+T5KAk+wCnA1/bnR9yFmZzrl39bylJY8/hW5KeYlX1IPAPSW4G/nTK5i8CS5LcxsQHMzftxiH/dPJDisB/B74JfBxY05avvJR2db2qvsjEOunNSW4E/u92jIuAT0x+4HKk13uZWKP+lXbc66vq8ln82DOa5bkuBX4vyTdGPnApSfNGnvivepIkSZKeSl75liRJknriB1MkSbOW5A+At0wp/11VnTtEP5I07lx2IkmSJPXEZSeSJElSTxy+JUmSpJ44fEuSJEk9cfiWJEmSevL/A9pIQZfYfeBsAAAAAElFTkSuQmCC\n",
      "text/plain": [
       "<Figure size 864x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "df_trx.groupby('transaction_month')['transaction_id'].count().plot(figsize=(12, 4), kind='bar')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 147,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.axes._subplots.AxesSubplot at 0x7faf99271128>"
      ]
     },
     "execution_count": 147,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 864x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "df_trx['store_id'].value_counts().reset_index(drop=True).plot(figsize=(12, 4), grid=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 51,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 864x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "df_trx.groupby('client_id')['transaction_id'].count().clip(None, 150).hist(bins=20, figsize=(12, 4))\n",
    "plt.title('Trx per client')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 65,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.15     5.0\n",
       "0.95    54.0\n",
       "Name: transaction_id, dtype: float64"
      ]
     },
     "execution_count": 65,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_trx.groupby('client_id')['transaction_id'].count().quantile([0.15, 0.95])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 203,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 864x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "df_purchases.groupby('client_id')['transaction_id'].count().clip(None, 800).hist(bins=20, figsize=(12, 4))\n",
    "plt.title('Products per client')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 66,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.15     29.0\n",
       "0.95    312.0\n",
       "Name: transaction_id, dtype: float64"
      ]
     },
     "execution_count": 66,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_purchases.groupby('client_id')['transaction_id'].count().quantile([0.15, 0.95])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 112,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "client_id\n",
       "000012768d                NaT\n",
       "000012768d   15 days 01:43:16\n",
       "000012768d   82 days 01:16:02\n",
       "000012768d    6 days 04:49:44\n",
       "000036f903                NaT\n",
       "                   ...       \n",
       "fffff6ce77    1 days 11:54:23\n",
       "fffff6ce77    5 days 02:10:32\n",
       "fffff6ce77    1 days 01:19:32\n",
       "fffff6ce77    0 days 00:26:35\n",
       "fffff6ce77    9 days 00:53:52\n",
       "Name: transaction_datetime, Length: 8045229, dtype: timedelta64[ns]"
      ]
     },
     "execution_count": 112,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_trx.sort_values(['client_id', 'transaction_datetime']).set_index('client_id') \\\n",
    "    .groupby(level='client_id')['transaction_datetime'].diff()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 123,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.axes._subplots.AxesSubplot at 0x7fb42573f7b8>"
      ]
     },
     "execution_count": 123,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 864x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "df_trx.sort_values(['client_id', 'transaction_datetime']).set_index('client_id') \\\n",
    "    .groupby(level='client_id')['transaction_datetime'].diff().dropna() \\\n",
    "    .astype(int).div(1e9 * 24 * 60 * 60).clip(None, 30).hist(bins=20, figsize=(12, 4))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 163,
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 1008x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA04AAAEVCAYAAADXdrWcAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4xLjIsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy8li6FKAAAgAElEQVR4nO3df5RlZX3n+/cntBii8ktMLexmhIk98SIuiXaAjLm5FZlAQzJpZy11IEzoOMTOukKic1kTMXPX5UblLr03hAhR73RCD+AQkWviakYx2BetScy6IBiJCMii5EfoTgOR5oeto07r9/5xnpJjWVW7fp06Xafer7XOqn2e/ez9PN99Tp9vfevsvTtVhSRJkiRpdj827AlIkiRJ0sHOwkmSJEmSOlg4SZIkSVIHCydJkiRJ6mDhJEmSJEkdLJwkSZIkqYOFkyRp1Uny6SRbhz2P5ZbkvCSfGcB+x5PsXu79StJaEv8fJ0nSKEsyAfznqvrTYc9lWJKM0zsGG4Y9F0larfzGSZIEQHrMC/OQ5JBhz0GStLJMkJK0SiR5aZI/T/KPSR5K8jut/eYkl/f1uyHJjrb8G0n+JskfJ3kmyVeTnN7XdyLJZUn+BvgW8E+THJHk6iR7k+xJ8t6pQiHJy5P817avryf5WGtPkiuSPJHk2SR3JzmpI55rkvzfSXYl+Ubb78v61v/zJHe0se5I8s+nzfs3+2L8fJI/SPJUOzZntXWXAf8j8MdJ9rfjsNi5frgd628Cv5jk+W3Mv0/yeIvlsL5ttiS5q43xtSSbW/tcx/c3kny+LX84yR9Mm8fOJP/LXO+Htu6wNuenktwL/Oxc8UmSulk4SdIq0L4J+i/A3wHrgdOBdyQ5E/i3wK8neX2S84BTgLf3bX4q8DXgGOBS4C+SHN23/teBbcCLgEeAa4ADwMuBnwHOAH6z9X0P8BngKGADcFVrPwP4BeCfAUcAbwaenEdo57V9HgPcBVzf4j0a+BRwJfBi4A+BTyV58Sz7ORW4v+3n/wSuTpKq+g/AXwMXVdULq+qiJcz114DL6B2nzwPva/s4md6xWg/8b23+pwDXAf8eOLKN93DbzzXMfnz7fRT410nS9nlU63tDx/sBeq/zT7XHmcDIXQ8mSSvNwkmSVoefBV5SVe+uqu9W1YPAnwDnVNVjwP8MXAt8ADi/qr7Rt+0TwB9V1X+vqo/RKzB+uW/9NVV1T1UdAI4GzgbeUVXfrKongCuAc1rf/w68DHhpVX27qj7f1/4i4BX0rp+9r6r2ziOuT1XVX1XVd4D/APxckuPa/B6oqo9U1YGq+ijwVeBfzrKfR6rqT6rqe+04HAuMzdJ3sXPdWVV/U1XfB75Dr9j8d1W1rx3v/4PnjtMFwI6q2lVV36+qPVX11SRjzH18+/01UPS+MQN4I/D/VdU/MMf7ofV9M3BZm9uj9ApQSdISWDhJ0urwMuClSZ6eegC/x3PFwX8BDgHu7ytmpuypH74T0CPAS/uePzptnOcBe/vG+Y/AT7b1vwsE+EKSe5L8W4Cq+izwx8AHgSeSbE9y+Dzi+sHYVbUf2Nfm9tI2z36P0Pt2ZSaP9e3nW23xhTN1XI65Ai8BfgL4Yt9x+svWDnAcvW/5pus6vv3zLOAG4NzW9Gu0b+Tofj+8dNp8px9LSdICWThJ0urwKPBQVR3Z93hRVZ3d1l8G3Accm+Tcaduunzrdq/knwD/0Pe8vqh6l923KMX3jHF5VrwSoqseq6q1V9VLgt4APJXl5W3dlVb0WOJHeKWz/fh5xHTe1kOSF9L7x+of2eNm0vv8E2DOPfU73I7ePXeRc+/fzdeC/Aa/sO05HVNVUsfYovdPkppvz+M7go8Ab27VfpwJ/3refud4Pe+k7tvSOnSRpCSycJGl1+ALwjSTvbBf+H5LkpCQ/m+QXgLcA59O7luWqJP3fzPwk8DtJnpfkTcD/ANw80yDtlLXPAJcnOTzJjyX5qST/E0CSNyWZuqX1U/SKie+3eZya5HnAN4FvA9+fR1xnJ/n5JIfSu9bptnZq2c3AP0vya0nWJfnX9IqcT87/kP3A48A/nXqyhLn+QDtd70+AK5L8ZNvv+r5rjK4G3pLk9HYM1yd5RdfxnWGcL9Er0v4UuKWqnm6rZn0/tPU3Au9KclR7vX57IfFJkn6UhZMkrQLt2p1foXcjgod47pfpY+ndhOCidh3NX9P7pf0/9X3LdDuwsW1zGfDGqprrZgjnA4cC99Irjj7exoHetTW3J9kP3AS8vV1fczi9QuIpeqeFPQn8X/MI7c/o3chgH/Ba4N+0eJ9s8V7c9vW7wK9U1dfnsc/pPkDvW5unkly5hLlO905gErgtybPA/wv8dJv/F+gVs1cAzwD/lee+QZvr+M7kz4B/0X7S9j/b++GI1uX3W2wP0SvUPrKI+CRJffwPcCVphCX5DeA3q+rnhz2X6ZJcA+yuqv912HORJKmL3zhJkiRJUgcLJ0nSwLQ77+2f4XHesOc23WqaqyRp5XmqniRJkiR18BsnSZIkSepg4SRJkiRJHSycJEmSJKmDhZMkSZIkdbBwkiRJkqQOFk6SJEmS1MHCSZIkSZI6WDhJkiRJUgcLJ0mSJEnqYOEkSZIkSR0snCRJkiSpg4WTJEmSJHWwcJIkSZKkDhZOkiRJktRh3bAnsFKOOeaYOv744xe9/Te/+U1e8IIXLN+EDhLGtbqMYlyjGBMY12y++MUvfr2qXrKMUxoZ5qluox7jqMcHxjgKRj2+ufLUmimcjj/+eO68885Fbz8xMcH4+PjyTeggYVyryyjGNYoxgXHNJskjyzeb0WKe6jbqMY56fGCMo2DU45srT3mqniRJkiR1sHCSJEmSpA4WTpIkSZLUwcJJkiRJkjpYOEmSJElSBwsnSZIkSeowr8Ipyb9Lck+SryT5aJIfT3JCktuTTCb5WJJDW9/nt+eTbf3xfft5V2u/P8mZfe2bW9tkkkv62hc8hiRp7TFPSZIGrbNwSrIe+B1gU1WdBBwCnAO8H7iiql4OPAVc0Da5AHiqtV/R+pHkxLbdK4HNwIeSHJLkEOCDwFnAicC5rS8LHUOStPaYpyRJK2G+p+qtAw5Lsg74CWAv8Hrg4239tcAb2vKW9py2/vQkae03VNV3quohYBI4pT0mq+rBqvoucAOwpW2z0DEkSWuTeUqSNFDrujpU1Z4kfwD8PfDfgM8AXwSerqoDrdtuYH1bXg882rY9kOQZ4MWt/ba+Xfdv8+i09lPbNgsd4+vziHlR7t7zDL9xyacGtftOD7/vl4c2tiQdzMxTPcPOU2CukjTaOgunJEfR+8vZCcDTwP9D7xSGg16SbcA2gLGxMSYmJha9r7HD4OJXHejuOCBLmftc9u/fP7B9D5NxrR6jGBMY10oyT/UMO0/B4HLVlIPx/becRj0+MMZRMOrxzaWzcAL+BfBQVf0jQJK/AF4HHJlkXftL2wZgT+u/BzgO2N1OmTgCeLKvfUr/NjO1P7mIMX5IVW0HtgNs2rSpxsfH5xHuzK66fieX3z2fwzUYD583PpD9TkxMsJTjcrAyrtVjFGMC41ph5imGn6dgcLlqykH6/ls2ox4fGOMoGPX45jKfa5z+HjgtyU+087NPB+4FPge8sfXZCuxsyze157T1n62qau3ntDsNnQBsBL4A3AFsbHcmOpTehbk3tW0WOoYkae0xT0mSBm4+1zjdnuTjwN8CB4Av0fvr2KeAG5K8t7Vd3Ta5GvhIkklgH70EQ1Xdk+RGesnsAHBhVX0PIMlFwC307oS0o6ruaft650LGkCStPeYpSdJKmNd3+lV1KXDptOYH6d1paHrfbwNvmmU/lwGXzdB+M3DzDO0LHkOStPaYpyRJgzbf25FLkiRJ0ppl4SRJkiRJHSycJEmSJKmDhZMkSZIkdbBwkiRJkqQOFk6SJEmS1MHCSZIkSZI6WDhJkiRJUgcLJ0mSJEnqYOEkSZIkSR0snCRJkiSpg4WTJEmSJHWwcJIkSZKkDhZOkiRJktTBwkmSJEmSOlg4SZIkSVIHCydJkiRJ6tBZOCX56SR39T2eTfKOJEcn2ZXkgfbzqNY/Sa5MMpnky0le07evra3/A0m29rW/NsndbZsrk6S1L3gMSdLaYp6SJK2EzsKpqu6vqpOr6mTgtcC3gE8AlwC3VtVG4Nb2HOAsYGN7bAM+DL3kAlwKnAqcAlw6lWBan7f2bbe5tS9oDEnS2mOekiSthIWeqnc68LWqegTYAlzb2q8F3tCWtwDXVc9twJFJjgXOBHZV1b6qegrYBWxu6w6vqtuqqoDrpu1rIWNIktY285QkaSDWLbD/OcBH2/JYVe1ty48BY215PfBo3za7W9tc7btnaF/MGHuRJK1lqypPJdlG7xspxsbGmJiYmE+MMxo7DC5+1YFFb78cljL/+di/f//AxximUY8PjHEUjHp8c5l34ZTkUOBXgXdNX1dVlaSWc2LLMcYoJaRBvUFH9c1vXKvHKMYExjUMqzFPVdV2YDvApk2banx8fNHjX3X9Ti6/e6F/D11eD583PtD9T0xMsJRjdLAb9fjAGEfBqMc3l4V8wp4F/G1VPd6eP57k2Kra204/eKK17wGO69tuQ2vbA4xPa59o7Rtm6L+YMX7IKCWkQSWjUX3zG9fqMYoxgXENyarLU5Kk1WMh1zidy3OnPwDcBEzdcWgrsLOv/fx2R6HTgGfaaQy3AGckOapdbHsGcEtb92yS09pdis6ftq+FjCFJWrvMU5KkgZnXVyhJXgD8EvBbfc3vA25McgHwCPDm1n4zcDYwSe/ORm8BqKp9Sd4D3NH6vbuq9rXltwHXAIcBn26PBY8hSVqbzFOSpEGbV+FUVd8EXjyt7Ul6dy+a3reAC2fZzw5gxwztdwInzdC+4DEkSWuPeUqSNGgLvR25JEmSJK05Fk6SJEmS1MHCSZIkSZI6WDhJkiRJUgcLJ0mSJEnqYOEkSZIkSR0snCRJkiSpg4WTJEmSJHWwcJIkSZKkDhZOkiRJktTBwkmSJEmSOlg4SZIkSVIHCydJkiRJ6mDhJEmSJEkdLJwkSZIkqYOFkyRJkiR1sHCSJEmSpA7zKpySHJnk40m+muS+JD+X5Ogku5I80H4e1fomyZVJJpN8Oclr+vaztfV/IMnWvvbXJrm7bXNlkrT2BY8hSVp7zFOSpEGb7zdOHwD+sqpeAbwauA+4BLi1qjYCt7bnAGcBG9tjG/Bh6CUX4FLgVOAU4NKpBNP6vLVvu82tfUFjSJLWLPOUJGmgOgunJEcAvwBcDVBV362qp4EtwLWt27XAG9ryFuC66rkNODLJscCZwK6q2ldVTwG7gM1t3eFVdVtVFXDdtH0tZAxJ0hpjnpIkrYR18+hzAvCPwH9K8mrgi8DbgbGq2tv6PAaMteX1wKN92+9ubXO1756hnUWMsbevjSTb6P2lj7GxMSYmJuYR7szGDoOLX3Vg0dsv1VLmPpf9+/cPbN/DZFyrxyjGBMa1wsxTDD9PweBy1ZSD9P23bEY9PjDGUTDq8c1lPoXTOuA1wG9X1e1JPsBzpyIAUFWVpAYxwaWMUVXbge0AmzZtqvHx8UWPf9X1O7n87vkcrsF4+Lzxgex3YmKCpRyXg5VxrR6jGBMY1wozTzH8PAWDy1VTDtL337IZ9fjAGEfBqMc3l/lc47Qb2F1Vt7fnH6eXoB6fOu2g/Xyird8DHNe3/YbWNlf7hhnaWcQYkqS1xzwlSRq4zsKpqh4DHk3y063pdOBe4CZg6o5DW4Gdbfkm4Px2R6HTgGfaaQy3AGckOapdbHsGcEtb92yS09pdis6ftq+FjCFJWmPMU5KklTDf7/R/G7g+yaHAg8Bb6BVdNya5AHgEeHPrezNwNjAJfKv1par2JXkPcEfr9+6q2teW3wZcAxwGfLo9AN63kDEkSWuWeUqSNFDzKpyq6i5g0wyrTp+hbwEXzrKfHcCOGdrvBE6aof3JhY4hSVp7zFOSpEGb7//jJEmSJElrloWTJEmSJHWwcJIkSZKkDhZOkiRJktTBwkmSJEmSOlg4SZIkSVIHCydJkiRJ6mDhJEmSJEkdLJwkSZIkqYOFkyRJkiR1sHCSJEmSpA4WTpIkSZLUwcJJkiRJkjpYOEmSJElSBwsnSZIkSepg4SRJkiRJHSycJEmSJKnDvAqnJA8nuTvJXUnubG1HJ9mV5IH286jWniRXJplM8uUkr+nbz9bW/4EkW/vaX9v2P9m2zWLHkCStPeYpSdKgLeQbp1+sqpOralN7fglwa1VtBG5tzwHOAja2xzbgw9BLLsClwKnAKcClUwmm9Xlr33abFzOGJGlNM09JkgZmKafqbQGubcvXAm/oa7+uem4DjkxyLHAmsKuq9lXVU8AuYHNbd3hV3VZVBVw3bV8LGUOSpCnmKUnSslk3z34FfCZJAf+xqrYDY1W1t61/DBhry+uBR/u23d3a5mrfPUM7ixhjb18bSbbR+0sfY2NjTExMzDPcHzV2GFz8qgOL3n6pljL3uezfv39g+x4m41o9RjEmMK4hME8NOU/B4HLVlIP4/bcsRj0+MMZRMOrxzWW+hdPPV9WeJD8J7Ery1f6VVVUtWQ3MYsZoiXM7wKZNm2p8fHzR4191/U4uv3u+h2v5PXze+ED2OzExwVKOy8HKuFaPUYwJjGsIzFNDzlMwuFw15SB+/y2LUY8PjHEUjHp8c5nXqXpVtaf9fAL4BL1zvx+fOu2g/Xyidd8DHNe3+YbWNlf7hhnaWcQYkqQ1yDwlSRq0zsIpyQuSvGhqGTgD+ApwEzB1x6GtwM62fBNwfruj0GnAM+00hluAM5Ic1S62PQO4pa17Nslp7S5F50/b10LGkCStMeYpSdJKmM93+mPAJ9qdV9cBf1ZVf5nkDuDGJBcAjwBvbv1vBs4GJoFvAW8BqKp9Sd4D3NH6vbuq9rXltwHXAIcBn24PgPctZAxJ0ppknpIkDVxn4VRVDwKvnqH9SeD0GdoLuHCWfe0AdszQfidw0nKMIUlaW8xTkqSVsJTbkUuSJEnSmmDhJEmSJEkdLJwkSZIkqYOFkyRJkiR1sHCSJEmSpA4WTpIkSZLUwcJJkiRJkjpYOEmSJElSBwsnSZIkSepg4SRJkiRJHSycJEmSJKmDhZMkSZIkdbBwkiRJkqQOFk6SJEmS1MHCSZIkSZI6WDhJkiRJUod5F05JDknypSSfbM9PSHJ7kskkH0tyaGt/fns+2dYf37ePd7X2+5Oc2de+ubVNJrmkr33BY0iS1ibzlCRpkBbyjdPbgfv6nr8fuKKqXg48BVzQ2i8AnmrtV7R+JDkROAd4JbAZ+FBLcocAHwTOAk4Ezm19FzyGJGlNM09JkgZmXoVTkg3ALwN/2p4HeD3w8dblWuANbXlLe05bf3rrvwW4oaq+U1UPAZPAKe0xWVUPVtV3gRuALYscQ5K0BpmnJEmDNt9vnP4I+F3g++35i4Gnq+pAe74bWN+W1wOPArT1z7T+P2ifts1s7YsZQ5K0NpmnJEkDta6rQ5JfAZ6oqi8mGR/8lJZPkm3ANoCxsTEmJiYWva+xw+DiVx3o7jggS5n7XPbv3z+wfQ+Tca0eoxgTGNdKMk/1DDtPweBy1ZSD8f23nEY9PjDGUTDq8c2ls3ACXgf8apKzgR8HDgc+AByZZF37S9oGYE/rvwc4DtidZB1wBPBkX/uU/m1man9yEWP8kKraDmwH2LRpU42Pj88j3Jlddf1OLr97PodrMB4+b3wg+52YmGApx+VgZVyrxyjGBMa1wsxTDD9PweBy1ZSD9P23bEY9PjDGUTDq8c2l81S9qnpXVW2oquPpXTT72ao6D/gc8MbWbSuwsy3f1J7T1n+2qqq1n9PuNHQCsBH4AnAHsLHdmejQNsZNbZuFjiFJWmPMU5KklbCUP029E7ghyXuBLwFXt/argY8kmQT20UswVNU9SW4E7gUOABdW1fcAklwE3AIcAuyoqnsWM4YkSX3MU5KkZbOgwqmqJoCJtvwgvTsNTe/zbeBNs2x/GXDZDO03AzfP0L7gMSRJa5d5SpI0KAv5f5wkSZIkaU2ycJIkSZKkDhZOkiRJktTBwkmSJEmSOlg4SZIkSVIHCydJkiRJ6mDhJEmSJEkdLJwkSZIkqYOFkyRJkiR1sHCSJEmSpA4WTpIkSZLUwcJJkiRJkjpYOEmSJElSBwsnSZIkSepg4SRJkiRJHSycJEmSJKmDhZMkSZIkdegsnJL8eJIvJPm7JPck+f3WfkKS25NMJvlYkkNb+/Pb88m2/vi+fb2rtd+f5My+9s2tbTLJJX3tCx5DkrS2mKckSSthPt84fQd4fVW9GjgZ2JzkNOD9wBVV9XLgKeCC1v8C4KnWfkXrR5ITgXOAVwKbgQ8lOSTJIcAHgbOAE4FzW18WOoYkaU0yT0mSBq6zcKqe/e3p89qjgNcDH2/t1wJvaMtb2nPa+tOTpLXfUFXfqaqHgEnglPaYrKoHq+q7wA3AlrbNQseQJK0x5ilJ0kqY1zVO7S9udwFPALuArwFPV9WB1mU3sL4trwceBWjrnwFe3N8+bZvZ2l+8iDEkSWuQeUqSNGjr5tOpqr4HnJzkSOATwCsGOqtlkmQbsA1gbGyMiYmJRe9r7DC4+FUHujsOyFLmPpf9+/cPbN/DZFyrxyjGBMa10sxTw89TMLhcNeVgff8tl1GPD4xxFIx6fHOZV+E0paqeTvI54OeAI5Osa39J2wDsad32AMcBu5OsA44Anuxrn9K/zUztTy5ijOnz3Q5sB9i0aVONj48vJNwfctX1O7n87gUdrmX18HnjA9nvxMQESzkuByvjWj1GMSYwrmExTw0vT8HgctWUg/39t1SjHh8Y4ygY9fjmMp+76r2k/QWPJIcBvwTcB3wOeGPrthXY2ZZvas9p6z9bVdXaz2l3GjoB2Ah8AbgD2NjuTHQovQtzb2rbLHQMSdIaY56SJK2E+fxp6ljg2nZXoR8DbqyqTya5F7ghyXuBLwFXt/5XAx9JMgnso5dgqKp7ktwI3AscAC5sp1aQ5CLgFuAQYEdV3dP29c6FjCFJWpPMU5KkgessnKrqy8DPzND+IL07DU1v/zbwpln2dRlw2QztNwM3L8cYkqS1xTwlSVoJ87qrniRJkiStZRZOkiRJktTBwkmSJEmSOlg4SZIkSVIHCydJkiRJ6mDhJEmSJEkdLJwkSZIkqYOFkyRJkiR1sHCSJEmSpA4WTpIkSZLUwcJJkiRJkjpYOEmSJElSBwsnSZIkSepg4SRJkiRJHSycJEmSJKmDhZMkSZIkdbBwkiRJkqQOnYVTkuOSfC7JvUnuSfL21n50kl1JHmg/j2rtSXJlkskkX07ymr59bW39H0iyta/9tUnubttcmSSLHUOStLaYpyRJK2E+3zgdAC6uqhOB04ALk5wIXALcWlUbgVvbc4CzgI3tsQ34MPSSC3ApcCpwCnDpVIJpfd7at93m1r6gMSRJa5J5SpI0cJ2FU1Xtraq/bcvfAO4D1gNbgGtbt2uBN7TlLcB11XMbcGSSY4EzgV1Vta+qngJ2AZvbusOr6raqKuC6aftayBiSpDXGPCVJWgnrFtI5yfHAzwC3A2NVtbetegwYa8vrgUf7Ntvd2uZq3z1DO4sYY29fG0m20ftLH2NjY0xMTMwrzpmMHQYXv+rAordfqqXMfS779+8f2L6HybhWj1GMCYxrWMxTw8tTMLhcNeVgf/8t1ajHB8Y4CkY9vrnMu3BK8kLgz4F3VNWz7fRuAKqqktQA5rekMapqO7AdYNOmTTU+Pr7o8a+6fieX372gOnNZPXze+ED2OzExwVKOy8HKuFaPUYwJjGsYzFPDzVMwuFw15WB+/y2HUY8PjHEUjHp8c5nXXfWSPI9eMrq+qv6iNT8+ddpB+/lEa98DHNe3+YbWNlf7hhnaFzOGJGkNMk9JkgZtPnfVC3A1cF9V/WHfqpuAqTsObQV29rWf3+4odBrwTDuN4RbgjCRHtYttzwBuaeueTXJaG+v8aftayBiSpDXGPCVJWgnz+U7/dcCvA3cnuau1/R7wPuDGJBcAjwBvbutuBs4GJoFvAW8BqKp9Sd4D3NH6vbuq9rXltwHXAIcBn24PFjqGJGlNMk9Jkgaus3Cqqs8DmWX16TP0L+DCWfa1A9gxQ/udwEkztD+50DEkSWuLeUqStBLmdY2TJEmSJK1lFk6SJEmS1MHCSZIkSZI6WDhJkiRJUgcLJ0mSJEnqYOEkSZIkSR0snCRJkiSpg4WTJEmSJHWwcJIkSZKkDhZOkiRJktTBwkmSJEmSOlg4SZIkSVIHCydJkiRJ6mDhJEmSJEkdLJwkSZIkqYOFkyRJkiR1sHCSJEmSpA6dhVOSHUmeSPKVvrajk+xK8kD7eVRrT5Irk0wm+XKS1/Rts7X1fyDJ1r721ya5u21zZZIsdgxJ0tpjnpIkrYT5fON0DbB5WtslwK1VtRG4tT0HOAvY2B7bgA9DL7kAlwKnAqcAl04lmNbnrX3bbV7MGJKkNesazFOSpAHrLJyq6q+AfdOatwDXtuVrgTf0tV9XPbcBRyY5FjgT2FVV+6rqKWAXsLmtO7yqbquqAq6btq+FjCFJWoPMU5KklbBukduNVdXetvwYMNaW1wOP9vXb3drmat89Q/tixtjLNEm20ftrH2NjY0xMTMwvuhmMHQYXv+rAordfqqXMfS779+8f2L6HybhWj1GMCYzrIGCeGoJBvzdW0ftvUUY9PjDGUTDq8c1lsYXTD1RVJanlmMxyj1FV24HtAJs2barx8fFFz+Gq63dy+d1LPlyL9vB54wPZ78TEBEs5Lgcr41o9RjEmMK6DiXlq5QwqV01Zje+/hRj1+MAYR8GoxzeXxd5V7/Gp0w7azyda+x7guL5+G1rbXO0bZmhfzBiSJE0xT0mSltViC6ebgKk7Dm0Fdva1n9/uKHQa8Ew7jeEW4IwkR7WLbc8Abmnrnk1yWrtL0fnT9rWQMSRJmmKekiQtq87v9JN8FBgHjkmym95dh94H3JjkAuAR4M2t+83A2cAk8C3gLQBVtS/Je4A7Wr93V9XUhbxvo3dHpMOAT7cHCx1DkrQ2mackSSuhs3CqqnNnWXX6DH0LuHCW/ewAdszQfidw0gztTy50DEnS2kv7cCMAAAdSSURBVGOekiSthMWeqidJkiRJa4aFkyRJkiR1sHCSJEmSpA4WTpIkSZLUwcJJkiRJkjpYOEmSJElSBwsnSZIkSepg4SRJkiRJHSycJEmSJKmDhZMkSZIkdbBwkiRJkqQOFk6SJEmS1MHCSZIkSZI6WDhJkiRJUgcLJ0mSJEnqYOEkSZIkSR1WbeGUZHOS+5NMJrlk2PORJGk6c5UkjY5VWTglOQT4IHAWcCJwbpIThzsrSZKeY66SpNGyKgsn4BRgsqoerKrvAjcAW4Y8J0mS+pmrJGmErNbCaT3waN/z3a1NkqSDhblKkkbIumFPYJCSbAO2taf7k9y/hN0dA3x96bNanLx/YLsealwDZFyrxyjGBMY1m5ct10RGwSjlKRhorpoy9BgHbNTjA2McBaMe36x5arUWTnuA4/qeb2htP6SqtgPbl2PAJHdW1abl2NfBxLhWl1GMaxRjAuMSMI9cZZ5amFGPcdTjA2McBaMe31xW66l6dwAbk5yQ5FDgHOCmIc9JkqR+5ipJGiGr8hunqjqQ5CLgFuAQYEdV3TPkaUmS9APmKkkaLauycAKoqpuBm1dwyGU5leIgZFyryyjGNYoxgXGJFc9Va+G1GfUYRz0+MMZRMOrxzSpVNew5SJIkSdJBbbVe4yRJkiRJK8bCaR6SbE5yf5LJJJcMez5LkeThJHcnuSvJna3t6CS7kjzQfh417Hl2SbIjyRNJvtLXNmMc6bmyvX5fTvKa4c18drPE9L8n2dNer7uSnN237l0tpvuTnDmcWXdLclySzyW5N8k9Sd7e2lft6zVHTKv69Ury40m+kOTvWly/39pPSHJ7m//H2o0OSPL89nyyrT9+mPNfy0YpT81kps/HUTLbZ8oome3zZdQkOSTJl5J8cthzGYSZfo9cSyycOiQ5BPggcBZwInBukhOHO6sl+8WqOrnvVpKXALdW1Ubg1vb8YHcNsHla22xxnAVsbI9twIdXaI4LdQ0/GhPAFe31OrldL0F7D54DvLJt86H2Xj0YHQAurqoTgdOAC9v8V/PrNVtMsLpfr+8Ar6+qVwMnA5uTnAa8n15cLweeAi5o/S8AnmrtV7R+WmEjmqemu4aZPx9HxVyfKaNits+XUfN24L5hT2LApv8euWZYOHU7BZisqger6rvADcCWIc9puW0Brm3L1wJvGOJc5qWq/grYN615tji2ANdVz23AkUmOXZmZzt8sMc1mC3BDVX2nqh4CJum9Vw86VbW3qv62LX+DXkJZzyp+veaIaTar4vVqx3x/e/q89ijg9cDHW/v012rqNfw4cHqSrNB09ZyRz1ML/HxcdRbxmbLqzPH5MjKSbAB+GfjTYc9Fg2Hh1G098Gjf892s7g+zAj6T5Ivp/Y/1AGNVtbctPwaMDWdqSzZbHKv9NbyonbK2o+80ylUZUzuV62eA2xmR12taTLDKX692msldwBPALuBrwNNVdaB16Z/7D+Jq658BXryyMxar6P2lbjN8poyM6Z8vVTVqMf4R8LvA94c9kQGa6ffINcPCae35+ap6Db1TOi5M8gv9K6t3m8VV/xegUYmD3mlqP0XvtIa9wOXDnc7iJXkh8OfAO6rq2f51q/X1miGmVf96VdX3qupkYAO9bzJeMeQpSWvGXJ+To2D650uSk4Y9p+WS5FeAJ6rqi8Oey4DN+XvkqLNw6rYHOK7v+YbWtipV1Z728wngE/R+MXp86lSo9vOJ4c1wSWaLY9W+hlX1eEs03wf+hOdO71pVMSV5Hr1fBq6vqr9ozav69ZopplF5vQCq6mngc8DP0Ttdcur//euf+w/iauuPAJ5c4alqFb6/9KNm+ZwcSX2fL6N03drrgF9N8jC902Vfn+Q/D3dKy2+W3yPXDAunbncAG9tdpQ6ld4H3TUOe06IkeUGSF00tA2cAX6EXz9bWbSuwczgzXLLZ4rgJOL/dre004Jm+U8QOatOu7flX9F4v6MV0Trur2Qn0bqTwhZWe33y0a16uBu6rqj/sW7VqX6/ZYlrtr1eSlyQ5si0fBvwSvWstPge8sXWb/lpNvYZvBD5b/ueAwzAyeWqtmuNzcmTM8vny1eHOavlU1buqakNVHU/v3+Bnq+rfDHlay2qO3yPXjHXdXda2qjqQ5CLgFuAQYEdV3TPkaS3WGPCJdu32OuDPquovk9wB3JjkAuAR4M1DnOO8JPkoMA4ck2Q3cCnwPmaO42bgbHoX5H8LeMuKT3geZolpPMnJ9E5jexj4LYCquifJjcC99O7GdGFVfW8Y856H1wG/Dtzdzm0H+D1W9+s1W0znrvLX61jg2naXth8DbqyqTya5F7ghyXuBL9H7BY/28yNJJulduH/OMCa91o1YnprRTJ+PVXX13FutKjN+pkzdmXNEzPj5MuQ5aWFm/D1yuFNaWfGPg5IkSZI0N0/VkyRJkqQOFk6SJEmS1MHCSZIkSZI6WDhJkiRJUgcLJ0mSJEnqYOEkSZIkSR0snCRJkiSpg4WTJEmSJHX4/wFUFIR0zdgbDgAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 1008x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 1008x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 1008x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 1008x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "for col in [\n",
    "    'regular_points_received', 'express_points_received',\n",
    "    'regular_points_spent', 'express_points_spent',\n",
    "    'purchase_sum',\n",
    "    # 'product_quantity', 'trn_sum_from_iss', 'trn_sum_from_red',\n",
    "]:\n",
    "    _, (ax0, ax1) = plt.subplots(1, 2, figsize=(14, 4))\n",
    "    df_trx[col].hist(ax=ax0)\n",
    "    (np.log1p(abs(df_trx[col])) * np.sign(df_trx[col])).hist(ax=ax1)\n",
    "    plt.suptitle(col)\n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Time periods"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 124,
   "metadata": {},
   "outputs": [],
   "source": [
    "# choose top N products and check it over time"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 138,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "['113e3ace79',\n",
       " '5645789fdf',\n",
       " '31dcf71bbd',\n",
       " 'dc2001d036',\n",
       " '0a46068efc',\n",
       " '343e841aaa',\n",
       " '439498bce2',\n",
       " '4a29330c8d',\n",
       " '5cb93c9bc5',\n",
       " 'f4599ca21a',\n",
       " '4dcf79043e',\n",
       " '3e038662c0',\n",
       " 'bf07df54e1',\n",
       " '15ccaa8685',\n",
       " '4009f09b04']"
      ]
     },
     "execution_count": 138,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "top_n_products = df_purchases.groupby('product_id')['transaction_id'].count().sort_values().iloc[-15:].index.tolist()\n",
    "top_n_products"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 139,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.axes._subplots.AxesSubplot at 0x7fb49174f240>"
      ]
     },
     "execution_count": 139,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAtgAAAFoCAYAAABt8YztAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4xLjIsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy8li6FKAAAgAElEQVR4nO3de7AmdX3n8fcHRkTRcF9EBjKsooghIg6XxCWLGGFQS0hKRDcroyESV7ytu8pkdyuyuqQGU1kvVV7CChFSRiQmEWJAZLkYNykuM4gOF4EJYhgilzCAcV0vwHf/OD1yTk+fy8xppp/znPer6tQ8/et+nv4e58PxO31+/etUFZIkSZL6sd3QBUiSJEnjxAZbkiRJ6pENtiRJktQjG2xJkiSpRzbYkiRJUo9ssCVJkqQezanBTnJ3knVJbkqyphnbLckVSe5s/ty1GU+STyRZn+TbSQ6d9Dkrm+PvTLJy0vjLms9f37w3M51DkiRJGlWZyzrYSe4GllfVP08a+wiwsapWJ1kF7FpVZyR5NfAu4NXAEcDHq+qIJLsBa4DlQAFrgZdV1cNJrgfeDVwHXAp8oqoum+4cM9W6xx571LJly7bwfwZJkiRp7tauXfvPVbVn174l8/jcE4Cjm9fnA9cAZzTjF9RE535tkl2S7N0ce0VVbQRIcgWwIsk1wC9U1bXN+AXAicBlM5xjWsuWLWPNmjXz+LYkSZKkmSX53nT75joHu4CvJVmb5LRmbK+q+n7z+j5gr+b1PsA9k967oRmbaXxDx/hM55giyWlJ1iRZ8+CDD87xW5IkSZL6N9cr2P+mqu5N8q+AK5J8Z/LOqqokT+kz12c6R1WdA5wDsHz5cp/9LkmSpMHM6Qp2Vd3b/PkA8FfA4cD9zdQPmj8faA6/F9h30tuXNmMzjS/tGGeGc0iSJEkjadYGO8lOSZ696TVwLHAzcAmwaSWQlcDFzetLgFOa1USOBB5tpnlcDhybZNdmNZBjgcubfT9IcmSzesgprc/qOockSZI0kuYyRWQv4K+alfOWAH9WVV9NcgNwUZJTge8Bb2iOv5SJFUTWAz8C3gpQVRuTfBi4oTnuQ5tueATeAXwOeAYTNzde1oyvnuYckiRJ0kia0zJ9C8ny5cvLVUQkSZL0VEqytqqWd+3zSY6SJElSj2ywJUmSpB7ZYEuSJEk9ms+THCVJ0gK3YdU3pmwvXX3UQJVI48Mr2JIkSVKPbLAlSZKkHtlgS5IkST2ywZYkSZJ6ZIMtSZIk9cgGW5IkSeqRDbYkSZLUIxtsSZIkqUc22JIkSVKPbLAlSZKkHtlgS5IkST2ywZYkSZJ6ZIMtSZIk9cgGW5IkSeqRDbYkSZLUIxtsSZIkqUc22JIkSVKPbLAlSZKkHtlgS5IkST1aMnQBkqRtY8Oqb0zZXrr6qIEqkaTxZoMtjSEbKUmShuMUEUmSJKlHNtiSJElSj2ywJUmSpB7ZYEuSJEk9ssGWJEmSemSDLUmSJPXIBluSJEnqkQ22JEmS1CMbbEmSJKlHc26wk2yf5JtJvtJs75/kuiTrk3wxyQ7N+NOb7fXN/mWTPuP3mvHbkxw3aXxFM7Y+yapJ453nkCRJkkbVllzBfg9w26Tts4GPVtXzgYeBU5vxU4GHm/GPNseR5CDgjcCLgRXAp5qmfXvgk8DxwEHAm5pjZzqHJEmSNJLm1GAnWQq8Bvhssx3gGOBLzSHnAyc2r09otmn2v7I5/gTgwqr6SVV9F1gPHN58ra+qu6rqp8CFwAmznEOSJEkaSXO9gv0x4APAE8327sAjVfVYs70B2Kd5vQ9wD0Cz/9Hm+J+Pt94z3fhM55giyWlJ1iRZ8+CDD87xW5IkSZL6N2uDneS1wANVtXYb1LNVquqcqlpeVcv33HPPocuRJEnSIrZkDse8HHhdklcDOwK/AHwc2CXJkuYK81Lg3ub4e4F9gQ1JlgA7Aw9NGt9k8nu6xh+a4RySJEnSSJr1CnZV/V5VLa2qZUzcpHhVVf0WcDXw+uawlcDFzetLmm2a/VdVVTXjb2xWGdkfOAC4HrgBOKBZMWSH5hyXNO+Z7hySJEnSSJrPOthnAO9Lsp6J+dLnNuPnArs34+8DVgFU1S3ARcCtwFeB06vq8ebq9DuBy5lYpeSi5tiZziFJkiSNpLlMEfm5qroGuKZ5fRcTK4C0j/kxcNI07z8LOKtj/FLg0o7xznNIkiRJo8onOUqSJEk9ssGWJEmSemSDLUmSJPXIBluSJEnqkQ22JEmS1CMbbEmSJKlHNtiSJElSj2ywJUmSpB7ZYEuSJEk9ssGWJEmSemSDLUmSJPXIBluSJEnqkQ22JEmS1KMlQxcgSZKk0bJh1TembC9dfdRAlSxMXsGWJEmSemSDLUmSJPXIBluSJEnqkQ22JEmS1CMbbEmSJKlHNtiSJElSj2ywJUmSpB7ZYEuSJEk9ssGWJEmSemSDLUmSJPXIR6VLkqSR8cm3XzVl+/TPHDNQJdLW8wq2JEmS1CMbbEmSJKlHNtiSJElSj2ywJUmSpB7ZYEuSJEk9ssGWJEmSemSDLUmSJPXIBluSJEnqkQ22JEmS1KNZG+wkOya5Psm3ktyS5L834/snuS7J+iRfTLJDM/70Znt9s3/ZpM/6vWb89iTHTRpf0YytT7Jq0njnOSRJkqRRNZcr2D8BjqmqlwCHACuSHAmcDXy0qp4PPAyc2hx/KvBwM/7R5jiSHAS8EXgxsAL4VJLtk2wPfBI4HjgIeFNzLDOcQ5IkSRpJszbYNeGHzebTmq8CjgG+1IyfD5zYvD6h2abZ/8okacYvrKqfVNV3gfXA4c3X+qq6q6p+ClwInNC8Z7pzSJIkSSNpTnOwmyvNNwEPAFcA/wA8UlWPNYdsAPZpXu8D3APQ7H8U2H3yeOs9043vPsM52vWdlmRNkjUPPvjgXL4lSZIk6Skxpwa7qh6vqkOApUxccT7wKa1qC1XVOVW1vKqW77nnnkOXI0mSpEVsi1YRqapHgKuBXwF2SbKk2bUUuLd5fS+wL0Czf2fgocnjrfdMN/7QDOeQJEmSRtJcVhHZM8kuzetnAK8CbmOi0X59c9hK4OLm9SXNNs3+q6qqmvE3NquM7A8cAFwP3AAc0KwYsgMTN0Je0rxnunNIkiRJI2nJ7IewN3B+s9rHdsBFVfWVJLcCFyb5H8A3gXOb488F/jTJemAjEw0zVXVLkouAW4HHgNOr6nGAJO8ELge2B86rqluazzpjmnNIkiRJI2nWBruqvg28tGP8LibmY7fHfwycNM1nnQWc1TF+KXDpXM8hSZIkjSqf5ChJkiT1yAZbkiRJ6pENtiRJktQjG2xJkiSpRzbYkiRJUo9ssCVJkqQe2WBLkiRJPbLBliRJknpkgy1JkiT1yAZbkiRJ6pENtiRJktQjG2xJkiSpRzbYkiRJUo9ssCVJkqQe2WBLkiRJPbLBliRJknpkgy1JkiT1yAZbkiRJ6pENtiRJktQjG2xJkiSpRzbYkiRJUo9ssCVJkqQe2WBLkiRJPbLBliRJknpkgy1JkiT1yAZbkiRJ6pENtiRJktQjG2xJkiSpRzbYkiRJUo9ssCVJkqQe2WBLkiRJPbLBliRJknpkgy1JkiT1yAZbkiRJ6pENtiRJktSjWRvsJPsmuTrJrUluSfKeZny3JFckubP5c9dmPEk+kWR9km8nOXTSZ61sjr8zycpJ4y9Lsq55zyeSZKZzSJIkSaNqLlewHwP+U1UdBBwJnJ7kIGAVcGVVHQBc2WwDHA8c0HydBnwaJppl4IPAEcDhwAcnNcyfBt426X0rmvHpziFJkiSNpFkb7Kr6flXd2Lz+F+A2YB/gBOD85rDzgROb1ycAF9SEa4FdkuwNHAdcUVUbq+ph4ApgRbPvF6rq2qoq4ILWZ3WdQ5IkSRpJWzQHO8ky4KXAdcBeVfX9Ztd9wF7N632Aeya9bUMzNtP4ho5xZjhHu67TkqxJsubBBx/ckm9JkiRJ6tWcG+wkzwL+AnhvVf1g8r7mynP1XNsUM52jqs6pquVVtXzPPfd8KsuQJEmSZjSnBjvJ05horj9fVX/ZDN/fTO+g+fOBZvxeYN9Jb1/ajM00vrRjfKZzSJIkSSNpLquIBDgXuK2q/uekXZcAm1YCWQlcPGn8lGY1kSOBR5tpHpcDxybZtbm58Vjg8mbfD5Ic2ZzrlNZndZ1DkiRJGklL5nDMy4E3A+uS3NSM/RdgNXBRklOB7wFvaPZdCrwaWA/8CHgrQFVtTPJh4IbmuA9V1cbm9TuAzwHPAC5rvpjhHJIkSdJImrXBrqr/A2Sa3a/sOL6A06f5rPOA8zrG1wC/1DH+UNc5JEmSpFHlkxwlSZKkHtlgS5IkST2ywZYkSZJ6ZIMtSZIk9cgGW5IkSerRXJbpkyRJI+bg8w+esr1u5bqBKpHU5hVsSZIkqUc22JIkSVKPnCIiaV78NbUkSVN5BVuSJEnqkQ22JEmS1CMbbEmSJKlHNtiSJElSj2ywJUmSpB7ZYEuSJEk9ssGWJEmSemSDLUmSJPXIB81II6T90BbwwS2SJC00XsGWJEmSemSDLUmSJPXIKSKSNOKcOiRJC4tXsCVJkqQe2WBLkiRJPbLBliRJknpkgy1JkiT1yAZbkiRJ6pGriEiSJI2J9qpDrjg0DBvsBW7Dqm9sNrZ09VEDVCJJkiRwiogkSZLUKxtsSZIkqUc22JIkSVKPbLAlSZKkHnmToyRJi8QfnfzazcZO3v+MASqRxptXsCVJkqQezdpgJzkvyQNJbp40tluSK5Lc2fy5azOeJJ9Isj7Jt5McOuk9K5vj70yyctL4y5Ksa97ziSSZ6RySJEnSKJvLFezPAStaY6uAK6vqAODKZhvgeOCA5us04NMw0SwDHwSOAA4HPjipYf408LZJ71sxyzkkSZKkkTVrg11VfwtsbA2fAJzfvD4fOHHS+AU14VpglyR7A8cBV1TVxqp6GLgCWNHs+4WquraqCrig9Vld55AkSZJG1tbe5LhXVX2/eX0fsFfzeh/gnknHbWjGZhrf0DE+0zk2k+Q0Jq6Ys99++23p9yJJkrbAc66+abOx+15xyACVSKNp3quIVFUlqT6K2dpzVNU5wDkAy5cvf0prkaSFYOjVIg4+/+Ap2+tWrttm55akoW3tKiL3N9M7aP58oBm/F9h30nFLm7GZxpd2jM90DkmSJGlkbW2DfQmwaSWQlcDFk8ZPaVYTORJ4tJnmcTlwbJJdm5sbjwUub/b9IMmRzeohp7Q+q+sckp4Cz7n6ps2+JEnSlpt1ikiSLwBHA3sk2cDEaiCrgYuSnAp8D3hDc/ilwKuB9cCPgLcCVNXGJB8GbmiO+1BVbbpx8h1MrFTyDOCy5osZziFJkiSNrFkb7Kp60zS7XtlxbAGnT/M55wHndYyvAX6pY/yhrnNIkrYdb2bTVjtz546xR7d9HdIAfJKjJEmS1KN5ryIiaXjtFSO25WoRkjRXri6jxcIGW5IkzejKq543dSB/MUwh0gLhFBFJkiSpRzbYkiRJUo+cIiItUlv1K9+uVQH236+fgrRwmQtJmsIGW5IkaRFr3ygP3iw/XzbYkiTp584888zNxo76tW1fh7SQ2WBLkn7O1SIkbS0fTPUkG2xpEfCKlCRpJCySJ3zaYEuSpHlbtupvpmzfveNAhUgjwGX6JEmSpB55BVtaYD759quGLkHSU6x9NRjg7tWvGaCSp9ZtB75o88GjP7ntC5F6ZoMtSdKY8h/k0jBssKVtZLFckdLC4c2v0uLU1z+8XHVoejbYkjSgrf2HV/tX6y/6zm291aQR1V59ofW0TKdbSKPDBluSRs0sjVSXUZ8K0NX8+Y8CaeHwN15bxgZbGnGbNSYjfkXKRkqStCUOPv/gKdvrVq4bqJL+2GAPpB0mGI9AaQttxZVKaWiudywNY7P/9ryPZ2S5DrYkSZLUI69gS5Ik6SmxNb/xGoebuL2CLUmSJPXIK9iSpuVcW0la2Fy+cRg22JIkSQtR+0Z58Gb5EeEUEUmSJKlHNtiSJElSj2ywJUmSpB45B3sRes7VN202dt8rDpn1feP4pCVJkqS+2WAvMH908munbJ+8/xlPzYm8cUKSJGmr2GCPsE++/apePufKq543dSB/0cvnSpIkaXM22E+B9trBAHevfs02O/+ZZ545ZfuoX9tmp5YkSVr0bLC3lfaUi47pFpstBj/iC8F3LV6/EB9nKkmS1CdXEZEkSZJ6ZIMtSZIk9Wjkp4gkWQF8HNge+GxVrR64pLHUnjd+944DFSJJkrTAjfQV7CTbA58EjgcOAt6U5KBhq5IkSZKmN9INNnA4sL6q7qqqnwIXAicMXJMkSZI0rVTV0DVMK8nrgRVV9TvN9puBI6rqna3jTgNOazZfCNy+TQsdXXsA/zx0ERo55kJdzIW6mAu1mYkn/WJV7dm1Y+TnYM9FVZ0DnDN0HaMmyZqqWj50HRot5kJdzIW6mAu1mYm5GfUpIvcC+07aXtqMSZIkSSNp1BvsG4ADkuyfZAfgjcAlA9ckSZIkTWukp4hU1WNJ3glczsQyfedV1S0Dl7WQOG1GXcyFupgLdTEXajMTczDSNzlKkiRJC82oTxGRJEmSFhQbbEmSJKlHNtiSJElSj0b6JkfNXZIw8eTLfZqhe4Hry0n2i5q5UBdzoS7mQl2S7MWkTFTV/UPWs1B4k+MYSHIs8CngTp5cJ3wp8HzgHVX1taFq03DMhbqYC3UxF2pLcgjwGWBnpmbiESYyceNQtS0ENthjIMltwPFVdXdrfH/g0qp60SCFaVDmQl3MhbqYC7UluQn43aq6rjV+JPDHVfWSYSpbGJyDPR6WABs6xu8FnraNa9HoMBfqYi7UxVyobad2cw1QVdcCOw1Qz4LiHOzxcB5wQ5ILgXuasX2ZePLluYNVpaGZC3UxF+piLtR2WZK/AS5gaiZOAb46WFULhFNExkSSg4DXMfXmlEuq6tbhqtLQzIW6mAt1MRdqS3I8cAKbZ+LS4apaGGywx0yS3QCqauPQtWh0mAt1MRfqYi6k+XMO9hhIsl+SC5M8AFwHXJ/kgWZs2bDVaSjmQl3MhbqYC7Ul2TnJ6iS3JdmY5KHm9eokuwxd36izwR4PXwT+Cti7qg6oqucDewNfBi4ctDINyVyoi7lQF3OhtouAh4FXVNVuVbU78Aomlum7aNDKFgCniIyBJHdW1QFbuk/jzVyoi7lQF3OhtiS3V9ULt3SfJriKyHhYm+RTwPlMvdN3JfDNwarS0MyFupgLdTEXavtekg8A5296emPzVMe38GRGNA2vYI+BJDsApzL1Tt8NwF8D51bVT4aqTcMxF+piLtTFXKgtya7AKiYysRdQwP3AJcDZ3gQ7MxtsSZIkqUfe5Dhmkrx2pm0tTuZCXcyFupgLtSU5dKZtbc4Ge/wcNsu2FidzoS7mQl3Mhdr+wyzbanGKiCRJktQjVxEZE0kOpPtxprcNV5WGZi7UxVyoi7lQW5KdgRVMzcTlVfXIcFUtDE4RGQNJzmDiQQABrm++Anwhyaoha9NwzIW6mAt1MRdqS3IKcCNwNPDM5usVTCzpeMqApS0IThEZA0nuAF5cVT9rje8A3OIDAhYnc6Eu5kJdzIXaktwOHNG+Wt0s33ddVb1gmMoWBq9gj4cngOd2jO/d7NPiZC7UxVyoi7lQW5hY+7rtiWafZuAc7PHwXuDKJHfy5NOV9gOeD7xzsKo0NHOhLuZCXcyF2s4CbkzyNaZm4lXAhweraoFwisiYSLIdcDhTb0S4oaoeH64qDc1cqIu5UBdzobZmOshxbH6T48PDVbUweAV7fNSkr03b/lpP5kJdzIW6mAtNUVUPJ7maSQ22zfXceAV7DCQ5FvgUcCcT/7oEWMrEr/beUVVfG6o2DcdcqIu5UBdzobYkhwCfAXYGNjAx73op8AgTmbhxwPJGng32GEhyG3B8Vd3dGt8fuLSqXjRIYRqUuVAXc6Eu5kJtSW4CfreqrmuNHwn8cVW9ZJjKFgZXERkPS5j412XbvcDTtnEtGh3mQl3MhbqYC7Xt1G6uAarqWmCnAepZUJyDPR7OA25IciFP3um7L/BG4NzBqtLQzIW6mAt1MRdquyzJ3wAXMDUTpwBfHayqBcIpImMiyYvofsTtrcNVpaGZC3UxF+piLtSW5Hi6M3HpcFUtDDbYkiRJUo+cgz1mkpw507YWJ3OhLuZCXcyF2pKcNtO2NmeDPX7WzrKtxclcqIu5UBdzobb2o9F9VPosnCIiSZIk9chVRMZAkiXAqcBvAM9thu8FLgbOraqfDVWbhmMu1MVcqIu5UJckxwEnMvUmx4urylVEZuEV7DGQ5AtMPFnpfJ5cx3QpsBLYrapOHqo2DcdcqIu5UBdzobYkHwNewMQyfZMzcQpwZ1W9Z6jaFgIb7DGQ5I6qesGW7tN4MxfqYi7UxVyobbq/9yQB7qiqAwYoa8HwJsfxsDHJSUl+/veZZLskJwMPD1iXhmUu1MVcqIu5UNuPkxzWMX4Y8ONtXcxC4xXsMZBkGXA2cAwTPwgD7AJcBayqqu8OVpwGYy7UxVyoi7lQW5JDgU8Dz+bJKSL7Ao8Cp1eVq8vMwAZ7zCTZHaCqHhq6Fo0Oc6Eu5kJdzIUmS/IcJt3kWFX3DVnPQmGDPSaSHMjmjzO9uKq+M1xVGpq5UBdzoS7mQm1JdgZWMDUTl1fVI8NVtTA4B3sMJDkDuJCJX+ld33wFuDDJqiFr03DMhbqYC3UxF2pLcgpwI3A08Mzm6xXA2mafZuAV7DGQ5A7gxe11SpPsANzinb6Lk7lQF3OhLuZCbUluB45oX61OsitwnSvLzMwr2OPhCZ58MMBkezf7tDiZC3UxF+piLtQWoOsq7BP4qPRZ+STH8fBe4MokdwL3NGP7Ac8H3jlYVRqauVAXc6Eu5kJtZwE3JvkaUzPxKuDDg1W1QDhFZEw0a5ceztQbEW6oqseHq0pDMxfqYi7UxVyorZkOchyb3+To2uizsMGWJEmSeuQcbEmSJKlHNtiSJElSj2ywJUmSpB7ZYI+5JOuGrkGjx1yoi7lQF3OhtiSXDV3DqHOZvjGQ5Den2wU8Z1vWotFhLtTFXKiLuVBbkkOn2wUcsi1rWYhssMfDF4HP070g/I7buBaNDnOhLuZCXcyF2m4Avk73Q2V22ca1LDgu0zcGkqwFVlbVzR377qmqfQcoSwMzF+piLtTFXKgtyc3Ab1TVnR37zMQsnIM9Ht4L/GCafb+xLQvRSDEX6mIu1MVcqO1Mpu8T37UN61iQvIItSZIk9cg52GMgyRLgVCauMjy3Gb4XuBg4t6p+NlRtGo65UBdzoS7mQl2SHAecyNRHpV9cVV8drqqFwSvYYyDJF4BHgPOBDc3wUmAlsFtVnTxUbRqOuVAXc6Eu5kJtST4GvAC4gKmZOAW4s6reM1RtC4EN9hhIckdVvWBL92m8mQt1MRfqYi7UNt3fe5IAd1TVAQOUtWB4k+N42JjkpCQ///tMsl2Sk4GHB6xLwzIX6mIu1MVcqO3HSQ7rGD8M+PG2Lmah8Qr2GEiyDDgbOIYnfxDuClwFrKqq7w5TmYZkLtTFXKiLuVBb86CZTwPP5skpIvsCjwKnV9XaoWpbCGywx0yS3QGq6qGha9HoMBfqYi7UxVxosiTPYdJNjlV135D1LBROERkzVfVQVT2U5Jyha9HoMBfqYi7UxVxosqq6r6rWNles3z50PQuFDfb4Wj50ARpJ5kJdzIW6mAu1vW7oAhYKG+zx9cDQBWgkmQt1MRfqYi7UlqELWCicgy1JkqRZJdmuqp4Yuo6FwCvYY845dItXku2T/G6SDyd5eWvffxuqLo0uf14sXv68UFuSZyb5QJL3J9kxyVuALyf5SJJnDV3fqPMK9hhIstt0u4BvVdXSbVmPRkOSzwLPBK4H3gx8vare1+y7saoOHbI+DcOfF+rizwu1JbkIuAd4BvBC4Dbgi0zMw35OVb15wPJGng32GEjyOPA9ps6NqmZ7n6raYZDCNKgk366qX25eLwE+BewBvAm4tqpeOmR9GoY/L9TFnxdqS3JTVR3SPLnx+8DeVVXN9rc25UXdlgxdgHpxF/DKqvrH9o4k9wxQj0bDzxulqnoMOC3J7zPx4Ah/vbd4+fNCXfx5oU5NU31pNVdkm22vzs7COdjj4WNMPHGry0e2ZSEaKWuSrJg8UFUfAv4EWDZIRRoF/rxQF39eqG3NprnWVfXbmwaTPA/4l8GqWiCcIiJJkqQ5S5KygZyRU0TGXJJXVdUVQ9eh0WIuFrckBwInMOnxx8AlVXXbcFVpaOZCbWZi6zlFZPydO3QBGknmYpFKcgZwIRM3NV7ffAX4QpJVQ9am4ZgLtZmJ+XGKyBhIcsl0u4BjqmqnbVmPRoO5UJckdwAvrqqftcZ3AG6pqgOGqUxDMhdqMxPz4xSR8XAU8O+BH7bGAxy+7cvRiDAX6vIE8FwmluqbbO9mnxYnc6E2MzEPNtjj4VrgR1X19faOJLcPUI9Gg7lQl/cCVya5k4mHSADsBzwfeOdgVWlo5kJtZmIenCIiSYtMku2Y+C3G5BuXbqiqx4erSkMzF2ozE1vPBntMJXltVX1l6Do0WsyFuiQ5rarOGboOjRZzoTYzMXc22GMqyY1VdejQdWi0mAt1MRfqYi7UZibmzmX6xleGLkAjyVyoi7lQF3OhNjMxR17BHlNJDq+q64euQ6PFXKhLkqVVtWHoOjRazIXazMTc2WCPgWZNyjcC/1RV/zvJvwN+FbgNOKe9hqUWB3Oh6ST518BvAvsCjwN3AH9WVT8YtDANylyozUxsPaeIjIc/AV4DvCfJnwInAdcBhwGfHbIwDcpcaDNJ3g18BtiRiSw8nYn/87w2ydEDlqYBmQu1mYn58Qr2GEjy7ar65SRLmFhC57lV9XiSAN+qql8euEQNwFyoS5J1wCFNFp4JXFpVRyfZD7i4ql46cIkagLlQm5mYH69gj4ftmukAzwaeCezcjD8deNpgVWlo5kLT2fSQsacDzwKoqn/EXCx25kJtZmIr+STH8XAu8B1ge+C/An+e5C7gSODCIQvToMyFunwWuCHJdcBRwNkASfYENg5ZmAZlLtRmJubBKSJjIslzAarqn5LsAvw68P7lgrgAAAXISURBVI+uGLG4mQt1SfJi4EXAzVX1naHr0WgwF2ozE1vPBnvMJXlWVf1w6Do0WsyFupgLdTEXajMTs3MO9vi7degCNJLMhbqYC3UxF2ozE7NwDvYYSPK+6XbR3JSgxcdcqIu5UBdzoTYzMT9ewR4PfwDsysRqEZO/noV/x4uZuVAXc6Eu5kJtZmIevII9Hm4EvlxVa9s7kvzOAPVoNJgLdTEX6mIu1GYm5sGbHMdAkhcCG6vqwY59e1XV/QOUpYGZC3UxF+piLtRmJubHBluSJEnqkXNoxkCSnZOsTvKdJBuTPJTktmZsl6Hr0zDMhbqYC3UxF2ozE/Njgz0eLgIeBo6uqt2qanfgFc3YRYNWpiGZC3UxF+piLtRmJubBKSJjIMntVfXCLd2n8WYu1MVcqIu5UJuZmB+vYI+H7yX5QJK9Ng0k2SvJGcA9A9alYZkLdTEX6mIu1GYm5sEGezycDOwOfL2ZJ7URuAbYDXjDkIVpUOZCXcyFupgLtZmJeXCKiCRJktQjr2CPiSQHJnllkp1a4yuGqknDMxfqYi7UxVyozUxsPRvsMZDk3cDFwLuAW5KcMGn3HwxTlYZmLtTFXKiLuVCbmZgfH5U+Ht4GvKyqfphkGfClJMuq6uNABq1MQzIX6mIu1MVcqM1MzIMN9njYrqp+CFBVdyc5mon/EH4R/yNYzMyFupgLdTEXajMT8+AUkfFwf5JDNm00/0G8FtgDOHiwqjQ0c6Eu5kJdzIXazMQ8uIrIGEiyFHisqu7r2Pfyqvq7AcrSwMyFupgLdTEXajMT82ODLUmSJPXIKSKSJElSj2ywJUmSpB7ZYEuSJEk9ssGWpJ4k2SXJO4auY7Ikb0ny3Enbn01y0JA1zUWSEyfXmeSaJMuHrEmS5soGW5L6swuwWYOdZMhnDrwF+HmDXVW/U1W3DlfOnJ0IjPw/BCSpiw22JPVnNfC8JDcluSHJN5JcAtwKkOTLSdYmuSXJaZvelOSHSc5K8q0k1ybZqxk/KcnNzfjfNmPLms+9sfn61Umfc0aSdc3xq5O8HlgOfL6p6RmTrwQneVNz/M1Jzp6tni5JPpfk081xdyU5Osl5SW5L8rlJx835XM339DrgD5u6n9ccflKS65PckeSorf9rkqSnlg22JPVnFfAPVXUI8H7gUOA9VfWCZv9vV9XLmGh6351k92Z8J+DaqnoJ8LdMPKIY4PeB45rx1zVjDwCvqqpDgZOBTwAkOR44ATiiOf4jVfUlYA3wW1V1SFX9v02FNtNGzgaOAQ4BDkty4iz1TGdX4FeA/whcAnwUeDFwcJJDtvRcVfX3zee8v6n7H5pjl1TV4cB7gQ/OUpMkDcYGW5KeOtdX1Xcnbb87ybeAa4F9gQOa8Z8CX2lerwWWNa//DvhckrcB2zdjTwP+V5J1wJ/z5DSKXwf+pKp+BFBVG2ep7TDgmqp6sKoeAz4P/Nos9Uznr2vioQrrgPural1VPQHc0ry3r3P95RbUJEmDGXJeoCSNu/+76UWSo5logn+lqn6U5Bpgx2b3z+rJp349TvOzuarenuQI4DXA2iQvA94F3A+8hImLJD9+CururGcGP2n+fGLS603bS4Cf9XSun8zxOEkalFewJak//wI8e5p9OwMPN831gcCRs31YkudV1XVV9fvAg0xc9d4Z+H5zhfjNPHll+wrgrUme2bx3t1lquh74t0n2SLI98Cbg63P5JrfC1pxrpv8tJWmk2WBLUk+q6iHg75LcDPxha/dXgSVJbmPiZshr5/CRf7jpxkDg74FvAZ8CVjZTTQ6kuUpeVV9lYt7ymiQ3Af+5+YzPAZ/ZdJPjpFq/z8Sc8aubz11bVRdvxbc9q60814XA+5N8c9JNjpK0IOTJ38xJkiRJmi+vYEuSJEk98iYRSdKskvxX4KTW8J9X1VlD1CNJo8wpIpIkSVKPnCIiSZIk9cgGW5IkSeqRDbYkSZLUIxtsSZIkqUf/HxuOyawMXrTZAAAAAElFTkSuQmCC\n",
      "text/plain": [
       "<Figure size 864x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "df_purchases[lambda x: x['product_id'].isin(top_n_products)] \\\n",
    "    .groupby(['transaction_month', 'product_id'])['transaction_id'].count().unstack() \\\n",
    "    .plot(figsize=(12, 4), kind='bar', legend=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 194,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "84M\t../data/test_trx.parquet\r\n",
      "722M\t../data/train_trx.parquet\r\n"
     ]
    }
   ],
   "source": [
    "!du -sh ../data/*.parquet"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python (TDL)",
   "language": "python",
   "name": "tdl_env"
  },
  "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.9"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
