{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Enforcing Fairness in NLP\n",
    "\n",
    "This code demonstrates how to enforce fairness when working with deep neural networks in NLP. \n",
    "\n",
    "We demonstrate how different notions of fairness and performance can be measured and enforced with our toolkit. \n",
    "\n",
    "We recommend you first consider the quickstart_xgboost.ipynb and quickstart_DeepFairPredictor_computer_vision.ipynb notebooks for an introduction to the toolkit's functionality. \n",
    "\n",
    "We first show an example on [Jigsaw](https://www.kaggle.com/c/jigsaw-toxic-comment-classification-challenge). The protected groups are given by the labels for the attribute `Religion` . The target attribute indicates if hate speech is present. \n",
    "You can also specify which fairness and performance metrics to measure.\n",
    "\n",
    "Input Requirements: \n",
    "\n",
    "1. We need the validation and test labels for the protected and target attributes.\n",
    "2. We also require the model outputs. These will typically be logits for the target attribute and probabilities for the inferred protected attribute. It is also possible to use the true group labels (non-inferred). This data used in this notebook demonstration is fetched from an anonymous repository.\n",
    "\n",
    "We use DeepFairPredictor (reccomended), which is optimized for deep learning classifiers. \n",
    "\n",
    "We also reccomend checking out this [paper](https://arxiv.org/pdf/2203.04913) for theoretically explanations into why the majority of fairness methods designed for low capacity models should not be used in settings involving high-capacity models and this [paper](https://proceedings.neurips.cc/paper_files/paper/2022/file/698c05933e5f7fde98e567a669d2c752-Paper-Conference.pdf) for more details on the two/multi headed approach for a post-processing approach to enforce fairness with validation data when working with deep learning models."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np \n",
    "import anonfair\n",
    "import os\n",
    "from anonfair.utils import group_metrics as gm\n",
    "from matplotlib import pyplot as plt\n",
    "#Helper functions.\n",
    "def sigmoid(array):\n",
    "    return np.stack ((1/(1+np.exp(array[:,0])),1/(1+np.exp(-array[:,0]))),1)\n",
    "def square_align(array):\n",
    "    return np.stack((array[:,1],1-array[:,1]),1)\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Train the model.\n",
    "%cd training_nlp_jigsaw_religion\n",
    "! pip install -r requirements.txt\n",
    "!./download_data.sh\n",
    "!./train.sh\n",
    "%cd .."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "expdir = \"training_nlp_jigsaw_religion/output/data=jigsawreligion,mfair=[christian,other,muslim]\"\n",
    "\n",
    "val = np.load(os.path.join(expdir, 'outputs_val.npy'))\n",
    "val_target = np.load(os.path.join(expdir, 'target_label_val.npy'))\n",
    "val_groups = np.load(os.path.join(expdir, 'protected_label_val.npy'))\n",
    "\n",
    "test = np.load(os.path.join(expdir, 'outputs_test.npy'))\n",
    "test_target = np.load(os.path.join(expdir, 'target_label_test.npy'))\n",
    "test_groups = np.load(os.path.join(expdir, 'protected_label_test.npy'))\n",
    "\n",
    "val_dict={'data':val, 'target':val_target, 'groups':val_groups}\n",
    "test_dict={'data':test,'target':test_target,'groups':test_groups}\n",
    "\n",
    "val_dict={'data':val, 'target':val_target, 'groups':val_groups}\n",
    "test_dict={'data':test,'target':test_target,'groups':test_groups}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>original</th>\n",
       "      <th>updated</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>Accuracy</th>\n",
       "      <td>0.709878</td>\n",
       "      <td>0.887488</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Balanced Accuracy</th>\n",
       "      <td>0.739778</td>\n",
       "      <td>0.589080</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>F1 score</th>\n",
       "      <td>0.395768</td>\n",
       "      <td>0.296471</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>MCC</th>\n",
       "      <td>0.327244</td>\n",
       "      <td>0.304862</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Precision</th>\n",
       "      <td>0.265231</td>\n",
       "      <td>0.623762</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Recall</th>\n",
       "      <td>0.779321</td>\n",
       "      <td>0.194444</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>ROC AUC</th>\n",
       "      <td>0.821055</td>\n",
       "      <td>0.816665</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                   original   updated\n",
       "Accuracy           0.709878  0.887488\n",
       "Balanced Accuracy  0.739778  0.589080\n",
       "F1 score           0.395768  0.296471\n",
       "MCC                0.327244  0.304862\n",
       "Precision          0.265231  0.623762\n",
       "Recall             0.779321  0.194444\n",
       "ROC AUC            0.821055  0.816665"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "fpred=anonfair.DeepFairPredictor(val_target,val,val_groups,use_fast='hybrid', use_actual_groups = False)\n",
    "fpred.fit(gm.accuracy,gm.equal_opportunity,0.05)\n",
    "fpred.evaluate(test_dict)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th>Accuracy</th>\n",
       "      <th>Balanced Accuracy</th>\n",
       "      <th>F1 score</th>\n",
       "      <th>MCC</th>\n",
       "      <th>Precision</th>\n",
       "      <th>Recall</th>\n",
       "      <th>ROC AUC</th>\n",
       "      <th>Number of Datapoints</th>\n",
       "      <th>Positive Count</th>\n",
       "      <th>Negative Count</th>\n",
       "      <th>Positive Label Rate</th>\n",
       "      <th>Positive Prediction Rate</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th></th>\n",
       "      <th>Groups</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th rowspan=\"5\" valign=\"top\">original</th>\n",
       "      <th>Overall</th>\n",
       "      <td>0.692525</td>\n",
       "      <td>0.727988</td>\n",
       "      <td>0.370178</td>\n",
       "      <td>0.302978</td>\n",
       "      <td>0.243236</td>\n",
       "      <td>0.774247</td>\n",
       "      <td>0.807432</td>\n",
       "      <td>10248.0</td>\n",
       "      <td>1196.0</td>\n",
       "      <td>9052.0</td>\n",
       "      <td>0.116706</td>\n",
       "      <td>0.371487</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0.776947</td>\n",
       "      <td>0.752390</td>\n",
       "      <td>0.331384</td>\n",
       "      <td>0.306796</td>\n",
       "      <td>0.214918</td>\n",
       "      <td>0.723404</td>\n",
       "      <td>0.829316</td>\n",
       "      <td>6151.0</td>\n",
       "      <td>470.0</td>\n",
       "      <td>5681.0</td>\n",
       "      <td>0.076410</td>\n",
       "      <td>0.257194</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>0.635283</td>\n",
       "      <td>0.672269</td>\n",
       "      <td>0.349103</td>\n",
       "      <td>0.238375</td>\n",
       "      <td>0.230108</td>\n",
       "      <td>0.722973</td>\n",
       "      <td>0.743579</td>\n",
       "      <td>1094.0</td>\n",
       "      <td>148.0</td>\n",
       "      <td>946.0</td>\n",
       "      <td>0.135283</td>\n",
       "      <td>0.425046</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>0.540460</td>\n",
       "      <td>0.650236</td>\n",
       "      <td>0.409752</td>\n",
       "      <td>0.240510</td>\n",
       "      <td>0.272159</td>\n",
       "      <td>0.828720</td>\n",
       "      <td>0.744693</td>\n",
       "      <td>3003.0</td>\n",
       "      <td>578.0</td>\n",
       "      <td>2425.0</td>\n",
       "      <td>0.192474</td>\n",
       "      <td>0.586081</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Maximum difference</th>\n",
       "      <td>0.236487</td>\n",
       "      <td>0.102154</td>\n",
       "      <td>0.078368</td>\n",
       "      <td>0.068421</td>\n",
       "      <td>0.057241</td>\n",
       "      <td>0.105747</td>\n",
       "      <td>0.085738</td>\n",
       "      <td>5057.0</td>\n",
       "      <td>430.0</td>\n",
       "      <td>4735.0</td>\n",
       "      <td>0.116064</td>\n",
       "      <td>0.328887</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"5\" valign=\"top\">updated</th>\n",
       "      <th>Overall</th>\n",
       "      <td>0.894223</td>\n",
       "      <td>0.594353</td>\n",
       "      <td>0.309554</td>\n",
       "      <td>0.323102</td>\n",
       "      <td>0.649733</td>\n",
       "      <td>0.203177</td>\n",
       "      <td>0.804791</td>\n",
       "      <td>10248.0</td>\n",
       "      <td>1196.0</td>\n",
       "      <td>9052.0</td>\n",
       "      <td>0.116706</td>\n",
       "      <td>0.036495</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0.928142</td>\n",
       "      <td>0.588336</td>\n",
       "      <td>0.284790</td>\n",
       "      <td>0.306278</td>\n",
       "      <td>0.594595</td>\n",
       "      <td>0.187234</td>\n",
       "      <td>0.828960</td>\n",
       "      <td>6151.0</td>\n",
       "      <td>470.0</td>\n",
       "      <td>5681.0</td>\n",
       "      <td>0.076410</td>\n",
       "      <td>0.024061</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>0.876600</td>\n",
       "      <td>0.575267</td>\n",
       "      <td>0.262295</td>\n",
       "      <td>0.292570</td>\n",
       "      <td>0.685714</td>\n",
       "      <td>0.162162</td>\n",
       "      <td>0.734001</td>\n",
       "      <td>1094.0</td>\n",
       "      <td>148.0</td>\n",
       "      <td>946.0</td>\n",
       "      <td>0.135283</td>\n",
       "      <td>0.031993</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>0.831169</td>\n",
       "      <td>0.600951</td>\n",
       "      <td>0.340702</td>\n",
       "      <td>0.326163</td>\n",
       "      <td>0.685864</td>\n",
       "      <td>0.226644</td>\n",
       "      <td>0.742037</td>\n",
       "      <td>3003.0</td>\n",
       "      <td>578.0</td>\n",
       "      <td>2425.0</td>\n",
       "      <td>0.192474</td>\n",
       "      <td>0.063603</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Maximum difference</th>\n",
       "      <td>0.096973</td>\n",
       "      <td>0.025684</td>\n",
       "      <td>0.078407</td>\n",
       "      <td>0.033593</td>\n",
       "      <td>0.091269</td>\n",
       "      <td>0.064481</td>\n",
       "      <td>0.094959</td>\n",
       "      <td>5057.0</td>\n",
       "      <td>430.0</td>\n",
       "      <td>4735.0</td>\n",
       "      <td>0.116064</td>\n",
       "      <td>0.039542</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                             Accuracy  Balanced Accuracy  F1 score       MCC  \\\n",
       "         Groups                                                                \n",
       "original Overall             0.692525           0.727988  0.370178  0.302978   \n",
       "         0                   0.776947           0.752390  0.331384  0.306796   \n",
       "         1                   0.635283           0.672269  0.349103  0.238375   \n",
       "         2                   0.540460           0.650236  0.409752  0.240510   \n",
       "         Maximum difference  0.236487           0.102154  0.078368  0.068421   \n",
       "updated  Overall             0.894223           0.594353  0.309554  0.323102   \n",
       "         0                   0.928142           0.588336  0.284790  0.306278   \n",
       "         1                   0.876600           0.575267  0.262295  0.292570   \n",
       "         2                   0.831169           0.600951  0.340702  0.326163   \n",
       "         Maximum difference  0.096973           0.025684  0.078407  0.033593   \n",
       "\n",
       "                             Precision    Recall   ROC AUC  \\\n",
       "         Groups                                              \n",
       "original Overall              0.243236  0.774247  0.807432   \n",
       "         0                    0.214918  0.723404  0.829316   \n",
       "         1                    0.230108  0.722973  0.743579   \n",
       "         2                    0.272159  0.828720  0.744693   \n",
       "         Maximum difference   0.057241  0.105747  0.085738   \n",
       "updated  Overall              0.649733  0.203177  0.804791   \n",
       "         0                    0.594595  0.187234  0.828960   \n",
       "         1                    0.685714  0.162162  0.734001   \n",
       "         2                    0.685864  0.226644  0.742037   \n",
       "         Maximum difference   0.091269  0.064481  0.094959   \n",
       "\n",
       "                             Number of Datapoints  Positive Count  \\\n",
       "         Groups                                                     \n",
       "original Overall                          10248.0          1196.0   \n",
       "         0                                 6151.0           470.0   \n",
       "         1                                 1094.0           148.0   \n",
       "         2                                 3003.0           578.0   \n",
       "         Maximum difference                5057.0           430.0   \n",
       "updated  Overall                          10248.0          1196.0   \n",
       "         0                                 6151.0           470.0   \n",
       "         1                                 1094.0           148.0   \n",
       "         2                                 3003.0           578.0   \n",
       "         Maximum difference                5057.0           430.0   \n",
       "\n",
       "                             Negative Count  Positive Label Rate  \\\n",
       "         Groups                                                    \n",
       "original Overall                     9052.0             0.116706   \n",
       "         0                           5681.0             0.076410   \n",
       "         1                            946.0             0.135283   \n",
       "         2                           2425.0             0.192474   \n",
       "         Maximum difference          4735.0             0.116064   \n",
       "updated  Overall                     9052.0             0.116706   \n",
       "         0                           5681.0             0.076410   \n",
       "         1                            946.0             0.135283   \n",
       "         2                           2425.0             0.192474   \n",
       "         Maximum difference          4735.0             0.116064   \n",
       "\n",
       "                             Positive Prediction Rate  \n",
       "         Groups                                        \n",
       "original Overall                             0.371487  \n",
       "         0                                   0.257194  \n",
       "         1                                   0.425046  \n",
       "         2                                   0.586081  \n",
       "         Maximum difference                  0.328887  \n",
       "updated  Overall                             0.036495  \n",
       "         0                                   0.024061  \n",
       "         1                                   0.031993  \n",
       "         2                                   0.063603  \n",
       "         Maximum difference                  0.039542  "
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "fpred.evaluate_groups(return_original=True) #on val"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th>Accuracy</th>\n",
       "      <th>Balanced Accuracy</th>\n",
       "      <th>F1 score</th>\n",
       "      <th>MCC</th>\n",
       "      <th>Precision</th>\n",
       "      <th>Recall</th>\n",
       "      <th>ROC AUC</th>\n",
       "      <th>Number of Datapoints</th>\n",
       "      <th>Positive Count</th>\n",
       "      <th>Negative Count</th>\n",
       "      <th>Positive Label Rate</th>\n",
       "      <th>Positive Prediction Rate</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th></th>\n",
       "      <th>Groups</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th rowspan=\"5\" valign=\"top\">original</th>\n",
       "      <th>Overall</th>\n",
       "      <td>0.709878</td>\n",
       "      <td>0.739778</td>\n",
       "      <td>0.395768</td>\n",
       "      <td>0.327244</td>\n",
       "      <td>0.265231</td>\n",
       "      <td>0.779321</td>\n",
       "      <td>0.821055</td>\n",
       "      <td>5315.0</td>\n",
       "      <td>648.0</td>\n",
       "      <td>4667.0</td>\n",
       "      <td>0.121919</td>\n",
       "      <td>0.358231</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0.782473</td>\n",
       "      <td>0.756232</td>\n",
       "      <td>0.343720</td>\n",
       "      <td>0.317203</td>\n",
       "      <td>0.225248</td>\n",
       "      <td>0.725100</td>\n",
       "      <td>0.830447</td>\n",
       "      <td>3195.0</td>\n",
       "      <td>251.0</td>\n",
       "      <td>2944.0</td>\n",
       "      <td>0.078560</td>\n",
       "      <td>0.252895</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>0.696481</td>\n",
       "      <td>0.728158</td>\n",
       "      <td>0.366972</td>\n",
       "      <td>0.301640</td>\n",
       "      <td>0.240964</td>\n",
       "      <td>0.769231</td>\n",
       "      <td>0.810940</td>\n",
       "      <td>682.0</td>\n",
       "      <td>78.0</td>\n",
       "      <td>604.0</td>\n",
       "      <td>0.114370</td>\n",
       "      <td>0.365103</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>0.554937</td>\n",
       "      <td>0.651278</td>\n",
       "      <td>0.451115</td>\n",
       "      <td>0.255495</td>\n",
       "      <td>0.310508</td>\n",
       "      <td>0.824451</td>\n",
       "      <td>0.754909</td>\n",
       "      <td>1438.0</td>\n",
       "      <td>319.0</td>\n",
       "      <td>1119.0</td>\n",
       "      <td>0.221836</td>\n",
       "      <td>0.589013</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Maximum difference</th>\n",
       "      <td>0.227535</td>\n",
       "      <td>0.104953</td>\n",
       "      <td>0.107394</td>\n",
       "      <td>0.061708</td>\n",
       "      <td>0.085260</td>\n",
       "      <td>0.099352</td>\n",
       "      <td>0.075538</td>\n",
       "      <td>2513.0</td>\n",
       "      <td>241.0</td>\n",
       "      <td>2340.0</td>\n",
       "      <td>0.143276</td>\n",
       "      <td>0.336117</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"5\" valign=\"top\">updated</th>\n",
       "      <th>Overall</th>\n",
       "      <td>0.887488</td>\n",
       "      <td>0.589080</td>\n",
       "      <td>0.296471</td>\n",
       "      <td>0.304862</td>\n",
       "      <td>0.623762</td>\n",
       "      <td>0.194444</td>\n",
       "      <td>0.816665</td>\n",
       "      <td>5315.0</td>\n",
       "      <td>648.0</td>\n",
       "      <td>4667.0</td>\n",
       "      <td>0.121919</td>\n",
       "      <td>0.038006</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0.924257</td>\n",
       "      <td>0.585349</td>\n",
       "      <td>0.275449</td>\n",
       "      <td>0.288721</td>\n",
       "      <td>0.554217</td>\n",
       "      <td>0.183267</td>\n",
       "      <td>0.827922</td>\n",
       "      <td>3195.0</td>\n",
       "      <td>251.0</td>\n",
       "      <td>2944.0</td>\n",
       "      <td>0.078560</td>\n",
       "      <td>0.025978</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>0.894428</td>\n",
       "      <td>0.571956</td>\n",
       "      <td>0.250000</td>\n",
       "      <td>0.285722</td>\n",
       "      <td>0.666667</td>\n",
       "      <td>0.153846</td>\n",
       "      <td>0.798565</td>\n",
       "      <td>682.0</td>\n",
       "      <td>78.0</td>\n",
       "      <td>604.0</td>\n",
       "      <td>0.114370</td>\n",
       "      <td>0.026393</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>0.802503</td>\n",
       "      <td>0.591838</td>\n",
       "      <td>0.323810</td>\n",
       "      <td>0.298631</td>\n",
       "      <td>0.673267</td>\n",
       "      <td>0.213166</td>\n",
       "      <td>0.751023</td>\n",
       "      <td>1438.0</td>\n",
       "      <td>319.0</td>\n",
       "      <td>1119.0</td>\n",
       "      <td>0.221836</td>\n",
       "      <td>0.070236</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Maximum difference</th>\n",
       "      <td>0.121753</td>\n",
       "      <td>0.019882</td>\n",
       "      <td>0.073810</td>\n",
       "      <td>0.012909</td>\n",
       "      <td>0.119050</td>\n",
       "      <td>0.059320</td>\n",
       "      <td>0.076899</td>\n",
       "      <td>2513.0</td>\n",
       "      <td>241.0</td>\n",
       "      <td>2340.0</td>\n",
       "      <td>0.143276</td>\n",
       "      <td>0.044258</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                             Accuracy  Balanced Accuracy  F1 score       MCC  \\\n",
       "         Groups                                                                \n",
       "original Overall             0.709878           0.739778  0.395768  0.327244   \n",
       "         0                   0.782473           0.756232  0.343720  0.317203   \n",
       "         1                   0.696481           0.728158  0.366972  0.301640   \n",
       "         2                   0.554937           0.651278  0.451115  0.255495   \n",
       "         Maximum difference  0.227535           0.104953  0.107394  0.061708   \n",
       "updated  Overall             0.887488           0.589080  0.296471  0.304862   \n",
       "         0                   0.924257           0.585349  0.275449  0.288721   \n",
       "         1                   0.894428           0.571956  0.250000  0.285722   \n",
       "         2                   0.802503           0.591838  0.323810  0.298631   \n",
       "         Maximum difference  0.121753           0.019882  0.073810  0.012909   \n",
       "\n",
       "                             Precision    Recall   ROC AUC  \\\n",
       "         Groups                                              \n",
       "original Overall              0.265231  0.779321  0.821055   \n",
       "         0                    0.225248  0.725100  0.830447   \n",
       "         1                    0.240964  0.769231  0.810940   \n",
       "         2                    0.310508  0.824451  0.754909   \n",
       "         Maximum difference   0.085260  0.099352  0.075538   \n",
       "updated  Overall              0.623762  0.194444  0.816665   \n",
       "         0                    0.554217  0.183267  0.827922   \n",
       "         1                    0.666667  0.153846  0.798565   \n",
       "         2                    0.673267  0.213166  0.751023   \n",
       "         Maximum difference   0.119050  0.059320  0.076899   \n",
       "\n",
       "                             Number of Datapoints  Positive Count  \\\n",
       "         Groups                                                     \n",
       "original Overall                           5315.0           648.0   \n",
       "         0                                 3195.0           251.0   \n",
       "         1                                  682.0            78.0   \n",
       "         2                                 1438.0           319.0   \n",
       "         Maximum difference                2513.0           241.0   \n",
       "updated  Overall                           5315.0           648.0   \n",
       "         0                                 3195.0           251.0   \n",
       "         1                                  682.0            78.0   \n",
       "         2                                 1438.0           319.0   \n",
       "         Maximum difference                2513.0           241.0   \n",
       "\n",
       "                             Negative Count  Positive Label Rate  \\\n",
       "         Groups                                                    \n",
       "original Overall                     4667.0             0.121919   \n",
       "         0                           2944.0             0.078560   \n",
       "         1                            604.0             0.114370   \n",
       "         2                           1119.0             0.221836   \n",
       "         Maximum difference          2340.0             0.143276   \n",
       "updated  Overall                     4667.0             0.121919   \n",
       "         0                           2944.0             0.078560   \n",
       "         1                            604.0             0.114370   \n",
       "         2                           1119.0             0.221836   \n",
       "         Maximum difference          2340.0             0.143276   \n",
       "\n",
       "                             Positive Prediction Rate  \n",
       "         Groups                                        \n",
       "original Overall                             0.358231  \n",
       "         0                                   0.252895  \n",
       "         1                                   0.365103  \n",
       "         2                                   0.589013  \n",
       "         Maximum difference                  0.336117  \n",
       "updated  Overall                             0.038006  \n",
       "         0                                   0.025978  \n",
       "         1                                   0.026393  \n",
       "         2                                   0.070236  \n",
       "         Maximum difference                  0.044258  "
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "fpred.evaluate_groups(test_dict,return_original=True) #on the test set"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAkgAAAHHCAYAAABEEKc/AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuNSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/xnp5ZAAAACXBIWXMAAA9hAAAPYQGoP6dpAABcvUlEQVR4nO3deVxUVeM/8M+wDJssCsgWAm4oibiCWLkkhlqUy+OaCoqYpWaQ/YRSEU0pK8VyoQyXyi3LLfUxFdPSEApCUxF3MQUUDVCUReb8/vDLfZxhcQZnGNDP+/Wal8655557zgWbT/ece0cmhBAgIiIiIomBvjtAREREVN8wIBERERGpYEAiIiIiUsGARERERKSCAYmIiIhIBQMSERERkQoGJCIiIiIVDEhEREREKhiQiIiIiFQwIBHRE2fOnDmQyWT67ka9FhISAnd3d313g6jeYkAiIrWtWbMGMpmsyldkZGSd9uXu3buYM2cODh48WKfHVVURxqp6xcfH67VvRFR7RvruABE1PHPnzoWHh4dSWbt27eq0D3fv3kVMTAwAoFevXkrbZs6cWeeBbcWKFWjUqJFSmZ+fX532gYi0hwGJiDTWv39/dOnSRa26xcXFkMvlMDCouwvWRkZGMDLS3n/e7t69C3Nz8xrr/Oc//4GdnZ3WjklE+sUpNiLSmoMHD0Imk2Hjxo2YOXMmXFxcYG5ujsLCQgDA5s2b0blzZ5iZmcHOzg6jR4/G1atXldoICQlBo0aNcPXqVQwcOBCNGjWCvb09pk+fjvLycgDApUuXYG9vDwCIiYmRprTmzJkDoPo1SN999510/CZNmmDEiBG4cuWKUp1evXqhXbt2SE1NRY8ePWBubo7333//sc+NOmPv1atXpathFefk4fVCly5dgkwmw6effoqvvvoKLVq0gImJCbp27Yo//vij0v7btm1Du3btYGpqinbt2mHr1q2PPR6iJx2vIBGRxgoKCpCXl6dU9vDVk3nz5kEul2P69OkoKSmBXC7HmjVrMG7cOHTt2hWxsbHIzc3FkiVLcOTIEfz111+wsbGR9i8vL0dgYCD8/Pzw6aefYv/+/fjss8/QokULvPnmm7C3t8eKFSvw5ptvYtCgQRg8eDAAoH379tX2ef78+Zg1axaGDRuGCRMm4MaNG/jiiy/Qo0ePSse/efMm+vfvjxEjRmD06NFwcHB45Dm5deuW0ntDQ0M0btwYADQauybWr1+P27dv44033oBMJsPChQsxePBgXLhwAcbGxgCAvXv3YsiQIfDy8kJsbCxu3ryJcePG4ZlnnqnVMYmeGoKISE2rV68WAKp8CSHEL7/8IgCI5s2bi7t370r7lZaWiqZNm4p27dqJe/fuSeU7d+4UAMTs2bOlsuDgYAFAzJ07V+nYHTt2FJ07d5be37hxQwAQ0dHRlfoZHR0tHv7P26VLl4ShoaGYP3++Ur2///5bGBkZKZX37NlTABDx8fFqnZOKY6m+3NzcNB57z549Rc+ePSsdIzg4WGpPCCEuXrwoAAhbW1tx69YtqXz79u0CgPjpp5+ksg4dOggnJyeRn58vle3du1epj0RUGa8gEZHGli1bhtatW1e7PTg4GGZmZtL7P//8E9evX8ecOXNgamoqlb/88sto06YNdu3aJS24rjBp0iSl9y+88AK+/fbbWvV3y5YtUCgUGDZsmNKVL0dHR7Rq1Qq//PKL0jSaiYkJxo0bp9ExfvzxR1hZWUnvK8Zfm7Gra/jw4dJVKuDBOQKACxcuAACys7ORnp6OyMhIWFtbS/X69u0LLy8vFBUV1eq4RE8DBiQi0pivr2+Ni7RV73C7fPkyAMDT07NS3TZt2uDw4cNKZaamptIaowqNGzfGv//+W6v+nj17FkIItGrVqsrtFdNRFVxcXCCXyzU6Ro8ePapcpK3p2DXRrFkzpfcVYaniPFUcu6pxe3p6Ii0trdbHJnrSMSARkdY9fPWoNgwNDbXUkwcUCgVkMhn++9//Vtm26u35j9v/2pLJZBBCVCqvWJyuqrrzVFUbRKQZBiQi0jk3NzcAQGZmJl588UWlbZmZmdJ2TWjypOwWLVpACAEPD48apwZ1QZOxN27cWJoee1jFlaDaHvvs2bOVtmVmZtaqTaKnBW/zJyKd69KlC5o2bYr4+HiUlJRI5f/973+RkZGBl19+WeM2K55LlJ+f/8i6gwcPhqGhIWJiYipdXRFC4ObNmxofX12ajL1FixY4ffo0bty4IZUdO3YMR44cqdWxnZyc0KFDB6xduxYFBQVS+b59+3Dq1KlatUn0tOAVJCLSOWNjY3z88ccYN24cevbsiZEjR0q3uru7uyM8PFzjNs3MzODl5YVNmzahdevWaNKkCdq1a1flE71btGiBDz/8EFFRUbh06RIGDhwIS0tLXLx4EVu3bsXEiRMxffp0bQy1Ek3GPn78eCxatAiBgYEIDQ3F9evXER8fj2effVZ6lpSmYmNj8fLLL+P555/H+PHjcevWLXzxxRd49tlncefOHW0Nk+iJwytIRFQnQkJCsGnTJpSWlmLGjBn48ssvMWjQIBw+fLjWzwH6+uuv4eLigvDwcIwcORI//PBDtXUjIyPx448/wsDAADExMZg+fTp27NiBl156Ca+++motR6Uedcfetm1bfPPNNygoKEBERAR27NiBb7/9Fp06dar1sfv164fNmzejvLwcUVFR2LJlC1avXq32k9CJnlYywdV8REREREp4BYmIiIhIBQMSERERkQoGJCIiIiIVDEhEREREKhiQiIiIiFQwIBERERGp4IMia0mhUODatWuwtLTU6CsPiIiISH+EELh9+zacnZ1hYFD9dSIGpFq6du0aXF1d9d0NIiIiqoUrV67gmWeeqXY7A1ItWVpaAnhwgq2srPTcGyIiIlJHYWEhXF1dpc/x6jAg1VLFtJqVlRUDEhERUQPzqOUxXKRNREREpIIBiYiIiEgFAxIRERGRCq5BIiKiapWXl6OsrEzf3SBSm7GxMQwNDR+7HQYkIiKqRAiBnJwc5Ofn67srRBqzsbGBo6PjYz2nkAGJiIgqqQhHTZs2hbm5OR+ISw2CEAJ3797F9evXAQBOTk61bosBiYiIlJSXl0vhyNbWVt/dIdKImZkZAOD69eto2rRprafbuEibiIiUVKw5Mjc313NPiGqn4nf3cdbPMSAREVGVOK1GDZU2fnc5xUakpnKFQMrFW7h+uxhNLU3h69EEhga1+0eozbaIiEj7GJCI1LDnRDZifjqF7IJiqczJ2hTRQV7o106zRYDabIuo9L4C3yZdwuVbd+HWxBxj/N0hN+LkgL7NmTMH27ZtQ3p6ur67QrUkE0IIfXeiISosLIS1tTUKCgr4XWxPsHKFwNID57B4/5lK2yqu96wY3UntYLPnRDbe/C4Nqv/oatMWPd0uF17G0l/+xo9/Xau0bUhHZ0zp7Q03K7datV1cXIyLFy/Cw8MDpqamj9vVOhUSEoK1a9dWKj979ixatmypk2PKZDJs3boVAwcOlMru3LmDkpISLnLXk5p+h9X9/OYVJHqq1TTVtedENubsOImcwpIq9xV4EGxifjqFvl6Oj5wiK1cIxPx0qlI4qk1bmo7lScJxPghHr2x9BQBg4VF53z35wJ6twM5BO2sdkrRFHz+vfv36YfXq1Upl9vb2Su9LS0shl8t11odGjRqhUaNGj9VGWVkZjI2NtdQj0hQDEj21aprqAlDllR5VAkB2QTFSLt6Cf4ua/08x5eItpWM9TluqnpZpO47zwTjzi++o1U5+8R246fECt75+XiYmJnB0dFQq69WrF9q1awcjIyN899138Pb2xi+//IJDhw7hvffew7Fjx9CkSRMEBwfjww8/hJGRkbRf+/btYWpqiq+//hpyuRyTJk3CnDlzAADu7u4AgEGDBgEA3NzccOnSpSqn2L7++mt89tlnuHjxItzd3fH222/jrbfeAgBcunQJHh4e2LhxI5YvX47k5GTEx8cjJCREZ+eJasaJanoqVUx1qQaWnIJiTPouDZFb/n5kOHrY9dvVBx9N6mhSr0JNY3nzuzTsOZGtUXv1Fcf5v3HuSP9HrbbUracL9fHntXbtWsjlchw5cgTx8fG4evUqBgwYgK5du+LYsWNYsWIFEhIS8OGHH1baz8LCAsnJyVi4cCHmzp2Lffv2AQD++OMPAMDq1auRnZ0tvVe1bt06zJ49G/Pnz0dGRgYWLFiAWbNmVZoOjIyMxLRp05CRkYHAwEAdnAVSF68g0VPnUVNdAJB/V7NnZzS1fPQ6DXXqVFWvpikKXU/b1Rccp/I4mzT+FzB7dHvJF/7Vcg/Vo++f186dO5Wmt/r37w8AaNWqFRYuXCiVf/DBB3B1dcXSpUshk8nQpk0bXLt2DTNmzMDs2bNhYPDgGkL79u0RHR0ttbF06VIkJiaib9++0tRdxVdbVCc6OhqfffYZBg8eDADw8PDAqVOn8OWXXyI4OFiq984770h1SL8YkEiirbUC9X2NyKOmujQhA+Bo/WCMj+Lr0QRO1qbIKSiu8oOjqrYeNUWhy2m7+oTjfKBinKYW99UKSNDoOqj26Pvn1bt3b6xYsUJ6b2FhgZEjR6Jz585K9TIyMuDv76/0zJznnnsOd+7cwT///INmzZoBeBCQHubk5CR9lYU6ioqKcP78eYSGhiIsLEwqv3//PqytrZXqdunSRe12SbcYkAiA9tYKNIQ1IppOYT1KdJCXWgHQ0ECG6CAvvPldGmRQ/uiq2Pvhtqq7461iimLF6E4oua9Qq4/aHnNd09X0ZH2jbv/dbc2Rd//R9bo1109Y1PfPy8LCoso71iwsLGrVnupCaZlMBoVCvX97wIM72gBg5cqV8PPzU9qm+jUYte0jaR/XIJHW1grUxzUHVVF3qutRnKxNNb4tv187J6wY3QmO1sp9cFRpS51pwJifTsGukYlax9XWmPWlttOTDY26/Q9o66BWvaAOLo/TnVprKD+vtm3bIikpCQ8/7ebIkSOwtLTEM888o3Y7xsbGKC8vr3a7g4MDnJ2dceHCBbRs2VLp5eFRxW2IVC/wCtJTTltrBfS95kAT6kx1WZsbo+D/1iFVVSc8oBWmvNiqVmPp184Jfb0ca5yGVHeKAgIaT9s1RLWZnmyI1B2nj6sN8Pej2zM21M+/tYby83rrrbcQFxeHqVOnYsqUKcjMzER0dDQiIiKk9UfqcHd3R2JiIp577jmYmJigcePGlerExMTg7bffhrW1Nfr164eSkhL8+eef+PfffxEREaHNYZGW8ArSU06TtQJ10U5dqJjqAv43tVWh4v1Hg72rvNLjZG2K+NGdMC2g9WMFPUMDGfxb2OK1Di7wb2FbqS11px7yikoeORZ1pwDrM3V+Zk/TOC1N1Hu+joWxfqZrGsrPy8XFBbt370ZKSgp8fHwwadIkhIaGYubMmRq189lnn2Hfvn1wdXVFx44dq6wzYcIEfP3111i9ejW8vb3Rs2dPrFmzhleQ6jE+SbuWnpQnaW9Pv4ppG9MfWW/JiA54rYbL9dpqpy6ps15KXwvOk87fxMiVRx9Zb0NYN/i3sG0Qa7+0geP83zgvF15GUVkRysoFdh+/huyCYjhZm2JAe2cYG8pgYWyh9ydpPy0/L6p/+CRtemzaWiugyzUHugop6kx1VVzpqWuaTlGoM5YnAcf5v3E+HH58Ap7VRzcf6Wn5edGTiQHpKaettQK6WnOg6/8D1VcAehRN73ir2Kc+jkXbOM6G5UkZBz19uAbpKaettQK6WHPQUO6K0xV173gjIiLt4xUkkj6IVa/UOGp4paa27ZTeV+DbpEu4fOsu3JqYY4y/OwwNZA3mrjhd4hQFEZF+MCARAO19EGvaTuzuU1j520UoHkpC83dn4GVvx6fiycnq4BQFEVHdY0AiibY+iNVtJ3b3KXz568VK5QoB/HQ8R61jNfQnJxMRUf3EgPSU09dt7KX3FVj5W+VwpCl9P4mXiIieTAxI9UhdhxV9PqPk26RLStNqmqovT+IlIqInEwNSPVHXYUWdL0LVZUi6fOuu2nXVvc2diIhIW3ibfz1Q17ezq/tFqOWPc4nnEdyamKtV7z+dXHibOxHVmUuXLkEmkyE9PV3tfdasWQMbGxu990PXZDIZtm3bBqB+9k/beAVJz/TxJa+afG+aru6eGuPvjvm7M2qcZjOQAQsGt4ehgYy3uROR2q5cuYLo6Gjs2bMHeXl5cHJywsCBAzF79mzY2tb83zRXV1dkZ2fDzs5O7eMNHz4cAwYMeNxuNyianqeQkBDk5+dLAash4BUkPdPHl7yqe+eXLu8QkxsZIOyFmr+kMewFD8iNDB75xa5EVM+V3QN+/fTBnzp24cIFdOnSBWfPnsWGDRtw7tw5xMfHIzExEf7+/rh1q/r/lpaWlsLQ0BCOjo4wMlL/+oGZmRmaNm2qje7rXFlZmVbaqc150obS0tI6OxYDkp7pI6zo8nvTNBE1wAtv9PCAat4xkAFv9PBA1AAvnR6fiOrIqR3AgXlAxk86P9TkyZMhl8uxd+9e9OzZE82aNUP//v2xf/9+XL16FR988IFU193dHfPmzcPYsWNhZWWFiRMnVjl1tGPHDrRq1Qqmpqbo3bs31q5dC5lMhvz8fACVp9jmzJmDDh064Ntvv4W7uzusra0xYsQI3L59W6qzZ88ePP/887CxsYGtrS1eeeUVnD9/XqOxVvR/5MiRsLCwgIuLC5YtW6ZURyaTYcWKFXj11VdhYWGB+fPnAwC2b9+OTp06wdTUFM2bN0dMTAzu378v7Xf27Fn06NEDpqam8PLywr59+5Tareo8nTx5Eq+88gqsrKxgaWmJF154AefPn8ecOXOwdu1abN++HTKZDDKZDAcPHgQA/P3333jxxRdhZmYGW1tbTJw4EXfu3JHaDAkJwcCBAzF//nw4OzvD09NTo3P0OPQekJYtWwZ3d3eYmprCz88PKSkpNdaPi4uDp6cnzMzM4OrqivDwcBQX/y88uLu7Sz+Ah1+TJ0+W6vTq1avS9kmTJulsjDXRR1ip+N606q7DyPBggXhd3CEWNcALp+f1x6yX22KsvxtmvdwWp+f1ZzgiepKc3Kr8p47cunULP//8M9566y2YmZkpbXN0dMTrr7+OTZs2QYj/ze1/+umn8PHxwV9//YVZs2ZVavPixYv4z3/+g4EDB+LYsWN44403lEJWdc6fP49t27Zh586d2LlzJw4dOoSPPvpI2l5UVISIiAj8+eefSExMhIGBAQYNGgSFQqHRmD/55BOp/5GRkZg2bVqlMDNnzhwMGjQIf//9N8aPH4/ffvsNY8eOxbRp03Dq1Cl8+eWXWLNmjRSeFAoFBg8eDLlcjuTkZMTHx2PGjBk19uPq1avo0aMHTExMcODAAaSmpmL8+PG4f/8+pk+fjmHDhqFfv37Izs5GdnY2unfvjqKiIgQGBqJx48b4448/sHnzZuzfvx9TpkxRajsxMRGZmZnYt28fdu7cqdH5eRx6XYO0adMmREREID4+Hn5+foiLi0NgYCAyMzOrvFy5fv16REZGYtWqVejevTvOnDmDkJAQyGQyLFq0CADwxx9/oLy8XNrnxIkT6Nu3L4YOHarUVlhYGObOnSu9NzdXb9GwtunqS15rUpsvQtUluZEBQl9oXifHIqI6cOc6kLQMUPzfFYnziQ/+PLcf+Pn/woWBEeA/BWhkr7XDnj17FkIItG3btsrtbdu2xb///osbN25InzEvvvgi3n33XanOpUuXlPb58ssv4enpiU8++QQA4OnpiRMnTkhhojoKhQJr1qyBpaUlAGDMmDFITEyU9hsyZIhS/VWrVsHe3h6nTp1Cu3bt1B7zc889h8jISABA69atceTIESxevBh9+/aV6owaNQrjxo2T3o8fPx6RkZEIDg4GADRv3hzz5s3D//t//w/R0dHYv38/Tp8+jZ9//hnOzs4AgAULFqB///7V9mPZsmWwtrbGxo0bYWxsLPWngpmZGUpKSuDo6CiVrV27FsXFxfjmm29gYWEBAFi6dCmCgoLw8ccfw8HBAQBgYWGBr7/+GnK5XO3zog16vYK0aNEihIWFYdy4cfDy8kJ8fDzMzc2xatWqKuv//vvveO655zBq1Ci4u7vjpZdewsiRI5WuOtnb28PR0VF67dy5Ey1atEDPnj2V2jI3N1eqZ2VlpdOxVkcXX/KqDn4RKhHpzO0c4OgKIGkpcHQ5oPi//2lVlD94n7T0wfbbuvnC6YevED1Kly5datyemZmJrl27KpX5+vo+sl13d3cpHAGAk5MTrl+/Lr0/e/YsRo4ciebNm8PKygru7u4AgKysLLX7DgD+/v6V3mdkZCiVqY7x2LFjmDt3Lho1aiS9wsLCkJ2djbt37yIjIwOurq5SOKrqOKrS09PxwgsvSOFIHRkZGfDx8ZHCEfAg8CkUCmRmZkpl3t7edR6OAD0GpNLSUqSmpiIgIOB/nTEwQEBAAJKSkqrcp3v37khNTZUC0YULF7B79+5q7x4oLS3Fd999h/Hjx0MmUw4Y69atg52dHdq1a4eoqCjcvav+c3m0TV9hpV87Jxye8SI2hHXDkhEdsCGsGw7PeJHhiIgej1N74I1DgN3/XUEQ5cp/2rV+sN2pvVYP27JlS8hkskoBoUJGRgYaN24Me/v/XbV6+MNZm1SDgkwmU5o+CwoKwq1bt7By5UokJycjOTkZgG4WIauO8c6dO4iJiUF6err0+vvvv3H27FmYmtZuOYfqlKY26epn9Ch6m2LLy8tDeXm5dAmtgoODA06fPl3lPqNGjUJeXh6ef/55CCFw//59TJo0Ce+//36V9bdt24b8/HyEhIRUasfNzQ3Ozs44fvw4ZsyYgczMTGzZsqXa/paUlKCkpER6X1hYqOZI1aOvb23nF6ESkU40bQuE7gUWVjF9HroXMGus9UPa2tqib9++WL58OcLDw5U+tHNycrBu3TqMHTu20v8w18TT0xO7d+9WKvvjjz8eq583b95EZmYmVq5ciRdeeAEAcPjw4Vq1dfTo0Urvq5tirNCpUydkZmaiZcuWVW5v27Ytrly5guzsbDg5OVV5HFXt27fH2rVrUVZWVuVVJLlcrrT8peI4a9asQVFRkRSCjhw5AgMDgzpdjF0dvS/S1sTBgwexYMECLF++HGlpadiyZQt27dqFefPmVVk/ISEB/fv3V7pMCAATJ05EYGAgvL298frrr+Obb77B1q1ba7yDIDY2FtbW1tLL1dVVq2MDwNvZiejJcvl3QKgsOhYK4HLVswTasHTpUpSUlCAwMBC//vorrly5gj179qBv375wcXF55NohVW+88QZOnz6NGTNm4MyZM/j++++xZs0aANAoaD2scePGsLW1xVdffYVz587hwIEDiIiIqFVbR44cwcKFC3HmzBksW7YMmzdvxrRp02rcZ/bs2fjmm28QExODkydPIiMjAxs3bsTMmTMBAAEBAWjdujWCg4Nx7Ngx/Pbbb49cmD5lyhQUFhZixIgR+PPPP3H27Fl8++230lSZu7s7jh8/jszMTOTl5aGsrAyvv/46TE1NERwcjBMnTuCXX37B1KlTMWbMmEoXT/RBbwHJzs4OhoaGyM3NVSrPzc1VWsT1sFmzZmHMmDGYMGECvL29MWjQICxYsACxsbGVVv5fvnwZ+/fvx4QJEx7ZFz8/PwDAuXPnqq0TFRWFgoIC6XXlypVHtktE9FTL2PHgz2b+QOh+wLWbcrkOtGrVCn/++SeaN2+OYcOGoUWLFpg4cSJ69+6NpKQkNGmi2Q0vHh4e+OGHH7Blyxa0b98eK1askMKCiYlJrfpoYGCAjRs3IjU1Fe3atUN4eLi0CFxT7777Lv7880907NgRH374IRYtWoTAwMAa9wkMDMTOnTuxd+9edO3aFd26dcPixYvh5uYm9W/r1q24d+8efH19MWHChEcGS1tbWxw4cAB37txBz5490blzZ6xcuVK6mhQWFgZPT0906dIF9vb2OHLkCMzNzfHzzz/j1q1b6Nq1K/7zn/+gT58+WLp0aa3OhdYJPfL19RVTpkyR3peXlwsXFxcRGxtbZf1OnTqJ//f//p9S2fr164WZmZm4f/++Unl0dLRwdHQUZWVlj+zH4cOHBQBx7NgxtfteUFAgAIiCggK19yEiagju3bsnTp06Je7du/d4DSWtEOK3xUKU/99/n8vvP3iftOJxu6hXH374oXjmmWf03Q3h5uYmFi9erO9u1Es1/Q6r+/mt19v8IyIiEBwcjC5dusDX1xdxcXEoKiqSbkccO3YsXFxcEBsbC+DBorZFixahY8eO8PPzw7lz5zBr1iwEBQXB0NBQalehUGD16tUIDg6u9JTP8+fPY/369RgwYABsbW1x/PhxhIeHo0ePHmjfXrsLBomInmrdVJ4vZ2AIPP+OXrryOJYvX46uXbvC1tYWR44cwSeffFLpWT305NFrQBo+fDhu3LiB2bNnIycnBx06dMCePXukucesrCwYGPxvFnDmzJmQyWSYOXMmrl69Cnt7ewQFBVW69Ld//35kZWVh/PjxlY4pl8uxf/9+KYy5urpiyJAh0twrERHRw86ePYsPP/wQt27dQrNmzfDuu+8iKipK390iHZMJocEDI0hSWFgIa2trFBQU6O0ZSkREulBcXIyLFy/Cw8Oj1rd9E+lTTb/D6n5+N6i72IiIiIjqAgMSERERkQoGJCIiIiIVDEhEREREKhiQiIiIiFQwIBERERGpYEAiIiJSU69evfDOO+/o5dgHDx6ETCZDfn6+Xo6v6tKlS5DJZEhPTwdQ//r3uBiQiIjoiVFdgFmzZg1sbGzqvD9PWmioSffu3ZGdnQ1ra2u16uszbKpDr0/SJiKiJ9PlwssoKiuqdruFsQXcrNzqsEdUnbKyMulLZR+HXC6v9svmdam0tBRyuVzr7fIKEhERadXlwst4ZesrGL5zeLWvV7a+gsuFl/XWx5CQEAwcOBAxMTGwt7eHlZUVJk2ahNLSUqlOUVERxo4di0aNGsHJyQmfffZZpXa+/fZbdOnSBZaWlnB0dMSoUaNw/fp1AA+moHr37g0AaNy4MWQyGUJCQgA8+M7Q2NhYeHh4wMzMDD4+Pvjhhx+U2t69ezdat24NMzMz9O7dG5cuXXrkuGQyGVasWIH+/fvDzMwMzZs3V2q3Ylps06ZN6NmzJ0xNTbFu3ToAwNdff422bdvC1NQUbdq0wfLly5XaTklJQceOHWFqaoouXbrgr7/+Utpe1dWyI0eOoFevXjA3N0fjxo0RGBiIf//9FyEhITh06BCWLFkCmUwGmUwmje/QoUPw9fWFiYkJnJycEBkZifv370tt9urVC1OmTME777wDOzs7BAYGPvK81AYDEhERaVVNV45qU09XEhMTkZGRgYMHD2LDhg3YsmULYmJipO3vvfceDh06hO3bt2Pv3r04ePAg0tLSlNooKyvDvHnzcOzYMWzbtg2XLl2SQpCrqyt+/PFHAEBmZiays7OxZMkSAEBsbCy++eYbxMfH4+TJkwgPD8fo0aNx6NAhAMCVK1cwePBgBAUFIT09HRMmTEBkZKRa45o1axaGDBmCY8eO4fXXX8eIESOQkZGhVCcyMhLTpk1DRkYGAgMDsW7dOsyePRvz589HRkYGFixYgFmzZmHt2rUAgDt37uCVV16Bl5cXUlNTMWfOHEyfPr3GfqSnp6NPnz7w8vJCUlISDh8+jKCgIJSXl2PJkiXw9/dHWFgYsrOzkZ2dDVdXV1y9ehUDBgxA165dcezYMaxYsQIJCQn48MMPldpeu3Yt5HI5jhw5gvj4eLXOi8YE1UpBQYEAIAoKCvTdFSIirbp37544deqUuHfvXq32P5l3UrRb0+6Rr5N5J7XccyF69uwppk2bVql89erVwtraWnofHBwsmjRpIoqKiqSyFStWiEaNGony8nJx+/ZtIZfLxffffy9tv3nzpjAzM6uy/Qp//PGHACBu374thBDil19+EQDEv//+K9UpLi4W5ubm4vfff1faNzQ0VIwcOVIIIURUVJTw8vJS2j5jxoxKbakCICZNmqRU5ufnJ958800hhBAXL14UAERcXJxSnRYtWoj169crlc2bN0/4+/sLIYT48ssvha2trdLvxIoVKwQA8ddff1U51pEjR4rnnnuu2r5W9bN6//33haenp1AoFFLZsmXLpJ9LxX4dO3astl0hav4dVvfzm2uQiIjoqeTj4wNzc3Ppvb+/P+7cuYMrV64gPz8fpaWl8PPzk7Y3adIEnp6eSm1UXE05duwY/v33XygUCgBAVlYWvLy8qjzuuXPncPfuXfTt21epvLS0FB07dgQAZGRkKB27on/qUK3n7+8v3WlWoUuXLtLfi4qKcP78eYSGhiIsLEwqv3//vrTgOiMjA+3bt1f64tdH9Sc9PR1Dhw5Vq88VMjIy4O/vD5lMJpU999xzuHPnDv755x80a9YMANC5c2eN2q0NBiQiInpiWFlZoaCgoFJ5fn6+2ndXqauoqAiBgYHSFJW9vT2ysrIQGBiotJZJ1Z07dwAAu3btgouLi9I2ExMTrfaxOhYWFpX6s3LlykqhzNDQsNbHMDMzq/W+j/Jw/3WFa5CIiOiJ4enpWWmdEACkpaWhdevWSmXHjh3DvXv3pPdHjx5Fo0aN4OrqihYtWsDY2BjJycnS9n///RdnzpyR3p8+fRo3b97ERx99hBdeeAFt2rSRFmhXqLi7qry8XCrz8vKCiYkJsrKy0LJlS6WXq6srAKBt27ZISUlRauvo0aNqnQPVekePHkXbtm2rre/g4ABnZ2dcuHChUn88PDyk/hw/fhzFxcVq96d9+/ZITEysdrtcLlc6LxXHSUpKghBCKjty5AgsLS3xzDPP1Hg8bWNAIiKiJ8abb76JM2fO4O2338bx48eRmZmJRYsWYcOGDXj33XeV6paWliI0NBSnTp3C7t27ER0djSlTpsDAwACNGjVCaGgo3nvvPRw4cAAnTpxASEgIDAz+97HZrFkzyOVyfPHFF7hw4QJ27NiBefPmKR3Dzc0NMpkMO3fuxI0bN3Dnzh1YWlpi+vTpCA8Px9q1a3H+/HmkpaXhiy++kBZFT5o0CWfPnsV7772HzMxMrF+/HmvWrFHrHGzevBmrVq3CmTNnEB0djZSUFEyZMqXGfWJiYhAbG4vPP/8cZ86cwd9//43Vq1dj0aJFAIBRo0ZBJpMhLCxMOl+ffvppjW1GRUXhjz/+wFtvvYXjx4/j9OnTWLFiBfLy8gAA7u7uSE5OxqVLl5CXlweFQoG33noLV65cwdSpU3H69Gls374d0dHRiIiIUDr3daLGFUpULS7SJqInVUNepC2EECkpKaJv377C3t5eWFtbCz8/P7F161alOsHBweK1114Ts2fPFra2tqJRo0YiLCxMFBcXS3Vu374tRo8eLczNzYWDg4NYuHBhpYXF69evF+7u7sLExET4+/uLHTt2KC1cFkKIuXPnCkdHRyGTyURwcLAQQgiFQiHi4uKEp6enMDY2Fvb29iIwMFAcOnRI2u+nn34SLVu2FCYmJuKFF14Qq1atUmuR9rJly0Tfvn2FiYmJcHd3F5s2bZK2VyzSfrh/FdatWyc6dOgg5HK5aNy4sejRo4fYsmWLtD0pKUn4+PgIuVwuOnToIH788ccaF2kLIcTBgwdF9+7dhYmJibCxsRGBgYHS9szMTNGtWzdhZmYmAIiLFy9K+3Tt2lXI5XLh6OgoZsyYIcrKyqQ2q1uI/zBtLNKWCfHQdSxSW2FhIaytrVFQUAArKyt9d4eISGuKi4tx8eJFeHh4KC3KVVfFc5AeZeegnXp7WGRISAjy8/Oxbds2vRxfV2QyGbZu3YqBAwfquyt6VdPvsLqf31ykTUREWuVm5Yadg3bySdrUoDEgERGR1jH8UEPHgERERE8ddRc8NzRcNaM9vIuNiIiISAUDEhERVYlXI6ih0sbvLgMSEREpMTY2BgDcvXtXzz0hqp2K392K3+Xa4BokIiJSYmhoCBsbG+mp0Obm5krfjUVUXwkhcPfuXVy/fh02NjaP9VUpDEhERFSJo6MjAFT66gyihsDGxkb6Ha4tBiQiIqpEJpPByckJTZs2RVlZmb67Q6Q2Y2Pjx7pyVIEBiYiIqmVoaKiVDxuihoaLtImIiIhUMCARERERqWBAIiIiIlLBgERERESkggGJiIiISAUDEhEREZEKBiQiIiIiFQxIRERERCr0HpCWLVsGd3d3mJqaws/PDykpKTXWj4uLg6enJ8zMzODq6orw8HAUFxdL2+fMmQOZTKb0atOmjVIbxcXFmDx5MmxtbdGoUSMMGTIEubm5OhkfERERNTx6DUibNm1CREQEoqOjkZaWBh8fHwQGBlb73T/r169HZGQkoqOjkZGRgYSEBGzatAnvv/++Ur1nn30W2dnZ0uvw4cNK28PDw/HTTz9h8+bNOHToEK5du4bBgwfrbJxERETUsOj1q0YWLVqEsLAwjBs3DgAQHx+PXbt2YdWqVYiMjKxU//fff8dzzz2HUaNGAQDc3d0xcuRIJCcnK9UzMjKq9kvqCgoKkJCQgPXr1+PFF18EAKxevRpt27bF0aNH0a1bN20OkYiIiBogvV1BKi0tRWpqKgICAv7XGQMDBAQEICkpqcp9unfvjtTUVGka7sKFC9i9ezcGDBigVO/s2bNwdnZG8+bN8frrryMrK0valpqairKyMqXjtmnTBs2aNav2uERERPR00dsVpLy8PJSXl8PBwUGp3MHBAadPn65yn1GjRiEvLw/PP/88hBC4f/8+Jk2apDTF5ufnhzVr1sDT0xPZ2dmIiYnBCy+8gBMnTsDS0hI5OTmQy+WwsbGpdNycnJxq+1tSUoKSkhLpfWFhYS1GTURERA2B3hdpa+LgwYNYsGABli9fjrS0NGzZsgW7du3CvHnzpDr9+/fH0KFD0b59ewQGBmL37t3Iz8/H999//1jHjo2NhbW1tfRydXV93OEQERFRPaW3gGRnZwdDQ8NKd4/l5uZWu35o1qxZGDNmDCZMmABvb28MGjQICxYsQGxsLBQKRZX72NjYoHXr1jh37hwAwNHREaWlpcjPz1f7uAAQFRWFgoIC6XXlyhUNRktEREQNid4CklwuR+fOnZGYmCiVKRQKJCYmwt/fv8p97t69CwMD5S4bGhoCAIQQVe5z584dnD9/Hk5OTgCAzp07w9jYWOm4mZmZyMrKqva4AGBiYgIrKyulFxERET2Z9HoXW0REBIKDg9GlSxf4+voiLi4ORUVF0l1tY8eOhYuLC2JjYwEAQUFBWLRoETp27Ag/Pz+cO3cOs2bNQlBQkBSUpk+fjqCgILi5ueHatWuIjo6GoaEhRo4cCQCwtrZGaGgoIiIi0KRJE1hZWWHq1Knw9/fnHWxEREQEQM8Bafjw4bhx4wZmz56NnJwcdOjQAXv27JEWbmdlZSldMZo5cyZkMhlmzpyJq1evwt7eHkFBQZg/f75U559//sHIkSNx8+ZN2Nvb4/nnn8fRo0dhb28v1Vm8eDEMDAwwZMgQlJSUIDAwEMuXL6+7gRMREVG9JhPVzU1RjQoLC2FtbY2CggJOtxERETUQ6n5+N6i72IiIiIjqAgMSERERkQoGJCIiIiIVDEhEREREKhiQiIiIiFQwIBERERGpYEAiIiIiUsGARERERKSCAYmIiIhIBQMSERERkQoGJCIiIiIVDEhEREREKhiQiIiIiFQwIBERERGpYEAiIiIiUsGARERERKSCAYmIiIhIBQMSERERkQoGJCIiIiIVDEhEREREKhiQiIiIiFQwIBERERGpYEAiIiIiUsGARERERKSCAYmIiIhIBQMSERERkQoGJCIiIiIVDEhEREREKhiQiIiIiFQwIBERERGpYEAiIiIiUsGARERERKSCAYmIiIhIBQMSERERkQoGJCIiIiIVDEhEREREKvQekJYtWwZ3d3eYmprCz88PKSkpNdaPi4uDp6cnzMzM4OrqivDwcBQXF0vbY2Nj0bVrV1haWqJp06YYOHAgMjMzldro1asXZDKZ0mvSpEk6GR8RERE1PHoNSJs2bUJERASio6ORlpYGHx8fBAYG4vr161XWX79+PSIjIxEdHY2MjAwkJCRg06ZNeP/996U6hw4dwuTJk3H06FHs27cPZWVleOmll1BUVKTUVlhYGLKzs6XXwoULdTpWIiIiajiM9HnwRYsWISwsDOPGjQMAxMfHY9euXVi1ahUiIyMr1f/999/x3HPPYdSoUQAAd3d3jBw5EsnJyVKdPXv2KO2zZs0aNG3aFKmpqejRo4dUbm5uDkdHR10Mi4iIiBo4vV1BKi0tRWpqKgICAv7XGQMDBAQEICkpqcp9unfvjtTUVGka7sKFC9i9ezcGDBhQ7XEKCgoAAE2aNFEqX7duHezs7NCuXTtERUXh7t27jzskIiIiekLo7QpSXl4eysvL4eDgoFTu4OCA06dPV7nPqFGjkJeXh+effx5CCNy/fx+TJk1SmmJ7mEKhwDvvvIPnnnsO7dq1U2rHzc0Nzs7OOH78OGbMmIHMzExs2bKl2v6WlJSgpKREel9YWKjJcImIiKgB0esUm6YOHjyIBQsWYPny5fDz88O5c+cwbdo0zJs3D7NmzapUf/LkyThx4gQOHz6sVD5x4kTp797e3nByckKfPn1w/vx5tGjRospjx8bGIiYmRrsDIiIionpJb1NsdnZ2MDQ0RG5urlJ5bm5utWuDZs2ahTFjxmDChAnw9vbGoEGDsGDBAsTGxkKhUCjVnTJlCnbu3IlffvkFzzzzTI198fPzAwCcO3eu2jpRUVEoKCiQXleuXFFnmERERNQA6S0gyeVydO7cGYmJiVKZQqFAYmIi/P39q9zn7t27MDBQ7rKhoSEAQAgh/TllyhRs3boVBw4cgIeHxyP7kp6eDgBwcnKqto6JiQmsrKyUXkRERPRk0usUW0REBIKDg9GlSxf4+voiLi4ORUVF0l1tY8eOhYuLC2JjYwEAQUFBWLRoETp27ChNsc2aNQtBQUFSUJo8eTLWr1+P7du3w9LSEjk5OQAAa2trmJmZ4fz581i/fj0GDBgAW1tbHD9+HOHh4ejRowfat2+vnxNBRERE9YpeA9Lw4cNx48YNzJ49Gzk5OejQoQP27NkjLdzOyspSumI0c+ZMyGQyzJw5E1evXoW9vT2CgoIwf/58qc6KFSsAPHgY5MNWr16NkJAQyOVy7N+/Xwpjrq6uGDJkCGbOnKn7ARMREVGDIBMVc1OkkcLCQlhbW6OgoIDTbURERA2Eup/fev+qESIiIqL6hgGJiIiISAUDEhEREZEKBiQiIiIiFQxIRERERCoYkIiIiIhUMCARERERqWBAIiIiIlLBgERERESkggGJiIiISAUDEhEREZEKBiQiIiIiFQxIRERERCo0Dkju7u6YO3cusrKydNEfIiIiIr3TOCC988472LJlC5o3b46+ffti48aNKCkp0UXfiIiIiPSiVgEpPT0dKSkpaNu2LaZOnQonJydMmTIFaWlpuugjERERUZ2SCSHE4zRQVlaG5cuXY8aMGSgrK4O3tzfefvttjBs3DjKZTFv9rHcKCwthbW2NgoICWFlZ6bs7REREpAZ1P7+NanuAsrIybN26FatXr8a+ffvQrVs3hIaG4p9//sH777+P/fv3Y/369bVtnoiIiEhvNA5IaWlpWL16NTZs2AADAwOMHTsWixcvRps2baQ6gwYNQteuXbXaUSIiIqK6onFA6tq1K/r27YsVK1Zg4MCBMDY2rlTHw8MDI0aM0EoHiYiIiOqaxgHpwoULcHNzq7GOhYUFVq9eXetOEREREemTxnexXb9+HcnJyZXKk5OT8eeff2qlU0RERET6pHFAmjx5Mq5cuVKp/OrVq5g8ebJWOkVERESkTxoHpFOnTqFTp06Vyjt27IhTp05ppVNERERE+qRxQDIxMUFubm6l8uzsbBgZ1fqpAURERET1hsYB6aWXXkJUVBQKCgqksvz8fLz//vvo27evVjtHREREpA8aX/L59NNP0aNHD7i5uaFjx44AgPT0dDg4OODbb7/VegeJiIiI6prGAcnFxQXHjx/HunXrcOzYMZiZmWHcuHEYOXJklc9EIiIiImpoarVoyMLCAhMnTtR2X4iIiIjqhVqvqj516hSysrJQWlqqVP7qq68+dqeIiIiI9KlWT9IeNGgQ/v77b8hkMgghAAAymQwAUF5ert0eEhEREdUxje9imzZtGjw8PHD9+nWYm5vj5MmT+PXXX9GlSxccPHhQB10kIiIiqlsaX0FKSkrCgQMHYGdnBwMDAxgYGOD5559HbGws3n77bfz111+66CcRERFRndH4ClJ5eTksLS0BAHZ2drh27RoAwM3NDZmZmdrtHREREZEeaHwFqV27djh27Bg8PDzg5+eHhQsXQi6X46uvvkLz5s110UciIiKiOqVxQJo5cyaKiooAAHPnzsUrr7yCF154Aba2tti0aZPWO0hERERU1zSeYgsMDMTgwYMBAC1btsTp06eRl5eH69ev48UXX9S4A8uWLYO7uztMTU3h5+eHlJSUGuvHxcXB09MTZmZmcHV1RXh4OIqLizVqs7i4GJMnT4atrS0aNWqEIUOGVPn9ckRERPR00igglZWVwcjICCdOnFAqb9KkiXSbvyY2bdqEiIgIREdHIy0tDT4+PggMDMT169errL9+/XpERkYiOjoaGRkZSEhIwKZNm/D+++9r1GZ4eDh++uknbN68GYcOHcK1a9ek0EdEREQEoSEPDw+Rnp6u6W5V8vX1FZMnT5bel5eXC2dnZxEbG1tl/cmTJ4sXX3xRqSwiIkI899xzareZn58vjI2NxebNm6U6GRkZAoBISkpSu+8FBQUCgCgoKFB7HyIiItIvdT+/NZ5i++CDD/D+++/j1q1bjxXMSktLkZqaioCAAKnMwMAAAQEBSEpKqnKf7t27IzU1VZoyu3DhAnbv3o0BAwao3WZqairKysqU6rRp0wbNmjWr9rhERET0dNF4kfbSpUtx7tw5ODs7w83NDRYWFkrb09LS1GonLy8P5eXlcHBwUCp3cHDA6dOnq9xn1KhRyMvLw/PPPw8hBO7fv49JkyZJU2zqtJmTkwO5XA4bG5tKdXJycqrtb0lJCUpKSqT3hYWFao2TiIiIGh6NA9LAgQN10A31HDx4EAsWLMDy5cvh5+eHc+fOYdq0aZg3bx5mzZql02PHxsYiJiZGp8cgIiKi+kHjgBQdHa2VA9vZ2cHQ0LDS3WO5ublwdHSscp9Zs2ZhzJgxmDBhAgDA29sbRUVFmDhxIj744AO12nR0dERpaSny8/OVriLVdFwAiIqKQkREhPS+sLAQrq6uGo2ZiIiIGgaN1yBpi1wuR+fOnZGYmCiVKRQKJCYmwt/fv8p97t69CwMD5S4bGhoCAIQQarXZuXNnGBsbK9XJzMxEVlZWtccFABMTE1hZWSm9iIiI6Mmk8RUkAwODGm/pLy8vV7utiIgIBAcHo0uXLvD19UVcXByKioowbtw4AMDYsWPh4uKC2NhYAEBQUBAWLVqEjh07SlNss2bNQlBQkBSUHtWmtbU1QkNDERERgSZNmsDKygpTp06Fv78/unXrpunpICIioieQxgFp69atSu/Lysrw119/Ye3atRqv0Rk+fDhu3LiB2bNnIycnBx06dMCePXukRdZZWVlKV4xmzpwJmUyGmTNn4urVq7C3t0dQUBDmz5+vdpsAsHjxYhgYGGDIkCEoKSlBYGAgli9frumpICIioieUTAghtNHQ+vXrsWnTJmzfvl0bzdV7hYWFsLa2RkFBAafbiIiIGgh1P7+1tgapW7duSut6iIiIiBoqrQSke/fu4fPPP4eLi4s2miMiIiLSK43XIDVu3FhpkbYQArdv34a5uTm+++47rXaOiIiISB80DkiLFy9WCkgGBgawt7eHn58fGjdurNXOEREREemDxgEpJCREB90gIiIiqj80XoO0evVqbN68uVL55s2bsXbtWq10ioiIiEifNA5IsbGxsLOzq1TetGlTLFiwQCudIiIiItInjQNSVlYWPDw8KpW7ubkhKytLK50iIiIi0ieNA1LTpk1x/PjxSuXHjh2Dra2tVjpFREREpE8aB6SRI0fi7bffxi+//ILy8nKUl5fjwIEDmDZtGkaMGKGLPhIRERHVKY3vYps3bx4uXbqEPn36wMjowe4KhQJjx47lGiQiIiJ6ItT6u9jOnj2L9PR0mJmZwdvbG25ubtruW73G72IjIiJqeNT9/Nb4ClKFVq1aoVWrVrXdnYiIiKje0ngN0pAhQ/Dxxx9XKl+4cCGGDh2qlU4RERER6ZPGAenXX3/FgAEDKpX3798fv/76q1Y6RURERKRPGgekO3fuQC6XVyo3NjZGYWGhVjpFREREpE8aByRvb29s2rSpUvnGjRvh5eWllU4RERER6ZPGi7RnzZqFwYMH4/z583jxxRcBAImJiVi/fj1++OEHrXeQiIiIqK5pHJCCgoKwbds2LFiwAD/88APMzMzg4+ODAwcOoEmTJrroIxEREVGdqvVzkCoUFhZiw4YNSEhIQGpqKsrLy7XVt3qNz0EiIiJqeNT9/NZ4DVKFX3/9FcHBwXB2dsZnn32GF198EUePHq1tc0RERET1hkZTbDk5OVizZg0SEhJQWFiIYcOGoaSkBNu2beMCbSIiInpiqH0FKSgoCJ6enjh+/Dji4uJw7do1fPHFF7rsGxEREZFeqH0F6b///S/efvttvPnmm/yKESIiInqiqX0F6fDhw7h9+zY6d+4MPz8/LF26FHl5ebrsGxEREZFeqB2QunXrhpUrVyI7OxtvvPEGNm7cCGdnZygUCuzbtw+3b9/WZT+JiIiI6sxj3eafmZmJhIQEfPvtt8jPz0ffvn2xY8cObfav3uJt/kRERA2Pzm/zBwBPT08sXLgQ//zzDzZs2PA4TRERERHVG4/9oMinFa8gERERNTx1cgWJiIiI6EnEgERERESkggGJiIiISAUDEhEREZEKBiQiIiIiFQxIRERERCoYkIiIiIhU1IuAtGzZMri7u8PU1BR+fn5ISUmptm6vXr0gk8kqvV5++WWpTlXbZTIZPvnkE6mOu7t7pe0fffSRTsdJREREDYORvjuwadMmREREID4+Hn5+foiLi0NgYCAyMzPRtGnTSvW3bNmC0tJS6f3Nmzfh4+ODoUOHSmXZ2dlK+/z3v/9FaGgohgwZolQ+d+5chIWFSe8tLS21NSwiIiJqwPQekBYtWoSwsDCMGzcOABAfH49du3Zh1apViIyMrFS/SZMmSu83btwIc3NzpYDk6OioVGf79u3o3bs3mjdvrlRuaWlZqS4RERGRXqfYSktLkZqaioCAAKnMwMAAAQEBSEpKUquNhIQEjBgxAhYWFlVuz83Nxa5duxAaGlpp20cffQRbW1t07NgRn3zyCe7fv1+7gRAREdETRa9XkPLy8lBeXg4HBwelcgcHB5w+ffqR+6ekpODEiRNISEiots7atWthaWmJwYMHK5W//fbb6NSpE5o0aYLff/8dUVFRyM7OxqJFi6psp6SkBCUlJdL7wsLCR/aPiIiIGia9T7E9joSEBHh7e8PX17faOqtWrcLrr78OU1NTpfKIiAjp7+3bt4dcLscbb7yB2NhYmJiYVGonNjYWMTEx2us8ERER1Vt6nWKzs7ODoaEhcnNzlcpzc3MfuTaoqKgIGzdurHLqrMJvv/2GzMxMTJgw4ZF98fPzw/3793Hp0qUqt0dFRaGgoEB6Xbly5ZFtEhERUcOk14Akl8vRuXNnJCYmSmUKhQKJiYnw9/evcd/NmzejpKQEo0ePrrZOQkICOnfuDB8fn0f2JT09HQYGBlXeOQcAJiYmsLKyUnoRERHRk0nvU2wREREIDg5Gly5d4Ovri7i4OBQVFUl3tY0dOxYuLi6IjY1V2i8hIQEDBw6Era1tle0WFhZi8+bN+OyzzyptS0pKQnJyMnr37g1LS0skJSUhPDwco0ePRuPGjbU/SCIiImpQ9B6Qhg8fjhs3bmD27NnIyclBhw4dsGfPHmnhdlZWFgwMlC90ZWZm4vDhw9i7d2+17W7cuBFCCIwcObLSNhMTE2zcuBFz5sxBSUkJPDw8EB4errQuiYiIiJ5eMiGE0HcnGqLCwkJYW1ujoKCA021EREQNhLqf3/Xiq0aIiIiI6hMGJCIiIiIVDEhEREREKhiQiIiIiFQwIBERERGpYEAiIiIiUsGARERERKSCAYmIiIhIBQMSERERkQoGJCIiIiIVDEhEREREKhiQiIiIiFQwIBERERGpYEAiIiIiUsGARERERKSCAYmIiIhIBQMSERERkQoGJCIiIiIVDEhEREREKhiQiIiIiFQwIBERERGpYEAiIiIiUsGARERERKSCAYmIiIhIBQMSERERkQoGJCIiIiIVDEhEREREKhiQiIiIiFQwIBERERGpYEAiIiIiUsGARERERKSCAYmIiIhIBQMSERERkQoGJCIiIiIVDEhEREREKhiQiIiIiFTUi4C0bNkyuLu7w9TUFH5+fkhJSam2bq9evSCTySq9Xn75ZalOSEhIpe39+vVTaufWrVt4/fXXYWVlBRsbG4SGhuLOnTs6GyMRERE1HHoPSJs2bUJERASio6ORlpYGHx8fBAYG4vr161XW37JlC7Kzs6XXiRMnYGhoiKFDhyrV69evn1K9DRs2KG1//fXXcfLkSezbtw87d+7Er7/+iokTJ+psnERERNRwyIQQQp8d8PPzQ9euXbF06VIAgEKhgKurK6ZOnYrIyMhH7h8XF4fZs2cjOzsbFhYWAB5cQcrPz8e2bduq3CcjIwNeXl74448/0KVLFwDAnj17MGDAAPzzzz9wdnZ+5HELCwthbW2NgoICWFlZqTlaIiIi0id1P7/1egWptLQUqampCAgIkMoMDAwQEBCApKQktdpISEjAiBEjpHBU4eDBg2jatCk8PT3x5ptv4ubNm9K2pKQk2NjYSOEIAAICAmBgYIDk5OQqj1NSUoLCwkKlFxERET2Z9BqQ8vLyUF5eDgcHB6VyBwcH5OTkPHL/lJQUnDhxAhMmTFAq79evH7755hskJibi448/xqFDh9C/f3+Ul5cDAHJyctC0aVOlfYyMjNCkSZNqjxsbGwtra2vp5erqqslQiYiIqAEx0ncHHkdCQgK8vb3h6+urVD5ixAjp797e3mjfvj1atGiBgwcPok+fPrU6VlRUFCIiIqT3hYWFDElERERPKL1eQbKzs4OhoSFyc3OVynNzc+Ho6FjjvkVFRdi4cSNCQ0MfeZzmzZvDzs4O586dAwA4OjpWWgR+//593Lp1q9rjmpiYwMrKSulFRERETya9BiS5XI7OnTsjMTFRKlMoFEhMTIS/v3+N+27evBklJSUYPXr0I4/zzz//4ObNm3BycgIA+Pv7Iz8/H6mpqVKdAwcOQKFQwM/Pr5ajISIioieF3m/zj4iIwMqVK7F27VpkZGTgzTffRFFREcaNGwcAGDt2LKKioirtl5CQgIEDB8LW1lap/M6dO3jvvfdw9OhRXLp0CYmJiXjttdfQsmVLBAYGAgDatm2Lfv36ISwsDCkpKThy5AimTJmCESNGqHUHGxERET3Z9L4Gafjw4bhx4wZmz56NnJwcdOjQAXv27JEWbmdlZcHAQDnHZWZm4vDhw9i7d2+l9gwNDXH8+HGsXbsW+fn5cHZ2xksvvYR58+bBxMREqrdu3TpMmTIFffr0gYGBAYYMGYLPP/9ct4MlIiKiBkHvz0FqqPgcJCIiooanQTwHiYiIiKg+YkAiIiIiUsGARERERKSCAYmIiIhIBQMSERERkQoGJCIiIiIVDEhEREREKhiQiIiIiFQwIBERERGpYEAiIiIiUsGARERERKSCAYmIiIhIBQMSERERkQoGJCIiIiIVDEhEREREKhiQiIiIiFQwIBERERGpYEAiIiIiUsGARERERKSCAYmIiIhIBQMSERERkQoGJCIiIiIVDEhEREREKhiQiIiIiFQwIBERERGpYEAiIiIiUsGARERERKSCAYmIiIhIBQMSERERkQoGJCIiIiIVDEhEREREKhiQiIiIiFQwIBERERGpYEAiIiIiUsGARERERKSCAYmIiIhIRb0ISMuWLYO7uztMTU3h5+eHlJSUauv26tULMpms0uvll18GAJSVlWHGjBnw9vaGhYUFnJ2dMXbsWFy7dk2pHXd390ptfPTRRzodJxERETUMeg9ImzZtQkREBKKjo5GWlgYfHx8EBgbi+vXrVdbfsmULsrOzpdeJEydgaGiIoUOHAgDu3r2LtLQ0zJo1C2lpadiyZQsyMzPx6quvVmpr7ty5Sm1NnTpVp2MlIiKihsFI3x1YtGgRwsLCMG7cOABAfHw8du3ahVWrViEyMrJS/SZNmii937hxI8zNzaWAZG1tjX379inVWbp0KXx9fZGVlYVmzZpJ5ZaWlnB0dNT2kIiIiKiB0+sVpNLSUqSmpiIgIEAqMzAwQEBAAJKSktRqIyEhASNGjICFhUW1dQoKCiCTyWBjY6NU/tFHH8HW1hYdO3bEJ598gvv371fbRklJCQoLC5VeRERE9GTS6xWkvLw8lJeXw8HBQancwcEBp0+ffuT+KSkpOHHiBBISEqqtU1xcjBkzZmDkyJGwsrKSyt9++2106tQJTZo0we+//46oqChkZ2dj0aJFVbYTGxuLmJgYNUdGREREDZnep9geR0JCAry9veHr61vl9rKyMgwbNgxCCKxYsUJpW0REhPT39u3bQy6X44033kBsbCxMTEwqtRUVFaW0T2FhIVxdXbU0EiIiIqpP9DrFZmdnB0NDQ+Tm5iqV5+bmPnJtUFFRETZu3IjQ0NAqt1eEo8uXL2Pfvn1KV4+q4ufnh/v37+PSpUtVbjcxMYGVlZXSi4iIiJ5Meg1IcrkcnTt3RmJiolSmUCiQmJgIf3//GvfdvHkzSkpKMHr06ErbKsLR2bNnsX//ftja2j6yL+np6TAwMEDTpk01HwgRERE9UfQ+xRYREYHg4GB06dIFvr6+iIuLQ1FRkXRX29ixY+Hi4oLY2Fil/RISEjBw4MBK4aesrAz/+c9/kJaWhp07d6K8vBw5OTkAHtwBJ5fLkZSUhOTkZPTu3RuWlpZISkpCeHg4Ro8ejcaNG9fNwImIiKje0ntAGj58OG7cuIHZs2cjJycHHTp0wJ49e6SF21lZWTAwUL7QlZmZicOHD2Pv3r2V2rt69Sp27NgBAOjQoYPStl9++QW9evWCiYkJNm7ciDlz5qCkpAQeHh4IDw9XWmNERERETy+ZEELouxMNUWFhIaytrVFQUMD1SERERA2Eup/fen+SNhEREVF9w4BEREREpIIBiYiIiEgFAxIRERGRCgYkIiIiIhUMSEREREQqGJCIiIiIVDAgEREREalgQCIiIiJSwYBEREREpIIBiYiIiEgFAxIRERGRCgYkIiIiIhUMSEREREQqGJCIiIiIVDAgEREREalgQCIiIiJSwYBERERE9UvZPeDXTx/8qScMSERERFS/nNoBHJgHZPykty4wIBEREVH9cnKr8p96YKS3IxMREREBwJ3rQNIyQHH/wfvziQ/+PLcf+PmDB383MAL8pwCN7OukSwxIREREpF+3c4CjK4DyEkBmAED2oFxRDhxdDggFYGgCtBtSZwGJU2xERESkX07tgTcOAXatH7wX5cp/2rV+sN2pfZ11iQGJiIiI9K9pWyB0b9XbQvc+2F6HGJCIiIiofrj8+4PptIcJBXA5qc67woBERERE9UPGjgd/NvMHQvcDrt2Uy+sQF2kTERFR/eDUEbBvC3SfChgYAuN2A79/ARiZ1nlXGJCIiIiofug2Sfm9gSHw/Dt66Qqn2IiIiIhUMCARERERqWBAIiIiIlLBgERERESkggGJiIiISAUDEhEREZEKBiQiIiIiFQxIRERERCoYkIiIiIhUMCARERERqeBXjdSSEAIAUFhYqOeeEBERkboqPrcrPserw4BUS7dv3wYAuLq66rknREREpKnbt2/D2tq62u0y8agIRVVSKBS4du0aLC0tIZPJtNZuYWEhXF1dceXKFVhZWWmt3YaK50MZz0dlPCfKeD6U8Xwo4/l4cOXo9u3bcHZ2hoFB9SuNeAWplgwMDPDMM8/orH0rK6un9pe3Kjwfyng+KuM5UcbzoYznQ9nTfj5qunJUgYu0iYiIiFQwIBERERGpYECqZ0xMTBAdHQ0TExN9d6Ve4PlQxvNRGc+JMp4PZTwfyng+1MdF2kREREQqeAWJiIiISAUDEhEREZEKBiQiIiIiFQxIRERERCoYkOrAsmXL4O7uDlNTU/j5+SElJaXG+ps3b0abNm1gamoKb29v7N69W2m7EAKzZ8+Gk5MTzMzMEBAQgLNnz+pyCFql7fOxZcsWvPTSS7C1tYVMJkN6eroOe6992jwfZWVlmDFjBry9vWFhYQFnZ2eMHTsW165d0/UwtEbbvx9z5sxBmzZtYGFhgcaNGyMgIADJycm6HIJWaft8PGzSpEmQyWSIi4vTcq91R9vnIyQkBDKZTOnVr18/XQ5Bq3Tx+5GRkYFXX30V1tbWsLCwQNeuXZGVlaWrIdRfgnRq48aNQi6Xi1WrVomTJ0+KsLAwYWNjI3Jzc6usf+TIEWFoaCgWLlwoTp06JWbOnCmMjY3F33//LdX56KOPhLW1tdi2bZs4duyYePXVV4WHh4e4d+9eXQ2r1nRxPr755hsRExMjVq5cKQCIv/76q45G8/i0fT7y8/NFQECA2LRpkzh9+rRISkoSvr6+onPnznU5rFrTxe/HunXrxL59+8T58+fFiRMnRGhoqLCyshLXr1+vq2HVmi7OR4UtW7YIHx8f4ezsLBYvXqzjkWiHLs5HcHCw6Nevn8jOzpZet27dqqshPRZdnI9z586JJk2aiPfee0+kpaWJc+fOie3bt1fb5pOMAUnHfH19xeTJk6X35eXlwtnZWcTGxlZZf9iwYeLll19WKvPz8xNvvPGGEEIIhUIhHB0dxSeffCJtz8/PFyYmJmLDhg06GIF2aft8POzixYsNLiDp8nxUSElJEQDE5cuXtdNpHaqL81FQUCAAiP3792un0zqkq/Pxzz//CBcXF3HixAnh5ubWYAKSLs5HcHCweO2113TSX13TxfkYPny4GD16tG463MBwik2HSktLkZqaioCAAKnMwMAAAQEBSEpKqnKfpKQkpfoAEBgYKNW/ePEicnJylOpYW1vDz8+v2jbrC12cj4asrs5HQUEBZDIZbGxstNJvXamL81FaWoqvvvoK1tbW8PHx0V7ndUBX50OhUGDMmDF477338Oyzz+qm8zqgy9+PgwcPomnTpvD09MSbb76Jmzdvan8AWqaL86FQKLBr1y60bt0agYGBaNq0Kfz8/LBt2zadjaM+Y0DSoby8PJSXl8PBwUGp3MHBATk5OVXuk5OTU2P9ij81abO+0MX5aMjq4nwUFxdjxowZGDlyZL3/Ykpdno+dO3eiUaNGMDU1xeLFi7Fv3z7Y2dlpdwBapqvz8fHHH8PIyAhvv/229jutQ7o6H/369cM333yDxMREfPzxxzh06BD69++P8vJy7Q9Ci3RxPq5fv447d+7go48+Qr9+/bB3714MGjQIgwcPxqFDh3QzkHrMSN8dICLdKCsrw7BhwyCEwIoVK/TdHb3q3bs30tPTkZeXh5UrV2LYsGFITk5G06ZN9d21OpWamoolS5YgLS0NMplM392pF0aMGCH93dvbG+3bt0eLFi1w8OBB9OnTR489q3sKhQIA8NprryE8PBwA0KFDB/z++++Ij49Hz5499dm9OscrSDpkZ2cHQ0ND5ObmKpXn5ubC0dGxyn0cHR1rrF/xpyZt1he6OB8NmS7PR0U4unz5Mvbt21fvrx4Buj0fFhYWaNmyJbp164aEhAQYGRkhISFBuwPQMl2cj99++w3Xr19Hs2bNYGRkBCMjI1y+fBnvvvsu3N3ddTIObamr/340b94cdnZ2OHfu3ON3Wod0cT7s7OxgZGQELy8vpTpt27Z9Ku9iY0DSIblcjs6dOyMxMVEqUygUSExMhL+/f5X7+Pv7K9UHgH379kn1PTw84OjoqFSnsLAQycnJ1bZZX+jifDRkujofFeHo7Nmz2L9/P2xtbXUzAC2ry98PhUKBkpKSx++0DunifIwZMwbHjx9Henq69HJ2dsZ7772Hn3/+WXeD0YK6+v34559/cPPmTTg5OWmn4zqii/Mhl8vRtWtXZGZmKtU5c+YM3NzctDyCBkDfq8SfdBs3bhQmJiZizZo14tSpU2LixInCxsZG5OTkCCGEGDNmjIiMjJTqHzlyRBgZGYlPP/1UZGRkiOjo6Cpv87exsRHbt28Xx48fF6+99lqDus1f2+fj5s2b4q+//hK7du0SAMTGjRvFX3/9JbKzs+t8fJrS9vkoLS0Vr776qnjmmWdEenq60q3LJSUlehmjJrR9Pu7cuSOioqJEUlKSuHTpkvjzzz/FuHHjhImJiThx4oRexqgJXfx7UdWQ7mLT9vm4ffu2mD59ukhKShIXL14U+/fvF506dRKtWrUSxcXFehmjJnTx+7FlyxZhbGwsvvrqK3H27FnxxRdfCENDQ/Hbb7/V+fj0jQGpDnzxxReiWbNmQi6XC19fX3H06FFpW8+ePUVwcLBS/e+//160bt1ayOVy8eyzz4pdu3YpbVcoFGLWrFnCwcFBmJiYiD59+ojMzMy6GIpWaPt8rF69WgCo9IqOjq6D0Tw+bZ6PikcdVPX65Zdf6mhEj0eb5+PevXti0KBBwtnZWcjlcuHk5CReffVVkZKSUlfDeWza/veiqiEFJCG0ez7u3r0rXnrpJWFvby+MjY2Fm5ubCAsLkwJGQ6CL34+EhATRsmVLYWpqKnx8fMS2bdt0PYx6SSaEEPq5dkVERERUP3ENEhEREZEKBiQiIiIiFQxIRERERCoYkIiIiIhUMCARERERqWBAIiIiIlLBgERERESkggGJiBqEXr164Z133tF3N+q9kJAQDBw4UN/dIGrwGJCIqFohISGQyWSVXv369dN316p07949REdHo3Xr1jAxMYGdnR2GDh2KkydP6rtrSnQZYpYsWYI1a9ZI7xksiWrHSN8dIKL6rV+/fli9erVSmYmJiZ56U72SkhIEBAQgKysLn332Gfz8/JCbm4vY2Fj4+flh//796Natm177WF5eDplMptNjWFtb67R9oqcFryARUY1MTEzg6Oio9GrcuLG0/ezZs+jRowdMTU3h5eWFffv2QSaTYdu2bQCAgwcPQiaTIT8/X9onPT0dMpkMly5dAgDcvHkTI0eOhIuLC8zNzeHt7Y0NGzZo1M+4uDgkJSVh586dGDZsGNzc3ODr64sff/wRbdu2RWhoKCq+WaniCk5MTAzs7e1hZWWFSZMmobS0VGqvV69emDJlCqZMmQJra2vY2dlh1qxZePjbmf7991+MHTsWjRs3hrm5Ofr374+zZ89K29esWQMbGxvs2LEDXl5eMDExwfjx47F27Vps375duiJ38OBBtc5TRXs///wz2rZti0aNGqFfv37Izs6W9nn46lRISAgOHTqEJUuWSMe6ePEiWrZsiU8//VTp/FUc69y5cxqdd6InFQMSEdWaQqHA4MGDIZfLkZycjPj4eMyYMUPjdoqLi9G5c2fs2rULJ06cwMSJEzFmzBikpKSo3cb69evRt29f+Pj4KJUbGBggPDwcp06dwrFjx6TyxMREZGRk4ODBg9iwYQO2bNmCmJgYpX3Xrl0LIyMjpKSkYMmSJVi0aBG+/vpraXtISAj+/PNP7NixA0lJSRBCYMCAASgrK5Pq3L17Fx9//DG+/vprnDx5Ep9//jmGDRsmBZvs7Gx0795d7XHevXsXn376Kb799lv8+uuvyMrKwvTp06usu2TJEvj7+yMsLEw6VrNmzTB+/PhKVwVXr16NHj16oGXLlmr3hehJxoBERDXauXMnGjVqpPRasGABAGD//v04ffo0vvnmG/j4+KBHjx7SNk24uLhg+vTp6NChA5o3b46pU6eiX79++P7779Vu48yZM2jbtm2V2yrKz5w5I5XJ5XKsWrUKzz77LF5++WXMnTsXn3/+ORQKhVTH1dUVixcvhqenJ15//XVMnToVixcvBvDgytmOHTvw9ddf44UXXoCPjw/WrVuHq1evSlfPAKCsrAzLly9H9+7d4enpCSsrK5iZmSldmZPL5WqPs6ysDPHx8ejSpQs6deqEKVOmIDExscq61tbWkMvlMDc3l45laGiIkJAQZGZmSgG0rKwM69evx/jx49XuB9GTjmuQiKhGvXv3xooVK5TKmjRpAgDIyMiAq6srnJ2dpW3+/v4aH6O8vBwLFizA999/j6tXr6K0tBQlJSUwNzfXqJ2Hp78excfHR6l9f39/3LlzB1euXIGbmxsAoFu3bkprhvz9/fHZZ5+hvLwcGRkZMDIygp+fn7Td1tYWnp6eyMjIkMrkcjnat2+v0ThqYm5ujhYtWkjvnZyccP36dY3acHZ2xssvv4xVq1bB19cXP/30E0pKSjB06FCt9ZOooWNAIqIaWVhYPNa0i4HBgwvVD4eXh6egAOCTTz7BkiVLEBcXB29vb1hYWOCdd95RWhP0KK1bt1YKJg+rKG/durWm3X9sZmZmai3MVuc8AYCxsbHSe5lMplEwrDBhwgSMGTMGixcvxurVqzF8+HCNAynRk4xTbERUa23btsWVK1eUFgkfPXpUqY69vT0AKNVJT09XqnPkyBG89tprGD16NHx8fNC8eXOl6TB1jBgxAvv371daZwQ8WCe1ePFieHl5Ka1POnbsGO7du6fU70aNGsHV1VUqS05OVmrr6NGjaNWqFQwNDdG2bVvcv39fqc7NmzeRmZkJLy+vGvsql8tRXl6uVKbOeaqNqo4FAAMGDICFhQVWrFiBPXv2cHqNSAUDEhHVqKSkBDk5OUqvvLw8AEBAQABat26N4OBgHDt2DL/99hs++OADpf1btmwJV1dXzJkzB2fPnsWuXbvw2WefKdVp1aoV9u3bh99//x0ZGRl44403kJubq1E/w8PD4evri6CgIGzevBlZWVn4448/MGTIEGRkZCAhIUHpSk5paSlCQ0Nx6tQp7N69G9HR0ZgyZYp0JQcAsrKyEBERgczMTGzYsAFffPEFpk2bJvX5tddeQ1hYGA4fPoxjx45h9OjRcHFxwWuvvVZjX93d3XH8+HFkZmYiLy8PZWVlap2n2nB3d0dycjIuXbqEvLw8aY1VxVqkqKgotGrVqlZTo0RPMgYkIqrRnj174OTkpPR6/vnnATyYFtq6dSvu3bsHX19fTJgwAfPnz1fa39jYGBs2bMDp06fRvn17fPzxx/jwww+V6sycOROdOnVCYGAgevXqBUdHR40fpGhqaooDBw5g7NixeP/999GyZUv069cPhoaGOHr0aKVnIPXp0wetWrVCjx49MHz4cLz66quYM2eOUp2xY8dKY5s8eTKmTZuGiRMnSttXr16Nzp0745VXXoG/vz+EENi9e3elaTBVYWFh8PT0RJcuXWBvb48jR46odZ5qY/r06TA0NISXlxfs7e2RlZUlbQsNDUVpaSnGjRv32MchetLIRG0mr4mIaiCTybB169Z6+5UXISEhyM/PV7rbTFWvXr3QoUMHxMXF1Vm/6tpvv/2GPn364MqVK3BwcNB3d4jqFS7SJiJ6ypSUlODGjRuYM2cOhg4dynBEVAVOsRERPWU2bNgANzc35OfnY+HChfruDlG9xCk2IiIiIhW8gkRERESkggGJiIiISAUDEhEREZEKBiQiIiIiFQxIRERERCoYkIiIiIhUMCARERERqWBAIiIiIlLBgERERESk4v8DYwGLsQjbky0AAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "figure = fpred.plot_frontier(test_dict)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fpred.plot_frontier()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "anonfair",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.8.19"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
