{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "import matplotlib as mpl\n",
    "import numba as nb\n",
    "\n",
    "from sklearn.cluster import KMeans \n",
    "from sklearn.cluster import SpectralClustering\n",
    "from sklearn.cluster import AgglomerativeClustering\n",
    "from pathlib import Path"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "import sys\n",
    "\n",
    "sys.path.append('../../src')\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Imports"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "from base_exp_gen import generate_experiment as GEN_EXP\n",
    "from clustering_algos import  kmeans_clustering,\\\n",
    "box_clustering, adaptive_box2, optimal_clustering\n",
    "from sklearn.model_selection import train_test_split as datasplit\n",
    "from sklearn.ensemble import GradientBoostingRegressor as GDBR\n",
    "from evaluations import computeATT_per_cluster as ATTC, predict_cf, calculate_ite, get_homogeneity, generate_paths,\\\n",
    "confusion_matrix\n",
    "\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Set random seed for consistency across runs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "np.random.seed(seed = 0)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Set parameters for plotting"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "fonts = {'family': 'cmr10','weight': 'normal',\n",
    "            'size': 20}    \n",
    "div = 1\n",
    "\n",
    "l1 = 22/div\n",
    "l2 = 20/div\n",
    "l3 = 13/(div-0.2)\n",
    "\n",
    "mpl.rcParams['xtick.labelsize'] = l2\n",
    "mpl.rcParams['ytick.labelsize'] = l2\n",
    "mpl.rcParams['axes.labelsize'] = l1\n",
    "mpl.rcParams['font.serif'] = 'Times New Roman'\n",
    "mpl.rcParams['font.weight'] = 'normal'\n",
    "mpl.rcParams['font.size'] = 20\n",
    "mpl.rcParams['legend.fontsize'] = l3"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Pandas parameters for dataframe display"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "pd.set_option(\"display.max_columns\", None)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Directory to save figures"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "save = True\n",
    "path_figs = './figs/200K/'\n",
    "Path(path_figs).mkdir(exist_ok = True, parents = True)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Generate Experiment"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Number of Clusters:441, Number of Points:200000\n",
      "CPU times: user 169 ms, sys: 78.7 ms, total: 248 ms\n",
      "Wall time: 235 ms\n"
     ]
    }
   ],
   "source": [
    "%%time\n",
    "\n",
    "N,D = 2*10**5, 2\n",
    "x = int((N)**(1/4))\n",
    "clusters = x**2\n",
    "print(\"Number of Clusters:{}, Number of Points:{}\".format(clusters, N))\n",
    "kw_generate =  {'N':N, 'D':D,'f_gen_name': 'uniform_gen','low':0, 'high': 1}\n",
    "centers = [[0.5,0.5],[0.5,0.5]]\n",
    "r_small = [0, 0.325735]\n",
    "r_big = [0.325735,0.46065886]\n",
    "eligibilities = [2,1]\n",
    "kw_cluster =  {'f_class_name':'circle_class4', 'centers': centers,\n",
    "               'eligibilities':eligibilities,'r_small': r_small, 'r_big':r_big}\n",
    "kw_treatment = {'f_treat_name' :'uniform_treat','choices':[0,1], 'probabilities':[0.5,0.5]}\n",
    "\n",
    "std = 5\n",
    "stats = np.array([[1, std], [0, std], [0, std], [1, std],[1, std],\n",
    "                  [2, std]])\n",
    "kw_outcome = {'f_outcome_name': 'outcome1','treatment':'Treatment', 'cls':'C', 'stats':stats}\n",
    "\n",
    "data = GEN_EXP(kw_generate, kw_cluster, kw_treatment, kw_outcome).dat\n",
    "data = calculate_ite(data.copy(), treatment = 'Treatment',\n",
    "                     counterfactual = 'Ycf', outcome = 'Y', ite_name = 'ITE')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Plot generated experiment"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots()\n",
    "\n",
    "ax.scatter(data['x0'].values, data['x1'].values, c=data['C'].values, cmap = 'Greys', s=0.1)\n",
    "\n",
    "if save:\n",
    "    fig.savefig(path_figs+'data.jpeg',bbox_inches='tight', pad_inches = 0)\n",
    "    ax.set_aspect('equal', adjustable='box')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    " ### Estimate ITE with Gradient Boosting "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "CPU times: user 5min 13s, sys: 196 ms, total: 5min 13s\n",
      "Wall time: 5min 13s\n"
     ]
    }
   ],
   "source": [
    "%%time\n",
    "f1_kwargs = {'n_estimators':400, 'max_depth':18}\n",
    "f2_kwargs = {'n_estimators':400, 'max_depth':18}\n",
    "\n",
    "data, models = predict_cf(data.copy(), col_select = ['x0', 'x1'], f1 = GDBR,\n",
    "                          f2 = GDBR, cf_name = 'Ycf-GDBR', f1_kwargs=f1_kwargs, \n",
    "                          f2_kwargs=f2_kwargs, ite_name ='ITE-GDBR')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Apply box clustering (to be used as a sped up to PCM)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [],
   "source": [
    "col_select = ['x0', 'x1']\n",
    "data,_ = box_clustering(data.copy(), clusters = clusters, col_select = col_select )"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Calculate ATT per box cluster for optimal clustering"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [],
   "source": [
    "ite_name = 'ITE-GDBR'\n",
    "box2 = ATTC(data.copy(), cluster_name = 'Box-Cluster', ATT_CLUST_name='Box-ATT',\n",
    "           points_name='Box-points', weight_names='Box-Weights', ITE_name = ite_name,\n",
    "            hom_name = 'Box-Hom', att = False)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Optimal 1d clustering"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [],
   "source": [
    "name2 = 'Box-ATT'\n",
    "name = 'Opt-Clust'\n",
    "box2, means = optimal_clustering(box2, max_clusters = 7, col_select = name2, \n",
    "                      cluster_name = name, N=N )"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### PCM"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/mavrog2/.conda/envs/jorje/lib/python3.7/site-packages/numba/core/ir_utils.py:2031: NumbaPendingDeprecationWarning: \n",
      "Encountered the use of a type that is scheduled for deprecation: type 'reflected list' found for argument 'data_groups2' of function 'adapt_numba'.\n",
      "\n",
      "For more information visit http://numba.pydata.org/numba-doc/latest/reference/deprecation.html#deprecation-of-reflection-for-list-and-set-types\n",
      "\n",
      "File \"../../../src/clustering_algos.py\", line 427:\n",
      "@jit(nopython = True)\n",
      "def adapt_numba(data_groups2, new_ites, values, pivot_array,\n",
      "^\n",
      "\n",
      "  warnings.warn(NumbaPendingDeprecationWarning(msg, loc=loc))\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "CPU times: user 3min 24s, sys: 536 ms, total: 3min 25s\n",
      "Wall time: 3min 24s\n"
     ]
    }
   ],
   "source": [
    "%%time\n",
    "adaptive_ite_name = 'ITE-ADAPTIVE'\n",
    "ite_old_name = 'ITE-GDBR'\n",
    "data = adaptive_box2(data, clusters = clusters, ite_old_name = ite_old_name,\n",
    "                    ite_name = adaptive_ite_name, col_select = col_select)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Assign points to the corresponding means recovered by optimal 1-d clustering"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [],
   "source": [
    "clusts = len(means)\n",
    "means2 = means.reshape(3,1)\n",
    "\n",
    "data, km = kmeans_clustering(data, clusters = clusts, cluster_name = 'ITE-ADAPTIVE-3CLUST',\n",
    "                           col_select = [adaptive_ite_name], assign_means = True, means = means2 )"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "###  Appendix: A.1 Reconstructed Subpopulations (column: PCM (this work), row: 200k)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAASEAAAEBCAYAAAA3sRMtAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4xLjEsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy8QZhcZAAAgAElEQVR4nO29eXzU1dn3/75mMplksq+ELAQIhC3sm4iySVncFVQeK27tz/rT59b26XL3bmtbvV/au727eOtTbVErLvctpagVlVZEFpFNAiggO5iwJIEshOzLzJznj8kMSUhgkszMdyY579crr2/mu5xzzXxnPt9zrnOd64hSCo1GozEKk9EGaDSavo0WIY1GYyhahDQajaFoEdJoNIaiRUij0RhKmNEGBJLk5GQ1cOBAo83QaHotu3btKlNKpXTlmj4lQgMHDiQ/P99oMzSaXouIFHb1Gt0d02g0hqJFSKPRGIoWIY1GYyhei5CILBaR50Vks4hUiYgSkTe7U6mIZIrIX0SkSEQaRaRARJ4VkYTLXDNSRFaKyDkRaRCRwyLypIhEdscGjUYTHHTFMf0zYCxQA5wGhnenQhHJAbYCqcB7wCFgCvA4sEBEpiulyttdMxVYD1iAVcApYA7wc+A6EblOKdXYHXs0Go2xdKU79j0gF4gF/v8e1PkCLgF6TCl1q1Lqx0qpOcAfgGHA061PFhEz8CpgAxYrpe5WSv0rMBV4G5jeYptGowlBvBYhpdQGpdRR1YNp9yIyGJgHFAB/bHf4F0AtsFREolrtnwmMAD5VSq1uZY8T+FHLy4dFRLprl0ajMY5AO6bntGzXtoiIB6VUNbAFV4vnqg6u+Wf7wpRSJ4AjQDYw2OfWajQavxNoERrWsj3SyfGjLdvcHl6jCXIcDgdVVVU4nW2eRSilUEpRU1PDhQsX8GW+K6UUTqfTp2Vqek6gRSiuZXuhk+Pu/fE9vMaDiDwkIvkikl9aWuq1oRr/YjabiYiIwGS69CsoIhQVFVFZWekRJV8gIphMJnTPPbgItmkb7m9HV751l71GKbUMWAYwadIk/QgMEhwOBzU1NSQkJHhEweFw8NVXX/HZZ595zjOZTMyYMYORI0eilNIC0gsJtAi5Wy1xnRyPbXded6/RGIzT6aShoYHIyMgOhWPLli3s37+fBQsWMGjQIDZt2sSpU6eorq6+pJz9+/eTlpbGwYMHGTRoEOnp6YF6G5oAEGgROtyy7cx/M7Rl29r/051rNAGgqamJ7du3k5aWRnNzM6NGjfK0VgoKCoiKisJms+F0OjGZTG1aMmFhYZjNZqqrqzl+/DgHDhzotJ6ysjJWrFgBQGNjY7dFyF2/blEFF4EWoQ0t23kiYmo9QiYiMbhifuqB7a2uWQ/8FFgA/Kp1YS1D/rlAIXDCj3ZrOqCkpIT9+/dTVFREVFQUI0eOxOFwEBYWRkJCAn/961+JioqiurqaiRMnsmvXLiwWC3FxcZSVlQGuFlFXiI6O7ra91dXVvPPOO8yePZvs7Oxul6PxLX4RIRGxADlAs1LquHu/Uuq4iKzFFSv0KPB8q8ueBKKAPyulalvt3wQcBGaIyM3uWCERMQG/bjnnTz2JX9J0j6qqKgCsVivFxcUsW7YMi8VCdHQ0NTU1OJ1OT/dq165dADQ3N3sEqDtcKR9UZ62cpqYmVq9eTV1dHYmJiYCrVWW1Wrtti8Y3eC1CInIrcGvLy7SW7TQRWd7yf5lS6gct/2fgEo5CYGC7oh7BNW3jORG5ruW8qcBsXF2qn7Y+WSnlEJEHcLWIVonIKuAkcB0wCVds0R+8fR+artPU1ER4eLjntfuHvnnzZgCKi4s9xxwOBw0NDZ2WZbFYaG5u7rYtUVFROBwOzGbzJccqKio4evQoY8eOxWQyYbFYPILU0NDAqFGj2LZtG3v27CE1NZWUlBQtQkFAV1pC44D72u0bzMUgwULgB1yBltbQJOApXF2s64Fi4DngSaVURQfX7BCRybhaS/OAmJb6ngL+Q88b8y9ms7nND9/pdPLpp592a+i8JwIEUFBQwKhRo3jnnXeYMmUKmZmZABw/fpytW7dSXV3N2bNnycrKYtSoUR7xjImJYezYsRQUFDB+/HhiYmJ6ZIfGd3gtQkqpXwK/9PLcAi4OnXd0/BTwgLd1t1xzALijK9doek5+fj67du3i7rvv9ox0nT17loMHDxpiT3l5OXV1dTQ0NFBbW4vT6eTgwYPs2bPH0/U7ffo0p0+fZv/+/dx9992YzWZEBBFh7Nix2Gw2Q2zXdEywxQlpgozKykocDgfr1q1j8ODB7Ny5k/DwcEaPHs2+ffsCbs/w4cP561//Sn19PQMHDsRutzNq1CgOHjxIQ0MDTU1NgCu+6LrrrrskGHLwYD27J9jQIqTpFKUUhYWulMHFxcU0NjZit9uJjY3lzJkzhtj08ccf09jo6n2XlpZit9spLy/n3Llzbc5zOp0cOHCAqKgoT9ertraWiIgILBYLSinq6uqIioq6pA5NYNEipOmU0tJSzw8eXI5foEejWz3lwoWLMamrV6++zJlw5MgRjhw5wuDBg2lsbOSqq64iJiaG+vp6rFYr27dv57rrrvO3yZoroEVI0yFOp5PU1FSuvfZatm7disPhMNqkblNcXEx9fT3vv/8+TqcTu90OuEILnE6nx1+kMQadY1rTISKC0+lk9OjRnriaUKW+vh5whRq4BQhccULvvfce9fX1IS2yoY4WIU2HKKVwOBxs3LiR3px9oLi4mJUrV3oc2O73XV9fr1N+BAjdHdO0wT3Pa8OGDRw+fPjKF/QC6uvrqa2txeFwUFhYSElJCceOHeOOO+4gJSWFpqYmHA4HkZF6TQV/oEVI0wYRYc+ePZSXl1/55F6CUorXX3/d8zo9PR2TycSaNWtoaGggLCwMu93O/fffj91u94yoNTU1tYnK1iNu3UOLkAalFDt37vTMgh8+fDjbtm0z2izDKCoqAlxD+uCaimIymXj11VdxOp1kZWWRnp7Ovn37uPHGG0lKSqKpqYm33noLpRQPPOCKw9VOb+/QItSLqa6uJiYm5oqpK0pLS8nPzyc/Px+AlJSUQJkYMrROQ3v69GlOnToFwMqVK5k1axZ1dXXU1dUBsHfvXpKSkqisrCQ2NpasrCxDbA4VtAj1Aa70JI6OjsZkMnl+aL3ZEe0L2jusN27c2OZ168yQMTExLF26NBBmhSx6dKwXUlNTw8cff8yKFSvYt28fDQ0NbN68mfLy8g5HfGw2G+PGjTPA0t5NXFwcU6dONdqMoEe3hEKY1pkC3axdu5Zz5855JnM2Njby5ptv0tTUxL59+8jMzGTmzJkAxMa6MuOWl5fz9ddfB/4N9GIiIyNJT09n3bp1REZG6i7ZZdAi1AtwC9FXX33F8ePH2xz7/PPP27yura0lLs6Vrru4uJjIyEhWrlwZMFv7CvX19ZSXlxMdHY3FYjHanKBGd8dCmNa+ni+++ILBgwdf8Yl7/vx5z/D7Z599xpo1a/xqY1/m3Llz1NTU8OGHH/p06aLehhahXoBSinHjxtHQ0EBJSckVz9+6dSunT5+mtLSUysrKAFjYt2lsbGT58uWcOKHToHeE7o71ApxOJ//93/9NdHS0V5kLc3Jy2LBhwxXP0/iOxsZGnUytE7QIhThKKYqLi6mtrfUE112J9kPKGv/jdDpJTEzE4XBw4cIFEhISgCuHT/QFtAiFIO5RscbGRmprazl//rz2N4QAr7zyiuf/nJwcwsPDycjIYOjQoX1ajLQIhRhuASouLmbz5s2UlZV1uPKEJrhxj2IePHiQIUOG9OlFGbVjOkRwt3SOHz+OUoqjR496MhzqXDihi4iwbNkyXnnllT7ruNYtoSDG/WQsKyvjyy+/pKKigtLSUqKjoz0J3Xsrdrsdk8l0SaL63ohSisbGRj766CMiIiK44YYb6Nevn9FmBYzef4dDEKUUX3zxhWd99p07d3L48GHPnK6amppeK0LueJqioiJ+/OMfs2LFCq8d7qGIUqpNnqKGhgY+/PBDwBVY+t5771FQUEBJSQk1NTVGmelXdEvoMgS6j+5OKFZZWUlcXBzr16/n66+/5uTJkwGzwSgcDgcHDx4kLy+Pc+fO8etfu1b43rx5MzExMSxcuLDXpsVwz753406lUltby5kzZxARMjIymDhxIg6Hg/LyclJSUnrNZ6FF6DKIiCeXTCBueFFREcePH2fMmDEMGjSI5OTkkBOgzoTbm3Qif/rTn7jnnnsuWU5o3bp1REREUFNTww033EBYWO/+2n7xxRfAxeH706dPc+bMGTIzM9m/fz8DBgwgNTXVSBN9iu6OXYHDhw8HRICam5v56quv+OqrrzxrvE+YMMHv9fqazj4rp9PJ559/3mEogVKKr7/+mvDwcN544w3Wr1/f5nhTUxPvvvsua9eu5fz5836xOxhp/VkppXj77bc5fPiwoUsu+QMtQldg2LBhlJWV+SUOx+2QvHDhAqtWrfIM254+fZpNmzbxwQcf+LxOf9PZ53T69Glee+01Dh06dMkxEWHo0KGXdcYqpbjttttITk72ZD505z9yOBzU1dXhcDj6RLxUSUkJR48e7TXvtXe3a3uAUgqn08m2bduoq6tj3rx5Pq/jwoULREZGcujQoUue8F999ZXP6wsEIkJzczMWi4Xq6mpOnDjB6NGjWbVqFQAffPABycnJJCUlYTKZUEpx/Phxnn322Sv+qDZt2sSZM2c4dOgQd9xxB8ePH2fRokWYzWZsNhv79u0jIiKCoUOHBuKtBpz09HQGDhzI8OHDiYiIAALvt/QHWoQ6QUQwm82MHz+exsZGv9zsuLg4RCSkEqPb7XacTqcnPYVSCpPJRHFxMVFRUZw5c4YXX3yR3NxcDh8+jNPp5Dvf+Y7nfKvVyu9//3vuvPNOxo4di4hw7Ngxr57qFRUVfP755yxcuJAJEyZw/PhxnnjiCY/gNTQ0EBcXx89//nPPj7Q3UVRURGVlJSUlJVx77bVYLBbCwsK0CPV2oqKi/CYS7i+PO19xMOGekxYTE3NJnurly5dzzz33EBkZybJly7BYLOzduxe73Y7ZbPaMdAFkZmaSnZ3tGV4+f/48VVVVvPzyywwfPpwZM2YQHh6O1Wpts+T05di8eTMNDQ3s2LHDs7ChG5vN1qkAuUcf29Pc3IzZbA6J0be6ujpOnDjBgAED2Lx5Mw6Hg8TERK699lpSUlIIDw832sQuI72lX+kNkyZNUu5k7kbjXlhwyJAhnriQYEEpRX5+PsuXL2fgwIGEhYVRXFzMwoULWb16NU1NTZjNZoYMGeLV2mSRkZGXiAXgWUrHl4gIt99+O9dccw3V1dWcOnUKm81GTk4OJpOJ999/n5ycHEpLS5k+fTonTpzg+eefJzs7m6KiIp5++mkiIyM9YtSZcAUTSUlJzJ8/n/j4eKNNQUR2KaUmdekaLULGUFtby2uvvUZ4eHhQBR46HA5+9atfUVxcbLQpPcL9ubqFLjs7m5KSEhobGz3ztGw22yUxOm6+9a1veYQ32EUoOzubuXPn0tzcTHR0tKG2dEeEdHcsgNjtdsLCwqitrSU8PJwxY8ZQX1/P0aNHjTYNp9PJxx9/jNlsDnkBAjzC7m5pFRYWeo65H7ydCRC4Zrzn5eUFvQCB670tX74ch8PBQw89FHJxVKFlbYBxf1l76idQSrF//342b97MgAEDPFGwvu6KdBe73Y7dbmf16tVGmxJUiAgVFRVYLBZiYmKMNueyOBwOoqKiQjKjQpdkXkQyReQvIlIkIo0iUiAiz4pIgpfXzxIR5cVfVrvrLnfu9q68h67Q3NxMbW1tm4XvusOXX37pCUA8efIkDofDUAFy+3z279+P3W7n5MmT/OhHPzLMnmDlmmuuYf369W3yAAUjkZGRxMbGsnTp0qB3rHeE1y0hEckBtgKpwHvAIWAK8DiwQESmK6WutIB5AfBkJ8dGA7cDXymlOhouKgSWd7D/9BWN7ybh4eGcPXu2R/1sp9PJ2bNnfWhVzyksLOTVV1812oygZ/ny5dTX15OXl0d1dbXnexBsP3Sn00lDQ0PIBi92pTv2Ai4Bekwp9bx7p4j8Hvge8DTw8OUKUEoVAL/s6JiIvNXy77JOLi9QSnV4rT/JyMjo8Zri8+fP58UXXwyKL4lSinPnznmG0jWd4x7RKy8v59133+Xee+/l6NGjQRcM6Q5tqK6uDooRsq7ilQiJyGBgHq6WzB/bHf4F8BCwVES+r5Tqct4FEUkCbgPqgTe6er0/6alj0uFwsGXLlqAQIHA9xc+cOaMFqAsUFxdTUlJCaWkpUVFRQSdCbkJ1fTNvf2FzWrZrlVJtHCRKqWpgC2ADruqmHfcDVuBvSqnOZijGi8iDIvITEXlURLpb12VxP/3cUdI9xWKxkJaW1uNyfMktt9zCnXfeGXTdimBGKcXJkye55557guaB0p5QjRL3VoSGtWyPdHLcPcac2007vt2y/fNlzhkLvIKr2/d/gW0i8oWIjO5mnR1y6NAhGhsb2b17N01NTd36wrkd2UopSktL2bFjhy9N7Dbu93L06FHWr18ftD+mYMVut/PUU0+1Ge4PFkaNGhUS4QQd4a3VcS3bC50cd+/vcodURGYCw3E5pLd2ctrvgelAChADTAZW4RKm9SKScZnyHxKRfBHJd2cmvBzZ2dmcOXOGKVOmdDkE3j3p1T2i9v7777Nr1y6qqqq6VI4/+c1vfsMrr7ziWYVV0zVqa2v5r//6Lw4dOkRRUVHQdGu/+uorPvvsM8B3rfhA4SvpdLfru/POH2rZdtoKUkp9Xym1VSlVppSqUUrlK6XuAN4GkoEfXObaZUqpSUqpSSkpKVc0Jj4+nn79+nV7LlF1dbUnN/KFCxeCKinZxo0bOX36NLW1tSH1JQ02mpqaeP7553n66ac5fPgw9fX1PQ7j6Ckmk4nw8HDef/99rFarobZ0FW9FyN3SievkeGy787xCRBKBRXTfIf2nlu2MblzbISaTqUcTVjds2EB5eTlbt26luro6KAIS6+vreeGFF1i1alXQPLl7C83NzYhIh+lYAonT6WT//v2cOnWK1157zTA7uoO3Q/TuWYqd+XzcwwWd+Yw64z5cDunXlFLdWRTd3b8KilwYjY2NVFVVsX79+stOCQg0kZGR9O/fP2RzFAUzy5YtIysri1OnTjFkyBC+973vGWaLe6i+traWL774gvHjx9PQ0BD0DmtvW0LuhcvniUiba0QkBpe/ph7oavTy/9ey7Sw26Eq4R8iCYsEmq9XKvffey0033QS4ZokPGzbsClf5B3d3y+l0UldXx86dOw2xoy9w6tQpwsPDycvLM9oUD+75Y8XFxUGZKqY1XrWElFLHRWQtrlihR4HnWx1+EldL5M+tY4REZHjLtZfm83QdvxYYAey/jEMaEZkAHG4ffyQiY3CNlAG86c378Ddu/1F8fDxRUVFcffXVJCQkcOLECZqbmwNuy+7du1m9ejXl5eWG+yx6O7GxsSQnJwdNpsPdu3dz4cIFjh49ypgxY8jKyrryRQbRlYjpR3BN23hORK4DDgJTgdm4umE/bXf+wZZtZ3fE7ZC+UivoMeB2EVkPnAIacY2mLQDMwEvAW51fHnicTidKKTZu3Ehzc7Mhs5p/+9vfUlBQoB3QAaKsrIxXX32V5557DjA+7WptbS179+4FYNeuXZjNZsaNG2eYPZfD69ExpdRxYBKu+VtTge8DOcBzwDQv5o15aJnwuhjvHNJ/B9YBebh8SI8BE4F/ALcopR5SQfZLs1gszJw5k5EjRxIWFkZ2dnZAv5A1NTUsXbqUO++8M2B19nVEhBEjRvDb3/426Lo/drs9qMJE2qOTmvmRuro6ampqSE1NZf369R2uNOEvDhw4wIkTJ/jHP/4RsDo1F3n++eeDKngwNTWVxYsX+70endQsSHAvZdw633F1dXVAbfjLX/7SYUpVjf9JSkrq8aRnXxPMoRnBI9W9CBGhqamJTZs28fnnn/Pll18GLFuh3W7nwoULjB07NiD1aS6lvLycxx9/3BOVHgy9jfPnz3ti1oLBntbo7pgfqKmpYeXKlTQ0NPi9rvbs2rWLiRMncuDAAf74x/YJDzSB5sYbb2Tq1KkkJiYabQrgSk0za9Ys4uI6izvuGbo7FiRYrVbD0mympqby0ksvUVBQYEj9mrZ88MEH1NTUcMcdd3hyjBvJmTNnWLVqFampqdx4441B0V3U3TEf4m7uhoWFMXPmTENsyMrKYsmSJUE9GtLXyM/P5+233/YsX200jY2NVFdXB4UAgRYhn+IOSGxubqaiosIQG9zxKX2pmx3s1NXVsXHjxqBqndpsNqNN8KC7Yz7Ebrfz+uuve1YbDTTuUblQzjfcG3FHq//1r3/l6quvNrxLBnhm2hsdVAm6JeQzlFJERkYa4ox2IyLs2LGDX/ziF4bZoLk87pw/gZ7G0x73ctzB8LDSIuQjRIS3334bu90esCA1pRTvv/++53VtbS0fffRRQOrWdI+//e1vnDhxwvDWR2VlJR999FFQBFQa3y4McZxOJ+fPn+eTTz7xJBoP1GTRkydPsmXLFgYPHkxCQgIffvgh3mSP1BiLyWQKii5ZaWkpTqfTcCEy/pMIcZRSREVFUVZW5reb6e6319fXc+bMGXJychARzGYz1dXVvPDCC36pV+Mfnn/+ee68806mTp1qmA2JiYnk5uYa3iIDLUI9xuFwsGrVKsB/LaAzZ87w0ksvcf78eRwOB4mJiQwePJgjR7qaQ04TDDQ0NHDy5ElDRWjSpEn0798/KETI+A5hiBMeHs7ixYv9Gpy4du1aysrKPPN/KioqyM/P17FAIczGjRupre3yEn0+Y+3ataxbt86w+lujW0LdxD2qUFdXx7lz5/w2QbCuro6DBw9e+URNyFFZWcmZM2dITk4mMjKSyMjIgNUdHR3N5MmTA1bf5dAi1EXsdjsff/wxzc3NVFZW0tDQ4Ldk9k6nE4vFEhROTI3veeaZZwDXmmGPPPJIwOoNCwvjnnvuMdwh7UZ/u73E7RwuLi7m66+/DkidK1as4OjRo7rb1cs5cuQIn3zyCYmJiYwfP97v9cXGxnL8+HESExNJTEw03C+kRchLRIQtW7bw5ZdfBqQ+pRSzZ89m69ZO029regnNzc2kpqYyerRPFxPuELPZzOTJk8nJyWH16tVER0czYMAAhgwZ4ve6O0OLkJfU1tYGTIDAJXr9+/cnNjaWCxe6tJybJsQwm80kJSVRV1eHzWbz61QKh8PBZ599RmFhIbW1tZw+fZqCggJDRSg4OoUhQKCnY1RVVfE///M/WoD6AA6Hg//4j//gN7/5DQ6Hw+/do9raWg4dOoSIMHDgQBYuXOjX+q6Ebgl5gdPpZN26dVgsloDN+XnhhReCLmG6xn84HA6io6MDkofKarV6HNPuKH8j0S0hLzCZTNjt9oBOOrz66quDKt2Cxv/Ex8fz5z//2e+TSmfNmoXVag2aUVctQpehqqoKh8PBkSNHSE1NDWjdM2bMICoqKFa31gSA5ORkvv3tb3PzzTf7PQtCVFRUUKTwcKNF6DKUlJTQ2NhIbm4uY8eODfiTI5CxIxpjKSsr45VXXmHlypX069cPuBgQ66uWUUZGBqNGjQq6FnZwtMeCEKUUubm5gCtxfUJCApGRkQFbukcpRV1dHWazOaiXa9H4jt27dwOukdGVK1diNptZtGiRz8qfM2cOMTExQdUKAi1CneJOkSoiREZGsmPHjoCuHSYifP7551qA+iBKKTZt2gS4WkiZmZnccMMN1NbW9qgrtWfPnqDJ7Nga3R27DO4bXVxczBdffBHQupVSDBgwwNM01/RN9u7dy5o1a/jXf/1XzyTm7rZiBg8eHHQCBFqELktRURFvvvkmO3fuNKT+q666iocfftiQujXBRWRkJG+88Ua3p/CYzWY+//zzoEjn2p7gk8Ug4eDBg2zYsAHAkLlbIkJDQwPvvfdewOvWBB9KKYqLi6mrqyMhIaHL1zscDrKysjyLIQTL5FXQLaFLcK9WEcgpGp2xbNmygHcDNcFJWVkZw4cP71F3auTIkZhMJurq6nxoWc/RItSOhoYGIiIiDFu8sDUxMTFGm6AJIpYuXdojH6FbfKKjozs8blRXTYtQO3bu3EllZSWnT5822hTuvfdeZs2aZbQZGoMxmUw88cQTxMfH96ic8+fPX7LP3T0DDBu21yLUjsmTJ1NYWEh+fr7RpuBwOHQuIQ0RERGkpaX1KFxj4sSJ5Obm4nA4LhEedziKbgkFCWFhYYwZM8bQqFKHw8Enn3zCW2+95Qlg0/Rd6urq+O1vf9ujya21tbUopaivr+fFF19k+fLlbN++neLiYl577TUqKioMEyEJxiE7fzFp0iTlbQtHKcXGjRsNye9cXV1NTEwMy5YtCwoHucZYUlNTefjhh0lNTe1Rl2nQoEGXZAWNiIjgxhtvxGq1curUKeLj48nMzOx2HSKySyk1qSvXdKklJCKZIvIXESkSkUYRKRCRZ0XE6zFDEdkoIuoyfxGdXDdSRFaKyDkRaRCRwyLypIj4PDu4exWE2bNnG5LsyR1aHxsbG/C6NcFHcnIy/fr167HP5vz585eMrtlsNlJTUzlz5gyffvop27Zt61Ed3cHr8T4RyQG2AqnAe8AhYArwOLBARKYrpcq7UPeTney/JGu8iEwF1gMWYBVwCpgD/By4TkSuU0o1dqHuTikuLiYxMRFwdYtOnjzpi2K7THNzM5s3bzakbk1wceDAAc+obU/IyckhNzeXt956y7OvoqKCDRs2eL7306dP76m5XaYrQQcv4BKgx5RSz7t3isjvge8BTwNeh/cqpX7pzXkiYgZeBWzALUqp1S37TcBKYFFL/f/hbd2XIyoqCqvVCriCFI3qroaHhzN+/Hj27duHiAQ0l5EmuPDVstG7du26ZIjfZrNx8OBBbDab5/+0tLSABjN6VZOIDAbmAQXAH9sd/gVQCywVEX8kwJkJjAA+dQsQgFLKCfyo5eXD4qPxxdjYWM8oRF1dnaE//m9/+9s8++yz/O53vwuKDHgaYzCbzT57GK5Zs6bN67q6OsLCwqivr6empobDhw9TX18f0Ievt3I3pzF3q24AACAASURBVGW7tuXH70EpVQ1swdVSucrbikXkLhH5sYj8HxFZKCLWK9T9z/YHlFIngCNANjDY27ovx7Fjxzz94oyMDAYNGuSLYruNiARViL0m8DQ3N/PRRx/5TRjsdjtKKdLS0vjGN76BiNDY6PJu+Gtp89Z4++0e1rLtbPHzoy3b3C7UvQL4FfA7YA1wUkQWB6juTmlsbMRut1NSUsJnn33W4RpjYWFhxMXF+aK6K6KU4osvvtDdsT5OUlKS34MJCwoKWLduHWVlZTQ2NlJZWUlNTY0ntshfeNvRdP/iOlv6wb3fm5DO94DfAnuAclytmPuA7wN/FZEblVL/8FXdIvIQ8BDAgAEDrmjcyJEjERHq6+uJjY3lG9/4BoMGDaK6uppdu3ZRXFzM3Llz6d+/PytWrKCiouKKZXaXpqYmfvnLX+oVNzQBm8JjMpnIzMykubmZV155BYvFwv333+/X1rivZtG7JfqKcqmU+kO7XYeBn4hIEfA88Azwj0su7GbdSqllwDJwxQldsbCWp01kZCRjxozx7E9ISGDu3Lk4nU5MJhP19fXExcX5VYQ+/fRTLUAagIDlG3c4HLz77ruMHj0aEcFsNlNaWkr//v39Vqe38ub+JXTWB4ltd153eBnX8Pw4EWkt+4Go22vcTwSz2czZs2dJTk72W13XXHON38rWhA5ms9mvItCec+fO8emnn3oySrz//vvU19f7rT5vW0KHW7ad+V2Gtmw789tcEaVUg4hUAwlAFODOper3uruDxWKhX79+5OTkcOrUKUpLS33SKmpoaOBHP/oRt9xyC6WlpT6wVBOKxMbGcvvttzNw4ECSk5MDOrlUKUVTU5PntcPh4PXXX/dbgj1vRWhDy3aeiJhaj5C1tFqmA/XA9u4aIiLDcAlQNVDW6tB64KfAAlyO7NbXDMYlToXAie7W3R1EhIkTJ5KamsqQIUMwmUw+8RGFhYXhcDh45513fGSpJhSZMGECkydPNtoMD/4cJfOqO6aUOg6sBQYCj7Y7/CSulsvrSqla904RGS4iw1ufKCKDRSSjffkikowrIBFghVKqddT0JuAgMENEbm51jQn4dcvLPykDogrda5GZTCaqqqoIDw/vUXlKKbZv3x5UKyFojGHz5s3s2bPHaDMCQlcc04/gmrbxnIhch0sYpgKzcXWFftrufPfMz9a/qBnAyyKyCTgOVAADgOtx+XzyuRiACIBSyiEiD+BqEa0SkVXASeA6YBKuGKX2zu6A424+Hzt2jLVr13arDBHhwIEDQZkHWBNYHA4Hn332GWPGjAnI0tBXYvTo0X4r2+txt5bW0CRgOS7x+T6QAzwHTPNy3tgu4E1c0z8WtZSxANgHPAZMV0pVdlD3DmAyruH9ebimacQBTwHf8NW8sZ6yffv2bguQmwceeMBH1mhCnf/1v/6XIQJktVrbjMYlJCQwZcoUv9XXpSF6pdQpwKtfiVLqkj6FUmofcH9X6mx17QHgju5cGyiOHz/eo+uVUlRVVTFp0qSgSKqmMY5+/fqRlJRkSL1nz57l+uuvB2DDhg2MGzfOM5/SH+j5AD6kpz4hESEpKYnZs2fruWJ9nOuuu84Q32BNTQ0zZ86kvr6ec+fOUVlZyYYNGzh37pzf6tRJzXzMxx9/zNGjR698Yif885//ZNOmTTzyyCOICKdOnSIlJYW3337bsLQimsCTlpbGE088YbQZbXjkkUeueE53kprpdcd8hHtp3p7mfJk/fz6zZs3ylOPOcvfwww/zk5/8pMd2akIDd8vD4XAEhWPan+jumI9wJwvv6az7zoTMn9NDNMGH0+nkiSee8GukcrCgW0I+5Msvv2Tr1q09LsfdqlJKsWPHDv7+978H3YJ1Gv/zxBNP9NjPGArolpAPSUtL89kqHU6nE6UU586dw26392i5F01o8uSTnWVADjz+HCjRIuRD0tLSmDhxYo/Lca8FZTKZuPnmm7n77rt7vV9Acyl1dXVB0wL2Z4tMi5APUEp5Wio9GRlrTevh2QkTJuiVWPsYNpuNP/zhD36Nz+kK7kyL/kCLkA8QEZqamnjhhRcoKSnxSx12u90zUhaorI4a46irq+Pjjz8OmnmE/gyc1I5pH+B0OtmxY4df61i0aBFmsxmHw8FXX33FsmXL9ByzXk5ubm7QiJA/08rollAPUUrxxhtvcODAAb/W4/YJmUwmhgwZQnh4OBkZlyQk0PQSZs2axeHDh4NGhLRjOog5c+aMZ8XWQCAi2Gw2ZsyYETRfUI3v2bp1K++9916b5GJGon1CQUxaWhrp6ekBrVMpxcKFC0lI8Hr1bU2IMXToUH72s58FTZzQwIED/Va2FqEe0tzcTHl5V1a/9g1Wq5X777+f8ePHB7xujX8JCwujqanJkFn0neHPXOpahHrIxo0b/dpU7Qh3N6y+vr7PZN/rS0RERGCxWAyJDXOPvEZERJCWlubZN2lSl+akdgktQj0kIiKix5NWu0tCQgJDhw698omakMFkMhEfH8+jjz5qyMq77rXqk5KSPF1Bf0fr6yH6HnLVVVdRWFhoSN0Oh4OzZ88aUrfGPzidTs6fP++ZPxgoUlNTmTt3LjabjYyMDIYMGYLT6aShoQGr1epXQdQtoR5y4MABw0LrnU4nsbGxVz5RE1KYzWa+/PLLgNaZlZVFfHw8FouFESNGYLFYsFqtxMXF+b2lr0WohxiZYsNsNnP77bcbVr/GP1RVVfHSSy8FbNLy0KFDGTlyJIAhYR9ahHrAsWPHfDZXrDuYTCZSUlJ0KtheyNKlS/3umJ4wYQL3338/ycnJFBUV+bWuy6FFqAfExMSQnZ1tqA2JiYnMmzePUaNGGWqHxndce+21XHXVVX6tIz09nTFjxmCz2Rg/fjzDhg3za32XQ4tQD+jXr5+hN8/N3LlzeeSRRzxDqprQJSMjg0WLFvm9nqKiIg4dOuT3erxBj451E6UUx44dY+PGjUabgtPp5KOPPvLrigiawHDmzBmam5v92sXOzMwkJiaGIUOG+K2OrqBFqJvs3r3b7zPnvSUiIoJJkyaxevVqo03R9IBvfetbjBgxwq+jUYMGDWLhwoV+K7876O5YNxk7dixWqxWLxUJ0dLQhgWWtiY+PJzo62lAbNN3HZrMxYcIEIiMjfTpCFRERQV5eHjabjUWLFgWdAIEWoW4TFhbG+PHjaW5uJioqCqfT6TmWlJTEDTfcEFBhMplMxMTEBKw+je/4zne+ww9/+EO/lN3Q0EBxcTFLliwJ2pU7tAj1gLy8PGbPns1NN93UphUybdo0srOz/TrzuCMeffRRHbwYYiQkJJCenk5ycrLPk9TNnz+fcePGMWfOHCwWi+EjuZ2hRagHhIeHM2LECMLDw7nppptITk5GRCguLsbpdAb8yXPhwgXmz58f0Do1PeMHP/gBycnJmEwmnwcKOhwOsrOziY+Px2w2B23+KS1CPiIuLo5FixYxaNAgpk6dCsD58+cDVr+I0L9/f7Zv3x6wOjU9x19R0TabjbS0NDIyMoI+mFWLkI9wOp28++67zJ8/H6UUJpOJBx98kJycnIDZYLVaPeH3muDHnTbDH0I0ZsyYkOmaaxHyEWFhYSxcuJDq6uo2zd7m5uaA2pGXlxfQ+jTd57bbbvPbWvNKqZBZCEGLkA+x2WyXPH0mTJgQUBsGDhyoI6dDgFGjRjF58mS/ZE+Mj49nwoQJQesDao8WIR/S/qYrpUhPTw/oqITJZOKxxx7Ta5MFKRkZGTz22GPcfPPNKKXahHb4CpPJRFlZmc/L9RdahPyIW5Sqq6sDWm9sbGxQ5SfuK6SmphIVFXXZVKjZ2dkMGzaMzMxMRMTnTuPMzEzmzZtHSkqKT8v1J3rahp8xYqje6XTy3e9+lwMHDjBq1Ci2bt3K22+/HTTLx/RWwsPDeeyxx6ivr2ffvn1tco+np6cTHh7O7NmzcTqdPg9kjYyMpKmpiVmzZoWMQ9pNlz4JEckUkb+ISJGINIpIgYg8KyJerT0jIlEi8k0R+R8ROSQitSJSLSL5IvJ9EelwfRMRUZf5C+oxabcIBTJpudlsxmw2k5eXh8lk4pprrmHJkiUh4yMIVdzxOGlpaTzyyCNtRiobGhr44Q9/SEJCgl+6YBaLhaVLlxqW77wneN0SEpEcYCuQCrwHHAKmAI8DC0RkulLqSmvfXAu8CVQAG4C/A4nATcBvgdtF5DqlVEMH1xYCyzvYf9rb92AEYWFh3Hnnnbz33nsBy5TnprXoTJkyhdzcXF588UXOnDkTUDv6AtnZ2SxYsIDY2FiUUgwZMoSqqioOHjxIVFQUN9xwA+Cay+WPUauqqirq6ur8ujSPv+hKd+wFXAL0mFLqefdOEfk98D3gaeDhK5RRAtwD/E0p5ekbiEgMsBG4GngU+F0H1xYopX7ZBXuDhtjYWPLy8qioqODrr782xAYRISEhgYaGjvRd0xPmzp3Lbbfdht1uB1wpfz/55BNuv/12nnvuuTZdLxHxW4u0pKQkJEXIq+6YiAwG5gEFwB/bHf4FUAssFZGoy5WjlPpCKfXfrQWoZX81F4Vnljc2hRLh4eFMnTqVhQsXMm3aNKxWq2G23HvvvYDLgRkWpl2CvmDGjBkAns8zKSmJRYsWERYW5hGcQMTsHD58OKTig9x46xOa07Jdq5Rq06FtEZAtgA3oSU5Kd1SfvZPj8SLyoIj8REQeFRH/5r/0E+PHj/cIgRFkZGQQHR3Nv/3bv/Gf//mfhtnRm/jTn/7EJ5980maf2Wxus2xPIPxxZ8+e5eTJk36vx9d4K0LuHKZHOjnuzvae2wNbHmzZ/rOT42OBV3B1+/4vsE1EvhCR0ZcrVEQeanF855eWlvbAvO7T/slk5JMqMjKSf/mXf6G2thaLxcKsWbP4zne+E/Tzi4KZoqKiDn/8RgwEpKamIiIh1RryVoTckW8XOjnu3h/fHSNE5H8DC4AvgL90cMrvgelAChADTAZW4RKm9SKS0VnZSqllSqlJSqlJRsVOtP8yGp3bNzMzk6ioKGpqapg2bRpjxowhPr5bt67PY7Va+d73vscDDzxgtCnMnTuXyMjIgC+c2FN85RRwv+Muy6+I3A48i8tpvUgpdclkK6XU99vtygfuEJFVwCLgB7ic40GL0+mktLSUDRs2cP78eSwWCzExMYauWxYTE4PFYuGjjz7CqFZiqPPv//7vREVd1hXqdwYNGsT8+fM9LaBQEiDwXoTcLZ3O5gLEtjvPK0TkVmAFcA6YrZQ60ZXrgT/hEqEZXbwu4IgI/fr1Y+7cuezbt4+jR49yyy23cOrUKTZs2BDw4Xs3VquV7OxssrOzWbhwIQkJCdTX13Pw4EE++ugjQ2wKJYqKihg6dGjA683IyODmm2+mubnZs2Z8qOKtCB1u2Xbm83Hfhc58RpcgIncA/4OrBTRHKdWdVQTdj29jH0Ve4H46JScnM3v2bBISElBKERMTY5gAue0aPnw4w4cPB6C+vh6lFM8995xhNoUSL7/8Mr/+9a8DVl9kZCTx8fGMHTsWEQl5AQLvRWhDy3aeiJhaj5C1xPhMB+oBr6KXReRu4HXgDN1rAblxj5B193pDcDgcNDY2YrPZsNlsjBkzhr179xptFuD6kgPcd9995Ofns2/fvkvOuemmm8jPz6e4uDjQ5gUNEydOJDY2lmuuuSag9c6cOZPBgwcHNGGev/FKhJRSx0VkLa5YoUeB51sdfhJXS+TPSqla904RGd5ybRsvrIjch8v5XIhLgAovV7eITAAOty67Zf8YXCNl4IrCDhnMZjNTpkzxvO7oh24kSikmTZpEUlISc+fOpaGhgRdffJH4+Hjuu+8+cnNzmT9/Pk8//XSfESKz2expsT7++OMMHTo04L6X2NhYmpubqa2t7VUDCV1xTD+Ca9rGcyJyHXAQmArMxtUN+2m78w+2bD13SkRm4xIgE67W1QMd3MhKpdSzrV4/hms6x3rgFNAIDMc1mmYGXgLe6sL7CArc7/vrr78OuuFUt22DBg0CXE71O++8k4EDB5KVleU556677iI+Pp7XX3+dEydCqjHaZUSE+Ph4vv/975OYmBjw+m02GxaLhePHj5ObmxtyzufLIV35AYhIFvAULgFIAopxzf96UilV0e5cBaCUai1C9wOvXqGaQqXUwFbX3ArcC4zBNW0kAijHNUL2klLK6xX/Jk2apPLz8709PWCsWbOGgoICo83oNs3NzXz3u9812gy/ct9997VpvQaS8PBwFixYQGZmpiH1dwUR2aWU6jyXSUfXBNtT2J8EowgppaisrOSdd95pk/ohlKitrcVqtXLixAneeOMNQ8MOeoI760BH/rlnnnnGsERxN998c0gIEHRPhHRSM4NxTyz95je/yaxZszzzkEIJm81GWFgYzc3NQSNAAwYMuOxxd2RxayZMmMBDDz10SeDhE088YViOnjFjxoRUgrLuoEUoSIiIiCA5OZlt27YZbUqXcf+Yhw0bxpIlS1iwYIHBFrmSiLkZNmxYm8UprVYrTU1NHl9cTEwMIuJZ+2vChAncfffdpKenc9VVV3UoWIFARJg2bVpAc1EZgZ5GHSTs2LGD3bt3B52TuiuEhYVx7bXXAq4pBM888wx5eXl8+umngKvFVFdX55e6hw4ditVqpbi4mLvvvpvo6Gjy8/OJiYlh0aJF1NTU8OKLLxIdHc1TTz3F2bNnMZvN1NbWkpyczKFDh5g4cSLgytE8ffp0pk+f7hdbvcUtfL1dhLRPyGDcYfbr1683fE6ZP/jzn/9MYWEhFy5c4Prrr2fNmjXk5uZy5MgRMjIyPKvV+oJFixYxZ84cz2fa3NxMU1NTm2kVJ0+eJCsrK6hHl9LT08nKyvIsXhhKdMcnpFtCBlNZWYnFYuH06aBOENltFi9eTFJSEufOnSMlJcXj89q2bRvz5s3j8ccf90qETCYTiYmJVFVVtcmVfdttt9HU1MSpU6cYMWIEcLEFYbFYLskOcCVfkdFMnjwZi8XCqFGj+kxmA+0TMpimpia2bNlCfX19r1whw/2e3H6VmJgYrFYr8+bNQynFt771LWJiYjznR0VFYbPZLilnwoQJ/OxnP2PUqFEekRk4cCBz585l3Lhx3HrrrfTv3z8wb8qPxMXFMW7cuD4jQKBbQobTr18/5s+fT11dHTabjQ8++CAkE1N1Bfd8JxFhzJgxNDY2snz5cgDS0tJ48MEH+elP28a+5ufnM2TIEKZMmcJ9993H4cOHqa6uxul0kp6eHtK+tNaEaphGT9AiFCRYrVZKSkqoqKggIiKiT+WCzs7Opn///pw9e5bFixeza9euNsdTU1MZO3YsUVFRnlievLw8jhw54snfHMw+Hm+IjIxkyZIlnrl7fQktQkGCe6kYk8nEkiVLcDqdrFixok+sFZaamsq//du/8c9//tOTqD07O5vCQte0wtLSUr7xjW9ckrcnJycnJPPndISIhORyPb5A+4SCCKUU3/zmN7HZbERHR/Ptb3+b66+/vkMfSW/DbDYzefJkCgsLGTBgALfeemub4z/96U85derUJdeEsgANHTrU05K77bbbQvq99ATdEgoiOvoSZmVlcdddd7F3795Luim9jdTUVFJTU7lw4YIn02N0dDR5eXnk5eXRr18/gy30HWFhYcydO5e5c+cCod+d7Am6JRTkuJ/2NputT3xRS0pK+MlPfsLevXv5+c9/jslkYtCgQYwfP75XJPByc88993j+7wv39XJoEQoBrFYro0aNYvHixb3ecRkVFUViYiJnz55l1apVVFVVsXLlSo9/qLdQWlrq14UQQwktQiGAe15TSkoK06ZNazMPqrcRExPDU089RVZWlmfSqMPh8OQx6g1YrVYSEhKMNiNo0D6hEOLcuXM4nc4+EUuydOlSnE4nFy5c4ODBgxQUFDB48GCjzfIJQ4YMMWxWfjCiRSiEcDtuzWYzmzZt8qx93tsQESwWC06nk8mTJzNr1izi4uJoamrqFX4hd3zThAkTDF8uKBjQ3bEQJCMjo9f7hkQEs9nM1KlTycvLIzExsdckdxcRCgsLg3ZqRqDXs9ctoRAkOjqaGTNm8OGHHxptSsBwr9sWirhHN202GzNnziQ2NjboAxMDuZCiFqEQxG63k5qaSkREBA6HA7vdjlKKsLAwJk+ezNGjRykrKzPaTA0QHx/PrFmziI6ODhk/kFt4AjVyp0UoBAkLCyMsLIzrr7+efv36UVhYyJo1a7jrrruIi4sjLS2Nd99912gz+yRDhw5lwIAB7N+/n6ysLCIjI4mIiKCoqMiTwVHTFi1CIczZs2exWq1UVlYCsH//fpRSHD9+3Kvr3U/nIUOGsHXr1l7r6PYHFouF5ubmS/ZXVFQwffp0hg0bhsPhwGw209DQQE5OjgFW9gylFA6Hg7Aw/8qEFqEQZsSIEbz88suEh4djtVoZO3Ys0dHRXLhwgcbGRqxWKzfddBOxsbG8/fbb2O12YmJimD59Op999hm33HIL58+fJyEhgSNHjlBSUmL0WwoaoqKiSEpK6jStSnNzM8nJyVRXV5Obm0tGRgZbtmzhzjvv9CRpc6dljYiIwG63h0wraOfOnWRnZ5OamsqHH37IDTfcgMlk8sxz8zVahEKY8PBw5syZQ0REBDExMURHR6OU4oYbbqC+vh6r1er54judTu644w7PEPf06dNpamrCYrGwbds2zp8/z0033cS+fftCeg00X3H99deTkpJCbW0te/bsYf/+/ZhMJux2O6NGjSIxMZGsrCyamppITU1FKUV6ejolJSWkpqZ6ylFKYbfbKSkpITMzMyiFqLUDevfu3ezcuZM9e/YQHx9PXl4eYWFhPkvB2xFahEKc4cOHt3nt/jJZrVZMJpNnqDUsLKxNjI07ZUZ4eDjTpk0jJyeH1NRU0tLS2LJlCwcOHPCMkPR2RISRI0dSUFCAUorx48d7MkJGRUUxduxYGhsbmTVrFsXFxfTv3/+S5PPuVBz9+/f3LBft3h8WFhY0AmS326moqPAIp3vqyOeff86kSZM8gbB2u52ysjJqampobm7m0KFDjB492i826UT3fYDTp0+TkJBw2cA4p9OJUgqz2cyePXuIi4tjwIABrF69utd30xYuXMigQYOoqqqitra2x2ligznH0Y4dO2hububqq6+mtLSUfv360dTUxLlz50hKSiIiIoLS0lIqKio8KWQGDBjg9XvSie41HtwPl5KSEs6ePdtmHa6OaN3fdz/5zWYzt99+O2+99VavCRTsiJ07d1JXV0ddXR2TJ0/ucXnBKkAVFRXs2rWL6Oho9u7d68nmGBER0WZVj9TUVOx2O+np6dTV1XmCF/31vrQI9VIKCwvZvXs3Nputy4sRmkymNhHZd911F8eOHWPbtm3U1tYyfvx4jh07RnV1ta/NNoSKigo2bdpEamqqT0QoWDl27BjR0dFkZGRgs9mIiIjoNPI+NTWV2tpaT+vZn8KqRaiXMnDgQE88UU8xmUwMHTqU3NxcnE4nJpOJ0aNH8/rrr3v8RiaT6RLnpYiQlJREeXl5UPuWnE4neXl5noUbeyvHjh2jpqaG8ePHExcXR01NTactHF99d7xBi1AvJjMz02dlub+o7m6b1WplyZIlfP3115SUlDBv3jzOnz/PBx98wOLFi3E4HHz55ZeMHj2ad999l7FjxxIfH8/HH39MTEwMSUlJFBYWkp6eTl5eHrt37/ZkUww0FouFvLy8oO1G+YrbbruNhoYGEhISUEoRFxdntEmAFiFNN7FYLCQmJpKQkOD58SYlJXHNNdd4pifMnDmTs2fPYjKZ6N+/PzExMVgsFoYNG8aUKVMoKyvzjNIlJiayZs0a7HY7tbW1frffPYs9Pz+f5ORkEhMTg9qh7AsiIyM93a9gep96dEzjd9yRw61xOzvdLSv391ApxYoVKzxR4N3FZrORmZnJ0aNHO+wKjh07lunTp1NXV+cJZ4Dg+nGGIt0ZHdOpPDR+p70AwcVska1fiwhVVVWkpaWxZMkSZs+e3WZ1VnAtk5ydnd1pXdHR0VgsFqKjo5k9ezZDhgzxHIuIiPDMxHe3tmw2myePtxYgY9DdMU1QERsby5w5cwBISEhg4MCB7Nixg5iYGJRSTJo0iYqKik5zTvfv35+jR4/S2NjoSZJ/9OhRAKZNm8bQoUPZsWMHo0aN6vXdr1BBi5AmqGjfOoqMjGTWrFnAxS5cdXU1NpuN66+/nsrKStatWwe4RnTGjx9PcnIy27dvp7Gxsc0Ij/v16NGjqaurIzIyEqvVGtD3p7mULnXHRCRTRP4iIkUi0igiBSLyrIh0KWu3iCS2XFfQUk5RS7mdDuf4qm5N6OLuMmVnZ3PfffeRmppKTk6Op7tnNptJSkoiNTWV8PBwCgoKWLNmjef6Y8eOceHCBcrLy9m6dasWoCDBa8e0iOQAW4FU4D3gEDAFmA0cBqYrpcq9KCeppZxcYD2wExgO3AKcA6YppU74o+6+6ph2x+/4axa00axbt44jR44ALiFyT0F58MEHOXbsGJ9++qnn3PDwcAYNGkRBQQHDhg0jJSWFYcOGGWV6r8PfjukXcInAY0qpW5VSP1ZKzQH+AAwDnvaynGdwCdAflFLXtZRzK/B4S/kv+LHuPklvFR83M2bMYPTo0VgsFubNm+cZDXM6neTm5rY5d8yYMYwbN47Gxkb27t1LfX29ESZrWuFVS0hEBgPHgQIgRynlbHUsBigGBEhVSnUa5CEiUUAp4AT6K6WqWx0ztdQxsKWOE76sG/pmS0gpxe7du+nfv/8V54/1Fv72t79RWlrKzTffTFpaGsuWLWPy5MnYbDZGjBhBXV0df//73xkxYgQTJkzQzmkf4s+W0JyW7drWIgDQIiRbABtw1RXKmQZEAltaC1BLOU5gbcvL2X6ou08iIgwYMKBXLJXjLTfeeCPz5s0jPT0ds9lMRkYGTU1NjBw5EpPJ5JmYO3HiRC1AQYC3IuTuXWFSYgAABOlJREFUNB/p5PjRlm1uJ8d7Uk6P6haRh0QkX0TyjZoWYCRKKU+ys75CZGQkQ4YMQUQ8eXEOHTrk8Y19+eWXrFu3rsP0rJrA4+0QvXuSyYVOjrv3x/uhnB7VrZRaBiwDV3fsCvb1OkSEc+fOeXLD9CVEhKamJhYsWEBzc7On1ZOTk6MFKIjwVZyQu03b0x95d8rxVd29lstFGPd2oqKiLknmlpKSQkpKikEWadrjbXfM3drobNptbLvzfFmOr+rWaDRBiLcidLhl25nPZ2jLtjO/TU/K8VXdGo0mCPFWhDa0bOe1DKV7aBkmnw7UA9uvUM72lvOmt1zXuhwTMK9dfb6sW6PRBCFeiZBS6jiu4fOBwKPtDj8JRAGvt47TEZHhItJmKQilVA3wRsv5v2xXzv9uKf+j1hHT3albo9GEDj2ZtnEQmIorpucIcHXrqRMiogCUUtKunPbTNj4HRnBx2sbVLcLT7bo7oy8GK2o0gcSv0zZahGESsByXAHwfyAGewzXf64oi0FJOOa6gxeeAIS3lTAVeBSa2FyBf1q3RaIIPnVlRo9H4DJ1ZUaPRhBx9qiUkIqVAxyn52pIMlPnZHI136HsRHHh7H7KVUl2KBO1TIuQtIpLf1Salxj/oexEc+PM+6O6YRqMxFC1CGo3GULQIdcwyow3QeND3Ijjw233QPiGNRmMouiWk0WgMRYuQRqMxFC1CGo3GUPqECBm5aKPmIr64DyKyUUTUZf4i/PkeQh0RWSwiz4vIZhGpavnM3uxmWT75XfX6ZaAvs3Di48ACEenuoo0rcC3a+ABwg4hcsmij5iK+ug+teLKT/fYeGdr7+RkwFqgBTuP6DncZn95P9/revfUP+AhX/ul/abf/9y37/+RlOX9uOf/37fY/1rL/n0a/12D+8+F92Oj62hr/nkLxD1f6m6G4crPPavns3zTqfiqlevcQvZGLNmou4ssFLEVkIzBTtctTpek6IjILV+bS/1ZK3dOF63x2P6H3+4SMXLRRcxGfL2ApIneJyI9F5P+IyEIRsfrOXM0V8On97O0iZOSijZqL+OPzWwH8CvgdsAY4KSKLu2eepov49H72dhEyctFGzUV8+fm9B9wEZOJqnQ7HJUbxwF9FZGEP7NR4h09/D71+dOwKGLloo+YiXn9+Sqk/tNt1GPiJiBQBzwPPAP/wrXmaLtKl30NvbwkZuWij5iKB+PxexjU8P679clIan+PT+9nbRcjIRRs1F/H756eUagDcgwZRlztX02N8ej97uwgZuWij5iJ+X8BSRIYBCbiESKeD9S8+vZ+9WoSUgYs2ai7iq/sgIoNFJKN9+SKSjGvJKIAVSikdNe0DRMTSch9yWu/vzv28bD29OVgRjF20UXMRX9wHEbkfl+9nE65guQpgAHA9Lv9EPvANpVSl/99RaCIitwK3trxMA+YDJ4DNLfvKlFI/aDl3IPA1UKiUGtiuHJ8sSAr0/mkbLSKbhetJWQw04Vpx47+AxA7OVXQyLQBIbLmusKWcYuAvQKbR7zEU/np6H4DRuBbA3AeUA824hGgz8C9AuNHvMdj/cLXk1WX+ClqdO7D9vu7ez8v99fqWkEajCW56tU9Io9EEP1qENBqNoWgR0mg0hqJFSKPRGIoWIY1GYyhahDQajaFoEdJoNIaiRUij0RiKFiGNRmMo/w9N/PQYqJ+OvwAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "path3 = path_figs+'reconstruction/'\n",
    "Path(path3).mkdir(exist_ok = True, parents = True)\n",
    "\n",
    "fig, ax = plt.subplots()\n",
    "\n",
    "sc = ax.scatter(data['x0'].values, data['x1'].values, c=data['ITE-ADAPTIVE-3CLUST'], cmap = 'Greys', s = 1)\n",
    "\n",
    "if save:\n",
    "    ax.set_aspect('equal', adjustable='box')\n",
    "    fig.savefig(path3+'{}.jpeg'.format('ITE-ADAPTIVE-3CLUST'), bbox_inches='tight',pad_inches = 0)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Figure 2. Main Text, (column: PCM (this work), row: top)\n",
    "### A.2 ITE Histograms (column: PCM (this work), row: 200k)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/mavrog2/.conda/envs/jorje/lib/python3.7/site-packages/seaborn/distributions.py:2619: FutureWarning: `distplot` is a deprecated function and will be removed in a future version. Please adapt your code to use either `displot` (a figure-level function with similar flexibility) or `histplot` (an axes-level function for histograms).\n",
      "  warnings.warn(msg, FutureWarning)\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "path2 = path_figs+'histograms/'\n",
    "Path(path2).mkdir(exist_ok = True)\n",
    "\n",
    "fig, ax = plt.subplots()\n",
    "\n",
    "ax = sns.distplot(data[adaptive_ite_name],  bins=400, kde = False,ax = ax)\n",
    "ax.set_xlabel('ITE-PCM')\n",
    "#ax.set_xlim(-2,2)\n",
    "if save:\n",
    "    fig.savefig(path2+'adaptivehist.pdf', bbox_inches='tight',pad_inches = 0)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [],
   "source": [
    "from evaluations import MAE_pd "
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Table 1, Main text (column: PCM (this work), row: 200K)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>mean</th>\n",
       "      <th>std</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>ITE-ADAPTIVE-3CLUST-err-GDBR</th>\n",
       "      <td>0.109</td>\n",
       "      <td>0.224</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                               mean    std\n",
       "ITE-ADAPTIVE-3CLUST-err-GDBR  0.109  0.224"
      ]
     },
     "execution_count": 25,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "#ite_column = 'ITE-GDBR'\n",
    "ite_column = 'ITE-GDBR'\n",
    "clust2 = 'ITE-ADAPTIVE-3CLUST'\n",
    "data = data.groupby(clust2).apply(lambda x: MAE_pd(x, 'C', ite_column, clust2+'-err-GDBR'))\n",
    "errors = data.describe().loc[['mean', 'std'], [col for col in data.columns if 'err' in col]].T\n",
    "errors.sort_values(by = 'mean').round(3)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Table 2, Main text (columns: PCM (this work), row: 200K)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "ITE-ADAPTIVE-3CLUST\n",
       "0    0.064\n",
       "1    0.963\n",
       "2    1.947\n",
       "Name: ITE-GDBR, dtype: float64"
      ]
     },
     "execution_count": 24,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "data.groupby('ITE-ADAPTIVE-3CLUST').mean()['ITE-GDBR'].round(3)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Figure 2 (column: PCM (this work), row: bottom)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>C0 Pred</th>\n",
       "      <th>C1 Pred</th>\n",
       "      <th>C2 Pred</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>C0 True</th>\n",
       "      <td>0.915</td>\n",
       "      <td>0.085</td>\n",
       "      <td>0.000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>C1 True</th>\n",
       "      <td>0.044</td>\n",
       "      <td>0.919</td>\n",
       "      <td>0.037</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>C2 True</th>\n",
       "      <td>0.000</td>\n",
       "      <td>0.026</td>\n",
       "      <td>0.974</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "         C0 Pred  C1 Pred  C2 Pred\n",
       "C0 True    0.915    0.085    0.000\n",
       "C1 True    0.044    0.919    0.037\n",
       "C2 True    0.000    0.026    0.974"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "from IPython.display import display\n",
    "\n",
    "path4 = path_figs+'matrices/'\n",
    "Path(path4).mkdir(exist_ok = True)\n",
    "\n",
    "mat = confusion_matrix(data, 'C', 'ITE-ADAPTIVE-3CLUST', 3, save = save, save_dir = path4)\n",
    "display(mat.round(3))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python [conda env:jorje]",
   "language": "python",
   "name": "conda-env-jorje-py"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.7.2"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
