{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "from sklearn.linear_model import LinearRegression, Lasso, LogisticRegression\n",
    "from sklearn.ensemble import GradientBoostingRegressor, GradientBoostingClassifier\n",
    "from sklearn.ensemble import RandomForestRegressor, RandomForestClassifier\n",
    "from sklearn.preprocessing import PolynomialFeatures\n",
    "from sklearn.pipeline import Pipeline\n",
    "import scipy.special"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# 2. Synthetic Data with Binary Instrument and Treatment\n",
    "\n",
    "Data generating process inspired by an \"intent to treat\" instrument setting with non-compliance. The instrument corresponds to a fully randomized recommendation of treatment. Then each sample complies with the recommendation with some probability. This probability also depends on an unobserved confounder that has a direct effect on the outcome. Moreover, compliance also depends on the observed feature $X$.\n",
    "\n",
    "\\begin{align}\n",
    "X \\sim \\; & \\text{U}[0.2, 1]^d \\tag{features}\\\\\n",
    "Z \\sim \\; & \\text{Bernoulli}(p=.5) \\tag{instrument}\\\\\n",
    "\\nu \\sim \\; & \\text{U}[0, 1] \\tag{unobserved confounder}\\\\\n",
    "C \\sim \\; & \\text{Bernoulli}(p=\\text{Logistic}(X[0] + \\nu)) \\tag{compliance indicator}\\\\\n",
    "T \\sim \\; & C\\cdot Z + (1 - C)\\cdot (1 - Z) \\tag{treatment}\\\\\n",
    "y \\sim \\; & \\text{Normal}(\\mu=\\theta(X) \\cdot (T + \\nu) + X[0], \\sigma=.1) \\tag{outcome}\n",
    "\\end{align}\n",
    "\n",
    "Moreover:\n",
    "\\begin{align}\n",
    "\\theta(X) = \\; & \\alpha + \\beta \\cdot X[0] \\tag{CATE}\n",
    "\\end{align}\n",
    "\n",
    "We need to make sure that for \"overlap\" we have that:\n",
    "\\begin{equation}\n",
    "Cov[T, Z \\mid X] = (P[T=1\\mid Z=1, X] - P[T=1\\mid Z=0, X])\\cdot P[Z=1\\mid X] \\cdot (1-P[Z=1\\mid X]) \\geq \\gamma > 0\n",
    "\\end{equation}\n",
    "for the DRIV method to work, as the variance depends inversely in $\\gamma$. This is the reason that we have $X[0]$ be distributed strictly positively, so that the probability of compliance $C$ is bounded strictly above $0.5$. This then implies that:\n",
    "\\begin{equation}\n",
    "P[T=1 \\mid Z=1, X] - P[T=1 \\mid Z=0, X] = P[C=1\\mid X] - P[C=0\\mid X] = 2 P[C=1 \\mid X] - 1 >0\n",
    "\\end{equation}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "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": "iVBORw0KGgoAAAANSUhEUgAAAXcAAAEICAYAAACktLTqAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADl0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uIDIuMi4zLCBodHRwOi8vbWF0cGxvdGxpYi5vcmcvIxREBQAAIABJREFUeJztvX+UVNd15/vdVX0bqlFCNRbOEy0QWFFEQjCNRQRjzWQCY0u2FKF++oVkKWNPnOglmWQtsMKkZWkEaOSIhOVBmRWvSWQvj18iPbklIfdDRn4oGaE1s7CRBdONGBRh6xeIQi9iDM2M6AKqq/f8UXWKU7fOOffcqlvdXdX7sxaL7lv3nnvqVNc+5+6z93cTM0MQBEFoL1KT3QFBEAQhecS4C4IgtCFi3AVBENoQMe6CIAhtiBh3QRCENkSMuyAIQhsixl0QBKENEeMuTCpE9B4R5Ynobye5H68Q0W9MZh8ahYi2ENFZImIi6pjs/giTixh3IVE0Y/0REf0jEf0nIrok4rKbmfm3iGhB+Tr1j8vGSv3+z2L0YzUR7SGiM0T0XoPv6Qehfn1EROfK/VsQs60niOgIEY0T0ZdiXHdJeWy/oB37OSI6RkS3AwAzbwKwJE5/hPZFjLvQDG5m5ksAfArArwF4KHwClaj6+2PmY8x8ifpXPrxMO/ZfY/ThLIBvA9hY53vQ+/X5UL9mA9gH4G+Y+VjM5g4C+AMA/y1mHz4CcB+AvyCiueXDfw5gPzM/F7MPwjRAHt2EpsHMOSL6AYBfBUquDwB7AfwGSoZ/aRPv/WMAPyaizzSh+T8FMAfAjXEvZOZvAAARnavj2peIaBeA/0BEfw3gTpTHVhDCiHEXmgYRzUfJAD6vHf4tAJ8HcAQA1dFmP4B+2+vMnI3bZsz73wLg/wLwa8w8qh0fcVy2lZm3JtSFDQDeAPBZAH/MzB8k1K7QZohxF5rBIBGNATgDYBdKK13Fd5j5sPqFKJ59LxvJpAxlLIjoSgDfAfBlZv5pqF9NnVS0+5wmosMAPo3qSVMQqhCfu9AM+pg5y8xXMPMfMHNee+39SetVAxDRTADPAfg2M++YxH7cC2AhgL8H8GeT1Q9h6iPGXZhoGtKYJqKvGiJXKv+S6qSBb6C0Sfsnln5Z+0REX02iA0T0cQDbAfwuSq6hO4no15NoW2g/xC0jtBTM/KeodvMYKUfidAIISr/STADjzHwh7j2J6LcB/CaA5cw8ZulXVLinaqsTpUUVAQjK/brAzOPlOPs9zGzzVf0lgEFm3lNu698A+CYRfZKZz8d6U0LbIyt3oV35dQB5AC8CWFD++aU623oIpeiYnxhW5d6x92VeKvfl0wCeKP+sVt/zAfzIdBER9QH4p9BCO5n5WwCOA3g4Zh+EaQBJJSZhMiGiIwAuA/A9Zv7iJPbjFQCbmfmVSezDtwA8y8y767x+E4CvAJgBYBYzF5Psn9BaiHEXBEwN4y4ISSJuGUEo8R0A701yHwQhMWTlLgiC0IZMWrTMpZdeygsXLpys2wuCILQkBw4c+B/MPDfqvEkz7gsXLsT+/fsn6/aCIAgtCREd9TlPfO6CIAhtiBh3QRCENkSMuyAIQhsixl0QBKENEeMuCILQhohxFwRBaEPEuAuCILQhYtwFQRDakMgkJiL6Nkpa1h8yc00xXirVSfsLlGpljgL4EjPHquwuTF0Gh3LY8sJhnB4tVB0nKq0MimX1CgLQkQIK4xPeRUFoOWamCW9+LXZ99Vj4ZKh+B6UiAX9jef3zAK4q/1sJ4D+W/xemEINDOWzbfQS5kTzSRCgyI0XAuCYtlCLgn3xiDobfP4OzF9xqscyAfgZDDLsg+HKuyFj84ItNNfCRxp2Z/wsRLXSccguAv+GSAtk+IsoS0WVSlb25KGN9YiSPedkMNt5wNQDgq8+/jtGylSUC7lm5AADw5L5jlWuLZbG48ZBm3DgDe98+NQG9FwThXLG5oo1JaMv0oLro8fHysRrjTkT3AbgPABYsWJDAracX+upbJzeSx8bnDqIQ+mNhrjbqgiBMH5LYUDXVezROScz8BDOvYOYVc+dGipoJGoNDOTzw/KEaw64IG3ZBEKY3SRj34yjVflRcDuBEAu0KGtt2H0G+IFXTBKFdmJm21UFPhiSM+04A/5JKrAJwRvztyXPCsmIXBKH1mBLRMkT0NIDfAHApER0HsAlAAADM/FcoVZe/EcBbKIVC/qtmdbadMW2Q9i3vqbw+L5uxumQEYSqQCVKYGaQxMlpAtisAM3AmXzD+PQvNxyda5u6I1xnAv06sR9MMUxx5biSPDQPD2H/0FB7tW4rBoRzOnh+bxF4K04UgVcpdGGcgTYS7V87Ho31LAUQvQISpxaTVUF2xYgVPx0pM+hdkdibA2Qtjzs3QWZ1pXBgbRyEctygIdUKojnggAPesWlAx4sLUhogOMPOKqPMmrczedERFvKiN0ZF8IeIKRCYTCYIv95YNuKzApwdi3CcQiXiJJpw1K8SDAGxf14sHnn8d+XIyW4qAL6y8uDLvW94jxnwaIMZ9ApGIFzc9smncMPOyGTHeAgBRhZwwBodySFFz4lqvu3KOMZOs1VC6N0J9ZIJ0RYZCEMS4TwDK115s0ub1j987jU+3iYFv1hhNJBPxOWSCNO5dtQA92QwIpaeex25dKit2oYK4ZRLEtlHVbF97och472d5bF/Xi/UDw027z2TQ3RXgTL7QUn74VFl10xSVksTbSBOJIRcikZV7QujaL4ySi+GB5w9hcCjn9LV3Bcl8BCdG8uhb3lOXW2OqukJ6shl0dXa0lGEHLj59MC6u4nuyGWxf14v3tt6Enmym7rYJwNfvXCaGXYhEjHtCmFbn+UIR23YfwTzLl5kAdHakE7k/A7hu68tY9Ynu2Ncm4QoJmqCTcWIk3/Kb0IySYd/bv6ZikDfecDUyQX2fOwNi2AUvxLgnhC3KIzeSx8YbrrZKZ/rEusfpw963T+EXfq4z1mo8iZV7M1Qpp8KCPUg1PjbhCapveQ8eu3Up6hn2qfqUJUw9xLg3wOBQDtdtfRmL+ndZzyGUvswTaaj+8X9dwN0r5+Pxdb1eK8SpvIlp61k2EyCbCZp672wmwLY7ljXcjunJrW95D7rqWL1P5c9KmFqIca+TsI/dBpfPbcTPWg9P7juG+5856LWR22qrwe6uAMObrseZBJ96wmSCNDavXYK+5T3Oz85n7GzhifVkH0/035HQuohxr5M4ETAPfu+Qt/BXlLGIY4Z9V3lF5sgVPtHEhPj5MFIWWZvdpJW7Hlb40OAho98/SBMeX9eLcY8x3n/0VOUJ77qtL2NwKFdXv4IUSRy74I0Y9zqJk0l59kLR27c+zuxcnc3UomtmdSazGQsAFOE46iDC9nW9XitH0yQQpAnZTFCJyW4k8Uq5OZrxwKFvfj40eAhP7jtmKStW3RcXT+07ZoyiiuNWUi4i2UwVfJE49zqod+Xlw7xsBqsXz7XWPlV6IQBwYWwcHSnCWIxYQVus9ajWronCOGPb7iPYeMPVVeJnJro60zh7oYh0Od67xyJOpecFqNjwKPQszJFRf7dMNhOACBWt8TOjBYTfcZCuXhk//er7sBFnPMLvSkVRbV67BBufPehU/CQA7269yfHOBMGMrNxjonztzUAZrj1vnvQ6vzDOkStunZ5spqGNXRVLf9s17tWj8iUrd49NdbBveQ/29q/Bu1tvwtfvXGZ0DWWCFLq7AmMWZtSqubsrqGRxnskX0NXZge3rejH08PX49+t6q1bOszrTmNXZgQ0DwxXXSdRko8bjsVuXxvaFq2u33bHMea3Pk4EgmBA995hct/XlxMWtCKjKaF3Uv6sp0TV6IYZ6UCvwqJWq6bq9/Wsiz/OVolXn5UbyNU8imSCNx24tqR+Gi6AAF59c9KeJsBSzaufcWBGur0f4fZnasZEigPni5w7A2AfJRBXC+Oq5i3GPSVzDmwlSAMj6he8KUnjj332+6lgzJpBGUYZGGdU4JOlaMBlQZbCVG6grSEW6mdR196xagD1vnjS+J1c7QYqqfOD6hKO7o06dPV/lSjOhT0iisy5EIca9ScQ1vPeuWoAVV8zBhmeGravAx9f1Vn2J464AG0nPT1HJKLr8vtlMUAkLrOepIk2EceZIg2VauQPVBu/s+THj5nS9ui2u6wgX9w/CdHcFGHr4+kq/v/LMcNXnkCLg39/Ziw0Dw1798n26EQRf4y4+95hsvOHqmqzFIEVWjZg9b54sGTPHN3zzzsNVv1cyGCP6EqQJX1i5oMZXHSeIhBkVvy+h9KSh3l6aCPeuWoDhTdd7+7lNFJlrIkWA6iSw3i0vYeNzB6uiSjY+dxBfGRiuOmaLOqp3flMrfhPzshmMWmLRT48WKu/jq8+/XjPBjnPpuO94tbrMgjD1EONeD2FbQPZoE/WldX3JR/IFYwSOy2D1ZDPYdvsyPNq3tLKhpzYd71lVa/BtqOIOe/vXYPu6XgBUMVRFZuw4kKvqWxxdFFPmvooUCSeBjeQLNRIGhSLXRLQ0A1OcP6E0mbg0+NVEZfvsRwvj3uMlG6dC0ohxj8HgUA73P3PQaIRcqz8AVn0ZxbbdR5y/64SFqPSok739ayoG3ycOXA/9s4mfrR8YxsL+XVj+yEsAEBkdkqKSq8nmhjoxkp9SJQezmaDqPemuGlfETL5QxJYXDltfB+AVXSRFNoRmIMbdk6iCG6bVn/6l7Vveg3tWLbC2H34sdz2m64ZAd23o2Y99y3uw/c5ep1pjV5Cq8n9HuQZOjxaw8bmDAIC9/WuskxVz6f621ei8bCYxN0Q2EyDdoLjX2Qul7OG9/Wtih4uGo3F01OS66/UPrOdIkQ2hWYhx9yRqpam+pK7KOI/2LUV3lzkrMUVUZaBthnFWZ7oqQsOmIQ+UDOy225dZV/AzQpORj2ugUGRsGBh29lF/WrFNeEm4IQjAhbEiih47ymoITPNAociVJ6Ukfd/3rCxN5q4JQCJihGYhxt2DwaGcM0JGT9TR3SMAalbVm25eYvTBhjcdVy+ea1x1Xxgbrxhvl4a8wrWZG87w9PUPM4D15Y3OcA/DTyu2Cc90ryBFVQlL9zqedFQ/fEMeP33lHPRkM9bIotxIHtdtfTmx/IJZnWmsuGJO5Hn6ZCwISSLyAxFEZaTaSp6FwxmV0X7s1qWVeHFb2n2+UMSeN09iVmdHTXSISnvvW95jXWWGj8/LZoyTU3j1rN5DnFh2VW0onBikt2nLTlX3iorrtkkx+MIAfvj2qUjDnWRuwdkLxcrfTTYTWKN81GQsq3chacS4R+Byx5gyCPVkljDqi6xvhtq04F3uAT0Cx8dom7JKbZt4ql+m7E4berWhONgMv86jfUux4oo5uP+Zgw1pmU9GNoevhoyEQQrNQIx7BK4vnsmwRyUfxV1Vu17zNdpxVsmDQzlsfK42IigK0ziZkpL2Hz2Fp199v8ZQE5V81I/2La1pR/XTlRDU3RVgZLTgLUA2USgNGQDWCUrCIIVmIMY9Apvx7SnHh+v4hPeFv8g2BcjVi+dixRVzIo33zCBVeV1lkgIlX3/YkPs8+m954XBdJfPC78vklrr/2YPWzU/mi+4Xm4Hff/SU1UXT1dmBoYevd8oTNEKQJnSkKFJKIMzsTFD5LGZnApy9MFY1vhIGKTQLrw1VIvocER0horeIqN/w+gIi2kNEQ0T0OhHdmHxXJwdXxEeYqMdrQslo69gUIFVma3hD8rZrerBt9xEs7N+FDQPDVa6T82Pj2H/0lDOCxsXgUM7bFaOjj4cKzVw/MFwz0flEtbhkdk1GX6EmYNOYxUnq0tE3d7fdvgxzZs2I3cbZC2NViVpgWFUuBSFJIlfuRJQG8A0AnwVwHMBrRLSTmd/QTnsIwDPM/B+J6FcAvAhgYRP6O+HEcWnYVvkKBrDjQA4rrphTuT5qU1RfcYdXpSadcJPLw2fTzkfK+L2y+FdYJEu1v//oKew4kGsoOUnvu8mt02MZYyqfr8Yr/F5XXDHHqiRpo6uzA5tuXlLlFvLFpktTGOfKU4YgNBMft8y1AN5i5ncAgIi+C+AWALpxZwA/X/55NoATSXZysvF1afjI4eYLRdz/zEFsGBjGvGwGsy2RFPOymRrjNnphLNJw2vzNUU8VUS4lXftcjUXY7fKUrWpRDFSmry3a6LZreoz34fJ7sH1O6jOMI/ym7rn/6CnsefOk93tTapNPWVxIsoEqTAQ+xr0HgP6sfBzAytA5mwG8RER/BGAWgM+YGiKi+wDcBwALFrhjmFuR8CrfZgyUAc6N5BGkCUGqWpUxE6Sx8GOZqg1EX4OUtmwoRm3audoPUlTx5StMk0ES25h3r5xvbV+FiNru42M04xrWfKEYe9JilNxqvtFMgtAMfHzupvzG8N/63QC+w8yXA7gRwN8SUU3bzPwEM69g5hVz584Nv9wW6IlMPtV5CkXGJTM7avzqPnHZYTJBGnevnO+9R6DjKsxtqt2Z9OqTqCSPrPzqLneVLcvXx2jWY1htn4Pr8z0xko+1XyMISeOzcj8OYL72++Wodbt8GcDnAICZf0REMwFcCuDDJDrZqvhWLRoZLVT5YONkSpoSiJR/OU7RB1f4YJz9hXojU7KZoCqj09Z+tivAR+fGao7r9U9thTM23nB1XZWkTBBKWjQ2N888LZpKCnAIk4GPcX8NwFVEtAhADsBdAL4QOucYgH8B4DtE9MsAZgLwKwTaxoS/3LYYbD1cLmpTNpsJMGtGh9NYhO+r5AhcRsW2UWlbndpi7G+7pgd73jzp9V50To8WKhu6Sp7A1D4zjMlAszo7jCXzdBeYKUN4tlY42xSqaJusfHMNfPdrBCFpIo07M48R0R8C2A0gDeDbzHyYiB4BsJ+ZdwK4H8A3iWgDSt+FL/FklXhqEr71PcO4ol2Akj/77IWL1YWijKGqiBTVV9NmpOqPiThZrHo7tjFR4xUHParH1r4tYuVMefy2vHDYuio3ZQiHCX/OqxfPrYkAChtv1zgIwmQhZfY8sBVQridGWTceGc9an4p0ivB1g/87jM1VECURUO8EZmqnXtdHVL3V5Y+8ZIzF7wpS+NNbP4n1EeGK9dRzTWpcBCEJfMvsSYaqBy71xbhfcrUqfWjwUGxBrKImGubCtRk5EYaqkUIcszPmzVKFbS0yWhjHV59/PbL9ejZUxbUitCLT3rj7GDtf9cU4uDIxXeTKBtplbGy+7tmZwOquAWrj1qNcOTYaGZezF8ac7++MRV0RiJb/lUgVYToxrY27r2/aFa/smhxcrzUiblWP/5wAY7KUrv+e1NNJnI3UMKpwhu2ejbQ9UytibvpsAH/fubhqhKnOtPa5+/qmbT73267pMW62PXZrKVbbJmDVUy4z18jI+/rPfdLtVYS76Zywj9rHqDXiczfdM9x2lF/dhe1zC9IEhCJxbPsqDw0eqklsqncPRhDi4utzn9aVmHzdLbaKQnvePGlc7d7/zEGjcJaebZpqsO5nlOtDJVP51ASdl81ElswDosv66ffWxyubCayJR1H3DNOo8VT6O+HPplDkmhBL/alGCaIt7N+FJw0Zq+EKWIIw2Uxrt0yc9HDTppotLM/H5VIcZ8zqTONcYbwuF43vxmDUJKD7oaNCIeNsLNs2IRf173JONlF+8cGhnPVJxDeBKs54q01onycR0YwRphLTeuXeaHp4oxohoxeKePuxG/GeQ6ogmwma1kddctZV71SRxMayb39sbNt9xGrAP33lnCqBMxsuqYUw87IZ7+gf0YwRphLTcuWu+42zXQFmdKRwJl+IvTG2evHchpQQdWNgSyJSgl31bt7ZNlfvWVVb9Sgq5C8JISzb+/T1V7smkvd+lsesGbV1Z3Xi+txdiVNhwlr9gjCZTDvjHn7EPj1aQCZIY/u63lj+3MGhHHYcyMXWgFGEV9+mTMfVi+dW/R63j6rd/UdPVU1CJl15H+JmsQLmDVg9/T/uZGWTSAainyCi9HcA8yTqWzDcVnhFECaDaRctExUh4xvi5qsLrkfP+ESZ6JonNp2TnpgGsd6MVRNxQgCTzOxV2DJUgYs6OEm9V4Wvz72e7FdBiItkqFqwGWTTxpkrkcfHz9wTsSLUCd/btDrVo202Pnuwpl82wxvlK49jsONka0ZtwNYTKz7iKAPouzEcF18BOPG5C1OJaWXcXZEWto0zPcRNN0Qu9wBQ/STgM2HETdkvjDM27zxsFSXT7xOVhOU7ofnGuEcVK4k7kert2tpUW6TNEvKKEoCT7FdhqjEt3DJ6Qo8JArB9XW9V5aMwmSAduQGnn6tcDzaXSJoI48xVaof1fBJKr9xWgQkoFWT+6NyYMUHHNi6+iVy6i8XXfRHXfTI4lMPG5w5WuahM+Lit6nlaaDSbVRCSRNwyZXwMDgPOjTNVBFqnUGR0dwXo6uyoyQKdGaSw/+gp54QS1hnPdgVWX7IL1Y4rdvv0aAFBmpDNBDVRQbZIkLArxyfG3efpIyoCxeRC2vLC4UjDDlS7rUxPAb5PC669D10Xvl4fviBMBG0f5+5jcFRstC3u3WY4R0YL2Nu/Bo+v68VM7brTowU8ue+YtwZKvlAEM2ruHaQoVmani0KRMZIvINsVVK0yfTJTAb8Yd9c+RDh23ve+AOqa9EwZo1FuN6A2C3ckX6iZWCQbVWgF2t64+2x86kqEpkQeW4KRMkSNSNwqzuQLNffedscyDD18PR5f11tyAyXA6dECNj53sCIZ4JvI5WOMbef0ZDN4d+tNVUUyJqK+aPiz95mgfD9LyUYVpjpt75bxURHUlQht0SC2DbTBoVwslUKbb3xmkLLeW3d71KuIqBN+v6ptl//YJ8bddE6QJpw9P4ZF/buq2o6z8ZmN2Ly2EZ5sfJKwfI12uDSi+NyFqUbbb6gmFaMczmplLj2yxykInQlSmBmkrW6Gew1Zo6Z++Gwu+vBeEyoShcfJtpEbJxJncCiHjc8erGonSBHWXTsfe948aVS+NN3HZ1PYJ38hSBFAqPoMRBVSmCh8N1Tb3rgDpS/15p2HvUIXfdpqRM7WRZoIbz92Y+R5vVteqmslW8+9GqFRSeVwJI5rYrG9bqqJqhfwNrVjqnN7ycwOjIyWNqNHL4wZJ+hGEqUEwReJltFQkTA2gxh2L+ihk8qNosLrfH2yXTHrowL+aoWuakRJ36sRfIXGfCJxopKnTK+bomN2HMg5V9g+7qJF/bu83pcgTCbTwrgD7i/ebdeUjP+GgeGa0LdwyKKPYa/XR5wiePlxoxKofLBtEieJr9BYM8oYAvXXvp0IATVBaDZtHy2jsH3xursC7DiQc4a+KfKFopdcbN2GlxFZCGNwKIezF8ZqLiWUfcEaQYpgqgkSpGlCsimTjMSph2ZNGhMR6SMIjTJtjLvtC8lcWzvURZG5pp1GSRMhE6QQduLYYrVNkw8DWHft/MqKPE2EwjhjdiZARqsd2t0VYNvty7w2/gaHclj+yEtY2L8LC/t3oXfLSzWTjQsfjXigecayWZOG7/sShMlk2rhlbL5UX61uhe57V+3YNtjCpAjQ1QqCNFUMra8f17Xq/P7BD7B57ZIaSWO1eI+jJmmKyhnJF4yCZS58hMaapQezevFcPLnvmPG4IrzZ3t0VYNPNS7z6LMZcmMpMG+MOmL+QcWLH1Woy3I7NMOuY4tv1eHNfP64rbn8kX8ADz7+OfGgjNyot34TtCaEwzpE+63pohrG06aur46YQS5XkpfokCK3KtHHL2DC5BPS0f+Vjdz16Rz3muyQM1Erc1zURVe0nbNhrX/dLnXc9ITQ7KkQVo17UvwvXbX3ZyxVkuibK575t9xGj8JuadAWhlZlWK3cTSbgEbKXsdIVC2xOCmhh8+5FEtR8f4+x6QmhmVEhcKWDXNbaoIgZw5QMvOsNBJaxRaHWmvXEHGncJ+BrmqPR9n34kYXR8jPPGG642ZsIGqeZG2tQTvmi7ZmaQqpFqVkTF+UtYo9DqtL1xr0e/ux58kmyAxjcNfbRyXPhGoah+bXnhcGWzOJsJsHlt9GZjvbh0eupxE50eLSCbCWJnE09UqKggNJO2Nu5Rj/gTZfgVSWwamlxAQMnwForjOHvBbsji1l717W8S46g+KxuulbRtwiP45RwQAWoh7xstIwhTHa8NVSL6HBEdIaK3iKjfcs6dRPQGER0mov8n2W7Wh+sRP6zbbUsa0qlnoy9pTDHWj6/rxfCm6zEaYdh1yd2kqGccTbhkHaKeNkyb0XEE3ZhRGc+uzrZe7wjTiMi/ZCJKA/gGgM8COA7gNSLaycxvaOdcBeABANcx82ki+nizOhwH2yN+biQf27dbz0Zfs7CtqF0um6Q3CF2lC31S/MO4+meLUgorUM7oSFUqTcV1XanzJ/NzFYQk8VmmXAvgLWZ+BwCI6LsAbgHwhnbO7wL4BjOfBgBm/jDpjtaDTTs9TWQ1JrmRvFHfxTYZbN55uOmuHV9lQ1ct1no3CG31Q6N0dnLlIti+Y2EzyD3ZjNdke3q0gCBF6OxINax5X8/kJAhTDR/j3gPgfe334wBWhs75JQAgor0A0gA2M/P/F26IiO4DcB8ALFiwoJ7+xsIWEaFUHm1+WtMqzjYZjOQLFb+uOn//0VNVxtdmjH310cNPDHrWZXiluf/oKTy171iNtnk9G4S2p5UZHSmvTco4K2CfYiA6psm2MM7VKcAhMkEat13TU/ksUo6i4hIKKbQ6kXruRHQHgBuY+XfKv/8WgGuZ+Y+0c74PoADgTgCXA/ivAH6VmUds7U6EnrtLT9wVm246H7C7eeKijMyOAzmnhrnrPZj6qLTEk9oo9r23i+6uAEMPX+91bpx+L+rf5e1TB8ybya420kS4e+V8p/a7IEwGSeq5HwcwX/v9cgAnDOfsY+YCgHeJ6AiAqwC85tnfhjEZBmPZtxRh9MIYNgwMe/tpT4zksX1db2JFOvKFIp5+9f2aVaPJHeBrXPWVZlSUi68RTWL1enq04O2eiRNNFNevbiqi4WqjyFzzhBRXV0cQJhOfaJnXAFxFRIuIqBPAXQB2hs4ZBLAaAIjoUpTcNO8k2VEXpoiN9QPD2PLCYdx2TU8lEiKbCQAqGRxG6f/zY+PYvq4Xe/vXOAthm6JUuoL61Rsw7JAVAAAgAElEQVR83QE+EsOqjz7EiW5xySTHUcZsRiq/KULGhm0M47QBlNw+m3ce9j5fECaTSOvEzGMA/hDAbgD/AOAZZj5MRI8Q0dryabsB/IyI3gCwB8BGZv5ZszodxhZGd3q0gB0Hcth4w9V4d+tNmDWjoybjUtdaidJ36Vveg739a/Du1puw8YarjbokvtgMTtig+lZMOnt+zCv80BUlFMY2HptuXlIz0blohv86PNlmM4FRux4A7l4533hcb8OXRoukCMJE4RXUy8wvAngxdOxh7WcG8JXyvwnHZTx0V0eUkFScLFKbaqJPfLXL5x7eQLRu/GqJN4BShIzewIxTwCJqPHz3BpqVyh924wwO5fDg9w5VErkIwD0RRcdVG0nsLwjCVKItMjai/K/KcPnI6qovu/JLbxgYxrbdR2qMvO1+jFL6um74U1QujTdaqDKQK66YEzmR2DTJu4J0TTaqTwhf3BJxvv5723jE1aJpZDO4kQxgW+ZvGKUWKghTnbYw7lFfTGW4fMPtfGQLXJE14WIeNgPlY4x2vf6B8bhNZiDKBWKLElLx/XGMaXicwsTVopnMRLHwU8rsTID/dX4MRc31FqQJm25e0tR+CEJStIVxV19MvaKOIuwzB1CV1ciMmtV5VPbqtt1HjIadAGMxDx9syUI+FZ50olwg+hjkRvJVk1RcY2rb69DDMuNQb0FrH3yeCExunonUHhKEJGkL4w7UulNsX0j9PNsqMcovbXudUd8K05UsZCObCXB+bNw76UfH5WeOY0yTLkBdb3tRn3mcJwIx6EK70DbGXeG7at7ywmHrKjHKL+1Kla8H24rV5f/dvHZJ5dp6DVGjxjmu/74Z7fkYbpd0RL2TgCBMddqqzJ6vauPgUM7q7jgxko8MifQtiedL3JVuNhNUJjEVmlmP4qPNaPoa56THIW57g0M53P/MwcjQTpd0hP43EidMVBCmOm2zco+z6nJ9WVXCkjrPFQKY1ON7nGzLTJDG5rVLMDiUa7iQRlw9lzBKy0Zl26aJcNs18fYbwm4QXfvFNa7q8/ZJBnONr+6CStrNJAiTSdsY9zibcS5Dqm++RlVWSuJRfXAoh9ELY97nP3ZrKWY7XAJvJF+InR7f6CQ1OJTDjgO5ioEtMuOpfcfw5L5jXoVBTBPyjgM5o8RveBIYvTDmdFtlu4KKuufsjD180WcSkJJ7QivSNsbdd9XlCmNU7o6JIiqUMIySv71u68vGBKrCOMeOLGlkkjJNqHEib3wnZNMk4CJIEz46N1Z5qnFlleqGu9EnGUGYSrSNcfddddnCGIGLm5RxqTfCwlV9KJwIpRuZeuqJxiEpYbGoyBuXpv7C/l2VkneucQqTJsKszg6jQQ9P6qYC5UBy7jZBmEzaxrj7rrqS9J+G/d5AvAgLV19mdXZg1owOo5Fx+ZAbdSHE2bvw2Stwvceo60+PFmrcTy6UZPKGgWHj64yLBVxsbqOk3G2CMNm0TbSMSbXR5Lt1Gb84URHKCJqibnwjLFx9OZMvWCNhNt5wNYJ0rUpW3FR/E40Ki4VJEVmjlnyuLxTZKrKWzQTGz9vlYy8yVyZ9MeJCO9OSK3eb28Bn1bXxhqux3rKyi7OqN8XJx22r3rJ46j3qTw2Eiz53/RwgntuoXmExly66beXvc71qIxOka57KTNFBg0M5nI3YoJYyesJ0oOVW7iY98o3PHUTvlpci49uBkkHJWlZ2cTTRo2QBbG3psfjbdh/BL358lvG81YvnOtvvW96DoYevx+PrepEJ0jUbmWoM4ui3u/rtEhZzaeED7icZn+vVqjzqqUzFvfu4cSS8UWh3Wm7lbqydWeSaOqaA3ee9ee2ShqIiolwutrZM/mxbKY49b56sXONadfvo4PhGpJj0ZlzvRyfKWPoImm189mCNRn6QJi+9nqi49zAS3ii0Oy23cvdZcUX5vH398/X0IZsJrG25QgdN9/BZdderg6Mf1++j+qQmHd+xiTKWPoJm2+5YVvVU1d0VYNvtyxqOPAqjBN4EoZ1puZW7bzZn1CTQSFSErQ/ZTIDhTfZi0HFcAfOyGa9Vd706OLqxtU06cdQdXbLLcZ6KZs3owJl8warYCZifZuKMLQMVrX4JdxTalZZbufvWvWzmY7dNAyUqTt7Wp7BrRhlDn1X36sVzrde7+qob2yTS7vWnIeBiGUHflX/4KeX0aAEj+ULVE8tDg4ew/JGXsH5guOZpxhUhE0bp1/vsQQhCq9JyK3eTJvtH58aqfLWZII3Vi+dW0s+TXJ2pVWO+UIyMmQ5ji8W36anYokjUJKHS/8OunU8tmB1LByeptPuks1118oUintp3zOjGyheKmBmkaiJqghQBhJoN1nAbEj0jtCMtZ9yB6KIKqxfPrapPmpR0a3hDNG7MdDj0L02EfKGIPW+eNLYRlZhlM4g/fPsUBodyVQbe1b+pkHbv85Tg2io9PVpANhNgZpCqKmcIXJzYujprSxPGub8gtBItadzDhI3XdVtfbkpFnyQqBanzfLJAo1bdrqIh9fRpMtPu4yhj2hjJF5AJ0ti+rtc4jlc+8KLtUomeEdqOtjDuYZol3ZpUu3EmCdeqe3YmsIpixe3TZKfd+xaojiJfKGL9wDDWDwwjTYS7V87Ho30lJU1XmKREzwjtRlsa92ZJt9rajbOZB9hVDXPl8EefFfRDg4e81Q4bZSJKz6n2THVwCcCnr5yD/3bsTCzjX2TGk/uOAQAe7Vta2SMJQ2jMXScIU5GWi5bxISqCpF423nB1aZMuxP88V4gVbWFoAkDJyLji2lV268L+XRWjZWsnN5KPzNb1IW6GayP0Le/B8KZS1q2eg7B9XS+e+t1/UpObYMs0DvP0q+8DAO5eOd/4+j2rFiT0DgRh6tB2K3dTBAkBsSsEmehb3oOvPv96TRblOMNYj9O22h23eAcYcIp2+bot4miqR5HEPoONuBpBpo10nzFRq3XlntErR+luG0FoJ9rOuNsScp5+9X08te9Yw26F0cK48bjuSki60PKJkXysDEwdX0NsM7Q2F1Kj+xdJjFF4I9jmUddVJR/tWyrGXJgWtJ1xtxkdtXqbiIr2UavdTJBC3jBJ2CpEzctmGjKmUdfaDO3+o6es19Tr09c1bMLU80Sgr+YfGjxkdFfZ3DGC0M60nc/dx+g0UtG+u8vs59WPu6JqBodyGDP4ZVIo+X5t2aSNbJBGXWubjJ5y+PXD+xe62qXN1x/WsDHRyCT2aN9S3LtqQWWlnibCvasWyEpdmJa09Mrd5ErwDakz1Vb1iQjZdPOSmupAQZqw6eaL0gOuaJ1tu48YJWlndwV4tG8pVlwxx9oP1/vKZgL85rLLqpK3gMYUHV1JQ1E1Tk1PRz6upbiRR2HE7SIIJbyMOxF9DsBfAEgD+BYzb7WcdzuAZwH8GjPvT6yXBmwG5bFbl+KxW5dWDGTKEv6mr2ZNbW0YGMb+o6dqDIVPwo9pggnShLPnx6zhiyNlfXjXZmLUfQE4JwcbjSYQ+W66+qzKR/IFPDR4CI/2LZ2QEExBaFeII/SviSgN4CcAPgvgOIDXANzNzG+Ezvs5ALsAdAL4wyjjvmLFCt6/v377f93Wl40GKaxkaIqoCOu52CYAAHU/1uuGyaR/E9XvicQ36kTR3RVg6OGL6peL+ndZV/m67o7tMwtDKLmoTE8hcaSZBaEdIaIDzLwi6jwfn/u1AN5i5neY+QKA7wK4xXDevwPw5wDOxeppnfhmi5q022+7pgc7DuQqsduuzMWn9h2rK6ZbVRh6d+tN6OrscBr2idZxCRNWdHQRdkEBbp++Hhfvq+ipoptMTwP3P3NQFBwFwQMf494D4H3t9+PlYxWIaDmA+cz8fVdDRHQfEe0nov0nT56M3VmdOOXgdEO7t38N9rx50nuVqnRaGiHKHTGjY/L3tdUYuejJZozFM6KMtu6i0SdaW+FrwD7hqpqsYuAFwY2PVTF9AyvfPCJKAdgO4P6ohpj5CWZewcwr5s511wiNwken3EbciIxGY7qjolVG8oUpY7BsBjdNhL39a6z7AVErfzWG+kT79TuXWcsMugx/I9FOgjBd8DHuxwHogcKXAzih/f5zAH4VwCtE9B6AVQB2ElGkT6gRGimVFzessFGdFh93hDJYPiGFzcQWE373yvnOvkUVurY9Ud2zaoFRKuLulfOdYyYSvYLgxida5jUAVxHRIgA5AHcB+IJ6kZnPALhU/U5ErwD442ZHywD1Kxna9Ms/tWA2fvj2Ka/i0HEiOXwzKZV/Omkd+jjYUvRXXDHHq29xteFd4Z8rrpiD+585GBnt5EIiboTpSmS0DAAQ0Y0AHkcpFPLbzPw1InoEwH5m3hk69xV4GPdGo2Vs+H6Zbef5XG+LwLE9OYTbtIVE2lQLJzOSRhEVnRSODmIGzuQLDRvUuGOd1LWCMFXxjZbxMu7NoBnGfaK+zK6Qvp7QRLHlhcM4PVptyIM0AYya0oC2TV4C8O7WmxLrfz3Ywh0JwPZ1vd7j7jt5hitrmcoQRuEbLisIrcS0NO7N+jKHjU1UrLaKow/Haet0dwXo6uyolNtTLhDTyl2dazJuzXY7uLRgAFR87I3kHOiTQL0TtGkcNgwMWyekyZ4sBaFefI17S8sPhKm3UpLLQJqyV20CX4p8oVjxWdsYGS1g081LamqyhgnShI/OjVVW/7qvG/Ar11cvUclNype+YWDY+Hp43H0yWaPOMX1WgHkcsl1BzVMTICX1hOlBWxn3eiowRemi2CSEowy8y7CrPtm0VlIEMMPqn9dDAZultQ64tWB095NtZR8ed5/JN0p0zfRZzehIGcdhRkeqxt012QljgjBRTH72TILUE/vuWikCblEtV1y3I0y70idb2+Nc8mPv7V+DM44aqVHGstGwSlv7BFTFvK9ebM5ZCB/3STxznWP7rGx6PWfyhbrDZQWh1Wkr415P7HuUgbQZG0JpMrFJAJvK8QFAV5Cq9ClruRa4mBXrMnau15Ioj+ebBbznTXO2cfi4z+TrOidubPvsTFCTnSyGXZgutJVxB2qlBnwUEV3HN95wtTVFd9vuI0afLgBcMMj6AkD3rBkV3/GI5Vrg4uTiMnau16KeSHzwXZHH1fnRJ8QZHSnsP3qq8oSxbfcR3HZNj3GCtn1W1pq0jqcnQWh32srnXg9RSTd9y3uw3rFhaItwsaH7jl1XKUPmI/WrfN5poooBT6I8nu+K3BpBREDvlpeq4t0B4JxWhWokX6iqnpQbyePJfcfQ3RVg+7reyAQpgr0mrWvyFIR2Z9obdx/j2ePYqI2rg+7aSFUol4/ex6js1/ufPYji+MVSgq77++K7IrcVSGG+WFvWtflp4vRooSbyR/+sfKKWJCpGmM60nVumHqJcOS73h49Mbvga1+pZaZnH8Q0/+L1DFcPuc39ffH3uyt1ic48oXJuftvM37zxccy+lYeN6xxIVI0x3xLh7EN6o7e4KMKMjhQ0Dwzh7fqyUcWohTeTtO04TYfu63tjFQc5esK+EG4kUMU1qhNIq3CQc5jG/xGYkXzBuArsmyGwmkKgYYdoz7d0yvhmeyjUSjrUeyRcQpAhdQQqjmi8ZsGdW2vz8zTBIcTNzw+OhKlaF3SD1Jkx1dwU4Vxj31tMHgM07D9fcw+USOz82bjwuCNOJab1yrydc0OQvL4wzumfNwOPreiNXysp45gvFimZ5o/HXtucGddw33t00HjsO5Crup/DCPF8oYv3AcKXNbERx60yQxqabl9SEq967aoHzWtPq3SWjLHrvgtBm2jJxqUeLxiWgFaVX0ixhs4cGD1VFnCjuXbUAQKlUoN5ntQLvCT2puMbDJVWs3sdt1/Rg4MfvG0sKhu9lYvkjL1lDS02fyeBQzhrJBADviX6M0IZMS20ZGzbXSxwtmocGD+GpV49ZDZwrIUnho60Shem9uDTYTeJZNteKazyiIoPyhSL2vHkS2+5YFlv1UZ2z6eYlzrBTUxs2XJWcBGE60PbG3aUd46tFY1sZ63x0bgyDQ7mGsmGjcL2XR/uW4tG+pRWj99S+Y3j61fedq22genKxjUeKyCv08MRIPrKAiuk9rB8Yxuadh7F57RJ0e4h9RQmaAdHaPoLQ7rS9z921WvbVonn61fcRRWGcI/28mcA83LbjYaKyTsM+c18D58qGhdaOEkyz4RNXbovxV3Vkb/rkZZGfSVSeAODW/RGE6UDbG3fXatlXiyaukTQxOJSriaZRjBbGvTRfolb+PkbPhJ4Nq4+HybXBKEW8NKM4uXLtRH0mUU86EuMuCNPALRPlevGpw+orMeBauUat6n387lHvpZ6i0WFDqI/Hov5dxmtOjxZw76oFVT7+267xq2cb5bv3ce242ojTF0FoZ9p65T44lMPZ82M1x+Ou7O5eOT/ynLBkQJgow5sra864iHIj+abbq/W4vio2hUu62ht47WIxkiIzdhzIYXAoFxl26Qph9H0Prjb0vgjCdKZtQyFtm27dXQE23bwk9squEi1jGC4lGaBvaIYjQVx1VxX1lpOLKlGnEpFsESyu68JhlC5MCUqm92SrLavOBdxaPwBwzzd/hL1vn7L2ReqkCu3KtA+FtPmfuzo7agyNT4bqo31LseKKOUZVQt2w26JZXDU9FT5hkT4iYnFrqto2ave8edLbsAMwRrnY3lNXZwdOjxYqLi8VBw9Elw4cHMrhhw7DDtTnohKEdqLtjHtUQWeli+IyJPuPnjKudG0l93a9/gEe7VvqjGbZ27/GmXCjaNQo+ewh+N7zxEjeqohZT/umFXuRueJaUk84PnVWoyYdUYQUpjsta9x9CiXbiKq9GdYXVytHmxE8PVpKj4+KZvExlJNhlFwbtTY53zCZII0ZHSmj6qNeGcrUjm68bWOoT8oSLSMI0bTkhqpNE2bzzsPeoYBx5GeV8XEZ3vUDw0hZsiL1qk6uzUQAOHt+bMI3A10btSo80pXxqYqEAEA6pPsbpMlaGUonqqwhcPFzdmUDd3eJIqQgAC1q3OMWSk6CEyP5yNWgKVwySBPOnh8zlpDLZgLM6qw2qiqZZyINfFS8f9/yHnz9zmU10sbpFCFIXQwTHckXanXly79GrbZ9J8B8oQhmGM+57so5GHr4ejHsgoAWjZaxiXfFxZbqbkJFX/zyv/0B8pZkJEWaCOPMyHYF+OjcWJWQVjh6pB7xsolmcCiHB793yKkb70Jli/r47ru7Atz0ycsqMsMm1CZ2OJKnWbLJgjCV8I2WacmVu+3R3ZQ5aUPJz0bJ1KpzVy+eW97si9YKLzJjXjaD06OFGoXEsBxto3ozSTE4lEPvlpewsH8XFvbvwvJHXqrErW987mDdhh24+NTj89mcHi1g4LX3nVWu5mUzxkgeU+UmQZiutKRxt/mIlVa4i7DbYfPaJTVtBSlCd1dQOfe2a3qw40DOO2pEVSuyoRtu31J2zWRwKIeNzx6scmudHi1g43MHseWFwygUG3tOmpfNePnuFYUiR2r/2CY/W+UmQZhutGS0TFQ8ty0U0uTq8IkNN4Xn2YhSTgSqDbetKpPu349KXIob1x5m2+4jRg32QpEj3VZR71d/L33Le7DBIxwUuChDoPpnCku1TaBxJJQFoV1pSeMOuOO5Vy+ea/TH2jZEo2LDo1wkevELnyzUsJYLcNGAzc4EIAI2DAxj2+4jWL14LnYcyBmTeoDohB8f6nUBKd+3nhOwevFcZzZslLaMfh5g/2wWfszejiQwCYKncSeizwH4CwBpAN9i5q2h178C4HcAjAE4CeC3mflown314qHBQ8bKQ42ISbkMkm81I9O5Clt91txI3pj+r/z2oxfGGi7+EfX+iGCUXAAuZubGYfXiuZHa+Cp80kZUhqokMAmCh3EnojSAbwD4LIDjAF4jop3M/IZ22hCAFcw8SkS/D+DPAaxrRoddDA7ljMaQAex582SsdnRXQHj1DDSn+LUtA9aEr0/f9p70SWbjDVdj47MHja4Zk2HPZgJsXuuvz6PfOwof7Z+oDFVJYBIEv5X7tQDeYuZ3AICIvgvgFgAV487Me7Tz9wG4N8lO+uL60jdS7WjHgVyk+JbOzOBi5mvYELqMbFLuhPDKNar6kbr/5p2HK5uqKQIMth7dXQG6OjuwfmAY9z9zsEoXxjQePlWTAL8atArXOHV3BeJvFwT4GfceAHopouMAVjrO/zKAH5heIKL7ANwHAAsWLPDsoj+uL73vo7otQer7Bz/ArBnu4TIZsrMXxrB552FsGBjG7EyAsxfGKtEnYR+5rz86ivDK1VX9aMPAMPYfPYVH+6qfLFxa7mqTVSUvuXz9vgVEsl0Brtv6stfkaRsnArDp5iWR9xKE6YBPKKQpds24QCaiewGsALDN9DozP8HMK5h5xdy5c/176UlU6nrvlpciw+RcIXZhuYNwWyZDVigyRvIFcLmNcFihHvduC/3r8izDB5SeFMJG0TXpMYCn9h2reS9x/db5QhH3P3OwRsfd92nko3NjkeOrtOJVPVcdtbkrq3ZBKOFjNY4D0KtVXA7gRPgkIvoMgAcBrGXm88l0Lx5RiTIj+QI2PnvQaeB9jVo4GQmo362irrPJAPgkTgElA7d5be3KNeo9MUouGb3IxurFc70TwhRF5hrj7DOeRIhM9tL1hFSfFT3ZDLav6429uSsI7YyPcX8NwFVEtIiIOgHcBWCnfgIRLQfw1ygZ9g+T76Yffct7cNs1Pc5EmahC1qsX+z9RhF0D9UZp6Nf1Le/B3v41eHfrTdjbv6bironCtXL1yQ4NP5mofQY10cTFVYRcJ0iTNRpHnyxt7h1VAUtW7IJQTaRxZ+YxAH8IYDeAfwDwDDMfJqJHiGht+bRtAC4B8CwRDRPRTktzTWVwKIcdB3KR9U51oxEuC7fr9Q+87xeeRHxT7HV85GmjXtcLhphQTwTdDjXFMKpYh5pobFIALnIjeWzbfQSfWjDbPkEwrP3SJzXbUxEjuj6tIExHvJy5zPwiM/8SM1/JzF8rH3uYmXeWf/4MM/8CM/eW/611t9gcfDfvlNEwSQf7CokBtSqQ4SeHFNUOcFjawFfoypW17xPq2be8B0MPX497V/lvZOtPJvVMXKqNH759yhrFVBhno8qjknDwqecqSUuCUEvLZqia8PmSB6mLCTK+k4ENJTqmV3/S0/HHueR2+PnODpzJF+qSB1C6L1Hinb4GbsUVczDw2vteejFUvr+eJarep14ez5QHoBN1pzP5Arav6zWOofLfu+q5StKSINTSVsY9KpQwHHPe6IqPqDb8MWx8CkXGrBkd2Lx2CbbtPlKRFfA18pt3HjYmF4WJE+rpKwSmuzz02PzH1/XW9H3FFXOcei8ulLCYrZC4chHZZH4laUkQamlp4+6TSRqkCJfM7MDIaKEmTt02GWQzAWbN6Ki0azNYp0cLlUQeF2r16asBo78vHzMcx8DFndBUwpP+u6nvLuPsItx3lwSyKlLeqFCaIEwHWrJYB3DRXaGvaoMUYd218yuZpOGkIaBaCsCUdGSSClj+yEuxfPFhlAsjjMr2rKcObLhtV5aoTlzja8NWTMQnI1Vlv5r63ArFSwRhMmnrYh2A2V1RGGd8/+AHlQgPIhiThtYPDOO6rS8DgLO8HFAyVh+dG6u7n5kgbV3Znx6tTYzyrQPbmaaqtm2JP2Hq3RgNY5sg9Fh9G5fNzuA9LdQzqn/iehGE+LSkW2ZwKGetlzqSL+DKB17Eqk90O1fbyhg+dutS54rQpnXuQpcAVsWhfVbL+ULRe8VeKDIuFOMrQoYlhut9bnPlEigXja0cYtj1EnavxdHxEQTBTMsZd/XY76LIjL0OSViFjzH09VGruqlhTXOTJnsSNCKQpke/1OtyMj2NhI307ExgnIT1zV+TqNmT+46huyvAdsPGrSAIfrScW6bR8MUwUStqnyiUTJDG1+9chne33oSNN1xdKclny/bsyWastVvj1IGtt7+KRl1OuoaMKWfg7IUxBKnqFX44ft32eZ4eLXi5mQRBMNNyG6q2R/1G6O4KMDJqjkP32SC8V8sOtW0IdncFGHr4eme7ajN3/9FTkQUtuoIUGFSXbrwiqc3VbLl6lOkJQG0ah+PXVX+jJmrZSBWEatp2Q3W2ZcXbCKdHC5XV5vqB4Sr1SLVB6ELPDrW5RU6PVhdutomEAcCOA+7VapAm/Omtn4zcDI4iqczOkXzB6toZGS1gb/8a9GQzxopSUQWzJftUEOqj5XzuEbYgEUbyBawfGMaWFw5XqgKtdxR2zo3kK5mcrrh43b9vK9oRVYw7HD7YiE862xU0FOLpg3IT2Yx0kdm5gpfsU0Goj5Yz7iNNNkY6yu8LlNwLLkO48bmDVZWMTCgDZ9pEVPexGcGoSkWDQ7mq++vl6kwTCYCG/O0+KMVGwJ09PKMjBQJjNCRtLCGQglA/Ledzr9dPrBJnwn5fX4IU4CmrbkVlvroKaAPmTV7le7YZalMN1CBNWPdr8431X2cGqaav2lW/T4zkke0K8NG5MWdYaSZIYWaQtu5/CILg73NvOeP+0OChyM1GE0pXRl/ddgUpFMbZW2ulUYI0Oe9FALav67VutAK12auZII0ZHSnrE4MtO3YiCE+kQZowq7PD+XQTd1NYEKYbbbuhGiVta0NVYdINC6O0so2jc94IUZOIEuoKh00qY2er7+oylo0adhXJaNrrUIeymQBBujbk0Sai5to2MVW4EgQhPi3nc28kesJUym3Pmycx9PD1dT8RJI2KizetXut5742u3Me5OtTRpmUTdhfZXE+5kTyyluQmhUTICELjtNzKPenoCWWE6n0iaAb5QhGbdx6uOV7Pe7975fyGtWT0UMciM4IUYfTCGDaUNXpUpJBeHtClLeMy7IBEyAhCErScz31wKIcNA8OJJzJNRbKZAL+57DLsefNkKQmIEFm0I8x7W2/CPd/8kZccQ72ojdvvH/ygaj8jHP3ig/jcBcFN2+MN6GcAAAlTSURBVG6oAsDC/l0J96Z9qdfITga+ssWCMJ3xNe4t53MHSkYgibT56UArGXaRGRCE5Gg5nzuQnCa5MDWQZCVBSJ6WXLmrx/YtLxyekEQcoXnombSCICRHSxp3AJW4bzHurUN3VwBm4ExeMlAFodm0rHEHorXYwygJAhWr3d0V4KNzhYZlBYRoxKcuCBNLyxr3hwbd1ZhMMJdCA/U2npoCiUvtjvjUBWHiackN1cGhXF3ZpCmiqspBT+07Ni3i5SeaTJBCd1dQt868IAiN05Jx7r/yb3/QMiF+041wxSlBEJKlbYXDBodyYtinMJtuXjLZXRAEAS3ocxfFwKkJAbhn1QJxvwjCFMFr5U5EnyOiI0T0FhH1G16fQUQD5ddfJaKFSXdUIZmpU4MUUOVX376ut1IkXBCEySdy5U5EaQDfAPBZAMcBvEZEO5n5De20LwM4zcy/SER3AfgzAOua0eF6KykJ9aM0X0w1XwVBmJr4uGWuBfAWM78DAET0XQC3ANCN+y0ANpd/fg7AXxIRcRN2a8WwTyxBiiqGXIy5ILQOPm6ZHgDva78fLx8znsPMYwDOAPhYuCEiuo+I9hPR/pMnp45+unCRWZ0XNXuymQDb7lgmRl0QWhCflbupKlp4Ae1zDpj5CQBPAKVQSI9719DdFYjkQILYKisJgtDa+Bj34wDma79fDuCE5ZzjRNQBYDaAplSH2HTzkmlTrMMHAvCLH5+Ftz48WxmTzjQhSKdw9kLReI0qFi6GXBDaFx/j/hqAq4hoEYAcgLsAfCF0zk4AXwTwIwC3A3i5Gf524KIi5J/seB3nx9on3l2FEq64Yg427zwcWYoOkOIWgiDY8cpQJaIbATwOIA3g28z8NSJ6BMB+Zt5JRDMB/C2A5Sit2O9SG7A2GslQFQRBmK4kWomJmV8E8GLo2MPaz+cA3BG3k4IgCEJzaDn5AUEQBCEaMe6CIAhtiBh3QRCENkSMuyAIQhsixl0QBKENEeMuCILQhohxFwRBaEMmrcweEZ0EcLTBZi4F8D8S6E6STMU+AdKvuEzFfk3FPgHSr7g02q8rmHlu1EmTZtyTgIj2+2RqTSRTsU+A9CsuU7FfU7FPgPQrLhPVL3HLCIIgtCFi3AVBENqQVjfuT0x2BwxMxT4B0q+4TMV+TcU+AdKvuExIv1ra5y4IgiCYafWVuyAIgmBAjLsgCEIbMqWNOxHdQUSHiWiciKyhQ0T0OSI6QkRvEVG/dnwREb1KRD8logEi6kyoX3OI6O/K7f4dEXUbzllNRMPav3NE1Fd+7TtE9K72Wu9E9at8XlG7907t+GSOVy8R/aj8eb9OROu01xIbL9vfivb6jPJ7f6s8Fgu11x4oHz9CRDfU24c6+/UVInqjPDb/mYiu0F4zfp4T1K8vEdFJ7f6/o732xfJn/lMi+uIE9mm71p+fENGI9lozx+rbRPQhEf13y+tERP+h3O/XiehT2mvJjxUzT9l/AH4ZwNUAXgGwwnJOGsDbAD4BoBPAQQC/Un7tGZSqQgHAXwH4/YT69ecA+ss/9wP4s4jz56BUoaqr/Pt3ANzehPHy6heAjyzHJ228APwSgKvKP88D8AGAbJLj5fpb0c75AwB/Vf75LgAD5Z9/pXz+DACLyu2kExofn36t1v5+fl/1y/V5TlC/vgTgLw3XzgHwTvn/7vLP3RPRp9D5f4RS9bimjlW57V8H8CkA/93y+o0AfoBSVc1VAF5t5lhN6ZU7M/8DMx+JOO1aAG8x8zvMfAHAdwHcQkQEYA2A58rn/d8A+hLq2i3l9nzbvR3AD5h5NKH724jbrwqTPV7M/BNm/mn55xMAPgQQmYUXE+PfiqOvzwH4F+WxuQXAd5n5PDO/C+CtcnsT0i9m3qP9/exDqVB9s/EZLxs3APg7Zj7FzKcB/B2Az01Cn+4G8HQC942Emf8LSos4G7cA+BsusQ9AloguQ5PGakobd096ALyv/X68fOxjAEaYeSx0PAl+gZk/AIDy/x+POP8u1P6Bfa38aLadiGZMcL9mEtF+ItqnXEWYQuNFRNeitCp7WzucxHjZ/laM55TH4gxKY+Nzbb3EbfvLKK0AFabPcyL7dVv5s3mOiObHvLZZfULZdbUIwMva4WaNlQ+2vjdlrLxqqDYTIvp7AP+H4aUHmfn/9WnCcIwdxxvul28b5XYuA7AUwG7t8AMA/n+UDNgTAP4EwCMT2K8FzHyCiD4B4GUiOgTgfxrOm6zx+lsAX2Tm8fLhuscr3LzhWPg9NuXvKQLvtonoXgArAPxz7XDN58nMb5uub0K/XgDwNDOfJ6LfQ+mpZ43ntc3qk+IuAM8xc1E71qyx8mFC/7Ym3bgz82cabOI4gPna75cDOIGSME+WiDrKKzB1vOF+EdE/EtFlzPxB2Rh96GjqTgDfY+aC1vYH5R/PE9F/AvDHE9mvstsDzPwOEb0CYDmAHZjk8SKinwewC8BD5cdW1Xbd4xXC9rdiOuc4EXUAmI3So7bPtfXi1TYRfQalyfKfM/N5ddzyeSZhsCL7xcw/0379JoA/0679jdC1r0xEnzTuAvCv9QNNHCsfbH1vyli1g1vmNQBXUSnSoxOlD3Qnl3Yq9qDk7waALwLweRLwYWe5PZ92a3x+ZQOn/Nx9AIy7683oFxF1K7cGEV0K4DoAb0z2eJU/u++h5JN8NvRaUuNl/Ftx9PV2AC+Xx2YngLuoFE2zCMBVAH5cZz9i94uIlgP4awBrmflD7bjx85zAfl2m/boWwD+Uf94N4Ppy/7oBXI/qp9em9ancr6tR2pz8kXasmWPlw04A/7IcNbMKwJnywqU5Y9WsneMk/gH4P1Ga1c4D+EcAu8vH5wF4UTvvRgA/QWkGflA7/gmUvoBvAXgWwIyE+vUxAP8ZwE/L/88pH18B4FvaeQsB5ACkQte/DOAQSkbqSQCXTFS/AHy6fO+D5f+/PBXGC8C9AAoAhrV/vUmPl+lvBSUXz9ryzzPL7/2t8lh8Qrv2wfJ1RwB8PuG/9ah+/X35O6DGZmfU5zlB/XoMwOHy/fcAWKxd+9vlcXwLwL+aqD6Vf98MYGvoumaP1dMoRXkVULJbXwbwewB+r/w6AfhGud+HoEUANmOsRH5AEAShDWkHt4wgCIIQQoy7IAhCGyLGXRAEoQ0R4y4IgtCGiHEXBEFoQ8S4C4IgtCFi3AVBENqQ/w0p4+K8IOf+kQAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 720x144 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "def dgp_binary(n, d, true_fn):\n",
    "    X = np.random.uniform(-1, 1, size=(n, d))\n",
    "    Z = np.random.binomial(1, .66, size=(n,))\n",
    "    nu = np.random.uniform(0, 1, size=(n,))\n",
    "    C = np.random.binomial(1, scipy.special.expit(10*(X[:, 0] + .4 + nu))) # Compliers when recomended\n",
    "    C0 = np.random.binomial(1, scipy.special.expit(10*(X[:, 1] + nu))) # always takers \n",
    "    plt.title(\"Pr[T=1 | Z=1, X]\")\n",
    "    plt.scatter(X[:, 0], scipy.special.expit(10*(X[:, 0] + .4 + nu)))\n",
    "    plt.show()\n",
    "    plt.title(\"Pr[T=1 | Z=1, X]\")\n",
    "    plt.scatter(X[:, 1], scipy.special.expit(10*(X[:, 1] + nu)))\n",
    "    plt.show()\n",
    "    T = C * Z + (1 - C*Z) * C0\n",
    "    y = true_fn(X) * (T + nu)  + X[:, 0] + np.random.normal(0, .1, size=(n,))\n",
    "    return y, T, X, Z\n",
    "\n",
    "\n",
    "true_fn = lambda X: 1.7 *np.ones(X.shape[0]) + 5*X[:,0] - 5*X[:, 1]\n",
    "\n",
    "np.random.seed(123)\n",
    "n = 3000\n",
    "d = 29\n",
    "y, T, X, Z = dgp_binary(n, d, true_fn)\n",
    "\n",
    "X_df = pd.DataFrame(X, columns=['f'+str(i) for i in range(X.shape[1])])\n",
    "\n",
    "plt.figure(figsize=(10, 2))\n",
    "plt.subplot(1, 2, 1)\n",
    "plt.hist(T[Z==0])\n",
    "plt.title(\"T[Z=0]: Total: {}, T1/Total: {:.2f}\".format(T[Z==0].shape[0], np.sum(T[Z==0])/T[Z==0].shape[0]))\n",
    "plt.subplot(1, 2, 2)\n",
    "plt.hist(T[Z==1])\n",
    "plt.title(\"T[Z=1]: Total: {}, T1/Total: {:.2f}\".format(T[Z==1].shape[0], np.sum(T[Z==1])/T[Z==1].shape[0]))\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# NLSYM DATA"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'\\n# Preprocess data\\ndf = pd.read_csv(\"data/card.csv\")\\ndata_filter = df[\\'educ\\'].values >= 6\\nT = df[\\'educ\\'].values[data_filter]\\nZ = df[\\'nearc4\\'].values[data_filter]\\ny = df[\\'lwage\\'].values[data_filter]\\n\\n# Impute missing values with mean, add dummy columns\\n# I excluded the columns \\'weights\\' as we don\\'t know what it is\\nX_df = df[[\"age\"]].copy()\\nX_df[\\'fatheduc\\'] = df[\\'fatheduc\\'].fillna(value=df[\\'fatheduc\\'].mean())\\nX_df[\\'fatheduc_nan\\'] = df[\\'fatheduc\\'].isnull()*1\\nX_df[\\'motheduc\\'] = df[\\'motheduc\\'].fillna(value=df[\\'motheduc\\'].mean())\\nX_df[\\'motheduc_nan\\'] = df[\\'motheduc\\'].isnull()*1\\nX_df[[\\'momdad14\\', \\'sinmom14\\', \\'step14\\', \\'reg661\\', \\'reg662\\',\\n        \\'reg663\\', \\'reg664\\', \\'reg665\\', \\'reg666\\', \\'reg667\\', \\'reg668\\', \\'reg669\\', \\'south66\\']] = df[[\\'momdad14\\', \\'sinmom14\\', \\'step14\\', \\'reg661\\', \\'reg662\\',\\n        \\'reg663\\', \\'reg664\\', \\'reg665\\', \\'reg666\\', \\'reg667\\', \\'reg668\\', \\'reg669\\', \\'south66\\']]\\nX_df[[\\'black\\', \\'smsa\\', \\'south\\', \\'smsa66\\', \\'enroll\\']] = df[[\\'black\\', \\'smsa\\', \\'south\\', \\'smsa66\\', \\'enroll\\']]\\nX_df[\\'kww\\'] = df[\\'kww\\'].fillna(value=df[\\'kww\\'].mean())\\nX_df[\\'kww_nan\\'] = df[\\'kww\\'].isnull()*1\\nX_df[\\'iq\\'] = df[\\'iq\\'].fillna(value=df[\\'iq\\'].mean())\\nX_df[\\'iq_nan\\'] = df[\\'iq\\'].isnull()*1\\nX_df[\\'libcrd14\\'] = (df[\\'libcrd14\\']==1)*1\\nX_df[\\'libcrd14_nan\\'] = (df[\\'libcrd14\\'].isnull())*1\\n#X_df[[\\'exper\\', \\'expersq\\']] = df[[\\'exper\\', \\'expersq\\']]\\ncolumns_to_scale = [\\'age\\', \\'fatheduc\\', \\'motheduc\\', \\'kww\\', \\'iq\\']#, \\'exper\\', \\'expersq\\']\\nscaler = StandardScaler()\\nX_df[columns_to_scale] = scaler.fit_transform(X_df[columns_to_scale])\\nX = X_df.values[data_filter]\\n\\ntrue_fn = lambda x: np.zeros(x.shape[0])\\n'"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "import pandas as pd\n",
    "from sklearn.preprocessing import StandardScaler\n",
    "\"\"\"\n",
    "# Preprocess data\n",
    "df = pd.read_csv(\"data/card.csv\")\n",
    "data_filter = df['educ'].values >= 6\n",
    "T = df['educ'].values[data_filter]\n",
    "Z = df['nearc4'].values[data_filter]\n",
    "y = df['lwage'].values[data_filter]\n",
    "\n",
    "# Impute missing values with mean, add dummy columns\n",
    "# I excluded the columns 'weights' as we don't know what it is\n",
    "X_df = df[[\"age\"]].copy()\n",
    "X_df['fatheduc'] = df['fatheduc'].fillna(value=df['fatheduc'].mean())\n",
    "X_df['fatheduc_nan'] = df['fatheduc'].isnull()*1\n",
    "X_df['motheduc'] = df['motheduc'].fillna(value=df['motheduc'].mean())\n",
    "X_df['motheduc_nan'] = df['motheduc'].isnull()*1\n",
    "X_df[['momdad14', 'sinmom14', 'step14', 'reg661', 'reg662',\n",
    "        'reg663', 'reg664', 'reg665', 'reg666', 'reg667', 'reg668', 'reg669', 'south66']] = df[['momdad14', 'sinmom14', 'step14', 'reg661', 'reg662',\n",
    "        'reg663', 'reg664', 'reg665', 'reg666', 'reg667', 'reg668', 'reg669', 'south66']]\n",
    "X_df[['black', 'smsa', 'south', 'smsa66', 'enroll']] = df[['black', 'smsa', 'south', 'smsa66', 'enroll']]\n",
    "X_df['kww'] = df['kww'].fillna(value=df['kww'].mean())\n",
    "X_df['kww_nan'] = df['kww'].isnull()*1\n",
    "X_df['iq'] = df['iq'].fillna(value=df['iq'].mean())\n",
    "X_df['iq_nan'] = df['iq'].isnull()*1\n",
    "X_df['libcrd14'] = (df['libcrd14']==1)*1\n",
    "X_df['libcrd14_nan'] = (df['libcrd14'].isnull())*1\n",
    "#X_df[['exper', 'expersq']] = df[['exper', 'expersq']]\n",
    "columns_to_scale = ['age', 'fatheduc', 'motheduc', 'kww', 'iq']#, 'exper', 'expersq']\n",
    "scaler = StandardScaler()\n",
    "X_df[columns_to_scale] = scaler.fit_transform(X_df[columns_to_scale])\n",
    "X = X_df.values[data_filter]\n",
    "\n",
    "true_fn = lambda x: np.zeros(x.shape[0])\n",
    "\"\"\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\moprescu\\AppData\\Local\\Continuum\\anaconda3\\lib\\site-packages\\sklearn\\preprocessing\\data.py:645: DataConversionWarning: Data with input dtype int64, float64 were all converted to float64 by StandardScaler.\n",
      "  return self.partial_fit(X, y)\n",
      "C:\\Users\\moprescu\\AppData\\Local\\Continuum\\anaconda3\\lib\\site-packages\\sklearn\\base.py:464: DataConversionWarning: Data with input dtype int64, float64 were all converted to float64 by StandardScaler.\n",
      "  return self.fit(X, **fit_params).transform(X)\n"
     ]
    }
   ],
   "source": [
    "# Preprocess data\n",
    "df = pd.read_csv(\"data/card.csv\")\n",
    "data_filter = df['educ'].values >= 6\n",
    "T = df['educ'].values[data_filter]\n",
    "Z = df['nearc4'].values[data_filter]\n",
    "y = df['lwage'].values[data_filter]\n",
    "\n",
    "# Impute missing values with mean, add dummy columns\n",
    "# I excluded the columns 'weights' as we don't know what it is\n",
    "X_df = df[['exper', 'expersq']].copy()\n",
    "X_df['fatheduc'] = df['fatheduc'].fillna(value=df['fatheduc'].mean())\n",
    "X_df['fatheduc_nan'] = df['fatheduc'].isnull()*1\n",
    "X_df['motheduc'] = df['motheduc'].fillna(value=df['motheduc'].mean())\n",
    "X_df['motheduc_nan'] = df['motheduc'].isnull()*1\n",
    "X_df[['momdad14', 'sinmom14', 'reg661', 'reg662',\n",
    "        'reg663', 'reg664', 'reg665', 'reg666', 'reg667', 'reg668', 'reg669', 'south66']] = df[['momdad14', 'sinmom14', \n",
    "        'reg661', 'reg662','reg663', 'reg664', 'reg665', 'reg666', 'reg667', 'reg668', 'reg669', 'south66']]\n",
    "X_df[['black', 'smsa', 'south', 'smsa66']] = df[['black', 'smsa', 'south', 'smsa66']]\n",
    "#X_df[['black', 'smsa', 'south', 'smsa66', 'enroll']] = df[['black', 'smsa', 'south', 'smsa66', 'enroll']]\n",
    "#X_df['kww'] = df['kww'].fillna(value=df['kww'].mean())\n",
    "#X_df['kww_nan'] = df['kww'].isnull()*1\n",
    "#X_df['iq'] = df['iq'].fillna(value=df['iq'].mean())\n",
    "#X_df['iq_nan'] = df['iq'].isnull()*1\n",
    "#X_df['libcrd14'] = (df['libcrd14']==1)*1\n",
    "#X_df['libcrd14_nan'] = (df['libcrd14'].isnull())*1\n",
    "#X_df[['exper', 'expersq']] = df[['exper', 'expersq']]\n",
    "#columns_to_scale = ['age', 'fatheduc', 'motheduc', 'kww', 'iq', 'exper', 'expersq']\n",
    "columns_to_scale = ['fatheduc', 'motheduc', 'exper', 'expersq']\n",
    "scaler = StandardScaler()\n",
    "X_raw = X_df.values[data_filter]\n",
    "X_df[columns_to_scale] = scaler.fit_transform(X_df[columns_to_scale])\n",
    "X = X_df.values[data_filter]\n",
    "\n",
    "true_fn = lambda x: np.zeros(x.shape[0])\n",
    "#X_raw = np.tile(X_raw, (5, 1))\n",
    "#X = np.tile(X, (5, 1))\n",
    "#Z = np.tile(Z, 5)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 512,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Index(['exper', 'expersq', 'fatheduc', 'fatheduc_nan', 'motheduc',\n",
       "       'motheduc_nan', 'momdad14', 'sinmom14', 'reg661', 'reg662', 'reg663',\n",
       "       'reg664', 'reg665', 'reg666', 'reg667', 'reg668', 'reg669', 'south66',\n",
       "       'black', 'smsa', 'south', 'smsa66'],\n",
       "      dtype='object')"
      ]
     },
     "execution_count": 512,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "X_df.columns"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 513,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.hist(T[T<=12])\n",
    "plt.hist(T[T>12])\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 514,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 720x144 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "(2991, 22)"
      ]
     },
     "execution_count": 514,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "plt.figure(figsize=(10, 2))\n",
    "plt.subplot(1, 2, 1)\n",
    "plt.hist(T[Z==0])\n",
    "plt.title(\"T[Z=0]: Total: {}, T1/Total: {:.2f}\".format(T[Z==0].shape[0], np.sum(T[Z==0])/T[Z==0].shape[0]))\n",
    "plt.subplot(1, 2, 2)\n",
    "plt.hist(T[Z==1])\n",
    "plt.title(\"T[Z=1]: Total: {}, T1/Total: {:.2f}\".format(T[Z==1].shape[0], np.sum(T[Z==1])/T[Z==1].shape[0]))\n",
    "plt.show()\n",
    "X.shape"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# 2. Semi-Synthetic Data with Binary Instrument and Continuous Treatment\n",
    "\n",
    "Data generating process uning real covariates $X$ and instrument $Z$, but synthetic $y$ and $T$ based on the \"intent to treat\" instrument setting with non-compliance. The instrument corresponds to a fully randomized recommendation of treatment. Then each sample complies with the recommendation to some degree. This probability also depends on an unobserved confounder that has a direct effect on the outcome. Moreover, compliance also depends on the observed feature $X$.\n",
    "\n",
    "\\begin{align}\n",
    "X \\tag{ real features}\\\\\n",
    "Z \\tag{real instrument}\\\\\n",
    "\\nu \\sim \\; & \\text{U}[0, 1] \\tag{unobserved confounder}\\\\\n",
    "C = \\; & c\\cdot X[i], \\; c \\;(const)\\sim \\text{U}[0, 1] \\tag{compliance degree}\\\\\n",
    "T = \\; & C\\cdot Z + g(X) + \\nu  \\tag{treatment}\\\\\n",
    "y \\sim \\; & \\text{Normal}(\\mu=\\theta(X) \\cdot (T + \\nu) + f(X),\\; \\sigma=.1) \\tag{outcome}\n",
    "\\end{align}\n",
    "\n",
    "Moreover:\n",
    "\\begin{align}\n",
    "\\theta(X) = \\; & \\alpha + \\beta \\cdot X[i] \\tag{CATE}\\\\\n",
    "f(X) = \\; & X[i] \\tag{Nuissance function}\\\\\n",
    "g(X) = \\; & X[i] \\tag{Nuissance function}\n",
    "\\end{align}\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 848,
   "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": [
    "def dgp_bin_Z_cont_T(X, Z, hetero_col, true_fn, random_seed=None):\n",
    "    np.random.seed(random_seed)\n",
    "    n, d = X.shape\n",
    "    nu = np.random.uniform(-1, 1, size=(n,))\n",
    "    c = np.random.uniform(0.2, 0.3)\n",
    "    C = c * X[:, hetero_col] # Compliers when recomended\n",
    "    T = C * Z + X[:, hetero_col] + nu # Treatment with compliance\n",
    "    y = true_fn(X) * (T + nu)  + 0.05*X[:, hetero_col] + np.random.normal(0, .1, size=(n,))\n",
    "    return y, T\n",
    "\n",
    "hetero_col = 4 # Mother's education\n",
    "hetero_col_2 = 7\n",
    "#true_fn = lambda X: 0.1 * np.ones(X.shape[0]) - 0.1*(X[:, hetero_col] - 10)\n",
    "mean_TE = np.mean(0.05*X_raw[:, hetero_col] - 0.1*X_raw[:, hetero_col_2])\n",
    "true_fn = lambda X: 0.1 + 0.05*X[:, hetero_col] - 0.1*X[:, hetero_col_2]\n",
    "\n",
    "np.random.seed(1237)\n",
    "y, T = dgp_bin_Z_cont_T(X_raw, Z, hetero_col, true_fn)\n",
    "\n",
    "plt.figure(figsize=(10, 2))\n",
    "plt.subplot(1, 2, 1)\n",
    "plt.hist(T[Z==0])\n",
    "plt.title(\"T[Z=0]: Total: {}, T1/Total: {:.2f}\".format(T[Z==0].shape[0], np.sum(T[Z==0])/T[Z==0].shape[0]))\n",
    "plt.subplot(1, 2, 2)\n",
    "plt.hist(T[Z==1])\n",
    "plt.title(\"T[Z=1]: Total: {}, T1/Total: {:.2f}\".format(T[Z==1].shape[0], np.sum(T[Z==1])/T[Z==1].shape[0]))\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 849,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array([   5.,   43.,   69.,  117.,  226.,  712.,  544., 1012.,  113.,\n",
       "         150.]),\n",
       " array([0. , 0.1, 0.2, 0.3, 0.4, 0.5, 0.6, 0.7, 0.8, 0.9, 1. ]),\n",
       " <a list of 10 Patch objects>)"
      ]
     },
     "execution_count": 849,
     "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": [
    "plt.hist(true_fn(X_raw))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# ANALYSIS"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Defining some hyperparameters"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 840,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.003343363423604146\n"
     ]
    }
   ],
   "source": [
    "random_seed = 123459 # random seed for each experiment\n",
    "N_SPLITS = 10 # number of splits for cross-fitting\n",
    "COV_CLIP = 10/X.shape[0] # covariance clipping in driv\n",
    "print(COV_CLIP)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Defining some generic non-parametric regressors and classifiers"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 850,
   "metadata": {},
   "outputs": [],
   "source": [
    "from utilities import RegWrapper\n",
    "from sklearn.model_selection import GridSearchCV\n",
    "from sklearn.linear_model import LassoCV, LogisticRegressionCV\n",
    "from xgboost import XGBClassifier, XGBRegressor\n",
    "from xgb_utilities import XGBWrapper\n",
    "\n",
    "\n",
    "# This a generic non-parametric regressor\n",
    "#model = lambda: GradientBoostingRegressor(n_estimators=20, max_depth=3, min_samples_leaf=20,\n",
    "#                                         n_iter_no_change=5, min_impurity_decrease=.001, tol=0.001)\n",
    "#model = lambda: XGBWrapper(XGBRegressor(gamma=0.001, n_estimators=100, min_child_weight=50, n_jobs=10),\n",
    "#                           early_stopping_rounds=5, eval_metric='rmse', binary=False)\n",
    "\n",
    "# This a generic non-parametric regressor\n",
    "#model = lambda: GridSearchCV(GradientBoostingRegressor(),\n",
    "#                             param_grid={'n_estimators': [10, 30, 60]}, cv=3, iid=True)\n",
    "#model = lambda: GridSearchCV(RandomForestRegressor(n_estimators=100, min_samples_leaf=100),\n",
    "#                             param_grid={'max_depth': [1, 3, 5]}, cv=3, iid=True)\n",
    "#model = lambda: GradientBoostingRegressor(n_estimators=10)\n",
    "#model = lambda: Lasso(alpha=10/np.sqrt(X.shape[0]))\n",
    "model = lambda: LassoCV(cv=5, n_jobs=-1)\n",
    "\n",
    "# This is a generic non-parametric classifier. We have to wrap it with the RegWrapper, because\n",
    "# we want to use predict_proba and not predict. The RegWrapper calls predict_proba of the\n",
    "# underlying model whenever predict is called.\n",
    "#model_clf = lambda: RegWrapper(GridSearchCV(GradientBoostingClassifier(),\n",
    "#                                            param_grid={'n_estimators': [10, 30, 60]}, cv=3, iid=True))\n",
    "#model_clf = lambda: RegWrapper(GridSearchCV(RandomForestClassifier(n_estimators=100, min_samples_leaf=100),\n",
    "#                             param_grid={'max_depth': [1, 3, 5]}, cv=3, iid=True))\n",
    "#model_clf = lambda: RegWrapper(GradientBoostingClassifier(n_estimators=10)) \n",
    "#model_clf = lambda: RegWrapper(LogisticRegression(C=10/np.sqrt(X.shape[0]), penalty='l1', solver='saga'))\n",
    "model_clf = lambda: RegWrapper(LogisticRegressionCV(n_jobs=-1, cv=5, solver='liblinear',\n",
    "                                                   scoring='neg_log_loss'))\n",
    "#model_clf = lambda: RegWrapper(GradientBoostingClassifier(n_estimators=20, max_depth=3, min_samples_leaf=20,\n",
    "#                                         n_iter_no_change=5, min_impurity_decrease=.001, tol=0.001))\n",
    "#model_clf = lambda: RegWrapper(XGBWrapper(XGBClassifier(gamma=0.001, n_estimators=100, min_child_weight=50, n_jobs=10),\n",
    "#                                          early_stopping_rounds=5, eval_metric='logloss', binary=True))\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Some utility functions"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 851,
   "metadata": {},
   "outputs": [],
   "source": [
    "def nuisance_diagnostic(cate, nuisance_model, property_name, property_fn, \n",
    "                        index_names=None, statistic=np.std, threshold=None):\n",
    "    std = statistic([property_fn(ns) for ns in cate.fitted_nuisances[nuisance_model]], axis=0)\n",
    "    if hasattr(std, '__len__'):\n",
    "        if threshold is None:\n",
    "            coefs = np.argmax(std).flatten()\n",
    "        else:\n",
    "            coefs = np.argwhere(std >= threshold).flatten()\n",
    "        if index_names is None:\n",
    "            index_names = np.arange(std.shape[0])\n",
    "        for high_var in coefs:\n",
    "            plt.title(\"{}: {}[{}] Across Folds\".format(nuisance_model, property_name, index_names[high_var]))\n",
    "            plt.plot([property_fn(ns)[high_var] for ns in cate.fitted_nuisances[nuisance_model]])\n",
    "            plt.xlabel('fold')\n",
    "            plt.ylabel('property')\n",
    "            plt.show()\n",
    "    else:\n",
    "        plt.title(\"{}: {} Across Folds\".format(nuisance_model, property_name))    \n",
    "        plt.plot([property_fn(ns) for ns in cate.fitted_nuisances[nuisance_model]])\n",
    "        plt.xlabel('fold')\n",
    "        plt.ylabel('property')\n",
    "        plt.show()\n",
    "    "
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# ATE via DMLATEIV"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 852,
   "metadata": {},
   "outputs": [],
   "source": [
    "from dml_ate_iv import DMLATEIV\n",
    "\n",
    "np.random.seed(random_seed)\n",
    "\n",
    "# We need to specify models to be used for each of these residualizations\n",
    "model_Y_X = lambda: Pipeline([('poly', PolynomialFeatures(degree=2, include_bias=True)),\n",
    "                                      ('reg', model())]) # model for E[Y | X]\n",
    "#model_Y_X = lambda: model()\n",
    "model_T_X = lambda: model() # model for E[T | X]. We use a regressor since T is continuous\n",
    "model_Z_X = lambda: model_clf() # model for E[Z | X]. We use a classifier since Z is binary\n",
    "\n",
    "dmlate = DMLATEIV(model_Y_X(), model_T_X(), model_Z_X(),\n",
    "                  n_splits=N_SPLITS, # n_splits determines the number of splits to be used for cross-fitting.\n",
    "                  binary_instrument=True, # a flag whether to stratify cross-fitting by instrument\n",
    "                  binary_treatment=False # a flag whether to stratify cross-fitting by treatment\n",
    "                 )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 853,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<dml_ate_iv.DMLATEIV at 0x1e191917cc0>"
      ]
     },
     "execution_count": 853,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# We fit DMLATEIV with these models\n",
    "dmlate.fit(y, T, X, Z)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 854,
   "metadata": {},
   "outputs": [],
   "source": [
    "# We call effect() to get the ATE\n",
    "ta_effect = dmlate.effect()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 855,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "ATE Estimate: 0.651\n",
      "True ATE: 0.609\n",
      "CATE MSE: 0.03\n"
     ]
    }
   ],
   "source": [
    "# Comparison with true ATE\n",
    "print(\"ATE Estimate: {:.3f}\".format(ta_effect))\n",
    "print(\"True ATE: {:.3f}\".format(np.mean(true_fn(X_raw))))\n",
    "# CATE MSE\n",
    "print(\"CATE MSE: {:.2f}\".format(np.mean((true_fn(X_raw) - ta_effect)**2)))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 856,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "ATE Estimate Interval: (0.609, 0.692)\n",
      "True ATE: 0.609\n"
     ]
    }
   ],
   "source": [
    "# We can call normal_effect_interval to get confidence intervals based\n",
    "# based on the asympotic normal approximation\n",
    "ta_effect = dmlate.normal_effect_interval(lower=2.5, upper=97.5)\n",
    "# Comparison with true ATE\n",
    "print(\"ATE Estimate Interval: ({:.3f}, {:.3f})\".format(ta_effect[0], ta_effect[1]))\n",
    "print(\"True ATE: {:.3f}\".format(np.mean(true_fn(X_raw))))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 679,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "\"\\n# coverage\\nn_experiments = 100\\ncontains_truth = np.zeros(n_experiments)\\ntrue_ate = np.mean(true_fn(X_raw))\\nfor i in range(n_experiments):\\n    y, T = dgp_bin_Z_cont_T(X_raw, Z, hetero_col, true_fn, random_seed=i)\\n    model_Y_X = lambda: Pipeline([('poly', PolynomialFeatures(degree=2, include_bias=True)),\\n                                      ('reg', model())]) # model for E[Y | X]\\n    model_T_X = lambda: model() # model for E[T | X]. We use a regressor since T is continuous\\n    model_Z_X = lambda: model_clf() # model for E[Z | X]. We use a classifier since Z is binary\\n\\n    dmlate = DMLATEIV(model_Y_X(), model_T_X(), model_Z_X(),\\n                      n_splits=N_SPLITS, # n_splits determines the number of splits to be used for cross-fitting.\\n                      binary_instrument=True, # a flag whether to stratify cross-fitting by instrument\\n                      binary_treatment=False # a flag whether to stratify cross-fitting by treatment\\n                     )\\n    dmlate.fit(y, T, X, Z)\\n    ta_effect = dmlate.effect()\\n    left, right = dmlate.normal_effect_interval(lower=2.5, upper=97.5)\\n    print(i, ta_effect, left, right)\\n    if true_ate >= left and true_ate <= right:\\n        contains_truth[i] = 1\\n\""
      ]
     },
     "execution_count": 679,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "\"\"\"\n",
    "# coverage\n",
    "n_experiments = 100\n",
    "contains_truth = np.zeros(n_experiments)\n",
    "true_ate = np.mean(true_fn(X_raw))\n",
    "for i in range(n_experiments):\n",
    "    y, T = dgp_bin_Z_cont_T(X_raw, Z, hetero_col, true_fn, random_seed=i)\n",
    "    model_Y_X = lambda: Pipeline([('poly', PolynomialFeatures(degree=2, include_bias=True)),\n",
    "                                      ('reg', model())]) # model for E[Y | X]\n",
    "    model_T_X = lambda: model() # model for E[T | X]. We use a regressor since T is continuous\n",
    "    model_Z_X = lambda: model_clf() # model for E[Z | X]. We use a classifier since Z is binary\n",
    "\n",
    "    dmlate = DMLATEIV(model_Y_X(), model_T_X(), model_Z_X(),\n",
    "                      n_splits=N_SPLITS, # n_splits determines the number of splits to be used for cross-fitting.\n",
    "                      binary_instrument=True, # a flag whether to stratify cross-fitting by instrument\n",
    "                      binary_treatment=False # a flag whether to stratify cross-fitting by treatment\n",
    "                     )\n",
    "    dmlate.fit(y, T, X, Z)\n",
    "    ta_effect = dmlate.effect()\n",
    "    left, right = dmlate.normal_effect_interval(lower=2.5, upper=97.5)\n",
    "    print(i, ta_effect, left, right)\n",
    "    if true_ate >= left and true_ate <= right:\n",
    "        contains_truth[i] = 1\n",
    "\"\"\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 634,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.08"
      ]
     },
     "execution_count": 634,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "contains_truth.mean()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 992,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[None, None, None]"
      ]
     },
     "execution_count": 992,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# The property .fitted_nuisances is a dictionary of the form:\n",
    "# {'name_of_nuisance': [fitted_model_fold_1, fitted_model_fold_2, ...]}\n",
    "# then we can access all properties of each of the fitted models for each fold.\n",
    "# If for instance all nuisances have a linear form we can look at the standard deviation\n",
    "# of the coefficients of each of the nuisance model across folds to check for stability\n",
    "[print(\"Model {} max std of coefs: {}\".format(name,\n",
    "                                              np.max(np.std([ns.coef_ for ns in nuisance_insts], axis=0)))) \n",
    " if hasattr(nuisance_insts[0], 'coef_') else None\n",
    " for name, nuisance_insts in dmlate.fitted_nuisances.items()]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 993,
   "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": "iVBORw0KGgoAAAANSUhEUgAAAYsAAAEWCAYAAACXGLsWAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADl0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uIDIuMi4zLCBodHRwOi8vbWF0cGxvdGxpYi5vcmcvIxREBQAAIABJREFUeJzs3Xl83HWd+PHXO/c96ZG2yWRK79ImbUpJD0ABQeQsHisgqyIioqt47IrXsite6x7u6s9zFaEgiiyHqC2HgIqikEJD2/QuJWlpkkmaNGmuprnfvz/mO+00TK42c7+fj8c8OvM9Zt6ZNPOe7+f9OURVMcYYY0aTFOkAjDHGRD9LFsYYY8ZkycIYY8yYLFkYY4wZkyULY4wxY7JkYYwxZkyWLBKQiNwvIt8c57EHReTtoY4pGonIn0XkVuf++0Xk2dN8noMiclxEfjG5EZ5WLF8TkWMioiKSEul4IkVEbhaRv42y/8Tv3vhYsjBnREQuE5HDIjI9YFu6iOwRkY+Nct45ItIuIgsCtp0rIm0iMie0UU+cqj6oqu8Y6zgR+aqI/DLIrnWq+kHnmBki8pCIeJ334EURWTPC893nfLAvGLb9fc57fExEqkXkrc7294tIV8Ct2zn/XOfnuAsoGcfPISJSIyK7xzo2kpwP/cFhP/MPIx1XPLJkYc6Iqj4HPAF8L2DzvwANwN2jnLcV+BHwM+eDKRVYD3xFVQ9OdpxR9i06B9gMnAtMBX4OPCkiOYEHichbgPnDTxaRy4D/BD4M5AIXAjVwIqnl+G/AJ5x9WyYY44XADGCeiKya4Ln+OMP1nlcE/syqenuYXjehWLKIUk7TxedFZLvz7fFeEZkpIk+LSKeI/EFEpgQcf62I7HK+mf9ZRJYE7DtHRLY45z0MZAx7rWtEZJtz7ksisnyC4f4TcJGIXC0ipcDtwEd17OkBvgYUArcB/wx0AeP+Vuh8Y/608w34iIh8W0SSnH03O9/YvysircBXne23ON/Ij4rIMyJyVsDzXSYie51v+z8EJGDfKc0WIlIiIs+JSKtzZfXPInKF83Pc4HzDrQoWt6rWqOp3VLVBVQdV9W4gDVgc8PwpwA+c9zLY+/Z1Vd2kqkOqWq+q9SO8TR8CHhjH7yLYeb8DnnLunyAiU50rHq/zPv7W2X6xiNSJyBdFpBG4z9n+URF53XmvNohIkbNdnN9Pk/Oeb3f+/yAiV4nIbuf/bL2I3DHB+BERl4g8ICLNIvKGiPyL//9HkGNH+90vEJG/OPuOOH9DiUdV7RaFN+AgsAmYCbiBJnzfDs8B0oE/AXc5xy4CjgGXAanAF4DX8X0ApQFvAP/o7Hsv0A980zl3pfPca4BkfB8MB4H0gDjePo541wG1wCvAZyfwc14AtAEdwNnD9v0Y+PEo5yrwPL5v57OB14BbnX03AwPAp4AUIBN4l/O+LHG2/QvwknP8dCeG9zrv0z865wc+39+c+7n4rpw+hy/x5gJrnH1fBX4Z5Hc54nsIrAB6AFfAts8D3wv4ORc495OBPuBLzs9Shy/BZgZ53rOAQWDusO1znOdMGSGeLOe9uAr4O+AIkBaw/0ngYWCK815d5Gy/2HnP/hPf/9FM4BLn/JXOth8ALzjHXw68CuTj+3BeAhQ6+xqAtzr3pwArR4j1xO8lyL4H8CW8XOdnfg34SJDf51i/+4eAO/F9uc4A3hLpz4dI3CIegN1G+MX4PmDeH/D418D/Bjz+FPBb5/6/Ao8E7EsC6p0/3gsBLyAB+1/iZLL4X+Abw157X8AHwEHGkSycYx8FKoGkCfycLufD5MXTeI8UuCLg8SeAPzr3bwYODTv+af+HRcD71I3vQ/UmYFPAPsH3QRwsWdwIbB0hpq8ygWQB5AE7gC8HbPPgSwSugJ/TnyyKnMeV+K7KpgMvAv8W5Ln/FfhzkO1zGD1ZfABoxpdQ0/El83c7+wqBIWBKkPMuxpfIMgK23Qv8V8DjHHxfVubgSySvAWuH/58BDgEfA/LG+D9wM74P9raA21p8SbUXWBpw7Mf878ew3+dYv/sH8DWpFp/u33M83KwZKrodDrh/PMhjfxt3Eb6rBwBUdQjft3y3s69enf/1jjcC7p8FfM5pgmoTkTZ8H1ZFpxHvLmCv8/rj9T/AX4BiEXnfabxmbcD9Nzg17tphx54FfC/g52zF98Hgf59OHO+8X8PP9/MA1acR6ylEJBPYiO+D6t8Ddv0/fM1M7UFOO+78+wP1NWMdAb6D7ypguJvw1UMm6kP4vnwMqGov8Dgnm6I8QKuqHh3h3GZV7Ql4PPz/ZhfQArhV9U/4rop+BBwWkbtFJM859O+cn+kNpwnovFHi3aSq+QG3TfiSqP+q2u8NfL/r4cb63X8B3/+TV5ym3ltGiSVuWbKID158H4SAry0Y3x91Pb7LebezzW92wP1afN9KA//YslT1oVAHLSKXAu8EPu7cviciUyf4NJ6A+7PxvRd+w9vpa4GPDftZM1X1JXzv04nnCngPg6klSOF5hNcMSkTSgd/i+x0N7zV2KfBtEWl02v4BKkTk750P6bqxXkdELsD3IfjYeOIJOK8Y3zf+DwS8/nuBq8TX460WmCoi+SM8xfC4hv/fzAam4fu5UdXvq+q5+HpoLcLX/IaqblbVd+Irsv8WeGQiPwe+q9X+wNfG9/8jWG1n1N+9qjaq6kdVtQjf7+rHMqx3WiKwZBEfHgGuFpFLxder6HP4LsFfAirwXaZ/WkRSROQ9wOqAc38GfFxE1jgFx2ynUJ0byoCdD42f4atvNKvq08BzwHcn+FSfF5EpIuIBPoOvLX0kPwG+LCIlTgwuEbnO2fckUCIi73GKy58GZo3wPE8As0Tks+LrJpwrJ7u+HgbmjFRIdV43Fd+H+HHgpiBXYouAMny1jBXOtnXAb5z79wGfEl8X3CnAZ52YAn0I+LWqdo4Uxwg+iK9paHHA6y/Cl6BuVNUGfM15P3be91QRuXCU5/sV8GERWeEkyG8BL6vqQRFZ5fy/S8VXc+sBBkUkTXxdgF2q2o+vnjA4kR9CVQfx/V38m/P7OQtfR4xg3ZpH/d2LyHVOEgU4ii8hTiieeGDJIg6o6j587cw/wPeNah2+fv19qtoHvAdfG+1R4AZ8zQr+cyuBj+JrDjiKr6385jCE/S18TVYPBmz7LHCliLwDQER+IiI/GeN5foevSLoN3x/9vSMdqKq/wVd8/T8R6QB2Alc6+44A1wH/ga+ZZCG+WkCw5+nE15lgHdAI7Afe5ux+1Pm3RURG6q56PnAN8A6gTU6OD3ir8/xNzrfZRlX1X1kcUVV/E9Q38HW9fQ3YA2wF/s3/5CKSAVzP6TdB/Tjw9Z0YfsLJpqgP4vvWvhdf54jPjvRkqvpHfLWTX+P7Bj8f8Dc35uH7wnAUXxNRC/DfAa9x0Pk9fRzf/++J+hS+JFQD/A1f4lofJMaxfvergJdFpAvYAHxGVQ+cRjwxTU5tyjYmdoiIAgtV9fVIxzIaEdmHrzD8G1X90FjHhziWu/B9w04Hsp1v4MaMyZKFiVmxkiyMiQfWDGXGRXyDAbuC3P55lHOGTz3hv+0KZ+zGmDNnVxbGGGPGZFcWxhhjxhRNk6udkenTp+ucOXMiHYYxxsSUV1999YiqFox1XNwkizlz5lBZWRnpMIwxJqaIyBtjH2XNUMYYY8bBkoUxxpgxWbIwxhgzJksWxhhjxmTJwhhjzJgsWRhjjBmTJQtjjDFjsmRhTnGkq5ffbg22PowxJpFZsjCn+N4f9vPZh7dR29od6VCMMVHEkoU5YWBwiKd2NACwvS7Y8s/GmERlycKc8GJ1Cy3H+gCoqmuLcDTGmGgSN3NDmTO3scpLbkYKnilZbKu1ZGGMOcmuLAwAPf2DPLOzkStKZrF67lR21rczOGRrnRhjfCxZGAD+vK+Zzt4B1pUVsbzYRXffIK83dUU6LGNMlLBkYQBfE9T0nDTOnz+NMk8+AFXWFGWMcViyMHT1DvCHPYe5alkhKclJzJ2WTW5GCtusyG2McViyMDy3u5HegSGuLSsCIClJKCvOtysLY8wJliwMG7Z5cednsnL2lBPblhe72NfYSU//YAQjM8ZEi5AlCxFZLyJNIrIzYNtXRaReRLY5t6tGOPcKEdknIq+LyJdCFaOBo8f6+Ov+I1xTVkhSkpzYXubJZ2BI2eXtiGB0xphoEcori/uBK4Js/66qrnBuTw3fKSLJwI+AK4GlwI0isjSEcSa0p3Y2MDCkJ5qg/FZYkdsYEyBkyUJVXwBaT+PU1cDrqlqjqn3A/wHvnNTgzAkbq7zML8hmaWHeKdtn5mUwKy/DRnIbY4DI1CxuF5HtTjPVlCD73UBtwOM6Z9ubiMhtIlIpIpXNzc2hiDWuNbb38PKBVq4tcyMib9q/vNhlc0QZY4DwJ4v/BeYDK4AG4H+CHPPmTy0IOpRYVe9W1XJVLS8oKJi8KBPEE9u9qMK6ssKg+8s8+Rw4coy27r4wR2aMiTZhTRaqelhVB1V1CPgZvian4eoAT8DjYsAbjvgSzcYqL6XuPOYV5ATd769b2NWFMSasyUJEAr/CvhvYGeSwzcBCEZkrImnA+4AN4YgvkRw8coyquvY3FbYDLSt2AVbkNsaEcNZZEXkIuBiYLiJ1wF3AxSKyAl+z0kHgY86xRcA9qnqVqg6IyO3AM0AysF5Vd4UqzkS1scp3sXbN8pGTRV5GKvMLsqmyKwtjEl7IkoWq3hhk870jHOsFrgp4/BTwpm61ZnKoKhuqvKyeM5Wi/MxRjy0rzueF/UdQ1aBFcGNMYrAR3Alob2Mn+5u6WLdi5KsKvzJPPke6emlo7wlDZMaYaGXJIgFtqPKSnCRcVTprzGNtBlpjDFiySDiqysYqL29ZMJ1pOeljHr+kMJfUZLG6hTEJzpJFgtla20bd0eOsG6UXVKD0lGSWFObZlYUxCc6SRYLZsM1LWkoSl5fMHPc5ZcX57LBlVo1JaJYsEsjgkPLkjgYuWTyD3IzUcZ9X5smnq3eAmmZbZtWYRGXJIoFsqmmhubOXa8fRCyrQCo8zOM/qFsac0Nbdx44E+puwZJFANmzzkpOewiVnz5jQefOm55CTnmJ1C2Mc7d393PDTTVz305foGxiKdDhhYckiQfQODPL0zgbesXQmGanJEzo3KUlY5nbZdOXGAMf7BvnIzzez73AnPf1DvHa4M9IhhYUliwTxwmtH6OgZGNdAvGDKPPnsaeigd8CWWTWJa2BwiNt/tYVXDx3l85cvBmBnfWI0RVmySBAbqrxMyUrlLQumn9b5Kzwu+geVPQ2J8S3KmOFUlS8/voM/7m3i6+8s5R8umk9uego7vZYsTJzo7hvgD7sPc9WyQlKTT+9XvrzYRnKbxPafv9/Ho6/W8ZlLF/LBtWeRlCSUuPPYUZ8Y69RbskgAf9jTxPH+wXEPxAum0JVBQW66JQuTkO75aw0/+Us1718zm8++feGJ7aVFLvY0dNA/GP9FbksWCWDDNi+z8jJYPWfqaT+HiFBWnM82K3KbBPObrXV888k9XLVsFl9/Z+kpsy8vK3bRNzDE603xPwbJkkWca+/u5y+vNXHN8kKSks5sivEVHhc1zcfo6OmfpOiMiW7P72vi849u57x50/juDStIHvY3VFLkG4OUCEVuSxZx7ve7Gugf1AkPxAvGX7dIpIFIJnFtOXSUT/xyC4tn5XL3TeeSnvLmLufzpmeTnZZsycLEvg1VXuZMy2KZ23XGz7XcWWZ1m9UtTJx7vamTW+7fzIy8dO7/8OoRp8dJShKWFuWx0xv/RW5LFnGsqbOHiuoWri0rmpRV7vKz0pg7PduK3CaueduO88F7XyElKYlf3LKGgtzRp/IvdbvY7e2I+4k2LVnEsSe3NzCkTEoTlF9ZsYvt1gxl4tTRY33ctP4VunoG+Pktq5g9LWvMc0qLXBzvH4z7iTZDlixEZL2INInIziD77hARFZGgI8RE5L9EZJeI7BGR74st/nxaNlR5WVKYx4IZuZP2nMuL82ns6KHRllk1caa7b4Bbfr6ZQ63d3H1T+Yni9ViWOc2zO+K8bhHKK4v7gSuGbxQRD3AZcCjYSSJyPnABsBwoBVYBF4UsyjhV29rN1kNtrCsrnNTnPbHMqnWhNXGkf3CITzy4haraNr7/vhWcN3/auM+dNz2bjNQkdsb54LyQJQtVfQFoDbLru8AXgJEa+BTIANKAdCAVOByKGOPZhiovAOuWT14TFEBJUR4pSWJ1CxM3hoaULz62nT/va+ab71rGFaUT+4KVkpzE0sK8uO8RFdaahYhcC9SratVIx6hqBfA80ODcnlHVPSM8320iUikilc3NzSGJOVZtrPKycnY+nqljt7lOREZqMmcX5lrdwsSNf396D49vreefLlvE36+ZfVrPUep2scvbzlAcF7nDlixEJAu4E/jKGMctAJYAxYAbuERELgx2rKrerarlqlpeUFAw2SHHrP2HO9nb2Mm1ZzC9x2iWF+dTVdcW138YJjH89C/V/OyvB7jpvLP41CULTvt5St0ujvUNcqDl2CRGF13CeWUxH5gLVInIQXzJYIuIzBp23LuBTarapapdwNPA2jDGGfM2VHlJErh6kpug/FYU59PZMxDXfxgm/j32ah3//vRerl5eyF3rSs6oe3lpAozkDluyUNUdqjpDVeeo6hygDlipqo3DDj0EXCQiKSKSiq+4HbQZyryZqrKhysv586eP2T/8dJ0oclvdwsSoP+45zBd/vZ0LFkzjO9eXvWkaj4laODOHtJQkSxanQ0QeAiqAxSJSJyIfGeXYchG5x3n4GFAN7ACqgCpV3RiqOOPN9rp23mjpDlkTFMCCGTlkpSVb3cLEpFffaOWTv9rC0sI8fvrB8qDTeExUanISS2blxnWPqJRQPbGq3jjG/jkB9yuBW537g8DHQhVXvNtQ5SUtOYnLS4e37k2e5CSh1O2yaT9MzHntcCe33F9JoSuT+z68ipz0yfsILHW72FDlRVUnZcaEaGMjuOPI4JDyxHYvFy0uwJUZfC6bybLCk89ub0fCLFZvYl9923FuuvcV0lKSeOCW1UzPmdxm2lK3i86eAQ61dk/q80YLSxZx5JUDrRzu6D2jRY7Gq6w4n77BIfY2xu9lt4kfrcf6+OC9L3Osb4AHblk96V3K4WSRO15HcluyiCMbqrxkpibz9iUzQv5aZR7fH0aV1S1MlDvWO8CH799M3dHj3HNTOUsK80LyOotm5ZCaLHFbt7BkESf6B4d4emcDly2dSVZayEpRJ7jzM5mWnWY9okxU6xsY4h8e3MKOujZ+eOM5rJk3/mk8Jio9JZlFM3PZ5Y3PL1CWLOLE3/Yfoa27P6S9oAKJCGWefEsWJmoNDSmff6yKF15r5lvvXsY7SkLX6cNvmdvFjvp2VONvwKolizixocqLKzOVCxeFbyR7WXE+rzd30dU7ELbXNGY8VJVvPrmH323z8vnLF/O+1ac3jcdElbhdtHX3U992PCyvF06WLOLA8b5Bnt3VyJWls0hLCd+vtMzjQtWWWTXR53//Us36Fw9w8/lz+MTF88P2uv4VKeNxcJ4lizjwp71NHOsbDFsTlJ9/TW6brtxEk0c21/Jfv9/HtWVFfOWapWEd83D2rFySk+KzyG3JIg5sqKqnIDc9pMW7YKZmpzF7apbVLUzUeG73Yb70+HbeunA6/31dGUlnOI3HRGWkJrNwRk5cdp+1ZBHjOnr6eX5fM1cvKzzj+W1OhxW5TbR45UArt/9qC8uK8/nJB84Na5NsoFK3i51xWOS2ZBHjntnZSN/A0KSusz0RZcUuvO09NHXaMqsmcvY2dvCRn2/GPSWT+25eRfYkTuMxUcvcLlqO9dHYEV9/E5YsYtyGKi+eqZmc48wEG27+GWi318bfZbeJDbWt3dx07ytkp6XwwC2rmZqdFtF4St2+QX/xVrewZBHDjnT18lJ1C+uWF0Vs4rKSojySk8SK3CYijnT1ctP6V+jpH+Tnt6ymeMrkT+MxUUsK80iS+Jv2I3LXauaMPb2jgcEhjVgTFEBWWgqLZubaDLQm7Lp6B/jwfZvxth3nwVvXsHhWbqRDAnx/E/MLctgVZ8nCrixi2IYqL4tm5nD2rNDMdTNeKzwuttfFX0HPRK/egUE+/otX2d3QwY/fv5LyOVMjHdIp/CO544klixhV33aczQePhn1sRTBlxfm0H+/njZb4nJrZRJehIeVzj1Txt9eP8B/vWcalS2ZGOqQ3KXG7aOrspSmOityWLGLUE1VegLBMRz4WG5xnwmnjdi9PbG/gi1eczXXlnkiHE9SJkdxxNKmgJYsYtaHKS5knn7OmZUc6FBbNzCEjNcnqFiYs/rr/CPlZqXzswnmRDmVES4vyEImvHlGhXIN7vYg0icjOIPvuEBEVkekjnDtbRJ4VkT0isltE5oQqzlhU3dzFLm8H65YXRjoUAFKSk1jmdtma3CYsKqpbWDN3athHZ09ETnoKc6dnx1XdIpRXFvcDVwzfKCIe4DLg0CjnPgB8W1WXAKuBplAEGKs2bPMiEh1NUH5lxfnsrG+nf9CWWTWhU9vaTX3bcc4L89Q2p6O0yBVXPaJClixU9QWgNciu7wJfAIJ2nRGRpUCKqj7nPE+Xqlrl1KGqbKzysmbuVGbmZUQ6nBOWe/LpHRhiX2NnpEMxcayipgWA8+YHbZSIKsvcvtkNWrp6Ix3KpAhrzUJErgXqVbVqlMMWAW0i8riIbBWRb4tIcphCjHq7vB3UHDnGtWXuSIdyihVW5DZhsKm6hWnZaSyamRPpUMZU4h/J7Y2PukXYkoWIZAF3Al8Z49AU4K3AHcAqYB5w8wjPeZuIVIpIZXNz8yRGG702VnlJSRKuLA39ql8T4ZmayZSsVJv2w4SMqlJR08LaedMiNmPBRJQUxdfaFuG8spgPzAWqROQgUAxsEZHhn3p1wFZVrVHVAeC3wMpgT6iqd6tquaqWFxSEb4W4SBka8jVBXbiogCkRnv9muBPLrNqVhQmRN1q6aWjvYe286BqANxJXZipnTcuyZDFRqrpDVWeo6hxVnYMvKaxU1cZhh24GpoiI/9P/EmB3uOKMZq8eOoq3vScqBuIFs7w4n9cOd3LMllk1IXCyXhH9xW2/0qL4Gckdyq6zDwEVwGIRqRORj4xybLmI3AOgqoP4mqD+KCI7AAF+Fqo4Y8mGbV4yUpO4bGn0jVgF37QfQxo/l90mumyqaaEgN535BdFfr/ArdbuoO3qctu6+SIdyxkI2kaCq3jjG/jkB9yuBWwMePwcsD1VssWhgcIindjRw6dkzIzpX/2j8I7m317WHfdU+E99UlYrq2KlX+PmnK9/l7eCCBdHfg2s0NoI7RrxY3ULLsb6oGlsx3PScdIqnZLLN6hZmktUcOUZTZ2/M1Cv8Sp0idzw0RVmyiBEbtnnJTU/h4sXRXcgvK7ZlVs3kq6h26hUxdsU6JTsNd35mXDTNWrKIAT39gzy7q5HLS2eRkRrdQ07KPL422ngZiGSiw6aaFmbmpTN3euTnQpuoZc6a3LHOkkUM+PO+Jjp7B6K2F1SgsoC6hTGTQVXZVNPKeTFWr/ArdedxsKWbjp7+SIdyRixZxIANVV6m56Rxfgx0GSx1u0gSbAZaM2leb+riSFdvTHWZDVTqTFe+K8ZnoLVkEeW6egf4454mrlpWSEpy9P+6stNTWDgj1wbnmUnjH1+xNsbqFX4nkkWMr20xrk8fESkNdSAmuOd2N9I7MBQTTVB+ZR4XVbVttsyqmRQV1S0UuTKYPTUr0qGcluk56RS6MmK+R9R4v6r+REReEZFPiEh+SCMyp9iwzYs7P5OVs6dEOpRxK/Pkc7S7n7qjxyMdiolxQ0PKywdaWTs/NusVfiVFsV/kHleyUNW3AO8HPECliPxKRC4LaWSGo8f6+Ov+I1yzvDCqF3oZzl/ktrqFOVOvNXXSeqwv5rrMDrfM7aLmyDG6YngqnHE3gqvqfuBfgC8CFwHfF5G9IvKeUAWX6J7a2cDAkEb1QLxgFs/KJT0lycZbmDPmH18Rq/UKv1J3HqqwpyF2i9zjrVksF5HvAnvwTey3zlnF7hJ8ixmZENiwzcu8gmxKivIiHcqEpCYnUVKUZ0Vuc8YqqlsonpKJJ0brFX7LnCL3jhjuUj7eK4sfAluAMlX9pKpuAVBVL76rDTPJGtt7eOVgK9eWFcVkW22ZJ5+d9R0M2DKr5jT56xWx3gQFMCMvg4LcdHbGcI+o8SaLx1X1F6p6omIpIp8BUNVfhCSyBPfEdi+qxFQvqEArPPkc7x9kf1NXpEMxMWpPYwftx/tjdnzFcLE+knu8yeKmINtunsQ4zDAbqryUuvOYF0PTMQfyz0BrdQtzuk7MBxUnyaK0KI/Xm7o43jcY6VBOy6jJQkRuFJGNwDwR2RBwex5oCU+IiefAkWNsr2uP2asKgDnTssjLSLG6hTltm2pamDMti0JXZqRDmRSlbt96L7tjtMg91sIILwENwHTgfwK2dwLbQxVUonuiygvANctjN1mcWGbV1uQ2p2HQqVdcvaww0qFMmsCR3OeeFTvjpvxGTRaq+oaI1AHHVPUvYYopoakqG6q8rJ4zlaL82P5GtcKTz4//XM3xvkEy06J7tlwTXXZ7O+jsGYibJiiAQlcG07LTYrZH1Jg1C2eZ024RcYUhnoS3t7GT/U1drCuL/W9Uy4vzGRzSmJ8Tx4RfRc0RIPbWrxiNiFDidrHTG5vNUOMtcPcAO0TkXhH5vv8WysAS1YYqL8lJwlVxcPldVuz7fmEjuc1EVVS3MK8gmxl5GZEOZVItc+ex/3AnPf2xV+Qeb7J4EvhX4AXg1YDbiERkvYg0icjOIPvuEBEVkREXpRWRPBGpF5EfjjPGmKeqbKzycsGC6UzLSY90OGdsRl4GRa4MW9vCTMjA4BCbDx6N+VHbwZQWuRgYUvY1dkY6lAkbq8ANgKr+XEQygdmqum+cz30/vsF8DwRuFBEPcBlwaIzzvwEkVJ1ky6E26o4e57NvXxTpUCZNmSffekSZCdlR305X70BcNUH5+YvcO+rbKfPE1pys453uYx2wDfi983iFiGwY7RxVfQFoDbLru8AXgBHnrxaRc4GZwLPjiS9ebKzykpaSxOW+mJhxAAAgAElEQVQlMyMdyqRZXpzPGy3dHD3WF+lQTIzYVOP72IjHK4viKZm4MlNjso433maorwKrgTYAVd0GzJ3oi4nItUC9qlaNckwSvm66nx/H890mIpUiUtnc3DzRcKLKwOAQT2xv4JLFM8jNSI10OJOmzOP7JmVXF2a8KmpaWDgjh4Lc2G+KHU5EKHXnsTMGV80bb7IYUNXhqXBCK9uISBZwJ/CVMQ79BPCUqtaO9ZyqereqlqtqeUFBwUTCiTrrXzzAka5erl0Ru2MrglnmdiFia3Kb8ekfHKLyYGtcdZkdrtTtYl9jJ30DsTVv2rhqFsBOEfl7IFlEFgKfxjdgbyLm47saqXImxisGtojIalVtDDjuPOCtIvIJIAdIE5EuVf3SBF8vZtz34gG+9dReriiZxTuWxk8TFEBuRioLCnJs2g8zLtvr2ujuG4zLJii/0iIXfYNDvHa480QNIxaM98riU0AJ0As8BHQAn53IC6nqDlWdoapzVHUOUAesHJYoUNX3q+ps55g7gAfiOVE8UHGQr23czeUlM/nB358TE+tsT9TyYl+R25ZZNWOJ53qFn3+68libVHC8K+V1q+qdwKXA21T1TlXtGe0cEXkIqAAWi0idiHxklGPLReSeiQQeD36x6Q2+8rtdXLZ0Jj+4cSWpcZgoAFZ4XBzp6qO+zZZZNaOrqG7h7Fm5TM1Oi3QoITN7aha56SkxN135uJqhRGQVsB7IdR63A7eo6ohjLVT1xtGe07ly8N+vBG4Ncsz9+Lrgxp0HX36Df/3tTt6+ZAY/+vuVpKXEZ6IATnQR3F7XTvGU2F7ExoRO78AglW+08r5VsyMdSkglJQkl7jx2xFiRe7yfUPcCnwhoQvokcF/IoopzD71yiDt/s5NLzp7Bj94f34kC4OxZeaQl2zKrZnRVte309A/FdXHbr7TIxZ6GDvpjaHGw8X5KdarqX/0PVPVv+GaeNRP0yOZavvz4Di5eXMD/fmAl6SnxP8FeWkoSS4rybNoPM6qK6hZEYM3cqZEOJeSWFbvoGxji9RhaHGy8yeIVEfmpiFwsIheJyI+BP4vIShFZGcoA48mjlbV88fHtXLiogJ984NyESBR+K4pd7KhvZ3DIitwmuE01LSyZlUd+VvzWK/xKimKvyD3eZLECWATchW+A3hLgfHyD5/47JJHFmV+/WscXfr2dtyyYzt0fPJeM1MRJFOCrW3T3DVLdHDvfpEz49PQP8uqhownRBAUwb3o22WnJMZUsxjs31NtCHUg8+83WOu54rIoL5k/nZzeVJ1yigJNF7m21bSyamRvhaEy02Xqojb6BobicDyqYpCRhaVFeTE1XPt65oVwi8h3/1Boi8j+2vsX4/G5bPZ97pIrz5k1L2EQBMHdaNrnpKVbkNkFV1LSQJLAqAeoVfqVuF7u9HTHTNDveZqj1+Ara1zu3Dqw31Jg2Vnn5x4e3sXruVO75UHlCrxaXlCQs97hsjqjT1NzZG1M9ZyZqU3ULJUUuXJnxMy/aWEqLXBzvH6QmRppmx5ss5qvqXapa49y+BswLZWCx7sntDXz24W2Uz5nK+ptXkZU23plV4ldZcT57G2Jz4ZdIqjvazUXffp7vPvdapEMJieN9g2yrbUuYeoXfsuKT05XHgvEmi+Mi8hb/AxG5ALDhuCN4ekcDn/6/raycnc99lihOKPPkMzCk7G6InXbaaPCtp/bQ3TfII5W1cXl1seXQUfoGE6de4TdvejYZqUkxMwPteJPFx4EfichBETmIb1Gjj4Usqhj2+52NfOqhrZzjyee+D68mO90Shd8Kp8htdYvxe6n6CE/taGTN3Kkc6erjT3ubIh3SpKuobiE5SRKqXgGQkpzE0sK8mOkRNWaycNaXWKyqZcByYLmqnqOq20MeXYx5dlcjt/9qC8uLXdz34VXkWKI4xcy8DGbmpVuyGKeBwSG+vnE37vxM7r15FTNy03lk85gz98ecipoWlrldCfn3Uup2scvbzlAMFLnHTBaqOgTc7tzvUNXYuGYKsz/sPswnf7WFUreLn9+yOq4WMJpMZcX5trbFOD20uZa9jZ3cefUSctJTeO+5xTy/r4nDHaPO4RlTuvsGqKpti+tZZkdT6nZxrG+QAy3HIh3KmMbbDPWciNwhIh4Rmeq/hTSyGPLHPYf5hwdfZWmRiwc+YoliNGWefGqOHKO9uz/SoUS1tu4+/ufZfaydN5UrS2cBcF25hyGFx16ti3B0k6fy4FEGhjThitt+pTE0knu8yeIWfCvY/QWoDLglvOf3NvEPv9zCksI8HrhlNXmWKEblr1tsr7emqNF897nX6Djez13rSnAWC2Pu9GxWz53Ko5W1cbM2SEVNCylJQvlZUyIdSkQsnJlDWkpSXCWLpcCPgCpgG/ADfIshJbQ/72viY798lUWzcvjFLWsSqo/46fKvDGZ1i5Hta+zkly8f4v1rzmJJYd4p+24o93CwpZtXDrRGKLrJVVHdQpknP2E7gqQmJ7FkVm5M9Igab7L4Ob75oL6PL1EscbYlrBdea+a2X7zKgoIcfvmRNbiyLFGMhyszlXkF2VRZ3SIoVeVrG3eRk57CP1226E37r1pWSG56Cg9Xxn6hu6t3gB317aydl9gt2qVuFzu97VF/tTjeZLFYVW9V1eed223A4lAGFs3+tv8IH32gkvkFOTx465qEmCVzMq0ozmdbrS2zGswzuxp5qbqFz71jEVOCrBaXmZbMuhVFPLWjgY6e2K77bD7YyuCQct686ZEOJaJK3S46ewY41Nod6VBGNd5ksVVE1vofiMga4MXQhBTdXnr9CB/5+WbmTs/mwVvXBP2DNqMr8+TT3NlLYxz16pkMPf2DfPPJPSyemcvfrx55tbjryz309A+xscobxugm36bqFlKThXMTtF7h5y9yR/tI7vEmizXASwGD8iqAi0Rkh4gkzHiLiuoWbvn5ZuZM8yWKeF4nOJSWF1vdIpifvVBD3dHj3LVuKSmjrMdeVuxi8cxcHqmM7V5RFTUtnOOZktBzpgEsmpVDarJEfd1ivMniCmAucJFzmwtcBVwDrAt2goisF5EmEdkZZN8dIqIi8qbrTxFZISIVIrJLRLaLyA3j/WFCaVNNC7fcvxnPlCwe/OgapuWkRzqkmLWkMI/UZLG6RYCG9uP8+M/VXFEyi/MXjN4sIyJcv8pDVW0b+xpjc8HKjp5+dta3szZBu8wGSk9JZtHMXHZ5o/vvYVzJQlXfGO02wmn340sypxARD3AZcGiE87qBm1S1xDn//4lI/njiDJVXDrRyy/2bcU/J5FcfXct0SxRnJCM1mSWFeXZlEeDfn9rLoCp3Xr1kXMe/+xw3qcnCwzE6ovuVmlaGlIQvbvstc/tWkozmOt54rywmTFVfAIL17/su8AUg6Luiqq+p6n7nvhdoAgpCFedYKg+2cvN9r1DoyuBXH11DQa4lisngH8kdC9MchNrmg61sqPLysQvn4ZmaNa5zpman8Y6ls/jN1jp6B2JvFt9NNS2kpSSxcnZi1yv8Stwu2rr7qW+L3vlZQ5YsghGRa4F6Va0a5/GrgTSgeoT9t/kXZGpubp7ESH1efaOVD61/hVl5GTz00bXMyM2Y9NdIVMuLXXT1DlBzJDbm8g+VwSHlqxt2UejK4B8unj+hc68rL+Zodz9/2B17kwtW1LSwcnZ+wi4GNtwyd/SP5A5bshCRLOBO4CvjPL4Q+AXwYWd+qjdR1btVtVxVywsKJvfiY8uho3xo/WZm5GXw0G1rmZFniWIynZyBNnr/OMLh0cpadnk7+NKVZ094Kvu3LiygyJXBIzE25qKtu4/dDR0J32U20NmzcklOiu4idzivLObjK4xXOT2qioEtIjJr+IEikgc8CfyLqm4KY4yAb53oD937CtNz0njoo2uZaYli0s0ryCEnPSWhV85rP97Pt5/Zx6o5U7i2rGjC5ycnCe89t5gX9jfjjeLmi+FePtCKKgk7H1QwGanJLJyRE9XdZ8OWLFR1h6rOUNU5qjoHqANWqmpj4HEikgb8BnhAVR8NV3x+2+va+OC9LzM1J42HblvLLJclilBIThKWuV0JXeT+/h/309rdd8r8TxN1XbkHjbHJBTfVtJCekkSZxxXpUKJKqdvFzigucocsWYjIQ/jGYywWkToR+cgox5aLyD3Ow+uBC4GbRWSbc1sRqjgD7ahr5wP3vEx+VioPfXQtha7McLxswlrucbG7oSMmC7Rn6vWmTn7+0kHet8pzYr6s0+GZmsUFC6bxSGVtzHQWqKhuoXzOFNJTrF4RaJnbRcuxvqgdrBrK3lA3qmqhqqaqarGq3jts/xxVPeLcr1TVW537v3TOWRFw2xaqOP121rfzgXtfJi/TlyiK8i1RhNqK4nz6B5W9DbE5VuB0qSpff2IPmWnJ3PGOM5815/pyD3VHj1NR0zIJ0YVW67E+9jZ2JtwSquNR6vZNGhmtdYuw9oaKVru8vkSRk57CQx9dS/GU8XVfNGemzF/kTrC6xR/3NPHCa8189u2LJmVw5+Uls8jLSImJQvfLTkKzesWbLSnMI0mid9qPhE8Wb7Qc4wP3vExWajL/d9vacfdzN2eu0JVBQW462xKobtE7MMg3ntzN/IJsbjrvrEl5zozUZN51jpundzZG/aJSFTUtZKYms7w4ouNso1JWWgrzC3LYZckiOhXlZ3JtWRH/d9t5lijCTEQoK06sIvf6vx3kjZZuvrKuhNRR5n+aqOvLPfQNDPG7qvpJe85Q2FTjq1dM5s8eT/wjuaNRwv/GUpOT+No7S5k9zRJFJJQV+5ZZjfXptsejqaOHH/5pP29fMoOLFk3uuKBSt4uSoryonv7jSFcvrx3usiaoUZS4XTR19tIUhUXuhE8WJrLKPPmows4EmFTwP36/l/5B5V+uXhqS57++3MMub0fUjgLe5K9XWHF7RCdGckfhpIKWLExE+acr3xbnRe6th47y+JZ6bnnLXOZMzw7Ja7xrhZu0lCQejdJCd0V1C9lpySc+EM2bLS3KQyQ6e0RZsjARlZ+VxpxpWXFdtxgaUr66cTczctO5/ZIFIXsdV1YqV5TM4rfbvPT0R9/YlU01LayaO3XUtToSXU56CnOnZ0dl3cJ+aybiyjy+GWjj1eNb66mqbeOLV5xNTvrE5n+aqBtWeWg/3s8zuxrHPjiMmjp6qG4+Zk1Q41Ba5IrKHlGWLEzElRXn09Dew+EoLOqdqa7eAf7z93tZ4cnn3ee4Q/56582bRvGUzKgbc1Fh4yvGbZnbhbe9h5au3kiHcgpLFibiTgzOi8OmqB/8aT/Nnb189doSkpJOb/6niUhKEq4718OLr7dQ29od8tcbr001LeRmpFBSZPWKsZT4R3J7o6tuYcnCRFxJUR4pSRJ3I7kPHDnG+r8d4L3nFp+Ykj0c3ltejAg8GkWTC1ZUt7Bm7lSSw5AwY50/oUZbrzZLFibiMlKTWTwrN+7qFt98YjdpyUl84Yozn/9pItz5mbx1YQGPVdYyGAWTCza0H+dgSzdrrV4xLq7MVM6almXJwphgyjz5VNW2xczMqWP5874m/ri3iU9dujAiKyzeUO7B297D314/EvbXHs4/vsKSxfiVFkXfSG5LFiYqrCjOp6NngIMtxyIdyhnrGxji60/sZs60LD58wZyIxPD2pTOYkpXKI1EworuiugVXZipLC/MiHUrMKHW7qDt6nLbuvkiHcoIlCxMVljsL4cRD3eKBioPUNB/jX69ZGrE1G9JTfJMLPru7kdZjkf3Aqajx1SvCUeCPF/7pyndFUZHbkoWJCgtn5JKVlhzza3I3d/byvT/s56JFBVxy9oyIxnLDKg/9g8pvt0ZucsG6o93Uth63LrMTVOoUuaOpKcqShYkKyUlCqdsV81cW//PsPo73D/Kv1yw97aVSJ8vZs/IoK3bxSGVtxJbq3FTTCli9YqKmZKfhzs+MqiK3JQsTNVZ48tnl7aBvYCjSoZyWHXXtPFxZy83nz2HBjJxIhwPA9as87G3sjFhPs4rqFqZkpbJ4Zm5EXj+WLXPW5I4WoVyDe72INInIziD77hARFZHpI5z7IRHZ79w+FKoYTXRZXuyib2CIfY2xt8yqqvK1jbuYlp3Gp9++MNLhnLCurIiM1CQejsCIblVlU00La+dNs3rFaSh153GwpTtqpu8P5ZXF/cAVwzeKiAe4DDgU7CQRmQrcBawBVgN3iciU0IVpokVZcewus7qhykvlG0f5/OWLyctIjXQ4J+RlpHJVaSEbt3k53hfeyQVrW49T32b1itNV6szOuytKZqANWbJQ1ReA1iC7vgt8ARipEfVy4DlVbVXVo8BzBEk6Jv4UT8lkWnZazE370d03wL8/tZdlbhfXneuJdDhvcv0qD529Azy9syGsr2vrV5yZE8kiSta2CGvNQkSuBepVtWqUw9xA4DVznbMt2PPdJiKVIlLZ3Nw8iZGaSBAR3+C8GLuy+PHz1TR29PDVa5dGZXPLmrlTmTMtK+yr6FXUtDA9Jy1q6jexZnpOOoWujKjpERW2ZCEiWcCdwFfGOjTItqBXIap6t6qWq2p5QcHkLlNpImN5sYv9TV109Q5EOpRxOdTSzd1/reFdK4o496ypkQ4nKBHhunIPLx9o5eCR8Ax6VFXffFDzpkW8V1gsKymKniJ3OK8s5gNzgSoROQgUA1tEZNaw4+qAwGv5YsAblghNxJ1YZjVK/kDG8m9P7SZZhC9duSTSoYzqvecWkySEberygy3dNHb0WBPUGVrmdlFz5FhUfHkKW7JQ1R2qOkNV56jqHHxJYaWqDl+l5RngHSIyxSlsv8PZZhLAiSJ3DNQtXnz9CM/sOswn3zafWa7wz/80ETPzMrh48Qwee7WOgcHQd02uqLb1KyZDqTsPVdjTEPkidyi7zj4EVACLRaRORD4yyrHlInIPgKq2At8ANju3rzvbTAKYmp3G7KlZUV+3GBgc4msbd+GZmsmtb50X6XDG5fpyD02dvbywP/T1vU01LczITWdeiNYbTxT+9cp3RMGMzCFb41FVbxxj/5yA+5XArQGP1wPrQxWbiW7Li11sPRTdyeKXm97gtcNd/OQD55KRGpn5nybq0iUzmJ6TxsOba7nk7Jkhex1VpaKmhfOsXnHGZuRlUJCbzs4o6BFlI7hN1Fnhyae+7TjNndG1rKRf67E+vvPca1ywYBqXl4TuQ3eypSYn8Z6VxfxxT1NI39vq5mM0d/ZaE9QkiZaR3JYsTNTxL7O6PUqbor7z3D6O9Q1y17qSmPvmfH15MQNDym+2hm4VvQobXzGpSovyeL2pK+yDKoezZGGiTklRHslJEpVF7t3eDn718iE+uPYsFsXgfEcLZuSycnY+D28O3eSCm6pbKHRlcNa0rJA8f6IpdbsYUtgd4SK3JQsTdbLSUlg0M5e/7D/Czvp2egci+43Kzz//kyszlX98+6JIh3Pabljlobr5GFtCUBcKnA8q1q66olW0jOQOWYHbmDNx4cLp/PSFGq75wd9ISRIWzMhhaVEeSwvzKClysbQwD1dWeOdgempHIy8faOWb7yoN+2tPpquXF/G1jbt5ZHMt5541udOu7W/qouVYnzVBTaJCVwbTstMi3iPKkoWJSl+68mxuWOVhd0MHu70d7G7o4K/7j/D4lpML+bjzM1lalEeJk0SWFuXhzs8MyTfa432DfOupPSwpzOPG1bMn/fnDKSc9hWuWF/LEdi9fWbeU7PTJ+xiw8RWTT0QocbvYGeFV8yxZmKgkIswryGFeQQ7XLC86sb2ps4c9DZ0nEsgubzt/2HMYf/O7f63nE1ch7jzmF+SQmnxmLa4/faGa+rbjfOf6MpKjcP6nibphlYdHKut4cnsD16+avMkPK6pbcOdn4plq9YrJtMydx0//UkNP/2DEumpbsjAxZUZuBjNyM7ho0cm5wLr7Btjb6Esgu5wk8stNb9DrLKKUlpzEolk5J5uwivI4e1YuueOcSry+7Tg/+Us1Vy8vZE2cNK+snD2FeQXZPFxZO2nJYmhIeflAC5cuiZ3uxLGitMjFwJCyr7HzRG/BcLNkYWJeVloKK2dPYeXsk+3vA4NDHGw55kseTgL5w54mHqk82WX0rGlZpzRhLS10MTMv/U3NWN96ag+q8OUrzw7bzxRqIsIN5R7+/em9vN7UNSkzw+473MnR7n5bQjUE/EXuHfXtliyMmUwpyUksmJHLghm5vHOFb4Z7VaWps5dd3vYTCWS3t4OndpycnmxadtqJJqylRXkAPLm9gc9cupDiKfHVtPKelcV8+5l9PFpZy5evOvOJEK1eETrFUzJxZaZGtEeUJQuTMESEmXkZzMzLOGW6i86e/hPNWLu9HexqaOe+Fw/S50y4V+TK4OMXzY9U2CFTkJvOJWfP4Ndb6rjj8sVnXNepqGlh9tQs3PmZkxSh8RMRSt157IzgqnmWLEzCy81IZdWcqayac3I9iv7BIaqbu9jT0MHSQheZabEx/9NE3bDKw7O7D/OnvU1cXjJ8tYDxGxxSXq5p4crSwkmMzgQqdbu4728H6RsYIi0l/EPkbFCeMUGkJidx9qw83n1OMYtnxd5I7fG6aFEBM3LTeeQMV9Hb09BBR8+ANUGFUGmRi77BIV473BmR17dkYUwCS0lO4u/OLeb5fU0c7ug57efxr7dtxe3Q8U9XHqlJBS1ZGJPgri/3MKTw6y2nP7lgRXULc6dnR/0iULFs9tQsctNTIjZduSULYxLc3OnZrJ47lUcr605rcsGBwSFeOdBqVxUhlpQklLjz2BGhIrclC2MMN5R7OHDkGK8cmPiilLu8HXT2Wr0iHEqLXOxp6KA/DEvjDmfJwhjDlctmkZOewsOVEy90n6xXTB3jSHOmlhW76BsY4vWmrrC/tiULYwxZaSmsKyviqR0NdPb0T+jcipoW5hdkMyPX6hWhVlIUuSJ3yJKFiKwXkSYR2Rmw7Rsisl1EtonIsyJSNMK5/yUiu0Rkj4h8X2xifGNC7oZVHnr6h9hY1TDuc/oHh9h8oNWaoMJk3vRsstOS4ytZAPcDVwzb9m1VXa6qK4AngK8MP0lEzgcuAJYDpcAq4KIQxmmMAcqKXSyemTuhpqgd9e0c6xvkvHnTQxiZ8UtKEpYW5UVkuvKQJQtVfQFoHbYt8CfMBoJ1vVAgA0gD0oFU4HCIwjTGOESE61d5qKptY1/j+AZ++esVa6xeETalbhe7vR0MDoVmWdyRhL1mISL/JiK1wPsJcmWhqhXA80CDc3tGVfeM8Fy3iUiliFQ2NzeHMmxjEsK7z3GTmiw8PM4R3RXVLSyamcP0nPQQR2b8SotcHO8fpKY5vEXusCcLVb1TVT3Ag8Dtw/eLyAJgCVAMuIFLROTCEZ7rblUtV9XygoKCYIcYYyZganYaly2dyW+21tE3MHr3zL6BISoPHrUlVMNsWfHJ6crDKZK9oX4F/F2Q7e8GNqlql6p2AU8Da8MamTEJ7PpyD0e7+/nDntFbf7fXtXG8f9CK22E2b3o2GalJYZ+BNqzJQkQWBjy8Ftgb5LBDwEUikiIiqfiK20GboYwxk++tCwsocmWM2RRVUd2CCKyZa8kinFKSk1hamBf2HlGh7Dr7EFABLBaROhH5CPAfIrJTRLYD7wA+4xxbLiL3OKc+BlQDO4AqoEpVN4YqTmPMqZKThPeeW8wL+5vxth0f8bhNB1o4e1YeU7LTwhidAV+Re5e3naEwFrlD2RvqRlUtVNVUVS1W1XtV9e9UtdTpPrtOVeudYytV9Vbn/qCqfkxVl6jqUlX9p1DFaIwJ7r3nelCFx14NPrlg78AglQeP2qjtCCl1uzjWN8iBlmNhe00bwW2MeZPZ07I4f/40Hn21Nui3122H2ugdGLLidoSURmAktyULY0xQN6zyUNt6/MRYikAVNVaviKSFM3NIS0myZGGMibzLS2aRlxF8csFNNS2UFOXhykqNQGQmNTmJJbNyw9ojypKFMSaojNRk3nWOm6d3NtLefXJywZ7+QbYcarMmqAgrcbvY6W0/rTVIToclC2PMiK4v99A3MMTvqupPbNty6Ch9A0O22FGELXO76OwZ4FBrd1hez5KFMWZEpW4XSwvzeCSgKWpTdQtJAqvmWk+oSPIXucM1ktuShTFmVDes8rCzvoNdztrPFTUtLHO7yMuwekUkLZqVQ2qyhK1uYcnCGDOqd61wk5aSxCObazneN8i22jbW2hQfEZeeksyimbknknioWbIwxozKlZXKFSWz+O02Ly9VH6F/UK24HSWWuV3sqA9PkduShTFmTNeXe2g/3s+3ntpDcpJQPsfqFdGgxO2irbuf+lGmZZksliyMMWM6f/40iqdkUt18jOXFLnLSUyIdksF3ZQHhGcltycIYM6akJOG6cz0A1gQVRc6elUtyUniK3JYsjDHjcsMqD4tn5nL18sJIh2IcGanJLJyRE5bus3YtaYwZl1muDJ75x6CLVpoIumZ5Icf7B0P+OpYsjDEmht1+ycKxD5oE1gxljDFmTJYsjDHGjMmShTHGmDGFcg3u9SLSJCI7A7Z9Q0S2i8g2EXlWRIpGOHe2s3+PiOwWkTmhitMYY8zYQnllcT9wxbBt33bW314BPAF8ZYRzH3COXQKsBppCFqUxxpgxhSxZqOoLQOuwbYEjR7KBN01oIiJLgRRVfc45p0tVwzNhuzHGmKDC3nVWRP4NuAloB94W5JBFQJuIPA7MBf4AfElVQ9+R2BhjTFBhL3Cr6p2q6gEeBG4PckgK8FbgDmAVMA+4OdhzichtIlIpIpXNzc0hitgYY4yEcmpbpzD9hKqWBtl3FvDk8H0ishb4D1W92Hn8QWCtqn5yjNdqBt44g3CnA0fO4Px4Yu/Fqez9OJW9HyfFw3txlqoWjHVQWJuhRGShqu53Hl4L7A1y2GZgiogUqGozcAlQOdZzj+eHHSO2SlUtP5PniBf2XpzK3o9T2ftxUiK9FyFLFiLyEBcYYHoAAAP8SURBVHAxMF1E6oC7gKtEZDEwhO8q4OPOseXAx1X1VlUdFJE7gD+KiACvAj8LVZzGGGPGFrJkoao3Btl87wjHVgK3Bjx+DlgeotCMMcZMkI3gPunuSAcQRey9OJW9H6ey9+OkhHkvQlrgNsYYEx/sysIYY8yYLFkYY4wZU8InCxG5QkT2icjrIvKlSMcTSSLiEZHnnQkcd4nIZyIdU6SJSLKIbBWRJyIdS6SJSL6IPCYie53/I+dFOqZIEpF/dP5OdorIQyKSEemYQimhk4WIJAM/Aq4ElgI3OnNTJaoB4HPOBI5rgU8m+PsB8BlgT6SDiBLfA36vqmcDZSTw+yIibuDTQLkzsDgZeF9kowqthE4W+Ga0fV1Va1S1D/g/4J0RjiliVLVBVbc49zvxfRi4IxtV5IhIMXA1cE+kY4k0EckDLsTp/q6qfaraFtmoIi4FyBSRFCAL8EY4npBK9GThBmoDHteRwB+OgZypWs4BXo5sJBH1/4Av4BtEmujmAc3AfU6z3D0ikh3poCJFVeuB/wYOAQ1Au6o+G9moQivRk4UE2ZbwfYlFJAf4NfDZYdPKJwwRuQZoUtVXIx1LlEgBVgL/q6rnAMeAhK3xicgUfK0Qc4EiIFtEPhDZqEIr0ZNFHeAJeFxMnF9KjkVEUvEligdV9fFIxxNBFwDXishBfM2Tl4jILyMbUkTVAXWq6r/SfAxf8khUbwcOqGqzqvYDjwPnRzimkEr0ZLEZWCgic0UkDV+BakOEY4oYZy6ue4E9qvqdSMcTSar6ZVUtVtU5+P5f/ElV4/qb42hUtRGodeZ2A7gU2B3BkCLtELBWRLKcv5tLifOCf9gXP4omqjogIrcDz+DrzbBeVXdFOKxIugD4ILBDRLY52/5ZVZ+KYEwmenwKeND5YlUDfDjC8USMqr4sIo8BW/D1ItxKnE/9YdN9GGOMGVOiN0MZY4wZB0sWxhhjxmTJwhhjzJgsWRhjjBmTJQtjjDFjsmRhzCQQkU87M7E+OML+m0XkhyPs6wptdMacuYQeZ2HMJPoEcKWqHoh0IMaEgiULY86QiPwE30R7G0TkfuCtzuNu4DZV3T7s+LnAr/D9/f0+vNEac3qsGcqYM6SqH8c3p9jbgDnAVlVdDvwz8ECQU76Hb0K+VUBjuOI05kxYsjBmcr0F+AWAqv4JmCYirmHHXAA85Nz/RRhjM+a0WbIwZnKNd9p7m2fHxBRLFsZMrheA9wOIyMXAkSBrgrzIySU43x++0Iw5fZYsjJlcXwXKRWQ78B/Ah4Ic8xl865tvBoY3URkTlWzWWfP/268DGQAAAABh/tYhJPBLtACWswBgiQUASywAWGIBwBILAJZYALDEAoAV9igouW2/TIMAAAAASUVORK5CYII=\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "nuisance_diagnostic(dmlate, 'model_T_X', 'predict', lambda ns: ns.predict(X))\n",
    "nuisance_diagnostic(dmlate, 'model_Y_X', 'predict', lambda ns: ns.predict(X))\n",
    "nuisance_diagnostic(dmlate, 'model_Z_X', 'predict', lambda ns: ns.predict(X))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 994,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "No handles with labels found to put in legend.\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAYIAAAEICAYAAABS0fM3AAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADl0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uIDIuMi4zLCBodHRwOi8vbWF0cGxvdGxpYi5vcmcvIxREBQAAIABJREFUeJzt3XmYXAWd7vHvr6q3dKeXpLuzdnbIRiAEmpAIQgBBQAR1UAFxAJlhxLkiyr1oZtT7OF7nzijjxQ28gIqgA14BgYFhG2STPTsJgRCy0Vk7nX3p9FK/+0edDpWmN3qpU1Xn/Tycp+qcOlXn7TxFv312c3dERCS6YmEHEBGRcKkIREQiTkUgIhJxKgIRkYhTEYiIRJyKQEQk4lQEIiIRpyIQEYk4FYFkFDPblzIkzOxgyvgXunjfv5nZE+2m3Wxmj3Qy/5Vm1hp87h4zW2pmF6S8Pt7M3MwWtXtflZk1mdm6lGmnmtlLZrbbzHaY2YtmdlIHy0kdRnWSy83sqB79Y4n0ExWBZBR3H9w2ABuAT6ZM+30Xb/0OMMnMrgIws7nAFcCXu3jPy8FyKoBbgHvNrKLdPCVmNiNl/DJgbduImZUBjwA/A4YCo4HvAYfaL6fdsKmLXCJppSKQnODuB4C/AW4ys/HAr4FvuXtdD96bAO4GSoCj2718N8lCafPXwF0p45ODz7jH3Vvd/aC7P+nuy3r7s3TEzGJm9m0zW29m28zsLjMrD14rMrPfmVmDme0ys9fNbHjw2pVmtsbM9prZ2q7WqiS6VASSM9z9WeA+YAGwFbitJ+8zszhwFdAMrG/38u+AS8wsbmbTgFLg1ZTXVwGtZvZbMzvPzIb07afo1JXBcAYwERgM/Dx47QqgHBgDVJJcCzpoZiXAT4Hz3L0U+AiwZIDySRZTEUiueYHkL8Pfe/dXVJxjZruARuAm4HJ339ZunjrgbeBjJH/hpq4N4O57gFMBB24H6s3s4ba/yFOXkzK824uf6wvAj919jbvvA+aTLKg8kgVWCRwVrJUsDHIBJIAZZjbI3Te7+4peLFtynIpAcoaZVZL8hX4z8E8dbO9v7xV3rwCGAA8DH+1kvrtI/jV+Kck1hCO4+0p3v9Lda4AZwKggwxHLSRkmfZifKzCKI9dW1gN5wHCSm6+eILmPY5OZ/dDM8t19P/B5kmsIm83sUTOb2otlS45TEUguuRl43N2/DjxPshS6FfyF/RXgi2Y2q4NZ7gc+Aaxx9/abjtp/1lvAnSQLoT9tAsaljI8FWoCt7t7s7t9z9+kkN/9cQHJfBu7+hLufDYwE3iK51iJyBBWB5AQzOx84G/hGMOmrwKfM7IyevN/dG4A7gO928Np+4EySO6PbL3eqmd1gZjXB+BiSaw6v9ObnCBQEO4DbhjhwD/B1M5tgZoOBfwb+4O4tZnaGmR0bzLeH5KaiVjMbbmYXBvsKDgH7gNY+5JIcpSKQrGdmpcAvgevcfQdAsK3/BuB2MxvUw4+6GTjfzI5r/4K7L3D3jrbt7wVOBl41s/0kC2B5sOw2czs4j+CkLnKsAA6mDFeRPArqbpJrOmtJ7tf4ajD/CJI7yfcAK4HnSG7CigU5NgE7gNNJrvmIHMF0hzIRkWjTGoGISMSpCCRrmNljHWxi2Wdm/xB2NpFspk1DIiIRlzdQH2xmvyZ5GNs2d58RTPsR8EmgCXgXuMrdd3X3WVVVVT5+/PiBiioikpMWLly43d2ru5tvwNYIzOw0koer3ZVSBOcAfw4OeftXAHf/ZnefVVtb6wsWLBiQnCIiucrMFrp7bXfzDdg+And/nuQha6nTnnT3lmD0FaBmoJYvIiI9E+bO4i8Bj3X2opldY2YLzGxBfX19GmOJiERLKEVgZv9I8vT4Tq8v7+63uXutu9dWV3e7iUtERHppwHYWd8bMriC5E/msHlwdUkREgObmZurq6mhsbPzAa0VFRdTU1JCfn9+rz05rEZjZucA3gdODG4mIiEgP1NXVUVpayvjx4zGzw9PdnYaGBurq6pgwYUKvPnvANg2Z2T3Ay8AUM6szs6tJ3kijFHjKzJaY2S8HavkiIrmksbGRysrKI0oAwMyorKzscE2hpwZsjcDdL+1g8q8GankiIrmufQl0N72ncvoSE8+8tY1bnl0ddgwRkYyW00Xw4urt3Pxf79DUkgg7iohIxsrpIjhuTAVNLQlWbd0bdhQRkT7r7EDLvh6AmdtFMLocgDc27g45iYhI3xQVFdHQ0PCBX/ptRw0VFRX1+rPTfh5BOo2rLKasKI9ldbu4dPbYsOOIiPRaTU0NdXV1dHSlhbbzCHorp4vAzDiupoJldVojEJHslp+f3+vzBLqT05uGAI6rKeftLXtpbNY9u0VEOhKJImhJOCs37wk7iohIRopAEVQAaPOQiEgncr4IRpYXUTW4QEUgItKJnC+C93cYd3tHTBGRSMr5IgA4dnQ5q+v3sf9QS/czi4hETCSK4LiactxhuU4sExH5gEgUwbE1OsNYRKQzkSiCYaVFjCwvYql2GIuIfEAkigCSm4fe0A5jEZEPiFARVLCu4QC7DzSHHUVEJKNEqAi0n0BEpCORKYJjg0tSL9uozUMiIqkiUwQVxQWMqyxm2XtaIxARSRWZIoDkWoE2DYmIHClSRTCzpoKNuw6yfd+hsKOIiGSMSBVB24lluu6QiMj7olUEo8uJGSzZoCIQEWkTqSIoKcxj2sgyFm7YGXYUEZGMEakiADhx3BAWb9hFS2si7CgiIhkhkkVwoKmVt7bsDTuKiEhGiGQRACxcr81DIiIQwSIYXTGI4WWFKgIRkcCAFYGZ/drMtpnZ8pRpQ83sKTN7J3gcMlDL7yIXteOGqghERAIDuUZwJ3Buu2nfAp5296OBp4PxtDth3BA27jrIlt2NYSxeRCSjDFgRuPvzwI52ky8Cfhs8/y3wqYFafldqtZ9AROSwdO8jGO7umwGCx2FpXj4A00eVUZQfY8H69j0lIhI9Gbuz2MyuMbMFZragvr6+Xz87Px5jZk0Fi7RGICKS9iLYamYjAYLHbZ3N6O63uXutu9dWV1f3e5ATxw1hxaY9HGxq7ffPFhHJJukugoeBK4LnVwAPpXn5h504bggtCWepLkAnIhE3kIeP3gO8DEwxszozuxr4F+BsM3sHODsYD8UJY7XDWEQEIG+gPtjdL+3kpbMGapkfxpCSAiZVl6gIRCTyMnZncTrUjhvKog07SSQ87CgiIqGJdBGcOG4Iuw40s2b7/rCjiIiEJtpFML5tP4HOJxCR6Ip0EUysKmFIcb72E4hIpEW6CMyME8cNYcE6FYGIRFekiwBg9oShrNm+n617dAE6EYmmyBfB3IlVALyypiHkJCIi4Yh8EUwfVUZZUR4vv6siEJFoinwRxGPG7AmVvKw1AhGJqMgXAcDcSZWsbzjApl0Hw44iIpJ2KgJg7sRKAG0eEpFIUhEAU0eUMqQ4X5uHRCSSVARALGacPKFSawQiEkkqgsDcSZVs3HWQ93YcCDuKiEhaqQgCcydpP4GIRJOKIHD0sMFUDS7gpXe3hx1FRCStVAQBM+PkicnzCdx1fwIRiQ4VQYqPTKpk655DrNX9CUQkQlQEKQ6fT6DDSEUkQlQEKSZUlTC8rFA7jEUkUlQEKcyMuRMreWXNDu0nEJHIUBG0M3dSJdv3HWL1tn1hRxERSQsVQTsfmZS8P8FfVuswUhGJBhVBO2OGFjOxqoRn364PO4qISFqoCDpw2uRqXlnTQGNza9hRREQGnIqgA/OmVHOoJaHbV4pIJKgIOjBnYiWFeTFtHhKRSFARdKAoP86ciZU8v0pFICK5T0XQiXlTqlmzfT8bGnRZahHJbSqCTsybMgyAZ1dtCzmJiMjACqUIzOzrZrbCzJab2T1mVhRGjq6Mryxm7NBintN+AhHJcWkvAjMbDVwH1Lr7DCAOXJLuHN0xM+ZNqeald3UYqYjktrA2DeUBg8wsDygGNoWUo0vzplRzsLmV19ftCDuKiMiASXsRuPtG4CZgA7AZ2O3uT7afz8yuMbMFZragvj6czTNzJlZSENdhpCKS28LYNDQEuAiYAIwCSszs8vbzuftt7l7r7rXV1dXpjglAcUEeJ08cynM6jFREclgYm4Y+Bqx193p3bwYeAD4SQo4eOX1yNau37aNupw4jFZHcFEYRbADmmFmxmRlwFrAyhBw9Mm9Kcm1Em4dEJFd1WwRmdoqZlQTPLzezH5vZuN4u0N1fBe4DFgFvBBlu6+3nDbRJ1YMZXTFIRSAiOasnawS3AgfMbCZwI7AeuKsvC3X3/+nuU919hrt/0d0P9eXzBpKZcebUYby4ersOIxWRnNSTImjx5H0bLwJ+4u4/AUoHNlZmOeeY4RxsbtW1h0QkJ/WkCPaa2XzgcuBRM4sD+QMbK7PMmVhJWVEeT765NewoIiL9ridF8HngEHC1u28BRgM/GtBUGSY/HuOsacN5euVWWloTYccREelXPVojILlJ6AUzmwwcD9wzsLEyzznTh7PzQDOv6SxjEckxPSmC54HC4BpBTwNXAXcOZKhMdPqUagrzYjy5QpuHRCS39KQIzN0PAJ8BfubunwaOGdhYmae4II+PHl3NU29uJbnvXEQkN/SoCMxsLvAF4NFgWnzgImWuc44ZzsZdB1m+cU/YUURE+k1PiuB6YD7wJ3dfYWYTgWcGNlZm+ti04cQMnnxzS9hRRET6TbdF4O7PufuFwC1mNtjd17j7dWnIlnGGlhQwe8JQnlihIhCR3NGTS0wca2aLgeXAm2a20Mwit4+gzTnTR7Bq6z7Wbt8fdhQRkX7Rk01D/xf4hruPc/exwA3A7QMbK3Odc8xwAJ7UWoGI5IieFEGJux/eJ+DuzwIlA5Yow9UMKWbG6DJtHhKRnNGTIlhjZt8xs/HB8G1g7UAHy2TnTB/B4vd2sW1PY9hRRET6rCdF8CWgmuQNZB4AqoArBzBTxjt3xgjc4bHlWisQkezXk6OGdrr7de5+QjBcD3w7Ddky1uThpUwdUcpDSzaGHUVEpM96e4eyz/Vriix00fGjWbRhFxsadAtLEcluvS0C69cUWeiTM0cC8PBSrRWISHbrtAjMbGgnQyUqAmqGFHPS+CE8uGSTrj0kIlktr4vXFgJOx7/0mwYmTna56PjRfPvB5azcvJfpo8rCjiMi0iudrhG4+wR3nxg8th8mpjNkpjr/2JHkxUw7jUUkq/V2H4GQvPbQ6ZOreXjpJhIJbR4SkeykIuijC48fxebdjbyuO5eJSJZSEfTR2dOHU1wQ58Elm8KOIiLSK10dNXRmyvMJ7V77zECGyibFBXmcM304//nGZppadGN7Eck+Xa0R3JTy/P52r0X6zOL2Ljp+NLsPNvPcqvqwo4iIfGhdFYF18ryj8Ug79egqhpYU8KCOHhKRLNRVEXgnzzsaj7T8eIwLZ47iqRVb2blfp1iISHbpqggmmtnDZvYfKc/bxid08b5I+vxJY2hqTfCnxVorEJHs0tWZxRelPL+p3WvtxyNv2sgyZo6p4N7XN3DVKeMx09YzEckOXZ1Z/FzqALwE7AFWBuO9ZmYVZnafmb1lZivNbG5fPi9TXHLSGFZt3cfi93aFHUVEpMe6Onz0l203qTezcmApcBew2Mwu7eNyfwI87u5TgZnAyj5+Xkb45MxRFBfEufe1DWFHERHpsa72EXzU3VcEz68CVrn7scCJwI29XaCZlQGnAb8CcPcmd8+JP6EHF+bxyeNG8R9LN7O3sTnsOCIiPdJVEaQe/nI28CCAu/f1/owTgXrgN2a22MzuMLOS9jOZ2TVmtsDMFtTXZ8/x+ZfMHsPB5lb+Y+nmsKOIiPRIV0Wwy8wuMLNZwCnA4wBmlgcM6sMy84ATgFvdfRawH/hW+5nc/TZ3r3X32urq6j4sLr2OH1PBlOGl/OF1bR4SkezQVRH8HfDfgN8A16esCZwFPNqHZdYBde7+ajB+H8liyAlmxiWzx7C0bjdvbtoTdhwRkW51ddTQKnc/192Pd/c7U6Y/4e439HaBQaG8Z2ZTgklnAW/29vMy0adnjaYgL6a1AhHJCp2eR2BmP+3qje5+XR+W+1Xg92ZWAKwhuTM6Z1QUF3DejBH8afFG5p8/jaL8eNiRREQ61dUJZV8GlgP/D9hEP15fyN2XALX99XmZ6JKTxvLQkk08vGQTnztpTNhxREQ61VURjAQ+C3weaAH+ANzv7jvTESzbzZk4lKkjSvn1i2v5bG2NzjQWkYzV1T6CBnf/pbufAVwJVAArzOyL6QqXzcyML506gbe27OXldxvCjiMi0qlu71BmZicA1wOXA48BCwc6VK64cOYoqgYX8Ku/rA07iohIp7q6xMT3zGwh8A3gOaDW3a9295w6wmcgFeXH+cLJ43j6rW2sqd8XdhwRkQ51tUbwHaCc5LWA/jewyMyWmdkbZrYsLelywOVzxlEQj3HnS+vCjiIi0qGudhbrngP9oLq0kAuPH8UfF9Rxw9lTKC/ODzuSiMgRutpZvL6jgeSZwaemL2L2+9IpEzjY3Mq9OsFMRDJQV/sIysxsvpn93MzOsaSvkjwB7HPpi5j9po8qY+7ESn770jpaWhNhxxEROUJX+wjuBqYAbwB/AzwJXAxc5O4XdfE+6cDVp05g0+5GHl/R14u3ioj0r672EUwM7j+Amd0BbAfGuvvetCTLMWdOHcb4ymJue34Nnzh2pE4wE5GM0dUaweE7q7h7K7BWJdB7sZhx7bxJLKvbzXOrsuf+CiKS+7oqgplmticY9gLHtT03M11fuRc+PauG0RWD+MnT7+DuYccREQG6Pmoo7u5lwVDq7nkpz8vSGTJXFOTFuHbeJBZv2MWLq3XZCRHJDN1eYkL612draxhRVsRPnl6ltQIRyQgqgjQrzItz7bxJvL5uJy+v0VqBiIRPRRCCz580hmGlhfz06XfCjiIioiIIQ1F+nL87fRKvrNnBq1orEJGQqQhCctnssVQNLuBnf14ddhQRiTgVQUgGFcS55rSJ/GX1dl5buyPsOCISYSqCEH1xzniGlxXyz/+5UkcQiUhoVAQhGlQQ54azp7DkvV08+sbmsOOISESpCEL2VyfWMHVEKT98/G0OtbSGHUdEIkhFELJ4zJh//jQ27DjA717R/QpEJP1UBBng9MnVfPToKn7253fYfbC5+zeIiPQjFUGGmH/eNHYfbOaWZ3Q4qYikl4ogQ0wfVcZnZtXwm5fWUbfzQNhxRCRCVAQZ5L9/fDIG/Mtjb4UdRUQiREWQQUaWD+LaeZN4ZNlmXnhHN68RkfRQEWSYL58+iQlVJXznweU0NutwUhEZeKEVgZnFzWyxmT0SVoZMVJQf5/sXzWBdwwFuffbdsOOISASEuUbwNWBliMvPWKceXcWFM0dx67PvsqZ+X9hxRCTHhVIEZlYDfAK4I4zlZ4NvXzCNwvwY33loua5DJCIDKqw1gpuBG4FEZzOY2TVmtsDMFtTXR2/H6bDSIm78+BReXN3Aw0s3hR1HRHJY2ovAzC4Atrn7wq7mc/fb3L3W3Wurq6vTlC6zXHbyOGbWlPP9R1ay60BT2HFEJEeFsUZwCnChma0D7gXONLPfhZAj48Vjxg8+fSy7DjTx3YdWhB1HRHJU2ovA3ee7e427jwcuAf7s7penO0e2mDG6nOvOOpqHl27ikWXaRCQi/U/nEWSBr8ybxMwxFXz7weVs29MYdhwRyTGhFoG7P+vuF4SZIRvkxWP8+HMzOdjUyjfvX6ajiESkX2mNIEtMqh7M/POm8szb9dz7+nthxxGRHKIiyCJ/PXc8pxxVyfcfeZMNDbpCqYj0DxVBFonFjB9dPJN4zPjqvYt1a0sR6RcqgiwzqmIQP7r4OJa+t4sfPKordIhI36kIstC5M0ZyzWkTuevl9Ty4eGPYcUQky6kIstSNH5/C7AlD+dYDy3hry56w44hIFlMRZKm8eIyfXzaL0qJ8rv3dIvY26qb3ItI7KoIsNqy0iF9cdgIbdhzgf/xxGYmEzi8QkQ9PRZDlZk8YyvzzpvL4ii3c9OTbYccRkSyUF3YA6burT53Amu37ueXZdxk9ZBBfOHlc2JFEJIuoCHKAmfFPFx7Dlt2NfOfB5YwqH8QZU4eFHUtEsoQ2DeWIvHiMn106i2NGlfP3/76IN+p2hx1JRLKEiiCHlBTm8asraxlaUsBVd77Oezt0GQoR6Z6KIMcMKy3izqtm09ya4LI7XmHjroNhRxKRDKciyEFHDRvMXV+aza4DzVxy28sqAxHpkoogR80cU8Hvrj5ZZSAi3VIR5DCVgYj0hIogx80cU8HdKWWwpn5f2JFEJMOoCCLg+GDNYP+hVv7q1pdYuH5H2JFEJIOoCCJi5pgKHrj2I5QPyufS21/lsTc2hx1JRDKEiiBCxleV8MBXTmHGqDK+8u+LuOOFNWFHEpEMoCKImKElBfz7387h3GNG8L8eXcn8B96gsVm3vBSJMhVBBBXlx/nFZSdw7bxJ3PPaBi7+5UtsaNBZyCJRpSKIqFjM+Oa5U/nVFbVsaDjAJ372Ak+u2BJ2LBEJgYog4s6aNpxHr/soE6pKuObuhfzg0Tc51KJNRSJRoiIQxgwt5o9fnssX54zj9hfWcsFP/8LS93aFHUtE0kRFIAAU5sX5/qdm8JurTmJvYwufufUlfvj4W1o7EIkAFYEc4Ywpw3ji66fxmVmjueXZd7ngp39h0YadYccSkQGkIpAPKB+Uz48+O5PfXBmsHdzyEjfet5SGfYfCjiYiAyDtRWBmY8zsGTNbaWYrzOxr6c4gPXPG1GH81w2n83enTeSBRRs546ZnufvldbQmPOxoItKPzD29/1Ob2UhgpLsvMrNSYCHwKXd/s7P31NbW+oIFC9KWUT5o9ba9fPehFbz0bgPTRpbxjbMn87FpwzCzsKOJSCfMbKG713Y3X9rXCNx9s7svCp7vBVYCo9OdQz6co4aV8vu/OZmfXzaLA00t/O1dC7joFy/yzFvbSPcfEyLSv0LdR2Bm44FZwKth5pCeMTMuOG4UT3/jdH548XHsPNDEVXe+zqdveYmn3txKQpuMRLJS2jcNHV6w2WDgOeAH7v5AB69fA1wDMHbs2BPXr1+f5oTSnebWBPcvrOPnz6ymbudBJlaV8KVTJ3DxiTUU5cfDjicSeT3dNBRKEZhZPvAI8IS7/7i7+bWPILO1tCZ4bPkWbn9hDcvqdjO0pIDLZo/lc7VjGFtZHHY8kcjK2CKw5N7F3wI73P36nrxHRZAd3J3X1u7g9hfW8PRb23CHkycM5eITazj/2JGUFOaFHVEkUjK5CE4FXgDeABLB5H9w9//s7D0qguyzefdBHli0kfsW1rF2+36KC+KcNW04580Ywbwp1RQXqBREBlrGFkFvqAiyl7uzcP1O7l+0kSdXbKFhfxOFeTFOn1zNx48ZwUcnVzGstCjsmCI5SUUgGaelNcHr63by+PLNPL5iC1v3JM9UnjayjNMnV3Pa5CpOGDtEO5pF+omKQDJaIuG8uXkPz62q5/lV9Sxcv5OWhJMXM44ZXU7tuCGcOG4Is8ZWMKKsSCeuifSCikCyyr5DLby6poEF63eycN1Oltbt4lBLchfS0JICjhlVxvRRZRwzqpypI0qZUFVCflyXyhLpSk+LQHvsJCMMLszjrGnDOWvacACaWhKs2LSbZXW7WbFpNys27eHXf1lLc2vyD5f8uDGhqoTJw0uZVD2YcZXFjKssZuzQEqoGF2gNQuRDUBFIRirIizFr7BBmjR1yeFpTS4J3tu3lna37eHvrXt7Zupcl7+3i0Tc2k7piW1wQZ0R5ESPKksPw8iKGlxYyrKyIYaWFVJcWMqy0iEEF2hchAioCySIFeTGOGVXOMaPKj5je2NxK3c6DbNixn/UNB9iw4wBbdjeyZU8jr67dwdY9jbR0cPmLovwYQ4sLGFJSwNCSAsoH5VM+KJ+y4LF8UD4lhXkMLoxTUpBHSWEexQVxigvyGJQfp6ggRkE8prUPyXoqAsl6Rflxjho2mKOGDe7w9UTC2XGgifq9h9i29xD1wbDzQBM79jexc38TDfub2LjzILsPNrP7YHOHxdGRmMGg/DiDCuIU5iUfB+XHKcqPUZQfPzwU5sUoyIulPCantY0XxGPkxWPkxYy8uCUfYzHiwfN423gM4rEYcTNiMYjHjJgZMUteCypmRtwMs+Rr8Vjw3NrmMyzG++8h+XrMLPgsVGwRpCKQnBeLGVWDC6kaXMi0kd3P7+4caGplT2Mz+w+1sO9QK/sPtbC3sYXG5lYONLVysLk1eN5CY3Pi8HhySHCwqZW9jS3U7z1EY3MrTS0JmloTHGpOcKg1QVNLovsgIWorBAMsKIzgv8Pjh+c5PP395/D++wneA6nzBtODaR1pfxzL++/5cGV1+H1tP0cHn3fk/J1/tn3gyQdfa3u/u+MODiTa/TDt523j7iQcnOC9Dv/2uZnMmVjZaab+oCIQacfMKCnMG9BLYrh7shhakqXQ1JKgNeE0t7Y9Oq0JpyVx5HirO62JBK0JaE344V8cCff3hwS0upMI5k948Asm8f68fvg9beOpn5Ncizr8ywiCx+SIk/IL64hfWo4f/vmC+Q8/b/vF7od/wafOc+S/zZFFEbyrg89KeQ9+xC/51OnBkyOW1Ha0ZPuld3UQ5fs/WweZ2z1x/HARxtoVZOq/UUdSSxhL3jFwoKkIREJgZsHmIe2wlvDpQGwRkYhTEYiIRJyKQEQk4lQEIiIRpyIQEYk4FYGISMSpCEREIk5FICIScVlxPwIzqwfW9/LtVcD2foyTDso88LItLyhzumRb5q7yjnP36u4+ICuKoC/MbEFPbsyQSZR54GVbXlDmdMm2zP2RV5uGREQiTkUgIhJxUSiC28IO0AvKPPCyLS8oc7pkW+Y+5835fQQiItK1KKwRiIhIF1QEIiIRl9NFYGbnmtnbZrbazL4Vdp6OmNmvzWybmS1PmTbUzJ4ys3eCxyFhZkxlZmPM7BkzW2lmK8zsa8H0TM5cZGavmdnSIPP3gukTzOzVIPMfzKwg7KypzCxuZovN7JFgPNPzrjOzN8xsiZktCKZl7PcCwMwqzOw+M3sr+E7PzeTMZjYl+PdtG/aY2fV9zZyzRWBmceAXwHm8F1+iAAADOElEQVTAdOBSM5sebqoO3Qmc227at4Cn3f1o4OlgPFO0ADe4+zRgDvD3wb9rJmc+BJzp7jOB44FzzWwO8K/A/wky7wSuDjFjR74GrEwZz/S8AGe4+/Epx7Vn8vcC4CfA4+4+FZhJ8t87YzO7+9vBv+/xwInAAeBP9DWzB/crzbUBmAs8kTI+H5gfdq5Oso4HlqeMvw2MDJ6PBN4OO2MX2R8Czs6WzEAxsAg4meTZmHkdfV/CHoCa4H/oM4FHSN7yNmPzBpnWAVXtpmXs9wIoA9YSHDSTDZnb5TwHeLE/MufsGgEwGngvZbwumJYNhrv7ZoDgcVjIeTpkZuOBWcCrZHjmYDPLEmAb8BTwLrDL3VuCWTLt+3EzcCOQCMYryey8kLwv+5NmttDMrgmmZfL3YiJQD/wm2AR3h5mVkNmZU10C3BM871PmXC4C62CajpXtJ2Y2GLgfuN7d94Sdpzvu3urJ1ekaYDYwraPZ0puqY2Z2AbDN3RemTu5g1ozIm+IUdz+B5ObYvzez08IO1I084ATgVnefBewngzYDdSXYP3Qh8Mf++LxcLoI6YEzKeA2wKaQsH9ZWMxsJEDxuCznPEcwsn2QJ/N7dHwgmZ3TmNu6+C3iW5P6NCjPLC17KpO/HKcCFZrYOuJfk5qGbydy8ALj7puBxG8nt1rPJ7O9FHVDn7q8G4/eRLIZMztzmPGCRu28NxvuUOZeL4HXg6OBIiwKSq1EPh5yppx4GrgieX0FyO3xGMDMDfgWsdPcfp7yUyZmrzawieD4I+BjJnYLPABcHs2VMZnef7+417j6e5Pf2z+7+BTI0L4CZlZhZadtzktuvl5PB3wt33wK8Z2ZTgklnAW+SwZlTXMr7m4Wgr5nD3uExwDtTzgdWkdwe/I9h5+kk4z3AZqCZ5F8oV5PcHvw08E7wODTsnCl5TyW5SWIZsCQYzs/wzMcBi4PMy4HvBtMnAq8Bq0muYheGnbWD7POARzI9b5BtaTCsaPv/LZO/F0G+44EFwXfjQWBIFmQuBhqA8pRpfcqsS0yIiERcLm8aEhGRHlARiIhEnIpARCTiVAQiIhGnIhARiTgVgYhIxKkIREQi7v8DAJoQFsRA06IAAAAASUVORK5CYII=\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "No handles with labels found to put in legend.\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "No handles with labels found to put in legend.\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "results = dmlate.fitted_nuisances['model_T_X'][0].evals_result()\n",
    "epochs = len(results['validation_0']['rmse'])\n",
    "x_axis = range(0, epochs)\n",
    "# plot log loss\n",
    "fig, ax = plt.subplots()\n",
    "ax.plot(x_axis, results['validation_0']['rmse'])\n",
    "ax.legend()\n",
    "plt.ylabel('RMSE Loss')\n",
    "plt.title('T_X RMSE Loss')\n",
    "plt.show()\n",
    "results = dmlate.fitted_nuisances['model_Y_X'][0].evals_result()\n",
    "epochs = len(results['validation_0']['rmse'])\n",
    "x_axis = range(0, epochs)\n",
    "# plot log loss\n",
    "fig, ax = plt.subplots()\n",
    "ax.plot(x_axis, results['validation_0']['rmse'])\n",
    "ax.legend()\n",
    "plt.ylabel('Log Loss')\n",
    "plt.title('XGBoost Log Loss')\n",
    "plt.show()\n",
    "results = dmlate.fitted_nuisances['model_Z_X'][0].evals_result()\n",
    "epochs = len(results['validation_0']['logloss'])\n",
    "x_axis = range(0, epochs)\n",
    "# plot log loss\n",
    "fig, ax = plt.subplots()\n",
    "ax.plot(x_axis, results['validation_0']['logloss'])\n",
    "ax.legend()\n",
    "plt.ylabel('Log Loss')\n",
    "plt.title('XGBoost Log Loss')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# ATE and CATE via DMLIV"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 804,
   "metadata": {},
   "outputs": [],
   "source": [
    "from dml_iv import DMLIV\n",
    "from utilities import SelectiveLasso\n",
    "from sklearn.linear_model import LassoCV, LogisticRegressionCV\n",
    "from econml.utilities import hstack\n",
    "\n",
    "np.random.seed(random_seed)\n",
    "\n",
    "# For DMLIV we also need a model for E[T | X, Z]. We use a classifier since T is binary\n",
    "# Because Z is also binary, we could have also done a more complex model_T_XZ, where we split\n",
    "# the data based on Z=1 and Z=0 and fit a separate sub-model for each case.\n",
    "\"\"\"\n",
    "model_T_XZ = lambda: model_clf()\n",
    "\"\"\"\n",
    "\n",
    "# To allow for heterogeneity in the compliance, i.e. to allow for a model of the form:\n",
    "# Pr[T=1|X] = beta(X) * Z + gamma(X)\n",
    "# we need to either create cross features between X and Z and run a linear model.\n",
    "# The method below will learn a linear beta(X)=<beta_1, X> + beta_0 and\n",
    "# gamma(X)=<gamma_1, X> + gamma_0.\n",
    "\"\"\"\n",
    "class Featurizer:\n",
    "    def __init__(self):\n",
    "        return\n",
    "    def fit(self, XZ, y=None):\n",
    "        return self\n",
    "    def transform(self, XZ):\n",
    "        # Z is the last feature in XZ, when the model is called by the dmliv class\n",
    "        return hstack([XZ[:, [-1]] * XZ[:, :-1], XZ]) # Create features (Z*X, X, Z)\n",
    "    def fit_transform(self, XZ, y=None):\n",
    "        return self.transform(XZ)\n",
    "\n",
    "model_T_XZ = lambda: Pipeline([('poly', Featurizer()), ('clf', model_clf())])\n",
    "\"\"\"\n",
    "\n",
    "# Or we need to train a separate model for Z=1 and Z=0. The model for Z=1 learns the\n",
    "# quantity beta(X) + gamma(X) and the model for Z=0 learns gamma(X). This below can\n",
    "# allow for non-linear beta(X) and gamma(X), e.g. random forests\n",
    "class SeparateModel:\n",
    "    def __init__(self, model0, model1):\n",
    "        self.model0 = model0\n",
    "        self.model1 = model1\n",
    "        return\n",
    "    def fit(self, XZ, T):\n",
    "        Z0 = (XZ[:, -1] == 0)\n",
    "        Z1 = (XZ[:, -1] == 1)\n",
    "        self.model0.fit(XZ[Z0, :-1], T[Z0])\n",
    "        self.model1.fit(XZ[Z1, :-1], T[Z1])\n",
    "        return self\n",
    "    def predict(self, XZ):\n",
    "        Z0 = (XZ[:, -1] == 0)\n",
    "        Z1 = (XZ[:, -1] == 1)\n",
    "        t_pred = np.zeros(XZ.shape[0])\n",
    "        if np.sum(Z0) > 0:\n",
    "            t_pred[Z0] = self.model0.predict(XZ[Z0, :-1])\n",
    "        if np.sum(Z1) > 0:\n",
    "            t_pred[Z1] = self.model1.predict(XZ[Z1, :-1])\n",
    "        return t_pred\n",
    "    @property\n",
    "    def coef_(self):\n",
    "        return np.concatenate((self.model0.coef_, self.model1.coef_))\n",
    "\n",
    "model_T_XZ = lambda: SeparateModel(model(), model())\n",
    "\n",
    "# We now specify the features to be used for heterogeneity. We will fit a CATE model of the form\n",
    "#      theta(X) = <theta, phi(X)>\n",
    "# for some set of features phi(X). The featurizer needs to support fit_transform, that takes\n",
    "# X and returns phi(X). We need to include a bias if we also want a constant term.\n",
    "dmliv_featurizer = lambda: PolynomialFeatures(degree=1, include_bias=True)\n",
    "\n",
    "# Then we need to specify a model to be used for fitting the parameters theta in the linear form.\n",
    "# This model will minimize the square loss:\n",
    "#        (Y - E[Y|X] - <theta, phi(X)> * (E[T|X,Z] - E[T|X]))**2\n",
    "# potentially with some regularization on theta. Here we use an ell_1 penalty on theta\n",
    "#dmliv_model_effect = lambda: Lasso(alpha=0.001)\n",
    "\n",
    "# We could also use LassoCV to select the regularization weight in the final stage with\n",
    "# cross validation.\n",
    "#dmliv_model_effect = lambda: LassoCV(fit_intercept=False, cv=3)\n",
    "\n",
    "# If we also have a prior that there is no effect heterogeneity we can use a selective lasso\n",
    "# that does not penalize the constant term in the CATE model\n",
    "#dmliv_model_effect = lambda: SelectiveLasso(np.arange(1, X.shape[1]+1), \n",
    "#                                            LassoCV(cv=5))\n",
    "dmliv_model_effect = lambda: LinearRegression(fit_intercept=False)\n",
    "\n",
    "# We initialize DMLIV with all these models and call fit\n",
    "cate = DMLIV(model_Y_X(), model_T_X(), model_T_XZ(), \n",
    "             dmliv_model_effect(), dmliv_featurizer(),\n",
    "             n_splits=N_SPLITS, # number of splits to use for cross-fitting\n",
    "             binary_instrument=True, # a flag whether to stratify cross-fitting by instrument\n",
    "             binary_treatment=False # a flag whether to stratify cross-fitting by treatment\n",
    "            )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 805,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<dml_iv.DMLIV at 0x1e191ebc908>"
      ]
     },
     "execution_count": 805,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "cate.fit(y, T, X, Z)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 806,
   "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": [
    "# To get the CATE at every X we call effect(X)\n",
    "dml_effect = cate.effect(X)\n",
    "plt.hist(dml_effect, label='est')\n",
    "plt.hist(true_fn(X_raw), alpha=.2, label='true')\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 759,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[ 0.49332146 -0.00081757 -0.00186321 -0.00843515 -0.02279761  0.14235179\n",
      "  0.07492087 -0.00965121 -0.06959382  0.05777629  0.09053964  0.05942848\n",
      "  0.10292672  0.04908478 -0.00103537  0.01730524  0.14282231 -0.02552663\n",
      "  0.06535464 -0.07708868  0.05088902 -0.0255692  -0.02651171]\n",
      "0.029131673190993683\n"
     ]
    }
   ],
   "source": [
    "# To get the parameter theta we call coef_. The first entry is the intercept of the CATE model\n",
    "print(cate.coef_)\n",
    "print(cate.intercept_)\n",
    "#print(cate.effect_model.lasso_model.alpha_)\n",
    "#plt.plot(cate.effect_model.lasso_model.alphas_, cate.effect_model.lasso_model.mse_path_)\n",
    "#plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 807,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "ATE Estimate: 0.584\n",
      "True ATE: 0.609\n"
     ]
    }
   ],
   "source": [
    "# We can average the CATE to get an ATE\n",
    "print(\"ATE Estimate: {:.3f}\".format(np.mean(dml_effect)))\n",
    "print(\"True ATE: {:.3f}\".format(np.mean(true_fn(X_raw))))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 558,
   "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 as Function of {}\".format(X_df.columns[np.argmax(np.abs(cate.coef_[1:]))]))\n",
    "plt.scatter(X[:, np.argmax(np.abs(cate.coef_[1:]))], dml_effect, label='est')\n",
    "plt.scatter(X[:, np.argmax(np.abs(cate.coef_[1:]))], true_fn(X_raw), label='true', alpha=.2)\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 841,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Unavailable\n"
     ]
    }
   ],
   "source": [
    "# The property .fitted_nuisances is a dictionary of the form:\n",
    "# {'name_of_nuisance': [fitted_model_fold_1, fitted_model_fold_2, ...]}\n",
    "# then we can access all properties of each of the fitted models for each fold.\n",
    "# If for instance all nuisances have a linear form we can look at the standard deviation\n",
    "# of the coefficients of each of the nuisance model across folds to check for stability\n",
    "try:\n",
    "    [print(\"Model {} max std of coefs: {}\".format(name,\n",
    "                                                  np.max(np.std([ns.coef_ for ns in nuisance_insts], axis=0)))) \n",
    "     if hasattr(nuisance_insts[0], 'coef_') else\n",
    "     print(\"Model {} max std of coefs: {}\".format(name,\n",
    "                                                  np.max(np.std([ns.named_steps['clf'].coef_ for ns in nuisance_insts],\n",
    "                                                                axis=0)))) \n",
    "     for name, nuisance_insts in cate.fitted_nuisances.items()]\n",
    "except:\n",
    "    print(\"Unavailable\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 842,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Unavailable\n"
     ]
    }
   ],
   "source": [
    "try:\n",
    "    nuisance_diagnostic(cate, 'model_T_XZ', 'coef', lambda ns: ns.coef_.flatten(),\n",
    "                        [c+\"_0\" for c in X_df.columns] + [c+\"_1\" for c in X_df.columns])\n",
    "    nuisance_diagnostic(cate, 'model_T_X', 'coef', lambda ns: ns.coef_.flatten(), X_df.columns)\n",
    "    nuisance_diagnostic(cate, 'model_Y_X', 'coef', lambda ns: ns.coef_.flatten(), X_df.columns)\n",
    "except:\n",
    "    print(\"Unavailable\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 843,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "try:\n",
    "    nuisance_diagnostic(cate, 'model_T_XZ', 'predict', lambda ns: ns.predict(hstack([X, Z.reshape(-1,1)])))\n",
    "    nuisance_diagnostic(cate, 'model_T_X', 'predict', lambda ns: ns.predict(X))\n",
    "except:\n",
    "    print(\"Unavailable\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 844,
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Unavailable\n"
     ]
    }
   ],
   "source": [
    "try:\n",
    "    nuisance_diagnostic(cate, 'model_T_XZ', 'coef_0', lambda ns: ns.model0.coef_.flatten(), index_names=X_df.columns)\n",
    "    nuisance_diagnostic(cate, 'model_T_XZ', 'coef_1', lambda ns: ns.model1.coef_.flatten(), index_names=X_df.columns)\n",
    "\n",
    "    plt.title(\"Difference in coefficients betwen model0 and model1\")\n",
    "    for i in range(N_SPLITS):\n",
    "        plt.plot([c0 - c1 for c0, c1 in zip(cate.fitted_nuisances['model_T_XZ'][i].model0.coef_.flatten(),\n",
    "              cate.fitted_nuisances['model_T_XZ'][i].model1.coef_.flatten())])\n",
    "    plt.show()\n",
    "except:\n",
    "    print(\"Unavailable\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 845,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Average correlation of residual h-p with Z: [2.30754016]\n",
      "Heterogeneity of residual h-p with respect to X: [ 0.02537762 -0.01381751 -0.03434589  0.018144   -0.01256423  0.04886166\n",
      "  0.07487091 -0.         -0.1653968  -0.23777345  0.05004132  0.05864307\n",
      " -0.          0.25296042  0.16056571 -0.         -0.          0.1305969\n",
      " -0.         -0.25902463  0.03957447 -1.01490025  3.01168626]\n"
     ]
    }
   ],
   "source": [
    "try:\n",
    "    for i in range(3):\n",
    "        plt.figure()\n",
    "        plt.hist(cate.fitted_nuisances['model_T_XZ'][i].predict(hstack([X[Z==0], Z[Z==0].reshape(-1,1)]))\n",
    "                 -cate.fitted_nuisances['model_T_X'][i].predict(X[Z==0]))\n",
    "        plt.hist(cate.fitted_nuisances['model_T_XZ'][i].predict(hstack([X[Z==1], Z[Z==1].reshape(-1,1)]))\n",
    "                 -cate.fitted_nuisances['model_T_X'][i].predict(X[Z==1]), alpha=.2)\n",
    "        plt.show()\n",
    "    print(\"Average correlation of residual h-p with Z: {}\".format(LinearRegression().fit(Z.reshape(-1,1), cate.fitted_nuisances['model_T_XZ'][i].predict(hstack([X, Z.reshape(-1,1)]))\n",
    "                 -cate.fitted_nuisances['model_T_X'][i].predict(X)).coef_))\n",
    "    print(\"Heterogeneity of residual h-p with respect to X: {}\".format(LassoCV(cv=5).fit(hstack([X, Z.reshape(-1,1)]), cate.fitted_nuisances['model_T_XZ'][i].predict(hstack([X, Z.reshape(-1,1)]))\n",
    "                 -cate.fitted_nuisances['model_T_X'][i].predict(X)).coef_))\n",
    "except:\n",
    "    print(\"Unavailable\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# ATE via DRIV"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 761,
   "metadata": {},
   "outputs": [],
   "source": [
    "import statsmodels.api as sm\n",
    "\n",
    "# A wrapper of statsmodel linear regression, wrapped in a sklearn interface.\n",
    "# We can use statsmodel for all hypothesis testing capabilities\n",
    "class StatsModelLinearRegression:\n",
    "    def __init__(self):\n",
    "        return\n",
    "    def fit(self, X, y):\n",
    "        self.model = sm.OLS(y, X).fit()\n",
    "        return self\n",
    "    def predict(self, X):\n",
    "        return self.model.predict(exog=X)\n",
    "    def summary(self, *args, **kwargs):\n",
    "        return self.model.summary(*args, **kwargs)\n",
    "    @property\n",
    "    def coef_(self):\n",
    "        return self.model._results.params\n",
    "    @property\n",
    "    def intercept_(self):\n",
    "        return 0"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 786,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'const_dr_cate = ProjectedDRIV(model_Y_X(), model_T_X(), model_T_XZ(), # same as in DMLIV\\n                        prel_model_effect, # preliminary model for CATE, must support fit(y, T, X, Z) and effect(X)\\n                        model_cov_TZ_X(), # model for Cov(T, E[T|Z,X] | X)\\n                        const_driv_model_effect(), # model for final stage of fitting theta(X)\\n                        cov_clip=.0001, # covariance clipping to avoid large values in final regression from weak instruments\\n                        n_splits=10, # number of splits to use for cross-fitting\\n                        binary_instrument=True, # a flag whether to stratify cross-fitting by instrument\\n                        binary_treatment=True # a flag whether to stratify cross-fitting by treatment\\n                       )'"
      ]
     },
     "execution_count": 786,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "from dml_iv import DMLIV\n",
    "from dr_iv import DRIV, ProjectedDRIV\n",
    "from utilities import SubsetWrapper\n",
    "from sklearn.dummy import DummyRegressor\n",
    "\n",
    "np.random.seed(random_seed)\n",
    "\n",
    "# For ProjectedDRIV we also need a model that predicts\n",
    "# Cov(T, E[T|Z,X] | X) = E[(T-E[T|X]) * (E[T|Z,X]-E[T|X]) | X]\n",
    "model_cov_TZ_X = lambda: model()\n",
    "# For DRIV we need a model for predicting E[T*Z | X]. We use a classifier\n",
    "model_TZ_X = lambda: model()\n",
    "\n",
    "# We also need a model for the final regression that will fit the function theta(X)\n",
    "# If we want to fit an ATE, we simply fit a constant functin theta(X) = theta\n",
    "# We can do this with a pipeline where the preprocessing step only creates a bias column\n",
    "# and the regression step fits a linear regression with no intercept.\n",
    "# To get normal confidence intervals easily we can use a statsmodels linear regression\n",
    "# wrapped in an sklearn interface\n",
    "const_driv_model_effect = lambda: Pipeline([('poly', PolynomialFeatures(degree=0, include_bias=True)),\n",
    "                                      ('reg', StatsModelLinearRegression())])\n",
    "\n",
    "# As in OrthoDMLIV we need a perliminary estimator of the CATE.\n",
    "# We use a DMLIV estimator with no cross-fitting (n_splits=1)\n",
    "dmliv_prel_model_effect = DMLIV(model_Y_X(), model_T_X(), model_T_XZ(),\n",
    "                                dmliv_model_effect(), dmliv_featurizer(),\n",
    "                                n_splits=1, binary_instrument=True, binary_treatment=True)\n",
    "\n",
    "# We could have also used a non-doubly robust DRIV model with a zero preliminary effect model.\n",
    "# Though this is less advisable as it has much higher variacen than DMLIV and also depends\n",
    "# on exactly the same functions. So if these functions are not easily learnable, we wouldn't\n",
    "# be able to fix it via the learnability of other functions. This is what happens if we use\n",
    "# dmliv as a preliminary model.\n",
    "\"\"\"\n",
    "class DummyCATE:\n",
    "    def __init__(self):\n",
    "        return\n",
    "    def fit(self, y, T, X, Z):\n",
    "        return self\n",
    "    def effect(self, X):\n",
    "        return np.zeros(X.shape[0])\n",
    "\n",
    "lasso_driv_model_effect = lambda: Pipeline([('poly', PolynomialFeatures(degree=1, include_bias=False)),\n",
    "                                      ('reg', Lasso(alpha=.01))])\n",
    "driv_prel_model_effect = DRIV(model_Y_X(), model_T_X(), model_Z_X(), # same as in DMLATEIV\n",
    "                        DummyCATE(), # preliminary model for CATE, must support fit(y, T, X, Z) and effect(X)\n",
    "                        model_TZ_X(), # model for E[T * Z | X]\n",
    "                        lasso_driv_model_effect(), # model for final stage of fitting theta(X)\n",
    "                        cov_clip=0.01, # covariance clipping to avoid large values in final regression from weak instruments\n",
    "                        n_splits=N_SPLITS, # number of splits to use for cross-fitting\n",
    "                        binary_instrument=True, # a flag whether to stratify cross-fitting by instrument\n",
    "                        binary_treatment=True # a flag whether to stratify cross-fitting by treatment\n",
    "                       )\n",
    "\"\"\"\n",
    "\n",
    "const_dr_cate = DRIV(model_Y_X(), model_T_X(), model_Z_X(), # same as in DMLATEIV\n",
    "                        dmliv_prel_model_effect, # preliminary model for CATE, must support fit(y, T, X, Z) and effect(X)\n",
    "                        model_TZ_X(), # model for E[T * Z | X]\n",
    "                        const_driv_model_effect(), # model for final stage of fitting theta(X)\n",
    "                        cov_clip=COV_CLIP, # covariance clipping to avoid large values in final regression from weak instruments\n",
    "                        n_splits=N_SPLITS, # number of splits to use for cross-fitting\n",
    "                        binary_instrument=True, # a flag whether to stratify cross-fitting by instrument\n",
    "                        binary_treatment=False # a flag whether to stratify cross-fitting by treatment\n",
    "                       )\n",
    "\n",
    "# For comparison here is how ProjectedDRIV is called. A set of slightly different models\n",
    "\"\"\"const_dr_cate = ProjectedDRIV(model_Y_X(), model_T_X(), model_T_XZ(), # same as in DMLIV\n",
    "                        prel_model_effect, # preliminary model for CATE, must support fit(y, T, X, Z) and effect(X)\n",
    "                        model_cov_TZ_X(), # model for Cov(T, E[T|Z,X] | X)\n",
    "                        const_driv_model_effect(), # model for final stage of fitting theta(X)\n",
    "                        cov_clip=.0001, # covariance clipping to avoid large values in final regression from weak instruments\n",
    "                        n_splits=10, # number of splits to use for cross-fitting\n",
    "                        binary_instrument=True, # a flag whether to stratify cross-fitting by instrument\n",
    "                        binary_treatment=True # a flag whether to stratify cross-fitting by treatment\n",
    "                       )\"\"\"\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 787,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<dr_iv.DRIV at 0x1e191c6dd30>"
      ]
     },
     "execution_count": 787,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "const_dr_cate.fit(y, T, X, Z, store_final=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 788,
   "metadata": {},
   "outputs": [],
   "source": [
    "# To get the ATE we look at the params of the fitted statsmodel\n",
    "const_dr_effect = const_dr_cate.effect_model.named_steps['reg'].coef_[0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 789,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\moprescu\\AppData\\Local\\Continuum\\anaconda3\\lib\\site-packages\\statsmodels\\regression\\linear_model.py:1554: RuntimeWarning: divide by zero encountered in double_scalars\n",
      "  return self.ess/self.df_model\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<table class=\"simpletable\">\n",
       "<caption>OLS Regression Results</caption>\n",
       "<tr>\n",
       "  <th>Dep. Variable:</th>            <td>y</td>        <th>  R-squared:         </th> <td>  -0.000</td> \n",
       "</tr>\n",
       "<tr>\n",
       "  <th>Model:</th>                   <td>OLS</td>       <th>  Adj. R-squared:    </th> <td>  -0.000</td> \n",
       "</tr>\n",
       "<tr>\n",
       "  <th>Method:</th>             <td>Least Squares</td>  <th>  F-statistic:       </th> <td>    -inf</td> \n",
       "</tr>\n",
       "<tr>\n",
       "  <th>Date:</th>             <td>Wed, 22 May 2019</td> <th>  Prob (F-statistic):</th>  <td>   nan</td>  \n",
       "</tr>\n",
       "<tr>\n",
       "  <th>Time:</th>                 <td>08:45:34</td>     <th>  Log-Likelihood:    </th> <td> -5969.4</td> \n",
       "</tr>\n",
       "<tr>\n",
       "  <th>No. Observations:</th>      <td>  2991</td>      <th>  AIC:               </th> <td>1.194e+04</td>\n",
       "</tr>\n",
       "<tr>\n",
       "  <th>Df Residuals:</th>          <td>  2990</td>      <th>  BIC:               </th> <td>1.195e+04</td>\n",
       "</tr>\n",
       "<tr>\n",
       "  <th>Df Model:</th>              <td>     0</td>      <th>                     </th>     <td> </td>    \n",
       "</tr>\n",
       "<tr>\n",
       "  <th>Covariance Type:</th>      <td>nonrobust</td>    <th>                     </th>     <td> </td>    \n",
       "</tr>\n",
       "</table>\n",
       "<table class=\"simpletable\">\n",
       "<tr>\n",
       "    <td></td>       <th>coef</th>     <th>std err</th>      <th>t</th>      <th>P>|t|</th>  <th>[0.025</th>    <th>0.975]</th>  \n",
       "</tr>\n",
       "<tr>\n",
       "  <th>const</th> <td>    0.5274</td> <td>    0.033</td> <td>   16.199</td> <td> 0.000</td> <td>    0.464</td> <td>    0.591</td>\n",
       "</tr>\n",
       "</table>\n",
       "<table class=\"simpletable\">\n",
       "<tr>\n",
       "  <th>Omnibus:</th>       <td>4294.814</td> <th>  Durbin-Watson:     </th>  <td>   1.993</td>  \n",
       "</tr>\n",
       "<tr>\n",
       "  <th>Prob(Omnibus):</th>  <td> 0.000</td>  <th>  Jarque-Bera (JB):  </th> <td>8045218.868</td>\n",
       "</tr>\n",
       "<tr>\n",
       "  <th>Skew:</th>           <td>-7.685</td>  <th>  Prob(JB):          </th>  <td>    0.00</td>  \n",
       "</tr>\n",
       "<tr>\n",
       "  <th>Kurtosis:</th>       <td>256.612</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:                Wed, 22 May 2019   Prob (F-statistic):                nan\n",
       "Time:                        08:45:34   Log-Likelihood:                -5969.4\n",
       "No. Observations:                2991   AIC:                         1.194e+04\n",
       "Df Residuals:                    2990   BIC:                         1.195e+04\n",
       "Df Model:                           0                                         \n",
       "Covariance Type:            nonrobust                                         \n",
       "==============================================================================\n",
       "                 coef    std err          t      P>|t|      [0.025      0.975]\n",
       "------------------------------------------------------------------------------\n",
       "const          0.5274      0.033     16.199      0.000       0.464       0.591\n",
       "==============================================================================\n",
       "Omnibus:                     4294.814   Durbin-Watson:                   1.993\n",
       "Prob(Omnibus):                  0.000   Jarque-Bera (JB):          8045218.868\n",
       "Skew:                          -7.685   Prob(JB):                         0.00\n",
       "Kurtosis:                     256.612   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": 789,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# To get the statsmodel summary we look at the effect_model, which is the pipeline, we then look\n",
    "# at the reg step of the pipeline which is the statsmodel wrapper and then we look\n",
    "# at the model attribute of the statsmodel wrapper and print the summary()\n",
    "const_dr_cate.effect_model.named_steps['reg'].summary()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 766,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_driv_coverage(true_effect, iteration):\n",
    "    y, T = dgp_bin_Z_cont_T(X_raw, Z, hetero_col, true_fn, random_seed=iteration)\n",
    "    dmliv_prel_model_effect = DMLIV(model_Y_X(), model_T_X(), model_T_XZ(),\n",
    "                                dmliv_model_effect(), dmliv_featurizer(),\n",
    "                                n_splits=1, binary_instrument=True, binary_treatment=True)\n",
    "    const_dr_cate = DRIV(model_Y_X(), model_T_X(), model_Z_X(), # same as in DMLATEIV\n",
    "                            dmliv_prel_model_effect, # preliminary model for CATE, must support fit(y, T, X, Z) and effect(X)\n",
    "                            model_TZ_X(), # model for E[T * Z | X]\n",
    "                            const_driv_model_effect(), # model for final stage of fitting theta(X)\n",
    "                            cov_clip=COV_CLIP, # covariance clipping to avoid large values in final regression from weak instruments\n",
    "                            n_splits=N_SPLITS, # number of splits to use for cross-fitting\n",
    "                            binary_instrument=True, # a flag whether to stratify cross-fitting by instrument\n",
    "                            binary_treatment=False # a flag whether to stratify cross-fitting by treatment\n",
    "                           )\n",
    "    const_dr_cate.fit(y, T, X, Z, store_final=True)\n",
    "    const_dr_effect = const_dr_cate.effect_model.named_steps['reg'].coef_[0]\n",
    "    left, right = const_dr_cate.effect_model.named_steps['reg'].model.conf_int(alpha=0.05)[0]\n",
    "    if true_effect >= left and true_effect <= right:\n",
    "        return 1\n",
    "    return 0"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 647,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[Parallel(n_jobs=-1)]: Using backend LokyBackend with 8 concurrent workers.\n",
      "[Parallel(n_jobs=-1)]: Done  16 tasks      | elapsed:  4.4min\n",
      "[Parallel(n_jobs=-1)]: Done 100 out of 100 | elapsed: 16.1min finished\n"
     ]
    }
   ],
   "source": [
    "from joblib import Parallel, delayed\n",
    "contains_truth = np.array(Parallel(n_jobs=-1, verbose=3)(\n",
    "            delayed(get_driv_coverage)(true_ate, it) for it in range(n_experiments)))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 648,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.92"
      ]
     },
     "execution_count": 648,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "contains_truth.mean()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 790,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "ATE Estimate: 0.527\n",
      "True ATE: 0.609\n"
     ]
    }
   ],
   "source": [
    "print(\"ATE Estimate: {:.3f}\".format(const_dr_effect))\n",
    "print(\"True ATE: {:.3f}\".format(np.mean(true_fn(X_raw))))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 857,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Split 0\n",
      "Split 1\n",
      "Split 2\n",
      "Split 3\n",
      "Split 4\n",
      "Split 5\n",
      "Split 6\n",
      "Split 7\n",
      "Split 8\n",
      "Split 9\n"
     ]
    }
   ],
   "source": [
    "### Learn beta(X)\n",
    "from sklearn.model_selection import StratifiedKFold\n",
    "T_pred = np.zeros(T.shape[0])\n",
    "Z_pred = np.zeros(Z.shape[0])\n",
    "TZ_pred = np.zeros(Z.shape[0])\n",
    "kfold = StratifiedKFold(shuffle=True, n_splits=N_SPLITS)\n",
    "split_i = 0\n",
    "for train_index, test_index in kfold.split(X, Z):\n",
    "    print(\"Split {0}\".format(split_i))\n",
    "    split_i += 1\n",
    "    X_train, X_test = X[train_index], X[test_index]\n",
    "    T_train, T_test = T[train_index], T[test_index]\n",
    "    Z_train, Z_test = Z[train_index], Z[test_index]\n",
    "    T_pred[test_index] = model_T_X().fit(X_train, T_train).predict(X_test)\n",
    "    Z_pred[test_index] = model_Z_X().fit(X_train, Z_train).predict(X_test)\n",
    "    TZ_pred[test_index] = model_TZ_X().fit(X_train, Z_train*T_train).predict(X_test)\n",
    "beta_X = TZ_pred - T_pred * Z_pred"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 858,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.6107765860004235"
      ]
     },
     "execution_count": 858,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.mean(true_fn(X_raw) * beta_X)/ np.mean(beta_X)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 859,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.8333030339879555"
      ]
     },
     "execution_count": 859,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.std(true_fn(X_raw) * beta_X/ np.mean(beta_X))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 860,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.1554116114114398"
      ]
     },
     "execution_count": 860,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.std(true_fn(X_raw))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 906,
   "metadata": {},
   "outputs": [],
   "source": [
    "# The property .fitted_nuisances is a dictionary of the form:\n",
    "# {'name_of_nuisance': [fitted_model_fold_1, fitted_model_fold_2, ...]}\n",
    "# then we can access all properties of each of the fitted models for each fold.\n",
    "# If for instance all nuisances have a linear form we can look at the standard deviation\n",
    "# of the coefficients of each of the nuisance model across folds to check for stability\n",
    "try:\n",
    "    [print(\"Model {} max std of coefs: {}\".format(name,\n",
    "                                                  np.max(np.std([ns.coef_ for ns in nuisance_insts], axis=0)))) \n",
    "     if hasattr(nuisance_insts[0], 'coef_') else None\n",
    "     for name, nuisance_insts in const_dr_cate.fitted_nuisances.items()]\n",
    "except:\n",
    "    print(\"Unavailable\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 908,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Model prel_model_effect mean std of predictions: 0.023234809445957304\n",
      "Model model_TZ_X mean std of predictions: 0.43943816966205007\n",
      "Model model_T_X mean std of predictions: 0.13506208683526943\n",
      "Model model_Z_X mean std of predictions: 0.019901978450449602\n",
      "Model model_Y_X mean std of predictions: 0.10194187443697185\n",
      "Model prel_model_effect max std of predictions: 0.06316308512165714\n",
      "Model model_TZ_X max std of predictions: 2.1003541946411133\n",
      "Model model_T_X max std of predictions: 1.0878682732582092\n",
      "Model model_Z_X max std of predictions: 0.07336191087961197\n",
      "Model model_Y_X max std of predictions: 0.6146256923675537\n"
     ]
    }
   ],
   "source": [
    "import scipy.stats\n",
    "\n",
    "# We can also measure the variation of the predictions of the fitted models across folds\n",
    "try:\n",
    "    # Statistic for measuring variation across folds at each prediction point\n",
    "    statistic = scipy.stats.iqr \n",
    "    #statistic = lambda x, axis: scipy.stats.variation(np.abs(x), axis=axis)\n",
    "    #statistic = np.std\n",
    "\n",
    "    [print(\"Model {} mean std of predictions: {}\".format(name,\n",
    "                                                  np.mean(statistic([ns.predict(X) for ns in nuisance_insts], axis=0)))) \n",
    "     if hasattr(nuisance_insts[0], 'predict') else\n",
    "     print(\"Model {} mean std of predictions: {}\".format(name,\n",
    "                                                  np.mean(statistic([ns.effect(X) for ns in nuisance_insts], axis=0)))) \n",
    "     for name, nuisance_insts in const_dr_cate.fitted_nuisances.items()]\n",
    "    [print(\"Model {} max std of predictions: {}\".format(name,\n",
    "                                                  np.max(statistic([ns.predict(X) for ns in nuisance_insts], axis=0)))) \n",
    "     if hasattr(nuisance_insts[0], 'predict') else\n",
    "     print(\"Model {} max std of predictions: {}\".format(name,\n",
    "                                                  np.max(statistic([ns.effect(X) for ns in nuisance_insts], axis=0)))) \n",
    "     for name, nuisance_insts in const_dr_cate.fitted_nuisances.items()]\n",
    "except:\n",
    "    print(\"Unavailable\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 909,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "std of prel_model ATE across folds: 0.020387260625285335\n"
     ]
    }
   ],
   "source": [
    "# Or the variation on the prel model fitted ATE\n",
    "# (this is almost a sub-sample based estimate of the standard deviation of the preliminary ATE)\n",
    "try:\n",
    "    # Statistic for measuring variation across folds\n",
    "    #statistic = scipy.stats.iqr \n",
    "    #statistic = lambda x, axis: scipy.stats.variation(np.abs(x), axis=axis)\n",
    "    statistic = np.std\n",
    "    print(\"std of prel_model ATE across folds: {}\".format(np.mean(statistic([ns.effect(X) \n",
    "                                                                for ns in const_dr_cate.fitted_nuisances['prel_model_effect']], \n",
    "                                                               axis=0))))\n",
    "except:\n",
    "    print(\"Unavailable\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 910,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Unavailable\n"
     ]
    }
   ],
   "source": [
    "try:\n",
    "    nuisance_diagnostic(const_dr_cate, 'model_TZ_X', 'coef', lambda ns: ns.coef_.flatten(), X_df.columns)\n",
    "    nuisance_diagnostic(const_dr_cate, 'model_TZ_X', 'predict', lambda ns: ns.predict(X), np.arange(X.shape[0]))\n",
    "    nuisance_diagnostic(const_dr_cate, 'model_T_X', 'coef', lambda ns: ns.coef_.flatten(), X_df.columns)\n",
    "    nuisance_diagnostic(const_dr_cate, 'prel_model_effect', 'effect', lambda ns: ns.effect(X), np.arange(X.shape[0]))\n",
    "except:\n",
    "    print(\"Unavailable\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# CATE via DRIV"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 769,
   "metadata": {},
   "outputs": [],
   "source": [
    "from dml_iv import DMLIV\n",
    "from dr_iv import DRIV, ProjectedDRIV\n",
    "\n",
    "np.random.seed(random_seed)\n",
    "\n",
    "# We need a model for the final regression that will fit the function theta(X)\n",
    "# Now we use a linear model and a lasso.\n",
    "lasso_driv_model_effect = lambda: Pipeline([('poly', PolynomialFeatures(degree=1, include_bias=False)),\n",
    "                                      ('reg', Lasso(alpha=0.02))])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 770,
   "metadata": {},
   "outputs": [],
   "source": [
    "lasso_dr_cate = const_dr_cate.refit_final(lasso_driv_model_effect())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 771,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\moprescu\\AppData\\Local\\Continuum\\anaconda3\\lib\\site-packages\\scipy\\stats\\stats.py:1713: FutureWarning: Using a non-tuple sequence for multidimensional indexing is deprecated; use `arr[tuple(seq)]` instead of `arr[seq]`. In the future this will be interpreted as an array index, `arr[np.array(seq)]`, which will result either in an error or a different result.\n",
      "  return np.add.reduce(sorted[indexer] * weights, axis=axis) / sumval\n",
      "No handles with labels found to put in legend.\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import seaborn as sns\n",
    "lasso_dr_effect = lasso_dr_cate.effect(X)\n",
    "#plt.hist(lasso_dr_effect, label='est', bins=20)\n",
    "#plt.hist(true_fn(X_raw), alpha=.2, label='true', bins=20)\n",
    "sns.distplot(lasso_dr_effect)\n",
    "sns.distplot(true_fn(X_raw))\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 742,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[-0.06757247 -0.         -0.00830893  0.          0.16380055  0.\n",
      "  0.         -0.         -0.          0.          0.41855843  0.\n",
      "  0.         -0.         -0.         -0.         -0.         -0.\n",
      " -0.02909324  0.         -0.          0.        ]\n",
      "0.5817731492092577\n",
      "not available\n"
     ]
    }
   ],
   "source": [
    "# To get the final fitted model we can use dr_cate.effect_model. This is an instance of\n",
    "# the same model that we used as driv_model_effect\n",
    "# We can access all of its properties for any interpretability purposes\n",
    "print(lasso_dr_cate.effect_model.named_steps['reg'].coef_) # coefficients of CATE in front of X\n",
    "print(lasso_dr_cate.effect_model.named_steps['reg'].intercept_) # intercept of CATE\n",
    "\n",
    "try:\n",
    "    print(lasso_dr_cate.effect_model.named_steps['reg'].alpha_)\n",
    "    plt.plot(lasso_dr_cate.effect_model.named_steps['reg'].alphas_,\n",
    "             lasso_dr_cate.effect_model.named_steps['reg'].mse_path_)\n",
    "    plt.show()\n",
    "except:\n",
    "    print('not available')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 743,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "ATE Estimate: 0.660\n",
      "True ATE: 0.609\n"
     ]
    }
   ],
   "source": [
    "print(\"ATE Estimate: {:.3f}\".format(np.mean(lasso_dr_effect)))\n",
    "print(\"True ATE: {:.3f}\".format(np.mean(true_fn(X_raw))))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 736,
   "metadata": {},
   "outputs": [],
   "source": [
    "from sklearn.metrics import r2_score"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 744,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.4726205106578948"
      ]
     },
     "execution_count": 744,
     "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": [
    "plt.scatter(true_fn(X_raw), lasso_dr_effect)\n",
    "r2_score(lasso_dr_effect, true_fn(X_raw))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 745,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.6528592444990994"
      ]
     },
     "execution_count": 745,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.mean(lasso_dr_effect * beta_X)/ np.mean(beta_X)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 702,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "coef = lasso_dr_cate.effect_model.named_steps['reg'].coef_\n",
    "# We can also see how it compares to the true CATE at each target point and calculate MSE\n",
    "plt.title(\"DMLIV CATE as Function of {}\".format(X_df.columns[np.argmax(np.abs(coef))]))\n",
    "plt.scatter(X[:, np.argmax(np.abs(coef))], lasso_dr_effect, label='est')\n",
    "plt.scatter(X[:, np.argmax(np.abs(coef))], true_fn(X), label='true', alpha=.2)\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Projecting CATE to a pre-chosen subset of variables in final model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 659,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[4 7]\n"
     ]
    }
   ],
   "source": [
    "from dml_iv import DMLIV\n",
    "from dr_iv import DRIV, ProjectedDRIV\n",
    "from utilities import SubsetWrapper\n",
    "\n",
    "np.random.seed(random_seed)\n",
    "\n",
    "# We could also fit a projection on a subset of the features by using the\n",
    "# subset wrapper from our utilities.\n",
    "\n",
    "# Example: including everything for expository purposes, but any array-like of indices would work\n",
    "#subset_names = X_df.columns.values\n",
    "#subset_names = set(['age', 'motheduc', 'motheduc_nan', 'fatheduc', 'fatheduc_nan', 'iq', 'kww'])\n",
    "subset_names = set(['motheduc', 'sinmom14'])\n",
    "#subset_names = set(['f0'])\n",
    "# list of indices of features X to use in the final model\n",
    "feature_inds = np.argwhere([(x in subset_names) for x in X_df.columns.values]).flatten() #[0] #np.arange(X.shape[1]) \n",
    "print(feature_inds)\n",
    "# Because we are projecting to a low dimensional model space, we can\n",
    "# do valid inference and we can use statsmodel linear regression to get all\n",
    "# the hypothesis testing capability\n",
    "proj_driv_model_effect = lambda: SubsetWrapper(Pipeline([('poly', PolynomialFeatures(degree=2, include_bias=True)),\n",
    "                                                      ('reg', StatsModelLinearRegression())]),\n",
    "                                          feature_inds # list of indices of features X to use in the final model\n",
    "                                         )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 660,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Index(['exper', 'expersq', 'fatheduc', 'fatheduc_nan', 'motheduc',\n",
       "       'motheduc_nan', 'momdad14', 'sinmom14', 'reg661', 'reg662', 'reg663',\n",
       "       'reg664', 'reg665', 'reg666', 'reg667', 'reg668', 'reg669', 'south66',\n",
       "       'black', 'smsa', 'south', 'smsa66'],\n",
       "      dtype='object')"
      ]
     },
     "execution_count": 660,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "X_df.columns"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 661,
   "metadata": {},
   "outputs": [],
   "source": [
    "proj_dr_cate = const_dr_cate.refit_final(proj_driv_model_effect())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 662,
   "metadata": {},
   "outputs": [],
   "source": [
    "# To get the CATE at every X we call effect(X[:, feature_inds])\n",
    "proj_dr_effect = proj_dr_cate.effect(X[:, feature_inds])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 663,
   "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.010</td> \n",
       "</tr>\n",
       "<tr>\n",
       "  <th>Model:</th>                   <td>OLS</td>       <th>  Adj. R-squared:    </th> <td>   0.009</td> \n",
       "</tr>\n",
       "<tr>\n",
       "  <th>Method:</th>             <td>Least Squares</td>  <th>  F-statistic:       </th> <td>   14.79</td> \n",
       "</tr>\n",
       "<tr>\n",
       "  <th>Date:</th>             <td>Wed, 22 May 2019</td> <th>  Prob (F-statistic):</th> <td>4.05e-07</td> \n",
       "</tr>\n",
       "<tr>\n",
       "  <th>Time:</th>                 <td>03:19:27</td>     <th>  Log-Likelihood:    </th> <td> -6018.8</td> \n",
       "</tr>\n",
       "<tr>\n",
       "  <th>No. Observations:</th>      <td>  2991</td>      <th>  AIC:               </th> <td>1.204e+04</td>\n",
       "</tr>\n",
       "<tr>\n",
       "  <th>Df Residuals:</th>          <td>  2988</td>      <th>  BIC:               </th> <td>1.206e+04</td>\n",
       "</tr>\n",
       "<tr>\n",
       "  <th>Df Model:</th>              <td>     2</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.5999</td> <td>    0.035</td> <td>   17.156</td> <td> 0.000</td> <td>    0.531</td> <td>    0.668</td>\n",
       "</tr>\n",
       "<tr>\n",
       "  <th>motheduc</th> <td>    0.1697</td> <td>    0.034</td> <td>    5.030</td> <td> 0.000</td> <td>    0.104</td> <td>    0.236</td>\n",
       "</tr>\n",
       "<tr>\n",
       "  <th>sinmom14</th> <td>   -0.1469</td> <td>    0.111</td> <td>   -1.318</td> <td> 0.188</td> <td>   -0.365</td> <td>    0.072</td>\n",
       "</tr>\n",
       "</table>\n",
       "<table class=\"simpletable\">\n",
       "<tr>\n",
       "  <th>Omnibus:</th>       <td>3919.904</td> <th>  Durbin-Watson:     </th>   <td>   2.012</td>  \n",
       "</tr>\n",
       "<tr>\n",
       "  <th>Prob(Omnibus):</th>  <td> 0.000</td>  <th>  Jarque-Bera (JB):  </th> <td>17083224.343</td>\n",
       "</tr>\n",
       "<tr>\n",
       "  <th>Skew:</th>           <td> 6.067</td>  <th>  Prob(JB):          </th>   <td>    0.00</td>  \n",
       "</tr>\n",
       "<tr>\n",
       "  <th>Kurtosis:</th>       <td>373.040</td> <th>  Cond. No.          </th>   <td>    3.41</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.010\n",
       "Model:                            OLS   Adj. R-squared:                  0.009\n",
       "Method:                 Least Squares   F-statistic:                     14.79\n",
       "Date:                Wed, 22 May 2019   Prob (F-statistic):           4.05e-07\n",
       "Time:                        03:19:27   Log-Likelihood:                -6018.8\n",
       "No. Observations:                2991   AIC:                         1.204e+04\n",
       "Df Residuals:                    2988   BIC:                         1.206e+04\n",
       "Df Model:                           2                                         \n",
       "Covariance Type:            nonrobust                                         \n",
       "==============================================================================\n",
       "                 coef    std err          t      P>|t|      [0.025      0.975]\n",
       "------------------------------------------------------------------------------\n",
       "const          0.5999      0.035     17.156      0.000       0.531       0.668\n",
       "motheduc       0.1697      0.034      5.030      0.000       0.104       0.236\n",
       "sinmom14      -0.1469      0.111     -1.318      0.188      -0.365       0.072\n",
       "==============================================================================\n",
       "Omnibus:                     3919.904   Durbin-Watson:                   2.012\n",
       "Prob(Omnibus):                  0.000   Jarque-Bera (JB):         17083224.343\n",
       "Skew:                           6.067   Prob(JB):                         0.00\n",
       "Kurtosis:                     373.040   Cond. No.                         3.41\n",
       "==============================================================================\n",
       "\n",
       "Warnings:\n",
       "[1] Standard Errors assume that the covariance matrix of the errors is correctly specified.\n",
       "\"\"\""
      ]
     },
     "execution_count": 663,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# To get the statsmodel summary we look at the effect_model, which is\n",
    "# an instance of SubsetWrapper, we look at the model of the SubsetWrapper which is \n",
    "# and instance of the pipeline, we then look at the reg step of the pipeline which is the statsmodel wrapper and\n",
    "# call summary() of the wrapper (most prob there is a better API for this, but we can go with this for now :)\n",
    "proj_dr_cate.effect_model.named_steps['reg'].summary(alpha=.05, xname=['const']+list(X_df.columns[feature_inds]))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 664,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Estimated Params: [ 0.59985421  0.16965284 -0.14686786]\n",
      "True Params: [ 0.1   0.05 -0.1 ]\n"
     ]
    }
   ],
   "source": [
    "# We can access the coefficient by looking at the coefficient attribute of the final step of the pipeline\n",
    "print(\"Estimated Params: {}\".format(proj_dr_cate.effect_model.named_steps['reg'].coef_))\n",
    "# True coefficients of projection\n",
    "print(\"True Params: {}\".format(\n",
    "        LinearRegression(fit_intercept=False).fit(PolynomialFeatures(degree=1,\n",
    "                                                                     include_bias=True).fit_transform(X[:, feature_inds]),\n",
    "                                                  true_fn(X)).coef_))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 665,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "ATE Estimate: 0.59\n",
      "True ATE: 0.09\n"
     ]
    }
   ],
   "source": [
    "print(\"ATE Estimate: {:.2f}\".format(np.mean(proj_dr_effect)))\n",
    "print(\"True ATE: {:.2f}\".format(np.mean(true_fn(X))))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 668,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "coef = proj_dr_cate.effect_model.named_steps['reg'].coef_[1:]\n",
    "# We can also see how it compares to the true CATE at each target point and calculate MSE\n",
    "plt.title(\"DMLIV CATE as Function of {}\".format(X_df.columns[feature_inds][np.argmax(np.abs(coef))]))\n",
    "plt.scatter(X[:, feature_inds][:, np.argmax(np.abs(coef))], proj_dr_effect, label='est')\n",
    "plt.scatter(X[:, feature_inds][:, np.argmax(np.abs(coef))], true_fn(X), label='true', alpha=.2)\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 666,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Coverage of True Projection: 0.03\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAe8AAAFpCAYAAAC1YKAIAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADl0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uIDIuMi4zLCBodHRwOi8vbWF0cGxvdGxpYi5vcmcvIxREBQAAIABJREFUeJzs3Xd4FNXXwPHvJCGE3nsLvYcaWmhKV4oKFqQoqKAoKKIIKlUsWH4ICiICUkRElPYiiIDSgzTpHUIJRSG0QEi/7x+HFEJ6ZrMJnM/z+Gx2Z3bmJsGcve0cyxiDUkoppTIPF2c3QCmllFIpo8FbKaWUymQ0eCullFKZjAZvpZRSKpPR4K2UUkplMhq8lVJKqUxGg7dSSimVyWjwVkoppTIZDd5KKaVUJqPBWymllMpk3JzdgIQULFjQeHp6OrsZSimlVLrZuXPnZWNMoaTOy7DB29PTkx07dji7GUoppVS6sSzrdHLO02FzpZRSKpPR4K2UUkplMhq8lVJKqUwmw855xycsLAx/f3+Cg4Od3RSVQh4eHpQsWZIsWbI4uylKKZXpZarg7e/vT65cufD09MSyLGc3RyWTMYaAgAD8/f0pW7ass5ujlFKZXqYaNg8ODqZAgQIauDMZy7IoUKCAjpgopZRNMlXwBjRwZ1L6e1NKKftkuuCtlFJKPeg0eN8nduzYwaBBg5zdDKWUUukgUy1YUwmrX78+9evXd3YzooWHh+Pmpv+8lFLKETJ3z7tly3v/mzJFjgUFxX981iw5fvnyvceS4dSpU1SpUoUXX3yRGjVq0KNHD9asWYOPjw8VK1Zk27Zt3Lp1i759++Lt7U2dOnVYunRp9HubNWtG3bp1qVu3Llu2bAFg3bp1tGzZkm7dulGlShV69OiBMSbBNmzfvp0mTZpQq1YtGjRoQGBgIOvWraNjx44Jvmf06NF8/vnn0c9r1KjBqVOnor+f5557Di8vL7p160ZQUBAgKWrfeecdGjRoQIMGDTh+/DgAly5domvXrnh7e+Pt7c3mzZuj79GvXz/atm1L7969k/XzVEoplXK2dI0sy5oJdAT+M8bUiOd4D+CdO09vAq8YY/bYcW9nOH78OAsXLmTatGl4e3vz448/smnTJpYtW8ZHH31EtWrVePjhh5k5cybXrl2jQYMGtG7dmsKFC7N69Wo8PDw4duwY3bt3j87f/s8//3DgwAGKFy+Oj48PmzdvpmnTpvfcOzQ0lKeffpoFCxbg7e3NjRs3yJYtW5q+nyNHjjBjxgx8fHzo27cvU6ZM4a233gIgd+7cbNu2jTlz5vDGG2+wfPlyXn/9dQYPHkzTpk05c+YM7dq149ChQwDs3LmTTZs2pblNSimlEmbXuOYs4GtgTgLH/YAWxpirlmV1AKYBDdN813XrEj6WPXvixwsWTPx4IsqWLUvNmjUBqF69Oq1atcKyLGrWrMmpU6fw9/dn2bJl0T3d4OBgzpw5Q/HixXnttdfYvXs3rq6uHD16NPqaDRo0oGTJkgDUrl2bU6dOxRu8jxw5QrFixfD29gYkuKZVqVKl8PHxAaBnz55MmjQpOnh37949+nHw4MEArFmzhoMHD0a//8aNGwQGBgLQuXNnDdxKKeVgtgRvY8wGy7I8Ezm+JdbTrUBJO+7rLFmzZo3+2sXFJfq5i4sL4eHhuLq68uuvv1K5cuW73jd69GiKFCnCnj17iIyMxMPDI95rurq6Eh4eHu+9jTGp2nbl5uZGZGRk9PPYe67jXi/28/i+joyMxNfXN94gnSNHjhS3TSmlVMo4Y877BWClE+6bbtq1a8dXX30VPW/9zz//AHD9+nWKFSuGi4sLc+fOJSIiIsXXrlKlCufPn2f79u0ABAYGJhjoY/P09GTXrl0A7Nq1Cz8/v+hjZ86cwdfXF4D58+ff1eNfsGBB9GPjxo0BaNu2LV9//XX0Obt3707x96GUUpnaoUPg5QV//eWU26dr8LYs6yEkeL+TwPF+lmXtsCxrx6VLl9KzabYaMWIEYWFheHl5UaNGDUaMGAHAgAEDmD17No0aNeLo0aOp6qW6u7uzYMECBg4cSK1atWjTpk2yMpd17dqVK1euULt2bb755hsqVaoUfaxq1arMnj0bLy8vrly5wiuvvBJ9LCQkhIYNGzJx4kQmTJgAwKRJk9ixYwdeXl5Uq1aNqVOnpvj7UEqpTC04GPbtgxs3nHJ7K7FVzSm6kAybL49vwdqd417AYqCDMeZofOfEVr9+fRO1mCvKoUOHqFq1atobq6KdOnWKjh07sn///nuOeXp6smPHDgoWLGjLvfT3p5S6b/zzD9StC0uWQJcutl3Wsqydxpgk9/2mS8/bsqzSwCKgV3ICt1JKKaUSZtdWsflAS6CgZVn+wCggC4AxZiowEigATLmz6Ck8OZ8sHnSPP/74XXPTAOPHj6ddu3YJvuf7779n4sSJd73m4+PD5MmT4z3f09Mz3l43SK9cKaVUxmPXavPuSRx/EXjRjns9SBYvXpzi9/Tp04c+ffo4oDVKKaWIjISQEMiVC1q3hkKFnNKMzJ1hTSmllHK0gACYPx9694ZixeCLL6BCBVi9Gpo0cUqTNPm0UkopFR9joFUrWL9eetz580P79tCggbNbpsFbKaWUIiAA/vgDVq6Eq1fh//4PLAtq1YJmzaBDB/D2BldXZ7cU0OCtlFLqQbZgAUycCH//Lb3rAgUkUEdESKC+k98io9E57/tEUvW8Z82axWuvvZaOLVJKqQwmIAB+/BF69YILF+S1K1cgPBzefx+2boV//4W5czNMDzsh2vO+T2SUet5ax1splaGcOgVz5sCKFbBtm8xjFywIL70ki89efhliZZXMLDJ3z1vreSe7nndsp0+fplWrVnh5edGqVSvOnDlDREQE5cqVwxjDtWvXcHFxYcOGDQA0a9aM48ePJ/h9zZo1iyeffJJOnTrRtm3bZLVBKaXSRVgYfPKJBO1Ro2R4/OJFaN5cjqei0FNGoF2kVMjs9bxfe+01evfuzXPPPcfMmTMZNGgQS5YsoVKlShw8eBA/Pz/q1avHxo0badiwIf7+/lSoUIF333033u8LwNfXl71795I/f/60/4CVUiotfvtNFp59/TVUrCidtezZnd0qW2Xu4K31vFNVz9vX15dFixYB0KtXL4YOHQpID3vDhg34+fkxfPhwvvvuO1q0aBF9rz/++CPe7wugTZs2GriVUs519iy8/josXgxVq8qq8Xz57rvADZk9eDtJZqznnZio6zVr1oypU6dy/vx5xo4dy2effca6detofmd4yRgT7/f1999/ax1vpZTzhIXBpEkyLB4ZCR9/DG++Ce7uzm6Zw2TuOe8MKiPW846tSZMm/PTTTwDMmzcvuoffsGFDtmzZgouLCx4eHtSuXZtvv/2WZs2aJfp9KaWUU928CePHw0MPwcGDMGzYfR24QYO3Q2TEet6xTZo0ie+//x4vLy/mzp0bXcgka9aslCpVikaNGgHSEw8MDIyeIkjo+1JKqXQXEABjx8o2r3z5pETnsmXg6enslqUL2+p5203red9/9PenlEozY2D2bHj7bZnTXrcO4lkflFllqHreSimlVJodOAAtWkCfPlC5svS276PAnRK6YC0DS4963koplSkYAz16yIry6dMlgLs8uP1PHTZX6UZ/f0qpFPvtN0mokiuX9LyLFJGtvvcpHTZXSimVeZ05A489Bh07wldfyWvVq9/XgTslNHgrpZTKOMLC4NNPJcnK6tWyBeztt53dqgxH57yVUkplHIMGwdSp0LmzJF4pU8bZLcqQtOftZDlz5nR2E5RSyrkuXpShcWMkM9qSJbB0qQbuRGjP2wEiIiJwzeC1YJVSKkP47jvo10++Ll0aunSRYiIqUfd9z9v3rC8fb/wY37O+tlwvqiToc889h5eXF926dSMoKAhPT0/Gjh1L06ZNWbhwISdOnKB9+/bUq1ePZs2acfjwYQD8/Pxo3Lgx3t7emqFMKaXulB4GIM7WWJWwTN3zbjmr5T2vPVX9KQZ4DyAoLAifmT7s/XcvkSYSF8sFryJevN7wdZ6v/TyXgy7T7edud7133fPrknXfI0eOMGPGDHx8fOjbty9T7tQQ9/DwYNOmTQC0atWKqVOnUrFiRf7++28GDBjAn3/+yeuvv84rr7xC7969de+1UurBc+0ajBwJL7wAtWrBt99C/vwyv62SLVMH76RcD75OpIkEINJEcj34ui3XLVWqFD4+PgD07NmTSXf+0T399NMA3Lx5ky1btvDkk09GvyckJASAzZs38+uvvwJSjvOdd96xpU1KKZWhGQPz5sFbb8GlSzI0XquWlOusVk3OyWR5ya0xMRUezaj0zZmSqYN3Yj3l7FmyM++JebSa04rQiFDcXd2Z98Q8GpdqDEDB7AWT3dOOK25JzqjnUYVGIiMjyZs3L7t3707W+5VS6r528CAMGADr10ODBrBiBdStG3M8amFa0aLOaV8qxA7cUc/TM4Df13PejUs1Zm3vtXzw0Aes7b02OnCn1ZkzZ/D1lTn0+fPnR5fUjJI7d27Kli3LwoULAamDvWfPHkBSlcYux6mUUve9BQtg714ZIvf1vTtwA+TNCz4+kkVNJct9HbxBAvjwZsNtC9wAVatWZfbs2Xh5eXHlyhVeeeWVe86ZN28eM2bMoFatWlSvXp2lS5cCMHHiRCZPnoy3tzfXr9szjK+UUhmKMbBokSRZAamvfeSIrCqPLx95o0awaZNkUFPJYktuc8uyZgIdgf+MMTXiOW4BE4FHgCDgeWPMrsSumVFzm586dYqOHTuyf/9+p7YjM8oIvz+llIOdOAEDB8LKlZJo5U7H5X7kiDnv9M5tPgton8jxDkDFO//1A76x6b5KKaUyguBgGDNGes8bN8L//gd3Fufej0LCQzgx6AQ3h99M98VqYFPwNsZsAK4kckoXYI4RW4G8lmUVs+Pe6c3T01N73UopFdfixTB6NDz+uAyRDx4Mbpl6TXSiDl46SPlJ5Vlzco1T7p9eP9kSwNlYz/3vvHYhne6vlFLKbmfPwv790KEDPP00lC0r89fK4dJrwVp8e6PuGWewLKufZVk7LMvacenSpXRollJKqRQLC4PPPpPKX337QkiILETTwJ1u0it4+wOlYj0vCZyPe5IxZpoxpr4xpn6hQoXSqWlKKaWSbf16qF0bhg6Fhx+GLVsga1Znt+qBk17D5suA1yzL+gloCFw3xuiQuVJKZSaHDkHLlpJUZelSWU2eweX4MAdB4UFkd8vOrfduObs5trEleFuWNR9oCRS0LMsfGAVkATDGTAVWINvEjiNbxfrYcd/0FhAQQKtWrQC4ePEirq6uRI0QbNu2DXd3d2c2TymlHKtqVUm40rGjpDXN4KICN0BQeBA5PsxhWwAvmbskX3f4mppFatpyvZSyJXgbY7oncdwAr9pxL2cqUKBAdMrT0aNHkzNnTt566627zjHGYIzBJb5EBEopldk99ZSzW5As8/fNjw7cUeI+T4tCOQrxagPnhTWNMDY4fvw4NWrU4OWXX6Zu3bqcPXuWvHnzRh//6aefePHFFwH4999/eeKJJ6hfvz4NGjRg69atzmq2UkqlTP/+MG6cs1uRoIs3LxIUJgH6ZuhNrDhrpV0tV9vudTvsNnsu7rGt4FVKZdpNeAcOgN3ZRfPkSX12voMHD/L9998zdepUwsPDEzxv0KBBDB06lEaNGmm2NqVU5hEZCevWQU3nDBMn5vDlw3yx5Qvm7J3D520+Z2DDgbxQ9wVeqvdS9NB5VpesXH7nMgD/3fqPQtkLpalI1OHLh6k7rS5Lnl5Clypd7PpWki3TBu+Mpnz58nh7eyd53po1azhy5Ej086tXr3L79m2yZcvmyOYppVTq/PcffP89TJsGJ0/CQw85u0XRNp7eyOe+n7PsyDI83DzoW7svHSp2AMDFkoHluHPct8Nu03JWS8rlK8f3Xb6nUI7MubMp0wbvjJa/PqocKICLiwuxc8YHBwdHf22M0cVtSqmMLTJS9nJnzQp//CGFRVq0kCHzJ55watOMMdE95uFrh3P48mFGtRjFq96vJisQe7h5MMB7AG/98RZeU72Y89gc2pRv4+hm207nvB3AxcWFfPnycezYMSIjI1m8eHH0sdatWzN58uTo5wnV/FZKqXR3+TJ8/jlUrgwTJ8pr3bpJPe5166B7d6ft6b4ddptvtn+D11Qv/r35LwBzHp/DmcFnGN1ydLJ70JZl8VqD19j20jbyeeSj7Q9tGbp6KKERoY5svu00eDvI+PHjad++Pa1ataJkyZLRr0+ePJnNmzfj5eVFtWrV+O6775zYSqWUAjZsgGefhRIl4O23oUgR2RYG4OER87UTXA66zJh1Yyj9ZWkGrBhA9izZ+e/WfwCUy1eO7FlSt2XNq4gXO/rtoF/dfqw7tc7GFqcPW0qCOkJGLQmqUk9/f0plIEFBMXu127eHrVuhd2+puV3jnsrOTnH19lVKf1mam6E36VipI283eZtmpZulaaFZfILCgsieJTtXbl9h9YnVPF3j6STfc+X2FZYfXU5Lz5aUzlPatrYktyRopp3zVkoplULGSDrTb7+FRYskY1qpUvK8UKEMkXhl27ltbDi9gbeavEW+bPkY33o8LT1bUq1QNYfdM6r3PnHrRMZuGMvyY8uZ/MhkcmfNneB78mfLT+9avR3WpqRo8FZKqftdYCDMni1Bev9+yJVLetlRPdgyZZzaPGvM3T3p/Nny82LdF8nrkZcB3gPSrR0jWozA1cWVMevHsOXsFuZ3nU+DEg3iPfdm6E32XNxDlYJVKJC9QLq1MYrOeSul1P3ImJhkGIGB8MYbMn/93Xdw/jxMmQKx1uM4Q0h4yD2BG+DU66fI65E3nnc4lpuLGyNbjGT98+sJjwzHZ6YPCw8sjPfcYwHHaPp9Uzad2ZTOrRTa81ZKqftJYCC8/75U/ypYENasgeLF4ehRKFfO2a2LtujQIl5dEX960VxZc6Vza+7WtHRTdvffzTtr3qFZmWZObUtCtOetlFL3A2Pgl18gd26YNAkuXYInn5TXIUME7tPXTnM+UKpBF85RGK8iXk5uUcLyZcvHtE7TKJqzKBGRETy58EmWH13u7GZF0+CtlFKZ3Z49Ulv7ySdjXlu2THKR27wyOzX+ufAPz/76LOUnlWfcBsmN3rR0U1b1XIUZdfeOp7jPM4KA2wEcv3KcTvM7MWjlIILDg5N+k4Np8E6BgIAAateuTe3atSlatCglSpSIfh4amrYN/tOnT6dQoULUrl2bqlWrMnPmzBS9/++//2bw4MFpaoNSKpOaNAn27YOpU2HGDHktf37ntglYc3INree0pu60uiw/upw3Gr3B8KbD7zlvVc9VZHXNytYXMmahpsI5CrP1ha280fANvtr2FQ2nN+TQ5UNObZPOeaeAo0uC9ujRgy+//JKLFy9So0YNOnfuTMGCBaOPh4eH4+YW/6+sYcOGNGzYMMX3VEplQmFhsuCsaVOoVw8+/VQyo+XLJ6vJP/1UvnaC8Mhw3Fzk79SC/Qs4dPkQ41uPp1+9fgkuQltxbAUhESH4+vvSsGTG/DuW1S0rE9pPoHW51jy/9HmZDy/djD5L+/DIwUf44Ykf0rU92vO2gd0lQYsWLYqnpydnzpzh/fffp3///rRp04Y+ffpw+/ZtnnvuOWrWrEndunXZsGEDIAVPHnvssfT5hpVSzvPHH1CrlqweX7BAXitQICZY16ghWdLypu9q7RshN/hiyxeUnViWrf7yd218m/GcHHSSoT5DnbJ63BEerfQoe1/eS60itdh4ZiNXg68yb988ei7qma7tyLQ97/u5JOjx48c5ffo05e4sMPnnn3/YsGEDHh4ejB8/Hnd3d/bt28eBAwd45JFHOHbsWOoarZTKPI4fhyFDZC67fHlYuhQ6dXJ2qzgfeJ6JWycydedUboTcoKVny+ied/5szh+6d4RiuYrhe9b3rtdWHluZrm3ItME7o0lrSVCAefPmsX79etzd3Zk+fXp0771Lly54eHgAsGnTJt5++20AqlevTvHixTl+/Ljd345SKqP56Sf480/45BPpdTupQEhs4ZHh1P22LpeCLtGtWjfebvI29YsnmdnzvtChYgfm7Zt31/P0lGmD9/1YEjRqzjuxa2fUXPRKKZtFRsLcuZK29JFHpNf9wgtQrJjTmhQ7oUrEyAjcXNyY3nk61QpVo1y+1G9Fy+aWDYCsrs7/QJJcUXPcK4+tpEPFDjrnfT9wZEnQ5s2bM2+efNo7dOgQFy5coEKFCvY0XCmVMWzdCo0bw/PPw5w58lq2bBkmcAO4jnUFoGOljmkK3ABDmgxhda/VPFvz2TRdJ7398MQPBLwTkO6BGzR4O4yjSoIOHDiQ27dvU7NmTXr06MGcOXOie/F2V9pRSqWz8+cl53jjxnD2rATuH390dqscrmD2grQu15o8Hnmc3ZRMQ0uC3icWLFjAH3/8wYyoPZ4ZkP7+lErCDz/I0PiQIfDuu5Azp7NbFC2+HOR2JVT5vyP/R+efOrOxz0aalm5qyzUzq+SWBNWe931g8eLFjBo1ipdeesnZTVFKpYQxsGQJzJolz599VnKQf/RRhgrccG+gtjMT2lq/tQDsOL8jiTMzkBs34Pff4d9/nXJ7Dd73gccff5zDhw/TqFEjZzdFKZVchw5Bmzbw+ONS6csYcHFxennOxAQMDeDaO9cyZArTdHfiBHToIOsTnCDTBe+MOsyvEqe/N6XuuHAB+vWDatVg50746iupAJYJ1qzkz5Zf56UziEwVvD08PAgICNBAkMkYYwgICIjeq67UA+nmTRg9GipWvHuY/LXXIIG0xxnNpL8nMX/ffGc3Q5HJ9nmXLFkSf39/Ll265OymqBTy8PC4a9W9Ug+U336DF1+EixehWzf4+GMJ4nGyK2Z003ZOo0rBKnSv2d3W6+Zyl/rd2bNkt/W697NMFbyzZMlC2bJlnd0MpZRKmjEQGiqZ0AoVkpSmixbJNjCQAN68uXPbmEEMaTKEjpU6Uq1QNfsuGhoKGzbIB6fq1eXD033EluBtWVZ7YCLgCkw3xnwS53hpYDaQ9845w4wxK+y4t1JKZTi7dklxkHLlZDFagwawcePd89rDhjnk1rG3dGWWhWV5PfLaW01s2TLo2RMCA+W5mxs0awaVK9t3j/LlY4rEOEGa57wty3IFJgMdgGpAd8uy4n58eh/42RhTB3gGmJLW+yqlVIZz5owkWalXD/bsgdq1Y46lw4K0uHux49ubnREtPLAQa4zFn35/puyNxsDevbK1rnHjmCpr1apB9+4SxP38IEcO6YHbKXdu2S1QuLC9100mO3reDYDjxpiTAJZl/QR0AQ7GOscAue98nQc4b8N9lVIq4/jlF+ntAbzzjvSs06ksZ0h4yF1FMjKbzWc3A7D33708XPbhpN8QEgJvvgnLl8sHJgBvb4iqGVGhAnz7bcz5R4/aH2SvXoU1a6BJEyhRwt5rJ4MdwbsEcDbWc38g7vjHaOAPy7IGAjmA1vFdyLKsfkA/gNKlS9vQNKWUcqDQULhyBYoWhYYNpbc3enS67dW+FnyNqTumMunvSVy4eSHecw5dOkSF/BXI4polzffb2W+nc9IwX7woPecbN2DwYFlH4OsLderAyJFSuCWxvO9RgfvAAahUCbKk/WfBqVPw1FOSZMcJwduOrWLx/SbjTrR0B2YZY0oCjwBzLcu6597GmGnGmPrGmPqFChWyoWlKKeUAxsjis+rVpbdtDJQqBd9/n26B+3bYbSp+VZHha4dTvXB1VvVcReTIyLvOuTHsBi1nt8Rnpg8nrpxI8z2zumXF3fXeiogOceAAjB0r6wWKFZMFZ7Nmyc8aZI/8kiXJr7S2fz94eUGswlCZmR3B2x8oFet5Se4dFn8B+BnAGOMLeAAFbbi3Ukqlr61bZfFT164yTDt4cLrdes/FPYzbMA6AbFmy8UmrT9jVbxere62mbfm2WJbFQ54PAbC291pyZc3FlEemcOzKMep8W4cf9qat+tXHGz9m5j8z0/x9JOjgQQgLk6+//15GMVxdYdw4WUOwe3fM2oGUjgBUrw6tW8s174PtxnYE7+1ARcuyylqW5Y4sSFsW55wzQCsAy7KqIsE78//0lFIPlgULZGHU8eMwbZoElEcfdehiNGMMq0+spu3cttT+tjafbPoE/xv+ALxQ9wXqFKtz1/lVClYBIHdWWWbUtVpX9ry8h9pFa9NrcS96Le5FSHhIqtoyb988VhyzcaPQv//CjBnMWzcJgPH7voMtW+TYkCEyXO7rC++9J73mtPycLQsmTJBkOSNH2tB450pz8DbGhAOvAauAQ8iq8gOWZY21LKvzndOGAC9ZlrUHmA88bzRNmlIqMwgIkCANEqg/+kiC90svOTwz2uHLh6k7rS5tf2jLvv/28XGrjzk7+Cwlcyec8KhhCVlyVCBbgejXSucpzZ/P/cmYlmMIDg9Ov6HvuIyBoCD5+tQpKFaMajte5LKHAQMX80C1va/I8WLF7F9kVq0avPpqzAevTMyWf3l39myviPPayFhfHwR87LiXUkqlC2Pg6adh4UKoWlXmYHPmhOHDHXrbwJBATl8/TY3CNSiZuyTZs2RnRucZ9KjZg6xuWZN8f16PvFQvVP2eBWpuLm6MbDESYwyWZXHiygmWHF7C4MaDcbl3CZJ9wsNh0ybZtrVsmYxczJ0rawP+9z+OXH+T2Mukjlw94ri2AIwaBb/+KkPwadmjXamSjApUqmRf21IgU2VYU0ophwsPlx61ZUngBpg+3eH7tM8HnmfS35OYumMqxXIV4+CAg+R0z8nmvptTdJ1rwdc4cOkAYRFh8R6PWi0+e89sPtjwAatOrGL2Y7MplisZi75Savhw2bJ19aqsEG/VCtq1i2oIvPEGlSdP49DlQxK/LahcwMZEKvHJn19GTtJaayFHDnBiJcdMVZhEKaUcJjgYJk6UHuGRO72/li3lsW5d229njbGi/+u7tC+eX3ry2ZbPaFu+LXMem+PwLVljWo5hWsdpbDqzCa+pXvx2NOkkJq4urgn30s+ehSlTJHd7eLi8lj07dO4sPd3Ll2W7V9Re+DsOvnqQqrnK4WKgau6KHHz1YDwCXuKOAAAgAElEQVQXt5mHh4ys/P67/N5TIyAAZs6E06ftbVtyGWMy5H/16tUzSinlcMHBxkyebEzx4saAMQ8/bMz+/XIsPNyYa9dsvyWjuee/AcsHmOMBx9N87a4LuhpGYzae3pis8w/+d9DU+qaWYTRmwf4FKbuZn58xo0cbU6eO/OzAmIoV5fWUWLPGmPz5jdm+PWXvS4udO6W9H36Yuvfv2iXvX7LE1mYBO0wyYqT2vJVSD66wMFnF/Oqrkof8r79g7VrZVgSyTSmPffWrwyPDEyxpPPnRyZTPXz7N97hy+woAoRGhyTq/aqGqbH1xK+MeGsejFR8FINJExn9ySAisWiUZywBOnoQxY6SHPX48HD4sxzw9U9bo27cl2U1I6lbBp0rduvDYY7IA8XzmS/qpwVsp9WAJD4/Jc50li9TTXrVKKlBFDZPb7FboLb7e9jWVvqrE78d/d8g90sLDzYP3mr9HDvcc3Aq9hfd33ny387t7PmiMeK0ak0e0hxkz5IVmzWS716ZNMHRo6gt/rFkjj9u3p+G7SIXPP5cPcO++m773tYEGb6XUgyEiAubNk+1CHTvKSmGAgQOhbVuHLEi7dOsSo/4aRZkvyzBw5UCK5CxCDvcc91T7srP6V83CNQHIkzV1IwZBYUHkz5affsv78dQvT3H19tXoY4tzneOvBoUk0QnIh5/MnA2zfHnJkT57Nmzb5uzWpIgGb6XU/S0yEn7+GWrWlMVS2bJJWk0HrxQ2xtD0+6aM3TAWn9I+bOyzkS19t9C8zN01vO0u21m3mCyuy58tf6reXyhHIVb1XMX41uNZcngJtb+tzaYzm2JOcHeXn+H94t13ZcvYf/85uyUposFbKXV/CwqSofGorV///ANdujikp+171pcXlr5AaEQolmXxdYevOfTqIZY+s5SmpZumS1GPvB55qVG4RpoKkbhYLgz1GcrmvpvJ4pKFd9a8gzGGINdIDmcNxPesr40tJqawhzN68blyyb+Jjh1T9r4qVSRf+kMPOaZdSdDgrZS6vxgjpSKffFLmt3PmhI0bpe5zt27gYu+fvUgTydLDS2k6sylNZjZh8eHFHPjvAABtyreJTlcan1zuuWxtC8g+7/3/7U9wn3dKNCjRgF39d/Fzt5/Z6r8VvxxhHPC4Qas5rewN4DVlqJ/yaV+wlyqWJXPf334Lt24l7z3ZssnCxty5kz7XATR4K6XuD8bIwrNGjaBTJ9i1K6bWc+XKsnLcZhcCL1BtcjUeW/AY5wLPMbH9RM4MPnNPvvH4LHl6CX8995ftbbJb7qy5KZG7BOtOrYuuIRkaESrP7VK+PIwY4ZTSmtH++QdefllWzSfHf//BpEmy4t4JNHgrpTK/f/+Vlc/t20sxi+++k21L5crZfqsrt6+w5qSsji6asyjeJbyZ33U+xwYeY1DDQeR0z5ms63Sp0oV6xevZ3r5FhxcBcPbGWVuv29KzJR5uHrharri7utPSs6V9Fz95Ej75xLlbtho0gGefhc8+k7zrSTl3Dl5/Hfbtc3jT4qPBWymV+RUsKOkqp0yBY8ek9nOW1M/5xsfvqh+DVg6i1IRSdP25K0FhQViWxdzH5/JMjWdwc0lZtmlrjEXbuW3ta2BgIMyfT+DR/QCEXzhn37WBxqUa8+dfpfngv+qs7b2WxqUa23fx4GAZtk7Pfd7xGT9eplWGDnVuO5JBc5srpTKnyEjZm712LXzwgQyZ28waE7PAzMVywdVy5dmaz/JWk7fIniV7mq+/+uTqtF0gMFDm93/+GVaulOD3HFAW+OILWNg9zW2MrfHFLDTOWxHsDNwgyXFApjqaN0/8XEcqWRLeeUeKl2zY4Ny2JEGDt1IqczlzRvblzpolw625c8OAAVJC0kaxAzfIwrQzb5yhRG4nzssChIbKdi2ADh1g82b53vv3hyefpO6SAfzFPvJt2gnXrkHevM5tb2bz1lvw99+2j9zYTYO3UirzWLlSamobAw8/DGPHwuOPS3pOG4RGhBJpIvFwi7/ilNMCd1QPe+FCWLdOimHkyiWpSd3dwccnehV9zemukAvyfjpJA3dqZM8ek4EvA9M5b6VUxmQM7Nwpe7Sj0nE2bSpDmidPynB5jx62BO7rwdf5dPOnlJ1Ylinbp6T5erbZuxeeeAIKF5bFVFu3SqKZ27fleKtWslAv1va3vA2bU+NfyFKnnvwMr11zUuNToHRpeSxSxLntiO3aNXjvPbh+Pf7j1avLh6g2bdK3XXdoz1splbFcvixpTGfOlOCVNWvMAqJcuSR428T/hj8Tt07k253fEhgayMNlH47OUGZGmbuGzu3OhAZQKHucpCQ3b0oPu1w5Wf3s4iIB+6WXZN96rB52Qq5FBrG/CIRFhsPTT8vq+/Xr7UlK8/TTULRo2q8TV7Vq8li2rP3XTq2TJ+Hjj2Udweef33vc3T3mQ4cTaPBWSjmfMbJoqUABmXNcswa8vWX1+DPPQL58Drltn6V9+MvvL56q/hRvNXkrOnBHeaLqEyw6tIjrwxLofaXB6l6rKZazWEzAjlp0Fhwsc/gNGkjvzt8/ZYll9u+HosCl/yT714ABMgyc0gxi8RkxIu3XiE/FijBuHJQq5Zjrp0bdutC3r9R479cPKlW6+/jFizIi9OST9x5LD8mpG+qM/7Set1IPgFu3jJk61ZiqVaU2cpMmUtN53z7bbxUZGWnWnFhjHp33qDl345wxxph9/+4zflf9EnzPJxs/MYzGBIUG2d6e4LBgExoeakzlyvK9FytmzMCBxmzYYExERKqvW+BdN8NojPdnlY0JDZX62tWrS23ytAoLs+c6ca1cKT8DX1/7r50WFy8akyuXMR073ntM63krpR44UaUmjxyRrFZRhS62bIH69aFGDdtuFR4Zzvx986k3rR6t57Zmx/kdHLl8BIAahWvgmdczwfcG3A4AEqlvnRIREfDnn7JKHvD40IOHvqonQ7MbNkgPe9Kke+awU6Ld3HYEuIcDsP3WEdr91FHqVR84AHPmpP17qF1bhs7tFpWSNDjY/munRZEiMtqwfDn8nrFKueqwuVIq/WzdCl9+KQlVZsyAOnUkLWWtWvDhh7ZXdgoOD6b6lOqcvHqSKgWrML3TdHp49UhwNXlc03dNByAkIoQc5EhdI/btgx9+kHn8c+dkaLh3bwA2X98nq+VtsvHMxnufv/u7DMFPnQrPP++QgixptvFOu3fvdlhN9VQbNAiOH3de3vUEaM9bKeV4gYHw1VfQuLH0YGIveqpdWwLK++9LzzONLt68yKzdswDwcPOgT+0+LHtmGQcGHOCFui8kO3ADDPAeEH2dVPnwQ/Dygv/9Tz6o/PSTjDbYXBwlSrPSzcAg/0U9tyy5719/ZczAndFlzSoFSypWdHZL7qI9b6WU4/j5yXYbX9+Yco/+/lLpy0axV4W7u7oTHhlO63KtKZm7JO83fz/V142q+mWRjKAXGAiLF0sve9QoWRneqRPkySNDzelQ7nJVr1W0G1KYjR6XaFbUm1W97mSdi1rFHRoqaUhzpHIU4UF2+rT8W/7yS0nH62QavJVS9gsIkF7n5MlSzevNN+U5ODRwgyRaOTbwGCVzl0zztTed3QRAWGQY2ch27wkREfDHHxKwFy+W/ddly8r3D9Lr9vJKcztSYpXXZzI8fnLB3QeCgqT336ULfPppurYpSVEFZIoXd247EnPzpoxg5M4tuyBq1pTfs83/npNLh82VUvY6dkzmBydOhF695Pm4cbJv9pdf0qUJFfJXsOU6m89sBmTRWzRjpIoZSPDu2VO2eD33HGzaBCdOQOfOybp+Sft3oCUse3aZtpg0Cc6msuJY374S/O0WtdXKifumk1S9Orzyigyh79sHbm6QP39Mqtp0psFbKZV2kZGyvxigQgVJKrJnD0yfHlOjuWxZ6NrVeW1MhXYV2gGQxSWLlIn86CNJKNKkiQRxd3dZQX7hAnzzjQyVJ3Ne2fe3oqxz6Wt/o6NSe8ZXXnPsWHkcOTJ1137zTflAZreMuM87PmPGSMrZ11+XxYfDhsHBg05pigZvpVTarF4N9epJr+7SJQlen31m63avxMTNfGZnJrTaRWoD4Na+g3z4eO89mbseNgzC7/TGa9WSRU0pVHHdfop8NNG2tkYLCpLH8PB7j5UuLelmZ89OXR3q69dl+Nhux47JgsXUjgikl/z55QPQX39JD3z8eGm7E9gSvC3Lam9Z1hHLso5bljUsgXOesizroGVZByzL+tGO+yqlnGjPHmjXDtq2lTzQ06ZJhrR0FmkiebzK4yzotsC+wL1jB/z5JxduXpB7/Pef9Az9/GRP9ksvpbnqVMHPCtJyUt2kT0ypJ5+Ux4SGoN99V+ZtZ85M+bV9fGQ+3W43bshj1H7vjKx/fwngTi4XmuYFa5ZluQKTgTaAP7DdsqxlxpiDsc6pCAwHfIwxVy3LKpzW+yqlnOjUKUkfmSePbIMaMCBVvU+7LD68mNpFa6ftIoGBMH++9Kh27YIGDZjzqEwFhGxaR4589i+m2nnrGNN2TqNfvX62XztB+fPLfntnpPRMyJYt8rhvnxRbycjc3CRxyz//OLUZdvS8GwDHjTEnjTGhwE9A3BUNLwGTjTFXAYwx9mZiUEo53rVrMQvOPD0lY9eJEzB4sC2B2xpjRf+X7iZOlJXO/fvLVqrJk+GPP3jjnMzBekTaO8M4bee06K/7L+9/1/M0W7NGHi9eTPicKlVkr/nVqzHZ7lTK7Nkjj46YRkgGO/5FlgBiT1T433kttkpAJcuyNluWtdWyrPY23FcpZSc/Pwle5crJqukoISEwYYKsIO/ePWYhVI8ethQMCY8MvydgOzyA37olw8ZRGd1KlJDSm1u2yB/lAQMgTx6ynjwj7YmIsPX2vx78NdHnaRIWJo+RSaR03bdP5vEXL7bv3g+SRo1k6139+k65vR3BO77/y+J+lHMDKgItge7AdMuy7qkSb1lWP8uydliWtePSpUs2NE0plahDh2JWiRsjC5n8/GQFbWSkDCNXqSKrjOvVg+3bbduLe/X2VT7a+BGlJ6Tj9qD9+2HgQAnWL7wAv94Jmt26yffeuPFdq8X/LCWBMCwyzNZmdK3W9a5MaF2r2bgKv0MHeUzq91S1qpwzfHj8i9vSU1T2soy+2jy2KlVkeqVyZafc3o4kLf5A7J94SSDuHgV/YKsxJgzwsyzrCBLMt8c+yRgzDZgGUL9+fR3LUcoRLl6UZBM//AA7d0pu7UWLpMd98GBMDueLF2Vfb+XKsGqVLExLg9i96dcbvs70XdO5FXaLtuXbRi8MS62yecuS1+Oe/kCM0FBo3VpyaLu7y6Ku/v2hadNEr7u9iPS4wyPt7Xn3q9cP+vXn12rQ9Y1v03fOO4qbG3zyiezbnjFDfh5JGTjQMYsSo/7NlYg7aKsSYkfw3g5UtCyrLHAOeAZ4Ns45S5Ae9yzLsgoiw+gnbbi3UiolXn4ZvvtOetX16slw+DPPxBz3uJPDO0sW6ZVt2SIZwlxd03TbuMPgE/+eSC+vXgxpPIRaRWvdc07B7AU5H3ie4rmS7uW7WC6cfD2ePyeHD8vw/4svSsCuUUMC1XPPJTu9ZadL+ZlTKoAsbvYn4ujn3oh+FTuA3YF7yRJ59PePSYuakE6dZAX56NGSbCaptKnJCfCpUbEifPABlEx7VrwHRZqHzY0x4cBrwCrgEPCzMeaAZVljLcuKSjO0CgiwLOsg8BfwtjEmIK33VkolIjxceswvvijz1iCBeNgwKRG5Ywe88cbdRUIKFYKnnoKHHpLndeqkOXAnZM7jc6IDd2yHXj1EUFgQPRf1JCKlPd6QEBnqb9lShoUHDpRFWSApLYcMSVFe6mplvQFw83BALnBf39QnS7GLZcle5YsXY5K7JObCBdnLb7djx2QFt7+//de+T9myhNIYs8IYU8kYU94Y8+Gd10YaY5bd+doYY940xlQzxtQ0xvxkx32VUnEYI/NwgwdLL6Z9e5nXPXRIjg8YIDnGq1WL//1ZssCCBbKa3EmqFKzC5Ecm89epv/hw44dJnh9pImkztw1z5w+X7/nZZ+HMGamTfepUmhbVna4p8/ERWdO2pzten3widaLt9thj8pjcXqyPj0yXPPVU0ue2aSMpQu125Yo8Ru33VknSwiRK3Q8iIqSHvGOH1G52d4eOHWUo9JFHnLoHGyTrWexh8fiSqXzS6hOuh0iy7+dqPcdav7WMWT+GFmVa0MKzRaLXX3NyDc3q1YYWLaBfP5nftqHs5k+7fwAg9NYNyJorzde7y/Dh8pgRtmpVrSqPV67IPvD0tm2bPB48mOa1FQ8KDd5KZVZXr8LChbLwzMsLvv5atq3Mni2B2xl/hOMxbM0wGpdsHP08oSxo7zR9J/pry7KY8sgUjDF45vVM/AZRwc/V1fbCJ0NPlWB4mWN4GMdMHTjEypXyeP580nPesc2bJx989u9P2fuUU2huc6Uykxs3JGhPnSpz1f37yxxklSpy3LKgd+8ME7jXn1rP+M3j+fvc31QpWCXRc8euH8uQVUOin+fKmosfnviBMnnLYIzBJNRDjXo9qvdmo+ElJG91jq+L2X5th4lK25rSkYeWLeVnOWKE7U1S9tPgrVRGd+OG9K67dIHChSX714gRsv1p504ZanztNWe38h6hEaEMWDGAMnnK8H7z9+lQoQO53BMeeh61bhT/2/q/e14PCgui0/xOTNg6wZHNvYc1xgLXOM8zg9at5TH2QsTkKFFCFjDOm5f+qT+jhu2duNYis9HgrVRGZYzsRy5USMow7toli4UefRQuX5Zz6tZNdgnK9Pbl1i85eOkgX3X4iuxZshMYEkhgaGCKr5PNLRvuru4MWzOM7ee2x3tOzX+hMA5YEf6gGTpURm2i5uPjGjYM+vSx/75lyshjSj9wPMA0eCuVUVy/DnPnwjt35n4tS1ZKDxgg+61Pn5Z92XXqyIrqChWc295EXAi8wJj1Y+hSuQudKncCIOB26naHWpbFjM4zKJarGE//8jTXg6/fddzFcmHvN/Cy5Z3mdsfLUevJHnsMvvzS/usuXCiPZ86k/L1580rZ0z//hOPH7z3es6d8eLSb7vNOMQ3eSjlTVMDu3FmGxHv3luxnUaURp02TgN24sS2rp9NL0ZxF+bbjt0xsH1Ov2jOvZ8LD5sHBiV4vX7Z8zO86nzPXz9Bveb+E579tZEYZSf5sYj230+LF8Prr9l4TIHt2eUzt/vxXX4UjR+L/cHjihGNqbus+7xTLPH8NlLpfXLsWE5x/+EEC9u7d8kfT11dyiyeV6erHH+PvGdkgrdW9Ik0klmXR06snZfKWiX5927lt8Q+b//333XOdYfHnEW9SqgnjHh7HxtMb70qnGomh0YdlmVHT3vzjAGZEBGZkOGZkEkU+UuP9921fHQ/E9IxTm2o0a9aY1eZR+6+jdOkiOQTsFlUgJiqhjkqSBm+l0sO1a1JCs1Mn6WH/dCdP0TPPSMA+dUrqYjdqlLwedsuWtjdx85nNaa7uFRQWRJ1v6/DD3h/uvf7ZzTFPAgJiSipWqQKNGzNxJYxbC6xfn+D1h/oMZd8r++5Om2pZ/B3mx7n8DkikMnGiDCUnMTKQKh9+KGsaMqrBgyVnQGio4++1a5c8Hjni+HvdJzR4K+UoN2/KnttHHpGA/dxzsHevpOxs1EjOKVAg+QE7tr/+sjW5x5azW2j6feJFOpLj440fs/ffvZTMncjc5ZtvQunSsgjPGMiTBxYvZtDf8N5GEs065mK5UCB7AcIjw5ngO4Fbobdifg6BKV8Ml6T/+z/5PaZHALPLsmXyeO5c2q7Trp0Mk0+zsdZ4QkqXvvtRJUmDt1J28vePSUV66JAE7k2bYNAg2LpVethffAHVqzu1mbfDbjN1x1Qm+Mr2q8YlGzP7sdlpuuaRy0cYv3k8Pb160tKz5T3HawXlli8mTYKuXSUHeayV8u/OeY4BnzSDzz9P8l47zu9gyB9DGLRyUEzw3rkzTe2P1+7d8mhzPW+Hyn3n55wljSMR7dpJjvuxYx3zwSi2wYPh55+lprpKFg3eSqXV4cOSR7tBA6lHPHSovO52J4Hh3LkSkBo2dPq2rstBlxm7fixlvizDK7+9wm/HfsMYg2VZ9K7Vm7ARd88bJ3eRljGGV1e8Sg73HHzeJp7gawwP77lBrhBkcdKcOfd8gPn45Gy+Cd4Y83NLRKOSjRjedDgzd8/kx30/JquND4yoKZXChdN2naiiJZcuJesDVZrvlZGnEDIgTY+qVFp06yaFPwC8veGjj6Q+NsTM323YIAt9nGzOnjm8vPxlboff5tGKj/J2k7dpXqY5VqwPFG4ubqlaVb3t3DbW+q1lyiNTKJKzyL0nnDrF5ewQmJWkU2+OGAE5c8ZsmUvAmIfGsP70el5eMYBCt6BUjjwpbrdKgre3FCyZPVsW2I0dK2sAlNNpz1up5AgLg7VrJZNZ5coQFCSvP/645BQ/e1bScw4fHpOqNOocJ66g3X5uO8evyKr0moVr8kyNZ9j/yn6WP7ucFp4t7grcADdDb/Lp5k/ZfXF3iu7TsGRDtr24jX4J1aYuW5aw8p7Ju9ju3ZJFLok5fTcXN37s+iPuru5cygp9WWJ/FrRad0qWOqIs6ksvwYwZ9l/3xzsjEadP23O9iRNlcWGWLDKs/fDD9lxXpYkGb6USc/CgLDQrUkTSTs6cKeU0o7bQ9OghW7wyUHKJSBPJb0d/o8WsFjSY3oDxm8YDUKdYHWZ2mUn1wgnPt98IucE7a95h27nk5wk/H3geAO8S3ri6JBzkink/TC7X7ElfsGtX+TC0Y0eSp5bOU5qrwVcdl8a0Y0fIlk2qtNlt2jTo29f+6xYoII92tbloUVlUGBEho0jHjtlzXZUmGryViu3KFZmPjQocwcGy4rhTJ0mqcfmyPCYnWJcrJ48NGzquvXHM3zefmt/UpOP8jvhd9eOLtl/wv3b35gu3y64Lu/D80pOFBxYmfNKKFdC0KRt2LiIwIijpi3buLPPeUdMRyeGopQRDhsgISrZs9l87Ko+43dq1k8diNhZTiYyUut8tWiScOlWlKw3eSgUEyDBt69YxW7qihh7r1IF//5U5v8cei8lelRx57szBOjhf8/Xg69EZx7ad20YWlyzMfXwuJwad4M3Gb5LL7jrUd0SaSF757RXyZctHm/JtEj5xzhw4coSd2a8ler1py+B/vyO5tR96SIK3s2tdjx8vi6lu37b/2hMnSrrRzMDFJeZDgQOqt6mU0wVrSvXtK3tjq1SRleKPPw716skxy0r9lpuoTGE3btjTzlhiDw3ndM/JkqeX0KpcKz5q9REebh73zGU7wvRd09l2bhtzH59LXo8EFjFduwZLlkidaL5K9Hov7Yr1pGdPWLVKer1JZJszIyOxxsb0Q2xNYxq15zw01DG9b0eIGrE4e9beutxvvSUL1jLQFNGDTIO3Uv37yzxr7972XtfbW1JV2rx3Ne6c7s3Qm5TILakws2VJnwDz363/GLZmGC3KtKBHzR4Jn/jLLxASAr160WDaV2xL5O/+y7O6cSXkGj+D/C6S+/swBjMaGDMGRo5M/jeRHAcOyGNm2ucdNdLj4WHvdXPlkkVwKRl9Ug6jwVupRx5xzHUtK9FsYSlhjGHNyTV8tuWzeI9XKVjFlvsUyVGEi0MuJjnUvtV/K+GR4Ux5dErivfw5c2REo359fEbAoUIJn/rtKcnzbY2xYnrPJ05A+fIp/TYebD4+8N13UkrWbpoBLcPQ4K3U4cOyIKdaNWe3JEFnb5yl/bz2FMkRzx5qG7m6uMa/TzuOzpU7c3bwWfJ4JLK32hgpXZozJ1gW54rnIjBr/Jm64supbkrPlCmNI0egUqUUfR9K3e90wZpSr74qQ+cZSGBIIP/z/R/9/0/aVTpPaVb3Wo3f6373zOnaOcd7I+QGI/4cwfZz2+M9HhYRxqrjqwASD9wgIw8vvxy9KCtbsVIpa0zr1vK4aFHK3mcn7zs1wpOR9S3F3nhDqsrZbc4cefTzs//aKsPQ4K1UBnI+8DzD1gyj1IRSDPljCEevHCUkPASAh8s+TFa3rABMfmQyQxoPsXdx1ubN3Hy0DeM2juOfi//Ee8rEvyfSfl57fM/6Jn4tYyQtbKwENflrNUp8n7chunY2IKlmGzRI2ZYxu3XsKDsQ0ponPD4TJkieALtFLSjTuen7mgZvlTkEB8O778LGjVLcI4Gaz5nZ/x35Pzy/9OSzLZ/Rtnxbtr24jb+e+ys6YMf26opX+cL3C3tufOyYLNhr2jTRrFxnr59l9LrRdKrUicalGid+TV9fWXC2dGn0SxP2zyQwIijeJCpmlIEIooN39IeSrl1lz31i2cIsS3YLPPNM4m1Kjf79Zd7d7sVfAC++6JgMa1EZ0Io4dopFOZcGb5Xx3bwp23Q+/hiaN5ftL1mzQvHiMH26nHPtmtTDXrhQqnedO5fhVwgbY1h/aj0bT28EoEmpJrxc/2WOvnaUn5/8Ge8S3o5vxFtvyVz/qlXwwQfw22/y+uFD95z6xqo3iDSRTOowKenrzp0rv7OuXYE7c9pJZEEz48CMjTMNELVSP7Ghc8uSJDqOmBefMEFWWTuinveMGRLAlUoFXbCmMj4PD/kvOBhGj4YSJWQPq79/zOrXY8ckG1Zsrq6Swerpp+H4cfj2WxmKjfqvZMm0V15KhfDIcBYfWsxnWz5j+/nttCvfjt/L/E6B7AWSFxjTKiwsZhg4MhJeeEF+rkWLwrE7m60vXbrrLSuOrWDRoUV89PBHeOb1TPz6ISHw008SeHPFWrVuSHkmtAoVpPfeokXC5xgjHzoqVbI/gEd9aAgJyXz7vM+ft3eft8pQNHirjOvQIciXT4LKokWypatdO2jU6N5z69eX1KZnz979X1TZyePH4auv5I9wbH/8IVWsIiMd//0AP+3/iXfXvovfNT8q5q/I1Een0ruWzfvLExIZKWrLqJUAACAASURBVEH13Xdh1iwpHfnFF8kqUxoaEUrzMs0Z0mRIkueyfLmMhMS3TzuxAH70KISH3/t6586J388Y6Xk7Yp93VB7vdPr3YYuJE2WFfpMmzm6JciBbgrdlWe2BicjA2HRjzCcJnNcNWAh4G2OSrjqgHlxRZTSbNJFe1d698vqxY/EHb8uSQJ8vH3h53Xu8fXtJcXnpkvTYo4K7l5dD5wZjDw+bUYYbITcomrMoX7T9gs6VOydayMNW69bJEPnOnZLyNWoON07gLpq9MLc+BPevfO56/bEqj9GlcpfkZW7bulXyardqFf2SGWWwRlgyUWclsEK+cOH406GGh0tAqlAhQ5RWzfDKlo0pR6vuW2kO3pZluQKTgTaAP7DdsqxlxpiDcc7LBQwC/k7rPdV97uefoVcv+SM0ebK8FjW8nS9f6q9rWXKdwoWhbt20tzOp28WzdzliZETCZTNToE/tPuy8sDOZJ/eRnnbJkrKNqEcPyVUdDxfLhexhgCUfKo4GHGXFsRW81uA13FyS+efis8+kdx+njKZZ5iUfwhLKV54vnxyLe9zVVZKOlCypwVupO+xYsNYAOG6MOWmMCQV+AuL7P+wD4FPAASs/1H3BGFl09vTTsr92yxbw9JRjURWSChZ0WvOSy/esL08siD8lqotlzxrRmV1msuflPQmf8N9/MQv2GjWSxX5Hj8qHogQCN8D1sJu88UR2tlj+GGN4dcWrjFo3ioCggOQ1LGp4Ob4PWa1a3T0HHldCQd2yZOHbunVSRCY9+dwZgXDEPu/335f0sUqlgh1/SUoAZ2M997/zWjTLsuoApYwx9uSKVBlPeDhs2iTbuFLr9m3pYXXtCmvWSHWpKFF/tK9fT1MzHSXSRLLk8BJ8ZvrQZGYT1p1a59D7TfCdwIDfBtx7ICgIPvxQUorOnSuv9e8Pw4Yla8HVrfw5megVxP66JVl4cCFrTq7hw4c/TFbWNUDm0d97L/5jAwfC6tXJu05cTzwhH0ZibT1LFx07SmlXR9Tz/uCD6NX4SqWUHcE7vkmw6I/QlmW5ABOAJFe6WJbVz7KsHZZl7bgUZ7WryoCuXJHSmc8+K0PRzZrB99+n/Dq3b8tCsuzZZa7755/v3Ve7/U7Gr0P3bmHKCILDg3np/17ifOB5JrWfxJnBZ/jxiR/vOsfOhCpv/vEm3+z4JuaFiAgZGq9USXp0rVunacHSjZAbvPH7G9QtVpdX6r+SvDcdOiT78BMaHfnqK2iTSOnQxNStK6Mw8SVssSz46y/7C8uATDFs2iRbE+3WqZNsRVMqFewI3v5A7LyHJYHzsZ7nAmoA6yzLOgU0ApZZllU/7oWMMdOMMfWNMfULOSKpvkobY+DyZfk6LEz+mPboIb3kzp0l6L75ZsquGRAgf9D79pXnhQrFP6wb9cfTEZmuUiEgKIBxG8bRdGZTIiIjyJ4lO+ufX8+xgccY2HAgOd1zRg+R254JLT7du8vcdvHi8gFo8eLUbZu6cgWAUWvf5+LNi3zz6DfJX1Q3d67MT3fvHv/xVasgMP7c5kmyLHjqKRmWj7vy27Kkxx81xWKnyZPlZ+qIfd7Ll6f8/xel7rBjImc7UNGyrLLAOeAZ4Nmog8aY60D0R3HLstYBb+lq80wiKAj+/FNWfP/2m/Sqdu2SIDplClSsKPPTUQG3Th2oXFm2JCXFzw86dJCh9tdfT/zchx6CTz+NqbPtJH5X/ZiwdQIz/plBUFgQHSp04MrtKxTKUYhqhe4ubFKpgATPZqWbOa5BN29K4Y+XXpKh5aeeSnROO0mhoQAERcqWugYlGiTvfZGRkqe7XbuYkpRxHTwY/+vJ9ckn8W9rM0b+vdWsCTVqpO0ecUX9O85M+7zVAyHNwdsYE25Z1mvAKmSr2ExjzAHLssYCO4wxy9J6D+Uk48bJ/GlwMOTIIT3kjh3lj6VlRRecuEtYWPx7dePauVNqXYeGyjxoMwcGOJts9d+Kz0wfXC1Xnq35LG81eYsahW0OFskRe0ppwgTZp57a4eg4SvxY76692HeV50zM+vWy9e6z+EuWJsvZs4lnxYsK3Lduyb/HKFHVy8aMsT94R6VlddQ+79jfh1IpYMvSV2PMCmNMJWNMeWPMh3deGxlf4DbGtNRedwYTHi5zlcOGSe/l7J31h1WqQL9+ksgkIECGYl94IVlJPRIVEgKPPSbz2ps3Jy9w79snj+lYKckYw8pjK5m3dx4A3sW9GdtyLH6v+zHrsVlJBu5Dl2V+/k+/P+1pUFiYBOuKFWNeGxDPojVnKF9ePkQklVAlMVmyJD0tMnGi7Dy4dSv198korl+PnqZQKqU0t/mD7MQJmZ8sXFhyhn/xhXwdVQmqWzf5Y9mmjb0LdrJmlRzkvr5QtWry3vPyyzIc362bfe1IQGhEKLN2z6LmNzV55MdH+ML3C4wxuLq48l7z9yiRu0TSF4HofdHxFRZJlZs34aOPoFEjBmyDxmeBAgXsuXZalS4NY8cmPrTsnUSu9qJFJfVtYmrWlHnz339PeRszmty5HbOKXT0QNHg/KIyJGc6eNUsSoEREyCrdLl0kmF6+DGvXxp+hzI77jxkD48fL80aNYvZuJ0euXHD4sMMXrC0+tJiyE8vSZ2kfXCwX5jw2h60vbk1eZrE4KuaXHrJPKZ8kzkzEsWNS9zkiQvZO//MPrFzJ5NzPsOVP+/NWm5cvSnWvqOfJGTLfuFEWXyU1tNy0aeL7vJOjeXP5wJJeZUIfekgeHbHPW6k00H+R97PAQJlPXrFC/vvkE9lOs3atLBILDoYLF9I+DB5b9+73phsNC5Oe88yZsiI6as48g4idCW3D8xuoWrAqMzvPpG35tqkK2ra4cUPWG0yYICMVzz8PtWtH12r+qOAhjjS9zGy771ukCOaDFK6MHzdOEsA88kji5w0cKAl40sLNTaZcfv5Zpl8csYUrto4dZYRKe8gqg9HgfT+6fVv+6GzcKIEzTx5o2xbKlJHj587J4+XL9gfRuAk6bt6EJ5+UYc6RI6V6VQYN3ADNZzW3bVvXgUsHAFhzcg1dqiQzrWdkpKQwHT4cLl6UoP3xx/es4H6v4B4oiP3BO6XOnZOtgu+9l/Qq96++khKuN26k7Z5du0o5zTVrZNGjZUkegOLF03bd+HTpIlnWNHirDEaDd2Z3+7akjVyxQvbYfvmlzDvmyQODB0tvqEmT9NsfHRYmf0zd3GSYvlUrWVk+fbosdnuAZHWVXmEO9xSsKI6IkC1xnp6wbFnS88R2u3xZ1hUMGSJJRJLy44/ygaNXr6TPXbo09fu8Y2vVStLo1qkjzy1Lqso5wnffyULOoCDdKqYyFA3emdUvv8jc9Z9/SgDPnh0efzzmeFQd4vRWp46sUv/lFwngL74Io0YlPaR6H6qQ///bu+/wJsuvD+Dfu0l3oZTSUkopG8peZSkqskGUJSC8IjIsIIL8BEQFQREBQQVkKSIIyFI2yF4iG0TK3rOUMkrLsHSkud8/TtOmbdpmPGmS5nyuq1ea5snz3E0hJ/c6pwIAoHFI49wPjI6mhWgTJ9Iipl27aOrBkv3a5kpOpm1fPXvmfayUwKJFtH5BfwV8Tq5ds7x9APWC//e/zO34+WfKAaB0HoDFi+k2MZGDN7MrvGDNEaSkUO/6k08y6lEfP07pKPv3pyHp2FhKkmEM3Rutj49Vmotz54AtW+j7996z68CddYjc6pnQ9CUm0pB4pUoUfA4coJ+XKGGbwG2qBw+oJ61UWtKHD6mgijESE4GlS4GTJyl4DxhASYSUdvcu3eZUNIUxG3GAdwgntnkzzRcXK0arXr//Hjhzhh4bPx64cgX44QfKapU1F3hudDmvrZWC9vx5yq9trcQWCmtWthmahDZRPHCfuU9/q+1Xt2d+QEpg3TqgWjUqndmyJX3gadtW0etbXWAg7btXajrk6VPjC89otZSDYN48Za6dkzZt6JaTqTA7w8HbnvXrR1u5unenBCmxsRnDgm5u5i/86tABOHs27z215ggNpaQr27c7Ru8RQPdq3dGzuhHDxCbycvUCAPh6+GZ/cO5c+sC1Ywf9bcuXN+3kGgDa7Avu8k1qKo0IubgYv5irSZPcHy9b1rjhd4Cmidq1o9fOmh8Sly2jD1vWXtXOmIkc493VWX33HbBxI/UuOna0fI+szoYNlOxCt+pcSRs30pypvSQPMUJEvQgMqm9k5SwTlPMrBwBoWLIhJb753/9oi54QNMURGUnVv0wkvhSUiFgvhaliXF2pgldeddO3baNta7qRIGPUr6/cv2GAVp3HxFDdd8acDC9Ys2fGLBoyx9mz1FuxRm1slZEVqOzI0yRaAV3IXcHAom/rVmBCPwrg1avTiIoSUxbW6HQHBNDugLwsWUK9b1Mqlw0ZQoVTlNKuHfX68ythC2N2hHve9uzYMeVW6GY9L8B5ldN0XNkR7ZYpv6ju9O7lAICtO3+koH3ihHLzwwJUQMQWHj+mOfsePUzb/zxzJuUbUErhwnS+ixcp+5695HlnLB9w8LZn7drR0DmD+FKkf9m9u3eBXr3g8zVV2PIPLk9rF2rVUuT0cpykOW+pd18pDx7QuorcthquWkWrvU1dZf7778rs89a3YgWNbFSunPdQP2MFCAdvZveyBmy7DuAzZ1Ig+f13lG3zFgCgfv9ximeVkxMAOd4KW9tSUmiE4OHDnI9ZvJh+R1MTo+S1xsKcLGbe3rSg7NtvqdANY06Cg7c5pKQSld98Q2/KQlDRDWP3qNqarpJX4cK2bYcF4hPjbd0Ew65do1XVZ84AIz+mnznw62zQl1/SiJDSaW7j4iidrqkmTwZGjqQdDow5CQ7eplqwgLZD1axJSVN0vvgCKFWKclEbs+DHlho0oFsHWhGeVe0fa+PgbTtYZRwdTQsL9+6l+1OmULKQihVxaj8tpNr853Tbtc8amjalnOJKu3GDioCYyjdtK54pK98Zc3AcvHMiJb0ZTJ0KNGtGi2IAoEgRCn7z5wNRUXSclLRgJiKCVr6Gh9M+Xnv15pvArVv0YcPO3X58G6+WeTXTzw71OwQX4YKXF76MCfsmIFWbmsOzjdOndh/0r9PftCelpNBQbeXKND986RL93NU1vUda+B6NDhSPirOofXZDV9b1/Hnznt+8ee6PV6tm3roAXVpgXwP76RkrqKSUdvlVr149aRN37kgZESFlqVK6sCxljRpS7ttn+Pg5c6QMDZXy+XO6Hx8v5fTpUt6+Tfd37JDy66+lvH/f9LasXy/liRPm/R4FRJeVXaTnBE/ZYXkHiS8gpx2aJqWUMv55vOyxqofEF5Afbf0ofxu1Z4+UVarQv4327aW8csXgYSfmjpX4AnLd+82Ub0PPnlJWqKD8eR88kPKVV6TcsCH7YwcP0u+8YIF55/7kEylLlMj5cd3/N3NERkr55Il5z2XMjgA4Lo2Ikc69z1tK6kVs3kzlMrt2pcxNf/xBQ4Njx1J6xLQaygaNHk1zdQkJlDHL1xf48MOMx3fvpvzV48fT8OrQoVSX2RhvvGHRr+fotlzegtXnV2Nis4kAgPUX16OoZ1EAlLVsaeelaFOhDZqWaQoASElNgavK9Opp9/+7DyklivsUz/tgADh1inLMb9xIpVfz0LHYbuBLoeziMk9P6+SmL1YsYwogq8WL6bpduph37t69aRTLGmrWtM55GbNTzjlsvnkzMGgQlV2sVo0Wu+gKaRQpQttl1qyhoh+5BW5jTJxISVH69AFWrqSqW8aUTwRoe5G5Q5QO7nnKc3yw5QOEFQvD8BeGo04JKv9YyT8jKYgQAu/UegehvqHQSi06rOiAQZsG4XnKc5Ou1WN1D7z5x5s5H5CcTIsTly2j+++/T3/TPAJ33Xvj0xqadqPkKvkqVYCGDZU7X16SkmhbVqdO5i/AmzfP/MDPGMvEeYL3tm0Z30+dSukp69YFfvoJuHmTFqLpKJ0lrGpVmgOPiqJ5Ut3cX1ISFRvJKVlKt27ArFnKtsVBzD0+F9firmF2u9lwU7mhVflWSBqThAYlGxg8Xiu1qB5YHT/+8yPq/1wfp++dVqYh27dTKtlPPsnokarVxheCkbBOJrQTJ6h0qNLu3aN5/JUrM/980yYgPt6yCmJLlii/z5sxJ+UcwTs1lYa/+/al+4sXU5GPtWtpkVloaP60w88PGD6cVqQDNKQ+fDj17iMiaPsZAwAMrj8Yq7utRrOyNMy65/oeBH0bhH+iDa/kV7uoMaXlFGx7exseJjxE/Z/rY/bR2ZDmlnK8dYt6ia1bUyrZLVvMq2BlrS3py5ZRVTmlpabS4rusqXPv3qVUqHktOstNbnvHAV5wxpgJnCN4697AFy+m21KlzEsIYYhuu5U5e17btqWA3asXjQTUrEmlP+Mcd3WypZnQpJRISEmAu9odnat0Tv955L1IxCXG4cqj3ANWq/KtcGrQKTQr2wwT90/E4yQz87dHRlLAnjCBdh3oSkOawKa1wpX2wQc0haO24jKZ+Hium82YkZwjeFvTqlW0bczcaknVq9PQfVQUzav6+NC8O0A9lVTLtkHlJyUyof1x7g+EzQrD1UeZ9/veenwLAHDvv3t5niPQOxCbem7CoX6HUMSjCFJSU3Ak6kjeF9+6NWOL3+uvU63q0aPNLwe5dy/kF4AM+tGxA3dcHAVVBynxypgz4P+NlqpVi4pNWNojKVoU+PhjWsEsBPDff/RzB0mksvHiRovP8STpCYZtHYYA7wCUKVLGonO5CBeE+tJ0yIwjM9D4l8YYvWs0UlJTsh07uNxbGPpXEo2E/PQToNHQA8WNXH2eE11RmSNGfHCwZ61bA2+9Zfl52ilf/IUxZ8XB21JTp9IQ/HPTVjjnydub3vw/+0zZ8ypESok91/fgrxt/AQCahDax+Jzj9oxDzLMYzH1tLlQuyi0aHBg+EH1q98HE/RPx8q8v43rc9UyPd562FV1/P0NpNo8ete7QsFJ69gQqVFD+vO7utIpetw7kwgWqQteokeXnrl8fqFjR8vMwZgcePaJ1nbdu2eb6zhG8dfPR1vjkP2kSZdtSOngDQNmyFMTtiEarwYozKxD+cziaLW6GSfsnAQD8PP0smuM9GXMSPxz9AQPqDTC4orxkoZIAgAAv0+tg+7j54JcOv2Dlmytx/sF51P6pNjZd2pT++I3nd3HjxWrAqFHKrYWwNj8/y0cGDPH3p9Ef3Rz/kiW0+6JHD8vP/cUXGZnoGHNwz57Rcph4G5VZUKSLIYRoA2AGABWA+VLKyVke/whAf1AhwwcA+kopbypxbaOoVLwQRgHLTy/HZ7s/w434G6jkXwnz2s9Dr1qZ96zv7b0X3m7eCA82reLUopOL4O/pj4nNJxp8vGbxmnBTuaFCUfN7m92qdUODkg3Qd33f9A8DANCv+lUkIxV/m31mGwgOBp48se41tFoK3q1bA0FB1r0WY8wkFgdvIYQKwGwALQFEATgmhNggpTynd9i/AMKllAlCiEEApgDobum1jSYlvREJwYtuTBTzLAaF3ArB280b/6X8h5KFSmJ66+l4vfLrcBHZX8tXyrxi1nW+b/09hjYcCj9PP4OPt67QGkljksw6t74yRcpgd+/d6ffH/zUeu72pGlzhSYXx5FMFA6Jf2u9SsmTux5nj7Fka4ldaTAzlP5gyhdp9+zZ9z5iD0GppSPvBA7qNiwMCAmjWpiC9/SvR824A4IqU8hoACCFWAOgAID14Syn36B1/GMDbClzXeKmpVDAiNJQSsrA8XXh4Ad8d/A6LTy3G1JZTMbThUPSt0xf96+ZewGPP9T3wcfNB/ZL1jbpObEIsEjWJKFm4JMr6lc3xuG1XtqH98vbY32c/GoYok1ksNiEW4/aOS7//NPmpsgG8bVsqaBMcrMz59OmyvSlNq6U93QkJlMFt6VKgQwfrXIsxMyUm0machw8pQD96RMPXjx/Tl/5AqxB0/+RJSt1QrJjt2q0kJYJ3SQC39e5HAcjt3bUfgC0KXNd0d+4of84SJeijndK1jW1k/639mHpwKjZc3AAPtQf61u6LdhVprYChnnZWQ7YMQVixMKzqtsqo632842OsvbAWN4bdQGH3nNNuRt6LhEarweVHlxUL3v5eaSv59bKgPU1WMAOYhwclNnFUXl60MI6xfKbV0qyQrvccG0tvs48f021iYubjdWUlgoIoc7CfHwVpf3/aeXvkCLBjBzB7NuUZeuEFx++FKxG8DUUtgxPMQoi3AYQDMDi2KoSIABABAKH5lfXMUqtXU6EKc/d52wEpJUTah49Pd32Kcw/OYezLYzG4wWAEegda7boHbh3AgpMLMPKFkbkGbgCIfhoNAHiYkEeWLhMVciuEp0lP0wN4ITcF/447dgCtWgHTp2cuVuMItmyhrsyHH5q/z52xXCQnZ/Sc79wB9u+n+lBPntCXfooLIegt1s+Psvf6+VFgLlqUgrSXV+7Xatw4o3rvtm3AuXNA586O3QtXInhHAdAvDB0CIDrrQUKIFgBGA3hFSmlw8lJKOQ/APAAIDw93jBVmYWH05UD0k6fMfW0u5hybg+29tiPIJwiLOi5Cce/i8Haz7ip3jVaDQX8OQqnCpTD2lbFWvVZunnz6BIVHq/BUrUUh90LKznnfThuQioxU7pz5Zd064N9/gREjbN0S5sD0e89Zh7d1qSz03bxJuwkrVMgIzrpbJVJp9O8PHDpEn6vnzKFe+IsvWnZeW1EieB8DUFEIURbAHQBvAcg01iaEqAPgJwBtpJT3FbgmM1PWrGeD/hyE8OBw3P/vPoJ8glDOr1y+tOOHIz/g9P3TWNNtDXzcrFDa0gRPDjelbsDfDrTevGdP6yxY8/QEXn4Z2LeP0vY6+tgisyqNJmNxWFwcDW/Hx2d86fId6Xh7U6+5bFkKproe9OHD1Btu3pyqMVuTfi9861bK+tu5M7XHkVgcvKWUGiHEBwC2gbaKLZBSnhVCjAcVFd8AYCoAHwB/pA3P3pJS5l+xat18dPf8W+Buj67FXTP486P9j6YPm+eX63HX0b5Se3QM62jU8bpsaUE+vGUJAK21KGeFD1p+fpQaVhe8GdNz9ix96eafsxaJU6tp7tnXlyou64Kzvz8NUefUez51yupNz0TXCz9wgIrzzZoFtGxJgd1RKLLPW0q5GcDmLD8bq/d9CyWuYzbe540jUUfwwoIXDD6mZOBe2GEhvFzzmIACMLPdTKSkphh97VrFa8Hf09+ifd45KlOGEu04Ek9PyoOvNCmBRYsoo5ojL7ZjVrFzJ/WoAwOpvlORIhSUdcPburIMjuLFFzN64Zs30wcTR+mFO0AeSAVISR8TPTyMr8Ps4LRSi82XN+PR80d4p9Y7CA8Ox9fNvsY7td5Bye8z9h0rXTAjry1iB24dgJerF+qUqANXlavR53217Ku489Edk55jtF9+Uf6cQEZe+tKllT/3tWvW6a7o0kaNG5f3sczpSElD3paUdbc3xYpRL/zgQcfqhTtH8E5NpfGboCDaw1qAJWmSsPT0Unx78Fucf3gedYLqoFfNXlC5qPBJk08AWLc05Z+X/kRh98J4qfRL2R5L1CSi97recFO54cz7Z4zaeqaz/ep2tF3aFof6HUKjEAXybOeHdu2A6OiMZC1KstY+70KFaJWRA++ecEb6W6vu3qV53D59HCfbr625uABNmtDa49WrqRd+7hztC7fX0QTnCN46Dx7YugVWtfb8WgzePBh3n91FreK18Fun39CtWrdsQ9OT/p6Ez3Z/hjODzqBaYDVF2zBq5yiEFQszGLy/2f8NrsZdxY5eO0wK3ADQbmlbAMCLv7yA1HFaRdqabsgQWlmjKweqFFdXmpt2NBy47ZJua5Vue1VcHN0+fpx9axUATJxIyxbKl7dNex1RsWLAe+/RtrU9e4AffqDswA2VSS2hKOcK3o5QLcpEtx7fgkqoULJwSQR6B6J6YHUs6rgILcq1yHE+ece1HQCoNnY1KBu8c3Ll0RVM2j8Jb1V/Cy3KmbYEQj1eTUsWBKCVEurxamjGavJ8ntHOnaN3RqVt3gy89hpVKxs1SvnzswLHlK1Vrq60MKxYscxbq7ZsocCemgr8+isQHk7J/rgXbhwXF9pwERYGrF0LbNpEM0n21gsveNHMELUaaNasQM3jnYw5iakHp2LlmZV4r+57mNt+Ll4MfRHbe223ddOykVLig80fwE3lhu9bfW/y81Nlaq737VZMDN1evGjbdjC7odFQzzk2Fjh+PCN1p271tjFbqwICKFDntF7x77/pfF27Apcv03WuXAE6duReuCkCAzP3wnVz4fbSC3eO4A3QSoQCYNe1XZh8YDJ2XtsJHzcfDG04FMMaDbN1s3KllVq8UOoFdAzriBKFTB9GVsEFqcgYKldpAJw+DdSooWArHYy19nkziz17RsFZt/dZ92VoaxVAgdjXlwK0sVurjOHuTr3F6tWB9eupF16/PlV75V64cfR74atXUy/83DmgUydbt8yZgrcD02g1ULvQn2rl2ZU4e/8sJjefjAHhA1DEw47GcXKgclFZlEVNc6Yz1JVXIVUFqFxcoPk5AFjzFmUuK4BTIUYpV846NeRZngxVrdLNPcfFZd916OVFw61Zt1b9+is9PszKn70rVwaGDqXAc+wY9cI7daIPC8w4gYHAgAGU/uCvv6gXXrOmbdvkpO98jkE/G9rBvgfRuFRjTG4xGTPbzoS72vx808V9igMAPNTKb5v7vevvmc475cAUhBULwxuVLcjJ89tv0Lz+mHIaTvsOWFGbKhMoFbirVnW8fd6JiVT5i1lFYiJw/z5luD17loJtfDwF56dPM6eNUKmAwoWp9xwSQr1nXc7tYsXso5fr4QG8+SZQrRqwcSOwcCHQoAH1wp3186+pXFwo+1vVqtQLP3bMtu3hP5udyprG9IUFL0COkyjqaXn2gIUdFmJW21lW6bVXDaia/v2pe6fw2a7P0K9OP8uCt7s7/Y/ZQQvtMuVPoxc0GwAAIABJREFUjI3N2E9trpkzLXt+TgLTirpYY6IxOhq4elX58zoJrZaCcWwszUFnHd7OWrUqJoYCcnAwBeesVascJYtslSrU496wgSptXbpEQ+vWSEVQUOn3wo8ezfhvnt84eDshD7WHVXrdAPD72d9RxKMIWpRrgUF/DoKfpx8mtZhk3smePaPNlxMmGH58xQogIoIqDVTLn1XzJmnblpYPWyMxkLX2eRcgpmyt0q9aFRSUMfe8ejU9PmJE3pWrHIWHB9CtGy0Z2biRchRxL9w0ul64tfOw54b/VE7o892fY8LfExA5MBI1iys7cTP+r/EIKxaGqCdROHj7IBZ2WGj+aMHSpTSvnVOuwqZN6R21a1caw/I2sxJa//60zFc3CckczvnzwK1bGVur4uOzzyq4umb0mCtVyhjeDgig3rOhwLVpE5BksAai46tShXrcmzZRL1w3F869cMfAwdtOyXEy09C5klnRDtw+AED52tg6cYlx+HjHx2gS2gTv1DIzj6KUwOzZQO3alKfw4EH6eUBAxjFBQRTgW7YEBg82P/hev26dfd5btlCRjwkTgNGjlT33yJHA3r3KntNBabXA8uX0T6ZQIZp7Ll8+Y3g7r61VzszLi3rhurnwX36htPatWnEv3N7xn8eOWTONqTUV8SiCaa2noXZQbZMzqaXbv5+2g/38M41pdupEE5GvvJL5uObNgc8/B8aPp574u+9a2nzl3E+rfmuNuekpU5Q/p43otlZduEA94fq5p8c3SEqaYWndWvn2OYNq1WgufONGmoW6dIkKdISG2rplLCccvO1YoiYRKqGyTjEOKzn74CzOPjiLrZe34r/R/+X9hJzMnk1jmT3TSsOXLw+MGWP42LFj6R0nPt786zGri4mhz2QeHrlvrSpalJOJ2IKXF1VNrl6dgvj8+dwLt2cOskbSOZWaVgrDttp3AhZ93l9nzDknaBIy3TdZ797At99mrBJat4564H/9lf1YlQrYutX6G2aZ2e7fp89jkZGU8evhQ/rT1qhBgyddu2Ycu3w5EBVlu7Y6u2rVaF94lSr0mXj2bFpPYE26Pec83248/jzlhEIKhwAAPNWeip43QZOQ632TtG2b+b5ufvfff7MPnQMZe3U2baJsetOmGX+tevWy56VkiomKApYsybg/dqzhrVV//EG3ajXw22+0jrBYsfxpI8vMywvo0YNyem/aRL3wxo2zFz9RSs2atk964mi45+2EFnZYiKQxSYqX1vRSeQF60/ReajP21qSkAF99ZX7X69gxYPp0YNEi458zZQrwvek51/MUFES3lSsrf24rSE6m7eMXLyr3Web6dVpHqF8jJ6890e+8Q9dftIi2dDHbqV49oxd+8CDPTNkT7nlbyGOCB5JSk+CuckfimMS8n2AHVC4qqKBS/Lz/9TwN75/LI8EN8HLzMm/Oe9066prVqUPpqkw1dixlT3j/fVr5VLVq3s+xlnbtMqfisgM5Va3KurXqjTfMWzim7+JF2orv40OzIDNmGPe84GDq9S1ZQgH8vfess1WeGUfXCz91igrl2VNlLWfGwdsCHl95IElLm0CTUpPgMcHDIQL4iO0j8N2h73Ai4gTqlKhj2cmuX6cxzjFjgHLl8N+CQOCll4BVq8w73+zZQJky2YfNjaVSUQKT2rVpIvXo0bz3f//f/1GP//ffzbtmTlJSaHLXzy/foo9+1arYWFoQpkvraahqVdatVZ6ewLZtlu+cO3UKWLOG3ujffdf0N/zy5Smd5++/0z+vd9/lRVO2xkPb9oX/O5jhetx1fH/o+/TArZOUqmw2h2ENh6FGceUrZ524ewIA7cc2W0oK8N13tEVLpaJV4eXLZ96HbaozZ2hB2jff0Dn16Vay6Iaic1OiBL3jt25N+8AjInI/PibGevW8O3YEvvhC0XK0z54BN29Ss3VFMnQ1n7NWrVKrKTjrykr6+2fsfS5aNHtAjI+n4G2JY8dotXJgINC3r/mZyapXpxrWmzZRD75nT8dJQ8qYtXHwNsHx6OOYenAqVp1bBZVQwQUu0OqVqnRXuePes3vwdvOGj5vlGSFGv6xwYg+l7N8PDBxIFRs6d6bxUHOGuLOaM4fymPftm/2xTp3ondvQYjVDWrakXne9epa3y1yxsXR786ZJT9NoKCDHxmbc6veec6taVbRoxldAABXMyE/791PwL1WK5q4tHXBo2JA+rOzdS2Ut7aEUo70LDqaCKpam/Gf2jYN3HqSUEGmrbb7a9xX23tiLEY1HYGjDoShZuGR6FjR3F3c8H/0cLZa0QNSTKCzvshx1S9S16NqxCbFwV7sr8kFAMYmJNBzt7k7dq/btMz8+YID5S4STk4FevQw/PySElh+bEg3Cw+n24kW6taOFYwkJGTm3sw5v51a1KjSUes668vSff24fVasAqhuzbx9VK+3VS7lh7ubNKYAfP07z5y1bKnPegqp9e6BZs4KTi50ZxsE7B0maJCw7vQzTDk/Dmu5rUKFoBcxsOxNFPIqgsHtGd8bPww9xiXGIHhENIQQ+f/lzvL3mbTSa3wiTW0zGsEbDzM4yFjY7DN2qdsPs12Yr9WuZR0qq0NChAwXPzZspObShueQhQ8y/zvz5OS/wWruW8jju2kXvTMbSaGjhmKcn9cTz6R1NqwXiW3bHRcwDXpuAuM2ZF4dlzZft4UHBWVe1yt8/c+8563CxLnjbS+DW5ccOC6NEH0rPT7/+On3g2beP/oQvvqjs+QsaDtwFHwfvLB4nPsZP//yEGUdmIPppNGoE1sDDhIeoULQCQn2z5woc1mgYxu0dl16lq2mZpogcGIn+G/tj+Pbh2HFtBxZ3XIwAbwvmghV26PYhAEDX37sidlRs7gdfuEBD5H/9RUt/33mHVoLnJDY2Y6LVWFJSPsbKlTPvKdJ3gPKx49Qp04K3Wg3MnUslk4YOpQ8IWTVpYtbeqKxVq3TD2/Hx1HtOTfUGxhwGTtKv5etLX2FhGUPbuprPjrqaWqulhWmRkUCtWjSLYo15aRcXGvBZtIiG5b29aU2io8u6tIMxY3Hw1pOoSUTFmRXxIOEBmpdtjgVvLECr8q3Sh80NcVe5AwAEMo7x9/LHmm5r8OPxHzHr2Cy4qeykewSgxLclkJhKK+IfJT5CiW9L4O6Iu9kPfP4cmDiRFo/5+ADz5gFvv533BV55haKTKavN9+yhsdE//6RestJatQI++wz4+mtqX69emR//8sscn6qr+fzoEQVpXXDOrWpVQAB9DomJoenucuVoq1RBW2yl0QArV9Lnu4YNs8+gKE2tpj/d/Pm0o9DbG6hY0brXtKZRo+xn5IQ5HqcP3pExkdh4aSPGvDwGHmoPTGo+CXVK1DF6vnrPjT0AgBRtCjyRkbFMCIFB9QfhvXrvQe2iRpImCTOPzsSQBkPgrna3yu9ijJj/YnK9n65HD1oh1KsXpSm1ZsX52bNpnNiUHrWpvviCxlwHDqRIU6lS+kMJCbTjzZytVf7+GV9Zq1YdOkTB28ur4AXu5GRayH/tGtWDad48f67r5kaDP/PmURrVvn1pqsERcZUzZgmnDN5SSuy6vgtTD07F9qvb4e3qjXdrv4uQwiHoV7efSedqWqYptl3dBrWL4ZdS9/NNlzZh5I6RWH5mOZZ3WY5K/pUMHm9tQd5BmQJ2kLfe1qu7dynS+PpST3XoUOsGVIAyqa1fDwwfbt2xY7Wa3u2nT89WKumPJjNw5Wlx4K23oFbTym1jt1Y5o8REGr6OiqLZiPyef/bxoX3f8+ZRIpd+pv2XNYm/P2Wd4787szdO80/S+2tvJGgS4KHyQFhAGE7GnESQTxAmNpuIgeED4efpZ9Z5dcPl+sPmhnSp2gXruq9D3w19UfenupjVbhZ61+qd65D8mJfGoEpAFbPalZO7I+6ixLclEPNfDIK8g2jIPDUV+Okn4NNPaXz3hx+ABg0UvW6OfvqJJk4HDsz9OF2ZqZIlzb9WyZLA1Kn0/fPntIgNQFKCBoHau+g9Mv+3VjmaZ88o3en9+7R+UbegP78VLUo98AULTMuEa6r33qMpEx7eZvZGkeAthGgDYAYAFYD5UsrJWR53B7AYQD0AsQC6SylvKHFtY+gCNwAkpiYiMiYS81+fj7drvm3xEPbWq1sBAMmpyfB0zb3QR4ewDogMjkSvtb3QZ30fXH10FV81+yrH4z9s9KFFbctJpjnuf/+lwHn0KI19WrJa3FRSUja0117LKCuUk06dcD/VH4HG7vPOza1bwKuv0lx32jy+WqRy4M5DfDwF7vh4Wvhfvbpt2xMcTMnxFi+23jXUauvOGDFmLouDtxBCBWA2gJYAogAcE0JskFKe0zusH4A4KWUFIcRbAL4B0N3Saxsra3UrCWny8HhOImMiAQCp0rhyOyGFQ7Cz105MOTAFHcI6UHv09pLruxl/E95u3ijmZaXSSgsWUNeiWDGawOzRI+fV3sb66CPqFhlDCNq8G5d3prd5G4rj9s03UHyZB/pGWLgVJjiYeuEDB9qu6+hgHj4EFi6kAYsePexny3zZspRGdeVKSj3AmLNQYhlNAwBXpJTXpJTJAFYA6JDlmA4AdINbqwA0F7mNFyssa3Urs6pdKUjlosKnL32KqgFVIaXEu+vfxdf7vkaqNvMHgPCfwzFuj3JpNdOtX0/z2S+9BAwaRMuFe/a0PHADtIKoY0fjj/fzo+XYOdBqKb/17Z0Xgenf496xm5gxg3aMmU2tph6/pyd1IbOmLGOZREfTCu+kJJpVsZfArVOtGpVyb9LE1i1hLP8oEbxLAritdz8q7WcGj5FSagA8BpAteZ8QIkIIcVwIcfzBgwcKNI08/vRx+vdeajOrXeXg4xc/BoD0fd6mStGmICU1BWP2jEGLJS1w58kdxdqWoyFDgJkzadh61iwKoAp5cvY2tNE5rGDXFxlJvd4zZ3I8RKOhFOWnTwOIoteluvoivLyo9vPy5dm3axktJIRWO50+DVy7atvqY3bs5k3qcQP0uUyXYt7e8GJC5myU+OduqLuWNU2WMcdASjkPwDwACA8PV7yWokqoFA3cgPEL1nLipnLD0s5L0bp8awzePBg1f6yJBW8sSB9SV4RGQ4vQwsJoH3VoKCU/jorKtGXK2FPlWrVq1ibUKv8f3jw8IvcTzZ4NnDuX4wK05GSKrTdu0PT005O3cRxAcZ//0GUwpeLUbcVq397M+dc2bYBPPgH+KAK0aGHGCQq2y5fpA5KnJ/W4LZ37FSL3CqkjR9JIC2Msb0oE7ygApfTuhwCIzuGYKCGEGoAvgEcKXNvmdt/YDSD7Pm9TCCHQu3ZvNC7VGD1W90Cf9X1wrcw1PEx4iDnH52DN+TWGE6kY4+hRyjd+8iTdtmuX59LZZ8+o5rMuOOvSesbFUZUnfVmrVp1zSUJCah5Lc+PjaY69Z0+Dvf6EBFpBHB1NzW3cGFg/LfM127al4dK1a2m+8+xZSqFp8lz4V18BoYATbbwwytWr9AGpcGHqcStRw/njj+nfVU54wSBjxlPiHesYgIpCiLIA7gB4C0DPLMdsANAbwCEAbwLYLWVun8Gto1pgNcXP2axMM2y/uh2uLq4Wn6uSfyUc7HsQ5x+eR5VZGVvEYv6LyTkTWk4ePwZGj6ZKXSVKUMazzp0BABqtC+4jCI9veuHRgbyrVnl7U4AuXTrvqlXXByQCyCOC/vorRejBg7M99OwZDdM+eEAVpOrmkisnNJROsX07cPgwJVp5/XUK6kZTq2mPhHHrDZ3G5cvU0+7TR7lkIj4+nJiEMaVYHLyllBohxAcAtoHeBhdIKc8KIcYDOC6l3ADgFwBLhBBXQD3utyy9rinULmrIcfn+WcEs7mp31A6qbXwmtBwk/PEnHs7egIfdJyGux2DEJvkg/mcKzk+e/g/AP8D+UsA1w1Wr9PNuK7rHVaulDxSNG2fLkR4fTwvgnzyh4haZgnDJYADRQPHMY7dqNfXOdb3wFStoCN2sXjhL/1uHhNBQuaPmXGesoFNkrFBKuRnA5iw/G6v3fSKArkpcy95suLQBgHH7vE2RayY0pFWtiqce6qNHacPbF+4j/tI9xIfUQFJiD2BACyAgEDhOb8J+frRL6knJEODEP2j6qgvqtTdctcpqtFpK6pxlrvv+feqQJybS3t1sOasbNQYelAFqGZ4jL10a+OADC3vhDF5etHswOJgXgDFmz5ziv6dGq4HrV65oEtoEf/f5W9Fzn39wHoDx+7yNdXfEXRSfXBL37wP+qITlr+zB6tVZq1alHZyaCnHkMHz3bYSvtwZhP05C0UBXFC0aaLBq1bwrgbid3BYhVQopMpeZSatWQGAupZLU6mz5LKOiaHGaVktpL0OzF2+jXyCoOOCZc1fQUC+8Rg1a0Ma9cOMZfP0ZY3bFKYK3jq4UppJcVZbPdefkM887eJhWMnvXLkpC4esLFC9Oe239/YGiN07Af/xQFL1wAC4dO9Kq8lJ5tOnGdWDbTmBkEACFJyHr1gVyytFy6xbVj+zbN32y/Pp1Wrumi+lBQTk898hhYM7fQOk2QKvcU7fqeuFbt9J6vWvXKJVnFWUzzTLGmM04VfC2ho8afYRPdn0CT7VyQ+Y6z54BZcrQLqaAAAO9x0uXgBfDaYJy3TqKUMZ4+oxuk5OVbC65dw9IFQAM7CuaOxeYMoUWzhUujIsXqXfs40Pzq8VySyR35Srd3rwJyguUO7Waety6XviyZdQLf+ONgjGPO2gQrV9gjDmnAlao0EasuDe1SBHqSaYHbikpHzlAe7SXLqX90sYGbiAt6wloollpCxdSRM4qMZHSdL3xBhAailOnaA+xry/1uHMN3BYoW5aSyTVsSPlgfvgBOH/eOtfKT8HBPJLAmDPjnrcRNBpaFBYbm3Gr21o1b3cIEP8lDjRLRQsFambk6soV6nLt2UMZyqpVo0TTjuCPPyi7y+DBOHYM2LiRtiL17Wv9+WhDvfBatehn1uyFe6dNeXgqPyjDGHNyThW8G4U0yvGxhASKLQ8fUlDWJSd5/JgWh+nvStdtrfLzA0oXKYNr8Vexc5s7bl4BunRRJqFFJsnJNNw8YQJNfOuypTmS2bOBypWx3705tm0ASpWiko75OYRdtmzGXPixYxlz4dZSsyaVSG/Z0nrXYIw5J6cI3moXNVJGSzx5Aly8qLe16lHG6u2kpMzP0d9a5eeXtjhMLzGJbmvV8oO05PuFF7X49zilCm/ZkoZpFZGqoZOdPElFNKZNo0ZZomQwcOkyUCifMmY8ewZ4emJHvVHYt12gXDmgVy8TtyKVKgUgmhLOWMDNjUbuq1WjZQK//Wbdso+tW1vnvIwx5+YUwVurpdLN+oSg+VZfX+rE6rKGGdpalZtDtw8CALamjMYXg77F6tXApk00Dd2pkwK9cJUa6N+fKm+1bWvhydKULg3gMuCr9BBBDnx8sGn4Hhw5LBEWRglYTN5D3KgREFceqF1ckSaVL0/1WbZsoaqkrtbbNMAYY4pziuCt0WowYd9EBHoHYd+0iPRetKWJSUbtHIVnyWoA7ph7bDYK+agwacA32LcP+Osv6oW3bg3Ur2/mBW7eAAq7AkOypxG1SJmyQJu2QBHlqomle+01oHjGPytt/BOs+UODyFtFUbuOQKdOZr7uvr5ABV9Fd7a5udGweb16CmeRY4wxK3Oq1eYPEu6hcmXqWSuRUWzNuTXZ7ru4AE2b0royf39gwwZagB0fb8YFli4F/vzT8oZmdeM6sHULEB+n/Llr1ADCaBm0RgMsf38fIgfOReOKD9ClSz5mcjNBSIj1hs0ZY8wa7PCt1HF0rto5x/uBgVTEq3lz2po8axYtkrILuk8SiUm5H2eOW7eA6DtU0nORFhe2XEfTqg/Q7p0Ai06rG9Z2d1egjYwx5uA4eFvgmxbfoEnpl+Dn4Y9hjT/CNy2+yfS4rhc+cCAN02/YQKUunzyxTXvTnUvb6Pwwl/qM5lq2DMm/r8fChcC1HVfRJn45mo9pbPFpW7WitQmNLT8VY4w5PKeY87am1uXboGkI8GmznI8JCqIAvncvsG8f7fRq0wYID8+3ZuarmwkBEHeADlGzEB50nVbuWUitpoIljDHGnKTnLSAAAGX9ytqsDS4uQLNmGb3w9evtpBeuMCEkVEKLbs0eIvzIHCAigleDMcaYwpyi561yUWHMy2MhhK1bktEL37MH+PtvYOZMWpFusBfetStQ0wqBL7QUcOlCenEQJbXz2Qf3sjcQ2rQ7ZYTTpRljjDGmGKfoedsbFxdayDZwIO2AWr8eWLzYQC+8YiWgdBnlGxASQrdWCN4V3W8j1CuW7pQubb2k5Ywx5sScInjTPu/xmHnkB1s3JZOgIOD992lR27Vr1As/cULvgMuXaK+3wlTlywBt2kLt76v4uTFjBtUsbdfOzP1xjDHG8uIUwVsnPjEO8/6ZZ+tmZKLrhUdEUC987VrqhT97BirmsX274tfsUnQPSm/9EeV9YxU/N5o1A44coS1jvlb4cMAYY8w5gvfPJ35O/37ApgF2F8ABSlf+/vvAyy9TL3zGDCBFWidnZ5FH19EfC6gai9K++w745x9g8GDYxSIDxhgrgJwieK87vy7T/dXnVtuoJblzcaGiJhERNB2dChe4QOb9RFPt3k239+4pf+6RI+n27beVPzdjjDEATrLavEvVLtiJmEz37VlwMKVX/efz7Shboo6tm2Oajz8GChWiL8YYY1bhFME7ol4ENlb8Bxcenseo9j8hol6Ecic/fQrY8TcwIgKAcsPcajXQ0PVfwKuiYufMF998k/cxjDHGLOIUwRsA6paoh3rB9RBRT9nzig3rgURJe7I3rzKj1mUu1q2jAuJKq1+fNpoXLar8uRljjFmdU8x5K0pKqvY1ahQA4K0hASiBGHjtWA/07g2kpip3rRdfBCpVUu58OlWr0i2vBmeMMYfEwdsUV65QhYy336Yk5YmJKO//GO9jLjBuHLBsGdCnj3IBfPVq65Qia9gQmD2bapYyxhhzOE4VvM2uJZ2cDHz9NVC9OnD0KAW+/fsBDw/gl1/omA8/BL76irZJPX6sTIMHDgR+/VWZc+k7coS2csVaYZ83Y4wxq3OK4O3iQlk6u3c38wT37wOTJwOvvw6cP08bslUqeuzhQ7qVEhgzhoJ70aKARgNotYq0X3HXrtHts2e2bQdjjDGzWBS8hRBFhRA7hBCX0279DBxTWwhxSAhxVghxSghhbgi1yIcfAlWqmPCEuDhg2jQKyiEhwNmzlPEsODjzcQMG0K27O916e1Pg7tEDGDKEnm9v/v6bbh9YoZ43Y4wxq7O05/0JgF1SyooAdqXdzyoBwDtSymoA2gCYLoQoYuF1rUdKYMUKivQjRmQkGw8NNXx8kbRfRX9MXqUCypYF5swBhg2zzwDOGGPMYVm6r6kDgKZp3y8CsBfAKP0DpJSX9L6PFkLcBxAAwP6qVly/TkPiW7dSjc4tW4A6eSRJOXSIblNSAE9P+l4I2u+s0VDvXa0Gvv2W04UyxhhThKXBu7iU8i4ASCnvCiECcztYCNEAgBuAqxZeV3laLdCmDRAdTYnFBw/OmNfOze3bGc/XJwTl+dZogO+/B3x8gC+/NK1NO3cCftlmIiz3wgu0z5vLdTLGmEPKM3gLIXYCCDLw0GhTLiSEKAFgCYDeUkqDK7mEEBEAIgAgNKdhaqUdPw7UqEFz1r/+SvPbpUoZ//xu3WhoXTfnrU8I+iDg7k4fDExVq5bpzzFGxbSsbZzClDHGHFKec95SyhZSyuoGvtYDuJcWlHXB+b6hcwghCgP4E8AYKeXhXK41T0oZLqUMD7BGZjF9jx9T77pBAyqkDQCNG5sWuI0hBDB1Kp0boG1axlq0iLakKa19e/rQknXxHWOMMYdg6YK1DQB6p33fG8D6rAcIIdwArAWwWEr5h4XXs5yUwKpVtCDtxx+BoUMzVoybY+5cuk1MzPvYLVuARo2AiRONO/eIEcDy5ea3LSf+/kC9eoZHCxhjjNk9S4P3ZAAthRCXAbRMuw8hRLgQYn7aMd0AvAzgXSHEybSv2hZe13yjRlEe8hIlqBc8fbplw8dPntCtMSvKddnZRo8Gpkwx/5qMMcacmkUL1qSUsQCaG/j5cQD9077/DcBvllxHUd27U+AeMkSZIiJDhgDjx1O2tbyoVMDChbSIbdQouv5HH1neBsYYY07FOaqKpaZSoBwwgIbK6ylYWszLi26N3QamVgNLllCbhg8HWrQAatZUrj2MMcYKPKdIj5o+pD1/fu7HmWPfPrpNSTH+OWo1VSbbsoUDN2OMMZM5R8/bmh49oltT85i7umZsH9u3D7h8GejXL/Mxhw/T/nDGGGNMj3P0vK2pY0e6tWTl9qxZQP/+NB+ur3x5oHhx88/LGGOsQOKetz1YvJj2nffrR0PqvXrRz+fMASpXBppnWxPIGGPMiTlXz9sa6UBnzKDb58/NP4eHB7BuHdCsGfDuu8CyZfTzceOANWssbiJjjLGCxTmCt0oFxMcDN24of25jkrMYw9MT2LABeOklYNs2Zc7JGGOsQHKO4C0E4Otr3F5sUw0fTrdKnNvLC9i8GViwgO5rNJafkzHGWIHjHME7NZUC+NtvK39uXaIXpcp9ennRSEF0NI0W3L2rzHkZY4wVGM4RvHX7vFesUP7cO3fSbXKysuf19qYCIt26KXtexhhjDo9Xm1tK6aCt4+sLbNxonXMzxhhzaM7R87amdu3o1s3Ntu1gjDHmNDh4M8YYYw7GuYJ3cLDy55w6lW4t2efNGGOMmcA55rxVKtp2pdSKcMYYY8yGnKPnLQQFcBcr/LojR9Ktp6fy52aMMcYMcI7grdvn3aGDrVvCGGOMWcw5grdun/effyp/7s2b6dZaW8YYY4yxLJwjeFsTbxFjjDGWzzh4W6pFC7rlIM4YYyyfcPC2lK54iG5onjHGGLMy5wreFSsqf87vvqNbpUqDMsYYY3lwjuC/ofEXAAAFd0lEQVStVlPP+Px55c89fz7d+vkpf27GGGPMAOdI0mJNnTvzkDljjLF85Rw9b90+7+bNbd0SxhhjzGLOEbx1PeO//rJtOxhjjDEFOEfwZowxxgoQi4K3EKKoEGKHEOJy2m2Oq7aEEIWFEHeEELMsuSZjjDHm7CzteX8CYJeUsiKAXWn3c/IVAB63ZowxxixkafDuAGBR2veLAHQ0dJAQoh6A4gC2W3g9y9Sta9PLM8YYY0qwdKtYcSnlXQCQUt4VQgRmPUAI4QLgOwC9ANhmubdunzdjjDFWAOQZvIUQOwEEGXhotJHXeB/AZinlbSFEXteKABABAKGhoUaenjHGGHMueQZvKWWLnB4TQtwTQpRI63WXAHDfwGGNAbwkhHgfgA8ANyHEMylltvlxKeU8APMAIDw8XLmuskYDuLoC9esDR48qdlrGGGPMFiwdNt8AoDeAyWm367MeIKX8P933Qoh3AYQbCtz54sQJm1yWMcYYU5KlC9YmA2gphLgMoGXafQghwoUQ8y1tHGOMMcays6jnLaWMhYFFaFLK4wD6G/j5rwB+teSaZlGn/Zq//JLvl2aMMcaU5jyFSXi1OWOMsQKC06MyxhhjDoaDN2OMMeZgOHgzxhhjDoaDN2OMMeZgOHgzxhhjDoaDN2OMMeZgOHgzxhhjDoaDN2OMMeZgOHgzxhhjDoaDN2OMMeZgOHgzxhhjDoaDN2OMMeZgOHgzxhhjDkZIO622JYR4AOCmrduhoGIAHtq6EXaCX4vM+PXIwK9FBn4tMnOW16O0lDIgr4PsNngXNEKI41LKcFu3wx7wa5EZvx4Z+LXIwK9FZvx6ZMbD5owxxpiD4eDNGGOMORgO3vlnnq0bYEf4tciMX48M/Fpk4NciM3499PCcN2OMMeZguOfNGGOMORgO3vlICPGVEOKUEOKkEGK7ECLY1m2yFSHEVCHEhbTXY60Qooit22QrQoiuQoizQgitEMJpV9MKIdoIIS4KIa4IIT6xdXtsRQixQAhxXwhxxtZtsTUhRCkhxB4hxPm0/yMf2rpN9oKDd/6aKqWsKaWsDWATgLG2bpAN7QBQXUpZE8AlAJ/auD22dAZAZwD7bN0QWxFCqADMBtAWQFUAPYQQVW3bKpv5FUAbWzfCTmgADJdSVgHQCMBgJ/53kQkH73wkpXyid9cbgNMuOJBSbpdSatLuHgYQYsv22JKU8ryU8qKt22FjDQBckVJek1ImA1gBoION22QTUsp9AB7Zuh32QEp5V0p5Iu37pwDOAyhp21bZB7WtG+BshBBfA3gHwGMAr9q4OfaiL4CVtm4Es6mSAG7r3Y8C0NBGbWF2SAhRBkAdAEds2xL7wMFbYUKInQCCDDw0Wkq5Xko5GsBoIcSnAD4AMC5fG5iP8not0o4ZDRoaW5qfbctvxrwWTk4Y+JnTjkyxzIQQPgBWAxiWZQTTaXHwVpiUsoWRhy4D8CcKcPDO67UQQvQG0B5Ac1nA9yya8O/CWUUBKKV3PwRAtI3awuyIEMIVFLiXSinX2Lo99oLnvPOREKKi3t03AFywVVtsTQjRBsAoAG9IKRNs3R5mc8cAVBRClBVCuAF4C8AGG7eJ2ZgQQgD4BcB5KeX3tm6PPeEkLflICLEaQGUAWlDFtIFSyju2bZVtCCGuAHAHEJv2o8NSyoE2bJLNCCE6AZgJIABAPICTUsrWtm1V/hNCtAMwHYAKwAIp5dc2bpJNCCGWA2gKqqJ1D8A4KeUvNm2UjQghmgD4G8Bp0PsmAHwmpdxsu1bZBw7ejDHGmIPhYXPGGGPMwXDwZowxxhwMB2/GGGPMwXDwZowxxhwMB2/GGGPMwXDwZowxxhwMB2/GGGPMwXDwZowxxhzM/wOgOH1+A6dfFgAAAABJRU5ErkJggg==\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 = proj_dr_cate.effect_model.named_steps['reg'].model\n",
    "predictions = res.get_prediction(PolynomialFeatures(degree=1, include_bias=True).fit_transform(X[:, feature_inds]))\n",
    "frame = predictions.summary_frame(alpha=0.05)\n",
    "pred = frame['mean']\n",
    "iv_l = frame['mean_ci_lower']\n",
    "iv_u = frame['mean_ci_upper']\n",
    "\n",
    "# This is the true CATE functions\n",
    "theta_true = true_fn(X)\n",
    "# This is the true projection of the CATE function on the subspace of linear functions of the\n",
    "# subset of the features used in the projection\n",
    "true_proj = LinearRegression().fit(X[:, feature_inds], theta_true).predict(X[:, feature_inds])\n",
    "\n",
    "# Are we covering the true projection\n",
    "covered = (true_proj <= iv_u) & (true_proj >= iv_l)\n",
    "print(\"Coverage of True Projection: {:.2f}\".format(np.mean(covered)))\n",
    "\n",
    "fig, ax = plt.subplots(figsize=(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], 'b-', 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": 678,
   "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(random_seed)\n",
    "\n",
    "# We need a model for the final regression that will fit the function theta(X)\n",
    "# Now we use a linear model and a lasso.\n",
    "rf_driv_model_effect = lambda: RandomForestRegressor(n_estimators=5000, max_depth=1, min_impurity_decrease=0.01,\n",
    "                                                     min_samples_leaf=100, bootstrap=True)\n",
    "#rf_driv_model_effect = lambda: GradientBoostingRegressor(n_estimators=3, max_depth=5, min_samples_leaf=100)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 679,
   "metadata": {},
   "outputs": [],
   "source": [
    "rf_dr_cate = const_dr_cate.refit_final(rf_driv_model_effect())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 680,
   "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": [
    "rf_dr_effect = rf_dr_cate.effect(X)\n",
    "plt.hist(rf_dr_effect)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 681,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "ATE Estimate: 0.05\n",
      "True ATE: 0.00\n"
     ]
    }
   ],
   "source": [
    "print(\"ATE Estimate: {:.2f}\".format(np.mean(rf_dr_effect)))\n",
    "print(\"True ATE: {:.2f}\".format(np.mean(true_fn(X))))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 682,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.title(\"DRIV CATE: MSE {:.2}\".format(np.mean((true_fn(X) - rf_dr_effect)**2)))\n",
    "plt.scatter(X[:, 0], rf_dr_effect, label='est')\n",
    "plt.scatter(X[:, 0], true_fn(X), label='true', alpha=.2)\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 683,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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RERERCQGKIgjInKaRx99lL1790a7Gi2yYsUKnn/++WhXQ0RE5IyefvppNm7cGO1qiIjEJAVxRERERERi3P33309ubm6HLU9ERCJDQRwRERERERERkRjgiXYFREQ6osOHD/Pqq69SWFjI6NGjmTlzJh6Ph9LSUl544QUOHTpEMBhk0KBBzJw5E5/PB8AHH3zAypUrKS4uJjk5mcsuu4yJEycCsGnTJlavXk1RURH9+/dn1qxZdOvWrc66n3nmGUaOHMnkyZOr5/3hD39g+vTpjBkzhldffZVt27ZRXl5Ojx49mDFjBpmZmXXK2b9/P88//zx333139bxHH32U2bNnM3ToUBzHYfXq1WzYsIGysjKGDh3KzJkzSUpKivTmFBGRJjh+/DiLFy/m6NGjeL1errjiCkaNGgXYIUgTJ05k0qRJgD3fbNy4kVtvvZWnnnoKsOcKYwyzZ88mNTWV559/nvPOO493332X+Pj4Wuek5pY3fvz46npWVFTwq1/9iltvvZXevXsDUFxczCOPPMJdd92Fy+Vq8FwZbsWKFeTm5vKpT30KgLy8PB599FF+9KMf4XK5KCsrY9myZezatQtjDOeccw7Tp0/H5dJv0SLSNenoJyJSj82bN3PTTTfx7W9/m5MnT/L2228D4DgOZ599NnfddRd33XUXHo+HJUuWAOD3+3n11Ve58cYbue+++7jtttvo27cvANu3b2fVqlV87nOf43vf+x6ZmZk899xz9a57woQJbN68ufr18ePHyc/PZ8SIEQD079+fO++8k/nz5zNhwgT++9//UlFR0ezv+N5777F9+3ZuueUWvvvd75KYmMjixYubXY6IiLReZWUl//rXvxg2bBj33HMPn/zkJ3nuuec4ceJEo5+95ZZbAPjqV7/KfffdVx1wKSoqoqSkhLvvvpvrrruOl19+uVXlVfF4PIwZM6bWuWrLli0MHjyYlJSUBs+VzfXiiy/icrn41re+xZ133smePXuUT0dEujQFcURE6jF58mTS0tJISkri4osvrr5QTU5OZuzYscTFxZGQkMDFF1/M/v37qz9njCEnJ4dAIIDX663+hXL9+vVMmzaN9PR0XC4XF110EUePHiUvL6/OukePHl3rvY8++ogxY8bg8djOkxMnTiQ5ORmXy8UFF1xARUVFky7KT7d+/Xouu+wyfD4fHo+H6dOns3XrVoLB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09M5deoUmzZtwu/3079/f8aPHx+5LyIiIoCCOCIiIiIindaZ8l82lhezqZ87fPgwt912G8ePH+cf//gHRUVFzJ8/n+3btzN79mz27dvXsoqLiEi9FMQREREREemkBg0aVD2dk5NTZ3rgwIGt+tzvf/979uzZQ3JyMjfddBMpKSl88YtfBCAQCLBy5coIfRMREQEFcUREREREOq3zzjuPnj17AvDcc88BkJ2dzdq1awGYMWMGYIdFjR49mscffxyAyy+/HI/HU+tzH330UfVjyas+l5+fD0BJSQlbtmwBYP369dXrT0lJabsvJyLSBekR4yIiHUhhYaED4PV69ehVERFprnov7P/0pz9xxx13ALUfMd6rVy8+/PBDMjIyMMaedn784x9XP13qvvvu44EHHgBg5MiRHDx4kNLSUkaMGMGmTZtISUnhjTfe4Morr8RxHJKTkxk2bBhbt26lsrKSvn37smPHDnw+X33V0nlORKQF1BNHRERERKQT+8pXvsIzzzzD2WefTXZ2NsYY5s6dy+rVq8nIyDjj537+85/z6KOPMnr0aPbt20dKSgo333wzK1eurO5hc/nll7NkyRKuuOIKvF4vO3fuZMCAAXzxi19k9erVZwrgiIhIC6knjohIB6KeOCIi0gqxdGGv85yISAuoJ46IiIiIiIiISAxQEEdEREREREREJAYoiCMiIiIiIiIiEgMUxBERERERERERiQEK4oiIiIiIiIiIxAAFcUREREREOodj0a5AE8VKPUVEOhxPtCsgIiIiIiIR0TeShRUWFjoAXq9XjwMXEekg1BNHIsYYM8MYs8MYs9sY8/163k8wxvw79P57xpjBp70/yBhTZIz5f+1VZ5GWtltjzGBjTKkx5oPQf0+0d92la2vNMdcYM9EY864xZosxZrMxJrE96y5dWyuOuzeGHXM/MMYEjTFnt3f9petqRduNM8b8LXS83WaMube96y5dVyvabbwx5qlQu/3QGDO9nasuZ6AgjkSEMcYN/A64BhgL3GCMGXvaYrcBpxzHGQ48Aiw47f1HgFfbuq4iVSLQbvc4jnN26L8726XSIrSu7RpjPMAzwJ2O44wDpgOBdqq6dHGtabuO4/yz6pgLfAHY7zjOB+1Xe+nKWnnN8BkgwXGcCcAngDtO/zFTpC20st3eDhBqt1cCvzbGKH7QAeiPIJEyGdjtOM5ex3H8wEJgzmnLzAH+Fpp+FrjcGGMAjDHXAXuBLe1UXxFoZbsViaLWtN2rgI8cx/kQwHGck47jVLZTvUUiddy9AfhXm9ZUpLbWtF0HSAkF0ZMAP1DQPtWWLq417XYs8AaA4zg5QB5wbrvUWhqkII5ESn/gYNjrQ6F59S7jOE4FkA/0NMakAPOB/22HeoqEa3G7Db03xBizyRiz0hhzUVtXViRMa9ruSMAxxiwzxmw0xnyvHeorUqW1x90qn0NBHGlfrWm7zwLFwBHgAPArx3Fy27rCIrSu3X4IzDHGeIwxQ7C9yAa2eY2lUUpsLJFSX88Ep4nL/C/wiOM4RergIO2sNe32CDDIcZyTxphPAC8aY8Y5jqNf1qQ9tKbteoBpwHlACfCGMWaD4zhvRLaKIvVqTdu1bxpzPlDiOM7HkayYSCNa03YnA5VABtAdWGWMWe44zt7IVlGkjta02yeBMcB6IAtYA1REtHbSIuqJI5FyiNqR2QFA9pmWCXUnTQNygfOBB40x+4HvAPcZY77R1hUWoRXt1nGccsdxTgI4jrMB2IPt4SDSHlpzzD0ErHQc54TjOCXAEmBSm9dYxGpN260yD/XCkfbXmrb7eWCp4ziB0LCU1WhYirSP1lzrVjiOc1coF9kcoBuwqx3qLI1QEEciZR0wwhgzxBgTj73Aeum0ZV4Cvhiavh5407EuchxnsOM4g4FHgV84jvN4e1VcurQWt1tjTHooWRzGmKHACGxeJ5H20OK2CywDJhpjkkMXa5cAW9up3iKtabuEkmp+BpvXQaQ9tabtHgAuM1YKMAXY3k71lq6tNde6yaH2ijHmSqDCcRxdL3QAGk4lEeE4TkWo98wywA086TjOFmPMT4D1juO8BPwV+IcxZjf2V4l50auxSKvb7cXAT4wxFdgu0ndqfLu0l9a0XcdxThljHsZe2DnAEsdxFkfli0iXE4HrhYuBQxqGIu2tlW33d8BTwMfYoStPOY7zUbt/CelyWtluewPLjDFB4DD2qYDSAZjQDxsiItIBFBYWOgBer1cJokREJKp0ThIR6Xg0nEpEREREREREJAYoiCMiIiIiIiIiEgMUxBERERERERERiQEK4oiIiIiIiIiIxAAFcaRdGWO+Eu06iLSE2q7EKrVdiUVqtxKr1HYlVqntxg4FcaS96eAgsUptV2KV2q7EIrVbiVVquxKr1HZjhII4IiIiIiIiIiIxwDiO0+SFZ8yY4Zw4caINqyOd3fHjx0lPT492NUSarb3abjAYBMDlUoxdIkPHXYlFarcdg85Jzae2K7FKbTf6NmzYsMxxnBmNLdesIA7QrIVFRKR5CgsLAfB6vVGuiYiIdHU6J4mItCvTlIUUVhcRERERERERiQEK4oiIiIiIiIiIxAAFcUREREREREREYoCCOCIiIiIiIiIiMcAT7QqIiEgNJY8UEREREZEzUU8cEREREREREZEYoCCOiIiIiIiIiEgMUBBHRERERERERCQGKIgjIiIiIiIiIhIDFMQREREREREREYkBxnGc5izfrIUlzMkC2H4Yqra3y4AxdtoYqKy0/1bNAzBAZbDu/HBNWSZc1fqdUB3akuPUtJi2Xpd0Ho5j20tz2rVIZ+Y4gKnZN0RE2knh+P4AbM+Pj3JNRJrOZQAHgqHTZ2fiDl0XVzbvHr7V5XiMAeNQEbSvXab2pnUZQ6LHMLKXG5dL/URaoUktVkGc9nD0FOw+Unvef1bD02/A7VfB3Cl23rNr4MnldvqKs+Dbs8Dtgk174X+eqVvu1FFw7/Xgcdvyv/XnhuvRvyf85suQnAAl5fCFR6DU3/rvV5/MdHj4NkiKh8JSuPlRKA+0zbqkc/nJ5+Hc4Xb64UWw/MPo1kckmvp2h8duh5REKPPbY2lRWbRrJSJdROFhe205/veFUa6JSNPEueDJT/ekW5KLsoDD95flsSe3ItrViog+qS7+NLcHLmM4VRrkq4tyKfY3//a8n9fFE9eFlfNiLsWBM5dzzchEvjbFC8DaA+U8sLKAP8/tQe9UN47jYMJ+cHUbGNvHU2ueNEuTNpzCZO2hW0rdeddMgsQ4+HBfzbwZk2zQA+Cj/TXzzxkKg3vXLWPLAarDocP7wfjMhuuRfRJOFNjp5AS46pwmf4VmO3gCckMnfG+SDUqJNEV427/u/KhVQ6RDOHoKjuXZ6cR4e54QERGRek0fmki3JHuLW1AeZN+pzhHAAZg1OglXKDiyN7eiRQEcgFljkqvL2X0y0GAAxwCzxyRVv/7oaICpg+Lpneq2758WrEmKqztPIk9BnPaQGA89vLXnVQU21u2CQyfsvNREuPJsO52TD2u21Sxf381sQSm8GdZLoapHz5k4wIvv1byeM7ntuuYHHVj0fs3r687vdN0ZpY0s3Wh7HAAM7QtnDYlufUSiLfy4PXuy7aEpIiIidVw3tibg8Mr2UjukqhNIiTNcOSKx+vWirSUtKyfecOWwmnJe3Fra4PLn9o9nQJoHgGJ/kOW7y7hubPIZl8/wuVtUL2keXQm2lwE9686bc77N91ErsHJ+TWDl+bU18y+dAN3r6dET/tnzR0L/Hg3X482PID+00/ftDlNHN63+LbH8AzuUCuxQrskj225d0nkUlcFrH9S8biw4KdLZrfgYcovsdC8fXDQ2uvURERHpgM7JiGNQNxtwKAkEeW1X5xl+fNWIRJLj7K171qkKNh1pWZqKGSMSSYyz95r7civ46GjD5cwJC4ot21XGoG5uRqfH1btsggcS4xReaA/ayu3Fm2RzGoTr3xMmj4A3PoKCUGClX3eYMspO7zgMWw/a6TgPXHte3XIPnYT3d9ppl7FBoIb4K2Dx+prXbXmDXBaAVze2z7qkc1n0HtU/nUweAQN7Rbc+ItFUUQmvrKt5rWOpiIhIHeE9RF7fVdbgMKFY4jYwK2xI04vbGu49cyYe12nlNNKbZ2gPD2f1s6k+KoMOr2wvbbAXTj+veuG0FwVx2osx9ffGmTvVJvxdsiFsXtgF+gthvXGuPRfiPXXLCF/mirPtsKyGLF4HgdD40LEDYfSAxuvfUi+/b29AACYOtrl7RBpz5BSs3VHzurHgpEhnt2R9TXL4ERkwflB06yMiItKBDOrmZlJGTcDh5e0tC3R0RBdkJpCeYgMkp0qDrNzbsh5GF2Ym0DPZlpNbUsnb+8sbXH5OWMDnnaxyXAamDqr/SXUeF/gSFVpoL9rS7amXr24QZkImjOhnf2UNhIId4wbBKPtIR97dbhNbAqQlw2UT65b74X7Yc9ROJ8bBJz/RcD1OFcNbm2tez23DG+SThfD2lprXSlQrTRUenLx8IvjOHPkX6fQKSuGNZuRAExER6ULCAw5rD/o5VhSMYm0ia27YkKYlO0oJtPCrhecLWryjrPr5OPXpkeTiosEJ1a8XbS1l1ugk3GfIp5qeorBCe9LWbk/G2CFUp7tuis13sPLjsHmhYEdTEwSH3/DOmmzDoQ0Jz6VzwRjondZo9VssfF0Xj4Oe3jMvK1JlywHYedhOJ8TBtY0EJ0U6u1o50EZBRiM50ERERLqAbomGS4eGJ+ttWdLfjmhsbw8jetkcNP5KhyU7WtbDaHyfOIb3tOWUVzgs3dlwOdeOSiTObW86txwLcLigslZi5XAG6KUgTrvS1m5vfbrVfSLURWNtL50XwwIx08bWBFZe2wTFoW5zg9LhE8Prlvv2x7bXC9ggycXjGq7H/hzYuMdOu11tO1xl95Gax0Z73DbIJNIU4cHJmedBnMbaShdWJweajqUiIiKfHJVUHXDYfjzA9uOd57Hic8bU9ER/c08ZBeUty/MTnqC4sXISPDBjVO3cOeGJlU/XPcnoseLtTEGc9uZx26dCnT5v1nmw9xh8sM/Oc7tqgh2lfli6qWb5+rrRVwTh5WYmvgy/Qb76HEhOOPOyrRW+rmsItkapAAAgAElEQVQm2WFfIo15Zxscz7fT3VNh+vjo1kck2sKPpVc2IQeaiIhIJxbvtkGcKosaeWR2LOmb6mJKWA6al1qY0DjD62bygKaXc9nQRHwJNkxwpLCS9Yf9zA4brna6fj6FFNqbtng01NcF/ppP2MBGeG+cGedAUmiHe/l9qAwNXDxnKAzpU7eMVzfYJ0IBDOtnEwk3ZMMeOHDcTicn2EBOW3l/Jxw+aae9STYBs0hjKk8LTl6nPCDSxX24H/ZW5UCLt+cOERGRLmr60ETSQgl1c4oqWXOg4WS9sWT2mCRcoR4uGw77OZhf2epy1h0q51DBmcsx1O618/K2UqYMqkmsfLrUeHC7FFJob9ri0ZAYXzcvTGqiDWys2wWHTth5KYlwVSjYkZMPq7fVLF9fguDC0xJfNiWJcPivurMn1x3qFSkO9rHRVea04bqkc1m60fZGAxu8PHtIdOsjEm21cqCd13gONBERkU4qPKHxy9tLCXaOp4qTEme4YnjTHwd+JqnxhsuHhecLargXzrkD4unvsw/iKfIHWb67jOsa6IWT4VOqg2jQlV+01PeknfGDbLBj68GaeePCHiO75UD988OFLzN2YP1JkMOFr6tPN0hvwwTHW8LW1b+nHR4j0piiMsjKqXl9prYv0lWEH0t7+eyxW0REpItJSzT0DwsibMsJRLE2kTWkh4ekOHsjVxl02HmiZXl+hvbwkBgqpyLosKuRcsb2rkl5sT+3AgeHoT089S5rDCR49KN8NCiIEw2OA0dy685fssH2yAlPSrxkQ810eLf58Pnhwh8vvnSjDQo15JpJNdPrd8OxvEY+0Arh61q7oyYRs0hDhvaB0QPsdGXQJvoW6crCj/Mf7oPD9ZxPREREOrn8Mod3D/irX189svPkidtyLMDBPBtwcbsMVwxv2XfbfDTA4QJbjsdluHx4wzlQX9tVStCxN5Dj+8bTK8XNW3vL6l3WcSCvtJN0fYoxCuJEQ15xTe6aKntCT3CaMckOtwLYF5bo+JyhMLi3nS4ph2Ub65Y7IgPGZ9rpisrauUTqk5IAV4XlwQnvoh9pp+fBact1SecSngdn1VY4XhC9uohEW1K8PU9U0bFURES6sPBhRtOHJNItsXP0DHGARWEJiGePTmpRJgqH2smeZ49JbrCcI4VB3jtYExibMyapVj1Od7SwZXl6pHUUxImGqpw34V5Ya/MazJ5ce16V8KdNvbYJiutJ2jU3LAfO21sa7+ly9aSaJ1Ltz4FNexuve0tVJW4G+8jxzVltty7pPHqkwiVhT6R6UTes0sWFP5Hq0AmbR01ERKSL2nGigu3H7Y/jcW7DtaPOnL8l1ry1t4yCMvtgmz5eN1MGxjfyifq9ubeMgnJbTr/TnlRVn/C8OZcOTSSvNMjGbH+9ywaCUBIqW9qPgjjtrbgM8k9LTHWy0AZdpo21+Q0Acotgxcd2OjMdzh1upyuD8NL7dcvt5YOLwoZhNfbrrLuBgFGkedww+7z2WZd0LjPPg7jQWOePD8DO7OjWRySaXAbmhAXrX3yv8SGzIiIinVx4b5xPjkoivpPk2vVXwpIdNQGV68bWk1O1CcorYGkzytmaE2DXCRsYS/AYrhmZ1GBi5cPqjdPuFMRpb1WP2Q738vtQEazd2+aVdXZIFNR+ytS72+FoPXlrZk+2gRmwj6Ddc7Thelw4BnqHkhifKoIVm5v8FZrt4nHQI/Q0rhMFsGpL261LOo8ET+3cHy+8G726iHQEU0ZBv+52uqCk9tMIRUREuqh3D/g5VmTvm3yJLi4d2nly4yzeUUqg0v5iM6Z3HKN61Z9kuPFyyqrLGdcnjhE9Gy4nfAjVtaOT2Hw0wIG8+pMilwYgUKneOO1JQZz25K+A4/m155UFbJLi8YNsThuA8gAsWW+n05Lh0ok1y7/4HnUkxtXOkdCUISfhAaPF6yHQhhHU8GFer6yzASuRxlx+Vs1T3I7kwns7o1sfkWgLzw+1ZIP9aU1ERKSLCzrwcnj+mDFJjT6gN1bklTms3FeTRmPO2JYNF8stDbJqf9PLeWd/OSeK7f1h9yQXlwxJqJVb53TZBbq/a08K4rSnI7l1u74v/8A+Qjk8qPLGR1AQ2kmuPRfiQ5HSHYdrPxK8SniOhMMn4f1GbnbHDoRR/e20v8IGcdrKxMEwrJ+dLvOf+alaIuEMtXugLXrfnqFFuqqRGTbYDzbo/kojietFRES6kNd3l1Hit4GEQd08TMpoWf6YjmhR2FCmCwYl0DulZbfw4b1rpmUmkN5AOZUOvLy9Zvk5Y5NZsa+MvNL6gzX5ZQ7BoAI57UVBnPZSGYTseh4Du+g9yOgB54+qPQ9sLpCZ4blk6hlO4jK1b3abkiMhPGD05kd1c/REUvi6ln9oA1YijTlvBAzoZaeLyuD1D6JbH5FoC++Fs/JjmzdNREREACgJOLy2u+Y+o6U9Vjqi/XmVbAolFna7DDNHt+y77c2t4MMjTS9n2a4yygL2xnJIdw9jesexZOeZe+McK1IQp70oiNNejufbQE64tTvgcC7MmUz1s97e3wUHQ0+vunQCdEux0zl58M62uuWePxL69bDThaU2UNKQvt1h6uia1/UNz4qU/j1t/cD2oljUhuuSziU8+Ld0I5TWnxFfpEtI98FFY2te6yltIiIidby8rZTKUM/tczLiGdytk2Q4pvZjwq8ekUhSXMsGjNUpx3Pmcor9Dq/vqQmMXTcmiVd3lOKvrL/HwMkSB8dRz/n2oCBOe3CcMz9WPDXRDocKn1cl/Eb2TMNJ5k6tmV6ywebTaUh4wGj9bjhwvPH6t1R4D6H3dtqAlUhjhvaFs4bY6TM9jU2kK5kVlrj+g32w91h06yMiItIB5RQHefdAeN6Xlj3NqSPamO2vTiycHO/iquEtS968/rCfQ/m2nJR4F1c0Us7L20oIhgIz5w5IwJvgYsXe+kdWBB3IK1UQpz0oiNMeThXZBMbhdh+BzVlwzScgMTRmc+9R+HCfnZ40DDJ72+mScli2qW65I07LkfByIze7KQlw1Tk1r9vyUd/eJJuYtj3WJZ1LeCLsVVvsE81EuqqkeLgmLHG9jqUiIiJn9GJYT5NLhiTQLbFzpDh2qJ3TZtaYpOrf5VtTzuxGyjlSGOS9g/5ayzeU4PioHjfeLlr2jDJpHo/bJif2hz1JZPU22+OgMmiHWqWn1cwDO4xqzxGbFHjtTjsM6nR9u9lEx2MHwsY90C3V/lefoAOJHnj+XTvEKTnB5sKpWl+kpSXbgNS5w22y5ZLytluXdC65RXZooDfJDi9Uu5GuzJsEH+6HySPgRCHkFmqfEJF2N7h75xmWIp1beaXD3twAbmMfPd7X68abEMRlwJjYDujsyw1QWB4kwWPYmhNgRE835S2ImezJDVDsDxLnNmw73ng57x0sZ+qgBArKguSXBXG5YGuOn9HpcRT7HVLiDS5jcByHxDgXjuPE/Lbu6Ewzx62pf1RrFJZCSZkN6KSl1gxrchzIL7aPU3ad1jmqqMwmOE6IO3O5JeVgjP3FtkpesR3CtS8Hdh2GnHxISbS9cTK6Q3dv+zzt57+r4XPT9GQhaZ7/roZ5F9XNIyXSVelYKiJRUDjN5jZ8/1gD16EiHYzbBfmlQY4UVlIScCitsOfO/j43g7p5yPC56ZPqpluiiblgQ7E/SKLH4G5JN5wWluM4DkV+h9T4mu1VFnBwGXtZYnDIL3fomWxwn34vK83VpD+seuK0J2+S/e90xpy5B01qE8Y7JsXb3jxbD9reO7uOQFGoJ0Nqku3FM3ogtfrKOaH1tof2XJd0HkFH7UYknI6lItLOvKt3cfD1bfDVT0e7KiJNVhmE1AQXIxJqAgr+Soe80iA7jgf48IifEr+DMTawk9nNQ79QYCetgwd2UuIjEyRpTjnGGLwJtbdJYq3EyobeivO2KwVxYlFFJRw5BQeP29w6e47a3jypSbY3z+gBNvjTEQ5AxtTtXSTSGLUbkdq0T4hIlBh0+JHYl+gy9I1z09dXMzSwvMIhryzI9hMBNh3xUxLqXTIgzcOgNDf9vG76eN34Ejp2YEe6HgVxYkGZHw6dtEGbHdn23/g4G6jp6YXzRtQeStWRuAy4ddCTZlK7EalN+4SIRIvRk1Ckc0ryGJJS3fRLrQnslFXYHjvbjwfYmG177LjdMDDNw6Bubvqm2sCON16BHYkeBXE6ooISG7TZdwx2ZcOxPBuw8SZBLx9cPA7iYuhPpwOctITajUht2idEJAoMtOgpOCKxKDnOkBznJiOsx05pwPbY2ZYTYMMhP8UBhziXYWCam4Hd3PT12qFYqQrsSDuJoUhAJ+U4cLIQDhy3jxjffRQKS+ywKF8yDOwJEzJthq5YZIzO/NJ8ajcitWmfEJEosYcfHX+k60qJN6TEu+jvs68dxyZLPlXqsDWngvWhwE6C2zAgzc3ANDd9vR76pLpITYjRezjp0BTEaW+VQTh6Cg6esPls9h61CVy9SdA9FcYNAl9S5/nFVXkcpCXUbkRq0z4hIlFi6DyXpSKRYIwJBXZgQJrtseM4DqUBh1OlQbbmVLDusJ9iv0OSp3Zgp3eqK2LJiaXrUhCnrZUH7NCoA6EkxAeOhx4xngI9U2HKKEhOiHYt24764EpLqN2I1KZ9QkSixBijw49IY4whNcGQmuBiYGiW4ziUhAI7W3ICvH/IT6HfISXutMBOiotkBXakGRTEibTCUjh0Avbn2KdGHT1lnxqVlgTpaTCinw3idBUaAiAtoXYjUpv2CRGJIh1+RFog9Ghub4KLQaFZjuNQ5A8Fdo4FeO9ggKLyIKkJhv5pbgb6PNU5dmo/xlukRheKJrQBx4HcQjh4EvaH8tnkl0C3FPvfoHQ4Zwi43Y2X1VlpCIC0hNqNSG3aJ0QkShRDFokgY0hLNKQl1pzTqwI7uSVBPj7m571DUFgexJfgYkCam/4+mzy5d4oCO2IpiNMclUH7pKiDJ2wvm31H7by0ZOjhtQmIu6Vo4HA4DQGQllC7EalN+4SIRInNiaPjj0hbMcbgSwRfYs0P/47jUFjukFsa5OOjAdYeLKew3CEt0QZ2Bvjso857p7hJ8Gj/7GoUxGmIvwIOnwwlIc6GrOOQEAfdU2zQ5oIx9tHfcmbGKKglzad2I1Kb9gkRiRL1xBGJAmPolmTollTTYydYFdgpCfLR0QBFB8opKnfoluRigM9N/zT7RKx0BXY6PQVxwhWV2aDN/hzYc8Tms/EmQbdUm89m9EAbxJGm0xAAaQm1G5HatE+ISNQosbFIR+Ayhu5Jhu6nBXbyy0KBnSN+CsuDFPkdeiS5yEhzM8DnoY/XBnbi3dqRO4uuG8RxHDhVbJMQ7zsGe49BXpF9zHf3VBjaF84bAZ4unM8mEjQEQFpC7UakNu0TIhIl6okj0nG5jKFnsqFnck1gpzLoUFDucLIkyIdH/RTudyj2B+mR7K7OsdM71U16ios4BXZiUtcJ4gSDkJMPB07YXDZ7j0FFpQ3Y9PLC2YNtPhv90hlZOvNLS6jdiNSmfUJEosTmxIl2LUSkqTxuQ49kQ4/TAjv5ZTaw88ERPwVlDsWBIL2S3fQPBXb6pLrpleLCo+uNDq/zBnECFXA4Fw4etwGbrOMQ77a5bNLT4JLxNp+NzkptS0MApCXUbkRq0z4hIlFiDOjoIxLbXC5Dr2RDr9MCO6dKg+SWBtmUXUlhue2x0yvFJk7OCAV2eiqw0+F0niBOSbkdGnXgOOw5BkdybT6bnl7onQbjB0FifLRr2fVoCIC0hNqNSG3aJ0QkSgz2BlBEOheXy9Db66K3t2ZeRSiwc7IkyMZsm2OnJOCQnmJ762SEhmL1Snbh1nEhamIziOM4kFcMh05CVo7NaXOy0AZsenpheF+4YJTy2XQEGgIgLaF2I1Kb9gkRiRZjAzki0vnFuQy9U+yjy6tUBG3i5JMlQTYeDpBfXkZpwKFPqg3s9PN56J3ioqcCO+0mNoI4wSAcL7CP+t6fA3uP2sd/9/JBuhcmDYUeqepq3hHp12NpCbUbkdq0T4hIlOjwI9K1xbsNfb1u+nprAjuBSofcqh47h8vJK3MoCzj0SXXRP81NP6993HmPZBcupS+JuI4dxDl4AlZstkOk4j3Q02eHRl02AXzJymcTC5THQVpC7UakNu0TIhIlxugR4yJSW4LH0M/rpl9YYMdfaXvsnCgJsiEU2PFXOPROdTEqPY7zByZEscadS8cO4uw9CmUBmD0ZkvRHj01GwTZpAbUbkdq0T4hIdNieODr+iEjDEj2GDJ+LDF/NvPIKhyOFlaw75FcQJ4I6dhAHIC0ZUhKjXQtpKfXBlZZQuxGpTfuEiESLUnKJSAslxRn6pLrYkhPtmnQuHT+I41IX8pimIQDSEmo3IrVpnxCRKDGoI6CItJyOH5HX8YM4eiJHbNPfT1pC7UakNu0TIhIlOvyISGu49IS7iOv4QRyXzhwxTUMApCXUbkRq0z4hIlGknDgi0lI6fkRexw/iqAt5bNPfT1pC7UakNu0TIhIl6okjIq1h9GyGiOv4QRz1xIltOvNLS6jdiNSmfUJEosRgdAMmIi2m40fkdfwgjh6rGtuUDU9aQu1GpDbtEyISJYohi0hrKCdO5HX8II7bgFtdyGOW6cR/v4vuhQe+ANPG1n1v7Q64+6+w5sG2W0dn1pnbjUhLaJ+QWPa7JXDwBPzy5mjXRFoo0kGc/acquHdpPgfzK/n61FRuOCu5WZ9/aVspL24p5cnre7S6LtkFlcz82wne/3pvPIpWiUScdqvI6/hBHIX/m+7ev8N7O2FfDjz4RfjMhWdetjwAP/gnvLoBEuPhzqvhy1dFvk6d/e93puF+Vb+YR+K7t/WQQrWb2HbwhA327X4CPO7Wl3fh92HBzV0vcNjRaZ+QWPbNa6Ndg6Z5ZR08+QZsPQhnDYZ/31P/cs+ugf/3lA1KzbsosnXIK4bvPQ2rtkKPVPjep2DO+fUv6zjwy+fg3+/Y15+bBt//dMR77bXF4efvG4s5d0A8//68t9FlDxdUcu3TJ1j/jZogS1V1IlGv8Eu2jnCYve25XDYfDeAOVaZ3iotFN/dq8DOBSofP/N9JSvwOr92WDsCp0iDfeSWP/acqqAzC0B4e7pqWyjkZ8QD4Kxx+s6aI13aVUVbhMGNkIt+72Euc26534YclvLStlF0nKpgxKpGfXplWa53LdpbxxHtFHCsK0jfVxTcuSOWyYYkAOI7D79YWs2hrKaUBh1HpHu6d7mN4T0/1un++ooDlu8pJjDN8aVIyX5iUUud7PfFeEU+8V8wT13VjyqAEAB55p5ClO8soKnfwJRo+NT6J289LrfPZl7aV8qPXC/jRZV4+Nd4GCZ/eUMzL20o5UhikW5LhsxOS+dInatZ7uKCSH7+ez8fHAvT1uvn+Jd7q9f7szQIW7yirXrai0iHObVjz1d7Vn/3FWwV8dDRAvNtwxfAE7rnYW91mV+4t57drCskuDDKip4cfX+5jWGh7LNpayv++UUCCp6YB/nZWN84bEN/g370+gUqHe5fmsyUnwJHCIH/+VPc65WzLCfDQ24VsO15Bksdw23kp3Hh28wKpzaGfoCIvNoI46kLeNGMGwszJ8MtnG99uv3kZ9ufAmgWQkw83/ApG9Ifp4yNbp848BKDqu9X3/Uzof6397g2tI1LUbmLLhfNhwRdrgixV2ylS7aQ92lxH9vSb8Oxq2HEYZk+GX9/a8PJ/eQ2eWAplAZgxCX5+EyTERb5e2idE2l73VLjtCthzFNZsq3+fyy+GP7wKIzPs60jvlz/6P4j3wIaHbTDplt/C2IEwsn/dZf/vbXj9A1j6Y1uPGx+GQelw0/SIVslg8+JE0pHCIDNGxDepXFP9r6lePnxea9VXfjQZ4N5LfNWBh6b428ZieiS5KPFXVn+HlDgXP7kijUHd3Bjgrb3lfPvlPN663QbDntpQzNacAM/d2IvKIHzr5VP8ZV0xX5tiA2vpKW5uPy+VNQfKKa9wam2bY0WV/M9r+fxmZncuzIxn1f5y7nk1jyVfiqdnspvXdpWxaGspT1/fg35eN4+/W8QPXsvn3zfYYNQT7xVxIK+Spbekc6IkyJefz2VYjzguHJxQvY6DeRUs311Oeoqr1t/mU+OSufP8VJLjXBwrquTOF08xtHscVwxPrP5sQVmQJ9cXM6yHp87f9edXdWNELw+H8iu588Vc+nrdXDMyCYB7l+YzsW8cv5vTg3f2l3PPknxeujmdHskufnhZGj+8rCaQ9cPX8zCmpuwH3iqgZ7KLN27rTWF5kDtePMV/PirlxrNTyMqr4L5l+Tw+pzsT+8bxtw3FfOeVPF78Qi88LlvCxL5x/O0zPZv8Nz8TA5yTEc+N56Rwz5K8OvvvqdIgX1uUxz0XeblyeCKBoMOxomCbtv2OsWd1LjEQxHG1/RM5fr8EnlwORaXQpxv8PDR85eEXYWe2PZm+tgkG9II/fR2WbLAX7vEeeOgWuCR0A/ufd+A3L8HJQujhhXvmwtyp9qZ3/tP2ZGyMXf5nN0FahCOet1xh/310UeNPMnnuXXtz0t1r/7vhYvvL0mUTI1unzv5ElY+y4P5/2YDGVefAL26GxLia71z17+8W24utkwWQ0QPu+RRc84macv5vJfz5NTiSa9//zVdgQqZ9r2ob7j4CNz8C8z995l/lWkLtJvaEb5/wfyO1zbry9u/XHb41C1Z+bAMzDW2HFR/DH5bCwnvsueP2x+HRl+Dez0S+Xl35byKxo6Hrqf058Nuv2N6DF3wPHr4NfvUClPrhy1fa/Q6af+119BTc+w9Ytwu6pcDXroHPX9Kysi4O/fuvt4Ez7HMPvmDPm6+si+xxF6Ck3PZ0Xf5T8CbD+aPgyrPhhbX1H1eeWwNfuRr6h3pp3HG1vda4+bLI1YnI98S57blc1h/2synbz4OrCvnPDT05kFfBY+8WcTC/ktR4w6fGJVUHE259NheAaX/MAeBPc7vb3xqAh98p4PktpfgSXPzPpT4uCgUBCsuDPPR2Iav2l+MyMGdsEl+fkorbZagMOjyyupBFW0tJiXfxxUn2eryqJ87VT+Zw/xVpTA31wPj92kIO5FXyyxndANh42M/DqwvZe7KC5HjDN6amct3YyF7TN2ebH8qvYPH2Uu652Mf9b+RXfy4pzjC0h73VCzoOHhcUlDsUlgfpmexm5b4ybj03le5Jtg3feHYyj6wu5BtT7Xa/aoQNimzNCXCsqLJWfY4XV+JLcHHxELuNpg9NJCnOcLigkvQUN9mFlZyTEc+gbnb9s8Yk8swHxdVlvLK9lJ9emUa3JBfdklx8enwSL20v5aIhNUGcB1YWcNeFXn7+Vn6t7VH1naDmb3Yov6JW/X67ppAbz0ph2a7SWp+97dyaHjtDe3i4dGgiHx4JcO2oJPafqmDb8QB/mtud5DjDVSMS+ecHxby5p4zPTqz99y0JBFm+u5zHZ3evLvtwQSU3nJVCUpwhKc7NtMx49ubaer17oJxJ/eM5t7/tEXPbeSn88f0iNh72M2VQQnV7PtPffG9uBQ+sKGBrToAeSS6+PjWVGaHA0+kSPIabQ72aXK66Pcye2VTMhZnxzBpjP5+IwZvQttcXLhtJkgjq+EEcF23bt3H3EXj6DVjyI+jb3V5cVAZDGZgMLP8AnvwWPPpluPtJuOlhe+O64WH4z2o7FGXtQ/bE++P/g8U/guH94Fie7RJblcnpmzPh/JH2wub238Eji+Ann6+/Tlf8EA6frP+966bAA42NKTcNH/3zim39xg+qWWbcIHuBE+lt3dmHALy4Fv75XUhOgC/9Bh572QZZTh9ONbgPvHAv9E6Dl9fBt/8M5w63F7kvr7Pt4a/fhLOG2AvdOHfNZ42BLVlw62Pwiy/YC7r6qN10XOf/P/jS5faCe3+ODcJ9/9Nw11/h/V1wzlD449fsDQjYbfrAs/bmZNwg+7cbkQHf/BMczoVbf2vPzHfNhlmT7WdeXAsPhW6Ibr8Kvh26IQoG4fev2kBhfom9ofrlzfYXZ7BBuAefh+IyezMANdv/O3+xQY35n7bz12y3ddjwsH19+KQ97r23E4IOXHe+vWk7k3+/Y2+OJg2FhavAl2zbdFUQ8N+rbF2PnIKeXnsz9oVLa6/79qvsjaLbZbfh5yI8lOHac+2/m/fbejTUDp9bbYdSjBlgX39nNnzzj/A/n41snaDz7RPS+TR2PVV1h1LVjtfvgrcfgL1HYeZP7b43IqN5115gjwsjM2DjI7YONzwEmb3horHNL6tK1Q3H6fvcpr3w0X6bq27xuobvuu79uz0u16d/TxuoOd3+Y/bYNrxfzbxxA+HdHfWvZ2e2PUeEn5N3Zkf8WGEwES3yqet78KX/nmTmmCSuD/U2OVFcyQNXpzG8p4ddJyq4/YVTjEmP4/Lhifz9Mz246qkTrP1qzXCqrFMVbD4WYM7YJFbf0Zv/bi7lx8vzeevL6Rhj+MFr+fRMdvHqLb0oDTh8bVEeGd5SPjsxmf9uKeXtfeU8e2MvkuIM33klD6jdPMOnqzpCuozNn/PVRae4/3IfV41IpNjvcKSwst7t85M381myvazuG0A/n5sXbqp/iJQBfrOmkEdXFzK4u4dvX5DK5IEJ9S4L8MuVhXznQi9Jnvqb5NxnTrA3t4KKIHx6fBLpKTVDrw1OrcvNY0VBiv3BWjf19QUYJvSJY2gPNyv2lnHJkARW7C0n3m0Yne7BZeDaUUks23mKA3kV9Pe5eWlbGdMyE3AZyC8LklMcrF4WYHR6HG/tKa9+vWxnGfFuw/ShCfz8rbqBiD+vK+KP7xdTGnAY4HMzc3RS9fsfHfWzNSfAjy738dppQZxwjuOwMdvPZyck4zI2UDLQ56713Uelx7Ent6LO59/YXU6PJBeTB8RVX/J/4RwbNDp/YDwF5UHeyfLzzampYUl9a7a144AD7Mmt4ILMBAyw/XgFF/3xGGmJLmaNSUs1WwQAABjzSURBVOL281LwuAwlgSB3vJDLN6am8se53dl5ooLbn89lZC8Pw3s23PO3vkPZR0cDjOzl4Qv/OcmBvEom9I3jB5f6yPBFYEj+GejyJfI6fhCnrS9c49zgr7An/nQfZKaHrRv7K0jVDcbs8+wvJN+aaU+yc8+345YLSyDOY+u58zAM7GVvfPp1t58b1tf+B5AUb38peXjRmb/Xmz9r/fdqKPhVWm7/TUuuWSYtGYrK2uBmvIF6dAa3XG7/3gDfmQX/8wzce73d/uHffc7kms/MnWJ75ny4zw6/+Nfb8LVPwqRh9v2qtlJl3S67zGNfgQvHnLkuajcd25L1Nr9CRRCu/BF8fAAevtXefNz4MDy1HL57ne3G/7Un4KlvwQWj4U+v2QDhyl/A7+6A93fa3lAXj7PlHjxu/123C975pb0h+uRP7A3RyAz4y3JYthGev9cGRn7wT/jBM/CHr9ohQ/f+HZ652wZWfvFsTeCi6qoj/Bgc3q4rg7ZeF46Bx++w8z7c3/DfzYW9CfrshbDlcXhmhc0rsekRu550H/zjLnscfneH3S7nDIWJg+1nj+fbQPimR+DtLfDl39kebd3qjqPn+3+HF96tvx79eza+vzT2sxjYm6UZk2qWGT8IjhfYgGePuuPzW6Uz7hPSuTR2PUXoWFJ1f/Td6yAlwfY6HTsQth2EUf2bd+1VVGaPif/4DiTHw8RM2wvn+TVwybjmlZUWdhypL69dZRDu+4cdMlmVf6yha9QFX7T/NUdJOXiTapfpS7ZB9vrWU1xW95xcXBb54ZdtcSl+2iG2Ku8IwJjecXxyVCLrD/u5ckRivYEVl4EMr5vPhXpIzB2XxE/fKiC3NIgBVmWV8/7X+pDoMaTGw5cmJfOfzaXMOyuZZbvKuPmcFPqHblrvmJzCukP+mvJPq1v46WDJjlKmDqrpxZDgMfRIrr8Xw/9v777jpKjvP46/Z7Zd79zBATakC4pRwAgGaxQriqK/2BNsxMTYYsLPRGMh+pOoPwWV2IOxJwEVTdQoYtcYRQVRoxEwcBzletmaPz57t1f2gNO7hMHX8/G4B+zO7uzM7OzsfN/7/X7migPzdcWB+Wmnbc5FE3O1a7FfAdfRohVNmrGwSn88ubi1V0tbz37apFg8oUMGZ+jNVc2t26atBaeUqDma0HOfNikSS02fuFNI8//eoPEDQ4olEnrg3QZJUnM0ofzUyKROpwKS5PocHT0iUz99plrN0YQCPunGwwuUE7RtUZrjaq/+QR1+33r5HKlvrk/3TrVeK03RhCQpP8NtnWdeyFF9JC7XkerDcd30aq3uOrYw7fshSWePzdFZe2dreWVUz3/apPwMJ3lqktDVf63RzP3zLPDbzFf5La/VKZGQjhtpAVBjJKGckNv+4xdyOvVCkqzeztEjMlrrFknS2AFBPfZBg8bNrVAsIR0zIkMH72q9bPbdMaQbX67T26ubtUd5UHe+Va9IzLa169hzF55arPI8nz7dENWFT1Up4Epnjc3RS583q3+eT8clA8/dygI6ZHCGnv2kWUNKtjx8u2MAVlEX0/LKiO46tkhDSvy6YUmtLn26Sr8/8esP5drcMnAG07O2/RCnp7uqdjSon3TV96TZf7IGzaRR1kOmb2GyUZGfev3MkDWCAsnNlpU8wjVGbGjJvBn2K/JF90hjB0tXnGS/KlXWSDN/Z79W1zXaL9YF2b23Xo42PwwtN9klsD6cWof6Zikns+eXaXseAuA41jW7Zf0G9rGeKq5r219KTXvkZaubsWq93a5vkjbV2/Q1G6Wdy9JvJ8eR7n/BGvMTR/by+oj9prc4jvT9Q6SyZLA7fqhUkmc9ryRp8resiKXrSk+8ab2t9k82OmZMlu58VvrbPywwaalX07J9Wva1S46VsjOkUTtJI3aQlq+Whg2woOTaU21flaxI5p4/keYkbEjBwXukwsHLplqY1DL/rl7LdW15KqrsONfSoNln2Ba2gysNKE519Z820cKWDbVSaYF0yJ6px04YYbWW3vxE2mMXe27AJ108xV7v4DHWAPyswnq1dXT96fb3VXVc93Tqm63h1/KYljCpodne3560vX0msP3Z0vlU63EluR/3LUzt01khqSGcOu5s7bnXuhrrVZjXJoDZoY/1lunuvArbfL7Sff7vfs7CprFDun7M15WbmfxhpM08N/c9m51h01um1Tfbfb6e/UW9t8qktZ3ve2vCmr2kTp9siCgSk8IxK7TrtHQl6LgcjlSS7bbezgrafxojCVU3xRWNSfvNW9f6WvGE1C/XJ8eR1tXF1C8v9dyWHght559unR1HWlsXsxozvdgi3aM8VYR2ym6ZempFo176Z7NOGdO+2dYQiWv2klrdkRxe1nY7dZQRcHTE8ExNvrdSw8v8GtYnoHPH5ai2uVZT5q9X0O/o+FGZWr4u0m67tp1f2/te/aJZNyyp1X3HF2lkmV8fVkR13oJNmjfFp+GlAc19vU7vV0T04vQ+Ksl2tXB5o05/bJOePK1E2cn3qj4SV0bAtn19OKHsgL3ura/X6ejhmRrYJrRK/344GlkW0CtfNOuW1+r0s0l5enBpg4b2CWjP/sHNPnf+3+u1YHmTHphWpFDAJmYHHdWH4+0eWxdOKDvYfnusqY3prdVhXXVwXuv98URC0/+4UdNGZ+mhE7NVH0lo5l+qNfvlOl2yX64GFfs169B8Xf1CrdbVx3TU8EztWuxX3+Q+uUNhal2H9gnovPE5uuvtep09LkdramNaujaisXMrWh8Ti0tHDc/Qmlq7slqLd84v6/zmd1j/DL+jg3bN0Oh+FgDN2CdH+9y2TnUdemD1JEr69bxtP8T5T/z6ePy+9lfbKF10t3T1I9Lcczr/Eru5f11HOnB3+2sM21CIi+6WnrxcuvYRm774GquVs+hta7h0tV4TLks19tMt6w1nbGGFNhM7S/YLcVmBtHylVDbK7lu2ShrWn2Ex3bVmY2r9/rUxeVLa4aeiVettX3j8Mmnvwfbr36SZqenlxdIXlV1vpxvOkG55UvrFA1ZLqSvsN9u2svzUOmUGbWhd6+2QNfxdx4KRgSVt9iGf1L9IqtjU+ZjT8n9J6luQ+n9WMDW/1RukM25u3wDwuVafqaLKQpWW5+VmWIOoYz/ydMe8NZssGAp242vEkYU1LfPJSTagGsJ233PvWY2Mf6y1M+7GZms0tSxPYU7718sK2WN6Y19pmeXm5p0Tat8TrT7ZbT4vk88Evpm25nwq3XFMSu3j3Tn3Ki+UNtVJDU0WdEg2zLNfYffn1XFZ2k6XpJeX2bDO55fa7ao66f0vpA9Xpu9xc/E90qOvpN9OA0us52RHu/aTojHp84pUr9xlKy2QT/f5H9bfejC1BNm99J1sm7Cn5+kkh2nZfC9eVK2Tx2TpruOKFPI7uuaFam1qjMt1nNbeDq6Teryr1H1tuY6j8jy/gn7pjfPK0l4yvDTHp4q6eOtzK2rj7eafFXDVHE3Ne0NDIrl7OuqX69fSteGt2h6/eLZaC5c3pp1WnufTotP7pJ3WUUvx3I6vubIqri9rYjr5YasZFIknVNuc0ITb1+mR/ynWgPzO38/RuLS6Oq4RpY6ygo6uOChfVxxkvYUeWtqgkWUBBXztG/KOHDlO+9dfURnV3gOC2r2fhSW79wtqdN+AXl8Z1siyoFasj+rwYZkqz7NlmLpbtma9WKvPNkY1qm9QpdmuPq6Mad+dbPrH66MaXOKX6zh6fWVYa2tjevA96xm0sTGunzxVpel75+issZ17ucYT0urqWOtz31od1kufW6+k6qa4lq+L6qPKqH6Z7BX12PsN+u1b9XpgWnHr8knSkJKAVlXH1BBJtPYoWlEZ1ZHDM9qt+8JljRpTHtSOhaleMFWNCa2pjeuUMdnKCLjKCEjHjczSTa/U6qffsR91Jg/N1OShdpyqaYrrDx+s0+i+wbT7Uut+7jgqz/Vr7wFB3dtF0eN3f9Q37f1t59X2NYb2CSQ73tt9vuS/6faxntJb8/0m2/ZDnI5frD3tk39ZY2TcEGtYZQbtaNC231fb/pRtb7dt5Kyvkf72qQ1xyAxa48SfrCZV32TdYQtzrMbFnEXtn9/Rq9d9tXUJR63+hRIW0YYj1uBJ9+vNtAnSjQttCM+6amn+CzZch2Ex3XP3c9J3x1hj8uaFVhOk477TGE4NFXEdGxr10Wq1Dl06dZINcdlnqF3S9PMK+5WwZZhWbqb06KXSlFnSVQ9Lvzwx/bKw32zbOjbC2zUskve5jjU+lq1KTUskrA5OeVGbRkmaEKdT8JK8r7zI3qNxQzovU9+C9vUTGpqtQdQy/+wMqSmcml5ZnXqtgcXWWIrHt/7S5l0NUXIlRaJW62fuOdJhe9pn4OQbU6/XVajSVbhx0d1dN6AGlGz589JxO6czbIA1sI4db7eXrbJwrqd74Ujb52cC25etPZ/a0jGrO+deA0qs5/PVj0q/OskC4N8vtuGi3Z2XjcWwY1E8bsfecMRC74DfhrM2RVLre9rNNjzr5EnpP5u/OdP+uiM3Uzpib+n6x62GzwcrpaffsatPpXuNaROtuPrBe9i63fa01Q3rlRCnR2dp822zC9SHEyrMcJUZcPTemrCeWN6kCTsF5TpSSZZPriN9WR3Tzsmitl0doh3Hhu5M2DGk6xbX6IJ9c5UddLSqOqa1tTGNGxjS5KEZuv+dBh0wKENZAUfz3qqTlNolR5T6tWhFoybtEtJHlRH9+ZNGTdzJ6rkcMyJTd7xRp6dXNOq7QzJU22w1cUaUdh7WcvUh+br6kO4Np6ppiuvdNRGNGxiUz5We+qhJb68O6/ID8jqt67A+fi05u7T19jtfhnXl8zVacGqJijJdvbcmrFhcGt0voHjcrmC1oT6uMeUBuY60tjYmx7FLmL+7JqK5r9dq1ncLWl8nGk8oFrdeJvGEXbra50p+19HofgHNe6tOH1VGNKI0oA8rIvrbl2GdPCZbrmNXWnrm40YdOSxDRVmuFixrVDQm7VxodXCOGZmpuW/UaXS/gNbXx/XI+w369aH5ch3pdycUKxpPtK7XlPnr9fNJefrOziFJCT28tEGTh2YqL+Ro6dqIHni3QeeMs9oz/3dYgZpjqeeet2CTDh2S0Vr3ZsGyRv3m5VrNn1aknQrbN4MHFfs1vDSgOa/V6cIJuVr8ebNWrI9ozpCCdtv+T8saddbYnHb3lWS7Gpjv04PvNegHe2erIZzQn5Y1aHhpqu7PB2sjGl7qV1VTXFc+X6MDBoU0uMSWYfFnTRpZFlBJtk//2BDV3NfrdNhQG0p4wK4h3bCkVguWNeiIYRYCLV8XUVbQ6bImTnM0tQ2icXvvgj4LBI8flakZCzbptMqIBhf7NfeNOu3VP6CCzN7r7dtbvfm+yQhxIjFrGH/8L2uIjB1sX5xbaix1+jdhQ6nOvd2eM2pH6/ngOlYU9NzbpJ2n27CZaRPsi7an12vqddIry+3/b35iRVOfmGnDEh55xYrnvna9Tf/5VBv2tcePpYygFUHtqmDu17G9/3o89dvS8ddJa6psSMwlU1L7bMtZz4gBNiTm0Cvt9okT7SS3ZdtMGW8N57PnWs+egX2kO85N1RNo6YHwx59JR15jAcvMHrz6DfvNf0a7BkuHY0vbcGPKeOnmJ6UlH9owutv/LIX8NgTLdaTSPGllZfrjUOs2azP/Mw+SrnlUmnu2DTNYX2M1JCbvZQWWD/6FDfX81iDpusdTjS7XsfoScxbZfh2OSnc8k1rOlsLcVz1sBYZ9rvTu57acXW6DNtui47aJxqTmiIWdQb/1ynnxffv8dPxMdbVd27rx+/bXXdGY/cXj9heO2HdDuqDqxInSjDusxk/fQqt1dtJ+vd/aAbZFW3s+taVjVnfOvVxHuvOHVrB45Pk2pPGy46QDk8NRuzuvh16WZsxLrVP/M6WTJlq4XNihB0DQbz/QpavJ9XXMPkP64Txp2Ax7zdlnWI9EyXoCnXC9tPpuu33mgdIX66SJP7Pbp0yy+3q6tdQLh5+Ou8OvDs7TtS/W6srnazR2YFCHD8tQTZPVSMkOOpoxPkfTHtygSDyhe6cWpe0s1XLbdaTZhxfo+sW1OuyeStWFE9qhwKezkw3vk3bP0j83xXTkfZXKCbn6wV7Zem1lqibOhRNy9eMnq/StWys0dmBQRw3PVFWjLcuAfJ/umlqkWS/WaOZfqpUbcnThhFztVrbl2iRbI5awK2d9tiEq15UGFfl1+5RC7VpsTbY3V4d15mMb9cEFfRX0OSrLSX03FWZaPZeW+6LxhK58vkarqmLy+6ShJQHddVyh+uXa9NXVUV20qFobGmLql+vTpfu1BCVm7ut1+v9X61pvL1jWqB99O0cX7JurfXYI6cffztX5CzdpfX1cRVmuzhuf0/r8c8flaGNDXEfev16NkYR2LPBp7jEFrUHBT/bN1eXPVus789Yp5Hd09ths7b+L9c4t7lBjyOc4KshwlRtyFU8k9OwnNpQrErPaO6fuma3T98yS46hTEBH0OcoLucrPsPtvfKVWVU1xHTs/dSGQo0dk6ppk2HbLkQW65Olq7XnrWpXn+jTnqMJ2haDf+TKstXVxHT4so9O+d9vRhbrqhRrNe7NOPlcaPzCk/90/Fb5d9UK1PloXld8nTR6SqZn757ZOe21lWJc+U62GSEIlWa6OSV5NzXWkvJCr+08o0tUv1GjWi7WKJxIaXhrQzEmdg70Wh9xdqS9rYpKkM5JXd3vprD4akO/XvjuGdPHEXE3/w0Y1RhLaa0BQNx1R2OOf8bY4fel5TiKR2PKjUrr14K9t8Qf2rk8Y8R99WfSgWY9ZoV+gO7a3/WbU+XZp3f2Tw9Cm3yrt0je1jvf91S7fvjA5zO6Jt6wxtGajBcKzz5SGJ0/in3o7WYiz0erDHD1OGv0jacP8VNBw+K+kEyZIpx2QujrVPc9bT8CSPOnYfVI9un6/2EKe+mYLG+//a2pZm8LSObdZoLJDifS9SdKtT0nL59hzV62XfnqfNSwc2TCKzdWheWCx1Xj68xWp+/JPsqvKDOor/fYvFiSFo1YwOBKTdimTLp9mNYPOmpN67XTbtSfMekz69ePt77vsOHuvVq23K429cUOqp9ytT9llxZsi0lFjLTgK9czJfKfl2p4+EwA8I3Hto9LPe/DHIwDfKLXNcT28tEHTx+b+txfFC7Yq8tr2QxyfS4jjZXzx46tgvwHa4zMB4L+F4w+Ar6G2Oa6H3mvQ9DQ1jdDJVoU4XOoCAAAAAADAA7b9mjgAAO+44E7p4SWd75820epjAAAAAPjKCHEAAD3nph8Q1gAAAAC9hOFUAAAAAAAAHkCIAwAAAAAA4AHb9nCqHfpIDheWBwAAAADAawI+R3uUB/7bi7Fd2bYvMQ4AAAAAALD94xLjAAAAAAAA2wtCHAAAAAAAAA8gxAEAAAAAAPAAQhwAAAAAAAAPIMQBAAAAAADwAEIcAAAAAAAADyDEAQAAAAAA8ABCHAAAAAAAAA8gxAEAAAAAAPAAQhwAAAAAAAAPIMQBAAAAAADwAEIcAAAAAAAADyDEAQAAAAAA8ABCHAAAAAAAAA8gxAEAAAAAAPAAQhwAAAAAAAAPIMQBAAAAAADwAEIcAAAAAAAADyDEAQAAAAAA8ABCHAAAAAAAAA8gxAEAAAAAAPAAQhwAAAAAAAAPIMQBAAAAAADwAEIcAAAAAAAADyDEAQAAAAAA8ABCHAAAAAAAAA8gxAEAAAAAAPAAQhwAAAAAAAAPIMQBAAAAAADwAEIcAAAAAAAADyDEAQAAAAAA8ABCHAAAAAAAAA8gxAEAAAAAAPAAQhwAAAAAAAAPIMQBAAAAAADwAEIcAAAAAAAADyDEAQAAAAAA8ABCHAAAAAAAAA8gxAEAAAAAAPAAQhwAAAAAAAAPIMQBAAAAAADwAEIcAAAAAAAADyDEAQAAAAAA8ABCHAAAAAAAAA8gxAEAAAAAAPAAQhwAAAAAAAAPIMQBAAAAAADwAEIcAAAAAAAADyDEAQAAAAAA8ABCHAAAAAAAAA8gxAEAAAAAAPAAQhwAAAAAAAAPIMQBAAAAAADwAEIcAAAAAAAADyDEAQAAAAAA8ABCHAAAAAAAAA8gxAEAAAAAAPAAQhwAAAAAAAAPIMQBAAAAAADwAEIcAAAAAAAADyDEAQAAAAAA8ABCHAAAAAAAAA8gxAEAAAAAAPAAQhwAAAAAAAAPIMQBAAAAAADwAEIcAAAAAAAADyDEAQAAAAAA8ABCHAAAAAAAAA8gxAEAAAAAAPAAQhwAAAAAAAAPIMQBAAAAAADwAEIcAAAAAAAADyDEAQAAAAAA8ABCHAAAAAAAAA8gxAEAAAAAAPAAQhwAAAAAAAAPIMQBAAAAAADwAEIcAAAAAAAAD/B38/FOrywFAAAAAAAANoueOAAAAAAAAB5AiAMAAAAAAOABhDgAAAAAAAAeQIgDAAAAAADgAYQ4AAAAAAAAHkCIAwAAAAAA4AGEOAAAAAAAAB5AiAMAAAAAAOABhDgAAAAAAAAeQIgDAAAAAADgAf8GD2aECAuZSrUAAAAASUVORK5CYII=\n",
      "text/plain": [
       "<Figure size 1440x216 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import shap\n",
    "import pandas as pd\n",
    "\n",
    "Xdf = pd.DataFrame(X, columns=X_df.columns)\n",
    "# explain the model's predictions using SHAP values\n",
    "explainer = shap.TreeExplainer(rf_dr_cate.effect_model)\n",
    "shap_values = explainer.shap_values(Xdf)\n",
    "\n",
    "# visualize the first prediction's explanation (use matplotlib=True to avoid Javascript)\n",
    "shap.force_plot(explainer.expected_value, shap_values[0,:], Xdf.iloc[0,:], matplotlib=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 684,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 576x684 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "shap.summary_plot(shap_values, Xdf)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 685,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 576x684 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": {
    "collapsed": true
   },
   "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
}
