{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "VyVyoLZXEp70",
    "outputId": "5bae6b5c-4b14-4d40-bc17-e6cc4194a56f"
   },
   "outputs": [],
   "source": [
    "# from google.colab import drive\n",
    "import pickle\n",
    "# drive.mount('/content/drive')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {
    "id": "ziwrREgJx5ov"
   },
   "outputs": [],
   "source": [
    "dname = 'A548_cells'  # 'TDC_datasets/cyp2c19_veith'  # 'TDC_datasets/ames_mutagenicity'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {
    "id": "33zdXjdb2OZ0"
   },
   "outputs": [],
   "source": [
    "EXP_NAME = 'testing_pickle1'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {
    "id": "bo8IFgCbT80v"
   },
   "outputs": [],
   "source": [
    "BASE_DIR = '/data/'  # Path to load data from\n",
    "# BASE_DIR = '/content/drive/My Drive/chem_ood_datasets'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {
    "id": "we_9ZHOJ1u77"
   },
   "outputs": [],
   "source": [
    "SAVE_DIR = ''"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "!module load cuda/12.3"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "Cu709diOzAUj",
    "outputId": "0f01931b-bcd9-4405-ed30-f753cf232b6c"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-05-15_17:17:53\n"
     ]
    }
   ],
   "source": [
    "from datetime import datetime\n",
    "now = datetime.now()\n",
    "dt_string = now.strftime('%Y-%m-%d_%H:%M:%S')\n",
    "print(dt_string)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {
    "id": "MHh5CY-k2Cq3"
   },
   "outputs": [],
   "source": [
    "import os\n",
    "save_path = os.path.join(SAVE_DIR, dname, EXP_NAME)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {
    "id": "EXxipvmSWDIi"
   },
   "outputs": [],
   "source": [
    "%matplotlib inline\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import scipy.stats\n",
    "import pandas as pd"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {
    "id": "FDwgr2mvrr43"
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2024-05-15 17:17:56.644674: I tensorflow/core/platform/cpu_feature_guard.cc:210] This TensorFlow binary is optimized to use available CPU instructions in performance-critical operations.\n",
      "To enable the following instructions: AVX2 AVX512F FMA, in other operations, rebuild TensorFlow with the appropriate compiler flags.\n",
      "2024-05-15 17:17:58.535083: W tensorflow/compiler/tf2tensorrt/utils/py_utils.cc:38] TF-TRT Warning: Could not find TensorRT\n"
     ]
    }
   ],
   "source": [
    "import tensorflow as tf\n",
    "import tensorflow_probability as tfp"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {
    "id": "MiA1dcJqpTKA"
   },
   "outputs": [],
   "source": [
    "from xgboost import XGBClassifier\n",
    "from xgboost import XGBRegressor\n",
    "from scipy.linalg import null_space\n",
    "from sklearn.cross_decomposition import CCA\n",
    "from sklearn.ensemble import RandomForestClassifier\n",
    "from scipy.spatial.distance import cdist\n",
    "from sklearn.linear_model import LogisticRegression"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {
    "id": "ZvQxVPBdwJfc"
   },
   "outputs": [],
   "source": [
    "from scipy.integrate import trapezoid\n",
    "from sklearn import metrics\n",
    "\n",
    "# def auprc_threshs(confidences, Y, threshs, as_percentages=True):\n",
    "#   areas = []\n",
    "#   sorti = np.argsort(-confidences)\n",
    "#   sortY = Y[sorti]\n",
    "#   precisions = np.cumsum(sortY)/np.arange(1, len(sortY)+1)\n",
    "#   recalls = np.cumsum(sortY)/np.sum(sortY)\n",
    "#   for t in threshs:\n",
    "#     # recalls_eq_t = np.equal(recalls, t)\n",
    "#     # if np.any(recalls_eq_t):\n",
    "#     #   interp_prec_t = recalls[recalls_eq_t][0]\n",
    "#     # else:\n",
    "#     #   interp_prec_t = np.interp(t, recalls, precisions)\n",
    "#     interp_prec_t = np.interp(t, recalls, precisions)\n",
    "#     recalls_thresh = np.concatenate(([0.0], recalls[recalls<t], [t]))\n",
    "#     precisions_thresh = np.concatenate(([1.0], precisions[recalls<t], [interp_prec_t]))\n",
    "#     area_t = trapezoid(precisions_thresh, recalls_thresh)\n",
    "#     # area_t = metrics.auc(recalls_thresh, precisions_thresh)\n",
    "#     if as_percentages:\n",
    "#       area_t = area_t/t\n",
    "#     areas.append(area_t)\n",
    "#   return np.array(areas)\n",
    "\n",
    "def auprc_threshs(confidences, Y, threshs, as_percentages=True):\n",
    "  areas = []\n",
    "  precisions, recalls, thresholds = metrics.precision_recall_curve(Y, confidences)\n",
    "  for t in threshs:\n",
    "    if t < 1.0:\n",
    "      interp_prec_t = np.interp(t, recalls[::-1], precisions[::-1])\n",
    "      recalls_thresh = np.concatenate(([t], recalls[recalls<t]))\n",
    "      precisions_thresh = np.concatenate(([interp_prec_t], precisions[recalls<t]))\n",
    "    else:\n",
    "      recalls_thresh = recalls\n",
    "      precisions_thresh = precisions\n",
    "    area_t = metrics.auc(recalls_thresh, precisions_thresh)\n",
    "    if as_percentages:\n",
    "      area_t = area_t/t\n",
    "    areas.append(area_t)\n",
    "  return np.array(areas)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {
    "id": "8Id7d7pQs3Wd"
   },
   "outputs": [],
   "source": [
    "external_colstart = 4 if dname in set(['dataset1', 'dataset2', 'dataset3', 'dataset4']) else 2  # SHOULD BE 4 for 'dataset1' ... 'dataset4' otherwise 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {
    "id": "dguz7FBcW5mq"
   },
   "outputs": [],
   "source": [
    "with open(os.path.join(BASE_DIR, dname, 'train.csv'), 'r') as f:\n",
    "  dataX = np.float32(np.array([line.strip().split(',')[2:] for line in f])[1:])\n",
    "\n",
    "with open(os.path.join(BASE_DIR, dname, 'train.csv'), 'r') as f:\n",
    "  dataY = np.float32(np.array([line.strip().split(',')[1] for line in f])[1:])\n",
    "\n",
    "X = dataX\n",
    "Y = dataY"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {
    "id": "48e-tD-8W5mq"
   },
   "outputs": [],
   "source": [
    "with open(os.path.join(BASE_DIR, dname, 'val_id.csv'), 'r') as f:\n",
    "  dataX_val = np.float32(np.array([line.strip().split(',')[2:] for line in f])[1:])\n",
    "\n",
    "with open(os.path.join(BASE_DIR, dname, 'val_id.csv'), 'r') as f:\n",
    "  dataY_val = np.float32(np.array([line.strip().split(',')[1] for line in f])[1:])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {
    "id": "Ww0XXrrvW5mq"
   },
   "outputs": [],
   "source": [
    "with open(os.path.join(BASE_DIR, dname, 'test_id.csv'), 'r') as f:\n",
    "  dataX_tst = np.float32(np.array([line.strip().split(',')[2:] for line in f])[1:])\n",
    "\n",
    "with open(os.path.join(BASE_DIR, dname, 'test_id.csv'), 'r') as f:\n",
    "  dataY_tst = np.float32(np.array([line.strip().split(',')[1] for line in f])[1:])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {
    "id": "-Zt3t0tqW5mr"
   },
   "outputs": [],
   "source": [
    "with open(os.path.join(BASE_DIR, dname, 'val_ood.csv'), 'r') as f:\n",
    "  external_X = np.float32(np.array([line.strip().split(',')[external_colstart:] for line in f])[1:])\n",
    "\n",
    "with open(os.path.join(BASE_DIR, dname, 'val_ood.csv'), 'r') as f:\n",
    "  external_Y = np.float32(np.array([line.strip().split(',')[1] for line in f])[1:])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {
    "id": "vaojUtEdY2p2"
   },
   "outputs": [],
   "source": [
    "X = dataX\n",
    "Y = dataY\n",
    "\n",
    "# standardize the data\n",
    "mu_x = np.mean(X, 0, keepdims=True)\n",
    "#sigma_x = np.std(X, 0, keepdims=True)\n",
    "sigma_x = np.ones_like(mu_x)\n",
    "X = (X-mu_x)/sigma_x\n",
    "\n",
    "# PCA\n",
    "XtX = np.matmul(X.T, X)\n",
    "eigvals, eigvecs = np.linalg.eig(XtX)\n",
    "sortinds = np.argsort(-eigvals)\n",
    "V = eigvecs[:, sortinds]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {
    "id": "T8FwitHVZ0-W"
   },
   "outputs": [],
   "source": [
    "external_X = (external_X-mu_x)/sigma_x\n",
    "# held_X = (dataX_val-mu_x)/sigma_x\n",
    "# held_Y = dataY_val\n",
    "held_X = (np.concatenate((dataX_val, dataX_tst), 0)-mu_x)/sigma_x\n",
    "held_Y = np.concatenate((dataY_val, dataY_tst), 0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {
    "id": "2PuqxRwXJICh"
   },
   "outputs": [],
   "source": [
    "NDIRS = 128  # 256\n",
    "X = X@V[:, :NDIRS]\n",
    "held_X = held_X@V[:, :NDIRS]\n",
    "external_X = external_X@V[:, :NDIRS]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {
    "id": "_U_l31CacP8F"
   },
   "outputs": [],
   "source": [
    "def get_preds(x, ests, mus=None, dirs=None, use_proba=False):\n",
    "  if mus is None:\n",
    "    mus = [0.0 for _ in range(len(ests))]\n",
    "  if dirs is not None:\n",
    "    if use_proba:\n",
    "      pred_array = [e.predict_proba((x-mu)@d)[:, 1] for mu, d, e in zip(mus, dirs, ests)]\n",
    "    else:\n",
    "      pred_array = [e.predict((x-mu)@d) for mu, d, e in zip(mus, dirs, ests)]\n",
    "  else:\n",
    "    if use_proba:\n",
    "      pred_array = [e.predict_proba((x-mu))[:, 1] for mu, e in zip(mus, ests)]\n",
    "    else:\n",
    "      pred_array = [e.predict((x-mu)) for mu, e in zip(mus, ests)]\n",
    "  return np.stack(pred_array, -1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {
    "id": "s-1Nkhj3gdfx"
   },
   "outputs": [],
   "source": [
    "def aggregate_preds(preds, use_bernoulli_std=False):\n",
    "  mean_pred = np.mean(preds, 1, keepdims=False)\n",
    "  if use_bernoulli_std:\n",
    "    std_pred = mean_pred*(1-mean_pred)\n",
    "  else:\n",
    "    std_pred = np.std(preds, 1, keepdims=False)\n",
    "  return np.float32(mean_pred>0.5), mean_pred, std_pred"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "NDuawjDXkq8C"
   },
   "source": [
    "Train on random directions"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {
    "id": "31XMRekNlXBt"
   },
   "outputs": [],
   "source": [
    "from sklearn.metrics import precision_score"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {
    "id": "KpPp9Psmlmk0"
   },
   "outputs": [],
   "source": [
    "def divide_points(percentage_threshold, X, y, index):\n",
    "  dot_products = (X @ X[index, None, :].T)[:, 0]\n",
    "  thresh = np.quantile(dot_products, 1.-percentage_threshold)\n",
    "  # id_x, id_y, ood_x, ood_y\n",
    "  return (X[dot_products<thresh], y[dot_products<thresh],\n",
    "    X[dot_products>=thresh], y[dot_products>=thresh])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "bvAV0wn8kqXB",
    "outputId": "e2fc1d11-64f4-4ada-8a49-2c25304bcf38"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0\n",
      "100\n",
      "200\n",
      "300\n",
      "400\n",
      "500\n",
      "600\n",
      "700\n",
      "800\n",
      "900\n"
     ]
    }
   ],
   "source": [
    "index_lst = []\n",
    "score_lst = []\n",
    "logreg_estimators = []\n",
    "for i in range(1000):\n",
    "  if i % 100 == 0:\n",
    "    print(i)\n",
    "  index = np.random.randint(0, len(X) - 1)\n",
    "  pseudo_id_x, pseudo_id_y, pseudo_ood_x, pseudo_ood_y = divide_points(0.1, X, Y, index)\n",
    "  log_reg = LogisticRegression(random_state=0, max_iter=1000).fit(pseudo_id_x, pseudo_id_y)\n",
    "  logreg_estimators.append(log_reg)\n",
    "  pred = log_reg.predict(pseudo_ood_x)\n",
    "  score_lst.append(precision_score(pseudo_ood_y, pred, average='macro'))\n",
    "  # score_lst_random.append(log_reg.score(pseudo_ood_x, pseudo_ood_y))\n",
    "  index_lst.append(index)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "oRbACNnzqzUz",
    "outputId": "28ce8717-0997-4861-d4ba-05692ca457a2"
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "930"
      ]
     },
     "execution_count": 25,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(np.unique(index_lst))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {
    "id": "xDkqfzI2o2r9"
   },
   "outputs": [],
   "source": [
    "score_lst = np.array(score_lst)\n",
    "index_lst = np.array(index_lst)\n",
    "\n",
    "score_perc = .9\n",
    "score_thresh = np.quantile(score_lst, score_perc)\n",
    "critical_indices = index_lst[score_lst >= score_thresh]\n",
    "critical_ood = np.concatenate(\n",
    "  [divide_points(0.1, X, Y, ci)[2] for ci in critical_indices], 0\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 489
    },
    "id": "YwxdTOSvr-gs",
    "outputId": "7f91724c-10a8-40b5-a149-efc3bc84218d"
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0.5, 1.0, 'Precision vs Recall by Thresholding Ensemble Std')"
      ]
     },
     "execution_count": 27,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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euHh4cGDBw8IDAzk5s2bzJ8/n7CwMIKDg6lUqVK+P0wuXbqEVqulatWqprKPP/6YgQMH4u/vz6pVq/jhhx+4d+8e7dq1Izw83HTc77//Trt27bh69Spz587lt99+47///a9F4hUREUHZsmX55JNP2Lx5M/Pnz0er1dKyZUvOnDmTrzpn57nnnqN69eqsWbOGqVOnsn79erp27YperwfgzTffJC4ujmXLllmcFx4eztatWxk7dmyB1ueFF16gZs2arF27lnfffZdly5YxYcKETMetX7+eBQsW8MEHH5ie0/DwcJo3b86JEyeYM2cOv/76Kz169GDcuHFMmzbNdO6sWbOYOnUqAwcOZOPGjaxcuZIRI0Zkmdw8qj6KovDss88ye/ZshgwZwsaNG5k4cSJLliyhY8eOJCcnZ/tYExMT6dy5M3/88QczZsxg9erVeHl5MWDAgFw/X8eOHeM///kPEyZMYMOGDTRo0IARI0awY8cO0zHHjx8nMDCQhIQElixZwldffcXhw4f53//+l+v7AfW9lZqaanFJS0vLdJz5+2zp0qU8ePCA7t27WySZ3bt359ChQ8yaNYuwsDAWLFhA48aNLV6D3L6nAPR6Pc8//zw9evRgw4YNdOvWjUmTJvHee+8xdOhQXnnlFdatW0etWrUYNmwYhw4dylTvESNGYGNjw7JlywgODmb//v08/fTTj0x6R40axfjx4+ncuTPr168nJCSEkydP0rp160xfqDIKCAhg3759jBs3jn379pnedxmtW7eOqlWr0rhxY/bs2cOePXtYt24doCb07du358SJE4SEhPDDDz9w//59Xn/99Rzv+19DEcXe4sWLFUDZu3evotfrlXv37im//vqr4unpqbi4uChRUVGKoijK0KFDFUD57rvvLM5fvny5Aihr1661KD9w4IACKCEhIYqiKMrFixcVW1tbZfDgwTnWZ+jQoYqfn5/p+uzZsxVAuXPnTrbnXLp0SQGUxYsXm8patWqllCtXTrl3756pLDU1ValXr55SsWJFJT093eLxBwUFWcScNWuWAiiRkZE51vf5559XKlasqKSlpZnKNm3apADKL7/8oiiKohw8eFABlPXr1+cYKytDhw5VnJ2dFb1er+j1euXWrVvKggULFBsbG+W9994zHXf16lVFq9Uqb7zxhsX59+7dU7y8vJT+/fubyqpVq6ZUq1ZNSUxMzHU9UlNTlZSUFKVGjRrKhAkTTOVZPffG5/TSpUs5xpwyZYoCWMRTFEVZunSpAig//vijqax9+/ZKo0aNLI4bM2aM4urqavEaP4qfn5/So0ePHOsza9Ysi/KgoCDFwcHB9DejKIoCKG5ubsrt27ctju3atatSsWJF5e7duxblr7/+uuLg4GA6vmfPnpkeT37rs3nz5iyPW7lypQIoCxcuNJW1b99ead++ven6ggULFEDZsGGDxbmvvvpqptfVWB9zfn5+ioODg3LlyhVTWWJiolKmTBll1KhRprJ+/fopzs7OSkxMjKksLS1N8ff3z9PfSlaXatWqmY4z/j3Wr19fSU1NNZXv379fAZTly5criqIot27dUgAlODg42/vMy3vK+Plo/jmo1+sVT09PBVAOHz5sKo+NjVVsbW2ViRMnmsqM75nnnnvO4r52796tAMpHH31kcV/mn5F79uxRAGXOnDkW5167dk1xdHRU/u///i/bx2h8Ltq2bWt6PnU6ndK6dWtlxowZmd5bdevWtfj7MXrnnXcUjUajHD161KI8MDBQAZStW7fmWIeSTlqWSpBWrVqh0+lwcXGhZ8+eeHl58dtvv1G+fHmL41544QWL67/++iulS5emV69eFt/2GjVqhJeXl2kWRFhYGGlpaXluBWjevDkA/fv3Z9WqVbmaoffgwQP27dtH3759KVWqlKnc1taWIUOGcP369UytI71797a43qBBA4AcW70Ahg8fzvXr19myZYupbPHixXh5edGtWzcAqlevjru7O++88w5fffVVpm+kuXk8Op0OnU6Hh4cHY8aMYcCAARbfyn///XdSU1N5+eWXLV4HBwcH2rdvb3odzp49y4ULFxgxYgQODg7Z3mdqaioff/wx/v7+2NnZodVqsbOz49y5c5w6dSpP9X+UjGPi+vfvj1arZevWraayN998k6NHj7J7924A4uPj+eGHHxg6dKjFa1wQsvpbSEpKIjo62qK8Y8eOuLu7m64nJSXx559/8txzz+Hk5GTxOnTv3p2kpCRTV1CLFi04duwYQUFB/P777znObHxUfYyD/zMOuu3Xrx/Ozs78+eef2cbeunUrLi4ume5j0KBB2Z6TUaNGjahUqZLpuoODAzVr1rR47xhbes3HG9nY2NC/f/9c3w/Ali1bOHDggMVl/fr1mY7r0aMHtra2pusZ389lypShWrVqfPrpp8ydO5cjR46Qnp5uESO37ykjjUZD9+7dTde1Wi3Vq1fH29ubxo0bm8rLlClDuXLlsvxsyfheaN26NX5+fhbvhYx+/fVXNBoNL730kkU9vby8aNiw4SNnopUtW5adO3dy4MABPvnkE/r06cPZs2eZNGkS9evXz9VszK1bt1K3bl0aNmxoUZ6Xv6OSTJKlEuT777/nwIEDHDlyhIiICI4fP06bNm0sjnFycsLV1dWi7ObNm9y5cwc7OzvTP3TjJSoqyvRGM45ByesA0aeeeor169ebPrQqVqxIvXr1WL58ebbnxMXFoShKljNkKlSoAKj99ObKli1rcd3e3h7AohsxK926dcPb25vFixeb7vvnn3/m5ZdfNn1Yu7m5sX37dho1asR7771H3bp1qVChAlOmTMm2yduco6Oj6R/DL7/8wtNPP83y5ctN4yHg4dil5s2bZ3odVq5cmefXYeLEibz//vs8++yz/PLLL+zbt48DBw7QsGHDRz4neeXl5WVxXavVUrZsWYvXqE+fPlSuXNk09ic0NJQHDx4UeBcc5P5vIePfV2xsLKmpqXzxxReZXgPjP1Hj6zBp0iRmz57N3r176datG2XLlqVTp05ZTh1/VH1iY2PRarUWXeag/vP28vLK9Leesc4ZvxBB5tckJxnrZ6yj+fOV3f1kVZaThg0b0qxZM4tLvXr1HlmnjM+ZRqPhzz//pGvXrsyaNYsmTZrg6enJuHHjTF3juX1PGTk5OWX6AmJnZ0eZMmUy1c/Ozo6kpKRM5Vk97496DW/evImiKJQvXz5TPffu3ZvrpSeaNWvGO++8w+rVq4mIiGDChAlcvnw5V4O8Y2Njs627kNlwJUqdOnVMg4azk9UaK8YB0Zs3b87yHBcXF+Dh2Kfr16/j6+ubp7r16dOHPn36kJyczN69e5kxYwaDBg2icuXKBAQEZDre3d0dGxsbIiMjM91mHLRdUDNqjK1Vn3/+OXfu3GHZsmUkJyczfPhwi+Pq16/PihUrUBSF48ePExoayvTp03F0dOTdd9/N8T5sbGwsXpvAwECaNm3KtGnTGDx4ML6+vqbHs2bNGvz8/LKNZf465OTHH3/k5Zdf5uOPP7Yov3XrFqVLl87x3LyKiorCx8fHdD01NZXY2FiLf3g2NjaMHTuW9957jzlz5hASEkKnTp2oVatWgdYlLzK+H9zd3U1/D9klccaZi1qtlokTJzJx4kTu3LnDli1beO+99+jatSvXrl3L0yzTsmXLkpqaSkxMjEXCpCgKUVFRptbZ7M7dv39/pvKsBng/jrJly2Y5dqag7ycv/Pz8TJNLzp49y6pVq5g6dSopKSl89dVXuX5PFaSsno+oqCiqV6+e7TkeHh5oNBp27txpSgrNZVX2KDqdjilTpjBv3jxOnDjxyOPLli2bbd2FtCwJoGfPnsTGxpKWlpbpG1+zZs1M/8y6dOmCra0tCxYsyPd92dvb0759e2bOnAmQ5SwvAGdnZ1q2bMlPP/1k8e02PT2dH3/8kYoVK1KzZs181yOj4cOHk5SUxPLlywkNDSUgIIDatWtneaxGo6Fhw4bMmzeP0qVLc/jw4Tzfn729PfPnzycpKYmPPvoIgK5du6LVarlw4UKWr4Mx2apZsybVqlXju+++y3Hgr0ajyfQhu3HjRqssVLp06VKL66tWrSI1NTXT4okjR47Ezs6OwYMHc+bMmSdu8KiTkxMdOnTgyJEjNGjQIMvXIKtWmNKlS9O3b1/Gjh3L7du38zwzzDgr9ccff7QoX7t2LQ8ePDDdnpUOHTpw7949fv75Z4vyjIPpH1f79u3566+/LFo50tPTWb16dYHeT37VrFmT//73v9SvX9/0nszte6ogZXwv/P3331y5ciXHhUR79uyJoijcuHEjyzrWr18/x/vM6kslYOpuN7bGQ+YWQ6MOHTpw8uRJjh07ZlFe0H9HxZW0LAlefPFFli5dSvfu3XnzzTdp0aIFOp2O69evs3XrVvr06cNzzz1H5cqVee+99/jwww9JTEw0TYUODw/n1q1bFjOFzH3wwQdcv36dTp06UbFiRe7cucNnn32GTqejffv22dZrxowZBAYG0qFDB9566y3s7OwICQnhxIkTLF++vEBXIq5duzYBAQHMmDGDa9eusXDhQovbf/31V0JCQnj22WepWrUqiqLw008/cefOHQIDA/N1n+3bt6d79+4sXryYd999lypVqjB9+nQmT57MxYsXeeaZZ3B3d+fmzZvs378fZ2dn03M8f/58evXqRatWrZgwYQKVKlXi6tWr/P7776YP6549exIaGkrt2rVp0KABhw4d4tNPP7XKOjs//fQTWq2WwMBATp48yfvvv0/Dhg0zjWcpXbo0L7/8MgsWLMDPz49evXoVeF0e12effUbbtm1p164dY8aMoXLlyty7d4/z58/zyy+/mMYX9erVy7S2maenJ1euXCE4OBg/Pz9q1KiRp/sMDAyka9euvPPOO8THx9OmTRuOHz/OlClTaNy4MUOGDMn23Jdffpl58+bx8ssv87///Y8aNWqwadMmfv/998d6HjKaPHkyv/zyC506dWLy5Mk4Ojry1Vdf8eDBA8ByinpODh06lOWilP7+/pmGCOTk+PHjvP766/Tr148aNWpgZ2fHX3/9xfHjx00tvZUrV871e6qgHDx4kJEjR9KvXz+uXbvG5MmT8fHxISgoKNtz2rRpw2uvvcbw4cM5ePAgTz31FM7OzkRGRrJr1y7q16/PmDFjsj2/a9euVKxYkV69elG7dm3S09M5evQoc+bMoVSpUhaLBBtbyFeuXEnVqlVxcHCgfv36jB8/nu+++44ePXrw0UcfUb58eZYuXcrp06cL9PkptopydLkoGMZZGAcOHMjxOOOsrKzo9Xpl9uzZSsOGDRUHBwelVKlSSu3atZVRo0Yp586dszj2+++/V5o3b246rnHjxhYzbjLO9Pj111+Vbt26KT4+PoqdnZ1Srlw5pXv37srOnTtNx2Q1I0tRFGXnzp1Kx44dFWdnZ8XR0VFp1aqVaYbaox7/1q1b8zSLY+HChQqgODo6ZpoJdfr0aWXgwIFKtWrVFEdHR8XNzU1p0aKFEhoa+si4OT3v//zzj2JjY6MMHz7cVLZ+/XqlQ4cOiqurq2Jvb6/4+fkpffv2VbZs2WJx7p49e5Ru3bopbm5uir29vVKtWjWLWWlxcXHKiBEjlHLlyilOTk5K27ZtlZ07d2aaTVUQs+EOHTqk9OrVSylVqpTi4uKiDBw4ULl582aW52zbtk0BlE8++STH2NnJzWw48xlb2T0eQBk7dmyWcS5duqS88sorio+Pj6LT6RRPT0+ldevWFjOa5syZo7Ru3Vrx8PBQ7OzslEqVKikjRoxQLl++nK/6JCYmKu+8847i5+en6HQ6xdvbWxkzZowSFxdncW7G109RFOX69evKCy+8YHr+X3jhBeXvv//O9Wy4rJ7PrO5n586dSsuWLRV7e3vFy8tLefvtt5WZM2c+crar+X1ndwkLC1MU5eHf46effpopBqBMmTJFURRFuXnzpjJs2DCldu3airOzs1KqVCmlQYMGyrx58yxm0SlK7t5T2b1P27dvr9StWzdTecbnzfia/vHHH8qQIUOU0qVLK46Ojkr37t0zfYZm/Iw0+u6775SWLVuaPu+qVaumvPzyy8rBgwezf2IVddbkoEGDlBo1aiilSpVSdDqdUqlSJWXIkCFKeHi4xbGXL19WunTpori4uCiART3Cw8OVwMBAxcHBQSlTpowyYsQIZcOGDTIbTlEUjaIoSqFkZUIIAfznP/9hwYIFXLt2LcsuLVG8dOnShcuXL3P27NmirooQViPdcEKIQrF3717Onj1LSEgIo0aNkkSpGJo4cSKNGzfG19eX27dvs3TpUsLCwixW8BeiJJJkSQhRKAICAnBycqJnz56mQe2ieElLS+ODDz4gKioKjUaDv78/P/zwwyNXyheiuJNuOCGEEEKIHMjSAUIIIYQQOZBkSQghhBAiB5IsCSGEEELkQAZ4ZyE9PZ2IiAhcXFwKdOFDIYQQQliPoijcu3ePChUq5Hqh1NyQZCkLERERed77TAghhBBPhmvXrhXobgWSLGXBuHHstWvX8rT8vpFer+ePP/6gS5cu6HS6gq6exJf4El/iS3yJL/GzcPv2bapUqWL6P15QJFnKgrHrzdXVNd/JkpOTE66urlb7Y5P4El/iS3yJL/Elfub4QIEPoZEB3kIIIYQQOZBkSQghhBAiB5IsCSGEEELkQJIlIYQQQogcSLIkhBBCCJEDSZaEEEIIIXIgyZIQQgghRA4kWRJCCCGEyIEkS0IIIYQQOZBkSQghhBAiB0WaLO3YsYNevXpRoUIFNBoN69evf+Q527dvp2nTpjg4OFC1alW++uqrTMesXbsWf39/7O3t8ff3Z926dVaofc50V68S27s3d3bs4Pj8+STGxBR6HYQQQgjx+Io0WXrw4AENGzbkyy+/zNXxly5donv37rRr144jR47w3nvvMW7cONauXWs6Zs+ePQwYMIAhQ4Zw7NgxhgwZQv/+/dm3b5+1HkaWHG7cwGvzZh4cPsyJkBBJloQQQohiqkg30u3WrRvdunXL9fFfffUVlSpVIjg4GIA6depw8OBBZs+ezQsvvABAcHAwgYGBTJo0CYBJkyaxfft2goODWb58eYE/huxo4+MBSI+NLbT7FEIIIUTBK9JkKa/27NlDly5dLMq6du3KokWL0Ov16HQ69uzZw4QJEzIdY0ywspKcnExycrLperwh0dHr9aYdjHMj6cQJ9GfPkhgXR+1lywBQgoNx9/QketEiEtu0QVe9Og4eHjh6euY6bkbGOuWlbhJf4kt8iS/xJf6/JX5B0yiKolglch5pNBrWrVvHs88+m+0xNWvWZNiwYbz33numsr///ps2bdoQERGBt7c3dnZ2hIaGMmjQINMxy5YtY/jw4RYJkbmpU6cybdq0TOXLli3Dyckp14+h+v/+R90DB7K9/R8PD/4pVw5dx47Yde6c67hCCCGEeLSEhAQGDRrE3bt3cXV1LbC4xaplCdSkypwx1zMvz+qYjGXmJk2axMSJE03X4+Pj8fX1pUuXLnl6spMqVeK2oWVJN3065SIjuVaqFCc8Pany3HOUadOGzgXUshQWFkZgYCA6nS7fcSS+xJf4El/iS/ySFD/WSkNfilWy5OXlRVRUlEVZdHQ0Wq2WsmXL5nhM+fLls41rb2+Pvb19pnKdTpenF1PXuDE0boxeryf6q68gMpIkrZY4R0dajhhBGX//XMfK1f3lsX4SX+JLfIkv8SV+SY5vrToXq3WWAgICCAsLsyj7448/aNasmekJyu6Y1q1bF1o9AZQcWrKEEEIIUXwUacvS/fv3OX/+vOn6pUuXOHr0KGXKlKFSpUpMmjSJGzdu8P333wMwevRovvzySyZOnMirr77Knj17WLRokcUstzfffJOnnnqKmTNn0qdPHzZs2MCWLVvYtWtXoT62NGdnAPQ2NpSuXfuxut2EEEIIUXSKtGXp4MGDNG7cmMaNGwMwceJEGjduzAcffABAZGQkV69eNR1fpUoVNm3axLZt22jUqBEffvghn3/+uWnZAIDWrVuzYsUKFi9eTIMGDQgNDWXlypW0bNmyUB9buosLAGk2NpSpU0eSJSGEEKKYKtKWpaeffpqcJuOFhoZmKmvfvj2HDx/OMW7fvn3p27fv41bv8Ug3nBBCCFEiFKsxS8WJjFkSQgghSgZJlqxMUiYhhBCieJNkyVqkZUkIIYQoESRZshLphhNCCCFKBkmWrEzzZOwmI4QQQoh8kmTJWqRlSQghhCgRJFmyEumGE0IIIUoGSZasTFImIYQQoniTZMlapGVJCCGEKBEkWbIS6YYTQgghSgZJlqxMZsMJIYQQxZskS9YiLUtCCCFEiSDJkpUoNupTKymTEEIIUbxJsiSEEEIIkQNJlqzF0A0nLUtCCCFE8SbJkpXIbDghhBCiZJBkydpkNpwQQghRrBV5shQSEkKVKlVwcHCgadOm7Ny5M8fj58+fT506dXB0dKRWrVp8//33FreHhoai0WgyXZKSkqz5MDKTbjghhBCiRNAW5Z2vXLmS8ePHExISQps2bfj666/p1q0b4eHhVKpUKdPxCxYsYNKkSXzzzTc0b96c/fv38+qrr+Lu7k6vXr1Mx7m6unLmzBmLcx0cHKz+eMxJN5wQQghRMhRpsjR37lxGjBjByJEjAQgODub3339nwYIFzJgxI9PxP/zwA6NGjWLAgAEAVK1alb179zJz5kyLZEmj0eDl5VU4D0IIIYQQJVqRJUspKSkcOnSId99916K8S5cu/P3331mek5ycnKmFyNHRkf3796PX69HpdADcv38fPz8/0tLSaNSoER9++CGNGzfOti7JyckkJyebrsfHxwOg1+vR6/V5fmx6vd6iGy49PT1fcXKMb/azoEl8iS/xJb7El/jFOX5B0yhK0YxAjoiIwMfHh927d9O6dWtT+ccff8ySJUsydaMBvPfeeyxevJhff/2VJk2acOjQIXr06EF0dDQRERF4e3uzd+9ezp8/T/369YmPj+ezzz5j06ZNHDt2jBo1amRZl6lTpzJt2rRM5cuWLcPJySlfj6/mypXUWb6cc+7uHOnZE/sXXshXHCGEEELkTkJCAoMGDeLu3bu4uroWWNwi7YYDtcvMnKIomcqM3n//faKiomjVqhWKolC+fHmGDRvGrFmzsLW1BaBVq1a0atXKdE6bNm1o0qQJX3zxBZ9//nmWcSdNmsTEiRNN1+Pj4/H19aVLly75erL1ej1XVq40PiAqVqxI8+7d8xwnp/hhYWEEBgaaWtMKksSX+BJf4kt8iV8c48fGxhZ4TCjCZMnDwwNbW1uioqIsyqOjoylfvnyW5zg6OvLdd9/x9ddfc/PmTby9vVm4cCEuLi54eHhkeY6NjQ3Nmzfn3Llz2dbF3t4ee3v7TOU6nS7/L6ZZN5yNjY1V/igeq34SX+JLfIkv8SV+CYtvrToX2dIBdnZ2NG3alLCwMIvysLAwi265rOh0OipWrIitrS0rVqygZ8+e2Nhk/VAUReHo0aN4e3sXWN1zRWbDCSGEECVCkXbDTZw4kSFDhtCsWTMCAgJYuHAhV69eZfTo0YDaPXbjxg3TWkpnz55l//79tGzZkri4OObOncuJEydYsmSJKea0adNo1aoVNWrUID4+ns8//5yjR48yf/78Qn1sshSlEEIIUTIUabI0YMAAYmNjmT59OpGRkdSrV49Nmzbh5+cHQGRkJFevXjUdn5aWxpw5czhz5gw6nY4OHTrw999/U7lyZdMxd+7c4bXXXiMqKgo3NzcaN27Mjh07aNGiReE+OFmUUgghhCgRinyAd1BQEEFBQVneFhoaanG9Tp06HDlyJMd48+bNY968eQVVvfyTbjghhBCiRCjy7U5KKtMK3rI3nBBCCFGsSbJkZdK+JIQQQhRvkixZi3TDCSGEECWCJEtWosgAbyGEEKJEkGRJCCGEECIHkixZi3TDCSGEECWCJEtWYuqGk9lwQgghRLEmyZIQQgghRA4kWbIWw1510hknhBBCFG+SLFmJdL4JIYQQJYMkS9YiA7yFEEKIEkGSJWuRAd5CCCFEiSDJkpVIiiSEEEKUDJIsWYt0wwkhhBAlgiRL1iLbnQghhBAlgiRLVqJIy5IQQghRIkiyJIQQQgiRgyJPlkJCQqhSpQoODg40bdqUnTt35nj8/PnzqVOnDo6OjtSqVYvvv/8+0zFr167F398fe3t7/P39WbdunbWqnz2ZDSeEEEKUCEWaLK1cuZLx48czefJkjhw5Qrt27ejWrRtXr17N8vgFCxYwadIkpk6dysmTJ5k2bRpjx47ll19+MR2zZ88eBgwYwJAhQzh27BhDhgyhf//+7Nu3r7AeFiDdcEIIIURJUaTJ0ty5cxkxYgQjR46kTp06BAcH4+vry4IFC7I8/ocffmDUqFEMGDCAqlWr8uKLLzJixAhmzpxpOiY4OJjAwEAmTZpE7dq1mTRpEp06dSI4OLiQHpUlSZmEEEKI4k1bVHeckpLCoUOHePfddy3Ku3Tpwt9//53lOcnJyTg4OFiUOTo6sn//fvR6PTqdjj179jBhwgSLY7p27ZpjspScnExycrLpenx8PAB6vR69Xp+Xh2U6z3zpgPT09HzFyTG+2c+CJvElvsSX+BJf4hfn+AVNoyhFM6gmIiICHx8fdu/eTevWrU3lH3/8MUuWLOHMmTOZznnvvfdYvHgxv/76K02aNOHQoUP06NGD6OhoIiIi8Pb2xs7OjtDQUAYNGmQ6b9myZQwfPtwiITI3depUpk2blql82bJlODk55evxVfrzTxp/8QU3SpVi93PPYf/CC/mKI4QQQojcSUhIYNCgQdy9exdXV9cCi1tkLUtGmgxjexRFyVRm9P777xMVFUWrVq1QFIXy5cszbNgwZs2aha2tbb5iAkyaNImJEyearsfHx+Pr60uXLl3y9WTr9XpO//mnWhegYsWKNO/ePc9xcoofFhZGYGAgOp2uwOJKfIkv8SW+xJf4xTl+bGxsgceEIkyWPDw8sLW1JSoqyqI8Ojqa8uXLZ3mOo6Mj3333HV9//TU3b97E29ubhQsX4uLigoeHBwBeXl55iglgb2+Pvb19pnKdTpf/F9OYnCkKNjY2VvmjeKz6SXyJL/ElvsSX+CUsvrXqXGQDvO3s7GjatClhYWEW5WFhYRbdclnR6XRUrFgRW1tbVqxYQc+ePbGxUR9KQEBApph//PHHI2MWOJkNJ4QQQpQIRdoNN3HiRIYMGUKzZs0ICAhg4cKFXL16ldGjRwNq99iNGzdMaymdPXuW/fv307JlS+Li4pg7dy4nTpxgyZIlpphvvvkmTz31FDNnzqRPnz5s2LCBLVu2sGvXrkJ9bMaBYJIyCSGEEMVbkSZLAwYMIDY2lunTpxMZGUm9evXYtGkTfn5+AERGRlqsuZSWlsacOXM4c+YMOp2ODh068Pfff1O5cmXTMa1bt2bFihX897//5f3336datWqsXLmSli1bFu6Dk5YlIYQQokQo8gHeQUFBBAUFZXlbaGioxfU6depw5MiRR8bs27cvffv2LYjq5Z8kS0IIIUSJUOTbnZRU0g0nhBBClAySLFmL2Ww4IYQQQhRfkixZi3TDCSGEECWCJEtWYtxIV1ImIYQQoniTZMlapGVJCCGEKBEkWbISaVkSQgghSgZJlqxNBngLIYQQxZokS9Yi3XBCCCFEiSDJkrVIN5wQQghRIkiyZCXS+SaEEEKUDJIsWYu0LAkhhBAlgiRL1iJjloQQQogSQZIlKzF1w8lsOCGEEKJYk2TJWqQbTgghhCgRJFmyFumGE0IIIUoESZasRDrfhBBCiJJBkiVrkW44IYQQokQo8mQpJCSEKlWq4ODgQNOmTdm5c2eOxy9dupSGDRvi5OSEt7c3w4cPJzY21nR7aGgoGo0m0yUpKcnaD8WSdMMJIYQQJUKRJksrV65k/PjxTJ48mSNHjtCuXTu6devG1atXszx+165dvPzyy4wYMYKTJ0+yevVqDhw4wMiRIy2Oc3V1JTIy0uLi4OBQGA/JRJFkSQghhCgRijRZmjt3LiNGjGDkyJHUqVOH4OBgfH19WbBgQZbH7927l8qVKzNu3DiqVKlC27ZtGTVqFAcPHrQ4TqPR4OXlZXEpKhpZOkAIIYQo1rRFdccpKSkcOnSId99916K8S5cu/P3331me07p1ayZPnsymTZvo1q0b0dHRrFmzhh49elgcd//+ffz8/EhLS6NRo0Z8+OGHNG7cONu6JCcnk5ycbLoeHx8PgF6vR6/X5/mx6fV6i2649PT0fMXJMb7Zz4Im8SW+xJf4El/iF+f4BU2jKEXT9BEREYGPjw+7d++mdevWpvKPP/6YJUuWcObMmSzPW7NmDcOHDycpKYnU1FR69+7NmjVr0Ol0gNr6dP78eerXr098fDyfffYZmzZt4tixY9SoUSPLmFOnTmXatGmZypctW4aTk1O+Hp/nsWO0njKFOHt7wvr3x/6FF/IVRwghhBC5k5CQwKBBg7h79y6urq4FFrfIWpaMNBnG9iiKkqnMKDw8nHHjxvHBBx/QtWtXIiMjefvttxk9ejSLFi0CoFWrVrRq1cp0Tps2bWjSpAlffPEFn3/+eZZxJ02axMSJE03X4+Pj8fX1pUuXLvl6svV6PUeOHVMfH1CxYkWad++e5zg5xQ8LCyMwMNCUJBYkiS/xJb7El/gSvzjGN5/wVZCKLFny8PDA1taWqKgoi/Lo6GjKly+f5TkzZsygTZs2vP322wA0aNAAZ2dn2rVrx0cffYS3t3emc2xsbGjevDnnzp3Lti729vbY29tnKtfpdPl/Mc0SPhsbG6v8UTxW/SS+xJf4El/iS/wSFt9adS6yAd52dnY0bdqUsLAwi/KwsDCLbjlzCQkJ2NhYVtnW1hZQW6SyoigKR48ezTKRsiqZDSeEEEKUCEXaDTdx4kSGDBlCs2bNCAgIYOHChVy9epXRo0cDavfYjRs3+P777wHo1asXr776KgsWLDB1w40fP54WLVpQoUIFAKZNm0arVq2oUaMG8fHxfP755xw9epT58+cX6mMzpm4yG04IIYQo3oo0WRowYACxsbFMnz6dyMhI6tWrx6ZNm/Dz8wMgMjLSYs2lYcOGce/ePb788kv+85//ULp0aTp27MjMmTNNx9y5c4fXXnuNqKgo3NzcaNy4MTt27KBFixaF++CkZUkIIYQoEYp8gHdQUBBBQUFZ3hYaGpqp7I033uCNN97INt68efOYN29eQVUv3xTZ7kQIIYQoEYp8u5MSS1qWhBBCiBKhyFuWSixpWSp2EmNiCF+8GA1QZ/hwHD09i7pKQgghngCSLFmJaW84GeBdbCTGxHBmyRIAKvfsKcmSEEIIQLrhhBBCCCFyJC1L1iLdcMVCYkwMcWfPkhAVxRnDEhUAV/74g7sXL+Lg7k7pmjUBOLdqFTX690dbunQR1VYIIURRkGTJWmSAd7FwbtUqToSEZCo/9c03pt/rBQVRsUMHToSEULFDB1weM1lKjIkxJV7S1SeEEE8+6YazEhmpVDw4lCmDjZ0dAFqzTZNdKlcmYOZMOixcSI3+/S3OSYyJIWXLFhJjYvJ1n4kxMZwICbE4PzEmhuPz5+c7phBCCOuRZMlapBuuSKXHx3NywYJMyYcxKbl/4wYH//c/Dn70EekpKZRv1Yp2n31mOu7e1avEHDoEwI0dO9gzeTIAkbt2EX3gAPq//uJuDvsN5lVWCZQQQogng3TDWYvMhitSyr17hH/9NZU6d7bo6jImJdf++IO7588DUPe116j/+uvcOXPmYYD0dM6vWsX5Vass4h4zS6iub9mCb/v2Frdn18WWGBNDYkwM+vv3OfnttwAcnjULl8qVsXN1xTaLjZyFEEI8GSRZshJJkZ4c6Xo9SXFxJN++TcTOnQDcPX8eO1dXAj75BB9DwuPo6UmtoUOJO32a6H37LGKUrlXLMpkC7N3duR0ebjrX0dPTlIxV7NABeDgo/NzKlZxYsMDi/OgDB4g+cMCi7Ma2bZRPTSX17FmOnjpFvREjZFyTEEIUMUmWrEW64QqdqfUmJQX9X38BEDZkCGlJSZmOdapQgWaTJ5sSHGNCUqVnT3zat2frwYMoaWnY2ttTd/Robp88mSlZOr1oEacXLQLUQeANxo61uC9j4lTG35/ogwdN5Q4eHiTdukUpPz/uX7liEfOf+fP5x7Dp8zmgWu/ekiwJIUQRk2TJWmQ2XKFKjIlh11tvEWOWlABZJkoACRER7Bg7FniY6GQ1My4tOZnjZl1vATNnEn34MBdWrsTGwYHK3bpRPiAAOxcX9n/4IRcM3XZ73n2XMvXrA7BzwgQUvR4bnY66o0bh1bo1YYMG0WzyZBzc3QG4eeAAR2bNMt2PxtsbJTLyMZ8VIYQQBUGSJSuRbrjCYxy0HXPwIG7Vq6tjkTQaUBTqjx2LS9WqKCkpOJQty4PISPZPmUKLadMo4+8PYGq5qdG/v6n77HZ4uMVxSXFxRO3ejVfLljj5+HBh5UrSk5K4uG4dqQkJXP39d4s63b1wgbsXLgCg6PW4+/tTb9QoPBo2NA3idnB3N9XBqHKvXlz57TdTohT599+m24xdfRkfuyxDIIQQ1iXJkrVIN1yhSYyJ4cLq1YA6FsnW0RGbzp3R//ILPk8/bZGQGMcYlfH3z5SoZJWMmB9XoU0bAO5laPG5Zujy0zo5UapSJe6cPp2pjnHh4ex8803qBQVRo39/6gUFZZncXP7lF4vrx+bN49i8eQB4NmtG29mzsxywXrFDB0mWhBDCSiRZshaZDWd1xjFKN80GSWudnGg8aRLH/vnHaveZHBeHbaNGpB0/DunpKHo9ZRs0oN6YMejv3ePv//s/AmbOJC0pKctWLEdPTxoYugCNjIPLK7Rpg62LC9u//x79b78B6ppPtYcN48DUqcSdPWvRkhRnSMxkyQEhhLAeSZasRFIk6zJ2vRlblIxSExI48P77AFSoUweXxYth4kTw9gbUpCS7Vh1z2R2X3YrfscePs33MGKr16weAW9WqptuyasXK6v6a/t//AaDX67GtWhU9YOfmxr3Ll01LGCTHxXEiJARHT0+iDxzgiiGhurBunamuWbWQCSGEyD9JlqxFuuGs6tyqVZkSJXPa5s1pNnAgumeegYEDLZKljK06WcnuuBr9++PVrh27du2ibtmyHJo+3aLlSGNjY7GMwOOqNXQo4QsXEmfoPozctQuAA9OmWRx3PSyM62FhwMMB60IIIQpGka/gHRISQpUqVXBwcKBp06bsNKyDk52lS5fSsGFDnJyc8Pb2Zvjw4cTGxlocs3btWvz9/bG3t8ff359169ZZ8yFkTWbD5Si7FbZzy6tVK+wMe7Q5eXmZygNmzqTz8uXoOnXCvlQptTCbGXGZREbC1Knqz2w4enriXqcOtj4+uNepAzxsOSrj74977do0GDvWlDDlphUrKxoXFzyaNuWfzz+3mNFnPqbJ1sEBW0dHAMo2aEDAzJkEzJyJb6dOeb4/IYQQ2SvSZGnlypWMHz+eyZMnc+TIEdq1a0e3bt24evVqlsfv2rWLl19+mREjRnDy5ElWr17NgQMHGDlypOmYPXv2MGDAAIYMGcKxY8cYMmQI/fv3Z1+GRQatTpKlHBlX2M5PshR/5Qq733qLlDt3KF2zJq0+/th0W2kXF9yTkvC4dg3boUPVwrZtoUoV6NoV3nsPfvsNIiIyjyeLjIRp03JMlvLC2DqVn2TJxtWVVp98wjOrV5u69jJKS0oiLTERULsB97zzDnveeYdrf/75WPUWQghhqUiTpblz5zJixAhGjhxJnTp1CA4OxtfXlwUZVjo22rt3L5UrV2bcuHFUqVKFtm3bMmrUKA6ara0THBxMYGAgkyZNonbt2kyaNIlOnToRHBxcSI9KZfw3/CSmTAW1aetjxcnjwPfIPXtY37kzF9av58/hw0mMjsatRg06LlqEnYsLANX69aPUr7+ia9mSdpMnY2OYuo+iwOXL8McfMGMGdO8OPj5Qrhx07gz/+Q98/z2cPZunOjl4eOS75Sg3HD09KePvT4OxYwmYOROAGgMHAlB31Ci1FSkw0HR808mTeWb16kwb/wohhHg8RTZmKSUlhUOHDvHuu+9alHfp0oW/zdaWMde6dWsmT57Mpk2b6NatG9HR0axZs4YePXqYjtmzZw8TJkywOK9r1645JkvJyckkJyebrsfHxwPqQFu9Xp/Xh6aeYzYbLj09PV9xcoxv9jOv7kVGciIkBK927dAaurLyE/9RcRJjYri4Zg1V+/Y1jeG5e+4cV3//neQ9ewC4vmMHqampgJp8ZJd4RB85QkJkJIdmzCD1/n1cq1blqa+/xtbFBW1SEv6jRlG1b1+IiSH955+xOXsWxckJTUICqZ98Avb2aM6dQ3P9Oppz5+DsWTS3bsGff6oXM6m7dqEY6oSXl2m8U8bnR1u6NHVeey1Xz1VeZHz+taVL41ypEgDu9evD8uV4P/007nXqoHVx4ZphrNLZZcso37YtZ5YvNz3nuYlf0CS+xJf4Er+o4xc0jaIUzdz2iIgIfHx82L17N61btzaVf/zxxyxZsoQzGbaWMFqzZg3Dhw8nKSmJ1NRUevfuzZo1a9DpdADY2dkRGhrKoEGDTOcsW7aM4cOHWyRE5qZOncq0DANmjec5OTnl6/GVunGDTmPHkmJjw/rBg7F/4YV8xbGGtBs3SJo/H4exY7H18cnVOenx8aTu34+2RQtsXF3VOFevkvTVVziMGYOtr+8j7ydlyxbTNiRZ0XXsiF3nzlnelrxpE6mGwc0aT08cR45EY2hRMrK7e5fWU6bgdvkyyW5uHB85kuZz5rBtzhzuVqtmcaxNcjIu165Ra+VKvDPsz2bu9IABnDG05hQl4/NvU6kSyaGhpufU+Bzj4ABJSWjbtCF19+48vbZCCFFSJCQkMGjQIO7evYur4X9VQSjy2XCaDGN7FEXJVGYUHh7OuHHj+OCDD+jatSuRkZG8/fbbjB49mkWGPbryGhNg0qRJTJw40XQ9Pj4eX19funTpkq8nW6/X8/eSJabrFStWpHn37nmOk1P8sLAwAgMDTUnioyTGxJB06xYA1y9c4DRQt0wZ3KtUASxbdbKKH3fqFFs++YRWffuqMbZsIfb4cZKA8tevU6l+fa7/+SfV+vXDvXbth+fMn09zf3+cK1Ykwd2dq6VKcfnnn0318uvd29S1lLFlKWrPHm6fOIH+/n3OGcac2djZUaNHD7Tx8ZSpVAmvgADDwVFou3ZFc/kySvny7P7vfwlo3BjmzKFN27bQuHHWT0y/fuijotTYa9dia9hyJL1FC9Jmz6aanx/VsmhZyuvznxfZxn/xRbW1zt6eqs8+a2qtu5iaitbZmeNz56IcPgxA27ZtTQPQcx3f2vWX+BJf4kt8K8fPOOGroBRZsuTh4YGtrS1Rhn9URtHR0ZQvXz7Lc2bMmEGbNm14++23AWjQoAHOzs60a9eOjz76CG9vb7y8vPIUE8De3h57e/tM5TqdLv8vptnSATY2Nlb5o8hL/U6tW5dpfaBDH35o+j2r6ebm8ZMNiVbE1q2Zpuxf+eUXrhhmaaUnJ1O5e3ci//6b64ZWpJ05TWNPS8PF2zvLbTz2vP02qffvW5Snp6RwJjQUACdvb57dsgVu3FDHHp09Cz4+pP7+O/fOn0fr6wtTpqDz9YXsnqdKldQLgFYLs2aBgwM2+/dj8/HHsH59tuc+1t9HLmQVX1ehAo3GjbO4XmvgQBJu3uRy1arEX7wIQPyZM2i16ts7u3WXiqL+El/iS3yJb8341qpzkQ3wtrOzo2nTpoQZxlsYhYWFWXTLmUtISMDGxrLKtra2gNp6BBAQEJAp5h9//JFtTGt50halrNG/P8+sXk0Ds3+0NV58kWdWr852UHBiTAy3w8M5s3QpO994A1C3E6kxeLDFcV5t2uDdrh2grgO0PSiIsz/+SEJExCPrdWXjRs4ZFlzMeN+p9+9j7+EBgMbwj79sw4bUHzeOxkOH0snPDw4cgPbt1USpUiXYvh1q1lSDeHurSwFkaBl6pM8/B0dH2LwZ+vaFlJS8nV/Izq1axe8DBpgSJYD9U6eyuV8/Nvfrl+XzK4QQIveKtBtu4sSJDBkyhGbNmhEQEMDChQu5evUqo0ePBtTusRs3bvD9998D0KtXL1599VUWLFhg6oYbP348LVq0oEKFCgC8+eabPPXUU8ycOZM+ffqwYcMGtmzZwi7DeJdC84Rtd2JsXTj0ySemMvssNnI1d+b77zn3ww8WZbeOHOHWkSMWZXfPnyfx5k0AUu7cAcClShXcqlfnelgYjf7zHxzLlSMlPp77V69y5ocf1GQkMZEKTz+NZ6NG3A4Pt2gBSU9LA9QWLV2pUlTu3Ztzy5ZRoX176o8aBYcPwzvvwKZNEBWlLg2wdSv4+UF+B/h5e8OUKdCzJ1SrBj16wK+/woABsGpV9q1TRcx8A+Czy5Zx0bCuWNXnn6fSM88QtXs3iTExsqq3EELkU5EuHTBgwACCg4OZPn06jRo1YseOHWzatAk/Pz8AIiMjLdZcGjZsGHPnzuXLL7+kXr169OvXj1q1avHTTz+ZjmndujUrVqxg8eLFNGjQgNDQUFauXEnLli0L98E9gSt43zl3jphDh0zX9Rm6uDIyjQfiYctOVoyJkrl7ly5hb5gh59WqFVV69iQ5Lk5NlAAM6wNFbNvG1tdeY3O/foQvXszt8HBuh4dzbO5c9X5tbWn0n/+gpKdb3oHx7yIqCmrUgB071ETpcZi3RHXsCBs2gL292hU3aBAYZ8g9YYxLDJTx96em2cSGiz/9xI1t2zi9ZInsHSeEEI+hyAd4BwUFERQUlOVtoYaxKebeeOMN3jB0CWWnb9++9DUMRC4qT0Z7kqXzGbpjHjURUmtYHRqg2vPPc37VKgJmzuT+lSv8ExKCo7c3iRkWcKw7ejSuVarg4O4OYDG+qUb//rj4+bHnnXfQeHqixMRQqWtX/A2Lip5fvZrNGRZgVNLSTFt7lLKzw8veHtauhREj1AO8vOCLLyA6Gmxt897llpMuXWDdOnj2WVizRh3TlKGl7UlVc/Bgzi5dyrlly4q6KkIIUewV+XYnJdYTtoJ3zNGjnF2xAgCPRo0ASM+iuyoxJoa4U6dIu3GDM4YZffbu7pRt2BAAB3d3fAxdPhkTJYCTX33FnnfeIeboUUrXrGmxaKOjpydeLVviP2oUNsYB9zY2plaRisZlA8yeuxbTppnGVXXr3BnP4cPVcUR376oHREXBM89A06bw9deP9yRlpVs3NVHS6WDFChg+HAxdhE8iR09Pag0dik/79lQzW67i4rp1plY7aWUSQoi8KfKWpRLrCeuGu7B2LaSnY1+mDJW6duXW0aOkGBMOM+dWrTLNmjMOz06Oi2Pf5MkAXA0Lo1yzZgC4VK3KvYsXsbGzI90wCLrZ5Ml4NGpkGn+UcYado6cndceM4eypUwAW/7hTHzxQf1EUKjz1FBE7dpgSKUBt6fnmGzVR8vWFa9fU602aqLcXZKuSuV69YOVK6N8ffvwRWxsbtbXpCeTo6YnO2ZmthsUyjc4uW8ZZQyuT/6hRj99lKYQQ/yLSsmQlT1o33E3DOkVerVqZxhKlGFYqN1ejf386L1+O1my8UvMpU0ytOzonJ/a88w4A9wyzr9LNZovdu36dMv7+jxxMbGxZSoyO5nZ4OFH79nFg+nQASlWqhG/XroCaqAFw8KA60PruXWjeXN2eBNREyXixVrIE8NxzsHw52Npi8/33NFywADKOo3pCGGc+PrN6Nc3ef99U7t2uHU8vXIg+IYH0LF57IYQQWZOWJWt5AmbDxZ0+zZ3z57l//ToPbtwAID09nTjD6ugJxvWoIiPVLqxRo3D09gZ7e1KPHzfFKVuvnql1x9HTk8o9ewJwOzyc/VOmUHfUKE5+/TUBM2filcuB9MbVpRMiIzONU7p/9aqpJSti9268bW3VTXDj4yEgQN0I17jvW2Hq2xd+/BFl8GAqh4WRNm4cfPXVE9flmuW6ShoNkTt34tWqFed++AGHnNa+EkIIYUGSJWt5ArrhDs6YQYzZJsMA1zZvNv1+//p19ZfISJg2DXr3Bm9vLv30Ezx4gIOnJ0kZxreY/yPWxMRQPzoaTz8/NEFBeLVsmevp6RpD61a6Xo9Phw7c2LoVjVaLkppKi2nTTMmZ84ULEBgI9+9Du3awcSO4uDyc5m/N1qSsvPgiaUlJ2L7yCrYLF4KdnbouU1SUKeEs9DrlQpU+fbi0fj0nFy4s6qoIIUSxI91w1vIEtDY0mzSJVjNmoC1VylRWuXdvGhm2dtFoteqaRMZFPBWFtJQUThtmIfr36EEnPz8cs+lusomJof6tWzjq9TQYOzZP6/ho7OzQGbaSubF1KwD1DOtrGccplbl5E/sXX1QTpY4d1RYl435w+V1wsgAogwdz5PXXUTQa+PJLmDgRIiLUhDOLQe9FyTjg2zcwkFIVK5rGqaVHRBB36pQM+BZCiFyQZMlKnoQxS+61a+NUrhyp9+9j6+AAgHebNlR99lkc9Hpcb91C6dED3n1XPaFTJxLatKHyqVO46HRUad2a8r/9hmM2K1jbG5YHMP7MK/PkqsbAgfi0b//wxj/+gO7dISFBHdj966/g7Jyv+7GGa506kbZggXolOFhtXXoCGQd87xg79mFLIpCybh1bBg6UFb6FECIXpBvOWp6AbjiAyxs3AlC2QQOi9+8HwM7VlRpxcdS/dQsuX3548N27uBw8SBOgcXQ0yoQJanlS0sNjIiNNrScOv/2m/ly7FowJk7d3jq09iTEx3IuMJO3GDewN6ziV8vWlcq9eJMXFUXvoUJyPHVOn6Ccnq6tor1kDhmTvSaJ06waTJsGMGQ8HnJvvm/eI56KwGFf4Tk1MZMvLLwNg1707Tw0ZglarlZW9hRDiEaRlyVqegGQpLTmZa3/8AUCVnj3xbNaM0tWrY6PTWa7IbVgU8k6vXlwrVYpErVbdAPjAAfX22bPV7UUOH1Z/b9pUvcyZo96+YMHDskesdXRu1Sq2DBxI0vz53D5xAoD7164RNmgQ2157jTIXLmA/dKiaKD37LPz00xOZKAHYfPONmiiZ++STh8/FV18VTcUyMK7wXa5pU5y8vABIPX8eBw+PXM1cFEKIfztJlqzkSeiGi9ixA/39+zh5eVH1uecIXLIE99q14ccfqWeYCRc7fDiMGQPAnlOnuOPggGPGbT3WrXuYAAAcOgRmG/Ka1KqlDsbOgXFpAoexY2n6wQfAw4Une40cid9336njqPr1U/djs7N7vCfBitJffVV9Lg4dgo8+UgsNGzsD6jYpP/30RC0x4FK5MgDpZ8+SdOtW0VZGCCGKCUmWrMV8gHcRLB+QGBPDMcM4Gr9u3dDcvKkOiF6+XO3iAk6VKcOtTp0enpSWxoXy5Uncto1tc+aQapi+j7097N+vJgVvvaUuaGhY3RtQx+t4eMCZM+pq2suXZ1svR09P3OvUwdbHB/c6dQDDgO6jR3F5+200qanqPmzLlj2xG9eaeHs/XOOpWze17Oef4c031Y2Cjx+HF16AunXV5yu/G/wWoDJ16xZ1FYQQotiRZMlaing2XPzly8QbFo2s3KOHaXkAZfhwSE3lurc3R8qX55+QEHbPm8fJChVI1Gop1aIF2tatuVutmjr4G9QuMXv7hws//u9/6uKQNWqot7dpA0ePwlNPqTPXBg2CV19VB2fngt369TBkiLqNyLBh6vifHDbufaJ5eakDvq9cgf/+F9zc4PRp9XFVr67OnjNsIlyYEmNiuB0ejqOHh6nMOBtOZsQJIUTOJFmyEou2pCJoWTIO5nb28aF07drq1iCAJjmZSGdndpUuDRoNKXfucOXwYY6VLk2STkfqgweEf/MNyVu3Envy5MOAu3erPy9dUv/hgzpV3rjWkY8P/PknvP++mih++y20aAHh4dnW0cHDg6caNcL5v/9Vu6pefRUWLbLsyiouMq775OkJH34IV6/CzJlQvrz6+xtvQOXK6linLLabsZZzq1axuV8/Ds+caSo7NH06m/v1kxlxQgjxCJIsWUsRtCwZWw8ub9pE+Hff4aDXU9HdnXvffUe6oestzcsLp5AQ2gwbhkMW3UK3T5zg5Pz5pIaFcXjJEjBO5//7b/Xn5Mlqd1JgIAwcaLnWkVYL06er6zaVLw8nT0KzZrB4cZYJo/PatVRctgyNosDYseqAaJti+ieZ3bpPrq7wf/+nJpnz56uJUnQ0vPceVKqk/oyOfnh8ZCQ206djf/t2gVbPfAsU12rVAPBq08ZUVqN//wK9PyGEKEmKaV9HMWCWLGkKqWXJfBNcAP+4OOqvWqUOlDawjYrCbehQ3IA7Hh4kjhuHY7lyRGzfTuyxY5Rt2BCvtm05c/Ys9Z9/Xl02YPt2tWXp4MGH45HMWigy6dQJjh2Dl16CLVvglVdg61YICYF797AJCaHm+fPYrlihHj9hgjqz7glYyNNqHB0hKEhtPVuxQp01Fx6utjDNm6fOSHzrLYiNxfajj3AwzjQsqLs3W3ndr3dv/pk3j9snT1K6Rg1sCmhsWGJMDOdWraLyc88VSDwhhHhSFNOv8U++opgNZ2w9qNilCwDnSpfmQcOGAKQbp99/8w0cOsTd1as55+5O9RdeoP6oUVQwtCBVaN8e/1dfxb5DB7wCAqBVKzWJuXQJevVSY7z0EjRunHNlypeH339XxzfZ2MAPP6iz6bZvx/ajj6hjTJTeeafkJ0rmdDp1fNY//6izDJs3VxPSL79UxzRNnWr1Kng2aQJAyp07ROzcWWBxE2NiOBESIrPshBAljiRL1lLIs+HiTp8mat8+7l68yG3DJrg179zB+dgxFFtbEo2rdBtmb9m1b0/1N9989Bo7rq5Qv776e1SU2tVmnCb/KDY2ajfTtm3qmKazZ9VEyyBt8mS1ZeXfkiiZs7FR15Hatw9WrlSTptRU+OUXAKr+8svDta0KeAsVJy8vbCpVAuD8mjV5OjcxJobj8+fLgHAhxL9KkSdLISEhVKlSBQcHB5o2bcrOHL7pDhs2DI1Gk+lS12w6dGhoaJbHJJmvQl0YCjkBODhjBnveeYcjEydS7fhxasbGUs/wDX9v+fL8Y1xg0sDR09NiPzePBg1w8vbGo0GDzMHbtHn4+8CB6tIBeVG9ujp1vm1bdcYbENmiBem9e8ORI0/cfmqFSqNRu+MyvD6Vtm1D16pVrhb6zCtHT0/sX3gBUNfiOjRzZpbJT1aJkbH1yFiWEB3NtT//5MicORz+9FNAnWWXduMGcadOSVIlhCgRinTM0sqVKxk/fjwhISG0adOGr7/+mm7duhEeHk4lwzdfc5999hmffPKJ6XpqaioNGzakX79+Fse5urpy5swZizKHQl4FWinkMUvNJk3izvnzJP/1F7XnzSPNUB7bpw9eI0fi7uqqDrbOZvsN74AAnt2yBQC9ceB3ZCTcugUVKjw8sGlTtbUDcr+dx9dfqzPnzO9v/35o2VK9MmVKoXQ/PbFGjYLevdXfDx6EUaNIt7HBJj1dXb/KsB5VQbLx9MSjSRNuHT7Mme+/p4qhi/XcqlXU6N8fR09PU2JUsUOHTC2QN/fv5/yaNVzZtAn9vXsWtx2aPh2ALfPnUy8oiAZjxxZ4/YUQojAVabI0d+5cRowYwUjDdhvBwcH8/vvvLFiwgBkZt5EA3NzccHNzM11fv349cXFxDDfM9DLSaDR4GbZ1KDKF3A3nXrs27rVrc94wANsWuN+uHWV/+omyxhlmTz2Vp5g233yTuctt/PiHv+c2yTFPBg4fhldf5cjYsdR7+WV0Wu0TsX9akcoi6Tw8fjxNN25Ec+YMvPii2vL0v/+p610VkCrPPcctQ+KrpKdnSo7SDK2x18LCuLBuHQmRkdw5dw6AI4ZWJABsbHAsV45Ew6rwTT/4gJOxsbRt2xaXf/trK4QoEYosWUpJSeHQoUO8axxLY9ClSxf+Nk5Tf4RFixbRuXNn/DJ0C92/fx8/Pz/S0tJo1KgRH374IY1zGJCcnJxMcnKy6Xp8fDygtrDo87Hqsl6vt0iW0tPT8xUnx/hkaAGKigJFwWftWgDu6XTc6d4d+4MH1YUS8/BPyxg3edgwdIYWB82RI2hHjyb1q69QjM+ll1fuVqX28FAvAKmp6IC7Vauir1fv4Srd1nx+CphV4xuen/s+PiTu2oX95MnYLlwIc+agbNlC6vffP3ZLk3EjY4fGjbGxtyc9OZkd48bhVrMmALveegv9vXskG5YvOLlwYY7xag0bhk/79vw1dCgALjVqYOvgQKnq1dHqdAX+PBXr11fiS3yJXyjxC5pGUYpgxUQgIiICHx8fdu/eTevWrU3lH3/8MUuWLMnUjZZRZGQkvr6+LFu2jP5ma8Ts3buX8+fPU79+feLj4/nss8/YtGkTx44do4ZxxekMpk6dyrQM3UQAy5Ytw8nJKV+PzyY5mV4DBgDw04svYvvii/mKkxu1li+n9sqV2d5+esAAzgwc+Fj34XbhAk//5z9smzOHu4Z1eooyTkllf/s2lX//nctdu5JcpgwAXvv30+jLL7GPjyfNzo4Tw4dz+Zln8j0uLmXLFvR//ZWvczUVKqBERGD33HPYGLpnNS4uoNGQaGgNdhg9GtssutGFEMLaEhISGDRoEHfv3sXV1bXA4uarZenBgwd88skn/Pnnn0RHR5OeYaPQi4ZtNnJDk+EDX1GUTGVZCQ0NpXTp0jz77LMW5a1ataJVq1am623atKFJkyZ88cUXfG7YKy2jSZMmMXHiRNP1+Ph4fH196dKlS76ebL1ez58bN5qu+1SoQJPu3fMcJ6f4YWFhBAYGotPpoHFj9BMncn3iRKoYVto2bwGq5uVFtTy2LFnEB3UgNtCmbdtHLxuQk8hI9LGxJLm7W8YvQFnWvzjFHzCAM+bxu3dXxzGNHIltWBgNv/6a+tevk7ZwobpSeB7da9yYbXXq0KpVK8588w2RO3bkeHzTDz4w7eOXHBfHzqAgnurf31QG6vv2p7lzSU9OpnmzZhyOji6+z7/El/gSv9jGj42NLfCYkM9kaeTIkWzfvp0hQ4bg7e2dq+QmIw8PD2xtbYkyjHMwio6Opnz58jmeqygK3333HUOGDMHuEbvS29jY0Lx5c84Zxlpkxd7eHvssxoLodLr8v5hmz4mNRmOVPwpT/SpVgkqV0Ny4YbpN27y5ukxAQcQH8PWFKVPQ+fo+3ga3lSqhnzqV5E2bHu/5zYUSFb9SJdi8Wd20+J13sNm4EZsmTdRZhl275imui7c3tj4+eNavDy+9ROSOHQTMnElaUhL7p0yhxbRplPH35+7Fi+x55x0869enjL8/ALcN29dotdpMj92lYkXuXrjAlXXrSK9fv2Q9/xJf4kv8YhHfWnXOV7L022+/sXHjRtqYTynPIzs7O5o2bUpYWBjPma34GxYWRp8+fXI8d/v27Zw/f54RI0Y88n4UReHo0aPUN64VVEgKq28z7vRp7pw/T1pyMmXMEs8bO3aQEhFB6erVca9d+/HvyLidhyg6NjbqAPuOHdUlHMLD4Zln1LIZMyAfMz4d3N0BcKta1VRWxt/flBxl5OjpSb2goCzX53I2JEtXN27EoXLlPNdFCCGeVPlKltzd3SljGE/xOCZOnMiQIUNo1qwZAQEBLFy4kKtXrzJ69GhA7R67ceMG33//vcV5ixYtomXLltSrVy9TzGnTptGqVStq1KhBfHw8n3/+OUePHmX+/PmPXd88KaTZcAdnzCDm4EG0aWn0NcxeOlWmDKdCQkjS6fBs1ozAJUusdv+iCDRooC4x8H//p678HRysbmK8bBlk8Z7IiXnyk3FNpKwSI+P6XFkpVbFinh+KEEIUB/lKlj788EM++OADlixZku8B0AADBgwgNjaW6dOnExkZSb169di0aZNpdltkZCRXr161OOfu3busXbuWzz77LMuYd+7c4bXXXiMqKgo3NzcaN27Mjh07aNGiRb7rmS+FtCilcX2lmx9/jA1wX6cj7rXXaGxo9StdvXqh1EMUMkdH+OIL6NYNhg9Xt09p1gw+/RRef12dHfn11+qyDTmMV8uY/JgnRzklRuYSY2JIjInBxtbWVJZ+9Spxp06h1Wot9qUTQojiKF/J0pw5c7hw4QLly5encuXKmfoIDxsXLcyFoKAggoKCsrwtNDQ0U5mbmxsJCQnZxps3bx7z5s3L9f1bi3lbkjUXpTSur5T4+usA3HJ0xLtNG6r07Gm1+xRPkO7d4fhxNWH67TcYN079OWGCuhBo7965XjYit8lRRhk3cAZI+eUXthi2bqk1dCg6Z2fTYpdGxo13M5YLIcSTJl/JUsYZaCILhdCyFHf6NA+uXCHl7l1KG7Y2iXFyQjHMXCuw8UriyVa+PGzcCPPnw1tvqcnSnj3qbRlmqlpDjf79qdihAwCXN27ktPFLjkZDlWefpXyLFuwYOzbTSuA5rRBekCQpE0I8rnwlS1OmTCnoepQ8hTBm6einn3Lr0CE0isILiYmA2rIUt2IF51eskPFK/yYaDbzwApQrB5Mnw/nzanm3btC/v9rC1KCBVVZLz9jNdjo0FNtatUg7c4ZL69YRk4eWZmsorKRMCFFyPdYK3ocOHeLUqVNoNBr8/f1zXCX7X6cQWpYavf02D65c4eaiRdidOoXexga3fv2o3a4dIOOV/nWy2IOPW7cgJES91K4N8+bB009bvSragAD8u3Xj9Lffcv/KFQDCXnoJW0dHbHQ6tE5OaAzb8Nzcv9903qPGNyXGxHBm+XLSDbP4hBCiMOQrWYqOjubFF19k27ZtlC5dGkVRuHv3Lh06dGDFihV4yrc3C9Yas+Reuzbl6tfn/vvvAxDr6Ih3u3YyXunfKos9+Bg+HA4dUsc1nT4N3bqh9fOjZps20KgRZNgq6HE5enriP2oUZ0+c4B/DAqlGacnJpJltK2Rkvs9cvaAgavTvn223WWJMDOFff42D2diqrLrZEmNiuHPhArcOHeL61q0A3Ni2zaKe0sokhMitfCVLb7zxBvHx8Zw8eZI6hlV8w8PDGTp0KOPGjWO5YTPXfztFo7Hq4G4A/f37lLp8GYAYR0dKWfXexBMtiw15ef11dXHSkyfhm29gyRI0V65Q58oVlJUroWdPeO01dWFLs9lsgLrnYC5m1Jlz9PSk7pgxXFqxgqdffx2tVsvt8HD2T5lCg3Hj0JUqReKtW9hotSRERnJx3TrTuW41auDZpEmeu83Mj9c/eMD1v/7i7NKlJGRY8Paf+fP5x7CEiGezZrSdPVsSJiFEruQrWdq8eTNbtmwxJUoA/v7+zJ8/ny5duhRY5UoMKyZMt44dw+PBAwD0DRtK15vIWt266npMM2aQunIldz79FI/wcNiwQb34+sLIkfDKK2BcLykyMs8z6oxsXF1xr1PHYqZshXbtLBa7vB0ezsV166g9bBjnV63i7rlzbBs1Cj/D1kDRhw8Tf/Ei9yMiSIyORn//Pg8iIgBI2byZA9euoXVwIN2wcebON9803W7kUrkyLn5+RGzfDkCZ+vWpOWgQeydNIjEmRpIlIUSu5CtZSk9Pz3JJcZ1Ol2mfuH81jcaqiRJA3PbteOv1KECTNWugdGmr3p8oJry9YcqUzEmOoyPK4MHsdnene5Uq6EJD1S1Trl1Tj582TV2O4LXX1Fl2haByjx5U7tGDI7Nnc3PfPi4blhw4bNiYNyvpFy5w+cIFi7IHERFobG0pU7cuPk8/TZVevXCuUIHb4eFEbN+Orb09t//5h8idO636eIQQJY9Nfk7q2LEjb775JhFm3+Ju3LjBhAkT6NSpU4FVrsSwYsKU+uefAKT4+kqiJB4ybk+TU4tQnTowdy7cuAFLl6oDv9PT4ddf1dYk455zBw6oY6AOH1Zbm/Iouy1SzMuvb93KzX37so3hUrkylXv1wsewRIEmmx0ElLQ0Yo8fJz01FecKFSxuq96vHwBXNm0C1JatiN272Td1KnGnT+f5cQkh/j3y1bL05Zdf0qdPHypXroyvry8ajYarV69Sv359fvzxx4KuY7GlaDRoAGvNi0tPTcXu5En1ymPs0yf+5RwcYNAg9fL66+p6TQB37qg/DdsPAWrrUx73CMxusUvzcvO1moxjnIwb+hqPdfT05HZ4ODe2bsWud2/ade1qMSYq4/Hm9+PZrBlnMnw27c+wBEpL2ftQCJGNfCVLvr6+HD58mLCwME6fPo2iKPj7+9O5c+eCrl/xZuXlA+6ePUvZ+HgA7PK487wQWZo8WR23lJICCxaAcV/GFi1gzhyoVs0qd5vV7LScNvTVODtnGhOV3fGOnp60nT2bxJgYlPR0Tnz1FTcMM+ScvL1JiIykUmBgAT4aIURJ81jrLAUGBhIoHzKPZqVuuNj9+6lp2DxXY1hbSYjHYj6jzs5OTZYcHGD/fnV1cEMXVlExLk1wycUlz+cZk7EaAwdyY+tWtE5OJBi6FWNPnsTesHaTVrqzhRAZ5DpZ+vzzz3nttddwcHDg888/z/HYcePGPXbFSgQrtywlb9mCraKQ6uKCtmpVq96X+Bf76it1r7l9+6B9e/jjD6usBG6U3Rgn4211x4wxjTt61PFZuRYWBkCq2R6Txz/7jOOGzbn9R40q8PWnhBDFW66TpXnz5jF48GAcHBxy3KhWo9FIspSBNdZaUhQF7cGDAKQ2aYK2EFYMF/8yxhl1XbrAjh3qzxMnoG1b2LIFqlSxyt3mdUPfvB5f88UXAagUGMjtkyc5ZkySXn2Vcs2bc2PnTtIN3dtCCAF5SJYuXbqU5e8ie4phOwdrdMMpd+7gFhMDgE7GKwlrMM6oM/6+axcEBsLFi+qEgrAwdf2mYsa9dm3TYG57d3dTsnR26VI8Gzfm3A8/WKwQLoQQ+Vo6IKO0tDSOHj1KXFxcQYQTuZB++TIehm4E2/bti7g24l+halU1YapXT11C4Kmn1LFMkZFqUpWPZQVyZK24WShdqxapCQmc+Oorq9+XEKL4yVeyNH78eBYtWgSoidJTTz1FkyZN8PX1ZZvZ/kv/esauMSu0LDmeOIFjWhrptrbQtGmBxxciS97esH07tGwJt29Dp07qCuDTplknWbJGXDOOnp7UGjqUmoMHo9FqiT1+HID069eJO3WK2+HhJBpacIUQ/175SpbWrFlDw4YNAfjll1+4fPkyp0+fZvz48UyePLlAK1gSWGM0UZlTpwDQ16oF9vZWuAchslGmjDpmqVMnuH8fivEYRUdPT3TOzuz/4AOU1FRTecqGDWwZOJDN/fpxbtWqR8ZJjInh+Pz5klgJUULlK1m6desWXl5eAGzatIl+/fpRs2ZNRowYwT///JOnWCEhIVSpUgUHBweaNm3Kzhy2Ihg2bBgajSbTpW6GcRNr167F398fe3t7/P39WWe2WWehslLLUszhw5Q1fNu2efrpAo0tRK7cuwcffQQdOoBhbzaaNQNbW7SOjvR6/nm0zs5qIu/gAI6O4OQEzs5QqhS4uICrK7i5qSvPu7urSZi7+8Prxu7lL79UZ+LlcwXxR6nRvz/PrF5N11WrqPrss6ZyjVZLzcGDqfbCC49Mhoyb+UqyJETJlK9kqXz58oSHh5OWlsbmzZtNi1EmJCRgm3Hn8hysXLnS1Bp15MgR2rVrR7du3bh69WqWx3/22WdERkaaLteuXaNMmTL0M2xjALBnzx4GDBjAkCFDOHbsGEOGDKF///7sy2ErBaux0gy1yB078DSMV9LJOleiKHz9NQQEgGFxR0D9UpCejiYtDZv0dDR6vbq4ZXIyJCVBYiIkJMCDB2qL1L17EB8Pd++qq4XHxak/jdfv31fjLl4MrVqp3c3BwQX+UBw9PSnj70/ZunWpOXgwADaVKqGkpnJ26VJ2TZhAzJEjmZIhRVFIiI4mau9ermzeDECaYd0zIUTJkq9FKYcPH07//v3x9vZGo9GYFqbct28ftWvXznWcuXPnMmLECEaOHAlAcHAwv//+OwsWLGBGFptourm54ebmZrq+fv164uLiGD58uKksODiYwMBAJk2aBMCkSZPYvn07wcHBLF++PD8PN99M7UkF3LKUePYsbsnJ6pWAgAKNLUSujBql7h8HaovPq6/Cp59C/fro9Xp2nTlD2+eeQ6fVqn//xveA8ffsLtHR6kVR4ORJdcySm5uaQAF88QU29+/jVL/+w7pERqrJ26hRBbb+k13PntQrV45js2cTe/w4u99+G4Dza9aQ+uAB8ZcucffiRdISEy3OO79mDbYODkDWq5ILIYqnfCVLU6dOpV69ely7do1+/fphbxgzY2try7vvvpurGCkpKRw6dCjT8V26dOHvv//OVYxFixbRuXNn/MwWkNuzZw8TJkywOK5r164E5/CNNDk5mWRj8gHEG9ZY0ev16I1dDHlgOsfQsqSkp+crjrm406eJv3hRvbJnDxrgQalSRO7dC4Br1aq45yFRzYmxro9bZ4lfguN7eKgXgNRUdID+qaegcWP0ej3xaWnovbzAbDuSXDHfTsXPD920aeg3bkRz9iy2wcFojh/HNiSEzhoNaZs3kzpxIoqDg3pc9+4P65RP2tKlqfXqq1x1dcWjZUtafvIJp775hthjxwA4v3Jljudf2rCBSxs2AOrilnXHjMl0TLF4fSW+xC/m8QuaRlGstBfHI0RERODj48Pu3btp3bq1qfzjjz9myZIlnDlzJsfzIyMj8fX1ZdmyZfTv399UbmdnR2hoKIMGDTKVLVu2jOHDh1skROamTp3KtGnTMpUvW7YMJyenvD40k2defBH7pCQ29+pF8ogR+Y4DkLhwIemXLwNQPzqa+rducdHNjb0+PgDYVK6M42uvPdZ9CJEfbhcu8PR//sO2OXO4W4B7x2WKqyh4HD9O9Q0bKH/4sOm4u35+uF25wrbZs7lbvXqB3X/Kli3o//or29ttGzdG17Il2NqSvGEDyvXr2Navj+6ppwDQuLhg4+paYPURQjxaQkICgwYN4u7du7gW4PuvyLc70WQY16MoSqayrISGhlK6dGmeNRuQmd+YkyZNYuLEiabr8fHx+Pr60qVLl3w92Xq9nrCwMGy16tNbvnx56nXvnuc45uKqViX+4kVS7tyhjGHBvNTmzWnx+utAwbcshYWFERgYaLFRaUGR+CUsfmQkaXFxtOnbF7y9Cy5+hrgA9OiB/q232DV3Lq327cN282bcrlwB4Kk1a0ibPVttzfLyyneXnLH+nd5+m9RXXwUg7tQpDk2fTtMPPsC9Th0AHDw8TN1s2/btI+b6dSrVqEEzwzmPil9sXl+JL/GLUfzY2NgCjwlFuN2Jh4cHtra2REVFWZRHR0dTvnz5HM9VFIXvvvuOIUOGYGdnZ3Gbl5dXnmPa29ubuhLN6XS6x3sxDQmajUbz2H8U5erXp1z9+tz480/KGgZ3O/TqRaU+fR4rbk4e+/FL/H9H/EqV4MMPyTi147HjZxMXwOPECbS//mpRZrN3LzZt26pXpkx5uPp4Prl4e6OrVAkAreGLj2f9+pTx9890bLph2QElOTnXj7nYvL4SX+IXo/jWqnOuZ8NdunSJsmXLmn7P7nLROK7mEezs7GjatClhhk0tjcLCwiy65bKyfft2zp8/z4gsurYCAgIyxfzjjz8eGdMarNG/mfjXX+gUhRQbG1J8fa1wD0I8+S537Yp+3z44dAi++UYtNH7hqVwZHrMlN69sDB/Q2sfothdCPLnyNcC7oEycOJEhQ4bQrFkzAgICWLhwIVevXmX06NGA2j1248YNvv/+e4vzFi1aRMuWLalXr16mmG+++SZPPfUUM2fOpE+fPmzYsIEtW7awa9euQnlMFgwtSwW5ka5mzx4Abrm64lqA4zOEKE6Sy5SBxo0tB5CHhsJbb8Hly+pMvV9+gebNC+T+HD09qRcUZDG7LTEmxrSUgGIYVBp39iy3w8NN58hsOCFKhnyts9S3b18++eSTTOWffvqpxZpHjzJgwACCg4OZPn06jRo1YseOHWzatMk0uy0yMjLTmkt3795l7dq1WbYqAbRu3ZoVK1awePFiGjRoQGhoKCtXrqRly5Z5eIRPLgfDwPe4Fi0KbIySECVCzZrq4pUNG8LNm+qiloaZaY/L0dOTBmPHWiQ/51atYnO/fmzu149bR48CEHvsmKksNyt/CyGKh3y1LG3fvp0pU6ZkKn/mmWeYPXt2nmIFBQURFBSU5W2hoaGZytzc3EgwjNnJTt++fenbt2+e6mEVj7GCd2JMDOdWraJG//6mD+jUxETcDN9k45o0KbBqClGseXurY5S8vdXLzp3Qvz9s3gzPPQfz5sGbbxb43dbo35+KHToAcDs8nP2Gz0RbBwdaf/IJHo0aFfh9CiGKRr5alu7fv59pYDWoA6uMaxQJHmsFb4vtEwy7r9/bsIFSej0KcMewN58Q/3re3upgbuPsNxcXtQtu1Cj1i8r48WqylJZWoHdrXPnbeAFw9/cnLSmJf0JCSE1Kkv3ihCgh8pUs1atXj5VZLM62YsUK/LOYKfKv97hjlgy7r6cbmvXvu7uT5uhYABUTooTSamHBApg1S73++efw/PPqVitW1Gj8eBzKluXO2bMcmT1b9osTooTIVzfc+++/zwsvvMCFCxfo2LEjAH/++SfLly9n9erVBVrB4kwxDvDO5fHmA0bPG57HG1u3Ylu+PG6AjWFchL5ixQKuqRAlkEYDb7+tzo4bMgR+/lkdx/Trr+o6TAXIOAC8dM2aBHzyCVtfe43rW7YU6H0IIYpOvpKl3r17s379ej7++GPWrFmDo6MjDRo0YMuWLbQ37hQuHsply9K5Vas4ERICgINej3tqKjEzZ1LFsNO6s2Gwu6ZiRexv37ZOXYUoafr1Ax8f6NNHXWqgZUvYtAnq1i2wuzAOAE+MicG+dGmqPf88F9auBSD2xAmL47SlSxfY/QohCke+lw7o0aMHPXr0KMi6lDx5HLNkPmD0Zrdu1MkwE9DOMObC/bffqJWaqn7Y+/oW2OahQpRYrVvDnj3q+kvnzkGbNrB2LXTqVKB3Y/6Fx+iA2VZK9YKCqCPbEglR7ORrzBLAnTt3+Pbbb3nvvfe4bWjlOHz4MDdu3CiwyhV7eZwNZxww6l6nDmdcXPitShUSsll5vEpYmLov1ddfF1RthSjZqldXE6a2beHuXXjmGXVtJsMECgwtuI+jRv/+PLN6Nc+sXo19mTIA1B42zFRWw2wfSyFE8ZGvlqXjx4/TuXNn3NzcuHz5MiNHjqRMmTKsW7eOK1euZFpE8t8ur3PikmJjSVAUEhwd0dvaqmvGAP94eFD/1i1Sv/qKXQ8e0KZtW3SyircQuVe2LISFwfDhsGKF+nPkSPj2W3Uhy0e10kZGql9QRo3K8ljzhShdfH1Jvn0brYODxRYp1toVXQhhPflqWZo4cSLDhg3j3LlzODg4mMq7devGjh07CqxyxV4+lw54YNY6Z282eyfesFyD0rixugt748bSBSdEXjk4wNKl8N576vVvv1V//v03RETk3BJsmJmam1Yox3LlAHhg+LIjhCi+8pUsHThwgFGjRmUq9/HxybSJ7b+Z8SM3/tKlPE0fvn/9uiGAgt2tWwBcq1OHZNusthQVQuTZzZvwwgvw/vsPv9S88Qb4+KAtX562kyZh83//B99/D0ePQkpKnu/CzbAd0a0jR2T5ACGKuXx1wzk4OGS5+OSZM2fwlL2QHrJRc9H7V66QGBOT632ijC1LDmlp2Oj1pAMH3N0hNZXYF17A1curQMZXCPGv9fXXagtRFjR37lD2zh04dephoa0tVKkCxvfw4cMPbzOuHJ6Be506ANy7fDlX7/+sVu0XQjwZ8tWy1KdPH6ZPn27qe9doNFy9epV3332XF154oUArWBLktTPuviFZKmX4Npug05F05w5JOh36t9+WrjchHteoUeoyAocOwTffqGXffAO7d5MaGso/w4aR9vrr6rpM9vbq6t/nz6sDxAFefRWaNlUv2UyyKJXH9dAsVu0XQjxR8tWyNHv2bLp37065cuVITEykffv2REVFERAQwP/+97+CrmOxkxgTQ9qNG6Qbt1dQFNNO5PDo3cjjL10CHiZL9812Vr+5fz/6pCTSbtwgMSYGXYUKVngEQpRwWbUGNWkCTZqgNG/OxdKlqd29O7Y6nTqO6cgRdcmBGTMgOhqqVYMffwQ7u0xxjIvLpiYmmsp2vPkmTl5eOJQujUP58ujv3eOarS3O5crhULYsDmXLomQxVkpam4R4MuQrWXJ1dWXXrl389ddfHD58mPT0dJo0aULnzp0Lun7F0sU1a0j6+mtS7t3DuCnJfrONh+sFBdFg7Nhsz79z7hwApQwtd/fN9uE7+dVXD+8nNZVG48YVYM2FEJlUqKBeQF3XrG9fuHABFi6ERYsyTeTIaq2lhIgIEiIiLMr2/vqrxXWNodv+aHAwtQYPxtHTk+S4OE6EhFCxQwdJloQoQnlOllJTU3FwcODo0aN07NjRtN2JeKhq375c1GqxmzIFbt1CA7SYNs00fTinD730tDRSDTPgTC1LZslS3dGjKdOgAQdOnqTqs89a7TEI8a/h7Q1TpuSue7tKFfWnRgOLF0P9+jBhgsUh5ovL3jp2jIMffUSNgQOxc3Eh+e5dUpOSuHbhAu729sRfuEDKnTsAKOnpAETt3k3U7t0A+Bji5FV6fDwnFyyg1sCBkmQJUQDynCxptVr8/PxIK+AdvEsSR09PbH180Jh1n5nvTJ6TxOhoFMNzm1U3nG+nTrjUqIHtnTvyIShEQfD2VhelzO2xU6aoydLUqfDWW1CnjrrApUFW3ezVnn/e9P7X6/XEbNpEh+7dSb1zR+221+uJOXiQo3Pn4uzry4Nr1wB1b0iAPZMn41atGk6enrhVr04Zf3+cK1bEzsUly2oq9+4R/vXXVOrcWT4nhCgA+eqG++9//8ukSZP48ccfKWNYpVYUDPM1lrLqhhNCFCFjYqUocPUqfPcdDBgA+/ZB7dp5DmeeWNkavhR5tWrFBUOyZHT37Fnunj2b6Xw7V1ecK1aklI8Pzj4+lPLxwcHLCyUuLu+PTQiRrXwlS59//jnnz5+nQoUK+Pn54ezsbHH7YfNptf9mhrEMLr6+uf52Z1xjyTY9HafUVLXMkCxV7tlTviUK8STQaCAkBM6ehV27oFcvNWHK8OXR0dOTekFBeXrf+gYGmrZFuXngAEdmzaJyr15obGxIjI4m6fZtEqOjSY6LIyU+npTwcOLMJpCY2/Hmm5SpUwfXatUo17gx5Vu2xNbePsf7l0HlQmSWr2Tp2WefRaPRZDl7I69CQkL49NNPiYyMpG7dugQHB9OuXbtsj09OTmb69On8+OOPREVFUbFiRSZPnswrr7wCQGhoKMOHD890XmJiosVq44XJpVKlXH/oxBm+PTobWpVSbGxIMQz8rPXyyzh6esp2CUI8Cezt1c14mzdXlxUYMAB++w20Dz9WHT09c5zMYc6YWLnXrJnp86L2yy9n6sbXP3jAg4gI7l+/zoOICC7/+iuxx49bHGMaWP7nn4QDGltb3KpVU/eg9PenTJ06lK5VC53ZF17jEgYyqFyIh/KULCUkJPD222+zfv169Ho9nTp14osvvsDDwyNfd75y5UrGjx9PSEgIbdq04euvv6Zbt26Eh4dTqVKlLM/p378/N2/eZNGiRVSvXp3o6GhSDS0wRq6urpw5c8airCgSJSUf253cu3wZyDC42xAn7tQpNBoNqamppGexKKgQopCVKwc//wxt2sCWLTBxInz+eb5C5SWxAtA5O1O6Rg1K16gBQKUuXdQlC1JT2bFyJSnr11N9wADS9XriL1wg/vJlUu7e5c7Zs9w5exbWr1cDaTS4VqmCe506lPH3R1eqVL7qL0RJlqdkacqUKYSGhjJ48GAcHR1ZtmwZY8aMYfXq1fm687lz5zJixAhGjhwJQHBwML///jsLFixgxowZmY7fvHkz27dv5+LFi6axUpUrV850nEajwcvLK191KlCGJEeTixa4xBMniJswgWRDq1FWg7vNlx/QdewIL75YkLUVQuRHw4bwww/w/PPwxRdQr57aLZfDhru5lZduPOP4J71ej42PDwDV+/Y1tUgpikLizZvcDg/n9qlT3D55krhTp0iMjib+4kXiL17kysaNpnixJ05kii3Ev1WekqWffvqJRYsW8aLhn/TgwYNp06YNaWlp2OZx37KUlBQOHTrEu+++a1HepUsX/v777yzP+fnnn2nWrBmzZs3ihx9+wNnZmd69e/Phhx/i6OhoOu7+/fumGXuNGjXiww8/pHHjxtnWJTk5meTkZNN141Yuer0+X11eGc9JT0/PMU5iTAx3//gD3y1bOFalCjg6Zjm42/upp6g7ZgypqansO3nSat1xxrgSX+JL/Fzq2RObadOwnTIFZexY0tLT0U6bhr57d8jQ8p6X+NrSpanz2mt5qo/5campqRbXdWXLUr5dO8qbDXVIunWLo3PmcO233yziHDDbDsZ/1CjqjhmT5/rnh8SX+AURv6BplDwMPLKzs+PSpUv4GL61ADg6OnL27Fl8fX3zdMcRERH4+Piwe/duWrdubSr/+OOPWbJkSaZuNIBnnnmGbdu20blzZz744ANu3bpFUFAQHTt25LvvvgNg7969nD9/nvr16xMfH89nn33Gpk2bOHbsGDUMzdUZTZ06lWlZ7BO1bNkynJyc8vS4zD316qu4x8SwvVMn7rzxRrbHpWzZQrVVq2gSHc1vVaoQ5+hI+6tX8bl/n/3e3lxq04a08HDshw1DW7NmvusjhLAiRaHp3LlU3LmTFCcn7BIS2DZnDnerVSv0qqTHx5O6fz/aFi2wcXXN1fHKvXsApB44QOr+/QBomzdH26IFGheXXMURoqglJCQwaNAg7t69i2sB/s3mqWUpLS0NuwzT2LVabaYxQ3mhyTCuR1GUTGVG6enpaDQali5dipubG6B25fXt25f58+fj6OhIq1ataNWqlemcNm3a0KRJE7744gs+z2YswaRJk5g4caLpenx8PL6+vnTp0iVfT7ZerycsLAx7wzgpz7Jlad29e6bjkk6cQH/2LIk6HT7R0QB4OThAYiJlDINEfUaNwvvpp9kZFES7rl1xr1PHFD8wMBCdWTddQZH4El/i5yN+ZCR89BHpo0djZ9iEt61Oh2LshvPyAm/vQqt/j5kz8xU/rm1btgwcCKiJU/1Onahu1uX/xD7/El/iA7GxsQUeE/KYLCmKwrBhw7A3m3qalJTE6NGjLZYP+Omnnx4Zy8PDA1tbW6KioizKo6OjKV++fJbneHt74+PjY0qUAOrUqYOiKFy/fj3LliMbGxuaN2/OOcMWIlmxt7e3eExGOp3usV5MY9Jno9FkGef25MmUz9D03dh8p3PAuWVL7P39qRcUhIu3t0Wcx63fo0h8iS/x8xD/u+8gQwu11nw7oilTLBa/fOLqb6A1fFGr3r8/51et4sjMmTiWLUvlDF/4ntT6S/x/d3xr1dkmLwcPHTqUcuXK4ebmZrq89NJLVKhQwaIsN+zs7GjatClhYWEW5WFhYRbdcubatGlDREQE9+/fN5WdPXsWGxsbKmazw7eiKBw9ehTvxxhkmV+P6t90nTWLu6tXEx0YaCqL7NaNvwxdmgpg36CBaZaMDLAU4gk2ahQcOqRe3nrrYfnkyWrZqFFFV7c8MA4qrzdmDDUGDgRFYe+kSURmM5ZUiH+DPLUsLV68uEDvfOLEiQwZMoRmzZoREBDAwoULuXr1KqNHjwbU7rEbN27w/fffAzBo0CA+/PBDhg8fzrRp07h16xZvv/02r7zyimmA97Rp02jVqhU1atQgPj6ezz//nKNHjzJ//vwCrXuuGLsTsxkW5livHo716hGzZImpzKlKFSrVrg3z5qGpXBlH4waeQognm7e35cy32bPVn59+Cs8991iz4gqT+RIGTSdNIjkujqubN7Nz3Dg6LV6MrmxZUrZsIbF5c3Ty+ST+JfLUslTQBgwYQHBwMNOnT6dRo0bs2LGDTZs24efnB0BkZCRXr141HV+qVCnCwsK4c+cOzZo1Y/DgwfTq1ctiLNKdO3d47bXXqFOnDl26dOHGjRvs2LGDFi1aFPrjy7gbebaH3bxp+t3u7l2qG2fuFcHAUCFEAWrXDlJSoG9fKIZbkNjY2hIwYwZeAQGkJiaybfRoYo8dQ//XXyTdulXU1ROi0ORrBe+CFBQURFBQUJa3hYaGZiqrXbt2pq47c/PmzWPevHkFVb2C8YgJh7ZmA9J0iYlw4YJ6pWpVa9ZKCGEtxg13BwyAHj3g0iV4+WXYsKGoa5ZntnZ2tPvsM/4cPpzbJ09y2LAGXkHs4CBEcVGkLUslnnFRykccpr179+HvsbFw8aJ6RZIlIYon44a7deqoW6LY28Ovv8KsWUVds3xJTUig4YQJOHl7k2z4crdr3DgO/O9/3Nixg8SYmCKuoRDWJclSYXjENzA7swHrnD0ryZIQJUnjxvDll+rvkyej2batSKuTH+dWrWLryJEkREaaypJv3eLcsmVsHzOGPwYP5uKGDegfPLA4LzEmhuPz50syJYo9SZasKFd7w6WmYme2ejiRkXDypPq7JEtClAwjRsDQoZCeju1LL+Fw+3ZR1yhPavTvzzOrV/PM6tU0/eADAPx69cK9Th0AHty4wd733uOn9u35e9IkovbsIT0tzbQpryRLorgr8jFLJVrG2XCRkZn2i1KiotAA6YDG3R1NXBzcuaMeLwO8hSgZNBoICYEjR9AcP06zTz9VxzNZcR2bgmS+N5xxEeIagwZRrkED7l+/zqVffuHSzz9z/+pVLv/8M5d//hnH8uXxMlsgWIjiTFqWrCnjmKXISHXROrOmbP3ZswAkarVgvpVJ6dLg7l449RRCWJ+TE6xZg+LiQtlTp7B5//38x4qMVMdEmX2WFJVSFStSf8wYem3aRODSpVTu3RutszOJN29yyTCg/dhnnxFz5Ai3w8OllUkUS5IsFQZjy1IW28LoDSuLJ9vbo6lV6+EN0gUnRMlTowZp334LgO3cubBuXf7iZPHFq7A4eHig69gRhwwbBGs0GjwbNaJUxYqkZhi7FLlrF2EvvcTmfv04t2pVYVZXiAIhyZIVGccs2cfFwYED0KePesPBg3D4MBw+TPqJEwCklCoF5tu1FJMF7IQQeaM89xzne/dWrwwbBrt3W6eVyEqtT46enth17pztjgLm45taGLZ/sTPb2eHW0aM8iIgo0DoJYW0yZsmaDMmS39atYL4optm2B7p69QDQu7lZJktlyxZKFYUQhS/85ZepGhuLze7dasJ0/jz07m35JUmvhxs34PJluHIFTpxQZ8tGRoJxsd533oGnn1aXKGjZEnx8Hp4fFaW2PmWMa2Xm45uM2n/5JTe2bePUkiVE/f03v/bqRb3Ro6k9dCi2GTZnF+JJJMlSIbjaoQOVJk6EXr3UgrlzoX17AFJefx0HIK1MGctkybA/nBCi5FG0WtKWLsWmRQs1UQKYPx+Sk9XE6MoVNVFKT8850JYt6gXAzg4CArBp3BgfGxt4nMHVWUxGeRy2Dg40mjiRyr17c/DDD4k+eJBjwcFc/uUXmr3/PuWbN3/s+xDCmiRZsiZDy1KymxsYtnAB1G+BTZqov8fHA6CzswPzfv6EBLWrDjLvOSWEKNbsb9+GmzfVlp+gIHVc43ffZT7Qzg4qVYLKlcHTE9zc1M+Cu3fVL10dOsCtW3DmjLqtyvbt2G7fTjPzGB98AK++qn4BM/8sySkhMo6JesxWKeOmvMaWptLVq9MpNJRLP//MkdmzuXvhAn8OG0aV3r1p/NZbOEiLunhCyZilwmK+8KReb/rVuNWJz44d8NRTD4+ZNw+aNlUvX39dWLUUQhSCyr//jq5lSxgzJutFa0eMgIgISEyEc+cgLAyWLYMFC9TkZ/Bg9bjZs+H4cfWL1rFjanKT0caN8Oyz6mfJmDEPP4seY5C4/e3b2Eyf/shzjZvymnfLaTQaqvbpQ89ffqF6//6g0XDp55/5pWdPzq1cifKo1jQhioC0LFmT+TpL9+49LDcb7KgzbHUSOXYs3q+8Atu2wX/+A99887D1SVqVhChRLnftSrWJE9FptWoL8quvZn7P5+V9r9VCgwbw1VfoJ09m965dtLWzQ/vGG+DvD+Hh6nEbNqhx+/WD1q3VsnPnIDZWbZ26cAFu3364P+WaNeosXq3Wok4OcXHYfvQRPPecWpZVK9UjuvLsS5emxZQpVH3uOQ5Mm0bc6dMcmD6dCz/9RNrTT+fjWRXCeiRZsiKLFbzNW5ZKl1Z/6vXqxrlAWrt2Dz8oQf3d/LoQosRILlNG3QbFfFHKvLznjRv1ZkxCvL3Bw4O7kZEoxtt++EHtwvv+e/j2W3XA+OLF6gXgxRezv58ZM9QLQOfO8PHHYJiUYiGrbrtcduV5NGhA15UrObdiBcc+/5zbJ07AyZMciY2l0ZtvYufikrvnRAgrkmSpEGgytiwZtze5edO0erddlSpFUTUhRHFk3Kg3t3x9YfJkdVzT9OnZH1etmjqr7t49+OUXdSHNhAT1NsNgcq2zM42NayxNn66OwTR+GTxzRk3M8jj2yEarpdZLL+HbpQuHZs7k2ubNnF++nOSVKwm4eRPbH39E06VLnmIKUZAkWbKm7FqWjMmSYa2RRK0We+OHT3bfGIUQJZO13vNeXpnjjh79cL23AwfU61l1/x0+rCZL27erXXBbt8JXX8HZs2gePMDNOBllwwb1YjRo0MPftYZ/LytXWj5WeNg9Z/67tzdO5crR6pNPiPH2Rvvnn7gcPIj21i0Sn3+etFWrKHXlCkyYQGJyMg5Ako0NjmlpBfaUCZEdSZYKQ8aWpZQUANKuXsUWNVlyNX4Ty+s3RiFE8Wat93xWcbMaC5VT95+NDTRqpF5efBGuX0cfHs7Nb7+l4q5dOd+/cceCWbPUC6iD0/v0edg9FxOj/h4QoN7+9dfwyivY1qhBl9GjSWjXDm7dwvHBAy4OHIhTfDw2qP+4NIBWBoOLQiLJkjU9omUp7cIFNVmys6Osq2vh1k0IIbKTVWuXMdFq1IjzsbFqsvTjj2o3nHGQ+qefqsckJsLp0zBnDtjagrH1Z8MGKFVK/f3cOXX8FKjLHxjHOLm40GztWuzGjMHBbLadjyFREqIoFPnfXkhICFWqVMHBwYGmTZuyc+fOHI9PTk5m8uTJ+Pn5YW9vT7Vq1fguw/oka9euxd/fH3t7e/z9/VmX3/2XHpdxI90MLUuX168nMSaGNMMHRbK9PUm3bhVFDYUQ/1Y5df8ZW6Ue1TVoXDPO2DLVsaO6rMHIkQ+75H79VU2k7O3V5Q3+7//U8hdfhHffVX//+mt13ShA+9Zb+OzZg02GZQnszX63Nfup12jQazQk2toihLUUabK0cuVKxo8fz+TJkzly5Ajt2rWjW7duXDUu5Z+F/v378+eff7Jo0SLOnDnD8uXLqV27tun2PXv2MGDAAIYMGcKxY8cYMmQI/fv3Z9++fYXxkCxYrJ5i1rJ0feNGEmNiSL92DYAHIDtxCyEKV24ToiwkubuT9t//5u7ccuWgQoWHYzWzsnMnLF0KYJr0khMbs586w8VBuuSEFRVpN9zcuXMZMWIEI0eOBCA4OJjff/+dBQsWMMM4XdXM5s2b2b59OxcvXqRMmTIAVK5c2eKY4OBgAgMDmTRpEgCTJk1i+/btBAcHs3z5cus+oIyyWWfJxrAIncbwzSlRK72hQojiI7lMGdJfeglb49IH2XXbGctGjXq4YOa776qLbOYgt9/i0wHj8O5UGxsc8/IghMiDIvsvnZKSwqFDh3jX2Axr0KVLF/7+++8sz/n5559p1qwZs2bN4ocffsDZ2ZnevXvz4Ycf4uiovk327NnDhAkTLM7r2rUrwcHB2dYlOTmZZLNvPfGGLUj0ej16s9W2c8t4jmJIitJSUki+e9fUjGyjKFz85RdqG1qWErVaYv75h1TDgEgHD49sd/Q2j5+fuuWl/hJf4kt8iZ+r+B4e6tIE6g2Zy4zXAcaPRxcWhn7JEjSHDqH9/HNSX3kFvLzQfvwxycOGYRcaitmIz0wU1BaoNDBNmNFmrFNe6l+AJP6TEb+gFVmydOvWLdLS0ihfvrxFefny5YmKisrynIsXL7Jr1y4cHBxYt24dt27dIigoiNu3b5vGLUVFReUpJsCMGTOYNm1apvI//vgDJyenvD40kwcJCbgBcdeuUfrKFcoZym0UhbPff0/d27cBSNTpOGS29omuY0fsOnd+ZPywR3w7e1wSX+JLfIlf0PHdLlzgaWD3rVuUsrWlGXDUzY37ZcvyNLCnfn3KP/885Y4fxykqCkfDEIY0Ho5VSkXtegPYtGlTodZf4j/Z8ROM64IVsCLv/9FoLL8/KIqSqcwoPT0djUbD0qVLcTNsGTJ37lz69u3L/PnzTa1LeYkJalfdxIkTTdfj4+Px9fWlS5cuuOZjlpperycsLAxnw6wP94oVcVcUdcE2wFZRqNy9O46GLQgStVqafvAB7nXqALlrWQoLCyMwMBCd+QrABUTiS3yJL/GtFj8ykrS4ONr07Qv//APz5tGwUyd1MUugZcuW/FGtGn6BgWhnz1a78oB0R0dsExNRNBr0iqK2JNnY0L1798Ktv8R/ouPHGvZbLWhFlix5eHhga2ubqcUnOjo6U8uQkbe3Nz4+PqZECaBOnTooisL169epUaMGXl5eeYoJYG9vj729faZynU73eC+mIUHT6nTojGuOoLYseRvGWqUDyba2eNavTxl//zyFf+z6SXyJL/ElfmHHr1QJPvxQbSXS6WDKFHTG2XRTpqD19YVbt9T4AQHq4papqejKlIFbt9DMm4fTmDEA5L/d/wl+fiT+Y8e1hiKbDWdnZ0fTpk0zNcWFhYXR2rjBYwZt2rQhIiKC+2Yzy86ePYuNjQ0VK1YEICAgIFPMP/74I9uYVpXNOku2ioImOhowDO7OodVLCCFKLPMZeVnNzgsMhLffVj8jX34ZkpLAkCgJUZiKdOmAiRMn8u233/Ldd99x6tQpJkyYwNWrVxk9ejSgdo+9/PLLpuMHDRpE2bJlGT58OOHh4ezYsYO3336bV155xdQF9+abb/LHH38wc+ZMTp8+zcyZM9myZQvjx48vioeoymI2nL2hXzVRq6Vyz545drsJIcS/1scfQ3q6+lOIIlKkY5YGDBhAbGws06dPJzIyknr16rFp0yb8/PwAiIyMtFhzqVSpUoSFhfHGG2/QrFkzypYtS//+/fnoo49Mx7Ru3ZoVK1bw3//+l/fff59q1aqxcuVKWrZsWeiPz7QoZXr6w80oUZMlnaGlKVGno9aQIZIsCSGEEE+oIh/gHRQURFBQUJa3hYaGZiqrXbv2I0fR9+3bl759+xZE9R6PIVmyNUxtNbJVFGzMuuHcS5cu7JoJIYQQIpeKfLuTkkzJJlmyyTBmyc5swLoQQgghniySLBUC2wzL/NuYtSwl2dmhM24sKYQQQognjiRL1pRDy5KtYUFKvZtbjmtACSGEEKJoSbJkTcZkKUPLkm16OnaG2XFphj3uhBBCCPFkkmSpEGRsWdIqCnaGBCq9XLmsThFCCCHEE0KSJWvKpmXJybDRXxqQLoO7hRBCiCeaJEtWpBh+ZmxZcjZcT9JqsclimxUhhBBCPDkkWbKmDC1L6XZ2AOgUNY1K1Omwc3YumroJIYQQIleKfFHKEs2QLNkYWpL0jo7Ym7UyJWq1pCYlcTs8HABHT09ZyVsIIYR4wkiyVAi0hgQpWaPBvNMtUavlxtat3Ni6FYB6QUE0GDu2CGoohBBCiOxIsmRNGdZPSnd1hTt3TNcTtVqqPv88NQcOBJBWJSGEEOIJJMmSFSkZrusdHCyuJ+p0uNWoQRl//8KrlBBCCCHyRAZ4W1OGlqUUnc7ieqJWi04GeAshhBBPNEmWrClDspRsa2txPVGrpZSPT2HWSAghhBB5JMlSIUqxsXy6E7VaXPz8iqg2QgghhMgNSZasKUPLUpLZ9TTUliY7F5dCrpQQQggh8kKSpUKUaPZ7kk6HxtYWrZNTkdVHCCGEEI8myZIVKRlbltLTTb8narVoS5VCYyMvgRBCCPEkk//U1pQhWUpMS3v4u1aL1tGxsGskhBBCiDySZKkQJZglSyk2Ntga9ooTQgghxJNLkiVrytCypAeMHXGpGo0kS0IIIUQxIMlSIVGcnFA0GlOylKzVYiPJkhBCCPHEk2TJmsxbluzscE9MNJXZpafjdv8+HD4MkZFFVEEhhBBCPIokS1ZkPhtOc+cO3S5dQquoO8bVvn2b1r//Dk2bwtdfF1UVhRBCCPEIspGuNZklS6l+foTZ2FA1PZ1aV66wz9ub9AYNCPj4Y/D2LsJKCiGEECIn0rJUSNLd3YlzdOSmYS+42w4OPPDygiZNJFkSQgghnmDSsmRN5i1Lxk10zcsSErgdHg6Ao6cnjp6ehVo9IYQQQjyatCwVkgf37gFwKzqafzw8SNRquX3yJJv79WNzv36cW7WqiGsohBBCiKxIy5IVmQ/wtvP2hpgYnJs2xTYwkKQ5c2gxdSpl6tYFkFYlIYQQ4gklyZI1mSVLimHDXEcPD7xatQKgTN26lPH3L5KqCSGEECJ3pBuukKRq1bzU1sGhiGsihBBCiLyQZMmazFqW0gzJktbREUdPT+oFBUnXmxBCCFEMSDdcIdHbqHmprSFZajB2bBHXSAghhBC5IS1LVmQ+wFtv+F0r3XBCCCFEsSLJkjVllSw5OhZVbYQQQgiRD5IsFRK94acM8BZCCCGKF0mWrMm8Zcmwga7WsISAEEIIIYoHSZYKSXJ6OiBjloQQQojiRpIlazJrWUoxJEvSDSeEEEIUL5IsWZH5bLjk1FRABngLIYQQxY0kS4UkRZIlIYQQoliSZMmaDC1L6TY2pCQnA5IsCSGEEMWNJEuFIN3OjtSkJEDGLAkhhBDFjSRL1mRoWUqzsyM1MRGQliUhhBCiuJFkyZqMyZJOR3pKCqDuDSeEEEKI4kOSJStSDD819+/joFfX8Nbfv190FRJCCCFEnkmyZE2GliXH5GQcDbPhUuLji7JGQgghhMgjSZasyWydpYdFmcuEEEII8eTSFnUFSqKkEydw2bMH5do1U1kZw2y4W6Gh6Nu0QVejBo6enjh6ehZVNYUQQgiRC5IsWcGD996j4+bNFmUtIyPVXz79lH8WL+afcuWoFxREg7Fji6CGQgghhMgtSZaswPnjj/mrYUPKxsSQ9NtvtIyMZJ+3N7cdHKjWty/l2rThGUPLkhBCCCGebJIsWYFDvXrcu3oVz5s3ub11KwC3HRyIc3TEY9gwyvj7F3ENhRBCCJFbMsBbCCGEECIHkixZWaJWyz8eHiRqtZSqVEm63oQQQohiRrrhrCxJp+OfcuUA8K1VS5IlIYQQopiRlqVCJFudCCGEEMWPJEuFSDbRFUIIIYofSZYKkdbBoairIIQQQog8kmSpEEnLkhBCCFH8SLJUiGylZUkIIYQodiRZKkTa/2/vzoOauhM4gH8DIRBuORQUBI8V0XpVVI6u1NEFV2ux1l2qWGU9dq2tYh21uGxFq6tjDy0eqEXAtgvqDkeLq7bqVBC1i0fBqqhYgQoad71QEWs9fvuHS2yaEExIXox+PzOZMS/vPb48A+87v997wdHR0hGIiIjIQCxLEuI1S0RERNaHZUlCnIYjIiKyPixLEuIF3kRERNaHZUlCLEtERETWh2VJQvwEbyIiIuvDsiQhXuBNRERkfViWJMRpOCIiIuvDsiQhTsMRERFZH5YlCXEajoiIyPqwLEmI03BERETWh2VJIjK5HDZ2dpaOQURERAZiWZIIR5WIiIisE8uSRHi9EhERkXViWZII74QjIiKyTixLEuHIEhERkXViWZIIR5aIiIisE8uSRHiBNxERkXViWZIIp+GIiIisE8uSRDiyREREZJ1YliTCa5aIiIisE8uSRDiyREREZJ1YliTCa5aIiIisE8uSRGxZloiIiKwSy5JE5I6Olo5ARERERmBZkgin4YiIiKwTy5JEeDccERGRdWJZkghHloiIiKwTy5JEeM0SERGRdWJZkgjvhiMiIrJOLEsS4TQcERGRdWJZkgg/wZuIiMg6sSxJhHfDERERWSeWJYlwZImIiMg6sSxJhNcsERERWSeWJYnwbjgiIiLrxLIkAVsHB8hseKiJiIisEc/gEuAUHBERkfViWZIA74QjIiKyXixLEuCdcERERNaLZUkCLEtERETWi2VJAj9dvYrbly5ZOgYREREZgWVJAg0qFcsSERGRlWJZIiIiItJDbukAT6Pbly7h/vnzuH31qnrZ1fJy9b+V3t5QentbIhoREREZiGXJDCpzcvDT+vX44RfLDiYnq//93LRp6Pnmm9IHIyIiIoOxLJlBx9GjUSmX44UXXsCNigocTE5G/4UL4dGtGwBwVImIiMiKsCyZgdLbG7bt2qFVcDDk8oeH2KNbN3VZIiIiIuvBC7yJiIiI9GBZMjOltzeemzaNU29ERERWitNwZqb09ubF3ERERFaMI0tEREREerAsEREREenBskRERESkB8sSERERkR4sS0RERER6sCwRERER6cGyRERERKQHyxIRERGRHixLRERERHqwLBERERHpwT93ooMQAgBw48YNo7a/e/cuGhoacOPGDdjZ2ZkyGvfP/XP/3D/3z/1z/024efMmgEfncVNhWdKh8WD7+/tbOAkREREZ6sqVK3BzczPZ/mTC1PXrKfDgwQNcuHABLi4ukMlkBm9/48YN+Pv7o6amBq6urmZICPTr1w+HDh0yy76Zv3nM3zTmbx7zN435m8f8Tbt+/Trat2+Pa9euwd3d3WT75ciSDjY2NvDz82vxflxdXc32ZrO1tTXbvhsxf9OYv3nM3zTm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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "logreg_preds = get_preds(external_X, logreg_estimators, use_proba=True)\n",
    "ens_preds_pca, mp_pca, sp_pca = aggregate_preds(logreg_preds, use_bernoulli_std=True)\n",
    "threshs = sp_pca\n",
    "ens_preds = ens_preds_pca\n",
    "std_threshs = np.linspace(np.min(threshs), np.max(threshs), 100)\n",
    "reject_rate = [1 - np.mean((threshs<=s)) for s in std_threshs]\n",
    "accus = [np.mean((ens_preds==external_Y)[(threshs<=s)]) for s in std_threshs]\n",
    "tps = [np.sum(((external_Y)*(ens_preds==external_Y))[(threshs<=s)]) for s in std_threshs]  # correct and positive\n",
    "fps = [np.sum(((ens_preds)*(ens_preds!=external_Y))[(threshs<=s)]) for s in std_threshs]  # incorrect and predicted positive\n",
    "pos = np.sum(external_Y)\n",
    "recall = [tp/pos for tp in tps]\n",
    "precision = [tp/(tp+fp) for tp, fp in zip(tps, fps)]\n",
    "plt.plot(recall, precision, marker='+', c='brown')\n",
    "\n",
    "ens_preds_pca, mp_pca, sp_pca = aggregate_preds(logreg_preds, use_bernoulli_std=False)\n",
    "threshs = sp_pca\n",
    "ens_preds = ens_preds_pca\n",
    "std_threshs = np.linspace(np.min(threshs), np.max(threshs), 100)\n",
    "reject_rate = [1 - np.mean((threshs<=s)) for s in std_threshs]\n",
    "accus = [np.mean((ens_preds==external_Y)[(threshs<=s)]) for s in std_threshs]\n",
    "tps = [np.sum(((external_Y)*(ens_preds==external_Y))[(threshs<=s)]) for s in std_threshs]  # correct and positive\n",
    "fps = [np.sum(((ens_preds)*(ens_preds!=external_Y))[(threshs<=s)]) for s in std_threshs]  # incorrect and predicted positive\n",
    "pos = np.sum(external_Y)\n",
    "recall = [tp/pos for tp in tps]\n",
    "precision = [tp/(tp+fp) for tp, fp in zip(tps, fps)]\n",
    "plt.plot(recall, precision, marker='+', c='red')\n",
    "\n",
    "plt.xticks(np.arange(0, 1.01, step=0.1))\n",
    "plt.xticks(np.arange(0, 1.01, step=0.05), minor=True)\n",
    "plt.yticks(np.arange(0.6, 1.01, step=0.05))\n",
    "plt.grid(True, which='both')\n",
    "plt.xlabel('Recall ({} Positive)'.format(int(pos)))\n",
    "plt.ylabel('Precision')\n",
    "plt.title('Precision vs Recall by Thresholding Ensemble Std')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 489
    },
    "id": "8dgeMjX7qDPO",
    "outputId": "26690811-9d9f-4164-c851-d78852011cbf"
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7f39a445e5d0>"
      ]
     },
     "execution_count": 28,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAksAAAHFCAYAAADi7703AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy81sbWrAAAACXBIWXMAAA9hAAAPYQGoP6dpAAB0+0lEQVR4nO3deViU1dsH8O+wb4KyCAgIigvgLriAuaAiuWsqpIZLWBnmRpmSuZdbqWiJZamYP1FzzdRULBfcN9AU9w0VUEQRlMUBzvuH8byODCPgwIz4/VzXXDVnznPOfc8wcPss55EJIQSIiIiISCkdTQdAREREpM1YLBERERGpwGKJiIiISAUWS0REREQqsFgiIiIiUoHFEhEREZEKLJaIiIiIVGCxRERERKQCiyUiIiIiFVgsVQCRkZGQyWTSQ09PD46Ojhg6dCju3r1b7vEMGTIELi4uJdrm5s2bkMlkiIyMLJOYNGnIkCEKn4+BgQFcXV3xxRdfID09XdPhKX3vC36mbt68qXLbqVOnQiaT4cGDB2US2759+xTeO1WP8oinpMoinnbt2qFdu3av7Kfscy2IRxMK5i7q8aqfNW1X8J05efLkK/uW5nfkqxw7dgy9e/dG9erVYWhoCFtbW3h7e+Pzzz9X6BcREVGi37MF38F9+/apNd43jZ6mAyD1WbFiBdzc3JCVlYUDBw5g1qxZ2L9/P/7991+YmpqWWxyTJk3C6NGjS7SNvb09jhw5AldX1zKKSrOMjY3xzz//AADS0tKwYcMGzJs3D2fPnsXu3bs1HJ32atq0KY4cOaLQ1rt3b7i6uuL777/XUFRvrmHDhuHdd9/VaAw7d+6EhYVFoXZ7e3sNRFMxbN++HT169EC7du0wd+5c2NvbIykpCSdPnsTatWsxb948qW9ERASsra0xZMgQzQX8BmKxVIHUr18fXl5eAABfX1/k5eVhxowZ2LJlCwYOHKh0m8zMTJiYmKg1jtIUPIaGhmjZsqVa49AmOjo6Cvm9++67uH79OqKjo3Hjxg3UqFFDg9FpL3Nz80I/F4aGhqhcubLaf16EEMjOzoaxsbFax9Umjo6OcHR01GgMnp6esLa21mgMFc3cuXNRo0YN7Nq1C3p6//9n/f3338fcuXM1GFnFwcNwFVjBH5Nbt24BeL7r18zMDP/++y86deqESpUqoUOHDgCAZ8+e4ZtvvoGbmxsMDQ1hY2ODoUOHIiUlpdC4UVFR8Pb2hpmZGczMzNC4cWMsW7ZMel3ZLub169ejRYsWsLCwgImJCWrWrIkPP/xQer2ow3AHDx5Ehw4dUKlSJZiYmMDHxwfbt29X6FOw+3vv3r349NNPYW1tDSsrK7z33ntITExU+R6Fh4dDJpPh6tWrhV4bP348DAwMpEMosbGx6NatG6pWrQpDQ0NUq1YNXbt2xZ07d1TOUZSCwvbevXsK7evWrYO3tzdMTU1hZmYGf39/xMbGFtr+2LFj6N69O6ysrGBkZARXV1eMGTNGev3q1asYOnQoateuDRMTEzg4OKB79+74999/SxWvKrdv38Z7770Hc3NzWFhY4IMPPlD42QkODoalpSUyMzMLbdu+fXvUq1dPrfHcu3cP/fv3h4WFBWxtbfHhhx/i8ePHCn1kMhk+++wz/PTTT3B3d4ehoSFWrlwJALhy5QoGDBggfdbu7u5YvHixwvb5+fn45ptvULduXRgbG6Ny5cpo2LAhFi5cWKp4srOzERYWhho1asDAwAAODg4YMWIE0tLSXplvYmIiAgICUKlSJVhYWCAwMBDJycmF+ik7DOfi4oJu3bph586daNq0KYyNjeHm5obly5cX2v7gwYPw9vaGkZERHBwcMGnSJPz6669qPYxW8Lvg+++/x/z581GjRg2YmZnB29sbR48eVeh7/fp1vP/++6hWrZp06KlDhw6Ii4tT6Fec71TB78eLFy/C398fpqamsLe3x+zZswEAR48exTvvvANTU1PUqVNH+ll52aNHjzB06FBYWlrC1NQU3bt3x/Xr11+ZtxACERERaNy4MYyNjVGlShX07du3WNumpqbC2tpaoVAqoKPz/3/mXVxccP78eezfv186/Pni7+qLFy/i3XffhYmJCaytrTF8+HBkZGS8cv63AYulCqygALCxsZHanj17hh49eqB9+/b4448/MG3aNOTn56Nnz56YPXs2BgwYgO3bt2P27NmIjo5Gu3btkJWVJW0/efJkDBw4ENWqVUNkZCQ2b96MwYMHSwWZMkeOHEFgYCBq1qyJtWvXYvv27Zg8eTJyc3NVxr9//360b98ejx8/xrJly7BmzRpUqlQJ3bt3x7p16wr1HzZsGPT19REVFYW5c+di3759+OCDD1TO8cEHH8DAwKBQkZaXl4f//e9/6N69O6ytrfH06VP4+fnh3r17WLx4MaKjoxEeHo7q1auX+pfJjRs3oKenh5o1a0ptM2fORP/+/eHh4YHff/8dq1atQkZGBlq3bo34+Hip365du9C6dWskJCRg/vz5+Ouvv/D1118rFF6JiYmwsrLC7NmzsXPnTixevBh6enpo0aIFLl26VKqYi9K7d2/UqlULGzZswNSpU7Flyxb4+/tDLpcDAEaPHo1Hjx4hKipKYbv4+Hjs3bsXI0aMUGs8ffr0QZ06dbBx40ZMmDABUVFRGDt2bKF+W7ZswZIlSzB58mTpPY2Pj0ezZs1w7tw5zJs3D9u2bUPXrl0xatQoTJs2Tdp27ty5mDp1Kvr374/t27dj3bp1CA4OVlrcvCoeIQR69eqF77//HkFBQdi+fTtCQ0OxcuVKtG/fHjk5OUXmmpWVhY4dO2L37t2YNWsW1q9fDzs7OwQGBhb7/Tpz5gw+//xzjB07Fn/88QcaNmyI4OBgHDhwQOpz9uxZ+Pn5ITMzEytXrsRPP/2E06dP49tvvy32PMDz71Zubq7CIy8vr1C/F79nq1evxtOnT9GlSxeFIrNLly44deoU5s6di+joaCxZsgRNmjRR+AyK+50CALlcjvfeew9du3bFH3/8gc6dOyMsLAxfffUVBg8ejA8//BCbN29G3bp1MWTIEJw6dapQ3MHBwdDR0UFUVBTCw8Nx/PhxtGvX7pVF7yeffIIxY8agY8eO2LJlCyIiInD+/Hn4+PgU+gfVy7y9vXHs2DGMGjUKx44dk753L9u8eTNq1qyJJk2a4MiRIzhy5Ag2b94M4HlB37ZtW5w7dw4RERFYtWoVnjx5gs8++0zl3G8NQW+8FStWCADi6NGjQi6Xi4yMDLFt2zZhY2MjKlWqJJKTk4UQQgwePFgAEMuXL1fYfs2aNQKA2Lhxo0L7iRMnBAAREREhhBDi+vXrQldXVwwcOFBlPIMHDxbOzs7S8++//14AEGlpaUVuc+PGDQFArFixQmpr2bKlqFq1qsjIyJDacnNzRf369YWjo6PIz89XyD8kJERhzLlz5woAIikpSWW87733nnB0dBR5eXlS244dOwQA8eeffwohhDh58qQAILZs2aJyLGUGDx4sTE1NhVwuF3K5XDx48EAsWbJE6OjoiK+++krql5CQIPT09MTIkSMVts/IyBB2dnYiICBAanN1dRWurq4iKyur2HHk5uaKZ8+eidq1a4uxY8dK7cre+4L39MaNGyrHnDJligCgMJ4QQqxevVoAEP/73/+ktrZt24rGjRsr9Pv000+Fubm5wmf8Ks7OzqJr164q45k7d65Ce0hIiDAyMpJ+ZoQQAoCwsLAQDx8+VOjr7+8vHB0dxePHjxXaP/vsM2FkZCT179atW6F8ShvPzp07lfZbt26dACCWLl0qtbVt21a0bdtWer5kyRIBQPzxxx8K23700UeFPteCeF7k7OwsjIyMxK1bt6S2rKwsYWlpKT755BOprV+/fsLU1FSkpKRIbXl5ecLDw6NEPyvKHq6urlK/gp/HBg0aiNzcXKn9+PHjAoBYs2aNEEKIBw8eCAAiPDy8yDlL8p0q+P344u9BuVwubGxsBABx+vRpqT01NVXo6uqK0NBQqa3gO9O7d2+FuQ4dOiQAiG+++UZhrhd/Rx45ckQAEPPmzVPY9vbt28LY2Fh8+eWXReZY8F6888470vupr68vfHx8xKxZswp9t+rVq6fw81Ng/PjxQiaTibi4OIV2Pz8/AUDs3btXZQwVHfcsVSAtW7aEvr4+KlWqhG7dusHOzg5//fUXbG1tFfr16dNH4fm2bdtQuXJldO/eXeFfe40bN4adnZ10FUR0dDTy8vJKvBegWbNmAICAgAD8/vvvxbpC7+nTpzh27Bj69u0LMzMzqV1XVxdBQUG4c+dOob0jPXr0UHjesGFDAFC51wsAhg4dijt37mDPnj1S24oVK2BnZ4fOnTsDAGrVqoUqVapg/Pjx+Omnnwr9i7Q4+ejr60NfXx/W1tb49NNPERgYqPCv8l27diE3NxeDBg1S+ByMjIzQtm1b6XO4fPkyrl27huDgYBgZGRU5Z25uLmbOnAkPDw8YGBhAT08PBgYGuHLlCi5cuFCi+F/l5XPiAgICoKenh71790pto0ePRlxcHA4dOgQASE9Px6pVqzB48GCFz1gdlP0sZGdn4/79+wrt7du3R5UqVaTn2dnZ+Pvvv9G7d2+YmJgofA5dunRBdna2dCioefPmOHPmDEJCQrBr1y6VVza+Kp6Ck/9fPum2X79+MDU1xd9//13k2Hv37kWlSpUKzTFgwIAit3lZ48aNUb16dem5kZER6tSpo/DdKdjT++L5Rjo6OggICCj2PACwZ88enDhxQuGxZcuWQv26du0KXV1d6fnL32dLS0u4urriu+++w/z58xEbG4v8/HyFMYr7nSogk8nQpUsX6bmenh5q1aoFe3t7NGnSRGq3tLRE1apVlf5uefm74OPjA2dnZ4Xvwsu2bdsGmUyGDz74QCFOOzs7NGrU6JVXollZWSEmJgYnTpzA7Nmz0bNnT1y+fBlhYWFo0KBBsa7G3Lt3L+rVq4dGjRoptJfk56giY7FUgfz22284ceIEYmNjkZiYiLNnz6JVq1YKfUxMTGBubq7Qdu/ePaSlpcHAwED6g17wSE5Olr5oBeeglPQE0TZt2mDLli3SLy1HR0fUr18fa9asKXKbR48eQQih9AqZatWqAXh+nP5FVlZWCs8NDQ0BQOEwojKdO3eGvb09VqxYIc29detWDBo0SPplbWFhgf3796Nx48b46quvUK9ePVSrVg1Tpkwpcpf3i4yNjaU/DH/++SfatWuHNWvWSOdDAP9/7lKzZs0KfQ7r1q0r8ecQGhqKSZMmoVevXvjzzz9x7NgxnDhxAo0aNXrle1JSdnZ2Cs/19PRgZWWl8Bn17NkTLi4u0rk/kZGRePr0qdoPwQHF/1l4+ecrNTUVubm5+OGHHwp9BgV/RAs+h7CwMHz//fc4evQoOnfuDCsrK3To0EHppeOviic1NRV6enoKh8yB53+87ezsCv2svxzzy/8gAgp/Jqq8HF9BjC++X0XNo6xNlUaNGsHLy0vhUb9+/VfG9PJ7JpPJ8Pfff8Pf3x9z585F06ZNYWNjg1GjRkmHxov7nSpgYmJS6B8gBgYGsLS0LBSfgYEBsrOzC7Ure99f9Rneu3cPQgjY2toWivPo0aPFXnrCy8sL48ePx/r165GYmIixY8fi5s2bxTrJOzU1tcjYiVfDVSju7u7SScNFUbbGSsEJ0Tt37lS6TaVKlQD8/7lPd+7cgZOTU4li69mzJ3r27ImcnBwcPXoUs2bNwoABA+Di4gJvb+9C/atUqQIdHR0kJSUVeq3gpG11XVFTsLdq0aJFSEtLQ1RUFHJycjB06FCFfg0aNMDatWshhMDZs2cRGRmJ6dOnw9jYGBMmTFA5h46OjsJn4+fnB09PT0ybNg0DBw6Ek5OTlM+GDRvg7Oxc5Fgvfg6q/O9//8OgQYMwc+ZMhfYHDx6gcuXKKrctqeTkZDg4OEjPc3NzkZqaqvAHT0dHByNGjMBXX32FefPmISIiAh06dEDdunXVGktJvPx9qFKlivTzUFQRV3Dlop6eHkJDQxEaGoq0tDTs2bMHX331Ffz9/XH79u0SXWVqZWWF3NxcpKSkKBRMQggkJydLe2eL2vb48eOF2pWd4P06rKyslJ47o+55SsLZ2Vm6uOTy5cv4/fffMXXqVDx79gw//fRTsb9T6qTs/UhOTkatWrWK3Mba2hoymQwxMTFSUfgiZW2voq+vjylTpmDBggU4d+7cK/tbWVkVGTtxzxIB6NatG1JTU5GXl1foX3xeXl7SH7NOnTpBV1cXS5YsKfVchoaGaNu2LebMmQMASq/yAgBTU1O0aNECmzZtUvjXbX5+Pv73v//B0dERderUKXUcLxs6dCiys7OxZs0aREZGwtvbG25ubkr7ymQyNGrUCAsWLEDlypVx+vTpEs9naGiIxYsXIzs7G9988w0AwN/fH3p6erh27ZrSz6Gg2KpTpw5cXV2xfPlylSf+ymSyQr9kt2/fXiYLla5evVrh+e+//47c3NxCiycOGzYMBgYGGDhwIC5duqR1J4+amJjA19cXsbGxaNiwodLPQNlemMqVK6Nv374YMWIEHj58WOIrwwquSv3f//6n0L5x40Y8ffpUel0ZX19fZGRkYOvWrQrtL59M/7ratm2Lf/75R2EvR35+PtavX6/WeUqrTp06+Prrr9GgQQPpO1nc75Q6vfxdOHz4MG7duqVyIdFu3bpBCIG7d+8qjbFBgwYq51T2j0oA0uH2gr3xQOE9hgV8fX1x/vx5nDlzRqFd3T9HbyruWSK8//77WL16Nbp06YLRo0ejefPm0NfXx507d7B371707NkTvXv3houLC7766ivMmDEDWVlZ0qXQ8fHxePDggcKVQi+aPHky7ty5gw4dOsDR0RFpaWlYuHAh9PX10bZt2yLjmjVrFvz8/ODr64svvvgCBgYGiIiIwLlz57BmzRq1rkTs5uYGb29vzJo1C7dv38bSpUsVXt+2bRsiIiLQq1cv1KxZE0IIbNq0CWlpafDz8yvVnG3btkWXLl2wYsUKTJgwATVq1MD06dMxceJEXL9+He+++y6qVKmCe/fu4fjx4zA1NZXe48WLF6N79+5o2bIlxo4di+rVqyMhIQG7du2Sfll369YNkZGRcHNzQ8OGDXHq1Cl89913ZbLOzqZNm6Cnpwc/Pz+cP38ekyZNQqNGjQqdz1K5cmUMGjQIS5YsgbOzM7p37672WF7XwoUL8c4776B169b49NNP4eLigoyMDFy9ehV//vmndH5R9+7dpbXNbGxscOvWLYSHh8PZ2Rm1a9cu0Zx+fn7w9/fH+PHjkZ6ejlatWuHs2bOYMmUKmjRpgqCgoCK3HTRoEBYsWIBBgwbh22+/Re3atbFjxw7s2rXrtd6Hl02cOBF//vknOnTogIkTJ8LY2Bg//fQTnj59CkDxEnVVTp06pXRRSg8Pj0KnCKhy9uxZfPbZZ+jXrx9q164NAwMD/PPPPzh79qy0p9fFxaXY3yl1OXnyJIYNG4Z+/frh9u3bmDhxIhwcHBASElLkNq1atcLHH3+MoUOH4uTJk2jTpg1MTU2RlJSEgwcPokGDBvj000+L3N7f3x+Ojo7o3r073NzckJ+fj7i4OMybNw9mZmYKiwQX7CFft24datasCSMjIzRo0ABjxozB8uXL0bVrV3zzzTewtbXF6tWrcfHiRbW+P28sTZ5dTupRcBXGiRMnVPYruCpLGblcLr7//nvRqFEjYWRkJMzMzISbm5v45JNPxJUrVxT6/vbbb6JZs2ZSvyZNmihccfPylR7btm0TnTt3Fg4ODsLAwEBUrVpVdOnSRcTExEh9lF2RJYQQMTExon379sLU1FQYGxuLli1bSleovSr/vXv3lugqjqVLlwoAwtjYuNCVUBcvXhT9+/cXrq6uwtjYWFhYWIjmzZuLyMjIV46r6n3/999/hY6Ojhg6dKjUtmXLFuHr6yvMzc2FoaGhcHZ2Fn379hV79uxR2PbIkSOic+fOwsLCQhgaGgpXV1eFq9IePXokgoODRdWqVYWJiYl45513RExMTKGrqdRxNdypU6dE9+7dhZmZmahUqZLo37+/uHfvntJt9u3bJwCI2bNnqxy7KMW5Gu7FK7aKygeAGDFihNJxbty4IT788EPh4OAg9PX1hY2NjfDx8VG4omnevHnCx8dHWFtbCwMDA1G9enURHBwsbt68Wap4srKyxPjx44Wzs7PQ19cX9vb24tNPPxWPHj1S2Pblz08IIe7cuSP69Okjvf99+vQRhw8fLvbVcMreT2XzxMTEiBYtWghDQ0NhZ2cnxo0bJ+bMmfPKq11fnLuoR3R0tBDi/38ev/vuu0JjABBTpkwRQghx7949MWTIEOHm5iZMTU2FmZmZaNiwoViwYIHCVXRCFO87VdT3tG3btqJevXqF2l9+3wo+0927d4ugoCBRuXJlYWxsLLp06VLod+jLvyMLLF++XLRo0UL6fefq6ioGDRokTp48WfQbK55fNTlgwABRu3ZtYWZmJvT19UX16tVFUFCQiI+PV+h78+ZN0alTJ1GpUiUBQCGO+Ph44efnJ4yMjISlpaUIDg4Wf/zxB6+GE0LIhBCiXKoyIiIAn3/+OZYsWYLbt28rPaRFb5ZOnTrh5s2buHz5sqZDISozPAxHROXi6NGjuHz5MiIiIvDJJ5+wUHoDhYaGokmTJnBycsLDhw+xevVqREdHK6zgT1QRsVgionLh7e0NExMTdOvWTTqpnd4seXl5mDx5MpKTkyGTyeDh4YFVq1a9cqV8ojcdD8MRERERqaDRpQMOHDiA7t27o1q1apDJZEpXcX3Z/v374enpCSMjI9SsWRM//fRToT4bN26Eh4cHDA0N4eHhId37hoiIiKikNFosPX36FI0aNcKPP/5YrP43btxAly5d0Lp1a8TGxuKrr77CqFGjsHHjRqlPwU1bg4KCcObMGQQFBSEgIADHjh0rqzSIiIioAtOaw3AymQybN29Gr169iuwzfvx4bN26VeG+VsOHD8eZM2dw5MgRAEBgYCDS09Px119/SX0K1tZQdXsNIiIiImXeqBO8jxw5gk6dOim0+fv7Y9myZZDL5dDX18eRI0cwduzYQn3Cw8OLHDcnJ0dhJeT8/Hw8fPgQVlZWal34kIiIiMqOEAIZGRmoVq1asRdKLY43qlhKTk4udNNGW1tb5Obm4sGDB7C3ty+yj6r728yaNUvtq7gSERGRZty+fVutdyt4o4oloPCNLwuOIr7YrqyPqj1EYWFhCA0NlZ4/fvwY1atXx+XLl5XebVod5HI59u7dC19fX+jr63MODY3PObRrjoqQA+fQnvE5h3bNUR45PHz4EHXq1JFuAK8ub1SxZGdnV2gP0f3796GnpyctcFdUn5f3Nr3I0NBQ6V2dLS0ty2zhPLlcDhMTE1hZWZXpD/6bPkdFyIFzaM/4nEO75qgIOXAO7Rn/Reo+hUajV8OVlLe3N6KjoxXadu/eDS8vL+mNL6qPj49PucVJREREFYdG9yw9efIEV69elZ7fuHEDcXFxsLS0RPXq1REWFoa7d+/it99+A/D8yrcff/wRoaGh+Oijj3DkyBEsW7ZM4Sq30aNHo02bNpgzZw569uyJP/74A3v27MHBgwfLPT8iIiJ682l0z9LJkyfRpEkTNGnSBMD/33do8uTJAICkpCQkJCRI/WvUqIEdO3Zg3759aNy4MWbMmIFFixahT58+Uh8fHx+sXbsWK1asQMOGDREZGYl169ahRYsW5ZscERERVQga3bPUrl07qFrmKTIyslBb27Ztcfr0aZXj9u3bF3379n3d8IiIiFTKy8tDTk4O9PT0kJ2djby8vDKZRy6Xv/FzqGt8AwMDtS4LUBxv1AneRERE2kAIgeTkZKSlpUEIATs7O9y+fbvM1uarCHOoa3wdHR3UqFEDBgYGaoxONRZLREREJVRQKFWtWhVGRkZ4+vQpzMzMymyPR35+Pp48efJGz6GO8fPz85GYmIikpCRUr1693BaOZrFERERUAnl5eVKhZGVlhfz8fMjlchgZGZVpIfPs2bM3eg51jW9jY4PExETk5uaW+RIEBd6opQOIiIg0TS6XAwBMTEw0HMnbqeDwW1mdu6UMiyUiIqJS4L1DNUMT7zuLJSIiIiIVWCwRERGR2shkMmzZsgUAcPPmTchkMsTFxQEADh48CF1dXaSlpWksvtJgsURERPQW6N69Ozp27Kj0tSNHjkBXVxdnzpx57XmSkpLQuXPn1x5Hm7BYIiIi0qCslBScXbwYWSkpZTpPcHAw/vnnH9y6davQa8uXL0fjxo3RqFGj157Hzs5O6c3p32QsloiIiDQoKyUF5yIiyrxY6tatG6pWrVro7hiZmZlYt24devbsieDgYFSvXh0mJiZo0KCBwr1Xged33hg1ahS+/PJLWFpaws7ODlOnTlXo8+JhuFdJTU1F//794ejoWOSc2oDFEhER0WsSQiA3M7NUj7zsbABAXna26r5ZWUrbVd027EV6enoYNGgQIiMjFbZZv349nj17huDgYDRu3Bhbt27FuXPn8PHHHyMoKAjHjh1TGGflypUwNTXFsWPHMHfuXEyfPh3R0dGlet+ys7Ph6emJbdu2qZxT07goJRER0WvKy87Ghnfeea0xooOCSrVdwIkT0Cvmmk8ffvghvvvuO+zbtw++vr4Anh+Ce++99+Dg4ICRI0fC3NwcOjo6GDlyJHbu3In169cr3Iy+YcOGmDJlCgCgdu3a+PHHH/H333/Dz8+vxLE7ODjgiy++kJ4XNaemsVgiIiJ6S7i5ucHHxwfLly+Hr68vrl27hpiYGOzevRt5eXn4/vvvsXXrVty9exc5OTnIycmBqampwhgNGzZUeG5vb4/79++XKp68vDzMnj0b69atUzmnprFYIiIiek26Rkboe+xYsW/jkfXgAbIfPAAAPLp4ESe//RZeEyeiipsbAMDI2hrG1tZS//z8fKRnZMC8UqVCc+gaG5co1uDgYHz22WdYvHgxVqxYAWdnZ3To0AFz587FkiVLsGDBAjRq1AimpqYYM2YMnj17prD9y7cYkclkyM/PL1EMBebNm4cFCxYgPDwcDRo0KHJOTWOxRERE9JpkMhn0TEyKXSxVql4dlapXB/C80AIA68aNYenhobR/fn4+9HJzSzRHUQICAjB69GhERUVh5cqV+OijjyCTyRATE4MuXbrggw8+gI6ODvLz83HlyhW4u7u/1nyqxMTEoGfPnvjggw8AoFzmLA2e4E1ERPQWMTMzQ2BgIL766iskJiZiyJAhAIBatWph7969OHz4MC5cuIBPPvkEycnJZRpLrVq1EB0dXa5zlgaLJSIiIg0ytrFB/ZAQGNvYlNucwcHBePToETp27Ijq/+3h+vrrr9GoUSN07twZ7dq1g52dHXr16lWmcUyaNAlNmzaFv79/uc1ZGjwMR0REpEHGNjZoOGJEuc7p7e1daMkBS0tLrF69WroaTpl9+/YVant5TaUXx3VxcZGe5+fn45133kFeXp40vqWlZbHXZNIk7lkiIiIiUoHFEhEREZEKLJaIiIiIVGCxRERERKQCiyUiIqJSKO492Ui9NPG+s1giIiIqgYIVrDMzMzUcydupYHVvXV3dcpuTSwcQERGVgK6uLipXrizdD83IyAjPnj1Ddnb2a6+uXZT8/Pw3fg51jJ+fn4+UlBSYmJhAT6/8ShgWS0RERCVkZ2cHALh//z6EEMjKyoKxsTFkMlmZzFcR5lDX+Do6OqhevXqZvQ/KsFgiIiIqIZlMBnt7e1StWhVZWVnYv38/2rRpU+gms+oil8tx4MCBN3oOdY1vYGBQZnvXisJiiYiIqJR0dXVhaGiI3NxcGBkZlVkho6ur+8bPUR45lBWe4E1ERESkAoslIiIiIhVYLBERERGpwGKJiIiISAUWS0REREQqsFgiIiIiUoHFEhEREZEKGi+WIiIiUKNGDRgZGcHT0xMxMTEq+y9evBju7u4wNjZG3bp18dtvvym8HhkZCZlMVuiRnZ1dlmkQERFRBaXRRSnXrVuHMWPGICIiAq1atcLPP/+Mzp07Iz4+HtWrVy/Uf8mSJQgLC8Mvv/yCZs2a4fjx4/joo49QpUoVdO/eXepnbm6OS5cuKWxrZGRU5vkQERFRxaPRYmn+/PkIDg7GsGHDAADh4eHYtWsXlixZglmzZhXqv2rVKnzyyScIDAwEANSsWRNHjx7FnDlzFIolmUwm3beHiIiI6HVorFh69uwZTp06hQkTJii0d+rUCYcPH1a6TU5OTqE9RMbGxjh+/Djkcrm0fPqTJ0/g7OyMvLw8NG7cGDNmzECTJk2KjCUnJwc5OTnS8/T0dADP72Mjl8tLld+rFIxbVuNXlDkqQg6cQ3vG5xzaNUdFyIFzaM/4ZTm2TAghymTkV0hMTISDgwMOHToEHx8fqX3mzJlYuXJlocNoAPDVV19hxYoV2LZtG5o2bYpTp06ha9euuH//PhITE2Fvb4+jR4/i6tWraNCgAdLT07Fw4ULs2LEDZ86cQe3atZXGMnXqVEybNq1Qe1RUFExMTNSXNBEREZWZzMxMDBgwAI8fP4a5ubnaxtX4jXRlMpnCcyFEobYCkyZNQnJyMlq2bAkhBGxtbTFkyBDMnTsXurq6AICWLVuiZcuW0jatWrVC06ZN8cMPP2DRokVKxw0LC0NoaKj0PD09HU5OTvD19YWVldXrpqiUXC5HdHQ0/Pz8yvQO0m/6HBUhB86hPeNzDu2aoyLkwDm0Z3wASE1NLZNxNVYsWVtbQ1dXF8nJyQrt9+/fh62trdJtjI2NsXz5cvz888+4d+8e7O3tsXTpUlSqVAnW1tZKt9HR0UGzZs1w5cqVImMxNDSEoaFhoXZ9ff0yvzMy59CO8TmHds1REXLgHNozPufQrjnKcvyyGldjSwcYGBjA09MT0dHRCu3R0dEKh+WU0dfXh6OjI3R1dbF27Vp069YNOjrKUxFCIC4uDvb29mqLnYiIiN4eGj0MFxoaiqCgIHh5ecHb2xtLly5FQkIChg8fDuD54bG7d+9KayldvnwZx48fR4sWLfDo0SPMnz8f586dw8qVK6Uxp02bhpYtW6J27dpIT0/HokWLEBcXh8WLF2skRyIiInqzabRYCgwMRGpqKqZPn46kpCTUr18fO3bsgLOzMwAgKSkJCQkJUv+8vDzMmzcPly5dgr6+Pnx9fXH48GG4uLhIfdLS0vDxxx8jOTkZFhYWaNKkCQ4cOIDmzZuXd3pERERUAWj8BO+QkBCEhIQofS0yMlLhubu7O2JjY1WOt2DBAixYsEBd4REREdFbTuO3OyEiIiLSZiyWiIiIiFRgsURERESkAoslIiIiIhVYLBERERGpwGKJiIiISAUWS0REREQqsFgiIiIiUoHFEhEREZEKLJaIiIiIVGCxRERERKQCiyUiIiIiFVgsEREREanAYomIiIhIBRZLRERERCqwWCIiIiJSgcUSERERkQosloiIiIhUYLFEREREpAKLJSIiIiIVWCwRERERqcBiiYiIiEgFFktEREREKrBYIiIiIlKBxRIRERGRCiyWiIiIiFRgsURERESkAoslIiIiIhVYLBERERGpwGKJiIiISAUWS0REREQqsFgiIiIiUoHFEhEREZEKLJaIiIiIVNB4sRQREYEaNWrAyMgInp6eiImJUdl/8eLFcHd3h7GxMerWrYvffvutUJ+NGzfCw8MDhoaG8PDwwObNm8sqfCIiIqrgNFosrVu3DmPGjMHEiRMRGxuL1q1bo3PnzkhISFDaf8mSJQgLC8PUqVNx/vx5TJs2DSNGjMCff/4p9Tly5AgCAwMRFBSEM2fOICgoCAEBATh27Fh5pUVEREQViEaLpfnz5yM4OBjDhg2Du7s7wsPD4eTkhCVLlijtv2rVKnzyyScIDAxEzZo18f777yM4OBhz5syR+oSHh8PPzw9hYWFwc3NDWFgYOnTogPDw8HLKioiIiCoSjRVLz549w6lTp9CpUyeF9k6dOuHw4cNKt8nJyYGRkZFCm7GxMY4fPw65XA7g+Z6ll8f09/cvckwiIiIiVfQ0NfGDBw+Ql5cHW1tbhXZbW1skJycr3cbf3x+//vorevXqhaZNm+LUqVNYvnw55HI5Hjx4AHt7eyQnJ5doTOB5EZaTkyM9T09PBwDI5XKpCFO3gnHLavyKMkdFyIFzaM/4nEO75qgIOXAO7Rm/LMeWCSFEmYz8ComJiXBwcMDhw4fh7e0ttX/77bdYtWoVLl68WGibrKwsjBgxAqtWrYIQAra2tvjggw8wd+5c3Lt3D1WrVoWBgQFWrlyJ/v37S9utXr0awcHByM7OVhrL1KlTMW3atELtUVFRMDExUUO2REREVNYyMzMxYMAAPH78GObm5mobV2N7lqytraGrq1toj8/9+/cL7RkqYGxsjOXLl+Pnn3/GvXv3YG9vj6VLl6JSpUqwtrYGANjZ2ZVoTAAICwtDaGio9Dw9PR1OTk7w9fWFlZVVaVNUSS6XIzo6Gn5+ftDX1+ccGhqfc2jXHBUhB86hPeNzDu2aozxySE1NLZNxNVYsGRgYwNPTE9HR0ejdu7fUHh0djZ49e6rcVl9fH46OjgCAtWvXolu3btDReX76lbe3N6KjozF27Fip/+7du+Hj41PkeIaGhjA0NFQ6T1l9oJxDu8bnHNo1R0XIgXNoz/icQ7vmKMvxy2pcjRVLABAaGoqgoCB4eXnB29sbS5cuRUJCAoYPHw7g+R6fu3fvSmspXb58GcePH0eLFi3w6NEjzJ8/H+fOncPKlSulMUePHo02bdpgzpw56NmzJ/744w/s2bMHBw8e1EiORERE9GbTaLEUGBiI1NRUTJ8+HUlJSahfvz527NgBZ2dnAEBSUpLCmkt5eXmYN28eLl26BH19ffj6+uLw4cNwcXGR+vj4+GDt2rX4+uuvMWnSJLi6umLdunVo0aJFeadHREREFYBGiyUACAkJQUhIiNLXIiMjFZ67u7sjNjb2lWP27dsXffv2VUd4RERE9JbT+O1OiIiIiLQZiyUiIiIiFVgsEREREanAYomIiIhIBRZLRERERCqwWCIiIiJSgcUSERERkQosloiIiIhUYLFEREREpAKLJSIiIiIVWCwRERERqcBiiYiIiEgFFktEREREKrBYIiIiIlKBxRIRERGRCiyWiIiIiFRgsURERESkAoslIiIiIhVYLBERERGpwGKJiIiISAUWS0REREQqsFgiIiIiUoHFEhEREZEKLJaIiIiIVGCxRERERKQCiyUiIiIiFVgsEREREanAYomIiIhIBRZLRERERCqwWCIiIiJSgcUSERERkQosloiIiIhUYLFEREREpAKLJSIiIiIVWCwRERERqaDxYikiIgI1atSAkZERPD09ERMTo7L/6tWr0ahRI5iYmMDe3h5Dhw5Famqq9HpkZCRkMlmhR3Z2dlmnQkRERBWQRouldevWYcyYMZg4cSJiY2PRunVrdO7cGQkJCUr7Hzx4EIMGDUJwcDDOnz+P9evX48SJExg2bJhCP3NzcyQlJSk8jIyMyiMlIiIiqmA0WizNnz8fwcHBGDZsGNzd3REeHg4nJycsWbJEaf+jR4/CxcUFo0aNQo0aNfDOO+/gk08+wcmTJxX6yWQy2NnZKTyIiIiISkNPUxM/e/YMp06dwoQJExTaO3XqhMOHDyvdxsfHBxMnTsSOHTvQuXNn3L9/Hxs2bEDXrl0V+j158gTOzs7Iy8tD48aNMWPGDDRp0qTIWHJycpCTkyM9T09PBwDI5XLI5fLSpqhSwbhlNX5FmaMi5MA5tGd8zqFdc1SEHDiH9oxflmPLhBCiTEZ+hcTERDg4OODQoUPw8fGR2mfOnImVK1fi0qVLSrfbsGEDhg4diuzsbOTm5qJHjx7YsGED9PX1ATzf+3T16lU0aNAA6enpWLhwIXbs2IEzZ86gdu3aSsecOnUqpk2bVqg9KioKJiYmasiWiIiIylpmZiYGDBiAx48fw9zcXG3jarxYOnz4MLy9vaX2b7/9FqtWrcLFixcLbRMfH4+OHTti7Nix8Pf3R1JSEsaNG4dmzZph2bJlSufJz89H06ZN0aZNGyxatEhpH2V7lpycnJCUlAQrK6vXzFQ5uVyO6Oho+Pn5SYUe5yj/8TmHds1REXLgHNozPufQrjnKI4fU1FTY29urvVjS2GE4a2tr6OrqIjk5WaH9/v37sLW1VbrNrFmz0KpVK4wbNw4A0LBhQ5iamqJ169b45ptvYG9vX2gbHR0dNGvWDFeuXCkyFkNDQxgaGhZq19fXL7MPlHNo1/icQ7vmqAg5cA7tGZ9zaNccZTl+WY2rsRO8DQwM4OnpiejoaIX26OhohcNyL8rMzISOjmLIurq6AICidpAJIRAXF6e0kCIiIiJ6FY3tWQKA0NBQBAUFwcvLC97e3li6dCkSEhIwfPhwAEBYWBju3r2L3377DQDQvXt3fPTRR1iyZIl0GG7MmDFo3rw5qlWrBgCYNm0aWrZsidq1ayM9PR2LFi1CXFwcFi9erLE8iYiI6M2l0WIpMDAQqampmD59OpKSklC/fn3s2LEDzs7OAICkpCSFNZeGDBmCjIwM/Pjjj/j8889RuXJltG/fHnPmzJH6pKWl4eOPP0ZycjIsLCzQpEkTHDhwAM2bNy/3/IiIiOjNp9FiCQBCQkIQEhKi9LXIyMhCbSNHjsTIkSOLHG/BggVYsGCBusIjIiKit5zGb3dCREREpM1YLBERERGpwGKJiIiISAUWS0REREQqsFgiIiIiUoHFEhEREZEKLJaIiIiIVGCxRERERKQCiyUiIiIiFVgsEREREanAYomIiIhIBRZLRERERCqwWCIiIiJSgcUSERERkQp6pdno6dOnmD17Nv7++2/cv38f+fn5Cq9fv35dLcERERERaVqpiqVhw4Zh//79CAoKgr29PWQymbrjIiIiItIKpSqW/vrrL2zfvh2tWrVSdzxEREREWqVU5yxVqVIFlpaW6o6FiIiISOuUqliaMWMGJk+ejMzMTHXHQ0RERKRVSnUYbt68ebh27RpsbW3h4uICfX19hddPnz6tluCIiIiINK1UxVKvXr3UHAYRERGRdipVsTRlyhR1x0FERESklUpVLBU4deoULly4AJlMBg8PDzRp0kRdcRERERFphVIVS/fv38f777+Pffv2oXLlyhBC4PHjx/D19cXatWthY2Oj7jiJiIiINKJUV8ONHDkS6enpOH/+PB4+fIhHjx7h3LlzSE9Px6hRo9QdIxEREZHGlGrP0s6dO7Fnzx64u7tLbR4eHli8eDE6deqktuCIiIiINK1Ue5by8/MLLRcAAPr6+oXuE0dERET0JitVsdS+fXuMHj0aiYmJUtvdu3cxduxYdOjQQW3BEREREWlaqYqlH3/8ERkZGXBxcYGrqytq1aqFGjVqICMjAz/88IO6YyQiIiLSmFKds+Tk5ITTp08jOjoaFy9ehBACHh4e6Nixo7rjIyIiItKo11pnyc/PD35+fuqKhYiIiEjrFLtYWrRoET7++GMYGRlh0aJFKvty+QAiIiKqKIpdLC1YsAADBw6EkZERFixYUGQ/mUzGYomIiIgqjGIXSzdu3FD6/0REREQVWamuhntZXl4e4uLi8OjRI3UMR0RERKQ1SlUsjRkzBsuWLQPwvFBq06YNmjZtCicnJ+zbt69EY0VERKBGjRowMjKCp6cnYmJiVPZfvXo1GjVqBBMTE9jb22Po0KFITU1V6LNx40Z4eHjA0NAQHh4e2Lx5c4liIiIiIipQqmJpw4YNaNSoEQDgzz//xM2bN3Hx4kWMGTMGEydOLPY469atk7aJjY1F69at0blzZyQkJCjtf/DgQQwaNAjBwcE4f/481q9fjxMnTmDYsGFSnyNHjiAwMBBBQUE4c+YMgoKCEBAQgGPHjpUmVSIiInrLlapYevDgAezs7AAAO3bsQL9+/VCnTh0EBwfj33//LfY48+fPR3BwMIYNGwZ3d3eEh4fDyckJS5YsUdr/6NGjcHFxwahRo1CjRg288847+OSTT3Dy5EmpT3h4OPz8/BAWFgY3NzeEhYWhQ4cOCA8PL02qRERE9JYr1TpLtra2iI+Ph729PXbu3ImIiAgAQGZmJnR1dYs1xrNnz3Dq1ClMmDBBob1Tp044fPiw0m18fHwwceJE7NixA507d8b9+/exYcMGdO3aVepz5MgRjB07VmE7f39/lcVSTk4OcnJypOfp6ekAALlcDrlcXqx8Sqpg3LIav6LMURFy4BzaMz7n0K45KkIOnEN7xi/LsWVCCFHSjaZOnYrw8HDY29sjMzMTly9fhqGhIZYvX45ffvkFR44ceeUYiYmJcHBwwKFDh+Dj4yO1z5w5EytXrsSlS5eUbrdhwwYMHToU2dnZyM3NRY8ePbBhwwbpxr4GBgaIjIzEgAEDpG2ioqIwdOhQhYLo5XymTZtWqD0qKgomJiavzIWIiIg0LzMzEwMGDMDjx49hbm6utnFLtWdp6tSpqF+/Pm7fvo1+/frB0NAQAKCrq1toT9GryGQyhedCiEJtBeLj4zFq1ChMnjwZ/v7+SEpKwrhx4zB8+HDphPOSjgkAYWFhCA0NlZ6np6fDyckJvr6+sLKyKlE+xSWXyxEdHQ0/Pz+p0OMc5T8+59CuOSpCDpxDe8bnHNo1R3nk8PIFX+pS6tud9O3bt1Db4MGDi729tbU1dHV1kZycrNB+//592NraKt1m1qxZaNWqFcaNGwcAaNiwIUxNTdG6dWt88803sLe3h52dXYnGBABDQ0Op4HuRvr5+mX2gnEO7xucc2jVHRciBc2jP+JxDu+Yoy/HLalyN3e7EwMAAnp6eiI6ORu/evaX26Oho9OzZU+k2mZmZ0NNTDLngHKmCo4ne3t6Ijo5WOG9p9+7dCof6iIiIiIpLo7c7CQ0NRVBQELy8vODt7Y2lS5ciISEBw4cPB/D88Njdu3fx22+/AQC6d++Ojz76CEuWLJEOw40ZMwbNmzdHtWrVAACjR49GmzZtMGfOHPTs2RN//PEH9uzZg4MHDxY3VSIiIiKJRm93EhgYiNTUVEyfPh1JSUmoX78+duzYAWdnZwBAUlKSwppLQ4YMQUZGBn788Ud8/vnnqFy5Mtq3b485c+ZIfXx8fLB27Vp8/fXXmDRpElxdXbFu3Tq0aNFCLTETERHR26XU5yypS0hICEJCQpS+FhkZWaht5MiRGDlypMox+/btq/ScKiIiIqKSKtWilH379sXs2bMLtX/33Xfo16/fawdFREREpC1KVSzt379fYSHIAu+++y4OHDjw2kERERERaYtSFUtPnjyBgYFBoXZ9fX1p9WsiIiKiiqBUxVL9+vWxbt26Qu1r166Fh4fHawdFREREpC1KdYL3pEmT0KdPH1y7dg3t27cHAPz9999Ys2YN1q9fr9YAiYiIiDSpVMVSjx49sGXLFsycORMbNmyAsbExGjZsiD179qBt27bqjpGIiIhIY0q9dEDXrl2VnuRNREREVJGU6pwlAEhLS8Ovv/6Kr776Cg8fPgQAnD59Gnfv3lVbcERERESaVqo9S2fPnkXHjh1hYWGBmzdvYtiwYbC0tMTmzZtx69Yt6fYkRERERG+6Uu1ZCg0NxZAhQ3DlyhUYGRlJ7Z07d+Y6S0RERFShlKpYOnHiBD755JNC7Q4ODkhOTn7toIiIiIi0RamKJSMjI6WLT166dAk2NjavHRQRERGRtihVsdSzZ09Mnz4dcrkcACCTyZCQkIAJEyagT58+ag2QiIiISJNKVSx9//33SElJQdWqVZGVlYW2bduiVq1aqFSpEr799lt1x0hERESkMaW6Gs7c3BwHDx7EP//8g9OnTyM/Px9NmzZFx44d1R0fERERkUaVuFjKzc2FkZER4uLi0L59e+l2J0REREQVUYkPw+np6cHZ2Rl5eXllEQ8RERGRVinVOUtff/01wsLCpJW7iYiIiCqqUp2ztGjRIly9ehXVqlWDs7MzTE1NFV4/ffq0WoIjIiIi0rRSFUu9evWCTCaDEELd8RARERFplRIVS5mZmRg3bhy2bNkCuVyODh064IcffoC1tXVZxUdERESkUSU6Z2nKlCmIjIxE165d0b9/f+zZsweffvppWcVGREREpHEl2rO0adMmLFu2DO+//z4AYODAgWjVqhXy8vKgq6tbJgESERERaVKJ9izdvn0brVu3lp43b94cenp6SExMVHtgRERERNqgRMVSXl4eDAwMFNr09PSQm5ur1qCIiIiItEWJDsMJITBkyBAYGhpKbdnZ2Rg+fLjC8gGbNm1SX4REREREGlSiYmnw4MGF2j744AO1BUNERESkbUpULK1YsaKs4iAiIiLSSqW63QkRERHR24LFEhEREZEKLJaIiIiIVGCxRERERKQCiyUiIiIiFVgsEREREanAYomIiIhIBY0XSxEREahRowaMjIzg6emJmJiYIvsOGTIEMpms0KNevXpSn8jISKV9srOzyyMdIiIiqmA0WiytW7cOY8aMwcSJExEbG4vWrVujc+fOSEhIUNp/4cKFSEpKkh63b9+GpaUl+vXrp9DP3NxcoV9SUhKMjIzKIyUiIiKqYDRaLM2fPx/BwcEYNmwY3N3dER4eDicnJyxZskRpfwsLC9jZ2UmPkydP4tGjRxg6dKhCP5lMptDPzs6uPNIhIiKiCqhEtztRp2fPnuHUqVOYMGGCQnunTp1w+PDhYo2xbNkydOzYEc7OzgrtT548gbOzM/Ly8tC4cWPMmDEDTZo0KXKcnJwc5OTkSM/T09MBAHK5HHK5vLgplUjBuGU1fkWZoyLkwDm0Z3zOoV1zVIQcOIf2jF+WY8uEEKJMRn6FxMREODg44NChQ/Dx8ZHaZ86ciZUrV+LSpUsqt09KSoKTkxOioqIQEBAgtR89ehRXr15FgwYNkJ6ejoULF2LHjh04c+YMateurXSsqVOnYtq0aYXao6KiYGJiUsoMiYiIqDxlZmZiwIABePz4MczNzdU2rsb2LBWQyWQKz4UQhdqUiYyMROXKldGrVy+F9pYtW6Jly5bS81atWqFp06b44YcfsGjRIqVjhYWFITQ0VHqenp4OJycn+Pr6wsrKqgTZFJ9cLkd0dDT8/Pygr6/POTQ0PufQrjkqQg6cQ3vG5xzaNUd55JCamlom42qsWLK2toauri6Sk5MV2u/fvw9bW1uV2wohsHz5cgQFBcHAwEBlXx0dHTRr1gxXrlwpso+hoSEMDQ0Ltevr65fZB8o5tGt8zqFdc1SEHDiH9ozPObRrjrIcv6zG1dgJ3gYGBvD09ER0dLRCe3R0tMJhOWX279+Pq1evIjg4+JXzCCEQFxcHe3v714qXiIiI3k4aPQwXGhqKoKAgeHl5wdvbG0uXLkVCQgKGDx8O4Pnhsbt37+K3335T2G7ZsmVo0aIF6tevX2jMadOmoWXLlqhduzbS09OxaNEixMXFYfHixeWSExEREVUsGi2WAgMDkZqaiunTpyMpKQn169fHjh07pKvbkpKSCq259PjxY2zcuBELFy5UOmZaWho+/vhjJCcnw8LCAk2aNMGBAwfQvHnzMs+HiIiIKh6Nn+AdEhKCkJAQpa9FRkYWarOwsEBmZmaR4y1YsAALFixQV3hERET0ltP47U6IiIiItBmLJSIiIiIVWCwRERERqcBiiYiIiEgFFktEREREKrBYIiIiIlKBxRIRERGRCiyWiIiIiFRgsURERESkAoslIiIiIhVYLBERERGpwGKJiIiISAUWS0REREQqsFgiIiIiUoHFEhEREZEKLJaIiIiIVGCxRERERKQCiyUiIiIiFVgsEREREanAYomIiIhIBRZLRERERCqwWCIiIiJSgcUSERERkQosloiIiIhUYLFEREREpAKLJSIiIiIVWCwRERERqcBiiYiIiEgFFktEVO5iw8MRVa8eYsPDNR0KEdErsVgionKXfPSown+JiLQZiyUiKnfyR480HUIhjy5eRPTgwXh08aKmQyEiLaOn6QCI6O0QGx6O5KNHIXJz8eTOHQDAo3PnsOO99yAzMIBdy5aoP2KExuJLu3oVKSdPIu3qVVRxc9NYHESkfVgsEVG5uPDLL4UbhUDapUsAgEf//qvRYomIqCgsloioXLh/9JF0jlLapUsQz54pvK5nZoakAwfKNaZHFy/i/unTeBAXh/snTwIAkg4dkl6vXKsW9zIRkebPWYqIiECNGjVgZGQET09PxMTEFNl3yJAhkMlkhR716tVT6Ldx40Z4eHjA0NAQHh4e2Lx5c1mnQUSv0GTMGHReuxad165F5bp1AQBV6tdHy2++gZGVFXKfPMHBUaOQvXIlMm7dKtNYRFYWbmzZgj1DhuDUt9/i1vbtyLp3DwBwc+tWHBk/HkfGj8fJWbPKNA4iejNotFhat24dxowZg4kTJyI2NhatW7dG586dkZCQoLT/woULkZSUJD1u374NS0tL9OvXT+pz5MgRBAYGIigoCGfOnEFQUBACAgJw7Nix8kqLiIpLJkPN3r3RfccOuA8dCpmeHvIuXcKuPn0Q+/33kD95orap8nJycDs6Goc//xyZs2bh5NSpkGdkAADMqleHmZOT1NfUwQFNxo+HV1iY2uYnojeXRoul+fPnIzg4GMOGDYO7uzvCw8Ph5OSEJUuWKO1vYWEBOzs76XHy5Ek8evQIQ4cOlfqEh4fDz88PYWFhcHNzQ1hYGDp06IBwrudCpDXsWrZU+K++mRmafPEF/DduhG7duhC5ubiwYgX+7NIF1zdvhsjPL9U8+Xl5SD56FEcnTcKmtm0RM2YM7v79N5CbC/OaNdFo9Gj02LULPf76Cw0++wwAoGtsjKd37+LckiV4mpionoSJ6I2msWLp2bNnOHXqFDp16qTQ3qlTJxw+fLhYYyxbtgwdO3aEs7Oz1HbkyJFCY/r7+xd7TCIqe03GjMGA8+fRZMwYhfZKzs4wGjwY7yxahErOzshOTcXRr7/G7gED8ODsWYW+RV3qL4TAw/PncWrOHPzRoQP+CQ7G9U2bIM/IgImdHeoOGQKjkSPRaeNG1Pv4Y5g5Oips32j0aFg1agR5ejoOjByJ03PnIl8u59ICRG8xjZ3g/eDBA+Tl5cHW1lah3dbWFsnJya/cPikpCX/99ReioqIU2pOTk0s8Zk5ODnJycqTn6enpAAC5XA65XP7KWEqjYNyyGr+izFERcuAcJR/f2tsbnTZswJXVqxG/dClS//0Xu/v3h0uPHmgwahSMrK2ReukSUk6eROqlSzBzdcWThAQk/PUXEv76Cxk3b0pj6pubw8nPD9W7dIF1kybIzcvDneho5ObmQiaTSf1MnZ1h7ekJy8aNUaNPH/y7aBEur1qFiytXIiU2Fk7vvqswX3HyeJM/i/KYoyLkwDm0Z/yyHFsmhBBlMvIrJCYmwsHBAYcPH4a3t7fU/u2332LVqlW4+Ip/vc2aNQvz5s1DYmIiDAwMpHYDAwOsXLkS/fv3l9pWr16N4OBgZGdnKx1r6tSpmDZtWqH2qKgomJiYlDQ1IlKj/PR0yHfvRu7p088bDA2h7+sLmakpnm3cCN3GjSEePED+f2s3AQD09KDr7g69xo2hW7s2ZHql+3dhbnw8cjZsALKzAX19QC6HQUAA9Bs3fv3EiEjtMjMzMWDAADx+/Bjm5uZqG1dje5asra2hq6tbaI/P/fv3C+0ZepkQAsuXL0dQUJBCoQQAdnZ2JR4zLCwMoaGh0vP09HQ4OTnB19cXVlZWxU2pRORyOaKjo+Hn5wd9fX3OoaHxOYd2zVHk+O+/j9R//8WJKVOQcf065Dt3QsfQEACQFxcndbNs2BC1AgJQzdcX+qamr53Do5o1kWJnhytRUcj87/wl+8xMFPw2Ma9ZU+nSAhXhsyiPOSpCDpxDe8YHgNTU1DIZV2PFkoGBATw9PREdHY3evXtL7dHR0ejZs6fKbffv34+rV68iODi40Gve3t6Ijo7G2LFjpbbdu3fDx8enyPEMDQ1h+N8v3hfp6+uX2QfKObRrfM6hXXMoG9+uaVMYWVoi4/p1AED+C4fOC+gaGKDWC79PSjrHy858/z1S/lt/qcCtbdtwa9s2AICNlxf8Vq58rTleV0WYoyLkwDm0Y/yyGleji1KGhoYiKCgIXl5e8Pb2xtKlS5GQkIDhw4cDeL7H5+7du/jtt98Utlu2bBlatGiB+vXrFxpz9OjRaNOmDebMmYOePXvijz/+wJ49e3Dw4MFyyYmIyo5XWBjSrl5FXnY2bm7fjvvHj8OlRw/Yt2oF4PkikmUxHwAcmzwZ+Tk5sG/dGi7dupXJfESknTRaLAUGBiI1NRXTp09HUlIS6tevjx07dkhXtyUlJRVac+nx48fYuHEjFi5cqHRMHx8frF27Fl9//TUmTZoEV1dXrFu3Di1atCjzfIiobFVxc5MOe+kaGeH+8eOwb9UKNf4rXspyvvO//IL0q1dhYmtbZvMRkXbS+O1OQkJCEBISovS1yMjIQm0WFhbIzMxUOWbfvn3Rt29fdYRHRAQAMKlaFelXr+Le8ePISkmBsY2NpkMionKi8dudEBGVRuVatWDj5VVuh8Is/zvs/yQhAVkpKeUyJxFpBxZLRPRGquLmBr+VK8vtRrfV3nmnXOYhIu3DYomISIWslBQ8jI+HyMsD/lvE8t+ICKSeP4+H8fHcy0T0FtD4OUtERNrsyu+/41xEhELb3b17cXfvXgCAa79+SL9xA15hYeW2l4uIyheLJSIiFWoHBMDR1xcA8DA+HsenTJFes/HygnmNGri2fj3Srl5lsURUQbFYIiJSwdjGptCVb00+/xxnfvgBKSdPIuv+fQ1FRkTlhcUSEVEJGdnawv3DD3ExMhJP/lsLLunQIel10//WiiOiioHFEhFRMRnb2KB+SAgur16N1DNnFF67uXUrbm7dCgCw9vQE+vTRRIhEVAZYLBERFZOxjQ0ajhgBpw4dkHb1KuTp6Tj57bcAAOdu3VCtdWsAz/csHfnvHnZE9OZjsUREVEIFt0ERQuDU3LkQcjks3dyk26DI5XKAxRJRhcF1loiISkkmk8HIygoAkP3wodI+WSkpOLt4MR5dvIizixdzXSaiNxCLJSKi11Dpv5O5U2JjlRZCWSkpOBcRgbSrV3EuIoIFE9EbiMUSEdFrsPLwAAA8UFIsPUtPx4O4OADAo/h4AMC19etZLBG9YXjOEhHRazCrXl36/4xbt/Dw/HkkHjmCp8eO4Y+vvpJeu7hypfT/906eBKB8DSci0j4sloiISiErJeX5HiIhpLZDX3xRrG1j58wB8PxWKQ1HjGDBRKTlWCwREZWCsnvGvUinVi00++gjXP/9d6ScOqW0z7X166XlCIhIe7FYIiIqhRfvGZd0+DDOLFiAZlOmwKp+feTm5uLQmTOo7u8P4ypVsO/jj9Fg1Cj8u2iRwhjec+bArkULTYRPRCXAYomIqBRePt/ozIIFsKpfH5YeHpDL5dC5cQMAYFSlCgDAzMGh0BgWNWvyEBzRG4BXwxERlaGCW6QYWVnBsWNHhdcexsdLD14hR6S9uGeJiOg1FRREyvYSFZyTdHbxYtzZs0fhteNTpkj/Xz8khOcuEWkpFktERK+pOCdpF5zjJPLzsX/ECGQ/eIBq7drB2MYGTn5+qFKnTjlFS0QlxcNwRETlwNjGBpYeHrCqXx+uffoAeL6Q5bX162FUpQrPXSLSYiyWiIjKWbU2bQAAzx4/1nAkRFQcPAxHRFSOslJSkPv0KarUq4dH588DAB7+91+Aq3oTaSMWS0RE5UjZYpbHp06V/p8nehNpHxZLRETl6MXFLPd9+imyHzxA3aAg1OjRAwC4V4lIC7FYIiIqRy8eZrOoWRPZDx5AR08Plh4eGo6MiIrCE7yJiDTE1NERAPDkzh0NR0JEqrBYIiLSkCp16wIAHpw9yxW8ibQYiyUiIg2xbtQIAJB17x7OLl7MgolIS7FYIiLSEPMaNaT/v7Z+PYslIi3FE7yJiMpZVkqKVBjpV6oEeUYGACDtyhUAXGuJSNuwWCIiKmfK1loCgKNffQUAcO3XDw1HjGDBRKQleBiOiKic1Q4IgGu/fkW+fm39elz5/fdyjIiIVGGxRERUzoxtbNBwxAi8u349vOfM+f8XZDIAgPecOagdEICslBSe+E2kBTReLEVERKBGjRowMjKCp6cnYmJiVPbPycnBxIkT4ezsDENDQ7i6umL58uXS65GRkZDJZIUe2dnZZZ0KEVGxGdvYwNLDAxY1a/5/oxAAILWdXbwY5yIipHOcWDgRaYZGz1lat24dxowZg4iICLRq1Qo///wzOnfujPj4eFSvXl3pNgEBAbh37x6WLVuGWrVq4f79+8jNzVXoY25ujkuXLim0GRkZlVkeRESlJdPRgWPHjrizZ4/UdnHlSti3aoVr69dLbVkpKTgXEQFHX1+ey0RUzjRaLM2fPx/BwcEYNmwYACA8PBy7du3CkiVLMGvWrEL9d+7cif379+P69euwtLQEALi4uBTqJ5PJYGdnV6axExGpw+2//1YolADg5rZtuLltm/T83yVL4NihAwAg59Gjco2PiDR4GO7Zs2c4deoUOnXqpNDeqVMnHD58WOk2W7duhZeXF+bOnQsHBwfUqVMHX3zxBbKyshT6PXnyBM7OznB0dES3bt0QGxtbZnkQEb2O2gEBeHf9ery7fj0ahYYq7XP3n39wbOJEAMClqCg8jI/HowsXkJ+eXp6hEr21NLZn6cGDB8jLy4Otra1Cu62tLZKTk5Vuc/36dRw8eBBGRkbYvHkzHjx4gJCQEDx8+FA6b8nNzQ2RkZFo0KAB0tPTsXDhQrRq1QpnzpxB7dq1lY6bk5ODnJwc6Xn6f7+A5HI55HK5OtItpGDcshq/osxREXLgHNozvjbOoVe5MipVrgwAuLR27Sv7J+7bh8R9+wAA+u3bQ96nT6njBJ4f3ru+YQNq9u1b6PAeP2/O8SaNX5Zjy4T474zCcpaYmAgHBwccPnwY3t7eUvu3336LVatW4eLFi4W26dSpE2JiYpCcnAwLCwsAwKZNm9C3b188ffoUxsbGhbbJz89H06ZN0aZNGyxatEhpLFOnTsW0adMKtUdFRcHExKS0KRIRlUju5cvIiYyEQUAAIJfj2ebNAAA9Hx/kvrDH3SAgADo2NpBVqgQdc/NSzZWfno7c48ehU706ciIjYTRiBHQdHNSSB5GmZGZmYsCAAXj8+DHMS/ndUEZje5asra2hq6tbaC/S/fv3C+1tKmBvbw8HBwepUAIAd3d3CCFw584dpXuOdHR00KxZM1z5b2VcZcLCwhD6wu7v9PR0ODk5wdfXF1ZWViVNrVjkcjmio6Ph5+cHfX19zqGh8TmHds1REXJ4nTmymjXDdUND1OzbF9kPHmDPf8VSu5EjcfTOHTxJSAAAtGjXDlbNmpV4jhf3ImU/eIA9s2ej+cyZOA7A6J9/4DVlCoysrHB9wwZU8/XF7b//RoKVFfz79OHnzTm0fnwASE1NLZNxNVYsGRgYwNPTE9HR0ejdu7fUHh0djZ49eyrdplWrVli/fj2ePHkCMzMzAMDly5eho6MDR0dHpdsIIRAXF4cGDRoUGYuhoSEMDQ0Ltevr65fZB8o5tGt8zqFdc1SEHEozh361amg8ahQAIDctDQDg3K0b8jIyULl2balYenjmDAyrVEHe3bvITUuDSbVqRY6ZlZKCK7//jtoBAchNS0P8zz/Dql493P7vpPIrq1YBANIuXMDZ+fPh5OeH+J9/hkXNmrj0yy8wGjGCnzfneGPGL6txNbrOUmhoKH799VcsX74cFy5cwNixY5GQkIDhw4cDeL7HZ9CgQVL/AQMGwMrKCkOHDkV8fDwOHDiAcePG4cMPP5QOwU2bNg27du3C9evXERcXh+DgYMTFxUljEhG9CYxtbFA/JATGVlbY+/HHuPP339Jr53/+GXv690f24sW4vmGDwnYvr8dUsORAVkoKsv+7ku7Ql1/i5tatAIBHFy5I294/fhynvv1WYTz58eNc24neehpdOiAwMBCpqamYPn06kpKSUL9+fezYsQPOzs4AgKSkJCT89y8pADAzM0N0dDRGjhwJLy8vWFlZISAgAN98843UJy0tDR9//LF0XlOTJk1w4MABNG/evNzzIyIqrYJVvh9dvIgqHh7IuHVL4X5y9UaMwJWUFFTz9ZX2Hjl16IDLa9fi2vr1yEpJQcMRI5D98CEA4EJkJJL+O+8pX8UivXpmZsh98gTHp04FAOSdOIG7f/+NXE9P3uCX3loav5FuSEgIQkJClL4WGRlZqM3NzQ3R0dFFjrdgwQIsWLBAXeEREWnU7b//VnrT3fOLFwMAEqtUQfWOHXEuIgKVnJ2lhSyvrV8PfVNTXF6zBgBwa/v2Ys2X++QJACDvhSVZYmfPBgDUDwlBwxEjSp8M0RtK48USEREVrXZAAKwbN0bOo0e4HBWF1DNnAAC1+vfH9TNnUMnFBek3bgAAHp4/r7DtRSX/4ASAau3awcLVFReWLStWDI7+/nBq3x5GVaogKyWFe5forcNiiYhIixnb2ODK778X2rt09b89RsfCwqQb8F767bcix2nyxRcwsrHBkfHjUXfAACSo2EP/sju7duHOrl0AuHeJ3k4sloiItFztgAA4+vri8fXrODJ+fOEOxVguL/3WLdi2aAEAMKxSBXXefx8AUN3PD7d27cL1jRsBPN9jdXXNGrj06CGdBG7drBlq9+0LAKhcq5Y6UiJ6o7BYIiLScgUnVst0dGDVpAlSX7qFU2V3d6RduADbli1x7+hRqb3e8OEwtrLCyW+/RXU/v/+/wu6/8Vr8dxJ3zuPHUrEkz8gAAKlQAoAHJ07gwYkTAJ7vWari5laW6RJpHRZLRERvgEcXL+LfJUsKFUrA8zWSAED/v/XnCjh16ABjGxtkP3qEynXqSFfYvcz8vxuSu/brh+r+/qjWujUA4MiECdJeK5Nq1eDcuTOyHzzgeUv01mGxRET0Bjg5axZSTp5U2ceuRQvc2bMHjh074s5/i04WVSC9qGCPU+2AAKXnRwFAZmKidEJ4rX79WCzRW4XFEhHRG8ArLAxpV68CAJIOHZIOk9UbMQJGlSvj8ZUrsGnaFPVDQuDUoYO0J6k4XiyoXrz67uXzoxz9/HAnOho5/y1uSfS2YLFERPQGqOLmpnCuUEGxZP/OO6jasKFCvxf/Wxq3o6Ol9ZpedOe/K+hOz52Lep98AnMXFy5USW8Fjd7uhIiISk/HwwNG1tZqHfPK778rLZRe9PjqVRweNw47+/XDld9/V+v8RNqIe5aIiN4wlWvVgrWnJ554e6t9r460TMGNG7j9zz+4s3NnoT565ubITU+H58SJqO7np9b5ibQR9ywREb1hqri5wXfZMuhWq6b2sY1tbGDp4YEaXbvCbfBgpX1y09MBAE+Tk3FhxQreaJcqPO5ZIiKiUrn439VxMj093Ny2DS2//Rb23t4ajopI/bhniYiIlDKytgbMzV/Z78KyZci6dw/nly1DVKNG2Pvpp9zbRBUKiyUiIlLK2MYG+u3aoVLNmsXqnxoXB+TmIunAARZLVKGwWCIioiLJ9+9HxvXrxeqbl5Ul/X/ioUNlFRJRueM5S0REVCTD995DLRMTpJw4gfvHjxd7u7OLFiH56FFYNWgAt4EDuRYTvdG4Z4mIiIqkV7s2PD76CK3mzoV9u3bF3zA/H/ePHsWFX37hWkz0xmOxREREr2RsYwPr/1YKt6hTp9jb2fv6wqlDh7IKi6hcsFgiIqJisW7YECb29qgdGCi1OXbsCLPq1YvcJmnvXtz+++/yCI+ozPCcJSIiKhZ7b2/02rMHWSkpyEhIgAyA+9ChuLZlC86Ghyv01TU0RF5ODuzeeQc2jRvjYXw87yNHbywWS0REVCLGNjbw/PJL6blD69Z4eO4c7uzZI7Xl5eQAAJIPHkTywYMAgPohIWg4YkT5BkukBiyWiIjotdz++2+FQulljh07wsnPD5Vr1SrHqIjUh+csERHRa6kdEIB316+Ha79+Sl+/s2cPjowfz3OX6I3FPUtERPRaCs5FajhiBKp6eeHI+PEwtLREzsOHMK9VCz6zZkn9iN5E3LNERERqJ/LzAQD5ubkajoTo9bFYIiIitbjy++84Mn48AOBZWhoA4MnNm9jZrx929uvHxSnpjcXDcEREpBY2TZuiwahRAIBLkZF4lp4OY1tb1PpvXaaCRS2J3jQsloiISC3O/fQTUk6eVGjLuncP/y5aBACwbNgQKadPo3ZAAM9fojcKiyUiIlILr7AwpF29CgA4NXMmnj1+DCMbG1g3agTbFi1gWLkyDo8bh4yEBBhbWaHWBx9oOGKi4uE5S0REpBZV3NxQo1s31OjWDXqVKgEA9M3McGfPHqRdvgxDCwsAwK1t23Bx5UpkP3ggbZuVkoKzixcjKyVFI7ETqcI9S0REpBZZKSlSsSPkcgBAzn8nel9bvx5ply4p9H9w5gxyYmKQ1awZctPScC4iAo6+vjxER1qHxRIREalF/IoVuLRypULbs0ePpP9PPXtW4bW42bMBAAm7dkE8e1b2ARKVEoslIiJSC1kptzv7/ffS/9/YulX6f954l7QFz1kiIiK1cB86FO+uX4+Go0fD0Nq6VGNcWrWK6zKR1uGeJSIiUouCPUEHRo1Czgsnb5eU16RJeHTxIpw6dFBjdESlp/E9SxEREahRowaMjIzg6emJmJgYlf1zcnIwceJEODs7w9DQEK6urli+fLlCn40bN8LDwwOGhobw8PDA5s2byzIFIiJ6QYsZM+DSowcAwMTBQWp36dkTptWrS8/dP/oIAOA5eTK858yR2hMPHMC19eulW6YQaZpG9yytW7cOY8aMQUREBFq1aoWff/4ZnTt3Rnx8PKq/8IV6UUBAAO7du4dly5ahVq1auH//PnJfuPfQkSNHEBgYiBkzZqB3797YvHkzAgICcPDgQbRo0aK8UiMiemvZe3ujcq1aMHN0RPajR7i6Zg0AwO2DD1Cja1fs/fhjuHTrBusmTQAAVdzdoaf3/3+Okg4e1EjcREXRaLE0f/58BAcHY9iwYQCA8PBw7Nq1C0uWLMGs/+5S/aKdO3di//79uH79OiwtLQEALi4uCn3Cw8Ph5+eHsLAwAEBYWBj279+P8PBwrPnvC0tERGXL2MYGDUeMwL8//wwAqNq8uXSYrn5ICGoHBCAjKUnqL9PRgWu/fkiJjUX6fwtbPoyPVxiPJ3uTpmisWHr27BlOnTqFCRMmKLR36tQJhw8fVrrN1q1b4eXlhblz52LVqlUwNTVFjx49MGPGDBgbGwN4vmdp7NixCtv5+/sjPDy8yFhycnKQk5MjPU9PTwcAyOVyyP9bK0TdCsYtq/EryhwVIQfOoT3jc47yn6OyuzuM7e1Rd+hQ6FWuDABw//hjAIBeVhb027eHXuXKuLVlC66tX6+w7fEpU6T/9/jkE9T79NMSz/+mvE9vwxzlmYO6yYQQokxGfoXExEQ4ODjg0KFD8PHxkdpnzpyJlStX4tJLi5cBwLvvvot9+/ahY8eOmDx5Mh48eICQkBC0b99eOm/JwMAAkZGRGDBggLRdVFQUhg4dqlAQvWjq1KmYNm1aofaoqCiYmJi8bqpERPQK+enpEBkZgBDIv3ULz7Zvh0Hv3tCpVg0AIKtUCTrm5hqOkrRdZmYmBgwYgMePH8NcjT8vGr8aTiZTXJlDCFGorUB+fj5kMhlWr14Ni/+WzZ8/fz769u2LxYsXS3uXSjIm8PxQXWhoqPQ8PT0dTk5O8PX1hZWVVanyehW5XI7o6Gj4+flBX1+fc2hofM6hXXNUhBw4x+uP/+jCBezZvh1tAgJQxd29TOZQJ86hHeMDQGpqapmMq7FiydraGrq6ukhOTlZov3//PmxtbZVuY29vDwcHB6lQAgB3d3cIIXDnzh3Url0bdnZ2JRoTAAwNDWFoaFioXV9fv8w+UM6hXeNzDu2aoyLkwDlKP37Byd56enpqm7civE8VZY6yHL+sxtVYsWRgYABPT09ER0ejd+/eUnt0dDR69uypdJtWrVph/fr1ePLkCczMzAAAly9fho6ODhwdHQEA3t7eiI6OVjhvaffu3QqH+l6l4MhkRkZGmVbwmZmZSE9P5xwaHJ9zaNccFSEHzvH648uNjOAydCjkRkbSOaTqnkOdOId2jA88/7sN/P/fcbURGrR27Vqhr68vli1bJuLj48WYMWOEqampuHnzphBCiAkTJoigoCCpf0ZGhnB0dBR9+/YV58+fF/v37xe1a9cWw4YNk/ocOnRI6OrqitmzZ4sLFy6I2bNnCz09PXH06NFix3Xt2jUBgA8++OCDDz74eAMf165dU1+xIoTQ6DlLgYGBSE1NxfTp05GUlIT69etjx44dcHZ2BgAkJSUhISFB6m9mZobo6GiMHDkSXl5esLKyQkBAAL755hupj4+PD9auXYuvv/4akyZNgqurK9atW1eiNZYKliVISEhQOOSnbs2aNcOJEyfKbPyCc69u376t1hPdXlaWeVSEHADmURIVIQeAeRRHRcgBYB4lUdY5PH78GNWrV5f+jquLxk/wDgkJQUhIiNLXIiMjC7W5ubkhOjpa5Zh9+/ZF3759Sx2Tjs7zhc0tLCzK9AdfV1e3TMcvYG5u/sbnURFyAJhHcVSEHADmURIVIQeAeRRHeeVQ8HdcbeOpdTQqkREjRmg6BLWoCHlUhByAipFHRcgBYB7apCLkAFSMPN7UHDS2zpI2S09Ph4WFhdrXaShvFSGPipADwDy0SUXIAagYeVSEHADmoU3KKgfuWVLC0NAQU6ZMUbqcwJukIuRREXIAmIc2qQg5ABUjj4qQA8A8tElZ5cA9S0REREQqcM8SERERkQosloiIiIhUYLFEREREpAKLJSIiIiIV3tpiKSIiAjVq1ICRkRE8PT0RExOjsv/+/fvh6ekJIyMj1KxZEz/99FM5RapaSfJISkrCgAEDULduXejo6GDMmDHlF6gKJclh06ZN8PPzg42NDczNzeHt7Y1du3aVY7RFK0keBw8eRKtWrWBlZQVjY2O4ublhwYIF5RitciX9XhQ4dOgQ9PT00Lhx47INsJhKkse+ffsgk8kKPS5evFiOEStX0s8jJycHEydOhLOzMwwNDeHq6orly5eXU7TKlSSHIUOGKP0s6tWrV44RK1fSz2L16tVo1KgRTExMYG9vj6FDhyI1NbWcolWupDksXrwY7u7uMDY2Rt26dfHbb7+VU6RFO3DgALp3745q1apBJpNhy5Ytr9xGLX+/1XrzlDdEwT3pfvnlFxEfHy9Gjx4tTE1Nxa1bt5T2v379ujAxMRGjR48W8fHx4pdffhH6+vpiw4YN5Ry5opLmcePGDTFq1CixcuVK0bhxYzF69OjyDViJkuYwevRoMWfOHHH8+HFx+fJlERYWJvT19cXp06fLOXJFJc3j9OnTIioqSpw7d07cuHFDrFq1SpiYmIiff/65nCP/fyXNoUBaWpqoWbOm6NSpk2jUqFH5BKtCSfPYu3evACAuXbokkpKSpEdubm45R66oNJ9Hjx49RIsWLUR0dLS4ceOGOHbsmDh06FA5Rq2opDmkpaUpfAa3b98WlpaWYsqUKeUb+EtKmkdMTIzQ0dERCxcuFNevXxcxMTGiXr16olevXuUc+f8raQ4RERGiUqVKYu3ateLatWtizZo1wszMTGzdurWcI1e0Y8cOMXHiRLFx40YBQGzevFllf3X9/X4ri6XmzZuL4cOHK7S5ubmJCRMmKO3/5ZdfCjc3N4W2Tz75RLRs2bLMYiyOkubxorZt22pFsfQ6ORTw8PAQ06ZNU3doJaKOPHr37i0++OADdYdWbKXNITAwUHz99ddiypQpWlEslTSPgmLp0aNH5RBd8ZU0j7/++ktYWFiI1NTU8givWF73e7F582Yhk8mkm6trSknz+O6770TNmjUV2hYtWiQcHR3LLMZXKWkO3t7e4osvvlBoGz16tGjVqlWZxVhSxSmW1PX3+607DPfs2TOcOnUKnTp1Umjv1KkTDh8+rHSbI0eOFOrv7++PkydPQi6Xl1msqpQmD22jjhzy8/ORkZGh9psmloQ68oiNjcXhw4fRtm3bsgjxlUqbw4oVK3Dt2jVMmTKlrEMsltf5LJo0aQJ7e3t06NABe/fuLcswX6k0eWzduhVeXl6YO3cuHBwcUKdOHXzxxRfIysoqj5ALUcf3YtmyZejYsaN0c3VNKE0ePj4+uHPnDnbs2AEhBO7du4cNGzaga9eu5RFyIaXJIScnB0ZGRgptxsbGOH78uMb+7pWGuv5+v3XF0oMHD5CXlwdbW1uFdltbWyQnJyvdJjk5WWn/3NxcPHjwoMxiVaU0eWgbdeQwb948PH36FAEBAWURYrG8Th6Ojo4wNDSEl5cXRowYgWHDhpVlqEUqTQ5XrlzBhAkTsHr1aujpafye3ABKl4e9vT2WLl2KjRs3YtOmTahbty46dOiAAwcOlEfISpUmj+vXr+PgwYM4d+4cNm/ejPDwcGzYsEFj9+J63e93UlIS/vrrL419JwqUJg8fHx+sXr0agYGBMDAwgJ2dHSpXrowffvihPEIupDQ5+Pv749dff8WpU6cghMDJkyexfPlyyOVyjf3dKw11/f3Wjt9wGiCTyRSeCyEKtb2qv7L28lbSPLRRaXNYs2YNpk6dij/++ANVq1Ytq/CKrTR5xMTE4MmTJzh69CgmTJiAWrVqoX///mUZpkrFzSEvLw8DBgzAtGnTUKdOnfIKr9hK8lnUrVsXdevWlZ57e3vj9u3b+P7779GmTZsyjfNVSpJHfn4+ZDIZVq9eDQsLCwDA/Pnz0bdvXyxevBjGxsZlHq8ypf1+R0ZGonLlyujVq1cZRVYyJckjPj4eo0aNwuTJk+Hv74+kpCSMGzcOw4cPx7Jly8ojXKVKksOkSZOQnJyMli1bQggBW1tbDBkyBHPnzoWurm55hKs26vj7/dbtWbK2toaurm6havr+/fuFqs8CdnZ2Svvr6enBysqqzGJVpTR5aJvXyWHdunUIDg7G77//jo4dO5ZlmK/0OnnUqFEDDRo0wEcffYSxY8di6tSpZRhp0UqaQ0ZGBk6ePInPPvsMenp60NPTw/Tp03HmzBno6enhn3/+Ka/QFajre9GyZUtcuXJF3eEVW2nysLe3h4ODg1QoAYC7uzuEELhz506ZxqvM63wWQggsX74cQUFBMDAwKMswX6k0ecyaNQutWrXCuHHj0LBhQ/j7+yMiIgLLly9HUlJSeYStoDQ5GBsbY/ny5cjMzMTNmzeRkJAAFxcXVKpUCdbW1uURtlqo6+/3W1csGRgYwNPTE9HR0Qrt0dHR8PHxUbqNt7d3of67d++Gl5cX9PX1yyxWVUqTh7YpbQ5r1qzBkCFDEBUVpbFzAF6krs9CCIGcnBx1h1csJc3B3Nwc//77L+Li4qTH8OHDUbduXcTFxaFFixblFboCdX0WsbGxsLe3V3d4xVaaPFq1aoXExEQ8efJEart8+TJ0dHTg6OhYpvEq8zqfxf79+3H16lUEBweXZYjFUpo8MjMzoaOj+Oe1YG+M0MDtWF/ns9DX14ejoyN0dXWxdu1adOvWrVBu2kxtf79LdDp4BVFwCeWyZctEfHy8GDNmjDA1NZWuuJgwYYIICgqS+hdcejh27FgRHx8vli1bplVLBxQ3DyGEiI2NFbGxscLT01MMGDBAxMbGivPnz2sifCFEyXOIiooSenp6YvHixQqXGKelpWkqBSFEyfP48ccfxdatW8Xly5fF5cuXxfLly4W5ubmYOHGiplIo1c/Ti7TlariS5rFgwQKxefNmcfnyZXHu3DkxYcIEAUBs3LhRUykIIUqeR0ZGhnB0dBR9+/YV58+fF/v37xe1a9cWw4YN01QKpf6Z+uCDD0SLFi3KO9wilTSPFStWCD09PRERESGuXbsmDh48KLy8vETz5s01lUKJc7h06ZJYtWqVuHz5sjh27JgIDAwUlpaW4saNGxrK4LmMjAzp7xgAMX/+fBEbGystgVBWf7/fymJJCCEWL14snJ2dhYGBgWjatKnYv3+/9NrgwYNF27ZtFfrv27dPNGnSRBgYGAgXFxexZMmSco5YuZLmAaDQw9nZuXyDfklJcmjbtq3SHAYPHlz+gb+kJHksWrRI1KtXT5iYmAhzc3PRpEkTERERIfLy8jQQ+f8r6c/Ti7SlWBKiZHnMmTNHuLq6CiMjI1GlShXxzjvviO3bt2sg6sJK+nlcuHBBdOzYURgbGwtHR0cRGhoqMjMzyzlqRSXNIS0tTRgbG4ulS5eWc6SqlTSPRYsWCQ8PD2FsbCzs7e3FwIEDxZ07d8o5akUlySE+Pl40btxYGBsbC3Nzc9GzZ09x8eJFDUStqGCpj6L+BpTV32+ZEBrYJ0hERET0hnhzDjwSERERaQCLJSIiIiIVWCwRERERqcBiiYiIiEgFFktEREREKrBYIiIiIlKBxRIRERGRCiyWiIiIiFRgsURE5cLFxQXh4eHSc5lMhi1btqjcJjU1FVWrVsXNmzfLNDZtMGTIEPTq1Utln3379kEmkyEtLU1t837xxRcYNWqU2sYjqohYLBFVcEOGDIFMJoNMJoOenh6qV6+OTz/9FI8ePdJ0aK80a9YsdO/eHS4uLoVeS01NhaOjY6HiYd++fejZsyfs7e1hamqKxo0bY/Xq1QrbJiUlYcCAAahbty50dHQwZsyYV8Zy8+ZN6X2UyWSoUqUK2rRpg/37979mls8tXLgQkZGR0vN27doVisvHxwdJSUmwsLBQy5wA8OWXX2LFihW4ceOG2sYkqmhYLBG9Bd59910kJSXh5s2b+PXXX/Hnn38iJCRE02GplJWVhWXLlmHYsGFKXw8ODkbDhg0LtR8+fBgNGzbExo0bcfbsWXz44YcYNGgQ/vzzT6lPTk4ObGxsMHHiRDRq1KhEce3ZswdJSUnYv38/zM3N0aVLF7UUGhYWFqhcubLKPgYGBrCzs4NMJnvt+QpUrVoVnTp1wk8//aS2MYkqGhZLRG8BQ0ND2NnZwdHREZ06dUJgYCB2796t0GfFihVwd3eHkZER3NzcEBERofD6nTt38P7778PS0hKmpqbw8vLCsWPHAADXrl1Dz549YWtrCzMzMzRr1gx79ux5rZj/+usv6Onpwdvbu9BrS5YsQVpaGr744otCr3311VeYMWMGfHx84OrqilGjRuHdd9/F5s2bpT4uLi5YuHAhBg0aVOK9NFZWVrCzs0PDhg3x888/IzMzU3ov9+/fj+bNm8PQ0BD29vaYMGECcnNzpW03bNiABg0awNjYGFZWVujYsSOePn0KQPEw3JAhQ7B//34sXLhQ2pN18+ZNhcNwjx8/hrGxMXbu3KkQ36ZNm2BqaoonT54AAO7evYvAwEBUqVIFVlZW6NmzZ6HDmj169MCaNWtK9D4QvU1YLBG9Za5fv46dO3dCX19favvll18wceJEfPvtt7hw4QJmzpyJSZMmYeXKlQCAJ0+eoG3btkhMTMTWrVtx5swZfPnll8jPz5de79KlC/bs2YPY2Fj4+/uje/fuSEhIKHWcBw4cgJeXV6H2+Ph4TJ8+Hb/99ht0dIr3K+zx48ewtLQsdSxFMTExAQDI5XLcvXsXXbp0QbNmzXDmzBksWbIEy5YtwzfffAPg+aG//v3748MPP8SFCxewb98+vPfee1B2L/OFCxfC29sbH330EZKSkpCUlAQnJyeFPhYWFujatWuhQ4xRUVHo2bMnzMzMkJmZCV9fX5iZmeHAgQM4ePAgzMzM8O677+LZs2fSNs2bN8ft27dx69Ytdb9FRBWCnqYDIKKyt23bNpiZmSEvLw/Z2dkAgPnz50uvz5gxA/PmzcN7770HAKhRowbi4+Px888/Y/DgwYiKikJKSgpOnDghFR21atWStm/UqJHC4axvvvkGmzdvxtatW/HZZ5+VKuabN2+iWrVqCm05OTno378/vvvuO1SvXh3Xr19/5TgbNmzAiRMn8PPPP5cqjqI8ffoUYWFh0NXVRdu2bREREQEnJyf8+OOPkMlkcHNzQ2JiIsaPH4/JkycjKSkJubm5eO+99+Ds7AwAaNCggdKxLSwsYGBgABMTE9jZ2RUZw8CBAzFo0CBkZmbCxMQE6enp2L59OzZu3AgAWLt2LXR0dPDrr79Kh+5WrFiBypUrY9++fejUqRMAwMHBAcDz97wgNiL6f9yzRPQW8PX1RVxcHI4dO4aRI0fC398fI0eOBACkpKTg9u3bCA4OhpmZmfT45ptvcO3aNQBAXFwcmjRpUuTemadPn+LLL7+Eh4cHKleuDDMzM1y8ePG19ixlZWXByMhIoS0sLAzu7u744IMPijXGvn37MGTIEPzyyy+oV69eqWN5kY+PD8zMzFCpUiX8+eefiIyMRIMGDXDhwgV4e3srnE/UqlUrPHnyBHfu3EGjRo3QoUMHNGjQAP369cMvv/zy2ifZd+3aFXp6eti6dSsAYOPGjahUqZJUBJ06dQpXr15FpUqVpM/V0tIS2dnZ0mcLAMbGxgCAzMzM14qHqKLiniWit4Cpqam0J2jRokXw9fXFtGnTMGPGDOlQ2i+//IIWLVoobKerqwvg//+YFmXcuHHYtWsXvv/+e9SqVQvGxsbo27evwqGekrK2ti5UTPzzzz/4999/sWHDBgCQDmFZW1tj4sSJmDZtmtR3//796N69O+bPn49BgwaVOo6XrVu3TioKrayspHYhRKETrwvik8lk0NXVRXR0NA4fPozdu3fjhx9+wMSJE3Hs2DHUqFGjVLEYGBigb9++iIqKwvvvv4+oqCgEBgZCT+/5r/b8/Hx4enoWOlQHADY2NtL/P3z4sFAbEf0/FktEb6EpU6agc+fO+PTTT1GtWjU4ODjg+vXrGDhwoNL+DRs2xK+//oqHDx8q3bsUExODIUOGoHfv3gCen8P0umsjNWnSBP/73/8U2jZu3IisrCzp+YkTJ/Dhhx8iJiYGrq6uUvu+ffvQrVs3zJkzBx9//PFrxfEyJycnhbkKeHh4YOPGjQpF0+HDh1GpUiXpMJdMJkOrVq3QqlUrTJ48Gc7Ozti8eTNCQ0MLjWdgYIC8vLxXxjNw4EB06tQJ58+fx969ezFjxgzptaZNm2LdunWoWrUqzM3Nixzj3Llz0NfXV9veN6KKhofhiN5C7dq1Q7169TBz5kwAwNSpUzFr1iwsXLgQly9fxr///osVK1ZI5zX1798fdnZ26NWrFw4dOoTr169j48aNOHLkCIDn5y9t2rQJcXFxOHPmDAYMGCDtsSotf39/nD9/XmHvkqurK+rXry89CvbIuLu7o2rVqgCeF0pdu3bFqFGj0KdPHyQnJyM5OVnae1IgLi4OcXFxePLkCVJSUhAXF4f4+PhSxxsSEoLbt29j5MiRuHjxIv744w9MmTIFoaGh0NHRwbFjxzBz5kycPHkSCQkJ2LRpE1JSUuDu7q50PBcXFxw7dgw3b97EgwcPinw/27ZtC1tbWwwcOBAuLi5o2bKl9NrAgQNhbW2Nnj17IiYmBjdu3MD+/fsxevRo3LlzR+oXExOD1q1bv3IPItFbSxBRhTZ48GDRs2fPQu2rV68WBgYGIiEhQXreuHFjYWBgIKpUqSLatGkjNm3aJPW/efOm6NOnjzA3NxcmJibCy8tLHDt2TAghxI0bN4Svr68wNjYWTk5O4scffxRt27YVo0ePlrZ3dnYWCxYskJ4DEJs3b1YZe8uWLcVPP/1U5Ot79+4VAMSjR48U8gVQ6NG2bVuFbZX1cXZ2LnKuGzduCAAiNja2yD779u0TzZo1EwYGBsLOzk6MHz9eyOVyIYQQ8fHxwt/fX9jY2AhDQ0NRp04d8cMPPyjE/eLndOnSJdGyZUthbGwsAIgbN24ozVcIIcaNGycAiMmTJxeKKSkpSQwaNEhYW1sLQ0NDUbNmTfHRRx+Jx48fS33q1Kkj1qxZU2ReRG87mRBKrlslItICO3bswBdffIFz584Ve5kAKpnt27dj3LhxOHv2rHSuExEp4jeDiLRWly5dcOXKFdy9e7fQOkOkHk+fPsWKFStYKBGpwD1LRERERCpwvzYRERGRCiyWiIiIiFRgsURERESkAoslIiIiIhVYLBERERGpwGKJiIiISAUWS0REREQqsFgiIiIiUoHFEhEREZEK/wdM9yuvek8mrwAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "logreg_preds = get_preds(external_X, logreg_estimators)\n",
    "ens_preds_pca, mp_pca, sp_pca = aggregate_preds(logreg_preds)\n",
    "threshs = sp_pca\n",
    "ens_preds = ens_preds_pca\n",
    "std_threshs = np.linspace(np.min(threshs), np.max(threshs), 100)\n",
    "reject_rate = [1 - np.mean((threshs<=s)) for s in std_threshs]\n",
    "accus = [np.mean((ens_preds==external_Y)[(threshs<=s)]) for s in std_threshs]\n",
    "tps = [np.sum(((external_Y)*(ens_preds==external_Y))[(threshs<=s)]) for s in std_threshs]  # correct and positive\n",
    "fps = [np.sum(((ens_preds)*(ens_preds!=external_Y))[(threshs<=s)]) for s in std_threshs]  # incorrect and predicted positive\n",
    "pos = np.sum(external_Y)\n",
    "recall = [tp/pos for tp in tps]\n",
    "precision = [tp/(tp+fp) for tp, fp in zip(tps, fps)]\n",
    "plt.plot(recall, precision, marker='+', c='brown')\n",
    "\n",
    "plt.xticks(np.arange(0, 1.01, step=0.1))\n",
    "plt.xticks(np.arange(0, 1.01, step=0.05), minor=True)\n",
    "plt.yticks(np.arange(0.6, 1.01, step=0.05))\n",
    "plt.grid(True, which='both')\n",
    "plt.xlabel('Recall ({} Positive)'.format(int(pos)))\n",
    "plt.ylabel('Precision')\n",
    "plt.title('Precision vs Recall by Thresholding Ensemble Std')\n",
    "plt.legend(['Vanilla', 'PCA'])"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "WLFih2JtxsXh"
   },
   "source": [
    "Most Vanilla Ensemble with randomly chosen subset and projects."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {
    "id": "WnAOruvQp_iL"
   },
   "outputs": [],
   "source": [
    "from abc import ABC, abstractmethod"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "metadata": {
    "id": "0PlRAAV5p_iL"
   },
   "outputs": [],
   "source": [
    "class Ensemble(ABC):\n",
    "  \"\"\" General Ensembling Class \"\"\"\n",
    "\n",
    "  @abstractmethod\n",
    "  def __init__(self, *args, **kwargs):\n",
    "    self.nmodels = kwargs.get('nmodels', 256)\n",
    "\n",
    "  @property\n",
    "  @abstractmethod\n",
    "  def estimators(self):\n",
    "    pass\n",
    "\n",
    "  @abstractmethod\n",
    "  def add_estimator(self, est):\n",
    "    pass\n",
    "\n",
    "  @abstractmethod\n",
    "  def base_model_generator(self):\n",
    "    # Returns something trainable with fit(X,Y)\n",
    "    pass\n",
    "\n",
    "  def random_sample(self, X, Y):\n",
    "    # Potentially subsample X and Y\n",
    "    return X, Y\n",
    "\n",
    "  def fit(self, X, Y, verbose=True):\n",
    "    # Returns something trainable with fit(X,Y)\n",
    "    for t in range(self.nmodels):\n",
    "      sX, sY = self.random_sample(X, Y)\n",
    "      est = self.base_model_generator()\n",
    "      if verbose:\n",
    "        print('Fitting Model {}'.format(t))\n",
    "      est.fit(sX, sY)\n",
    "      self.add_estimator(est)\n",
    "\n",
    "  def predictions(self, x):\n",
    "    # Assumes estimators return (N, ) shape predict\n",
    "    pred_array = [e.predict(x) for e in self.estimators]\n",
    "    return np.stack(pred_array, -1)\n",
    "\n",
    "  def predict(self, x=None, preds=None, return_only_prediction=True):\n",
    "    assert (x is not None) or (preds is not None)\n",
    "    if preds is None:\n",
    "      preds = self.predictions(x)\n",
    "\n",
    "    mean_pred = np.mean(preds, 1, keepdims=False)\n",
    "    std_pred = np.std(preds, 1, keepdims=False)\n",
    "\n",
    "    if return_only_prediction:\n",
    "      return np.float32(mean_pred>0.5)\n",
    "    return np.float32(mean_pred>0.5), mean_pred, std_pred"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "metadata": {
    "id": "keuiurs4p_iM"
   },
   "outputs": [],
   "source": [
    "class ProjectionEnsemble(Ensemble):\n",
    "  \"\"\" General Ensembling Class With Projections of Dimensions\"\"\"\n",
    "\n",
    "  @abstractmethod\n",
    "  def __init__(self, *args, **kwargs):\n",
    "    super(ProjectionEnsemble, self).__init__(*args, **kwargs)\n",
    "\n",
    "  @property\n",
    "  @abstractmethod\n",
    "  def directions(self):\n",
    "    pass\n",
    "\n",
    "  @property\n",
    "  @abstractmethod\n",
    "  def means(self):\n",
    "    pass\n",
    "\n",
    "  def predictions(self, x):\n",
    "    # Assumes estimators return (N, ) shape predict\n",
    "    pred_array = [\n",
    "      e.predict((x-mu)@d)\n",
    "      for mu, d, e in zip(self.means, self.directions, self.estimators)\n",
    "    ]\n",
    "    return np.stack(pred_array, -1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "metadata": {
    "id": "lKdrmysap_iM"
   },
   "outputs": [],
   "source": [
    "class PCAProjectionEnsemble(ProjectionEnsemble):\n",
    "  \"\"\" General Ensembling Class With Projections of Dimensions\"\"\"\n",
    "\n",
    "  def __init__(self, *args, **kwargs):\n",
    "    super(ProjectionEnsemble, self).__init__(*args, **kwargs)\n",
    "    self.ndirs = kwargs.get('ndirs', 8)\n",
    "    self.Vpca = kwargs['Vpca']  # d x k\n",
    "    self.Vorth = kwargs.get('Vorth', 8)\n",
    "    self.projection_split = kwargs.get('projection_split', False)\n",
    "    self.split_perc = kwargs.get('split_perc', .5)\n",
    "    self._splits_rand = []\n",
    "    self._dirs_inds = []\n",
    "    self._estimators = []\n",
    "\n",
    "  @property\n",
    "  def directions(self):\n",
    "    return [self.Vpca[:, dinds] for dinds in self._dirs_inds]\n",
    "\n",
    "  @property\n",
    "  def means(self):\n",
    "    return [np.zeros((1, self.Vpca.shape[0]), dtype=np.float32)] * len(self._dirs_inds)\n",
    "\n",
    "  @property\n",
    "  def estimators(self):\n",
    "    return self._estimators\n",
    "\n",
    "  def add_estimator(self, est):\n",
    "    self._estimators.append(est)\n",
    "\n",
    "  def base_model_generator(self):\n",
    "    # Returns something trainable with fit(X,Y)\n",
    "    # TODO: make init argument\n",
    "    return XGBClassifier(n_estimators=40)\n",
    "\n",
    "  def random_sample(self, X, Y, XV=None):\n",
    "    # Potentially subsample X and Y\n",
    "    N_tot, d = X.shape\n",
    "\n",
    "    if self.projection_split:\n",
    "      newdir = np.random.randn(d, 1)\n",
    "      newdir = newdir/np.sqrt(np.sum(newdir**2))\n",
    "      projs = (X@newdir)[:, 0]\n",
    "      medianp = np.median(projs)\n",
    "      in_range = projs <= medianp\n",
    "    else:\n",
    "      in_range = np.random.rand(N_tot) <= self.split_perc\n",
    "    self._splits_rand.append(in_range)\n",
    "\n",
    "    Y_train = Y[in_range]\n",
    "    rprm = np.random.permutation(self.Vpca.shape[1])\n",
    "    self._dirs_inds.append(rprm[:self.ndirs])\n",
    "    if XV is not None:\n",
    "      X_train = XV[in_range][:, self._dirs_inds[-1]]\n",
    "    else:\n",
    "      X_train = X[in_range]@self.Vpca[:, self._dirs_inds[-1]]\n",
    "\n",
    "    return X_train, Y_train\n",
    "\n",
    "  def fit(self, X, Y, verbose=True):\n",
    "    XV = X@self.Vpca\n",
    "    for t in range(self.nmodels):\n",
    "      sX, sY = self.random_sample(X, Y, XV)\n",
    "      est = self.base_model_generator()\n",
    "      if verbose:\n",
    "        print('Fitting Model {}'.format(t))\n",
    "      est.fit(sX, sY)\n",
    "      self.add_estimator(est)\n",
    "\n",
    "  def predictions(self, x):\n",
    "    xV = x@self.Vpca\n",
    "    # Assumes estimators return (N, ) shape predict\n",
    "    pred_array = [\n",
    "      e.predict(xV[:, di])\n",
    "      for di, e in zip(self._dirs_inds, self.estimators)\n",
    "    ]\n",
    "    return np.stack(pred_array, -1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "cIgY3Cnvp_iM",
    "outputId": "38ce96a2-6baf-4060-d805-ef563f3610fe"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Fitting Model 0\n",
      "Fitting Model 1\n",
      "Fitting Model 2\n",
      "Fitting Model 3\n",
      "Fitting Model 4\n",
      "Fitting Model 5\n",
      "Fitting Model 6\n",
      "Fitting Model 7\n",
      "Fitting Model 8\n",
      "Fitting Model 9\n",
      "Fitting Model 10\n",
      "Fitting Model 11\n",
      "Fitting Model 12\n",
      "Fitting Model 13\n",
      "Fitting Model 14\n",
      "Fitting Model 15\n",
      "Fitting Model 16\n",
      "Fitting Model 17\n",
      "Fitting Model 18\n",
      "Fitting Model 19\n",
      "Fitting Model 20\n",
      "Fitting Model 21\n",
      "Fitting Model 22\n",
      "Fitting Model 23\n",
      "Fitting Model 24\n",
      "Fitting Model 25\n",
      "Fitting Model 26\n",
      "Fitting Model 27\n",
      "Fitting Model 28\n",
      "Fitting Model 29\n",
      "Fitting Model 30\n",
      "Fitting Model 31\n",
      "Fitting Model 32\n",
      "Fitting Model 33\n",
      "Fitting Model 34\n",
      "Fitting Model 35\n",
      "Fitting Model 36\n",
      "Fitting Model 37\n",
      "Fitting Model 38\n",
      "Fitting Model 39\n",
      "Fitting Model 40\n",
      "Fitting Model 41\n",
      "Fitting Model 42\n",
      "Fitting Model 43\n",
      "Fitting Model 44\n",
      "Fitting Model 45\n",
      "Fitting Model 46\n",
      "Fitting Model 47\n",
      "Fitting Model 48\n",
      "Fitting Model 49\n",
      "Fitting Model 50\n",
      "Fitting Model 51\n",
      "Fitting Model 52\n",
      "Fitting Model 53\n",
      "Fitting Model 54\n",
      "Fitting Model 55\n",
      "Fitting Model 56\n",
      "Fitting Model 57\n",
      "Fitting Model 58\n",
      "Fitting Model 59\n",
      "Fitting Model 60\n",
      "Fitting Model 61\n",
      "Fitting Model 62\n",
      "Fitting Model 63\n",
      "Fitting Model 64\n",
      "Fitting Model 65\n",
      "Fitting Model 66\n",
      "Fitting Model 67\n",
      "Fitting Model 68\n",
      "Fitting Model 69\n",
      "Fitting Model 70\n",
      "Fitting Model 71\n",
      "Fitting Model 72\n",
      "Fitting Model 73\n",
      "Fitting Model 74\n",
      "Fitting Model 75\n",
      "Fitting Model 76\n",
      "Fitting Model 77\n",
      "Fitting Model 78\n",
      "Fitting Model 79\n",
      "Fitting Model 80\n",
      "Fitting Model 81\n",
      "Fitting Model 82\n",
      "Fitting Model 83\n",
      "Fitting Model 84\n",
      "Fitting Model 85\n",
      "Fitting Model 86\n",
      "Fitting Model 87\n",
      "Fitting Model 88\n",
      "Fitting Model 89\n",
      "Fitting Model 90\n",
      "Fitting Model 91\n",
      "Fitting Model 92\n",
      "Fitting Model 93\n",
      "Fitting Model 94\n",
      "Fitting Model 95\n",
      "Fitting Model 96\n",
      "Fitting Model 97\n",
      "Fitting Model 98\n",
      "Fitting Model 99\n",
      "Fitting Model 100\n",
      "Fitting Model 101\n",
      "Fitting Model 102\n",
      "Fitting Model 103\n",
      "Fitting Model 104\n",
      "Fitting Model 105\n",
      "Fitting Model 106\n",
      "Fitting Model 107\n",
      "Fitting Model 108\n",
      "Fitting Model 109\n",
      "Fitting Model 110\n",
      "Fitting Model 111\n",
      "Fitting Model 112\n",
      "Fitting Model 113\n",
      "Fitting Model 114\n",
      "Fitting Model 115\n",
      "Fitting Model 116\n",
      "Fitting Model 117\n",
      "Fitting Model 118\n",
      "Fitting Model 119\n",
      "Fitting Model 120\n",
      "Fitting Model 121\n",
      "Fitting Model 122\n",
      "Fitting Model 123\n",
      "Fitting Model 124\n",
      "Fitting Model 125\n",
      "Fitting Model 126\n",
      "Fitting Model 127\n",
      "Fitting Model 128\n",
      "Fitting Model 129\n",
      "Fitting Model 130\n",
      "Fitting Model 131\n",
      "Fitting Model 132\n",
      "Fitting Model 133\n",
      "Fitting Model 134\n",
      "Fitting Model 135\n",
      "Fitting Model 136\n",
      "Fitting Model 137\n",
      "Fitting Model 138\n",
      "Fitting Model 139\n",
      "Fitting Model 140\n",
      "Fitting Model 141\n",
      "Fitting Model 142\n",
      "Fitting Model 143\n",
      "Fitting Model 144\n",
      "Fitting Model 145\n",
      "Fitting Model 146\n",
      "Fitting Model 147\n",
      "Fitting Model 148\n",
      "Fitting Model 149\n",
      "Fitting Model 150\n",
      "Fitting Model 151\n",
      "Fitting Model 152\n",
      "Fitting Model 153\n",
      "Fitting Model 154\n",
      "Fitting Model 155\n",
      "Fitting Model 156\n",
      "Fitting Model 157\n",
      "Fitting Model 158\n",
      "Fitting Model 159\n",
      "Fitting Model 160\n",
      "Fitting Model 161\n",
      "Fitting Model 162\n",
      "Fitting Model 163\n",
      "Fitting Model 164\n",
      "Fitting Model 165\n",
      "Fitting Model 166\n",
      "Fitting Model 167\n",
      "Fitting Model 168\n",
      "Fitting Model 169\n",
      "Fitting Model 170\n",
      "Fitting Model 171\n",
      "Fitting Model 172\n",
      "Fitting Model 173\n",
      "Fitting Model 174\n",
      "Fitting Model 175\n",
      "Fitting Model 176\n",
      "Fitting Model 177\n",
      "Fitting Model 178\n",
      "Fitting Model 179\n",
      "Fitting Model 180\n",
      "Fitting Model 181\n",
      "Fitting Model 182\n",
      "Fitting Model 183\n",
      "Fitting Model 184\n",
      "Fitting Model 185\n",
      "Fitting Model 186\n",
      "Fitting Model 187\n",
      "Fitting Model 188\n",
      "Fitting Model 189\n",
      "Fitting Model 190\n",
      "Fitting Model 191\n",
      "Fitting Model 192\n",
      "Fitting Model 193\n",
      "Fitting Model 194\n",
      "Fitting Model 195\n",
      "Fitting Model 196\n",
      "Fitting Model 197\n",
      "Fitting Model 198\n",
      "Fitting Model 199\n",
      "Fitting Model 200\n",
      "Fitting Model 201\n",
      "Fitting Model 202\n",
      "Fitting Model 203\n",
      "Fitting Model 204\n",
      "Fitting Model 205\n",
      "Fitting Model 206\n",
      "Fitting Model 207\n",
      "Fitting Model 208\n",
      "Fitting Model 209\n",
      "Fitting Model 210\n",
      "Fitting Model 211\n",
      "Fitting Model 212\n",
      "Fitting Model 213\n",
      "Fitting Model 214\n",
      "Fitting Model 215\n",
      "Fitting Model 216\n",
      "Fitting Model 217\n",
      "Fitting Model 218\n",
      "Fitting Model 219\n",
      "Fitting Model 220\n",
      "Fitting Model 221\n",
      "Fitting Model 222\n",
      "Fitting Model 223\n",
      "Fitting Model 224\n",
      "Fitting Model 225\n",
      "Fitting Model 226\n",
      "Fitting Model 227\n",
      "Fitting Model 228\n",
      "Fitting Model 229\n",
      "Fitting Model 230\n",
      "Fitting Model 231\n",
      "Fitting Model 232\n",
      "Fitting Model 233\n",
      "Fitting Model 234\n",
      "Fitting Model 235\n",
      "Fitting Model 236\n",
      "Fitting Model 237\n",
      "Fitting Model 238\n",
      "Fitting Model 239\n",
      "Fitting Model 240\n",
      "Fitting Model 241\n",
      "Fitting Model 242\n",
      "Fitting Model 243\n",
      "Fitting Model 244\n",
      "Fitting Model 245\n",
      "Fitting Model 246\n",
      "Fitting Model 247\n",
      "Fitting Model 248\n",
      "Fitting Model 249\n",
      "Fitting Model 250\n",
      "Fitting Model 251\n",
      "Fitting Model 252\n",
      "Fitting Model 253\n",
      "Fitting Model 254\n",
      "Fitting Model 255\n",
      "Fitting Model 256\n",
      "Fitting Model 257\n",
      "Fitting Model 258\n",
      "Fitting Model 259\n",
      "Fitting Model 260\n",
      "Fitting Model 261\n",
      "Fitting Model 262\n",
      "Fitting Model 263\n",
      "Fitting Model 264\n",
      "Fitting Model 265\n",
      "Fitting Model 266\n",
      "Fitting Model 267\n",
      "Fitting Model 268\n",
      "Fitting Model 269\n",
      "Fitting Model 270\n",
      "Fitting Model 271\n",
      "Fitting Model 272\n",
      "Fitting Model 273\n",
      "Fitting Model 274\n",
      "Fitting Model 275\n",
      "Fitting Model 276\n",
      "Fitting Model 277\n",
      "Fitting Model 278\n",
      "Fitting Model 279\n",
      "Fitting Model 280\n",
      "Fitting Model 281\n",
      "Fitting Model 282\n",
      "Fitting Model 283\n",
      "Fitting Model 284\n",
      "Fitting Model 285\n",
      "Fitting Model 286\n",
      "Fitting Model 287\n",
      "Fitting Model 288\n",
      "Fitting Model 289\n",
      "Fitting Model 290\n",
      "Fitting Model 291\n",
      "Fitting Model 292\n",
      "Fitting Model 293\n",
      "Fitting Model 294\n",
      "Fitting Model 295\n",
      "Fitting Model 296\n",
      "Fitting Model 297\n",
      "Fitting Model 298\n",
      "Fitting Model 299\n",
      "Fitting Model 300\n",
      "Fitting Model 301\n",
      "Fitting Model 302\n",
      "Fitting Model 303\n",
      "Fitting Model 304\n",
      "Fitting Model 305\n",
      "Fitting Model 306\n",
      "Fitting Model 307\n",
      "Fitting Model 308\n",
      "Fitting Model 309\n",
      "Fitting Model 310\n",
      "Fitting Model 311\n",
      "Fitting Model 312\n",
      "Fitting Model 313\n",
      "Fitting Model 314\n",
      "Fitting Model 315\n",
      "Fitting Model 316\n",
      "Fitting Model 317\n",
      "Fitting Model 318\n",
      "Fitting Model 319\n",
      "Fitting Model 320\n",
      "Fitting Model 321\n",
      "Fitting Model 322\n",
      "Fitting Model 323\n",
      "Fitting Model 324\n",
      "Fitting Model 325\n",
      "Fitting Model 326\n",
      "Fitting Model 327\n",
      "Fitting Model 328\n",
      "Fitting Model 329\n",
      "Fitting Model 330\n",
      "Fitting Model 331\n",
      "Fitting Model 332\n",
      "Fitting Model 333\n",
      "Fitting Model 334\n",
      "Fitting Model 335\n",
      "Fitting Model 336\n",
      "Fitting Model 337\n",
      "Fitting Model 338\n",
      "Fitting Model 339\n",
      "Fitting Model 340\n",
      "Fitting Model 341\n",
      "Fitting Model 342\n",
      "Fitting Model 343\n",
      "Fitting Model 344\n",
      "Fitting Model 345\n",
      "Fitting Model 346\n",
      "Fitting Model 347\n",
      "Fitting Model 348\n",
      "Fitting Model 349\n",
      "Fitting Model 350\n",
      "Fitting Model 351\n",
      "Fitting Model 352\n",
      "Fitting Model 353\n",
      "Fitting Model 354\n",
      "Fitting Model 355\n",
      "Fitting Model 356\n",
      "Fitting Model 357\n",
      "Fitting Model 358\n",
      "Fitting Model 359\n",
      "Fitting Model 360\n",
      "Fitting Model 361\n",
      "Fitting Model 362\n",
      "Fitting Model 363\n",
      "Fitting Model 364\n",
      "Fitting Model 365\n",
      "Fitting Model 366\n",
      "Fitting Model 367\n",
      "Fitting Model 368\n",
      "Fitting Model 369\n",
      "Fitting Model 370\n",
      "Fitting Model 371\n",
      "Fitting Model 372\n",
      "Fitting Model 373\n",
      "Fitting Model 374\n",
      "Fitting Model 375\n",
      "Fitting Model 376\n",
      "Fitting Model 377\n",
      "Fitting Model 378\n",
      "Fitting Model 379\n",
      "Fitting Model 380\n",
      "Fitting Model 381\n",
      "Fitting Model 382\n",
      "Fitting Model 383\n",
      "Fitting Model 384\n",
      "Fitting Model 385\n",
      "Fitting Model 386\n",
      "Fitting Model 387\n",
      "Fitting Model 388\n",
      "Fitting Model 389\n",
      "Fitting Model 390\n",
      "Fitting Model 391\n",
      "Fitting Model 392\n",
      "Fitting Model 393\n",
      "Fitting Model 394\n",
      "Fitting Model 395\n",
      "Fitting Model 396\n",
      "Fitting Model 397\n",
      "Fitting Model 398\n",
      "Fitting Model 399\n",
      "Fitting Model 400\n",
      "Fitting Model 401\n",
      "Fitting Model 402\n",
      "Fitting Model 403\n",
      "Fitting Model 404\n",
      "Fitting Model 405\n",
      "Fitting Model 406\n",
      "Fitting Model 407\n",
      "Fitting Model 408\n",
      "Fitting Model 409\n",
      "Fitting Model 410\n",
      "Fitting Model 411\n",
      "Fitting Model 412\n",
      "Fitting Model 413\n",
      "Fitting Model 414\n",
      "Fitting Model 415\n",
      "Fitting Model 416\n",
      "Fitting Model 417\n",
      "Fitting Model 418\n",
      "Fitting Model 419\n",
      "Fitting Model 420\n",
      "Fitting Model 421\n",
      "Fitting Model 422\n",
      "Fitting Model 423\n",
      "Fitting Model 424\n",
      "Fitting Model 425\n",
      "Fitting Model 426\n",
      "Fitting Model 427\n",
      "Fitting Model 428\n",
      "Fitting Model 429\n",
      "Fitting Model 430\n",
      "Fitting Model 431\n",
      "Fitting Model 432\n",
      "Fitting Model 433\n",
      "Fitting Model 434\n",
      "Fitting Model 435\n",
      "Fitting Model 436\n",
      "Fitting Model 437\n",
      "Fitting Model 438\n",
      "Fitting Model 439\n",
      "Fitting Model 440\n",
      "Fitting Model 441\n",
      "Fitting Model 442\n",
      "Fitting Model 443\n",
      "Fitting Model 444\n",
      "Fitting Model 445\n",
      "Fitting Model 446\n",
      "Fitting Model 447\n",
      "Fitting Model 448\n",
      "Fitting Model 449\n",
      "Fitting Model 450\n",
      "Fitting Model 451\n",
      "Fitting Model 452\n",
      "Fitting Model 453\n",
      "Fitting Model 454\n",
      "Fitting Model 455\n",
      "Fitting Model 456\n",
      "Fitting Model 457\n",
      "Fitting Model 458\n",
      "Fitting Model 459\n",
      "Fitting Model 460\n",
      "Fitting Model 461\n",
      "Fitting Model 462\n",
      "Fitting Model 463\n",
      "Fitting Model 464\n",
      "Fitting Model 465\n",
      "Fitting Model 466\n",
      "Fitting Model 467\n",
      "Fitting Model 468\n",
      "Fitting Model 469\n",
      "Fitting Model 470\n",
      "Fitting Model 471\n",
      "Fitting Model 472\n",
      "Fitting Model 473\n",
      "Fitting Model 474\n",
      "Fitting Model 475\n",
      "Fitting Model 476\n",
      "Fitting Model 477\n",
      "Fitting Model 478\n",
      "Fitting Model 479\n",
      "Fitting Model 480\n",
      "Fitting Model 481\n",
      "Fitting Model 482\n",
      "Fitting Model 483\n",
      "Fitting Model 484\n",
      "Fitting Model 485\n",
      "Fitting Model 486\n",
      "Fitting Model 487\n",
      "Fitting Model 488\n",
      "Fitting Model 489\n",
      "Fitting Model 490\n",
      "Fitting Model 491\n",
      "Fitting Model 492\n",
      "Fitting Model 493\n",
      "Fitting Model 494\n",
      "Fitting Model 495\n",
      "Fitting Model 496\n",
      "Fitting Model 497\n",
      "Fitting Model 498\n",
      "Fitting Model 499\n",
      "Fitting Model 500\n",
      "Fitting Model 501\n",
      "Fitting Model 502\n",
      "Fitting Model 503\n",
      "Fitting Model 504\n",
      "Fitting Model 505\n",
      "Fitting Model 506\n",
      "Fitting Model 507\n",
      "Fitting Model 508\n",
      "Fitting Model 509\n",
      "Fitting Model 510\n",
      "Fitting Model 511\n",
      "Fitting Model 512\n",
      "Fitting Model 513\n",
      "Fitting Model 514\n",
      "Fitting Model 515\n",
      "Fitting Model 516\n",
      "Fitting Model 517\n",
      "Fitting Model 518\n",
      "Fitting Model 519\n",
      "Fitting Model 520\n",
      "Fitting Model 521\n",
      "Fitting Model 522\n",
      "Fitting Model 523\n",
      "Fitting Model 524\n",
      "Fitting Model 525\n",
      "Fitting Model 526\n",
      "Fitting Model 527\n",
      "Fitting Model 528\n",
      "Fitting Model 529\n",
      "Fitting Model 530\n",
      "Fitting Model 531\n",
      "Fitting Model 532\n",
      "Fitting Model 533\n",
      "Fitting Model 534\n",
      "Fitting Model 535\n",
      "Fitting Model 536\n",
      "Fitting Model 537\n",
      "Fitting Model 538\n",
      "Fitting Model 539\n",
      "Fitting Model 540\n",
      "Fitting Model 541\n",
      "Fitting Model 542\n",
      "Fitting Model 543\n",
      "Fitting Model 544\n",
      "Fitting Model 545\n",
      "Fitting Model 546\n",
      "Fitting Model 547\n",
      "Fitting Model 548\n",
      "Fitting Model 549\n",
      "Fitting Model 550\n",
      "Fitting Model 551\n",
      "Fitting Model 552\n",
      "Fitting Model 553\n",
      "Fitting Model 554\n",
      "Fitting Model 555\n",
      "Fitting Model 556\n",
      "Fitting Model 557\n",
      "Fitting Model 558\n",
      "Fitting Model 559\n",
      "Fitting Model 560\n",
      "Fitting Model 561\n",
      "Fitting Model 562\n",
      "Fitting Model 563\n",
      "Fitting Model 564\n",
      "Fitting Model 565\n",
      "Fitting Model 566\n",
      "Fitting Model 567\n",
      "Fitting Model 568\n",
      "Fitting Model 569\n",
      "Fitting Model 570\n",
      "Fitting Model 571\n",
      "Fitting Model 572\n",
      "Fitting Model 573\n",
      "Fitting Model 574\n",
      "Fitting Model 575\n",
      "Fitting Model 576\n",
      "Fitting Model 577\n",
      "Fitting Model 578\n",
      "Fitting Model 579\n",
      "Fitting Model 580\n",
      "Fitting Model 581\n",
      "Fitting Model 582\n",
      "Fitting Model 583\n",
      "Fitting Model 584\n",
      "Fitting Model 585\n",
      "Fitting Model 586\n",
      "Fitting Model 587\n",
      "Fitting Model 588\n",
      "Fitting Model 589\n",
      "Fitting Model 590\n",
      "Fitting Model 591\n",
      "Fitting Model 592\n",
      "Fitting Model 593\n",
      "Fitting Model 594\n",
      "Fitting Model 595\n",
      "Fitting Model 596\n",
      "Fitting Model 597\n",
      "Fitting Model 598\n",
      "Fitting Model 599\n",
      "Fitting Model 600\n",
      "Fitting Model 601\n",
      "Fitting Model 602\n",
      "Fitting Model 603\n",
      "Fitting Model 604\n",
      "Fitting Model 605\n",
      "Fitting Model 606\n",
      "Fitting Model 607\n",
      "Fitting Model 608\n",
      "Fitting Model 609\n",
      "Fitting Model 610\n",
      "Fitting Model 611\n",
      "Fitting Model 612\n",
      "Fitting Model 613\n",
      "Fitting Model 614\n",
      "Fitting Model 615\n",
      "Fitting Model 616\n",
      "Fitting Model 617\n",
      "Fitting Model 618\n",
      "Fitting Model 619\n",
      "Fitting Model 620\n",
      "Fitting Model 621\n",
      "Fitting Model 622\n",
      "Fitting Model 623\n",
      "Fitting Model 624\n",
      "Fitting Model 625\n",
      "Fitting Model 626\n",
      "Fitting Model 627\n",
      "Fitting Model 628\n",
      "Fitting Model 629\n",
      "Fitting Model 630\n",
      "Fitting Model 631\n",
      "Fitting Model 632\n",
      "Fitting Model 633\n",
      "Fitting Model 634\n",
      "Fitting Model 635\n",
      "Fitting Model 636\n",
      "Fitting Model 637\n",
      "Fitting Model 638\n",
      "Fitting Model 639\n",
      "Fitting Model 640\n",
      "Fitting Model 641\n",
      "Fitting Model 642\n",
      "Fitting Model 643\n",
      "Fitting Model 644\n",
      "Fitting Model 645\n",
      "Fitting Model 646\n",
      "Fitting Model 647\n",
      "Fitting Model 648\n",
      "Fitting Model 649\n",
      "Fitting Model 650\n",
      "Fitting Model 651\n",
      "Fitting Model 652\n",
      "Fitting Model 653\n",
      "Fitting Model 654\n",
      "Fitting Model 655\n",
      "Fitting Model 656\n",
      "Fitting Model 657\n",
      "Fitting Model 658\n",
      "Fitting Model 659\n",
      "Fitting Model 660\n",
      "Fitting Model 661\n",
      "Fitting Model 662\n",
      "Fitting Model 663\n",
      "Fitting Model 664\n",
      "Fitting Model 665\n",
      "Fitting Model 666\n",
      "Fitting Model 667\n",
      "Fitting Model 668\n",
      "Fitting Model 669\n",
      "Fitting Model 670\n",
      "Fitting Model 671\n",
      "Fitting Model 672\n",
      "Fitting Model 673\n",
      "Fitting Model 674\n",
      "Fitting Model 675\n",
      "Fitting Model 676\n",
      "Fitting Model 677\n",
      "Fitting Model 678\n",
      "Fitting Model 679\n",
      "Fitting Model 680\n",
      "Fitting Model 681\n",
      "Fitting Model 682\n",
      "Fitting Model 683\n",
      "Fitting Model 684\n",
      "Fitting Model 685\n",
      "Fitting Model 686\n",
      "Fitting Model 687\n",
      "Fitting Model 688\n",
      "Fitting Model 689\n",
      "Fitting Model 690\n",
      "Fitting Model 691\n",
      "Fitting Model 692\n",
      "Fitting Model 693\n",
      "Fitting Model 694\n",
      "Fitting Model 695\n",
      "Fitting Model 696\n",
      "Fitting Model 697\n",
      "Fitting Model 698\n",
      "Fitting Model 699\n",
      "Fitting Model 700\n",
      "Fitting Model 701\n",
      "Fitting Model 702\n",
      "Fitting Model 703\n",
      "Fitting Model 704\n",
      "Fitting Model 705\n",
      "Fitting Model 706\n",
      "Fitting Model 707\n",
      "Fitting Model 708\n",
      "Fitting Model 709\n",
      "Fitting Model 710\n",
      "Fitting Model 711\n",
      "Fitting Model 712\n",
      "Fitting Model 713\n",
      "Fitting Model 714\n",
      "Fitting Model 715\n",
      "Fitting Model 716\n",
      "Fitting Model 717\n",
      "Fitting Model 718\n",
      "Fitting Model 719\n",
      "Fitting Model 720\n",
      "Fitting Model 721\n",
      "Fitting Model 722\n",
      "Fitting Model 723\n",
      "Fitting Model 724\n",
      "Fitting Model 725\n",
      "Fitting Model 726\n",
      "Fitting Model 727\n",
      "Fitting Model 728\n",
      "Fitting Model 729\n",
      "Fitting Model 730\n",
      "Fitting Model 731\n",
      "Fitting Model 732\n",
      "Fitting Model 733\n",
      "Fitting Model 734\n",
      "Fitting Model 735\n",
      "Fitting Model 736\n",
      "Fitting Model 737\n",
      "Fitting Model 738\n",
      "Fitting Model 739\n",
      "Fitting Model 740\n",
      "Fitting Model 741\n",
      "Fitting Model 742\n",
      "Fitting Model 743\n",
      "Fitting Model 744\n",
      "Fitting Model 745\n",
      "Fitting Model 746\n",
      "Fitting Model 747\n",
      "Fitting Model 748\n",
      "Fitting Model 749\n",
      "Fitting Model 750\n",
      "Fitting Model 751\n",
      "Fitting Model 752\n",
      "Fitting Model 753\n",
      "Fitting Model 754\n",
      "Fitting Model 755\n",
      "Fitting Model 756\n",
      "Fitting Model 757\n",
      "Fitting Model 758\n",
      "Fitting Model 759\n",
      "Fitting Model 760\n",
      "Fitting Model 761\n",
      "Fitting Model 762\n",
      "Fitting Model 763\n",
      "Fitting Model 764\n",
      "Fitting Model 765\n",
      "Fitting Model 766\n",
      "Fitting Model 767\n",
      "Fitting Model 768\n",
      "Fitting Model 769\n",
      "Fitting Model 770\n",
      "Fitting Model 771\n",
      "Fitting Model 772\n",
      "Fitting Model 773\n",
      "Fitting Model 774\n",
      "Fitting Model 775\n",
      "Fitting Model 776\n",
      "Fitting Model 777\n",
      "Fitting Model 778\n",
      "Fitting Model 779\n",
      "Fitting Model 780\n",
      "Fitting Model 781\n",
      "Fitting Model 782\n",
      "Fitting Model 783\n",
      "Fitting Model 784\n",
      "Fitting Model 785\n",
      "Fitting Model 786\n",
      "Fitting Model 787\n",
      "Fitting Model 788\n",
      "Fitting Model 789\n",
      "Fitting Model 790\n",
      "Fitting Model 791\n",
      "Fitting Model 792\n",
      "Fitting Model 793\n",
      "Fitting Model 794\n",
      "Fitting Model 795\n",
      "Fitting Model 796\n",
      "Fitting Model 797\n",
      "Fitting Model 798\n",
      "Fitting Model 799\n",
      "Fitting Model 800\n",
      "Fitting Model 801\n",
      "Fitting Model 802\n",
      "Fitting Model 803\n",
      "Fitting Model 804\n",
      "Fitting Model 805\n",
      "Fitting Model 806\n",
      "Fitting Model 807\n",
      "Fitting Model 808\n",
      "Fitting Model 809\n",
      "Fitting Model 810\n",
      "Fitting Model 811\n",
      "Fitting Model 812\n",
      "Fitting Model 813\n",
      "Fitting Model 814\n",
      "Fitting Model 815\n",
      "Fitting Model 816\n",
      "Fitting Model 817\n",
      "Fitting Model 818\n",
      "Fitting Model 819\n",
      "Fitting Model 820\n",
      "Fitting Model 821\n",
      "Fitting Model 822\n",
      "Fitting Model 823\n",
      "Fitting Model 824\n",
      "Fitting Model 825\n",
      "Fitting Model 826\n",
      "Fitting Model 827\n",
      "Fitting Model 828\n",
      "Fitting Model 829\n",
      "Fitting Model 830\n",
      "Fitting Model 831\n",
      "Fitting Model 832\n",
      "Fitting Model 833\n",
      "Fitting Model 834\n",
      "Fitting Model 835\n",
      "Fitting Model 836\n",
      "Fitting Model 837\n",
      "Fitting Model 838\n",
      "Fitting Model 839\n",
      "Fitting Model 840\n",
      "Fitting Model 841\n",
      "Fitting Model 842\n",
      "Fitting Model 843\n",
      "Fitting Model 844\n",
      "Fitting Model 845\n",
      "Fitting Model 846\n",
      "Fitting Model 847\n",
      "Fitting Model 848\n",
      "Fitting Model 849\n",
      "Fitting Model 850\n",
      "Fitting Model 851\n",
      "Fitting Model 852\n",
      "Fitting Model 853\n",
      "Fitting Model 854\n",
      "Fitting Model 855\n",
      "Fitting Model 856\n",
      "Fitting Model 857\n",
      "Fitting Model 858\n",
      "Fitting Model 859\n",
      "Fitting Model 860\n",
      "Fitting Model 861\n",
      "Fitting Model 862\n",
      "Fitting Model 863\n",
      "Fitting Model 864\n",
      "Fitting Model 865\n",
      "Fitting Model 866\n",
      "Fitting Model 867\n",
      "Fitting Model 868\n",
      "Fitting Model 869\n",
      "Fitting Model 870\n",
      "Fitting Model 871\n",
      "Fitting Model 872\n",
      "Fitting Model 873\n",
      "Fitting Model 874\n",
      "Fitting Model 875\n",
      "Fitting Model 876\n",
      "Fitting Model 877\n",
      "Fitting Model 878\n",
      "Fitting Model 879\n",
      "Fitting Model 880\n",
      "Fitting Model 881\n",
      "Fitting Model 882\n",
      "Fitting Model 883\n",
      "Fitting Model 884\n",
      "Fitting Model 885\n",
      "Fitting Model 886\n",
      "Fitting Model 887\n",
      "Fitting Model 888\n",
      "Fitting Model 889\n",
      "Fitting Model 890\n",
      "Fitting Model 891\n",
      "Fitting Model 892\n",
      "Fitting Model 893\n",
      "Fitting Model 894\n",
      "Fitting Model 895\n",
      "Fitting Model 896\n",
      "Fitting Model 897\n",
      "Fitting Model 898\n",
      "Fitting Model 899\n",
      "Fitting Model 900\n",
      "Fitting Model 901\n",
      "Fitting Model 902\n",
      "Fitting Model 903\n",
      "Fitting Model 904\n",
      "Fitting Model 905\n",
      "Fitting Model 906\n",
      "Fitting Model 907\n",
      "Fitting Model 908\n",
      "Fitting Model 909\n",
      "Fitting Model 910\n",
      "Fitting Model 911\n",
      "Fitting Model 912\n",
      "Fitting Model 913\n",
      "Fitting Model 914\n",
      "Fitting Model 915\n",
      "Fitting Model 916\n",
      "Fitting Model 917\n",
      "Fitting Model 918\n",
      "Fitting Model 919\n",
      "Fitting Model 920\n",
      "Fitting Model 921\n",
      "Fitting Model 922\n",
      "Fitting Model 923\n",
      "Fitting Model 924\n",
      "Fitting Model 925\n",
      "Fitting Model 926\n",
      "Fitting Model 927\n",
      "Fitting Model 928\n",
      "Fitting Model 929\n",
      "Fitting Model 930\n",
      "Fitting Model 931\n",
      "Fitting Model 932\n",
      "Fitting Model 933\n",
      "Fitting Model 934\n",
      "Fitting Model 935\n",
      "Fitting Model 936\n",
      "Fitting Model 937\n",
      "Fitting Model 938\n",
      "Fitting Model 939\n",
      "Fitting Model 940\n",
      "Fitting Model 941\n",
      "Fitting Model 942\n",
      "Fitting Model 943\n",
      "Fitting Model 944\n",
      "Fitting Model 945\n",
      "Fitting Model 946\n",
      "Fitting Model 947\n",
      "Fitting Model 948\n",
      "Fitting Model 949\n",
      "Fitting Model 950\n",
      "Fitting Model 951\n",
      "Fitting Model 952\n",
      "Fitting Model 953\n",
      "Fitting Model 954\n",
      "Fitting Model 955\n",
      "Fitting Model 956\n",
      "Fitting Model 957\n",
      "Fitting Model 958\n",
      "Fitting Model 959\n",
      "Fitting Model 960\n",
      "Fitting Model 961\n",
      "Fitting Model 962\n",
      "Fitting Model 963\n",
      "Fitting Model 964\n",
      "Fitting Model 965\n",
      "Fitting Model 966\n",
      "Fitting Model 967\n",
      "Fitting Model 968\n",
      "Fitting Model 969\n",
      "Fitting Model 970\n",
      "Fitting Model 971\n",
      "Fitting Model 972\n",
      "Fitting Model 973\n",
      "Fitting Model 974\n",
      "Fitting Model 975\n",
      "Fitting Model 976\n",
      "Fitting Model 977\n",
      "Fitting Model 978\n",
      "Fitting Model 979\n",
      "Fitting Model 980\n",
      "Fitting Model 981\n",
      "Fitting Model 982\n",
      "Fitting Model 983\n",
      "Fitting Model 984\n",
      "Fitting Model 985\n",
      "Fitting Model 986\n",
      "Fitting Model 987\n",
      "Fitting Model 988\n",
      "Fitting Model 989\n",
      "Fitting Model 990\n",
      "Fitting Model 991\n",
      "Fitting Model 992\n",
      "Fitting Model 993\n",
      "Fitting Model 994\n",
      "Fitting Model 995\n",
      "Fitting Model 996\n",
      "Fitting Model 997\n",
      "Fitting Model 998\n",
      "Fitting Model 999\n",
      "Fitting Model 1000\n",
      "Fitting Model 1001\n",
      "Fitting Model 1002\n",
      "Fitting Model 1003\n",
      "Fitting Model 1004\n",
      "Fitting Model 1005\n",
      "Fitting Model 1006\n",
      "Fitting Model 1007\n",
      "Fitting Model 1008\n",
      "Fitting Model 1009\n",
      "Fitting Model 1010\n",
      "Fitting Model 1011\n",
      "Fitting Model 1012\n",
      "Fitting Model 1013\n",
      "Fitting Model 1014\n",
      "Fitting Model 1015\n",
      "Fitting Model 1016\n",
      "Fitting Model 1017\n",
      "Fitting Model 1018\n",
      "Fitting Model 1019\n",
      "Fitting Model 1020\n",
      "Fitting Model 1021\n",
      "Fitting Model 1022\n",
      "Fitting Model 1023\n"
     ]
    }
   ],
   "source": [
    "pca_proj = PCAProjectionEnsemble(nmodels=2**10, ndirs=64, Vpca=np.eye(NDIRS, dtype=np.float32))\n",
    "pca_proj.fit(X, Y)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 43,
   "metadata": {},
   "outputs": [],
   "source": [
    "# with open(os.path.join(BASE_DIR +'/' + EXP_NAME + '/' + dname, 'pca_projens_1024.p'), 'rb') as f:\n",
    "#     pca_proj = pickle.load(f)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 44,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 489
    },
    "id": "1oNxyeimp_iN",
    "outputId": "b3206c6c-8b1b-4ba1-c3b3-d7c680e777b4"
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_1533261/3828342236.py:11: RuntimeWarning: invalid value encountered in scalar divide\n",
      "  precision = [tp/(tp+fp) for tp, fp in zip(tps, fps)]\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7f39a38cf4d0>"
      ]
     },
     "execution_count": 44,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAksAAAHFCAYAAADi7703AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy81sbWrAAAACXBIWXMAAA9hAAAPYQGoP6dpAACQaUlEQVR4nOzdeVxU5f7A8c8AAww7CAKC4i4g7rigqblhbpk3xbJMvVgaVi63flczc2kxLRW9iWVXxbzue4upWLkF7ru47wooIArKDuf3hzA5sgg4MIDf9+vFS+aZ53znew4D8/U5z3mOSlEUBSGEEEIIkS8jQycghBBCCFGeSbEkhBBCCFEIKZaEEEIIIQohxZIQQgghRCGkWBJCCCGEKIQUS0IIIYQQhZBiSQghhBCiEFIsCSGEEEIUQoolIYQQQohCSLFUCYSGhqJSqbRfJiYmuLu7M2zYMG7dulXm+QwdOpSaNWsWa5urV6+iUqkIDQ0tlZwMaejQoTo/H1NTU+rUqcOHH35IYmKiodPL99jnvqeuXr1a6LZTpkxBpVIRFxdXKrnt3LlT59gV9lUW+RRXaeTz4osv8uKLLz61X34/19x8DCH3tQv6etp7rbzL/Z05dOjQU/uW5G/k0+zfv59+/fpRo0YNzMzMcHZ2xs/Pj3/96186/UJCQor1dzb3d3Dnzp16zbeiMTF0AkJ/lixZgqenJykpKezevZvp06eza9cuTp48iaWlZZnlMWnSJEaPHl2sbVxdXYmIiKBOnTqllJVhaTQa/vjjDwDu3bvHunXrmDVrFidOnGD79u0Gzq78at68ORERETpt/fr1o06dOnzzzTcGyqriGj58OC+99JJBc9i6dSu2trZ52l1dXQ2QTeXw66+/8vLLL/Piiy8yc+ZMXF1diY6O5tChQ6xatYpZs2Zp+4aEhODo6MjQoUMNl3AFJMVSJeLj44Ovry8AnTp1Iisri88++4xNmzbxxhtv5LtNcnIyFhYWes2jJAWPmZkZbdq00Wse5YmRkZHO/r300ktcvnyZsLAwrly5Qq1atQyYXfllY2OT531hZmaGnZ2d3t8viqKQmpqKRqPRa9zyxN3dHXd3d4Pm0KJFCxwdHQ2aQ2Uzc+ZMatWqxbZt2zAx+ftj/bXXXmPmzJkGzKzykNNwlVjuh8m1a9eAR0O/VlZWnDx5En9/f6ytrenSpQsA6enpfP7553h6emJmZoaTkxPDhg0jNjY2T9wVK1bg5+eHlZUVVlZWNG3alEWLFmmfz2+Iee3atbRu3RpbW1ssLCyoXbs2//znP7XPF3Qabu/evXTp0gVra2ssLCxo27Ytv/76q06f3OHvP//8k3fffRdHR0eqVKnCP/7xD6Kiogo9RsHBwahUKi5evJjnuX//+9+YmppqT6EcPXqU3r17U7VqVczMzKhWrRq9evXi5s2bhb5GQXIL29u3b+u0r169Gj8/PywtLbGysqJ79+4cPXo0z/b79++nT58+VKlSBXNzc+rUqcOYMWO0z1+8eJFhw4ZRr149LCwscHNzo0+fPpw8ebJE+Rbmxo0b/OMf/8DGxgZbW1vefPNNnfdOYGAgDg4OJCcn59m2c+fONGzYUK/53L59m9dffx1bW1ucnZ355z//yf3793X6qFQq3nvvPb777ju8vLwwMzNj6dKlAFy4cIFBgwZpf9ZeXl7Mnz9fZ/vs7Gw+//xzGjRogEajwc7OjsaNGzN37twS5ZOamsqECROoVasWpqamuLm5MWrUKO7du/fU/Y2KiiIgIABra2tsbW0ZOHAgMTExefrldxquZs2a9O7dm61bt9K8eXM0Gg2enp4sXrw4z/Z79+7Fz88Pc3Nz3NzcmDRpEv/973/1ehot92/BN998w+zZs6lVqxZWVlb4+fmxb98+nb6XL1/mtddeo1q1atpTT126dOHYsWM6/YryO5X79/Hs2bN0794dS0tLXF1d+eqrrwDYt28fL7zwApaWltSvX1/7XnlSQkICw4YNw8HBAUtLS/r06cPly5efut+KohASEkLTpk3RaDTY29vTv3//Im0bHx+Po6OjTqGUy8jo74/5mjVrcvr0aXbt2qU9/fn43+qzZ8/y0ksvYWFhgaOjIyNHjiQpKempr/88kGKpEsstAJycnLRt6enpvPzyy3Tu3JnNmzczdepUsrOz6du3L1999RWDBg3i119/5auvviIsLIwXX3yRlJQU7faffvopb7zxBtWqVSM0NJSNGzcyZMgQbUGWn4iICAYOHEjt2rVZtWoVv/76K59++imZmZmF5r9r1y46d+7M/fv3WbRoEStXrsTa2po+ffqwevXqPP2HDx+OWq1mxYoVzJw5k507d/Lmm28W+hpvvvkmpqameYq0rKws/ve//9GnTx8cHR15+PAh3bp14/bt28yfP5+wsDCCg4OpUaNGif+YXLlyBRMTE2rXrq1t+/LLL3n99dfx9vZmzZo1LFu2jKSkJNq3b09kZKS237Zt22jfvj3Xr19n9uzZ/Pbbb3zyySc6hVdUVBRVqlThq6++YuvWrcyfPx8TExNat27NuXPnSpRzQfr160fdunVZt24dU6ZMYdOmTXTv3p2MjAwARo8eTUJCAitWrNDZLjIykj///JNRo0bpNZ9XX32V+vXrs379esaPH8+KFSsYO3Zsnn6bNm1iwYIFfPrpp9pjGhkZScuWLTl16hSzZs3il19+oVevXnzwwQdMnTpVu+3MmTOZMmUKr7/+Or/++iurV68mMDAw3+LmafkoisIrr7zCN998w+DBg/n1118ZN24cS5cupXPnzqSlpRW4rykpKXTt2pXt27czffp01q5di4uLCwMHDizy8Tp+/Dj/+te/GDt2LJs3b6Zx48YEBgaye/dubZ8TJ07QrVs3kpOTWbp0Kd999x1Hjhzhiy++KPLrwKPfrczMTJ2vrKysPP0e/z1bvnw5Dx8+pGfPnjpFZs+ePTl8+DAzZ84kLCyMBQsW0KxZM52fQVF/pwAyMjL4xz/+Qa9evdi8eTM9evRgwoQJfPzxxwwZMoR//vOfbNy4kQYNGjB06FAOHz6cJ+/AwECMjIxYsWIFwcHBHDhwgBdffPGpRe+IESMYM2YMXbt2ZdOmTYSEhHD69Gnatm2b5z9UT/Lz82P//v188MEH7N+/X/t796SNGzdSu3ZtmjVrRkREBBEREWzcuBF4VNB37NiRU6dOERISwrJly3jw4AHvvfdeoa/93FBEhbdkyRIFUPbt26dkZGQoSUlJyi+//KI4OTkp1tbWSkxMjKIoijJkyBAFUBYvXqyz/cqVKxVAWb9+vU77wYMHFUAJCQlRFEVRLl++rBgbGytvvPFGofkMGTJE8fDw0D7+5ptvFEC5d+9egdtcuXJFAZQlS5Zo29q0aaNUrVpVSUpK0rZlZmYqPj4+iru7u5Kdna2z/0FBQToxZ86cqQBKdHR0ofn+4x//UNzd3ZWsrCxt25YtWxRA+fnnnxVFUZRDhw4pgLJp06ZCY+VnyJAhiqWlpZKRkaFkZGQocXFxyoIFCxQjIyPl448/1va7fv26YmJiorz//vs62yclJSkuLi5KQECAtq1OnTpKnTp1lJSUlCLnkZmZqaSnpyv16tVTxo4dq23P79jnHtMrV64UGnPy5MkKoBNPURRl+fLlCqD873//07Z17NhRadq0qU6/d999V7GxsdH5GT+Nh4eH0qtXr0LzmTlzpk57UFCQYm5urn3PKIqiAIqtra1y9+5dnb7du3dX3N3dlfv37+u0v/fee4q5ubm2f+/evfPsT0nz2bp1a779Vq9erQDKwoULtW0dO3ZUOnbsqH28YMECBVA2b96ss+3bb7+d5+eam8/jPDw8FHNzc+XatWvatpSUFMXBwUEZMWKEtm3AgAGKpaWlEhsbq23LyspSvL29i/Veye+rTp062n6578dGjRopmZmZ2vYDBw4ogLJy5UpFURQlLi5OAZTg4OACX7M4v1O5fx8f/zuYkZGhODk5KYBy5MgRbXt8fLxibGysjBs3TtuW+zvTr18/ndf666+/FED5/PPPdV7r8b+RERERCqDMmjVLZ9sbN24oGo1G+b//+78C9zH3WLzwwgva46lWq5W2bdsq06dPz/O71bBhQ533T65///vfikqlUo4dO6bT3q1bNwVQ/vzzz0JzqOxkZKkSadOmDWq1Gmtra3r37o2Liwu//fYbzs7OOv1effVVnce//PILdnZ29OnTR+d/e02bNsXFxUV7FURYWBhZWVnFHgVo2bIlAAEBAaxZs6ZIV+g9fPiQ/fv3079/f6ysrLTtxsbGDB48mJs3b+YZHXn55Zd1Hjdu3Big0FEvgGHDhnHz5k127NihbVuyZAkuLi706NEDgLp162Jvb8+///1vvvvuuzz/Iy3K/qjVatRqNY6Ojrz77rsMHDhQ53/l27ZtIzMzk7feekvn52Bubk7Hjh21P4fz589z6dIlAgMDMTc3L/A1MzMz+fLLL/H29sbU1BQTExNMTU25cOECZ86cKVb+T/PknLiAgABMTEz4888/tW2jR4/m2LFj/PXXXwAkJiaybNkyhgwZovMz1of83gupqancuXNHp71z587Y29trH6empvL777/Tr18/LCwsdH4OPXv2JDU1VXsqqFWrVhw/fpygoCC2bdtW6JWNT8snd/L/k5NuBwwYgKWlJb///nuBsf/880+sra3zvMagQYMK3OZJTZs2pUaNGtrH5ubm1K9fX+d3J3ek9/H5RkZGRgQEBBT5dQB27NjBwYMHdb42bdqUp1+vXr0wNjbWPn7y99nBwYE6derw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vED79u159913qVmzJklJSVy8eJGff/5ZO7+oT58+2rXNnJycuHbtGsHBwXh4eFCvXr1ivWa3bt3o3r07//73v0lMTKRdu3acOHGCyZMn06xZMwYPHlzgtm+99RZz5szhrbfe4osvvqBevXps2bKFbdu2PdNxeNLEiRP5+eef6dKlCxMnTkSj0fDdd9/x8OFDQPcS9cIcPnw430Upvb2980wRKMyJEyd47733GDBgAPXq1cPU1JQ//viDEydOaEd6a9asWeTfKX05dOgQw4cPZ8CAAdy4cYOJEyfi5uZGUFBQgdu0a9eOd955h2HDhnHo0CE6dOiApaUl0dHR7N27l0aNGvHuu+8WuH337t1xd3enT58+eHp6kp2dzbFjx5g1axZWVlY6iwTnjpCvXr2a2rVrY25uTqNGjRgzZgyLFy+mV69efP755zg7O7N8+XLOnj2r1+NTYRlydrnQj9yrMA4ePFhov9yrsvKTkZGhfPPNN0qTJk0Uc3NzxcrKSvH09FRGjBihXLhwQafvjz/+qLRs2VLbr1mzZjpX3Dx5pccvv/yi9OjRQ3Fzc1NMTU2VqlWrKj179lT27Nmj7ZPfFVmKoih79uxROnfurFhaWioajUZp06aN9gq1p+3/n3/+WayrOBYuXKgAikajyXMl1NmzZ5XXX39dqVOnjqLRaBRbW1ulVatWSmho6FPjFnbcT548qRgZGSnDhg3Ttm3atEnp1KmTYmNjo5iZmSkeHh5K//79lR07duhsGxERofTo0UOxtbVVzMzMlDp16uhclZaQkKAEBgYqVatWVSwsLJQXXnhB2bNnT56rqfRxNdzhw4eVPn36KFZWVoq1tbXy+uuvK7dv3853m507dyqA8tVXXxUauyBFuRru8Su2CtofQBk1alS+ca5cuaL885//VNzc3BS1Wq04OTkpbdu21bmiadasWUrbtm0VR0dHxdTUVKlRo4YSGBioXL16tUT5pKSkKP/+978VDw8PRa1WK66ursq7776rJCQk6Gz75M9PURTl5s2byquvvqo9/q+++qoSHh5e5Kvh8jue+b3Onj17lNatWytmZmaKi4uL8tFHHykzZsx46tWuj792QV9hYWGKovz9fvz666/zxACUyZMnK4qiKLdv31aGDh2qeHp6KpaWloqVlZXSuHFjZc6cOTpX0SlK0X6nCvo97dixo9KwYcM8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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "ens_preds_pca, mp_pca, sp_pca = pca_proj.predict(external_X, return_only_prediction=False)\n",
    "threshs = sp_pca\n",
    "ens_preds = ens_preds_pca\n",
    "std_threshs = np.linspace(np.min(threshs), np.max(threshs), 100)\n",
    "reject_rate = [1 - np.mean((threshs<=s)) for s in std_threshs]\n",
    "accus = [np.mean((ens_preds==external_Y)[(threshs<=s)]) for s in std_threshs]\n",
    "tps = [np.sum(((external_Y)*(ens_preds==external_Y))[(threshs<=s)]) for s in std_threshs]  # correct and positive\n",
    "fps = [np.sum(((ens_preds)*(ens_preds!=external_Y))[(threshs<=s)]) for s in std_threshs]  # incorrect and predicted positive\n",
    "pos = np.sum(external_Y)\n",
    "recall = [tp/pos for tp in tps]\n",
    "precision = [tp/(tp+fp) for tp, fp in zip(tps, fps)]\n",
    "plt.plot(recall, precision, marker='+', c='brown')\n",
    "\n",
    "plt.xticks(np.arange(0, 1.01, step=0.1))\n",
    "plt.xticks(np.arange(0, 1.01, step=0.05), minor=True)\n",
    "plt.yticks(np.arange(0.6, 1.01, step=0.05))\n",
    "plt.grid(True, which='both')\n",
    "plt.xlabel('Recall ({} Positive)'.format(int(pos)))\n",
    "plt.ylabel('Precision')\n",
    "plt.title('Precision vs Recall by Thresholding Ensemble Std')\n",
    "plt.legend(['Vanilla', 'PCA'])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 45,
   "metadata": {
    "id": "8zBUa9f9b47h"
   },
   "outputs": [],
   "source": [
    "AUCTHRESHS = [0.1, 0.2, 0.3, 0.4, 1.0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 46,
   "metadata": {
    "id": "8vubaemycBI1"
   },
   "outputs": [],
   "source": [
    "TEACHER_AUC = auprc_threshs(mp_pca, external_Y, AUCTHRESHS)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 47,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "SSAgw0c0VIEn",
    "outputId": "e5db4473-35f0-4ea9-d9b4-2f60d1321e7c"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[0.97261434 0.95054931 0.91292666 0.87937477 0.72737865]\n"
     ]
    }
   ],
   "source": [
    "print(TEACHER_AUC)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 48,
   "metadata": {
    "id": "T-BQxXkAXn-J"
   },
   "outputs": [],
   "source": [
    "precision, recall, thresholds = metrics.precision_recall_curve(external_Y, mp_pca)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 49,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "Cb8PEUiRX7lW",
    "outputId": "250faf4b-8059-43cc-ef75-84ab43e2892f"
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.7273786540545522"
      ]
     },
     "execution_count": 49,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "metrics.auc(recall, precision)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 50,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 489
    },
    "id": "thqnjpfdtMML",
    "outputId": "facbed5d-9638-498a-c703-bbf59af087a2"
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_1533261/3006512206.py:28: RuntimeWarning: invalid value encountered in scalar divide\n",
      "  precision = [tp/(tp+fp) for tp, fp in zip(tps, fps)]\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7f39a3764590>"
      ]
     },
     "execution_count": 50,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "logreg_preds = get_preds(external_X, logreg_estimators, use_proba=True)\n",
    "ens_preds_logreg, mp_logreg, sp_logreg = aggregate_preds(logreg_preds, use_bernoulli_std=True)\n",
    "\n",
    "ens_preds_pca, mp_pca, sp_pca = pca_proj.predict(external_X, return_only_prediction=False)\n",
    "\n",
    "ens_mp = .5*mp_logreg+.5*mp_pca\n",
    "ens_preds = np.float32((.5*mp_logreg+.5*mp_pca)>.5)\n",
    "threshs = np.sqrt(ens_mp*(1-ens_mp))\n",
    "std_threshs = np.linspace(np.min(threshs), np.max(threshs), 100)\n",
    "reject_rate = [1 - np.mean((threshs<=s)) for s in std_threshs]\n",
    "accus = [np.mean((ens_preds==external_Y)[(threshs<=s)]) for s in std_threshs]\n",
    "tps = [np.sum(((external_Y)*(ens_preds==external_Y))[(threshs<=s)]) for s in std_threshs]  # correct and positive\n",
    "fps = [np.sum(((ens_preds)*(ens_preds!=external_Y))[(threshs<=s)]) for s in std_threshs]  # incorrect and predicted positive\n",
    "pos = np.sum(external_Y)\n",
    "recall = [tp/pos for tp in tps]\n",
    "precision = [tp/(tp+fp) for tp, fp in zip(tps, fps)]\n",
    "plt.plot(recall, precision, marker='+', c='brown')\n",
    "\n",
    "threshs = sp_pca\n",
    "ens_preds = ens_preds_pca\n",
    "std_threshs = np.linspace(np.min(threshs), np.max(threshs), 100)\n",
    "reject_rate = [1 - np.mean((threshs<=s)) for s in std_threshs]\n",
    "accus = [np.mean((ens_preds==external_Y)[(threshs<=s)]) for s in std_threshs]\n",
    "tps = [np.sum(((external_Y)*(ens_preds==external_Y))[(threshs<=s)]) for s in std_threshs]  # correct and positive\n",
    "fps = [np.sum(((ens_preds)*(ens_preds!=external_Y))[(threshs<=s)]) for s in std_threshs]  # incorrect and predicted positive\n",
    "pos = np.sum(external_Y)\n",
    "recall = [tp/pos for tp in tps]\n",
    "precision = [tp/(tp+fp) for tp, fp in zip(tps, fps)]\n",
    "plt.plot(recall, precision, marker='+', c='red')\n",
    "\n",
    "\n",
    "plt.xticks(np.arange(0, 1.01, step=0.1))\n",
    "plt.xticks(np.arange(0, 1.01, step=0.05), minor=True)\n",
    "plt.yticks(np.arange(0.6, 1.01, step=0.05))\n",
    "plt.grid(True, which='both')\n",
    "plt.xlabel('Recall ({} Positive)'.format(int(pos)))\n",
    "plt.ylabel('Precision')\n",
    "plt.title('Precision vs Recall by Thresholding Ensemble Std')\n",
    "plt.legend(['Logistic+XGB', 'Only XGB'])"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "BSc49LGOxACU"
   },
   "source": [
    "Mine for uncertain examples"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 51,
   "metadata": {
    "id": "VhsbsS3b00fZ"
   },
   "outputs": [],
   "source": [
    "def knn_gibbs(Xsamp, X, nn_featinds, k):\n",
    "  Xf = X[:, nn_featinds]\n",
    "  Xsf = Xsamp[:, nn_featinds]\n",
    "  Xfnorm2 = np.sum(Xf**2, keepdims=True)\n",
    "  Xsfnorm2 = np.sum(Xsf**2, keepdims=True)\n",
    "  dotsf = Xsf@Xf.T\n",
    "  distsf = Xsfnorm2 + Xfnorm2.T - 2*dotsf\n",
    "  sortdistsf = np.argsort(distsf, axis=1)\n",
    "  # neighs = sortdistsf[:, np.random.choice(k, size=(X.shape[0], ))]\n",
    "  neighs = sortdistsf[np.arange(Xsamp.shape[0]), np.random.choice(k, size=(X.shape[0], ))]\n",
    "  Xsamp = np.copy(Xsamp)\n",
    "  Xsamp[:, np.logical_not(nn_featinds)] = X[neighs, :][:, np.logical_not(nn_featinds)]\n",
    "  return Xsamp\n",
    "\n",
    "def gibbs_sample(X, k, nrounds):\n",
    "  Xsamp = X\n",
    "  for r in range(nrounds):\n",
    "    featinds = np.random.rand(X.shape[1])<.5\n",
    "    Xsamp = knn_gibbs(Xsamp, X, featinds, k)\n",
    "    Xsamp = knn_gibbs(Xsamp, X, np.logical_not(featinds), k)\n",
    "  return Xsamp\n",
    "\n",
    "def permute_expand(X):\n",
    "  N, d = X.shape\n",
    "  return np.stack([X[np.random.permutation(N), i] for i in range(d)], -1)\n",
    "\n",
    "def convex_expand(X):\n",
    "  N, d = X.shape\n",
    "  X1 = X[np.random.permutation(N), :]\n",
    "  alphas = np.random.rand(N, 1)\n",
    "  return alphas*X + (1-alphas)*X1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 52,
   "metadata": {
    "id": "nMFXxF3r1Ux8"
   },
   "outputs": [],
   "source": [
    "expand_funcs = [\n",
    "    # lambda x: gibbs_sample(x, 40, 2),\n",
    "    # lambda x: permute_expand(x),\n",
    "    # lambda x: convex_expand(x),\n",
    "    lambda x: x*(1+np.abs(np.random.randn(x.shape[0], 1)))\n",
    "]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 53,
   "metadata": {
    "id": "wbZJQblJE35k"
   },
   "outputs": [],
   "source": [
    "class DatasetDiscriminator(tf.keras.Model):\n",
    "  def __init__(self, dim, nhidden_layers=2, hidden_size=256, out_size=64, net=None):\n",
    "    super(DatasetDiscriminator, self).__init__()\n",
    "\n",
    "    self.dim = dim\n",
    "    if net is not None:\n",
    "      self.net = net\n",
    "    else:\n",
    "      layers = [\n",
    "        tf.keras.layers.Dense(\n",
    "            hidden_size, activation=tf.nn.elu) for _ in range(nhidden_layers)] + \\\n",
    "            [tf.keras.layers.Dense(out_size)]\n",
    "      self.net = tf.keras.Sequential(layers)\n",
    "\n",
    "    # self.beta = tf.Variable(\n",
    "    #  tf.random.normal([out_size, 1], stddev=0.01), name='beta')\n",
    "\n",
    "  def get_features(self, x_in):\n",
    "    # print(x_in.shape)\n",
    "    feats = self.net(x_in)\n",
    "    # print(feats.shape)\n",
    "    return feats\n",
    "\n",
    "  def __call__(self, x_in):\n",
    "    return self.get_features(x_in)\n",
    "\n",
    "  def predictions(self, x_in):\n",
    "    return tf.nn.sigmoid(self.get_features(x_in))\n",
    "\n",
    "  # def get_logits(self, x_in):\n",
    "  #   return tf.matmul(self.get_features(x_in), self.beta)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 54,
   "metadata": {
    "id": "gbIGqE5nr86Z"
   },
   "outputs": [],
   "source": [
    "def smooth_maximum(v, temp=1.0):\n",
    "  softmaxv = tf.nn.softmax(v/temp, axis=-1)\n",
    "  return tf.reduce_sum(v*softmaxv, axis=-1, keepdims=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 55,
   "metadata": {
    "id": "hMSLzFqAr9vb"
   },
   "outputs": [],
   "source": [
    "def sigmoid_entropy(logits, normalize=False):\n",
    "  NORM = 0.6931471805599453  # -np.log(.5)\n",
    "  p = tf.nn.sigmoid(logits)\n",
    "  entropy = p*tf.nn.softplus(-logits) + (1.-p)*tf.nn.softplus(logits)\n",
    "  if normalize:\n",
    "    return entropy/NORM\n",
    "  return entropy"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 56,
   "metadata": {
    "id": "44YxSZgIe2G8"
   },
   "outputs": [],
   "source": [
    "# def loss(model, inputs, labels, inputs_conf, labels_conf, alpha=0.5):\n",
    "#   conf_loss = tf.reduce_mean(\n",
    "#       tf.keras.losses.binary_crossentropy(labels_conf, model.get_features(inputs_conf), from_logits=True))\n",
    "#   in_probs = tf.reduce_mean(tf.nn.sigmoid(model.get_features(inputs)), 1, keepdims=True)\n",
    "#   in_loss = tf.reduce_mean(tf.abs(labels-in_probs))\n",
    "#   return alpha*in_loss + (1-alpha)*conf_loss"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 57,
   "metadata": {
    "id": "XAFjz88dGLeo"
   },
   "outputs": [],
   "source": [
    "def training_batch(data, llks, batchsize):\n",
    "  def generate_batch():\n",
    "    rprm_in = np.random.permutation(data.shape[0])\n",
    "    if len(llks.shape)==1:\n",
    "      return data[rprm_in[:batchsize], :], llks[rprm_in[:batchsize], None]\n",
    "    return data[rprm_in[:batchsize], :], llks[rprm_in[:batchsize]]\n",
    "  return generate_batch"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 58,
   "metadata": {
    "id": "b2QZCRh04rnj"
   },
   "outputs": [],
   "source": [
    "X_train = X  # X[~train_low_conf_ind]\n",
    "labels_train = Y[:, None]  # Y[~train_low_conf_ind, None]\n",
    "\n",
    "train_predictions = pca_proj.predictions(X)\n",
    "train_ens_preds, train_mp, train_sp = pca_proj.predict(preds=train_predictions, return_only_prediction=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "k4v2lSfWgq7v"
   },
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 59,
   "metadata": {
    "id": "qnS-1z_sgrbE"
   },
   "outputs": [],
   "source": [
    "expand_funcs = [\n",
    "    # lambda x: gibbs_sample(x, 40, 2),\n",
    "    lambda x: permute_expand(x),\n",
    "    lambda x: convex_expand(x),\n",
    "    lambda x: x*(1+np.abs(np.random.randn(x.shape[0], 1)))\n",
    "]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 61,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "rj3Yvj1BxaZI",
    "outputId": "b2e9d09d-6c41-46ec-8094-9550a49ecaa8"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[[[[[[[[[[[[[[[[[[[[[  0  ]]]]]]]]]]]]]]]]]]]]]]\n",
      ">>>>>>>>0\n",
      "1011 21\n",
      ">>>>>>>>1\n",
      "450 957\n",
      ">>>>>>>>2\n",
      "477 961\n",
      "[[[[[[[[[[[[[[[[[[[[[[  1  ]]]]]]]]]]]]]]]]]]]]]]\n",
      ">>>>>>>>0\n",
      "969 31\n",
      ">>>>>>>>1\n",
      "486 930\n",
      ">>>>>>>>2\n",
      "462 980\n",
      "[[[[[[[[[[[[[[[[[[[[[[  2  ]]]]]]]]]]]]]]]]]]]]]]\n",
      ">>>>>>>>0\n",
      "1013 19\n",
      ">>>>>>>>1\n",
      "446 971\n",
      ">>>>>>>>2\n",
      "461 996\n",
      "[[[[[[[[[[[[[[[[[[[[[[  3  ]]]]]]]]]]]]]]]]]]]]]]\n",
      ">>>>>>>>0\n",
      "981 18\n",
      ">>>>>>>>1\n",
      "481 920\n",
      ">>>>>>>>2\n",
      "462 972\n",
      "[[[[[[[[[[[[[[[[[[[[[[  4  ]]]]]]]]]]]]]]]]]]]]]]\n",
      ">>>>>>>>0\n",
      "1006 19\n",
      ">>>>>>>>1\n",
      "469 929\n",
      ">>>>>>>>2\n",
      "483 999\n",
      "[[[[[[[[[[[[[[[[[[[[[[  5  ]]]]]]]]]]]]]]]]]]]]]]\n",
      ">>>>>>>>0\n",
      "1053 24\n",
      ">>>>>>>>1\n",
      "446 923\n",
      ">>>>>>>>2\n",
      "481 994\n",
      "[[[[[[[[[[[[[[[[[[[[[[  6  ]]]]]]]]]]]]]]]]]]]]]]\n",
      ">>>>>>>>0\n",
      "992 24\n",
      ">>>>>>>>1\n",
      "469 901\n",
      ">>>>>>>>2\n",
      "454 925\n",
      "[[[[[[[[[[[[[[[[[[[[[[  7  ]]]]]]]]]]]]]]]]]]]]]]\n",
      ">>>>>>>>0\n",
      "1013 22\n",
      ">>>>>>>>1\n",
      "447 938\n",
      ">>>>>>>>2\n",
      "471 952\n",
      "[[[[[[[[[[[[[[[[[[[[[[  8  ]]]]]]]]]]]]]]]]]]]]]]\n",
      ">>>>>>>>0\n",
      "1019 25\n",
      ">>>>>>>>1\n",
      "456 961\n",
      ">>>>>>>>2\n",
      "466 969\n",
      "[[[[[[[[[[[[[[[[[[[[[[  9  ]]]]]]]]]]]]]]]]]]]]]]\n",
      ">>>>>>>>0\n",
      "1010 25\n",
      ">>>>>>>>1\n",
      "478 942\n",
      ">>>>>>>>2\n",
      "469 1000\n"
     ]
    }
   ],
   "source": [
    "conf_range = .1\n",
    "conf_expX = []\n",
    "conf_exppreds = []\n",
    "unconf_expX = []\n",
    "unconf_exppreds = []\n",
    "all_expX = []\n",
    "all_exppreds = []\n",
    "for dexptrl in range(10):\n",
    "  print('[[[[[[[[[[[[[[[[[[[[[[  {}  ]]]]]]]]]]]]]]]]]]]]]]'.format(dexptrl))\n",
    "  for trnd, expfunc in enumerate(expand_funcs):\n",
    "    print('>>>>>>>>{}'.format(trnd))\n",
    "    # print('[[[[[[[[[[[[[[[[[[[[[[]]]]]]]]]]]]]]]]]]]]]]')\n",
    "\n",
    "    expanded_X = expfunc(X)\n",
    "    preds_exp = pca_proj.predictions(expanded_X)\n",
    "    ens_preds_exp, mp_exp, sp_exp = pca_proj.predict(preds=preds_exp, return_only_prediction=False)\n",
    "\n",
    "    low_conf_ind = np.logical_and(\n",
    "      np.greater(mp_exp, .5-conf_range/2), np.less(mp_exp, .5+conf_range/2))\n",
    "    unconf_expX.append(expanded_X[low_conf_ind])\n",
    "    unconf_exppreds.append(preds_exp[low_conf_ind])\n",
    "\n",
    "    # TODO: make on all?\n",
    "    all_expX.append(expanded_X[~low_conf_ind])\n",
    "    all_exppreds.append(preds_exp[~low_conf_ind])\n",
    "\n",
    "    high_conf_ind = np.logical_or(\n",
    "      np.greater(mp_exp, 1-conf_range/2), np.less(mp_exp, conf_range/2))\n",
    "    conf_expX.append(expanded_X[high_conf_ind])\n",
    "    conf_exppreds.append(preds_exp[high_conf_ind])\n",
    "\n",
    "    print(np.sum(low_conf_ind), np.sum(high_conf_ind))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "Z8-NJ_CK3qUY"
   },
   "outputs": [],
   "source": [
    "unconf_expX = np.concatenate(unconf_expX, 0)\n",
    "unconf_exppreds = np.concatenate(unconf_exppreds, 0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "oQTlC7F44xe1"
   },
   "outputs": [],
   "source": [
    "conf_expX = np.concatenate(conf_expX, 0)\n",
    "conf_exppreds = np.concatenate(conf_exppreds, 0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "FX6iSutUwYKB"
   },
   "outputs": [],
   "source": [
    "all_expX = np.concatenate(all_expX, 0)\n",
    "all_exppreds = np.concatenate(all_exppreds, 0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 1000
    },
    "id": "JmqpeS-CGOQf",
    "outputId": "7624752d-5912-4bab-8b84-f41dc9345c29"
   },
   "outputs": [],
   "source": [
    "# score_perc = .75\n",
    "score_perc = .85\n",
    "score_thresh = np.quantile(score_lst, score_perc)\n",
    "critical_indices = index_lst[score_lst >= score_thresh]\n",
    "critical_ood = np.concatenate(\n",
    "  [divide_points(0.1, X, Y, ci)[2] for ci in critical_indices], 0\n",
    ")\n",
    "\n",
    "def loss(model, inputs, labels, inputs_conf, labels_conf, inputs_unconf, labels_unconf, alpha=0.5):\n",
    "  inputs_unconf_logits = model.get_features(inputs_unconf)\n",
    "  inputs_unconf_sigmoids = tf.nn.sigmoid(inputs_unconf_logits)\n",
    "  # Encourage diversity by minimizing probability distribution innerproducts\n",
    "  # p*q + (1-p)(1-q) = 1 - p - q + 2*p*q\n",
    "  # Note: encouraging diversity for low confidence instances, to minimize dependencies on errors\n",
    "  # WRT existing previous experts\n",
    "  # pw_prods = 1. - inputs_unconf_sigmoids - labels_unconf + 2.*inputs_unconf_sigmoids*labels_unconf  # N x nexps\n",
    "  # diversity_loss = tf.reduce_mean(tf.reduce_mean(pw_prods, -1))\n",
    "  diversity_loss = 0.0\n",
    "\n",
    "  # uncertainty_loss = .5*tf.reduce_mean(\n",
    "  #   tf.abs(tf.reduce_mean(inputs_unconf_sigmoids, -1)-.5)) + \\\n",
    "  #   .5*tf.reduce_mean(\n",
    "  #     tf.abs(tf.reduce_mean(inputs_unconf_sigmoids, 0)-.5))\n",
    "  # mean_axis1 = tf.reduce_mean(inputs_unconf_sigmoids, -1, keepdims=True)\n",
    "  # var_axis1 = tf.reduce_mean(\n",
    "  #   tf.reduce_mean((inputs_unconf_sigmoids-mean_axis1)**2, -1))\n",
    "  # mean_axis0 = tf.reduce_mean(inputs_unconf_sigmoids, 0, keepdims=True)\n",
    "  # var_axis0 = tf.reduce_mean(\n",
    "  #   tf.reduce_mean((inputs_unconf_sigmoids-mean_axis0)**2, 0))\n",
    "  # uncertainty_loss = -.5*(var_axis0 + var_axis1)  # increase variances\n",
    "  uncertainty_loss = 0.0\n",
    "\n",
    "  conf_logits = model.get_features(inputs_conf)\n",
    "  conf_ce_loss = tf.reduce_mean(\n",
    "    tf.keras.losses.binary_crossentropy(labels_conf, conf_logits, from_logits=True))\n",
    "  conf_prob_loss = tf.reduce_mean(tf.abs(\n",
    "    tf.reduce_mean(tf.nn.sigmoid(conf_logits), 1, keepdims=True) - tf.reduce_mean(labels_conf, 1, keepdims=True)\n",
    "  ))\n",
    "  conf_loss = conf_ce_loss  # + conf_prob_loss\n",
    "\n",
    "  in_logits = model.get_features(inputs)\n",
    "  in_ce_loss = tf.reduce_mean(\n",
    "    tf.keras.losses.binary_crossentropy(labels, in_logits, from_logits=True))\n",
    "  in_prob_loss = tf.reduce_mean(tf.abs(\n",
    "    tf.reduce_mean(tf.nn.sigmoid(in_logits), 1, keepdims=True) - tf.reduce_mean(labels, 1, keepdims=True)\n",
    "  ))\n",
    "  in_loss = in_ce_loss + in_prob_loss\n",
    "  return in_loss + alpha*conf_loss + diversity_loss + uncertainty_loss\n",
    "\n",
    "def grad(model, inputs, labels, inputs_conf, labels_conf, inputs_unconf, labels_unconf, alpha=0.5):\n",
    "  with tf.GradientTape() as tape:\n",
    "    loss_value = loss(model, inputs, labels, inputs_conf, labels_conf, inputs_unconf, labels_unconf, alpha=alpha)\n",
    "  return tape.gradient(loss_value, model.trainable_variables)\n",
    "\n",
    "steps = 20000\n",
    "#optimizer = tf.keras.optimizers.Adam(learning_rate=0.001)\n",
    "bsize = 256\n",
    "# model = DatasetDiscriminator(dim=X.shape[0], hidden_size=512, nhidden_layers=2, out_size=train_predictions.shape[1])\n",
    "\n",
    "avgint = 5000\n",
    "\n",
    "conf_thresh = .4\n",
    "alpha_rnd = .5\n",
    "print(alpha_rnd)\n",
    "# critical_X = critical_ood[np.random.permutation(critical_ood.shape[0])[:X.shape[0]]]\n",
    "# critical_X = critical_ood[np.random.permutation(critical_ood.shape[0])[:1000]]\n",
    "critical_X = critical_ood\n",
    "expanded_X = critical_X*(1+np.abs(np.random.randn(critical_X.shape[0], 1)))\n",
    "expanded_predictions = pca_proj.predictions(expanded_X)\n",
    "expanded_ens_preds, expanded_mp, expanded_sp = pca_proj.predict(expanded_X, preds=expanded_predictions, return_only_prediction=False)\n",
    "expanded_X = expanded_X[np.abs(expanded_mp-.5)>conf_thresh]\n",
    "expanded_predictions = expanded_predictions[np.abs(expanded_mp-.5)>conf_thresh]\n",
    "\n",
    "batch = training_batch(\n",
    "  X_train,  # np.concatenate((X_train, conf_expX), 0),\n",
    "  np.float32(train_predictions),  #np.concatenate((np.float32(labels_train), np.float32(conf_exppreds)), 0),\n",
    "  bsize)\n",
    "batch_conf = training_batch(\n",
    "  np.concatenate((conf_expX, expanded_X), 0), # expanded_X,\n",
    "  np.float32(np.concatenate((conf_exppreds, expanded_predictions), 0)),\n",
    "  bsize)\n",
    "batch_unconf = training_batch(\n",
    "  unconf_expX,\n",
    "  np.float32(unconf_exppreds),\n",
    "  bsize)\n",
    "# conf_lbls = np.concatenate((train_predictions, expanded_predictions), 0)\n",
    "# batch_conf = training_batch(\n",
    "#   np.concatenate((X, expanded_X), 0),\n",
    "#   conf_lbls,  # (conf_lbls-np.min(conf_lbls))/(np.max(conf_lbls)-np.min(conf_lbls)),\n",
    "#   bsize)\n",
    "\n",
    "xb, xlbls = batch()\n",
    "xb_conf, xlbls_conf = batch_conf()\n",
    "xb_unconf, xlbls_unconf = batch_unconf()\n",
    "# TODO: consider new model each round?\n",
    "T = 0\n",
    "model = DatasetDiscriminator(dim=X.shape[0], hidden_size=512, nhidden_layers=2, out_size=train_predictions.shape[1])\n",
    "average_model = DatasetDiscriminator(dim=X.shape[0], hidden_size=512, nhidden_layers=2, out_size=train_predictions.shape[1])\n",
    "optimizer = tf.keras.optimizers.Adam(learning_rate=0.0005)\n",
    "print(\"Loss at step {:03d}: {:.3f}\".format(-1, loss(model, xb, xlbls, xb_conf, xlbls_conf, xb_unconf, xlbls_unconf, alpha=alpha_rnd)))\n",
    "print(\"Loss at step {:03d}: {:.3f}\".format(-1, loss(average_model, xb, xlbls, xb_conf, xlbls_conf, xb_unconf, xlbls_unconf, alpha=alpha_rnd)))\n",
    "for i in range(steps):\n",
    "  xb, xlbls = batch()\n",
    "  xb_conf, xlbls_conf = batch_conf()\n",
    "  xb_unconf, xlbls_unconf = batch_unconf()\n",
    "  grads = grad(model, xb, xlbls, xb_conf, xlbls_conf, xb_unconf, xlbls_unconf, alpha=alpha_rnd)\n",
    "  optimizer.apply_gradients(zip(grads, model.trainable_variables))\n",
    "  if i % 1000 == 0:\n",
    "    print(\"Loss at step {:03d}: {:.3f}\".format(i, loss(model, xb, xlbls, xb_conf, xlbls_conf, xb_unconf, xlbls_unconf, alpha=alpha_rnd)))\n",
    "  if i > 0 and i % avgint == 0:\n",
    "    print('Getting Average Model (T={})'.format(T))\n",
    "    for avgweights, weights in zip(average_model.trainable_variables, model.trainable_variables):\n",
    "      avgweights.assign((T/(T+1.))*avgweights + (1./(T+1))*weights)\n",
    "    T = T + 1\n",
    "\n",
    "# plot\n",
    "plt.figure()\n",
    "ex_sigmoids = tf.nn.sigmoid(model.get_features(external_X))\n",
    "ex_conf_sigmoids = np.std(ex_sigmoids, axis=1)\n",
    "\n",
    "threshs = np.mean(ex_sigmoids, 1)*(1-np.mean(ex_sigmoids, 1))  # + sp_le_agg_new\n",
    "ens_preds = (np.mean(ex_sigmoids, 1) >.5)\n",
    "std_threshs = np.linspace(np.min(threshs), np.max(threshs), 100)\n",
    "reject_rate = [1 - np.mean((threshs<=s)) for s in std_threshs]\n",
    "accus = [np.mean((ens_preds==external_Y)[(threshs<=s)]) for s in std_threshs]\n",
    "tps = [np.sum(((external_Y)*(ens_preds==external_Y))[(threshs<=s)]) for s in std_threshs]  # correct and positive\n",
    "fps = [np.sum(((ens_preds)*(ens_preds!=external_Y))[(threshs<=s)]) for s in std_threshs]  # incorrect and predicted positive\n",
    "pos = np.sum(external_Y)\n",
    "recall = [tp/pos for tp in tps]\n",
    "precision = [tp/(tp+fp) for tp, fp in zip(tps, fps)]\n",
    "plt.plot(recall, precision, marker='+', c='red')\n",
    "\n",
    "ens_preds_pca, mp_pca, sp_pca = pca_proj.predict(external_X, return_only_prediction=False)\n",
    "threshs = sp_pca\n",
    "ens_preds = ens_preds_pca\n",
    "std_threshs = np.linspace(np.min(threshs), np.max(threshs), 100)\n",
    "reject_rate = [1 - np.mean((threshs<=s)) for s in std_threshs]\n",
    "accus = [np.mean((ens_preds==external_Y)[(threshs<=s)]) for s in std_threshs]\n",
    "tps = [np.sum(((external_Y)*(ens_preds==external_Y))[(threshs<=s)]) for s in std_threshs]  # correct and positive\n",
    "fps = [np.sum(((ens_preds)*(ens_preds!=external_Y))[(threshs<=s)]) for s in std_threshs]  # incorrect and predicted positive\n",
    "pos = np.sum(external_Y)\n",
    "recall = [tp/pos for tp in tps]\n",
    "precision = [tp/(tp+fp) for tp, fp in zip(tps, fps)]\n",
    "plt.plot(recall, precision, marker='+', c='brown')\n",
    "\n",
    "mp_combi = .5*np.mean(ex_sigmoids, 1)+.5*mp_pca\n",
    "ens_preds = (mp_combi >.5)\n",
    "threshs = np.sqrt(mp_combi*(1-mp_combi))  # + sp_le_agg_new\n",
    "std_threshs = np.linspace(np.min(threshs), np.max(threshs), 100)\n",
    "reject_rate = [1 - np.mean((threshs<=s)) for s in std_threshs]\n",
    "accus = [np.mean((ens_preds==external_Y)[(threshs<=s)]) for s in std_threshs]\n",
    "tps = [np.sum(((external_Y)*(ens_preds==external_Y))[(threshs<=s)]) for s in std_threshs]  # correct and positive\n",
    "fps = [np.sum(((ens_preds)*(ens_preds!=external_Y))[(threshs<=s)]) for s in std_threshs]  # incorrect and predicted positive\n",
    "pos = np.sum(external_Y)\n",
    "recall = [tp/pos for tp in tps]\n",
    "precision = [tp/(tp+fp) for tp, fp in zip(tps, fps)]\n",
    "plt.plot(recall, precision, marker='+', c='blue')\n",
    "\n",
    "ex_sigmoids = tf.nn.sigmoid(average_model.get_features(external_X))\n",
    "ex_conf_sigmoids = np.std(ex_sigmoids, axis=1)\n",
    "\n",
    "threshs = np.mean(ex_sigmoids, 1)*(1-np.mean(ex_sigmoids, 1))  # + sp_le_agg_new\n",
    "ens_preds = (np.mean(ex_sigmoids, 1) >.5)\n",
    "std_threshs = np.linspace(np.min(threshs), np.max(threshs), 100)\n",
    "reject_rate = [1 - np.mean((threshs<=s)) for s in std_threshs]\n",
    "accus = [np.mean((ens_preds==external_Y)[(threshs<=s)]) for s in std_threshs]\n",
    "tps = [np.sum(((external_Y)*(ens_preds==external_Y))[(threshs<=s)]) for s in std_threshs]  # correct and positive\n",
    "fps = [np.sum(((ens_preds)*(ens_preds!=external_Y))[(threshs<=s)]) for s in std_threshs]  # incorrect and predicted positive\n",
    "pos = np.sum(external_Y)\n",
    "recall = [tp/pos for tp in tps]\n",
    "precision = [tp/(tp+fp) for tp, fp in zip(tps, fps)]\n",
    "plt.plot(recall, precision, marker='+', c='pink')\n",
    "\n",
    "mp_combi = .5*np.mean(ex_sigmoids, 1)+.5*mp_pca\n",
    "ens_preds = (mp_combi >.5)\n",
    "threshs = np.sqrt(mp_combi*(1-mp_combi))  # + sp_le_agg_new\n",
    "std_threshs = np.linspace(np.min(threshs), np.max(threshs), 100)\n",
    "reject_rate = [1 - np.mean((threshs<=s)) for s in std_threshs]\n",
    "accus = [np.mean((ens_preds==external_Y)[(threshs<=s)]) for s in std_threshs]\n",
    "tps = [np.sum(((external_Y)*(ens_preds==external_Y))[(threshs<=s)]) for s in std_threshs]  # correct and positive\n",
    "fps = [np.sum(((ens_preds)*(ens_preds!=external_Y))[(threshs<=s)]) for s in std_threshs]  # incorrect and predicted positive\n",
    "pos = np.sum(external_Y)\n",
    "recall = [tp/pos for tp in tps]\n",
    "precision = [tp/(tp+fp) for tp, fp in zip(tps, fps)]\n",
    "plt.plot(recall, precision, marker='+', c='cyan')\n",
    "\n",
    "# harmonic_mp = 2*np.mean(ex_sigmoids, 1)*mp_pca/(np.mean(ex_sigmoids, 1)+mp_pca)\n",
    "mp_combi_har = 2*np.mean(ex_sigmoids, 1)*mp_pca/(np.mean(ex_sigmoids, 1)+mp_pca)\n",
    "ens_preds = (mp_combi_har >.5)\n",
    "threshs = np.sqrt(mp_combi_har*(1-mp_combi_har))  # + sp_le_agg_new\n",
    "std_threshs = np.linspace(np.min(threshs), np.max(threshs), 100)\n",
    "reject_rate = [1 - np.mean((threshs<=s)) for s in std_threshs]\n",
    "accus = [np.mean((ens_preds==external_Y)[(threshs<=s)]) for s in std_threshs]\n",
    "tps = [np.sum(((external_Y)*(ens_preds==external_Y))[(threshs<=s)]) for s in std_threshs]  # correct and positive\n",
    "fps = [np.sum(((ens_preds)*(ens_preds!=external_Y))[(threshs<=s)]) for s in std_threshs]  # incorrect and predicted positive\n",
    "pos = np.sum(external_Y)\n",
    "recall = [tp/pos for tp in tps]\n",
    "precision = [tp/(tp+fp) for tp, fp in zip(tps, fps)]\n",
    "plt.plot(recall, precision, marker='+', c='cyan')\n",
    "\n",
    "plt.xticks(np.arange(0, 1.01, step=0.1))\n",
    "plt.xticks(np.arange(0, 1.01, step=0.05), minor=True)\n",
    "plt.yticks(np.arange(0.6, 1.01, step=0.05))\n",
    "plt.grid(True, which='both')\n",
    "plt.xlabel('Recall ({} Positive)'.format(int(pos)))\n",
    "plt.ylabel('Precision')\n",
    "plt.title('Precision vs Recall by Thresholding Ensemble Std')\n",
    "plt.show()\n",
    "print(auprc_threshs(mp_combi, external_Y, [0.1, 0.2, 0.3, 0.4, 1.0]))\n",
    "print(auprc_threshs(mp_combi_har, external_Y, [0.1, 0.2, 0.3, 0.4, 1.0]))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "-1yyCAnBf7yY"
   },
   "source": [
    "# Save results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "qRpN9DyOk8Gx"
   },
   "outputs": [],
   "source": [
    "os.makedirs(save_path, exist_ok=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "afZOy7y-NiiB"
   },
   "outputs": [],
   "source": [
    "models_dict = {}\n",
    "models_dict['base'] = pca_proj\n",
    "models_dict['model_net'] = model.net\n",
    "models_dict['avg_model_net'] = average_model.net"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "RYMGc3UDMC3r"
   },
   "outputs": [],
   "source": [
    "with open(os.path.join(save_path, 'models.p'), 'wb') as f:\n",
    "    pickle.dump(models_dict, f)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "xpRyP1LZNSAy"
   },
   "outputs": [],
   "source": [
    "predictions_dict = {}\n",
    "predictions_dict['heldid_Y'] = held_Y\n",
    "predictions_dict['heldid_base'] = pca_proj.predictions(held_X)\n",
    "predictions_dict['heldid_model_net'] = model.predictions(held_X)\n",
    "predictions_dict['heldid_avg_model_net'] = average_model.predictions(held_X)\n",
    "predictions_dict['heldood_Y'] = external_Y\n",
    "predictions_dict['heldood_base'] = pca_proj.predictions(external_X)\n",
    "predictions_dict['heldood_model_net'] = model.predictions(external_X)\n",
    "predictions_dict['heldood_avg_model_net'] = average_model.predictions(external_X)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "G6hL7lSwS2Tn"
   },
   "outputs": [],
   "source": [
    "with open(os.path.join(save_path, 'predictions.p'), 'wb') as f:\n",
    "    pickle.dump(predictions_dict, f)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "keJoFOHJZci2"
   },
   "outputs": [],
   "source": [
    "results_dict = {}\n",
    "results_dict['threshs'] = AUCTHRESHS"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 646
    },
    "id": "CAnzerSDU0Bh",
    "outputId": "02d60e08-fd60-4c14-e42a-317bf9e81bbf"
   },
   "outputs": [],
   "source": [
    "# plot id\n",
    "###########\n",
    "base_predictions = predictions_dict['heldid_base']\n",
    "model_predictions = predictions_dict['heldid_model_net']\n",
    "average_model_predictions = predictions_dict['heldid_avg_model_net']\n",
    "true_Y = predictions_dict['heldid_Y']\n",
    "\n",
    "plt.figure()\n",
    "\n",
    "# base model\n",
    "confs = np.mean(base_predictions, -1)\n",
    "preds = (confs >.5)\n",
    "precision, recall, thresholds = metrics.precision_recall_curve(true_Y, confs)\n",
    "plt.plot(recall, precision, c='brown')\n",
    "BASE_AUPRC = auprc_threshs(confs, true_Y, AUCTHRESHS)\n",
    "BASE_AUROC = metrics.roc_auc_score(true_Y, confs)\n",
    "BASE_ACC = metrics.accuracy_score(true_Y, preds)\n",
    "\n",
    "print('Base:\\n{} (AUROC:{},ACC:{})'.format(BASE_AUPRC, BASE_AUROC,BASE_ACC))\n",
    "\n",
    "# student model\n",
    "confs = np.mean(model_predictions, -1)\n",
    "preds = (confs >.5)\n",
    "precision, recall, thresholds = metrics.precision_recall_curve(true_Y, confs)\n",
    "plt.plot(recall, precision, c='red')\n",
    "MOD_AUPRC = auprc_threshs(confs, true_Y, AUCTHRESHS)\n",
    "MOD_AUROC = metrics.roc_auc_score(true_Y, confs)\n",
    "MOD_ACC = metrics.accuracy_score(true_Y, preds)\n",
    "print('Model:\\n{} (AUROC:{},ACC:{})'.format(MOD_AUPRC, MOD_AUROC,MOD_ACC))\n",
    "\n",
    "# average student model\n",
    "confs = np.mean(average_model_predictions, -1)\n",
    "preds = (confs >.5)\n",
    "precision, recall, thresholds = metrics.precision_recall_curve(true_Y, confs)\n",
    "plt.plot(recall, precision, c='pink')\n",
    "AVGMOD_AUPRC = auprc_threshs(confs, true_Y, AUCTHRESHS)\n",
    "AVGMOD_AUROC = metrics.roc_auc_score(true_Y, confs)\n",
    "AVGMOD_ACC = metrics.accuracy_score(true_Y, preds)\n",
    "print('Average Model:\\n{} (AUROC:{},ACC:{})'.format(AVGMOD_AUPRC, AVGMOD_AUROC,AVGMOD_ACC))\n",
    "\n",
    "# base+student model\n",
    "confs = (np.mean(base_predictions, -1)+np.mean(model_predictions, -1))/2.\n",
    "preds = (confs >.5)\n",
    "precision, recall, thresholds = metrics.precision_recall_curve(true_Y, confs)\n",
    "plt.plot(recall, precision, c='blue')\n",
    "EMOE_AUPRC = auprc_threshs(confs, true_Y, AUCTHRESHS)\n",
    "EMOE_AUROC = metrics.roc_auc_score(true_Y, confs)\n",
    "EMOE_ACC = metrics.accuracy_score(true_Y, preds)\n",
    "print('Base+Model:\\n{} (AUROC:{},ACC:{})'.format(EMOE_AUPRC, EMOE_AUROC,EMOE_ACC))\n",
    "\n",
    "# base+average student model\n",
    "confs = (np.mean(base_predictions, -1)+np.mean(average_model_predictions, -1))/2.\n",
    "preds = (confs >.5)\n",
    "precision, recall, thresholds = metrics.precision_recall_curve(true_Y, confs)\n",
    "plt.plot(recall, precision, c='cyan')\n",
    "AVGEMOE_AUPRC = auprc_threshs(confs, true_Y, AUCTHRESHS)\n",
    "AVGEMOE_AUROC = metrics.roc_auc_score(true_Y, confs)\n",
    "AVGEMOE_ACC = metrics.accuracy_score(true_Y, preds)\n",
    "print('Base+Average Model:\\n{} (AUROC:{},ACC:{})'.format(AVGEMOE_AUPRC, AVGEMOE_AUROC,AVGEMOE_ACC))\n",
    "\n",
    "plt.xticks(np.arange(0, 1.01, step=0.1))\n",
    "plt.xticks(np.arange(0, 1.01, step=0.05), minor=True)\n",
    "plt.yticks(np.arange(0.6, 1.01, step=0.05))\n",
    "plt.grid(True, which='both')\n",
    "plt.xlabel('Recall ({} Positive)'.format(int(np.sum(true_Y))))\n",
    "plt.ylabel('Precision')\n",
    "plt.title('ID Precision vs Recall')\n",
    "plt.legend(['Base', 'NNet', 'AVGNNET', 'EMOE', 'AVGEMOE'])\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "S9dNIiJzZG_v"
   },
   "outputs": [],
   "source": [
    "results_dict['heldid_base_AUPRC'] = BASE_AUPRC\n",
    "results_dict['heldid_model_AUPRC'] = MOD_AUPRC\n",
    "results_dict['heldid_avg_model_AUPRC'] = AVGMOD_AUPRC\n",
    "results_dict['heldid_emoe_AUPRC'] = EMOE_AUPRC\n",
    "results_dict['heldid_avg_emoe_AUPRC'] = AVGEMOE_AUPRC\n",
    "\n",
    "results_dict['heldid_base_AUROC'] = BASE_AUROC\n",
    "results_dict['heldid_model_AUROC'] = MOD_AUROC\n",
    "results_dict['heldid_avg_model_AUROC'] = AVGMOD_AUROC\n",
    "results_dict['heldid_emoe_AUROC'] = EMOE_AUROC\n",
    "results_dict['heldid_avg_emoe_AUROC'] = AVGEMOE_AUROC"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 646
    },
    "id": "OSEwGfoUdVMR",
    "outputId": "b2ef2112-d231-49d0-dd4d-4235c507a66e"
   },
   "outputs": [],
   "source": [
    "# plot ood\n",
    "###########\n",
    "base_predictions = predictions_dict['heldood_base']\n",
    "model_predictions = predictions_dict['heldood_model_net']\n",
    "average_model_predictions = predictions_dict['heldood_avg_model_net']\n",
    "true_Y = predictions_dict['heldood_Y']\n",
    "\n",
    "plt.figure()\n",
    "\n",
    "# base model\n",
    "confs = np.mean(base_predictions, -1)\n",
    "preds = (confs >.5)\n",
    "precision, recall, thresholds = metrics.precision_recall_curve(true_Y, confs)\n",
    "plt.plot(recall, precision, c='brown')\n",
    "BASE_AUPRC = auprc_threshs(confs, true_Y, AUCTHRESHS)\n",
    "BASE_AUROC = metrics.roc_auc_score(true_Y, confs)\n",
    "BASE_ACC = metrics.accuracy_score(true_Y, preds)\n",
    "\n",
    "print('Base:\\n{} (AUROC:{},ACC:{})'.format(BASE_AUPRC, BASE_AUROC,BASE_ACC))\n",
    "\n",
    "# student model\n",
    "confs = np.mean(model_predictions, -1)\n",
    "preds = (confs >.5)\n",
    "precision, recall, thresholds = metrics.precision_recall_curve(true_Y, confs)\n",
    "plt.plot(recall, precision, c='red')\n",
    "MOD_AUPRC = auprc_threshs(confs, true_Y, AUCTHRESHS)\n",
    "MOD_AUROC = metrics.roc_auc_score(true_Y, confs)\n",
    "MOD_ACC = metrics.accuracy_score(true_Y, preds)\n",
    "print('Model:\\n{} (AUROC:{},ACC:{})'.format(MOD_AUPRC, MOD_AUROC,MOD_ACC))\n",
    "\n",
    "# average student model\n",
    "confs = np.mean(average_model_predictions, -1)\n",
    "preds = (confs >.5)\n",
    "precision, recall, thresholds = metrics.precision_recall_curve(true_Y, confs)\n",
    "plt.plot(recall, precision, c='pink')\n",
    "AVGMOD_AUPRC = auprc_threshs(confs, true_Y, AUCTHRESHS)\n",
    "AVGMOD_AUROC = metrics.roc_auc_score(true_Y, confs)\n",
    "AVGMOD_ACC = metrics.accuracy_score(true_Y, preds)\n",
    "print('Average Model:\\n{} (AUROC:{},ACC:{})'.format(AVGMOD_AUPRC, AVGMOD_AUROC,AVGMOD_ACC))\n",
    "\n",
    "# base+student model\n",
    "confs = (np.mean(base_predictions, -1)+np.mean(model_predictions, -1))/2.\n",
    "preds = (confs >.5)\n",
    "precision, recall, thresholds = metrics.precision_recall_curve(true_Y, confs)\n",
    "plt.plot(recall, precision, c='blue')\n",
    "EMOE_AUPRC = auprc_threshs(confs, true_Y, AUCTHRESHS)\n",
    "EMOE_AUROC = metrics.roc_auc_score(true_Y, confs)\n",
    "EMOE_ACC = metrics.accuracy_score(true_Y, preds)\n",
    "print('Base+Model:\\n{} (AUROC:{},ACC:{})'.format(EMOE_AUPRC, EMOE_AUROC,EMOE_ACC))\n",
    "\n",
    "# base+average student model\n",
    "confs = (np.mean(base_predictions, -1)+np.mean(average_model_predictions, -1))/2.\n",
    "preds = (confs >.5)\n",
    "precision, recall, thresholds = metrics.precision_recall_curve(true_Y, confs)\n",
    "plt.plot(recall, precision, c='cyan')\n",
    "AVGEMOE_AUPRC = auprc_threshs(confs, true_Y, AUCTHRESHS)\n",
    "AVGEMOE_AUROC = metrics.roc_auc_score(true_Y, confs)\n",
    "AVGEMOE_ACC = metrics.accuracy_score(true_Y, preds)\n",
    "print('Base+Average Model:\\n{} (AUROC:{},ACC:{})'.format(AVGEMOE_AUPRC, AVGEMOE_AUROC,AVGEMOE_ACC))\n",
    "\n",
    "plt.xticks(np.arange(0, 1.01, step=0.1))\n",
    "plt.xticks(np.arange(0, 1.01, step=0.05), minor=True)\n",
    "plt.yticks(np.arange(0.6, 1.01, step=0.05))\n",
    "plt.grid(True, which='both')\n",
    "plt.xlabel('Recall ({} Positive)'.format(int(np.sum(true_Y))))\n",
    "plt.ylabel('Precision')\n",
    "plt.title('ID Precision vs Recall')\n",
    "plt.legend(['Base', 'NNet', 'AVGNNET', 'EMOE', 'AVGEMOE'])\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "nORwKBMOfgqY"
   },
   "outputs": [],
   "source": [
    "results_dict['heldood_base_AUPRC'] = BASE_AUPRC\n",
    "results_dict['heldood_model_AUPRC'] = MOD_AUPRC\n",
    "results_dict['heldood_avg_model_AUPRC'] = AVGMOD_AUPRC\n",
    "results_dict['heldood_emoe_AUPRC'] = EMOE_AUPRC\n",
    "results_dict['heldood_avg_emoe_AUPRC'] = AVGEMOE_AUPRC\n",
    "\n",
    "results_dict['heldood_base_AUROC'] = BASE_AUROC\n",
    "results_dict['heldood_model_AUROC'] = MOD_AUROC\n",
    "results_dict['heldood_avg_model_AUROC'] = AVGMOD_AUROC\n",
    "results_dict['heldood_emoe_AUROC'] = EMOE_AUROC\n",
    "results_dict['heldood_avg_emoe_AUROC'] = AVGEMOE_AUROC\n",
    "\n",
    "results_dict['heldood_base_ACC'] = BASE_ACC\n",
    "results_dict['heldood_model_ACC'] = MOD_ACC\n",
    "results_dict['heldood_avg_model_ACC'] = AVGMOD_ACC\n",
    "results_dict['heldood_emoe_ACC'] = EMOE_ACC\n",
    "results_dict['heldood_avg_emoe_ACC'] = AVGEMOE_ACC"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "Y0YgbE2BfngI"
   },
   "outputs": [],
   "source": [
    "with open(os.path.join(save_path, 'results.p'), 'wb') as f:\n",
    "    pickle.dump(results_dict, f)"
   ]
  }
 ],
 "metadata": {
  "accelerator": "GPU",
  "colab": {
   "gpuType": "T4",
   "machine_shape": "hm",
   "provenance": []
  },
  "kernelspec": {
   "display_name": "venv_chemML",
   "language": "python",
   "name": "venv_chemml"
  },
  "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.11.8"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
