{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "import matplotlib as mpl\n",
    "import numba as nb\n",
    "\n",
    "from sklearn.cluster import KMeans \n",
    "from sklearn.cluster import SpectralClustering\n",
    "from sklearn.cluster import AgglomerativeClustering\n",
    "from pathlib import Path"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "import sys\n",
    "\n",
    "sys.path.append('../../src')\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Imports"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "from base_exp_gen import generate_experiment as GEN_EXP\n",
    "from clustering_algos import  kmeans_clustering,\\\n",
    "box_clustering, adaptive_box2, optimal_clustering\n",
    "from sklearn.model_selection import train_test_split as datasplit\n",
    "from sklearn.ensemble import GradientBoostingRegressor as GDBR\n",
    "from evaluations import computeATT_per_cluster as ATTC, predict_cf, calculate_ite, get_homogeneity, generate_paths,\\\n",
    "confusion_matrix\n",
    "\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Set random seed for consistency across runs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "np.random.seed(seed = 0)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Set parameters for plotting"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "fonts = {'family': 'cmr10','weight': 'normal',\n",
    "            'size': 20}    \n",
    "div = 1\n",
    "\n",
    "l1 = 22/div\n",
    "l2 = 20/div\n",
    "l3 = 13/(div-0.2)\n",
    "\n",
    "mpl.rcParams['xtick.labelsize'] = l2\n",
    "mpl.rcParams['ytick.labelsize'] = l2\n",
    "mpl.rcParams['axes.labelsize'] = l1\n",
    "mpl.rcParams['font.serif'] = 'Times New Roman'\n",
    "mpl.rcParams['font.weight'] = 'normal'\n",
    "mpl.rcParams['font.size'] = 20\n",
    "mpl.rcParams['legend.fontsize'] = l3"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Pandas parameters for dataframe display"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "pd.set_option(\"display.max_columns\", None)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Directory to save figures"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "save = True\n",
    "path_figs = './figs/2M/'\n",
    "Path(path_figs).mkdir(exist_ok = True, parents = True)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Generate Experiment"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Number of Clusters:1369, Number of Points:2000000\n",
      "CPU times: user 1.31 s, sys: 454 ms, total: 1.77 s\n",
      "Wall time: 1.74 s\n"
     ]
    }
   ],
   "source": [
    "%%time\n",
    "\n",
    "N,D = 2*10**6, 2\n",
    "x = int((N)**(1/4))\n",
    "clusters = x**2\n",
    "print(\"Number of Clusters:{}, Number of Points:{}\".format(clusters, N))\n",
    "kw_generate =  {'N':N, 'D':D,'f_gen_name': 'uniform_gen','low':0, 'high': 1}\n",
    "centers = [[0.5,0.5],[0.5,0.5]]\n",
    "r_small = [0, 0.325735]\n",
    "r_big = [0.325735,0.46065886]\n",
    "eligibilities = [2,1]\n",
    "kw_cluster =  {'f_class_name':'circle_class4', 'centers': centers,\n",
    "               'eligibilities':eligibilities,'r_small': r_small, 'r_big':r_big}\n",
    "kw_treatment = {'f_treat_name' :'uniform_treat','choices':[0,1], 'probabilities':[0.5,0.5]}\n",
    "\n",
    "std = 5\n",
    "stats = np.array([[1, std], [0, std], [0, std], [1, std],[1, std],\n",
    "                  [2, std]])\n",
    "kw_outcome = {'f_outcome_name': 'outcome1','treatment':'Treatment', 'cls':'C', 'stats':stats}\n",
    "\n",
    "data = GEN_EXP(kw_generate, kw_cluster, kw_treatment, kw_outcome).dat\n",
    "data = calculate_ite(data.copy(), treatment = 'Treatment',\n",
    "                     counterfactual = 'Ycf', outcome = 'Y', ite_name = 'ITE')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Plot generated experiment"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots()\n",
    "\n",
    "ax.scatter(data['x0'].values, data['x1'].values, c=data['C'].values, cmap = 'Greys', s=0.1)\n",
    "\n",
    "if save:\n",
    "    fig.savefig(path_figs+'data.jpeg',bbox_inches='tight', pad_inches = 0)\n",
    "    ax.set_aspect('equal', adjustable='box')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    " ### Estimate ITE with Gradient Boosting "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "CPU times: user 1h 6min 8s, sys: 2.16 s, total: 1h 6min 10s\n",
      "Wall time: 1h 6min 10s\n"
     ]
    }
   ],
   "source": [
    "%%time\n",
    "f1_kwargs = {'n_estimators':400, 'max_depth':18}\n",
    "f2_kwargs = {'n_estimators':400, 'max_depth':18}\n",
    "\n",
    "data, models = predict_cf(data.copy(), col_select = ['x0', 'x1'], f1 = GDBR,\n",
    "                          f2 = GDBR, cf_name = 'Ycf-GDBR', f1_kwargs=f1_kwargs, \n",
    "                          f2_kwargs=f2_kwargs, ite_name ='ITE-GDBR')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Apply box clustering (to be used as a sped up to PCM)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [],
   "source": [
    "col_select = ['x0', 'x1']\n",
    "data,_ = box_clustering(data.copy(), clusters = clusters, col_select = col_select )"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Calculate ATT per box cluster for optimal clustering"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [],
   "source": [
    "ite_name = 'ITE-GDBR'\n",
    "box2 = ATTC(data.copy(), cluster_name = 'Box-Cluster', ATT_CLUST_name='Box-ATT',\n",
    "           points_name='Box-points', weight_names='Box-Weights', ITE_name = ite_name,\n",
    "            hom_name = 'Box-Hom', att = False)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Optimal 1d clustering"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Did not pick 3, it picked: 4\n"
     ]
    }
   ],
   "source": [
    "name2 = 'Box-ATT'\n",
    "name = 'Opt-Clust'\n",
    "box2, means = optimal_clustering(box2, max_clusters = 7, col_select = name2, \n",
    "                      cluster_name = name, N=N )"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### PCM"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/mavrog2/.conda/envs/jorje/lib/python3.7/site-packages/numba/core/ir_utils.py:2031: NumbaPendingDeprecationWarning: \n",
      "Encountered the use of a type that is scheduled for deprecation: type 'reflected list' found for argument 'data_groups2' of function 'adapt_numba'.\n",
      "\n",
      "For more information visit http://numba.pydata.org/numba-doc/latest/reference/deprecation.html#deprecation-of-reflection-for-list-and-set-types\n",
      "\n",
      "File \"../../../src/clustering_algos.py\", line 427:\n",
      "@jit(nopython = True)\n",
      "def adapt_numba(data_groups2, new_ites, values, pivot_array,\n",
      "^\n",
      "\n",
      "  warnings.warn(NumbaPendingDeprecationWarning(msg, loc=loc))\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "CPU times: user 1h 52min 28s, sys: 18.2 s, total: 1h 52min 46s\n",
      "Wall time: 1h 52min 18s\n"
     ]
    }
   ],
   "source": [
    "%%time\n",
    "adaptive_ite_name = 'ITE-ADAPTIVE'\n",
    "ite_old_name = 'ITE-GDBR'\n",
    "data = adaptive_box2(data, clusters = clusters, ite_old_name = ite_old_name,\n",
    "                    ite_name = adaptive_ite_name, col_select = col_select)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Assign points to the corresponding means recovered by optimal 1-d clustering"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [],
   "source": [
    "clusts = len(means)\n",
    "means2 = means.reshape(3,1)\n",
    "\n",
    "data, km = kmeans_clustering(data, clusters = clusts, cluster_name = 'ITE-ADAPTIVE-3CLUST',\n",
    "                           col_select = [adaptive_ite_name], assign_means = True, means = means2 )"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "###  Appendix: A.1 Reconstructed Subpopulations (column: PCM (this work), row: 2M)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "path3 = path_figs+'reconstruction/'\n",
    "Path(path3).mkdir(exist_ok = True, parents = True)\n",
    "\n",
    "fig, ax = plt.subplots()\n",
    "\n",
    "sc = ax.scatter(data['x0'].values, data['x1'].values, c=data['ITE-ADAPTIVE-3CLUST'], cmap = 'Greys', s = 1)\n",
    "\n",
    "if save:\n",
    "    ax.set_aspect('equal', adjustable='box')\n",
    "    fig.savefig(path3+'{}.jpeg'.format('ITE-ADAPTIVE-3CLUST'), bbox_inches='tight',pad_inches = 0)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "###  A.2 ITE Histograms (column: PCM (our work), row: 2M)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/mavrog2/.conda/envs/jorje/lib/python3.7/site-packages/seaborn/distributions.py:2619: FutureWarning: `distplot` is a deprecated function and will be removed in a future version. Please adapt your code to use either `displot` (a figure-level function with similar flexibility) or `histplot` (an axes-level function for histograms).\n",
      "  warnings.warn(msg, FutureWarning)\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "path2 = path_figs+'histograms/'\n",
    "Path(path2).mkdir(exist_ok = True)\n",
    "\n",
    "fig, ax = plt.subplots()\n",
    "\n",
    "ax = sns.distplot(data[adaptive_ite_name],  bins=400, kde = False,ax = ax)\n",
    "ax.set_xlabel('ITE-PCM')\n",
    "#ax.set_xlim(-2,2)\n",
    "if save:\n",
    "    fig.savefig(path2+'adaptivehist.pdf', bbox_inches='tight',pad_inches = 0)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [],
   "source": [
    "from evaluations import MAE_pd "
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Table 1, Main text (column: PCM (this work), row: 2M)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "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>mean</th>\n",
       "      <th>std</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>ITE-ADAPTIVE-3CLUST-err-GDBR</th>\n",
       "      <td>0.037</td>\n",
       "      <td>0.136</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                               mean    std\n",
       "ITE-ADAPTIVE-3CLUST-err-GDBR  0.037  0.136"
      ]
     },
     "execution_count": 25,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "#ite_column = 'ITE-GDBR'\n",
    "ite_column = 'ITE-GDBR'\n",
    "clust2 = 'ITE-ADAPTIVE-3CLUST'\n",
    "data = data.groupby(clust2).apply(lambda x: MAE_pd(x, 'C', ite_column, clust2+'-err-GDBR'))\n",
    "errors = data.describe().loc[['mean', 'std'], [col for col in data.columns if 'err' in col]].T\n",
    "errors.sort_values(by = 'mean').round(3)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Table 2, Main text (columns: PCM (this work), row: 2M)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "ITE-ADAPTIVE-3CLUST\n",
       "0    0.041\n",
       "1    0.996\n",
       "2    1.993\n",
       "Name: ITE-GDBR, dtype: float64"
      ]
     },
     "execution_count": 24,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "data.groupby('ITE-ADAPTIVE-3CLUST').mean()['ITE-GDBR'].round(3)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Confusion Matrix (Not displayed in text for 2M)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "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>C0 Pred</th>\n",
       "      <th>C1 Pred</th>\n",
       "      <th>C2 Pred</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>C0 True</th>\n",
       "      <td>0.991</td>\n",
       "      <td>0.009</td>\n",
       "      <td>0.000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>C1 True</th>\n",
       "      <td>0.029</td>\n",
       "      <td>0.957</td>\n",
       "      <td>0.014</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>C2 True</th>\n",
       "      <td>0.000</td>\n",
       "      <td>0.008</td>\n",
       "      <td>0.992</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "         C0 Pred  C1 Pred  C2 Pred\n",
       "C0 True    0.991    0.009    0.000\n",
       "C1 True    0.029    0.957    0.014\n",
       "C2 True    0.000    0.008    0.992"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "from IPython.display import display\n",
    "\n",
    "path4 = path_figs+'matrices/'\n",
    "Path(path4).mkdir(exist_ok = True)\n",
    "\n",
    "mat = confusion_matrix(data, 'C', 'ITE-ADAPTIVE-3CLUST', 3, save = save, save_dir = path4)\n",
    "display(mat.round(3))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python [conda env:jorje]",
   "language": "python",
   "name": "conda-env-jorje-py"
  },
  "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.7.2"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
