{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "The autoreload extension is already loaded. To reload it, use:\n",
      "  %reload_ext autoreload\n"
     ]
    }
   ],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "from sklearn.linear_model import LinearRegression, Lasso, LogisticRegression\n",
    "from sklearn.ensemble import GradientBoostingRegressor, GradientBoostingClassifier\n",
    "from sklearn.ensemble import RandomForestRegressor, RandomForestClassifier\n",
    "from sklearn.preprocessing import PolynomialFeatures\n",
    "from sklearn.pipeline import Pipeline\n",
    "import scipy.special"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# 2. Synthetic Data with Binary Instrument and Treatment\n",
    "\n",
    "Data generating process inspired by an \"intent to treat\" instrument setting with non-compliance. The instrument corresponds to a fully randomized recommendation of treatment. Then each sample complies with the recommendation with some probability. This probability also depends on an unobserved confounder that has a direct effect on the outcome. Moreover, compliance also depends on the observed feature $X$.\n",
    "\n",
    "\\begin{align}\n",
    "X \\sim \\; & \\text{U}[0.2, 1]^d \\tag{features}\\\\\n",
    "Z \\sim \\; & \\text{Bernoulli}(p=.5) \\tag{instrument}\\\\\n",
    "\\nu \\sim \\; & \\text{U}[0, 1] \\tag{unobserved confounder}\\\\\n",
    "C \\sim \\; & \\text{Bernoulli}(p=\\text{Logistic}(X[0] + \\nu)) \\tag{compliance indicator}\\\\\n",
    "T \\sim \\; & C\\cdot Z + (1 - C)\\cdot (1 - Z) \\tag{treatment}\\\\\n",
    "y \\sim \\; & \\text{Normal}(\\mu=\\theta(X) \\cdot (T + \\nu) + X[0], \\sigma=.1) \\tag{outcome}\n",
    "\\end{align}\n",
    "\n",
    "Moreover:\n",
    "\\begin{align}\n",
    "\\theta(X) = \\; & \\alpha + \\beta \\cdot X[0] \\tag{CATE}\n",
    "\\end{align}\n",
    "\n",
    "We need to make sure that for \"overlap\" we have that:\n",
    "\\begin{equation}\n",
    "Cov[T, Z \\mid X] = (P[T=1\\mid Z=1, X] - P[T=1\\mid Z=0, X])\\cdot P[Z=1\\mid X] \\cdot (1-P[Z=1\\mid X]) \\geq \\gamma > 0\n",
    "\\end{equation}\n",
    "for the DRIV method to work, as the variance depends inversely in $\\gamma$. This is the reason that we have $X[0]$ be distributed strictly positively, so that the probability of compliance $C$ is bounded strictly above $0.5$. This then implies that:\n",
    "\\begin{equation}\n",
    "P[T=1 \\mid Z=1, X] - P[T=1 \\mid Z=0, X] = P[C=1\\mid X] - P[C=0\\mid X] = 2 P[C=1 \\mid X] - 1 >0\n",
    "\\end{equation}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "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"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 720x144 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "def dgp_binary(n, d, true_fn):\n",
    "    X = np.random.uniform(-1, 1, size=(n, d))\n",
    "    Z = np.random.binomial(1, .66, size=(n,))\n",
    "    nu = np.random.uniform(0, 1, size=(n,))\n",
    "    C = np.random.binomial(1, scipy.special.expit(10*(X[:, 0] + .4 + nu))) # Compliers when recomended\n",
    "    C0 = np.random.binomial(1, scipy.special.expit(10*(X[:, 1] + nu))) # always takers \n",
    "    plt.title(\"Pr[T=1 | Z=1, X]\")\n",
    "    plt.scatter(X[:, 0], scipy.special.expit(10*(X[:, 0] + .4 + nu)))\n",
    "    plt.show()\n",
    "    plt.title(\"Pr[T=1 | Z=1, X]\")\n",
    "    plt.scatter(X[:, 1], scipy.special.expit(10*(X[:, 1] + nu)))\n",
    "    plt.show()\n",
    "    T = C * Z + (1 - C*Z) * C0\n",
    "    y = true_fn(X) * (T + nu)  + X[:, 0] + np.random.normal(0, .1, size=(n,))\n",
    "    return y, T, X, Z\n",
    "\n",
    "\n",
    "true_fn = lambda X: 1.7 *np.ones(X.shape[0]) + 5*X[:,0] - 5*X[:, 1]\n",
    "\n",
    "np.random.seed(123)\n",
    "n = 3000\n",
    "d = 29\n",
    "y, T, X, Z = dgp_binary(n, d, true_fn)\n",
    "\n",
    "X_df = pd.DataFrame(X, columns=['f'+str(i) for i in range(X.shape[1])])\n",
    "\n",
    "plt.figure(figsize=(10, 2))\n",
    "plt.subplot(1, 2, 1)\n",
    "plt.hist(T[Z==0])\n",
    "plt.title(\"T[Z=0]: Total: {}, T1/Total: {:.2f}\".format(T[Z==0].shape[0], np.sum(T[Z==0])/T[Z==0].shape[0]))\n",
    "plt.subplot(1, 2, 2)\n",
    "plt.hist(T[Z==1])\n",
    "plt.title(\"T[Z=1]: Total: {}, T1/Total: {:.2f}\".format(T[Z==1].shape[0], np.sum(T[Z==1])/T[Z==1].shape[0]))\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# NLSYM DATA"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'\\n# Preprocess data\\ndf = pd.read_csv(\"data/card.csv\")\\ndata_filter = df[\\'educ\\'].values >= 6\\nT = df[\\'educ\\'].values[data_filter]\\nZ = df[\\'nearc4\\'].values[data_filter]\\ny = df[\\'lwage\\'].values[data_filter]\\n\\n# Impute missing values with mean, add dummy columns\\n# I excluded the columns \\'weights\\' as we don\\'t know what it is\\nX_df = df[[\"age\"]].copy()\\nX_df[\\'fatheduc\\'] = df[\\'fatheduc\\'].fillna(value=df[\\'fatheduc\\'].mean())\\nX_df[\\'fatheduc_nan\\'] = df[\\'fatheduc\\'].isnull()*1\\nX_df[\\'motheduc\\'] = df[\\'motheduc\\'].fillna(value=df[\\'motheduc\\'].mean())\\nX_df[\\'motheduc_nan\\'] = df[\\'motheduc\\'].isnull()*1\\nX_df[[\\'momdad14\\', \\'sinmom14\\', \\'step14\\', \\'reg661\\', \\'reg662\\',\\n        \\'reg663\\', \\'reg664\\', \\'reg665\\', \\'reg666\\', \\'reg667\\', \\'reg668\\', \\'reg669\\', \\'south66\\']] = df[[\\'momdad14\\', \\'sinmom14\\', \\'step14\\', \\'reg661\\', \\'reg662\\',\\n        \\'reg663\\', \\'reg664\\', \\'reg665\\', \\'reg666\\', \\'reg667\\', \\'reg668\\', \\'reg669\\', \\'south66\\']]\\nX_df[[\\'black\\', \\'smsa\\', \\'south\\', \\'smsa66\\', \\'enroll\\']] = df[[\\'black\\', \\'smsa\\', \\'south\\', \\'smsa66\\', \\'enroll\\']]\\nX_df[\\'kww\\'] = df[\\'kww\\'].fillna(value=df[\\'kww\\'].mean())\\nX_df[\\'kww_nan\\'] = df[\\'kww\\'].isnull()*1\\nX_df[\\'iq\\'] = df[\\'iq\\'].fillna(value=df[\\'iq\\'].mean())\\nX_df[\\'iq_nan\\'] = df[\\'iq\\'].isnull()*1\\nX_df[\\'libcrd14\\'] = (df[\\'libcrd14\\']==1)*1\\nX_df[\\'libcrd14_nan\\'] = (df[\\'libcrd14\\'].isnull())*1\\n#X_df[[\\'exper\\', \\'expersq\\']] = df[[\\'exper\\', \\'expersq\\']]\\ncolumns_to_scale = [\\'age\\', \\'fatheduc\\', \\'motheduc\\', \\'kww\\', \\'iq\\']#, \\'exper\\', \\'expersq\\']\\nscaler = StandardScaler()\\nX_df[columns_to_scale] = scaler.fit_transform(X_df[columns_to_scale])\\nX = X_df.values[data_filter]\\n\\ntrue_fn = lambda x: np.zeros(x.shape[0])\\n'"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "import pandas as pd\n",
    "from sklearn.preprocessing import StandardScaler\n",
    "\"\"\"\n",
    "# Preprocess data\n",
    "df = pd.read_csv(\"data/card.csv\")\n",
    "data_filter = df['educ'].values >= 6\n",
    "T = df['educ'].values[data_filter]\n",
    "Z = df['nearc4'].values[data_filter]\n",
    "y = df['lwage'].values[data_filter]\n",
    "\n",
    "# Impute missing values with mean, add dummy columns\n",
    "# I excluded the columns 'weights' as we don't know what it is\n",
    "X_df = df[[\"age\"]].copy()\n",
    "X_df['fatheduc'] = df['fatheduc'].fillna(value=df['fatheduc'].mean())\n",
    "X_df['fatheduc_nan'] = df['fatheduc'].isnull()*1\n",
    "X_df['motheduc'] = df['motheduc'].fillna(value=df['motheduc'].mean())\n",
    "X_df['motheduc_nan'] = df['motheduc'].isnull()*1\n",
    "X_df[['momdad14', 'sinmom14', 'step14', 'reg661', 'reg662',\n",
    "        'reg663', 'reg664', 'reg665', 'reg666', 'reg667', 'reg668', 'reg669', 'south66']] = df[['momdad14', 'sinmom14', 'step14', 'reg661', 'reg662',\n",
    "        'reg663', 'reg664', 'reg665', 'reg666', 'reg667', 'reg668', 'reg669', 'south66']]\n",
    "X_df[['black', 'smsa', 'south', 'smsa66', 'enroll']] = df[['black', 'smsa', 'south', 'smsa66', 'enroll']]\n",
    "X_df['kww'] = df['kww'].fillna(value=df['kww'].mean())\n",
    "X_df['kww_nan'] = df['kww'].isnull()*1\n",
    "X_df['iq'] = df['iq'].fillna(value=df['iq'].mean())\n",
    "X_df['iq_nan'] = df['iq'].isnull()*1\n",
    "X_df['libcrd14'] = (df['libcrd14']==1)*1\n",
    "X_df['libcrd14_nan'] = (df['libcrd14'].isnull())*1\n",
    "#X_df[['exper', 'expersq']] = df[['exper', 'expersq']]\n",
    "columns_to_scale = ['age', 'fatheduc', 'motheduc', 'kww', 'iq']#, 'exper', 'expersq']\n",
    "scaler = StandardScaler()\n",
    "X_df[columns_to_scale] = scaler.fit_transform(X_df[columns_to_scale])\n",
    "X = X_df.values[data_filter]\n",
    "\n",
    "true_fn = lambda x: np.zeros(x.shape[0])\n",
    "\"\"\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\moprescu\\AppData\\Local\\Continuum\\anaconda3\\lib\\site-packages\\sklearn\\preprocessing\\data.py:645: DataConversionWarning: Data with input dtype int64, float64 were all converted to float64 by StandardScaler.\n",
      "  return self.partial_fit(X, y)\n",
      "C:\\Users\\moprescu\\AppData\\Local\\Continuum\\anaconda3\\lib\\site-packages\\sklearn\\base.py:464: DataConversionWarning: Data with input dtype int64, float64 were all converted to float64 by StandardScaler.\n",
      "  return self.fit(X, **fit_params).transform(X)\n"
     ]
    }
   ],
   "source": [
    "# Preprocess data\n",
    "df = pd.read_csv(\"data/card.csv\")\n",
    "data_filter = df['educ'].values >= 6\n",
    "T = df['educ'].values[data_filter]\n",
    "Z = df['nearc4'].values[data_filter]\n",
    "y = df['lwage'].values[data_filter]\n",
    "\n",
    "# Impute missing values with mean, add dummy columns\n",
    "# I excluded the columns 'weights' as we don't know what it is\n",
    "X_df = df[['exper', 'expersq']].copy()\n",
    "X_df['fatheduc'] = df['fatheduc'].fillna(value=df['fatheduc'].mean())\n",
    "X_df['fatheduc_nan'] = df['fatheduc'].isnull()*1\n",
    "X_df['motheduc'] = df['motheduc'].fillna(value=df['motheduc'].mean())\n",
    "X_df['motheduc_nan'] = df['motheduc'].isnull()*1\n",
    "X_df[['momdad14', 'sinmom14', 'reg661', 'reg662',\n",
    "        'reg663', 'reg664', 'reg665', 'reg666', 'reg667', 'reg668', 'reg669', 'south66']] = df[['momdad14', 'sinmom14', \n",
    "        'reg661', 'reg662','reg663', 'reg664', 'reg665', 'reg666', 'reg667', 'reg668', 'reg669', 'south66']]\n",
    "X_df[['black', 'smsa', 'south', 'smsa66']] = df[['black', 'smsa', 'south', 'smsa66']]\n",
    "#X_df[['black', 'smsa', 'south', 'smsa66', 'enroll']] = df[['black', 'smsa', 'south', 'smsa66', 'enroll']]\n",
    "#X_df['kww'] = df['kww'].fillna(value=df['kww'].mean())\n",
    "#X_df['kww_nan'] = df['kww'].isnull()*1\n",
    "#X_df['iq'] = df['iq'].fillna(value=df['iq'].mean())\n",
    "#X_df['iq_nan'] = df['iq'].isnull()*1\n",
    "#X_df['libcrd14'] = (df['libcrd14']==1)*1\n",
    "#X_df['libcrd14_nan'] = (df['libcrd14'].isnull())*1\n",
    "#X_df[['exper', 'expersq']] = df[['exper', 'expersq']]\n",
    "#columns_to_scale = ['age', 'fatheduc', 'motheduc', 'kww', 'iq', 'exper', 'expersq']\n",
    "columns_to_scale = ['fatheduc', 'motheduc', 'exper', 'expersq']\n",
    "scaler = StandardScaler()\n",
    "X_df[columns_to_scale] = scaler.fit_transform(X_df[columns_to_scale])\n",
    "X = X_df.values[data_filter]\n",
    "\n",
    "true_fn = lambda x: np.zeros(x.shape[0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Index(['exper', 'expersq', 'fatheduc', 'fatheduc_nan', 'motheduc',\n",
       "       'motheduc_nan', 'momdad14', 'sinmom14', 'reg661', 'reg662', 'reg663',\n",
       "       'reg664', 'reg665', 'reg666', 'reg667', 'reg668', 'reg669', 'south66',\n",
       "       'black', 'smsa', 'south', 'smsa66'],\n",
       "      dtype='object')"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "X_df.columns"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "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": [
    "plt.hist(T[T<=12])\n",
    "plt.hist(T[T>12])\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 720x144 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "(2991, 22)"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "plt.figure(figsize=(10, 2))\n",
    "plt.subplot(1, 2, 1)\n",
    "plt.hist(T[Z==0])\n",
    "plt.title(\"T[Z=0]: Total: {}, T1/Total: {:.2f}\".format(T[Z==0].shape[0], np.sum(T[Z==0])/T[Z==0].shape[0]))\n",
    "plt.subplot(1, 2, 2)\n",
    "plt.hist(T[Z==1])\n",
    "plt.title(\"T[Z=1]: Total: {}, T1/Total: {:.2f}\".format(T[Z==1].shape[0], np.sum(T[Z==1])/T[Z==1].shape[0]))\n",
    "plt.show()\n",
    "X.shape"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# ANALYSIS"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Defining some hyperparameters"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 274,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.003343363423604146\n"
     ]
    }
   ],
   "source": [
    "random_seed = 123459 # random seed for each experiment\n",
    "N_SPLITS = 10 # number of splits for cross-fitting\n",
    "COV_CLIP = 10/X.shape[0] # covariance clipping in driv\n",
    "print(COV_CLIP)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Defining some generic non-parametric regressors and classifiers"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 275,
   "metadata": {},
   "outputs": [],
   "source": [
    "from utilities import RegWrapper\n",
    "from sklearn.model_selection import GridSearchCV\n",
    "from sklearn.linear_model import LassoCV, LogisticRegressionCV\n",
    "from xgboost import XGBClassifier, XGBRegressor\n",
    "from xgb_utilities import XGBWrapper\n",
    "\n",
    "\n",
    "# This a generic non-parametric regressor\n",
    "#model = lambda: GradientBoostingRegressor(n_estimators=20, max_depth=3, min_samples_leaf=20,\n",
    "#                                         n_iter_no_change=5, min_impurity_decrease=.001, tol=0.001)\n",
    "#model = lambda: XGBWrapper(XGBRegressor(gamma=0.001, n_estimators=100, min_child_weight=50, n_jobs=10),\n",
    "#                           early_stopping_rounds=5, eval_metric='rmse', binary=False)\n",
    "\n",
    "# This a generic non-parametric regressor\n",
    "#model = lambda: GridSearchCV(GradientBoostingRegressor(),\n",
    "#                             param_grid={'n_estimators': [10, 30, 60]}, cv=3, iid=True)\n",
    "#model = lambda: GridSearchCV(RandomForestRegressor(n_estimators=100, min_samples_leaf=100),\n",
    "#                             param_grid={'max_depth': [1, 3, 5]}, cv=3, iid=True)\n",
    "#model = lambda: GradientBoostingRegressor(n_estimators=10)\n",
    "#model = lambda: Lasso(alpha=10/np.sqrt(X.shape[0]))\n",
    "model = lambda: LassoCV(cv=5, n_jobs=-1)\n",
    "\n",
    "# This is a generic non-parametric classifier. We have to wrap it with the RegWrapper, because\n",
    "# we want to use predict_proba and not predict. The RegWrapper calls predict_proba of the\n",
    "# underlying model whenever predict is called.\n",
    "#model_clf = lambda: RegWrapper(GridSearchCV(GradientBoostingClassifier(),\n",
    "#                                            param_grid={'n_estimators': [10, 30, 60]}, cv=3, iid=True))\n",
    "#model_clf = lambda: RegWrapper(GridSearchCV(RandomForestClassifier(n_estimators=100, min_samples_leaf=100),\n",
    "#                             param_grid={'max_depth': [1, 3, 5]}, cv=3, iid=True))\n",
    "#model_clf = lambda: RegWrapper(GradientBoostingClassifier(n_estimators=10)) \n",
    "#model_clf = lambda: RegWrapper(LogisticRegression(C=10/np.sqrt(X.shape[0]), penalty='l1', solver='saga'))\n",
    "model_clf = lambda: RegWrapper(LogisticRegressionCV(n_jobs=-1, cv=5, solver='liblinear',\n",
    "                                                   scoring='neg_log_loss'))\n",
    "#model_clf = lambda: RegWrapper(GradientBoostingClassifier(n_estimators=20, max_depth=3, min_samples_leaf=20,\n",
    "#                                         n_iter_no_change=5, min_impurity_decrease=.001, tol=0.001))\n",
    "#model_clf = lambda: RegWrapper(XGBWrapper(XGBClassifier(gamma=0.001, n_estimators=100, min_child_weight=50, n_jobs=10),\n",
    "#                                          early_stopping_rounds=5, eval_metric='logloss', binary=True))\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Some utility functions"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 276,
   "metadata": {},
   "outputs": [],
   "source": [
    "def nuisance_diagnostic(cate, nuisance_model, property_name, property_fn, \n",
    "                        index_names=None, statistic=np.std, threshold=None):\n",
    "    std = statistic([property_fn(ns) for ns in cate.fitted_nuisances[nuisance_model]], axis=0)\n",
    "    if hasattr(std, '__len__'):\n",
    "        if threshold is None:\n",
    "            coefs = np.argmax(std).flatten()\n",
    "        else:\n",
    "            coefs = np.argwhere(std >= threshold).flatten()\n",
    "        if index_names is None:\n",
    "            index_names = np.arange(std.shape[0])\n",
    "        for high_var in coefs:\n",
    "            plt.title(\"{}: {}[{}] Across Folds\".format(nuisance_model, property_name, index_names[high_var]))\n",
    "            plt.plot([property_fn(ns)[high_var] for ns in cate.fitted_nuisances[nuisance_model]])\n",
    "            plt.xlabel('fold')\n",
    "            plt.ylabel('property')\n",
    "            plt.show()\n",
    "    else:\n",
    "        plt.title(\"{}: {} Across Folds\".format(nuisance_model, property_name))    \n",
    "        plt.plot([property_fn(ns) for ns in cate.fitted_nuisances[nuisance_model]])\n",
    "        plt.xlabel('fold')\n",
    "        plt.ylabel('property')\n",
    "        plt.show()\n",
    "    "
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# ATE via DMLATEIV"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "from dml_ate_iv import DMLATEIV\n",
    "\n",
    "np.random.seed(random_seed)\n",
    "\n",
    "# We need to specify models to be used for each of these residualizations\n",
    "model_Y_X = lambda: model() # model for E[Y | X]\n",
    "model_T_X = lambda: model() # model for E[T | X]. We use a regressor since T is continuous\n",
    "model_Z_X = lambda: model_clf() # model for E[Z | X]. We use a classifier since Z is binary\n",
    "\n",
    "dmlate = DMLATEIV(model_Y_X(), model_T_X(), model_Z_X(),\n",
    "                  n_splits=N_SPLITS, # n_splits determines the number of splits to be used for cross-fitting.\n",
    "                  binary_instrument=True, # a flag whether to stratify cross-fitting by instrument\n",
    "                  binary_treatment=True # a flag whether to stratify cross-fitting by treatment\n",
    "                 )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\moprescu\\AppData\\Local\\Continuum\\anaconda3\\lib\\site-packages\\sklearn\\model_selection\\_split.py:652: Warning: The least populated class in y has only 8 members, which is too few. The minimum number of members in any class cannot be less than n_splits=10.\n",
      "  % (min_groups, self.n_splits)), Warning)\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<dml_ate_iv.DMLATEIV at 0x19a5a6df5f8>"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# We fit DMLATEIV with these models\n",
    "dmlate.fit(y, T, X, Z)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [],
   "source": [
    "# We call effect() to get the ATE\n",
    "ta_effect = dmlate.effect()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "ATE Estimate: 0.137\n",
      "True ATE: 0.000\n",
      "CATE MSE: 0.02\n"
     ]
    }
   ],
   "source": [
    "# Comparison with true ATE\n",
    "print(\"ATE Estimate: {:.3f}\".format(ta_effect))\n",
    "print(\"True ATE: {:.3f}\".format(np.mean(true_fn(X))))\n",
    "# CATE MSE\n",
    "print(\"CATE MSE: {:.2f}\".format(np.mean((true_fn(X) - ta_effect)**2)))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "ATE Estimate Interval: (0.027, 0.248)\n",
      "STD: 0.056\n"
     ]
    }
   ],
   "source": [
    "# We can call normal_effect_interval to get confidence intervals based\n",
    "# based on the asympotic normal approximation\n",
    "ta_effect = dmlate.normal_effect_interval(lower=2.5, upper=97.5)\n",
    "# Comparison with true ATE\n",
    "print(\"ATE Estimate Interval: ({:.3f}, {:.3f})\".format(ta_effect[0], ta_effect[1]))\n",
    "#print(\"True ATE: {:.3f}\".format(np.mean(true_fn(X))))\n",
    "print(\"STD: {:.3f}\".format(dmlate.std))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Model model_Y_X max std of coefs: 0.026554847406610755\n",
      "Model model_T_X max std of coefs: 0.07953278250754159\n",
      "Model model_Z_X max std of coefs: 0.01439120811937396\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "[None, None, None]"
      ]
     },
     "execution_count": 16,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# The property .fitted_nuisances is a dictionary of the form:\n",
    "# {'name_of_nuisance': [fitted_model_fold_1, fitted_model_fold_2, ...]}\n",
    "# then we can access all properties of each of the fitted models for each fold.\n",
    "# If for instance all nuisances have a linear form we can look at the standard deviation\n",
    "# of the coefficients of each of the nuisance model across folds to check for stability\n",
    "[print(\"Model {} max std of coefs: {}\".format(name,\n",
    "                                              np.max(np.std([ns.coef_ for ns in nuisance_insts], axis=0)))) \n",
    " if hasattr(nuisance_insts[0], 'coef_') else None\n",
    " for name, nuisance_insts in dmlate.fitted_nuisances.items()]"
   ]
  },
  {
   "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"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAYwAAAEWCAYAAAB1xKBvAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADl0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uIDIuMi4zLCBodHRwOi8vbWF0cGxvdGxpYi5vcmcvIxREBQAAIABJREFUeJzt3Xd4XHeZ6PHvO+plJFuWNCO5N40cJ3YcnN6JEwKJAywsJDcEAoRs7u4CW2EpC+xlG7t32cvCQjaFlmRDCYFNgAB2Qnp1EsdOLMm9yNaouEij3t77xzmjjBVJHtmaOVPez/PMI82cMq+OpPPOr4uqYowxxpyIz+sAjDHGpAdLGMYYY+JiCcMYY0xcLGEYY4yJiyUMY4wxcbGEYYwxJi6WMLKQiHxfRP4+zn33isi6RMeUikTkcRG5xf3+RhH53UmeZ6+I9InIPTMb4UnF8n03lmavY/GSiHxFRO6dYnvW/t1PxRKGOSUicqWItIpIZcxrBSLSICJ/NMVxa0SkU0SWxbz2NhE5JiKLEhv19Knqfap61Yn2m+JGtF5Vb3L3qRaR+0XkkHsNnhGRc8ed53+JyD4R6RGRX4hIRcy2FSLymHvsThF57ySxfFlENPbGp6o3A++M4+coEZFuEfn1ifb1knu9h9xYo4/PeB1XprKEYU6Jqm4Afgl8I+blLwItwB1THPcq8J/AneLIA74LfElV9850nCKSO9PnPAWlwEvA24AK4AfAr0SkFEBEVgL/BdwEBIBe4Nvutlzgf3CueQVwK3CviNTFvoGILAXej/N7OBnvBwaAq0Sk5mROkMRr/mNVLY15/EuS3jfrWMJIUW6R+K9FZIv7KfNuEQmIyCMiEhGRjSIyO2b/60TkDfcT+uMisiJm2xoRecU97sdA4bj3ulZENrvHPisiq6YZ7l8Al4rINSJyOvCnwCf0xNMI/B1Qg3PT+zzQDXwr3jd1Pz1/SkR2i0iHiPyriPjcbTe7n9z/XUSOAF9xX/+YW/o5KiK/FZGFMee7UkQa3U/u3wIkZtvNIvJ0zPOVIrJBRI64JazPi8jV7s/xQfeT7msTxa2qu1X166raoqojqnoHkA+E3F1uBB5W1SdVtRv4W+APRMQP1AO1wL+7xz4GPIOTXGJ9C/gsMBjv9RznI8DtwBY3njEiMl9EHhSRdhE57F6rCa+5iPhE5ItuaalNRH4oIuXu/oUicq97jmMi8pKIBGLOtdv9m90jIjcyTSJSKyIPub+jnSLyiSn2vcmN8bCIfGHctnNEZJOIdLm/669PN5aMoar2SMEHsBd4HucT5lygDXgFWAMUAI8BX3b3rQN6gCuBPOAzwE6cm1A+sA/4c3fb+4Eh4O/dY89yz30ukINzo9gLFMTEsS6OeNcDB4AXgT+bxs95IXAM6ALqx237NvDtKY5V4Pc4n7QXANuBW9xtNwPDwCeBXKAIeI97XVa4r30ReNbdv9KN4f3udfpz9/jY8z3tfu/H+eT+lzjJ1w+c6277CnDvBL/LSa8hcCbQD5S7z/8H+Oy4fbpxSiRnuN9LzLYNwM9jnv8h8D+TvTdwGdA8RTwLgFHgNPdn3BKzLQd4Dfh3oMT9+S+a4pp/zL3mS3BKVg8C97j7/xHwMFDsnvdtQJl73i4g5O5XA6ycJNa3XO+YbU+4f0OF7jVuB64Yf5z7c3YDl+D8b33d/TnWudufA25yvy8FzvP6/uDVw/MA7DHJL8b5R78x5vnPgO/EPP8k8Av3+78FfhKzzQccdG8MlwCHxt1gnuXNhPEd4Kvj3rsJuDQmjhMmDHffnwKbAN80fs5yoAN45iSukQJXxzz/Y+BR9/ubgf3j9n8E+Pi469QLLAQ+DDwfs02AZiZOGDcAr04S01tuYFNdQ/cGuRX4XMxrjwK3jdsv+vvMA3bjfCjIA67CKUX81t2vFNgBLJ7svTlxwvgisNn9vhYYAda4z8/HufHmTnDcRNf8UeCPY56HcD6w5OIkk2eBVeOOKcH5EPE+oOgEfwNfcX/+YzGPWmC+G7c/Zt9/Ar4//vcEfAn40bj3H+TNhPEkTmm48mT+lzPpYVVSqa015vu+CZ6Xut/X4pQiAFDVUZxP+3PdbQfV/ct37Yv5fiHwl26VwDEROYbzz1Z7EvG+ATS67x+vf8P5JDhPRK4/ifc8EPP9Po6P+8C4fRcC34j5OY/gJIbodRrb371e44+Pmg/sOolYjyMiRTifsJ9X1X+K2dSNk0hilQERVR3CKSldA4RxSgA/wUlu4NzY7lHVPacQ2oeB+wBU9RDO7+cj7rb5wD5VHZ7k2PHX7Li/Tff7XJyS8z3Ab4EfidMB4F9EJE9Ve4APArcBLSLyKxGpnyLen6jqrJjHIfd9j6hqZNx7z53g+PG/+x7gcMz2j+OU4hvdarNrp4glo1nCyAyHcG6GAIiI4PxjH8SpOpnrvha1IOb7A8A/jPuHK1bV+xMdtIhcAbwb58ZwG87NvGLqo95ifsz3C3CuRdT4NpQDwB+N+1mLVPVZnOs0dq6YaziRA8DSSbbFNf2ziBQAv8D5HY3vTfYGsDpm3yU4VSXbAVR1i6peqqpzVPUdONU9L7q7XwF8SkTCIhJ2f4afiMhn44zrAmA58LmYc5wL3CBOI/YBYIFM3qA9/uc/7m8T53c0DLSq6pCq/p2qngZcAFyLk6xQ1d+q6pU41VGNwJ3xxD/ufSvcdp/Y9z44wb7jf/fFwJyxH0h1h6reAFQDXwMeEJGSacaTESxhZIafANeIyBXi9Db6S5weLs/i1L8O49xEckXkD4BzYo69E7hNRM4VR4nbeO0f/yYzyf2HuxOnvaNdVR/BqYv/92me6q9FZLaIzAc+Dfx4in1vx7kRrnRjKBeRP3S3/QpYKSJ/4N4MPwUEJznPL4GgiPyZOF2I/fJmt9hWYFG08X0i7u/oAZxS4ocnKJHdB6wXkYvd6/R/gAejn5ZFZJXbYFwsIn+Fc1P9vnvsFcDpOHX2Z+LcOP8Ip0daPD6C83s4LeYcp+O0M7wTJzG1AP/s/q0UisiFU5zvfuDPRWSxOL3A/hGnV9OwiFwuImeISA5Om8UQMCJO547r3J99AKfENRJn/ACo6gGcv/9/cmNchVNSuG+C3R8ArhWRi0QkH+d6j/3+RORDIlLl/p6OuS9PK55MYQkjA6hqE/Ah4Js47QHrcfr9D6rqIPAHOPXLR3GK+g/GHLsJ+AROr5qjOA2UNych7H/Eqb6K/Qf+M+CdInIVgIjcLiK3n+A8/wO8DGzGuenfPdmOqvpznE+IPxKRLuB13DEJqtqB01j8zzjVEctxeh9NdJ4ITgeD9TjVQjuAy93NP3W/HhaRVyYJJfpp+irgmLw5fuBi9/xv4JS47sPpkODHaZ+Jugnnpt2GkyCuVNUB99jDqhqOPnBubEfV6W01JREpBD4AfDP2HG711j3AR1R1xP25lwH7carCPjjFab/rHvsksAencf+T7rYgzs26C2jAqfq6F+e+9Jc4ye4IcOm4nz9eNwCL3PP8HKeTyIbxO7nX+0+A/8a5rkd5s4oP4GrgDRHpxuk+fr2q9p9EPGlPjq/aNiZ9iIgCy1V1p9exTEVEmnBKAT9X1Y+caP8Ex3I3TmJsU9VlJ9rfmFiWMEzaSpeEYUymsCopExdxBgx2T/D4/BTH3DjJMW8kM3ZjzMywEoYxxpi4WAnDGGNMXFJpQrZTVllZqYsWLfI6DGOMSRsvv/xyh6pWxbNvRiWMRYsWsWnTJq/DMMaYtCEi+068l8OqpIwxxsTFEoYxxpi4WMIwxhgTF0sYxhhj4mIJwxhjTFwsYRhjjImLJQxjjDFxsYRhjtMzMMz9L+5ndNSmjDHGHM8ShjnO7U/s4nMPbuXl/Ue9DiUl/PaNMD96cb/XYRiTEixhmDG9g8Pc87wz6LOxpcvjaFLD7U/s4t82bPc6DGNSgiUMM+aBl5s51jtEjk9oDEe8Dsdzo6NKUzhCe2SAIz2DXodjjOcsYRgARkaVu5/ew5oFszhrwSxLGEDz0T56B52lm7e32vUwxhKGAWDDtjD7Dvdy68VLqA+WsT0cIdvXSmkIv1ktZwnDGEsYxnXHk7tZUFHMVSuDhIJ+IgPDHDzW53VYnmoKRxCBkvwcmqzEZYwlDAMv7zvCK/uP8fGLFpPjE1bU+AFobMnum2RjuIsFFcWsrC23EoYxWMIwwJ1P7qG8KI8/XDsPgLqAkzCasvwm2dgSoT7opy5YSpNV0RljCSPb7e3o4bfbwtx03kKK8531tPyFecybXZTVDd99gyPsPdxDKFhGKOCnq3+Y1q4Br8MyxlOWMLLc3U/vIc/n48MXLDzu9fqgP6vHYuxoizCqsCLotxKXMS5LGFnsaM8gP335AO9ZU0u1v/C4baGgn90dPQwMj3gUnbeipatQTMLYnsUlLmPAEkZWu/f5ffQPjXLLxUvesq0+WMbIqLKzrduDyLzX2BKhMM/HwjklzC7Jp8pfYCUMk/UsYWSp/qERfvDcXi4PVY19go5VH3SrYbL0U3VTaxehgJ8cnwAQCvitp5TJepYwstQvXj1IR/cgn5igdAGwqLKE/BxfViYMVaWhJUIo+GYirQv42dHabbP4mqxmCSMLjY4qdz61m5W1ZZy/dM6E++Tl+FhWXUpDFiaM9m5n7qj6YNnYa6FgKX1DIzQfze7BjCa7WcLIQo9vb2NXew+3XrIEEZl0v/qgn6Zw9vWUipaq6seVMMB6SpnsZgkjC93x5G5qywt51xk1U+5XX+OntWuAo1k2U2t0hHtsldTyaE8pSxgmi1nCyDJbmo/x/O4jfPTCxeTlTP3rD7lVMtk2gK8xHKHaX8Cc0oKx10oLcpk3uygr23SMibKEkWXufGoP/oJcrj9n/gn3fbOnVHZVSzWGu44rXURZTymT7SxhZJHmo738emsLN5y7AH9h3gn3r/YXMLs4L6tKGMMjo+xo62ZFTdlbttUF/exq72ZoZNSDyIzxniWMLPK9Z/YiwM0XLIprfxEhFPRnVcLYe7iHweFRQhOMTQkF/AyNKHs7ejyIzBjvWcLIEp19Q/zoxf1cu6qG2llFcR9XHyxje2ska8YfNLgN3vU1b00Y1lPKZDtLGFni/hf30zM4MuE0IFOpD/rpHRzhwNHeBEWWWprCEXJ8wrLq0rdsW1JVQo5PbE4pk7UsYWSBweFRvv/MXi5cNofT55ZP69ho42+2VEs1hrtYUllCQW7OW7YV5uWwaE6xlTBM1rKEkQV+ueUQ4a7+aZcuwKmGEcme1fcawxHqJ2jwjgoF/Wxvzc4JGY2xhJHhVJU7ntzN8upSLqurmvbxJQW5LKgopqk187vWRvqHaD7ad9wI7/HqAn72Hu6hfyg7p3032c0SRoZ7emcHjeEInzjBNCBTCQWyo6dUdIzFVAkjFPCjStZO+26yW0IThojMEpEHRKRRRBpE5Pxx298tIltEZLOIbBKRi9zXzxSR50TkDXf7BxMZZya786k9VPkLePeZtSd9jvqaMvZ2ZP6n6oYJpgQZry7Lp3032S3RJYxvAL9R1XpgNdAwbvujwGpVPRP4GHCX+3ov8GFVXQlcDfw/EZmV4FgzTkNLF09ub+fmCxZN2Igbr/qgn1GFHRled98Y7sJfkMvcKbodL6woJj/XZyO+TVZKWMIQkTLgEuBuAFUdVNVjsfuoareqRjv4lwDqvr5dVXe43x8C2oDpV8Bnubue2kNRXg43nrvglM5TP9ZTKrPbMZrCzhoYU1Xd5eb4WFZVaj2lTFZKZAljCdAOfE9EXhWRu0SkZPxOIvJeEWkEfoVTyhi//RwgH9g10ZuIyK1uddam9vb2mf0J0lhrVz8PvXaQD549n1nF+ad0roVzSijM82V0O4aquj2kJq+OigoF/TYWw2SlRCaMXOAs4DuqugboAf5m/E6q+nO3yuo9wFdjt4lIDXAP8FFVnXACH1W9Q1XXquraqiorhER9/9m9jIwqH7tw8SmfK8cnLK/2Z3S9/aHOfiL9w8ctmjSZuoCfQ539dPUPJSEyY1JHIhNGM9Csqi+4zx/ASSATUtUngaUiUgljVVq/Ar6oqs8nMM6M0z0wzH3P7+Pq04MsmFM8I+esD/ozukqqscX52abqIRUVCjqjwHdYtZTJMglLGKoaBg6ISMh96QpgW+w+IrJM3ApjETkLp+rpsIjkAz8HfqiqP01UjJnqJy8doKt/eNL1uk9GKOino3uQju6BGTtnKolWt9XFkTDG5pQKZ3YnAGPGy03w+T8J3OcmgN3AR0XkNgBVvR14H/BhERkC+oAPqqqKyAdwGszniMjN7rluVtXNCY437Q2PjPLdZ/Zw9qLZrFkwe8bOG62qaQpHqFxWcIK9009jOMLcWUWUxTHt+9xZRZTk51hPKZN1Epow3Bv82nEv3x6z/WvA1yY47l7g3kTGlql+80aY5qN9fOna02b0vNHG4IaWLi5cVjmj504FjS1drIijwRucad/rgpndpmPMRGykdwZRVe58cjeLK0tYtyIwo+euLC2gsjQ/I2+SA8Mj7O7oiavBO8pW3zPZyBJGBnlxzxFea+7k4xctxuc7uWlAplIfLMvI8Qc727oZGdUpR3iPVxfwc7gnc9t0jJmIJYwMcudTe6goyed9Z81LyPlDbjXMSIYtphQtNcVbJQVvTh9i4zFMNrGEkSF2tXezsaGVm85bSFH+yU8DMpVQ0M/A8Cj7DmfWEqWN4Qj5uT4WzXnLuNJJ2ep7JhtZwsgQdz21h/xcHzedvzBh77HCrePPtBHfjeEIy6tLyc2J/9+hsjSfipJ8a8cwWcUSRgbo6B7gZ680876z5lFZmrgur8sDpfgkAxNGS9e02i/A7SkVKM3ITgDGTMYSRga457l9DA6PcsvFpz4NyFQK83JYVFlCUwaN+D7SM0hbZGCs9DQdTk+pbt6cP9OYzGYJI831DY5wz/P7WLciwNKq0oS/nzNFSOZ8qo5OdxLPpIPj1QX9dA8Mc6izf6bDMiYlWcJIcz97pZkjPYN8IsGli6hQoIz9R3rpGRhOyvslWmMciyZNJhSwnlImu1jCSGOjo8rdT+9h9bxyzllckZT3rK9xlijNlMbepnCEOSX5VJ1E289y6yllsowljDS2saGVPR09p7Re93TVZ9gSpY3hrhMumjSZ8qI8asoLrYRhsoYljDR251O7mTe7iKtXBpP2nvNnF1Ocn5MR7Rgjo8r21u5pTQkyXl3AbyUMkzUsYaSpV/Yf5aW9R/nYhYunNX7gVPl8Ql0gM9bG2H+kl76hkbjWwJhMXaCUHe7UIsZkOksYaequp3ZTVpjLB86en/T3rnenCEn37qRjiyadRA+pqLqAn8EMHP1uzEQsYaSh/Yd7+c3rYW48byGlBYle0uSt6oN+jvYO0R5J74n3GsMRfALLq08+YYzNKWXVUiYLWMJIQ999Zg85PuHmCxZ58v4ht86/Ic3bMRrDXSyaU3JKc28tqy5FxFbfM9nBEkaaOdY7yI9fOsB1q+cSKCv0JIY3e0qldztGUzhyStVRAMX5uSyoKLYShskKljDSzH0v7KdvaIRPXJKcgXoTmV2ST6CsYGzQWzrqHRxm35FeQoGT7yEVZT2lTLawhJFGBoZH+P6ze7mkruqUuoLOhFCwLK271jpzQJ1ag3dUKOBnT0cPA8MjMxCZManLEkYa+Z/Nh2iPDHDrxUu8DoX6oJ+dbd0Mj4x6HcpJifaQOplJB8erC/oZGVV2t1tPKZPZLGGkieh63fVBPxcum+N1ONQH/QyOjLKnIz1vko3hCMX5OcybXXTK5xqbU8qqpUyGs4SRJh7f3s6Otm5uTeI0IFOJdidN12qp6JQgM7H2+eLKEnJ9kjHTpRgzGUsYaeKup3YTLCvk2lW1XocCON1Jc9L0JqmqNIYjpzTCO1Z+ro8lVSVWwjAZzxJGGnj9YCfP7DzMRy9cRH5uavzKCnJzWFJZkpZThLRFBjjWOzSjHQesp5TJBqlx9zFTuuup3ZTk53D9OQu8DuU4oTRdTKnBbfA+mTUwJhMK+DlwpC9j1gkxZiKWMFLcoWN9PLylhevPWUB5UZ7X4RxnRU0ZzUf7iPQPeR3KtESr0WaqSgqcnlIAO9psxLfJXJYwUtz3n90LwEcvXORpHBNJ195BjeEINeWFzCrOn7Fz2up7JhtYwkhhXf1D/PcL+7nmjBrmzS72Opy3SNeeUg0tXTNaHQUwv6KYwjxf2iVPY6bDEkYK+/GLB+geGOYTKTBQbyLzZhdRWpCbVlOEDI2Msqv91BZNmkiOT1hebQ3fJrNZwkhRQyOjfPeZPZy3pIIz5pV7Hc6ERISQuzZGutjd3sPQiM5o+0VUXcBvJQyT0SxhpKhfb22hpbOfWy9JzdJFVH3QT0O4K20WU4p2A56JOaTGCwVLae0a4Fjv4Iyf25hUkNCEISKzROQBEWkUkQYROX/c9neLyBYR2Swim0TkophtHxGRHe7jI4mMM9WoKnc8uZtl1aVcVlftdThTqg/6ifQP09LZ73UocWkMR8j1CUsqS2f83HVjnQCsp1SijIwqP3npAB/8r+c4cKTX63CyTqJLGN8AfqOq9cBqoGHc9keB1ap6JvAx4C4AEakAvgycC5wDfFlEZic41pTx3K7DvHGoi1suWjwjU1ckUnQxpXSplmps6WJZdWlCBkBGG9KtHSMxntt1mPXffJrP/GwLL+w5wo9e2u91SFknYQlDRMqAS4C7AVR1UFWPxe6jqt36Zl1GCRD9/h3ABlU9oqpHgQ3A1YmKNdXc+dRuKkvzec+auV6HckLRm2RDmoz4bprBKUHGC5YV4i/Mta61M2xvRw+3/nATN9z5PJ19Q/zHDWu4eHklD7/WkjZVoZkikQtCLwHage+JyGrgZeDTqnrc9KYi8l7gn4Bq4Br35bnAgZjdmt3XMt721gi/b2rnL6+sozDv5JcOTZbyojxqywvTooTR2TvEoc7+sVLRTBMRQjZFyIzp6h/iW4/t5HvP7CEvx8dfvyPExy9aTGFeDv1DI3zmgS281tzJmfNneR1q1khklVQucBbwHVVdA/QAfzN+J1X9uVtl9R7gq+7LE9XDTPhRQkRudds/NrW3t89M5B6666ndFOb5+NB5C70OJW71NWVpkTCiN/JENHhH1QWdnlL2yffkDY+Mcs/z+7jsXx/nzqd28941c3n8ry7jTy5fNvYh6h0rg+Tn+Hho8yGPo80uiUwYzUCzqr7gPn8AJ4FMSFWfBJaKSKV77PyYzfOACf8yVPUOVV2rqmurqqpmJnKPtEX6+cWrh/jDt81ndsnMjUJOtJC7mNLgcGovpjTWQypBVVLgjPg+1jtEe2QgYe+RyZ7c3s67/uMp/vYXr7O8upSH//Qi/uX9q6ket359eVEel4aq+OWWQ4yMWnJOloQlDFUNAwdEJOS+dAWwLXYfEVkm7uIOInIWkA8cBn4LXCUis93G7qvc1zLaD5/dx9DoKB+/yLv1uk9GfdDP8KiyuyO1ewc1hiOUF+URHHfzmUnRnlJWLTU9O9u6+dj3X+LD332R/qFRbv/QWfzo1vM4fe7kY5DWr66lLTLAi3uOJDHS7JbINgyATwL3iUg+sBv4qIjcBqCqtwPvAz4sIkNAH/BBtxH8iIh8FXjJPc//UdWM/Kto7epna3MnWw528sPn9vKO04IsqizxOqxpiY6abmyJeL7W+FQaW7qoD/oTugBVXcDprtsUjnDx8vQu8SbD0Z5BvvHoDu59fh9FeTl8/l31fOSCRRTknrj9bt2Kaorycnh4yyHOX+r9KpTZIKEJQ1U3A2vHvXx7zPavAV+b5NjvAt9NXHTJ19bVz9aDnWxp7uT1g51sPdhJm1t14ROni+pfXFXncZTTt6SqhLwcSek5pUZHlaZwhPe/bV5C32dOaQGVpQU24vsEhkZGuee5fXzj0R1E+oe44ZwF/PmVdVSWFsR9juL8XNadFuCRrS383XUrycuxcciJlugSRtZqi/Q7SaG5i60Hj7H1YCetXU5yEIFlVaVctKySM+aVc8bcck6rLaM4Pz1/HXk5PpZWldKUwl1rDx7ro2dwhPqaxJeAQsFSmmzw3oRUlcca2/iHXzewu72Hi5dX8oVrVpx0yfS61bU8/Nohnt7ZweWh1B7kmgnS8w6VYtojA2MlhmjpIdzljHwWgaVVpVywtJIz5pZzxrxyTqspo6Qgsy59fdDPCylcl5yIRZMmUxfw8+OXDjA6qik/8DKZmsIR/v5X23hqRwdLKkv47s1ruTxUfUpVhJfUVVJWmMvDmw9ZwkiCzLprJUFH9wBbD3byerOTILYe7BybFkMEllSWcN6SCk6fW86qebM4rbaM0gxLDhMJBcv4xeZDdPYOUV6cWgs9wZsj0aPrViRSKOCnd3CEg8f6mF+RetPSJ9vh7gG+vmE797+4H39hHl+69jRuOn/hjFQhFeTmcPXpQX69NUz/0EhajF1KZ5l/JzsFR3oGnaTQfMz92smhmDmTllSWcM7iCqfkMLeclXPLsyI5TCQ6tqEx3MW5S1KvAbIxHGFBRXFSSnbR1feawpGsThgDwyN8/5m9fOuxnfQNjfDh8xfxZ+uWz+jCVeD0lvrJpmZ+39jGO8+omdFzm+PF9d8jIqer6uuJDsZLR6PJwU0MWw92cvBY39j2xZUlrF1UMVattLK2DH9h6n2S9kp9zDxKqZkwuhI6/iLW8mq3p1RrhHWnBZLynqlEVfntG2H+8deN7D/Sy9vrq/n8u1awrHrmJ3wEOH/JHCpL83l4yyFLGAkW78et292usd8H/nv8nFDpbHB4lHVff4L9MTNfLppTzFkLZ/ORCxZy+txyTp9bTpklhykFywopK8xNyZ5S/UMj7Ono4ZpVtUl5P39hHnNnFWVlT6nXD3by1V9u44U9R6gLlPLDj53DJXWJ7V6cm+PjXWfU8OOXDhDpH7IPcgkUV8JQ1YtEZDnOjLKbRORF4HuquiGh0SVBfq6PK1ZUEywrHKtWKi+yP7jpEhHqa8pobEm9nlI7WrsZ1cSO8B4v3RaWOlVtXf3862+beOCVZmYX5/P37zmd68+eT26Surpet7qWHz63j40Nrbx3TWK7TmezuCt0VXWHiHwR2AT8B7DGHaX9eVV9MFEBJsOX168AQXkWAAAgAElEQVT0OoSMUB/08+ArB1HVhA6Om65kTAkyXl3Az9M7OhgaGc3o8QH9QyPc9dRuvv34LoZGRvnExUv4k8uXJf1D11kLZlNbXshDmw9ZwkigeNswVgEfxZlNdgOwXlVfEZFa4DkgrROGmRmhoJ/ugWGaj6ZW76DGcITCPB8L5yRvBH0oWMrgyCj7DvewrDp5iSpZVJWHt7TwtUcaOXisj3esDPC5d67wbJYCn09Yv7qWu5/ew9GewbSaiy2dxPvR51vAKziLHf2Jqr4CoKqHgC8mKjiTXsamCEmxqpimcIS6gJ+cJI6JGJtTKpx5A/g2HzjG+29/jk/d/yrlRXnc/4nz+K+b1no+pc361bUMjyqPvB72NI5MFm/CeFBV71HVsW5DIvJpAFW9JyGRmbQztuJcio34bgx3JWX8RaylVaX4JLMmIVRVPvfgFt7zn8+w73Av//K+VTz8yYtSZh6nlbVlLKks4eHXbMrzRIk3YXx4gtdunsE4TAYoLchlfkURDSlUwmiPDNDRPZiUKUFiFeblsGhOSUatvrf1YCf3v3iAG85ZwON/fRkfOHt+UkttJyIiXLu6luf3HKa1Kz3WmE83UyYMEblBRB4GlojIQzGP3+NMQ27McUKB1FpMKRrLiiQ2eEfVBfwZ1bV247ZWfAJ//Y5Qyg5QvW51Darwqy0tXoeSkU70W38WaAEqgX+LeT0CbElUUCZ91Qf9/L6pLWWmaYj2kErGHFLj1QX9/G5b5kxZsaGhjbWLKqhI4QblZdV+VtSU8dBrh/hYmq0rkw6mLGGo6j7gKaBHVZ+IebyiqsPJCdGkk/oaPyOjys621GjsbQxHqPIXMGca02bPlFDAz6iSMtfiVDQf7aWhpYsrV6T+yPXrVtey+cAxDsQMxjUz44RtGKo6AvSKyORLXxnjqo+ZRykVJHNKkPFCQWcqjEyolnq0oQ0gLaY6uXaVMz3Iw1us8Xumxdvo3Q9sFZG7ReQ/oo9EBmbS06I5JeTn+lKid9DwyCg7Wrs9SxgL55SQn5Ma1+JUbdjWytKqEhanwWqQ8yuKOWvBLB7abAljpsWbMH4F/C3wJPByzMOY4+Tm+FheXTq2/oSX9h7uZWB41LNlY/NyfCypSv+eUl39Qzy/+3BalC6i1q+upTEcYUcGJOtUElfCUNUfAD8BnlfVH0QfiQ3NpKtUmUdpbA0Mj0oY0ffenuar7z3R1M7wqKZF+0XUNatq8Ak2JmOGxZUwRGQ9sBn4jfv8TBF5KJGBmfS1IlhGW2SAIz2DnsbRGO4ixycJm1Y7HnUBPweP9RHpH/IshlO1saGVipJ81iyY7XUocav2F3Lekjk8vKUFVfU6nIwRb5XUV4BzgGMAqroZsD5rZkLRT/SNHo/4bmiJsLiyxNMurdER5ulayhgaGeX3jW28vb46pQbpxeO61bXs6ejh9YPeV49mingTxrCqdo57zdK2mVCq9JRqavWuh1RUNHmma0+pl/Yeoat/mCvTqP0i6urTg+TliPWWmkHxJozXReR/ATkislxEvokzqM+Yt6jyF1BRkk9ji3c3ye6BYQ4c6fM8YcydVURxfo7nyfNkbdzWRn6uj4uXV3odyrTNKs7nkuVVPPzaIUZH7fPtTIg3YXwSWAkMAPcDXcCfJSook95EhFDAT6OHn6qjN2ivekhF+XzC8jSdIkRV2dAQ5qJllRTnp+ZUICeyfnUtLZ39vLz/qNehZIR4e0n1quoXgCuAy1X1C6pqs3uZSdXX+Nkejnj2yW5s0aQa79eiCAVK0zJhbG/t5sCRPtalUe+o8a48LUBhns/GZMyQeHtJnS0iW3Hmj9oqIq+JyNsSG5pJZ/VBP31DI8etlZ5MTeEI/oJc5s4q8uT9Y9UF/HR0D9LRPeB1KNOysaEVgCtWVHscyckrKcjlivoAv97awvDIqNfhpL14q6TuBv5YVRep6iLgT4DvJSwqk/ZCHi+m1NgSIRT0p8RSsena8L1hWyur55UTKCv0OpRTsn51LYd7Bnl2l02wfariTRgRVX0q+kRVn8aZsdaYCdUFShHxpmutqtIQ7vJ0wF6ssa61adTw3RbpZ/OBY2ldHRV1WagKf0GuDeKbAfEmjBdF5L9E5DIRuVREvg08LiJnichZiQzQpKfi/FwWVhR70juopbOfSP9w0hdNmkyVv4BZxXk0pdFYjMfcyQavXJn+CaMwL4erVgb5zRthBoZHvA4nrcXb9eFM9+uXx71+Ac54jLfPWEQmY3g1RchYg3eKlDBEJO0WU9rY0Mq82UVJX9o2UdavruFnrzTzRFM7V60Meh1O2oorYajq5YkOxGSe+mAZv9vWSt/gCEX5yRtt3ZgCc0iNFwr4+cWrB1HVlGhXmUrf4AhP7ejghnMWpHys8bpwWSUVJfk89NohSxinIN5eUuUi8nUR2eQ+/s3WxzAnUh/0owo72pL7ybqxJcLcWUWUFeYl9X2nUhf0ExkYpqUz9XujP72zg4Hh0bQc3T2ZvBwf7zw9yKMNbfQO2tpvJyveNozv4jRyf8B9dBFHLykRmSUiD4hIo4g0iMj547bfKCJb3MezIrI6Ztufi8gbIvK6iNwvIundVSMLRdsQkj3iuykcSZnqqKho1U46rI2xYVsYf2Eu5yyu8DqUGXXd6lr6hkbYsK3V61DSVrwJY6mqfllVd7uPvwOWxHHcN4DfqGo9sBpoGLd9D3Cpqq4CvgrcASAic4FPAWtV9XQgB7g+zlhNilhQUUxhni+pXWsHhkfY1d6dEgP2YtUF3NX3Uryn1Mio8mhDG5eFqsnLiff2kB7OXlRBsKyQh19r8TqUtBXvX0SfiFwUfSIiFwJ9Ux0gImXAJThjOFDVQVU9FruPqj6rqtEx+88D82I25wJFIpILFAPWJy7N5Picxt6m1uR1rd3V1sPwqI6NA0kVs4rzCZQVpHwJY/OBYxzuGWRdGg/Wm4zPJ1y7qoYntrfR2Zu+0817Kd6EcRvwnyKyV0T2At8C/ugExywB2oHvicirInKXiEy1vuPHgUcAVPUg8H+B/UAL0Kmqv5voIBG5Ndq20t7eHuePY5KlPuhPapVUNDmtSLEqKXBGfO9I8a61GxtayfUJl4UyL2GAM4hvaET57Rthr0NJSydMGCLiA0KquhpYBaxS1TWquuUEh+YCZwHfUdU1QA/wN5O8x+U4CeOz7vPZwLtx1tyoBUpE5EMTHauqd6jqWlVdW1VVdaIfxyRZKFjG4Z5B2iPJmRajsSVCfo4vJdeeDgX87GiLMJLCM6du3NbKuUsqKC9KnQ4DM2nVvHIWzinmIRvEd1JOmDBUdRT4U/f7LlWNt36hGWhW1Rfc5w/gJJDjiMgq4C7g3aoaHbu/Dtijqu2qOgQ8iDPmw6SZZK+N0RiOsKy6lNwUrH+vC/rpHxrlgEfza53I3o4edrR1Z8To7smICOtX1fLsro6kfYjJJPH+V20Qkb8SkfkiUhF9THWAqoaBAyIScl+6AtgWu4+ILMBJBjep6vaYTfuB80SkWJyO4Ffw1gZzkwbqk7z6XmO4K+UavKNSvadUdLLBTE4Y4FRLjSr8eqs1fk9XvAnjY8AfA08Am2IeJ/JJ4D4R2YIzWvwfReQ2EbnN3f4lYA7wbRHZLCKbANxSyQPAK8BWN8474ozVpJA5pQVUlhYkpafU0Z5BWrsGUq5LbdTyFO8ptWFbK/VBP/Mrir0OJaFCQT+hgN/mljoJ8U4NchpOwrgIZyqQp4DbT3SQu/b32nEv3x6z/RbglkmO/TJvnYrEpKEVNf6klDAaU2TRpMkU5+eyoKI4JUsYR3sG2bTvKP/70qVeh5IU61fX8H9/t52Dx/pSYgr8dBFvCeMHwArgP4Bvut//IFFBmcwScnsHJbqxN9XmkJpIqs4p9fj2NkZGlXUZNLp7KutX1wLwSytlTEu8CSOkqreo6u/dx61A6IRHGYNTBTAwPMrewz0JfZ+mcISKknyq/AUJfZ9TEQqWsru9h8Hh1FrMZ+O2Nqr8Bayamx0z/iycU8LqeeU8vMUSxnTEmzBeFZHzok9E5FzgmcSEZDLNiiRNEdLgTgmSyhPm1QX8DI8qezoSmzynY2B4hCe2t7NuRTU+X+peu5m2fnUtrx/sYnd7ao+NSSXxJoxzgWdjBu49B1wqIlvdBm1jJrWsuhSfQFMC2zFGR5Xt4UhKzVA7kWh8qdSO8cLuI3QPDGfUZIPxuHZVLSLYVCHTEG+j99UJjcJktMK8HBZXltCQwN5B+4/00jc0wooUbfCOWlJZSq5PnJ5Sq0+8fzJsbGilKC+HC5ZWeh1KUgXLCzlnUQUPvXaQT12xLKVLpqkirhKGqu6b6pHoIE36qw+WJXTwXiqugTGR/FxnFHqqlDBUlY3bWrl4eSWFeclbsyRVrF9dy672HhqSPKNyukq94bAmI4WCfvYf6aVnIDFrETSGuxBx2ghSXV0wdXpKvXGoi0Od/VnTO2q8d51RQ45PbKqQOFnCMElRn+C6+8aWCIvnlCR1Zb+TFQo4yTMVFvLZ2NCKCLy9PjMnGzyRipJ8LlpWycOvHUI1def4ShWWMExSRAfTJapaqqk19Ru8o+oCpajCzjbve+dsbGjlrAWzqSxN3a7IiXbd6loOHuvjlf3HTrxzlrOEYZJi3uwiivNzEpIwegeH2Xu4J2VHeI8XrTZL1oSMk2np7OP1g10ZP3fUiVy1MkB+rs+mComDJQyTFD6fEAr6aWiZ+a61O1q7UU39Bu+ohXNKyM/1ed6OsbGhDSDrutOO5y/M4+2han61tSWlp55PBZYwTNLUB/00tUZmvK44OiXIihSdpXa8HJ+wvLqUJo8XU9q4rZXFlSUsrUq9tUOSbf3qWtojA7yw+/CJd85iljBM0tQHyzjWO0Rr18yuQ9DQEqE4P4f5s9NnltVQwO/prLXdA8M8t+sw61ZU2/gDnEb/kvwc6y11ApYwTNKEErQ2RlM4Ql3An1bTWtQF/YS7+j1bW/qp7e0MjoxmfftFVFF+DleeFuCR18MpN89XKrGEYZImEavvqSqN4a60qY6Kii6mtL3Nm1LGhm2tzCrO420LZ3vy/qnoujNr6ewb4qkd7V6HkrIsYZikmVWcT7CscEYXU2qPDHC0d2jsBpwu6pK8dG2s4ZFRHmtq4+2h6pRcytYrFy2rorwoz3pLTcH+WkxShYL+GU0Y0fmp6mvSo0ttVG15IaUFuZ70lHp531GO9Q5l7ejuyeTn+njXGUF+t62VvsERr8NJSZYwTFLVB/3sbIswNDIz9cRNabBo0kREhLpAqScljI0NreTn+Likrirp753q1q+qpXdwhMca27wOJSVZwjBJVV/jZ2hk5taDaGyJECwrZFZx/oycL5lC7pxSyZySQlXZsK2V85fOobQg3smqs8e5S+ZQ5S/godcOeh1KSrKEYZIqFHAXU5qhT9YNabAGxmTqAn6O9g7R3j2z3Yynsqu9h72He606ahI5PuGaM2r4fVM7Xf3e9GBLZZYwTFItrS4h1yc0zsCI76GRUXa1dVOfZj2kosZ6SoWTN4BvY0MrAOtWZOdkg/G47sxaBodH+d0brV6HknIsYZikKsjNYUlVyYzU3e/p6GFwZDTlF02aTJ0Hq+9t2NbK6XPLqCkvStp7pps182cxb3aR9ZaagCUMk3ShYNmMVEmly6JJk6ksLWBOSX7SRnx3dA/wyv6jNljvBESE9atreXpnB4eTWF2YDixhmKSrD/o5eKzvlOuIG1u6yPUJS6tKZyiy5KsL+JNWwnissQ1VLGHEYf2qWkZGlUdeD3sdSkqxhGGSLtoF9lQ/WTeFIyytKiU/N33/jENBPztaI4wmYZbUjdtaqSkvZGVtelbhJdOKGj/Lqkttbqlx0vc/zaSt6CC7hlNMGI3hSNo2eEfVBfz0DI5w8FhfQt+nf2iEp3Z0sG5FwCYbjIOIsH5VLS/tPUJLZ2J/N+nEEoZJutryQvyFuWOD7k5GZ98QB4/1pc2iSZMJBZ3qtESP+H52Vwd9QyNZv/bFdKxfXYMq/GpLi9ehpAxLGCbpRIRQwH9KPaWiN9h0G+E93vJAcnpKbdjWRmlBLucuqUjo+2SSJVWlnD63zHpLxbCEYTxRX+PMKXWyo5yj4zjSvUqqrDCP2vLChPaUGh1VHm1o5dK6KgpycxL2PpnoutW1vNbcyb7DMzMzQbqzhGE8EQqWEekf5lBn/0kd3xiOUFaYS7CscIYjS766oD+hq+9tOdhJW2SAdafZYL3pumZVLYCVMlyWMIwn3lwb4+TaMZwG77KMaMANBfzsautmeIYmZBxv47ZWcnzC5SFLGNM1d1YRZy+azcOvWTsGWMIwHokOtmtomX5VjKrSFI6kfftFVF3Az+DIKHsP9ybk/BsbWlm7cHZaTtCYCtavrqWpNeLJzMKpJqEJQ0RmicgDItIoIg0icv647TeKyBb38ayIrI73WJPeygrzmDur6KT+CZuP9tE9MJz2PaSioskzET2lDhzppTEcsd5Rp+BdZ9TgE6uWgsSXML4B/EZV64HVQMO47XuAS1V1FfBV4I5pHGvSXH3Qf1LrezeOLZqUGSWMZdWliCRm9b3oZIOWME5eZWkBFy6r5KHXDiV1KvpUlLCEISJlwCXA3QCqOqiqx2L3UdVnVfWo+/R5YF68x5r0Fwr62d3ew+Dw9Oruo+0edWm2LOtkCvNyWDSnJCEljI0NrSyvLmXhnJIZP3c2Wb+6lv1HetnS3Ol1KJ5KZAljCdAOfE9EXhWRu0Rkqr/ajwOPTPdYEblVRDaJyKb2dlu8PZ2Egn6GR5Vd7dPrIdQQjrCgojijFgCqC5TO+FiMzr4hXth9xNa+mAHvWBkkP8eX9VOFJDJh5AJnAd9R1TVAD/A3E+0oIpfjJIzPTvdYVb1DVdeq6tqqKltyMp2sqIkupjS9aqmmNF40aTKhgJ+9HT30D83cWtJPbG9neFRtssEZUF6Ux6WhKn655VBS5v1KVYlMGM1As6q+4D5/ACcJHEdEVgF3Ae9W1cPTOdakt8WVJeTlyLSmOu8fGmFPRw8rMixh1AX9jCrTLm1NZcO2VipL8zlz/qwZO2c2W7+6ltauAV7ce8TrUDyTsIShqmHggIiE3JeuALbF7iMiC4AHgZtUdft0jjXpLy/Hx9KqUhqn0bV2Z1s3I6NKKEN6SEWNrb43Q9VSg8OjPN7Uxtvrq8nxpf9YlVSwbkU1RXk5Wd1bKtG9pD4J3CciW4AzgX8UkdtE5DZ3+5eAOcC3RWSziGya6tgEx2o8sKKmbFq9gzKth1TUIre01TRDy7W+tPcIkf5hq46aQcX5uaw7LcCvt7YwlKBBlqkuoa2GqroZWDvu5dtjtt8C3DKNY02GCQX9/PzVgxzrHYxrYFljSxcFuT4WZVivn2hpa6ZKGBu2tVKQ6+Oi5ZUzcj7jWL+qhodfO8QzOzu4LAtHzttIb+Op6GjteNsxmloj1AX8GVnNUneKM/hGqSobG1q5eHklxfmZ05MsFVwaqsJfmJu1vaUsYRhPRUdrx3ujbGjJnClBxgu5S9d2Dwyf0nmaWiM0H+2z6qgEKMjN4eqVQX73RuuM9mhLF5YwjKcCZQWUF+XFVcLo6B6go3sg47rURkUHIu44xWqpjduc0d1vX5F9VSbJcN2ZtXQPDPN4U5vXoSSdJQzjKRGJe4qQaCkkOn4j08xUT6kN21o5c/4sqv3pP/V7Kjp/yRwqS/OzcgZbSxjGc/VBP9vDkRMOiBrrIZWhJYx5s4soyss5pZ5SrV39vNbcaXNHJVBujo93nVHDxobWU64+TDeWMIzn6mvK6Bkcoflo35T7NbZ0UVlawJzSgiRFllw+n7A8cGo9pR5tcKpJrP0isdavrmVgeHSs+i9bWMIwnguN9ZSaulqqMRxhRYaNvxivLuA/pTmlNja0Mr+iiLpA6QxGZcZ724LZ1JYXZl1vKUsYxnPRxt6pekqNjCrbWyNj9fyZKhTw0x4Z4EjP4LSP7R0c5umdHaxbEciIlQhTmc8nXLu6lie2t/PZB7bw6v6jWTH1uXXSNp4rLchlQUXxlD2l9h7uYWB4lPoMbfCOqotZTOm8JXOmdexTOzoYHB619osk+ePLltLZO8RDrx3ix5sOUB/0c8M5C3jPmrmUF+V5HV5CWAnDpITQCXpKNWV4g3fUqfSU2ritlbLCXM5eVDHTYZkJzCrO52vvX8WLX7iCf3jv6eTl+PjyQ29wzj9s5C9+spmX9h7JuFKHlTBMSqgP+nm0wRkMVZiX85btjS1d+MRZnS6TBcoKKCvMnfaI75FR5bHGNi6vryYvxz4HJpO/MI8bz13Ijecu5PWDndz/4n7+Z/MhHnzlIMuqS7n+7Pm876x5zC5J/zXV7S/LpIT6YBmj6sxGO5HGcIQlVaUTJpNMIiKEgv5plzBe3X+Uwz2D1jvKY6fPLecf3nsGL37hCv7lfavwF+by979q4Nx/fJRP3v8qz+7qSOtSh5UwTEoIxcwpdfrc8rdsbwxHOGPeW1/PRHUBPw+760fH23i9oaGVXJ9wacgWEUsFxfm5fODs+Xzg7Pk0hrv40YsHePCVZh5+7RCL5hRz/TkLeN9Z86jyp1cXcSthmJSwaE4xBbk+Glve2o7RPTDM/iO9Gbdo0mRCQT9d/cO0dg3EfczGba2ct2QOZYWZ2diazuqDZXzlupW8+IV1/PsHV1PtL+SfH2nk/H96lP9978s8ub09bVbxsxKGSQm5OT6WT7KudbR6JtMWTZrMWDfj1gjB8hNP77G7vZtd7T3cdN7CRIdmTkFhXg7vXTOP966Zx862bn780n4eeLmZR14PM292ER9c65RIAmWpO6WLlTBMyggFyibsWhtdkS/Te0hFRRPG9jgbvsdGd1t32rSxrLqUL1xzGs9//gq+ecMaFlQU828btnPBPz/GLT/YxKMNrYykYKnDShgmZayo8fOzV5o53D1w3PQfTeEuSgtymTe7yMPokqeiJJ8qf0HcI743NLSyoqaMebOLExyZmWkFuTmsX13L+tW17O3o4cebDvDTTc1sbGilpryQP1w7nw+ePZ+5s1Ljb99KGCZlRBu+x3cpbQhHCAX9WTV6ORSIr6fU0Z5BNu09wpU2lXnaW1RZwmevrue5z72d2z90FnUBP998bAcXfe0xbv7ei/zm9bDnS8NaCcOkjGjCaAhHuGCZs7SoqtIUjnDtqhovQ0u6uoCf/35xH6Ojim+K1QV/39TGqFp1VCbJy/Fx9ek1XH16DQeO9PLTTQf4yaZmbrv3Zar8Bfzh2+Zx/dkLWDAn+SVKSxgmZVSVFjCnJJ+mmBHf4a5+OvuGsqb9IioULKV/aJQDR3tZOMX65Ru2tRIoK+D02uzocpxt5lcU8xdXhfjUFct5vKmdH720n9uf2MW3H9/FRcsquf6c+Vx1WpD83ORUFlnCMCkjOmgttkpqrME7w+eQGi92QsbJEkb/0AhPbG/nPWvmTlkKMekvN8fHutMCrDstQEtnHz/d1MyPXzrAn/73q1SU5PO+s+byV+8IUZCb2IGt1oZhUkp9sIym1shYD5For6m6DJ+ldrzlccwp9fzuw/QOjnClje7OKjXlRXzqiuU8+ZnL+cHHzuGcRRU8v/sI+UmYEsZKGCal1Af99A+Nsv9IL4srS2gMdzF3VlHGzv45mWivsKbWyVff29jQSnF+Ducvnd6stiYz5PiES+uquLSuiuGR0aR0CrEShkkpb/aU6nK/RrKu/SIqFPBPOhZDVdm4rY1Llldl/Pxa5sRykzThpCUMk1LqAn5EoKElwuDwKDvbuseSSLapC/rZ1d7N4PBbu1K+caiLcFe/9Y4ySWUJw6SUovwcFs0poSkcYXdHN8OjmnUN3lGhgJ/hUWXv4Z63bNuwrRWfwOU22aBJIksYJuWEAs5iStk2Jch4Uy1du2FbK29bOPu4EfHGJJolDJNy6mv87DvSy6v7j5Kf42Nx5eTjEDLZkqoScnzylp5SB4/1sa2ly9a+MElnCcOknPqgH1X41dYwS6tLs3YFucK8HBbNKX5LCePRhlbARneb5MvO/0ST0urdacw7ugeyZg2MyUy0+t6Gba0sqSxhaVVmL1drUo8lDJNyFlQUU+R2Fa2vye6EURdwquf6BkcAiPQP8fzuw1xppQvjgYQmDBGZJSIPiEijiDSIyPnjtt8oIlvcx7Misnrc9hwReVVEfpnIOE1q8fmEuoDz6TlbFk2aTCjgVM9F1zp/cnsHQyNq1VHGE4kuYXwD+I2q1gOrgYZx2/cAl6rqKuCrwB3jtn96gmNMFohWS2V7lVRd8M3V98AZ3T27OI+zFsz2MiyTpRI2NYiIlAGXADcDqOogMBi7j6o+G/P0eWBezPHzgGuAfwD+IlFxmtT0/rXzKMrPocqf3d1GF1YUk5/rY3trhOGRUR5rbGPdigA5Ntmg8UAi55JaArQD33Orml4GPq2qbx2F5Pg48EjM8/8HfAaY8iOmiNwK3AqwYMGCU43ZpIizF1Vw9qIKr8PwXG6Oj2VVpTSFI7y09yidfUNceZotlmS8kcgqqVzgLOA7qroG6AH+ZqIdReRynITxWff5tUCbqr58ojdR1TtUda2qrq2qslGvJvNEe0ptbGglP8fHxcvt79x4I5EJoxloVtUX3OcP4CSQ44jIKuAu4N2qeth9+ULgOhHZC/wIeLuI3JvAWI1JWXUBPy2d/fxyyyEuWDaHkgKbZNp4I2EJQ1XDwAERCbkvXQFsi91HRBYADwI3qer2mGM/p6rzVHURcD3wmKp+KFGxGpPKQkGnx1hr14CN7jaeSvRHlU8C94lIPrAb+KiI3AagqrcDXwLmAN9253IfVtW1CY7JmLQSu3iUJQzjpYQmDFXdDIxPALfHbL8FuOUE53gceHymYzMmXcydVURJfg5Lq0sJlhd6HY7JYlYZakyKExG+cM1pzK8o8joUk+UsYRiTBv7XudZl3HjP5pIyxneZGPMAAAQ6SURBVBgTF0sYxhhj4mIJwxhjTFwsYRhjjImLJQxjjDFxsYRhjDEmLpYwjDHGxMUShjHGmLiIqnodw4wRkXZg30keXgl0zGA46cyuxfHsehzPrsebMuFaLFTVuObMz6iEcSpEZJNNfOiwa3E8ux7Hs+vxpmy7FlYlZYwxJi6WMIwxxsTFEsab7vA6gBRi1+J4dj2OZ9fjTVl1LawNwxhjTFyshGGMMSYuljCMMcbEJesThohcLSJNIrJTRP7G63i8JCLzReT3ItIgIm+IyKe9jslrIpIjIq+KyC+9jsVrIjJLRB4QkUb3b+R8r2Pykoj8uft/8rqI3C8iGb9+blYnDBHJAf4TeCdwGnCDiJzmbVSeGgb+UlVXAOcBf5Ll1wPg00CD10GkiG8Av1HVemA1WXxdRGQu8ClgraqeDuQA13sbVeJldcIAzgF2qupuVR0EfgS82+OYPKOqLar6ivt9BOeGMNfbqLwjIvOAa4C7vI7FayJSBlwC3A2gqoOqeszbqDyXCxSJSC5QDBzyOJ6Ey/aEMRc4EPO8mSy+QcYSkUXAGuAFbyPx1P8DPgOMeh1IClgCtAPfc6vo7hKREq+D8oqqHgT+L7AfaAE6VfV33kaVeNmeMGSC17K+n7GIlAI/A/5MVbu8jscLInIt0KaqL3sdS4rIBc4CvqOqa4AeIGvb/ERkNk5txGKgFigRkQ95G1XiZXvCaAbmxzyfRxYUK6ciInk4yeI+VX3Q63g8dCFwnYjsxamqfLuI3OttSJ5qBppVNVrifAAngWSrdcAeVW1X1SHgQeACj2NKuGxPGC8By0VksYjk4zRaPeRxTJ4REcGpo25Q1a97HY+XVPVzqjpPVRfh/F08pqoZ/wlyMqoaBg6ISMh96Qpgm4cheW0/cJ6IFLv/N1eQBZ0Acr0OwEuqOiwifwr8FqeXw3dV9Q2Pw/LShcBNwFYR2ey+9nlV/bWHMZnU8UngPvfD1W7gox7H4xlVfUFEHgBeweld+CpZME2ITQ1ijDEmLtleJWWMMSZOljCMMcbExRKGMcaYuFjCMMYYExdLGMYYY+JiCcOYGSAin3JncL1vku03i8i3JtnWndjojJkZWT0Ow5gZ9MfAO1V1j9eBGJMoljCMOUUicjvO5HwPicj3gYvd573Araq6Zdz+i4H/xvn/+01yozXm5FmVlDGnSFVvw5mD7HJgEfCqqq4CPg/8cIJDvoEzid/ZQDhZcRpzqixhGDOzLgLuAVDVx4A5IlI+bp8Lgfvd7+9JYmzGnBJLGMbMrHinzLc5eUzasYRhzMx6ErgRQEQuAzomWFPkGd5czvPG5IVmzKmxhGHMzPoKsFZEtgD/DHxkgn0+jbNe+kvA+OoqY1KWzVZrjDEmLlbCMMYYExdLGMYYY+JiCcMYY0xcLGEYY4yJiyUMY4wxcbGEYYwxJi6WMIwxxsTl/wOzsHiVKt+1vwAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "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": [
    "nuisance_diagnostic(dmlate, 'model_T_X', 'predict', lambda ns: ns.predict(X))\n",
    "nuisance_diagnostic(dmlate, 'model_Y_X', 'predict', lambda ns: ns.predict(X))\n",
    "nuisance_diagnostic(dmlate, 'model_Z_X', 'predict', lambda ns: ns.predict(X))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 499,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "No handles with labels found to put in legend.\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"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "No handles with labels found to put in legend.\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"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "No handles with labels found to put in legend.\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": [
    "results = dmlate.fitted_nuisances['model_T_X'][0].evals_result()\n",
    "epochs = len(results['validation_0']['rmse'])\n",
    "x_axis = range(0, epochs)\n",
    "# plot log loss\n",
    "fig, ax = plt.subplots()\n",
    "ax.plot(x_axis, results['validation_0']['rmse'])\n",
    "ax.legend()\n",
    "plt.ylabel('RMSE Loss')\n",
    "plt.title('T_X RMSE Loss')\n",
    "plt.show()\n",
    "results = dmlate.fitted_nuisances['model_Y_X'][0].evals_result()\n",
    "epochs = len(results['validation_0']['rmse'])\n",
    "x_axis = range(0, epochs)\n",
    "# plot log loss\n",
    "fig, ax = plt.subplots()\n",
    "ax.plot(x_axis, results['validation_0']['rmse'])\n",
    "ax.legend()\n",
    "plt.ylabel('Log Loss')\n",
    "plt.title('XGBoost Log Loss')\n",
    "plt.show()\n",
    "results = dmlate.fitted_nuisances['model_Z_X'][0].evals_result()\n",
    "epochs = len(results['validation_0']['logloss'])\n",
    "x_axis = range(0, epochs)\n",
    "# plot log loss\n",
    "fig, ax = plt.subplots()\n",
    "ax.plot(x_axis, results['validation_0']['logloss'])\n",
    "ax.legend()\n",
    "plt.ylabel('Log Loss')\n",
    "plt.title('XGBoost Log Loss')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# ATE and CATE via DMLIV"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [],
   "source": [
    "from dml_iv import DMLIV\n",
    "from utilities import SelectiveLasso\n",
    "from sklearn.linear_model import LassoCV, LogisticRegressionCV\n",
    "from econml.utilities import hstack\n",
    "\n",
    "np.random.seed(random_seed)\n",
    "\n",
    "# For DMLIV we also need a model for E[T | X, Z]. We use a classifier since T is binary\n",
    "# Because Z is also binary, we could have also done a more complex model_T_XZ, where we split\n",
    "# the data based on Z=1 and Z=0 and fit a separate sub-model for each case.\n",
    "\"\"\"\n",
    "model_T_XZ = lambda: model_clf()\n",
    "\"\"\"\n",
    "\n",
    "# To allow for heterogeneity in the compliance, i.e. to allow for a model of the form:\n",
    "# Pr[T=1|X] = beta(X) * Z + gamma(X)\n",
    "# we need to either create cross features between X and Z and run a linear model.\n",
    "# The method below will learn a linear beta(X)=<beta_1, X> + beta_0 and\n",
    "# gamma(X)=<gamma_1, X> + gamma_0.\n",
    "\"\"\"\n",
    "class Featurizer:\n",
    "    def __init__(self):\n",
    "        return\n",
    "    def fit(self, XZ, y=None):\n",
    "        return self\n",
    "    def transform(self, XZ):\n",
    "        # Z is the last feature in XZ, when the model is called by the dmliv class\n",
    "        return hstack([XZ[:, [-1]] * XZ[:, :-1], XZ]) # Create features (Z*X, X, Z)\n",
    "    def fit_transform(self, XZ, y=None):\n",
    "        return self.transform(XZ)\n",
    "\n",
    "model_T_XZ = lambda: Pipeline([('poly', Featurizer()), ('clf', model_clf())])\n",
    "\"\"\"\n",
    "\n",
    "# Or we need to train a separate model for Z=1 and Z=0. The model for Z=1 learns the\n",
    "# quantity beta(X) + gamma(X) and the model for Z=0 learns gamma(X). This below can\n",
    "# allow for non-linear beta(X) and gamma(X), e.g. random forests\n",
    "class SeparateModel:\n",
    "    def __init__(self, model0, model1):\n",
    "        self.model0 = model0\n",
    "        self.model1 = model1\n",
    "        return\n",
    "    def fit(self, XZ, T):\n",
    "        Z0 = (XZ[:, -1] == 0)\n",
    "        Z1 = (XZ[:, -1] == 1)\n",
    "        self.model0.fit(XZ[Z0, :-1], T[Z0])\n",
    "        self.model1.fit(XZ[Z1, :-1], T[Z1])\n",
    "        return self\n",
    "    def predict(self, XZ):\n",
    "        Z0 = (XZ[:, -1] == 0)\n",
    "        Z1 = (XZ[:, -1] == 1)\n",
    "        t_pred = np.zeros(XZ.shape[0])\n",
    "        if np.sum(Z0) > 0:\n",
    "            t_pred[Z0] = self.model0.predict(XZ[Z0, :-1])\n",
    "        if np.sum(Z1) > 0:\n",
    "            t_pred[Z1] = self.model1.predict(XZ[Z1, :-1])\n",
    "        return t_pred\n",
    "    @property\n",
    "    def coef_(self):\n",
    "        return np.concatenate((self.model0.coef_, self.model1.coef_))\n",
    "\n",
    "model_T_XZ = lambda: SeparateModel(model(), model())\n",
    "\n",
    "# We now specify the features to be used for heterogeneity. We will fit a CATE model of the form\n",
    "#      theta(X) = <theta, phi(X)>\n",
    "# for some set of features phi(X). The featurizer needs to support fit_transform, that takes\n",
    "# X and returns phi(X). We need to include a bias if we also want a constant term.\n",
    "dmliv_featurizer = lambda: PolynomialFeatures(degree=1, include_bias=True)\n",
    "\n",
    "# Then we need to specify a model to be used for fitting the parameters theta in the linear form.\n",
    "# This model will minimize the square loss:\n",
    "#        (Y - E[Y|X] - <theta, phi(X)> * (E[T|X,Z] - E[T|X]))**2\n",
    "# potentially with some regularization on theta. Here we use an ell_1 penalty on theta\n",
    "#dmliv_model_effect = lambda: Lasso(alpha=0.001)\n",
    "\n",
    "# We could also use LassoCV to select the regularization weight in the final stage with\n",
    "# cross validation.\n",
    "#dmliv_model_effect = lambda: LassoCV(fit_intercept=False, cv=3)\n",
    "\n",
    "# If we also have a prior that there is no effect heterogeneity we can use a selective lasso\n",
    "# that does not penalize the constant term in the CATE model\n",
    "#dmliv_model_effect = lambda: SelectiveLasso(np.arange(1, X.shape[1]+1), \n",
    "#                                           LassoCV(cv=5))\n",
    "dmliv_model_effect = lambda: LinearRegression(fit_intercept=False)\n",
    "\n",
    "# We initialize DMLIV with all these models and call fit\n",
    "cate = DMLIV(model_Y_X(), model_T_X(), model_T_XZ(), \n",
    "             dmliv_model_effect(), dmliv_featurizer(),\n",
    "             n_splits=N_SPLITS, # number of splits to use for cross-fitting\n",
    "             binary_instrument=True, # a flag whether to stratify cross-fitting by instrument\n",
    "             binary_treatment=True # a flag whether to stratify cross-fitting by treatment\n",
    "            )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\moprescu\\AppData\\Local\\Continuum\\anaconda3\\lib\\site-packages\\sklearn\\model_selection\\_split.py:652: Warning: The least populated class in y has only 8 members, which is too few. The minimum number of members in any class cannot be less than n_splits=10.\n",
      "  % (min_groups, self.n_splits)), Warning)\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<dml_iv.DMLIV at 0x19a641bb978>"
      ]
     },
     "execution_count": 19,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "cate.fit(y, T, X, Z)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAXoAAAD8CAYAAAB5Pm/hAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADl0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uIDIuMi4zLCBodHRwOi8vbWF0cGxvdGxpYi5vcmcvIxREBQAAFBBJREFUeJzt3X+MXeWd3/H3J2BikoUYzMAS26qpYm2XosZhJ4Q20m4aJyiQChMBhShdDHHkRqHZ3VKpcX9IURukkDYKCUqCaoUtZrPdQNyNsBJKSw2oagQ0A3EIxEvtUMATUzyLwZst9RLqb/+YZ5SJPXjOeO7M2If3S7o65zznufd+7wE+c3juuedJVSFJ6q83LXQBkqS5ZdBLUs8Z9JLUcwa9JPWcQS9JPWfQS1LPGfSS1HMGvST1nEEvST134kIXAHDGGWfUypUrF7oMSTquPProo39eVUPT9Tsmgn7lypWMjIwsdBmSdFxJ8myXfg7dSFLPGfSS1HMGvST13DExRi9Jc+EXv/gFo6OjHDhwYKFLmZXFixezfPlyFi1adFTPN+gl9dbo6CinnHIKK1euJMlCl3NUqooXX3yR0dFRzjnnnKN6DYduJPXWgQMHWLp06XEb8gBJWLp06az+r8Sgl9Rrx3PIT5jtZzDoJannHKOX9IaxcuP3Bvp6z9z04YG91u23385FF13E29/+9oG95gSDXseFQf8H2tUg/0OWjuT222/nvPPOM+gl6XjzzW9+k1tuuYVXX32V97znPXz9619n/fr1jIyMkISPf/zjrFixgpGRET72sY9x8skn89BDD3HyyScPrAaDXpLmyI4dO7jzzjv5/ve/z6JFi/jUpz7FjTfeyM9+9jOeeOIJAF5++WWWLFnCV7/6Vb74xS8yPDw88Dr8MlaS5si2bdt49NFHefe7383q1avZtm0b+/bt4+mnn+bTn/409957L6eeeuqc12HQS9IcqSrWrVvH9u3b2b59O0899RRf+cpX+NGPfsT73vc+vva1r/GJT3xizusw6CVpjqxZs4YtW7awd+9eAPbt28ezzz7LwYMHufzyy/nc5z7HY489BsApp5zCz3/+8zmpwzF6SW8Y830V1bnnnsuNN97IRRddxMGDB1m0aBFf+tKX+MhHPsLBgwcB+PznPw/Atddeyyc/+cmF+zI2yT8GPgEU8GPgOuBs4FvA6cBjwO9W1atJ3gzcAfwW8CJwVVU9M7CKJek4ctVVV3HVVVf9StvEWfxkl19+OZdffvmc1DDt0E2SZcDvAcNVdR5wAnA18AXg5qpaBbwErG9PWQ+8VFXvAG5u/SRJC6TrGP2JwMlJTgTeAjwPvB/Y0vZvBi5r62vbNm3/mvThZhOSdJyaNuir6mfAF4HnGA/4/cCjwMtV9VrrNgosa+vLgN3tua+1/ksHW7YkdVNVC13CrM32M3QZujmN8bP0c4C3A28FLp6qlomnHGHf5NfdkGQkycjY2Fj3iiWpo8WLF/Piiy8e12E/cT/6xYsXH/VrdPky9gPA/6qqMYAkfwr8HWBJkhPbWftyYE/rPwqsAEbbUM/bgH1TFL8J2AQwPDx8/P5TkHTMWr58OaOjoxzvJ5MTM0wdrS5B/xxwYZK3AP8XWAOMAA8AVzB+5c064O7Wf2vbfqjtv7+O5z+nko5bixYtOupZmfqkyxj9I4x/qfoY45dWvonxM/HPADck2cX4GPxt7Sm3AUtb+w3AxjmoW5LUUafr6Kvqs8BnD2l+Grhgir4HgCtnX5okaRC8BYIk9ZxBL0k9Z9BLUs8Z9JLUc969UjqChZqrFpyvVoPjGb0k9ZxBL0k9Z9BLUs8Z9JLUcwa9JPWcQS9JPWfQS1LPGfSS1HMGvST1nEEvST1n0EtSz3WZHPw3kmyf9PiLJH+Q5PQk9yXZ2Zantf5JckuSXUkeT3L+3H8MSdLr6TKV4FNVtbqqVgO/BbwCfIfxKQK3VdUqYBu/nDLwYmBVe2wAbp2LwiVJ3cx06GYN8NOqehZYC2xu7ZuBy9r6WuCOGvcwsCTJ2QOpVpI0YzMN+quBP2nrZ1XV8wBteWZrXwbsnvSc0db2K5JsSDKSZGRsbGyGZUiSuuoc9ElOAi4Fvj1d1yna6rCGqk1VNVxVw0NDQ13LkCTN0EzO6C8GHquqF9r2CxNDMm25t7WPAismPW85sGe2hUqSjs5Mgv6j/HLYBmArsK6trwPuntR+Tbv65kJg/8QQjyRp/nWaSjDJW4APAv9wUvNNwF1J1gPPAVe29nuAS4BdjF+hc93AqpUkzVinoK+qV4Clh7S9yPhVOIf2LeD6gVQnSZo1fxkrST1n0EtSzxn0ktRzBr0k9ZxBL0k9Z9BLUs8Z9JLUcwa9JPWcQS9JPWfQS1LPGfSS1HMGvST1nEEvST1n0EtSzxn0ktRznYI+yZIkW5L8WZIdSf52ktOT3JdkZ1ue1vomyS1JdiV5PMn5c/sRJElH0vWM/ivAvVX1N4B3AjuAjcC2qloFbGvbMD637Kr22ADcOtCKJUkzMm3QJzkV+G3gNoCqerWqXgbWAptbt83AZW19LXBHjXsYWDIxibgkaf51OaP/68AY8O+T/DDJN5K8FThrYtLvtjyz9V8G7J70/NHWJklaAF2C/kTgfODWqnoX8H/45TDNVDJFWx3WKdmQZCTJyNjYWKdiJUkz1yXoR4HRqnqkbW9hPPhfmBiSacu9k/qvmPT85cCeQ1+0qjZV1XBVDQ8NDR1t/ZKkaUwb9FX1v4HdSX6jNa0BfgJsBda1tnXA3W19K3BNu/rmQmD/xBCPJGn+ndix36eBP05yEvA0cB3jfyTuSrIeeA64svW9B7gE2AW80vpKkhZIp6Cvqu3A8BS71kzRt4DrZ1mXJGlA/GWsJPWcQS9JPWfQS1LPGfSS1HMGvST1nEEvST1n0EtSzxn0ktRzBr0k9ZxBL0k9Z9BLUs8Z9JLUcwa9JPWcQS9JPWfQS1LPGfSS1HOdgj7JM0l+nGR7kpHWdnqS+5LsbMvTWnuS3JJkV5LHk5w/lx9AknRkMzmj/7tVtbqqJmaa2ghsq6pVwLa2DXAxsKo9NgC3DqpYSdLMzWboZi2wua1vBi6b1H5HjXsYWJLk7Fm8jyRpFroGfQH/JcmjSTa0trOq6nmAtjyztS8Ddk967mhr+xVJNiQZSTIyNjZ2dNVLkqbVaXJw4L1VtSfJmcB9Sf7sCH0zRVsd1lC1CdgEMDw8fNh+SdJgdDqjr6o9bbkX+A5wAfDCxJBMW+5t3UeBFZOevhzYM6iCJUkzM23QJ3lrklMm1oGLgCeArcC61m0dcHdb3wpc066+uRDYPzHEI0maf12Gbs4CvpNkov9/qKp7k/wAuCvJeuA54MrW/x7gEmAX8Apw3cCrliR1Nm3QV9XTwDunaH8RWDNFewHXD6Q6SdKs+ctYSeo5g16Ses6gl6SeM+glqecMeknqOYNeknrOoJeknjPoJannDHpJ6jmDXpJ6zqCXpJ4z6CWp5wx6Seo5g16Seq7rVIISACs3fm+hS5A0Q53P6JOckOSHSb7bts9J8kiSnUnuTHJSa39z297V9q+cm9IlSV3MZOjm94Edk7a/ANxcVauAl4D1rX098FJVvQO4ufWTJC2QTkGfZDnwYeAbbTvA+4Etrctm4LK2vrZt0/avaf0lSQug6xn9l4F/Chxs20uBl6vqtbY9Cixr68uA3QBt//7WX5K0AKYN+iR/D9hbVY9Obp6ia3XYN/l1NyQZSTIyNjbWqVhJ0sx1OaN/L3BpkmeAbzE+ZPNlYEmSiat2lgN72voosAKg7X8bsO/QF62qTVU1XFXDQ0NDs/oQkqTXN23QV9U/q6rlVbUSuBq4v6o+BjwAXNG6rQPubutb2zZt//1VddgZvSRpfszmB1OfAW5IsovxMfjbWvttwNLWfgOwcXYlSpJmY0Y/mKqqB4EH2/rTwAVT9DkAXDmA2qQ3tIX6cdozN314Qd5Xc8dbIEhSzxn0ktRzBr0k9ZxBL0k9Z9BLUs8Z9JLUcwa9JPWcQS9JPWfQS1LPGfSS1HPOGXscct5WSTPhGb0k9ZxBL0k9Z9BLUs8Z9JLUcwa9JPVcl8nBFyf5H0l+lOTJJP+qtZ+T5JEkO5PcmeSk1v7mtr2r7V85tx9BknQkXc7o/wp4f1W9E1gNfCjJhcAXgJurahXwErC+9V8PvFRV7wBubv0kSQuky+TgVVV/2TYXtUcB7we2tPbNwGVtfW3bpu1fkyQDq1iSNCOdxuiTnJBkO7AXuA/4KfByVb3WuowCy9r6MmA3QNu/n/HJww99zQ1JRpKMjI2Nze5TSJJeV6egr6r/V1WrgeWMTwj+m1N1a8upzt7rsIaqTVU1XFXDQ0NDXeuVJM3QjK66qaqXgQeBC4ElSSZuobAc2NPWR4EVAG3/24B9gyhWkjRzXa66GUqypK2fDHwA2AE8AFzRuq0D7m7rW9s2bf/9VXXYGb0kaX50uanZ2cDmJCcw/ofhrqr6bpKfAN9KciPwQ+C21v824I+S7GL8TP7qOahbktTRtEFfVY8D75qi/WnGx+sPbT8AXDmQ6iRJs+YvYyWp5wx6Seo5g16Ses6gl6SeM+glqecMeknqOYNeknrOoJeknjPoJannDHpJ6jmDXpJ6zqCXpJ4z6CWp5wx6Seo5g16Seq7LDFMrkjyQZEeSJ5P8fms/Pcl9SXa25WmtPUluSbIryeNJzp/rDyFJen1dzuhfA/5JVf0m43PFXp/kXGAjsK2qVgHb2jbAxcCq9tgA3DrwqiVJnU0b9FX1fFU91tZ/zvh8scuAtcDm1m0zcFlbXwvcUeMeZnwS8bMHXrkkqZMZjdEnWcn4tIKPAGdV1fMw/scAOLN1WwbsnvS00dYmSVoAnYM+ya8B/xH4g6r6iyN1naKtpni9DUlGkoyMjY11LUOSNEOdgj7JIsZD/o+r6k9b8wsTQzJtube1jwIrJj19ObDn0Nesqk1VNVxVw0NDQ0dbvyRpGl2uuglwG7Cjqr40addWYF1bXwfcPan9mnb1zYXA/okhHknS/DuxQ5/3Ar8L/DjJ9tb2z4GbgLuSrAeeA65s++4BLgF2Aa8A1w20YknSjEwb9FX135l63B1gzRT9C7h+lnVJkgbEX8ZKUs8Z9JLUcwa9JPWcQS9JPWfQS1LPGfSS1HMGvST1nEEvST1n0EtSzxn0ktRzBr0k9ZxBL0k9Z9BLUs8Z9JLUcwa9JPWcQS9JPddlKsE/TLI3yROT2k5Pcl+SnW15WmtPkluS7EryeJLz57J4SdL0upzR3w586JC2jcC2qloFbGvbABcDq9pjA3DrYMqUJB2tLlMJ/rckKw9pXgu8r61vBh4EPtPa72jTCT6cZEmSs50cXDp+rNz4vQV772du+vCCvXefHe0Y/VkT4d2WZ7b2ZcDuSf1GW9thkmxIMpJkZGxs7CjLkCRNZ9Bfxk41iXhN1bGqNlXVcFUNDw0NDbgMSdKEow36F5KcDdCWe1v7KLBiUr/lwJ6jL0+SNFtHG/RbgXVtfR1w96T2a9rVNxcC+x2fl6SFNe2XsUn+hPEvXs9IMgp8FrgJuCvJeuA54MrW/R7gEmAX8Apw3RzULEmagS5X3Xz0dXatmaJvAdfPtihJ0uD4y1hJ6rlpz+j1+hbyemNJ6sozeknqOYNeknrOoJeknjPoJannDHpJ6jmDXpJ6zqCXpJ4z6CWp5/zBlKRjxkL9CLHvE554Ri9JPWfQS1LPGfSS1HMGvST13JwEfZIPJXkqya4kG+fiPSRJ3Qz8qpskJwBfAz7I+ByyP0iytap+Muj3Am8VLEnTmYsz+guAXVX1dFW9CnwLWDsH7yNJ6mAurqNfBuyetD0KvGcO3keSBmIhRwbm4xr+uQj6TNFWh3VKNgAb2uZfJnlqDmo5Vp0B/PlCF3EM8/hMz2M0vePiGOULs3r6X+vSaS6CfhRYMWl7ObDn0E5VtQnYNAfvf8xLMlJVwwtdx7HK4zM9j9H0PEa/NBdj9D8AViU5J8lJwNXA1jl4H0lSBwM/o6+q15L8I+A/AycAf1hVTw76fSRJ3czJTc2q6h7gnrl47Z54Qw5ZzYDHZ3oeo+l5jJpUHfY9qSSpR7wFgiT1nEE/D5KcnuS+JDvb8rQp+qxO8lCSJ5M8nuSqhah1Pk13q4wkb05yZ9v/SJKV81/lwupwjG5I8pP278y2JJ0ut+uTrrdcSXJFkkryhrsSx6CfHxuBbVW1CtjWtg/1CnBNVf1N4EPAl5Msmcca59WkW2VcDJwLfDTJuYd0Ww+8VFXvAG4GZnfF8XGm4zH6ITBcVX8L2AL8m/mtcmF1PEYkOQX4PeCR+a3w2GDQz4+1wOa2vhm47NAOVfU/q2pnW98D7AWG5q3C+dflVhmTj9sWYE2SqX6Q11fTHqOqeqCqXmmbDzP+u5U3kq63XPkc438ED8xncccKg35+nFVVzwO05ZlH6pzkAuAk4KfzUNtCmepWGcter09VvQbsB5bOS3XHhi7HaLL1wH+a04qOPdMeoyTvAlZU1Xfns7BjiXPGDkiS/wr8+hS7/sUMX+ds4I+AdVV1cBC1HaO63Cqj0+00eqzz50/yD4Bh4HfmtKJjzxGPUZI3MT7sd+18FXQsMugHpKo+8Hr7kryQ5Oyqer4F+d7X6Xcq8D3gX1bVw3NU6rGiy60yJvqMJjkReBuwb37KOyZ0up1Ikg8wfkLxO1X1V/NU27FiumN0CnAe8GAb9ft1YGuSS6tqZN6qXGAO3cyPrcC6tr4OuPvQDu12Ed8B7qiqb89jbQuly60yJh+3K4D76431w49pj1Eblvh3wKVVNeUJRM8d8RhV1f6qOqOqVlbVSsa/x3hDhTwY9PPlJuCDSXYyPiHLTQBJhpN8o/X5+8BvA9cm2d4eqxem3LnXxtwnbpWxA7irqp5M8q+TXNq63QYsTbILuIGpr1bqrY7H6N8CvwZ8u/0784a6r1THY/SG5y9jJannPKOXpJ4z6CWp5wx6Seo5g16Ses6gl6SeM+glqecMeknqOYNeknru/wMmG6WHCo/z8gAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# To get the CATE at every X we call effect(X)\n",
    "dml_effect = cate.effect(X)\n",
    "plt.hist(dml_effect, label='est')\n",
    "#plt.hist(true_fn(X), alpha=.2, label='true')\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 417,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[ 0.02975042  0.04347443 -0.03862505  0.02305182 -0.01320292  0.00344808\n",
      "  0.09997247 -0.05785311  0.04544055  0.11985316  0.00339822 -0.00801335\n",
      "  0.01175173 -0.05101555 -0.06729893  0.05735538  0.04223998 -0.07852021\n",
      " -0.06095911 -0.05350563  0.07035496  0.12237924 -0.06537911]\n",
      "0.0070042050825846235\n"
     ]
    },
    {
     "ename": "AttributeError",
     "evalue": "'LinearRegression' object has no attribute 'lasso_model'",
     "output_type": "error",
     "traceback": [
      "\u001b[1;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[1;31mAttributeError\u001b[0m                            Traceback (most recent call last)",
      "\u001b[1;32m<ipython-input-417-fe8b92780b90>\u001b[0m in \u001b[0;36m<module>\u001b[1;34m\u001b[0m\n\u001b[0;32m      2\u001b[0m \u001b[0mprint\u001b[0m\u001b[1;33m(\u001b[0m\u001b[0mcate\u001b[0m\u001b[1;33m.\u001b[0m\u001b[0mcoef_\u001b[0m\u001b[1;33m)\u001b[0m\u001b[1;33m\u001b[0m\u001b[1;33m\u001b[0m\u001b[0m\n\u001b[0;32m      3\u001b[0m \u001b[0mprint\u001b[0m\u001b[1;33m(\u001b[0m\u001b[0mcate\u001b[0m\u001b[1;33m.\u001b[0m\u001b[0mintercept_\u001b[0m\u001b[1;33m)\u001b[0m\u001b[1;33m\u001b[0m\u001b[1;33m\u001b[0m\u001b[0m\n\u001b[1;32m----> 4\u001b[1;33m \u001b[0mprint\u001b[0m\u001b[1;33m(\u001b[0m\u001b[0mcate\u001b[0m\u001b[1;33m.\u001b[0m\u001b[0meffect_model\u001b[0m\u001b[1;33m.\u001b[0m\u001b[0mlasso_model\u001b[0m\u001b[1;33m.\u001b[0m\u001b[0malpha_\u001b[0m\u001b[1;33m)\u001b[0m\u001b[1;33m\u001b[0m\u001b[1;33m\u001b[0m\u001b[0m\n\u001b[0m\u001b[0;32m      5\u001b[0m \u001b[0mplt\u001b[0m\u001b[1;33m.\u001b[0m\u001b[0mplot\u001b[0m\u001b[1;33m(\u001b[0m\u001b[0mcate\u001b[0m\u001b[1;33m.\u001b[0m\u001b[0meffect_model\u001b[0m\u001b[1;33m.\u001b[0m\u001b[0mlasso_model\u001b[0m\u001b[1;33m.\u001b[0m\u001b[0malphas_\u001b[0m\u001b[1;33m,\u001b[0m \u001b[0mcate\u001b[0m\u001b[1;33m.\u001b[0m\u001b[0meffect_model\u001b[0m\u001b[1;33m.\u001b[0m\u001b[0mlasso_model\u001b[0m\u001b[1;33m.\u001b[0m\u001b[0mmse_path_\u001b[0m\u001b[1;33m)\u001b[0m\u001b[1;33m\u001b[0m\u001b[1;33m\u001b[0m\u001b[0m\n\u001b[0;32m      6\u001b[0m \u001b[0mplt\u001b[0m\u001b[1;33m.\u001b[0m\u001b[0mshow\u001b[0m\u001b[1;33m(\u001b[0m\u001b[1;33m)\u001b[0m\u001b[1;33m\u001b[0m\u001b[1;33m\u001b[0m\u001b[0m\n",
      "\u001b[1;31mAttributeError\u001b[0m: 'LinearRegression' object has no attribute 'lasso_model'"
     ]
    }
   ],
   "source": [
    "# To get the parameter theta we call coef_. The first entry is the intercept of the CATE model\n",
    "print(cate.coef_)\n",
    "print(cate.intercept_)\n",
    "print(cate.effect_model.lasso_model.alpha_)\n",
    "plt.plot(cate.effect_model.lasso_model.alphas_, cate.effect_model.lasso_model.mse_path_)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "ATE Estimate: 0.072\n",
      "True ATE: 0.000\n"
     ]
    }
   ],
   "source": [
    "# We can average the CATE to get an ATE\n",
    "print(\"ATE Estimate: {:.3f}\".format(np.mean(dml_effect)))\n",
    "print(\"True ATE: {:.3f}\".format(np.mean(true_fn(X))))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 215,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAX8AAAEICAYAAAC3Y/QeAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADl0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uIDIuMi4zLCBodHRwOi8vbWF0cGxvdGxpYi5vcmcvIxREBQAAHH1JREFUeJzt3XuUXGWd7vHvQ9KQAIFIkgFygUTNRC5HLraJDjMjLtAAxgRPYIKIBIXJIMLMUVfWgHKYiHjMTFAHjrC4CAJyEUEMESIZDXLwRqRDEghmMiaRS3eUxMRmwHRCLr/zx94dK01Vd1dqV1V37eezVq+ueveu/b5vX5797nfvqq2IwMzM8mWfejfAzMxqz+FvZpZDDn8zsxxy+JuZ5ZDD38wshxz+ZmY55PA366Mk/VDSzDrUe42kP0j6fa3rttpx+Pdhkl6Q1CHpNUntkn4h6WJJ+xSsc4ekkDS1y2v/PS2/IH1+gaSflajnCUkXSRolaYektxVZ5/uSri3x+n0lzZH0G0l/Stt9u6SxXda7I93+yIKymyS9nn69IWl7wfMfShqb9uP1Ll8zyvhRli2t808F9bVXub45ku4uLIuI0yPizmrWW6QdY4DPAUdHxGE1qnN/STemO5xXJT3ZZfmJkp5Mfw+vSPqngmXHS/pp+rpWSVfVos2NwOHf9304IoYARwJzgX8Gbuuyzn8Bu0eIkgYCZwNry6koItqAxcDHC8slHQKcAZQKogeBqcC5wMHAccBS4JSCbRwATAdeBT5WUOfFEXFgRBwI/B/g/s7nEXF6QR1DC8oPjIj7y+nbXjquoL6hNaivLzgS2BQRG3qzcvq3VqlbgEOAo9LvnynY/nDgMeBmYBjwduA/Cl57L/Bk+rr3AZ/qOhCy4hz+/UREvBoRC4AZwExJxxYs/gFwkqS3pM9PA54F9uaw/U66hD9wDvB8RDzXdWVJpwIfAKZFxNMRsSNt6w0RUbiTmg60A1dTsKPKmqRPSFqVHi2tk/QPBcuGS3okPYranI4Yy/ofKHYElR4lvD19fIekGyQ9mrZhSeGRlKRjJP0orf8VSZ+XdBrweWBGOrpdka77hKSL0sf7SLpS0ouSNki6S9LB6bLOo6OZkl5KR9Bf6KYPB6ev35hu78p0+6cCPwJGpu24o8hrT05H2P+sZFroW2n5FEnL9ecj1HcWvOZEScvSn8cDku6XdE26bALJwGFWRGyMiJ0RsbSgys8CiyLinojYFhGvRcSqguVjgXvS160FfgYc0+0v0QCHf78TEb8CWoG/KSjeCiwgCWmA84G79rKK7wPDJf11QdnHu9neqcCvIuLlHrY7E7gP+A7wDkkn7mX7erIBmAIcBHwC+HpBXZ8j+dmNAA4lCdxqfL7JR4EvAm8B1gBfBpA0BPgxyUh2JMkodnFEPMaeRz3HFdnmBenX+4G3AgcC3+iyzl8DE0iOuK6SdFSJ9v1fkiO0t5KMls8HPhERPwZOB9an7bigxOsPIxlpHwnMSn++twP/QDI6vxlYIGk/SfuS/E3dkb7mPuAjBduaBLwIfDHdaT0naXrB8vcAm9MdygZJP5B0RMHyfwfOl9SU7kjeS/Izth44/Pun9ST/SIXuIvknOJjkH3r+3mw4IjqAB0gCAUnjgXeRHF4XMwz4XXfbTP9Z3w/cGxGvkEwtlTv6/0M6quz8KhpsEfFoRKyNxP8jmSLo3FFuBw4HjoyI7RHx0+j+w62eKajv+jLa+lBE/CoidgD3AMen5VOA30fEVyNiazqKXdLLbX4M+FpErIuI14ErgHO6TLt8MSI6ImIFsIJk+m0PkgaQHD1ekdb/AvBV3ny0151dwL+kI/EO4O+BmyNiSToCvxPYRhLc7wEGAtenP/OHgF8VbGs0cCzJdOBI4FLgzoLf72iSv5V/Ao4AfkuyA+n0CHAW0AH8J3BbRDxdRl9yy+HfP40CNhcWRMTPSEa0VwKPpP+Ue+tO4O8kDSIJhce6mQPeRBKo3fk4sCoilqfP7wHOldRURpuGR8TQgq9VxVaSdLqkp9JplXaScxXD08XzSEbi/5FOCV3eQ50nFtT3j2W0tXC6bQvJKB1gDGWehykwkmSE3OlFklA9tBf1FhoO7FtkW6PKaMvGiNha8PxI4HOFO2eSvo5Mv9q67GQLjxI7SHbK10TEG+kO+yfABwuWfz+dUtxKckT1V+nU1SEkR1FXA4PSOidLuqSMvuSWw7+fkfRukn/UYlfu3E0ytbG3Uz4ARMRPSUJ9GnBeD9v7MTBR0uhu1jkfeKuk36fzxF8jCaHTu3lN2STtB3wPuBY4ND1JuxAQQDrS/VxEvBX4MPBZSaeU3GBxfwL2L6iznCtiXgbedCVVqqfpp/UkIdvpCGAH8EoZ9QP8gSRsu26rrYxtdG3ry8CXu+yc94+I+0iOCkdJUsH6YwoeP9tDXc92qa/zsUimrXZGxF3puaZWkmnFM8roS245/PsJSQdJmkLyx313sZOvwPUkJ1+fLLIs3YwGFX51U+VdwL8CQ0lOKBeVzhP/CPi+pHdJGihpiJJLUj8p6b0kgTeRZPrjeJLD/HvJ/sTvvsB+wEZgh6TT+fMIsvOk5NvTIPpvYGf6VY4VwDFKLjEcBMwp47WPAIdJ+l/pfPgQSZPSZa8AY1X6BPR9wGckjZNUeGXUjnIaHxE7ge8CX07rP5LkpOrd3b+yW7cCF0uapMQBkj6UnuP4JcnP+NL0b2Mayd9CpyeBl4Ar0uUnAScDi9Ll3wI+kv68m4D/DfwsItpJrnKTpHPTE9aHkUxpraigL7nh8O/7fiDpNZLR1RdIRs2fKLZiRGyOiMXdzGP/Fclh9O4vlb5U7y6SEeH9EbGthzaeRTLCvp9k7nYl0ExyVDATeDginouI33d+AdcBU9JD995o157X+X+26woR8RrwjyTh9keSS08XFKwyPm3T6yShdGNEPNHL+jvr+C+SaYYfA7+h+BFYqde+RrJz/jDJFM1vSM6FQHKeBWCTpGeKvPx24NskYflbkpP8l5XT9gKXkRzBrCNp/73p9vdKRLSQzPt/g+Tnvobk5DQR8QbwP4ELSa72Oo9kJ7gtXb6d5AjzDJK/nVuB8yPiP9Plj5OcmH+U5GT+20l+r0TEf6fb/kxa73KSv70v721f8kTdn+8yM8uWpCXATRHxrXq3Jc888jezqpL0PkmHpdM6M4F3kpyotTrK4t15ZmbdmUAyFXcgydVOZ0VEt5cHW/V52sfMLIc87WNmlkN9dtpn+PDhMXbs2Ho3w8ysX1m6dOkfImJET+v12fAfO3YsLS0t9W6GmVm/IunFntfytI+ZWS45/M3Mcsjhb2aWQ312zr+Y7du309raytatW3teuR8aNGgQo0ePpqmpnA+7NDMrX78K/9bWVoYMGcLYsWPZ80MC+7+IYNOmTbS2tjJu3Lh6N8fMGly/mvbZunUrw4YNa7jgB5DEsGHDGvaoxsz6ln4V/kBDBn+nRu6bmfUt/S78zcyscg7/KrrjjjtYv359vZthZvYmDv8qcvibWV/Vr672Kdf8ZW3MW7Sa9e0djBw6mNmTJ3DmCeXcp7q4u+++m+uvv5433niDSZMmceONN3LhhRfS0tKCJD75yU8yZswYWlpa+NjHPsbgwYP55S9/yeDBgzPolZlZ5Ro2/Ocva+OKh56jY3tyi9a29g6ueCi57W0lO4BVq1Zx//338/Of/5ympiYuueQSrrnmGtra2li5ciUA7e3tDB06lG984xtce+21NDc3V94hM7MMNey0z7xFq3cHf6eO7TuZt2h1RdtdvHgxS5cu5d3vfjfHH388ixcvZvPmzaxbt47LLruMxx57jIMOOqiiOswsP+Yva+OkuY8z7vJHOWnu48xf1laTehs2/Ne3d5RV3lsRwcyZM1m+fDnLly9n9erVXHfddaxYsYKTTz6ZG264gYsuuqiiOswsHzpnKNraOwj+PENRix1Aw4b/yKHF59dLlffWKaecwoMPPsiGDRsA2Lx5My+++CK7du1i+vTpfOlLX+KZZ54BYMiQIbz22msV1WdmjataMxS90bBz/rMnT9hjzh9gcNMAZk+eUNF2jz76aK655ho++MEPsmvXLpqamvja177GRz7yEXbt2gXAV77yFQAuuOACLr74Yp/wNbOiqjVD0RsNG/6dJ3WrcbXPjBkzmDFjxh5lnaP9QtOnT2f69OkV12dmjWnk0MG0FQn6SmcoeqNhwx+SHUAWYW9mVg3VmqHojYYOfzOzvqyaMxQ9cfibmdVRvWYoGvZqHzMzK80jfzOzOqrWx9D0xOFvZlYn1foYmt7wtE+Z2tvbufHGG+vdDDNrAPV8k5fDv0ylwn/nzp1F1jYzK81v8qqWLZth81rY+ioMOhgOeRvsf0hFm7z88stZu3Ytxx9/PE1NTRx44IEcfvjhLF++nIULFzJlypTdn+557bXX8vrrrzNnzhzWrl3Lpz/9aTZu3Mj+++/Prbfeyjve8Y4semlm/dTQ/Zv445btRcurrXHDf8tmaGuBpgNg8CGwvSN5Pqq5oh3A3LlzWblyJcuXL+eJJ57gQx/6ECtXrmTcuHG88MILJV83a9YsbrrpJsaPH8+SJUu45JJLePzxx/e6HWbW/0WUV56lxg3/zWuT4N93/+R55/fNayse/ReaOHEi48aN63ad119/nV/84hecffbZu8u2bduWWRvMrH9q73jzqL+78iw1bvhvfTUZ8RdqGgwdmzOt5oADDtj9eODAgbs/3A1g69atAOzatYuhQ4eyfPnyTOs2s/5tgMTOIsP8AVLV627cE76DDk6megpt70jKK9DdxzQfeuihbNiwgU2bNrFt2zYeeeQRAA466CDGjRvHAw88ACT3BFixYkVF7TCz/q9Y8HdXnqXGDf9D3gbb/wRvbEkm0N7Ykjw/5G0VbXbYsGGcdNJJHHvsscyePXuPZU1NTVx11VVMmjSJKVOm7HFC95577uG2227juOOO45hjjuHhhx+uqB1m1v8dsO+AssqzpKjFmYW90NzcHC0tLXuUrVq1iqOOOqr3G6nC1T7VVnYfzazfGnf5oxRLYAG/nfuhvdqmpKUR0eONwxt3zh+SoO/jYW9m+VVq6F2LIXnjTvuYmVlJ/S78++o0VRYauW9m1rf0q/AfNGgQmzZtasiQjAg2bdrEoEGD6t0UM6uRUSVu11iqPEuZzPlLOg24DhgAfDMi5nZZ/lngImAHsBH4ZES8WG49o0ePprW1lY0bN2bQ6r5n0KBBjB49ut7NMLMa6de3cZQ0ALgB+ADQCjwtaUFE/LpgtWVAc0RskfQp4N+AGW/eWveampp6fDetmVl/0d9v4zgRWBMR6wAkfQeYBuwO/4j4ScH6TwHnZVCvmVm/V6/bOGYR/qOAlwuetwKTuln/QuCHxRZImgXMAjjiiCMyaJqZWd925fznuG/Jy+yMYIDERyeN4Zoz/0fV683ihG+xD6EoekZW0nlAMzCv2PKIuCUimiOiecSIERk0zcys77py/nPc/dRLuz/OYWcEdz/1ElfOf67qdWcR/q3AmILno4H1XVeSdCrwBWBqRNTkIy3nL2vjpLmPM+7yRzlp7uPMX9ZWi2rNzHrlviUvl1WepSymfZ4GxksaB7QB5wDnFq4g6QTgZuC0iNiQQZ09que9Mc3MeqNff7BbROwALgUWAauA70bE85KuljQ1XW0ecCDwgKTlkhZUWm9P6nlvTDOzvi6T6/wjYiGwsEvZVQWPT82innK0lbgHZqlyM7M86Vfv8C3HPiXuhVCq3Mys1oYOLn6v3lLlWWrY8N9VYsqsVLmZWa2VumFXDW7k1bjhb2bW17VvKXEP3xLlWWrY8K/n4ZSZWW+MLPEBbqXKs9Sw4T9n6jE0dZngb9pHzJl6TJ1aZGa2p9mTJzC4ac9bNtbqg90aNvzPPGEUMyaOYUA6eTZAYsbEMb7G38z6jDNPGMX0d43aI6emv6s2n/XTsOE/f1kb31vatsfbpr+3tM3v8jWzPqOeOdWw4e83eZlZX1fPnGrY8F9f4s1cpcrNzGqtnm9Gbdjwr+dZdDOzvq5hw3/25AlFr/apxVl0M7O+rmHDH2BHl7fzdn1uZpZXDRv+n3/o2TfdUSbScjOzvGvY8N+yfVdZ5WZmedKw4W9mZqU5/M3Mcsjhb2aWQw5/M7MccvibmeWQw9/MLIcc/mZmdVLPe407/M3M6uTcSUeUVZ4lh7+ZWZ08+PTLZZVnyeFvZlYnW3cW/7yxUuVZcvibmeWQw9/MLIcc/mZmOeTwNzPLIYe/mVkOOfzNzHLI4W9mlkMOfzOzHHL4m5nlkMPfzCyHHP5mZjnk8DczyyGHv5lZDmUS/pJOk7Ra0hpJlxdZ/reSnpG0Q9JZWdRpZmZ7r+LwlzQAuAE4HTga+Kiko7us9hJwAXBvpfWZmVnlBmawjYnAmohYByDpO8A04NedK0TEC+myXRnUZ2ZmFcpi2mcUUHjbmda0rGySZklqkdSycePGDJpmZmbFZBH+xW41vFe3oYmIWyKiOSKaR4wYUWGzzMyslCzCvxUYU/B8NLA+g+2amVmVZBH+TwPjJY2TtC9wDrAgg+2amVmVVBz+EbEDuBRYBKwCvhsRz0u6WtJUAEnvltQKnA3cLOn5Sus1M7O9l8XVPkTEQmBhl7KrCh4/TTIdZGZmfYDf4WtmlkMOfzOzOikVwLUIZoe/mVm9FLtQvrvyDDn8zczqZFeJd0SVKs+Sw9/MLIcc/mZmOeTwNzOrk1FDB5dVniWHv5lZncyePIHBTQP2KBvcNIDZkydUve5M3uRlZmblO/OE5AOQ5y1azfr2DkYOHczsyRN2l1eTw9/MrI7OPGFUTcK+K0/7mJnlkMPfzCyHHP5mZjnk8DczyyGHv5lZDjn8zcxyyOFvZpZDvs7fzKyO5i9r85u8zMzyZP6yNq546Dk6tu8EoK29gyseeg6g6jsAT/uYmdXJvEWrdwd/p47tO5m3aHXV63b4m5nVyfr2jrLKs+TwNzOrk5ElPrq5VHmWHP5mZnXij3Q2M8shf6SzmVlO+SOdzcysZhz+ZmY55PA3M8shh7+ZWQ45/M3Mcsjhb2aWQw5/M7MccvibmeWQw9/MLIcc/mZmOeTwNzPLIYe/mVkOOfzNzHIok0/1lHQacB0wAPhmRMztsnw/4C7gXcAmYEZEvJBF3d15lnMZtA9IEAFbd8E7ubfa1ZqZ9d6cg4uUvVr1aise+UsaANwAnA4cDXxU0tFdVrsQ+GNEvB34OvCvldbbk2c5l8EDkuBP2gmDByTlZmZ9QrHg7648Q1lM+0wE1kTEuoh4A/gOMK3LOtOAO9PHDwKnSJ2xXB2DSvSsVLmZWZ5kEYWjgJcLnremZUXXiYgdwKvAsK4bkjRLUouklo0bN1bUqFK7lurucszM+ocswr9YnMZerENE3BIRzRHRPGLEiIoaFW/aevflZmZ5kkX4twJjCp6PBtaXWkfSQOBgYHMGdZe0dVd55WZmeZJF+D8NjJc0TtK+wDnAgi7rLABmpo/PAh6PqO4Y/J3cS8fOP4/0I6Bjp6/2MbM+pNRVPTW42qfiSz0jYoekS4FFJJd63h4Rz0u6GmiJiAXAbcC3Ja0hGfGfU2m9vfFO7gWP9M2sL6tB0BeTyXX+EbEQWNil7KqCx1uBs7Ooy8zMKucLH83Mcsjhb2aWQw5/M7MccvibmeWQw9/MLIcc/mZmOeTwNzPLIYe/mVkOOfzNzHLI4W9mlkMOfzOzHHL4m5nlkMPfzCyHHP5mZjnk8DczyyGHv5lZDjn8zcxyyOFvZpZDDn8zsxxy+JuZ5ZDD38wshxz+ZmY55PA3M8shh7+ZWQ45/M3Mcsjhb2aWQw5/M7MccvibmeWQw9/MLIcc/mZmOeTwNzPLIYe/mVkOOfzNzHLI4W9mlkMOfzOzHHL4m5nlkMPfzCyHKgp/SYdI+pGk36Tf31JivccktUt6pJL6zMwsG5WO/C8HFkfEeGBx+ryYecDHK6zLzMwyUmn4TwPuTB/fCZxZbKWIWAy8VmFdZmaWkUrD/9CI+B1A+v0vKm+SmZlV28CeVpD0Y+CwIou+kHVjJM0CZgEcccQRWW/ezMxSPYZ/RJxaapmkVyQdHhG/k3Q4sKGSxkTELcAtAM3NzVHJtszMrLRKp30WADPTxzOBhyvcnpmZ1UCl4T8X+ICk3wAfSJ8jqVnSNztXkvRT4AHgFEmtkiZXWK+ZmVWgx2mf7kTEJuCUIuUtwEUFz/+mknrMzCxbfoevmVkOOfzNzHLI4W9mlkMOfzOzHHL4m5nlkMPfzCyHHP5mZjnk8DczyyGHv5lZDjn8zcxyyOFvZpZDDn8zsxxy+JuZ5ZDD38wshxz+ZmY55PA3M8uhhg3/oYObyio3M8uThg3/OVOPoWkf7VHWtI+YM/WYOrXIzKzvqOg2jn3ZmSeMAmDeotWsb+9g5NDBzJ48YXe5mVmeNWz4Q7IDcNibmb1Zw077mJlZaQ5/M7MccvibmeWQw9/MLIcc/mZmOeTwNzPLIYe/mVkOOfzNzHLI4W9mlkMOfzOzHHL4m5nlkMPfzCyHFBH1bkNRkjYCL2a0ueHAHzLaVl+Xp76C+9vI8tRXyK6/R0bEiJ5W6rPhnyVJLRHRXO921EKe+grubyPLU1+h9v31tI+ZWQ45/M3Mcigv4X9LvRtQQ3nqK7i/jSxPfYUa9zcXc/5mZranvIz8zcysgMPfzCyHGib8JZ0mabWkNZIuL7J8P0n3p8uXSBpb+1Zmpxf9/aykX0t6VtJiSUfWo51Z6am/BeudJSkk9dtLBHvTV0l/l/5+n5d0b63bmKVe/C0fIeknkpalf89n1KOdWZB0u6QNklaWWC5J16c/i2clnVi1xkREv/8CBgBrgbcC+wIrgKO7rHMJcFP6+Bzg/nq3u8r9fT+wf/r4U43e33S9IcCTwFNAc73bXcXf7XhgGfCW9Plf1LvdVe7vLcCn0sdHAy/Uu90V9PdvgROBlSWWnwH8EBDwHmBJtdrSKCP/icCaiFgXEW8A3wGmdVlnGnBn+vhB4BRJqmEbs9RjfyPiJxGxJX36FDC6xm3MUm9+vwBfAv4N2FrLxmWsN339e+CGiPgjQERsqHEbs9Sb/gZwUPr4YGB9DduXqYh4EtjczSrTgLsi8RQwVNLh1WhLo4T/KODlguetaVnRdSJiB/AqMKwmrcteb/pb6EKS0UR/1WN/JZ0AjImIR2rZsCroze/2L4G/lPRzSU9JOq1mrcteb/o7BzhPUiuwELisNk2ri3L/t/fawGpstA6KjeC7XsPam3X6i173RdJ5QDPwvqq2qLq67a+kfYCvAxfUqkFV1Jvf7UCSqZ+TSY7ofirp2Ihor3LbqqE3/f0ocEdEfFXSe4Fvp/3dVf3m1VzNcqpRRv6twJiC56N586Hh7nUkDSQ5fOzu8Ksv601/kXQq8AVgakRsq1HbqqGn/g4BjgWekPQCyVzpgn560re3f8sPR8T2iPgtsJpkZ9Af9aa/FwLfBYiIXwKDSD4ErRH16n87C40S/k8D4yWNk7QvyQndBV3WWQDMTB+fBTwe6RmWfqjH/qbTIDeTBH9/nhOGHvobEa9GxPCIGBsRY0nOcUyNiJb6NLcivflbnk9yQh9Jw0mmgdbVtJXZ6U1/XwJOAZB0FEn4b6xpK2tnAXB+etXPe4BXI+J31aioIaZ9ImKHpEuBRSRXD9weEc9LuhpoiYgFwG0kh4trSEb859SvxZXpZX/nAQcCD6TntV+KiKl1a3QFetnfhtDLvi4CPijp18BOYHZEbKpfq/deL/v7OeBWSZ8hmQK5oL8O3CTdRzJdNzw9h/EvQBNARNxEck7jDGANsAX4RNXa0k9/hmZmVoFGmfYxM7MyOPzNzHLI4W9mlkMOfzOzHHL4m5nlkMPfzCyHHP5mZjn0/wHfVXq0DUpLNQAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# We can also see how it compares to the true CATE at each target point and calculate MSE\n",
    "plt.title(\"DMLIV CATE as Function of {}\".format(X_df.columns[np.argmax(np.abs(cate.coef_[1:]))]))\n",
    "plt.scatter(X[:, np.argmax(np.abs(cate.coef_[1:]))], dml_effect, label='est')\n",
    "plt.scatter(X[:, np.argmax(np.abs(cate.coef_[1:]))], true_fn(X), label='true', alpha=.2)\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 128,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Unavailable\n"
     ]
    }
   ],
   "source": [
    "# The property .fitted_nuisances is a dictionary of the form:\n",
    "# {'name_of_nuisance': [fitted_model_fold_1, fitted_model_fold_2, ...]}\n",
    "# then we can access all properties of each of the fitted models for each fold.\n",
    "# If for instance all nuisances have a linear form we can look at the standard deviation\n",
    "# of the coefficients of each of the nuisance model across folds to check for stability\n",
    "try:\n",
    "    [print(\"Model {} max std of coefs: {}\".format(name,\n",
    "                                                  np.max(np.std([ns.coef_ for ns in nuisance_insts], axis=0)))) \n",
    "     if hasattr(nuisance_insts[0], 'coef_') else\n",
    "     print(\"Model {} max std of coefs: {}\".format(name,\n",
    "                                                  np.max(np.std([ns.named_steps['clf'].coef_ for ns in nuisance_insts],\n",
    "                                                                axis=0)))) \n",
    "     for name, nuisance_insts in cate.fitted_nuisances.items()]\n",
    "except:\n",
    "    print(\"Unavailable\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 129,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Unavailable\n"
     ]
    }
   ],
   "source": [
    "try:\n",
    "    nuisance_diagnostic(cate, 'model_T_XZ', 'coef', lambda ns: ns.coef_.flatten(),\n",
    "                        [c+\"_0\" for c in X_df.columns] + [c+\"_1\" for c in X_df.columns])\n",
    "    nuisance_diagnostic(cate, 'model_T_X', 'coef', lambda ns: ns.coef_.flatten(), X_df.columns)\n",
    "    nuisance_diagnostic(cate, 'model_Y_X', 'coef', lambda ns: ns.coef_.flatten(), X_df.columns)\n",
    "except:\n",
    "    print(\"Unavailable\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 130,
   "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"
    },
    {
     "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": [
    "try:\n",
    "    nuisance_diagnostic(cate, 'model_T_XZ', 'predict', lambda ns: ns.predict(hstack([X, Z.reshape(-1,1)])))\n",
    "    nuisance_diagnostic(cate, 'model_T_X', 'predict', lambda ns: ns.predict(X))\n",
    "except:\n",
    "    print(\"Unavailable\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "scrolled": false
   },
   "outputs": [],
   "source": [
    "try:\n",
    "    nuisance_diagnostic(cate, 'model_T_XZ', 'coef_0', lambda ns: ns.model0.coef_.flatten(), index_names=X_df.columns)\n",
    "    nuisance_diagnostic(cate, 'model_T_XZ', 'coef_1', lambda ns: ns.model1.coef_.flatten(), index_names=X_df.columns)\n",
    "\n",
    "    plt.title(\"Difference in coefficients betwen model0 and model1\")\n",
    "    for i in range(N_SPLITS):\n",
    "        plt.plot([c0 - c1 for c0, c1 in zip(cate.fitted_nuisances['model_T_XZ'][i].model0.coef_.flatten(),\n",
    "              cate.fitted_nuisances['model_T_XZ'][i].model1.coef_.flatten())])\n",
    "    plt.show()\n",
    "except:\n",
    "    print(\"Unavailable\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "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"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Average correlation of residual h-p with Z: [0.25169285]\n",
      "Heterogeneity of residual h-p with respect to X: [-0.19268455  0.23146173 -0.01722326  0.00733857  0.00713799  0.00617641\n",
      " -0.05307162 -0.12368983 -0.         -0.          0.00416005  0.05341523\n",
      "  0.          0.         -0.         -0.12145698 -0.00517997  0.06338805\n",
      " -0.03051394  0.05007449 -0.         -0.06571574  0.28509872]\n"
     ]
    }
   ],
   "source": [
    "try:\n",
    "    for i in range(3):\n",
    "        plt.figure()\n",
    "        plt.hist(cate.fitted_nuisances['model_T_XZ'][i].predict(hstack([X[Z==0], Z[Z==0].reshape(-1,1)]))\n",
    "                 -cate.fitted_nuisances['model_T_X'][i].predict(X[Z==0]))\n",
    "        plt.hist(cate.fitted_nuisances['model_T_XZ'][i].predict(hstack([X[Z==1], Z[Z==1].reshape(-1,1)]))\n",
    "                 -cate.fitted_nuisances['model_T_X'][i].predict(X[Z==1]), alpha=.2)\n",
    "        plt.show()\n",
    "    print(\"Average correlation of residual h-p with Z: {}\".format(LinearRegression().fit(Z.reshape(-1,1), cate.fitted_nuisances['model_T_XZ'][i].predict(hstack([X, Z.reshape(-1,1)]))\n",
    "                 -cate.fitted_nuisances['model_T_X'][i].predict(X)).coef_))\n",
    "    print(\"Heterogeneity of residual h-p with respect to X: {}\".format(LassoCV(cv=5).fit(hstack([X, Z.reshape(-1,1)]), cate.fitted_nuisances['model_T_XZ'][i].predict(hstack([X, Z.reshape(-1,1)]))\n",
    "                 -cate.fitted_nuisances['model_T_X'][i].predict(X)).coef_))\n",
    "except:\n",
    "    print(\"Unavailable\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# ATE via DRIV"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [],
   "source": [
    "import statsmodels.api as sm\n",
    "\n",
    "# A wrapper of statsmodel linear regression, wrapped in a sklearn interface.\n",
    "# We can use statsmodel for all hypothesis testing capabilities\n",
    "class StatsModelLinearRegression:\n",
    "    def __init__(self):\n",
    "        return\n",
    "    def fit(self, X, y):\n",
    "        self.model = sm.OLS(y, X).fit()\n",
    "        return self\n",
    "    def predict(self, X):\n",
    "        return self.model.predict(exog=X)\n",
    "    def summary(self, *args, **kwargs):\n",
    "        return self.model.summary(*args, **kwargs)\n",
    "    @property\n",
    "    def coef_(self):\n",
    "        return self.model._results.params\n",
    "    @property\n",
    "    def intercept_(self):\n",
    "        return 0"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'const_dr_cate = ProjectedDRIV(model_Y_X(), model_T_X(), model_T_XZ(), # same as in DMLIV\\n                        prel_model_effect, # preliminary model for CATE, must support fit(y, T, X, Z) and effect(X)\\n                        model_cov_TZ_X(), # model for Cov(T, E[T|Z,X] | X)\\n                        const_driv_model_effect(), # model for final stage of fitting theta(X)\\n                        cov_clip=.0001, # covariance clipping to avoid large values in final regression from weak instruments\\n                        n_splits=10, # number of splits to use for cross-fitting\\n                        binary_instrument=True, # a flag whether to stratify cross-fitting by instrument\\n                        binary_treatment=True # a flag whether to stratify cross-fitting by treatment\\n                       )'"
      ]
     },
     "execution_count": 23,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "from dml_iv import DMLIV\n",
    "from dr_iv import DRIV, ProjectedDRIV\n",
    "from utilities import SubsetWrapper\n",
    "from sklearn.dummy import DummyRegressor\n",
    "\n",
    "np.random.seed(random_seed)\n",
    "\n",
    "# For ProjectedDRIV we also need a model that predicts\n",
    "# Cov(T, E[T|Z,X] | X) = E[(T-E[T|X]) * (E[T|Z,X]-E[T|X]) | X]\n",
    "model_cov_TZ_X = lambda: model()\n",
    "# For DRIV we need a model for predicting E[T*Z | X]. We use a classifier\n",
    "model_TZ_X = lambda: model()\n",
    "\n",
    "# We also need a model for the final regression that will fit the function theta(X)\n",
    "# If we want to fit an ATE, we simply fit a constant functin theta(X) = theta\n",
    "# We can do this with a pipeline where the preprocessing step only creates a bias column\n",
    "# and the regression step fits a linear regression with no intercept.\n",
    "# To get normal confidence intervals easily we can use a statsmodels linear regression\n",
    "# wrapped in an sklearn interface\n",
    "const_driv_model_effect = lambda: Pipeline([('poly', PolynomialFeatures(degree=0, include_bias=True)),\n",
    "                                      ('reg', StatsModelLinearRegression())])\n",
    "\n",
    "# As in OrthoDMLIV we need a perliminary estimator of the CATE.\n",
    "# We use a DMLIV estimator with no cross-fitting (n_splits=1)\n",
    "dmliv_prel_model_effect = DMLIV(model_Y_X(), model_T_X(), model_T_XZ(),\n",
    "                                dmliv_model_effect(), dmliv_featurizer(),\n",
    "                                n_splits=1, binary_instrument=True, binary_treatment=False)\n",
    "\n",
    "# We could have also used a non-doubly robust DRIV model with a zero preliminary effect model.\n",
    "# Though this is less advisable as it has much higher variacen than DMLIV and also depends\n",
    "# on exactly the same functions. So if these functions are not easily learnable, we wouldn't\n",
    "# be able to fix it via the learnability of other functions. This is what happens if we use\n",
    "# dmliv as a preliminary model.\n",
    "\"\"\"\n",
    "class DummyCATE:\n",
    "    def __init__(self):\n",
    "        return\n",
    "    def fit(self, y, T, X, Z):\n",
    "        return self\n",
    "    def effect(self, X):\n",
    "        return np.zeros(X.shape[0])\n",
    "\n",
    "lasso_driv_model_effect = lambda: Pipeline([('poly', PolynomialFeatures(degree=1, include_bias=False)),\n",
    "                                      ('reg', Lasso(alpha=.01))])\n",
    "driv_prel_model_effect = DRIV(model_Y_X(), model_T_X(), model_Z_X(), # same as in DMLATEIV\n",
    "                        DummyCATE(), # preliminary model for CATE, must support fit(y, T, X, Z) and effect(X)\n",
    "                        model_TZ_X(), # model for E[T * Z | X]\n",
    "                        lasso_driv_model_effect(), # model for final stage of fitting theta(X)\n",
    "                        cov_clip=0.01, # covariance clipping to avoid large values in final regression from weak instruments\n",
    "                        n_splits=N_SPLITS, # number of splits to use for cross-fitting\n",
    "                        binary_instrument=True, # a flag whether to stratify cross-fitting by instrument\n",
    "                        binary_treatment=True # a flag whether to stratify cross-fitting by treatment\n",
    "                       )\n",
    "\"\"\"\n",
    "\n",
    "const_dr_cate = DRIV(model_Y_X(), model_T_X(), model_Z_X(), # same as in DMLATEIV\n",
    "                        dmliv_prel_model_effect, # preliminary model for CATE, must support fit(y, T, X, Z) and effect(X)\n",
    "                        model_TZ_X(), # model for E[T * Z | X]\n",
    "                        const_driv_model_effect(), # model for final stage of fitting theta(X)\n",
    "                        cov_clip=COV_CLIP, # covariance clipping to avoid large values in final regression from weak instruments\n",
    "                        n_splits=N_SPLITS, # number of splits to use for cross-fitting\n",
    "                        binary_instrument=True, # a flag whether to stratify cross-fitting by instrument\n",
    "                        binary_treatment=True # a flag whether to stratify cross-fitting by treatment\n",
    "                       )\n",
    "\n",
    "# For comparison here is how ProjectedDRIV is called. A set of slightly different models\n",
    "\"\"\"const_dr_cate = ProjectedDRIV(model_Y_X(), model_T_X(), model_T_XZ(), # same as in DMLIV\n",
    "                        prel_model_effect, # preliminary model for CATE, must support fit(y, T, X, Z) and effect(X)\n",
    "                        model_cov_TZ_X(), # model for Cov(T, E[T|Z,X] | X)\n",
    "                        const_driv_model_effect(), # model for final stage of fitting theta(X)\n",
    "                        cov_clip=.0001, # covariance clipping to avoid large values in final regression from weak instruments\n",
    "                        n_splits=10, # number of splits to use for cross-fitting\n",
    "                        binary_instrument=True, # a flag whether to stratify cross-fitting by instrument\n",
    "                        binary_treatment=True # a flag whether to stratify cross-fitting by treatment\n",
    "                       )\"\"\"\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\moprescu\\AppData\\Local\\Continuum\\anaconda3\\lib\\site-packages\\sklearn\\model_selection\\_split.py:652: Warning: The least populated class in y has only 8 members, which is too few. The minimum number of members in any class cannot be less than n_splits=10.\n",
      "  % (min_groups, self.n_splits)), Warning)\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<dr_iv.DRIV at 0x19a65f9ef60>"
      ]
     },
     "execution_count": 24,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "const_dr_cate.fit(y, T, X, Z, store_final=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [],
   "source": [
    "# To get the ATE we look at the params of the fitted statsmodel\n",
    "const_dr_effect = const_dr_cate.effect_model.named_steps['reg'].coef_[0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\moprescu\\AppData\\Local\\Continuum\\anaconda3\\lib\\site-packages\\statsmodels\\regression\\linear_model.py:1554: RuntimeWarning: invalid value encountered in double_scalars\n",
      "  return self.ess/self.df_model\n",
      "C:\\Users\\moprescu\\AppData\\Local\\Continuum\\anaconda3\\lib\\site-packages\\scipy\\stats\\_distn_infrastructure.py:879: RuntimeWarning: invalid value encountered in greater\n",
      "  return (self.a < x) & (x < self.b)\n",
      "C:\\Users\\moprescu\\AppData\\Local\\Continuum\\anaconda3\\lib\\site-packages\\scipy\\stats\\_distn_infrastructure.py:879: RuntimeWarning: invalid value encountered in less\n",
      "  return (self.a < x) & (x < self.b)\n",
      "C:\\Users\\moprescu\\AppData\\Local\\Continuum\\anaconda3\\lib\\site-packages\\scipy\\stats\\_distn_infrastructure.py:1821: RuntimeWarning: invalid value encountered in less_equal\n",
      "  cond2 = cond0 & (x <= self.a)\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<table class=\"simpletable\">\n",
       "<caption>OLS Regression Results</caption>\n",
       "<tr>\n",
       "  <th>Dep. Variable:</th>            <td>y</td>        <th>  R-squared:         </th> <td>   0.000</td> \n",
       "</tr>\n",
       "<tr>\n",
       "  <th>Model:</th>                   <td>OLS</td>       <th>  Adj. R-squared:    </th> <td>   0.000</td> \n",
       "</tr>\n",
       "<tr>\n",
       "  <th>Method:</th>             <td>Least Squares</td>  <th>  F-statistic:       </th> <td>     nan</td> \n",
       "</tr>\n",
       "<tr>\n",
       "  <th>Date:</th>             <td>Tue, 21 May 2019</td> <th>  Prob (F-statistic):</th>  <td>   nan</td>  \n",
       "</tr>\n",
       "<tr>\n",
       "  <th>Time:</th>                 <td>20:00:48</td>     <th>  Log-Likelihood:    </th> <td> -6840.5</td> \n",
       "</tr>\n",
       "<tr>\n",
       "  <th>No. Observations:</th>      <td>  2991</td>      <th>  AIC:               </th> <td>1.368e+04</td>\n",
       "</tr>\n",
       "<tr>\n",
       "  <th>Df Residuals:</th>          <td>  2990</td>      <th>  BIC:               </th> <td>1.369e+04</td>\n",
       "</tr>\n",
       "<tr>\n",
       "  <th>Df Model:</th>              <td>     0</td>      <th>                     </th>     <td> </td>    \n",
       "</tr>\n",
       "<tr>\n",
       "  <th>Covariance Type:</th>      <td>nonrobust</td>    <th>                     </th>     <td> </td>    \n",
       "</tr>\n",
       "</table>\n",
       "<table class=\"simpletable\">\n",
       "<tr>\n",
       "    <td></td>       <th>coef</th>     <th>std err</th>      <th>t</th>      <th>P>|t|</th>  <th>[0.025</th>    <th>0.975]</th>  \n",
       "</tr>\n",
       "<tr>\n",
       "  <th>const</th> <td>    0.0652</td> <td>    0.044</td> <td>    1.497</td> <td> 0.135</td> <td>   -0.020</td> <td>    0.151</td>\n",
       "</tr>\n",
       "</table>\n",
       "<table class=\"simpletable\">\n",
       "<tr>\n",
       "  <th>Omnibus:</th>       <td>1875.562</td> <th>  Durbin-Watson:     </th>  <td>   1.975</td>  \n",
       "</tr>\n",
       "<tr>\n",
       "  <th>Prob(Omnibus):</th>  <td> 0.000</td>  <th>  Jarque-Bera (JB):  </th> <td>6353222.501</td>\n",
       "</tr>\n",
       "<tr>\n",
       "  <th>Skew:</th>           <td> 1.267</td>  <th>  Prob(JB):          </th>  <td>    0.00</td>  \n",
       "</tr>\n",
       "<tr>\n",
       "  <th>Kurtosis:</th>       <td>228.770</td> <th>  Cond. No.          </th>  <td>    1.00</td>  \n",
       "</tr>\n",
       "</table><br/><br/>Warnings:<br/>[1] Standard Errors assume that the covariance matrix of the errors is correctly specified."
      ],
      "text/plain": [
       "<class 'statsmodels.iolib.summary.Summary'>\n",
       "\"\"\"\n",
       "                            OLS Regression Results                            \n",
       "==============================================================================\n",
       "Dep. Variable:                      y   R-squared:                       0.000\n",
       "Model:                            OLS   Adj. R-squared:                  0.000\n",
       "Method:                 Least Squares   F-statistic:                       nan\n",
       "Date:                Tue, 21 May 2019   Prob (F-statistic):                nan\n",
       "Time:                        20:00:48   Log-Likelihood:                -6840.5\n",
       "No. Observations:                2991   AIC:                         1.368e+04\n",
       "Df Residuals:                    2990   BIC:                         1.369e+04\n",
       "Df Model:                           0                                         \n",
       "Covariance Type:            nonrobust                                         \n",
       "==============================================================================\n",
       "                 coef    std err          t      P>|t|      [0.025      0.975]\n",
       "------------------------------------------------------------------------------\n",
       "const          0.0652      0.044      1.497      0.135      -0.020       0.151\n",
       "==============================================================================\n",
       "Omnibus:                     1875.562   Durbin-Watson:                   1.975\n",
       "Prob(Omnibus):                  0.000   Jarque-Bera (JB):          6353222.501\n",
       "Skew:                           1.267   Prob(JB):                         0.00\n",
       "Kurtosis:                     228.770   Cond. No.                         1.00\n",
       "==============================================================================\n",
       "\n",
       "Warnings:\n",
       "[1] Standard Errors assume that the covariance matrix of the errors is correctly specified.\n",
       "\"\"\""
      ]
     },
     "execution_count": 26,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# To get the statsmodel summary we look at the effect_model, which is the pipeline, we then look\n",
    "# at the reg step of the pipeline which is the statsmodel wrapper and then we look\n",
    "# at the model attribute of the statsmodel wrapper and print the summary()\n",
    "const_dr_cate.effect_model.named_steps['reg'].summary()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "ATE Estimate: 0.065\n",
      "True ATE: 0.000\n"
     ]
    }
   ],
   "source": [
    "print(\"ATE Estimate: {:.3f}\".format(const_dr_effect))\n",
    "print(\"True ATE: {:.3f}\".format(np.mean(true_fn(X))))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Model prel_model_effect max std of coefs: 0.08861170536431566\n",
      "Model model_TZ_X max std of coefs: 0.1551255726963639\n",
      "Model model_T_X max std of coefs: 0.07953278250754159\n",
      "Model model_Z_X max std of coefs: 0.01439120811937396\n",
      "Model model_Y_X max std of coefs: 0.026554847406610755\n"
     ]
    }
   ],
   "source": [
    "# The property .fitted_nuisances is a dictionary of the form:\n",
    "# {'name_of_nuisance': [fitted_model_fold_1, fitted_model_fold_2, ...]}\n",
    "# then we can access all properties of each of the fitted models for each fold.\n",
    "# If for instance all nuisances have a linear form we can look at the standard deviation\n",
    "# of the coefficients of each of the nuisance model across folds to check for stability\n",
    "try:\n",
    "    [print(\"Model {} max std of coefs: {}\".format(name,\n",
    "                                                  np.max(np.std([ns.coef_ for ns in nuisance_insts], axis=0)))) \n",
    "     if hasattr(nuisance_insts[0], 'coef_') else None\n",
    "     for name, nuisance_insts in const_dr_cate.fitted_nuisances.items()]\n",
    "except:\n",
    "    print(\"Unavailable\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Model prel_model_effect mean std of predictions: 0.07430046966010621\n",
      "Model model_TZ_X mean std of predictions: 0.1247928899700226\n",
      "Model model_T_X mean std of predictions: 0.058554367145643424\n",
      "Model model_Z_X mean std of predictions: 0.005573508912835486\n",
      "Model model_Y_X mean std of predictions: 0.012996545613115458\n",
      "Model prel_model_effect max std of predictions: 0.2932805376258246\n",
      "Model model_TZ_X max std of predictions: 0.43008271132931064\n",
      "Model model_T_X max std of predictions: 0.2527778193665977\n",
      "Model model_Z_X max std of predictions: 0.020786724018445224\n",
      "Model model_Y_X max std of predictions: 0.052350216646192216\n"
     ]
    }
   ],
   "source": [
    "import scipy.stats\n",
    "\n",
    "# We can also measure the variation of the predictions of the fitted models across folds\n",
    "try:\n",
    "    # Statistic for measuring variation across folds at each prediction point\n",
    "    statistic = scipy.stats.iqr \n",
    "    #statistic = lambda x, axis: scipy.stats.variation(np.abs(x), axis=axis)\n",
    "    #statistic = np.std\n",
    "\n",
    "    [print(\"Model {} mean std of predictions: {}\".format(name,\n",
    "                                                  np.mean(statistic([ns.predict(X) for ns in nuisance_insts], axis=0)))) \n",
    "     if hasattr(nuisance_insts[0], 'predict') else\n",
    "     print(\"Model {} mean std of predictions: {}\".format(name,\n",
    "                                                  np.mean(statistic([ns.effect(X) for ns in nuisance_insts], axis=0)))) \n",
    "     for name, nuisance_insts in const_dr_cate.fitted_nuisances.items()]\n",
    "    [print(\"Model {} max std of predictions: {}\".format(name,\n",
    "                                                  np.max(statistic([ns.predict(X) for ns in nuisance_insts], axis=0)))) \n",
    "     if hasattr(nuisance_insts[0], 'predict') else\n",
    "     print(\"Model {} max std of predictions: {}\".format(name,\n",
    "                                                  np.max(statistic([ns.effect(X) for ns in nuisance_insts], axis=0)))) \n",
    "     for name, nuisance_insts in const_dr_cate.fitted_nuisances.items()]\n",
    "except:\n",
    "    print(\"Unavailable\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 647,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "std of prel_model ATE across folds: 0.05481286208267543\n"
     ]
    }
   ],
   "source": [
    "# Or the variation on the prel model fitted ATE\n",
    "# (this is almost a sub-sample based estimate of the standard deviation of the preliminary ATE)\n",
    "try:\n",
    "    # Statistic for measuring variation across folds\n",
    "    #statistic = scipy.stats.iqr \n",
    "    #statistic = lambda x, axis: scipy.stats.variation(np.abs(x), axis=axis)\n",
    "    statistic = np.std\n",
    "    print(\"std of prel_model ATE across folds: {}\".format(np.mean(statistic([ns.effect(X) \n",
    "                                                                for ns in const_dr_cate.fitted_nuisances['prel_model_effect']], \n",
    "                                                               axis=0))))\n",
    "except:\n",
    "    print(\"Unavailable\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 648,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Unavailable\n"
     ]
    }
   ],
   "source": [
    "try:\n",
    "    nuisance_diagnostic(const_dr_cate, 'model_TZ_X', 'coef', lambda ns: ns.coef_.flatten(), X_df.columns)\n",
    "    nuisance_diagnostic(const_dr_cate, 'model_TZ_X', 'predict', lambda ns: ns.predict(X), np.arange(X.shape[0]))\n",
    "    nuisance_diagnostic(const_dr_cate, 'model_T_X', 'coef', lambda ns: ns.coef_.flatten(), X_df.columns)\n",
    "    nuisance_diagnostic(const_dr_cate, 'prel_model_effect', 'effect', lambda ns: ns.effect(X), np.arange(X.shape[0]))\n",
    "except:\n",
    "    print(\"Unavailable\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# CATE via DRIV"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "metadata": {},
   "outputs": [],
   "source": [
    "from dml_iv import DMLIV\n",
    "from dr_iv import DRIV, ProjectedDRIV\n",
    "\n",
    "np.random.seed(random_seed)\n",
    "\n",
    "# We need a model for the final regression that will fit the function theta(X)\n",
    "# Now we use a linear model and a lasso.\n",
    "lasso_driv_model_effect = lambda: Pipeline([('poly', PolynomialFeatures(degree=1, include_bias=False)),\n",
    "                                      ('reg', Lasso(alpha=0.001))])\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "metadata": {},
   "outputs": [],
   "source": [
    "lasso_dr_cate = const_dr_cate.refit_final(lasso_driv_model_effect())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "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": [
    "lasso_dr_effect = lasso_dr_cate.effect(X)\n",
    "plt.hist(lasso_dr_effect, label='est')\n",
    "plt.hist(true_fn(X), alpha=.2, label='true')\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[ 0.09754573 -0.06412111 -0.109053   -0.12507385 -0.05644703  0.35411219\n",
      "  0.12833318  0.31710713  0.08266819 -0.05679276  0.03528419 -0.\n",
      " -0.15311263 -0.11785307  0.         -0.          0.01343438 -0.06260626\n",
      "  0.00990405 -0.05991237  0.06300467 -0.0351892 ]\n",
      "0.024732851578658566\n",
      "not available\n"
     ]
    }
   ],
   "source": [
    "# To get the final fitted model we can use dr_cate.effect_model. This is an instance of\n",
    "# the same model that we used as driv_model_effect\n",
    "# We can access all of its properties for any interpretability purposes\n",
    "print(lasso_dr_cate.effect_model.named_steps['reg'].coef_) # coefficients of CATE in front of X\n",
    "print(lasso_dr_cate.effect_model.named_steps['reg'].intercept_) # intercept of CATE\n",
    "\n",
    "try:\n",
    "    print(lasso_dr_cate.effect_model.named_steps['reg'].alpha_)\n",
    "    plt.plot(lasso_dr_cate.effect_model.named_steps['reg'].alphas_,\n",
    "             lasso_dr_cate.effect_model.named_steps['reg'].mse_path_)\n",
    "    plt.show()\n",
    "except:\n",
    "    print('not available')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Index(['exper', 'expersq', 'fatheduc', 'fatheduc_nan', 'motheduc',\n",
       "       'motheduc_nan', 'momdad14', 'sinmom14', 'reg661', 'reg662', 'reg663',\n",
       "       'reg664', 'reg665', 'reg666', 'reg667', 'reg668', 'reg669', 'south66',\n",
       "       'black', 'smsa', 'south', 'smsa66'],\n",
       "      dtype='object')"
      ]
     },
     "execution_count": 34,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "X_df.columns"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "ATE Estimate: 0.065\n",
      "True ATE: 0.000\n"
     ]
    }
   ],
   "source": [
    "print(\"ATE Estimate: {:.3f}\".format(np.mean(lasso_dr_effect)))\n",
    "print(\"True ATE: {:.3f}\".format(np.mean(true_fn(X))))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 46,
   "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": [
    "coef = lasso_dr_cate.effect_model.named_steps['reg'].coef_\n",
    "# We can also see how it compares to the true CATE at each target point and calculate MSE\n",
    "plt.title(\"DMLIV CATE as Function of {}\".format(X_df.columns[np.argmax(np.abs(coef))]))\n",
    "plt.scatter(X[:, np.argmax(np.abs(coef))], lasso_dr_effect, label='est')\n",
    "plt.scatter(X[:, np.argmax(np.abs(coef))], true_fn(X), label='true', alpha=.2)\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 259,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Split 0\n",
      "Split 1\n",
      "Split 2\n",
      "Split 3\n",
      "Split 4\n",
      "Split 5\n",
      "Split 6\n",
      "Split 7\n",
      "Split 8\n",
      "Split 9\n"
     ]
    }
   ],
   "source": [
    "# Learn beta(X)\n",
    "from sklearn.model_selection import StratifiedKFold\n",
    "T_pred = np.zeros(T.shape[0])\n",
    "Z_pred = np.zeros(Z.shape[0])\n",
    "TZ_pred = np.zeros(Z.shape[0])\n",
    "kfold = StratifiedKFold(shuffle=True, n_splits=N_SPLITS)\n",
    "split_i = 0\n",
    "for train_index, test_index in kfold.split(X, Z):\n",
    "    print(\"Split {0}\".format(split_i))\n",
    "    split_i += 1\n",
    "    X_train, X_test = X[train_index], X[test_index]\n",
    "    T_train, T_test = T[train_index], T[test_index]\n",
    "    Z_train, Z_test = Z[train_index], Z[test_index]\n",
    "    T_pred[test_index] = model_T_X().fit(X_train, T_train).predict(X_test)\n",
    "    Z_pred[test_index] = model_Z_X().fit(X_train, Z_train).predict(X_test)\n",
    "    TZ_pred[test_index] = model_TZ_X().fit(X_train, Z_train*T_train).predict(X_test)\n",
    "beta_X = TZ_pred - T_pred * Z_pred"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 260,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.15367614735231072"
      ]
     },
     "execution_count": 260,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.mean(beta_X)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 261,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.2731181439017822"
      ]
     },
     "execution_count": 261,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.mean(lasso_dr_effect * beta_X)/np.mean(beta_X)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Projecting CATE to a pre-chosen subset of variables in final model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 235,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[4]\n"
     ]
    }
   ],
   "source": [
    "from dml_iv import DMLIV\n",
    "from dr_iv import DRIV, ProjectedDRIV\n",
    "from utilities import SubsetWrapper\n",
    "\n",
    "np.random.seed(random_seed)\n",
    "\n",
    "# We could also fit a projection on a subset of the features by using the\n",
    "# subset wrapper from our utilities.\n",
    "\n",
    "# Example: including everything for expository purposes, but any array-like of indices would work\n",
    "#subset_names = X_df.columns.values\n",
    "#subset_names = set(['age', 'motheduc', 'motheduc_nan', 'fatheduc', 'fatheduc_nan', 'iq', 'kww'])\n",
    "subset_names = set(['motheduc'])\n",
    "#subset_names = set(['f0'])\n",
    "# list of indices of features X to use in the final model\n",
    "feature_inds = np.argwhere([(x in subset_names) for x in X_df.columns.values]).flatten() #[0] #np.arange(X.shape[1]) \n",
    "print(feature_inds)\n",
    "# Because we are projecting to a low dimensional model space, we can\n",
    "# do valid inference and we can use statsmodel linear regression to get all\n",
    "# the hypothesis testing capability\n",
    "proj_driv_model_effect = lambda: SubsetWrapper(Pipeline([('poly', PolynomialFeatures(degree=1, include_bias=True)),\n",
    "                                                      ('reg', StatsModelLinearRegression())]),\n",
    "                                          feature_inds # list of indices of features X to use in the final model\n",
    "                                         )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 236,
   "metadata": {},
   "outputs": [],
   "source": [
    "proj_dr_cate = const_dr_cate.refit_final(proj_driv_model_effect())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 237,
   "metadata": {},
   "outputs": [],
   "source": [
    "# To get the CATE at every X we call effect(X[:, feature_inds])\n",
    "proj_dr_effect = proj_dr_cate.effect(X[:, feature_inds])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 238,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<table class=\"simpletable\">\n",
       "<caption>OLS Regression Results</caption>\n",
       "<tr>\n",
       "  <th>Dep. Variable:</th>            <td>y</td>        <th>  R-squared:         </th> <td>   0.003</td> \n",
       "</tr>\n",
       "<tr>\n",
       "  <th>Model:</th>                   <td>OLS</td>       <th>  Adj. R-squared:    </th> <td>   0.002</td> \n",
       "</tr>\n",
       "<tr>\n",
       "  <th>Method:</th>             <td>Least Squares</td>  <th>  F-statistic:       </th> <td>   7.701</td> \n",
       "</tr>\n",
       "<tr>\n",
       "  <th>Date:</th>             <td>Wed, 22 May 2019</td> <th>  Prob (F-statistic):</th>  <td>0.00555</td> \n",
       "</tr>\n",
       "<tr>\n",
       "  <th>Time:</th>                 <td>02:40:41</td>     <th>  Log-Likelihood:    </th> <td> -6836.6</td> \n",
       "</tr>\n",
       "<tr>\n",
       "  <th>No. Observations:</th>      <td>  2991</td>      <th>  AIC:               </th> <td>1.368e+04</td>\n",
       "</tr>\n",
       "<tr>\n",
       "  <th>Df Residuals:</th>          <td>  2989</td>      <th>  BIC:               </th> <td>1.369e+04</td>\n",
       "</tr>\n",
       "<tr>\n",
       "  <th>Df Model:</th>              <td>     1</td>      <th>                     </th>     <td> </td>    \n",
       "</tr>\n",
       "<tr>\n",
       "  <th>Covariance Type:</th>      <td>nonrobust</td>    <th>                     </th>     <td> </td>    \n",
       "</tr>\n",
       "</table>\n",
       "<table class=\"simpletable\">\n",
       "<tr>\n",
       "      <td></td>        <th>coef</th>     <th>std err</th>      <th>t</th>      <th>P>|t|</th>  <th>[0.025</th>    <th>0.975]</th>  \n",
       "</tr>\n",
       "<tr>\n",
       "  <th>const</th>    <td>    0.0663</td> <td>    0.044</td> <td>    1.525</td> <td> 0.127</td> <td>   -0.019</td> <td>    0.152</td>\n",
       "</tr>\n",
       "<tr>\n",
       "  <th>motheduc</th> <td>   -0.1217</td> <td>    0.044</td> <td>   -2.775</td> <td> 0.006</td> <td>   -0.208</td> <td>   -0.036</td>\n",
       "</tr>\n",
       "</table>\n",
       "<table class=\"simpletable\">\n",
       "<tr>\n",
       "  <th>Omnibus:</th>       <td>1880.974</td> <th>  Durbin-Watson:     </th>  <td>   1.981</td>  \n",
       "</tr>\n",
       "<tr>\n",
       "  <th>Prob(Omnibus):</th>  <td> 0.000</td>  <th>  Jarque-Bera (JB):  </th> <td>6264370.053</td>\n",
       "</tr>\n",
       "<tr>\n",
       "  <th>Skew:</th>           <td> 1.280</td>  <th>  Prob(JB):          </th>  <td>    0.00</td>  \n",
       "</tr>\n",
       "<tr>\n",
       "  <th>Kurtosis:</th>       <td>227.186</td> <th>  Cond. No.          </th>  <td>    1.01</td>  \n",
       "</tr>\n",
       "</table><br/><br/>Warnings:<br/>[1] Standard Errors assume that the covariance matrix of the errors is correctly specified."
      ],
      "text/plain": [
       "<class 'statsmodels.iolib.summary.Summary'>\n",
       "\"\"\"\n",
       "                            OLS Regression Results                            \n",
       "==============================================================================\n",
       "Dep. Variable:                      y   R-squared:                       0.003\n",
       "Model:                            OLS   Adj. R-squared:                  0.002\n",
       "Method:                 Least Squares   F-statistic:                     7.701\n",
       "Date:                Wed, 22 May 2019   Prob (F-statistic):            0.00555\n",
       "Time:                        02:40:41   Log-Likelihood:                -6836.6\n",
       "No. Observations:                2991   AIC:                         1.368e+04\n",
       "Df Residuals:                    2989   BIC:                         1.369e+04\n",
       "Df Model:                           1                                         \n",
       "Covariance Type:            nonrobust                                         \n",
       "==============================================================================\n",
       "                 coef    std err          t      P>|t|      [0.025      0.975]\n",
       "------------------------------------------------------------------------------\n",
       "const          0.0663      0.044      1.525      0.127      -0.019       0.152\n",
       "motheduc      -0.1217      0.044     -2.775      0.006      -0.208      -0.036\n",
       "==============================================================================\n",
       "Omnibus:                     1880.974   Durbin-Watson:                   1.981\n",
       "Prob(Omnibus):                  0.000   Jarque-Bera (JB):          6264370.053\n",
       "Skew:                           1.280   Prob(JB):                         0.00\n",
       "Kurtosis:                     227.186   Cond. No.                         1.01\n",
       "==============================================================================\n",
       "\n",
       "Warnings:\n",
       "[1] Standard Errors assume that the covariance matrix of the errors is correctly specified.\n",
       "\"\"\""
      ]
     },
     "execution_count": 238,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# To get the statsmodel summary we look at the effect_model, which is\n",
    "# an instance of SubsetWrapper, we look at the model of the SubsetWrapper which is \n",
    "# and instance of the pipeline, we then look at the reg step of the pipeline which is the statsmodel wrapper and\n",
    "# call summary() of the wrapper (most prob there is a better API for this, but we can go with this for now :)\n",
    "proj_dr_cate.effect_model.named_steps['reg'].summary(alpha=.05, xname=['const']+list(X_df.columns[feature_inds]))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 239,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Estimated Params: [ 0.06634904 -0.12171362]\n",
      "True Params: [0. 0.]\n"
     ]
    }
   ],
   "source": [
    "# We can access the coefficient by looking at the coefficient attribute of the final step of the pipeline\n",
    "print(\"Estimated Params: {}\".format(proj_dr_cate.effect_model.named_steps['reg'].coef_))\n",
    "# True coefficients of projection\n",
    "print(\"True Params: {}\".format(\n",
    "        LinearRegression(fit_intercept=False).fit(PolynomialFeatures(degree=1,\n",
    "                                                                     include_bias=True).fit_transform(X[:, feature_inds]),\n",
    "                                                  true_fn(X)).coef_))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 240,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "ATE Estimate: 0.07\n",
      "True ATE: 0.00\n"
     ]
    }
   ],
   "source": [
    "print(\"ATE Estimate: {:.2f}\".format(np.mean(proj_dr_effect)))\n",
    "print(\"True ATE: {:.2f}\".format(np.mean(true_fn(X))))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 241,
   "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": [
    "coef = proj_dr_cate.effect_model.named_steps['reg'].coef_[1:]\n",
    "# We can also see how it compares to the true CATE at each target point and calculate MSE\n",
    "plt.title(\"DMLIV CATE as Function of {}\".format(X_df.columns[feature_inds][np.argmax(np.abs(coef))]))\n",
    "plt.scatter(X[:, feature_inds][:, np.argmax(np.abs(coef))], proj_dr_effect, label='est')\n",
    "plt.scatter(X[:, feature_inds][:, np.argmax(np.abs(coef))], true_fn(X), label='true', alpha=.2)\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 245,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Coverage of True Projection: 0.69\n"
     ]
    },
    {
     "data": {
      "image/png": "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+GEATpw4QfrMZ/369VitVsLDwx337d27l2PHjtGlSxcSEhKwWCyISLaOARMmTGDcuHGcOHHC0dbbb79dsDesAJTaHjMdKVOG5MOHiRk1mloL5mPJZZ5huJJ58+YxatQonnzySQAmTpzI1Vdf7TgfFhZGhw4duHDhArNmzXKUt2nThr59+xIdHc3zzz9PREQEERER7Ny50zGMDA4O5rPPPsPHxydXGaZOncqiRYuwWq2MGDHC0astXLiQ999/H19fXwIDA1mwYEGmnvrZZ5/llVdeAWxD7ltuuYW33nrLsaySkT59+nDy5El69uzpGGENGzaskO9aPlDVEvVq2bKlFpSLq37THQ2v1SOPPaZWq7XA93uKHTt2eFqEXOnSpYv++eefV5RPnDhRp06d6gGJ3Et2nw82w2ae3+NSO5TNSPB1naj85BNcXPoDsTNnelocg8EMZdOpMGwYiX/vIH7Vb4QPG4bkMXwy5M3KlSuzLZ80aZJb5SiOGMW0IyJUffUVxGIxSmnwOGYomwFLQADi709qXBzHX5hI2qV4T4tkKKUYxcyGpL17OffVVxwb/zSawS/TYHAXRjGzIahNG6o8PY5LP//Cmfff97Q4hlKIUcwcCBsyhND+/Tkz4x0uLl/uaXG8luDgYE+LwFtvveXYjvXmm286yidNmkS1atUc276WLLF5f/7+++80adKE1q1bs2/fPgDOnTvH9ddf73BIyEpKSgrjx4+nXr16REVF0aZNG5YuXQrYYhmfOXPGqc9kFDMHRISr/m8SAVFRnP73m2hamqdFMoBjr2U627dv5+OPP2b9+vX89ddfLFq0iL179zrOP/74445tX3369AFg+vTpfPXVV7z66qu8bx8RvfTSSzzzzDM5umY+//zzHD9+nO3bt7N9+3a+//57Ll686KKnNIqZK5aAAKq/+w41584xltoCcPjwYXr06EGTJk3o0aMH0dHRpKWlUadOHVSVc+fOYbFYWLVqFWDbM7lv3z7i4+MZNmwYrVu3pnnz5vzvf/8DYM6cOQwYMICbb76Z3r17Z2pr586dtGvXjrJly+Lr60uXLl345ptvcpUvfdtXQkICfn5+7N+/n6NHj9KlS5dsr09ISODjjz9mxowZlClTBoAqVapw5513FvWtyhGzXJIHflWqAKApKZz76mvK3zkAsXjn75m3bPsaPXo09957L0OHDmXWrFmMGTOGb7/9lvr167Njxw4OHjxIy5Yt+e2332jbti0xMTHUrVuXZ555hu7duzNr1izOnTtHmzZt6NmzJ2DbvrV161YqVKiQqa2oqCieffZZYmNjCQwMZMmSJbRq1cpx/p133mHevHm0atWK6dOnExYWxoQJE3jwwQcJDAzk008/5amnnuKll17K8Xn27dtHzZo1MznFuxrv/IZ5IReXr+DEpEmcnjHD06J4PWvXrmXQoEEADBkyhNWrVwO2nnHVqlWsWrWKCRMmsHr1av78809at24N2HaGTJ48mWbNmtG1a1cSExOJjo4GbBugsyolQMOGDXn66afp1asXN9xwA02bNnVs+xoxYgT79+9ny5YtVK1a1eHP26xZM9atW8eKFSs4cOAAERERqCp33XUXgwcP5uTJky5/j/IkP357xelVGF/Z/GC1WvXos8/qjmsa6PkffnRJGwXFG3xlg4KCrigLDw/X5ORkVVVNTk7WihUrqqrqr7/+qgMHDtQuXbro5cuXtV27dvrSSy/pjBkzVFW1RYsWumvXrivqmz17to4aNSpf8kyYMEHffffdK8oPHjyojRo1ylRmtVq1V69eevbsWR00aJDu3LlTly5dqs8880ym6+Lj47VChQp64cKFbNuMjIzU06dPX1FufGXdgIhw1QsvENi0KccmTCDRvufPcCUdOnRgwYIFAHz++eeObWBt27ZlzZo1WCwWAgICaNasGR9++CHXXXcdANdffz0zZsxwWEY3b96cr/bSt31FR0fz9ddfOzZnHz9+3HHNN998c0XgsLlz59K3b1/CwsIc274sFgsJCQmZritbtizDhw9nzJgxJCcnO+r+7LPPCvS+FIj8aG9xermqx0wn+cRJ3dPpOt1/cz+1pqW5tK288IYeU0S0WrVqjtf06dP14MGD2q1bN23cuLF2795dDx8+7Li+U6dOOmHCBFVV/fzzzzU0NFTT7O9jQkKCPvjggxoVFaWNGjXSvn37qmrePWanTp20YcOG2qRJE/35558d5YMHD9aoqCht3Lix3nzzzXrs2DHHufj4eO3ataujZ1+1apVGRUVpixYtdPfu3Ve0kZSUpGPHjtWrr75aGzVqpG3atNEffvhBVV3TY4rmsG5TXGnVqpW6Oj/m5a1bEX9/Aho0cGk7ebFz504aNmzoURkMOZPd5yMiG1W1VQ63ODBD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\n",
      "text/plain": [
       "<Figure size 216x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# We can also evaluate coverage and create prediction intervals using statsmodels attributes\n",
    "from statsmodels.sandbox.regression.predstd import wls_prediction_std\n",
    "res = proj_dr_cate.effect_model.named_steps['reg'].model\n",
    "predictions = res.get_prediction(PolynomialFeatures(degree=1, include_bias=True).fit_transform(X[:, feature_inds]))\n",
    "frame = predictions.summary_frame(alpha=0.05)\n",
    "pred = frame['mean']\n",
    "iv_l = frame['mean_ci_lower']\n",
    "iv_u = frame['mean_ci_upper']\n",
    "\n",
    "# This is the true CATE functions\n",
    "theta_true = true_fn(X)\n",
    "# This is the true projection of the CATE function on the subspace of linear functions of the\n",
    "# subset of the features used in the projection\n",
    "true_proj = LinearRegression().fit(X[:, feature_inds], theta_true).predict(X[:, feature_inds])\n",
    "\n",
    "# Are we covering the true projection\n",
    "covered = (true_proj <= iv_u) & (true_proj >= iv_l)\n",
    "print(\"Coverage of True Projection: {:.2f}\".format(np.mean(covered)))\n",
    "\n",
    "fig, ax = plt.subplots(figsize=(3,4))\n",
    "\n",
    "order = np.argsort(X[:, feature_inds[0]])\n",
    "ax.plot(X[order, feature_inds[0]], iv_u[order], 'C3--', label=\"Upper 95% CI\")\n",
    "ax.plot(X[order, feature_inds[0]], iv_l[order], 'C3--', label=\"Lower 95% CI\")\n",
    "ax.plot(X[order, feature_inds[0]], pred[order], 'C0--.', label=\"Prediction\")\n",
    "#plt.xlabel()\n",
    "#ax.plot(X[order, feature_inds[0]], theta_true[order], 'b-', label=\"True\", alpha=.3)\n",
    "#ax.plot(X[order, feature_inds[0]], true_proj[order], 'b-', label=\"TrueProj\", alpha=.3)\n",
    "ax.legend(loc='best')\n",
    "plt.xlabel(\"Mother's Education (scaled)\")\n",
    "plt.ylabel(\"Treatment Effect\")\n",
    "plt.savefig(\"NLSYM_momeduc_linear_projection_2.pdf\", dpi=300, bbox_inches='tight')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Random Forest Based CATE and Tree Explainer"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 246,
   "metadata": {},
   "outputs": [],
   "source": [
    "from dml_iv import DMLIV\n",
    "from dr_iv import DRIV, ProjectedDRIV\n",
    "from utilities import SubsetWrapper\n",
    "from sklearn.ensemble import RandomForestRegressor, GradientBoostingRegressor\n",
    "\n",
    "np.random.seed(123459)\n",
    "\n",
    "# We need a model for the final regression that will fit the function theta(X)\n",
    "# Now we use a linear model and a lasso.\n",
    "rf_driv_model_effect = lambda: RandomForestRegressor(n_estimators=5000, max_depth=2, min_impurity_decrease=0.01,\n",
    "                                                     min_samples_leaf=100, bootstrap=True)\n",
    "#rf_driv_model_effect = lambda: GradientBoostingRegressor(n_estimators=3, max_depth=5, min_samples_leaf=100)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 247,
   "metadata": {},
   "outputs": [],
   "source": [
    "rf_dr_cate = const_dr_cate.refit_final(rf_driv_model_effect())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 248,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\moprescu\\AppData\\Local\\Continuum\\anaconda3\\lib\\site-packages\\scipy\\stats\\stats.py:1713: FutureWarning: Using a non-tuple sequence for multidimensional indexing is deprecated; use `arr[tuple(seq)]` instead of `arr[seq]`. In the future this will be interpreted as an array index, `arr[np.array(seq)]`, which will result either in an error or a different result.\n",
      "  return np.add.reduce(sorted[indexer] * weights, axis=axis) / sumval\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAANsAAAEKCAYAAACbliB+AAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADl0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uIDIuMi4zLCBodHRwOi8vbWF0cGxvdGxpYi5vcmcvIxREBQAAIABJREFUeJztnXmcXGWZ779PVfWepbvT2ZPOAmFVSCAgioiyuDAK6kVlXC4qyh3HcUPHQZkZvd7xjtsVHRkvoMgqIqAgKlsgrANZSSAL2fd0ku4knU7vtT3zxznVqe6uU32qq+tUNXm+n0996pxT55z3qeVXz7s87/OKqmIYRuEJFdsAwzheMLEZRkCY2AwjIExshhEQJjbDCAgTm2EEhInNMALCxGYYAWFiM4yAiBTbAD80NDTo7Nmzi22GYQxi5cqVB1V1op9zR4XYZs+ezYoVK4pthmEMQkR2+j3XqpGGERAmNsMICBObYQSEic0wAsLEZhgBYWIzjIAwsRlGQJjYDCMgTGyGERCjIoLEKG3uXbqrb/vjb2ksoiWljXk2wwgIE5thBISJzTAComBiE5HfiEiziKwdcPxLIrJRRNaJyI8KVb4RLLFEkqQl/M1KIT3bHcB70w+IyLuAK4AzVPV04CcFLN8IkJue2cILm1qKbUZJUzCxqerzwOEBh78A/EBVe91zmgtVvhEsrZ1RDnfFim1GSRN0m+0k4AIRWSoiz4nIOQGXbxSApCrxpBJLJIttSkkT9DhbBKgDzgPOAe4XkbmaYXUPEbkWuBagsdHGbkqZeML5+kxs2Qnas+0B/qgOy4Ak0JDpRFW9VVUXqurCiRN9pXgwikTUFVlKdEZmghbbw8BFACJyElAOHAzYBmOEibtiM8+WnYJVI0Xkd8A7gQYR2QN8B/gN8Bt3OCAKXJ2pCmmMLqImNl8UTGyq+rceL32yUGUaxeFYm83+N7NhESRG3sTMs/nCxGbkTV8HSdI8WzZMbEbeWNe/P0xsRt5YB4k/TGxG3sTiKbEp1rnsjYnNyJtYWlutN27ezQsTm5E3sTSB9cZMbF6Y2Iy8SW+rdccSRbSktDGxGXmTPpjdY2LzxMRm5E26Z+uJm9i8MLEZedNPbNZm88TEZuRNf7GZZ/PCxGbkTXqbzTpIvDGxGXkTSyQpCwsAvSY2T0xsRt7EEkmqysKAtdmyYWIz8iaWUKrLnamR1mbzJvAkre5r3xARFZGM+UeM0UUskaSqPOXZTGxeBJqkFUBEZgKXArsGvmaMTmKJJDWu2LqtGulJ0ElaAW4EvglYePgbhGhCqbJq5JAE2mYTkcuBvar6apDlGoUlnkhSHhYiIbEIkiwElqRVRKqBG4B3+zzfkrSOAlTV7foPEQmLRf1nIUjPdgIwB3hVRHYAM4BXRGRKppMtSevoIJZQkgplkRDl4RDdUfNsXgTm2VR1DTApte8KbqGqWpLWUUyq2lgWEiLhkFUjs1DIrv/fAS8DJ4vIHhG5plBlGcWjx/VkZZEQZWGxDpIsFCNJa+r12YUq2wiOVMRIWShEWThkESRZsAgSIy963WpjJCxEQiELRM6Cic3Ii1SCn0goRCQkfYtsGIMxsRl50Se2sBAKgaX798bEZuRFXzUyJAhCImmezQsTm5EXxzxbiFBIbEHELJjYjLxIRYxEQkJInPW1jcyY2Iy8SOX5j4SFkIitZJMFE5uRF6k0CJFQyPFsJjZPTGxGXvTrjTTPlhUTm5EX0fixCJKQiHm2LJjYjLxIebZwSBCx1UezYWIz8iI9XCsUEuuNzIKJzciLaDxJWJz2Wsg8W1ZMbEZe9MaTRNwErSEREiY2T0xsRl70xhOEQyY2P5jYjLzojTn5RwBCgoktC4EmaRWRH4vIBhF5TUQeEpHaQpVvBEM0kSTiejYxz5aVoJO0LgLepKpnAJuAbxWwfCMAemPJ/tVI6430JNAkrar6pKrG3d0lOBm2jFFMbzzRrxqpaiFbXhSzzfZZ4LEilm+MAOnVyJD7bN4tM0URm4jcAMSB32Y551oRWSEiK1paWoIzzsiJ3liScKrr3z1m7bbMBC42EbkaeD/wCVXvv0BL0jo66I0nKQu51UjXs9nAdmYCS9IKICLvBf4JuFBVu4Is2ygM6W02EbcaaWLLSNBJWm8CxgKLRGS1iNxcqPKNYIjG09pszpOJzYOgk7TeVqjyjOLQG08SSVUjzbNlxSJIjLwYGBsJJjYvTGxGXmSsRlrXf0ZMbEZe9MYTRMIDqpGWzi4jJjZj2CSTSiyhaYPaznHzbJkxsRnD5lgau4Fd/5YVORMmNmPYpCdohfQOkqKZVNKY2Ixhk55/BI51kMTNs2XExGYMm/TlouCYZzOtZcbEZgyb9AStYJ5tKExsxrBJXy4K0jyb9UZmxMRmDJuB1chUb6QtG5UZX2ITkTcV2hBj9BEdWI20cbas+PVsN4vIMhH5e0vSY6To7cvzn5o8arGR2fAlNlV9O/AJYCawQkTuFZFLC2qZUfKklosKh23yqB98t9lUdTPwz7iTP4H/cNPSfbhQxhmlTV8EyYBAZEv4kxm/bbYzRORG4HXgIuADqnqqu31jAe0zSpi+NtuA3kjzbJnx69luAl4BzlTVL6rqKwCq2oTj7QbhkaS1XkQWichm97ku3zdgFI9Y4thyUZA+qG1iy4RfsV0G3Kuq3QAiEhKRagBVvdvjmjsYnKT1euBpVZ0HPO3uG6OUaLy/2KRvUNvElgm/YnsKqErbr3aPeZIpSStwBXCnu30n8EGf5RslSNQdT0uNs4VtUDsrfsVWqaodqR13u3oY5U1W1X3uPfYBk4ZxD6NE8PRsNqidEb9i6xSRs1I7InI20F0Yk/rKsCStJc6gNptlRM6K3+xaXwUeEJEmd38q8LFhlHdARKaq6j4RmQo0e52oqrcCtwIsXLjQvr0SJBpPEpLBHSQ2qJ0ZX2JT1eUicgpwMiDABlWNDaO8R4CrgR+4z38axj2MEiGWOLY2G1jeyKHIJW/kOcBs95oFIoKq3uV1spuk9Z1Ag4jsAb6DI7L73YStu4CPDNNuowTojScpjxwTm2VEzo4vsYnI3cAJwGog4R5WwFNsHklaAS7OxUCjdIklkpSnebawiS0rfj3bQuC0bAthGMcfscRAz+Y8m9gy47c3ci0wpZCGGKOPaHxgm816I7Ph17M1AOtFZBnQmzqoqpcXxCpjVBBLaD/PZh0k2fErtu8W0ghjdNI70LOFrM2WDb9d/8+JyCxgnqo+5cZFhgtrmlHqDGqzuc8WG5kZv1NsPg88CNziHpoOPFwoo4zRQTSepDwsffsiQjgkFvXvgd8Oki8C5wNHoW8iqcU1HucMHNQGp/vfPFtm/IqtV1WjqR0RieCMsxnHMdEB1UhwQrcs139m/IrtORH5NlDl5h55APhz4cwyRgMDu/4hJbYiGVTi+BXb9UALsAb4X8CjeMzQNo4fzLPlht/eyCTwK/dhGMDgcC1w8pHYoHZm/MZGbidDG01V5464RcaowemN7C+2UEhsnM2DXGIjU1TiROvXj7w5xmgillDKItLvWMTE5onfJK2H0h57VfVnOGnsjOOUe5fuorM3zvaWzn7HQ9b174nfauRZabshHE83tiAWGaOGRFL7ZmmniIRtUNsLv9XI/5e2HQd2AB8dcWuMUYOqumKzQW2/+O2NfNdIFioiXwM+h9Ppsgb4jKr2jGQZRmFJqvPlDfRs4ZBYKjsP/FYjr8v2uqr+1G+BIjId+DLOZNRuEbkfuAonqasxSkh1gkQyiM1S2WUml97Ic3AS9gB8AHge2J1HuVUiEsPJP9k0xPlGiZFaytc8m39ymTx6lqq2A4jId4EHVPVzuRaoqntF5Cc4CX+6gSdV9cmB54nItcC1AI2NjbkWYxSYPs8WzuDZrM2WEb/hWo1ANG0/ipNpK2fcxTSuAOYA04AaEfnkwPNU9VZVXaiqCydOnDicoowCkhJUKslPirCNs3ni17PdDSwTkYdw2sUfIktmrSG4BNiuqi0AIvJH4G3APcO8n1EEUoIaVI0UE5sXfnsjvy8ijwEXuIc+o6qrhlnmLuA8d7Z3N05quxXDvJdRJOJ91chMgcgmtkz4XnkUpyPjqKr+HNgjInOGU6CqLsWZ9f0KTrd/CDfNuDF6SFg1Mmf8dv1/B6dH8mTgdqAMp9p3/nAKVdXv4GRINkYpidQSv9ZB4hu/nu1DwOVAJ/StOGrhWscxcfVos1nXvyd+xRZ1syErgIjUFM4kYzSQSGQe1I7YoLYnfsV2v4jcAtS6mbaewiaSHtd49kaaZ/PEb2/kT9zcI0dx2m3/qqqLCmqZUdLEs4jN2myZGVJsIhIGnlDVSwATmAFk82whm2LjwZDVSFVNAF0iMj4Ae4xRQt8426ApNpYR2Qu/ESQ9wBoRWYTbIwmgql8uiFVGyZPNs9k4W2b8iu2v7sMwAPrS1Q2eYmMLa3iRVWwi0qiqu1T1zqAMMkYH3h0kIUtl58FQbba+xTNE5A8FtsUYRXhXI82zeTGU2NI/ScsRafTh5dki1mbzZCixqce2cZyTSCohOba0b4qQTbHxZKgOkjNF5CiOh6tyt3H3VVXHFdQ6o2TpiSWoLBu8HmYkLH0pE4z+ZBWbqtrqokZGumMJqjKJzabYeJLLfDbD6KM7mqCqfLDYysIhYglFrUdyECY2Y1h4ebbUElIxi/wfRFHEJiK1IvKgiGwQkddF5K3FsMMYPt6ezekwidmKiIPwG0Ey0vwceFxVrxSRcpyUC8Yooiua2bOlViI1sQ0mcLGJyDjgHcCnAdy1uqPZrjFKi2RS6YklqPZos4GzKqnRn2JUI+fiLBl8u4isEpFfZ5r5LSLXisgKEVnR0tISvJWGJ+29cRQyt9nC1mbzohhiiwBnAf9fVRfgzCK4fuBJlqS1dDnaHQOgqnxwxSi1OGIsbp5tIMUQ2x5gj5vSDpy0dmdlOd8oMY50uWKzNltOBC42Vd0P7BaRk91DFwPrg7bDGD5tfZ7N2my5UKzeyC8Bv3V7IrcBnymSHcYwONLt9GdlEpu12bwpithUdTVO0ldjFJLybNVWjcwJiyAxciZ7NdI6SLwwsRk509YVIxKSPi+WTlnE2mxemNiMnGnrjmX0amBttmyY2IycOdIVy9jtD9Zmy4aJzciZI91RT89mgcjemNiMnGntjFGTIXoE0j2bVSMHYmIzcuZQZ5SaCo82W8SqkV6Y2IycUFVau6JUe3i2VNJWE9tgTGxGThztiZNIKjUVHtXIVNe/jbMNwsRm5MThTidUq8a6/nPGxGbkREpsXtVI6/r3xsRm5ERryrN5dJCEQ0JITGyZMLEZOXGsGukdw14WDlm4VgZMbEZOHO5yq5Eeng2cdlssbm22gZjYjJxo7YxSEQn1dYQM5N6lu0iosq6pLWDLSp+iiU1Ewm7Cn78UywYjdw51RqmvKUcGLKiRjqUgz0wxPdtXgNeLWL4xDFo7o9RVl2c9J2xiy0ixMiLPAP4G+HUxyjeGz+GuKBPG+BCb5fofRLE828+AbwLWZTXKOGyebdgELjYReT/QrKorhzjPkrSWIIfdNls2TGyZKYZnOx+4XER2APcBF4nIPQNPsiStpUcskaS9Jz602Gz10YwUI2/kt1R1hqrOBq4CFqvqJ4O2w8idVPRI3ZCeLdS35rZxDBtnM3yTGtCuH6LNZl3/mSmq2FT1WVV9fzFtMPyTCtWyNtvwMM9m+MbElh8mNsM3T647AMCzG5uznmdiy4yJzfBNZzQOeM9lS2GD2pkxsRm+6exNUFkWIhzyjosE82xemNgM33RF41nnsaUIh8S6/jNgYjN809Wb8Ez0k044JCRNbIMwsRm+6YzGMy5aP5CIRZBkxMRm+Kaz13810sQ2GBOb4QtVpSua8Ez0k06qN1KtR7IfJjbDF53RBPGkDtntD/T1VlruyP6Y2AxftLT3AvjuIAFLZzcQE5vhix2HOgGYMESoFpjYvDCxGb7YcdAV2xApEeCY2Cx3ZH9MbIYvdhzspCISYoyPamTE2mwZMbEZvth2sJOGMRVZU9il6KtG2ko2/TCxGb7YcajTVxUSjq1k09EbL6RJo46h6wQjjIjMBO4CpuBk17pVVX8etB2Gf3rjCfa2djNv0lhf5493Z3Lfu3QXb5o+nv/acpBzZtfx6fPnFNLMkqcYni0OfF1VTwXOA74oIqcVwQ7DJ7sPd5FUfz2RcCxtQmtXlN54gkXrD3Df8t2FNHFUUIyEP/tU9RV3ux0nK/L0oO0w/LOtxemJbBhT4ev8qvIwlWUhWrtirN17lGgiyb62nkKaOCooaptNRGYDC4ClxbTDyE5qjM2v2ADqqstp7Yzyyq5WANq6Y3RF43RF43zhnpVsd4cSjieKubDGGOAPwFdV9WiG1y1Ja4mw/WAX9TXlVPmI+E9RV13OvrZudhzs7Kt+7mvr4dXdbTy2dj9PrNtfKHNLlmLl+i/DEdpvVfWPmc6xJK2lw/aDHcyeUJ3TNXXVZRztiaPAWbPqANjf1sPm5nYANuwb9P/6hqcY6ccFuA14XVV/GnT5Rm7cu3QX65tyF0YqkWt5JMTpU8cBjmfbfKADgA3720fOyFFCsdKPfwon7fhq93FZEewwfBCNJznaE2dCDu01oG/xjTkTavqEt7+tm00HHJFtae4gepwNehejN/JFVRVVPUNV57uPR4O2w/DHoU4n2t9vt3+KVG7JEyaNoSwcor6mnH1tPWxp7qCqLEw8qfxi8eYRt7eUsQgSIysHO5zErLn0RAJMGlvBVefM5NzZ9QBMGVfJuqajHOqMcvo0p1q53x0O6OiNc/+K3W/4vCUmNiMrqXlsfkO1UogIZ8yopTzi/MSmjq9k9e4jAJw2bRyRkLD3SDcAv3p+G9988DVe3HJwBC0vPUxsRla2tXQwaWwFFRH/3f6ZmDK+EnA83qz6GuY01LBhfzvJpPKHV/YA8OdXm/K2t5QxsRmeHO2JseNQJ6dM8RcTmY1Pv202377sFBZddyFV5WFOnTqOw51Rvvr71exp7WZsZYTH1+2nN54Ydhkb9h/ls3csHzI9erEwsRmevLj5IEmFk6eMy/te8yaP5dp3nMD4qjIATnWHA/7yWhNVZWGuOHMa7T1xPvCLF1m+4/Cwyrjthe0s3tDMp29fzrLtw7tHITGxGZ4s3tBMVVmYxvrcBrT9ML6qjMb6aioiYa5+6yxOnTqO711xOq1dMX78xMac79cTS/D42v1ccuokAF7bc2SkTc4bE5uRkWRSeXZjM/Mmjxkyt/9w+dR5s/j6pSfROKEGESESCnHmjFqWbT/MntaunO717MZm2nvjzKyvprIsxFOvD68qGU8k6YkNvyqbjcDnsxmjg9f2tnGwI8pFp0wakfvdu3TXoGOZMnXNn1nLU68f4E+rm/jiu070f/9lu5k4toK5DWOod4Ogh2PjI682sa2lg2U3XJLz9UNhns3IyOINzYQETvI5YXSkqK8pZ2ZdFYs3+PdMP3liI89vamHBzFrCIaGuprxv4cZciMaTvLKrleb23r4hj5HExGYM4t6lu3hwxW5m1FVT7SPBz0gzrbaKTfvbfWdUfn5zC+WREG+ZMwFwBNvaFc15kHxdU1tfCNnavW25Ge0DE1sBuXHRJr77yLqMVahSZmtLB01tPZw5Y3xRyp88rpL23rivCadr9rTx2p423jp3Qt8UoPqacuJJ5UB7bhNWV+0+wrhK589ljYmt8Gxt6eDfH32d217cntd9Yokk9yzZyR0v7eDJ9fv7/Uv3xhN0BpAMJ5FUNubgIcDJ6b9o/QHGV5Wx0A21CprJ45wB8FTQcja+/+h6qsvDXHjSsWlYqbjMXYf8d7Ic6uhla3MHZzXW0TCm3MRWaFSV/3nbMm55fhs/fGxDXgOsD6zYw6HOKLMnVPPsxhYecaMjVJVr71rJB256saArvRzpivLenz3Pe372PNfevdL3dat2H2HX4S4uPGkiZeHi/Dwmj3XiMFPTcbxYubOVJdsO866TJ1FZdizCJZUDZddh/2J7fN1+FHjzjPFMq62yamShWdd0lL1HujllyliiiSQ/fXLTsO7TE0vw86c30VhfzTVvn0tjfTX/8vBalm0/zEOr9vLcpha2tXTy9OsHRvgdODQf7eGqW5ew7WAnsydUs2j9ARat91fWgyv3UBYWFsysLYhtfqiuiDBxbAUbh/Bst724jXGVERbOrut3vLa6nJA4uS798uiafTSMKWfKuEpm1Faxr62H5hyroUNx3Ipt7d42PvzL/+Ks/7OIf3l4Lc3tPTz9ejMi8O7TpwCwM4dqSDp3v7yTA0d7efdpkwmHhI+cPYOxlWV89JaXue7+V5k2vpLa6rK8q6oDeWFzCxf8cDHn/t+n2drSwdVvnc01b5/LhJpyfvnsliGv74kl+POrTZw+bTwVZfnFQubLuMoIS7Yd8nz9psVbeGzNfubPrBsUtxkOCVPHV7HKzX8yFM9vauGlrYc4Y0YtIkLjhBoAVuzwd71fjstxtngiyTV3LqerN8GshhruXbaLP76yh8qyMAtm1jJlXCUTasrZmUM1JEV7T4xfPruFC+Y1MHfiGAAmjKng8xfMZfmOw0TCwpumjWflzlYeX7efrS0dnOCelw8vbz3Ep25bRl11GZecOonTpo1nitv2edsJE/jza/t4ZVcrZzXWed7jlue20d4Tz3pOUEwdX8WSbYdo6471hXil8/LWg4jAW0+YkPH6xgnVrNrVSiyRzFod3n6wk6/ct4qTJo3lHfOcdt+02koqy0Is236Yy948dWTeEMXLQfJeEdkoIltE5Pqgy392YwsHjvZyxfzpfPzcRr5y8TwuPnUybd0xrpjvZNVrrK9m16HOnBf0+9UL22ntivHN95zS73h5JMT5JzbwljkTqKmIMH9mLSLwp9X5R7p3RxN8+6E1NNZX85WLT+KiUyb3CQ2cHCDjq8r454fWsutQF5sOtNMd7d8e/ctrTdz41CY+tGA6J0ysydumfJk/s5Z4UnnInRGQTCpbmjto7YxytCfGip2tnDGjNqMQAWbVV9MTS2ZN6bCtpYPLb3qRaDzJ37x5at90oEgoxIKZdcOO0fSiGBmRw8B/ApcCe4DlIvKIqq4vVJntPTHae+JMq60C4L7lTrTByW40e8OYChrGVLBwVl1faNKJk8awavcRnnq9mUtPm+yrnB0HO7n5ua28adq4IXuzxlWV8bYTJvDI6r187ZJ5vnLoD0RV2dPazT8++Co7DnVyzzVvyVj1rYiE+flV8/n8XSt4x4+fASAswlmzavnpR+fTdKSbr963mln11SyYWTssW0aaabVVzKir4q4lO6mrKeeHj22gqa2HsZURZtZV0xtPcv6JDZ7Xz0pVBXe2cuaA9qeqsmr3Ef7u7pUkk8o1F8ylYWz/ybHnzKnnpsWbOdoTY1xlZkHnSjGqkecCW1R1G4CI3AdcAQxLbKpKe2+c13a30dTWTVlYGF9VxiF3hvHuw13cvWQnrV2xvu7h5ze1cOFJEwfF/EXSqhtnzKjlmY0t/Pujr1NbXUbDmAqOdsd4cv1+Xtp6iMpImHPm1HPy5LEc6Y7y+r6j/Gl1E2ER3n3aFF+2XzF/Ot988DVufm4b7z9jKgeO9nCwI0p5RGisr2FrSwd3v7yTprZuaqvKmDdpLPMmj6GxvppNB9p5aNVetrZ0EhL4yNkzsrYxm4708Nnz57DrcBdjK8vYcbCTlbtaufDHz5BUJxvWJ86b1e8zKDZvP7GB+5bv5iv3rWbS2Ao+tGA6K3YcZvvBTv723Eamu3+emRhfVcb02ioeXLmHBY21HGzvZXNzBy9sbmFLcycHO3ppGFPO5y6Y2zfUkM55c+r5D4X/XLyF6993yoj8AUnQ6x6LyJXAe1X1c+7+p4C3qOo/eF2zcOFCXbFixaDja/e2ceXNL9ETy544Zu7EGmZPqGH59sO098Y5dcpYrjq3cciu7Y37j3LXkp2kf0QhgbNn1dF0pIemI92kXqosC9FYX83lZ07vG+cZiivPnsFXf7+KR9d451BMRcd39MZpbu/tNz7XWF/NmTPGc+KksUwcm1vaAnASpy7ddojqighnN9bllBcyKA529NLaFWX2hBrKwiFUlXhSfQ1L1FaX8Y0HXqUrrco8dXwl02qrmFlXzZunj/d8z1edM5MbHl7D75bt5ssXz+O6S0/KeJ6IrFTVhX7eSzHE9hHgPQPEdq6qfmnAedcC17q7JwO5z7twaABKdb59KdsGpW1fqdg2S1V9JTYtRjVyDzAzbX8GMKiXQFVvBW7NtzARWeH3nydoStk2KG37Stk2L4pRQV8OzBOROSJSDlwFPFIEOwwjUAL3bKoaF5F/AJ4AwsBvVHVd0HYYRtAUZVDbTcoaVGLWvKuiBaSUbYPStq+UbctI4B0khnG8UjqDKobxBucNITYRqReRRSKy2X3OGNwnIom0xTweSTs+R0SWutf/3u24Ccw2EZkvIi+LyDoReU1EPpb22h0isj3N7vkjYFPWcDkRqXA/hy3u5zI77bVvucc3ish78rVlGLZdJyLr3c/paRGZlfZaxu+3ZFDVUf8AfgRc725fD/zQ47wOj+P3A1e52zcDXwjSNuAkYJ67PQ3YB9S6+3cAV46gPWFgKzAXKAdeBU4bcM7fAze721cBv3e3T3PPrwDmuPcJB2zbu4Bqd/sLKduyfb+l8nhDeDaccK873e07gQ/6vdBdL+4i4MHhXD8StqnqJlXd7G43Ac1AoVaA7AuXU9UokAqX87L5QeBi93O6ArhPVXtVdTuwxb1fYLap6jOqmopLW4IzTjsqeKOIbbKq7gNwn73yr1W6SwcvEZHUj34CcERVU3FQe4DpRbANABE5F+dffWva4e+71aYbRST3uKz+TAd2p+1ner9957ifSxvO5+Tn2kLbls41wGNp+5m+35Jh1MxnE5GngEwRvjfkcJtGVW0SkbnAYhFZA2Sag5FTF+0I2YaITAXuBq5W1VTA57eA/TgCvBX4J+B7udx3YDEZjg18v17n+Lk2H3zfX0Q+CSwELkw7POj7VdWtma4vBqNGbKrqmTVTRA6IyFRV3ef+YDMmHXSraKjqNhF5FliAs7Z3rYhE3H/xjOFjhbZNRMZzDbLwAAAEL0lEQVQBfwX+WVWXpN17n7vZKyK3A9/IxbYM+AmXS52zR0QiwHjgsM9rC20bInIJzh/Zharal+DR4/stGbG9UaqRjwBXu9tXA38aeIKI1KWqYCLSgLPc8Hp1WtbPAFdmu77AtpUDDwF3qeoDA16b6j4LTntvbZ72+AmXS7f5SmCx+zk9Alzl9lbOAeYBy/K0JyfbRGQBcAtwuao2px3P+P2OoG35U+wempF44LQnngY2u8/17vGFwK/d7bcBa3B6uNYA16RdPxfnR7MFeACoCNi2TwIxYHXaY7772mLX3rXAPcCYEbDpMmATzr/+De6x7+H8gAEq3c9hi/u5zE279gb3uo3A+wrwXQ5l21PAgbTP6ZGhvt9SeVgEiWEExBulGmkYJY+JzTACwsRmGAFhYjOMgDCxGUZAmNhGCBGZkBZxvl9E9qbt5zWLQEQ+KyL+8uMVqBwRuWfA7IMX3ONVIrLYPXaliLzTnb2wKtf3LSIfFpFThj5zdDJqIkhKHVU9BMwHEJHv4kSg/yT9HHdgWvRYKJZfPgu8ghO2VUiGKudrqvrwgGNnA6qqqff+a+AHqnr3MMr/MJAENgzj2pLHPFuBEZETRWStiNyM80OeKiLvc+evveLOG6txz/3fIrI8db44fAxHxL9PeUkR2SMi33cDbpeLyFki8qSIbBWRz6eVfb2ILHODmP91gD23uR7oMRGpzFSOj/c2DWcK0EL3mr/DEcz3ROQuLxvc459xj70qIreLyAU4A9o3uveaPQIff2lR7FH1N+ID+C7wDXf7RJx/63Pc/UnAcxybk3UD8G13OxVdIsDvcCM0gBdxI0rc/T3A593tXwCrgBpgMrDfPX4Z8Ev3XiHgcZwoixNxolXe7J73R47N5etXzoD3dA+wnWORG3e5xy8BHh5w3geHsOFMHO9VP+B99137RnxYNTIYtqrqcnf7bTiTMF9yapWU4/zIwZk39o844VINwEr6TyFJJxUzuAaIqGon0CkiSREZA7wbeB+OEAHG4ExSbcaZM7bGPb4SmO3zfWSqRmbDy4Y6nEmfhwFSz290TGzBkL4qnwCPq+qn0k8QkWrgJuAsVd0rIv+GIzovUtHuybTt1H7ELeffVPW2AeWcOOD8BIX7HXjZcB0jOzVnVGBttuB5CbhQnDlXiEiNiMwDqnCEclBExgL/I+2admBsjuU8AVyT1h6c4UbDZ2M45QzHhqdwZg/Uu8dTi3ePdPklhXm2gFHVAyJyDU5HRKoT4tuq+lcRuRMnun8nsDTtstuBX4tINz7TEKjqo243+hK3utoOfHyIy/qVo05qgnRudHtaU5w9HBtU9TUR+RHwvIjEcaqy1+C0U28Rka/jtN12+HirowaL+jeMgLBqpGEEhInNMALCxGYYAWFiM4yAMLEZRkCY2AwjIExshhEQJjbDCIj/Bimc1LiKm5ayAAAAAElFTkSuQmCC\n",
      "text/plain": [
       "<Figure size 216x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import seaborn as sns\n",
    "plt.figure(figsize=(3,4))\n",
    "rf_dr_effect = rf_dr_cate.effect(X)\n",
    "#plt.hist(rf_dr_effect, bins=40)\n",
    "sns.distplot(rf_dr_effect)\n",
    "plt.xlabel(\"Treatment Effect\")\n",
    "plt.ylabel(\"Frequency\")\n",
    "plt.savefig(\"NLSYM_hte_distribution_2.pdf\", dpi=300, bbox_inches='tight')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 270,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.8873286526245403"
      ]
     },
     "execution_count": 270,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.mean(rf_dr_effect > 0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 199,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "ATE Estimate: 0.065\n",
      "True ATE: 0.000\n"
     ]
    }
   ],
   "source": [
    "print(\"ATE Estimate: {:.3f}\".format(np.mean(rf_dr_effect)))\n",
    "print(\"True ATE: {:.3f}\".format(np.mean(true_fn(X))))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 200,
   "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": [
    "plt.title(\"DRIV CATE: MSE {:.2}\".format(np.mean((true_fn(X) - rf_dr_effect)**2)))\n",
    "plt.scatter(X[:, 0], rf_dr_effect, label='est')\n",
    "plt.scatter(X[:, 0], true_fn(X), label='true', alpha=.2)\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 250,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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j4iIiIiIiIhIDlGwR0REJMUdd9zBhg0b0l2MHnnhhRd4+OGH010MERGRrHf//ffz1ltvpbsYIj2iYI+IiIiIiIgcErfccgt79+7N2OWJ5AoFe0REREREREREcogv3QUQERHJRFu3buWpp56itraWqVOnct555+Hz+aivr+eRRx5hy5YtRKNRxo4dy3nnnUcoFALg7bff5sUXX+TAgQMUFBRwxhlnMGPGDACWL1/OkiVLqKurY9SoUZx//vmUlJS0+uwHHniAKVOmMHPmzJbn7r77bubMmcO0adN46qmnWL16NeFwmMGDB3POOedQUVHRajkbN27k4Ycf5vrrr2957o477uCCCy5gwoQJOI7DkiVLePPNN2loaGDChAmcd9555Ofn9/XmFBGRHLJr1y6eeOIJtm/fTnFxMWeeeSaHHXYYYJs+zZgxg2OPPRawx8W33nqLq666ivvuuw+wxzRjDBdccAFFRUU8/PDDnHDCCbzyyisEAoGkY2d3l3fkkUe2lLO5uZlbb72Vq666imHDhgFw4MABbr/9dq677jo8Hk+Hx3S3F154gb179/Lxj38cgP3793PHHXdw88034/F4aGhoYNGiRaxbtw5jDMcccwxz5szB41F+haSHap6IiEgbVqxYwWWXXcZXv/pV9uzZw0svvQSA4zgcffTRXHfddVx33XX4fD6efPJJABobG3nqqaf4zGc+w0033cTnPvc5RowYAcCaNWtYvHgxl1xyCd/61reoqKhg4cKFbX729OnTWbFiRcvjXbt2UV1dzeTJkwEYNWoU1157LfPmzWP69Ok8+OCDNDc3d3sdly1bxpo1a7jyyiv5+te/Tl5eHk888US3lyMiIgNHJBLhb3/7GxMnTuSb3/wmH/3oR1m4cCG7d+/u9L1XXnklAF/4whe46aabWgIzdXV1HDx4kOuvv54LL7yQxx9/vFfLi/P5fEybNi3pmLpq1SrGjRtHYWFhh8f07nr00UfxeDx85Stf4dprr2X9+vXq70fSSsEeERGRNsycOZNBgwaRn5/Paaed1nKiWFBQwOGHH47f7ycYDHLaaaexcePGlvcZY9i5cydNTU0UFxe33El84403OOWUUxg6dCgej4dTTz2V7du3s3///lafPXXq1KTX3nnnHaZNm4bPZxNyZ8yYQUFBAR6Ph9mzZ9Pc3Nylk+JUb7zxBmeccQahUAifz8ecOXN49913iUaj3V6WiIgMDFu2bKGxsZFTTjkFr9fL+PHjmTJlCitXruzVck8//XR8Ph/jxo1jypQprFq1qk/KO3369KSyrVixgunTpwOdH9O7qq6ujnXr1nHOOecQCAQoLCzkpJNO6vU2EekNNeMSERFpgzuFe9CgQdTW1gLQ1NTE008/zfvvv09DQwMA4XCYaDRKIBDg4osvZunSpTz22GOMGTOGs88+myFDhlBdXc3TTz/NP//5z5blOo5DbW1tq6ZcwWCw5cT5lFNOYeXKlZx//vktry9dupS33nqL2tpajDGEw2EOHjzY7XWsrq7m73//O8aYluc8Hg91dXVtprCLiIjU1tYSCoWSjh0lJSXU1NT0eJl5eXkEAoGWx+7jbm+NHz+epqYmtmzZQlFREdu3b2fq1KlAx8f07jS/qq6uJhqNctttt7U85ziOjqWSVgr2iIiItMF90lpdXU1xcTFgAy179uzh6quvbjlpvOeee1rmnTRpEpMmTaKpqYnnnnuOxx57jKuuuopQKMSpp57a0gdBZ4488khefPFFKioqaG5uZvz48QBUVlayZMkSLr/8coYNG4Yxhp/85CdtLsPv99PU1NTyOBqNcuDAgZbHoVCIj33sY4wdO7brG0ZERAa04uJiampqcBynJeBTXV1NWVkZ0PrYU1dX1+kyGxoaaGxsbAn4VFdXt2TG9mR5bsYYjjjiCFauXElhYSFTpkwhGAwCnR/T3ToqRygUwuv18q1vfUt99EjGUE0UERFpw2uvvUZNTQ319fUsXry4pR+AxsZGfD4feXl51NfX88ILL7S8p66ujrVr17bMEwgEWk76jj/+eF5++WV27twJ2BPbjlLUJ0+ezP79+3n++ec54ogjWk6oGxsb8Xg8FBYWEo1GefHFFwmHw20uo6ysjObmZt577z0ikQgvvfQSkUik5fXjjz+e5557rqW52IEDB1izZk3PN5qIiOS80aNH4/f7WbJkCZFIhI0bN7J27dqW4+SIESNYvXo1TU1N7N27t1W/NUVFRezbt6/Vcl944QUikQiVlZW89957HHHEEb1anlu8KZe7CRd0fExPNWLECCorK6murqahoYHFixe3vFZcXMzEiRNZtGgR4XAYx3HYu3dvj5qEifQVZfaIiIi0Yfr06fz5z3+mtraWww47jNNOOw2Ak046iYULF/LTn/6U4uJiZs2a1RIgcRyHpUuX8vDDD2OMYcSIEZx77rkATJs2jcbGRh566CGqq6sJBoNMnDix5WQ2VbxTyeXLl/PhD3+45fmJEycyadIkfvWrX+H3+5k1axaDBg1qcxl5eXmce+65PPbYYziOw8knn5yUUn7SSScBtKxnYWEhRx55ZEt6u4iISCqv18ull17KE088weLFiwmFQlx00UUMGTIEgFmzZlFVVcXPfvYzhg8fzowZM9iwYUPL++fMmcMjjzxCc3Mz559/PoWFhRQVFZGXl8dtt92G3+/nvPPO6/Hy2jqujh49mkAgQG1tbctgB9DxMT1V/Jh99913U1BQwMknn8zatWtbXr/ooot45pln+PWvf004HKa0tJRTTjmldxtbpBeM4zjpLoOIiEg66UDYNabzWUREJAf163Fy48aNPPzww1x//fX9+TGZSMdV6VdqxiUiIiIiIiIikkMU7BERERERERERySFqxiUiIgOdDoRdo3RzEZGBScfJ/qHjqvQrZfaIiIiIiIiIiOQQBXtERERERERERHKIgj0iIjLQ7Uh3AbKAtpGIyMClY0Df0zaVfqc+e0RERERERORQyraLUPWvI1lHmT0iIiIiIiIiIjlEwR4RERERERERkRyiYI+IiIiIiIhkhAULFnDssceSn5/P4MGDufjii3n//fc7fM/DDz/MWWedxeDBgzHGYIzh/vvvT5pn69atfOELX2DGjBkMHjyYgoICpk6dyi233EJdXV0/rpFIeijYIyIiIiIiIml37733cumll7J8+XJGjhxJJBJh4cKFnHzyyWzfvr3d97300ku89NJLDB06tN151q1bxz333MOaNWsYOXIk+fn5rF27lu9///vMnTu3P1ZHJK0U7BEREREREZG0amxs5IYbbgDgE5/4BBs2bGD16tUUFxezc+dOfvSjH7X73htvvJHa2loWLlzY7jyDBw/mt7/9LdXV1axatYotW7Zw4oknAvDEE0+wb9++vl0hkTRTsEdERERERETS6vXXX2f37t2ADfYAlJeXc9JJJwGwaNGidt87fPhwAoFAh8ufMWMGV199Nfn5+QDk5+dzwgknAODxePD7/b1eB5FMomCPiIiIiIiIpNXmzZtbpocNG9YyPXz4cAA2bdrUp5+3bds2HnroIQAuu+wyioqK+nT5IummYI+IiIiIiIikleM43Xq+N959992WfoBOPfVU7rrrrj7/DJF0U7BHRERERERE0mrs2LEt0zt37mw1PWbMmD75nEWLFjF79mw++OADLrroIhYtWkRhYWGfLFskkyjYIyIiIiIiIml1wgknUFZWBtDS0XJVVRWvvvoqAOeccw4AU6dOZerUqdx5553d/oy77rqLc889l+rqar7xjW/w0EMPtfThI5JrTH+kxYmIiEj31dbWOgDFxcUm3WURERHpR21ehP72t7/lmmuuAWD8+PHs2bOHmpoahgwZwr///W/Ky8sxxh4iv/e973HLLbcA8Mtf/pJf/vKXNDY2tvT9M2zYMIqLi/nEJz7B/PnzefXVV5k1axZgO2eeMWNG0mc/8sgjjBw5sr3y6rgsWceX7gKIiIiIiIiIfP7zn6ewsJBbb72V1atXk5eXx0UXXcRPfvITysvL233f3r17Wb9+fdJzO3fuZOfOnezYsQOAhoaGltfq6+tZtmxZ0vzhcLgP10Qk/ZTZIyIikiGU2SMiIgNEtl2E6rgsWUd99oiIiIiIiIiI5BAFe0REREREREREcoiCPSIiIiIiIiIiOUTBHhERERERERGRHKJgj4iIiIiIiIhIDlGwR0RERERERA6lHekuQDdkU1lFWvjSXQAREREREREZUEb09QJra2sdgOLiYg2TLoIye7KKMeYcY8xaY8z7xpgb2ng9aIz5e+z1ZcaYcbHnzzLGvGmMWRH7f8ahLrvknp7WR9frY40xdcaYbxyqMkvu6k19NMbMMMa8YoxZFdtP5h3Ksktu6cWx2m+M+WOsDq42xtx4qMsuuacL9fE0Y8xbxphmY8zFKa9dYYxZF/u74tCVWnJVT+ujMeZo13H6HWPMJYe25JKLerN/jL0eMsZsNcbceWhK3H0K9mQJY4wX+DXwH8DhwKXGmMNTZvscsM9xnEnA7cD82PO7gfMdx5kOXAH8+dCUWnJVL+tj3O3AU/1dVsl9vamPxhgf8ABwreM4RwBzgKZDVHTJMb3cN34SCMaO1ccB16QGyUW6o4v1cRPwWeCvKe8dDHwPOBGYCXzPGFPa32WW3NWb+ggcBC6PHafPAe4wxpT0b4kll/WyPsb9EHixv8rYFxTsyR4zgfcdx9ngOE4jsAD4WMo8HwP+GJt+CPiwMcY4jrPccZyq2POrgDxjTPCQlFpyVY/rI4Ax5kJgA7Y+ivRWb+rjR4B3HMf5N4DjOHscx4kconJL7ulNXXSAwlgAMh9oBGoOTbElR3VaHx3H2eg4zjtANOW9ZwP/chxnr+M4+4B/YS+yRXqqx/XRcZz3HMdZF5uuAnYCQw9NsSVH9Wb/iDHmOGA48M9DUdieUrAne4wCNrseb4k91+Y8juM0A9VAWco8nwCWO44T7qdyysDQ4/pojCkE5gHfPwTllIGhN/vHKYBjjFkUS9X91iEor+Su3tTFh4ADwDbs3cRbHcfZ298FlpzWlfrYH+8VaUuf1CljzEwgAKzvo3LJwNTj+miM8QC3Ad/sh3L1KXXQnD3a6mjM6c48xpgjsOniH+nDcsnA1Jv6+H3gdsdx6mKJPiK91Zv66ANOAU7Apok/a4x503GcZ/u2iDJA9KYuzgQiQDlQCiw2xjzjOM6Gvi2iDCBdqY/98V6RtvS6ThljRmK7o7jCcZxW2RYi3dCb+vhF4EnHcTZn+rWMgj3ZYwswxvV4NFDVzjxbYmngg4C9AMaY0cAj2PauioRLb/WmPp4IXGyM+SlQAkSNMQ2O42Rs52aS8XpTH7cALzqOsxvAGPMkcCygYI/0RG/q4qeBpx3HaQJ2GmOWAMdjm7yK9ERX6mNH752T8t4X+qRUMlD1pj5ijAkBTwDfcRzn1T4umww8vamPs4BTjTFfBIqAgDGmznGcVp08p5uacWWP14HJxpjxxpgAMBd4LGWex7AdMANcDDznOI4T68DsCeBGx3GWHLISSy7rcX10HOdUx3HGOY4zDrgD+JECPdJLPa6PwCJghjGmIHbh/SHg3UNUbsk9vamLm4AzjFUInASsOUTlltzUlfrYnkXAR4wxpbGOmT8Se06kp3pcH2PzPwL8yXGcB/uxjDJw9Lg+Oo7zGcdxxsauZb6BrZcZF+gBBXuyRqxd/5ewB9rVwD8cx1lljPmBMeaC2Gz3YvtEeR+4HohXui8Bk4DvGmPejv0NO8SrIDmkl/VRpE/1pj7GOh79Ofag/zbwluM4TxzqdZDc0Mt946+xdwhXYuvjfbGOIUV6pCv10RhzgjFmC3Y0uN8YY1bF3rsXO9LM67G/H6gPKemN3tRH4FPAacBnXdcyR6dhNSRH9LI+Zg1jbyaJiIhIutXW1joAxcXFmd0IXEREJMPoGCqSTJk9IiIiIiIiIiI5RMEeEREREREREZEcomCPiIiIiIiIiEgOUbBHRERERERERCSHKNiTY4wxn093GUTiVB8lk6g+SiZRfZRMovoomUJ1UTJJttdHBXtyT1ZXSMk5qo+SSVQfJZOoPkomUX2UTKG6KJkkq+ujgj0iIiIiIiIiIjnEOI7T7Tedc845zu7du/uhONJbu3btYujQoekuhgig+iiZJRvqYzQaBcDj0b2YXJcN9VEGDtVHyRS9qYs6hkpfS9e+8c0331zkOM45vV1Oj4I9QI/eJCIiIu2rra0FoLi4OM0lERERyS46hkoOMX2xEIU9RURERERERERyiII9IiIiIiIiIiI5RMEeEREREREREZEcomCPiIiIiIiIiEgO8aW7ACIiImKpU0kRERER6QvK7BERERERERERySEK9oiIiIiIiIiI5BAFe0REREREREREcoiCPSIiIiIiIiIiOUTBHhERERERERGRHGIcx+nJ+3r0JhER6UOOA2u2wJ5a+9hjwJjO3+PE5s0YDkQBQ+flzxbxY2vGbes+4Djg8UAkYr+vXPnOcpXHQHM0t35fIiJtqD1yFABrqgNpLkn/8BoDOESy/ErcGzsWRWLnSvHHUcexp7LY9TTGUOA3TBriwzPwjl99ssIK9oiIZKvX10G4KfH4tkfh2XfanveYCfDDz9gLv3VV8NXfH5oydua0w+GGi+308g3w7QfSW56+MG00/PSz4PXA1j1w9a/TXaK+9e1PwsnT7PQvHodFy9NbHmnfBTPh2nPs9HPvwK2Pprc8IiL9qHbr7wA48q7aNJek740r8fKrCwYDsOtAhM8t3JuVF+THlvv5/pklAKzd1cSj79Yz70MhAHbWRRhW5G31Hq+Bw4f7MAMr4NMnK6tmXCIi2aqkMPnxnOntz7tmi83EAJhcDsMG9V+5umPV5sT0jHFQnJ+2ovSZ97clgnCjyqBiaHrL09dWbUpMz56avnJI51a6vqsTp4BPp30iItloVkWwZfrdnU1ZGegBmDU2eT1mjU1kYRUE2o5vFAbMQAv09Bkd9UVEstXQUPLjo8ZBnr/teesbYfkHiceZcpG+pxZWb7HTXo+9IM12TRGbdRU3e1r6ytIflq5JTB89AQqC7c8r6bVhO2zfZ6cL8+Co8ektj4iI9Ig7SPLKpnAaS9JzHgMnjUmsx2tbwhw/OhHsKQq0HZooyVfIoqe05UREslWoMLk/GJ8XTpjc/vxLVyemT86gAESmlqs33AGRkzMksNZXdlbbpoAAfi/M7KDOSfol1cUc+X2JiAwgI4u9jC/1ARBudnhza2OaS9Qzhw/ztwRu9hyMUOD3UOC3j2vD0XbfVxxUVk9PKdgjIpKtPAYGFyc/96Ej2p//1bUQiR1Mp42B0qL+K1t3LHFdjB47AfJzoGPF19dBY7OdnjACRpamtzx9bYkCCFljiSuYOuuw3OswXEQkx812NXVaXtVIQ3MaC9ML7iZbr25qTMpWaq8b4aKAwavjVo8p2CMiks2GpvS9c9wkm23Rlpp6WFlppz3GXvhlgu37YP12O+33wQmT0luevtDQBG+uTzzOlGZzfcWdjXXcJAj60lcW6diaLbA31lnpoEI4fGx6yyMiIt3iDooszdImXJC8Hq9uDjNzTCL4E8pTE67+oK0nIpLNSguTh1MO+u3IW+1xZ2RkUgDC3dQkV/q4cQdEcmWd4rbsgU277HSeH46dmN7ySPsccrtZoYhIDhtS4OGwobY/xuaow+tbsrMJ1+QyH0ML7c3ImnAUA4SCNhRxoLH9JlyhPGX19IaCPSIi2czjaT0q12mHtz//K66LvhnjoCivX4rVbe7AyAmT289OyibL3nM1mxsNZcUdz59t1BdM9liaoUFeERHp0Emupk8rtjdR15id43C5s3pe29zIia6Ompsibb+nwG/wqQlXryjYIyKS7VKHUT9pavv9cuyptc06wHboPDNDRr+q3AVb99jp/AAckwOZInUN8M7GxONMaTbXV9x9wczUsN4ZbUUl1Nbb6aGDYHJ5essjIiJdkitNuGZXJIJWSzeFk4JY7TXVKslXoKe3dGYmIpLtUjtaLgjC9Ir258/UJh1LMrRcvbEkh5tyrd8OO/bb6aI8mKFhvTNWJGo7aI/Lld+XiEgOCwUNRwyzTbiijsOyzdnZhGvsIC+jQrZvv/omh4ONUcoKbAZ3fQdNuAa104+PdJ22oIhItvN5IVSQ/NypHTTlcgd7jp1o+1zJBO6mXCdOAW8OHKJeWQvRWMr19AoI5ae3PH1NzYOyh5rdiYhklRPHBFtGolqzq5l99e0HRjKZOzvpja1hZrqacDVE2m6WlucDv1eZPb2VA2fSIiLC8JLkx6ccDu0dI6v2wgc77HTQb0dTygTrqmBXtZ0OFcCRHWQnZYt9dYlmc16PDWLlEg3rnT2Wb4D62F3hUWUwdmh6yyMiIh1yD1W+tDJ7m3DNSmrClTzkeolG4epX2ooiIrmgIJj8OFQARR1kkVTuSkyPG9Y/ZeouB9i0O/F4XI5cjFbuTExXZMi27iubXPWotKh1hplkjsZm2LY38ThXfl8iIjlqbImvZXpzdXMaS9JzHgOjQ4n12FHbzLDCRAjCmLZvEuX5dPOoLyjYIyKSC/bUJj/esCPRIWsqrweOdQ3P/tq6/itXd+T5k/saev399JWlrxjs6GJxr2fItu4rx7uywtZVwf4D6SuLdGxICCaMsNPNEXhrQ3rLIyIiHXpza6KPnuNGBTqYM3NFHVhelViP6SMCrNzR1PJgB7epAAAgAElEQVQ43Nx2M66acHY2Wcs0CvaIiOSCePOnuOffaX/eIysSGRi7qu1FeiY4fhIEYnd/Pthhm5tlu8nl9iIboOagHRUpl7j7fnF3sC2Zxz0a3Dsb7WhxIiKSsdyjb7mbPmWb1PV4xfX4QDsdNFfXOzhOdg4zn0kU7BERyXb1YQg3JT+3tIMLb/dIPB3Nd6i5R6vKpHL1hnudXnV11pwLgr7k/p7cHWxL5snF35eISA5bub2J2liGy9BCL5PLfJ28IzO9vqWR5tj5z9ShftbuTjRJa2/ErYgDB5ty6JwpTRTsERHJdrtrkh9v3QPb9rU9rwFmuYI9mZKN4ffCTFdzpyU5EjjI1MBaXzhuUmIkt027YMue9JZH2hcqgCPH2umoY0eJExGRjBZx4DXXcOuzK7Izu6eu0WHF9sRNyalDfazZZR97PYamdkbkqs7S0ccyiYI9IiLZbmdqE64V7c87dTSUFdvp/Qfg3U39V67uOGZCopPpqr2wcWfH82eDccPsqEcAB8N2NKRcMjuHA1m5ZtZhtq8ugNWb7ShxIiKS8dxNoGaPzc5+e6Djply17fTPs79BTbl6S8EeEZFsFm5KDKcc19GFd6Y2K8rFwIF7nV5fB02R9JWlr/lShpHPlUysXJWLvy8RkQHg7W2N1MeaM5WHfIwt8aa5RD3z6qYw0Vjg5ohhflZsT5y7htppytUchYbsHIQsYyjYIyKSzVKbcO2u6Tgrxn3RlykX6B4DJ7k6j82UcvVWJm7rvnLUeCjMs9Pb98H67ektj7SvIAhHu0bfy7W6KCKSwxoj8MZWd3ZPdjbl2t/gsHqnjdx4PYZxpX4+2Gsf+zyGSDs3H6vrc+hGWRoo2CMiks1aNeFa2f68E4bDyFI7faAB/v1B/5WrO6a7RgfbXQPvbU1vefrCyNLEMNeNzfBGDgwj76ZMkewxc7LtEwvsyHup+wwREcloSzclsmCyeVSuV5KacgWSmnZVN7TflEt6TsEeEZFs1dRsgzZuS95tf353E65l79n82EyQGjjIheO6e53eXA8NTe3Pm208JrmTbwV7MpsCcyIiWe3NLY0tnRhPGOxjRFF2XsK7gz1HjwywvCoRxCoMmDbf0xiBcHMunBimR3bWFBERgT21yY+rD9g79+3JxIu+1NHBMqVcvZU0zHWONZs5fAyUFNrpvbW2w1/JTEEfHD8p8ThXfl8iIgNIfbOTFBjJ1uyenQeivL/H3vzyew3Di7xU1dimXEGfp93OmDUqV88p2CMikq1Sm2O8tKr9rJhRZXZ0KLBZJm+u79eiddmUUTAkZKerD8LKyvSWpy+UFcO00XY6ErVZVLnEHTR8ZW1uZGLlqmMnQl5s9JZNu2Dz7vSWR0REeiR1NKts9UpKkzR3E7V97QR19rXTxEs650t3AUREpIfyAjazojlqm3St3gJjhoLjAI69CHcc+zeoABYshplToOZgYkjw/hS/Q+M4dtQvJ6VMjgNBP/zjZdtB85Y9MG54/5erL8XXI+pax1AB/O0lm1ERicKwEhiW7oL2Acex61O1F556C846Cj7YkeibSDJPaRGs3wbjh9v9g74rERkAxpVm54hVHdleF6E5EmXp5kYONjqML/Vm5b2Wyv1NOI7D8xvCbK5uZlttM1DAvvoIW2siDC5IfHeO4+AAebGsH2Pabuol7TM9HLs+G+uWiEhmcBxojkC42Q6d3thkp+P/4881NMLBRju0+sGwfdzQCPWx18JNNsjj9YLHAwGvnfYaMMY+5zHg9YDPaztpLS2yf13Z98fL2RSxnQw3NXc83dQcexxJPOf1QMBnP9vvS572+2yZ/T6bDTOoIDOOLo5jy97QaLOg4tu9ITbMvfv55ogNWOUFIM8P+QEIxqbLimFwcde2dSYKN9mmgvG/fXVQEICykF2viqH2+5XM9+AS+NTJmfH7EhHpJ7WnTAHgtR3+NJekf3gNvL+nmbW7mzhxTJDS/Ow8BhscKvdH2Fcfpa7RoSTPcMRwP+NKfYws9oBj7OHKQIHfDNQgT5+stII9IiJdFY3aYEZLYKadIM3BRqgPJwID9W0EDUw8COOxQRmv+7+xfz5vIkjj94LP55qOBUk8scBOW+KZGJ0GapptD3gtwZrY4+bmWBApFpjxe1tPtzx2BW7i075Y+TJF1LHfT30HwZv4NNjAjTuIE5/Oc00H/e1v/2wSdaDmQCKws7vW1ueyYhhcZJvaDS6CQG6eQOe8f7wMnzol3aUQEelfI0vZ8OdX+eDai9Jdkn5VVRPh39saOXZUgOFF2Z3FFHUcqhscdh6IUBd2aIw4TCzzMXWoDf5ka0CrD/TJyaWacYlI7otEY4GZpliwJmW6sTkRlDnYCA2xQE29KwAQny8ehPF6kv/iWTQeTyIQEw/MDCqEIb7WQZrOxIM1qcGY2obWQRp3Vo07iOPxxAIz/uRgTTzDJj9oy5eadRPwJdYz0zVHEsGaluBNSpCtvtEGegL+lOBNAEKFMNwdxAkkhqrOVeEm2wRwd40N7uyts9ukrBiGlsDUMbY5WiYF66Tn4pl+IiK5zJgBsbsbXeIlPxBg2eZGjhzuZ2xJ9l7SezCUFRrKCu2X1hhx2FUX4aUPwjyxpp5Q0MPUYT4mlfkZPchLwKvzku7I3pohIrkt3pQmni2TlFGT0tTpQPziPpzI1gjHgjXhJhsM8MeaOPlSsmi8JjEdD3T4vPaCvzg/OWjj83YviyM1WNPYBHX1bQdmGtvJsDGmdYDG/bggAIF8V0ZNyjzZEKxpi+PYbdBedlTL800248qdcRMP5AwLJT8O+rN3e/SG49jOr/fU2IydPTV2+5XGMnamxjrJDiprJ2d5jN3XiYjkMmMwDIwRiIYWeDltXJCllY2Emx2mlPlyorlTntcwZpCPMYNsnz01YYdN+5tZsb2Jg00O40t9TB3qY1ypj7ICT06sc39SsEdE+lZ3mjrFAzT1qRfxsXkwNjjTXiaN19gAjt+VSVOcb/sT8bue76ipU2fizaAamqCxm4GacLNNwkwK1riaOwV89gK7ON/VLMqfG8Ga9sSzrNxBnLayceob7XfvDtbkB6AgaL9fd3ZOwJcbTan6SmNzIrCzu8Zm8AT9NqBTVgyHjbLZXMraGVj0GxGRXBfP7Bkgu7uSPA9zJgRZWhkm3OwwY4QfTy7t642hNN+0NOVqjjjsPBBl2eZG/rWugaDPMG2Yn4llPsaW+Mjz5dC69xEFe0TE6k5Tp/jF+cHG5H5O4oEcrzfRKbAvtamTJxHAiQdkgj4oCqY0f+qj/l5aMmvaCMi4gzWpj+PBHMdJ7psm/j8Y/++Horzk193TuRasaU9TsytQ4wrgubOt6hvtfEF/cgAnLwClhZA/OPZcLEvHl+NNqfqC49jR1eKBnT01UBeGsiLbkfJho2BIcWL4bRmYBtLVj4gMXB6DweRWwKMTRQHDnAl5vLIpzBtbmjhhdABvju7vAz7D6EEeRseyfuoaHXbURVi7q4m6RofRg7wcNtTHhFI/w4qU9QMK9ohkt9SmTuHmtoM1Sc1eUjukjY8qFE00VfJ5wJMSqIn/uZs1hfJtp63uAI3P07d3kCPRWOClqe1gTGrAJnU62kawJilw44fC/ORsm9RgzUA9WDhOIgunrQCfe9pxYoGaYCJYkx+0I2zlxTJy4k2pcvQk5JBoarZ97OyqSQR3/D6btTMkBFNGQUnhwAkyStcMhE4sRERiidwD7bQt6DOcOi7I61saebkyzOyxQQI5nuVijCGUZwjl2WNbJOqw+0CUd7Y1sfiDRoyBw4b6mFzmp6LES0FgYB4DFewRSYduN3VKaeISdmXSGJOcQdPS5Ck2BLd72O14UKagOPlxb5s6dbiuTscBmc6CNZFochCmraBNYbD18/HHfR18ygWRqCt4E07O2EoNCvp9NvsmPxjLwvFDcR4MG5TIyikIdL8/I+mc40BtfSKws7vG9vkU72tn8kiYPdV+DyIdMSjIKiK5L95nzwDc3Xm8hlljA/x7WxMvbgxz6rgABf6BE+DweA0jQ15GhmxW+MHGKNvrojz7fgPV4SjDi7wcNsTHhDIfI4u9Ayb7S8Eeke5ojiQ3a+pKU6dWWTRN0BRr6uTztm7q1BKkcTVzigc0SgrbDtL0p6jT9UBN6l9LsMbbfjAm4IOCgkR/NamvKVjTNW11aJz05xoKvikSC+AEkrNuhoQSz8dfU4bIodMUiQ17Xp0I8Hg9MHRQIrhTWqTvRLpPzbhEZCAYYH32tGIMx5T7eW93My9sCHPquCCD8gbmOUNR0MOkoAfKbNbP3voo7+1p5rUtjTRHYXKZj8lDfFSU+ggFc3cbKdgjua87TZ2S+qBxBWfi046TCM60BGni/dO4gjXuTnhLU5o59WRUp16vfwcBmTYDN02J55ojKUEaf3LAJuCDULD1c/GAjV8ZH70Sjbr6wekgiFPfaM9u8l3BG3eHxu4gTtCv7yTdHAfqGmBXLLCzq9r2vVNaZIM7k0bCSYdBYV66Syq5QM24RGQg8AzczJ4WxnZanO83vPhBmNljAwwrGth9IHq8huFFXobHtkN9k+3rZ0llmP9bXU9pgZepsayf8pAXXw5VIAV7JHN1talTSxZNU9uBmnhTJ78rOOMO2HiMqy+aWJCmINbXiDtIE/Dak+VDfZHc1WBNq3nifdxEkkd6aiuzJpTfdrAmPo8CA30v3qFxW0Gb+N/BsP0eg/5EM6r4X0kBlJcmgjr5AftdSWZqjmXtxIM7O6vtvmfoIDtE/MQRtlNl78A+IZN+MuCvfkRkQDAm1m+P9nfjB/vJ93t4ZVOY40YFGFOic8S4goBh/GAP4wdD1HHYVx9lU3WEf29vpL4JJgz2MmWIn3GlPkrys/tGib516XvNkZTAjDuLJhaUSOqHxhWkCbsyaZqaE82c/N5YkCalTxpfSn80oQI7tLA7s8bvTe8dzXhmUVJQpqnz4E08YBPfDm1l1MSDNfHRoNwBnWC8GVSa138giXdo7B5W/mBbwZywbR7n7gsnnoVTXJCYjveRo+8vuzgOHGhIBHV2VUP1ASiJZe2MHw4zp9immTohlUNhIPZYKiIDzwDus6ct5SEvcybk8dLGBsIRhylD/OkuUsbxGMPQQi9DC72An3Czzfp5fUuYResaKAoYpgz1MXGwn9GDvAS82VW5FOwRq7ujOtXHAzPu6dh8USeRRePzuZo8eRP90vhc2TJ5fijOT+7X5VA3deps2zRH2g/GuLOP2su28XpSAjUpgZuitjJrYvOkO1gliQ6NWwI24UTmjTsLJ96hsbsJVX7ABuPiHRrnB22HxsqYyh2RWNbOzmr7t7vG7jeGDrJ/E0bYILSGkpd0UTMuERkIPAO8z542DCn08JFJebywIUxDk8NRI/3KfOpAvt8wrtTHuFIfjuOwv8FhW22E93bVUxt2GFviZcoQ+3pZQeYP765gT7brblOn+DDKDSkBmoZGeyIYz5JxdxwcD9K0ZNnEgjTF+bYvkJYMGleQJpM4jr1YD6cGY9oIzrSaJzZfS7DGFaQJuh4XBSFQ2H5TKXWomnncHRrXu7Nw2gjkNDUnN5eKB3HKQjZw487OybT6L33vQEMiY2dnNeyrs80+h5XYrJ0Tp9gAX4afAMgAolvdIjIQKLOnTaE8Dx+ZkseLG8Is29zIiWMCeLWROmcMZQWGsgJ7HdcUsVk/K7c38cKGMAGvYfIQHxPLfIwt8ZGXgcPdK9iTLp01dWp0NWdy90cTz7JxN3WKDy/t85HcL40nuRlUvMlPYTAx3dInTQZnj8SDNW0GY7oSsGmy69Ze5kwgNrR0SWH78yhYkz3iHRqnZt20FcSBRLAmHsApCMLgIldQJ2izz3ThPjBFoom+dnZWw4799rnhg2xw54TJMKRY/SVJZtOtbhEZCIxarbYn3284c3KQlzeGeWmjHanLn2VNktIt4DOMKfExpgQcx6E27FBVG+G59Q1U1zuMDHmYPMTHhFI/w4oyI+tHZ6fd0d2mTknDbbuaPYWb7bL8rkCM151Rk5JF4/dBcZ69AG0J0MSyazKlqVNnkppBuYIxrZo/pWQmxZ8zpu3+aOKP8wIQKkw8H/QnXs/EbCPpvuZIIlBz0NWc6qArI+dg2P7egv7WQZxBhTBycHJQRxfokupAGHbthx3VsHM/7K2zfYENGwRjh9rgTnF+dux3ReLUjEtEBoJ4Zk+6y5GhAh7DnPFBXtvcyLPvhzl9QpB8v85nesQYSvIMJXkeGArNUYeddVHW74mwbFMjDjCpzMekMj8VJV4KAumplQPjSicaTW7SlNTsKaWpU0NqkKYJwrEATUOjq3mTK1CT2ieNu+PcgtQATYY2depMPLMmNcjVbp817mBNLLiVFISJBWLiTaHy/LERodzBHNe82ba9pGscx9YTd+bNgZQsnHhgpzligzSFwUSzqYIgDC9JTMeHHFcmlnRFJAp7XX3t7NhvsyWHubN2QnYfJJLN1K5BRAYCYzDG4NH+rl0eDLMqgryzvYl/vt/AhyfmEcrTeXNvBTyG0SUeRpfYx3XhKNtqIyypbODx1Q5DC23Wz/jBPkYWe/EcopuGmX0G252mTqnBGfd0cyTRxMnvS2TPtDR/igVf4n3PFAYTTXoyaVSn3kgN1rQVpEkN2LibQ0WiNlDjDsKkTruH73YHdYJ+e/GtO+EDh7tD49TMm6TpsP3tubNtCoL2Nzg0lGhGVRC0dUx1SHqjvtEGdHbGMnf21NjO0YeXwJgyOG6i7XtH9UxyjZpxichAENvPaW/XMWMMR48MUOA3/HNdA6dPCDKkUDfW+1Jx0ENx0MOUIX4iUYfdB6NsqYnw9rYmws0OEwb7mFTmo6LURyjYf/GFvg/2dKepU5tZNPFgjaupk9/r6o8mpbmTewSn0sJE9kw8gyaeFZLtJ++tOmLuQsDGvb3jwZqkjJqU6Zbhu9t4PRe2ofReU3Mi8+ZgSuZNy3SsKZW7z5uC2HRZMYwOQEFe4jllbUl/iEZtE6wdriZZDU02a2f4IDhugh0pK6hhSGUAUGaPiAwE6qC5W6YO9VPoNzy/IczJFQFGD8rsPJBs5fEaRhZ7GVlsr3nqmxyqaiK8tbWRRe81MCjPw+QyHxPKfJSHvPj6sAJ3/xsNzZ3MX65PHnq7oTkRpAnHRi6KN1tq6Rw4ZYSneFAmP2D7Q3Bn0QRc7x1I3v7ANikItxG4aY60bvqUmllTkGebQ7U1n4I10l0rKmH7vljTqgb733Fs8KbQFcQpzIPSokRWTkGsQ+NszYKT7LZ+O7y72XaoXJRnm2ONimXtlBRqPygDk/rsEZGBwGjo9e6qKPVREDA8tz7MrLEwtkQBn/5WGLCjeE0e4iPqOOw5GKWqNsKatU0cCDtUlPr4+pP7h1bOK9/V28/qybd5ONv3w9ghKVk0rmwanVD0zDsb4diJtvNPd1OoYKyTYV2kyKH07maYNsY2p8qPBXVUDyXTrd8OowbDR462/TeJCC1D1IiI5DITT2TU/q47hhf5OGqkw7baKONKte0OJY8xDC/yMLzIhmXCzQ4vbwwDjAbSEuyxJ9KTy3v72ZLKGJg80mZGiKSbx8C4oTZrRyRbeLDNBbUfFUlQuwYRGQg8yuzpKW9su2nbpVe+31AYSGczLlA6cH+Jb1dtW8kEqo+SjYxH9VYklc7bRGQgiPXZo8Se7otvM2279OvL76BnwR6F/fpH/M6btq1kAtVHyUbxszzVW5EE/SZEZCBQnz095lFmT8ZIf7BHv6L+YYy2rWQOo72+ZCGdrYi0pmZcIjIQGIPBqM+eHjDGYIy2XSboy2+gh5k9SpHvFy0XKdq2kgHUjEuykdF+VKQVNeMSkYFAffb0mAfdF8gUGRDs0a+oX6jZjGQSZZpJNlK9FWlNvwkRGQhiWSlKTum++OmTtl36pb8ZV1+XQmL0K5MMEu/7RPVRsonOVkRaU4+lIjIQqM+eHlPvDZkj/cEer8f+Sd/yGG1byRweY8dhVH0cuDZsh6/8Dip3wtcvhM9+uHvvf2gp/H0xPDiv92XZshtOuwneuxt83vbn035UpDWjfbmIDAAm85sinXv/Lm4+I8SJY4PpLkoST4Zuu6qaCOf9cTev/dcwfH1QuEzd/m7pb8bV25DpY6/BLx6Hqr0wdBDc+lmYOcW+Vh+G/3kInngDmiMwbTT841uJ966shB/8HVZugoIAfPGjcNWZPS9LW5ashu/+1Zbv6PFw65UwuqzteTfvhm/eD29/AOWD4QeXwimH9+xz+zKkunQN/PL/YNUmCBXAkp+0P++jr8JNDyQeRx1oaITHvwPTK+A3i2DhUti6B0qL4D9Ph2vOTsx/8g2wuyZxInncRPjzdXZ67Vb473/Y72tfHWz8XfJnX/IzWL4hcfE2ogSe++/E6/c/C7//F+w/AOOHw82XwAmT7WtX/AJeX5eYt6kZJoyARbfYx7c9Cv98G97fBl86F667IDHvc+/AXU/Z8gX9cOZR8J1PQVGeff2sm2Hr3sT84SaYcyTc++XY9l1t62nlTrtNvvAf8OnTEtv++wts/fF6YOZk+MGnYURpYlnf+Qs89SbkBeDas+H/faRvvotVm+CWv8GarVAYhEtPg6+eT4+kI8TfnXoL8H+vw+2PwfZ9MHIwfPMiOPsY+1q4CeY/bOdpaIILZsL3LgG/a7fX3r6osRm++jt4p9Ju6799A2Ydlnjfvc/YurmvDgqCcN4JcNPFiXo891Z4b6tdzughcP3H4CNHJ97/v8vgpw/D3jq7v/jZZ6Gk0L52+JeS17GhEf5zDnz/0/bxgsVw91OwqwaOn2TfO7zEvtZR/dhdY+vlsvegvhGmlNs6f8yExGel/t6GhOCkw+DJm+12nvIFCLi239Pfg7FDbVDo5r/Cy6thUAHMGAe3XJrIJvjOA/DossT7miPg98KqO5PX9YMdcPYt8NHj4I7/l/xa/DZHZ3XyUNXbzvZdbWlshnO+Dwcb4NWf2ef21sLVv4b12yEShUkj4duftN8tdF6P//icDaqt3QrnnwC3XZX8mR39RhzH7icfXAoHw3D4GPjhp2HKqMRnt7evcrvjMbjjcXjgusTx78cP2d9Xbb2tE5eeZvfDqR5aCt+4D35yOcw91T7X2X6uo+PuTX/uuK5t3g3f/Qu8tcHW5Y8eZ48r8e/xmX/b3+aWPTB1NMy/HCaX29ceXALz/mi3Rdy9X07eN3RVZ/sY6NvzHd3qFunY5t1w6o3w/j0d31DoqpNvsPuPnl4TSM9kWJ893/1XNcOLvHxpVlHS84eijH9efoD73zxIuNnhw5OCfHtOiICv7Q9dtjnMLc/UsPtAlKNG+vnBWYMoD/XB76AH/uO+XXzvwyFOigVjunr61x2ZUkccx+EXS+t4ZFU9ABcens/XTi5qt5PsivlVnwZ+DAwB/gVcVTmvfG+bM8d0L9gTmmvn702K/OJVMH8h3HmNDaTsrKZlmQA3/tme8D77Q3vx8+6mxGt7a+0F/ncvsSdoTRHYtrdvc5321sK1d8P8K+DDR9kT4S//Fh69qe35v/I7OHYi/PGr8NwK+OI98MKPoKy4+58djfZd84PCIFxyir1Q/PWTHS/zoln2L+7BJfaCe3pF7H0O/PxzNvBWuQv+8+f2BPuCmXZ+A/zhy20f0Pw+eyF8+en2gia1HAYbCLn0tNbvXb7BXuQ8+C04sgIeeAGuuQve+LkNovzpa8nzX/JTmD0t8RnjhsGNF8NfXmydwl7bAF8+D06cbE+6v/w7e3Hyo/+0rz/zw8S8jmNPAM493i6jqRmuudsu+9OnwTsb7cX9MRPsxdKUchvsGl5iL5Zue9ReMMUDRb94HDbuhKXzbf2/9FaYPMoGk3r7XXz19/ZC7u/fspkQn5gPR4yFs1yBhvY0R1JOcNLQHKY79Xb7PrjuXvjdl+y2i//+lvzEBinueRpWVMK/vg8RBz73K7jzSRt4gY73RcbYoOLnzoIv3NO6/px1FHzyZHsRu78Orr0H7n8Oro5dCN8y114g+ry2Hn/mNnj+f2ydeG+rvSC976tw5Fi44U/24vPOa+x7V/868TkHw3Dc9XDuCfbzX10LP3sEFnwDxg2H7//N7oNaAuId1I/6RjhqvN1/DgnZjJurfmW3V2Fe27+3WxbYdTWx2z3nHQ+/uLr1d1Fbb3//L6+GZbfa7+7zv7ZBUIAfX27/4r7+h7br1s1/tWWMfw9u8ced1cn4S/1dbzvad7Xnt4tgSDFsCifKV5gPP7sSxg+zz/3zbVtX37rd1p/O6vHwErsve2mlDQa517uz38gTb8A/lsDCG2BUGdz6CFz3Bxvcg473VXGVO+Gpt2DYoOTv5pJT4WsX2GDo9n1w2e02kPUfxyXeW33ABi6nxIIpLWXvZD/X0XG3s7r23b/YdX/9Nqg5CJf93Nb1K8+0wcav/R7u/6rdn/9mEfy/O20Qz+e1yzh2ot1evdXZPqavz3fUjEsk2cnz7Ll+/Ny1q8eYror/5gbq7+7+5+ChJfZGxAUzW9+ISPX7f9rjXUMTnHMs/M9l9mZsdxljN32f5kb0nGn5MynPmX4t45LKMPe9cZDffbyUYYVerntiH3cvO8DXTm59fbqvPsrXn6jmquMLGVfi5d/bm5j3VDUPXNJOokM/S90+Lad1fbTNDsX276qHVtbz/PowD146BAxc+8heRg/yMaywdSZuxfyqI4DfAOcCbwG/Be4C5nb0GZ0He0JzNwJ3A58BDgPmsq/OBkSWrbUXCf/vLLjqLDt/fSPc9Cf419v2TvmnToE/PGNPrMDeYfzaBXB8LDuj3FWR1m+zd9Veuw2K8+1zR7nuOv/+GfjQkfCJ2fZxPvbuf1/Yvs9eaLy40l707qq2J6lfvxCmfdHeefz55+y8X7jbvvZfH7UX+gA/XmjvRDY1w51PJO7C1xyEHyyA51fYHf6nTrHL9HrgHy/D316yFzcPLbUXflee2QmL4XQAACAASURBVDcjZhw7yf4tXmUfd2eZC1+Bi2eDN3bh/0XX3djJ5fCRY+DN9XDhSYnn2xvpY3K5/ftgRzvlMO2P+LR1r73DHK8DnzzFBk321iUyGeI274bX1sFtn0ss61Oxu8T/u6x1+T7uCqgUAp/5kA3KtFWOV9bCnlp7we3xQE29vbiNb6NjJtqLmPe32Yvk4aWJ93o89iKhcmdi2QtfsQe90mL7d+lp9mJjweLWv6mFr9jQ8/88CDfPtd9FvP7ddhWMHwE//Lv9PhYuhbp6GHe2DbKNH2EvWH7xuA0udFb/Lj/dBjC+eR+8u9kGXZesTgSpXloFN//FXvR9fBas2WJ/i9252O1Md+rtjv329//ho+zjs462d78374ZhJXZf8sWPwuCQff3KM+HHD8I3LrKPO9oX5QXg6lgmgdfTuo6OH5GYNh7b3K1yV2KeIyoSr3s8dp+yfb/NrHj0NTjzaJg11b7+zY/DGd+2gZ2i/OR1fOotGxw46TD7/T37jg06Th1jX//qBXDC12HTbhvc7Oi3Om44XHNO4vXLTrf16oOdNhMn9ff2+Ou23Lf8Df77QfjUyXabf/QHtj4X59tMjOsvtN/ZF+6x7zv2OhsgrW+062Swn/P3xfb7uvkSmyly39egriGxfww32WPGucfDpl3gAD960AY8i/MS30f8u5j1TfjpZ+HUI+zzP3/UBibOPNq+/sb79v3rquxv6hsX2frfZzrYd7Vl0y6bcXLzJfCtPybeVxBMZI5Eo3Z/UX3Q7meGhDqvx+eeYP+vqIRt+5LL09lvZMsem3k4brh9/eOz4d5/dbyvemgpnDEj8Rk3/xVu+iR8+8/J+9n4OoH9jXiMrafu8v30Ebs+//d68rbsqB5v2G4z//76dSjIszcT/vAMPP2WzQByOxhO1LX4srfssZ9ZELR/c6bDum329cXv2sy+E2MZNv/1Ubv/fG2dvSCMBz3b+87f32b3ke9UQlmR/Y7On9n2vJ3tY/r6fEejcYm05v5duP/31W9lIP/uRpbCV86311UNTR1vhxdWwt1Pw4Jv2vP7q++0GaM3frL7nxsL9vQka+PeN+r469sHqWt0GFbo4dun2+ySxmaH25fUsmhdAwBnT87jupOLCfgMj757kIdX1vOnTyXOIaf/YjtPXDGEZZsbeXKtfc8Dbx9k5ugAd15grxHe293MrYtr2VYb4eSKIP/zkUEE28m66YnHV9fz8SPymTLEBsyumVnEDYuquf6U1sGe59Y3MLHMx6wxQfbWR/jiSUWc9pudbNzXzITBXcsLOfsPO5l7VCGPr65nS3WEc6bk8ZXZRXznX9Usr2pi+gg/t320hEF5th48v6GBXyypY2ddhMOG+vjuGYOYMNjHjYv2s602ylce34fHY7h2ZiFnT7GtLp5a28Cdr9TS0Ozwn8cU8vmZNlsq6jj84Y0DLFxVT204yoljgtx8Rqjlsx5fXc+vXqnlYJPD5cfYLPp4Zs+3/7mf4UVevjLbbpfXt4S5YVE1z35uGADbayP85MUa3qpqJOrAf0zJ59unh3r6tbTy+Jp6rji2kJGxLKorji1k4ap6rj6hsK3ZPwM8Xjmv/CWAivlV3wVWV8yvKq6cV17b3md0NbPnUmwUaTdwNrf8DS48Ee661t5pmnurvdidMx1+8Zg9mVr6U3uidfntdgkeYy8e39loT9xOvSEWvT0GvnMJ5AdsSvboMvj5/9oL1+GD7IXEucfbZSxfb+/0Xfg/9qT+mAk2E2NUO5HHaV9sf43+69xESnk0Clf90mZEDC+xdxvvfSaxTuOH2xPGi2fbC913Ntq7rIvftXcS39loo9YrfglX3AF/ft7edS0tguvvtSfsS+bb7XHFHTBqsD0pNcbeTf/YifDOL+CuJ1vnqD3yir1Qb88zP2x//SE5960rtuy2AYefX9X2exzHnvheNif59a/8zm7HIyts05Ajxia/z9NOOQzwk4dsVs3EETDvEzA7dhH84Rlwz1Pw9gYbkPjHy3a5I0pa3yl5eCmcOMVe8LbaBnSer7fsPThsVNvzLFxi62C8idfwElv/H1xiv8flG2wa/olTEu/fugfO/K7NIPJ67EWpx9jmMTv228BefN7Dx9g7yF8+N/k3NajQfhePfcfWmzOPSq5/Bvhgu23OUzHU1r9r7oJvP2AveGsO2oPs6UfCwzd2Xv+aIvYu+IeOhIfm2eY8E4bbcu6thWt+bS/8zj4G7nvWBqgunt32NjsU9fboCfZC8Jm37cXsv96GgN/WEff74tMGezFcV28v/jvaF7VVntSyPPKKzcqpa4DBRTYY557n8jvg5VUQbraZEMeMt6+v22qb6MTnnTDcBuc2xoIubg8tgYtPbt3XRss6xf6v22qX49bebzVu5aZY08fYd5z6ezvvBBtAuGUufGaODYa+/YENRpQPtnfe/vyC/c2fc6ytYyd902YmPfNvuPFPNni1/AMbqF3xK1tnvn6f3W/OPsxmqQwJwdO3wIU/ss1qVlbajKm/vQTP/ts2yywI2szA+Lq71989Hb+FtqvaZi399Ar7261tsE312toON/7JNp9sy6iy5Cw/t472XW25+a9wwycgP5hYD7czv2uDBU0RmzE4bFDy623VY/fFf3zd3cvt7Ddy4Ynw+Gv/v737jrOiuvs4/p27fVmWsvQiCoKUgIIFFAsaCRGjiAWNxPJoxETEFkuMRhMTURIVNbG3qNixx95FsALBWLFERUDKgsDusmy5+/zxvbNz9+7dXUDymNzn8369cL1t7tyZM2fm/M7vnHEwfqsOPu+OGtx0XTVoK+nZ+dHjx9/2Ptt3+6RgT9L3//UJB0sqNni43/gR0evzP/cxeMlR0hNvNz1RQGo5/mSJl5X82wf19POpn39qrlRS7LIWHivHj/bwspH9pW8rpJf/6aFt9Z+ti/6/LvDjhYulPQd5Ge99JQ05xZnHh+zmejs7y7/xyMu8rBlnSB8ukn56uYeCbde98e9KlbrtNvV6Z1OXD/w3Gn6m5457cI6Pi3HDXa+efovriaG9pRtOioZFPzvfdfQ3q11/XZIYljnlRndwHHe1gxCnHxgFZh95wxm066ucrRsOhY/HPfz/7lcckN99oIeftksMz5k5x0NAyyulSYlAbnjcnXazgx/nHOLn53zkdZh7hR8vLpUuvNvXovE6180XH9X0drgv0Vk3rLc7CosLXT+Egfj7Znldl672+fak/aJgePjdJ/zI7Y6smLfh4XtsmX0UCttu//wi0RHRTP3z4Gx3Hg3o4cenHShNuUE6b8Kmf+9mTtD8r1U1undBhe77aYk6FWVp8Zoa1SZOBze9U6Z3v6nWgxNLFCjQlMdX68a3y3TKbq2dG5Lm+4JAOnxIoRYsrVLn1lk6dbeGQZZnPqnUjePbKTc70FH3leqxD9fr8CGNA/pzF1dp8qOrm1zva8a1047dG1+3fraqRj/sk1e/XgM65ai0Iq61lXG1LWh4Tfn5qhr175Bdn4hWlBtTz7bZ+nxVjbYt2fhBQM9/WqmbD26n2jrp0LtK9dGKav1hdBv1aZ+tEx9ZrXsWVOikEUX6YnWNznlqja4+oK127pGrO+aX6+THVuuxozto2o/bat7i5bpodBvtmhjGtXhNjSRp/tIqPXFsR32xukZH3Fuq0X3z1ad9tmbMr9BLn2/Q7Ye2V/uCmKa+vFYXv7RWl41tq09La/SHl9bq+nHtNKRLjqbPXqdlZfH6S8nUJmLypVRtvE6TH1ut4T1zdemPOyorCPTesuq0ZevvH63XH19c2+S2eehnHdIOi/ustEYDOmbXL7N/pxx9+uq6phICB0maEz748pxun/WatqRKUj9Jc5v67o3dg1dr7b2LJEnFR/TVmgpnB0gOhEzcyxdP+wzxxd+lR7vx077IF1aXP+KttnytL2SfeMfDorKzpP+5Srr6cQ+J+Wa15xrZfyfpH1e6Z/ao6b5Q6tfNr7/3pXTfWb6A+uP90uTr3RhO5+PrNu7X/eMLZ2786iAHZ7q39/LD39S+yBd6p9/iyv+2U1yxVmxww7BDsecTCAI3kt790nPCjPqBe6w/utbvK8r3CWDGy9Ix+0gxOXDw80RWVG5242DPIbtFPXubo6kgS1NmNhM0kaQ/P+KL75/uES3zml94mFFdnQMEEy+XZl3iYEVL63H+BO/bnGxn4Bx7lfT8Rf7+4gKXhfGXeNnFhdLdZ6SfZHLmHOm0A5r4nUHTDQnJAZGZs6UnLmj8nooNLq+3n9rwtfEj3Gi94G4/vvRoqWeH6PWeHVz+Vpd5GFm/rv78+g1+vU1htLyVa51BkXpM3fys98WOfZxqnFr+/vywsx86JpW/yWNd5nY83RcMsUC69pcbX/5ysnzRsXyNH++YCEq8+E/vp3AYxYljPCSlqTPq/0W5jWVJh+0mTb7BWSE52dJNJ0VBuX2GSLc+J+0+wBdptz7v5zdUe5hYc3VRskDeVqnrEv7Gz79x4K9zm4bvmXG6gymvfuBGfDhErmKD91/ye4sLPI9L8nNfl3rY1vTjo+f33d4BvWP2cTm58jHvg8rqxuuX7lgNrVvv+ULOOCi6KE53vPXpnOjlDLzvjxrl7Jt5n3l4y+CtvI5jd/Q2kqRlq93w/91PpapqB/CPGuXXDt/dQcAj93AAMawfL37A7+le4mycXfo52+OEH0XH1Sk/kV7/qGEd2SDwk/hPLHCwaY+BUQZfXo4zpNKZdoz/barm6q5UT86Vamu9fed8mL4+evGPLpdPzXO5CV9vrhwnL6M+6yQ50NnCMdKlnbNY9jzX9Wq39g70NlVXtSl0cDMWuEEz7UEPKUy3PyTvsyn7O0Dy9DypbWHU8fObO52mHx4XTdUlqeW4YoPLaoPjp9DXB6mfnznbvz/5nLFbfzfWtjvJ6zFhpMtvEEh7DXL5e+MjZ/z99QmpqjY6vnbbTnr5Ypfpjxd7OG9Oln/nCwuknh2jTMftt/H+fvKdqAHTlHR1zKZe77SkuXMg8N/kyXd8XNTEPb/ie1+5g7JfN2niFdJtz/t66rNvPMTztlN83N/4rOvpV6ZK15wovbXQHVh7JrJDF63w37c/kV671Of2sRf5OO7Xzdl2z8xzx0ZJa2eanz9Duu6Xrg/OvcOB3mG9pakzowBHuhZlTMktSq/XyAEezh0LpAVftHD9IwfMJ4z0fGQzXvYIhPnT/T0diz2dQK+Ozk6feIUDYUO29mdXrHGHwfzpztr++TUeYts2TTbBr+9w51Y63Utanqsu3bkp1cIl7jQK3/ODrdyR+W2522CbYjMze7KzXN1/vqpGJYUOdoSe+KhS5+1drI6tfL6aPKJIF76wRqeNbF2/e1O/r37Xp3s9kI4aWqgurb28Ub3z9fGK9EGEnXvk6q3JnRu/0IL11XUqzo/VL7M4L0g8H1f7wobtqIrqOrUviDX4La1zA62vjm/8dgykn+1QqE5F/k07ds9R+8KYBnV2ZtHobfP0xqIqxQLp6YWV2mubPO2+tYM5x+/USjPmV+jdpVXapWdeo2Zb+PfkEUUqzAk0sFOO+nfI0cKV1epbkq0H3qvQ+XsX1wdTTt61SD+8ZYXidXV67tNKjdomT7v0dEDs1JFFumdBRf3yU/dP8t8Fy6q1orxWZ+/Zun5i6J17pOkQlnTggAIdOKAg7WvNqUiznyqq63zd01iRpDUpz62R1OzcMRsb7FmU9P8dVbrOF0qh2rg0op8bBcu+9YSkYbpeOLFxLOaUa8mNy67t/f+/2E+a/qijtwV5vnA64yAfdbsPdOX36vu+2MnPlcbu5CEDklOkB0z2xed3SW9evMrrvd1Jvtiukxu64W9aV5mYpHSus33C4RetC3wR2LVdNOSprNIXxMvXeLnVtdIOSXPLxOOuHGMxp7aH/y9F6Z5bMuUzDNNu7DJnznEvRrr33/KcG7WPnR/1TkveNqHTDvR73vo0mgRUUqM02VA4hEaSjtjTwxxefNeTgN75knssXp3qhu3L70lHXen5nMLJjiVnvyxfIx04PP16N7cN3vnUDaGbpzQcdhB6ep57bUYOTMqiWOJhjLed4iyYz5d53oeu7RvPjVNS7N6Kvc+XFlwltU6U0/Kq6HhYVOpjKPWYisfdCxWLSWOGOWMnLH/hvjhxjPTwGy5/q8ukIy93ptDYHT3U5+jp0sDJ7s2Xmi9/knThEdKlD/oCp67OAaNJY6Tl3zZ+b7f2/74U5Y0pt6+85wbQw+f6AmbBF/6995zpbJPTxzmoMfpCH88/G+XGU6e2fl5qui5qtD7NHJfbdvO2PjcxD0+yvFyXiVuecxn+8TBnFZVvaLi8dZUuG8nP1Qdek07ye/1AOvtgB1rWVnhYVlF+433T1LEqOWB4zJUOIp6WNGl5uuPt6OkeThSLSQN6eijN5Bulj7/2NnzlfZfxsDxJ0sTp0rH7OhB27yxnqITrtqbCf0cPjerHwac4sNAq32UuL8f7PvVcslVH/w3ryNQyEj4OAl/IbtP531M2Q83VXcnKN7ic3v2rhtsp3boV5nu77X6ONHhr90Q3V46Tl5HumGnpGLniUWnBv6T5V3o/zZwjHTpNevWS9HVVeWKoYSwmXfaIh32G5bO5Y3b7bbwulz0iXTTRAauBPaMbMzT12XTluHVBIuCU9N6yymi9QotL3chJHtobjzv75qh9HNwvr3SPezhMdrse0l8meZL85d9Kh4x0Iy88vpKHbw7q5QbltU/6OFq8ytk4yfV4Ta230ZJVnvct9K+UGxVIjeuYLX298/95OAkyRxBIx/8oGi4/Yjt3uIZzvY3d0Vn3sZizFkfvIO2dyHaZPNYdknM/c9ui0Tkk8fesg30+Gry1NHAr6cOv3QaZ8bI09WiflySfi4edLl1T5/bB6B28XEn69aEOOoXLb+q7YjGvz7Jv3UESBr93bSZLNPx8jxLp6H38+PA9HJQpXedzw4+GRe/dfaA7n9/6xNmeQcxtrTPH+/tGD/V8iZ8vi24MkOxPx/rf5tqY67nyDe4gDt8TBp0qNnj/bopExGJTp0raul22zh3VWte8UaZPS2u0+9Z5Omev1upclKXlZbXqXhyrX2b3NllaURb347C/KeX7gqTn0k3d1LFVtLyCHGlFed0Wnd6pMCdQeVW8fpnl1Q4etMqLNfqeVrmByqvjDS6jyqrq1Cq38Xub0yHpN+VnB+pQmPQ4x0GMIJBWlNeqW9L2zAoCdW2dpeXl8fTbLPG3Y1Hy8hzQCgLfrWvK4982SupfVRHXivJadW0dfa5VbkxtC2INlp/uu4JAWlZWq27FWcrJ+vd1lKTbT4U5gYL0UbYySakHRLGkJodwSRsf7EkOL61U17bSP65K/87ObdwjFfZkLUmknsUCR2e7tY96iiXVHymxwJHc8L0N8qkSjwdt1TAyHvbWNRXC7fXzxs+FTjswujtTjxI3JN66TLrjRene16IJKssrPT/FK+/5ou+rFU7xPHhX/8bSdW4Qh+sZznXStZ1PCHnZ0sfXpp/ZP/m3hdsitXdz5mxnkDRl9qXRiSedTcnseXOhe+XH7dL4/Xe9Iv3l777oburOZKF0YeyNHU6W/L4PFjlgFAZh9t3emSjvfBplmEieYPQnO0XzPDVaptL3Gr/7hXTMdOmqnzeccDTZ/a95no/knuGPF0t9ukbzYPTr5pP8i+82DHCF4nXO3ilPDPfp3Fb68Cup82C/vrbcJ9rPbog+8+ZCacK0aF9cOjMqf2fd5uEYj53vTIelq/0bF61IzP0QuHEytLeUHfOJ/p4zN267dGkX3QXp/BmeD+hHQ/380/Oi99bVuQHTVG/8/0W5/eArXxAN6+PHO/bxv1nvu2HbKq9h1sYdL/qCMCer5boo3fo0ty7xeGJepibeUxuXvkq83r+H1z187xfLnQHTt2vDzz8w2xkDqcv8+egoG+uzpdKVj7rhHL6vuWN1Q7V7ELu2bzxUM93xlpPd8HeddJ10/L7SfWe6l/TOl6LtU+5x6Rqzg/SrxOTBQeI/4ecfmO2/PTp4aFZetnT2eGeIhHc4Kq/0sJ6smIc0hp9dUhp9Vyzw55OzW1asjcp057bN749kZ94WrVeqnh3cw7sxmqrjvljmOXIOvNiPq2scqPvBlOhuZqmqa32sD+7VfDlu8P1q/P0tHSMfLPI8OGE5OXJPT2D86RI3ClLrqg8WSf0Tw11nfeD9c9sLfq10rSflnvITl9tUtfHEvFaB9NoHHkrwwrt+7dsyDxl8/6vodzZVjsNJmysqozmuPlgkHbJr4+Nn574NhzeurnBQ5oTRznYsyPVvvmSmG1qSh4WMG+7/X1MeDZVoql6oS2RQ9ihx9sDMJiZv/vLm9M8nLyv5Ozb1eqclDONCpkjOoi3ITXQohI/zHCCIBQ6g9OyQdD2R5cz9ZUlZgKmZopKnCgj/vzA3Wt7Xpc4ATg5aZMVc9y371nVA+LnW+e4oTG3PpEsfWLra58TcjW2SJZbVKWk9w2zNiirVZ7de9rCzm+J17lAJrxNigdct+fsK8/yef0cdke7clKooL8oalaLridQszo38vkCBmrqbUXPGDSzUuIGFKtsQ12+fW6PLZ5XpsrFt1akoS0vXxbVdRy/zm3VxdSrKUiwI1ConpsqauvrvW1FeK0mKBUH9v9T1CRQoCKLngvqhZ43X+e2vq3TCQ03fbOmmg9unzTbp2yFbH6+s0f79vcyFK2vUoTCmksLG7dG+HXL0yPsViWZooMqaOi1aU6N+HXI2ejs2/k1q+DhREGJBoM5FWVq4sqb+tbq6Oi0tq1WX1t6msZRlJf9NXl64Xbu2ztLUMW3TDmfr1CpLn62Kvmt9dZ2+XR+vX35hTkyVNdF3lFbU1X9Xt+JsLV0bV7xOLd7y/bEP1+uC51KTbiJPHtsx7TCuviXZ+nhlrXbolthPK2rUt0N2U9v9fUnbhw96TVvSW1KepIXNrdvm3Hr9ExXm+yJs0hhXFgsXu7d4WB9p3AgPhdixjyvIW5/zp8KNdOSeHp6y7xA3JG582o2DWOAx9D1K/PnTDnS0e/ZHnuw4Fvizx17lbIb+3d0rOaJfNF421aJbNu4X7bStK5S//N0XjL+7V7rhac+x8fQ/fDH+9Dynfn61wkPLduvvRlGPEjcqrnvKJ5UF//K6/mgHqX1rz39w4d0eGlKU74vUJauSehXU+ESQXKAm7L55k4rG477LVG3cF6NVicnRmjuZ3P+a9JNdGvcaPjDbqe2P/KbxvCBfr/TF89De/s6bnvXwjBH9ogvhDdXu4ZS8HkHg3vs15d7Hu/V3MOzhNzwkZOrP/NlhvT2J7qQxTkV9+T2n1SY3bNdXebhd6jAryY2q8PfXxv3dOdk+OX+4SDriz9KlxzS8O0yyxaW+u9DlKY3i7bf2XDmvfeChIl8sl56b74noYoGHMvbv7nk8VpV5ws4hvaI7tB2+u3/XsD7OSHrhXV+sJB9TNzztO4sVF7pRdM+rLn+3vyhd/qj0yLneF2987EDSzc+6B7mqRnp/kY+v2jrf6WflWqfrtlT+JA9H2WlbB4sK8/yenJiDAL++w8Oe9hvmHvfla5R2eJP0f1Nuh/WJbtM+uJeDd28s9NDRWBAFo7q0ld75zNvt6hM2ri6SXG7DNMqaWq9LmHVy50vO0unYxkNPr3pc2icx18nCJa4nRg5wsO3hNxyU+11iTp8JI3178Tc/doN72oOeHyf5uHtroYPmBw1vuH0rqzy/Sv8eLp+/utVlJkxzbu5Yra7xHDkFudJ1v2gcgE53vFVWSd3aeR2enOssn7at3NN57ZPeRpLL16mJxuxRe6cEsBU9vv81/43Jyx012PXnyxe7vH1d6rtx1Ma9f2961mWvVb73tRTVkYN7OfA+enun8T+eGHYbC/yZo66UHnvT23ZtopE/OGni7NAVx/nfpmip7ko2qKfnxAq99Ylv3/3SH91jOfczD/Ea1se/+8ZnHLgK53VqqRzX1PpfPJGJV1XtdcrOavkYGdbb2+2QXT3M7YE5XlafLn49ta6a8ZIzX2KB66Dq2uh37XuB9MeJiSB4nXTHSw4ktSn0bc5ve94TiscCD6GorI4+e8xV0oE7R/PyNFeO+3Zzx9Blj0i/OdSNmg8WNT4H3P9aIks16bmOxS7bf3vBc/aVV3ruix/0it73j395W60u83768dBozp3nF/iY7dTGx/kVj0YB+TFDHRx/YLZ0cOLmBf/80mW3qTl7mqtjNvV6pyWbGyQC/tOkBi4bBFESz8UCd7p+sKhhJ9XiVYmOnqBxB2u6AFCg6DqnW3vXf8P7NV6nLm1dJ4Sfq9jgOiRcfqt8n0/rOyfWRN/Vs8Tn83CC/o3dBumO6Zh8rj/uas8Bud8wX9/8LGn+1KaCL00FhH91a9MdIj06+G6NLa5rE8sOhZ1gYd35wSLXs5ua1ZP4vs2JbX++qkbLymo1rFuu8nMCFeQE9bMhHDCgQNe9Wabtu+YoUKBr3lincQMLFAukgZ1y9ElpjT5aUa0+7bP119fL6n92LHC2y9drahrvqpRiFj6XanjPXL17apfGL7Rg/KACnfPUGo0bUKBORVm67o0yHfyDgrTfMaZvnv70ylq9+dUGbdMuW9e+XqbtOuaob4dNCxOkNmEbNHGTiuz+/Qt04x0r9cZXG7Rzj1zdPq9ceVmBduyeq1gglbSKafGa2mYPzXCZsUD66faFmv7aOv15vzbq3iZbpRW1mrekWqO3zdd+2+Xr0LtKNW9xlYZ0zdHVc9bV79dYIA3snKNb3ynTySOKVB2v0+3zyuu/a4euOepUFNPls9bp1N2KlBXznD3pgkoHDSzQQQM3fRjX+EEF+tvcMu3dO09BIN06t1xHDy1s6j5hd0l6vde0JXvId+O6SNJDzU3OLG1esCeuS4+S7nrV6YsbEj3S503wljlnvHTGrdLQ0135Hbab3xvunbPHuwG8y1nOwTpouHTmQX49L0e661eenWy88AAAC4hJREFUS+Kqv7sCvP4XvtCRnH3x28N9+9eKDU7fvOnk734BE8ty5sP5d7mhEY879T1e54vhtRVOYexR4vmHurWXTrnRt1897oeeU+Ci+/z+Lm2lv06KKqjrfyn9/l7f4nFdpedzCC9Ak09KUlRqt8QF2ZyPpQMujh53P86Nz78nxvvveraHB0wY6ceVVR6GcEeaoMnUmd5noy+InjtspOcSKd/gnvEvlnv/De7lWzeHv/+rldL2ScPYuh/noNi7V7lhM3VmYmLNmOe1mXF6dGF85J4OThx4sRtX3RLZCP2TLpyfmutA3V6DGudInn6LdM+s6PEVj0rXTJKO3MsT161c57J2aiKlvmcH6fU/Re8Pe4b7pFSyfbr4hH/unQ52FRd4Et2jRyV6kxJ3dlu51gGWkQM8djrcrr851FkvO5zqbIZTD3Cm2Pl3+ZiqrPJ2veBwN6JPuj4qf/fPdm158KU+fqpr3dD/fJk07Aw3xAvzpJ3OdKN+v2HOANiY8id5DPh5M1zm83Kk307wcBhJ+tspDvhMudGNwOH9tnxv8aaU2z0GerLD/7naF04lraUzDvREw5KDCL+83vuhe4mHqIWvSc3XRZI0/CxnZEge2iJJC65MZAF+4qEf5Rv8veOGS+cdGl1I/ekhZ4DFYi4vt05xQFRysPKK4zzfx+oyl91rTmy4He99zdlqbVICr9U10qRrfbwV5fsYOX9C9NnmjtV3PpWeme9y0XtS9Pr9Zztoke5469PVWV2xwAGNDdWejF2BM832GOihWU/NdaA7J8vbTfI2PS9xJ41Y4G22NCnTMxZE9eNBU6PyuXUnHxcnj/VQmr3Oc9beyWMT6fmJz553mIez9TnRgdFDd5NWl3v7d2sv3X+Wj8PTbvaQpPMPc6B2S2ip7przkTThT9LXtzpQ2TVp2GlJke/eFj5XUyOdc4fLa3aWy8d9Z7oHWmq5HF/xqDTtoejxA7Olcw72hJstHSOnHeDljjrPmTLbdHHQJAwopKurwqGqqRfhWTF/rrjA59An50p/uN9ltks733nqF4m5xVIDFrnZDnaGqfvNlWPJx9NJN3jf9+jgdU6e0Dosa6nBUkm68zTp3BkOgmXFvI2Sg3S/udPBsewsH9cXT4xem/W+dPINPu47FifubjjOr7cplB76tXTeXc6Oitc5KJX8+VTN1TFb+nqHzB5kigat5JRAQnKLcvwItyVmve9z3PXPOJt0xHZ+vVOxO2aabVEmLf+4fX3ev/ZEH6Mr17pjZuxOritGX+Cs7B37uBMnuUU5pJd0zZOewL2qxh164XrutK2zKP9wn+vtrJiDzslTJDTaBknbInXb1NQm7m5Z7Lr1+QWeiH5gj2h90gaKmqgjph8f1b2bor4jIjEtQXJHRKoj9vCUChNG+nxxxaOe/2xz6qxg8+bsqa6t059fXafPSmvcV9ItV1PHtFEskKbsWqTyqrh+crvr67Hb5WvKrkWKBVKfkmydsmuRjnmgVPnZgc7ao7XuWRBtzsOHFOrkR1dr6F++0YieubphvM/tTQVCtpS9e+dr0i41+tn9q7Shpk5j+vkOYuF3jLl1hX45okgHDSxQx1ZZunZcO537zLdaXhbXsO65+ssBbTd5fRr8JjUdS922JFtX7N9WF724Vt+sq9XATjm66eB2yk/cjeyk4UX63QtrNO3VtTp5RJH22y6//rPpmszH7eRrh2NnrtLysrhKCmPav3++xvTNV/+OOfr9vsU6/YnVWl9dp+N3aqUurbPq1/WQQQV6/csNGnXTcnUvztKhgwt0y9vlXnZWoJsObq+LXlijPW9criDw3DxNzduzOSbuUKiv19Rq/9s9Z9jhgws1cYdCPf+p503sNW1JmaT9vjyn26wvz+n2fq9pS34hB31KJD0v6X9a+o6gLv0EQE0rPmKcXp36SP342Jbc/JzvlPTkhZv2Pf8t7nrFPZjP/O67L+uqx93jGqZjAi3ZkuUv1Y3PuMe/pImelf0vcmPnmH22/HcDm+vB193I3pg7IAH/X1wys/Hk88B/m8FTpKsnSXsnhpae8Fepd5eobN/+os8Bj53nx4+/7SDK0kRm5+XHef45yZnKZ//Nc6KdOd4BmyGnSKUzooBE8nVOeDeu215w5m2HYnfUXXiE33v3K1En0OSxHnIbrmtlled6fH6B73w4cZQngP8wcZfJRSudSTjnI7eSDxvZ/Dw56a792vxUmjfdHUw3PeuAU1WNs5Cra50l+dvD3Wky6Zrou9Nt1y3hkpmeAzLZrw/xvlq00ndWe/Oy6CYMf33CN52orPZUDdOPd6fjZqijvtssC5ZWqbQirn360A79vj37SaUmPbx62JfndJv/XZe1ecGeWZc0Hez5ZrV7nXfp67Gih07zsIDJY7/ruv5nuutl6faXpGd//92XRbAHm2pLlr9UNzztbImmgj1jf+9JAQn24D/Jg3M8LIdgDxCZ+oD0m8O+77UAgH8/6rvNsmBplVZWxPVDgj3fu2c/Wa8THtoywZ7NGcbVvKoaD4v5coXTmg/ZzbfPBQAAAAAAwL/dlg/2bNXRaXn/X0wc5X/A9+H7LH+ZOjQTAADg+3TazdJ9sxo/f/ge0V1TAaAFWz7YAwAAAADYPFf+nKAOgO8s1vJbAAAAAAAA8N+CYA8AAAAAAEAG2ZxhXAvVqc0WXxFI2nlbKZeRdfgPMbSPlJ/7fa8FsGn695DaF33fawEAAPBfo1OrLBXlkgfyn2CbdtmStGxLLGvTb71um/UhAAAAAAAANCnYEgshfAcAAAAAAJBBCPYAAAAAAABkEII9AAAAAAAAGYRgDwAAAAAAQAYh2AMAAAAAAJBBCPYAAAAAAABkEII9AAAAAAAAGYRgDwAAAAAAQAYh2AMAAAAAAJBBCPYAAAAAAABkEII9AAAAAAAAGYRgDwAAAAAAQAYh2AMAAAAAAJBBCPYAAAAAAABkEII9AAAAAAAAGYRgDwAAAAAAQAYh2AMAAAAAAJBBCPYAAAAAAABkEII9AAAAAAAAGYRgDwAAAAAAQAYh2AMAAAAAAJBBCPYAAAAAAABkEII9AAAAAAAAGYRgDwAAAAAAQAYh2AMAAAAAAJBBCPYAAAAAAABkEII9AAAAAAAAGYRgDwAAAAAAQAYh2AMAAAAAAJBBCPYAAAAAAABkEII9AAAAAAAAGYRgDwAAAAAAQAYh2AMAAAAAAJBBCPYAAAAAAABkEII9AAAAAAAAGYRgDwAAAAAAQAYh2AMAAAAAAJBBCPYAAAAAAABkEII9AAAAAAAAGYRgDwAAAAAAQAYh2AMAAAAAAJBBCPYAAAAAAABkEII9AAAAAAAAGYRgDwAAAAAAQAYh2AMAAAAAAJBBCPYAAAAAAABkEII9AAAAAAAAGYRgDwAAAAAAQAYh2AMAAAAAAJBBCPYAAAAAAABkEII9AAAAAAAAGYRgDwAAAAAAQAYh2AMAAAAAAJBBCPYAAAAAAABkEII9AAAAAAAAGYRgDwAAAAAAQAYh2AMAAAAAAJBBCPYAAAAAAABkEII9AAAAAAAAGYRgDwAAAAAAQAYh2AMAAAAAAJBBCPYAAAAAAABkEII9AAAAAAAAGYRgDwAAAAAAQAYh2AMAAAAAAJBBCPYAAAAAAABkEII9AAAAAAAAGYRgDwAAAAAAQAYh2AMAAAAAAJBBCPYAAAAAAABkEII9AAAAAAAAGYRgDwAAAAAAQAYh2AMAAAAAAJBBCPYAAAAAAABkEII9AAAAAAAAGYRgDwAAAAAAQAYh2AMAAAAAAJBBCPYAAAAAAABkkOzN/FywRdcCAAAAAAAAWwSZPQAAAAAAABmEYA8AAAAAAEAGIdgDAAAAAACQQQj2AAAAAAAAZBCCPQAAAAAAABmEYA8AAAAAAEAGIdgDAAAAAACQQQj2AAAAAAAAZBCCPQAAAAAAABmEYA8AAAAAAEAG+V/MnJGu9gZOUQAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 1440x216 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import shap\n",
    "import pandas as pd\n",
    "\n",
    "Xdf = pd.DataFrame(X, columns=X_df.columns)\n",
    "# explain the model's predictions using SHAP values\n",
    "explainer = shap.TreeExplainer(rf_dr_cate.effect_model)\n",
    "shap_values = explainer.shap_values(Xdf)\n",
    "\n",
    "# visualize the first prediction's explanation (use matplotlib=True to avoid Javascript)\n",
    "shap.force_plot(explainer.expected_value, shap_values[0,:], Xdf.iloc[0,:], matplotlib=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 256,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 288x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure(figsize=(4,4))\n",
    "shap.summary_plot(shap_values, Xdf, plot_type=\"violin\", max_display=10, show=False, auto_size_plot=False)\n",
    "#plt.savefig(\"NLSYM_shap_summary_violin_2.pdf\", dpi=300, bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 227,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 360x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure(figsize=(5,4))\n",
    "shap.summary_plot(shap_values, Xdf, plot_type='bar', max_display=10, show=False, auto_size_plot=False)\n",
    "plt.xlabel(\"mean(|SHAP value|)\\n average impact on model output magnitude\")\n",
    "plt.savefig(\"NLSYM_shap_summary_bar.pdf\", dpi=300, bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 257,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<function shap.plots.summary.summary_plot(shap_values, features=None, feature_names=None, max_display=None, plot_type='dot', color=None, axis_color='#333333', title=None, alpha=1, show=True, sort=True, color_bar=True, auto_size_plot=True, layered_violin_max_num_bins=20, class_names=None)>"
      ]
     },
     "execution_count": 257,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "shap.summary_plot"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 262,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.23655058403052018"
      ]
     },
     "execution_count": 262,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.mean(beta_X * rf_dr_effect) / np.mean(beta_X)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 266,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(0.15367614735231072,\n",
       " (array([ 11.,  54., 163., 304., 495., 581., 714., 522., 131.,  16.]),\n",
       "  array([-2.96649586, -2.41141329, -1.85633071, -1.30124814, -0.74616556,\n",
       "         -0.19108299,  0.36399959,  0.91908216,  1.47416474,  2.02924731,\n",
       "          2.58432989]),\n",
       "  <a list of 10 Patch objects>))"
      ]
     },
     "execution_count": 266,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "np.mean(beta_X), plt.hist(beta_X)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 267,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "61.59247780192203"
      ]
     },
     "execution_count": 267,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "0.134*np.sum(beta_X)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 268,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "400.79400000000004"
      ]
     },
     "execution_count": 268,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "0.134*len(X)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.7.1"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
