{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import warnings\n",
    "warnings.filterwarnings('ignore')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "import numpy as np\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.preprocessing import PolynomialFeatures, StandardScaler, RobustScaler, QuantileTransformer\n",
    "from sklearn.pipeline import Pipeline\n",
    "import scipy.special\n",
    "from dml_iv import DMLIV\n",
    "from dr_iv import DRIV, ProjectedDRIV\n",
    "from dml_ate_iv import DMLATEIV"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Data Generation"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "- Used for generating data that looks similar in structure to the data used for the a/b test at W. Useful for testing the input format.\n",
    "- Input rows are not necessarily internally consistent (e.g. non-0 clicks but 0 visits is possible).\n",
    "- Columns names will be the same (or similar), but the values are generated from a fixed distribution that depends on the data type (e.g. integer, counts, floating point). \n",
    "- Also removed some columns that are repetitive (e.g. only include days_visited some, rather than all the different business units)."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 98,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import pandas as pd\n",
    "import locale\n",
    "\n",
    "n = 1000000\n",
    "##100000  # Generated dataset size\n",
    "np.random.seed(123)\n",
    "\n",
    "X_colnames = {\n",
    "    'days_visited_as_pre': 'day_count_pre',  # How many days did they visit W attractions pages in the pre-period\n",
    "    'days_visited_free_pre': 'day_count_pre',  # How many days did they visit W through free channels (e.g. domain direct) in the pre-period\n",
    "    'days_visited_fs_pre': 'day_count_pre',  # How many days did they visit W fs pages in the pre-period    \n",
    "    'days_visited_hs_pre': 'day_count_pre',  # How many days did they visit W hotels pages in the pre-period\n",
    "    'days_visited_rs_pre': 'day_count_pre',  # How many days did they visit W restaurant pages in the pre-period\n",
    "    'days_visited_vrs_pre': 'day_count_pre',  # How many days did they visit W vrs pages in the pre-period\n",
    "    'first_visit_days': 'day_count_post',   # How many days into the experiment did they first visit\n",
    "    'is_existing_member': 'binary', #Binary indicator of whether they are existing member\n",
    "    'last_visit_days_pre': 'day_count_pre',  # How many days before the experiment did they last visit (if at all). 0 means they did not visit, 1 means they visited the day before the experiment etc.\n",
    "    'locale': 'locale',  # User's locale\n",
    "    'meta_clicks_pre': 'count',  # Meta clicks in the pre-period\n",
    "    'meta_revenue_in_dollars_pre': 'revenue',  # Meta Revenue in the pre-period\n",
    "    'no_visit_in_pre': 'binary',  # Binary indicator of whether they visited in the pre-period or not (if this is 1, then all pre-period values will be 0)\n",
    "    'os_type': 'os',  # User's operating system\n",
    "    'rio_revenue_in_dollars_pre': 'revenue',  # Rio Revenue in the pre-period\n",
    "    'sherpa_revenue_in_dollars_pre': 'revenue',  # Sherpa Revenue in the pre-period\n",
    "    'sherps_clicks_pre': 'count',  # Sherps clicks in the pre-period\n",
    "}\n",
    "\n",
    "treat_colnames = {\n",
    "    'treatment': 'binary',  # Did they receive the treatment experiment? [This is the instrument]\n",
    "    'is_member': 'is_member'  # Did they become a member during the experiment period (through any means)? [This is the treatment of interest]\n",
    "}\n",
    "\n",
    "outcome_colnames = {\n",
    "    'days_visited': 'days_visited',  # How many days did they visit W in the experimental period\n",
    "}\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 99,
   "metadata": {},
   "outputs": [],
   "source": [
    "def gen_data(data_type, n):\n",
    "    gen_func = {'day_count_pre': lambda: np.random.randint(0, 29 , n),  # Pre-experiment period was 28 days\n",
    "                'day_count_post': lambda: np.random.randint(0, 15, n),  # Experiment ran for 14 days\n",
    "                'os': lambda: np.random.choice(['osx', 'windows', 'linux'], n),\n",
    "                'locale': lambda: np.random.choice(list(locale.locale_alias.keys()), n),\n",
    "                'count': lambda: np.random.lognormal(1, 1, n).astype('int'),\n",
    "                'binary': lambda: np.random.binomial(1, .5, size=(n,)),\n",
    "                ##'days_visited': lambda: \n",
    "                'revenue': lambda: np.round(np.random.lognormal(0, 3, n), 2)\n",
    "                \n",
    "               }\n",
    "    \n",
    "    return gen_func[data_type]() if data_type else None\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 100,
   "metadata": {},
   "outputs": [],
   "source": [
    "X_data = {colname: gen_data(datatype, n) for colname, datatype in X_colnames.items()}\n",
    "##treat_data = {colname: gen_data(datatype, N) for colname, datatype in treat_colnames.items()}\n",
    "##outcome_data = {colname: gen_data(datatype, N) for colname, datatype in outcome_colnames.items()}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 101,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "['days_visited_as_pre' 'days_visited_free_pre' 'days_visited_fs_pre'\n",
      " 'days_visited_hs_pre' 'days_visited_rs_pre' 'days_visited_vrs_pre'\n",
      " 'first_visit_days' 'is_existing_member' 'last_visit_days_pre' 'locale'\n",
      " 'meta_clicks_pre' 'meta_revenue_in_dollars_pre' 'no_visit_in_pre'\n",
      " 'os_type' 'rio_revenue_in_dollars_pre' 'sherpa_revenue_in_dollars_pre'\n",
      " 'sherps_clicks_pre']\n"
     ]
    }
   ],
   "source": [
    "X_data=pd.DataFrame({**X_data})\n",
    "# Turn strings into categories for numeric mapping\n",
    "X_data['os_type'] = X_data.os_type.astype('category').cat.codes\n",
    "X_data['locale'] = X_data.locale.astype('category').cat.codes\n",
    "print(X_data.columns.values)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 102,
   "metadata": {},
   "outputs": [],
   "source": [
    "X_pre=X_data.values.astype('float')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 109,
   "metadata": {},
   "outputs": [],
   "source": [
    "def dgp_binary(X,n,true_fn):\n",
    "    ##X = np.random.uniform(-1, 1, size=(n, d))\n",
    "    Z = np.random.binomial(1, .5, size=(n,))\n",
    "    nu = np.random.uniform(0, 10, size=(n,))\n",
    "    coef_Z = 0.017\n",
    "    plt.title(\"Pr[T=1 | Z=1, X] vs Pr[T=1 | Z=0, X]\")\n",
    "    plt.scatter(X[:, 0], coef_Z*scipy.special.expit(0.1*(X[:, 0] + nu)))\n",
    "    plt.scatter(X[:, 0], .006*np.ones(X.shape[0]))\n",
    "    plt.show()\n",
    "    C = np.random.binomial(1, coef_Z*scipy.special.expit(0.1*(X[:, 0] + nu))) # Compliers when recomended\n",
    "    C0 = np.random.binomial(1, .006*np.ones(X.shape[0])) # Non-compliers when not recommended \n",
    "    T = C * Z + C0 * (1 - Z)\n",
    "    y = true_fn(X) * (T + 0.05*nu)  + (0.1*X[:, 0] + 0.1*np.random.uniform(0, 1, size=(n,)))\n",
    "    return y, T, Z\n",
    "true_fn = lambda X: (.8+.5*X[:,0] - 3*X[:, 7])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 110,
   "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": [
    "y, T, Z = dgp_binary(X_pre, n, true_fn)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 111,
   "metadata": {},
   "outputs": [],
   "source": [
    "X = QuantileTransformer(subsample=100000).fit_transform(X_pre)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 112,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array([1.50760e+04, 4.26681e+05, 3.75968e+05, 1.52990e+05, 2.46910e+04,\n",
       "        1.38500e+03, 1.40500e+03, 1.09000e+03, 5.21000e+02, 1.93000e+02]),\n",
       " array([-3.26993549, -0.44447935,  2.38097679,  5.20643293,  8.03188907,\n",
       "        10.85734521, 13.68280135, 16.50825749, 19.33371363, 22.15916977,\n",
       "        24.98462591]),\n",
       " <a list of 10 Patch objects>)"
      ]
     },
     "execution_count": 112,
     "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": [
    "#### y menas number of days visit W in the experimental period, should be in range [0,14], \n",
    "##should be strong right skewed\n",
    "plt.hist(y)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 113,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "True ATE: 6.300\n"
     ]
    }
   ],
   "source": [
    "print(\"True ATE: {:.3f}\".format(np.mean(true_fn(X_pre))))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 114,
   "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"
    }
   ],
   "source": [
    "plt.figure(figsize=(10, 2))\n",
    "plt.subplot(1, 2, 1)\n",
    "plt.hist(T[Z==0])\n",
    "plt.title(\"T[Z=0]\")\n",
    "plt.subplot(1, 2, 2)\n",
    "plt.hist(T[Z==1])\n",
    "plt.title(\"T[Z=1]\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "check some summary stats, proportion should be around:\n",
    "* New members: in treatment = 33618*2/4708480 = 0.014\n",
    "* New members: in control = 14785*2/4708480 = 0.006"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 115,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "New members: in treatment = 0.014384, in control = 0.005828\n"
     ]
    }
   ],
   "source": [
    "print(\"New members: in treatment = {:f}, in control = {:f}\".format(T[Z == 1].sum()/Z.sum(), T[Z == 0].sum()/(1-Z).sum()))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 116,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Z treatment proportion: 0.49964\n"
     ]
    }
   ],
   "source": [
    "print(\"Z treatment proportion: {:.5f}\".format(np.mean(Z)))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Defining some generic regressors and classifiers"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 130,
   "metadata": {},
   "outputs": [],
   "source": [
    "from dml_ate_iv import DMLATEIV\n",
    "from utilities import RegWrapper\n",
    "from sklearn.model_selection import GridSearchCV, StratifiedKFold, train_test_split\n",
    "from sklearn.ensemble import RandomForestClassifier, RandomForestRegressor\n",
    "from sklearn.dummy import DummyClassifier\n",
    "from sklearn.linear_model import LinearRegression, LogisticRegression, LogisticRegressionCV, LassoCV\n",
    "from sklearn import metrics\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=50, min_child_weight=50, n_jobs=10),\n",
    "                           early_stopping_rounds=5, eval_metric='rmse', binary=False)\n",
    "\n",
    "# model = lambda: RandomForestRegressor(n_estimators=100)\n",
    "# model = lambda: Lasso(alpha=0.0001) #CV(cv=5)\n",
    "# model = lambda: GradientBoostingRegressor(n_estimators=60)\n",
    "# model = lambda: LinearRegression(n_jobs=-1)\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(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=50, min_child_weight=50, n_jobs=10),\n",
    "                                          early_stopping_rounds=5, eval_metric='logloss', binary=True))\n",
    "# model_clf = lambda: RandomForestClassifier(n_estimators=100)\n",
    "# model_clf = lambda: RegWrapper(GradientBoostingClassifier(n_estimators=60))\n",
    "# model_clf = lambda: RegWrapper(LogisticRegression(C=10, penalty='l1', solver='liblinear'))\n",
    "model_clf_log = lambda: RegWrapper(LogisticRegressionCV(n_jobs=-1,\n",
    "                                                    cv=StratifiedKFold(n_splits=3, shuffle=True),\n",
    "                                                    scoring=metrics.make_scorer(metrics.log_loss,\n",
    "                                                                                greater_is_better=False,\n",
    "                                                                                needs_proba=True)))\n",
    "\n",
    "model_clf_dummy = lambda: RegWrapper(DummyClassifier(strategy='prior'))\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_clf() # model for E[T | X]. We use a classifier since T is binary\n",
    "\n",
    "# model_Z_X = lambda: model_clf() # model for E[Z | X]. We use a classifier since Z is binary\n",
    "model_Z_X = lambda: model_clf_dummy() # model for E[Z | X]. We use a classifier since Z is binary\n",
    "\n",
    "# We fit DMLATEIV with these models and then we call effect() to get the ATE.\n",
    "# n_splits determines the number of splits to be used for cross-fitting.\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 118,
   "metadata": {},
   "outputs": [],
   "source": [
    "est = model_clf_log().fit(X, T)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 119,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([-4.73138608])"
      ]
     },
     "execution_count": 119,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "est.intercept_"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Some generic plots and output for diagnostics"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 120,
   "metadata": {},
   "outputs": [],
   "source": [
    "def plot_diagnostics_dmliv(cate, X):\n",
    "    dml_effect = cate.effect(X)\n",
    "\n",
    "    # Plot the CATE histogram\n",
    "    plt.hist(dml_effect, bins=100, log=True)\n",
    "    plt.xlabel(\"Treatment Effect\")\n",
    "    plt.ylabel(\"Frequency\")\n",
    "    plt.show()\n",
    "    \n",
    "    print(\"ATE Estimate: {:.3f}\".format(np.mean(dml_effect)))\n",
    "    print(\"Coefficients:\")\n",
    "    print(cate.coef_)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Algorithm 2 - Current Method"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 121,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<dml_ate_iv.DMLATEIV at 0x1d3099b4240>"
      ]
     },
     "execution_count": 121,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "dmlateiv_obj = DMLATEIV(model_Y_X(), model_T_X(), model_Z_X(),\n",
    "                  n_splits=10, # 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",
    "                 )\n",
    "\n",
    "dmlateiv_obj.fit(y, T, X, Z)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 122,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "True ATE: 6.300\n",
      "Estimate: 6.730\n",
      "ATE Estimate Interval: (6.201, 7.258)\n",
      "ATE Estimate Std: 0.321\n"
     ]
    }
   ],
   "source": [
    "ta_effect = dmlateiv_obj.effect()\n",
    "ta_effect_conf = dmlateiv_obj.normal_effect_interval(lower=5, upper=95)\n",
    "\n",
    "print(\"True ATE: {:.3f}\".format(np.mean(true_fn(X_pre))))\n",
    "print(\"Estimate: {:.3f}\".format(ta_effect))\n",
    "print(\"ATE Estimate Interval: ({:.3f}, {:.3f})\".format(ta_effect_conf[0], ta_effect_conf[1]))\n",
    "print(\"ATE Estimate Std: {:.3f}\".format(dmlateiv_obj.std))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# DMLIV - Logistic + Linear Regression"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 131,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'\\ndmliv_model_effect = lambda: model()\\ncate = GenericDMLIV(model_Y_X(), model_T_X(), model_T_XZ(), \\n             dmliv_model_effect(),\\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": 131,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "from dml_iv import DMLIV, GenericDMLIV\n",
    "from utilities import SelectiveLasso\n",
    "from sklearn.linear_model import LassoCV\n",
    "from econml.utilities import hstack\n",
    "\n",
    "np.random.seed(123)\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",
    "#model_T_XZ = lambda: model_clf()\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 = RegWrapper(LogisticRegression(C=10/np.sqrt(np.sum(Z0)), penalty='l1', solver='liblinear'))\n",
    "        #self.model1 = RegWrapper(LogisticRegression(C=10/np.sqrt(np.sum(Z1)), penalty='l1', solver='liblinear'))\n",
    "        #self.model0 = RegWrapper(LogisticRegressionCV(cv=5, n_jobs=-1))\n",
    "        #self.model1 = RegWrapper(LogisticRegressionCV(cv=5, n_jobs=-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",
    "                \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_clf(), model_clf())\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.0001)\n",
    "# dmliv_model_effect = lambda: LinearRegression()\n",
    "#dmliv_model_effect = lambda: LassoCV(cv=3, n_jobs=-1)\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",
    "feature_inds = np.arange(1, X.shape[1]+1)\n",
    "dmliv_model_effect = lambda: SelectiveLasso(feature_inds, LassoCV(cv=5, n_jobs=-1))\n",
    "cate = DMLIV(model_Y_X(), model_T_X(), model_T_XZ(), \n",
    "             dmliv_model_effect(), dmliv_featurizer(),\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",
    "dmliv_model_effect = lambda: model()\n",
    "cate = GenericDMLIV(model_Y_X(), model_T_X(), model_T_XZ(), \n",
    "             dmliv_model_effect(),\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",
    "            )\"\"\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 132,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Wall time: 9min 36s\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<dml_iv.DMLIV at 0x1d309a5c630>"
      ]
     },
     "execution_count": 132,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "%%time\n",
    "cate.fit(y, T, X, Z, store_final=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 133,
   "metadata": {},
   "outputs": [],
   "source": [
    "dmliv_effect = cate.effect(X)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 134,
   "metadata": {},
   "outputs": [],
   "source": [
    "# To get the parameter theta we call coef_. The first entry is the intercept of the CATE model\n",
    "#print(cate.coef_)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 135,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "ATE Estimate: 6.226\n",
      "True ATE: 6.300\n"
     ]
    }
   ],
   "source": [
    "# We can average the CATE to get an ATE\n",
    "print(\"ATE Estimate: {:.3f}\".format(np.mean(dmliv_effect)))\n",
    "print(\"True ATE: {:.3f}\".format(np.mean(true_fn(X_pre))))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 136,
   "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": [
    "# We can also see how it compares to the true CATE at each target point and calculate MSE\n",
    "plt.title(\"DMLIV CATE: MSE {:.2}\".format(np.mean((true_fn(X_pre) - dmliv_effect)**2)))\n",
    "plt.scatter(X[:, 0], dmliv_effect, label='est')\n",
    "plt.scatter(X[:, 0], true_fn(X_pre), label='true', alpha=.05)\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 137,
   "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": [
    "##histogram of estimated treatment effect\n",
    "plt.hist(dmliv_effect, bins=100, label='est')\n",
    "plt.hist(true_fn(X_pre), bins=100, label='true')\n",
    "plt.legend()\n",
    "plt.xlabel(\"Treatment Effect\")\n",
    "plt.ylabel(\"Frequency\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 138,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "\"\\nplt.plot([cate.fitted_nuisances['model_T_XZ'][i].coef_.flatten()[:X.shape[1]] \\n          - cate.fitted_nuisances['model_T_XZ'][i].coef_.flatten()[X.shape[1]:]\\n          for i in range(10)])\\nplt.show()\\nplt.plot([cate.fitted_nuisances['model_T_X'][i].coef_.flatten() for i in range(10)])\\nplt.show()\\nplt.plot([cate.fitted_nuisances['model_Y_X'][i].coef_.flatten() for i in range(10)])\\nplt.show()\\n\""
      ]
     },
     "execution_count": 138,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "\"\"\"\n",
    "plt.plot([cate.fitted_nuisances['model_T_XZ'][i].coef_.flatten()[:X.shape[1]] \n",
    "          - cate.fitted_nuisances['model_T_XZ'][i].coef_.flatten()[X.shape[1]:]\n",
    "          for i in range(10)])\n",
    "plt.show()\n",
    "plt.plot([cate.fitted_nuisances['model_T_X'][i].coef_.flatten() for i in range(10)])\n",
    "plt.show()\n",
    "plt.plot([cate.fitted_nuisances['model_Y_X'][i].coef_.flatten() for i in range(10)])\n",
    "plt.show()\n",
    "\"\"\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 139,
   "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": {
      "text/plain": [
       "array([7.51053794])"
      ]
     },
     "execution_count": 139,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "res_y = y - cate.fitted_nuisances['model_Y_X'][0].predict(X)\n",
    "plt.hist(res_y)\n",
    "plt.show()\n",
    "res_t = cate.fitted_nuisances['model_T_XZ'][0].predict(hstack([X, Z.reshape(-1,1)]))\\\n",
    "        -cate.fitted_nuisances['model_T_X'][0].predict(X)\n",
    "plt.hist(res_t)\n",
    "plt.show()\n",
    "LassoCV(cv=3).fit(res_t.reshape(-1,1), res_y).coef_"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Algorithm 3 - DRIV ATE"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 140,
   "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):\n",
    "        return self.model.summary()\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": 141,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'\\n# For comparison here is how ProjectedDRIV is called. A set of slightly different models\\ndr_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                        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'"
      ]
     },
     "execution_count": 141,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "from dml_iv import DMLIV\n",
    "from dr_iv import DRIV, ProjectedDRIV\n",
    "from utilities import SubsetWrapper\n",
    "\n",
    "np.random.seed(123)\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_clf1 = lambda: RegWrapper(LogisticRegressionCV(n_jobs=-1, solver='lbfgs',max_iter=500))\n",
    "model_TZ_X = lambda: model_clf()\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",
    "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_model_effect = lambda: SelectiveLasso(np.arange(1, X.shape[1]+1), LassoCV(cv=5, n_jobs=-1))\n",
    "prel_model_effect = DMLIV(model_Y_X(), model_T_X(), model_T_XZ(),\n",
    "                          dmliv_model_effect(), dmliv_featurizer(), n_splits=1)\n",
    "#dmliv_model_effect = lambda: model()\n",
    "#prel_model_effect = GenericDMLIV(model_Y_X(), model_T_X(), model_T_XZ(), \n",
    "#                                 dmliv_model_effect(),\n",
    "#                                 n_splits=1)\n",
    "dr_cate = DRIV(model_Y_X(), model_T_X(), model_Z_X(), # same as in DMLATEIV\n",
    "                        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",
    "                        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",
    "# For comparison here is how ProjectedDRIV is called. A set of slightly different models\n",
    "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",
    "                        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",
    "\"\"\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 142,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Wall time: 27min 27s\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<dr_iv.DRIV at 0x1d301a01048>"
      ]
     },
     "execution_count": 142,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "%%time\n",
    "dr_cate.fit(y, T, X, Z, store_final=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 174,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<dr_iv.DRIV at 0x1d301a01048>"
      ]
     },
     "execution_count": 174,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "dr_cate.refit_final(driv_model_effect())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 189,
   "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.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>     inf</td>  \n",
       "</tr>\n",
       "<tr>\n",
       "  <th>Date:</th>             <td>Sat, 18 May 2019</td> <th>  Prob (F-statistic):</th>   <td>   nan</td>   \n",
       "</tr>\n",
       "<tr>\n",
       "  <th>Time:</th>                 <td>09:18:51</td>     <th>  Log-Likelihood:    </th> <td>-6.3827e+06</td>\n",
       "</tr>\n",
       "<tr>\n",
       "  <th>No. Observations:</th>      <td>1000000</td>     <th>  AIC:               </th>  <td>1.277e+07</td> \n",
       "</tr>\n",
       "<tr>\n",
       "  <th>Df Residuals:</th>          <td>999999</td>      <th>  BIC:               </th>  <td>1.277e+07</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>    6.1853</td> <td>    0.143</td> <td>   43.212</td> <td> 0.000</td> <td>    5.905</td> <td>    6.466</td>\n",
       "</tr>\n",
       "</table>\n",
       "<table class=\"simpletable\">\n",
       "<tr>\n",
       "  <th>Omnibus:</th>       <td>43380.945</td> <th>  Durbin-Watson:     </th>  <td>   2.002</td> \n",
       "</tr>\n",
       "<tr>\n",
       "  <th>Prob(Omnibus):</th>  <td> 0.000</td>   <th>  Jarque-Bera (JB):  </th> <td>148241.166</td>\n",
       "</tr>\n",
       "<tr>\n",
       "  <th>Skew:</th>           <td> 0.034</td>   <th>  Prob(JB):          </th>  <td>    0.00</td> \n",
       "</tr>\n",
       "<tr>\n",
       "  <th>Kurtosis:</th>       <td> 4.885</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:                       inf\n",
       "Date:                Sat, 18 May 2019   Prob (F-statistic):                nan\n",
       "Time:                        09:18:51   Log-Likelihood:            -6.3827e+06\n",
       "No. Observations:             1000000   AIC:                         1.277e+07\n",
       "Df Residuals:                  999999   BIC:                         1.277e+07\n",
       "Df Model:                           0                                         \n",
       "Covariance Type:            nonrobust                                         \n",
       "==============================================================================\n",
       "                 coef    std err          t      P>|t|      [0.025      0.975]\n",
       "------------------------------------------------------------------------------\n",
       "const          6.1853      0.143     43.212      0.000       5.905       6.466\n",
       "==============================================================================\n",
       "Omnibus:                    43380.945   Durbin-Watson:                   2.002\n",
       "Prob(Omnibus):                  0.000   Jarque-Bera (JB):           148241.166\n",
       "Skew:                           0.034   Prob(JB):                         0.00\n",
       "Kurtosis:                       4.885   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": 189,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "dr_cate.effect_model.named_steps['reg'].summary()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Projecting to subset"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 163,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[ 0  1  2  3  4  5  6  7  8  9 10 11 12 13 14 15 16]\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<dr_iv.DRIV at 0x1d301a01048>"
      ]
     },
     "execution_count": 163,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "subset_names = X_data.columns.values\n",
    "#subset_names = set(['days_visited_as_pre', 'is_existing_member'])\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_data.columns.values]).flatten()\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",
    "lr_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",
    "                                         )\n",
    "dr_cate.refit_final(lr_driv_model_effect())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 164,
   "metadata": {},
   "outputs": [],
   "source": [
    "driv_cate = dr_cate.effect(X[:, feature_inds])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 165,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0, 0.5, 'Frequency')"
      ]
     },
     "execution_count": 165,
     "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": [
    "##histogram of estimated treatment effect\n",
    "plt.hist(driv_cate, bins=100, label='est')\n",
    "plt.hist(true_fn(X_pre), bins=100, label='true')\n",
    "plt.legend()\n",
    "plt.xlabel(\"Treatment Effect\")\n",
    "plt.ylabel(\"Frequency\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 166,
   "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": [
    "# We can also see how it compares to the true CATE at each target point and calculate MSE\n",
    "plt.title(\"DMLIV CATE: MSE {:.2}\".format(np.mean((true_fn(X_pre) - driv_cate)**2)))\n",
    "plt.scatter(X[:, 0], driv_cate, label='est')\n",
    "plt.scatter(X[:, 0], true_fn(X_pre), label='true', alpha=.2)\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 167,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "6.185295616639953"
      ]
     },
     "execution_count": 167,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# To get the ATE we look at the params of the fitted statsmodel\n",
    "dr_effect = np.mean(driv_cate)\n",
    "dr_effect"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 168,
   "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.001</td>  \n",
       "</tr>\n",
       "<tr>\n",
       "  <th>Model:</th>                   <td>OLS</td>       <th>  Adj. R-squared:    </th>  <td>   0.001</td>  \n",
       "</tr>\n",
       "<tr>\n",
       "  <th>Method:</th>             <td>Least Squares</td>  <th>  F-statistic:       </th>  <td>   44.13</td>  \n",
       "</tr>\n",
       "<tr>\n",
       "  <th>Date:</th>             <td>Sat, 18 May 2019</td> <th>  Prob (F-statistic):</th>  <td>2.04e-148</td> \n",
       "</tr>\n",
       "<tr>\n",
       "  <th>Time:</th>                 <td>08:52:54</td>     <th>  Log-Likelihood:    </th> <td>-6.3824e+06</td>\n",
       "</tr>\n",
       "<tr>\n",
       "  <th>No. Observations:</th>      <td>1000000</td>     <th>  AIC:               </th>  <td>1.276e+07</td> \n",
       "</tr>\n",
       "<tr>\n",
       "  <th>Df Residuals:</th>          <td>999982</td>      <th>  BIC:               </th>  <td>1.276e+07</td> \n",
       "</tr>\n",
       "<tr>\n",
       "  <th>Df Model:</th>              <td>    17</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.3784</td> <td>    0.961</td> <td>    0.394</td> <td> 0.694</td> <td>   -1.505</td> <td>    2.262</td>\n",
       "</tr>\n",
       "<tr>\n",
       "  <th>x1</th>    <td>   12.5335</td> <td>    0.492</td> <td>   25.482</td> <td> 0.000</td> <td>   11.569</td> <td>   13.497</td>\n",
       "</tr>\n",
       "<tr>\n",
       "  <th>x2</th>    <td>    0.3893</td> <td>    0.494</td> <td>    0.789</td> <td> 0.430</td> <td>   -0.578</td> <td>    1.357</td>\n",
       "</tr>\n",
       "<tr>\n",
       "  <th>x3</th>    <td>   -0.4696</td> <td>    0.492</td> <td>   -0.955</td> <td> 0.340</td> <td>   -1.433</td> <td>    0.494</td>\n",
       "</tr>\n",
       "<tr>\n",
       "  <th>x4</th>    <td>   -0.0994</td> <td>    0.493</td> <td>   -0.202</td> <td> 0.840</td> <td>   -1.066</td> <td>    0.867</td>\n",
       "</tr>\n",
       "<tr>\n",
       "  <th>x5</th>    <td>    0.2131</td> <td>    0.492</td> <td>    0.433</td> <td> 0.665</td> <td>   -0.752</td> <td>    1.178</td>\n",
       "</tr>\n",
       "<tr>\n",
       "  <th>x6</th>    <td>    0.0456</td> <td>    0.493</td> <td>    0.093</td> <td> 0.926</td> <td>   -0.921</td> <td>    1.012</td>\n",
       "</tr>\n",
       "<tr>\n",
       "  <th>x7</th>    <td>    0.4050</td> <td>    0.485</td> <td>    0.835</td> <td> 0.404</td> <td>   -0.545</td> <td>    1.355</td>\n",
       "</tr>\n",
       "<tr>\n",
       "  <th>x8</th>    <td>   -2.6665</td> <td>    0.286</td> <td>   -9.318</td> <td> 0.000</td> <td>   -3.227</td> <td>   -2.106</td>\n",
       "</tr>\n",
       "<tr>\n",
       "  <th>x9</th>    <td>    0.0760</td> <td>    0.493</td> <td>    0.154</td> <td> 0.877</td> <td>   -0.890</td> <td>    1.042</td>\n",
       "</tr>\n",
       "<tr>\n",
       "  <th>x10</th>   <td>    1.1331</td> <td>    0.495</td> <td>    2.288</td> <td> 0.022</td> <td>    0.163</td> <td>    2.104</td>\n",
       "</tr>\n",
       "<tr>\n",
       "  <th>x11</th>   <td>    0.5747</td> <td>    0.469</td> <td>    1.224</td> <td> 0.221</td> <td>   -0.345</td> <td>    1.495</td>\n",
       "</tr>\n",
       "<tr>\n",
       "  <th>x12</th>   <td>   -0.2075</td> <td>    0.495</td> <td>   -0.419</td> <td> 0.675</td> <td>   -1.178</td> <td>    0.763</td>\n",
       "</tr>\n",
       "<tr>\n",
       "  <th>x13</th>   <td>   -0.0830</td> <td>    0.286</td> <td>   -0.290</td> <td> 0.772</td> <td>   -0.644</td> <td>    0.478</td>\n",
       "</tr>\n",
       "<tr>\n",
       "  <th>x14</th>   <td>    0.4295</td> <td>    0.350</td> <td>    1.226</td> <td> 0.220</td> <td>   -0.257</td> <td>    1.116</td>\n",
       "</tr>\n",
       "<tr>\n",
       "  <th>x15</th>   <td>   -0.5895</td> <td>    0.494</td> <td>   -1.195</td> <td> 0.232</td> <td>   -1.557</td> <td>    0.378</td>\n",
       "</tr>\n",
       "<tr>\n",
       "  <th>x16</th>   <td>   -0.5009</td> <td>    0.493</td> <td>   -1.017</td> <td> 0.309</td> <td>   -1.466</td> <td>    0.465</td>\n",
       "</tr>\n",
       "<tr>\n",
       "  <th>x17</th>   <td>    0.4450</td> <td>    0.468</td> <td>    0.950</td> <td> 0.342</td> <td>   -0.473</td> <td>    1.363</td>\n",
       "</tr>\n",
       "</table>\n",
       "<table class=\"simpletable\">\n",
       "<tr>\n",
       "  <th>Omnibus:</th>       <td>43378.615</td> <th>  Durbin-Watson:     </th>  <td>   2.001</td> \n",
       "</tr>\n",
       "<tr>\n",
       "  <th>Prob(Omnibus):</th>  <td> 0.000</td>   <th>  Jarque-Bera (JB):  </th> <td>148075.039</td>\n",
       "</tr>\n",
       "<tr>\n",
       "  <th>Skew:</th>           <td>-0.036</td>   <th>  Prob(JB):          </th>  <td>    0.00</td> \n",
       "</tr>\n",
       "<tr>\n",
       "  <th>Kurtosis:</th>       <td> 4.884</td>   <th>  Cond. No.          </th>  <td>    17.3</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.001\n",
       "Model:                            OLS   Adj. R-squared:                  0.001\n",
       "Method:                 Least Squares   F-statistic:                     44.13\n",
       "Date:                Sat, 18 May 2019   Prob (F-statistic):          2.04e-148\n",
       "Time:                        08:52:54   Log-Likelihood:            -6.3824e+06\n",
       "No. Observations:             1000000   AIC:                         1.276e+07\n",
       "Df Residuals:                  999982   BIC:                         1.276e+07\n",
       "Df Model:                          17                                         \n",
       "Covariance Type:            nonrobust                                         \n",
       "==============================================================================\n",
       "                 coef    std err          t      P>|t|      [0.025      0.975]\n",
       "------------------------------------------------------------------------------\n",
       "const          0.3784      0.961      0.394      0.694      -1.505       2.262\n",
       "x1            12.5335      0.492     25.482      0.000      11.569      13.497\n",
       "x2             0.3893      0.494      0.789      0.430      -0.578       1.357\n",
       "x3            -0.4696      0.492     -0.955      0.340      -1.433       0.494\n",
       "x4            -0.0994      0.493     -0.202      0.840      -1.066       0.867\n",
       "x5             0.2131      0.492      0.433      0.665      -0.752       1.178\n",
       "x6             0.0456      0.493      0.093      0.926      -0.921       1.012\n",
       "x7             0.4050      0.485      0.835      0.404      -0.545       1.355\n",
       "x8            -2.6665      0.286     -9.318      0.000      -3.227      -2.106\n",
       "x9             0.0760      0.493      0.154      0.877      -0.890       1.042\n",
       "x10            1.1331      0.495      2.288      0.022       0.163       2.104\n",
       "x11            0.5747      0.469      1.224      0.221      -0.345       1.495\n",
       "x12           -0.2075      0.495     -0.419      0.675      -1.178       0.763\n",
       "x13           -0.0830      0.286     -0.290      0.772      -0.644       0.478\n",
       "x14            0.4295      0.350      1.226      0.220      -0.257       1.116\n",
       "x15           -0.5895      0.494     -1.195      0.232      -1.557       0.378\n",
       "x16           -0.5009      0.493     -1.017      0.309      -1.466       0.465\n",
       "x17            0.4450      0.468      0.950      0.342      -0.473       1.363\n",
       "==============================================================================\n",
       "Omnibus:                    43378.615   Durbin-Watson:                   2.001\n",
       "Prob(Omnibus):                  0.000   Jarque-Bera (JB):           148075.039\n",
       "Skew:                          -0.036   Prob(JB):                         0.00\n",
       "Kurtosis:                       4.884   Cond. No.                         17.3\n",
       "==============================================================================\n",
       "\n",
       "Warnings:\n",
       "[1] Standard Errors assume that the covariance matrix of the errors is correctly specified.\n",
       "\"\"\""
      ]
     },
     "execution_count": 168,
     "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",
    "dr_cate.effect_model.named_steps['reg'].model.summary(alpha=0.05)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 169,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "ATE Estimate: 6.19\n",
      "True ATE: 6.30\n"
     ]
    }
   ],
   "source": [
    "print(\"ATE Estimate: {:.2f}\".format(dr_effect))\n",
    "print(\"True ATE: {:.2f}\".format(np.mean(true_fn(X_pre))))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 170,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[ 1.43879591e+01 -2.40461427e-04 -3.79423954e-04  1.19861948e-04\n",
      "  -9.10706948e-05 -1.56724914e-04  3.18034102e-04 -3.00010508e+00\n",
      "  -1.45881050e-04 -5.26042692e-05 -1.37925546e-05 -2.58188824e-04\n",
      "   1.37876246e-04 -1.69120388e-04 -6.56378760e-06  3.81225149e-04\n",
      "   2.21649001e-04]]\n",
      "[0.602499]\n"
     ]
    }
   ],
   "source": [
    "lr = LinearRegression().fit(X[:, feature_inds], true_fn(X_pre).reshape(-1, 1))\n",
    "print(lr.coef_)\n",
    "print(lr.intercept_)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 172,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Coverage of True Projection: 0.96\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 576x432 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 = 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.01)\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_pre)\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=(8,6))\n",
    "\n",
    "order = np.argsort(X[:, feature_inds[0]])\n",
    "ax.plot(X[order, feature_inds[0]], iv_u[order], 'r--')\n",
    "ax.plot(X[order, feature_inds[0]], iv_l[order], 'r--')\n",
    "ax.plot(X[order, feature_inds[0]], pred[order], 'g--.', label=\"pred\")\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], 'y-', label=\"TrueProj\", alpha=.3)\n",
    "ax.legend(loc='best')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Random Forest Based CATE and Tree Explainer"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 154,
   "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(123)\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=100, max_depth=3, min_impurity_decrease=0.1,\n",
    "                                                     min_samples_leaf=500, bootstrap=True)\n",
    "#rf_driv_model_effect = lambda: GradientBoostingRegressor(n_estimators=20, max_depth=3, min_samples_leaf=500,\n",
    "#                                         n_iter_no_change=5, min_impurity_decrease=.001, tol=0.001)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 155,
   "metadata": {},
   "outputs": [],
   "source": [
    "rf_dr_cate = dr_cate.refit_final(rf_driv_model_effect())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 156,
   "metadata": {},
   "outputs": [],
   "source": [
    "rf_dr_effect = rf_dr_cate.effect(X)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 157,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0, 0.5, 'Frequency')"
      ]
     },
     "execution_count": 157,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAYgAAAEKCAYAAAAIO8L1AAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADl0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uIDMuMC4yLCBodHRwOi8vbWF0cGxvdGxpYi5vcmcvOIA7rQAAHCdJREFUeJzt3XuYVPWd5/H3J4hpRBSFxCjIdLuwOiyuREuc1XHXjA6LGjTKuII+u5q4EMMYNzu7+6RzeYwz4hMy6+jGEdcQZYj3CzFGAkq8rHEmGsMlqBDMBgiuLYkYGPES8QLf/aNOY9Ge6q5q6vSp0/15PU89XfWrc/nW6erz7d/l/I4iAjMzs64+kncAZmbWnJwgzMwslROEmZmlcoIwM7NUThBmZpbKCcLMzFI5QZiZWSonCDMzS+UEYWZmqfbJO4C9MXLkyGhtbc07DDOzQlm5cuXvI+JjPS1X6ATR2trKihUr8g7DzKxQJL1Yy3KFbGKSNFXS/O3bt+cdiplZv1XIBBERiyNi1oEHHph3KGZm/VYhE4SZmWWv0H0QZmZ747333qOjo4MdO3bkHUomWlpaGD16NIMHD+7V+k4QZjZgdXR0MGzYMFpbW5GUdzgNFRFs3bqVjo4O2traerUNNzGZ2YC1Y8cORowY0e+SA4AkRowYsVe1IycIMxvQ+mNy6LS3n80JwszMUjVNH4SkU4CrgLXA3RHxRK4BNanW9iUAbJp7Zs6R9KxIsZrBB9/ZRmn0d3/hwoVMnjyZww47rKHbrSbTGoSkBZK2SFrTpXyKpF9JWi+pPSkO4E2gBejIMi4zsyJauHAhmzdv7rP9Zd3EtBCYUlkgaRAwDzgdGA/MkDQe+MeIOB34MvDXGcdlZtY0br/9diZNmsTEiRP5/Oc/z86dO7n44ouZMGECRx99NNdddx2LFi1ixYoVXHjhhUycOJG3334787gybWKKiCcltXYpngSsj4iNAJLuBs6OiF8m7/8z8NFq25Q0C5gFMGbMmEaHbGbWp9atW8c999zDT3/6UwYPHszs2bOZM2cOL7/8MmvWlBtfXnvtNYYPH84NN9zANddcQ6lU6pPY8uikHgW8VPG6Axgl6VxJ3wFuA26otnJEzI+IUkSUPvaxHicjNDNrao899hgrV67k+OOPZ+LEiTz22GNs27aNjRs38sUvfpGHH36YAw44IJfY8uikTht3FRFxP3B/TRuQpgJTx44d29DAzMz6WkRw0UUX8c1vfnOP8quvvpply5Yxb9487r33XhYsWNDnseVRg+gADq94PRqoq9fFk/X1L63tSxo+esSsKE499VQWLVrEli1bANi2bRsvvvgiu3btYtq0aVx11VWsWrUKgGHDhvHGG2/0WWx51CCWA+MktQEvA9OBC+rZgGsQljcP4e2f8vh9jh8/njlz5jB58mR27drF4MGDufbaaznnnHPYtWsXwO7axcUXX8yll17KkCFDePrppxkyZEimsWWaICTdBZwCjJTUAXwjIm6RdBmwDBgELIiItfVsNyIWA4tLpdLMRsdsZtbXzj//fM4///w9yjprDZWmTZvGtGnT+iqszEcxzahSvhRY2tvtugZhZpa9Qk614T4IM7PsFTJBmJlZ9gqZIHxPajOz7BUyQbiJycwse4VMEGZmlr2mme67Hh7FZGaZuLLBrRJX9twM/tprr3HnnXcye/bsxu67AQpZg3ATk5n1F6+99ho33njjh8p37tyZQzR7KmSCMDPrL9rb29mwYQMTJ07k+OOP51Of+hQXXHABRx99NJs2bWLChAm7l73mmmu48sorAdiwYQNTpkzhuOOO4+STT+aFF15oeGyFbGIyM+sv5s6dy5o1a1i9ejVPPPEEZ555JmvWrKGtrY1NmzZVXW/WrFncdNNNjBs3jmeeeYbZs2fz+OOPNzS2QiYI90GYWX81adIk2traul3mzTff5KmnnuK8887bXfbOO+80PJZCJgjPxWRm/dXQoUN3P99nn312T9gHsGPHDgB27drF8OHDWb16daaxFDJBWIrK0RfVRk705TLAppZkkt4ru9/WppbOF00Qd43L7FXMTfh5mmqZPPaXo+6m8D7kkEPYsmULW7duZf/99+dHP/oRU6ZM4YADDqCtrY377ruP8847j4jgueee45hjjmlobE4QZmadckgiI0aM4KSTTmLChAkMGTKEQw45ZPd7gwcP5oorruCEE06gra2No446avd7d9xxB1/4wheYM2cO7733HtOnT3eCMLPmV3kDKN8zo2d33nln1fcuv/xyLr/88g+Vt7W18fDDD2cZVjGHuXouJjOz7BUyQfhCOTOz7BUyQZiZNUpE5B1CZvb2s7kPwsz2Wmv7koqRXR9+r1O1ZfLS0tLC1q1b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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.hist(rf_dr_effect, bins=100, label='est', log=True)\n",
    "plt.hist(true_fn(X_pre), bins=100, label='true', log=True)\n",
    "plt.legend()\n",
    "plt.xlabel(\"Treatment Effect\")\n",
    "plt.ylabel(\"Frequency\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 158,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "ATE Estimate: 6.18\n",
      "True ATE: 6.30\n"
     ]
    }
   ],
   "source": [
    "print(\"ATE Estimate: {:.2f}\".format(np.mean(rf_dr_effect)))\n",
    "print(\"True ATE: {:.2f}\".format(np.mean(true_fn(X_pre))))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 159,
   "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_pre) - rf_dr_effect)**2)))\n",
    "plt.scatter(X[:, 0], rf_dr_effect, label='est')\n",
    "plt.scatter(X[:, 0], true_fn(X_pre), label='true', alpha=.2)\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 160,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABPUAAAEDCAYAAABd1DFXAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADl0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uIDMuMC4yLCBodHRwOi8vbWF0cGxvdGxpYi5vcmcvOIA7rQAAIABJREFUeJzs3Xd8G/X9x/HXV5a3LWdv4oQMMgkQoEmBlLLLpoyaDaUDyijjRwO0ZZUWwt6jlBWWIYRNCKMQVsIMlJFFCHHIIovYjrek+/3xlayTLHkksSzF7yePYFk6nb66053v3vp872scx0FERERERERERETSh6ejGyAiIiIiIiIiIiJto1BPREREREREREQkzSjUExERERERERERSTMK9URERERERERERNKMQj0REREREREREZE0o1BPREREREREREQkzSjUExERERERERERSTMK9URERERERERERNKMQj0REREREREREZE0o1BPREREREREREQkzSjUExERERERkdTnKynq6CaIiKQShXoiIiIiIiKdja9kKb6SkxI8dhm+kpfaMK+H8ZX8Z2s1LZGv+gwom7nbP99u79cREUkXCvVEREREREQkoqL0X1SUHtbRzYh14eHHL/j50m93xldydUe3RUQkFXg7ugEiIiIiIiIiAPhK9gbiVuO9Ebn5d3wlM6go/TA5jYoonrIys2xyv4Zkv66ISDwK9URERERERDqngfhK/gv8DFgK/IGK0tn4Sq4E9qSidD8AfCV9gPuBScCPwBTgP8BgKkqXhuaVja/kfuBYoAq4morS+xpfyVeyF3AtMAr4CbgbuJmKUicU5L0JnA5cFXr+oNjGHnnqea9OLf33MF9d7eNDLrm+2j9l5VvAzqH5PQhcWza5X6B4yso7gKyyyf3+CFA8ZeV7wMCyyf2KQ79PBiaVTe53SOj3I4G/A0OAVcA1ZZP7PR567DTgb8B9wJ+BcmB0Wxe0iEh7UPdbERERERGRzum3wHlAEbYQ7pEE0z0O1APbAXsCJ8eZ5hjgJaAbcC5wJ76SYgB8JaOBGcANQE/gEOCcmPlkAL/ChnS9qChdF/vv6tefHfpV3+0WFP/15sv8Gd43sBV9fULz+y1wYWhebwL7AxRPWVkA7ASY4ikrh4ce3y80DcVTVu4PPACcH2r7qcCdxVNWTnK1bRDQDxgG7JZgGYmIJJ0q9URERERERDqn+6go/QYgNNDF+U1GmPWVDAD2AYZQUVoBVOAr+Qfwi5h5vUVF6Yuh28/iK9mIDdPKgLOAaVSUvhB6fAG+kjuBU4CprnlcQkVpOUDxlJUGKCib3K8y/OCZR582f0VRtxnYEK8eW1HnAPOLp6ycgg31bsCGfdsVT1m5PTAS+AT4Fti/eMrKMmAPIgHgn4Hbyib3ey/0+8fFU1Y+Fmrbu6H7GoBLyib3q2theYqIJJVCPRERERERkc5plet2VehnYcw0/UM/l7nuK2thXuH5hec1GNgHX8mvXY97gB9cvwfDv4cCvQdC05wWnmBFUbf60M3tgKWhQC/su9D9lE3uV1E8ZeWn2Iq8kdgqxMXAicACoKJscr+vXG37ZfGUlRe65pUBvOf6fZUCPRFJRQr1REREREREJJEVoZ8DgSWu221RBjxIRenZzUzjUFHquAK9XbEVgvH8ABQXT1lpXMHe9kSHhG8SCfVOB74H/g0sAv4b07aHyyb3u6GZtgWbeUxEpMMo1BMREREREZH4KkqX4yuZBVyHr+QMIBc7cERb3A28g69kJjATcIDhQE8qSt+JmfZobAgHsLZ4ysrYeYW7/W4ALiuesvIGbLXdZOxgFmFvYrvW1gNzyyb3CxZPWfk98Efs9fPCbgUeKp6y8kNgNrZKbyxgyib3+7SN71NEJKk0UIaIiIiIiIg05wQgD1gOvA9MC93fui6pFaVfA4diw7RVwBrgYeygGbFeAJ4DvsJW3/V0/ZuNHUG3J7YKbz/saLyvYa/Nd7NrPnOw57tvlU3uF660exPwhX4CUDa53+vAH7DX4lsXat8tQEGr3puISAcyjuO0PJWIiIiIiIgIgK/kQGz4lktF6VY/oSyestILlAKVZZP7nd7S9CIinZVCPREREREREUnMVzIO22X2K2xX16eAeVSUntpeLxkK9rqUTe63rr1eQ0Qk3emaeiIiIiIiItKcbsD9QF+gHHgVuKg9X7Bscj8/tjusiIgkoEo9ERERERERERGRNKNKPRERERERkc5nNdC7oxshHeJHoE9HN0JEtpwq9URERERERDofnQh2bqajGyAiW87T0Q0QERERERERERGRtlGoJyIiIiIiIiIikmYU6omIiIiIiIiIiKQZhXoiIiIiIiLSaTz88MPMnTu3o5vRolmzZvHss892dDNEJIUp1BMREREREZEtcuWVV7Jhw4aUnZ+IyLZIoZ6IiIiIiIiIiEiaybjyyis7ug0iIiIiIiKSXFfG3rF27VqmTZvGzJkz+d///kdRURE9evQAbJfVYDBI3759Afjiiy+YMWMGO++8Mw899BDl5eXMnTuX999/n65du1JdXc2DDz6I3+/nqaee4pNPPiEvL4/evXtv1vx69erV2E6/38/111/P8OHDyc/PB6Cqqorrr7+e8ePHEwgEmDZtGq+++irvvfcey5Yto7i4mOzs7MbX6t27N3379mXWrFnMnTuXkSNHArBx40auu+46Jk2ahDGG2tpaXnnlFV5++WXmzJlDbW0txcXFGGNatZAfe+wxamtr6d+/f+N999xzDwUFBfTs2ZNXX32Vl156iVmzZjFv3jx69uxJly5dAFi6dCk1NTWMHDmSpUuX8uCDDzJx4sTG+dx666306tWLrl274jgOH3zwAc899xzvvPMOq1atYvvttyczMzNR065q1RsQkZSmSj0REREREZFOLhAI8OSTTzJkyBAuvvhiDj74YKZPn866detafO7pp58OwFlnncVll13GmDFjANi0aRPV1dVceOGFHHnkkbz00ktbNL8wr9fLyJEj+eqrrxrv++abbxg0aBD5+fk4jsNOO+3EBRdcwAUXXIDX62XGjBmtXhZuzz//PB6Ph/POO48zzzyT7777rk3X4xs7dmxUO9euXUt5eTnDhg0DoH///px55plMnjyZsWPHMm3aNPx+f5vb+dFHH7FgwQJOP/10LrroInJycnjllVfaPB8RSS8K9URERERERDq55cuXU19fz5577klGRgaDBw9m+PDhfP3111s031/+8pd4vV4GDRrE8OHD+eabb7ZKe8eOHRvVtq+++oqxY8cCkJeXx6hRo8jMzCQ7O5tJkyaxdOnSNr/Gpk2b+PbbbznooIPIysoiPz+fCRMmtGmZjBgxgtWrV7Nx40YAvvzyS0aOHInX6wVgxx13JC8vD4/Hw89//nP8fn+rgs9Yn376Kfvssw8+nw+v18vee+/NvHnzCAaDbZ6XiKQPb0c3QERERERERDpWZWUlPp8vqltply5dqKio2Ox55uTkkJWV1fh7UVERlZWVW9TOsMGDB9PQ0MDy5cspKChg9erVjBgxAoCGhgZmzpzJ4sWLqa2tBaCuro5gMIjH0/q6lvLycoLBIDfddFPjfY7j4PP5Wj2P7OzsxnB0zz335Ouvv+awww5rfHz27NnMnTuXyspKjDHU1dVRXV3d6vm72/rUU09FrT+Px8OmTZva1F4RSS8K9URERERERDq5wsJCKioqcBynMRgqLy+ne/fuAGRmZtLQ0NA4/aZNm1qcZ21tLfX19Y3BXnl5eeO18TZnfm7GGEaPHs3XX39Nfn4+w4cPb7xm3uzZs1m/fj2///3vGwO/e++9N+58mmuHz+cjIyODv/zlL20KA2ONGTOGd955h+LiYvx+P4MHDwagrKyMDz74gFNOOYVevXphjOG6665rVTuDwSBVVVVRbT3iiCMYOHDgZrdTRNKPut+KiIiIiIh0cgMGDCAzM5MPPviAQCDA0qVLWbhwYeP17Pr06cP8+fNpaGhgw4YNTa4rV1BQwE8//dRkvrNmzSIQCFBWVsaiRYsYPXr0Fs3PLdwF1931FqC+vh6v10tOTg41NTXMmjUr4Tz69OlDWVkZ5eXl1NbW8t577zU+VlhYyJAhQ3jttdeoq6vDcRw2bNjQ5q68w4YNY+PGjbz99tuMHj26MTStr6/H4/GQn59PMBjknXfeoa6uLu48unfvjt/vZ9GiRQQCAd59910CgUDj47vuuitvvfVWYzffqqoqFixY0KZ2ikj6UaWeiIiIiIhIJ5eRkcHxxx/PK6+8wnvvvYfP5+Ooo45qHP124sSJrFy5khtuuIHevXuz4447smTJksbn77333jz33HP4/X4OO+ww8vPzKSgoICcnh5tuuonMzEwOPfTQzZ5fOAx0GzBgAFlZWVRWVjYOPAEwYcIEpk+fzvXXX09hYSETJ05MGHANGTKE0aNHc88995CXl8cee+zBwoULGx8/6qijePPNN7nrrruoq6uja9eu7Lnnnm1atuGBPT7//HP23XffqNceOnQod9xxB5mZmUycOJGioqK488jJyeGQQw7hxRdfxHEc9thjj6hutRMmTADg0UcfpbKykvz8fMaMGdPYJVlEtk3GcZyOboOIiIiIiIgkV7ueCC5dupRnn32WCy+8sD1fRjafaXkSEUl16n4rIiIiIiIiIiKSZhTqiYiIiIiIiIiIpBl1vxUREREREel8dCLYuan7rcg2QJV6IiIiIiIiIiIiaUahnoiIiIiIiIiISJpRqCciIiIiItL5/NjRDZAOo3Uvso3QNfVERERERERka0i3k0tdV05E0poq9URERERERERERNKMQj0REREREREREZE0o1BPRERERERE2s2VV16JMSbuP7/fn/B5VVVV/OMf/2DkyJHk5eXRq1cvTj31VFauXBl3+srKSoYMGdI47zvvvLO93pKISErwdnQDREREREREZNvXo0cPhgwZEnWfMYkva3f44Yfz1ltvYYxhzJgxrFixgqlTp/Lee+/xxRdf4PP5oqY/55xzWLJkSbu0XUQkFalST0RERERERNrdIYccwocffhj1LyMjI+608+bN46233gLgxhtv5Msvv2Tx4sXk5eXx/fffc/fdd0dN//TTTzN16lSOO+64dn8fIiKpQqGeiIiIiIiItLvp06eTm5tL3759OeSQQ/j8888TThsMBhtvezz2tNVd1ff666833v7hhx/44x//yPjx47nmmmvaoeUiIqlJoZ6IiIiIiIi0q4yMDPr06cOgQYNYvXo1M2bMYOLEiQmDvZEjRzJu3DgALrroIsaNG8fQoUOprq4GYMWKFYAN/04++WQaGhp44oknyMzMTM4bEhFJAQr1REREREREpN2ccMIJrFmzhm+//Zb58+czc+ZMAOrq6rjrrrviPicjI4MZM2Zw2mmn0adPH7777jvGjBnD+PHjARrDu9tuu4133nmH2267jeHDhyfnDYmIpAjjOE5Ht0FERERERETSX6tPLnv06MH69evZf//9o7rSNjtzx2HEiBEsWrSIo48+mmeeeYbTTjuNRx55hPz8/MZpwtV8WVlZjB8/ntmzZyeaZeJROkRE0oAq9URERERERKTdTJkyhWXLljX+/sYbb7B+/XoABg0aBMC+++7LiBEjuPTSSxunmzt3LuXl5Y2/X3vttSxatAiAkpKSqNeoqqqiqqqqMdADqK+vj/pdRGRbo0o9ERERERER2RrinlwOGjSIZcuWMXDgQPLy8liwYAGO45Cfn8/HH3/MqFGjGDRoEGVlZZx66qk8/PDDAJx//vnce++9DB06lPXr17N69WoAjj32WJ5++um4DVi6dCmDBw8G4I477uCcc85prr3tWqlXWVnpABQWFqoiUETahSr1REREREREpN1cdtll7LvvvtTX17NkyRKKi4s58cQT+eyzzxg1alTC5+22224MGzaMpUuXsnHjRnbccUduueUWnnzyySS2XkQkdalST0RERERERLaGdDu5VKWeiKQ1VeqJiIiIiIiIiIikGYV6IiIiIiIiIiIiaUahnoiIiIiIiIiISJpRqCciIiIiIiIiIpJmFOqJiIiIiIiIiIikGYV6IiIiIiIisjX82NENaIN0aquISFzejm6AiIiIiIiIbBP6bO0ZVlZWOgCFhYVma89bRCTdqVJP2swYs50x5m1jzHxjzDfGmD/HmcYYY243xiw2xnxpjNmlI9raGbRyfextjCk3xnwR+nd5R7S1szDG5BhjPjbG/C+0Tq6KM022Meap0DbykTFmUPJb2jm0cn2cZoxZ69pGftcRbe1sjDEZxpjPjTEvx3lM20iStbA+tI0kmTFmqTHmq9Dy/jTO4zrWSrJWrBMdbyWRMaaLMeYZY8yC0HHwxJjHtY0kWSvWibaRJDLG7OBa1l8YYyqMMefHTKPtJElauT7avI2oUk82hx+4yHGcucaYQuAzY8wbjuPMc03zK2BY6N/PgHtCP2Xra836AHjPcZxDO6B9nVEdsI/jOJuMMZnA+8aYVx3H+dA1zRnAT47jDDXGlABTgN90RGM7gdasD4CnHMc5pwPa15n9GZgP+OI8pm0k+ZpbH6BtpCP80nGcdQke07FWx2hunYCOt5LpNmCm4zjHGGOygLyYx7WNJF9L6wS0jSSN4zgLgZ3AfnEHrACei5lM20mStHJ9QBu3EVXqSZs5jrPKcZy5oduV2BOA/jGTHQFMdawPgS7GmL5Jbmqn0Mr1IUkU+txvCv2aGfrnxEx2BPBI6PYzwL7GGHUraQetXB+SZMaYAcAhwH8STKJtJIlasT4k9ehYSzotY4wPmAQ8AOA4Tr3jOBtjJtM2kkStXCfScfYFvnMcpyzmfm0nHSPR+mgzhXqyRULdoXYGPop5qD/wg+v35ShoanfNrA+AiaHuh68aY0YntWGdUKgb2xfAGuANx3ESbiOO4/iBcqB7clvZebRifQAcHep28IwxZrskN7EzuhX4CxBM8Li2keRqaX2AtpFkc4DXjTGfGWP+EOdxHWslX0vrBHS8lSzbA2uBh0KXDfiPMSY/ZhptI8nVmnUC2kY6SgnwZJz7tZ10jETrA9q4jSjUk81mjCkApgPnO45TEftwnKeoMqYdtbA+5gLFjuOMA+4Ank92+zobx3ECjuPsBAwAdjfGjImZRNtIErVifbwEDHIcZ0fgTSIVYtIOjDGHAmscx/msucni3KdtpB20cn1oG0m+PRzH2QXbNepsY8ykmMe1jSRfS+tEx1vJ4wV2Ae5xHGdnoAq4JGYabSPJ1Zp1om2kA4S6Qh8OTIv3cJz7tJ20oxbWR5u3EYV6sllC16WaDjzuOM6zcSZZDri/xR8ArExG2zqjltaH4zgV4e6HjuPMADKNMT2S3MxOKdTtYBZwUMxDjduIMcYLFAEbktq4TijR+nAcZ73jOHWhX+8Hxie5aZ3NHsDhxpilQCmwjzHmsZhptI0kT4vrQ9tI8jmOszL0cw32mju7x0yiY60ka2md6HgrqZYDy12V989gA6XYabSNJE+L60TbSIf5FTDXcZwf4zym7ST5Eq6PzdlGFOpJm4WuafQAMN9xnJsTTPYicEpoNJ0JQLnjOKuS1shOpDXrwxjTJ3wtKmPM7thtf33yWtm5GGN6GmO6hG7nAvsBC2ImexE4NXT7GOAtx3H0rVg7aM36iLl2yOHYa1NKO3Ec51LHcQY4jjMI2/3gLcdxToqZTNtIkrRmfWgbSS5jTH5o8CtC3dcOAL6OmUzHWknUmnWi463kcRxnNfCDMWaH0F37ArGDxGkbSaLWrBNtIx3meBJ39dR2knwJ18fmbCMa/VY2xx7AycBXoWtUAVwGDARwHOdeYAZwMLAYqAZO74B2dhatWR/HAGcZY/xADVCik+N21Rd4xNhRjTzA047jvGyMuRr41HGcF7FB7KPGmMXY6qOSjmvuNq816+M8Y8zh2NGkNwCndVhrOzFtI6lF20iH6g08Fzqu9wJPOI4z0xhzJuhYq4O0Zp3oeCu5zgUeD3VlWwKcrm2kw7W0TrSNJJkxJg/YH/ij6z5tJx2kFeujzduI0TYkIiIiIiIiqaiystIBKCwsTLsR0NO57SKSHtT9VkREREREREREJM0o1BMREREREREREUkzCvVERERERERERETSjEI9ERERERERERGRNKNQT7YqY8wfOroNEqH1kXq0TlKP1klq0fpIPVonqUXrI/VonaQerZPUovWRerROUsuWrA+FerK1aeeQWrQ+Uo/WSerROkktWh+pR+sktWh9pB6tk9SjdZJatD5Sj9ZJalGoJyIiIiIiIiIi0lkYx3E6ug2SZg466CBn3bp1cR9bu3YtPXv2THKLJBGtj9SjdZJ6tE5Si9ZH6tE6SS1aH6lH66R9BYNBADye1tejpMo62Zy2b4tSZX1IhNZJanGvj88+++w1x3EOau1zFerJ5tCHRkRERERE2l1lZSUAhYWFHdyStkvntotIhzFtmbhzf2UgIiIiIiIiIiKShhTqiYiIiIiIiIiIpBmFeiIiIiIiIiIiImlGoZ6IiIiIiIiIiEia8XZ0A0RERERERES2NRogQ0Tamyr1RERERERERERE0oxCPRERERERERERkTSjUE9ERERERERERCTNKNQTERERERERERFJMwr1RERERERERERE0oxxHKej2yDpRx8aERER2Tr8AZi/HMqrIvcZwJMBwaC9DeAxEHDszzDHAY8HAqHpjOuxWI5jHw86LU8rIimjckx/ABaUZ3VwS0REWs9jAAeCRA47wociGdg7h/bwkp/pwUQfk7TpAEWhnmwOfWhERERkyzkOzF5gf7r5A+DNsLcvfxyuPtHe3lQLv7k+ciRy9Qmw61B7+7rp8O43iV/rmJ/Db/ezt2d8CnfO2GpvQ0TaT+WK+wEYc3dlB7dERKT1/n1UN/oW2mOZr1fXM6ZP/C8m+hR66FWQ4b6rTaGeut+KiIiISMcwBnIym97vdR3c9ukGGzbZ2wU5UNwr8tjCFZHbo7dr/rUWrYzcHjWw7W0VERERaYVuuZ7GQK/O71Dc1Ztw2sKsLes5oFBPRERERDpOUX7zj4/eDuYti/w+yhXezfvBdX8LQd3CFbYCEGBQLxsQioiIiGxlI3tFQryynxoozLbRW7yesjmZCvVEREREJF31KGz+8dEDY8I7V6i3YLm9nh7YoC4vO/F86hrgu9Xx5yMiIiKylYzqFemFUFEXCfJirp1HZkbT+9pKoZ6IiIiIdJzCvPj3h8O6Hj5Y+VPk/tGuiryaevj+R3s7wwMjBjT/WonCQREREZGtZGTPSKjn9SQO7ba06y0o1BMRERGRjpThgaw415pxHwQX5EBtvb3du4sN+sK+cXXNbem6eu5pdV09ERER2cpyvYbtu9njmqDjNF5bL56i3C2P5BTqiYiIiEjHilet5+6OMnIALHANirG519VzT7tDP9vvRURERGQrGd7TS0boi8nlGwP0DoV68a6nl69KPRERERFJey1dV2/UdjFVdglCvR3628q/RDZWwYr19namF4b1a3tbRURERBJwX09vbXWg8XbstfMyPODZwuvpgUI9EREREeloXRKMgBv+Vru4Fyz5MXK/u5vt+kpYFbrmXk4mDOnT/GslCgdFREREtpA71GtOfusma5FCPRERERHpWJne+BV2wVCo5zH2qLVxpNve0SPdzndV641uQxfclqYVERERaSWPgR16RNK67nntez09UKgnIiIiIqmgIKfpfe6gb2i/xCPdtqX67htXqDdyAGx5zxcRERERBnf1kptpDyzWVQXYrijx9fQKsxXqiYiIiMi2otsWXFfPHdS1FOqtWA/lVfa2Lw8G9GhbO0VERETicHe9XVERaBwwI5bHgDfBY22lUE9EREREOp67O208vYtgTXn072FrXfcX5UN2CxeqiZpPl9a3UURERCSB3gWRiK0hEKnOizdIxtaiUE9EREREOt6GTc0/vnCFHd3W/XvYcNcotmVroK4h8XyyvPaafGGLVratnSIiIiJxLFznb7zt7l4b2/22IRC/S+7mUKgnIiIiIh0v3CU2kXk/RHetdQ94MWpg/PvjGd4PMkMXrl62Fiqq29ZOERERkTjmrYl8qVjcxUtVvR3gK7ZSD6DWr1BPRERERLYFjgM1dU3vD492C7DqJ+jhs7er62Dpmshjo93X13Nddy8edwA4v4UAUERERKSV1lcHWbMpAEBOpmHZxkDCaStqFeqJiIiIyLagug7iHduGLzpTUw8FuZH75/0AwdATPCZ6JNyWKvUSDbAhIiIisoXc1Xqb6oMJp6uoS/xYWyjUExEREZGO1dL19BYsh1EJgrtBvSODbKwtjx4EI5YhJtRroapPREREpA3coV6ON9LtNvYaerXNXP63LRTqiYiIiEjH+qmy+cfn/ZD4unmjE1xnL57iXlCQY29v2GS79IqIiIhsJe5Qb0CRt3EU3Njr6jlEj5C7uRTqiYiIiEjHqmrhenpLVsOgXva2PxA98u1oV9jXUnfaqIE2VKUnIiIiW9eyjYHGbrddcz0s2+hPOG1l7ZZ3wVWoJyIiIiIdp64hOsAL84S+0Q4EI9fWA/hutX1OWFuCutFtGCVXREREpI0cYIGrWu+nZoK78q1wXT2FeiIiIiLScTYmuJ5euJvKktUwtG/kfvd18HoVJR4RNx4NkiEiIiLtbN6aSHWexySerrp+y19LoZ6IiIiIdJz1W3I9Pdf985dHRsSNp4cPenext2vrbVgoIiIispW5r6vXOz+j8XbsYBkBB4LNHbu0gkI9EREREek4lTVN73Mf4C5YDjv0i/yecJCMFrreuqv0FqyI3+VXREREZAt9u76hcRCM/kVeVlTYyr3YwTKAxuvvbS7vFj1bRERERATAcWxQ1hCwg1k0BMDvj/xe12AHxKius5VyNfX29rcrobw6cl9WBmRnQW0D7LK9HaV2+hzbBXdgD+hWCF0L7Gut/AlenQt7j7HTbd8ncfu6FtjqvIE9YeWG5qcVkZQzqGtGyxOJiKSIH8r99C30sjgU8PXMy2BDTYBeBRl4jMFxHDzGsKUD4JrY8j+RVtCHRkREJF0EgtDgB3/4ZyAmeAvY+8O3w/fXNdiQraoOqmsjIVxdKHwFnItEAAAgAElEQVSrabC36/x22roGW2EXDvcCrvn7gxAMggH7Pwec0LfVjmN/z8iwgV5BLnQrgJwsGNAdsjLt4/7Q89dvgp82QV6WDfi6F8J2PSCzld9VT/sAjt2jPZa0iLSDyj2HA/Dxj5kd3BIRkdYzQE6m4aMf6jj354VkmFBHBMeh1u+Qm2nweOJ2nm3mKnxNqVJPREREJNmCsRVtCYK1qN/9UB8K0Nw/6/2Rx+r9kYq3ugZ7OxC0X8cFQ+FZOHhrDOAc255g6GcgfNuxh5WZGTZwyzAQPvj0GMBEDju9GXaEWgfbVicI2ZmQmw05oZ+5WTaoy/baoC7ba6cJ/8vw2MExgkHYWGWvtbe+0lbjNQRs0NejEEYOsGFe1hYcxsbp/iIiqanw+/UsmToHzjyqo5siItJqDq7DpNBoGRmhLzfzt2LhsUI9EREREbABV7yuo02CtlDVW/jx+gZbrdbgtz/rw2FbIBS4uX4PB3eBgA2xPJ7IsGjh3hPhUC0cwAWDoeDNHcZhg7NgKJRzwtME7DyzvKF/mZDvtVVsmRk2fPN4wDgQDL2mEwS/K9gLuKrr6htsuz3GFcC5wrisOPdlZ9rXa264N7fqOvixHNZX2BBvYxUU5EB3H/TtBmOKoTB36wVxxhVOikjqM0abrYikpWR8h6hQT0RERFKX40QCJnclW0vdScOVbA3+SOjWWNEWE7Y1uObjMZGKMY8HvKHgzRAJ4IyxQ401hmJOpK2hbhWNAz2EA7pweBYIhh4Phl47EHldbyh0y8ywoZjXEwnjwoGcN/xY+L5QdVxjIBe086ttiLzvcNfYqhr70x9sGsTlxoRz4bAuJ9OGg96t9JVyIAgbKiNVeOsqbdt7FNoQb9wgW5HX2q60m8Njwl+Vi0g6CBUFK9MTkXTT2u83t4RCPREREWkbxxUeNcRUtcW9Xlvo8Xp/pKKtPrairSE6cPOHbvv9kYAt3P0zXOFmTCSEC4dt7vsa/4XCL4+xAzBkByGYja2Ew4ZKDqEKtTjXn6triN891uNxhXDh0M0bCeUy3QFdzHSZrmnDXVch8nruMC78r7YB6qqjH6tvsM93V87lhAO5LCjKd4V0XntfZkZyvjp2HKiqtcHd+kpbiVdeDb48ex28AT1g3GBblZfs7rDqfiuSPsKVetpsRSTNKNQTERGR1tuSAREaQ7ZwwBaIDt7cFXANfvt64Yq2DFfQlmHAhAK08D/jCt4aA7ZQFVxGBhR4ISPXThMOuMLdRD0m5vpzMeGh+/2Gu8I2qeoLRJZHhie6K6o7XMt0VcLlxoZwMc9pTffSoBOqlnOFdDX1oXAu9p/fDjoRdCLXnct2VctlZ0J+QdOALssbCQQ7WkMgUoW3LtSVFqCHz4Z4xUNsFd7WqvrbXEoHRNKLx2AweBTGi0iaMUnYbynUExERaU+JBkSIDd7iDYhQ76poC3cf9QeiA7gGfyTAcpxIeOZxDWzgrnJzB20eE6k2Cwdz4aAt3wu+3EgI1/gzdLu5UCTcZbYhNoRzXaOuzg9Vrt9jl0X4d3+gabfU2HAtHLrl5SR4zHV7c8Oc8Huqa7CjwdZtSlBJ56qia/Db13Vfiy4n01YLFuTaoCsquMuyyzgdTlwdByprIuHdugqoqIYuocEsBvWG3YZBXnbqvR9dnEskvYQq9VJtVyIi0hJV6omIiLSHRAMixFa2xRsQoT4Q03XUdZ22cBjX4LodDLqq2DzRXUMbu5V6mla1uf+FQ7eCnKb3uQO5LanYCjquwNH1/mvqmg/nmlTPhZZZ1PXgYsO10GNZXhv6ZDbTZXVLgrjmBIJxquUamlbRuX+PGiwiMzqQK8xtWlmXlbntVIQ1+G032nUVkX/eDFuF19MHQ/pA14LUqRpsjmHbWS8inYEx2mxFJC1poAwREek8Eg2IENt9Mt6ACO6KtnDIFhvCubuOBgK2i2hGvKDNfe02E7l2W4aJVKlFVbRlh7qOhirZoqreMiJBXXsIOpHlUlsfHbYlCuEa/E2XZ4PfhlzeOMFabPfTbK8NF2Pvj71uXDJLKhwnMjBGbBCX6LY/0DSYC/8syov/WEd3G00Wx7HXvltXAWtDAV5VrQ3tevpgWF+YuIMNZNORut+KpBddU09E0lQyvupUqCciIoklGhAh3jXLYgdEaNKF1D3yaENMyBSalzGR6625r9HmcQVvsddti6paCwVtednR4Vts0BaukusIjcuzhQCu3t800KyPCeQCwUiYlhXTFdUdyuVkQWFMtVxWnGvFpUrfpnA319hArrY+cRVdeLCInJgqurxsG0Y1qaLzps777Wh1DdEB3roKG972LLKVeCP622616VCF1xrqfiuSXjyq1BOR9KRKPRERiS8qaGtmQITY67bVhQdAaHCFboHoEM7vCpUa/IC7O2j4Wm3ukM310339tsYgLVTBlheuaAsFa+EArjGM86TuiXYgJsSsjw3hwiO1NhPWhZen47jCtDhVceHbeVl2AIes2Co4VyCXSkFcIsFg9HXmGoO4eqiJDehCoV3QiVxjLjao61YYXVUXvn9bCZzaWzAIG6siAd7aCqiuteFdDx+MHGB/5mZ1dEvbj9IBkfRi7L9kXHBeRGRr0jX1RETSSTAYp4KtFSORxqtmcwdujWGbK0xynOiKtnjXbHNXtjUOiOCJDtpysqAgpootdppUDdpaEgg0DddiKwMT/e4PRJa9P2BDpswMW90Vt4tq6PfcLPDlNX3MXUnXkVWCWyp8LcLYcC58u7a+aXVdvd8ut5zY7qxZthtvj8Km4V2yu+9uy2rqYV25De/WVsD6Chuw9/DZSrxR20GX/PTdzjeHrrgvkl50TT0RSVMa/VZEZEtFjcLZzIAIsQMmhMOzuIMhNESmcQdtgWDTAQ7c12xzB3BNBkNwDXqQExoZMypoiwnbtsWqJMexwWjsiK6x14GLG8bF+QlxBmCI8zM/J/FADeGqOE8aB3HNCQ8WURsbzrm6usY+ZrCf0exM189QGFeY56qiy4qM+NqZAqOOFAjCT5tgbTjEK7frLBzgjS22P7MzO7qlHUvdb0XSi66pJyJpStfUE5FtU/g6bbHdE2O7k8ZWvcW7Tpt7oAT3yKP+UAAXCESHaVFBm7tLqeu+2O6j3gwbVDSOPOoaECF25NFtMfhpTnhdNl7/zVVdmChsc/+Mep7fLr/MmC6nWXGCuPBADbHVc1mubqqdZVCDsPBgEe4QLraCLiqoC3XBjg3mcrIig0WEb4cr63I60WAR6aC6DtaU2/BuTTls2GS3jV5F0K8r7DQIivI7336pJSr5EUkvqtQTkTSla+qJSPI4TmQkzeYGRIitenNfuL9JRZu7O2lMoNNs0GZC1WihwRC84a6krmq1cNCWkR0dvrkHRejoARFSVVT1YkzlW9T6illniYI7jyuI83qjgzZ3IJeTGR28xQvrtsUKxM3lDzQN4sK3a+JU0dWGBovIdQVw4bAuN8sOFuG+LydLg0WkE3/AhnbhAG9Nub2vpw96dYHxQ6B7oarwWkMlPyLpxWPUa15E0pKuqSci8QdEiArWEly3LRzC1MWEavWxXUdd3Rhju4R63ZVrrt+9Hhu2ZbiDttDP7EzIy4keddQbM00qD4iQqsJBXJMquJjQLV4VnPs6feHPTTj0jBesuUO33KzIY1ne+NMpiGtZMFTN2BjGuSvpwgNGuKrpahvsc3Ky4lfLdfdFgjn3/VoX2wbHgaraSHi3ptx2q/XlQe8iGNgTdh1qf9dZbtup+61IeglX6nV0O0RE2kiVeiKpKt6ACK0ZiTQctNQ3uC7C74+MPhpbCeUPDYjQpKItI7qaLaoracwgB16PDV/y3BVtMV1Hw6GbTnK2rvCgAu51H6/yzV3dGP48xJsuwxO/0i3q99CoqU2mc1XSha8RJ5snHLDW1DetlKutb/ozPGhEljd+SJefY0M6d4VdTpYGi+hM/AF7Dbw15bB2o/0ZdKB3F9uV9mfD7HXxMnXYtlWoH59IegmNfOvRdisiaUaVeiJtEW9AhCYjkcYZEMEdtjR2H3UPhhCnm2kwGBmsIBySZWTEr2hrHCAhputoVoYNX6KCtZhpvBn2+TqxT55wEOf+TPhjArkm4VycEC78GfM2UwUXDtqyQoM1uEO38LTuKjoFce0jPFhEkyq60M+a+qZVdMZEV8q5f/pyY8K7LA0WIRGOAxU1sGZjpApvY5XtHt2rCLbvAxN2gMJc7fvbi7rfiqSX0L5QW62IpBuThD2XQj1pX/EGRAi4grdEAyK4r+1VH6eCyV3R1jifYKRizR2MeWJCttiqNve0maHrUTUJ2mIq2nSdttQSjPmMxQ6a0eS2q+tq7Eir/kDks+DubtoYwoVCuexMe9LtbW46VT8mnXuwiJp61/XoXKFcTUxA1+CPVM3lxoR0RaHujrkxIZ0Gi5DWavBHd6Nds9H+/ejdxV4Lb1hfW4Wnz1TyqFJPJL1ooAwRSVOq1JPU4yvJZtpf7Elx3MqkmGu0+QNxArSMpuFb7D93kJbphdzs6GuyJQrbFLRte+oa4JNvo0e8jQ3vAsFIuOauhIu9nZNlg7jGEM5VFeeujNPnKPUFgvDRIthU27Sra4bHruuogC70r0tB0+AuO1PrXLYux4E5C2DlT1BeZQew6NUFhveHvUbbEWql4+iaeiLpJTRQhkI9EUk3uqaepKIiPv0Oxg2KVKvEjjoaOwKpDpxlS1TWQNla2H14pBIuXnCnUKZzafDDguXwizFNq+g0WIR0tKADXy+DoyZAt0JV4aUcXdZCJK00VuppuxWR9KJQT1JTbiaM2q6jWyGdhTF2kI8R/Tu6JZJKPMZWVw7v19EtEWnKCZWU9Ona0S2ReNSPTyS9GFXqiUh6SkapgUI9aTt1W5Fk8rgGGxEJMx7tiyR1Oejzmcq0bkTSi7FZvAr1RCTd6Jp6kqL0VZkkUXj0X33mxM1jVG0jqcvRfiulad2IpBddU09E0pRJwrcRCvWk7XQiLcnkQZ85aUphr6QyhXqpTX9TRNKLMRiMrqknImlHlXqSmtRtRZLJeOw/febETd2yJZWp+21q07oRSS+6pp6IpCkNlCGpSd9wSzKpm6XEo8+FpDJHn8+UpnRAJL2EzopVqCci6UaVepK69FdVksWYyD+RMGOwV87W50JSkD6fqU1X3BdJL6rUE5E0lYzdVttDPV/Jw8ByKkr/ttVbs7l8JQOBeUARFaWBZqY7ETiVitIDttLrPkyqLYtkMAYy1G2lXW3/B3jrGhjUC/76GPTpAuce2vxzjr8RjvwZ/Gav5LSxPR14BVx1AkzYwX7WPPrMRTn9Njh0Nzj651tvnre+CGVr4ZYzWp52r0vh2pNhz1Fte97WpM9F+3Cv2/bw4UK48AGYfX37zD+VbCufT/f+OJla+7cv1or1cOCV8L/bEi//dD6Oufgh6NMVLjqyo1sikjyexMXPV7xRTq+CDM6eWJD0ZiWyqjLAMY+v590/9CSjmSRyxsIaXp5fy91Hdt0qr5uKy0Kks1OlXmtVlC4DWt57VZQ+Djze+LuvxAGGUVG6uN3ati1q7VdlP6yDix+GL76Hft3g6uMTnyjWNcDfHodXP4OcLDjzQPjdAZH57HUp5GVHpj/zIDgvdKD/z2nwxhewthx6d4WzfxUddgz6PeRmRb6VP2w3mHKqvX3Li3DXDMhybQozr4CBPWHJavjXMzD3OwgEYcdBcOXxcNmjcNQEe0Iw+RHb3rAHzoWJoROfPS6BdRWRE4fxQ+DRC+ztZ2bDw/+FpWugIAeO+BlcfBR4MyLzOvBKyAz93qcL/Pkwe3vOQjjhJvuewq4+wf4MBOGSR+CD+bCxCop72fn+cmzrluVFD8KLH0Oma3l8dbt9D3O/g5tfgK/K7O8TdoArS6BXl5aX5eashwHdQ9dMc11w3nHguunw1Pt2mt/sCZccHb/iwnHsPJ94FyqqYe+xNqwozG35vQKUvgf3vAprK2DXoXDDadC7S/Rr1PvhoKuguhY+vCFyf3PvtbwariqFd762v5+0N1xweNP2f7gQSm6Ecw6G/zvK3jftg8hn7pPFcMWT0Z+5zxbD1U/B4lWwXQ/4x4mw27Cm8/6/h+xncNY/bXAMMH0OrNpgtyWwn7m3rom/LANBqK2PrJvwkfbGKtjnb7B9H3hmsn1uS5+51T/Zbf+Tb+0yO+cQu0xiPTPbtvu6U6Bkr9QcKOM/b8C9M+3+7KBd4JoTITsz/rTNfb5a2pYunQofLYLv18D1p8Kxe0Smq2uAKc/Cy59AbQMcvjtc8ZvI5/yRt+yyXLjCfi5v+m3kuT+ss4HI7++KbAdtWVfNteuyR+H5j+xnp74BRvzJ7t++uTN6uXz/o933HTwebv2dve+tL+HuV22bszNhv3Hwt+PsvhNa3m/d+LzdXhr8dpmedRBccISdbvYCuP1l+GYZ+PLg/Wvhpudh2myorrPLEyL75vB+PPazfvyNdt88ZiAsW2enLcqDQ8bDsH729wfetPv9nzbZ7eHQ3eCyY6L3+xB/23/xYxugr62w7+EXY+Cq4yP7s/P/Ax8sgJo66OmDPx5kt5NYt74It74Ej10Q+Xt87TN2/pU1ts3HT7LrFmBDpV0uf7rXrruhfeGvx9rPbKzwMlh8b+Q9ldwIi1bYfeWAHnDhEXDATpFlf1UprNxg19Xuw+zfsj6hk9trT7Y/4+1Xvl0JFz5ov1CorIFRA+znZVg/u++76Ej7nETLOtX2HW2Vil27F6+Cvz8OXy+DbgVw6TF2PxhPS/uplubV3P6zpb+xzf2dbOm4obl94MeL4LTbo99ndR3ccyb8anxkHxjmD0TvA0edE/3c2no4eW8bqLf0nrfk+Kul/VJrjytao6VjuNnz4Z/PQNka6FoAZ/0KTphkH2uuUi8FDwf6+zKYc1avFqc7dEQuh47Ibfx9p9t/5MVTujOwy2aeoqfgsugojuNw2+xNPPdNDQBHjsrl/D0KWhyJ9PI3ynlxfm2T9TBzUS33fbSJVZUBeuRlcPX+Pnbpn8UrC2q45u3KqNet9cMTJd0Y1StyDNgQcDj2ifVU1zu8fkbPxvsDQYd7PqrihXk1VNU7bFeUwf1Hd8WX7eGatyp4ZWFt47T+gENmhmF2zGerbKOfYx9fz35Dc/jXgUWN92+oDnL9u5W8v7QOY2DPQdlcG3r814+tY1VlsHHaer/DHsVZ3H54dMD84vwaLn+jgsv3KeTXY/Ia75+/poEb3q1k/lo/uV7DGbvlc+JOeayqDPDrx9ZHzaOmweHCPQs4ZZf8dl3W93y4iQc+rSIzI7KOp53QjQFFHRt5afTbzsZX4qWi1J/yr9Habivn3Q+7DIFH/gxvfWVPCmb9C7oXNp32tpdswDV7CqwptycHw/rD3mMir/XV7U1PfsAehDxwLmzfG/63FE65FQb1jj7pmHmFvS/eezl0V7jt900fq6yB/XeCm06H/By47WX4w132hInQMthlCEy/JP77N8CD58YPMmvr4YoS2Gl7e9J0xh3QJR/+dHBkmvMPhXPiVCgY7IHcRzdE3//MBxAM2gD1qb9A/27w9ldwzn3w2lX2YKylZWmMPRm8+Kimj1XUwAm/gEmjweuBvz9hQ9tHzrcHas0ty7CW1sNNv23arnBoZIw90H7jCzsfY+DEm+1Ba7wQaPpseO5Du37ys+Gih+DKJ+HmM1p+rx8uhBueg9L/s+296kn7eX76L9HT/fs16FEIy+qabhOJ3us1T9n1/8F1sK7SBrQDusNxe0amafDbg+idtyeqC19zn7mNm+B3d8E/T7InPy98BGfcaUOKItcf0U++hWVrQ/Mjut07DoIX/tr8sizKg10ugEdnwYG7RGrKjbEH60P7QtCJbjPE/8wFgnD+AzBqO7j3LPh2FZTcAEP6ws9HRKYrr7InM8P7ReYZO/9EAsHkVOS88zXc+yo8+X92+/zDXTZAueSYptO29PlqaVsauR0cujtc90zTrun3zrTB+xtXQcCx+5Y7Z9gwBWzbzj0U3v3anky7nxu+ff/ZNjSK1dK6aq5d155i/81ZYOez58j43eovfwLGDY5uT2WtbfPPhtlw6Nz7bRD1r5Mj0zW33yrIgbED4Z6z7PzvfhV2GWr/vuRn2xPL2np7UjzjM3j6A/tZ798dxv0ZuhXCu/+Knq/7sx4OKwHu/KMNyhsC8Ps74dx/2/0vwP7jbNBZlGe31zPvhYffgt+7Og8k2vZ3G2bb1K0Qqmrh0kdt+Bg+4T/7YLj+NBt6Lg6tmzEDYeygyLzL1sCrc6FXUfSy/81ecP7h9m/p6p/gpFvse/vVeMjPhRtOh8G97PSvf2E/U3Nvid6en/swsgzc876yxAZt3gz4fAmceBO8/U/7ORzezwakvbvYkOem521g8sC5iZd1eL69u9r1OaA77DHZ7hfbsqzTufvt1uzavbX2j/6A/TLgxF/A4xfZfdwZd8AO/W0YG6u5/VRL82pp/9nc39iW/k7G/q3783+ijxua2wf+bAeYf1fkPc5ZYNu991i7rsL7wLCLHozeVtzPra6D8RfCIbvZx7f0bwYkPiZpbltp7XFFazV3DNfghz/eYwPcEybBl0vtlwI7b2+XuTF2s43Tkc00/kvTbTqGCf23ec9N7WXhOA4OJGUU42e+ruHt7+qYdnwPMHDmcxsYUOTluLF5CZ8zd2U9y8ttpz/3epizrI7bPqjk+oO6MKZPJmurgo3THDoij0NHROb5wrxq/v1xFaN6Zkath0fmVtEt10N1fSDq/ns/2sT/VjUw9dju9C30sHiDn5wMDwbD3/cp4u/7REK6v7+xEWOafj6ufbuS0b0zG9sUdtGMjYzulcnM03uS4zUsXu9vfPy5kyLBouM4HPLIOg4Ylhv1/IraIA9+WsWQbt6o5fFTTZA/vbCRi/cqZP+hOTQEHX7cFMRg6Ffo5cOzIvua5eV+Dpu6jv2G5kTNuz2WtQEOGJbDtQfGFGF0sNSo1POV7Aw8AAwDZmDHdAs/1hV4FPhZaF4fAGdSUbocX8mxwCVUlI53TX8RsBcVpUfiKzkYuBHYDqgAbqGi9MZm2jEfuJiK0pdDv3uB1cABwAbgeyCTilI/vpLTgMuBnsA64G9UlD4euv93VJTuia/k3dCc/xeq2DuDitKn8JUcClwDDMJ26T2TitIvW1wWW9bu3wFXAEvxlRwA/Af4FZABfAscSkXpj828xixgDrAvsAMwCziditIN+EoGNXkNmISvZAJwMzAKKAP+TEXprBbfDwCm5VHjlqy2lQ9PXAR5OfabvwffhJlz4eRfNp1++hwb6HQttP+On2SrSfbZMfJangQjoP6f60Ru/FDYfbg9edh9eOT+39wAZ+xvX6dsjf1WePLR9uBt+XpbUXfPn2ywBra64+qnbDXAw/+1J06/PwDueNm+t8+X2LXfJd+26YonbJVhZQ0M7g1XHB9aVAmW1an72oPpu2fYb19Xb7AVB7/+uQ3lIDLi6wUPQN+u8Jdf2/s//c62d/Q59gTvmpNClXgGcrLhov3hx43wq6ttxeJ2PeH+1+HtL+03vGCrMo7Zo2m7wicKz8yGJ9+FMcX2ILdXkX2dfcfZyY6dYg/E3psHO/wJ3rjanmx/vgR2u8jO47g9bbWE+4Qh3ii2Ey+2J8FflsHIs2HhPbDXJfYEda/R9uT45U/tN9EbNtkT+x5F9uT1jwfag8RT9ome55wFcNlj9kD78GvsfP50sG33N8tsZUimFw7Y2bbnrlfsAeR9Z9vn//dL6Flk5331ifaz88u/wc7n2+cdtycct4c9md97jH3f/5wGT71nq1rc73XixZH3AvDSpzBhuD1Zzs+1IelVpfCPp2yIcNUJ9vM3abQ9IXF/hsIB529ugF9PtNvJ0+9D6bv2s1BeZcOOghy7fm9/GV77HEpC33T7A7a675Yz4IAr7EnB4lX2hNgfiH6t1z+HKdPtSb43w85vQA/7WGGuPcmoa4iclHy+BBattPOZ9wOMOdeGPOEqL4/HBqs5mbYa7MOFcNcf7c8ff7LLriAXBvexFYnuMPz65+D0/WxVx/c/ws8uhuP3sieGj75tt42jJtppL3gg+jUeONfuC64PVYXU++3JyeUl0dWuW2r6HPjNJBixnf39z4fDef+Gy45rOu1/v4RDdo2edreLbIXXoF6RZZpoP3v6fvbnrS80ne7N/9nPejdfZNprp0X2k4fsZn9+VQarfop+rvtz5vHY9XvtNHjpExuorKuwJ43ZWXbfMG4wnHm33ZeF90WTRsNfH7XL+4on7Jc4Zx0cCd49HjuvVz+Dh863X+Jc/gR8tNC+bp8udrtcuibSnl9PjLQxH3uyf9PzrrY3s7z2HWerW2/6LfTrbpf1W19G/r7sMtT+e+8bO/3y9bZiLHzym5cNK9dFz/uzxfazfsIkeHyW/VLq1t/BEf+01dEZGeAP2ucsXRt57mBXuGE8kGHsft897/+8EX/bD2974WXo9UQ/N/xZArvPNcZ+nsZtH7n/8ifgsmPt+nHPO1xJGG6XJ/Rcj8e+/1NusfuwPUbaLwTKq2HsefaxIyfYKij3MnD/rR5dHPp7WgoLltuw4s3/2eOArEy7H/rXyfY9Bx0bjj87x+5vLnjAzmPJajhid1spPvZc28bh/WzV3gUPwIoN9u+VPwj3vWaPNyZdBt/fb9vx2zthzUa4bybc8oJd36MHRNr4zAe2mrOq1u7rn3ovep8dz83P289AltfuKwf0gH+fbUPh/7xu77/h9Eg4XlFtl8HbXzX9+/j0+7b94wbDtPftccVtf7Dv+8bn7D7rr8e5Kl+NrV486Wa7bMcU22Uf/owsXgWXP27/pnYvsNv+Ybvbx+LtH5t7n621ZKU97vjDgfb97TUadh1mj7Eu/nXT6ZvbT7U0r5b2n29+CVMviPyNLdnLBvUlk2DuEvvFbHh5xP6d/O+XdvrwsvzTwVByvQ3jgo5dZveeFdkHHlqjtpMAACAASURBVLJr079XYdPnwMG72r9rsarrIvvAePutV+faLwwn7GCXwZb+zYD4x1/Q/H6ppeUF9hj2vpm2t8y4wbYC0L2/iloms+167R963H0MV1Fjj6GP+bndh+48xIb5i1fZZR0K9TzGVghd8WY5ZRsD7DUouzEX9Rgorw1y2WvlfPVjPf4g7Nw3i7/v46NPYQavfVvLA59u4unjI+17ZG4Vn62o5/bDuvLu93Xc9H4FqyuDFGQZTt45n9PGJw4vD5+6lov2LOQX29uqcX/Q4Zf3r+G+o7pRlGM46KF1fH5ub7wew/Pzqrn3oyp+qgnSNdfDORMLOHRELs/Pq+bZr2uYelx3Tp1mq5uOe2I9GLh6Px8HDc/lnSW13DFnEysrAmzf3cvff+ljh542wGluWSTS3DICErY1kefnVTP96xpG9srkpfk19Mj38Ne9fUwYaHtonP7Menbul8Uny+uZv6aBZ0/qQddcDze8W8l7S+vwGDhiVC5nTyhotqtyW720oIZTd8mnr8++r1N3yWf6NzWU7Bg/1PMHHaa8U8E1+xdxzBPrGzsLAdzz0SbO3L2AnfrZ48a+hXEKIxpft5bDR+ZGvZfl5X5eWVDDxZN8XPnf8sb5ltcGeeyLaqaf0J0BRXaeO/SI38OjuiHIm4vruPPwrlHr99WFNfhyPAzplsGyjYHGx2aX1fFjZYCHju7W2JZw8BfrkxUNbKgJsv+w7Kh53z67khPH5fPatzVRFaCPfV7FHsVZHDbSfi5yMBRmx9//vLKglvH9s9jOVS3XXsva3XkolSSjOc2Her6SLOB54FbgTuAI4ElgSmgKD/AQcBw2gHowNN2RwIvAffhKRlJROj80/UnYwAxsOHYcFaXvhcLBwS209UngeODl0O8HAuuoKJ0bCq7Cbc4Hbgd2o6J0Ib6SvkC3JnOrKJ0UCvPGNXa/9ZXsEnoPhwGfhtr7Ir6SHbARTnPLYkva/QtgJBAETgWKsGFnHbATUNPCawCcEpr398DU0DI4yfV45DV8Jf2BV4CTgZnYMHA6vpIRVJSubTJnX8nLQLiMyHDVk/bgC2C34TD1/Kat+XalDX18rh3n6O3s/bFb2sYqewA3ZmDksdED7YGyeyufeDFg7MH/34+zJ5Gxaurhy+/htH2iX2dNue3qMWm0PVg//TYb7uw1ygYzHy6EvS+zB9kH7Ayn3gq3/96GZe/Pt1U3V5bYcGtIH3uSmZFhT452PM+eYB23F1x4uP2G86y77QnLeffb6rkxxba72OiBkTbd9zq8+JGtVPjXNHsgn5cdafe/X7NhnMfAL0bbn58vsQGU49gumP4AvPSx7X4Z/npuxXpb6XjmQXDgznDDs7BsDbx6pQ3CJlwM1zwdWR7uZWmwIUldg12Wg3vbCqsZn9llMOd62yXCYAPaHfrDzCtte1773IZlednQ3QfPzbHVgu4Q99gpkWrC71bZg8bKWnsiHTbkDzaUCv/1eOhNeyL5xtW2ImN9pQ1X//JruzwXxflMGWPfQ209fHSjPRh/4UO7vP50sD0RPfo6ezA641Pb3WvJj/akrjDXvp+yNfaz4jH2m3qw31b/fKT9fLzxue02MneJDR6H9oWv7oDHZtluNsdeZ1+3staGIbFt9BgbqjzzgV0O8++yn7Xf3WGX8RtX22tKuf86GWO7IzUE7IHumnJb5fL59zY02b4P/HY/W0H52c32fSx0LZ8H3rCBYvhzuMMAeO4y+7k6dortfrPjeTZcXLTCVmFO3MF2h5z2vv0GPdy9pyFggxdjAAf+9pg9iX34vzYEfGayDTrDy27ixTYMaAjYCtap58OGKvvY30vsZ3VjFVz0gO1mGW7z50ts4HrtyfDKJ/b11pbbaf98mK3IPfkWezIxtK9dXi+Etqup50N9wG5fy9bC61fZ7k5n3we3vwiXHtt0H/LxIrt+E3nk/OgvDMIWrbTvIdzuMQNtiL6xynYfi8e9XgG+XWErjo2xJ71jz7X7nNP2hVP3iTMDQ9RRVtx5Yz9nm2qi98fh/YX7ueHb591v9xXdCmzo8MbVtov5xMk2sLjyeLte5iywQdn718KP5Xb78RgbfP/uF/CnX9l960m3wM6DbdWYMVBXb/cRE4bBIf+wy23KqXDI1fBTld324h2V3fmK3f/V1tu/lqNDIXxNvf1cPfq2rUg+91B7AgxN/758vMiecH67Inr+4XVw5M/sPvX7H2FgD3vybTww7jy7H7/s2Mhnff5yGyid9atINziPse2qqrNh58VHRb/Oc3PgkqmwqdYu38tLIo8vX2e7pb12ZdNtH2zbT7nVnvjmZtlAxv34pVNteFFbb9/vfuMij7/0id129xvnCvVcz73zFRvMVdfZv91HTYh+fPIjNuBvCNh9wjOX2PW9YIUNcE/5ZfQyCD931U92X2uwz91xkP2y4NBd7WfgsmPgjNtpPOQdW+yqWg6FfFMvsOFWlhc+uck+NHeJ/Wy+GbpcQHhZn32w7UYO9survz5ql7XHwH/OtX/zTr4ZPvvO3rdohV3Wj19oK+evewZWb0y8Xbk/L29+AQ+eZwO1Cx+0Idvxk+y+9+kP7PoIX5bhwgeghw8+mGKX8am3Rv4+hr8UOWESXHGnfa9n32t7CnwwxW5Dv7/LLrP8HLuonvvQ7t923h7++bTdZp+/zM77hBvtsnjsQpj/Axx/E4wYYP9ex9s/xr7PS6fC8x/Gf9/9u8Ob/4izPIis+8YKHCf+32e3ePup1s4r0f4zPD/3tIvC27shVCYUeSz272Rsu+r+v737jm+q6v8A/rlpmzYdoaWDvfeQJRscgOBiu6qiuBG3D7gQFR8H6iOCzwOioqCCGgQVZKkMmSLIUFQEARd7t+lKmyb5/fHJbZI2bR9/KpjHz/v1itLk5ubcc88999zvPefcYp7r6qUHfi942Z37y25jQSHbTW/cHX77l2xm+e/eLHyPy7nrGEAr3Yvy95wzzPZXx8a88VwnKPBWbr1USX59vIV18ht3s704eRFHh3xUzlTjPxxg+yO4rW/u12rJrH/nrONxsfVHtme7NC2pUwyDwYC7F57ENe0TcFXbeKz4sRD3L8nCDR0TWGQADGllwwsXJ8Pr82Hs0myMX+nEfwamoE/DWPxzeTZ+OlmMRlXZllm4owAjOifCYgCPLcvGCxcn48xaVmS7vNjv9FRYfC9qZsOSH1zo1YhBvfW/FiLFZkHrajHYn11csstcxV48syoHszNT0aBqNI7meZDt8pakF/4iNfPyVLSadAjvD0tFPf9QxO1H3Hh0mRNTBiajVbUYLNjhwl0LTmLR8HTAQIV5UZ6K8ijfXX5aK1rfN4fc6NckDmtHZGDZbhfuXZSFT25IR3KcBQYYYHtlcArqp0TD5wP+sSgLqfEWLLk+DQVuH26bn4WaSQW4PEzAbeGOAjy5wlnu738wLA017WUDP3uOF6NFenRJ2ptnxGD36pxyt2XW1nx0rGVFC/+QWfNQ93h9+O6wG70axuKiN46iyOND70ZxGH1WEuKiQ1d2wOnB5v1FeLKvPeR3nlmVg3t6JMEWHVo97TlejGgDWLrbhbe25iPRamBY+3hc1bZsMHn57kJUtVnQuXZMSRWQW+jFlC9y8folVfHBt/kh1dO2Q27UT4nG2KXZWPNzIWpXicJ9Z9nRqXbZG9oLvi9Av8axSLQG6pxth4pY/vrY8WmpoN62Q240TYvGNe8dx69ZHpxRPQZje9nD7ocFOwowonNomfyz8toAsOqnQvR4+TDSE6JwVdt4ZLYtv2fmqXIqgoyV9bnvCiAGwCQ4HW44HXMBfFnyqdNxHE7H+3A68uF05AB4CgweAU5HIYDZMANL9sxWYO83M7jlBtAS9kw7nI6TcDq2VJKWdwAMhD3T3DNX+d8LxwugNeyZNjgdB+F0fFfJuk03A3gFTscGOB0eOB1vgoG1rpXmxe9L9zg4HXlwOgrAfEkF0Nifhs1wOsqvyQJmwun4Fk5HHoBHAFwOe2bwkRX8G8MALIbTsRhOhxdOx1IwiHlRmPUCTkd/OB3JcDqSATTBuKvYm2rnVM7LYzbgg1/5hYDdFvqePT5w0Rf8Kijk71SJD7xXJT7QEE9LApY8xsb8p+O4jjteDf+7D73Fbvq9zwi898FD7On29DA2yu6bwaFMHRpx3r4144FHr2CwbtJHHLrRpw0b1NFR7InVvDZ7OI0L6oHXvRnnJPv238Ds+xiEfG0pL2SLioH7BgMbn2e6e7TgsKOc/EC63l3N3oJb9jBo8cgV3FbzyJ/zALB1ItO14EsGJRxrGFBc/gTw9STgw4f4/uMOfmfXQeDSZ9igv/IsDkca2o3b8cN+DjVb8hjw1aTweXlTX15EPHk1g4yLN3NI85CuTMeKbVwuz8Wg2dPX8ELLmc90rB7P+WEm3ci7rq8vC90PG59nfndoxDu1303mhc39Q7it+6bzwiTXxYCB2Wg8rx0bqvmF/h6XnwfKSZ4rcIYseYF3mw+eBI5lAx4Pe/oBbHjGRHEb66UD0+5gYNPj4RBPi8HfKnQzv/YfY49Ew9+4zajCoM6hLAYODLDhfc25XO8V/gvSRY9wW6MM9jTzernuBhlsxOa7GGSLsjDYaJa1mGj+P8mGkiFi5naZZa5jI2B4L16crfyGQ4vuG8LeKDYrgxgzlvFuuzn33cETDDjeP5TBV4B3yW1W9mg8qyWH026dCNRJ5UVy/QwGd27qy/358WZedOX47zMUupnG3Ye4T9s14AV/lIXrvW8wg49zH+Bx0LctUK0Ky0V0FJBhZ/l57VMOQ993DPjih0CafT4GSJ8aFjQXlr9e+scg5nePFgxULPwSJS3k89vzQiA6CrDFAO+s4lxdqUmsh+4eAMzfGL4O6dosUL+Fe3VtVk6d5ypbhwFAQZg677y2PKZ37GMeTvqI+9nl5ucDO3O457f/AZ6/np/P31B2PQDLevB7vdsA05cyP49ls4e0ua+Clwu+nWm+0pJYvqeMYP3ws7+DeEYV9lxrWpO9KorcHKpqMXhDIzqKx3HTmnwvOYH7NsrC/XNOK2DjrsCxWVAEXNadvQWP5/BmyosLGBga3psXyTDKbu9d/dkbyhbL48DcJwsfYV3yzb+BB4ayN9Km3WXPLzv2MS+v7RU4v5TOz+opHEZ39kNAoxEsx0v/GajHL3mGAbN2DYB9/vncbuobaE1ZDKbp+yncz23qhf7GJd2BXS9zaOC1vXg8mJ89+g7TH+7YN8vmD1M59PW2Cxl8C/782eGcz27eGPYQiosJ5MGz73MurJJyEyZvd7/MwPel3YHk+NB8ef56/naj6jyGTuYynTFRwKZdZfPAfH24nr3s9rzCINPQbgyeffYNP7+sB3B9HwbkE2J5o8T87q4D3B/tGrAsuT2su2JjAvXMzqm8SXT9eUF57U/H0K7M63YNWB+c2ZC/MbAzA+4Wg+e4fu2Yt3ExrB/LnE/CvAywnPRuwzpsYCeW5bv6M31DujC4mJMPHHdye5+4mjesMqqwt9JHGwPprZvOgGBMFAMbB04Aowax/PU6A7BGMdht/vZ5bVhv26y82bJ5N+v45V+zd/6VZzNdbRvwPLV4U/j6Md5adtueHV5+/bfiyfD50bQmg5Yvf8xz6ervGIwsKAq/fEX1VGXrqqz+7HUG66d8F/Ns9prAdzs3Yc/w+Ru47rnrQs+Tvduwbbb/GM91Ly0OpMsez7bjix+xDvz2F5YfV5htXLyZwbEezcNv/9x1rAPNBz4Fvw6c4PZe0fOPO2cEt7+qpzCobLZJKqqXKsuvWSuBOy9mwNgaDdwzAPhuL4Nx4bY7L8x5MrgNN6Qr22oNbgaGjmd9UCet5JxlgMGjYi9wXYd4xEYbuLBpHFpXiylZRdV4Cy5oGocEK3sO3do5EZv2F8FiAHExBi5sFodFOwpgMYA9x9044PSgd0P2ToqJAn48UYz8Im9JcK6iamBAizh89mMhCot93O07Xbi4uS30FB20/J4TxSjy+FAtMQpN0wLrDq5ySn9n7rf5uLyNDe1qWhETZWBoKxus0Qa2HXZXmhflvSrKo8rSWtE6zXRc3NyGBinRWPMTe+HBAIa0tKFpWgysUQZyCr1Y80shxvSyI9FqQXpCFK7rEI8lP7jCrntgCxs23l6t3FftKlFhv5fv9sEeZyn52x5rIN/tgwFfmWUP53ow55t83NU9scx+OFngRbEXWLrLhVmXV8WHw9Kw44gbr27MLbOej74vwJm1YlA3ObrkveV7XPB4fejXJK7Muo/keZBT5MMvWR4suzEdL/ZPxktf5GL9r4Vh1z2oZRyiLEbJe5PX5+KS1jbUskeVadYdyfXg81+L0KWOFWtuycD1ZybgzgUnS4K05quw2IdPd7swtFWg7Pp8Pjy5womHe9kR7S+kwes+nOvB/O8LMOZcO1bclI46VaJw/5KsMmnesr8Ix/O9uKBp3CnJ6wub2bBoeBo+vzUDT/S1Y+qGXCzZWVBp+f2zX6dito/Kht/WBLAfTkfwMNNfSv7FQNVEABcAMGdVTII9M8r/FNo3AbwLe+ZYsFfYe/5gHwBcAmAsgGdgz9wGDtVdX25KnI7d/qGsA2DPXABgIID2YZbLgz3zCgCjAbwOe+Y6AKPgdOyoZFsBoB6A4bBnBk/oYvXng6/CvPh96d4b9O+ZYC89B+yZyQBmAXgYToe7kl8KXscvYAAyrZzP6wG4DPbMAUHvxQD4rLLNAQBeRFYSD06y+S+agpbLdXEYQunvJvkvfvOKOFQXYC8Hc9mkeAYMAM6j88y1HPqTVxiYvBjgHCM797PxEhUUz+zRguupXw0Y1os9weqksWHdwj+UIcHGhvjN/dhIOZQFLP2an3l9QF4BcHZrNnxmreTRGTxkYfV2Nt6ffZ+NyZwCBq0S/Ntzz0Defdy4mw1qgA23fSfYQJzzAId7ls5DWyyDUIezGFA7eILDycx016/GO6rDJvC9D9Zz+f4dOe+UNZoNvMFdOI/UqBlspI27kkOuSudlO/9QrehoBnTa1Ocd5a7NmGdHstmg27EfuKQbe60B7K1S7GWPLpOriOk193cP/7JxVuCpa7gfdh9iXnZswh4/AC+UkmwM7lgsvPiqmsh/J8RxHpfDWfw7r5DvBe9vgD1r0qpwf13yLINm5qT6Vz4fSJO7mBdiQ7uxsf7BevbE2XOIw6ZumsyLDq//sB89gz1Wcl3MH4slMOTFXKc51KbY5x9OnsieZbsP+QPObXgx1/1B/r7LzfU3u41/F7rZk8hcd/CQGrPMWSzMr1GD2euyZgovgt68l8eBWSbPbsVgi8XCoPSowUByItMCMO/MdbdpwDJpi+XDT2pWZZm7qR97AU6Yzx4tsTHchy43e23kuZhfcx5gLbngSwapm9waWHedNPZctcVynq7XlgbK3LQ7gNHT2UMwIY7zD2Xl8bvTlzHPzJ5x5lxSyQk8Zs28McummWfmNgMsPwVFoWXT52PQsrJ67LdIiOM2mevM85/qkuLL/s45rRk8uGkyA+IjLmD5rJXKZc3jG+DxcHM/YNGmsk87NlB2SNW9g/zzgT7G43/Yubz4zEgOXS7ccK2keO7f6CjWtR4vA2/mvnr6Gvb26DiKZbV9Iy5bevuy83hhNs7Bsl1QyP1osQDHc3nT4/KzgK9/4rHc+FYukxDH5TPs4YeSbdrNXpav3Rk6ZNSstwCgb3vWTWa9ZZ5fvt8P3PBvDhG2Wcuei8z8eGE+07V1Es8Rcz9nD6zV4zks718f8lwAAHPX88aANYb7AQjUBYk29qK6axqw5tnAXKymxjU5lO6hmcCMu9nTOdcVGEZe0XC6WqlA77bAyKlle01ZLEC35qzL3lrJsvP8PAbPzCHFFa27bQP2jnt+HqceCF4+Po6Bub6PAt3v57kmpwCYcGP4PAB4cb9wU+B8mudiIKNni8Ay1/QGpi9nYPCuaXxq7TEnbwhc04vL9WkbmGML4E2Uu/xNmCgLe9iPfIl5XTod8bHsxWzmdXwcy6/FwvJnHncA91tK4n8xlNHgOdtcxhbLmwbmgx7MtkyBO9DDsV3QqAavN/C7hoXlw1yX+d1qQZOVx1n9gSmzjgtKc1I803zEyXPx1j08n5iKPdz/4erHP0qslb21Hp7JnlttGwADu7AOCvdbFdVTUZaK11VZ/fn0NbwZ1P1Bth2GdGPPRosl9Dw5ZibPN8HnyavP8fcu9bcbbr2Q80ia6546kg8j6ziKgdih3fw9zUpt45x17HFaum0C8JhYv5PHTbi8mfs5g67B89/93nNGee2vlkHfA8rWS5Xl1/7jnF/58dlBK/HxfPzhF7xZA/BGwb+uD3+eNNtwuw4At04FZtzF7f3xMOveGlV5k90fsTia50G1RAssZjQAQE0zoGFwQv7xK51Y+3MhsgvZdssr8sHr8yHKYmBISxtGLc7GPT0SsWCHCxc0jUNsDNf17wEpmLohFy+szUHTtGiMOisJ7WuWP01H/ZRoNKoajZU/udCrYRxW7CnEh8MSS5oqANOUYLXghYuTMWNTHsYuzUaHmlY8cE4SGlaNDlnOZAT9fdDpwfztBXj7q/ySz90eH47meWAAFeZFeSrKowrTWh4jXDosTKP/rRpJUYFtyvGg2AOc/eqRkuW9vtBl/gjxMQbyirwl68xz+xAfY4Sk0zR+pRO3dUuEPS5wTJr7Ic5fPoa1T0A1/1DQ685MwMsbcnFvz9BRYx99X4BbOieU/Ga+24sJa3LwypCUMuUCQEnvs9u7JcIWY6B5RgwuambDmp8L0bN+4AFzB3M8+HJfEZ7oaw9Mw3nEjfV7i/DBsNTQ8mOuO8ZALXsULvPPIdi/uQ2vbMjD1gNF6NM4rmT5ZbtdqBJnoHMda8l3392Wj2bpMehQyxqy3uB0n9c4Dm1qxJSkv9vUI8gt8oYMw53/fQH6NolFYtB7f1ZeA0CTtEA57VDLims7xOOTXS70b1H+8PFTIUyR+8NVFtQ7CKAW7JlGUDCrLoA9/n+PAudw6wKn4xDsme0AbIVZZJ2OL2DPLAJwFthD7aqSNTsdXwIYBHtmDIA7ALwHBrMqYg5ltQDYXu5Ta52OTwB8AnumDRzuO82fhsrsBfAUnI6nynxizzwHFefF70l3IFDI4N3jAB73D89dDGAnOFy5IsF5Vxfs8Xcs6P3gYOResGdfBTPqBrFnLkEg/wyMfZsXawAvmmbfV/Y7LWoz+JPvCgQ5tu/lxVbpkl01kd3uv/8VqHZGYNnmtcIfBSXzPiHw+bPvMwAx/+FAD5ky3ysVLg/uRxx8kRNnZQN44o0MLgwZD/Q6g735Qpb1f3f9TmDyQuD2i3khteJJoPGIssM/Sg/0T04AnnufvZhaBw3LDV4+OH0AG3Dm3XpTlBHYu/cP4dwrPR5koMNxHy/S+7Tlq6CIc66Nms7eLeHy0vz74MnAhPUWg423Tk14UV87lUOvze/UTgNio4GdLwV6VP17IXshhtuHcz9nWi4cxyDWtRNDG7fmkBOLwYud7Fz+u3ktXthXT+Hf5ZUTc18/eAlfAIN5h7LYGyVcQ7p+Btd96CTvsi95FGhai985816m6esX2fui32O8AG99Jy9S3cX8d/DT5sz9Zz711czjXBcb7FNH8m76vA3smfDq7QyavbMKePVTvnLymdYd+wJPTi7ZR2b58KGkV1PPFuxVlH4NA7dXPMcePRaDvQ03/sC5Ir3+Ce0vepwXQJd0Bw4cD6yzRkrgqZ8WI3CRPP0uXhy0vJ3Hba2qzB9XEZ9w6yry98a1BJ4k2uy2QPrM9QXnx0Vn8uUuZs/Fp+fygsRiAGu38wmZyzmtKbJy+TTtgkLAVRhI7/4TrHNK3/IDgPQkBnHWjufFQWXW7+Tk5+Vx3Bd42nCw5rVZHod05d/f7+VFf5q97LIAAxg39eW/9xzk/Hgt61Rc55X5zCh77CbEsqeN+WTDt1bwOI4pHfg21x3u9/z5l5HM8m7+htfHY33LRNYhn3/PHmHB6yh0MxgzvA/w1NUMclw7MbDeVd/y4rxhNfZgqpvOIePj5wSeJH44m0Otz9sfeALztp9Z9xR7yh8e/ctrodtkMVhO0+zA8Im8KL6iJx+8ULreMP+9fS+H59f232S46mw+hXP3AQa9PR4OU3vkHaYfAKoPZ1AFYODm9Tt58wQ+1nOHT7LnS2leb6A+X7udwcTW/nuKFR375nd/PhJ+/wEMyJrrXrOdN1hmLOdnx52cTuHO/oE5L8t892jZ/LEY7FGXZueTSnML2Rv85sk8Fs16xcyDbs14zjLPpwB7OvZty2CJ+Vv3z2AA5L217BGc5wK++pF599ZnnJvMVcRXciIw5372SO/QiAEG80LJzGtzbtzgesDrC+3pZn5ePZnBDXO5giL2Qgz+bjilz+cV/T/c+TFkXf7/lD7fl/794DbBgROBf+e6mOaaKSy33ZtzeHR5Ktu20TMYlAqnThqw9pnwn51RL3TY5UWP8yEs4X6rsnqqsnVVVH+mJgGvBAU1n3wP6NAw8F3zPAmwPuk0KnCetESFths++4bnw1pV+Xm9dD4MyTTipdB1A2wrfb6D83iG2/Y569iWalit7Gfm53f1L/vdP+ScAcBnlC2/wYLrJaDi/KqZyjk1w83R3KVp4AFNpua1eG40H2QX3IbbuZ8PHTHnbm5ak8G8Fdt4M9wADBiolhiFI7lefxCAaTyU40G95GhYDANvbM7Fzyc9mHN1GtITorD9iBuDZx6DYRiwGAY61IqFNQrYcsCNhTsKMOGiFJgPbWhbw4qXB1eF2+PDrK/ycO/CLKweUc5+8uvfIg6LdrgAn4HGqdFoUDXGn/VGyf8thoFzGsThnAZxcLl9mLguB48szca7mWmwwAhZPvg7AFDDHo2RXawY2bXslEMb9xZWmBflqSyPyktreSwwyqTjYI4XfRpHwWLw8QXB21TTHg1rNLDhNs43WBk+fTW73M8XX5cedthnZdvspgAAF5xJREFUk9Ro7DzmQbua/I0fjhajSVr4vPlibxG2HHDj+dWBJ6tmOk5gbC87BrSwoXqi2ePP3F/+bQ9a1+b9RTiS68WFzWwl7/+axWHcw2ZzhIzb60NOoQ89Xz6C965KLRl+GhWUPzylGSHr/mh7AdrXtKJeSmBOvC/3ubE/24Pe0zhzVr7bB4/Phz2zjmHeNelonh6Dz34sDFkPL2FD1z1vewGGtIxHVNC10Re/FuHLfUVY/RNvUGe7vPj+SDF2HC3GY32qoFl6jH+giFGSfpRKt8vtw8c/uDBlUErI7/1ZeR1O8HF4Ov0VeuqtB1AM4C7YM6eAvcw6I9CjKwmc7y0L9syq4IMYSnsLnIOuGE4Hn2HOufouA7AQTkc27JlOAJ7/Ir0OcIhvVZQ39NaeWQ18cMdyf9pyK1j3YQANAZhBtmkAPoQ9cxmAjQDiAZwLYDUqz4vfl+5A+nuBwbjt4ANE3BWkP9gw2DPfAh+E8U8Ac+F0eGDPDLfsLABfwp55PoBlYC+9rgB2w+nYV2Zpp+PCoPRl4Klhh3HDeRWnpklNBqqen8c5c5Z9zZP3m+XML3JFT/bs6NCId/hmfQb85xYuu2k3A3WNqjPI9vBMNjLMhvvEjxhMWzC27AX0jn28Q+7zsWfRY++wgWb3D2/6eAsbwIaPdz+nfco5ef6zkMNVJi3gUMfz2vCiqFYqe2/8eoQNjTb1Gbj0AXh7FXvETZjHde3czwCI18v1nsjhfGYWg8NJsvK4LnOOuu17mTYzoOV2+xtXRznnXJ82bAgOfpqNyCFdOTR2zEzgwg4c/mqN5jrX7wQ62Dn08JiTQ3PObsXfKHIzEJiVWzYvP9rInmQ+sHfZu6uBd0dxjqkd+7kdN57Hp5exNuf3aqbwTvGDb/KpvrsO8EmgV53DZcz90LKOf97DX7g/1z0DdBrNC+dbzud+3vIjcOHjvCi2GAwafLoVuC+HE6CPf5+9NA5ncbisGQAKZiDQMK2fwflfdh/kcl/9BJzZiA3nuBjeEd7yI3uTtK3PniJ10gJP9PV6eCe5XjqHGraoBSwcy9/v1IQ92N5aAax6iuXvh/1Mg8/L4cJeHy9UGlXjRfu8L7gvfD72htu+l3nq8wGjBnKIbd10Bi7HzOT/Rw9m2pd9zTJnADiaBby6gfOUncjh59t+ZnALYBmuWZXDdgBg478CPQ4BoOUdDFb3a8+yvGgTe9F5vcyXI9k8TsyhyxaD++SHA5z37Ma+vEBtWI1BueeuY3mZ9imD9K/fyeAJwOOlYQZ7aK38NlDmioo5xOrS7sy7nfsZFLr9Iv7elBE8bk3DX+RTTN9YwYBoRhU+YGHpV4Fhe6WD7pYolpdH3uYFZHoVXhDv2MeyXlqP5sDeyu6hhJHZk0PZL+vBQMELH3EIfLj6zlXEOdua1+YF4KjpLP/m3HuLN7NeMo+HaZ8CYy8LrKuo2B9A8fc4LHIHerEcOMHtr57Mh+pMmM/5Qc3vFnv48vr4KnJzP0ZHsa51F/P4z8plMDTJxuVP5nJqgkGd+Xf1FPbQbN+Q6TiUxWUykrneeCvTuOxr7vMW/ovPz77hei0GL+zsNtaha5/1j306xCcrF7rZy9hi8CIw81/cDjNoGsyst+ADVn0HzPkceOcf/O6BE8yvlAT2qtl9MPT84vXyc4+Xx2Cbehxqdkk3Bo5nrWKe1E7lupMTgUVj2WN41krWG5NHMB/7PsYy26EhA1MrvuFy5kXrzM/4kJb0KqxPX1wQmCpizKUcumYqfezPWRcIku07zpszZ/vnWj2azcBdv/bM21XfspfMK7fx83kPsf41nfcopx/o05Z59tZnDGSa5W3GMk7EbzGAL3dzXxR7+f87XmHd0KkpjyFrNJ9gGut/+ELfx4AVT/B43n2QddCrnwDLzuSDjtbv4Hny4An+1uffs7yNywS++RkoPsq6oW87Ts5fPZnD5ce/D2zZzad9erwsg78eAXwtOSfsfxYF8vqI/+LveA7PqQWFwIqvA/MEBgfNBnUB+o3jEOJ2DTkHrQ+hdUg45kflBeKCb17UTGEPp8fe4VDZxDie1w+cYBuhTICw1LoR9LeZ/mVf8yZNh0a8qXlmY563khP40KU56zj8GGBv24Q4/5x6RuXb9sINfP1W3/3K87rXx17Wh7N5bg/3W5XVUxWtq7L686fDLMtVEljfzPyM7UNz3eZ5sqCI56jg8+TJXLbNzHbDo+9wagszGLtzP5ePjeG5fOU3nGs4eBvnrOO5slGYp/4CDF7fPSB8vmz8gTcWB3cJ/fz3nDNKt7+ensPj4r+plyrLr+t789hsU59pc+Yzzwd1Cb/tV5wFTP040PMuuA3Xtj7w0yHe4DirJW9aLN3KHrn+cm8Y7H0TZQFmbs3HsPbxWL7bhW2H3Ohal0No890+xEUbSI6zwOnyYsp6Bg6CY9lDWtnwz+VORFvYOwkAijw+LNnpQu9GsUiKtSAp1lIyzLEiA5rbMHFtDpyFPgxsYQsb1z+R78FXB93oXteKuBgDCVbDH8Qpe0imxVuwz+lBA3/PuMw2NoycfxI96seibfUYFLh92LC3CJ3qWCvNi/JUlEcVpbU8hgEcz/di5tZ8XN0uHkt3u7DnRDF6NYwLqSLNf1dPikLPerF4dpUT9/RIQoLVwN5sDw7leNClTmyZ9Q9uacPglr+9p9WQVja8sTkXvRryASLTN+fh2vbxYbdl2Q3p8Ab93W3qEbw6JAUt0jn0+NLW8Zi1NR/nNohFdJSBN7fkoXejuJB1zduej/ObxsEe1CuteXo01ozIKPl7y/4iPL7cifnXpqGqjWWsU20rXt6Qi0d627E3uxiLd7owqX9yqXUX4JbOiSHvXdk2HgNaBHrcvfZlHvZle/BP/xxz5zeJw7OrnJj3XT4GtbTh010uHM71oGMta8l6DuZ4sGFvEZ7oVyVk3f+6MBmFnsA1w23zT+KCpnG4/Azm32Vn2HD7/JMYftSNJqnReGlDLjrWikGyLbDty/a4YI+1oHtda0hQ68/Ka4BzE3aubYU91sC2Q27M3JqHUT2TKj2O/2yn4ucrDuo5HUWwZw4Fg11Pgr3GPghaYhIYpDoG4ACACeBDMoLNBPCE/xXsGgCT/fO+7UToQx3KS89B2DPXg/P2hXmkIAA2h0b5f9cH4CsAt5Wz7DgAb/p79N0Cp+M92DNvBoOQTcCg4FoAq/+LvPi96TZVB/AygNpgQHI2GISrzEwAbwBoDmAVgJEVpGcv7JmDADwH9iL0gEHM8r8TrLIGoWn6ncBtr3BeotppDOhl+HsrvLeOT6Fb/xz/HnMph4a2u5u9Ne4ewJM+wGDVE+8xOJVk43xjr90RSMOT7/HConPQ3dN7B3E+mmNOrnf/ceC2lxlMmH0fHxJhGLzwuWtaYEjQY1dwWEPXpsDIl3lRsvVHXmRao/mbL49kT8WXlvifMgheTP96hBdHt/knTX/1Ez4oIDaGd53n3B8IOk6YxwvJAyeALqNZUpNswPpnuTzAC43oKF7oDurMBjnAxt7trwIjpvqHHbVjsOLKCWyQzlzJXgELNgE1rmNPmdqpvOg2L+YNAD0fKpuXr3zC/HAX+x+q0Qy47t/cbwM6ArPXcfhZQREv9h6exXnwAP6GYw3zwDCYB2f45zgy94P5II3OTbgfzG1d9z17phW52WBMsjGIaTGAkRfwov7sMbzoblqTjeY56xisuaFP4IKq9g286LMYXDbzee771CQ+OKRZLfay2XOIF3o+MIBVLwN48SZu98iXGSC65SU2KhPjOOwuv5AP6sjxD729ewAbxomxAAz+G+C2AsC5Y/nd1nW5P5rfzuHKHRszCFXvJjb6nxrGnov/nM392aERMOF6rs9mZY+GVP8d2jXf8aL6eA4b3zecx/nv3l7Nbf7PIq4bYG8cc85LIDCJfbA9hzixdtsG7FG7YCN7xTWtwV6fkxfxKcKNazCg2WgE05IYB1zgfyhETDSHntVI4UXGvA28iBz8NPDwZewddPdrvFDyehkENMucxfDPd+fgvkiIBV64MVBPmL2fTNZolp/qybx4fWE+hzhPuJ4XKECg105wHfX4lZzX8PxxDIDWqMpyY16Y/BH6tmPvisFP8QJsQGfWa2Y6ut3PeunyHixnweXrqrP5IB1zWbNeMo+He/pzWJjp0md5zACcq+7e14EFD/MJjL8cYRk+5mQA6LFMHkumF+az/jPNWcd53B68hHXtUSeHPCUn8MKqcxMeewD33TurOVTyjHrsDfqvD9lbK70Ky+t2/0wPUxbzdW5rXjAaYNDweA4DbGavmHdHA2PfBi4Yx6BRkxrsrRFnDZSDl5bwabB3T+MLYADDPH+Y9RZ8QF3/sXy2/4meb6/khWa+i+UXYDkyzy/zNgI3Tg7kx4T5LF/nPszecl4fy2b3B7nN7z8QGOpWO5XlsU095h0AjHmLvZzjrLzAnvtAoLfuxl08J+QV8jga1AV42F9GqsSH9jIvfez/cIDHSVY+57vr2469xy0G640Zy1nH+rw83z49jNMwAGVvdkVZeGzZbTwmF2/mOdZdzEDizecDt57PerW4mOeV615kXWmek7qM5j6YfifrQ4DfB5h/0VHc59OXsSfZsImB7Vqyhcfe5t3AtKU8D5z7MIMS1mgGFUYPZmA4MY51S76Lc8Z2Gs3t79WG5WLs2zz/FhXzN19fxvMlAPR6OPDAkh7NA/llAUp6xrWsAzx3LXDTFNbxIy9g73BzPsLylLl5UMH/zXbD446y55CS9FSwDn9yS37PgH8444fAl7sYUJl2W6AcffAg8PDbvJHh9fEc9NTVge+Wrh//KO+tY4Co2MO2w4cPBp4wvvcY68D1z7HcVFZPVbSuyurPbT8zKJ6dz3Psq7eHDjMNPk+e1yb0PHkyl22p4HbD9X0C3135DeuIgiLWB3MfCNRTJWlfy16wYYN2u1g/lA7amRxredyWHnHye84ZlbW/KqqXKsuvgZ153Nw0mXPiJsXzZmG4my8Az7u/HGHPfiC0DdeoOm+2PDST67Lb2APw2nMDQT1w2N/UwSkY80k2Jq7NwbkNY3F+k7iSYn1DxwTcszALnaYcRkaiBTd1TMDS3YH5yQBgSKt4TFybizu6hc7pNX97AR5fng2vD2hQNRovXJxc6aFSPSkK7WtasXFvESYPSC73MJ6+KQ+jF2fBMICWGTF4wh94KX0/4O4eibh/SRZcxT483a8KLm5uw/jzq+Dx5U78fLIYcdEGOtayoktda6V5UZ6K8qiitJbHMIB2NWLwS1YxOk05jLQEC14amILUeEvJ58H5DwATLk7Gc6tycOGMo8gt8qFuclTJA0v+KFe3i8e+bA8ufpPn5yvOiMfV7eJL8rz1pEOYfmlVdK5tRXpi2Z5+qfEWxFu58J3dE3HS5cV5048iNsrAxc3jQspPYbEPi3e68NKg0CfTWqPYu9SUYmMvtOD3XuyfjAc/zkanKYeRGm/BP3omhgy93bK/CIdyvbi4eWhgK8FqIMEaFfJ3XDSQnsD3qsZb8OrQqnh0aTbGLXeiYdVovDKkKtISgobHbi9A+5oxaJASGhIKDs6Z22GPtaCKf8hsj3qxGH1WEm7+4AQK3D50rG3FpP6h2/7hd/kY2jr0KcAA/rS8BoBFOwrw0MdZKPIA1ZMsGNE5EZeecfoflHEqGD6fr/Klfg8GzI4A6ACnY9ef+2N/U/bMlQBmwel47RT8Vgaev/4wbu73p/+UnEZvr2Jw7pNxpzsl7NHx8dbQhrX8fa3ZzqGDmyZwbr67B1T+HZFTzePlU0wfuOR0p0TCGT+XveZKy3UBdW/kEPP6GWU/F5HTxlfecfsbudw+nDn5MBYOTyvpESf/f3O+ycfsbfmYe3X5Q3RF/u4mrcvBvT3LmZInvN8U4j4VNdlIAF8qoPc/pLIZWCXymbv3r7CfzaFJf4W0yOkXXDZVF8lflTkjtsrnX5e5b5Zs5jQMPh97t7Wqy4Ce9p3IX4oB/CHH5ayv8tCmRgwapsZUvrBUyvCf7wzVmSKnzZ8b1LNn/gzWwaWH5Ja3/BgAY8J8siZkXre/mlORbntmbjmf/HXzRYCh4zmHUGmjBgOjh5z69AS75zVg9pqy719xFtCp8alPz2/1/Iccxlxat+Z8AnKkqzE8/PvvPxh46vCpWMfpUNG+vXfgqU+PiJRv9lrgnmll36+TDmx8/tSn57datIm9f30+zhE54y4GDv7K528R+X/pMfUwfABeHfpfPDgLwOT1OZiyvuwlWKfaVrx1eeofnLo/zh+d7jGfZOHD7wrKvD+kla3CJwSLyKnx5w+/lf8t9swMTLhBw2/l1Dl4gg80ub6Sh7PI30ueS8Nv5a/L4+WcZw9q+O1f0tNzgDGXne5UiMhvoeNWRCLUxLXOP3X4raXyRUREREREREREROSvREE9ERERERERERGRCKOgnoiIiIiIiIiISIRRUE9+q3y0a3C60yB/JwlxQBuVOSklJjoyHugif08GgO7NT3cqREREROR/nB6UIf8fKjQiIiIiIiIiIn8sPShDRERERERERETkf5mCeiIiIiIiIiIiIhFGQT0REREREREREZEIo6CeiIiIiIiIiIhIhFFQT0REREREREREJMIoqCciIiIiIiIiIhJhFNQTERERERERERGJMArqiYiIiIiIiIiIRBgF9URERERERERERCKMgnoiIiIiIiIiIiIRRkE9ERERERERERGRCKOgnoiIiIiIiIiISIRRUE9ERERERERERCTCKKgnIiIiIiIiIiISYRTUExERERERERERiTAK6omIiIiIiIiIiEQYBfVEREREREREREQijIJ6IiIiIiIiIiIiEUZBPRERERERERERkQijoJ6IiIiIiIiIiEiEUVBPREREREREREQkwiioJyIiIiIiIiIiEmEU1BMREREREREREYkwCuqJiIiIiIiIiIhEGAX1REREREREREREIoyCeiIiIiIiIiIiIhFGQT0REREREREREZEIo6CeiIiIiIiIiIhIhFFQT0REREREREREJMIoqCciIiIiIiIiIhJhFNQTERERERERERGJMArqiYiIiIiIiIiIRBgF9URERERERERERCKMgnoiIiIiIiIiIiIRRkE9ERERERERERGRCKOgnoiIiIiIiIiISIRRUE9ERERERERERCTCKKgnIiIiIiIiIiISYRTUExERERERERERiTAK6omIiIiIiIiIiEQYBfVEREREREREREQijIJ6IiIiIiIiIiIiEUZBPRERERERERERkQijoJ6IiIiIiIiIiEiEUVBPREREREREREQkwiioJyIiIiIiIiIiEmEU1BMREREREREREYkwCuqJiIiIiIiIiIhEGAX1REREREREREREIoyCeiIiIiIiIiIiIhFGQT0REREREREREZEIo6CeiIiIiIiIiIhIhFFQT0REREREREREJMIoqCciIiIiIiIiIhJhFNQTERERERERERGJMArqiYiIiIiIiIiIRBgF9URERERERERERCKMgnoiIiIiIiIiIiIRRkE9ERERERERERGRCKOgnoiIiIiIiIiISIRRUE9ERERERERERCTCKKgnIiIiIiIiIiISYRTUExERERERERERiTAK6omIiIiIiIiIiEQYBfVEREREREREREQijIJ6IiIiIiIiIiIiEUZBPRERERERERERkQijoJ6IiIiIiIiIiEiEUVBPREREREREREQkwiioJyIiIiIiIiIiEmEU1BMREREREREREYkwCuqJiIiIiIiIiIhEGAX1REREREREREREIoyCeiIiIiIiIiIiIhFGQT0REREREREREZEIo6CeiIiIiIiIiIhIhFFQT0REREREREREJMIoqCciIiIiIiIiIhJhok93AiQiGac7ASIiIiIiIiIif2fqqSciIiIiIiIiIhJhFNQTERERERERERGJMArqiYiIiIiIiIiIRBgF9URERERERERERCKMgnoiIiIiIiIiIiIRRkE9ERERERERERGRCKOgnoiIiIiIiIiISIRRUE9ERERERERERCTCKKgnIiIiIiIiIiISYRTUExERERERERERiTD/Bx9R3OvKO0cZAAAAAElFTkSuQmCC\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_data.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": 161,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 576x597.6 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "shap.summary_plot(shap_values, Xdf)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 162,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAqEAAAH3CAYAAACLnYYpAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADl0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uIDMuMC4yLCBodHRwOi8vbWF0cGxvdGxpYi5vcmcvOIA7rQAAIABJREFUeJzs3Xm8lVX5///XkShTcMYRGZw/kpm/3qafDHIuQsqvaeaQ4kBqjhmSKY75cQBnzZJQEME0zVQ0nMMhDb3MKc0UFUQDBVNkKgTO74+1tt5uzzl7g+fsc+C8n48Hj733fa97rXXf9zl6nWutde+6+vp6zMzMzMxqaYXW7oCZmZmZtT8OQs3MzMys5hyEmpmZmVnNOQg1MzMzs5pzEGpmZmZmNecg1MzMzMxqzkGomZmZmdWcg1AzMzMzqzkHoWZmZmZWcw5CzczMzKzmPtfaHTBbno0bN66+f//+rd0NMzOzWqqrppAzoWZmZmZWcw5CzczMzKzmHISamZmZWc05CDUzMzOzmnMQamZmZmY15yDUzMzMzGrOQaiZmZmZ1ZyDUDMzMzOrOQehZmZmZlZzDkLNzMzMrOYchJqZmZlZzTkINTMzM7OacxBqZmZmZjXnINTMzMzMas5BqJmZmZnVXF19fX1r98FsuVV34UL/gpmZWZtUP+hzLVV1XTWFnAk1MzMzs5pzEGpmZmZmNecg1MzMzMxqzkFoC5DUVVK9pB6t3ZeGSHpB0r5VlDtA0rMt0P4ISaOau14zMzNbdrTYjFRruyKiV5XlxgJjS59z4LgwIg5voa6ZmZlZO+FMqFkTJHVs7T6YmZktj5wJbQaS1gWGA98E3gaGFvbtApwLbAYsBB4AjouIdyT1BUYDG0TEgly+MzAN6As8CpwDHAJ0Bt4FLoqIK5royx7AtbnOD/O2TsB04DsR8bCkycCQiBgjafXc951JPw9TgaMi4hFJA3K5TSQNBg7I9f0wN7dqRCyStCdwGrBx7vs5OYta6tOhwKlAF+B20qMbFlZxXRu9doV+nAF0BeYB4yNiQIU6zwR6A88BBwHzgSsj4vy8f0fgftI1Pyv3ubOklYCzge8DqwJPAMdExKRK52FmZmaf5kxo8xgLLAK6AX2AAYV9/wWOIQUzWwHrA5flffcAc4HvFcrvB0yNiEeA3YCDge0iojOwHfCXCn0ZTwrY+hW27UMKQh9poPxJwEpAd2A1YC/gzfJCETE0n+d1EdEp/1skaTfgGuAEYI3c3ysl9QGQ1Bv4FXBk3n8fUHE+atbotctB4fXA0fnabJT7UY0+pD8W1iNd+xMl7VfY34H0R8A2wDp52whgC2B7YF1gInCnM6VmZmZLx5nQz0jSBqQs4iYRMQuYJeks4F6AiHi0UHy6pKGkTCURsVjSCOAw4OZc5jBSwAOwAFgR6CVpRkS8TQqeGpUDw+tJmbzb8uZDgJER0dCD0xcAawKbA09HxMvVnz0AxwOX5aAZ4AlJY0hZxofz6y0RcV/eP1rSEdVU3NS1yz4EtpD0TET8m4aD7IZMAy7I1+MpScNJ1+h3hTIn5/uJpLVIfxx0z/eAfI9PIP1hUOynmZmZVcFB6GfXNb9OKWx7vfRG0ldJQ8pbkzKOdUCnQtlrgNMkdQNWAb5CzmJGxARJpwBDgN9Lehw4NSKiQp9GAs9JWps0jP91YP9Gyg4DOgLXAetJuhMYXAq2qtAT2EnSiYVtHfg4IOwKlPf3darQ1LWLiHmSvgOcCPyfpNdIUxVuqKLqKWUB+WRSBrhkMWlaQknP/PqcpGI9HYENqzkXMzMz+yQHoZ/dW/m1O/Bqft+zsP9G4BZgn4j4IM/ZHFfaGRHTJN1FysStDtwWETML+4cDw/Pw85nAraRh/0ZFxEuSngIOzHXeHxGfGmLPZeeS5muemue2jiEFpgc1UHxxA9umAKMiYlgj3XkL6FG2rSfwSlPnkFW6dhOACZI6AN8F/iBpYkS82mBtH+suqa4QiPbgk1MQ6suC1NIfGJtGxIwq+m1mZmYVOAj9jCLiTUkTgKGSDgG+SFqkU7IKMAuYnbOdJzdQzXDgamBloLToB0nbAl8AniTNj5xNFQt6spHAcaRM6EmNFZLUH5gEvAzMAf7TRBvTge0lrRARpYD0UmCkpL8Cj5GyoFsBdTljOxq4Jz/e6aF8fl+juiC00WsnaR3gG6QAe5ak9/OuRVXUux5wkqRLgC8BA0kZ1QblRWQ3AFdJOiEi3pK0GrATcF9EzKmiTTMzMyvwwqTmsT8pWJxKGoYeXdj3Y+BwUgB5Kx/P/Sy6l5RlnEVaAV7SGbgcmElaGb87hSC1ghtJi3U6kVakN2ZjUnbxA9Kw9HwaDpQhzVVdGXhX0vuSOkTEvaRzHJb7OQ24hI+HzR8Gjs3H/hv4NnBTlefQ1LVbATgamCxpNmnx08ERMbmKeh8hBaLTgTtJi50qDeMPBP5JyrzOBp4nLfhqaJ6tmZmZVVBXX+//h7YFOZt6b0Sc29p9WZ7lRzR9IyJ2rUV7dRcu9C+YmZm1SfWDWmxAvK6aQh6ObwPy44y2JWXWzMzMzJZ7DkJbmaQngU2AY6td9JJXzJ/SyO6+hccltWmSDiDNhW3IEcUH3i9Bnb1Jz0ptiLPMZmZmbYSH481a0Lhx4+r79+/f2t0wMzOrpaqG470wyczMzMxqzkGomZmZmdWcg1AzMzMzqzkHoWZmZmZWcw5CzczMzKzmHISamZmZWc05CDUzMzOzmvNzQs1akL+205ZGC36VnplZLfg5oWZmZmbWNjkINTMzM7OacxBqZmZmZjXnIPQzkjRe0uBWbP8FSfsu5bHdJM2RtH5z96utkjRZ0oGt3Q8zM7P2zrPfP6OI6NvK7feqppykAcCQiNikcOwbQKcW6pqZmZlZo5wJNfsMJHVs7T6YmZkti5wJ/YwkTQDuB4YCVwJ7AisC04FTIuKWCsevBJwNfB9YFXgCOCYiJknqBDwJjI2Ic3L504D9AUXEXEmTSRnOMZJWB4YDO5Pu7VTgKGAh8Bvg85Lm5Kb3ACYDrwMbRsSbks4EegMTgcNzuV9HxBmF/vYDhgHdgAnAK8A2EbFjhfMs1R3AoaQ/gP4P+AMwEtgWeBk4MCL+kY/5HDAYGACsDbwAHBcRT+X9o4AOwIfAXsBcYBDwD+C3wBa5vQMi4l+F7mwk6VHgK8BLwFER8WShrwOB44ENgdeAn0fEvYXz6AP8DfhRfm3VbLiZmdmyyJnQ5jOAFEj9T0SsAuwCvFjFcSNIwdL2wLqkAPBOSR0jYg6wDzBY0k6SdgJOAvaOiLkN1HUSsBLQHViNFJi9GRGPA0cCr0VEp/xvQiP96QO8AawP9AdOkbQDgKSNgVuBX+b6LwEOq+Ici3W/ks/zQFIwew1wNLAGKXi8rFD+bOB7wLeBNYFrgXtysF2yNymQXSP367f5uP8HrAPUA2eW9eNIUpC5BnAL8CdJq+Rz/DHwc+AAYHXgVOBWSZsUju8DTCMFqd9fgvM3MzOzzJnQ5rOANL9yS0mPR8TUSgdIWgvYD+geEW/nbWcBJwDbAY9GxN8lHQfckA87NiJeaKIPawKbA09HxMtLcR4vR8Rv8vuJkp4BBPwl93ViRPwu739A0u2kYKzaukfk9+MlvQvcU8h83gCMze/rgGOBfhHxWj7mGkknAP2AMXnbgxFxVz5mNPBr4PqIeDNvuwUYWNaPawrZ1AuAn5AywzcAxwFnR8SzueyfJP0Z+CFwTt72RkRclN8vqPLczczMrMBBaPMZQ8q8XQJsKukBYHBETGrimJ759TlJxe0d+WRgdxNwPjAPuL6J+oblY68D1pN0Z+7D20twHtPKPs8FOuf3GwBTyvZPofogtLzueWXb5hXaWosU1I+TVPzWoY5A14bqjIh5+To2VmfJ5MIx9ZLeKNTZE/iVpMsL5T8HvNnQ8WZmZrZ0HIQ2k4hYCFwAXCBpNdL80GtJQ7eNKQV0m0bEjCbKXUGau7gmaWj59Eb6MJc0fHyqpHVJgfEw4CBgcdUn07i3gN3LtnVrhnobMpMUAO9anK/ZTHqU3uSMazc+DjKnAGdExM1NHN8c19LMzKxdcxDaTCTtDMwCngPmkwKohU0dExHv5CHoqySdEBFv5QB2J+C+iJgj6UekoeJtSAuXJkp6JCLua6AP/YFJpAU+c4D/FPowHVhb0ioR8cFSnubvgNMk/YA0D7M3aSHW35ayvkblDOVlwIWSDo+IV/JCrR2A58sWGi2pQyX9EXge+ClpHu1ded8lwJmSXgGeJS0y+yowMyJe+gxtmpmZWYEXJjWfdUhD5e+RhoO7A0dUcdxA4J/ABEmzSYHRPkC9pC2BX5FWd0/LQdDRwBhJ6zVQ18bAOOAD0pDxfODkvO9B4D7gdUnvS/rmkp5gRLya+3YWKeAelM/5v0taV5XOAG4Hbpf0AWlR05F89p/b4cDlpHu1L2ne6SyAiPgt6UkHI/P+N4DTSNMAzMzMrJnU1dfXVy5l1ghJvwNmR8SPW7svbVHdhQv9C2ZLrH6QB6nMbJlWV00h/5fOlkge8n8UmE1apf594Fut2ikzMzNb5jgIbWGSfkN6JmZDtsxfnbks+SZpqHpF0lD1kRHxZ0m9gfGNHHNuRJxbqw6amZlZ2+fheLMW5OF4WxoejjezZZyH481a2x2bj6d///6t3Q0zM7M2x6vjzczMzKzmHISamZmZWc05CDUzMzOzmnMQamZmZmY15yDUzMzMzGrOQaiZmZmZ1ZyfE2rWgpp6TqifBWlmZsupqp4T6kyomZmZmdWcg1AzMzMzqzkHoWZmZmZWcw5CbZkiaYKkITVop17SN1q6HTMzs/bKQaiZmZmZ1ZyDUDMzMzOrOT8jxpZZkr4MXApsA7wHXAucFxGL8v4ewDDgG8AXgReA70bEu5LOBX4IrA28DVwREZc20VZv4Dxgy9zWVcDFEeFnnJmZmS0FZ0JtmSRpVeA+4M/AukA/4FDgxLx/JeBB4B1gC2AtYBCwIFfxIik47QwMBM6T9K1G2uoF/IkU0HbJbR0D/KgFTs3MzKxdcCbUllX9SAHlOTkb+Q9JF5CC0GHAHqTs5/ERsTAf83jp4IgYU6jrQUl3AbsA9zTQ1lHAzRFxe/78kqQrgYOA0c14TmZmZu2Gg1BbVm0ITC4bDn81bwfoAbxWCEA/QdJxpAxoV9I3O3wRuKGRtnoCO0vaq7BtBWDqUvfezMysnXMQasuqqUB3SXWFQHQjPg4MJwM9JXUozREtkbQDcAEp8zkxIhZJuoXGv2ZsCnBtRBzd3CdhZmbWXjkItWXVXaRFSadIGkbKVv4cuLqwfyhwiaTTgDnAtqTFSasAi4AZQL2kfkBf4OZG2roKeEjS3cDdQD2wGdAlIh5qgXMzMzNb7nlhki2TImIWsDuwK2l1+z2k+ZkX5/1zgZ1Jw/OvAO+S5op2zGWvB54AZgJ7A39soq2/k+aYngBMIy12GkVapGRmZmZLoa6+3k+YMWspdRcubPQXrH6QByLMzGy51Nj0tk9wJtTMzMzMas5BqJmZmZnVnINQMzMzM6s5T0oza0F3bD6e/v37t3Y3zMzM2hxnQs3MzMys5hyEmpmZmVnNOQg1MzMzs5pzEGpmZmZmNecg1MzMzMxqzkGomZmZmdWcv7bTrAX5azvNzKwd8td2mpmZmVnb5CDUzMzMzGrOQaiZmZmZ1ZwnpbUwSV2BqUDPiJjcyt35FEkvAGdHxE0Vyh0ADI6IrZu5/RHA5yJiQBVlrwD2A1YENoqId5qzL2ZmZlY7DkLbuYjoVWW5scDY0mdJo4CFEXF4C3XtEyR9HTgU6BERM2rRppmZmbUcD8fbsmIjYFqtA1BJHWvZnpmZWXvhTGgzk7QuMBz4JvA2MLSwbxfgXGAzYCHwAHBcRLwjqS8wGtggIhbk8p2BaUBf4FHgHOAQoDPwLnBRRFzRRF/2AK7NdX6Yt3UCpgPfiYiHJU0GhkTEGEmr577vTPrZmAocFRGPSBqQy20iaTBwQK7vh7m5VSNikaQ9gdOAjXPfz8lZ1FKfDgVOBboAt5Me47CwwjUdDJwNfF7SHOAJYJclvR65rgnAM8AmwI7AFGBQRIzP+88E+gB/A36UX/tK6gZcDOyQqxoH/CwiZjfVnpmZmTXMmdDmNxZYBHQjBTMDCvv+CxxDCsC2AtYHLsv77gHmAt8rlN8PmBoRjwC7AQcD20VEZ2A74C8V+jKeFOD1K2zbhxSEPtJA+ZOAlYDuwGrAXsCb5YUiYmg+z+siolP+t0jSbsA1wAnAGrm/V0rqAyCpN/Ar4Mi8/z5g3wrnUGrvSOC13NbOLN31KDmMdN1XI/1R8EdJPQr7+5AC6A2B70taEXgQeJGUkd0S6MrH987MzMyWkDOhzUjSBqQs4iYRMQuYJeks4F6AiHi0UHy6pKGkTCURsTgv0jkMuDmXOQwYkd8vIC3I6SVpRkS8Tcq0NioHhteTsoW35c2HACMjoqGHqC8A1gQ2B56OiJerP3sAjgcuy0EzwBOSxgAHAQ/n11si4r68f7SkI5awjWJfl+h6FNxW6MNYSUcB+5MCUoA3IuKiUjuS9gbqIuL0vG2+pNOAxyQNjIhFS3kOZmZm7ZaD0ObVNb9OKWx7vfRG0ldJgc7WpIxjHdCpUPYa4LQ89LsK8BVyFjMiJkg6BRgC/F7S48CpEREV+jQSeE7S2qRh66+TAq6GDAM6AtcB60m6k7Qivtrgriewk6QTC9s68HHWtStQ3t/XWQqf4XoATG7gc9cm9vcEukl6v2x7PbAu8FaV3TYzM7PMQWjzKgUj3YFX8/uehf03ArcA+0TEB3nO5rjSzoiYJukuUrZydVLGbmZh/3BguKSVgDOBW0nD/o2KiJckPQUcmOu8PyI+NcSey84lzdc8Nc9tHUMKTA9qoPjiBrZNAUZFxLBGuvMW0KNsW0/glabOoTFLcz2y8j70AP5U+Fx+blOAl6t9koCZmZlV5iC0GUXEm3nhy1BJhwBfJC3SKVkFmAXMztnOkxuoZjhwNbAyUFr0g6RtgS8AT5Lmls6mwoKegpHAcaRM6EmNFZLUH5gEvAzMAf7TRBvTge0lrRARpaDtUmCkpL8Cj5GyoFuRhrKDtPDqnvx4p4fy+X2NpQhCP+P12DMvEpsA/ADYloYD7ZI7gXNy5vUK0rVZH/haRPxxSftuZmZmXpjUEvYnBUdTScPQowv7fgwcTgqYbuXjuZ9F95IycbNIq+dLOgOXAzNJK8F3pxCkVnAjaUFNJ9KK9MZsTMrMfkAakp5Pw4EypLmqKwPvSnpfUoeIuJd0jsNyP6cBl+R2iYiHgWPzsf8Gvg00+ZD8JnyW63ENcCLpGp8O7BURrzVWOCLmkVbjbwm8xMf35itL2XczM7N2r66+vqH1Kdaacjb13og4t1JZWzL52t4fEefUor26Cxc2+gtWP8gDEWZmtlyqq6aQ/y/YxuTHGW1LepSSmZmZ2XLJQWgbIulJ0kPUj632m4HyPMVTGtndt/C4pDYtfzf91Y3sPqL4wPsK9TR5PZamb2ZmZtb8PBxv1oI8HG9mZu2Qh+PNWtsdm4+nf//+rd0NMzOzNser483MzMys5hyEmpmZmVnNOQg1MzMzs5pzEGpmZmZmNecg1MzMzMxqzkGomZmZmdWcnxNq1oLKnxPqZ4OamVk7UNVzQp0JNTMzM7OacxBqZmZmZjXnINTMzMzMam6pg1BJPSTVS+ranB2y5iOpm6Q5ktZvofoXStqxyrIDJE0qfB4laURL9MvMzMzaPq+SWI5FxBtAp9buh5mZmVm5NjUcL6nj8tyeNQ9JHSTV5GfXPyNmZmYto6pMqKTjgJ8CawEfANcBw/PunST9AtgQeBw4OCKm5eNWAs4Gvg+sCjwBHBMRk/L+CcAzQA9gZ+BcSdOBIcBvgROADsD1wMkR8WE+biSwK7AaMBU4JyJuqOI8PtUecL6k3sB5wJbAe8BVwMURUS8pgOsj4rJCPWcBvSNi5/x5T+A0YGNgWu7P2LxvQD6fy4HBwMrA74GfRMQiST2A14ENI+LN4jERsUk117GJ8/1E3ZLOBHoDE4HDc7FfR8QZVVy7zsCVQH9gNnB6A2WOIt2zdYF/ACdFxCOV6s7Hngv8EFgbeBu4IiIuLTuPw4Gfka5z9zwV4AygKzAPGB8RAyq0cybpGjwHHATMB66MiPPz/h2B+4FDgLOALkDnpb0HZmZm1rCK2SRJmwHnA3tERGegF3BHoci+QB9gA1KAdXZh3whgC2B7UmAyEbizLLt0KClAWzW/AnQHugEbAf9LCnwGFY55FPgKKQg9GxglacvKp/vp9iT1Av4EDCMFHP2AY4Af5fLXkgKS0vWoIwUvI/Pn3YBrSMHXGsDBwJWS+hTa7A6sQwqetgX2IQVc1armOlarD/AGsD7pup4iaYcqjrsU2JQUqH8Z+B7pDwQAJO0H/JJ0bdYk/RFxt6TuVfbrReAbQGdgIHCepG+Vldmf9MdDZ1IgfD1wdP653Ih0H6rRhxTorpfP48Tc/5IOQF9gG9J9g+a9B2ZmZu1eNZnQhaSHjvaSNCUi3gf+mrNTAGdFxEwASTeQM2yS1gL2A7pHxNt521mkYG07UiAJcEtEPJjfz5MEsJiURZsPvCppKCmLeB5ARBSDjRslDQJ2JAUylZS3dxRwc0Tcnre9JOlKUjA1GvgdcLGkbSLiaWAnUrD5h1z+eOCyQsbvCUlj8vEP523zgdMjYhEwSdIDgICxlTq7BNexWi9HxG/y+4mSnsl9+UsTfVgBOADoFxHT87afA/+vUOwQ4OqImJg/XyPpcFLgeF6lTkXEmMLHByXdBewC3FPYflah/c8BHwJbSHomIv4NVJV1JWWrL4iIeuApScNz/39XKHNyRMzKbTX3PTAzM2v3KgahEfGapAOAo4ARkp4jZR9fzkWmFYrPJWWpAHrm1+dyYFnSkTR0XzK5gWbfiYh5ZWW6wkcB0ZmkDOy6QD0pA9ul0rk00l5PYGdJexW2rUAa5ici3pN0GylIeTq/3ljoX0/SlIQTC8d34JMB0Ts5AC0pXqdKqr2O1ZpW9rmavnQBvsAnr93rZWU2BG4q2/YqVfYxT/kYSLrPdcAXgfIpFh+1HxHzJH0HOBH4P0mvARdVMy0DmJID0GK9xfu/mHz/s+a+B2ZmZu1eVXNCI+JW4FZJnweOBG4HvlrhsCn5ddOImNFEucUNbFtb0kqFQK8H8GZ+vx8p27o78GJELM7zNqv6iqgG2psCXBsRRzdxzEhgrKSzScHKLmXHj4qIYVW2X25Ofl25sK34SKVqr2NLmgEsIN2HV/O2nmVlpjawbSNgXKXK83SAC0jXdWKeK3sLn76nn7h3ETEBmCCpA/Bd4A+SJkbEqzStu6S6QiDag49/vgDqy4LUtnAPzMzMlisVg1BJm5OCi4dJw8qzSNnHhoLHj0TEO3l4/ipJJ0TEW5JWIw1n3xcRc5o4fAXSgqGfk+btDSIthgJYhTRFYAawQl7EszVwZ6VzacRVwEOS7gbuzue2GdAlIh7KZe4jnftoUhbtr4XjLwVGSvor8BgpC7oVUBcRUanxiJgpaQpwqKRTSHMuBwKL8v7Pch2bRQ70bwDOkvR30rUoH2IfBVwm6Q7gb8CBpHm7+1fRxCqk850B1EvqR5qTeXNjB0hahzSH9P6ImCXp/bxrUWPHFKwHnCTpEuBLpOt9YmOF28I9MDMzW95U85ibz5NWIE8D3geOI60Q/k8Vxw4E/knKVs0Gnictyqlv8qiUeXqLNOQ7kRQcDs37rsvbJuUyW1L9XMBPiYi/A3uQ5vdNA94hBVRdCmUWkwLQvqSFSsXj7wV+TFrYNDPXcQlL9nzOg3MfZgEX8+kFNkt7HZvT8aT78VJufxyFgC8Pg58FjAHeBX4CfCciJldR9z2kRUZPkK7h3sAfKxyzAnA0MDlfk1+RnsxQTXuPkALR6aQ/Xi7j00P/5drCPTAzM1tu1NXXt63/h5Y/nsisOeVHNH0jInatRXt1Fy78xC9Y/SB/P4SZmS33qpoi2aYeVm9mZmZm7cNylZbJcypPaWR332ofnL4skdTYfMRHIqLvEtSzXFy7/MUD4xvZfW4t+2JmZmaNa3PD8WbLEw/Hm5lZO1TVcLz/j2jWgu7YfDz9+/dv7W6YmZm1OZ4TamZmZmY15yDUzMzMzGrOQaiZmZmZ1ZyDUDMzMzOrOQehZmZmZlZzDkLNzMzMrOb8nFCzFlR8TqifEWpmZu2Ev7bTzMzMzNomB6FmZmZmVnMOQs3MzMys5tp8ECrpAEnPtnY/lkWSfiPpyhaqe4ikCUtQfrKkA/P7HpLqJXVtib6ZmZlZ29fmV0pExFhgbGv3Y1kUEUe2dh/MzMzMGrIsZEI7Lkv1Wsur5b3zz4mZmVnLaHOZUEmTgWuBnYCvAb+UdHhEbJL3rwScB+wFfBF4FDguIt6oUO+OwP3AIcBZQBegc67vbOD7wKrAE8AxETFJ0h65LxtExIe5nk7AdOA7EfGwpDWBocDuwIrAn4FjI+LtwvkMB3YBtgMmAz+OiMfy/lHAwog4vOwaDImIMflz73zOWwLvAVcBF0dEk8/XKq9bUj1wdL4GWwAvAAMi4qWm6snH9gOGAd2ACcCksv3dgcuBHYD5wB+AX0TE/Crq3jof2wvoAPyVdA9eLZxHR2AB8D3gJkmnkK7rzqSf46nAURHxSIW26oGfAgOAjYEABkbEpLx/AvAM0CPXfS5w/tLeAzMzM2tYW82EDgROBDoBs8r2XQJsn/91B2YC4yR1qKLeDkBfYBtgnbxtBCkg2x5YF5gI3JkzYOOBhUC/Qh37kILQRyTVAbcB9cCXcn9mAzeUtXsocBwpyL0PuK6KvgIgqRfwJ1IA2CX35RjgR9XWUWYAKeBeixS4XVFFHzYCbiUFZKuRAsaBhf2fA+4iXZfupGu5A3BhlX2qB84ENiAFf3OAMWVl9gHuJl2DnwEnASvl9lYj/VHyZpXt/RjYG1ibFIjfUfbzcyjpHFcFLm+Be2BmZtbutblMaPbbiHgaQNJHmTRJKwAHAd+NiLfythOAf5Oypo9XUffJETErH7sWsB/QvZC5PAs4AdguIh6VdD0pc3hbPv4QYGRE1EsS8FVg14j+XIJ4AAAgAElEQVT4bz5+MDBTUteIKAVFV0fEC3n/COAESauW+lHBUcDNEXF7/vxSXmx0EDC6iuPLDStljXOGsTzYa8h+wBOlzCxwr6TbSEEjpGu/KemazQXmShoC3CbpmErZwoh4rvDxv/kePC9p5VwfwKMRcVN+P0/SAmBNYHPg6Yh4uYrzKLmokPkcTMpsbgc8lvffEhEPFtpq7ntgZmbW7rXVIHRyI9u7kIa8XyttiIg5kt4BNqRyELqYlP0r6Zlfn0vx5Ec65voARub9awOdga8D+xeO/wLwdtnx/yENW5eC0GmFfaWgqjOfzvI2pCews6S9CttWKDuPJVHel85VHNOVT9+T1/k4CN0QeKcQMAK8SrpXXYB3mqpc0sakLON2uT+loHUtPr5e5e0PI92n64D1JN0JDC79MVHBR3VFxDxJM0jn+Kn9WXPfAzMzs3avrQahixvZPgP4LykoKM0X7EQaVq0mIKgvy8pNya+bRsSMhg6IiJckPQUcCKwO3F/IcE4hBUlrRERjfa5kDimjB3w0tL12WR+vjYijl7L+5vAW8K2ybT0L76cCa0taKSLm5W0bkYLxmVXU/xvgX8CXI+JdSV8CnueTX/v1ieubA95TgVMlrUvK6A4jZScr6VF6k+cEd+GTQ/nl97It3AMzM7PlSlsNQhsUEYsljSYtVnoReB+4CHiJtKBoSet7R9INwFWSToiItyStRloUdV9EzMlFR5LmdHYmzUX8qArSIpbLJJ2ZA6guwC4RcWO13QCGSupJCsTOJmX4Sq4CHpJ0N2lOZD2wGdAlIh5a0nNeSr8DTpe0H3AzsCNpgVDk/U+QFipdJOlnpDmavyRNW6gmOF8FeAV4P0+ROLvSAZL65zZfJgXy/yHN363GT/MCpLeA80mZ9YlNlG8L98DMzGy50lYXJjXlp6Tg50ngDWA90hzRRUtZ30Dgn8AESbNJGbh9+HhIGOBGUmavE1CaF0gOsPYkXcen8vETSUFatcYCdwB/I2V33yAFR6U2/g7sQZqnOo00tD2KlL2ribxKfW/gdFLg/1PSgq7S/oW5j11J/X+CdB0GVdnET4HewAfAI8CdVRyzMTAuHzOZtCL/5CrbG0FaaDUD2Br4XlM/P23hHpiZmS1v6urr/YQZaz/yI5p6R8SjtWiv7sKFH/2C1Q9apgYezMzMllZd5SLLZibUzMzMzJZxy1VqRtKcRnY9EhF9a9qZGsgPbD+lkd19Kz24vayu5eLaSRpPGtr/lIjoVOPumJmZWSM8HG/Wgjwcb2Zm7VBVw/H+v6JZC7pj8/H079+/tbthZmbW5nhOqJmZmZnVnINQMzMzM6s5B6FmZmZmVnMOQs3MzMys5hyEmpmZmVnNOQg1MzMzs5rzc0LNWlDpOaF+RqiZmbUj/tpOMzMzM2ubHISamZmZWc05CDUzMzOzmnMQai1KUg9J9ZK65s8HSHq2ymNHSRrRsj00MzOz1uAgtJ2SNFnSgbVuNyLGRsTWtW7XzMzM2hYHoWZNkNSxtftgZma2PPJzY5YRkiYDI4BdgG2B14EDgF7AL4EuwM3AkRGxUFI34GJgh1zFOOBnETFb0jigGzBC0m+AxyJid0k/BH4B9ATmAncAJ0bE3Cr6903gnNyfxcC4iDikgXIDgCERsUn+3BE4CTgYWB94BxgcEX9o4NghwEFAP2AKcCWwJ7AiMB04JSJuqdDPycC1wO7AV4CXgKMi4sm8fxTQEVgAfA+4CThK0peAi4CvAvOAscDpEfFhpWtjZmZmn+ZM6LLlYOAnwOrAs8AfgZ2ArYGtgO8CP5C0IvAg8CKwEbAl0BW4DCAi+gNvAIdHRKeI2D3XPwvYH1gN6J3/DanUKUlfBu4BrgHWAzYERld5TucABwL7AKsA3wReKau/o6Rrge8AX4+IV4ABpGD8fyJiFVJw/mKVbR4JHA+sAdwC/EnSKoX9+wB3kwL7n0laG3gIuJUUKP8vsBspYDczM7Ol4EzosmV4RPwDQNINpEzo9jlTOVfSBFJgtgCoi4jT83HzJZ0GPCZpYEQsaqjyiBhf+DhJ0lWkzGMlR5Iyn6MK2/5c6SBJdcDRwL4R8Vze/Gb+V7IqMB54H9glIubn7QuATsCWkh6PiKlV9LPkmoh4KvfhAlJgvwdwQ97/aETclN/Pk/QT4NmIuDpve0vSecAFwNlL0K6ZmZllDkKXLdMK7+cBiyJiRtm2zqTh9G6S3i87vh5YF3irocol7QacDmwBfAHoQBoer6QH8HQV5cp1AVYGXm6iTG9SIPr/FQJQgDHAOsAlwKaSHiAN40+qot3JpTcRUS/pDVKm+FP7s57ADmXXs450fczMzGwpOAhdPk0BXo6IXk2UWVz8IOnzwG3AYODaiJgv6RhgUBXtTQY2XYp+ziDNPd2UsiH4gjtJUw/+LOlbEfEsQEQsJGUiL5C0Gml+6LVAnyra7VF6k7Ox3fhk9nVxWfkpwP0R0a+Kus3MzKwKDkKXT3cC50g6BbgCmEOay/i1iPhjLjOdTwaOnyct8HkvB6BbAsdU2d7VwERJPyIt5OkAbBcRE5o6KGchfw0MzdnIF3I/14iI5wvlrpA0B3hAUv+IeFzSzqQ5rM8B80nB7MIq+3uopD8CzwM/BVYC7mqi/GjS3NBDSUP2C0iB7GYRcXeVbZqZmVmBFyYthyJiHmmhzpak1d+zgAdIq8FLzgEOlPSepPERMQc4ihQQzgF+xcdzJCu19yxp0dBRpOH7N4AfVdndU4Hfk7Kws0kLgD6VVY2Ikbn+uyTtQhqKvx54jzRNoTtwRJVtDgcuz8fuC/SLiFmNFY6I6aQFYHuSsr7vkRaFbVRle2ZmZlamrr6+vrX7YFYz+RFNQyJiTC3aq7twYT1A/SAPOpiZWbtRV00hZ0LNzMzMrOacnrGK8oPvG3sG55iIOLKW/WlKfvh+Y19HumUt+2JmZmaN83C8WQvycLyZmbVDHo43a213bD7eAaiZmVkDHISamZmZWc05CDUzMzOzmnMQamZmZmY15yDUzMzMzGrOQaiZmZmZ1ZyDUDMzMzOrOT8n1KwF+TmhZmbWDvk5oWZmZmbWNjkINTMzM7OacxBqZmZmZjXniWptlKQewOvAhhHxZit35zORNApYGBGH588vAGdHxE0VjuvBcnINzMzM7JMchFrNRUSv1u6DmZmZtS4Px7cjkjq2dh+WNZI6SPLviZmZWTNzJrQNkHQc8FNgLeAD4DpgeN69k6RfABsCjwMHR8S0fNxKwNnA94FVgSeAYyJiUt4/AXgG6AHsDJwraTowBPgtcALQAbgeODkiPpT0eeBKYE9gRWA6cEpE3FLhHDoBZwJ7AV2AN4AjIuLRBspOBoZExJj8+cvAUOCruT9PRcRuDRy3EfAn4KaIOEPSrsAwYGNgAfBMROxaoZ8DKpx/D9IUgMOBn+W6u0uaCQwGBgBrAy8Ax0XEU021Z2ZmZg1zhqeVSdoMOB/YIyI6A72AOwpF9gX6ABsAK5OCzpIRwBbA9sC6wETgzrKM56HA5aQg9fK8rTvQDdgI+F+gPzAo7xsAbAv8T0SsAuwCvFjFqVwDbJfLr0IKYqdXOkjSesBD+V+PfB4XNFBue+AR4PyIOCNvHl04tw2A/6uin9D0+ZfsTwrcOwMzSNf9e8C3gTWBa4F7JK1eZZtmZmZW4Exo61tIeqhrL0lTIuJ94K85IwdwVkTMBJB0AylDh6S1gP2A7hHxdt52Fim7tx1QykDeEhEP5vfzJAEsBk6KiPnAq5KGkrJ855Eyip2ALSU9HhFTK52ApLWBHwBfiojX8+ZXqjz/HwGTIuK8wrb7y8rsDZwMHBgRxX0LSJnKdSJiOvDnKtts6vxLzsp1IqkOOBboFxGv5f3XSDoB6AeMqbJdMzMzyxyEtrKIeE3SAcBRwAhJz5Gybi/nItMKxeeSMnMAPfPrczmwLOlIGrovmdxAs+9ExLyyMl3z+zHAOsAlwKaSHgAGl4b4G9Ejv77cRJmmjq103MnA3WUBKKTM5CnA85JmAMMj4tIq2mzq/IvbStYiBebjJBW/YqxjA8eZmZlZFRyEtgERcStwa56PeSRwO2l+ZFOm5NdNI2JGE+UWN7BtbUkrFQKxHsCbuS8LScPhF0hajTQ/9FrSlIDGTC71heqG7suP3btCmT2AkZJ+DfwkIupzX58F9s2Zym8A90p6rpD5bUyj519QvG4zSX8A7BoRT1Y6ITMzM6vMQWgrk7Q5Kav5MDAfmAXU03Dw+JGIeCcPz18l6YSIeCsHjTsB90XEnCYOXwE4X9LPgfVI8yGvy/3ZOffhudyfuaQpA5X6ckvuywBSgLxx3tdUBhVS5vXU3JcrgA+BPhHxQKHMdOCbwN3A9bmNFUjTEe6KiJmS3iNdsyb7Wun8Gzm/ekmXARdKOjwiXskLsXYAno+If1XRppmZmRV4YVLr+zxwBmnY/X3gONJq9/9UcexA4J/ABEmzgeeBfUhBbFOmAG+RVoFPJAV3Q/O+dUirxd/LfeoOHFFFXw4lrcR/CJhNyuauW+mgHMDtCOxGyka+Dfy8gXL/Ji162hC4hTSPdl/gJUlzSIu5zoiIh6voa1Pn35gz8jndLukD0pzXI/HvkJmZ2VKpq6+vFK/Y8qT0iKKI2KS1+9Iaan3+dRcurAeoH+RBBzMzazfqqinkLI6ZmZmZ1ZzTM1YVSb8BDmxk95YR8UYt+9MYSd1ofHHUGOCvNeyOmZmZNcLD8WYtyMPxZmbWDnk43qy13bH5eAegZmZmDXAQamZmZmY15yDUzMzMzGrOQaiZmZmZ1ZyDUDMzMzOrOQehZmZmZlZzDkLNzMzMrOb8nFCzFuTnhJqZWTvk54SamZmZWdvkINTMzMzMas5BqJmZmZnVnIPQFiCpq6R6ST1auy8NkfSCpH2rKHeApGdboP0RkkZVUW6UpBHN3b6ZmZm1Pq+WaIcioleV5cYCY0ufc+C4MCIOb6GumZmZWTvhTKhZBZI6tnYfzMzMljfOhDYDSesCw4FvAm8DQwv7dgHOBTYDFgIPAMdFxDuS+gKjgQ0iYkEu3xmYBvQFHgXOAQ4BOgPvAhdFxBVN9GUP4Npc54d5WydgOvCdiHhY0mRgSESMkbR67vvOpJ+HqcBREfGIpAG53CaSBgMH5Pp+mJtbNSIWSdoTOA3YOPf9nJxFLfXpUOBUoAtwO+nRDQurvLxfkPRbYB9gLnB2RFyd6+0BXA1sB9QDrwH7R8Q/m7g+PYDXgYHAYGBt4CFgYES8k8tMztdwJ+BrwGHAjZXO08zMzKrnTGjzGAssAroBfYABhX3/BY4hBWBbAesDl+V995ACq+8Vyu8HTI2IR4DdgIOB7SKiMynY+kuFvownBXj9Ctv2IQWhjzRQ/iRgJaA7sBqwF/BmeaGIGJrP87qI6JT/LZK0G3ANcAKwRu7vlZL6AEjqDfwKODLvvw+oOB+1YG9gXD722Fx397zvXOANYB1gLVKw/n6V9R5EulfdgMXAmLL9A4ETgU7A7ZXO08zMzJaMM6GfkaQNSFnETSJiFjBL0lnAvQAR8Wih+HRJQ0lZNiJicV54cxhwcy5zGFBajLMAWBHoJWlGRLxNyrQ2KgeG15MCstvy5kOAkRHR0DcTLADWBDYHno6Il6s/ewCOBy7LQTPAE5LGkIK8h/PrLRFxX94/WtIRS1D/gxFxR35/q6T3ga8AU3Lf1wU2ioh/AM8tQb1nRcR0AEknAa9IWj8i/pX3/zYins7v50uqdJ5mZma2BByEfnZd8+uUwrbXS28kfZWUsdualHGsI2XXSq4BTpPUDViFFGD1A4iICZJOAYYAv5f0OHBqRESFPo0EnpO0NmkY/+vA/o2UHQZ0BK4D1pN0JzA4B7zV6AnsJOnEwrYOfJx17QqU9/d1qjet7PNc0jlByuKeBoyTtDJwC/CLiJhTRb2TG3jfFfhXA/uh8nmamZnZEnAQ+tm9lV+7A6/m9z0L+28kBUf7RMQHec7muNLOiJgm6S5StnJ14LaImFnYPxwYLmkl4EzgVtIQcqMi4iVJTwEH5jrvj4hPDbHnsnNJ8zVPzXNbx5AC04MaKL64gW1TgFERMayR7rwF9Cjb1hN4palzqEZEzACOA46TtBFpvulg4PQqDu/Bx/er1L/iNSo/10rnaWZmZkvAQehnFBFvSpoADJV0CPBFUnauZBVgFjA7ZztPbqCa4aQFNisDpUU/SNoW+ALwJGlu6WyqX9AzkhSgdSZlDBskqT8wCXgZmAP8p4k2pgPbS1ohIkpB2qXASEl/BR4jZQe3AupyxnY0cE9+vNND+fy+RjMEoflZp0+QspazSMPz1V6f0yT9HZgPXAA8UBiKb0il8zQzM7Ml4IVJzWN/UrA4lTQ8O7qw78fA4aQA8lY+nvtZdC8p8zaLtHq+pDNwOTCTtDJ+dwpBagU3AhuRF9Y0UW5jUmb2A1IwN5+GA2VIc1VXBt6V9L6kDhFxL+kch+V+TgMuye0SEQ+TFhSNAP4NfBu4qcpzqGQbUmA7B3gB+BtwYZXHjiHdq6nA50lZ40ZVOk8zMzNbMnX19Q2tVbFay9nUeyPi3Nbuy/Ks8IimDRubotCc6i5cWA9QP8iDDmZm1m7UVVPI/2dsA/JjfrYlPUrJzMzMbLnnILSVSXoS2AQ4Ni+0qeaYU4BTGtndt/AYoTZN0gGkubANOWJpHwQv6QXSQrFyU/jk81PNzMyslXg43qwFeTjezMzaoaqG470wyawF3bH5eAegZmZmDXAQamZmZmY15yDUzMzMzGrOQaiZmZmZ1ZyDUDMzMzOrOQehZmZmZlZzDkLNzMzMrOb8nFCzFuTnhJqZWTvk54SamZmZWdvkINTMzMzMas5BqJmZmZnVnIPQ5Zik8ZIGt1DdIySNWoLy9ZK+kd/vKGlhS/TLzMzMlg1terWEpMnAkIgY09p9WRZFRN/W7oOZmZlZQ9ptJlRSx9bugy2dWt47/5yYmZm1jGbNhObM5QhgF2Bb4HXgAKAX8EugC3AzcGRELJTUDbgY2CFXMQ74WUTMljQO6AaMkPQb4LGI2F3SD4FfAD2BucAdwIkRMbdC3wYAQ4CrgeOBWUAvSWsCQ4HdgRWBPwPHRsTbko4BDouIbQr19AQmARtHxOSmziGXrweOBg4BtgBeAAZExEt5/wTg/og4p9BGPdA7Ih7Nn/cETgM2BqYB50TE2KbOt7xuST1I9+OgfP02BB4HDo6IaVXUdShwKuke3k56/MLCwv4vA5cC2wDvAdcC50XEoirq3gU4F9gs1/kAcFxEvFM4j2eAHsDOwLmSbiTdy+2AeuA1YP+I+GcT7ZSuwUBgMLA28BAwsNDW5Nz3nYCvAYcBNy7tPTAzM7OGtUQm9GDgJ8DqwLPAH0n/Q98a2Ar4LvADSSsCDwIvAhsBWwJdgcsAIqI/8AZweER0iojdc/2zgP2B1YDe+d+QKvvWA1gf2BTYVlIdcBspiPkS0B2YDdyQy48F/kfSVwp1DAAm5AC0yXMoO+b7wFrAVOCKKvuLpN2Aa4ATgDVI1/dKSX2qraPMvkAfYANgZeDsKvrQG/gVcGTuw325ntL+VfO2PwPrAv2AQ4ETq+zTf4FjSAHuVqR7VH4NDwUuB1bNr+eSfj7WIV3XQ4D3q2zvINI16AYsBsqnewzMfe8E3N4C98DMzKzda4k5ocMj4h8Akm4gZUK3z5nKuTmrtS2wAKiLiNPzcfMlnQY8JmlgYxm0iBhf+DhJ0lWkoKIaHwInR8R/c/8EfBXYtbBtMDBTUteIeFPS7aQA5/gctB5MyggC7FHlOQyLiDf+//buPN6u6f7/+GtJhJLEVLREJAStUFof1YkaSptGSgdfY0lQQ2soNbQxVPtVQ1Cl9EeERCQa5WuKMWiDKOWjSmljTCIiISGJRBBJ9u+PtY7sHGe6N/fuG/e+n4/Hedxz9lp7r7WHc+7nrGGftP0RfDzoqeV44BJ3fzi9ftzMRqV9fqgJ2yn5jbvPSnW5Hji8gXUOBm5y9/vS65FmdmQuvT/xfJ7t7hnwXzM7nxjIXVBv46UW32SGmQ0htkbm3eTuf03PF5jZQmLAu0m63p5pYD9KfuPuMwDM7GTgRTPbwN1fT+lXuftT6fl7ZtbS50BERKTDa40gNN+1uwBY7O4zy5Z1I3an9zSz8tarjBhcTKu08dQqdSaxa3sVoBPwZqN1KwWbSe+0jTdiPPqR94mtZK8Bw4FRKVjZkdgCe3Nu/Ub2IX9M3iXuf6N6A7uYWb5VsRPwcJX89TSnLj0AL1s2Kfd8I2ByCkBLXk7L6zKz7Ygtm9sAqxG7+ruWZZtc9vpkYvf4WDNbHbgJ+JW7z2+gyMkVnvcAXq+QDi1/DkRERDq8tpwdPwV4wd371sizJP/CzLoQu89PAa5x9/fSuM2TGixzSdnrKcRAbG13L08rGUcMSvcEvg+Mcff3mrAP9cwndosDYGYbVKjjCHev26LYiqYRhzLk9QZeTM+nAhubWcgFopuk5Y0YQwwi93H3d8xsT+LY2rxlzk/6YnMccJyZbUIcp3oK8QtKPb2IQXLpOcQvHBXLYsU4ByIiIu1KWwahdwBnm9lg4hjJ+cSxgF9291tSnhnE8ZslXYiTh2anAHRL4ljC5nLihJdLzOwsd3/LzNYFdnP3MQDuvsTMRhIDnu2J41ubsg+N1OF/zOz3xGD3d2XpfwCGm9ljwN+JLXBbE4cBlLdOtpaRwL1pKMGDwH7ESTulIPTOVM/BZnYBMUA9lThxqBHdiWN956WJXr+st4KZ7Qs8Tmy1nEscDtDovUfPMLNngfeA84EHcl3xlawI50BERKRdabNbNLn7AuIs+i2BicRA4gEgPwnobOAgM5ttZnenrtajgSFmNp84WeZ6mim1fu5NPA5Pmtk84B/AzmVZhwPfBCa5++NN3Id6Lk7rvkwMiO8sq+M44Aji2MpZxO70i/l4d3WrcfeHgGOJdz54G/gOcEMufS7x7gLfAt4A7iUGrr9vsIgjiGNT5xGHOtzYwDpfJAbE84l3HPgncGGD5Y0idqVPJX6xOahW5hXhHIiIiLQ3Icuy+rlE2oHcLZo2cvfX6mRvEeHCRRlAdtIK/bsQIiIiLSk0kqnD3qxeRERERNpOu2meSWMJ/1MleZS7H1VkfYqQbuJfrSt5y9JtoRrYTrs5dmb2HPF+r+WmEG8lJSIiIisAdceLtCJ1x4uISAek7niRtnb7FncrABUREalAQaiIiIiIFE5BqIiIiIgUTkGoiIiIiBROQaiIiIiIFE5BqIiIiIgUTkGoiIiIiBROQaiIiIiIFE43qxdpRbpZvYiIdEC6Wb2IiIiIrJgUhIqIiIhI4dRH2E6Y2drAn4GvAG8D6wKbu/vrbVoxwMzuBv7m7kPq5NsRGOvua7ZQuT2AqUBvd5/cEtsUERGRlqEgtP04CugKrOPui5ZnQ2a2M3C/u7fI9eHu/RrM9zDwUQBqZmcB33D3b7VEPURERGTFoe749mMT4L+NBKBmtnIB9RERERGpSrPj2wEzGwt8J738APg/4GBgI3d/LbUo7gT8E/hx+rsXcBmwN7AqMAMYDPwdeDktezdt82fufm2VsrdK29vQ3WemZQF4Bfi1u480s/HEltWzzaxLpXLd/aZ8C6yZ7QtcR/yi9H4q7gvu/kqN4/AZYCjwTeANYAhwFak73sx2A84BNgcWAQ8Ax7n7m2bWDxiZ9mNh2l43YDrQD5gAnA0MAroBbwEXufsfq9UHNDteREQ6JM2O7yjcfQAwGrjW3bsCv66QbSdiQLUR8ENgILA98Hl37w7sBvwnjSHtByx2967pUTEATWU/C/wLODC3eGdgHeCmCqtULLfCdm8gBozjc/WoGoAmo4HFQM+0vwPL0j8AjiGOl90a2AC4JKXdSwy698rl3x+YmoYJ7A4cAuzg7t2AHYBH6tRHREREqlDzTMfxqrtflJ4vNLOFxDGkW5rZo+4+dTm2PZw4JvUP6fUg4AZ3X1Ahb0uW+xEz2xDYFejj7nOBuWb2G2BcKY+7T8itMsPMhgDXpLQlZjYMOAy4MeU5DBiWq/eqQF8zm+nubxBbW0VERKQZFIR2HJPLXo8C1gcuBjYzsweAU9z9pWZs+8/A783sS8CLxJbWapOJWrLcvB7p75Tcskn5DGa2HbF1dRtgNWJ3QddclquBM8ysJ9Ad2BboD+Du481sMHA68BczexQ4zd19OestIiLSIak7vuNYkn/h7ovc/Xx3N2BjYAGpVbA8bz3uPge4ldj9/T/EVtdHq+StVW7NOtcxLf3dOLesd1meMcTxq5unoQD7l9VtOnAnsSX3cOBWd5+VSx/q7t8APgM8DdzchPqJiIhIjlpCOygz2xWYCzwDvEccD1maWT8D6GRmvd19UpVNlBsOXE8cKzm8meWWmwH0NLMupclC1aQJWOOBIWY2CPgUcEZZtu6p7HmptfOXFTY1FLgSWB3YL1fv7YFVgCeIY0vn1ai3iIiI1KGW0I5rfeLs89nECUsbA0cCuPsLwJ+Ax81sjpn9uIHt3U9s1dyOOMu8yeVWcCPxZvMzUj3KWzbLHUAMFKcCD1eoxxHEFs55xFbMG/m4ccQW2LnE2fMl3YBLgVnEmfF7kAtSRUREpGl0iyaRMqlFdZy7n7O829ItmkREpANq6BZN+s8okmNmOxFvIbVPW9dFRESkPVMQKnWZ2YHEcZKVHOnuowuqxxXAQVWSt3T3V5dz+08AfYBjSzfeFxERkdah7niRVqTueBER6YD0i0kibe32Le5WACoiIlKBglARERERKZyCUBEREREpnIJQERERESmcglARERERKZyCUBEREREpnIJQERERESmcglARERERKZxuVi/SinSzehER6YB0s3oRERERWTEpCBURERGRwikIbWVmNt7MTm/reuSZ2XNmtm8D+Q40s6dbsNxvmJnGf4iIiAgaqPYJYGYDgdPdvU9LbM/d+zaYbzQwOsLIOFEAACAASURBVFePEcAidz+8JeohIiIiHZdaQkVqMLOV27oOIiIi7ZFaQgtkZsOBbwFrAlOBs939+pS2FjAU2JV4XqYCRwOLgCuALmY2P21qT3cfX6WMPYFrgA3d/cO0rCswA/iuuz9kZpOJLaujqpXr7g/nW2DN7BTgwLS9/VJxa7j74hr7uxlwFbAd8AowvCx9P+BXQG/gXeB24ER3f9fMjgaOcvdtcvk3BZ4HNgWmA5cBewOrpv0b7O43VatP2sbkdHz2ALYFJqb9fSKljwBWBhYCewE3AEeb2VbARWlfFhBbiM8sHWMRERFpGrWEFmsCMfBZE/gtMMLMtkxpJwOrARun9B8Ar7n7o8BRwCvu3jU9xtco425i4No/t2wfYpD2cIX8Fcstz+TuQ4iB17W5etQKQDsDY4HngPWAH6X9yJsLHJDK3TE9SuNnRwObmtn2ufyHAfe7+xRgILA98Hl37w7sBvynWn3KHAUcD6wN3ATcZWbdc+n7APcA6wK/MLP1gAeBm4ENgK8CuxMDaBEREWkGtYQWyN2vzr0cY2YnATsTg6eFwDrAFsBT7v5CM8tYbGbXAYOAW9PiQcBwd680KahFyq1gB2IL58nu/h7wopldRGx1LdX17lz+l8zsT8DBKe0dMxtDDDyfMLNOwCHAcbl6dwW2NLNH3X1qE+p2tbs/CWBm5wM/BfYErk/pE9z9hvR8gZn9FHja3a9My6aZ2bnA+cQvEyIiItJECkILYmYrAWcB+wKfATJgdWJrG8AFxG7ga4HPmtkdwCnu/kYzihsOPJNa8LoBXyO2OFbSkuXm9QDedPcFuWWT8hnMbHfgTOBzwCpAJ+DNXJYrgfvN7ERiS2dnYpc9wChgfeBiYDMzeyDV+6UG6ja59MTdMzN7NdX3Y+lJb+DrZjYntyyk+oqIiEgzqDu+OPsDhwM/BNZy9zWBp0m/KuDu77r7ae6+FdAX2JAYIAIsaUpB7j4ReBI4iNhtfb+7f6yLvYFyyzWlHtOA9cxstdyy3qUnZtaF2FI7BuiZutRPJfcrC2mc5svE7vHDgBGlMZjuvsjdz3d3Iw4lWEAc69mIXrl6BKAnyw5BKN/PKcRjuGbusYa7d22wPBERESmjltDidCeO1ZwJrJQm/WwD3AFgZgOAl4AXgPnA+yk/xPGc65lZd3d/p8HyhhO7rrsRx31WVKfccjOAr5jZSu5eLyB9jBi8nWdmpxLHUp6QS+9CnFA0293fS2Njj6mwnaHAL4itpR/th5ntShxT+gzwHnFiU7V6lzvUzG4B/p3qtBpwZ438I4ljQw8ldtkvJAaym7v7PQ2WKSIiIjlqCS3OtcA/iAHfNGBLlp0otClxIs87xO7g94BfprS/AvcBk8xsjpl9s4HyxgCbEMdN3lYjX61yyw0jDiF4K9Wjane0uy8CvkcMtN8kTurJjwedT5z9PyTN+r+cpWMy80YTW1AfcfcXc8vXB64DZhNnym8MHFljP/OGApemdfcF+rv73Br7MgPYhTgTf3Ja7xbi8RUREZFmCFmmH7CRFVfqLn8FOK10O6vl3N5k0u2plndbjQgXLsoAspPU6SAiIh1GqJ9FLaGy4juQ2HVf8/6fIiIi8smi5plPIDMbDAyuktzP3SvdD7Q16nE38d6eH9MSk3bMbCZxnOdh7r6wwXWuIE7IqmTLKstFRESkYOqOF2lF6o4XEZEOSN3xIm3t9i3uVgAqIiJSgYJQERERESmcglARERERKZyCUBEREREpnIJQERERESmcglARERERKZyCUBEREREpnIJQERERESmcglCRVvS95/u1dRVERERWSApCRURERKRwCkJFREREpHAKQkVERESkcApCl5OZ9TCzzMx6tXVdKjGz58xs3wbyHWhmT7dC+cPMbERLb1dEREQ+2Tq3dQWkdbl73wbzjQZGl16nwHGRux/eSlUTERGRDkwtofKJZGYrF1ROMDN9WRMREWlh+ufaRGb2GWAo8E3gDWBILm034Bxgc2AR8ABwnLu/aWb9gJHAhu6+MOXvBkwH+gETgLOBQUA34C3gInf/Y4267Alck7b5YVrWFZgBfNfdHzKzycDp7j7KzNZKdd+VeO6nAke7+8NmNjDl62NmpwAHpu3tl4pbw90Xm9newBnApqnuZ6dW1FKdDgVOA9YFbgNCOha1julWwD/TfsxMywLwCvBrdx+Z9uMaYBfgy8BhZvY88Edga2AxMBHo7+6za5S1M3A/cBjwW+Kxvh04xt3npzwZ8HPgx0DfVOZjZvYT4Hhgo1S3U919XK19ExERkcrUEtp0o4kBT09gJ2BgLu0D4BhiALY1sAFwSUq7F3gX2CuXf39gqrs/DOwOHALs4O7dgB2AR+rU5W5igNc/t2wfYhD6cIX8JwOrARsDawI/AF4rz+TuQ9J+XuvuXdNjsZntDlxNDNDWTvW9zMx2AjCzHYHLgaNS+n1A3fGo7v4s8C9S4JvsDKwD3JRb9hPgRKArMcC9HBiXylo/pS2sVx7QCRgAfAH4PPFLw0VleQ5Lde8KPGVmRwCnpjquRQy0bzazPg2UJyIiImXUEtoEZrYhsRWxj7vPBeaa2W+IgRDuPiGXfYaZDSG23uHuS8xsGDG4uTHlOQwYlp4vBFYF+prZTHd/g9jSWlUKDK8jtp7emhYPAoa7e1ZhlYXEwG4L4Cl3f6HxvQdiK+AlKWgGeNzMRgEHAw+lvze5+30pfaSZHdngtocTg9c/5PbjBndfkMtzlbs/lZ6/Z2YLiV8GNnL3ycBjTdiXU3Pn8EzgDjM72t2XpPQL3f3l9HyxmR0H/NbdS5O37jKzvwH7EVuwRUREpAkUhDZNj/R3Sm7ZpNITM9uO2B2/DbHFMRBb0kquBs4ws55Ad2BbUiumu483s8HA6cBfzOxR4DR39zp1Gg48Y2brEbuWvwYcUCXvBcDKwLXAZ83sDuCUFPA2ojewi5mdmFvWiaWtrj2A8vpOojF/Bn5vZl8CXgR+CHyrLM/ksteDiEMDJpjZh8Ao4DfuXrP7P8mfw8nAKsCngTerlNUbuNzMLs0t60yFlmQRERGpT0Fo00xLfzcGSq1kvXPpY4jdx/u4+ztpzObYUqK7TzezO4nB01rAre4+K5c+FBhqZqsBZwE3E1v6qnL3iWb2JHBQ2ub97l4xMHL3d4ndyKelsa2jiIHpwRWyL6mwbAowwt0vqFKdaUCvsmW9iUFlTe4+x8xuJQ5veBp41d0frVUnd58EHApgZlsTW6QnkVqf68ifw17EoRSzcunl+z+FOD71RkRERGS5KQhtAnd/zczGA0PMbBDwKWJLXEl3YC4wL7V2/rLCZoYCVwKrE7tyATCz7YmtcU8QA6J51JnQkzMcOI7YEnpytUxmNgB4CXgBmA+8X6OMGcBXzGylXBf1H4DhZvYY8HdiK+jWQEgttiOBe9PtnR5M+/dlGghCc/txPXE87PB6mc3sEOA+d38dmJP2pdFjdq6ZHU4cAnEWcF1uPyu5GDjLzF4kBsmrAtsBs9x9YoNlioiISKKJSU13ADFYnErshh6ZSzsCOJwYQN7M0rGfeeOIrWxzibPnS7oBlxJb494C9iAXpNYxBtiEpRN2qtmU2DL7DrG7+T0qB8oQx6quDrxlZnPMrFOaCX4EsfV0FnF2/MWpXNz9IeDYtO7bwHeAGxrcB4iz1hcQg7uRdfJCHJ/7pJnNBx4lBrCja68CxIlldwL/Bp4nznQ/sdYK7n4V8U4Iw4HZwKvELyCF3CpKRESkvQlZVmn+irSm1Jo6zt3Paeu6dDSlWzS5eyG9AOHCRVl2kjocRESkQwmNZNJ/x4Kl2xltT7yVkoiIiEiHpCC0QGb2BNAHOLZ0U/YG1hkMDK6S3C93u6QVmpkdSBwLW8mR+Rvet0BZ86skPQyc31LliIiISPOpO16kFY0dOzYbMGBAW1dDRESkSA11x2tikoiIiIgUTkGoiIiIiBROQaiIiIiIFE5BqIiIiIgUTkGoiIiIiBROQaiIiIiIFE5BqIiIiIgUTkGoSCv63vP92roKIiIiKyQFoSIiIiJSOAWhIiIiIlI4BaEiIiIiUjgFoa3IzHqYWWZmvdq6LpWY2XNmtm8D+Q40s6dbofxhZjaipbcrIiIiK77ObV0BaTvu3rfBfKOB0aXXKXBc5O6Ht1LVREREpJ1TS6h84pjZyu2xLBERkY5ELaEtyMw+AwwFvgm8AQzJpe0GnANsDiwCHgCOc/c3zawfMBLY0N0XpvzdgOlAP2ACcDYwCOgGvAVc5O5/rFGXPYFr0jY/TMu6AjOA77r7Q2Y2GTjd3UeZ2Vqp7rsSr4upwNHu/rCZDUz5+pjZKcCBaXv7peLWcPfFZrY3cAawaar72akVtVSnQ4HTgHWB24CQjkW94zoCWBlYCOwF3GBmg6vVt862MuAEYGCqpwM/cfeXUvp44F9Ar7Ttc4DzzGxH4FxgS2A28Cfg9+6e1au/iIiIfJxaQlvWaGAx0BPYiRjolHwAHEMMwLYGNgAuSWn3Au8SA6yS/YGpKajaHTgE2MHduwE7AI/UqcvdxACvf27ZPsQgtFKgdjKwGrAxsCbwA+C18kzuPiTt57Xu3jU9FpvZ7sDVwM+BtVN9LzOznQBSEHc5cFRKvw+oOx61rO73EI/fLxqtbxVHAD8C1gOeA243s0659EOBS4E1gEvNrC9wF3BBKr8/8Vz+uAn1FxERkRy1hLYQM9uQ2HLWx93nAnPN7DfAOAB3n5DLPsPMhhBbKnH3JWY2DDgMuDHlOQwYlp4vBFYF+prZTHd/g9jSWlUKDK8jtp7emhYPAoZXab1bCKwDbAE85e4vNL73ABwPXJJriXzczEYBBwMPpb83uft9KX2kmR3ZhO1PcPcb0vMFZrY89b0o1/J5CrFlcwfg7yn9Jnf/a66so4Eb3f22tGyimV2W9mlkE8oVERGRREFoy+mR/k7JLZtUemJm2xG7drchtuAFoGsu79XAGWbWE+gObEtqxXT38an7+XTgL2b2KHCau3udOg0HnjGz9Yjd+F8DDqiS9wJil/e1wGfN7A7glBTwNqI3sIuZnZhb1omlra49iF3feZNo3OQWrO9H23L3BWY2k6Xnr1JZvYFdzewHuWUrEYcAiIiISDMoCG0509LfjYGX0/PeufQxwE3APu7+ThqzObaU6O7TzexOYmvlWsCt7j4rlz4UGGpmqwFnATcTu/2rcveJZvYkcFDa5v3uXrHL2t3fJY7XPC2NbR1FDPQOrpB9SYVlU4AR7n5BlepMI46zzOsNvFhrH6qV2cT6lvuoHul4rsuyXfnl+zcFuMbdf9ZgXUVERKQOBaEtxN1fS5NahpjZIOBTxEk6Jd2BucC81Nr5ywqbGQpcCawOlCb9YGbbA6sATxDHls6jgQk9yXDgOGJL6MnVMpnZAOAl4AVgPvB+jTJmAF8xs5XcvRSw/QEYbmaPEbu1OxHHvobUYjsSuDdNMnow7d+XaTwIXZ76ljshnatpwHnAK8A/auT/E/Cgmd1DHJeaESeYrevuDzan/iIiIh2dJia1rAOIweJUYjd0frzgEcDhxADyZpaO/cwbR2yFm0ucPV/SjThRZhZxZvwe5ILUOsYAmxC7/m+rkW9TYsvsO8Tu6PeoHChDHKu6OvCWmc0xs07uPo64jxekek4HLk7l4u4PAcemdd8GvgPcUGHbjWpKfSvV/2ZgJnF4xF7uvrhaZnd/FtiTOOlqOvAmMILYgioiIiLNELJMd5hZkaQWunHufk5b16U9Srdo2rFsolirCRcuyrKT1OEgIiIdSmgkk/47rkDS7Yy2J96OSERERKTdUhC6gjCzJ4A+wLHuPrPBdQYDg6sk96t34/YVhZkdSBwLW8mR+RveN7Ctu4EdK6W5e9dKy0VERKR46o4XaUVjx47NBgwY0NbVEBERKVJD3fGamCQiIiIihVMQKiIiIiKFUxAqIiIiIoVTECoiIiIihVMQKiIiIiKFUxAqIiIiIoVTECoiIiIihVMQKtKKvvd8v7augoiIyApJQaiIiIiIFE5BqIiIiIgUTkGoiIiIiBSuc1tX4JPAzHoAU4He7j65javzMWb2HPBbd7+hTr4DgVPcfZsWLn8Y0NndBzaQ94/A/sCqwCbu/mZL1kVEREQ+GRSEtgPu3rfBfKOB0aXXZjYCWOTuh7dS1ZZhZl8DDgV6ufvMIsoUERGRFZO646VImwDTqwWgZhbMbIX6YmRmK7d1HURERNqjFeof/orCzD4DDAW+CbwBDMml7QacA2wOLAIeAI5z9zfNrB8wEtjQ3Rem/N2A6UA/YAJwNjAI6Aa8BVzk7n+sUZc9gWvSNj9My7oCM4DvuvtDZjYZON3dR5nZWqnuuxLP71TgaHd/2MwGpnx9zOwU4MC0vf1ScWu4+2Iz2xs4A9g01f3s1IpaqtOhwGnAusBtQEjHotYxPQX4LdDFzOYDj7v7rmaWAT8Hfgz0BXYBHjOznwDHAxsBrwCnuvu43PZq1rFGPSan47kHsC0wMR2fJ1L6CGBlYCGwF3ADcLSZbQVcBGwHLCC2KJ9ZOiciIiLSNGoJrWw0sBjoCewEDMylfQAcQwzAtgY2AC5JafcC7xKDl5L9ganu/jCwO3AIsIO7dwN2AB6pU5e7iQFe/9yyfYhB6MMV8p8MrAZsDKwJ/AB4rTyTuw9J+3mtu3dNj8VmtjtwNTEwXDvV9zIz2wnAzHYELgeOSun3AfvW2YdSeUcBr6Syds0lH5a20RV4ysyOAE4lBslrEQPem82sT6pDzTo24ChigLs2cBNwl5l1z6XvA9xDPMe/MLP1gAeBm4nn+6vEc/mrBssTERGRMmoJLWNmGxJbEfu4+1xgrpn9BhgH4O4TctlnmNkQYssa7r4kTdI5DLgx5TkMGJaeLyROyOlrZjPd/Q1iS2tVKTC8jth6emtaPAgY7u5ZhVUWAusAWwBPufsLje89EIOzS1LQDPC4mY0CDgYeSn9vcvf7UvpIMzuyiWWUu9DdX07PF5vZccSJVk+nZXeZ2d+A/YgtyfXqWM/V7v4kgJmdD/wU2BO4PqVPyE3yWmBmPwWedvcr07JpZnYucD6xdVdERESaSEHox/VIf6fklk0qPTGz7Yjd8dsQWxwDsQWv5GrgDDPrCXQndvn2B3D38WY2GDgd+IuZPQqc5u5ep07DgWdSi1w34GvAAVXyXkDsTr4W+KyZ3UGcEV8z2M3pDexiZifmlnViaatrD6C8vpNYPpMr1OFyM7s0t6wzS1t069Wx4fLcPTOzV1l63qvV5+tmNie3LKQyRUREpBkUhH7ctPR3Y6DUOtc7lz6G2IW7j7u/k8Zsji0luvt0M7uT2Fq5FnCru8/KpQ8FhprZasBZxC7enrUq5O4TzexJ4KC0zfvd/WNd7Cnvu8Tu69PS2NZRxMD04ArZl1RYNgUY4e4XVKnONKBX2bLewIu19qGO8npMAX7t7jdWykz9OtbTq/TEzALx+OePZ6X63O/u/REREZEWoSC0jLu/ZmbjgSFmNgj4FHECTEl3YC4wL7V2/rLCZoYCVwKrE7uQATCz7YFVgCeIY0vnUWdCT85w4DhiS+jJ1TKZ2QDgJeAFYD7wfo0yZgBfMbOV3L0UeP0BGG5mjwF/J7b2bQ2E1GI7Erg3TeB5MO3fl1m+ILTcxcBZZvYi8DRxCMN2wCx3n9hAHes51MxuAf4NnEBs0b6zRv6RxLGhhxK77BcSA9nN3f2eZuyfiIhIh6eJSZUdQAwWpxK7eEfm0o4ADicGkDezdOxn3jhia9pc4uz5km7ApcAs4sz4PcgFqXWMId7iqCtxRno1mxJbZt8hdiu/R+VAGeJY1dWBt8xsjpl1SjPQjyC2ns4izjy/OJWLuz8EHJvWfRv4DnEGeYtx96uIdyQYDswGXiV+EVg5pdesYwOGEs/DbOKEqP5p/G+1+swgztrfm3hMZwO3EM+HiIiINEPIskpzW2R5pdbUce5+TlvXRZbK386qiPLChYuy7CR1OIiISIcSGsmk/46tIN0qaHvirX5EREREpIyC0BZmZk8AfYBjG/1pyjRjfnCV5H65WxGt0NJv019ZJfnIRm4m3wJ1uII4gauSLVu7fBEREWmMuuNFWtHYsWOzAQMGtHU1REREitRQd7wmJomIiIhI4RSEioiIiEjhFISKiIiISOEUhIqIiIhI4RSEioiIiEjhFISKiIiISOEUhIqIiIhI4RSEioiIiEjhFISKiIiISOEUhIqIiIhI4RSEioiIiEjhFIRKs5nZjmY2p8G8d5vZKa1djoiIiHwyhCzL2roO0gGZWQbs6O4T2rourWns2LHZgAED2roaIiIiRQqNZFJLqEgNZrZyW9dBRESkPerc1hWQlmFmk4GhwG7ADsBk4Ah3/7uZdQYGAwOBNYGngOPd/dk627wJmOruJ+SWDQJOB/oA3wTud/fOKe1bwAXApsBC4F/u/q2UNj7lPdvMnk6bG2dmS4Ax7n54jXrsXFbOCKAT8D6wD/Au8Ft3v7LB43QNsAewLTARONrdn8hte+VU/72AG4CjzWwr4CJgO2ABMBo4090/rFemiIiIfJxaQtuXQ4HjgDWA+4Br0/KTgYOB7wKfBR4G7jOz7nW2dw1wUFlr4EBghLtXGscxErg0lb8h8LtKG3X3bdLTPdy9a60AtIYfAWOBtYFjgcvMbOMG1z0KOD6texNwV9mx2Ae4B1gX+IWZrQc8CNwMbAB8Fdgd+FUz6i0iIiIoCG1vrnT359x9MTAM6GNmawCDgPPdfaK7fwD8FlgM9K+zvXuJLYJ7ApjZpsDXgRFV8i8ktoKu7+4fuPvflneHaviru9/u7kvc/WZgDrFlsxFXu/uT7r4QOB94j7SPyQR3v8HdF7v7AmIA/7S7X+nuC919GnBuWi4iIiLNoCC0fZmee/5u+tsN2Ah4pZTg7kuI3fUb1dpYCmavIwaxEFtBH3D3qVVW2QvYDPi3mf3HzH7exPo3xfSy1+8S97URk0tPUovuq0CPSulJb+DrZjan9CC2En+mKRUWERGRpTQmtGOYSgykADCzlYBeaXk9w4lB5WeJLX+nVsvo7k8D+5pZAL5BHPP5jLv/tUL2trwtQ6/Sk1TXnsBrufQlZfmnEMek1ms5FhERkQYpCO0YRgCnmNlDxFa+U4nn/s56K7r782bmwNXElsZbKuUzsy7A/sCd7j7LzGYTg7lFVTY9g9hq2ha3aDrUzG4B/g2cAKxG7WMxkjg29FDgeuKwg17A5u5+TyvXVUREpF1Sd3zHcAHwZ2Ac8AawK3FS0DsNrj8c6Adcn8aUVrMvMNHM5gO3A79294eq5D0N+K2ZzTazurPaW9hQ4gSq2cQ693f3udUyu/sMYBdgb2IQP5sYjG/S6jUVERFpp3SzeulQ0i2aTnf3UUWUp5vVi4hIB6Sb1YuIiIjIikljQjs4M3sOqHR/zSnu3regOvQE/lMleZS7H9WEbV0BHFQlecum1k1ERERah7rjRVqRuuNFRKQDUne8iIiIiKyYFISKiIiISOEUhIqIiIhI4RSEioiIiEjhFISKiIiISOEUhIqIiIhI4RSEioiIiEjhFISKiIiISOEUhIqIiIhI4RSEioiIiEjhFISKiIiISOEUhIqIiIhI4RSESrtiZmeZ2f1tXQ8RERGpTUGoiIiIiBSuc1tXQDo2M1sHuBjYHQjAvcAJ7v62mR0HnAB8GngHuNbdB9fY1r7AYGAlM5ufFm8DPAQc4+635PKOBD5098PMbASwMrAE2AuYCfyvu4/I5d8ROBfYEpgN/An4vbtny30QREREOiC1hEpbGw2sRQzuPk8MOK8zs82B84A93b0b0Be4vdaG3P0G4BxgvLt3TY+XgauBw0v5zGwN4EfAVbnV/4cYAK8NHAX8PzP7WsrfF7gLuABYF+gPHAP8ePl2XUREpONSS6i0GTPbAPg2sLm7z07LTgQmEoPJAPQ1synuPgd4rJlFDQN+aWYbuvs04ADgZXfPb+8xdx+Vnt9nZv8HDAT+DhwN3Ojut6X0iWZ2GXAwMLKZdRIREenQ1BIqbWmj9HdSbtnL6e+HwIHAT4DXzWyCme3RnELc/VXgPmBQWnQ4y7aCAkyu8LpHet4b2N/M5pQewK+BzzanPiIiIqKWUGlbU9PfXsBL6fkmpTR3fxy42cy6ELvIbzOzddx9QY1tLqmy/ErgD2Z2J7Hr/7qy9F4VXr+Wnk8BrnH3n9UoV0RERJpAQai0GXd/3czGAReZ2SHE7veLgLuB7mZWmlT0HjAXyKgeZJbMAHqaWRd3X5hbfidxMtHVwP+Vuv9zvmJm+wN/Ab4J/JA4WYq03oNmdg9wT6rH5sC67v5gM3ZdRESkw1N3vLS1g4B5xHGgE4E5xLGWXYhd3tPTsuOAH7r7+3W2dyOxhXVG6jrvDeDui4kB6Bf5eFc8xODzu8SZ71cDP3P3CWndZ4E9gZ+n+rwJjCBOUhIREZFmUEuotCl3n0kMRMvNAr7ajO3NBnarkjwJeKFK6+V77n54heWl7T5aY7siIiLSRGoJlQ7BzLoBxwOXtnVdRERERC2h8gljZgcSJxlVcqS7j66wzs+Jt3waBwxtxeqJiIhIg0KW6QdfRFrL2LFjswEDBrR1NURERIoUGsmk7ngRERERKZyCUBEREREpnIJQERERESmcglARERERKZyCUBEREREpnIJQERERESmcglARERERKZyCUBEREREpnIJQERERESmcglARERERKZyCUBEREREpnIJQERERESmcglARERERKZyCUBEREREpnIJQERERESmcglARERERKVzIsqyt6yDSbq2yyirPLly48P22rkdb69y586cXLVo0q63r0dZ0HCIdh0jHIdJxiNrZcZiVZdl36mXqXERNRDqqrbfe+n13t7auR1szM9dx0HEo0XGIdBwiHYeoIx4HdceLiIiISOEUhIqIiIhI4RSEirSuoW1dgRWEjkOktfKcBAAAEkdJREFU4xDpOEQ6DpGOQ9ThjoMmJomIiIhI4dQSKiIiIiKF0+x4keVkZpsD1wLrAG8BB7v7i2V5OgGXAt8BMuA8dx9WdF1bU4PH4Szgp8DradEj7v6zIuvZ2szsQuCHQC9ga3d/tkKejnA9NHIczqIdXw9mtg5wHbAp8AHwEnCku88sy7caMBzYDlgEnOTudxRc3VbThOMwAvgWULpN0Y3u/rsCq9rqzOxWoDewBJgPHOvu/yrL0+4/H0rUEiqy/K4ALnf3zYHLgSsr5DkQ6ANsBnwVOMvMehVWw2I0chwARrr7tunRbgKOnFuBnYApNfJ0hOuhkeMA7ft6yIAh7r6Fu38BeBk4r0K+k4B57t4HGAAMM7OuBdaztTV6HCAGXKXroV0FoMkh7r6Nu38RuBC4pkKejvD5ACgIFVkuZrYe8CXgz2nRn4Evmdm6ZVn3Ba5y9yXp2/+twD7F1bR1NeE4tHvuPsHdp9bJ1q6vB2j4OLRr7v62u4/PLXoM2LhC1n2JX+JIvQcO9Gv1ChakCceh3XP3ubmXaxBbRMu1+8+HEnXHiyyfjYBp7r4YwN0Xm9nraXm+q6kny7YIvZrytBeNHgeA/cxsD2AG8Gt3f7TYqq4Q2vv10BQd4nows5WAo4HbKyR3mOuhznEAONHMjiS2lv7K3f9bWOUKYmbDgD2AQOxyL9dhrge1hIpIka4AeqcuuQuA29J4MemYOtL18EfiGMDL2roibazWcTgN6OPuWwM3A/ek8ZHtirsf7u49gcHE677DUhAqsnymAhuWPijT3w3S8rxXWbb7qWeFPJ9kDR0Hd5/h7h+m5/el9K0KruuKoL1fDw3pKNdDmqS1GbCvu1fqfu0Q10O94+Du00rL3X0k0BXoUWwti+Pu1wG7VPji1SGuB1AQKrJc3P1N4F/A/mnR/sBT5bM+gRuBn5jZSmmc5N7A/xVX09bV6HEwsw1zz7clzpx+vqBqrkja9fXQqI5wPZjZ74iz3vd29w+qZLsRODLl3wzYHrinmBoWo5HjUHY9fBtYDEwrpoatz8y6mtlGudcDgLfTI6/DfD7oZvUiy8nMPke8NdFawGzirYmeN7O7gDPd3VPL4GXEcUAA57t7u/p1jAaPw7XEf0SLgYXEMYB3tVmlW4GZXQr8APgM8VYzb7l73w54PTRyHNr19WBmfYFngReA99LiSe7+fTP7F/Bdd3/dzFYHRgBfJB6LU9z9traoc2townG4H1ifOFnnHeBkd3+sTSrdCsxsfeA2YHXieX6beDuuf3a0z4cSBaEiIiIiUjh1x4uIiIhI4RSEioiIiEjhFISKiIiISOEUhIqIiIhI4RSEioiIiEjhFISKyDJCCN8OITyce71zCGFyG1apMCGEESGEYS24vV4hhCz3et0QwpQQwqcbWPeoEMJ1LVWXT4IQwo4hhDltXY+OKIRwUFPe5y39XpHaWuu90Yzzfn4I4X9bqnwFoSLykRBCAC4Gfl0n39EhhGdDCO+EEGaHEDyEsG8ufXII4aAK631seYheSNvqWpa2cwghCyHMT4/XQwjDQwhrL9+eto0sy2YC11P/+K4O/BY4q4BqrTCyLHs4y7I127oe1YQQzgoh3N/W9egIWutYhxDGhxBOb+nttrby90YbXovnAT8LIWxYN2cDFISKSN4eQBfgb9UyhBD2JwZRhwFrEH+e8wTiDeqbYxdgE+INqvevkL44y7KuWZZ1Bb4BfBX4QzPLWhFcAwwKIXSvkecg4N9Zlr1cUJ2WEULoFELQ/wcRWUaWZbOBu0m/8LW89CEj0kZSq+DpIYS/pVa+f4cQvhBC2D+E8FIIYW4IYVgIoXNunZ4hhJtCCNPTY2gIoVsu/ZwQwitpey+HEH6eS+uVWhV/HEL4TwhhXghhXAjhs7lq7Q3cn9X+FYuvAQ9lWfaPLHovfUsf18xDcSTxJwqvo84HW5ZlrwB3EH9ZZhkhhM7pmOxVtvzaEMI16fluIYR/pNbbmSGEMSGE9aqVl47XN3Kvdw4hLCorc3BqyZ0TQngkhLBdnX14kfgLQt+qkW1v4L6yuhwfQpiYzturIYRzQwidUtqFIYRbyvLvkvKunl5vFUK4N4QwK7f+yimtdG0cFkL4D7AAWC+EsF8I4enUSj09hHBlaXtpvc+EEMama/WFtH4WQuiVy/OT1Go+N4TwVAhhD6qocHxHhBCuCyFck47vtPT+2DaE8ETav7+FEDbIrTM5hHBmCGFCeh94CGH7XHrNayCEsHI6p8+n7b8cQvhhiC39g4Gdw9KW+U2q7Mc3Uxlz0zk7Mpe2cwhhUQhh37TtuSGEv+TfxxW215zPii+EEP6a9vOVtH6nXPqX07GZH0KYQPwimC9ztXRdTQohvB1CuCeE0KdaHSvUeZ0Qwsh03cwI8X24di59mV6R3DXYo9qxDiEMTPt7atrumyGEiypcxz1y2x0YQngpPb8M2BE4I22z4k/EhtjK+ECIXc8zQwhvhRBODCFsnI7pvBDCkyGEz+fWWa73Su5avyp3rX/suknPax6fsn1ZZthEC533+4ifUcsvyzI99NCjDR7AZOBF4PPAysAo4GVgKPFn3XoCbwIHpPyrAi8Ru2k/Rfx5zLuAa3LbPIjYMhmAXYk/kfftlNYLyIhB3KeB7sAjwFW59f8BHFdWz52BybnX+wDvA2cDuwFrVtm3g+otB9YFPiD+vOO2qX7blZW9KPe6D/G3xa+pckyHALfmXncF5gM7ptffIP4ud2fiz0k+BPw5l38EMCz3OgO+UaM+56RjtgnQidg6PAtYK3/MK9RzLHB2jWvjDeB7Zct+CPRO5/aLKc+RKW1L4s9erpvLfy1wdXq+HvAWMcjvAmwIOHBm2bXxQDouXdL+9AP6Ehss+gD/Ac7NlfEA8Tetu6cyxqft9ErpRxCv2W3SNr6bzkefKvtdfnxHEK/h/mn9o9L6twM9gNWAvwJDy66x14k/B9oF+CUwE+je4DVwftrPL6Rj3QP4Qko7i/glrdb7uneq86BUxleIP8+4T24fM+Bq4vW5PvFz4LQW/KxYI10fZwCrpPVeAU7Opb+Vjk2XdDxmsOz7/HriZ8X6Kc9vgInAypXeKxXqfA/xOl8rPe4E7qzxWdArHZce1Y41MBD4ELic+Bm4KfGnQH9VaRu5dV7KvR4PnF7nHJ6Vyjmcpe+DxcD9ZedgXG6d5X2vjCBeN99L2/hBqsPGVd4b1Y7PS2XLPjpPLXHeU57tiD1XXWodx0Yehf7T1UMPPZY+0ofwybnX300fSvlA4i/Axen5j4CXy7axHTGI61SljJuAIel56QN6+1z6z4Cncq9fAAaWbWPn/IdUWrYncDPxH91iYvf9VmX79i4wp+yxhGX/8ZxC/OdZ+sf2T+DKsrKztO5sYBJwBRUC35T/88RgbL30+lDghRrnYE/gzdzrjz6w0+uqQSgxQJkH7FS2zX+X9pHqQeho4E816rUQ2LnO9XMh8Jfc638AJ6Tn3YjB2tfT65OAv5at/0PSP6zctbFTnTKPAR5Pz3ukdTbJpe/Gsv9YnwUOLtvGWKoEAVQOQvOBy2pp+/vklv2UZa/hycD/5l4H4FVSgFbrGkh55wP9q+Q9i/pB6GDgkbJl5wL3ll3T+ff5BcAtNbY5maZ9VhwATCX9NHdadiTwfHp+YDom+fTfkd7nxC+pGdAzl74SMJf0fqBGEEr8IpwBm+WWbZGWfTa3T80JQj8AVsstO5z0Hi/fRm6d5gShz5Ute7PCOZjdgu+VEeSu9bRsJrBXlfdGteNTKwhd7vOelm2W8q1X6zg28vio6V5E2sT03PMFxPGPM8uWlbrpegM9w8dnSGbEFp1pIYTjgJ8QP/QCsbXg+hplvpvbPsRAr9ZYxVhglt1B/LZMCOFzwJ+AO0IIvbP0KUVspRuVXy/kZmGGEEKq66gsyz5Mi68Gzgsh/CLLsvlp2eKswckqWZb9N4TwT2KL8O+JrVHDc2VuR2y93IYY0ARia1RzfDqtOzbkZsATW0l6VF7lI92JAXU1HzsPIY7FPZHY6tqZ2ErxWC7LcGJAdjHwP8C0LMseSWm9ga+XXTuB2MqTN7mszN2BM4HPEVvUOhH/GUNsTYX4T61kStn2egOXhxAuzS3rDLxG4z66XrMsWxAvm4+9b8q7sifn1slCCK+Szkmda2BdYsviC02oX7mNiK2OeS8D+WEi5e/z8vdhJU35rNiIGFjkr8uX03KIx2JKWXr+euyd/j6TjnfJyrlt1FLKk9/my7m06TTfm1mWLci9nkz991tzlNdxATWuuxZ4r1Qqs5Hroila6rx3Z2njwHLRmFCRT44pxG/8a5Y9Vs2ybFoI4evErsQjgU+nwG0s8Z9so54idu02LMuyicTAZ2Nit1ujdiN2Wx2axozNIHb9dCW25DTXcGBgGsf0FWBkLm0MsbV18yzLulN5IlTeu8SgpGSD3PNZKf1bZedj9SzLzquz3a2Ix7qaZc5DCGEjYvff2cSWpDWIXZL5czsG2CyE8CVii8jwXNoUYqtJvp5rZHGyV96SXJldgFvTdnum43Vqrsxp6W/P3Pr556VyDy0rt2uWZUfX2PeW0Kv0JH3Z6cnSwLfWNTCTeE43q7LdJVWW501l6T/zkk3S8qJMBTYOy0YS+TpMq5Cer3MpQNqs7NytlmXZnxssH3LngaVjD0tp86n+3oLqx3q9EMJqude9WHpuS19cm7PdZmuh90pTVdqP8mMKy+5/S533rYgtxQubW/kSBaEinxx3AKVJE91CtGEI4fspvTuxa3wmkIUQ+hPHKTXFrcTgsKoQwqEhhH1CutdlmgRwFPCfLMvebkJZRxDH432OOB50W+KH23CWb+blGGJweylwX5Zl03Jp3YldS/NCCD2JY6NqceCQEEKXNIHgxFJCak24BLgwhLAZQAiha4j3WS3/x/eRFByvSxxfVs2tLDtxqSvx83om8GEI4SvAj/MrZFk2B7iFGKiWB98jAUvnbtUQwkppIsN3atShC3Ec8uwsy94LIWxJ7GIslfcasWvzvHQ9rgeU3/rmYuCsECcShRDCp0II30it563p0BDCl0KcsHIyscXzzpRW9RpI5/T/AUNCnMhVeo9tnbLMIPZGdKlR9p+B7UIIB4c4ce3LxOv56hbdw9ruJJ67wena3YIYFJXqcAfxmjo5xIlYXyIOXQEgy7I3iT0ofwrpVjwhhDVDCN8PZbdRqyTLsteBccBFab21gIuAu7MsK7X2ObB/es+sSxy/mlftWK9EvOY+FeLEsJOI45/JsmwW6YtPiHd42JrY21K+3YYnWDWoJd4rTVXp+DxFDNL3TO/x7wM75dJb6rzvTvyMWm4KQkU+IVIX1G7EFrKJxH+kDxCDN4B7iTPMHye20v2IGJQ0xb3AohDCzjXyzCZ2+/43hPAucSziHOLYuoakD+G9gQuzLJuRfxBbc78YQrAm1h2ALMvmEve7H/F2SHlHEMeQzSOOab2xzuaOIf7Deps45m5EWfqvgduA20II7xAnjxxF7c/WQ4ERqZ7VXAdsk/7JkmXZf3NlzSEGTpVapIYT9/veFAiQ1p9BvBXW3sTuy9nEY1RxdndaZz5wNDEgm09seS0f2nEAMcB7DZjA0uP5QdrGVcTJYsNTma8Sg42Va+x7SxhK/BIyG9iXOMazdLzrXQOnEc/1rSnPgyxtGb2R2JI3I8QZzOUtnmRZNok4XvAY4iSQ64gTwP7SYntXR9rXPYhfZN4gvq9HEoeolL6w9Ccem9nEY/X/yjbzE+IkwPEhhHnEsc77ELthG3EQ8fhNTI85wMG59NOJX5qnEwO0MWXrVzvWU4gtepOInz33EK+xkkOIn0Vz0/6WB/8XE7+QzQkhPNfgvtTUEu+VZvjY8cniLd2OJ17/bwPfIU6GKtVzuc97CGFN4vV9RTPrvYyw7NAAEenoUuvY4CzLdkqvdyYGTb3asl6fRKn1dFKWZSG9/jTwJGBl4/kqrXsUcWLRj2vlW5GEEL5NDJQ/lbXRP5cQxx2fXj4eWT75QggDiee2pVsyC7civFeaI4RwLnE8covc8F8Tk0RkGVmW3UNsXZAWlroLN24w7xW0UGtDawkhbENsIfk3cWzZ2cANn6R/qiJFaC/vlSzLftWS21N3vIjUM5lP9i8UtaU5xMlW7dXaxC7t+cQuxmeI3YEisiy9VypQd7yIiIiIFE4toSIiIiJSOAWhIiIiIlI4BaEiIiIiUjgFoSIiIiJSOAWhIiIiIlI4BaEiIiIiUrj/D1GJ9c5rLzpuAAAAAElFTkSuQmCC\n",
      "text/plain": [
       "<Figure size 576x597.6 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "shap.summary_plot(shap_values, Xdf, plot_type='bar')"
   ]
  },
  {
   "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
}
